From eb8b2d05b5dfbb042a6f935724cb222122e051da Mon Sep 17 00:00:00 2001 From: Bowen Wang Date: Fri, 21 Jun 2019 11:32:16 -0700 Subject: [PATCH 1/3] Fix some resolver bugs --- dist/asc.js | 2 +- dist/asc.js.map | 2 +- dist/assemblyscript.d.ts | 11197 +++++++++--------- dist/assemblyscript.js | 2 +- dist/assemblyscript.js.map | 2 +- package-lock.json | 41 +- src/resolver.ts | 26 +- tests/compiler/resolve-access.json | 5 + tests/compiler/resolve-access.optimized.wat | 576 + tests/compiler/resolve-access.ts | 25 + tests/compiler/resolve-access.untouched.wat | 2077 ++++ 11 files changed, 8321 insertions(+), 5634 deletions(-) create mode 100644 tests/compiler/resolve-access.json create mode 100644 tests/compiler/resolve-access.optimized.wat create mode 100644 tests/compiler/resolve-access.ts create mode 100644 tests/compiler/resolve-access.untouched.wat diff --git a/dist/asc.js b/dist/asc.js index 6d821af1ac..c7a1642923 100644 --- a/dist/asc.js +++ b/dist/asc.js @@ -1,2 +1,2 @@ -!function(n,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(function(){try{return require("assemblyscript")}catch(n){}}()):"function"==typeof define&&define.amd?define(["assemblyscript"],e):"object"==typeof exports?exports.asc=e(function(){try{return require("assemblyscript")}catch(n){}}()):n.asc=e(n.assemblyscript)}("undefined"!=typeof self?self:this,function(__WEBPACK_EXTERNAL_MODULE__10__){return function(n){var e={};function t(r){if(e[r])return e[r].exports;var i=e[r]={i:r,l:!1,exports:{}};return n[r].call(i.exports,i,i.exports,t),i.l=!0,i.exports}return t.m=n,t.c=e,t.d=function(n,e,r){t.o(n,e)||Object.defineProperty(n,e,{enumerable:!0,get:r})},t.r=function(n){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})},t.t=function(n,e){if(1&e&&(n=t(n)),8&e)return n;if(4&e&&"object"==typeof n&&n&&n.__esModule)return n;var r=Object.create(null);if(t.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:n}),2&e&&"string"!=typeof n)for(var i in n)t.d(r,i,function(e){return n[e]}.bind(null,i));return r},t.n=function(n){var e=n&&n.__esModule?function(){return n.default}:function(){return n};return t.d(e,"a",e),e},t.o=function(n,e){return Object.prototype.hasOwnProperty.call(n,e)},t.p="",t(t.s=4)}([function(n,e,t){var r,i;e.nextTick=function(n){setTimeout(n,0)},e.platform=e.arch=e.execPath=e.title="browser",e.pid=1,e.browser=!0,e.env={},e.argv=[],e.binding=function(n){throw new Error("No such module. (Possibly not yet loaded)")},i="/",e.cwd=function(){return i},e.chdir=function(n){r||(r=t(1)),i=r.resolve(n,i)},e.exit=e.kill=e.umask=e.dlopen=e.uptime=e.memoryUsage=e.uvCounters=function(){},e.features={}},function(n,e,t){(function(n){function t(n,e){for(var t=0,r=n.length-1;r>=0;r--){var i=n[r];"."===i?n.splice(r,1):".."===i?(n.splice(r,1),t++):t&&(n.splice(r,1),t--)}if(e)for(;t--;t)n.unshift("..");return n}var r=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/,i=function(n){return r.exec(n).slice(1)};function o(n,e){if(n.filter)return n.filter(e);for(var t=[],r=0;r=-1&&!r;i--){var a=i>=0?arguments[i]:n.cwd();if("string"!=typeof a)throw new TypeError("Arguments to path.resolve must be strings");a&&(e=a+"/"+e,r="/"===a.charAt(0))}return(r?"/":"")+(e=t(o(e.split("/"),function(n){return!!n}),!r).join("/"))||"."},e.normalize=function(n){var r=e.isAbsolute(n),i="/"===a(n,-1);return(n=t(o(n.split("/"),function(n){return!!n}),!r).join("/"))||r||(n="."),n&&i&&(n+="/"),(r?"/":"")+n},e.isAbsolute=function(n){return"/"===n.charAt(0)},e.join=function(){var n=Array.prototype.slice.call(arguments,0);return e.normalize(o(n,function(n,e){if("string"!=typeof n)throw new TypeError("Arguments to path.join must be strings");return n}).join("/"))},e.relative=function(n,t){function r(n){for(var e=0;e=0&&""===n[t];t--);return e>t?[]:n.slice(e,t-e+1)}n=e.resolve(n).substr(1),t=e.resolve(t).substr(1);for(var i=r(n.split("/")),o=r(t.split("/")),a=Math.min(i.length,o.length),s=a,l=0;l{try{assemblyscript=__webpack_require__(10)}catch(e){try{__webpack_require__(!function(){var n=new Error("Cannot find module 'ts-node'");throw n.code="MODULE_NOT_FOUND",n}()).register({project:path.join(".","..","src","tsconfig.json")}),__webpack_require__(!function(){var n=new Error("Cannot find module '../src/glue/js'");throw n.code="MODULE_NOT_FOUND",n}()),assemblyscript=__webpack_require__(!function(){var n=new Error("Cannot find module '../src'");throw n.code="MODULE_NOT_FOUND",n}()),isDev=!0}catch(e_ts){try{assemblyscript=eval("require('./assemblyscript')")}catch(n){throw n.stack=e_ts.stack+"\n---\n"+n.stack,n}}}})(),exports.isBundle=!0,exports.isDev=isDev,exports.version=exports.isBundle?"0.7.0":__webpack_require__(!function(){var n=new Error("Cannot find module '../package.json'");throw n.code="MODULE_NOT_FOUND",n}()).version,exports.options=__webpack_require__(11),exports.sourceMapRoot="assemblyscript:///",exports.libraryPrefix=assemblyscript.LIBRARY_PREFIX,exports.defaultOptimizeLevel=3,exports.defaultShrinkLevel=1,exports.libraryFiles=exports.isBundle?Object({array:'/// \n\nimport { BLOCK_MAXSIZE } from "./rt/common";\nimport { COMPARATOR, SORT } from "./util/sort";\nimport { ArrayBuffer, ArrayBufferView } from "./arraybuffer";\nimport { itoa, dtoa, itoa_stream, dtoa_stream, MAX_DOUBLE_LENGTH } from "./util/number";\nimport { idof, isArray as builtin_isArray } from "./builtins";\nimport { E_INDEXOUTOFRANGE, E_INVALIDLENGTH, E_EMPTYARRAY, E_HOLEYARRAY } from "./util/error";\n\n/** Ensures that the given array has _at least_ the specified backing size. */\nfunction ensureSize(array: usize, minSize: usize, alignLog2: u32): void {\n var oldCapacity = changetype(array).dataLength;\n if (minSize > oldCapacity >>> alignLog2) {\n if (minSize > BLOCK_MAXSIZE >>> alignLog2) throw new RangeError(E_INVALIDLENGTH);\n let oldData = changetype(changetype(array).data);\n let newCapacity = minSize << alignLog2;\n let newData = __realloc(oldData, newCapacity);\n memory.fill(newData + oldCapacity, 0, newCapacity - oldCapacity);\n if (newData !== oldData) { // oldData has been free\'d\n store(changetype(array), __retain(newData), offsetof("data"));\n changetype(array).dataStart = newData;\n }\n changetype(array).dataLength = newCapacity;\n }\n}\n\nexport class Array extends ArrayBufferView {\n [key: number]: T;\n\n // Implementing ArrayBufferView isn\'t strictly necessary here but is done to allow glue code\n // to work with typed and normal arrays interchangeably. Technically, normal arrays do not need\n // `dataStart` (equals `data`) and `dataLength` (equals computed `data.byteLength`).\n\n // Also note that Array with non-nullable T must guard against implicit null values whenever\n // length is modified in a way that a null value would exist. Otherwise, the compiler wouldn\'t be\n // able to guarantee type-safety anymore. For lack of a better word, such an array is "holey".\n\n private length_: i32;\n\n static isArray(value: U): bool {\n return builtin_isArray(value) && value !== null;\n }\n\n static create(capacity: i32 = 0): Array {\n if (capacity > BLOCK_MAXSIZE >>> alignof()) throw new RangeError(E_INVALIDLENGTH);\n var array = changetype>(__allocArray(capacity, alignof(), idof())); // retains\n changetype>(array).length_ = 0; // safe even if T is a non-nullable reference\n memory.fill(array.dataStart, 0, array.dataLength);\n return array;\n }\n\n constructor(length: i32 = 0) {\n super(length, alignof());\n if (isReference()) {\n if (!isNullable()) {\n if (length) throw new Error(E_HOLEYARRAY);\n }\n }\n this.length_ = length;\n }\n\n @unsafe get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.length_;\n }\n\n set length(newLength: i32) {\n var oldLength = this.length_;\n if (isReference()) {\n if (!isNullable()) {\n if (newLength > oldLength) throw new Error(E_HOLEYARRAY);\n }\n }\n ensureSize(changetype(this), newLength, alignof());\n if (isManaged()) { // release no longer used refs\n if (oldLength > newLength) {\n let dataStart = this.dataStart;\n do __release(load(dataStart + (--oldLength << alignof())));\n while (oldLength > newLength);\n // no need to zero memory on shrink -> is zeroed on grow\n }\n }\n this.length_ = newLength;\n }\n\n every(fn: (value: T, index: i32, array: Array) => bool): bool {\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n if (!fn(load(this.dataStart + (index << alignof())), index, this)) return false;\n }\n return true;\n }\n\n findIndex(predicate: (value: T, index: i32, array: Array) => bool): i32 {\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n if (predicate(load(this.dataStart + (index << alignof())), index, this)) return index;\n }\n return -1;\n }\n\n @operator("[]") private __get(index: i32): T {\n if (isReference()) {\n if (!isNullable()) {\n if (index >= this.length_) throw new Error(E_HOLEYARRAY);\n }\n }\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return this.__unchecked_get(index);\n }\n\n @operator("{}") private __unchecked_get(index: i32): T {\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") private __set(index: i32, value: T): void {\n var length = this.length_;\n if (isReference()) {\n if (!isNullable()) {\n if (index > length) throw new Error(E_HOLEYARRAY);\n }\n }\n ensureSize(changetype(this), index + 1, alignof());\n this.__unchecked_set(index, value);\n if (index >= length) this.length_ = index + 1;\n }\n\n @operator("{}=") private __unchecked_set(index: i32, value: T): void {\n if (isManaged()) {\n let offset = this.dataStart + (index << alignof());\n let oldRef: usize = load(offset);\n if (changetype(value) != oldRef) {\n store(offset, __retain(changetype(value)));\n __release(oldRef);\n }\n } else {\n store(this.dataStart + (index << alignof()), value);\n }\n }\n\n fill(value: T, start: i32 = 0, end: i32 = i32.MAX_VALUE): this {\n var dataStart = this.dataStart;\n var length = this.length_;\n start = start < 0 ? max(length + start, 0) : min(start, length);\n end = end < 0 ? max(length + end, 0) : min(end, length);\n if (isManaged()) {\n for (; start < end; ++start) {\n let oldRef: usize = load(dataStart + (start << alignof()));\n if (changetype(value) != oldRef) {\n store(dataStart + (start << alignof()), __retain(changetype(value)));\n __release(oldRef);\n }\n }\n } else if (sizeof() == 1) {\n if (start < end) {\n memory.fill(\n dataStart + start,\n u8(value),\n (end - start)\n );\n }\n } else {\n for (; start < end; ++start) {\n store(dataStart + (start << alignof()), value);\n }\n }\n return this;\n }\n\n includes(value: T, fromIndex: i32 = 0): bool {\n return this.indexOf(value, fromIndex) >= 0;\n }\n\n indexOf(value: T, fromIndex: i32 = 0): i32 {\n var length = this.length_;\n if (length == 0 || fromIndex >= length) return -1;\n if (fromIndex < 0) fromIndex = max(length + fromIndex, 0);\n var dataStart = this.dataStart;\n while (fromIndex < length) {\n if (load(dataStart + (fromIndex << alignof())) == value) return fromIndex;\n ++fromIndex;\n }\n return -1;\n }\n\n lastIndexOf(value: T, fromIndex: i32 = this.length_): i32 {\n var length = this.length_;\n if (length == 0) return -1;\n if (fromIndex < 0) fromIndex = length + fromIndex;\n else if (fromIndex >= length) fromIndex = length - 1;\n var dataStart = this.dataStart;\n while (fromIndex >= 0) {\n if (load(dataStart + (fromIndex << alignof())) == value) return fromIndex;\n --fromIndex;\n }\n return -1;\n }\n\n push(value: T): i32 {\n var length = this.length_;\n var newLength = length + 1;\n ensureSize(changetype(this), newLength, alignof());\n if (isManaged()) {\n store(this.dataStart + (length << alignof()), __retain(changetype(value)));\n } else {\n store(this.dataStart + (length << alignof()), value);\n }\n this.length_ = newLength;\n return newLength;\n }\n\n concat(other: Array): Array {\n var thisLen = this.length_;\n var otherLen = select(0, other.length_, other === null);\n var outLen = thisLen + otherLen;\n if (outLen > BLOCK_MAXSIZE >>> alignof()) throw new Error(E_INVALIDLENGTH);\n var out = changetype>(__allocArray(outLen, alignof(), idof>())); // retains\n var outStart = out.dataStart;\n var thisSize = thisLen << alignof();\n if (isManaged()) {\n let thisStart = this.dataStart;\n for (let offset: usize = 0; offset < thisSize; offset += sizeof()) {\n let ref = load(thisStart + offset);\n store(outStart + offset, __retain(ref));\n }\n outStart += thisSize;\n let otherStart = other.dataStart;\n let otherSize = otherLen << alignof();\n for (let offset: usize = 0; offset < otherSize; offset += sizeof()) {\n let ref = load(otherStart + offset);\n store(outStart + offset, __retain(ref));\n }\n } else {\n memory.copy(outStart, this.dataStart, thisSize);\n memory.copy(outStart + thisSize, other.dataStart, otherLen << alignof());\n }\n return out;\n }\n\n copyWithin(target: i32, start: i32, end: i32 = i32.MAX_VALUE): this {\n var dataStart = this.dataStart;\n var len = this.length_;\n\n end = min(end, len);\n var to = target < 0 ? max(len + target, 0) : min(target, len);\n var from = start < 0 ? max(len + start, 0) : min(start, len);\n var last = end < 0 ? max(len + end, 0) : min(end, len);\n var count = min(last - from, len - to);\n\n if (isManaged()) {\n if (from < to && to < (from + count)) { // right to left\n from += count - 1;\n to += count - 1;\n while (count) {\n let oldRef: usize = load(dataStart + (to << alignof()));\n let newRef: usize = load(dataStart + (from << alignof()));\n if (newRef != oldRef) {\n store(dataStart + (to << alignof()), __retain(newRef));\n __release(oldRef);\n }\n --from, --to, --count;\n }\n } else { // left to right\n while (count) {\n let oldRef: usize = load(dataStart + (to << alignof()));\n let newRef: usize = load(dataStart + (from << alignof()));\n if (newRef != oldRef) {\n store(dataStart + (to << alignof()), __retain(newRef));\n __release(oldRef);\n }\n ++from, ++to, --count;\n }\n }\n } else {\n memory.copy( // is memmove\n dataStart + (to << alignof()),\n dataStart + (from << alignof()),\n count << alignof()\n );\n }\n return this;\n }\n\n pop(): T {\n var length = this.length_;\n if (length < 1) throw new RangeError(E_EMPTYARRAY);\n var element = load(this.dataStart + ((--length) << alignof()));\n this.length_ = length;\n return element; // no need to retain -> is moved\n }\n\n forEach(fn: (value: T, index: i32, array: Array) => void): void {\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n fn(load(this.dataStart + (index << alignof())), index, this);\n }\n }\n\n map(fn: (value: T, index: i32, array: Array) => U): Array {\n var length = this.length_;\n var out = changetype>(__allocArray(length, alignof(), idof>())); // retains\n var outStart = out.dataStart;\n for (let index = 0; index < min(length, this.length_); ++index) {\n let result = fn(load(this.dataStart + (index << alignof())), index, this); // retains\n if (isManaged()) {\n store(outStart + (index << alignof()), __retain(changetype(result)));\n } else {\n store(outStart + (index << alignof()), result);\n }\n // releases result\n }\n return out;\n }\n\n filter(fn: (value: T, index: i32, array: Array) => bool): Array {\n var result = changetype>(__allocArray(0, alignof(), idof>())); // retains\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n let value = load(this.dataStart + (index << alignof()));\n if (fn(value, index, this)) result.push(value);\n }\n return result;\n }\n\n reduce(\n fn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U,\n initialValue: U\n ): U {\n var accum = initialValue;\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n accum = fn(accum, load(this.dataStart + (index << alignof())), index, this);\n }\n return accum;\n }\n\n reduceRight(\n fn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U,\n initialValue: U\n ): U {\n var accum = initialValue;\n for (let index = this.length_ - 1; index >= 0; --index) {\n accum = fn(accum, load(this.dataStart + (index << alignof())), index, this);\n }\n return accum;\n }\n\n shift(): T {\n var length = this.length_;\n if (length < 1) throw new RangeError(E_EMPTYARRAY);\n var base = this.dataStart;\n var element = load(base);\n var lastIndex = length - 1;\n memory.copy(\n base,\n base + sizeof(),\n lastIndex << alignof()\n );\n store(base + (lastIndex << alignof()),\n // @ts-ignore: cast\n null\n );\n this.length_ = lastIndex;\n return element; // no need to retain -> is moved\n }\n\n some(fn: (value: T, index: i32, array: Array) => bool): bool {\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n if (fn(load(this.dataStart + (index << alignof())), index, this)) return true;\n }\n return false;\n }\n\n unshift(value: T): i32 {\n var newLength = this.length_ + 1;\n ensureSize(changetype(this), newLength, alignof());\n var dataStart = this.dataStart;\n memory.copy(\n dataStart + sizeof(),\n dataStart,\n (newLength - 1) << alignof()\n );\n if (isManaged()) {\n store(dataStart, __retain(changetype(value)));\n } else {\n store(dataStart, value);\n }\n this.length_ = newLength;\n return newLength;\n }\n\n slice(start: i32 = 0, end: i32 = i32.MAX_VALUE): Array {\n var length = this.length_;\n start = start < 0 ? max(start + length, 0) : min(start, length);\n end = end < 0 ? max(end + length, 0) : min(end , length);\n length = max(end - start, 0);\n var slice = changetype>(__allocArray(length, alignof(), idof>())); // retains\n var sliceBase = slice.dataStart;\n var thisBase = this.dataStart + (start << alignof());\n if (isManaged()) {\n let off = 0;\n let end = length << alignof();\n while (off < end) {\n let ref = load(thisBase + off);\n store(sliceBase + off, __retain(ref));\n off += sizeof();\n }\n } else {\n memory.copy(sliceBase, thisBase, length << alignof());\n }\n return slice;\n }\n\n splice(start: i32, deleteCount: i32 = i32.MAX_VALUE): Array {\n var length = this.length_;\n start = start < 0 ? max(length + start, 0) : min(start, length);\n deleteCount = max(min(deleteCount, length - start), 0);\n var result = changetype>(__allocArray(deleteCount, alignof(), idof>())); // retains\n var resultStart = result.dataStart;\n var thisStart = this.dataStart;\n var thisBase = thisStart + (start << alignof());\n if (isManaged()) {\n for (let i = 0; i < deleteCount; ++i) {\n store(resultStart + (i << alignof()),\n load(thisBase + (i << alignof()))\n );\n // no need to retain -> is moved\n }\n } else {\n memory.copy(\n resultStart,\n thisBase,\n deleteCount << alignof()\n );\n }\n var offset = start + deleteCount;\n if (length != offset) {\n memory.copy(\n thisBase,\n thisStart + (offset << alignof()),\n (length - offset) << alignof()\n );\n }\n this.length_ = length - deleteCount;\n return result;\n }\n\n reverse(): Array {\n var length = this.length_;\n if (length) {\n let front = this.dataStart;\n let back = this.dataStart + ((length - 1) << alignof());\n while (front < back) {\n let temp = load(front);\n store(front, load(back));\n store(back, temp);\n front += sizeof();\n back -= sizeof();\n }\n }\n return this;\n }\n\n sort(comparator: (a: T, b: T) => i32 = COMPARATOR()): this {\n var length = this.length_;\n if (length <= 1) return this;\n var base = this.dataStart;\n if (length == 2) {\n let a: T = load(base, sizeof()); // a = arr[1]\n let b: T = load(base); // b = arr[0]\n if (comparator(a, b) < 0) {\n store(base, b, sizeof()); // arr[1] = b;\n store(base, a); // arr[0] = a;\n }\n return this;\n }\n SORT(base, length, comparator);\n return this;\n }\n\n join(separator: string = ","): string {\n if (isBoolean()) return this.join_bool(separator);\n if (isInteger()) return this.join_int(separator);\n if (isFloat()) return this.join_flt(separator);\n if (isString()) return this.join_str(separator);\n if (isArray()) return this.join_arr(separator);\n if (isReference()) return this.join_ref(separator);\n ERROR("unspported element type");\n return unreachable();\n }\n\n private join_bool(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n var dataStart = this.dataStart;\n if (!lastIndex) return select("true", "false", load(dataStart));\n\n var sepLen = separator.length;\n var valueLen = 5; // max possible length of element len("false")\n var estLen = (valueLen + sepLen) * lastIndex + valueLen;\n var result = changetype(__alloc(estLen << 1, idof())); // retains\n var offset = 0;\n var value: bool;\n for (let i = 0; i < lastIndex; ++i) {\n value = load(dataStart + i);\n valueLen = 4 + i32(!value);\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(select("true", "false", value)),\n valueLen << 1\n );\n offset += valueLen;\n if (sepLen) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(separator),\n sepLen << 1\n );\n offset += sepLen;\n }\n }\n value = load(dataStart + lastIndex);\n valueLen = 4 + i32(!value);\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(select("true", "false", value)),\n valueLen << 1\n );\n offset += valueLen;\n\n if (estLen > offset) return result.substring(0, offset);\n return result;\n }\n\n private join_int(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n var dataStart = this.dataStart;\n // @ts-ignore: type\n if (!lastIndex) return changetype(itoa(load(dataStart))); // retains\n\n var sepLen = separator.length;\n const valueLen = (sizeof() <= 4 ? 10 : 20) + i32(isSigned());\n var estLen = (valueLen + sepLen) * lastIndex + valueLen;\n var result = changetype(__alloc(estLen << 1, idof())); // retains\n var offset = 0;\n var value: T;\n for (let i = 0; i < lastIndex; ++i) {\n value = load(dataStart + (i << alignof()));\n // @ts-ignore: type\n offset += itoa_stream(changetype(result), offset, value);\n if (sepLen) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(separator),\n sepLen << 1\n );\n offset += sepLen;\n }\n }\n value = load(dataStart + (lastIndex << alignof()));\n // @ts-ignore: type\n offset += itoa_stream(changetype(result), offset, value);\n if (estLen > offset) return result.substring(0, offset);\n return result;\n }\n\n private join_flt(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n var dataStart = this.dataStart;\n if (!lastIndex) {\n return changetype(dtoa(\n // @ts-ignore: type\n load(dataStart))\n ); // retains\n }\n\n const valueLen = MAX_DOUBLE_LENGTH;\n var sepLen = separator.length;\n var estLen = (valueLen + sepLen) * lastIndex + valueLen;\n var result = changetype(__alloc(estLen << 1, idof())); // retains\n var offset = 0;\n var value: T;\n for (let i = 0; i < lastIndex; ++i) {\n value = load(dataStart + (i << alignof()));\n offset += dtoa_stream(changetype(result), offset,\n // @ts-ignore: type\n value\n );\n if (sepLen) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(separator),\n sepLen << 1\n );\n offset += sepLen;\n }\n }\n value = load(dataStart + (lastIndex << alignof()));\n offset += dtoa_stream(changetype(result), offset,\n // @ts-ignore: type\n value\n );\n if (estLen > offset) return result.substring(0, offset);\n return result;\n }\n\n private join_str(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n var dataStart = this.dataStart;\n if (!lastIndex) return load(dataStart);\n\n var sepLen = separator.length;\n var estLen = 0;\n var value: string | null;\n for (let i = 0, len = lastIndex + 1; i < len; ++i) {\n value = load(dataStart + (i << alignof()));\n if (value !== null) estLen += value.length;\n }\n var offset = 0;\n var result = changetype(__alloc((estLen + sepLen * lastIndex) << 1, idof())); // retains\n for (let i = 0; i < lastIndex; ++i) {\n value = load(dataStart + (i << alignof()));\n if (value !== null) {\n let valueLen = changetype(value).length;\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(value),\n valueLen << 1\n );\n offset += valueLen;\n }\n if (sepLen) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(separator),\n sepLen << 1\n );\n offset += sepLen;\n }\n }\n value = load(dataStart + (lastIndex << alignof()));\n if (value !== null) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(value),\n changetype(value).length << 1\n );\n }\n return result;\n }\n\n private join_arr(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n\n var result = "";\n var sepLen = separator.length;\n var base = this.dataStart;\n var value: T;\n if (!lastIndex) {\n value = load(base);\n // @ts-ignore: type\n return value ? value.join(separator) : "";\n }\n for (let i = 0; i < lastIndex; ++i) {\n value = load(base + (i << alignof()));\n // @ts-ignore: type\n if (value) result += value.join(separator);\n if (sepLen) result += separator;\n }\n value = load(base + (lastIndex << alignof()));\n // @ts-ignore: type\n if (value) result += value.join(separator);\n return result; // registered by concatenation (FIXME: lots of garbage)\n }\n\n private join_ref(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n var base = this.dataStart;\n if (!lastIndex) return "[object Object]";\n\n const valueLen = 15; // max possible length of element len("[object Object]")\n var sepLen = separator.length;\n var estLen = (valueLen + sepLen) * lastIndex + valueLen;\n var result = changetype(__alloc(estLen << 1, idof()));\n var offset = 0;\n var value: T;\n for (let i = 0; i < lastIndex; ++i) {\n value = load(base + (i << alignof()));\n if (value) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype("[object Object]"),\n valueLen << 1\n );\n offset += valueLen;\n }\n if (sepLen) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(separator),\n sepLen << 1\n );\n offset += sepLen;\n }\n }\n if (load(base + (lastIndex << alignof()))) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype("[object Object]"),\n valueLen << 1\n );\n offset += valueLen;\n }\n if (estLen > offset) return result.substring(0, offset);\n return result;\n }\n\n toString(): string {\n return this.join();\n }\n\n // RT integration\n\n @unsafe private __visit_impl(cookie: u32): void {\n if (isManaged()) {\n let cur = this.dataStart;\n let end = cur + (this.length_ << alignof());\n while (cur < end) {\n let val = load(cur);\n if (val) __visit(val, cookie);\n cur += sizeof();\n }\n }\n // automatically visits ArrayBufferView (.data) next\n }\n}\n',arraybuffer:'/// \n\nimport { BLOCK, BLOCK_MAXSIZE, BLOCK_OVERHEAD } from "./rt/common";\nimport { idof } from "./builtins";\nimport { E_INVALIDLENGTH } from "./util/error";\n\nexport abstract class ArrayBufferView {\n\n @unsafe data: ArrayBuffer;\n @unsafe dataStart: usize;\n @unsafe dataLength: u32;\n\n protected constructor(length: i32, alignLog2: i32) {\n if (length > BLOCK_MAXSIZE >>> alignLog2) throw new RangeError(E_INVALIDLENGTH);\n var buffer = __alloc(length = length << alignLog2, idof());\n this.data = changetype(buffer); // retains\n this.dataStart = buffer;\n this.dataLength = length;\n }\n\n get byteOffset(): i32 {\n return (this.dataStart - changetype(this.data));\n }\n\n get byteLength(): i32 {\n return this.dataLength;\n }\n\n get length(): i32 {\n ERROR("missing implementation: subclasses must implement ArrayBufferView#length");\n return unreachable();\n }\n}\n\n@sealed export class ArrayBuffer {\n\n static isView(value: T): bool {\n if (value) {\n if (value instanceof Int8Array) return true;\n if (value instanceof Uint8Array) return true;\n if (value instanceof Uint8ClampedArray) return true;\n if (value instanceof Int16Array) return true;\n if (value instanceof Uint16Array) return true;\n if (value instanceof Int32Array) return true;\n if (value instanceof Uint32Array) return true;\n if (value instanceof Int64Array) return true;\n if (value instanceof Uint64Array) return true;\n if (value instanceof Float32Array) return true;\n if (value instanceof Float64Array) return true;\n if (value instanceof DataView) return true;\n }\n return false;\n }\n\n constructor(length: i32) {\n if (length > BLOCK_MAXSIZE) throw new RangeError(E_INVALIDLENGTH);\n var buffer = __alloc(length, idof());\n memory.fill(buffer, 0, length);\n return changetype(buffer); // retains\n }\n\n get byteLength(): i32 {\n return changetype(changetype(this) - BLOCK_OVERHEAD).rtSize;\n }\n\n slice(begin: i32 = 0, end: i32 = BLOCK_MAXSIZE): ArrayBuffer {\n var length = this.byteLength;\n begin = begin < 0 ? max(length + begin, 0) : min(begin, length);\n end = end < 0 ? max(length + end , 0) : min(end , length);\n var outSize = max(end - begin, 0);\n var out = __alloc(outSize, idof());\n memory.copy(out, changetype(this) + begin, outSize);\n return changetype(out); // retains\n }\n\n toString(): string {\n return "[object ArrayBuffer]";\n }\n}\n',"bindings/Date":"export declare function UTC(\n // NOTE: Using i32 below saves us a f64.convert_s instruction and moves the responsibility for\n // converting the value to the WASM/JS boundary.\n year: i32,\n month: i32,\n day: i32,\n hour: i32,\n minute: i32,\n second: i32,\n millisecond: f64\n): f64;\nexport declare function now(): f64;\n","bindings/Math":"export declare const E: f64;\nexport declare const LN2: f64;\nexport declare const LN10: f64;\nexport declare const LOG2E: f64;\nexport declare const LOG10E: f64;\nexport declare const PI: f64;\nexport declare const SQRT1_2: f64;\nexport declare const SQRT2: f64;\n\nexport declare function abs(x: f64): f64;\nexport declare function acos(x: f64): f64;\nexport declare function acosh(x: f64): f64;\nexport declare function asin(x: f64): f64;\nexport declare function asinh(x: f64): f64;\nexport declare function atan(x: f64): f64;\nexport declare function atan2(y: f64, x: f64): f64;\nexport declare function atanh(x: f64): f64;\nexport declare function cbrt(x: f64): f64;\nexport declare function ceil(x: f64): f64;\nexport declare function clz32(x: f64): f64;\nexport declare function cos(x: f64): f64;\nexport declare function cosh(x: f64): f64;\nexport declare function exp(x: f64): f64;\nexport declare function expm1(x: f64): f64;\nexport declare function floor(x: f64): f64;\nexport declare function fround(x: f64): f32;\nexport declare function hypot(value1: f64, value2: f64): f64; // TODO: rest\nexport declare function imul(a: f64, b: f64): f64;\nexport declare function log(x: f64): f64;\nexport declare function log10(x: f64): f64;\nexport declare function log1p(x: f64): f64;\nexport declare function log2(x: f64): f64;\nexport declare function max(value1: f64, value2: f64): f64; // TODO: rest\nexport declare function min(value1: f64, value2: f64): f64; // TODO: rest\nexport declare function pow(base: f64, exponent: f64): f64;\nexport declare function random(): f64;\nexport declare function round(x: f64): f64;\nexport declare function sign(x: f64): f64;\nexport declare function sin(x: f64): f64;\nexport declare function sinh(x: f64): f64;\nexport declare function sqrt(x: f64): f64;\nexport declare function tan(x: f64): f64;\nexport declare function tanh(x: f64): f64;\nexport declare function trunc(x: f64): f64;\n","bindings/wasi_unstable":"// see: https://wasi.dev\n\n/* tslint:disable:max-line-length */\n\n// helper types to be more explicit\ntype char = u8;\ntype ptr = usize; // all pointers are usize'd\ntype struct = T; // structs are references already in AS\n\n/** Read command-line argument data. */\nexport declare function args_get(\n /** Input: Pointer to a buffer to write the argument pointers. */\n argv: ptr>,\n /** Input: Pointer to a buffer to write the argument string data. */\n argv_buf: ptr\n): errno;\n\n/** Return command-line argument data sizes. */\nexport declare function args_sizes_get(\n /** Output: Number of arguments. */\n argc: ptr,\n /** Output: Size of the argument string data. */\n argv_buf_size: ptr\n): errno;\n\n/** Return the resolution of a clock. */\nexport declare function clock_res_get(\n /** Input: The clock for which to return the resolution. */\n clock: clockid,\n /** Output: The resolution of the clock. */\n resolution: ptr\n): errno;\n\n/** Return the time value of a clock. */\nexport declare function clock_time_get(\n /** Input: Cock for which to return the time. */\n clock: clockid,\n /** Input: Maximum lag (exclusive) that the returned time value may have, compared to its actual value. */\n precision: timestamp,\n /** Output: Time value of the clock. */\n time: ptr\n): errno;\n\n/** Read environment variable data. */\nexport declare function environ_get(\n /** Input: Pointer to a buffer to write the environment variable pointers. */\n environ: ptr,\n /** Input: Pointer to a buffer to write the environment variable string data. */\n environ_buf: usize\n): errno;\n\n/** Return command-line argument data sizes. */\nexport declare function environ_sizes_get(\n /** Output: The number of environment variables. */\n environ_count: ptr,\n /** Output: The size of the environment variable string data. */\n environ_buf_size: ptr\n): errno;\n\n/** Provide file advisory information on a file descriptor. */\nexport declare function fd_advise(\n /** Input: The file descriptor for the file for which to provide file advisory information. */\n fd: fd,\n /** Input: The offset within the file to which the advisory applies. */\n offset: filesize,\n /** Input: The length of the region to which the advisory applies. */\n len: filesize,\n /** Input: The advice. */\n advice: advice\n): errno;\n\n/** Provide file advisory information on a file descriptor. */\nexport declare function fd_allocate(\n /** Input: The file descriptor for the file in which to allocate space. */\n fd: fd,\n /** Input: The offset at which to start the allocation. */\n offset: filesize,\n /** Input: The length of the area that is allocated. */\n len: filesize\n): errno;\n\n/** Close a file descriptor. */\nexport declare function fd_close(\n /** Input: The file descriptor to close. */\n fd: fd\n): errno;\n\n/** Synchronize the data of a file to disk. */\nexport declare function fd_datasync(\n /** Input: The file descriptor of the file to synchronize to disk. */\n fd: fd\n): errno;\n\n/** Get the attributes of a file descriptor. */\nexport declare function fd_fdstat_get(\n /** Input: The file descriptor to inspect. */\n fd: fd,\n /** Input: The buffer where the file descriptor's attributes are stored. */\n buf: struct\n): errno;\n\n/** Adjust the flags associated with a file descriptor. */\nexport declare function fd_fdstat_set_flags(\n /** Input: The file descriptor to operate on. */\n fd: fd,\n /** Input: The desired values of the file descriptor flags. */\n flags: fdflags\n): errno;\n\n/** Adjust the rights associated with a file descriptor. */\nexport declare function fd_fdstat_set_rights(\n /** Input: The file descriptor to operate on. */\n fd: fd,\n /** Input: The desired rights of the file descriptor. */\n fs_rights_base: rights,\n /** Input: The desired rights of the file descriptor. */\n fs_rights_inheriting: rights\n): errno;\n\n/** Return the attributes of an open file. */\nexport declare function fd_filestat_get(\n /** Input: The file descriptor to inspect. */\n fd: fd,\n /** Input: The buffer where the file's attributes are stored. */\n buf: struct\n): errno;\n\n/** Adjust the size of an open file. If this increases the file's size, the extra bytes are filled with zeros. */\nexport declare function fd_filestat_set_size(\n /** Input: A file descriptor for the file to adjust. */\n fd: fd,\n /** Input: The desired file size. */\n size: filesize\n): errno;\n\n/** Adjust the timestamps of an open file or directory. */\nexport declare function fd_filestat_set_times(\n /** Input: The file descriptor to operate on. */\n fd: fd,\n /** Input: The desired values of the data access timestamp. */\n st_atim: timestamp,\n /** Input: The desired values of the data modification timestamp. */\n st_mtim: timestamp,\n /** Input: A bitmask indicating which timestamps to adjust. */\n fstflags: fstflags\n): errno;\n\n/** Read from a file descriptor, without using and updating the file descriptor's offset. */\nexport declare function fd_pread(\n /** Input: The file descriptor from which to read data. */\n fd: fd,\n /** Input: List of scatter/gather vectors in which to store data. */\n iovs: ptr>,\n /** Input: Length of the list of scatter/gather vectors in which to store data. */\n iovs_len: usize,\n /** Input: The offset within the file at which to read. */\n offset: filesize,\n /** Output: The number of bytes read. */\n nread: ptr\n): errno;\n\n/** Return a description of the given preopened file descriptor. */\nexport declare function fd_prestat_get(\n /** Input: The file descriptor about which to retrieve information. */\n fd: fd,\n /** Input: The buffer where the description is stored. */\n buf: struct\n): errno;\n\n/** Return a description of the given preopened file descriptor. */\nexport declare function fd_prestat_dir_name(\n /** Input: The file descriptor about which to retrieve information. */\n fd: fd,\n /** Input: Buffer into which to write the preopened directory name. */\n path: ptr,\n /** Input: Length of the buffer into which to write the preopened directory name. */\n path_len: usize\n): errno;\n\n/** Write to a file descriptor, without using and updating the file descriptor's offset. */\nexport declare function fd_pwrite(\n /** Input: The file descriptor to which to write data. */\n fd: fd,\n /** Input: List of scatter/gather vectors from which to retrieve data. */\n iovs: ptr>,\n /** Input: Length of the list of scatter/gather vectors from which to retrieve data. */\n iovs_len: usize,\n /** Input: The offset within the file at which to write. */\n offset: filesize,\n /** Output: The number of bytes written. */\n nwritten: ptr\n): errno;\n\n/** Read from a file descriptor. */\nexport declare function fd_read(\n /** Input: The file descriptor from which to read data. */\n fd: fd,\n /** Input: List of scatter/gather vectors to which to store data. */\n iovs: ptr>,\n /** Input: Length of the list of scatter/gather vectors to which to store data. */\n iovs_len: usize,\n /** Output: The number of bytes read. */\n nread: ptr\n): errno;\n\n/** Read directory entries from a directory. */\nexport declare function fd_readdir(\n /** Input: Directory from which to read the directory entries. */\n fd: fd,\n /** Input: Buffer where directory entries are stored. */\n buf: ptr>,\n /** Input: Length of the buffer where directory entries are stored. */\n buf_len: usize,\n /** Input: Location within the directory to start reading. */\n cookie: dircookie,\n /** Output: Number of bytes stored in the read buffer. If less than the size of the read buffer, the end of the directory has been reached. */\n buf_used: ptr\n): errno;\n\n/** Atomically replace a file descriptor by renumbering another file descriptor. */\nexport declare function fd_renumber(\n /** Input: The file descriptor to renumber. */\n from: fd,\n /** Input: The file descriptor to overwrite. */\n to: fd\n): errno;\n\n/** Move the offset of a file descriptor. */\nexport declare function fd_seek(\n /** Input: The file descriptor to operate on. */\n fd: fd,\n /** Input: The number of bytes to move. */\n offset: filedelta,\n /** Input: The base from which the offset is relative. */\n whence: whence,\n /** Output: The new offset of the file descriptor, relative to the start of the file. */\n newoffset: ptr\n): errno;\n\n/** Synchronize the data and metadata of a file to disk. */\nexport declare function fd_sync(\n /** Input: The file descriptor of the file containing the data and metadata to synchronize to disk. */\n fd: fd\n): errno;\n\n/** Return the current offset of a file descriptor. */\nexport declare function fd_tell(\n /** Input: The file descriptor to inspect. */\n fd: fd,\n /** Output: The current offset of the file descriptor, relative to the start of the file. */\n newoffset: ptr\n): errno;\n\n/** Write to a file descriptor. */\nexport declare function fd_write(\n /** Input: The file descriptor to which to write data. */\n fd: fd,\n /** Input: List of scatter/gather vectors from which to retrieve data. */\n iovs: ptr>,\n /** Input: List of scatter/gather vectors from which to retrieve data. */\n iovs_len: usize,\n /** Output: The number of bytes written. */\n nwritten: ptr\n): errno;\n\n/* Create a directory. */\nexport declare function path_create_directory(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: The path at which to create the directory. */\n path: ptr,\n /** Input: The path at which to create the directory. */\n path_len: usize\n): errno;\n\n/** Return the attributes of a file or directory. */\nexport declare function path_filestat_get(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: Flags determining the method of how the path is resolved. */\n flags: lookupflags,\n /** Input: The path of the file or directory to inspect. */\n path: ptr,\n /** Input: The path of the file or directory to inspect. */\n path_len: usize,\n /** Input: The buffer where the file's attributes are stored. */\n buf: struct\n): errno;\n\n/** Adjust the timestamps of a file or directory. */\nexport declare function path_filestat_set_times(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: Flags determining the method of how the path is resolved. */\n flags: lookupflags,\n /** Input: The path of the file or directory to operate on. */\n path: ptr,\n /** Input: The path of the file or directory to operate on. */\n path_len: usize,\n /** Input: The desired values of the data access timestamp. */\n st_atim: timestamp,\n /** Input: The desired values of the data modification timestamp. */\n st_mtim: timestamp,\n /** Input: A bitmask indicating which timestamps to adjust. */\n fstflags: fstflags\n): errno;\n\n/** Create a hard link. */\nexport declare function path_link(\n /** Input: The working directory at which the resolution of the old path starts. */\n old_fd: fd,\n /** Input: Flags determining the method of how the path is resolved. */\n old_flags: lookupflags,\n /** Input: The source path from which to link. */\n old_path: ptr,\n /** Input: The source path from which to link. */\n old_path_len: usize,\n /** Input: The working directory at which the resolution of the new path starts. */\n new_fd: fd,\n /** Input: The destination path at which to create the hard link. */\n new_path: ptr,\n /** Input: The length of the destination path at which to create the hard link. */\n new_path_len: usize\n): errno;\n\n/** Open a file or directory. */\nexport declare function path_open(\n /** Input: The working directory at which the resolution of the path starts. */\n dirfd: fd,\n /** Input: Flags determining the method of how the path is resolved. */\n dirflags: lookupflags,\n /** Input: The path of the file or directory to open. */\n path: ptr,\n /** Input: The length of the path of the file or directory to open. */\n path_len: usize,\n /** Input: The method by which to open the file. */\n oflags: oflags,\n /** Input: The initial base rights that apply to operations using the file descriptor itself. */\n fs_rights_base: rights,\n /** Input: The initial inheriting rights that apply to file descriptors derived from it. */\n fs_rights_inheriting: rights,\n /** Input: The initial flags of the file descriptor. */\n fs_flags: fdflags,\n /** Output: The file descriptor of the file that has been opened. */\n fd: ptr\n): errno;\n\n/** Read the contents of a symbolic link. */\nexport declare function path_readlink(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: The path of the symbolic link from which to read. */\n path: ptr,\n /** Input: The length of the path of the symbolic link from which to read. */\n path_len: usize,\n /** Input: The buffer to which to write the contents of the symbolic link. */\n buf: ptr,\n /** Input: The length of the buffer to which to write the contents of the symbolic link. */\n buf_len: usize,\n /** Output: The number of bytes placed in the buffer. */\n buf_used: ptr\n): errno;\n\n/** Remove a directory. */\nexport declare function path_remove_directory(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: The path to a directory to remove. */\n path: ptr,\n /** Input: The length of the path to a directory to remove. */\n path_len: usize\n): errno;\n\n/** Rename a file or directory. */\nexport declare function path_rename(\n /** Input: The working directory at which the resolution of the old path starts. */\n old_fd: fd,\n /** Input: The source path of the file or directory to rename. */\n old_path: ptr,\n /** Input: The length of the source path of the file or directory to rename. */\n old_path_len: usize,\n /** Input: The working directory at which the resolution of the new path starts. */\n new_fd: fd,\n /** Input: The destination path to which to rename the file or directory. */\n new_path: ptr,\n /** Input: The length of the destination path to which to rename the file or directory. */\n new_path_len: usize\n): errno;\n\n/** Create a symbolic link. */\nexport declare function path_symlink(\n /** Input: The contents of the symbolic link. */\n old_path: ptr,\n /** Input: The length of the contents of the symbolic link. */\n old_path_len: usize,\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: The destination path at which to create the symbolic link. */\n new_path: ptr,\n /** Input: The length of the destination path at which to create the symbolic link. */\n new_path_len: usize\n): errno;\n\n/** Unlink a file. */\nexport declare function path_unlink_file(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: The path to a file to unlink. */\n path: ptr,\n /** Input: The length of the path to a file to unlink. */\n path_len: usize\n): errno;\n\n/** Concurrently poll for the occurrence of a set of events. */\nexport declare function poll_oneoff(\n /** Input: The events to which to subscribe. */\n in_: ptr>,\n /** Input: The events that have occurred. */\n out: ptr>,\n /** Input: Both the number of subscriptions and events. */\n nsubscriptions: usize,\n /** Output: The number of events stored. */\n nevents: ptr\n): errno;\n\n/** Terminate the process normally. An exit code of 0 indicates successful termination of the program. The meanings of other values is dependent on the environment. */\nexport declare function proc_exit(\n /** Input: The exit code returned by the process. */\n rval: u32\n): void;\n\n/** Send a signal to the process of the calling thread. */\nexport declare function proc_raise(\n /** Input: The signal condition to trigger. */\n sig: signal\n): errno;\n\n/** Write high-quality random data into a buffer. */\nexport declare function random_get(\n /** Input: The buffer to fill with random data. */\n buf: usize,\n /** Input: The length of the buffer to fill with random data. */\n buf_len: usize\n): errno;\n\n/** Temporarily yield execution of the calling thread. */\nexport declare function sched_yield(): errno;\n\n/** Receive a message from a socket. */\nexport declare function sock_recv(\n /** Input: The socket on which to receive data. */\n sock: fd,\n /** Input: List of scatter/gather vectors to which to store data. */\n ri_data: ptr>,\n /** Input: The length of the list of scatter/gather vectors to which to store data. */\n ri_data_len: usize,\n /** Input: Message flags. */\n ri_flags: riflags,\n /** Output: Number of bytes stored in `ri_data`. */\n ro_datalen: ptr,\n /** Output: Message flags. */\n ro_flags: ptr\n): errno;\n\n/** Send a message on a socket. */\nexport declare function sock_send(\n /** Input: The socket on which to send data. */\n sock: fd,\n /** Input: List of scatter/gather vectors to which to retrieve data */\n si_data: ptr>,\n /** Input: The length of the list of scatter/gather vectors to which to retrieve data */\n si_data_len: usize,\n /** Input: Message flags. */\n si_flags: siflags,\n /** Output: Number of bytes transmitted. */\n so_datalen: ptr\n): errno;\n\n/** Shut down socket send and receive channels. */\nexport declare function sock_shutdown(\n /** Input: The socket on which to shutdown channels. */\n sock: fd,\n /** Input: Which channels on the socket to shut down. */\n how: sdflags\n): errno;\n\n// === Types ======================================================================================\n\n/** File or memory access pattern advisory information. */\nexport namespace advice {\n /** The application has no advice to give on its behavior with respect to the specified data. */\n // @ts-ignore: decorator\n @inline\n export const NORMAL: advice = 0;\n /** The application expects to access the specified data sequentially from lower offsets to higher offsets. */\n // @ts-ignore: decorator\n @inline\n export const SEQUENTIAL : advice = 1;\n /** The application expects to access the specified data in a random order. */\n // @ts-ignore: decorator\n @inline\n export const RANDOM: advice = 2;\n /** The application expects to access the specified data in the near future. */\n // @ts-ignore: decorator\n @inline\n export const WILLNEED: advice = 3;\n /** The application expects that it will not access the specified data in the near future. */\n // @ts-ignore: decorator\n @inline\n export const DONTNEED: advice = 4;\n /** The application expects to access the specified data once and then not reuse it thereafter. */\n // @ts-ignore: decorator\n @inline\n export const NOREUSE: advice = 5;\n}\nexport type advice = u8;\n\n/** Identifiers for clocks. */\nexport namespace clockid {\n /** The clock measuring real time. Time value zero corresponds with 1970-01-01T00:00:00Z. */\n // @ts-ignore: decorator\n @inline\n export const REALTIME: clockid = 0;\n /** The store-wide monotonic clock. Absolute value has no meaning. */\n // @ts-ignore: decorator\n @inline\n export const MONOTONIC: clockid = 1;\n /** The CPU-time clock associated with the current process. */\n // @ts-ignore: decorator\n @inline\n export const PROCESS_CPUTIME_ID: clockid = 2;\n /** The CPU-time clock associated with the current thread. */\n // @ts-ignore: decorator\n @inline\n export const THREAD_CPUTIME_ID: clockid = 3;\n}\nexport type clockid = u32;\n\n/** Identifier for a device containing a file system. Can be used in combination with `inode` to uniquely identify a file or directory in the filesystem. */\nexport type device = u64;\n\n/** A reference to the offset of a directory entry. */\nexport type dircookie = u64;\n\n/** A directory entry. */\n@unmanaged export class dirent {\n /** The offset of the next directory entry stored in this directory. */\n next: dircookie;\n /** The serial number of the file referred to by this directory entry. */\n ino: inode;\n /** The length of the name of the directory entry. */\n namlen: u32;\n /** The type of the file referred to by this directory entry. */\n type: filetype;\n private __padding0: u16;\n}\n\n/** Error codes returned by functions. */\nexport namespace errno {\n /** No error occurred. System call completed successfully. */\n // @ts-ignore: decorator\n @inline\n export const SUCCESS: errno = 0;\n /** Argument list too long. */\n // @ts-ignore: decorator\n @inline\n export const TOOBIG: errno = 1;\n /** Permission denied. */\n // @ts-ignore: decorator\n @inline\n export const ACCES: errno = 2;\n /** Address in use. */\n // @ts-ignore: decorator\n @inline\n export const ADDRINUSE: errno = 3;\n /** Address not available. */\n // @ts-ignore: decorator\n @inline\n export const ADDRNOTAVAIL: errno = 4;\n /** Address family not supported. */\n // @ts-ignore: decorator\n @inline\n export const AFNOSUPPORT: errno = 5;\n /** Resource unavailable, or operation would block. */\n // @ts-ignore: decorator\n @inline\n export const AGAIN: errno = 6;\n /** Connection already in progress. */\n // @ts-ignore: decorator\n @inline\n export const ALREADY: errno = 7;\n /** Bad file descriptor. */\n // @ts-ignore: decorator\n @inline\n export const BADF: errno = 8;\n /** Bad message. */\n // @ts-ignore: decorator\n @inline\n export const BADMSG: errno = 9;\n /** Device or resource busy. */\n // @ts-ignore: decorator\n @inline\n export const BUSY: errno = 10;\n /** Operation canceled. */\n // @ts-ignore: decorator\n @inline\n export const CANCELED: errno = 11;\n /** No child processes. */\n // @ts-ignore: decorator\n @inline\n export const CHILD: errno = 12;\n /** Connection aborted. */\n // @ts-ignore: decorator\n @inline\n export const CONNABORTED: errno = 13;\n /** Connection refused. */\n // @ts-ignore: decorator\n @inline\n export const CONNREFUSED: errno = 14;\n /** Connection reset. */\n // @ts-ignore: decorator\n @inline\n export const CONNRESET: errno = 15;\n /** Resource deadlock would occur. */\n // @ts-ignore: decorator\n @inline\n export const DEADLK: errno = 16;\n /** Destination address required. */\n // @ts-ignore: decorator\n @inline\n export const DESTADDRREQ: errno = 17;\n /** Mathematics argument out of domain of function. */\n // @ts-ignore: decorator\n @inline\n export const DOM: errno = 18;\n /** Reserved. */\n // @ts-ignore: decorator\n @inline\n export const DQUOT: errno = 19;\n /** File exists. */\n // @ts-ignore: decorator\n @inline\n export const EXIST: errno = 20;\n /** Bad address. */\n // @ts-ignore: decorator\n @inline\n export const FAULT: errno = 21;\n /** File too large. */\n // @ts-ignore: decorator\n @inline\n export const FBIG: errno = 22;\n /** Host is unreachable. */\n // @ts-ignore: decorator\n @inline\n export const HOSTUNREACH: errno = 23;\n /** Identifier removed. */\n // @ts-ignore: decorator\n @inline\n export const IDRM: errno = 24;\n /** Illegal byte sequence. */\n // @ts-ignore: decorator\n @inline\n export const ILSEQ: errno = 25;\n /** Operation in progress. */\n // @ts-ignore: decorator\n @inline\n export const INPROGRESS: errno = 26;\n /** Interrupted function. */\n // @ts-ignore: decorator\n @inline\n export const INTR: errno = 27;\n /** Invalid argument. */\n // @ts-ignore: decorator\n @inline\n export const INVAL: errno = 28;\n /** I/O error. */\n // @ts-ignore: decorator\n @inline\n export const IO: errno = 29;\n /** Socket is connected. */\n // @ts-ignore: decorator\n @inline\n export const ISCONN: errno = 30;\n /** Is a directory. */\n // @ts-ignore: decorator\n @inline\n export const ISDIR: errno = 31;\n /** Too many levels of symbolic links. */\n // @ts-ignore: decorator\n @inline\n export const LOOP: errno = 32;\n /** File descriptor value too large. */\n // @ts-ignore: decorator\n @inline\n export const MFILE: errno = 33;\n /** Too many links. */\n // @ts-ignore: decorator\n @inline\n export const MLINK: errno = 34;\n /** Message too large. */\n // @ts-ignore: decorator\n @inline\n export const MSGSIZE: errno = 35;\n /** Reserved. */\n // @ts-ignore: decorator\n @inline\n export const MULTIHOP: errno = 36;\n /** Filename too long. */\n // @ts-ignore: decorator\n @inline\n export const NAMETOOLONG: errno = 37;\n /** Network is down. */\n // @ts-ignore: decorator\n @inline\n export const NETDOWN: errno = 38;\n /** Connection aborted by network. */\n // @ts-ignore: decorator\n @inline\n export const NETRESET: errno = 39;\n /** Network unreachable. */\n // @ts-ignore: decorator\n @inline\n export const NETUNREACH: errno = 40;\n /** Too many files open in system. */\n // @ts-ignore: decorator\n @inline\n export const NFILE: errno = 41;\n /** No buffer space available. */\n // @ts-ignore: decorator\n @inline\n export const NOBUFS: errno = 42;\n /** No such device. */\n // @ts-ignore: decorator\n @inline\n export const NODEV: errno = 43;\n /** No such file or directory. */\n // @ts-ignore: decorator\n @inline\n export const NOENT: errno = 44;\n /** Executable file format error. */\n // @ts-ignore: decorator\n @inline\n export const NOEXEC: errno = 45;\n /** No locks available. */\n // @ts-ignore: decorator\n @inline\n export const NOLCK: errno = 46;\n /** Reserved. */\n // @ts-ignore: decorator\n @inline\n export const NOLINK: errno = 47;\n /** Not enough space. */\n // @ts-ignore: decorator\n @inline\n export const NOMEM: errno = 48;\n /** No message of the desired type. */\n // @ts-ignore: decorator\n @inline\n export const NOMSG: errno = 49;\n /** Protocol not available. */\n // @ts-ignore: decorator\n @inline\n export const NOPROTOOPT: errno = 50;\n /** No space left on device. */\n // @ts-ignore: decorator\n @inline\n export const NOSPC: errno = 51;\n /** Function not supported. */\n // @ts-ignore: decorator\n @inline\n export const NOSYS: errno = 52;\n /** The socket is not connected. */\n // @ts-ignore: decorator\n @inline\n export const NOTCONN: errno = 53;\n /** Not a directory or a symbolic link to a directory. */\n // @ts-ignore: decorator\n @inline\n export const NOTDIR: errno = 54;\n /** Directory not empty. */\n // @ts-ignore: decorator\n @inline\n export const NOTEMPTY: errno = 55;\n /** State not recoverable. */\n // @ts-ignore: decorator\n @inline\n export const NOTRECOVERABLE: errno = 56;\n /** Not a socket. */\n // @ts-ignore: decorator\n @inline\n export const NOTSOCK: errno = 57;\n /** Not supported, or operation not supported on socket. */\n // @ts-ignore: decorator\n @inline\n export const NOTSUP: errno = 58;\n /** Inappropriate I/O control operation. */\n // @ts-ignore: decorator\n @inline\n export const NOTTY: errno = 59;\n /** No such device or address. */\n // @ts-ignore: decorator\n @inline\n export const NXIO: errno = 60;\n /** Value too large to be stored in data type. */\n // @ts-ignore: decorator\n @inline\n export const OVERFLOW: errno = 61;\n /** Previous owner died. */\n // @ts-ignore: decorator\n @inline\n export const OWNERDEAD: errno = 62;\n /** Operation not permitted. */\n // @ts-ignore: decorator\n @inline\n export const PERM: errno = 63;\n /** Broken pipe. */\n // @ts-ignore: decorator\n @inline\n export const PIPE: errno = 64;\n /** Protocol error. */\n // @ts-ignore: decorator\n @inline\n export const PROTO: errno = 65;\n /** Protocol not supported. */\n // @ts-ignore: decorator\n @inline\n export const PROTONOSUPPORT: errno = 66;\n /** Protocol wrong type for socket. */\n // @ts-ignore: decorator\n @inline\n export const PROTOTYPE: errno = 67;\n /** Result too large. */\n // @ts-ignore: decorator\n @inline\n export const RANGE: errno = 68;\n /** Read-only file system. */\n // @ts-ignore: decorator\n @inline\n export const ROFS: errno = 69;\n /** Invalid seek. */\n // @ts-ignore: decorator\n @inline\n export const SPIPE: errno = 70;\n /** No such process. */\n // @ts-ignore: decorator\n @inline\n export const SRCH: errno = 71;\n /** Reserved. */\n // @ts-ignore: decorator\n @inline\n export const STALE: errno = 72;\n /** Connection timed out. */\n // @ts-ignore: decorator\n @inline\n export const TIMEDOUT: errno = 73;\n /** Text file busy. */\n // @ts-ignore: decorator\n @inline\n export const TXTBSY: errno = 74;\n /** Cross-device link. */\n // @ts-ignore: decorator\n @inline\n export const XDEV: errno = 75;\n /** Extension: Capabilities insufficient. */\n // @ts-ignore: decorator\n @inline\n export const NOTCAPABLE: errno = 76;\n}\nexport type errno = u16;\n\n/** An event that occurred. */\n@unmanaged export abstract class event {\n /** User-provided value that got attached to `subscription#userdata`. */\n userdata: userdata;\n /** If non-zero, an error that occurred while processing the subscription request. */\n error: errno;\n /* The type of the event that occurred. */\n type: eventtype;\n private __padding0: u16;\n}\n\n/** An event that occurred when type is `eventtype.FD_READ` or `eventtype.FD_WRITE`. */\n@unmanaged export class rwevent extends event {\n /* The number of bytes available for reading or writing. */\n nbytes: filesize;\n /* The state of the file descriptor. */\n flags: eventrwflags;\n private __padding1: u32;\n}\n\n/** The state of the file descriptor subscribed to with `eventtype.FD_READ` or `eventtype.FD_WRITE`. */\nexport namespace eventrwflags {\n /** The peer of this socket has closed or disconnected. */\n // @ts-ignore: decorator\n @inline\n export const HANGUP: eventrwflags = 1;\n}\nexport type eventrwflags = u16;\n\n/** Type of a subscription to an event or its occurrence. */\nexport namespace eventtype {\n /** The time value of clock has reached the timestamp. */\n // @ts-ignore: decorator\n @inline\n export const CLOCK: eventtype = 0;\n /** File descriptor has data available for reading. */\n // @ts-ignore: decorator\n @inline\n export const FD_READ: eventtype = 1;\n /** File descriptor has capacity available for writing */\n // @ts-ignore: decorator\n @inline\n export const FD_WRITE: eventtype = 2;\n}\nexport type eventtype = u8;\n\n/** Exit code generated by a process when exiting. */\nexport type exitcode = u32;\n\n/** A file descriptor number. */\nexport type fd = u32;\n\n/** File descriptor flags. */\nexport namespace fdflags {\n /** Append mode: Data written to the file is always appended to the file's end. */\n // @ts-ignore: decorator\n @inline\n export const APPEND: fdflags = 1;\n /** Write according to synchronized I/O data integrity completion. Only the data stored in the file is synchronized. */\n // @ts-ignore: decorator\n @inline\n export const DSYNC: fdflags = 2;\n /** Non-blocking mode. */\n // @ts-ignore: decorator\n @inline\n export const NONBLOCK: fdflags = 4;\n /** Synchronized read I/O operations. */\n // @ts-ignore: decorator\n @inline\n export const RSYNC: fdflags = 8;\n /** Write according to synchronized I/O file integrity completion. */\n // @ts-ignore: decorator\n @inline\n export const SYNC: fdflags = 16;\n}\nexport type fdflags = u16;\n\n/** File descriptor attributes. */\n@unmanaged export class fdstat {\n /** File type. */\n filetype: filetype;\n /** File descriptor flags. */\n flags: fdflags;\n /** Rights that apply to this file descriptor. */\n rights_base: rights;\n /** Maximum set of rights that may be installed on new file descriptors that are created through this file descriptor, e.g., through `path_open`. */\n rights_inheriting: rights;\n}\n\n/** Relative offset within a file. */\nexport type filedelta = i64;\n\n/** Non-negative file size or length of a region within a file. */\nexport type filesize = u64;\n\n/** File attributes. */\n@unmanaged export class filestat {\n /** Device ID of device containing the file. */\n dev: device;\n /** File serial number. */\n ino: inode;\n /** File type. */\n filetype: filetype;\n /** Number of hard links to the file. */\n nlink: linkcount;\n /** For regular files, the file size in bytes. For symbolic links, the length in bytes of the pathname contained in the symbolic link. */\n size: filesize;\n /** Last data access timestamp. */\n atim: timestamp;\n /** Last data modification timestamp. */\n mtim: timestamp;\n /** Last file status change timestamp. */\n ctim: timestamp;\n}\n\n/** The type of a file descriptor or file. */\nexport namespace filetype {\n /** The type of the file descriptor or file is unknown or is different from any of the other types specified. */\n // @ts-ignore: decorator\n @inline\n export const UNKNOWN: filetype = 0;\n /** The file descriptor or file refers to a block device inode. */\n // @ts-ignore: decorator\n @inline\n export const BLOCK_DEVICE: filetype = 1;\n /** The file descriptor or file refers to a character device inode. */\n // @ts-ignore: decorator\n @inline\n export const CHARACTER_DEVICE: filetype = 2;\n /** The file descriptor or file refers to a directory inode. */\n // @ts-ignore: decorator\n @inline\n export const DIRECTORY: filetype = 3;\n /** The file descriptor or file refers to a regular file inode. */\n // @ts-ignore: decorator\n @inline\n export const REGULAR_FILE: filetype = 4;\n /** The file descriptor or file refers to a datagram socket. */\n // @ts-ignore: decorator\n @inline\n export const SOCKET_DGRAM: filetype = 5;\n /** The file descriptor or file refers to a byte-stream socket. */\n // @ts-ignore: decorator\n @inline\n export const SOCKET_STREAM: filetype = 6;\n /** The file refers to a symbolic link inode. */\n // @ts-ignore: decorator\n @inline\n export const SYMBOLIC_LINK: filetype = 7;\n}\nexport type filetype = u8;\n\n/** Which file time attributes to adjust. */\nexport namespace fstflags {\n /** Adjust the last data access timestamp to the value stored in `filestat#st_atim`. */\n // @ts-ignore: decorator\n @inline\n export const SET_ATIM: fstflags = 1;\n /** Adjust the last data access timestamp to the time of clock `clockid.REALTIME`. */\n // @ts-ignore: decorator\n @inline\n export const SET_ATIM_NOW: fstflags = 2;\n /** Adjust the last data modification timestamp to the value stored in `filestat#st_mtim`. */\n // @ts-ignore: decorator\n @inline\n export const SET_MTIM: fstflags = 4;\n /** Adjust the last data modification timestamp to the time of clock `clockid.REALTIME`. */\n // @ts-ignore: decorator\n @inline\n export const SET_MTIM_NOW: fstflags = 8;\n}\nexport type fstflags = u16;\n\n/** File serial number that is unique within its file system. */\nexport type inode = u64;\n\n/** A region of memory for scatter/gather reads. */\n@unmanaged export class iovec {\n /** The address of the buffer to be filled. */\n buf: usize;\n /** The length of the buffer to be filled. */\n buf_len: usize;\n}\n\n/** Number of hard links to an inode. */\nexport type linkcount = u32;\n\n/** Flags determining the method of how paths are resolved. */\nexport namespace lookupflags {\n /** As long as the resolved path corresponds to a symbolic link, it is expanded. */\n // @ts-ignore: decorator\n @inline\n export const SYMLINK_FOLLOW: lookupflags = 1;\n}\nexport type lookupflags = u32;\n\n/** Open flags. */\nexport namespace oflags {\n /** Create file if it does not exist. */\n // @ts-ignore: decorator\n @inline\n export const CREAT: oflags = 1;\n /** Fail if not a directory. */\n // @ts-ignore: decorator\n @inline\n export const DIRECTORY: oflags = 2;\n /** Fail if file already exists. */\n // @ts-ignore: decorator\n @inline\n export const EXCL: oflags = 4;\n /** Truncate file to size 0. */\n // @ts-ignore: decorator\n @inline\n export const TRUNC: oflags = 8;\n}\nexport type oflags = u16;\n\n// TODO: undocumented\nexport namespace preopentype {\n // @ts-ignore: decorator\n @inline\n export const DIR: preopentype = 0;\n}\nexport type preopentype = u8;\n\n// TODO: undocumented\nexport abstract class prestat {\n type: preopentype;\n}\n\n// TODO: undocumented\nexport class dirprestat extends prestat {\n name_len: usize;\n}\n\n/** Flags provided to `sock_recv`. */\nexport namespace riflags {\n /** Returns the message without removing it from the socket's receive queue. */\n // @ts-ignore: decorator\n @inline\n export const PEEK: riflags = 1;\n /** On byte-stream sockets, block until the full amount of data can be returned. */\n // @ts-ignore: decorator\n @inline\n export const WAITALL: riflags = 2;\n}\nexport type riflags = u16;\n\n/** File descriptor rights, determining which actions may be performed. */\nexport namespace rights {\n /** The right to invoke `fd_datasync`. */\n // @ts-ignore: decorator\n @inline\n export const FD_DATASYNC: rights = 1;\n /** The right to invoke `fd_read` and `sock_recv`. */\n // @ts-ignore: decorator\n @inline\n export const FD_READ: rights = 2;\n /** The right to invoke `fd_seek`. This flag implies `rights.FD_TELL`. */\n // @ts-ignore: decorator\n @inline\n export const FD_SEEK: rights = 4;\n /** The right to invoke `fd_fdstat_set_flags`. */\n // @ts-ignore: decorator\n @inline\n export const FD_FDSTAT_SET_FLAGS: rights = 8;\n /** The right to invoke `fd_sync`. */\n // @ts-ignore: decorator\n @inline\n export const FD_SYNC: rights = 16;\n /** The right to invoke `fd_seek` in such a way that the file offset remains unaltered (i.e., `whence.CUR` with offset zero), or to invoke `fd_tell`). */\n // @ts-ignore: decorator\n @inline\n export const FD_TELL: rights = 32;\n /** The right to invoke `fd_write` and `sock_send`. If `rights.FD_SEEK` is set, includes the right to invoke `fd_pwrite`. */\n // @ts-ignore: decorator\n @inline\n export const FD_WRITE: rights = 64;\n /** The right to invoke `fd_advise`. */\n // @ts-ignore: decorator\n @inline\n export const FD_ADVISE: rights = 128;\n /** The right to invoke `fd_allocate`. */\n // @ts-ignore: decorator\n @inline\n export const FD_ALLOCATE: rights = 256;\n /** The right to invoke `path_create_directory`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_CREATE_DIRECTORY: rights = 512;\n /** If `rights.PATH_OPEN` is set, the right to invoke `path_open` with `oflags.CREAT`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_CREATE_FILE: rights = 1024;\n /** The right to invoke `path_link` with the file descriptor as the source directory. */\n // @ts-ignore: decorator\n @inline\n export const PATH_LINK_SOURCE: rights = 2048;\n /** The right to invoke `path_link` with the file descriptor as the target directory. */\n // @ts-ignore: decorator\n @inline\n export const PATH_LINK_TARGET: rights = 4096;\n /** The right to invoke `path_open`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_OPEN: rights = 8192;\n /** The right to invoke `fd_readdir`. */\n // @ts-ignore: decorator\n @inline\n export const FD_READDIR: rights = 16384;\n /** The right to invoke `path_readlink`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_READLINK: rights = 32768;\n /** The right to invoke `path_rename` with the file descriptor as the source directory. */\n // @ts-ignore: decorator\n @inline\n export const PATH_RENAME_SOURCE: rights = 65536;\n /** The right to invoke `path_rename` with the file descriptor as the target directory. */\n // @ts-ignore: decorator\n @inline\n export const PATH_RENAME_TARGET: rights = 131072;\n /** The right to invoke `path_filestat_get`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_FILESTAT_GET: rights = 262144;\n /** The right to change a file's size (there is no `path_filestat_set_size`). If `rights.PATH_OPEN` is set, includes the right to invoke `path_open` with `oflags.TRUNC`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_FILESTAT_SET_SIZE: rights = 524288;\n /** The right to invoke `path_filestat_set_times`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_FILESTAT_SET_TIMES: rights = 1048576;\n /** The right to invoke `fd_filestat_get`. */\n // @ts-ignore: decorator\n @inline\n export const FD_FILESTAT_GET: rights = 2097152;\n /** The right to invoke `fd_filestat_set_size`. */\n // @ts-ignore: decorator\n @inline\n export const FD_FILESTAT_SET_SIZE: rights = 4194304;\n /** The right to invoke `fd_filestat_set_times`. */\n // @ts-ignore: decorator\n @inline\n export const FD_FILESTAT_SET_TIMES: rights = 8388608;\n /** The right to invoke `path_symlink`. */\n // @ts-ignore: decorator\n @inline\n export const RIGHT_PATH_SYMLINK: rights = 16777216;\n /** The right to invoke `path_remove_directory`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_REMOVE_DIRECTORY: rights = 33554432;\n /** The right to invoke `path_unlink_file`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_UNLINK_FILE: rights = 67108864;\n /** If `rights.FD_READ` is set, includes the right to invoke `poll_oneoff` to subscribe to `eventtype.FD_READ`. If `rights.FD_WRITE` is set, includes the right to invoke `poll_oneoff` to subscribe to `eventtype.FD_WRITE`. */\n // @ts-ignore: decorator\n @inline\n export const POLL_FD_READWRITE: rights = 134217728;\n /** The right to invoke `sock_shutdown`. */\n // @ts-ignore: decorator\n @inline\n export const SOCK_SHUTDOWN: rights = 268435456;\n}\nexport type rights = u64;\n\n/** Flags returned by `sock_recv`. */\nexport namespace roflags {\n /** Message data has been truncated. */\n // @ts-ignore: decorator\n @inline\n export const DATA_TRUNCATED: roflags = 1;\n}\nexport type roflags = u16;\n\n/** Which channels on a socket to shut down. */\nexport namespace sdflags {\n /** Disables further receive operations. */\n // @ts-ignore: decorator\n @inline\n export const RD: sdflags = 1;\n /** Disables further send operations. */\n // @ts-ignore: decorator\n @inline\n export const WR: sdflags = 2;\n}\nexport type sdflags = u8;\n\n/** Flags provided to `sock_send`. */\nexport namespace siflags {\n // As there are currently no flags defined, it must be set to zero.\n}\nexport type siflags = u16;\n\n/** Signal condition. */\nexport namespace signal {\n /** Hangup. */\n // @ts-ignore: decorator\n @inline\n export const HUP: signal = 1;\n /** Terminate interrupt signal. */\n // @ts-ignore: decorator\n @inline\n export const INT: signal = 2;\n /** Terminal quit signal. */\n // @ts-ignore: decorator\n @inline\n export const QUIT: signal = 3;\n /** Illegal instruction. */\n // @ts-ignore: decorator\n @inline\n export const ILL: signal = 4;\n /** Trace/breakpoint trap. */\n // @ts-ignore: decorator\n @inline\n export const TRAP: signal = 5;\n /** Process abort signal. */\n // @ts-ignore: decorator\n @inline\n export const ABRT: signal = 6;\n /** Access to an undefined portion of a memory object. */\n // @ts-ignore: decorator\n @inline\n export const BUS: signal = 7;\n /** Erroneous arithmetic operation. */\n // @ts-ignore: decorator\n @inline\n export const FPE: signal = 8;\n /** Kill. */\n // @ts-ignore: decorator\n @inline\n export const KILL: signal = 9;\n /** User-defined signal 1. */\n // @ts-ignore: decorator\n @inline\n export const USR1: signal = 10;\n /** Invalid memory reference. */\n // @ts-ignore: decorator\n @inline\n export const SEGV: signal = 11;\n /** User-defined signal 2. */\n // @ts-ignore: decorator\n @inline\n export const USR2: signal = 12;\n /** Write on a pipe with no one to read it. */\n // @ts-ignore: decorator\n @inline\n export const PIPE: signal = 13;\n /** Alarm clock. */\n // @ts-ignore: decorator\n @inline\n export const ALRM: signal = 14;\n /** Termination signal. */\n // @ts-ignore: decorator\n @inline\n export const TERM: signal = 15;\n /** Child process terminated, stopped, or continued. */\n // @ts-ignore: decorator\n @inline\n export const CHLD: signal = 16;\n /** Continue executing, if stopped. */\n // @ts-ignore: decorator\n @inline\n export const CONT: signal = 17;\n /** Stop executing. */\n // @ts-ignore: decorator\n @inline\n export const STOP: signal = 18;\n /** Terminal stop signal. */\n // @ts-ignore: decorator\n @inline\n export const TSTP: signal = 19;\n /** Background process attempting read. */\n // @ts-ignore: decorator\n @inline\n export const TTIN: signal = 20;\n /** Background process attempting write. */\n // @ts-ignore: decorator\n @inline\n export const TTOU: signal = 21;\n /** High bandwidth data is available at a socket. */\n // @ts-ignore: decorator\n @inline\n export const URG: signal = 22;\n /** CPU time limit exceeded. */\n // @ts-ignore: decorator\n @inline\n export const XCPU: signal = 23;\n /** File size limit exceeded. */\n // @ts-ignore: decorator\n @inline\n export const XFSZ: signal = 24;\n /** Virtual timer expired. */\n // @ts-ignore: decorator\n @inline\n export const VTALRM: signal = 25;\n // @ts-ignore: decorator\n @inline\n export const PROF: signal = 26;\n // @ts-ignore: decorator\n @inline\n export const WINCH: signal = 27;\n // @ts-ignore: decorator\n @inline\n export const POLL: signal = 28;\n // @ts-ignore: decorator\n @inline\n export const PWR: signal = 29;\n /** Bad system call. */\n // @ts-ignore: decorator\n @inline\n export const SYS: signal = 30;\n}\nexport type signal = u8;\n\n/** Flags determining how to interpret the timestamp provided in `subscription_t::u.clock.timeout. */\nexport namespace subclockflags {\n /** If set, treat the timestamp provided in `clocksubscription` as an absolute timestamp. */\n // @ts-ignore: decorator\n @inline\n export const ABSTIME: subclockflags = 1;\n}\nexport type subclockflags = u16;\n\n/** Subscription to an event. */\n@unmanaged export abstract class subscription {\n /** User-provided value that is attached to the subscription. */\n userdata: userdata;\n /** The type of the event to which to subscribe. */\n type: eventtype;\n private __padding0: u32;\n}\n\n/* Subscription to an event of type `eventtype.CLOCK`.**/\n@unmanaged export class clocksubscription extends subscription {\n /** The user-defined unique identifier of the clock. */\n identifier: userdata;\n /** The clock against which to compare the timestamp. */\n clock_id: clockid;\n /** The absolute or relative timestamp. */\n timeout: timestamp;\n /** The amount of time that the implementation may wait additionally to coalesce with other events. */\n precision: timestamp;\n /** Flags specifying whether the timeout is absolute or relative. */\n flags: subclockflags;\n private __padding1: u32;\n}\n\n/* Subscription to an event of type `eventtype.FD_READ` or `eventtype.FD_WRITE`.**/\n@unmanaged export class fdsubscription extends subscription {\n /** The file descriptor on which to wait for it to become ready for reading or writing. */\n fd: fd;\n}\n\n/** Timestamp in nanoseconds. */\nexport type timestamp = u64;\n\n/** User-provided value that may be attached to objects that is retained when extracted from the implementation. */\nexport type userdata = u64;\n\n/** The position relative to which to set the offset of the file descriptor. */\nexport namespace whence {\n /** Seek relative to current position. */\n // @ts-ignore: decorator\n @inline\n export const CUR: whence = 0;\n /** Seek relative to end-of-file. */\n // @ts-ignore: decorator\n @inline\n export const END: whence = 1;\n /** Seek relative to start-of-file. */\n // @ts-ignore: decorator\n @inline\n export const SET: whence = 2;\n}\nexport type whence = u8;\n","bindings/wasi":'export * from "./wasi_unstable";\n',builtins:'// @ts-ignore: decorator\n@builtin\nexport declare function isInteger(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isFloat(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isBoolean(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isSigned(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isReference(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isString(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isArray(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isArrayLike(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isFunction(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isNullable(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isDefined(expression: void): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isConstant(expression: void): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isManaged(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function clz(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function ctz(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function popcnt(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function rotl(value: T, shift: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function rotr(value: T, shift: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function abs(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function max(left: T, right: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function min(left: T, right: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function ceil(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function floor(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function copysign(left: T, right: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function nearest(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function reinterpret(value: number): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function sqrt(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function trunc(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function load(offset: usize, immOffset?: usize, immAlign?: usize): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function store(offset: usize, value: void, immOffset?: usize, immAlign?: usize): void;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function sizeof(): usize; // | u32 / u64\n\n// @ts-ignore: decorator\n@builtin\nexport declare function alignof(): usize; // | u32 / u64\n\n// @ts-ignore: decorator\n@builtin\nexport declare function offsetof(fieldName?: string): usize; // | u32 / u64\n\n// @ts-ignore: decorator\n@builtin\nexport declare function idof(): u32;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function select(ifTrue: T, ifFalse: T, condition: bool): T;\n\n// @ts-ignore: decorator\n@unsafe @builtin\nexport declare function unreachable(): void;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function changetype(value: void): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function assert(isTrueish: T, message?: string): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function unchecked(expr: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function call_indirect(target: void, ...args: void[]): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function call_direct(target: void, ...args: void[]): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function instantiate(...args: void[]): T;\n\nexport namespace atomic {\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: T, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg(ptr: usize, expected: T, replacement: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function wait(ptr: usize, expected: T, timeout: i64): AtomicWaitResult;\n\n // @ts-ignore: decorator\n @builtin\n export declare function notify(ptr: usize, count: i32): i32;\n}\n\n// @ts-ignore: decorator\n@lazy\nexport const enum AtomicWaitResult {\n OK = 0,\n NOT_EQUAL = 1,\n TIMED_OUT = 2\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i8(value: void): i8;\n\nexport namespace i8 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: i8 = -128;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: i8 = 127;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i16(value: void): i16;\n\nexport namespace i16 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: i16 = -32768;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: i16 = 32767;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i32(value: void): i32;\n\nexport namespace i32 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: i32 = -2147483648;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: i32 = 2147483647;\n\n // @ts-ignore: decorator\n @builtin\n export declare function clz(value: i32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ctz(value: i32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function popcnt(value: i32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function rotl(value: i32, shift: i32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function rotr(value: i32, shift: i32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function reinterpret_f32(value: f32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_s(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_u(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_s(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_u(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store8(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store16(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n\n export namespace atomic {\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_u(offset: usize, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_u(offset: usize, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store8(offset: usize, value: i32, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store16(offset: usize, value: i32, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: i32, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function wait(ptr: usize, expected: i32, timeout: i64): AtomicWaitResult;\n\n export namespace rmw8 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg_u(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n\n export namespace rmw16 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg_u(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n\n export namespace rmw {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n }\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i64(value: void): i64;\n\nexport namespace i64 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: i64 = -9223372036854775808;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: i64 = 9223372036854775807;\n\n // @ts-ignore: decorator\n @builtin\n export declare function clz(value: i64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ctz(value: i64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load32_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load32_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function popcnt(value: i64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function rotl(value: i64, shift: i64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function rotr(value: i64, shift: i64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function reinterpret_f64(value: f64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store8(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store16(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store32(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n\n export namespace atomic {\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_u(offset: usize, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_u(offset: usize, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load32_u(offset: usize, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store8(offset: usize, value: i64, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store16(offset: usize, value: i64, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store32(offset: usize, value: i64, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: i64, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function wait(ptr: usize, expected: i64, timeout: i64): AtomicWaitResult;\n\n export namespace rmw8 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n\n export namespace rmw16 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n\n export namespace rmw32 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n\n export namespace rmw {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n }\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isize(value: void): isize;\n\nexport namespace isize {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: isize = sizeof() == sizeof()\n ? -2147483648\n : -9223372036854775808;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: isize = sizeof() == sizeof()\n ? 2147483647\n : 9223372036854775807;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function u8(value: void): u8;\n\nexport namespace u8 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: u8 = 0;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: u8 = 255;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function u16(value: void): u16;\n\nexport namespace u16 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: u16 = 0;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: u16 = 65535;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function u32(value: void): u32;\n\nexport namespace u32 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: u32 = 0;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: u32 = 4294967295;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function u64(value: void): u64;\n\nexport namespace u64 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: u64 = 0;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: u64 = 18446744073709551615;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function usize(value: void): usize;\n\nexport namespace usize {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: usize = 0;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: usize = sizeof() == sizeof()\n ? 4294967295\n : 18446744073709551615;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function bool(value: void): bool;\n\nexport namespace bool {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: bool = false;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: bool = true;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function f32(value: void): f32;\n\nexport namespace f32 {\n\n // @ts-ignore: decorator\n @lazy\n export const EPSILON = reinterpret(0x34000000); // 0x1p-23f\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE = reinterpret(0x00000001); // 0x0.000001p+0f\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE = reinterpret(0x7F7FFFFF); // 0x1.fffffep+127f\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_NORMAL_VALUE = reinterpret(0x00800000); // 0x1p-126f\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_SAFE_INTEGER: f32 = -16777215;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_SAFE_INTEGER: f32 = 16777215;\n\n // @ts-ignore: decorator\n @builtin\n export declare function abs(value: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ceil(value: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function copysign(x: f32, y: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function floor(value: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize, immAlign?: usize): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function max(left: f32, right: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function min(left: f32, right: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function nearest(value: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function reinterpret_i32(value: i32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sqrt(value: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: f32, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc(value: f32): f32;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function f64(value: void): f64;\n\nexport namespace f64 {\n\n // @ts-ignore: decorator\n @lazy\n export const EPSILON = reinterpret(0x3CB0000000000000); // 0x1p-52\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE = reinterpret(0x0000000000000001); // 0x0.0000000000001p+0\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE = reinterpret(0x7FEFFFFFFFFFFFFF); // 0x1.fffffffffffffp+1023\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_NORMAL_VALUE = reinterpret(0x0010000000000000); // 0x1p-1022\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_SAFE_INTEGER: f64 = -9007199254740991;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_SAFE_INTEGER: f64 = 9007199254740991;\n\n // @ts-ignore: decorator\n @builtin\n export declare function abs(value: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ceil(value: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function copysign(x: f64, y: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function floor(value: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize, immAlign?: usize): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function max(left: f64, right: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function min(left: f64, right: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function nearest(value: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function reinterpret_i64(value: i64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sqrt(value: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: f64, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc(value: f64): f64;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function v128(\n a: i8, b: i8, c: i8, d: i8, e: i8, f: i8, g: i8, h: i8,\n i: i8, j: i8, k: i8, l: i8, m: i8, n: i8, o: i8, p: i8\n): v128;\n\nexport namespace v128 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: T): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane(x: v128, idx: u8): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: T): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shuffle(a: v128, b: v128, ...lanes: u8[]): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize, immAlign?: usize): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: v128, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128; // except i64\n\n // @ts-ignore: decorator\n @builtin\n export declare function div(a: v128, b: v128): v128; // f32, f64 only\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_saturate(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_saturate(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shl(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function not(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function bitselect(v1: v128, v2: v128, c: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function any_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function all_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function min(a: v128, b: v128): v128; // f32, f64 only\n\n // @ts-ignore: decorator\n @builtin\n export declare function max(a: v128, b: v128): v128; // f32, f64 only\n\n // @ts-ignore: decorator\n @builtin\n export declare function abs(a: v128): v128; // f32, f64 only\n\n // @ts-ignore: decorator\n @builtin\n export declare function sqrt(a: v128): v128; // f32, f64 only\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function convert(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc(a: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i8x16(\n a: i8, b: i8, c: i8, d: i8, e: i8, f: i8, g: i8, h: i8,\n i: i8, j: i8, k: i8, l: i8, m: i8, n: i8, o: i8, p: i8\n): v128;\n\nexport namespace i8x16 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: i8): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane_s(x: v128, idx: u8): i8;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane_u(x: v128, idx: u8): u8;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: i8): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_saturate_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_saturate_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_saturate_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_saturate_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shl(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_s(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_u(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function any_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function all_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_u(a: v128, b: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i16x8(a: i16, b: i16, c: i16, d: i16, e: i16, f: i16, g: i16, h: i16): v128;\n\nexport namespace i16x8 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: i16): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane_s(x: v128, idx: u8): i16;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane_u(x: v128, idx: u8): u16;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: i16): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_saturate_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_saturate_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_saturate_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_saturate_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shl(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_s(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_u(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function any_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function all_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_u(a: v128, b: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i32x4(a: i32, b: i32, c: i32, d: i32): v128;\n\nexport namespace i32x4 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane(x: v128, idx: u8): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shl(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_s(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_u(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function any_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function all_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc_s_f32x4_sat(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc_u_f32x4_sat(a: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i64x2(a: i64, b: i64): v128;\n\nexport namespace i64x2 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: i64): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane(x: v128, idx: u8): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: i64): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shl(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_s(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_u(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function any_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function all_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc_s_f64x2_sat(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc_u_f64x2_sat(a: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function f32x4(a: f32, b: f32, c: f32, d: f32): v128;\n\nexport namespace f32x4 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: f32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane(x: v128, idx: u8): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: f32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function div(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function min(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function max(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function abs(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sqrt(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function convert_s_i32x4(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function convert_u_i32x4(a: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function f64x2(a: f64, b: f64): v128;\n\nexport namespace f64x2 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: f64): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane(x: v128, idx: u8): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: f64): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function div(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function min(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function max(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function abs(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sqrt(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function convert_s_i64x2(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function convert_u_i64x2(a: v128): v128;\n}\n\nexport namespace v8x16 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function shuffle(\n a: v128, b: v128,\n l0: u8, l1: u8, l2: u8, l3: u8, l4: u8, l5: u8, l6: u8, l7: u8,\n l8: u8, l9: u8, l10: u8, l11: u8, l12: u8, l13: u8, l14: u8, l15: u8\n ): v128;\n}\n\n// @ts-ignore: decorator\n@external("env", "abort")\ndeclare function abort(\n message?: string | null,\n fileName?: string | null,\n lineNumber?: u32,\n columnNumber?: u32\n): void;\n\n// @ts-ignore: decorator\n@external("env", "trace")\ndeclare function trace(\n message: string,\n n?: i32,\n a0?: f64,\n a1?: f64,\n a2?: f64,\n a3?: f64,\n a4?: f64\n): void;\n',dataview:'import { BLOCK_MAXSIZE } from "./rt/common";\nimport { ArrayBuffer } from "./arraybuffer";\nimport { E_INDEXOUTOFRANGE, E_INVALIDLENGTH } from "./util/error";\n\n// TODO: there is probably a smarter way to check byteOffset for accesses larger than 1 byte\n\nexport class DataView {\n\n private data: ArrayBuffer;\n private dataStart: usize;\n private dataLength: i32;\n\n constructor(\n buffer: ArrayBuffer,\n byteOffset: i32 = 0,\n byteLength: i32 = buffer.byteLength\n ) {\n if (\n i32(byteLength > BLOCK_MAXSIZE) |\n i32(byteOffset + byteLength > buffer.byteLength)\n ) throw new RangeError(E_INVALIDLENGTH);\n this.data = buffer; // retains\n var dataStart = changetype(buffer) + byteOffset;\n this.dataStart = dataStart;\n this.dataLength = byteLength;\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get byteOffset(): i32 {\n return (this.dataStart - changetype(this.data));\n }\n\n get byteLength(): i32 {\n return this.dataLength;\n }\n\n getFloat32(byteOffset: i32, littleEndian: boolean = false): f32 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n return littleEndian\n ? load(this.dataStart + byteOffset)\n : reinterpret(\n bswap(\n load(this.dataStart + byteOffset)\n )\n );\n }\n\n getFloat64(byteOffset: i32, littleEndian: boolean = false): f64 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n return littleEndian\n ? load(this.dataStart + byteOffset)\n : reinterpret(\n bswap(\n load(this.dataStart + byteOffset)\n )\n );\n }\n\n getInt8(byteOffset: i32): i8 {\n if (byteOffset >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + byteOffset);\n }\n\n getInt16(byteOffset: i32, littleEndian: boolean = false): i16 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 2 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result: i16 = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n getInt32(byteOffset: i32, littleEndian: boolean = false): i32 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result: i32 = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n getUint8(byteOffset: i32): u8 {\n if (byteOffset >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + byteOffset);\n }\n\n getUint16(byteOffset: i32, littleEndian: boolean = false): u16 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 2 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result: u16 = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n getUint32(byteOffset: i32, littleEndian: boolean = false): u32 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result: u32 = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n setFloat32(byteOffset: i32, value: f32, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n if (littleEndian) store(this.dataStart + byteOffset, value);\n else store(this.dataStart + byteOffset, bswap(reinterpret(value)));\n }\n\n setFloat64(byteOffset: i32, value: f64, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n if (littleEndian) store(this.dataStart + byteOffset, value);\n else store(this.dataStart + byteOffset, bswap(reinterpret(value)));\n }\n\n setInt8(byteOffset: i32, value: i8): void {\n if (byteOffset >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, value);\n }\n\n setInt16(byteOffset: i32, value: i16, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 2 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n setInt32(byteOffset: i32, value: i32, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n setUint8(byteOffset: i32, value: u8): void {\n if (byteOffset >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, value);\n }\n\n setUint16(byteOffset: i32, value: u16, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 2 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n setUint32(byteOffset: i32, value: u32, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n // Non-standard additions that make sense in WebAssembly, but won\'t work in JS:\n\n getInt64(byteOffset: i32, littleEndian: boolean = false): i64 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result: i64 = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n getUint64(byteOffset: i32, littleEndian: boolean = false): u64 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n setInt64(byteOffset: i32, value: i64, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n setUint64(byteOffset: i32, value: u64, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n toString(): string {\n return "[object DataView]";\n }\n}\n',date:'import {\n UTC as Date_UTC,\n now as Date_now\n} from "./bindings/Date";\n\nexport class Date {\n\n @inline static UTC(\n year: i32,\n month: i32 = 0,\n day: i32 = 1,\n hour: i32 = 0,\n minute: i32 = 0,\n second: i32 = 0,\n millisecond: i64 = 0\n ): i64 {\n return Date_UTC(year, month, day, hour, minute, second, millisecond);\n }\n\n @inline static now(): i64 {\n return Date_now();\n }\n\n private value: i64;\n\n constructor(value: i64) {\n this.value = value;\n }\n\n getTime(): i64 {\n return this.value;\n }\n\n setTime(value: i64): i64 {\n this.value = value;\n return value;\n }\n}\n',diagnostics:"// @ts-ignore: decorator\n@builtin\nexport declare function ERROR(message?: string): void;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function WARNING(message?: string): void;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function INFO(message?: string): void;\n",error:'export class Error {\n\n name: string = "Error";\n stack: string = ""; // TODO\n\n constructor(\n public message: string = ""\n ) {}\n\n toString(): string {\n var message = this.message;\n return message.length\n ? this.name + ": " + message\n : this.name;\n }\n}\n\nexport class RangeError extends Error {\n constructor(message: string = "") {\n super(message);\n this.name = "RangeError";\n }\n}\n\nexport class TypeError extends Error {\n constructor(message: string = "") {\n super(message);\n this.name = "TypeError";\n }\n}\n\nexport class SyntaxError extends Error {\n constructor(message: string = "") {\n super(message);\n this.name = "SyntaxError";\n }\n}\n',fixedarray:'/// \n\nimport { BLOCK, BLOCK_OVERHEAD, BLOCK_MAXSIZE } from "./rt/common";\nimport { idof } from "./builtins";\nimport { E_INDEXOUTOFRANGE, E_INVALIDLENGTH, E_HOLEYARRAY } from "./util/error";\n\n// NOTE: DO NOT USE YET!\n\n// TODO: FixedArray with S being the static size, i.e. `new FixedArray`.\n// Then hard-wire this special type to the compiler and do static length checks instead :)\n\nexport class FixedArray {\n [key: number]: T;\n\n constructor(length: i32) {\n if (length > BLOCK_MAXSIZE >>> alignof()) throw new RangeError(E_INVALIDLENGTH);\n if (isReference()) {\n if (!isNullable()) {\n if (length) throw new Error(E_HOLEYARRAY);\n }\n }\n var outSize = length << alignof();\n var out = __alloc(outSize, idof>());\n memory.fill(out, 0, outSize);\n return changetype>(out); // retains\n }\n\n get length(): i32 {\n return changetype(changetype(this) - BLOCK_OVERHEAD).rtSize >>> alignof();\n }\n\n @operator("[]") private __get(index: i32): T {\n if (index >= this.length) throw new RangeError(E_INDEXOUTOFRANGE);\n return this.__unchecked_get(index);\n }\n\n @operator("[]=") private __set(index: i32, value: T): void {\n if (index >= this.length) throw new RangeError(E_INDEXOUTOFRANGE);\n this.__unchecked_set(index, value);\n }\n\n @operator("{}") private __unchecked_get(index: i32): T {\n return load(changetype(this) + (index << alignof()));\n }\n\n @operator("{}=") private __unchecked_set(index: i32, value: T): void {\n if (isManaged()) {\n let offset = changetype(this) + (index << alignof());\n let oldValue = load(offset);\n if (changetype(value) != oldValue) {\n store(offset, __retain(changetype(value)));\n __release(changetype(oldValue));\n }\n } else {\n store(changetype(this) + (index << alignof()), value);\n }\n }\n\n // RT integration\n\n @unsafe private __visit_impl(cookie: u32): void {\n if (isManaged()) {\n let cur = changetype(this);\n let end = cur + changetype(changetype(this) - BLOCK_OVERHEAD).rtSize;\n while (cur < end) {\n let val = load(cur);\n if (val) __visit(val, cookie);\n cur += sizeof();\n }\n }\n }\n}\n',heap:"// @ts-ignore: decorator\n@builtin\nexport declare const __heap_base: usize;\n",iterator:"export abstract class Iterable {\n // ?\n}\n\n@sealed\nexport abstract class Iterator {\n\n // private constructor(iterable: Iterable) {\n // }\n\n // TODO: these need to evaluate the classId at the respective reference in order to obtain the\n // next value, i.e. arrays work differently than maps. we'd then have:\n //\n // ╒═══════════════════ Iterator layout (32-bit) ══════════════════╕\n // 3 2 1\n // 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n // ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤\n // │ index │\n // ├─────────────────────────────────────────────────────────┬───┬─┤\n // │ reference │ 0 │D│\n // └─────────────────────────────────────────────────────────┴───┴─┘\n // D: Done flag\n\n // get value(this: u64): T {\n // ?\n // }\n\n // next(this: u64): Iterator {\n // ?\n // }\n\n done(this: u64): bool {\n return (this & 1);\n }\n}\n",map:'/// \n\nimport { HASH } from "./util/hash";\n\n// A deterministic hash map based on CloseTable from https://github.com/jorendorff/dht\n\n// @ts-ignore: decorator\n@inline\nconst INITIAL_CAPACITY = 4;\n\n// @ts-ignore: decorator\n@inline\nconst FILL_FACTOR: f64 = 8 / 3;\n\n// @ts-ignore: decorator\n@inline\nconst FREE_FACTOR: f64 = 3 / 4;\n\n/** Structure of a map entry. */\n@unmanaged class MapEntry {\n key: K;\n value: V;\n taggedNext: usize; // LSB=1 indicates EMPTY\n}\n\n/** Empty bit. */\n// @ts-ignore: decorator\n@inline\nconst EMPTY: usize = 1 << 0;\n\n/** Size of a bucket. */\n// @ts-ignore: decorator\n@inline\nconst BUCKET_SIZE = sizeof();\n\n/** Computes the alignment of an entry. */\n// @ts-ignore: decorator\n@inline\nfunction ENTRY_ALIGN(): usize {\n // can align to 4 instead of 8 if 32-bit and K/V is <= 32-bits\n const maxkv = sizeof() > sizeof() ? sizeof() : sizeof();\n const align = (maxkv > sizeof() ? maxkv : sizeof()) - 1;\n return align;\n}\n\n/** Computes the aligned size of an entry. */\n// @ts-ignore: decorator\n@inline\nfunction ENTRY_SIZE(): usize {\n const align = ENTRY_ALIGN();\n const size = (offsetof>() + align) & ~align;\n return size;\n}\n\nexport class Map {\n\n // buckets holding references to the respective first entry within\n private buckets: ArrayBuffer; // usize[bucketsMask + 1]\n private bucketsMask: u32;\n\n // entries in insertion order\n private entries: ArrayBuffer; // MapEntry[entriesCapacity]\n private entriesCapacity: i32;\n private entriesOffset: i32;\n private entriesCount: i32;\n\n get size(): i32 { return this.entriesCount; }\n\n constructor() {\n this.clear();\n }\n\n clear(): void {\n const bucketsSize = INITIAL_CAPACITY * BUCKET_SIZE;\n this.buckets = new ArrayBuffer(bucketsSize);\n this.bucketsMask = INITIAL_CAPACITY - 1;\n const entriesSize = INITIAL_CAPACITY * ENTRY_SIZE();\n this.entries = new ArrayBuffer(entriesSize);\n this.entriesCapacity = INITIAL_CAPACITY;\n this.entriesOffset = 0;\n this.entriesCount = 0;\n }\n\n private find(key: K, hashCode: u32): MapEntry | null {\n var entry = load>( // unmanaged!\n changetype(this.buckets) + (hashCode & this.bucketsMask) * BUCKET_SIZE\n );\n while (entry) {\n if (!(entry.taggedNext & EMPTY) && entry.key == key) return entry;\n entry = changetype>(entry.taggedNext & ~EMPTY);\n }\n return null;\n }\n\n has(key: K): bool {\n return this.find(key, HASH(key)) !== null;\n }\n\n get(key: K): V {\n var entry = this.find(key, HASH(key));\n return entry ? entry.value : unreachable();\n }\n\n set(key: K, value: V): void {\n var hashCode = HASH(key);\n var entry = this.find(key, hashCode); // unmanaged!\n if (entry) {\n if (isManaged()) {\n let oldRef = changetype(entry.value);\n if (changetype(value) != oldRef) {\n entry.value = changetype(__retain(changetype(value)));\n __release(oldRef);\n }\n } else {\n entry.value = value;\n }\n } else {\n // check if rehashing is necessary\n if (this.entriesOffset == this.entriesCapacity) {\n this.rehash(\n this.entriesCount < (this.entriesCapacity * FREE_FACTOR)\n ? this.bucketsMask // just rehash if 1/4+ entries are empty\n : (this.bucketsMask << 1) | 1 // grow capacity to next 2^N\n );\n }\n // append new entry\n let entries = this.entries;\n entry = changetype>(changetype(entries) + this.entriesOffset++ * ENTRY_SIZE());\n // link with the map\n entry.key = isManaged()\n ? changetype(__retain(changetype(key)))\n : key;\n entry.value = isManaged()\n ? changetype(__retain(changetype(value)))\n : value;\n ++this.entriesCount;\n // link with previous entry in bucket\n let bucketPtrBase = changetype(this.buckets) + (hashCode & this.bucketsMask) * BUCKET_SIZE;\n entry.taggedNext = load(bucketPtrBase);\n store(bucketPtrBase, changetype(entry));\n }\n }\n\n delete(key: K): bool {\n var entry = this.find(key, HASH(key));\n if (!entry) return false;\n if (isManaged()) __release(changetype(entry.key));\n if (isManaged()) __release(changetype(entry.value));\n entry.taggedNext |= EMPTY;\n --this.entriesCount;\n // check if rehashing is appropriate\n var halfBucketsMask = this.bucketsMask >> 1;\n if (\n halfBucketsMask + 1 >= max(INITIAL_CAPACITY, this.entriesCount) &&\n this.entriesCount < (this.entriesCapacity * FREE_FACTOR)\n ) this.rehash(halfBucketsMask);\n return true;\n }\n\n private rehash(newBucketsMask: u32): void {\n var newBucketsCapacity = (newBucketsMask + 1);\n var newBuckets = new ArrayBuffer(newBucketsCapacity * BUCKET_SIZE);\n var newEntriesCapacity = (newBucketsCapacity * FILL_FACTOR);\n var newEntries = new ArrayBuffer(newEntriesCapacity * ENTRY_SIZE());\n\n // copy old entries to new entries\n var oldPtr = changetype(this.entries);\n var oldEnd = oldPtr + this.entriesOffset * ENTRY_SIZE();\n var newPtr = changetype(newEntries);\n while (oldPtr != oldEnd) {\n let oldEntry = changetype>(oldPtr);\n if (!(oldEntry.taggedNext & EMPTY)) {\n let newEntry = changetype>(newPtr);\n newEntry.key = oldEntry.key;\n newEntry.value = oldEntry.value;\n let newBucketIndex = HASH(oldEntry.key) & newBucketsMask;\n let newBucketPtrBase = changetype(newBuckets) + newBucketIndex * BUCKET_SIZE;\n newEntry.taggedNext = load(newBucketPtrBase);\n store(newBucketPtrBase, newPtr);\n newPtr += ENTRY_SIZE();\n }\n oldPtr += ENTRY_SIZE();\n }\n\n this.buckets = newBuckets;\n this.bucketsMask = newBucketsMask;\n this.entries = newEntries;\n this.entriesCapacity = newEntriesCapacity;\n this.entriesOffset = this.entriesCount;\n }\n\n keys(): K[] {\n // FIXME: this is preliminary, needs iterators/closures\n var start = changetype(this.entries);\n var size = this.entriesOffset;\n var keys = Array.create(size);\n for (let i = 0; i < size; ++i) {\n let entry = changetype>(start + i * ENTRY_SIZE());\n if (!(entry.taggedNext & EMPTY)) {\n keys.push(entry.key);\n }\n }\n return keys;\n }\n\n values(): V[] {\n // FIXME: this is preliminary, needs iterators/closures\n var start = changetype(this.entries);\n var size = this.entriesOffset;\n var values = Array.create(size);\n for (let i = 0; i < size; ++i) {\n let entry = changetype>(start + i * ENTRY_SIZE());\n if (!(entry.taggedNext & EMPTY)) {\n values.push(entry.value);\n }\n }\n return values;\n }\n\n toString(): string {\n return "[object Map]";\n }\n\n // RT integration\n\n @unsafe private __visit_impl(cookie: u32): void {\n __visit(changetype(this.buckets), cookie);\n var entries = changetype(this.entries);\n if (isManaged() || isManaged()) {\n let cur = entries;\n let end = cur + this.entriesOffset * ENTRY_SIZE();\n while (cur < end) {\n let entry = changetype>(cur);\n if (!(entry.taggedNext & EMPTY)) {\n if (isManaged()) {\n let val = changetype(entry.key);\n if (isNullable()) {\n if (val) __visit(val, cookie);\n } else __visit(val, cookie);\n }\n if (isManaged()) {\n let val = changetype(entry.value);\n if (isNullable()) {\n if (val) __visit(val, cookie);\n } else __visit(val, cookie);\n }\n }\n cur += ENTRY_SIZE();\n }\n }\n __visit(entries, cookie);\n }\n}\n',math:'import * as JSMath from "./bindings/Math";\nexport { JSMath };\n\nimport {\n abs as builtin_abs,\n ceil as builtin_ceil,\n clz as builtin_clz,\n copysign as builtin_copysign,\n floor as builtin_floor,\n max as builtin_max,\n min as builtin_min,\n sqrt as builtin_sqrt,\n trunc as builtin_trunc\n} from "./builtins";\n\n// SUN COPYRIGHT NOTICE\n//\n// Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.\n// Developed at SunPro, a Sun Microsystems, Inc. business.\n// Permission to use, copy, modify, and distribute this software\n// is freely granted, provided that this notice is preserved.\n//\n// Applies to all functions marked with a comment referring here.\n\n// TODO: sin, cos, tan for Math namespace\n\n/** @internal */\nfunction R(z: f64): f64 { // Rational approximation of (asin(x)-x)/x^3\n const // see: musl/src/math/asin.c and SUN COPYRIGHT NOTICE above\n pS0 = reinterpret(0x3FC5555555555555), // 1.66666666666666657415e-01\n pS1 = reinterpret(0xBFD4D61203EB6F7D), // -3.25565818622400915405e-01\n pS2 = reinterpret(0x3FC9C1550E884455), // 2.01212532134862925881e-01\n pS3 = reinterpret(0xBFA48228B5688F3B), // -4.00555345006794114027e-02\n pS4 = reinterpret(0x3F49EFE07501B288), // 7.91534994289814532176e-04\n pS5 = reinterpret(0x3F023DE10DFDF709), // 3.47933107596021167570e-05\n qS1 = reinterpret(0xC0033A271C8A2D4B), // -2.40339491173441421878e+00\n qS2 = reinterpret(0x40002AE59C598AC8), // 2.02094576023350569471e+00\n qS3 = reinterpret(0xBFE6066C1B8D0159), // -6.88283971605453293030e-01\n qS4 = reinterpret(0x3FB3B8C5B12E9282); // 7.70381505559019352791e-02\n var p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5)))));\n var q = 1.0 + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4)));\n return p / q;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction expo2(x: f64): f64 { // exp(x)/2 for x >= log(DBL_MAX)\n const // see: musl/src/math/__expo2.c\n k = 2043,\n kln2 = reinterpret(0x40962066151ADD8B); // 0x1.62066151add8bp+10\n var scale = reinterpret(((0x3FF + k / 2) << 20) << 32);\n return NativeMath.exp(x - kln2) * scale * scale;\n}\n\n// @ts-ignore: decorator\n@lazy\nvar random_seeded = false;\n\n// @ts-ignore: decorator\n@lazy\nvar random_state0_64: u64;\n\n// @ts-ignore: decorator\n@lazy\nvar random_state1_64: u64;\n\n// @ts-ignore: decorator\n@lazy\nvar random_state0_32: u32;\n\n// @ts-ignore: decorator\n@lazy\nvar random_state1_32: u32;\n\nfunction murmurHash3(h: u64): u64 { // Force all bits of a hash block to avalanche\n h ^= h >> 33; // see: https://github.com/aappleby/smhasher\n h *= 0xFF51AFD7ED558CCD;\n h ^= h >> 33;\n h *= 0xC4CEB9FE1A85EC53;\n h ^= h >> 33;\n return h;\n}\n\nfunction splitMix32(h: u32): u32 {\n h += 0x6D2B79F5;\n h = (h ^ (h >> 15)) * (h | 1);\n h ^= h + (h ^ (h >> 7)) * (h | 61);\n return h ^ (h >> 14);\n}\n\nexport namespace NativeMath {\n\n // @ts-ignore: decorator\n @lazy\n export const E = reinterpret(0x4005BF0A8B145769); // 2.7182818284590452354\n\n // @ts-ignore: decorator\n @lazy\n export const LN2 = reinterpret(0x3FE62E42FEFA39EF); // 0.69314718055994530942\n\n // @ts-ignore: decorator\n @lazy\n export const LN10 = reinterpret(0x40026BB1BBB55516); // 2.30258509299404568402\n\n // @ts-ignore: decorator\n @lazy\n export const LOG2E = reinterpret(0x3FF71547652B82FE); // 1.4426950408889634074\n\n // @ts-ignore: decorator\n @lazy\n export const LOG10E = reinterpret(0x3FDBCB7B1526E50E); // 0.43429448190325182765\n\n // @ts-ignore: decorator\n @lazy\n export const PI = reinterpret(0x400921FB54442D18); // 3.14159265358979323846\n\n // @ts-ignore: decorator\n @lazy\n export const SQRT1_2 = reinterpret(0x3FE6A09E667F3BCD); // 0.70710678118654752440\n\n // @ts-ignore: decorator\n @lazy\n export const SQRT2 = reinterpret(0x3FF6A09E667F3BCD); // 1.41421356237309504880\n\n // @ts-ignore: decorator\n @inline export function abs(x: f64): f64 {\n return builtin_abs(x);\n }\n\n export function acos(x: f64): f64 { // see: musl/src/math/acos.c and SUN COPYRIGHT NOTICE above\n const\n pio2_hi = reinterpret(0x3FF921FB54442D18), // 1.57079632679489655800e+00\n pio2_lo = reinterpret(0x3C91A62633145C07), // 6.12323399573676603587e-17\n Ox1p_120f = reinterpret(0x03800000);\n var hx = (reinterpret(x) >> 32);\n var ix = hx & 0x7FFFFFFF;\n if (ix >= 0x3FF00000) {\n let lx = reinterpret(x);\n if ((ix - 0x3FF00000 | lx) == 0) {\n if (hx >> 31) return 2 * pio2_hi + Ox1p_120f;\n return 0;\n }\n return 0 / (x - x);\n }\n if (ix < 0x3FE00000) {\n if (ix <= 0x3C600000) return pio2_hi + Ox1p_120f;\n return pio2_hi - (x - (pio2_lo - x * R(x * x)));\n }\n var s: f64, w: f64, z: f64;\n if (hx >> 31) {\n // z = (1.0 + x) * 0.5;\n z = 0.5 + x * 0.5;\n s = builtin_sqrt(z);\n w = R(z) * s - pio2_lo;\n return 2 * (pio2_hi - (s + w));\n }\n // z = (1.0 - x) * 0.5;\n z = 0.5 - x * 0.5;\n s = builtin_sqrt(z);\n var df = reinterpret(reinterpret(s) & 0xFFFFFFFF00000000);\n var c = (z - df * df) / (s + df);\n w = R(z) * s + c;\n return 2 * (df + w);\n }\n\n export function acosh(x: f64): f64 { // see: musl/src/math/acosh.c\n const s = reinterpret(0x3FE62E42FEFA39EF);\n var e = reinterpret(x) >> 52 & 0x7FF;\n if (e < 0x3FF + 1) return log1p(x - 1 + builtin_sqrt((x - 1) * (x - 1) + 2 * (x - 1)));\n if (e < 0x3FF + 26) return log(2 * x - 1 / (x + builtin_sqrt(x * x - 1)));\n return log(x) + s;\n }\n\n export function asin(x: f64): f64 { // see: musl/src/math/asin.c and SUN COPYRIGHT NOTICE above\n const\n pio2_hi = reinterpret(0x3FF921FB54442D18), // 1.57079632679489655800e+00\n pio2_lo = reinterpret(0x3C91A62633145C07), // 6.12323399573676603587e-17\n Ox1p_120f = reinterpret(0x03800000);\n var hx = (reinterpret(x) >> 32);\n var ix = hx & 0x7FFFFFFF;\n if (ix >= 0x3FF00000) {\n let lx = reinterpret(x);\n if ((ix - 0x3FF00000 | lx) == 0) return x * pio2_hi + Ox1p_120f;\n return 0 / (x - x);\n }\n if (ix < 0x3FE00000) {\n if (ix < 0x3E500000 && ix >= 0x00100000) return x;\n return x + x * R(x * x);\n }\n // var z = (1.0 - builtin_abs(x)) * 0.5;\n var z = 0.5 - builtin_abs(x) * 0.5;\n var s = builtin_sqrt(z);\n var r = R(z);\n if (ix >= 0x3FEF3333) x = pio2_hi - (2 * (s + s * r) - pio2_lo);\n else {\n let f = reinterpret(reinterpret(s) & 0xFFFFFFFF00000000);\n let c = (z - f * f) / (s + f);\n x = 0.5 * pio2_hi - (2 * s * r - (pio2_lo - 2 * c) - (0.5 * pio2_hi - 2 * f));\n }\n if (hx >> 31) return -x;\n return x;\n }\n\n export function asinh(x: f64): f64 { // see: musl/src/math/asinh.c\n const c = reinterpret(0x3FE62E42FEFA39EF); // 0.693147180559945309417232121458176568\n var u = reinterpret(x);\n var e = u >> 52 & 0x7FF;\n var y = reinterpret(u & 0x7FFFFFFFFFFFFFFF);\n if (e >= 0x3FF + 26) y = log(y) + c;\n else if (e >= 0x3FF + 1) y = log(2 * y + 1 / (builtin_sqrt(y * y + 1) + y));\n else if (e >= 0x3FF - 26) y = log1p(y + y * y / (builtin_sqrt(y * y + 1) + 1));\n return builtin_copysign(y, x);\n }\n\n export function atan(x: f64): f64 { // see musl/src/math/atan.c and SUN COPYRIGHT NOTICE above\n const\n atanhi0 = reinterpret(0x3FDDAC670561BB4F), // 4.63647609000806093515e-01\n atanhi1 = reinterpret(0x3FE921FB54442D18), // 7.85398163397448278999e-01\n atanhi2 = reinterpret(0x3FEF730BD281F69B), // 9.82793723247329054082e-01\n atanhi3 = reinterpret(0x3FF921FB54442D18), // 1.57079632679489655800e+00\n atanlo0 = reinterpret(0x3C7A2B7F222F65E2), // 2.26987774529616870924e-17\n atanlo1 = reinterpret(0x3C81A62633145C07), // 3.06161699786838301793e-17\n atanlo2 = reinterpret(0x3C7007887AF0CBBD), // 1.39033110312309984516e-17\n atanlo3 = reinterpret(0x3C91A62633145C07), // 6.12323399573676603587e-17\n aT0 = reinterpret(0x3FD555555555550D), // 3.33333333333329318027e-01\n aT1 = reinterpret(0xBFC999999998EBC4), // -1.99999999998764832476e-01\n aT2 = reinterpret(0x3FC24924920083FF), // 1.42857142725034663711e-01\n aT3 = reinterpret(0xBFBC71C6FE231671), // -1.11111104054623557880e-01,\n aT4 = reinterpret(0x3FB745CDC54C206E), // 9.09088713343650656196e-02\n aT5 = reinterpret(0xBFB3B0F2AF749A6D), // -7.69187620504482999495e-02\n aT6 = reinterpret(0x3FB10D66A0D03D51), // 6.66107313738753120669e-02\n aT7 = reinterpret(0xBFADDE2D52DEFD9A), // -5.83357013379057348645e-02\n aT8 = reinterpret(0x3FA97B4B24760DEB), // 4.97687799461593236017e-02\n aT9 = reinterpret(0xBFA2B4442C6A6C2F), // -3.65315727442169155270e-02\n aT10 = reinterpret(0x3F90AD3AE322DA11), // 1.62858201153657823623e-02\n Ox1p_120f = reinterpret(0x03800000);\n var ix = (reinterpret(x) >> 32);\n var sx = x;\n ix &= 0x7FFFFFFF;\n var z: f64;\n if (ix >= 0x44100000) {\n if (isNaN(x)) return x;\n z = atanhi3 + Ox1p_120f;\n return builtin_copysign(z, sx);\n }\n var id: i32;\n if (ix < 0x3FDC0000) {\n if (ix < 0x3E400000) return x;\n id = -1;\n } else {\n x = builtin_abs(x);\n if (ix < 0x3FF30000) {\n if (ix < 0x3FE60000) {\n id = 0;\n x = (2.0 * x - 1.0) / (2.0 + x);\n } else {\n id = 1;\n x = (x - 1.0) / (x + 1.0);\n }\n } else {\n if (ix < 0x40038000) {\n id = 2;\n x = (x - 1.5) / (1.0 + 1.5 * x);\n } else {\n id = 3;\n x = -1.0 / x;\n }\n }\n }\n z = x * x;\n var w = z * z;\n var s1 = z * (aT0 + w * (aT2 + w * (aT4 + w * (aT6 + w * (aT8 + w * aT10)))));\n var s2 = w * (aT1 + w * (aT3 + w * (aT5 + w * (aT7 + w * aT9))));\n var s3 = x * (s1 + s2);\n if (id < 0) return x - s3;\n switch (id) {\n case 0: { z = atanhi0 - ((s3 - atanlo0) - x); break; }\n case 1: { z = atanhi1 - ((s3 - atanlo1) - x); break; }\n case 2: { z = atanhi2 - ((s3 - atanlo2) - x); break; }\n case 3: { z = atanhi3 - ((s3 - atanlo3) - x); break; }\n default: unreachable();\n }\n return builtin_copysign(z, sx);\n }\n\n export function atanh(x: f64): f64 { // see: musl/src/math/atanh.c\n var u = reinterpret(x);\n var e = u >> 52 & 0x7FF;\n var s = u >> 63;\n u &= 0x7FFFFFFFFFFFFFFF;\n var y = reinterpret(u);\n if (e < 0x3FF - 1) {\n if (e >= 0x3FF - 32) y = 0.5 * log1p(2 * y + 2 * y * y / (1 - y));\n } else {\n y = 0.5 * log1p(2 * (y / (1 - y)));\n }\n return builtin_copysign(y, x);\n }\n\n export function atan2(y: f64, x: f64): f64 { // see: musl/src/math/atan2.c and SUN COPYRIGHT NOTICE above\n const pi_lo = reinterpret(0x3CA1A62633145C07); // 1.2246467991473531772E-16\n if (isNaN(x) || isNaN(y)) return x + y;\n var u = reinterpret(x);\n var ix = (u >> 32);\n var lx = u;\n u = reinterpret(y);\n var iy = (u >> 32);\n var ly = u;\n if ((ix - 0x3FF00000 | lx) == 0) return atan(y);\n var m = ((iy >> 31) & 1) | ((ix >> 30) & 2);\n ix = ix & 0x7FFFFFFF;\n iy = iy & 0x7FFFFFFF;\n if ((iy | ly) == 0) {\n switch (m) {\n case 0:\n case 1: return y;\n case 2: return PI;\n case 3: return -PI;\n }\n }\n if ((ix | lx) == 0) return m & 1 ? -PI / 2 : PI / 2;\n if (ix == 0x7FF00000) {\n if (iy == 0x7FF00000) {\n switch (m) {\n case 0: return PI / 4;\n case 1: return -PI / 4;\n case 2: return 3 * PI / 4;\n case 3: return -3 * PI / 4;\n }\n } else {\n switch (m) {\n case 0: return 0.0;\n case 1: return -0.0;\n case 2: return PI;\n case 3: return -PI;\n }\n }\n }\n var z: f64;\n if (ix + (64 << 20) < iy || iy == 0x7FF00000) return m & 1 ? -PI / 2 : PI / 2;\n if ((m & 2) && iy + (64 << 20) < ix) z = 0;\n else z = atan(builtin_abs(y / x));\n switch (m) {\n case 0: return z;\n case 1: return -z;\n case 2: return PI - (z - pi_lo);\n case 3: return (z - pi_lo) - PI;\n }\n unreachable();\n return 0;\n }\n\n export function cbrt(x: f64): f64 { // see: musl/src/math/cbrt.c and SUN COPYRIGHT NOTICE above\n const\n B1 = 715094163,\n B2 = 696219795,\n P0 = reinterpret(0x3FFE03E60F61E692), // 1.87595182427177009643\n P1 = reinterpret(0xBFFE28E092F02420), // -1.88497979543377169875\n P2 = reinterpret(0x3FF9F1604A49D6C2), // 1.621429720105354466140\n P3 = reinterpret(0xBFE844CBBEE751D9), // -0.758397934778766047437\n P4 = reinterpret(0x3FC2B000D4E4EDD7), // 0.145996192886612446982\n Ox1p54 = reinterpret(0x4350000000000000);\n var u = reinterpret(x);\n var hx = (u >> 32) & 0x7FFFFFFF;\n if (hx >= 0x7FF00000) return x + x;\n if (hx < 0x00100000) {\n u = reinterpret(x * Ox1p54);\n hx = (u >> 32) & 0x7FFFFFFF;\n if (hx == 0) return x;\n hx = hx / 3 + B2;\n } else {\n hx = hx / 3 + B1;\n }\n u &= 1 << 63;\n u |= hx << 32;\n var t = reinterpret(u);\n var r = (t * t) * (t / x);\n t = t * ((P0 + r * (P1 + r * P2)) + ((r * r) * r) * (P3 + r * P4));\n t = reinterpret((reinterpret(t) + 0x80000000) & 0xFFFFFFFFC0000000);\n var s = t * t;\n r = x / s;\n r = (r - t) / (2 * t + r);\n t = t + t * r;\n return t;\n }\n\n // @ts-ignore: decorator\n @inline\n export function ceil(x: f64): f64 {\n return builtin_ceil(x);\n }\n\n export function clz32(x: f64): f64 {\n if (!isFinite(x)) return 32;\n /*\n * Wasm (MVP) and JS have different approaches for double->int conversions.\n *\n * For emulate JS conversion behavior and avoid trapping from wasm we should modulate by MAX_INT\n * our float-point arguments before actual convertion to integers.\n */\n return builtin_clz(\n (x - 4294967296 * builtin_floor(x * (1.0 / 4294967296)))\n );\n }\n\n export function cos(x: f64): f64 { // TODO\n return JSMath.cos(x);\n }\n\n export function cosh(x: f64): f64 { // see: musl/src/math/cosh.c\n var u = reinterpret(x);\n u &= 0x7FFFFFFFFFFFFFFF;\n x = reinterpret(u);\n var w = (u >> 32);\n var t: f64;\n if (w < 0x3FE62E42) {\n if (w < 0x3FF00000 - (26 << 20)) return 1;\n t = expm1(x);\n // return 1 + t * t / (2 * (1 + t));\n return 1 + t * t / (2 + 2 * t);\n }\n if (w < 0x40862E42) {\n t = exp(x);\n return 0.5 * (t + 1 / t);\n }\n t = expo2(x);\n return t;\n }\n\n export function exp(x: f64): f64 { // see: musl/src/math/exp.c and SUN COPYRIGHT NOTICE above\n const\n ln2hi = reinterpret(0x3FE62E42FEE00000), // 6.93147180369123816490e-01\n ln2lo = reinterpret(0x3DEA39EF35793C76), // 1.90821492927058770002e-10\n invln2 = reinterpret(0x3FF71547652B82FE), // 1.44269504088896338700e+00\n P1 = reinterpret(0x3FC555555555553E), // 1.66666666666666019037e-01\n P2 = reinterpret(0xBF66C16C16BEBD93), // -2.77777777770155933842e-03\n P3 = reinterpret(0x3F11566AAF25DE2C), // 6.61375632143793436117e-05\n P4 = reinterpret(0xBEBBBD41C5D26BF1), // -1.65339022054652515390e-06\n P5 = reinterpret(0x3E66376972BEA4D0), // 4.13813679705723846039e-08\n overflow = reinterpret(0x40862E42FEFA39EF), // 709.782712893383973096\n underflow = reinterpret(0xC0874910D52D3051), // -745.13321910194110842\n Ox1p1023 = reinterpret(0x7FE0000000000000);\n var hx = (reinterpret(x) >> 32);\n var sign_ = (hx >> 31);\n hx &= 0x7FFFFFFF;\n if (hx >= 0x4086232B) {\n if (isNaN(x)) return x;\n if (x > overflow) return x * Ox1p1023;\n if (x < underflow) return 0;\n }\n var hi: f64, lo: f64 = 0;\n var k = 0;\n if (hx > 0x3FD62E42) {\n if (hx >= 0x3FF0A2B2) {\n k = (invln2 * x + builtin_copysign(0.5, x));\n } else {\n k = 1 - (sign_ << 1);\n }\n hi = x - k * ln2hi;\n lo = k * ln2lo;\n x = hi - lo;\n } else if (hx > 0x3E300000) {\n hi = x;\n } else return 1.0 + x;\n var xs = x * x;\n // var c = x - xp2 * (P1 + xp2 * (P2 + xp2 * (P3 + xp2 * (P4 + xp2 * P5))));\n var xq = xs * xs;\n var c = x - (xs * P1 + xq * ((P2 + xs * P3) + xq * (P4 + xs * P5)));\n var y = 1.0 + (x * c / (2 - c) - lo + hi);\n if (k == 0) return y;\n return scalbn(y, k);\n }\n\n export function expm1(x: f64): f64 { // see: musl/src/math/expm1.c and SUN COPYRIGHT NOTICE above\n const\n o_threshold = reinterpret(0x40862E42FEFA39EF), // 7.09782712893383973096e+02\n ln2_hi = reinterpret(0x3FE62E42FEE00000), // 6.93147180369123816490e-01\n ln2_lo = reinterpret(0x3DEA39EF35793C76), // 1.90821492927058770002e-10\n invln2 = reinterpret(0x3FF71547652B82FE), // 1.44269504088896338700e+00\n Q1 = reinterpret(0xBFA11111111110F4), // -3.33333333333331316428e-02\n Q2 = reinterpret(0x3F5A01A019FE5585), // 1.58730158725481460165e-03\n Q3 = reinterpret(0xBF14CE199EAADBB7), // -7.93650757867487942473e-05\n Q4 = reinterpret(0x3ED0CFCA86E65239), // 4.00821782732936239552e-06\n Q5 = reinterpret(0xBE8AFDB76E09C32D), // -2.01099218183624371326e-07\n Ox1p1023 = reinterpret(0x7FE0000000000000);\n var u = reinterpret(x);\n var hx = (u >> 32 & 0x7FFFFFFF);\n var k = 0, sign_ = (u >> 63);\n if (hx >= 0x4043687A) {\n if (isNaN(x)) return x;\n if (sign_) return -1;\n if (x > o_threshold) return x * Ox1p1023;\n }\n var c = 0.0, t: f64;\n if (hx > 0x3FD62E42) {\n k = select(\n 1 - (sign_ << 1),\n (invln2 * x + builtin_copysign(0.5, x)),\n hx < 0x3FF0A2B2\n );\n t = k;\n let hi = x - t * ln2_hi;\n let lo = t * ln2_lo;\n x = hi - lo;\n c = (hi - x) - lo;\n } else if (hx < 0x3C900000) return x;\n var hfx = 0.5 * x;\n var hxs = x * hfx;\n // var r1 = 1.0 + hxs * (Q1 + hxs * (Q2 + hxs * (Q3 + hxs * (Q4 + hxs * Q5))));\n var hxq = hxs * hxs;\n var r1 = (1.0 + hxs * Q1) + hxq * ((Q2 + hxs * Q3) + hxq * (Q4 + hxs * Q5));\n t = 3.0 - r1 * hfx;\n var e = hxs * ((r1 - t) / (6.0 - x * t));\n if (k == 0) return x - (x * e - hxs);\n e = x * (e - c) - c;\n e -= hxs;\n if (k == -1) return 0.5 * (x - e) - 0.5;\n if (k == 1) {\n if (x < -0.25) return -2.0 * (e - (x + 0.5));\n return 1.0 + 2.0 * (x - e);\n }\n u = (0x3FF + k) << 52;\n var twopk = reinterpret(u);\n var y: f64;\n if (k < 0 || k > 56) {\n y = x - e + 1.0;\n if (k == 1024) y = y * 2.0 * Ox1p1023;\n else y = y * twopk;\n return y - 1.0;\n }\n u = (0x3FF - k) << 52;\n y = reinterpret(u);\n if (k < 20) y = (1 - y) - e;\n else y = 1 - (e + y);\n return (x + y) * twopk;\n }\n\n // @ts-ignore: decorator\n @inline\n export function floor(x: f64): f64 {\n return builtin_floor(x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function fround(x: f64): f64 {\n return x;\n }\n\n export function hypot(x: f64, y: f64): f64 { // see: musl/src/math/hypot.c\n const\n SPLIT = reinterpret(0x41A0000000000000) + 1, // 0x1p27 + 1\n Ox1p700 = reinterpret(0x6BB0000000000000),\n Ox1p_700 = reinterpret(0x1430000000000000);\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n ux &= 0x7FFFFFFFFFFFFFFF;\n uy &= 0x7FFFFFFFFFFFFFFF;\n if (ux < uy) {\n let ut = ux;\n ux = uy;\n uy = ut;\n }\n var ex = (ux >> 52);\n var ey = (uy >> 52);\n y = reinterpret(uy);\n if (ey == 0x7FF) return y;\n x = reinterpret(ux);\n if (ex == 0x7FF || uy == 0) return x;\n if (ex - ey > 64) return x + y;\n var z = 1.0;\n if (ex > 0x3FF + 510) {\n z = Ox1p700;\n x *= Ox1p_700;\n y *= Ox1p_700;\n } else if (ey < 0x3FF - 450) {\n z = Ox1p_700;\n x *= Ox1p700;\n y *= Ox1p700;\n }\n var c = x * SPLIT;\n var h = x - c + c;\n var l = x - h;\n var hx = x * x;\n var lx = h * h - hx + (2 * h + l) * l;\n c = y * SPLIT;\n h = y - c + c;\n l = y - h;\n var hy = y * y;\n var ly = h * h - hy + (2 * h + l) * l;\n return z * builtin_sqrt(ly + lx + hy + hx);\n }\n\n export function imul(x: f64, y: f64): f64 {\n /*\n * Wasm (MVP) and JS have different approaches for double->int conversions.\n *\n * For emulate JS conversion behavior and avoid trapping from wasm we should modulate by MAX_INT\n * our float-point arguments before actual convertion to integers.\n */\n if (!isFinite(x + y)) return 0;\n const inv32 = 1.0 / 4294967296;\n return (\n (x - 4294967296 * builtin_floor(x * inv32)) *\n (y - 4294967296 * builtin_floor(y * inv32))\n );\n }\n\n export function log(x: f64): f64 { // see: musl/src/math/log.c and SUN COPYRIGHT NOTICE above\n const\n ln2_hi = reinterpret(0x3FE62E42FEE00000), // 6.93147180369123816490e-01\n ln2_lo = reinterpret(0x3DEA39EF35793C76), // 1.90821492927058770002e-10\n Lg1 = reinterpret(0x3FE5555555555593), // 6.666666666666735130e-01\n Lg2 = reinterpret(0x3FD999999997FA04), // 3.999999999940941908e-01\n Lg3 = reinterpret(0x3FD2492494229359), // 2.857142874366239149e-01\n Lg4 = reinterpret(0x3FCC71C51D8E78AF), // 2.222219843214978396e-01\n Lg5 = reinterpret(0x3FC7466496CB03DE), // 1.818357216161805012e-01\n Lg6 = reinterpret(0x3FC39A09D078C69F), // 1.531383769920937332e-01\n Lg7 = reinterpret(0x3FC2F112DF3E5244), // 1.479819860511658591e-01\n Ox1p54 = reinterpret(0x4350000000000000);\n var u = reinterpret(x);\n var hx = (u >> 32);\n var k = 0;\n if (hx < 0x00100000 || (hx >> 31)) {\n if (u << 1 == 0) return -1 / (x * x);\n if (hx >> 31) return (x - x) / 0.0;\n k -= 54;\n x *= Ox1p54;\n u = reinterpret(x);\n hx = (u >> 32);\n } else if (hx >= 0x7FF00000) return x;\n else if (hx == 0x3FF00000 && u << 32 == 0) return 0;\n hx += 0x3FF00000 - 0x3FE6A09E;\n k += (hx >> 20) - 0x3FF;\n hx = (hx & 0x000FFFFF) + 0x3FE6A09E;\n u = hx << 32 | (u & 0xFFFFFFFF);\n x = reinterpret(u);\n var f = x - 1.0;\n var hfsq = 0.5 * f * f;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * (Lg4 + w * Lg6));\n var t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7)));\n var r = t2 + t1;\n var dk = k;\n return s * (hfsq + r) + dk * ln2_lo - hfsq + f + dk * ln2_hi;\n }\n\n export function log10(x: f64): f64 { // see: musl/src/math/log10.c and SUN COPYRIGHT NOTICE above\n const\n ivln10hi = reinterpret(0x3FDBCB7B15200000), // 4.34294481878168880939e-01\n ivln10lo = reinterpret(0x3DBB9438CA9AADD5), // 2.50829467116452752298e-11\n log10_2hi = reinterpret(0x3FD34413509F6000), // 3.01029995663611771306e-01\n log10_2lo = reinterpret(0x3D59FEF311F12B36), // 3.69423907715893078616e-13\n Lg1 = reinterpret(0x3FE5555555555593), // 6.666666666666735130e-01\n Lg2 = reinterpret(0x3FD999999997FA04), // 3.999999999940941908e-01\n Lg3 = reinterpret(0x3FD2492494229359), // 2.857142874366239149e-01\n Lg4 = reinterpret(0x3FCC71C51D8E78AF), // 2.222219843214978396e-01\n Lg5 = reinterpret(0x3FC7466496CB03DE), // 1.818357216161805012e-01\n Lg6 = reinterpret(0x3FC39A09D078C69F), // 1.531383769920937332e-01\n Lg7 = reinterpret(0x3FC2F112DF3E5244), // 1.479819860511658591e-01\n Ox1p54 = reinterpret(0x4350000000000000);\n var u = reinterpret(x);\n var hx = (u >> 32);\n var k = 0;\n if (hx < 0x00100000 || (hx >> 31)) {\n if (u << 1 == 0) return -1 / (x * x);\n if (hx >> 31) return (x - x) / 0.0;\n k -= 54;\n x *= Ox1p54;\n u = reinterpret(x);\n hx = (u >> 32);\n } else if (hx >= 0x7FF00000) return x;\n else if (hx == 0x3FF00000 && u << 32 == 0) return 0;\n hx += 0x3FF00000 - 0x3FE6A09E;\n k += (hx >> 20) - 0x3FF;\n hx = (hx & 0x000FFFFF) + 0x3FE6A09E;\n u = hx << 32 | (u & 0xFFFFFFFF);\n x = reinterpret(u);\n var f = x - 1.0;\n var hfsq = 0.5 * f * f;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * (Lg4 + w * Lg6));\n var t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7)));\n var r = t2 + t1;\n var hi = f - hfsq;\n u = reinterpret(hi);\n u &= 0xFFFFFFFF00000000;\n hi = reinterpret(u);\n var lo = f - hi - hfsq + s * (hfsq + r);\n var val_hi = hi * ivln10hi;\n var dk = k;\n var y = dk * log10_2hi;\n var val_lo = dk * log10_2lo + (lo + hi) * ivln10lo + lo * ivln10hi;\n w = y + val_hi;\n val_lo += (y - w) + val_hi;\n return val_lo + w;\n }\n\n export function log1p(x: f64): f64 { // see: musl/src/math/log1p.c and SUN COPYRIGHT NOTICE above\n const\n ln2_hi = reinterpret(0x3FE62E42FEE00000), // 6.93147180369123816490e-01\n ln2_lo = reinterpret(0x3DEA39EF35793C76), // 1.90821492927058770002e-10\n Lg1 = reinterpret(0x3FE5555555555593), // 6.666666666666735130e-01\n Lg2 = reinterpret(0x3FD999999997FA04), // 3.999999999940941908e-01\n Lg3 = reinterpret(0x3FD2492494229359), // 2.857142874366239149e-01\n Lg4 = reinterpret(0x3FCC71C51D8E78AF), // 2.222219843214978396e-01\n Lg5 = reinterpret(0x3FC7466496CB03DE), // 1.818357216161805012e-01\n Lg6 = reinterpret(0x3FC39A09D078C69F), // 1.531383769920937332e-01\n Lg7 = reinterpret(0x3FC2F112DF3E5244); // 1.479819860511658591e-01\n var u = reinterpret(x);\n var hx = (u >> 32);\n var k = 1;\n var c = 0.0, f = 0.0;\n if (hx < 0x3FDA827A || (hx >> 31)) {\n if (hx >= 0xBFF00000) {\n if (x == -1) return x / 0.0;\n return (x - x) / 0.0;\n }\n if (hx << 1 < 0x3CA00000 << 1) return x;\n if (hx <= 0xBFD2BEC4) {\n k = 0;\n c = 0;\n f = x;\n }\n } else if (hx >= 0x7FF00000) return x;\n if (k) {\n u = reinterpret(1 + x);\n let hu = (u >> 32);\n hu += 0x3FF00000 - 0x3FE6A09E;\n k = (hu >> 20) - 0x3FF;\n if (k < 54) {\n let uf = reinterpret(u);\n c = k >= 2 ? 1 - (uf - x) : x - (uf - 1);\n c /= uf;\n } else c = 0;\n hu = (hu & 0x000FFFFF) + 0x3FE6A09E;\n u = hu << 32 | (u & 0xFFFFFFFF);\n f = reinterpret(u) - 1;\n }\n var hfsq = 0.5 * f * f;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * (Lg4 + w * Lg6));\n var t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7)));\n var r = t2 + t1;\n var dk = k;\n return s * (hfsq + r) + (dk * ln2_lo + c) - hfsq + f + dk * ln2_hi;\n }\n\n export function log2(x: f64): f64 { // see: musl/src/math/log2.c and SUN COPYRIGHT NOTICE above\n const\n ivln2hi = reinterpret(0x3FF7154765200000), // 1.44269504072144627571e+00\n ivln2lo = reinterpret(0x3DE705FC2EEFA200), // 1.67517131648865118353e-10\n Lg1 = reinterpret(0x3FE5555555555593), // 6.666666666666735130e-01\n Lg2 = reinterpret(0x3FD999999997FA04), // 3.999999999940941908e-01\n Lg3 = reinterpret(0x3FD2492494229359), // 2.857142874366239149e-01\n Lg4 = reinterpret(0x3FCC71C51D8E78AF), // 2.222219843214978396e-01\n Lg5 = reinterpret(0x3FC7466496CB03DE), // 1.818357216161805012e-01\n Lg6 = reinterpret(0x3FC39A09D078C69F), // 1.531383769920937332e-01\n Lg7 = reinterpret(0x3FC2F112DF3E5244), // 1.479819860511658591e-01\n Ox1p54 = reinterpret(0x4350000000000000);\n var u = reinterpret(x);\n var hx = (u >> 32);\n var k = 0;\n if (hx < 0x00100000 || (hx >> 31)) {\n if (u << 1 == 0) return -1 / (x * x);\n if (hx >> 31) return (x - x) / 0.0;\n k -= 54;\n x *= Ox1p54;\n u = reinterpret(x);\n hx = (u >> 32);\n } else if (hx >= 0x7FF00000) return x;\n else if (hx == 0x3FF00000 && u << 32 == 0) return 0;\n hx += 0x3FF00000 - 0x3FE6A09E;\n k += (hx >> 20) - 0x3FF;\n hx = (hx & 0x000FFFFF) + 0x3FE6A09E;\n u = hx << 32 | (u & 0xFFFFFFFF);\n x = reinterpret(u);\n var f = x - 1.0;\n var hfsq = 0.5 * f * f;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * (Lg4 + w * Lg6));\n var t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7)));\n var r = t2 + t1;\n var hi = f - hfsq;\n u = reinterpret(hi);\n u &= 0xFFFFFFFF00000000;\n hi = reinterpret(u);\n var lo = f - hi - hfsq + s * (hfsq + r);\n var val_hi = hi * ivln2hi;\n var val_lo = (lo + hi) * ivln2lo + lo * ivln2hi;\n var y = k;\n w = y + val_hi;\n val_lo += (y - w) + val_hi;\n val_hi = w;\n return val_lo + val_hi;\n }\n\n // @ts-ignore: decorator\n @inline\n export function max(value1: f64, value2: f64): f64 {\n return builtin_max(value1, value2);\n }\n\n // @ts-ignore: decorator\n @inline\n export function min(value1: f64, value2: f64): f64 {\n return builtin_min(value1, value2);\n }\n\n export function pow(x: f64, y: f64): f64 { // see: musl/src/math/pow.c and SUN COPYRIGHT NOTICE above\n const\n dp_h1 = reinterpret(0x3FE2B80340000000), // 5.84962487220764160156e-01\n dp_l1 = reinterpret(0x3E4CFDEB43CFD006), // 1.35003920212974897128e-08\n two53 = reinterpret(0x4340000000000000), // 9007199254740992.0\n huge = reinterpret(0x7E37E43C8800759C), // 1e+300\n tiny = reinterpret(0x01A56E1FC2F8F359), // 1e-300\n L1 = reinterpret(0x3FE3333333333303), // 5.99999999999994648725e-01\n L2 = reinterpret(0x3FDB6DB6DB6FABFF), // 4.28571428578550184252e-01\n L3 = reinterpret(0x3FD55555518F264D), // 3.33333329818377432918e-01\n L4 = reinterpret(0x3FD17460A91D4101), // 2.72728123808534006489e-01\n L5 = reinterpret(0x3FCD864A93C9DB65), // 2.30660745775561754067e-01\n L6 = reinterpret(0x3FCA7E284A454EEF), // 2.06975017800338417784e-01\n P1 = reinterpret(0x3FC555555555553E), // 1.66666666666666019037e-01\n P2 = reinterpret(0xBF66C16C16BEBD93), // -2.77777777770155933842e-03\n P3 = reinterpret(0x3F11566AAF25DE2C), // 6.61375632143793436117e-05\n P4 = reinterpret(0xBEBBBD41C5D26BF1), // -1.65339022054652515390e-06\n P5 = reinterpret(0x3E66376972BEA4D0), // 4.13813679705723846039e-08\n lg2 = reinterpret(0x3FE62E42FEFA39EF), // 6.93147180559945286227e-01\n lg2_h = reinterpret(0x3FE62E4300000000), // 6.93147182464599609375e-01\n lg2_l = reinterpret(0xBE205C610CA86C39), // -1.90465429995776804525e-09\n ovt = reinterpret(0x3C971547652B82FE), // 8.0085662595372944372e-017\n cp = reinterpret(0x3FEEC709DC3A03FD), // 9.61796693925975554329e-01\n cp_h = reinterpret(0x3FEEC709E0000000), // 9.61796700954437255859e-01\n cp_l = reinterpret(0xBE3E2FE0145B01F5), // -7.02846165095275826516e-09\n ivln2 = reinterpret(0x3FF71547652B82FE), // 1.44269504088896338700e+00\n ivln2_h = reinterpret(0x3FF7154760000000), // 1.44269502162933349609e+00\n ivln2_l = reinterpret(0x3E54AE0BF85DDF44), // 1.92596299112661746887e-08\n inv3 = reinterpret(0x3FD5555555555555); // 0.3333333333333333333333\n var u_ = reinterpret(x);\n var hx = (u_ >> 32);\n var lx = u_;\n u_ = reinterpret(y);\n var hy = (u_ >> 32);\n var ly = u_;\n var ix = hx & 0x7FFFFFFF;\n var iy = hy & 0x7FFFFFFF;\n if ((iy | ly) == 0) return 1.0; // x**0 = 1, even if x is NaN\n // if (hx == 0x3FF00000 && lx == 0) return 1.0; // C: 1**y = 1, even if y is NaN, JS: NaN\n if ( // NaN if either arg is NaN\n ix > 0x7FF00000 || (ix == 0x7FF00000 && lx != 0) ||\n iy > 0x7FF00000 || (iy == 0x7FF00000 && ly != 0)\n ) return x + y;\n var yisint = 0, k: i32;\n if (hx < 0) {\n if (iy >= 0x43400000) yisint = 2;\n else if (iy >= 0x3FF00000) {\n k = (iy >> 20) - 0x3FF;\n let kcond = k > 20;\n let offset = select(52, 20, kcond) - k;\n let Ly = select(ly, iy, kcond);\n let jj = Ly >> offset;\n if ((jj << offset) == Ly) yisint = 2 - (jj & 1);\n }\n }\n if (ly == 0) {\n if (iy == 0x7FF00000) { // y is +-inf\n if (((ix - 0x3FF00000) | lx) == 0) return NaN; // C: (-1)**+-inf is 1, JS: NaN\n else if (ix >= 0x3FF00000) return hy >= 0 ? y : 0.0; // (|x|>1)**+-inf = inf,0\n else return hy >= 0 ? 0.0 : -y; // (|x|<1)**+-inf = 0,inf\n }\n if (iy == 0x3FF00000) {\n if (hy >= 0) return x;\n return 1 / x;\n }\n if (hy == 0x40000000) return x * x;\n if (hy == 0x3FE00000) {\n if (hx >= 0) return builtin_sqrt(x);\n }\n }\n var ax = builtin_abs(x), z: f64;\n if (lx == 0) {\n if (ix == 0 || ix == 0x7FF00000 || ix == 0x3FF00000) {\n z = ax;\n if (hy < 0) z = 1.0 / z;\n if (hx < 0) {\n if (((ix - 0x3FF00000) | yisint) == 0) {\n let d = z - z;\n z = d / d;\n } else if (yisint == 1) z = -z;\n }\n return z;\n }\n }\n var s = 1.0;\n if (hx < 0) {\n if (yisint == 0) {\n let d = x - x;\n return d / d;\n }\n if (yisint == 1) s = -1.0;\n }\n var t1: f64, t2: f64, p_h: f64, p_l: f64, r: f64, t: f64, u: f64, v: f64, w: f64;\n var j: i32, n: i32;\n if (iy > 0x41E00000) {\n if (iy > 0x43F00000) {\n if (ix <= 0x3FEFFFFF) return hy < 0 ? huge * huge : tiny * tiny;\n if (ix >= 0x3FF00000) return hy > 0 ? huge * huge : tiny * tiny;\n }\n if (ix < 0x3FEFFFFF) return hy < 0 ? s * huge * huge : s * tiny * tiny;\n if (ix > 0x3FF00000) return hy > 0 ? s * huge * huge : s * tiny * tiny;\n t = ax - 1.0;\n w = (t * t) * (0.5 - t * (inv3 - t * 0.25));\n u = ivln2_h * t;\n v = t * ivln2_l - w * ivln2;\n t1 = u + v;\n t1 = reinterpret(reinterpret(t1) & 0xFFFFFFFF00000000);\n t2 = v - (t1 - u);\n } else {\n let ss: f64, s2: f64, s_h: f64, s_l: f64, t_h: f64, t_l: f64;\n n = 0;\n if (ix < 0x00100000) {\n ax *= two53;\n n -= 53;\n ix = (reinterpret(ax) >> 32);\n }\n n += (ix >> 20) - 0x3FF;\n j = ix & 0x000FFFFF;\n ix = j | 0x3FF00000;\n if (j <= 0x3988E) k = 0;\n else if (j < 0xBB67A) k = 1;\n else {\n k = 0;\n n += 1;\n ix -= 0x00100000;\n }\n ax = reinterpret(reinterpret(ax) & 0xFFFFFFFF | (ix << 32));\n let bp = select(1.5, 1.0, k); // k ? 1.5 : 1.0\n u = ax - bp;\n v = 1.0 / (ax + bp);\n ss = u * v;\n s_h = ss;\n s_h = reinterpret(reinterpret(s_h) & 0xFFFFFFFF00000000);\n t_h = reinterpret((((ix >> 1) | 0x20000000) + 0x00080000 + (k << 18)) << 32);\n t_l = ax - (t_h - bp);\n s_l = v * ((u - s_h * t_h) - s_h * t_l);\n s2 = ss * ss;\n r = s2 * s2 * (L1 + s2 * (L2 + s2 * (L3 + s2 * (L4 + s2 * (L5 + s2 * L6)))));\n r += s_l * (s_h + ss);\n s2 = s_h * s_h;\n t_h = 3.0 + s2 + r;\n t_h = reinterpret(reinterpret(t_h) & 0xFFFFFFFF00000000);\n t_l = r - ((t_h - 3.0) - s2);\n u = s_h * t_h;\n v = s_l * t_h + t_l * ss;\n p_h = u + v;\n p_h = reinterpret(reinterpret(p_h) & 0xFFFFFFFF00000000);\n p_l = v - (p_h - u);\n let z_h = cp_h * p_h;\n let dp_l = select(dp_l1, 0.0, k);\n let z_l = cp_l * p_h + p_l * cp + dp_l;\n t = n;\n let dp_h = select(dp_h1, 0.0, k);\n t1 = ((z_h + z_l) + dp_h) + t;\n t1 = reinterpret(reinterpret(t1) & 0xFFFFFFFF00000000);\n t2 = z_l - (((t1 - t) - dp_h) - z_h);\n }\n var y1 = y;\n y1 = reinterpret(reinterpret(y1) & 0xFFFFFFFF00000000);\n p_l = (y - y1) * t1 + y * t2;\n p_h = y1 * t1;\n z = p_l + p_h;\n u_ = reinterpret(z);\n j = (u_ >> 32);\n var i = u_;\n if (j >= 0x40900000) {\n if (((j - 0x40900000) | i) != 0) return s * huge * huge;\n if (p_l + ovt > z - p_h) return s * huge * huge;\n } else if ((j & 0x7FFFFFFF) >= 0x4090CC00) {\n if (((j - 0xC090CC00) | i) != 0) return s * tiny * tiny;\n if (p_l <= z - p_h) return s * tiny * tiny;\n }\n i = j & 0x7FFFFFFF;\n k = (i >> 20) - 0x3FF;\n n = 0;\n if (i > 0x3FE00000) {\n n = j + (0x00100000 >> (k + 1));\n k = ((n & 0x7FFFFFFF) >> 20) - 0x3FF;\n t = 0.0;\n t = reinterpret((n & ~(0x000FFFFF >> k)) << 32);\n n = ((n & 0x000FFFFF) | 0x00100000) >> (20 - k);\n if (j < 0) n = -n;\n p_h -= t;\n }\n t = p_l + p_h;\n t = reinterpret(reinterpret(t) & 0xFFFFFFFF00000000);\n u = t * lg2_h;\n v = (p_l - (t - p_h)) * lg2 + t * lg2_l;\n z = u + v;\n w = v - (z - u);\n t = z * z;\n t1 = z - t * (P1 + t * (P2 + t * (P3 + t * (P4 + t * P5))));\n r = (z * t1) / (t1 - 2.0) - (w + z * w);\n z = 1.0 - (r - z);\n j = (reinterpret(z) >> 32);\n j += n << 20;\n if ((j >> 20) <= 0) z = scalbn(z, n);\n else z = reinterpret(reinterpret(z) & 0xFFFFFFFF | (j << 32));\n return s * z;\n }\n\n export function seedRandom(value: i64): void {\n assert(value);\n random_seeded = true;\n random_state0_64 = murmurHash3(value);\n random_state1_64 = murmurHash3(~random_state0_64);\n random_state0_32 = splitMix32(value);\n random_state1_32 = splitMix32(random_state0_32);\n }\n\n export function random(): f64 { // see: v8/src/base/random-number-generator.cc\n if (!random_seeded) throw new Error("PRNG must be seeded.");\n var s1 = random_state0_64;\n var s0 = random_state1_64;\n random_state0_64 = s0;\n s1 ^= s1 << 23;\n s1 ^= s1 >> 17;\n s1 ^= s0;\n s1 ^= s0 >> 26;\n random_state1_64 = s1;\n var r = ((s0 + s1) & 0x000FFFFFFFFFFFFF) | 0x3FF0000000000000;\n return reinterpret(r) - 1;\n }\n\n // @ts-ignore: decorator\n @inline\n export function round(x: f64): f64 {\n return builtin_copysign(builtin_floor(x + 0.5), x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function sign(x: f64): f64 {\n if (ASC_SHRINK_LEVEL > 0) {\n return builtin_abs(x) > 0 ? builtin_copysign(1, x) : x;\n } else {\n return x > 0 ? 1 : x < 0 ? -1 : x;\n }\n }\n\n // @ts-ignore: decorator\n @inline\n export function signbit(x: f64): bool {\n // In ECMAScript all NaN values are indistinguishable from each other\n // so we need handle NaN and negative NaN in similar way\n return ((reinterpret(x) >>> 63) & i32(x == x));\n }\n\n export function sin(x: f64): f64 { // TODO\n return JSMath.sin(x);\n }\n\n export function sinh(x: f64): f64 { // see: musl/src/math/sinh.c\n var u = reinterpret(x) & 0x7FFFFFFFFFFFFFFF;\n var absx = reinterpret(u);\n var w = (u >> 32);\n var t: f64;\n var h = builtin_copysign(0.5, x);\n if (w < 0x40862E42) {\n t = expm1(absx);\n if (w < 0x3FF00000) {\n if (w < 0x3FF00000 - (26 << 20)) return x;\n return h * (2 * t - t * t / (t + 1));\n }\n return h * (t + t / (t + 1));\n }\n t = 2 * h * expo2(absx);\n return t;\n }\n\n // @ts-ignore: decorator\n @inline\n export function sqrt(x: f64): f64 {\n return builtin_sqrt(x);\n }\n\n export function tan(x: f64): f64 { // TODO\n return JSMath.tan(x);\n }\n\n export function tanh(x: f64): f64 { // see: musl/src/math/tanh.c\n var u = reinterpret(x);\n u &= 0x7FFFFFFFFFFFFFFF;\n var y = reinterpret(u);\n var w = (u >> 32);\n var t: f64;\n if (w > 0x3FE193EA) {\n if (w > 0x40340000) {\n t = 1 - 0 / y;\n } else {\n t = expm1(2 * y);\n t = 1 - 2 / (t + 2);\n }\n } else if (w > 0x3FD058AE) {\n t = expm1(2 * y);\n t = t / (t + 2);\n } else if (w >= 0x00100000) {\n t = expm1(-2 * y);\n t = -t / (t + 2);\n } else t = y;\n return builtin_copysign(t, x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function trunc(x: f64): f64 {\n return builtin_trunc(x);\n }\n\n export function scalbn(x: f64, n: i32): f64 { // see: https://git.musl-libc.org/cgit/musl/tree/src/math/scalbn.c\n const\n Ox1p53 = reinterpret(0x4340000000000000),\n Ox1p1023 = reinterpret(0x7FE0000000000000),\n Ox1p_1022 = reinterpret(0x0010000000000000);\n var y = x;\n if (n > 1023) {\n y *= Ox1p1023;\n n -= 1023;\n if (n > 1023) {\n y *= Ox1p1023;\n n = builtin_min(n - 1023, 1023);\n }\n } else if (n < -1022) {\n /* make sure final n < -53 to avoid double\n rounding in the subnormal range */\n y *= Ox1p_1022 * Ox1p53;\n n += 1022 - 53;\n if (n < -1022) {\n y *= Ox1p_1022 * Ox1p53;\n n = builtin_max(n + 1022 - 53, -1022);\n }\n }\n return y * reinterpret((0x3FF + n) << 52);\n }\n\n export function mod(x: f64, y: f64): f64 { // see: musl/src/math/fmod.c\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n var ex = (ux >> 52 & 0x7FF);\n var ey = (uy >> 52 & 0x7FF);\n var sx = ux >> 63;\n var uy1 = uy << 1;\n if (uy1 == 0 || ex == 0x7FF || isNaN(y)) {\n let m = x * y;\n return m / m;\n }\n var ux1 = ux << 1;\n if (ux1 <= uy1) {\n if (ux1 == uy1) return 0 * x;\n return x;\n }\n if (!ex) {\n ex -= builtin_clz(ux << 12);\n ux <<= -ex + 1;\n } else {\n ux &= -1 >> 12;\n ux |= 1 << 52;\n }\n if (!ey) {\n ey -= builtin_clz(uy << 12);\n uy <<= -ey + 1;\n } else {\n uy &= -1 >> 12;\n uy |= 1 << 52;\n }\n while (ex > ey) {\n if (ux >= uy) {\n if (ux == uy) return 0 * x;\n ux -= uy;\n }\n ux <<= 1;\n --ex;\n }\n if (ux >= uy) {\n if (ux == uy) return 0 * x;\n ux -= uy;\n }\n // for (; !(ux >> 52); ux <<= 1) --ex;\n var shift = builtin_clz(ux << 11);\n ex -= shift;\n ux <<= shift;\n if (ex > 0) {\n ux -= 1 << 52;\n ux |= ex << 52;\n } else {\n ux >>= -ex + 1;\n }\n ux |= sx << 63;\n return reinterpret(ux);\n }\n\n export function rem(x: f64, y: f64): f64 { // see: musl/src/math/remquo.c\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n var ex = (ux >> 52 & 0x7FF);\n var ey = (uy >> 52 & 0x7FF);\n var sx = (ux >> 63);\n if (uy << 1 == 0 || ex == 0x7FF || isNaN(y)) {\n let m = x * y;\n return m / m;\n }\n if (ux << 1 == 0) return x;\n var uxi = ux;\n if (!ex) {\n ex -= builtin_clz(uxi << 12);\n uxi <<= -ex + 1;\n } else {\n uxi &= -1 >> 12;\n uxi |= 1 << 52;\n }\n if (!ey) {\n ey -= builtin_clz(uy << 12);\n uy <<= -ey + 1;\n } else {\n uy &= -1 >> 12;\n uy |= 1 << 52;\n }\n var q: u32 = 0;\n do {\n if (ex < ey) {\n if (ex + 1 == ey) break; // goto end\n return x;\n }\n while (ex > ey) {\n if (uxi >= uy) {\n uxi -= uy;\n ++q;\n }\n uxi <<= 1;\n q <<= 1;\n --ex;\n }\n if (uxi >= uy) {\n uxi -= uy;\n ++q;\n }\n if (uxi == 0) ex = -60;\n else {\n let shift = builtin_clz(uxi << 11);\n ex -= shift;\n uxi <<= shift;\n }\n break;\n } while (false);\n // end:\n if (ex > 0) {\n uxi -= 1 << 52;\n uxi |= ex << 52;\n } else {\n uxi >>= -ex + 1;\n }\n x = reinterpret(uxi);\n y = builtin_abs(y);\n var x2 = x + x;\n if (ex == ey || (ex + 1 == ey && (x2 > y || (x2 == y && (q & 1))))) {\n x -= y;\n // ++q;\n }\n return sx ? -x : x;\n }\n}\n\n// @ts-ignore: decorator\n@lazy\nvar rempio2f_y: f64;\n\n// @ts-ignore: decorator\n@lazy\nconst PIO2_TABLE: u64[] = [\n 0xA2F9836E4E441529,\n 0xFC2757D1F534DDC0,\n 0xDB6295993C439041,\n 0xFE5163ABDEBBC561\n];\n\nfunction Rf(z: f32): f32 { // Rational approximation of (asin(x)-x)/x^3\n const // see: musl/src/math/asinf.c and SUN COPYRIGHT NOTICE above\n pS0 = reinterpret(0x3E2AAA75), // 1.6666586697e-01f\n pS1 = reinterpret(0xBD2F13BA), // -4.2743422091e-02f\n pS2 = reinterpret(0xBC0DD36B), // -8.6563630030e-03f\n qS1 = reinterpret(0xBF34E5AE); // -7.0662963390e-01f\n var p = z * (pS0 + z * (pS1 + z * pS2));\n var q: f32 = 1 + z * qS1;\n return p / q;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction expo2f(x: f32): f32 { // exp(x)/2 for x >= log(DBL_MAX)\n const // see: musl/src/math/__expo2f.c\n k = 235,\n kln2 = reinterpret(0x4322E3BC); // 0x1.45c778p+7f\n var scale = reinterpret((0x7F + (k >> 1)) << 23);\n return NativeMathf.exp(x - kln2) * scale * scale;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction pio2_large_quot(x: f32, u: i32): i32 { // see: jdh8/metallic/blob/master/src/math/float/rem_pio2f.c\n const coeff = reinterpret(0x3BF921FB54442D18); // π * 0x1p-65 = 8.51530395021638647334e-20\n const bits = PIO2_TABLE;\n\n var offset = (u >> 23) - 152;\n var index = offset >> 6;\n var shift = offset & 63;\n\n var b0 = unchecked(bits[index + 0]);\n var b1 = unchecked(bits[index + 1]);\n var lo: u64;\n\n if (shift > 32) {\n let b2 = unchecked(bits[index + 2]);\n lo = b2 >> (96 - shift);\n lo |= b1 << (shift - 32);\n } else {\n lo = b1 >> (32 - shift);\n }\n\n var hi = (b1 >> (64 - shift)) | (b0 << shift);\n var mantissa: u64 = (u & 0x007FFFFF) | 0x00800000;\n var product: u64 = mantissa * hi + (mantissa * lo >> 32);\n var r: i64 = product << 2;\n var q: i32 = ((product >> 62) + (r >>> 63));\n rempio2f_y = copysign(coeff, x) * r;\n return q;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction rempio2f(x: f32, u: u32, sign: i32): i32 { // see: jdh8/metallic/blob/master/src/math/float/rem_pio2f.c\n const pi2hi = reinterpret(0x3FF921FB50000000); // 1.57079631090164184570\n const pi2lo = reinterpret(0x3E5110B4611A6263); // 1.58932547735281966916e-8\n const _2_pi = reinterpret(0x3FE45F306DC9C883); // 0.63661977236758134308\n\n if (u < 0x4DC90FDB) { /* π * 0x1p28 */\n let q = nearest(x * _2_pi);\n rempio2f_y = x - q * pi2hi - q * pi2lo;\n return q;\n }\n\n var q = pio2_large_quot(x, u);\n return select(-q, q, sign);\n}\n\n/* |sin(x)/x - s(x)| < 2**-37.5 (~[-4.89e-12, 4.824e-12]). */\n// @ts-ignore: decorator\n@inline\nfunction sin_kernf(x: f64): f32 { // see: musl/tree/src/math/__sindf.c\n const S1 = reinterpret(0xBFC5555554CBAC77); // -0x15555554cbac77.0p-55\n const S2 = reinterpret(0x3F811110896EFBB2); // 0x111110896efbb2.0p-59\n const S3 = reinterpret(0xBF2A00F9E2CAE774); // -0x1a00f9e2cae774.0p-65\n const S4 = reinterpret(0x3EC6CD878C3B46A7); // 0x16cd878c3b46a7.0p-71\n\n var z = x * x;\n var w = z * z;\n var r = S3 + z * S4;\n var s = z * x;\n return ((x + s * (S1 + z * S2)) + s * w * r);\n}\n\n/* |cos(x) - c(x)| < 2**-34.1 (~[-5.37e-11, 5.295e-11]). */\n// @ts-ignore: decorator\n@inline\nfunction cos_kernf(x: f64): f32 { // see: musl/tree/src/math/__cosdf.c\n const C0 = reinterpret(0xBFDFFFFFFD0C5E81); // -0x1ffffffd0c5e81.0p-54\n const C1 = reinterpret(0x3FA55553E1053A42); // 0x155553e1053a42.0p-57\n const C2 = reinterpret(0xBF56C087E80F1E27); // -0x16c087e80f1e27.0p-62\n const C3 = reinterpret(0x3EF99342E0EE5069); // 0x199342e0ee5069.0p-68\n\n var z = x * x;\n var w = z * z;\n var r = C2 + z * C3;\n return (((1 + z * C0) + w * C1) + (w * z) * r);\n}\n\n/* |tan(x)/x - t(x)| < 2**-25.5 (~[-2e-08, 2e-08]). */\n// @ts-ignore: decorator\n@inline\nfunction tan_kernf(x: f64, odd: i32): f32 { // see: musl/tree/src/math/__tandf.c\n\n const T0 = reinterpret(0x3FD5554D3418C99F); /* 0x15554d3418c99f.0p-54 */\n const T1 = reinterpret(0x3FC112FD38999F72); /* 0x1112fd38999f72.0p-55 */\n const T2 = reinterpret(0x3FAB54C91D865AFE); /* 0x1b54c91d865afe.0p-57 */\n const T3 = reinterpret(0x3F991DF3908C33CE); /* 0x191df3908c33ce.0p-58 */\n const T4 = reinterpret(0x3F685DADFCECF44E); /* 0x185dadfcecf44e.0p-61 */\n const T5 = reinterpret(0x3F8362B9BF971BCD); /* 0x1362b9bf971bcd.0p-59 */\n\n var z = x * x;\n var r = T4 + z * T5;\n var t = T2 + z * T3;\n var w = z * z;\n var s = z * x;\n var u = T0 + z * T1;\n\n r = (x + s * u) + (s * w) * (t + w * r);\n return (odd ? -1 / r : r);\n}\n\nexport namespace NativeMathf {\n\n // @ts-ignore: decorator\n @lazy\n export const E = NativeMath.E;\n\n // @ts-ignore: decorator\n @lazy\n export const LN2 = NativeMath.LN2;\n\n // @ts-ignore: decorator\n @lazy\n export const LN10 = NativeMath.LN10;\n\n // @ts-ignore: decorator\n @lazy\n export const LOG2E = NativeMath.LOG2E;\n\n // @ts-ignore: decorator\n @lazy\n export const LOG10E = NativeMath.LOG10E;\n\n // @ts-ignore: decorator\n @lazy\n export const PI = NativeMath.PI;\n\n // @ts-ignore: decorator\n @lazy\n export const SQRT1_2 = NativeMath.SQRT1_2;\n\n // @ts-ignore: decorator\n @lazy\n export const SQRT2 = NativeMath.SQRT2;\n\n // @ts-ignore: decorator\n @lazy\n export var sincos_sin: f32 = 0;\n\n // @ts-ignore: decorator\n @lazy\n export var sincos_cos: f32 = 0;\n\n // @ts-ignore: decorator\n @inline\n export function abs(x: f32): f32 {\n return builtin_abs(x);\n }\n\n export function acos(x: f32): f32 { // see: musl/src/math/acosf.c and SUN COPYRIGHT NOTICE above\n const\n pio2_hi = reinterpret(0x3FC90FDA), // 1.5707962513e+00f\n pio2_lo = reinterpret(0x33A22168), // 7.5497894159e-08f\n Ox1p_120f = reinterpret(0x03800000);\n var hx = reinterpret(x);\n var ix = hx & 0x7FFFFFFF;\n if (ix >= 0x3F800000) {\n if (ix == 0x3F800000) {\n if (hx >> 31) return 2 * pio2_hi + Ox1p_120f;\n return 0;\n }\n return 0 / (x - x);\n }\n if (ix < 0x3F000000) {\n if (ix <= 0x32800000) return pio2_hi + Ox1p_120f;\n return pio2_hi - (x - (pio2_lo - x * Rf(x * x)));\n }\n var z: f32, w: f32, s: f32;\n if (hx >> 31) {\n // z = (1 + x) * 0.5;\n z = 0.5 + x * 0.5;\n s = builtin_sqrt(z);\n w = Rf(z) * s - pio2_lo;\n return 2 * (pio2_hi - (s + w));\n }\n // z = (1 - x) * 0.5;\n z = 0.5 - x * 0.5;\n s = builtin_sqrt(z);\n hx = reinterpret(s);\n var df = reinterpret(hx & 0xFFFFF000);\n var c = (z - df * df) / (s + df);\n w = Rf(z) * s + c;\n return 2 * (df + w);\n }\n\n export function acosh(x: f32): f32 { // see: musl/src/math/acoshf.c\n const s = reinterpret(0x3F317218); // 0.693147180559945309417232121458176568f\n var u = reinterpret(x);\n var a = u & 0x7FFFFFFF;\n if (a < 0x3F800000 + (1 << 23)) {\n let xm1 = x - 1;\n return log1p(xm1 + builtin_sqrt(xm1 * (xm1 + 2)));\n }\n if (a < 0x3F800000 + (12 << 23)) return log(2 * x - 1 / (x + builtin_sqrt(x * x - 1)));\n return log(x) + s;\n }\n\n export function asin(x: f32): f32 { // see: musl/src/math/asinf.c and SUN COPYRIGHT NOTICE above\n const\n pio2 = reinterpret(0x3FC90FDB), // 1.570796326794896558e+00f\n Ox1p_120f = reinterpret(0x03800000);\n var sx = x;\n var hx = reinterpret(x) & 0x7FFFFFFF;\n if (hx >= 0x3F800000) {\n if (hx == 0x3F800000) return x * pio2 + Ox1p_120f;\n return 0 / (x - x);\n }\n if (hx < 0x3F000000) {\n if (hx < 0x39800000 && hx >= 0x00800000) return x;\n return x + x * Rf(x * x);\n }\n // var z: f32 = (1 - builtin_abs(x)) * 0.5;\n var z: f32 = 0.5 - builtin_abs(x) * 0.5;\n var s = builtin_sqrt(z); // sic\n x = (pio2 - 2 * (s + s * Rf(z)));\n return builtin_copysign(x, sx);\n }\n\n export function asinh(x: f32): f32 { // see: musl/src/math/asinhf.c\n const c = reinterpret(0x3F317218); // 0.693147180559945309417232121458176568f\n var u = reinterpret(x) & 0x7FFFFFFF;\n var y = reinterpret(u);\n if (u >= 0x3F800000 + (12 << 23)) y = log(y) + c;\n else if (u >= 0x3F800000 + (1 << 23)) y = log(2 * y + 1 / (builtin_sqrt(y * y + 1) + y));\n else if (u >= 0x3F800000 - (12 << 23)) y = log1p(y + y * y / (builtin_sqrt(y * y + 1) + 1));\n return builtin_copysign(y, x);\n }\n\n export function atan(x: f32): f32 { // see: musl/src/math/atanf.c and SUN COPYRIGHT NOTICE above\n const\n atanhi0 = reinterpret(0x3EED6338), // 4.6364760399e-01f\n atanhi1 = reinterpret(0x3F490FDA), // 7.8539812565e-01f\n atanhi2 = reinterpret(0x3F7B985E), // 9.8279368877e-01f\n atanhi3 = reinterpret(0x3FC90FDA), // 1.5707962513e+00f\n atanlo0 = reinterpret(0x31AC3769), // 5.0121582440e-09f\n atanlo1 = reinterpret(0x33222168), // 3.7748947079e-08f\n atanlo2 = reinterpret(0x33140FB4), // 3.4473217170e-08f\n atanlo3 = reinterpret(0x33A22168), // 7.5497894159e-08f\n aT0 = reinterpret(0x3EAAAAA9), // 3.3333328366e-01f\n aT1 = reinterpret(0xBE4CCA98), // -1.9999158382e-01f\n aT2 = reinterpret(0x3E11F50D), // 1.4253635705e-01f\n aT3 = reinterpret(0xBDDA1247), // -1.0648017377e-01f\n aT4 = reinterpret(0x3D7CAC25), // 6.1687607318e-02f\n Ox1p_120f = reinterpret(0x03800000);\n var ix = reinterpret(x);\n var sx = x;\n ix &= 0x7FFFFFFF;\n var z: f32;\n if (ix >= 0x4C800000) {\n if (isNaN(x)) return x;\n z = atanhi3 + Ox1p_120f;\n return builtin_copysign(z, sx);\n }\n var id: i32;\n if (ix < 0x3EE00000) {\n if (ix < 0x39800000) return x;\n id = -1;\n } else {\n x = builtin_abs(x);\n if (ix < 0x3F980000) {\n if (ix < 0x3F300000) {\n id = 0;\n x = (2.0 * x - 1.0) / (2.0 + x);\n } else {\n id = 1;\n x = (x - 1.0) / (x + 1.0);\n }\n } else {\n if (ix < 0x401C0000) {\n id = 2;\n x = (x - 1.5) / (1.0 + 1.5 * x);\n } else {\n id = 3;\n x = -1.0 / x;\n }\n }\n }\n z = x * x;\n var w = z * z;\n var s1 = z * (aT0 + w * (aT2 + w * aT4));\n var s2 = w * (aT1 + w * aT3);\n var s3 = x * (s1 + s2);\n if (id < 0) return x - s3;\n switch (id) {\n case 0: { z = atanhi0 - ((s3 - atanlo0) - x); break; }\n case 1: { z = atanhi1 - ((s3 - atanlo1) - x); break; }\n case 2: { z = atanhi2 - ((s3 - atanlo2) - x); break; }\n case 3: { z = atanhi3 - ((s3 - atanlo3) - x); break; }\n default: unreachable();\n }\n return builtin_copysign(z, sx);\n }\n\n export function atanh(x: f32): f32 { // see: musl/src/math/atanhf.c\n var u = reinterpret(x);\n u &= 0x7FFFFFFF;\n var y = reinterpret(u);\n if (u < 0x3F800000 - (1 << 23)) {\n if (u >= 0x3F800000 - (32 << 23)) y = 0.5 * log1p(2 * y * (1.0 + y / (1 - y)));\n } else y = 0.5 * log1p(2 * (y / (1 - y)));\n return builtin_copysign(y, x);\n }\n\n export function atan2(y: f32, x: f32): f32 { // see: musl/src/math/atan2f.c and SUN COPYRIGHT NOTICE above\n const\n pi = reinterpret(0x40490FDB), // 3.1415927410e+00f\n pi_lo = reinterpret(0xB3BBBD2E); // -8.7422776573e-08f\n if (isNaN(x) || isNaN(y)) return x + y;\n var ix = reinterpret(x);\n var iy = reinterpret(y);\n if (ix == 0x3F800000) return atan(y);\n var m = (((iy >> 31) & 1) | ((ix >> 30) & 2));\n ix &= 0x7FFFFFFF;\n iy &= 0x7FFFFFFF;\n if (iy == 0) {\n switch (m) {\n case 0:\n case 1: return y;\n case 2: return pi;\n case 3: return -pi;\n }\n }\n if (ix == 0) return m & 1 ? -pi / 2 : pi / 2;\n if (ix == 0x7F800000) {\n if (iy == 0x7F800000) {\n switch (m) {\n case 0: return pi / 4;\n case 1: return -pi / 4;\n case 2: return 3 * pi / 4;\n case 3: return -3 * pi / 4;\n }\n } else {\n switch (m) {\n case 0: return 0;\n case 1: return -0;\n case 2: return pi;\n case 3: return -pi;\n }\n }\n }\n if (ix + (26 << 23) < iy || iy == 0x7F800000) return m & 1 ? -pi / 2 : pi / 2;\n var z: f32;\n if ((m & 2) && iy + (26 << 23) < ix) z = 0.0;\n else z = atan(builtin_abs(y / x));\n switch (m) {\n case 0: return z;\n case 1: return -z;\n case 2: return pi - (z - pi_lo);\n case 3: return (z - pi_lo) - pi;\n }\n unreachable();\n return 0;\n }\n\n export function cbrt(x: f32): f32 { // see: musl/src/math/cbrtf.c and SUN COPYRIGHT NOTICE above\n const\n B1 = 709958130,\n B2 = 642849266,\n Ox1p24f = reinterpret(0x4B800000);\n var u = reinterpret(x);\n var hx = u & 0x7FFFFFFF;\n if (hx >= 0x7F800000) return x + x;\n if (hx < 0x00800000) {\n if (hx == 0) return x;\n u = reinterpret(x * Ox1p24f);\n hx = u & 0x7FFFFFFF;\n hx = hx / 3 + B2;\n } else {\n hx = hx / 3 + B1;\n }\n u &= 0x80000000;\n u |= hx;\n var t = reinterpret(u);\n var r = t * t * t;\n t = t * (x + x + r) / (x + r + r);\n r = t * t * t;\n t = t * (x + x + r) / (x + r + r);\n return t;\n }\n\n // @ts-ignore: decorator\n @inline\n export function ceil(x: f32): f32 {\n return builtin_ceil(x);\n }\n\n export function clz32(x: f32): f32 {\n if (!isFinite(x)) return 32;\n return builtin_clz(\n (x - 4294967296 * builtin_floor(x * (1.0 / 4294967296)))\n );\n }\n\n export function cos(x: f32): f32 { // see: musl/src/math/cosf.c\n const c1pio2 = reinterpret(0x3FF921FB54442D18); // M_PI_2 * 1\n const c2pio2 = reinterpret(0x400921FB54442D18); // M_PI_2 * 2\n const c3pio2 = reinterpret(0x4012D97C7F3321D2); // M_PI_2 * 3\n const c4pio2 = reinterpret(0x401921FB54442D18); // M_PI_2 * 4\n\n var ix = reinterpret(x);\n var sign = ix >> 31;\n ix &= 0x7FFFFFFF;\n\n if (ix <= 0x3f490fda) { /* |x| ~<= π/4 */\n if (ix < 0x39800000) { /* |x| < 2**-12 */\n /* raise inexact if x != 0 */\n return 1;\n }\n return cos_kernf(x);\n }\n\n if (ASC_SHRINK_LEVEL < 1) {\n if (ix <= 0x407b53d1) { /* |x| ~<= 5π/4 */\n if (ix > 0x4016cbe3) { /* |x| ~> 3π/4 */\n return -cos_kernf(sign ? x + c2pio2 : x - c2pio2);\n } else {\n return sign ? sin_kernf(x + c1pio2) : sin_kernf(c1pio2 - x);\n }\n }\n if (ix <= 0x40e231d5) { /* |x| ~<= 9π/4 */\n if (ix > 0x40afeddf) { /* |x| ~> 7π/4 */\n return cos_kernf(sign ? x + c4pio2 : x - c4pio2);\n } else {\n return sign ? sin_kernf(-x - c3pio2) : sin_kernf(x - c3pio2);\n }\n }\n }\n\n /* cos(Inf or NaN) is NaN */\n if (ix >= 0x7f800000) return x - x;\n\n /* general argument reduction needed */\n var n = rempio2f(x, ix, sign);\n var y = rempio2f_y;\n\n var t = n & 1 ? sin_kernf(y) : cos_kernf(y);\n return (n + 1) & 2 ? -t : t;\n }\n\n export function cosh(x: f32): f32 { // see: musl/src/math/coshf.c\n var u = reinterpret(x);\n u &= 0x7FFFFFFF;\n x = reinterpret(u);\n if (u < 0x3F317217) {\n if (u < 0x3F800000 - (12 << 23)) return 1;\n let t = expm1(x);\n // return 1 + t * t / (2 * (1 + t));\n return 1 + t * t / (2 + 2 * t);\n }\n if (u < 0x42B17217) {\n let t = exp(x);\n // return 0.5 * (t + 1 / t);\n return 0.5 * t + 0.5 / t;\n }\n return expo2f(x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function floor(x: f32): f32 {\n return builtin_floor(x);\n }\n\n export function exp(x: f32): f32 { // see: musl/src/math/expf.c and SUN COPYRIGHT NOTICE above\n const\n ln2hi = reinterpret(0x3F317200), // 6.9314575195e-1f\n ln2lo = reinterpret(0x35BFBE8E), // 1.4286067653e-6f\n invln2 = reinterpret(0x3FB8AA3B), // 1.4426950216e+0f\n P1 = reinterpret(0x3E2AAA8F), // 1.6666625440e-1f\n P2 = reinterpret(0xBB355215), // -2.7667332906e-3f\n Ox1p127f = reinterpret(0x7F000000);\n var hx = reinterpret(x);\n var sign_ = (hx >> 31);\n hx &= 0x7FFFFFFF;\n if (hx >= 0x42AEAC50) {\n if (hx >= 0x42B17218) {\n if (!sign_) return x * Ox1p127f;\n else if (hx >= 0x42CFF1B5) return 0;\n }\n }\n var hi: f32, lo: f32;\n var k: i32;\n if (hx > 0x3EB17218) {\n if (hx > 0x3F851592) {\n k = (invln2 * x + builtin_copysign(0.5, x));\n } else {\n k = 1 - (sign_ << 1);\n }\n hi = x - k * ln2hi;\n lo = k * ln2lo;\n x = hi - lo;\n } else if (hx > 0x39000000) {\n k = 0;\n hi = x;\n lo = 0;\n } else {\n return 1 + x;\n }\n var xx = x * x;\n var c = x - xx * (P1 + xx * P2);\n var y: f32 = 1 + (x * c / (2 - c) - lo + hi);\n if (k == 0) return y;\n return scalbn(y, k);\n }\n\n export function expm1(x: f32): f32 { // see: musl/src/math/expm1f.c and SUN COPYRIGHT NOTICE above\n const\n o_threshold = reinterpret(0x42B17180), // 8.8721679688e+01f\n ln2_hi = reinterpret(0x3F317180), // 6.9313812256e-01f\n ln2_lo = reinterpret(0x3717F7D1), // 9.0580006145e-06f\n invln2 = reinterpret(0x3FB8AA3B), // 1.4426950216e+00f\n Q1 = reinterpret(0xBD088868), // -3.3333212137e-02f\n Q2 = reinterpret(0x3ACF3010), // 1.5807170421e-03f\n Ox1p127f = reinterpret(0x7F000000);\n var u = reinterpret(x);\n var hx = u & 0x7FFFFFFF;\n var sign_ = (u >> 31);\n if (hx >= 0x4195B844) {\n if (hx > 0x7F800000) return x;\n if (sign_) return -1;\n if (x > o_threshold) {\n x *= Ox1p127f;\n return x;\n }\n }\n var c: f32 = 0.0, t: f32, k: i32;\n if (hx > 0x3EB17218) {\n k = select(\n 1 - (sign_ << 1),\n (invln2 * x + builtin_copysign(0.5, x)),\n hx < 0x3F851592\n );\n t = k;\n let hi = x - t * ln2_hi;\n let lo = t * ln2_lo;\n x = hi - lo;\n c = (hi - x) - lo;\n } else if (hx < 0x33000000) {\n return x;\n } else k = 0;\n var hfx: f32 = 0.5 * x;\n var hxs: f32 = x * hfx;\n var r1: f32 = 1.0 + hxs * (Q1 + hxs * Q2);\n t = 3.0 - r1 * hfx;\n var e = hxs * ((r1 - t) / (6.0 - x * t));\n if (k == 0) return x - (x * e - hxs);\n e = x * (e - c) - c;\n e -= hxs;\n if (k == -1) return 0.5 * (x - e) - 0.5;\n if (k == 1) {\n if (x < -0.25) return -2.0 * (e - (x + 0.5));\n return 1.0 + 2.0 * (x - e);\n }\n u = (0x7F + k) << 23;\n var twopk = reinterpret(u);\n var y: f32;\n if (k < 0 || k > 56) {\n y = x - e + 1.0;\n if (k == 128) y = y * 2.0 * Ox1p127f;\n else y = y * twopk;\n return y - 1.0;\n }\n u = (0x7F - k) << 23;\n y = reinterpret(u);\n if (k < 20) y = (1 - y) - e;\n else y = 1 - (e + y);\n return (x + y) * twopk;\n }\n\n // @ts-ignore: decorator\n @inline\n export function fround(x: f32): f32 {\n return x;\n }\n\n export function hypot(x: f32, y: f32): f32 { // see: musl/src/math/hypotf.c\n const\n Ox1p90f = reinterpret(0x6C800000),\n Ox1p_90f = reinterpret(0x12800000);\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n ux &= 0x7FFFFFFF;\n uy &= 0x7FFFFFFF;\n if (ux < uy) {\n let ut = ux;\n ux = uy;\n uy = ut;\n }\n x = reinterpret(ux);\n y = reinterpret(uy);\n if (uy == 0xFF << 23) return y;\n if (ux >= 0xFF << 23 || uy == 0 || ux - uy >= 25 << 23) return x + y;\n var z: f32 = 1;\n if (ux >= (0x7F + 60) << 23) {\n z = Ox1p90f;\n x *= Ox1p_90f;\n y *= Ox1p_90f;\n } else if (uy < (0x7F - 60) << 23) {\n z = Ox1p_90f;\n x *= Ox1p90f;\n y *= Ox1p90f;\n }\n return z * builtin_sqrt((x * x + y * y));\n }\n\n // @ts-ignore: decorator\n @inline\n export function imul(x: f32, y: f32): f32 {\n /*\n * Wasm (MVP) and JS have different approaches for double->int conversions.\n *\n * For emulate JS conversion behavior and avoid trapping from wasm we should modulate by MAX_INT\n * our float-point arguments before actual convertion to integers.\n */\n if (!isFinite(x + y)) return 0;\n const inv32 = 1.0 / 4294967296;\n return (\n (x - 4294967296 * builtin_floor(x * inv32)) *\n (y - 4294967296 * builtin_floor(y * inv32))\n );\n }\n\n export function log(x: f32): f32 { // see: musl/src/math/logf.c and SUN COPYRIGHT NOTICE above\n const\n ln2_hi = reinterpret(0x3F317180), // 6.9313812256e-01f\n ln2_lo = reinterpret(0x3717F7D1), // 9.0580006145e-06f\n Lg1 = reinterpret(0x3F2AAAAA), // 0xaaaaaa.0p-24f\n Lg2 = reinterpret(0x3ECCCE13), // 0xccce13.0p-25f\n Lg3 = reinterpret(0x3E91E9EE), // 0x91e9ee.0p-25f\n Lg4 = reinterpret(0x3E789E26), // 0xf89e26.0p-26f\n Ox1p25f = reinterpret(0x4C000000);\n var u = reinterpret(x);\n var k = 0;\n if (u < 0x00800000 || (u >> 31)) {\n if (u << 1 == 0) return -1 / (x * x);\n if (u >> 31) return (x - x) / 0;\n k -= 25;\n x *= Ox1p25f;\n u = reinterpret(x);\n } else if (u >= 0x7F800000) return x;\n else if (u == 0x3F800000) return 0;\n u += 0x3F800000 - 0x3F3504F3;\n k += (u >> 23) - 0x7F;\n u = (u & 0x007FFFFF) + 0x3F3504F3;\n x = reinterpret(u);\n var f = x - 1.0;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * Lg4);\n var t2 = z * (Lg1 + w * Lg3);\n var r = t2 + t1;\n var hfsq = 0.5 * f * f;\n var dk = k;\n return s * (hfsq + r) + dk * ln2_lo - hfsq + f + dk * ln2_hi;\n }\n\n export function log10(x: f32): f32 { // see: musl/src/math/log10f.c and SUN COPYRIGHT NOTICE above\n const\n ivln10hi = reinterpret(0x3EDE6000), // 4.3432617188e-01f\n ivln10lo = reinterpret(0xB804EAD9), // -3.1689971365e-05f\n log10_2hi = reinterpret(0x3E9A2080), // 3.0102920532e-01f\n log10_2lo = reinterpret(0x355427DB), // 7.9034151668e-07f\n Lg1 = reinterpret(0x3F2AAAAA), // 0xaaaaaa.0p-24f, 0.66666662693f\n Lg2 = reinterpret(0x3ECCCE13), // 0xccce13.0p-25f, 0.40000972152f\n Lg3 = reinterpret(0x3E91E9EE), // 0x91e9ee.0p-25f, 0.28498786688f\n Lg4 = reinterpret(0x3E789E26), // 0xf89e26.0p-26f, 0.24279078841f\n Ox1p25f = reinterpret(0x4C000000);\n var ix = reinterpret(x);\n var k = 0;\n if (ix < 0x00800000 || (ix >> 31)) {\n if (ix << 1 == 0) return -1 / (x * x);\n if (ix >> 31) return (x - x) / 0.0;\n k -= 25;\n x *= Ox1p25f;\n ix = reinterpret(x);\n } else if (ix >= 0x7F800000) return x;\n else if (ix == 0x3F800000) return 0;\n ix += 0x3F800000 - 0x3F3504F3;\n k += (ix >> 23) - 0x7F;\n ix = (ix & 0x007FFFFF) + 0x3F3504F3;\n x = reinterpret(ix);\n var f = x - 1.0;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * Lg4);\n var t2 = z * (Lg1 + w * Lg3);\n var r = t2 + t1;\n var hfsq: f32 = 0.5 * f * f;\n var hi = f - hfsq;\n ix = reinterpret(hi);\n ix &= 0xFFFFF000;\n hi = reinterpret(ix);\n var lo = f - hi - hfsq + s * (hfsq + r);\n var dk = k;\n return dk * log10_2lo + (lo + hi) * ivln10lo + lo * ivln10hi + hi * ivln10hi + dk * log10_2hi;\n }\n\n export function log1p(x: f32): f32 { // see: musl/src/math/log1pf.c and SUN COPYRIGHT NOTICE above\n const\n ln2_hi = reinterpret(0x3F317180), // 6.9313812256e-01\n ln2_lo = reinterpret(0x3717F7D1), // 9.0580006145e-06\n Lg1 = reinterpret(0x3F2AAAAA), // 0xaaaaaa.0p-24f, 0.66666662693f\n Lg2 = reinterpret(0x3ECCCE13), // 0xccce13.0p-25f, 0.40000972152f\n Lg3 = reinterpret(0x3E91E9EE), // 0x91e9ee.0p-25f, 0.28498786688f\n Lg4 = reinterpret(0x3E789E26); // 0xf89e26.0p-26f, 0.24279078841f\n var ix = reinterpret(x);\n var c: f32 = 0, f: f32 = 0;\n var k: i32 = 1;\n if (ix < 0x3ED413D0 || (ix >> 31)) {\n if (ix >= 0xBF800000) {\n if (x == -1) return x / 0.0;\n return (x - x) / 0.0;\n }\n if (ix << 1 < 0x33800000 << 1) return x;\n if (ix <= 0xBE95F619) {\n k = 0;\n c = 0;\n f = x;\n }\n } else if (ix >= 0x7F800000) return x;\n if (k) {\n let uf: f32 = 1 + x;\n let iu = reinterpret(uf);\n iu += 0x3F800000 - 0x3F3504F3;\n k = (iu >> 23) - 0x7F;\n if (k < 25) {\n c = k >= 2 ? 1 - (uf - x) : x - (uf - 1);\n c /= uf;\n } else c = 0;\n iu = (iu & 0x007FFFFF) + 0x3F3504F3;\n f = reinterpret(iu) - 1;\n }\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * Lg4);\n var t2 = z * (Lg1 + w * Lg3);\n var r = t2 + t1;\n var hfsq: f32 = 0.5 * f * f;\n var dk = k;\n return s * (hfsq + r) + (dk * ln2_lo + c) - hfsq + f + dk * ln2_hi;\n }\n\n export function log2(x: f32): f32 { // see: musl/src/math/log2f.c and SUN COPYRIGHT NOTICE above\n const\n ivln2hi = reinterpret(0x3FB8B000), // 1.4428710938e+00f\n ivln2lo = reinterpret(0xB9389AD4), // -1.7605285393e-04\n Lg1 = reinterpret(0x3F2AAAAA), // 0xaaaaaa.0p-24f, 0.66666662693f\n Lg2 = reinterpret(0x3ECCCE13), // 0xccce13.0p-25f, 0.40000972152f\n Lg3 = reinterpret(0x3E91E9EE), // 0x91e9ee.0p-25f, 0.28498786688f\n Lg4 = reinterpret(0x3E789E26), // 0xf89e26.0p-26f, 0.24279078841f\n Ox1p25f = reinterpret(0x4C000000);\n var ix = reinterpret(x);\n var k: i32 = 0;\n if (ix < 0x00800000 || (ix >> 31)) {\n if (ix << 1 == 0) return -1 / (x * x);\n if (ix >> 31) return (x - x) / 0.0;\n k -= 25;\n x *= Ox1p25f;\n ix = reinterpret(x);\n } else if (ix >= 0x7F800000) return x;\n else if (ix == 0x3F800000) return 0;\n ix += 0x3F800000 - 0x3F3504F3;\n k += (ix >> 23) - 0x7F;\n ix = (ix & 0x007FFFFF) + 0x3F3504F3;\n x = reinterpret(ix);\n var f = x - 1.0;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * Lg4);\n var t2 = z * (Lg1 + w * Lg3);\n var r = t2 + t1;\n var hfsq: f32 = 0.5 * f * f;\n var hi = f - hfsq;\n var u = reinterpret(hi);\n u &= 0xFFFFF000;\n hi = reinterpret(u);\n var lo: f32 = f - hi - hfsq + s * (hfsq + r);\n var dk = k;\n return (lo + hi) * ivln2lo + lo * ivln2hi + hi * ivln2hi + dk;\n }\n\n // @ts-ignore: decorator\n @inline\n export function max(value1: f32, value2: f32): f32 {\n return builtin_max(value1, value2);\n }\n\n // @ts-ignore: decorator\n @inline\n export function min(value1: f32, value2: f32): f32 {\n return builtin_min(value1, value2);\n }\n\n export function pow(x: f32, y: f32): f32 { // see: musl/src/math/powf.c and SUN COPYRIGHT NOTICE above\n const\n dp_h1 = reinterpret(0x3F15C000), // 5.84960938e-01f\n dp_l1 = reinterpret(0x35D1CFDC), // 1.56322085e-06f\n two24 = reinterpret(0x4B800000), // 16777216f\n huge = reinterpret(0x7149F2CA), // 1.0e+30f\n tiny = reinterpret(0x0DA24260), // 1.0e-30f\n L1 = reinterpret(0x3F19999A), // 6.0000002384e-01f\n L2 = reinterpret(0x3EDB6DB7), // 4.2857143283e-01f\n L3 = reinterpret(0x3EAAAAAB), // 3.3333334327e-01f\n L4 = reinterpret(0x3E8BA305), // 2.7272811532e-01f\n L5 = reinterpret(0x3E6C3255), // 2.3066075146e-01f\n L6 = reinterpret(0x3E53F142), // 2.0697501302e-01f\n P1 = reinterpret(0x3E2AAAAB), // 1.6666667163e-01f\n P2 = reinterpret(0xBB360B61), // -2.7777778450e-03f\n P3 = reinterpret(0x388AB355), // 6.6137559770e-05f\n P4 = reinterpret(0xB5DDEA0E), // -1.6533901999e-06f\n P5 = reinterpret(0x3331BB4C), // 4.1381369442e-08f\n lg2 = reinterpret(0x3F317218), // 6.9314718246e-01f\n lg2_h = reinterpret(0x3F317200), // 6.93145752e-01f\n lg2_l = reinterpret(0x35BFBE8C), // 1.42860654e-06f\n ovt = reinterpret(0x3338AA3C), // 4.2995665694e-08f\n cp = reinterpret(0x3F76384F), // 9.6179670095e-01\n cp_h = reinterpret(0x3F764000), // 9.6191406250e-01\n cp_l = reinterpret(0xB8F623C6), // -1.1736857402e-04\n ivln2 = reinterpret(0x3FB8AA3B), // 1.4426950216e+00\n ivln2_h = reinterpret(0x3FB8AA00), // 1.4426879883e+00\n ivln2_l = reinterpret(0x36ECA570), // 7.0526075433e-06\n inv3 = reinterpret(0x3EAAAAAB); // 0.333333333333\n var hx = reinterpret(x);\n var hy = reinterpret(y);\n var ix = hx & 0x7FFFFFFF;\n var iy = hy & 0x7FFFFFFF;\n if (iy == 0) return 1.0; // x**0 = 1, even if x is NaN\n // if (hx == 0x3F800000) return 1.0; // C: 1**y = 1, even if y is NaN, JS: NaN\n if (ix > 0x7F800000 || iy > 0x7F800000) return x + y; // NaN if either arg is NaN\n var yisint = 0, j: i32, k: i32;\n if (hx < 0) {\n if (iy >= 0x4B800000) yisint = 2;\n else if (iy >= 0x3F800000) {\n k = (iy >> 23) - 0x7F;\n let ki = 23 - k;\n j = iy >> ki;\n if ((j << ki) == iy) yisint = 2 - (j & 1);\n }\n }\n if (iy == 0x7F800000) { // y is +-inf\n if (ix == 0x3F800000) return NaN; // C: (-1)**+-inf is 1, JS: NaN\n else if (ix > 0x3F800000) return hy >= 0 ? y : 0.0; // (|x|>1)**+-inf = inf,0\n else return hy >= 0 ? 0.0 : -y; // (|x|<1)**+-inf = 0,inf\n }\n if (iy == 0x3F800000) return hy >= 0 ? x : 1.0 / x;\n if (hy == 0x40000000) return x * x;\n if (hy == 0x3F000000) {\n if (hx >= 0) return builtin_sqrt(x);\n }\n var ax = builtin_abs(x);\n var z: f32;\n if (ix == 0x7F800000 || ix == 0 || ix == 0x3F800000) {\n z = ax;\n if (hy < 0) z = 1.0 / z;\n if (hx < 0) {\n if (((ix - 0x3F800000) | yisint) == 0) {\n let d = z - z;\n z = d / d;\n }\n else if (yisint == 1) z = -z;\n }\n return z;\n }\n var sn = 1.0;\n if (hx < 0) {\n if (yisint == 0) {\n let d = x - x;\n return d / d;\n }\n if (yisint == 1) sn = -1.0;\n }\n var t1: f32, t2: f32, r: f32, s: f32, t: f32, u: f32, v: f32, w: f32, p_h: f32, p_l: f32;\n var n: i32, is: i32;\n if (iy > 0x4D000000) {\n if (ix < 0x3F7FFFF8) return hy < 0 ? sn * huge * huge : sn * tiny * tiny;\n if (ix > 0x3F800007) return hy > 0 ? sn * huge * huge : sn * tiny * tiny;\n t = ax - 1;\n w = (t * t) * (0.5 - t * (inv3 - t * 0.25));\n u = ivln2_h * t;\n v = t * ivln2_l - w * ivln2;\n t1 = u + v;\n is = reinterpret(t1);\n t1 = reinterpret(is & 0xFFFFF000);\n t2 = v - (t1 - u);\n } else {\n let s2: f32, s_h: f32, s_l: f32, t_h: f32, t_l: f32;\n n = 0;\n if (ix < 0x00800000) {\n ax *= two24;\n n -= 24;\n ix = reinterpret(ax);\n }\n n += (ix >> 23) - 0x7F;\n j = ix & 0x007FFFFF;\n ix = j | 0x3F800000;\n if (j <= 0x1CC471) k = 0;\n else if (j < 0x5DB3D7) k = 1;\n else {\n k = 0;\n n += 1;\n ix -= 0x00800000;\n }\n ax = reinterpret(ix);\n let bp = select(1.5, 1.0, k); // k ? 1.5 : 1.0\n u = ax - bp;\n v = 1.0 / (ax + bp);\n s = u * v;\n s_h = s;\n is = reinterpret(s_h);\n s_h = reinterpret(is & 0xFFFFF000);\n is = ((ix >> 1) & 0xFFFFF000) | 0x20000000;\n t_h = reinterpret(is + 0x00400000 + (k << 21));\n t_l = ax - (t_h - bp);\n s_l = v * ((u - s_h * t_h) - s_h * t_l);\n s2 = s * s;\n r = s2 * s2 * (L1 + s2 * (L2 + s2 * (L3 + s2 * (L4 + s2 * (L5 + s2 * L6)))));\n r += s_l * (s_h + s);\n s2 = s_h * s_h;\n t_h = 3.0 + s2 + r;\n is = reinterpret(t_h);\n t_h = reinterpret(is & 0xFFFFF000);\n t_l = r - ((t_h - 3.0) - s2);\n u = s_h * t_h;\n v = s_l * t_h + t_l * s;\n p_h = u + v;\n is = reinterpret(p_h);\n p_h = reinterpret(is & 0xFFFFF000);\n p_l = v - (p_h - u);\n let z_h = cp_h * p_h;\n let dp_l = select(dp_l1, 0.0, k);\n let z_l = cp_l * p_h + p_l * cp + dp_l;\n t = n;\n let dp_h = select(dp_h1, 0.0, k);\n t1 = (((z_h + z_l) + dp_h) + t);\n is = reinterpret(t1);\n t1 = reinterpret(is & 0xFFFFF000);\n t2 = z_l - (((t1 - t) - dp_h) - z_h);\n }\n is = reinterpret(y);\n var y1 = reinterpret(is & 0xFFFFF000);\n p_l = (y - y1) * t1 + y * t2;\n p_h = y1 * t1;\n z = p_l + p_h;\n j = reinterpret(z);\n if (j > 0x43000000) {\n return sn * huge * huge;\n } else if (j == 0x43000000) {\n if (p_l + ovt > z - p_h) return sn * huge * huge;\n } else if ((j & 0x7FFFFFFF) > 0x43160000) {\n return sn * tiny * tiny;\n } else if (j == 0xC3160000) {\n if (p_l <= z - p_h) return sn * tiny * tiny;\n }\n var i = j & 0x7FFFFFFF;\n k = (i >> 23) - 0x7F;\n n = 0;\n if (i > 0x3F000000) {\n n = j + (0x00800000 >> (k + 1));\n k = ((n & 0x7FFFFFFF) >> 23) - 0x7F;\n t = reinterpret(n & ~(0x007FFFFF >> k));\n n = ((n & 0x007FFFFF) | 0x00800000) >> (23 - k);\n if (j < 0) n = -n;\n p_h -= t;\n }\n t = p_l + p_h;\n is = reinterpret(t);\n t = reinterpret(is & 0xFFFF8000);\n u = t * lg2_h;\n v = (p_l - (t - p_h)) * lg2 + t * lg2_l;\n z = u + v;\n w = v - (z - u);\n t = z * z;\n t1 = z - t * (P1 + t * (P2 + t * (P3 + t * (P4 + t * P5))));\n r = (z * t1) / (t1 - 2.0) - (w + z * w);\n z = 1.0 - (r - z);\n j = reinterpret(z);\n j += n << 23;\n if ((j >> 23) <= 0) z = scalbn(z, n);\n else z = reinterpret(j);\n return sn * z;\n }\n\n // @ts-ignore: decorator\n @inline\n export function seedRandom(value: i64): void {\n NativeMath.seedRandom(value);\n }\n\n // Using xoroshiro64starstar from http://xoshiro.di.unimi.it/xoroshiro64starstar.c\n export function random(): f32 {\n if (!random_seeded) throw new Error("PRNG must be seeded.");\n\n var s0 = random_state0_32;\n var s1 = random_state1_32;\n var r = rotl(s0 * 0x9E3779BB, 5) * 5;\n\n s1 ^= s0;\n random_state0_32 = rotl(s0, 26) ^ s1 ^ (s1 << 9);\n random_state1_32 = rotl(s1, 13);\n\n return reinterpret((r >> 9) | (127 << 23)) - 1.0;\n }\n\n // @ts-ignore: decorator\n @inline\n export function round(x: f32): f32 {\n return builtin_copysign(builtin_floor(x + 0.5), x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function sign(x: f32): f32 {\n if (ASC_SHRINK_LEVEL > 0) {\n return builtin_abs(x) > 0 ? builtin_copysign(1, x) : x;\n } else {\n return x > 0 ? 1 : x < 0 ? -1 : x;\n }\n }\n\n // @ts-ignore: decorator\n @inline\n export function signbit(x: f32): bool {\n // @ts-ignore: type\n return ((reinterpret(x) >>> 31) & (x == x));\n }\n\n export function sin(x: f32): f32 { // see: musl/src/math/sinf.c\n const s1pio2 = reinterpret(0x3FF921FB54442D18); // M_PI_2 * 1\n const s2pio2 = reinterpret(0x400921FB54442D18); // M_PI_2 * 2\n const s3pio2 = reinterpret(0x4012D97C7F3321D2); // M_PI_2 * 3\n const s4pio2 = reinterpret(0x401921FB54442D18); // M_PI_2 * 4\n\n var ix = reinterpret(x);\n var sign = ix >> 31;\n ix &= 0x7FFFFFFF;\n\n if (ix <= 0x3f490fda) { /* |x| ~<= π/4 */\n if (ix < 0x39800000) { /* |x| < 2**-12 */\n return x;\n }\n return sin_kernf(x);\n }\n\n if (ASC_SHRINK_LEVEL < 1) {\n if (ix <= 0x407b53d1) { /* |x| ~<= 5π/4 */\n if (ix <= 0x4016cbe3) { /* |x| ~<= 3π/4 */\n return sign ? -cos_kernf(x + s1pio2) : cos_kernf(x - s1pio2);\n }\n return sin_kernf(-(sign ? x + s2pio2 : x - s2pio2));\n }\n\n if (ix <= 0x40e231d5) { /* |x| ~<= 9π/4 */\n if (ix <= 0x40afeddf) { /* |x| ~<= 7π/4 */\n return sign ? cos_kernf(x + s3pio2) : -cos_kernf(x - s3pio2);\n }\n return sin_kernf(sign ? x + s4pio2 : x - s4pio2);\n }\n }\n\n /* sin(Inf or NaN) is NaN */\n if (ix >= 0x7f800000) return x - x;\n\n var n = rempio2f(x, ix, sign);\n var y = rempio2f_y;\n\n var t = n & 1 ? cos_kernf(y) : sin_kernf(y);\n return n & 2 ? -t : t;\n }\n\n export function sinh(x: f32): f32 { // see: musl/src/math/sinhf.c\n var u = reinterpret(x) & 0x7FFFFFFF;\n var absx = reinterpret(u);\n var t: f32;\n var h = builtin_copysign(0.5, x);\n if (u < 0x42B17217) {\n t = expm1(absx);\n if (u < 0x3F800000) {\n if (u < 0x3F800000 - (12 << 23)) return x;\n return h * (2 * t - t * t / (t + 1));\n }\n return h * (t + t / (t + 1));\n }\n t = 2 * h * expo2f(absx);\n return t;\n }\n\n // @ts-ignore: decorator\n @inline\n export function sqrt(x: f32): f32 {\n return builtin_sqrt(x);\n }\n\n export function tan(x: f32): f32 { // see: musl/src/math/tanf.c\n const t1pio2 = reinterpret(0x3FF921FB54442D18); // 1 * M_PI_2\n const t2pio2 = reinterpret(0x400921FB54442D18); // 2 * M_PI_2\n const t3pio2 = reinterpret(0x4012D97C7F3321D2); // 3 * M_PI_2\n const t4pio2 = reinterpret(0x401921FB54442D18); // 4 * M_PI_2\n\n var ix = reinterpret(x);\n var sign = ix >> 31;\n ix &= 0x7FFFFFFF;\n\n if (ix <= 0x3f490fda) { /* |x| ~<= π/4 */\n if (ix < 0x39800000) { /* |x| < 2**-12 */\n return x;\n }\n return tan_kernf(x, 0);\n }\n\n if (ASC_SHRINK_LEVEL < 1) {\n if (ix <= 0x407b53d1) { /* |x| ~<= 5π/4 */\n if (ix <= 0x4016cbe3) { /* |x| ~<= 3π/4 */\n return tan_kernf((sign ? x + t1pio2 : x - t1pio2), 1);\n } else {\n return tan_kernf((sign ? x + t2pio2 : x - t2pio2), 0);\n }\n }\n if (ix <= 0x40e231d5) { /* |x| ~<= 9π/4 */\n if (ix <= 0x40afeddf) { /* |x| ~<= 7π/4 */\n return tan_kernf((sign ? x + t3pio2 : x - t3pio2), 1);\n } else {\n return tan_kernf((sign ? x + t4pio2 : x - t4pio2), 0);\n }\n }\n }\n\n /* tan(Inf or NaN) is NaN */\n if (ix >= 0x7f800000) return x - x;\n\n /* argument reduction */\n var n = rempio2f(x, ix, sign);\n var y = rempio2f_y;\n return tan_kernf(y, n & 1);\n }\n\n export function tanh(x: f32): f32 { // see: musl/src/math/tanhf.c\n var u = reinterpret(x);\n u &= 0x7FFFFFFF;\n var y = reinterpret(u);\n var t: f32;\n if (u > 0x3F0C9F54) {\n if (u > 0x41200000) t = 1 + 0 / y;\n else {\n t = expm1(2 * y);\n t = 1 - 2 / (t + 2);\n }\n } else if (u > 0x3E82C578) {\n t = expm1(2 * y);\n t = t / (t + 2);\n } else if (u >= 0x00800000) {\n t = expm1(-2 * y);\n t = -t / (t + 2);\n } else t = y;\n return builtin_copysign(t, x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function trunc(x: f32): f32 {\n return builtin_trunc(x);\n }\n\n export function scalbn(x: f32, n: i32): f32 { // see: https://git.musl-libc.org/cgit/musl/tree/src/math/scalbnf.c\n const\n Ox1p24f = reinterpret(0x4B800000),\n Ox1p127f = reinterpret(0x7F000000),\n Ox1p_126f = reinterpret(0x00800000);\n var y = x;\n if (n > 127) {\n y *= Ox1p127f;\n n -= 127;\n if (n > 127) {\n y *= Ox1p127f;\n n = builtin_min(n - 127, 127);\n }\n } else if (n < -126) {\n y *= Ox1p_126f * Ox1p24f;\n n += 126 - 24;\n if (n < -126) {\n y *= Ox1p_126f * Ox1p24f;\n n = builtin_max(n + 126 - 24, -126);\n }\n }\n return y * reinterpret((0x7F + n) << 23);\n }\n\n export function mod(x: f32, y: f32): f32 { // see: musl/src/math/fmodf.c\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n var ex = (ux >> 23 & 0xFF);\n var ey = (uy >> 23 & 0xFF);\n var sx = ux & 0x80000000;\n var uy1 = uy << 1;\n if (uy1 == 0 || ex == 0xFF || isNaN(y)) {\n let m = x * y;\n return m / m;\n }\n var ux1 = ux << 1;\n if (ux1 <= uy1) {\n if (ux1 == uy1) return 0 * x;\n return x;\n }\n if (!ex) {\n ex -= builtin_clz(ux << 9);\n ux <<= -ex + 1;\n } else {\n ux &= -1 >> 9;\n ux |= 1 << 23;\n }\n if (!ey) {\n ey -= builtin_clz(uy << 9);\n uy <<= -ey + 1;\n } else {\n uy &= -1 >> 9;\n uy |= 1 << 23;\n }\n while (ex > ey) {\n if (ux >= uy) {\n if (ux == uy) return 0 * x;\n ux -= uy;\n }\n ux <<= 1;\n --ex;\n }\n if (ux >= uy) {\n if (ux == uy) return 0 * x;\n ux -= uy;\n }\n // for (; !(ux >> 23); ux <<= 1) --ex;\n var shift = builtin_clz(ux << 8);\n ex -= shift;\n ux <<= shift;\n if (ex > 0) {\n ux -= 1 << 23;\n ux |= ex << 23;\n } else {\n ux >>= -ex + 1;\n }\n ux |= sx;\n return reinterpret(ux);\n }\n\n export function rem(x: f32, y: f32): f32 { // see: musl/src/math/remquof.c\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n var ex = (ux >> 23 & 0xFF);\n var ey = (uy >> 23 & 0xFF);\n var sx = (ux >> 31);\n var uxi = ux;\n if (uy << 1 == 0 || ex == 0xFF || isNaN(y)) return (x * y) / (x * y);\n if (ux << 1 == 0) return x;\n if (!ex) {\n ex -= builtin_clz(uxi << 9);\n uxi <<= -ex + 1;\n } else {\n uxi &= -1 >> 9;\n uxi |= 1 << 23;\n }\n if (!ey) {\n ey -= builtin_clz(uy << 9);\n uy <<= -ey + 1;\n } else {\n uy &= -1 >> 9;\n uy |= 1 << 23;\n }\n var q = 0;\n do {\n if (ex < ey) {\n if (ex + 1 == ey) break; // goto end\n return x;\n }\n while (ex > ey) {\n if (uxi >= uy) {\n uxi -= uy;\n ++q;\n }\n uxi <<= 1;\n q <<= 1;\n --ex;\n }\n if (uxi >= uy) {\n uxi -= uy;\n ++q;\n }\n if (uxi == 0) ex = -30;\n else {\n let shift = builtin_clz(uxi << 8);\n ex -= shift;\n uxi <<= shift;\n }\n break;\n } while (false);\n // end\n if (ex > 0) {\n uxi -= 1 << 23;\n uxi |= ex << 23;\n } else {\n uxi >>= -ex + 1;\n }\n x = reinterpret(uxi);\n y = builtin_abs(y);\n var x2 = x + x;\n if (ex == ey || (ex + 1 == ey && (x2 > y || (x2 == y && (q & 1))))) {\n x -= y;\n // q++;\n }\n return sx ? -x : x;\n }\n\n export function sincos(x: f32): void { // see: musl/tree/src/math/sincosf.c\n const s1pio2 = reinterpret(0x3FF921FB54442D18); // 1 * M_PI_2\n const s2pio2 = reinterpret(0x400921FB54442D18); // 2 * M_PI_2\n const s3pio2 = reinterpret(0x4012D97C7F3321D2); // 3 * M_PI_2\n const s4pio2 = reinterpret(0x401921FB54442D18); // 4 * M_PI_2\n\n var ix = reinterpret(x);\n var sign = ix >> 31;\n ix &= 0x7fffffff;\n\n if (ix <= 0x3f490fda) { /* |x| ~<= π/4 */\n if (ix < 0x39800000) { /* |x| < 2**-12 */\n sincos_sin = x;\n sincos_cos = 1;\n return;\n }\n sincos_sin = sin_kernf(x);\n sincos_cos = cos_kernf(x);\n return;\n }\n\n if (ASC_SHRINK_LEVEL < 1) {\n if (ix <= 0x407b53d1) { /* |x| ~<= 5π/4 */\n if (ix <= 0x4016cbe3) { /* |x| ~<= 3π/4 */\n if (sign) {\n sincos_sin = -cos_kernf(x + s1pio2);\n sincos_cos = sin_kernf(x + s1pio2);\n } else {\n sincos_sin = cos_kernf(s1pio2 - x);\n sincos_cos = sin_kernf(s1pio2 - x);\n }\n return;\n }\n /* -sin(x + c) is not correct if x+c could be 0: -0 vs +0 */\n sincos_sin = -sin_kernf(sign ? x + s2pio2 : x - s2pio2);\n sincos_cos = -cos_kernf(sign ? x + s2pio2 : x - s2pio2);\n return;\n }\n\n if (ix <= 0x40e231d5) { /* |x| ~<= 9π/4 */\n if (ix <= 0x40afeddf) { /* |x| ~<= 7π/4 */\n if (sign) {\n sincos_sin = cos_kernf(x + s3pio2);\n sincos_cos = -sin_kernf(x + s3pio2);\n } else {\n sincos_sin = -cos_kernf(x - s3pio2);\n sincos_cos = sin_kernf(x - s3pio2);\n }\n return;\n }\n sincos_sin = sin_kernf(sign ? x + s4pio2 : x - s4pio2);\n sincos_cos = cos_kernf(sign ? x + s4pio2 : x - s4pio2);\n return;\n }\n }\n\n /* sin(Inf or NaN) is NaN */\n if (ix >= 0x7f800000) {\n let xx = x - x;\n sincos_sin = xx;\n sincos_cos = xx;\n return;\n }\n\n /* general argument reduction needed */\n var n = rempio2f(x, ix, sign);\n var y = rempio2f_y;\n var s = sin_kernf(y);\n var c = cos_kernf(y);\n\n switch (n & 3) {\n case 0: {\n sincos_sin = s;\n sincos_cos = c;\n break;\n }\n case 1: {\n sincos_sin = c;\n sincos_cos = -s;\n break;\n }\n case 2: {\n sincos_sin = -s;\n sincos_cos = -c;\n break;\n }\n case 3:\n default: {\n sincos_sin = -c;\n sincos_cos = s;\n break;\n }\n }\n }\n}\n\nexport function ipow32(x: i32, e: i32): i32 {\n var out = 1;\n if (ASC_SHRINK_LEVEL < 1) {\n if (e < 0) return 0;\n\n switch (e) {\n case 0: return 1;\n case 1: return x;\n case 2: return x * x;\n }\n\n let log = 32 - clz(e);\n if (log <= 5) {\n // 32 = 2 ^ 5, so need only five cases.\n // But some extra cases needs for properly overflowing\n switch (log) {\n case 5: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 4: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 3: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 2: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 1: {\n if (e & 1) out *= x;\n }\n }\n return out;\n }\n }\n\n while (e > 0) {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n return out;\n}\n\nexport function ipow64(x: i64, e: i32): i64 {\n var out: i64 = 1;\n if (ASC_SHRINK_LEVEL < 1) {\n if (e < 0) return 0;\n switch (e) {\n case 0: return 1;\n case 1: return x;\n case 2: return x * x;\n }\n\n let log = 32 - clz(e);\n if (log <= 6) {\n // 64 = 2 ^ 6, so need only six cases.\n // But some extra cases needs for properly overflowing\n switch (log) {\n case 6: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 5: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 4: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 3: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 2: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 1: {\n if (e & 1) out *= x;\n }\n }\n return out;\n }\n }\n\n while (e > 0) {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n return out;\n}\n\nexport function ipow32f(x: f32, e: i32): f32 {\n var sign = e >> 31;\n e = (e + sign) ^ sign; // abs(e)\n var out: f32 = 1;\n while (e) {\n out *= select(x, 1.0, e & 1);\n e >>= 1;\n x *= x;\n }\n return sign ? 1.0 / out : out;\n}\n\nexport function ipow64f(x: f64, e: i32): f64 {\n var sign = e >> 31;\n e = (e + sign) ^ sign; // abs(e)\n var out = 1.0;\n while (e) {\n out *= select(x, 1.0, e & 1);\n e >>= 1;\n x *= x;\n }\n return sign ? 1.0 / out : out;\n}\n',memory:'import { memcmp, memmove, memset } from "./util/memory";\nimport { E_NOTIMPLEMENTED } from "./util/error";\n\n/** Memory manager interface. */\nexport namespace memory {\n\n /** Gets the size of the memory in pages. */\n // @ts-ignore: decorator\n @builtin\n export declare function size(): i32;\n\n /** Grows the memory by the given size in pages and returns the previous size in pages. */\n // @ts-ignore: decorator\n @unsafe @builtin\n export declare function grow(pages: i32): i32;\n\n /** Fills a section in memory with the specified byte value. */\n // @ts-ignore: decorator\n @unsafe @builtin\n export function fill(dst: usize, c: u8, n: usize): void {\n memset(dst, c, n); // fallback if "bulk-memory" isn\'t enabled\n }\n\n /** Copies a section of memory to another. Has move semantics. */\n // @ts-ignore: decorator\n @unsafe @builtin\n export function copy(dst: usize, src: usize, n: usize): void {\n memmove(dst, src, n); // fallback if "bulk-memory" isn\'t enabled\n }\n\n /** Initializes a memory segment. */\n // @ts-ignore: decorator\n @unsafe\n export function init(segmentIndex: u32, srcOffset: usize, dstOffset: usize, n: usize): void {\n throw new Error(E_NOTIMPLEMENTED);\n }\n\n /** Drops a memory segment. */\n // @ts-ignore: decorator\n @unsafe\n export function drop(segmentIndex: u32): void {\n throw new Error(E_NOTIMPLEMENTED);\n }\n\n /** Repeats a section of memory at a specific address. */\n // @ts-ignore: decorator\n @unsafe\n export function repeat(dst: usize, src: usize, srcLength: usize, count: usize): void {\n var index: usize = 0;\n var total = srcLength * count;\n while (index < total) {\n memory.copy(dst + index, src, srcLength);\n index += srcLength;\n }\n }\n\n /** Compares a section of memory to another. */\n // @ts-ignore: decorator\n @inline\n export function compare(vl: usize, vr: usize, n: usize): i32 {\n return memcmp(vl, vr, n);\n }\n}\n',number:'import { itoa, dtoa } from "./util/number";\nimport { strtol } from "./util/string";\n\n// @ts-ignore: decorator\n@builtin @inline\nexport const NaN: f64 = 0 / 0;\n\n// @ts-ignore: decorator\n@builtin @inline\nexport const Infinity: f64 = 1 / 0;\n\nexport function isNaN(value: T): bool {\n if (!isFloat()) {\n if (!isInteger()) ERROR("numeric type expected");\n }\n return value != value;\n}\n\nexport function isFinite(value: T): bool {\n if (!isFloat()) {\n if (!isInteger()) ERROR("numeric type expected");\n }\n return value - value == 0;\n}\n\n@sealed @unmanaged\nexport abstract class I8 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: i8 = i8.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: i8 = i8.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): i8 {\n return strtol(value, radix);\n }\n\n toString(this: i8): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class I16 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: i16 = i16.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: i16 = i16.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): i16 {\n return strtol(value, radix);\n }\n\n toString(this: i16): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class I32 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: i32 = i32.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: i32 = i32.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): i32 {\n return strtol(value, radix);\n }\n\n toString(this: i32): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class I64 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: i64 = i64.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: i64 = i64.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): i64 {\n return strtol(value, radix);\n }\n\n toString(this: i64): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class Isize {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: isize = isize.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: isize = isize.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): isize {\n return strtol(value, radix);\n }\n\n toString(this: isize): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class U8 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: u8 = u8.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: u8 = u8.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): u8 {\n return strtol(value, radix);\n }\n\n toString(this: u8): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class U16 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: u16 = u16.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: u16 = u16.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): u16 {\n return strtol(value, radix);\n }\n\n toString(this: u16): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class U32 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: u32 = u32.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: u32 = u32.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): u32 {\n return strtol(value, radix);\n }\n\n toString(this: u32): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class U64 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: u64 = u64.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: u64 = u64.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): u64 {\n return strtol(value, radix);\n }\n\n toString(this: u64): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class Usize {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: usize = usize.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: usize = usize.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): usize {\n return strtol(value, radix);\n }\n\n toString(this: usize): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class Bool {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: bool = bool.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: bool = bool.MAX_VALUE;\n\n toString(this: bool): String {\n // TODO: radix?\n return this ? "true" : "false";\n }\n}\n\nexport { Bool as Boolean };\n\n@sealed @unmanaged\nexport abstract class F32 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly EPSILON: f32 = f32.EPSILON;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: f32 = f32.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: f32 = f32.MAX_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_SAFE_INTEGER: f32 = f32.MIN_SAFE_INTEGER;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_SAFE_INTEGER: f32 = f32.MAX_SAFE_INTEGER;\n\n // @ts-ignore: decorator\n @lazy\n static readonly POSITIVE_INFINITY: f32 = Infinity;\n\n // @ts-ignore: decorator\n @lazy\n static readonly NEGATIVE_INFINITY: f32 = -Infinity;\n\n // @ts-ignore: decorator\n @lazy\n static readonly NaN: f32 = NaN;\n\n static isNaN(value: f32): bool {\n return isNaN(value);\n }\n\n static isFinite(value: f32): bool {\n return isFinite(value);\n }\n\n static isSafeInteger(value: f32): bool {\n return abs(value) <= f32.MAX_SAFE_INTEGER && trunc(value) == value;\n }\n\n static isInteger(value: f32): bool {\n return isFinite(value) && trunc(value) == value;\n }\n\n static parseInt(value: string, radix: i32 = 0): f32 {\n return strtol(value, radix);\n }\n\n static parseFloat(value: string): f32 {\n return parseFloat(value);\n }\n\n toString(this: f32): String {\n // TODO: radix\n return dtoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class F64 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly EPSILON: f64 = f64.EPSILON;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: f64 = f64.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: f64 = f64.MAX_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_SAFE_INTEGER: f64 = f64.MIN_SAFE_INTEGER;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_SAFE_INTEGER: f64 = f64.MAX_SAFE_INTEGER;\n\n // @ts-ignore: decorator\n @lazy\n static readonly POSITIVE_INFINITY: f64 = Infinity;\n\n // @ts-ignore: decorator\n @lazy\n static readonly NEGATIVE_INFINITY: f64 = -Infinity;\n\n // @ts-ignore: decorator\n @lazy\n static readonly NaN: f64 = NaN;\n\n static isNaN(value: f64): bool {\n return isNaN(value);\n }\n\n static isFinite(value: f64): bool {\n return isFinite(value);\n }\n\n static isSafeInteger(value: f64): bool {\n return abs(value) <= f64.MAX_SAFE_INTEGER && trunc(value) == value;\n }\n\n static isInteger(value: f64): bool {\n return isFinite(value) && trunc(value) == value;\n }\n\n static parseInt(value: string, radix: i32 = 0): f64 {\n return strtol(value, radix);\n }\n\n static parseFloat(value: string): f64 {\n return parseFloat(value);\n }\n\n toString(this: f64, radix: i32 = 0): String {\n // TODO: radix\n return dtoa(this);\n }\n}\n\nexport { F64 as Number };\n',polyfills:"export function bswap(value: T): T {\n if (isInteger()) {\n if (sizeof() == 2) {\n return ((value << 8) | ((value >> 8) & 0x00FF));\n }\n if (sizeof() == 4) {\n return (\n rotl(value & 0xFF00FF00, 8) |\n rotr(value & 0x00FF00FF, 8)\n );\n }\n if (sizeof() == 8) {\n let a = (value >> 8) & 0x00FF00FF00FF00FF;\n let b = (value & 0x00FF00FF00FF00FF) << 8;\n let v = a | b;\n\n a = (v >> 16) & 0x0000FFFF0000FFFF;\n b = (v & 0x0000FFFF0000FFFF) << 16;\n\n return rotr(a | b, 32);\n }\n return value;\n }\n assert(false);\n return value;\n}\n\nexport function bswap16(value: T): T {\n if (isInteger() && sizeof() <= 4) {\n if (sizeof() == 2) {\n return ((value << 8) | ((value >> 8) & 0x00FF));\n } else if (sizeof() == 4) {\n return (((value << 8) & 0xFF00) | ((value >> 8) & 0x00FF) | (value & 0xFFFF0000));\n }\n return value;\n }\n assert(false);\n return value;\n}\n",regexp:'export class RegExp {\n\n // @binding(CALL_NEW, [ STRING, STRING], OBJECT_HANDLE)\n constructor(pattern: string, flags: string = "") { throw new Error("unreachable"); }\n\n // @binding(CALL_THIS, [ STRING ], PASS_THRU)\n test(search: string): bool { throw new Error("unreachable"); }\n\n // @binding(CALL_THIS, [], STRING)\n toString(): string { throw new Error("unreachable"); }\n\n}\n',rt:'import { Typeinfo, TypeinfoFlags } from "./shared/typeinfo";\nimport { E_INDEXOUTOFRANGE } from "./util/error";\nimport { BLOCK, BLOCK_OVERHEAD } from "./rt/common";\nimport { ArrayBufferView } from "./arraybuffer";\n\n// @ts-ignore: decorator\n@builtin\nexport declare const __rtti_base: usize;\n\n// @ts-ignore: decorator\n@builtin @unsafe\nexport declare function __visit_globals(cookie: u32): void;\n\n// @ts-ignore: decorator\n@builtin @unsafe\nexport declare function __visit_members(ref: usize, cookie: u32): void;\n\n// @ts-ignore: decorator\n@unsafe\nexport function __typeinfo(id: u32): TypeinfoFlags {\n var ptr = __rtti_base;\n if (id > load(ptr)) throw new Error(E_INDEXOUTOFRANGE);\n return changetype(ptr + sizeof() + id * offsetof()).flags;\n}\n\n// @ts-ignore: decorator\n@unsafe\nexport function __instanceof(ref: usize, superId: u32): bool { // keyword\n var id = changetype(ref - BLOCK_OVERHEAD).rtId;\n var ptr = __rtti_base;\n if (id <= load(ptr)) {\n do if (id == superId) return true;\n while (id = changetype(ptr + sizeof() + id * offsetof()).base);\n }\n return false;\n}\n\n// @ts-ignore: decorator\n@unsafe\nexport function __allocArray(length: i32, alignLog2: usize, id: u32, data: usize = 0): usize {\n var array = __alloc(offsetof(), id);\n var bufferSize = length << alignLog2;\n var buffer = __alloc(bufferSize, idof());\n store(array, __retain(buffer), offsetof("data"));\n changetype(array).dataStart = buffer;\n changetype(array).dataLength = bufferSize;\n store(changetype(array), length, offsetof("length_"));\n if (data) memory.copy(buffer, data, bufferSize);\n return array;\n}\n\n// These are provided by the respective implementation, included as another entry file by asc:\n\n// @builtin @unsafe\n// export declare function __alloc(size: usize, id: u32): usize;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __realloc(ref: usize, size: usize): usize;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __free(ref: usize): void;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __retain(ref: usize): usize;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __release(ref: usize): void;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __collect(): void;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __visit(ref: usize, cookie: u32): void;\n',"rt/common":"// Alignment guarantees\n\n// @ts-ignore: decorator\n@inline export const AL_BITS: u32 = 4; // 16 bytes to fit up to v128\n// @ts-ignore: decorator\n@inline export const AL_SIZE: usize = 1 << AL_BITS;\n// @ts-ignore: decorator\n@inline export const AL_MASK: usize = AL_SIZE - 1;\n\n// Extra debugging\n\n// @ts-ignore: decorator\n@inline export const DEBUG = true;\n\n// ╒════════════════ Common block layout (32-bit) ═════════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤\n// │ MM info │ -16\n// ├───────────────────────────────────────────────────────────────┤\n// │ GC info │ -12\n// ├───────────────────────────────────────────────────────────────┤\n// │ runtime id │ -8\n// ├───────────────────────────────────────────────────────────────┤\n// │ runtime size │ -4\n// ╞═══════════════════════════════════════════════════════════════╡\n// │ ... │ ref\n@unmanaged export class BLOCK {\n /** Memory manager info. */\n mmInfo: usize; // WASM64 needs adaption\n /** Garbage collector info. */\n gcInfo: u32;\n /** Runtime class id. */\n rtId: u32;\n /** Runtime object size. */\n rtSize: u32;\n}\n\n// @ts-ignore: decorator\n@inline export const BLOCK_OVERHEAD = (offsetof() + AL_MASK) & ~AL_MASK;\n\n// @ts-ignore: decorator\n@inline export const BLOCK_MAXSIZE: usize = (1 << 30) - BLOCK_OVERHEAD;\n","rt/index-full":'export { __alloc } from "rt/tlsf";\nexport { __retain, __release, __collect } from "rt/pure";\nexport { __rtti_base } from "rt";\n',"rt/index-half":'import "rt/index-full";\n',"rt/index-none":'import "rt/index-stub";\n',"rt/index-stub":'export { __alloc, __retain, __release, __collect } from "rt/stub";\nexport { __rtti_base } from "rt";\n',"rt/pure":'import { DEBUG, BLOCK_OVERHEAD } from "rt/common";\nimport { Block, freeBlock, ROOT } from "rt/tlsf";\nimport { TypeinfoFlags } from "shared/typeinfo";\nimport { onincrement, ondecrement, onfree, onalloc } from "./rtrace";\n\n/////////////////////////// A Pure Reference Counting Garbage Collector ///////////////////////////\n// see: https://researcher.watson.ibm.com/researcher/files/us-bacon/Bacon03Pure.pdf\n\n// ╒══════════════════════ GC Info structure ══════════════════════╕\n// │ 3 2 1 │\n// │1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0│\n// ├─┼─┴─┴─┼─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤\n// │B│color│ refCount │\n// └─┴─────┴───────────────────────────────────────────────────────┘\n// B: buffered\n\n// @ts-ignore: decorator\n@inline const BUFFERED_MASK: u32 = 1 << ((sizeof() * 8) - 1);\n// @ts-ignore: decorator\n@inline const COLOR_BITS = 3;\n// @ts-ignore: decorator\n@inline const COLOR_SHIFT: u32 = ctz(BUFFERED_MASK) - COLOR_BITS;\n// @ts-ignore: decorator\n@inline const COLOR_MASK: u32 = ((1 << COLOR_BITS) - 1) << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const REFCOUNT_MASK: u32 = (1 << COLOR_SHIFT) - 1;\n\n// ╒════════╤═══════════════════ Colors ═══════════════════════════╕\n// │ Color │ Meaning │\n// ├────────┼──────────────────────────────────────────────────────┤\n// │ BLACK │ In use or free │\n// │ GRAY │ Possible member of cycle │\n// │ WHITE │ Member of garbage cycle │\n// │ PURPLE │ Possible root of cycle │\n// │ RED │ Candidate cycle undergoing Σ-computation *concurrent │\n// │ ORANGE │ Candidate cycle awaiting epoch boundary *concurrent │\n// └────────┴──────────────────────────────────────────────────────┘\n// Acyclic detection has been decoupled, hence no GREEN.\n\n// @ts-ignore: decorator\n@inline const COLOR_BLACK: u32 = 0 << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const COLOR_GRAY: u32 = 1 << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const COLOR_WHITE: u32 = 2 << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const COLOR_PURPLE: u32 = 3 << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const COLOR_RED: u32 = 4 << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const COLOR_ORANGE: u32 = 5 << COLOR_SHIFT;\n\n// @ts-ignore: decorator\n@inline const VISIT_DECREMENT = 1; // guard 0\n// @ts-ignore: decorator\n@inline const VISIT_MARKGRAY = 2;\n// @ts-ignore: decorator\n@inline const VISIT_SCAN = 3;\n// @ts-ignore: decorator\n@inline const VISIT_SCANBLACK = 4;\n// @ts-ignore: decorator\n@inline const VISIT_COLLECTWHITE = 5;\n\n// @ts-ignore: decorator\n@global @unsafe\nfunction __visit(ref: usize, cookie: i32): void {\n if (ref < __heap_base) return;\n var s = changetype(ref - BLOCK_OVERHEAD);\n switch (cookie) {\n case VISIT_DECREMENT: {\n decrement(s);\n break;\n }\n case VISIT_MARKGRAY: {\n if (DEBUG) assert((s.gcInfo & REFCOUNT_MASK) > 0);\n s.gcInfo = s.gcInfo - 1;\n markGray(s);\n break;\n }\n case VISIT_SCAN: {\n scan(s);\n break;\n }\n case VISIT_SCANBLACK: {\n let info = s.gcInfo;\n assert((info & ~REFCOUNT_MASK) == ((info + 1) & ~REFCOUNT_MASK)); // overflow\n s.gcInfo = info + 1;\n if ((info & COLOR_MASK) != COLOR_BLACK) {\n scanBlack(s);\n }\n break;\n }\n case VISIT_COLLECTWHITE: {\n collectWhite(s);\n break;\n }\n default: if (DEBUG) assert(false);\n }\n}\n\n/** Increments the reference count of the specified block by one.*/\nfunction increment(s: Block): void {\n var info = s.gcInfo;\n assert((info & ~REFCOUNT_MASK) == ((info + 1) & ~REFCOUNT_MASK)); // overflow\n s.gcInfo = info + 1;\n if (isDefined(ASC_RTRACE)) onincrement(s);\n if (DEBUG) assert(!(s.mmInfo & 1)); // used\n}\n\n/** Decrements the reference count of the specified block by one, possibly freeing it. */\nfunction decrement(s: Block): void {\n var info = s.gcInfo;\n var rc = info & REFCOUNT_MASK;\n if (isDefined(ASC_RTRACE)) ondecrement(s);\n if (DEBUG) assert(!(s.mmInfo & 1)); // used\n if (rc == 1) {\n __visit_members(changetype(s) + BLOCK_OVERHEAD, VISIT_DECREMENT);\n if (!(info & BUFFERED_MASK)) {\n freeBlock(ROOT, s);\n } else {\n s.gcInfo = BUFFERED_MASK | COLOR_BLACK | 0;\n }\n } else {\n if (DEBUG) assert(rc > 0);\n if (!(__typeinfo(s.rtId) & TypeinfoFlags.ACYCLIC)) {\n s.gcInfo = BUFFERED_MASK | COLOR_PURPLE | (rc - 1);\n if (!(info & BUFFERED_MASK)) {\n appendRoot(s);\n }\n } else {\n s.gcInfo = (info & ~REFCOUNT_MASK) | (rc - 1);\n }\n }\n}\n\n/** Buffer of possible roots. */\n// @ts-ignore: decorator\n@lazy var ROOTS: usize;\n/** Current absolute offset into the `ROOTS` buffer. */\n// @ts-ignore: decorator\n@lazy var CUR: usize = 0;\n/** Current absolute end offset into the `ROOTS` buffer. */\n// @ts-ignore: decorator\n@lazy var END: usize = 0;\n\n/** Appends a block to possible roots. */\nfunction appendRoot(s: Block): void {\n var cur = CUR;\n if (cur >= END) {\n growRoots(); // TBD: either that or pick a default and force collection on overflow\n cur = CUR;\n }\n store(cur, s);\n CUR = cur + sizeof();\n}\n\n/** Grows the roots buffer if it ran full. */\nfunction growRoots(): void {\n var oldRoots = ROOTS;\n var oldSize = CUR - oldRoots;\n var newSize = max(oldSize * 2, 64 << alignof());\n var newRoots = __alloc(newSize, 0);\n if (isDefined(ASC_RTRACE)) onfree(changetype(newRoots - BLOCK_OVERHEAD)); // neglect unmanaged\n memory.copy(newRoots, oldRoots, oldSize);\n if (oldRoots) {\n if (isDefined(ASC_RTRACE)) onalloc(changetype(oldRoots - BLOCK_OVERHEAD)); // neglect unmanaged\n __free(oldRoots);\n }\n ROOTS = newRoots;\n CUR = newRoots + oldSize;\n END = newRoots + newSize;\n}\n\n/** Collects cyclic garbage. */\n// @ts-ignore: decorator\n@global @unsafe\nexport function __collect(): void {\n\n // markRoots\n var roots = ROOTS;\n var cur = roots;\n for (let pos = cur, end = CUR; pos < end; pos += sizeof()) {\n let s = load(pos);\n let info = s.gcInfo;\n if ((info & COLOR_MASK) == COLOR_PURPLE && (info & REFCOUNT_MASK) > 0) {\n markGray(s);\n store(cur, s);\n cur += sizeof();\n } else {\n if ((info & COLOR_MASK) == COLOR_BLACK && !(info & REFCOUNT_MASK)) {\n freeBlock(ROOT, s);\n } else {\n s.gcInfo = info & ~BUFFERED_MASK;\n }\n }\n }\n CUR = cur;\n\n // scanRoots\n for (let pos = roots; pos < cur; pos += sizeof()) {\n scan(load(pos));\n }\n\n // collectRoots\n for (let pos = roots; pos < cur; pos += sizeof()) {\n let s = load(pos);\n s.gcInfo = s.gcInfo & ~BUFFERED_MASK;\n collectWhite(s);\n }\n CUR = roots;\n}\n\n/** Marks a block as gray (possible member of cycle) during the collection phase. */\nfunction markGray(s: Block): void {\n var info = s.gcInfo;\n if ((info & COLOR_MASK) != COLOR_GRAY) {\n s.gcInfo = (info & ~COLOR_MASK) | COLOR_GRAY;\n __visit_members(changetype(s) + BLOCK_OVERHEAD, VISIT_MARKGRAY);\n }\n}\n\n/** Scans a block during the collection phase, determining whether it is garbage or not. */\nfunction scan(s: Block): void {\n var info = s.gcInfo;\n if ((info & COLOR_MASK) == COLOR_GRAY) {\n if ((info & REFCOUNT_MASK) > 0) {\n scanBlack(s);\n } else {\n s.gcInfo = (info & ~COLOR_MASK) | COLOR_WHITE;\n __visit_members(changetype(s) + BLOCK_OVERHEAD, VISIT_SCAN);\n }\n }\n}\n\n/** Marks a block as black (in use) if it was found to be reachable during the collection phase. */\nfunction scanBlack(s: Block): void {\n s.gcInfo = (s.gcInfo & ~COLOR_MASK) | COLOR_BLACK;\n __visit_members(changetype(s) + BLOCK_OVERHEAD, VISIT_SCANBLACK);\n}\n\n/** Collects all white (member of a garbage cycle) nodes when completing the collection phase. */\nfunction collectWhite(s: Block): void {\n var info = s.gcInfo;\n if ((info & COLOR_MASK) == COLOR_WHITE && !(info & BUFFERED_MASK)) {\n s.gcInfo = (info & ~COLOR_MASK) | COLOR_BLACK;\n __visit_members(changetype(s) + BLOCK_OVERHEAD, VISIT_COLLECTWHITE);\n freeBlock(ROOT, s);\n }\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __retain(ref: usize): usize {\n if (ref > __heap_base) increment(changetype(ref - BLOCK_OVERHEAD));\n return ref;\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __release(ref: usize): void {\n if (ref > __heap_base) decrement(changetype(ref - BLOCK_OVERHEAD));\n}\n',"rt/rtrace":'import { BLOCK } from "./common";\n\nexport declare function onalloc(s: BLOCK): void;\nexport declare function onincrement(s: BLOCK): void;\nexport declare function ondecrement(s: BLOCK): void;\nexport declare function onfree(s: BLOCK): void;\n',"rt/stub":'import { AL_MASK, BLOCK, BLOCK_OVERHEAD, BLOCK_MAXSIZE } from "rt/common";\n\n// @ts-ignore: decorator\n@lazy\nvar startOffset: usize = (__heap_base + AL_MASK) & ~AL_MASK;\n\n// @ts-ignore: decorator\n@lazy\nvar offset: usize = startOffset;\n\n// @ts-ignore: decorator\n@unsafe @global\nexport function __alloc(size: usize, id: u32): usize {\n if (size > BLOCK_MAXSIZE) unreachable();\n var ptr = offset + BLOCK_OVERHEAD;\n var newPtr = (ptr + max(size, 1) + AL_MASK) & ~AL_MASK;\n var pagesBefore = memory.size();\n if (newPtr > pagesBefore << 16) {\n let pagesNeeded = ((newPtr - ptr + 0xffff) & ~0xffff) >>> 16;\n let pagesWanted = max(pagesBefore, pagesNeeded); // double memory\n if (memory.grow(pagesWanted) < 0) {\n if (memory.grow(pagesNeeded) < 0) unreachable(); // out of memory\n }\n }\n offset = newPtr;\n var block = changetype(ptr - BLOCK_OVERHEAD);\n block.rtId = id;\n block.rtSize = size;\n return ptr;\n}\n\n// @ts-ignore: decorator\n@unsafe @global\nexport function __realloc(ref: usize, size: usize): usize {\n var block = changetype(ref - BLOCK_OVERHEAD);\n var oldSize = block.rtSize;\n if (size > oldSize) {\n let newRef = __alloc(size, block.rtId);\n memory.copy(newRef, ref, oldSize);\n ref = newRef;\n } else {\n block.rtSize = size;\n }\n return ref;\n}\n\n// @ts-ignore: decorator\n@unsafe @global\nexport function __free(ref: usize): void {\n}\n\n// @ts-ignore: decorator\n@unsafe @global\nfunction __reset(): void { // special\n offset = startOffset;\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __retain(ref: usize): usize {\n return ref;\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __release(ref: usize): void {\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __visit(ref: usize, cookie: u32): void {\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __collect(): void {\n}\n',"rt/tlsf":"import { AL_BITS, AL_MASK, DEBUG, BLOCK, BLOCK_OVERHEAD, BLOCK_MAXSIZE } from \"rt/common\";\nimport { onfree, onalloc } from \"./rtrace\";\n\n/////////////////////// The TLSF (Two-Level Segregate Fit) memory allocator ///////////////////////\n// see: http://www.gii.upv.es/tlsf/\n\n// - `ffs(x)` is equivalent to `ctz(x)` with x != 0\n// - `fls(x)` is equivalent to `sizeof(x) * 8 - clz(x) - 1`\n\n// ╒══════════════ Block size interpretation (32-bit) ═════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┼─┴─┴─┴─╫─┴─┴─┴─┤\n// │ | FL │ SB = SL + AL │ ◄─ usize\n// └───────────────────────────────────────────────┴───────╨───────┘\n// FL: first level, SL: second level, AL: alignment, SB: small block\n\n// @ts-ignore: decorator\n@inline const SL_BITS: u32 = 4;\n// @ts-ignore: decorator\n@inline const SL_SIZE: usize = 1 << SL_BITS;\n\n// @ts-ignore: decorator\n@inline const SB_BITS: usize = (SL_BITS + AL_BITS);\n// @ts-ignore: decorator\n@inline const SB_SIZE: usize = 1 << SB_BITS;\n\n// @ts-ignore: decorator\n@inline const FL_BITS: u32 = 31 - SB_BITS;\n\n// [00]: < 256B (SB) [12]: < 1M\n// [01]: < 512B [13]: < 2M\n// [02]: < 1K [14]: < 4M\n// [03]: < 2K [15]: < 8M\n// [04]: < 4K [16]: < 16M\n// [05]: < 8K [17]: < 32M\n// [06]: < 16K [18]: < 64M\n// [07]: < 32K [19]: < 128M\n// [08]: < 64K [20]: < 256M\n// [09]: < 128K [21]: < 512M\n// [10]: < 256K [22]: <= 1G - OVERHEAD\n// [11]: < 512K\n// VMs limit to 2GB total (currently), making one 1G block max (or three 512M etc.) due to block overhead\n\n// Tags stored in otherwise unused alignment bits\n\n// @ts-ignore: decorator\n@inline const FREE: usize = 1 << 0;\n// @ts-ignore: decorator\n@inline const LEFTFREE: usize = 1 << 1;\n// @ts-ignore: decorator\n@inline const TAGS_MASK: usize = FREE | LEFTFREE; // <= AL_MASK\n\n// ╒════════════════════ Block layout (32-bit) ════════════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┼─┼─┼─┤ overhead ┐\n// │ size │0│L│F│ ◄─┐ info\n// ├─────────────────────────────────────────────────────────┴─┴─┴─┤ │\n// │ │ │\n// │ ... additional runtime overhead ... │ │\n// │ │ │\n// ╞═══════════════════════════════════════════════════════════════╡ │ ┐ ┘\n// │ if free: ◄ prev │ ◄─┤ usize\n// ├───────────────────────────────────────────────────────────────┤ │\n// │ if free: next ► │ ◄─┤\n// ├───────────────────────────────────────────────────────────────┤ │\n// │ ... │ │ = 0\n// ├───────────────────────────────────────────────────────────────┤ │\n// │ if free: back ▲ │ ◄─┘\n// └───────────────────────────────────────────────────────────────┘ payload ┘ >= MIN SIZE\n// F: FREE, L: LEFTFREE\n@unmanaged export class Block extends BLOCK {\n\n /** Previous free block, if any. Only valid if free, otherwise part of payload. */\n prev: Block | null;\n /** Next free block, if any. Only valid if free, otherwise part of payload. */\n next: Block | null;\n\n // If the block is free, there is a 'back'reference at its end pointing at its start.\n}\n\n// Block constants. A block must have a minimum size of three pointers so it can hold `prev`,\n// `next` and `back` if free.\n\n// @ts-ignore: decorator\n@inline const BLOCK_MINSIZE: usize = (3 * sizeof() + AL_MASK) & ~AL_MASK; // prev + next + back\n// @ts-ignore: decorator\n// @inline const BLOCK_MAXSIZE: usize = 1 << (FL_BITS + SB_BITS - 1); // exclusive, lives in common.ts\n\n/** Gets the left block of a block. Only valid if the left block is free. */\n// @ts-ignore: decorator\n@inline function GETFREELEFT(block: Block): Block {\n return load(changetype(block) - sizeof());\n}\n\n/** Gets the right block of of a block by advancing to the right by its size. */\n// @ts-ignore: decorator\n@inline function GETRIGHT(block: Block): Block {\n return changetype(changetype(block) + BLOCK_OVERHEAD + (block.mmInfo & ~TAGS_MASK));\n}\n\n// ╒═════════════════════ Root layout (32-bit) ════════════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤ ┐\n// │ 0 | flMap S│ ◄────┐\n// ╞═══════════════════════════════════════════════════════════════╡ │\n// │ slMap[0] S │ ◄─┐ │\n// ├───────────────────────────────────────────────────────────────┤ │ │\n// │ slMap[1] │ ◄─┤ │\n// ├───────────────────────────────────────────────────────────────┤ u32 │\n// │ slMap[22] │ ◄─┘ │\n// ╞═══════════════════════════════════════════════════════════════╡ usize\n// │ head[0] │ ◄────┤\n// ├───────────────────────────────────────────────────────────────┤ │\n// │ ... │ ◄────┤\n// ├───────────────────────────────────────────────────────────────┤ │\n// │ head[367] │ ◄────┤\n// ╞═══════════════════════════════════════════════════════════════╡ │\n// │ tail │ ◄────┘\n// └───────────────────────────────────────────────────────────────┘ SIZE ┘\n// S: Small blocks map\n@unmanaged class Root {\n /** First level bitmap. */\n flMap: usize;\n}\n\n// Root constants. Where stuff is stored inside of the root structure.\n\n// @ts-ignore: decorator\n@inline const SL_START = sizeof();\n// @ts-ignore: decorator\n@inline const SL_END = SL_START + (FL_BITS << alignof());\n// @ts-ignore: decorator\n@inline const HL_START = (SL_END + AL_MASK) & ~AL_MASK;\n// @ts-ignore: decorator\n@inline const HL_END = HL_START + FL_BITS * SL_SIZE * sizeof();\n// @ts-ignore: decorator\n@inline const ROOT_SIZE = HL_END + sizeof();\n\n// @ts-ignore: decorator\n@lazy export var ROOT: Root;\n\n/** Gets the second level map of the specified first level. */\n// @ts-ignore: decorator\n@inline function GETSL(root: Root, fl: usize): u32 {\n return load(\n changetype(root) + (fl << alignof()),\n SL_START\n );\n}\n\n/** Sets the second level map of the specified first level. */\n// @ts-ignore: decorator\n@inline function SETSL(root: Root, fl: usize, slMap: u32): void {\n store(\n changetype(root) + (fl << alignof()),\n slMap,\n SL_START\n );\n}\n\n/** Gets the head of the free list for the specified combination of first and second level. */\n// @ts-ignore: decorator\n@inline function GETHEAD(root: Root, fl: usize, sl: u32): Block | null {\n return load(\n changetype(root) + (((fl << SL_BITS) + sl) << alignof()),\n HL_START\n );\n}\n\n/** Sets the head of the free list for the specified combination of first and second level. */\n// @ts-ignore: decorator\n@inline function SETHEAD(root: Root, fl: usize, sl: u32, head: Block | null): void {\n store(\n changetype(root) + (((fl << SL_BITS) + sl) << alignof()),\n head,\n HL_START\n );\n}\n\n/** Gets the tail block.. */\n// @ts-ignore: decorator\n@inline function GETTAIL(root: Root): Block {\n return load(\n changetype(root),\n HL_END\n );\n}\n\n/** Sets the tail block. */\n// @ts-ignore: decorator\n@inline function SETTAIL(root: Root, tail: Block): void {\n store(\n changetype(root),\n tail,\n HL_END\n );\n}\n\n/** Inserts a previously used block back into the free list. */\nfunction insertBlock(root: Root, block: Block): void {\n if (DEBUG) assert(block); // cannot be null\n var blockInfo = block.mmInfo;\n if (DEBUG) assert(blockInfo & FREE); // must be free\n\n var right = GETRIGHT(block);\n var rightInfo = right.mmInfo;\n\n // merge with right block if also free\n if (rightInfo & FREE) {\n let newSize = (blockInfo & ~TAGS_MASK) + BLOCK_OVERHEAD + (rightInfo & ~TAGS_MASK);\n if (newSize < BLOCK_MAXSIZE) {\n removeBlock(root, right);\n block.mmInfo = blockInfo = (blockInfo & TAGS_MASK) | newSize;\n right = GETRIGHT(block);\n rightInfo = right.mmInfo;\n // 'back' is set below\n }\n }\n\n // merge with left block if also free\n if (blockInfo & LEFTFREE) {\n let left = GETFREELEFT(block);\n let leftInfo = left.mmInfo;\n if (DEBUG) assert(leftInfo & FREE); // must be free according to right tags\n let newSize = (leftInfo & ~TAGS_MASK) + BLOCK_OVERHEAD + (blockInfo & ~TAGS_MASK);\n if (newSize < BLOCK_MAXSIZE) {\n removeBlock(root, left);\n left.mmInfo = blockInfo = (leftInfo & TAGS_MASK) | newSize;\n block = left;\n // 'back' is set below\n }\n }\n\n right.mmInfo = rightInfo | LEFTFREE;\n // right is no longer used now, hence rightInfo is not synced\n\n // we now know the size of the block\n var size = blockInfo & ~TAGS_MASK;\n if (DEBUG) assert(size >= BLOCK_MINSIZE && size < BLOCK_MAXSIZE); // must be a valid size\n if (DEBUG) assert(changetype(block) + BLOCK_OVERHEAD + size == changetype(right)); // must match\n\n // set 'back' to itself at the end of block\n store(changetype(right) - sizeof(), block);\n\n // mapping_insert\n var fl: usize, sl: u32;\n if (size < SB_SIZE) {\n fl = 0;\n sl = (size >> AL_BITS);\n } else {\n const inv: usize = sizeof() * 8 - 1;\n fl = inv - clz(size);\n sl = ((size >> (fl - SL_BITS)) ^ (1 << SL_BITS));\n fl -= SB_BITS - 1;\n }\n if (DEBUG) assert(fl < FL_BITS && sl < SL_SIZE); // fl/sl out of range\n\n // perform insertion\n var head = GETHEAD(root, fl, sl);\n block.prev = null;\n block.next = head;\n if (head) head.prev = block;\n SETHEAD(root, fl, sl, block);\n\n // update first and second level maps\n root.flMap |= (1 << fl);\n SETSL(root, fl, GETSL(root, fl) | (1 << sl));\n}\n\n/** Removes a free block from internal lists. */\nfunction removeBlock(root: Root, block: Block): void {\n var blockInfo = block.mmInfo;\n if (DEBUG) assert(blockInfo & FREE); // must be free\n var size = blockInfo & ~TAGS_MASK;\n if (DEBUG) assert(size >= BLOCK_MINSIZE && size < BLOCK_MAXSIZE); // must be valid\n\n // mapping_insert\n var fl: usize, sl: u32;\n if (size < SB_SIZE) {\n fl = 0;\n sl = (size >> AL_BITS);\n } else {\n const inv: usize = sizeof() * 8 - 1;\n fl = inv - clz(size);\n sl = ((size >> (fl - SL_BITS)) ^ (1 << SL_BITS));\n fl -= SB_BITS - 1;\n }\n if (DEBUG) assert(fl < FL_BITS && sl < SL_SIZE); // fl/sl out of range\n\n // link previous and next free block\n var prev = block.prev;\n var next = block.next;\n if (prev) prev.next = next;\n if (next) next.prev = prev;\n\n // update head if we are removing it\n if (block == GETHEAD(root, fl, sl)) {\n SETHEAD(root, fl, sl, next);\n\n // clear second level map if head is empty now\n if (!next) {\n let slMap = GETSL(root, fl);\n SETSL(root, fl, slMap &= ~(1 << sl));\n\n // clear first level map if second level is empty now\n if (!slMap) root.flMap &= ~(1 << fl);\n }\n }\n // note: does not alter left/back because it is likely that splitting\n // is performed afterwards, invalidating those changes. so, the caller\n // must perform those updates.\n}\n\n/** Searches for a free block of at least the specified size. */\nfunction searchBlock(root: Root, size: usize): Block | null {\n // size was already asserted by caller\n\n // mapping_search\n var fl: usize, sl: u32;\n if (size < SB_SIZE) {\n fl = 0;\n sl = (size >> AL_BITS);\n } else {\n const halfMaxSize = BLOCK_MAXSIZE >> 1; // don't round last fl\n const inv: usize = sizeof() * 8 - 1;\n const invRound = inv - SL_BITS;\n let requestSize = size < halfMaxSize\n ? size + (1 << (invRound - clz(size))) - 1\n : size;\n fl = inv - clz(requestSize);\n sl = ((requestSize >> (fl - SL_BITS)) ^ (1 << SL_BITS));\n fl -= SB_BITS - 1;\n }\n if (DEBUG) assert(fl < FL_BITS && sl < SL_SIZE); // fl/sl out of range\n\n // search second level\n var slMap = GETSL(root, fl) & (~0 << sl);\n var head: Block | null = null;\n if (!slMap) {\n // search next larger first level\n let flMap = root.flMap & (~0 << (fl + 1));\n if (!flMap) {\n head = null;\n } else {\n fl = ctz(flMap);\n slMap = GETSL(root, fl);\n if (DEBUG) assert(slMap); // can't be zero if fl points here\n head = GETHEAD(root, fl, ctz(slMap));\n }\n } else {\n head = GETHEAD(root, fl, ctz(slMap));\n }\n return head;\n}\n\n/** Prepares the specified block before (re-)use, possibly splitting it. */\nfunction prepareBlock(root: Root, block: Block, size: usize): void {\n // size was already asserted by caller\n\n var blockInfo = block.mmInfo;\n if (DEBUG) assert(!(size & AL_MASK)); // size must be aligned so the new block is\n\n // split if the block can hold another MINSIZE block incl. overhead\n var remaining = (blockInfo & ~TAGS_MASK) - size;\n if (remaining >= BLOCK_OVERHEAD + BLOCK_MINSIZE) {\n block.mmInfo = size | (blockInfo & LEFTFREE); // also discards FREE\n\n let spare = changetype(changetype(block) + BLOCK_OVERHEAD + size);\n spare.mmInfo = (remaining - BLOCK_OVERHEAD) | FREE; // not LEFTFREE\n insertBlock(root, spare); // also sets 'back'\n\n // otherwise tag block as no longer FREE and right as no longer LEFTFREE\n } else {\n block.mmInfo = blockInfo & ~FREE;\n GETRIGHT(block).mmInfo &= ~LEFTFREE;\n }\n}\n\n/** Adds more memory to the pool. */\nfunction addMemory(root: Root, start: usize, end: usize): bool {\n if (DEBUG) {\n assert(\n start <= end && // must be valid\n !(start & AL_MASK) && // must be aligned\n !(end & AL_MASK) // must be aligned\n );\n }\n\n var tail = GETTAIL(root);\n var tailInfo: usize = 0;\n if (tail) { // more memory\n if (DEBUG) assert(start >= changetype(tail) + BLOCK_OVERHEAD);\n\n // merge with current tail if adjacent\n if (start - BLOCK_OVERHEAD == changetype(tail)) {\n start -= BLOCK_OVERHEAD;\n tailInfo = tail.mmInfo;\n } else {\n // We don't do this, but a user might `memory.grow` manually\n // leading to non-adjacent pages managed by TLSF.\n }\n\n } else if (DEBUG) { // first memory\n assert(start >= changetype(root) + ROOT_SIZE); // starts after root\n }\n\n // check if size is large enough for a free block and the tail block\n var size = end - start;\n if (size < BLOCK_OVERHEAD + BLOCK_MINSIZE + BLOCK_OVERHEAD) {\n return false;\n }\n\n // left size is total minus its own and the zero-length tail's header\n var leftSize = size - 2 * BLOCK_OVERHEAD;\n var left = changetype(start);\n left.mmInfo = leftSize | FREE | (tailInfo & LEFTFREE);\n left.prev = null;\n left.next = null;\n\n // tail is a zero-length used block\n tail = changetype(start + size - BLOCK_OVERHEAD);\n tail.mmInfo = 0 | LEFTFREE;\n SETTAIL(root, tail);\n\n insertBlock(root, left); // also merges with free left before tail / sets 'back'\n\n return true;\n}\n\n/** Grows memory to fit at least another block of the specified size. */\nfunction growMemory(root: Root, size: usize): void {\n var pagesBefore = memory.size();\n var pagesNeeded = (((size + 0xffff) & ~0xffff) >>> 16);\n var pagesWanted = max(pagesBefore, pagesNeeded); // double memory\n if (memory.grow(pagesWanted) < 0) {\n if (memory.grow(pagesNeeded) < 0) unreachable();\n }\n var pagesAfter = memory.size();\n addMemory(root, pagesBefore << 16, pagesAfter << 16);\n}\n\n/** Prepares and checks an allocation size. */\nfunction prepareSize(size: usize): usize {\n if (size >= BLOCK_MAXSIZE) throw new Error(\"allocation too large\");\n return max((size + AL_MASK) & ~AL_MASK, BLOCK_MINSIZE); // align and ensure min size\n}\n\n/** Initilizes the root structure. */\nexport function initializeRoot(): void {\n var rootOffset = (__heap_base + AL_MASK) & ~AL_MASK;\n var pagesBefore = memory.size();\n var pagesNeeded = ((((rootOffset + ROOT_SIZE) + 0xffff) & ~0xffff) >>> 16);\n if (pagesNeeded > pagesBefore && memory.grow(pagesNeeded - pagesBefore) < 0) unreachable();\n var root = changetype(rootOffset);\n root.flMap = 0;\n SETTAIL(root, changetype(0));\n for (let fl: usize = 0; fl < FL_BITS; ++fl) {\n SETSL(root, fl, 0);\n for (let sl: u32 = 0; sl < SL_SIZE; ++sl) {\n SETHEAD(root, fl, sl, null);\n }\n }\n addMemory(root, (rootOffset + ROOT_SIZE + AL_MASK) & ~AL_MASK, memory.size() << 16);\n ROOT = root;\n}\n\n/** Allocates a block of the specified size. */\nexport function allocateBlock(root: Root, size: usize): Block {\n var payloadSize = prepareSize(size);\n var block = searchBlock(root, payloadSize);\n if (!block) {\n growMemory(root, payloadSize);\n block = searchBlock(root, payloadSize);\n if (DEBUG) assert(block); // must be found now\n }\n if (DEBUG) assert((block.mmInfo & ~TAGS_MASK) >= payloadSize); // must fit\n block.gcInfo = 0; // RC=0\n // block.rtId = 0; // set by the caller (__alloc)\n block.rtSize = size;\n removeBlock(root, block);\n prepareBlock(root, block, payloadSize);\n if (isDefined(ASC_RTRACE)) onalloc(block);\n return block;\n}\n\n/** Reallocates a block to the specified size. */\nexport function reallocateBlock(root: Root, block: Block, size: usize): Block {\n var payloadSize = prepareSize(size);\n var blockInfo = block.mmInfo;\n if (DEBUG) assert(!(blockInfo & FREE)); // must be used\n\n // possibly split and update runtime size if it still fits\n if (payloadSize <= (blockInfo & ~TAGS_MASK)) {\n prepareBlock(root, block, payloadSize);\n block.rtSize = size;\n return block;\n }\n\n // merge with right free block if merger is large enough\n var right = GETRIGHT(block);\n var rightInfo = right.mmInfo;\n if (rightInfo & FREE) {\n let mergeSize = (blockInfo & ~TAGS_MASK) + BLOCK_OVERHEAD + (rightInfo & ~TAGS_MASK);\n if (mergeSize >= payloadSize) {\n removeBlock(root, right);\n // TODO: this can yield an intermediate block larger than BLOCK_MAXSIZE, which\n // is immediately split though. does this trigger any assertions / issues?\n block.mmInfo = (blockInfo & TAGS_MASK) | mergeSize;\n block.rtSize = size;\n prepareBlock(root, block, payloadSize);\n return block;\n }\n }\n\n // otherwise move the block\n var newBlock = allocateBlock(root, size);\n newBlock.gcInfo = block.gcInfo;\n newBlock.rtId = block.rtId;\n memory.copy(changetype(newBlock) + BLOCK_OVERHEAD, changetype(block) + BLOCK_OVERHEAD, size);\n block.mmInfo = blockInfo | FREE;\n insertBlock(root, block);\n return newBlock;\n}\n\n/** Frees a block. */\nexport function freeBlock(root: Root, block: Block): void {\n var blockInfo = block.mmInfo;\n assert(!(blockInfo & FREE)); // must be used (user might call through to this)\n block.mmInfo = blockInfo | FREE;\n insertBlock(root, block);\n if (isDefined(ASC_RTRACE)) onfree(block);\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __alloc(size: usize, id: u32): usize {\n var root = ROOT;\n if (!root) {\n initializeRoot();\n root = ROOT;\n }\n var block = allocateBlock(root, size);\n block.rtId = id;\n return changetype(block) + BLOCK_OVERHEAD;\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __realloc(ref: usize, size: usize): usize {\n if (DEBUG) assert(ROOT); // must be initialized\n assert(ref != 0 && !(ref & AL_MASK)); // must exist and be aligned\n return changetype(reallocateBlock(ROOT, changetype(ref - BLOCK_OVERHEAD), size)) + BLOCK_OVERHEAD;\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __free(ref: usize): void {\n if (DEBUG) assert(ROOT); // must be initialized\n assert(ref != 0 && !(ref & AL_MASK)); // must exist and be aligned\n freeBlock(ROOT, changetype(ref - BLOCK_OVERHEAD));\n}\n",set:'/// \n\nimport { HASH } from "./util/hash";\n\n// A deterministic hash set based on CloseTable from https://github.com/jorendorff/dht\n\n// @ts-ignore: decorator\n@inline\nconst INITIAL_CAPACITY = 4;\n\n// @ts-ignore: decorator\n@inline\nconst FILL_FACTOR: f64 = 8 / 3;\n\n// @ts-ignore: decorator\n@inline\nconst FREE_FACTOR: f64 = 3 / 4;\n\n/** Structure of a set entry. */\n@unmanaged class SetEntry {\n key: K;\n taggedNext: usize; // LSB=1 indicates EMPTY\n}\n\n/** Empty bit. */\n// @ts-ignore: decorator\n@inline\nconst EMPTY: usize = 1 << 0;\n\n/** Size of a bucket. */\n// @ts-ignore: decorator\n@inline\nconst BUCKET_SIZE = sizeof();\n\n/** Computes the alignment of an entry. */\n// @ts-ignore: decorator\n@inline\nfunction ENTRY_ALIGN(): usize {\n // can align to 4 instead of 8 if 32-bit and K is <= 32-bits\n const align = (sizeof() > sizeof() ? sizeof() : sizeof()) - 1;\n return align;\n}\n\n/** Computes the aligned size of an entry. */\n// @ts-ignore: decorator\n@inline\nfunction ENTRY_SIZE(): usize {\n const align = ENTRY_ALIGN();\n const size = (offsetof>() + align) & ~align;\n return size;\n}\n\nexport class Set {\n\n // buckets holding references to the respective first entry within\n private buckets: ArrayBuffer; // usize[bucketsMask + 1]\n private bucketsMask: u32;\n\n // entries in insertion order\n private entries: ArrayBuffer; // SetEntry[entriesCapacity]\n private entriesCapacity: i32;\n private entriesOffset: i32;\n private entriesCount: i32;\n\n get size(): i32 { return this.entriesCount; }\n\n constructor() { this.clear(); }\n\n clear(): void {\n const bucketsSize = INITIAL_CAPACITY * BUCKET_SIZE;\n this.buckets = new ArrayBuffer(bucketsSize);\n this.bucketsMask = INITIAL_CAPACITY - 1;\n const entriesSize = INITIAL_CAPACITY * ENTRY_SIZE();\n this.entries = new ArrayBuffer(entriesSize);\n this.entriesCapacity = INITIAL_CAPACITY;\n this.entriesOffset = 0;\n this.entriesCount = 0;\n }\n\n private find(key: T, hashCode: u32): SetEntry | null {\n var entry = load>( // unmanaged!\n changetype(this.buckets) + (hashCode & this.bucketsMask) * BUCKET_SIZE\n );\n while (entry) {\n if (!(entry.taggedNext & EMPTY) && entry.key == key) return entry;\n entry = changetype>(entry.taggedNext & ~EMPTY);\n }\n return null;\n }\n\n has(key: T): bool {\n return this.find(key, HASH(key)) !== null;\n }\n\n add(key: T): void {\n var hashCode = HASH(key);\n var entry = this.find(key, hashCode); // unmanaged!\n if (!entry) {\n // check if rehashing is necessary\n if (this.entriesOffset == this.entriesCapacity) {\n this.rehash(\n this.entriesCount < (this.entriesCapacity * FREE_FACTOR)\n ? this.bucketsMask // just rehash if 1/4+ entries are empty\n : (this.bucketsMask << 1) | 1 // grow capacity to next 2^N\n );\n }\n // append new entry\n entry = changetype>(changetype(this.entries) + this.entriesOffset++ * ENTRY_SIZE());\n entry.key = isManaged()\n ? changetype(__retain(changetype(key)))\n : key;\n ++this.entriesCount;\n // link with previous entry in bucket\n let bucketPtrBase = changetype(this.buckets) + (hashCode & this.bucketsMask) * BUCKET_SIZE;\n entry.taggedNext = load(bucketPtrBase);\n store(bucketPtrBase, changetype(entry));\n }\n }\n\n delete(key: T): bool {\n var entry = this.find(key, HASH(key)); // unmanaged!\n if (!entry) return false;\n if (isManaged()) __release(changetype(entry.key)); // exact \'key\'\n entry.taggedNext |= EMPTY;\n --this.entriesCount;\n // check if rehashing is appropriate\n var halfBucketsMask = this.bucketsMask >> 1;\n if (\n halfBucketsMask + 1 >= max(INITIAL_CAPACITY, this.entriesCount) &&\n this.entriesCount < (this.entriesCapacity * FREE_FACTOR)\n ) this.rehash(halfBucketsMask);\n return true;\n }\n\n private rehash(newBucketsMask: u32): void {\n var newBucketsCapacity = (newBucketsMask + 1);\n var newBuckets = new ArrayBuffer(newBucketsCapacity * BUCKET_SIZE);\n var newEntriesCapacity = (newBucketsCapacity * FILL_FACTOR);\n var newEntries = new ArrayBuffer(newEntriesCapacity * ENTRY_SIZE());\n\n // copy old entries to new entries\n var oldPtr = changetype(this.entries);\n var oldEnd = oldPtr + this.entriesOffset * ENTRY_SIZE();\n var newPtr = changetype(newEntries);\n while (oldPtr != oldEnd) {\n let oldEntry = changetype>(oldPtr); // unmanaged!\n if (!(oldEntry.taggedNext & EMPTY)) {\n let newEntry = changetype>(newPtr); // unmanaged!\n newEntry.key = oldEntry.key;\n let newBucketIndex = HASH(oldEntry.key) & newBucketsMask;\n let newBucketPtrBase = changetype(newBuckets) + newBucketIndex * BUCKET_SIZE;\n newEntry.taggedNext = load(newBucketPtrBase);\n store(newBucketPtrBase, newPtr);\n newPtr += ENTRY_SIZE();\n }\n oldPtr += ENTRY_SIZE();\n }\n\n this.buckets = newBuckets;\n this.bucketsMask = newBucketsMask;\n this.entries = newEntries;\n this.entriesCapacity = newEntriesCapacity;\n this.entriesOffset = this.entriesCount;\n }\n\n values(): T[] {\n // FIXME: this is preliminary, needs iterators/closures\n var start = changetype(this.entries);\n var size = this.entriesOffset;\n var values = Array.create(size);\n for (let i = 0; i < size; ++i) {\n let entry = changetype>(start + i * ENTRY_SIZE());\n if (!(entry.taggedNext & EMPTY)) {\n values.push(entry.key);\n }\n }\n return values;\n }\n\n toString(): string {\n return "[object Set]";\n }\n\n // RT integration\n\n @unsafe private __visit_impl(cookie: u32): void {\n __visit(changetype(this.buckets), cookie);\n var entries = changetype(this.entries);\n if (isManaged()) {\n let cur = entries;\n let end = cur + this.entriesOffset * ENTRY_SIZE();\n while (cur < end) {\n let entry = changetype>(cur);\n if (!(entry.taggedNext & EMPTY)) {\n let val = changetype(entry.key);\n if (isNullable()) {\n if (val) __visit(val, cookie);\n } else __visit(val, cookie);\n }\n cur += ENTRY_SIZE();\n }\n }\n __visit(entries, cookie);\n }\n}\n',"shared/feature":"// This file is shared with the compiler and must remain portable\n\n/** Indicates specific features to activate. */\nexport const enum Feature {\n /** No additional features. */\n NONE = 0,\n /** Sign extension operations. */\n SIGN_EXTENSION = 1 << 0, // see: https://github.com/WebAssembly/sign-extension-ops\n /** Mutable global imports and exports. */\n MUTABLE_GLOBAL = 1 << 1, // see: https://github.com/WebAssembly/mutable-global\n /** Bulk memory operations. */\n BULK_MEMORY = 1 << 2, // see: https://github.com/WebAssembly/bulk-memory-operations\n /** SIMD types and operations. */\n SIMD = 1 << 3, // see: https://github.com/WebAssembly/simd\n /** Threading and atomic operations. */\n THREADS = 1 << 4 // see: https://github.com/WebAssembly/threads\n}\n","shared/target":"// This file is shared with the compiler and must remain portable\n\n/** Compilation target. */\nexport enum Target {\n /** WebAssembly with 32-bit pointers. */\n WASM32,\n /** WebAssembly with 64-bit pointers. Experimental and not supported by any runtime yet. */\n WASM64,\n /** Portable. */\n JS\n}\n","shared/typeinfo":"// This file is shared with the compiler and must remain portable\n\n// ╒═══════════════════ Typeinfo interpretation ═══════════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤ ◄─ __rtti_base\n// │ count │\n// ╞═══════════════════════════════════════════════════════════════╡ ┐\n// │ Typeinfo#flags [id=0] │ id < count\n// ├ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ┤\n// │ Typeinfo#base [id=0] │\n// ├───────────────────────────────────────────────────────────────┤\n// │ ... │\n\n/** Runtime type information data structure. */\n@unmanaged\nexport class Typeinfo {\n /** Flags describing the shape of this class type. */\n flags: TypeinfoFlags;\n /** Base class id or `0` if none. */\n base: u32;\n}\n\n/** Runtime type information flags. */\nexport const enum TypeinfoFlags {\n /** No specific flags. */\n NONE = 0,\n /** Type is an `ArrayBufferView`. */\n ARRAYBUFFERVIEW = 1 << 0,\n /** Type is an `Array`. */\n ARRAY = 1 << 1,\n /** Type is a `Set`. */\n SET = 1 << 2,\n /** Type is a `Map`. */\n MAP = 1 << 3,\n /** Type is inherently acyclic. */\n ACYCLIC = 1 << 4,\n /** Value alignment of 1 byte. */\n VALUE_ALIGN_0 = 1 << 5,\n /** Value alignment of 2 bytes. */\n VALUE_ALIGN_1 = 1 << 6,\n /** Value alignment of 4 bytes. */\n VALUE_ALIGN_2 = 1 << 7,\n /** Value alignment of 8 bytes. */\n VALUE_ALIGN_3 = 1 << 8,\n /** Value alignment of 16 bytes. */\n VALUE_ALIGN_4 = 1 << 9,\n /** Value is a signed type. */\n VALUE_SIGNED = 1 << 10,\n /** Value is a float type. */\n VALUE_FLOAT = 1 << 11,\n /** Value type is nullable. */\n VALUE_NULLABLE = 1 << 12,\n /** Value type is managed. */\n VALUE_MANAGED = 1 << 13,\n /** Key alignment of 1 byte. */\n KEY_ALIGN_0 = 1 << 14,\n /** Key alignment of 2 bytes. */\n KEY_ALIGN_1 = 1 << 15,\n /** Key alignment of 4 bytes. */\n KEY_ALIGN_2 = 1 << 16,\n /** Key alignment of 8 bytes. */\n KEY_ALIGN_3 = 1 << 17,\n /** Key alignment of 16 bytes. */\n KEY_ALIGN_4 = 1 << 18,\n /** Value is a signed type. */\n KEY_SIGNED = 1 << 19,\n /** Value is a float type. */\n KEY_FLOAT = 1 << 20,\n /** Key type is nullable. */\n KEY_NULLABLE = 1 << 21,\n /** Key type is managed. */\n KEY_MANAGED = 1 << 22\n}\n",string:'/// \n\nimport { BLOCK, BLOCK_OVERHEAD, BLOCK_MAXSIZE } from "./rt/common";\nimport { compareImpl, strtol, strtod, isWhiteSpaceOrLineTerminator } from "./util/string";\nimport { E_INVALIDLENGTH } from "./util/error";\nimport { ArrayBufferView } from "./arraybuffer";\nimport { idof } from "./builtins";\n\n@sealed export abstract class String {\n\n @lazy static readonly MAX_LENGTH: i32 = BLOCK_MAXSIZE >>> alignof();\n\n static fromCharCode(unit: i32, surr: i32 = -1): string {\n var out: usize;\n if (~surr) {\n out = __alloc(4, idof());\n store(out, unit);\n store(out, surr, 2);\n } else {\n out = __alloc(2, idof());\n store(out, unit);\n }\n return changetype(out); // retains\n }\n\n static fromCodePoint(code: i32): string {\n assert(code <= 0x10FFFF);\n var sur = code > 0xFFFF;\n var out = __alloc((i32(sur) + 1) << 1, idof());\n if (!sur) {\n store(out, code);\n } else {\n code -= 0x10000;\n let hi: u32 = (code >>> 10) + 0xD800;\n let lo: u32 = (code & 0x3FF) + 0xDC00;\n store(out, (hi << 16) | lo);\n }\n return changetype(out); // retains\n }\n\n get length(): i32 {\n return changetype(changetype(this) - BLOCK_OVERHEAD).rtSize >> 1;\n }\n\n @operator("[]") charAt(pos: i32): String {\n if (pos >= this.length) return changetype("");\n var out = __alloc(2, idof());\n store(out, load(changetype(this) + (pos << 1)));\n return changetype(out); // retains\n }\n\n charCodeAt(pos: i32): i32 {\n if (pos >= this.length) return -1; // (NaN)\n return load(changetype(this) + (pos << 1));\n }\n\n codePointAt(pos: i32): i32 {\n if (pos >= this.length) return -1; // (undefined)\n var first = load(changetype(this) + (pos << 1));\n if (first < 0xD800 || first > 0xDBFF || pos + 1 == this.length) return first;\n var second = load(changetype(this) + ((pos + 1) << 1));\n if (second < 0xDC00 || second > 0xDFFF) return first;\n return ((first - 0xD800) << 10) + (second - 0xDC00) + 0x10000;\n }\n\n @operator("+") private static __concat(left: String, right: String): String {\n return select(left, changetype("null"), left !== null).concat(right);\n }\n\n concat(other: String): String {\n if (other === null) other = changetype("null");\n var thisSize: isize = this.length << 1;\n var otherSize: isize = other.length << 1;\n var outSize: usize = thisSize + otherSize;\n if (outSize == 0) return changetype("");\n var out = changetype(__alloc(outSize, idof())); // retains\n memory.copy(changetype(out), changetype(this), thisSize);\n memory.copy(changetype(out) + thisSize, changetype(other), otherSize);\n return out;\n }\n\n endsWith(search: String, end: i32 = String.MAX_LENGTH): bool {\n if (search === null) return false;\n end = min(max(end, 0), this.length);\n var searchLength = search.length;\n var searchStart = end - searchLength;\n if (searchStart < 0) return false;\n // @ts-ignore: string <-> String\n return !compareImpl(this, searchStart, search, 0, searchLength);\n }\n\n @operator("==") private static __eq(left: String | null, right: String | null): bool {\n if (left === right) return true;\n if (left === null || right === null) return false;\n var leftLength = left.length;\n if (leftLength != right.length) return false;\n // @ts-ignore: string <-> String\n return !compareImpl(left, 0, right, 0, leftLength);\n }\n\n @operator.prefix("!")\n private static __not(str: String | null): bool {\n return str === null || !str.length;\n }\n\n @operator("!=")\n private static __ne(left: String | null, right: String | null): bool {\n return !this.__eq(left, right);\n }\n\n @operator(">") private static __gt(left: String | null, right: String | null): bool {\n if (left === right || left === null || right === null) return false;\n var leftLength = left.length;\n var rightLength = right.length;\n if (!leftLength) return false;\n if (!rightLength) return true;\n // @ts-ignore: string <-> String\n return compareImpl(left, 0, right, 0, min(leftLength, rightLength)) > 0;\n }\n\n @operator(">=") private static __gte(left: String, right: String): bool {\n return !this.__lt(left, right);\n }\n\n @operator("<") private static __lt(left: String, right: String): bool {\n if (left === right || left === null || right === null) return false;\n var leftLength = left.length;\n var rightLength = right.length;\n if (!rightLength) return false;\n if (!leftLength) return true;\n // @ts-ignore: string <-> String\n return compareImpl(left, 0, right, 0, min(leftLength, rightLength)) < 0;\n }\n\n @operator("<=") private static __lte(left: String, right: String): bool {\n return !this.__gt(left, right);\n }\n\n includes(search: String, start: i32 = 0): bool {\n return this.indexOf(search, start) != -1;\n }\n\n indexOf(search: String, start: i32 = 0): i32 {\n var searchLen = search.length;\n if (!searchLen) return 0;\n var len = this.length;\n if (!len) return -1;\n var searchStart = min(max(start, 0), len);\n for (len -= searchLen; searchStart <= len; ++searchStart) {\n // @ts-ignore: string <-> String\n if (!compareImpl(this, searchStart, search, 0, searchLen)) return searchStart;\n }\n return -1;\n }\n\n lastIndexOf(search: String, start: i32 = i32.MAX_VALUE): i32 {\n var searchLen = search.length;\n if (!searchLen) return this.length;\n var len = this.length;\n if (!len) return -1;\n var searchStart = min(max(start, 0), len - searchLen);\n for (; searchStart >= 0; --searchStart) {\n // @ts-ignore: string <-> String\n if (!compareImpl(this, searchStart, search, 0, searchLen)) return searchStart;\n }\n return -1;\n }\n\n startsWith(search: String, start: i32 = 0): bool {\n if (search === null) search = changetype("null");\n var len = this.length;\n var searchStart = min(max(start, 0), len);\n var searchLength = search.length;\n if (searchLength + searchStart > len) return false;\n // @ts-ignore: string <-> String\n return !compareImpl(this, searchStart, search, 0, searchLength);\n }\n\n substr(start: i32, length: i32 = i32.MAX_VALUE): String { // legacy\n var intStart: isize = start;\n var end: isize = length;\n var size: isize = this.length;\n if (intStart < 0) intStart = max(size + intStart, 0);\n var resultLength = min(max(end, 0), size - intStart);\n if (resultLength <= 0) return changetype("");\n var out = __alloc(resultLength << 1, idof());\n memory.copy(out, changetype(this) + intStart, resultLength);\n return changetype(out); // retains\n }\n\n substring(start: i32, end: i32 = i32.MAX_VALUE): String {\n var len: isize = this.length;\n var finalStart = min(max(start, 0), len);\n var finalEnd = min(max(end, 0), len);\n var fromPos = min(finalStart, finalEnd) << 1;\n var toPos = max(finalStart, finalEnd) << 1;\n len = toPos - fromPos;\n if (!len) return changetype("");\n if (!fromPos && toPos == this.length << 1) return this;\n var out = __alloc(len, idof());\n memory.copy(out, changetype(this) + fromPos, len);\n return changetype(out); // retains\n }\n\n trim(): String {\n var length = this.length;\n var size: usize = length << 1;\n while (\n size &&\n isWhiteSpaceOrLineTerminator(\n load(changetype(this) + size)\n )\n ) {\n size -= 2;\n }\n var offset: usize = 0;\n while (\n offset < size &&\n isWhiteSpaceOrLineTerminator(\n load(changetype(this) + offset)\n )\n ) {\n offset += 2; size -= 2;\n }\n if (!size) return changetype("");\n if (!start && size == length << 1) return this;\n var out = __alloc(size, idof());\n memory.copy(out, changetype(this) + offset, size);\n return changetype(out); // retains\n }\n\n @inline\n trimLeft(): String {\n return this.trimStart();\n }\n\n @inline\n trimRight(): String {\n return this.trimEnd();\n }\n\n trimStart(): String {\n var size = this.length << 1;\n var offset: usize = 0;\n while (\n offset < size &&\n isWhiteSpaceOrLineTerminator(\n load(changetype(this) + offset)\n )\n ) {\n offset += 2;\n }\n if (!offset) return this;\n size -= offset;\n if (!size) return changetype("");\n var out = __alloc(size, idof());\n memory.copy(out, changetype(this) + offset, size);\n return changetype(out); // retains\n }\n\n trimEnd(): String {\n var originalSize = this.length << 1;\n var size = originalSize;\n while (\n size &&\n isWhiteSpaceOrLineTerminator(\n load(changetype(this) + size)\n )\n ) {\n size -= 2;\n }\n if (!size) return changetype("");\n if (size == originalSize) return this;\n var out = __alloc(size, idof());\n memory.copy(out, changetype(this), size);\n return changetype(out); // retains\n }\n\n padStart(length: i32, pad: string = " "): String {\n var thisSize = this.length << 1;\n var targetSize = length << 1;\n var padSize = pad.length << 1;\n if (targetSize < thisSize || !padSize) return this;\n var prependSize = targetSize - thisSize;\n var out = __alloc(targetSize, idof());\n if (prependSize > padSize) {\n let repeatCount = (prependSize - 2) / padSize;\n let restBase = repeatCount * padSize;\n let restSize = prependSize - restBase;\n memory.repeat(out, changetype(pad), padSize, repeatCount);\n memory.copy(out + restBase, changetype(pad), restSize);\n } else {\n memory.copy(out, changetype(pad), prependSize);\n }\n memory.copy(out + prependSize, changetype(this), thisSize);\n return changetype(out); // retains\n }\n\n padEnd(length: i32, pad: string = " "): String {\n var thisSize = this.length << 1;\n var targetSize = length << 1;\n var padSize = pad.length << 1;\n if (targetSize < thisSize || !padSize) return this;\n var appendSize = targetSize - thisSize;\n var out = __alloc(targetSize, idof());\n memory.copy(out, changetype(this), thisSize);\n if (appendSize > padSize) {\n let repeatCount = (appendSize - 2) / padSize;\n let restBase = repeatCount * padSize;\n let restSize = appendSize - restBase;\n memory.repeat(out + thisSize, changetype(pad), padSize, repeatCount);\n memory.copy(out + thisSize + restBase, changetype(pad), restSize);\n } else {\n memory.copy(out + thisSize, changetype(pad), appendSize);\n }\n return changetype(out); // retains\n }\n\n repeat(count: i32 = 0): String {\n var length = this.length;\n\n // Most browsers can\'t handle strings 1 << 28 chars or longer\n if (count < 0 || length * count > (1 << 28)) {\n throw new RangeError(E_INVALIDLENGTH);\n }\n\n if (count == 0 || !length) return changetype("");\n if (count == 1) return this;\n var out = __alloc((length * count) << 1, idof());\n memory.repeat(out, changetype(this), length << 1, count);\n return changetype(out); // retains\n }\n\n replace(search: String, replacement: String): String {\n var len: usize = this.length;\n var slen: usize = search.length;\n if (len <= slen) {\n return len < slen ? this : select(replacement, this, search == this);\n }\n var index: isize = this.indexOf(search);\n if (~index) {\n let rlen: usize = replacement.length;\n len -= slen;\n let olen = len + rlen;\n if (olen) {\n let out = __alloc(olen << 1, idof());\n memory.copy(out, changetype(this), index << 1);\n memory.copy(\n out + (index << 1),\n changetype(replacement),\n rlen << 1\n );\n memory.copy(\n out + ((index + rlen) << 1),\n changetype(this) + ((index + slen) << 1),\n (len - index) << 1\n );\n return changetype(out);\n }\n }\n return this;\n }\n\n replaceAll(search: String, replacement: String): String {\n var len: usize = this.length;\n var slen: usize = search.length;\n if (len <= slen) {\n return len < slen ? this : select(replacement, this, search == this);\n }\n var rlen: usize = replacement.length;\n if (!slen) {\n if (!rlen) return this;\n // Special case: \'abc\'.replaceAll(\'\', \'-\') -> \'-a-b-c-\'\n let out = __alloc((len + (len + 1) * rlen) << 1, idof());\n memory.copy(out, changetype(replacement), rlen << 1);\n let offset = rlen;\n for (let i: usize = 0; i < len; ++i) {\n store(\n changetype(out) + (offset++ << 1),\n load(changetype(this) + (i << 1))\n );\n memory.copy(\n out + (offset << 1),\n changetype(replacement),\n rlen << 1\n );\n offset += rlen;\n }\n return changetype(out);\n }\n var prev: isize = 0, next: isize = 0;\n if (slen == rlen) {\n // Fast path when search and replacement have same length\n let size = len << 1;\n let out = __alloc(size, idof());\n memory.copy(out, changetype(this), size);\n while (~(next = this.indexOf(search, prev))) {\n memory.copy(out + (next << 1), changetype(replacement), rlen << 1);\n prev = next + slen;\n }\n return changetype(out);\n }\n var out: usize = 0, offset: usize = 0, resLen = len;\n while (~(next = this.indexOf(search, prev))) {\n if (!out) out = __alloc(len << 1, idof());\n if (offset > resLen) {\n let newLength = resLen << 1;\n out = __realloc(out, newLength << 1);\n resLen = newLength;\n }\n let chunk = next - prev;\n memory.copy(\n out + (offset << 1),\n changetype(this) + (prev << 1),\n chunk << 1\n );\n offset += chunk;\n memory.copy(\n out + (offset << 1),\n changetype(replacement),\n rlen << 1\n );\n offset += rlen;\n prev = next + slen;\n }\n if (offset) {\n if (offset > resLen) {\n let newLength = resLen << 1;\n out = __realloc(out, newLength << 1);\n resLen = newLength;\n }\n let rest = len - prev;\n if (rest) {\n memory.copy(\n out + (offset << 1),\n changetype(this) + (prev << 1),\n rest << 1\n );\n }\n rest += offset;\n if (resLen > rest) out = __realloc(out, rest << 1);\n return changetype(out);\n }\n return this;\n }\n\n slice(start: i32, end: i32 = i32.MAX_VALUE): String {\n var len = this.length;\n start = start < 0 ? max(start + len, 0) : min(start, len);\n end = end < 0 ? max(end + len, 0) : min(end, len);\n len = end - start;\n if (len <= 0) return changetype("");\n var out = __alloc(len << 1, idof());\n memory.copy(out, changetype(this) + (start << 1), len << 1);\n return changetype(out); // retains\n }\n\n split(separator: String | null = null, limit: i32 = i32.MAX_VALUE): String[] {\n if (!limit) return changetype>(__allocArray(0, alignof(), idof>())); // retains\n if (separator === null) return [this];\n var length: isize = this.length;\n var sepLen: isize = separator.length;\n if (limit < 0) limit = i32.MAX_VALUE;\n if (!sepLen) {\n if (!length) return changetype>(__allocArray(0, alignof(), idof>())); // retains\n // split by chars\n length = min(length, limit);\n let result = __allocArray(length, alignof(), idof>());\n let resultStart = changetype(result).dataStart;\n for (let i: isize = 0; i < length; ++i) {\n let charStr = __alloc(2, idof());\n store(charStr, load(changetype(this) + (i << 1)));\n store(resultStart + (i << alignof()), charStr); // result[i] = charStr\n if (isManaged()) __retain(charStr);\n }\n return changetype>(result); // retains\n } else if (!length) {\n let result = __allocArray(1, alignof(), idof>());\n store(changetype(result).dataStart, changetype("")); // static ""\n return changetype>(result); // retains\n }\n var result = changetype>(__allocArray(0, alignof(), idof>())); // retains\n var end = 0, start = 0, i = 0;\n while (~(end = this.indexOf(separator, start))) {\n let len = end - start;\n if (len > 0) {\n let out = __alloc(len << 1, idof());\n memory.copy(out, changetype(this) + (start << 1), len << 1);\n result.push(changetype(out));\n } else {\n result.push(changetype(""));\n }\n if (++i == limit) return changetype>(result); // retains\n start = end + sepLen;\n }\n if (!start) { // also means: loop above didn\'t do anything\n result.push(this);\n return changetype>(result); // retains\n }\n var len = length - start;\n if (len > 0) {\n let out = __alloc(len << 1, idof());\n memory.copy(out, changetype(this) + (start << 1), len << 1);\n result.push(changetype(out)); // retains\n } else {\n result.push(changetype("")); // static ""\n }\n return changetype>(result); // retains\n // releases result\n }\n\n toString(): String {\n return this;\n }\n\n get lengthUTF8(): i32 {\n var len = 1; // null terminated\n var pos: usize = 0;\n var end = this.length;\n while (pos < end) {\n let c = load(changetype(this) + (pos << 1));\n if (c < 128) {\n len += 1; ++pos;\n } else if (c < 2048) {\n len += 2; ++pos;\n } else {\n if (\n (c & 0xFC00) == 0xD800 && pos + 1 < end &&\n (load(changetype(this) + ((pos + 1) << 1)) & 0xFC00) == 0xDC00\n ) {\n len += 4; pos += 2;\n } else {\n len += 3; ++pos;\n }\n }\n }\n return len;\n }\n\n static fromUTF8(ptr: usize, len: usize): String {\n if (len < 1) return changetype("");\n var ptrPos = 0;\n var buf = __alloc(len << 1, 0);\n var bufPos = 0;\n while (ptrPos < len) {\n let cp = load(ptr + ptrPos++);\n if (cp < 128) {\n store(buf + bufPos, cp);\n bufPos += 2;\n } else if (cp > 191 && cp < 224) {\n assert(ptrPos + 1 <= len);\n store(buf + bufPos, (cp & 31) << 6 | load(ptr + ptrPos++) & 63);\n bufPos += 2;\n } else if (cp > 239 && cp < 365) {\n assert(ptrPos + 3 <= len);\n cp = (\n (cp & 7) << 18 |\n (load(ptr + ptrPos++) & 63) << 12 |\n (load(ptr + ptrPos++) & 63) << 6 |\n load(ptr + ptrPos++) & 63\n ) - 0x10000;\n store(buf + bufPos, 0xD800 + (cp >> 10));\n bufPos += 2;\n store(buf + bufPos, 0xDC00 + (cp & 1023));\n bufPos += 2;\n } else {\n assert(ptrPos + 2 <= len);\n store(buf + bufPos,\n (cp & 15) << 12 |\n (load(ptr + ptrPos++) & 63) << 6 |\n load(ptr + ptrPos++) & 63\n );\n bufPos += 2;\n }\n }\n assert(ptrPos == len);\n var out = __alloc(bufPos, idof());\n memory.copy(out, buf, bufPos);\n __free(buf);\n return changetype(out); // retains\n }\n\n toUTF8(): usize {\n var buf = __alloc(this.lengthUTF8, 0);\n var pos: usize = 0;\n var end = this.length;\n var off: usize = 0;\n while (pos < end) {\n let c1 = load(changetype(this) + (pos << 1));\n if (c1 < 128) {\n store(buf + off, c1);\n ++off; ++pos;\n } else if (c1 < 2048) {\n let ptr = buf + off;\n store(ptr, c1 >> 6 | 192);\n store(ptr, c1 & 63 | 128, 1);\n off += 2; ++pos;\n } else {\n let ptr = buf + off;\n if ((c1 & 0xFC00) == 0xD800 && pos + 1 < end) {\n let c2 = load(changetype(this) + ((pos + 1) << 1));\n if ((c2 & 0xFC00) == 0xDC00) {\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\n store(ptr, c1 >> 18 | 240);\n store(ptr, c1 >> 12 & 63 | 128, 1);\n store(ptr, c1 >> 6 & 63 | 128, 2);\n store(ptr, c1 & 63 | 128, 3);\n off += 4; pos += 2;\n continue;\n }\n }\n store(ptr, c1 >> 12 | 224);\n store(ptr, c1 >> 6 & 63 | 128, 1);\n store(ptr, c1 & 63 | 128, 2);\n off += 3; ++pos;\n }\n }\n store(buf + off, 0);\n return buf;\n }\n}\n\n// @ts-ignore: nolib\nexport type string = String;\n\nexport function parseInt(str: string, radix: i32 = 0): f64 {\n return strtol(str, radix);\n}\n\nexport function parseFloat(str: string): f64 {\n return strtod(str);\n}\n',symbol:'import { Map } from "./map";\n\n// @ts-ignore: decorator\n@lazy\nvar stringToId: Map;\n\n// @ts-ignore: decorator\n@lazy\nvar idToString: Map;\n\n// @ts-ignore: decorator\n@lazy\nvar nextId: usize = 12; // Symbol.unscopables + 1\n\n@unmanaged @sealed abstract class _Symbol {\n\n // TODO: all of the following default symbols are unused currently yet add to\n // binary size if #toString becomes compiled. Ultimately we\'ll most likely want\n // to remove the unsupported ones and only keep what\'s actually supported.\n\n // @ts-ignore: decorator\n @lazy\n static readonly hasInstance: symbol = changetype(1);\n\n // @ts-ignore: decorator\n @lazy\n static readonly isConcatSpreadable: symbol = changetype(2);\n\n // @ts-ignore: decorator\n @lazy\n static readonly isRegExp: symbol = changetype(3);\n\n // @ts-ignore: decorator\n @lazy\n static readonly iterator: symbol = changetype(3);\n\n // @ts-ignore: decorator\n @lazy\n static readonly match: symbol = changetype(4);\n\n // @ts-ignore: decorator\n @lazy\n static readonly replace: symbol = changetype(5);\n\n // @ts-ignore: decorator\n @lazy\n static readonly search: symbol = changetype(6);\n\n // @ts-ignore: decorator\n @lazy\n static readonly species: symbol = changetype(7);\n\n // @ts-ignore: decorator\n @lazy\n static readonly split: symbol = changetype(8);\n\n // @ts-ignore: decorator\n @lazy\n static readonly toPrimitive: symbol = changetype(9);\n\n // @ts-ignore: decorator\n @lazy\n static readonly toStringTag: symbol = changetype(10);\n\n // @ts-ignore: decorator\n @lazy\n static readonly unscopables: symbol = changetype(11);\n\n static for(key: string): symbol {\n if (!stringToId) { stringToId = new Map(); idToString = new Map(); }\n else if (stringToId.has(key)) return changetype(stringToId.get(key));\n var id = nextId++;\n if (!id) unreachable(); // out of ids\n stringToId.set(key, id);\n idToString.set(id, key);\n return changetype(id);\n }\n\n static keyFor(sym: symbol): string | null {\n return idToString !== null && idToString.has(changetype(sym))\n ? idToString.get(changetype(sym))\n : null;\n }\n\n toString(): string {\n var id = changetype(this);\n var str = "";\n switch (id) {\n case 1: { str = "hasInstance"; break; }\n case 2: { str = "isConcatSpreadable"; break; }\n case 3: { str = "isRegExp"; break; }\n case 4: { str = "match"; break; }\n case 5: { str = "replace"; break; }\n case 6: { str = "search"; break; }\n case 7: { str = "species"; break; }\n case 8: { str = "split"; break; }\n case 9: { str = "toPrimitive"; break; }\n case 10: { str = "toStringTag"; break; }\n case 11: { str = "unscopables"; break; }\n default: {\n if (idToString !== null && idToString.has(id)) str = idToString.get(id);\n break;\n }\n }\n return "Symbol(" + str + ")";\n }\n}\n\nexport function Symbol(description: string | null = null): symbol {\n var id = nextId++;\n if (!id) unreachable(); // out of ids\n return changetype(id);\n}\n\nexport type Symbol = _Symbol;\n\n// @ts-ignore: nolib\nexport type symbol = _Symbol;\n',table:'import { E_NOTIMPLEMENTED } from "./util/error";\n\nexport namespace table {\n\n export function copy(dst: u32, src: u32, n: u32): void {\n throw new Error(E_NOTIMPLEMENTED);\n }\n\n export function init(elementIndex: u32, srcOffset: u32, dstOffset: u32, n: u32): void {\n throw new Error(E_NOTIMPLEMENTED);\n }\n\n export function drop(elementIndex: u32): void {\n throw new Error(E_NOTIMPLEMENTED);\n }\n}\n',typedarray:'import { COMPARATOR, SORT as SORT_IMPL } from "./util/sort";\nimport { E_INDEXOUTOFRANGE } from "./util/error";\nimport { idof } from "./builtins";\nimport { ArrayBufferView } from "./arraybuffer";\n\nexport class Int8Array extends ArrayBufferView {\n [key: number]: i8;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength;\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): i8 {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + index);\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: native): void {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + index, value);\n }\n\n fill(value: i32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Int8Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: i8, b: i8) => i32 = COMPARATOR()): Int8Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Int8Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: i8, index: i32, array: Int8Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: i8, index: i32, array: Int8Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: i8, index: i32, self: Int8Array) => i8): Int8Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: i8, index: i32, self: Int8Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: i8, index: i32, self: Int8Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: i8, index: i32, self: Int8Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: i8, index: i32, self: Int8Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Uint8Array extends ArrayBufferView {\n [key: number]: u8;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength;\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): u8 {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + index);\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: native): void {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + index, value);\n }\n\n fill(value: u32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Uint8Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: u8, b: u8) => i32 = COMPARATOR()): Uint8Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Uint8Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: u8, index: i32, array: Uint8Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: u8, index: i32, array: Uint8Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: u8, index: i32, self: Uint8Array) => u8): Uint8Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: u8, index: i32, self: Uint8Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: u8, index: i32, self: Uint8Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: u8, index: i32, self: Uint8Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: u8, index: i32, self: Uint8Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Uint8ClampedArray extends ArrayBufferView {\n [key: number]: u8;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength;\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): u8 {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + index);\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: native): void {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + index, ~(value >> 31) & (((255 - value) >> 31) | value));\n }\n\n fill(value: u32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Uint8ClampedArray {\n return FILL(this, value, start, end);\n }\n\n sort(fn: (a: u8, b: u8) => i32 = COMPARATOR()): Uint8ClampedArray {\n return SORT(this, fn);\n }\n\n subarray(start: i32 = 0, end: i32 = 0x7fffffff): Uint8ClampedArray {\n return SUBARRAY(this, start, end);\n }\n\n reduce(\n fn: (accumulator: T, value: u8, index: i32, array: Uint8ClampedArray) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: u8, index: i32, array: Uint8ClampedArray) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: u8, index: i32, self: Uint8ClampedArray) => u8): Uint8ClampedArray {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: u8, index: i32, self: Uint8ClampedArray) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: u8, index: i32, self: Uint8ClampedArray) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: u8, index: i32, self: Uint8ClampedArray) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: u8, index: i32, self: Uint8ClampedArray) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Int16Array extends ArrayBufferView {\n [key: number]: i16;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): i16 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: native): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n fill(value: i32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Int16Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: i16, b: i16) => i32 = COMPARATOR()): Int16Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Int16Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: i16, index: i32, array: Int16Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: i16, index: i32, array: Int16Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: i16, index: i32, self: Int16Array) => i16): Int16Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: i16, index: i32, self: Int16Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: i16, index: i32, self: Int16Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: i16, index: i32, self: Int16Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: i16, index: i32, self: Int16Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Uint16Array extends ArrayBufferView {\n [key: number]: u16;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): u16 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: native): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n fill(value: u32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Uint16Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: u16, b: u16) => i32 = COMPARATOR()): Uint16Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Uint16Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: u16, index: i32, array: Uint16Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: u16, index: i32, array: Uint16Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: u16, index: i32, self: Uint16Array) => u16): Uint16Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: u16, index: i32, self: Uint16Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: u16, index: i32, self: Uint16Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: u16, index: i32, self: Uint16Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: u16, index: i32, self: Uint16Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Int32Array extends ArrayBufferView {\n [key: number]: i32;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): i32 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: i32): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n fill(value: i32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Int32Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: i32, b: i32) => i32 = COMPARATOR()): Int32Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Int32Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: i32, index: i32, array: Int32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: i32, index: i32, array: Int32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: i32, index: i32, self: Int32Array) => i32): Int32Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: i32, index: i32, self: Int32Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: i32, index: i32, self: Int32Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: i32, index: i32, self: Int32Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: i32, index: i32, self: Int32Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Uint32Array extends ArrayBufferView {\n [key: number]: u32;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): u32 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: u32): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n fill(value: u32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Uint32Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: u32, b: u32) => i32 = COMPARATOR()): Uint32Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Uint32Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: u32, index: i32, array: Uint32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: u32, index: i32, array: Uint32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: u32, index: i32, self: Uint32Array) => u32): Uint32Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: u32, index: i32, self: Uint32Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: u32, index: i32, self: Uint32Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: u32, index: i32, self: Uint32Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: u32, index: i32, self: Uint32Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Int64Array extends ArrayBufferView {\n [key: number]: i64;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): i64 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: i64): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n fill(value: i64, start: i32 = 0, end: i32 = i32.MAX_VALUE): Int64Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: i64, b: i64) => i32 = COMPARATOR()): Int64Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Int64Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: i64, index: i32, array: Int64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: i64, index: i32, array: Int64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: i64, index: i32, self: Int64Array) => i64): Int64Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: i64, index: i32, self: Int64Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: i64, index: i32, self: Int64Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: i64, index: i32, self: Int64Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: i64, index: i32, self: Int64Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Uint64Array extends ArrayBufferView {\n [key: number]: u64;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): u64 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: u64): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n fill(value: u64, start: i32 = 0, end: i32 = i32.MAX_VALUE): Uint64Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: u64, b: u64) => i32 = COMPARATOR()): Uint64Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Uint64Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: u64, index: i32, array: Uint64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: u64, index: i32, array: Uint64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: u64, index: i32, self: Uint64Array) => u64): Uint64Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: u64, index: i32, self: Uint64Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: u64, index: i32, self: Uint64Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: u64, index: i32, self: Uint64Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: u64, index: i32, self: Uint64Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Float32Array extends ArrayBufferView {\n [key: number]: f32;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): f32 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: f32): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n fill(value: f32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Float32Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: f32, b: f32) => i32 = COMPARATOR()): Float32Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Float32Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: f32, index: i32, array: Float32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: f32, index: i32, array: Float32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: f32, index: i32, self: Float32Array) => f32): Float32Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: f32, index: i32, self: Float32Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: f32, index: i32, self: Float32Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: f32, index: i32, self: Float32Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: f32, index: i32, self: Float32Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Float64Array extends ArrayBufferView {\n [key: number]: f64;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): f64 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: f64): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n fill(value: f64, start: i32 = 0, end: i32 = i32.MAX_VALUE): Float64Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: f64, b: f64) => i32 = COMPARATOR()): Float64Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Float64Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: f64, index: i32, array: Float64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: f64, index: i32, array: Float64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: f64, index: i32, self: Float64Array) => f64): Float64Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: f64, index: i32, self: Float64Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: f64, index: i32, self: Float64Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: f64, index: i32, self: Float64Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: f64, index: i32, self: Float64Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\n// @ts-ignore: decorator\n@inline\nfunction FILL(\n array: TArray,\n value: native,\n start: i32,\n end: i32\n): TArray {\n var dataStart = array.dataStart;\n var length = array.length;\n start = start < 0 ? max(length + start, 0) : min(start, length);\n end = end < 0 ? max(length + end, 0) : min(end, length);\n if (sizeof() == 1) {\n if (start < end) memory.fill(dataStart + start, value, (end - start));\n } else {\n for (; start < end; ++start) {\n store(dataStart + (start << alignof()), value);\n }\n }\n return array;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction SORT(\n array: TArray,\n comparator: (a: T, b: T) => i32\n): TArray {\n var length = array.length;\n if (length <= 1) return array;\n var base = array.dataStart;\n if (length == 2) {\n let a: T = load(base, sizeof()); // a = arr[1]\n let b: T = load(base); // b = arr[0]\n if (comparator(a, b) < 0) {\n store(base, b, sizeof()); // arr[1] = b\n store(base, a); // arr[0] = a\n }\n return array;\n }\n SORT_IMPL(base, length, comparator);\n return array;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction SUBARRAY(\n array: TArray,\n begin: i32,\n end: i32\n): TArray {\n var len = array.length;\n begin = begin < 0 ? max(len + begin, 0) : min(begin, len);\n end = end < 0 ? max(len + end, 0) : min(end, len);\n end = max(end, begin);\n var out = changetype(__alloc(offsetof(), idof())); // retains\n out.data = array.data; // retains\n out.dataStart = array.dataStart + (begin << alignof());\n out.dataLength = (end - begin) << alignof();\n return out;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction REDUCE(\n array: TArray,\n fn: (accumulator: TRet, value: T, index: i32, array: TArray) => TRet,\n initialValue: TRet\n): TRet {\n var dataStart = array.dataStart;\n for (let i = 0, k = array.length; i < k; i++) {\n initialValue = fn(initialValue, load(dataStart + (i << alignof())), i, array);\n }\n return initialValue;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction REDUCE_RIGHT(\n array: TArray,\n fn: (accumulator: TRet, value: T, index: i32, array: TArray) => TRet,\n initialValue: TRet\n): TRet {\n var dataStart = array.dataStart;\n for (let i = array.length - 1; i >= 0; i--) {\n initialValue = fn(initialValue, load(dataStart + (i << alignof())), i, array);\n }\n return initialValue;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction MAP(\n array: TArray,\n fn: (value: T, index: i32, self: TArray) => T,\n): TArray {\n var length = array.length;\n var dataStart = array.dataStart;\n var out = instantiate(length);\n var outDataStart = out.dataStart;\n for (let i = 0; i < length; i++) {\n store(\n outDataStart + (i << alignof()),\n fn(load(dataStart + (i << alignof())), i, array)\n );\n }\n return out;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction FIND_INDEX(\n array: TArray,\n fn: (value: T, index: i32, array: TArray) => bool,\n): i32 {\n var dataStart = array.dataStart;\n for (let i = 0, k = array.length; i < k; i++) {\n if (fn(load(dataStart + (i << alignof())), i, array)) return i;\n }\n return -1;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction SOME(\n array: TArray,\n fn: (value: T, index: i32, array: TArray) => bool,\n): bool {\n var dataStart = array.dataStart;\n for (let i = 0, k = array.length; i < k; i++) {\n if (fn(load(dataStart + (i << alignof())), i, array)) return true;\n }\n return false;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction EVERY(\n array: TArray,\n fn: (value: T, index: i32, array: TArray) => bool,\n): bool {\n var dataStart = array.dataStart;\n for (let i = 0, k = array.length; i < k; i++) {\n if (fn(load(dataStart + (i << alignof())), i, array)) continue;\n return false;\n }\n return true;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction FOREACH(\n array: TArray,\n fn: (value: T, index: i32, array: TArray) => void,\n): void {\n var dataStart = array.dataStart;\n for (let i = 0, k = array.length; i < k; i++) {\n fn(load(dataStart + (i << alignof())), i, array);\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function REVERSE(array: TArray): TArray {\n var dataStart = array.dataStart;\n for (let front = 0, back = array.length - 1; front < back; ++front, --back) {\n let frontPtr = dataStart + (front << alignof());\n let backPtr = dataStart + (back << alignof());\n let temp = load(frontPtr);\n store(frontPtr, load(backPtr));\n store(backPtr, temp);\n }\n return array;\n}\n',"util/error":'// Common error messages for use accross the standard library. Keeping error messages compact\n// and reusing them where possible ensures minimal static data in binaries.\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_INDEXOUTOFRANGE: string = "Index out of range";\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_INVALIDLENGTH: string = "Invalid length";\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_EMPTYARRAY: string = "Array is empty";\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_HOLEYARRAY: string = "Element type must be nullable if array is holey";\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_NOTIMPLEMENTED: string = "Not implemented";\n',"util/hash":"// @ts-ignore: decorator\n@inline\nexport function HASH(key: T): u32 {\n if (isString()) {\n return hashStr(changetype(key));\n } else if (isReference()) {\n if (sizeof() == 4) return hash32(changetype(key));\n if (sizeof() == 8) return hash64(changetype(key));\n } else if (isFloat()) {\n if (sizeof() == 4) return hash32(reinterpret(f32(key)));\n if (sizeof() == 8) return hash64(reinterpret(f64(key)));\n } else {\n if (sizeof() == 1) return hash8 (u32(key));\n if (sizeof() == 2) return hash16(u32(key));\n if (sizeof() == 4) return hash32(u32(key));\n if (sizeof() == 8) return hash64(u64(key));\n }\n return unreachable();\n}\n\n// FNV-1a 32-bit as a starting point, see: http://isthe.com/chongo/tech/comp/fnv/\n\n// @ts-ignore: decorator\n@inline\nconst FNV_OFFSET: u32 = 2166136261;\n\n// @ts-ignore: decorator\n@inline\nconst FNV_PRIME: u32 = 16777619;\n\nfunction hash8(key: u32): u32 {\n return (FNV_OFFSET ^ key) * FNV_PRIME;\n}\n\nfunction hash16(key: u32): u32 {\n var v = FNV_OFFSET;\n v = (v ^ ( key & 0xff)) * FNV_PRIME;\n v = (v ^ ( key >> 8 )) * FNV_PRIME;\n return v;\n}\n\nfunction hash32(key: u32): u32 {\n var v = FNV_OFFSET;\n v = (v ^ ( key & 0xff)) * FNV_PRIME;\n v = (v ^ ((key >> 8) & 0xff)) * FNV_PRIME;\n v = (v ^ ((key >> 16) & 0xff)) * FNV_PRIME;\n v = (v ^ ( key >> 24 )) * FNV_PRIME;\n return v;\n}\n\nfunction hash64(key: u64): u32 {\n var l = key;\n var h = (key >>> 32);\n var v = FNV_OFFSET;\n v = (v ^ ( l & 0xff)) * FNV_PRIME;\n v = (v ^ ((l >> 8) & 0xff)) * FNV_PRIME;\n v = (v ^ ((l >> 16) & 0xff)) * FNV_PRIME;\n v = (v ^ ( l >> 24 )) * FNV_PRIME;\n v = (v ^ ( h & 0xff)) * FNV_PRIME;\n v = (v ^ ((h >> 8) & 0xff)) * FNV_PRIME;\n v = (v ^ ((h >> 16) & 0xff)) * FNV_PRIME;\n v = (v ^ ( h >> 24 )) * FNV_PRIME;\n return v;\n}\n\nfunction hashStr(key: string): u32 {\n var v = FNV_OFFSET;\n if (key !== null) {\n for (let i: usize = 0, k: usize = key.length << 1; i < k; ++i) {\n v = (v ^ load(changetype(key) + i)) * FNV_PRIME;\n }\n }\n return v;\n}\n","util/memory":"export function memcpy(dest: usize, src: usize, n: usize): void { // see: musl/src/string/memcpy.c\n if (ASC_SHRINK_LEVEL > 1) {\n while (n) {\n store(dest++, load(src++));\n --n;\n }\n } else {\n let w: u32, x: u32;\n\n // copy 1 byte each until src is aligned to 4 bytes\n while (n && (src & 3)) {\n store(dest++, load(src++));\n n--;\n }\n\n // if dst is aligned to 4 bytes as well, copy 4 bytes each\n if ((dest & 3) == 0) {\n while (n >= 16) {\n store(dest , load(src ));\n store(dest + 4, load(src + 4));\n store(dest + 8, load(src + 8));\n store(dest + 12, load(src + 12));\n src += 16; dest += 16; n -= 16;\n }\n if (n & 8) {\n store(dest , load(src ));\n store(dest + 4, load(src + 4));\n dest += 8; src += 8;\n }\n if (n & 4) {\n store(dest, load(src));\n dest += 4; src += 4;\n }\n if (n & 2) { // drop to 2 bytes each\n store(dest, load(src));\n dest += 2; src += 2;\n }\n if (n & 1) { // drop to 1 byte\n store(dest++, load(src++));\n }\n return;\n }\n\n // if dst is not aligned to 4 bytes, use alternating shifts to copy 4 bytes each\n // doing shifts if faster when copying enough bytes (here: 32 or more)\n if (n >= 32) {\n switch (dest & 3) {\n // known to be != 0\n case 1: {\n w = load(src);\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n n -= 3;\n while (n >= 17) {\n x = load(src + 1);\n store(dest, w >> 24 | x << 8);\n w = load(src + 5);\n store(dest + 4, x >> 24 | w << 8);\n x = load(src + 9);\n store(dest + 8, w >> 24 | x << 8);\n w = load(src + 13);\n store(dest + 12, x >> 24 | w << 8);\n src += 16; dest += 16; n -= 16;\n }\n break;\n }\n case 2: {\n w = load(src);\n store(dest++, load(src++));\n store(dest++, load(src++));\n n -= 2;\n while (n >= 18) {\n x = load(src + 2);\n store(dest, w >> 16 | x << 16);\n w = load(src + 6);\n store(dest + 4, x >> 16 | w << 16);\n x = load(src + 10);\n store(dest + 8, w >> 16 | x << 16);\n w = load(src + 14);\n store(dest + 12, x >> 16 | w << 16);\n src += 16; dest += 16; n -= 16;\n }\n break;\n }\n case 3: {\n w = load(src);\n store(dest++, load(src++));\n n -= 1;\n while (n >= 19) {\n x = load(src + 3);\n store(dest, w >> 8 | x << 24);\n w = load(src + 7);\n store(dest + 4, x >> 8 | w << 24);\n x = load(src + 11);\n store(dest + 8, w >> 8 | x << 24);\n w = load(src + 15);\n store(dest + 12, x >> 8 | w << 24);\n src += 16; dest += 16; n -= 16;\n }\n break;\n }\n }\n }\n\n // copy remaining bytes one by one\n if (n & 16) {\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n }\n if (n & 8) {\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n }\n if (n & 4) {\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n }\n if (n & 2) {\n store(dest++, load(src++));\n store(dest++, load(src++));\n }\n if (n & 1) {\n store(dest++, load(src++));\n }\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function memmove(dest: usize, src: usize, n: usize): void { // see: musl/src/string/memmove.c\n if (dest === src) return;\n if (ASC_SHRINK_LEVEL < 1) {\n if (src + n <= dest || dest + n <= src) {\n memcpy(dest, src, n);\n return;\n }\n }\n if (dest < src) {\n if ((src & 7) == (dest & 7)) {\n while (dest & 7) {\n if (!n) return;\n --n;\n store(dest++, load(src++));\n }\n while (n >= 8) {\n store(dest, load(src));\n n -= 8;\n dest += 8;\n src += 8;\n }\n }\n while (n) {\n store(dest++, load(src++));\n --n;\n }\n } else {\n if ((src & 7) == (dest & 7)) {\n while ((dest + n) & 7) {\n if (!n) return;\n store(dest + --n, load(src + n));\n }\n while (n >= 8) {\n n -= 8;\n store(dest + n, load(src + n));\n }\n }\n while (n) {\n store(dest + --n, load(src + n));\n }\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function memset(dest: usize, c: u8, n: usize): void { // see: musl/src/string/memset\n if (ASC_SHRINK_LEVEL > 1) {\n while (n) {\n store(dest++, c);\n --n;\n }\n } else {\n // fill head and tail with minimal branching\n if (!n) return;\n store(dest, c);\n store(dest + n - 1, c);\n if (n <= 2) return;\n\n store(dest + 1, c);\n store(dest + 2, c);\n store(dest + n - 2, c);\n store(dest + n - 3, c);\n if (n <= 6) return;\n store(dest + 3, c);\n store(dest + n - 4, c);\n if (n <= 8) return;\n\n // advance pointer to align it at 4-byte boundary\n let k: usize = -dest & 3;\n dest += k;\n n -= k;\n n &= -4;\n\n let c32: u32 = -1 / 255 * c;\n\n // fill head/tail up to 28 bytes each in preparation\n store(dest, c32);\n store(dest + n - 4, c32);\n if (n <= 8) return;\n store(dest + 4, c32);\n store(dest + 8, c32);\n store(dest + n - 12, c32);\n store(dest + n - 8, c32);\n if (n <= 24) return;\n store(dest + 12, c32);\n store(dest + 16, c32);\n store(dest + 20, c32);\n store(dest + 24, c32);\n store(dest + n - 28, c32);\n store(dest + n - 24, c32);\n store(dest + n - 20, c32);\n store(dest + n - 16, c32);\n\n // align to a multiple of 8\n k = 24 + (dest & 4);\n dest += k;\n n -= k;\n\n // copy 32 bytes each\n let c64: u64 = c32 | (c32 << 32);\n while (n >= 32) {\n store(dest, c64);\n store(dest + 8, c64);\n store(dest + 16, c64);\n store(dest + 24, c64);\n n -= 32;\n dest += 32;\n }\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function memcmp(vl: usize, vr: usize, n: usize): i32 { // see: musl/src/string/memcmp.c\n if (vl == vr) return 0;\n while (n != 0 && load(vl) == load(vr)) {\n n--; vl++; vr++;\n }\n return n ? load(vl) - load(vr) : 0;\n}\n","util/number":'/// \n\nimport { idof } from "../builtins";\nimport { CharCode } from "./string";\nimport { ArrayBufferView } from "../arraybuffer";\n\n// @ts-ignore: decorator\n@inline\nexport const MAX_DOUBLE_LENGTH = 28;\n\n// @ts-ignore: decorator\n@lazy @inline\nconst POWERS10: u32[] = [\n 1,\n 10,\n 100,\n 1000,\n 10000,\n 100000,\n 1000000,\n 10000000,\n 100000000,\n 1000000000\n];\n\n/*\n Lookup table for pairwise char codes in range [0-99]\n\n "00", "01", "02", "03", "04", "05", "06", "07", "08", "09",\n "10", "11", "12", "13", "14", "15", "16", "17", "18", "19",\n "20", "21", "22", "23", "24", "25", "26", "27", "28", "29",\n "30", "31", "32", "33", "34", "35", "36", "37", "38", "39",\n "40", "41", "42", "43", "44", "45", "46", "47", "48", "49",\n "50", "51", "52", "53", "54", "55", "56", "57", "58", "59",\n "60", "61", "62", "63", "64", "65", "66", "67", "68", "69",\n "70", "71", "72", "73", "74", "75", "76", "77", "78", "79",\n "80", "81", "82", "83", "84", "85", "86", "87", "88", "89",\n "90", "91", "92", "93", "94", "95", "96", "97", "98", "99"\n*/\n// @ts-ignore: decorator\n@lazy @inline\nconst DIGITS: u32[] = [\n 0x00300030, 0x00310030, 0x00320030, 0x00330030, 0x00340030,\n 0x00350030, 0x00360030, 0x00370030, 0x00380030, 0x00390030,\n 0x00300031, 0x00310031, 0x00320031, 0x00330031, 0x00340031,\n 0x00350031, 0x00360031, 0x00370031, 0x00380031, 0x00390031,\n 0x00300032, 0x00310032, 0x00320032, 0x00330032, 0x00340032,\n 0x00350032, 0x00360032, 0x00370032, 0x00380032, 0x00390032,\n 0x00300033, 0x00310033, 0x00320033, 0x00330033, 0x00340033,\n 0x00350033, 0x00360033, 0x00370033, 0x00380033, 0x00390033,\n 0x00300034, 0x00310034, 0x00320034, 0x00330034, 0x00340034,\n 0x00350034, 0x00360034, 0x00370034, 0x00380034, 0x00390034,\n 0x00300035, 0x00310035, 0x00320035, 0x00330035, 0x00340035,\n 0x00350035, 0x00360035, 0x00370035, 0x00380035, 0x00390035,\n 0x00300036, 0x00310036, 0x00320036, 0x00330036, 0x00340036,\n 0x00350036, 0x00360036, 0x00370036, 0x00380036, 0x00390036,\n 0x00300037, 0x00310037, 0x00320037, 0x00330037, 0x00340037,\n 0x00350037, 0x00360037, 0x00370037, 0x00380037, 0x00390037,\n 0x00300038, 0x00310038, 0x00320038, 0x00330038, 0x00340038,\n 0x00350038, 0x00360038, 0x00370038, 0x00380038, 0x00390038,\n 0x00300039, 0x00310039, 0x00320039, 0x00330039, 0x00340039,\n 0x00350039, 0x00360039, 0x00370039, 0x00380039, 0x00390039\n];\n\n// @ts-ignore: decorator\n@lazy @inline\nconst EXP_POWERS: i16[] = [\n -1220, -1193, -1166, -1140, -1113, -1087, -1060, -1034, -1007, -980,\n -954, -927, -901, -874, -847, -821, -794, -768, -741, -715,\n -688, -661, -635, -608, -582, -555, -529, -502, -475, -449,\n -422, -396, -369, -343, -316, -289, -263, -236, -210, -183,\n -157, -130, -103, -77, -50, -24, 3, 30, 56, 83,\n 109, 136, 162, 189, 216, 242, 269, 295, 322, 348,\n 375, 402, 428, 455, 481, 508, 534, 561, 588, 614,\n 641, 667, 694, 720, 747, 774, 800, 827, 853, 880,\n 907, 933, 960, 986, 1013, 1039, 1066\n];\n\n// 1e-348, 1e-340, ..., 1e340\n// @ts-ignore: decorator\n@lazy @inline\nconst FRC_POWERS: u64[] = [\n 0xFA8FD5A0081C0288, 0xBAAEE17FA23EBF76, 0x8B16FB203055AC76, 0xCF42894A5DCE35EA,\n 0x9A6BB0AA55653B2D, 0xE61ACF033D1A45DF, 0xAB70FE17C79AC6CA, 0xFF77B1FCBEBCDC4F,\n 0xBE5691EF416BD60C, 0x8DD01FAD907FFC3C, 0xD3515C2831559A83, 0x9D71AC8FADA6C9B5,\n 0xEA9C227723EE8BCB, 0xAECC49914078536D, 0x823C12795DB6CE57, 0xC21094364DFB5637,\n 0x9096EA6F3848984F, 0xD77485CB25823AC7, 0xA086CFCD97BF97F4, 0xEF340A98172AACE5,\n 0xB23867FB2A35B28E, 0x84C8D4DFD2C63F3B, 0xC5DD44271AD3CDBA, 0x936B9FCEBB25C996,\n 0xDBAC6C247D62A584, 0xA3AB66580D5FDAF6, 0xF3E2F893DEC3F126, 0xB5B5ADA8AAFF80B8,\n 0x87625F056C7C4A8B, 0xC9BCFF6034C13053, 0x964E858C91BA2655, 0xDFF9772470297EBD,\n 0xA6DFBD9FB8E5B88F, 0xF8A95FCF88747D94, 0xB94470938FA89BCF, 0x8A08F0F8BF0F156B,\n 0xCDB02555653131B6, 0x993FE2C6D07B7FAC, 0xE45C10C42A2B3B06, 0xAA242499697392D3,\n 0xFD87B5F28300CA0E, 0xBCE5086492111AEB, 0x8CBCCC096F5088CC, 0xD1B71758E219652C,\n 0x9C40000000000000, 0xE8D4A51000000000, 0xAD78EBC5AC620000, 0x813F3978F8940984,\n 0xC097CE7BC90715B3, 0x8F7E32CE7BEA5C70, 0xD5D238A4ABE98068, 0x9F4F2726179A2245,\n 0xED63A231D4C4FB27, 0xB0DE65388CC8ADA8, 0x83C7088E1AAB65DB, 0xC45D1DF942711D9A,\n 0x924D692CA61BE758, 0xDA01EE641A708DEA, 0xA26DA3999AEF774A, 0xF209787BB47D6B85,\n 0xB454E4A179DD1877, 0x865B86925B9BC5C2, 0xC83553C5C8965D3D, 0x952AB45CFA97A0B3,\n 0xDE469FBD99A05FE3, 0xA59BC234DB398C25, 0xF6C69A72A3989F5C, 0xB7DCBF5354E9BECE,\n 0x88FCF317F22241E2, 0xCC20CE9BD35C78A5, 0x98165AF37B2153DF, 0xE2A0B5DC971F303A,\n 0xA8D9D1535CE3B396, 0xFB9B7CD9A4A7443C, 0xBB764C4CA7A44410, 0x8BAB8EEFB6409C1A,\n 0xD01FEF10A657842C, 0x9B10A4E5E9913129, 0xE7109BFBA19C0C9D, 0xAC2820D9623BF429,\n 0x80444B5E7AA7CF85, 0xBF21E44003ACDD2D, 0x8E679C2F5E44FF8F, 0xD433179D9C8CB841,\n 0x9E19DB92B4E31BA9, 0xEB96BF6EBADF77D9, 0xAF87023B9BF0EE6B\n];\n\n// Count number of decimals for u32 values\n// In our case input value always non-zero so we can simplify some parts\nexport function decimalCount32(value: u32): u32 {\n if (value < 100000) {\n if (value < 100) {\n return select(1, 2, value < 10);\n } else {\n let m = select(4, 5, value < 10000);\n return select(3, m, value < 1000);\n }\n } else {\n if (value < 10000000) {\n return select(6, 7, value < 1000000);\n } else {\n let m = select(9, 10, value < 1000000000);\n return select(8, m, value < 100000000);\n }\n }\n}\n\n// Count number of decimals for u64 values\n// In our case input value always greater than 2^32-1 so we can skip some parts\nexport function decimalCount64(value: u64): u32 {\n if (value < 1000000000000000) {\n if (value < 1000000000000) {\n return select(11, 12, value < 100000000000);\n } else {\n let m = select(14, 15, value < 100000000000000);\n return select(13, m, value < 10000000000000);\n }\n } else {\n if (value < 100000000000000000) {\n return select(16, 17, value < 10000000000000000);\n } else {\n let m = select(19, 20, value < 10000000000000000000);\n return select(18, m, value < 1000000000000000000);\n }\n }\n}\n\nfunction utoa32_lut(buffer: usize, num: u32, offset: usize): void {\n var lut = changetype(DIGITS).dataStart;\n while (num >= 10000) {\n // in most VMs i32/u32 div and modulo by constant can be shared and simplificate\n let t = num / 10000;\n let r = num % 10000;\n num = t;\n\n let d1 = r / 100;\n let d2 = r % 100;\n\n let digits1 = load(lut + (d1 << alignof()));\n let digits2 = load(lut + (d2 << alignof()));\n\n offset -= 4;\n store(buffer + (offset << 1), digits1 | (digits2 << 32));\n }\n\n if (num >= 100) {\n let t = num / 100;\n let d1 = num % 100;\n num = t;\n offset -= 2;\n let digits = load(lut + (d1 << alignof()));\n store(buffer + (offset << 1), digits);\n }\n\n if (num >= 10) {\n offset -= 2;\n let digits = load(lut + (num << alignof()));\n store(buffer + (offset << 1), digits);\n } else {\n offset -= 1;\n let digit = CharCode._0 + num;\n store(buffer + (offset << 1), digit);\n }\n}\n\nfunction utoa64_lut(buffer: usize, num: u64, offset: usize): void {\n var lut = changetype(DIGITS).dataStart;\n while (num >= 100000000) {\n let t = num / 100000000;\n let r = (num - t * 100000000);\n num = t;\n\n let b = r / 10000;\n let c = r % 10000;\n\n let b1 = b / 100;\n let b2 = b % 100;\n let c1 = c / 100;\n let c2 = c % 100;\n\n let digits1 = load(lut + (c1 << alignof()));\n let digits2 = load(lut + (c2 << alignof()));\n\n offset -= 4;\n store(buffer + (offset << 1), digits1 | (digits2 << 32));\n\n digits1 = load(lut + (b1 << alignof()));\n digits2 = load(lut + (b2 << alignof()));\n\n offset -= 4;\n store(buffer + (offset << 1), digits1 | (digits2 << 32));\n }\n\n utoa32_lut(buffer, num, offset);\n}\n\nfunction utoa_simple(buffer: usize, num: T, offset: usize): void {\n do {\n let t = num / 10;\n let r = (num % 10);\n num = changetype(t);\n offset -= 1;\n store(buffer + (offset << 1), CharCode._0 + r);\n } while (num);\n}\n\n// @ts-ignore: decorator\n@inline\nexport function utoa32_core(buffer: usize, num: u32, offset: u32): void {\n if (ASC_SHRINK_LEVEL >= 1) {\n utoa_simple(buffer, num, offset);\n } else {\n utoa32_lut(buffer, num, offset);\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function utoa64_core(buffer: usize, num: u64, offset: u32): void {\n if (ASC_SHRINK_LEVEL >= 1) {\n utoa_simple(buffer, num, offset);\n } else {\n utoa64_lut(buffer, num, offset);\n }\n}\n\nexport function utoa32(value: u32): String {\n if (!value) return "0";\n\n var decimals = decimalCount32(value);\n var out = __alloc(decimals << 1, idof());\n\n utoa32_core(out, value, decimals);\n return changetype(out); // retains\n}\n\nexport function itoa32(value: i32): String {\n if (!value) return "0";\n\n var sign = value < 0;\n if (sign) value = -value;\n\n var decimals = decimalCount32(value) + u32(sign);\n var out = __alloc(decimals << 1, idof());\n\n utoa32_core(out, value, decimals);\n if (sign) store(out, CharCode.MINUS);\n return changetype(out); // retains\n}\n\nexport function utoa64(value: u64): String {\n if (!value) return "0";\n\n var out: usize;\n if (value <= u32.MAX_VALUE) {\n let val32 = value;\n let decimals = decimalCount32(val32);\n out = __alloc(decimals << 1, idof());\n utoa32_core(out, val32, decimals);\n } else {\n let decimals = decimalCount64(value);\n out = __alloc(decimals << 1, idof());\n utoa64_core(out, value, decimals);\n }\n return changetype(out); // retains\n}\n\nexport function itoa64(value: i64): String {\n if (!value) return "0";\n\n var sign = value < 0;\n if (sign) value = -value;\n\n var out: usize;\n if (value <= u32.MAX_VALUE) {\n let val32 = value;\n let decimals = decimalCount32(val32) + u32(sign);\n out = __alloc(decimals << 1, idof());\n utoa32_core(out, val32, decimals);\n } else {\n let decimals = decimalCount64(value) + u32(sign);\n out = __alloc(decimals << 1, idof());\n utoa64_core(out, value, decimals);\n }\n if (sign) store(out, CharCode.MINUS);\n\n return changetype(out); // retains\n}\n\nexport function itoa(value: T): String {\n if (!isInteger()) ERROR("integer type expected");\n if (isSigned()) {\n if (sizeof() <= 4) {\n return itoa32(value);\n } else {\n return itoa64(value);\n }\n } else {\n if (sizeof() <= 4) {\n return utoa32(value);\n } else {\n return utoa64(value);\n }\n }\n}\n\n// @ts-ignore: decorator\n@lazy\nvar _K: i32 = 0;\n\n// // @ts-ignore: decorator\n// @lazy\n// var _frc: u64 = 0;\n\n// @ts-ignore: decorator\n@lazy\nvar _exp: i32 = 0;\n\n// @ts-ignore: decorator\n@lazy\nvar _frc_minus: u64 = 0;\n\n// @ts-ignore: decorator\n@lazy\nvar _frc_plus: u64 = 0;\n\n// @ts-ignore: decorator\n@lazy\nvar _frc_pow: u64 = 0;\n\n// @ts-ignore: decorator\n@lazy\nvar _exp_pow: i32 = 0;\n\n// @ts-ignore: decorator\n@inline\nfunction umul64f(u: u64, v: u64): u64 {\n var u0 = u & 0xFFFFFFFF;\n var v0 = v & 0xFFFFFFFF;\n\n var u1 = u >> 32;\n var v1 = v >> 32;\n\n var l = u0 * v0;\n var t = u1 * v0 + (l >> 32);\n var w = u0 * v1 + (t & 0xFFFFFFFF);\n\n w += 0x7FFFFFFF; // rounding\n\n t >>= 32;\n w >>= 32;\n\n return u1 * v1 + t + w;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction umul64e(e1: i32, e2: i32): i32 {\n return e1 + e2 + 64; // where 64 is significand size\n}\n\n// @ts-ignore: decorator\n@inline\nfunction normalizedBoundaries(f: u64, e: i32): void {\n var frc = (f << 1) + 1;\n var exp = e - 1;\n var off = clz(frc);\n frc <<= off;\n exp -= off;\n\n var m = 1 + i32(f == 0x0010000000000000);\n\n _frc_plus = frc;\n _frc_minus = ((f << m) - 1) << e - m - exp;\n _exp = exp;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction grisuRound(buffer: usize, len: i32, delta: u64, rest: u64, ten_kappa: u64, wp_w: u64): void {\n var lastp = buffer + ((len - 1) << 1);\n var digit = load(lastp);\n while (\n rest < wp_w &&\n delta - rest >= ten_kappa && (\n rest + ten_kappa < wp_w ||\n wp_w - rest > rest + ten_kappa - wp_w\n )\n ) {\n --digit;\n rest += ten_kappa;\n }\n store(lastp, digit);\n}\n\n// @ts-ignore: decorator\n@inline\nfunction getCachedPower(minExp: i32): void {\n const c = reinterpret(0x3FD34413509F79FE); // 1 / lg(10) = 0.30102999566398114\n var dk = (-61 - minExp) * c + 347;\t // dk must be positive, so can do ceiling in positive\n var k = dk;\n k += i32(k != dk); // conversion with ceil\n\n var index = (k >> 3) + 1;\n _K = 348 - (index << 3);\t// decimal exponent no need lookup table\n _frc_pow = unchecked(FRC_POWERS[index]);\n _exp_pow = unchecked(EXP_POWERS[index]);\n}\n\n// @ts-ignore: decorator\n@inline\nfunction grisu2(value: f64, buffer: usize, sign: i32): i32 {\n\n // frexp routine\n var uv = reinterpret(value);\n var exp = ((uv & 0x7FF0000000000000) >>> 52);\n var sid = uv & 0x000FFFFFFFFFFFFF;\n var frc = (u64(exp != 0) << 52) + sid;\n exp = select(exp, 1, exp != 0) - (0x3FF + 52);\n\n normalizedBoundaries(frc, exp);\n getCachedPower(_exp);\n\n // normalize\n var off = clz(frc);\n frc <<= off;\n exp -= off;\n\n var frc_pow = _frc_pow;\n var exp_pow = _exp_pow;\n\n var w_frc = umul64f(frc, frc_pow);\n var w_exp = umul64e(exp, exp_pow);\n\n var wp_frc = umul64f(_frc_plus, frc_pow) - 1;\n var wp_exp = umul64e(_exp, exp_pow);\n\n var wm_frc = umul64f(_frc_minus, frc_pow) + 1;\n var delta = wp_frc - wm_frc;\n\n return genDigits(buffer, w_frc, w_exp, wp_frc, wp_exp, delta, sign);\n}\n\nfunction genDigits(buffer: usize, w_frc: u64, w_exp: i32, mp_frc: u64, mp_exp: i32, delta: u64, sign: i32): i32 {\n var one_exp = -mp_exp;\n var one_frc = (1) << one_exp;\n var mask = one_frc - 1;\n\n var wp_w_frc = mp_frc - w_frc;\n var wp_w_exp = mp_exp;\n\n var p1 = (mp_frc >> one_exp);\n var p2 = mp_frc & mask;\n\n var kappa = decimalCount32(p1);\n var len = sign;\n\n var lut = changetype(POWERS10).dataStart;\n\n while (kappa > 0) {\n let d: u32;\n switch (kappa) {\n case 10: { d = p1 / 1000000000; p1 %= 1000000000; break; }\n case 9: { d = p1 / 100000000; p1 %= 100000000; break; }\n case 8: { d = p1 / 10000000; p1 %= 10000000; break; }\n case 7: { d = p1 / 1000000; p1 %= 1000000; break; }\n case 6: { d = p1 / 100000; p1 %= 100000; break; }\n case 5: { d = p1 / 10000; p1 %= 10000; break; }\n case 4: { d = p1 / 1000; p1 %= 1000; break; }\n case 3: { d = p1 / 100; p1 %= 100; break; }\n case 2: { d = p1 / 10; p1 %= 10; break; }\n case 1: { d = p1; p1 = 0; break; }\n default: { d = 0; break; }\n }\n\n if (d | len) store(buffer + (len++ << 1), CharCode._0 + d);\n\n --kappa;\n let tmp = ((p1) << one_exp) + p2;\n if (tmp <= delta) {\n _K += kappa;\n grisuRound(buffer, len, delta, tmp, load(lut + (kappa << alignof())) << one_exp, wp_w_frc);\n return len;\n }\n }\n\n while (1) {\n p2 *= 10;\n delta *= 10;\n\n let d = p2 >> one_exp;\n if (d | len) store(buffer + (len++ << 1), CharCode._0 + d);\n\n p2 &= mask;\n --kappa;\n if (p2 < delta) {\n _K += kappa;\n wp_w_frc *= load(lut + (-kappa << alignof()));\n grisuRound(buffer, len, delta, p2, one_frc, wp_w_frc);\n return len;\n }\n }\n\n return len;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction genExponent(buffer: usize, k: i32): i32 {\n var sign = k < 0;\n if (sign) k = -k;\n var decimals = decimalCount32(k) + 1;\n utoa32_core(buffer, k, decimals);\n store(buffer, select(CharCode.MINUS, CharCode.PLUS, sign));\n return decimals;\n}\n\nfunction prettify(buffer: usize, length: i32, k: i32): i32 {\n if (!k) {\n store(buffer + (length << 1), CharCode.DOT | (CharCode._0 << 16));\n return length + 2;\n }\n\n var kk = length + k;\n if (length <= kk && kk <= 21) {\n // 1234e7 -> 12340000000\n for (let i = length; i < kk; ++i) {\n store(buffer + (i << 1), CharCode._0);\n }\n store(buffer + (kk << 1), CharCode.DOT | (CharCode._0 << 16));\n return kk + 2;\n } else if (kk > 0 && kk <= 21) {\n // 1234e-2 -> 12.34\n let ptr = buffer + (kk << 1);\n memory.copy(\n ptr + 2,\n ptr,\n -k << 1\n );\n store(buffer + (kk << 1), CharCode.DOT);\n return length + 1;\n } else if (-6 < kk && kk <= 0) {\n // 1234e-6 -> 0.001234\n let offset = 2 - kk;\n memory.copy(\n buffer + (offset << 1),\n buffer,\n length << 1\n );\n store(buffer, CharCode._0 | (CharCode.DOT << 16));\n for (let i = 2; i < offset; ++i) {\n store(buffer + (i << 1), CharCode._0);\n }\n return length + offset;\n } else if (length == 1) {\n // 1e30\n store(buffer, CharCode.e, 2);\n length = genExponent(buffer + 4, kk - 1);\n return length + 2;\n } else {\n let len = length << 1;\n memory.copy(\n buffer + 4,\n buffer + 2,\n len - 2\n );\n store(buffer, CharCode.DOT, 2);\n store(buffer + len, CharCode.e, 2);\n length += genExponent(buffer + len + 4, kk - 1);\n return length + 2;\n }\n}\n\nexport function dtoa_core(buffer: usize, value: f64): i32 {\n var sign = i32(value < 0);\n if (sign) {\n value = -value;\n store(buffer, CharCode.MINUS);\n }\n // assert(value > 0 && value <= 1.7976931348623157e308);\n var len = grisu2(value, buffer, sign);\n len = prettify(buffer + (sign << 1), len - sign, _K);\n return len + sign;\n}\n\nexport function dtoa(value: f64): String {\n if (value == 0) return "0.0";\n if (!isFinite(value)) {\n if (isNaN(value)) return "NaN";\n return select("-Infinity", "Infinity", value < 0);\n }\n var buffer = __alloc(MAX_DOUBLE_LENGTH << 1, idof());\n var length = dtoa_core(buffer, value);\n if (length == MAX_DOUBLE_LENGTH) return changetype(buffer);\n var result = changetype(buffer).substring(0, length);\n __free(buffer);\n return result;\n}\n\nexport function itoa_stream(buffer: usize, offset: usize, value: T): u32 {\n buffer += (offset << 1);\n if (!value) {\n store(buffer, CharCode._0);\n return 1;\n }\n var decimals: u32 = 0;\n if (isSigned()) {\n let sign = i32(value < 0);\n if (sign) value = changetype(-value);\n if (sizeof() <= 4) {\n decimals = decimalCount32(value) + sign;\n utoa32_core(buffer, value, decimals);\n } else {\n if (value <= u32.MAX_VALUE) {\n let val32 = value;\n decimals = decimalCount32(val32) + sign;\n utoa32_core(buffer, val32, decimals);\n } else {\n decimals = decimalCount64(value) + sign;\n utoa64_core(buffer, value, decimals);\n }\n }\n if (sign) store(buffer, CharCode.MINUS);\n } else {\n if (sizeof() <= 4) {\n decimals = decimalCount32(value);\n utoa32_core(buffer, value, decimals);\n } else {\n if (value <= u32.MAX_VALUE) {\n let val32 = value;\n decimals = decimalCount32(val32);\n utoa32_core(buffer, val32, decimals);\n } else {\n decimals = decimalCount64(value);\n utoa64_core(buffer, value, decimals);\n }\n }\n }\n return decimals;\n}\n\nexport function dtoa_stream(buffer: usize, offset: usize, value: f64): u32 {\n buffer += (offset << 1);\n if (value == 0.0) {\n store(buffer, CharCode._0);\n store(buffer, CharCode.DOT, 2);\n store(buffer, CharCode._0, 4);\n return 3;\n }\n if (!isFinite(value)) {\n if (isNaN(value)) {\n store(buffer, CharCode.N);\n store(buffer, CharCode.a, 2);\n store(buffer, CharCode.N, 4);\n return 3;\n } else {\n let sign = i32(value < 0);\n let len = 8 + sign;\n memory.copy(buffer, changetype(select("-Infinity", "Infinity", sign)), len << 1);\n return len;\n }\n }\n return dtoa_core(buffer, value);\n}\n',"util/sort":'import { compareImpl } from "./string";\n\n// @ts-ignore: decorator\n@inline\nexport function COMPARATOR(): (a: T, b: T) => i32 {\n if (isInteger()) {\n if (isSigned() && sizeof() <= 4) {\n return (a: T, b: T): i32 => (i32(a) - i32(b));\n } else {\n return (a: T, b: T): i32 => (i32(a > b) - i32(a < b));\n }\n } else if (isFloat()) {\n if (sizeof() == 4) {\n return (a: T, b: T): i32 => {\n var ia = reinterpret(f32(a));\n var ib = reinterpret(f32(b));\n ia ^= (ia >> 31) >>> 1;\n ib ^= (ib >> 31) >>> 1;\n return i32(ia > ib) - i32(ia < ib);\n };\n } else {\n return (a: T, b: T): i32 => {\n var ia = reinterpret(f64(a));\n var ib = reinterpret(f64(b));\n ia ^= (ia >> 63) >>> 1;\n ib ^= (ib >> 63) >>> 1;\n return i32(ia > ib) - i32(ia < ib);\n };\n }\n } else if (isString()) {\n return (a: T, b: T): i32 => {\n if (a === b || a === null || b === null) return 0;\n var alen = changetype(a).length;\n var blen = changetype(b).length;\n if (!alen && !blen) return 0;\n if (!alen) return -1;\n if (!blen) return 1;\n return compareImpl(changetype(a), 0, changetype(b), 0, min(alen, blen));\n };\n } else {\n return (a: T, b: T): i32 => (i32(a > b) - i32(a < b));\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function SORT(\n dataStart: usize,\n length: i32,\n comparator: (a: T, b: T) => i32\n): void {\n if (isReference()) {\n // TODO replace this to faster stable sort (TimSort) when it implemented\n insertionSort(dataStart, length, comparator);\n } else {\n if (length < 256) {\n insertionSort(dataStart, length, comparator);\n } else {\n weakHeapSort(dataStart, length, comparator);\n }\n }\n}\n\nfunction insertionSort(\n dataStart: usize,\n length: i32,\n comparator: (a: T, b: T) => i32\n): void {\n for (let i = 0; i < length; i++) {\n let a: T = load(dataStart + (i << alignof())); // a = arr[i]\n let j = i - 1;\n while (j >= 0) {\n let b: T = load(dataStart + (j << alignof())); // b = arr[j]\n if (comparator(a, b) < 0) {\n store(dataStart + ((j-- + 1) << alignof()), b); // arr[j + 1] = b\n } else break;\n }\n store(dataStart + ((j + 1) << alignof()), a); // arr[j + 1] = a\n }\n}\n\nfunction weakHeapSort(\n dataStart: usize,\n length: i32,\n comparator: (a: T, b: T) => i32\n): void {\n const shift32 = alignof();\n\n var bitsetSize = (length + 31) >> 5 << shift32;\n var bitset = __alloc(bitsetSize, 0); // indexed in 32-bit chunks below\n memory.fill(bitset, 0, bitsetSize);\n\n // see: http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.21.1863&rep=rep1&type=pdf\n\n for (let i = length - 1; i > 0; i--) {\n let j = i;\n while ((j & 1) == (load(bitset + (j >> 6 << shift32)) >> (j >> 1 & 31) & 1)) j >>= 1;\n\n let p = j >> 1;\n let a: T = load(dataStart + (p << alignof())); // a = arr[p]\n let b: T = load(dataStart + (i << alignof())); // b = arr[i]\n if (comparator(a, b) < 0) {\n store(\n bitset + (i >> 5 << shift32),\n load(bitset + (i >> 5 << shift32)) ^ (1 << (i & 31))\n );\n store(dataStart + (i << alignof()), a); // arr[i] = a\n store(dataStart + (p << alignof()), b); // arr[p] = b\n }\n }\n\n for (let i = length - 1; i >= 2; i--) {\n let a: T = load(dataStart); // a = arr[0]\n store(dataStart, load(dataStart + (i << alignof()))); // arr[0] = arr[i]\n store(dataStart + (i << alignof()), a); // arr[i] = a\n\n let x = 1, y: i32;\n while ((y = (x << 1) + ((load(bitset + (x >> 5 << shift32)) >> (x & 31)) & 1)) < i) x = y;\n\n while (x > 0) {\n a = load(dataStart); // a = arr[0]\n let b: T = load(dataStart + (x << alignof())); // b = arr[x]\n\n if (comparator(a, b) < 0) {\n store(\n bitset + (x >> 5 << shift32),\n load(bitset + (x >> 5 << shift32)) ^ (1 << (x & 31))\n );\n store(dataStart + (x << alignof()), a); // arr[x] = a\n store(dataStart, b); // arr[0] = b\n }\n x >>= 1;\n }\n }\n\n __free(bitset);\n\n var t: T = load(dataStart, sizeof()); // t = arr[1]\n store(dataStart, load(dataStart), sizeof()); // arr[1] = arr[0]\n store(dataStart, t); // arr[0] = t\n}\n',"util/string":"export function compareImpl(str1: string, index1: usize, str2: string, index2: usize, len: usize): i32 {\n var result: i32 = 0;\n var ptr1 = changetype(str1) + (index1 << 1);\n var ptr2 = changetype(str2) + (index2 << 1);\n while (len && !(result = load(ptr1) - load(ptr2))) {\n --len, ptr1 += 2, ptr2 += 2;\n }\n return result;\n}\n\n// @ts-ignore: decorator\n@inline\nexport const enum CharCode {\n PLUS = 0x2B,\n MINUS = 0x2D,\n DOT = 0x2E,\n _0 = 0x30,\n _1 = 0x31,\n _2 = 0x32,\n _3 = 0x33,\n _4 = 0x34,\n _5 = 0x35,\n _6 = 0x36,\n _7 = 0x37,\n _8 = 0x38,\n _9 = 0x39,\n A = 0x41,\n B = 0x42,\n E = 0x45,\n N = 0x4E,\n O = 0x4F,\n X = 0x58,\n Z = 0x5a,\n a = 0x61,\n b = 0x62,\n e = 0x65,\n n = 0x6E,\n o = 0x6F,\n x = 0x78,\n z = 0x7A\n}\n\nexport function isWhiteSpaceOrLineTerminator(c: i32): bool {\n switch (c) {\n case 9: // \n case 10: // \n case 13: // \n case 11: // \n case 12: // \n case 32: // \n case 160: // \n case 8232: // \n case 8233: // \n case 65279: return true; // \n default: return false;\n }\n}\n\n/** Parses a string to an integer (usually), using the specified radix. */\nexport function strtol(str: string, radix: i32 = 0): T {\n var len: i32 = str.length;\n // @ts-ignore: cast\n if (!len) return NaN;\n\n var ptr = changetype(str) /* + HEAD -> offset */;\n var code = load(ptr);\n\n // determine sign\n // @ts-ignore: cast\n var sign: T = 1;\n // trim white spaces\n while (isWhiteSpaceOrLineTerminator(code)) {\n code = load(ptr += 2);\n --len;\n }\n if (code == CharCode.MINUS) {\n // @ts-ignore: cast\n if (!--len) return NaN;\n code = load(ptr += 2);\n // @ts-ignore: type\n sign = -1;\n } else if (code == CharCode.PLUS) {\n // @ts-ignore: cast\n if (!--len) return NaN;\n code = load(ptr += 2);\n }\n\n // determine radix\n if (!radix) {\n if (code == CharCode._0 && len > 2) {\n switch (load(ptr + 2)) {\n case CharCode.B:\n case CharCode.b: {\n ptr += 4; len -= 2;\n radix = 2;\n break;\n }\n case CharCode.O:\n case CharCode.o: {\n ptr += 4; len -= 2;\n radix = 8;\n break;\n }\n case CharCode.X:\n case CharCode.x: {\n ptr += 4; len -= 2;\n radix = 16;\n break;\n }\n default: radix = 10;\n }\n } else radix = 10;\n } else if (radix < 2 || radix > 36) {\n // @ts-ignore: cast\n return NaN;\n }\n\n // calculate value\n // @ts-ignore: type\n var num: T = 0;\n while (len--) {\n code = load(ptr);\n if (code >= CharCode._0 && code <= CharCode._9) {\n code -= CharCode._0;\n } else if (code >= CharCode.A && code <= CharCode.Z) {\n code -= CharCode.A - 10;\n } else if (code >= CharCode.a && code <= CharCode.z) {\n code -= CharCode.a - 10;\n } else break;\n if (code >= radix) break;\n // @ts-ignore: type\n num = num * radix + code;\n ptr += 2;\n }\n // @ts-ignore: type\n return sign * num;\n}\n\n// FIXME: naive implementation\nexport function strtod(str: string): f64 {\n var len: i32 = str.length;\n if (!len) return NaN;\n\n var ptr = changetype(str);\n var code = load(ptr);\n\n // determine sign\n var sign = 1.0;\n // trim white spaces\n while (isWhiteSpaceOrLineTerminator(code)) {\n code = load(ptr += 2);\n --len;\n }\n if (code == CharCode.MINUS) {\n if (!--len) return NaN;\n code = load(ptr += 2);\n sign = -1.0;\n } else if (code == CharCode.PLUS) {\n if (!--len) return NaN;\n code = load(ptr += 2);\n }\n\n // calculate value\n var num = 0.0;\n while (len--) {\n code = load(ptr);\n if (code == CharCode.DOT) {\n ptr += 2;\n let fac = 0.1; // precision :(\n while (len--) {\n code = load(ptr);\n if (code == CharCode.E || code == CharCode.e) {\n assert(false); // TODO\n }\n code -= CharCode._0;\n if (code > 9) break;\n num += code * fac;\n fac *= 0.1;\n ptr += 2;\n }\n break;\n }\n code -= CharCode._0;\n if (code >= 10) break;\n num = num * 10 + code;\n ptr += 2;\n }\n return sign * num;\n}\n",vector:"/** Vector abstraction. */\n@sealed @unmanaged\nexport abstract class V128 {\n}\n"}):(()=>{const n=path.join(".","..","std","assembly"),e=__webpack_require__(!function(){var n=new Error("Cannot find module 'glob'");throw n.code="MODULE_NOT_FOUND",n}()).sync("**/!(*.d).ts",{cwd:n}),t={};return e.forEach(e=>t[e.replace(/\.ts$/,"")]=fs.readFileSync(path.join(n,e),"utf8")),t})(),exports.definitionFiles=exports.isBundle?Object({assembly:'/**\n * Environment definitions for compiling AssemblyScript to WebAssembly using asc.\n * @module std/assembly\n *//***/\n\n/// \n\n// Types\n\n/** An 8-bit signed integer. */\ndeclare type i8 = number;\n/** A 16-bit signed integer. */\ndeclare type i16 = number;\n/** A 32-bit signed integer. */\ndeclare type i32 = number;\n/** A 64-bit signed integer. */\ndeclare type i64 = number;\n/** A 32-bit signed integer when targeting 32-bit WebAssembly or a 64-bit signed integer when targeting 64-bit WebAssembly. */\ndeclare type isize = number;\n/** An 8-bit unsigned integer. */\ndeclare type u8 = number;\n/** A 16-bit unsigned integer. */\ndeclare type u16 = number;\n/** A 32-bit unsigned integer. */\ndeclare type u32 = number;\n/** A 64-bit unsigned integer. */\ndeclare type u64 = number;\n/** A 32-bit unsigned integer when targeting 32-bit WebAssembly or a 64-bit unsigned integer when targeting 64-bit WebAssembly. */\ndeclare type usize = number;\n/** A 1-bit unsigned integer. */\ndeclare type bool = boolean | number;\n/** A 32-bit float. */\ndeclare type f32 = number;\n/** A 64-bit float. */\ndeclare type f64 = number;\n/** A 128-bit vector. */\ndeclare type v128 = object;\n\n// Compiler hints\n\n/** Compiler target. 0 = JS, 1 = WASM32, 2 = WASM64. */\ndeclare const ASC_TARGET: i32;\n/** Provided noAssert option. */\ndeclare const ASC_NO_ASSERT: bool;\n/** Provided memoryBase option. */\ndeclare const ASC_MEMORY_BASE: i32;\n/** Provided optimizeLevel option. */\ndeclare const ASC_OPTIMIZE_LEVEL: i32;\n/** Provided shrinkLevel option. */\ndeclare const ASC_SHRINK_LEVEL: i32;\n/** Whether the mutable global feature is enabled. */\ndeclare const ASC_FEATURE_MUTABLE_GLOBAL: bool;\n/** Whether the sign extension feature is enabled. */\ndeclare const ASC_FEATURE_SIGN_EXTENSION: bool;\n/** Whether the bulk memory feature is enabled. */\ndeclare const ASC_FEATURE_BULK_MEMORY: bool;\n/** Whether the SIMD feature is enabled. */\ndeclare const ASC_FEATURE_SIMD: bool;\n/** Whether the threads feature is enabled. */\ndeclare const ASC_FEATURE_THREADS: bool;\n\n// Builtins\n\n/** Performs the sign-agnostic count leading zero bits operation on a 32-bit or 64-bit integer. All zero bits are considered leading if the value is zero. */\ndeclare function clz(value: T): T;\n/** Performs the sign-agnostic count tailing zero bits operation on a 32-bit or 64-bit integer. All zero bits are considered trailing if the value is zero. */\ndeclare function ctz(value: T): T;\n/** Performs the sign-agnostic count number of one bits operation on a 32-bit or 64-bit integer. */\ndeclare function popcnt(value: T): T;\n/** Performs the sign-agnostic rotate left operation on a 32-bit or 64-bit integer. */\ndeclare function rotl(value: T, shift: T): T;\n/** Performs the sign-agnostic rotate right operation on a 32-bit or 64-bit integer. */\ndeclare function rotr(value: T, shift: T): T;\n/** Computes the absolute value of an integer or float. */\ndeclare function abs(value: T): T;\n/** Determines the maximum of two integers or floats. If either operand is `NaN`, returns `NaN`. */\ndeclare function max(left: T, right: T): T;\n/** Determines the minimum of two integers or floats. If either operand is `NaN`, returns `NaN`. */\ndeclare function min(left: T, right: T): T;\n/** Performs the ceiling operation on a 32-bit or 64-bit float. */\ndeclare function ceil(value: T): T;\n/** Composes a 32-bit or 64-bit float from the magnitude of `x` and the sign of `y`. */\ndeclare function copysign(x: T, y: T): T;\n/** Performs the floor operation on a 32-bit or 64-bit float. */\ndeclare function floor(value: T): T;\n/** Rounds to the nearest integer tied to even of a 32-bit or 64-bit float. */\ndeclare function nearest(value: T): T;\n/** Reinterprets the bits of the specified value as type `T`. Valid reinterpretations are u32/i32 to/from f32 and u64/i64 to/from f64. */\ndeclare function reinterpret(value: number): T;\n/** Selects one of two pre-evaluated values depending on the condition. */\ndeclare function select(ifTrue: T, ifFalse: T, condition: bool): T;\n/** Calculates the square root of a 32-bit or 64-bit float. */\ndeclare function sqrt(value: T): T;\n/** Rounds to the nearest integer towards zero of a 32-bit or 64-bit float. */\ndeclare function trunc(value: T): T;\n/** Loads a value of the specified type from memory. Equivalent to dereferncing a pointer in other languages. */\ndeclare function load(ptr: usize, immOffset?: usize, immAlign?: usize): T;\n/** Stores a value of the specified type to memory. Equivalent to dereferencing a pointer in other languages when assigning a value. */\ndeclare function store(ptr: usize, value: any, immOffset?: usize, immAlign?: usize): void;\n/** Emits an unreachable operation that results in a runtime error when executed. Both a statement and an expression of any type. */\ndeclare function unreachable(): any; // sic\n\n/** NaN (not a number) as a 32-bit or 64-bit float depending on context. */\ndeclare const NaN: f32 | f64;\n/** Positive infinity as a 32-bit or 64-bit float depending on context. */\ndeclare const Infinity: f32 | f64;\n/** Heap base offset. */\ndeclare const __heap_base: usize;\n/** Determines the byte size of the specified underlying core type. Compiles to a constant. */\ndeclare function sizeof(): usize;\n/** Determines the alignment (log2) of the specified underlying core type. Compiles to a constant. */\ndeclare function alignof(): usize;\n/** Determines the offset of the specified field within the given class type. Returns the class type\'s end offset if field name has been omitted. Compiles to a constant. */\ndeclare function offsetof(fieldName?: string): usize;\n/** Determines the unique runtime id of a class type. Compiles to a constant. */\ndeclare function idof(): u32;\n/** Changes the type of any value of `usize` kind to another one of `usize` kind. Useful for casting class instances to their pointer values and vice-versa. Beware that this is unsafe.*/\ndeclare function changetype(value: any): T;\n/** Explicitly requests no bounds checks on the provided expression. Useful for array accesses. */\ndeclare function unchecked(value: T): T;\n/** Emits a `call_indirect` instruction, calling the specified function in the function table by index with the specified arguments. Does result in a runtime error if the arguments do not match the called function. */\ndeclare function call_indirect(target: Function | u32, ...args: any[]): T;\n/** Emits a `call` instruction, calling the specified function in the function table directly with the specified arguments. Function index must be a compile-time constant. */\ndeclare function call_direct(target: Function | u32, ...args: any[]): T;\n/** Instantiates a new instance of `T` using the specified constructor arguments. */\ndeclare function instantiate(...args: any[]): T;\n/** Tests if a 32-bit or 64-bit float is `NaN`. */\ndeclare function isNaN(value: T): bool;\n/** Tests if a 32-bit or 64-bit float is finite, that is not `NaN` or +/-`Infinity`. */\ndeclare function isFinite(value: T): bool;\n/** Tests if the specified type *or* expression is of an integer type and not a reference. Compiles to a constant. */\ndeclare function isInteger(value?: any): value is number;\n/** Tests if the specified type *or* expression is of a float type. Compiles to a constant. */\ndeclare function isFloat(value?: any): value is number;\n/** Tests if the specified type *or* expression is of a boolean type. */\ndeclare function isBoolean(value?: any): value is number;\n/** Tests if the specified type *or* expression can represent negative numbers. Compiles to a constant. */\ndeclare function isSigned(value?: any): value is number;\n/** Tests if the specified type *or* expression is of a reference type. Compiles to a constant. */\ndeclare function isReference(value?: any): value is object | string;\n/** Tests if the specified type *or* expression can be used as a string. Compiles to a constant. */\ndeclare function isString(value?: any): value is string | String;\n/** Tests if the specified type *or* expression can be used as an array. Compiles to a constant. */\ndeclare function isArray(value?: any): value is Array;\n/** Tests if the specified type *or* expression can be used as an array like object. Compiles to a constant. */\ndeclare function isArrayLike(value?: any): value is ArrayLike;\n/** Tests if the specified type *or* expression is of a function type. Compiles to a constant. */\ndeclare function isFunction(value?: any): value is (...args: any) => any;\n/** Tests if the specified type *or* expression is of a nullable reference type. Compiles to a constant. */\ndeclare function isNullable(value?: any): bool;\n/** Tests if the specified expression resolves to a defined element. Compiles to a constant. */\ndeclare function isDefined(expression: any): bool;\n/** Tests if the specified expression evaluates to a constant value. Compiles to a constant. */\ndeclare function isConstant(expression: any): bool;\n/** Tests if the specified type *or* expression is of a managed type. Compiles to a constant. */\ndeclare function isManaged(value?: any): bool;\n/** Traps if the specified value is not true-ish, otherwise returns the (non-nullable) value. */\ndeclare function assert(isTrueish: T, message?: string): T & object; // any better way to model `: T != null`?\n/** Parses an integer string to a 64-bit float. */\ndeclare function parseInt(str: string, radix?: i32): f64;\n/** Parses a string to a 64-bit float. */\ndeclare function parseFloat(str: string): f64;\n/** Returns the 64-bit floating-point remainder of `x/y`. */\ndeclare function fmod(x: f64, y: f64): f64;\n/** Returns the 32-bit floating-point remainder of `x/y`. */\ndeclare function fmodf(x: f32, y: f32): f32;\n\n/** Atomic operations. */\ndeclare namespace atomic {\n /** Atomically loads an integer value from memory and returns it. */\n export function load(offset: usize, immOffset?: usize): T;\n /** Atomically stores an integer value to memory. */\n export function store(offset: usize, value: T, immOffset?: usize): void;\n /** Atomically adds an integer value in memory. */\n export function add(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically subtracts an integer value in memory. */\n export function sub(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically performs a bitwise AND operation on an integer value in memory. */\n export function and(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically performs a bitwise OR operation on an integer value in memory. */\n export function or(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically performs a bitwise XOR operation on an integer value in memory. */\n export function xor(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically exchanges an integer value in memory. */\n export function xchg(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically compares and exchanges an integer value in memory if the condition is met. */\n export function cmpxchg(ptr: usize, expected: T, replacement: T, immOffset?: usize): T;\n /** Performs a wait operation on an address in memory suspending this agent if the integer condition is met. */\n export function wait(ptr: usize, expected: T, timeout: i64): AtomicWaitResult;\n /** Performs a notify operation on an address in memory waking up suspended agents. */\n export function notify(ptr: usize, count: i32): i32;\n}\n\n/** Describes the result of an atomic wait operation. */\ndeclare enum AtomicWaitResult {\n /** Woken by another agent. */\n OK,\n /** Loaded value did not match the expected value. */\n NOT_EQUAL,\n /** Not woken before the timeout expired. */\n TIMED_OUT\n}\n\n/** Converts any other numeric value to an 8-bit signed integer. */\ndeclare function i8(value: any): i8;\ndeclare namespace i8 {\n /** Smallest representable value. */\n export const MIN_VALUE: i8;\n /** Largest representable value. */\n export const MAX_VALUE: i8;\n}\n/** Converts any other numeric value to a 16-bit signed integer. */\ndeclare function i16(value: any): i8;\ndeclare namespace i16 {\n /** Smallest representable value. */\n export const MIN_VALUE: i16;\n /** Largest representable value. */\n export const MAX_VALUE: i16;\n}\n/** Converts any other numeric value to a 32-bit signed integer. */\ndeclare function i32(value: any): i32;\ndeclare namespace i32 {\n /** Smallest representable value. */\n export const MIN_VALUE: i32;\n /** Largest representable value. */\n export const MAX_VALUE: i32;\n /** Loads an 8-bit signed integer value from memory and returns it as a 32-bit integer. */\n export function load8_s(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n /** Loads an 8-bit unsigned integer value from memory and returns it as a 32-bit integer. */\n export function load8_u(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n /** Loads a 16-bit signed integer value from memory and returns it as a 32-bit integer. */\n export function load16_s(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n /** Loads a 16-bit unsigned integer value from memory and returns it as a 32-bit integer. */\n export function load16_u(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n /** Loads a 32-bit integer value from memory. */\n export function load(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n /** Stores a 32-bit integer value to memory as an 8-bit integer. */\n export function store8(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n /** Stores a 32-bit integer value to memory as a 16-bit integer. */\n export function store16(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n /** Stores a 32-bit integer value to memory. */\n export function store(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n /** Atomic 32-bit integer operations. */\n export namespace atomic {\n /** Atomically loads an 8-bit unsigned integer value from memory and returns it as a 32-bit integer. */\n export function load8_u(offset: usize, immOffset?: usize): i32;\n /** Atomically loads a 16-bit unsigned integer value from memory and returns it as a 32-bit integer. */\n export function load16_u(offset: usize, immOffset?: usize): i32;\n /** Atomically loads a 32-bit integer value from memory and returns it. */\n export function load(offset: usize, immOffset?: usize): i32;\n /** Atomically stores a 32-bit integer value to memory as an 8-bit integer. */\n export function store8(offset: usize, value: i32, immOffset?: usize): void;\n /** Atomically stores a 32-bit integer value to memory as a 16-bit integer. */\n export function store16(offset: usize, value: i32, immOffset?: usize): void;\n /** Atomically stores a 32-bit integer value to memory. */\n export function store(offset: usize, value: i32, immOffset?: usize): void;\n /** Performs a wait operation on a 32-bit integer value in memory suspending this agent if the condition is met. */\n export function wait(ptr: usize, expected: i32, timeout: i64): AtomicWaitResult;\n /** Atomic 32-bit integer read-modify-write operations on 8-bit values. */\n export namespace rmw8 {\n /** Atomically adds an 8-bit unsigned integer value in memory. */\n export function add_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically subtracts an 8-bit unsigned integer value in memory. */\n export function sub_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise AND operation an 8-bit unsigned integer value in memory. */\n export function and_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise OR operation an 8-bit unsigned integer value in memory. */\n export function or_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise XOR operation an 8-bit unsigned integer value in memory. */\n export function xor_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically exchanges an 8-bit unsigned integer value in memory. */\n export function xchg_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically compares and exchanges an 8-bit unsigned integer value in memory if the condition is met. */\n export function cmpxchg_u(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n /** Atomic 32-bit integer read-modify-write operations on 16-bit values. */\n export namespace rmw16 {\n /** Atomically adds a 16-bit unsigned integer value in memory. */\n export function add_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically adds a 16-bit unsigned integer value in memory. */\n export function sub_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise AND operation a 16-bit unsigned integer value in memory. */\n export function and_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise OR operation a 16-bit unsigned integer value in memory. */\n export function or_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise XOR operation a 16-bit unsigned integer value in memory. */\n export function xor_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically exchanges a 16-bit unsigned integer value in memory. */\n export function xchg_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically compares and exchanges a 16-bit unsigned integer value in memory if the condition is met. */\n export function cmpxchg_u(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n /** Atomic 32-bit integer read-modify-write operations. */\n export namespace rmw {\n /** Atomically adds a 32-bit integer value in memory. */\n export function add(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically subtracts a 32-bit integer value in memory. */\n export function sub(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise AND operation a 32-bit integer value in memory. */\n export function and(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise OR operation a 32-bit integer value in memory. */\n export function or(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise XOR operation a 32-bit integer value in memory. */\n export function xor(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically exchanges a 32-bit integer value in memory. */\n export function xchg(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically compares and exchanges a 32-bit integer value in memory if the condition is met. */\n export function cmpxchg(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n }\n}\n/** Converts any other numeric value to a 64-bit signed integer. */\ndeclare function i64(value: any): i64;\ndeclare namespace i64 {\n /** Smallest representable value. */\n export const MIN_VALUE: i64;\n /** Largest representable value. */\n export const MAX_VALUE: i64;\n /** Loads an 8-bit signed integer value from memory and returns it as a 64-bit integer. */\n export function load8_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads an 8-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load8_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads a 16-bit signed integer value from memory and returns it as a 64-bit integer. */\n export function load16_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads a 16-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load16_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads a 32-bit signed integer value from memory and returns it as a 64-bit integer. */\n export function load32_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads a 32-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load32_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads a 64-bit unsigned integer value from memory. */\n export function load(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Stores a 64-bit integer value to memory as an 8-bit integer. */\n export function store8(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n /** Stores a 64-bit integer value to memory as a 16-bit integer. */\n export function store16(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n /** Stores a 64-bit integer value to memory as a 32-bit integer. */\n export function store32(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n /** Stores a 64-bit integer value to memory. */\n export function store(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n /** Atomic 64-bit integer operations. */\n export namespace atomic {\n /** Atomically loads an 8-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load8_u(offset: usize, immOffset?: usize): i64;\n /** Atomically loads a 16-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load16_u(offset: usize, immOffset?: usize): i64;\n /** Atomically loads a 32-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load32_u(offset: usize, immOffset?: usize): i64;\n /** Atomically loads a 64-bit integer value from memory and returns it. */\n export function load(offset: usize, immOffset?: usize): i64;\n /** Atomically stores a 64-bit integer value to memory as an 8-bit integer. */\n export function store8(offset: usize, value: i64, immOffset?: usize): void;\n /** Atomically stores a 64-bit integer value to memory as a 16-bit integer. */\n export function store16(offset: usize, value: i64, immOffset?: usize): void;\n /** Atomically stores a 64-bit integer value to memory as a 32-bit integer. */\n export function store32(offset: usize, value: i64, immOffset?: usize): void;\n /** Atomically stores a 64-bit integer value to memory. */\n export function store(offset: usize, value: i64, immOffset?: usize): void;\n /** Performs a wait operation on a 64-bit integer value in memory suspending this agent if the condition is met. */\n export function wait(ptr: usize, expected: i64, timeout: i64): AtomicWaitResult;\n /** Atomic 64-bit integer read-modify-write operations on 8-bit values. */\n export namespace rmw8 {\n /** Atomically adds an 8-bit unsigned integer value in memory. */\n export function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically subtracts an 8-bit unsigned integer value in memory. */\n export function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise AND operation on an 8-bit unsigned integer value in memory. */\n export function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise OR operation on an 8-bit unsigned integer value in memory. */\n export function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise XOR operation on an 8-bit unsigned integer value in memory. */\n export function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically exchanges an 8-bit unsigned integer value in memory. */\n export function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically compares and exchanges an 8-bit unsigned integer value in memory if the condition is met. */\n export function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n /** Atomic 64-bit integer read-modify-write operations on 16-bit values. */\n export namespace rmw16 {\n /** Atomically adds a 16-bit unsigned integer value in memory. */\n export function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically subtracts a 16-bit unsigned integer value in memory. */\n export function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise AND operation on a 16-bit unsigned integer value in memory. */\n export function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise OR operation on a 16-bit unsigned integer value in memory. */\n export function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise XOR operation on a 16-bit unsigned integer value in memory. */\n export function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically exchanges a 16-bit unsigned integer value in memory. */\n export function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically compares and exchanges a 16-bit unsigned integer value in memory if the condition is met. */\n export function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n /** Atomic 64-bit integer read-modify-write operations on 32-bit values. */\n export namespace rmw32 {\n /** Atomically adds a 32-bit unsigned integer value in memory. */\n export function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically subtracts a 32-bit unsigned integer value in memory. */\n export function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise AND operation on a 32-bit unsigned integer value in memory. */\n export function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise OR operation on a 32-bit unsigned integer value in memory. */\n export function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise XOR operation on a 32-bit unsigned integer value in memory. */\n export function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically exchanges a 32-bit unsigned integer value in memory. */\n export function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically compares and exchanges a 32-bit unsigned integer value in memory if the condition is met. */\n export function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n /** Atomic 64-bit integer read-modify-write operations. */\n export namespace rmw {\n /** Atomically adds a 64-bit integer value in memory. */\n export function add(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically subtracts a 64-bit integer value in memory. */\n export function sub(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise AND operation on a 64-bit integer value in memory. */\n export function and(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise OR operation on a 64-bit integer value in memory. */\n export function or(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise XOR operation on a 64-bit integer value in memory. */\n export function xor(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically exchanges a 64-bit integer value in memory. */\n export function xchg(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically compares and exchanges a 64-bit integer value in memory if the condition is met. */\n export function cmpxchg(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n }\n}\n/** Converts any other numeric value to a 32-bit (in WASM32) respectivel 64-bit (in WASM64) signed integer. */\ndeclare var isize: typeof i32 | typeof i64;\n/** Converts any other numeric value to an 8-bit unsigned integer. */\ndeclare function u8(value: any): i8;\ndeclare namespace u8 {\n /** Smallest representable value. */\n export const MIN_VALUE: u8;\n /** Largest representable value. */\n export const MAX_VALUE: u8;\n}\n/** Converts any other numeric value to a 16-bit unsigned integer. */\ndeclare function u16(value: any): i8;\ndeclare namespace u16 {\n /** Smallest representable value. */\n export const MIN_VALUE: u16;\n /** Largest representable value. */\n export const MAX_VALUE: u16;\n}\n/** Converts any other numeric value to a 32-bit unsigned integer. */\ndeclare function u32(value: any): i32;\ndeclare namespace u32 {\n /** Smallest representable value. */\n export const MIN_VALUE: u32;\n /** Largest representable value. */\n export const MAX_VALUE: u32;\n}\n/** Converts any other numeric value to a 64-bit unsigned integer. */\ndeclare function u64(value: any): i64;\ndeclare namespace u64 {\n /** Smallest representable value. */\n export const MIN_VALUE: u64;\n /** Largest representable value. */\n export const MAX_VALUE: u64;\n}\n/** Converts any other numeric value to a 32-bit (in WASM32) respectivel 64-bit (in WASM64) unsigned integer. */\ndeclare var usize: typeof u32 | typeof u64;\n/** Converts any other numeric value to a 1-bit unsigned integer. */\ndeclare function bool(value: any): bool;\ndeclare namespace bool {\n /** Smallest representable value. */\n export const MIN_VALUE: bool;\n /** Largest representable value. */\n export const MAX_VALUE: bool;\n}\n/** Converts any other numeric value to a 32-bit float. */\ndeclare function f32(value: any): f32;\ndeclare namespace f32 {\n /** Smallest representable value. */\n export const MIN_VALUE: f32;\n /** Largest representable value. */\n export const MAX_VALUE: f32;\n /** Smallest normalized positive value. */\n export const MIN_POSITIVE_VALUE: f32;\n /** Smallest safely representable integer value. */\n export const MIN_SAFE_INTEGER: f32;\n /** Largest safely representable integer value. */\n export const MAX_SAFE_INTEGER: f32;\n /** Difference between 1 and the smallest representable value greater than 1. */\n export const EPSILON: f32;\n /** Loads a 32-bit float from memory. */\n export function load(offset: usize, immOffset?: usize, immAlign?: usize): f32;\n /** Stores a 32-bit float to memory. */\n export function store(offset: usize, value: f32, immOffset?: usize, immAlign?: usize): void;\n}\n/** Converts any other numeric value to a 64-bit float. */\ndeclare function f64(value: any): f64;\ndeclare namespace f64 {\n /** Smallest representable value. */\n export const MIN_VALUE: f64;\n /** Largest representable value. */\n export const MAX_VALUE: f64;\n /** Smallest normalized positive value. */\n export const MIN_POSITIVE_VALUE: f64;\n /** Smallest safely representable integer value. */\n export const MIN_SAFE_INTEGER: f64;\n /** Largest safely representable integer value. */\n export const MAX_SAFE_INTEGER: f64;\n /** Difference between 1 and the smallest representable value greater than 1. */\n export const EPSILON: f64;\n /** Loads a 64-bit float from memory. */\n export function load(offset: usize, immOffset?: usize, immAlign?: usize): f64;\n /** Stores a 64-bit float to memory. */\n export function store(offset: usize, value: f64, immOffset?: usize, immAlign?: usize): void;\n}\n/** Initializes a 128-bit vector from sixteen 8-bit integer values. Arguments must be compile-time constants. */\ndeclare function v128(a: i8, b: i8, c: i8, d: i8, e: i8, f: i8, g: i8, h: i8, i: i8, j: i8, k: i8, l: i8, m: i8, n: i8, o: i8, p: i8): v128;\ndeclare namespace v128 {\n /** Creates a 128-bit vector with identical lanes. */\n export function splat(x: T): v128;\n /** Extracts one lane from a 128-bit vector as a scalar. */\n export function extract_lane(x: v128, idx: u8): T;\n /** Replaces one lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: T): v128;\n /** Selects lanes from either 128-bit vector according to the specified lane indexes. */\n export function shuffle(a: v128, b: v128, ...lanes: u8[]): v128;\n /** Loads a 128-bit vector from memory. */\n export function load(offset: usize, immOffset?: usize, immAlign?: usize): v128;\n /** Stores a 128-bit vector to memory. */\n export function store(offset: usize, value: v128, immOffset?: usize, immAlign?: usize): void;\n /** Adds each lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128; // except i64\n /** Divides each lane of two 128-bit vectors. */\n export function div(a: v128, b: v128): v128;\n /** Negates each lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Adds each lane of two 128-bit vectors using saturation. */\n export function add_saturate(a: v128, b: v128): v128;\n /** Subtracts each lane of two 128-bit vectors using saturation. */\n export function sub_saturate(a: v128, b: v128): v128;\n /** Performs a bitwise left shift on each lane of a 128-bit vector by a scalar. */\n export function shl(a: v128, b: i32): v128;\n /** Performs a bitwise right shift on each lane of a 128-bit vector by a scalar. */\n export function shr(a: v128, b: i32): v128;\n /** Performs the bitwise AND operation on each lane of two 128-bit vectors. */\n export function and(a: v128, b: v128): v128;\n /** Performs the bitwise OR operation on each lane of two 128-bit vectors. */\n export function or(a: v128, b: v128): v128;\n /** Performs the bitwise XOR operation on each lane of two 128-bit vectors. */\n export function xor(a: v128, b: v128): v128;\n /** Performs the bitwise NOT operation on each lane of a 128-bit vector. */\n export function not(a: v128): v128;\n /** Selects bits of either 128-bit vector according to the specified mask. */\n export function bitselect(v1: v128, v2: v128, mask: v128): v128;\n /** Reduces a 128-bit vector to a scalar indicating whether any lane is considered `true`. */\n export function any_true(a: v128): bool;\n /** Reduces a 128-bit vector to a scalar indicating whether all lanes are considered `true`. */\n export function all_true(a: v128): bool;\n /** Computes the minimum of each lane of two 128-bit vectors. */\n export function min(a: v128, b: v128): v128;\n /** Computes the maximum of each lane of two 128-bit vectors. */\n export function max(a: v128, b: v128): v128;\n /** Computes the absolute value of each lane of a 128-bit vector. */\n export function abs(a: v128): v128;\n /** Computes the square root of each lane of a 128-bit vector. */\n export function sqrt(a: v128): v128;\n /** Computes which lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which lanes of the first 128-bit vector are less than those of the second. */\n export function lt(a: v128, b: v128): v128;\n /** Computes which lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le(a: v128, b: v128): v128;\n /** Computes which lanes of the first 128-bit vector are greater than those of the second. */\n export function gt(a: v128, b: v128): v128;\n /** Computes which lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge(a: v128, b: v128): v128;\n /** Converts each lane of a 128-bit vector from integer to floating point. */\n export function convert(a: v128): v128;\n /** Truncates each lane of a 128-bit vector from floating point to integer with saturation. */\n export function trunc(a: v128): v128;\n}\n/** Initializes a 128-bit vector from sixteen 8-bit integer values. Arguments must be compile-time constants. */\ndeclare function i8x16(a: i8, b: i8, c: i8, d: i8, e: i8, f: i8, g: i8, h: i8, i: i8, j: i8, k: i8, l: i8, m: i8, n: i8, o: i8, p: i8): v128;\ndeclare namespace i8x16 {\n /** Creates a vector with sixteen identical 8-bit integer lanes. */\n export function splat(x: i8): v128;\n /** Extracts one 8-bit integer lane from a 128-bit vector as a signed scalar. */\n export function extract_lane_s(x: v128, idx: u8): i8;\n /** Extracts one 8-bit integer lane from a 128-bit vector as an unsigned scalar. */\n export function extract_lane_u(x: v128, idx: u8): u8;\n /** Replaces one 8-bit integer lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: i8): v128;\n /** Adds each 8-bit integer lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 8-bit integer lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 8-bit integer lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Negates each 8-bit integer lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Adds each 8-bit integer lane of two 128-bit vectors using signed saturation. */\n export function add_saturate_s(a: v128, b: v128): v128;\n /** Adds each 8-bit integer lane of two 128-bit vectors using unsigned saturation. */\n export function add_saturate_u(a: v128, b: v128): v128;\n /** Subtracts each 8-bit integer lane of two 128-bit vectors using signed saturation. */\n export function sub_saturate_s(a: v128, b: v128): v128;\n /** Subtracts each 8-bit integer lane of two 128-bit vectors using unsigned saturation. */\n export function sub_saturate_u(a: v128, b: v128): v128;\n /** Performs a bitwise left shift on each 8-bit integer lane of a 128-bit vector by a scalar. */\n export function shl(a: v128, b: i32): v128;\n /** Performs a bitwise arithmetic right shift on each 8-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_s(a: v128, b: i32): v128;\n /** Performs a bitwise logical right shift on each 8-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_u(a: v128, b: i32): v128;\n /** Reduces a 128-bit vector to a scalar indicating whether any 8-bit integer lane is considered `true`. */\n export function any_true(a: v128): bool;\n /** Reduces a 128-bit vector to a scalar indicating whether all 8-bit integer lanes are considered `true`. */\n export function all_true(a: v128): bool;\n /** Computes which 8-bit integer lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which 8-bit integer lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which 8-bit signed integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_s(a: v128, b: v128): v128;\n /** Computes which 8-bit unsigned integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_u(a: v128, b: v128): v128;\n /** Computes which 8-bit signed integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_s(a: v128, b: v128): v128;\n /** Computes which 8-bit unsigned integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_u(a: v128, b: v128): v128;\n /** Computes which 8-bit signed integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_s(a: v128, b: v128): v128;\n /** Computes which 8-bit unsigned integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_u(a: v128, b: v128): v128;\n /** Computes which 8-bit signed integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_s(a: v128, b: v128): v128;\n /** Computes which 8-bit unsigned integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_u(a: v128, b: v128): v128;\n}\n/** Initializes a 128-bit vector from eight 16-bit integer values. Arguments must be compile-time constants. */\ndeclare function i16x8(a: i16, b: i16, c: i16, d: i16, e: i16, f: i16, g: i16, h: i16): v128;\ndeclare namespace i16x8 {\n /** Creates a vector with eight identical 16-bit integer lanes. */\n export function splat(x: i16): v128;\n /** Extracts one 16-bit integer lane from a 128-bit vector as a signed scalar. */\n export function extract_lane_s(x: v128, idx: u8): i16;\n /** Extracts one 16-bit integer lane from a 128-bit vector as an unsigned scalar. */\n export function extract_lane_u(x: v128, idx: u8): u16;\n /** Replaces one 16-bit integer lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: i16): v128;\n /** Adds each 16-bit integer lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 16-bit integer lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 16-bit integer lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Negates each 16-bit integer lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Adds each 16-bit integer lane of two 128-bit vectors using signed saturation. */\n export function add_saturate_s(a: v128, b: v128): v128;\n /** Adds each 16-bit integer lane of two 128-bit vectors using unsigned saturation. */\n export function add_saturate_u(a: v128, b: v128): v128;\n /** Subtracts each 16-bit integer lane of two 128-bit vectors using signed saturation. */\n export function sub_saturate_s(a: v128, b: v128): v128;\n /** Subtracts each 16-bit integer lane of two 128-bit vectors using unsigned saturation. */\n export function sub_saturate_u(a: v128, b: v128): v128;\n /** Performs a bitwise left shift on each 16-bit integer lane of a 128-bit vector by a scalar. */\n export function shl(a: v128, b: i32): v128;\n /** Performs a bitwise arithmetic right shift each 16-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_s(a: v128, b: i32): v128;\n /** Performs a bitwise logical right shift on each 16-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_u(a: v128, b: i32): v128;\n /** Reduces a 128-bit vector to a scalar indicating whether any 16-bit integer lane is considered `true`. */\n export function any_true(a: v128): bool;\n /** Reduces a 128-bit vector to a scalar indicating whether all 16-bit integer lanes are considered `true`. */\n export function all_true(a: v128): bool;\n /** Computes which 16-bit integer lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which 16-bit integer lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which 16-bit signed integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_s(a: v128, b: v128): v128;\n /** Computes which 16-bit unsigned integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_u(a: v128, b: v128): v128;\n /** Computes which 16-bit signed integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_s(a: v128, b: v128): v128;\n /** Computes which 16-bit unsigned integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_u(a: v128, b: v128): v128;\n /** Computes which 16-bit signed integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_s(a: v128, b: v128): v128;\n /** Computes which 16-bit unsigned integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_u(a: v128, b: v128): v128;\n /** Computes which 16-bit signed integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_s(a: v128, b: v128): v128;\n /** Computes which 16-bit unsigned integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_u(a: v128, b: v128): v128;\n}\n/** Initializes a 128-bit vector from four 32-bit integer values. Arguments must be compile-time constants. */\ndeclare function i32x4(a: i32, b: i32, c: i32, d: i32): v128;\ndeclare namespace i32x4 {\n /** Creates a 128-bit vector with four identical 32-bit integer lanes. */\n export function splat(x: i32): v128;\n /** Extracts one 32-bit integer lane from a 128-bit vector as a scalar. */\n export function extract_lane(x: v128, idx: u8): i32;\n /** Replaces one 32-bit integer lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: i32): v128;\n /** Adds each 32-bit integer lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 32-bit integer lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 32-bit integer lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Negates each 32-bit integer lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Performs a bitwise left shift on each 32-bit integer lane of a 128-bit vector by a scalar. */\n export function shl(a: v128, b: i32): v128;\n /** Performs a bitwise arithmetic right shift on each 32-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_s(a: v128, b: i32): v128;\n /** Performs a bitwise logical right shift on each 32-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_u(a: v128, b: i32): v128;\n /** Reduces a 128-bit vector to a scalar indicating whether any 32-bit integer lane is considered `true`. */\n export function any_true(a: v128): bool;\n /** Reduces a 128-bit vector to a scalar indicating whether all 32-bit integer lanes are considered `true`. */\n export function all_true(a: v128): bool;\n /** Computes which 32-bit integer lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which 32-bit integer lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which 32-bit signed integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_s(a: v128, b: v128): v128;\n /** Computes which 32-bit unsigned integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_u(a: v128, b: v128): v128;\n /** Computes which 32-bit signed integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_s(a: v128, b: v128): v128;\n /** Computes which 32-bit unsigned integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_u(a: v128, b: v128): v128;\n /** Computes which 32-bit signed integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_s(a: v128, b: v128): v128;\n /** Computes which 32-bit unsigned integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_u(a: v128, b: v128): v128;\n /** Computes which 32-bit signed integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_s(a: v128, b: v128): v128;\n /** Computes which 32-bit unsigned integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_u(a: v128, b: v128): v128;\n /** Truncates each 32-bit float lane of a 128-bit vector to a signed integer with saturation. */\n export function trunc_s_f32x4_sat(a: v128): v128;\n /** Truncates each 32-bit float lane of a 128-bit vector to an unsigned integer with saturation. */\n export function trunc_u_f32x4_sat(a: v128): v128;\n}\n/** Initializes a 128-bit vector from two 64-bit integer values. Arguments must be compile-time constants. */\ndeclare function i64x2(a: i64, b: i64): v128;\ndeclare namespace i64x2 {\n /** Creates a 128-bit vector with two identical 64-bit integer lanes. */\n export function splat(x: i64): v128;\n /** Extracts one 64-bit integer lane from a 128-bit vector as a scalar. */\n export function extract_lane(x: v128, idx: u8): i64;\n /** Replaces one 64-bit integer lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: i64): v128;\n /** Adds each 64-bit integer lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 64-bit integer lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 64-bit integer lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Negates each 64-bit integer lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Performs a bitwise left shift on each 64-bit integer lane of a 128-bit vector by a scalar. */\n export function shl(a: v128, b: i32): v128;\n /** Performs a bitwise arithmetic right shift on each 64-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_s(a: v128, b: i32): v128;\n /** Performs a bitwise logical right shift on each 64-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_u(a: v128, b: i32): v128;\n /** Reduces a 128-bit vector to a scalar indicating whether any 64-bit integer lane is considered `true`. */\n export function any_true(a: v128): bool;\n /** Reduces a 128-bit vector to a scalar indicating whether all 64-bit integer lanes are considered `true`. */\n export function all_true(a: v128): bool;\n /** Truncates each 64-bit float lane of a 128-bit vector to a signed integer with saturation. */\n export function trunc_s_f64x2_sat(a: v128): v128;\n /** Truncates each 64-bit float lane of a 128-bit vector to an unsigned integer with saturation. */\n export function trunc_u_f64x2_sat(a: v128): v128;\n}\n/** Initializes a 128-bit vector from four 32-bit float values. Arguments must be compile-time constants. */\ndeclare function f32x4(a: f32, b: f32, c: f32, d: f32): v128;\ndeclare namespace f32x4 {\n /** Creates a 128-bit vector with four identical 32-bit float lanes. */\n export function splat(x: f32): v128;\n /** Extracts one 32-bit float lane from a 128-bit vector as a scalar. */\n export function extract_lane(x: v128, idx: u8): f32;\n /** Replaces one 32-bit float lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: f32): v128;\n /** Adds each 32-bit float lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 32-bit float lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 32-bit float lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Divides each 32-bit float lane of two 128-bit vectors. */\n export function div(a: v128, b: v128): v128;\n /** Negates each 32-bit float lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Computes the minimum of each 32-bit float lane of two 128-bit vectors. */\n export function min(a: v128, b: v128): v128;\n /** Computes the maximum of each 32-bit float lane of two 128-bit vectors. */\n export function max(a: v128, b: v128): v128;\n /** Computes the absolute value of each 32-bit float lane of a 128-bit vector. */\n export function abs(a: v128): v128;\n /** Computes the square root of each 32-bit float lane of a 128-bit vector. */\n export function sqrt(a: v128): v128;\n /** Computes which 32-bit float lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which 32-bit float lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which 32-bit float lanes of the first 128-bit vector are less than those of the second. */\n export function lt(a: v128, b: v128): v128;\n /** Computes which 32-bit float lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le(a: v128, b: v128): v128;\n /** Computes which 32-bit float lanes of the first 128-bit vector are greater than those of the second. */\n export function gt(a: v128, b: v128): v128;\n /** Computes which 32-bit float lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge(a: v128, b: v128): v128;\n /** Converts each 32-bit signed integer lane of a 128-bit vector to floating point. */\n export function convert_s_i32x4(a: v128): v128;\n /** Converts each 32-bit unsigned integer lane of a 128-bit vector to floating point. */\n export function convert_u_i32x4(a: v128): v128;\n}\n/** Initializes a 128-bit vector from two 64-bit float values. Arguments must be compile-time constants. */\ndeclare function f64x2(a: f64, b: f64): v128;\ndeclare namespace f64x2 {\n /** Creates a 128-bit vector with two identical 64-bit float lanes. */\n export function splat(x: f64): v128;\n /** Extracts one 64-bit float lane from a 128-bit vector as a scalar. */\n export function extract_lane(x: v128, idx: u8): f64;\n /** Replaces one 64-bit float lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: f64): v128;\n /** Adds each 64-bit float lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 64-bit float lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 64-bit float lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Divides each 64-bit float lane of two 128-bit vectors. */\n export function div(a: v128, b: v128): v128;\n /** Negates each 64-bit float lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Computes the minimum of each 64-bit float lane of two 128-bit vectors. */\n export function min(a: v128, b: v128): v128;\n /** Computes the maximum of each 64-bit float lane of two 128-bit vectors. */\n export function max(a: v128, b: v128): v128;\n /** Computes the absolute value of each 64-bit float lane of a 128-bit vector. */\n export function abs(a: v128): v128;\n /** Computes the square root of each 64-bit float lane of a 128-bit vector. */\n export function sqrt(a: v128): v128;\n /** Computes which 64-bit float lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which 64-bit float lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which 64-bit float lanes of the first 128-bit vector are less than those of the second. */\n export function lt(a: v128, b: v128): v128;\n /** Computes which 64-bit float lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le(a: v128, b: v128): v128;\n /** Computes which 64-bit float lanes of the first 128-bit vector are greater than those of the second. */\n export function gt(a: v128, b: v128): v128;\n /** Computes which 64-bit float lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge(a: v128, b: v128): v128;\n /** Converts each 64-bit signed integer lane of a 128-bit vector to floating point. */\n export function convert_s_i64x2(a: v128): v128;\n /** Converts each 64-bit unsigned integer lane of a 128-bit vector to floating point. */\n export function convert_u_i64x2(a: v128): v128;\n}\ndeclare namespace v8x16 {\n /** Selects 8-bit lanes from either 128-bit vector according to the specified lane indexes. */\n export function shuffle(a: v128, b: v128, l0: u8, l1: u8, l2: u8, l3: u8, l4: u8, l5: u8, l6: u8, l7: u8, l8: u8, l9: u8, l10: u8, l11: u8, l12: u8, l13: u8, l14: u8, l15: u8): v128;\n}\n/** Macro type evaluating to the underlying native WebAssembly type. */\ndeclare type native = T;\n\n/** Pseudo-class representing the backing class of integer types. */\ndeclare class _Integer {\n /** Smallest representable value. */\n static readonly MIN_VALUE: number;\n /** Largest representable value. */\n static readonly MAX_VALUE: number;\n /** Converts a string to an integer of this type. */\n static parseInt(value: string, radix?: number): number;\n /** Converts this integer to a string. */\n toString(): string;\n}\n\n/** Pseudo-class representing the backing class of floating-point types. */\ndeclare class _Float {\n /** Difference between 1 and the smallest representable value greater than 1. */\n static readonly EPSILON: f32 | f64;\n /** Smallest representable value. */\n static readonly MIN_VALUE: f32 | f64;\n /** Largest representable value. */\n static readonly MAX_VALUE: f32 | f64;\n /** Smallest safely representable integer value. */\n static readonly MIN_SAFE_INTEGER: f32 | f64;\n /** Largest safely representable integer value. */\n static readonly MAX_SAFE_INTEGER: f32 | f64;\n /** Value representing positive infinity. */\n static readonly POSITIVE_INFINITY: f32 | f64;\n /** Value representing negative infinity. */\n static readonly NEGATIVE_INFINITY: f32 | f64;\n /** Value representing \'not a number\'. */\n static readonly NaN: f32 | f64;\n /** Returns a boolean value that indicates whether a value is the reserved value NaN (not a number). */\n static isNaN(value: f32 | f64): bool;\n /** Returns true if passed value is finite. */\n static isFinite(value: f32 | f64): bool;\n /** Returns true if the value passed is a safe integer. */\n static isSafeInteger(value: f32 | f64): bool;\n /** Returns true if the value passed is an integer, false otherwise. */\n static isInteger(value: f32 | f64): bool;\n /** Converts a string to an integer. */\n static parseInt(value: string, radix?: i32): f32 | f64;\n /** Converts a string to a floating-point number. */\n static parseFloat(value: string): f32 | f64;\n /** Converts this floating-point number to a string. */\n toString(this: f64): string;\n}\n\n/** Backing class of signed 8-bit integers. */\ndeclare const I8: typeof _Integer;\n/** Backing class of signed 16-bit integers. */\ndeclare const I16: typeof _Integer;\n/** Backing class of signed 32-bit integers. */\ndeclare const I32: typeof _Integer;\n/** Backing class of signed 64-bit integers. */\ndeclare const I64: typeof _Integer;\n/** Backing class of signed size integers. */\ndeclare const Isize: typeof _Integer;\n/** Backing class of unsigned 8-bit integers. */\ndeclare const U8: typeof _Integer;\n/** Backing class of unsigned 16-bit integers. */\ndeclare const U16: typeof _Integer;\n/** Backing class of unsigned 32-bit integers. */\ndeclare const U32: typeof _Integer;\n/** Backing class of unsigned 64-bit integers. */\ndeclare const U64: typeof _Integer;\n/** Backing class of unsigned size integers. */\ndeclare const Usize: typeof _Integer;\n/** Backing class of 32-bit floating-point values. */\ndeclare const F32: typeof _Float;\n/** Backing class of 64-bit floating-point values. */\ndeclare const F64: typeof _Float;\n\n// User-defined diagnostic macros\n\n/** Emits a user-defined diagnostic error when encountered. */\ndeclare function ERROR(message?: any): void;\n/** Emits a user-defined diagnostic warning when encountered. */\ndeclare function WARNING(message?: any): void;\n/** Emits a user-defined diagnostic info when encountered. */\ndeclare function INFO(message?: any): void;\n\n// Polyfills\n\n/** Performs the sign-agnostic reverse bytes **/\ndeclare function bswap(value: T): T;\n/** Performs the sign-agnostic reverse bytes only for last 16-bit **/\ndeclare function bswap16(value: T): T;\n\n// Standard library\n\n/** Memory operations. */\ndeclare namespace memory {\n /** Whether the memory managed interface is implemented. */\n export const implemented: bool;\n /** Returns the current memory size in units of pages. One page is 64kb. */\n export function size(): i32;\n /** Grows linear memory by a given unsigned delta of pages. One page is 64kb. Returns the previous memory size in units of pages or `-1` on failure. */\n export function grow(value: i32): i32;\n /** Sets n bytes beginning at the specified destination in memory to the specified byte value. */\n export function fill(dst: usize, value: u8, count: usize): void;\n /** Copies n bytes from the specified source to the specified destination in memory. These regions may overlap. */\n export function copy(dst: usize, src: usize, n: usize): void;\n /** Repeats `src` of length `srcLength` `count` times at `dst`. */\n export function repeat(dst: usize, src: usize, srcLength: usize, count: usize): void;\n /** Copies elements from a passive element segment to a table. */\n export function init(segmentIndex: u32, srcOffset: usize, dstOffset: usize, n: usize): void;\n /** Prevents further use of a passive element segment. */\n export function drop(segmentIndex: u32): void;\n /** Compares two chunks of memory. Returns `0` if equal, otherwise the difference of the first differing bytes. */\n export function compare(vl: usize, vr: usize, n: usize): i32;\n}\n\n/** Garbage collector operations. */\ndeclare namespace gc {\n /** Whether the garbage collector interface is implemented. */\n export const implemented: bool;\n /** Performs a full garbage collection cycle. */\n export function collect(): void;\n /** Retains a reference, making sure that it doesn\'t become collected. */\n export function retain(ref: usize): void;\n /** Releases a reference, allowing it to become collected. */\n export function release(ref: usize): void;\n}\n\n/** Table operations. */\ndeclare namespace table {\n /** Copies elements from a passive element segment to a table. */\n export function init(elementIndex: u32, srcOffset: u32, dstOffset: u32, n: u32): void;\n /** Prevents further use of a passive element segment. */\n export function drop(elementIndex: u32): void;\n /** Copies elements from one region of a table to another region. */\n export function copy(dest: u32, src: u32, n: u32): void;\n}\n\n/** Class representing a generic, fixed-length raw binary data buffer. */\ndeclare class ArrayBuffer {\n /** The size, in bytes, of the array. */\n readonly byteLength: i32;\n /** Returns true if value is one of the ArrayBuffer views, such as typed array or a DataView **/\n static isView(value: T): bool;\n /** Constructs a new array buffer of the given length in bytes. */\n constructor(length: i32);\n /** Returns a copy of this array buffer\'s bytes from begin, inclusive, up to end, exclusive. */\n slice(begin?: i32, end?: i32): ArrayBuffer;\n /** Returns a string representation of ArrayBuffer. */\n toString(): string;\n}\n\n/** The `DataView` view provides a low-level interface for reading and writing multiple number types in a binary `ArrayBuffer`, without having to care about the platform\'s endianness. */\ndeclare class DataView {\n /** The `buffer` accessor property represents the `ArrayBuffer` or `SharedArrayBuffer` referenced by the `DataView` at construction time. */\n readonly buffer: ArrayBuffer;\n /** The `byteLength` accessor property represents the length (in bytes) of this view from the start of its `ArrayBuffer` or `SharedArrayBuffer`. */\n readonly byteLength: i32;\n /** The `byteOffset` accessor property represents the offset (in bytes) of this view from the start of its `ArrayBuffer` or `SharedArrayBuffer`. */\n readonly byteOffset: i32;\n /** Constructs a new `DataView` with the given properties */\n constructor(buffer: ArrayBuffer, byteOffset?: i32, byteLength?: i32);\n /** The `getFloat32()` method gets a signed 32-bit float (float) at the specified byte offset from the start of the `DataView`. */\n getFloat32(byteOffset: i32, littleEndian?: boolean): f32;\n /** The `getFloat64()` method gets a signed 64-bit float (double) at the specified byte offset from the start of the `DataView`. */\n getFloat64(byteOffset: i32, littleEndian?: boolean): f64;\n /** The `getInt8()` method gets a signed 8-bit integer (byte) at the specified byte offset from the start of the `DataView`. */\n getInt8(byteOffset: i32): i8;\n /** The `getInt16()` method gets a signed 16-bit integer (short) at the specified byte offset from the start of the `DataView`. */\n getInt16(byteOffset: i32, littleEndian?: boolean): i16;\n /** The `getInt32()` method gets a signed 32-bit integer (long) at the specified byte offset from the start of the `DataView`. */\n getInt32(byteOffset: i32, littleEndian?: boolean): i32;\n /** The `getInt64()` method gets a signed 64-bit integer (long long) at the specified byte offset from the start of the `DataView`. */\n getInt64(byteOffset: i32, littleEndian?: boolean): i64;\n /** The `getUint8()` method gets an unsigned 8-bit integer (unsigned byte) at the specified byte offset from the start of the `DataView`. */\n getUint8(byteOffset: i32): u8;\n /** The `getUint16()` method gets an unsigned 16-bit integer (unsigned short) at the specified byte offset from the start of the `DataView`. */\n getUint16(byteOffset: i32, littleEndian?: boolean): u16;\n /** The `getUint32()` method gets an unsigned 32-bit integer (unsigned long) at the specified byte offset from the start of the `DataView`. */\n getUint32(byteOffset: i32, littleEndian?: boolean): u32;\n /** The `getUint64()` method gets an unsigned 64-bit integer (unsigned long long) at the specified byte offset from the start of the `DataView`. */\n getUint64(byteOffset: i32, littleEndian?: boolean): u64;\n /** The `setFloat32()` method stores a signed 32-bit float (float) value at the specified byte offset from the start of the `DataView`. */\n setFloat32(byteOffset: i32, value: f32, littleEndian?: boolean): void;\n /** The `setFloat64()` method stores a signed 64-bit float (double) value at the specified byte offset from the start of the `DataView`. */\n setFloat64(byteOffset: i32, value: f64, littleEndian?: boolean): void;\n /** The `setInt8()` method stores a signed 8-bit integer (byte) value at the specified byte offset from the start of the `DataView`. */\n setInt8(byteOffset: i32, value: i8): void;\n /** The `setInt16()` method stores a signed 16-bit integer (short) value at the specified byte offset from the start of the `DataView`. */\n setInt16(byteOffset: i32, value: i16, littleEndian?: boolean): void;\n /** The `setInt32()` method stores a signed 32-bit integer (long) value at the specified byte offset from the start of the `DataView`. */\n setInt32(byteOffset: i32, value: i32, littleEndian?: boolean): void;\n /** The `setInt64()` method stores a signed 64-bit integer (long long) value at the specified byte offset from the start of the `DataView`. */\n setInt64(byteOffset: i32, value: i64, littleEndian?: boolean): void;\n /** The `setUint8()` method stores an unsigned 8-bit integer (byte) value at the specified byte offset from the start of the `DataView`. */\n setUint8(byteOffset: i32, value: u8): void;\n /** The `setUint16()` method stores an unsigned 16-bit integer (unsigned short) value at the specified byte offset from the start of the `DataView`. */\n setUint16(byteOffset: i32, value: u16, littleEndian?: boolean): void;\n /** The `setUint32()` method stores an unsigned 32-bit integer (unsigned long) value at the specified byte offset from the start of the `DataView`. */\n setUint32(byteOffset: i32, value: u32, littleEndian?: boolean): void;\n /** The `setUint64()` method stores an unsigned 64-bit integer (unsigned long long) value at the specified byte offset from the start of the `DataView`. */\n setUint64(byteOffset: i32, value: u64, littleEndian?: boolean): void;\n /** Returns a string representation of DataView. */\n toString(): string;\n}\n\ninterface ArrayLike {\n length: i32;\n // [key: number]: T;\n}\n\n/** Interface for a typed view on an array buffer. */\ninterface ArrayBufferView {\n [key: number]: T;\n /** The {@link ArrayBuffer} referenced by this view. */\n readonly buffer: ArrayBuffer;\n /** The offset in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteOffset: i32;\n /** The length in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteLength: i32;\n}\n\n/* @internal */\ndeclare abstract class TypedArray implements ArrayBufferView {\n [key: number]: T;\n /** Number of bytes per element. */\n static readonly BYTES_PER_ELEMENT: usize;\n /** Constructs a new typed array. */\n constructor(length: i32);\n /** The {@link ArrayBuffer} referenced by this view. */\n readonly buffer: ArrayBuffer;\n /** The offset in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteOffset: i32;\n /** The length in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteLength: i32;\n /** The length (in elements). */\n readonly length: i32;\n /** Returns a new TypedArray of this type on the same ArrayBuffer from begin inclusive to end exclusive. */\n subarray(begin?: i32, end?: i32): this;\n /** The reduce() method applies a function against an accumulator and each value of the typed array (from left-to-right) has to reduce it to a single value. This method has the same algorithm as Array.prototype.reduce(). */\n reduce(\n callbackfn: (accumulator: W, value: T, index: i32, self: this) => W,\n initialValue: W,\n ): W;\n /** The reduceRight() method applies a function against an accumulator and each value of the typed array (from left-to-right) has to reduce it to a single value, starting from the end of the array. This method has the same algorithm as Array.prototype.reduceRight(). */\n reduceRight(\n callbackfn: (accumulator: W, value: T, index: i32, self: this) => W,\n initialValue: W,\n ): W;\n /** The some() method tests whether some element in the typed array passes the test implemented by the provided function. This method has the same algorithm as Array.prototype.some().*/\n some(callbackfn: (value: T, index: i32, self: this) => bool): bool;\n /** The map() method creates a new typed array with the results of calling a provided function on every element in this typed array. This method has the same algorithm as Array.prototype.map().*/\n map(callbackfn: (value: T, index: i32, self: this) => T): this;\n /** The sort() method sorts the elements of a typed array numerically in place and returns the typed array. This method has the same algorithm as Array.prototype.sort(), except that sorts the values numerically instead of as strings. TypedArray is one of the typed array types here. */\n sort(callback?: (a: T, b: T) => i32): this;\n /** The fill() method fills all the elements of a typed array from a start index to an end index with a static value. This method has the same algorithm as Array.prototype.fill(). */\n fill(value: T, start?: i32, end?: i32): this;\n /** The findIndex() method returns an index in the typed array, if an element in the typed array satisfies the provided testing function. Otherwise -1 is returned. See also the find() [not implemented] method, which returns the value of a found element in the typed array instead of its index. */\n findIndex(callbackfn: (value: T, index: i32, self: this) => bool): i32;\n /** The every() method tests whether all elements in the typed array pass the test implemented by the provided function. This method has the same algorithm as Array.prototype.every(). */\n every(callbackfn: (value: T, index: i32, self: this) => bool): bool;\n /** The forEach() method executes a provided function once per array element. This method has the same algorithm as Array.prototype.forEach().*/\n forEach(callbackfn: (value: T, index: i32, self: this) => void): void;\n /** The reverse() method reverses a typed array in place. The first typed array element becomes the last and the last becomes the first. This method has the same algorithm as Array.prototype.reverse(). */\n reverse(): this;\n}\n\n/** An array of twos-complement 8-bit signed integers. */\ndeclare class Int8Array extends TypedArray {}\n/** An array of 8-bit unsigned integers. */\ndeclare class Uint8Array extends TypedArray {}\n/** A clamped array of 8-bit unsigned integers. */\ndeclare class Uint8ClampedArray extends TypedArray {}\n/** An array of twos-complement 16-bit signed integers. */\ndeclare class Int16Array extends TypedArray {}\n/** An array of 16-bit unsigned integers. */\ndeclare class Uint16Array extends TypedArray {}\n/** An array of twos-complement 32-bit signed integers. */\ndeclare class Int32Array extends TypedArray {}\n/** An array of 32-bit unsigned integers. */\ndeclare class Uint32Array extends TypedArray {}\n/** An array of twos-complement 64-bit signed integers. */\ndeclare class Int64Array extends TypedArray {}\n/** An array of 64-bit unsigned integers. */\ndeclare class Uint64Array extends TypedArray {}\n/** An array of 32-bit floating point numbers. */\ndeclare class Float32Array extends TypedArray {}\n/** An array of 64-bit floating point numbers. */\ndeclare class Float64Array extends TypedArray {}\n\n/** Class representing a sequence of values of type `T`. */\ndeclare class Array {\n\n /** Tests if a value is an array. */\n static isArray(value: any): value is Array;\n /** Creates a new array with at least the specified capacity and length zero. */\n static create(capacity?: i32): Array;\n\n [key: number]: T;\n /** Current length of the array. */\n length: i32;\n /** Constructs a new array. If length is greater than zero and T is a non-nullable reference, use `Array.create` instead.*/\n constructor(capacity?: i32);\n\n fill(value: T, start?: i32, end?: i32): this;\n every(callbackfn: (element: T, index: i32, array?: Array) => bool): bool;\n findIndex(predicate: (element: T, index: i32, array?: Array) => bool): i32;\n includes(searchElement: T, fromIndex?: i32): bool;\n indexOf(searchElement: T, fromIndex?: i32): i32;\n lastIndexOf(searchElement: T, fromIndex?: i32): i32;\n push(element: T): i32;\n concat(items: T[]): T[];\n copyWithin(target: i32, start: i32, end?: i32): this;\n pop(): T;\n forEach(callbackfn: (value: T, index: i32, array: Array) => void): void;\n map(callbackfn: (value: T, index: i32, array: Array) => U): Array;\n filter(callbackfn: (value: T, index: i32, array: Array) => bool): Array;\n reduce(callbackfn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U, initialValue: U): U;\n reduceRight(callbackfn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U, initialValue: U): U;\n shift(): T;\n some(callbackfn: (element: T, index: i32, array?: Array) => bool): bool;\n unshift(element: T): i32;\n slice(from: i32, to?: i32): Array;\n splice(start: i32, deleteCount?: i32): Array;\n sort(comparator?: (a: T, b: T) => i32): this;\n join(separator?: string): string;\n reverse(): T[];\n toString(): string;\n}\n\n/** Class representing a fixed sequence of values of type `T`. */\ndeclare class FixedArray {\n [key: number]: T;\n readonly length: i32;\n constructor(capacity?: i32);\n}\n\n/** Class representing a sequence of characters. */\ndeclare class String {\n\n static fromCharCode(ls: i32, hs?: i32): string;\n static fromCharCodes(arr: u16[]): string;\n static fromCodePoint(code: i32): string;\n static fromCodePoints(arr: i32[]): string;\n\n readonly length: i32;\n readonly lengthUTF8: i32;\n\n charAt(index: u32): string;\n charCodeAt(index: u32): u16;\n concat(other: string): string;\n endsWith(other: string): bool;\n indexOf(other: string, fromIndex?: i32): u32;\n lastIndexOf(other: string, fromIndex?: i32): i32;\n includes(other: string): bool;\n startsWith(other: string): bool;\n substr(start: u32, length?: u32): string;\n substring(start: u32, end?: u32): string;\n trim(): string;\n trimLeft(): string;\n trimRight(): string;\n trimStart(): string;\n trimEnd(): string;\n padStart(targetLength: i32, padString?: string): string;\n padEnd(targetLength: i32, padString?: string): string;\n repeat(count?: i32): string;\n replace(search: string, replacement: string): string;\n replaceAll(search: string, replacement: string): string;\n slice(beginIndex: i32, endIndex?: i32): string;\n split(separator?: string, limit?: i32): string[];\n toString(): string;\n static fromUTF8(ptr: usize, len: usize): string;\n toUTF8(): usize;\n}\n\n/** Class for representing a runtime error. Base class of all errors. */\ndeclare class Error {\n\n /** Error name. */\n name: string;\n\n /** Message provided on construction. */\n message: string;\n\n /** Stack trace. */\n stack?: string;\n\n /** Constructs a new error, optionally with a message. */\n constructor(message?: string);\n\n /** Method returns a string representing the specified Error class. */\n toString(): string;\n}\n\n/** Class for indicating an error when a value is not in the set or range of allowed values. */\ndeclare class RangeError extends Error { }\n\n/** Class for indicating an error when a value is not of the expected type. */\ndeclare class TypeError extends Error { }\n\n/** Class for indicating an error when trying to interpret syntactically invalid code. */\ndeclare class SyntaxError extends Error { }\n\ninterface Boolean {}\ninterface Function {}\ninterface IArguments {}\ninterface Number {}\ninterface Object {}\ninterface RegExp {}\n\ndeclare class Map {\n readonly size: i32;\n has(key: K): bool;\n set(key: K, value: V): void;\n get(key: K): V;\n delete(key: K): bool;\n clear(): void;\n keys(): K[]; // preliminary\n values(): V[]; // preliminary\n toString(): string;\n}\n\ndeclare class Set {\n readonly size: i32;\n has(value: K): bool;\n add(value: K): void;\n delete(value: K): bool;\n clear(): void;\n values(): K[]; // preliminary\n toString(): string;\n}\n\ninterface SymbolConstructor {\n readonly hasInstance: symbol;\n readonly isConcatSpreadable: symbol;\n readonly isRegExp: symbol;\n readonly iterator: symbol;\n readonly match: symbol;\n readonly replace: symbol;\n readonly search: symbol;\n readonly species: symbol;\n readonly split: symbol;\n readonly toPrimitive: symbol;\n readonly toStringTag: symbol;\n readonly unscopables: symbol;\n (description?: string | null): symbol;\n for(key: string): symbol;\n keyFor(sym: symbol): string | null;\n}\n\ndeclare const Symbol: SymbolConstructor;\n\ninterface IMath {\n /** The base of natural logarithms, e, approximately 2.718. */\n readonly E: T;\n /** The natural logarithm of 2, approximately 0.693. */\n readonly LN2: T;\n /** The natural logarithm of 10, approximately 2.302. */\n readonly LN10: T;\n /** The base 2 logarithm of e, approximately 1.442. */\n readonly LOG2E: T;\n /** The base 10 logarithm of e, approximately 0.434. */\n readonly LOG10E: T;\n /** The ratio of the circumference of a circle to its diameter, approximately 3.14159. */\n readonly PI: T;\n /** The square root of 1/2, approximately 0.707. */\n readonly SQRT1_2: T;\n /** The square root of 2, approximately 1.414. */\n readonly SQRT2: T;\n /** Returns the absolute value of `x`. */\n abs(x: T): T;\n /** Returns the arccosine (in radians) of `x`. */\n acos(x: T): T;\n /** Returns the hyperbolic arc-cosine of `x`. */\n acosh(x: T): T;\n /** Returns the arcsine (in radians) of `x`. */\n asin(x: T): T;\n /** Returns the hyperbolic arcsine of `x`. */\n asinh(x: T): T;\n /** Returns the arctangent (in radians) of `x`. */\n atan(x: T): T;\n /** Returns the arctangent of the quotient of its arguments. */\n atan2(y: T, x: T): T;\n /** Returns the hyperbolic arctangent of `x`. */\n atanh(x: T): T;\n /** Returns the cube root of `x`. */\n cbrt(x: T): T;\n /** Returns the smallest integer greater than or equal to `x`. */\n ceil(x: T): T;\n /** Returns the number of leading zero bits in the 32-bit binary representation of `x`. */\n clz32(x: T): T;\n /** Returns the cosine (in radians) of `x`. */\n cos(x: T): T;\n /** Returns the hyperbolic cosine of `x`. */\n cosh(x: T): T;\n /** Returns e to the power of `x`. */\n exp(x: T): T;\n /** Returns e to the power of `x`, minus 1. */\n expm1(x: T): T;\n /** Returns the largest integer less than or equal to `x`. */\n floor(x: T): T;\n /** Returns the nearest 32-bit single precision float representation of `x`. */\n fround(x: T): T;\n /** Returns the square root of the sum of squares of its arguments. */\n hypot(value1: T, value2: T): T; // TODO: rest\n /** Returns the result of the C-like 32-bit multiplication of `a` and `b`. */\n imul(a: T, b: T): T;\n /** Returns the natural logarithm (base e) of `x`. */\n log(x: T): T;\n /** Returns the base 10 logarithm of `x`. */\n log10(x: T): T;\n /** Returns the natural logarithm (base e) of 1 + `x`. */\n log1p(x: T): T;\n /** Returns the base 2 logarithm of `x`. */\n log2(x: T): T;\n /** Returns the largest-valued number of its arguments. */\n max(value1: T, value2: T): T; // TODO: rest\n /** Returns the lowest-valued number of its arguments. */\n min(value1: T, value2: T): T; // TODO: rest\n /** Returns `base` to the power of `exponent`. */\n pow(base: T, exponent: T): T;\n /** Returns a pseudo-random number in the range from 0.0 inclusive up to but not including 1.0. */\n random(): T;\n /** Returns the value of `x` rounded to the nearest integer. */\n round(x: T): T;\n /** Returns the sign of `x`, indicating whether the number is positive, negative or zero. */\n sign(x: T): T;\n /** Returns whether the sign bit of `x` is set. */\n signbit(x: T): bool;\n /** Returns the sine of `x`. */\n sin(x: T): T;\n /** Returns the hyperbolic sine of `x`. */\n sinh(x: T): T;\n /** Returns the square root of `x`. */\n sqrt(x: T): T;\n /** Returns the tangent of `x`. */\n tan(x: T): T;\n /** Returns the hyperbolic tangent of `x`. */\n tanh(x: T): T;\n /** Returns the integer part of `x` by removing any fractional digits. */\n trunc(x: T): T;\n}\n\ninterface INativeMath extends IMath {\n /** Contains sin value produced after Math/Mathf.sincos */\n sincos_sin: T;\n /** Contains cos value produced after Math/Mathf.sincos */\n sincos_cos: T;\n /** Seeds the random number generator. */\n seedRandom(value: i64): void;\n /** Returns the floating-point remainder of `x / y` (rounded towards zero). */\n mod(x: T, y: T): T;\n /** Returns the floating-point remainder of `x / y` (rounded to nearest). */\n rem(x: T, y: T): T;\n /** Returns sin and cos simultaneously for same angle. Results stored to `sincos_s32/64` and `sincos_c32/64` globals */\n sincos(x: T): void;\n}\n\n/** Double precision math imported from JavaScript. */\ndeclare const JSMath: IMath;\n/** Double precision math implemented natively. */\ndeclare const NativeMath: INativeMath;\n/** Single precision math implemented natively. */\ndeclare const NativeMathf: INativeMath;\n/** Alias of {@link NativeMath} or {@link JSMath} respectively. Defaults to `NativeMath`. */\ndeclare const Math: IMath;\n/** Alias of {@link NativeMathf} or {@link JSMath} respectively. Defaults to `NativeMathf`. */\ndeclare const Mathf: IMath;\n\ndeclare class Date {\n /** Returns the UTC timestamp in milliseconds of the specified date. */\n static UTC(\n year: i32,\n month: i32,\n day: i32,\n hour: i32,\n minute: i32,\n second: i32,\n millisecond: i32\n ): i64;\n /** Returns the current UTC timestamp in milliseconds. */\n static now(): i64;\n /** Constructs a new date object from an UTC timestamp in milliseconds. */\n constructor(value: i64);\n /** Returns the UTC timestamp of this date in milliseconds. */\n getTime(): i64;\n /** Sets the UTC timestamp of this date in milliseconds. */\n setTime(value: i64): i64;\n}\n\n/** Environmental tracing function for debugging purposes. */\ndeclare function trace(msg: string, n?: i32, a0?: f64, a1?: f64, a2?: f64, a3?: f64, a4?: f64): void;\n\n// Decorators\n\ninterface TypedPropertyDescriptor {\n configurable?: boolean;\n enumerable?: boolean;\n writable?: boolean;\n value?: T;\n get?(): T;\n set?(value: T): void;\n}\n\n/** Annotates a method as a binary operator overload for the specified `token`. */\ndeclare function operator(token:\n "[]" | "[]=" | "{}" | "{}=" | "==" | "!=" | ">" | "<" | "<=" | ">=" |\n ">>" | ">>>" | "<<" | "&" | "|" | "^" | "+" | "-" | "*" | "**" | "/" | "%"\n): (\n target: any,\n propertyKey: string,\n descriptor: TypedPropertyDescriptor\n) => TypedPropertyDescriptor | void;\n\ndeclare namespace operator {\n /** Annotates a method as a binary operator overload for the specified `token`. */\n export function binary(token:\n "[]" | "[]=" | "{}" | "{}=" | "==" | "!=" | ">" | "<" | "<=" | ">=" |\n ">>" | ">>>" | "<<" | "&" | "|" | "^" | "+" | "-" | "*" | "**" | "/" | "%"\n ): (\n target: any,\n propertyKey: string,\n descriptor: TypedPropertyDescriptor\n ) => TypedPropertyDescriptor | void;\n /** Annotates a method as an unary prefix operator overload for the specified `token`. */\n export function prefix(token: "!" | "~" | "+" | "-" | "++" | "--"): (\n target: any,\n propertyKey: string,\n descriptor: TypedPropertyDescriptor\n ) => TypedPropertyDescriptor | void;\n /** Annotates a method as an unary postfix operator overload for the specified `token`. */\n export function postfix(token: "++" | "--"): (\n target: any,\n propertyKey: string,\n descriptor: TypedPropertyDescriptor\n ) => TypedPropertyDescriptor | void;\n}\n\n/** Annotates an element as a program global. */\ndeclare function global(...args: any[]): any;\n\n/** Annotates a class as being unmanaged with limited capabilities. */\ndeclare function unmanaged(constructor: Function): void;\n\n/** Annotates a class as being sealed / non-derivable. */\ndeclare function sealed(constructor: Function): void;\n\n/** Annotates a method, function or constant global as always inlined. */\ndeclare function inline(...args: any[]): any;\n\n/** Annotates a method, function or constant global as unsafe. */\ndeclare function unsafe(...args: any[]): any;\n\n/** Annotates an explicit external name of a function or global. */\ndeclare function external(...args: any[]): any;\n\n/** Annotates a global for lazy compilation. */\ndeclare function lazy(...args: any[]): any;\n\n/** Annotates a function as the explicit start function. */\ndeclare function start(...args: any[]): any;\n',portable:"/**\n * Environment definitions for compiling AssemblyScript to JavaScript using tsc.\n *\n * Note that semantic differences require additional explicit conversions for full compatibility.\n * For example, when casting an i32 to an u8, doing `(someI32 & 0xff)` will yield the same\n * result when compiling to WebAssembly or JS while `someI32` alone does nothing in JS.\n *\n * Note that i64's are not portable (JS numbers are IEEE754 doubles with a maximum safe integer\n * value of 2^53-1) and instead require a compatibility layer to work in JS as well, as for example\n * {@link glue/js/i64} respectively {@link glue/wasm/i64}.\n *\n * @module std/portable\n *//***/\n\n/// \n\n// Types\n\ndeclare type bool = boolean;\ndeclare type i8 = number;\ndeclare type i16 = number;\ndeclare type i32 = number;\ndeclare type isize = number;\ndeclare type u8 = number;\ndeclare type u16 = number;\ndeclare type u32 = number;\ndeclare type usize = number;\ndeclare type f32 = number;\ndeclare type f64 = number;\n\n// Compiler hints\n\n/** Compiler target. 0 = JS, 1 = WASM32, 2 = WASM64. */\ndeclare const ASC_TARGET: i32;\n/** Provided noAssert option. */\ndeclare const ASC_NO_ASSERT: bool;\n/** Provided memoryBase option. */\ndeclare const ASC_MEMORY_BASE: i32;\n/** Provided optimizeLevel option. */\ndeclare const ASC_OPTIMIZE_LEVEL: i32;\n/** Provided shrinkLevel option. */\ndeclare const ASC_SHRINK_LEVEL: i32;\n/** Whether the mutable global feature is enabled. */\ndeclare const ASC_FEATURE_MUTABLE_GLOBAL: bool;\n/** Whether the sign extension feature is enabled. */\ndeclare const ASC_FEATURE_SIGN_EXTENSION: bool;\n\n// Builtins\n\n/** Performs the sign-agnostic count leading zero bits operation on a 32-bit integer. All zero bits are considered leading if the value is zero. */\ndeclare function clz(value: T): T;\n/** Performs the sign-agnostic count tailing zero bits operation on a 32-bit integer. All zero bits are considered trailing if the value is zero. */\ndeclare function ctz(value: T): T;\n/** Performs the sign-agnostic count number of one bits operation on a 32-bit integer. */\ndeclare function popcnt(value: T): T;\n/** Performs the sign-agnostic rotate left operation on a 32-bit integer. */\ndeclare function rotl(value: T, shift: T): T;\n/** Performs the sign-agnostic rotate right operation on a 32-bit integer. */\ndeclare function rotr(value: T, shift: T): T;\n/** Computes the absolute value of an integer or float. */\ndeclare function abs(value: T): T;\n/** Determines the maximum of two integers or floats. If either operand is `NaN`, returns `NaN`. */\ndeclare function max(left: T, right: T): T;\n/** Determines the minimum of two integers or floats. If either operand is `NaN`, returns `NaN`. */\ndeclare function min(left: T, right: T): T;\n/** Composes a 32-bit or 64-bit float from the magnitude of `x` and the sign of `y`. */\ndeclare function copysign(x: T, y: T): T;\n/** Performs the ceiling operation on a 32-bit or 64-bit float. */\ndeclare function ceil(value: T): T;\n/** Performs the floor operation on a 32-bit or 64-bit float. */\ndeclare function floor(value: T): T;\n/** Rounds to the nearest integer tied to even of a 32-bit or 64-bit float. */\ndeclare function nearest(value: T): T;\n/** Selects one of two pre-evaluated values depending on the condition. */\ndeclare function select(ifTrue: T, ifFalse: T, condition: bool): T;\n/** Calculates the square root of a 32-bit or 64-bit float. */\ndeclare function sqrt(value: T): T;\n/** Rounds to the nearest integer towards zero of a 32-bit or 64-bit float. */\ndeclare function trunc(value: T): T;\n/** Loads a value of the specified type from memory. Type must be `u8`. */\ndeclare function load(ptr: usize, constantOffset?: usize): T;\n/** Stores a value of the specified type to memory. Type must be `u8`. */\ndeclare function store(ptr: usize, value: T, constantOffset?: usize): void;\n/** Emits an unreachable operation that results in a runtime error when executed. */\ndeclare function unreachable(): any; // sic\n\n/** NaN (not a number) as a 32-bit or 64-bit float depending on context. */\ndeclare const NaN: f32 | f64;\n/** Positive infinity as a 32-bit or 64-bit float depending on context. */\ndeclare const Infinity: f32 | f64;\n/** Changes the type of any value of `usize` kind to another one of `usize` kind. Useful for casting class instances to their pointer values and vice-versa. Beware that this is unsafe.*/\ndeclare function changetype(value: any): T;\n/** Explicitly requests no bounds checks on the provided expression. Useful for array accesses. */\ndeclare function unchecked(value: T): T;\n/** Tests if a 32-bit or 64-bit float is `NaN`. */\ndeclare function isNaN(value: T): bool;\n/** Tests if a 32-bit or 64-bit float is finite, that is not `NaN` or +/-`Infinity`. */\ndeclare function isFinite(value: T): bool;\n/** Tests if the specified value is a valid integer. Can't distinguish an integer from an integral float. */\ndeclare function isInteger(value: any): value is number;\n/** Tests if the specified value is a valid float. Can't distinguish a float from an integer. */\ndeclare function isFloat(value: any): value is number;\n/** Tests if the specified value is of a nullable reference type. */\ndeclare function isNullable(value: any): bool;\n/** Tests if the specified value is of a reference type. */\ndeclare function isReference(value: any): value is object | string;\n/** Tests if the specified value is of a function type */\ndeclare function isFunction(value: any): value is Function;\n/** Tests if the specified value can be used as a string. */\ndeclare function isString(value: any): value is string | String;\n/** Tests if the specified value can be used as an array. */\ndeclare function isArray(value: any): value is Array;\n/** Tests if the specified type *or* expression can be used as an array like object. */\ndeclare function isArrayLike(value: any): value is ArrayLike;\n/** Tests if the specified expression resolves to a defined element. */\ndeclare function isDefined(expression: any): bool;\n/** Tests if the specified expression evaluates to a constant value. */\ndeclare function isConstant(expression: any): bool;\n/** Traps if the specified value is not true-ish, otherwise returns the value. */\ndeclare function assert(isTrueish: T | null, message?: string): T;\n/** Parses an integer string to a 64-bit float. */\ndeclare function parseInt(str: string, radix?: i32): f64;\n/** Parses a floating point string to a 64-bit float. */\ndeclare function parseFloat(str: string): f64;\n/** Returns the 64-bit floating-point remainder of `x/y`. */\ndeclare function fmod(x: f64, y: f64): f64;\n/** Returns the 32-bit floating-point remainder of `x/y`. */\ndeclare function fmodf(x: f32, y: f32): f32;\n\n/** Converts any other numeric value to an 8-bit signed integer. */\ndeclare function i8(value: any): i8;\ndeclare namespace i8 {\n /** Smallest representable value. */\n export const MIN_VALUE: i8;\n /** Largest representable value. */\n export const MAX_VALUE: i8;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): i8;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): i8;\n}\n/** Converts any other numeric value to a 16-bit signed integer. */\ndeclare function i16(value: any): i16;\ndeclare namespace i16 {\n /** Smallest representable value. */\n export const MIN_VALUE: i16;\n /** Largest representable value. */\n export const MAX_VALUE: i16;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): i16;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): i16;\n}\n/** Converts any other numeric value to a 32-bit signed integer. */\ndeclare function i32(value: any): i32;\ndeclare namespace i32 {\n /** Smallest representable value. */\n export const MIN_VALUE: i32;\n /** Largest representable value. */\n export const MAX_VALUE: i32;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): i32;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): i32;\n}\n/** Converts any other numeric value to a 32-bit (in WASM32) respectivel 64-bit (in WASM64) signed integer. */\ndeclare function isize(value: any): isize;\ndeclare namespace isize {\n /** Smallest representable value. */\n export const MIN_VALUE: isize;\n /** Largest representable value. */\n export const MAX_VALUE: isize;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): isize;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): isize;\n}\n/** Converts any other numeric value to an 8-bit unsigned integer. */\ndeclare function u8(value: any): u8;\ndeclare namespace u8 {\n /** Smallest representable value. */\n export const MIN_VALUE: u8;\n /** Largest representable value. */\n export const MAX_VALUE: u8;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): u8;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): u8;\n}\n/** Converts any other numeric value to a 16-bit unsigned integer. */\ndeclare function u16(value: any): u16;\ndeclare namespace u16 {\n /** Smallest representable value. */\n export const MIN_VALUE: u16;\n /** Largest representable value. */\n export const MAX_VALUE: u16;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): u16;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): u16;\n}\n/** Converts any other numeric value to a 32-bit unsigned integer. */\ndeclare function u32(value: any): u32;\ndeclare namespace u32 {\n /** Smallest representable value. */\n export const MIN_VALUE: u32;\n /** Largest representable value. */\n export const MAX_VALUE: u32;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): u32;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): u32;\n}\n/** Converts any other numeric value to a 32-bit (in WASM32) respectivel 64-bit (in WASM64) unsigned integer. */\ndeclare function usize(value: any): isize;\ndeclare namespace usize {\n /** Smallest representable value. */\n export const MIN_VALUE: usize;\n /** Largest representable value. */\n export const MAX_VALUE: usize;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): usize;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): usize;\n}\n/** Converts any other numeric value to a 1-bit unsigned integer. */\ndeclare function bool(value: any): bool;\ndeclare namespace bool {\n /** Smallest representable value. */\n export const MIN_VALUE: bool;\n /** Largest representable value. */\n export const MAX_VALUE: bool;\n}\n/** Converts any other numeric value to a 32-bit float. */\ndeclare function f32(value: any): f32;\ndeclare namespace f32 {\n /** Smallest representable value. */\n export const MIN_VALUE: f32;\n /** Largest representable value. */\n export const MAX_VALUE: f32;\n /** Smallest normalized positive value. */\n export const MIN_POSITIVE_VALUE: f32;\n /** Smallest safely representable integer value. */\n export const MIN_SAFE_INTEGER: f32;\n /** Largest safely representable integer value. */\n export const MAX_SAFE_INTEGER: f32;\n /** Difference between 1 and the smallest representable value greater than 1. */\n export const EPSILON: f32;\n /** Returns a boolean value that indicates whether a value is the reserved value NaN (not a number). */\n export function isNaN(value: f32): bool;\n /** Returns true if passed value is finite. */\n export function isFinite(value: f32): bool;\n /** Returns true if the value passed is a safe integer. */\n export function isSafeInteger(value: f32): bool;\n /** Returns true if the value passed is an integer, false otherwise. */\n export function isInteger(value: f32): bool;\n /** Converts a string to a floating-point number. */\n export function parseFloat(string: string): f32;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): f32;\n}\n/** Converts any other numeric value to a 64-bit float. */\ndeclare function f64(value: any): f64;\ndeclare namespace f64 {\n /** Smallest representable value. */\n export const MIN_VALUE: f64;\n /** Largest representable value. */\n export const MAX_VALUE: f64;\n /** Smallest normalized positive value. */\n export const MIN_POSITIVE_VALUE: f64;\n /** Smallest safely representable integer value. */\n export const MIN_SAFE_INTEGER: f64;\n /** Largest safely representable integer value. */\n export const MAX_SAFE_INTEGER: f64;\n /** Difference between 1 and the smallest representable value greater than 1. */\n export const EPSILON: f64;\n /** Returns a boolean value that indicates whether a value is the reserved value NaN (not a number). */\n export function isNaN(value: f32): bool;\n /** Returns true if passed value is finite. */\n export function isFinite(value: f32): bool;\n /** Returns true if the value passed is a safe integer. */\n export function isSafeInteger(value: f64): bool;\n /** Returns true if the value passed is an integer, false otherwise. */\n export function isInteger(value: f64): bool;\n /** Converts a string to a floating-point number. */\n export function parseFloat(string: string): f64;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): f64;\n}\n\n// Polyfills\n\n/** [Polyfill] Performs the sign-agnostic reverse bytes **/\ndeclare function bswap(value: T): T;\n/** [Polyfill] Performs the sign-agnostic reverse bytes only for last 16-bit **/\ndeclare function bswap16(value: T): T;\n\n// Standard library\n\n/** Memory operations. */\ndeclare namespace memory {\n /** Allocates a chunk of memory of the specified size and returns a pointer to it. */\n function allocate(size: usize): usize;\n /** Disposes a chunk of memory by its pointer. */\n function free(ptr: usize): void;\n /** Copies n bytes from the specified source to the specified destination in memory. These regions may overlap. */\n function copy(dst: usize, src: usize, n: usize): void;\n /** Fills size bytes from from the specified destination by same value in memory. */\n function fill(dst: usize, value: u8, size: usize): void;\n /** Resets the allocator to its initial state, if supported. */\n function reset(): void;\n}\n\n/** Class representing a generic, fixed-length raw binary data buffer. */\ndeclare class ArrayBuffer {\n /** The size, in bytes, of the array. */\n readonly byteLength: i32;\n /** Returns true if value is one of the ArrayBuffer views, such as typed array or a DataView **/\n static isView(value: T): bool;\n /** Constructs a new array buffer of the given length in bytes. */\n constructor(length: i32);\n /** Returns a copy of this array buffer's bytes from begin, inclusive, up to end, exclusive. */\n slice(begin?: i32, end?: i32): ArrayBuffer;\n /** Returns a string representation of ArrayBuffer. */\n toString(): string;\n}\n\n/** The `DataView` view provides a low-level interface for reading and writing multiple number types in a binary `ArrayBuffer`, without having to care about the platform's endianness. */\ndeclare class DataView {\n /** The `buffer` accessor property represents the `ArrayBuffer` or `SharedArrayBuffer` referenced by the `DataView` at construction time. */\n readonly buffer: ArrayBuffer;\n /** The `byteLength` accessor property represents the length (in bytes) of this view from the start of its `ArrayBuffer` or `SharedArrayBuffer`. */\n readonly byteLength: i32;\n /** The `byteOffset` accessor property represents the offset (in bytes) of this view from the start of its `ArrayBuffer` or `SharedArrayBuffer`. */\n readonly byteOffset: i32;\n /** Constructs a new `DataView` with the given properties */\n constructor(buffer: ArrayBuffer, byteOffset?: i32, byteLength?: i32);\n /** The `getFloat32()` method gets a signed 32-bit float (float) at the specified byte offset from the start of the `DataView`. */\n getFloat32(byteOffset: i32, littleEndian?: boolean): f32;\n /** The `getFloat64()` method gets a signed 64-bit float (double) at the specified byte offset from the start of the `DataView`. */\n getFloat64(byteOffset: i32, littleEndian?: boolean): f64;\n /** The `getInt8()` method gets a signed 8-bit integer (byte) at the specified byte offset from the start of the `DataView`. */\n getInt8(byteOffset: i32): i8;\n /** The `getInt16()` method gets a signed 16-bit integer (short) at the specified byte offset from the start of the `DataView`. */\n getInt16(byteOffset: i32, littleEndian?: boolean): i16;\n /** The `getInt32()` method gets a signed 32-bit integer (long) at the specified byte offset from the start of the `DataView`. */\n getInt32(byteOffset: i32, littleEndian?: boolean): i32;\n /** The `getUint8()` method gets an unsigned 8-bit integer (unsigned byte) at the specified byte offset from the start of the `DataView`. */\n getUint8(byteOffset: i32): u8;\n /** The `getUint16()` method gets an unsigned 16-bit integer (unsigned short) at the specified byte offset from the start of the `DataView`. */\n getUint16(byteOffset: i32, littleEndian?: boolean): u16;\n /** The `getUint32()` method gets an unsigned 32-bit integer (unsigned long) at the specified byte offset from the start of the `DataView`. */\n getUint32(byteOffset: i32, littleEndian?: boolean): u32;\n /** The `setFloat32()` method stores a signed 32-bit float (float) value at the specified byte offset from the start of the `DataView`. */\n setFloat32(byteOffset: i32, value: f32, littleEndian?: boolean): void;\n /** The `setFloat64()` method stores a signed 64-bit float (double) value at the specified byte offset from the start of the `DataView`. */\n setFloat64(byteOffset: i32, value: f64, littleEndian?: boolean): void;\n /** The `setInt8()` method stores a signed 8-bit integer (byte) value at the specified byte offset from the start of the `DataView`. */\n setInt8(byteOffset: i32, value: i8): void;\n /** The `setInt16()` method stores a signed 16-bit integer (short) value at the specified byte offset from the start of the `DataView`. */\n setInt16(byteOffset: i32, value: i16, littleEndian?: boolean): void;\n /** The `setInt32()` method stores a signed 32-bit integer (long) value at the specified byte offset from the start of the `DataView`. */\n setInt32(byteOffset: i32, value: i32, littleEndian?: boolean): void;\n /** The `setUint8()` method stores an unsigned 8-bit integer (byte) value at the specified byte offset from the start of the `DataView`. */\n setUint8(byteOffset: i32, value: u8): void;\n /** The `setUint16()` method stores an unsigned 16-bit integer (unsigned short) value at the specified byte offset from the start of the `DataView`. */\n setUint16(byteOffset: i32, value: u16, littleEndian?: boolean): void;\n /** The `setUint32()` method stores an unsigned 32-bit integer (unsigned long) value at the specified byte offset from the start of the `DataView`. */\n setUint32(byteOffset: i32, value: u32, littleEndian?: boolean): void;\n /** Returns a string representation of DataView. */\n toString(): string;\n}\n\ndeclare class Array {\n\n static isArray(value: any): value is Array;\n static create(capacity?: i32): Array;\n\n [key: number]: T;\n length: i32;\n constructor(capacity?: i32);\n\n fill(value: T, start?: i32, end?: i32): this;\n every(callbackfn: (element: T, index: i32, array?: Array) => bool): bool;\n findIndex(predicate: (element: T, index: i32, array?: Array) => bool): i32;\n includes(searchElement: T, fromIndex?: i32): bool;\n indexOf(searchElement: T, fromIndex?: i32): i32;\n lastIndexOf(searchElement: T, fromIndex?: i32): i32;\n push(element: T): i32;\n concat(items: T[]): T[];\n copyWithin(target: i32, start: i32, end?: i32): this;\n pop(): T;\n forEach(callbackfn: (value: T, index: i32, array: Array) => void): void;\n map(callbackfn: (value: T, index: i32, array: Array) => U): Array;\n filter(callbackfn: (value: T, index: i32, array: Array) => bool): Array;\n reduce(callbackfn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U, initialValue: U): U;\n reduceRight(callbackfn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U, initialValue: U): U;\n shift(): T;\n some(callbackfn: (element: T, index: i32, array?: Array) => bool): bool;\n unshift(element: T): i32;\n slice(from?: i32, to?: i32): Array;\n splice(start: i32, deleteCount?: i32): Array;\n sort(comparator?: (a: T, b: T) => i32): this;\n join(separator?: string): string;\n reverse(): T[];\n toString(): string;\n}\n\ndeclare class Uint8Array extends Array {}\ndeclare class Uint8ClampedArray extends Array {}\ndeclare class Uint16Array extends Array {}\ndeclare class Uint32Array extends Array {}\ndeclare class Int8Array extends Array {}\ndeclare class Int16Array extends Array {}\ndeclare class Int32Array extends Array {}\ndeclare class Float32Array extends Array {}\ndeclare class Float64Array extends Array {}\n\ninterface ArrayLike {\n length: i32;\n [key: number]: T;\n}\n\n/** Interface for a typed view on an array buffer. */\ninterface ArrayBufferView {\n [key: number]: T;\n /** The {@link ArrayBuffer} referenced by this view. */\n readonly buffer: ArrayBuffer;\n /** The offset in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteOffset: i32;\n /** The length in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteLength: i32;\n}\n\ndeclare class String {\n\n static fromCharCode(ls: i32, hs?: i32): string;\n static fromCharCodes(arr: u16[]): string;\n static fromCodePoint(code: i32): string;\n static fromCodePoints(arr: i32[]): string;\n\n readonly length: i32;\n\n private constructor();\n\n charAt(index: i32): string;\n charCodeAt(index: i32): i32;\n concat(other: string): string;\n indexOf(other: string, fromIndex?: i32): i32;\n lastIndexOf(other: string, fromIndex?: i32): i32;\n includes(other: string): bool;\n startsWith(other: string): bool;\n endsWith(other: string): bool;\n substr(start: u32, length?: u32): string;\n substring(from: i32, to?: i32): string;\n trim(): string;\n trimLeft(): string;\n trimRight(): string;\n trimStart(): string;\n trimEnd(): string;\n padStart(targetLength: i32, padString?: string): string;\n padEnd(targetLength: i32, padString?: string): string;\n replace(search: string, replacement: string): string;\n replaceAll(search: string, replacement: string): string;\n repeat(count?: i32): string;\n slice(beginIndex: i32, endIndex?: i32): string;\n split(separator?: string, limit?: i32): string[];\n toString(): string;\n}\n\ninterface Boolean {}\n\ndeclare class Number {\n private constructor();\n toString(radix?: i32): string;\n}\n\ninterface Object {}\n\ninterface Function {}\n\ninterface RegExp {}\n\ninterface IArguments {}\n\n/** Class for representing a runtime error. Base class of all errors. */\ndeclare class Error {\n\n /** Error name. */\n name: string;\n\n /** Message provided on construction. */\n message: string;\n\n /** Stack trace. */\n stack?: string;\n\n /** Constructs a new error, optionally with a message. */\n constructor(message?: string);\n\n /** Method returns a string representing the specified Error class. */\n toString(): string;\n}\n\n/** Class for indicating an error when a value is not in the set or range of allowed values. */\ndeclare class RangeError extends Error { }\n\n/** Class for indicating an error when a value is not of the expected type. */\ndeclare class TypeError extends Error { }\n\n/** Class for indicating an error when trying to interpret syntactically invalid code. */\ndeclare class SyntaxError extends Error { }\n\ndeclare class Set {\n constructor(entries?: T[]);\n readonly size: i32;\n has(value: T): bool;\n add(value: T): void;\n delete(value: T): bool;\n clear(): void;\n toString(): string;\n [Symbol.iterator](): Iterator;\n}\n\ndeclare class Map {\n constructor(entries?: [K, V][]);\n readonly size: i32;\n set(key: K, value: V): void;\n has(key: K): bool;\n get(key: K): V | null;\n clear(): void;\n entries(): Iterable<[K, V]>;\n keys(): Iterable;\n values(): Iterable;\n delete(key: K): bool;\n toString(): string;\n [Symbol.iterator](): Iterator<[K,V]>;\n}\n\ninterface SymbolConstructor {\n readonly hasInstance: symbol;\n readonly isConcatSpreadable: symbol;\n readonly isRegExp: symbol;\n readonly iterator: symbol;\n readonly match: symbol;\n readonly replace: symbol;\n readonly search: symbol;\n readonly species: symbol;\n readonly split: symbol;\n readonly toPrimitive: symbol;\n readonly toStringTag: symbol;\n readonly unscopables: symbol;\n (description?: string | null): symbol;\n for(key: string): symbol;\n keyFor(sym: symbol): string | null;\n}\ndeclare const Symbol: SymbolConstructor;\n\ninterface Iterable {\n [Symbol.iterator](): Iterator;\n}\n\ninterface Iterator {}\n\ninterface IMath {\n readonly E: f64;\n readonly LN2: f64;\n readonly LN10: f64;\n readonly LOG2E: f64;\n readonly LOG10E: f64;\n readonly PI: f64;\n readonly SQRT1_2: f64;\n readonly SQRT2: f64;\n\n sincos_sin: f64;\n sincos_cos: f64;\n\n abs(x: f64): f64;\n acos(x: f64): f64;\n acosh(x: f64): f64;\n asin(x: f64): f64;\n asinh(x: f64): f64;\n atan(x: f64): f64;\n atan2(y: f64, x: f64): f64;\n atanh(x: f64): f64;\n cbrt(x: f64): f64;\n ceil(x: f64): f64;\n clz32(x: f64): i32;\n cos(x: f64): f64;\n cosh(x: f64): f64;\n exp(x: f64): f64;\n expm1(x: f64): f64;\n floor(x: f64): f64;\n fround(x: f64): f32;\n hypot(value1: f64, value2: f64): f64; // TODO: see std/math\n imul(a: f64, b: f64): i32;\n log(x: f64): f64;\n log10(x: f64): f64;\n log1p(x: f64): f64;\n log2(x: f64): f64;\n max(value1: f64, value2: f64): f64; // TODO: see std/math\n min(value1: f64, value2: f64): f64; // TODO: see std/math\n pow(base: f64, exponent: f64): f64;\n random(): f64;\n round(x: f64): f64;\n sign(x: f64): f64;\n signbit(x: f64): bool;\n sin(x: f64): f64;\n sincos(x: f64): f64;\n sinh(x: f64): f64;\n sqrt(x: f64): f64;\n tan(x: f64): f64;\n tanh(x: f64): f64;\n trunc(x: f64): f64;\n}\n\ndeclare const Math: IMath;\ndeclare const Mathf: IMath;\ndeclare const JSMath: IMath;\n\ndeclare class Date {\n /** Returns the UTC timestamp in milliseconds of the specified date. */\n static UTC(\n year: i32,\n month: i32,\n day: i32,\n hour: i32,\n minute: i32,\n second: i32,\n millisecond: i32\n ): number;\n /** Returns the current UTC timestamp in milliseconds. */\n static now(): number;\n /** Constructs a new date object from an UTC timestamp in milliseconds. */\n constructor(value: number);\n /** Returns the UTC timestamp of this date in milliseconds. */\n getTime(): number;\n /** Sets the UTC timestamp of this date in milliseconds. */\n setTime(value: number): number;\n}\n\ndeclare namespace console {\n /** @deprecated */\n function log(message: string): void;\n}\n\n/** Annotates a class as being unmanaged with limited capabilities. */\ndeclare function unmanaged(constructor: Function): void;\n"}):(()=>{const n=path.join(".","..","std");return{assembly:fs.readFileSync(path.join(n,"assembly","index.d.ts"),"utf8"),portable:fs.readFileSync(path.join(n,"portable","index.d.ts"),"utf8")}})(),exports.compileString=(n,e)=>{"string"==typeof n&&(n={"input.ts":n});const t=Object.create({stdout:createMemoryStream(),stderr:createMemoryStream()});var r=["--binaryFile","binary","--textFile","text"];return Object.keys(e||{}).forEach(n=>{var t=e[n];Array.isArray(t)?t.forEach(e=>r.push("--"+n,String(e))):r.push("--"+n,String(t))}),exports.main(r.concat(Object.keys(n)),{stdout:t.stdout,stderr:t.stderr,readFile:e=>n.hasOwnProperty(e)?n[e]:null,writeFile:(n,e)=>t[n]=e,listFiles:()=>[]}),t},exports.main=function(n,e,t){"function"==typeof e?(t=e,e={}):e||(e={});const r=e.stdout||process.stdout,i=e.stderr||process.stderr,o=e.readFile||z,a=e.writeFile||F,s=e.listFiles||S,l=e.stats||createStats();if(!r)throw Error("'options.stdout' must be specified");if(!i)throw Error("'options.stderr' must be specified");const u=optionsUtil.parse(n,exports.options),f=u.options;if(n=u.arguments,f.noColors?colorsUtil.stdout.supported=colorsUtil.stderr.supported=!1:(colorsUtil.stdout=colorsUtil.from(r),colorsUtil.stderr=colorsUtil.from(i)),u.unknown.length&&u.unknown.forEach(n=>{i.write(colorsUtil.stderr.yellow("WARN: ")+"Unknown option '"+n+"'"+EOL)}),u.trailing.length&&i.write(colorsUtil.stderr.yellow("WARN: ")+"Unsupported trailing arguments: "+u.trailing.join(" ")+EOL),t||(t=function(n){var e=0;return n&&(i.write(colorsUtil.stderr.red("ERROR: ")+n.stack.replace(/^ERROR: /i,"")+EOL),e=1),e}),f.version)return r.write("Version "+exports.version+(isDev?"-dev":"")+EOL),t(null);if(f.help||!n.length){var c=f.help?r:i,d=f.help?colorsUtil.stdout:colorsUtil.stderr;return c.write([d.white("SYNTAX")," "+d.cyan("asc")+" [entryFile ...] [options]","",d.white("EXAMPLES")," "+d.cyan("asc")+" hello.ts"," "+d.cyan("asc")+" hello.ts -b hello.wasm -t hello.wat"," "+d.cyan("asc")+" hello1.ts hello2.ts -b -O > hello.wasm","",d.white("OPTIONS")].concat(optionsUtil.help(exports.options,24,EOL)).join(EOL)+EOL),t(null)}if(!fs.readFileSync){if(o===z)throw Error("'options.readFile' must be specified");if(a===F)throw Error("'options.writeFile' must be specified");if(s===S)throw Error("'options.listFiles' must be specified")}const p=f.baseDir?path.resolve(f.baseDir):".",h=[];f.transform&&f.transform.forEach(n=>h.push(__webpack_require__(12)(path.isAbsolute(n=n.trim())?n:path.join(process.cwd(),n))));var g=null;Object.keys(exports.libraryFiles).forEach(n=>{n.indexOf("/")>=0||(l.parseCount++,l.parseTime+=measure(()=>{g=assemblyscript.parseFile(exports.libraryFiles[n],exports.libraryPrefix+n+".ts",!1,g)}))});const x=[];if(f.lib){let n=f.lib;"string"==typeof n&&(n=n.split(",")),Array.prototype.push.apply(x,n.map(n=>n.trim()));for(let n=0,e=x.length;n{g=assemblyscript.parseFile(a,exports.libraryPrefix+i,!1,g)})}}}function v(){for(var n,e;null!=(n=g.nextFile());){if(e=null,n.startsWith(exports.libraryPrefix)){const t=n.substring(exports.libraryPrefix.length),r=n.substring(exports.libraryPrefix.length)+"/index";if(exports.libraryFiles.hasOwnProperty(t))e=exports.libraryFiles[t],n=exports.libraryPrefix+t+".ts";else if(exports.libraryFiles.hasOwnProperty(r))e=exports.libraryFiles[r],n=exports.libraryPrefix+r+".ts";else for(let i=0,a=x.length;i{assemblyscript.parseFile(e,n,!1,g)})}if(checkDiagnostics(g,i))return t(Error("Parse error"))}{let n=String(f.runtime),e="rt/index-"+n,r=exports.libraryFiles[e];if(null==r){if(null==(r=o((e=n)+".ts",p)))return t(Error("Runtime '"+n+"' not found."))}else e="~lib/"+e;l.parseCount++,l.parseTime+=measure(()=>{g=assemblyscript.parseFile(r,e,!0,g)})}for(let e=0,r=n.length;e{g=assemblyscript.parseFile(a,i,!0,g)})}{let n=v();if(n)return n}!function(n,...e){h.forEach(t=>{"function"==typeof t[n]&&t[n](...e)})}("afterParse",g);{let n=v();if(n)return n}const m=assemblyscript.finishParsing(g);var y=0,b=0;f.optimize&&(y=exports.defaultOptimizeLevel,b=exports.defaultShrinkLevel),"number"==typeof f.optimizeLevel&&(y=f.optimizeLevel),"number"==typeof f.shrinkLevel&&(b=f.shrinkLevel),y=Math.min(Math.max(y,0),3),b=Math.min(Math.max(b,0),2);const _=assemblyscript.createOptions();if(assemblyscript.setTarget(_,0),assemblyscript.setNoAssert(_,f.noAssert),assemblyscript.setImportMemory(_,f.importMemory),assemblyscript.setSharedMemory(_,f.sharedMemory),assemblyscript.setImportTable(_,f.importTable),assemblyscript.setExplicitStart(_,f.explicitStart),assemblyscript.setMemoryBase(_,f.memoryBase>>>0),assemblyscript.setSourceMap(_,null!=f.sourceMap),assemblyscript.setOptimizeLevelHints(_,y,b),assemblyscript.setGlobalAlias(_,"Math","NativeMath"),assemblyscript.setGlobalAlias(_,"Mathf","NativeMathf"),assemblyscript.setGlobalAlias(_,"abort","~lib/builtins/abort"),assemblyscript.setGlobalAlias(_,"trace","~lib/builtins/trace"),f.use){let n=f.use;for(let e=0,r=n.length;e{T=assemblyscript.compileProgram(m,_)})}catch(n){return t(n)}if(checkDiagnostics(g,i))return T&&T.dispose(),t(Error("Compile error"));if(f.validate&&(l.validateCount++,l.validateTime+=measure(()=>{if(!T.validate())return T.dispose(),t(Error("Validate error"))})),"clamp"===f.trapMode)l.optimizeCount++,l.optimizeTime+=measure(()=>{T.runPasses(["trap-mode-clamp"])});else if("js"===f.trapMode)l.optimizeCount++,l.optimizeTime+=measure(()=>{T.runPasses(["trap-mode-js"])});else if("allow"!==f.trapMode)return T.dispose(),t(Error("Unsupported trap mode"));(y>=3||b>=2)&&(y=4),T.setOptimizeLevel(y),T.setShrinkLevel(b),T.setDebugInfo(f.debug);var A=[];if(f.runPasses&&("string"==typeof f.runPasses&&(f.runPasses=f.runPasses.split(",")),f.runPasses.length&&f.runPasses.forEach(n=>{A.indexOf(n)<0&&A.push(n)})),(y>0||b>0)&&(l.optimizeCount++,l.optimizeTime+=measure(()=>{T.optimize()})),A.length&&(l.optimizeCount++,l.optimizeTime+=measure(()=>{T.runPasses(A.map(n=>n.trim()))})),!f.noEmit){let n=!1,e=!1;if(null!=f.outFile&&(/\.was?t$/.test(f.outFile)&&null==f.textFile?f.textFile=f.outFile:/\.js$/.test(f.outFile)&&null==f.asmjsFile?f.asmjsFile=f.outFile:null==f.binaryFile&&(f.binaryFile=f.outFile)),null!=f.binaryFile){let r,s=null!=f.sourceMap?f.sourceMap.length?f.sourceMap:path.basename(f.binaryFile)+".map":null;if(l.emitCount++,l.emitTime+=measure(()=>{r=T.toBinary(s)}),f.binaryFile.length?a(f.binaryFile,r.output,p):(I(r.output),n=!0),e=!0,null!=r.sourceMap)if(f.binaryFile.length){let n=JSON.parse(r.sourceMap);n.sourceRoot=exports.sourceMapRoot,n.sources.forEach((e,r)=>{let i=null;if(e.startsWith(exports.libraryPrefix)){let n=e.substring(exports.libraryPrefix.length).replace(/\.ts$/,"");if(exports.libraryFiles.hasOwnProperty(n))i=exports.libraryFiles[n];else for(let n=0,t=x.length;n{t=T.toAsmjs()}),a(f.asmjsFile,t,p)):n||(l.emitCount++,l.emitTime+=measure(()=>{t=T.toAsmjs()}),I(t),n=!0),e=!0}if(null!=f.idlFile){let t;f.idlFile.length?(l.emitCount++,l.emitTime+=measure(()=>{t=assemblyscript.buildIDL(m)}),a(f.idlFile,t,p)):n||(l.emitCount++,l.emitTime+=measure(()=>{t=assemblyscript.buildIDL(m)}),I(t),n=!0),e=!0}if(null!=f.tsdFile){let t;f.tsdFile.length?(l.emitCount++,l.emitTime+=measure(()=>{t=assemblyscript.buildTSD(m)}),a(f.tsdFile,t,p)):n||(l.emitCount++,l.emitTime+=measure(()=>{t=assemblyscript.buildTSD(m)}),I(t),n=!0),e=!0}if(null!=f.textFile||!e){let e;f.textFile&&f.textFile.length?(l.emitCount++,l.emitTime+=measure(()=>{e=T.toText()}),a(f.textFile,e,p)):n||(l.emitCount++,l.emitTime+=measure(()=>{e=T.toText()}),I(e))}}return T.dispose(),f.measure&&printStats(l,i),f.printrtti&&printRTTI(m,i),t(null);function z(n,e){try{let t;return l.readCount++,l.readTime+=measure(()=>{t=fs.readFileSync(path.join(e,n),{encoding:"utf8"})}),t}catch(n){return null}}function F(n,e,t){try{return l.writeCount++,l.writeTime+=measure(()=>{mkdirp(path.join(t,path.dirname(n))),"string"==typeof e?fs.writeFileSync(path.join(t,n),e,{encoding:"utf8"}):fs.writeFileSync(path.join(t,n),e)}),!0}catch(n){return!1}}function S(n,e){var t;try{return l.readTime+=measure(()=>{t=fs.readdirSync(path.join(e,n)).filter(n=>/^(?!.*\.d\.ts$).*\.ts$/.test(n))}),t}catch(n){return[]}}function I(n){I.used||(l.writeCount++,I.used=!0),l.writeTime+=measure(()=>{"string"==typeof n?r.write(n,{encoding:"utf8"}):r.write(n)})}},exports.checkDiagnostics=checkDiagnostics,exports.createStats=createStats,process.hrtime||(process.hrtime=__webpack_require__(13)),exports.measure=measure,exports.formatTime=formatTime,exports.printStats=printStats,exports.printRTTI=printRTTI;var allocBuffer=void 0!==global&&global.Buffer?global.Buffer.allocUnsafe||function(n){return new global.Buffer(n)}:function(n){return new Uint8Array(n)};function createMemoryStream(n){var e=[];return e.write=function(e){if(n&&n(e),"string"==typeof e){let n=allocBuffer(utf8.length(e));utf8.write(e,n,0),e=n}this.push(e)},e.reset=function(){e.length=0},e.toBuffer=function(){for(var n=0,e=0,t=this.length;e191&&r<224?o[a++]=(31&r)<<6|63&n[e++]:r>239&&r<365?(r=((7&r)<<18|(63&n[e++])<<12|(63&n[e++])<<6|63&n[e++])-65536,o[a++]=55296+(r>>10),o[a++]=56320+(1023&r)):o[a++]=(15&r)<<12|(63&n[e++])<<6|63&n[e++],a>8191&&((i||(i=[])).push(String.fromCharCode.apply(String,o)),a=0);return i?(a&&i.push(String.fromCharCode.apply(String,o.slice(0,a))),i.join("")):String.fromCharCode.apply(String,o.slice(0,a))},r.write=function(n,e,t){for(var r,i,o=t,a=0;a>6|192,e[t++]=63&r|128):55296==(64512&r)&&56320==(64512&(i=n.charCodeAt(a+1)))?(r=65536+((1023&r)<<10)+(1023&i),++a,e[t++]=r>>18|240,e[t++]=r>>12&63|128,e[t++]=r>>6&63|128,e[t++]=63&r|128):(e[t++]=r>>12|224,e[t++]=r>>6&63|128,e[t++]=63&r|128);return t-o}},function(n,e,t){(function(n){var t=void 0!==n&&n||{},r=t.env&&"CI"in t.env;function i(n,t){var i=t||{};return i.supported=n&&!!n.isTTY||r,i.gray=n=>i.supported?e.GRAY+n+e.RESET:n,i.red=n=>i.supported?e.RED+n+e.RESET:n,i.green=n=>i.supported?e.GREEN+n+e.RESET:n,i.yellow=n=>i.supported?e.YELLOW+n+e.RESET:n,i.blue=n=>i.supported?e.BLUE+n+e.RESET:n,i.magenta=n=>i.supported?e.MAGENTA+n+e.RESET:n,i.cyan=n=>i.supported?e.CYAN+n+e.RESET:n,i.white=n=>i.supported?e.WHITE+n+e.RESET:n,i}e.stdout=i(t.stdout,e),e.stderr=i(t.stderr),e.from=i,e.GRAY="",e.RED="",e.GREEN="",e.YELLOW="",e.BLUE="",e.MAGENTA="",e.CYAN="",e.WHITE="",e.RESET=""}).call(this,t(0))},function(n,e){e.parse=function(n,e){var t={},r=[],arguments=[],i=[],o={};Object.keys(e).forEach(n=>{if(!n.startsWith(" ")){var r=e[n];null!=r.alias&&("string"==typeof r.alias?o[r.alias]=n:Array.isArray(r.alias)&&r.alias.forEach(e=>o[e]=n)),null!=r.default&&(t[n]=r.default)}});for(var a=0,s=(n=n.slice()).length;at[n]=s.value[n])}else r.push(i)}for(;a{var a=n[e];if(null!=a.description){for(var s="";s.length{for(let e=0;e=0;r--){var i=n[r];"."===i?n.splice(r,1):".."===i?(n.splice(r,1),t++):t&&(n.splice(r,1),t--)}if(e)for(;t--;t)n.unshift("..");return n}var r=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/,i=function(n){return r.exec(n).slice(1)};function o(n,e){if(n.filter)return n.filter(e);for(var t=[],r=0;r=-1&&!r;i--){var a=i>=0?arguments[i]:n.cwd();if("string"!=typeof a)throw new TypeError("Arguments to path.resolve must be strings");a&&(e=a+"/"+e,r="/"===a.charAt(0))}return(r?"/":"")+(e=t(o(e.split("/"),function(n){return!!n}),!r).join("/"))||"."},e.normalize=function(n){var r=e.isAbsolute(n),i="/"===a(n,-1);return(n=t(o(n.split("/"),function(n){return!!n}),!r).join("/"))||r||(n="."),n&&i&&(n+="/"),(r?"/":"")+n},e.isAbsolute=function(n){return"/"===n.charAt(0)},e.join=function(){var n=Array.prototype.slice.call(arguments,0);return e.normalize(o(n,function(n,e){if("string"!=typeof n)throw new TypeError("Arguments to path.join must be strings");return n}).join("/"))},e.relative=function(n,t){function r(n){for(var e=0;e=0&&""===n[t];t--);return e>t?[]:n.slice(e,t-e+1)}n=e.resolve(n).substr(1),t=e.resolve(t).substr(1);for(var i=r(n.split("/")),o=r(t.split("/")),a=Math.min(i.length,o.length),s=a,l=0;l{try{assemblyscript=__webpack_require__(10)}catch(e){try{__webpack_require__(!function(){var n=new Error("Cannot find module 'ts-node'");throw n.code="MODULE_NOT_FOUND",n}()).register({project:path.join(".","..","src","tsconfig.json")}),__webpack_require__(!function(){var n=new Error("Cannot find module '../src/glue/js'");throw n.code="MODULE_NOT_FOUND",n}()),assemblyscript=__webpack_require__(!function(){var n=new Error("Cannot find module '../src'");throw n.code="MODULE_NOT_FOUND",n}()),isDev=!0}catch(e_ts){try{assemblyscript=eval("require('./assemblyscript')")}catch(n){throw n.stack=e_ts.stack+"\n---\n"+n.stack,n}}}})(),exports.isBundle=!0,exports.isDev=isDev,exports.version=exports.isBundle?"0.7.0":__webpack_require__(!function(){var n=new Error("Cannot find module '../package.json'");throw n.code="MODULE_NOT_FOUND",n}()).version,exports.options=__webpack_require__(11),exports.sourceMapRoot="assemblyscript:///",exports.libraryPrefix=assemblyscript.LIBRARY_PREFIX,exports.defaultOptimizeLevel=3,exports.defaultShrinkLevel=1,exports.libraryFiles=exports.isBundle?Object({array:'/// \n\nimport { BLOCK_MAXSIZE } from "./rt/common";\nimport { COMPARATOR, SORT } from "./util/sort";\nimport { ArrayBuffer, ArrayBufferView } from "./arraybuffer";\nimport { itoa, dtoa, itoa_stream, dtoa_stream, MAX_DOUBLE_LENGTH } from "./util/number";\nimport { idof, isArray as builtin_isArray } from "./builtins";\nimport { E_INDEXOUTOFRANGE, E_INVALIDLENGTH, E_EMPTYARRAY, E_HOLEYARRAY } from "./util/error";\n\n/** Ensures that the given array has _at least_ the specified backing size. */\nfunction ensureSize(array: usize, minSize: usize, alignLog2: u32): void {\n var oldCapacity = changetype(array).dataLength;\n if (minSize > oldCapacity >>> alignLog2) {\n if (minSize > BLOCK_MAXSIZE >>> alignLog2) throw new RangeError(E_INVALIDLENGTH);\n let oldData = changetype(changetype(array).data);\n let newCapacity = minSize << alignLog2;\n let newData = __realloc(oldData, newCapacity);\n memory.fill(newData + oldCapacity, 0, newCapacity - oldCapacity);\n if (newData !== oldData) { // oldData has been free\'d\n store(changetype(array), __retain(newData), offsetof("data"));\n changetype(array).dataStart = newData;\n }\n changetype(array).dataLength = newCapacity;\n }\n}\n\nexport class Array extends ArrayBufferView {\n [key: number]: T;\n\n // Implementing ArrayBufferView isn\'t strictly necessary here but is done to allow glue code\n // to work with typed and normal arrays interchangeably. Technically, normal arrays do not need\n // `dataStart` (equals `data`) and `dataLength` (equals computed `data.byteLength`).\n\n // Also note that Array with non-nullable T must guard against implicit null values whenever\n // length is modified in a way that a null value would exist. Otherwise, the compiler wouldn\'t be\n // able to guarantee type-safety anymore. For lack of a better word, such an array is "holey".\n\n private length_: i32;\n\n static isArray(value: U): bool {\n return builtin_isArray(value) && value !== null;\n }\n\n static create(capacity: i32 = 0): Array {\n if (capacity > BLOCK_MAXSIZE >>> alignof()) throw new RangeError(E_INVALIDLENGTH);\n var array = changetype>(__allocArray(capacity, alignof(), idof())); // retains\n changetype>(array).length_ = 0; // safe even if T is a non-nullable reference\n memory.fill(array.dataStart, 0, array.dataLength);\n return array;\n }\n\n constructor(length: i32 = 0) {\n super(length, alignof());\n if (isReference()) {\n if (!isNullable()) {\n if (length) throw new Error(E_HOLEYARRAY);\n }\n }\n this.length_ = length;\n }\n\n @unsafe get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.length_;\n }\n\n set length(newLength: i32) {\n var oldLength = this.length_;\n if (isReference()) {\n if (!isNullable()) {\n if (newLength > oldLength) throw new Error(E_HOLEYARRAY);\n }\n }\n ensureSize(changetype(this), newLength, alignof());\n if (isManaged()) { // release no longer used refs\n if (oldLength > newLength) {\n let dataStart = this.dataStart;\n do __release(load(dataStart + (--oldLength << alignof())));\n while (oldLength > newLength);\n // no need to zero memory on shrink -> is zeroed on grow\n }\n }\n this.length_ = newLength;\n }\n\n every(fn: (value: T, index: i32, array: Array) => bool): bool {\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n if (!fn(load(this.dataStart + (index << alignof())), index, this)) return false;\n }\n return true;\n }\n\n findIndex(predicate: (value: T, index: i32, array: Array) => bool): i32 {\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n if (predicate(load(this.dataStart + (index << alignof())), index, this)) return index;\n }\n return -1;\n }\n\n @operator("[]") private __get(index: i32): T {\n if (isReference()) {\n if (!isNullable()) {\n if (index >= this.length_) throw new Error(E_HOLEYARRAY);\n }\n }\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return this.__unchecked_get(index);\n }\n\n @operator("{}") private __unchecked_get(index: i32): T {\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") private __set(index: i32, value: T): void {\n var length = this.length_;\n if (isReference()) {\n if (!isNullable()) {\n if (index > length) throw new Error(E_HOLEYARRAY);\n }\n }\n ensureSize(changetype(this), index + 1, alignof());\n this.__unchecked_set(index, value);\n if (index >= length) this.length_ = index + 1;\n }\n\n @operator("{}=") private __unchecked_set(index: i32, value: T): void {\n if (isManaged()) {\n let offset = this.dataStart + (index << alignof());\n let oldRef: usize = load(offset);\n if (changetype(value) != oldRef) {\n store(offset, __retain(changetype(value)));\n __release(oldRef);\n }\n } else {\n store(this.dataStart + (index << alignof()), value);\n }\n }\n\n fill(value: T, start: i32 = 0, end: i32 = i32.MAX_VALUE): this {\n var dataStart = this.dataStart;\n var length = this.length_;\n start = start < 0 ? max(length + start, 0) : min(start, length);\n end = end < 0 ? max(length + end, 0) : min(end, length);\n if (isManaged()) {\n for (; start < end; ++start) {\n let oldRef: usize = load(dataStart + (start << alignof()));\n if (changetype(value) != oldRef) {\n store(dataStart + (start << alignof()), __retain(changetype(value)));\n __release(oldRef);\n }\n }\n } else if (sizeof() == 1) {\n if (start < end) {\n memory.fill(\n dataStart + start,\n u8(value),\n (end - start)\n );\n }\n } else {\n for (; start < end; ++start) {\n store(dataStart + (start << alignof()), value);\n }\n }\n return this;\n }\n\n includes(value: T, fromIndex: i32 = 0): bool {\n return this.indexOf(value, fromIndex) >= 0;\n }\n\n indexOf(value: T, fromIndex: i32 = 0): i32 {\n var length = this.length_;\n if (length == 0 || fromIndex >= length) return -1;\n if (fromIndex < 0) fromIndex = max(length + fromIndex, 0);\n var dataStart = this.dataStart;\n while (fromIndex < length) {\n if (load(dataStart + (fromIndex << alignof())) == value) return fromIndex;\n ++fromIndex;\n }\n return -1;\n }\n\n lastIndexOf(value: T, fromIndex: i32 = this.length_): i32 {\n var length = this.length_;\n if (length == 0) return -1;\n if (fromIndex < 0) fromIndex = length + fromIndex;\n else if (fromIndex >= length) fromIndex = length - 1;\n var dataStart = this.dataStart;\n while (fromIndex >= 0) {\n if (load(dataStart + (fromIndex << alignof())) == value) return fromIndex;\n --fromIndex;\n }\n return -1;\n }\n\n push(value: T): i32 {\n var length = this.length_;\n var newLength = length + 1;\n ensureSize(changetype(this), newLength, alignof());\n if (isManaged()) {\n store(this.dataStart + (length << alignof()), __retain(changetype(value)));\n } else {\n store(this.dataStart + (length << alignof()), value);\n }\n this.length_ = newLength;\n return newLength;\n }\n\n concat(other: Array): Array {\n var thisLen = this.length_;\n var otherLen = select(0, other.length_, other === null);\n var outLen = thisLen + otherLen;\n if (outLen > BLOCK_MAXSIZE >>> alignof()) throw new Error(E_INVALIDLENGTH);\n var out = changetype>(__allocArray(outLen, alignof(), idof>())); // retains\n var outStart = out.dataStart;\n var thisSize = thisLen << alignof();\n if (isManaged()) {\n let thisStart = this.dataStart;\n for (let offset: usize = 0; offset < thisSize; offset += sizeof()) {\n let ref = load(thisStart + offset);\n store(outStart + offset, __retain(ref));\n }\n outStart += thisSize;\n let otherStart = other.dataStart;\n let otherSize = otherLen << alignof();\n for (let offset: usize = 0; offset < otherSize; offset += sizeof()) {\n let ref = load(otherStart + offset);\n store(outStart + offset, __retain(ref));\n }\n } else {\n memory.copy(outStart, this.dataStart, thisSize);\n memory.copy(outStart + thisSize, other.dataStart, otherLen << alignof());\n }\n return out;\n }\n\n copyWithin(target: i32, start: i32, end: i32 = i32.MAX_VALUE): this {\n var dataStart = this.dataStart;\n var len = this.length_;\n\n end = min(end, len);\n var to = target < 0 ? max(len + target, 0) : min(target, len);\n var from = start < 0 ? max(len + start, 0) : min(start, len);\n var last = end < 0 ? max(len + end, 0) : min(end, len);\n var count = min(last - from, len - to);\n\n if (isManaged()) {\n if (from < to && to < (from + count)) { // right to left\n from += count - 1;\n to += count - 1;\n while (count) {\n let oldRef: usize = load(dataStart + (to << alignof()));\n let newRef: usize = load(dataStart + (from << alignof()));\n if (newRef != oldRef) {\n store(dataStart + (to << alignof()), __retain(newRef));\n __release(oldRef);\n }\n --from, --to, --count;\n }\n } else { // left to right\n while (count) {\n let oldRef: usize = load(dataStart + (to << alignof()));\n let newRef: usize = load(dataStart + (from << alignof()));\n if (newRef != oldRef) {\n store(dataStart + (to << alignof()), __retain(newRef));\n __release(oldRef);\n }\n ++from, ++to, --count;\n }\n }\n } else {\n memory.copy( // is memmove\n dataStart + (to << alignof()),\n dataStart + (from << alignof()),\n count << alignof()\n );\n }\n return this;\n }\n\n pop(): T {\n var length = this.length_;\n if (length < 1) throw new RangeError(E_EMPTYARRAY);\n var element = load(this.dataStart + ((--length) << alignof()));\n this.length_ = length;\n return element; // no need to retain -> is moved\n }\n\n forEach(fn: (value: T, index: i32, array: Array) => void): void {\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n fn(load(this.dataStart + (index << alignof())), index, this);\n }\n }\n\n map(fn: (value: T, index: i32, array: Array) => U): Array {\n var length = this.length_;\n var out = changetype>(__allocArray(length, alignof(), idof>())); // retains\n var outStart = out.dataStart;\n for (let index = 0; index < min(length, this.length_); ++index) {\n let result = fn(load(this.dataStart + (index << alignof())), index, this); // retains\n if (isManaged()) {\n store(outStart + (index << alignof()), __retain(changetype(result)));\n } else {\n store(outStart + (index << alignof()), result);\n }\n // releases result\n }\n return out;\n }\n\n filter(fn: (value: T, index: i32, array: Array) => bool): Array {\n var result = changetype>(__allocArray(0, alignof(), idof>())); // retains\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n let value = load(this.dataStart + (index << alignof()));\n if (fn(value, index, this)) result.push(value);\n }\n return result;\n }\n\n reduce(\n fn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U,\n initialValue: U\n ): U {\n var accum = initialValue;\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n accum = fn(accum, load(this.dataStart + (index << alignof())), index, this);\n }\n return accum;\n }\n\n reduceRight(\n fn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U,\n initialValue: U\n ): U {\n var accum = initialValue;\n for (let index = this.length_ - 1; index >= 0; --index) {\n accum = fn(accum, load(this.dataStart + (index << alignof())), index, this);\n }\n return accum;\n }\n\n shift(): T {\n var length = this.length_;\n if (length < 1) throw new RangeError(E_EMPTYARRAY);\n var base = this.dataStart;\n var element = load(base);\n var lastIndex = length - 1;\n memory.copy(\n base,\n base + sizeof(),\n lastIndex << alignof()\n );\n store(base + (lastIndex << alignof()),\n // @ts-ignore: cast\n null\n );\n this.length_ = lastIndex;\n return element; // no need to retain -> is moved\n }\n\n some(fn: (value: T, index: i32, array: Array) => bool): bool {\n for (let index = 0, length = this.length_; index < min(length, this.length_); ++index) {\n if (fn(load(this.dataStart + (index << alignof())), index, this)) return true;\n }\n return false;\n }\n\n unshift(value: T): i32 {\n var newLength = this.length_ + 1;\n ensureSize(changetype(this), newLength, alignof());\n var dataStart = this.dataStart;\n memory.copy(\n dataStart + sizeof(),\n dataStart,\n (newLength - 1) << alignof()\n );\n if (isManaged()) {\n store(dataStart, __retain(changetype(value)));\n } else {\n store(dataStart, value);\n }\n this.length_ = newLength;\n return newLength;\n }\n\n slice(start: i32 = 0, end: i32 = i32.MAX_VALUE): Array {\n var length = this.length_;\n start = start < 0 ? max(start + length, 0) : min(start, length);\n end = end < 0 ? max(end + length, 0) : min(end , length);\n length = max(end - start, 0);\n var slice = changetype>(__allocArray(length, alignof(), idof>())); // retains\n var sliceBase = slice.dataStart;\n var thisBase = this.dataStart + (start << alignof());\n if (isManaged()) {\n let off = 0;\n let end = length << alignof();\n while (off < end) {\n let ref = load(thisBase + off);\n store(sliceBase + off, __retain(ref));\n off += sizeof();\n }\n } else {\n memory.copy(sliceBase, thisBase, length << alignof());\n }\n return slice;\n }\n\n splice(start: i32, deleteCount: i32 = i32.MAX_VALUE): Array {\n var length = this.length_;\n start = start < 0 ? max(length + start, 0) : min(start, length);\n deleteCount = max(min(deleteCount, length - start), 0);\n var result = changetype>(__allocArray(deleteCount, alignof(), idof>())); // retains\n var resultStart = result.dataStart;\n var thisStart = this.dataStart;\n var thisBase = thisStart + (start << alignof());\n if (isManaged()) {\n for (let i = 0; i < deleteCount; ++i) {\n store(resultStart + (i << alignof()),\n load(thisBase + (i << alignof()))\n );\n // no need to retain -> is moved\n }\n } else {\n memory.copy(\n resultStart,\n thisBase,\n deleteCount << alignof()\n );\n }\n var offset = start + deleteCount;\n if (length != offset) {\n memory.copy(\n thisBase,\n thisStart + (offset << alignof()),\n (length - offset) << alignof()\n );\n }\n this.length_ = length - deleteCount;\n return result;\n }\n\n reverse(): Array {\n var length = this.length_;\n if (length) {\n let front = this.dataStart;\n let back = this.dataStart + ((length - 1) << alignof());\n while (front < back) {\n let temp = load(front);\n store(front, load(back));\n store(back, temp);\n front += sizeof();\n back -= sizeof();\n }\n }\n return this;\n }\n\n sort(comparator: (a: T, b: T) => i32 = COMPARATOR()): this {\n var length = this.length_;\n if (length <= 1) return this;\n var base = this.dataStart;\n if (length == 2) {\n let a: T = load(base, sizeof()); // a = arr[1]\n let b: T = load(base); // b = arr[0]\n if (comparator(a, b) < 0) {\n store(base, b, sizeof()); // arr[1] = b;\n store(base, a); // arr[0] = a;\n }\n return this;\n }\n SORT(base, length, comparator);\n return this;\n }\n\n join(separator: string = ","): string {\n if (isBoolean()) return this.join_bool(separator);\n if (isInteger()) return this.join_int(separator);\n if (isFloat()) return this.join_flt(separator);\n if (isString()) return this.join_str(separator);\n if (isArray()) return this.join_arr(separator);\n if (isReference()) return this.join_ref(separator);\n ERROR("unspported element type");\n return unreachable();\n }\n\n private join_bool(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n var dataStart = this.dataStart;\n if (!lastIndex) return select("true", "false", load(dataStart));\n\n var sepLen = separator.length;\n var valueLen = 5; // max possible length of element len("false")\n var estLen = (valueLen + sepLen) * lastIndex + valueLen;\n var result = changetype(__alloc(estLen << 1, idof())); // retains\n var offset = 0;\n var value: bool;\n for (let i = 0; i < lastIndex; ++i) {\n value = load(dataStart + i);\n valueLen = 4 + i32(!value);\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(select("true", "false", value)),\n valueLen << 1\n );\n offset += valueLen;\n if (sepLen) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(separator),\n sepLen << 1\n );\n offset += sepLen;\n }\n }\n value = load(dataStart + lastIndex);\n valueLen = 4 + i32(!value);\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(select("true", "false", value)),\n valueLen << 1\n );\n offset += valueLen;\n\n if (estLen > offset) return result.substring(0, offset);\n return result;\n }\n\n private join_int(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n var dataStart = this.dataStart;\n // @ts-ignore: type\n if (!lastIndex) return changetype(itoa(load(dataStart))); // retains\n\n var sepLen = separator.length;\n const valueLen = (sizeof() <= 4 ? 10 : 20) + i32(isSigned());\n var estLen = (valueLen + sepLen) * lastIndex + valueLen;\n var result = changetype(__alloc(estLen << 1, idof())); // retains\n var offset = 0;\n var value: T;\n for (let i = 0; i < lastIndex; ++i) {\n value = load(dataStart + (i << alignof()));\n // @ts-ignore: type\n offset += itoa_stream(changetype(result), offset, value);\n if (sepLen) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(separator),\n sepLen << 1\n );\n offset += sepLen;\n }\n }\n value = load(dataStart + (lastIndex << alignof()));\n // @ts-ignore: type\n offset += itoa_stream(changetype(result), offset, value);\n if (estLen > offset) return result.substring(0, offset);\n return result;\n }\n\n private join_flt(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n var dataStart = this.dataStart;\n if (!lastIndex) {\n return changetype(dtoa(\n // @ts-ignore: type\n load(dataStart))\n ); // retains\n }\n\n const valueLen = MAX_DOUBLE_LENGTH;\n var sepLen = separator.length;\n var estLen = (valueLen + sepLen) * lastIndex + valueLen;\n var result = changetype(__alloc(estLen << 1, idof())); // retains\n var offset = 0;\n var value: T;\n for (let i = 0; i < lastIndex; ++i) {\n value = load(dataStart + (i << alignof()));\n offset += dtoa_stream(changetype(result), offset,\n // @ts-ignore: type\n value\n );\n if (sepLen) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(separator),\n sepLen << 1\n );\n offset += sepLen;\n }\n }\n value = load(dataStart + (lastIndex << alignof()));\n offset += dtoa_stream(changetype(result), offset,\n // @ts-ignore: type\n value\n );\n if (estLen > offset) return result.substring(0, offset);\n return result;\n }\n\n private join_str(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n var dataStart = this.dataStart;\n if (!lastIndex) return load(dataStart);\n\n var sepLen = separator.length;\n var estLen = 0;\n var value: string | null;\n for (let i = 0, len = lastIndex + 1; i < len; ++i) {\n value = load(dataStart + (i << alignof()));\n if (value !== null) estLen += value.length;\n }\n var offset = 0;\n var result = changetype(__alloc((estLen + sepLen * lastIndex) << 1, idof())); // retains\n for (let i = 0; i < lastIndex; ++i) {\n value = load(dataStart + (i << alignof()));\n if (value !== null) {\n let valueLen = changetype(value).length;\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(value),\n valueLen << 1\n );\n offset += valueLen;\n }\n if (sepLen) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(separator),\n sepLen << 1\n );\n offset += sepLen;\n }\n }\n value = load(dataStart + (lastIndex << alignof()));\n if (value !== null) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(value),\n changetype(value).length << 1\n );\n }\n return result;\n }\n\n private join_arr(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n\n var result = "";\n var sepLen = separator.length;\n var base = this.dataStart;\n var value: T;\n if (!lastIndex) {\n value = load(base);\n // @ts-ignore: type\n return value ? value.join(separator) : "";\n }\n for (let i = 0; i < lastIndex; ++i) {\n value = load(base + (i << alignof()));\n // @ts-ignore: type\n if (value) result += value.join(separator);\n if (sepLen) result += separator;\n }\n value = load(base + (lastIndex << alignof()));\n // @ts-ignore: type\n if (value) result += value.join(separator);\n return result; // registered by concatenation (FIXME: lots of garbage)\n }\n\n private join_ref(separator: string = ","): string {\n var lastIndex = this.length_ - 1;\n if (lastIndex < 0) return "";\n var base = this.dataStart;\n if (!lastIndex) return "[object Object]";\n\n const valueLen = 15; // max possible length of element len("[object Object]")\n var sepLen = separator.length;\n var estLen = (valueLen + sepLen) * lastIndex + valueLen;\n var result = changetype(__alloc(estLen << 1, idof()));\n var offset = 0;\n var value: T;\n for (let i = 0; i < lastIndex; ++i) {\n value = load(base + (i << alignof()));\n if (value) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype("[object Object]"),\n valueLen << 1\n );\n offset += valueLen;\n }\n if (sepLen) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype(separator),\n sepLen << 1\n );\n offset += sepLen;\n }\n }\n if (load(base + (lastIndex << alignof()))) {\n memory.copy(\n changetype(result) + (offset << 1),\n changetype("[object Object]"),\n valueLen << 1\n );\n offset += valueLen;\n }\n if (estLen > offset) return result.substring(0, offset);\n return result;\n }\n\n toString(): string {\n return this.join();\n }\n\n // RT integration\n\n @unsafe private __visit_impl(cookie: u32): void {\n if (isManaged()) {\n let cur = this.dataStart;\n let end = cur + (this.length_ << alignof());\n while (cur < end) {\n let val = load(cur);\n if (val) __visit(val, cookie);\n cur += sizeof();\n }\n }\n // automatically visits ArrayBufferView (.data) next\n }\n}\n',arraybuffer:'/// \n\nimport { BLOCK, BLOCK_MAXSIZE, BLOCK_OVERHEAD } from "./rt/common";\nimport { idof } from "./builtins";\nimport { E_INVALIDLENGTH } from "./util/error";\n\nexport abstract class ArrayBufferView {\n\n @unsafe data: ArrayBuffer;\n @unsafe dataStart: usize;\n @unsafe dataLength: u32;\n\n protected constructor(length: i32, alignLog2: i32) {\n if (length > BLOCK_MAXSIZE >>> alignLog2) throw new RangeError(E_INVALIDLENGTH);\n var buffer = __alloc(length = length << alignLog2, idof());\n memory.fill(buffer, 0, length);\n this.data = changetype(buffer); // retains\n this.dataStart = buffer;\n this.dataLength = length;\n }\n\n get byteOffset(): i32 {\n return (this.dataStart - changetype(this.data));\n }\n\n get byteLength(): i32 {\n return this.dataLength;\n }\n\n get length(): i32 {\n ERROR("missing implementation: subclasses must implement ArrayBufferView#length");\n return unreachable();\n }\n}\n\n@sealed export class ArrayBuffer {\n\n static isView(value: T): bool {\n if (value) {\n if (value instanceof Int8Array) return true;\n if (value instanceof Uint8Array) return true;\n if (value instanceof Uint8ClampedArray) return true;\n if (value instanceof Int16Array) return true;\n if (value instanceof Uint16Array) return true;\n if (value instanceof Int32Array) return true;\n if (value instanceof Uint32Array) return true;\n if (value instanceof Int64Array) return true;\n if (value instanceof Uint64Array) return true;\n if (value instanceof Float32Array) return true;\n if (value instanceof Float64Array) return true;\n if (value instanceof DataView) return true;\n }\n return false;\n }\n\n constructor(length: i32) {\n if (length > BLOCK_MAXSIZE) throw new RangeError(E_INVALIDLENGTH);\n var buffer = __alloc(length, idof());\n memory.fill(buffer, 0, length);\n return changetype(buffer); // retains\n }\n\n get byteLength(): i32 {\n return changetype(changetype(this) - BLOCK_OVERHEAD).rtSize;\n }\n\n slice(begin: i32 = 0, end: i32 = BLOCK_MAXSIZE): ArrayBuffer {\n var length = this.byteLength;\n begin = begin < 0 ? max(length + begin, 0) : min(begin, length);\n end = end < 0 ? max(length + end , 0) : min(end , length);\n var outSize = max(end - begin, 0);\n var out = __alloc(outSize, idof());\n memory.copy(out, changetype(this) + begin, outSize);\n return changetype(out); // retains\n }\n\n toString(): string {\n return "[object ArrayBuffer]";\n }\n}\n',"bindings/Date":"export declare function UTC(\n // NOTE: Using i32 below saves us a f64.convert_s instruction and moves the responsibility for\n // converting the value to the WASM/JS boundary.\n year: i32,\n month: i32,\n day: i32,\n hour: i32,\n minute: i32,\n second: i32,\n millisecond: f64\n): f64;\nexport declare function now(): f64;\n","bindings/Math":"export declare const E: f64;\nexport declare const LN2: f64;\nexport declare const LN10: f64;\nexport declare const LOG2E: f64;\nexport declare const LOG10E: f64;\nexport declare const PI: f64;\nexport declare const SQRT1_2: f64;\nexport declare const SQRT2: f64;\n\nexport declare function abs(x: f64): f64;\nexport declare function acos(x: f64): f64;\nexport declare function acosh(x: f64): f64;\nexport declare function asin(x: f64): f64;\nexport declare function asinh(x: f64): f64;\nexport declare function atan(x: f64): f64;\nexport declare function atan2(y: f64, x: f64): f64;\nexport declare function atanh(x: f64): f64;\nexport declare function cbrt(x: f64): f64;\nexport declare function ceil(x: f64): f64;\nexport declare function clz32(x: f64): f64;\nexport declare function cos(x: f64): f64;\nexport declare function cosh(x: f64): f64;\nexport declare function exp(x: f64): f64;\nexport declare function expm1(x: f64): f64;\nexport declare function floor(x: f64): f64;\nexport declare function fround(x: f64): f32;\nexport declare function hypot(value1: f64, value2: f64): f64; // TODO: rest\nexport declare function imul(a: f64, b: f64): f64;\nexport declare function log(x: f64): f64;\nexport declare function log10(x: f64): f64;\nexport declare function log1p(x: f64): f64;\nexport declare function log2(x: f64): f64;\nexport declare function max(value1: f64, value2: f64): f64; // TODO: rest\nexport declare function min(value1: f64, value2: f64): f64; // TODO: rest\nexport declare function pow(base: f64, exponent: f64): f64;\nexport declare function random(): f64;\nexport declare function round(x: f64): f64;\nexport declare function sign(x: f64): f64;\nexport declare function sin(x: f64): f64;\nexport declare function sinh(x: f64): f64;\nexport declare function sqrt(x: f64): f64;\nexport declare function tan(x: f64): f64;\nexport declare function tanh(x: f64): f64;\nexport declare function trunc(x: f64): f64;\n","bindings/wasi_unstable":"// see: https://wasi.dev\n\n/* tslint:disable:max-line-length */\n\n// helper types to be more explicit\ntype char = u8;\ntype ptr = usize; // all pointers are usize'd\ntype struct = T; // structs are references already in AS\n\n/** Read command-line argument data. */\nexport declare function args_get(\n /** Input: Pointer to a buffer to write the argument pointers. */\n argv: ptr>,\n /** Input: Pointer to a buffer to write the argument string data. */\n argv_buf: ptr\n): errno;\n\n/** Return command-line argument data sizes. */\nexport declare function args_sizes_get(\n /** Output: Number of arguments. */\n argc: ptr,\n /** Output: Size of the argument string data. */\n argv_buf_size: ptr\n): errno;\n\n/** Return the resolution of a clock. */\nexport declare function clock_res_get(\n /** Input: The clock for which to return the resolution. */\n clock: clockid,\n /** Output: The resolution of the clock. */\n resolution: ptr\n): errno;\n\n/** Return the time value of a clock. */\nexport declare function clock_time_get(\n /** Input: Cock for which to return the time. */\n clock: clockid,\n /** Input: Maximum lag (exclusive) that the returned time value may have, compared to its actual value. */\n precision: timestamp,\n /** Output: Time value of the clock. */\n time: ptr\n): errno;\n\n/** Read environment variable data. */\nexport declare function environ_get(\n /** Input: Pointer to a buffer to write the environment variable pointers. */\n environ: ptr,\n /** Input: Pointer to a buffer to write the environment variable string data. */\n environ_buf: usize\n): errno;\n\n/** Return command-line argument data sizes. */\nexport declare function environ_sizes_get(\n /** Output: The number of environment variables. */\n environ_count: ptr,\n /** Output: The size of the environment variable string data. */\n environ_buf_size: ptr\n): errno;\n\n/** Provide file advisory information on a file descriptor. */\nexport declare function fd_advise(\n /** Input: The file descriptor for the file for which to provide file advisory information. */\n fd: fd,\n /** Input: The offset within the file to which the advisory applies. */\n offset: filesize,\n /** Input: The length of the region to which the advisory applies. */\n len: filesize,\n /** Input: The advice. */\n advice: advice\n): errno;\n\n/** Provide file advisory information on a file descriptor. */\nexport declare function fd_allocate(\n /** Input: The file descriptor for the file in which to allocate space. */\n fd: fd,\n /** Input: The offset at which to start the allocation. */\n offset: filesize,\n /** Input: The length of the area that is allocated. */\n len: filesize\n): errno;\n\n/** Close a file descriptor. */\nexport declare function fd_close(\n /** Input: The file descriptor to close. */\n fd: fd\n): errno;\n\n/** Synchronize the data of a file to disk. */\nexport declare function fd_datasync(\n /** Input: The file descriptor of the file to synchronize to disk. */\n fd: fd\n): errno;\n\n/** Get the attributes of a file descriptor. */\nexport declare function fd_fdstat_get(\n /** Input: The file descriptor to inspect. */\n fd: fd,\n /** Input: The buffer where the file descriptor's attributes are stored. */\n buf: struct\n): errno;\n\n/** Adjust the flags associated with a file descriptor. */\nexport declare function fd_fdstat_set_flags(\n /** Input: The file descriptor to operate on. */\n fd: fd,\n /** Input: The desired values of the file descriptor flags. */\n flags: fdflags\n): errno;\n\n/** Adjust the rights associated with a file descriptor. */\nexport declare function fd_fdstat_set_rights(\n /** Input: The file descriptor to operate on. */\n fd: fd,\n /** Input: The desired rights of the file descriptor. */\n fs_rights_base: rights,\n /** Input: The desired rights of the file descriptor. */\n fs_rights_inheriting: rights\n): errno;\n\n/** Return the attributes of an open file. */\nexport declare function fd_filestat_get(\n /** Input: The file descriptor to inspect. */\n fd: fd,\n /** Input: The buffer where the file's attributes are stored. */\n buf: struct\n): errno;\n\n/** Adjust the size of an open file. If this increases the file's size, the extra bytes are filled with zeros. */\nexport declare function fd_filestat_set_size(\n /** Input: A file descriptor for the file to adjust. */\n fd: fd,\n /** Input: The desired file size. */\n size: filesize\n): errno;\n\n/** Adjust the timestamps of an open file or directory. */\nexport declare function fd_filestat_set_times(\n /** Input: The file descriptor to operate on. */\n fd: fd,\n /** Input: The desired values of the data access timestamp. */\n st_atim: timestamp,\n /** Input: The desired values of the data modification timestamp. */\n st_mtim: timestamp,\n /** Input: A bitmask indicating which timestamps to adjust. */\n fstflags: fstflags\n): errno;\n\n/** Read from a file descriptor, without using and updating the file descriptor's offset. */\nexport declare function fd_pread(\n /** Input: The file descriptor from which to read data. */\n fd: fd,\n /** Input: List of scatter/gather vectors in which to store data. */\n iovs: ptr>,\n /** Input: Length of the list of scatter/gather vectors in which to store data. */\n iovs_len: usize,\n /** Input: The offset within the file at which to read. */\n offset: filesize,\n /** Output: The number of bytes read. */\n nread: ptr\n): errno;\n\n/** Return a description of the given preopened file descriptor. */\nexport declare function fd_prestat_get(\n /** Input: The file descriptor about which to retrieve information. */\n fd: fd,\n /** Input: The buffer where the description is stored. */\n buf: struct\n): errno;\n\n/** Return a description of the given preopened file descriptor. */\nexport declare function fd_prestat_dir_name(\n /** Input: The file descriptor about which to retrieve information. */\n fd: fd,\n /** Input: Buffer into which to write the preopened directory name. */\n path: ptr,\n /** Input: Length of the buffer into which to write the preopened directory name. */\n path_len: usize\n): errno;\n\n/** Write to a file descriptor, without using and updating the file descriptor's offset. */\nexport declare function fd_pwrite(\n /** Input: The file descriptor to which to write data. */\n fd: fd,\n /** Input: List of scatter/gather vectors from which to retrieve data. */\n iovs: ptr>,\n /** Input: Length of the list of scatter/gather vectors from which to retrieve data. */\n iovs_len: usize,\n /** Input: The offset within the file at which to write. */\n offset: filesize,\n /** Output: The number of bytes written. */\n nwritten: ptr\n): errno;\n\n/** Read from a file descriptor. */\nexport declare function fd_read(\n /** Input: The file descriptor from which to read data. */\n fd: fd,\n /** Input: List of scatter/gather vectors to which to store data. */\n iovs: ptr>,\n /** Input: Length of the list of scatter/gather vectors to which to store data. */\n iovs_len: usize,\n /** Output: The number of bytes read. */\n nread: ptr\n): errno;\n\n/** Read directory entries from a directory. */\nexport declare function fd_readdir(\n /** Input: Directory from which to read the directory entries. */\n fd: fd,\n /** Input: Buffer where directory entries are stored. */\n buf: ptr>,\n /** Input: Length of the buffer where directory entries are stored. */\n buf_len: usize,\n /** Input: Location within the directory to start reading. */\n cookie: dircookie,\n /** Output: Number of bytes stored in the read buffer. If less than the size of the read buffer, the end of the directory has been reached. */\n buf_used: ptr\n): errno;\n\n/** Atomically replace a file descriptor by renumbering another file descriptor. */\nexport declare function fd_renumber(\n /** Input: The file descriptor to renumber. */\n from: fd,\n /** Input: The file descriptor to overwrite. */\n to: fd\n): errno;\n\n/** Move the offset of a file descriptor. */\nexport declare function fd_seek(\n /** Input: The file descriptor to operate on. */\n fd: fd,\n /** Input: The number of bytes to move. */\n offset: filedelta,\n /** Input: The base from which the offset is relative. */\n whence: whence,\n /** Output: The new offset of the file descriptor, relative to the start of the file. */\n newoffset: ptr\n): errno;\n\n/** Synchronize the data and metadata of a file to disk. */\nexport declare function fd_sync(\n /** Input: The file descriptor of the file containing the data and metadata to synchronize to disk. */\n fd: fd\n): errno;\n\n/** Return the current offset of a file descriptor. */\nexport declare function fd_tell(\n /** Input: The file descriptor to inspect. */\n fd: fd,\n /** Output: The current offset of the file descriptor, relative to the start of the file. */\n newoffset: ptr\n): errno;\n\n/** Write to a file descriptor. */\nexport declare function fd_write(\n /** Input: The file descriptor to which to write data. */\n fd: fd,\n /** Input: List of scatter/gather vectors from which to retrieve data. */\n iovs: ptr>,\n /** Input: List of scatter/gather vectors from which to retrieve data. */\n iovs_len: usize,\n /** Output: The number of bytes written. */\n nwritten: ptr\n): errno;\n\n/* Create a directory. */\nexport declare function path_create_directory(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: The path at which to create the directory. */\n path: ptr,\n /** Input: The path at which to create the directory. */\n path_len: usize\n): errno;\n\n/** Return the attributes of a file or directory. */\nexport declare function path_filestat_get(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: Flags determining the method of how the path is resolved. */\n flags: lookupflags,\n /** Input: The path of the file or directory to inspect. */\n path: ptr,\n /** Input: The path of the file or directory to inspect. */\n path_len: usize,\n /** Input: The buffer where the file's attributes are stored. */\n buf: struct\n): errno;\n\n/** Adjust the timestamps of a file or directory. */\nexport declare function path_filestat_set_times(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: Flags determining the method of how the path is resolved. */\n flags: lookupflags,\n /** Input: The path of the file or directory to operate on. */\n path: ptr,\n /** Input: The path of the file or directory to operate on. */\n path_len: usize,\n /** Input: The desired values of the data access timestamp. */\n st_atim: timestamp,\n /** Input: The desired values of the data modification timestamp. */\n st_mtim: timestamp,\n /** Input: A bitmask indicating which timestamps to adjust. */\n fstflags: fstflags\n): errno;\n\n/** Create a hard link. */\nexport declare function path_link(\n /** Input: The working directory at which the resolution of the old path starts. */\n old_fd: fd,\n /** Input: Flags determining the method of how the path is resolved. */\n old_flags: lookupflags,\n /** Input: The source path from which to link. */\n old_path: ptr,\n /** Input: The source path from which to link. */\n old_path_len: usize,\n /** Input: The working directory at which the resolution of the new path starts. */\n new_fd: fd,\n /** Input: The destination path at which to create the hard link. */\n new_path: ptr,\n /** Input: The length of the destination path at which to create the hard link. */\n new_path_len: usize\n): errno;\n\n/** Open a file or directory. */\nexport declare function path_open(\n /** Input: The working directory at which the resolution of the path starts. */\n dirfd: fd,\n /** Input: Flags determining the method of how the path is resolved. */\n dirflags: lookupflags,\n /** Input: The path of the file or directory to open. */\n path: ptr,\n /** Input: The length of the path of the file or directory to open. */\n path_len: usize,\n /** Input: The method by which to open the file. */\n oflags: oflags,\n /** Input: The initial base rights that apply to operations using the file descriptor itself. */\n fs_rights_base: rights,\n /** Input: The initial inheriting rights that apply to file descriptors derived from it. */\n fs_rights_inheriting: rights,\n /** Input: The initial flags of the file descriptor. */\n fs_flags: fdflags,\n /** Output: The file descriptor of the file that has been opened. */\n fd: ptr\n): errno;\n\n/** Read the contents of a symbolic link. */\nexport declare function path_readlink(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: The path of the symbolic link from which to read. */\n path: ptr,\n /** Input: The length of the path of the symbolic link from which to read. */\n path_len: usize,\n /** Input: The buffer to which to write the contents of the symbolic link. */\n buf: ptr,\n /** Input: The length of the buffer to which to write the contents of the symbolic link. */\n buf_len: usize,\n /** Output: The number of bytes placed in the buffer. */\n buf_used: ptr\n): errno;\n\n/** Remove a directory. */\nexport declare function path_remove_directory(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: The path to a directory to remove. */\n path: ptr,\n /** Input: The length of the path to a directory to remove. */\n path_len: usize\n): errno;\n\n/** Rename a file or directory. */\nexport declare function path_rename(\n /** Input: The working directory at which the resolution of the old path starts. */\n old_fd: fd,\n /** Input: The source path of the file or directory to rename. */\n old_path: ptr,\n /** Input: The length of the source path of the file or directory to rename. */\n old_path_len: usize,\n /** Input: The working directory at which the resolution of the new path starts. */\n new_fd: fd,\n /** Input: The destination path to which to rename the file or directory. */\n new_path: ptr,\n /** Input: The length of the destination path to which to rename the file or directory. */\n new_path_len: usize\n): errno;\n\n/** Create a symbolic link. */\nexport declare function path_symlink(\n /** Input: The contents of the symbolic link. */\n old_path: ptr,\n /** Input: The length of the contents of the symbolic link. */\n old_path_len: usize,\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: The destination path at which to create the symbolic link. */\n new_path: ptr,\n /** Input: The length of the destination path at which to create the symbolic link. */\n new_path_len: usize\n): errno;\n\n/** Unlink a file. */\nexport declare function path_unlink_file(\n /** Input: The working directory at which the resolution of the path starts. */\n fd: fd,\n /** Input: The path to a file to unlink. */\n path: ptr,\n /** Input: The length of the path to a file to unlink. */\n path_len: usize\n): errno;\n\n/** Concurrently poll for the occurrence of a set of events. */\nexport declare function poll_oneoff(\n /** Input: The events to which to subscribe. */\n in_: ptr>,\n /** Input: The events that have occurred. */\n out: ptr>,\n /** Input: Both the number of subscriptions and events. */\n nsubscriptions: usize,\n /** Output: The number of events stored. */\n nevents: ptr\n): errno;\n\n/** Terminate the process normally. An exit code of 0 indicates successful termination of the program. The meanings of other values is dependent on the environment. */\nexport declare function proc_exit(\n /** Input: The exit code returned by the process. */\n rval: u32\n): void;\n\n/** Send a signal to the process of the calling thread. */\nexport declare function proc_raise(\n /** Input: The signal condition to trigger. */\n sig: signal\n): errno;\n\n/** Write high-quality random data into a buffer. */\nexport declare function random_get(\n /** Input: The buffer to fill with random data. */\n buf: usize,\n /** Input: The length of the buffer to fill with random data. */\n buf_len: usize\n): errno;\n\n/** Temporarily yield execution of the calling thread. */\nexport declare function sched_yield(): errno;\n\n/** Receive a message from a socket. */\nexport declare function sock_recv(\n /** Input: The socket on which to receive data. */\n sock: fd,\n /** Input: List of scatter/gather vectors to which to store data. */\n ri_data: ptr>,\n /** Input: The length of the list of scatter/gather vectors to which to store data. */\n ri_data_len: usize,\n /** Input: Message flags. */\n ri_flags: riflags,\n /** Output: Number of bytes stored in `ri_data`. */\n ro_datalen: ptr,\n /** Output: Message flags. */\n ro_flags: ptr\n): errno;\n\n/** Send a message on a socket. */\nexport declare function sock_send(\n /** Input: The socket on which to send data. */\n sock: fd,\n /** Input: List of scatter/gather vectors to which to retrieve data */\n si_data: ptr>,\n /** Input: The length of the list of scatter/gather vectors to which to retrieve data */\n si_data_len: usize,\n /** Input: Message flags. */\n si_flags: siflags,\n /** Output: Number of bytes transmitted. */\n so_datalen: ptr\n): errno;\n\n/** Shut down socket send and receive channels. */\nexport declare function sock_shutdown(\n /** Input: The socket on which to shutdown channels. */\n sock: fd,\n /** Input: Which channels on the socket to shut down. */\n how: sdflags\n): errno;\n\n// === Types ======================================================================================\n\n/** File or memory access pattern advisory information. */\nexport namespace advice {\n /** The application has no advice to give on its behavior with respect to the specified data. */\n // @ts-ignore: decorator\n @inline\n export const NORMAL: advice = 0;\n /** The application expects to access the specified data sequentially from lower offsets to higher offsets. */\n // @ts-ignore: decorator\n @inline\n export const SEQUENTIAL : advice = 1;\n /** The application expects to access the specified data in a random order. */\n // @ts-ignore: decorator\n @inline\n export const RANDOM: advice = 2;\n /** The application expects to access the specified data in the near future. */\n // @ts-ignore: decorator\n @inline\n export const WILLNEED: advice = 3;\n /** The application expects that it will not access the specified data in the near future. */\n // @ts-ignore: decorator\n @inline\n export const DONTNEED: advice = 4;\n /** The application expects to access the specified data once and then not reuse it thereafter. */\n // @ts-ignore: decorator\n @inline\n export const NOREUSE: advice = 5;\n}\nexport type advice = u8;\n\n/** Identifiers for clocks. */\nexport namespace clockid {\n /** The clock measuring real time. Time value zero corresponds with 1970-01-01T00:00:00Z. */\n // @ts-ignore: decorator\n @inline\n export const REALTIME: clockid = 0;\n /** The store-wide monotonic clock. Absolute value has no meaning. */\n // @ts-ignore: decorator\n @inline\n export const MONOTONIC: clockid = 1;\n /** The CPU-time clock associated with the current process. */\n // @ts-ignore: decorator\n @inline\n export const PROCESS_CPUTIME_ID: clockid = 2;\n /** The CPU-time clock associated with the current thread. */\n // @ts-ignore: decorator\n @inline\n export const THREAD_CPUTIME_ID: clockid = 3;\n}\nexport type clockid = u32;\n\n/** Identifier for a device containing a file system. Can be used in combination with `inode` to uniquely identify a file or directory in the filesystem. */\nexport type device = u64;\n\n/** A reference to the offset of a directory entry. */\nexport type dircookie = u64;\n\n/** A directory entry. */\n@unmanaged export class dirent {\n /** The offset of the next directory entry stored in this directory. */\n next: dircookie;\n /** The serial number of the file referred to by this directory entry. */\n ino: inode;\n /** The length of the name of the directory entry. */\n namlen: u32;\n /** The type of the file referred to by this directory entry. */\n type: filetype;\n private __padding0: u16;\n}\n\n/** Error codes returned by functions. */\nexport namespace errno {\n /** No error occurred. System call completed successfully. */\n // @ts-ignore: decorator\n @inline\n export const SUCCESS: errno = 0;\n /** Argument list too long. */\n // @ts-ignore: decorator\n @inline\n export const TOOBIG: errno = 1;\n /** Permission denied. */\n // @ts-ignore: decorator\n @inline\n export const ACCES: errno = 2;\n /** Address in use. */\n // @ts-ignore: decorator\n @inline\n export const ADDRINUSE: errno = 3;\n /** Address not available. */\n // @ts-ignore: decorator\n @inline\n export const ADDRNOTAVAIL: errno = 4;\n /** Address family not supported. */\n // @ts-ignore: decorator\n @inline\n export const AFNOSUPPORT: errno = 5;\n /** Resource unavailable, or operation would block. */\n // @ts-ignore: decorator\n @inline\n export const AGAIN: errno = 6;\n /** Connection already in progress. */\n // @ts-ignore: decorator\n @inline\n export const ALREADY: errno = 7;\n /** Bad file descriptor. */\n // @ts-ignore: decorator\n @inline\n export const BADF: errno = 8;\n /** Bad message. */\n // @ts-ignore: decorator\n @inline\n export const BADMSG: errno = 9;\n /** Device or resource busy. */\n // @ts-ignore: decorator\n @inline\n export const BUSY: errno = 10;\n /** Operation canceled. */\n // @ts-ignore: decorator\n @inline\n export const CANCELED: errno = 11;\n /** No child processes. */\n // @ts-ignore: decorator\n @inline\n export const CHILD: errno = 12;\n /** Connection aborted. */\n // @ts-ignore: decorator\n @inline\n export const CONNABORTED: errno = 13;\n /** Connection refused. */\n // @ts-ignore: decorator\n @inline\n export const CONNREFUSED: errno = 14;\n /** Connection reset. */\n // @ts-ignore: decorator\n @inline\n export const CONNRESET: errno = 15;\n /** Resource deadlock would occur. */\n // @ts-ignore: decorator\n @inline\n export const DEADLK: errno = 16;\n /** Destination address required. */\n // @ts-ignore: decorator\n @inline\n export const DESTADDRREQ: errno = 17;\n /** Mathematics argument out of domain of function. */\n // @ts-ignore: decorator\n @inline\n export const DOM: errno = 18;\n /** Reserved. */\n // @ts-ignore: decorator\n @inline\n export const DQUOT: errno = 19;\n /** File exists. */\n // @ts-ignore: decorator\n @inline\n export const EXIST: errno = 20;\n /** Bad address. */\n // @ts-ignore: decorator\n @inline\n export const FAULT: errno = 21;\n /** File too large. */\n // @ts-ignore: decorator\n @inline\n export const FBIG: errno = 22;\n /** Host is unreachable. */\n // @ts-ignore: decorator\n @inline\n export const HOSTUNREACH: errno = 23;\n /** Identifier removed. */\n // @ts-ignore: decorator\n @inline\n export const IDRM: errno = 24;\n /** Illegal byte sequence. */\n // @ts-ignore: decorator\n @inline\n export const ILSEQ: errno = 25;\n /** Operation in progress. */\n // @ts-ignore: decorator\n @inline\n export const INPROGRESS: errno = 26;\n /** Interrupted function. */\n // @ts-ignore: decorator\n @inline\n export const INTR: errno = 27;\n /** Invalid argument. */\n // @ts-ignore: decorator\n @inline\n export const INVAL: errno = 28;\n /** I/O error. */\n // @ts-ignore: decorator\n @inline\n export const IO: errno = 29;\n /** Socket is connected. */\n // @ts-ignore: decorator\n @inline\n export const ISCONN: errno = 30;\n /** Is a directory. */\n // @ts-ignore: decorator\n @inline\n export const ISDIR: errno = 31;\n /** Too many levels of symbolic links. */\n // @ts-ignore: decorator\n @inline\n export const LOOP: errno = 32;\n /** File descriptor value too large. */\n // @ts-ignore: decorator\n @inline\n export const MFILE: errno = 33;\n /** Too many links. */\n // @ts-ignore: decorator\n @inline\n export const MLINK: errno = 34;\n /** Message too large. */\n // @ts-ignore: decorator\n @inline\n export const MSGSIZE: errno = 35;\n /** Reserved. */\n // @ts-ignore: decorator\n @inline\n export const MULTIHOP: errno = 36;\n /** Filename too long. */\n // @ts-ignore: decorator\n @inline\n export const NAMETOOLONG: errno = 37;\n /** Network is down. */\n // @ts-ignore: decorator\n @inline\n export const NETDOWN: errno = 38;\n /** Connection aborted by network. */\n // @ts-ignore: decorator\n @inline\n export const NETRESET: errno = 39;\n /** Network unreachable. */\n // @ts-ignore: decorator\n @inline\n export const NETUNREACH: errno = 40;\n /** Too many files open in system. */\n // @ts-ignore: decorator\n @inline\n export const NFILE: errno = 41;\n /** No buffer space available. */\n // @ts-ignore: decorator\n @inline\n export const NOBUFS: errno = 42;\n /** No such device. */\n // @ts-ignore: decorator\n @inline\n export const NODEV: errno = 43;\n /** No such file or directory. */\n // @ts-ignore: decorator\n @inline\n export const NOENT: errno = 44;\n /** Executable file format error. */\n // @ts-ignore: decorator\n @inline\n export const NOEXEC: errno = 45;\n /** No locks available. */\n // @ts-ignore: decorator\n @inline\n export const NOLCK: errno = 46;\n /** Reserved. */\n // @ts-ignore: decorator\n @inline\n export const NOLINK: errno = 47;\n /** Not enough space. */\n // @ts-ignore: decorator\n @inline\n export const NOMEM: errno = 48;\n /** No message of the desired type. */\n // @ts-ignore: decorator\n @inline\n export const NOMSG: errno = 49;\n /** Protocol not available. */\n // @ts-ignore: decorator\n @inline\n export const NOPROTOOPT: errno = 50;\n /** No space left on device. */\n // @ts-ignore: decorator\n @inline\n export const NOSPC: errno = 51;\n /** Function not supported. */\n // @ts-ignore: decorator\n @inline\n export const NOSYS: errno = 52;\n /** The socket is not connected. */\n // @ts-ignore: decorator\n @inline\n export const NOTCONN: errno = 53;\n /** Not a directory or a symbolic link to a directory. */\n // @ts-ignore: decorator\n @inline\n export const NOTDIR: errno = 54;\n /** Directory not empty. */\n // @ts-ignore: decorator\n @inline\n export const NOTEMPTY: errno = 55;\n /** State not recoverable. */\n // @ts-ignore: decorator\n @inline\n export const NOTRECOVERABLE: errno = 56;\n /** Not a socket. */\n // @ts-ignore: decorator\n @inline\n export const NOTSOCK: errno = 57;\n /** Not supported, or operation not supported on socket. */\n // @ts-ignore: decorator\n @inline\n export const NOTSUP: errno = 58;\n /** Inappropriate I/O control operation. */\n // @ts-ignore: decorator\n @inline\n export const NOTTY: errno = 59;\n /** No such device or address. */\n // @ts-ignore: decorator\n @inline\n export const NXIO: errno = 60;\n /** Value too large to be stored in data type. */\n // @ts-ignore: decorator\n @inline\n export const OVERFLOW: errno = 61;\n /** Previous owner died. */\n // @ts-ignore: decorator\n @inline\n export const OWNERDEAD: errno = 62;\n /** Operation not permitted. */\n // @ts-ignore: decorator\n @inline\n export const PERM: errno = 63;\n /** Broken pipe. */\n // @ts-ignore: decorator\n @inline\n export const PIPE: errno = 64;\n /** Protocol error. */\n // @ts-ignore: decorator\n @inline\n export const PROTO: errno = 65;\n /** Protocol not supported. */\n // @ts-ignore: decorator\n @inline\n export const PROTONOSUPPORT: errno = 66;\n /** Protocol wrong type for socket. */\n // @ts-ignore: decorator\n @inline\n export const PROTOTYPE: errno = 67;\n /** Result too large. */\n // @ts-ignore: decorator\n @inline\n export const RANGE: errno = 68;\n /** Read-only file system. */\n // @ts-ignore: decorator\n @inline\n export const ROFS: errno = 69;\n /** Invalid seek. */\n // @ts-ignore: decorator\n @inline\n export const SPIPE: errno = 70;\n /** No such process. */\n // @ts-ignore: decorator\n @inline\n export const SRCH: errno = 71;\n /** Reserved. */\n // @ts-ignore: decorator\n @inline\n export const STALE: errno = 72;\n /** Connection timed out. */\n // @ts-ignore: decorator\n @inline\n export const TIMEDOUT: errno = 73;\n /** Text file busy. */\n // @ts-ignore: decorator\n @inline\n export const TXTBSY: errno = 74;\n /** Cross-device link. */\n // @ts-ignore: decorator\n @inline\n export const XDEV: errno = 75;\n /** Extension: Capabilities insufficient. */\n // @ts-ignore: decorator\n @inline\n export const NOTCAPABLE: errno = 76;\n}\nexport type errno = u16;\n\n/** An event that occurred. */\n@unmanaged export abstract class event {\n /** User-provided value that got attached to `subscription#userdata`. */\n userdata: userdata;\n /** If non-zero, an error that occurred while processing the subscription request. */\n error: errno;\n /* The type of the event that occurred. */\n type: eventtype;\n private __padding0: u16;\n}\n\n/** An event that occurred when type is `eventtype.FD_READ` or `eventtype.FD_WRITE`. */\n@unmanaged export class rwevent extends event {\n /* The number of bytes available for reading or writing. */\n nbytes: filesize;\n /* The state of the file descriptor. */\n flags: eventrwflags;\n private __padding1: u32;\n}\n\n/** The state of the file descriptor subscribed to with `eventtype.FD_READ` or `eventtype.FD_WRITE`. */\nexport namespace eventrwflags {\n /** The peer of this socket has closed or disconnected. */\n // @ts-ignore: decorator\n @inline\n export const HANGUP: eventrwflags = 1;\n}\nexport type eventrwflags = u16;\n\n/** Type of a subscription to an event or its occurrence. */\nexport namespace eventtype {\n /** The time value of clock has reached the timestamp. */\n // @ts-ignore: decorator\n @inline\n export const CLOCK: eventtype = 0;\n /** File descriptor has data available for reading. */\n // @ts-ignore: decorator\n @inline\n export const FD_READ: eventtype = 1;\n /** File descriptor has capacity available for writing */\n // @ts-ignore: decorator\n @inline\n export const FD_WRITE: eventtype = 2;\n}\nexport type eventtype = u8;\n\n/** Exit code generated by a process when exiting. */\nexport type exitcode = u32;\n\n/** A file descriptor number. */\nexport type fd = u32;\n\n/** File descriptor flags. */\nexport namespace fdflags {\n /** Append mode: Data written to the file is always appended to the file's end. */\n // @ts-ignore: decorator\n @inline\n export const APPEND: fdflags = 1;\n /** Write according to synchronized I/O data integrity completion. Only the data stored in the file is synchronized. */\n // @ts-ignore: decorator\n @inline\n export const DSYNC: fdflags = 2;\n /** Non-blocking mode. */\n // @ts-ignore: decorator\n @inline\n export const NONBLOCK: fdflags = 4;\n /** Synchronized read I/O operations. */\n // @ts-ignore: decorator\n @inline\n export const RSYNC: fdflags = 8;\n /** Write according to synchronized I/O file integrity completion. */\n // @ts-ignore: decorator\n @inline\n export const SYNC: fdflags = 16;\n}\nexport type fdflags = u16;\n\n/** File descriptor attributes. */\n@unmanaged export class fdstat {\n /** File type. */\n filetype: filetype;\n /** File descriptor flags. */\n flags: fdflags;\n /** Rights that apply to this file descriptor. */\n rights_base: rights;\n /** Maximum set of rights that may be installed on new file descriptors that are created through this file descriptor, e.g., through `path_open`. */\n rights_inheriting: rights;\n}\n\n/** Relative offset within a file. */\nexport type filedelta = i64;\n\n/** Non-negative file size or length of a region within a file. */\nexport type filesize = u64;\n\n/** File attributes. */\n@unmanaged export class filestat {\n /** Device ID of device containing the file. */\n dev: device;\n /** File serial number. */\n ino: inode;\n /** File type. */\n filetype: filetype;\n /** Number of hard links to the file. */\n nlink: linkcount;\n /** For regular files, the file size in bytes. For symbolic links, the length in bytes of the pathname contained in the symbolic link. */\n size: filesize;\n /** Last data access timestamp. */\n atim: timestamp;\n /** Last data modification timestamp. */\n mtim: timestamp;\n /** Last file status change timestamp. */\n ctim: timestamp;\n}\n\n/** The type of a file descriptor or file. */\nexport namespace filetype {\n /** The type of the file descriptor or file is unknown or is different from any of the other types specified. */\n // @ts-ignore: decorator\n @inline\n export const UNKNOWN: filetype = 0;\n /** The file descriptor or file refers to a block device inode. */\n // @ts-ignore: decorator\n @inline\n export const BLOCK_DEVICE: filetype = 1;\n /** The file descriptor or file refers to a character device inode. */\n // @ts-ignore: decorator\n @inline\n export const CHARACTER_DEVICE: filetype = 2;\n /** The file descriptor or file refers to a directory inode. */\n // @ts-ignore: decorator\n @inline\n export const DIRECTORY: filetype = 3;\n /** The file descriptor or file refers to a regular file inode. */\n // @ts-ignore: decorator\n @inline\n export const REGULAR_FILE: filetype = 4;\n /** The file descriptor or file refers to a datagram socket. */\n // @ts-ignore: decorator\n @inline\n export const SOCKET_DGRAM: filetype = 5;\n /** The file descriptor or file refers to a byte-stream socket. */\n // @ts-ignore: decorator\n @inline\n export const SOCKET_STREAM: filetype = 6;\n /** The file refers to a symbolic link inode. */\n // @ts-ignore: decorator\n @inline\n export const SYMBOLIC_LINK: filetype = 7;\n}\nexport type filetype = u8;\n\n/** Which file time attributes to adjust. */\nexport namespace fstflags {\n /** Adjust the last data access timestamp to the value stored in `filestat#st_atim`. */\n // @ts-ignore: decorator\n @inline\n export const SET_ATIM: fstflags = 1;\n /** Adjust the last data access timestamp to the time of clock `clockid.REALTIME`. */\n // @ts-ignore: decorator\n @inline\n export const SET_ATIM_NOW: fstflags = 2;\n /** Adjust the last data modification timestamp to the value stored in `filestat#st_mtim`. */\n // @ts-ignore: decorator\n @inline\n export const SET_MTIM: fstflags = 4;\n /** Adjust the last data modification timestamp to the time of clock `clockid.REALTIME`. */\n // @ts-ignore: decorator\n @inline\n export const SET_MTIM_NOW: fstflags = 8;\n}\nexport type fstflags = u16;\n\n/** File serial number that is unique within its file system. */\nexport type inode = u64;\n\n/** A region of memory for scatter/gather reads. */\n@unmanaged export class iovec {\n /** The address of the buffer to be filled. */\n buf: usize;\n /** The length of the buffer to be filled. */\n buf_len: usize;\n}\n\n/** Number of hard links to an inode. */\nexport type linkcount = u32;\n\n/** Flags determining the method of how paths are resolved. */\nexport namespace lookupflags {\n /** As long as the resolved path corresponds to a symbolic link, it is expanded. */\n // @ts-ignore: decorator\n @inline\n export const SYMLINK_FOLLOW: lookupflags = 1;\n}\nexport type lookupflags = u32;\n\n/** Open flags. */\nexport namespace oflags {\n /** Create file if it does not exist. */\n // @ts-ignore: decorator\n @inline\n export const CREAT: oflags = 1;\n /** Fail if not a directory. */\n // @ts-ignore: decorator\n @inline\n export const DIRECTORY: oflags = 2;\n /** Fail if file already exists. */\n // @ts-ignore: decorator\n @inline\n export const EXCL: oflags = 4;\n /** Truncate file to size 0. */\n // @ts-ignore: decorator\n @inline\n export const TRUNC: oflags = 8;\n}\nexport type oflags = u16;\n\n// TODO: undocumented\nexport namespace preopentype {\n // @ts-ignore: decorator\n @inline\n export const DIR: preopentype = 0;\n}\nexport type preopentype = u8;\n\n// TODO: undocumented\nexport abstract class prestat {\n type: preopentype;\n}\n\n// TODO: undocumented\nexport class dirprestat extends prestat {\n name_len: usize;\n}\n\n/** Flags provided to `sock_recv`. */\nexport namespace riflags {\n /** Returns the message without removing it from the socket's receive queue. */\n // @ts-ignore: decorator\n @inline\n export const PEEK: riflags = 1;\n /** On byte-stream sockets, block until the full amount of data can be returned. */\n // @ts-ignore: decorator\n @inline\n export const WAITALL: riflags = 2;\n}\nexport type riflags = u16;\n\n/** File descriptor rights, determining which actions may be performed. */\nexport namespace rights {\n /** The right to invoke `fd_datasync`. */\n // @ts-ignore: decorator\n @inline\n export const FD_DATASYNC: rights = 1;\n /** The right to invoke `fd_read` and `sock_recv`. */\n // @ts-ignore: decorator\n @inline\n export const FD_READ: rights = 2;\n /** The right to invoke `fd_seek`. This flag implies `rights.FD_TELL`. */\n // @ts-ignore: decorator\n @inline\n export const FD_SEEK: rights = 4;\n /** The right to invoke `fd_fdstat_set_flags`. */\n // @ts-ignore: decorator\n @inline\n export const FD_FDSTAT_SET_FLAGS: rights = 8;\n /** The right to invoke `fd_sync`. */\n // @ts-ignore: decorator\n @inline\n export const FD_SYNC: rights = 16;\n /** The right to invoke `fd_seek` in such a way that the file offset remains unaltered (i.e., `whence.CUR` with offset zero), or to invoke `fd_tell`). */\n // @ts-ignore: decorator\n @inline\n export const FD_TELL: rights = 32;\n /** The right to invoke `fd_write` and `sock_send`. If `rights.FD_SEEK` is set, includes the right to invoke `fd_pwrite`. */\n // @ts-ignore: decorator\n @inline\n export const FD_WRITE: rights = 64;\n /** The right to invoke `fd_advise`. */\n // @ts-ignore: decorator\n @inline\n export const FD_ADVISE: rights = 128;\n /** The right to invoke `fd_allocate`. */\n // @ts-ignore: decorator\n @inline\n export const FD_ALLOCATE: rights = 256;\n /** The right to invoke `path_create_directory`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_CREATE_DIRECTORY: rights = 512;\n /** If `rights.PATH_OPEN` is set, the right to invoke `path_open` with `oflags.CREAT`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_CREATE_FILE: rights = 1024;\n /** The right to invoke `path_link` with the file descriptor as the source directory. */\n // @ts-ignore: decorator\n @inline\n export const PATH_LINK_SOURCE: rights = 2048;\n /** The right to invoke `path_link` with the file descriptor as the target directory. */\n // @ts-ignore: decorator\n @inline\n export const PATH_LINK_TARGET: rights = 4096;\n /** The right to invoke `path_open`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_OPEN: rights = 8192;\n /** The right to invoke `fd_readdir`. */\n // @ts-ignore: decorator\n @inline\n export const FD_READDIR: rights = 16384;\n /** The right to invoke `path_readlink`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_READLINK: rights = 32768;\n /** The right to invoke `path_rename` with the file descriptor as the source directory. */\n // @ts-ignore: decorator\n @inline\n export const PATH_RENAME_SOURCE: rights = 65536;\n /** The right to invoke `path_rename` with the file descriptor as the target directory. */\n // @ts-ignore: decorator\n @inline\n export const PATH_RENAME_TARGET: rights = 131072;\n /** The right to invoke `path_filestat_get`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_FILESTAT_GET: rights = 262144;\n /** The right to change a file's size (there is no `path_filestat_set_size`). If `rights.PATH_OPEN` is set, includes the right to invoke `path_open` with `oflags.TRUNC`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_FILESTAT_SET_SIZE: rights = 524288;\n /** The right to invoke `path_filestat_set_times`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_FILESTAT_SET_TIMES: rights = 1048576;\n /** The right to invoke `fd_filestat_get`. */\n // @ts-ignore: decorator\n @inline\n export const FD_FILESTAT_GET: rights = 2097152;\n /** The right to invoke `fd_filestat_set_size`. */\n // @ts-ignore: decorator\n @inline\n export const FD_FILESTAT_SET_SIZE: rights = 4194304;\n /** The right to invoke `fd_filestat_set_times`. */\n // @ts-ignore: decorator\n @inline\n export const FD_FILESTAT_SET_TIMES: rights = 8388608;\n /** The right to invoke `path_symlink`. */\n // @ts-ignore: decorator\n @inline\n export const RIGHT_PATH_SYMLINK: rights = 16777216;\n /** The right to invoke `path_remove_directory`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_REMOVE_DIRECTORY: rights = 33554432;\n /** The right to invoke `path_unlink_file`. */\n // @ts-ignore: decorator\n @inline\n export const PATH_UNLINK_FILE: rights = 67108864;\n /** If `rights.FD_READ` is set, includes the right to invoke `poll_oneoff` to subscribe to `eventtype.FD_READ`. If `rights.FD_WRITE` is set, includes the right to invoke `poll_oneoff` to subscribe to `eventtype.FD_WRITE`. */\n // @ts-ignore: decorator\n @inline\n export const POLL_FD_READWRITE: rights = 134217728;\n /** The right to invoke `sock_shutdown`. */\n // @ts-ignore: decorator\n @inline\n export const SOCK_SHUTDOWN: rights = 268435456;\n}\nexport type rights = u64;\n\n/** Flags returned by `sock_recv`. */\nexport namespace roflags {\n /** Message data has been truncated. */\n // @ts-ignore: decorator\n @inline\n export const DATA_TRUNCATED: roflags = 1;\n}\nexport type roflags = u16;\n\n/** Which channels on a socket to shut down. */\nexport namespace sdflags {\n /** Disables further receive operations. */\n // @ts-ignore: decorator\n @inline\n export const RD: sdflags = 1;\n /** Disables further send operations. */\n // @ts-ignore: decorator\n @inline\n export const WR: sdflags = 2;\n}\nexport type sdflags = u8;\n\n/** Flags provided to `sock_send`. */\nexport namespace siflags {\n // As there are currently no flags defined, it must be set to zero.\n}\nexport type siflags = u16;\n\n/** Signal condition. */\nexport namespace signal {\n /** Hangup. */\n // @ts-ignore: decorator\n @inline\n export const HUP: signal = 1;\n /** Terminate interrupt signal. */\n // @ts-ignore: decorator\n @inline\n export const INT: signal = 2;\n /** Terminal quit signal. */\n // @ts-ignore: decorator\n @inline\n export const QUIT: signal = 3;\n /** Illegal instruction. */\n // @ts-ignore: decorator\n @inline\n export const ILL: signal = 4;\n /** Trace/breakpoint trap. */\n // @ts-ignore: decorator\n @inline\n export const TRAP: signal = 5;\n /** Process abort signal. */\n // @ts-ignore: decorator\n @inline\n export const ABRT: signal = 6;\n /** Access to an undefined portion of a memory object. */\n // @ts-ignore: decorator\n @inline\n export const BUS: signal = 7;\n /** Erroneous arithmetic operation. */\n // @ts-ignore: decorator\n @inline\n export const FPE: signal = 8;\n /** Kill. */\n // @ts-ignore: decorator\n @inline\n export const KILL: signal = 9;\n /** User-defined signal 1. */\n // @ts-ignore: decorator\n @inline\n export const USR1: signal = 10;\n /** Invalid memory reference. */\n // @ts-ignore: decorator\n @inline\n export const SEGV: signal = 11;\n /** User-defined signal 2. */\n // @ts-ignore: decorator\n @inline\n export const USR2: signal = 12;\n /** Write on a pipe with no one to read it. */\n // @ts-ignore: decorator\n @inline\n export const PIPE: signal = 13;\n /** Alarm clock. */\n // @ts-ignore: decorator\n @inline\n export const ALRM: signal = 14;\n /** Termination signal. */\n // @ts-ignore: decorator\n @inline\n export const TERM: signal = 15;\n /** Child process terminated, stopped, or continued. */\n // @ts-ignore: decorator\n @inline\n export const CHLD: signal = 16;\n /** Continue executing, if stopped. */\n // @ts-ignore: decorator\n @inline\n export const CONT: signal = 17;\n /** Stop executing. */\n // @ts-ignore: decorator\n @inline\n export const STOP: signal = 18;\n /** Terminal stop signal. */\n // @ts-ignore: decorator\n @inline\n export const TSTP: signal = 19;\n /** Background process attempting read. */\n // @ts-ignore: decorator\n @inline\n export const TTIN: signal = 20;\n /** Background process attempting write. */\n // @ts-ignore: decorator\n @inline\n export const TTOU: signal = 21;\n /** High bandwidth data is available at a socket. */\n // @ts-ignore: decorator\n @inline\n export const URG: signal = 22;\n /** CPU time limit exceeded. */\n // @ts-ignore: decorator\n @inline\n export const XCPU: signal = 23;\n /** File size limit exceeded. */\n // @ts-ignore: decorator\n @inline\n export const XFSZ: signal = 24;\n /** Virtual timer expired. */\n // @ts-ignore: decorator\n @inline\n export const VTALRM: signal = 25;\n // @ts-ignore: decorator\n @inline\n export const PROF: signal = 26;\n // @ts-ignore: decorator\n @inline\n export const WINCH: signal = 27;\n // @ts-ignore: decorator\n @inline\n export const POLL: signal = 28;\n // @ts-ignore: decorator\n @inline\n export const PWR: signal = 29;\n /** Bad system call. */\n // @ts-ignore: decorator\n @inline\n export const SYS: signal = 30;\n}\nexport type signal = u8;\n\n/** Flags determining how to interpret the timestamp provided in `subscription_t::u.clock.timeout. */\nexport namespace subclockflags {\n /** If set, treat the timestamp provided in `clocksubscription` as an absolute timestamp. */\n // @ts-ignore: decorator\n @inline\n export const ABSTIME: subclockflags = 1;\n}\nexport type subclockflags = u16;\n\n/** Subscription to an event. */\n@unmanaged export abstract class subscription {\n /** User-provided value that is attached to the subscription. */\n userdata: userdata;\n /** The type of the event to which to subscribe. */\n type: eventtype;\n private __padding0: u32;\n}\n\n/* Subscription to an event of type `eventtype.CLOCK`.**/\n@unmanaged export class clocksubscription extends subscription {\n /** The user-defined unique identifier of the clock. */\n identifier: userdata;\n /** The clock against which to compare the timestamp. */\n clock_id: clockid;\n /** The absolute or relative timestamp. */\n timeout: timestamp;\n /** The amount of time that the implementation may wait additionally to coalesce with other events. */\n precision: timestamp;\n /** Flags specifying whether the timeout is absolute or relative. */\n flags: subclockflags;\n private __padding1: u32;\n}\n\n/* Subscription to an event of type `eventtype.FD_READ` or `eventtype.FD_WRITE`.**/\n@unmanaged export class fdsubscription extends subscription {\n /** The file descriptor on which to wait for it to become ready for reading or writing. */\n fd: fd;\n}\n\n/** Timestamp in nanoseconds. */\nexport type timestamp = u64;\n\n/** User-provided value that may be attached to objects that is retained when extracted from the implementation. */\nexport type userdata = u64;\n\n/** The position relative to which to set the offset of the file descriptor. */\nexport namespace whence {\n /** Seek relative to current position. */\n // @ts-ignore: decorator\n @inline\n export const CUR: whence = 0;\n /** Seek relative to end-of-file. */\n // @ts-ignore: decorator\n @inline\n export const END: whence = 1;\n /** Seek relative to start-of-file. */\n // @ts-ignore: decorator\n @inline\n export const SET: whence = 2;\n}\nexport type whence = u8;\n","bindings/wasi":'export * from "./wasi_unstable";\n',builtins:'// @ts-ignore: decorator\n@builtin\nexport declare function isInteger(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isFloat(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isBoolean(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isSigned(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isReference(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isString(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isArray(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isArrayLike(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isFunction(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isNullable(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isDefined(expression: void): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isConstant(expression: void): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isManaged(value?: T): bool;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function clz(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function ctz(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function popcnt(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function rotl(value: T, shift: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function rotr(value: T, shift: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function abs(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function max(left: T, right: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function min(left: T, right: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function ceil(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function floor(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function copysign(left: T, right: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function nearest(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function reinterpret(value: number): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function sqrt(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function trunc(value: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function load(offset: usize, immOffset?: usize, immAlign?: usize): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function store(offset: usize, value: void, immOffset?: usize, immAlign?: usize): void;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function sizeof(): usize; // | u32 / u64\n\n// @ts-ignore: decorator\n@builtin\nexport declare function alignof(): usize; // | u32 / u64\n\n// @ts-ignore: decorator\n@builtin\nexport declare function offsetof(fieldName?: string): usize; // | u32 / u64\n\n// @ts-ignore: decorator\n@builtin\nexport declare function idof(): u32;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function select(ifTrue: T, ifFalse: T, condition: bool): T;\n\n// @ts-ignore: decorator\n@unsafe @builtin\nexport declare function unreachable(): void;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function changetype(value: void): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function assert(isTrueish: T, message?: string): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function unchecked(expr: T): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function call_indirect(target: void, ...args: void[]): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function call_direct(target: void, ...args: void[]): T;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function instantiate(...args: void[]): T;\n\nexport namespace atomic {\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: T, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg(ptr: usize, value: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg(ptr: usize, expected: T, replacement: T, immOffset?: usize): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function wait(ptr: usize, expected: T, timeout: i64): AtomicWaitResult;\n\n // @ts-ignore: decorator\n @builtin\n export declare function notify(ptr: usize, count: i32): i32;\n}\n\n// @ts-ignore: decorator\n@lazy\nexport const enum AtomicWaitResult {\n OK = 0,\n NOT_EQUAL = 1,\n TIMED_OUT = 2\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i8(value: void): i8;\n\nexport namespace i8 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: i8 = -128;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: i8 = 127;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i16(value: void): i16;\n\nexport namespace i16 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: i16 = -32768;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: i16 = 32767;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i32(value: void): i32;\n\nexport namespace i32 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: i32 = -2147483648;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: i32 = 2147483647;\n\n // @ts-ignore: decorator\n @builtin\n export declare function clz(value: i32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ctz(value: i32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function popcnt(value: i32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function rotl(value: i32, shift: i32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function rotr(value: i32, shift: i32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function reinterpret_f32(value: f32): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_s(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_u(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_s(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_u(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store8(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store16(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n\n export namespace atomic {\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_u(offset: usize, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_u(offset: usize, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store8(offset: usize, value: i32, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store16(offset: usize, value: i32, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: i32, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function wait(ptr: usize, expected: i32, timeout: i64): AtomicWaitResult;\n\n export namespace rmw8 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg_u(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n\n export namespace rmw16 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg_u(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg_u(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n\n export namespace rmw {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg(offset: usize, value: i32, immOffset?: usize): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n }\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i64(value: void): i64;\n\nexport namespace i64 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: i64 = -9223372036854775808;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: i64 = 9223372036854775807;\n\n // @ts-ignore: decorator\n @builtin\n export declare function clz(value: i64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ctz(value: i64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load32_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load32_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function popcnt(value: i64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function rotl(value: i64, shift: i64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function rotr(value: i64, shift: i64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function reinterpret_f64(value: f64): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store8(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store16(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store32(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n\n export namespace atomic {\n\n // @ts-ignore: decorator\n @builtin\n export declare function load8_u(offset: usize, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load16_u(offset: usize, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load32_u(offset: usize, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store8(offset: usize, value: i64, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store16(offset: usize, value: i64, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store32(offset: usize, value: i64, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: i64, immOffset?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function wait(ptr: usize, expected: i64, timeout: i64): AtomicWaitResult;\n\n export namespace rmw8 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n\n export namespace rmw16 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n\n export namespace rmw32 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n\n export namespace rmw {\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xchg(offset: usize, value: i64, immOffset?: usize): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function cmpxchg(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n }\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function isize(value: void): isize;\n\nexport namespace isize {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: isize = sizeof() == sizeof()\n ? -2147483648\n : -9223372036854775808;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: isize = sizeof() == sizeof()\n ? 2147483647\n : 9223372036854775807;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function u8(value: void): u8;\n\nexport namespace u8 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: u8 = 0;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: u8 = 255;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function u16(value: void): u16;\n\nexport namespace u16 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: u16 = 0;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: u16 = 65535;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function u32(value: void): u32;\n\nexport namespace u32 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: u32 = 0;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: u32 = 4294967295;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function u64(value: void): u64;\n\nexport namespace u64 {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: u64 = 0;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: u64 = 18446744073709551615;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function usize(value: void): usize;\n\nexport namespace usize {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: usize = 0;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: usize = sizeof() == sizeof()\n ? 4294967295\n : 18446744073709551615;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function bool(value: void): bool;\n\nexport namespace bool {\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE: bool = false;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE: bool = true;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function f32(value: void): f32;\n\nexport namespace f32 {\n\n // @ts-ignore: decorator\n @lazy\n export const EPSILON = reinterpret(0x34000000); // 0x1p-23f\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE = reinterpret(0x00000001); // 0x0.000001p+0f\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE = reinterpret(0x7F7FFFFF); // 0x1.fffffep+127f\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_NORMAL_VALUE = reinterpret(0x00800000); // 0x1p-126f\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_SAFE_INTEGER: f32 = -16777215;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_SAFE_INTEGER: f32 = 16777215;\n\n // @ts-ignore: decorator\n @builtin\n export declare function abs(value: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ceil(value: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function copysign(x: f32, y: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function floor(value: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize, immAlign?: usize): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function max(left: f32, right: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function min(left: f32, right: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function nearest(value: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function reinterpret_i32(value: i32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sqrt(value: f32): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: f32, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc(value: f32): f32;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function f64(value: void): f64;\n\nexport namespace f64 {\n\n // @ts-ignore: decorator\n @lazy\n export const EPSILON = reinterpret(0x3CB0000000000000); // 0x1p-52\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_VALUE = reinterpret(0x0000000000000001); // 0x0.0000000000001p+0\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_VALUE = reinterpret(0x7FEFFFFFFFFFFFFF); // 0x1.fffffffffffffp+1023\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_NORMAL_VALUE = reinterpret(0x0010000000000000); // 0x1p-1022\n\n // @ts-ignore: decorator\n @lazy\n export const MIN_SAFE_INTEGER: f64 = -9007199254740991;\n\n // @ts-ignore: decorator\n @lazy\n export const MAX_SAFE_INTEGER: f64 = 9007199254740991;\n\n // @ts-ignore: decorator\n @builtin\n export declare function abs(value: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ceil(value: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function copysign(x: f64, y: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function floor(value: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize, immAlign?: usize): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function max(left: f64, right: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function min(left: f64, right: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function nearest(value: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function reinterpret_i64(value: i64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sqrt(value: f64): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: f64, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc(value: f64): f64;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function v128(\n a: i8, b: i8, c: i8, d: i8, e: i8, f: i8, g: i8, h: i8,\n i: i8, j: i8, k: i8, l: i8, m: i8, n: i8, o: i8, p: i8\n): v128;\n\nexport namespace v128 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: T): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane(x: v128, idx: u8): T;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: T): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shuffle(a: v128, b: v128, ...lanes: u8[]): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function load(offset: usize, immOffset?: usize, immAlign?: usize): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function store(offset: usize, value: v128, immOffset?: usize, immAlign?: usize): void;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128; // except i64\n\n // @ts-ignore: decorator\n @builtin\n export declare function div(a: v128, b: v128): v128; // f32, f64 only\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_saturate(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_saturate(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shl(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function and(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function or(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function xor(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function not(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function bitselect(v1: v128, v2: v128, c: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function any_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function all_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function min(a: v128, b: v128): v128; // f32, f64 only\n\n // @ts-ignore: decorator\n @builtin\n export declare function max(a: v128, b: v128): v128; // f32, f64 only\n\n // @ts-ignore: decorator\n @builtin\n export declare function abs(a: v128): v128; // f32, f64 only\n\n // @ts-ignore: decorator\n @builtin\n export declare function sqrt(a: v128): v128; // f32, f64 only\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function convert(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc(a: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i8x16(\n a: i8, b: i8, c: i8, d: i8, e: i8, f: i8, g: i8, h: i8,\n i: i8, j: i8, k: i8, l: i8, m: i8, n: i8, o: i8, p: i8\n): v128;\n\nexport namespace i8x16 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: i8): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane_s(x: v128, idx: u8): i8;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane_u(x: v128, idx: u8): u8;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: i8): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_saturate_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_saturate_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_saturate_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_saturate_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shl(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_s(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_u(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function any_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function all_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_u(a: v128, b: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i16x8(a: i16, b: i16, c: i16, d: i16, e: i16, f: i16, g: i16, h: i16): v128;\n\nexport namespace i16x8 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: i16): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane_s(x: v128, idx: u8): i16;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane_u(x: v128, idx: u8): u16;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: i16): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_saturate_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add_saturate_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_saturate_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub_saturate_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shl(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_s(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_u(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function any_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function all_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_u(a: v128, b: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i32x4(a: i32, b: i32, c: i32, d: i32): v128;\n\nexport namespace i32x4 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane(x: v128, idx: u8): i32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shl(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_s(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_u(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function any_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function all_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_s(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge_u(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc_s_f32x4_sat(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc_u_f32x4_sat(a: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function i64x2(a: i64, b: i64): v128;\n\nexport namespace i64x2 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: i64): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane(x: v128, idx: u8): i64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: i64): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shl(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_s(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function shr_u(a: v128, b: i32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function any_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function all_true(a: v128): bool;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc_s_f64x2_sat(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function trunc_u_f64x2_sat(a: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function f32x4(a: f32, b: f32, c: f32, d: f32): v128;\n\nexport namespace f32x4 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: f32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane(x: v128, idx: u8): f32;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: f32): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function div(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function min(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function max(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function abs(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sqrt(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function convert_s_i32x4(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function convert_u_i32x4(a: v128): v128;\n}\n\n// @ts-ignore: decorator\n@builtin\nexport declare function f64x2(a: f64, b: f64): v128;\n\nexport namespace f64x2 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function splat(x: f64): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function extract_lane(x: v128, idx: u8): f64;\n\n // @ts-ignore: decorator\n @builtin\n export declare function replace_lane(x: v128, idx: u8, value: f64): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function add(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sub(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function mul(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function div(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function neg(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function min(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function max(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function abs(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function sqrt(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function eq(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ne(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function lt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function le(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function gt(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function ge(a: v128, b: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function convert_s_i64x2(a: v128): v128;\n\n // @ts-ignore: decorator\n @builtin\n export declare function convert_u_i64x2(a: v128): v128;\n}\n\nexport namespace v8x16 {\n\n // @ts-ignore: decorator\n @builtin\n export declare function shuffle(\n a: v128, b: v128,\n l0: u8, l1: u8, l2: u8, l3: u8, l4: u8, l5: u8, l6: u8, l7: u8,\n l8: u8, l9: u8, l10: u8, l11: u8, l12: u8, l13: u8, l14: u8, l15: u8\n ): v128;\n}\n\n// @ts-ignore: decorator\n@external("env", "abort")\ndeclare function abort(\n message?: string | null,\n fileName?: string | null,\n lineNumber?: u32,\n columnNumber?: u32\n): void;\n\n// @ts-ignore: decorator\n@external("env", "trace")\ndeclare function trace(\n message: string,\n n?: i32,\n a0?: f64,\n a1?: f64,\n a2?: f64,\n a3?: f64,\n a4?: f64\n): void;\n',dataview:'import { BLOCK_MAXSIZE } from "./rt/common";\nimport { ArrayBuffer } from "./arraybuffer";\nimport { E_INDEXOUTOFRANGE, E_INVALIDLENGTH } from "./util/error";\n\n// TODO: there is probably a smarter way to check byteOffset for accesses larger than 1 byte\n\nexport class DataView {\n\n private data: ArrayBuffer;\n private dataStart: usize;\n private dataLength: i32;\n\n constructor(\n buffer: ArrayBuffer,\n byteOffset: i32 = 0,\n byteLength: i32 = buffer.byteLength\n ) {\n if (\n i32(byteLength > BLOCK_MAXSIZE) |\n i32(byteOffset + byteLength > buffer.byteLength)\n ) throw new RangeError(E_INVALIDLENGTH);\n this.data = buffer; // retains\n var dataStart = changetype(buffer) + byteOffset;\n this.dataStart = dataStart;\n this.dataLength = byteLength;\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get byteOffset(): i32 {\n return (this.dataStart - changetype(this.data));\n }\n\n get byteLength(): i32 {\n return this.dataLength;\n }\n\n getFloat32(byteOffset: i32, littleEndian: boolean = false): f32 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n return littleEndian\n ? load(this.dataStart + byteOffset)\n : reinterpret(\n bswap(\n load(this.dataStart + byteOffset)\n )\n );\n }\n\n getFloat64(byteOffset: i32, littleEndian: boolean = false): f64 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n return littleEndian\n ? load(this.dataStart + byteOffset)\n : reinterpret(\n bswap(\n load(this.dataStart + byteOffset)\n )\n );\n }\n\n getInt8(byteOffset: i32): i8 {\n if (byteOffset >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + byteOffset);\n }\n\n getInt16(byteOffset: i32, littleEndian: boolean = false): i16 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 2 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result: i16 = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n getInt32(byteOffset: i32, littleEndian: boolean = false): i32 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result: i32 = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n getUint8(byteOffset: i32): u8 {\n if (byteOffset >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + byteOffset);\n }\n\n getUint16(byteOffset: i32, littleEndian: boolean = false): u16 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 2 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result: u16 = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n getUint32(byteOffset: i32, littleEndian: boolean = false): u32 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result: u32 = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n setFloat32(byteOffset: i32, value: f32, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n if (littleEndian) store(this.dataStart + byteOffset, value);\n else store(this.dataStart + byteOffset, bswap(reinterpret(value)));\n }\n\n setFloat64(byteOffset: i32, value: f64, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n if (littleEndian) store(this.dataStart + byteOffset, value);\n else store(this.dataStart + byteOffset, bswap(reinterpret(value)));\n }\n\n setInt8(byteOffset: i32, value: i8): void {\n if (byteOffset >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, value);\n }\n\n setInt16(byteOffset: i32, value: i16, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 2 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n setInt32(byteOffset: i32, value: i32, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n setUint8(byteOffset: i32, value: u8): void {\n if (byteOffset >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, value);\n }\n\n setUint16(byteOffset: i32, value: u16, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 2 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n setUint32(byteOffset: i32, value: u32, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 4 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n // Non-standard additions that make sense in WebAssembly, but won\'t work in JS:\n\n getInt64(byteOffset: i32, littleEndian: boolean = false): i64 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result: i64 = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n getUint64(byteOffset: i32, littleEndian: boolean = false): u64 {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n var result = load(this.dataStart + byteOffset);\n return littleEndian ? result : bswap(result);\n }\n\n setInt64(byteOffset: i32, value: i64, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n setUint64(byteOffset: i32, value: u64, littleEndian: boolean = false): void {\n if (\n i32(byteOffset < 0) |\n i32(byteOffset + 8 > this.dataLength)\n ) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + byteOffset, littleEndian ? value : bswap(value));\n }\n\n toString(): string {\n return "[object DataView]";\n }\n}\n',date:'import {\n UTC as Date_UTC,\n now as Date_now\n} from "./bindings/Date";\n\nexport class Date {\n\n @inline static UTC(\n year: i32,\n month: i32 = 0,\n day: i32 = 1,\n hour: i32 = 0,\n minute: i32 = 0,\n second: i32 = 0,\n millisecond: i64 = 0\n ): i64 {\n return Date_UTC(year, month, day, hour, minute, second, millisecond);\n }\n\n @inline static now(): i64 {\n return Date_now();\n }\n\n private value: i64;\n\n constructor(value: i64) {\n this.value = value;\n }\n\n getTime(): i64 {\n return this.value;\n }\n\n setTime(value: i64): i64 {\n this.value = value;\n return value;\n }\n}\n',diagnostics:"// @ts-ignore: decorator\n@builtin\nexport declare function ERROR(message?: string): void;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function WARNING(message?: string): void;\n\n// @ts-ignore: decorator\n@builtin\nexport declare function INFO(message?: string): void;\n",error:'export class Error {\n\n name: string = "Error";\n stack: string = ""; // TODO\n\n constructor(\n public message: string = ""\n ) {}\n\n toString(): string {\n var message = this.message;\n return message.length\n ? this.name + ": " + message\n : this.name;\n }\n}\n\nexport class RangeError extends Error {\n constructor(message: string = "") {\n super(message);\n this.name = "RangeError";\n }\n}\n\nexport class TypeError extends Error {\n constructor(message: string = "") {\n super(message);\n this.name = "TypeError";\n }\n}\n\nexport class SyntaxError extends Error {\n constructor(message: string = "") {\n super(message);\n this.name = "SyntaxError";\n }\n}\n',fixedarray:'/// \n\nimport { BLOCK, BLOCK_OVERHEAD, BLOCK_MAXSIZE } from "./rt/common";\nimport { idof } from "./builtins";\nimport { E_INDEXOUTOFRANGE, E_INVALIDLENGTH, E_HOLEYARRAY } from "./util/error";\n\n// NOTE: DO NOT USE YET!\n\n// TODO: FixedArray with S being the static size, i.e. `new FixedArray`.\n// Then hard-wire this special type to the compiler and do static length checks instead :)\n\nexport class FixedArray {\n [key: number]: T;\n\n constructor(length: i32) {\n if (length > BLOCK_MAXSIZE >>> alignof()) throw new RangeError(E_INVALIDLENGTH);\n if (isReference()) {\n if (!isNullable()) {\n if (length) throw new Error(E_HOLEYARRAY);\n }\n }\n var outSize = length << alignof();\n var out = __alloc(outSize, idof>());\n memory.fill(out, 0, outSize);\n return changetype>(out); // retains\n }\n\n get length(): i32 {\n return changetype(changetype(this) - BLOCK_OVERHEAD).rtSize >>> alignof();\n }\n\n @operator("[]") private __get(index: i32): T {\n if (index >= this.length) throw new RangeError(E_INDEXOUTOFRANGE);\n return this.__unchecked_get(index);\n }\n\n @operator("[]=") private __set(index: i32, value: T): void {\n if (index >= this.length) throw new RangeError(E_INDEXOUTOFRANGE);\n this.__unchecked_set(index, value);\n }\n\n @operator("{}") private __unchecked_get(index: i32): T {\n return load(changetype(this) + (index << alignof()));\n }\n\n @operator("{}=") private __unchecked_set(index: i32, value: T): void {\n if (isManaged()) {\n let offset = changetype(this) + (index << alignof());\n let oldValue = load(offset);\n if (changetype(value) != oldValue) {\n store(offset, __retain(changetype(value)));\n __release(changetype(oldValue));\n }\n } else {\n store(changetype(this) + (index << alignof()), value);\n }\n }\n\n // RT integration\n\n @unsafe private __visit_impl(cookie: u32): void {\n if (isManaged()) {\n let cur = changetype(this);\n let end = cur + changetype(changetype(this) - BLOCK_OVERHEAD).rtSize;\n while (cur < end) {\n let val = load(cur);\n if (val) __visit(val, cookie);\n cur += sizeof();\n }\n }\n }\n}\n',heap:"// @ts-ignore: decorator\n@builtin\nexport declare const __heap_base: usize;\n",iterator:"export abstract class Iterable {\n // ?\n}\n\n@sealed\nexport abstract class Iterator {\n\n // private constructor(iterable: Iterable) {\n // }\n\n // TODO: these need to evaluate the classId at the respective reference in order to obtain the\n // next value, i.e. arrays work differently than maps. we'd then have:\n //\n // ╒═══════════════════ Iterator layout (32-bit) ══════════════════╕\n // 3 2 1\n // 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n // ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤\n // │ index │\n // ├─────────────────────────────────────────────────────────┬───┬─┤\n // │ reference │ 0 │D│\n // └─────────────────────────────────────────────────────────┴───┴─┘\n // D: Done flag\n\n // get value(this: u64): T {\n // ?\n // }\n\n // next(this: u64): Iterator {\n // ?\n // }\n\n done(this: u64): bool {\n return (this & 1);\n }\n}\n",map:'/// \n\nimport { HASH } from "./util/hash";\nimport { E_KEYNOTFOUND } from "util/error";\n\n// A deterministic hash map based on CloseTable from https://github.com/jorendorff/dht\n\n// @ts-ignore: decorator\n@inline\nconst INITIAL_CAPACITY = 4;\n\n// @ts-ignore: decorator\n@inline\nconst FILL_FACTOR: f64 = 8 / 3;\n\n// @ts-ignore: decorator\n@inline\nconst FREE_FACTOR: f64 = 3 / 4;\n\n/** Structure of a map entry. */\n@unmanaged class MapEntry {\n key: K;\n value: V;\n taggedNext: usize; // LSB=1 indicates EMPTY\n}\n\n/** Empty bit. */\n// @ts-ignore: decorator\n@inline\nconst EMPTY: usize = 1 << 0;\n\n/** Size of a bucket. */\n// @ts-ignore: decorator\n@inline\nconst BUCKET_SIZE = sizeof();\n\n/** Computes the alignment of an entry. */\n// @ts-ignore: decorator\n@inline\nfunction ENTRY_ALIGN(): usize {\n // can align to 4 instead of 8 if 32-bit and K/V is <= 32-bits\n const maxkv = sizeof() > sizeof() ? sizeof() : sizeof();\n const align = (maxkv > sizeof() ? maxkv : sizeof()) - 1;\n return align;\n}\n\n/** Computes the aligned size of an entry. */\n// @ts-ignore: decorator\n@inline\nfunction ENTRY_SIZE(): usize {\n const align = ENTRY_ALIGN();\n const size = (offsetof>() + align) & ~align;\n return size;\n}\n\nexport class Map {\n\n // buckets holding references to the respective first entry within\n private buckets: ArrayBuffer; // usize[bucketsMask + 1]\n private bucketsMask: u32;\n\n // entries in insertion order\n private entries: ArrayBuffer; // MapEntry[entriesCapacity]\n private entriesCapacity: i32;\n private entriesOffset: i32;\n private entriesCount: i32;\n\n get size(): i32 { return this.entriesCount; }\n\n constructor() {\n this.clear();\n }\n\n clear(): void {\n const bucketsSize = INITIAL_CAPACITY * BUCKET_SIZE;\n this.buckets = new ArrayBuffer(bucketsSize);\n this.bucketsMask = INITIAL_CAPACITY - 1;\n const entriesSize = INITIAL_CAPACITY * ENTRY_SIZE();\n this.entries = new ArrayBuffer(entriesSize);\n this.entriesCapacity = INITIAL_CAPACITY;\n this.entriesOffset = 0;\n this.entriesCount = 0;\n }\n\n private find(key: K, hashCode: u32): MapEntry | null {\n var entry = load>( // unmanaged!\n changetype(this.buckets) + (hashCode & this.bucketsMask) * BUCKET_SIZE\n );\n while (entry) {\n if (!(entry.taggedNext & EMPTY) && entry.key == key) return entry;\n entry = changetype>(entry.taggedNext & ~EMPTY);\n }\n return null;\n }\n\n has(key: K): bool {\n return this.find(key, HASH(key)) !== null;\n }\n\n @operator("[]")\n get(key: K): V {\n var entry = this.find(key, HASH(key));\n if (!entry) throw new Error(E_KEYNOTFOUND); // cannot represent `undefined`\n return entry.value;\n }\n\n @operator("[]=")\n set(key: K, value: V): void {\n var hashCode = HASH(key);\n var entry = this.find(key, hashCode); // unmanaged!\n if (entry) {\n if (isManaged()) {\n let oldRef = changetype(entry.value);\n if (changetype(value) != oldRef) {\n entry.value = changetype(__retain(changetype(value)));\n __release(oldRef);\n }\n } else {\n entry.value = value;\n }\n } else {\n // check if rehashing is necessary\n if (this.entriesOffset == this.entriesCapacity) {\n this.rehash(\n this.entriesCount < (this.entriesCapacity * FREE_FACTOR)\n ? this.bucketsMask // just rehash if 1/4+ entries are empty\n : (this.bucketsMask << 1) | 1 // grow capacity to next 2^N\n );\n }\n // append new entry\n let entries = this.entries;\n entry = changetype>(changetype(entries) + this.entriesOffset++ * ENTRY_SIZE());\n // link with the map\n entry.key = isManaged()\n ? changetype(__retain(changetype(key)))\n : key;\n entry.value = isManaged()\n ? changetype(__retain(changetype(value)))\n : value;\n ++this.entriesCount;\n // link with previous entry in bucket\n let bucketPtrBase = changetype(this.buckets) + (hashCode & this.bucketsMask) * BUCKET_SIZE;\n entry.taggedNext = load(bucketPtrBase);\n store(bucketPtrBase, changetype(entry));\n }\n }\n\n delete(key: K): bool {\n var entry = this.find(key, HASH(key));\n if (!entry) return false;\n if (isManaged()) __release(changetype(entry.key));\n if (isManaged()) __release(changetype(entry.value));\n entry.taggedNext |= EMPTY;\n --this.entriesCount;\n // check if rehashing is appropriate\n var halfBucketsMask = this.bucketsMask >> 1;\n if (\n halfBucketsMask + 1 >= max(INITIAL_CAPACITY, this.entriesCount) &&\n this.entriesCount < (this.entriesCapacity * FREE_FACTOR)\n ) this.rehash(halfBucketsMask);\n return true;\n }\n\n private rehash(newBucketsMask: u32): void {\n var newBucketsCapacity = (newBucketsMask + 1);\n var newBuckets = new ArrayBuffer(newBucketsCapacity * BUCKET_SIZE);\n var newEntriesCapacity = (newBucketsCapacity * FILL_FACTOR);\n var newEntries = new ArrayBuffer(newEntriesCapacity * ENTRY_SIZE());\n\n // copy old entries to new entries\n var oldPtr = changetype(this.entries);\n var oldEnd = oldPtr + this.entriesOffset * ENTRY_SIZE();\n var newPtr = changetype(newEntries);\n while (oldPtr != oldEnd) {\n let oldEntry = changetype>(oldPtr);\n if (!(oldEntry.taggedNext & EMPTY)) {\n let newEntry = changetype>(newPtr);\n newEntry.key = oldEntry.key;\n newEntry.value = oldEntry.value;\n let newBucketIndex = HASH(oldEntry.key) & newBucketsMask;\n let newBucketPtrBase = changetype(newBuckets) + newBucketIndex * BUCKET_SIZE;\n newEntry.taggedNext = load(newBucketPtrBase);\n store(newBucketPtrBase, newPtr);\n newPtr += ENTRY_SIZE();\n }\n oldPtr += ENTRY_SIZE();\n }\n\n this.buckets = newBuckets;\n this.bucketsMask = newBucketsMask;\n this.entries = newEntries;\n this.entriesCapacity = newEntriesCapacity;\n this.entriesOffset = this.entriesCount;\n }\n\n keys(): K[] {\n // FIXME: this is preliminary, needs iterators/closures\n var start = changetype(this.entries);\n var size = this.entriesOffset;\n var keys = Array.create(size);\n for (let i = 0; i < size; ++i) {\n let entry = changetype>(start + i * ENTRY_SIZE());\n if (!(entry.taggedNext & EMPTY)) {\n keys.push(entry.key);\n }\n }\n return keys;\n }\n\n values(): V[] {\n // FIXME: this is preliminary, needs iterators/closures\n var start = changetype(this.entries);\n var size = this.entriesOffset;\n var values = Array.create(size);\n for (let i = 0; i < size; ++i) {\n let entry = changetype>(start + i * ENTRY_SIZE());\n if (!(entry.taggedNext & EMPTY)) {\n values.push(entry.value);\n }\n }\n return values;\n }\n\n toString(): string {\n return "[object Map]";\n }\n\n // RT integration\n\n @unsafe private __visit_impl(cookie: u32): void {\n __visit(changetype(this.buckets), cookie);\n var entries = changetype(this.entries);\n if (isManaged() || isManaged()) {\n let cur = entries;\n let end = cur + this.entriesOffset * ENTRY_SIZE();\n while (cur < end) {\n let entry = changetype>(cur);\n if (!(entry.taggedNext & EMPTY)) {\n if (isManaged()) {\n let val = changetype(entry.key);\n if (isNullable()) {\n if (val) __visit(val, cookie);\n } else __visit(val, cookie);\n }\n if (isManaged()) {\n let val = changetype(entry.value);\n if (isNullable()) {\n if (val) __visit(val, cookie);\n } else __visit(val, cookie);\n }\n }\n cur += ENTRY_SIZE();\n }\n }\n __visit(entries, cookie);\n }\n}\n',math:'import * as JSMath from "./bindings/Math";\nexport { JSMath };\n\nimport {\n abs as builtin_abs,\n ceil as builtin_ceil,\n clz as builtin_clz,\n copysign as builtin_copysign,\n floor as builtin_floor,\n max as builtin_max,\n min as builtin_min,\n sqrt as builtin_sqrt,\n trunc as builtin_trunc\n} from "./builtins";\n\n// SUN COPYRIGHT NOTICE\n//\n// Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.\n// Developed at SunPro, a Sun Microsystems, Inc. business.\n// Permission to use, copy, modify, and distribute this software\n// is freely granted, provided that this notice is preserved.\n//\n// Applies to all functions marked with a comment referring here.\n\n// TODO: sin, cos, tan for Math namespace\n\n/** @internal */\nfunction R(z: f64): f64 { // Rational approximation of (asin(x)-x)/x^3\n const // see: musl/src/math/asin.c and SUN COPYRIGHT NOTICE above\n pS0 = reinterpret(0x3FC5555555555555), // 1.66666666666666657415e-01\n pS1 = reinterpret(0xBFD4D61203EB6F7D), // -3.25565818622400915405e-01\n pS2 = reinterpret(0x3FC9C1550E884455), // 2.01212532134862925881e-01\n pS3 = reinterpret(0xBFA48228B5688F3B), // -4.00555345006794114027e-02\n pS4 = reinterpret(0x3F49EFE07501B288), // 7.91534994289814532176e-04\n pS5 = reinterpret(0x3F023DE10DFDF709), // 3.47933107596021167570e-05\n qS1 = reinterpret(0xC0033A271C8A2D4B), // -2.40339491173441421878e+00\n qS2 = reinterpret(0x40002AE59C598AC8), // 2.02094576023350569471e+00\n qS3 = reinterpret(0xBFE6066C1B8D0159), // -6.88283971605453293030e-01\n qS4 = reinterpret(0x3FB3B8C5B12E9282); // 7.70381505559019352791e-02\n var p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5)))));\n var q = 1.0 + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4)));\n return p / q;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction expo2(x: f64): f64 { // exp(x)/2 for x >= log(DBL_MAX)\n const // see: musl/src/math/__expo2.c\n k = 2043,\n kln2 = reinterpret(0x40962066151ADD8B); // 0x1.62066151add8bp+10\n var scale = reinterpret(((0x3FF + k / 2) << 20) << 32);\n return NativeMath.exp(x - kln2) * scale * scale;\n}\n\n// @ts-ignore: decorator\n@lazy\nvar random_seeded = false;\n\n// @ts-ignore: decorator\n@lazy\nvar random_state0_64: u64;\n\n// @ts-ignore: decorator\n@lazy\nvar random_state1_64: u64;\n\n// @ts-ignore: decorator\n@lazy\nvar random_state0_32: u32;\n\n// @ts-ignore: decorator\n@lazy\nvar random_state1_32: u32;\n\nfunction murmurHash3(h: u64): u64 { // Force all bits of a hash block to avalanche\n h ^= h >> 33; // see: https://github.com/aappleby/smhasher\n h *= 0xFF51AFD7ED558CCD;\n h ^= h >> 33;\n h *= 0xC4CEB9FE1A85EC53;\n h ^= h >> 33;\n return h;\n}\n\nfunction splitMix32(h: u32): u32 {\n h += 0x6D2B79F5;\n h = (h ^ (h >> 15)) * (h | 1);\n h ^= h + (h ^ (h >> 7)) * (h | 61);\n return h ^ (h >> 14);\n}\n\nexport namespace NativeMath {\n\n // @ts-ignore: decorator\n @lazy\n export const E = reinterpret(0x4005BF0A8B145769); // 2.7182818284590452354\n\n // @ts-ignore: decorator\n @lazy\n export const LN2 = reinterpret(0x3FE62E42FEFA39EF); // 0.69314718055994530942\n\n // @ts-ignore: decorator\n @lazy\n export const LN10 = reinterpret(0x40026BB1BBB55516); // 2.30258509299404568402\n\n // @ts-ignore: decorator\n @lazy\n export const LOG2E = reinterpret(0x3FF71547652B82FE); // 1.4426950408889634074\n\n // @ts-ignore: decorator\n @lazy\n export const LOG10E = reinterpret(0x3FDBCB7B1526E50E); // 0.43429448190325182765\n\n // @ts-ignore: decorator\n @lazy\n export const PI = reinterpret(0x400921FB54442D18); // 3.14159265358979323846\n\n // @ts-ignore: decorator\n @lazy\n export const SQRT1_2 = reinterpret(0x3FE6A09E667F3BCD); // 0.70710678118654752440\n\n // @ts-ignore: decorator\n @lazy\n export const SQRT2 = reinterpret(0x3FF6A09E667F3BCD); // 1.41421356237309504880\n\n // @ts-ignore: decorator\n @inline export function abs(x: f64): f64 {\n return builtin_abs(x);\n }\n\n export function acos(x: f64): f64 { // see: musl/src/math/acos.c and SUN COPYRIGHT NOTICE above\n const\n pio2_hi = reinterpret(0x3FF921FB54442D18), // 1.57079632679489655800e+00\n pio2_lo = reinterpret(0x3C91A62633145C07), // 6.12323399573676603587e-17\n Ox1p_120f = reinterpret(0x03800000);\n var hx = (reinterpret(x) >> 32);\n var ix = hx & 0x7FFFFFFF;\n if (ix >= 0x3FF00000) {\n let lx = reinterpret(x);\n if ((ix - 0x3FF00000 | lx) == 0) {\n if (hx >> 31) return 2 * pio2_hi + Ox1p_120f;\n return 0;\n }\n return 0 / (x - x);\n }\n if (ix < 0x3FE00000) {\n if (ix <= 0x3C600000) return pio2_hi + Ox1p_120f;\n return pio2_hi - (x - (pio2_lo - x * R(x * x)));\n }\n var s: f64, w: f64, z: f64;\n if (hx >> 31) {\n // z = (1.0 + x) * 0.5;\n z = 0.5 + x * 0.5;\n s = builtin_sqrt(z);\n w = R(z) * s - pio2_lo;\n return 2 * (pio2_hi - (s + w));\n }\n // z = (1.0 - x) * 0.5;\n z = 0.5 - x * 0.5;\n s = builtin_sqrt(z);\n var df = reinterpret(reinterpret(s) & 0xFFFFFFFF00000000);\n var c = (z - df * df) / (s + df);\n w = R(z) * s + c;\n return 2 * (df + w);\n }\n\n export function acosh(x: f64): f64 { // see: musl/src/math/acosh.c\n const s = reinterpret(0x3FE62E42FEFA39EF);\n var e = reinterpret(x) >> 52 & 0x7FF;\n if (e < 0x3FF + 1) return log1p(x - 1 + builtin_sqrt((x - 1) * (x - 1) + 2 * (x - 1)));\n if (e < 0x3FF + 26) return log(2 * x - 1 / (x + builtin_sqrt(x * x - 1)));\n return log(x) + s;\n }\n\n export function asin(x: f64): f64 { // see: musl/src/math/asin.c and SUN COPYRIGHT NOTICE above\n const\n pio2_hi = reinterpret(0x3FF921FB54442D18), // 1.57079632679489655800e+00\n pio2_lo = reinterpret(0x3C91A62633145C07), // 6.12323399573676603587e-17\n Ox1p_120f = reinterpret(0x03800000);\n var hx = (reinterpret(x) >> 32);\n var ix = hx & 0x7FFFFFFF;\n if (ix >= 0x3FF00000) {\n let lx = reinterpret(x);\n if ((ix - 0x3FF00000 | lx) == 0) return x * pio2_hi + Ox1p_120f;\n return 0 / (x - x);\n }\n if (ix < 0x3FE00000) {\n if (ix < 0x3E500000 && ix >= 0x00100000) return x;\n return x + x * R(x * x);\n }\n // var z = (1.0 - builtin_abs(x)) * 0.5;\n var z = 0.5 - builtin_abs(x) * 0.5;\n var s = builtin_sqrt(z);\n var r = R(z);\n if (ix >= 0x3FEF3333) x = pio2_hi - (2 * (s + s * r) - pio2_lo);\n else {\n let f = reinterpret(reinterpret(s) & 0xFFFFFFFF00000000);\n let c = (z - f * f) / (s + f);\n x = 0.5 * pio2_hi - (2 * s * r - (pio2_lo - 2 * c) - (0.5 * pio2_hi - 2 * f));\n }\n if (hx >> 31) return -x;\n return x;\n }\n\n export function asinh(x: f64): f64 { // see: musl/src/math/asinh.c\n const c = reinterpret(0x3FE62E42FEFA39EF); // 0.693147180559945309417232121458176568\n var u = reinterpret(x);\n var e = u >> 52 & 0x7FF;\n var y = reinterpret(u & 0x7FFFFFFFFFFFFFFF);\n if (e >= 0x3FF + 26) y = log(y) + c;\n else if (e >= 0x3FF + 1) y = log(2 * y + 1 / (builtin_sqrt(y * y + 1) + y));\n else if (e >= 0x3FF - 26) y = log1p(y + y * y / (builtin_sqrt(y * y + 1) + 1));\n return builtin_copysign(y, x);\n }\n\n export function atan(x: f64): f64 { // see musl/src/math/atan.c and SUN COPYRIGHT NOTICE above\n const\n atanhi0 = reinterpret(0x3FDDAC670561BB4F), // 4.63647609000806093515e-01\n atanhi1 = reinterpret(0x3FE921FB54442D18), // 7.85398163397448278999e-01\n atanhi2 = reinterpret(0x3FEF730BD281F69B), // 9.82793723247329054082e-01\n atanhi3 = reinterpret(0x3FF921FB54442D18), // 1.57079632679489655800e+00\n atanlo0 = reinterpret(0x3C7A2B7F222F65E2), // 2.26987774529616870924e-17\n atanlo1 = reinterpret(0x3C81A62633145C07), // 3.06161699786838301793e-17\n atanlo2 = reinterpret(0x3C7007887AF0CBBD), // 1.39033110312309984516e-17\n atanlo3 = reinterpret(0x3C91A62633145C07), // 6.12323399573676603587e-17\n aT0 = reinterpret(0x3FD555555555550D), // 3.33333333333329318027e-01\n aT1 = reinterpret(0xBFC999999998EBC4), // -1.99999999998764832476e-01\n aT2 = reinterpret(0x3FC24924920083FF), // 1.42857142725034663711e-01\n aT3 = reinterpret(0xBFBC71C6FE231671), // -1.11111104054623557880e-01,\n aT4 = reinterpret(0x3FB745CDC54C206E), // 9.09088713343650656196e-02\n aT5 = reinterpret(0xBFB3B0F2AF749A6D), // -7.69187620504482999495e-02\n aT6 = reinterpret(0x3FB10D66A0D03D51), // 6.66107313738753120669e-02\n aT7 = reinterpret(0xBFADDE2D52DEFD9A), // -5.83357013379057348645e-02\n aT8 = reinterpret(0x3FA97B4B24760DEB), // 4.97687799461593236017e-02\n aT9 = reinterpret(0xBFA2B4442C6A6C2F), // -3.65315727442169155270e-02\n aT10 = reinterpret(0x3F90AD3AE322DA11), // 1.62858201153657823623e-02\n Ox1p_120f = reinterpret(0x03800000);\n var ix = (reinterpret(x) >> 32);\n var sx = x;\n ix &= 0x7FFFFFFF;\n var z: f64;\n if (ix >= 0x44100000) {\n if (isNaN(x)) return x;\n z = atanhi3 + Ox1p_120f;\n return builtin_copysign(z, sx);\n }\n var id: i32;\n if (ix < 0x3FDC0000) {\n if (ix < 0x3E400000) return x;\n id = -1;\n } else {\n x = builtin_abs(x);\n if (ix < 0x3FF30000) {\n if (ix < 0x3FE60000) {\n id = 0;\n x = (2.0 * x - 1.0) / (2.0 + x);\n } else {\n id = 1;\n x = (x - 1.0) / (x + 1.0);\n }\n } else {\n if (ix < 0x40038000) {\n id = 2;\n x = (x - 1.5) / (1.0 + 1.5 * x);\n } else {\n id = 3;\n x = -1.0 / x;\n }\n }\n }\n z = x * x;\n var w = z * z;\n var s1 = z * (aT0 + w * (aT2 + w * (aT4 + w * (aT6 + w * (aT8 + w * aT10)))));\n var s2 = w * (aT1 + w * (aT3 + w * (aT5 + w * (aT7 + w * aT9))));\n var s3 = x * (s1 + s2);\n if (id < 0) return x - s3;\n switch (id) {\n case 0: { z = atanhi0 - ((s3 - atanlo0) - x); break; }\n case 1: { z = atanhi1 - ((s3 - atanlo1) - x); break; }\n case 2: { z = atanhi2 - ((s3 - atanlo2) - x); break; }\n case 3: { z = atanhi3 - ((s3 - atanlo3) - x); break; }\n default: unreachable();\n }\n return builtin_copysign(z, sx);\n }\n\n export function atanh(x: f64): f64 { // see: musl/src/math/atanh.c\n var u = reinterpret(x);\n var e = u >> 52 & 0x7FF;\n var s = u >> 63;\n u &= 0x7FFFFFFFFFFFFFFF;\n var y = reinterpret(u);\n if (e < 0x3FF - 1) {\n if (e >= 0x3FF - 32) y = 0.5 * log1p(2 * y + 2 * y * y / (1 - y));\n } else {\n y = 0.5 * log1p(2 * (y / (1 - y)));\n }\n return builtin_copysign(y, x);\n }\n\n export function atan2(y: f64, x: f64): f64 { // see: musl/src/math/atan2.c and SUN COPYRIGHT NOTICE above\n const pi_lo = reinterpret(0x3CA1A62633145C07); // 1.2246467991473531772E-16\n if (isNaN(x) || isNaN(y)) return x + y;\n var u = reinterpret(x);\n var ix = (u >> 32);\n var lx = u;\n u = reinterpret(y);\n var iy = (u >> 32);\n var ly = u;\n if ((ix - 0x3FF00000 | lx) == 0) return atan(y);\n var m = ((iy >> 31) & 1) | ((ix >> 30) & 2);\n ix = ix & 0x7FFFFFFF;\n iy = iy & 0x7FFFFFFF;\n if ((iy | ly) == 0) {\n switch (m) {\n case 0:\n case 1: return y;\n case 2: return PI;\n case 3: return -PI;\n }\n }\n if ((ix | lx) == 0) return m & 1 ? -PI / 2 : PI / 2;\n if (ix == 0x7FF00000) {\n if (iy == 0x7FF00000) {\n switch (m) {\n case 0: return PI / 4;\n case 1: return -PI / 4;\n case 2: return 3 * PI / 4;\n case 3: return -3 * PI / 4;\n }\n } else {\n switch (m) {\n case 0: return 0.0;\n case 1: return -0.0;\n case 2: return PI;\n case 3: return -PI;\n }\n }\n }\n var z: f64;\n if (ix + (64 << 20) < iy || iy == 0x7FF00000) return m & 1 ? -PI / 2 : PI / 2;\n if ((m & 2) && iy + (64 << 20) < ix) z = 0;\n else z = atan(builtin_abs(y / x));\n switch (m) {\n case 0: return z;\n case 1: return -z;\n case 2: return PI - (z - pi_lo);\n case 3: return (z - pi_lo) - PI;\n }\n unreachable();\n return 0;\n }\n\n export function cbrt(x: f64): f64 { // see: musl/src/math/cbrt.c and SUN COPYRIGHT NOTICE above\n const\n B1 = 715094163,\n B2 = 696219795,\n P0 = reinterpret(0x3FFE03E60F61E692), // 1.87595182427177009643\n P1 = reinterpret(0xBFFE28E092F02420), // -1.88497979543377169875\n P2 = reinterpret(0x3FF9F1604A49D6C2), // 1.621429720105354466140\n P3 = reinterpret(0xBFE844CBBEE751D9), // -0.758397934778766047437\n P4 = reinterpret(0x3FC2B000D4E4EDD7), // 0.145996192886612446982\n Ox1p54 = reinterpret(0x4350000000000000);\n var u = reinterpret(x);\n var hx = (u >> 32) & 0x7FFFFFFF;\n if (hx >= 0x7FF00000) return x + x;\n if (hx < 0x00100000) {\n u = reinterpret(x * Ox1p54);\n hx = (u >> 32) & 0x7FFFFFFF;\n if (hx == 0) return x;\n hx = hx / 3 + B2;\n } else {\n hx = hx / 3 + B1;\n }\n u &= 1 << 63;\n u |= hx << 32;\n var t = reinterpret(u);\n var r = (t * t) * (t / x);\n t = t * ((P0 + r * (P1 + r * P2)) + ((r * r) * r) * (P3 + r * P4));\n t = reinterpret((reinterpret(t) + 0x80000000) & 0xFFFFFFFFC0000000);\n var s = t * t;\n r = x / s;\n r = (r - t) / (2 * t + r);\n t = t + t * r;\n return t;\n }\n\n // @ts-ignore: decorator\n @inline\n export function ceil(x: f64): f64 {\n return builtin_ceil(x);\n }\n\n export function clz32(x: f64): f64 {\n if (!isFinite(x)) return 32;\n /*\n * Wasm (MVP) and JS have different approaches for double->int conversions.\n *\n * For emulate JS conversion behavior and avoid trapping from wasm we should modulate by MAX_INT\n * our float-point arguments before actual convertion to integers.\n */\n return builtin_clz(\n (x - 4294967296 * builtin_floor(x * (1.0 / 4294967296)))\n );\n }\n\n export function cos(x: f64): f64 { // TODO\n return JSMath.cos(x);\n }\n\n export function cosh(x: f64): f64 { // see: musl/src/math/cosh.c\n var u = reinterpret(x);\n u &= 0x7FFFFFFFFFFFFFFF;\n x = reinterpret(u);\n var w = (u >> 32);\n var t: f64;\n if (w < 0x3FE62E42) {\n if (w < 0x3FF00000 - (26 << 20)) return 1;\n t = expm1(x);\n // return 1 + t * t / (2 * (1 + t));\n return 1 + t * t / (2 + 2 * t);\n }\n if (w < 0x40862E42) {\n t = exp(x);\n return 0.5 * (t + 1 / t);\n }\n t = expo2(x);\n return t;\n }\n\n export function exp(x: f64): f64 { // see: musl/src/math/exp.c and SUN COPYRIGHT NOTICE above\n const\n ln2hi = reinterpret(0x3FE62E42FEE00000), // 6.93147180369123816490e-01\n ln2lo = reinterpret(0x3DEA39EF35793C76), // 1.90821492927058770002e-10\n invln2 = reinterpret(0x3FF71547652B82FE), // 1.44269504088896338700e+00\n P1 = reinterpret(0x3FC555555555553E), // 1.66666666666666019037e-01\n P2 = reinterpret(0xBF66C16C16BEBD93), // -2.77777777770155933842e-03\n P3 = reinterpret(0x3F11566AAF25DE2C), // 6.61375632143793436117e-05\n P4 = reinterpret(0xBEBBBD41C5D26BF1), // -1.65339022054652515390e-06\n P5 = reinterpret(0x3E66376972BEA4D0), // 4.13813679705723846039e-08\n overflow = reinterpret(0x40862E42FEFA39EF), // 709.782712893383973096\n underflow = reinterpret(0xC0874910D52D3051), // -745.13321910194110842\n Ox1p1023 = reinterpret(0x7FE0000000000000);\n var hx = (reinterpret(x) >> 32);\n var sign_ = (hx >> 31);\n hx &= 0x7FFFFFFF;\n if (hx >= 0x4086232B) {\n if (isNaN(x)) return x;\n if (x > overflow) return x * Ox1p1023;\n if (x < underflow) return 0;\n }\n var hi: f64, lo: f64 = 0;\n var k = 0;\n if (hx > 0x3FD62E42) {\n if (hx >= 0x3FF0A2B2) {\n k = (invln2 * x + builtin_copysign(0.5, x));\n } else {\n k = 1 - (sign_ << 1);\n }\n hi = x - k * ln2hi;\n lo = k * ln2lo;\n x = hi - lo;\n } else if (hx > 0x3E300000) {\n hi = x;\n } else return 1.0 + x;\n var xs = x * x;\n // var c = x - xp2 * (P1 + xp2 * (P2 + xp2 * (P3 + xp2 * (P4 + xp2 * P5))));\n var xq = xs * xs;\n var c = x - (xs * P1 + xq * ((P2 + xs * P3) + xq * (P4 + xs * P5)));\n var y = 1.0 + (x * c / (2 - c) - lo + hi);\n if (k == 0) return y;\n return scalbn(y, k);\n }\n\n export function expm1(x: f64): f64 { // see: musl/src/math/expm1.c and SUN COPYRIGHT NOTICE above\n const\n o_threshold = reinterpret(0x40862E42FEFA39EF), // 7.09782712893383973096e+02\n ln2_hi = reinterpret(0x3FE62E42FEE00000), // 6.93147180369123816490e-01\n ln2_lo = reinterpret(0x3DEA39EF35793C76), // 1.90821492927058770002e-10\n invln2 = reinterpret(0x3FF71547652B82FE), // 1.44269504088896338700e+00\n Q1 = reinterpret(0xBFA11111111110F4), // -3.33333333333331316428e-02\n Q2 = reinterpret(0x3F5A01A019FE5585), // 1.58730158725481460165e-03\n Q3 = reinterpret(0xBF14CE199EAADBB7), // -7.93650757867487942473e-05\n Q4 = reinterpret(0x3ED0CFCA86E65239), // 4.00821782732936239552e-06\n Q5 = reinterpret(0xBE8AFDB76E09C32D), // -2.01099218183624371326e-07\n Ox1p1023 = reinterpret(0x7FE0000000000000);\n var u = reinterpret(x);\n var hx = (u >> 32 & 0x7FFFFFFF);\n var k = 0, sign_ = (u >> 63);\n if (hx >= 0x4043687A) {\n if (isNaN(x)) return x;\n if (sign_) return -1;\n if (x > o_threshold) return x * Ox1p1023;\n }\n var c = 0.0, t: f64;\n if (hx > 0x3FD62E42) {\n k = select(\n 1 - (sign_ << 1),\n (invln2 * x + builtin_copysign(0.5, x)),\n hx < 0x3FF0A2B2\n );\n t = k;\n let hi = x - t * ln2_hi;\n let lo = t * ln2_lo;\n x = hi - lo;\n c = (hi - x) - lo;\n } else if (hx < 0x3C900000) return x;\n var hfx = 0.5 * x;\n var hxs = x * hfx;\n // var r1 = 1.0 + hxs * (Q1 + hxs * (Q2 + hxs * (Q3 + hxs * (Q4 + hxs * Q5))));\n var hxq = hxs * hxs;\n var r1 = (1.0 + hxs * Q1) + hxq * ((Q2 + hxs * Q3) + hxq * (Q4 + hxs * Q5));\n t = 3.0 - r1 * hfx;\n var e = hxs * ((r1 - t) / (6.0 - x * t));\n if (k == 0) return x - (x * e - hxs);\n e = x * (e - c) - c;\n e -= hxs;\n if (k == -1) return 0.5 * (x - e) - 0.5;\n if (k == 1) {\n if (x < -0.25) return -2.0 * (e - (x + 0.5));\n return 1.0 + 2.0 * (x - e);\n }\n u = (0x3FF + k) << 52;\n var twopk = reinterpret(u);\n var y: f64;\n if (k < 0 || k > 56) {\n y = x - e + 1.0;\n if (k == 1024) y = y * 2.0 * Ox1p1023;\n else y = y * twopk;\n return y - 1.0;\n }\n u = (0x3FF - k) << 52;\n y = reinterpret(u);\n if (k < 20) y = (1 - y) - e;\n else y = 1 - (e + y);\n return (x + y) * twopk;\n }\n\n // @ts-ignore: decorator\n @inline\n export function floor(x: f64): f64 {\n return builtin_floor(x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function fround(x: f64): f64 {\n return x;\n }\n\n export function hypot(x: f64, y: f64): f64 { // see: musl/src/math/hypot.c\n const\n SPLIT = reinterpret(0x41A0000000000000) + 1, // 0x1p27 + 1\n Ox1p700 = reinterpret(0x6BB0000000000000),\n Ox1p_700 = reinterpret(0x1430000000000000);\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n ux &= 0x7FFFFFFFFFFFFFFF;\n uy &= 0x7FFFFFFFFFFFFFFF;\n if (ux < uy) {\n let ut = ux;\n ux = uy;\n uy = ut;\n }\n var ex = (ux >> 52);\n var ey = (uy >> 52);\n y = reinterpret(uy);\n if (ey == 0x7FF) return y;\n x = reinterpret(ux);\n if (ex == 0x7FF || uy == 0) return x;\n if (ex - ey > 64) return x + y;\n var z = 1.0;\n if (ex > 0x3FF + 510) {\n z = Ox1p700;\n x *= Ox1p_700;\n y *= Ox1p_700;\n } else if (ey < 0x3FF - 450) {\n z = Ox1p_700;\n x *= Ox1p700;\n y *= Ox1p700;\n }\n var c = x * SPLIT;\n var h = x - c + c;\n var l = x - h;\n var hx = x * x;\n var lx = h * h - hx + (2 * h + l) * l;\n c = y * SPLIT;\n h = y - c + c;\n l = y - h;\n var hy = y * y;\n var ly = h * h - hy + (2 * h + l) * l;\n return z * builtin_sqrt(ly + lx + hy + hx);\n }\n\n export function imul(x: f64, y: f64): f64 {\n /*\n * Wasm (MVP) and JS have different approaches for double->int conversions.\n *\n * For emulate JS conversion behavior and avoid trapping from wasm we should modulate by MAX_INT\n * our float-point arguments before actual convertion to integers.\n */\n if (!isFinite(x + y)) return 0;\n const inv32 = 1.0 / 4294967296;\n return (\n (x - 4294967296 * builtin_floor(x * inv32)) *\n (y - 4294967296 * builtin_floor(y * inv32))\n );\n }\n\n export function log(x: f64): f64 { // see: musl/src/math/log.c and SUN COPYRIGHT NOTICE above\n const\n ln2_hi = reinterpret(0x3FE62E42FEE00000), // 6.93147180369123816490e-01\n ln2_lo = reinterpret(0x3DEA39EF35793C76), // 1.90821492927058770002e-10\n Lg1 = reinterpret(0x3FE5555555555593), // 6.666666666666735130e-01\n Lg2 = reinterpret(0x3FD999999997FA04), // 3.999999999940941908e-01\n Lg3 = reinterpret(0x3FD2492494229359), // 2.857142874366239149e-01\n Lg4 = reinterpret(0x3FCC71C51D8E78AF), // 2.222219843214978396e-01\n Lg5 = reinterpret(0x3FC7466496CB03DE), // 1.818357216161805012e-01\n Lg6 = reinterpret(0x3FC39A09D078C69F), // 1.531383769920937332e-01\n Lg7 = reinterpret(0x3FC2F112DF3E5244), // 1.479819860511658591e-01\n Ox1p54 = reinterpret(0x4350000000000000);\n var u = reinterpret(x);\n var hx = (u >> 32);\n var k = 0;\n if (hx < 0x00100000 || (hx >> 31)) {\n if (u << 1 == 0) return -1 / (x * x);\n if (hx >> 31) return (x - x) / 0.0;\n k -= 54;\n x *= Ox1p54;\n u = reinterpret(x);\n hx = (u >> 32);\n } else if (hx >= 0x7FF00000) return x;\n else if (hx == 0x3FF00000 && u << 32 == 0) return 0;\n hx += 0x3FF00000 - 0x3FE6A09E;\n k += (hx >> 20) - 0x3FF;\n hx = (hx & 0x000FFFFF) + 0x3FE6A09E;\n u = hx << 32 | (u & 0xFFFFFFFF);\n x = reinterpret(u);\n var f = x - 1.0;\n var hfsq = 0.5 * f * f;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * (Lg4 + w * Lg6));\n var t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7)));\n var r = t2 + t1;\n var dk = k;\n return s * (hfsq + r) + dk * ln2_lo - hfsq + f + dk * ln2_hi;\n }\n\n export function log10(x: f64): f64 { // see: musl/src/math/log10.c and SUN COPYRIGHT NOTICE above\n const\n ivln10hi = reinterpret(0x3FDBCB7B15200000), // 4.34294481878168880939e-01\n ivln10lo = reinterpret(0x3DBB9438CA9AADD5), // 2.50829467116452752298e-11\n log10_2hi = reinterpret(0x3FD34413509F6000), // 3.01029995663611771306e-01\n log10_2lo = reinterpret(0x3D59FEF311F12B36), // 3.69423907715893078616e-13\n Lg1 = reinterpret(0x3FE5555555555593), // 6.666666666666735130e-01\n Lg2 = reinterpret(0x3FD999999997FA04), // 3.999999999940941908e-01\n Lg3 = reinterpret(0x3FD2492494229359), // 2.857142874366239149e-01\n Lg4 = reinterpret(0x3FCC71C51D8E78AF), // 2.222219843214978396e-01\n Lg5 = reinterpret(0x3FC7466496CB03DE), // 1.818357216161805012e-01\n Lg6 = reinterpret(0x3FC39A09D078C69F), // 1.531383769920937332e-01\n Lg7 = reinterpret(0x3FC2F112DF3E5244), // 1.479819860511658591e-01\n Ox1p54 = reinterpret(0x4350000000000000);\n var u = reinterpret(x);\n var hx = (u >> 32);\n var k = 0;\n if (hx < 0x00100000 || (hx >> 31)) {\n if (u << 1 == 0) return -1 / (x * x);\n if (hx >> 31) return (x - x) / 0.0;\n k -= 54;\n x *= Ox1p54;\n u = reinterpret(x);\n hx = (u >> 32);\n } else if (hx >= 0x7FF00000) return x;\n else if (hx == 0x3FF00000 && u << 32 == 0) return 0;\n hx += 0x3FF00000 - 0x3FE6A09E;\n k += (hx >> 20) - 0x3FF;\n hx = (hx & 0x000FFFFF) + 0x3FE6A09E;\n u = hx << 32 | (u & 0xFFFFFFFF);\n x = reinterpret(u);\n var f = x - 1.0;\n var hfsq = 0.5 * f * f;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * (Lg4 + w * Lg6));\n var t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7)));\n var r = t2 + t1;\n var hi = f - hfsq;\n u = reinterpret(hi);\n u &= 0xFFFFFFFF00000000;\n hi = reinterpret(u);\n var lo = f - hi - hfsq + s * (hfsq + r);\n var val_hi = hi * ivln10hi;\n var dk = k;\n var y = dk * log10_2hi;\n var val_lo = dk * log10_2lo + (lo + hi) * ivln10lo + lo * ivln10hi;\n w = y + val_hi;\n val_lo += (y - w) + val_hi;\n return val_lo + w;\n }\n\n export function log1p(x: f64): f64 { // see: musl/src/math/log1p.c and SUN COPYRIGHT NOTICE above\n const\n ln2_hi = reinterpret(0x3FE62E42FEE00000), // 6.93147180369123816490e-01\n ln2_lo = reinterpret(0x3DEA39EF35793C76), // 1.90821492927058770002e-10\n Lg1 = reinterpret(0x3FE5555555555593), // 6.666666666666735130e-01\n Lg2 = reinterpret(0x3FD999999997FA04), // 3.999999999940941908e-01\n Lg3 = reinterpret(0x3FD2492494229359), // 2.857142874366239149e-01\n Lg4 = reinterpret(0x3FCC71C51D8E78AF), // 2.222219843214978396e-01\n Lg5 = reinterpret(0x3FC7466496CB03DE), // 1.818357216161805012e-01\n Lg6 = reinterpret(0x3FC39A09D078C69F), // 1.531383769920937332e-01\n Lg7 = reinterpret(0x3FC2F112DF3E5244); // 1.479819860511658591e-01\n var u = reinterpret(x);\n var hx = (u >> 32);\n var k = 1;\n var c = 0.0, f = 0.0;\n if (hx < 0x3FDA827A || (hx >> 31)) {\n if (hx >= 0xBFF00000) {\n if (x == -1) return x / 0.0;\n return (x - x) / 0.0;\n }\n if (hx << 1 < 0x3CA00000 << 1) return x;\n if (hx <= 0xBFD2BEC4) {\n k = 0;\n c = 0;\n f = x;\n }\n } else if (hx >= 0x7FF00000) return x;\n if (k) {\n u = reinterpret(1 + x);\n let hu = (u >> 32);\n hu += 0x3FF00000 - 0x3FE6A09E;\n k = (hu >> 20) - 0x3FF;\n if (k < 54) {\n let uf = reinterpret(u);\n c = k >= 2 ? 1 - (uf - x) : x - (uf - 1);\n c /= uf;\n } else c = 0;\n hu = (hu & 0x000FFFFF) + 0x3FE6A09E;\n u = hu << 32 | (u & 0xFFFFFFFF);\n f = reinterpret(u) - 1;\n }\n var hfsq = 0.5 * f * f;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * (Lg4 + w * Lg6));\n var t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7)));\n var r = t2 + t1;\n var dk = k;\n return s * (hfsq + r) + (dk * ln2_lo + c) - hfsq + f + dk * ln2_hi;\n }\n\n export function log2(x: f64): f64 { // see: musl/src/math/log2.c and SUN COPYRIGHT NOTICE above\n const\n ivln2hi = reinterpret(0x3FF7154765200000), // 1.44269504072144627571e+00\n ivln2lo = reinterpret(0x3DE705FC2EEFA200), // 1.67517131648865118353e-10\n Lg1 = reinterpret(0x3FE5555555555593), // 6.666666666666735130e-01\n Lg2 = reinterpret(0x3FD999999997FA04), // 3.999999999940941908e-01\n Lg3 = reinterpret(0x3FD2492494229359), // 2.857142874366239149e-01\n Lg4 = reinterpret(0x3FCC71C51D8E78AF), // 2.222219843214978396e-01\n Lg5 = reinterpret(0x3FC7466496CB03DE), // 1.818357216161805012e-01\n Lg6 = reinterpret(0x3FC39A09D078C69F), // 1.531383769920937332e-01\n Lg7 = reinterpret(0x3FC2F112DF3E5244), // 1.479819860511658591e-01\n Ox1p54 = reinterpret(0x4350000000000000);\n var u = reinterpret(x);\n var hx = (u >> 32);\n var k = 0;\n if (hx < 0x00100000 || (hx >> 31)) {\n if (u << 1 == 0) return -1 / (x * x);\n if (hx >> 31) return (x - x) / 0.0;\n k -= 54;\n x *= Ox1p54;\n u = reinterpret(x);\n hx = (u >> 32);\n } else if (hx >= 0x7FF00000) return x;\n else if (hx == 0x3FF00000 && u << 32 == 0) return 0;\n hx += 0x3FF00000 - 0x3FE6A09E;\n k += (hx >> 20) - 0x3FF;\n hx = (hx & 0x000FFFFF) + 0x3FE6A09E;\n u = hx << 32 | (u & 0xFFFFFFFF);\n x = reinterpret(u);\n var f = x - 1.0;\n var hfsq = 0.5 * f * f;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * (Lg4 + w * Lg6));\n var t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7)));\n var r = t2 + t1;\n var hi = f - hfsq;\n u = reinterpret(hi);\n u &= 0xFFFFFFFF00000000;\n hi = reinterpret(u);\n var lo = f - hi - hfsq + s * (hfsq + r);\n var val_hi = hi * ivln2hi;\n var val_lo = (lo + hi) * ivln2lo + lo * ivln2hi;\n var y = k;\n w = y + val_hi;\n val_lo += (y - w) + val_hi;\n val_hi = w;\n return val_lo + val_hi;\n }\n\n // @ts-ignore: decorator\n @inline\n export function max(value1: f64, value2: f64): f64 {\n return builtin_max(value1, value2);\n }\n\n // @ts-ignore: decorator\n @inline\n export function min(value1: f64, value2: f64): f64 {\n return builtin_min(value1, value2);\n }\n\n export function pow(x: f64, y: f64): f64 { // see: musl/src/math/pow.c and SUN COPYRIGHT NOTICE above\n const\n dp_h1 = reinterpret(0x3FE2B80340000000), // 5.84962487220764160156e-01\n dp_l1 = reinterpret(0x3E4CFDEB43CFD006), // 1.35003920212974897128e-08\n two53 = reinterpret(0x4340000000000000), // 9007199254740992.0\n huge = reinterpret(0x7E37E43C8800759C), // 1e+300\n tiny = reinterpret(0x01A56E1FC2F8F359), // 1e-300\n L1 = reinterpret(0x3FE3333333333303), // 5.99999999999994648725e-01\n L2 = reinterpret(0x3FDB6DB6DB6FABFF), // 4.28571428578550184252e-01\n L3 = reinterpret(0x3FD55555518F264D), // 3.33333329818377432918e-01\n L4 = reinterpret(0x3FD17460A91D4101), // 2.72728123808534006489e-01\n L5 = reinterpret(0x3FCD864A93C9DB65), // 2.30660745775561754067e-01\n L6 = reinterpret(0x3FCA7E284A454EEF), // 2.06975017800338417784e-01\n P1 = reinterpret(0x3FC555555555553E), // 1.66666666666666019037e-01\n P2 = reinterpret(0xBF66C16C16BEBD93), // -2.77777777770155933842e-03\n P3 = reinterpret(0x3F11566AAF25DE2C), // 6.61375632143793436117e-05\n P4 = reinterpret(0xBEBBBD41C5D26BF1), // -1.65339022054652515390e-06\n P5 = reinterpret(0x3E66376972BEA4D0), // 4.13813679705723846039e-08\n lg2 = reinterpret(0x3FE62E42FEFA39EF), // 6.93147180559945286227e-01\n lg2_h = reinterpret(0x3FE62E4300000000), // 6.93147182464599609375e-01\n lg2_l = reinterpret(0xBE205C610CA86C39), // -1.90465429995776804525e-09\n ovt = reinterpret(0x3C971547652B82FE), // 8.0085662595372944372e-017\n cp = reinterpret(0x3FEEC709DC3A03FD), // 9.61796693925975554329e-01\n cp_h = reinterpret(0x3FEEC709E0000000), // 9.61796700954437255859e-01\n cp_l = reinterpret(0xBE3E2FE0145B01F5), // -7.02846165095275826516e-09\n ivln2 = reinterpret(0x3FF71547652B82FE), // 1.44269504088896338700e+00\n ivln2_h = reinterpret(0x3FF7154760000000), // 1.44269502162933349609e+00\n ivln2_l = reinterpret(0x3E54AE0BF85DDF44), // 1.92596299112661746887e-08\n inv3 = reinterpret(0x3FD5555555555555); // 0.3333333333333333333333\n var u_ = reinterpret(x);\n var hx = (u_ >> 32);\n var lx = u_;\n u_ = reinterpret(y);\n var hy = (u_ >> 32);\n var ly = u_;\n var ix = hx & 0x7FFFFFFF;\n var iy = hy & 0x7FFFFFFF;\n if ((iy | ly) == 0) return 1.0; // x**0 = 1, even if x is NaN\n // if (hx == 0x3FF00000 && lx == 0) return 1.0; // C: 1**y = 1, even if y is NaN, JS: NaN\n if ( // NaN if either arg is NaN\n ix > 0x7FF00000 || (ix == 0x7FF00000 && lx != 0) ||\n iy > 0x7FF00000 || (iy == 0x7FF00000 && ly != 0)\n ) return x + y;\n var yisint = 0, k: i32;\n if (hx < 0) {\n if (iy >= 0x43400000) yisint = 2;\n else if (iy >= 0x3FF00000) {\n k = (iy >> 20) - 0x3FF;\n let kcond = k > 20;\n let offset = select(52, 20, kcond) - k;\n let Ly = select(ly, iy, kcond);\n let jj = Ly >> offset;\n if ((jj << offset) == Ly) yisint = 2 - (jj & 1);\n }\n }\n if (ly == 0) {\n if (iy == 0x7FF00000) { // y is +-inf\n if (((ix - 0x3FF00000) | lx) == 0) return NaN; // C: (-1)**+-inf is 1, JS: NaN\n else if (ix >= 0x3FF00000) return hy >= 0 ? y : 0.0; // (|x|>1)**+-inf = inf,0\n else return hy >= 0 ? 0.0 : -y; // (|x|<1)**+-inf = 0,inf\n }\n if (iy == 0x3FF00000) {\n if (hy >= 0) return x;\n return 1 / x;\n }\n if (hy == 0x40000000) return x * x;\n if (hy == 0x3FE00000) {\n if (hx >= 0) return builtin_sqrt(x);\n }\n }\n var ax = builtin_abs(x), z: f64;\n if (lx == 0) {\n if (ix == 0 || ix == 0x7FF00000 || ix == 0x3FF00000) {\n z = ax;\n if (hy < 0) z = 1.0 / z;\n if (hx < 0) {\n if (((ix - 0x3FF00000) | yisint) == 0) {\n let d = z - z;\n z = d / d;\n } else if (yisint == 1) z = -z;\n }\n return z;\n }\n }\n var s = 1.0;\n if (hx < 0) {\n if (yisint == 0) {\n let d = x - x;\n return d / d;\n }\n if (yisint == 1) s = -1.0;\n }\n var t1: f64, t2: f64, p_h: f64, p_l: f64, r: f64, t: f64, u: f64, v: f64, w: f64;\n var j: i32, n: i32;\n if (iy > 0x41E00000) {\n if (iy > 0x43F00000) {\n if (ix <= 0x3FEFFFFF) return hy < 0 ? huge * huge : tiny * tiny;\n if (ix >= 0x3FF00000) return hy > 0 ? huge * huge : tiny * tiny;\n }\n if (ix < 0x3FEFFFFF) return hy < 0 ? s * huge * huge : s * tiny * tiny;\n if (ix > 0x3FF00000) return hy > 0 ? s * huge * huge : s * tiny * tiny;\n t = ax - 1.0;\n w = (t * t) * (0.5 - t * (inv3 - t * 0.25));\n u = ivln2_h * t;\n v = t * ivln2_l - w * ivln2;\n t1 = u + v;\n t1 = reinterpret(reinterpret(t1) & 0xFFFFFFFF00000000);\n t2 = v - (t1 - u);\n } else {\n let ss: f64, s2: f64, s_h: f64, s_l: f64, t_h: f64, t_l: f64;\n n = 0;\n if (ix < 0x00100000) {\n ax *= two53;\n n -= 53;\n ix = (reinterpret(ax) >> 32);\n }\n n += (ix >> 20) - 0x3FF;\n j = ix & 0x000FFFFF;\n ix = j | 0x3FF00000;\n if (j <= 0x3988E) k = 0;\n else if (j < 0xBB67A) k = 1;\n else {\n k = 0;\n n += 1;\n ix -= 0x00100000;\n }\n ax = reinterpret(reinterpret(ax) & 0xFFFFFFFF | (ix << 32));\n let bp = select(1.5, 1.0, k); // k ? 1.5 : 1.0\n u = ax - bp;\n v = 1.0 / (ax + bp);\n ss = u * v;\n s_h = ss;\n s_h = reinterpret(reinterpret(s_h) & 0xFFFFFFFF00000000);\n t_h = reinterpret((((ix >> 1) | 0x20000000) + 0x00080000 + (k << 18)) << 32);\n t_l = ax - (t_h - bp);\n s_l = v * ((u - s_h * t_h) - s_h * t_l);\n s2 = ss * ss;\n r = s2 * s2 * (L1 + s2 * (L2 + s2 * (L3 + s2 * (L4 + s2 * (L5 + s2 * L6)))));\n r += s_l * (s_h + ss);\n s2 = s_h * s_h;\n t_h = 3.0 + s2 + r;\n t_h = reinterpret(reinterpret(t_h) & 0xFFFFFFFF00000000);\n t_l = r - ((t_h - 3.0) - s2);\n u = s_h * t_h;\n v = s_l * t_h + t_l * ss;\n p_h = u + v;\n p_h = reinterpret(reinterpret(p_h) & 0xFFFFFFFF00000000);\n p_l = v - (p_h - u);\n let z_h = cp_h * p_h;\n let dp_l = select(dp_l1, 0.0, k);\n let z_l = cp_l * p_h + p_l * cp + dp_l;\n t = n;\n let dp_h = select(dp_h1, 0.0, k);\n t1 = ((z_h + z_l) + dp_h) + t;\n t1 = reinterpret(reinterpret(t1) & 0xFFFFFFFF00000000);\n t2 = z_l - (((t1 - t) - dp_h) - z_h);\n }\n var y1 = y;\n y1 = reinterpret(reinterpret(y1) & 0xFFFFFFFF00000000);\n p_l = (y - y1) * t1 + y * t2;\n p_h = y1 * t1;\n z = p_l + p_h;\n u_ = reinterpret(z);\n j = (u_ >> 32);\n var i = u_;\n if (j >= 0x40900000) {\n if (((j - 0x40900000) | i) != 0) return s * huge * huge;\n if (p_l + ovt > z - p_h) return s * huge * huge;\n } else if ((j & 0x7FFFFFFF) >= 0x4090CC00) {\n if (((j - 0xC090CC00) | i) != 0) return s * tiny * tiny;\n if (p_l <= z - p_h) return s * tiny * tiny;\n }\n i = j & 0x7FFFFFFF;\n k = (i >> 20) - 0x3FF;\n n = 0;\n if (i > 0x3FE00000) {\n n = j + (0x00100000 >> (k + 1));\n k = ((n & 0x7FFFFFFF) >> 20) - 0x3FF;\n t = 0.0;\n t = reinterpret((n & ~(0x000FFFFF >> k)) << 32);\n n = ((n & 0x000FFFFF) | 0x00100000) >> (20 - k);\n if (j < 0) n = -n;\n p_h -= t;\n }\n t = p_l + p_h;\n t = reinterpret(reinterpret(t) & 0xFFFFFFFF00000000);\n u = t * lg2_h;\n v = (p_l - (t - p_h)) * lg2 + t * lg2_l;\n z = u + v;\n w = v - (z - u);\n t = z * z;\n t1 = z - t * (P1 + t * (P2 + t * (P3 + t * (P4 + t * P5))));\n r = (z * t1) / (t1 - 2.0) - (w + z * w);\n z = 1.0 - (r - z);\n j = (reinterpret(z) >> 32);\n j += n << 20;\n if ((j >> 20) <= 0) z = scalbn(z, n);\n else z = reinterpret(reinterpret(z) & 0xFFFFFFFF | (j << 32));\n return s * z;\n }\n\n export function seedRandom(value: i64): void {\n assert(value);\n random_seeded = true;\n random_state0_64 = murmurHash3(value);\n random_state1_64 = murmurHash3(~random_state0_64);\n random_state0_32 = splitMix32(value);\n random_state1_32 = splitMix32(random_state0_32);\n }\n\n export function random(): f64 { // see: v8/src/base/random-number-generator.cc\n if (!random_seeded) throw new Error("PRNG must be seeded.");\n var s1 = random_state0_64;\n var s0 = random_state1_64;\n random_state0_64 = s0;\n s1 ^= s1 << 23;\n s1 ^= s1 >> 17;\n s1 ^= s0;\n s1 ^= s0 >> 26;\n random_state1_64 = s1;\n var r = ((s0 + s1) & 0x000FFFFFFFFFFFFF) | 0x3FF0000000000000;\n return reinterpret(r) - 1;\n }\n\n // @ts-ignore: decorator\n @inline\n export function round(x: f64): f64 {\n return builtin_copysign(builtin_floor(x + 0.5), x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function sign(x: f64): f64 {\n if (ASC_SHRINK_LEVEL > 0) {\n return builtin_abs(x) > 0 ? builtin_copysign(1, x) : x;\n } else {\n return x > 0 ? 1 : x < 0 ? -1 : x;\n }\n }\n\n // @ts-ignore: decorator\n @inline\n export function signbit(x: f64): bool {\n // In ECMAScript all NaN values are indistinguishable from each other\n // so we need handle NaN and negative NaN in similar way\n return ((reinterpret(x) >>> 63) & i32(x == x));\n }\n\n export function sin(x: f64): f64 { // TODO\n return JSMath.sin(x);\n }\n\n export function sinh(x: f64): f64 { // see: musl/src/math/sinh.c\n var u = reinterpret(x) & 0x7FFFFFFFFFFFFFFF;\n var absx = reinterpret(u);\n var w = (u >> 32);\n var t: f64;\n var h = builtin_copysign(0.5, x);\n if (w < 0x40862E42) {\n t = expm1(absx);\n if (w < 0x3FF00000) {\n if (w < 0x3FF00000 - (26 << 20)) return x;\n return h * (2 * t - t * t / (t + 1));\n }\n return h * (t + t / (t + 1));\n }\n t = 2 * h * expo2(absx);\n return t;\n }\n\n // @ts-ignore: decorator\n @inline\n export function sqrt(x: f64): f64 {\n return builtin_sqrt(x);\n }\n\n export function tan(x: f64): f64 { // TODO\n return JSMath.tan(x);\n }\n\n export function tanh(x: f64): f64 { // see: musl/src/math/tanh.c\n var u = reinterpret(x);\n u &= 0x7FFFFFFFFFFFFFFF;\n var y = reinterpret(u);\n var w = (u >> 32);\n var t: f64;\n if (w > 0x3FE193EA) {\n if (w > 0x40340000) {\n t = 1 - 0 / y;\n } else {\n t = expm1(2 * y);\n t = 1 - 2 / (t + 2);\n }\n } else if (w > 0x3FD058AE) {\n t = expm1(2 * y);\n t = t / (t + 2);\n } else if (w >= 0x00100000) {\n t = expm1(-2 * y);\n t = -t / (t + 2);\n } else t = y;\n return builtin_copysign(t, x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function trunc(x: f64): f64 {\n return builtin_trunc(x);\n }\n\n export function scalbn(x: f64, n: i32): f64 { // see: https://git.musl-libc.org/cgit/musl/tree/src/math/scalbn.c\n const\n Ox1p53 = reinterpret(0x4340000000000000),\n Ox1p1023 = reinterpret(0x7FE0000000000000),\n Ox1p_1022 = reinterpret(0x0010000000000000);\n var y = x;\n if (n > 1023) {\n y *= Ox1p1023;\n n -= 1023;\n if (n > 1023) {\n y *= Ox1p1023;\n n = builtin_min(n - 1023, 1023);\n }\n } else if (n < -1022) {\n /* make sure final n < -53 to avoid double\n rounding in the subnormal range */\n y *= Ox1p_1022 * Ox1p53;\n n += 1022 - 53;\n if (n < -1022) {\n y *= Ox1p_1022 * Ox1p53;\n n = builtin_max(n + 1022 - 53, -1022);\n }\n }\n return y * reinterpret((0x3FF + n) << 52);\n }\n\n export function mod(x: f64, y: f64): f64 { // see: musl/src/math/fmod.c\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n var ex = (ux >> 52 & 0x7FF);\n var ey = (uy >> 52 & 0x7FF);\n var sx = ux >> 63;\n var uy1 = uy << 1;\n if (uy1 == 0 || ex == 0x7FF || isNaN(y)) {\n let m = x * y;\n return m / m;\n }\n var ux1 = ux << 1;\n if (ux1 <= uy1) {\n if (ux1 == uy1) return 0 * x;\n return x;\n }\n if (!ex) {\n ex -= builtin_clz(ux << 12);\n ux <<= -ex + 1;\n } else {\n ux &= -1 >> 12;\n ux |= 1 << 52;\n }\n if (!ey) {\n ey -= builtin_clz(uy << 12);\n uy <<= -ey + 1;\n } else {\n uy &= -1 >> 12;\n uy |= 1 << 52;\n }\n while (ex > ey) {\n if (ux >= uy) {\n if (ux == uy) return 0 * x;\n ux -= uy;\n }\n ux <<= 1;\n --ex;\n }\n if (ux >= uy) {\n if (ux == uy) return 0 * x;\n ux -= uy;\n }\n // for (; !(ux >> 52); ux <<= 1) --ex;\n var shift = builtin_clz(ux << 11);\n ex -= shift;\n ux <<= shift;\n if (ex > 0) {\n ux -= 1 << 52;\n ux |= ex << 52;\n } else {\n ux >>= -ex + 1;\n }\n ux |= sx << 63;\n return reinterpret(ux);\n }\n\n export function rem(x: f64, y: f64): f64 { // see: musl/src/math/remquo.c\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n var ex = (ux >> 52 & 0x7FF);\n var ey = (uy >> 52 & 0x7FF);\n var sx = (ux >> 63);\n if (uy << 1 == 0 || ex == 0x7FF || isNaN(y)) {\n let m = x * y;\n return m / m;\n }\n if (ux << 1 == 0) return x;\n var uxi = ux;\n if (!ex) {\n ex -= builtin_clz(uxi << 12);\n uxi <<= -ex + 1;\n } else {\n uxi &= -1 >> 12;\n uxi |= 1 << 52;\n }\n if (!ey) {\n ey -= builtin_clz(uy << 12);\n uy <<= -ey + 1;\n } else {\n uy &= -1 >> 12;\n uy |= 1 << 52;\n }\n var q: u32 = 0;\n do {\n if (ex < ey) {\n if (ex + 1 == ey) break; // goto end\n return x;\n }\n while (ex > ey) {\n if (uxi >= uy) {\n uxi -= uy;\n ++q;\n }\n uxi <<= 1;\n q <<= 1;\n --ex;\n }\n if (uxi >= uy) {\n uxi -= uy;\n ++q;\n }\n if (uxi == 0) ex = -60;\n else {\n let shift = builtin_clz(uxi << 11);\n ex -= shift;\n uxi <<= shift;\n }\n break;\n } while (false);\n // end:\n if (ex > 0) {\n uxi -= 1 << 52;\n uxi |= ex << 52;\n } else {\n uxi >>= -ex + 1;\n }\n x = reinterpret(uxi);\n y = builtin_abs(y);\n var x2 = x + x;\n if (ex == ey || (ex + 1 == ey && (x2 > y || (x2 == y && (q & 1))))) {\n x -= y;\n // ++q;\n }\n return sx ? -x : x;\n }\n}\n\n// @ts-ignore: decorator\n@lazy\nvar rempio2f_y: f64;\n\n// @ts-ignore: decorator\n@lazy\nconst PIO2_TABLE: u64[] = [\n 0xA2F9836E4E441529,\n 0xFC2757D1F534DDC0,\n 0xDB6295993C439041,\n 0xFE5163ABDEBBC561\n];\n\nfunction Rf(z: f32): f32 { // Rational approximation of (asin(x)-x)/x^3\n const // see: musl/src/math/asinf.c and SUN COPYRIGHT NOTICE above\n pS0 = reinterpret(0x3E2AAA75), // 1.6666586697e-01f\n pS1 = reinterpret(0xBD2F13BA), // -4.2743422091e-02f\n pS2 = reinterpret(0xBC0DD36B), // -8.6563630030e-03f\n qS1 = reinterpret(0xBF34E5AE); // -7.0662963390e-01f\n var p = z * (pS0 + z * (pS1 + z * pS2));\n var q: f32 = 1 + z * qS1;\n return p / q;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction expo2f(x: f32): f32 { // exp(x)/2 for x >= log(DBL_MAX)\n const // see: musl/src/math/__expo2f.c\n k = 235,\n kln2 = reinterpret(0x4322E3BC); // 0x1.45c778p+7f\n var scale = reinterpret((0x7F + (k >> 1)) << 23);\n return NativeMathf.exp(x - kln2) * scale * scale;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction pio2_large_quot(x: f32, u: i32): i32 { // see: jdh8/metallic/blob/master/src/math/float/rem_pio2f.c\n const coeff = reinterpret(0x3BF921FB54442D18); // π * 0x1p-65 = 8.51530395021638647334e-20\n const bits = PIO2_TABLE;\n\n var offset = (u >> 23) - 152;\n var index = offset >> 6;\n var shift = offset & 63;\n\n var b0 = unchecked(bits[index + 0]);\n var b1 = unchecked(bits[index + 1]);\n var lo: u64;\n\n if (shift > 32) {\n let b2 = unchecked(bits[index + 2]);\n lo = b2 >> (96 - shift);\n lo |= b1 << (shift - 32);\n } else {\n lo = b1 >> (32 - shift);\n }\n\n var hi = (b1 >> (64 - shift)) | (b0 << shift);\n var mantissa: u64 = (u & 0x007FFFFF) | 0x00800000;\n var product: u64 = mantissa * hi + (mantissa * lo >> 32);\n var r: i64 = product << 2;\n var q: i32 = ((product >> 62) + (r >>> 63));\n rempio2f_y = copysign(coeff, x) * r;\n return q;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction rempio2f(x: f32, u: u32, sign: i32): i32 { // see: jdh8/metallic/blob/master/src/math/float/rem_pio2f.c\n const pi2hi = reinterpret(0x3FF921FB50000000); // 1.57079631090164184570\n const pi2lo = reinterpret(0x3E5110B4611A6263); // 1.58932547735281966916e-8\n const _2_pi = reinterpret(0x3FE45F306DC9C883); // 0.63661977236758134308\n\n if (u < 0x4DC90FDB) { /* π * 0x1p28 */\n let q = nearest(x * _2_pi);\n rempio2f_y = x - q * pi2hi - q * pi2lo;\n return q;\n }\n\n var q = pio2_large_quot(x, u);\n return select(-q, q, sign);\n}\n\n/* |sin(x)/x - s(x)| < 2**-37.5 (~[-4.89e-12, 4.824e-12]). */\n// @ts-ignore: decorator\n@inline\nfunction sin_kernf(x: f64): f32 { // see: musl/tree/src/math/__sindf.c\n const S1 = reinterpret(0xBFC5555554CBAC77); // -0x15555554cbac77.0p-55\n const S2 = reinterpret(0x3F811110896EFBB2); // 0x111110896efbb2.0p-59\n const S3 = reinterpret(0xBF2A00F9E2CAE774); // -0x1a00f9e2cae774.0p-65\n const S4 = reinterpret(0x3EC6CD878C3B46A7); // 0x16cd878c3b46a7.0p-71\n\n var z = x * x;\n var w = z * z;\n var r = S3 + z * S4;\n var s = z * x;\n return ((x + s * (S1 + z * S2)) + s * w * r);\n}\n\n/* |cos(x) - c(x)| < 2**-34.1 (~[-5.37e-11, 5.295e-11]). */\n// @ts-ignore: decorator\n@inline\nfunction cos_kernf(x: f64): f32 { // see: musl/tree/src/math/__cosdf.c\n const C0 = reinterpret(0xBFDFFFFFFD0C5E81); // -0x1ffffffd0c5e81.0p-54\n const C1 = reinterpret(0x3FA55553E1053A42); // 0x155553e1053a42.0p-57\n const C2 = reinterpret(0xBF56C087E80F1E27); // -0x16c087e80f1e27.0p-62\n const C3 = reinterpret(0x3EF99342E0EE5069); // 0x199342e0ee5069.0p-68\n\n var z = x * x;\n var w = z * z;\n var r = C2 + z * C3;\n return (((1 + z * C0) + w * C1) + (w * z) * r);\n}\n\n/* |tan(x)/x - t(x)| < 2**-25.5 (~[-2e-08, 2e-08]). */\n// @ts-ignore: decorator\n@inline\nfunction tan_kernf(x: f64, odd: i32): f32 { // see: musl/tree/src/math/__tandf.c\n\n const T0 = reinterpret(0x3FD5554D3418C99F); /* 0x15554d3418c99f.0p-54 */\n const T1 = reinterpret(0x3FC112FD38999F72); /* 0x1112fd38999f72.0p-55 */\n const T2 = reinterpret(0x3FAB54C91D865AFE); /* 0x1b54c91d865afe.0p-57 */\n const T3 = reinterpret(0x3F991DF3908C33CE); /* 0x191df3908c33ce.0p-58 */\n const T4 = reinterpret(0x3F685DADFCECF44E); /* 0x185dadfcecf44e.0p-61 */\n const T5 = reinterpret(0x3F8362B9BF971BCD); /* 0x1362b9bf971bcd.0p-59 */\n\n var z = x * x;\n var r = T4 + z * T5;\n var t = T2 + z * T3;\n var w = z * z;\n var s = z * x;\n var u = T0 + z * T1;\n\n r = (x + s * u) + (s * w) * (t + w * r);\n return (odd ? -1 / r : r);\n}\n\nexport namespace NativeMathf {\n\n // @ts-ignore: decorator\n @lazy\n export const E = NativeMath.E;\n\n // @ts-ignore: decorator\n @lazy\n export const LN2 = NativeMath.LN2;\n\n // @ts-ignore: decorator\n @lazy\n export const LN10 = NativeMath.LN10;\n\n // @ts-ignore: decorator\n @lazy\n export const LOG2E = NativeMath.LOG2E;\n\n // @ts-ignore: decorator\n @lazy\n export const LOG10E = NativeMath.LOG10E;\n\n // @ts-ignore: decorator\n @lazy\n export const PI = NativeMath.PI;\n\n // @ts-ignore: decorator\n @lazy\n export const SQRT1_2 = NativeMath.SQRT1_2;\n\n // @ts-ignore: decorator\n @lazy\n export const SQRT2 = NativeMath.SQRT2;\n\n // @ts-ignore: decorator\n @lazy\n export var sincos_sin: f32 = 0;\n\n // @ts-ignore: decorator\n @lazy\n export var sincos_cos: f32 = 0;\n\n // @ts-ignore: decorator\n @inline\n export function abs(x: f32): f32 {\n return builtin_abs(x);\n }\n\n export function acos(x: f32): f32 { // see: musl/src/math/acosf.c and SUN COPYRIGHT NOTICE above\n const\n pio2_hi = reinterpret(0x3FC90FDA), // 1.5707962513e+00f\n pio2_lo = reinterpret(0x33A22168), // 7.5497894159e-08f\n Ox1p_120f = reinterpret(0x03800000);\n var hx = reinterpret(x);\n var ix = hx & 0x7FFFFFFF;\n if (ix >= 0x3F800000) {\n if (ix == 0x3F800000) {\n if (hx >> 31) return 2 * pio2_hi + Ox1p_120f;\n return 0;\n }\n return 0 / (x - x);\n }\n if (ix < 0x3F000000) {\n if (ix <= 0x32800000) return pio2_hi + Ox1p_120f;\n return pio2_hi - (x - (pio2_lo - x * Rf(x * x)));\n }\n var z: f32, w: f32, s: f32;\n if (hx >> 31) {\n // z = (1 + x) * 0.5;\n z = 0.5 + x * 0.5;\n s = builtin_sqrt(z);\n w = Rf(z) * s - pio2_lo;\n return 2 * (pio2_hi - (s + w));\n }\n // z = (1 - x) * 0.5;\n z = 0.5 - x * 0.5;\n s = builtin_sqrt(z);\n hx = reinterpret(s);\n var df = reinterpret(hx & 0xFFFFF000);\n var c = (z - df * df) / (s + df);\n w = Rf(z) * s + c;\n return 2 * (df + w);\n }\n\n export function acosh(x: f32): f32 { // see: musl/src/math/acoshf.c\n const s = reinterpret(0x3F317218); // 0.693147180559945309417232121458176568f\n var u = reinterpret(x);\n var a = u & 0x7FFFFFFF;\n if (a < 0x3F800000 + (1 << 23)) {\n let xm1 = x - 1;\n return log1p(xm1 + builtin_sqrt(xm1 * (xm1 + 2)));\n }\n if (a < 0x3F800000 + (12 << 23)) return log(2 * x - 1 / (x + builtin_sqrt(x * x - 1)));\n return log(x) + s;\n }\n\n export function asin(x: f32): f32 { // see: musl/src/math/asinf.c and SUN COPYRIGHT NOTICE above\n const\n pio2 = reinterpret(0x3FC90FDB), // 1.570796326794896558e+00f\n Ox1p_120f = reinterpret(0x03800000);\n var sx = x;\n var hx = reinterpret(x) & 0x7FFFFFFF;\n if (hx >= 0x3F800000) {\n if (hx == 0x3F800000) return x * pio2 + Ox1p_120f;\n return 0 / (x - x);\n }\n if (hx < 0x3F000000) {\n if (hx < 0x39800000 && hx >= 0x00800000) return x;\n return x + x * Rf(x * x);\n }\n // var z: f32 = (1 - builtin_abs(x)) * 0.5;\n var z: f32 = 0.5 - builtin_abs(x) * 0.5;\n var s = builtin_sqrt(z); // sic\n x = (pio2 - 2 * (s + s * Rf(z)));\n return builtin_copysign(x, sx);\n }\n\n export function asinh(x: f32): f32 { // see: musl/src/math/asinhf.c\n const c = reinterpret(0x3F317218); // 0.693147180559945309417232121458176568f\n var u = reinterpret(x) & 0x7FFFFFFF;\n var y = reinterpret(u);\n if (u >= 0x3F800000 + (12 << 23)) y = log(y) + c;\n else if (u >= 0x3F800000 + (1 << 23)) y = log(2 * y + 1 / (builtin_sqrt(y * y + 1) + y));\n else if (u >= 0x3F800000 - (12 << 23)) y = log1p(y + y * y / (builtin_sqrt(y * y + 1) + 1));\n return builtin_copysign(y, x);\n }\n\n export function atan(x: f32): f32 { // see: musl/src/math/atanf.c and SUN COPYRIGHT NOTICE above\n const\n atanhi0 = reinterpret(0x3EED6338), // 4.6364760399e-01f\n atanhi1 = reinterpret(0x3F490FDA), // 7.8539812565e-01f\n atanhi2 = reinterpret(0x3F7B985E), // 9.8279368877e-01f\n atanhi3 = reinterpret(0x3FC90FDA), // 1.5707962513e+00f\n atanlo0 = reinterpret(0x31AC3769), // 5.0121582440e-09f\n atanlo1 = reinterpret(0x33222168), // 3.7748947079e-08f\n atanlo2 = reinterpret(0x33140FB4), // 3.4473217170e-08f\n atanlo3 = reinterpret(0x33A22168), // 7.5497894159e-08f\n aT0 = reinterpret(0x3EAAAAA9), // 3.3333328366e-01f\n aT1 = reinterpret(0xBE4CCA98), // -1.9999158382e-01f\n aT2 = reinterpret(0x3E11F50D), // 1.4253635705e-01f\n aT3 = reinterpret(0xBDDA1247), // -1.0648017377e-01f\n aT4 = reinterpret(0x3D7CAC25), // 6.1687607318e-02f\n Ox1p_120f = reinterpret(0x03800000);\n var ix = reinterpret(x);\n var sx = x;\n ix &= 0x7FFFFFFF;\n var z: f32;\n if (ix >= 0x4C800000) {\n if (isNaN(x)) return x;\n z = atanhi3 + Ox1p_120f;\n return builtin_copysign(z, sx);\n }\n var id: i32;\n if (ix < 0x3EE00000) {\n if (ix < 0x39800000) return x;\n id = -1;\n } else {\n x = builtin_abs(x);\n if (ix < 0x3F980000) {\n if (ix < 0x3F300000) {\n id = 0;\n x = (2.0 * x - 1.0) / (2.0 + x);\n } else {\n id = 1;\n x = (x - 1.0) / (x + 1.0);\n }\n } else {\n if (ix < 0x401C0000) {\n id = 2;\n x = (x - 1.5) / (1.0 + 1.5 * x);\n } else {\n id = 3;\n x = -1.0 / x;\n }\n }\n }\n z = x * x;\n var w = z * z;\n var s1 = z * (aT0 + w * (aT2 + w * aT4));\n var s2 = w * (aT1 + w * aT3);\n var s3 = x * (s1 + s2);\n if (id < 0) return x - s3;\n switch (id) {\n case 0: { z = atanhi0 - ((s3 - atanlo0) - x); break; }\n case 1: { z = atanhi1 - ((s3 - atanlo1) - x); break; }\n case 2: { z = atanhi2 - ((s3 - atanlo2) - x); break; }\n case 3: { z = atanhi3 - ((s3 - atanlo3) - x); break; }\n default: unreachable();\n }\n return builtin_copysign(z, sx);\n }\n\n export function atanh(x: f32): f32 { // see: musl/src/math/atanhf.c\n var u = reinterpret(x);\n u &= 0x7FFFFFFF;\n var y = reinterpret(u);\n if (u < 0x3F800000 - (1 << 23)) {\n if (u >= 0x3F800000 - (32 << 23)) y = 0.5 * log1p(2 * y * (1.0 + y / (1 - y)));\n } else y = 0.5 * log1p(2 * (y / (1 - y)));\n return builtin_copysign(y, x);\n }\n\n export function atan2(y: f32, x: f32): f32 { // see: musl/src/math/atan2f.c and SUN COPYRIGHT NOTICE above\n const\n pi = reinterpret(0x40490FDB), // 3.1415927410e+00f\n pi_lo = reinterpret(0xB3BBBD2E); // -8.7422776573e-08f\n if (isNaN(x) || isNaN(y)) return x + y;\n var ix = reinterpret(x);\n var iy = reinterpret(y);\n if (ix == 0x3F800000) return atan(y);\n var m = (((iy >> 31) & 1) | ((ix >> 30) & 2));\n ix &= 0x7FFFFFFF;\n iy &= 0x7FFFFFFF;\n if (iy == 0) {\n switch (m) {\n case 0:\n case 1: return y;\n case 2: return pi;\n case 3: return -pi;\n }\n }\n if (ix == 0) return m & 1 ? -pi / 2 : pi / 2;\n if (ix == 0x7F800000) {\n if (iy == 0x7F800000) {\n switch (m) {\n case 0: return pi / 4;\n case 1: return -pi / 4;\n case 2: return 3 * pi / 4;\n case 3: return -3 * pi / 4;\n }\n } else {\n switch (m) {\n case 0: return 0;\n case 1: return -0;\n case 2: return pi;\n case 3: return -pi;\n }\n }\n }\n if (ix + (26 << 23) < iy || iy == 0x7F800000) return m & 1 ? -pi / 2 : pi / 2;\n var z: f32;\n if ((m & 2) && iy + (26 << 23) < ix) z = 0.0;\n else z = atan(builtin_abs(y / x));\n switch (m) {\n case 0: return z;\n case 1: return -z;\n case 2: return pi - (z - pi_lo);\n case 3: return (z - pi_lo) - pi;\n }\n unreachable();\n return 0;\n }\n\n export function cbrt(x: f32): f32 { // see: musl/src/math/cbrtf.c and SUN COPYRIGHT NOTICE above\n const\n B1 = 709958130,\n B2 = 642849266,\n Ox1p24f = reinterpret(0x4B800000);\n var u = reinterpret(x);\n var hx = u & 0x7FFFFFFF;\n if (hx >= 0x7F800000) return x + x;\n if (hx < 0x00800000) {\n if (hx == 0) return x;\n u = reinterpret(x * Ox1p24f);\n hx = u & 0x7FFFFFFF;\n hx = hx / 3 + B2;\n } else {\n hx = hx / 3 + B1;\n }\n u &= 0x80000000;\n u |= hx;\n var t = reinterpret(u);\n var r = t * t * t;\n t = t * (x + x + r) / (x + r + r);\n r = t * t * t;\n t = t * (x + x + r) / (x + r + r);\n return t;\n }\n\n // @ts-ignore: decorator\n @inline\n export function ceil(x: f32): f32 {\n return builtin_ceil(x);\n }\n\n export function clz32(x: f32): f32 {\n if (!isFinite(x)) return 32;\n return builtin_clz(\n (x - 4294967296 * builtin_floor(x * (1.0 / 4294967296)))\n );\n }\n\n export function cos(x: f32): f32 { // see: musl/src/math/cosf.c\n const c1pio2 = reinterpret(0x3FF921FB54442D18); // M_PI_2 * 1\n const c2pio2 = reinterpret(0x400921FB54442D18); // M_PI_2 * 2\n const c3pio2 = reinterpret(0x4012D97C7F3321D2); // M_PI_2 * 3\n const c4pio2 = reinterpret(0x401921FB54442D18); // M_PI_2 * 4\n\n var ix = reinterpret(x);\n var sign = ix >> 31;\n ix &= 0x7FFFFFFF;\n\n if (ix <= 0x3f490fda) { /* |x| ~<= π/4 */\n if (ix < 0x39800000) { /* |x| < 2**-12 */\n /* raise inexact if x != 0 */\n return 1;\n }\n return cos_kernf(x);\n }\n\n if (ASC_SHRINK_LEVEL < 1) {\n if (ix <= 0x407b53d1) { /* |x| ~<= 5π/4 */\n if (ix > 0x4016cbe3) { /* |x| ~> 3π/4 */\n return -cos_kernf(sign ? x + c2pio2 : x - c2pio2);\n } else {\n return sign ? sin_kernf(x + c1pio2) : sin_kernf(c1pio2 - x);\n }\n }\n if (ix <= 0x40e231d5) { /* |x| ~<= 9π/4 */\n if (ix > 0x40afeddf) { /* |x| ~> 7π/4 */\n return cos_kernf(sign ? x + c4pio2 : x - c4pio2);\n } else {\n return sign ? sin_kernf(-x - c3pio2) : sin_kernf(x - c3pio2);\n }\n }\n }\n\n /* cos(Inf or NaN) is NaN */\n if (ix >= 0x7f800000) return x - x;\n\n /* general argument reduction needed */\n var n = rempio2f(x, ix, sign);\n var y = rempio2f_y;\n\n var t = n & 1 ? sin_kernf(y) : cos_kernf(y);\n return (n + 1) & 2 ? -t : t;\n }\n\n export function cosh(x: f32): f32 { // see: musl/src/math/coshf.c\n var u = reinterpret(x);\n u &= 0x7FFFFFFF;\n x = reinterpret(u);\n if (u < 0x3F317217) {\n if (u < 0x3F800000 - (12 << 23)) return 1;\n let t = expm1(x);\n // return 1 + t * t / (2 * (1 + t));\n return 1 + t * t / (2 + 2 * t);\n }\n if (u < 0x42B17217) {\n let t = exp(x);\n // return 0.5 * (t + 1 / t);\n return 0.5 * t + 0.5 / t;\n }\n return expo2f(x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function floor(x: f32): f32 {\n return builtin_floor(x);\n }\n\n export function exp(x: f32): f32 { // see: musl/src/math/expf.c and SUN COPYRIGHT NOTICE above\n const\n ln2hi = reinterpret(0x3F317200), // 6.9314575195e-1f\n ln2lo = reinterpret(0x35BFBE8E), // 1.4286067653e-6f\n invln2 = reinterpret(0x3FB8AA3B), // 1.4426950216e+0f\n P1 = reinterpret(0x3E2AAA8F), // 1.6666625440e-1f\n P2 = reinterpret(0xBB355215), // -2.7667332906e-3f\n Ox1p127f = reinterpret(0x7F000000);\n var hx = reinterpret(x);\n var sign_ = (hx >> 31);\n hx &= 0x7FFFFFFF;\n if (hx >= 0x42AEAC50) {\n if (hx >= 0x42B17218) {\n if (!sign_) return x * Ox1p127f;\n else if (hx >= 0x42CFF1B5) return 0;\n }\n }\n var hi: f32, lo: f32;\n var k: i32;\n if (hx > 0x3EB17218) {\n if (hx > 0x3F851592) {\n k = (invln2 * x + builtin_copysign(0.5, x));\n } else {\n k = 1 - (sign_ << 1);\n }\n hi = x - k * ln2hi;\n lo = k * ln2lo;\n x = hi - lo;\n } else if (hx > 0x39000000) {\n k = 0;\n hi = x;\n lo = 0;\n } else {\n return 1 + x;\n }\n var xx = x * x;\n var c = x - xx * (P1 + xx * P2);\n var y: f32 = 1 + (x * c / (2 - c) - lo + hi);\n if (k == 0) return y;\n return scalbn(y, k);\n }\n\n export function expm1(x: f32): f32 { // see: musl/src/math/expm1f.c and SUN COPYRIGHT NOTICE above\n const\n o_threshold = reinterpret(0x42B17180), // 8.8721679688e+01f\n ln2_hi = reinterpret(0x3F317180), // 6.9313812256e-01f\n ln2_lo = reinterpret(0x3717F7D1), // 9.0580006145e-06f\n invln2 = reinterpret(0x3FB8AA3B), // 1.4426950216e+00f\n Q1 = reinterpret(0xBD088868), // -3.3333212137e-02f\n Q2 = reinterpret(0x3ACF3010), // 1.5807170421e-03f\n Ox1p127f = reinterpret(0x7F000000);\n var u = reinterpret(x);\n var hx = u & 0x7FFFFFFF;\n var sign_ = (u >> 31);\n if (hx >= 0x4195B844) {\n if (hx > 0x7F800000) return x;\n if (sign_) return -1;\n if (x > o_threshold) {\n x *= Ox1p127f;\n return x;\n }\n }\n var c: f32 = 0.0, t: f32, k: i32;\n if (hx > 0x3EB17218) {\n k = select(\n 1 - (sign_ << 1),\n (invln2 * x + builtin_copysign(0.5, x)),\n hx < 0x3F851592\n );\n t = k;\n let hi = x - t * ln2_hi;\n let lo = t * ln2_lo;\n x = hi - lo;\n c = (hi - x) - lo;\n } else if (hx < 0x33000000) {\n return x;\n } else k = 0;\n var hfx: f32 = 0.5 * x;\n var hxs: f32 = x * hfx;\n var r1: f32 = 1.0 + hxs * (Q1 + hxs * Q2);\n t = 3.0 - r1 * hfx;\n var e = hxs * ((r1 - t) / (6.0 - x * t));\n if (k == 0) return x - (x * e - hxs);\n e = x * (e - c) - c;\n e -= hxs;\n if (k == -1) return 0.5 * (x - e) - 0.5;\n if (k == 1) {\n if (x < -0.25) return -2.0 * (e - (x + 0.5));\n return 1.0 + 2.0 * (x - e);\n }\n u = (0x7F + k) << 23;\n var twopk = reinterpret(u);\n var y: f32;\n if (k < 0 || k > 56) {\n y = x - e + 1.0;\n if (k == 128) y = y * 2.0 * Ox1p127f;\n else y = y * twopk;\n return y - 1.0;\n }\n u = (0x7F - k) << 23;\n y = reinterpret(u);\n if (k < 20) y = (1 - y) - e;\n else y = 1 - (e + y);\n return (x + y) * twopk;\n }\n\n // @ts-ignore: decorator\n @inline\n export function fround(x: f32): f32 {\n return x;\n }\n\n export function hypot(x: f32, y: f32): f32 { // see: musl/src/math/hypotf.c\n const\n Ox1p90f = reinterpret(0x6C800000),\n Ox1p_90f = reinterpret(0x12800000);\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n ux &= 0x7FFFFFFF;\n uy &= 0x7FFFFFFF;\n if (ux < uy) {\n let ut = ux;\n ux = uy;\n uy = ut;\n }\n x = reinterpret(ux);\n y = reinterpret(uy);\n if (uy == 0xFF << 23) return y;\n if (ux >= 0xFF << 23 || uy == 0 || ux - uy >= 25 << 23) return x + y;\n var z: f32 = 1;\n if (ux >= (0x7F + 60) << 23) {\n z = Ox1p90f;\n x *= Ox1p_90f;\n y *= Ox1p_90f;\n } else if (uy < (0x7F - 60) << 23) {\n z = Ox1p_90f;\n x *= Ox1p90f;\n y *= Ox1p90f;\n }\n return z * builtin_sqrt((x * x + y * y));\n }\n\n // @ts-ignore: decorator\n @inline\n export function imul(x: f32, y: f32): f32 {\n /*\n * Wasm (MVP) and JS have different approaches for double->int conversions.\n *\n * For emulate JS conversion behavior and avoid trapping from wasm we should modulate by MAX_INT\n * our float-point arguments before actual convertion to integers.\n */\n if (!isFinite(x + y)) return 0;\n const inv32 = 1.0 / 4294967296;\n return (\n (x - 4294967296 * builtin_floor(x * inv32)) *\n (y - 4294967296 * builtin_floor(y * inv32))\n );\n }\n\n export function log(x: f32): f32 { // see: musl/src/math/logf.c and SUN COPYRIGHT NOTICE above\n const\n ln2_hi = reinterpret(0x3F317180), // 6.9313812256e-01f\n ln2_lo = reinterpret(0x3717F7D1), // 9.0580006145e-06f\n Lg1 = reinterpret(0x3F2AAAAA), // 0xaaaaaa.0p-24f\n Lg2 = reinterpret(0x3ECCCE13), // 0xccce13.0p-25f\n Lg3 = reinterpret(0x3E91E9EE), // 0x91e9ee.0p-25f\n Lg4 = reinterpret(0x3E789E26), // 0xf89e26.0p-26f\n Ox1p25f = reinterpret(0x4C000000);\n var u = reinterpret(x);\n var k = 0;\n if (u < 0x00800000 || (u >> 31)) {\n if (u << 1 == 0) return -1 / (x * x);\n if (u >> 31) return (x - x) / 0;\n k -= 25;\n x *= Ox1p25f;\n u = reinterpret(x);\n } else if (u >= 0x7F800000) return x;\n else if (u == 0x3F800000) return 0;\n u += 0x3F800000 - 0x3F3504F3;\n k += (u >> 23) - 0x7F;\n u = (u & 0x007FFFFF) + 0x3F3504F3;\n x = reinterpret(u);\n var f = x - 1.0;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * Lg4);\n var t2 = z * (Lg1 + w * Lg3);\n var r = t2 + t1;\n var hfsq = 0.5 * f * f;\n var dk = k;\n return s * (hfsq + r) + dk * ln2_lo - hfsq + f + dk * ln2_hi;\n }\n\n export function log10(x: f32): f32 { // see: musl/src/math/log10f.c and SUN COPYRIGHT NOTICE above\n const\n ivln10hi = reinterpret(0x3EDE6000), // 4.3432617188e-01f\n ivln10lo = reinterpret(0xB804EAD9), // -3.1689971365e-05f\n log10_2hi = reinterpret(0x3E9A2080), // 3.0102920532e-01f\n log10_2lo = reinterpret(0x355427DB), // 7.9034151668e-07f\n Lg1 = reinterpret(0x3F2AAAAA), // 0xaaaaaa.0p-24f, 0.66666662693f\n Lg2 = reinterpret(0x3ECCCE13), // 0xccce13.0p-25f, 0.40000972152f\n Lg3 = reinterpret(0x3E91E9EE), // 0x91e9ee.0p-25f, 0.28498786688f\n Lg4 = reinterpret(0x3E789E26), // 0xf89e26.0p-26f, 0.24279078841f\n Ox1p25f = reinterpret(0x4C000000);\n var ix = reinterpret(x);\n var k = 0;\n if (ix < 0x00800000 || (ix >> 31)) {\n if (ix << 1 == 0) return -1 / (x * x);\n if (ix >> 31) return (x - x) / 0.0;\n k -= 25;\n x *= Ox1p25f;\n ix = reinterpret(x);\n } else if (ix >= 0x7F800000) return x;\n else if (ix == 0x3F800000) return 0;\n ix += 0x3F800000 - 0x3F3504F3;\n k += (ix >> 23) - 0x7F;\n ix = (ix & 0x007FFFFF) + 0x3F3504F3;\n x = reinterpret(ix);\n var f = x - 1.0;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * Lg4);\n var t2 = z * (Lg1 + w * Lg3);\n var r = t2 + t1;\n var hfsq: f32 = 0.5 * f * f;\n var hi = f - hfsq;\n ix = reinterpret(hi);\n ix &= 0xFFFFF000;\n hi = reinterpret(ix);\n var lo = f - hi - hfsq + s * (hfsq + r);\n var dk = k;\n return dk * log10_2lo + (lo + hi) * ivln10lo + lo * ivln10hi + hi * ivln10hi + dk * log10_2hi;\n }\n\n export function log1p(x: f32): f32 { // see: musl/src/math/log1pf.c and SUN COPYRIGHT NOTICE above\n const\n ln2_hi = reinterpret(0x3F317180), // 6.9313812256e-01\n ln2_lo = reinterpret(0x3717F7D1), // 9.0580006145e-06\n Lg1 = reinterpret(0x3F2AAAAA), // 0xaaaaaa.0p-24f, 0.66666662693f\n Lg2 = reinterpret(0x3ECCCE13), // 0xccce13.0p-25f, 0.40000972152f\n Lg3 = reinterpret(0x3E91E9EE), // 0x91e9ee.0p-25f, 0.28498786688f\n Lg4 = reinterpret(0x3E789E26); // 0xf89e26.0p-26f, 0.24279078841f\n var ix = reinterpret(x);\n var c: f32 = 0, f: f32 = 0;\n var k: i32 = 1;\n if (ix < 0x3ED413D0 || (ix >> 31)) {\n if (ix >= 0xBF800000) {\n if (x == -1) return x / 0.0;\n return (x - x) / 0.0;\n }\n if (ix << 1 < 0x33800000 << 1) return x;\n if (ix <= 0xBE95F619) {\n k = 0;\n c = 0;\n f = x;\n }\n } else if (ix >= 0x7F800000) return x;\n if (k) {\n let uf: f32 = 1 + x;\n let iu = reinterpret(uf);\n iu += 0x3F800000 - 0x3F3504F3;\n k = (iu >> 23) - 0x7F;\n if (k < 25) {\n c = k >= 2 ? 1 - (uf - x) : x - (uf - 1);\n c /= uf;\n } else c = 0;\n iu = (iu & 0x007FFFFF) + 0x3F3504F3;\n f = reinterpret(iu) - 1;\n }\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * Lg4);\n var t2 = z * (Lg1 + w * Lg3);\n var r = t2 + t1;\n var hfsq: f32 = 0.5 * f * f;\n var dk = k;\n return s * (hfsq + r) + (dk * ln2_lo + c) - hfsq + f + dk * ln2_hi;\n }\n\n export function log2(x: f32): f32 { // see: musl/src/math/log2f.c and SUN COPYRIGHT NOTICE above\n const\n ivln2hi = reinterpret(0x3FB8B000), // 1.4428710938e+00f\n ivln2lo = reinterpret(0xB9389AD4), // -1.7605285393e-04\n Lg1 = reinterpret(0x3F2AAAAA), // 0xaaaaaa.0p-24f, 0.66666662693f\n Lg2 = reinterpret(0x3ECCCE13), // 0xccce13.0p-25f, 0.40000972152f\n Lg3 = reinterpret(0x3E91E9EE), // 0x91e9ee.0p-25f, 0.28498786688f\n Lg4 = reinterpret(0x3E789E26), // 0xf89e26.0p-26f, 0.24279078841f\n Ox1p25f = reinterpret(0x4C000000);\n var ix = reinterpret(x);\n var k: i32 = 0;\n if (ix < 0x00800000 || (ix >> 31)) {\n if (ix << 1 == 0) return -1 / (x * x);\n if (ix >> 31) return (x - x) / 0.0;\n k -= 25;\n x *= Ox1p25f;\n ix = reinterpret(x);\n } else if (ix >= 0x7F800000) return x;\n else if (ix == 0x3F800000) return 0;\n ix += 0x3F800000 - 0x3F3504F3;\n k += (ix >> 23) - 0x7F;\n ix = (ix & 0x007FFFFF) + 0x3F3504F3;\n x = reinterpret(ix);\n var f = x - 1.0;\n var s = f / (2.0 + f);\n var z = s * s;\n var w = z * z;\n var t1 = w * (Lg2 + w * Lg4);\n var t2 = z * (Lg1 + w * Lg3);\n var r = t2 + t1;\n var hfsq: f32 = 0.5 * f * f;\n var hi = f - hfsq;\n var u = reinterpret(hi);\n u &= 0xFFFFF000;\n hi = reinterpret(u);\n var lo: f32 = f - hi - hfsq + s * (hfsq + r);\n var dk = k;\n return (lo + hi) * ivln2lo + lo * ivln2hi + hi * ivln2hi + dk;\n }\n\n // @ts-ignore: decorator\n @inline\n export function max(value1: f32, value2: f32): f32 {\n return builtin_max(value1, value2);\n }\n\n // @ts-ignore: decorator\n @inline\n export function min(value1: f32, value2: f32): f32 {\n return builtin_min(value1, value2);\n }\n\n export function pow(x: f32, y: f32): f32 { // see: musl/src/math/powf.c and SUN COPYRIGHT NOTICE above\n const\n dp_h1 = reinterpret(0x3F15C000), // 5.84960938e-01f\n dp_l1 = reinterpret(0x35D1CFDC), // 1.56322085e-06f\n two24 = reinterpret(0x4B800000), // 16777216f\n huge = reinterpret(0x7149F2CA), // 1.0e+30f\n tiny = reinterpret(0x0DA24260), // 1.0e-30f\n L1 = reinterpret(0x3F19999A), // 6.0000002384e-01f\n L2 = reinterpret(0x3EDB6DB7), // 4.2857143283e-01f\n L3 = reinterpret(0x3EAAAAAB), // 3.3333334327e-01f\n L4 = reinterpret(0x3E8BA305), // 2.7272811532e-01f\n L5 = reinterpret(0x3E6C3255), // 2.3066075146e-01f\n L6 = reinterpret(0x3E53F142), // 2.0697501302e-01f\n P1 = reinterpret(0x3E2AAAAB), // 1.6666667163e-01f\n P2 = reinterpret(0xBB360B61), // -2.7777778450e-03f\n P3 = reinterpret(0x388AB355), // 6.6137559770e-05f\n P4 = reinterpret(0xB5DDEA0E), // -1.6533901999e-06f\n P5 = reinterpret(0x3331BB4C), // 4.1381369442e-08f\n lg2 = reinterpret(0x3F317218), // 6.9314718246e-01f\n lg2_h = reinterpret(0x3F317200), // 6.93145752e-01f\n lg2_l = reinterpret(0x35BFBE8C), // 1.42860654e-06f\n ovt = reinterpret(0x3338AA3C), // 4.2995665694e-08f\n cp = reinterpret(0x3F76384F), // 9.6179670095e-01\n cp_h = reinterpret(0x3F764000), // 9.6191406250e-01\n cp_l = reinterpret(0xB8F623C6), // -1.1736857402e-04\n ivln2 = reinterpret(0x3FB8AA3B), // 1.4426950216e+00\n ivln2_h = reinterpret(0x3FB8AA00), // 1.4426879883e+00\n ivln2_l = reinterpret(0x36ECA570), // 7.0526075433e-06\n inv3 = reinterpret(0x3EAAAAAB); // 0.333333333333\n var hx = reinterpret(x);\n var hy = reinterpret(y);\n var ix = hx & 0x7FFFFFFF;\n var iy = hy & 0x7FFFFFFF;\n if (iy == 0) return 1.0; // x**0 = 1, even if x is NaN\n // if (hx == 0x3F800000) return 1.0; // C: 1**y = 1, even if y is NaN, JS: NaN\n if (ix > 0x7F800000 || iy > 0x7F800000) return x + y; // NaN if either arg is NaN\n var yisint = 0, j: i32, k: i32;\n if (hx < 0) {\n if (iy >= 0x4B800000) yisint = 2;\n else if (iy >= 0x3F800000) {\n k = (iy >> 23) - 0x7F;\n let ki = 23 - k;\n j = iy >> ki;\n if ((j << ki) == iy) yisint = 2 - (j & 1);\n }\n }\n if (iy == 0x7F800000) { // y is +-inf\n if (ix == 0x3F800000) return NaN; // C: (-1)**+-inf is 1, JS: NaN\n else if (ix > 0x3F800000) return hy >= 0 ? y : 0.0; // (|x|>1)**+-inf = inf,0\n else return hy >= 0 ? 0.0 : -y; // (|x|<1)**+-inf = 0,inf\n }\n if (iy == 0x3F800000) return hy >= 0 ? x : 1.0 / x;\n if (hy == 0x40000000) return x * x;\n if (hy == 0x3F000000) {\n if (hx >= 0) return builtin_sqrt(x);\n }\n var ax = builtin_abs(x);\n var z: f32;\n if (ix == 0x7F800000 || ix == 0 || ix == 0x3F800000) {\n z = ax;\n if (hy < 0) z = 1.0 / z;\n if (hx < 0) {\n if (((ix - 0x3F800000) | yisint) == 0) {\n let d = z - z;\n z = d / d;\n }\n else if (yisint == 1) z = -z;\n }\n return z;\n }\n var sn = 1.0;\n if (hx < 0) {\n if (yisint == 0) {\n let d = x - x;\n return d / d;\n }\n if (yisint == 1) sn = -1.0;\n }\n var t1: f32, t2: f32, r: f32, s: f32, t: f32, u: f32, v: f32, w: f32, p_h: f32, p_l: f32;\n var n: i32, is: i32;\n if (iy > 0x4D000000) {\n if (ix < 0x3F7FFFF8) return hy < 0 ? sn * huge * huge : sn * tiny * tiny;\n if (ix > 0x3F800007) return hy > 0 ? sn * huge * huge : sn * tiny * tiny;\n t = ax - 1;\n w = (t * t) * (0.5 - t * (inv3 - t * 0.25));\n u = ivln2_h * t;\n v = t * ivln2_l - w * ivln2;\n t1 = u + v;\n is = reinterpret(t1);\n t1 = reinterpret(is & 0xFFFFF000);\n t2 = v - (t1 - u);\n } else {\n let s2: f32, s_h: f32, s_l: f32, t_h: f32, t_l: f32;\n n = 0;\n if (ix < 0x00800000) {\n ax *= two24;\n n -= 24;\n ix = reinterpret(ax);\n }\n n += (ix >> 23) - 0x7F;\n j = ix & 0x007FFFFF;\n ix = j | 0x3F800000;\n if (j <= 0x1CC471) k = 0;\n else if (j < 0x5DB3D7) k = 1;\n else {\n k = 0;\n n += 1;\n ix -= 0x00800000;\n }\n ax = reinterpret(ix);\n let bp = select(1.5, 1.0, k); // k ? 1.5 : 1.0\n u = ax - bp;\n v = 1.0 / (ax + bp);\n s = u * v;\n s_h = s;\n is = reinterpret(s_h);\n s_h = reinterpret(is & 0xFFFFF000);\n is = ((ix >> 1) & 0xFFFFF000) | 0x20000000;\n t_h = reinterpret(is + 0x00400000 + (k << 21));\n t_l = ax - (t_h - bp);\n s_l = v * ((u - s_h * t_h) - s_h * t_l);\n s2 = s * s;\n r = s2 * s2 * (L1 + s2 * (L2 + s2 * (L3 + s2 * (L4 + s2 * (L5 + s2 * L6)))));\n r += s_l * (s_h + s);\n s2 = s_h * s_h;\n t_h = 3.0 + s2 + r;\n is = reinterpret(t_h);\n t_h = reinterpret(is & 0xFFFFF000);\n t_l = r - ((t_h - 3.0) - s2);\n u = s_h * t_h;\n v = s_l * t_h + t_l * s;\n p_h = u + v;\n is = reinterpret(p_h);\n p_h = reinterpret(is & 0xFFFFF000);\n p_l = v - (p_h - u);\n let z_h = cp_h * p_h;\n let dp_l = select(dp_l1, 0.0, k);\n let z_l = cp_l * p_h + p_l * cp + dp_l;\n t = n;\n let dp_h = select(dp_h1, 0.0, k);\n t1 = (((z_h + z_l) + dp_h) + t);\n is = reinterpret(t1);\n t1 = reinterpret(is & 0xFFFFF000);\n t2 = z_l - (((t1 - t) - dp_h) - z_h);\n }\n is = reinterpret(y);\n var y1 = reinterpret(is & 0xFFFFF000);\n p_l = (y - y1) * t1 + y * t2;\n p_h = y1 * t1;\n z = p_l + p_h;\n j = reinterpret(z);\n if (j > 0x43000000) {\n return sn * huge * huge;\n } else if (j == 0x43000000) {\n if (p_l + ovt > z - p_h) return sn * huge * huge;\n } else if ((j & 0x7FFFFFFF) > 0x43160000) {\n return sn * tiny * tiny;\n } else if (j == 0xC3160000) {\n if (p_l <= z - p_h) return sn * tiny * tiny;\n }\n var i = j & 0x7FFFFFFF;\n k = (i >> 23) - 0x7F;\n n = 0;\n if (i > 0x3F000000) {\n n = j + (0x00800000 >> (k + 1));\n k = ((n & 0x7FFFFFFF) >> 23) - 0x7F;\n t = reinterpret(n & ~(0x007FFFFF >> k));\n n = ((n & 0x007FFFFF) | 0x00800000) >> (23 - k);\n if (j < 0) n = -n;\n p_h -= t;\n }\n t = p_l + p_h;\n is = reinterpret(t);\n t = reinterpret(is & 0xFFFF8000);\n u = t * lg2_h;\n v = (p_l - (t - p_h)) * lg2 + t * lg2_l;\n z = u + v;\n w = v - (z - u);\n t = z * z;\n t1 = z - t * (P1 + t * (P2 + t * (P3 + t * (P4 + t * P5))));\n r = (z * t1) / (t1 - 2.0) - (w + z * w);\n z = 1.0 - (r - z);\n j = reinterpret(z);\n j += n << 23;\n if ((j >> 23) <= 0) z = scalbn(z, n);\n else z = reinterpret(j);\n return sn * z;\n }\n\n // @ts-ignore: decorator\n @inline\n export function seedRandom(value: i64): void {\n NativeMath.seedRandom(value);\n }\n\n // Using xoroshiro64starstar from http://xoshiro.di.unimi.it/xoroshiro64starstar.c\n export function random(): f32 {\n if (!random_seeded) throw new Error("PRNG must be seeded.");\n\n var s0 = random_state0_32;\n var s1 = random_state1_32;\n var r = rotl(s0 * 0x9E3779BB, 5) * 5;\n\n s1 ^= s0;\n random_state0_32 = rotl(s0, 26) ^ s1 ^ (s1 << 9);\n random_state1_32 = rotl(s1, 13);\n\n return reinterpret((r >> 9) | (127 << 23)) - 1.0;\n }\n\n // @ts-ignore: decorator\n @inline\n export function round(x: f32): f32 {\n return builtin_copysign(builtin_floor(x + 0.5), x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function sign(x: f32): f32 {\n if (ASC_SHRINK_LEVEL > 0) {\n return builtin_abs(x) > 0 ? builtin_copysign(1, x) : x;\n } else {\n return x > 0 ? 1 : x < 0 ? -1 : x;\n }\n }\n\n // @ts-ignore: decorator\n @inline\n export function signbit(x: f32): bool {\n // @ts-ignore: type\n return ((reinterpret(x) >>> 31) & (x == x));\n }\n\n export function sin(x: f32): f32 { // see: musl/src/math/sinf.c\n const s1pio2 = reinterpret(0x3FF921FB54442D18); // M_PI_2 * 1\n const s2pio2 = reinterpret(0x400921FB54442D18); // M_PI_2 * 2\n const s3pio2 = reinterpret(0x4012D97C7F3321D2); // M_PI_2 * 3\n const s4pio2 = reinterpret(0x401921FB54442D18); // M_PI_2 * 4\n\n var ix = reinterpret(x);\n var sign = ix >> 31;\n ix &= 0x7FFFFFFF;\n\n if (ix <= 0x3f490fda) { /* |x| ~<= π/4 */\n if (ix < 0x39800000) { /* |x| < 2**-12 */\n return x;\n }\n return sin_kernf(x);\n }\n\n if (ASC_SHRINK_LEVEL < 1) {\n if (ix <= 0x407b53d1) { /* |x| ~<= 5π/4 */\n if (ix <= 0x4016cbe3) { /* |x| ~<= 3π/4 */\n return sign ? -cos_kernf(x + s1pio2) : cos_kernf(x - s1pio2);\n }\n return sin_kernf(-(sign ? x + s2pio2 : x - s2pio2));\n }\n\n if (ix <= 0x40e231d5) { /* |x| ~<= 9π/4 */\n if (ix <= 0x40afeddf) { /* |x| ~<= 7π/4 */\n return sign ? cos_kernf(x + s3pio2) : -cos_kernf(x - s3pio2);\n }\n return sin_kernf(sign ? x + s4pio2 : x - s4pio2);\n }\n }\n\n /* sin(Inf or NaN) is NaN */\n if (ix >= 0x7f800000) return x - x;\n\n var n = rempio2f(x, ix, sign);\n var y = rempio2f_y;\n\n var t = n & 1 ? cos_kernf(y) : sin_kernf(y);\n return n & 2 ? -t : t;\n }\n\n export function sinh(x: f32): f32 { // see: musl/src/math/sinhf.c\n var u = reinterpret(x) & 0x7FFFFFFF;\n var absx = reinterpret(u);\n var t: f32;\n var h = builtin_copysign(0.5, x);\n if (u < 0x42B17217) {\n t = expm1(absx);\n if (u < 0x3F800000) {\n if (u < 0x3F800000 - (12 << 23)) return x;\n return h * (2 * t - t * t / (t + 1));\n }\n return h * (t + t / (t + 1));\n }\n t = 2 * h * expo2f(absx);\n return t;\n }\n\n // @ts-ignore: decorator\n @inline\n export function sqrt(x: f32): f32 {\n return builtin_sqrt(x);\n }\n\n export function tan(x: f32): f32 { // see: musl/src/math/tanf.c\n const t1pio2 = reinterpret(0x3FF921FB54442D18); // 1 * M_PI_2\n const t2pio2 = reinterpret(0x400921FB54442D18); // 2 * M_PI_2\n const t3pio2 = reinterpret(0x4012D97C7F3321D2); // 3 * M_PI_2\n const t4pio2 = reinterpret(0x401921FB54442D18); // 4 * M_PI_2\n\n var ix = reinterpret(x);\n var sign = ix >> 31;\n ix &= 0x7FFFFFFF;\n\n if (ix <= 0x3f490fda) { /* |x| ~<= π/4 */\n if (ix < 0x39800000) { /* |x| < 2**-12 */\n return x;\n }\n return tan_kernf(x, 0);\n }\n\n if (ASC_SHRINK_LEVEL < 1) {\n if (ix <= 0x407b53d1) { /* |x| ~<= 5π/4 */\n if (ix <= 0x4016cbe3) { /* |x| ~<= 3π/4 */\n return tan_kernf((sign ? x + t1pio2 : x - t1pio2), 1);\n } else {\n return tan_kernf((sign ? x + t2pio2 : x - t2pio2), 0);\n }\n }\n if (ix <= 0x40e231d5) { /* |x| ~<= 9π/4 */\n if (ix <= 0x40afeddf) { /* |x| ~<= 7π/4 */\n return tan_kernf((sign ? x + t3pio2 : x - t3pio2), 1);\n } else {\n return tan_kernf((sign ? x + t4pio2 : x - t4pio2), 0);\n }\n }\n }\n\n /* tan(Inf or NaN) is NaN */\n if (ix >= 0x7f800000) return x - x;\n\n /* argument reduction */\n var n = rempio2f(x, ix, sign);\n var y = rempio2f_y;\n return tan_kernf(y, n & 1);\n }\n\n export function tanh(x: f32): f32 { // see: musl/src/math/tanhf.c\n var u = reinterpret(x);\n u &= 0x7FFFFFFF;\n var y = reinterpret(u);\n var t: f32;\n if (u > 0x3F0C9F54) {\n if (u > 0x41200000) t = 1 + 0 / y;\n else {\n t = expm1(2 * y);\n t = 1 - 2 / (t + 2);\n }\n } else if (u > 0x3E82C578) {\n t = expm1(2 * y);\n t = t / (t + 2);\n } else if (u >= 0x00800000) {\n t = expm1(-2 * y);\n t = -t / (t + 2);\n } else t = y;\n return builtin_copysign(t, x);\n }\n\n // @ts-ignore: decorator\n @inline\n export function trunc(x: f32): f32 {\n return builtin_trunc(x);\n }\n\n export function scalbn(x: f32, n: i32): f32 { // see: https://git.musl-libc.org/cgit/musl/tree/src/math/scalbnf.c\n const\n Ox1p24f = reinterpret(0x4B800000),\n Ox1p127f = reinterpret(0x7F000000),\n Ox1p_126f = reinterpret(0x00800000);\n var y = x;\n if (n > 127) {\n y *= Ox1p127f;\n n -= 127;\n if (n > 127) {\n y *= Ox1p127f;\n n = builtin_min(n - 127, 127);\n }\n } else if (n < -126) {\n y *= Ox1p_126f * Ox1p24f;\n n += 126 - 24;\n if (n < -126) {\n y *= Ox1p_126f * Ox1p24f;\n n = builtin_max(n + 126 - 24, -126);\n }\n }\n return y * reinterpret((0x7F + n) << 23);\n }\n\n export function mod(x: f32, y: f32): f32 { // see: musl/src/math/fmodf.c\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n var ex = (ux >> 23 & 0xFF);\n var ey = (uy >> 23 & 0xFF);\n var sx = ux & 0x80000000;\n var uy1 = uy << 1;\n if (uy1 == 0 || ex == 0xFF || isNaN(y)) {\n let m = x * y;\n return m / m;\n }\n var ux1 = ux << 1;\n if (ux1 <= uy1) {\n if (ux1 == uy1) return 0 * x;\n return x;\n }\n if (!ex) {\n ex -= builtin_clz(ux << 9);\n ux <<= -ex + 1;\n } else {\n ux &= -1 >> 9;\n ux |= 1 << 23;\n }\n if (!ey) {\n ey -= builtin_clz(uy << 9);\n uy <<= -ey + 1;\n } else {\n uy &= -1 >> 9;\n uy |= 1 << 23;\n }\n while (ex > ey) {\n if (ux >= uy) {\n if (ux == uy) return 0 * x;\n ux -= uy;\n }\n ux <<= 1;\n --ex;\n }\n if (ux >= uy) {\n if (ux == uy) return 0 * x;\n ux -= uy;\n }\n // for (; !(ux >> 23); ux <<= 1) --ex;\n var shift = builtin_clz(ux << 8);\n ex -= shift;\n ux <<= shift;\n if (ex > 0) {\n ux -= 1 << 23;\n ux |= ex << 23;\n } else {\n ux >>= -ex + 1;\n }\n ux |= sx;\n return reinterpret(ux);\n }\n\n export function rem(x: f32, y: f32): f32 { // see: musl/src/math/remquof.c\n var ux = reinterpret(x);\n var uy = reinterpret(y);\n var ex = (ux >> 23 & 0xFF);\n var ey = (uy >> 23 & 0xFF);\n var sx = (ux >> 31);\n var uxi = ux;\n if (uy << 1 == 0 || ex == 0xFF || isNaN(y)) return (x * y) / (x * y);\n if (ux << 1 == 0) return x;\n if (!ex) {\n ex -= builtin_clz(uxi << 9);\n uxi <<= -ex + 1;\n } else {\n uxi &= -1 >> 9;\n uxi |= 1 << 23;\n }\n if (!ey) {\n ey -= builtin_clz(uy << 9);\n uy <<= -ey + 1;\n } else {\n uy &= -1 >> 9;\n uy |= 1 << 23;\n }\n var q = 0;\n do {\n if (ex < ey) {\n if (ex + 1 == ey) break; // goto end\n return x;\n }\n while (ex > ey) {\n if (uxi >= uy) {\n uxi -= uy;\n ++q;\n }\n uxi <<= 1;\n q <<= 1;\n --ex;\n }\n if (uxi >= uy) {\n uxi -= uy;\n ++q;\n }\n if (uxi == 0) ex = -30;\n else {\n let shift = builtin_clz(uxi << 8);\n ex -= shift;\n uxi <<= shift;\n }\n break;\n } while (false);\n // end\n if (ex > 0) {\n uxi -= 1 << 23;\n uxi |= ex << 23;\n } else {\n uxi >>= -ex + 1;\n }\n x = reinterpret(uxi);\n y = builtin_abs(y);\n var x2 = x + x;\n if (ex == ey || (ex + 1 == ey && (x2 > y || (x2 == y && (q & 1))))) {\n x -= y;\n // q++;\n }\n return sx ? -x : x;\n }\n\n export function sincos(x: f32): void { // see: musl/tree/src/math/sincosf.c\n const s1pio2 = reinterpret(0x3FF921FB54442D18); // 1 * M_PI_2\n const s2pio2 = reinterpret(0x400921FB54442D18); // 2 * M_PI_2\n const s3pio2 = reinterpret(0x4012D97C7F3321D2); // 3 * M_PI_2\n const s4pio2 = reinterpret(0x401921FB54442D18); // 4 * M_PI_2\n\n var ix = reinterpret(x);\n var sign = ix >> 31;\n ix &= 0x7fffffff;\n\n if (ix <= 0x3f490fda) { /* |x| ~<= π/4 */\n if (ix < 0x39800000) { /* |x| < 2**-12 */\n sincos_sin = x;\n sincos_cos = 1;\n return;\n }\n sincos_sin = sin_kernf(x);\n sincos_cos = cos_kernf(x);\n return;\n }\n\n if (ASC_SHRINK_LEVEL < 1) {\n if (ix <= 0x407b53d1) { /* |x| ~<= 5π/4 */\n if (ix <= 0x4016cbe3) { /* |x| ~<= 3π/4 */\n if (sign) {\n sincos_sin = -cos_kernf(x + s1pio2);\n sincos_cos = sin_kernf(x + s1pio2);\n } else {\n sincos_sin = cos_kernf(s1pio2 - x);\n sincos_cos = sin_kernf(s1pio2 - x);\n }\n return;\n }\n /* -sin(x + c) is not correct if x+c could be 0: -0 vs +0 */\n sincos_sin = -sin_kernf(sign ? x + s2pio2 : x - s2pio2);\n sincos_cos = -cos_kernf(sign ? x + s2pio2 : x - s2pio2);\n return;\n }\n\n if (ix <= 0x40e231d5) { /* |x| ~<= 9π/4 */\n if (ix <= 0x40afeddf) { /* |x| ~<= 7π/4 */\n if (sign) {\n sincos_sin = cos_kernf(x + s3pio2);\n sincos_cos = -sin_kernf(x + s3pio2);\n } else {\n sincos_sin = -cos_kernf(x - s3pio2);\n sincos_cos = sin_kernf(x - s3pio2);\n }\n return;\n }\n sincos_sin = sin_kernf(sign ? x + s4pio2 : x - s4pio2);\n sincos_cos = cos_kernf(sign ? x + s4pio2 : x - s4pio2);\n return;\n }\n }\n\n /* sin(Inf or NaN) is NaN */\n if (ix >= 0x7f800000) {\n let xx = x - x;\n sincos_sin = xx;\n sincos_cos = xx;\n return;\n }\n\n /* general argument reduction needed */\n var n = rempio2f(x, ix, sign);\n var y = rempio2f_y;\n var s = sin_kernf(y);\n var c = cos_kernf(y);\n\n switch (n & 3) {\n case 0: {\n sincos_sin = s;\n sincos_cos = c;\n break;\n }\n case 1: {\n sincos_sin = c;\n sincos_cos = -s;\n break;\n }\n case 2: {\n sincos_sin = -s;\n sincos_cos = -c;\n break;\n }\n case 3:\n default: {\n sincos_sin = -c;\n sincos_cos = s;\n break;\n }\n }\n }\n}\n\nexport function ipow32(x: i32, e: i32): i32 {\n var out = 1;\n if (ASC_SHRINK_LEVEL < 1) {\n if (e < 0) return 0;\n\n switch (e) {\n case 0: return 1;\n case 1: return x;\n case 2: return x * x;\n }\n\n let log = 32 - clz(e);\n if (log <= 5) {\n // 32 = 2 ^ 5, so need only five cases.\n // But some extra cases needs for properly overflowing\n switch (log) {\n case 5: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 4: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 3: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 2: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 1: {\n if (e & 1) out *= x;\n }\n }\n return out;\n }\n }\n\n while (e > 0) {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n return out;\n}\n\nexport function ipow64(x: i64, e: i32): i64 {\n var out: i64 = 1;\n if (ASC_SHRINK_LEVEL < 1) {\n if (e < 0) return 0;\n switch (e) {\n case 0: return 1;\n case 1: return x;\n case 2: return x * x;\n }\n\n let log = 32 - clz(e);\n if (log <= 6) {\n // 64 = 2 ^ 6, so need only six cases.\n // But some extra cases needs for properly overflowing\n switch (log) {\n case 6: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 5: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 4: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 3: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 2: {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n case 1: {\n if (e & 1) out *= x;\n }\n }\n return out;\n }\n }\n\n while (e > 0) {\n if (e & 1) out *= x;\n e >>= 1;\n x *= x;\n }\n return out;\n}\n\nexport function ipow32f(x: f32, e: i32): f32 {\n var sign = e >> 31;\n e = (e + sign) ^ sign; // abs(e)\n var out: f32 = 1;\n while (e) {\n out *= select(x, 1.0, e & 1);\n e >>= 1;\n x *= x;\n }\n return sign ? 1.0 / out : out;\n}\n\nexport function ipow64f(x: f64, e: i32): f64 {\n var sign = e >> 31;\n e = (e + sign) ^ sign; // abs(e)\n var out = 1.0;\n while (e) {\n out *= select(x, 1.0, e & 1);\n e >>= 1;\n x *= x;\n }\n return sign ? 1.0 / out : out;\n}\n',memory:'import { memcmp, memmove, memset } from "./util/memory";\nimport { E_NOTIMPLEMENTED } from "./util/error";\n\n/** Memory manager interface. */\nexport namespace memory {\n\n /** Gets the size of the memory in pages. */\n // @ts-ignore: decorator\n @builtin\n export declare function size(): i32;\n\n /** Grows the memory by the given size in pages and returns the previous size in pages. */\n // @ts-ignore: decorator\n @unsafe @builtin\n export declare function grow(pages: i32): i32;\n\n /** Fills a section in memory with the specified byte value. */\n // @ts-ignore: decorator\n @unsafe @builtin\n export function fill(dst: usize, c: u8, n: usize): void {\n memset(dst, c, n); // fallback if "bulk-memory" isn\'t enabled\n }\n\n /** Copies a section of memory to another. Has move semantics. */\n // @ts-ignore: decorator\n @unsafe @builtin\n export function copy(dst: usize, src: usize, n: usize): void {\n memmove(dst, src, n); // fallback if "bulk-memory" isn\'t enabled\n }\n\n /** Initializes a memory segment. */\n // @ts-ignore: decorator\n @unsafe\n export function init(segmentIndex: u32, srcOffset: usize, dstOffset: usize, n: usize): void {\n throw new Error(E_NOTIMPLEMENTED);\n }\n\n /** Drops a memory segment. */\n // @ts-ignore: decorator\n @unsafe\n export function drop(segmentIndex: u32): void {\n throw new Error(E_NOTIMPLEMENTED);\n }\n\n /** Repeats a section of memory at a specific address. */\n // @ts-ignore: decorator\n @unsafe\n export function repeat(dst: usize, src: usize, srcLength: usize, count: usize): void {\n var index: usize = 0;\n var total = srcLength * count;\n while (index < total) {\n memory.copy(dst + index, src, srcLength);\n index += srcLength;\n }\n }\n\n /** Compares a section of memory to another. */\n // @ts-ignore: decorator\n @inline\n export function compare(vl: usize, vr: usize, n: usize): i32 {\n return memcmp(vl, vr, n);\n }\n}\n',number:'import { itoa, dtoa } from "./util/number";\nimport { strtol } from "./util/string";\n\n// @ts-ignore: decorator\n@builtin @inline\nexport const NaN: f64 = 0 / 0;\n\n// @ts-ignore: decorator\n@builtin @inline\nexport const Infinity: f64 = 1 / 0;\n\nexport function isNaN(value: T): bool {\n if (!isFloat()) {\n if (!isInteger()) ERROR("numeric type expected");\n }\n return value != value;\n}\n\nexport function isFinite(value: T): bool {\n if (!isFloat()) {\n if (!isInteger()) ERROR("numeric type expected");\n }\n return value - value == 0;\n}\n\n@sealed @unmanaged\nexport abstract class I8 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: i8 = i8.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: i8 = i8.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): i8 {\n return strtol(value, radix);\n }\n\n toString(this: i8): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class I16 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: i16 = i16.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: i16 = i16.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): i16 {\n return strtol(value, radix);\n }\n\n toString(this: i16): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class I32 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: i32 = i32.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: i32 = i32.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): i32 {\n return strtol(value, radix);\n }\n\n toString(this: i32): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class I64 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: i64 = i64.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: i64 = i64.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): i64 {\n return strtol(value, radix);\n }\n\n toString(this: i64): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class Isize {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: isize = isize.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: isize = isize.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): isize {\n return strtol(value, radix);\n }\n\n toString(this: isize): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class U8 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: u8 = u8.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: u8 = u8.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): u8 {\n return strtol(value, radix);\n }\n\n toString(this: u8): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class U16 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: u16 = u16.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: u16 = u16.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): u16 {\n return strtol(value, radix);\n }\n\n toString(this: u16): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class U32 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: u32 = u32.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: u32 = u32.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): u32 {\n return strtol(value, radix);\n }\n\n toString(this: u32): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class U64 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: u64 = u64.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: u64 = u64.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): u64 {\n return strtol(value, radix);\n }\n\n toString(this: u64): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class Usize {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: usize = usize.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: usize = usize.MAX_VALUE;\n\n static parseInt(value: string, radix: i32 = 0): usize {\n return strtol(value, radix);\n }\n\n toString(this: usize): String {\n // TODO: radix\n return itoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class Bool {\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: bool = bool.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: bool = bool.MAX_VALUE;\n\n toString(this: bool): String {\n // TODO: radix?\n return this ? "true" : "false";\n }\n}\n\nexport { Bool as Boolean };\n\n@sealed @unmanaged\nexport abstract class F32 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly EPSILON: f32 = f32.EPSILON;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: f32 = f32.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: f32 = f32.MAX_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_SAFE_INTEGER: f32 = f32.MIN_SAFE_INTEGER;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_SAFE_INTEGER: f32 = f32.MAX_SAFE_INTEGER;\n\n // @ts-ignore: decorator\n @lazy\n static readonly POSITIVE_INFINITY: f32 = Infinity;\n\n // @ts-ignore: decorator\n @lazy\n static readonly NEGATIVE_INFINITY: f32 = -Infinity;\n\n // @ts-ignore: decorator\n @lazy\n static readonly NaN: f32 = NaN;\n\n static isNaN(value: f32): bool {\n return isNaN(value);\n }\n\n static isFinite(value: f32): bool {\n return isFinite(value);\n }\n\n static isSafeInteger(value: f32): bool {\n return abs(value) <= f32.MAX_SAFE_INTEGER && trunc(value) == value;\n }\n\n static isInteger(value: f32): bool {\n return isFinite(value) && trunc(value) == value;\n }\n\n static parseInt(value: string, radix: i32 = 0): f32 {\n return strtol(value, radix);\n }\n\n static parseFloat(value: string): f32 {\n return parseFloat(value);\n }\n\n toString(this: f32): String {\n // TODO: radix\n return dtoa(this);\n }\n}\n\n@sealed @unmanaged\nexport abstract class F64 {\n\n // @ts-ignore: decorator\n @lazy\n static readonly EPSILON: f64 = f64.EPSILON;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_VALUE: f64 = f64.MIN_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_VALUE: f64 = f64.MAX_VALUE;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MIN_SAFE_INTEGER: f64 = f64.MIN_SAFE_INTEGER;\n\n // @ts-ignore: decorator\n @lazy\n static readonly MAX_SAFE_INTEGER: f64 = f64.MAX_SAFE_INTEGER;\n\n // @ts-ignore: decorator\n @lazy\n static readonly POSITIVE_INFINITY: f64 = Infinity;\n\n // @ts-ignore: decorator\n @lazy\n static readonly NEGATIVE_INFINITY: f64 = -Infinity;\n\n // @ts-ignore: decorator\n @lazy\n static readonly NaN: f64 = NaN;\n\n static isNaN(value: f64): bool {\n return isNaN(value);\n }\n\n static isFinite(value: f64): bool {\n return isFinite(value);\n }\n\n static isSafeInteger(value: f64): bool {\n return abs(value) <= f64.MAX_SAFE_INTEGER && trunc(value) == value;\n }\n\n static isInteger(value: f64): bool {\n return isFinite(value) && trunc(value) == value;\n }\n\n static parseInt(value: string, radix: i32 = 0): f64 {\n return strtol(value, radix);\n }\n\n static parseFloat(value: string): f64 {\n return parseFloat(value);\n }\n\n toString(this: f64, radix: i32 = 0): String {\n // TODO: radix\n return dtoa(this);\n }\n}\n\nexport { F64 as Number };\n',polyfills:"export function bswap(value: T): T {\n if (isInteger()) {\n if (sizeof() == 2) {\n return ((value << 8) | ((value >> 8) & 0x00FF));\n }\n if (sizeof() == 4) {\n return (\n rotl(value & 0xFF00FF00, 8) |\n rotr(value & 0x00FF00FF, 8)\n );\n }\n if (sizeof() == 8) {\n let a = (value >> 8) & 0x00FF00FF00FF00FF;\n let b = (value & 0x00FF00FF00FF00FF) << 8;\n let v = a | b;\n\n a = (v >> 16) & 0x0000FFFF0000FFFF;\n b = (v & 0x0000FFFF0000FFFF) << 16;\n\n return rotr(a | b, 32);\n }\n return value;\n }\n assert(false);\n return value;\n}\n\nexport function bswap16(value: T): T {\n if (isInteger() && sizeof() <= 4) {\n if (sizeof() == 2) {\n return ((value << 8) | ((value >> 8) & 0x00FF));\n } else if (sizeof() == 4) {\n return (((value << 8) & 0xFF00) | ((value >> 8) & 0x00FF) | (value & 0xFFFF0000));\n }\n return value;\n }\n assert(false);\n return value;\n}\n",regexp:'export class RegExp {\n\n // @binding(CALL_NEW, [ STRING, STRING], OBJECT_HANDLE)\n constructor(pattern: string, flags: string = "") { throw new Error("unreachable"); }\n\n // @binding(CALL_THIS, [ STRING ], PASS_THRU)\n test(search: string): bool { throw new Error("unreachable"); }\n\n // @binding(CALL_THIS, [], STRING)\n toString(): string { throw new Error("unreachable"); }\n\n}\n',rt:'import { Typeinfo, TypeinfoFlags } from "./shared/typeinfo";\nimport { E_INDEXOUTOFRANGE } from "./util/error";\nimport { BLOCK, BLOCK_OVERHEAD } from "./rt/common";\nimport { ArrayBufferView } from "./arraybuffer";\n\n// @ts-ignore: decorator\n@builtin\nexport declare const __rtti_base: usize;\n\n// @ts-ignore: decorator\n@builtin @unsafe\nexport declare function __visit_globals(cookie: u32): void;\n\n// @ts-ignore: decorator\n@builtin @unsafe\nexport declare function __visit_members(ref: usize, cookie: u32): void;\n\n// @ts-ignore: decorator\n@unsafe\nexport function __typeinfo(id: u32): TypeinfoFlags {\n var ptr = __rtti_base;\n if (id > load(ptr)) throw new Error(E_INDEXOUTOFRANGE);\n return changetype(ptr + sizeof() + id * offsetof()).flags;\n}\n\n// @ts-ignore: decorator\n@unsafe\nexport function __instanceof(ref: usize, superId: u32): bool { // keyword\n var id = changetype(ref - BLOCK_OVERHEAD).rtId;\n var ptr = __rtti_base;\n if (id <= load(ptr)) {\n do if (id == superId) return true;\n while (id = changetype(ptr + sizeof() + id * offsetof()).base);\n }\n return false;\n}\n\n// @ts-ignore: decorator\n@unsafe\nexport function __allocArray(length: i32, alignLog2: usize, id: u32, data: usize = 0): usize {\n var array = __alloc(offsetof(), id);\n var bufferSize = length << alignLog2;\n var buffer = __alloc(bufferSize, idof());\n store(array, __retain(buffer), offsetof("data"));\n changetype(array).dataStart = buffer;\n changetype(array).dataLength = bufferSize;\n store(changetype(array), length, offsetof("length_"));\n if (data) memory.copy(buffer, data, bufferSize);\n return array;\n}\n\n// These are provided by the respective implementation, included as another entry file by asc:\n\n// @builtin @unsafe\n// export declare function __alloc(size: usize, id: u32): usize;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __realloc(ref: usize, size: usize): usize;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __free(ref: usize): void;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __retain(ref: usize): usize;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __release(ref: usize): void;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __collect(): void;\n\n// // @ts-ignore: decorator\n// @builtin @unsafe\n// export declare function __visit(ref: usize, cookie: u32): void;\n',"rt/common":"// Alignment guarantees\n\n// @ts-ignore: decorator\n@inline export const AL_BITS: u32 = 4; // 16 bytes to fit up to v128\n// @ts-ignore: decorator\n@inline export const AL_SIZE: usize = 1 << AL_BITS;\n// @ts-ignore: decorator\n@inline export const AL_MASK: usize = AL_SIZE - 1;\n\n// Extra debugging\n\n// @ts-ignore: decorator\n@inline export const DEBUG = true;\n\n// ╒════════════════ Common block layout (32-bit) ═════════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤\n// │ MM info │ -16\n// ├───────────────────────────────────────────────────────────────┤\n// │ GC info │ -12\n// ├───────────────────────────────────────────────────────────────┤\n// │ runtime id │ -8\n// ├───────────────────────────────────────────────────────────────┤\n// │ runtime size │ -4\n// ╞═══════════════════════════════════════════════════════════════╡\n// │ ... │ ref\n@unmanaged export class BLOCK {\n /** Memory manager info. */\n mmInfo: usize; // WASM64 needs adaption\n /** Garbage collector info. */\n gcInfo: u32;\n /** Runtime class id. */\n rtId: u32;\n /** Runtime object size. */\n rtSize: u32;\n}\n\n// @ts-ignore: decorator\n@inline export const BLOCK_OVERHEAD = (offsetof() + AL_MASK) & ~AL_MASK;\n\n// @ts-ignore: decorator\n@inline export const BLOCK_MAXSIZE: usize = (1 << 30) - BLOCK_OVERHEAD;\n","rt/index-full":'export { __alloc } from "rt/tlsf";\nexport { __retain, __release, __collect } from "rt/pure";\nexport { __rtti_base } from "rt";\n',"rt/index-half":'import "rt/index-full";\n',"rt/index-none":'import "rt/index-stub";\n',"rt/index-stub":'export { __alloc, __retain, __release, __collect } from "rt/stub";\nexport { __rtti_base } from "rt";\n',"rt/pure":'import { DEBUG, BLOCK_OVERHEAD } from "rt/common";\nimport { Block, freeBlock, ROOT } from "rt/tlsf";\nimport { TypeinfoFlags } from "shared/typeinfo";\nimport { onincrement, ondecrement, onfree, onalloc } from "./rtrace";\n\n/////////////////////////// A Pure Reference Counting Garbage Collector ///////////////////////////\n// see: https://researcher.watson.ibm.com/researcher/files/us-bacon/Bacon03Pure.pdf\n\n// ╒══════════════════════ GC Info structure ══════════════════════╕\n// │ 3 2 1 │\n// │1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0│\n// ├─┼─┴─┴─┼─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤\n// │B│color│ refCount │\n// └─┴─────┴───────────────────────────────────────────────────────┘\n// B: buffered\n\n// @ts-ignore: decorator\n@inline const BUFFERED_MASK: u32 = 1 << ((sizeof() * 8) - 1);\n// @ts-ignore: decorator\n@inline const COLOR_BITS = 3;\n// @ts-ignore: decorator\n@inline const COLOR_SHIFT: u32 = ctz(BUFFERED_MASK) - COLOR_BITS;\n// @ts-ignore: decorator\n@inline const COLOR_MASK: u32 = ((1 << COLOR_BITS) - 1) << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline export const REFCOUNT_MASK: u32 = (1 << COLOR_SHIFT) - 1;\n\n// ╒════════╤═══════════════════ Colors ═══════════════════════════╕\n// │ Color │ Meaning │\n// ├────────┼──────────────────────────────────────────────────────┤\n// │ BLACK │ In use or free │\n// │ GRAY │ Possible member of cycle │\n// │ WHITE │ Member of garbage cycle │\n// │ PURPLE │ Possible root of cycle │\n// │ RED │ Candidate cycle undergoing Σ-computation *concurrent │\n// │ ORANGE │ Candidate cycle awaiting epoch boundary *concurrent │\n// └────────┴──────────────────────────────────────────────────────┘\n// Acyclic detection has been decoupled, hence no GREEN.\n\n// @ts-ignore: decorator\n@inline const COLOR_BLACK: u32 = 0 << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const COLOR_GRAY: u32 = 1 << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const COLOR_WHITE: u32 = 2 << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const COLOR_PURPLE: u32 = 3 << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const COLOR_RED: u32 = 4 << COLOR_SHIFT;\n// @ts-ignore: decorator\n@inline const COLOR_ORANGE: u32 = 5 << COLOR_SHIFT;\n\n// @ts-ignore: decorator\n@inline const VISIT_DECREMENT = 1; // guard 0\n// @ts-ignore: decorator\n@inline const VISIT_MARKGRAY = 2;\n// @ts-ignore: decorator\n@inline const VISIT_SCAN = 3;\n// @ts-ignore: decorator\n@inline const VISIT_SCANBLACK = 4;\n// @ts-ignore: decorator\n@inline const VISIT_COLLECTWHITE = 5;\n\n// @ts-ignore: decorator\n@global @unsafe\nfunction __visit(ref: usize, cookie: i32): void {\n if (ref < __heap_base) return;\n var s = changetype(ref - BLOCK_OVERHEAD);\n switch (cookie) {\n case VISIT_DECREMENT: {\n decrement(s);\n break;\n }\n case VISIT_MARKGRAY: {\n if (DEBUG) assert((s.gcInfo & REFCOUNT_MASK) > 0);\n s.gcInfo = s.gcInfo - 1;\n markGray(s);\n break;\n }\n case VISIT_SCAN: {\n scan(s);\n break;\n }\n case VISIT_SCANBLACK: {\n let info = s.gcInfo;\n assert((info & ~REFCOUNT_MASK) == ((info + 1) & ~REFCOUNT_MASK)); // overflow\n s.gcInfo = info + 1;\n if ((info & COLOR_MASK) != COLOR_BLACK) {\n scanBlack(s);\n }\n break;\n }\n case VISIT_COLLECTWHITE: {\n collectWhite(s);\n break;\n }\n default: if (DEBUG) assert(false);\n }\n}\n\n/** Increments the reference count of the specified block by one.*/\nfunction increment(s: Block): void {\n var info = s.gcInfo;\n assert((info & ~REFCOUNT_MASK) == ((info + 1) & ~REFCOUNT_MASK)); // overflow\n s.gcInfo = info + 1;\n if (isDefined(ASC_RTRACE)) onincrement(s);\n if (DEBUG) assert(!(s.mmInfo & 1)); // used\n}\n\n/** Decrements the reference count of the specified block by one, possibly freeing it. */\nfunction decrement(s: Block): void {\n var info = s.gcInfo;\n var rc = info & REFCOUNT_MASK;\n if (isDefined(ASC_RTRACE)) ondecrement(s);\n if (DEBUG) assert(!(s.mmInfo & 1)); // used\n if (rc == 1) {\n __visit_members(changetype(s) + BLOCK_OVERHEAD, VISIT_DECREMENT);\n if (!(info & BUFFERED_MASK)) {\n freeBlock(ROOT, s);\n } else {\n s.gcInfo = BUFFERED_MASK | COLOR_BLACK | 0;\n }\n } else {\n if (DEBUG) assert(rc > 0);\n if (!(__typeinfo(s.rtId) & TypeinfoFlags.ACYCLIC)) {\n s.gcInfo = BUFFERED_MASK | COLOR_PURPLE | (rc - 1);\n if (!(info & BUFFERED_MASK)) {\n appendRoot(s);\n }\n } else {\n s.gcInfo = (info & ~REFCOUNT_MASK) | (rc - 1);\n }\n }\n}\n\n/** Buffer of possible roots. */\n// @ts-ignore: decorator\n@lazy var ROOTS: usize;\n/** Current absolute offset into the `ROOTS` buffer. */\n// @ts-ignore: decorator\n@lazy var CUR: usize = 0;\n/** Current absolute end offset into the `ROOTS` buffer. */\n// @ts-ignore: decorator\n@lazy var END: usize = 0;\n\n/** Appends a block to possible roots. */\nfunction appendRoot(s: Block): void {\n var cur = CUR;\n if (cur >= END) {\n growRoots(); // TBD: either that or pick a default and force collection on overflow\n cur = CUR;\n }\n store(cur, s);\n CUR = cur + sizeof();\n}\n\n/** Grows the roots buffer if it ran full. */\nfunction growRoots(): void {\n var oldRoots = ROOTS;\n var oldSize = CUR - oldRoots;\n var newSize = max(oldSize * 2, 64 << alignof());\n var newRoots = __alloc(newSize, 0);\n if (isDefined(ASC_RTRACE)) onfree(changetype(newRoots - BLOCK_OVERHEAD)); // neglect unmanaged\n memory.copy(newRoots, oldRoots, oldSize);\n if (oldRoots) {\n if (isDefined(ASC_RTRACE)) onalloc(changetype(oldRoots - BLOCK_OVERHEAD)); // neglect unmanaged\n __free(oldRoots);\n }\n ROOTS = newRoots;\n CUR = newRoots + oldSize;\n END = newRoots + newSize;\n}\n\n/** Collects cyclic garbage. */\n// @ts-ignore: decorator\n@global @unsafe\nexport function __collect(): void {\n\n // markRoots\n var roots = ROOTS;\n var cur = roots;\n for (let pos = cur, end = CUR; pos < end; pos += sizeof()) {\n let s = load(pos);\n let info = s.gcInfo;\n if ((info & COLOR_MASK) == COLOR_PURPLE && (info & REFCOUNT_MASK) > 0) {\n markGray(s);\n store(cur, s);\n cur += sizeof();\n } else {\n if ((info & COLOR_MASK) == COLOR_BLACK && !(info & REFCOUNT_MASK)) {\n freeBlock(ROOT, s);\n } else {\n s.gcInfo = info & ~BUFFERED_MASK;\n }\n }\n }\n CUR = cur;\n\n // scanRoots\n for (let pos = roots; pos < cur; pos += sizeof()) {\n scan(load(pos));\n }\n\n // collectRoots\n for (let pos = roots; pos < cur; pos += sizeof()) {\n let s = load(pos);\n s.gcInfo = s.gcInfo & ~BUFFERED_MASK;\n collectWhite(s);\n }\n CUR = roots;\n}\n\n/** Marks a block as gray (possible member of cycle) during the collection phase. */\nfunction markGray(s: Block): void {\n var info = s.gcInfo;\n if ((info & COLOR_MASK) != COLOR_GRAY) {\n s.gcInfo = (info & ~COLOR_MASK) | COLOR_GRAY;\n __visit_members(changetype(s) + BLOCK_OVERHEAD, VISIT_MARKGRAY);\n }\n}\n\n/** Scans a block during the collection phase, determining whether it is garbage or not. */\nfunction scan(s: Block): void {\n var info = s.gcInfo;\n if ((info & COLOR_MASK) == COLOR_GRAY) {\n if ((info & REFCOUNT_MASK) > 0) {\n scanBlack(s);\n } else {\n s.gcInfo = (info & ~COLOR_MASK) | COLOR_WHITE;\n __visit_members(changetype(s) + BLOCK_OVERHEAD, VISIT_SCAN);\n }\n }\n}\n\n/** Marks a block as black (in use) if it was found to be reachable during the collection phase. */\nfunction scanBlack(s: Block): void {\n s.gcInfo = (s.gcInfo & ~COLOR_MASK) | COLOR_BLACK;\n __visit_members(changetype(s) + BLOCK_OVERHEAD, VISIT_SCANBLACK);\n}\n\n/** Collects all white (member of a garbage cycle) nodes when completing the collection phase. */\nfunction collectWhite(s: Block): void {\n var info = s.gcInfo;\n if ((info & COLOR_MASK) == COLOR_WHITE && !(info & BUFFERED_MASK)) {\n s.gcInfo = (info & ~COLOR_MASK) | COLOR_BLACK;\n __visit_members(changetype(s) + BLOCK_OVERHEAD, VISIT_COLLECTWHITE);\n freeBlock(ROOT, s);\n }\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __retain(ref: usize): usize {\n if (ref > __heap_base) increment(changetype(ref - BLOCK_OVERHEAD));\n return ref;\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __release(ref: usize): void {\n if (ref > __heap_base) decrement(changetype(ref - BLOCK_OVERHEAD));\n}\n',"rt/rtrace":'import { BLOCK } from "./common";\n\nexport declare function onalloc(s: BLOCK): void;\nexport declare function onincrement(s: BLOCK): void;\nexport declare function ondecrement(s: BLOCK): void;\nexport declare function onfree(s: BLOCK): void;\n',"rt/stub":'import { AL_MASK, BLOCK, BLOCK_OVERHEAD, BLOCK_MAXSIZE } from "rt/common";\n\n// @ts-ignore: decorator\n@lazy\nvar startOffset: usize = (__heap_base + AL_MASK) & ~AL_MASK;\n\n// @ts-ignore: decorator\n@lazy\nvar offset: usize = startOffset;\n\n// @ts-ignore: decorator\n@unsafe @global\nexport function __alloc(size: usize, id: u32): usize {\n if (size > BLOCK_MAXSIZE) unreachable();\n var ptr = offset + BLOCK_OVERHEAD;\n var newPtr = (ptr + max(size, 1) + AL_MASK) & ~AL_MASK;\n var pagesBefore = memory.size();\n if (newPtr > pagesBefore << 16) {\n let pagesNeeded = ((newPtr - ptr + 0xffff) & ~0xffff) >>> 16;\n let pagesWanted = max(pagesBefore, pagesNeeded); // double memory\n if (memory.grow(pagesWanted) < 0) {\n if (memory.grow(pagesNeeded) < 0) unreachable(); // out of memory\n }\n }\n offset = newPtr;\n var block = changetype(ptr - BLOCK_OVERHEAD);\n block.rtId = id;\n block.rtSize = size;\n return ptr;\n}\n\n// @ts-ignore: decorator\n@unsafe @global\nexport function __realloc(ref: usize, size: usize): usize {\n var block = changetype(ref - BLOCK_OVERHEAD);\n var oldSize = block.rtSize;\n if (size > oldSize) {\n let newRef = __alloc(size, block.rtId);\n memory.copy(newRef, ref, oldSize);\n ref = newRef;\n } else {\n block.rtSize = size;\n }\n return ref;\n}\n\n// @ts-ignore: decorator\n@unsafe @global\nexport function __free(ref: usize): void {\n}\n\n// @ts-ignore: decorator\n@unsafe @global\nfunction __reset(): void { // special\n offset = startOffset;\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __retain(ref: usize): usize {\n return ref;\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __release(ref: usize): void {\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __visit(ref: usize, cookie: u32): void {\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __collect(): void {\n}\n',"rt/tlsf":"import { AL_BITS, AL_MASK, DEBUG, BLOCK, BLOCK_OVERHEAD, BLOCK_MAXSIZE } from \"rt/common\";\nimport { onfree, onalloc } from \"./rtrace\";\nimport { REFCOUNT_MASK } from \"./pure\";\n\n/////////////////////// The TLSF (Two-Level Segregate Fit) memory allocator ///////////////////////\n// see: http://www.gii.upv.es/tlsf/\n\n// - `ffs(x)` is equivalent to `ctz(x)` with x != 0\n// - `fls(x)` is equivalent to `sizeof(x) * 8 - clz(x) - 1`\n\n// ╒══════════════ Block size interpretation (32-bit) ═════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┼─┴─┴─┴─╫─┴─┴─┴─┤\n// │ | FL │ SB = SL + AL │ ◄─ usize\n// └───────────────────────────────────────────────┴───────╨───────┘\n// FL: first level, SL: second level, AL: alignment, SB: small block\n\n// @ts-ignore: decorator\n@inline const SL_BITS: u32 = 4;\n// @ts-ignore: decorator\n@inline const SL_SIZE: usize = 1 << SL_BITS;\n\n// @ts-ignore: decorator\n@inline const SB_BITS: usize = (SL_BITS + AL_BITS);\n// @ts-ignore: decorator\n@inline const SB_SIZE: usize = 1 << SB_BITS;\n\n// @ts-ignore: decorator\n@inline const FL_BITS: u32 = 31 - SB_BITS;\n\n// [00]: < 256B (SB) [12]: < 1M\n// [01]: < 512B [13]: < 2M\n// [02]: < 1K [14]: < 4M\n// [03]: < 2K [15]: < 8M\n// [04]: < 4K [16]: < 16M\n// [05]: < 8K [17]: < 32M\n// [06]: < 16K [18]: < 64M\n// [07]: < 32K [19]: < 128M\n// [08]: < 64K [20]: < 256M\n// [09]: < 128K [21]: < 512M\n// [10]: < 256K [22]: <= 1G - OVERHEAD\n// [11]: < 512K\n// VMs limit to 2GB total (currently), making one 1G block max (or three 512M etc.) due to block overhead\n\n// Tags stored in otherwise unused alignment bits\n\n// @ts-ignore: decorator\n@inline const FREE: usize = 1 << 0;\n// @ts-ignore: decorator\n@inline const LEFTFREE: usize = 1 << 1;\n// @ts-ignore: decorator\n@inline const TAGS_MASK: usize = FREE | LEFTFREE; // <= AL_MASK\n\n// ╒════════════════════ Block layout (32-bit) ════════════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┼─┼─┼─┤ overhead ┐\n// │ size │0│L│F│ ◄─┐ info\n// ├─────────────────────────────────────────────────────────┴─┴─┴─┤ │\n// │ │ │\n// │ ... additional runtime overhead ... │ │\n// │ │ │\n// ╞═══════════════════════════════════════════════════════════════╡ │ ┐ ┘\n// │ if free: ◄ prev │ ◄─┤ usize\n// ├───────────────────────────────────────────────────────────────┤ │\n// │ if free: next ► │ ◄─┤\n// ├───────────────────────────────────────────────────────────────┤ │\n// │ ... │ │ = 0\n// ├───────────────────────────────────────────────────────────────┤ │\n// │ if free: back ▲ │ ◄─┘\n// └───────────────────────────────────────────────────────────────┘ payload ┘ >= MIN SIZE\n// F: FREE, L: LEFTFREE\n@unmanaged export class Block extends BLOCK {\n\n /** Previous free block, if any. Only valid if free, otherwise part of payload. */\n prev: Block | null;\n /** Next free block, if any. Only valid if free, otherwise part of payload. */\n next: Block | null;\n\n // If the block is free, there is a 'back'reference at its end pointing at its start.\n}\n\n// Block constants. A block must have a minimum size of three pointers so it can hold `prev`,\n// `next` and `back` if free.\n\n// @ts-ignore: decorator\n@inline const BLOCK_MINSIZE: usize = (3 * sizeof() + AL_MASK) & ~AL_MASK; // prev + next + back\n// @ts-ignore: decorator\n// @inline const BLOCK_MAXSIZE: usize = 1 << (FL_BITS + SB_BITS - 1); // exclusive, lives in common.ts\n\n/** Gets the left block of a block. Only valid if the left block is free. */\n// @ts-ignore: decorator\n@inline function GETFREELEFT(block: Block): Block {\n return load(changetype(block) - sizeof());\n}\n\n/** Gets the right block of of a block by advancing to the right by its size. */\n// @ts-ignore: decorator\n@inline function GETRIGHT(block: Block): Block {\n return changetype(changetype(block) + BLOCK_OVERHEAD + (block.mmInfo & ~TAGS_MASK));\n}\n\n// ╒═════════════════════ Root layout (32-bit) ════════════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤ ┐\n// │ 0 | flMap S│ ◄────┐\n// ╞═══════════════════════════════════════════════════════════════╡ │\n// │ slMap[0] S │ ◄─┐ │\n// ├───────────────────────────────────────────────────────────────┤ │ │\n// │ slMap[1] │ ◄─┤ │\n// ├───────────────────────────────────────────────────────────────┤ u32 │\n// │ slMap[22] │ ◄─┘ │\n// ╞═══════════════════════════════════════════════════════════════╡ usize\n// │ head[0] │ ◄────┤\n// ├───────────────────────────────────────────────────────────────┤ │\n// │ ... │ ◄────┤\n// ├───────────────────────────────────────────────────────────────┤ │\n// │ head[367] │ ◄────┤\n// ╞═══════════════════════════════════════════════════════════════╡ │\n// │ tail │ ◄────┘\n// └───────────────────────────────────────────────────────────────┘ SIZE ┘\n// S: Small blocks map\n@unmanaged class Root {\n /** First level bitmap. */\n flMap: usize;\n}\n\n// Root constants. Where stuff is stored inside of the root structure.\n\n// @ts-ignore: decorator\n@inline const SL_START = sizeof();\n// @ts-ignore: decorator\n@inline const SL_END = SL_START + (FL_BITS << alignof());\n// @ts-ignore: decorator\n@inline const HL_START = (SL_END + AL_MASK) & ~AL_MASK;\n// @ts-ignore: decorator\n@inline const HL_END = HL_START + FL_BITS * SL_SIZE * sizeof();\n// @ts-ignore: decorator\n@inline const ROOT_SIZE = HL_END + sizeof();\n\n// @ts-ignore: decorator\n@lazy export var ROOT: Root;\n\n/** Gets the second level map of the specified first level. */\n// @ts-ignore: decorator\n@inline function GETSL(root: Root, fl: usize): u32 {\n return load(\n changetype(root) + (fl << alignof()),\n SL_START\n );\n}\n\n/** Sets the second level map of the specified first level. */\n// @ts-ignore: decorator\n@inline function SETSL(root: Root, fl: usize, slMap: u32): void {\n store(\n changetype(root) + (fl << alignof()),\n slMap,\n SL_START\n );\n}\n\n/** Gets the head of the free list for the specified combination of first and second level. */\n// @ts-ignore: decorator\n@inline function GETHEAD(root: Root, fl: usize, sl: u32): Block | null {\n return load(\n changetype(root) + (((fl << SL_BITS) + sl) << alignof()),\n HL_START\n );\n}\n\n/** Sets the head of the free list for the specified combination of first and second level. */\n// @ts-ignore: decorator\n@inline function SETHEAD(root: Root, fl: usize, sl: u32, head: Block | null): void {\n store(\n changetype(root) + (((fl << SL_BITS) + sl) << alignof()),\n head,\n HL_START\n );\n}\n\n/** Gets the tail block.. */\n// @ts-ignore: decorator\n@inline function GETTAIL(root: Root): Block {\n return load(\n changetype(root),\n HL_END\n );\n}\n\n/** Sets the tail block. */\n// @ts-ignore: decorator\n@inline function SETTAIL(root: Root, tail: Block): void {\n store(\n changetype(root),\n tail,\n HL_END\n );\n}\n\n/** Inserts a previously used block back into the free list. */\nfunction insertBlock(root: Root, block: Block): void {\n if (DEBUG) assert(block); // cannot be null\n var blockInfo = block.mmInfo;\n if (DEBUG) assert(blockInfo & FREE); // must be free\n\n var right = GETRIGHT(block);\n var rightInfo = right.mmInfo;\n\n // merge with right block if also free\n if (rightInfo & FREE) {\n let newSize = (blockInfo & ~TAGS_MASK) + BLOCK_OVERHEAD + (rightInfo & ~TAGS_MASK);\n if (newSize < BLOCK_MAXSIZE) {\n removeBlock(root, right);\n block.mmInfo = blockInfo = (blockInfo & TAGS_MASK) | newSize;\n right = GETRIGHT(block);\n rightInfo = right.mmInfo;\n // 'back' is set below\n }\n }\n\n // merge with left block if also free\n if (blockInfo & LEFTFREE) {\n let left = GETFREELEFT(block);\n let leftInfo = left.mmInfo;\n if (DEBUG) assert(leftInfo & FREE); // must be free according to right tags\n let newSize = (leftInfo & ~TAGS_MASK) + BLOCK_OVERHEAD + (blockInfo & ~TAGS_MASK);\n if (newSize < BLOCK_MAXSIZE) {\n removeBlock(root, left);\n left.mmInfo = blockInfo = (leftInfo & TAGS_MASK) | newSize;\n block = left;\n // 'back' is set below\n }\n }\n\n right.mmInfo = rightInfo | LEFTFREE;\n // right is no longer used now, hence rightInfo is not synced\n\n // we now know the size of the block\n var size = blockInfo & ~TAGS_MASK;\n if (DEBUG) assert(size >= BLOCK_MINSIZE && size < BLOCK_MAXSIZE); // must be a valid size\n if (DEBUG) assert(changetype(block) + BLOCK_OVERHEAD + size == changetype(right)); // must match\n\n // set 'back' to itself at the end of block\n store(changetype(right) - sizeof(), block);\n\n // mapping_insert\n var fl: usize, sl: u32;\n if (size < SB_SIZE) {\n fl = 0;\n sl = (size >> AL_BITS);\n } else {\n const inv: usize = sizeof() * 8 - 1;\n fl = inv - clz(size);\n sl = ((size >> (fl - SL_BITS)) ^ (1 << SL_BITS));\n fl -= SB_BITS - 1;\n }\n if (DEBUG) assert(fl < FL_BITS && sl < SL_SIZE); // fl/sl out of range\n\n // perform insertion\n var head = GETHEAD(root, fl, sl);\n block.prev = null;\n block.next = head;\n if (head) head.prev = block;\n SETHEAD(root, fl, sl, block);\n\n // update first and second level maps\n root.flMap |= (1 << fl);\n SETSL(root, fl, GETSL(root, fl) | (1 << sl));\n}\n\n/** Removes a free block from internal lists. */\nfunction removeBlock(root: Root, block: Block): void {\n var blockInfo = block.mmInfo;\n if (DEBUG) assert(blockInfo & FREE); // must be free\n var size = blockInfo & ~TAGS_MASK;\n if (DEBUG) assert(size >= BLOCK_MINSIZE && size < BLOCK_MAXSIZE); // must be valid\n\n // mapping_insert\n var fl: usize, sl: u32;\n if (size < SB_SIZE) {\n fl = 0;\n sl = (size >> AL_BITS);\n } else {\n const inv: usize = sizeof() * 8 - 1;\n fl = inv - clz(size);\n sl = ((size >> (fl - SL_BITS)) ^ (1 << SL_BITS));\n fl -= SB_BITS - 1;\n }\n if (DEBUG) assert(fl < FL_BITS && sl < SL_SIZE); // fl/sl out of range\n\n // link previous and next free block\n var prev = block.prev;\n var next = block.next;\n if (prev) prev.next = next;\n if (next) next.prev = prev;\n\n // update head if we are removing it\n if (block == GETHEAD(root, fl, sl)) {\n SETHEAD(root, fl, sl, next);\n\n // clear second level map if head is empty now\n if (!next) {\n let slMap = GETSL(root, fl);\n SETSL(root, fl, slMap &= ~(1 << sl));\n\n // clear first level map if second level is empty now\n if (!slMap) root.flMap &= ~(1 << fl);\n }\n }\n // note: does not alter left/back because it is likely that splitting\n // is performed afterwards, invalidating those changes. so, the caller\n // must perform those updates.\n}\n\n/** Searches for a free block of at least the specified size. */\nfunction searchBlock(root: Root, size: usize): Block | null {\n // size was already asserted by caller\n\n // mapping_search\n var fl: usize, sl: u32;\n if (size < SB_SIZE) {\n fl = 0;\n sl = (size >> AL_BITS);\n } else {\n const halfMaxSize = BLOCK_MAXSIZE >> 1; // don't round last fl\n const inv: usize = sizeof() * 8 - 1;\n const invRound = inv - SL_BITS;\n let requestSize = size < halfMaxSize\n ? size + (1 << (invRound - clz(size))) - 1\n : size;\n fl = inv - clz(requestSize);\n sl = ((requestSize >> (fl - SL_BITS)) ^ (1 << SL_BITS));\n fl -= SB_BITS - 1;\n }\n if (DEBUG) assert(fl < FL_BITS && sl < SL_SIZE); // fl/sl out of range\n\n // search second level\n var slMap = GETSL(root, fl) & (~0 << sl);\n var head: Block | null = null;\n if (!slMap) {\n // search next larger first level\n let flMap = root.flMap & (~0 << (fl + 1));\n if (!flMap) {\n head = null;\n } else {\n fl = ctz(flMap);\n slMap = GETSL(root, fl);\n if (DEBUG) assert(slMap); // can't be zero if fl points here\n head = GETHEAD(root, fl, ctz(slMap));\n }\n } else {\n head = GETHEAD(root, fl, ctz(slMap));\n }\n return head;\n}\n\n/** Prepares the specified block before (re-)use, possibly splitting it. */\nfunction prepareBlock(root: Root, block: Block, size: usize): void {\n // size was already asserted by caller\n\n var blockInfo = block.mmInfo;\n if (DEBUG) assert(!(size & AL_MASK)); // size must be aligned so the new block is\n\n // split if the block can hold another MINSIZE block incl. overhead\n var remaining = (blockInfo & ~TAGS_MASK) - size;\n if (remaining >= BLOCK_OVERHEAD + BLOCK_MINSIZE) {\n block.mmInfo = size | (blockInfo & LEFTFREE); // also discards FREE\n\n let spare = changetype(changetype(block) + BLOCK_OVERHEAD + size);\n spare.mmInfo = (remaining - BLOCK_OVERHEAD) | FREE; // not LEFTFREE\n insertBlock(root, spare); // also sets 'back'\n\n // otherwise tag block as no longer FREE and right as no longer LEFTFREE\n } else {\n block.mmInfo = blockInfo & ~FREE;\n GETRIGHT(block).mmInfo &= ~LEFTFREE;\n }\n}\n\n/** Adds more memory to the pool. */\nfunction addMemory(root: Root, start: usize, end: usize): bool {\n if (DEBUG) {\n assert(\n start <= end && // must be valid\n !(start & AL_MASK) && // must be aligned\n !(end & AL_MASK) // must be aligned\n );\n }\n\n var tail = GETTAIL(root);\n var tailInfo: usize = 0;\n if (tail) { // more memory\n if (DEBUG) assert(start >= changetype(tail) + BLOCK_OVERHEAD);\n\n // merge with current tail if adjacent\n if (start - BLOCK_OVERHEAD == changetype(tail)) {\n start -= BLOCK_OVERHEAD;\n tailInfo = tail.mmInfo;\n } else {\n // We don't do this, but a user might `memory.grow` manually\n // leading to non-adjacent pages managed by TLSF.\n }\n\n } else if (DEBUG) { // first memory\n assert(start >= changetype(root) + ROOT_SIZE); // starts after root\n }\n\n // check if size is large enough for a free block and the tail block\n var size = end - start;\n if (size < BLOCK_OVERHEAD + BLOCK_MINSIZE + BLOCK_OVERHEAD) {\n return false;\n }\n\n // left size is total minus its own and the zero-length tail's header\n var leftSize = size - 2 * BLOCK_OVERHEAD;\n var left = changetype(start);\n left.mmInfo = leftSize | FREE | (tailInfo & LEFTFREE);\n left.prev = null;\n left.next = null;\n\n // tail is a zero-length used block\n tail = changetype(start + size - BLOCK_OVERHEAD);\n tail.mmInfo = 0 | LEFTFREE;\n SETTAIL(root, tail);\n\n insertBlock(root, left); // also merges with free left before tail / sets 'back'\n\n return true;\n}\n\n/** Grows memory to fit at least another block of the specified size. */\nfunction growMemory(root: Root, size: usize): void {\n var pagesBefore = memory.size();\n var pagesNeeded = (((size + 0xffff) & ~0xffff) >>> 16);\n var pagesWanted = max(pagesBefore, pagesNeeded); // double memory\n if (memory.grow(pagesWanted) < 0) {\n if (memory.grow(pagesNeeded) < 0) unreachable();\n }\n var pagesAfter = memory.size();\n addMemory(root, pagesBefore << 16, pagesAfter << 16);\n}\n\n/** Prepares and checks an allocation size. */\nfunction prepareSize(size: usize): usize {\n if (size >= BLOCK_MAXSIZE) throw new Error(\"allocation too large\");\n return max((size + AL_MASK) & ~AL_MASK, BLOCK_MINSIZE); // align and ensure min size\n}\n\n/** Initilizes the root structure. */\nexport function initializeRoot(): void {\n var rootOffset = (__heap_base + AL_MASK) & ~AL_MASK;\n var pagesBefore = memory.size();\n var pagesNeeded = ((((rootOffset + ROOT_SIZE) + 0xffff) & ~0xffff) >>> 16);\n if (pagesNeeded > pagesBefore && memory.grow(pagesNeeded - pagesBefore) < 0) unreachable();\n var root = changetype(rootOffset);\n root.flMap = 0;\n SETTAIL(root, changetype(0));\n for (let fl: usize = 0; fl < FL_BITS; ++fl) {\n SETSL(root, fl, 0);\n for (let sl: u32 = 0; sl < SL_SIZE; ++sl) {\n SETHEAD(root, fl, sl, null);\n }\n }\n addMemory(root, (rootOffset + ROOT_SIZE + AL_MASK) & ~AL_MASK, memory.size() << 16);\n ROOT = root;\n}\n\n/** Allocates a block of the specified size. */\nexport function allocateBlock(root: Root, size: usize): Block {\n var payloadSize = prepareSize(size);\n var block = searchBlock(root, payloadSize);\n if (!block) {\n growMemory(root, payloadSize);\n block = searchBlock(root, payloadSize);\n if (DEBUG) assert(block); // must be found now\n }\n if (DEBUG) assert((block.mmInfo & ~TAGS_MASK) >= payloadSize); // must fit\n block.gcInfo = 0; // RC=0\n // block.rtId = 0; // set by the caller (__alloc)\n block.rtSize = size;\n removeBlock(root, block);\n prepareBlock(root, block, payloadSize);\n if (isDefined(ASC_RTRACE)) onalloc(block);\n return block;\n}\n\n/** Reallocates a block to the specified size. */\nexport function reallocateBlock(root: Root, block: Block, size: usize): Block {\n var payloadSize = prepareSize(size);\n var blockInfo = block.mmInfo;\n if (DEBUG) {\n assert(\n !(blockInfo & FREE) && // must be used\n !(block.gcInfo & ~REFCOUNT_MASK) // not buffered or != BLACK\n );\n }\n\n // possibly split and update runtime size if it still fits\n if (payloadSize <= (blockInfo & ~TAGS_MASK)) {\n prepareBlock(root, block, payloadSize);\n block.rtSize = size;\n return block;\n }\n\n // merge with right free block if merger is large enough\n var right = GETRIGHT(block);\n var rightInfo = right.mmInfo;\n if (rightInfo & FREE) {\n let mergeSize = (blockInfo & ~TAGS_MASK) + BLOCK_OVERHEAD + (rightInfo & ~TAGS_MASK);\n if (mergeSize >= payloadSize) {\n removeBlock(root, right);\n // TODO: this can yield an intermediate block larger than BLOCK_MAXSIZE, which\n // is immediately split though. does this trigger any assertions / issues?\n block.mmInfo = (blockInfo & TAGS_MASK) | mergeSize;\n block.rtSize = size;\n prepareBlock(root, block, payloadSize);\n return block;\n }\n }\n\n // otherwise move the block\n var newBlock = allocateBlock(root, size);\n newBlock.rtId = block.rtId;\n memory.copy(changetype(newBlock) + BLOCK_OVERHEAD, changetype(block) + BLOCK_OVERHEAD, size);\n block.mmInfo = blockInfo | FREE;\n insertBlock(root, block);\n if (isDefined(ASC_RTRACE)) onfree(block);\n return newBlock;\n}\n\n/** Frees a block. */\nexport function freeBlock(root: Root, block: Block): void {\n var blockInfo = block.mmInfo;\n assert(!(blockInfo & FREE)); // must be used (user might call through to this)\n block.mmInfo = blockInfo | FREE;\n insertBlock(root, block);\n if (isDefined(ASC_RTRACE)) onfree(block);\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __alloc(size: usize, id: u32): usize {\n var root = ROOT;\n if (!root) {\n initializeRoot();\n root = ROOT;\n }\n var block = allocateBlock(root, size);\n block.rtId = id;\n return changetype(block) + BLOCK_OVERHEAD;\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __realloc(ref: usize, size: usize): usize {\n if (DEBUG) assert(ROOT); // must be initialized\n assert(ref != 0 && !(ref & AL_MASK)); // must exist and be aligned\n return changetype(reallocateBlock(ROOT, changetype(ref - BLOCK_OVERHEAD), size)) + BLOCK_OVERHEAD;\n}\n\n// @ts-ignore: decorator\n@global @unsafe\nexport function __free(ref: usize): void {\n if (DEBUG) assert(ROOT); // must be initialized\n assert(ref != 0 && !(ref & AL_MASK)); // must exist and be aligned\n freeBlock(ROOT, changetype(ref - BLOCK_OVERHEAD));\n}\n",set:'/// \n\nimport { HASH } from "./util/hash";\n\n// A deterministic hash set based on CloseTable from https://github.com/jorendorff/dht\n\n// @ts-ignore: decorator\n@inline\nconst INITIAL_CAPACITY = 4;\n\n// @ts-ignore: decorator\n@inline\nconst FILL_FACTOR: f64 = 8 / 3;\n\n// @ts-ignore: decorator\n@inline\nconst FREE_FACTOR: f64 = 3 / 4;\n\n/** Structure of a set entry. */\n@unmanaged class SetEntry {\n key: K;\n taggedNext: usize; // LSB=1 indicates EMPTY\n}\n\n/** Empty bit. */\n// @ts-ignore: decorator\n@inline\nconst EMPTY: usize = 1 << 0;\n\n/** Size of a bucket. */\n// @ts-ignore: decorator\n@inline\nconst BUCKET_SIZE = sizeof();\n\n/** Computes the alignment of an entry. */\n// @ts-ignore: decorator\n@inline\nfunction ENTRY_ALIGN(): usize {\n // can align to 4 instead of 8 if 32-bit and K is <= 32-bits\n const align = (sizeof() > sizeof() ? sizeof() : sizeof()) - 1;\n return align;\n}\n\n/** Computes the aligned size of an entry. */\n// @ts-ignore: decorator\n@inline\nfunction ENTRY_SIZE(): usize {\n const align = ENTRY_ALIGN();\n const size = (offsetof>() + align) & ~align;\n return size;\n}\n\nexport class Set {\n\n // buckets holding references to the respective first entry within\n private buckets: ArrayBuffer; // usize[bucketsMask + 1]\n private bucketsMask: u32;\n\n // entries in insertion order\n private entries: ArrayBuffer; // SetEntry[entriesCapacity]\n private entriesCapacity: i32;\n private entriesOffset: i32;\n private entriesCount: i32;\n\n get size(): i32 { return this.entriesCount; }\n\n constructor() { this.clear(); }\n\n clear(): void {\n const bucketsSize = INITIAL_CAPACITY * BUCKET_SIZE;\n this.buckets = new ArrayBuffer(bucketsSize);\n this.bucketsMask = INITIAL_CAPACITY - 1;\n const entriesSize = INITIAL_CAPACITY * ENTRY_SIZE();\n this.entries = new ArrayBuffer(entriesSize);\n this.entriesCapacity = INITIAL_CAPACITY;\n this.entriesOffset = 0;\n this.entriesCount = 0;\n }\n\n private find(key: T, hashCode: u32): SetEntry | null {\n var entry = load>( // unmanaged!\n changetype(this.buckets) + (hashCode & this.bucketsMask) * BUCKET_SIZE\n );\n while (entry) {\n if (!(entry.taggedNext & EMPTY) && entry.key == key) return entry;\n entry = changetype>(entry.taggedNext & ~EMPTY);\n }\n return null;\n }\n\n @operator("[]")\n has(key: T): bool {\n return this.find(key, HASH(key)) !== null;\n }\n\n add(key: T): void {\n var hashCode = HASH(key);\n var entry = this.find(key, hashCode); // unmanaged!\n if (!entry) {\n // check if rehashing is necessary\n if (this.entriesOffset == this.entriesCapacity) {\n this.rehash(\n this.entriesCount < (this.entriesCapacity * FREE_FACTOR)\n ? this.bucketsMask // just rehash if 1/4+ entries are empty\n : (this.bucketsMask << 1) | 1 // grow capacity to next 2^N\n );\n }\n // append new entry\n entry = changetype>(changetype(this.entries) + this.entriesOffset++ * ENTRY_SIZE());\n entry.key = isManaged()\n ? changetype(__retain(changetype(key)))\n : key;\n ++this.entriesCount;\n // link with previous entry in bucket\n let bucketPtrBase = changetype(this.buckets) + (hashCode & this.bucketsMask) * BUCKET_SIZE;\n entry.taggedNext = load(bucketPtrBase);\n store(bucketPtrBase, changetype(entry));\n }\n }\n\n @operator("[]=")\n private __set(key: T, value: bool): void {\n if (value) this.add(key);\n else this.delete(key);\n }\n\n delete(key: T): bool {\n var entry = this.find(key, HASH(key)); // unmanaged!\n if (!entry) return false;\n if (isManaged()) __release(changetype(entry.key)); // exact \'key\'\n entry.taggedNext |= EMPTY;\n --this.entriesCount;\n // check if rehashing is appropriate\n var halfBucketsMask = this.bucketsMask >> 1;\n if (\n halfBucketsMask + 1 >= max(INITIAL_CAPACITY, this.entriesCount) &&\n this.entriesCount < (this.entriesCapacity * FREE_FACTOR)\n ) this.rehash(halfBucketsMask);\n return true;\n }\n\n private rehash(newBucketsMask: u32): void {\n var newBucketsCapacity = (newBucketsMask + 1);\n var newBuckets = new ArrayBuffer(newBucketsCapacity * BUCKET_SIZE);\n var newEntriesCapacity = (newBucketsCapacity * FILL_FACTOR);\n var newEntries = new ArrayBuffer(newEntriesCapacity * ENTRY_SIZE());\n\n // copy old entries to new entries\n var oldPtr = changetype(this.entries);\n var oldEnd = oldPtr + this.entriesOffset * ENTRY_SIZE();\n var newPtr = changetype(newEntries);\n while (oldPtr != oldEnd) {\n let oldEntry = changetype>(oldPtr); // unmanaged!\n if (!(oldEntry.taggedNext & EMPTY)) {\n let newEntry = changetype>(newPtr); // unmanaged!\n newEntry.key = oldEntry.key;\n let newBucketIndex = HASH(oldEntry.key) & newBucketsMask;\n let newBucketPtrBase = changetype(newBuckets) + newBucketIndex * BUCKET_SIZE;\n newEntry.taggedNext = load(newBucketPtrBase);\n store(newBucketPtrBase, newPtr);\n newPtr += ENTRY_SIZE();\n }\n oldPtr += ENTRY_SIZE();\n }\n\n this.buckets = newBuckets;\n this.bucketsMask = newBucketsMask;\n this.entries = newEntries;\n this.entriesCapacity = newEntriesCapacity;\n this.entriesOffset = this.entriesCount;\n }\n\n values(): T[] {\n // FIXME: this is preliminary, needs iterators/closures\n var start = changetype(this.entries);\n var size = this.entriesOffset;\n var values = Array.create(size);\n for (let i = 0; i < size; ++i) {\n let entry = changetype>(start + i * ENTRY_SIZE());\n if (!(entry.taggedNext & EMPTY)) {\n values.push(entry.key);\n }\n }\n return values;\n }\n\n toString(): string {\n return "[object Set]";\n }\n\n // RT integration\n\n @unsafe private __visit_impl(cookie: u32): void {\n __visit(changetype(this.buckets), cookie);\n var entries = changetype(this.entries);\n if (isManaged()) {\n let cur = entries;\n let end = cur + this.entriesOffset * ENTRY_SIZE();\n while (cur < end) {\n let entry = changetype>(cur);\n if (!(entry.taggedNext & EMPTY)) {\n let val = changetype(entry.key);\n if (isNullable()) {\n if (val) __visit(val, cookie);\n } else __visit(val, cookie);\n }\n cur += ENTRY_SIZE();\n }\n }\n __visit(entries, cookie);\n }\n}\n',"shared/feature":"// This file is shared with the compiler and must remain portable\n\n/** Indicates specific features to activate. */\nexport const enum Feature {\n /** No additional features. */\n NONE = 0,\n /** Sign extension operations. */\n SIGN_EXTENSION = 1 << 0, // see: https://github.com/WebAssembly/sign-extension-ops\n /** Mutable global imports and exports. */\n MUTABLE_GLOBAL = 1 << 1, // see: https://github.com/WebAssembly/mutable-global\n /** Bulk memory operations. */\n BULK_MEMORY = 1 << 2, // see: https://github.com/WebAssembly/bulk-memory-operations\n /** SIMD types and operations. */\n SIMD = 1 << 3, // see: https://github.com/WebAssembly/simd\n /** Threading and atomic operations. */\n THREADS = 1 << 4 // see: https://github.com/WebAssembly/threads\n}\n","shared/target":"// This file is shared with the compiler and must remain portable\n\n/** Compilation target. */\nexport enum Target {\n /** WebAssembly with 32-bit pointers. */\n WASM32,\n /** WebAssembly with 64-bit pointers. Experimental and not supported by any runtime yet. */\n WASM64,\n /** Portable. */\n JS\n}\n","shared/typeinfo":"// This file is shared with the compiler and must remain portable\n\n// ╒═══════════════════ Typeinfo interpretation ═══════════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤ ◄─ __rtti_base\n// │ count │\n// ╞═══════════════════════════════════════════════════════════════╡ ┐\n// │ Typeinfo#flags [id=0] │ id < count\n// ├ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ┤\n// │ Typeinfo#base [id=0] │\n// ├───────────────────────────────────────────────────────────────┤\n// │ ... │\n\n/** Runtime type information data structure. */\n@unmanaged\nexport class Typeinfo {\n /** Flags describing the shape of this class type. */\n flags: TypeinfoFlags;\n /** Base class id or `0` if none. */\n base: u32;\n}\n\n/** Runtime type information flags. */\nexport const enum TypeinfoFlags {\n /** No specific flags. */\n NONE = 0,\n /** Type is an `ArrayBufferView`. */\n ARRAYBUFFERVIEW = 1 << 0,\n /** Type is an `Array`. */\n ARRAY = 1 << 1,\n /** Type is a `Set`. */\n SET = 1 << 2,\n /** Type is a `Map`. */\n MAP = 1 << 3,\n /** Type is inherently acyclic. */\n ACYCLIC = 1 << 4,\n /** Value alignment of 1 byte. */\n VALUE_ALIGN_0 = 1 << 5,\n /** Value alignment of 2 bytes. */\n VALUE_ALIGN_1 = 1 << 6,\n /** Value alignment of 4 bytes. */\n VALUE_ALIGN_2 = 1 << 7,\n /** Value alignment of 8 bytes. */\n VALUE_ALIGN_3 = 1 << 8,\n /** Value alignment of 16 bytes. */\n VALUE_ALIGN_4 = 1 << 9,\n /** Value is a signed type. */\n VALUE_SIGNED = 1 << 10,\n /** Value is a float type. */\n VALUE_FLOAT = 1 << 11,\n /** Value type is nullable. */\n VALUE_NULLABLE = 1 << 12,\n /** Value type is managed. */\n VALUE_MANAGED = 1 << 13,\n /** Key alignment of 1 byte. */\n KEY_ALIGN_0 = 1 << 14,\n /** Key alignment of 2 bytes. */\n KEY_ALIGN_1 = 1 << 15,\n /** Key alignment of 4 bytes. */\n KEY_ALIGN_2 = 1 << 16,\n /** Key alignment of 8 bytes. */\n KEY_ALIGN_3 = 1 << 17,\n /** Key alignment of 16 bytes. */\n KEY_ALIGN_4 = 1 << 18,\n /** Value is a signed type. */\n KEY_SIGNED = 1 << 19,\n /** Value is a float type. */\n KEY_FLOAT = 1 << 20,\n /** Key type is nullable. */\n KEY_NULLABLE = 1 << 21,\n /** Key type is managed. */\n KEY_MANAGED = 1 << 22\n}\n",string:'/// \n\nimport { BLOCK, BLOCK_OVERHEAD, BLOCK_MAXSIZE } from "./rt/common";\nimport { compareImpl, strtol, strtod, isWhiteSpaceOrLineTerminator } from "./util/string";\nimport { E_INVALIDLENGTH } from "./util/error";\nimport { ArrayBufferView } from "./arraybuffer";\nimport { idof } from "./builtins";\n\n@sealed export abstract class String {\n\n @lazy static readonly MAX_LENGTH: i32 = BLOCK_MAXSIZE >>> alignof();\n\n static fromCharCode(unit: i32, surr: i32 = -1): string {\n var out: usize;\n if (~surr) {\n out = __alloc(4, idof());\n store(out, unit);\n store(out, surr, 2);\n } else {\n out = __alloc(2, idof());\n store(out, unit);\n }\n return changetype(out); // retains\n }\n\n static fromCodePoint(code: i32): string {\n assert(code <= 0x10FFFF);\n var sur = code > 0xFFFF;\n var out = __alloc((i32(sur) + 1) << 1, idof());\n if (!sur) {\n store(out, code);\n } else {\n code -= 0x10000;\n let hi: u32 = (code >>> 10) + 0xD800;\n let lo: u32 = (code & 0x3FF) + 0xDC00;\n store(out, (hi << 16) | lo);\n }\n return changetype(out); // retains\n }\n\n get length(): i32 {\n return changetype(changetype(this) - BLOCK_OVERHEAD).rtSize >> 1;\n }\n\n @operator("[]") charAt(pos: i32): String {\n if (pos >= this.length) return changetype("");\n var out = __alloc(2, idof());\n store(out, load(changetype(this) + (pos << 1)));\n return changetype(out); // retains\n }\n\n charCodeAt(pos: i32): i32 {\n if (pos >= this.length) return -1; // (NaN)\n return load(changetype(this) + (pos << 1));\n }\n\n codePointAt(pos: i32): i32 {\n if (pos >= this.length) return -1; // (undefined)\n var first = load(changetype(this) + (pos << 1));\n if (first < 0xD800 || first > 0xDBFF || pos + 1 == this.length) return first;\n var second = load(changetype(this) + ((pos + 1) << 1));\n if (second < 0xDC00 || second > 0xDFFF) return first;\n return ((first - 0xD800) << 10) + (second - 0xDC00) + 0x10000;\n }\n\n @operator("+") private static __concat(left: String, right: String): String {\n return select(left, changetype("null"), left !== null).concat(right);\n }\n\n concat(other: String): String {\n if (other === null) other = changetype("null");\n var thisSize: isize = this.length << 1;\n var otherSize: isize = other.length << 1;\n var outSize: usize = thisSize + otherSize;\n if (outSize == 0) return changetype("");\n var out = changetype(__alloc(outSize, idof())); // retains\n memory.copy(changetype(out), changetype(this), thisSize);\n memory.copy(changetype(out) + thisSize, changetype(other), otherSize);\n return out;\n }\n\n endsWith(search: String, end: i32 = String.MAX_LENGTH): bool {\n if (search === null) return false;\n end = min(max(end, 0), this.length);\n var searchLength = search.length;\n var searchStart = end - searchLength;\n if (searchStart < 0) return false;\n // @ts-ignore: string <-> String\n return !compareImpl(this, searchStart, search, 0, searchLength);\n }\n\n @operator("==") private static __eq(left: String | null, right: String | null): bool {\n if (left === right) return true;\n if (left === null || right === null) return false;\n var leftLength = left.length;\n if (leftLength != right.length) return false;\n // @ts-ignore: string <-> String\n return !compareImpl(left, 0, right, 0, leftLength);\n }\n\n @operator.prefix("!")\n private static __not(str: String | null): bool {\n return str === null || !str.length;\n }\n\n @operator("!=")\n private static __ne(left: String | null, right: String | null): bool {\n return !this.__eq(left, right);\n }\n\n @operator(">") private static __gt(left: String | null, right: String | null): bool {\n if (left === right || left === null || right === null) return false;\n var leftLength = left.length;\n var rightLength = right.length;\n if (!leftLength) return false;\n if (!rightLength) return true;\n // @ts-ignore: string <-> String\n return compareImpl(left, 0, right, 0, min(leftLength, rightLength)) > 0;\n }\n\n @operator(">=") private static __gte(left: String, right: String): bool {\n return !this.__lt(left, right);\n }\n\n @operator("<") private static __lt(left: String, right: String): bool {\n if (left === right || left === null || right === null) return false;\n var leftLength = left.length;\n var rightLength = right.length;\n if (!rightLength) return false;\n if (!leftLength) return true;\n // @ts-ignore: string <-> String\n return compareImpl(left, 0, right, 0, min(leftLength, rightLength)) < 0;\n }\n\n @operator("<=") private static __lte(left: String, right: String): bool {\n return !this.__gt(left, right);\n }\n\n includes(search: String, start: i32 = 0): bool {\n return this.indexOf(search, start) != -1;\n }\n\n indexOf(search: String, start: i32 = 0): i32 {\n var searchLen = search.length;\n if (!searchLen) return 0;\n var len = this.length;\n if (!len) return -1;\n var searchStart = min(max(start, 0), len);\n for (len -= searchLen; searchStart <= len; ++searchStart) {\n // @ts-ignore: string <-> String\n if (!compareImpl(this, searchStart, search, 0, searchLen)) return searchStart;\n }\n return -1;\n }\n\n lastIndexOf(search: String, start: i32 = i32.MAX_VALUE): i32 {\n var searchLen = search.length;\n if (!searchLen) return this.length;\n var len = this.length;\n if (!len) return -1;\n var searchStart = min(max(start, 0), len - searchLen);\n for (; searchStart >= 0; --searchStart) {\n // @ts-ignore: string <-> String\n if (!compareImpl(this, searchStart, search, 0, searchLen)) return searchStart;\n }\n return -1;\n }\n\n startsWith(search: String, start: i32 = 0): bool {\n if (search === null) search = changetype("null");\n var len = this.length;\n var searchStart = min(max(start, 0), len);\n var searchLength = search.length;\n if (searchLength + searchStart > len) return false;\n // @ts-ignore: string <-> String\n return !compareImpl(this, searchStart, search, 0, searchLength);\n }\n\n substr(start: i32, length: i32 = i32.MAX_VALUE): String { // legacy\n var intStart: isize = start;\n var end: isize = length;\n var size: isize = this.length;\n if (intStart < 0) intStart = max(size + intStart, 0);\n var resultLength = min(max(end, 0), size - intStart);\n if (resultLength <= 0) return changetype("");\n var out = __alloc(resultLength << 1, idof());\n memory.copy(out, changetype(this) + intStart, resultLength);\n return changetype(out); // retains\n }\n\n substring(start: i32, end: i32 = i32.MAX_VALUE): String {\n var len: isize = this.length;\n var finalStart = min(max(start, 0), len);\n var finalEnd = min(max(end, 0), len);\n var fromPos = min(finalStart, finalEnd) << 1;\n var toPos = max(finalStart, finalEnd) << 1;\n len = toPos - fromPos;\n if (!len) return changetype("");\n if (!fromPos && toPos == this.length << 1) return this;\n var out = __alloc(len, idof());\n memory.copy(out, changetype(this) + fromPos, len);\n return changetype(out); // retains\n }\n\n trim(): String {\n var length = this.length;\n var size: usize = length << 1;\n while (\n size &&\n isWhiteSpaceOrLineTerminator(\n load(changetype(this) + size)\n )\n ) {\n size -= 2;\n }\n var offset: usize = 0;\n while (\n offset < size &&\n isWhiteSpaceOrLineTerminator(\n load(changetype(this) + offset)\n )\n ) {\n offset += 2; size -= 2;\n }\n if (!size) return changetype("");\n if (!start && size == length << 1) return this;\n var out = __alloc(size, idof());\n memory.copy(out, changetype(this) + offset, size);\n return changetype(out); // retains\n }\n\n @inline\n trimLeft(): String {\n return this.trimStart();\n }\n\n @inline\n trimRight(): String {\n return this.trimEnd();\n }\n\n trimStart(): String {\n var size = this.length << 1;\n var offset: usize = 0;\n while (\n offset < size &&\n isWhiteSpaceOrLineTerminator(\n load(changetype(this) + offset)\n )\n ) {\n offset += 2;\n }\n if (!offset) return this;\n size -= offset;\n if (!size) return changetype("");\n var out = __alloc(size, idof());\n memory.copy(out, changetype(this) + offset, size);\n return changetype(out); // retains\n }\n\n trimEnd(): String {\n var originalSize = this.length << 1;\n var size = originalSize;\n while (\n size &&\n isWhiteSpaceOrLineTerminator(\n load(changetype(this) + size)\n )\n ) {\n size -= 2;\n }\n if (!size) return changetype("");\n if (size == originalSize) return this;\n var out = __alloc(size, idof());\n memory.copy(out, changetype(this), size);\n return changetype(out); // retains\n }\n\n padStart(length: i32, pad: string = " "): String {\n var thisSize = this.length << 1;\n var targetSize = length << 1;\n var padSize = pad.length << 1;\n if (targetSize < thisSize || !padSize) return this;\n var prependSize = targetSize - thisSize;\n var out = __alloc(targetSize, idof());\n if (prependSize > padSize) {\n let repeatCount = (prependSize - 2) / padSize;\n let restBase = repeatCount * padSize;\n let restSize = prependSize - restBase;\n memory.repeat(out, changetype(pad), padSize, repeatCount);\n memory.copy(out + restBase, changetype(pad), restSize);\n } else {\n memory.copy(out, changetype(pad), prependSize);\n }\n memory.copy(out + prependSize, changetype(this), thisSize);\n return changetype(out); // retains\n }\n\n padEnd(length: i32, pad: string = " "): String {\n var thisSize = this.length << 1;\n var targetSize = length << 1;\n var padSize = pad.length << 1;\n if (targetSize < thisSize || !padSize) return this;\n var appendSize = targetSize - thisSize;\n var out = __alloc(targetSize, idof());\n memory.copy(out, changetype(this), thisSize);\n if (appendSize > padSize) {\n let repeatCount = (appendSize - 2) / padSize;\n let restBase = repeatCount * padSize;\n let restSize = appendSize - restBase;\n memory.repeat(out + thisSize, changetype(pad), padSize, repeatCount);\n memory.copy(out + thisSize + restBase, changetype(pad), restSize);\n } else {\n memory.copy(out + thisSize, changetype(pad), appendSize);\n }\n return changetype(out); // retains\n }\n\n repeat(count: i32 = 0): String {\n var length = this.length;\n\n // Most browsers can\'t handle strings 1 << 28 chars or longer\n if (count < 0 || length * count > (1 << 28)) {\n throw new RangeError(E_INVALIDLENGTH);\n }\n\n if (count == 0 || !length) return changetype("");\n if (count == 1) return this;\n var out = __alloc((length * count) << 1, idof());\n memory.repeat(out, changetype(this), length << 1, count);\n return changetype(out); // retains\n }\n\n replace(search: String, replacement: String): String {\n var len: usize = this.length;\n var slen: usize = search.length;\n if (len <= slen) {\n return len < slen ? this : select(replacement, this, search == this);\n }\n var index: isize = this.indexOf(search);\n if (~index) {\n let rlen: usize = replacement.length;\n len -= slen;\n let olen = len + rlen;\n if (olen) {\n let out = __alloc(olen << 1, idof());\n memory.copy(out, changetype(this), index << 1);\n memory.copy(\n out + (index << 1),\n changetype(replacement),\n rlen << 1\n );\n memory.copy(\n out + ((index + rlen) << 1),\n changetype(this) + ((index + slen) << 1),\n (len - index) << 1\n );\n return changetype(out);\n }\n }\n return this;\n }\n\n replaceAll(search: String, replacement: String): String {\n var len: usize = this.length;\n var slen: usize = search.length;\n if (len <= slen) {\n return len < slen ? this : select(replacement, this, search == this);\n }\n var rlen: usize = replacement.length;\n if (!slen) {\n if (!rlen) return this;\n // Special case: \'abc\'.replaceAll(\'\', \'-\') -> \'-a-b-c-\'\n let out = __alloc((len + (len + 1) * rlen) << 1, idof());\n memory.copy(out, changetype(replacement), rlen << 1);\n let offset = rlen;\n for (let i: usize = 0; i < len; ++i) {\n store(\n changetype(out) + (offset++ << 1),\n load(changetype(this) + (i << 1))\n );\n memory.copy(\n out + (offset << 1),\n changetype(replacement),\n rlen << 1\n );\n offset += rlen;\n }\n return changetype(out);\n }\n var prev: isize = 0, next: isize = 0;\n if (slen == rlen) {\n // Fast path when search and replacement have same length\n let size = len << 1;\n let out = __alloc(size, idof());\n memory.copy(out, changetype(this), size);\n while (~(next = this.indexOf(search, prev))) {\n memory.copy(out + (next << 1), changetype(replacement), rlen << 1);\n prev = next + slen;\n }\n return changetype(out);\n }\n var out: usize = 0, offset: usize = 0, resLen = len;\n while (~(next = this.indexOf(search, prev))) {\n if (!out) out = __alloc(len << 1, idof());\n if (offset > resLen) {\n let newLength = resLen << 1;\n out = __realloc(out, newLength << 1);\n resLen = newLength;\n }\n let chunk = next - prev;\n memory.copy(\n out + (offset << 1),\n changetype(this) + (prev << 1),\n chunk << 1\n );\n offset += chunk;\n memory.copy(\n out + (offset << 1),\n changetype(replacement),\n rlen << 1\n );\n offset += rlen;\n prev = next + slen;\n }\n if (offset) {\n if (offset > resLen) {\n let newLength = resLen << 1;\n out = __realloc(out, newLength << 1);\n resLen = newLength;\n }\n let rest = len - prev;\n if (rest) {\n memory.copy(\n out + (offset << 1),\n changetype(this) + (prev << 1),\n rest << 1\n );\n }\n rest += offset;\n if (resLen > rest) out = __realloc(out, rest << 1);\n return changetype(out);\n }\n return this;\n }\n\n slice(start: i32, end: i32 = i32.MAX_VALUE): String {\n var len = this.length;\n start = start < 0 ? max(start + len, 0) : min(start, len);\n end = end < 0 ? max(end + len, 0) : min(end, len);\n len = end - start;\n if (len <= 0) return changetype("");\n var out = __alloc(len << 1, idof());\n memory.copy(out, changetype(this) + (start << 1), len << 1);\n return changetype(out); // retains\n }\n\n split(separator: String | null = null, limit: i32 = i32.MAX_VALUE): String[] {\n if (!limit) return changetype>(__allocArray(0, alignof(), idof>())); // retains\n if (separator === null) return [this];\n var length: isize = this.length;\n var sepLen: isize = separator.length;\n if (limit < 0) limit = i32.MAX_VALUE;\n if (!sepLen) {\n if (!length) return changetype>(__allocArray(0, alignof(), idof>())); // retains\n // split by chars\n length = min(length, limit);\n let result = __allocArray(length, alignof(), idof>());\n let resultStart = changetype(result).dataStart;\n for (let i: isize = 0; i < length; ++i) {\n let charStr = __alloc(2, idof());\n store(charStr, load(changetype(this) + (i << 1)));\n store(resultStart + (i << alignof()), charStr); // result[i] = charStr\n if (isManaged()) __retain(charStr);\n }\n return changetype>(result); // retains\n } else if (!length) {\n let result = __allocArray(1, alignof(), idof>());\n store(changetype(result).dataStart, changetype("")); // static ""\n return changetype>(result); // retains\n }\n var result = changetype>(__allocArray(0, alignof(), idof>())); // retains\n var end = 0, start = 0, i = 0;\n while (~(end = this.indexOf(separator, start))) {\n let len = end - start;\n if (len > 0) {\n let out = __alloc(len << 1, idof());\n memory.copy(out, changetype(this) + (start << 1), len << 1);\n result.push(changetype(out));\n } else {\n result.push(changetype(""));\n }\n if (++i == limit) return changetype>(result); // retains\n start = end + sepLen;\n }\n if (!start) { // also means: loop above didn\'t do anything\n result.push(this);\n return changetype>(result); // retains\n }\n var len = length - start;\n if (len > 0) {\n let out = __alloc(len << 1, idof());\n memory.copy(out, changetype(this) + (start << 1), len << 1);\n result.push(changetype(out)); // retains\n } else {\n result.push(changetype("")); // static ""\n }\n return changetype>(result); // retains\n // releases result\n }\n\n toString(): String {\n return this;\n }\n\n get lengthUTF8(): i32 {\n var len = 1; // null terminated\n var pos: usize = 0;\n var end = this.length;\n while (pos < end) {\n let c = load(changetype(this) + (pos << 1));\n if (c < 128) {\n len += 1; ++pos;\n } else if (c < 2048) {\n len += 2; ++pos;\n } else {\n if (\n (c & 0xFC00) == 0xD800 && pos + 1 < end &&\n (load(changetype(this) + ((pos + 1) << 1)) & 0xFC00) == 0xDC00\n ) {\n len += 4; pos += 2;\n } else {\n len += 3; ++pos;\n }\n }\n }\n return len;\n }\n\n static fromUTF8(ptr: usize, len: usize): String {\n if (len < 1) return changetype("");\n var ptrPos = 0;\n var buf = __alloc(len << 1, 0);\n var bufPos = 0;\n while (ptrPos < len) {\n let cp = load(ptr + ptrPos++);\n if (cp < 128) {\n store(buf + bufPos, cp);\n bufPos += 2;\n } else if (cp > 191 && cp < 224) {\n assert(ptrPos + 1 <= len);\n store(buf + bufPos, (cp & 31) << 6 | load(ptr + ptrPos++) & 63);\n bufPos += 2;\n } else if (cp > 239 && cp < 365) {\n assert(ptrPos + 3 <= len);\n cp = (\n (cp & 7) << 18 |\n (load(ptr + ptrPos++) & 63) << 12 |\n (load(ptr + ptrPos++) & 63) << 6 |\n load(ptr + ptrPos++) & 63\n ) - 0x10000;\n store(buf + bufPos, 0xD800 + (cp >> 10));\n bufPos += 2;\n store(buf + bufPos, 0xDC00 + (cp & 1023));\n bufPos += 2;\n } else {\n assert(ptrPos + 2 <= len);\n store(buf + bufPos,\n (cp & 15) << 12 |\n (load(ptr + ptrPos++) & 63) << 6 |\n load(ptr + ptrPos++) & 63\n );\n bufPos += 2;\n }\n }\n assert(ptrPos == len);\n var out = __alloc(bufPos, idof());\n memory.copy(out, buf, bufPos);\n __free(buf);\n return changetype(out); // retains\n }\n\n toUTF8(): usize {\n var buf = __alloc(this.lengthUTF8, 0);\n var pos: usize = 0;\n var end = this.length;\n var off: usize = 0;\n while (pos < end) {\n let c1 = load(changetype(this) + (pos << 1));\n if (c1 < 128) {\n store(buf + off, c1);\n ++off; ++pos;\n } else if (c1 < 2048) {\n let ptr = buf + off;\n store(ptr, c1 >> 6 | 192);\n store(ptr, c1 & 63 | 128, 1);\n off += 2; ++pos;\n } else {\n let ptr = buf + off;\n if ((c1 & 0xFC00) == 0xD800 && pos + 1 < end) {\n let c2 = load(changetype(this) + ((pos + 1) << 1));\n if ((c2 & 0xFC00) == 0xDC00) {\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\n store(ptr, c1 >> 18 | 240);\n store(ptr, c1 >> 12 & 63 | 128, 1);\n store(ptr, c1 >> 6 & 63 | 128, 2);\n store(ptr, c1 & 63 | 128, 3);\n off += 4; pos += 2;\n continue;\n }\n }\n store(ptr, c1 >> 12 | 224);\n store(ptr, c1 >> 6 & 63 | 128, 1);\n store(ptr, c1 & 63 | 128, 2);\n off += 3; ++pos;\n }\n }\n store(buf + off, 0);\n return buf;\n }\n}\n\n// @ts-ignore: nolib\nexport type string = String;\n\nexport function parseInt(str: string, radix: i32 = 0): f64 {\n return strtol(str, radix);\n}\n\nexport function parseFloat(str: string): f64 {\n return strtod(str);\n}\n',symbol:'import { Map } from "./map";\n\n// @ts-ignore: decorator\n@lazy\nvar stringToId: Map;\n\n// @ts-ignore: decorator\n@lazy\nvar idToString: Map;\n\n// @ts-ignore: decorator\n@lazy\nvar nextId: usize = 12; // Symbol.unscopables + 1\n\n@unmanaged @sealed abstract class _Symbol {\n\n // TODO: all of the following default symbols are unused currently yet add to\n // binary size if #toString becomes compiled. Ultimately we\'ll most likely want\n // to remove the unsupported ones and only keep what\'s actually supported.\n\n // @ts-ignore: decorator\n @lazy\n static readonly hasInstance: symbol = changetype(1);\n\n // @ts-ignore: decorator\n @lazy\n static readonly isConcatSpreadable: symbol = changetype(2);\n\n // @ts-ignore: decorator\n @lazy\n static readonly isRegExp: symbol = changetype(3);\n\n // @ts-ignore: decorator\n @lazy\n static readonly iterator: symbol = changetype(3);\n\n // @ts-ignore: decorator\n @lazy\n static readonly match: symbol = changetype(4);\n\n // @ts-ignore: decorator\n @lazy\n static readonly replace: symbol = changetype(5);\n\n // @ts-ignore: decorator\n @lazy\n static readonly search: symbol = changetype(6);\n\n // @ts-ignore: decorator\n @lazy\n static readonly species: symbol = changetype(7);\n\n // @ts-ignore: decorator\n @lazy\n static readonly split: symbol = changetype(8);\n\n // @ts-ignore: decorator\n @lazy\n static readonly toPrimitive: symbol = changetype(9);\n\n // @ts-ignore: decorator\n @lazy\n static readonly toStringTag: symbol = changetype(10);\n\n // @ts-ignore: decorator\n @lazy\n static readonly unscopables: symbol = changetype(11);\n\n static for(key: string): symbol {\n if (!stringToId) { stringToId = new Map(); idToString = new Map(); }\n else if (stringToId.has(key)) return changetype(stringToId.get(key));\n var id = nextId++;\n if (!id) unreachable(); // out of ids\n stringToId.set(key, id);\n idToString.set(id, key);\n return changetype(id);\n }\n\n static keyFor(sym: symbol): string | null {\n return idToString !== null && idToString.has(changetype(sym))\n ? idToString.get(changetype(sym))\n : null;\n }\n\n toString(): string {\n var id = changetype(this);\n var str = "";\n switch (id) {\n case 1: { str = "hasInstance"; break; }\n case 2: { str = "isConcatSpreadable"; break; }\n case 3: { str = "isRegExp"; break; }\n case 4: { str = "match"; break; }\n case 5: { str = "replace"; break; }\n case 6: { str = "search"; break; }\n case 7: { str = "species"; break; }\n case 8: { str = "split"; break; }\n case 9: { str = "toPrimitive"; break; }\n case 10: { str = "toStringTag"; break; }\n case 11: { str = "unscopables"; break; }\n default: {\n if (idToString !== null && idToString.has(id)) str = idToString.get(id);\n break;\n }\n }\n return "Symbol(" + str + ")";\n }\n}\n\nexport function Symbol(description: string | null = null): symbol {\n var id = nextId++;\n if (!id) unreachable(); // out of ids\n return changetype(id);\n}\n\nexport type Symbol = _Symbol;\n\n// @ts-ignore: nolib\nexport type symbol = _Symbol;\n',table:'import { E_NOTIMPLEMENTED } from "./util/error";\n\nexport namespace table {\n\n export function copy(dst: u32, src: u32, n: u32): void {\n throw new Error(E_NOTIMPLEMENTED);\n }\n\n export function init(elementIndex: u32, srcOffset: u32, dstOffset: u32, n: u32): void {\n throw new Error(E_NOTIMPLEMENTED);\n }\n\n export function drop(elementIndex: u32): void {\n throw new Error(E_NOTIMPLEMENTED);\n }\n}\n',typedarray:'import { COMPARATOR, SORT as SORT_IMPL } from "./util/sort";\nimport { E_INDEXOUTOFRANGE } from "./util/error";\nimport { idof } from "./builtins";\nimport { ArrayBufferView } from "./arraybuffer";\n\nexport class Int8Array extends ArrayBufferView {\n [key: number]: i8;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength;\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): i8 {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + index);\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: native): void {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + index, value);\n }\n\n includes(searchElement: i8, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: i8, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: i8, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: i32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Int8Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: i8, b: i8) => i32 = COMPARATOR()): Int8Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Int8Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: i8, index: i32, array: Int8Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: i8, index: i32, array: Int8Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: i8, index: i32, self: Int8Array) => i8): Int8Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: i8, index: i32, self: Int8Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: i8, index: i32, self: Int8Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: i8, index: i32, self: Int8Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: i8, index: i32, self: Int8Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Uint8Array extends ArrayBufferView {\n [key: number]: u8;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength;\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): u8 {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + index);\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: native): void {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + index, value);\n }\n\n includes(searchElement: u8, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: u8, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: u8, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: u32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Uint8Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: u8, b: u8) => i32 = COMPARATOR()): Uint8Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Uint8Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: u8, index: i32, array: Uint8Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: u8, index: i32, array: Uint8Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: u8, index: i32, self: Uint8Array) => u8): Uint8Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: u8, index: i32, self: Uint8Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: u8, index: i32, self: Uint8Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: u8, index: i32, self: Uint8Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: u8, index: i32, self: Uint8Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Uint8ClampedArray extends ArrayBufferView {\n [key: number]: u8;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength;\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): u8 {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + index);\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: native): void {\n if (index >= this.dataLength) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + index, ~(value >> 31) & (((255 - value) >> 31) | value));\n }\n\n includes(searchElement: u8, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: u8, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: u8, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: u32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Uint8ClampedArray {\n return FILL(this, value, start, end);\n }\n\n sort(fn: (a: u8, b: u8) => i32 = COMPARATOR()): Uint8ClampedArray {\n return SORT(this, fn);\n }\n\n subarray(start: i32 = 0, end: i32 = 0x7fffffff): Uint8ClampedArray {\n return SUBARRAY(this, start, end);\n }\n\n reduce(\n fn: (accumulator: T, value: u8, index: i32, array: Uint8ClampedArray) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: u8, index: i32, array: Uint8ClampedArray) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: u8, index: i32, self: Uint8ClampedArray) => u8): Uint8ClampedArray {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: u8, index: i32, self: Uint8ClampedArray) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: u8, index: i32, self: Uint8ClampedArray) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: u8, index: i32, self: Uint8ClampedArray) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: u8, index: i32, self: Uint8ClampedArray) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Int16Array extends ArrayBufferView {\n [key: number]: i16;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): i16 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: native): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n includes(searchElement: i16, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: i16, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: i16, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: i32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Int16Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: i16, b: i16) => i32 = COMPARATOR()): Int16Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Int16Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: i16, index: i32, array: Int16Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: i16, index: i32, array: Int16Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: i16, index: i32, self: Int16Array) => i16): Int16Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: i16, index: i32, self: Int16Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: i16, index: i32, self: Int16Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: i16, index: i32, self: Int16Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: i16, index: i32, self: Int16Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Uint16Array extends ArrayBufferView {\n [key: number]: u16;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): u16 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: native): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n includes(searchElement: u16, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: u16, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: u16, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: u32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Uint16Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: u16, b: u16) => i32 = COMPARATOR()): Uint16Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Uint16Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: u16, index: i32, array: Uint16Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: u16, index: i32, array: Uint16Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: u16, index: i32, self: Uint16Array) => u16): Uint16Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: u16, index: i32, self: Uint16Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: u16, index: i32, self: Uint16Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: u16, index: i32, self: Uint16Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: u16, index: i32, self: Uint16Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Int32Array extends ArrayBufferView {\n [key: number]: i32;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): i32 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: i32): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n includes(searchElement: i32, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: i32, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: i32, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: i32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Int32Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: i32, b: i32) => i32 = COMPARATOR()): Int32Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Int32Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: i32, index: i32, array: Int32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: i32, index: i32, array: Int32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: i32, index: i32, self: Int32Array) => i32): Int32Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: i32, index: i32, self: Int32Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: i32, index: i32, self: Int32Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: i32, index: i32, self: Int32Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: i32, index: i32, self: Int32Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Uint32Array extends ArrayBufferView {\n [key: number]: u32;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): u32 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: u32): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n includes(searchElement: u32, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: u32, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: u32, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: u32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Uint32Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: u32, b: u32) => i32 = COMPARATOR()): Uint32Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Uint32Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: u32, index: i32, array: Uint32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: u32, index: i32, array: Uint32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: u32, index: i32, self: Uint32Array) => u32): Uint32Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: u32, index: i32, self: Uint32Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: u32, index: i32, self: Uint32Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: u32, index: i32, self: Uint32Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: u32, index: i32, self: Uint32Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Int64Array extends ArrayBufferView {\n [key: number]: i64;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): i64 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: i64): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n includes(searchElement: i64, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: i64, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: i64, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: i64, start: i32 = 0, end: i32 = i32.MAX_VALUE): Int64Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: i64, b: i64) => i32 = COMPARATOR()): Int64Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Int64Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: i64, index: i32, array: Int64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: i64, index: i32, array: Int64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: i64, index: i32, self: Int64Array) => i64): Int64Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: i64, index: i32, self: Int64Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: i64, index: i32, self: Int64Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: i64, index: i32, self: Int64Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: i64, index: i32, self: Int64Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Uint64Array extends ArrayBufferView {\n [key: number]: u64;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): u64 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: u64): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n includes(searchElement: u64, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: u64, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: u64, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: u64, start: i32 = 0, end: i32 = i32.MAX_VALUE): Uint64Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: u64, b: u64) => i32 = COMPARATOR()): Uint64Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Uint64Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: u64, index: i32, array: Uint64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: u64, index: i32, array: Uint64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: u64, index: i32, self: Uint64Array) => u64): Uint64Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: u64, index: i32, self: Uint64Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: u64, index: i32, self: Uint64Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: u64, index: i32, self: Uint64Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: u64, index: i32, self: Uint64Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Float32Array extends ArrayBufferView {\n [key: number]: f32;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): f32 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: f32): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n includes(searchElement: f32, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: f32, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: f32, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: f32, start: i32 = 0, end: i32 = i32.MAX_VALUE): Float32Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: f32, b: f32) => i32 = COMPARATOR()): Float32Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Float32Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: f32, index: i32, array: Float32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: f32, index: i32, array: Float32Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: f32, index: i32, self: Float32Array) => f32): Float32Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: f32, index: i32, self: Float32Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: f32, index: i32, self: Float32Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: f32, index: i32, self: Float32Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: f32, index: i32, self: Float32Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\nexport class Float64Array extends ArrayBufferView {\n [key: number]: f64;\n\n // @ts-ignore: decorator\n @lazy\n static readonly BYTES_PER_ELEMENT: usize = sizeof();\n\n constructor(length: i32) {\n super(length, alignof());\n }\n\n get buffer(): ArrayBuffer {\n return this.data;\n }\n\n get length(): i32 {\n return this.byteLength >>> alignof();\n }\n\n @operator("[]") // unchecked is built-in\n private __get(index: i32): f64 {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n return load(this.dataStart + (index << alignof()));\n }\n\n @operator("[]=") // unchecked is built-in\n private __set(index: i32, value: f64): void {\n if (index >= this.dataLength >>> alignof()) throw new RangeError(E_INDEXOUTOFRANGE);\n store(this.dataStart + (index << alignof()), value);\n }\n\n includes(searchElement: f64, fromIndex: i32 = 0): bool {\n return INCLUDES(this, searchElement, fromIndex);\n }\n\n indexOf(searchElement: f64, fromIndex: i32 = 0): i32 {\n return INDEX_OF(this, searchElement, fromIndex);\n }\n\n lastIndexOf(searchElement: f64, fromIndex: i32 = this.length): i32 {\n return LAST_INDEX_OF(this, searchElement, fromIndex);\n }\n\n fill(value: f64, start: i32 = 0, end: i32 = i32.MAX_VALUE): Float64Array {\n return FILL(this, value, start, end);\n }\n\n sort(comparator: (a: f64, b: f64) => i32 = COMPARATOR()): Float64Array {\n return SORT(this, comparator);\n }\n\n subarray(begin: i32 = 0, end: i32 = 0x7fffffff): Float64Array {\n return SUBARRAY(this, begin, end);\n }\n\n reduce(\n fn: (accumulator: T, value: f64, index: i32, array: Float64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE(this, fn, initialValue);\n }\n\n reduceRight(\n fn: (accumulator: T, value: f64, index: i32, array: Float64Array) => T,\n initialValue: T,\n ): T {\n return REDUCE_RIGHT(this, fn, initialValue);\n }\n\n map(fn: (value: f64, index: i32, self: Float64Array) => f64): Float64Array {\n return MAP(this, fn);\n }\n\n findIndex(fn: (value: f64, index: i32, self: Float64Array) => bool): i32 {\n return FIND_INDEX(this, fn);\n }\n\n some(fn: (value: f64, index: i32, self: Float64Array) => bool): bool {\n return SOME(this, fn);\n }\n\n every(fn: (value: f64, index: i32, self: Float64Array) => bool): bool {\n return EVERY(this, fn);\n }\n\n forEach(fn: (value: f64, index: i32, self: Float64Array) => void): void {\n FOREACH(this, fn);\n }\n\n reverse(): this {\n return REVERSE(this);\n }\n}\n\n// @ts-ignore: decorator\n@inline\nfunction FILL(\n array: TArray,\n value: native,\n start: i32,\n end: i32\n): TArray {\n var dataStart = array.dataStart;\n var length = array.length;\n start = start < 0 ? max(length + start, 0) : min(start, length);\n end = end < 0 ? max(length + end, 0) : min(end, length);\n if (sizeof() == 1) {\n if (start < end) memory.fill(dataStart + start, value, (end - start));\n } else {\n for (; start < end; ++start) {\n store(dataStart + (start << alignof()), value);\n }\n }\n return array;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction SORT(\n array: TArray,\n comparator: (a: T, b: T) => i32\n): TArray {\n var length = array.length;\n if (length <= 1) return array;\n var base = array.dataStart;\n if (length == 2) {\n let a: T = load(base, sizeof()); // a = arr[1]\n let b: T = load(base); // b = arr[0]\n if (comparator(a, b) < 0) {\n store(base, b, sizeof()); // arr[1] = b\n store(base, a); // arr[0] = a\n }\n return array;\n }\n SORT_IMPL(base, length, comparator);\n return array;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction SUBARRAY(\n array: TArray,\n begin: i32,\n end: i32\n): TArray {\n var len = array.length;\n begin = begin < 0 ? max(len + begin, 0) : min(begin, len);\n end = end < 0 ? max(len + end, 0) : min(end, len);\n end = max(end, begin);\n var out = changetype(__alloc(offsetof(), idof())); // retains\n out.data = array.data; // retains\n out.dataStart = array.dataStart + (begin << alignof());\n out.dataLength = (end - begin) << alignof();\n return out;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction REDUCE(\n array: TArray,\n fn: (accumulator: TRet, value: T, index: i32, array: TArray) => TRet,\n initialValue: TRet\n): TRet {\n var dataStart = array.dataStart;\n for (let i = 0, k = array.length; i < k; i++) {\n initialValue = fn(initialValue, load(dataStart + (i << alignof())), i, array);\n }\n return initialValue;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction REDUCE_RIGHT(\n array: TArray,\n fn: (accumulator: TRet, value: T, index: i32, array: TArray) => TRet,\n initialValue: TRet\n): TRet {\n var dataStart = array.dataStart;\n for (let i = array.length - 1; i >= 0; i--) {\n initialValue = fn(initialValue, load(dataStart + (i << alignof())), i, array);\n }\n return initialValue;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction MAP(\n array: TArray,\n fn: (value: T, index: i32, self: TArray) => T,\n): TArray {\n var length = array.length;\n var dataStart = array.dataStart;\n var out = instantiate(length);\n var outDataStart = out.dataStart;\n for (let i = 0; i < length; i++) {\n store(\n outDataStart + (i << alignof()),\n fn(load(dataStart + (i << alignof())), i, array)\n );\n }\n return out;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction FIND_INDEX(\n array: TArray,\n fn: (value: T, index: i32, array: TArray) => bool,\n): i32 {\n var dataStart = array.dataStart;\n for (let i = 0, k = array.length; i < k; i++) {\n if (fn(load(dataStart + (i << alignof())), i, array)) return i;\n }\n return -1;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction INCLUDES(\n array: TArray,\n searchElement: T,\n fromIndex: i32,\n): bool {\n return INDEX_OF(array, searchElement, fromIndex) >= 0;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction INDEX_OF(\n array: TArray,\n searchElement: T,\n fromIndex: i32,\n): i32 {\n var index: isize = fromIndex;\n var length: isize = array.length;\n if (length == 0 || index >= length) return -1;\n if (index < 0) index = max(length + index, 0);\n var dataStart = array.dataStart;\n while (index < length) {\n if (load(dataStart + (index << alignof())) == searchElement) return index;\n ++index;\n }\n return -1;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction LAST_INDEX_OF(\n array: TArray,\n searchElement: T,\n fromIndex: i32,\n): i32 {\n var index: isize = fromIndex;\n var length: isize = array.length;\n if (length == 0) return -1;\n if (index < 0) index = length + index; // no need to clamp\n else if (index >= length) index = length - 1;\n var dataStart = array.dataStart;\n while (index >= 0) {\n if (load(dataStart + (index << alignof())) == searchElement) return index;\n --index;\n }\n return -1;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction SOME(\n array: TArray,\n fn: (value: T, index: i32, array: TArray) => bool,\n): bool {\n var dataStart = array.dataStart;\n for (let i = 0, k = array.length; i < k; i++) {\n if (fn(load(dataStart + (i << alignof())), i, array)) return true;\n }\n return false;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction EVERY(\n array: TArray,\n fn: (value: T, index: i32, array: TArray) => bool,\n): bool {\n var dataStart = array.dataStart;\n for (let i = 0, k = array.length; i < k; i++) {\n if (fn(load(dataStart + (i << alignof())), i, array)) continue;\n return false;\n }\n return true;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction FOREACH(\n array: TArray,\n fn: (value: T, index: i32, array: TArray) => void,\n): void {\n var dataStart = array.dataStart;\n for (let i = 0, k = array.length; i < k; i++) {\n fn(load(dataStart + (i << alignof())), i, array);\n }\n}\n\n// @ts-ignore: decorator\n@inline\nfunction REVERSE(array: TArray): TArray {\n var dataStart = array.dataStart;\n for (let front: usize = 0, back: usize = array.length - 1; front < back; ++front, --back) {\n let frontPtr = dataStart + (front << alignof());\n let backPtr = dataStart + (back << alignof());\n let temp = load(frontPtr);\n store(frontPtr, load(backPtr));\n store(backPtr, temp);\n }\n return array;\n}\n',"util/error":'// Common error messages for use accross the standard library. Keeping error messages compact\n// and reusing them where possible ensures minimal static data in binaries.\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_INDEXOUTOFRANGE: string = "Index out of range";\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_INVALIDLENGTH: string = "Invalid length";\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_EMPTYARRAY: string = "Array is empty";\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_HOLEYARRAY: string = "Element type must be nullable if array is holey";\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_NOTIMPLEMENTED: string = "Not implemented";\n\n// @ts-ignore: decorator\n@lazy @inline\nexport const E_KEYNOTFOUND: string = "Key does not exist";\n',"util/hash":"// @ts-ignore: decorator\n@inline\nexport function HASH(key: T): u32 {\n if (isString()) {\n return hashStr(changetype(key));\n } else if (isReference()) {\n if (sizeof() == 4) return hash32(changetype(key));\n if (sizeof() == 8) return hash64(changetype(key));\n } else if (isFloat()) {\n if (sizeof() == 4) return hash32(reinterpret(f32(key)));\n if (sizeof() == 8) return hash64(reinterpret(f64(key)));\n } else {\n if (sizeof() == 1) return hash8 (u32(key));\n if (sizeof() == 2) return hash16(u32(key));\n if (sizeof() == 4) return hash32(u32(key));\n if (sizeof() == 8) return hash64(u64(key));\n }\n return unreachable();\n}\n\n// FNV-1a 32-bit as a starting point, see: http://isthe.com/chongo/tech/comp/fnv/\n\n// @ts-ignore: decorator\n@inline\nconst FNV_OFFSET: u32 = 2166136261;\n\n// @ts-ignore: decorator\n@inline\nconst FNV_PRIME: u32 = 16777619;\n\nfunction hash8(key: u32): u32 {\n return (FNV_OFFSET ^ key) * FNV_PRIME;\n}\n\nfunction hash16(key: u32): u32 {\n var v = FNV_OFFSET;\n v = (v ^ ( key & 0xff)) * FNV_PRIME;\n v = (v ^ ( key >> 8 )) * FNV_PRIME;\n return v;\n}\n\nfunction hash32(key: u32): u32 {\n var v = FNV_OFFSET;\n v = (v ^ ( key & 0xff)) * FNV_PRIME;\n v = (v ^ ((key >> 8) & 0xff)) * FNV_PRIME;\n v = (v ^ ((key >> 16) & 0xff)) * FNV_PRIME;\n v = (v ^ ( key >> 24 )) * FNV_PRIME;\n return v;\n}\n\nfunction hash64(key: u64): u32 {\n var l = key;\n var h = (key >>> 32);\n var v = FNV_OFFSET;\n v = (v ^ ( l & 0xff)) * FNV_PRIME;\n v = (v ^ ((l >> 8) & 0xff)) * FNV_PRIME;\n v = (v ^ ((l >> 16) & 0xff)) * FNV_PRIME;\n v = (v ^ ( l >> 24 )) * FNV_PRIME;\n v = (v ^ ( h & 0xff)) * FNV_PRIME;\n v = (v ^ ((h >> 8) & 0xff)) * FNV_PRIME;\n v = (v ^ ((h >> 16) & 0xff)) * FNV_PRIME;\n v = (v ^ ( h >> 24 )) * FNV_PRIME;\n return v;\n}\n\nfunction hashStr(key: string): u32 {\n var v = FNV_OFFSET;\n if (key !== null) {\n for (let i: usize = 0, k: usize = key.length << 1; i < k; ++i) {\n v = (v ^ load(changetype(key) + i)) * FNV_PRIME;\n }\n }\n return v;\n}\n","util/memory":"export function memcpy(dest: usize, src: usize, n: usize): void { // see: musl/src/string/memcpy.c\n if (ASC_SHRINK_LEVEL > 1) {\n while (n) {\n store(dest++, load(src++));\n --n;\n }\n } else {\n let w: u32, x: u32;\n\n // copy 1 byte each until src is aligned to 4 bytes\n while (n && (src & 3)) {\n store(dest++, load(src++));\n n--;\n }\n\n // if dst is aligned to 4 bytes as well, copy 4 bytes each\n if ((dest & 3) == 0) {\n while (n >= 16) {\n store(dest , load(src ));\n store(dest + 4, load(src + 4));\n store(dest + 8, load(src + 8));\n store(dest + 12, load(src + 12));\n src += 16; dest += 16; n -= 16;\n }\n if (n & 8) {\n store(dest , load(src ));\n store(dest + 4, load(src + 4));\n dest += 8; src += 8;\n }\n if (n & 4) {\n store(dest, load(src));\n dest += 4; src += 4;\n }\n if (n & 2) { // drop to 2 bytes each\n store(dest, load(src));\n dest += 2; src += 2;\n }\n if (n & 1) { // drop to 1 byte\n store(dest++, load(src++));\n }\n return;\n }\n\n // if dst is not aligned to 4 bytes, use alternating shifts to copy 4 bytes each\n // doing shifts if faster when copying enough bytes (here: 32 or more)\n if (n >= 32) {\n switch (dest & 3) {\n // known to be != 0\n case 1: {\n w = load(src);\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n n -= 3;\n while (n >= 17) {\n x = load(src + 1);\n store(dest, w >> 24 | x << 8);\n w = load(src + 5);\n store(dest + 4, x >> 24 | w << 8);\n x = load(src + 9);\n store(dest + 8, w >> 24 | x << 8);\n w = load(src + 13);\n store(dest + 12, x >> 24 | w << 8);\n src += 16; dest += 16; n -= 16;\n }\n break;\n }\n case 2: {\n w = load(src);\n store(dest++, load(src++));\n store(dest++, load(src++));\n n -= 2;\n while (n >= 18) {\n x = load(src + 2);\n store(dest, w >> 16 | x << 16);\n w = load(src + 6);\n store(dest + 4, x >> 16 | w << 16);\n x = load(src + 10);\n store(dest + 8, w >> 16 | x << 16);\n w = load(src + 14);\n store(dest + 12, x >> 16 | w << 16);\n src += 16; dest += 16; n -= 16;\n }\n break;\n }\n case 3: {\n w = load(src);\n store(dest++, load(src++));\n n -= 1;\n while (n >= 19) {\n x = load(src + 3);\n store(dest, w >> 8 | x << 24);\n w = load(src + 7);\n store(dest + 4, x >> 8 | w << 24);\n x = load(src + 11);\n store(dest + 8, w >> 8 | x << 24);\n w = load(src + 15);\n store(dest + 12, x >> 8 | w << 24);\n src += 16; dest += 16; n -= 16;\n }\n break;\n }\n }\n }\n\n // copy remaining bytes one by one\n if (n & 16) {\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n }\n if (n & 8) {\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n }\n if (n & 4) {\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n store(dest++, load(src++));\n }\n if (n & 2) {\n store(dest++, load(src++));\n store(dest++, load(src++));\n }\n if (n & 1) {\n store(dest++, load(src++));\n }\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function memmove(dest: usize, src: usize, n: usize): void { // see: musl/src/string/memmove.c\n if (dest === src) return;\n if (ASC_SHRINK_LEVEL < 1) {\n if (src + n <= dest || dest + n <= src) {\n memcpy(dest, src, n);\n return;\n }\n }\n if (dest < src) {\n if ((src & 7) == (dest & 7)) {\n while (dest & 7) {\n if (!n) return;\n --n;\n store(dest++, load(src++));\n }\n while (n >= 8) {\n store(dest, load(src));\n n -= 8;\n dest += 8;\n src += 8;\n }\n }\n while (n) {\n store(dest++, load(src++));\n --n;\n }\n } else {\n if ((src & 7) == (dest & 7)) {\n while ((dest + n) & 7) {\n if (!n) return;\n store(dest + --n, load(src + n));\n }\n while (n >= 8) {\n n -= 8;\n store(dest + n, load(src + n));\n }\n }\n while (n) {\n store(dest + --n, load(src + n));\n }\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function memset(dest: usize, c: u8, n: usize): void { // see: musl/src/string/memset\n if (ASC_SHRINK_LEVEL > 1) {\n while (n) {\n store(dest++, c);\n --n;\n }\n } else {\n // fill head and tail with minimal branching\n if (!n) return;\n store(dest, c);\n store(dest + n - 1, c);\n if (n <= 2) return;\n\n store(dest + 1, c);\n store(dest + 2, c);\n store(dest + n - 2, c);\n store(dest + n - 3, c);\n if (n <= 6) return;\n store(dest + 3, c);\n store(dest + n - 4, c);\n if (n <= 8) return;\n\n // advance pointer to align it at 4-byte boundary\n let k: usize = -dest & 3;\n dest += k;\n n -= k;\n n &= -4;\n\n let c32: u32 = -1 / 255 * c;\n\n // fill head/tail up to 28 bytes each in preparation\n store(dest, c32);\n store(dest + n - 4, c32);\n if (n <= 8) return;\n store(dest + 4, c32);\n store(dest + 8, c32);\n store(dest + n - 12, c32);\n store(dest + n - 8, c32);\n if (n <= 24) return;\n store(dest + 12, c32);\n store(dest + 16, c32);\n store(dest + 20, c32);\n store(dest + 24, c32);\n store(dest + n - 28, c32);\n store(dest + n - 24, c32);\n store(dest + n - 20, c32);\n store(dest + n - 16, c32);\n\n // align to a multiple of 8\n k = 24 + (dest & 4);\n dest += k;\n n -= k;\n\n // copy 32 bytes each\n let c64: u64 = c32 | (c32 << 32);\n while (n >= 32) {\n store(dest, c64);\n store(dest + 8, c64);\n store(dest + 16, c64);\n store(dest + 24, c64);\n n -= 32;\n dest += 32;\n }\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function memcmp(vl: usize, vr: usize, n: usize): i32 { // see: musl/src/string/memcmp.c\n if (vl == vr) return 0;\n while (n != 0 && load(vl) == load(vr)) {\n n--; vl++; vr++;\n }\n return n ? load(vl) - load(vr) : 0;\n}\n","util/number":'/// \n\nimport { idof } from "../builtins";\nimport { CharCode } from "./string";\nimport { ArrayBufferView } from "../arraybuffer";\n\n// @ts-ignore: decorator\n@inline\nexport const MAX_DOUBLE_LENGTH = 28;\n\n// @ts-ignore: decorator\n@lazy @inline\nconst POWERS10: u32[] = [\n 1,\n 10,\n 100,\n 1000,\n 10000,\n 100000,\n 1000000,\n 10000000,\n 100000000,\n 1000000000\n];\n\n/*\n Lookup table for pairwise char codes in range [0-99]\n\n "00", "01", "02", "03", "04", "05", "06", "07", "08", "09",\n "10", "11", "12", "13", "14", "15", "16", "17", "18", "19",\n "20", "21", "22", "23", "24", "25", "26", "27", "28", "29",\n "30", "31", "32", "33", "34", "35", "36", "37", "38", "39",\n "40", "41", "42", "43", "44", "45", "46", "47", "48", "49",\n "50", "51", "52", "53", "54", "55", "56", "57", "58", "59",\n "60", "61", "62", "63", "64", "65", "66", "67", "68", "69",\n "70", "71", "72", "73", "74", "75", "76", "77", "78", "79",\n "80", "81", "82", "83", "84", "85", "86", "87", "88", "89",\n "90", "91", "92", "93", "94", "95", "96", "97", "98", "99"\n*/\n// @ts-ignore: decorator\n@lazy @inline\nconst DIGITS: u32[] = [\n 0x00300030, 0x00310030, 0x00320030, 0x00330030, 0x00340030,\n 0x00350030, 0x00360030, 0x00370030, 0x00380030, 0x00390030,\n 0x00300031, 0x00310031, 0x00320031, 0x00330031, 0x00340031,\n 0x00350031, 0x00360031, 0x00370031, 0x00380031, 0x00390031,\n 0x00300032, 0x00310032, 0x00320032, 0x00330032, 0x00340032,\n 0x00350032, 0x00360032, 0x00370032, 0x00380032, 0x00390032,\n 0x00300033, 0x00310033, 0x00320033, 0x00330033, 0x00340033,\n 0x00350033, 0x00360033, 0x00370033, 0x00380033, 0x00390033,\n 0x00300034, 0x00310034, 0x00320034, 0x00330034, 0x00340034,\n 0x00350034, 0x00360034, 0x00370034, 0x00380034, 0x00390034,\n 0x00300035, 0x00310035, 0x00320035, 0x00330035, 0x00340035,\n 0x00350035, 0x00360035, 0x00370035, 0x00380035, 0x00390035,\n 0x00300036, 0x00310036, 0x00320036, 0x00330036, 0x00340036,\n 0x00350036, 0x00360036, 0x00370036, 0x00380036, 0x00390036,\n 0x00300037, 0x00310037, 0x00320037, 0x00330037, 0x00340037,\n 0x00350037, 0x00360037, 0x00370037, 0x00380037, 0x00390037,\n 0x00300038, 0x00310038, 0x00320038, 0x00330038, 0x00340038,\n 0x00350038, 0x00360038, 0x00370038, 0x00380038, 0x00390038,\n 0x00300039, 0x00310039, 0x00320039, 0x00330039, 0x00340039,\n 0x00350039, 0x00360039, 0x00370039, 0x00380039, 0x00390039\n];\n\n// @ts-ignore: decorator\n@lazy @inline\nconst EXP_POWERS: i16[] = [\n -1220, -1193, -1166, -1140, -1113, -1087, -1060, -1034, -1007, -980,\n -954, -927, -901, -874, -847, -821, -794, -768, -741, -715,\n -688, -661, -635, -608, -582, -555, -529, -502, -475, -449,\n -422, -396, -369, -343, -316, -289, -263, -236, -210, -183,\n -157, -130, -103, -77, -50, -24, 3, 30, 56, 83,\n 109, 136, 162, 189, 216, 242, 269, 295, 322, 348,\n 375, 402, 428, 455, 481, 508, 534, 561, 588, 614,\n 641, 667, 694, 720, 747, 774, 800, 827, 853, 880,\n 907, 933, 960, 986, 1013, 1039, 1066\n];\n\n// 1e-348, 1e-340, ..., 1e340\n// @ts-ignore: decorator\n@lazy @inline\nconst FRC_POWERS: u64[] = [\n 0xFA8FD5A0081C0288, 0xBAAEE17FA23EBF76, 0x8B16FB203055AC76, 0xCF42894A5DCE35EA,\n 0x9A6BB0AA55653B2D, 0xE61ACF033D1A45DF, 0xAB70FE17C79AC6CA, 0xFF77B1FCBEBCDC4F,\n 0xBE5691EF416BD60C, 0x8DD01FAD907FFC3C, 0xD3515C2831559A83, 0x9D71AC8FADA6C9B5,\n 0xEA9C227723EE8BCB, 0xAECC49914078536D, 0x823C12795DB6CE57, 0xC21094364DFB5637,\n 0x9096EA6F3848984F, 0xD77485CB25823AC7, 0xA086CFCD97BF97F4, 0xEF340A98172AACE5,\n 0xB23867FB2A35B28E, 0x84C8D4DFD2C63F3B, 0xC5DD44271AD3CDBA, 0x936B9FCEBB25C996,\n 0xDBAC6C247D62A584, 0xA3AB66580D5FDAF6, 0xF3E2F893DEC3F126, 0xB5B5ADA8AAFF80B8,\n 0x87625F056C7C4A8B, 0xC9BCFF6034C13053, 0x964E858C91BA2655, 0xDFF9772470297EBD,\n 0xA6DFBD9FB8E5B88F, 0xF8A95FCF88747D94, 0xB94470938FA89BCF, 0x8A08F0F8BF0F156B,\n 0xCDB02555653131B6, 0x993FE2C6D07B7FAC, 0xE45C10C42A2B3B06, 0xAA242499697392D3,\n 0xFD87B5F28300CA0E, 0xBCE5086492111AEB, 0x8CBCCC096F5088CC, 0xD1B71758E219652C,\n 0x9C40000000000000, 0xE8D4A51000000000, 0xAD78EBC5AC620000, 0x813F3978F8940984,\n 0xC097CE7BC90715B3, 0x8F7E32CE7BEA5C70, 0xD5D238A4ABE98068, 0x9F4F2726179A2245,\n 0xED63A231D4C4FB27, 0xB0DE65388CC8ADA8, 0x83C7088E1AAB65DB, 0xC45D1DF942711D9A,\n 0x924D692CA61BE758, 0xDA01EE641A708DEA, 0xA26DA3999AEF774A, 0xF209787BB47D6B85,\n 0xB454E4A179DD1877, 0x865B86925B9BC5C2, 0xC83553C5C8965D3D, 0x952AB45CFA97A0B3,\n 0xDE469FBD99A05FE3, 0xA59BC234DB398C25, 0xF6C69A72A3989F5C, 0xB7DCBF5354E9BECE,\n 0x88FCF317F22241E2, 0xCC20CE9BD35C78A5, 0x98165AF37B2153DF, 0xE2A0B5DC971F303A,\n 0xA8D9D1535CE3B396, 0xFB9B7CD9A4A7443C, 0xBB764C4CA7A44410, 0x8BAB8EEFB6409C1A,\n 0xD01FEF10A657842C, 0x9B10A4E5E9913129, 0xE7109BFBA19C0C9D, 0xAC2820D9623BF429,\n 0x80444B5E7AA7CF85, 0xBF21E44003ACDD2D, 0x8E679C2F5E44FF8F, 0xD433179D9C8CB841,\n 0x9E19DB92B4E31BA9, 0xEB96BF6EBADF77D9, 0xAF87023B9BF0EE6B\n];\n\n// Count number of decimals for u32 values\n// In our case input value always non-zero so we can simplify some parts\nexport function decimalCount32(value: u32): u32 {\n if (value < 100000) {\n if (value < 100) {\n return select(1, 2, value < 10);\n } else {\n let m = select(4, 5, value < 10000);\n return select(3, m, value < 1000);\n }\n } else {\n if (value < 10000000) {\n return select(6, 7, value < 1000000);\n } else {\n let m = select(9, 10, value < 1000000000);\n return select(8, m, value < 100000000);\n }\n }\n}\n\n// Count number of decimals for u64 values\n// In our case input value always greater than 2^32-1 so we can skip some parts\nexport function decimalCount64(value: u64): u32 {\n if (value < 1000000000000000) {\n if (value < 1000000000000) {\n return select(11, 12, value < 100000000000);\n } else {\n let m = select(14, 15, value < 100000000000000);\n return select(13, m, value < 10000000000000);\n }\n } else {\n if (value < 100000000000000000) {\n return select(16, 17, value < 10000000000000000);\n } else {\n let m = select(19, 20, value < 10000000000000000000);\n return select(18, m, value < 1000000000000000000);\n }\n }\n}\n\nfunction utoa32_lut(buffer: usize, num: u32, offset: usize): void {\n var lut = changetype(DIGITS).dataStart;\n while (num >= 10000) {\n // in most VMs i32/u32 div and modulo by constant can be shared and simplificate\n let t = num / 10000;\n let r = num % 10000;\n num = t;\n\n let d1 = r / 100;\n let d2 = r % 100;\n\n let digits1 = load(lut + (d1 << alignof()));\n let digits2 = load(lut + (d2 << alignof()));\n\n offset -= 4;\n store(buffer + (offset << 1), digits1 | (digits2 << 32));\n }\n\n if (num >= 100) {\n let t = num / 100;\n let d1 = num % 100;\n num = t;\n offset -= 2;\n let digits = load(lut + (d1 << alignof()));\n store(buffer + (offset << 1), digits);\n }\n\n if (num >= 10) {\n offset -= 2;\n let digits = load(lut + (num << alignof()));\n store(buffer + (offset << 1), digits);\n } else {\n offset -= 1;\n let digit = CharCode._0 + num;\n store(buffer + (offset << 1), digit);\n }\n}\n\nfunction utoa64_lut(buffer: usize, num: u64, offset: usize): void {\n var lut = changetype(DIGITS).dataStart;\n while (num >= 100000000) {\n let t = num / 100000000;\n let r = (num - t * 100000000);\n num = t;\n\n let b = r / 10000;\n let c = r % 10000;\n\n let b1 = b / 100;\n let b2 = b % 100;\n let c1 = c / 100;\n let c2 = c % 100;\n\n let digits1 = load(lut + (c1 << alignof()));\n let digits2 = load(lut + (c2 << alignof()));\n\n offset -= 4;\n store(buffer + (offset << 1), digits1 | (digits2 << 32));\n\n digits1 = load(lut + (b1 << alignof()));\n digits2 = load(lut + (b2 << alignof()));\n\n offset -= 4;\n store(buffer + (offset << 1), digits1 | (digits2 << 32));\n }\n\n utoa32_lut(buffer, num, offset);\n}\n\nfunction utoa_simple(buffer: usize, num: T, offset: usize): void {\n do {\n let t = num / 10;\n let r = (num % 10);\n num = changetype(t);\n offset -= 1;\n store(buffer + (offset << 1), CharCode._0 + r);\n } while (num);\n}\n\n// @ts-ignore: decorator\n@inline\nexport function utoa32_core(buffer: usize, num: u32, offset: u32): void {\n if (ASC_SHRINK_LEVEL >= 1) {\n utoa_simple(buffer, num, offset);\n } else {\n utoa32_lut(buffer, num, offset);\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function utoa64_core(buffer: usize, num: u64, offset: u32): void {\n if (ASC_SHRINK_LEVEL >= 1) {\n utoa_simple(buffer, num, offset);\n } else {\n utoa64_lut(buffer, num, offset);\n }\n}\n\nexport function utoa32(value: u32): String {\n if (!value) return "0";\n\n var decimals = decimalCount32(value);\n var out = __alloc(decimals << 1, idof());\n\n utoa32_core(out, value, decimals);\n return changetype(out); // retains\n}\n\nexport function itoa32(value: i32): String {\n if (!value) return "0";\n\n var sign = value < 0;\n if (sign) value = -value;\n\n var decimals = decimalCount32(value) + u32(sign);\n var out = __alloc(decimals << 1, idof());\n\n utoa32_core(out, value, decimals);\n if (sign) store(out, CharCode.MINUS);\n return changetype(out); // retains\n}\n\nexport function utoa64(value: u64): String {\n if (!value) return "0";\n\n var out: usize;\n if (value <= u32.MAX_VALUE) {\n let val32 = value;\n let decimals = decimalCount32(val32);\n out = __alloc(decimals << 1, idof());\n utoa32_core(out, val32, decimals);\n } else {\n let decimals = decimalCount64(value);\n out = __alloc(decimals << 1, idof());\n utoa64_core(out, value, decimals);\n }\n return changetype(out); // retains\n}\n\nexport function itoa64(value: i64): String {\n if (!value) return "0";\n\n var sign = value < 0;\n if (sign) value = -value;\n\n var out: usize;\n if (value <= u32.MAX_VALUE) {\n let val32 = value;\n let decimals = decimalCount32(val32) + u32(sign);\n out = __alloc(decimals << 1, idof());\n utoa32_core(out, val32, decimals);\n } else {\n let decimals = decimalCount64(value) + u32(sign);\n out = __alloc(decimals << 1, idof());\n utoa64_core(out, value, decimals);\n }\n if (sign) store(out, CharCode.MINUS);\n\n return changetype(out); // retains\n}\n\nexport function itoa(value: T): String {\n if (!isInteger()) ERROR("integer type expected");\n if (isSigned()) {\n if (sizeof() <= 4) {\n return itoa32(value);\n } else {\n return itoa64(value);\n }\n } else {\n if (sizeof() <= 4) {\n return utoa32(value);\n } else {\n return utoa64(value);\n }\n }\n}\n\n// @ts-ignore: decorator\n@lazy\nvar _K: i32 = 0;\n\n// // @ts-ignore: decorator\n// @lazy\n// var _frc: u64 = 0;\n\n// @ts-ignore: decorator\n@lazy\nvar _exp: i32 = 0;\n\n// @ts-ignore: decorator\n@lazy\nvar _frc_minus: u64 = 0;\n\n// @ts-ignore: decorator\n@lazy\nvar _frc_plus: u64 = 0;\n\n// @ts-ignore: decorator\n@lazy\nvar _frc_pow: u64 = 0;\n\n// @ts-ignore: decorator\n@lazy\nvar _exp_pow: i32 = 0;\n\n// @ts-ignore: decorator\n@inline\nfunction umul64f(u: u64, v: u64): u64 {\n var u0 = u & 0xFFFFFFFF;\n var v0 = v & 0xFFFFFFFF;\n\n var u1 = u >> 32;\n var v1 = v >> 32;\n\n var l = u0 * v0;\n var t = u1 * v0 + (l >> 32);\n var w = u0 * v1 + (t & 0xFFFFFFFF);\n\n w += 0x7FFFFFFF; // rounding\n\n t >>= 32;\n w >>= 32;\n\n return u1 * v1 + t + w;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction umul64e(e1: i32, e2: i32): i32 {\n return e1 + e2 + 64; // where 64 is significand size\n}\n\n// @ts-ignore: decorator\n@inline\nfunction normalizedBoundaries(f: u64, e: i32): void {\n var frc = (f << 1) + 1;\n var exp = e - 1;\n var off = clz(frc);\n frc <<= off;\n exp -= off;\n\n var m = 1 + i32(f == 0x0010000000000000);\n\n _frc_plus = frc;\n _frc_minus = ((f << m) - 1) << e - m - exp;\n _exp = exp;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction grisuRound(buffer: usize, len: i32, delta: u64, rest: u64, ten_kappa: u64, wp_w: u64): void {\n var lastp = buffer + ((len - 1) << 1);\n var digit = load(lastp);\n while (\n rest < wp_w &&\n delta - rest >= ten_kappa && (\n rest + ten_kappa < wp_w ||\n wp_w - rest > rest + ten_kappa - wp_w\n )\n ) {\n --digit;\n rest += ten_kappa;\n }\n store(lastp, digit);\n}\n\n// @ts-ignore: decorator\n@inline\nfunction getCachedPower(minExp: i32): void {\n const c = reinterpret(0x3FD34413509F79FE); // 1 / lg(10) = 0.30102999566398114\n var dk = (-61 - minExp) * c + 347;\t // dk must be positive, so can do ceiling in positive\n var k = dk;\n k += i32(k != dk); // conversion with ceil\n\n var index = (k >> 3) + 1;\n _K = 348 - (index << 3);\t// decimal exponent no need lookup table\n _frc_pow = unchecked(FRC_POWERS[index]);\n _exp_pow = unchecked(EXP_POWERS[index]);\n}\n\n// @ts-ignore: decorator\n@inline\nfunction grisu2(value: f64, buffer: usize, sign: i32): i32 {\n\n // frexp routine\n var uv = reinterpret(value);\n var exp = ((uv & 0x7FF0000000000000) >>> 52);\n var sid = uv & 0x000FFFFFFFFFFFFF;\n var frc = (u64(exp != 0) << 52) + sid;\n exp = select(exp, 1, exp != 0) - (0x3FF + 52);\n\n normalizedBoundaries(frc, exp);\n getCachedPower(_exp);\n\n // normalize\n var off = clz(frc);\n frc <<= off;\n exp -= off;\n\n var frc_pow = _frc_pow;\n var exp_pow = _exp_pow;\n\n var w_frc = umul64f(frc, frc_pow);\n var w_exp = umul64e(exp, exp_pow);\n\n var wp_frc = umul64f(_frc_plus, frc_pow) - 1;\n var wp_exp = umul64e(_exp, exp_pow);\n\n var wm_frc = umul64f(_frc_minus, frc_pow) + 1;\n var delta = wp_frc - wm_frc;\n\n return genDigits(buffer, w_frc, w_exp, wp_frc, wp_exp, delta, sign);\n}\n\nfunction genDigits(buffer: usize, w_frc: u64, w_exp: i32, mp_frc: u64, mp_exp: i32, delta: u64, sign: i32): i32 {\n var one_exp = -mp_exp;\n var one_frc = (1) << one_exp;\n var mask = one_frc - 1;\n\n var wp_w_frc = mp_frc - w_frc;\n var wp_w_exp = mp_exp;\n\n var p1 = (mp_frc >> one_exp);\n var p2 = mp_frc & mask;\n\n var kappa = decimalCount32(p1);\n var len = sign;\n\n var lut = changetype(POWERS10).dataStart;\n\n while (kappa > 0) {\n let d: u32;\n switch (kappa) {\n case 10: { d = p1 / 1000000000; p1 %= 1000000000; break; }\n case 9: { d = p1 / 100000000; p1 %= 100000000; break; }\n case 8: { d = p1 / 10000000; p1 %= 10000000; break; }\n case 7: { d = p1 / 1000000; p1 %= 1000000; break; }\n case 6: { d = p1 / 100000; p1 %= 100000; break; }\n case 5: { d = p1 / 10000; p1 %= 10000; break; }\n case 4: { d = p1 / 1000; p1 %= 1000; break; }\n case 3: { d = p1 / 100; p1 %= 100; break; }\n case 2: { d = p1 / 10; p1 %= 10; break; }\n case 1: { d = p1; p1 = 0; break; }\n default: { d = 0; break; }\n }\n\n if (d | len) store(buffer + (len++ << 1), CharCode._0 + d);\n\n --kappa;\n let tmp = ((p1) << one_exp) + p2;\n if (tmp <= delta) {\n _K += kappa;\n grisuRound(buffer, len, delta, tmp, load(lut + (kappa << alignof())) << one_exp, wp_w_frc);\n return len;\n }\n }\n\n while (1) {\n p2 *= 10;\n delta *= 10;\n\n let d = p2 >> one_exp;\n if (d | len) store(buffer + (len++ << 1), CharCode._0 + d);\n\n p2 &= mask;\n --kappa;\n if (p2 < delta) {\n _K += kappa;\n wp_w_frc *= load(lut + (-kappa << alignof()));\n grisuRound(buffer, len, delta, p2, one_frc, wp_w_frc);\n return len;\n }\n }\n\n return len;\n}\n\n// @ts-ignore: decorator\n@inline\nfunction genExponent(buffer: usize, k: i32): i32 {\n var sign = k < 0;\n if (sign) k = -k;\n var decimals = decimalCount32(k) + 1;\n utoa32_core(buffer, k, decimals);\n store(buffer, select(CharCode.MINUS, CharCode.PLUS, sign));\n return decimals;\n}\n\nfunction prettify(buffer: usize, length: i32, k: i32): i32 {\n if (!k) {\n store(buffer + (length << 1), CharCode.DOT | (CharCode._0 << 16));\n return length + 2;\n }\n\n var kk = length + k;\n if (length <= kk && kk <= 21) {\n // 1234e7 -> 12340000000\n for (let i = length; i < kk; ++i) {\n store(buffer + (i << 1), CharCode._0);\n }\n store(buffer + (kk << 1), CharCode.DOT | (CharCode._0 << 16));\n return kk + 2;\n } else if (kk > 0 && kk <= 21) {\n // 1234e-2 -> 12.34\n let ptr = buffer + (kk << 1);\n memory.copy(\n ptr + 2,\n ptr,\n -k << 1\n );\n store(buffer + (kk << 1), CharCode.DOT);\n return length + 1;\n } else if (-6 < kk && kk <= 0) {\n // 1234e-6 -> 0.001234\n let offset = 2 - kk;\n memory.copy(\n buffer + (offset << 1),\n buffer,\n length << 1\n );\n store(buffer, CharCode._0 | (CharCode.DOT << 16));\n for (let i = 2; i < offset; ++i) {\n store(buffer + (i << 1), CharCode._0);\n }\n return length + offset;\n } else if (length == 1) {\n // 1e30\n store(buffer, CharCode.e, 2);\n length = genExponent(buffer + 4, kk - 1);\n return length + 2;\n } else {\n let len = length << 1;\n memory.copy(\n buffer + 4,\n buffer + 2,\n len - 2\n );\n store(buffer, CharCode.DOT, 2);\n store(buffer + len, CharCode.e, 2);\n length += genExponent(buffer + len + 4, kk - 1);\n return length + 2;\n }\n}\n\nexport function dtoa_core(buffer: usize, value: f64): i32 {\n var sign = i32(value < 0);\n if (sign) {\n value = -value;\n store(buffer, CharCode.MINUS);\n }\n // assert(value > 0 && value <= 1.7976931348623157e308);\n var len = grisu2(value, buffer, sign);\n len = prettify(buffer + (sign << 1), len - sign, _K);\n return len + sign;\n}\n\nexport function dtoa(value: f64): String {\n if (value == 0) return "0.0";\n if (!isFinite(value)) {\n if (isNaN(value)) return "NaN";\n return select("-Infinity", "Infinity", value < 0);\n }\n var buffer = __alloc(MAX_DOUBLE_LENGTH << 1, idof());\n var length = dtoa_core(buffer, value);\n if (length == MAX_DOUBLE_LENGTH) return changetype(buffer);\n var result = changetype(buffer).substring(0, length);\n __free(buffer);\n return result;\n}\n\nexport function itoa_stream(buffer: usize, offset: usize, value: T): u32 {\n buffer += (offset << 1);\n if (!value) {\n store(buffer, CharCode._0);\n return 1;\n }\n var decimals: u32 = 0;\n if (isSigned()) {\n let sign = i32(value < 0);\n if (sign) value = changetype(-value);\n if (sizeof() <= 4) {\n decimals = decimalCount32(value) + sign;\n utoa32_core(buffer, value, decimals);\n } else {\n if (value <= u32.MAX_VALUE) {\n let val32 = value;\n decimals = decimalCount32(val32) + sign;\n utoa32_core(buffer, val32, decimals);\n } else {\n decimals = decimalCount64(value) + sign;\n utoa64_core(buffer, value, decimals);\n }\n }\n if (sign) store(buffer, CharCode.MINUS);\n } else {\n if (sizeof() <= 4) {\n decimals = decimalCount32(value);\n utoa32_core(buffer, value, decimals);\n } else {\n if (value <= u32.MAX_VALUE) {\n let val32 = value;\n decimals = decimalCount32(val32);\n utoa32_core(buffer, val32, decimals);\n } else {\n decimals = decimalCount64(value);\n utoa64_core(buffer, value, decimals);\n }\n }\n }\n return decimals;\n}\n\nexport function dtoa_stream(buffer: usize, offset: usize, value: f64): u32 {\n buffer += (offset << 1);\n if (value == 0.0) {\n store(buffer, CharCode._0);\n store(buffer, CharCode.DOT, 2);\n store(buffer, CharCode._0, 4);\n return 3;\n }\n if (!isFinite(value)) {\n if (isNaN(value)) {\n store(buffer, CharCode.N);\n store(buffer, CharCode.a, 2);\n store(buffer, CharCode.N, 4);\n return 3;\n } else {\n let sign = i32(value < 0);\n let len = 8 + sign;\n memory.copy(buffer, changetype(select("-Infinity", "Infinity", sign)), len << 1);\n return len;\n }\n }\n return dtoa_core(buffer, value);\n}\n',"util/sort":'import { compareImpl } from "./string";\n\n// @ts-ignore: decorator\n@inline\nexport function COMPARATOR(): (a: T, b: T) => i32 {\n if (isInteger()) {\n if (isSigned() && sizeof() <= 4) {\n return (a: T, b: T): i32 => (i32(a) - i32(b));\n } else {\n return (a: T, b: T): i32 => (i32(a > b) - i32(a < b));\n }\n } else if (isFloat()) {\n if (sizeof() == 4) {\n return (a: T, b: T): i32 => {\n var ia = reinterpret(f32(a));\n var ib = reinterpret(f32(b));\n ia ^= (ia >> 31) >>> 1;\n ib ^= (ib >> 31) >>> 1;\n return i32(ia > ib) - i32(ia < ib);\n };\n } else {\n return (a: T, b: T): i32 => {\n var ia = reinterpret(f64(a));\n var ib = reinterpret(f64(b));\n ia ^= (ia >> 63) >>> 1;\n ib ^= (ib >> 63) >>> 1;\n return i32(ia > ib) - i32(ia < ib);\n };\n }\n } else if (isString()) {\n return (a: T, b: T): i32 => {\n if (a === b || a === null || b === null) return 0;\n var alen = changetype(a).length;\n var blen = changetype(b).length;\n if (!alen && !blen) return 0;\n if (!alen) return -1;\n if (!blen) return 1;\n return compareImpl(changetype(a), 0, changetype(b), 0, min(alen, blen));\n };\n } else {\n return (a: T, b: T): i32 => (i32(a > b) - i32(a < b));\n }\n}\n\n// @ts-ignore: decorator\n@inline\nexport function SORT(\n dataStart: usize,\n length: i32,\n comparator: (a: T, b: T) => i32\n): void {\n if (isReference()) {\n // TODO replace this to faster stable sort (TimSort) when it implemented\n insertionSort(dataStart, length, comparator);\n } else {\n if (length < 256) {\n insertionSort(dataStart, length, comparator);\n } else {\n weakHeapSort(dataStart, length, comparator);\n }\n }\n}\n\nfunction insertionSort(\n dataStart: usize,\n length: i32,\n comparator: (a: T, b: T) => i32\n): void {\n for (let i = 0; i < length; i++) {\n let a: T = load(dataStart + (i << alignof())); // a = arr[i]\n let j = i - 1;\n while (j >= 0) {\n let b: T = load(dataStart + (j << alignof())); // b = arr[j]\n if (comparator(a, b) < 0) {\n store(dataStart + ((j-- + 1) << alignof()), b); // arr[j + 1] = b\n } else break;\n }\n store(dataStart + ((j + 1) << alignof()), a); // arr[j + 1] = a\n }\n}\n\nfunction weakHeapSort(\n dataStart: usize,\n length: i32,\n comparator: (a: T, b: T) => i32\n): void {\n const shift32 = alignof();\n\n var bitsetSize = (length + 31) >> 5 << shift32;\n var bitset = __alloc(bitsetSize, 0); // indexed in 32-bit chunks below\n memory.fill(bitset, 0, bitsetSize);\n\n // see: http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.21.1863&rep=rep1&type=pdf\n\n for (let i = length - 1; i > 0; i--) {\n let j = i;\n while ((j & 1) == (load(bitset + (j >> 6 << shift32)) >> (j >> 1 & 31) & 1)) j >>= 1;\n\n let p = j >> 1;\n let a: T = load(dataStart + (p << alignof())); // a = arr[p]\n let b: T = load(dataStart + (i << alignof())); // b = arr[i]\n if (comparator(a, b) < 0) {\n store(\n bitset + (i >> 5 << shift32),\n load(bitset + (i >> 5 << shift32)) ^ (1 << (i & 31))\n );\n store(dataStart + (i << alignof()), a); // arr[i] = a\n store(dataStart + (p << alignof()), b); // arr[p] = b\n }\n }\n\n for (let i = length - 1; i >= 2; i--) {\n let a: T = load(dataStart); // a = arr[0]\n store(dataStart, load(dataStart + (i << alignof()))); // arr[0] = arr[i]\n store(dataStart + (i << alignof()), a); // arr[i] = a\n\n let x = 1, y: i32;\n while ((y = (x << 1) + ((load(bitset + (x >> 5 << shift32)) >> (x & 31)) & 1)) < i) x = y;\n\n while (x > 0) {\n a = load(dataStart); // a = arr[0]\n let b: T = load(dataStart + (x << alignof())); // b = arr[x]\n\n if (comparator(a, b) < 0) {\n store(\n bitset + (x >> 5 << shift32),\n load(bitset + (x >> 5 << shift32)) ^ (1 << (x & 31))\n );\n store(dataStart + (x << alignof()), a); // arr[x] = a\n store(dataStart, b); // arr[0] = b\n }\n x >>= 1;\n }\n }\n\n __free(bitset);\n\n var t: T = load(dataStart, sizeof()); // t = arr[1]\n store(dataStart, load(dataStart), sizeof()); // arr[1] = arr[0]\n store(dataStart, t); // arr[0] = t\n}\n',"util/string":"export function compareImpl(str1: string, index1: usize, str2: string, index2: usize, len: usize): i32 {\n var result: i32 = 0;\n var ptr1 = changetype(str1) + (index1 << 1);\n var ptr2 = changetype(str2) + (index2 << 1);\n while (len && !(result = load(ptr1) - load(ptr2))) {\n --len, ptr1 += 2, ptr2 += 2;\n }\n return result;\n}\n\n// @ts-ignore: decorator\n@inline\nexport const enum CharCode {\n PLUS = 0x2B,\n MINUS = 0x2D,\n DOT = 0x2E,\n _0 = 0x30,\n _1 = 0x31,\n _2 = 0x32,\n _3 = 0x33,\n _4 = 0x34,\n _5 = 0x35,\n _6 = 0x36,\n _7 = 0x37,\n _8 = 0x38,\n _9 = 0x39,\n A = 0x41,\n B = 0x42,\n E = 0x45,\n N = 0x4E,\n O = 0x4F,\n X = 0x58,\n Z = 0x5a,\n a = 0x61,\n b = 0x62,\n e = 0x65,\n n = 0x6E,\n o = 0x6F,\n x = 0x78,\n z = 0x7A\n}\n\nexport function isWhiteSpaceOrLineTerminator(c: i32): bool {\n switch (c) {\n case 9: // \n case 10: // \n case 13: // \n case 11: // \n case 12: // \n case 32: // \n case 160: // \n case 8232: // \n case 8233: // \n case 65279: return true; // \n default: return false;\n }\n}\n\n/** Parses a string to an integer (usually), using the specified radix. */\nexport function strtol(str: string, radix: i32 = 0): T {\n var len: i32 = str.length;\n // @ts-ignore: cast\n if (!len) return NaN;\n\n var ptr = changetype(str) /* + HEAD -> offset */;\n var code = load(ptr);\n\n // determine sign\n // @ts-ignore: cast\n var sign: T = 1;\n // trim white spaces\n while (isWhiteSpaceOrLineTerminator(code)) {\n code = load(ptr += 2);\n --len;\n }\n if (code == CharCode.MINUS) {\n // @ts-ignore: cast\n if (!--len) return NaN;\n code = load(ptr += 2);\n // @ts-ignore: type\n sign = -1;\n } else if (code == CharCode.PLUS) {\n // @ts-ignore: cast\n if (!--len) return NaN;\n code = load(ptr += 2);\n }\n\n // determine radix\n if (!radix) {\n if (code == CharCode._0 && len > 2) {\n switch (load(ptr + 2)) {\n case CharCode.B:\n case CharCode.b: {\n ptr += 4; len -= 2;\n radix = 2;\n break;\n }\n case CharCode.O:\n case CharCode.o: {\n ptr += 4; len -= 2;\n radix = 8;\n break;\n }\n case CharCode.X:\n case CharCode.x: {\n ptr += 4; len -= 2;\n radix = 16;\n break;\n }\n default: radix = 10;\n }\n } else radix = 10;\n } else if (radix < 2 || radix > 36) {\n // @ts-ignore: cast\n return NaN;\n }\n\n // calculate value\n // @ts-ignore: type\n var num: T = 0;\n while (len--) {\n code = load(ptr);\n if (code >= CharCode._0 && code <= CharCode._9) {\n code -= CharCode._0;\n } else if (code >= CharCode.A && code <= CharCode.Z) {\n code -= CharCode.A - 10;\n } else if (code >= CharCode.a && code <= CharCode.z) {\n code -= CharCode.a - 10;\n } else break;\n if (code >= radix) break;\n // @ts-ignore: type\n num = num * radix + code;\n ptr += 2;\n }\n // @ts-ignore: type\n return sign * num;\n}\n\n// FIXME: naive implementation\nexport function strtod(str: string): f64 {\n var len: i32 = str.length;\n if (!len) return NaN;\n\n var ptr = changetype(str);\n var code = load(ptr);\n\n // determine sign\n var sign = 1.0;\n // trim white spaces\n while (isWhiteSpaceOrLineTerminator(code)) {\n code = load(ptr += 2);\n --len;\n }\n if (code == CharCode.MINUS) {\n if (!--len) return NaN;\n code = load(ptr += 2);\n sign = -1.0;\n } else if (code == CharCode.PLUS) {\n if (!--len) return NaN;\n code = load(ptr += 2);\n }\n\n // calculate value\n var num = 0.0;\n while (len--) {\n code = load(ptr);\n if (code == CharCode.DOT) {\n ptr += 2;\n let fac = 0.1; // precision :(\n while (len--) {\n code = load(ptr);\n if (code == CharCode.E || code == CharCode.e) {\n assert(false); // TODO\n }\n code -= CharCode._0;\n if (code > 9) break;\n num += code * fac;\n fac *= 0.1;\n ptr += 2;\n }\n break;\n }\n code -= CharCode._0;\n if (code >= 10) break;\n num = num * 10 + code;\n ptr += 2;\n }\n return sign * num;\n}\n",vector:"/** Vector abstraction. */\n@sealed @unmanaged\nexport abstract class V128 {\n}\n"}):(()=>{const n=path.join(".","..","std","assembly"),e=__webpack_require__(!function(){var n=new Error("Cannot find module 'glob'");throw n.code="MODULE_NOT_FOUND",n}()).sync("**/!(*.d).ts",{cwd:n}),t={};return e.forEach(e=>t[e.replace(/\.ts$/,"")]=fs.readFileSync(path.join(n,e),"utf8")),t})(),exports.definitionFiles=exports.isBundle?Object({assembly:'/**\n * Environment definitions for compiling AssemblyScript to WebAssembly using asc.\n * @module std/assembly\n *//***/\n\n/// \n\n// Types\n\n/** An 8-bit signed integer. */\ndeclare type i8 = number;\n/** A 16-bit signed integer. */\ndeclare type i16 = number;\n/** A 32-bit signed integer. */\ndeclare type i32 = number;\n/** A 64-bit signed integer. */\ndeclare type i64 = number;\n/** A 32-bit signed integer when targeting 32-bit WebAssembly or a 64-bit signed integer when targeting 64-bit WebAssembly. */\ndeclare type isize = number;\n/** An 8-bit unsigned integer. */\ndeclare type u8 = number;\n/** A 16-bit unsigned integer. */\ndeclare type u16 = number;\n/** A 32-bit unsigned integer. */\ndeclare type u32 = number;\n/** A 64-bit unsigned integer. */\ndeclare type u64 = number;\n/** A 32-bit unsigned integer when targeting 32-bit WebAssembly or a 64-bit unsigned integer when targeting 64-bit WebAssembly. */\ndeclare type usize = number;\n/** A 1-bit unsigned integer. */\ndeclare type bool = boolean | number;\n/** A 32-bit float. */\ndeclare type f32 = number;\n/** A 64-bit float. */\ndeclare type f64 = number;\n/** A 128-bit vector. */\ndeclare type v128 = object;\n\n// Compiler hints\n\n/** Compiler target. 0 = JS, 1 = WASM32, 2 = WASM64. */\ndeclare const ASC_TARGET: i32;\n/** Provided noAssert option. */\ndeclare const ASC_NO_ASSERT: bool;\n/** Provided memoryBase option. */\ndeclare const ASC_MEMORY_BASE: i32;\n/** Provided optimizeLevel option. */\ndeclare const ASC_OPTIMIZE_LEVEL: i32;\n/** Provided shrinkLevel option. */\ndeclare const ASC_SHRINK_LEVEL: i32;\n/** Whether the mutable global feature is enabled. */\ndeclare const ASC_FEATURE_MUTABLE_GLOBAL: bool;\n/** Whether the sign extension feature is enabled. */\ndeclare const ASC_FEATURE_SIGN_EXTENSION: bool;\n/** Whether the bulk memory feature is enabled. */\ndeclare const ASC_FEATURE_BULK_MEMORY: bool;\n/** Whether the SIMD feature is enabled. */\ndeclare const ASC_FEATURE_SIMD: bool;\n/** Whether the threads feature is enabled. */\ndeclare const ASC_FEATURE_THREADS: bool;\n\n// Builtins\n\n/** Performs the sign-agnostic count leading zero bits operation on a 32-bit or 64-bit integer. All zero bits are considered leading if the value is zero. */\ndeclare function clz(value: T): T;\n/** Performs the sign-agnostic count tailing zero bits operation on a 32-bit or 64-bit integer. All zero bits are considered trailing if the value is zero. */\ndeclare function ctz(value: T): T;\n/** Performs the sign-agnostic count number of one bits operation on a 32-bit or 64-bit integer. */\ndeclare function popcnt(value: T): T;\n/** Performs the sign-agnostic rotate left operation on a 32-bit or 64-bit integer. */\ndeclare function rotl(value: T, shift: T): T;\n/** Performs the sign-agnostic rotate right operation on a 32-bit or 64-bit integer. */\ndeclare function rotr(value: T, shift: T): T;\n/** Computes the absolute value of an integer or float. */\ndeclare function abs(value: T): T;\n/** Determines the maximum of two integers or floats. If either operand is `NaN`, returns `NaN`. */\ndeclare function max(left: T, right: T): T;\n/** Determines the minimum of two integers or floats. If either operand is `NaN`, returns `NaN`. */\ndeclare function min(left: T, right: T): T;\n/** Performs the ceiling operation on a 32-bit or 64-bit float. */\ndeclare function ceil(value: T): T;\n/** Composes a 32-bit or 64-bit float from the magnitude of `x` and the sign of `y`. */\ndeclare function copysign(x: T, y: T): T;\n/** Performs the floor operation on a 32-bit or 64-bit float. */\ndeclare function floor(value: T): T;\n/** Rounds to the nearest integer tied to even of a 32-bit or 64-bit float. */\ndeclare function nearest(value: T): T;\n/** Reinterprets the bits of the specified value as type `T`. Valid reinterpretations are u32/i32 to/from f32 and u64/i64 to/from f64. */\ndeclare function reinterpret(value: number): T;\n/** Selects one of two pre-evaluated values depending on the condition. */\ndeclare function select(ifTrue: T, ifFalse: T, condition: bool): T;\n/** Calculates the square root of a 32-bit or 64-bit float. */\ndeclare function sqrt(value: T): T;\n/** Rounds to the nearest integer towards zero of a 32-bit or 64-bit float. */\ndeclare function trunc(value: T): T;\n/** Loads a value of the specified type from memory. Equivalent to dereferncing a pointer in other languages. */\ndeclare function load(ptr: usize, immOffset?: usize, immAlign?: usize): T;\n/** Stores a value of the specified type to memory. Equivalent to dereferencing a pointer in other languages when assigning a value. */\ndeclare function store(ptr: usize, value: any, immOffset?: usize, immAlign?: usize): void;\n/** Emits an unreachable operation that results in a runtime error when executed. Both a statement and an expression of any type. */\ndeclare function unreachable(): any; // sic\n\n/** NaN (not a number) as a 32-bit or 64-bit float depending on context. */\ndeclare const NaN: f32 | f64;\n/** Positive infinity as a 32-bit or 64-bit float depending on context. */\ndeclare const Infinity: f32 | f64;\n/** Heap base offset. */\ndeclare const __heap_base: usize;\n/** Determines the byte size of the specified underlying core type. Compiles to a constant. */\ndeclare function sizeof(): usize;\n/** Determines the alignment (log2) of the specified underlying core type. Compiles to a constant. */\ndeclare function alignof(): usize;\n/** Determines the end offset of the given class type. Compiles to a constant. */\ndeclare function offsetof(): usize;\n/** Determines the offset of the specified field within the given class type. Compiles to a constant. */\ndeclare function offsetof(fieldName: keyof T | string): usize;\n/** Determines the offset of the specified field within the given class type. Returns the class type\'s end offset if field name has been omitted. Compiles to a constant. */\ndeclare function offsetof(fieldName?: string): usize;\n/** Determines the unique runtime id of a class type. Compiles to a constant. */\ndeclare function idof(): u32;\n/** Changes the type of any value of `usize` kind to another one of `usize` kind. Useful for casting class instances to their pointer values and vice-versa. Beware that this is unsafe.*/\ndeclare function changetype(value: any): T;\n/** Explicitly requests no bounds checks on the provided expression. Useful for array accesses. */\ndeclare function unchecked(value: T): T;\n/** Emits a `call_indirect` instruction, calling the specified function in the function table by index with the specified arguments. Does result in a runtime error if the arguments do not match the called function. */\ndeclare function call_indirect(target: Function | u32, ...args: any[]): T;\n/** Emits a `call` instruction, calling the specified function in the function table directly with the specified arguments. Function index must be a compile-time constant. */\ndeclare function call_direct(target: Function | u32, ...args: any[]): T;\n/** Instantiates a new instance of `T` using the specified constructor arguments. */\ndeclare function instantiate(...args: any[]): T;\n/** Tests if a 32-bit or 64-bit float is `NaN`. */\ndeclare function isNaN(value: T): bool;\n/** Tests if a 32-bit or 64-bit float is finite, that is not `NaN` or +/-`Infinity`. */\ndeclare function isFinite(value: T): bool;\n/** Tests if the specified type *or* expression is of an integer type and not a reference. Compiles to a constant. */\ndeclare function isInteger(value?: any): value is number;\n/** Tests if the specified type *or* expression is of a float type. Compiles to a constant. */\ndeclare function isFloat(value?: any): value is number;\n/** Tests if the specified type *or* expression is of a boolean type. */\ndeclare function isBoolean(value?: any): value is number;\n/** Tests if the specified type *or* expression can represent negative numbers. Compiles to a constant. */\ndeclare function isSigned(value?: any): value is number;\n/** Tests if the specified type *or* expression is of a reference type. Compiles to a constant. */\ndeclare function isReference(value?: any): value is object | string;\n/** Tests if the specified type *or* expression can be used as a string. Compiles to a constant. */\ndeclare function isString(value?: any): value is string | String;\n/** Tests if the specified type *or* expression can be used as an array. Compiles to a constant. */\ndeclare function isArray(value?: any): value is Array;\n/** Tests if the specified type *or* expression can be used as an array like object. Compiles to a constant. */\ndeclare function isArrayLike(value?: any): value is ArrayLike;\n/** Tests if the specified type *or* expression is of a function type. Compiles to a constant. */\ndeclare function isFunction(value?: any): value is (...args: any) => any;\n/** Tests if the specified type *or* expression is of a nullable reference type. Compiles to a constant. */\ndeclare function isNullable(value?: any): bool;\n/** Tests if the specified expression resolves to a defined element. Compiles to a constant. */\ndeclare function isDefined(expression: any): bool;\n/** Tests if the specified expression evaluates to a constant value. Compiles to a constant. */\ndeclare function isConstant(expression: any): bool;\n/** Tests if the specified type *or* expression is of a managed type. Compiles to a constant. */\ndeclare function isManaged(value?: any): bool;\n/** Traps if the specified value is not true-ish, otherwise returns the (non-nullable) value. */\ndeclare function assert(isTrueish: T, message?: string): T & object; // any better way to model `: T != null`?\n/** Parses an integer string to a 64-bit float. */\ndeclare function parseInt(str: string, radix?: i32): f64;\n/** Parses a string to a 64-bit float. */\ndeclare function parseFloat(str: string): f64;\n/** Returns the 64-bit floating-point remainder of `x/y`. */\ndeclare function fmod(x: f64, y: f64): f64;\n/** Returns the 32-bit floating-point remainder of `x/y`. */\ndeclare function fmodf(x: f32, y: f32): f32;\n\n/** Atomic operations. */\ndeclare namespace atomic {\n /** Atomically loads an integer value from memory and returns it. */\n export function load(offset: usize, immOffset?: usize): T;\n /** Atomically stores an integer value to memory. */\n export function store(offset: usize, value: T, immOffset?: usize): void;\n /** Atomically adds an integer value in memory. */\n export function add(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically subtracts an integer value in memory. */\n export function sub(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically performs a bitwise AND operation on an integer value in memory. */\n export function and(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically performs a bitwise OR operation on an integer value in memory. */\n export function or(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically performs a bitwise XOR operation on an integer value in memory. */\n export function xor(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically exchanges an integer value in memory. */\n export function xchg(ptr: usize, value: T, immOffset?: usize): T;\n /** Atomically compares and exchanges an integer value in memory if the condition is met. */\n export function cmpxchg(ptr: usize, expected: T, replacement: T, immOffset?: usize): T;\n /** Performs a wait operation on an address in memory suspending this agent if the integer condition is met. */\n export function wait(ptr: usize, expected: T, timeout: i64): AtomicWaitResult;\n /** Performs a notify operation on an address in memory waking up suspended agents. */\n export function notify(ptr: usize, count: i32): i32;\n}\n\n/** Describes the result of an atomic wait operation. */\ndeclare enum AtomicWaitResult {\n /** Woken by another agent. */\n OK,\n /** Loaded value did not match the expected value. */\n NOT_EQUAL,\n /** Not woken before the timeout expired. */\n TIMED_OUT\n}\n\n/** Converts any other numeric value to an 8-bit signed integer. */\ndeclare function i8(value: any): i8;\ndeclare namespace i8 {\n /** Smallest representable value. */\n export const MIN_VALUE: i8;\n /** Largest representable value. */\n export const MAX_VALUE: i8;\n}\n/** Converts any other numeric value to a 16-bit signed integer. */\ndeclare function i16(value: any): i8;\ndeclare namespace i16 {\n /** Smallest representable value. */\n export const MIN_VALUE: i16;\n /** Largest representable value. */\n export const MAX_VALUE: i16;\n}\n/** Converts any other numeric value to a 32-bit signed integer. */\ndeclare function i32(value: any): i32;\ndeclare namespace i32 {\n /** Smallest representable value. */\n export const MIN_VALUE: i32;\n /** Largest representable value. */\n export const MAX_VALUE: i32;\n /** Loads an 8-bit signed integer value from memory and returns it as a 32-bit integer. */\n export function load8_s(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n /** Loads an 8-bit unsigned integer value from memory and returns it as a 32-bit integer. */\n export function load8_u(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n /** Loads a 16-bit signed integer value from memory and returns it as a 32-bit integer. */\n export function load16_s(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n /** Loads a 16-bit unsigned integer value from memory and returns it as a 32-bit integer. */\n export function load16_u(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n /** Loads a 32-bit integer value from memory. */\n export function load(offset: usize, immOffset?: usize, immAlign?: usize): i32;\n /** Stores a 32-bit integer value to memory as an 8-bit integer. */\n export function store8(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n /** Stores a 32-bit integer value to memory as a 16-bit integer. */\n export function store16(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n /** Stores a 32-bit integer value to memory. */\n export function store(offset: usize, value: i32, immOffset?: usize, immAlign?: usize): void;\n /** Atomic 32-bit integer operations. */\n export namespace atomic {\n /** Atomically loads an 8-bit unsigned integer value from memory and returns it as a 32-bit integer. */\n export function load8_u(offset: usize, immOffset?: usize): i32;\n /** Atomically loads a 16-bit unsigned integer value from memory and returns it as a 32-bit integer. */\n export function load16_u(offset: usize, immOffset?: usize): i32;\n /** Atomically loads a 32-bit integer value from memory and returns it. */\n export function load(offset: usize, immOffset?: usize): i32;\n /** Atomically stores a 32-bit integer value to memory as an 8-bit integer. */\n export function store8(offset: usize, value: i32, immOffset?: usize): void;\n /** Atomically stores a 32-bit integer value to memory as a 16-bit integer. */\n export function store16(offset: usize, value: i32, immOffset?: usize): void;\n /** Atomically stores a 32-bit integer value to memory. */\n export function store(offset: usize, value: i32, immOffset?: usize): void;\n /** Performs a wait operation on a 32-bit integer value in memory suspending this agent if the condition is met. */\n export function wait(ptr: usize, expected: i32, timeout: i64): AtomicWaitResult;\n /** Atomic 32-bit integer read-modify-write operations on 8-bit values. */\n export namespace rmw8 {\n /** Atomically adds an 8-bit unsigned integer value in memory. */\n export function add_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically subtracts an 8-bit unsigned integer value in memory. */\n export function sub_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise AND operation an 8-bit unsigned integer value in memory. */\n export function and_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise OR operation an 8-bit unsigned integer value in memory. */\n export function or_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise XOR operation an 8-bit unsigned integer value in memory. */\n export function xor_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically exchanges an 8-bit unsigned integer value in memory. */\n export function xchg_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically compares and exchanges an 8-bit unsigned integer value in memory if the condition is met. */\n export function cmpxchg_u(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n /** Atomic 32-bit integer read-modify-write operations on 16-bit values. */\n export namespace rmw16 {\n /** Atomically adds a 16-bit unsigned integer value in memory. */\n export function add_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically adds a 16-bit unsigned integer value in memory. */\n export function sub_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise AND operation a 16-bit unsigned integer value in memory. */\n export function and_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise OR operation a 16-bit unsigned integer value in memory. */\n export function or_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise XOR operation a 16-bit unsigned integer value in memory. */\n export function xor_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically exchanges a 16-bit unsigned integer value in memory. */\n export function xchg_u(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically compares and exchanges a 16-bit unsigned integer value in memory if the condition is met. */\n export function cmpxchg_u(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n /** Atomic 32-bit integer read-modify-write operations. */\n export namespace rmw {\n /** Atomically adds a 32-bit integer value in memory. */\n export function add(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically subtracts a 32-bit integer value in memory. */\n export function sub(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise AND operation a 32-bit integer value in memory. */\n export function and(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise OR operation a 32-bit integer value in memory. */\n export function or(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically performs a bitwise XOR operation a 32-bit integer value in memory. */\n export function xor(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically exchanges a 32-bit integer value in memory. */\n export function xchg(offset: usize, value: i32, immOffset?: usize): i32;\n /** Atomically compares and exchanges a 32-bit integer value in memory if the condition is met. */\n export function cmpxchg(offset: usize, expected: i32, replacement: i32, immOffset?: usize): i32;\n }\n }\n}\n/** Converts any other numeric value to a 64-bit signed integer. */\ndeclare function i64(value: any): i64;\ndeclare namespace i64 {\n /** Smallest representable value. */\n export const MIN_VALUE: i64;\n /** Largest representable value. */\n export const MAX_VALUE: i64;\n /** Loads an 8-bit signed integer value from memory and returns it as a 64-bit integer. */\n export function load8_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads an 8-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load8_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads a 16-bit signed integer value from memory and returns it as a 64-bit integer. */\n export function load16_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads a 16-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load16_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads a 32-bit signed integer value from memory and returns it as a 64-bit integer. */\n export function load32_s(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads a 32-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load32_u(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Loads a 64-bit unsigned integer value from memory. */\n export function load(offset: usize, immOffset?: usize, immAlign?: usize): i64;\n /** Stores a 64-bit integer value to memory as an 8-bit integer. */\n export function store8(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n /** Stores a 64-bit integer value to memory as a 16-bit integer. */\n export function store16(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n /** Stores a 64-bit integer value to memory as a 32-bit integer. */\n export function store32(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n /** Stores a 64-bit integer value to memory. */\n export function store(offset: usize, value: i64, immOffset?: usize, immAlign?: usize): void;\n /** Atomic 64-bit integer operations. */\n export namespace atomic {\n /** Atomically loads an 8-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load8_u(offset: usize, immOffset?: usize): i64;\n /** Atomically loads a 16-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load16_u(offset: usize, immOffset?: usize): i64;\n /** Atomically loads a 32-bit unsigned integer value from memory and returns it as a 64-bit integer. */\n export function load32_u(offset: usize, immOffset?: usize): i64;\n /** Atomically loads a 64-bit integer value from memory and returns it. */\n export function load(offset: usize, immOffset?: usize): i64;\n /** Atomically stores a 64-bit integer value to memory as an 8-bit integer. */\n export function store8(offset: usize, value: i64, immOffset?: usize): void;\n /** Atomically stores a 64-bit integer value to memory as a 16-bit integer. */\n export function store16(offset: usize, value: i64, immOffset?: usize): void;\n /** Atomically stores a 64-bit integer value to memory as a 32-bit integer. */\n export function store32(offset: usize, value: i64, immOffset?: usize): void;\n /** Atomically stores a 64-bit integer value to memory. */\n export function store(offset: usize, value: i64, immOffset?: usize): void;\n /** Performs a wait operation on a 64-bit integer value in memory suspending this agent if the condition is met. */\n export function wait(ptr: usize, expected: i64, timeout: i64): AtomicWaitResult;\n /** Atomic 64-bit integer read-modify-write operations on 8-bit values. */\n export namespace rmw8 {\n /** Atomically adds an 8-bit unsigned integer value in memory. */\n export function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically subtracts an 8-bit unsigned integer value in memory. */\n export function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise AND operation on an 8-bit unsigned integer value in memory. */\n export function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise OR operation on an 8-bit unsigned integer value in memory. */\n export function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise XOR operation on an 8-bit unsigned integer value in memory. */\n export function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically exchanges an 8-bit unsigned integer value in memory. */\n export function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically compares and exchanges an 8-bit unsigned integer value in memory if the condition is met. */\n export function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n /** Atomic 64-bit integer read-modify-write operations on 16-bit values. */\n export namespace rmw16 {\n /** Atomically adds a 16-bit unsigned integer value in memory. */\n export function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically subtracts a 16-bit unsigned integer value in memory. */\n export function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise AND operation on a 16-bit unsigned integer value in memory. */\n export function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise OR operation on a 16-bit unsigned integer value in memory. */\n export function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise XOR operation on a 16-bit unsigned integer value in memory. */\n export function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically exchanges a 16-bit unsigned integer value in memory. */\n export function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically compares and exchanges a 16-bit unsigned integer value in memory if the condition is met. */\n export function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n /** Atomic 64-bit integer read-modify-write operations on 32-bit values. */\n export namespace rmw32 {\n /** Atomically adds a 32-bit unsigned integer value in memory. */\n export function add_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically subtracts a 32-bit unsigned integer value in memory. */\n export function sub_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise AND operation on a 32-bit unsigned integer value in memory. */\n export function and_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise OR operation on a 32-bit unsigned integer value in memory. */\n export function or_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise XOR operation on a 32-bit unsigned integer value in memory. */\n export function xor_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically exchanges a 32-bit unsigned integer value in memory. */\n export function xchg_u(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically compares and exchanges a 32-bit unsigned integer value in memory if the condition is met. */\n export function cmpxchg_u(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n /** Atomic 64-bit integer read-modify-write operations. */\n export namespace rmw {\n /** Atomically adds a 64-bit integer value in memory. */\n export function add(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically subtracts a 64-bit integer value in memory. */\n export function sub(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise AND operation on a 64-bit integer value in memory. */\n export function and(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise OR operation on a 64-bit integer value in memory. */\n export function or(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically performs a bitwise XOR operation on a 64-bit integer value in memory. */\n export function xor(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically exchanges a 64-bit integer value in memory. */\n export function xchg(offset: usize, value: i64, immOffset?: usize): i64;\n /** Atomically compares and exchanges a 64-bit integer value in memory if the condition is met. */\n export function cmpxchg(offset: usize, expected: i64, replacement: i64, immOffset?: usize): i64;\n }\n }\n}\n/** Converts any other numeric value to a 32-bit (in WASM32) respectivel 64-bit (in WASM64) signed integer. */\ndeclare var isize: typeof i32 | typeof i64;\n/** Converts any other numeric value to an 8-bit unsigned integer. */\ndeclare function u8(value: any): i8;\ndeclare namespace u8 {\n /** Smallest representable value. */\n export const MIN_VALUE: u8;\n /** Largest representable value. */\n export const MAX_VALUE: u8;\n}\n/** Converts any other numeric value to a 16-bit unsigned integer. */\ndeclare function u16(value: any): i8;\ndeclare namespace u16 {\n /** Smallest representable value. */\n export const MIN_VALUE: u16;\n /** Largest representable value. */\n export const MAX_VALUE: u16;\n}\n/** Converts any other numeric value to a 32-bit unsigned integer. */\ndeclare function u32(value: any): i32;\ndeclare namespace u32 {\n /** Smallest representable value. */\n export const MIN_VALUE: u32;\n /** Largest representable value. */\n export const MAX_VALUE: u32;\n}\n/** Converts any other numeric value to a 64-bit unsigned integer. */\ndeclare function u64(value: any): i64;\ndeclare namespace u64 {\n /** Smallest representable value. */\n export const MIN_VALUE: u64;\n /** Largest representable value. */\n export const MAX_VALUE: u64;\n}\n/** Converts any other numeric value to a 32-bit (in WASM32) respectivel 64-bit (in WASM64) unsigned integer. */\ndeclare var usize: typeof u32 | typeof u64;\n/** Converts any other numeric value to a 1-bit unsigned integer. */\ndeclare function bool(value: any): bool;\ndeclare namespace bool {\n /** Smallest representable value. */\n export const MIN_VALUE: bool;\n /** Largest representable value. */\n export const MAX_VALUE: bool;\n}\n/** Converts any other numeric value to a 32-bit float. */\ndeclare function f32(value: any): f32;\ndeclare namespace f32 {\n /** Smallest representable value. */\n export const MIN_VALUE: f32;\n /** Largest representable value. */\n export const MAX_VALUE: f32;\n /** Smallest normalized positive value. */\n export const MIN_POSITIVE_VALUE: f32;\n /** Smallest safely representable integer value. */\n export const MIN_SAFE_INTEGER: f32;\n /** Largest safely representable integer value. */\n export const MAX_SAFE_INTEGER: f32;\n /** Difference between 1 and the smallest representable value greater than 1. */\n export const EPSILON: f32;\n /** Loads a 32-bit float from memory. */\n export function load(offset: usize, immOffset?: usize, immAlign?: usize): f32;\n /** Stores a 32-bit float to memory. */\n export function store(offset: usize, value: f32, immOffset?: usize, immAlign?: usize): void;\n}\n/** Converts any other numeric value to a 64-bit float. */\ndeclare function f64(value: any): f64;\ndeclare namespace f64 {\n /** Smallest representable value. */\n export const MIN_VALUE: f64;\n /** Largest representable value. */\n export const MAX_VALUE: f64;\n /** Smallest normalized positive value. */\n export const MIN_POSITIVE_VALUE: f64;\n /** Smallest safely representable integer value. */\n export const MIN_SAFE_INTEGER: f64;\n /** Largest safely representable integer value. */\n export const MAX_SAFE_INTEGER: f64;\n /** Difference between 1 and the smallest representable value greater than 1. */\n export const EPSILON: f64;\n /** Loads a 64-bit float from memory. */\n export function load(offset: usize, immOffset?: usize, immAlign?: usize): f64;\n /** Stores a 64-bit float to memory. */\n export function store(offset: usize, value: f64, immOffset?: usize, immAlign?: usize): void;\n}\n/** Initializes a 128-bit vector from sixteen 8-bit integer values. Arguments must be compile-time constants. */\ndeclare function v128(a: i8, b: i8, c: i8, d: i8, e: i8, f: i8, g: i8, h: i8, i: i8, j: i8, k: i8, l: i8, m: i8, n: i8, o: i8, p: i8): v128;\ndeclare namespace v128 {\n /** Creates a 128-bit vector with identical lanes. */\n export function splat(x: T): v128;\n /** Extracts one lane from a 128-bit vector as a scalar. */\n export function extract_lane(x: v128, idx: u8): T;\n /** Replaces one lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: T): v128;\n /** Selects lanes from either 128-bit vector according to the specified lane indexes. */\n export function shuffle(a: v128, b: v128, ...lanes: u8[]): v128;\n /** Loads a 128-bit vector from memory. */\n export function load(offset: usize, immOffset?: usize, immAlign?: usize): v128;\n /** Stores a 128-bit vector to memory. */\n export function store(offset: usize, value: v128, immOffset?: usize, immAlign?: usize): void;\n /** Adds each lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128; // except i64\n /** Divides each lane of two 128-bit vectors. */\n export function div(a: v128, b: v128): v128;\n /** Negates each lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Adds each lane of two 128-bit vectors using saturation. */\n export function add_saturate(a: v128, b: v128): v128;\n /** Subtracts each lane of two 128-bit vectors using saturation. */\n export function sub_saturate(a: v128, b: v128): v128;\n /** Performs a bitwise left shift on each lane of a 128-bit vector by a scalar. */\n export function shl(a: v128, b: i32): v128;\n /** Performs a bitwise right shift on each lane of a 128-bit vector by a scalar. */\n export function shr(a: v128, b: i32): v128;\n /** Performs the bitwise AND operation on each lane of two 128-bit vectors. */\n export function and(a: v128, b: v128): v128;\n /** Performs the bitwise OR operation on each lane of two 128-bit vectors. */\n export function or(a: v128, b: v128): v128;\n /** Performs the bitwise XOR operation on each lane of two 128-bit vectors. */\n export function xor(a: v128, b: v128): v128;\n /** Performs the bitwise NOT operation on each lane of a 128-bit vector. */\n export function not(a: v128): v128;\n /** Selects bits of either 128-bit vector according to the specified mask. */\n export function bitselect(v1: v128, v2: v128, mask: v128): v128;\n /** Reduces a 128-bit vector to a scalar indicating whether any lane is considered `true`. */\n export function any_true(a: v128): bool;\n /** Reduces a 128-bit vector to a scalar indicating whether all lanes are considered `true`. */\n export function all_true(a: v128): bool;\n /** Computes the minimum of each lane of two 128-bit vectors. */\n export function min(a: v128, b: v128): v128;\n /** Computes the maximum of each lane of two 128-bit vectors. */\n export function max(a: v128, b: v128): v128;\n /** Computes the absolute value of each lane of a 128-bit vector. */\n export function abs(a: v128): v128;\n /** Computes the square root of each lane of a 128-bit vector. */\n export function sqrt(a: v128): v128;\n /** Computes which lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which lanes of the first 128-bit vector are less than those of the second. */\n export function lt(a: v128, b: v128): v128;\n /** Computes which lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le(a: v128, b: v128): v128;\n /** Computes which lanes of the first 128-bit vector are greater than those of the second. */\n export function gt(a: v128, b: v128): v128;\n /** Computes which lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge(a: v128, b: v128): v128;\n /** Converts each lane of a 128-bit vector from integer to floating point. */\n export function convert(a: v128): v128;\n /** Truncates each lane of a 128-bit vector from floating point to integer with saturation. */\n export function trunc(a: v128): v128;\n}\n/** Initializes a 128-bit vector from sixteen 8-bit integer values. Arguments must be compile-time constants. */\ndeclare function i8x16(a: i8, b: i8, c: i8, d: i8, e: i8, f: i8, g: i8, h: i8, i: i8, j: i8, k: i8, l: i8, m: i8, n: i8, o: i8, p: i8): v128;\ndeclare namespace i8x16 {\n /** Creates a vector with sixteen identical 8-bit integer lanes. */\n export function splat(x: i8): v128;\n /** Extracts one 8-bit integer lane from a 128-bit vector as a signed scalar. */\n export function extract_lane_s(x: v128, idx: u8): i8;\n /** Extracts one 8-bit integer lane from a 128-bit vector as an unsigned scalar. */\n export function extract_lane_u(x: v128, idx: u8): u8;\n /** Replaces one 8-bit integer lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: i8): v128;\n /** Adds each 8-bit integer lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 8-bit integer lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 8-bit integer lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Negates each 8-bit integer lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Adds each 8-bit integer lane of two 128-bit vectors using signed saturation. */\n export function add_saturate_s(a: v128, b: v128): v128;\n /** Adds each 8-bit integer lane of two 128-bit vectors using unsigned saturation. */\n export function add_saturate_u(a: v128, b: v128): v128;\n /** Subtracts each 8-bit integer lane of two 128-bit vectors using signed saturation. */\n export function sub_saturate_s(a: v128, b: v128): v128;\n /** Subtracts each 8-bit integer lane of two 128-bit vectors using unsigned saturation. */\n export function sub_saturate_u(a: v128, b: v128): v128;\n /** Performs a bitwise left shift on each 8-bit integer lane of a 128-bit vector by a scalar. */\n export function shl(a: v128, b: i32): v128;\n /** Performs a bitwise arithmetic right shift on each 8-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_s(a: v128, b: i32): v128;\n /** Performs a bitwise logical right shift on each 8-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_u(a: v128, b: i32): v128;\n /** Reduces a 128-bit vector to a scalar indicating whether any 8-bit integer lane is considered `true`. */\n export function any_true(a: v128): bool;\n /** Reduces a 128-bit vector to a scalar indicating whether all 8-bit integer lanes are considered `true`. */\n export function all_true(a: v128): bool;\n /** Computes which 8-bit integer lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which 8-bit integer lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which 8-bit signed integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_s(a: v128, b: v128): v128;\n /** Computes which 8-bit unsigned integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_u(a: v128, b: v128): v128;\n /** Computes which 8-bit signed integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_s(a: v128, b: v128): v128;\n /** Computes which 8-bit unsigned integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_u(a: v128, b: v128): v128;\n /** Computes which 8-bit signed integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_s(a: v128, b: v128): v128;\n /** Computes which 8-bit unsigned integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_u(a: v128, b: v128): v128;\n /** Computes which 8-bit signed integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_s(a: v128, b: v128): v128;\n /** Computes which 8-bit unsigned integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_u(a: v128, b: v128): v128;\n}\n/** Initializes a 128-bit vector from eight 16-bit integer values. Arguments must be compile-time constants. */\ndeclare function i16x8(a: i16, b: i16, c: i16, d: i16, e: i16, f: i16, g: i16, h: i16): v128;\ndeclare namespace i16x8 {\n /** Creates a vector with eight identical 16-bit integer lanes. */\n export function splat(x: i16): v128;\n /** Extracts one 16-bit integer lane from a 128-bit vector as a signed scalar. */\n export function extract_lane_s(x: v128, idx: u8): i16;\n /** Extracts one 16-bit integer lane from a 128-bit vector as an unsigned scalar. */\n export function extract_lane_u(x: v128, idx: u8): u16;\n /** Replaces one 16-bit integer lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: i16): v128;\n /** Adds each 16-bit integer lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 16-bit integer lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 16-bit integer lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Negates each 16-bit integer lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Adds each 16-bit integer lane of two 128-bit vectors using signed saturation. */\n export function add_saturate_s(a: v128, b: v128): v128;\n /** Adds each 16-bit integer lane of two 128-bit vectors using unsigned saturation. */\n export function add_saturate_u(a: v128, b: v128): v128;\n /** Subtracts each 16-bit integer lane of two 128-bit vectors using signed saturation. */\n export function sub_saturate_s(a: v128, b: v128): v128;\n /** Subtracts each 16-bit integer lane of two 128-bit vectors using unsigned saturation. */\n export function sub_saturate_u(a: v128, b: v128): v128;\n /** Performs a bitwise left shift on each 16-bit integer lane of a 128-bit vector by a scalar. */\n export function shl(a: v128, b: i32): v128;\n /** Performs a bitwise arithmetic right shift each 16-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_s(a: v128, b: i32): v128;\n /** Performs a bitwise logical right shift on each 16-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_u(a: v128, b: i32): v128;\n /** Reduces a 128-bit vector to a scalar indicating whether any 16-bit integer lane is considered `true`. */\n export function any_true(a: v128): bool;\n /** Reduces a 128-bit vector to a scalar indicating whether all 16-bit integer lanes are considered `true`. */\n export function all_true(a: v128): bool;\n /** Computes which 16-bit integer lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which 16-bit integer lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which 16-bit signed integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_s(a: v128, b: v128): v128;\n /** Computes which 16-bit unsigned integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_u(a: v128, b: v128): v128;\n /** Computes which 16-bit signed integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_s(a: v128, b: v128): v128;\n /** Computes which 16-bit unsigned integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_u(a: v128, b: v128): v128;\n /** Computes which 16-bit signed integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_s(a: v128, b: v128): v128;\n /** Computes which 16-bit unsigned integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_u(a: v128, b: v128): v128;\n /** Computes which 16-bit signed integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_s(a: v128, b: v128): v128;\n /** Computes which 16-bit unsigned integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_u(a: v128, b: v128): v128;\n}\n/** Initializes a 128-bit vector from four 32-bit integer values. Arguments must be compile-time constants. */\ndeclare function i32x4(a: i32, b: i32, c: i32, d: i32): v128;\ndeclare namespace i32x4 {\n /** Creates a 128-bit vector with four identical 32-bit integer lanes. */\n export function splat(x: i32): v128;\n /** Extracts one 32-bit integer lane from a 128-bit vector as a scalar. */\n export function extract_lane(x: v128, idx: u8): i32;\n /** Replaces one 32-bit integer lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: i32): v128;\n /** Adds each 32-bit integer lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 32-bit integer lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 32-bit integer lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Negates each 32-bit integer lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Performs a bitwise left shift on each 32-bit integer lane of a 128-bit vector by a scalar. */\n export function shl(a: v128, b: i32): v128;\n /** Performs a bitwise arithmetic right shift on each 32-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_s(a: v128, b: i32): v128;\n /** Performs a bitwise logical right shift on each 32-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_u(a: v128, b: i32): v128;\n /** Reduces a 128-bit vector to a scalar indicating whether any 32-bit integer lane is considered `true`. */\n export function any_true(a: v128): bool;\n /** Reduces a 128-bit vector to a scalar indicating whether all 32-bit integer lanes are considered `true`. */\n export function all_true(a: v128): bool;\n /** Computes which 32-bit integer lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which 32-bit integer lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which 32-bit signed integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_s(a: v128, b: v128): v128;\n /** Computes which 32-bit unsigned integer lanes of the first 128-bit vector are less than those of the second. */\n export function lt_u(a: v128, b: v128): v128;\n /** Computes which 32-bit signed integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_s(a: v128, b: v128): v128;\n /** Computes which 32-bit unsigned integer lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le_u(a: v128, b: v128): v128;\n /** Computes which 32-bit signed integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_s(a: v128, b: v128): v128;\n /** Computes which 32-bit unsigned integer lanes of the first 128-bit vector are greater than those of the second. */\n export function gt_u(a: v128, b: v128): v128;\n /** Computes which 32-bit signed integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_s(a: v128, b: v128): v128;\n /** Computes which 32-bit unsigned integer lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge_u(a: v128, b: v128): v128;\n /** Truncates each 32-bit float lane of a 128-bit vector to a signed integer with saturation. */\n export function trunc_s_f32x4_sat(a: v128): v128;\n /** Truncates each 32-bit float lane of a 128-bit vector to an unsigned integer with saturation. */\n export function trunc_u_f32x4_sat(a: v128): v128;\n}\n/** Initializes a 128-bit vector from two 64-bit integer values. Arguments must be compile-time constants. */\ndeclare function i64x2(a: i64, b: i64): v128;\ndeclare namespace i64x2 {\n /** Creates a 128-bit vector with two identical 64-bit integer lanes. */\n export function splat(x: i64): v128;\n /** Extracts one 64-bit integer lane from a 128-bit vector as a scalar. */\n export function extract_lane(x: v128, idx: u8): i64;\n /** Replaces one 64-bit integer lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: i64): v128;\n /** Adds each 64-bit integer lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 64-bit integer lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 64-bit integer lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Negates each 64-bit integer lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Performs a bitwise left shift on each 64-bit integer lane of a 128-bit vector by a scalar. */\n export function shl(a: v128, b: i32): v128;\n /** Performs a bitwise arithmetic right shift on each 64-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_s(a: v128, b: i32): v128;\n /** Performs a bitwise logical right shift on each 64-bit integer lane of a 128-bit vector by a scalar. */\n export function shr_u(a: v128, b: i32): v128;\n /** Reduces a 128-bit vector to a scalar indicating whether any 64-bit integer lane is considered `true`. */\n export function any_true(a: v128): bool;\n /** Reduces a 128-bit vector to a scalar indicating whether all 64-bit integer lanes are considered `true`. */\n export function all_true(a: v128): bool;\n /** Truncates each 64-bit float lane of a 128-bit vector to a signed integer with saturation. */\n export function trunc_s_f64x2_sat(a: v128): v128;\n /** Truncates each 64-bit float lane of a 128-bit vector to an unsigned integer with saturation. */\n export function trunc_u_f64x2_sat(a: v128): v128;\n}\n/** Initializes a 128-bit vector from four 32-bit float values. Arguments must be compile-time constants. */\ndeclare function f32x4(a: f32, b: f32, c: f32, d: f32): v128;\ndeclare namespace f32x4 {\n /** Creates a 128-bit vector with four identical 32-bit float lanes. */\n export function splat(x: f32): v128;\n /** Extracts one 32-bit float lane from a 128-bit vector as a scalar. */\n export function extract_lane(x: v128, idx: u8): f32;\n /** Replaces one 32-bit float lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: f32): v128;\n /** Adds each 32-bit float lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 32-bit float lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 32-bit float lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Divides each 32-bit float lane of two 128-bit vectors. */\n export function div(a: v128, b: v128): v128;\n /** Negates each 32-bit float lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Computes the minimum of each 32-bit float lane of two 128-bit vectors. */\n export function min(a: v128, b: v128): v128;\n /** Computes the maximum of each 32-bit float lane of two 128-bit vectors. */\n export function max(a: v128, b: v128): v128;\n /** Computes the absolute value of each 32-bit float lane of a 128-bit vector. */\n export function abs(a: v128): v128;\n /** Computes the square root of each 32-bit float lane of a 128-bit vector. */\n export function sqrt(a: v128): v128;\n /** Computes which 32-bit float lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which 32-bit float lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which 32-bit float lanes of the first 128-bit vector are less than those of the second. */\n export function lt(a: v128, b: v128): v128;\n /** Computes which 32-bit float lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le(a: v128, b: v128): v128;\n /** Computes which 32-bit float lanes of the first 128-bit vector are greater than those of the second. */\n export function gt(a: v128, b: v128): v128;\n /** Computes which 32-bit float lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge(a: v128, b: v128): v128;\n /** Converts each 32-bit signed integer lane of a 128-bit vector to floating point. */\n export function convert_s_i32x4(a: v128): v128;\n /** Converts each 32-bit unsigned integer lane of a 128-bit vector to floating point. */\n export function convert_u_i32x4(a: v128): v128;\n}\n/** Initializes a 128-bit vector from two 64-bit float values. Arguments must be compile-time constants. */\ndeclare function f64x2(a: f64, b: f64): v128;\ndeclare namespace f64x2 {\n /** Creates a 128-bit vector with two identical 64-bit float lanes. */\n export function splat(x: f64): v128;\n /** Extracts one 64-bit float lane from a 128-bit vector as a scalar. */\n export function extract_lane(x: v128, idx: u8): f64;\n /** Replaces one 64-bit float lane in a 128-bit vector. */\n export function replace_lane(x: v128, idx: u8, value: f64): v128;\n /** Adds each 64-bit float lane of two 128-bit vectors. */\n export function add(a: v128, b: v128): v128;\n /** Subtracts each 64-bit float lane of two 128-bit vectors. */\n export function sub(a: v128, b: v128): v128;\n /** Multiplies each 64-bit float lane of two 128-bit vectors. */\n export function mul(a: v128, b: v128): v128;\n /** Divides each 64-bit float lane of two 128-bit vectors. */\n export function div(a: v128, b: v128): v128;\n /** Negates each 64-bit float lane of a 128-bit vector. */\n export function neg(a: v128): v128;\n /** Computes the minimum of each 64-bit float lane of two 128-bit vectors. */\n export function min(a: v128, b: v128): v128;\n /** Computes the maximum of each 64-bit float lane of two 128-bit vectors. */\n export function max(a: v128, b: v128): v128;\n /** Computes the absolute value of each 64-bit float lane of a 128-bit vector. */\n export function abs(a: v128): v128;\n /** Computes the square root of each 64-bit float lane of a 128-bit vector. */\n export function sqrt(a: v128): v128;\n /** Computes which 64-bit float lanes of two 128-bit vectors are equal. */\n export function eq(a: v128, b: v128): v128;\n /** Computes which 64-bit float lanes of two 128-bit vectors are not equal. */\n export function ne(a: v128, b: v128): v128;\n /** Computes which 64-bit float lanes of the first 128-bit vector are less than those of the second. */\n export function lt(a: v128, b: v128): v128;\n /** Computes which 64-bit float lanes of the first 128-bit vector are less than or equal those of the second. */\n export function le(a: v128, b: v128): v128;\n /** Computes which 64-bit float lanes of the first 128-bit vector are greater than those of the second. */\n export function gt(a: v128, b: v128): v128;\n /** Computes which 64-bit float lanes of the first 128-bit vector are greater than or equal those of the second. */\n export function ge(a: v128, b: v128): v128;\n /** Converts each 64-bit signed integer lane of a 128-bit vector to floating point. */\n export function convert_s_i64x2(a: v128): v128;\n /** Converts each 64-bit unsigned integer lane of a 128-bit vector to floating point. */\n export function convert_u_i64x2(a: v128): v128;\n}\ndeclare namespace v8x16 {\n /** Selects 8-bit lanes from either 128-bit vector according to the specified lane indexes. */\n export function shuffle(a: v128, b: v128, l0: u8, l1: u8, l2: u8, l3: u8, l4: u8, l5: u8, l6: u8, l7: u8, l8: u8, l9: u8, l10: u8, l11: u8, l12: u8, l13: u8, l14: u8, l15: u8): v128;\n}\n/** Macro type evaluating to the underlying native WebAssembly type. */\ndeclare type native = T;\n/** Special type evaluating the indexed access index type. */\ndeclare type indexof = keyof T;\n/** Special type evaluating the indexed access value type. */\ndeclare type valueof = T[0];\n\n/** Pseudo-class representing the backing class of integer types. */\ndeclare class _Integer {\n /** Smallest representable value. */\n static readonly MIN_VALUE: number;\n /** Largest representable value. */\n static readonly MAX_VALUE: number;\n /** Converts a string to an integer of this type. */\n static parseInt(value: string, radix?: number): number;\n /** Converts this integer to a string. */\n toString(): string;\n}\n\n/** Pseudo-class representing the backing class of floating-point types. */\ndeclare class _Float {\n /** Difference between 1 and the smallest representable value greater than 1. */\n static readonly EPSILON: f32 | f64;\n /** Smallest representable value. */\n static readonly MIN_VALUE: f32 | f64;\n /** Largest representable value. */\n static readonly MAX_VALUE: f32 | f64;\n /** Smallest safely representable integer value. */\n static readonly MIN_SAFE_INTEGER: f32 | f64;\n /** Largest safely representable integer value. */\n static readonly MAX_SAFE_INTEGER: f32 | f64;\n /** Value representing positive infinity. */\n static readonly POSITIVE_INFINITY: f32 | f64;\n /** Value representing negative infinity. */\n static readonly NEGATIVE_INFINITY: f32 | f64;\n /** Value representing \'not a number\'. */\n static readonly NaN: f32 | f64;\n /** Returns a boolean value that indicates whether a value is the reserved value NaN (not a number). */\n static isNaN(value: f32 | f64): bool;\n /** Returns true if passed value is finite. */\n static isFinite(value: f32 | f64): bool;\n /** Returns true if the value passed is a safe integer. */\n static isSafeInteger(value: f32 | f64): bool;\n /** Returns true if the value passed is an integer, false otherwise. */\n static isInteger(value: f32 | f64): bool;\n /** Converts a string to an integer. */\n static parseInt(value: string, radix?: i32): f32 | f64;\n /** Converts a string to a floating-point number. */\n static parseFloat(value: string): f32 | f64;\n /** Converts this floating-point number to a string. */\n toString(this: f64): string;\n}\n\n/** Backing class of signed 8-bit integers. */\ndeclare const I8: typeof _Integer;\n/** Backing class of signed 16-bit integers. */\ndeclare const I16: typeof _Integer;\n/** Backing class of signed 32-bit integers. */\ndeclare const I32: typeof _Integer;\n/** Backing class of signed 64-bit integers. */\ndeclare const I64: typeof _Integer;\n/** Backing class of signed size integers. */\ndeclare const Isize: typeof _Integer;\n/** Backing class of unsigned 8-bit integers. */\ndeclare const U8: typeof _Integer;\n/** Backing class of unsigned 16-bit integers. */\ndeclare const U16: typeof _Integer;\n/** Backing class of unsigned 32-bit integers. */\ndeclare const U32: typeof _Integer;\n/** Backing class of unsigned 64-bit integers. */\ndeclare const U64: typeof _Integer;\n/** Backing class of unsigned size integers. */\ndeclare const Usize: typeof _Integer;\n/** Backing class of 32-bit floating-point values. */\ndeclare const F32: typeof _Float;\n/** Backing class of 64-bit floating-point values. */\ndeclare const F64: typeof _Float;\n\n// User-defined diagnostic macros\n\n/** Emits a user-defined diagnostic error when encountered. */\ndeclare function ERROR(message?: any): void;\n/** Emits a user-defined diagnostic warning when encountered. */\ndeclare function WARNING(message?: any): void;\n/** Emits a user-defined diagnostic info when encountered. */\ndeclare function INFO(message?: any): void;\n\n// Polyfills\n\n/** Performs the sign-agnostic reverse bytes **/\ndeclare function bswap(value: T): T;\n/** Performs the sign-agnostic reverse bytes only for last 16-bit **/\ndeclare function bswap16(value: T): T;\n\n// Standard library\n\n/** Memory operations. */\ndeclare namespace memory {\n /** Whether the memory managed interface is implemented. */\n export const implemented: bool;\n /** Returns the current memory size in units of pages. One page is 64kb. */\n export function size(): i32;\n /** Grows linear memory by a given unsigned delta of pages. One page is 64kb. Returns the previous memory size in units of pages or `-1` on failure. */\n export function grow(value: i32): i32;\n /** Sets n bytes beginning at the specified destination in memory to the specified byte value. */\n export function fill(dst: usize, value: u8, count: usize): void;\n /** Copies n bytes from the specified source to the specified destination in memory. These regions may overlap. */\n export function copy(dst: usize, src: usize, n: usize): void;\n /** Repeats `src` of length `srcLength` `count` times at `dst`. */\n export function repeat(dst: usize, src: usize, srcLength: usize, count: usize): void;\n /** Copies elements from a passive element segment to a table. */\n export function init(segmentIndex: u32, srcOffset: usize, dstOffset: usize, n: usize): void;\n /** Prevents further use of a passive element segment. */\n export function drop(segmentIndex: u32): void;\n /** Compares two chunks of memory. Returns `0` if equal, otherwise the difference of the first differing bytes. */\n export function compare(vl: usize, vr: usize, n: usize): i32;\n}\n\n/** Garbage collector operations. */\ndeclare namespace gc {\n /** Whether the garbage collector interface is implemented. */\n export const implemented: bool;\n /** Performs a full garbage collection cycle. */\n export function collect(): void;\n /** Retains a reference, making sure that it doesn\'t become collected. */\n export function retain(ref: usize): void;\n /** Releases a reference, allowing it to become collected. */\n export function release(ref: usize): void;\n}\n\n/** Table operations. */\ndeclare namespace table {\n /** Copies elements from a passive element segment to a table. */\n export function init(elementIndex: u32, srcOffset: u32, dstOffset: u32, n: u32): void;\n /** Prevents further use of a passive element segment. */\n export function drop(elementIndex: u32): void;\n /** Copies elements from one region of a table to another region. */\n export function copy(dest: u32, src: u32, n: u32): void;\n}\n\n/** Class representing a generic, fixed-length raw binary data buffer. */\ndeclare class ArrayBuffer {\n /** The size, in bytes, of the array. */\n readonly byteLength: i32;\n /** Returns true if value is one of the ArrayBuffer views, such as typed array or a DataView **/\n static isView(value: T): bool;\n /** Constructs a new array buffer of the given length in bytes. */\n constructor(length: i32);\n /** Returns a copy of this array buffer\'s bytes from begin, inclusive, up to end, exclusive. */\n slice(begin?: i32, end?: i32): ArrayBuffer;\n /** Returns a string representation of ArrayBuffer. */\n toString(): string;\n}\n\n/** The `DataView` view provides a low-level interface for reading and writing multiple number types in a binary `ArrayBuffer`, without having to care about the platform\'s endianness. */\ndeclare class DataView {\n /** The `buffer` accessor property represents the `ArrayBuffer` or `SharedArrayBuffer` referenced by the `DataView` at construction time. */\n readonly buffer: ArrayBuffer;\n /** The `byteLength` accessor property represents the length (in bytes) of this view from the start of its `ArrayBuffer` or `SharedArrayBuffer`. */\n readonly byteLength: i32;\n /** The `byteOffset` accessor property represents the offset (in bytes) of this view from the start of its `ArrayBuffer` or `SharedArrayBuffer`. */\n readonly byteOffset: i32;\n /** Constructs a new `DataView` with the given properties */\n constructor(buffer: ArrayBuffer, byteOffset?: i32, byteLength?: i32);\n /** The `getFloat32()` method gets a signed 32-bit float (float) at the specified byte offset from the start of the `DataView`. */\n getFloat32(byteOffset: i32, littleEndian?: boolean): f32;\n /** The `getFloat64()` method gets a signed 64-bit float (double) at the specified byte offset from the start of the `DataView`. */\n getFloat64(byteOffset: i32, littleEndian?: boolean): f64;\n /** The `getInt8()` method gets a signed 8-bit integer (byte) at the specified byte offset from the start of the `DataView`. */\n getInt8(byteOffset: i32): i8;\n /** The `getInt16()` method gets a signed 16-bit integer (short) at the specified byte offset from the start of the `DataView`. */\n getInt16(byteOffset: i32, littleEndian?: boolean): i16;\n /** The `getInt32()` method gets a signed 32-bit integer (long) at the specified byte offset from the start of the `DataView`. */\n getInt32(byteOffset: i32, littleEndian?: boolean): i32;\n /** The `getInt64()` method gets a signed 64-bit integer (long long) at the specified byte offset from the start of the `DataView`. */\n getInt64(byteOffset: i32, littleEndian?: boolean): i64;\n /** The `getUint8()` method gets an unsigned 8-bit integer (unsigned byte) at the specified byte offset from the start of the `DataView`. */\n getUint8(byteOffset: i32): u8;\n /** The `getUint16()` method gets an unsigned 16-bit integer (unsigned short) at the specified byte offset from the start of the `DataView`. */\n getUint16(byteOffset: i32, littleEndian?: boolean): u16;\n /** The `getUint32()` method gets an unsigned 32-bit integer (unsigned long) at the specified byte offset from the start of the `DataView`. */\n getUint32(byteOffset: i32, littleEndian?: boolean): u32;\n /** The `getUint64()` method gets an unsigned 64-bit integer (unsigned long long) at the specified byte offset from the start of the `DataView`. */\n getUint64(byteOffset: i32, littleEndian?: boolean): u64;\n /** The `setFloat32()` method stores a signed 32-bit float (float) value at the specified byte offset from the start of the `DataView`. */\n setFloat32(byteOffset: i32, value: f32, littleEndian?: boolean): void;\n /** The `setFloat64()` method stores a signed 64-bit float (double) value at the specified byte offset from the start of the `DataView`. */\n setFloat64(byteOffset: i32, value: f64, littleEndian?: boolean): void;\n /** The `setInt8()` method stores a signed 8-bit integer (byte) value at the specified byte offset from the start of the `DataView`. */\n setInt8(byteOffset: i32, value: i8): void;\n /** The `setInt16()` method stores a signed 16-bit integer (short) value at the specified byte offset from the start of the `DataView`. */\n setInt16(byteOffset: i32, value: i16, littleEndian?: boolean): void;\n /** The `setInt32()` method stores a signed 32-bit integer (long) value at the specified byte offset from the start of the `DataView`. */\n setInt32(byteOffset: i32, value: i32, littleEndian?: boolean): void;\n /** The `setInt64()` method stores a signed 64-bit integer (long long) value at the specified byte offset from the start of the `DataView`. */\n setInt64(byteOffset: i32, value: i64, littleEndian?: boolean): void;\n /** The `setUint8()` method stores an unsigned 8-bit integer (byte) value at the specified byte offset from the start of the `DataView`. */\n setUint8(byteOffset: i32, value: u8): void;\n /** The `setUint16()` method stores an unsigned 16-bit integer (unsigned short) value at the specified byte offset from the start of the `DataView`. */\n setUint16(byteOffset: i32, value: u16, littleEndian?: boolean): void;\n /** The `setUint32()` method stores an unsigned 32-bit integer (unsigned long) value at the specified byte offset from the start of the `DataView`. */\n setUint32(byteOffset: i32, value: u32, littleEndian?: boolean): void;\n /** The `setUint64()` method stores an unsigned 64-bit integer (unsigned long long) value at the specified byte offset from the start of the `DataView`. */\n setUint64(byteOffset: i32, value: u64, littleEndian?: boolean): void;\n /** Returns a string representation of DataView. */\n toString(): string;\n}\n\ninterface ArrayLike {\n length: i32;\n // [key: number]: T;\n}\n\n/** Interface for a typed view on an array buffer. */\ninterface ArrayBufferView {\n [key: number]: T;\n /** The {@link ArrayBuffer} referenced by this view. */\n readonly buffer: ArrayBuffer;\n /** The offset in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteOffset: i32;\n /** The length in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteLength: i32;\n}\n\n/* @internal */\ndeclare abstract class TypedArray implements ArrayBufferView {\n [key: number]: T;\n /** Number of bytes per element. */\n static readonly BYTES_PER_ELEMENT: usize;\n /** Constructs a new typed array. */\n constructor(length: i32);\n /** The {@link ArrayBuffer} referenced by this view. */\n readonly buffer: ArrayBuffer;\n /** The offset in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteOffset: i32;\n /** The length in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteLength: i32;\n /** The length (in elements). */\n readonly length: i32;\n /** The includes() method determines whether a typed array includes a certain element, returning true or false as appropriate. */\n includes(searchElement: T, fromIndex?: i32): bool;\n /** The indexOf() method returns the first index at which a given element can be found in the typed array, or -1 if it is not present. */\n indexOf(searchElement: T, fromIndex?: i32): i32;\n /** The lastIndexOf() method returns the last index at which a given element can be found in the typed array, or -1 if it is not present. The typed array is searched backwards, starting at fromIndex. */\n lastIndexOf(searchElement: T, fromIndex?: i32): i32;\n /** Returns a new TypedArray of this type on the same ArrayBuffer from begin inclusive to end exclusive. */\n subarray(begin?: i32, end?: i32): this;\n /** The reduce() method applies a function against an accumulator and each value of the typed array (from left-to-right) has to reduce it to a single value. This method has the same algorithm as Array.prototype.reduce(). */\n reduce(callbackfn: (accumulator: W, value: T, index: i32, self: this) => W, initialValue: W): W;\n /** The reduceRight() method applies a function against an accumulator and each value of the typed array (from left-to-right) has to reduce it to a single value, starting from the end of the array. This method has the same algorithm as Array.prototype.reduceRight(). */\n reduceRight(callbackfn: (accumulator: W, value: T, index: i32, self: this) => W, initialValue: W): W;\n /** The some() method tests whether some element in the typed array passes the test implemented by the provided function. This method has the same algorithm as Array.prototype.some().*/\n some(callbackfn: (value: T, index: i32, self: this) => bool): bool;\n /** The map() method creates a new typed array with the results of calling a provided function on every element in this typed array. This method has the same algorithm as Array.prototype.map().*/\n map(callbackfn: (value: T, index: i32, self: this) => T): this;\n /** The sort() method sorts the elements of a typed array numerically in place and returns the typed array. This method has the same algorithm as Array.prototype.sort(), except that sorts the values numerically instead of as strings. TypedArray is one of the typed array types here. */\n sort(callback?: (a: T, b: T) => i32): this;\n /** The fill() method fills all the elements of a typed array from a start index to an end index with a static value. This method has the same algorithm as Array.prototype.fill(). */\n fill(value: T, start?: i32, end?: i32): this;\n /** The findIndex() method returns an index in the typed array, if an element in the typed array satisfies the provided testing function. Otherwise -1 is returned. See also the find() [not implemented] method, which returns the value of a found element in the typed array instead of its index. */\n findIndex(callbackfn: (value: T, index: i32, self: this) => bool): i32;\n /** The every() method tests whether all elements in the typed array pass the test implemented by the provided function. This method has the same algorithm as Array.prototype.every(). */\n every(callbackfn: (value: T, index: i32, self: this) => bool): bool;\n /** The forEach() method executes a provided function once per array element. This method has the same algorithm as Array.prototype.forEach().*/\n forEach(callbackfn: (value: T, index: i32, self: this) => void): void;\n /** The reverse() method reverses a typed array in place. The first typed array element becomes the last and the last becomes the first. This method has the same algorithm as Array.prototype.reverse(). */\n reverse(): this;\n}\n\n/** An array of twos-complement 8-bit signed integers. */\ndeclare class Int8Array extends TypedArray {}\n/** An array of 8-bit unsigned integers. */\ndeclare class Uint8Array extends TypedArray {}\n/** A clamped array of 8-bit unsigned integers. */\ndeclare class Uint8ClampedArray extends TypedArray {}\n/** An array of twos-complement 16-bit signed integers. */\ndeclare class Int16Array extends TypedArray {}\n/** An array of 16-bit unsigned integers. */\ndeclare class Uint16Array extends TypedArray {}\n/** An array of twos-complement 32-bit signed integers. */\ndeclare class Int32Array extends TypedArray {}\n/** An array of 32-bit unsigned integers. */\ndeclare class Uint32Array extends TypedArray {}\n/** An array of twos-complement 64-bit signed integers. */\ndeclare class Int64Array extends TypedArray {}\n/** An array of 64-bit unsigned integers. */\ndeclare class Uint64Array extends TypedArray {}\n/** An array of 32-bit floating point numbers. */\ndeclare class Float32Array extends TypedArray {}\n/** An array of 64-bit floating point numbers. */\ndeclare class Float64Array extends TypedArray {}\n\n/** Class representing a sequence of values of type `T`. */\ndeclare class Array {\n\n /** Tests if a value is an array. */\n static isArray(value: any): value is Array;\n /** Creates a new array with at least the specified capacity and length zero. */\n static create(capacity?: i32): Array;\n\n [key: number]: T;\n /** Current length of the array. */\n length: i32;\n /** Constructs a new array. If length is greater than zero and T is a non-nullable reference, use `Array.create` instead.*/\n constructor(capacity?: i32);\n\n fill(value: T, start?: i32, end?: i32): this;\n every(callbackfn: (element: T, index: i32, array?: Array) => bool): bool;\n findIndex(predicate: (element: T, index: i32, array?: Array) => bool): i32;\n includes(searchElement: T, fromIndex?: i32): bool;\n indexOf(searchElement: T, fromIndex?: i32): i32;\n lastIndexOf(searchElement: T, fromIndex?: i32): i32;\n push(element: T): i32;\n concat(items: T[]): T[];\n copyWithin(target: i32, start: i32, end?: i32): this;\n pop(): T;\n forEach(callbackfn: (value: T, index: i32, array: Array) => void): void;\n map(callbackfn: (value: T, index: i32, array: Array) => U): Array;\n filter(callbackfn: (value: T, index: i32, array: Array) => bool): Array;\n reduce(callbackfn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U, initialValue: U): U;\n reduceRight(callbackfn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U, initialValue: U): U;\n shift(): T;\n some(callbackfn: (element: T, index: i32, array?: Array) => bool): bool;\n unshift(element: T): i32;\n slice(from: i32, to?: i32): Array;\n splice(start: i32, deleteCount?: i32): Array;\n sort(comparator?: (a: T, b: T) => i32): this;\n join(separator?: string): string;\n reverse(): T[];\n toString(): string;\n}\n\n/** Class representing a fixed sequence of values of type `T`. */\ndeclare class FixedArray {\n [key: number]: T;\n readonly length: i32;\n constructor(capacity?: i32);\n}\n\n/** Class representing a sequence of characters. */\ndeclare class String {\n\n static fromCharCode(ls: i32, hs?: i32): string;\n static fromCharCodes(arr: u16[]): string;\n static fromCodePoint(code: i32): string;\n static fromCodePoints(arr: i32[]): string;\n\n readonly length: i32;\n readonly lengthUTF8: i32;\n\n charAt(index: u32): string;\n charCodeAt(index: u32): u16;\n concat(other: string): string;\n endsWith(other: string): bool;\n indexOf(other: string, fromIndex?: i32): u32;\n lastIndexOf(other: string, fromIndex?: i32): i32;\n includes(other: string): bool;\n startsWith(other: string): bool;\n substr(start: u32, length?: u32): string;\n substring(start: u32, end?: u32): string;\n trim(): string;\n trimLeft(): string;\n trimRight(): string;\n trimStart(): string;\n trimEnd(): string;\n padStart(targetLength: i32, padString?: string): string;\n padEnd(targetLength: i32, padString?: string): string;\n repeat(count?: i32): string;\n replace(search: string, replacement: string): string;\n replaceAll(search: string, replacement: string): string;\n slice(beginIndex: i32, endIndex?: i32): string;\n split(separator?: string, limit?: i32): string[];\n toString(): string;\n static fromUTF8(ptr: usize, len: usize): string;\n toUTF8(): usize;\n}\n\n/** Class for representing a runtime error. Base class of all errors. */\ndeclare class Error {\n\n /** Error name. */\n name: string;\n\n /** Message provided on construction. */\n message: string;\n\n /** Stack trace. */\n stack?: string;\n\n /** Constructs a new error, optionally with a message. */\n constructor(message?: string);\n\n /** Method returns a string representing the specified Error class. */\n toString(): string;\n}\n\n/** Class for indicating an error when a value is not in the set or range of allowed values. */\ndeclare class RangeError extends Error { }\n\n/** Class for indicating an error when a value is not of the expected type. */\ndeclare class TypeError extends Error { }\n\n/** Class for indicating an error when trying to interpret syntactically invalid code. */\ndeclare class SyntaxError extends Error { }\n\ninterface Boolean {}\ninterface Function {}\ninterface IArguments {}\ninterface Number {}\ninterface Object {}\ninterface RegExp {}\n\ndeclare class Map {\n readonly size: i32;\n has(key: K): bool;\n set(key: K, value: V): void;\n get(key: K): V;\n delete(key: K): bool;\n clear(): void;\n keys(): K[]; // preliminary\n values(): V[]; // preliminary\n toString(): string;\n}\n\ndeclare class Set {\n readonly size: i32;\n has(value: K): bool;\n add(value: K): void;\n delete(value: K): bool;\n clear(): void;\n values(): K[]; // preliminary\n toString(): string;\n}\n\ninterface SymbolConstructor {\n readonly hasInstance: symbol;\n readonly isConcatSpreadable: symbol;\n readonly isRegExp: symbol;\n readonly iterator: symbol;\n readonly match: symbol;\n readonly replace: symbol;\n readonly search: symbol;\n readonly species: symbol;\n readonly split: symbol;\n readonly toPrimitive: symbol;\n readonly toStringTag: symbol;\n readonly unscopables: symbol;\n (description?: string | null): symbol;\n for(key: string): symbol;\n keyFor(sym: symbol): string | null;\n}\n\ndeclare const Symbol: SymbolConstructor;\n\ninterface IMath {\n /** The base of natural logarithms, e, approximately 2.718. */\n readonly E: T;\n /** The natural logarithm of 2, approximately 0.693. */\n readonly LN2: T;\n /** The natural logarithm of 10, approximately 2.302. */\n readonly LN10: T;\n /** The base 2 logarithm of e, approximately 1.442. */\n readonly LOG2E: T;\n /** The base 10 logarithm of e, approximately 0.434. */\n readonly LOG10E: T;\n /** The ratio of the circumference of a circle to its diameter, approximately 3.14159. */\n readonly PI: T;\n /** The square root of 1/2, approximately 0.707. */\n readonly SQRT1_2: T;\n /** The square root of 2, approximately 1.414. */\n readonly SQRT2: T;\n /** Returns the absolute value of `x`. */\n abs(x: T): T;\n /** Returns the arccosine (in radians) of `x`. */\n acos(x: T): T;\n /** Returns the hyperbolic arc-cosine of `x`. */\n acosh(x: T): T;\n /** Returns the arcsine (in radians) of `x`. */\n asin(x: T): T;\n /** Returns the hyperbolic arcsine of `x`. */\n asinh(x: T): T;\n /** Returns the arctangent (in radians) of `x`. */\n atan(x: T): T;\n /** Returns the arctangent of the quotient of its arguments. */\n atan2(y: T, x: T): T;\n /** Returns the hyperbolic arctangent of `x`. */\n atanh(x: T): T;\n /** Returns the cube root of `x`. */\n cbrt(x: T): T;\n /** Returns the smallest integer greater than or equal to `x`. */\n ceil(x: T): T;\n /** Returns the number of leading zero bits in the 32-bit binary representation of `x`. */\n clz32(x: T): T;\n /** Returns the cosine (in radians) of `x`. */\n cos(x: T): T;\n /** Returns the hyperbolic cosine of `x`. */\n cosh(x: T): T;\n /** Returns e to the power of `x`. */\n exp(x: T): T;\n /** Returns e to the power of `x`, minus 1. */\n expm1(x: T): T;\n /** Returns the largest integer less than or equal to `x`. */\n floor(x: T): T;\n /** Returns the nearest 32-bit single precision float representation of `x`. */\n fround(x: T): T;\n /** Returns the square root of the sum of squares of its arguments. */\n hypot(value1: T, value2: T): T; // TODO: rest\n /** Returns the result of the C-like 32-bit multiplication of `a` and `b`. */\n imul(a: T, b: T): T;\n /** Returns the natural logarithm (base e) of `x`. */\n log(x: T): T;\n /** Returns the base 10 logarithm of `x`. */\n log10(x: T): T;\n /** Returns the natural logarithm (base e) of 1 + `x`. */\n log1p(x: T): T;\n /** Returns the base 2 logarithm of `x`. */\n log2(x: T): T;\n /** Returns the largest-valued number of its arguments. */\n max(value1: T, value2: T): T; // TODO: rest\n /** Returns the lowest-valued number of its arguments. */\n min(value1: T, value2: T): T; // TODO: rest\n /** Returns `base` to the power of `exponent`. */\n pow(base: T, exponent: T): T;\n /** Returns a pseudo-random number in the range from 0.0 inclusive up to but not including 1.0. */\n random(): T;\n /** Returns the value of `x` rounded to the nearest integer. */\n round(x: T): T;\n /** Returns the sign of `x`, indicating whether the number is positive, negative or zero. */\n sign(x: T): T;\n /** Returns whether the sign bit of `x` is set. */\n signbit(x: T): bool;\n /** Returns the sine of `x`. */\n sin(x: T): T;\n /** Returns the hyperbolic sine of `x`. */\n sinh(x: T): T;\n /** Returns the square root of `x`. */\n sqrt(x: T): T;\n /** Returns the tangent of `x`. */\n tan(x: T): T;\n /** Returns the hyperbolic tangent of `x`. */\n tanh(x: T): T;\n /** Returns the integer part of `x` by removing any fractional digits. */\n trunc(x: T): T;\n}\n\ninterface INativeMath extends IMath {\n /** Contains sin value produced after Math/Mathf.sincos */\n sincos_sin: T;\n /** Contains cos value produced after Math/Mathf.sincos */\n sincos_cos: T;\n /** Seeds the random number generator. */\n seedRandom(value: i64): void;\n /** Returns the floating-point remainder of `x / y` (rounded towards zero). */\n mod(x: T, y: T): T;\n /** Returns the floating-point remainder of `x / y` (rounded to nearest). */\n rem(x: T, y: T): T;\n /** Returns sin and cos simultaneously for same angle. Results stored to `sincos_s32/64` and `sincos_c32/64` globals */\n sincos(x: T): void;\n}\n\n/** Double precision math imported from JavaScript. */\ndeclare const JSMath: IMath;\n/** Double precision math implemented natively. */\ndeclare const NativeMath: INativeMath;\n/** Single precision math implemented natively. */\ndeclare const NativeMathf: INativeMath;\n/** Alias of {@link NativeMath} or {@link JSMath} respectively. Defaults to `NativeMath`. */\ndeclare const Math: IMath;\n/** Alias of {@link NativeMathf} or {@link JSMath} respectively. Defaults to `NativeMathf`. */\ndeclare const Mathf: IMath;\n\ndeclare class Date {\n /** Returns the UTC timestamp in milliseconds of the specified date. */\n static UTC(\n year: i32,\n month: i32,\n day: i32,\n hour: i32,\n minute: i32,\n second: i32,\n millisecond: i32\n ): i64;\n /** Returns the current UTC timestamp in milliseconds. */\n static now(): i64;\n /** Constructs a new date object from an UTC timestamp in milliseconds. */\n constructor(value: i64);\n /** Returns the UTC timestamp of this date in milliseconds. */\n getTime(): i64;\n /** Sets the UTC timestamp of this date in milliseconds. */\n setTime(value: i64): i64;\n}\n\n/** Environmental tracing function for debugging purposes. */\ndeclare function trace(msg: string, n?: i32, a0?: f64, a1?: f64, a2?: f64, a3?: f64, a4?: f64): void;\n\n// Decorators\n\ninterface TypedPropertyDescriptor {\n configurable?: boolean;\n enumerable?: boolean;\n writable?: boolean;\n value?: T;\n get?(): T;\n set?(value: T): void;\n}\n\n/** Annotates a method as a binary operator overload for the specified `token`. */\ndeclare function operator(token:\n "[]" | "[]=" | "{}" | "{}=" | "==" | "!=" | ">" | "<" | "<=" | ">=" |\n ">>" | ">>>" | "<<" | "&" | "|" | "^" | "+" | "-" | "*" | "**" | "/" | "%"\n): (\n target: any,\n propertyKey: string,\n descriptor: TypedPropertyDescriptor\n) => TypedPropertyDescriptor | void;\n\ndeclare namespace operator {\n /** Annotates a method as a binary operator overload for the specified `token`. */\n export function binary(token:\n "[]" | "[]=" | "{}" | "{}=" | "==" | "!=" | ">" | "<" | "<=" | ">=" |\n ">>" | ">>>" | "<<" | "&" | "|" | "^" | "+" | "-" | "*" | "**" | "/" | "%"\n ): (\n target: any,\n propertyKey: string,\n descriptor: TypedPropertyDescriptor\n ) => TypedPropertyDescriptor | void;\n /** Annotates a method as an unary prefix operator overload for the specified `token`. */\n export function prefix(token: "!" | "~" | "+" | "-" | "++" | "--"): (\n target: any,\n propertyKey: string,\n descriptor: TypedPropertyDescriptor\n ) => TypedPropertyDescriptor | void;\n /** Annotates a method as an unary postfix operator overload for the specified `token`. */\n export function postfix(token: "++" | "--"): (\n target: any,\n propertyKey: string,\n descriptor: TypedPropertyDescriptor\n ) => TypedPropertyDescriptor | void;\n}\n\n/** Annotates an element as a program global. */\ndeclare function global(...args: any[]): any;\n\n/** Annotates a class as being unmanaged with limited capabilities. */\ndeclare function unmanaged(constructor: Function): void;\n\n/** Annotates a class as being sealed / non-derivable. */\ndeclare function sealed(constructor: Function): void;\n\n/** Annotates a method, function or constant global as always inlined. */\ndeclare function inline(...args: any[]): any;\n\n/** Annotates a method, function or constant global as unsafe. */\ndeclare function unsafe(...args: any[]): any;\n\n/** Annotates an explicit external name of a function or global. */\ndeclare function external(...args: any[]): any;\n\n/** Annotates a global for lazy compilation. */\ndeclare function lazy(...args: any[]): any;\n\n/** Annotates a function as the explicit start function. */\ndeclare function start(...args: any[]): any;\n',portable:"/**\n * Environment definitions for compiling AssemblyScript to JavaScript using tsc.\n *\n * Note that semantic differences require additional explicit conversions for full compatibility.\n * For example, when casting an i32 to an u8, doing `(someI32 & 0xff)` will yield the same\n * result when compiling to WebAssembly or JS while `someI32` alone does nothing in JS.\n *\n * Note that i64's are not portable (JS numbers are IEEE754 doubles with a maximum safe integer\n * value of 2^53-1) and instead require a compatibility layer to work in JS as well, as for example\n * {@link glue/js/i64} respectively {@link glue/wasm/i64}.\n *\n * @module std/portable\n *//***/\n\n/// \n\n// Types\n\ndeclare type bool = boolean;\ndeclare type i8 = number;\ndeclare type i16 = number;\ndeclare type i32 = number;\ndeclare type isize = number;\ndeclare type u8 = number;\ndeclare type u16 = number;\ndeclare type u32 = number;\ndeclare type usize = number;\ndeclare type f32 = number;\ndeclare type f64 = number;\n\n/** Special type evaluating the indexed access index type. */\ndeclare type indexof = keyof T;\n/** Special type evaluating the indexed access value type. */\ndeclare type valueof = T[0];\n\n// Compiler hints\n\n/** Compiler target. 0 = JS, 1 = WASM32, 2 = WASM64. */\ndeclare const ASC_TARGET: i32;\n/** Provided noAssert option. */\ndeclare const ASC_NO_ASSERT: bool;\n/** Provided memoryBase option. */\ndeclare const ASC_MEMORY_BASE: i32;\n/** Provided optimizeLevel option. */\ndeclare const ASC_OPTIMIZE_LEVEL: i32;\n/** Provided shrinkLevel option. */\ndeclare const ASC_SHRINK_LEVEL: i32;\n/** Whether the mutable global feature is enabled. */\ndeclare const ASC_FEATURE_MUTABLE_GLOBAL: bool;\n/** Whether the sign extension feature is enabled. */\ndeclare const ASC_FEATURE_SIGN_EXTENSION: bool;\n\n// Builtins\n\n/** Performs the sign-agnostic count leading zero bits operation on a 32-bit integer. All zero bits are considered leading if the value is zero. */\ndeclare function clz(value: T): T;\n/** Performs the sign-agnostic count tailing zero bits operation on a 32-bit integer. All zero bits are considered trailing if the value is zero. */\ndeclare function ctz(value: T): T;\n/** Performs the sign-agnostic count number of one bits operation on a 32-bit integer. */\ndeclare function popcnt(value: T): T;\n/** Performs the sign-agnostic rotate left operation on a 32-bit integer. */\ndeclare function rotl(value: T, shift: T): T;\n/** Performs the sign-agnostic rotate right operation on a 32-bit integer. */\ndeclare function rotr(value: T, shift: T): T;\n/** Computes the absolute value of an integer or float. */\ndeclare function abs(value: T): T;\n/** Determines the maximum of two integers or floats. If either operand is `NaN`, returns `NaN`. */\ndeclare function max(left: T, right: T): T;\n/** Determines the minimum of two integers or floats. If either operand is `NaN`, returns `NaN`. */\ndeclare function min(left: T, right: T): T;\n/** Composes a 32-bit or 64-bit float from the magnitude of `x` and the sign of `y`. */\ndeclare function copysign(x: T, y: T): T;\n/** Performs the ceiling operation on a 32-bit or 64-bit float. */\ndeclare function ceil(value: T): T;\n/** Performs the floor operation on a 32-bit or 64-bit float. */\ndeclare function floor(value: T): T;\n/** Rounds to the nearest integer tied to even of a 32-bit or 64-bit float. */\ndeclare function nearest(value: T): T;\n/** Selects one of two pre-evaluated values depending on the condition. */\ndeclare function select(ifTrue: T, ifFalse: T, condition: bool): T;\n/** Calculates the square root of a 32-bit or 64-bit float. */\ndeclare function sqrt(value: T): T;\n/** Rounds to the nearest integer towards zero of a 32-bit or 64-bit float. */\ndeclare function trunc(value: T): T;\n/** Loads a value of the specified type from memory. Type must be `u8`. */\ndeclare function load(ptr: usize, constantOffset?: usize): T;\n/** Stores a value of the specified type to memory. Type must be `u8`. */\ndeclare function store(ptr: usize, value: T, constantOffset?: usize): void;\n/** Emits an unreachable operation that results in a runtime error when executed. */\ndeclare function unreachable(): any; // sic\n\n/** NaN (not a number) as a 32-bit or 64-bit float depending on context. */\ndeclare const NaN: f32 | f64;\n/** Positive infinity as a 32-bit or 64-bit float depending on context. */\ndeclare const Infinity: f32 | f64;\n/** Changes the type of any value of `usize` kind to another one of `usize` kind. Useful for casting class instances to their pointer values and vice-versa. Beware that this is unsafe.*/\ndeclare function changetype(value: any): T;\n/** Explicitly requests no bounds checks on the provided expression. Useful for array accesses. */\ndeclare function unchecked(value: T): T;\n/** Tests if a 32-bit or 64-bit float is `NaN`. */\ndeclare function isNaN(value: T): bool;\n/** Tests if a 32-bit or 64-bit float is finite, that is not `NaN` or +/-`Infinity`. */\ndeclare function isFinite(value: T): bool;\n/** Tests if the specified value is a valid integer. Can't distinguish an integer from an integral float. */\ndeclare function isInteger(value: any): value is number;\n/** Tests if the specified value is a valid float. Can't distinguish a float from an integer. */\ndeclare function isFloat(value: any): value is number;\n/** Tests if the specified value is of a nullable reference type. */\ndeclare function isNullable(value: any): bool;\n/** Tests if the specified value is of a reference type. */\ndeclare function isReference(value: any): value is object | string;\n/** Tests if the specified value is of a function type */\ndeclare function isFunction(value: any): value is Function;\n/** Tests if the specified value can be used as a string. */\ndeclare function isString(value: any): value is string | String;\n/** Tests if the specified value can be used as an array. */\ndeclare function isArray(value: any): value is Array;\n/** Tests if the specified type *or* expression can be used as an array like object. */\ndeclare function isArrayLike(value: any): value is ArrayLike;\n/** Tests if the specified expression resolves to a defined element. */\ndeclare function isDefined(expression: any): bool;\n/** Tests if the specified expression evaluates to a constant value. */\ndeclare function isConstant(expression: any): bool;\n/** Traps if the specified value is not true-ish, otherwise returns the value. */\ndeclare function assert(isTrueish: T | null, message?: string): T;\n/** Parses an integer string to a 64-bit float. */\ndeclare function parseInt(str: string, radix?: i32): f64;\n/** Parses a floating point string to a 64-bit float. */\ndeclare function parseFloat(str: string): f64;\n/** Returns the 64-bit floating-point remainder of `x/y`. */\ndeclare function fmod(x: f64, y: f64): f64;\n/** Returns the 32-bit floating-point remainder of `x/y`. */\ndeclare function fmodf(x: f32, y: f32): f32;\n\n/** Converts any other numeric value to an 8-bit signed integer. */\ndeclare function i8(value: any): i8;\ndeclare namespace i8 {\n /** Smallest representable value. */\n export const MIN_VALUE: i8;\n /** Largest representable value. */\n export const MAX_VALUE: i8;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): i8;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): i8;\n}\n/** Converts any other numeric value to a 16-bit signed integer. */\ndeclare function i16(value: any): i16;\ndeclare namespace i16 {\n /** Smallest representable value. */\n export const MIN_VALUE: i16;\n /** Largest representable value. */\n export const MAX_VALUE: i16;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): i16;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): i16;\n}\n/** Converts any other numeric value to a 32-bit signed integer. */\ndeclare function i32(value: any): i32;\ndeclare namespace i32 {\n /** Smallest representable value. */\n export const MIN_VALUE: i32;\n /** Largest representable value. */\n export const MAX_VALUE: i32;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): i32;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): i32;\n}\n/** Converts any other numeric value to a 32-bit (in WASM32) respectivel 64-bit (in WASM64) signed integer. */\ndeclare function isize(value: any): isize;\ndeclare namespace isize {\n /** Smallest representable value. */\n export const MIN_VALUE: isize;\n /** Largest representable value. */\n export const MAX_VALUE: isize;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): isize;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): isize;\n}\n/** Converts any other numeric value to an 8-bit unsigned integer. */\ndeclare function u8(value: any): u8;\ndeclare namespace u8 {\n /** Smallest representable value. */\n export const MIN_VALUE: u8;\n /** Largest representable value. */\n export const MAX_VALUE: u8;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): u8;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): u8;\n}\n/** Converts any other numeric value to a 16-bit unsigned integer. */\ndeclare function u16(value: any): u16;\ndeclare namespace u16 {\n /** Smallest representable value. */\n export const MIN_VALUE: u16;\n /** Largest representable value. */\n export const MAX_VALUE: u16;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): u16;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): u16;\n}\n/** Converts any other numeric value to a 32-bit unsigned integer. */\ndeclare function u32(value: any): u32;\ndeclare namespace u32 {\n /** Smallest representable value. */\n export const MIN_VALUE: u32;\n /** Largest representable value. */\n export const MAX_VALUE: u32;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): u32;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): u32;\n}\n/** Converts any other numeric value to a 32-bit (in WASM32) respectivel 64-bit (in WASM64) unsigned integer. */\ndeclare function usize(value: any): isize;\ndeclare namespace usize {\n /** Smallest representable value. */\n export const MIN_VALUE: usize;\n /** Largest representable value. */\n export const MAX_VALUE: usize;\n /** Converts a string to a floating-point number and cast to target integer after. */\n export function parseFloat(string: string): usize;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): usize;\n}\n/** Converts any other numeric value to a 1-bit unsigned integer. */\ndeclare function bool(value: any): bool;\ndeclare namespace bool {\n /** Smallest representable value. */\n export const MIN_VALUE: bool;\n /** Largest representable value. */\n export const MAX_VALUE: bool;\n}\n/** Converts any other numeric value to a 32-bit float. */\ndeclare function f32(value: any): f32;\ndeclare namespace f32 {\n /** Smallest representable value. */\n export const MIN_VALUE: f32;\n /** Largest representable value. */\n export const MAX_VALUE: f32;\n /** Smallest normalized positive value. */\n export const MIN_POSITIVE_VALUE: f32;\n /** Smallest safely representable integer value. */\n export const MIN_SAFE_INTEGER: f32;\n /** Largest safely representable integer value. */\n export const MAX_SAFE_INTEGER: f32;\n /** Difference between 1 and the smallest representable value greater than 1. */\n export const EPSILON: f32;\n /** Returns a boolean value that indicates whether a value is the reserved value NaN (not a number). */\n export function isNaN(value: f32): bool;\n /** Returns true if passed value is finite. */\n export function isFinite(value: f32): bool;\n /** Returns true if the value passed is a safe integer. */\n export function isSafeInteger(value: f32): bool;\n /** Returns true if the value passed is an integer, false otherwise. */\n export function isInteger(value: f32): bool;\n /** Converts a string to a floating-point number. */\n export function parseFloat(string: string): f32;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): f32;\n}\n/** Converts any other numeric value to a 64-bit float. */\ndeclare function f64(value: any): f64;\ndeclare namespace f64 {\n /** Smallest representable value. */\n export const MIN_VALUE: f64;\n /** Largest representable value. */\n export const MAX_VALUE: f64;\n /** Smallest normalized positive value. */\n export const MIN_POSITIVE_VALUE: f64;\n /** Smallest safely representable integer value. */\n export const MIN_SAFE_INTEGER: f64;\n /** Largest safely representable integer value. */\n export const MAX_SAFE_INTEGER: f64;\n /** Difference between 1 and the smallest representable value greater than 1. */\n export const EPSILON: f64;\n /** Returns a boolean value that indicates whether a value is the reserved value NaN (not a number). */\n export function isNaN(value: f32): bool;\n /** Returns true if passed value is finite. */\n export function isFinite(value: f32): bool;\n /** Returns true if the value passed is a safe integer. */\n export function isSafeInteger(value: f64): bool;\n /** Returns true if the value passed is an integer, false otherwise. */\n export function isInteger(value: f64): bool;\n /** Converts a string to a floating-point number. */\n export function parseFloat(string: string): f64;\n /** Converts A string to an integer. */\n export function parseInt(string: string, radix?: i32): f64;\n}\n\n// Polyfills\n\n/** [Polyfill] Performs the sign-agnostic reverse bytes **/\ndeclare function bswap(value: T): T;\n/** [Polyfill] Performs the sign-agnostic reverse bytes only for last 16-bit **/\ndeclare function bswap16(value: T): T;\n\n// Standard library\n\n/** Memory operations. */\ndeclare namespace memory {\n /** Allocates a chunk of memory of the specified size and returns a pointer to it. */\n function allocate(size: usize): usize;\n /** Disposes a chunk of memory by its pointer. */\n function free(ptr: usize): void;\n /** Copies n bytes from the specified source to the specified destination in memory. These regions may overlap. */\n function copy(dst: usize, src: usize, n: usize): void;\n /** Fills size bytes from from the specified destination by same value in memory. */\n function fill(dst: usize, value: u8, size: usize): void;\n /** Resets the allocator to its initial state, if supported. */\n function reset(): void;\n}\n\n/** Class representing a generic, fixed-length raw binary data buffer. */\ndeclare class ArrayBuffer {\n /** The size, in bytes, of the array. */\n readonly byteLength: i32;\n /** Returns true if value is one of the ArrayBuffer views, such as typed array or a DataView **/\n static isView(value: T): bool;\n /** Constructs a new array buffer of the given length in bytes. */\n constructor(length: i32);\n /** Returns a copy of this array buffer's bytes from begin, inclusive, up to end, exclusive. */\n slice(begin?: i32, end?: i32): ArrayBuffer;\n /** Returns a string representation of ArrayBuffer. */\n toString(): string;\n}\n\n/** The `DataView` view provides a low-level interface for reading and writing multiple number types in a binary `ArrayBuffer`, without having to care about the platform's endianness. */\ndeclare class DataView {\n /** The `buffer` accessor property represents the `ArrayBuffer` or `SharedArrayBuffer` referenced by the `DataView` at construction time. */\n readonly buffer: ArrayBuffer;\n /** The `byteLength` accessor property represents the length (in bytes) of this view from the start of its `ArrayBuffer` or `SharedArrayBuffer`. */\n readonly byteLength: i32;\n /** The `byteOffset` accessor property represents the offset (in bytes) of this view from the start of its `ArrayBuffer` or `SharedArrayBuffer`. */\n readonly byteOffset: i32;\n /** Constructs a new `DataView` with the given properties */\n constructor(buffer: ArrayBuffer, byteOffset?: i32, byteLength?: i32);\n /** The `getFloat32()` method gets a signed 32-bit float (float) at the specified byte offset from the start of the `DataView`. */\n getFloat32(byteOffset: i32, littleEndian?: boolean): f32;\n /** The `getFloat64()` method gets a signed 64-bit float (double) at the specified byte offset from the start of the `DataView`. */\n getFloat64(byteOffset: i32, littleEndian?: boolean): f64;\n /** The `getInt8()` method gets a signed 8-bit integer (byte) at the specified byte offset from the start of the `DataView`. */\n getInt8(byteOffset: i32): i8;\n /** The `getInt16()` method gets a signed 16-bit integer (short) at the specified byte offset from the start of the `DataView`. */\n getInt16(byteOffset: i32, littleEndian?: boolean): i16;\n /** The `getInt32()` method gets a signed 32-bit integer (long) at the specified byte offset from the start of the `DataView`. */\n getInt32(byteOffset: i32, littleEndian?: boolean): i32;\n /** The `getUint8()` method gets an unsigned 8-bit integer (unsigned byte) at the specified byte offset from the start of the `DataView`. */\n getUint8(byteOffset: i32): u8;\n /** The `getUint16()` method gets an unsigned 16-bit integer (unsigned short) at the specified byte offset from the start of the `DataView`. */\n getUint16(byteOffset: i32, littleEndian?: boolean): u16;\n /** The `getUint32()` method gets an unsigned 32-bit integer (unsigned long) at the specified byte offset from the start of the `DataView`. */\n getUint32(byteOffset: i32, littleEndian?: boolean): u32;\n /** The `setFloat32()` method stores a signed 32-bit float (float) value at the specified byte offset from the start of the `DataView`. */\n setFloat32(byteOffset: i32, value: f32, littleEndian?: boolean): void;\n /** The `setFloat64()` method stores a signed 64-bit float (double) value at the specified byte offset from the start of the `DataView`. */\n setFloat64(byteOffset: i32, value: f64, littleEndian?: boolean): void;\n /** The `setInt8()` method stores a signed 8-bit integer (byte) value at the specified byte offset from the start of the `DataView`. */\n setInt8(byteOffset: i32, value: i8): void;\n /** The `setInt16()` method stores a signed 16-bit integer (short) value at the specified byte offset from the start of the `DataView`. */\n setInt16(byteOffset: i32, value: i16, littleEndian?: boolean): void;\n /** The `setInt32()` method stores a signed 32-bit integer (long) value at the specified byte offset from the start of the `DataView`. */\n setInt32(byteOffset: i32, value: i32, littleEndian?: boolean): void;\n /** The `setUint8()` method stores an unsigned 8-bit integer (byte) value at the specified byte offset from the start of the `DataView`. */\n setUint8(byteOffset: i32, value: u8): void;\n /** The `setUint16()` method stores an unsigned 16-bit integer (unsigned short) value at the specified byte offset from the start of the `DataView`. */\n setUint16(byteOffset: i32, value: u16, littleEndian?: boolean): void;\n /** The `setUint32()` method stores an unsigned 32-bit integer (unsigned long) value at the specified byte offset from the start of the `DataView`. */\n setUint32(byteOffset: i32, value: u32, littleEndian?: boolean): void;\n /** Returns a string representation of DataView. */\n toString(): string;\n}\n\ndeclare class Array {\n\n static isArray(value: any): value is Array;\n static create(capacity?: i32): Array;\n\n [key: number]: T;\n length: i32;\n constructor(capacity?: i32);\n\n fill(value: T, start?: i32, end?: i32): this;\n every(callbackfn: (element: T, index: i32, array?: Array) => bool): bool;\n findIndex(predicate: (element: T, index: i32, array?: Array) => bool): i32;\n includes(searchElement: T, fromIndex?: i32): bool;\n indexOf(searchElement: T, fromIndex?: i32): i32;\n lastIndexOf(searchElement: T, fromIndex?: i32): i32;\n push(element: T): i32;\n concat(items: T[]): T[];\n copyWithin(target: i32, start: i32, end?: i32): this;\n pop(): T;\n forEach(callbackfn: (value: T, index: i32, array: Array) => void): void;\n map(callbackfn: (value: T, index: i32, array: Array) => U): Array;\n filter(callbackfn: (value: T, index: i32, array: Array) => bool): Array;\n reduce(callbackfn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U, initialValue: U): U;\n reduceRight(callbackfn: (previousValue: U, currentValue: T, currentIndex: i32, array: Array) => U, initialValue: U): U;\n shift(): T;\n some(callbackfn: (element: T, index: i32, array?: Array) => bool): bool;\n unshift(element: T): i32;\n slice(from?: i32, to?: i32): Array;\n splice(start: i32, deleteCount?: i32): Array;\n sort(comparator?: (a: T, b: T) => i32): this;\n join(separator?: string): string;\n reverse(): T[];\n toString(): string;\n}\n\ndeclare class Uint8Array extends Array {}\ndeclare class Uint8ClampedArray extends Array {}\ndeclare class Uint16Array extends Array {}\ndeclare class Uint32Array extends Array {}\ndeclare class Int8Array extends Array {}\ndeclare class Int16Array extends Array {}\ndeclare class Int32Array extends Array {}\ndeclare class Float32Array extends Array {}\ndeclare class Float64Array extends Array {}\n\ninterface ArrayLike {\n length: i32;\n [key: number]: T;\n}\n\n/** Interface for a typed view on an array buffer. */\ninterface ArrayBufferView {\n [key: number]: T;\n /** The {@link ArrayBuffer} referenced by this view. */\n readonly buffer: ArrayBuffer;\n /** The offset in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteOffset: i32;\n /** The length in bytes from the start of the referenced {@link ArrayBuffer}. */\n readonly byteLength: i32;\n}\n\ndeclare class String {\n\n static fromCharCode(ls: i32, hs?: i32): string;\n static fromCharCodes(arr: u16[]): string;\n static fromCodePoint(code: i32): string;\n static fromCodePoints(arr: i32[]): string;\n\n readonly length: i32;\n\n private constructor();\n\n charAt(index: i32): string;\n charCodeAt(index: i32): i32;\n concat(other: string): string;\n indexOf(other: string, fromIndex?: i32): i32;\n lastIndexOf(other: string, fromIndex?: i32): i32;\n includes(other: string): bool;\n startsWith(other: string): bool;\n endsWith(other: string): bool;\n substr(start: u32, length?: u32): string;\n substring(from: i32, to?: i32): string;\n trim(): string;\n trimLeft(): string;\n trimRight(): string;\n trimStart(): string;\n trimEnd(): string;\n padStart(targetLength: i32, padString?: string): string;\n padEnd(targetLength: i32, padString?: string): string;\n replace(search: string, replacement: string): string;\n replaceAll(search: string, replacement: string): string;\n repeat(count?: i32): string;\n slice(beginIndex: i32, endIndex?: i32): string;\n split(separator?: string, limit?: i32): string[];\n toString(): string;\n}\n\ninterface Boolean {}\n\ndeclare class Number {\n private constructor();\n toString(radix?: i32): string;\n}\n\ninterface Object {}\n\ninterface Function {}\n\ninterface RegExp {}\n\ninterface IArguments {}\n\n/** Class for representing a runtime error. Base class of all errors. */\ndeclare class Error {\n\n /** Error name. */\n name: string;\n\n /** Message provided on construction. */\n message: string;\n\n /** Stack trace. */\n stack?: string;\n\n /** Constructs a new error, optionally with a message. */\n constructor(message?: string);\n\n /** Method returns a string representing the specified Error class. */\n toString(): string;\n}\n\n/** Class for indicating an error when a value is not in the set or range of allowed values. */\ndeclare class RangeError extends Error { }\n\n/** Class for indicating an error when a value is not of the expected type. */\ndeclare class TypeError extends Error { }\n\n/** Class for indicating an error when trying to interpret syntactically invalid code. */\ndeclare class SyntaxError extends Error { }\n\ndeclare class Set {\n constructor(entries?: T[]);\n readonly size: i32;\n has(value: T): bool;\n add(value: T): void;\n delete(value: T): bool;\n clear(): void;\n toString(): string;\n [Symbol.iterator](): Iterator;\n}\n\ndeclare class Map {\n constructor(entries?: [K, V][]);\n readonly size: i32;\n set(key: K, value: V): void;\n has(key: K): bool;\n get(key: K): V | null;\n clear(): void;\n entries(): Iterable<[K, V]>;\n keys(): Iterable;\n values(): Iterable;\n delete(key: K): bool;\n toString(): string;\n [Symbol.iterator](): Iterator<[K,V]>;\n}\n\ninterface SymbolConstructor {\n readonly hasInstance: symbol;\n readonly isConcatSpreadable: symbol;\n readonly isRegExp: symbol;\n readonly iterator: symbol;\n readonly match: symbol;\n readonly replace: symbol;\n readonly search: symbol;\n readonly species: symbol;\n readonly split: symbol;\n readonly toPrimitive: symbol;\n readonly toStringTag: symbol;\n readonly unscopables: symbol;\n (description?: string | null): symbol;\n for(key: string): symbol;\n keyFor(sym: symbol): string | null;\n}\ndeclare const Symbol: SymbolConstructor;\n\ninterface Iterable {\n [Symbol.iterator](): Iterator;\n}\n\ninterface Iterator {}\n\ninterface IMath {\n readonly E: f64;\n readonly LN2: f64;\n readonly LN10: f64;\n readonly LOG2E: f64;\n readonly LOG10E: f64;\n readonly PI: f64;\n readonly SQRT1_2: f64;\n readonly SQRT2: f64;\n\n sincos_sin: f64;\n sincos_cos: f64;\n\n abs(x: f64): f64;\n acos(x: f64): f64;\n acosh(x: f64): f64;\n asin(x: f64): f64;\n asinh(x: f64): f64;\n atan(x: f64): f64;\n atan2(y: f64, x: f64): f64;\n atanh(x: f64): f64;\n cbrt(x: f64): f64;\n ceil(x: f64): f64;\n clz32(x: f64): i32;\n cos(x: f64): f64;\n cosh(x: f64): f64;\n exp(x: f64): f64;\n expm1(x: f64): f64;\n floor(x: f64): f64;\n fround(x: f64): f32;\n hypot(value1: f64, value2: f64): f64; // TODO: see std/math\n imul(a: f64, b: f64): i32;\n log(x: f64): f64;\n log10(x: f64): f64;\n log1p(x: f64): f64;\n log2(x: f64): f64;\n max(value1: f64, value2: f64): f64; // TODO: see std/math\n min(value1: f64, value2: f64): f64; // TODO: see std/math\n pow(base: f64, exponent: f64): f64;\n random(): f64;\n round(x: f64): f64;\n sign(x: f64): f64;\n signbit(x: f64): bool;\n sin(x: f64): f64;\n sincos(x: f64): f64;\n sinh(x: f64): f64;\n sqrt(x: f64): f64;\n tan(x: f64): f64;\n tanh(x: f64): f64;\n trunc(x: f64): f64;\n}\n\ndeclare const Math: IMath;\ndeclare const Mathf: IMath;\ndeclare const JSMath: IMath;\n\ndeclare class Date {\n /** Returns the UTC timestamp in milliseconds of the specified date. */\n static UTC(\n year: i32,\n month: i32,\n day: i32,\n hour: i32,\n minute: i32,\n second: i32,\n millisecond: i32\n ): number;\n /** Returns the current UTC timestamp in milliseconds. */\n static now(): number;\n /** Constructs a new date object from an UTC timestamp in milliseconds. */\n constructor(value: number);\n /** Returns the UTC timestamp of this date in milliseconds. */\n getTime(): number;\n /** Sets the UTC timestamp of this date in milliseconds. */\n setTime(value: number): number;\n}\n\ndeclare namespace console {\n /** @deprecated */\n function log(message: string): void;\n}\n\n/** Annotates a class as being unmanaged with limited capabilities. */\ndeclare function unmanaged(constructor: Function): void;\n"}):(()=>{const n=path.join(".","..","std");return{assembly:fs.readFileSync(path.join(n,"assembly","index.d.ts"),"utf8"),portable:fs.readFileSync(path.join(n,"portable","index.d.ts"),"utf8")}})(),exports.compileString=(n,e)=>{"string"==typeof n&&(n={"input.ts":n});const t=Object.create({stdout:createMemoryStream(),stderr:createMemoryStream()});var r=["--binaryFile","binary","--textFile","text"];return Object.keys(e||{}).forEach(n=>{var t=e[n];Array.isArray(t)?t.forEach(e=>r.push("--"+n,String(e))):r.push("--"+n,String(t))}),exports.main(r.concat(Object.keys(n)),{stdout:t.stdout,stderr:t.stderr,readFile:e=>n.hasOwnProperty(e)?n[e]:null,writeFile:(n,e)=>t[n]=e,listFiles:()=>[]}),t},exports.main=function(n,e,t){"function"==typeof e?(t=e,e={}):e||(e={});const r=e.stdout||process.stdout,i=e.stderr||process.stderr,o=e.readFile||z,a=e.writeFile||F,s=e.listFiles||S,l=e.stats||createStats();if(!r)throw Error("'options.stdout' must be specified");if(!i)throw Error("'options.stderr' must be specified");const u=optionsUtil.parse(n,exports.options),f=u.options;if(n=u.arguments,f.noColors?colorsUtil.stdout.supported=colorsUtil.stderr.supported=!1:(colorsUtil.stdout=colorsUtil.from(r),colorsUtil.stderr=colorsUtil.from(i)),u.unknown.length&&u.unknown.forEach(n=>{i.write(colorsUtil.stderr.yellow("WARN: ")+"Unknown option '"+n+"'"+EOL)}),u.trailing.length&&i.write(colorsUtil.stderr.yellow("WARN: ")+"Unsupported trailing arguments: "+u.trailing.join(" ")+EOL),t||(t=function(n){var e=0;return n&&(i.write(colorsUtil.stderr.red("ERROR: ")+n.stack.replace(/^ERROR: /i,"")+EOL),e=1),e}),f.version)return r.write("Version "+exports.version+(isDev?"-dev":"")+EOL),t(null);if(f.help||!n.length){var c=f.help?r:i,d=f.help?colorsUtil.stdout:colorsUtil.stderr;return c.write([d.white("SYNTAX")," "+d.cyan("asc")+" [entryFile ...] [options]","",d.white("EXAMPLES")," "+d.cyan("asc")+" hello.ts"," "+d.cyan("asc")+" hello.ts -b hello.wasm -t hello.wat"," "+d.cyan("asc")+" hello1.ts hello2.ts -b -O > hello.wasm","",d.white("OPTIONS")].concat(optionsUtil.help(exports.options,24,EOL)).join(EOL)+EOL),t(null)}if(!fs.readFileSync){if(o===z)throw Error("'options.readFile' must be specified");if(a===F)throw Error("'options.writeFile' must be specified");if(s===S)throw Error("'options.listFiles' must be specified")}const p=f.baseDir?path.resolve(f.baseDir):".",h=[];f.transform&&f.transform.forEach(n=>h.push(__webpack_require__(12)(path.isAbsolute(n=n.trim())?n:path.join(process.cwd(),n))));var g=null;Object.keys(exports.libraryFiles).forEach(n=>{n.indexOf("/")>=0||(l.parseCount++,l.parseTime+=measure(()=>{g=assemblyscript.parseFile(exports.libraryFiles[n],exports.libraryPrefix+n+".ts",!1,g)}))});const x=[];if(f.lib){let n=f.lib;"string"==typeof n&&(n=n.split(",")),Array.prototype.push.apply(x,n.map(n=>n.trim()));for(let n=0,e=x.length;n{g=assemblyscript.parseFile(a,exports.libraryPrefix+i,!1,g)})}}}function m(){for(var n,e;null!=(n=g.nextFile());){if(e=null,n.startsWith(exports.libraryPrefix)){const t=n.substring(exports.libraryPrefix.length),r=n.substring(exports.libraryPrefix.length)+"/index";if(exports.libraryFiles.hasOwnProperty(t))e=exports.libraryFiles[t],n=exports.libraryPrefix+t+".ts";else if(exports.libraryFiles.hasOwnProperty(r))e=exports.libraryFiles[r],n=exports.libraryPrefix+r+".ts";else for(let i=0,a=x.length;i{assemblyscript.parseFile(e,n,!1,g)})}if(checkDiagnostics(g,i))return t(Error("Parse error"))}{let n=String(f.runtime),e="rt/index-"+n,r=exports.libraryFiles[e];if(null==r){if(null==(r=o((e=n)+".ts",p)))return t(Error("Runtime '"+n+"' not found."))}else e="~lib/"+e;l.parseCount++,l.parseTime+=measure(()=>{g=assemblyscript.parseFile(r,e,!0,g)})}for(let e=0,r=n.length;e{g=assemblyscript.parseFile(a,i,!0,g)})}{let n=m();if(n)return n}!function(n,...e){h.forEach(t=>{"function"==typeof t[n]&&t[n](...e)})}("afterParse",g);{let n=m();if(n)return n}const v=assemblyscript.finishParsing(g);var y=0,b=0;f.optimize&&(y=exports.defaultOptimizeLevel,b=exports.defaultShrinkLevel),"number"==typeof f.optimizeLevel&&(y=f.optimizeLevel),"number"==typeof f.shrinkLevel&&(b=f.shrinkLevel),y=Math.min(Math.max(y,0),3),b=Math.min(Math.max(b,0),2);const _=assemblyscript.createOptions();if(assemblyscript.setTarget(_,0),assemblyscript.setNoAssert(_,f.noAssert),assemblyscript.setImportMemory(_,f.importMemory),assemblyscript.setSharedMemory(_,f.sharedMemory),assemblyscript.setImportTable(_,f.importTable),assemblyscript.setExplicitStart(_,f.explicitStart),assemblyscript.setMemoryBase(_,f.memoryBase>>>0),assemblyscript.setSourceMap(_,null!=f.sourceMap),assemblyscript.setOptimizeLevelHints(_,y,b),assemblyscript.setGlobalAlias(_,"Math","NativeMath"),assemblyscript.setGlobalAlias(_,"Mathf","NativeMathf"),assemblyscript.setGlobalAlias(_,"abort","~lib/builtins/abort"),assemblyscript.setGlobalAlias(_,"trace","~lib/builtins/trace"),f.use){let n=f.use;for(let e=0,r=n.length;e{T=assemblyscript.compileProgram(v,_)})}catch(n){return t(n)}if(checkDiagnostics(g,i))return T&&T.dispose(),t(Error("Compile error"));if(f.validate&&(l.validateCount++,l.validateTime+=measure(()=>{if(!T.validate())return T.dispose(),t(Error("Validate error"))})),"clamp"===f.trapMode)l.optimizeCount++,l.optimizeTime+=measure(()=>{T.runPasses(["trap-mode-clamp"])});else if("js"===f.trapMode)l.optimizeCount++,l.optimizeTime+=measure(()=>{T.runPasses(["trap-mode-js"])});else if("allow"!==f.trapMode)return T.dispose(),t(Error("Unsupported trap mode"));(y>=3||b>=2)&&(y=4),T.setOptimizeLevel(y),T.setShrinkLevel(b),T.setDebugInfo(f.debug);var A=[];if(f.runPasses&&("string"==typeof f.runPasses&&(f.runPasses=f.runPasses.split(",")),f.runPasses.length&&f.runPasses.forEach(n=>{A.indexOf(n)<0&&A.push(n)})),(y>0||b>0)&&(l.optimizeCount++,l.optimizeTime+=measure(()=>{T.optimize()})),A.length&&(l.optimizeCount++,l.optimizeTime+=measure(()=>{T.runPasses(A.map(n=>n.trim()))})),!f.noEmit){let n=!1,e=!1;if(null!=f.outFile&&(/\.was?t$/.test(f.outFile)&&null==f.textFile?f.textFile=f.outFile:/\.js$/.test(f.outFile)&&null==f.asmjsFile?f.asmjsFile=f.outFile:null==f.binaryFile&&(f.binaryFile=f.outFile)),null!=f.binaryFile){let r,s=null!=f.sourceMap?f.sourceMap.length?f.sourceMap:path.basename(f.binaryFile)+".map":null;if(l.emitCount++,l.emitTime+=measure(()=>{r=T.toBinary(s)}),f.binaryFile.length?a(f.binaryFile,r.output,p):(I(r.output),n=!0),e=!0,null!=r.sourceMap)if(f.binaryFile.length){let n=JSON.parse(r.sourceMap);n.sourceRoot=exports.sourceMapRoot,n.sources.forEach((e,r)=>{let i=null;if(e.startsWith(exports.libraryPrefix)){let n=e.substring(exports.libraryPrefix.length).replace(/\.ts$/,"");if(exports.libraryFiles.hasOwnProperty(n))i=exports.libraryFiles[n];else for(let n=0,t=x.length;n{t=T.toAsmjs()}),a(f.asmjsFile,t,p)):n||(l.emitCount++,l.emitTime+=measure(()=>{t=T.toAsmjs()}),I(t),n=!0),e=!0}if(null!=f.idlFile){let t;f.idlFile.length?(l.emitCount++,l.emitTime+=measure(()=>{t=assemblyscript.buildIDL(v)}),a(f.idlFile,t,p)):n||(l.emitCount++,l.emitTime+=measure(()=>{t=assemblyscript.buildIDL(v)}),I(t),n=!0),e=!0}if(null!=f.tsdFile){let t;f.tsdFile.length?(l.emitCount++,l.emitTime+=measure(()=>{t=assemblyscript.buildTSD(v)}),a(f.tsdFile,t,p)):n||(l.emitCount++,l.emitTime+=measure(()=>{t=assemblyscript.buildTSD(v)}),I(t),n=!0),e=!0}if(null!=f.textFile||!e){let e;f.textFile&&f.textFile.length?(l.emitCount++,l.emitTime+=measure(()=>{e=T.toText()}),a(f.textFile,e,p)):n||(l.emitCount++,l.emitTime+=measure(()=>{e=T.toText()}),I(e))}}return T.dispose(),f.measure&&printStats(l,i),f.printrtti&&printRTTI(v,i),t(null);function z(n,e){try{let t;return l.readCount++,l.readTime+=measure(()=>{t=fs.readFileSync(path.join(e,n),{encoding:"utf8"})}),t}catch(n){return null}}function F(n,e,t){try{return l.writeCount++,l.writeTime+=measure(()=>{mkdirp(path.join(t,path.dirname(n))),"string"==typeof e?fs.writeFileSync(path.join(t,n),e,{encoding:"utf8"}):fs.writeFileSync(path.join(t,n),e)}),!0}catch(n){return!1}}function S(n,e){var t;try{return l.readTime+=measure(()=>{t=fs.readdirSync(path.join(e,n)).filter(n=>/^(?!.*\.d\.ts$).*\.ts$/.test(n))}),t}catch(n){return[]}}function I(n){I.used||(l.writeCount++,I.used=!0),l.writeTime+=measure(()=>{"string"==typeof n?r.write(n,{encoding:"utf8"}):r.write(n)})}},exports.checkDiagnostics=checkDiagnostics,exports.createStats=createStats,process.hrtime||(process.hrtime=__webpack_require__(13)),exports.measure=measure,exports.formatTime=formatTime,exports.printStats=printStats,exports.printRTTI=printRTTI;var allocBuffer=void 0!==global&&global.Buffer?global.Buffer.allocUnsafe||function(n){return new global.Buffer(n)}:function(n){return new Uint8Array(n)};function createMemoryStream(n){var e=[];return e.write=function(e){if(n&&n(e),"string"==typeof e){let n=allocBuffer(utf8.length(e));utf8.write(e,n,0),e=n}this.push(e)},e.reset=function(){e.length=0},e.toBuffer=function(){for(var n=0,e=0,t=this.length;e191&&r<224?o[a++]=(31&r)<<6|63&n[e++]:r>239&&r<365?(r=((7&r)<<18|(63&n[e++])<<12|(63&n[e++])<<6|63&n[e++])-65536,o[a++]=55296+(r>>10),o[a++]=56320+(1023&r)):o[a++]=(15&r)<<12|(63&n[e++])<<6|63&n[e++],a>8191&&((i||(i=[])).push(String.fromCharCode.apply(String,o)),a=0);return i?(a&&i.push(String.fromCharCode.apply(String,o.slice(0,a))),i.join("")):String.fromCharCode.apply(String,o.slice(0,a))},r.write=function(n,e,t){for(var r,i,o=t,a=0;a>6|192,e[t++]=63&r|128):55296==(64512&r)&&56320==(64512&(i=n.charCodeAt(a+1)))?(r=65536+((1023&r)<<10)+(1023&i),++a,e[t++]=r>>18|240,e[t++]=r>>12&63|128,e[t++]=r>>6&63|128,e[t++]=63&r|128):(e[t++]=r>>12|224,e[t++]=r>>6&63|128,e[t++]=63&r|128);return t-o}},function(n,e,t){(function(n){var t=void 0!==n&&n||{},r=t.env&&"CI"in t.env;function i(n,t){var i=t||{};return i.supported=n&&!!n.isTTY||r,i.gray=n=>i.supported?e.GRAY+n+e.RESET:n,i.red=n=>i.supported?e.RED+n+e.RESET:n,i.green=n=>i.supported?e.GREEN+n+e.RESET:n,i.yellow=n=>i.supported?e.YELLOW+n+e.RESET:n,i.blue=n=>i.supported?e.BLUE+n+e.RESET:n,i.magenta=n=>i.supported?e.MAGENTA+n+e.RESET:n,i.cyan=n=>i.supported?e.CYAN+n+e.RESET:n,i.white=n=>i.supported?e.WHITE+n+e.RESET:n,i}e.stdout=i(t.stdout,e),e.stderr=i(t.stderr),e.from=i,e.GRAY="",e.RED="",e.GREEN="",e.YELLOW="",e.BLUE="",e.MAGENTA="",e.CYAN="",e.WHITE="",e.RESET=""}).call(this,t(0))},function(n,e){e.parse=function(n,e){var t={},r=[],arguments=[],i=[],o={};Object.keys(e).forEach(n=>{if(!n.startsWith(" ")){var r=e[n];null!=r.alias&&("string"==typeof r.alias?o[r.alias]=n:Array.isArray(r.alias)&&r.alias.forEach(e=>o[e]=n)),null!=r.default&&(t[n]=r.default)}});for(var a=0,s=(n=n.slice()).length;at[n]=s.value[n])}else r.push(i)}for(;a{var a=n[e];if(null!=a.description){for(var s="";s.length{for(let e=0;e 0\n var up = 0;\n for (var i = parts.length - 1; i >= 0; i--) {\n var last = parts[i];\n if (last === '.') {\n parts.splice(i, 1);\n } else if (last === '..') {\n parts.splice(i, 1);\n up++;\n } else if (up) {\n parts.splice(i, 1);\n up--;\n }\n }\n\n // if the path is allowed to go above the root, restore leading ..s\n if (allowAboveRoot) {\n for (; up--; up) {\n parts.unshift('..');\n }\n }\n\n return parts;\n}\n\n// Split a filename into [root, dir, basename, ext], unix version\n// 'root' is just a slash, or nothing.\nvar splitPathRe =\n /^(\\/?|)([\\s\\S]*?)((?:\\.{1,2}|[^\\/]+?|)(\\.[^.\\/]*|))(?:[\\/]*)$/;\nvar splitPath = function(filename) {\n return splitPathRe.exec(filename).slice(1);\n};\n\n// path.resolve([from ...], to)\n// posix version\nexports.resolve = function() {\n var resolvedPath = '',\n resolvedAbsolute = false;\n\n for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n var path = (i >= 0) ? arguments[i] : process.cwd();\n\n // Skip empty and invalid entries\n if (typeof path !== 'string') {\n throw new TypeError('Arguments to path.resolve must be strings');\n } else if (!path) {\n continue;\n }\n\n resolvedPath = path + '/' + resolvedPath;\n resolvedAbsolute = path.charAt(0) === '/';\n }\n\n // At this point the path should be resolved to a full absolute path, but\n // handle relative paths to be safe (might happen when process.cwd() fails)\n\n // Normalize the path\n resolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) {\n return !!p;\n }), !resolvedAbsolute).join('/');\n\n return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';\n};\n\n// path.normalize(path)\n// posix version\nexports.normalize = function(path) {\n var isAbsolute = exports.isAbsolute(path),\n trailingSlash = substr(path, -1) === '/';\n\n // Normalize the path\n path = normalizeArray(filter(path.split('/'), function(p) {\n return !!p;\n }), !isAbsolute).join('/');\n\n if (!path && !isAbsolute) {\n path = '.';\n }\n if (path && trailingSlash) {\n path += '/';\n }\n\n return (isAbsolute ? '/' : '') + path;\n};\n\n// posix version\nexports.isAbsolute = function(path) {\n return path.charAt(0) === '/';\n};\n\n// posix version\nexports.join = function() {\n var paths = Array.prototype.slice.call(arguments, 0);\n return exports.normalize(filter(paths, function(p, index) {\n if (typeof p !== 'string') {\n throw new TypeError('Arguments to path.join must be strings');\n }\n return p;\n }).join('/'));\n};\n\n\n// path.relative(from, to)\n// posix version\nexports.relative = function(from, to) {\n from = exports.resolve(from).substr(1);\n to = exports.resolve(to).substr(1);\n\n function trim(arr) {\n var start = 0;\n for (; start < arr.length; start++) {\n if (arr[start] !== '') break;\n }\n\n var end = arr.length - 1;\n for (; end >= 0; end--) {\n if (arr[end] !== '') break;\n }\n\n if (start > end) return [];\n return arr.slice(start, end - start + 1);\n }\n\n var fromParts = trim(from.split('/'));\n var toParts = trim(to.split('/'));\n\n var length = Math.min(fromParts.length, toParts.length);\n var samePartsLength = length;\n for (var i = 0; i < length; i++) {\n if (fromParts[i] !== toParts[i]) {\n samePartsLength = i;\n break;\n }\n }\n\n var outputParts = [];\n for (var i = samePartsLength; i < fromParts.length; i++) {\n outputParts.push('..');\n }\n\n outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n return outputParts.join('/');\n};\n\nexports.sep = '/';\nexports.delimiter = ':';\n\nexports.dirname = function(path) {\n var result = splitPath(path),\n root = result[0],\n dir = result[1];\n\n if (!root && !dir) {\n // No dirname whatsoever\n return '.';\n }\n\n if (dir) {\n // It has a dirname, strip trailing slash\n dir = dir.substr(0, dir.length - 1);\n }\n\n return root + dir;\n};\n\n\nexports.basename = function(path, ext) {\n var f = splitPath(path)[2];\n // TODO: make this comparison case-insensitive on windows?\n if (ext && f.substr(-1 * ext.length) === ext) {\n f = f.substr(0, f.length - ext.length);\n }\n return f;\n};\n\n\nexports.extname = function(path) {\n return splitPath(path)[3];\n};\n\nfunction filter (xs, f) {\n if (xs.filter) return xs.filter(f);\n var res = [];\n for (var i = 0; i < xs.length; i++) {\n if (f(xs[i], i, xs)) res.push(xs[i]);\n }\n return res;\n}\n\n// String.prototype.substr - negative index don't work in IE8\nvar substr = 'ab'.substr(-1) === 'b'\n ? function (str, start, len) { return str.substr(start, len) }\n : function (str, start, len) {\n if (start < 0) start = str.length + start;\n return str.substr(start, len);\n }\n;\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","/**\r\n * Compiler frontend for node.js\r\n *\r\n * Uses the low-level API exported from src/index.ts so it works with the compiler compiled to\r\n * JavaScript as well as the compiler compiled to WebAssembly (eventually). Runs the sources\r\n * directly through ts-node if distribution files are not present (indicated by a `-dev` version).\r\n *\r\n * Can also be packaged as a bundle suitable for in-browser use with the standard library injected\r\n * in the build step. See dist/asc.js for the bundle and webpack.config.js for building details.\r\n *\r\n * @module cli/asc\r\n */\r\n\r\n// Use \".\" instead of \"/\" as cwd in browsers\r\nif (process.browser) process.cwd = function() { return \".\"; };\r\n\r\nconst fs = require(\"fs\");\r\nconst path = require(\"path\");\r\nconst utf8 = require(\"@protobufjs/utf8\");\r\nconst colorsUtil = require(\"./util/colors\");\r\nconst optionsUtil = require(\"./util/options\");\r\nconst mkdirp = require(\"./util/mkdirp\");\r\nconst EOL = process.platform === \"win32\" ? \"\\r\\n\" : \"\\n\";\r\n\r\n// global.Binaryen = require(\"../lib/binaryen\");\r\n\r\n// Emscripten adds an `uncaughtException` listener to Binaryen that results in an additional\r\n// useless code fragment on top of an actual error. suppress this:\r\nif (process.removeAllListeners) process.removeAllListeners(\"uncaughtException\");\r\n\r\n// Use distribution files if present, otherwise run the sources directly\r\nvar assemblyscript, isDev = false;\r\n(() => {\r\n try { // `asc` on the command line\r\n assemblyscript = require(\"../dist/assemblyscript.js\");\r\n } catch (e) {\r\n try { // `asc` on the command line without dist files\r\n require(\"ts-node\").register({ project: path.join(__dirname, \"..\", \"src\", \"tsconfig.json\") });\r\n require(\"../src/glue/js\");\r\n assemblyscript = require(\"../src\");\r\n isDev = true;\r\n } catch (e_ts) {\r\n try { // `require(\"dist/asc.js\")` in explicit browser tests\r\n assemblyscript = eval(\"require('./assemblyscript')\");\r\n } catch (e) {\r\n // combine both errors that lead us here\r\n e.stack = e_ts.stack + \"\\n---\\n\" + e.stack;\r\n throw e;\r\n }\r\n }\r\n }\r\n})();\r\n\r\n/** Whether this is a webpack bundle or not. */\r\nexports.isBundle = typeof BUNDLE_VERSION === \"string\";\r\n\r\n/** Whether asc runs the sources directly or not. */\r\nexports.isDev = isDev;\r\n\r\n/** AssemblyScript version. */\r\nexports.version = exports.isBundle ? BUNDLE_VERSION : require(\"../package.json\").version;\r\n\r\n/** Available CLI options. */\r\nexports.options = require(\"./asc.json\");\r\n\r\n/** Common root used in source maps. */\r\nexports.sourceMapRoot = \"assemblyscript:///\";\r\n\r\n/** Prefix used for library files. */\r\nexports.libraryPrefix = assemblyscript.LIBRARY_PREFIX;\r\n\r\n/** Default Binaryen optimization level. */\r\nexports.defaultOptimizeLevel = 3;\r\n\r\n/** Default Binaryen shrink level. */\r\nexports.defaultShrinkLevel = 1;\r\n\r\n/** Bundled library files. */\r\nexports.libraryFiles = exports.isBundle ? BUNDLE_LIBRARY : (() => { // set up if not a bundle\r\n const libDir = path.join(__dirname, \"..\", \"std\", \"assembly\");\r\n const libFiles = require(\"glob\").sync(\"**/!(*.d).ts\", { cwd: libDir });\r\n const bundled = {};\r\n libFiles.forEach(file => bundled[file.replace(/\\.ts$/, \"\")] = fs.readFileSync(path.join(libDir, file), \"utf8\" ));\r\n return bundled;\r\n})();\r\n\r\n/** Bundled definition files. */\r\nexports.definitionFiles = exports.isBundle ? BUNDLE_DEFINITIONS : (() => { // set up if not a bundle\r\n const stdDir = path.join(__dirname, \"..\", \"std\");\r\n return {\r\n \"assembly\": fs.readFileSync(path.join(stdDir, \"assembly\", \"index.d.ts\"), \"utf8\"),\r\n \"portable\": fs.readFileSync(path.join(stdDir, \"portable\", \"index.d.ts\"), \"utf8\")\r\n };\r\n})();\r\n\r\n/** Convenience function that parses and compiles source strings directly. */\r\nexports.compileString = (sources, options) => {\r\n if (typeof sources === \"string\") sources = { \"input.ts\": sources };\r\n const output = Object.create({\r\n stdout: createMemoryStream(),\r\n stderr: createMemoryStream()\r\n });\r\n var argv = [\r\n \"--binaryFile\", \"binary\",\r\n \"--textFile\", \"text\",\r\n ];\r\n Object.keys(options || {}).forEach(key => {\r\n var val = options[key];\r\n if (Array.isArray(val)) val.forEach(val => argv.push(\"--\" + key, String(val)));\r\n else argv.push(\"--\" + key, String(val));\r\n });\r\n exports.main(argv.concat(Object.keys(sources)), {\r\n stdout: output.stdout,\r\n stderr: output.stderr,\r\n readFile: name => sources.hasOwnProperty(name) ? sources[name] : null,\r\n writeFile: (name, contents) => output[name] = contents,\r\n listFiles: () => []\r\n });\r\n return output;\r\n}\r\n\r\n/** Runs the command line utility using the specified arguments array. */\r\nexports.main = function main(argv, options, callback) {\r\n if (typeof options === \"function\") {\r\n callback = options;\r\n options = {};\r\n } else if (!options) {\r\n options = {};\r\n }\r\n\r\n const stdout = options.stdout || process.stdout;\r\n const stderr = options.stderr || process.stderr;\r\n const readFile = options.readFile || readFileNode;\r\n const writeFile = options.writeFile || writeFileNode;\r\n const listFiles = options.listFiles || listFilesNode;\r\n const stats = options.stats || createStats();\r\n\r\n // Output must be specified if not present in the environment\r\n if (!stdout) throw Error(\"'options.stdout' must be specified\");\r\n if (!stderr) throw Error(\"'options.stderr' must be specified\");\r\n\r\n const opts = optionsUtil.parse(argv, exports.options);\r\n const args = opts.options;\r\n argv = opts.arguments;\r\n if (args.noColors) {\r\n colorsUtil.stdout.supported =\r\n colorsUtil.stderr.supported = false;\r\n } else {\r\n colorsUtil.stdout = colorsUtil.from(stdout);\r\n colorsUtil.stderr = colorsUtil.from(stderr);\r\n }\r\n\r\n // Check for unknown arguments\r\n if (opts.unknown.length) {\r\n opts.unknown.forEach(arg => {\r\n stderr.write(colorsUtil.stderr.yellow(\"WARN: \") + \"Unknown option '\" + arg + \"'\" + EOL);\r\n });\r\n }\r\n\r\n // Check for trailing arguments\r\n if (opts.trailing.length) {\r\n stderr.write(colorsUtil.stderr.yellow(\"WARN: \") + \"Unsupported trailing arguments: \" + opts.trailing.join(\" \") + EOL);\r\n }\r\n\r\n // Use default callback if none is provided\r\n if (!callback) callback = function defaultCallback(err) {\r\n var code = 0;\r\n if (err) {\r\n stderr.write(colorsUtil.stderr.red(\"ERROR: \") + err.stack.replace(/^ERROR: /i, \"\") + EOL);\r\n code = 1;\r\n }\r\n return code;\r\n };\r\n\r\n // Just print the version if requested\r\n if (args.version) {\r\n stdout.write(\"Version \" + exports.version + (isDev ? \"-dev\" : \"\") + EOL);\r\n return callback(null);\r\n }\r\n // Print the help message if requested or no source files are provided\r\n if (args.help || !argv.length) {\r\n var out = args.help ? stdout : stderr;\r\n var color = args.help ? colorsUtil.stdout : colorsUtil.stderr;\r\n out.write([\r\n color.white(\"SYNTAX\"),\r\n \" \" + color.cyan(\"asc\") + \" [entryFile ...] [options]\",\r\n \"\",\r\n color.white(\"EXAMPLES\"),\r\n \" \" + color.cyan(\"asc\") + \" hello.ts\",\r\n \" \" + color.cyan(\"asc\") + \" hello.ts -b hello.wasm -t hello.wat\",\r\n \" \" + color.cyan(\"asc\") + \" hello1.ts hello2.ts -b -O > hello.wasm\",\r\n \"\",\r\n color.white(\"OPTIONS\"),\r\n ].concat(\r\n optionsUtil.help(exports.options, 24, EOL)\r\n ).join(EOL) + EOL);\r\n return callback(null);\r\n }\r\n\r\n // I/O must be specified if not present in the environment\r\n if (!fs.readFileSync) {\r\n if (readFile === readFileNode) throw Error(\"'options.readFile' must be specified\");\r\n if (writeFile === writeFileNode) throw Error(\"'options.writeFile' must be specified\");\r\n if (listFiles === listFilesNode) throw Error(\"'options.listFiles' must be specified\");\r\n }\r\n\r\n // Set up base directory\r\n const baseDir = args.baseDir ? path.resolve(args.baseDir) : \".\";\r\n\r\n // Set up transforms\r\n const transforms = [];\r\n if (args.transform) {\r\n args.transform.forEach(transform =>\r\n transforms.push(\r\n require(\r\n path.isAbsolute(transform = transform.trim())\r\n ? transform\r\n : path.join(process.cwd(), transform)\r\n )\r\n )\r\n );\r\n }\r\n function applyTransform(name, ...args) {\r\n transforms.forEach(transform => {\r\n if (typeof transform[name] === \"function\") transform[name](...args);\r\n });\r\n }\r\n\r\n // Begin parsing\r\n var parser = null;\r\n\r\n // Include library files\r\n Object.keys(exports.libraryFiles).forEach(libPath => {\r\n if (libPath.indexOf(\"/\") >= 0) return; // in sub-directory: imported on demand\r\n stats.parseCount++;\r\n stats.parseTime += measure(() => {\r\n parser = assemblyscript.parseFile(\r\n exports.libraryFiles[libPath],\r\n exports.libraryPrefix + libPath + \".ts\",\r\n false,\r\n parser\r\n );\r\n });\r\n });\r\n const customLibDirs = [];\r\n if (args.lib) {\r\n let lib = args.lib;\r\n if (typeof lib === \"string\") lib = lib.split(\",\");\r\n Array.prototype.push.apply(customLibDirs, lib.map(lib => lib.trim()));\r\n for (let i = 0, k = customLibDirs.length; i < k; ++i) { // custom\r\n let libDir = customLibDirs[i];\r\n let libFiles;\r\n if (libDir.endsWith(\".ts\")) {\r\n libFiles = [ path.basename(libDir) ];\r\n libDir = path.dirname(libDir);\r\n } else {\r\n libFiles = listFiles(libDir);\r\n }\r\n for (let j = 0, l = libFiles.length; j < l; ++j) {\r\n let libPath = libFiles[j];\r\n let libText = readFile(libPath, libDir);\r\n if (libText === null) return callback(Error(\"Library file '\" + libPath + \"' not found.\"));\r\n stats.parseCount++;\r\n stats.parseTime += measure(() => {\r\n parser = assemblyscript.parseFile(\r\n libText,\r\n exports.libraryPrefix + libPath,\r\n false,\r\n parser\r\n );\r\n });\r\n }\r\n }\r\n }\r\n\r\n // Parses the backlog of imported files after including entry files\r\n function parseBacklog() {\r\n var sourcePath, sourceText;\r\n while ((sourcePath = parser.nextFile()) != null) {\r\n sourceText = null;\r\n\r\n // Load library file if explicitly requested\r\n if (sourcePath.startsWith(exports.libraryPrefix)) {\r\n const plainName = sourcePath.substring(exports.libraryPrefix.length);\r\n const indexName = sourcePath.substring(exports.libraryPrefix.length) + \"/index\";\r\n if (exports.libraryFiles.hasOwnProperty(plainName)) {\r\n sourceText = exports.libraryFiles[plainName];\r\n sourcePath = exports.libraryPrefix + plainName + \".ts\";\r\n } else if (exports.libraryFiles.hasOwnProperty(indexName)) {\r\n sourceText = exports.libraryFiles[indexName];\r\n sourcePath = exports.libraryPrefix + indexName + \".ts\";\r\n } else {\r\n for (let i = 0, k = customLibDirs.length; i < k; ++i) {\r\n sourceText = readFile(plainName + \".ts\", customLibDirs[i]);\r\n if (sourceText !== null) {\r\n sourcePath = exports.libraryPrefix + plainName + \".ts\";\r\n break;\r\n } else {\r\n sourceText = readFile(indexName + \".ts\", customLibDirs[i]);\r\n if (sourceText !== null) {\r\n sourcePath = exports.libraryPrefix + indexName + \".ts\";\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n\r\n // Otherwise try nextFile.ts, nextFile/index.ts, ~lib/nextFile.ts, ~lib/nextFile/index.ts\r\n } else {\r\n const plainName = sourcePath;\r\n const indexName = sourcePath + \"/index\";\r\n sourceText = readFile(plainName + \".ts\", baseDir);\r\n if (sourceText !== null) {\r\n sourcePath = plainName + \".ts\";\r\n } else {\r\n sourceText = readFile(indexName + \".ts\", baseDir);\r\n if (sourceText !== null) {\r\n sourcePath = indexName + \".ts\";\r\n } else if (!plainName.startsWith(\".\")) {\r\n if (exports.libraryFiles.hasOwnProperty(plainName)) {\r\n sourceText = exports.libraryFiles[plainName];\r\n sourcePath = exports.libraryPrefix + plainName + \".ts\";\r\n } else if (exports.libraryFiles.hasOwnProperty(indexName)) {\r\n sourceText = exports.libraryFiles[indexName];\r\n sourcePath = exports.libraryPrefix + indexName + \".ts\";\r\n } else {\r\n for (let i = 0, k = customLibDirs.length; i < k; ++i) {\r\n const dir = customLibDirs[i];\r\n sourceText = readFile(plainName + \".ts\", dir);\r\n if (sourceText !== null) {\r\n sourcePath = exports.libraryPrefix + plainName + \".ts\";\r\n break;\r\n } else {\r\n sourceText = readFile(indexName + \".ts\", dir);\r\n if (sourceText !== null) {\r\n sourcePath = exports.libraryPrefix + indexName + \".ts\";\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n }\r\n }\r\n if (sourceText == null) {\r\n return callback(Error(\"Import file '\" + sourcePath + \".ts' not found.\"));\r\n }\r\n stats.parseCount++;\r\n stats.parseTime += measure(() => {\r\n assemblyscript.parseFile(sourceText, sourcePath, false, parser);\r\n });\r\n }\r\n if (checkDiagnostics(parser, stderr)) {\r\n return callback(Error(\"Parse error\"));\r\n }\r\n }\r\n\r\n // Include runtime template before entry files so its setup runs first\r\n {\r\n let runtimeName = String(args.runtime);\r\n let runtimePath = \"rt/index-\" + runtimeName;\r\n let runtimeText = exports.libraryFiles[runtimePath];\r\n if (runtimeText == null) {\r\n runtimePath = runtimeName;\r\n runtimeText = readFile(runtimePath + \".ts\", baseDir);\r\n if (runtimeText == null) {\r\n return callback(Error(\"Runtime '\" + runtimeName + \"' not found.\"));\r\n }\r\n } else {\r\n runtimePath = \"~lib/\" + runtimePath;\r\n }\r\n stats.parseCount++;\r\n stats.parseTime += measure(() => {\r\n parser = assemblyscript.parseFile(runtimeText, runtimePath, true, parser);\r\n });\r\n }\r\n\r\n // Include entry files\r\n for (let i = 0, k = argv.length; i < k; ++i) {\r\n const filename = argv[i];\r\n\r\n let sourcePath = String(filename).replace(/\\\\/g, \"/\").replace(/(\\.ts|\\/)$/, \"\");\r\n\r\n // Try entryPath.ts, then entryPath/index.ts\r\n let sourceText = readFile(sourcePath + \".ts\", baseDir);\r\n if (sourceText === null) {\r\n sourceText = readFile(sourcePath + \"/index.ts\", baseDir);\r\n if (sourceText === null) {\r\n return callback(Error(\"Entry file '\" + sourcePath + \".ts' not found.\"));\r\n } else {\r\n sourcePath += \"/index.ts\";\r\n }\r\n } else {\r\n sourcePath += \".ts\";\r\n }\r\n\r\n stats.parseCount++;\r\n stats.parseTime += measure(() => {\r\n parser = assemblyscript.parseFile(sourceText, sourcePath, true, parser);\r\n });\r\n }\r\n\r\n // Parse entry files\r\n {\r\n let code = parseBacklog();\r\n if (code) return code;\r\n }\r\n\r\n // Call afterParse transform hook\r\n applyTransform(\"afterParse\", parser);\r\n\r\n // Parse additional files, if any\r\n {\r\n let code = parseBacklog();\r\n if (code) return code;\r\n }\r\n\r\n // Finish parsing\r\n const program = assemblyscript.finishParsing(parser);\r\n\r\n // Set up optimization levels\r\n var optimizeLevel = 0;\r\n var shrinkLevel = 0;\r\n if (args.optimize) {\r\n optimizeLevel = exports.defaultOptimizeLevel;\r\n shrinkLevel = exports.defaultShrinkLevel;\r\n }\r\n if (typeof args.optimizeLevel === \"number\") {\r\n optimizeLevel = args.optimizeLevel;\r\n }\r\n if (typeof args.shrinkLevel === \"number\") {\r\n shrinkLevel = args.shrinkLevel;\r\n }\r\n optimizeLevel = Math.min(Math.max(optimizeLevel, 0), 3);\r\n shrinkLevel = Math.min(Math.max(shrinkLevel, 0), 2);\r\n\r\n // Begin compilation\r\n const compilerOptions = assemblyscript.createOptions();\r\n assemblyscript.setTarget(compilerOptions, 0);\r\n assemblyscript.setNoAssert(compilerOptions, args.noAssert);\r\n assemblyscript.setImportMemory(compilerOptions, args.importMemory);\r\n assemblyscript.setSharedMemory(compilerOptions, args.sharedMemory);\r\n assemblyscript.setImportTable(compilerOptions, args.importTable);\r\n assemblyscript.setExplicitStart(compilerOptions, args.explicitStart);\r\n assemblyscript.setMemoryBase(compilerOptions, args.memoryBase >>> 0);\r\n assemblyscript.setSourceMap(compilerOptions, args.sourceMap != null);\r\n assemblyscript.setOptimizeLevelHints(compilerOptions, optimizeLevel, shrinkLevel);\r\n\r\n // Initialize default aliases\r\n assemblyscript.setGlobalAlias(compilerOptions, \"Math\", \"NativeMath\");\r\n assemblyscript.setGlobalAlias(compilerOptions, \"Mathf\", \"NativeMathf\");\r\n assemblyscript.setGlobalAlias(compilerOptions, \"abort\", \"~lib/builtins/abort\");\r\n assemblyscript.setGlobalAlias(compilerOptions, \"trace\", \"~lib/builtins/trace\");\r\n\r\n // Add or override aliases if specified\r\n if (args.use) {\r\n let aliases = args.use;\r\n for (let i = 0, k = aliases.length; i < k; ++i) {\r\n let part = aliases[i];\r\n let p = part.indexOf(\"=\");\r\n if (p < 0) return callback(Error(\"Global alias '\" + part + \"' is invalid.\"));\r\n let name = part.substring(0, p).trim();\r\n let alias = part.substring(p + 1).trim();\r\n if (!name.length) return callback(Error(\"Global alias '\" + part + \"' is invalid.\"));\r\n assemblyscript.setGlobalAlias(compilerOptions, name, alias);\r\n }\r\n }\r\n\r\n // Enable additional features if specified\r\n var features = args.enable;\r\n if (features != null) {\r\n if (typeof features === \"string\") features = features.split(\",\");\r\n for (let i = 0, k = features.length; i < k; ++i) {\r\n let name = features[i].trim();\r\n let flag = assemblyscript[\"FEATURE_\" + name.replace(/\\-/g, \"_\").toUpperCase()];\r\n if (!flag) return callback(Error(\"Feature '\" + name + \"' is unknown.\"));\r\n assemblyscript.enableFeature(compilerOptions, flag);\r\n }\r\n }\r\n\r\n var module;\r\n stats.compileCount++;\r\n try {\r\n stats.compileTime += measure(() => {\r\n module = assemblyscript.compileProgram(program, compilerOptions);\r\n });\r\n } catch (e) {\r\n return callback(e);\r\n }\r\n if (checkDiagnostics(parser, stderr)) {\r\n if (module) module.dispose();\r\n return callback(Error(\"Compile error\"));\r\n }\r\n\r\n // Validate the module if requested\r\n if (args.validate) {\r\n stats.validateCount++;\r\n stats.validateTime += measure(() => {\r\n if (!module.validate()) {\r\n module.dispose();\r\n return callback(Error(\"Validate error\"));\r\n }\r\n });\r\n }\r\n\r\n // Set Binaryen-specific options\r\n if (args.trapMode === \"clamp\") {\r\n stats.optimizeCount++;\r\n stats.optimizeTime += measure(() => {\r\n module.runPasses([ \"trap-mode-clamp\" ]);\r\n });\r\n } else if (args.trapMode === \"js\") {\r\n stats.optimizeCount++;\r\n stats.optimizeTime += measure(() => {\r\n module.runPasses([ \"trap-mode-js\" ]);\r\n });\r\n } else if (args.trapMode !== \"allow\") {\r\n module.dispose();\r\n return callback(Error(\"Unsupported trap mode\"));\r\n }\r\n\r\n // Implicitly run costly non-LLVM optimizations on -O3 or -Oz\r\n // see: https://github.com/WebAssembly/binaryen/pull/1596\r\n if (optimizeLevel >= 3 || shrinkLevel >= 2) optimizeLevel = 4;\r\n\r\n module.setOptimizeLevel(optimizeLevel);\r\n module.setShrinkLevel(shrinkLevel);\r\n module.setDebugInfo(args.debug);\r\n\r\n var runPasses = [];\r\n if (args.runPasses) {\r\n if (typeof args.runPasses === \"string\") {\r\n args.runPasses = args.runPasses.split(\",\");\r\n }\r\n if (args.runPasses.length) {\r\n args.runPasses.forEach(pass => {\r\n if (runPasses.indexOf(pass) < 0)\r\n runPasses.push(pass);\r\n });\r\n }\r\n }\r\n\r\n // Optimize the module if requested\r\n if (optimizeLevel > 0 || shrinkLevel > 0) {\r\n stats.optimizeCount++;\r\n stats.optimizeTime += measure(() => {\r\n module.optimize();\r\n });\r\n }\r\n\r\n // Run additional passes if requested\r\n if (runPasses.length) {\r\n stats.optimizeCount++;\r\n stats.optimizeTime += measure(() => {\r\n module.runPasses(runPasses.map(pass => pass.trim()));\r\n });\r\n }\r\n\r\n // Prepare output\r\n if (!args.noEmit) {\r\n let hasStdout = false;\r\n let hasOutput = false;\r\n\r\n if (args.outFile != null) {\r\n if (/\\.was?t$/.test(args.outFile) && args.textFile == null) {\r\n args.textFile = args.outFile;\r\n } else if (/\\.js$/.test(args.outFile) && args.asmjsFile == null) {\r\n args.asmjsFile = args.outFile;\r\n } else if (args.binaryFile == null) {\r\n args.binaryFile = args.outFile;\r\n }\r\n }\r\n\r\n // Write binary\r\n if (args.binaryFile != null) {\r\n let sourceMapURL = args.sourceMap != null\r\n ? args.sourceMap.length\r\n ? args.sourceMap\r\n : path.basename(args.binaryFile) + \".map\"\r\n : null;\r\n\r\n let wasm;\r\n stats.emitCount++;\r\n stats.emitTime += measure(() => {\r\n wasm = module.toBinary(sourceMapURL)\r\n });\r\n\r\n if (args.binaryFile.length) {\r\n writeFile(args.binaryFile, wasm.output, baseDir);\r\n } else {\r\n writeStdout(wasm.output);\r\n hasStdout = true;\r\n }\r\n hasOutput = true;\r\n\r\n // Post-process source map\r\n if (wasm.sourceMap != null) {\r\n if (args.binaryFile.length) {\r\n let sourceMap = JSON.parse(wasm.sourceMap);\r\n sourceMap.sourceRoot = exports.sourceMapRoot;\r\n sourceMap.sources.forEach((name, index) => {\r\n let text = null;\r\n if (name.startsWith(exports.libraryPrefix)) {\r\n let stdName = name.substring(exports.libraryPrefix.length).replace(/\\.ts$/, \"\");\r\n if (exports.libraryFiles.hasOwnProperty(stdName)) {\r\n text = exports.libraryFiles[stdName];\r\n } else {\r\n for (let i = 0, k = customLibDirs.length; i < k; ++i) {\r\n text = readFile(name.substring(exports.libraryPrefix.length), customLibDirs[i]);\r\n if (text !== null) break;\r\n }\r\n }\r\n } else {\r\n text = readFile(name, baseDir);\r\n }\r\n if (text === null) {\r\n return callback(Error(\"Source file '\" + name + \"' not found.\"));\r\n }\r\n if (!sourceMap.sourceContents) sourceMap.sourceContents = [];\r\n sourceMap.sourceContents[index] = text;\r\n });\r\n writeFile(path.join(\r\n path.dirname(args.binaryFile),\r\n path.basename(sourceMapURL)\r\n ).replace(/^\\.\\//, \"\"), JSON.stringify(sourceMap), baseDir);\r\n } else {\r\n stderr.write(\"Skipped source map (stdout already occupied)\" + EOL);\r\n }\r\n }\r\n }\r\n\r\n // Write asm.js\r\n if (args.asmjsFile != null) {\r\n let asm;\r\n if (args.asmjsFile.length) {\r\n stats.emitCount++;\r\n stats.emitTime += measure(() => {\r\n asm = module.toAsmjs();\r\n });\r\n writeFile(args.asmjsFile, asm, baseDir);\r\n } else if (!hasStdout) {\r\n stats.emitCount++;\r\n stats.emitTime += measure(() => {\r\n asm = module.toAsmjs();\r\n });\r\n writeStdout(asm);\r\n hasStdout = true;\r\n }\r\n hasOutput = true;\r\n }\r\n\r\n // Write WebIDL\r\n if (args.idlFile != null) {\r\n let idl;\r\n if (args.idlFile.length) {\r\n stats.emitCount++;\r\n stats.emitTime += measure(() => {\r\n idl = assemblyscript.buildIDL(program);\r\n });\r\n writeFile(args.idlFile, idl, baseDir);\r\n } else if (!hasStdout) {\r\n stats.emitCount++;\r\n stats.emitTime += measure(() => {\r\n idl = assemblyscript.buildIDL(program);\r\n });\r\n writeStdout(idl);\r\n hasStdout = true;\r\n }\r\n hasOutput = true;\r\n }\r\n\r\n // Write TypeScript definition\r\n if (args.tsdFile != null) {\r\n let tsd;\r\n if (args.tsdFile.length) {\r\n stats.emitCount++;\r\n stats.emitTime += measure(() => {\r\n tsd = assemblyscript.buildTSD(program);\r\n });\r\n writeFile(args.tsdFile, tsd, baseDir);\r\n } else if (!hasStdout) {\r\n stats.emitCount++;\r\n stats.emitTime += measure(() => {\r\n tsd = assemblyscript.buildTSD(program);\r\n });\r\n writeStdout(tsd);\r\n hasStdout = true;\r\n }\r\n hasOutput = true;\r\n }\r\n\r\n // Write text (must be last)\r\n if (args.textFile != null || !hasOutput) {\r\n let wat;\r\n if (args.textFile && args.textFile.length) {\r\n stats.emitCount++;\r\n stats.emitTime += measure(() => {\r\n wat = module.toText();\r\n });\r\n writeFile(args.textFile, wat, baseDir);\r\n } else if (!hasStdout) {\r\n stats.emitCount++;\r\n stats.emitTime += measure(() => {\r\n wat = module.toText()\r\n });\r\n writeStdout(wat);\r\n }\r\n }\r\n }\r\n\r\n module.dispose();\r\n if (args.measure) {\r\n printStats(stats, stderr);\r\n }\r\n if (args.printrtti) {\r\n printRTTI(program, stderr);\r\n }\r\n return callback(null);\r\n\r\n function readFileNode(filename, baseDir) {\r\n try {\r\n let text;\r\n stats.readCount++;\r\n stats.readTime += measure(() => {\r\n text = fs.readFileSync(path.join(baseDir, filename), { encoding: \"utf8\" });\r\n });\r\n return text;\r\n } catch (e) {\r\n return null;\r\n }\r\n }\r\n\r\n function writeFileNode(filename, contents, baseDir) {\r\n try {\r\n stats.writeCount++;\r\n stats.writeTime += measure(() => {\r\n mkdirp(path.join(baseDir, path.dirname(filename)));\r\n if (typeof contents === \"string\") {\r\n fs.writeFileSync(path.join(baseDir, filename), contents, { encoding: \"utf8\" } );\r\n } else {\r\n fs.writeFileSync(path.join(baseDir, filename), contents);\r\n }\r\n });\r\n return true;\r\n } catch (e) {\r\n return false;\r\n }\r\n }\r\n\r\n function listFilesNode(dirname, baseDir) {\r\n var files;\r\n try {\r\n stats.readTime += measure(() => {\r\n files = fs.readdirSync(path.join(baseDir, dirname)).filter(file => /^(?!.*\\.d\\.ts$).*\\.ts$/.test(file));\r\n });\r\n return files;\r\n } catch (e) {\r\n return [];\r\n }\r\n }\r\n\r\n function writeStdout(contents) {\r\n if (!writeStdout.used) {\r\n stats.writeCount++;\r\n writeStdout.used = true;\r\n }\r\n stats.writeTime += measure(() => {\r\n if (typeof contents === \"string\") {\r\n stdout.write(contents, { encoding: \"utf8\" });\r\n } else {\r\n stdout.write(contents);\r\n }\r\n });\r\n }\r\n}\r\n\r\n/** Checks diagnostics emitted so far for errors. */\r\nfunction checkDiagnostics(emitter, stderr) {\r\n var diagnostic;\r\n var hasErrors = false;\r\n while ((diagnostic = assemblyscript.nextDiagnostic(emitter)) != null) {\r\n if (stderr) {\r\n stderr.write(\r\n assemblyscript.formatDiagnostic(diagnostic, stderr.isTTY, true) +\r\n EOL + EOL\r\n );\r\n }\r\n if (assemblyscript.isError(diagnostic)) hasErrors = true;\r\n }\r\n return hasErrors;\r\n}\r\n\r\nexports.checkDiagnostics = checkDiagnostics;\r\n\r\n/** Creates an empty set of stats. */\r\nfunction createStats() {\r\n return {\r\n readTime: 0,\r\n readCount: 0,\r\n writeTime: 0,\r\n writeCount: 0,\r\n parseTime: 0,\r\n parseCount: 0,\r\n compileTime: 0,\r\n compileCount: 0,\r\n emitTime: 0,\r\n emitCount: 0,\r\n validateTime: 0,\r\n validateCount: 0,\r\n optimizeTime: 0,\r\n optimizeCount: 0\r\n };\r\n}\r\n\r\nexports.createStats = createStats;\r\n\r\nif (!process.hrtime) process.hrtime = require(\"browser-process-hrtime\");\r\n\r\n/** Measures the execution time of the specified function. */\r\nfunction measure(fn) {\r\n const start = process.hrtime();\r\n fn();\r\n const times = process.hrtime(start);\r\n return times[0] * 1e9 + times[1];\r\n}\r\n\r\nexports.measure = measure;\r\n\r\n/** Formats a high resolution time to a human readable string. */\r\nfunction formatTime(time) {\r\n return time ? (time / 1e6).toFixed(3) + \" ms\" : \"N/A\";\r\n}\r\n\r\nexports.formatTime = formatTime;\r\n\r\n/** Formats and prints out the contents of a set of stats. */\r\nfunction printStats(stats, output) {\r\n function format(time, count) {\r\n return formatTime(time);\r\n }\r\n (output || process.stdout).write([\r\n \"I/O Read : \" + format(stats.readTime, stats.readCount),\r\n \"I/O Write : \" + format(stats.writeTime, stats.writeCount),\r\n \"Parse : \" + format(stats.parseTime, stats.parseCount),\r\n \"Compile : \" + format(stats.compileTime, stats.compileCount),\r\n \"Emit : \" + format(stats.emitTime, stats.emitCount),\r\n \"Validate : \" + format(stats.validateTime, stats.validateCount),\r\n \"Optimize : \" + format(stats.optimizeTime, stats.optimizeCount)\r\n ].join(EOL) + EOL);\r\n}\r\n\r\nexports.printStats = printStats;\r\n\r\n/** Prints runtime type information. */\r\nfunction printRTTI(program, output) {\r\n if (!output) output = process.stderr;\r\n output.write(\"# Runtime type information (RTTI)\\n\");\r\n output.write(assemblyscript.buildRTTI(program));\r\n}\r\n\r\nexports.printRTTI = printRTTI;\r\n\r\nvar allocBuffer = typeof global !== \"undefined\" && global.Buffer\r\n ? global.Buffer.allocUnsafe || function(len) { return new global.Buffer(len); }\r\n : function(len) { return new Uint8Array(len) };\r\n\r\n/** Creates a memory stream that can be used in place of stdout/stderr. */\r\nfunction createMemoryStream(fn) {\r\n var stream = [];\r\n stream.write = function(chunk) {\r\n if (fn) fn(chunk);\r\n if (typeof chunk === \"string\") {\r\n let buffer = allocBuffer(utf8.length(chunk));\r\n utf8.write(chunk, buffer, 0);\r\n chunk = buffer;\r\n }\r\n this.push(chunk);\r\n };\r\n stream.reset = function() {\r\n stream.length = 0;\r\n };\r\n stream.toBuffer = function() {\r\n var offset = 0, i = 0, k = this.length;\r\n while (i < k) offset += this[i++].length;\r\n var buffer = allocBuffer(offset);\r\n offset = i = 0;\r\n while (i < k) {\r\n buffer.set(this[i], offset);\r\n offset += this[i].length;\r\n ++i;\r\n }\r\n return buffer;\r\n };\r\n stream.toString = function() {\r\n var buffer = this.toBuffer();\r\n return utf8.read(buffer, 0, buffer.length);\r\n };\r\n return stream;\r\n}\r\n\r\nexports.createMemoryStream = createMemoryStream;\r\n\r\n/** Compatible TypeScript compiler options for syntax highlighting etc. */\r\nexports.tscOptions = {\r\n alwaysStrict: true,\r\n noImplicitAny: true,\r\n noImplicitReturns: true,\r\n noImplicitThis: true,\r\n noEmitOnError: true,\r\n strictNullChecks: true,\r\n experimentalDecorators: true,\r\n target: \"esnext\",\r\n module: \"commonjs\",\r\n noLib: true,\r\n types: [],\r\n allowJs: false\r\n};\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal UTF8 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar utf8 = exports;\r\n\r\n/**\r\n * Calculates the UTF8 byte length of a string.\r\n * @param {string} string String\r\n * @returns {number} Byte length\r\n */\r\nutf8.length = function utf8_length(string) {\r\n var len = 0,\r\n c = 0;\r\n for (var i = 0; i < string.length; ++i) {\r\n c = string.charCodeAt(i);\r\n if (c < 128)\r\n len += 1;\r\n else if (c < 2048)\r\n len += 2;\r\n else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) {\r\n ++i;\r\n len += 4;\r\n } else\r\n len += 3;\r\n }\r\n return len;\r\n};\r\n\r\n/**\r\n * Reads UTF8 bytes as a string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} String read\r\n */\r\nutf8.read = function utf8_read(buffer, start, end) {\r\n var len = end - start;\r\n if (len < 1)\r\n return \"\";\r\n var parts = null,\r\n chunk = [],\r\n i = 0, // char offset\r\n t; // temporary\r\n while (start < end) {\r\n t = buffer[start++];\r\n if (t < 128)\r\n chunk[i++] = t;\r\n else if (t > 191 && t < 224)\r\n chunk[i++] = (t & 31) << 6 | buffer[start++] & 63;\r\n else if (t > 239 && t < 365) {\r\n t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000;\r\n chunk[i++] = 0xD800 + (t >> 10);\r\n chunk[i++] = 0xDC00 + (t & 1023);\r\n } else\r\n chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63;\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\n/**\r\n * Writes a string as UTF8 bytes.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Bytes written\r\n */\r\nutf8.write = function utf8_write(string, buffer, offset) {\r\n var start = offset,\r\n c1, // character 1\r\n c2; // character 2\r\n for (var i = 0; i < string.length; ++i) {\r\n c1 = string.charCodeAt(i);\r\n if (c1 < 128) {\r\n buffer[offset++] = c1;\r\n } else if (c1 < 2048) {\r\n buffer[offset++] = c1 >> 6 | 192;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) {\r\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\r\n ++i;\r\n buffer[offset++] = c1 >> 18 | 240;\r\n buffer[offset++] = c1 >> 12 & 63 | 128;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else {\r\n buffer[offset++] = c1 >> 12 | 224;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n }\r\n }\r\n return offset - start;\r\n};\r\n","var proc = typeof process !== \"undefined\" && process || {};\r\nvar isCI = proc.env && \"CI\" in proc.env; // doesn't work when bundled because 'process' is a mock\r\n\r\nfunction from(stream, base) {\r\n var colors = base || {};\r\n colors.supported = (stream && !!stream.isTTY) || isCI;\r\n colors.gray = text => colors.supported ? exports.GRAY + text + exports.RESET : text;\r\n colors.red = text => colors.supported ? exports.RED + text + exports.RESET : text;\r\n colors.green = text => colors.supported ? exports.GREEN + text + exports.RESET : text;\r\n colors.yellow = text => colors.supported ? exports.YELLOW + text + exports.RESET : text;\r\n colors.blue = text => colors.supported ? exports.BLUE + text + exports.RESET : text;\r\n colors.magenta = text => colors.supported ? exports.MAGENTA + text + exports.RESET : text;\r\n colors.cyan = text => colors.supported ? exports.CYAN + text + exports.RESET : text;\r\n colors.white = text => colors.supported ? exports.WHITE + text + exports.RESET : text;\r\n return colors;\r\n}\r\n\r\nexports.stdout = from(proc.stdout, exports);\r\nexports.stderr = from(proc.stderr);\r\nexports.from = from;\r\n\r\nexports.GRAY = \"\\u001b[90m\";\r\nexports.RED = \"\\u001b[91m\";\r\nexports.GREEN = \"\\u001b[92m\";\r\nexports.YELLOW = \"\\u001b[93m\";\r\nexports.BLUE = \"\\u001b[94m\";\r\nexports.MAGENTA = \"\\u001b[95m\";\r\nexports.CYAN = \"\\u001b[96m\";\r\nexports.WHITE = \"\\u001b[97m\";\r\nexports.RESET = \"\\u001b[0m\";\r\n","// type | meaning\r\n// -----|---------------\r\n// b | boolean\r\n// i | integer\r\n// f | float\r\n// s | string\r\n// I | integer array\r\n// F | float array\r\n// S | string array\r\n\r\n/** Parses the specified command line arguments according to the given configuration. */\r\nfunction parse(argv, config) {\r\n var options = {};\r\n var unknown = [];\r\n var arguments = [];\r\n var trailing = [];\r\n\r\n // make an alias map and initialize defaults\r\n var aliases = {};\r\n Object.keys(config).forEach(key => {\r\n if (key.startsWith(\" \")) return;\r\n var option = config[key];\r\n if (option.alias != null) {\r\n if (typeof option.alias === \"string\") aliases[option.alias] = key;\r\n else if (Array.isArray(option.alias)) option.alias.forEach(alias => aliases[alias] = key);\r\n }\r\n if (option.default != null) options[key] = option.default;\r\n });\r\n\r\n // iterate over argv\r\n for (var i = 0, k = (argv = argv.slice()).length; i < k; ++i) {\r\n let arg = argv[i];\r\n if (arg == \"--\") { ++i; break; }\r\n let match = /^(?:(\\-\\w)(?:=(.*))?|(\\-\\-\\w{2,})(?:=(.*))?)$/.exec(arg), option, key;\r\n if (match) {\r\n if (config[arg]) option = config[key = arg]; // exact\r\n else if (match[1] != null) { // alias\r\n option = config[key = aliases[match[1].substring(1)]];\r\n if (option && match[2] != null) argv[i--] = match[2];\r\n } else if (match[3] != null) { // full\r\n option = config[key = match[3].substring(2)];\r\n if (option && match[4] != null) argv[i--] = match[4];\r\n }\r\n } else {\r\n if (arg.charCodeAt(0) == 45) option = config[key = arg]; // exact\r\n else { arguments.push(arg); continue; } // argument\r\n }\r\n if (option) {\r\n if (option.type == null || option.type === \"b\") options[key] = true; // flag\r\n else {\r\n if (i + 1 < argv.length && argv[i + 1].charCodeAt(0) != 45) { // present\r\n switch (option.type) {\r\n case \"i\": options[key] = parseInt(argv[++i], 10); break;\r\n case \"I\": options[key] = (options[key] || []).concat(parseInt(argv[++i], 10)); break;\r\n case \"f\": options[key] = parseFloat(argv[++i]); break;\r\n case \"F\": options[key] = (options[key] || []).concat(parseFloat(argv[++i])); break;\r\n case \"s\": options[key] = String(argv[++i]); break;\r\n case \"S\": options[key] = (options[key] || []).concat(argv[++i].split(\",\")); break;\r\n default: unknown.push(arg); --i;\r\n }\r\n } else { // omitted\r\n switch (option.type) {\r\n case \"i\":\r\n case \"f\": options[key] = option.default || 0; break;\r\n case \"s\": options[key] = option.default || \"\"; break;\r\n case \"I\":\r\n case \"F\":\r\n case \"S\": options[key] = options.default || []; break;\r\n default: unknown.push(arg);\r\n }\r\n }\r\n }\r\n if (option.value) Object.keys(option.value).forEach(k => options[k] = option.value[k]);\r\n } else unknown.push(arg);\r\n }\r\n while (i < k) trailing.push(argv[i++]); // trailing\r\n\r\n return { options, unknown, arguments, trailing };\r\n}\r\n\r\nexports.parse = parse;\r\n\r\n/** Generates the help text for the specified configuration. */\r\nfunction help(config, options) {\r\n if (!options) options = {};\r\n var indent = options.indent || 2;\r\n var padding = options.padding || 24;\r\n var eol = options.eol || \"\\n\";\r\n var sb = [];\r\n Object.keys(config).forEach(key => {\r\n var option = config[key];\r\n if (option.description == null) return;\r\n var text = \"\";\r\n while (text.length < indent) text += \" \";\r\n text += \"--\" + key;\r\n if (option.alias) text += \", -\" + option.alias;\r\n while (text.length < padding) text += \" \";\r\n if (Array.isArray(option.description)) {\r\n sb.push(text + option.description[0] + option.description.slice(1).map(line => {\r\n for (let i = 0; i < padding; ++i) line = \" \" + line;\r\n return eol + line;\r\n }).join(\"\"));\r\n } else sb.push(text + option.description);\r\n });\r\n return sb.join(eol);\r\n}\r\n\r\nexports.help = help;\r\n","/*\r\nCopyright 2010 James Halliday (mail@substack.net)\r\n\r\nThis project is free software released under the MIT/X11 license:\r\n\r\nPermission is hereby granted, free of charge, to any person obtaining a copy\r\nof this software and associated documentation files (the \"Software\"), to deal\r\nin the Software without restriction, including without limitation the rights\r\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\ncopies of the Software, and to permit persons to whom the Software is\r\nfurnished to do so, subject to the following conditions:\r\n\r\nThe above copyright notice and this permission notice shall be included in\r\nall copies or substantial portions of the Software.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\r\nTHE SOFTWARE.\r\n*/\r\n\r\nvar path = require(\"path\");\r\nvar fs = require(\"fs\");\r\nvar _0777 = parseInt(\"0777\", 8);\r\n\r\nmodule.exports = function mkdirp(p, opts, made) {\r\n if (!opts || typeof opts !== \"object\") {\r\n opts = { mode: opts };\r\n }\r\n var mode = opts.mode;\r\n if (mode === undefined) {\r\n mode = _0777 & (~process.umask());\r\n }\r\n if (!made) made = null;\r\n p = path.resolve(p);\r\n try {\r\n fs.mkdirSync(p, mode);\r\n made = made || p;\r\n } catch (err0) {\r\n switch (err0.code) {\r\n case \"ENOENT\":\r\n made = mkdirp(path.dirname(p), opts, made);\r\n mkdirp(p, opts, made);\r\n break;\r\n default:\r\n var stat;\r\n try {\r\n stat = fs.statSync(p);\r\n } catch (err1) {\r\n throw err0;\r\n }\r\n if (!stat.isDirectory()) throw err0;\r\n break;\r\n }\r\n }\r\n return made;\r\n};\r\n","if(typeof __WEBPACK_EXTERNAL_MODULE__10__ === 'undefined') {var e = new Error(\"Cannot find module 'assemblyscript'\"); e.code = 'MODULE_NOT_FOUND'; throw e;}\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__10__;","function webpackEmptyContext(req) {\n\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\te.code = 'MODULE_NOT_FOUND';\n\tthrow e;\n}\nwebpackEmptyContext.keys = function() { return []; };\nwebpackEmptyContext.resolve = webpackEmptyContext;\nmodule.exports = webpackEmptyContext;\nwebpackEmptyContext.id = 12;","module.exports = process.hrtime || hrtime\n\n// polyfil for window.performance.now\nvar performance = global.performance || {}\nvar performanceNow =\n performance.now ||\n performance.mozNow ||\n performance.msNow ||\n performance.oNow ||\n performance.webkitNow ||\n function(){ return (new Date()).getTime() }\n\n// generate timestamp or delta\n// see http://nodejs.org/api/process.html#process_process_hrtime\nfunction hrtime(previousTimestamp){\n var clocktime = performanceNow.call(performance)*1e-3\n var seconds = Math.floor(clocktime)\n var nanoseconds = Math.floor((clocktime%1)*1e9)\n if (previousTimestamp) {\n seconds = seconds - previousTimestamp[0]\n nanoseconds = nanoseconds - previousTimestamp[1]\n if (nanoseconds<0) {\n seconds--\n nanoseconds += 1e9\n }\n }\n return [seconds,nanoseconds]\n}"],"sourceRoot":""} \ No newline at end of file +{"version":3,"sources":["webpack://asc/webpack/universalModuleDefinition","webpack://asc/webpack/bootstrap","webpack://asc/../node_modules/node-libs-browser/mock/process.js","webpack://asc/../node_modules/path-browserify/index.js","webpack://asc/../node_modules/webpack/buildin/global.js","webpack://asc/./asc.js","webpack://asc/../node_modules/@protobufjs/utf8/index.js","webpack://asc/./util/colors.js","webpack://asc/./util/options.js","webpack://asc/./util/mkdirp.js","webpack://asc/external \"assemblyscript\"","webpack://asc/. sync","webpack://asc/../node_modules/browser-process-hrtime/index.js"],"names":["root","factory","exports","module","require","e","define","amd","self","this","__WEBPACK_EXTERNAL_MODULE__10__","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","path","cwd","nextTick","fn","setTimeout","platform","arch","execPath","title","pid","browser","env","argv","binding","Error","chdir","dir","resolve","exit","kill","umask","dlopen","uptime","memoryUsage","uvCounters","features","process","normalizeArray","parts","allowAboveRoot","up","length","last","splice","unshift","splitPathRe","splitPath","filename","exec","slice","filter","xs","f","res","push","resolvedPath","resolvedAbsolute","arguments","TypeError","charAt","split","join","normalize","isAbsolute","trailingSlash","substr","paths","Array","index","relative","from","to","trim","arr","start","end","fromParts","toParts","Math","min","samePartsLength","outputParts","concat","sep","delimiter","dirname","result","basename","ext","extname","str","len","g","Function","window","global","fs","utf8","colorsUtil","optionsUtil","mkdirp","EOL","removeAllListeners","assemblyscript","isDev","checkDiagnostics","emitter","stderr","diagnostic","hasErrors","nextDiagnostic","write","formatDiagnostic","isTTY","isError","createStats","readTime","readCount","writeTime","writeCount","parseTime","parseCount","compileTime","compileCount","emitTime","emitCount","validateTime","validateCount","optimizeTime","optimizeCount","measure","hrtime","times","formatTime","time","toFixed","printStats","stats","output","format","count","stdout","printRTTI","program","buildRTTI","code","register","project","e_ts","eval","stack","isBundle","version","options","sourceMapRoot","libraryPrefix","LIBRARY_PREFIX","defaultOptimizeLevel","defaultShrinkLevel","libraryFiles","array","arraybuffer","bindings/Date","bindings/Math","bindings/wasi_unstable","bindings/wasi","builtins","dataview","date","diagnostics","error","fixedarray","heap","iterator","map","math","memory","number","polyfills","regexp","rt","rt/common","rt/index-full","rt/index-half","rt/index-none","rt/index-stub","rt/pure","rt/rtrace","rt/stub","rt/tlsf","set","shared/feature","shared/target","shared/typeinfo","string","symbol","table","typedarray","util/error","util/hash","util/memory","util/number","util/sort","util/string","vector","libDir","libFiles","sync","bundled","forEach","file","replace","readFileSync","definitionFiles","assembly","portable","stdDir","compileString","sources","input.ts","createMemoryStream","keys","val","isArray","String","main","readFile","writeFile","contents","listFiles","callback","readFileNode","writeFileNode","listFilesNode","opts","parse","args","noColors","supported","unknown","arg","yellow","trailing","err","red","help","out","color","white","cyan","baseDir","transforms","transform","parser","libPath","indexOf","parseFile","customLibDirs","lib","apply","k","endsWith","j","libText","parseBacklog","sourcePath","sourceText","nextFile","startsWith","plainName","substring","indexName","runtimeName","runtime","runtimePath","runtimeText","applyTransform","finishParsing","optimizeLevel","shrinkLevel","optimize","max","compilerOptions","createOptions","setTarget","setNoAssert","noAssert","setImportMemory","importMemory","setSharedMemory","sharedMemory","setImportTable","importTable","setExplicitStart","explicitStart","setMemoryBase","memoryBase","setSourceMap","sourceMap","setOptimizeLevelHints","setGlobalAlias","use","aliases","part","alias","enable","flag","toUpperCase","enableFeature","compileProgram","dispose","validate","trapMode","runPasses","setOptimizeLevel","setShrinkLevel","setDebugInfo","debug","pass","noEmit","hasStdout","hasOutput","outFile","test","textFile","asmjsFile","binaryFile","wasm","sourceMapURL","toBinary","writeStdout","JSON","sourceRoot","text","stdName","sourceContents","stringify","asm","toAsmjs","idlFile","idl","buildIDL","tsdFile","tsd","buildTSD","wat","toText","printrtti","encoding","writeFileSync","files","readdirSync","used","allocBuffer","Buffer","allocUnsafe","Uint8Array","stream","chunk","buffer","reset","toBuffer","offset","toString","read","tscOptions","alwaysStrict","noImplicitAny","noImplicitReturns","noImplicitThis","noEmitOnError","strictNullChecks","experimentalDecorators","target","noLib","types","allowJs","charCodeAt","fromCharCode","c1","c2","proc","isCI","base","colors","gray","GRAY","RESET","RED","green","GREEN","YELLOW","blue","BLUE","magenta","MAGENTA","CYAN","WHITE","config","option","default","match","type","parseInt","parseFloat","indent","padding","eol","sb","description","line","_0777","made","undefined","mkdirSync","err0","stat","statSync","err1","isDirectory","webpackEmptyContext","req","id","previousTimestamp","clocktime","performanceNow","performance","seconds","floor","nanoseconds","now","mozNow","msNow","oNow","webkitNow","Date","getTime"],"mappings":"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","file":"asc.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory((function webpackLoadOptionalExternalModule() { try { return require(\"assemblyscript\"); } catch(e) {} }()));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"assemblyscript\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"asc\"] = factory((function webpackLoadOptionalExternalModule() { try { return require(\"assemblyscript\"); } catch(e) {} }()));\n\telse\n\t\troot[\"asc\"] = factory(root[\"assemblyscript\"]);\n})(typeof self !== 'undefined' ? self : this, function(__WEBPACK_EXTERNAL_MODULE__10__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 4);\n","exports.nextTick = function nextTick(fn) {\n\tsetTimeout(fn, 0);\n};\n\nexports.platform = exports.arch = \nexports.execPath = exports.title = 'browser';\nexports.pid = 1;\nexports.browser = true;\nexports.env = {};\nexports.argv = [];\n\nexports.binding = function (name) {\n\tthrow new Error('No such module. (Possibly not yet loaded)')\n};\n\n(function () {\n var cwd = '/';\n var path;\n exports.cwd = function () { return cwd };\n exports.chdir = function (dir) {\n if (!path) path = require('path');\n cwd = path.resolve(dir, cwd);\n };\n})();\n\nexports.exit = exports.kill = \nexports.umask = exports.dlopen = \nexports.uptime = exports.memoryUsage = \nexports.uvCounters = function() {};\nexports.features = {};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// resolves . and .. elements in a path array with directory names there\n// must be no slashes, empty elements, or device names (c:\\) in the array\n// (so also no leading and trailing slashes - it does not distinguish\n// relative and absolute paths)\nfunction normalizeArray(parts, allowAboveRoot) {\n // if the path tries to go above the root, `up` ends up > 0\n var up = 0;\n for (var i = parts.length - 1; i >= 0; i--) {\n var last = parts[i];\n if (last === '.') {\n parts.splice(i, 1);\n } else if (last === '..') {\n parts.splice(i, 1);\n up++;\n } else if (up) {\n parts.splice(i, 1);\n up--;\n }\n }\n\n // if the path is allowed to go above the root, restore leading ..s\n if (allowAboveRoot) {\n for (; up--; up) {\n parts.unshift('..');\n }\n }\n\n return parts;\n}\n\n// Split a filename into [root, dir, basename, ext], unix version\n// 'root' is just a slash, or nothing.\nvar splitPathRe =\n /^(\\/?|)([\\s\\S]*?)((?:\\.{1,2}|[^\\/]+?|)(\\.[^.\\/]*|))(?:[\\/]*)$/;\nvar splitPath = function(filename) {\n return splitPathRe.exec(filename).slice(1);\n};\n\n// path.resolve([from ...], to)\n// posix version\nexports.resolve = function() {\n var resolvedPath = '',\n resolvedAbsolute = false;\n\n for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n var path = (i >= 0) ? arguments[i] : process.cwd();\n\n // Skip empty and invalid entries\n if (typeof path !== 'string') {\n throw new TypeError('Arguments to path.resolve must be strings');\n } else if (!path) {\n continue;\n }\n\n resolvedPath = path + '/' + resolvedPath;\n resolvedAbsolute = path.charAt(0) === '/';\n }\n\n // At this point the path should be resolved to a full absolute path, but\n // handle relative paths to be safe (might happen when process.cwd() fails)\n\n // Normalize the path\n resolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) {\n return !!p;\n }), !resolvedAbsolute).join('/');\n\n return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';\n};\n\n// path.normalize(path)\n// posix version\nexports.normalize = function(path) {\n var isAbsolute = exports.isAbsolute(path),\n trailingSlash = substr(path, -1) === '/';\n\n // Normalize the path\n path = normalizeArray(filter(path.split('/'), function(p) {\n return !!p;\n }), !isAbsolute).join('/');\n\n if (!path && !isAbsolute) {\n path = '.';\n }\n if (path && trailingSlash) {\n path += '/';\n }\n\n return (isAbsolute ? '/' : '') + path;\n};\n\n// posix version\nexports.isAbsolute = function(path) {\n return path.charAt(0) === '/';\n};\n\n// posix version\nexports.join = function() {\n var paths = Array.prototype.slice.call(arguments, 0);\n return exports.normalize(filter(paths, function(p, index) {\n if (typeof p !== 'string') {\n throw new TypeError('Arguments to path.join must be strings');\n }\n return p;\n }).join('/'));\n};\n\n\n// path.relative(from, to)\n// posix version\nexports.relative = function(from, to) {\n from = exports.resolve(from).substr(1);\n to = exports.resolve(to).substr(1);\n\n function trim(arr) {\n var start = 0;\n for (; start < arr.length; start++) {\n if (arr[start] !== '') break;\n }\n\n var end = arr.length - 1;\n for (; end >= 0; end--) {\n if (arr[end] !== '') break;\n }\n\n if (start > end) return [];\n return arr.slice(start, end - start + 1);\n }\n\n var fromParts = trim(from.split('/'));\n var toParts = trim(to.split('/'));\n\n var length = Math.min(fromParts.length, toParts.length);\n var samePartsLength = length;\n for (var i = 0; i < length; i++) {\n if (fromParts[i] !== toParts[i]) {\n samePartsLength = i;\n break;\n }\n }\n\n var outputParts = [];\n for (var i = samePartsLength; i < fromParts.length; i++) {\n outputParts.push('..');\n }\n\n outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n return outputParts.join('/');\n};\n\nexports.sep = '/';\nexports.delimiter = ':';\n\nexports.dirname = function(path) {\n var result = splitPath(path),\n root = result[0],\n dir = result[1];\n\n if (!root && !dir) {\n // No dirname whatsoever\n return '.';\n }\n\n if (dir) {\n // It has a dirname, strip trailing slash\n dir = dir.substr(0, dir.length - 1);\n }\n\n return root + dir;\n};\n\n\nexports.basename = function(path, ext) {\n var f = splitPath(path)[2];\n // TODO: make this comparison case-insensitive on windows?\n if (ext && f.substr(-1 * ext.length) === ext) {\n f = f.substr(0, f.length - ext.length);\n }\n return f;\n};\n\n\nexports.extname = function(path) {\n return splitPath(path)[3];\n};\n\nfunction filter (xs, f) {\n if (xs.filter) return xs.filter(f);\n var res = [];\n for (var i = 0; i < xs.length; i++) {\n if (f(xs[i], i, xs)) res.push(xs[i]);\n }\n return res;\n}\n\n// String.prototype.substr - negative index don't work in IE8\nvar substr = 'ab'.substr(-1) === 'b'\n ? function (str, start, len) { return str.substr(start, len) }\n : function (str, start, len) {\n if (start < 0) start = str.length + start;\n return str.substr(start, len);\n }\n;\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","/**\n * Compiler frontend for node.js\n *\n * Uses the low-level API exported from src/index.ts so it works with the compiler compiled to\n * JavaScript as well as the compiler compiled to WebAssembly (eventually). Runs the sources\n * directly through ts-node if distribution files are not present (indicated by a `-dev` version).\n *\n * Can also be packaged as a bundle suitable for in-browser use with the standard library injected\n * in the build step. See dist/asc.js for the bundle and webpack.config.js for building details.\n *\n * @module cli/asc\n */\n\n// Use \".\" instead of \"/\" as cwd in browsers\nif (process.browser) process.cwd = function() { return \".\"; };\n\nconst fs = require(\"fs\");\nconst path = require(\"path\");\nconst utf8 = require(\"@protobufjs/utf8\");\nconst colorsUtil = require(\"./util/colors\");\nconst optionsUtil = require(\"./util/options\");\nconst mkdirp = require(\"./util/mkdirp\");\nconst EOL = process.platform === \"win32\" ? \"\\r\\n\" : \"\\n\";\n\n// global.Binaryen = require(\"../lib/binaryen\");\n\n// Emscripten adds an `uncaughtException` listener to Binaryen that results in an additional\n// useless code fragment on top of an actual error. suppress this:\nif (process.removeAllListeners) process.removeAllListeners(\"uncaughtException\");\n\n// Use distribution files if present, otherwise run the sources directly\nvar assemblyscript, isDev = false;\n(() => {\n try { // `asc` on the command line\n assemblyscript = require(\"../dist/assemblyscript.js\");\n } catch (e) {\n try { // `asc` on the command line without dist files\n require(\"ts-node\").register({ project: path.join(__dirname, \"..\", \"src\", \"tsconfig.json\") });\n require(\"../src/glue/js\");\n assemblyscript = require(\"../src\");\n isDev = true;\n } catch (e_ts) {\n try { // `require(\"dist/asc.js\")` in explicit browser tests\n assemblyscript = eval(\"require('./assemblyscript')\");\n } catch (e) {\n // combine both errors that lead us here\n e.stack = e_ts.stack + \"\\n---\\n\" + e.stack;\n throw e;\n }\n }\n }\n})();\n\n/** Whether this is a webpack bundle or not. */\nexports.isBundle = typeof BUNDLE_VERSION === \"string\";\n\n/** Whether asc runs the sources directly or not. */\nexports.isDev = isDev;\n\n/** AssemblyScript version. */\nexports.version = exports.isBundle ? BUNDLE_VERSION : require(\"../package.json\").version;\n\n/** Available CLI options. */\nexports.options = require(\"./asc.json\");\n\n/** Common root used in source maps. */\nexports.sourceMapRoot = \"assemblyscript:///\";\n\n/** Prefix used for library files. */\nexports.libraryPrefix = assemblyscript.LIBRARY_PREFIX;\n\n/** Default Binaryen optimization level. */\nexports.defaultOptimizeLevel = 3;\n\n/** Default Binaryen shrink level. */\nexports.defaultShrinkLevel = 1;\n\n/** Bundled library files. */\nexports.libraryFiles = exports.isBundle ? BUNDLE_LIBRARY : (() => { // set up if not a bundle\n const libDir = path.join(__dirname, \"..\", \"std\", \"assembly\");\n const libFiles = require(\"glob\").sync(\"**/!(*.d).ts\", { cwd: libDir });\n const bundled = {};\n libFiles.forEach(file => bundled[file.replace(/\\.ts$/, \"\")] = fs.readFileSync(path.join(libDir, file), \"utf8\" ));\n return bundled;\n})();\n\n/** Bundled definition files. */\nexports.definitionFiles = exports.isBundle ? BUNDLE_DEFINITIONS : (() => { // set up if not a bundle\n const stdDir = path.join(__dirname, \"..\", \"std\");\n return {\n \"assembly\": fs.readFileSync(path.join(stdDir, \"assembly\", \"index.d.ts\"), \"utf8\"),\n \"portable\": fs.readFileSync(path.join(stdDir, \"portable\", \"index.d.ts\"), \"utf8\")\n };\n})();\n\n/** Convenience function that parses and compiles source strings directly. */\nexports.compileString = (sources, options) => {\n if (typeof sources === \"string\") sources = { \"input.ts\": sources };\n const output = Object.create({\n stdout: createMemoryStream(),\n stderr: createMemoryStream()\n });\n var argv = [\n \"--binaryFile\", \"binary\",\n \"--textFile\", \"text\",\n ];\n Object.keys(options || {}).forEach(key => {\n var val = options[key];\n if (Array.isArray(val)) val.forEach(val => argv.push(\"--\" + key, String(val)));\n else argv.push(\"--\" + key, String(val));\n });\n exports.main(argv.concat(Object.keys(sources)), {\n stdout: output.stdout,\n stderr: output.stderr,\n readFile: name => sources.hasOwnProperty(name) ? sources[name] : null,\n writeFile: (name, contents) => output[name] = contents,\n listFiles: () => []\n });\n return output;\n}\n\n/** Runs the command line utility using the specified arguments array. */\nexports.main = function main(argv, options, callback) {\n if (typeof options === \"function\") {\n callback = options;\n options = {};\n } else if (!options) {\n options = {};\n }\n\n const stdout = options.stdout || process.stdout;\n const stderr = options.stderr || process.stderr;\n const readFile = options.readFile || readFileNode;\n const writeFile = options.writeFile || writeFileNode;\n const listFiles = options.listFiles || listFilesNode;\n const stats = options.stats || createStats();\n\n // Output must be specified if not present in the environment\n if (!stdout) throw Error(\"'options.stdout' must be specified\");\n if (!stderr) throw Error(\"'options.stderr' must be specified\");\n\n const opts = optionsUtil.parse(argv, exports.options);\n const args = opts.options;\n argv = opts.arguments;\n if (args.noColors) {\n colorsUtil.stdout.supported =\n colorsUtil.stderr.supported = false;\n } else {\n colorsUtil.stdout = colorsUtil.from(stdout);\n colorsUtil.stderr = colorsUtil.from(stderr);\n }\n\n // Check for unknown arguments\n if (opts.unknown.length) {\n opts.unknown.forEach(arg => {\n stderr.write(colorsUtil.stderr.yellow(\"WARN: \") + \"Unknown option '\" + arg + \"'\" + EOL);\n });\n }\n\n // Check for trailing arguments\n if (opts.trailing.length) {\n stderr.write(colorsUtil.stderr.yellow(\"WARN: \") + \"Unsupported trailing arguments: \" + opts.trailing.join(\" \") + EOL);\n }\n\n // Use default callback if none is provided\n if (!callback) callback = function defaultCallback(err) {\n var code = 0;\n if (err) {\n stderr.write(colorsUtil.stderr.red(\"ERROR: \") + err.stack.replace(/^ERROR: /i, \"\") + EOL);\n code = 1;\n }\n return code;\n };\n\n // Just print the version if requested\n if (args.version) {\n stdout.write(\"Version \" + exports.version + (isDev ? \"-dev\" : \"\") + EOL);\n return callback(null);\n }\n // Print the help message if requested or no source files are provided\n if (args.help || !argv.length) {\n var out = args.help ? stdout : stderr;\n var color = args.help ? colorsUtil.stdout : colorsUtil.stderr;\n out.write([\n color.white(\"SYNTAX\"),\n \" \" + color.cyan(\"asc\") + \" [entryFile ...] [options]\",\n \"\",\n color.white(\"EXAMPLES\"),\n \" \" + color.cyan(\"asc\") + \" hello.ts\",\n \" \" + color.cyan(\"asc\") + \" hello.ts -b hello.wasm -t hello.wat\",\n \" \" + color.cyan(\"asc\") + \" hello1.ts hello2.ts -b -O > hello.wasm\",\n \"\",\n color.white(\"OPTIONS\"),\n ].concat(\n optionsUtil.help(exports.options, 24, EOL)\n ).join(EOL) + EOL);\n return callback(null);\n }\n\n // I/O must be specified if not present in the environment\n if (!fs.readFileSync) {\n if (readFile === readFileNode) throw Error(\"'options.readFile' must be specified\");\n if (writeFile === writeFileNode) throw Error(\"'options.writeFile' must be specified\");\n if (listFiles === listFilesNode) throw Error(\"'options.listFiles' must be specified\");\n }\n\n // Set up base directory\n const baseDir = args.baseDir ? path.resolve(args.baseDir) : \".\";\n\n // Set up transforms\n const transforms = [];\n if (args.transform) {\n args.transform.forEach(transform =>\n transforms.push(\n require(\n path.isAbsolute(transform = transform.trim())\n ? transform\n : path.join(process.cwd(), transform)\n )\n )\n );\n }\n function applyTransform(name, ...args) {\n transforms.forEach(transform => {\n if (typeof transform[name] === \"function\") transform[name](...args);\n });\n }\n\n // Begin parsing\n var parser = null;\n\n // Include library files\n Object.keys(exports.libraryFiles).forEach(libPath => {\n if (libPath.indexOf(\"/\") >= 0) return; // in sub-directory: imported on demand\n stats.parseCount++;\n stats.parseTime += measure(() => {\n parser = assemblyscript.parseFile(\n exports.libraryFiles[libPath],\n exports.libraryPrefix + libPath + \".ts\",\n false,\n parser\n );\n });\n });\n const customLibDirs = [];\n if (args.lib) {\n let lib = args.lib;\n if (typeof lib === \"string\") lib = lib.split(\",\");\n Array.prototype.push.apply(customLibDirs, lib.map(lib => lib.trim()));\n for (let i = 0, k = customLibDirs.length; i < k; ++i) { // custom\n let libDir = customLibDirs[i];\n let libFiles;\n if (libDir.endsWith(\".ts\")) {\n libFiles = [ path.basename(libDir) ];\n libDir = path.dirname(libDir);\n } else {\n libFiles = listFiles(libDir);\n }\n for (let j = 0, l = libFiles.length; j < l; ++j) {\n let libPath = libFiles[j];\n let libText = readFile(libPath, libDir);\n if (libText === null) return callback(Error(\"Library file '\" + libPath + \"' not found.\"));\n stats.parseCount++;\n stats.parseTime += measure(() => {\n parser = assemblyscript.parseFile(\n libText,\n exports.libraryPrefix + libPath,\n false,\n parser\n );\n });\n }\n }\n }\n\n // Parses the backlog of imported files after including entry files\n function parseBacklog() {\n var sourcePath, sourceText;\n while ((sourcePath = parser.nextFile()) != null) {\n sourceText = null;\n\n // Load library file if explicitly requested\n if (sourcePath.startsWith(exports.libraryPrefix)) {\n const plainName = sourcePath.substring(exports.libraryPrefix.length);\n const indexName = sourcePath.substring(exports.libraryPrefix.length) + \"/index\";\n if (exports.libraryFiles.hasOwnProperty(plainName)) {\n sourceText = exports.libraryFiles[plainName];\n sourcePath = exports.libraryPrefix + plainName + \".ts\";\n } else if (exports.libraryFiles.hasOwnProperty(indexName)) {\n sourceText = exports.libraryFiles[indexName];\n sourcePath = exports.libraryPrefix + indexName + \".ts\";\n } else {\n for (let i = 0, k = customLibDirs.length; i < k; ++i) {\n sourceText = readFile(plainName + \".ts\", customLibDirs[i]);\n if (sourceText !== null) {\n sourcePath = exports.libraryPrefix + plainName + \".ts\";\n break;\n } else {\n sourceText = readFile(indexName + \".ts\", customLibDirs[i]);\n if (sourceText !== null) {\n sourcePath = exports.libraryPrefix + indexName + \".ts\";\n break;\n }\n }\n }\n }\n\n // Otherwise try nextFile.ts, nextFile/index.ts, ~lib/nextFile.ts, ~lib/nextFile/index.ts\n } else {\n const plainName = sourcePath;\n const indexName = sourcePath + \"/index\";\n sourceText = readFile(plainName + \".ts\", baseDir);\n if (sourceText !== null) {\n sourcePath = plainName + \".ts\";\n } else {\n sourceText = readFile(indexName + \".ts\", baseDir);\n if (sourceText !== null) {\n sourcePath = indexName + \".ts\";\n } else if (!plainName.startsWith(\".\")) {\n if (exports.libraryFiles.hasOwnProperty(plainName)) {\n sourceText = exports.libraryFiles[plainName];\n sourcePath = exports.libraryPrefix + plainName + \".ts\";\n } else if (exports.libraryFiles.hasOwnProperty(indexName)) {\n sourceText = exports.libraryFiles[indexName];\n sourcePath = exports.libraryPrefix + indexName + \".ts\";\n } else {\n for (let i = 0, k = customLibDirs.length; i < k; ++i) {\n const dir = customLibDirs[i];\n sourceText = readFile(plainName + \".ts\", dir);\n if (sourceText !== null) {\n sourcePath = exports.libraryPrefix + plainName + \".ts\";\n break;\n } else {\n sourceText = readFile(indexName + \".ts\", dir);\n if (sourceText !== null) {\n sourcePath = exports.libraryPrefix + indexName + \".ts\";\n break;\n }\n }\n }\n }\n }\n }\n }\n if (sourceText == null) {\n return callback(Error(\"Import file '\" + sourcePath + \".ts' not found.\"));\n }\n stats.parseCount++;\n stats.parseTime += measure(() => {\n assemblyscript.parseFile(sourceText, sourcePath, false, parser);\n });\n }\n if (checkDiagnostics(parser, stderr)) {\n return callback(Error(\"Parse error\"));\n }\n }\n\n // Include runtime template before entry files so its setup runs first\n {\n let runtimeName = String(args.runtime);\n let runtimePath = \"rt/index-\" + runtimeName;\n let runtimeText = exports.libraryFiles[runtimePath];\n if (runtimeText == null) {\n runtimePath = runtimeName;\n runtimeText = readFile(runtimePath + \".ts\", baseDir);\n if (runtimeText == null) {\n return callback(Error(\"Runtime '\" + runtimeName + \"' not found.\"));\n }\n } else {\n runtimePath = \"~lib/\" + runtimePath;\n }\n stats.parseCount++;\n stats.parseTime += measure(() => {\n parser = assemblyscript.parseFile(runtimeText, runtimePath, true, parser);\n });\n }\n\n // Include entry files\n for (let i = 0, k = argv.length; i < k; ++i) {\n const filename = argv[i];\n\n let sourcePath = String(filename).replace(/\\\\/g, \"/\").replace(/(\\.ts|\\/)$/, \"\");\n\n // Try entryPath.ts, then entryPath/index.ts\n let sourceText = readFile(sourcePath + \".ts\", baseDir);\n if (sourceText === null) {\n sourceText = readFile(sourcePath + \"/index.ts\", baseDir);\n if (sourceText === null) {\n return callback(Error(\"Entry file '\" + sourcePath + \".ts' not found.\"));\n } else {\n sourcePath += \"/index.ts\";\n }\n } else {\n sourcePath += \".ts\";\n }\n\n stats.parseCount++;\n stats.parseTime += measure(() => {\n parser = assemblyscript.parseFile(sourceText, sourcePath, true, parser);\n });\n }\n\n // Parse entry files\n {\n let code = parseBacklog();\n if (code) return code;\n }\n\n // Call afterParse transform hook\n applyTransform(\"afterParse\", parser);\n\n // Parse additional files, if any\n {\n let code = parseBacklog();\n if (code) return code;\n }\n\n // Finish parsing\n const program = assemblyscript.finishParsing(parser);\n\n // Set up optimization levels\n var optimizeLevel = 0;\n var shrinkLevel = 0;\n if (args.optimize) {\n optimizeLevel = exports.defaultOptimizeLevel;\n shrinkLevel = exports.defaultShrinkLevel;\n }\n if (typeof args.optimizeLevel === \"number\") {\n optimizeLevel = args.optimizeLevel;\n }\n if (typeof args.shrinkLevel === \"number\") {\n shrinkLevel = args.shrinkLevel;\n }\n optimizeLevel = Math.min(Math.max(optimizeLevel, 0), 3);\n shrinkLevel = Math.min(Math.max(shrinkLevel, 0), 2);\n\n // Begin compilation\n const compilerOptions = assemblyscript.createOptions();\n assemblyscript.setTarget(compilerOptions, 0);\n assemblyscript.setNoAssert(compilerOptions, args.noAssert);\n assemblyscript.setImportMemory(compilerOptions, args.importMemory);\n assemblyscript.setSharedMemory(compilerOptions, args.sharedMemory);\n assemblyscript.setImportTable(compilerOptions, args.importTable);\n assemblyscript.setExplicitStart(compilerOptions, args.explicitStart);\n assemblyscript.setMemoryBase(compilerOptions, args.memoryBase >>> 0);\n assemblyscript.setSourceMap(compilerOptions, args.sourceMap != null);\n assemblyscript.setOptimizeLevelHints(compilerOptions, optimizeLevel, shrinkLevel);\n\n // Initialize default aliases\n assemblyscript.setGlobalAlias(compilerOptions, \"Math\", \"NativeMath\");\n assemblyscript.setGlobalAlias(compilerOptions, \"Mathf\", \"NativeMathf\");\n assemblyscript.setGlobalAlias(compilerOptions, \"abort\", \"~lib/builtins/abort\");\n assemblyscript.setGlobalAlias(compilerOptions, \"trace\", \"~lib/builtins/trace\");\n\n // Add or override aliases if specified\n if (args.use) {\n let aliases = args.use;\n for (let i = 0, k = aliases.length; i < k; ++i) {\n let part = aliases[i];\n let p = part.indexOf(\"=\");\n if (p < 0) return callback(Error(\"Global alias '\" + part + \"' is invalid.\"));\n let alias = part.substring(0, p).trim();\n let name = part.substring(p + 1).trim();\n if (!alias.length) return callback(Error(\"Global alias '\" + part + \"' is invalid.\"));\n assemblyscript.setGlobalAlias(compilerOptions, alias, name);\n }\n }\n\n // Enable additional features if specified\n var features = args.enable;\n if (features != null) {\n if (typeof features === \"string\") features = features.split(\",\");\n for (let i = 0, k = features.length; i < k; ++i) {\n let name = features[i].trim();\n let flag = assemblyscript[\"FEATURE_\" + name.replace(/\\-/g, \"_\").toUpperCase()];\n if (!flag) return callback(Error(\"Feature '\" + name + \"' is unknown.\"));\n assemblyscript.enableFeature(compilerOptions, flag);\n }\n }\n\n var module;\n stats.compileCount++;\n try {\n stats.compileTime += measure(() => {\n module = assemblyscript.compileProgram(program, compilerOptions);\n });\n } catch (e) {\n return callback(e);\n }\n if (checkDiagnostics(parser, stderr)) {\n if (module) module.dispose();\n return callback(Error(\"Compile error\"));\n }\n\n // Validate the module if requested\n if (args.validate) {\n stats.validateCount++;\n stats.validateTime += measure(() => {\n if (!module.validate()) {\n module.dispose();\n return callback(Error(\"Validate error\"));\n }\n });\n }\n\n // Set Binaryen-specific options\n if (args.trapMode === \"clamp\") {\n stats.optimizeCount++;\n stats.optimizeTime += measure(() => {\n module.runPasses([ \"trap-mode-clamp\" ]);\n });\n } else if (args.trapMode === \"js\") {\n stats.optimizeCount++;\n stats.optimizeTime += measure(() => {\n module.runPasses([ \"trap-mode-js\" ]);\n });\n } else if (args.trapMode !== \"allow\") {\n module.dispose();\n return callback(Error(\"Unsupported trap mode\"));\n }\n\n // Implicitly run costly non-LLVM optimizations on -O3 or -Oz\n // see: https://github.com/WebAssembly/binaryen/pull/1596\n if (optimizeLevel >= 3 || shrinkLevel >= 2) optimizeLevel = 4;\n\n module.setOptimizeLevel(optimizeLevel);\n module.setShrinkLevel(shrinkLevel);\n module.setDebugInfo(args.debug);\n\n var runPasses = [];\n if (args.runPasses) {\n if (typeof args.runPasses === \"string\") {\n args.runPasses = args.runPasses.split(\",\");\n }\n if (args.runPasses.length) {\n args.runPasses.forEach(pass => {\n if (runPasses.indexOf(pass) < 0)\n runPasses.push(pass);\n });\n }\n }\n\n // Optimize the module if requested\n if (optimizeLevel > 0 || shrinkLevel > 0) {\n stats.optimizeCount++;\n stats.optimizeTime += measure(() => {\n module.optimize();\n });\n }\n\n // Run additional passes if requested\n if (runPasses.length) {\n stats.optimizeCount++;\n stats.optimizeTime += measure(() => {\n module.runPasses(runPasses.map(pass => pass.trim()));\n });\n }\n\n // Prepare output\n if (!args.noEmit) {\n let hasStdout = false;\n let hasOutput = false;\n\n if (args.outFile != null) {\n if (/\\.was?t$/.test(args.outFile) && args.textFile == null) {\n args.textFile = args.outFile;\n } else if (/\\.js$/.test(args.outFile) && args.asmjsFile == null) {\n args.asmjsFile = args.outFile;\n } else if (args.binaryFile == null) {\n args.binaryFile = args.outFile;\n }\n }\n\n // Write binary\n if (args.binaryFile != null) {\n let sourceMapURL = args.sourceMap != null\n ? args.sourceMap.length\n ? args.sourceMap\n : path.basename(args.binaryFile) + \".map\"\n : null;\n\n let wasm;\n stats.emitCount++;\n stats.emitTime += measure(() => {\n wasm = module.toBinary(sourceMapURL)\n });\n\n if (args.binaryFile.length) {\n writeFile(args.binaryFile, wasm.output, baseDir);\n } else {\n writeStdout(wasm.output);\n hasStdout = true;\n }\n hasOutput = true;\n\n // Post-process source map\n if (wasm.sourceMap != null) {\n if (args.binaryFile.length) {\n let sourceMap = JSON.parse(wasm.sourceMap);\n sourceMap.sourceRoot = exports.sourceMapRoot;\n sourceMap.sources.forEach((name, index) => {\n let text = null;\n if (name.startsWith(exports.libraryPrefix)) {\n let stdName = name.substring(exports.libraryPrefix.length).replace(/\\.ts$/, \"\");\n if (exports.libraryFiles.hasOwnProperty(stdName)) {\n text = exports.libraryFiles[stdName];\n } else {\n for (let i = 0, k = customLibDirs.length; i < k; ++i) {\n text = readFile(name.substring(exports.libraryPrefix.length), customLibDirs[i]);\n if (text !== null) break;\n }\n }\n } else {\n text = readFile(name, baseDir);\n }\n if (text === null) {\n return callback(Error(\"Source file '\" + name + \"' not found.\"));\n }\n if (!sourceMap.sourceContents) sourceMap.sourceContents = [];\n sourceMap.sourceContents[index] = text;\n });\n writeFile(path.join(\n path.dirname(args.binaryFile),\n path.basename(sourceMapURL)\n ).replace(/^\\.\\//, \"\"), JSON.stringify(sourceMap), baseDir);\n } else {\n stderr.write(\"Skipped source map (stdout already occupied)\" + EOL);\n }\n }\n }\n\n // Write asm.js\n if (args.asmjsFile != null) {\n let asm;\n if (args.asmjsFile.length) {\n stats.emitCount++;\n stats.emitTime += measure(() => {\n asm = module.toAsmjs();\n });\n writeFile(args.asmjsFile, asm, baseDir);\n } else if (!hasStdout) {\n stats.emitCount++;\n stats.emitTime += measure(() => {\n asm = module.toAsmjs();\n });\n writeStdout(asm);\n hasStdout = true;\n }\n hasOutput = true;\n }\n\n // Write WebIDL\n if (args.idlFile != null) {\n let idl;\n if (args.idlFile.length) {\n stats.emitCount++;\n stats.emitTime += measure(() => {\n idl = assemblyscript.buildIDL(program);\n });\n writeFile(args.idlFile, idl, baseDir);\n } else if (!hasStdout) {\n stats.emitCount++;\n stats.emitTime += measure(() => {\n idl = assemblyscript.buildIDL(program);\n });\n writeStdout(idl);\n hasStdout = true;\n }\n hasOutput = true;\n }\n\n // Write TypeScript definition\n if (args.tsdFile != null) {\n let tsd;\n if (args.tsdFile.length) {\n stats.emitCount++;\n stats.emitTime += measure(() => {\n tsd = assemblyscript.buildTSD(program);\n });\n writeFile(args.tsdFile, tsd, baseDir);\n } else if (!hasStdout) {\n stats.emitCount++;\n stats.emitTime += measure(() => {\n tsd = assemblyscript.buildTSD(program);\n });\n writeStdout(tsd);\n hasStdout = true;\n }\n hasOutput = true;\n }\n\n // Write text (must be last)\n if (args.textFile != null || !hasOutput) {\n let wat;\n if (args.textFile && args.textFile.length) {\n stats.emitCount++;\n stats.emitTime += measure(() => {\n wat = module.toText();\n });\n writeFile(args.textFile, wat, baseDir);\n } else if (!hasStdout) {\n stats.emitCount++;\n stats.emitTime += measure(() => {\n wat = module.toText()\n });\n writeStdout(wat);\n }\n }\n }\n\n module.dispose();\n if (args.measure) {\n printStats(stats, stderr);\n }\n if (args.printrtti) {\n printRTTI(program, stderr);\n }\n return callback(null);\n\n function readFileNode(filename, baseDir) {\n try {\n let text;\n stats.readCount++;\n stats.readTime += measure(() => {\n text = fs.readFileSync(path.join(baseDir, filename), { encoding: \"utf8\" });\n });\n return text;\n } catch (e) {\n return null;\n }\n }\n\n function writeFileNode(filename, contents, baseDir) {\n try {\n stats.writeCount++;\n stats.writeTime += measure(() => {\n mkdirp(path.join(baseDir, path.dirname(filename)));\n if (typeof contents === \"string\") {\n fs.writeFileSync(path.join(baseDir, filename), contents, { encoding: \"utf8\" } );\n } else {\n fs.writeFileSync(path.join(baseDir, filename), contents);\n }\n });\n return true;\n } catch (e) {\n return false;\n }\n }\n\n function listFilesNode(dirname, baseDir) {\n var files;\n try {\n stats.readTime += measure(() => {\n files = fs.readdirSync(path.join(baseDir, dirname)).filter(file => /^(?!.*\\.d\\.ts$).*\\.ts$/.test(file));\n });\n return files;\n } catch (e) {\n return [];\n }\n }\n\n function writeStdout(contents) {\n if (!writeStdout.used) {\n stats.writeCount++;\n writeStdout.used = true;\n }\n stats.writeTime += measure(() => {\n if (typeof contents === \"string\") {\n stdout.write(contents, { encoding: \"utf8\" });\n } else {\n stdout.write(contents);\n }\n });\n }\n}\n\n/** Checks diagnostics emitted so far for errors. */\nfunction checkDiagnostics(emitter, stderr) {\n var diagnostic;\n var hasErrors = false;\n while ((diagnostic = assemblyscript.nextDiagnostic(emitter)) != null) {\n if (stderr) {\n stderr.write(\n assemblyscript.formatDiagnostic(diagnostic, stderr.isTTY, true) +\n EOL + EOL\n );\n }\n if (assemblyscript.isError(diagnostic)) hasErrors = true;\n }\n return hasErrors;\n}\n\nexports.checkDiagnostics = checkDiagnostics;\n\n/** Creates an empty set of stats. */\nfunction createStats() {\n return {\n readTime: 0,\n readCount: 0,\n writeTime: 0,\n writeCount: 0,\n parseTime: 0,\n parseCount: 0,\n compileTime: 0,\n compileCount: 0,\n emitTime: 0,\n emitCount: 0,\n validateTime: 0,\n validateCount: 0,\n optimizeTime: 0,\n optimizeCount: 0\n };\n}\n\nexports.createStats = createStats;\n\nif (!process.hrtime) process.hrtime = require(\"browser-process-hrtime\");\n\n/** Measures the execution time of the specified function. */\nfunction measure(fn) {\n const start = process.hrtime();\n fn();\n const times = process.hrtime(start);\n return times[0] * 1e9 + times[1];\n}\n\nexports.measure = measure;\n\n/** Formats a high resolution time to a human readable string. */\nfunction formatTime(time) {\n return time ? (time / 1e6).toFixed(3) + \" ms\" : \"N/A\";\n}\n\nexports.formatTime = formatTime;\n\n/** Formats and prints out the contents of a set of stats. */\nfunction printStats(stats, output) {\n function format(time, count) {\n return formatTime(time);\n }\n (output || process.stdout).write([\n \"I/O Read : \" + format(stats.readTime, stats.readCount),\n \"I/O Write : \" + format(stats.writeTime, stats.writeCount),\n \"Parse : \" + format(stats.parseTime, stats.parseCount),\n \"Compile : \" + format(stats.compileTime, stats.compileCount),\n \"Emit : \" + format(stats.emitTime, stats.emitCount),\n \"Validate : \" + format(stats.validateTime, stats.validateCount),\n \"Optimize : \" + format(stats.optimizeTime, stats.optimizeCount)\n ].join(EOL) + EOL);\n}\n\nexports.printStats = printStats;\n\n/** Prints runtime type information. */\nfunction printRTTI(program, output) {\n if (!output) output = process.stderr;\n output.write(\"# Runtime type information (RTTI)\\n\");\n output.write(assemblyscript.buildRTTI(program));\n}\n\nexports.printRTTI = printRTTI;\n\nvar allocBuffer = typeof global !== \"undefined\" && global.Buffer\n ? global.Buffer.allocUnsafe || function(len) { return new global.Buffer(len); }\n : function(len) { return new Uint8Array(len) };\n\n/** Creates a memory stream that can be used in place of stdout/stderr. */\nfunction createMemoryStream(fn) {\n var stream = [];\n stream.write = function(chunk) {\n if (fn) fn(chunk);\n if (typeof chunk === \"string\") {\n let buffer = allocBuffer(utf8.length(chunk));\n utf8.write(chunk, buffer, 0);\n chunk = buffer;\n }\n this.push(chunk);\n };\n stream.reset = function() {\n stream.length = 0;\n };\n stream.toBuffer = function() {\n var offset = 0, i = 0, k = this.length;\n while (i < k) offset += this[i++].length;\n var buffer = allocBuffer(offset);\n offset = i = 0;\n while (i < k) {\n buffer.set(this[i], offset);\n offset += this[i].length;\n ++i;\n }\n return buffer;\n };\n stream.toString = function() {\n var buffer = this.toBuffer();\n return utf8.read(buffer, 0, buffer.length);\n };\n return stream;\n}\n\nexports.createMemoryStream = createMemoryStream;\n\n/** Compatible TypeScript compiler options for syntax highlighting etc. */\nexports.tscOptions = {\n alwaysStrict: true,\n noImplicitAny: true,\n noImplicitReturns: true,\n noImplicitThis: true,\n noEmitOnError: true,\n strictNullChecks: true,\n experimentalDecorators: true,\n target: \"esnext\",\n module: \"commonjs\",\n noLib: true,\n types: [],\n allowJs: false\n};\n","\"use strict\";\r\n\r\n/**\r\n * A minimal UTF8 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar utf8 = exports;\r\n\r\n/**\r\n * Calculates the UTF8 byte length of a string.\r\n * @param {string} string String\r\n * @returns {number} Byte length\r\n */\r\nutf8.length = function utf8_length(string) {\r\n var len = 0,\r\n c = 0;\r\n for (var i = 0; i < string.length; ++i) {\r\n c = string.charCodeAt(i);\r\n if (c < 128)\r\n len += 1;\r\n else if (c < 2048)\r\n len += 2;\r\n else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) {\r\n ++i;\r\n len += 4;\r\n } else\r\n len += 3;\r\n }\r\n return len;\r\n};\r\n\r\n/**\r\n * Reads UTF8 bytes as a string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} String read\r\n */\r\nutf8.read = function utf8_read(buffer, start, end) {\r\n var len = end - start;\r\n if (len < 1)\r\n return \"\";\r\n var parts = null,\r\n chunk = [],\r\n i = 0, // char offset\r\n t; // temporary\r\n while (start < end) {\r\n t = buffer[start++];\r\n if (t < 128)\r\n chunk[i++] = t;\r\n else if (t > 191 && t < 224)\r\n chunk[i++] = (t & 31) << 6 | buffer[start++] & 63;\r\n else if (t > 239 && t < 365) {\r\n t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000;\r\n chunk[i++] = 0xD800 + (t >> 10);\r\n chunk[i++] = 0xDC00 + (t & 1023);\r\n } else\r\n chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63;\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\n/**\r\n * Writes a string as UTF8 bytes.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Bytes written\r\n */\r\nutf8.write = function utf8_write(string, buffer, offset) {\r\n var start = offset,\r\n c1, // character 1\r\n c2; // character 2\r\n for (var i = 0; i < string.length; ++i) {\r\n c1 = string.charCodeAt(i);\r\n if (c1 < 128) {\r\n buffer[offset++] = c1;\r\n } else if (c1 < 2048) {\r\n buffer[offset++] = c1 >> 6 | 192;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) {\r\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\r\n ++i;\r\n buffer[offset++] = c1 >> 18 | 240;\r\n buffer[offset++] = c1 >> 12 & 63 | 128;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else {\r\n buffer[offset++] = c1 >> 12 | 224;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n }\r\n }\r\n return offset - start;\r\n};\r\n","var proc = typeof process !== \"undefined\" && process || {};\nvar isCI = proc.env && \"CI\" in proc.env; // doesn't work when bundled because 'process' is a mock\n\nfunction from(stream, base) {\n var colors = base || {};\n colors.supported = (stream && !!stream.isTTY) || isCI;\n colors.gray = text => colors.supported ? exports.GRAY + text + exports.RESET : text;\n colors.red = text => colors.supported ? exports.RED + text + exports.RESET : text;\n colors.green = text => colors.supported ? exports.GREEN + text + exports.RESET : text;\n colors.yellow = text => colors.supported ? exports.YELLOW + text + exports.RESET : text;\n colors.blue = text => colors.supported ? exports.BLUE + text + exports.RESET : text;\n colors.magenta = text => colors.supported ? exports.MAGENTA + text + exports.RESET : text;\n colors.cyan = text => colors.supported ? exports.CYAN + text + exports.RESET : text;\n colors.white = text => colors.supported ? exports.WHITE + text + exports.RESET : text;\n return colors;\n}\n\nexports.stdout = from(proc.stdout, exports);\nexports.stderr = from(proc.stderr);\nexports.from = from;\n\nexports.GRAY = \"\\u001b[90m\";\nexports.RED = \"\\u001b[91m\";\nexports.GREEN = \"\\u001b[92m\";\nexports.YELLOW = \"\\u001b[93m\";\nexports.BLUE = \"\\u001b[94m\";\nexports.MAGENTA = \"\\u001b[95m\";\nexports.CYAN = \"\\u001b[96m\";\nexports.WHITE = \"\\u001b[97m\";\nexports.RESET = \"\\u001b[0m\";\n","// type | meaning\n// -----|---------------\n// b | boolean\n// i | integer\n// f | float\n// s | string\n// I | integer array\n// F | float array\n// S | string array\n\n/** Parses the specified command line arguments according to the given configuration. */\nfunction parse(argv, config) {\n var options = {};\n var unknown = [];\n var arguments = [];\n var trailing = [];\n\n // make an alias map and initialize defaults\n var aliases = {};\n Object.keys(config).forEach(key => {\n if (key.startsWith(\" \")) return;\n var option = config[key];\n if (option.alias != null) {\n if (typeof option.alias === \"string\") aliases[option.alias] = key;\n else if (Array.isArray(option.alias)) option.alias.forEach(alias => aliases[alias] = key);\n }\n if (option.default != null) options[key] = option.default;\n });\n\n // iterate over argv\n for (var i = 0, k = (argv = argv.slice()).length; i < k; ++i) {\n let arg = argv[i];\n if (arg == \"--\") { ++i; break; }\n let match = /^(?:(\\-\\w)(?:=(.*))?|(\\-\\-\\w{2,})(?:=(.*))?)$/.exec(arg), option, key;\n if (match) {\n if (config[arg]) option = config[key = arg]; // exact\n else if (match[1] != null) { // alias\n option = config[key = aliases[match[1].substring(1)]];\n if (option && match[2] != null) argv[i--] = match[2];\n } else if (match[3] != null) { // full\n option = config[key = match[3].substring(2)];\n if (option && match[4] != null) argv[i--] = match[4];\n }\n } else {\n if (arg.charCodeAt(0) == 45) option = config[key = arg]; // exact\n else { arguments.push(arg); continue; } // argument\n }\n if (option) {\n if (option.type == null || option.type === \"b\") options[key] = true; // flag\n else {\n if (i + 1 < argv.length && argv[i + 1].charCodeAt(0) != 45) { // present\n switch (option.type) {\n case \"i\": options[key] = parseInt(argv[++i], 10); break;\n case \"I\": options[key] = (options[key] || []).concat(parseInt(argv[++i], 10)); break;\n case \"f\": options[key] = parseFloat(argv[++i]); break;\n case \"F\": options[key] = (options[key] || []).concat(parseFloat(argv[++i])); break;\n case \"s\": options[key] = String(argv[++i]); break;\n case \"S\": options[key] = (options[key] || []).concat(argv[++i].split(\",\")); break;\n default: unknown.push(arg); --i;\n }\n } else { // omitted\n switch (option.type) {\n case \"i\":\n case \"f\": options[key] = option.default || 0; break;\n case \"s\": options[key] = option.default || \"\"; break;\n case \"I\":\n case \"F\":\n case \"S\": options[key] = options.default || []; break;\n default: unknown.push(arg);\n }\n }\n }\n if (option.value) Object.keys(option.value).forEach(k => options[k] = option.value[k]);\n } else unknown.push(arg);\n }\n while (i < k) trailing.push(argv[i++]); // trailing\n\n return { options, unknown, arguments, trailing };\n}\n\nexports.parse = parse;\n\n/** Generates the help text for the specified configuration. */\nfunction help(config, options) {\n if (!options) options = {};\n var indent = options.indent || 2;\n var padding = options.padding || 24;\n var eol = options.eol || \"\\n\";\n var sb = [];\n Object.keys(config).forEach(key => {\n var option = config[key];\n if (option.description == null) return;\n var text = \"\";\n while (text.length < indent) text += \" \";\n text += \"--\" + key;\n if (option.alias) text += \", -\" + option.alias;\n while (text.length < padding) text += \" \";\n if (Array.isArray(option.description)) {\n sb.push(text + option.description[0] + option.description.slice(1).map(line => {\n for (let i = 0; i < padding; ++i) line = \" \" + line;\n return eol + line;\n }).join(\"\"));\n } else sb.push(text + option.description);\n });\n return sb.join(eol);\n}\n\nexports.help = help;\n","/*\nCopyright 2010 James Halliday (mail@substack.net)\n\nThis project is free software released under the MIT/X11 license:\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n*/\n\nvar path = require(\"path\");\nvar fs = require(\"fs\");\nvar _0777 = parseInt(\"0777\", 8);\n\nmodule.exports = function mkdirp(p, opts, made) {\n if (!opts || typeof opts !== \"object\") {\n opts = { mode: opts };\n }\n var mode = opts.mode;\n if (mode === undefined) {\n mode = _0777 & (~process.umask());\n }\n if (!made) made = null;\n p = path.resolve(p);\n try {\n fs.mkdirSync(p, mode);\n made = made || p;\n } catch (err0) {\n switch (err0.code) {\n case \"ENOENT\":\n made = mkdirp(path.dirname(p), opts, made);\n mkdirp(p, opts, made);\n break;\n default:\n var stat;\n try {\n stat = fs.statSync(p);\n } catch (err1) {\n throw err0;\n }\n if (!stat.isDirectory()) throw err0;\n break;\n }\n }\n return made;\n};\n","if(typeof __WEBPACK_EXTERNAL_MODULE__10__ === 'undefined') {var e = new Error(\"Cannot find module 'assemblyscript'\"); e.code = 'MODULE_NOT_FOUND'; throw e;}\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__10__;","function webpackEmptyContext(req) {\n\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\te.code = 'MODULE_NOT_FOUND';\n\tthrow e;\n}\nwebpackEmptyContext.keys = function() { return []; };\nwebpackEmptyContext.resolve = webpackEmptyContext;\nmodule.exports = webpackEmptyContext;\nwebpackEmptyContext.id = 12;","module.exports = process.hrtime || hrtime\n\n// polyfil for window.performance.now\nvar performance = global.performance || {}\nvar performanceNow =\n performance.now ||\n performance.mozNow ||\n performance.msNow ||\n performance.oNow ||\n performance.webkitNow ||\n function(){ return (new Date()).getTime() }\n\n// generate timestamp or delta\n// see http://nodejs.org/api/process.html#process_process_hrtime\nfunction hrtime(previousTimestamp){\n var clocktime = performanceNow.call(performance)*1e-3\n var seconds = Math.floor(clocktime)\n var nanoseconds = Math.floor((clocktime%1)*1e9)\n if (previousTimestamp) {\n seconds = seconds - previousTimestamp[0]\n nanoseconds = nanoseconds - previousTimestamp[1]\n if (nanoseconds<0) {\n seconds--\n nanoseconds += 1e9\n }\n }\n return [seconds,nanoseconds]\n}"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/assemblyscript.d.ts b/dist/assemblyscript.d.ts index 97612d7a88..f57db2b8a4 100644 --- a/dist/assemblyscript.d.ts +++ b/dist/assemblyscript.d.ts @@ -12,5597 +12,5606 @@ declare type f64 = number; declare module 'assemblyscript' { export * from 'assemblyscript/src/index'; } -declare module 'assemblyscript/src/common' { - /** - * Common constants. - * @module common - */ /***/ - /** Indicates traits of a {@link Node} or {@link Element}. */ - export enum CommonFlags { - /** No flags set. */ - NONE = 0, - /** Has an `import` modifier. */ - IMPORT = 1, - /** Has an `export` modifier. */ - EXPORT = 2, - /** Has a `declare` modifier. */ - DECLARE = 4, - /** Has a `const` modifier. */ - CONST = 8, - /** Has a `let` modifier. */ - LET = 16, - /** Has a `static` modifier. */ - STATIC = 32, - /** Has a `readonly` modifier. */ - READONLY = 64, - /** Has an `abstract` modifier. */ - ABSTRACT = 128, - /** Has a `public` modifier. */ - PUBLIC = 256, - /** Has a `private` modifier. */ - PRIVATE = 512, - /** Has a `protected` modifier. */ - PROTECTED = 1024, - /** Has a `get` modifier. */ - GET = 2048, - /** Has a `set` modifier. */ - SET = 4096, - /** Has a definite assignment assertion `!` as in `x!: i32;`. */ - DEFINITE_ASSIGNMENT = 8192, - /** Is ambient, that is either declared or nested in a declared element. */ - AMBIENT = 16384, - /** Is generic. */ - GENERIC = 32768, - /** Is part of a generic context. */ - GENERIC_CONTEXT = 65536, - /** Is an instance member. */ - INSTANCE = 131072, - /** Is a constructor. */ - CONSTRUCTOR = 262144, - /** Is a module export. */ - MODULE_EXPORT = 524288, - /** Is a module import. */ - MODULE_IMPORT = 1048576, - /** Is resolved. */ - RESOLVED = 2097152, - /** Is compiled. */ - COMPILED = 4194304, - /** Has a constant value and is therefore inlined. */ - INLINED = 8388608, - /** Is scoped. */ - SCOPED = 16777216, - /** Is a trampoline. */ - TRAMPOLINE = 33554432, - /** Is a virtual method. */ - VIRTUAL = 67108864, - /** Is the main function. */ - MAIN = 134217728, - /** Is quoted. */ - QUOTED = 268435456 - } - /** Path delimiter inserted between file system levels. */ - export const PATH_DELIMITER = "/"; - /** Substitution used to indicate the parent directory. */ - export const PARENT_SUBST = ".."; - /** Function name prefix used for getters. */ - export const GETTER_PREFIX = "get:"; - /** Function name prefix used for setters. */ - export const SETTER_PREFIX = "set:"; - /** Delimiter used between class names and instance members. */ - export const INSTANCE_DELIMITER = "#"; - /** Delimiter used between class and namespace names and static members. */ - export const STATIC_DELIMITER = "."; - /** Delimiter used between a function and its inner elements. */ - export const INNER_DELIMITER = "~"; - /** Substitution used to indicate a library directory. */ - export const LIBRARY_SUBST = "~lib"; - /** Library directory prefix. */ - export const LIBRARY_PREFIX: string; - /** Path index suffix. */ - export const INDEX_SUFFIX: string; - /** Common compiler symbols. */ - export namespace CommonSymbols { - const EMPTY = ""; - const i8 = "i8"; - const i16 = "i16"; - const i32 = "i32"; - const i64 = "i64"; - const isize = "isize"; - const u8 = "u8"; - const u16 = "u16"; - const u32 = "u32"; - const u64 = "u64"; - const usize = "usize"; - const bool = "bool"; - const f32 = "f32"; - const f64 = "f64"; - const v128 = "v128"; - const i8x16 = "i8x16"; - const u8x16 = "u8x16"; - const i16x8 = "i16x8"; - const u16x8 = "u16x8"; - const i32x4 = "i32x4"; - const u32x4 = "u32x4"; - const i64x2 = "i64x2"; - const u64x2 = "u64x2"; - const f32x4 = "f32x4"; - const f64x2 = "f64x2"; - const void_ = "void"; - const number = "number"; - const boolean = "boolean"; - const string = "string"; - const native = "native"; - const null_ = "null"; - const true_ = "true"; - const false_ = "false"; - const this_ = "this"; - const super_ = "super"; - const constructor = "constructor"; - const ASC_TARGET = "ASC_TARGET"; - const ASC_NO_TREESHAKING = "ASC_NO_TREESHAKING"; - const ASC_NO_ASSERT = "ASC_NO_ASSERT"; - const ASC_MEMORY_BASE = "ASC_MEMORY_BASE"; - const ASC_OPTIMIZE_LEVEL = "ASC_OPTIMIZE_LEVEL"; - const ASC_SHRINK_LEVEL = "ASC_SHRINK_LEVEL"; - const ASC_FEATURE_MUTABLE_GLOBAL = "ASC_FEATURE_MUTABLE_GLOBAL"; - const ASC_FEATURE_SIGN_EXTENSION = "ASC_FEATURE_SIGN_EXTENSION"; - const ASC_FEATURE_BULK_MEMORY = "ASC_FEATURE_BULK_MEMORY"; - const ASC_FEATURE_SIMD = "ASC_FEATURE_SIMD"; - const ASC_FEATURE_THREADS = "ASC_FEATURE_THREADS"; - const I8 = "I8"; - const I16 = "I16"; - const I32 = "I32"; - const I64 = "I64"; - const Isize = "Isize"; - const U8 = "U8"; - const U16 = "U16"; - const U32 = "U32"; - const U64 = "U64"; - const Usize = "Usize"; - const Bool = "Bool"; - const F32 = "F32"; - const F64 = "F64"; - const V128 = "V128"; - const String = "String"; - const Array = "Array"; - const FixedArray = "FixedArray"; - const Set = "Set"; - const Map = "Map"; - const ArrayBufferView = "ArrayBufferView"; - const ArrayBuffer = "ArrayBuffer"; - const Math = "Math"; - const Mathf = "Mathf"; - const Int8Array = "Int8Array"; - const Int16Array = "Int16Array"; - const Int32Array = "Int32Array"; - const Int64Array = "Int64Array"; - const Uint8Array = "Uint8Array"; - const Uint8ClampedArray = "Uint8ClampedArray"; - const Uint16Array = "Uint16Array"; - const Uint32Array = "Uint32Array"; - const Uint64Array = "Uint64Array"; - const Float32Array = "Float32Array"; - const Float64Array = "Float64Array"; - const abort = "abort"; - const pow = "pow"; - const mod = "mod"; - const alloc = "__alloc"; - const realloc = "__realloc"; - const free = "__free"; - const retain = "__retain"; - const release = "__release"; - const collect = "__collect"; - const typeinfo = "__typeinfo"; - const instanceof_ = "__instanceof"; - const visit = "__visit"; - const allocArray = "__allocArray"; - } - export { Feature } from 'assemblyscript/std/assembly/shared/feature'; - export { Target } from 'assemblyscript/std/assembly/shared/target'; - export { Typeinfo, TypeinfoFlags } from 'assemblyscript/std/assembly/shared/typeinfo'; - -} -declare module 'assemblyscript/src/diagnosticMessages.generated' { - /** - * Generated from diagnosticsMessages.json. Do not edit. - * @module diagnostics - */ /***/ - /** Enum of available diagnostic codes. */ - export enum DiagnosticCode { - Operation_not_supported = 100, - Operation_is_unsafe = 101, - User_defined_0 = 102, - Conversion_from_type_0_to_1_requires_an_explicit_cast = 200, - Conversion_from_type_0_to_1_will_require_an_explicit_cast_when_switching_between_32_64_bit = 201, - Type_0_cannot_be_changed_to_type_1 = 202, - Type_0_cannot_be_reinterpreted_as_type_1 = 203, - Basic_type_0_cannot_be_nullable = 204, - Cannot_export_a_mutable_global = 205, - Mutable_value_cannot_be_inlined = 206, - Unmanaged_classes_cannot_extend_managed_classes_and_vice_versa = 207, - Unmanaged_classes_cannot_implement_interfaces = 208, - Invalid_regular_expression_flags = 209, - Implementation_0_must_match_the_signature_1 = 210, - Class_0_is_sealed_and_cannot_be_extended = 211, - Decorator_0_is_not_valid_here = 212, - Duplicate_decorator = 213, - An_allocator_must_be_present_to_use_0 = 214, - Optional_parameter_must_have_an_initializer = 215, - Constructor_of_class_0_must_not_require_any_arguments = 216, - Function_0_cannot_be_inlined_into_itself = 217, - Cannot_access_method_0_without_calling_it_as_it_requires_this_to_be_set = 218, - Optional_properties_are_not_supported = 219, - Expression_must_be_a_compile_time_constant = 220, - Module_cannot_have_multiple_start_functions = 221, - _0_must_be_a_value_between_1_and_2_inclusive = 222, - _0_must_be_a_power_of_two = 223, - TODO_Cannot_inline_inferred_calls_and_specific_internals_yet = 224, - Expression_is_never_null = 225, - Unterminated_string_literal = 1002, - Identifier_expected = 1003, - _0_expected = 1005, - A_file_cannot_have_a_reference_to_itself = 1006, - Trailing_comma_not_allowed = 1009, - Unexpected_token = 1012, - A_rest_parameter_must_be_last_in_a_parameter_list = 1014, - Parameter_cannot_have_question_mark_and_initializer = 1015, - A_required_parameter_cannot_follow_an_optional_parameter = 1016, - Statements_are_not_allowed_in_ambient_contexts = 1036, - Initializers_are_not_allowed_in_ambient_contexts = 1039, - _0_modifier_cannot_be_used_here = 1042, - A_rest_parameter_cannot_be_optional = 1047, - A_rest_parameter_cannot_have_an_initializer = 1048, - A_set_accessor_must_have_exactly_one_parameter = 1049, - A_set_accessor_parameter_cannot_have_an_initializer = 1052, - A_get_accessor_cannot_have_parameters = 1054, - Enum_member_must_have_initializer = 1061, - Type_parameters_cannot_appear_on_a_constructor_declaration = 1092, - Type_annotation_cannot_appear_on_a_constructor_declaration = 1093, - An_accessor_cannot_have_type_parameters = 1094, - A_set_accessor_cannot_have_a_return_type_annotation = 1095, - Type_parameter_list_cannot_be_empty = 1098, - A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement = 1104, - A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement = 1105, - A_return_statement_can_only_be_used_within_a_function_body = 1108, - Expression_expected = 1109, - Type_expected = 1110, - A_default_clause_cannot_appear_more_than_once_in_a_switch_statement = 1113, - Duplicate_label_0 = 1114, - An_export_assignment_cannot_have_modifiers = 1120, - Octal_literals_are_not_allowed_in_strict_mode = 1121, - Digit_expected = 1124, - Hexadecimal_digit_expected = 1125, - Unexpected_end_of_text = 1126, - Invalid_character = 1127, - _case_or_default_expected = 1130, - _super_must_be_followed_by_an_argument_list_or_member_access = 1034, - A_declare_modifier_cannot_be_used_in_an_already_ambient_context = 1038, - Type_argument_expected = 1140, - String_literal_expected = 1141, - Line_break_not_permitted_here = 1142, - Declaration_expected = 1146, - _const_declarations_must_be_initialized = 1155, - Unterminated_regular_expression_literal = 1161, - Interface_declaration_cannot_have_implements_clause = 1176, - Binary_digit_expected = 1177, - Octal_digit_expected = 1178, - An_implementation_cannot_be_declared_in_ambient_contexts = 1183, - An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive = 1198, - Unterminated_Unicode_escape_sequence = 1199, - Decorators_are_not_valid_here = 1206, - _abstract_modifier_can_only_appear_on_a_class_method_or_property_declaration = 1242, - Method_0_cannot_have_an_implementation_because_it_is_marked_abstract = 1245, - A_definite_assignment_assertion_is_not_permitted_in_this_context = 1255, - A_class_may_only_extend_another_class = 1311, - A_parameter_property_cannot_be_declared_using_a_rest_parameter = 1317, - Duplicate_identifier_0 = 2300, - Cannot_find_name_0 = 2304, - Module_0_has_no_exported_member_1 = 2305, - Generic_type_0_requires_1_type_argument_s = 2314, - Type_0_is_not_generic = 2315, - Type_0_is_not_assignable_to_type_1 = 2322, - Index_signature_is_missing_in_type_0 = 2329, - _this_cannot_be_referenced_in_current_location = 2332, - _super_can_only_be_referenced_in_a_derived_class = 2335, - Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors = 2337, - Property_0_does_not_exist_on_type_1 = 2339, - Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures = 2349, - Cannot_use_new_with_an_expression_whose_type_lacks_a_construct_signature = 2351, - A_function_whose_declared_type_is_not_void_must_return_a_value = 2355, - The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access = 2357, - The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access = 2364, - Operator_0_cannot_be_applied_to_types_1_and_2 = 2365, - A_super_call_must_be_the_first_statement_in_the_constructor = 2376, - Constructors_for_derived_classes_must_contain_a_super_call = 2377, - _get_and_set_accessor_must_have_the_same_type = 2380, - Constructor_implementation_is_missing = 2390, - Function_implementation_is_missing_or_not_immediately_following_the_declaration = 2391, - Multiple_constructor_implementations_are_not_allowed = 2392, - Duplicate_function_implementation = 2393, - Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local = 2395, - A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged = 2434, - Type_0_has_no_property_1 = 2460, - The_0_operator_cannot_be_applied_to_type_1 = 2469, - In_const_enum_declarations_member_initializer_must_be_constant_expression = 2474, - Export_declaration_conflicts_with_exported_declaration_of_0 = 2484, - Object_is_possibly_null = 2531, - Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property = 2540, - The_target_of_an_assignment_must_be_a_variable_or_a_property_access = 2541, - Index_signature_in_type_0_only_permits_reading = 2542, - Expected_0_arguments_but_got_1 = 2554, - Expected_at_least_0_arguments_but_got_1 = 2555, - Expected_0_type_arguments_but_got_1 = 2558, - A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums = 2651, - Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration = 2673, - Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration = 2674, - Namespace_0_has_no_exported_member_1 = 2694, - Required_type_parameters_may_not_follow_optional_type_parameters = 2706, - Duplicate_property_0 = 2718, - File_0_not_found = 6054, - Numeric_separators_are_not_allowed_here = 6188, - Multiple_consecutive_numeric_separators_are_not_permitted = 6189, - _super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class = 17009, - _super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class = 17011 - } - /** Translates a diagnostic code to its respective string. */ - export function diagnosticCodeToString(code: DiagnosticCode): string; - -} -declare module 'assemblyscript/src/util/bitset' { - /** @module util */ /***/ - /** Tests if the bit at the specified index is set within a 64-bit map. */ - export function bitsetIs(map: I64, index: i32): bool; - /** Sets or unsets the bit at the specified index within a 64-bit map and returns the new map. */ - export function bitsetSet(map: I64, index: i32, isSet: bool): I64; - -} -declare module 'assemblyscript/src/util/charcode' { - /** @module util */ /***/ - /** An enum of named character codes. */ - export const enum CharCode { - NULL = 0, - LINEFEED = 10, - CARRIAGERETURN = 13, - LINESEPARATOR = 8232, - PARAGRAPHSEPARATOR = 8233, - NEXTLINE = 133, - SPACE = 32, - NONBREAKINGSPACE = 160, - ENQUAD = 8192, - EMQUAD = 8193, - ENSPACE = 8194, - EMSPACE = 8195, - THREEPEREMSPACE = 8196, - FOURPEREMSPACE = 8197, - SIXPEREMSPACE = 8198, - FIGURESPACE = 8199, - PUNCTUATIONSPACE = 8200, - THINSPACE = 8201, - HAIRSPACE = 8202, - ZEROWIDTHSPACE = 8203, - NARROWNOBREAKSPACE = 8239, - IDEOGRAPHICSPACE = 12288, - MATHEMATICALSPACE = 8287, - OGHAM = 5760, - _ = 95, - _0 = 48, - _1 = 49, - _2 = 50, - _3 = 51, - _4 = 52, - _5 = 53, - _6 = 54, - _7 = 55, - _8 = 56, - _9 = 57, - a = 97, - b = 98, - c = 99, - d = 100, - e = 101, - f = 102, - g = 103, - h = 104, - i = 105, - j = 106, - k = 107, - l = 108, - m = 109, - n = 110, - o = 111, - p = 112, - q = 113, - r = 114, - s = 115, - t = 116, - u = 117, - v = 118, - w = 119, - x = 120, - y = 121, - z = 122, - A = 65, - B = 66, - C = 67, - D = 68, - E = 69, - F = 70, - G = 71, - H = 72, - I = 73, - J = 74, - K = 75, - L = 76, - M = 77, - N = 78, - O = 79, - P = 80, - Q = 81, - R = 82, - S = 83, - T = 84, - U = 85, - V = 86, - W = 87, - X = 88, - Y = 89, - Z = 90, - AMPERSAND = 38, - ASTERISK = 42, - AT = 64, - BACKSLASH = 92, - BACKTICK = 96, - BAR = 124, - CARET = 94, - CLOSEBRACE = 125, - CLOSEBRACKET = 93, - CLOSEPAREN = 41, - COLON = 58, - COMMA = 44, - DOLLAR = 36, - DOT = 46, - DOUBLEQUOTE = 34, - EQUALS = 61, - EXCLAMATION = 33, - GREATERTHAN = 62, - HASH = 35, - LESSTHAN = 60, - MINUS = 45, - OPENBRACE = 123, - OPENBRACKET = 91, - OPENPAREN = 40, - PERCENT = 37, - PLUS = 43, - QUESTION = 63, - SEMICOLON = 59, - SINGLEQUOTE = 39, - SLASH = 47, - TILDE = 126, - BACKSPACE = 8, - FORMFEED = 12, - BYTEORDERMARK = 65279, - TAB = 9, - VERTICALTAB = 11 - } - /** Tests if the specified character code is some sort of line break. */ - export function isLineBreak(c: CharCode): bool; - /** Tests if the specified character code is some sort of white space. */ - export function isWhiteSpace(c: i32): bool; - /** Tests if the specified character code is a valid decimal digit. */ - export function isDecimalDigit(c: i32): bool; - /** Tests if the specified character code is a valid octal digit. */ - export function isOctalDigit(c: i32): bool; - /** Tests if the specified character code is a valid start of an identifier. */ - export function isIdentifierStart(c: i32): bool; - /** Tests if the specified character code is a valid keyword character. */ - export function isKeywordCharacter(c: i32): bool; - /** Tests if the specified character code is a valid part of an identifier. */ - export function isIdentifierPart(c: i32): bool; - -} -declare module 'assemblyscript/src/util/collections' { - export function makeArray(original?: Array | null): Array; - export function makeSet(original?: Set | null): Set; - export function makeMap(original?: Map | null, overrides?: Map | null): Map; - -} -declare module 'assemblyscript/src/util/path' { - /** @module util */ /***/ - /** - * Normalizes the specified path, removing interior placeholders. - * Expects a posix-compatible relative path (not Windows compatible). - */ - export function normalizePath(path: string): string; - /** Resolves the specified path relative to the specified origin. */ - export function resolvePath(normalizedPath: string, origin: string): string; - /** Obtains the directory portion of a normalized path. */ - export function dirname(normalizedPath: string): string; - -} -declare module 'assemblyscript/src/util/text' { - /** @module util */ /***/ - /** Creates an indentation matching the number of specified levels. */ - export function indent(sb: string[], level: i32): void; - -} -declare module 'assemblyscript/src/util/binary' { - /** @module util */ /***/ - /** Reads an 8-bit integer from the specified buffer. */ - export function readI8(buffer: Uint8Array, offset: i32): i32; - /** Writes an 8-bit integer to the specified buffer. */ - export function writeI8(value: i32, buffer: Uint8Array, offset: i32): void; - /** Reads a 16-bit integer from the specified buffer. */ - export function readI16(buffer: Uint8Array, offset: i32): i32; - /** Writes a 16-bit integer to the specified buffer. */ - export function writeI16(value: i32, buffer: Uint8Array, offset: i32): void; - /** Reads a 32-bit integer from the specified buffer. */ - export function readI32(buffer: Uint8Array, offset: i32): i32; - /** Writes a 32-bit integer to the specified buffer. */ - export function writeI32(value: i32, buffer: Uint8Array, offset: i32): void; - /** Reads a 64-bit integer from the specified buffer. */ - export function readI64(buffer: Uint8Array, offset: i32): I64; - /** Writes a 64-bit integer to the specified buffer. */ - export function writeI64(value: I64, buffer: Uint8Array, offset: i32): void; - /** Reads a 32-bit float from the specified buffer. */ - export function readF32(buffer: Uint8Array, offset: i32): f32; - /** Writes a 32-bit float to the specified buffer. */ - export function writeF32(value: f32, buffer: Uint8Array, offset: i32): void; - /** Reads a 64-bit float from the specified buffer. */ - export function readF64(buffer: Uint8Array, offset: i32): f64; - /** Writes a 64-bit float to the specified buffer. */ - export function writeF64(value: f64, buffer: Uint8Array, offset: i32): void; - -} -declare module 'assemblyscript/src/util/index' { - /** - * Various compiler utilities. - * @module util - * @preferred - */ /***/ - export * from 'assemblyscript/src/util/bitset'; - export * from 'assemblyscript/src/util/charcode'; - export * from 'assemblyscript/src/util/collections'; - export * from 'assemblyscript/src/util/path'; - export * from 'assemblyscript/src/util/text'; - export * from 'assemblyscript/src/util/binary'; - /** Tests if `x` is a power of two. */ - export function isPowerOf2(x: i32): bool; - -} -declare module 'assemblyscript/src/diagnostics' { - /** - * Shared diagnostic handling inherited by the parser and the compiler. - * @module diagnostics - * @preferred - */ /***/ - import { Range } from 'assemblyscript/src/ast'; - import { DiagnosticCode } from 'assemblyscript/src/diagnosticMessages.generated'; - export { DiagnosticCode, diagnosticCodeToString } from 'assemblyscript/src/diagnosticMessages.generated'; - /** Indicates the category of a {@link DiagnosticMessage}. */ - export enum DiagnosticCategory { - /** Informatory message. */ - INFO = 0, - /** Warning message. */ - WARNING = 1, - /** Error message. */ - ERROR = 2 - } - /** Returns the string representation of the specified diagnostic category. */ - export function diagnosticCategoryToString(category: DiagnosticCategory): string; - /** ANSI escape sequence for blue foreground. */ - export const COLOR_BLUE: string; - /** ANSI escape sequence for yellow foreground. */ - export const COLOR_YELLOW: string; - /** ANSI escape sequence for red foreground. */ - export const COLOR_RED: string; - /** ANSI escape sequence to reset the foreground color. */ - export const COLOR_RESET: string; - /** Returns the ANSI escape sequence for the specified category. */ - export function diagnosticCategoryToColor(category: DiagnosticCategory): string; - /** Represents a diagnostic message. */ - export class DiagnosticMessage { - /** Message code. */ - code: i32; - /** Message category. */ - category: DiagnosticCategory; - /** Message text. */ - message: string; - /** Respective source range, if any. */ - range: Range | null; - /** Related range, if any. */ - relatedRange: Range | null; - /** Constructs a new diagnostic message. */ - private constructor(); - /** Creates a new diagnostic message of the specified category. */ - static create(code: DiagnosticCode, category: DiagnosticCategory, arg0?: string | null, arg1?: string | null, arg2?: string | null): DiagnosticMessage; - /** Creates a new informatory diagnostic message. */ - static createInfo(code: DiagnosticCode, arg0?: string | null, arg1?: string | null): DiagnosticMessage; - /** Creates a new warning diagnostic message. */ - static createWarning(code: DiagnosticCode, arg0?: string | null, arg1?: string | null): DiagnosticMessage; - /** Creates a new error diagnostic message. */ - static createError(code: DiagnosticCode, arg0?: string | null, arg1?: string | null): DiagnosticMessage; - /** Adds a source range to this message. */ - withRange(range: Range): this; - /** Adds a related source range to this message. */ - withRelatedRange(range: Range): this; - /** Converts this message to a string. */ - toString(): string; - } - /** Formats a diagnostic message, optionally with terminal colors and source context. */ - export function formatDiagnosticMessage(message: DiagnosticMessage, useColors?: bool, showContext?: bool): string; - /** Formats the diagnostic context for the specified range, optionally with terminal colors. */ - export function formatDiagnosticContext(range: Range, useColors?: bool): string; - /** Base class of all diagnostic emitters. */ - export abstract class DiagnosticEmitter { - /** Diagnostic messages emitted so far. */ - diagnostics: DiagnosticMessage[]; - /** Initializes this diagnostic emitter. */ - protected constructor(diagnostics?: DiagnosticMessage[] | null); - /** Emits a diagnostic message of the specified category. */ - emitDiagnostic(code: DiagnosticCode, category: DiagnosticCategory, range: Range, relatedRange: Range | null, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; - /** Emits an informatory diagnostic message. */ - info(code: DiagnosticCode, range: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; - /** Emits an informatory diagnostic message with a related range. */ - infoRelated(code: DiagnosticCode, range: Range, relatedRange: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; - /** Emits a warning diagnostic message. */ - warning(code: DiagnosticCode, range: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; - /** Emits a warning diagnostic message with a related range. */ - warningRelated(code: DiagnosticCode, range: Range, relatedRange: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; - /** Emits an error diagnostic message. */ - error(code: DiagnosticCode, range: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; - /** Emits an error diagnostic message with a related range. */ - errorRelated(code: DiagnosticCode, range: Range, relatedRange: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; - } - -} -declare module 'assemblyscript/src/tokenizer' { - /** - * A TypeScript tokenizer modified for AssemblyScript. - * - * Skips over trivia and provides a general mark/reset mechanism for the parser to utilize on - * ambiguous tokens. - * - * @module tokenizer - */ /***/ - import { DiagnosticMessage, DiagnosticEmitter } from 'assemblyscript/src/diagnostics'; - import { Source, CommentKind } from 'assemblyscript/src/ast'; - /** Named token types. */ - export enum Token { - ABSTRACT = 0, - AS = 1, - ASYNC = 2, - AWAIT = 3, - BREAK = 4, - CASE = 5, - CATCH = 6, - CLASS = 7, - CONST = 8, - CONTINUE = 9, - CONSTRUCTOR = 10, - DEBUGGER = 11, - DECLARE = 12, - DEFAULT = 13, - DELETE = 14, - DO = 15, - ELSE = 16, - ENUM = 17, - EXPORT = 18, - EXTENDS = 19, - FALSE = 20, - FINALLY = 21, - FOR = 22, - FROM = 23, - FUNCTION = 24, - GET = 25, - IF = 26, - IMPLEMENTS = 27, - IMPORT = 28, - IN = 29, - INSTANCEOF = 30, - INTERFACE = 31, - IS = 32, - KEYOF = 33, - LET = 34, - MODULE = 35, - NAMESPACE = 36, - NEW = 37, - NULL = 38, - OF = 39, - PACKAGE = 40, - PRIVATE = 41, - PROTECTED = 42, - PUBLIC = 43, - READONLY = 44, - RETURN = 45, - SET = 46, - STATIC = 47, - SUPER = 48, - SWITCH = 49, - THIS = 50, - THROW = 51, - TRUE = 52, - TRY = 53, - TYPE = 54, - TYPEOF = 55, - VAR = 56, - VOID = 57, - WHILE = 58, - WITH = 59, - YIELD = 60, - OPENBRACE = 61, - CLOSEBRACE = 62, - OPENPAREN = 63, - CLOSEPAREN = 64, - OPENBRACKET = 65, - CLOSEBRACKET = 66, - DOT = 67, - DOT_DOT_DOT = 68, - SEMICOLON = 69, - COMMA = 70, - LESSTHAN = 71, - GREATERTHAN = 72, - LESSTHAN_EQUALS = 73, - GREATERTHAN_EQUALS = 74, - EQUALS_EQUALS = 75, - EXCLAMATION_EQUALS = 76, - EQUALS_EQUALS_EQUALS = 77, - EXCLAMATION_EQUALS_EQUALS = 78, - EQUALS_GREATERTHAN = 79, - PLUS = 80, - MINUS = 81, - ASTERISK_ASTERISK = 82, - ASTERISK = 83, - SLASH = 84, - PERCENT = 85, - PLUS_PLUS = 86, - MINUS_MINUS = 87, - LESSTHAN_LESSTHAN = 88, - GREATERTHAN_GREATERTHAN = 89, - GREATERTHAN_GREATERTHAN_GREATERTHAN = 90, - AMPERSAND = 91, - BAR = 92, - CARET = 93, - EXCLAMATION = 94, - TILDE = 95, - AMPERSAND_AMPERSAND = 96, - BAR_BAR = 97, - QUESTION = 98, - COLON = 99, - EQUALS = 100, - PLUS_EQUALS = 101, - MINUS_EQUALS = 102, - ASTERISK_EQUALS = 103, - ASTERISK_ASTERISK_EQUALS = 104, - SLASH_EQUALS = 105, - PERCENT_EQUALS = 106, - LESSTHAN_LESSTHAN_EQUALS = 107, - GREATERTHAN_GREATERTHAN_EQUALS = 108, - GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS = 109, - AMPERSAND_EQUALS = 110, - BAR_EQUALS = 111, - CARET_EQUALS = 112, - AT = 113, - IDENTIFIER = 114, - STRINGLITERAL = 115, - INTEGERLITERAL = 116, - FLOATLITERAL = 117, - INVALID = 118, - ENDOFFILE = 119 - } - export enum IdentifierHandling { - DEFAULT = 0, - PREFER = 1, - ALWAYS = 2 - } - export function tokenFromKeyword(text: string): Token; - export function tokenIsAlsoIdentifier(token: Token): bool; - export function operatorTokenToString(token: Token): string; - export class Range { - source: Source; - start: i32; - end: i32; - constructor(source: Source, start: i32, end: i32); - static join(a: Range, b: Range): Range; - readonly atStart: Range; - readonly atEnd: Range; - readonly line: i32; - readonly column: i32; - toString(): string; - debugInfoRef: usize; - } - /** Handler for intercepting comments while tokenizing. */ - export type CommentHandler = (kind: CommentKind, text: string, range: Range) => void; - /** Tokenizes a source to individual {@link Token}s. */ - export class Tokenizer extends DiagnosticEmitter { - source: Source; - end: i32; - pos: i32; - token: Token; - tokenPos: i32; - nextToken: Token; - nextTokenPos: i32; - nextTokenOnNewLine: bool; - onComment: CommentHandler | null; - /** Constructs a new tokenizer. */ - constructor(source: Source, diagnostics?: DiagnosticMessage[] | null); - next(identifierHandling?: IdentifierHandling): Token; - private unsafeNext; - peek(checkOnNewLine?: bool, identifierHandling?: IdentifierHandling, maxCompoundLength?: i32): Token; - skipIdentifier(identifierHandling?: IdentifierHandling): bool; - skip(token: Token, identifierHandling?: IdentifierHandling): bool; - mark(): State; - discard(state: State): void; - reset(state: State): void; - range(start?: i32, end?: i32): Range; - readIdentifier(): string; - readString(): string; - readEscapeSequence(): string; - readRegexpPattern(): string; - readRegexpFlags(): string; - testInteger(): bool; - readInteger(): I64; - readHexInteger(): I64; - readDecimalInteger(): I64; - readOctalInteger(): I64; - readBinaryInteger(): I64; - readFloat(): f64; - readDecimalFloat(): f64; - readHexFloat(): f64; - readUnicodeEscape(): string; - private readExtendedUnicodeEscape; - finish(): void; - } - /** Tokenizer state as returned by {@link Tokenizer#mark} and consumed by {@link Tokenizer#reset}. */ - export class State { - /** Current position. */ - pos: i32; - /** Current token. */ - token: Token; - /** Current token's position. */ - tokenPos: i32; - } - -} -declare module 'assemblyscript/src/ast' { - /** - * Abstract syntax tree representing a source file once parsed. - * @module ast - */ /***/ - import { CommonFlags } from 'assemblyscript/src/common'; - import { Token, Tokenizer, Range } from 'assemblyscript/src/tokenizer'; - export { Token, Range }; - /** Indicates the kind of a node. */ - export enum NodeKind { - SOURCE = 0, - TYPE = 1, - TYPENAME = 2, - TYPEPARAMETER = 3, - PARAMETER = 4, - SIGNATURE = 5, - IDENTIFIER = 6, - ASSERTION = 7, - BINARY = 8, - CALL = 9, - CLASS = 10, - COMMA = 11, - ELEMENTACCESS = 12, - FALSE = 13, - FUNCTION = 14, - INSTANCEOF = 15, - LITERAL = 16, - NEW = 17, - NULL = 18, - PARENTHESIZED = 19, - PROPERTYACCESS = 20, - TERNARY = 21, - SUPER = 22, - THIS = 23, - TRUE = 24, - CONSTRUCTOR = 25, - UNARYPOSTFIX = 26, - UNARYPREFIX = 27, - BLOCK = 28, - BREAK = 29, - CONTINUE = 30, - DO = 31, - EMPTY = 32, - EXPORT = 33, - EXPORTDEFAULT = 34, - EXPORTIMPORT = 35, - EXPRESSION = 36, - FOR = 37, - IF = 38, - IMPORT = 39, - RETURN = 40, - SWITCH = 41, - THROW = 42, - TRY = 43, - VARIABLE = 44, - VOID = 45, - WHILE = 46, - CLASSDECLARATION = 47, - ENUMDECLARATION = 48, - ENUMVALUEDECLARATION = 49, - FIELDDECLARATION = 50, - FUNCTIONDECLARATION = 51, - IMPORTDECLARATION = 52, - INDEXSIGNATUREDECLARATION = 53, - INTERFACEDECLARATION = 54, - METHODDECLARATION = 55, - NAMESPACEDECLARATION = 56, - TYPEDECLARATION = 57, - VARIABLEDECLARATION = 58, - DECORATOR = 59, - EXPORTMEMBER = 60, - SWITCHCASE = 61, - COMMENT = 62 - } - /** Checks if a node represents a constant value. */ - export function nodeIsConstantValue(kind: NodeKind): bool; - /** Checks if a node might be callable. */ - export function nodeIsCallable(kind: NodeKind): bool; - /** Checks if a node might be callable with generic arguments. */ - export function nodeIsGenericCallable(kind: NodeKind): bool; - /** Base class of all nodes. */ - export abstract class Node { - /** Node kind indicator. */ - kind: NodeKind; - /** Source range. */ - range: Range; - static createTypeName(name: IdentifierExpression, range: Range): TypeName; - static createSimpleTypeName(name: string, range: Range): TypeName; - static createType(name: TypeName, typeArguments: CommonTypeNode[] | null, isNullable: bool, range: Range): TypeNode; - static createOmittedType(range: Range): TypeNode; - static createTypeParameter(name: IdentifierExpression, extendsType: TypeNode | null, defaultType: TypeNode | null, range: Range): TypeParameterNode; - static createParameter(name: IdentifierExpression, type: CommonTypeNode, initializer: Expression | null, kind: ParameterKind, range: Range): ParameterNode; - static createSignature(parameters: ParameterNode[], returnType: CommonTypeNode, explicitThisType: TypeNode | null, isNullable: bool, range: Range): SignatureNode; - static createDecorator(name: Expression, args: Expression[] | null, range: Range): DecoratorNode; - static createComment(text: string, kind: CommentKind, range: Range): CommentNode; - static createIdentifierExpression(name: string, range: Range, isQuoted?: bool): IdentifierExpression; - static createEmptyIdentifierExpression(range: Range): IdentifierExpression; - static createArrayLiteralExpression(elements: (Expression | null)[], range: Range): ArrayLiteralExpression; - static createAssertionExpression(assertionKind: AssertionKind, expression: Expression, toType: CommonTypeNode | null, range: Range): AssertionExpression; - static createBinaryExpression(operator: Token, left: Expression, right: Expression, range: Range): BinaryExpression; - static createCallExpression(expression: Expression, typeArgs: CommonTypeNode[] | null, args: Expression[], range: Range): CallExpression; - static createClassExpression(declaration: ClassDeclaration): ClassExpression; - static createCommaExpression(expressions: Expression[], range: Range): CommaExpression; - static createConstructorExpression(range: Range): ConstructorExpression; - static createElementAccessExpression(expression: Expression, element: Expression, range: Range): ElementAccessExpression; - static createFalseExpression(range: Range): FalseExpression; - static createFloatLiteralExpression(value: f64, range: Range): FloatLiteralExpression; - static createFunctionExpression(declaration: FunctionDeclaration): FunctionExpression; - static createInstanceOfExpression(expression: Expression, isType: CommonTypeNode, range: Range): InstanceOfExpression; - static createIntegerLiteralExpression(value: I64, range: Range): IntegerLiteralExpression; - static createNewExpression(expression: Expression, typeArgs: CommonTypeNode[] | null, args: Expression[], range: Range): NewExpression; - static createNullExpression(range: Range): NullExpression; - static createObjectLiteralExpression(names: IdentifierExpression[], values: Expression[], range: Range): ObjectLiteralExpression; - static createParenthesizedExpression(expression: Expression, range: Range): ParenthesizedExpression; - static createPropertyAccessExpression(expression: Expression, property: IdentifierExpression, range: Range): PropertyAccessExpression; - static createRegexpLiteralExpression(pattern: string, flags: string, range: Range): RegexpLiteralExpression; - static createTernaryExpression(condition: Expression, ifThen: Expression, ifElse: Expression, range: Range): TernaryExpression; - static createStringLiteralExpression(value: string, range: Range): StringLiteralExpression; - static createSuperExpression(range: Range): SuperExpression; - static createThisExpression(range: Range): ThisExpression; - static createTrueExpression(range: Range): TrueExpression; - static createUnaryPostfixExpression(operator: Token, operand: Expression, range: Range): UnaryPostfixExpression; - static createUnaryPrefixExpression(operator: Token, operand: Expression, range: Range): UnaryPrefixExpression; - static createBlockStatement(statements: Statement[], range: Range): BlockStatement; - static createBreakStatement(label: IdentifierExpression | null, range: Range): BreakStatement; - static createClassDeclaration(identifier: IdentifierExpression, typeParameters: TypeParameterNode[] | null, extendsType: TypeNode | null, // can't be a function - implementsTypes: TypeNode[] | null, // can't be functions - members: DeclarationStatement[], decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): ClassDeclaration; - static createContinueStatement(label: IdentifierExpression | null, range: Range): ContinueStatement; - static createDoStatement(statement: Statement, condition: Expression, range: Range): DoStatement; - static createEmptyStatement(range: Range): EmptyStatement; - static createEnumDeclaration(name: IdentifierExpression, members: EnumValueDeclaration[], decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): EnumDeclaration; - static createEnumValueDeclaration(name: IdentifierExpression, value: Expression | null, flags: CommonFlags, range: Range): EnumValueDeclaration; - static createExportStatement(members: ExportMember[] | null, path: StringLiteralExpression | null, isDeclare: bool, range: Range): ExportStatement; - static createExportDefaultStatement(declaration: DeclarationStatement, range: Range): ExportDefaultStatement; - static createExportImportStatement(name: IdentifierExpression, externalName: IdentifierExpression, range: Range): ExportImportStatement; - static createExportMember(name: IdentifierExpression, externalName: IdentifierExpression | null, range: Range): ExportMember; - static createExpressionStatement(expression: Expression): ExpressionStatement; - static createIfStatement(condition: Expression, ifTrue: Statement, ifFalse: Statement | null, range: Range): IfStatement; - static createImportStatement(decls: ImportDeclaration[] | null, path: StringLiteralExpression, range: Range): ImportStatement; - static createImportStatementWithWildcard(identifier: IdentifierExpression, path: StringLiteralExpression, range: Range): ImportStatement; - static createImportDeclaration(foreignName: IdentifierExpression, name: IdentifierExpression | null, range: Range): ImportDeclaration; - static createInterfaceDeclaration(name: IdentifierExpression, typeParameters: TypeParameterNode[] | null, extendsType: TypeNode | null, // can't be a function - members: DeclarationStatement[], decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): InterfaceDeclaration; - static createFieldDeclaration(name: IdentifierExpression, type: CommonTypeNode | null, initializer: Expression | null, decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): FieldDeclaration; - static createForStatement(initializer: Statement | null, condition: Expression | null, incrementor: Expression | null, statement: Statement, range: Range): ForStatement; - static createFunctionDeclaration(name: IdentifierExpression, typeParameters: TypeParameterNode[] | null, signature: SignatureNode, body: Statement | null, decorators: DecoratorNode[] | null, flags: CommonFlags, arrowKind: ArrowKind, range: Range): FunctionDeclaration; - static createIndexSignatureDeclaration(keyType: TypeNode, valueType: CommonTypeNode, range: Range): IndexSignatureDeclaration; - static createMethodDeclaration(name: IdentifierExpression, typeParameters: TypeParameterNode[] | null, signature: SignatureNode, body: Statement | null, decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): MethodDeclaration; - static createNamespaceDeclaration(name: IdentifierExpression, members: Statement[], decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): NamespaceDeclaration; - static createReturnStatement(value: Expression | null, range: Range): ReturnStatement; - static createSwitchStatement(condition: Expression, cases: SwitchCase[], range: Range): SwitchStatement; - static createSwitchCase(label: Expression | null, statements: Statement[], range: Range): SwitchCase; - static createThrowStatement(value: Expression, range: Range): ThrowStatement; - static createTryStatement(statements: Statement[], catchVariable: IdentifierExpression | null, catchStatements: Statement[] | null, finallyStatements: Statement[] | null, range: Range): TryStatement; - static createTypeDeclaration(name: IdentifierExpression, typeParameters: TypeParameterNode[] | null, alias: CommonTypeNode, decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): TypeDeclaration; - static createVariableStatement(declarations: VariableDeclaration[], decorators: DecoratorNode[] | null, range: Range): VariableStatement; - static createVariableDeclaration(name: IdentifierExpression, type: CommonTypeNode | null, initializer: Expression | null, decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): VariableDeclaration; - static createVoidStatement(expression: Expression, range: Range): VoidStatement; - static createWhileStatement(condition: Expression, statement: Statement, range: Range): WhileStatement; - } - export abstract class CommonTypeNode extends Node { - /** Whether nullable or not. */ - isNullable: bool; - } - /** Represents a type name. */ - export class TypeName extends Node { - kind: NodeKind; - /** Identifier of this part. */ - identifier: IdentifierExpression; - /** Next part of the type name or `null` if this is the last part. */ - next: TypeName | null; - } - /** Represents a type annotation. */ - export class TypeNode extends CommonTypeNode { - kind: NodeKind; - /** Type name. */ - name: TypeName; - /** Type argument references. */ - typeArguments: CommonTypeNode[] | null; - } - /** Represents a type parameter. */ - export class TypeParameterNode extends Node { - kind: NodeKind; - /** Identifier reference. */ - name: IdentifierExpression; - /** Extended type reference, if any. */ - extendsType: TypeNode | null; - /** Default type if omitted, if any. */ - defaultType: TypeNode | null; - } - /** Represents the kind of a parameter. */ - export enum ParameterKind { - /** No specific flags. */ - DEFAULT = 0, - /** Is an optional parameter. */ - OPTIONAL = 1, - /** Is a rest parameter. */ - REST = 2 - } - /** Represents a function parameter. */ - export class ParameterNode extends Node { - kind: NodeKind; - /** Parameter kind. */ - parameterKind: ParameterKind; - /** Parameter name. */ - name: IdentifierExpression; - /** Parameter type. */ - type: CommonTypeNode; - /** Initializer expression, if present. */ - initializer: Expression | null; - /** Implicit field declaration, if applicable. */ - implicitFieldDeclaration: FieldDeclaration | null; - /** Common flags indicating specific traits. */ - flags: CommonFlags; - /** Tests if this node has the specified flag or flags. */ - is(flag: CommonFlags): bool; - /** Tests if this node has one of the specified flags. */ - isAny(flag: CommonFlags): bool; - /** Sets a specific flag or flags. */ - set(flag: CommonFlags): void; - } - /** Represents a function signature. */ - export class SignatureNode extends CommonTypeNode { - kind: NodeKind; - /** Accepted parameters. */ - parameters: ParameterNode[]; - /** Return type. */ - returnType: CommonTypeNode; - /** Explicitly provided this type, if any. */ - explicitThisType: TypeNode | null; - } - /** Built-in decorator kinds. */ - export enum DecoratorKind { - CUSTOM = 0, - GLOBAL = 1, - OPERATOR = 2, - OPERATOR_BINARY = 3, - OPERATOR_PREFIX = 4, - OPERATOR_POSTFIX = 5, - UNMANAGED = 6, - SEALED = 7, - INLINE = 8, - EXTERNAL = 9, - BUILTIN = 10, - LAZY = 11, - UNSAFE = 12 - } - /** Returns the kind of the specified decorator. Defaults to {@link DecoratorKind.CUSTOM}. */ - export function decoratorNameToKind(name: Expression): DecoratorKind; - /** Represents a decorator. */ - export class DecoratorNode extends Node { - kind: NodeKind; - /** Built-in kind, if applicable. */ - decoratorKind: DecoratorKind; - /** Name expression. */ - name: Expression; - /** Argument expressions. */ - arguments: Expression[] | null; - } - /** Comment kinds. */ - export enum CommentKind { - /** Line comment. */ - LINE = 0, - /** Triple-slash comment. */ - TRIPLE = 1, - /** Block comment. */ - BLOCK = 2 - } - /** Represents a comment. */ - export class CommentNode extends Node { - kind: NodeKind; - /** Comment kind. */ - commentKind: CommentKind; - /** Comment text. */ - text: string; - } - /** Base class of all expression nodes. */ - export abstract class Expression extends Node { - } - /** Represents an identifier expression. */ - export class IdentifierExpression extends Expression { - kind: NodeKind; - /** Textual name. */ - text: string; - /** Symbol. */ - symbol: string; - /** Whether quoted or not. */ - isQuoted: bool; - } - /** Indicates the kind of a literal. */ - export enum LiteralKind { - FLOAT = 0, - INTEGER = 1, - STRING = 2, - REGEXP = 3, - ARRAY = 4, - OBJECT = 5 - } - /** Base class of all literal expressions. */ - export abstract class LiteralExpression extends Expression { - kind: NodeKind; - /** Specific literal kind. */ - literalKind: LiteralKind; - } - /** Represents an `[]` literal expression. */ - export class ArrayLiteralExpression extends LiteralExpression { - literalKind: LiteralKind; - /** Nested element expressions. */ - elementExpressions: (Expression | null)[]; - } - /** Indicates the kind of an assertion. */ - export enum AssertionKind { - PREFIX = 0, - AS = 1, - NONNULL = 2 - } - /** Represents an assertion expression. */ - export class AssertionExpression extends Expression { - kind: NodeKind; - /** Specific kind of this assertion. */ - assertionKind: AssertionKind; - /** Expression being asserted. */ - expression: Expression; - /** Target type. */ - toType: CommonTypeNode | null; - } - /** Represents a binary expression. */ - export class BinaryExpression extends Expression { - kind: NodeKind; - /** Operator token. */ - operator: Token; - /** Left-hand side expression */ - left: Expression; - /** Right-hand side expression. */ - right: Expression; - } - /** Represents a call expression. */ - export class CallExpression extends Expression { - kind: NodeKind; - /** Called expression. Usually an identifier or property access expression. */ - expression: Expression; - /** Provided type arguments. */ - typeArguments: CommonTypeNode[] | null; - /** Provided arguments. */ - arguments: Expression[]; - /** Gets the type arguments range for reporting. */ - readonly typeArgumentsRange: Range; - /** Gets the arguments range for reporting. */ - readonly argumentsRange: Range; - } - /** Represents a class expression using the 'class' keyword. */ - export class ClassExpression extends Expression { - kind: NodeKind; - /** Inline class declaration. */ - declaration: ClassDeclaration; - } - /** Represents a comma expression composed of multiple expressions. */ - export class CommaExpression extends Expression { - kind: NodeKind; - /** Sequential expressions. */ - expressions: Expression[]; - } - /** Represents a `constructor` expression. */ - export class ConstructorExpression extends IdentifierExpression { - kind: NodeKind; - text: string; - symbol: string; - } - /** Represents an element access expression, e.g., array access. */ - export class ElementAccessExpression extends Expression { - kind: NodeKind; - /** Expression being accessed. */ - expression: Expression; - /** Element of the expression being accessed. */ - elementExpression: Expression; - } - /** Represents a float literal expression. */ - export class FloatLiteralExpression extends LiteralExpression { - literalKind: LiteralKind; - /** Float value. */ - value: f64; - } - /** Represents a function expression using the 'function' keyword. */ - export class FunctionExpression extends Expression { - kind: NodeKind; - /** Inline function declaration. */ - declaration: FunctionDeclaration; - } - /** Represents an `instanceof` expression. */ - export class InstanceOfExpression extends Expression { - kind: NodeKind; - /** Expression being asserted. */ - expression: Expression; - /** Type to test for. */ - isType: CommonTypeNode; - } - /** Represents an integer literal expression. */ - export class IntegerLiteralExpression extends LiteralExpression { - literalKind: LiteralKind; - /** Integer value. */ - value: I64; - } - /** Represents a `new` expression. Like a call but with its own kind. */ - export class NewExpression extends CallExpression { - kind: NodeKind; - } - /** Represents a `null` expression. */ - export class NullExpression extends IdentifierExpression { - kind: NodeKind; - text: string; - symbol: string; - } - /** Represents an object literal expression. */ - export class ObjectLiteralExpression extends LiteralExpression { - literalKind: LiteralKind; - /** Field names. */ - names: IdentifierExpression[]; - /** Field values. */ - values: Expression[]; - } - /** Represents a parenthesized expression. */ - export class ParenthesizedExpression extends Expression { - kind: NodeKind; - /** Expression in parenthesis. */ - expression: Expression; - } - /** Represents a property access expression. */ - export class PropertyAccessExpression extends Expression { - kind: NodeKind; - /** Expression being accessed. */ - expression: Expression; - /** Property of the expression being accessed. */ - property: IdentifierExpression; - } - /** Represents a regular expression literal expression. */ - export class RegexpLiteralExpression extends LiteralExpression { - literalKind: LiteralKind; - /** Regular expression pattern. */ - pattern: string; - /** Regular expression flags. */ - patternFlags: string; - } - /** Represents a ternary expression, i.e., short if notation. */ - export class TernaryExpression extends Expression { - kind: NodeKind; - /** Condition expression. */ - condition: Expression; - /** Expression executed when condition is `true`. */ - ifThen: Expression; - /** Expression executed when condition is `false`. */ - ifElse: Expression; - } - /** Represents a string literal expression. */ - export class StringLiteralExpression extends LiteralExpression { - literalKind: LiteralKind; - /** String value without quotes. */ - value: string; - } - /** Represents a `super` expression. */ - export class SuperExpression extends IdentifierExpression { - kind: NodeKind; - text: string; - symbol: string; - } - /** Represents a `this` expression. */ - export class ThisExpression extends IdentifierExpression { - kind: NodeKind; - text: string; - symbol: string; - } - /** Represents a `true` expression. */ - export class TrueExpression extends IdentifierExpression { - kind: NodeKind; - text: string; - symbol: string; - } - /** Represents a `false` expression. */ - export class FalseExpression extends IdentifierExpression { - kind: NodeKind; - text: string; - symbol: string; - } - /** Base class of all unary expressions. */ - export abstract class UnaryExpression extends Expression { - /** Operator token. */ - operator: Token; - /** Operand expression. */ - operand: Expression; - } - /** Represents a unary postfix expression, e.g. a postfix increment. */ - export class UnaryPostfixExpression extends UnaryExpression { - kind: NodeKind; - } - /** Represents a unary prefix expression, e.g. a negation. */ - export class UnaryPrefixExpression extends UnaryExpression { - kind: NodeKind; - } - /** Base class of all statement nodes. */ - export abstract class Statement extends Node { - } - /** Indicates the specific kind of a source. */ - export enum SourceKind { - /** Default source. Usually imported from an entry file. */ - DEFAULT = 0, - /** Entry file. */ - ENTRY = 1, - /** Library file. */ - LIBRARY = 2 - } - /** A top-level source node. */ - export class Source extends Node { - kind: NodeKind; - parent: null; - /** Source kind. */ - sourceKind: SourceKind; - /** Normalized path. */ - normalizedPath: string; - /** Path used internally. */ - internalPath: string; - /** Simple path (last part without extension). */ - simplePath: string; - /** Contained statements. */ - statements: Statement[]; - /** Full source text. */ - text: string; - /** Tokenizer reference. */ - tokenizer: Tokenizer | null; - /** Source map index. */ - debugInfoIndex: i32; - /** Re-exported sources. */ - exportPaths: Set | null; - /** Constructs a new source node. */ - constructor(normalizedPath: string, text: string, kind: SourceKind); - /** Tests if this source is an entry file. */ - readonly isEntry: bool; - /** Tests if this source is a stdlib file. */ - readonly isLibrary: bool; - } - /** Base class of all declaration statements. */ - export abstract class DeclarationStatement extends Statement { - /** Simple name being declared. */ - name: IdentifierExpression; - /** Array of decorators. */ - decorators: DecoratorNode[] | null; - /** Common flags indicating specific traits. */ - flags: CommonFlags; - /** Tests if this node has the specified flag or flags. */ - is(flag: CommonFlags): bool; - /** Tests if this node has one of the specified flags. */ - isAny(flag: CommonFlags): bool; - /** Sets a specific flag or flags. */ - set(flag: CommonFlags): void; - } - /** Represents an index signature declaration. */ - export class IndexSignatureDeclaration extends DeclarationStatement { - kind: NodeKind; - /** Key type. */ - keyType: TypeNode; - /** Value type. */ - valueType: CommonTypeNode; - } - /** Base class of all variable-like declaration statements. */ - export abstract class VariableLikeDeclarationStatement extends DeclarationStatement { - /** Variable type. */ - type: CommonTypeNode | null; - /** Variable initializer. */ - initializer: Expression | null; - } - /** Represents a block statement. */ - export class BlockStatement extends Statement { - kind: NodeKind; - /** Contained statements. */ - statements: Statement[]; - } - /** Represents a `break` statement. */ - export class BreakStatement extends Statement { - kind: NodeKind; - /** Target label, if applicable. */ - label: IdentifierExpression | null; - } - /** Represents a `class` declaration. */ - export class ClassDeclaration extends DeclarationStatement { - kind: NodeKind; - /** Accepted type parameters. */ - typeParameters: TypeParameterNode[] | null; - /** Base class type being extended, if any. */ - extendsType: TypeNode | null; - /** Interface types being implemented, if any. */ - implementsTypes: TypeNode[] | null; - /** Class member declarations. */ - members: DeclarationStatement[]; - readonly isGeneric: bool; - } - /** Represents a `continue` statement. */ - export class ContinueStatement extends Statement { - kind: NodeKind; - /** Target label, if applicable. */ - label: IdentifierExpression | null; - } - /** Represents a `do` statement. */ - export class DoStatement extends Statement { - kind: NodeKind; - /** Statement being looped over. */ - statement: Statement; - /** Condition when to repeat. */ - condition: Expression; - } - /** Represents an empty statement, i.e., a semicolon terminating nothing. */ - export class EmptyStatement extends Statement { - kind: NodeKind; - } - /** Represents an `enum` declaration. */ - export class EnumDeclaration extends DeclarationStatement { - kind: NodeKind; - /** Enum value declarations. */ - values: EnumValueDeclaration[]; - } - /** Represents a value of an `enum` declaration. */ - export class EnumValueDeclaration extends VariableLikeDeclarationStatement { - kind: NodeKind; - /** Value expression. */ - value: Expression | null; - } - /** Represents an `export import` statement of an interface. */ - export class ExportImportStatement extends Node { - kind: NodeKind; - /** Identifier being imported. */ - name: IdentifierExpression; - /** Identifier being exported. */ - externalName: IdentifierExpression; - } - /** Represents a member of an `export` statement. */ - export class ExportMember extends Node { - kind: NodeKind; - /** Local identifier. */ - localName: IdentifierExpression; - /** Exported identifier. */ - exportedName: IdentifierExpression; - } - /** Represents an `export` statement. */ - export class ExportStatement extends Statement { - kind: NodeKind; - /** Array of members if a set of named exports, or `null` if a file export. */ - members: ExportMember[] | null; - /** Path being exported from, if applicable. */ - path: StringLiteralExpression | null; - /** Normalized path, if `path` is set. */ - normalizedPath: string | null; - /** Mangled internal path being referenced, if `path` is set. */ - internalPath: string | null; - /** Whether this is a declared export. */ - isDeclare: bool; - } - /** Represents an `export default` statement. */ - export class ExportDefaultStatement extends Statement { - kind: NodeKind; - /** Declaration being exported as default. */ - declaration: DeclarationStatement; - } - /** Represents an expression that is used as a statement. */ - export class ExpressionStatement extends Statement { - kind: NodeKind; - /** Expression being used as a statement.*/ - expression: Expression; - } - /** Represents a field declaration within a `class`. */ - export class FieldDeclaration extends VariableLikeDeclarationStatement { - kind: NodeKind; - /** Parameter index if declared as a constructor parameter, otherwise `-1`. */ - parameterIndex: i32; - } - /** Represents a `for` statement. */ - export class ForStatement extends Statement { - kind: NodeKind; - /** - * Initializer statement, if present. - * Either a {@link VariableStatement} or {@link ExpressionStatement}. - */ - initializer: Statement | null; - /** Condition expression, if present. */ - condition: Expression | null; - /** Incrementor expression, if present. */ - incrementor: Expression | null; - /** Statement being looped over. */ - statement: Statement; - } - /** Indicates the kind of an array function. */ - export const enum ArrowKind { - /** Not an arrow function. */ - NONE = 0, - /** Parenthesized parameter list. */ - ARROW_PARENTHESIZED = 1, - /** Single parameter without parenthesis. */ - ARROW_SINGLE = 2 - } - /** Represents a `function` declaration. */ - export class FunctionDeclaration extends DeclarationStatement { - kind: NodeKind; - /** Type parameters, if any. */ - typeParameters: TypeParameterNode[] | null; - /** Function signature. */ - signature: SignatureNode; - /** Body statement. Usually a block. */ - body: Statement | null; - /** Arrow function kind, if applicable. */ - arrowKind: ArrowKind; - readonly isGeneric: bool; - /** Clones this function declaration. */ - clone(): FunctionDeclaration; - } - /** Represents an `if` statement. */ - export class IfStatement extends Statement { - kind: NodeKind; - /** Condition. */ - condition: Expression; - /** Statement executed when condition is `true`. */ - ifTrue: Statement; - /** Statement executed when condition is `false`. */ - ifFalse: Statement | null; - } - /** Represents an `import` declaration part of an {@link ImportStatement}. */ - export class ImportDeclaration extends DeclarationStatement { - kind: NodeKind; - /** Identifier being imported. */ - foreignName: IdentifierExpression; - } - /** Represents an `import` statement. */ - export class ImportStatement extends Statement { - kind: NodeKind; - /** Array of member declarations or `null` if an asterisk import. */ - declarations: ImportDeclaration[] | null; - /** Name of the local namespace, if an asterisk import. */ - namespaceName: IdentifierExpression | null; - /** Path being imported from. */ - path: StringLiteralExpression; - /** Normalized path. */ - normalizedPath: string; - /** Mangled internal path being referenced. */ - internalPath: string; - } - /** Represents an `interfarce` declaration. */ - export class InterfaceDeclaration extends ClassDeclaration { - kind: NodeKind; - } - /** Represents a method declaration within a `class`. */ - export class MethodDeclaration extends FunctionDeclaration { - kind: NodeKind; - } - /** Represents a `namespace` declaration. */ - export class NamespaceDeclaration extends DeclarationStatement { - kind: NodeKind; - /** Array of namespace members. */ - members: Statement[]; - } - /** Represents a `return` statement. */ - export class ReturnStatement extends Statement { - kind: NodeKind; - /** Value expression being returned, if present. */ - value: Expression | null; - } - /** Represents a single `case` within a `switch` statement. */ - export class SwitchCase extends Node { - kind: NodeKind; - /** Label expression. `null` indicates the default case. */ - label: Expression | null; - /** Contained statements. */ - statements: Statement[]; - } - /** Represents a `switch` statement. */ - export class SwitchStatement extends Statement { - kind: NodeKind; - /** Condition expression. */ - condition: Expression; - /** Contained cases. */ - cases: SwitchCase[]; - } - /** Represents a `throw` statement. */ - export class ThrowStatement extends Statement { - kind: NodeKind; - /** Value expression being thrown. */ - value: Expression; - } - /** Represents a `try` statement. */ - export class TryStatement extends Statement { - kind: NodeKind; - /** Contained statements. */ - statements: Statement[]; - /** Exception variable name, if a `catch` clause is present. */ - catchVariable: IdentifierExpression | null; - /** Statements being executed on catch, if a `catch` clause is present. */ - catchStatements: Statement[] | null; - /** Statements being executed afterwards, if a `finally` clause is present. */ - finallyStatements: Statement[] | null; - } - /** Represents a `type` declaration. */ - export class TypeDeclaration extends DeclarationStatement { - kind: NodeKind; - /** Type parameters, if any. */ - typeParameters: TypeParameterNode[] | null; - /** Type being aliased. */ - type: CommonTypeNode; - } - /** Represents a variable declaration part of a {@link VariableStatement}. */ - export class VariableDeclaration extends VariableLikeDeclarationStatement { - kind: NodeKind; - } - /** Represents a variable statement wrapping {@link VariableDeclaration}s. */ - export class VariableStatement extends Statement { - kind: NodeKind; - /** Array of decorators. */ - decorators: DecoratorNode[] | null; - /** Array of member declarations. */ - declarations: VariableDeclaration[]; - } - /** Represents a void statement dropping an expression's value. */ - export class VoidStatement extends Statement { - kind: NodeKind; - /** Expression being dropped. */ - expression: Expression; - } - /** Represents a `while` statement. */ - export class WhileStatement extends Statement { - kind: NodeKind; - /** Condition expression. */ - condition: Expression; - /** Statement being looped over. */ - statement: Statement; - } - /** Finds the first decorator matching the specified kind. */ - export function findDecorator(kind: DecoratorKind, decorators: DecoratorNode[] | null): DecoratorNode | null; - /** Mangles an external to an internal path. */ - export function mangleInternalPath(path: string): string; - /** Tests if the specified type node represents an omitted type. */ - export function isTypeOmitted(type: CommonTypeNode): bool; - -} -declare module 'assemblyscript/src/module' { - /** - * A thin wrapper around Binaryen's C-API. - * @module module - */ /***/ - import { Target } from 'assemblyscript/src/common'; - export type ModuleRef = usize; - export type FunctionTypeRef = usize; - export type FunctionRef = usize; - export type ExpressionRef = usize; - export type GlobalRef = usize; - export type ImportRef = usize; - export type ExportRef = usize; - export type RelooperRef = usize; - export type RelooperBlockRef = usize; - export type Index = u32; - export enum NativeType { - None, - I32, - I64, - F32, - F64, - V128, - Unreachable, - Auto - } - export enum FeatureFlags { - Atomics, - MutableGloabls, - NontrappingFPToInt, - SIMD128, - BulkMemory, - SignExt, - ExceptionHandling - } - export enum ExpressionId { - Invalid, - Block, - If, - Loop, - Break, - Switch, - Call, - CallIndirect, - LocalGet, - LocalSet, - GlobalGet, - GlobalSet, - Load, - Store, - Const, - Unary, - Binary, - Select, - Drop, - Return, - Host, - Nop, - Unreachable, - AtomicCmpxchg, - AtomicRMW, - AtomicWait, - AtomicNotify, - SIMDExtract, - SIMDReplace, - SIMDShuffle, - SIMDBitselect, - SIMDShift, - MemoryInit, - DataDrop, - MemoryCopy, - MemoryFill - } - export enum UnaryOp { - ClzI32, - CtzI32, - PopcntI32, - NegF32, - AbsF32, - CeilF32, - FloorF32, - TruncF32, - NearestF32, - SqrtF32, - EqzI32, - ClzI64, - CtzI64, - PopcntI64, - NegF64, - AbsF64, - CeilF64, - FloorF64, - TruncF64, - NearestF64, - SqrtF64, - EqzI64, - ExtendI32, - ExtendU32, - WrapI64, - TruncF32ToI32, - TruncF32ToI64, - TruncF32ToU32, - TruncF32ToU64, - TruncF64ToI32, - TruncF64ToI64, - TruncF64ToU32, - TruncF64ToU64, - ReinterpretF32, - ReinterpretF64, - ConvertI32ToF32, - ConvertI32ToF64, - ConvertU32ToF32, - ConvertU32ToF64, - ConvertI64ToF32, - ConvertI64ToF64, - ConvertU64ToF32, - ConvertU64ToF64, - PromoteF32, - DemoteF64, - ReinterpretI32, - ReinterpretI64, - ExtendI8ToI32, - ExtendI16ToI32, - ExtendI8ToI64, - ExtendI16ToI64, - ExtendI32ToI64, - SplatVecI8x16, - SplatVecI16x8, - SplatVecI32x4, - SplatVecI64x2, - SplatVecF32x4, - SplatVecF64x2, - NotVec128, - NegVecI8x16, - AnyTrueVecI8x16, - AllTrueVecI8x16, - NegVecI16x8, - AnyTrueVecI16x8, - AllTrueVecI16x8, - NegVecI32x4, - AnyTrueVecI32x4, - AllTrueVecI32x4, - NegVecI64x2, - AnyTrueVecI64x2, - AllTrueVecI64x2, - AbsVecF32x4, - NegVecF32x4, - SqrtVecF32x4, - AbsVecF64x2, - NegVecF64x2, - SqrtVecF64x2, - TruncSatSVecF32x4ToVecI32x4, - TruncSatUVecF32x4ToVecI32x4, - TruncSatSVecF64x2ToVecI64x2, - TruncSatUVecF64x2ToVecI64x2, - ConvertSVecI32x4ToVecF32x4, - ConvertUVecI32x4ToVecF32x4, - ConvertSVecI64x2ToVecF64x2, - ConvertUVecI64x2ToVecF64x2 - } - export enum BinaryOp { - AddI32, - SubI32, - MulI32, - DivI32, - DivU32, - RemI32, - RemU32, - AndI32, - OrI32, - XorI32, - ShlI32, - ShrU32, - ShrI32, - RotlI32, - RotrI32, - EqI32, - NeI32, - LtI32, - LtU32, - LeI32, - LeU32, - GtI32, - GtU32, - GeI32, - GeU32, - AddI64, - SubI64, - MulI64, - DivI64, - DivU64, - RemI64, - RemU64, - AndI64, - OrI64, - XorI64, - ShlI64, - ShrU64, - ShrI64, - RotlI64, - RotrI64, - EqI64, - NeI64, - LtI64, - LtU64, - LeI64, - LeU64, - GtI64, - GtU64, - GeI64, - GeU64, - AddF32, - SubF32, - MulF32, - DivF32, - CopysignF32, - MinF32, - MaxF32, - EqF32, - NeF32, - LtF32, - LeF32, - GtF32, - GeF32, - AddF64, - SubF64, - MulF64, - DivF64, - CopysignF64, - MinF64, - MaxF64, - EqF64, - NeF64, - LtF64, - LeF64, - GtF64, - GeF64, - EqVecI8x16, - NeVecI8x16, - LtSVecI8x16, - LtUVecI8x16, - LeSVecI8x16, - LeUVecI8x16, - GtSVecI8x16, - GtUVecI8x16, - GeSVecI8x16, - GeUVecI8x16, - EqVecI16x8, - NeVecI16x8, - LtSVecI16x8, - LtUVecI16x8, - LeSVecI16x8, - LeUVecI16x8, - GtSVecI16x8, - GtUVecI16x8, - GeSVecI16x8, - GeUVecI16x8, - EqVecI32x4, - NeVecI32x4, - LtSVecI32x4, - LtUVecI32x4, - LeSVecI32x4, - LeUVecI32x4, - GtSVecI32x4, - GtUVecI32x4, - GeSVecI32x4, - GeUVecI32x4, - EqVecF32x4, - NeVecF32x4, - LtVecF32x4, - LeVecF32x4, - GtVecF32x4, - GeVecF32x4, - EqVecF64x2, - NeVecF64x2, - LtVecF64x2, - LeVecF64x2, - GtVecF64x2, - GeVecF64x2, - AndVec128, - OrVec128, - XorVec128, - AddVecI8x16, - AddSatSVecI8x16, - AddSatUVecI8x16, - SubVecI8x16, - SubSatSVecI8x16, - SubSatUVecI8x16, - MulVecI8x16, - AddVecI16x8, - AddSatSVecI16x8, - AddSatUVecI16x8, - SubVecI16x8, - SubSatSVecI16x8, - SubSatUVecI16x8, - MulVecI16x8, - AddVecI32x4, - SubVecI32x4, - MulVecI32x4, - AddVecI64x2, - SubVecI64x2, - AddVecF32x4, - SubVecF32x4, - MulVecF32x4, - DivVecF32x4, - MinVecF32x4, - MaxVecF32x4, - AddVecF64x2, - SubVecF64x2, - MulVecF64x2, - DivVecF64x2, - MinVecF64x2, - MaxVecF64x2 - } - export enum HostOp { - MemorySize, - MemoryGrow - } - export enum AtomicRMWOp { - Add, - Sub, - And, - Or, - Xor, - Xchg - } - export enum SIMDExtractOp { - ExtractLaneSVecI8x16, - ExtractLaneUVecI8x16, - ExtractLaneSVecI16x8, - ExtractLaneUVecI16x8, - ExtractLaneVecI32x4, - ExtractLaneVecI64x2, - ExtractLaneVecF32x4, - ExtractLaneVecF64x2 - } - export enum SIMDReplaceOp { - ReplaceLaneVecI8x16, - ReplaceLaneVecI16x8, - ReplaceLaneVecI32x4, - ReplaceLaneVecI64x2, - ReplaceLaneVecF32x4, - ReplaceLaneVecF64x2 - } - export enum SIMDShiftOp { - ShlVecI8x16, - ShrSVecI8x16, - ShrUVecI8x16, - ShlVecI16x8, - ShrSVecI16x8, - ShrUVecI16x8, - ShlVecI32x4, - ShrSVecI32x4, - ShrUVecI32x4, - ShlVecI64x2, - ShrSVecI64x2, - ShrUVecI64x2 - } - export class MemorySegment { - buffer: Uint8Array; - offset: I64; - static create(buffer: Uint8Array, offset: I64): MemorySegment; - } - export class Module { - ref: ModuleRef; - private lit; - static create(): Module; - static createFrom(buffer: Uint8Array): Module; - private constructor(); - addFunctionType(name: string, result: NativeType, paramTypes: NativeType[] | null): FunctionRef; - getFunctionTypeBySignature(result: NativeType, paramTypes: NativeType[] | null): FunctionTypeRef; - removeFunctionType(name: string): void; - i32(value: i32): ExpressionRef; - i64(valueLow: i32, valueHigh?: i32): ExpressionRef; - f32(value: f32): ExpressionRef; - f64(value: f64): ExpressionRef; - v128(bytes: Uint8Array): ExpressionRef; - unary(op: UnaryOp, expr: ExpressionRef): ExpressionRef; - binary(op: BinaryOp, left: ExpressionRef, right: ExpressionRef): ExpressionRef; - host(op: HostOp, name?: string | null, operands?: ExpressionRef[] | null): ExpressionRef; - local_get(index: i32, type: NativeType): ExpressionRef; - local_tee(index: i32, value: ExpressionRef): ExpressionRef; - global_get(name: string, type: NativeType): ExpressionRef; - load(bytes: Index, signed: bool, ptr: ExpressionRef, type: NativeType, offset?: Index, align?: Index): ExpressionRef; - store(bytes: Index, ptr: ExpressionRef, value: ExpressionRef, type: NativeType, offset?: Index, align?: Index): ExpressionRef; - atomic_load(bytes: Index, ptr: ExpressionRef, type: NativeType, offset?: Index): ExpressionRef; - atomic_store(bytes: Index, ptr: ExpressionRef, value: ExpressionRef, type: NativeType, offset?: Index): ExpressionRef; - atomic_rmw(op: AtomicRMWOp, bytes: Index, offset: Index, ptr: ExpressionRef, value: ExpressionRef, type: NativeType): ExpressionRef; - atomic_cmpxchg(bytes: Index, offset: Index, ptr: ExpressionRef, expected: ExpressionRef, replacement: ExpressionRef, type: NativeType): ExpressionRef; - atomic_wait(ptr: ExpressionRef, expected: ExpressionRef, timeout: ExpressionRef, expectedType: NativeType): ExpressionRef; - atomic_notify(ptr: ExpressionRef, notifyCount: ExpressionRef): ExpressionRef; - local_set(index: Index, value: ExpressionRef): ExpressionRef; - global_set(name: string, value: ExpressionRef): ExpressionRef; - block(label: string | null, children: ExpressionRef[], type?: NativeType): ExpressionRef; - br(label: string | null, condition?: ExpressionRef, value?: ExpressionRef): ExpressionRef; - drop(expression: ExpressionRef): ExpressionRef; - loop(label: string | null, body: ExpressionRef): ExpressionRef; - if(condition: ExpressionRef, ifTrue: ExpressionRef, ifFalse?: ExpressionRef): ExpressionRef; - nop(): ExpressionRef; - return(expression?: ExpressionRef): ExpressionRef; - select(ifTrue: ExpressionRef, ifFalse: ExpressionRef, condition: ExpressionRef): ExpressionRef; - switch(names: string[], defaultName: string | null, condition: ExpressionRef, value?: ExpressionRef): ExpressionRef; - call(target: string, operands: ExpressionRef[] | null, returnType: NativeType): ExpressionRef; - call_indirect(index: ExpressionRef, operands: ExpressionRef[] | null, typeName: string): ExpressionRef; - unreachable(): ExpressionRef; - memory_copy(dest: ExpressionRef, source: ExpressionRef, size: ExpressionRef): ExpressionRef; - memory_fill(dest: ExpressionRef, value: ExpressionRef, size: ExpressionRef): ExpressionRef; - simd_extract(op: SIMDExtractOp, vec: ExpressionRef, idx: u8): ExpressionRef; - simd_replace(op: SIMDReplaceOp, vec: ExpressionRef, idx: u8, value: ExpressionRef): ExpressionRef; - simd_shuffle(vec1: ExpressionRef, vec2: ExpressionRef, mask: Uint8Array): ExpressionRef; - simd_bitselect(vec1: ExpressionRef, vec2: ExpressionRef, cond: ExpressionRef): ExpressionRef; - simd_shift(op: SIMDShiftOp, vec: ExpressionRef, shift: ExpressionRef): ExpressionRef; - addGlobal(name: string, type: NativeType, mutable: bool, initializer: ExpressionRef): GlobalRef; - removeGlobal(name: string): void; - addFunction(name: string, type: FunctionTypeRef, varTypes: NativeType[] | null, body: ExpressionRef): FunctionRef; - removeFunction(name: string): void; - private hasTemporaryFunction; - addTemporaryFunction(result: NativeType, paramTypes: NativeType[] | null, body: ExpressionRef): FunctionRef; - removeTemporaryFunction(): void; - addFunctionExport(internalName: string, externalName: string): ExportRef; - addTableExport(internalName: string, externalName: string): ExportRef; - addMemoryExport(internalName: string, externalName: string): ExportRef; - addGlobalExport(internalName: string, externalName: string): ExportRef; - removeExport(externalName: string): void; - addFunctionImport(internalName: string, externalModuleName: string, externalBaseName: string, functionType: FunctionTypeRef): ImportRef; - addTableImport(internalName: string, externalModuleName: string, externalBaseName: string): ImportRef; - addMemoryImport(internalName: string, externalModuleName: string, externalBaseName: string, shared?: bool): ImportRef; - addGlobalImport(internalName: string, externalModuleName: string, externalBaseName: string, globalType: NativeType): ImportRef; - /** Unlimited memory constant. */ - static readonly UNLIMITED_MEMORY: Index; - setMemory(initial: Index, maximum: Index, segments: MemorySegment[], target: Target, exportName?: string | null, shared?: bool): void; - setFunctionTable(initial: Index, maximum: Index, funcs: string[]): void; - setStart(func: FunctionRef): void; - getOptimizeLevel(): i32; - setOptimizeLevel(level?: i32): void; - getShrinkLevel(): i32; - setShrinkLevel(level?: i32): void; - setDebugInfo(on?: bool): void; - getFeatures(): BinaryenFeatureFlags; - setFeatures(featureFlags: BinaryenFeatureFlags): void; - optimize(func?: FunctionRef): void; - runPasses(passes: string[], func?: FunctionRef): void; - private cachedPrecomputeNames; - precomputeExpression(expr: ExpressionRef): ExpressionRef; - validate(): bool; - interpret(): void; - toBinary(sourceMapUrl: string | null): BinaryModule; - toText(): string; - toAsmjs(): string; - private cachedStrings; - private allocStringCached; - dispose(): void; - createRelooper(): Relooper; - cloneExpression(expr: ExpressionRef, noSideEffects?: bool, maxDepth?: i32): ExpressionRef; - addDebugInfoFile(name: string): Index; - getDebugInfoFile(index: Index): string | null; - setDebugLocation(func: FunctionRef, expr: ExpressionRef, fileIndex: Index, lineNumber: Index, columnNumber: Index): void; - } - export function getExpressionId(expr: ExpressionRef): ExpressionId; - export function getExpressionType(expr: ExpressionRef): NativeType; - export function getConstValueI32(expr: ExpressionRef): i32; - export function getConstValueI64Low(expr: ExpressionRef): i32; - export function getConstValueI64High(expr: ExpressionRef): i32; - export function getConstValueF32(expr: ExpressionRef): f32; - export function getConstValueF64(expr: ExpressionRef): f32; - export function getLocalGetIndex(expr: ExpressionRef): Index; - export function getLocalSetIndex(expr: ExpressionRef): Index; - export function getLocalSetValue(expr: ExpressionRef): ExpressionRef; - export function isLocalTee(expr: ExpressionRef): bool; - export function getGlobalGetName(expr: ExpressionRef): string | null; - export function getBinaryOp(expr: ExpressionRef): BinaryOp; - export function getBinaryLeft(expr: ExpressionRef): ExpressionRef; - export function getBinaryRight(expr: ExpressionRef): ExpressionRef; - export function getUnaryOp(expr: ExpressionRef): UnaryOp; - export function getUnaryValue(expr: ExpressionRef): ExpressionRef; - export function getLoadBytes(expr: ExpressionRef): u32; - export function getLoadOffset(expr: ExpressionRef): u32; - export function getLoadPtr(expr: ExpressionRef): ExpressionRef; - export function isLoadSigned(expr: ExpressionRef): bool; - export function getStoreBytes(expr: ExpressionRef): u32; - export function getStoreOffset(expr: ExpressionRef): u32; - export function getStorePtr(expr: ExpressionRef): ExpressionRef; - export function getStoreValue(expr: ExpressionRef): ExpressionRef; - export function getBlockName(expr: ExpressionRef): string | null; - export function getBlockChildCount(expr: ExpressionRef): Index; - export function getBlockChild(expr: ExpressionRef, index: Index): ExpressionRef; - export function getIfCondition(expr: ExpressionRef): ExpressionRef; - export function getIfTrue(expr: ExpressionRef): ExpressionRef; - export function getIfFalse(expr: ExpressionRef): ExpressionRef; - export function getLoopName(expr: ExpressionRef): string | null; - export function getLoopBody(expr: ExpressionRef): ExpressionRef; - export function getBreakName(expr: ExpressionRef): string | null; - export function getBreakCondition(expr: ExpressionRef): ExpressionRef; - export function getSelectThen(expr: ExpressionRef): ExpressionRef; - export function getSelectElse(expr: ExpressionRef): ExpressionRef; - export function getSelectCondition(expr: ExpressionRef): ExpressionRef; - export function getDropValue(expr: ExpressionRef): ExpressionRef; - export function getReturnValue(expr: ExpressionRef): ExpressionRef; - export function getCallTarget(expr: ExpressionRef): string | null; - export function getCallOperandCount(expr: ExpressionRef): i32; - export function getCallOperand(expr: ExpressionRef, index: Index): ExpressionRef; - export function getHostOp(expr: ExpressionRef): ExpressionRef; - export function getHostOperandCount(expr: ExpressionRef): Index; - export function getHostOperand(expr: ExpressionRef, index: Index): ExpressionRef; - export function getHostName(expr: ExpressionRef): string | null; - export function getFunctionBody(func: FunctionRef): ExpressionRef; - export function getFunctionName(func: FunctionRef): string | null; - export function getFunctionParamCount(func: FunctionRef): Index; - export function getFunctionParamType(func: FunctionRef, index: Index): NativeType; - export function getFunctionResultType(func: FunctionRef): NativeType; - export class Relooper { - module: Module; - ref: RelooperRef; - static create(module: Module): Relooper; - private constructor(); - addBlock(code: ExpressionRef): RelooperBlockRef; - addBranch(from: RelooperBlockRef, to: RelooperBlockRef, condition?: ExpressionRef, code?: ExpressionRef): void; - addBlockWithSwitch(code: ExpressionRef, condition: ExpressionRef): RelooperBlockRef; - addBranchForSwitch(from: RelooperBlockRef, to: RelooperBlockRef, indexes: i32[], code?: ExpressionRef): void; - renderAndDispose(entry: RelooperBlockRef, labelHelper: Index): ExpressionRef; - } - export function readString(ptr: usize): string | null; - /** Result structure of {@link Module#toBinary}. */ - export class BinaryModule { - /** WebAssembly binary. */ - output: Uint8Array; - /** Source map, if generated. */ - sourceMap: string | null; - } - /** Tests if an expression needs an explicit 'unreachable' when it is the terminating statement. */ - export function needsExplicitUnreachable(expr: ExpressionRef): bool; - /** Traverses all expression members of an expression, calling the given visitor. */ - export function traverse(expr: ExpressionRef, data: T, visit: (expr: ExpressionRef, data: T) => void): bool; - -} -declare module 'assemblyscript/src/types' { - /** - * Mappings from AssemblyScript types to WebAssembly types. - * @module types - */ /***/ - import { Class, FunctionTarget, Program } from 'assemblyscript/src/program'; - import { NativeType, ExpressionRef, Module } from 'assemblyscript/src/module'; - /** Indicates the kind of a type. */ - export const enum TypeKind { - /** An 8-bit signed integer. */ - I8 = 0, - /** A 16-bit signed integer. */ - I16 = 1, - /** A 32-bit signed integer. */ - I32 = 2, - /** A 64-bit signed integer. */ - I64 = 3, - /** A 32-bit/64-bit signed integer, depending on the target. */ - ISIZE = 4, - /** An 8-bit unsigned integer. */ - U8 = 5, - /** A 16-bit unsigned integer. */ - U16 = 6, - /** A 32-bit unsigned integer. Also the base of function types. */ - U32 = 7, - /** A 64-bit unsigned integer. */ - U64 = 8, - /** A 32-bit/64-bit unsigned integer, depending on the target. Also the base of class types. */ - USIZE = 9, - /** A 1-bit unsigned integer. */ - BOOL = 10, - /** A 32-bit float. */ - F32 = 11, - /** A 64-bit double. */ - F64 = 12, - /** A 128-bit vector. */ - V128 = 13, - /** No return type. */ - VOID = 14 - } - /** Indicates capabilities of a type. */ - export const enum TypeFlags { - NONE = 0, - /** Is a signed type that can represent negative values. */ - SIGNED = 1, - /** Is an unsigned type that cannot represent negative values. */ - UNSIGNED = 2, - /** Is an integer type. */ - INTEGER = 4, - /** Is a floating point type. */ - FLOAT = 8, - /** Is a pointer type. */ - POINTER = 16, - /** Is smaller than 32-bits. */ - SHORT = 32, - /** Is larger than 32-bits. */ - LONG = 64, - /** Is a value type. */ - VALUE = 128, - /** Is a reference type. */ - REFERENCE = 256, - /** Is a nullable type. */ - NULLABLE = 512, - /** Is a vector type. */ - VECTOR = 1024 - } - /** Represents a resolved type. */ - export class Type { - /** Type kind. */ - kind: TypeKind; - /** Type flags. */ - flags: TypeFlags; - /** Size in bits. */ - size: u32; - /** Size in bytes. */ - byteSize: i32; - /** Underlying class reference, if a class type. */ - classReference: Class | null; - /** Underlying signature reference, if a function type. */ - signatureReference: Signature | null; - /** Respective non-nullable type, if nullable. */ - nonNullableType: Type; - /** Cached nullable type, if non-nullable. */ - private cachedNullableType; - /** Constructs a new resolved type. */ - constructor(kind: TypeKind, flags: TypeFlags, size: u32); - /** Returns the closest int type representing this type. */ - readonly intType: Type; - /** Substitutes this type with the auto type if this type is void. */ - readonly exceptVoid: Type; - /** Gets this type's logarithmic alignment in memory. */ - readonly alignLog2: i32; - /** Tests if this is a managed type that needs GC hooks. */ - readonly isManaged: bool; - /** Tests if this is a class type explicitly annotated as unmanaged. */ - readonly isUnmanaged: bool; - /** Computes the sign-extending shift in the target type. */ - computeSmallIntegerShift(targetType: Type): u32; - /** Computes the truncating mask in the target type. */ - computeSmallIntegerMask(targetType: Type): u32; - /** Tests if this type has (all of) the specified flags. */ - is(flags: TypeFlags): bool; - /** Tests if this type has any of the specified flags. */ - isAny(flags: TypeFlags): bool; - /** Composes a class type from this type and a class. */ - asClass(classType: Class): Type; - /** Composes a function type from this type and a function. */ - asFunction(signature: Signature): Type; - /** Composes the respective nullable type of this type. */ - asNullable(): Type; - /** Tests if a value of this type is assignable to the target type incl. implicit conversion. */ - isAssignableTo(target: Type, signednessIsRelevant?: bool): bool; - /** Tests if a value of this type is assignable to the target type excl. implicit conversion. */ - isStrictlyAssignableTo(target: Type, signednessIsRelevant?: bool): bool; - /** Determines the common denominator type of two types, if there is any. */ - static commonDenominator(left: Type, right: Type, signednessIsImportant: bool): Type | null; - /** Converts this type to a string. */ - toString(): string; - /** Converts this type to its respective native type. */ - toNativeType(): NativeType; - /** Converts this type to its native `0` value. */ - toNativeZero(module: Module): ExpressionRef; - /** Converts this type to its native `1` value. */ - toNativeOne(module: Module): ExpressionRef; - /** Converts this type to its native `-1` value. */ - toNativeNegOne(module: Module): ExpressionRef; - /** Converts this type to its signature string. */ - toSignatureString(): string; - /** An 8-bit signed integer. */ - static readonly i8: Type; - /** A 16-bit signed integer. */ - static readonly i16: Type; - /** A 32-bit signed integer. */ - static readonly i32: Type; - /** A 64-bit signed integer. */ - static readonly i64: Type; - /** A 32-bit signed size. WASM32 only. */ - static readonly isize32: Type; - /** A 64-bit signed size. WASM64 only. */ - static readonly isize64: Type; - /** An 8-bit unsigned integer. */ - static readonly u8: Type; - /** A 16-bit unsigned integer. */ - static readonly u16: Type; - /** A 32-bit unsigned integer. */ - static readonly u32: Type; - /** A 64-bit unsigned integer. */ - static readonly u64: Type; - /** A 32-bit unsigned size. WASM32 only. */ - static readonly usize32: Type; - /** A 64-bit unsigned size. WASM64 only. */ - static readonly usize64: Type; - /** A 1-bit unsigned integer. */ - static readonly bool: Type; - /** A 32-bit float. */ - static readonly f32: Type; - /** A 64-bit float. */ - static readonly f64: Type; - /** A 128-bit vector. */ - static readonly v128: Type; - /** No return type. */ - static readonly void: Type; - /** Alias of i32 indicating type inference of locals and globals with just an initializer. */ - static readonly auto: Type; - } - /** Converts an array of types to an array of native types. */ - export function typesToNativeTypes(types: Type[]): NativeType[]; - /** Converts an array of types to its combined string representation. */ - export function typesToString(types: Type[]): string; - /** Represents a fully resolved function signature. */ - export class Signature { - /** Parameter types, if any, excluding `this`. */ - parameterTypes: Type[]; - /** Parameter names, if known, excluding `this`. */ - parameterNames: string[] | null; - /** Number of required parameters excluding `this`. Other parameters are considered optional. */ - requiredParameters: i32; - /** Return type. */ - returnType: Type; - /** This type, if an instance signature. */ - thisType: Type | null; - /** Whether the last parameter is a rest parameter. */ - hasRest: bool; - /** Cached {@link FunctionTarget}. */ - cachedFunctionTarget: FunctionTarget | null; - /** Respective function type. */ - type: Type; - /** Constructs a new signature. */ - constructor(parameterTypes?: Type[] | null, returnType?: Type | null, thisType?: Type | null); - asFunctionTarget(program: Program): FunctionTarget; - /** Gets the known or, alternatively, generic parameter name at the specified index. */ - getParameterName(index: i32): string; - /** Tests if a value of this function type is assignable to a target of the specified function type. */ - isAssignableTo(target: Signature): bool; - /** Converts a signature to a function type string. */ - static makeSignatureString(parameterTypes: Type[] | null, returnType: Type, thisType?: Type | null): string; - /** Converts this signature to a function type string. */ - toSignatureString(): string; - /** Converts this signature to a string. */ - toString(): string; - } - /** Gets the cached default parameter name for the specified index. */ - export function getDefaultParameterName(index: i32): string; - -} -declare module 'assemblyscript/src/flow' { - /** - * A control flow analyzer. - * @module flow - */ /***/ - import { Type } from 'assemblyscript/src/types'; - import { Local, Function, Element } from 'assemblyscript/src/program'; - import { ExpressionRef } from 'assemblyscript/src/module'; - import { Node } from 'assemblyscript/src/ast'; - /** Control flow flags indicating specific conditions. */ - export const enum FlowFlags { - /** No specific conditions. */ - NONE = 0, - /** This flow returns. */ - RETURNS = 1, - /** This flow returns a wrapped value. */ - RETURNS_WRAPPED = 2, - /** This flow returns a non-null value. */ - RETURNS_NONNULL = 4, - /** This flow throws. */ - THROWS = 8, - /** This flow breaks. */ - BREAKS = 16, - /** This flow continues. */ - CONTINUES = 32, - /** This flow allocates. Constructors only. */ - ALLOCATES = 64, - /** This flow calls super. Constructors only. */ - CALLS_SUPER = 128, - /** This flow terminates (returns, throws or continues). */ - TERMINATES = 256, - /** This flow conditionally returns in a child flow. */ - CONDITIONALLY_RETURNS = 512, - /** This flow conditionally throws in a child flow. */ - CONDITIONALLY_THROWS = 1024, - /** This flow conditionally terminates in a child flow. */ - CONDITIONALLY_TERMINATES = 2048, - /** This flow conditionally breaks in a child flow. */ - CONDITIONALLY_BREAKS = 4096, - /** This flow conditionally continues in a child flow. */ - CONDITIONALLY_CONTINUES = 8192, - /** This flow conditionally allocates in a child flow. Constructors only. */ - CONDITIONALLY_ALLOCATES = 16384, - /** This is an inlining flow. */ - INLINE_CONTEXT = 32768, - /** This is a flow with explicitly disabled bounds checking. */ - UNCHECKED_CONTEXT = 65536, - /** Any categorical flag. */ - ANY_CATEGORICAL = 511, - /** Any conditional flag. */ - ANY_CONDITIONAL = 30208 - } - /** Flags indicating the current state of a local. */ - export enum LocalFlags { - /** No specific conditions. */ - NONE = 0, - /** Local is constant. */ - CONSTANT = 1, - /** Local is properly wrapped. Relevant for small integers. */ - WRAPPED = 2, - /** Local is non-null. */ - NONNULL = 4, - /** Local is read from. */ - READFROM = 8, - /** Local is written to. */ - WRITTENTO = 16, - /** Local is retained. */ - RETAINED = 32, - /** Local is conditionally read from. */ - CONDITIONALLY_READFROM = 64, - /** Local is conditionally written to. */ - CONDITIONALLY_WRITTENTO = 128, - /** Local must be conditionally retained. */ - CONDITIONALLY_RETAINED = 256, - /** Any categorical flag. */ - ANY_CATEGORICAL = 63, - /** Any conditional flag. */ - ANY_CONDITIONAL = 480, - /** Any retained flag. */ - ANY_RETAINED = 288 - } - export namespace LocalFlags { - function join(left: LocalFlags, right: LocalFlags): LocalFlags; - } - /** Flags indicating the current state of a field. */ - export enum FieldFlags { - /** No specific conditions. */ - NONE = 0, - /** Field is initialized. Relevant in constructors. */ - INITIALIZED = 1, - /** Field is conditionally initialized. Relevant in constructors. */ - CONDITIONALLY_INITIALIZED = 2, - /** Any categorical flag. */ - ANY_CATEGORICAL = 1, - /** Any conditional flag. */ - ANY_CONDITIONAL = 2 - } - export namespace FieldFlags { - function join(left: FieldFlags, right: FieldFlags): FieldFlags; - } - /** A control flow evaluator. */ - export class Flow { - /** Parent flow. */ - parent: Flow | null; - /** Flow flags indicating specific conditions. */ - flags: FlowFlags; - /** Function this flow belongs to. */ - parentFunction: Function; - /** The label we break to when encountering a continue statement. */ - continueLabel: string | null; - /** The label we break to when encountering a break statement. */ - breakLabel: string | null; - /** The current return type. */ - returnType: Type; - /** The current contextual type arguments. */ - contextualTypeArguments: Map | null; - /** Scoped local variables. */ - scopedLocals: Map | null; - /** Local flags. */ - localFlags: LocalFlags[]; - /** Field flags. Relevant in constructors. */ - fieldFlags: Map | null; - /** Function being inlined, when inlining. */ - inlineFunction: Function | null; - /** The label we break to when encountering a return statement, when inlining. */ - inlineReturnLabel: string | null; - /** Creates the parent flow of the specified function. */ - static create(parentFunction: Function): Flow; - /** Creates an inline flow within `parentFunction`. */ - static createInline(parentFunction: Function, inlineFunction: Function): Flow; - private constructor(); - /** Gets the actual function being compiled, The inlined function when inlining, otherwise the parent function. */ - readonly actualFunction: Function; - /** Tests if this flow has the specified flag or flags. */ - is(flag: FlowFlags): bool; - /** Tests if this flow has one of the specified flags. */ - isAny(flag: FlowFlags): bool; - /** Sets the specified flag or flags. */ - set(flag: FlowFlags): void; - /** Unsets the specified flag or flags. */ - unset(flag: FlowFlags): void; - /** Forks this flow to a child flow. */ - fork(): Flow; - /** Gets a free temporary local of the specified type. */ - getTempLocal(type: Type, except?: Set | null): Local; - /** Gets a local that sticks around until this flow is exited, and then released. */ - getAutoreleaseLocal(type: Type, except?: Set | null): Local; - /** Frees the temporary local for reuse. */ - freeTempLocal(local: Local): void; - /** Gets and immediately frees a temporary local of the specified type. */ - getAndFreeTempLocal(type: Type, except?: Set | null): Local; - /** Gets the scoped local of the specified name. */ - getScopedLocal(name: string): Local | null; - /** Adds a new scoped local of the specified name. */ - addScopedLocal(name: string, type: Type, except?: Set | null): Local; - /** Adds a new scoped alias for the specified local. For example `super` aliased to the `this` local. */ - addScopedAlias(name: string, type: Type, index: i32, reportNode?: Node | null): Local; - /** Frees this flow's scoped variables and returns its parent flow. */ - freeScopedLocals(): void; - /** Looks up the local of the specified name in the current scope. */ - lookupLocal(name: string): Local | null; - /** Looks up the element with the specified name relative to the scope of this flow. */ - lookup(name: string): Element | null; - /** Tests if the local at the specified index has the specified flag or flags. */ - isLocalFlag(index: i32, flag: LocalFlags, defaultIfInlined?: bool): bool; - /** Tests if the local at the specified index has any of the specified flags. */ - isAnyLocalFlag(index: i32, flag: LocalFlags, defaultIfInlined?: bool): bool; - /** Sets the specified flag or flags on the local at the specified index. */ - setLocalFlag(index: i32, flag: LocalFlags): void; - /** Unsets the specified flag or flags on the local at the specified index. */ - unsetLocalFlag(index: i32, flag: LocalFlags): void; - /** Pushes a new break label to the stack, for example when entering a loop that one can `break` from. */ - pushBreakLabel(): string; - /** Pops the most recent break label from the stack. */ - popBreakLabel(): void; - /** Inherits flags and local wrap states from the specified flow (e.g. blocks). */ - inherit(other: Flow): void; - /** Inherits categorical flags as conditional flags from the specified flow (e.g. then without else). */ - inheritConditional(other: Flow): void; - /** Inherits mutual flags and local wrap states from the specified flows (e.g. then with else). */ - inheritMutual(left: Flow, right: Flow): void; - /** Checks if an expression of the specified type is known to be non-null, even if the type might be nullable. */ - isNonnull(expr: ExpressionRef, type: Type): bool; - /** Updates local states to reflect that this branch is only taken when `expr` is true-ish. */ - inheritNonnullIfTrue(expr: ExpressionRef): void; - /** Updates local states to reflect that this branch is only taken when `expr` is false-ish. */ - inheritNonnullIfFalse(expr: ExpressionRef): void; - /** - * Tests if an expression can possibly overflow in the context of this flow. Assumes that the - * expression might already have overflown and returns `false` only if the operation neglects - * any possible combination of garbage bits being present. - */ - canOverflow(expr: ExpressionRef, type: Type): bool; - toString(): string; - } - /** Finds all indexes of locals used in the specified expression. */ - export function findUsedLocals(expr: ExpressionRef, used?: Set): Set; - -} -declare module 'assemblyscript/src/resolver' { - /** - * Resolve infrastructure to obtain types and elements. - * @module resolver - */ /***/ - import { DiagnosticEmitter } from 'assemblyscript/src/diagnostics'; - import { Program, Element, Class, ClassPrototype, Function, FunctionPrototype, Global } from 'assemblyscript/src/program'; - import { Flow } from 'assemblyscript/src/flow'; - import { CommonTypeNode, TypeName, TypeParameterNode, Node, IdentifierExpression, CallExpression, ElementAccessExpression, PropertyAccessExpression, LiteralExpression, AssertionExpression, Expression, UnaryPrefixExpression, UnaryPostfixExpression, BinaryExpression, ThisExpression, SuperExpression } from 'assemblyscript/src/ast'; - import { Type } from 'assemblyscript/src/types'; - /** Indicates whether errors are reported or not. */ - export enum ReportMode { - /** Report errors. */ - REPORT = 0, - /** Swallow errors. */ - SWALLOW = 1 - } - /** Provides tools to resolve types and expressions. */ - export class Resolver extends DiagnosticEmitter { - /** The program this resolver belongs to. */ - program: Program; - /** Target expression of the previously resolved property or element access. */ - currentThisExpression: Expression | null; - /** Element expression of the previously resolved element access. */ - currentElementExpression: Expression | null; - /** Constructs the resolver for the specified program. */ - constructor( - /** The program to construct a resolver for. */ - program: Program); - /** Resolves a {@link CommonTypeNode} to a concrete {@link Type}. */ - resolveType( - /** The type to resolve. */ - node: CommonTypeNode, - /** Relative context. */ - context: Element, - /** Type arguments inherited through context, i.e. `T`. */ - contextualTypeArguments?: Map | null, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Type | null; - /** Resolves a type name to the program element it refers to. */ - resolveTypeName( - /** The type name to resolve. */ - typeName: TypeName, - /** Relative context. */ - context: Element, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves an array of type arguments to concrete types. */ - resolveTypeArguments( - /** Actual type parameter nodes. */ - typeParameters: TypeParameterNode[], - /** Type arguments provided. */ - typeArgumentNodes: CommonTypeNode[] | null, - /** Relative context. */ - context: Element, - /** Type arguments inherited through context, i.e. `T`. */ - contextualTypeArguments?: Map, - /** Alternative report node in case of empty type arguments. */ - alternativeReportNode?: Node | null, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Type[] | null; - /** Resolves an identifier to the program element it refers to. */ - resolveIdentifier( - /** The expression to resolve. */ - identifier: IdentifierExpression, - /** Optional flow to search for scoped locals. */ - flow: Flow | null, - /** Optional context to search. */ - context: Element | null, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves a lazily compiled global, i.e. a static class field. */ - ensureResolvedLazyGlobal(global: Global, reportMode?: ReportMode): bool; - /** Resolves a property access expression to the program element it refers to. */ - resolvePropertyAccessExpression( - /** The expression to resolve. */ - propertyAccess: PropertyAccessExpression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves an element access expression to the program element it refers to. */ - resolveElementAccessExpression( - /** The expression to resolve. */ - elementAccess: ElementAccessExpression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Determines the final type of an integer literal given the specified contextual type. */ - determineIntegerLiteralType( - /** Integer literal value. */ - intValue: I64, - /** Current contextual type. */ - contextualType: Type): Type; - /** Resolves any expression to the program element it refers to. */ - resolveExpression( - /** The expression to resolve. */ - expression: Expression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType?: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves an assertion expression to the program element it refers to. */ - resolveAssertionExpression( - /** The expression to resolve. */ - expression: AssertionExpression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType?: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves an unary prefix expression to the program element it refers to. */ - resolveUnaryPrefixExpression( - /** The expression to resolve. */ - expression: UnaryPrefixExpression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType?: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves an unary postfix expression to the program element it refers to. */ - resolveUnaryPostfixExpression( - /** The expression to resolve. */ - expression: UnaryPostfixExpression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType?: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves a binary expression to the program element it refers to. */ - resolveBinaryExpression( - /** The expression to resolve. */ - expression: BinaryExpression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType?: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves a this expression to the program element it refers to. */ - resolveThisExpression( - /** The expression to resolve. */ - expression: ThisExpression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType?: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves a super expression to the program element it refers to. */ - resolveSuperExpression( - /** The expression to resolve. */ - expression: SuperExpression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType?: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves a literal expression to the program element it refers to. */ - resolveLiteralExpression( - /** The expression to resolve. */ - expression: LiteralExpression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType?: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves a call expression to the program element it refers to. */ - resolveCallExpression( - /** The expression to resolve. */ - expression: CallExpression, - /** Current flow. */ - flow: Flow, - /** Current contextual type. */ - contextualType?: Type, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Element | null; - /** Resolves a function prototype using the specified concrete type arguments. */ - resolveFunction( - /** The prototype of the function. */ - prototype: FunctionPrototype, - /** Concrete type arguments. */ - typeArguments: Type[] | null, - /** Type arguments inherited through context, i.e. `T`. */ - contextualTypeArguments?: Map, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Function | null; - /** Resolves a function prototypeby first resolving the specified type arguments. */ - resolveFunctionInclTypeArguments( - /** The prototype of the function. */ - prototype: FunctionPrototype, - /** Type arguments provided. */ - typeArgumentNodes: CommonTypeNode[] | null, - /** Relative context. Type arguments are resolved from here. */ - context: Element, - /** Type arguments inherited through context, i.e. `T`. */ - contextualTypeArguments: Map, - /** The node to use when reporting intermediate errors. */ - reportNode: Node, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Function | null; - /** Resolves a class prototype using the specified concrete type arguments. */ - resolveClass( - /** The prototype of the class. */ - prototype: ClassPrototype, - /** Concrete type arguments. */ - typeArguments: Type[] | null, - /** Type arguments inherited through context, i.e. `T`. */ - contextualTypeArguments?: Map, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Class | null; - /** Resolves a class prototype by first resolving the specified type arguments. */ - resolveClassInclTypeArguments( - /** The prototype of the class. */ - prototype: ClassPrototype, - /** Type argument nodes provided. */ - typeArgumentNodes: CommonTypeNode[] | null, - /** Relative context. Type arguments are resolved from here. */ - context: Element, - /** Type arguments inherited through context, i.e. `T`. */ - contextualTypeArguments: Map, - /** The node to use when reporting intermediate errors. */ - reportNode: Node, - /** How to proceed with eventualy diagnostics. */ - reportMode?: ReportMode): Class | null; - } - -} -declare module 'assemblyscript/src/program' { - /** - * AssemblyScript's intermediate representation describing a program's elements. - * @module program - */ /***/ - import { CommonFlags } from 'assemblyscript/src/common'; - import { Options } from 'assemblyscript/src/compiler'; - import { DiagnosticMessage, DiagnosticEmitter } from 'assemblyscript/src/diagnostics'; - import { Type, TypeKind, Signature } from 'assemblyscript/src/types'; - import { Source, Range, DecoratorNode, DecoratorKind, SignatureNode, TypeParameterNode, CommonTypeNode, TypeNode, ArrowKind, Expression, IdentifierExpression, Statement, ClassDeclaration, DeclarationStatement, EnumDeclaration, EnumValueDeclaration, FieldDeclaration, FunctionDeclaration, InterfaceDeclaration, NamespaceDeclaration, TypeDeclaration, VariableDeclaration, VariableLikeDeclarationStatement } from 'assemblyscript/src/ast'; - import { Module, FunctionRef } from 'assemblyscript/src/module'; - import { Resolver } from 'assemblyscript/src/resolver'; - import { Flow } from 'assemblyscript/src/flow'; - /** Represents the kind of an operator overload. */ - export enum OperatorKind { - INVALID = 0, - INDEXED_GET = 1, - INDEXED_SET = 2, - UNCHECKED_INDEXED_GET = 3, - UNCHECKED_INDEXED_SET = 4, - ADD = 5, - SUB = 6, - MUL = 7, - DIV = 8, - REM = 9, - POW = 10, - BITWISE_AND = 11, - BITWISE_OR = 12, - BITWISE_XOR = 13, - BITWISE_SHL = 14, - BITWISE_SHR = 15, - BITWISE_SHR_U = 16, - EQ = 17, - NE = 18, - GT = 19, - GE = 20, - LT = 21, - LE = 22, - PLUS = 23, - MINUS = 24, - NOT = 25, - BITWISE_NOT = 26, - PREFIX_INC = 27, - PREFIX_DEC = 28, - POSTFIX_INC = 29, - POSTFIX_DEC = 30 - } - /** Represents an AssemblyScript program. */ - export class Program extends DiagnosticEmitter { - /** Resolver instance. */ - resolver: Resolver; - /** Array of sources. */ - sources: Source[]; - /** Diagnostic offset used where successively obtaining the next diagnostic. */ - diagnosticsOffset: i32; - /** Compiler options. */ - options: Options; - /** Special native code source. */ - nativeSource: Source; - /** Special native code file. */ - nativeFile: File; - /** Files by unique internal name. */ - filesByName: Map; - /** Elements by unique internal name in element space. */ - elementsByName: Map; - /** Elements by declaration. */ - elementsByDeclaration: Map; - /** Element instances by unique internal name. */ - instancesByName: Map; - /** Classes backing basic types like `i32`. */ - typeClasses: Map; - /** Managed classes contained in the program, by id. */ - managedClasses: Map; - /** ArrayBufferView reference. */ - arrayBufferViewInstance: Class; - /** ArrayBuffer instance reference. */ - arrayBufferInstance: Class; - /** Array prototype reference. */ - arrayPrototype: ClassPrototype; - /** Set prototype reference. */ - setPrototype: ClassPrototype; - /** Map prototype reference. */ - mapPrototype: ClassPrototype; - /** Fixed array prototype reference. */ - fixedArrayPrototype: ClassPrototype; - /** Int8Array prototype. */ - i8ArrayPrototype: ClassPrototype; - /** Int16Array prototype. */ - i16ArrayPrototype: ClassPrototype; - /** Int32Array prototype. */ - i32ArrayPrototype: ClassPrototype; - /** Int64Array prototype. */ - i64ArrayPrototype: ClassPrototype; - /** Uint8Array prototype. */ - u8ArrayPrototype: ClassPrototype; - /** Uint8ClampedArray prototype. */ - u8ClampedArrayPrototype: ClassPrototype; - /** Uint16Array prototype. */ - u16ArrayPrototype: ClassPrototype; - /** Uint32Array prototype. */ - u32ArrayPrototype: ClassPrototype; - /** Uint64Array prototype. */ - u64ArrayPrototype: ClassPrototype; - /** Float32Array prototype. */ - f32ArrayPrototype: ClassPrototype; - /** Float64Array prototype. */ - f64ArrayPrototype: ClassPrototype; - /** String instance reference. */ - stringInstance: Class; - /** Abort function reference, if present. */ - abortInstance: Function; - /** RT `__alloc(size: usize, id: u32): usize` */ - allocInstance: Function; - /** RT `__realloc(ref: usize, newSize: usize): usize` */ - reallocInstance: Function; - /** RT `__free(ref: usize): void` */ - freeInstance: Function; - /** RT `__retain(ref: usize): usize` */ - retainInstance: Function; - /** RT `__release(ref: usize): void` */ - releaseInstance: Function; - /** RT `__collect(): void` */ - collectInstance: Function; - /** RT `__visit(ref: usize, cookie: u32): void` */ - visitInstance: Function; - /** RT `__typeinfo(id: u32): RTTIFlags` */ - typeinfoInstance: Function; - /** RT `__instanceof(ref: usize, superId: u32): bool` */ - instanceofInstance: Function; - /** RT `__allocArray(length: i32, alignLog2: usize, id: u32, data: usize = 0): usize` */ - allocArrayInstance: Function; - /** Next class id. */ - nextClassId: u32; - /** Constructs a new program, optionally inheriting parser diagnostics. */ - constructor( - /** Shared array of diagnostic messages (emitted so far). */ - diagnostics?: DiagnosticMessage[] | null); - /** Writes a common runtime header to the specified buffer. */ - writeRuntimeHeader(buffer: Uint8Array, offset: i32, classInstance: Class, payloadSize: u32): void; - /** Gets the size of a runtime header. */ - readonly runtimeHeaderSize: i32; - /** Creates a native variable declaration. */ - makeNativeVariableDeclaration( - /** The simple name of the variable */ - name: string, - /** Flags indicating specific traits, e.g. `CONST`. */ - flags?: CommonFlags): VariableDeclaration; - /** Creates a native type declaration. */ - makeNativeTypeDeclaration( - /** The simple name of the type. */ - name: string, - /** Flags indicating specific traits, e.g. `GENERIC`. */ - flags?: CommonFlags): TypeDeclaration; - private nativeDummySignature; - /** Creates a native function declaration. */ - makeNativeFunctionDeclaration( - /** The simple name of the function. */ - name: string, - /** Flags indicating specific traits, e.g. `DECLARE`. */ - flags?: CommonFlags): FunctionDeclaration; - /** Creates a native namespace declaration. */ - makeNativeNamespaceDeclaration( - /** The simple name of the namespace. */ - name: string, - /** Flags indicating specific traits, e.g. `EXPORT`. */ - flags?: CommonFlags): NamespaceDeclaration; - /** Creates a native function. */ - makeNativeFunction( - /** The simple name of the function. */ - name: string, - /** Concrete function signature. */ - signature: Signature, - /** Parent element, usually a file, class or namespace. */ - parent?: Element, - /** Flags indicating specific traits, e.g. `GENERIC`. */ - flags?: CommonFlags, - /** Decorator flags representing built-in decorators. */ - decoratorFlags?: DecoratorFlags): Function; - /** Gets the (possibly merged) program element linked to the specified declaration. */ - getElementByDeclaration(declaration: DeclarationStatement): DeclaredElement; - /** Initializes the program and its elements prior to compilation. */ - initialize(options: Options): void; - /** Requires that a global library element of the specified kind is present and returns it. */ - private require; - /** Requires that a non-generic global class is present and returns it. */ - private requireClass; - /** Requires that a non-generic global function is present and returns it. */ - private requireFunction; - /** Marks an element and its children as a module export. */ - private markModuleExport; - /** Registers a native type with the program. */ - private registerNativeType; - /** Registers the backing class of a native type. */ - private registerNativeTypeClass; - /** Registers a constant integer value within the global scope. */ - private registerConstantInteger; - /** Registers a constant float value within the global scope. */ - private registerConstantFloat; - /** Ensures that the given global element exists. Attempts to merge duplicates. */ - ensureGlobal(name: string, element: DeclaredElement): DeclaredElement; - /** Looks up the element of the specified name in the global scope. */ - lookupGlobal(name: string): Element | null; - /** Looks up the element of the specified name in the global scope. Errors if not present. */ - requireGlobal(name: string): Element; - /** Tries to locate a foreign file given its normalized path. */ - private lookupForeignFile; - /** Tries to locate a foreign element by traversing exports and queued exports. */ - private lookupForeign; - /** Validates that only supported decorators are present. */ - private checkDecorators; - /** Initializes a class declaration. */ - private initializeClass; - /** Initializes a field of a class or interface. */ - private initializeField; - /** Initializes a method of a class or interface. */ - private initializeMethod; - /** Checks that operator overloads are generally valid, if present. */ - private checkOperatorOverloads; - /** Ensures that the property introduced by the specified getter or setter exists.*/ - private ensureProperty; - /** Initializes a property of a class. */ - private initializeProperty; - /** Initializes an enum. */ - private initializeEnum; - /** Initializes an enum value. */ - private initializeEnumValue; - /** Initializes an `export` statement. */ - private initializeExports; - /** Initializes a single `export` member. Does not handle `export *`. */ - private initializeExport; - private initializeExportDefault; - /** Initializes an `import` statement. */ - private initializeImports; - /** Initializes a single `import` declaration. Does not handle `import *`. */ - private initializeImport; - /** Initializes a function. Does not handle methods. */ - private initializeFunction; - /** Initializes an interface. */ - private initializeInterface; - /** Initializes a namespace. */ - private initializeNamespace; - /** Initializes a `type` definition. */ - private initializeTypeDefinition; - /** Initializes a variable statement. */ - private initializeVariables; - } - /** Indicates the specific kind of an {@link Element}. */ - export enum ElementKind { - /** A {@link Global}. */ - GLOBAL = 0, - /** A {@link Local}. */ - LOCAL = 1, - /** An {@link Enum}. */ - ENUM = 2, - /** An {@link EnumValue}. */ - ENUMVALUE = 3, - /** A {@link FunctionPrototype}. */ - FUNCTION_PROTOTYPE = 4, - /** A {@link Function}. */ - FUNCTION = 5, - /** A {@link FunctionTarget}. */ - FUNCTION_TARGET = 6, - /** A {@link ClassPrototype}. */ - CLASS_PROTOTYPE = 7, - /** A {@link Class}. */ - CLASS = 8, - /** An {@link InterfacePrototype}. */ - INTERFACE_PROTOTYPE = 9, - /** An {@link Interface}. */ - INTERFACE = 10, - /** A {@link FieldPrototype}. */ - FIELD_PROTOTYPE = 11, - /** A {@link Field}. */ - FIELD = 12, - /** A {@link PropertyPrototype}. */ - PROPERTY_PROTOTYPE = 13, - /** A {@link Property}. */ - PROPERTY = 14, - /** A {@link Namespace}. */ - NAMESPACE = 15, - /** A {@link File}. */ - FILE = 16, - /** A {@link TypeDefinition}. */ - TYPEDEFINITION = 17 - } - /** Indicates built-in decorators that are present. */ - export enum DecoratorFlags { - /** No flags set. */ - NONE = 0, - /** Is a program global. */ - GLOBAL = 1, - /** Is a binary operator overload. */ - OPERATOR_BINARY = 2, - /** Is a unary prefix operator overload. */ - OPERATOR_PREFIX = 4, - /** Is a unary postfix operator overload. */ - OPERATOR_POSTFIX = 8, - /** Is an unmanaged class. */ - UNMANAGED = 16, - /** Is a sealed class. */ - SEALED = 32, - /** Is always inlined. */ - INLINE = 64, - /** Is using a different external name. */ - EXTERNAL = 128, - /** Is a builtin. */ - BUILTIN = 256, - /** Is compiled lazily. */ - LAZY = 512, - /** Is considered unsafe code. */ - UNSAFE = 1024 - } - /** Translates a decorator kind to the respective decorator flag. */ - export function decoratorKindToFlag(kind: DecoratorKind): DecoratorFlags; - /** Base class of all program elements. */ - export abstract class Element { - /** Specific element kind. */ - kind: ElementKind; - /** Simple name. */ - name: string; - /** Internal name referring to this element. */ - internalName: string; - /** Containing {@link Program}. */ - program: Program; - /** Parent element. */ - parent: Element; - /** Common flags indicating specific traits. */ - flags: CommonFlags; - /** Decorator flags indicating annotated traits. */ - decoratorFlags: DecoratorFlags; - /** Member elements. */ - members: Map | null; - /** Shadowing type in type space, if any. */ - shadowType: TypeDefinition | null; - /** Constructs a new program element. */ - protected constructor( - /** Specific element kind. */ - kind: ElementKind, - /** Simple name. */ - name: string, - /** Internal name referring to this element. */ - internalName: string, - /** Containing {@link Program}. */ - program: Program, - /** Parent element. */ - parent: Element | null); - /** Gets the enclosing file. */ - readonly file: File; - /** Tests if this element has a specific flag or flags. */ - is(flag: CommonFlags): bool; - /** Tests if this element has any of the specified flags. */ - isAny(flags: CommonFlags): bool; - /** Sets a specific flag or flags. */ - set(flag: CommonFlags): void; - /** Unsets the specific flag or flags. */ - unset(flag: CommonFlags): void; - /** Tests if this element has a specific decorator flag or flags. */ - hasDecorator(flag: DecoratorFlags): bool; - /** Looks up the element with the specified name within this element. */ - lookupInSelf(name: string): DeclaredElement | null; - /** Looks up the element with the specified name relative to this element, like in JS. */ - abstract lookup(name: string): Element | null; - /** Adds an element as a member of this one. Reports and returns `false` if a duplicate. */ - add(name: string, element: DeclaredElement): bool; - /** Returns a string representation of this element. */ - toString(): string; - } - /** Base class of elements with an associated declaration statement. */ - export abstract class DeclaredElement extends Element { - /** Declaration reference. */ - declaration: DeclarationStatement; - /** Constructs a new declared program element. */ - protected constructor( - /** Specific element kind. */ - kind: ElementKind, - /** Simple name. */ - name: string, - /** Internal name referring to this element. */ - internalName: string, - /** Containing {@link Program}. */ - program: Program, - /** Parent element. */ - parent: Element | null, - /** Declaration reference. */ - declaration: DeclarationStatement); - /** Tests if this element is a library element. */ - readonly isDeclaredInLibrary: bool; - /** Gets the associated identifier node. */ - readonly identifierNode: IdentifierExpression; - /** Gets the assiciated decorator nodes. */ - readonly decoratorNodes: DecoratorNode[] | null; - } - /** Base class of elements that can be resolved to a concrete type. */ - export abstract class TypedElement extends DeclaredElement { - /** Resolved type. Set once `is(RESOLVED)`, otherwise void. */ - type: Type; - /** Sets the resolved type of this element. */ - setType(type: Type): void; - } - /** A file representing the implicit top-level namespace of a source. */ - export class File extends Element { - /** Source of this file. */ - source: Source; - /** File exports. */ - exports: Map | null; - /** File re-exports. */ - exportsStar: File[] | null; - /** Top-level start function of this file. */ - startFunction: Function; - /** Constructs a new file. */ - constructor( - /** Program this file belongs to. */ - program: Program, - /** Source of this file. */ - source: Source); - add(name: string, element: DeclaredElement, isImport?: bool): bool; - lookupInSelf(name: string): DeclaredElement | null; - lookup(name: string): Element | null; - /** Ensures that an element is an export of this file. */ - ensureExport(name: string, element: DeclaredElement): void; - /** Ensures that another file is a re-export of this file. */ - ensureExportStar(file: File): void; - /** Looks up the export of the specified name. */ - lookupExport(name: string): DeclaredElement | null; - /** Creates an imported namespace from this file. */ - asImportedNamespace(name: string, parent: Element): Namespace; - } - /** A type definition. */ - export class TypeDefinition extends TypedElement { - /** Constructs a new type definition. */ - constructor( - /** Simple name. */ - name: string, - /** Parent element, usually a file or namespace. */ - parent: Element, - /** Declaration reference. */ - declaration: TypeDeclaration, - /** Pre-checked flags indicating built-in decorators. */ - decoratorFlags?: DecoratorFlags); - /** Gets the associated type parameter nodes. */ - readonly typeParameterNodes: TypeParameterNode[] | null; - /** Gets the associated type node. */ - readonly typeNode: CommonTypeNode; - lookup(name: string): Element | null; - } - /** A namespace that differs from a file in being user-declared with a name. */ - export class Namespace extends DeclaredElement { - /** Constructs a new namespace. */ - constructor( - /** Simple name. */ - name: string, - /** Parent element, usually a file or another namespace. */ - parent: Element, - /** Declaration reference. */ - declaration: NamespaceDeclaration, - /** Pre-checked flags indicating built-in decorators. */ - decoratorFlags?: DecoratorFlags); - lookup(name: string): Element | null; - } - /** An enum. */ - export class Enum extends TypedElement { - /** Constructs a new enum. */ - constructor( - /** Simple name. */ - name: string, - /** Parent element, usually a file or namespace. */ - parent: Element, - /** Declaration reference. */ - declaration: EnumDeclaration, - /** Pre-checked flags indicating built-in decorators. */ - decoratorFlags?: DecoratorFlags); - lookup(name: string): Element | null; - } - /** Indicates the kind of an inlined constant value. */ - export const enum ConstantValueKind { - /** No constant value. */ - NONE = 0, - /** Constant integer value. */ - INTEGER = 1, - /** Constant float value. */ - FLOAT = 2 - } - /** Base class of all variable-like program elements. */ - export abstract class VariableLikeElement extends TypedElement { - /** Constant value kind. */ - constantValueKind: ConstantValueKind; - /** Constant integer value, if applicable. */ - constantIntegerValue: I64; - /** Constant float value, if applicable. */ - constantFloatValue: f64; - /** Constructs a new variable-like element. */ - protected constructor( - /** Specific element kind. */ - kind: ElementKind, - /** Simple name. */ - name: string, - /** Parent element, usually a file, namespace or class. */ - parent: Element, - /** Declaration reference. Creates a native declaration if omitted. */ - declaration?: VariableLikeDeclarationStatement); - /** Gets the associated type node.s */ - readonly typeNode: CommonTypeNode | null; - /** Gets the associated initializer node. */ - readonly initializerNode: Expression | null; - /** Applies a constant integer value to this element. */ - setConstantIntegerValue(value: I64, type: Type): void; - /** Applies a constant float value to this element. */ - setConstantFloatValue(value: f64, type: Type): void; - /** @override */ - lookup(name: string): Element | null; - } - /** An enum value. */ - export class EnumValue extends VariableLikeElement { - /** Constructs a new enum value. */ - constructor( - /** Simple name. */ - name: string, - /** Parent enum. */ - parent: Enum, - /** Declaration reference. */ - declaration: EnumValueDeclaration, - /** Pre-checked flags indicating built-in decorators. */ - decoratorFlags?: DecoratorFlags); - /** Whether this enum value is immutable. */ - isImmutable: bool; - /** Gets the associated value node. */ - readonly valueNode: Expression | null; - lookup(name: string): Element | null; - } - /** A global variable. */ - export class Global extends VariableLikeElement { - /** Constructs a new global variable. */ - constructor( - /** Simple name. */ - name: string, - /** Parent element, usually a file, namespace or static class. */ - parent: Element, - /** Pre-checked flags indicating built-in decorators. */ - decoratorFlags: DecoratorFlags, - /** Declaration reference. Creates a native declaration if omitted. */ - declaration?: VariableLikeDeclarationStatement); - } - /** A function parameter. */ - export class Parameter { - /** Parameter name. */ - name: string; - /** Parameter type. */ - type: Type; - /** Parameter initializer, if present. */ - initializer: Expression | null; - /** Constructs a new function parameter. */ - constructor( - /** Parameter name. */ - name: string, - /** Parameter type. */ - type: Type, - /** Parameter initializer, if present. */ - initializer?: Expression | null); - } - /** A local variable. */ - export class Local extends VariableLikeElement { - /** Zero-based index within the enclosing function. `-1` indicates a virtual local. */ - index: i32; - /** Constructs a new local variable. */ - constructor( - /** Simple name. */ - name: string, - /** Zero-based index within the enclosing function. `-1` indicates a virtual local. */ - index: i32, - /** Resolved type. */ - type: Type, - /** Parent function. */ - parent: Function, - /** Declaration reference. */ - declaration?: VariableLikeDeclarationStatement); - } - /** A yet unresolved function prototype. */ - export class FunctionPrototype extends DeclaredElement { - /** Operator kind, if an overload. */ - operatorKind: OperatorKind; - /** Already resolved instances. */ - instances: Map | null; - /** Clones of this prototype that are bounds to specific classes. */ - private boundPrototypes; - /** Constructs a new function prototype. */ - constructor( - /** Simple name */ - name: string, - /** Parent element, usually a file, namespace or class (if a method). */ - parent: Element, - /** Declaration reference. */ - declaration: FunctionDeclaration, - /** Pre-checked flags indicating built-in decorators. */ - decoratorFlags?: DecoratorFlags); - /** Gets the associated type parameter nodes. */ - readonly typeParameterNodes: TypeParameterNode[] | null; - /** Gets the associated signature node. */ - readonly signatureNode: SignatureNode; - /** Gets the associated body node. */ - readonly bodyNode: Statement | null; - /** Gets the arrow function kind. */ - readonly arrowKind: ArrowKind; - /** Tests if this prototype is bound to a class. */ - readonly isBound: bool; - /** Creates a clone of this prototype that is bound to a concrete class instead. */ - toBound(classInstance: Class): FunctionPrototype; - /** Gets the resolved instance for the specified instance key, if already resolved. */ - getResolvedInstance(instanceKey: string): Function | null; - /** Sets the resolved instance for the specified instance key. */ - setResolvedInstance(instanceKey: string, instance: Function): void; - lookup(name: string): Element | null; - } - /** A resolved function. */ - export class Function extends TypedElement { - /** Function prototype. */ - prototype: FunctionPrototype; - /** Function signature. */ - signature: Signature; - /** Map of locals by name. */ - localsByName: Map; - /** Array of locals by index. */ - localsByIndex: Local[]; - /** List of additional non-parameter locals. */ - additionalLocals: Type[]; - /** Contextual type arguments. */ - contextualTypeArguments: Map | null; - /** Default control flow. */ - flow: Flow; - /** Remembered debug locations. */ - debugLocations: Range[]; - /** Function reference, if compiled. */ - ref: FunctionRef; - /** Function table index, if any. */ - functionTableIndex: i32; - /** Trampoline function for calling with omitted arguments. */ - trampoline: Function | null; - /** Counting id of inline operations involving this function. */ - nextInlineId: i32; - /** Counting id of anonymous inner functions. */ - nextAnonymousId: i32; - /** Counting id of autorelease variables. */ - nextAutoreleaseId: i32; - /** Constructs a new concrete function. */ - constructor( - /** Name incl. type parameters, i.e. `foo`. */ - nameInclTypeParameters: string, - /** Respective function prototype. */ - prototype: FunctionPrototype, - /** Concrete signature. */ - signature: Signature, // pre-resolved - /** Contextual type arguments inherited from its parent class, if any. */ - contextualTypeArguments?: Map | null); - /** Adds a local of the specified type, with an optional name. */ - addLocal(type: Type, name?: string | null, declaration?: VariableDeclaration | null): Local; - lookup(name: string): Element | null; - tempI32s: Local[] | null; - tempI64s: Local[] | null; - tempF32s: Local[] | null; - tempF64s: Local[] | null; - tempV128s: Local[] | null; - nextBreakId: i32; - breakStack: i32[] | null; - breakLabel: string | null; - /** Finalizes the function once compiled, releasing no longer needed resources. */ - finalize(module: Module, ref: FunctionRef): void; - } - /** A resolved function target, that is a function called indirectly by an index and signature. */ - export class FunctionTarget extends Element { - /** Underlying signature. */ - signature: Signature; - /** Function type. */ - type: Type; - /** Constructs a new function target. */ - constructor( - /** Concrete signature. */ - signature: Signature, - /** Program reference. */ - program: Program, __s?: string); - lookup(name: string): Element | null; - } - /** A yet unresolved instance field prototype. */ - export class FieldPrototype extends DeclaredElement { - /** Constructs a new field prototype. */ - constructor( - /** Simple name. */ - name: string, - /** Parent class. */ - parent: ClassPrototype, - /** Declaration reference. */ - declaration: FieldDeclaration, - /** Pre-checked flags indicating built-in decorators. */ - decoratorFlags?: DecoratorFlags); - /** Gets the associated type node. */ - readonly typeNode: CommonTypeNode | null; - /** Gets the associated initializer node. */ - readonly initializerNode: Expression | null; - /** Gets the associated parameter index. Set if declared as a constructor parameter, otherwise `-1`. */ - readonly parameterIndex: i32; - lookup(name: string): Element | null; - } - /** A resolved instance field. */ - export class Field extends VariableLikeElement { - /** Field prototype reference. */ - prototype: FieldPrototype; - /** Field memory offset, if an instance field. */ - memoryOffset: i32; - /** Constructs a new field. */ - constructor( - /** Respective field prototype. */ - prototype: FieldPrototype, - /** Parent class. */ - parent: Class, - /** Concrete type. */ - type: Type); - } - /** A property comprised of a getter and a setter function. */ - export class PropertyPrototype extends DeclaredElement { - /** Getter prototype. */ - getterPrototype: FunctionPrototype | null; - /** Setter prototype. */ - setterPrototype: FunctionPrototype | null; - /** Constructs a new property prototype. */ - constructor( - /** Simple name. */ - name: string, - /** Parent class. */ - parent: ClassPrototype, - /** Declaration of the getter or setter introducing the property. */ - firstDeclaration: FunctionDeclaration); - lookup(name: string): Element | null; - } - /** A resolved property. */ - export class Property extends VariableLikeElement { - /** Prototype reference. */ - prototype: PropertyPrototype; - /** Getter instance. */ - getterInstance: Function | null; - /** Setter instance. */ - setterInstance: Function | null; - /** Constructs a new property prototype. */ - constructor( - /** Respective property prototype. */ - prototype: PropertyPrototype, - /** Parent element, usually a static class prototype or class instance. */ - parent: Element); - lookup(name: string): Element | null; - } - /** A yet unresolved class prototype. */ - export class ClassPrototype extends DeclaredElement { - /** Instance member prototypes. */ - instanceMembers: Map | null; - /** Base class prototype, if applicable. */ - basePrototype: ClassPrototype | null; - /** Constructor prototype. */ - constructorPrototype: FunctionPrototype | null; - /** Operator overload prototypes. */ - overloadPrototypes: Map; - /** Already resolved instances. */ - instances: Map | null; - constructor( - /** Simple name. */ - name: string, - /** Parent element, usually a file or namespace. */ - parent: Element, - /** Declaration reference. */ - declaration: ClassDeclaration, - /** Pre-checked flags indicating built-in decorators. */ - decoratorFlags?: DecoratorFlags, _isInterface?: bool); - /** Gets the associated type parameter nodes. */ - readonly typeParameterNodes: TypeParameterNode[] | null; - /** Gets the associated extends node. */ - readonly extendsNode: TypeNode | null; - /** Gets the associated implements nodes. */ - readonly implementsNodes: TypeNode[] | null; - /** Tests if this prototype is of a builtin array type (Array/TypedArray). */ - readonly isBuiltinArray: bool; - /** Tests if this prototype extends the specified. */ - extends(basePtototype: ClassPrototype | null): bool; - /** Adds an element as an instance member of this one. Returns the previous element if a duplicate. */ - addInstance(name: string, element: DeclaredElement): bool; - /** Gets the resolved instance for the specified instance key, if already resolved. */ - getResolvedInstance(instanceKey: string): Class | null; - /** Sets the resolved instance for the specified instance key. */ - setResolvedInstance(instanceKey: string, instance: Class): void; - lookup(name: string): Element | null; - } - /** A resolved class. */ - export class Class extends TypedElement { - /** Class prototype. */ - prototype: ClassPrototype; - /** Resolved type arguments. */ - typeArguments: Type[] | null; - /** Base class, if applicable. */ - base: Class | null; - /** Contextual type arguments for fields and methods. */ - contextualTypeArguments: Map | null; - /** Current member memory offset. */ - currentMemoryOffset: u32; - /** Constructor instance. */ - constructorInstance: Function | null; - /** Operator overloads. */ - overloads: Map | null; - /** Unique class id. */ - private _id; - /** Remembers acyclic state. */ - private _acyclic; - /** Runtime type information flags. */ - rttiFlags: u32; - /** Gets the unique runtime id of this class. */ - readonly id: u32; - /** Tests if this class is of a builtin array type (Array/TypedArray). */ - readonly isBuiltinArray: bool; - /** Tests if this class is array-like. */ - readonly isArrayLike: bool; - /** Constructs a new class. */ - constructor( - /** Name incl. type parameters, i.e. `Foo`. */ - nameInclTypeParameters: string, - /** The respective class prototype. */ - prototype: ClassPrototype, - /** Concrete type arguments, if any. */ - typeArguments?: Type[] | null, - /** Base class, if derived. */ - base?: Class | null, _isInterface?: bool); - /** Tests if a value of this class type is assignable to a target of the specified class type. */ - isAssignableTo(target: Class): bool; - /** Looks up the operator overload of the specified kind. */ - lookupOverload(kind: OperatorKind, unchecked?: bool): Function | null; - lookup(name: string): Element | null; - /** Calculates the memory offset of the specified field. */ - offsetof(fieldName: string): u32; - /** Writes a field value to a buffer and returns the number of bytes written. */ - writeField(name: string, value: T, buffer: Uint8Array, baseOffset: i32): i32; - /** Tests if this class extends the specified prototype. */ - extends(prototype: ClassPrototype): bool; - /** Gets the concrete type arguments to the specified extendend prototype. */ - getTypeArgumentsTo(extendedPrototype: ClassPrototype): Type[] | null; - /** Gets the value type of an array. Must be an array. */ - getArrayValueType(): Type; - /** Tests if this class is inherently acyclic. */ - readonly isAcyclic: bool; - /** Tests if this class potentially forms a reference cycle to another one. */ - private cyclesTo; - } - /** A yet unresolved interface. */ - export class InterfacePrototype extends ClassPrototype { - /** Constructs a new interface prototype. */ - constructor(name: string, parent: Element, declaration: InterfaceDeclaration, decoratorFlags: DecoratorFlags); - } - /** A resolved interface. */ - export class Interface extends Class { - /** Constructs a new interface. */ - constructor(nameInclTypeParameters: string, prototype: InterfacePrototype, typeArguments?: Type[], base?: Interface | null); - } - /** Mangles the internal name of an element with the specified name that is a child of the given parent. */ - export function mangleInternalName(name: string, parent: Element, isInstance: bool, asGlobal?: bool): string; - -} -declare module 'assemblyscript/src/compiler' { - /** - * The AssemblyScript compiler. - * @module compiler - */ /***/ - import { DiagnosticEmitter } from 'assemblyscript/src/diagnostics'; - import { Module, MemorySegment, ExpressionRef, NativeType, FunctionRef, FunctionTypeRef, GlobalRef } from 'assemblyscript/src/module'; - import { Feature, Target } from 'assemblyscript/src/common'; - import { Program, ClassPrototype, Class, Element, Enum, Field, FunctionPrototype, Function, Global, VariableLikeElement, File } from 'assemblyscript/src/program'; - import { Flow } from 'assemblyscript/src/flow'; - import { Resolver } from 'assemblyscript/src/resolver'; - import { Node, TypeNode, Range, Statement, BlockStatement, BreakStatement, ContinueStatement, DoStatement, EmptyStatement, ExpressionStatement, ForStatement, IfStatement, InstanceOfExpression, InterfaceDeclaration, ReturnStatement, SwitchStatement, ThrowStatement, TryStatement, VariableStatement, VoidStatement, WhileStatement, Expression, AssertionExpression, BinaryExpression, CallExpression, CommaExpression, ElementAccessExpression, FunctionExpression, IdentifierExpression, LiteralExpression, NewExpression, ObjectLiteralExpression, PropertyAccessExpression, TernaryExpression, StringLiteralExpression, UnaryPostfixExpression, UnaryPrefixExpression } from 'assemblyscript/src/ast'; - import { Type, Signature } from 'assemblyscript/src/types'; - /** Compiler options. */ - export class Options { - /** WebAssembly target. Defaults to {@link Target.WASM32}. */ - target: Target; - /** If true, replaces assertions with nops. */ - noAssert: bool; - /** If true, imports the memory provided by the embedder. */ - importMemory: bool; - /** If greater than zero, declare memory as shared by setting max memory to sharedMemory. */ - sharedMemory: i32; - /** If true, imports the function table provided by the embedder. */ - importTable: bool; - /** If true, generates information necessary for source maps. */ - sourceMap: bool; - /** If true, generates an explicit start function. */ - explicitStart: bool; - /** Static memory start offset. */ - memoryBase: i32; - /** Global aliases. */ - globalAliases: Map | null; - /** Additional features to activate. */ - features: Feature; - /** Hinted optimize level. Not applied by the compiler itself. */ - optimizeLevelHint: i32; - /** Hinted shrink level. Not applied by the compiler itself. */ - shrinkLevelHint: i32; - /** Tests if the target is WASM64 or, otherwise, WASM32. */ - readonly isWasm64: bool; - /** Gets the unsigned size type matching the target. */ - readonly usizeType: Type; - /** Gets the signed size type matching the target. */ - readonly isizeType: Type; - /** Gets the native size type matching the target. */ - readonly nativeSizeType: NativeType; - /** Tests if a specific feature is activated. */ - hasFeature(feature: Feature): bool; - } - /** Various constraints in expression compilation. */ - export const enum Constraints { - NONE = 0, - /** Must implicitly convert to the target type. */ - CONV_IMPLICIT = 1, - /** Must explicitly convert to the target type. */ - CONV_EXPLICIT = 2, - /** Must wrap small integer values to match the target type. */ - MUST_WRAP = 4, - /** Indicates that the value will be dropped immediately. */ - WILL_DROP = 8, - /** Indicates that the value will be retained immediately. */ - WILL_RETAIN = 16, - /** Indicates that static data is preferred. */ - PREFER_STATIC = 32 - } - /** Runtime features to be activated by the compiler. */ - export const enum RuntimeFeatures { - NONE = 0, - /** Requires heap setup. */ - HEAP = 1, - /** Requires runtime type information setup. */ - RTTI = 2, - /** Requires the built-in globals visitor. */ - visitGlobals = 4, - /** Requires the built-in members visitor. */ - visitMembers = 8 - } - /** Compiler interface. */ - export class Compiler extends DiagnosticEmitter { - /** Program reference. */ - program: Program; - /** Resolver reference. */ - resolver: Resolver; - /** Provided options. */ - options: Options; - /** Module instance being compiled. */ - module: Module; - /** Current control flow. */ - currentFlow: Flow; - /** Current inline functions stack. */ - currentInlineFunctions: Function[]; - /** Current enum in compilation. */ - currentEnum: Enum | null; - /** Current type in compilation. */ - currentType: Type; - /** Start function statements. */ - currentBody: ExpressionRef[]; - /** Counting memory offset. */ - memoryOffset: I64; - /** Memory segments being compiled. */ - memorySegments: MemorySegment[]; - /** Map of already compiled static string segments. */ - stringSegments: Map; - /** Function table being compiled. */ - functionTable: string[]; - /** Argument count helper global. */ - argcVar: GlobalRef; - /** Argument count helper setter. */ - argcSet: FunctionRef; - /** Requires runtime features. */ - runtimeFeatures: RuntimeFeatures; - /** Expressions known to have skipped an autorelease. Usually function returns. */ - skippedAutoreleases: Set; - /** Compiles a {@link Program} to a {@link Module} using the specified options. */ - static compile(program: Program, options?: Options | null): Module; - /** Constructs a new compiler for a {@link Program} using the specified options. */ - constructor(program: Program, options?: Options | null); - /** Performs compilation of the underlying {@link Program} to a {@link Module}. */ - compile(): Module; - /** Applies the respective module exports for the specified file. */ - private ensureModuleExports; - /** Applies the respective module export(s) for the specified element. */ - private ensureModuleExport; - /** Makes a function to get the value of a field of an exported class. */ - private ensureModuleFieldGetter; - /** Makes a function to set the value of a field of an exported class. */ - private ensureModuleFieldSetter; - /** Compiles any element. */ - compileElement(element: Element, compileMembers?: bool): void; - /** Compiles an element's members. */ - compileMembers(element: Element): void; - /** Compiles a file's exports. */ - compileExports(file: File): void; - /** Compiles the file matching the specified path. */ - compileFileByPath(normalizedPathWithoutExtension: string, reportNode: Node): void; - /** Compiles the specified file. */ - compileFile(file: File): void; - compileGlobal(global: Global): bool; - compileEnum(element: Enum): bool; - /** Resolves the specified type arguments prior to compiling the resulting function instance. */ - compileFunctionUsingTypeArguments(prototype: FunctionPrototype, typeArguments: TypeNode[], contextualTypeArguments?: Map, alternativeReportNode?: Node | null): Function | null; - /** Either reuses or creates the function type matching the specified signature. */ - ensureFunctionType(parameterTypes: Type[] | null, returnType: Type, thisType?: Type | null): FunctionTypeRef; - /** Compiles the body of a function within the specified flow. */ - compileFunctionBody( - /** Function to compile. */ - instance: Function, - /** Target array of statements. */ - stmts?: ExpressionRef[] | null): ExpressionRef[]; - /** Compiles a readily resolved function instance. */ - compileFunction(instance: Function): bool; - compileClassUsingTypeArguments(prototype: ClassPrototype, typeArguments: TypeNode[], contextualTypeArguments?: Map, alternativeReportNode?: Node | null): void; - compileClass(instance: Class): bool; - compileInterfaceDeclaration(declaration: InterfaceDeclaration, typeArguments: TypeNode[], contextualTypeArguments?: Map | null, alternativeReportNode?: Node | null): void; - /** Adds a static memory segment with the specified data. */ - addMemorySegment(buffer: Uint8Array, alignment?: i32): MemorySegment; - /** Ensures that the specified string exists in static memory and returns a pointer to it. */ - ensureStaticString(stringValue: string): ExpressionRef; - ensureStaticArrayBuffer(elementType: Type, values: ExpressionRef[]): MemorySegment; - ensureStaticArrayHeader(elementType: Type, bufferSegment: MemorySegment): MemorySegment; - /** Ensures that a table entry exists for the specified function and returns its index. */ - ensureFunctionTableEntry(func: Function): i32; - compileTopLevelStatement(statement: Statement, body: ExpressionRef[]): void; - compileStatement(statement: Statement, isLastInBody?: bool): ExpressionRef; - compileStatements(statements: Statement[], isBody?: bool, stmts?: ExpressionRef[] | null): ExpressionRef[]; - compileBlockStatement(statement: BlockStatement): ExpressionRef; - compileBreakStatement(statement: BreakStatement): ExpressionRef; - compileContinueStatement(statement: ContinueStatement): ExpressionRef; - compileDoStatement(statement: DoStatement): ExpressionRef; - compileEmptyStatement(statement: EmptyStatement): ExpressionRef; - compileExpressionStatement(statement: ExpressionStatement): ExpressionRef; - compileForStatement(statement: ForStatement): ExpressionRef; - compileIfStatement(statement: IfStatement): ExpressionRef; - compileReturnStatement(statement: ReturnStatement, isLastInBody: bool): ExpressionRef; - compileSwitchStatement(statement: SwitchStatement): ExpressionRef; - compileThrowStatement(statement: ThrowStatement): ExpressionRef; - compileTryStatement(statement: TryStatement): ExpressionRef; - /** Compiles a variable statement. Returns `0` if an initializer is not necessary. */ - compileVariableStatement(statement: VariableStatement): ExpressionRef; - compileVoidStatement(statement: VoidStatement): ExpressionRef; - compileWhileStatement(statement: WhileStatement): ExpressionRef; - /** Compiles the value of an inlined constant element. */ - compileInlineConstant(element: VariableLikeElement, contextualType: Type, constraints: Constraints): ExpressionRef; - compileExpression(expression: Expression, contextualType: Type, constraints?: Constraints): ExpressionRef; - /** Compiles and precomputes an expression, possibly yielding a costant value. */ - precomputeExpression(expression: Expression, contextualType: Type, constraints?: Constraints): ExpressionRef; - convertExpression(expr: ExpressionRef, - /** Original type. */ - fromType: Type, - /** New type. */ - toType: Type, - /** Whether the conversion is explicit.*/ - explicit: bool, - /** Whether the result should be wrapped, if a small integer. */ - wrap: bool, reportNode: Node): ExpressionRef; - compileAssertionExpression(expression: AssertionExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - private f32ModInstance; - private f64ModInstance; - private f32PowInstance; - private f64PowInstance; - compileBinaryExpression(expression: BinaryExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - compileUnaryOverload(operatorInstance: Function, value: Expression, valueExpr: ExpressionRef, reportNode: Node): ExpressionRef; - compileBinaryOverload(operatorInstance: Function, left: Expression, leftExpr: ExpressionRef, right: Expression, reportNode: Node): ExpressionRef; - compileAssignment(expression: Expression, valueExpression: Expression, contextualType: Type): ExpressionRef; - /** Makes an assignment expression or block, assigning a value to a target. */ - makeAssignment( - /** Target element, e.g. a Local. */ - target: Element, - /** Value expression that has been compiled in a previous step already. */ - valueExpr: ExpressionRef, - /** Expression reference. Has already been compiled to `valueExpr`. */ - valueExpression: Expression, - /** `this` expression reference if a field or property set. */ - thisExpression: Expression | null, - /** Index expression reference if an indexed set. */ - indexExpression: Expression | null, - /** Whether to tee the value. */ - tee: bool): ExpressionRef; - /** Makes an assignment to a local, possibly retaining and releasing affected references and keeping track of wrap and null states. */ - private makeLocalAssignment; - /** Makes an assignment to a global, possibly retaining and releasing affected references. */ - private makeGlobalAssignment; - /** Makes an assignment to a field, possibly retaining and releasing affected references. */ - makeFieldAssignment( - /** The field to assign to. */ - field: Field, - /** The value to assign. */ - valueExpr: ExpressionRef, - /** The value of `this`. */ - thisExpr: ExpressionRef, - /** Whether to tee the value. */ - tee: bool): ExpressionRef; - /** Compiles a call expression according to the specified context. */ - compileCallExpression( - /** Call expression to compile. */ - expression: CallExpression, - /** Contextual type indicating the return type the caller expects, if any. */ - contextualType: Type, - /** Constraints indicating contextual conditions. */ - constraints: Constraints): ExpressionRef; - private compileCallExpressionBuiltin; - /** - * Checks that a call with the given number as arguments can be performed according to the - * specified signature. - */ - checkCallSignature(signature: Signature, numArguments: i32, hasThis: bool, reportNode: Node): bool; - /** Compiles a direct call to a concrete function. */ - compileCallDirect(instance: Function, argumentExpressions: Expression[], reportNode: Node, thisArg?: ExpressionRef, constraints?: Constraints): ExpressionRef; - makeCallInline(instance: Function, operands: ExpressionRef[] | null, thisArg?: ExpressionRef, immediatelyDropped?: bool): ExpressionRef; - /** Gets the trampoline for the specified function. */ - ensureTrampoline(original: Function): Function; - /** Makes sure that the argument count helper global is present and returns its name. */ - private ensureArgcVar; - /** Makes sure that the argument count helper setter is present and returns its name. */ - private ensureArgcSet; - /** Makes retain call, retaining the expression's value. */ - makeRetain(expr: ExpressionRef): ExpressionRef; - /** Makes a retainRelease call, retaining the new expression's value and releasing the old expression's value, in this order. */ - makeRetainRelease(oldExpr: ExpressionRef, newExpr: ExpressionRef): ExpressionRef; - /** Makes a skippedRelease call, ignoring the new expression's value and releasing the old expression's value, in this order. */ - makeSkippedRelease(oldExpr: ExpressionRef, newExpr: ExpressionRef): ExpressionRef; - /** Makes a release call, releasing the expression's value. Changes the current type to void.*/ - makeRelease(expr: ExpressionRef): ExpressionRef; - /** Makes an automatic release call at the end of the current flow. */ - makeAutorelease(expr: ExpressionRef, flow?: Flow): ExpressionRef; - /** Attempts to undo a final autorelease, returning the index of the previously retaining variable or -1 if not possible. */ - undoAutorelease(expr: ExpressionRef, flow: Flow): i32; - /** - * Attemps to move a final autorelease from one flow to a parent. - * It is crucial that from flow hasn't processed autoreleases yet because otherwise the final - * retain would have been written already. - */ - moveAutorelease(expr: ExpressionRef, fromInnerFlow: Flow, toOuterFlow: Flow): ExpressionRef; - /** Performs any queued autoreleases in the specified flow. */ - performAutoreleases(flow: Flow, stmts: ExpressionRef[], clearFlags?: bool): void; - /** Performs any queued autoreleases in the specified flow and returns the value. */ - performAutoreleasesWithValue(flow: Flow, valueExpr: ExpressionRef, valueType: Type, stmts?: ExpressionRef[] | null, clearFlags?: bool): ExpressionRef; - /** Finishes any queued top-level autoreleases in the actual function of the specified flow. */ - finishAutoreleases(flow: Flow, stmts: ExpressionRef[]): void; - /** Creates a direct call to the specified function. */ - makeCallDirect(instance: Function, operands: ExpressionRef[] | null, reportNode: Node, immediatelyDropped?: bool, - /** Skip the usual autorelease and manage this at the callsite instead. */ - skipAutorelease?: bool): ExpressionRef; - /** Compiles an indirect call using an index argument and a signature. */ - compileCallIndirect(signature: Signature, indexArg: ExpressionRef, argumentExpressions: Expression[], reportNode: Node, thisArg?: ExpressionRef, immediatelyDropped?: bool): ExpressionRef; - /** Creates an indirect call to the function at `indexArg` in the function table. */ - makeCallIndirect(signature: Signature, indexArg: ExpressionRef, operands?: ExpressionRef[] | null, immediatelyDropped?: bool): ExpressionRef; - compileCommaExpression(expression: CommaExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - compileElementAccessExpression(expression: ElementAccessExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - compileFunctionExpression(expression: FunctionExpression, contextualSignature: Signature | null, constraints: Constraints): ExpressionRef; - /** Makes sure the enclosing source file of the specified expression has been compiled. */ - private maybeCompileEnclosingSource; - /** - * Compiles an identifier in the specified context. - * @param retainConstantType Retains the type of inlined constants if `true`, otherwise - * precomputes them according to context. - */ - compileIdentifierExpression(expression: IdentifierExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - compileInstanceOfExpression(expression: InstanceOfExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - compileLiteralExpression(expression: LiteralExpression, contextualType: Type, constraints: Constraints, implicitlyNegate?: bool): ExpressionRef; - compileStringLiteral(expression: StringLiteralExpression): ExpressionRef; - compileArrayLiteral(elementType: Type, expressions: (Expression | null)[], constraints: Constraints, reportNode: Node): ExpressionRef; - compileObjectLiteral(expression: ObjectLiteralExpression, contextualType: Type): ExpressionRef; - compileNewExpression(expression: NewExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - /** Gets the compiled constructor of the specified class or generates one if none is present. */ - ensureConstructor(classInstance: Class, reportNode: Node): Function; - compileInstantiate( - /** Class to instantiate. */ - classInstance: Class, - /** Constructor arguments. */ - argumentExpressions: Expression[], - /** Contextual flags. */ - constraints: Constraints, - /** Node to report on. */ - reportNode: Node): ExpressionRef; - /** - * Compiles a property access in the specified context. - * @param retainConstantType Retains the type of inlined constants if `true`, otherwise - * precomputes them according to context. - */ - compilePropertyAccessExpression(propertyAccess: PropertyAccessExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - compileTernaryExpression(expression: TernaryExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - compileUnaryPostfixExpression(expression: UnaryPostfixExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - compileUnaryPrefixExpression(expression: UnaryPrefixExpression, contextualType: Type, constraints: Constraints): ExpressionRef; - /** Makes sure that a 32-bit integer value is wrapped to a valid value of the specified type. */ - ensureSmallIntegerWrap(expr: ExpressionRef, type: Type): ExpressionRef; - /** Adds the debug location of the specified expression at the specified range to the source map. */ - addDebugLocation(expr: ExpressionRef, range: Range): void; - /** Creates a comparison whether an expression is 'false' in a broader sense. */ - makeIsFalseish(expr: ExpressionRef, type: Type): ExpressionRef; - /** Creates a comparison whether an expression is 'true' in a broader sense. */ - makeIsTrueish(expr: ExpressionRef, type: Type): ExpressionRef; - /** Makes an allocation suitable to hold the data of an instance of the given class. */ - makeAllocation(classInstance: Class): ExpressionRef; - /** Makes the initializers for a class's fields. */ - makeFieldInitialization(classInstance: Class, stmts?: ExpressionRef[]): ExpressionRef[]; - makeInstanceOfClass(expr: ExpressionRef, classInstance: Class): ExpressionRef; - } - /** Flattens a series of expressions to a nop, a single statement or a block depending on statement count. */ - export function flatten(module: Module, stmts: ExpressionRef[], type: NativeType): ExpressionRef; - -} -declare module 'assemblyscript/src/builtins' { - /** - * Built-in elements providing WebAssembly core functionality. - * @module builtins - */ /***/ - import { Compiler } from 'assemblyscript/src/compiler'; - import { Node, Expression, CallExpression } from 'assemblyscript/src/ast'; - import { Type } from 'assemblyscript/src/types'; - import { ExpressionRef } from 'assemblyscript/src/module'; - import { FunctionPrototype } from 'assemblyscript/src/program'; - /** Symbols of various compiler built-ins. */ - export namespace BuiltinSymbols { - const isInteger = "~lib/builtins/isInteger"; - const isFloat = "~lib/builtins/isFloat"; - const isBoolean = "~lib/builtins/isBoolean"; - const isSigned = "~lib/builtins/isSigned"; - const isReference = "~lib/builtins/isReference"; - const isString = "~lib/builtins/isString"; - const isArray = "~lib/builtins/isArray"; - const isArrayLike = "~lib/builtins/isArrayLike"; - const isFunction = "~lib/builtins/isFunction"; - const isNullable = "~lib/builtins/isNullable"; - const isDefined = "~lib/builtins/isDefined"; - const isConstant = "~lib/builtins/isConstant"; - const isManaged = "~lib/builtins/isManaged"; - const clz = "~lib/builtins/clz"; - const ctz = "~lib/builtins/ctz"; - const popcnt = "~lib/builtins/popcnt"; - const rotl = "~lib/builtins/rotl"; - const rotr = "~lib/builtins/rotr"; - const abs = "~lib/builtins/abs"; - const max = "~lib/builtins/max"; - const min = "~lib/builtins/min"; - const ceil = "~lib/builtins/ceil"; - const floor = "~lib/builtins/floor"; - const copysign = "~lib/builtins/copysign"; - const nearest = "~lib/builtins/nearest"; - const reinterpret = "~lib/builtins/reinterpret"; - const sqrt = "~lib/builtins/sqrt"; - const trunc = "~lib/builtins/trunc"; - const load = "~lib/builtins/load"; - const store = "~lib/builtins/store"; - const atomic_load = "~lib/builtins/atomic.load"; - const atomic_store = "~lib/builtins/atomic.store"; - const atomic_add = "~lib/builtins/atomic.add"; - const atomic_sub = "~lib/builtins/atomic.sub"; - const atomic_and = "~lib/builtins/atomic.and"; - const atomic_or = "~lib/builtins/atomic.or"; - const atomic_xor = "~lib/builtins/atomic.xor"; - const atomic_xchg = "~lib/builtins/atomic.xchg"; - const atomic_cmpxchg = "~lib/builtins/atomic.cmpxchg"; - const atomic_wait = "~lib/builtins/atomic.wait"; - const atomic_notify = "~lib/builtins/atomic.notify"; - const sizeof = "~lib/builtins/sizeof"; - const alignof = "~lib/builtins/alignof"; - const offsetof = "~lib/builtins/offsetof"; - const select = "~lib/builtins/select"; - const unreachable = "~lib/builtins/unreachable"; - const changetype = "~lib/builtins/changetype"; - const assert = "~lib/builtins/assert"; - const unchecked = "~lib/builtins/unchecked"; - const call_direct = "~lib/builtins/call_direct"; - const call_indirect = "~lib/builtins/call_indirect"; - const instantiate = "~lib/builtins/instantiate"; - const idof = "~lib/builtins/idof"; - const i8 = "~lib/builtins/i8"; - const i16 = "~lib/builtins/i16"; - const i32 = "~lib/builtins/i32"; - const i64 = "~lib/builtins/i64"; - const isize = "~lib/builtins/isize"; - const u8 = "~lib/builtins/u8"; - const u16 = "~lib/builtins/u16"; - const u32 = "~lib/builtins/u32"; - const u64 = "~lib/builtins/u64"; - const usize = "~lib/builtins/usize"; - const bool = "~lib/builtins/bool"; - const f32 = "~lib/builtins/f32"; - const f64 = "~lib/builtins/f64"; - const v128 = "~lib/builtins/v128"; - const void_ = "~lib/builtins/void"; - const i32_clz = "~lib/builtins/i32.clz"; - const i64_clz = "~lib/builtins/i64.clz"; - const i32_ctz = "~lib/builtins/i32.ctz"; - const i64_ctz = "~lib/builtins/i64.ctz"; - const i32_popcnt = "~lib/builtins/i32.popcnt"; - const i64_popcnt = "~lib/builtins/i64.popcnt"; - const i32_rotl = "~lib/builtins/i32.rotl"; - const i64_rotl = "~lib/builtins/i64.rotl"; - const i32_rotr = "~lib/builtins/i32.rotr"; - const i64_rotr = "~lib/builtins/i64.rotr"; - const f32_abs = "~lib/builtins/f32.abs"; - const f64_abs = "~lib/builtins/f64.abs"; - const f32_max = "~lib/builtins/f32.max"; - const f64_max = "~lib/builtins/f64.max"; - const f32_min = "~lib/builtins/f32.min"; - const f64_min = "~lib/builtins/f64.min"; - const f32_ceil = "~lib/builtins/f32.ceil"; - const f64_ceil = "~lib/builtins/f64.ceil"; - const f32_floor = "~lib/builtins/f32.floor"; - const f64_floor = "~lib/builtins/f64.floor"; - const f32_copysign = "~lib/builtins/f32.copysign"; - const f64_copysign = "~lib/builtins/f64.copysign"; - const f32_nearest = "~lib/builtins/f32.nearest"; - const f64_nearest = "~lib/builtins/f64.nearest"; - const i32_reinterpret_f32 = "~lib/builtins/i32.reinterpret_f32"; - const i64_reinterpret_f64 = "~lib/builtins/i64.reinterpret_f64"; - const f32_reinterpret_i32 = "~lib/builtins/f32.reinterpret_i32"; - const f64_reinterpret_i64 = "~lib/builtins/f64.reinterpret_i64"; - const f32_sqrt = "~lib/builtins/f32.sqrt"; - const f64_sqrt = "~lib/builtins/f64.sqrt"; - const f32_trunc = "~lib/builtins/f32.trunc"; - const f64_trunc = "~lib/builtins/f64.trunc"; - const i32_load8_s = "~lib/builtins/i32.load8_s"; - const i32_load8_u = "~lib/builtins/i32.load8_u"; - const i32_load16_s = "~lib/builtins/i32.load16_s"; - const i32_load16_u = "~lib/builtins/i32.load16_u"; - const i32_load = "~lib/builtins/i32.load"; - const i64_load8_s = "~lib/builtins/i64.load8_s"; - const i64_load8_u = "~lib/builtins/i64.load8_u"; - const i64_load16_s = "~lib/builtins/i64.load16_s"; - const i64_load16_u = "~lib/builtins/i64.load16_u"; - const i64_load32_s = "~lib/builtins/i64.load32_s"; - const i64_load32_u = "~lib/builtins/i64.load32_u"; - const i64_load = "~lib/builtins/i64.load"; - const f32_load = "~lib/builtins/f32.load"; - const f64_load = "~lib/builtins/f64.load"; - const i32_store8 = "~lib/builtins/i32.store8"; - const i32_store16 = "~lib/builtins/i32.store16"; - const i32_store = "~lib/builtins/i32.store"; - const i64_store8 = "~lib/builtins/i64.store8"; - const i64_store16 = "~lib/builtins/i64.store16"; - const i64_store32 = "~lib/builtins/i64.store32"; - const i64_store = "~lib/builtins/i64.store"; - const f32_store = "~lib/builtins/f32.store"; - const f64_store = "~lib/builtins/f64.store"; - const i32_atomic_load8_u = "~lib/builtins/i32.atomic.load8_u"; - const i32_atomic_load16_u = "~lib/builtins/i32.atomic.load16_u"; - const i32_atomic_load = "~lib/builtins/i32.atomic.load"; - const i64_atomic_load8_u = "~lib/builtins/i64.atomic.load8_u"; - const i64_atomic_load16_u = "~lib/builtins/i64.atomic.load16_u"; - const i64_atomic_load32_u = "~lib/builtins/i64.atomic.load32_u"; - const i64_atomic_load = "~lib/builtins/i64.atomic.load"; - const i32_atomic_store8 = "~lib/builtins/i32.atomic.store8"; - const i32_atomic_store16 = "~lib/builtins/i32.atomic.store16"; - const i32_atomic_store = "~lib/builtins/i32.atomic.store"; - const i64_atomic_store8 = "~lib/builtins/i64.atomic.store8"; - const i64_atomic_store16 = "~lib/builtins/i64.atomic.store16"; - const i64_atomic_store32 = "~lib/builtins/i64.atomic.store32"; - const i64_atomic_store = "~lib/builtins/i64.atomic.store"; - const i32_atomic_rmw8_add_u = "~lib/builtins/i32.atomic.rmw8.add_u"; - const i32_atomic_rmw16_add_u = "~lib/builtins/i32.atomic.rmw16.add_u"; - const i32_atomic_rmw_add = "~lib/builtins/i32.atomic.rmw.add"; - const i64_atomic_rmw8_add_u = "~lib/builtins/i64.atomic.rmw8.add_u"; - const i64_atomic_rmw16_add_u = "~lib/builtins/i64.atomic.rmw16.add_u"; - const i64_atomic_rmw32_add_u = "~lib/builtins/i64.atomic.rmw32.add_u"; - const i64_atomic_rmw_add = "~lib/builtins/i64.atomic.rmw.add"; - const i32_atomic_rmw8_sub_u = "~lib/builtins/i32.atomic.rmw8.sub_u"; - const i32_atomic_rmw16_sub_u = "~lib/builtins/i32.atomic.rmw16.sub_u"; - const i32_atomic_rmw_sub = "~lib/builtins/i32.atomic.rmw.sub"; - const i64_atomic_rmw8_sub_u = "~lib/builtins/i64.atomic.rmw8.sub_u"; - const i64_atomic_rmw16_sub_u = "~lib/builtins/i64.atomic.rmw16.sub_u"; - const i64_atomic_rmw32_sub_u = "~lib/builtins/i64.atomic.rmw32.sub_u"; - const i64_atomic_rmw_sub = "~lib/builtins/i64.atomic.rmw.sub"; - const i32_atomic_rmw8_and_u = "~lib/builtins/i32.atomic.rmw8.and_u"; - const i32_atomic_rmw16_and_u = "~lib/builtins/i32.atomic.rmw16.and_u"; - const i32_atomic_rmw_and = "~lib/builtins/i32.atomic.rmw.and"; - const i64_atomic_rmw8_and_u = "~lib/builtins/i64.atomic.rmw8.and_u"; - const i64_atomic_rmw16_and_u = "~lib/builtins/i64.atomic.rmw16.and_u"; - const i64_atomic_rmw32_and_u = "~lib/builtins/i64.atomic.rmw32.and_u"; - const i64_atomic_rmw_and = "~lib/builtins/i64.atomic.rmw.and"; - const i32_atomic_rmw8_or_u = "~lib/builtins/i32.atomic.rmw8.or_u"; - const i32_atomic_rmw16_or_u = "~lib/builtins/i32.atomic.rmw16.or_u"; - const i32_atomic_rmw_or = "~lib/builtins/i32.atomic.rmw.or"; - const i64_atomic_rmw8_or_u = "~lib/builtins/i64.atomic.rmw8.or_u"; - const i64_atomic_rmw16_or_u = "~lib/builtins/i64.atomic.rmw16.or_u"; - const i64_atomic_rmw32_or_u = "~lib/builtins/i64.atomic.rmw32.or_u"; - const i64_atomic_rmw_or = "~lib/builtins/i64.atomic.rmw.or"; - const i32_atomic_rmw8_u_xor = "~lib/builtins/i32.atomic.rmw8.xor_u"; - const i32_atomic_rmw16_u_xor = "~lib/builtins/i32.atomic.rmw16.xor_u"; - const i32_atomic_rmw_xor = "~lib/builtins/i32.atomic.rmw.xor"; - const i64_atomic_rmw8_xor_u = "~lib/builtins/i64.atomic.rmw8.xor_u"; - const i64_atomic_rmw16_xor_u = "~lib/builtins/i64.atomic.rmw16.xor_u"; - const i64_atomic_rmw32_xor_u = "~lib/builtins/i64.atomic.rmw32.xor_u"; - const i64_atomic_rmw_xor = "~lib/builtins/i64.atomic.rmw.xor"; - const i32_atomic_rmw8_xchg_u = "~lib/builtins/i32.atomic.rmw8.xchg_u"; - const i32_atomic_rmw16_xchg_u = "~lib/builtins/i32.atomic.rmw16.xchg_u"; - const i32_atomic_rmw_xchg = "~lib/builtins/i32.atomic.rmw.xchg"; - const i64_atomic_rmw8_xchg_u = "~lib/builtins/i64.atomic.rmw8.xchg_u"; - const i64_atomic_rmw16_xchg_u = "~lib/builtins/i64.atomic.rmw16.xchg_u"; - const i64_atomic_rmw32_xchg_u = "~lib/builtins/i64.atomic.rmw32.xchg_u"; - const i64_atomic_rmw_xchg = "~lib/builtins/i64.atomic.rmw.xchg"; - const i32_atomic_rmw8_cmpxchg_u = "~lib/builtins/i32.atomic.rmw8.cmpxchg_u"; - const i32_atomic_rmw16_cmpxchg_u = "~lib/builtins/i32.atomic.rmw16.cmpxchg_u"; - const i32_atomic_rmw_cmpxchg = "~lib/builtins/i32.atomic.rmw.cmpxchg"; - const i64_atomic_rmw8_cmpxchg_u = "~lib/builtins/i64.atomic.rmw8.cmpxchg_u"; - const i64_atomic_rmw16_cmpxchg_u = "~lib/builtins/i64.atomic.rmw16.cmpxchg_u"; - const i64_atomic_rmw32_cmpxchg_u = "~lib/builtins/i64.atomic.rmw32.cmpxchg_u"; - const i64_atomic_rmw_cmpxchg = "~lib/builtins/i64.atomic.rmw.cmpxchg"; - const i32_wait = "~lib/builtins/i32.wait"; - const i64_wait = "~lib/builtins/i64.wait"; - const v128_splat = "~lib/builtins/v128.splat"; - const v128_extract_lane = "~lib/builtins/v128.extract_lane"; - const v128_replace_lane = "~lib/builtins/v128.replace_lane"; - const v128_shuffle = "~lib/builtins/v128.shuffle"; - const v128_load = "~lib/builtins/v128.load"; - const v128_store = "~lib/builtins/v128.store"; - const v128_add = "~lib/builtins/v128.add"; - const v128_sub = "~lib/builtins/v128.sub"; - const v128_mul = "~lib/builtins/v128.mul"; - const v128_div = "~lib/builtins/v128.div"; - const v128_neg = "~lib/builtins/v128.neg"; - const v128_add_saturate = "~lib/builtins/v128.add_saturate"; - const v128_sub_saturate = "~lib/builtins/v128.sub_saturate"; - const v128_shl = "~lib/builtins/v128.shl"; - const v128_shr = "~lib/builtins/v128.shr"; - const v128_and = "~lib/builtins/v128.and"; - const v128_or = "~lib/builtins/v128.or"; - const v128_xor = "~lib/builtins/v128.xor"; - const v128_not = "~lib/builtins/v128.not"; - const v128_bitselect = "~lib/builtins/v128.bitselect"; - const v128_any_true = "~lib/builtins/v128.any_true"; - const v128_all_true = "~lib/builtins/v128.all_true"; - const v128_min = "~lib/builtins/v128.min"; - const v128_max = "~lib/builtins/v128.max"; - const v128_abs = "~lib/builtins/v128.abs"; - const v128_sqrt = "~lib/builtins/v128.sqrt"; - const v128_eq = "~lib/builtins/v128.eq"; - const v128_ne = "~lib/builtins/v128.ne"; - const v128_lt = "~lib/builtins/v128.lt"; - const v128_le = "~lib/builtins/v128.le"; - const v128_gt = "~lib/builtins/v128.gt"; - const v128_ge = "~lib/builtins/v128.ge"; - const v128_convert = "~lib/builtins/v128.convert"; - const v128_trunc = "~lib/builtins/v128.trunc"; - const i8x16 = "~lib/builtins/i8x16"; - const i16x8 = "~lib/builtins/i16x8"; - const i32x4 = "~lib/builtins/i32x4"; - const i64x2 = "~lib/builtins/i64x2"; - const f32x4 = "~lib/builtins/f32x4"; - const f64x2 = "~lib/builtins/f64x2"; - const i8x16_splat = "~lib/builtins/i8x16.splat"; - const i8x16_extract_lane_s = "~lib/builtins/i8x16.extract_lane_s"; - const i8x16_extract_lane_u = "~lib/builtins/i8x16.extract_lane_u"; - const i8x16_replace_lane = "~lib/builtins/i8x16.replace_lane"; - const i8x16_add = "~lib/builtins/i8x16.add"; - const i8x16_sub = "~lib/builtins/i8x16.sub"; - const i8x16_mul = "~lib/builtins/i8x16.mul"; - const i8x16_neg = "~lib/builtins/i8x16.neg"; - const i8x16_add_saturate_s = "~lib/builtins/i8x16.add_saturate_s"; - const i8x16_add_saturate_u = "~lib/builtins/i8x16.add_saturate_u"; - const i8x16_sub_saturate_s = "~lib/builtins/i8x16.sub_saturate_s"; - const i8x16_sub_saturate_u = "~lib/builtins/i8x16.sub_saturate_u"; - const i8x16_shl = "~lib/builtins/i8x16.shl"; - const i8x16_shr_s = "~lib/builtins/i8x16.shr_s"; - const i8x16_shr_u = "~lib/builtins/i8x16.shr_u"; - const i8x16_any_true = "~lib/builtins/i8x16.any_true"; - const i8x16_all_true = "~lib/builtins/i8x16.all_true"; - const i8x16_eq = "~lib/builtins/i8x16.eq"; - const i8x16_ne = "~lib/builtins/i8x16.ne"; - const i8x16_lt_s = "~lib/builtins/i8x16.lt_s"; - const i8x16_lt_u = "~lib/builtins/i8x16.lt_u"; - const i8x16_le_s = "~lib/builtins/i8x16.le_s"; - const i8x16_le_u = "~lib/builtins/i8x16.le_u"; - const i8x16_gt_s = "~lib/builtins/i8x16.gt_s"; - const i8x16_gt_u = "~lib/builtins/i8x16.gt_u"; - const i8x16_ge_s = "~lib/builtins/i8x16.ge_s"; - const i8x16_ge_u = "~lib/builtins/i8x16.ge_u"; - const i16x8_splat = "~lib/builtins/i16x8.splat"; - const i16x8_extract_lane_s = "~lib/builtins/i16x8.extract_lane_s"; - const i16x8_extract_lane_u = "~lib/builtins/i16x8.extract_lane_u"; - const i16x8_replace_lane = "~lib/builtins/i16x8.replace_lane"; - const i16x8_add = "~lib/builtins/i16x8.add"; - const i16x8_sub = "~lib/builtins/i16x8.sub"; - const i16x8_mul = "~lib/builtins/i16x8.mul"; - const i16x8_neg = "~lib/builtins/i16x8.neg"; - const i16x8_add_saturate_s = "~lib/builtins/i16x8.add_saturate_s"; - const i16x8_add_saturate_u = "~lib/builtins/i16x8.add_saturate_u"; - const i16x8_sub_saturate_s = "~lib/builtins/i16x8.sub_saturate_s"; - const i16x8_sub_saturate_u = "~lib/builtins/i16x8.sub_saturate_u"; - const i16x8_shl = "~lib/builtins/i16x8.shl"; - const i16x8_shr_s = "~lib/builtins/i16x8.shr_s"; - const i16x8_shr_u = "~lib/builtins/i16x8.shr_u"; - const i16x8_any_true = "~lib/builtins/i16x8.any_true"; - const i16x8_all_true = "~lib/builtins/i16x8.all_true"; - const i16x8_eq = "~lib/builtins/i16x8.eq"; - const i16x8_ne = "~lib/builtins/i16x8.ne"; - const i16x8_lt_s = "~lib/builtins/i16x8.lt_s"; - const i16x8_lt_u = "~lib/builtins/i16x8.lt_u"; - const i16x8_le_s = "~lib/builtins/i16x8.le_s"; - const i16x8_le_u = "~lib/builtins/i16x8.le_u"; - const i16x8_gt_s = "~lib/builtins/i16x8.gt_s"; - const i16x8_gt_u = "~lib/builtins/i16x8.gt_u"; - const i16x8_ge_s = "~lib/builtins/i16x8.ge_s"; - const i16x8_ge_u = "~lib/builtins/i16x8.ge_u"; - const i32x4_splat = "~lib/builtins/i32x4.splat"; - const i32x4_extract_lane = "~lib/builtins/i32x4.extract_lane"; - const i32x4_replace_lane = "~lib/builtins/i32x4.replace_lane"; - const i32x4_add = "~lib/builtins/i32x4.add"; - const i32x4_sub = "~lib/builtins/i32x4.sub"; - const i32x4_mul = "~lib/builtins/i32x4.mul"; - const i32x4_neg = "~lib/builtins/i32x4.neg"; - const i32x4_shl = "~lib/builtins/i32x4.shl"; - const i32x4_shr_s = "~lib/builtins/i32x4.shr_s"; - const i32x4_shr_u = "~lib/builtins/i32x4.shr_u"; - const i32x4_any_true = "~lib/builtins/i32x4.any_true"; - const i32x4_all_true = "~lib/builtins/i32x4.all_true"; - const i32x4_eq = "~lib/builtins/i32x4.eq"; - const i32x4_ne = "~lib/builtins/i32x4.ne"; - const i32x4_lt_s = "~lib/builtins/i32x4.lt_s"; - const i32x4_lt_u = "~lib/builtins/i32x4.lt_u"; - const i32x4_le_s = "~lib/builtins/i32x4.le_s"; - const i32x4_le_u = "~lib/builtins/i32x4.le_u"; - const i32x4_gt_s = "~lib/builtins/i32x4.gt_s"; - const i32x4_gt_u = "~lib/builtins/i32x4.gt_u"; - const i32x4_ge_s = "~lib/builtins/i32x4.ge_s"; - const i32x4_ge_u = "~lib/builtins/i32x4.ge_u"; - const i32x4_trunc_s_f32x4_sat = "~lib/builtins/i32x4.trunc_s_f32x4_sat"; - const i32x4_trunc_u_f32x4_sat = "~lib/builtins/i32x4.trunc_u_f32x4_sat"; - const i64x2_splat = "~lib/builtins/i64x2.splat"; - const i64x2_extract_lane = "~lib/builtins/i64x2.extract_lane"; - const i64x2_replace_lane = "~lib/builtins/i64x2.replace_lane"; - const i64x2_add = "~lib/builtins/i64x2.add"; - const i64x2_sub = "~lib/builtins/i64x2.sub"; - const i64x2_neg = "~lib/builtins/i64x2.neg"; - const i64x2_shl = "~lib/builtins/i64x2.shl"; - const i64x2_shr_s = "~lib/builtins/i64x2.shr_s"; - const i64x2_shr_u = "~lib/builtins/i64x2.shr_u"; - const i64x2_any_true = "~lib/builtins/i64x2.any_true"; - const i64x2_all_true = "~lib/builtins/i64x2.all_true"; - const i64x2_trunc_s_f64x2_sat = "~lib/builtins/i64x2.trunc_s_f64x2_sat"; - const i64x2_trunc_u_f64x2_sat = "~lib/builtins/i64x2.trunc_u_f64x2_sat"; - const f32x4_splat = "~lib/builtins/f32x4.splat"; - const f32x4_extract_lane = "~lib/builtins/f32x4.extract_lane"; - const f32x4_replace_lane = "~lib/builtins/f32x4.replace_lane"; - const f32x4_add = "~lib/builtins/f32x4.add"; - const f32x4_sub = "~lib/builtins/f32x4.sub"; - const f32x4_mul = "~lib/builtins/f32x4.mul"; - const f32x4_div = "~lib/builtins/f32x4.div"; - const f32x4_neg = "~lib/builtins/f32x4.neg"; - const f32x4_min = "~lib/builtins/f32x4.min"; - const f32x4_max = "~lib/builtins/f32x4.max"; - const f32x4_abs = "~lib/builtins/f32x4.abs"; - const f32x4_sqrt = "~lib/builtins/f32x4.sqrt"; - const f32x4_eq = "~lib/builtins/f32x4.eq"; - const f32x4_ne = "~lib/builtins/f32x4.ne"; - const f32x4_lt = "~lib/builtins/f32x4.lt"; - const f32x4_le = "~lib/builtins/f32x4.le"; - const f32x4_gt = "~lib/builtins/f32x4.gt"; - const f32x4_ge = "~lib/builtins/f32x4.ge"; - const f32x4_convert_s_i32x4 = "~lib/builtins/f32x4.convert_s_i32x4"; - const f32x4_convert_u_i32x4 = "~lib/builtins/f32x4.convert_u_i32x4"; - const f64x2_splat = "~lib/builtins/f64x2.splat"; - const f64x2_extract_lane = "~lib/builtins/f64x2.extract_lane"; - const f64x2_replace_lane = "~lib/builtins/f64x2.replace_lane"; - const f64x2_add = "~lib/builtins/f64x2.add"; - const f64x2_sub = "~lib/builtins/f64x2.sub"; - const f64x2_mul = "~lib/builtins/f64x2.mul"; - const f64x2_div = "~lib/builtins/f64x2.div"; - const f64x2_neg = "~lib/builtins/f64x2.neg"; - const f64x2_min = "~lib/builtins/f64x2.min"; - const f64x2_max = "~lib/builtins/f64x2.max"; - const f64x2_abs = "~lib/builtins/f64x2.abs"; - const f64x2_sqrt = "~lib/builtins/f64x2.sqrt"; - const f64x2_eq = "~lib/builtins/f64x2.eq"; - const f64x2_ne = "~lib/builtins/f64x2.ne"; - const f64x2_lt = "~lib/builtins/f64x2.lt"; - const f64x2_le = "~lib/builtins/f64x2.le"; - const f64x2_gt = "~lib/builtins/f64x2.gt"; - const f64x2_ge = "~lib/builtins/f64x2.ge"; - const f64x2_convert_s_i64x2 = "~lib/builtins/f64x2.convert_s_i64x2"; - const f64x2_convert_u_i64x2 = "~lib/builtins/f64x2.convert_u_i64x2"; - const v8x16_shuffle = "~lib/builtins/v8x16.shuffle"; - const heap_base = "~lib/heap/__heap_base"; - const rtti_base = "~lib/rt/__rtti_base"; - const visit_globals = "~lib/rt/__visit_globals"; - const visit_members = "~lib/rt/__visit_members"; - const ERROR = "~lib/diagnostics/ERROR"; - const WARNING = "~lib/diagnostics/WARNING"; - const INFO = "~lib/diagnostics/INFO"; - const memory_size = "~lib/memory/memory.size"; - const memory_grow = "~lib/memory/memory.grow"; - const memory_copy = "~lib/memory/memory.copy"; - const memory_fill = "~lib/memory/memory.fill"; - const memory_allocate = "~lib/memory/memory.allocate"; - const memory_free = "~lib/memory/memory.free"; - const memory_reset = "~lib/memory/memory.reset"; - const runtime_instanceof = "~lib/runtime/runtime.instanceof"; - const runtime_flags = "~lib/runtime/runtime.flags"; - const runtime_allocate = "~lib/util/runtime/allocate"; - const runtime_reallocate = "~lib/util/runtime/reallocate"; - const runtime_register = "~lib/util/runtime/register"; - const runtime_discard = "~lib/util/runtime/discard"; - const runtime_makeArray = "~lib/util/runtime/makeArray"; - const Int8Array = "~lib/typedarray/Int8Array"; - const Uint8Array = "~lib/typedarray/Uint8Array"; - const Int16Array = "~lib/typedarray/Int16Array"; - const Uint16Array = "~lib/typedarray/Uint16Array"; - const Int32Array = "~lib/typedarray/Int32Array"; - const Uint32Array = "~lib/typedarray/Uint32Array"; - const Int64Array = "~lib/typedarray/Int64Array"; - const Uint64Array = "~lib/typedarray/Uint64Array"; - const Uint8ClampedArray = "~lib/typedarray/Uint8ClampedArray"; - const Float32Array = "~lib/typedarray/Float32Array"; - const Float64Array = "~lib/typedarray/Float64Array"; - const started = "~lib/started"; - const argc = "~lib/argc"; - const setargc = "~lib/setargc"; - const capabilities = "~lib/capabilities"; - } - /** Compiles a call to a built-in function. */ - export function compileCall(compiler: Compiler, - /** Respective function prototype. */ - prototype: FunctionPrototype, - /** Pre-resolved type arguments. */ - typeArguments: Type[] | null, - /** Operand expressions. */ - operands: Expression[], - /** Contextual type. */ - contextualType: Type, - /** Respective call expression. */ - reportNode: CallExpression, - /** Indicates that contextual type is ASM type. */ - isAsm?: bool): ExpressionRef; - /** Compiles an abort wired to the conditionally imported 'abort' function. */ - export function compileAbort(compiler: Compiler, message: Expression | null, reportNode: Node): ExpressionRef; - /** Compiles the `visit_globals` function. */ - export function compileVisitGlobals(compiler: Compiler): void; - /** Compiles the `visit_members` function. */ - export function compileVisitMembers(compiler: Compiler): void; - /** Compiles runtime type information for use by stdlib. */ - export function compileRTTI(compiler: Compiler): void; - -} -declare module 'assemblyscript/src/decompiler' { - /** - * A decompiler that generates low-level AssemblyScript from WebAssembly binaries. - * @module decompiler - */ /***/ - import { Module, FunctionRef, ExpressionRef } from 'assemblyscript/src/module'; - export class Decompiler { - static decompile(module: Module): string; - text: string[]; - functionId: i32; - constructor(); - /** Decompiles a module to an AST that can then be serialized. */ - decompile(module: Module): void; - decompileFunction(func: FunctionRef): void; - decompileExpression(expr: ExpressionRef): void; - private push; - finish(): string; - } - -} -declare module 'assemblyscript/src/definitions' { - /** - * Definition builders for WebIDL and TypeScript. - * @module definitions - */ /***/ - import { Program, Element, Global, Enum, Field, Function, Class, Namespace, Interface, File } from 'assemblyscript/src/program'; - import { Type } from 'assemblyscript/src/types'; abstract class ExportsWalker { - /** Program reference. */ - program: Program; - /** Whether to include private members */ - includePrivate: bool; - /** Already seen elements. */ - seen: Map; - /** Constructs a new Element walker. */ - constructor(program: Program, includePrivate?: bool); - /** Walks all elements and calls the respective handlers. */ - walk(): void; - /** Visits all exported elements of a file. */ - visitFile(file: File): void; - /** Visits an element.*/ - visitElement(name: string, element: Element): void; - private visitFunctionInstances; - private visitClassInstances; - private visitPropertyInstances; - abstract visitGlobal(name: string, element: Global): void; - abstract visitEnum(name: string, element: Enum): void; - abstract visitFunction(name: string, element: Function): void; - abstract visitClass(name: string, element: Class): void; - abstract visitInterface(name: string, element: Interface): void; - abstract visitField(name: string, element: Field): void; - abstract visitNamespace(name: string, element: Element): void; - abstract visitAlias(name: string, element: Element, originalName: string): void; - } - /** A WebIDL definitions builder. */ - export class IDLBuilder extends ExportsWalker { - /** Builds WebIDL definitions for the specified program. */ - static build(program: Program): string; - private sb; - private indentLevel; - /** Constructs a new WebIDL builder. */ - constructor(program: Program, includePrivate?: bool); - visitGlobal(name: string, element: Global): void; - visitEnum(name: string, element: Enum): void; - visitFunction(name: string, element: Function): void; - visitClass(name: string, element: Class): void; - visitInterface(name: string, element: Interface): void; - visitField(name: string, element: Field): void; - visitNamespace(name: string, element: Namespace): void; - visitAlias(name: string, element: Element, originalName: string): void; - typeToString(type: Type): string; - build(): string; - } - /** A TypeScript definitions builder. */ - export class TSDBuilder extends ExportsWalker { - /** Builds TypeScript definitions for the specified program. */ - static build(program: Program): string; - private sb; - private indentLevel; - private unknown; - /** Constructs a new WebIDL builder. */ - constructor(program: Program, includePrivate?: bool); - visitGlobal(name: string, element: Global): void; - visitEnum(name: string, element: Enum): void; - visitFunction(name: string, element: Function): void; - visitClass(name: string, element: Class): void; - visitInterface(name: string, element: Interface): void; - visitField(name: string, element: Field): void; - visitNamespace(name: string, element: Element): void; - visitAlias(name: string, element: Element, originalName: string): void; - typeToString(type: Type): string; - build(): string; - } - export {}; - -} -declare module 'assemblyscript/src/parser' { - /** - * A TypeScript parser for the AssemblyScript subset. - * @module parser - */ /***/ - import { CommonFlags } from 'assemblyscript/src/common'; - import { Program } from 'assemblyscript/src/program'; - import { Tokenizer, CommentHandler } from 'assemblyscript/src/tokenizer'; - import { DiagnosticEmitter } from 'assemblyscript/src/diagnostics'; - import { CommonTypeNode, SignatureNode, Expression, ClassExpression, FunctionExpression, Statement, BlockStatement, BreakStatement, ClassDeclaration, ContinueStatement, DeclarationStatement, DecoratorNode, DoStatement, EnumDeclaration, EnumValueDeclaration, ExportImportStatement, ExportMember, ExportStatement, ExpressionStatement, ForStatement, FunctionDeclaration, IfStatement, ImportDeclaration, ImportStatement, IndexSignatureDeclaration, NamespaceDeclaration, ParameterNode, ReturnStatement, SwitchCase, SwitchStatement, ThrowStatement, TryStatement, TypeDeclaration, TypeParameterNode, VariableStatement, VariableDeclaration, VoidStatement, WhileStatement } from 'assemblyscript/src/ast'; - /** Parser interface. */ - export class Parser extends DiagnosticEmitter { - /** Program being created. */ - program: Program; - /** Source file names to be requested next. */ - backlog: string[]; - /** Source file names already seen, that is processed or backlogged. */ - seenlog: Set; - /** Source file names already completely processed. */ - donelog: Set; - /** Optional handler to intercept comments while tokenizing. */ - onComment: CommentHandler | null; - /** Constructs a new parser. */ - constructor(); - /** Parses a file and adds its definitions to the program. */ - parseFile(text: string, path: string, isEntry: bool): void; - /** Parses a top-level statement. */ - parseTopLevelStatement(tn: Tokenizer, namespace?: NamespaceDeclaration | null): Statement | null; - /** Obtains the next file to parse. */ - nextFile(): string | null; - /** Finishes parsing and returns the program. */ - finish(): Program; - /** Parses a type. */ - parseType(tn: Tokenizer, acceptParenthesized?: bool, suppressErrors?: bool): CommonTypeNode | null; - private tryParseSignatureIsSignature; - /** Parses a function signature, as used in type declarations. */ - tryParseSignature(tn: Tokenizer): SignatureNode | null; - parseDecorator(tn: Tokenizer): DecoratorNode | null; - parseVariable(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): VariableStatement | null; - parseVariableDeclaration(tn: Tokenizer, parentFlags: CommonFlags, parentDecorators: DecoratorNode[] | null): VariableDeclaration | null; - parseEnum(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): EnumDeclaration | null; - parseEnumValue(tn: Tokenizer, parentFlags: CommonFlags): EnumValueDeclaration | null; - parseReturn(tn: Tokenizer): ReturnStatement | null; - parseTypeParameters(tn: Tokenizer): TypeParameterNode[] | null; - parseTypeParameter(tn: Tokenizer): TypeParameterNode | null; - private parseParametersThis; - parseParameters(tn: Tokenizer, isConstructor?: bool): ParameterNode[] | null; - parseParameter(tn: Tokenizer, isConstructor?: bool): ParameterNode | null; - parseFunction(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): FunctionDeclaration | null; - parseFunctionExpression(tn: Tokenizer): FunctionExpression | null; - private parseFunctionExpressionCommon; - parseClassOrInterface(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): ClassDeclaration | null; - parseClassExpression(tn: Tokenizer): ClassExpression | null; - parseClassMember(tn: Tokenizer, parent: ClassDeclaration): DeclarationStatement | null; - parseIndexSignatureDeclaration(tn: Tokenizer, decorators: DecoratorNode[] | null): IndexSignatureDeclaration | null; - parseNamespace(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): NamespaceDeclaration | null; - parseExport(tn: Tokenizer, startPos: i32, isDeclare: bool): ExportStatement | null; - parseExportMember(tn: Tokenizer): ExportMember | null; - parseExportDefaultAlias(tn: Tokenizer, startPos: i32, defaultStart: i32, defaultEnd: i32): ExportStatement; - parseImport(tn: Tokenizer): ImportStatement | null; - parseImportDeclaration(tn: Tokenizer): ImportDeclaration | null; - parseExportImport(tn: Tokenizer, startPos: i32): ExportImportStatement | null; - parseStatement(tn: Tokenizer, topLevel?: bool): Statement | null; - parseBlockStatement(tn: Tokenizer, topLevel: bool): BlockStatement | null; - parseBreak(tn: Tokenizer): BreakStatement | null; - parseContinue(tn: Tokenizer): ContinueStatement | null; - parseDoStatement(tn: Tokenizer): DoStatement | null; - parseExpressionStatement(tn: Tokenizer): ExpressionStatement | null; - parseForStatement(tn: Tokenizer): ForStatement | null; - parseIfStatement(tn: Tokenizer): IfStatement | null; - parseSwitchStatement(tn: Tokenizer): SwitchStatement | null; - parseSwitchCase(tn: Tokenizer): SwitchCase | null; - parseThrowStatement(tn: Tokenizer): ThrowStatement | null; - parseTryStatement(tn: Tokenizer): TryStatement | null; - parseTypeDeclaration(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): TypeDeclaration | null; - parseVoidStatement(tn: Tokenizer): VoidStatement | null; - parseWhileStatement(tn: Tokenizer): WhileStatement | null; - parseExpressionStart(tn: Tokenizer): Expression | null; - tryParseTypeArgumentsBeforeArguments(tn: Tokenizer): CommonTypeNode[] | null; - parseArguments(tn: Tokenizer): Expression[] | null; - parseExpression(tn: Tokenizer, precedence?: Precedence): Expression | null; - private joinPropertyCall; - private maybeParseCallExpression; - /** Skips over a statement on errors in an attempt to reduce unnecessary diagnostic noise. */ - skipStatement(tn: Tokenizer): void; - /** Skips over a block on errors in an attempt to reduce unnecessary diagnostic noise. */ - skipBlock(tn: Tokenizer): void; - } - /** Operator precedence from least to largest. */ - export const enum Precedence { - NONE = 0, - COMMA = 1, - SPREAD = 2, - YIELD = 3, - ASSIGNMENT = 4, - CONDITIONAL = 5, - LOGICAL_OR = 6, - LOGICAL_AND = 7, - BITWISE_OR = 8, - BITWISE_XOR = 9, - BITWISE_AND = 10, - EQUALITY = 11, - RELATIONAL = 12, - SHIFT = 13, - ADDITIVE = 14, - MULTIPLICATIVE = 15, - EXPONENTIATED = 16, - UNARY_PREFIX = 17, - UNARY_POSTFIX = 18, - CALL = 19, - MEMBERACCESS = 20, - GROUPING = 21 - } - -} -declare module 'assemblyscript/src/index' { - /** - * Low-level C-like compiler API. - * @module index - */ /***/ - import { Target, Feature } from 'assemblyscript/src/common'; - import { Options } from 'assemblyscript/src/compiler'; - import { DiagnosticMessage, formatDiagnosticMessage } from 'assemblyscript/src/diagnostics'; - import { Module } from 'assemblyscript/src/module'; - import { Parser } from 'assemblyscript/src/parser'; - import { Program } from 'assemblyscript/src/program'; - /** Parses a source file. If `parser` has been omitted a new one is created. */ - export function parseFile(text: string, path: string, isEntry?: bool, parser?: Parser | null): Parser; - /** Obtains the next required file's path. Returns `null` once complete. */ - export function nextFile(parser: Parser): string | null; - /** Obtains the next diagnostic message. Returns `null` once complete. */ - export function nextDiagnostic(parser: Parser): DiagnosticMessage | null; - /** Formats a diagnostic message to a string. */ - export { formatDiagnosticMessage as formatDiagnostic }; - /** Tests whether a diagnostic is informatory. */ - export function isInfo(message: DiagnosticMessage): bool; - /** Tests whether a diagnostic is a warning. */ - export function isWarning(message: DiagnosticMessage): bool; - /** Tests whether a diagnostic is an error. */ - export function isError(message: DiagnosticMessage): bool; - /** Creates a new set of compiler options. */ - export function createOptions(): Options; - /** Sets the `target` option. */ - export function setTarget(options: Options, target: Target): void; - /** Sets the `noAssert` option. */ - export function setNoAssert(options: Options, noAssert: bool): void; - /** Sets the `importMemory` option. */ - export function setImportMemory(options: Options, importMemory: bool): void; - /** Sets the `sharedMemory` option. */ - export function setSharedMemory(options: Options, sharedMemory: i32): void; - /** Sets the `importTable` option. */ - export function setImportTable(options: Options, importTable: bool): void; - /** Sets the `sourceMap` option. */ - export function setSourceMap(options: Options, sourceMap: bool): void; - /** Sets the `memoryBase` option. */ - export function setMemoryBase(options: Options, memoryBase: u32): void; - /** Sets a 'globalAliases' value. */ - export function setGlobalAlias(options: Options, name: string, alias: string): void; - /** Sets the `explicitStart` option. */ - export function setExplicitStart(options: Options, explicitStart: bool): void; - /** Sign extension operations. */ - export const FEATURE_SIGN_EXTENSION: Feature; - /** Mutable global imports and exports. */ - export const FEATURE_MUTABLE_GLOBAL: Feature; - /** Bulk memory operations. */ - export const FEATURE_BULK_MEMORY: Feature; - /** SIMD types and operations. */ - export const FEATURE_SIMD: Feature; - /** Threading and atomic operations. */ - export const FEATURE_THREADS: Feature; - /** Enables a specific feature. */ - export function enableFeature(options: Options, feature: Feature): void; - /** Gives the compiler a hint at the optimize levels that will be used later on. */ - export function setOptimizeLevelHints(options: Options, optimizeLevel: i32, shrinkLevel: i32): void; - /** Finishes parsing. */ - export function finishParsing(parser: Parser): Program; - /** Compiles the sources computed by the parser to a module. */ - export function compileProgram(program: Program, options?: Options | null): Module; - /** Decompiles a module to its (low level) source. */ - export function decompileModule(module: Module): string; - /** Builds WebIDL definitions for the specified program. */ - export function buildIDL(program: Program): string; - /** Builds TypeScript definitions for the specified program. */ - export function buildTSD(program: Program): string; - /** Builds a JSON file of a program's runtime type information. */ - export function buildRTTI(program: Program): string; - /** Prefix indicating a library file. */ - export { LIBRARY_PREFIX } from 'assemblyscript/src/common'; - export * from 'assemblyscript/src/ast'; - export * from 'assemblyscript/src/common'; - export * from 'assemblyscript/src/compiler'; - export * from 'assemblyscript/src/decompiler'; - export * from 'assemblyscript/src/definitions'; - export * from 'assemblyscript/src/diagnosticMessages.generated'; - export * from 'assemblyscript/src/diagnostics'; - export * from 'assemblyscript/src/flow'; - export * from 'assemblyscript/src/module'; - export * from 'assemblyscript/src/parser'; - export * from 'assemblyscript/src/program'; - export * from 'assemblyscript/src/resolver'; - export * from 'assemblyscript/src/tokenizer'; - export * from 'assemblyscript/src/types'; - export * from 'assemblyscript/src/util'; - -} -declare module 'assemblyscript/src/extra/ast' { - /** - * Abstract Syntax Tree extras. - * - * Not needed in a standalone compiler but useful for testing the parser. - * - * @module extra/ast - */ /***/ - import { Node, Source, CommonTypeNode, TypeName, TypeParameterNode, SignatureNode, IdentifierExpression, LiteralExpression, FloatLiteralExpression, IntegerLiteralExpression, StringLiteralExpression, RegexpLiteralExpression, ArrayLiteralExpression, AssertionExpression, BinaryExpression, CallExpression, CommaExpression, ElementAccessExpression, FunctionExpression, NewExpression, ParenthesizedExpression, PropertyAccessExpression, TernaryExpression, UnaryPostfixExpression, UnaryExpression, UnaryPrefixExpression, ClassExpression, ObjectLiteralExpression, Statement, BlockStatement, BreakStatement, ContinueStatement, DoStatement, EmptyStatement, ExportImportStatement, ExportStatement, ExportDefaultStatement, ExpressionStatement, ForStatement, IfStatement, ImportStatement, InstanceOfExpression, ReturnStatement, SwitchStatement, ThrowStatement, TryStatement, VariableStatement, WhileStatement, ClassDeclaration, EnumDeclaration, EnumValueDeclaration, FieldDeclaration, FunctionDeclaration, ImportDeclaration, IndexSignatureDeclaration, InterfaceDeclaration, MethodDeclaration, NamespaceDeclaration, TypeDeclaration, VariableDeclaration, DecoratorNode, ParameterNode, ExportMember, SwitchCase, DeclarationStatement } from 'assemblyscript/src/ast'; - /** An AST builder. */ - export class ASTBuilder { - /** Rebuilds the textual source from the specified AST, as far as possible. */ - static build(node: Node): string; - private sb; - private indentLevel; - visitNode(node: Node): void; - visitSource(source: Source): void; - visitTypeNode(node: CommonTypeNode): void; - visitTypeName(node: TypeName): void; - visitTypeParameter(node: TypeParameterNode): void; - visitSignatureNode(node: SignatureNode): void; - visitIdentifierExpression(node: IdentifierExpression): void; - visitArrayLiteralExpression(node: ArrayLiteralExpression): void; - visitObjectLiteralExpression(node: ObjectLiteralExpression): void; - visitAssertionExpression(node: AssertionExpression): void; - visitBinaryExpression(node: BinaryExpression): void; - visitCallExpression(node: CallExpression): void; - visitClassExpression(node: ClassExpression): void; - visitCommaExpression(node: CommaExpression): void; - visitElementAccessExpression(node: ElementAccessExpression): void; - visitFunctionExpression(node: FunctionExpression): void; - visitLiteralExpression(node: LiteralExpression): void; - visitFloatLiteralExpression(node: FloatLiteralExpression): void; - visitInstanceOfExpression(node: InstanceOfExpression): void; - visitIntegerLiteralExpression(node: IntegerLiteralExpression): void; - visitStringLiteral(str: string, singleQuoted?: bool): void; - visitStringLiteralExpression(node: StringLiteralExpression): void; - visitRegexpLiteralExpression(node: RegexpLiteralExpression): void; - visitNewExpression(node: NewExpression): void; - visitParenthesizedExpression(node: ParenthesizedExpression): void; - visitPropertyAccessExpression(node: PropertyAccessExpression): void; - visitTernaryExpression(node: TernaryExpression): void; - visitUnaryExpression(node: UnaryExpression): void; - visitUnaryPostfixExpression(node: UnaryPostfixExpression): void; - visitUnaryPrefixExpression(node: UnaryPrefixExpression): void; - visitNodeAndTerminate(statement: Statement): void; - visitBlockStatement(node: BlockStatement): void; - visitBreakStatement(node: BreakStatement): void; - visitContinueStatement(node: ContinueStatement): void; - visitClassDeclaration(node: ClassDeclaration, isDefault?: bool): void; - visitDoStatement(node: DoStatement): void; - visitEmptyStatement(node: EmptyStatement): void; - visitEnumDeclaration(node: EnumDeclaration, isDefault?: bool): void; - visitEnumValueDeclaration(node: EnumValueDeclaration): void; - visitExportImportStatement(node: ExportImportStatement): void; - visitExportMember(node: ExportMember): void; - visitExportStatement(node: ExportStatement): void; - visitExportDefaultStatement(node: ExportDefaultStatement): void; - visitExpressionStatement(node: ExpressionStatement): void; - visitFieldDeclaration(node: FieldDeclaration): void; - visitForStatement(node: ForStatement): void; - visitFunctionDeclaration(node: FunctionDeclaration, isDefault?: bool): void; - visitFunctionCommon(node: FunctionDeclaration): void; - visitIfStatement(node: IfStatement): void; - visitImportDeclaration(node: ImportDeclaration): void; - visitImportStatement(node: ImportStatement): void; - visitIndexSignatureDeclaration(node: IndexSignatureDeclaration): void; - visitInterfaceDeclaration(node: InterfaceDeclaration, isDefault?: bool): void; - visitMethodDeclaration(node: MethodDeclaration): void; - visitNamespaceDeclaration(node: NamespaceDeclaration, isDefault?: bool): void; - visitReturnStatement(node: ReturnStatement): void; - visitSwitchCase(node: SwitchCase): void; - visitSwitchStatement(node: SwitchStatement): void; - visitThrowStatement(node: ThrowStatement): void; - visitTryStatement(node: TryStatement): void; - visitTypeDeclaration(node: TypeDeclaration): void; - visitVariableDeclaration(node: VariableDeclaration): void; - visitVariableStatement(node: VariableStatement): void; - visitWhileStatement(node: WhileStatement): void; - serializeDecorator(node: DecoratorNode): void; - serializeParameter(node: ParameterNode): void; - serializeExternalModifiers(node: DeclarationStatement): void; - serializeAccessModifiers(node: DeclarationStatement): void; - finish(): string; - } - -} -/** - * TypeScript definitions for Binaryen's C-API. - * - * See: https://github.com/WebAssembly/binaryen/blob/master/src/binaryen-c.h - * - * @module glue/binaryen - *//***/ - -declare function _malloc(size: usize): usize; -declare function _free(ptr: usize): void; - -declare type BinaryenIndex = u32; - -declare type BinaryenType = i32; - -declare function _BinaryenTypeNone(): BinaryenType; -declare function _BinaryenTypeInt32(): BinaryenType; -declare function _BinaryenTypeInt64(): BinaryenType; -declare function _BinaryenTypeFloat32(): BinaryenType; -declare function _BinaryenTypeFloat64(): BinaryenType; -declare function _BinaryenTypeVec128(): BinaryenType; -declare function _BinaryenTypeUnreachable(): BinaryenType; -declare function _BinaryenTypeAuto(): BinaryenType; - -declare type BinaryenFeatureFlags = u32; - -declare function _BinaryenFeatureAtomics(): BinaryenFeatureFlags; -declare function _BinaryenFeatureMutableGlobals(): BinaryenFeatureFlags; -declare function _BinaryenFeatureNontrappingFPToInt(): BinaryenFeatureFlags; -declare function _BinaryenFeatureSIMD128(): BinaryenFeatureFlags; -declare function _BinaryenFeatureBulkMemory(): BinaryenFeatureFlags; -declare function _BinaryenFeatureSignExt(): BinaryenFeatureFlags; -declare function _BinaryenFeatureExceptionHandling(): BinaryenFeatureFlags; - -declare type BinaryenExpressionId = i32; - -declare function _BinaryenInvalidId(): BinaryenExpressionId; -declare function _BinaryenBlockId(): BinaryenExpressionId; -declare function _BinaryenIfId(): BinaryenExpressionId; -declare function _BinaryenLoopId(): BinaryenExpressionId; -declare function _BinaryenBreakId(): BinaryenExpressionId; -declare function _BinaryenSwitchId(): BinaryenExpressionId; -declare function _BinaryenCallId(): BinaryenExpressionId; -declare function _BinaryenCallIndirectId(): BinaryenExpressionId; -declare function _BinaryenLocalGetId(): BinaryenExpressionId; -declare function _BinaryenLocalSetId(): BinaryenExpressionId; -declare function _BinaryenGlobalGetId(): BinaryenExpressionId; -declare function _BinaryenGlobalSetId(): BinaryenExpressionId; -declare function _BinaryenLoadId(): BinaryenExpressionId; -declare function _BinaryenStoreId(): BinaryenExpressionId; -declare function _BinaryenConstId(): BinaryenExpressionId; -declare function _BinaryenUnaryId(): BinaryenExpressionId; -declare function _BinaryenBinaryId(): BinaryenExpressionId; -declare function _BinaryenSelectId(): BinaryenExpressionId; -declare function _BinaryenDropId(): BinaryenExpressionId; -declare function _BinaryenReturnId(): BinaryenExpressionId; -declare function _BinaryenHostId(): BinaryenExpressionId; -declare function _BinaryenNopId(): BinaryenExpressionId; -declare function _BinaryenUnreachableId(): BinaryenExpressionId; -declare function _BinaryenAtomicCmpxchgId(): BinaryenExpressionId; -declare function _BinaryenAtomicRMWId(): BinaryenExpressionId; -declare function _BinaryenAtomicWaitId(): BinaryenExpressionId; -declare function _BinaryenAtomicNotifyId(): BinaryenExpressionId; -declare function _BinaryenSIMDExtractId(): BinaryenExpressionId; -declare function _BinaryenSIMDReplaceId(): BinaryenExpressionId; -declare function _BinaryenSIMDShuffleId(): BinaryenExpressionId; -declare function _BinaryenSIMDBitselectId(): BinaryenExpressionId; -declare function _BinaryenSIMDShiftId(): BinaryenExpressionId; -declare function _BinaryenMemoryInitId(): BinaryenExpressionId; -declare function _BinaryenDataDropId(): BinaryenExpressionId; -declare function _BinaryenMemoryCopyId(): BinaryenExpressionId; -declare function _BinaryenMemoryFillId(): BinaryenExpressionId; - -declare type BinaryenModuleRef = usize; -declare type v128ptr = usize; // TODO: LLVM C-abi for const uint8_t[16]? - -declare function _BinaryenModuleCreate(): BinaryenModuleRef; -declare function _BinaryenModuleDispose(module: BinaryenModuleRef): void; - -// LLVM C ABI with `out` being a large enough buffer receiving the -// BinaryenLiteral struct of size `_BinaryenSizeofLiteral()`. -declare function _BinaryenSizeofLiteral(): usize; -declare function _BinaryenLiteralInt32(out: usize, x: i32): void; -declare function _BinaryenLiteralInt64(out: usize, x: i32, y: i32): void; -declare function _BinaryenLiteralFloat32(out: usize, x: f32): void; -declare function _BinaryenLiteralFloat64(out: usize, x: f64): void; -declare function _BinaryenLiteralVec128(out: usize, x: v128ptr): void; -declare function _BinaryenLiteralFloat32Bits(out: usize, x: i32): void; -declare function _BinaryenLiteralFloat64Bits(out: usize, x: i32, y: i32): void; - -declare type BinaryenOp = i32; - -declare function _BinaryenClzInt32(): BinaryenOp; -declare function _BinaryenCtzInt32(): BinaryenOp; -declare function _BinaryenPopcntInt32(): BinaryenOp; -declare function _BinaryenNegFloat32(): BinaryenOp; -declare function _BinaryenAbsFloat32(): BinaryenOp; -declare function _BinaryenCeilFloat32(): BinaryenOp; -declare function _BinaryenFloorFloat32(): BinaryenOp; -declare function _BinaryenTruncFloat32(): BinaryenOp; -declare function _BinaryenNearestFloat32(): BinaryenOp; -declare function _BinaryenSqrtFloat32(): BinaryenOp; -declare function _BinaryenEqZInt32(): BinaryenOp; -declare function _BinaryenClzInt64(): BinaryenOp; -declare function _BinaryenCtzInt64(): BinaryenOp; -declare function _BinaryenPopcntInt64(): BinaryenOp; -declare function _BinaryenNegFloat64(): BinaryenOp; -declare function _BinaryenAbsFloat64(): BinaryenOp; -declare function _BinaryenCeilFloat64(): BinaryenOp; -declare function _BinaryenFloorFloat64(): BinaryenOp; -declare function _BinaryenTruncFloat64(): BinaryenOp; -declare function _BinaryenNearestFloat64(): BinaryenOp; -declare function _BinaryenSqrtFloat64(): BinaryenOp; -declare function _BinaryenEqZInt64(): BinaryenOp; -declare function _BinaryenExtendSInt32(): BinaryenOp; -declare function _BinaryenExtendUInt32(): BinaryenOp; -declare function _BinaryenWrapInt64(): BinaryenOp; -declare function _BinaryenTruncSFloat32ToInt32(): BinaryenOp; -declare function _BinaryenTruncSFloat32ToInt64(): BinaryenOp; -declare function _BinaryenTruncUFloat32ToInt32(): BinaryenOp; -declare function _BinaryenTruncUFloat32ToInt64(): BinaryenOp; -declare function _BinaryenTruncSFloat64ToInt32(): BinaryenOp; -declare function _BinaryenTruncSFloat64ToInt64(): BinaryenOp; -declare function _BinaryenTruncUFloat64ToInt32(): BinaryenOp; -declare function _BinaryenTruncUFloat64ToInt64(): BinaryenOp; -declare function _BinaryenReinterpretFloat32(): BinaryenOp; -declare function _BinaryenReinterpretFloat64(): BinaryenOp; -declare function _BinaryenConvertSInt32ToFloat32(): BinaryenOp; -declare function _BinaryenConvertSInt32ToFloat64(): BinaryenOp; -declare function _BinaryenConvertUInt32ToFloat32(): BinaryenOp; -declare function _BinaryenConvertUInt32ToFloat64(): BinaryenOp; -declare function _BinaryenConvertSInt64ToFloat32(): BinaryenOp; -declare function _BinaryenConvertSInt64ToFloat64(): BinaryenOp; -declare function _BinaryenConvertUInt64ToFloat32(): BinaryenOp; -declare function _BinaryenConvertUInt64ToFloat64(): BinaryenOp; -declare function _BinaryenPromoteFloat32(): BinaryenOp; -declare function _BinaryenDemoteFloat64(): BinaryenOp; -declare function _BinaryenReinterpretInt32(): BinaryenOp; -declare function _BinaryenReinterpretInt64(): BinaryenOp; -declare function _BinaryenExtendS8Int32(): BinaryenOp; -declare function _BinaryenExtendS16Int32(): BinaryenOp; -declare function _BinaryenExtendS8Int64(): BinaryenOp; -declare function _BinaryenExtendS16Int64(): BinaryenOp; -declare function _BinaryenExtendS32Int64(): BinaryenOp; -declare function _BinaryenAddInt32(): BinaryenOp; -declare function _BinaryenSubInt32(): BinaryenOp; -declare function _BinaryenMulInt32(): BinaryenOp; -declare function _BinaryenDivSInt32(): BinaryenOp; -declare function _BinaryenDivUInt32(): BinaryenOp; -declare function _BinaryenRemSInt32(): BinaryenOp; -declare function _BinaryenRemUInt32(): BinaryenOp; -declare function _BinaryenAndInt32(): BinaryenOp; -declare function _BinaryenOrInt32(): BinaryenOp; -declare function _BinaryenXorInt32(): BinaryenOp; -declare function _BinaryenShlInt32(): BinaryenOp; -declare function _BinaryenShrUInt32(): BinaryenOp; -declare function _BinaryenShrSInt32(): BinaryenOp; -declare function _BinaryenRotLInt32(): BinaryenOp; -declare function _BinaryenRotRInt32(): BinaryenOp; -declare function _BinaryenEqInt32(): BinaryenOp; -declare function _BinaryenNeInt32(): BinaryenOp; -declare function _BinaryenLtSInt32(): BinaryenOp; -declare function _BinaryenLtUInt32(): BinaryenOp; -declare function _BinaryenLeSInt32(): BinaryenOp; -declare function _BinaryenLeUInt32(): BinaryenOp; -declare function _BinaryenGtSInt32(): BinaryenOp; -declare function _BinaryenGtUInt32(): BinaryenOp; -declare function _BinaryenGeSInt32(): BinaryenOp; -declare function _BinaryenGeUInt32(): BinaryenOp; -declare function _BinaryenAddInt64(): BinaryenOp; -declare function _BinaryenSubInt64(): BinaryenOp; -declare function _BinaryenMulInt64(): BinaryenOp; -declare function _BinaryenDivSInt64(): BinaryenOp; -declare function _BinaryenDivUInt64(): BinaryenOp; -declare function _BinaryenRemSInt64(): BinaryenOp; -declare function _BinaryenRemUInt64(): BinaryenOp; -declare function _BinaryenAndInt64(): BinaryenOp; -declare function _BinaryenOrInt64(): BinaryenOp; -declare function _BinaryenXorInt64(): BinaryenOp; -declare function _BinaryenShlInt64(): BinaryenOp; -declare function _BinaryenShrUInt64(): BinaryenOp; -declare function _BinaryenShrSInt64(): BinaryenOp; -declare function _BinaryenRotLInt64(): BinaryenOp; -declare function _BinaryenRotRInt64(): BinaryenOp; -declare function _BinaryenEqInt64(): BinaryenOp; -declare function _BinaryenNeInt64(): BinaryenOp; -declare function _BinaryenLtSInt64(): BinaryenOp; -declare function _BinaryenLtUInt64(): BinaryenOp; -declare function _BinaryenLeSInt64(): BinaryenOp; -declare function _BinaryenLeUInt64(): BinaryenOp; -declare function _BinaryenGtSInt64(): BinaryenOp; -declare function _BinaryenGtUInt64(): BinaryenOp; -declare function _BinaryenGeSInt64(): BinaryenOp; -declare function _BinaryenGeUInt64(): BinaryenOp; -declare function _BinaryenAddFloat32(): BinaryenOp; -declare function _BinaryenSubFloat32(): BinaryenOp; -declare function _BinaryenMulFloat32(): BinaryenOp; -declare function _BinaryenDivFloat32(): BinaryenOp; -declare function _BinaryenCopySignFloat32(): BinaryenOp; -declare function _BinaryenMinFloat32(): BinaryenOp; -declare function _BinaryenMaxFloat32(): BinaryenOp; -declare function _BinaryenEqFloat32(): BinaryenOp; -declare function _BinaryenNeFloat32(): BinaryenOp; -declare function _BinaryenLtFloat32(): BinaryenOp; -declare function _BinaryenLeFloat32(): BinaryenOp; -declare function _BinaryenGtFloat32(): BinaryenOp; -declare function _BinaryenGeFloat32(): BinaryenOp; -declare function _BinaryenAddFloat64(): BinaryenOp; -declare function _BinaryenSubFloat64(): BinaryenOp; -declare function _BinaryenMulFloat64(): BinaryenOp; -declare function _BinaryenDivFloat64(): BinaryenOp; -declare function _BinaryenCopySignFloat64(): BinaryenOp; -declare function _BinaryenMinFloat64(): BinaryenOp; -declare function _BinaryenMaxFloat64(): BinaryenOp; -declare function _BinaryenEqFloat64(): BinaryenOp; -declare function _BinaryenNeFloat64(): BinaryenOp; -declare function _BinaryenLtFloat64(): BinaryenOp; -declare function _BinaryenLeFloat64(): BinaryenOp; -declare function _BinaryenGtFloat64(): BinaryenOp; -declare function _BinaryenGeFloat64(): BinaryenOp; - -declare type BinaryenHostOp = BinaryenOp; - -declare function _BinaryenMemorySize(): BinaryenHostOp; -declare function _BinaryenMemoryGrow(): BinaryenHostOp; - -declare type BinaryenAtomicRMWOp = BinaryenOp; - -declare function _BinaryenAtomicRMWAdd(): BinaryenAtomicRMWOp; -declare function _BinaryenAtomicRMWSub(): BinaryenAtomicRMWOp; -declare function _BinaryenAtomicRMWAnd(): BinaryenAtomicRMWOp; -declare function _BinaryenAtomicRMWOr(): BinaryenAtomicRMWOp; -declare function _BinaryenAtomicRMWXor(): BinaryenAtomicRMWOp; -declare function _BinaryenAtomicRMWXchg(): BinaryenAtomicRMWOp; - -declare type BinaryenSIMDOp = BinaryenOp; - -declare function _BinaryenSplatVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenExtractLaneSVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenExtractLaneUVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenReplaceLaneVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenSplatVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenExtractLaneSVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenExtractLaneUVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenReplaceLaneVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenSplatVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenExtractLaneVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenReplaceLaneVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenSplatVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenExtractLaneVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenReplaceLaneVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenSplatVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenExtractLaneVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenReplaceLaneVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenSplatVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenExtractLaneVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenReplaceLaneVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenEqVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenNeVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenLtSVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenLtUVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenGtSVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenGtUVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenLeSVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenLeUVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenGeSVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenGeUVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenEqVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenNeVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenLtSVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenLtUVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenGtSVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenGtUVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenLeSVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenLeUVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenGeSVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenGeUVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenEqVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenNeVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenLtSVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenLtUVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenGtSVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenGtUVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenLeSVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenLeUVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenGeSVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenGeUVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenEqVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenNeVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenLtVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenGtVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenLeVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenGeVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenEqVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenNeVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenLtVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenGtVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenLeVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenGeVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenNotVec128(): BinaryenSIMDOp; -declare function _BinaryenAndVec128(): BinaryenSIMDOp; -declare function _BinaryenOrVec128(): BinaryenSIMDOp; -declare function _BinaryenXorVec128(): BinaryenSIMDOp; -declare function _BinaryenNegVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenAnyTrueVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenAllTrueVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenShlVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenShrSVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenShrUVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenAddVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenAddSatSVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenAddSatUVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenSubVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenSubSatSVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenSubSatUVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenMulVecI8x16(): BinaryenSIMDOp; -declare function _BinaryenNegVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenAnyTrueVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenAllTrueVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenShlVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenShrSVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenShrUVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenAddVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenAddSatSVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenAddSatUVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenSubVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenSubSatSVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenSubSatUVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenMulVecI16x8(): BinaryenSIMDOp; -declare function _BinaryenNegVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenAnyTrueVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenAllTrueVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenShlVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenShrSVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenShrUVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenAddVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenSubVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenMulVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenNegVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenAnyTrueVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenAllTrueVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenShlVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenShrSVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenShrUVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenAddVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenSubVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenAbsVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenNegVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenSqrtVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenAddVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenSubVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenMulVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenDivVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenMinVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenMaxVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenAbsVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenNegVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenSqrtVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenAddVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenSubVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenMulVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenDivVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenMinVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenMaxVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenTruncSatSVecF32x4ToVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenTruncSatUVecF32x4ToVecI32x4(): BinaryenSIMDOp; -declare function _BinaryenTruncSatSVecF64x2ToVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenTruncSatUVecF64x2ToVecI64x2(): BinaryenSIMDOp; -declare function _BinaryenConvertSVecI32x4ToVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenConvertUVecI32x4ToVecF32x4(): BinaryenSIMDOp; -declare function _BinaryenConvertSVecI64x2ToVecF64x2(): BinaryenSIMDOp; -declare function _BinaryenConvertUVecI64x2ToVecF64x2(): BinaryenSIMDOp; - -declare type BinaryenExpressionRef = usize; - -declare function _BinaryenBlock(module: BinaryenModuleRef, name: usize, children: usize, numChildren: BinaryenIndex, type: BinaryenType): BinaryenExpressionRef; -declare function _BinaryenIf(module: BinaryenModuleRef, condition: BinaryenExpressionRef, ifTrue: BinaryenExpressionRef, ifFalse: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenLoop(module: BinaryenModuleRef, name: usize, body: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenBreak(module: BinaryenModuleRef, name: usize, condition: BinaryenExpressionRef, value: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSwitch(module: BinaryenModuleRef, names: usize, numNames: BinaryenIndex, defaultName: usize, condition: BinaryenExpressionRef, value: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenCall(module: BinaryenModuleRef, target: usize, operands: usize, numOperands: BinaryenIndex, returnType: BinaryenType): BinaryenExpressionRef; -declare function _BinaryenCallIndirect(module: BinaryenModuleRef, target: BinaryenExpressionRef, operands: usize, numOperands: BinaryenIndex, type: usize): BinaryenExpressionRef; -declare function _BinaryenLocalGet(module: BinaryenModuleRef, index: BinaryenIndex, type: BinaryenType): BinaryenExpressionRef; -declare function _BinaryenLocalSet(module: BinaryenModuleRef, index: BinaryenIndex, value: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenLocalTee(module: BinaryenModuleRef, index: BinaryenIndex, value: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenGlobalGet(module: BinaryenModuleRef, name: usize, type: BinaryenType): BinaryenExpressionRef; -declare function _BinaryenGlobalSet(module: BinaryenModuleRef, name: usize, value: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenLoad(module: BinaryenModuleRef, bytes: u32, signed: i8, offset: u32, align: u32, type: BinaryenType, ptr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenStore(module: BinaryenModuleRef, bytes: u32, offset: u32, align: u32, ptr: BinaryenExpressionRef, value: BinaryenExpressionRef, type: BinaryenType): BinaryenExpressionRef; -declare function _BinaryenConst(module: BinaryenModuleRef, value: usize): BinaryenExpressionRef; -declare function _BinaryenUnary(module: BinaryenModuleRef, op: BinaryenOp, value: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenBinary(module: BinaryenModuleRef, op: BinaryenOp, left: BinaryenExpressionRef, right: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSelect(module: BinaryenModuleRef, condition: BinaryenExpressionRef, ifTrue: BinaryenExpressionRef, ifFalse: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenDrop(module: BinaryenModuleRef, value: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenReturn(module: BinaryenModuleRef, value: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenHost(module: BinaryenModuleRef, op: BinaryenOp, name: usize | 0, operands: usize, numOperands: BinaryenIndex): BinaryenExpressionRef; -declare function _BinaryenNop(module: BinaryenModuleRef): BinaryenExpressionRef; -declare function _BinaryenUnreachable(module: BinaryenModuleRef): BinaryenExpressionRef; - -declare function _BinaryenAtomicLoad(module: BinaryenModuleRef, bytes: BinaryenIndex, offset: BinaryenIndex, type: BinaryenType, ptr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenAtomicStore(module: BinaryenModuleRef, bytes: BinaryenIndex, offset: BinaryenIndex, ptr: BinaryenExpressionRef, value: BinaryenExpressionRef, type: BinaryenType): BinaryenExpressionRef; -declare function _BinaryenAtomicRMW(module: BinaryenModuleRef, op: BinaryenAtomicRMWOp, bytes: i32, offset: i32, ptr: BinaryenExpressionRef, value: BinaryenExpressionRef, type: BinaryenType): BinaryenExpressionRef; -declare function _BinaryenAtomicCmpxchg(module: BinaryenModuleRef, bytes: i32, offset: i32, ptr: BinaryenExpressionRef, expected: BinaryenExpressionRef, replacement: BinaryenExpressionRef, type: BinaryenType): BinaryenExpressionRef; -declare function _BinaryenAtomicWait(module: BinaryenModuleRef, ptr: BinaryenExpressionRef, expected: BinaryenExpressionRef, timeout: BinaryenExpressionRef, expectedType: BinaryenType): BinaryenExpressionRef; -declare function _BinaryenAtomicNotify(module: BinaryenModuleRef, ptr: BinaryenExpressionRef, notifyCount: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenSIMDExtract(module: BinaryenModuleRef, op: BinaryenSIMDOp, vec: BinaryenExpressionRef, idx: u8): BinaryenExpressionRef; -declare function _BinaryenSIMDReplace(module: BinaryenModuleRef, op: BinaryenSIMDOp, vec: BinaryenExpressionRef, idx: u8, value: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSIMDShuffle(module: BinaryenModuleRef, left: BinaryenExpressionRef, right: BinaryenExpressionRef, mask: v128ptr): BinaryenExpressionRef; -declare function _BinaryenSIMDBitselect(module: BinaryenModuleRef, left: BinaryenExpressionRef, right: BinaryenExpressionRef, cond: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSIMDShift(module: BinaryenModuleRef, op: BinaryenSIMDOp, vec: BinaryenExpressionRef, shift: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenMemoryInit(module: BinaryenModuleRef, segment: u32, dest: BinaryenExpressionRef, offset: BinaryenExpressionRef, size: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenDataDrop(module: BinaryenModuleRef, segment: u32): BinaryenExpressionRef; -declare function _BinaryenMemoryCopy(module: BinaryenModuleRef, dest: BinaryenExpressionRef, source: BinaryenExpressionRef, size: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenMemoryFill(module: BinaryenModuleRef, dest: BinaryenExpressionRef, value: BinaryenExpressionRef, size: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenExpressionGetId(expr: BinaryenExpressionRef): BinaryenExpressionId; -declare function _BinaryenExpressionGetType(expr: BinaryenExpressionRef): BinaryenType; -declare function _BinaryenExpressionPrint(expr: BinaryenExpressionRef): void; - -declare function _BinaryenBlockGetName(expr: BinaryenExpressionRef): usize; -declare function _BinaryenBlockGetNumChildren(expr: BinaryenExpressionRef): BinaryenIndex; -declare function _BinaryenBlockGetChild(expr: BinaryenExpressionRef, index: BinaryenIndex): BinaryenExpressionRef; - -declare function _BinaryenIfGetCondition(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenIfGetIfTrue(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenIfGetIfFalse(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenLoopGetName(expr: BinaryenExpressionRef): usize; -declare function _BinaryenLoopGetBody(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenBreakGetName(expr: BinaryenExpressionRef): usize; -declare function _BinaryenBreakGetCondition(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenBreakGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenSwitchGetNumNames(expr: BinaryenExpressionRef): BinaryenIndex; -declare function _BinaryenSwitchGetName(expr: BinaryenExpressionRef, index: BinaryenIndex): usize; -declare function _BinaryenSwitchGetDefaultName(expr: BinaryenExpressionRef): usize; -declare function _BinaryenSwitchGetCondition(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSwitchGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenCallGetTarget(expr: BinaryenExpressionRef): usize; -declare function _BinaryenCallGetNumOperands(expr: BinaryenExpressionRef): BinaryenIndex; -declare function _BinaryenCallGetOperand(expr: BinaryenExpressionRef, index: BinaryenIndex): BinaryenExpressionRef; - -declare function _BinaryenCallIndirectGetTarget(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenCallIndirectGetNumOperands(expr: BinaryenExpressionRef): BinaryenIndex; -declare function _BinaryenCallIndirectGetOperand(expr: BinaryenExpressionRef, index: BinaryenIndex): BinaryenExpressionRef; - -declare function _BinaryenLocalGetGetIndex(expr: BinaryenExpressionRef): BinaryenIndex; - -declare function _BinaryenLocalSetIsTee(expr: BinaryenExpressionRef): bool; -declare function _BinaryenLocalSetGetIndex(expr: BinaryenExpressionRef): BinaryenIndex; -declare function _BinaryenLocalSetGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenGlobalGetGetName(expr: BinaryenExpressionRef): usize; - -declare function _BinaryenGlobalSetGetName(expr: BinaryenExpressionRef): usize; -declare function _BinaryenGlobalSetGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenHostGetOp(expr: BinaryenExpressionRef): BinaryenOp; -declare function _BinaryenHostGetNameOperand(expr: BinaryenExpressionRef): usize; -declare function _BinaryenHostGetNumOperands(expr: BinaryenExpressionRef): BinaryenIndex; -declare function _BinaryenHostGetOperand(expr: BinaryenExpressionRef, index: BinaryenIndex): BinaryenExpressionRef; - -declare function _BinaryenLoadIsAtomic(expr: BinaryenExpressionRef): bool; -declare function _BinaryenLoadIsSigned(expr: BinaryenExpressionRef): bool; -declare function _BinaryenLoadGetBytes(expr: BinaryenExpressionRef): u32; -declare function _BinaryenLoadGetOffset(expr: BinaryenExpressionRef): u32; -declare function _BinaryenLoadGetAlign(expr: BinaryenExpressionRef): u32; -declare function _BinaryenLoadGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenStoreIsAtomic(expr: BinaryenExpressionRef): bool; -declare function _BinaryenStoreGetBytes(expr: BinaryenExpressionRef): u32; -declare function _BinaryenStoreGetOffset(expr: BinaryenExpressionRef): u32; -declare function _BinaryenStoreGetAlign(expr: BinaryenExpressionRef): u32; -declare function _BinaryenStoreGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenStoreGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenConstGetValueI32(expr: BinaryenExpressionRef): i32; -declare function _BinaryenConstGetValueI64Low(expr: BinaryenExpressionRef): i32; -declare function _BinaryenConstGetValueI64High(expr: BinaryenExpressionRef): i32; -declare function _BinaryenConstGetValueF32(expr: BinaryenExpressionRef): f32; -declare function _BinaryenConstGetValueF64(expr: BinaryenExpressionRef): f64; - -declare function _BinaryenUnaryGetOp(expr: BinaryenExpressionRef): BinaryenOp; -declare function _BinaryenUnaryGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenBinaryGetOp(expr: BinaryenExpressionRef): BinaryenOp; -declare function _BinaryenBinaryGetLeft(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenBinaryGetRight(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenSelectGetIfTrue(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSelectGetIfFalse(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSelectGetCondition(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenDropGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenReturnGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenAtomicRMWGetOp(expr: BinaryenExpressionRef): BinaryenOp; -declare function _BinaryenAtomicRMWGetBytes(expr: BinaryenExpressionRef): u32; -declare function _BinaryenAtomicRMWGetOffset(expr: BinaryenExpressionRef): u32; -declare function _BinaryenAtomicRMWGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenAtomicRMWGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenAtomicCmpxchgGetBytes(expr: BinaryenExpressionRef): u32; -declare function _BinaryenAtomicCmpxchgGetOffset(expr: BinaryenExpressionRef): u32; -declare function _BinaryenAtomicCmpxchgGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenAtomicCmpxchgGetExpected(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenAtomicCmpxchgGetReplacement(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenAtomicWaitGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenAtomicWaitGetExpected(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenAtomicWaitGetTimeout(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenAtomicWaitGetExpectedType(expr: BinaryenExpressionRef): BinaryenType; - -declare function _BinaryenAtomicNotifyGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenAtomicNotifyGetNotifyCount(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenSIMDExtractGetOp(expr: BinaryenExpressionRef): BinaryenSIMDOp; -declare function _BinaryenSIMDExtractGetVec(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSIMDExtractGetIdx(expr: BinaryenExpressionRef): u8; - -declare function _BinaryenSIMDReplaceGetOp(expr: BinaryenExpressionRef): BinaryenSIMDOp; -declare function _BinaryenSIMDReplaceGetVec(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSIMDReplaceGetIdx(expr: BinaryenExpressionRef): u8; -declare function _BinaryenSIMDReplaceGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenSIMDShuffleGetLeft(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSIMDShuffleGetRight(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSIMDShuffleGetMask(expr: BinaryenExpressionRef, out: v128ptr): void; - -declare function _BinaryenSIMDBitselectGetLeft(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSIMDBitselectGetRight(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSIMDBitselectGetCond(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenSIMDShiftGetOp(expr: BinaryenExpressionRef): BinaryenSIMDOp; -declare function _BinaryenSIMDShiftGetVec(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenSIMDShiftGetShift(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenMemoryInitGetSegment(expr: BinaryenExpressionRef): u32; -declare function _BinaryenMemoryInitGetDest(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenMemoryInitGetOffset(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenMemoryInitGetSize(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenDataDropGetSegment(expr: BinaryenExpressionRef): u32; - -declare function _BinaryenMemoryCopyGetDest(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenMemoryCopyGetSource(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenMemoryCopyGetSize(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare function _BinaryenMemoryFillGetDest(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenMemoryFillGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; -declare function _BinaryenMemoryFillGetSize(expr: BinaryenExpressionRef): BinaryenExpressionRef; - -declare type BinaryenFunctionTypeRef = usize; - -declare function _BinaryenAddFunctionType(module: BinaryenModuleRef, name: usize, result: BinaryenType, paramTypes: usize, numParams: BinaryenIndex): BinaryenFunctionTypeRef; -declare function _BinaryenGetFunctionTypeBySignature(module: BinaryenModuleRef, result: BinaryenType, paramTypes: usize, numParams: BinaryenIndex): BinaryenFunctionTypeRef; -declare function _BinaryenRemoveFunctionType(module: BinaryenModuleRef, name: usize): void; - -declare function _BinaryenFunctionTypeGetName(ftype: BinaryenFunctionTypeRef): usize; -declare function _BinaryenFunctionTypeGetNumParams(ftype: BinaryenFunctionTypeRef): BinaryenIndex; -declare function _BinaryenFunctionTypeGetParam(ftype: BinaryenFunctionTypeRef, index: BinaryenIndex): BinaryenType; -declare function _BinaryenFunctionTypeGetResult(ftype: BinaryenFunctionTypeRef): BinaryenType; - -declare type BinaryenFunctionRef = usize; - -declare function _BinaryenAddFunction(module: BinaryenModuleRef, name: usize, type: BinaryenFunctionTypeRef, varTypes: usize, numVarTypes: BinaryenIndex, body: BinaryenExpressionRef): BinaryenFunctionRef; -declare function _BinaryenGetFunction(module: BinaryenModuleRef, name: usize): BinaryenFunctionRef; -declare function _BinaryenRemoveFunction(module: BinaryenModuleRef, name: usize): void; - -declare function _BinaryenFunctionGetName(func: BinaryenFunctionRef): usize; -declare function _BinaryenFunctionGetType(func: BinaryenFunctionRef): BinaryenFunctionTypeRef; -declare function _BinaryenFunctionGetNumParams(func: BinaryenFunctionRef): BinaryenIndex; -declare function _BinaryenFunctionGetParam(func: BinaryenFunctionRef, index: BinaryenIndex): BinaryenType; -declare function _BinaryenFunctionGetResult(func: BinaryenFunctionRef): BinaryenType; -declare function _BinaryenFunctionGetNumVars(func: BinaryenFunctionRef): BinaryenIndex; -declare function _BinaryenFunctionGetVar(func: BinaryenFunctionRef, index: BinaryenIndex): BinaryenType; -declare function _BinaryenFunctionGetBody(func: BinaryenFunctionRef): BinaryenExpressionRef; -declare function _BinaryenFunctionOptimize(func: BinaryenFunctionRef, module: BinaryenModuleRef): void; -declare function _BinaryenFunctionRunPasses(func: BinaryenFunctionRef, module: BinaryenModuleRef, passes: usize, numPasses: BinaryenIndex): void; -declare function _BinaryenFunctionSetDebugLocation(func: BinaryenFunctionRef, expr: BinaryenExpressionRef, fileIndex: BinaryenIndex, lineNumber: BinaryenIndex, columnNumber: BinaryenIndex): void; - -declare type BinaryenImportRef = usize; - -declare function _BinaryenAddFunctionImport(module: BinaryenModuleRef, internalName: usize, externalModuleName: usize, externalBaseName: usize, functionType: BinaryenFunctionTypeRef): BinaryenImportRef; -declare function _BinaryenAddTableImport(module: BinaryenModuleRef, internalName: usize, externalModuleName: usize, externalBaseName: usize): BinaryenImportRef; -declare function _BinaryenAddMemoryImport(module: BinaryenModuleRef, internalName: usize, externalModuleName: usize, externalBaseName: usize, shared:bool): BinaryenImportRef; -declare function _BinaryenAddGlobalImport(module: BinaryenModuleRef, internalName: usize, externalModuleName: usize, externalBaseName: usize, globalType: BinaryenType): BinaryenImportRef; - -declare type BinaryenExportRef = usize; - -declare function _BinaryenAddFunctionExport(module: BinaryenModuleRef, internalName: usize, externalName: usize): BinaryenExportRef; -declare function _BinaryenAddTableExport(module: BinaryenModuleRef, internalName: usize, externalName: usize): BinaryenExportRef; -declare function _BinaryenAddMemoryExport(module: BinaryenModuleRef, internalName: usize, externalName: usize): BinaryenExportRef; -declare function _BinaryenAddGlobalExport(module: BinaryenModuleRef, internalName: usize, externalName: usize): BinaryenExportRef; -declare function _BinaryenRemoveExport(module: BinaryenModuleRef, externalName: usize): void; - -declare type BinaryenGlobalRef = usize; - -declare function _BinaryenAddGlobal(module: BinaryenModuleRef, name: usize, type: BinaryenType, mutable: i8, init: BinaryenExpressionRef): BinaryenGlobalRef; -declare function _BinaryenRemoveGlobal(module: BinaryenModuleRef, name: usize): void; - -declare function _BinaryenSetFunctionTable(module: BinaryenModuleRef, initial: BinaryenIndex, maximum: BinaryenIndex, funcs: usize, numFuncs: BinaryenIndex): void; - -declare function _BinaryenSetMemory(module: BinaryenModuleRef, initial: BinaryenIndex, maximum: BinaryenIndex, exportName: usize, segments: usize, segmentPassive: usize, segmentOffsets: usize, segmentSizes: usize, numSegments: BinaryenIndex, shared: bool): void; - -declare function _BinaryenSetStart(module: BinaryenModuleRef, start: BinaryenFunctionRef): void; - -declare function _BinaryenModuleParse(text: usize): BinaryenModuleRef; -declare function _BinaryenModulePrint(module: BinaryenModuleRef): void; -declare function _BinaryenModulePrintAsmjs(module: BinaryenModuleRef): void; -declare function _BinaryenModuleValidate(module: BinaryenModuleRef): i32; -declare function _BinaryenModuleOptimize(module: BinaryenModuleRef): void; -declare function _BinaryenModuleRunPasses(module: BinaryenModuleRef, passes: usize, numPasses: BinaryenIndex): void; -declare function _BinaryenModuleAutoDrop(module: BinaryenModuleRef): void; -declare function _BinaryenModuleAllocateAndWrite(out: usize, module: BinaryenModuleRef, sourceMapUrl: usize): void; -declare function _BinaryenModuleRead(input: usize, inputSize: usize): BinaryenModuleRef; -declare function _BinaryenModuleInterpret(module: BinaryenModuleRef): void; -declare function _BinaryenModuleAddDebugInfoFileName(module: BinaryenModuleRef, filename: usize): BinaryenIndex; -declare function _BinaryenModuleGetDebugInfoFileName(module: BinaryenModuleRef, index: BinaryenIndex): usize; -declare function _BinaryenModuleGetFeatures(module: BinaryenModuleRef): BinaryenFeatureFlags; -declare function _BinaryenModuleSetFeatures(module: BinaryenModuleRef, featureFlags: BinaryenFeatureFlags): void; - -declare type BinaryenRelooperRef = usize; -declare type BinaryenRelooperBlockRef = usize; - -declare function _RelooperCreate(module: BinaryenModuleRef): BinaryenRelooperRef; -declare function _RelooperAddBlock(relooper: BinaryenRelooperRef, code: BinaryenExpressionRef): BinaryenRelooperBlockRef; -declare function _RelooperAddBranch(from: BinaryenRelooperBlockRef, to: BinaryenRelooperBlockRef, condition: BinaryenExpressionRef, code: BinaryenExpressionRef): void; -declare function _RelooperAddBlockWithSwitch(relooper: BinaryenRelooperRef, code: BinaryenExpressionRef, condition: BinaryenExpressionRef): BinaryenRelooperBlockRef; -declare function _RelooperAddBranchForSwitch(from: BinaryenRelooperBlockRef, to: BinaryenRelooperBlockRef, indexes: usize, numIndexes: BinaryenIndex, code: BinaryenExpressionRef): void; -declare function _RelooperRenderAndDispose(relooper: BinaryenRelooperRef, entry: BinaryenRelooperBlockRef, labelHelper: BinaryenIndex): BinaryenExpressionRef; - -declare function _BinaryenGetOptimizeLevel(): i32; -declare function _BinaryenSetOptimizeLevel(level: i32): void; -declare function _BinaryenGetShrinkLevel(): i32; -declare function _BinaryenSetShrinkLevel(level: i32): void; -declare function _BinaryenGetDebugInfo(): bool; -declare function _BinaryenSetDebugInfo(on: bool): void; - -declare function _BinaryenSetAPITracing(on: i32): void; -/** @module glue/js *//***/ - - -declare namespace binaryen { - class Module { - constructor(); - emitStackIR(optimize?: boolean): string; - emitAsmjs(): string; - } - function wrapModule(ptr: number): Module; -} -/** @module glue/js *//***/ - -declare function f32_as_i32(value: f32): i32; -declare function i32_as_f32(value: i32): f32; -declare function f64_as_i64(value: f64): I64; -declare function i64_as_f64(value: I64): f64; -/** @module glue/js *//***/ - -declare type I64 = { __Long__: true }; // opaque - -declare const i64_zero: I64; -declare const i64_one: I64; - -declare function i64_new(lo: i32, hi?: i32): I64; -declare function i64_low(value: I64): i32; -declare function i64_high(value: I64): i32; - -declare function i64_add(left: I64, right: I64): I64; -declare function i64_sub(left: I64, right: I64): I64; -declare function i64_mul(left: I64, right: I64): I64; -declare function i64_div(left: I64, right: I64): I64; -declare function i64_div_u(left: I64, right: I64): I64; -declare function i64_rem(left: I64, right: I64): I64; -declare function i64_rem_u(left: I64, right: I64): I64; -declare function i64_and(left: I64, right: I64): I64; -declare function i64_or(left: I64, right: I64): I64; -declare function i64_xor(left: I64, right: I64): I64; -declare function i64_shl(left: I64, right: I64): I64; -declare function i64_shr(left: I64, right: I64): I64; -declare function i64_shr_u(left: I64, right: I64): I64; -declare function i64_not(value: I64): I64; - -declare function i64_eq(left: I64, right: I64): bool; -declare function i64_ne(left: I64, right: I64): bool; - -declare function i64_align(value: I64, alignment: i32): I64; - -declare function i64_is_i8(value: I64): bool; -declare function i64_is_i16(value: I64): bool; -declare function i64_is_i32(value: I64): bool; -declare function i64_is_u8(value: I64): bool; -declare function i64_is_u16(value: I64): bool; -declare function i64_is_u32(value: I64): bool; -declare function i64_is_bool(value: I64): bool; -declare function i64_is_f32(value: I64): bool; -declare function i64_is_f64(value: I64): bool; - -declare function i64_to_f32(value: I64): f64; -declare function i64_to_f64(value: I64): f64; -declare function i64_to_string(value: I64, unsigned?: bool): string; +declare module 'assemblyscript/src/common' { + /** + * Common constants. + * @module common + */ /***/ + /** Indicates traits of a {@link Node} or {@link Element}. */ + export enum CommonFlags { + /** No flags set. */ + NONE = 0, + /** Has an `import` modifier. */ + IMPORT = 1, + /** Has an `export` modifier. */ + EXPORT = 2, + /** Has a `declare` modifier. */ + DECLARE = 4, + /** Has a `const` modifier. */ + CONST = 8, + /** Has a `let` modifier. */ + LET = 16, + /** Has a `static` modifier. */ + STATIC = 32, + /** Has a `readonly` modifier. */ + READONLY = 64, + /** Has an `abstract` modifier. */ + ABSTRACT = 128, + /** Has a `public` modifier. */ + PUBLIC = 256, + /** Has a `private` modifier. */ + PRIVATE = 512, + /** Has a `protected` modifier. */ + PROTECTED = 1024, + /** Has a `get` modifier. */ + GET = 2048, + /** Has a `set` modifier. */ + SET = 4096, + /** Has a definite assignment assertion `!` as in `x!: i32;`. */ + DEFINITE_ASSIGNMENT = 8192, + /** Is ambient, that is either declared or nested in a declared element. */ + AMBIENT = 16384, + /** Is generic. */ + GENERIC = 32768, + /** Is part of a generic context. */ + GENERIC_CONTEXT = 65536, + /** Is an instance member. */ + INSTANCE = 131072, + /** Is a constructor. */ + CONSTRUCTOR = 262144, + /** Is a module export. */ + MODULE_EXPORT = 524288, + /** Is a module import. */ + MODULE_IMPORT = 1048576, + /** Is resolved. */ + RESOLVED = 2097152, + /** Is compiled. */ + COMPILED = 4194304, + /** Has a constant value and is therefore inlined. */ + INLINED = 8388608, + /** Is scoped. */ + SCOPED = 16777216, + /** Is a trampoline. */ + TRAMPOLINE = 33554432, + /** Is a virtual method. */ + VIRTUAL = 67108864, + /** Is the main function. */ + MAIN = 134217728, + /** Is quoted. */ + QUOTED = 268435456 + } + /** Path delimiter inserted between file system levels. */ + export const PATH_DELIMITER = "/"; + /** Substitution used to indicate the parent directory. */ + export const PARENT_SUBST = ".."; + /** Function name prefix used for getters. */ + export const GETTER_PREFIX = "get:"; + /** Function name prefix used for setters. */ + export const SETTER_PREFIX = "set:"; + /** Delimiter used between class names and instance members. */ + export const INSTANCE_DELIMITER = "#"; + /** Delimiter used between class and namespace names and static members. */ + export const STATIC_DELIMITER = "."; + /** Delimiter used between a function and its inner elements. */ + export const INNER_DELIMITER = "~"; + /** Substitution used to indicate a library directory. */ + export const LIBRARY_SUBST = "~lib"; + /** Library directory prefix. */ + export const LIBRARY_PREFIX: string; + /** Path index suffix. */ + export const INDEX_SUFFIX: string; + /** Common compiler symbols. */ + export namespace CommonSymbols { + const EMPTY = ""; + const i8 = "i8"; + const i16 = "i16"; + const i32 = "i32"; + const i64 = "i64"; + const isize = "isize"; + const u8 = "u8"; + const u16 = "u16"; + const u32 = "u32"; + const u64 = "u64"; + const usize = "usize"; + const bool = "bool"; + const f32 = "f32"; + const f64 = "f64"; + const v128 = "v128"; + const i8x16 = "i8x16"; + const u8x16 = "u8x16"; + const i16x8 = "i16x8"; + const u16x8 = "u16x8"; + const i32x4 = "i32x4"; + const u32x4 = "u32x4"; + const i64x2 = "i64x2"; + const u64x2 = "u64x2"; + const f32x4 = "f32x4"; + const f64x2 = "f64x2"; + const void_ = "void"; + const number = "number"; + const boolean = "boolean"; + const string = "string"; + const native = "native"; + const indexof = "indexof"; + const valueof = "valueof"; + const null_ = "null"; + const true_ = "true"; + const false_ = "false"; + const this_ = "this"; + const super_ = "super"; + const constructor = "constructor"; + const ASC_TARGET = "ASC_TARGET"; + const ASC_NO_TREESHAKING = "ASC_NO_TREESHAKING"; + const ASC_NO_ASSERT = "ASC_NO_ASSERT"; + const ASC_MEMORY_BASE = "ASC_MEMORY_BASE"; + const ASC_OPTIMIZE_LEVEL = "ASC_OPTIMIZE_LEVEL"; + const ASC_SHRINK_LEVEL = "ASC_SHRINK_LEVEL"; + const ASC_FEATURE_MUTABLE_GLOBAL = "ASC_FEATURE_MUTABLE_GLOBAL"; + const ASC_FEATURE_SIGN_EXTENSION = "ASC_FEATURE_SIGN_EXTENSION"; + const ASC_FEATURE_BULK_MEMORY = "ASC_FEATURE_BULK_MEMORY"; + const ASC_FEATURE_SIMD = "ASC_FEATURE_SIMD"; + const ASC_FEATURE_THREADS = "ASC_FEATURE_THREADS"; + const I8 = "I8"; + const I16 = "I16"; + const I32 = "I32"; + const I64 = "I64"; + const Isize = "Isize"; + const U8 = "U8"; + const U16 = "U16"; + const U32 = "U32"; + const U64 = "U64"; + const Usize = "Usize"; + const Bool = "Bool"; + const F32 = "F32"; + const F64 = "F64"; + const V128 = "V128"; + const String = "String"; + const Array = "Array"; + const FixedArray = "FixedArray"; + const Set = "Set"; + const Map = "Map"; + const ArrayBufferView = "ArrayBufferView"; + const ArrayBuffer = "ArrayBuffer"; + const Math = "Math"; + const Mathf = "Mathf"; + const Int8Array = "Int8Array"; + const Int16Array = "Int16Array"; + const Int32Array = "Int32Array"; + const Int64Array = "Int64Array"; + const Uint8Array = "Uint8Array"; + const Uint8ClampedArray = "Uint8ClampedArray"; + const Uint16Array = "Uint16Array"; + const Uint32Array = "Uint32Array"; + const Uint64Array = "Uint64Array"; + const Float32Array = "Float32Array"; + const Float64Array = "Float64Array"; + const abort = "abort"; + const pow = "pow"; + const mod = "mod"; + const alloc = "__alloc"; + const realloc = "__realloc"; + const free = "__free"; + const retain = "__retain"; + const release = "__release"; + const collect = "__collect"; + const typeinfo = "__typeinfo"; + const instanceof_ = "__instanceof"; + const visit = "__visit"; + const allocArray = "__allocArray"; + } + export { Feature } from 'assemblyscript/std/assembly/shared/feature'; + export { Target } from 'assemblyscript/std/assembly/shared/target'; + export { Typeinfo, TypeinfoFlags } from 'assemblyscript/std/assembly/shared/typeinfo'; + +} +declare module 'assemblyscript/src/diagnosticMessages.generated' { + /** + * Generated from diagnosticsMessages.json. Do not edit. + * @module diagnostics + */ /***/ + /** Enum of available diagnostic codes. */ + export enum DiagnosticCode { + Operation_not_supported = 100, + Operation_is_unsafe = 101, + User_defined_0 = 102, + Conversion_from_type_0_to_1_requires_an_explicit_cast = 200, + Conversion_from_type_0_to_1_will_require_an_explicit_cast_when_switching_between_32_64_bit = 201, + Type_0_cannot_be_changed_to_type_1 = 202, + Type_0_cannot_be_reinterpreted_as_type_1 = 203, + Basic_type_0_cannot_be_nullable = 204, + Cannot_export_a_mutable_global = 205, + Mutable_value_cannot_be_inlined = 206, + Unmanaged_classes_cannot_extend_managed_classes_and_vice_versa = 207, + Unmanaged_classes_cannot_implement_interfaces = 208, + Invalid_regular_expression_flags = 209, + Implementation_0_must_match_the_signature_1 = 210, + Class_0_is_sealed_and_cannot_be_extended = 211, + Decorator_0_is_not_valid_here = 212, + Duplicate_decorator = 213, + An_allocator_must_be_present_to_use_0 = 214, + Optional_parameter_must_have_an_initializer = 215, + Constructor_of_class_0_must_not_require_any_arguments = 216, + Function_0_cannot_be_inlined_into_itself = 217, + Cannot_access_method_0_without_calling_it_as_it_requires_this_to_be_set = 218, + Optional_properties_are_not_supported = 219, + Expression_must_be_a_compile_time_constant = 220, + Module_cannot_have_multiple_start_functions = 221, + _0_must_be_a_value_between_1_and_2_inclusive = 222, + _0_must_be_a_power_of_two = 223, + TODO_Cannot_inline_inferred_calls_and_specific_internals_yet = 224, + Expression_is_never_null = 225, + Unterminated_string_literal = 1002, + Identifier_expected = 1003, + _0_expected = 1005, + A_file_cannot_have_a_reference_to_itself = 1006, + Trailing_comma_not_allowed = 1009, + Unexpected_token = 1012, + A_rest_parameter_must_be_last_in_a_parameter_list = 1014, + Parameter_cannot_have_question_mark_and_initializer = 1015, + A_required_parameter_cannot_follow_an_optional_parameter = 1016, + Statements_are_not_allowed_in_ambient_contexts = 1036, + Initializers_are_not_allowed_in_ambient_contexts = 1039, + _0_modifier_cannot_be_used_here = 1042, + A_rest_parameter_cannot_be_optional = 1047, + A_rest_parameter_cannot_have_an_initializer = 1048, + A_set_accessor_must_have_exactly_one_parameter = 1049, + A_set_accessor_parameter_cannot_have_an_initializer = 1052, + A_get_accessor_cannot_have_parameters = 1054, + Enum_member_must_have_initializer = 1061, + Type_parameters_cannot_appear_on_a_constructor_declaration = 1092, + Type_annotation_cannot_appear_on_a_constructor_declaration = 1093, + An_accessor_cannot_have_type_parameters = 1094, + A_set_accessor_cannot_have_a_return_type_annotation = 1095, + Type_parameter_list_cannot_be_empty = 1098, + A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement = 1104, + A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement = 1105, + A_return_statement_can_only_be_used_within_a_function_body = 1108, + Expression_expected = 1109, + Type_expected = 1110, + A_default_clause_cannot_appear_more_than_once_in_a_switch_statement = 1113, + Duplicate_label_0 = 1114, + An_export_assignment_cannot_have_modifiers = 1120, + Octal_literals_are_not_allowed_in_strict_mode = 1121, + Digit_expected = 1124, + Hexadecimal_digit_expected = 1125, + Unexpected_end_of_text = 1126, + Invalid_character = 1127, + _case_or_default_expected = 1130, + _super_must_be_followed_by_an_argument_list_or_member_access = 1034, + A_declare_modifier_cannot_be_used_in_an_already_ambient_context = 1038, + Type_argument_expected = 1140, + String_literal_expected = 1141, + Line_break_not_permitted_here = 1142, + Declaration_expected = 1146, + _const_declarations_must_be_initialized = 1155, + Unterminated_regular_expression_literal = 1161, + Interface_declaration_cannot_have_implements_clause = 1176, + Binary_digit_expected = 1177, + Octal_digit_expected = 1178, + An_implementation_cannot_be_declared_in_ambient_contexts = 1183, + An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive = 1198, + Unterminated_Unicode_escape_sequence = 1199, + Decorators_are_not_valid_here = 1206, + _abstract_modifier_can_only_appear_on_a_class_method_or_property_declaration = 1242, + Method_0_cannot_have_an_implementation_because_it_is_marked_abstract = 1245, + A_definite_assignment_assertion_is_not_permitted_in_this_context = 1255, + A_class_may_only_extend_another_class = 1311, + A_parameter_property_cannot_be_declared_using_a_rest_parameter = 1317, + Duplicate_identifier_0 = 2300, + Cannot_find_name_0 = 2304, + Module_0_has_no_exported_member_1 = 2305, + Generic_type_0_requires_1_type_argument_s = 2314, + Type_0_is_not_generic = 2315, + Type_0_is_not_assignable_to_type_1 = 2322, + Index_signature_is_missing_in_type_0 = 2329, + _this_cannot_be_referenced_in_current_location = 2332, + _super_can_only_be_referenced_in_a_derived_class = 2335, + Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors = 2337, + Property_0_does_not_exist_on_type_1 = 2339, + Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures = 2349, + Cannot_use_new_with_an_expression_whose_type_lacks_a_construct_signature = 2351, + A_function_whose_declared_type_is_not_void_must_return_a_value = 2355, + The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access = 2357, + The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access = 2364, + Operator_0_cannot_be_applied_to_types_1_and_2 = 2365, + A_super_call_must_be_the_first_statement_in_the_constructor = 2376, + Constructors_for_derived_classes_must_contain_a_super_call = 2377, + _get_and_set_accessor_must_have_the_same_type = 2380, + Constructor_implementation_is_missing = 2390, + Function_implementation_is_missing_or_not_immediately_following_the_declaration = 2391, + Multiple_constructor_implementations_are_not_allowed = 2392, + Duplicate_function_implementation = 2393, + Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local = 2395, + A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged = 2434, + Type_0_has_no_property_1 = 2460, + The_0_operator_cannot_be_applied_to_type_1 = 2469, + In_const_enum_declarations_member_initializer_must_be_constant_expression = 2474, + Export_declaration_conflicts_with_exported_declaration_of_0 = 2484, + Object_is_possibly_null = 2531, + Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property = 2540, + The_target_of_an_assignment_must_be_a_variable_or_a_property_access = 2541, + Index_signature_in_type_0_only_permits_reading = 2542, + Expected_0_arguments_but_got_1 = 2554, + Expected_at_least_0_arguments_but_got_1 = 2555, + Expected_0_type_arguments_but_got_1 = 2558, + A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums = 2651, + Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration = 2673, + Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration = 2674, + Namespace_0_has_no_exported_member_1 = 2694, + Required_type_parameters_may_not_follow_optional_type_parameters = 2706, + Duplicate_property_0 = 2718, + File_0_not_found = 6054, + Numeric_separators_are_not_allowed_here = 6188, + Multiple_consecutive_numeric_separators_are_not_permitted = 6189, + _super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class = 17009, + _super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class = 17011 + } + /** Translates a diagnostic code to its respective string. */ + export function diagnosticCodeToString(code: DiagnosticCode): string; + +} +declare module 'assemblyscript/src/util/bitset' { + /** @module util */ /***/ + /** Tests if the bit at the specified index is set within a 64-bit map. */ + export function bitsetIs(map: I64, index: i32): bool; + /** Sets or unsets the bit at the specified index within a 64-bit map and returns the new map. */ + export function bitsetSet(map: I64, index: i32, isSet: bool): I64; + +} +declare module 'assemblyscript/src/util/charcode' { + /** @module util */ /***/ + /** An enum of named character codes. */ + export const enum CharCode { + NULL = 0, + LINEFEED = 10, + CARRIAGERETURN = 13, + LINESEPARATOR = 8232, + PARAGRAPHSEPARATOR = 8233, + NEXTLINE = 133, + SPACE = 32, + NONBREAKINGSPACE = 160, + ENQUAD = 8192, + EMQUAD = 8193, + ENSPACE = 8194, + EMSPACE = 8195, + THREEPEREMSPACE = 8196, + FOURPEREMSPACE = 8197, + SIXPEREMSPACE = 8198, + FIGURESPACE = 8199, + PUNCTUATIONSPACE = 8200, + THINSPACE = 8201, + HAIRSPACE = 8202, + ZEROWIDTHSPACE = 8203, + NARROWNOBREAKSPACE = 8239, + IDEOGRAPHICSPACE = 12288, + MATHEMATICALSPACE = 8287, + OGHAM = 5760, + _ = 95, + _0 = 48, + _1 = 49, + _2 = 50, + _3 = 51, + _4 = 52, + _5 = 53, + _6 = 54, + _7 = 55, + _8 = 56, + _9 = 57, + a = 97, + b = 98, + c = 99, + d = 100, + e = 101, + f = 102, + g = 103, + h = 104, + i = 105, + j = 106, + k = 107, + l = 108, + m = 109, + n = 110, + o = 111, + p = 112, + q = 113, + r = 114, + s = 115, + t = 116, + u = 117, + v = 118, + w = 119, + x = 120, + y = 121, + z = 122, + A = 65, + B = 66, + C = 67, + D = 68, + E = 69, + F = 70, + G = 71, + H = 72, + I = 73, + J = 74, + K = 75, + L = 76, + M = 77, + N = 78, + O = 79, + P = 80, + Q = 81, + R = 82, + S = 83, + T = 84, + U = 85, + V = 86, + W = 87, + X = 88, + Y = 89, + Z = 90, + AMPERSAND = 38, + ASTERISK = 42, + AT = 64, + BACKSLASH = 92, + BACKTICK = 96, + BAR = 124, + CARET = 94, + CLOSEBRACE = 125, + CLOSEBRACKET = 93, + CLOSEPAREN = 41, + COLON = 58, + COMMA = 44, + DOLLAR = 36, + DOT = 46, + DOUBLEQUOTE = 34, + EQUALS = 61, + EXCLAMATION = 33, + GREATERTHAN = 62, + HASH = 35, + LESSTHAN = 60, + MINUS = 45, + OPENBRACE = 123, + OPENBRACKET = 91, + OPENPAREN = 40, + PERCENT = 37, + PLUS = 43, + QUESTION = 63, + SEMICOLON = 59, + SINGLEQUOTE = 39, + SLASH = 47, + TILDE = 126, + BACKSPACE = 8, + FORMFEED = 12, + BYTEORDERMARK = 65279, + TAB = 9, + VERTICALTAB = 11 + } + /** Tests if the specified character code is some sort of line break. */ + export function isLineBreak(c: CharCode): bool; + /** Tests if the specified character code is some sort of white space. */ + export function isWhiteSpace(c: i32): bool; + /** Tests if the specified character code is a valid decimal digit. */ + export function isDecimalDigit(c: i32): bool; + /** Tests if the specified character code is a valid octal digit. */ + export function isOctalDigit(c: i32): bool; + /** Tests if the specified character code is a valid start of an identifier. */ + export function isIdentifierStart(c: i32): bool; + /** Tests if the specified character code is a valid keyword character. */ + export function isKeywordCharacter(c: i32): bool; + /** Tests if the specified character code is a valid part of an identifier. */ + export function isIdentifierPart(c: i32): bool; + +} +declare module 'assemblyscript/src/util/collections' { + export function makeArray(original?: Array | null): Array; + export function makeSet(original?: Set | null): Set; + export function makeMap(original?: Map | null, overrides?: Map | null): Map; + +} +declare module 'assemblyscript/src/util/path' { + /** @module util */ /***/ + /** + * Normalizes the specified path, removing interior placeholders. + * Expects a posix-compatible relative path (not Windows compatible). + */ + export function normalizePath(path: string): string; + /** Resolves the specified path relative to the specified origin. */ + export function resolvePath(normalizedPath: string, origin: string): string; + /** Obtains the directory portion of a normalized path. */ + export function dirname(normalizedPath: string): string; + +} +declare module 'assemblyscript/src/util/text' { + /** @module util */ /***/ + /** Creates an indentation matching the number of specified levels. */ + export function indent(sb: string[], level: i32): void; + +} +declare module 'assemblyscript/src/util/binary' { + /** @module util */ /***/ + /** Reads an 8-bit integer from the specified buffer. */ + export function readI8(buffer: Uint8Array, offset: i32): i32; + /** Writes an 8-bit integer to the specified buffer. */ + export function writeI8(value: i32, buffer: Uint8Array, offset: i32): void; + /** Reads a 16-bit integer from the specified buffer. */ + export function readI16(buffer: Uint8Array, offset: i32): i32; + /** Writes a 16-bit integer to the specified buffer. */ + export function writeI16(value: i32, buffer: Uint8Array, offset: i32): void; + /** Reads a 32-bit integer from the specified buffer. */ + export function readI32(buffer: Uint8Array, offset: i32): i32; + /** Writes a 32-bit integer to the specified buffer. */ + export function writeI32(value: i32, buffer: Uint8Array, offset: i32): void; + /** Reads a 64-bit integer from the specified buffer. */ + export function readI64(buffer: Uint8Array, offset: i32): I64; + /** Writes a 64-bit integer to the specified buffer. */ + export function writeI64(value: I64, buffer: Uint8Array, offset: i32): void; + /** Reads a 32-bit float from the specified buffer. */ + export function readF32(buffer: Uint8Array, offset: i32): f32; + /** Writes a 32-bit float to the specified buffer. */ + export function writeF32(value: f32, buffer: Uint8Array, offset: i32): void; + /** Reads a 64-bit float from the specified buffer. */ + export function readF64(buffer: Uint8Array, offset: i32): f64; + /** Writes a 64-bit float to the specified buffer. */ + export function writeF64(value: f64, buffer: Uint8Array, offset: i32): void; + +} +declare module 'assemblyscript/src/util/index' { + /** + * Various compiler utilities. + * @module util + * @preferred + */ /***/ + export * from 'assemblyscript/src/util/bitset'; + export * from 'assemblyscript/src/util/charcode'; + export * from 'assemblyscript/src/util/collections'; + export * from 'assemblyscript/src/util/path'; + export * from 'assemblyscript/src/util/text'; + export * from 'assemblyscript/src/util/binary'; + /** Tests if `x` is a power of two. */ + export function isPowerOf2(x: i32): bool; + +} +declare module 'assemblyscript/src/diagnostics' { + /** + * Shared diagnostic handling inherited by the parser and the compiler. + * @module diagnostics + * @preferred + */ /***/ + import { Range } from 'assemblyscript/src/ast'; + import { DiagnosticCode } from 'assemblyscript/src/diagnosticMessages.generated'; + export { DiagnosticCode, diagnosticCodeToString } from 'assemblyscript/src/diagnosticMessages.generated'; + /** Indicates the category of a {@link DiagnosticMessage}. */ + export enum DiagnosticCategory { + /** Informatory message. */ + INFO = 0, + /** Warning message. */ + WARNING = 1, + /** Error message. */ + ERROR = 2 + } + /** Returns the string representation of the specified diagnostic category. */ + export function diagnosticCategoryToString(category: DiagnosticCategory): string; + /** ANSI escape sequence for blue foreground. */ + export const COLOR_BLUE: string; + /** ANSI escape sequence for yellow foreground. */ + export const COLOR_YELLOW: string; + /** ANSI escape sequence for red foreground. */ + export const COLOR_RED: string; + /** ANSI escape sequence to reset the foreground color. */ + export const COLOR_RESET: string; + /** Returns the ANSI escape sequence for the specified category. */ + export function diagnosticCategoryToColor(category: DiagnosticCategory): string; + /** Represents a diagnostic message. */ + export class DiagnosticMessage { + /** Message code. */ + code: i32; + /** Message category. */ + category: DiagnosticCategory; + /** Message text. */ + message: string; + /** Respective source range, if any. */ + range: Range | null; + /** Related range, if any. */ + relatedRange: Range | null; + /** Constructs a new diagnostic message. */ + private constructor(); + /** Creates a new diagnostic message of the specified category. */ + static create(code: DiagnosticCode, category: DiagnosticCategory, arg0?: string | null, arg1?: string | null, arg2?: string | null): DiagnosticMessage; + /** Creates a new informatory diagnostic message. */ + static createInfo(code: DiagnosticCode, arg0?: string | null, arg1?: string | null): DiagnosticMessage; + /** Creates a new warning diagnostic message. */ + static createWarning(code: DiagnosticCode, arg0?: string | null, arg1?: string | null): DiagnosticMessage; + /** Creates a new error diagnostic message. */ + static createError(code: DiagnosticCode, arg0?: string | null, arg1?: string | null): DiagnosticMessage; + /** Adds a source range to this message. */ + withRange(range: Range): this; + /** Adds a related source range to this message. */ + withRelatedRange(range: Range): this; + /** Converts this message to a string. */ + toString(): string; + } + /** Formats a diagnostic message, optionally with terminal colors and source context. */ + export function formatDiagnosticMessage(message: DiagnosticMessage, useColors?: bool, showContext?: bool): string; + /** Formats the diagnostic context for the specified range, optionally with terminal colors. */ + export function formatDiagnosticContext(range: Range, useColors?: bool): string; + /** Base class of all diagnostic emitters. */ + export abstract class DiagnosticEmitter { + /** Diagnostic messages emitted so far. */ + diagnostics: DiagnosticMessage[]; + /** Initializes this diagnostic emitter. */ + protected constructor(diagnostics?: DiagnosticMessage[] | null); + /** Emits a diagnostic message of the specified category. */ + emitDiagnostic(code: DiagnosticCode, category: DiagnosticCategory, range: Range, relatedRange: Range | null, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; + /** Emits an informatory diagnostic message. */ + info(code: DiagnosticCode, range: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; + /** Emits an informatory diagnostic message with a related range. */ + infoRelated(code: DiagnosticCode, range: Range, relatedRange: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; + /** Emits a warning diagnostic message. */ + warning(code: DiagnosticCode, range: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; + /** Emits a warning diagnostic message with a related range. */ + warningRelated(code: DiagnosticCode, range: Range, relatedRange: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; + /** Emits an error diagnostic message. */ + error(code: DiagnosticCode, range: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; + /** Emits an error diagnostic message with a related range. */ + errorRelated(code: DiagnosticCode, range: Range, relatedRange: Range, arg0?: string | null, arg1?: string | null, arg2?: string | null): void; + } + +} +declare module 'assemblyscript/src/tokenizer' { + /** + * A TypeScript tokenizer modified for AssemblyScript. + * + * Skips over trivia and provides a general mark/reset mechanism for the parser to utilize on + * ambiguous tokens. + * + * @module tokenizer + */ /***/ + import { DiagnosticMessage, DiagnosticEmitter } from 'assemblyscript/src/diagnostics'; + import { Source, CommentKind } from 'assemblyscript/src/ast'; + /** Named token types. */ + export enum Token { + ABSTRACT = 0, + AS = 1, + ASYNC = 2, + AWAIT = 3, + BREAK = 4, + CASE = 5, + CATCH = 6, + CLASS = 7, + CONST = 8, + CONTINUE = 9, + CONSTRUCTOR = 10, + DEBUGGER = 11, + DECLARE = 12, + DEFAULT = 13, + DELETE = 14, + DO = 15, + ELSE = 16, + ENUM = 17, + EXPORT = 18, + EXTENDS = 19, + FALSE = 20, + FINALLY = 21, + FOR = 22, + FROM = 23, + FUNCTION = 24, + GET = 25, + IF = 26, + IMPLEMENTS = 27, + IMPORT = 28, + IN = 29, + INSTANCEOF = 30, + INTERFACE = 31, + IS = 32, + KEYOF = 33, + LET = 34, + MODULE = 35, + NAMESPACE = 36, + NEW = 37, + NULL = 38, + OF = 39, + PACKAGE = 40, + PRIVATE = 41, + PROTECTED = 42, + PUBLIC = 43, + READONLY = 44, + RETURN = 45, + SET = 46, + STATIC = 47, + SUPER = 48, + SWITCH = 49, + THIS = 50, + THROW = 51, + TRUE = 52, + TRY = 53, + TYPE = 54, + TYPEOF = 55, + VAR = 56, + VOID = 57, + WHILE = 58, + WITH = 59, + YIELD = 60, + OPENBRACE = 61, + CLOSEBRACE = 62, + OPENPAREN = 63, + CLOSEPAREN = 64, + OPENBRACKET = 65, + CLOSEBRACKET = 66, + DOT = 67, + DOT_DOT_DOT = 68, + SEMICOLON = 69, + COMMA = 70, + LESSTHAN = 71, + GREATERTHAN = 72, + LESSTHAN_EQUALS = 73, + GREATERTHAN_EQUALS = 74, + EQUALS_EQUALS = 75, + EXCLAMATION_EQUALS = 76, + EQUALS_EQUALS_EQUALS = 77, + EXCLAMATION_EQUALS_EQUALS = 78, + EQUALS_GREATERTHAN = 79, + PLUS = 80, + MINUS = 81, + ASTERISK_ASTERISK = 82, + ASTERISK = 83, + SLASH = 84, + PERCENT = 85, + PLUS_PLUS = 86, + MINUS_MINUS = 87, + LESSTHAN_LESSTHAN = 88, + GREATERTHAN_GREATERTHAN = 89, + GREATERTHAN_GREATERTHAN_GREATERTHAN = 90, + AMPERSAND = 91, + BAR = 92, + CARET = 93, + EXCLAMATION = 94, + TILDE = 95, + AMPERSAND_AMPERSAND = 96, + BAR_BAR = 97, + QUESTION = 98, + COLON = 99, + EQUALS = 100, + PLUS_EQUALS = 101, + MINUS_EQUALS = 102, + ASTERISK_EQUALS = 103, + ASTERISK_ASTERISK_EQUALS = 104, + SLASH_EQUALS = 105, + PERCENT_EQUALS = 106, + LESSTHAN_LESSTHAN_EQUALS = 107, + GREATERTHAN_GREATERTHAN_EQUALS = 108, + GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS = 109, + AMPERSAND_EQUALS = 110, + BAR_EQUALS = 111, + CARET_EQUALS = 112, + AT = 113, + IDENTIFIER = 114, + STRINGLITERAL = 115, + INTEGERLITERAL = 116, + FLOATLITERAL = 117, + INVALID = 118, + ENDOFFILE = 119 + } + export enum IdentifierHandling { + DEFAULT = 0, + PREFER = 1, + ALWAYS = 2 + } + export function tokenFromKeyword(text: string): Token; + export function tokenIsAlsoIdentifier(token: Token): bool; + export function isIllegalVariableIdentifier(name: string): bool; + export function operatorTokenToString(token: Token): string; + export class Range { + source: Source; + start: i32; + end: i32; + constructor(source: Source, start: i32, end: i32); + static join(a: Range, b: Range): Range; + readonly atStart: Range; + readonly atEnd: Range; + readonly line: i32; + readonly column: i32; + toString(): string; + debugInfoRef: usize; + } + /** Handler for intercepting comments while tokenizing. */ + export type CommentHandler = (kind: CommentKind, text: string, range: Range) => void; + /** Tokenizes a source to individual {@link Token}s. */ + export class Tokenizer extends DiagnosticEmitter { + source: Source; + end: i32; + pos: i32; + token: Token; + tokenPos: i32; + nextToken: Token; + nextTokenPos: i32; + nextTokenOnNewLine: bool; + onComment: CommentHandler | null; + /** Constructs a new tokenizer. */ + constructor(source: Source, diagnostics?: DiagnosticMessage[] | null); + next(identifierHandling?: IdentifierHandling): Token; + private unsafeNext; + peek(checkOnNewLine?: bool, identifierHandling?: IdentifierHandling, maxCompoundLength?: i32): Token; + skipIdentifier(identifierHandling?: IdentifierHandling): bool; + skip(token: Token, identifierHandling?: IdentifierHandling): bool; + mark(): State; + discard(state: State): void; + reset(state: State): void; + range(start?: i32, end?: i32): Range; + readIdentifier(): string; + readString(): string; + readEscapeSequence(): string; + readRegexpPattern(): string; + readRegexpFlags(): string; + testInteger(): bool; + readInteger(): I64; + readHexInteger(): I64; + readDecimalInteger(): I64; + readOctalInteger(): I64; + readBinaryInteger(): I64; + readFloat(): f64; + readDecimalFloat(): f64; + readHexFloat(): f64; + readUnicodeEscape(): string; + private readExtendedUnicodeEscape; + finish(): void; + } + /** Tokenizer state as returned by {@link Tokenizer#mark} and consumed by {@link Tokenizer#reset}. */ + export class State { + /** Current position. */ + pos: i32; + /** Current token. */ + token: Token; + /** Current token's position. */ + tokenPos: i32; + } + +} +declare module 'assemblyscript/src/ast' { + /** + * Abstract syntax tree representing a source file once parsed. + * @module ast + */ /***/ + import { CommonFlags } from 'assemblyscript/src/common'; + import { Token, Tokenizer, Range } from 'assemblyscript/src/tokenizer'; + export { Token, Range }; + /** Indicates the kind of a node. */ + export enum NodeKind { + SOURCE = 0, + NAMEDTYPE = 1, + FUNCTIONTYPE = 2, + TYPENAME = 3, + TYPEPARAMETER = 4, + PARAMETER = 5, + IDENTIFIER = 6, + ASSERTION = 7, + BINARY = 8, + CALL = 9, + CLASS = 10, + COMMA = 11, + ELEMENTACCESS = 12, + FALSE = 13, + FUNCTION = 14, + INSTANCEOF = 15, + LITERAL = 16, + NEW = 17, + NULL = 18, + PARENTHESIZED = 19, + PROPERTYACCESS = 20, + TERNARY = 21, + SUPER = 22, + THIS = 23, + TRUE = 24, + CONSTRUCTOR = 25, + UNARYPOSTFIX = 26, + UNARYPREFIX = 27, + BLOCK = 28, + BREAK = 29, + CONTINUE = 30, + DO = 31, + EMPTY = 32, + EXPORT = 33, + EXPORTDEFAULT = 34, + EXPORTIMPORT = 35, + EXPRESSION = 36, + FOR = 37, + IF = 38, + IMPORT = 39, + RETURN = 40, + SWITCH = 41, + THROW = 42, + TRY = 43, + VARIABLE = 44, + VOID = 45, + WHILE = 46, + CLASSDECLARATION = 47, + ENUMDECLARATION = 48, + ENUMVALUEDECLARATION = 49, + FIELDDECLARATION = 50, + FUNCTIONDECLARATION = 51, + IMPORTDECLARATION = 52, + INDEXSIGNATUREDECLARATION = 53, + INTERFACEDECLARATION = 54, + METHODDECLARATION = 55, + NAMESPACEDECLARATION = 56, + TYPEDECLARATION = 57, + VARIABLEDECLARATION = 58, + DECORATOR = 59, + EXPORTMEMBER = 60, + SWITCHCASE = 61, + COMMENT = 62 + } + /** Checks if a node represents a constant value. */ + export function nodeIsConstantValue(kind: NodeKind): bool; + /** Checks if a node might be callable. */ + export function nodeIsCallable(kind: NodeKind): bool; + /** Checks if a node might be callable with generic arguments. */ + export function nodeIsGenericCallable(kind: NodeKind): bool; + /** Base class of all nodes. */ + export abstract class Node { + /** Node kind indicator. */ + kind: NodeKind; + /** Source range. */ + range: Range; + static createTypeName(name: IdentifierExpression, range: Range): TypeName; + static createSimpleTypeName(name: string, range: Range): TypeName; + static createNamedType(name: TypeName, typeArguments: TypeNode[] | null, isNullable: bool, range: Range): NamedTypeNode; + static createFunctionType(parameters: ParameterNode[], returnType: TypeNode, explicitThisType: NamedTypeNode | null, isNullable: bool, range: Range): FunctionTypeNode; + static createOmittedType(range: Range): NamedTypeNode; + static createTypeParameter(name: IdentifierExpression, extendsType: NamedTypeNode | null, defaultType: NamedTypeNode | null, range: Range): TypeParameterNode; + static createParameter(name: IdentifierExpression, type: TypeNode, initializer: Expression | null, kind: ParameterKind, range: Range): ParameterNode; + static createDecorator(name: Expression, args: Expression[] | null, range: Range): DecoratorNode; + static createComment(text: string, kind: CommentKind, range: Range): CommentNode; + static createIdentifierExpression(name: string, range: Range, isQuoted?: bool): IdentifierExpression; + static createEmptyIdentifierExpression(range: Range): IdentifierExpression; + static createArrayLiteralExpression(elements: (Expression | null)[], range: Range): ArrayLiteralExpression; + static createAssertionExpression(assertionKind: AssertionKind, expression: Expression, toType: TypeNode | null, range: Range): AssertionExpression; + static createBinaryExpression(operator: Token, left: Expression, right: Expression, range: Range): BinaryExpression; + static createCallExpression(expression: Expression, typeArgs: TypeNode[] | null, args: Expression[], range: Range): CallExpression; + static createClassExpression(declaration: ClassDeclaration): ClassExpression; + static createCommaExpression(expressions: Expression[], range: Range): CommaExpression; + static createConstructorExpression(range: Range): ConstructorExpression; + static createElementAccessExpression(expression: Expression, element: Expression, range: Range): ElementAccessExpression; + static createFalseExpression(range: Range): FalseExpression; + static createFloatLiteralExpression(value: f64, range: Range): FloatLiteralExpression; + static createFunctionExpression(declaration: FunctionDeclaration): FunctionExpression; + static createInstanceOfExpression(expression: Expression, isType: TypeNode, range: Range): InstanceOfExpression; + static createIntegerLiteralExpression(value: I64, range: Range): IntegerLiteralExpression; + static createNewExpression(expression: Expression, typeArgs: TypeNode[] | null, args: Expression[], range: Range): NewExpression; + static createNullExpression(range: Range): NullExpression; + static createObjectLiteralExpression(names: IdentifierExpression[], values: Expression[], range: Range): ObjectLiteralExpression; + static createParenthesizedExpression(expression: Expression, range: Range): ParenthesizedExpression; + static createPropertyAccessExpression(expression: Expression, property: IdentifierExpression, range: Range): PropertyAccessExpression; + static createRegexpLiteralExpression(pattern: string, flags: string, range: Range): RegexpLiteralExpression; + static createTernaryExpression(condition: Expression, ifThen: Expression, ifElse: Expression, range: Range): TernaryExpression; + static createStringLiteralExpression(value: string, range: Range): StringLiteralExpression; + static createSuperExpression(range: Range): SuperExpression; + static createThisExpression(range: Range): ThisExpression; + static createTrueExpression(range: Range): TrueExpression; + static createUnaryPostfixExpression(operator: Token, operand: Expression, range: Range): UnaryPostfixExpression; + static createUnaryPrefixExpression(operator: Token, operand: Expression, range: Range): UnaryPrefixExpression; + static createBlockStatement(statements: Statement[], range: Range): BlockStatement; + static createBreakStatement(label: IdentifierExpression | null, range: Range): BreakStatement; + static createClassDeclaration(identifier: IdentifierExpression, typeParameters: TypeParameterNode[] | null, extendsType: NamedTypeNode | null, // can't be a function + implementsTypes: NamedTypeNode[] | null, // can't be functions + members: DeclarationStatement[], decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): ClassDeclaration; + static createContinueStatement(label: IdentifierExpression | null, range: Range): ContinueStatement; + static createDoStatement(statement: Statement, condition: Expression, range: Range): DoStatement; + static createEmptyStatement(range: Range): EmptyStatement; + static createEnumDeclaration(name: IdentifierExpression, members: EnumValueDeclaration[], decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): EnumDeclaration; + static createEnumValueDeclaration(name: IdentifierExpression, value: Expression | null, flags: CommonFlags, range: Range): EnumValueDeclaration; + static createExportStatement(members: ExportMember[] | null, path: StringLiteralExpression | null, isDeclare: bool, range: Range): ExportStatement; + static createExportDefaultStatement(declaration: DeclarationStatement, range: Range): ExportDefaultStatement; + static createExportImportStatement(name: IdentifierExpression, externalName: IdentifierExpression, range: Range): ExportImportStatement; + static createExportMember(name: IdentifierExpression, externalName: IdentifierExpression | null, range: Range): ExportMember; + static createExpressionStatement(expression: Expression): ExpressionStatement; + static createIfStatement(condition: Expression, ifTrue: Statement, ifFalse: Statement | null, range: Range): IfStatement; + static createImportStatement(decls: ImportDeclaration[] | null, path: StringLiteralExpression, range: Range): ImportStatement; + static createImportStatementWithWildcard(identifier: IdentifierExpression, path: StringLiteralExpression, range: Range): ImportStatement; + static createImportDeclaration(foreignName: IdentifierExpression, name: IdentifierExpression | null, range: Range): ImportDeclaration; + static createInterfaceDeclaration(name: IdentifierExpression, typeParameters: TypeParameterNode[] | null, extendsType: NamedTypeNode | null, // can't be a function + members: DeclarationStatement[], decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): InterfaceDeclaration; + static createFieldDeclaration(name: IdentifierExpression, type: TypeNode | null, initializer: Expression | null, decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): FieldDeclaration; + static createForStatement(initializer: Statement | null, condition: Expression | null, incrementor: Expression | null, statement: Statement, range: Range): ForStatement; + static createFunctionDeclaration(name: IdentifierExpression, typeParameters: TypeParameterNode[] | null, signature: FunctionTypeNode, body: Statement | null, decorators: DecoratorNode[] | null, flags: CommonFlags, arrowKind: ArrowKind, range: Range): FunctionDeclaration; + static createIndexSignatureDeclaration(keyType: NamedTypeNode, valueType: TypeNode, range: Range): IndexSignatureDeclaration; + static createMethodDeclaration(name: IdentifierExpression, typeParameters: TypeParameterNode[] | null, signature: FunctionTypeNode, body: Statement | null, decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): MethodDeclaration; + static createNamespaceDeclaration(name: IdentifierExpression, members: Statement[], decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): NamespaceDeclaration; + static createReturnStatement(value: Expression | null, range: Range): ReturnStatement; + static createSwitchStatement(condition: Expression, cases: SwitchCase[], range: Range): SwitchStatement; + static createSwitchCase(label: Expression | null, statements: Statement[], range: Range): SwitchCase; + static createThrowStatement(value: Expression, range: Range): ThrowStatement; + static createTryStatement(statements: Statement[], catchVariable: IdentifierExpression | null, catchStatements: Statement[] | null, finallyStatements: Statement[] | null, range: Range): TryStatement; + static createTypeDeclaration(name: IdentifierExpression, typeParameters: TypeParameterNode[] | null, alias: TypeNode, decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): TypeDeclaration; + static createVariableStatement(declarations: VariableDeclaration[], decorators: DecoratorNode[] | null, range: Range): VariableStatement; + static createVariableDeclaration(name: IdentifierExpression, type: TypeNode | null, initializer: Expression | null, decorators: DecoratorNode[] | null, flags: CommonFlags, range: Range): VariableDeclaration; + static createVoidStatement(expression: Expression, range: Range): VoidStatement; + static createWhileStatement(condition: Expression, statement: Statement, range: Range): WhileStatement; + } + export abstract class TypeNode extends Node { + /** Whether nullable or not. */ + isNullable: bool; + } + /** Represents a type name. */ + export class TypeName extends Node { + kind: NodeKind; + /** Identifier of this part. */ + identifier: IdentifierExpression; + /** Next part of the type name or `null` if this is the last part. */ + next: TypeName | null; + } + /** Represents a named type. */ + export class NamedTypeNode extends TypeNode { + kind: NodeKind; + /** Type name. */ + name: TypeName; + /** Type argument references. */ + typeArguments: TypeNode[] | null; + } + /** Represents a function type. */ + export class FunctionTypeNode extends TypeNode { + kind: NodeKind; + /** Accepted parameters. */ + parameters: ParameterNode[]; + /** Return type. */ + returnType: TypeNode; + /** Explicitly provided this type, if any. */ + explicitThisType: NamedTypeNode | null; + } + /** Represents a type parameter. */ + export class TypeParameterNode extends Node { + kind: NodeKind; + /** Identifier reference. */ + name: IdentifierExpression; + /** Extended type reference, if any. */ + extendsType: NamedTypeNode | null; + /** Default type if omitted, if any. */ + defaultType: NamedTypeNode | null; + } + /** Represents the kind of a parameter. */ + export enum ParameterKind { + /** No specific flags. */ + DEFAULT = 0, + /** Is an optional parameter. */ + OPTIONAL = 1, + /** Is a rest parameter. */ + REST = 2 + } + /** Represents a function parameter. */ + export class ParameterNode extends Node { + kind: NodeKind; + /** Parameter kind. */ + parameterKind: ParameterKind; + /** Parameter name. */ + name: IdentifierExpression; + /** Parameter type. */ + type: TypeNode; + /** Initializer expression, if present. */ + initializer: Expression | null; + /** Implicit field declaration, if applicable. */ + implicitFieldDeclaration: FieldDeclaration | null; + /** Common flags indicating specific traits. */ + flags: CommonFlags; + /** Tests if this node has the specified flag or flags. */ + is(flag: CommonFlags): bool; + /** Tests if this node has one of the specified flags. */ + isAny(flag: CommonFlags): bool; + /** Sets a specific flag or flags. */ + set(flag: CommonFlags): void; + } + /** Built-in decorator kinds. */ + export enum DecoratorKind { + CUSTOM = 0, + GLOBAL = 1, + OPERATOR = 2, + OPERATOR_BINARY = 3, + OPERATOR_PREFIX = 4, + OPERATOR_POSTFIX = 5, + UNMANAGED = 6, + SEALED = 7, + INLINE = 8, + EXTERNAL = 9, + BUILTIN = 10, + LAZY = 11, + UNSAFE = 12 + } + /** Returns the kind of the specified decorator. Defaults to {@link DecoratorKind.CUSTOM}. */ + export function decoratorNameToKind(name: Expression): DecoratorKind; + /** Represents a decorator. */ + export class DecoratorNode extends Node { + kind: NodeKind; + /** Built-in kind, if applicable. */ + decoratorKind: DecoratorKind; + /** Name expression. */ + name: Expression; + /** Argument expressions. */ + arguments: Expression[] | null; + } + /** Comment kinds. */ + export enum CommentKind { + /** Line comment. */ + LINE = 0, + /** Triple-slash comment. */ + TRIPLE = 1, + /** Block comment. */ + BLOCK = 2 + } + /** Represents a comment. */ + export class CommentNode extends Node { + kind: NodeKind; + /** Comment kind. */ + commentKind: CommentKind; + /** Comment text. */ + text: string; + } + /** Base class of all expression nodes. */ + export abstract class Expression extends Node { + } + /** Represents an identifier expression. */ + export class IdentifierExpression extends Expression { + kind: NodeKind; + /** Textual name. */ + text: string; + /** Symbol. */ + symbol: string; + /** Whether quoted or not. */ + isQuoted: bool; + } + /** Indicates the kind of a literal. */ + export enum LiteralKind { + FLOAT = 0, + INTEGER = 1, + STRING = 2, + REGEXP = 3, + ARRAY = 4, + OBJECT = 5 + } + /** Base class of all literal expressions. */ + export abstract class LiteralExpression extends Expression { + kind: NodeKind; + /** Specific literal kind. */ + literalKind: LiteralKind; + } + /** Represents an `[]` literal expression. */ + export class ArrayLiteralExpression extends LiteralExpression { + literalKind: LiteralKind; + /** Nested element expressions. */ + elementExpressions: (Expression | null)[]; + } + /** Indicates the kind of an assertion. */ + export enum AssertionKind { + PREFIX = 0, + AS = 1, + NONNULL = 2 + } + /** Represents an assertion expression. */ + export class AssertionExpression extends Expression { + kind: NodeKind; + /** Specific kind of this assertion. */ + assertionKind: AssertionKind; + /** Expression being asserted. */ + expression: Expression; + /** Target type. */ + toType: TypeNode | null; + } + /** Represents a binary expression. */ + export class BinaryExpression extends Expression { + kind: NodeKind; + /** Operator token. */ + operator: Token; + /** Left-hand side expression */ + left: Expression; + /** Right-hand side expression. */ + right: Expression; + } + /** Represents a call expression. */ + export class CallExpression extends Expression { + kind: NodeKind; + /** Called expression. Usually an identifier or property access expression. */ + expression: Expression; + /** Provided type arguments. */ + typeArguments: TypeNode[] | null; + /** Provided arguments. */ + arguments: Expression[]; + /** Gets the type arguments range for reporting. */ + readonly typeArgumentsRange: Range; + /** Gets the arguments range for reporting. */ + readonly argumentsRange: Range; + } + /** Represents a class expression using the 'class' keyword. */ + export class ClassExpression extends Expression { + kind: NodeKind; + /** Inline class declaration. */ + declaration: ClassDeclaration; + } + /** Represents a comma expression composed of multiple expressions. */ + export class CommaExpression extends Expression { + kind: NodeKind; + /** Sequential expressions. */ + expressions: Expression[]; + } + /** Represents a `constructor` expression. */ + export class ConstructorExpression extends IdentifierExpression { + kind: NodeKind; + text: string; + symbol: string; + } + /** Represents an element access expression, e.g., array access. */ + export class ElementAccessExpression extends Expression { + kind: NodeKind; + /** Expression being accessed. */ + expression: Expression; + /** Element of the expression being accessed. */ + elementExpression: Expression; + } + /** Represents a float literal expression. */ + export class FloatLiteralExpression extends LiteralExpression { + literalKind: LiteralKind; + /** Float value. */ + value: f64; + } + /** Represents a function expression using the 'function' keyword. */ + export class FunctionExpression extends Expression { + kind: NodeKind; + /** Inline function declaration. */ + declaration: FunctionDeclaration; + } + /** Represents an `instanceof` expression. */ + export class InstanceOfExpression extends Expression { + kind: NodeKind; + /** Expression being asserted. */ + expression: Expression; + /** Type to test for. */ + isType: TypeNode; + } + /** Represents an integer literal expression. */ + export class IntegerLiteralExpression extends LiteralExpression { + literalKind: LiteralKind; + /** Integer value. */ + value: I64; + } + /** Represents a `new` expression. Like a call but with its own kind. */ + export class NewExpression extends CallExpression { + kind: NodeKind; + } + /** Represents a `null` expression. */ + export class NullExpression extends IdentifierExpression { + kind: NodeKind; + text: string; + symbol: string; + } + /** Represents an object literal expression. */ + export class ObjectLiteralExpression extends LiteralExpression { + literalKind: LiteralKind; + /** Field names. */ + names: IdentifierExpression[]; + /** Field values. */ + values: Expression[]; + } + /** Represents a parenthesized expression. */ + export class ParenthesizedExpression extends Expression { + kind: NodeKind; + /** Expression in parenthesis. */ + expression: Expression; + } + /** Represents a property access expression. */ + export class PropertyAccessExpression extends Expression { + kind: NodeKind; + /** Expression being accessed. */ + expression: Expression; + /** Property of the expression being accessed. */ + property: IdentifierExpression; + } + /** Represents a regular expression literal expression. */ + export class RegexpLiteralExpression extends LiteralExpression { + literalKind: LiteralKind; + /** Regular expression pattern. */ + pattern: string; + /** Regular expression flags. */ + patternFlags: string; + } + /** Represents a ternary expression, i.e., short if notation. */ + export class TernaryExpression extends Expression { + kind: NodeKind; + /** Condition expression. */ + condition: Expression; + /** Expression executed when condition is `true`. */ + ifThen: Expression; + /** Expression executed when condition is `false`. */ + ifElse: Expression; + } + /** Represents a string literal expression. */ + export class StringLiteralExpression extends LiteralExpression { + literalKind: LiteralKind; + /** String value without quotes. */ + value: string; + } + /** Represents a `super` expression. */ + export class SuperExpression extends IdentifierExpression { + kind: NodeKind; + text: string; + symbol: string; + } + /** Represents a `this` expression. */ + export class ThisExpression extends IdentifierExpression { + kind: NodeKind; + text: string; + symbol: string; + } + /** Represents a `true` expression. */ + export class TrueExpression extends IdentifierExpression { + kind: NodeKind; + text: string; + symbol: string; + } + /** Represents a `false` expression. */ + export class FalseExpression extends IdentifierExpression { + kind: NodeKind; + text: string; + symbol: string; + } + /** Base class of all unary expressions. */ + export abstract class UnaryExpression extends Expression { + /** Operator token. */ + operator: Token; + /** Operand expression. */ + operand: Expression; + } + /** Represents a unary postfix expression, e.g. a postfix increment. */ + export class UnaryPostfixExpression extends UnaryExpression { + kind: NodeKind; + } + /** Represents a unary prefix expression, e.g. a negation. */ + export class UnaryPrefixExpression extends UnaryExpression { + kind: NodeKind; + } + /** Base class of all statement nodes. */ + export abstract class Statement extends Node { + } + /** Indicates the specific kind of a source. */ + export enum SourceKind { + /** Default source. Usually imported from an entry file. */ + DEFAULT = 0, + /** Entry file. */ + ENTRY = 1, + /** Library file. */ + LIBRARY = 2 + } + /** A top-level source node. */ + export class Source extends Node { + kind: NodeKind; + parent: null; + /** Source kind. */ + sourceKind: SourceKind; + /** Normalized path. */ + normalizedPath: string; + /** Path used internally. */ + internalPath: string; + /** Simple path (last part without extension). */ + simplePath: string; + /** Contained statements. */ + statements: Statement[]; + /** Full source text. */ + text: string; + /** Tokenizer reference. */ + tokenizer: Tokenizer | null; + /** Source map index. */ + debugInfoIndex: i32; + /** Re-exported sources. */ + exportPaths: Set | null; + /** Constructs a new source node. */ + constructor(normalizedPath: string, text: string, kind: SourceKind); + /** Tests if this source is an entry file. */ + readonly isEntry: bool; + /** Tests if this source is a stdlib file. */ + readonly isLibrary: bool; + } + /** Base class of all declaration statements. */ + export abstract class DeclarationStatement extends Statement { + /** Simple name being declared. */ + name: IdentifierExpression; + /** Array of decorators. */ + decorators: DecoratorNode[] | null; + /** Common flags indicating specific traits. */ + flags: CommonFlags; + /** Tests if this node has the specified flag or flags. */ + is(flag: CommonFlags): bool; + /** Tests if this node has one of the specified flags. */ + isAny(flag: CommonFlags): bool; + /** Sets a specific flag or flags. */ + set(flag: CommonFlags): void; + } + /** Represents an index signature declaration. */ + export class IndexSignatureDeclaration extends DeclarationStatement { + kind: NodeKind; + /** Key type. */ + keyType: NamedTypeNode; + /** Value type. */ + valueType: TypeNode; + } + /** Base class of all variable-like declaration statements. */ + export abstract class VariableLikeDeclarationStatement extends DeclarationStatement { + /** Variable type. */ + type: TypeNode | null; + /** Variable initializer. */ + initializer: Expression | null; + } + /** Represents a block statement. */ + export class BlockStatement extends Statement { + kind: NodeKind; + /** Contained statements. */ + statements: Statement[]; + } + /** Represents a `break` statement. */ + export class BreakStatement extends Statement { + kind: NodeKind; + /** Target label, if applicable. */ + label: IdentifierExpression | null; + } + /** Represents a `class` declaration. */ + export class ClassDeclaration extends DeclarationStatement { + kind: NodeKind; + /** Accepted type parameters. */ + typeParameters: TypeParameterNode[] | null; + /** Base class type being extended, if any. */ + extendsType: NamedTypeNode | null; + /** Interface types being implemented, if any. */ + implementsTypes: NamedTypeNode[] | null; + /** Class member declarations. */ + members: DeclarationStatement[]; + readonly isGeneric: bool; + } + /** Represents a `continue` statement. */ + export class ContinueStatement extends Statement { + kind: NodeKind; + /** Target label, if applicable. */ + label: IdentifierExpression | null; + } + /** Represents a `do` statement. */ + export class DoStatement extends Statement { + kind: NodeKind; + /** Statement being looped over. */ + statement: Statement; + /** Condition when to repeat. */ + condition: Expression; + } + /** Represents an empty statement, i.e., a semicolon terminating nothing. */ + export class EmptyStatement extends Statement { + kind: NodeKind; + } + /** Represents an `enum` declaration. */ + export class EnumDeclaration extends DeclarationStatement { + kind: NodeKind; + /** Enum value declarations. */ + values: EnumValueDeclaration[]; + } + /** Represents a value of an `enum` declaration. */ + export class EnumValueDeclaration extends VariableLikeDeclarationStatement { + kind: NodeKind; + /** Value expression. */ + value: Expression | null; + } + /** Represents an `export import` statement of an interface. */ + export class ExportImportStatement extends Node { + kind: NodeKind; + /** Identifier being imported. */ + name: IdentifierExpression; + /** Identifier being exported. */ + externalName: IdentifierExpression; + } + /** Represents a member of an `export` statement. */ + export class ExportMember extends Node { + kind: NodeKind; + /** Local identifier. */ + localName: IdentifierExpression; + /** Exported identifier. */ + exportedName: IdentifierExpression; + } + /** Represents an `export` statement. */ + export class ExportStatement extends Statement { + kind: NodeKind; + /** Array of members if a set of named exports, or `null` if a file export. */ + members: ExportMember[] | null; + /** Path being exported from, if applicable. */ + path: StringLiteralExpression | null; + /** Normalized path, if `path` is set. */ + normalizedPath: string | null; + /** Mangled internal path being referenced, if `path` is set. */ + internalPath: string | null; + /** Whether this is a declared export. */ + isDeclare: bool; + } + /** Represents an `export default` statement. */ + export class ExportDefaultStatement extends Statement { + kind: NodeKind; + /** Declaration being exported as default. */ + declaration: DeclarationStatement; + } + /** Represents an expression that is used as a statement. */ + export class ExpressionStatement extends Statement { + kind: NodeKind; + /** Expression being used as a statement.*/ + expression: Expression; + } + /** Represents a field declaration within a `class`. */ + export class FieldDeclaration extends VariableLikeDeclarationStatement { + kind: NodeKind; + /** Parameter index if declared as a constructor parameter, otherwise `-1`. */ + parameterIndex: i32; + } + /** Represents a `for` statement. */ + export class ForStatement extends Statement { + kind: NodeKind; + /** + * Initializer statement, if present. + * Either a {@link VariableStatement} or {@link ExpressionStatement}. + */ + initializer: Statement | null; + /** Condition expression, if present. */ + condition: Expression | null; + /** Incrementor expression, if present. */ + incrementor: Expression | null; + /** Statement being looped over. */ + statement: Statement; + } + /** Indicates the kind of an array function. */ + export const enum ArrowKind { + /** Not an arrow function. */ + NONE = 0, + /** Parenthesized parameter list. */ + ARROW_PARENTHESIZED = 1, + /** Single parameter without parenthesis. */ + ARROW_SINGLE = 2 + } + /** Represents a `function` declaration. */ + export class FunctionDeclaration extends DeclarationStatement { + kind: NodeKind; + /** Type parameters, if any. */ + typeParameters: TypeParameterNode[] | null; + /** Function signature. */ + signature: FunctionTypeNode; + /** Body statement. Usually a block. */ + body: Statement | null; + /** Arrow function kind, if applicable. */ + arrowKind: ArrowKind; + readonly isGeneric: bool; + /** Clones this function declaration. */ + clone(): FunctionDeclaration; + } + /** Represents an `if` statement. */ + export class IfStatement extends Statement { + kind: NodeKind; + /** Condition. */ + condition: Expression; + /** Statement executed when condition is `true`. */ + ifTrue: Statement; + /** Statement executed when condition is `false`. */ + ifFalse: Statement | null; + } + /** Represents an `import` declaration part of an {@link ImportStatement}. */ + export class ImportDeclaration extends DeclarationStatement { + kind: NodeKind; + /** Identifier being imported. */ + foreignName: IdentifierExpression; + } + /** Represents an `import` statement. */ + export class ImportStatement extends Statement { + kind: NodeKind; + /** Array of member declarations or `null` if an asterisk import. */ + declarations: ImportDeclaration[] | null; + /** Name of the local namespace, if an asterisk import. */ + namespaceName: IdentifierExpression | null; + /** Path being imported from. */ + path: StringLiteralExpression; + /** Normalized path. */ + normalizedPath: string; + /** Mangled internal path being referenced. */ + internalPath: string; + } + /** Represents an `interfarce` declaration. */ + export class InterfaceDeclaration extends ClassDeclaration { + kind: NodeKind; + } + /** Represents a method declaration within a `class`. */ + export class MethodDeclaration extends FunctionDeclaration { + kind: NodeKind; + } + /** Represents a `namespace` declaration. */ + export class NamespaceDeclaration extends DeclarationStatement { + kind: NodeKind; + /** Array of namespace members. */ + members: Statement[]; + } + /** Represents a `return` statement. */ + export class ReturnStatement extends Statement { + kind: NodeKind; + /** Value expression being returned, if present. */ + value: Expression | null; + } + /** Represents a single `case` within a `switch` statement. */ + export class SwitchCase extends Node { + kind: NodeKind; + /** Label expression. `null` indicates the default case. */ + label: Expression | null; + /** Contained statements. */ + statements: Statement[]; + } + /** Represents a `switch` statement. */ + export class SwitchStatement extends Statement { + kind: NodeKind; + /** Condition expression. */ + condition: Expression; + /** Contained cases. */ + cases: SwitchCase[]; + } + /** Represents a `throw` statement. */ + export class ThrowStatement extends Statement { + kind: NodeKind; + /** Value expression being thrown. */ + value: Expression; + } + /** Represents a `try` statement. */ + export class TryStatement extends Statement { + kind: NodeKind; + /** Contained statements. */ + statements: Statement[]; + /** Exception variable name, if a `catch` clause is present. */ + catchVariable: IdentifierExpression | null; + /** Statements being executed on catch, if a `catch` clause is present. */ + catchStatements: Statement[] | null; + /** Statements being executed afterwards, if a `finally` clause is present. */ + finallyStatements: Statement[] | null; + } + /** Represents a `type` declaration. */ + export class TypeDeclaration extends DeclarationStatement { + kind: NodeKind; + /** Type parameters, if any. */ + typeParameters: TypeParameterNode[] | null; + /** Type being aliased. */ + type: TypeNode; + } + /** Represents a variable declaration part of a {@link VariableStatement}. */ + export class VariableDeclaration extends VariableLikeDeclarationStatement { + kind: NodeKind; + } + /** Represents a variable statement wrapping {@link VariableDeclaration}s. */ + export class VariableStatement extends Statement { + kind: NodeKind; + /** Array of decorators. */ + decorators: DecoratorNode[] | null; + /** Array of member declarations. */ + declarations: VariableDeclaration[]; + } + /** Represents a void statement dropping an expression's value. */ + export class VoidStatement extends Statement { + kind: NodeKind; + /** Expression being dropped. */ + expression: Expression; + } + /** Represents a `while` statement. */ + export class WhileStatement extends Statement { + kind: NodeKind; + /** Condition expression. */ + condition: Expression; + /** Statement being looped over. */ + statement: Statement; + } + /** Finds the first decorator matching the specified kind. */ + export function findDecorator(kind: DecoratorKind, decorators: DecoratorNode[] | null): DecoratorNode | null; + /** Mangles an external to an internal path. */ + export function mangleInternalPath(path: string): string; + /** Tests if the specified type node represents an omitted type. */ + export function isTypeOmitted(type: TypeNode): bool; + +} +declare module 'assemblyscript/src/module' { + /** + * A thin wrapper around Binaryen's C-API. + * @module module + */ /***/ + import { Target } from 'assemblyscript/src/common'; + export type ModuleRef = usize; + export type FunctionTypeRef = usize; + export type FunctionRef = usize; + export type ExpressionRef = usize; + export type GlobalRef = usize; + export type ImportRef = usize; + export type ExportRef = usize; + export type RelooperRef = usize; + export type RelooperBlockRef = usize; + export type Index = u32; + export enum NativeType { + None, + I32, + I64, + F32, + F64, + V128, + Unreachable, + Auto + } + export enum FeatureFlags { + Atomics, + MutableGloabls, + NontrappingFPToInt, + SIMD128, + BulkMemory, + SignExt, + ExceptionHandling + } + export enum ExpressionId { + Invalid, + Block, + If, + Loop, + Break, + Switch, + Call, + CallIndirect, + LocalGet, + LocalSet, + GlobalGet, + GlobalSet, + Load, + Store, + Const, + Unary, + Binary, + Select, + Drop, + Return, + Host, + Nop, + Unreachable, + AtomicCmpxchg, + AtomicRMW, + AtomicWait, + AtomicNotify, + SIMDExtract, + SIMDReplace, + SIMDShuffle, + SIMDBitselect, + SIMDShift, + MemoryInit, + DataDrop, + MemoryCopy, + MemoryFill + } + export enum UnaryOp { + ClzI32, + CtzI32, + PopcntI32, + NegF32, + AbsF32, + CeilF32, + FloorF32, + TruncF32, + NearestF32, + SqrtF32, + EqzI32, + ClzI64, + CtzI64, + PopcntI64, + NegF64, + AbsF64, + CeilF64, + FloorF64, + TruncF64, + NearestF64, + SqrtF64, + EqzI64, + ExtendI32, + ExtendU32, + WrapI64, + TruncF32ToI32, + TruncF32ToI64, + TruncF32ToU32, + TruncF32ToU64, + TruncF64ToI32, + TruncF64ToI64, + TruncF64ToU32, + TruncF64ToU64, + ReinterpretF32, + ReinterpretF64, + ConvertI32ToF32, + ConvertI32ToF64, + ConvertU32ToF32, + ConvertU32ToF64, + ConvertI64ToF32, + ConvertI64ToF64, + ConvertU64ToF32, + ConvertU64ToF64, + PromoteF32, + DemoteF64, + ReinterpretI32, + ReinterpretI64, + ExtendI8ToI32, + ExtendI16ToI32, + ExtendI8ToI64, + ExtendI16ToI64, + ExtendI32ToI64, + SplatVecI8x16, + SplatVecI16x8, + SplatVecI32x4, + SplatVecI64x2, + SplatVecF32x4, + SplatVecF64x2, + NotVec128, + NegVecI8x16, + AnyTrueVecI8x16, + AllTrueVecI8x16, + NegVecI16x8, + AnyTrueVecI16x8, + AllTrueVecI16x8, + NegVecI32x4, + AnyTrueVecI32x4, + AllTrueVecI32x4, + NegVecI64x2, + AnyTrueVecI64x2, + AllTrueVecI64x2, + AbsVecF32x4, + NegVecF32x4, + SqrtVecF32x4, + AbsVecF64x2, + NegVecF64x2, + SqrtVecF64x2, + TruncSatSVecF32x4ToVecI32x4, + TruncSatUVecF32x4ToVecI32x4, + TruncSatSVecF64x2ToVecI64x2, + TruncSatUVecF64x2ToVecI64x2, + ConvertSVecI32x4ToVecF32x4, + ConvertUVecI32x4ToVecF32x4, + ConvertSVecI64x2ToVecF64x2, + ConvertUVecI64x2ToVecF64x2 + } + export enum BinaryOp { + AddI32, + SubI32, + MulI32, + DivI32, + DivU32, + RemI32, + RemU32, + AndI32, + OrI32, + XorI32, + ShlI32, + ShrU32, + ShrI32, + RotlI32, + RotrI32, + EqI32, + NeI32, + LtI32, + LtU32, + LeI32, + LeU32, + GtI32, + GtU32, + GeI32, + GeU32, + AddI64, + SubI64, + MulI64, + DivI64, + DivU64, + RemI64, + RemU64, + AndI64, + OrI64, + XorI64, + ShlI64, + ShrU64, + ShrI64, + RotlI64, + RotrI64, + EqI64, + NeI64, + LtI64, + LtU64, + LeI64, + LeU64, + GtI64, + GtU64, + GeI64, + GeU64, + AddF32, + SubF32, + MulF32, + DivF32, + CopysignF32, + MinF32, + MaxF32, + EqF32, + NeF32, + LtF32, + LeF32, + GtF32, + GeF32, + AddF64, + SubF64, + MulF64, + DivF64, + CopysignF64, + MinF64, + MaxF64, + EqF64, + NeF64, + LtF64, + LeF64, + GtF64, + GeF64, + EqVecI8x16, + NeVecI8x16, + LtSVecI8x16, + LtUVecI8x16, + LeSVecI8x16, + LeUVecI8x16, + GtSVecI8x16, + GtUVecI8x16, + GeSVecI8x16, + GeUVecI8x16, + EqVecI16x8, + NeVecI16x8, + LtSVecI16x8, + LtUVecI16x8, + LeSVecI16x8, + LeUVecI16x8, + GtSVecI16x8, + GtUVecI16x8, + GeSVecI16x8, + GeUVecI16x8, + EqVecI32x4, + NeVecI32x4, + LtSVecI32x4, + LtUVecI32x4, + LeSVecI32x4, + LeUVecI32x4, + GtSVecI32x4, + GtUVecI32x4, + GeSVecI32x4, + GeUVecI32x4, + EqVecF32x4, + NeVecF32x4, + LtVecF32x4, + LeVecF32x4, + GtVecF32x4, + GeVecF32x4, + EqVecF64x2, + NeVecF64x2, + LtVecF64x2, + LeVecF64x2, + GtVecF64x2, + GeVecF64x2, + AndVec128, + OrVec128, + XorVec128, + AddVecI8x16, + AddSatSVecI8x16, + AddSatUVecI8x16, + SubVecI8x16, + SubSatSVecI8x16, + SubSatUVecI8x16, + MulVecI8x16, + AddVecI16x8, + AddSatSVecI16x8, + AddSatUVecI16x8, + SubVecI16x8, + SubSatSVecI16x8, + SubSatUVecI16x8, + MulVecI16x8, + AddVecI32x4, + SubVecI32x4, + MulVecI32x4, + AddVecI64x2, + SubVecI64x2, + AddVecF32x4, + SubVecF32x4, + MulVecF32x4, + DivVecF32x4, + MinVecF32x4, + MaxVecF32x4, + AddVecF64x2, + SubVecF64x2, + MulVecF64x2, + DivVecF64x2, + MinVecF64x2, + MaxVecF64x2 + } + export enum HostOp { + MemorySize, + MemoryGrow + } + export enum AtomicRMWOp { + Add, + Sub, + And, + Or, + Xor, + Xchg + } + export enum SIMDExtractOp { + ExtractLaneSVecI8x16, + ExtractLaneUVecI8x16, + ExtractLaneSVecI16x8, + ExtractLaneUVecI16x8, + ExtractLaneVecI32x4, + ExtractLaneVecI64x2, + ExtractLaneVecF32x4, + ExtractLaneVecF64x2 + } + export enum SIMDReplaceOp { + ReplaceLaneVecI8x16, + ReplaceLaneVecI16x8, + ReplaceLaneVecI32x4, + ReplaceLaneVecI64x2, + ReplaceLaneVecF32x4, + ReplaceLaneVecF64x2 + } + export enum SIMDShiftOp { + ShlVecI8x16, + ShrSVecI8x16, + ShrUVecI8x16, + ShlVecI16x8, + ShrSVecI16x8, + ShrUVecI16x8, + ShlVecI32x4, + ShrSVecI32x4, + ShrUVecI32x4, + ShlVecI64x2, + ShrSVecI64x2, + ShrUVecI64x2 + } + export class MemorySegment { + buffer: Uint8Array; + offset: I64; + static create(buffer: Uint8Array, offset: I64): MemorySegment; + } + export class Module { + ref: ModuleRef; + private lit; + static create(): Module; + static createFrom(buffer: Uint8Array): Module; + private constructor(); + addFunctionType(name: string, result: NativeType, paramTypes: NativeType[] | null): FunctionRef; + getFunctionTypeBySignature(result: NativeType, paramTypes: NativeType[] | null): FunctionTypeRef; + removeFunctionType(name: string): void; + i32(value: i32): ExpressionRef; + i64(valueLow: i32, valueHigh?: i32): ExpressionRef; + f32(value: f32): ExpressionRef; + f64(value: f64): ExpressionRef; + v128(bytes: Uint8Array): ExpressionRef; + unary(op: UnaryOp, expr: ExpressionRef): ExpressionRef; + binary(op: BinaryOp, left: ExpressionRef, right: ExpressionRef): ExpressionRef; + host(op: HostOp, name?: string | null, operands?: ExpressionRef[] | null): ExpressionRef; + local_get(index: i32, type: NativeType): ExpressionRef; + local_tee(index: i32, value: ExpressionRef): ExpressionRef; + global_get(name: string, type: NativeType): ExpressionRef; + load(bytes: Index, signed: bool, ptr: ExpressionRef, type: NativeType, offset?: Index, align?: Index): ExpressionRef; + store(bytes: Index, ptr: ExpressionRef, value: ExpressionRef, type: NativeType, offset?: Index, align?: Index): ExpressionRef; + atomic_load(bytes: Index, ptr: ExpressionRef, type: NativeType, offset?: Index): ExpressionRef; + atomic_store(bytes: Index, ptr: ExpressionRef, value: ExpressionRef, type: NativeType, offset?: Index): ExpressionRef; + atomic_rmw(op: AtomicRMWOp, bytes: Index, offset: Index, ptr: ExpressionRef, value: ExpressionRef, type: NativeType): ExpressionRef; + atomic_cmpxchg(bytes: Index, offset: Index, ptr: ExpressionRef, expected: ExpressionRef, replacement: ExpressionRef, type: NativeType): ExpressionRef; + atomic_wait(ptr: ExpressionRef, expected: ExpressionRef, timeout: ExpressionRef, expectedType: NativeType): ExpressionRef; + atomic_notify(ptr: ExpressionRef, notifyCount: ExpressionRef): ExpressionRef; + local_set(index: Index, value: ExpressionRef): ExpressionRef; + global_set(name: string, value: ExpressionRef): ExpressionRef; + block(label: string | null, children: ExpressionRef[], type?: NativeType): ExpressionRef; + br(label: string | null, condition?: ExpressionRef, value?: ExpressionRef): ExpressionRef; + drop(expression: ExpressionRef): ExpressionRef; + loop(label: string | null, body: ExpressionRef): ExpressionRef; + if(condition: ExpressionRef, ifTrue: ExpressionRef, ifFalse?: ExpressionRef): ExpressionRef; + nop(): ExpressionRef; + return(expression?: ExpressionRef): ExpressionRef; + select(ifTrue: ExpressionRef, ifFalse: ExpressionRef, condition: ExpressionRef): ExpressionRef; + switch(names: string[], defaultName: string | null, condition: ExpressionRef, value?: ExpressionRef): ExpressionRef; + call(target: string, operands: ExpressionRef[] | null, returnType: NativeType): ExpressionRef; + call_indirect(index: ExpressionRef, operands: ExpressionRef[] | null, typeName: string): ExpressionRef; + unreachable(): ExpressionRef; + memory_copy(dest: ExpressionRef, source: ExpressionRef, size: ExpressionRef): ExpressionRef; + memory_fill(dest: ExpressionRef, value: ExpressionRef, size: ExpressionRef): ExpressionRef; + simd_extract(op: SIMDExtractOp, vec: ExpressionRef, idx: u8): ExpressionRef; + simd_replace(op: SIMDReplaceOp, vec: ExpressionRef, idx: u8, value: ExpressionRef): ExpressionRef; + simd_shuffle(vec1: ExpressionRef, vec2: ExpressionRef, mask: Uint8Array): ExpressionRef; + simd_bitselect(vec1: ExpressionRef, vec2: ExpressionRef, cond: ExpressionRef): ExpressionRef; + simd_shift(op: SIMDShiftOp, vec: ExpressionRef, shift: ExpressionRef): ExpressionRef; + addGlobal(name: string, type: NativeType, mutable: bool, initializer: ExpressionRef): GlobalRef; + removeGlobal(name: string): void; + addFunction(name: string, type: FunctionTypeRef, varTypes: NativeType[] | null, body: ExpressionRef): FunctionRef; + removeFunction(name: string): void; + private hasTemporaryFunction; + addTemporaryFunction(result: NativeType, paramTypes: NativeType[] | null, body: ExpressionRef): FunctionRef; + removeTemporaryFunction(): void; + addFunctionExport(internalName: string, externalName: string): ExportRef; + addTableExport(internalName: string, externalName: string): ExportRef; + addMemoryExport(internalName: string, externalName: string): ExportRef; + addGlobalExport(internalName: string, externalName: string): ExportRef; + removeExport(externalName: string): void; + addFunctionImport(internalName: string, externalModuleName: string, externalBaseName: string, functionType: FunctionTypeRef): ImportRef; + addTableImport(internalName: string, externalModuleName: string, externalBaseName: string): ImportRef; + addMemoryImport(internalName: string, externalModuleName: string, externalBaseName: string, shared?: bool): ImportRef; + addGlobalImport(internalName: string, externalModuleName: string, externalBaseName: string, globalType: NativeType): ImportRef; + /** Unlimited memory constant. */ + static readonly UNLIMITED_MEMORY: Index; + setMemory(initial: Index, maximum: Index, segments: MemorySegment[], target: Target, exportName?: string | null, shared?: bool): void; + setFunctionTable(initial: Index, maximum: Index, funcs: string[]): void; + setStart(func: FunctionRef): void; + getOptimizeLevel(): i32; + setOptimizeLevel(level?: i32): void; + getShrinkLevel(): i32; + setShrinkLevel(level?: i32): void; + setDebugInfo(on?: bool): void; + getFeatures(): BinaryenFeatureFlags; + setFeatures(featureFlags: BinaryenFeatureFlags): void; + optimize(func?: FunctionRef): void; + runPasses(passes: string[], func?: FunctionRef): void; + private cachedPrecomputeNames; + precomputeExpression(expr: ExpressionRef): ExpressionRef; + validate(): bool; + interpret(): void; + toBinary(sourceMapUrl: string | null): BinaryModule; + toText(): string; + toAsmjs(): string; + private cachedStrings; + private allocStringCached; + dispose(): void; + createRelooper(): Relooper; + cloneExpression(expr: ExpressionRef, noSideEffects?: bool, maxDepth?: i32): ExpressionRef; + addDebugInfoFile(name: string): Index; + getDebugInfoFile(index: Index): string | null; + setDebugLocation(func: FunctionRef, expr: ExpressionRef, fileIndex: Index, lineNumber: Index, columnNumber: Index): void; + } + export function getExpressionId(expr: ExpressionRef): ExpressionId; + export function getExpressionType(expr: ExpressionRef): NativeType; + export function getConstValueI32(expr: ExpressionRef): i32; + export function getConstValueI64Low(expr: ExpressionRef): i32; + export function getConstValueI64High(expr: ExpressionRef): i32; + export function getConstValueF32(expr: ExpressionRef): f32; + export function getConstValueF64(expr: ExpressionRef): f32; + export function getLocalGetIndex(expr: ExpressionRef): Index; + export function getLocalSetIndex(expr: ExpressionRef): Index; + export function getLocalSetValue(expr: ExpressionRef): ExpressionRef; + export function isLocalTee(expr: ExpressionRef): bool; + export function getGlobalGetName(expr: ExpressionRef): string | null; + export function getBinaryOp(expr: ExpressionRef): BinaryOp; + export function getBinaryLeft(expr: ExpressionRef): ExpressionRef; + export function getBinaryRight(expr: ExpressionRef): ExpressionRef; + export function getUnaryOp(expr: ExpressionRef): UnaryOp; + export function getUnaryValue(expr: ExpressionRef): ExpressionRef; + export function getLoadBytes(expr: ExpressionRef): u32; + export function getLoadOffset(expr: ExpressionRef): u32; + export function getLoadPtr(expr: ExpressionRef): ExpressionRef; + export function isLoadSigned(expr: ExpressionRef): bool; + export function getStoreBytes(expr: ExpressionRef): u32; + export function getStoreOffset(expr: ExpressionRef): u32; + export function getStorePtr(expr: ExpressionRef): ExpressionRef; + export function getStoreValue(expr: ExpressionRef): ExpressionRef; + export function getBlockName(expr: ExpressionRef): string | null; + export function getBlockChildCount(expr: ExpressionRef): Index; + export function getBlockChild(expr: ExpressionRef, index: Index): ExpressionRef; + export function getIfCondition(expr: ExpressionRef): ExpressionRef; + export function getIfTrue(expr: ExpressionRef): ExpressionRef; + export function getIfFalse(expr: ExpressionRef): ExpressionRef; + export function getLoopName(expr: ExpressionRef): string | null; + export function getLoopBody(expr: ExpressionRef): ExpressionRef; + export function getBreakName(expr: ExpressionRef): string | null; + export function getBreakCondition(expr: ExpressionRef): ExpressionRef; + export function getSelectThen(expr: ExpressionRef): ExpressionRef; + export function getSelectElse(expr: ExpressionRef): ExpressionRef; + export function getSelectCondition(expr: ExpressionRef): ExpressionRef; + export function getDropValue(expr: ExpressionRef): ExpressionRef; + export function getReturnValue(expr: ExpressionRef): ExpressionRef; + export function getCallTarget(expr: ExpressionRef): string | null; + export function getCallOperandCount(expr: ExpressionRef): i32; + export function getCallOperand(expr: ExpressionRef, index: Index): ExpressionRef; + export function getHostOp(expr: ExpressionRef): ExpressionRef; + export function getHostOperandCount(expr: ExpressionRef): Index; + export function getHostOperand(expr: ExpressionRef, index: Index): ExpressionRef; + export function getHostName(expr: ExpressionRef): string | null; + export function getFunctionBody(func: FunctionRef): ExpressionRef; + export function getFunctionName(func: FunctionRef): string | null; + export function getFunctionParamCount(func: FunctionRef): Index; + export function getFunctionParamType(func: FunctionRef, index: Index): NativeType; + export function getFunctionResultType(func: FunctionRef): NativeType; + export class Relooper { + module: Module; + ref: RelooperRef; + static create(module: Module): Relooper; + private constructor(); + addBlock(code: ExpressionRef): RelooperBlockRef; + addBranch(from: RelooperBlockRef, to: RelooperBlockRef, condition?: ExpressionRef, code?: ExpressionRef): void; + addBlockWithSwitch(code: ExpressionRef, condition: ExpressionRef): RelooperBlockRef; + addBranchForSwitch(from: RelooperBlockRef, to: RelooperBlockRef, indexes: i32[], code?: ExpressionRef): void; + renderAndDispose(entry: RelooperBlockRef, labelHelper: Index): ExpressionRef; + } + export function readString(ptr: usize): string | null; + /** Result structure of {@link Module#toBinary}. */ + export class BinaryModule { + /** WebAssembly binary. */ + output: Uint8Array; + /** Source map, if generated. */ + sourceMap: string | null; + } + /** Tests if an expression needs an explicit 'unreachable' when it is the terminating statement. */ + export function needsExplicitUnreachable(expr: ExpressionRef): bool; + /** Traverses all expression members of an expression, calling the given visitor. */ + export function traverse(expr: ExpressionRef, data: T, visit: (expr: ExpressionRef, data: T) => void): bool; + +} +declare module 'assemblyscript/src/types' { + /** + * Mappings from AssemblyScript types to WebAssembly types. + * @module types + */ /***/ + import { Class, FunctionTarget, Program } from 'assemblyscript/src/program'; + import { NativeType, ExpressionRef, Module } from 'assemblyscript/src/module'; + /** Indicates the kind of a type. */ + export const enum TypeKind { + /** An 8-bit signed integer. */ + I8 = 0, + /** A 16-bit signed integer. */ + I16 = 1, + /** A 32-bit signed integer. */ + I32 = 2, + /** A 64-bit signed integer. */ + I64 = 3, + /** A 32-bit/64-bit signed integer, depending on the target. */ + ISIZE = 4, + /** An 8-bit unsigned integer. */ + U8 = 5, + /** A 16-bit unsigned integer. */ + U16 = 6, + /** A 32-bit unsigned integer. Also the base of function types. */ + U32 = 7, + /** A 64-bit unsigned integer. */ + U64 = 8, + /** A 32-bit/64-bit unsigned integer, depending on the target. Also the base of class types. */ + USIZE = 9, + /** A 1-bit unsigned integer. */ + BOOL = 10, + /** A 32-bit float. */ + F32 = 11, + /** A 64-bit double. */ + F64 = 12, + /** A 128-bit vector. */ + V128 = 13, + /** No return type. */ + VOID = 14 + } + /** Indicates capabilities of a type. */ + export const enum TypeFlags { + NONE = 0, + /** Is a signed type that can represent negative values. */ + SIGNED = 1, + /** Is an unsigned type that cannot represent negative values. */ + UNSIGNED = 2, + /** Is an integer type. */ + INTEGER = 4, + /** Is a floating point type. */ + FLOAT = 8, + /** Is a pointer type. */ + POINTER = 16, + /** Is smaller than 32-bits. */ + SHORT = 32, + /** Is larger than 32-bits. */ + LONG = 64, + /** Is a value type. */ + VALUE = 128, + /** Is a reference type. */ + REFERENCE = 256, + /** Is a nullable type. */ + NULLABLE = 512, + /** Is a vector type. */ + VECTOR = 1024 + } + /** Represents a resolved type. */ + export class Type { + /** Type kind. */ + kind: TypeKind; + /** Type flags. */ + flags: TypeFlags; + /** Size in bits. */ + size: u32; + /** Size in bytes. */ + byteSize: i32; + /** Underlying class reference, if a class type. */ + classReference: Class | null; + /** Underlying signature reference, if a function type. */ + signatureReference: Signature | null; + /** Respective non-nullable type, if nullable. */ + nonNullableType: Type; + /** Cached nullable type, if non-nullable. */ + private cachedNullableType; + /** Constructs a new resolved type. */ + constructor(kind: TypeKind, flags: TypeFlags, size: u32); + /** Returns the closest int type representing this type. */ + readonly intType: Type; + /** Substitutes this type with the auto type if this type is void. */ + readonly exceptVoid: Type; + /** Gets this type's logarithmic alignment in memory. */ + readonly alignLog2: i32; + /** Tests if this is a managed type that needs GC hooks. */ + readonly isManaged: bool; + /** Tests if this is a class type explicitly annotated as unmanaged. */ + readonly isUnmanaged: bool; + /** Computes the sign-extending shift in the target type. */ + computeSmallIntegerShift(targetType: Type): u32; + /** Computes the truncating mask in the target type. */ + computeSmallIntegerMask(targetType: Type): u32; + /** Tests if this type has (all of) the specified flags. */ + is(flags: TypeFlags): bool; + /** Tests if this type has any of the specified flags. */ + isAny(flags: TypeFlags): bool; + /** Composes a class type from this type and a class. */ + asClass(classType: Class): Type; + /** Composes a function type from this type and a function. */ + asFunction(signature: Signature): Type; + /** Composes the respective nullable type of this type. */ + asNullable(): Type; + /** Tests if a value of this type is assignable to the target type incl. implicit conversion. */ + isAssignableTo(target: Type, signednessIsRelevant?: bool): bool; + /** Tests if a value of this type is assignable to the target type excl. implicit conversion. */ + isStrictlyAssignableTo(target: Type, signednessIsRelevant?: bool): bool; + /** Determines the common denominator type of two types, if there is any. */ + static commonDenominator(left: Type, right: Type, signednessIsImportant: bool): Type | null; + /** Converts this type to a string. */ + toString(): string; + /** Converts this type to its respective native type. */ + toNativeType(): NativeType; + /** Converts this type to its native `0` value. */ + toNativeZero(module: Module): ExpressionRef; + /** Converts this type to its native `1` value. */ + toNativeOne(module: Module): ExpressionRef; + /** Converts this type to its native `-1` value. */ + toNativeNegOne(module: Module): ExpressionRef; + /** Converts this type to its signature string. */ + toSignatureString(): string; + /** An 8-bit signed integer. */ + static readonly i8: Type; + /** A 16-bit signed integer. */ + static readonly i16: Type; + /** A 32-bit signed integer. */ + static readonly i32: Type; + /** A 64-bit signed integer. */ + static readonly i64: Type; + /** A 32-bit signed size. WASM32 only. */ + static readonly isize32: Type; + /** A 64-bit signed size. WASM64 only. */ + static readonly isize64: Type; + /** An 8-bit unsigned integer. */ + static readonly u8: Type; + /** A 16-bit unsigned integer. */ + static readonly u16: Type; + /** A 32-bit unsigned integer. */ + static readonly u32: Type; + /** A 64-bit unsigned integer. */ + static readonly u64: Type; + /** A 32-bit unsigned size. WASM32 only. */ + static readonly usize32: Type; + /** A 64-bit unsigned size. WASM64 only. */ + static readonly usize64: Type; + /** A 1-bit unsigned integer. */ + static readonly bool: Type; + /** A 32-bit float. */ + static readonly f32: Type; + /** A 64-bit float. */ + static readonly f64: Type; + /** A 128-bit vector. */ + static readonly v128: Type; + /** No return type. */ + static readonly void: Type; + /** Alias of i32 indicating type inference of locals and globals with just an initializer. */ + static readonly auto: Type; + } + /** Converts an array of types to an array of native types. */ + export function typesToNativeTypes(types: Type[]): NativeType[]; + /** Converts an array of types to its combined string representation. */ + export function typesToString(types: Type[]): string; + /** Represents a fully resolved function signature. */ + export class Signature { + /** Parameter types, if any, excluding `this`. */ + parameterTypes: Type[]; + /** Parameter names, if known, excluding `this`. */ + parameterNames: string[] | null; + /** Number of required parameters excluding `this`. Other parameters are considered optional. */ + requiredParameters: i32; + /** Return type. */ + returnType: Type; + /** This type, if an instance signature. */ + thisType: Type | null; + /** Whether the last parameter is a rest parameter. */ + hasRest: bool; + /** Cached {@link FunctionTarget}. */ + cachedFunctionTarget: FunctionTarget | null; + /** Respective function type. */ + type: Type; + /** Constructs a new signature. */ + constructor(parameterTypes?: Type[] | null, returnType?: Type | null, thisType?: Type | null); + asFunctionTarget(program: Program): FunctionTarget; + /** Gets the known or, alternatively, generic parameter name at the specified index. */ + getParameterName(index: i32): string; + /** Tests if a value of this function type is assignable to a target of the specified function type. */ + isAssignableTo(target: Signature): bool; + /** Converts a signature to a function type string. */ + static makeSignatureString(parameterTypes: Type[] | null, returnType: Type, thisType?: Type | null): string; + /** Converts this signature to a function type string. */ + toSignatureString(): string; + /** Converts this signature to a string. */ + toString(): string; + } + /** Gets the cached default parameter name for the specified index. */ + export function getDefaultParameterName(index: i32): string; + +} +declare module 'assemblyscript/src/flow' { + /** + * A control flow analyzer. + * @module flow + */ /***/ + import { Type } from 'assemblyscript/src/types'; + import { Local, Function, Element } from 'assemblyscript/src/program'; + import { ExpressionRef } from 'assemblyscript/src/module'; + import { Node } from 'assemblyscript/src/ast'; + /** Control flow flags indicating specific conditions. */ + export const enum FlowFlags { + /** No specific conditions. */ + NONE = 0, + /** This flow returns. */ + RETURNS = 1, + /** This flow returns a wrapped value. */ + RETURNS_WRAPPED = 2, + /** This flow returns a non-null value. */ + RETURNS_NONNULL = 4, + /** This flow throws. */ + THROWS = 8, + /** This flow breaks. */ + BREAKS = 16, + /** This flow continues. */ + CONTINUES = 32, + /** This flow allocates. Constructors only. */ + ALLOCATES = 64, + /** This flow calls super. Constructors only. */ + CALLS_SUPER = 128, + /** This flow terminates (returns, throws or continues). */ + TERMINATES = 256, + /** This flow conditionally returns in a child flow. */ + CONDITIONALLY_RETURNS = 512, + /** This flow conditionally throws in a child flow. */ + CONDITIONALLY_THROWS = 1024, + /** This flow conditionally terminates in a child flow. */ + CONDITIONALLY_TERMINATES = 2048, + /** This flow conditionally breaks in a child flow. */ + CONDITIONALLY_BREAKS = 4096, + /** This flow conditionally continues in a child flow. */ + CONDITIONALLY_CONTINUES = 8192, + /** This flow conditionally allocates in a child flow. Constructors only. */ + CONDITIONALLY_ALLOCATES = 16384, + /** This is an inlining flow. */ + INLINE_CONTEXT = 32768, + /** This is a flow with explicitly disabled bounds checking. */ + UNCHECKED_CONTEXT = 65536, + /** Any categorical flag. */ + ANY_CATEGORICAL = 511, + /** Any conditional flag. */ + ANY_CONDITIONAL = 30208 + } + /** Flags indicating the current state of a local. */ + export enum LocalFlags { + /** No specific conditions. */ + NONE = 0, + /** Local is constant. */ + CONSTANT = 1, + /** Local is properly wrapped. Relevant for small integers. */ + WRAPPED = 2, + /** Local is non-null. */ + NONNULL = 4, + /** Local is read from. */ + READFROM = 8, + /** Local is written to. */ + WRITTENTO = 16, + /** Local is retained. */ + RETAINED = 32, + /** Local is conditionally read from. */ + CONDITIONALLY_READFROM = 64, + /** Local is conditionally written to. */ + CONDITIONALLY_WRITTENTO = 128, + /** Local must be conditionally retained. */ + CONDITIONALLY_RETAINED = 256, + /** Any categorical flag. */ + ANY_CATEGORICAL = 63, + /** Any conditional flag. */ + ANY_CONDITIONAL = 480, + /** Any retained flag. */ + ANY_RETAINED = 288 + } + export namespace LocalFlags { + function join(left: LocalFlags, right: LocalFlags): LocalFlags; + } + /** Flags indicating the current state of a field. */ + export enum FieldFlags { + /** No specific conditions. */ + NONE = 0, + /** Field is initialized. Relevant in constructors. */ + INITIALIZED = 1, + /** Field is conditionally initialized. Relevant in constructors. */ + CONDITIONALLY_INITIALIZED = 2, + /** Any categorical flag. */ + ANY_CATEGORICAL = 1, + /** Any conditional flag. */ + ANY_CONDITIONAL = 2 + } + export namespace FieldFlags { + function join(left: FieldFlags, right: FieldFlags): FieldFlags; + } + /** A control flow evaluator. */ + export class Flow { + /** Parent flow. */ + parent: Flow | null; + /** Flow flags indicating specific conditions. */ + flags: FlowFlags; + /** Function this flow belongs to. */ + parentFunction: Function; + /** The label we break to when encountering a continue statement. */ + continueLabel: string | null; + /** The label we break to when encountering a break statement. */ + breakLabel: string | null; + /** The current return type. */ + returnType: Type; + /** The current contextual type arguments. */ + contextualTypeArguments: Map | null; + /** Scoped local variables. */ + scopedLocals: Map | null; + /** Local flags. */ + localFlags: LocalFlags[]; + /** Field flags. Relevant in constructors. */ + fieldFlags: Map | null; + /** Function being inlined, when inlining. */ + inlineFunction: Function | null; + /** The label we break to when encountering a return statement, when inlining. */ + inlineReturnLabel: string | null; + /** Creates the parent flow of the specified function. */ + static create(parentFunction: Function): Flow; + /** Creates an inline flow within `parentFunction`. */ + static createInline(parentFunction: Function, inlineFunction: Function): Flow; + private constructor(); + /** Gets the actual function being compiled, The inlined function when inlining, otherwise the parent function. */ + readonly actualFunction: Function; + /** Tests if this flow has the specified flag or flags. */ + is(flag: FlowFlags): bool; + /** Tests if this flow has one of the specified flags. */ + isAny(flag: FlowFlags): bool; + /** Sets the specified flag or flags. */ + set(flag: FlowFlags): void; + /** Unsets the specified flag or flags. */ + unset(flag: FlowFlags): void; + /** Forks this flow to a child flow. */ + fork(): Flow; + /** Gets a free temporary local of the specified type. */ + getTempLocal(type: Type, except?: Set | null): Local; + /** Gets a local that sticks around until this flow is exited, and then released. */ + getAutoreleaseLocal(type: Type, except?: Set | null): Local; + /** Frees the temporary local for reuse. */ + freeTempLocal(local: Local): void; + /** Gets and immediately frees a temporary local of the specified type. */ + getAndFreeTempLocal(type: Type, except?: Set | null): Local; + /** Gets the scoped local of the specified name. */ + getScopedLocal(name: string): Local | null; + /** Adds a new scoped local of the specified name. */ + addScopedLocal(name: string, type: Type, except?: Set | null): Local; + /** Adds a new scoped alias for the specified local. For example `super` aliased to the `this` local. */ + addScopedAlias(name: string, type: Type, index: i32, reportNode?: Node | null): Local; + /** Frees this flow's scoped variables and returns its parent flow. */ + freeScopedLocals(): void; + /** Looks up the local of the specified name in the current scope. */ + lookupLocal(name: string): Local | null; + /** Looks up the element with the specified name relative to the scope of this flow. */ + lookup(name: string): Element | null; + /** Tests if the local at the specified index has the specified flag or flags. */ + isLocalFlag(index: i32, flag: LocalFlags, defaultIfInlined?: bool): bool; + /** Tests if the local at the specified index has any of the specified flags. */ + isAnyLocalFlag(index: i32, flag: LocalFlags, defaultIfInlined?: bool): bool; + /** Sets the specified flag or flags on the local at the specified index. */ + setLocalFlag(index: i32, flag: LocalFlags): void; + /** Unsets the specified flag or flags on the local at the specified index. */ + unsetLocalFlag(index: i32, flag: LocalFlags): void; + /** Pushes a new break label to the stack, for example when entering a loop that one can `break` from. */ + pushBreakLabel(): string; + /** Pops the most recent break label from the stack. */ + popBreakLabel(): void; + /** Inherits flags and local wrap states from the specified flow (e.g. blocks). */ + inherit(other: Flow): void; + /** Inherits categorical flags as conditional flags from the specified flow (e.g. then without else). */ + inheritConditional(other: Flow): void; + /** Inherits mutual flags and local wrap states from the specified flows (e.g. then with else). */ + inheritMutual(left: Flow, right: Flow): void; + /** Checks if an expression of the specified type is known to be non-null, even if the type might be nullable. */ + isNonnull(expr: ExpressionRef, type: Type): bool; + /** Updates local states to reflect that this branch is only taken when `expr` is true-ish. */ + inheritNonnullIfTrue(expr: ExpressionRef): void; + /** Updates local states to reflect that this branch is only taken when `expr` is false-ish. */ + inheritNonnullIfFalse(expr: ExpressionRef): void; + /** + * Tests if an expression can possibly overflow in the context of this flow. Assumes that the + * expression might already have overflown and returns `false` only if the operation neglects + * any possible combination of garbage bits being present. + */ + canOverflow(expr: ExpressionRef, type: Type): bool; + toString(): string; + } + /** Finds all indexes of locals used in the specified expression. */ + export function findUsedLocals(expr: ExpressionRef, used?: Set): Set; + +} +declare module 'assemblyscript/src/resolver' { + /** + * Resolve infrastructure to obtain types and elements. + * @module resolver + */ /***/ + import { DiagnosticEmitter } from 'assemblyscript/src/diagnostics'; + import { Program, Element, Class, ClassPrototype, Function, FunctionPrototype, Global } from 'assemblyscript/src/program'; + import { Flow } from 'assemblyscript/src/flow'; + import { TypeNode, TypeName, TypeParameterNode, Node, IdentifierExpression, CallExpression, ElementAccessExpression, PropertyAccessExpression, LiteralExpression, AssertionExpression, Expression, UnaryPrefixExpression, UnaryPostfixExpression, BinaryExpression, ThisExpression, SuperExpression } from 'assemblyscript/src/ast'; + import { Type } from 'assemblyscript/src/types'; + /** Indicates whether errors are reported or not. */ + export enum ReportMode { + /** Report errors. */ + REPORT = 0, + /** Swallow errors. */ + SWALLOW = 1 + } + /** Provides tools to resolve types and expressions. */ + export class Resolver extends DiagnosticEmitter { + /** The program this resolver belongs to. */ + program: Program; + /** Target expression of the previously resolved property or element access. */ + currentThisExpression: Expression | null; + /** Element expression of the previously resolved element access. */ + currentElementExpression: Expression | null; + /** Constructs the resolver for the specified program. */ + constructor( + /** The program to construct a resolver for. */ + program: Program); + /** Resolves a {@link CommonTypeNode} to a concrete {@link Type}. */ + resolveType( + /** The type to resolve. */ + node: TypeNode, + /** Relative context. */ + context: Element, + /** Type arguments inherited through context, i.e. `T`. */ + contextualTypeArguments?: Map | null, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Type | null; + private resolveBuiltinNativeType; + private resolveBuiltinIndexofType; + private resolveBuiltinValueofType; + /** Resolves a type name to the program element it refers to. */ + resolveTypeName( + /** The type name to resolve. */ + typeName: TypeName, + /** Relative context. */ + context: Element, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves an array of type arguments to concrete types. */ + resolveTypeArguments( + /** Actual type parameter nodes. */ + typeParameters: TypeParameterNode[], + /** Type arguments provided. */ + typeArgumentNodes: TypeNode[] | null, + /** Relative context. */ + context: Element, + /** Type arguments inherited through context, i.e. `T`. */ + contextualTypeArguments?: Map, + /** Alternative report node in case of empty type arguments. */ + alternativeReportNode?: Node | null, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Type[] | null; + /** Resolves an identifier to the program element it refers to. */ + resolveIdentifier( + /** The expression to resolve. */ + identifier: IdentifierExpression, + /** Optional flow to search for scoped locals. */ + flow: Flow | null, + /** Optional context to search. */ + context: Element | null, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves a lazily compiled global, i.e. a static class field. */ + ensureResolvedLazyGlobal(global: Global, reportMode?: ReportMode): bool; + /** Resolves a property access expression to the program element it refers to. */ + resolvePropertyAccessExpression( + /** The expression to resolve. */ + propertyAccess: PropertyAccessExpression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves an element access expression to the program element it refers to. */ + resolveElementAccessExpression( + /** The expression to resolve. */ + elementAccess: ElementAccessExpression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Determines the final type of an integer literal given the specified contextual type. */ + determineIntegerLiteralType( + /** Integer literal value. */ + intValue: I64, + /** Current contextual type. */ + contextualType: Type): Type; + /** Resolves any expression to the program element it refers to. */ + resolveExpression( + /** The expression to resolve. */ + expression: Expression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType?: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves an assertion expression to the program element it refers to. */ + resolveAssertionExpression( + /** The expression to resolve. */ + expression: AssertionExpression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType?: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves an unary prefix expression to the program element it refers to. */ + resolveUnaryPrefixExpression( + /** The expression to resolve. */ + expression: UnaryPrefixExpression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType?: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves an unary postfix expression to the program element it refers to. */ + resolveUnaryPostfixExpression( + /** The expression to resolve. */ + expression: UnaryPostfixExpression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType?: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves a binary expression to the program element it refers to. */ + resolveBinaryExpression( + /** The expression to resolve. */ + expression: BinaryExpression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType?: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves a this expression to the program element it refers to. */ + resolveThisExpression( + /** The expression to resolve. */ + expression: ThisExpression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType?: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves a super expression to the program element it refers to. */ + resolveSuperExpression( + /** The expression to resolve. */ + expression: SuperExpression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType?: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves a literal expression to the program element it refers to. */ + resolveLiteralExpression( + /** The expression to resolve. */ + expression: LiteralExpression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType?: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves a call expression to the program element it refers to. */ + resolveCallExpression( + /** The expression to resolve. */ + expression: CallExpression, + /** Current flow. */ + flow: Flow, + /** Current contextual type. */ + contextualType?: Type, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Element | null; + /** Resolves a function prototype using the specified concrete type arguments. */ + resolveFunction( + /** The prototype of the function. */ + prototype: FunctionPrototype, + /** Concrete type arguments. */ + typeArguments: Type[] | null, + /** Type arguments inherited through context, i.e. `T`. */ + contextualTypeArguments?: Map, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Function | null; + /** Resolves a function prototypeby first resolving the specified type arguments. */ + resolveFunctionInclTypeArguments( + /** The prototype of the function. */ + prototype: FunctionPrototype, + /** Type arguments provided. */ + typeArgumentNodes: TypeNode[] | null, + /** Relative context. Type arguments are resolved from here. */ + context: Element, + /** Type arguments inherited through context, i.e. `T`. */ + contextualTypeArguments: Map, + /** The node to use when reporting intermediate errors. */ + reportNode: Node, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Function | null; + /** Resolves a class prototype using the specified concrete type arguments. */ + resolveClass( + /** The prototype of the class. */ + prototype: ClassPrototype, + /** Concrete type arguments. */ + typeArguments: Type[] | null, + /** Type arguments inherited through context, i.e. `T`. */ + contextualTypeArguments?: Map, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Class | null; + /** Resolves a class prototype by first resolving the specified type arguments. */ + resolveClassInclTypeArguments( + /** The prototype of the class. */ + prototype: ClassPrototype, + /** Type argument nodes provided. */ + typeArgumentNodes: TypeNode[] | null, + /** Relative context. Type arguments are resolved from here. */ + context: Element, + /** Type arguments inherited through context, i.e. `T`. */ + contextualTypeArguments: Map, + /** The node to use when reporting intermediate errors. */ + reportNode: Node, + /** How to proceed with eventualy diagnostics. */ + reportMode?: ReportMode): Class | null; + } + +} +declare module 'assemblyscript/src/program' { + /** + * AssemblyScript's intermediate representation describing a program's elements. + * @module program + */ /***/ + import { CommonFlags } from 'assemblyscript/src/common'; + import { Options } from 'assemblyscript/src/compiler'; + import { DiagnosticMessage, DiagnosticEmitter } from 'assemblyscript/src/diagnostics'; + import { Type, TypeKind, Signature } from 'assemblyscript/src/types'; + import { Source, Range, DecoratorNode, DecoratorKind, TypeParameterNode, TypeNode, NamedTypeNode, FunctionTypeNode, ArrowKind, Expression, IdentifierExpression, Statement, ClassDeclaration, DeclarationStatement, EnumDeclaration, EnumValueDeclaration, FieldDeclaration, FunctionDeclaration, InterfaceDeclaration, NamespaceDeclaration, TypeDeclaration, VariableDeclaration, VariableLikeDeclarationStatement } from 'assemblyscript/src/ast'; + import { Module, FunctionRef } from 'assemblyscript/src/module'; + import { Resolver } from 'assemblyscript/src/resolver'; + import { Flow } from 'assemblyscript/src/flow'; + /** Represents the kind of an operator overload. */ + export enum OperatorKind { + INVALID = 0, + INDEXED_GET = 1, + INDEXED_SET = 2, + UNCHECKED_INDEXED_GET = 3, + UNCHECKED_INDEXED_SET = 4, + ADD = 5, + SUB = 6, + MUL = 7, + DIV = 8, + REM = 9, + POW = 10, + BITWISE_AND = 11, + BITWISE_OR = 12, + BITWISE_XOR = 13, + BITWISE_SHL = 14, + BITWISE_SHR = 15, + BITWISE_SHR_U = 16, + EQ = 17, + NE = 18, + GT = 19, + GE = 20, + LT = 21, + LE = 22, + PLUS = 23, + MINUS = 24, + NOT = 25, + BITWISE_NOT = 26, + PREFIX_INC = 27, + PREFIX_DEC = 28, + POSTFIX_INC = 29, + POSTFIX_DEC = 30 + } + /** Represents an AssemblyScript program. */ + export class Program extends DiagnosticEmitter { + /** Resolver instance. */ + resolver: Resolver; + /** Array of sources. */ + sources: Source[]; + /** Diagnostic offset used where successively obtaining the next diagnostic. */ + diagnosticsOffset: i32; + /** Compiler options. */ + options: Options; + /** Special native code source. */ + nativeSource: Source; + /** Special native code file. */ + nativeFile: File; + /** Files by unique internal name. */ + filesByName: Map; + /** Elements by unique internal name in element space. */ + elementsByName: Map; + /** Elements by declaration. */ + elementsByDeclaration: Map; + /** Element instances by unique internal name. */ + instancesByName: Map; + /** Classes backing basic types like `i32`. */ + typeClasses: Map; + /** Managed classes contained in the program, by id. */ + managedClasses: Map; + /** ArrayBufferView reference. */ + arrayBufferViewInstance: Class; + /** ArrayBuffer instance reference. */ + arrayBufferInstance: Class; + /** Array prototype reference. */ + arrayPrototype: ClassPrototype; + /** Set prototype reference. */ + setPrototype: ClassPrototype; + /** Map prototype reference. */ + mapPrototype: ClassPrototype; + /** Fixed array prototype reference. */ + fixedArrayPrototype: ClassPrototype; + /** Int8Array prototype. */ + i8ArrayPrototype: ClassPrototype; + /** Int16Array prototype. */ + i16ArrayPrototype: ClassPrototype; + /** Int32Array prototype. */ + i32ArrayPrototype: ClassPrototype; + /** Int64Array prototype. */ + i64ArrayPrototype: ClassPrototype; + /** Uint8Array prototype. */ + u8ArrayPrototype: ClassPrototype; + /** Uint8ClampedArray prototype. */ + u8ClampedArrayPrototype: ClassPrototype; + /** Uint16Array prototype. */ + u16ArrayPrototype: ClassPrototype; + /** Uint32Array prototype. */ + u32ArrayPrototype: ClassPrototype; + /** Uint64Array prototype. */ + u64ArrayPrototype: ClassPrototype; + /** Float32Array prototype. */ + f32ArrayPrototype: ClassPrototype; + /** Float64Array prototype. */ + f64ArrayPrototype: ClassPrototype; + /** String instance reference. */ + stringInstance: Class; + /** Abort function reference, if not explicitly disabled. */ + abortInstance: Function | null; + /** RT `__alloc(size: usize, id: u32): usize` */ + allocInstance: Function; + /** RT `__realloc(ref: usize, newSize: usize): usize` */ + reallocInstance: Function; + /** RT `__free(ref: usize): void` */ + freeInstance: Function; + /** RT `__retain(ref: usize): usize` */ + retainInstance: Function; + /** RT `__release(ref: usize): void` */ + releaseInstance: Function; + /** RT `__collect(): void` */ + collectInstance: Function; + /** RT `__visit(ref: usize, cookie: u32): void` */ + visitInstance: Function; + /** RT `__typeinfo(id: u32): RTTIFlags` */ + typeinfoInstance: Function; + /** RT `__instanceof(ref: usize, superId: u32): bool` */ + instanceofInstance: Function; + /** RT `__allocArray(length: i32, alignLog2: usize, id: u32, data: usize = 0): usize` */ + allocArrayInstance: Function; + /** Next class id. */ + nextClassId: u32; + /** Constructs a new program, optionally inheriting parser diagnostics. */ + constructor( + /** Shared array of diagnostic messages (emitted so far). */ + diagnostics?: DiagnosticMessage[] | null); + /** Writes a common runtime header to the specified buffer. */ + writeRuntimeHeader(buffer: Uint8Array, offset: i32, classInstance: Class, payloadSize: u32): void; + /** Gets the size of a runtime header. */ + readonly runtimeHeaderSize: i32; + /** Creates a native variable declaration. */ + makeNativeVariableDeclaration( + /** The simple name of the variable */ + name: string, + /** Flags indicating specific traits, e.g. `CONST`. */ + flags?: CommonFlags): VariableDeclaration; + /** Creates a native type declaration. */ + makeNativeTypeDeclaration( + /** The simple name of the type. */ + name: string, + /** Flags indicating specific traits, e.g. `GENERIC`. */ + flags?: CommonFlags): TypeDeclaration; + private nativeDummySignature; + /** Creates a native function declaration. */ + makeNativeFunctionDeclaration( + /** The simple name of the function. */ + name: string, + /** Flags indicating specific traits, e.g. `DECLARE`. */ + flags?: CommonFlags): FunctionDeclaration; + /** Creates a native namespace declaration. */ + makeNativeNamespaceDeclaration( + /** The simple name of the namespace. */ + name: string, + /** Flags indicating specific traits, e.g. `EXPORT`. */ + flags?: CommonFlags): NamespaceDeclaration; + /** Creates a native function. */ + makeNativeFunction( + /** The simple name of the function. */ + name: string, + /** Concrete function signature. */ + signature: Signature, + /** Parent element, usually a file, class or namespace. */ + parent?: Element, + /** Flags indicating specific traits, e.g. `GENERIC`. */ + flags?: CommonFlags, + /** Decorator flags representing built-in decorators. */ + decoratorFlags?: DecoratorFlags): Function; + /** Gets the (possibly merged) program element linked to the specified declaration. */ + getElementByDeclaration(declaration: DeclarationStatement): DeclaredElement; + /** Initializes the program and its elements prior to compilation. */ + initialize(options: Options): void; + /** Requires that a global library element of the specified kind is present and returns it. */ + private require; + /** Requires that a non-generic global class is present and returns it. */ + private requireClass; + /** Obtains a non-generic global function and returns it. Returns `null` if it does not exist. */ + private lookupFunction; + /** Requires that a non-generic global function is present and returns it. */ + private requireFunction; + /** Marks an element and its children as a module export. */ + private markModuleExport; + /** Registers a native type with the program. */ + private registerNativeType; + /** Registers the backing class of a native type. */ + private registerNativeTypeClass; + /** Registers a constant integer value within the global scope. */ + private registerConstantInteger; + /** Registers a constant float value within the global scope. */ + private registerConstantFloat; + /** Ensures that the given global element exists. Attempts to merge duplicates. */ + ensureGlobal(name: string, element: DeclaredElement): DeclaredElement; + /** Looks up the element of the specified name in the global scope. */ + lookupGlobal(name: string): Element | null; + /** Looks up the element of the specified name in the global scope. Errors if not present. */ + requireGlobal(name: string): Element; + /** Tries to locate a foreign file given its normalized path. */ + private lookupForeignFile; + /** Tries to locate a foreign element by traversing exports and queued exports. */ + private lookupForeign; + /** Validates that only supported decorators are present. */ + private checkDecorators; + /** Initializes a class declaration. */ + private initializeClass; + /** Initializes a field of a class or interface. */ + private initializeField; + /** Initializes a method of a class or interface. */ + private initializeMethod; + /** Checks that operator overloads are generally valid, if present. */ + private checkOperatorOverloads; + /** Ensures that the property introduced by the specified getter or setter exists.*/ + private ensureProperty; + /** Initializes a property of a class. */ + private initializeProperty; + /** Initializes an enum. */ + private initializeEnum; + /** Initializes an enum value. */ + private initializeEnumValue; + /** Initializes an `export` statement. */ + private initializeExports; + /** Initializes a single `export` member. Does not handle `export *`. */ + private initializeExport; + private initializeExportDefault; + /** Initializes an `import` statement. */ + private initializeImports; + /** Initializes a single `import` declaration. Does not handle `import *`. */ + private initializeImport; + /** Initializes a function. Does not handle methods. */ + private initializeFunction; + /** Initializes an interface. */ + private initializeInterface; + /** Initializes a namespace. */ + private initializeNamespace; + /** Initializes a `type` definition. */ + private initializeTypeDefinition; + /** Initializes a variable statement. */ + private initializeVariables; + } + /** Indicates the specific kind of an {@link Element}. */ + export enum ElementKind { + /** A {@link Global}. */ + GLOBAL = 0, + /** A {@link Local}. */ + LOCAL = 1, + /** An {@link Enum}. */ + ENUM = 2, + /** An {@link EnumValue}. */ + ENUMVALUE = 3, + /** A {@link FunctionPrototype}. */ + FUNCTION_PROTOTYPE = 4, + /** A {@link Function}. */ + FUNCTION = 5, + /** A {@link FunctionTarget}. */ + FUNCTION_TARGET = 6, + /** A {@link ClassPrototype}. */ + CLASS_PROTOTYPE = 7, + /** A {@link Class}. */ + CLASS = 8, + /** An {@link InterfacePrototype}. */ + INTERFACE_PROTOTYPE = 9, + /** An {@link Interface}. */ + INTERFACE = 10, + /** A {@link FieldPrototype}. */ + FIELD_PROTOTYPE = 11, + /** A {@link Field}. */ + FIELD = 12, + /** A {@link PropertyPrototype}. */ + PROPERTY_PROTOTYPE = 13, + /** A {@link Property}. */ + PROPERTY = 14, + /** A {@link Namespace}. */ + NAMESPACE = 15, + /** A {@link File}. */ + FILE = 16, + /** A {@link TypeDefinition}. */ + TYPEDEFINITION = 17 + } + /** Indicates built-in decorators that are present. */ + export enum DecoratorFlags { + /** No flags set. */ + NONE = 0, + /** Is a program global. */ + GLOBAL = 1, + /** Is a binary operator overload. */ + OPERATOR_BINARY = 2, + /** Is a unary prefix operator overload. */ + OPERATOR_PREFIX = 4, + /** Is a unary postfix operator overload. */ + OPERATOR_POSTFIX = 8, + /** Is an unmanaged class. */ + UNMANAGED = 16, + /** Is a sealed class. */ + SEALED = 32, + /** Is always inlined. */ + INLINE = 64, + /** Is using a different external name. */ + EXTERNAL = 128, + /** Is a builtin. */ + BUILTIN = 256, + /** Is compiled lazily. */ + LAZY = 512, + /** Is considered unsafe code. */ + UNSAFE = 1024 + } + /** Translates a decorator kind to the respective decorator flag. */ + export function decoratorKindToFlag(kind: DecoratorKind): DecoratorFlags; + /** Base class of all program elements. */ + export abstract class Element { + /** Specific element kind. */ + kind: ElementKind; + /** Simple name. */ + name: string; + /** Internal name referring to this element. */ + internalName: string; + /** Containing {@link Program}. */ + program: Program; + /** Parent element. */ + parent: Element; + /** Common flags indicating specific traits. */ + flags: CommonFlags; + /** Decorator flags indicating annotated traits. */ + decoratorFlags: DecoratorFlags; + /** Member elements. */ + members: Map | null; + /** Shadowing type in type space, if any. */ + shadowType: TypeDefinition | null; + /** Constructs a new program element. */ + protected constructor( + /** Specific element kind. */ + kind: ElementKind, + /** Simple name. */ + name: string, + /** Internal name referring to this element. */ + internalName: string, + /** Containing {@link Program}. */ + program: Program, + /** Parent element. */ + parent: Element | null); + /** Gets the enclosing file. */ + readonly file: File; + /** Tests if this element has a specific flag or flags. */ + is(flag: CommonFlags): bool; + /** Tests if this element has any of the specified flags. */ + isAny(flags: CommonFlags): bool; + /** Sets a specific flag or flags. */ + set(flag: CommonFlags): void; + /** Unsets the specific flag or flags. */ + unset(flag: CommonFlags): void; + /** Tests if this element has a specific decorator flag or flags. */ + hasDecorator(flag: DecoratorFlags): bool; + /** Looks up the element with the specified name within this element. */ + lookupInSelf(name: string): DeclaredElement | null; + /** Looks up the element with the specified name relative to this element, like in JS. */ + abstract lookup(name: string): Element | null; + /** Adds an element as a member of this one. Reports and returns `false` if a duplicate. */ + add(name: string, element: DeclaredElement): bool; + /** Returns a string representation of this element. */ + toString(): string; + } + /** Base class of elements with an associated declaration statement. */ + export abstract class DeclaredElement extends Element { + /** Declaration reference. */ + declaration: DeclarationStatement; + /** Constructs a new declared program element. */ + protected constructor( + /** Specific element kind. */ + kind: ElementKind, + /** Simple name. */ + name: string, + /** Internal name referring to this element. */ + internalName: string, + /** Containing {@link Program}. */ + program: Program, + /** Parent element. */ + parent: Element | null, + /** Declaration reference. */ + declaration: DeclarationStatement); + /** Tests if this element is a library element. */ + readonly isDeclaredInLibrary: bool; + /** Gets the associated identifier node. */ + readonly identifierNode: IdentifierExpression; + /** Gets the assiciated decorator nodes. */ + readonly decoratorNodes: DecoratorNode[] | null; + } + /** Base class of elements that can be resolved to a concrete type. */ + export abstract class TypedElement extends DeclaredElement { + /** Resolved type. Set once `is(RESOLVED)`, otherwise void. */ + type: Type; + /** Sets the resolved type of this element. */ + setType(type: Type): void; + } + /** A file representing the implicit top-level namespace of a source. */ + export class File extends Element { + /** Source of this file. */ + source: Source; + /** File exports. */ + exports: Map | null; + /** File re-exports. */ + exportsStar: File[] | null; + /** Top-level start function of this file. */ + startFunction: Function; + /** Constructs a new file. */ + constructor( + /** Program this file belongs to. */ + program: Program, + /** Source of this file. */ + source: Source); + add(name: string, element: DeclaredElement, isImport?: bool): bool; + lookupInSelf(name: string): DeclaredElement | null; + lookup(name: string): Element | null; + /** Ensures that an element is an export of this file. */ + ensureExport(name: string, element: DeclaredElement): void; + /** Ensures that another file is a re-export of this file. */ + ensureExportStar(file: File): void; + /** Looks up the export of the specified name. */ + lookupExport(name: string): DeclaredElement | null; + /** Creates an imported namespace from this file. */ + asImportedNamespace(name: string, parent: Element): Namespace; + } + /** A type definition. */ + export class TypeDefinition extends TypedElement { + /** Constructs a new type definition. */ + constructor( + /** Simple name. */ + name: string, + /** Parent element, usually a file or namespace. */ + parent: Element, + /** Declaration reference. */ + declaration: TypeDeclaration, + /** Pre-checked flags indicating built-in decorators. */ + decoratorFlags?: DecoratorFlags); + /** Gets the associated type parameter nodes. */ + readonly typeParameterNodes: TypeParameterNode[] | null; + /** Gets the associated type node. */ + readonly typeNode: TypeNode; + lookup(name: string): Element | null; + } + /** A namespace that differs from a file in being user-declared with a name. */ + export class Namespace extends DeclaredElement { + /** Constructs a new namespace. */ + constructor( + /** Simple name. */ + name: string, + /** Parent element, usually a file or another namespace. */ + parent: Element, + /** Declaration reference. */ + declaration: NamespaceDeclaration, + /** Pre-checked flags indicating built-in decorators. */ + decoratorFlags?: DecoratorFlags); + lookup(name: string): Element | null; + } + /** An enum. */ + export class Enum extends TypedElement { + /** Constructs a new enum. */ + constructor( + /** Simple name. */ + name: string, + /** Parent element, usually a file or namespace. */ + parent: Element, + /** Declaration reference. */ + declaration: EnumDeclaration, + /** Pre-checked flags indicating built-in decorators. */ + decoratorFlags?: DecoratorFlags); + lookup(name: string): Element | null; + } + /** Indicates the kind of an inlined constant value. */ + export const enum ConstantValueKind { + /** No constant value. */ + NONE = 0, + /** Constant integer value. */ + INTEGER = 1, + /** Constant float value. */ + FLOAT = 2 + } + /** Base class of all variable-like program elements. */ + export abstract class VariableLikeElement extends TypedElement { + /** Constant value kind. */ + constantValueKind: ConstantValueKind; + /** Constant integer value, if applicable. */ + constantIntegerValue: I64; + /** Constant float value, if applicable. */ + constantFloatValue: f64; + /** Constructs a new variable-like element. */ + protected constructor( + /** Specific element kind. */ + kind: ElementKind, + /** Simple name. */ + name: string, + /** Parent element, usually a file, namespace or class. */ + parent: Element, + /** Declaration reference. Creates a native declaration if omitted. */ + declaration?: VariableLikeDeclarationStatement); + /** Gets the associated type node.s */ + readonly typeNode: TypeNode | null; + /** Gets the associated initializer node. */ + readonly initializerNode: Expression | null; + /** Applies a constant integer value to this element. */ + setConstantIntegerValue(value: I64, type: Type): void; + /** Applies a constant float value to this element. */ + setConstantFloatValue(value: f64, type: Type): void; + /** @override */ + lookup(name: string): Element | null; + } + /** An enum value. */ + export class EnumValue extends VariableLikeElement { + /** Constructs a new enum value. */ + constructor( + /** Simple name. */ + name: string, + /** Parent enum. */ + parent: Enum, + /** Declaration reference. */ + declaration: EnumValueDeclaration, + /** Pre-checked flags indicating built-in decorators. */ + decoratorFlags?: DecoratorFlags); + /** Whether this enum value is immutable. */ + isImmutable: bool; + /** Gets the associated value node. */ + readonly valueNode: Expression | null; + lookup(name: string): Element | null; + } + /** A global variable. */ + export class Global extends VariableLikeElement { + /** Constructs a new global variable. */ + constructor( + /** Simple name. */ + name: string, + /** Parent element, usually a file, namespace or static class. */ + parent: Element, + /** Pre-checked flags indicating built-in decorators. */ + decoratorFlags: DecoratorFlags, + /** Declaration reference. Creates a native declaration if omitted. */ + declaration?: VariableLikeDeclarationStatement); + } + /** A function parameter. */ + export class Parameter { + /** Parameter name. */ + name: string; + /** Parameter type. */ + type: Type; + /** Parameter initializer, if present. */ + initializer: Expression | null; + /** Constructs a new function parameter. */ + constructor( + /** Parameter name. */ + name: string, + /** Parameter type. */ + type: Type, + /** Parameter initializer, if present. */ + initializer?: Expression | null); + } + /** A local variable. */ + export class Local extends VariableLikeElement { + /** Zero-based index within the enclosing function. `-1` indicates a virtual local. */ + index: i32; + /** Constructs a new local variable. */ + constructor( + /** Simple name. */ + name: string, + /** Zero-based index within the enclosing function. `-1` indicates a virtual local. */ + index: i32, + /** Resolved type. */ + type: Type, + /** Parent function. */ + parent: Function, + /** Declaration reference. */ + declaration?: VariableLikeDeclarationStatement); + } + /** A yet unresolved function prototype. */ + export class FunctionPrototype extends DeclaredElement { + /** Operator kind, if an overload. */ + operatorKind: OperatorKind; + /** Already resolved instances. */ + instances: Map | null; + /** Clones of this prototype that are bounds to specific classes. */ + private boundPrototypes; + /** Constructs a new function prototype. */ + constructor( + /** Simple name */ + name: string, + /** Parent element, usually a file, namespace or class (if a method). */ + parent: Element, + /** Declaration reference. */ + declaration: FunctionDeclaration, + /** Pre-checked flags indicating built-in decorators. */ + decoratorFlags?: DecoratorFlags); + /** Gets the associated type parameter nodes. */ + readonly typeParameterNodes: TypeParameterNode[] | null; + /** Gets the associated function type node. */ + readonly functionTypeNode: FunctionTypeNode; + /** Gets the associated body node. */ + readonly bodyNode: Statement | null; + /** Gets the arrow function kind. */ + readonly arrowKind: ArrowKind; + /** Tests if this prototype is bound to a class. */ + readonly isBound: bool; + /** Creates a clone of this prototype that is bound to a concrete class instead. */ + toBound(classInstance: Class): FunctionPrototype; + /** Gets the resolved instance for the specified instance key, if already resolved. */ + getResolvedInstance(instanceKey: string): Function | null; + /** Sets the resolved instance for the specified instance key. */ + setResolvedInstance(instanceKey: string, instance: Function): void; + lookup(name: string): Element | null; + } + /** A resolved function. */ + export class Function extends TypedElement { + /** Function prototype. */ + prototype: FunctionPrototype; + /** Function signature. */ + signature: Signature; + /** Map of locals by name. */ + localsByName: Map; + /** Array of locals by index. */ + localsByIndex: Local[]; + /** List of additional non-parameter locals. */ + additionalLocals: Type[]; + /** Contextual type arguments. */ + contextualTypeArguments: Map | null; + /** Default control flow. */ + flow: Flow; + /** Remembered debug locations. */ + debugLocations: Range[]; + /** Function reference, if compiled. */ + ref: FunctionRef; + /** Function table index, if any. */ + functionTableIndex: i32; + /** Trampoline function for calling with omitted arguments. */ + trampoline: Function | null; + /** Counting id of inline operations involving this function. */ + nextInlineId: i32; + /** Counting id of anonymous inner functions. */ + nextAnonymousId: i32; + /** Counting id of autorelease variables. */ + nextAutoreleaseId: i32; + /** Constructs a new concrete function. */ + constructor( + /** Name incl. type parameters, i.e. `foo`. */ + nameInclTypeParameters: string, + /** Respective function prototype. */ + prototype: FunctionPrototype, + /** Concrete signature. */ + signature: Signature, // pre-resolved + /** Contextual type arguments inherited from its parent class, if any. */ + contextualTypeArguments?: Map | null); + /** Adds a local of the specified type, with an optional name. */ + addLocal(type: Type, name?: string | null, declaration?: VariableDeclaration | null): Local; + lookup(name: string): Element | null; + tempI32s: Local[] | null; + tempI64s: Local[] | null; + tempF32s: Local[] | null; + tempF64s: Local[] | null; + tempV128s: Local[] | null; + nextBreakId: i32; + breakStack: i32[] | null; + breakLabel: string | null; + /** Finalizes the function once compiled, releasing no longer needed resources. */ + finalize(module: Module, ref: FunctionRef): void; + } + /** A resolved function target, that is a function called indirectly by an index and signature. */ + export class FunctionTarget extends Element { + /** Underlying signature. */ + signature: Signature; + /** Function type. */ + type: Type; + /** Constructs a new function target. */ + constructor( + /** Concrete signature. */ + signature: Signature, + /** Program reference. */ + program: Program, __s?: string); + lookup(name: string): Element | null; + } + /** A yet unresolved instance field prototype. */ + export class FieldPrototype extends DeclaredElement { + /** Constructs a new field prototype. */ + constructor( + /** Simple name. */ + name: string, + /** Parent class. */ + parent: ClassPrototype, + /** Declaration reference. */ + declaration: FieldDeclaration, + /** Pre-checked flags indicating built-in decorators. */ + decoratorFlags?: DecoratorFlags); + /** Gets the associated type node. */ + readonly typeNode: TypeNode | null; + /** Gets the associated initializer node. */ + readonly initializerNode: Expression | null; + /** Gets the associated parameter index. Set if declared as a constructor parameter, otherwise `-1`. */ + readonly parameterIndex: i32; + lookup(name: string): Element | null; + } + /** A resolved instance field. */ + export class Field extends VariableLikeElement { + /** Field prototype reference. */ + prototype: FieldPrototype; + /** Field memory offset, if an instance field. */ + memoryOffset: i32; + /** Constructs a new field. */ + constructor( + /** Respective field prototype. */ + prototype: FieldPrototype, + /** Parent class. */ + parent: Class, + /** Concrete type. */ + type: Type); + } + /** A property comprised of a getter and a setter function. */ + export class PropertyPrototype extends DeclaredElement { + /** Getter prototype. */ + getterPrototype: FunctionPrototype | null; + /** Setter prototype. */ + setterPrototype: FunctionPrototype | null; + /** Constructs a new property prototype. */ + constructor( + /** Simple name. */ + name: string, + /** Parent class. */ + parent: ClassPrototype, + /** Declaration of the getter or setter introducing the property. */ + firstDeclaration: FunctionDeclaration); + lookup(name: string): Element | null; + } + /** A resolved property. */ + export class Property extends VariableLikeElement { + /** Prototype reference. */ + prototype: PropertyPrototype; + /** Getter instance. */ + getterInstance: Function | null; + /** Setter instance. */ + setterInstance: Function | null; + /** Constructs a new property prototype. */ + constructor( + /** Respective property prototype. */ + prototype: PropertyPrototype, + /** Parent element, usually a static class prototype or class instance. */ + parent: Element); + lookup(name: string): Element | null; + } + /** A yet unresolved class prototype. */ + export class ClassPrototype extends DeclaredElement { + /** Instance member prototypes. */ + instanceMembers: Map | null; + /** Base class prototype, if applicable. */ + basePrototype: ClassPrototype | null; + /** Constructor prototype. */ + constructorPrototype: FunctionPrototype | null; + /** Operator overload prototypes. */ + overloadPrototypes: Map; + /** Already resolved instances. */ + instances: Map | null; + constructor( + /** Simple name. */ + name: string, + /** Parent element, usually a file or namespace. */ + parent: Element, + /** Declaration reference. */ + declaration: ClassDeclaration, + /** Pre-checked flags indicating built-in decorators. */ + decoratorFlags?: DecoratorFlags, _isInterface?: bool); + /** Gets the associated type parameter nodes. */ + readonly typeParameterNodes: TypeParameterNode[] | null; + /** Gets the associated extends node. */ + readonly extendsNode: NamedTypeNode | null; + /** Gets the associated implements nodes. */ + readonly implementsNodes: NamedTypeNode[] | null; + /** Tests if this prototype is of a builtin array type (Array/TypedArray). */ + readonly isBuiltinArray: bool; + /** Tests if this prototype extends the specified. */ + extends(basePtototype: ClassPrototype | null): bool; + /** Adds an element as an instance member of this one. Returns the previous element if a duplicate. */ + addInstance(name: string, element: DeclaredElement): bool; + /** Gets the resolved instance for the specified instance key, if already resolved. */ + getResolvedInstance(instanceKey: string): Class | null; + /** Sets the resolved instance for the specified instance key. */ + setResolvedInstance(instanceKey: string, instance: Class): void; + lookup(name: string): Element | null; + } + /** A resolved class. */ + export class Class extends TypedElement { + /** Class prototype. */ + prototype: ClassPrototype; + /** Resolved type arguments. */ + typeArguments: Type[] | null; + /** Base class, if applicable. */ + base: Class | null; + /** Contextual type arguments for fields and methods. */ + contextualTypeArguments: Map | null; + /** Current member memory offset. */ + currentMemoryOffset: u32; + /** Constructor instance. */ + constructorInstance: Function | null; + /** Operator overloads. */ + overloads: Map | null; + /** Unique class id. */ + private _id; + /** Remembers acyclic state. */ + private _acyclic; + /** Runtime type information flags. */ + rttiFlags: u32; + /** Gets the unique runtime id of this class. */ + readonly id: u32; + /** Tests if this class is of a builtin array type (Array/TypedArray). */ + readonly isBuiltinArray: bool; + /** Tests if this class is array-like. */ + readonly isArrayLike: bool; + /** Constructs a new class. */ + constructor( + /** Name incl. type parameters, i.e. `Foo`. */ + nameInclTypeParameters: string, + /** The respective class prototype. */ + prototype: ClassPrototype, + /** Concrete type arguments, if any. */ + typeArguments?: Type[] | null, + /** Base class, if derived. */ + base?: Class | null, _isInterface?: bool); + /** Tests if a value of this class type is assignable to a target of the specified class type. */ + isAssignableTo(target: Class): bool; + /** Looks up the operator overload of the specified kind. */ + lookupOverload(kind: OperatorKind, unchecked?: bool): Function | null; + lookup(name: string): Element | null; + /** Calculates the memory offset of the specified field. */ + offsetof(fieldName: string): u32; + /** Writes a field value to a buffer and returns the number of bytes written. */ + writeField(name: string, value: T, buffer: Uint8Array, baseOffset: i32): i32; + /** Tests if this class extends the specified prototype. */ + extends(prototype: ClassPrototype): bool; + /** Gets the concrete type arguments to the specified extendend prototype. */ + getTypeArgumentsTo(extendedPrototype: ClassPrototype): Type[] | null; + /** Gets the value type of an array. Must be an array. */ + getArrayValueType(): Type; + /** Tests if this class is inherently acyclic. */ + readonly isAcyclic: bool; + /** Tests if this class potentially forms a reference cycle to another one. */ + private cyclesTo; + } + /** A yet unresolved interface. */ + export class InterfacePrototype extends ClassPrototype { + /** Constructs a new interface prototype. */ + constructor(name: string, parent: Element, declaration: InterfaceDeclaration, decoratorFlags: DecoratorFlags); + } + /** A resolved interface. */ + export class Interface extends Class { + /** Constructs a new interface. */ + constructor(nameInclTypeParameters: string, prototype: InterfacePrototype, typeArguments?: Type[], base?: Interface | null); + } + /** Mangles the internal name of an element with the specified name that is a child of the given parent. */ + export function mangleInternalName(name: string, parent: Element, isInstance: bool, asGlobal?: bool): string; + +} +declare module 'assemblyscript/src/compiler' { + /** + * The AssemblyScript compiler. + * @module compiler + */ /***/ + import { DiagnosticEmitter } from 'assemblyscript/src/diagnostics'; + import { Module, MemorySegment, ExpressionRef, NativeType, FunctionRef, FunctionTypeRef, GlobalRef } from 'assemblyscript/src/module'; + import { Feature, Target } from 'assemblyscript/src/common'; + import { Program, ClassPrototype, Class, Element, Enum, Field, FunctionPrototype, Function, Global, VariableLikeElement, File } from 'assemblyscript/src/program'; + import { Flow } from 'assemblyscript/src/flow'; + import { Resolver } from 'assemblyscript/src/resolver'; + import { Node, NamedTypeNode, Range, Statement, BlockStatement, BreakStatement, ContinueStatement, DoStatement, EmptyStatement, ExpressionStatement, ForStatement, IfStatement, InstanceOfExpression, InterfaceDeclaration, ReturnStatement, SwitchStatement, ThrowStatement, TryStatement, VariableStatement, VoidStatement, WhileStatement, Expression, AssertionExpression, BinaryExpression, CallExpression, CommaExpression, ElementAccessExpression, FunctionExpression, IdentifierExpression, LiteralExpression, NewExpression, ObjectLiteralExpression, PropertyAccessExpression, TernaryExpression, StringLiteralExpression, UnaryPostfixExpression, UnaryPrefixExpression } from 'assemblyscript/src/ast'; + import { Type, Signature } from 'assemblyscript/src/types'; + /** Compiler options. */ + export class Options { + /** WebAssembly target. Defaults to {@link Target.WASM32}. */ + target: Target; + /** If true, replaces assertions with nops. */ + noAssert: bool; + /** If true, imports the memory provided by the embedder. */ + importMemory: bool; + /** If greater than zero, declare memory as shared by setting max memory to sharedMemory. */ + sharedMemory: i32; + /** If true, imports the function table provided by the embedder. */ + importTable: bool; + /** If true, generates information necessary for source maps. */ + sourceMap: bool; + /** If true, generates an explicit start function. */ + explicitStart: bool; + /** Static memory start offset. */ + memoryBase: i32; + /** Global aliases, mapping alias names as the key to internal names to be aliased as the value. */ + globalAliases: Map | null; + /** Additional features to activate. */ + features: Feature; + /** Hinted optimize level. Not applied by the compiler itself. */ + optimizeLevelHint: i32; + /** Hinted shrink level. Not applied by the compiler itself. */ + shrinkLevelHint: i32; + /** Tests if the target is WASM64 or, otherwise, WASM32. */ + readonly isWasm64: bool; + /** Gets the unsigned size type matching the target. */ + readonly usizeType: Type; + /** Gets the signed size type matching the target. */ + readonly isizeType: Type; + /** Gets the native size type matching the target. */ + readonly nativeSizeType: NativeType; + /** Tests if a specific feature is activated. */ + hasFeature(feature: Feature): bool; + } + /** Various constraints in expression compilation. */ + export const enum Constraints { + NONE = 0, + /** Must implicitly convert to the target type. */ + CONV_IMPLICIT = 1, + /** Must explicitly convert to the target type. */ + CONV_EXPLICIT = 2, + /** Must wrap small integer values to match the target type. */ + MUST_WRAP = 4, + /** Indicates that the value will be dropped immediately. */ + WILL_DROP = 8, + /** Indicates that the value will be retained immediately. */ + WILL_RETAIN = 16, + /** Indicates that static data is preferred. */ + PREFER_STATIC = 32 + } + /** Runtime features to be activated by the compiler. */ + export const enum RuntimeFeatures { + NONE = 0, + /** Requires heap setup. */ + HEAP = 1, + /** Requires runtime type information setup. */ + RTTI = 2, + /** Requires the built-in globals visitor. */ + visitGlobals = 4, + /** Requires the built-in members visitor. */ + visitMembers = 8 + } + /** Compiler interface. */ + export class Compiler extends DiagnosticEmitter { + /** Program reference. */ + program: Program; + /** Resolver reference. */ + resolver: Resolver; + /** Provided options. */ + options: Options; + /** Module instance being compiled. */ + module: Module; + /** Current control flow. */ + currentFlow: Flow; + /** Current inline functions stack. */ + currentInlineFunctions: Function[]; + /** Current enum in compilation. */ + currentEnum: Enum | null; + /** Current type in compilation. */ + currentType: Type; + /** Start function statements. */ + currentBody: ExpressionRef[]; + /** Counting memory offset. */ + memoryOffset: I64; + /** Memory segments being compiled. */ + memorySegments: MemorySegment[]; + /** Map of already compiled static string segments. */ + stringSegments: Map; + /** Function table being compiled. */ + functionTable: string[]; + /** Argument count helper global. */ + argcVar: GlobalRef; + /** Argument count helper setter. */ + argcSet: FunctionRef; + /** Requires runtime features. */ + runtimeFeatures: RuntimeFeatures; + /** Expressions known to have skipped an autorelease. Usually function returns. */ + skippedAutoreleases: Set; + /** Compiles a {@link Program} to a {@link Module} using the specified options. */ + static compile(program: Program, options?: Options | null): Module; + /** Constructs a new compiler for a {@link Program} using the specified options. */ + constructor(program: Program, options?: Options | null); + /** Performs compilation of the underlying {@link Program} to a {@link Module}. */ + compile(): Module; + /** Applies the respective module exports for the specified file. */ + private ensureModuleExports; + /** Applies the respective module export(s) for the specified element. */ + private ensureModuleExport; + /** Makes a function to get the value of a field of an exported class. */ + private ensureModuleFieldGetter; + /** Makes a function to set the value of a field of an exported class. */ + private ensureModuleFieldSetter; + /** Compiles any element. */ + compileElement(element: Element, compileMembers?: bool): void; + /** Compiles an element's members. */ + compileMembers(element: Element): void; + /** Compiles a file's exports. */ + compileExports(file: File): void; + /** Compiles the file matching the specified path. */ + compileFileByPath(normalizedPathWithoutExtension: string, reportNode: Node): void; + /** Compiles the specified file. */ + compileFile(file: File): void; + compileGlobal(global: Global): bool; + compileEnum(element: Enum): bool; + /** Resolves the specified type arguments prior to compiling the resulting function instance. */ + compileFunctionUsingTypeArguments(prototype: FunctionPrototype, typeArguments: NamedTypeNode[], contextualTypeArguments?: Map, alternativeReportNode?: Node | null): Function | null; + /** Either reuses or creates the function type matching the specified signature. */ + ensureFunctionType(parameterTypes: Type[] | null, returnType: Type, thisType?: Type | null): FunctionTypeRef; + /** Compiles the body of a function within the specified flow. */ + compileFunctionBody( + /** Function to compile. */ + instance: Function, + /** Target array of statements. */ + stmts?: ExpressionRef[] | null): ExpressionRef[]; + /** Compiles a readily resolved function instance. */ + compileFunction(instance: Function): bool; + compileClassUsingTypeArguments(prototype: ClassPrototype, typeArguments: NamedTypeNode[], contextualTypeArguments?: Map, alternativeReportNode?: Node | null): void; + compileClass(instance: Class): bool; + compileInterfaceDeclaration(declaration: InterfaceDeclaration, typeArguments: NamedTypeNode[], contextualTypeArguments?: Map | null, alternativeReportNode?: Node | null): void; + /** Adds a static memory segment with the specified data. */ + addMemorySegment(buffer: Uint8Array, alignment?: i32): MemorySegment; + /** Ensures that the specified string exists in static memory and returns a pointer to it. */ + ensureStaticString(stringValue: string): ExpressionRef; + ensureStaticArrayBuffer(elementType: Type, values: ExpressionRef[]): MemorySegment; + ensureStaticArrayHeader(elementType: Type, bufferSegment: MemorySegment): MemorySegment; + /** Ensures that a table entry exists for the specified function and returns its index. */ + ensureFunctionTableEntry(func: Function): i32; + compileTopLevelStatement(statement: Statement, body: ExpressionRef[]): void; + compileStatement(statement: Statement, isLastInBody?: bool): ExpressionRef; + compileStatements(statements: Statement[], isBody?: bool, stmts?: ExpressionRef[] | null): ExpressionRef[]; + compileBlockStatement(statement: BlockStatement): ExpressionRef; + compileBreakStatement(statement: BreakStatement): ExpressionRef; + compileContinueStatement(statement: ContinueStatement): ExpressionRef; + compileDoStatement(statement: DoStatement): ExpressionRef; + compileEmptyStatement(statement: EmptyStatement): ExpressionRef; + compileExpressionStatement(statement: ExpressionStatement): ExpressionRef; + compileForStatement(statement: ForStatement): ExpressionRef; + compileIfStatement(statement: IfStatement): ExpressionRef; + compileReturnStatement(statement: ReturnStatement, isLastInBody: bool): ExpressionRef; + compileSwitchStatement(statement: SwitchStatement): ExpressionRef; + compileThrowStatement(statement: ThrowStatement): ExpressionRef; + compileTryStatement(statement: TryStatement): ExpressionRef; + /** Compiles a variable statement. Returns `0` if an initializer is not necessary. */ + compileVariableStatement(statement: VariableStatement): ExpressionRef; + compileVoidStatement(statement: VoidStatement): ExpressionRef; + compileWhileStatement(statement: WhileStatement): ExpressionRef; + /** Compiles the value of an inlined constant element. */ + compileInlineConstant(element: VariableLikeElement, contextualType: Type, constraints: Constraints): ExpressionRef; + compileExpression(expression: Expression, contextualType: Type, constraints?: Constraints): ExpressionRef; + /** Compiles and precomputes an expression, possibly yielding a costant value. */ + precomputeExpression(expression: Expression, contextualType: Type, constraints?: Constraints): ExpressionRef; + convertExpression(expr: ExpressionRef, + /** Original type. */ + fromType: Type, + /** New type. */ + toType: Type, + /** Whether the conversion is explicit.*/ + explicit: bool, + /** Whether the result should be wrapped, if a small integer. */ + wrap: bool, reportNode: Node): ExpressionRef; + compileAssertionExpression(expression: AssertionExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + private f32ModInstance; + private f64ModInstance; + private f32PowInstance; + private f64PowInstance; + compileBinaryExpression(expression: BinaryExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + compileUnaryOverload(operatorInstance: Function, value: Expression, valueExpr: ExpressionRef, reportNode: Node): ExpressionRef; + compileBinaryOverload(operatorInstance: Function, left: Expression, leftExpr: ExpressionRef, right: Expression, reportNode: Node): ExpressionRef; + compileAssignment(expression: Expression, valueExpression: Expression, contextualType: Type): ExpressionRef; + /** Makes an assignment expression or block, assigning a value to a target. */ + makeAssignment( + /** Target element, e.g. a Local. */ + target: Element, + /** Value expression that has been compiled in a previous step already. */ + valueExpr: ExpressionRef, + /** Expression reference. Has already been compiled to `valueExpr`. */ + valueExpression: Expression, + /** `this` expression reference if a field or property set. */ + thisExpression: Expression | null, + /** Index expression reference if an indexed set. */ + indexExpression: Expression | null, + /** Whether to tee the value. */ + tee: bool): ExpressionRef; + /** Makes an assignment to a local, possibly retaining and releasing affected references and keeping track of wrap and null states. */ + private makeLocalAssignment; + /** Makes an assignment to a global, possibly retaining and releasing affected references. */ + private makeGlobalAssignment; + /** Makes an assignment to a field, possibly retaining and releasing affected references. */ + makeFieldAssignment( + /** The field to assign to. */ + field: Field, + /** The value to assign. */ + valueExpr: ExpressionRef, + /** The value of `this`. */ + thisExpr: ExpressionRef, + /** Whether to tee the value. */ + tee: bool): ExpressionRef; + /** Compiles a call expression according to the specified context. */ + compileCallExpression( + /** Call expression to compile. */ + expression: CallExpression, + /** Contextual type indicating the return type the caller expects, if any. */ + contextualType: Type, + /** Constraints indicating contextual conditions. */ + constraints: Constraints): ExpressionRef; + private compileCallExpressionBuiltin; + /** + * Checks that a call with the given number as arguments can be performed according to the + * specified signature. + */ + checkCallSignature(signature: Signature, numArguments: i32, hasThis: bool, reportNode: Node): bool; + /** Compiles a direct call to a concrete function. */ + compileCallDirect(instance: Function, argumentExpressions: Expression[], reportNode: Node, thisArg?: ExpressionRef, constraints?: Constraints): ExpressionRef; + makeCallInline(instance: Function, operands: ExpressionRef[] | null, thisArg?: ExpressionRef, immediatelyDropped?: bool): ExpressionRef; + /** Gets the trampoline for the specified function. */ + ensureTrampoline(original: Function): Function; + /** Makes sure that the argument count helper global is present and returns its name. */ + private ensureArgcVar; + /** Makes sure that the argument count helper setter is present and returns its name. */ + private ensureArgcSet; + /** Makes retain call, retaining the expression's value. */ + makeRetain(expr: ExpressionRef): ExpressionRef; + /** Makes a retainRelease call, retaining the new expression's value and releasing the old expression's value, in this order. */ + makeRetainRelease(oldExpr: ExpressionRef, newExpr: ExpressionRef): ExpressionRef; + /** Makes a skippedRelease call, ignoring the new expression's value and releasing the old expression's value, in this order. */ + makeSkippedRelease(oldExpr: ExpressionRef, newExpr: ExpressionRef): ExpressionRef; + /** Makes a release call, releasing the expression's value. Changes the current type to void.*/ + makeRelease(expr: ExpressionRef): ExpressionRef; + /** Makes an automatic release call at the end of the current flow. */ + makeAutorelease(expr: ExpressionRef, flow?: Flow): ExpressionRef; + /** Attempts to undo a final autorelease, returning the index of the previously retaining variable or -1 if not possible. */ + undoAutorelease(expr: ExpressionRef, flow: Flow): i32; + /** + * Attemps to move a final autorelease from one flow to a parent. + * It is crucial that from flow hasn't processed autoreleases yet because otherwise the final + * retain would have been written already. + */ + moveAutorelease(expr: ExpressionRef, fromInnerFlow: Flow, toOuterFlow: Flow): ExpressionRef; + /** Performs any queued autoreleases in the specified flow. */ + performAutoreleases(flow: Flow, stmts: ExpressionRef[], clearFlags?: bool): void; + /** Performs any queued autoreleases in the specified flow and returns the value. */ + performAutoreleasesWithValue(flow: Flow, valueExpr: ExpressionRef, valueType: Type, stmts?: ExpressionRef[] | null, clearFlags?: bool): ExpressionRef; + /** Finishes any queued top-level autoreleases in the actual function of the specified flow. */ + finishAutoreleases(flow: Flow, stmts: ExpressionRef[]): void; + /** Creates a direct call to the specified function. */ + makeCallDirect(instance: Function, operands: ExpressionRef[] | null, reportNode: Node, immediatelyDropped?: bool, + /** Skip the usual autorelease and manage this at the callsite instead. */ + skipAutorelease?: bool): ExpressionRef; + /** Compiles an indirect call using an index argument and a signature. */ + compileCallIndirect(signature: Signature, indexArg: ExpressionRef, argumentExpressions: Expression[], reportNode: Node, thisArg?: ExpressionRef, immediatelyDropped?: bool): ExpressionRef; + /** Creates an indirect call to the function at `indexArg` in the function table. */ + makeCallIndirect(signature: Signature, indexArg: ExpressionRef, operands?: ExpressionRef[] | null, immediatelyDropped?: bool): ExpressionRef; + compileCommaExpression(expression: CommaExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + compileElementAccessExpression(expression: ElementAccessExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + compileFunctionExpression(expression: FunctionExpression, contextualSignature: Signature | null, constraints: Constraints): ExpressionRef; + /** Makes sure the enclosing source file of the specified expression has been compiled. */ + private maybeCompileEnclosingSource; + /** + * Compiles an identifier in the specified context. + * @param retainConstantType Retains the type of inlined constants if `true`, otherwise + * precomputes them according to context. + */ + compileIdentifierExpression(expression: IdentifierExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + compileInstanceOfExpression(expression: InstanceOfExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + compileLiteralExpression(expression: LiteralExpression, contextualType: Type, constraints: Constraints, implicitlyNegate?: bool): ExpressionRef; + compileStringLiteral(expression: StringLiteralExpression): ExpressionRef; + compileArrayLiteral(elementType: Type, expressions: (Expression | null)[], constraints: Constraints, reportNode: Node): ExpressionRef; + compileObjectLiteral(expression: ObjectLiteralExpression, contextualType: Type): ExpressionRef; + compileNewExpression(expression: NewExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + /** Gets the compiled constructor of the specified class or generates one if none is present. */ + ensureConstructor(classInstance: Class, reportNode: Node): Function; + compileInstantiate( + /** Class to instantiate. */ + classInstance: Class, + /** Constructor arguments. */ + argumentExpressions: Expression[], + /** Contextual flags. */ + constraints: Constraints, + /** Node to report on. */ + reportNode: Node): ExpressionRef; + /** + * Compiles a property access in the specified context. + * @param retainConstantType Retains the type of inlined constants if `true`, otherwise + * precomputes them according to context. + */ + compilePropertyAccessExpression(propertyAccess: PropertyAccessExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + compileTernaryExpression(expression: TernaryExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + compileUnaryPostfixExpression(expression: UnaryPostfixExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + compileUnaryPrefixExpression(expression: UnaryPrefixExpression, contextualType: Type, constraints: Constraints): ExpressionRef; + /** Makes sure that a 32-bit integer value is wrapped to a valid value of the specified type. */ + ensureSmallIntegerWrap(expr: ExpressionRef, type: Type): ExpressionRef; + /** Adds the debug location of the specified expression at the specified range to the source map. */ + addDebugLocation(expr: ExpressionRef, range: Range): void; + /** Creates a comparison whether an expression is 'false' in a broader sense. */ + makeIsFalseish(expr: ExpressionRef, type: Type): ExpressionRef; + /** Creates a comparison whether an expression is 'true' in a broader sense. */ + makeIsTrueish(expr: ExpressionRef, type: Type): ExpressionRef; + /** Makes an allocation suitable to hold the data of an instance of the given class. */ + makeAllocation(classInstance: Class): ExpressionRef; + /** Makes the initializers for a class's fields. */ + makeFieldInitialization(classInstance: Class, stmts?: ExpressionRef[]): ExpressionRef[]; + makeInstanceOfClass(expr: ExpressionRef, classInstance: Class): ExpressionRef; + } + /** Flattens a series of expressions to a nop, a single statement or a block depending on statement count. */ + export function flatten(module: Module, stmts: ExpressionRef[], type: NativeType): ExpressionRef; + +} +declare module 'assemblyscript/src/builtins' { + /** + * Built-in elements providing WebAssembly core functionality. + * @module builtins + */ /***/ + import { Compiler } from 'assemblyscript/src/compiler'; + import { Node, Expression, CallExpression } from 'assemblyscript/src/ast'; + import { Type } from 'assemblyscript/src/types'; + import { ExpressionRef } from 'assemblyscript/src/module'; + import { FunctionPrototype } from 'assemblyscript/src/program'; + /** Symbols of various compiler built-ins. */ + export namespace BuiltinSymbols { + const isInteger = "~lib/builtins/isInteger"; + const isFloat = "~lib/builtins/isFloat"; + const isBoolean = "~lib/builtins/isBoolean"; + const isSigned = "~lib/builtins/isSigned"; + const isReference = "~lib/builtins/isReference"; + const isString = "~lib/builtins/isString"; + const isArray = "~lib/builtins/isArray"; + const isArrayLike = "~lib/builtins/isArrayLike"; + const isFunction = "~lib/builtins/isFunction"; + const isNullable = "~lib/builtins/isNullable"; + const isDefined = "~lib/builtins/isDefined"; + const isConstant = "~lib/builtins/isConstant"; + const isManaged = "~lib/builtins/isManaged"; + const clz = "~lib/builtins/clz"; + const ctz = "~lib/builtins/ctz"; + const popcnt = "~lib/builtins/popcnt"; + const rotl = "~lib/builtins/rotl"; + const rotr = "~lib/builtins/rotr"; + const abs = "~lib/builtins/abs"; + const max = "~lib/builtins/max"; + const min = "~lib/builtins/min"; + const ceil = "~lib/builtins/ceil"; + const floor = "~lib/builtins/floor"; + const copysign = "~lib/builtins/copysign"; + const nearest = "~lib/builtins/nearest"; + const reinterpret = "~lib/builtins/reinterpret"; + const sqrt = "~lib/builtins/sqrt"; + const trunc = "~lib/builtins/trunc"; + const load = "~lib/builtins/load"; + const store = "~lib/builtins/store"; + const atomic_load = "~lib/builtins/atomic.load"; + const atomic_store = "~lib/builtins/atomic.store"; + const atomic_add = "~lib/builtins/atomic.add"; + const atomic_sub = "~lib/builtins/atomic.sub"; + const atomic_and = "~lib/builtins/atomic.and"; + const atomic_or = "~lib/builtins/atomic.or"; + const atomic_xor = "~lib/builtins/atomic.xor"; + const atomic_xchg = "~lib/builtins/atomic.xchg"; + const atomic_cmpxchg = "~lib/builtins/atomic.cmpxchg"; + const atomic_wait = "~lib/builtins/atomic.wait"; + const atomic_notify = "~lib/builtins/atomic.notify"; + const sizeof = "~lib/builtins/sizeof"; + const alignof = "~lib/builtins/alignof"; + const offsetof = "~lib/builtins/offsetof"; + const select = "~lib/builtins/select"; + const unreachable = "~lib/builtins/unreachable"; + const changetype = "~lib/builtins/changetype"; + const assert = "~lib/builtins/assert"; + const unchecked = "~lib/builtins/unchecked"; + const call_direct = "~lib/builtins/call_direct"; + const call_indirect = "~lib/builtins/call_indirect"; + const instantiate = "~lib/builtins/instantiate"; + const idof = "~lib/builtins/idof"; + const i8 = "~lib/builtins/i8"; + const i16 = "~lib/builtins/i16"; + const i32 = "~lib/builtins/i32"; + const i64 = "~lib/builtins/i64"; + const isize = "~lib/builtins/isize"; + const u8 = "~lib/builtins/u8"; + const u16 = "~lib/builtins/u16"; + const u32 = "~lib/builtins/u32"; + const u64 = "~lib/builtins/u64"; + const usize = "~lib/builtins/usize"; + const bool = "~lib/builtins/bool"; + const f32 = "~lib/builtins/f32"; + const f64 = "~lib/builtins/f64"; + const v128 = "~lib/builtins/v128"; + const void_ = "~lib/builtins/void"; + const i32_clz = "~lib/builtins/i32.clz"; + const i64_clz = "~lib/builtins/i64.clz"; + const i32_ctz = "~lib/builtins/i32.ctz"; + const i64_ctz = "~lib/builtins/i64.ctz"; + const i32_popcnt = "~lib/builtins/i32.popcnt"; + const i64_popcnt = "~lib/builtins/i64.popcnt"; + const i32_rotl = "~lib/builtins/i32.rotl"; + const i64_rotl = "~lib/builtins/i64.rotl"; + const i32_rotr = "~lib/builtins/i32.rotr"; + const i64_rotr = "~lib/builtins/i64.rotr"; + const f32_abs = "~lib/builtins/f32.abs"; + const f64_abs = "~lib/builtins/f64.abs"; + const f32_max = "~lib/builtins/f32.max"; + const f64_max = "~lib/builtins/f64.max"; + const f32_min = "~lib/builtins/f32.min"; + const f64_min = "~lib/builtins/f64.min"; + const f32_ceil = "~lib/builtins/f32.ceil"; + const f64_ceil = "~lib/builtins/f64.ceil"; + const f32_floor = "~lib/builtins/f32.floor"; + const f64_floor = "~lib/builtins/f64.floor"; + const f32_copysign = "~lib/builtins/f32.copysign"; + const f64_copysign = "~lib/builtins/f64.copysign"; + const f32_nearest = "~lib/builtins/f32.nearest"; + const f64_nearest = "~lib/builtins/f64.nearest"; + const i32_reinterpret_f32 = "~lib/builtins/i32.reinterpret_f32"; + const i64_reinterpret_f64 = "~lib/builtins/i64.reinterpret_f64"; + const f32_reinterpret_i32 = "~lib/builtins/f32.reinterpret_i32"; + const f64_reinterpret_i64 = "~lib/builtins/f64.reinterpret_i64"; + const f32_sqrt = "~lib/builtins/f32.sqrt"; + const f64_sqrt = "~lib/builtins/f64.sqrt"; + const f32_trunc = "~lib/builtins/f32.trunc"; + const f64_trunc = "~lib/builtins/f64.trunc"; + const i32_load8_s = "~lib/builtins/i32.load8_s"; + const i32_load8_u = "~lib/builtins/i32.load8_u"; + const i32_load16_s = "~lib/builtins/i32.load16_s"; + const i32_load16_u = "~lib/builtins/i32.load16_u"; + const i32_load = "~lib/builtins/i32.load"; + const i64_load8_s = "~lib/builtins/i64.load8_s"; + const i64_load8_u = "~lib/builtins/i64.load8_u"; + const i64_load16_s = "~lib/builtins/i64.load16_s"; + const i64_load16_u = "~lib/builtins/i64.load16_u"; + const i64_load32_s = "~lib/builtins/i64.load32_s"; + const i64_load32_u = "~lib/builtins/i64.load32_u"; + const i64_load = "~lib/builtins/i64.load"; + const f32_load = "~lib/builtins/f32.load"; + const f64_load = "~lib/builtins/f64.load"; + const i32_store8 = "~lib/builtins/i32.store8"; + const i32_store16 = "~lib/builtins/i32.store16"; + const i32_store = "~lib/builtins/i32.store"; + const i64_store8 = "~lib/builtins/i64.store8"; + const i64_store16 = "~lib/builtins/i64.store16"; + const i64_store32 = "~lib/builtins/i64.store32"; + const i64_store = "~lib/builtins/i64.store"; + const f32_store = "~lib/builtins/f32.store"; + const f64_store = "~lib/builtins/f64.store"; + const i32_atomic_load8_u = "~lib/builtins/i32.atomic.load8_u"; + const i32_atomic_load16_u = "~lib/builtins/i32.atomic.load16_u"; + const i32_atomic_load = "~lib/builtins/i32.atomic.load"; + const i64_atomic_load8_u = "~lib/builtins/i64.atomic.load8_u"; + const i64_atomic_load16_u = "~lib/builtins/i64.atomic.load16_u"; + const i64_atomic_load32_u = "~lib/builtins/i64.atomic.load32_u"; + const i64_atomic_load = "~lib/builtins/i64.atomic.load"; + const i32_atomic_store8 = "~lib/builtins/i32.atomic.store8"; + const i32_atomic_store16 = "~lib/builtins/i32.atomic.store16"; + const i32_atomic_store = "~lib/builtins/i32.atomic.store"; + const i64_atomic_store8 = "~lib/builtins/i64.atomic.store8"; + const i64_atomic_store16 = "~lib/builtins/i64.atomic.store16"; + const i64_atomic_store32 = "~lib/builtins/i64.atomic.store32"; + const i64_atomic_store = "~lib/builtins/i64.atomic.store"; + const i32_atomic_rmw8_add_u = "~lib/builtins/i32.atomic.rmw8.add_u"; + const i32_atomic_rmw16_add_u = "~lib/builtins/i32.atomic.rmw16.add_u"; + const i32_atomic_rmw_add = "~lib/builtins/i32.atomic.rmw.add"; + const i64_atomic_rmw8_add_u = "~lib/builtins/i64.atomic.rmw8.add_u"; + const i64_atomic_rmw16_add_u = "~lib/builtins/i64.atomic.rmw16.add_u"; + const i64_atomic_rmw32_add_u = "~lib/builtins/i64.atomic.rmw32.add_u"; + const i64_atomic_rmw_add = "~lib/builtins/i64.atomic.rmw.add"; + const i32_atomic_rmw8_sub_u = "~lib/builtins/i32.atomic.rmw8.sub_u"; + const i32_atomic_rmw16_sub_u = "~lib/builtins/i32.atomic.rmw16.sub_u"; + const i32_atomic_rmw_sub = "~lib/builtins/i32.atomic.rmw.sub"; + const i64_atomic_rmw8_sub_u = "~lib/builtins/i64.atomic.rmw8.sub_u"; + const i64_atomic_rmw16_sub_u = "~lib/builtins/i64.atomic.rmw16.sub_u"; + const i64_atomic_rmw32_sub_u = "~lib/builtins/i64.atomic.rmw32.sub_u"; + const i64_atomic_rmw_sub = "~lib/builtins/i64.atomic.rmw.sub"; + const i32_atomic_rmw8_and_u = "~lib/builtins/i32.atomic.rmw8.and_u"; + const i32_atomic_rmw16_and_u = "~lib/builtins/i32.atomic.rmw16.and_u"; + const i32_atomic_rmw_and = "~lib/builtins/i32.atomic.rmw.and"; + const i64_atomic_rmw8_and_u = "~lib/builtins/i64.atomic.rmw8.and_u"; + const i64_atomic_rmw16_and_u = "~lib/builtins/i64.atomic.rmw16.and_u"; + const i64_atomic_rmw32_and_u = "~lib/builtins/i64.atomic.rmw32.and_u"; + const i64_atomic_rmw_and = "~lib/builtins/i64.atomic.rmw.and"; + const i32_atomic_rmw8_or_u = "~lib/builtins/i32.atomic.rmw8.or_u"; + const i32_atomic_rmw16_or_u = "~lib/builtins/i32.atomic.rmw16.or_u"; + const i32_atomic_rmw_or = "~lib/builtins/i32.atomic.rmw.or"; + const i64_atomic_rmw8_or_u = "~lib/builtins/i64.atomic.rmw8.or_u"; + const i64_atomic_rmw16_or_u = "~lib/builtins/i64.atomic.rmw16.or_u"; + const i64_atomic_rmw32_or_u = "~lib/builtins/i64.atomic.rmw32.or_u"; + const i64_atomic_rmw_or = "~lib/builtins/i64.atomic.rmw.or"; + const i32_atomic_rmw8_u_xor = "~lib/builtins/i32.atomic.rmw8.xor_u"; + const i32_atomic_rmw16_u_xor = "~lib/builtins/i32.atomic.rmw16.xor_u"; + const i32_atomic_rmw_xor = "~lib/builtins/i32.atomic.rmw.xor"; + const i64_atomic_rmw8_xor_u = "~lib/builtins/i64.atomic.rmw8.xor_u"; + const i64_atomic_rmw16_xor_u = "~lib/builtins/i64.atomic.rmw16.xor_u"; + const i64_atomic_rmw32_xor_u = "~lib/builtins/i64.atomic.rmw32.xor_u"; + const i64_atomic_rmw_xor = "~lib/builtins/i64.atomic.rmw.xor"; + const i32_atomic_rmw8_xchg_u = "~lib/builtins/i32.atomic.rmw8.xchg_u"; + const i32_atomic_rmw16_xchg_u = "~lib/builtins/i32.atomic.rmw16.xchg_u"; + const i32_atomic_rmw_xchg = "~lib/builtins/i32.atomic.rmw.xchg"; + const i64_atomic_rmw8_xchg_u = "~lib/builtins/i64.atomic.rmw8.xchg_u"; + const i64_atomic_rmw16_xchg_u = "~lib/builtins/i64.atomic.rmw16.xchg_u"; + const i64_atomic_rmw32_xchg_u = "~lib/builtins/i64.atomic.rmw32.xchg_u"; + const i64_atomic_rmw_xchg = "~lib/builtins/i64.atomic.rmw.xchg"; + const i32_atomic_rmw8_cmpxchg_u = "~lib/builtins/i32.atomic.rmw8.cmpxchg_u"; + const i32_atomic_rmw16_cmpxchg_u = "~lib/builtins/i32.atomic.rmw16.cmpxchg_u"; + const i32_atomic_rmw_cmpxchg = "~lib/builtins/i32.atomic.rmw.cmpxchg"; + const i64_atomic_rmw8_cmpxchg_u = "~lib/builtins/i64.atomic.rmw8.cmpxchg_u"; + const i64_atomic_rmw16_cmpxchg_u = "~lib/builtins/i64.atomic.rmw16.cmpxchg_u"; + const i64_atomic_rmw32_cmpxchg_u = "~lib/builtins/i64.atomic.rmw32.cmpxchg_u"; + const i64_atomic_rmw_cmpxchg = "~lib/builtins/i64.atomic.rmw.cmpxchg"; + const i32_wait = "~lib/builtins/i32.wait"; + const i64_wait = "~lib/builtins/i64.wait"; + const v128_splat = "~lib/builtins/v128.splat"; + const v128_extract_lane = "~lib/builtins/v128.extract_lane"; + const v128_replace_lane = "~lib/builtins/v128.replace_lane"; + const v128_shuffle = "~lib/builtins/v128.shuffle"; + const v128_load = "~lib/builtins/v128.load"; + const v128_store = "~lib/builtins/v128.store"; + const v128_add = "~lib/builtins/v128.add"; + const v128_sub = "~lib/builtins/v128.sub"; + const v128_mul = "~lib/builtins/v128.mul"; + const v128_div = "~lib/builtins/v128.div"; + const v128_neg = "~lib/builtins/v128.neg"; + const v128_add_saturate = "~lib/builtins/v128.add_saturate"; + const v128_sub_saturate = "~lib/builtins/v128.sub_saturate"; + const v128_shl = "~lib/builtins/v128.shl"; + const v128_shr = "~lib/builtins/v128.shr"; + const v128_and = "~lib/builtins/v128.and"; + const v128_or = "~lib/builtins/v128.or"; + const v128_xor = "~lib/builtins/v128.xor"; + const v128_not = "~lib/builtins/v128.not"; + const v128_bitselect = "~lib/builtins/v128.bitselect"; + const v128_any_true = "~lib/builtins/v128.any_true"; + const v128_all_true = "~lib/builtins/v128.all_true"; + const v128_min = "~lib/builtins/v128.min"; + const v128_max = "~lib/builtins/v128.max"; + const v128_abs = "~lib/builtins/v128.abs"; + const v128_sqrt = "~lib/builtins/v128.sqrt"; + const v128_eq = "~lib/builtins/v128.eq"; + const v128_ne = "~lib/builtins/v128.ne"; + const v128_lt = "~lib/builtins/v128.lt"; + const v128_le = "~lib/builtins/v128.le"; + const v128_gt = "~lib/builtins/v128.gt"; + const v128_ge = "~lib/builtins/v128.ge"; + const v128_convert = "~lib/builtins/v128.convert"; + const v128_trunc = "~lib/builtins/v128.trunc"; + const i8x16 = "~lib/builtins/i8x16"; + const i16x8 = "~lib/builtins/i16x8"; + const i32x4 = "~lib/builtins/i32x4"; + const i64x2 = "~lib/builtins/i64x2"; + const f32x4 = "~lib/builtins/f32x4"; + const f64x2 = "~lib/builtins/f64x2"; + const i8x16_splat = "~lib/builtins/i8x16.splat"; + const i8x16_extract_lane_s = "~lib/builtins/i8x16.extract_lane_s"; + const i8x16_extract_lane_u = "~lib/builtins/i8x16.extract_lane_u"; + const i8x16_replace_lane = "~lib/builtins/i8x16.replace_lane"; + const i8x16_add = "~lib/builtins/i8x16.add"; + const i8x16_sub = "~lib/builtins/i8x16.sub"; + const i8x16_mul = "~lib/builtins/i8x16.mul"; + const i8x16_neg = "~lib/builtins/i8x16.neg"; + const i8x16_add_saturate_s = "~lib/builtins/i8x16.add_saturate_s"; + const i8x16_add_saturate_u = "~lib/builtins/i8x16.add_saturate_u"; + const i8x16_sub_saturate_s = "~lib/builtins/i8x16.sub_saturate_s"; + const i8x16_sub_saturate_u = "~lib/builtins/i8x16.sub_saturate_u"; + const i8x16_shl = "~lib/builtins/i8x16.shl"; + const i8x16_shr_s = "~lib/builtins/i8x16.shr_s"; + const i8x16_shr_u = "~lib/builtins/i8x16.shr_u"; + const i8x16_any_true = "~lib/builtins/i8x16.any_true"; + const i8x16_all_true = "~lib/builtins/i8x16.all_true"; + const i8x16_eq = "~lib/builtins/i8x16.eq"; + const i8x16_ne = "~lib/builtins/i8x16.ne"; + const i8x16_lt_s = "~lib/builtins/i8x16.lt_s"; + const i8x16_lt_u = "~lib/builtins/i8x16.lt_u"; + const i8x16_le_s = "~lib/builtins/i8x16.le_s"; + const i8x16_le_u = "~lib/builtins/i8x16.le_u"; + const i8x16_gt_s = "~lib/builtins/i8x16.gt_s"; + const i8x16_gt_u = "~lib/builtins/i8x16.gt_u"; + const i8x16_ge_s = "~lib/builtins/i8x16.ge_s"; + const i8x16_ge_u = "~lib/builtins/i8x16.ge_u"; + const i16x8_splat = "~lib/builtins/i16x8.splat"; + const i16x8_extract_lane_s = "~lib/builtins/i16x8.extract_lane_s"; + const i16x8_extract_lane_u = "~lib/builtins/i16x8.extract_lane_u"; + const i16x8_replace_lane = "~lib/builtins/i16x8.replace_lane"; + const i16x8_add = "~lib/builtins/i16x8.add"; + const i16x8_sub = "~lib/builtins/i16x8.sub"; + const i16x8_mul = "~lib/builtins/i16x8.mul"; + const i16x8_neg = "~lib/builtins/i16x8.neg"; + const i16x8_add_saturate_s = "~lib/builtins/i16x8.add_saturate_s"; + const i16x8_add_saturate_u = "~lib/builtins/i16x8.add_saturate_u"; + const i16x8_sub_saturate_s = "~lib/builtins/i16x8.sub_saturate_s"; + const i16x8_sub_saturate_u = "~lib/builtins/i16x8.sub_saturate_u"; + const i16x8_shl = "~lib/builtins/i16x8.shl"; + const i16x8_shr_s = "~lib/builtins/i16x8.shr_s"; + const i16x8_shr_u = "~lib/builtins/i16x8.shr_u"; + const i16x8_any_true = "~lib/builtins/i16x8.any_true"; + const i16x8_all_true = "~lib/builtins/i16x8.all_true"; + const i16x8_eq = "~lib/builtins/i16x8.eq"; + const i16x8_ne = "~lib/builtins/i16x8.ne"; + const i16x8_lt_s = "~lib/builtins/i16x8.lt_s"; + const i16x8_lt_u = "~lib/builtins/i16x8.lt_u"; + const i16x8_le_s = "~lib/builtins/i16x8.le_s"; + const i16x8_le_u = "~lib/builtins/i16x8.le_u"; + const i16x8_gt_s = "~lib/builtins/i16x8.gt_s"; + const i16x8_gt_u = "~lib/builtins/i16x8.gt_u"; + const i16x8_ge_s = "~lib/builtins/i16x8.ge_s"; + const i16x8_ge_u = "~lib/builtins/i16x8.ge_u"; + const i32x4_splat = "~lib/builtins/i32x4.splat"; + const i32x4_extract_lane = "~lib/builtins/i32x4.extract_lane"; + const i32x4_replace_lane = "~lib/builtins/i32x4.replace_lane"; + const i32x4_add = "~lib/builtins/i32x4.add"; + const i32x4_sub = "~lib/builtins/i32x4.sub"; + const i32x4_mul = "~lib/builtins/i32x4.mul"; + const i32x4_neg = "~lib/builtins/i32x4.neg"; + const i32x4_shl = "~lib/builtins/i32x4.shl"; + const i32x4_shr_s = "~lib/builtins/i32x4.shr_s"; + const i32x4_shr_u = "~lib/builtins/i32x4.shr_u"; + const i32x4_any_true = "~lib/builtins/i32x4.any_true"; + const i32x4_all_true = "~lib/builtins/i32x4.all_true"; + const i32x4_eq = "~lib/builtins/i32x4.eq"; + const i32x4_ne = "~lib/builtins/i32x4.ne"; + const i32x4_lt_s = "~lib/builtins/i32x4.lt_s"; + const i32x4_lt_u = "~lib/builtins/i32x4.lt_u"; + const i32x4_le_s = "~lib/builtins/i32x4.le_s"; + const i32x4_le_u = "~lib/builtins/i32x4.le_u"; + const i32x4_gt_s = "~lib/builtins/i32x4.gt_s"; + const i32x4_gt_u = "~lib/builtins/i32x4.gt_u"; + const i32x4_ge_s = "~lib/builtins/i32x4.ge_s"; + const i32x4_ge_u = "~lib/builtins/i32x4.ge_u"; + const i32x4_trunc_s_f32x4_sat = "~lib/builtins/i32x4.trunc_s_f32x4_sat"; + const i32x4_trunc_u_f32x4_sat = "~lib/builtins/i32x4.trunc_u_f32x4_sat"; + const i64x2_splat = "~lib/builtins/i64x2.splat"; + const i64x2_extract_lane = "~lib/builtins/i64x2.extract_lane"; + const i64x2_replace_lane = "~lib/builtins/i64x2.replace_lane"; + const i64x2_add = "~lib/builtins/i64x2.add"; + const i64x2_sub = "~lib/builtins/i64x2.sub"; + const i64x2_neg = "~lib/builtins/i64x2.neg"; + const i64x2_shl = "~lib/builtins/i64x2.shl"; + const i64x2_shr_s = "~lib/builtins/i64x2.shr_s"; + const i64x2_shr_u = "~lib/builtins/i64x2.shr_u"; + const i64x2_any_true = "~lib/builtins/i64x2.any_true"; + const i64x2_all_true = "~lib/builtins/i64x2.all_true"; + const i64x2_trunc_s_f64x2_sat = "~lib/builtins/i64x2.trunc_s_f64x2_sat"; + const i64x2_trunc_u_f64x2_sat = "~lib/builtins/i64x2.trunc_u_f64x2_sat"; + const f32x4_splat = "~lib/builtins/f32x4.splat"; + const f32x4_extract_lane = "~lib/builtins/f32x4.extract_lane"; + const f32x4_replace_lane = "~lib/builtins/f32x4.replace_lane"; + const f32x4_add = "~lib/builtins/f32x4.add"; + const f32x4_sub = "~lib/builtins/f32x4.sub"; + const f32x4_mul = "~lib/builtins/f32x4.mul"; + const f32x4_div = "~lib/builtins/f32x4.div"; + const f32x4_neg = "~lib/builtins/f32x4.neg"; + const f32x4_min = "~lib/builtins/f32x4.min"; + const f32x4_max = "~lib/builtins/f32x4.max"; + const f32x4_abs = "~lib/builtins/f32x4.abs"; + const f32x4_sqrt = "~lib/builtins/f32x4.sqrt"; + const f32x4_eq = "~lib/builtins/f32x4.eq"; + const f32x4_ne = "~lib/builtins/f32x4.ne"; + const f32x4_lt = "~lib/builtins/f32x4.lt"; + const f32x4_le = "~lib/builtins/f32x4.le"; + const f32x4_gt = "~lib/builtins/f32x4.gt"; + const f32x4_ge = "~lib/builtins/f32x4.ge"; + const f32x4_convert_s_i32x4 = "~lib/builtins/f32x4.convert_s_i32x4"; + const f32x4_convert_u_i32x4 = "~lib/builtins/f32x4.convert_u_i32x4"; + const f64x2_splat = "~lib/builtins/f64x2.splat"; + const f64x2_extract_lane = "~lib/builtins/f64x2.extract_lane"; + const f64x2_replace_lane = "~lib/builtins/f64x2.replace_lane"; + const f64x2_add = "~lib/builtins/f64x2.add"; + const f64x2_sub = "~lib/builtins/f64x2.sub"; + const f64x2_mul = "~lib/builtins/f64x2.mul"; + const f64x2_div = "~lib/builtins/f64x2.div"; + const f64x2_neg = "~lib/builtins/f64x2.neg"; + const f64x2_min = "~lib/builtins/f64x2.min"; + const f64x2_max = "~lib/builtins/f64x2.max"; + const f64x2_abs = "~lib/builtins/f64x2.abs"; + const f64x2_sqrt = "~lib/builtins/f64x2.sqrt"; + const f64x2_eq = "~lib/builtins/f64x2.eq"; + const f64x2_ne = "~lib/builtins/f64x2.ne"; + const f64x2_lt = "~lib/builtins/f64x2.lt"; + const f64x2_le = "~lib/builtins/f64x2.le"; + const f64x2_gt = "~lib/builtins/f64x2.gt"; + const f64x2_ge = "~lib/builtins/f64x2.ge"; + const f64x2_convert_s_i64x2 = "~lib/builtins/f64x2.convert_s_i64x2"; + const f64x2_convert_u_i64x2 = "~lib/builtins/f64x2.convert_u_i64x2"; + const v8x16_shuffle = "~lib/builtins/v8x16.shuffle"; + const heap_base = "~lib/heap/__heap_base"; + const rtti_base = "~lib/rt/__rtti_base"; + const visit_globals = "~lib/rt/__visit_globals"; + const visit_members = "~lib/rt/__visit_members"; + const ERROR = "~lib/diagnostics/ERROR"; + const WARNING = "~lib/diagnostics/WARNING"; + const INFO = "~lib/diagnostics/INFO"; + const memory_size = "~lib/memory/memory.size"; + const memory_grow = "~lib/memory/memory.grow"; + const memory_copy = "~lib/memory/memory.copy"; + const memory_fill = "~lib/memory/memory.fill"; + const memory_allocate = "~lib/memory/memory.allocate"; + const memory_free = "~lib/memory/memory.free"; + const memory_reset = "~lib/memory/memory.reset"; + const runtime_instanceof = "~lib/runtime/runtime.instanceof"; + const runtime_flags = "~lib/runtime/runtime.flags"; + const runtime_allocate = "~lib/util/runtime/allocate"; + const runtime_reallocate = "~lib/util/runtime/reallocate"; + const runtime_register = "~lib/util/runtime/register"; + const runtime_discard = "~lib/util/runtime/discard"; + const runtime_makeArray = "~lib/util/runtime/makeArray"; + const Int8Array = "~lib/typedarray/Int8Array"; + const Uint8Array = "~lib/typedarray/Uint8Array"; + const Int16Array = "~lib/typedarray/Int16Array"; + const Uint16Array = "~lib/typedarray/Uint16Array"; + const Int32Array = "~lib/typedarray/Int32Array"; + const Uint32Array = "~lib/typedarray/Uint32Array"; + const Int64Array = "~lib/typedarray/Int64Array"; + const Uint64Array = "~lib/typedarray/Uint64Array"; + const Uint8ClampedArray = "~lib/typedarray/Uint8ClampedArray"; + const Float32Array = "~lib/typedarray/Float32Array"; + const Float64Array = "~lib/typedarray/Float64Array"; + const started = "~lib/started"; + const argc = "~lib/argc"; + const setargc = "~lib/setargc"; + const capabilities = "~lib/capabilities"; + } + /** Compiles a call to a built-in function. */ + export function compileCall(compiler: Compiler, + /** Respective function prototype. */ + prototype: FunctionPrototype, + /** Pre-resolved type arguments. */ + typeArguments: Type[] | null, + /** Operand expressions. */ + operands: Expression[], + /** Contextual type. */ + contextualType: Type, + /** Respective call expression. */ + reportNode: CallExpression, + /** Indicates that contextual type is ASM type. */ + isAsm?: bool): ExpressionRef; + /** Compiles an abort wired to the conditionally imported 'abort' function. */ + export function compileAbort(compiler: Compiler, message: Expression | null, reportNode: Node): ExpressionRef; + /** Compiles the `visit_globals` function. */ + export function compileVisitGlobals(compiler: Compiler): void; + /** Compiles the `visit_members` function. */ + export function compileVisitMembers(compiler: Compiler): void; + /** Compiles runtime type information for use by stdlib. */ + export function compileRTTI(compiler: Compiler): void; + +} +declare module 'assemblyscript/src/decompiler' { + /** + * A decompiler that generates low-level AssemblyScript from WebAssembly binaries. + * @module decompiler + */ /***/ + import { Module, FunctionRef, ExpressionRef } from 'assemblyscript/src/module'; + export class Decompiler { + static decompile(module: Module): string; + text: string[]; + functionId: i32; + constructor(); + /** Decompiles a module to an AST that can then be serialized. */ + decompile(module: Module): void; + decompileFunction(func: FunctionRef): void; + decompileExpression(expr: ExpressionRef): void; + private push; + finish(): string; + } + +} +declare module 'assemblyscript/src/definitions' { + /** + * Definition builders for WebIDL and TypeScript. + * @module definitions + */ /***/ + import { Program, Element, Global, Enum, Field, Function, Class, Namespace, Interface, File } from 'assemblyscript/src/program'; + import { Type } from 'assemblyscript/src/types'; abstract class ExportsWalker { + /** Program reference. */ + program: Program; + /** Whether to include private members */ + includePrivate: bool; + /** Already seen elements. */ + seen: Map; + /** Constructs a new Element walker. */ + constructor(program: Program, includePrivate?: bool); + /** Walks all elements and calls the respective handlers. */ + walk(): void; + /** Visits all exported elements of a file. */ + visitFile(file: File): void; + /** Visits an element.*/ + visitElement(name: string, element: Element): void; + private visitFunctionInstances; + private visitClassInstances; + private visitPropertyInstances; + abstract visitGlobal(name: string, element: Global): void; + abstract visitEnum(name: string, element: Enum): void; + abstract visitFunction(name: string, element: Function): void; + abstract visitClass(name: string, element: Class): void; + abstract visitInterface(name: string, element: Interface): void; + abstract visitField(name: string, element: Field): void; + abstract visitNamespace(name: string, element: Element): void; + abstract visitAlias(name: string, element: Element, originalName: string): void; + } + /** A WebIDL definitions builder. */ + export class IDLBuilder extends ExportsWalker { + /** Builds WebIDL definitions for the specified program. */ + static build(program: Program): string; + private sb; + private indentLevel; + /** Constructs a new WebIDL builder. */ + constructor(program: Program, includePrivate?: bool); + visitGlobal(name: string, element: Global): void; + visitEnum(name: string, element: Enum): void; + visitFunction(name: string, element: Function): void; + visitClass(name: string, element: Class): void; + visitInterface(name: string, element: Interface): void; + visitField(name: string, element: Field): void; + visitNamespace(name: string, element: Namespace): void; + visitAlias(name: string, element: Element, originalName: string): void; + typeToString(type: Type): string; + build(): string; + } + /** A TypeScript definitions builder. */ + export class TSDBuilder extends ExportsWalker { + /** Builds TypeScript definitions for the specified program. */ + static build(program: Program): string; + private sb; + private indentLevel; + private unknown; + /** Constructs a new WebIDL builder. */ + constructor(program: Program, includePrivate?: bool); + visitGlobal(name: string, element: Global): void; + visitEnum(name: string, element: Enum): void; + visitFunction(name: string, element: Function): void; + visitClass(name: string, element: Class): void; + visitInterface(name: string, element: Interface): void; + visitField(name: string, element: Field): void; + visitNamespace(name: string, element: Element): void; + visitAlias(name: string, element: Element, originalName: string): void; + typeToString(type: Type): string; + build(): string; + } + export {}; + +} +declare module 'assemblyscript/src/parser' { + /** + * A TypeScript parser for the AssemblyScript subset. + * @module parser + */ /***/ + import { CommonFlags } from 'assemblyscript/src/common'; + import { Program } from 'assemblyscript/src/program'; + import { Tokenizer, CommentHandler } from 'assemblyscript/src/tokenizer'; + import { DiagnosticEmitter } from 'assemblyscript/src/diagnostics'; + import { TypeNode, FunctionTypeNode, Expression, ClassExpression, FunctionExpression, Statement, BlockStatement, BreakStatement, ClassDeclaration, ContinueStatement, DeclarationStatement, DecoratorNode, DoStatement, EnumDeclaration, EnumValueDeclaration, ExportImportStatement, ExportMember, ExportStatement, ExpressionStatement, ForStatement, FunctionDeclaration, IfStatement, ImportDeclaration, ImportStatement, IndexSignatureDeclaration, NamespaceDeclaration, ParameterNode, ReturnStatement, SwitchCase, SwitchStatement, ThrowStatement, TryStatement, TypeDeclaration, TypeParameterNode, VariableStatement, VariableDeclaration, VoidStatement, WhileStatement } from 'assemblyscript/src/ast'; + /** Parser interface. */ + export class Parser extends DiagnosticEmitter { + /** Program being created. */ + program: Program; + /** Source file names to be requested next. */ + backlog: string[]; + /** Source file names already seen, that is processed or backlogged. */ + seenlog: Set; + /** Source file names already completely processed. */ + donelog: Set; + /** Optional handler to intercept comments while tokenizing. */ + onComment: CommentHandler | null; + /** Constructs a new parser. */ + constructor(); + /** Parses a file and adds its definitions to the program. */ + parseFile(text: string, path: string, isEntry: bool): void; + /** Parses a top-level statement. */ + parseTopLevelStatement(tn: Tokenizer, namespace?: NamespaceDeclaration | null): Statement | null; + /** Obtains the next file to parse. */ + nextFile(): string | null; + /** Finishes parsing and returns the program. */ + finish(): Program; + /** Parses a type. */ + parseType(tn: Tokenizer, acceptParenthesized?: bool, suppressErrors?: bool): TypeNode | null; + private tryParseSignatureIsSignature; + /** Parses a function type, as used in type declarations. */ + tryParseFunctionType(tn: Tokenizer): FunctionTypeNode | null; + parseDecorator(tn: Tokenizer): DecoratorNode | null; + parseVariable(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): VariableStatement | null; + parseVariableDeclaration(tn: Tokenizer, parentFlags: CommonFlags, parentDecorators: DecoratorNode[] | null): VariableDeclaration | null; + parseEnum(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): EnumDeclaration | null; + parseEnumValue(tn: Tokenizer, parentFlags: CommonFlags): EnumValueDeclaration | null; + parseReturn(tn: Tokenizer): ReturnStatement | null; + parseTypeParameters(tn: Tokenizer): TypeParameterNode[] | null; + parseTypeParameter(tn: Tokenizer): TypeParameterNode | null; + private parseParametersThis; + parseParameters(tn: Tokenizer, isConstructor?: bool): ParameterNode[] | null; + parseParameter(tn: Tokenizer, isConstructor?: bool): ParameterNode | null; + parseFunction(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): FunctionDeclaration | null; + parseFunctionExpression(tn: Tokenizer): FunctionExpression | null; + private parseFunctionExpressionCommon; + parseClassOrInterface(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): ClassDeclaration | null; + parseClassExpression(tn: Tokenizer): ClassExpression | null; + parseClassMember(tn: Tokenizer, parent: ClassDeclaration): DeclarationStatement | null; + parseIndexSignatureDeclaration(tn: Tokenizer, decorators: DecoratorNode[] | null): IndexSignatureDeclaration | null; + parseNamespace(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): NamespaceDeclaration | null; + parseExport(tn: Tokenizer, startPos: i32, isDeclare: bool): ExportStatement | null; + parseExportMember(tn: Tokenizer): ExportMember | null; + parseExportDefaultAlias(tn: Tokenizer, startPos: i32, defaultStart: i32, defaultEnd: i32): ExportStatement; + parseImport(tn: Tokenizer): ImportStatement | null; + parseImportDeclaration(tn: Tokenizer): ImportDeclaration | null; + parseExportImport(tn: Tokenizer, startPos: i32): ExportImportStatement | null; + parseStatement(tn: Tokenizer, topLevel?: bool): Statement | null; + parseBlockStatement(tn: Tokenizer, topLevel: bool): BlockStatement | null; + parseBreak(tn: Tokenizer): BreakStatement | null; + parseContinue(tn: Tokenizer): ContinueStatement | null; + parseDoStatement(tn: Tokenizer): DoStatement | null; + parseExpressionStatement(tn: Tokenizer): ExpressionStatement | null; + parseForStatement(tn: Tokenizer): ForStatement | null; + parseIfStatement(tn: Tokenizer): IfStatement | null; + parseSwitchStatement(tn: Tokenizer): SwitchStatement | null; + parseSwitchCase(tn: Tokenizer): SwitchCase | null; + parseThrowStatement(tn: Tokenizer): ThrowStatement | null; + parseTryStatement(tn: Tokenizer): TryStatement | null; + parseTypeDeclaration(tn: Tokenizer, flags: CommonFlags, decorators: DecoratorNode[] | null, startPos: i32): TypeDeclaration | null; + parseVoidStatement(tn: Tokenizer): VoidStatement | null; + parseWhileStatement(tn: Tokenizer): WhileStatement | null; + parseExpressionStart(tn: Tokenizer): Expression | null; + tryParseTypeArgumentsBeforeArguments(tn: Tokenizer): TypeNode[] | null; + parseArguments(tn: Tokenizer): Expression[] | null; + parseExpression(tn: Tokenizer, precedence?: Precedence): Expression | null; + private joinPropertyCall; + private maybeParseCallExpression; + /** Skips over a statement on errors in an attempt to reduce unnecessary diagnostic noise. */ + skipStatement(tn: Tokenizer): void; + /** Skips over a block on errors in an attempt to reduce unnecessary diagnostic noise. */ + skipBlock(tn: Tokenizer): void; + } + /** Operator precedence from least to largest. */ + export const enum Precedence { + NONE = 0, + COMMA = 1, + SPREAD = 2, + YIELD = 3, + ASSIGNMENT = 4, + CONDITIONAL = 5, + LOGICAL_OR = 6, + LOGICAL_AND = 7, + BITWISE_OR = 8, + BITWISE_XOR = 9, + BITWISE_AND = 10, + EQUALITY = 11, + RELATIONAL = 12, + SHIFT = 13, + ADDITIVE = 14, + MULTIPLICATIVE = 15, + EXPONENTIATED = 16, + UNARY_PREFIX = 17, + UNARY_POSTFIX = 18, + CALL = 19, + MEMBERACCESS = 20, + GROUPING = 21 + } + +} +declare module 'assemblyscript/src/index' { + /** + * Low-level C-like compiler API. + * @module index + */ /***/ + import { Target, Feature } from 'assemblyscript/src/common'; + import { Options } from 'assemblyscript/src/compiler'; + import { DiagnosticMessage, formatDiagnosticMessage } from 'assemblyscript/src/diagnostics'; + import { Module } from 'assemblyscript/src/module'; + import { Parser } from 'assemblyscript/src/parser'; + import { Program } from 'assemblyscript/src/program'; + /** Parses a source file. If `parser` has been omitted a new one is created. */ + export function parseFile(text: string, path: string, isEntry?: bool, parser?: Parser | null): Parser; + /** Obtains the next required file's path. Returns `null` once complete. */ + export function nextFile(parser: Parser): string | null; + /** Obtains the next diagnostic message. Returns `null` once complete. */ + export function nextDiagnostic(parser: Parser): DiagnosticMessage | null; + /** Formats a diagnostic message to a string. */ + export { formatDiagnosticMessage as formatDiagnostic }; + /** Tests whether a diagnostic is informatory. */ + export function isInfo(message: DiagnosticMessage): bool; + /** Tests whether a diagnostic is a warning. */ + export function isWarning(message: DiagnosticMessage): bool; + /** Tests whether a diagnostic is an error. */ + export function isError(message: DiagnosticMessage): bool; + /** Creates a new set of compiler options. */ + export function createOptions(): Options; + /** Sets the `target` option. */ + export function setTarget(options: Options, target: Target): void; + /** Sets the `noAssert` option. */ + export function setNoAssert(options: Options, noAssert: bool): void; + /** Sets the `importMemory` option. */ + export function setImportMemory(options: Options, importMemory: bool): void; + /** Sets the `sharedMemory` option. */ + export function setSharedMemory(options: Options, sharedMemory: i32): void; + /** Sets the `importTable` option. */ + export function setImportTable(options: Options, importTable: bool): void; + /** Sets the `sourceMap` option. */ + export function setSourceMap(options: Options, sourceMap: bool): void; + /** Sets the `memoryBase` option. */ + export function setMemoryBase(options: Options, memoryBase: u32): void; + /** Sets a 'globalAliases' value. */ + export function setGlobalAlias(options: Options, alias: string, name: string): void; + /** Sets the `explicitStart` option. */ + export function setExplicitStart(options: Options, explicitStart: bool): void; + /** Sign extension operations. */ + export const FEATURE_SIGN_EXTENSION: Feature; + /** Mutable global imports and exports. */ + export const FEATURE_MUTABLE_GLOBAL: Feature; + /** Bulk memory operations. */ + export const FEATURE_BULK_MEMORY: Feature; + /** SIMD types and operations. */ + export const FEATURE_SIMD: Feature; + /** Threading and atomic operations. */ + export const FEATURE_THREADS: Feature; + /** Enables a specific feature. */ + export function enableFeature(options: Options, feature: Feature): void; + /** Gives the compiler a hint at the optimize levels that will be used later on. */ + export function setOptimizeLevelHints(options: Options, optimizeLevel: i32, shrinkLevel: i32): void; + /** Finishes parsing. */ + export function finishParsing(parser: Parser): Program; + /** Compiles the sources computed by the parser to a module. */ + export function compileProgram(program: Program, options?: Options | null): Module; + /** Decompiles a module to its (low level) source. */ + export function decompileModule(module: Module): string; + /** Builds WebIDL definitions for the specified program. */ + export function buildIDL(program: Program): string; + /** Builds TypeScript definitions for the specified program. */ + export function buildTSD(program: Program): string; + /** Builds a JSON file of a program's runtime type information. */ + export function buildRTTI(program: Program): string; + /** Prefix indicating a library file. */ + export { LIBRARY_PREFIX } from 'assemblyscript/src/common'; + export * from 'assemblyscript/src/ast'; + export * from 'assemblyscript/src/common'; + export * from 'assemblyscript/src/compiler'; + export * from 'assemblyscript/src/decompiler'; + export * from 'assemblyscript/src/definitions'; + export * from 'assemblyscript/src/diagnosticMessages.generated'; + export * from 'assemblyscript/src/diagnostics'; + export * from 'assemblyscript/src/flow'; + export * from 'assemblyscript/src/module'; + export * from 'assemblyscript/src/parser'; + export * from 'assemblyscript/src/program'; + export * from 'assemblyscript/src/resolver'; + export * from 'assemblyscript/src/tokenizer'; + export * from 'assemblyscript/src/types'; + export * from 'assemblyscript/src/util'; + +} +declare module 'assemblyscript/src/extra/ast' { + /** + * Abstract Syntax Tree extras. + * + * Not needed in a standalone compiler but useful for testing the parser. + * + * @module extra/ast + */ /***/ + import { Node, Source, TypeNode, NamedTypeNode, FunctionTypeNode, TypeName, TypeParameterNode, IdentifierExpression, LiteralExpression, FloatLiteralExpression, IntegerLiteralExpression, StringLiteralExpression, RegexpLiteralExpression, ArrayLiteralExpression, AssertionExpression, BinaryExpression, CallExpression, CommaExpression, ElementAccessExpression, FunctionExpression, NewExpression, ParenthesizedExpression, PropertyAccessExpression, TernaryExpression, UnaryPostfixExpression, UnaryExpression, UnaryPrefixExpression, ClassExpression, ObjectLiteralExpression, Statement, BlockStatement, BreakStatement, ContinueStatement, DoStatement, EmptyStatement, ExportImportStatement, ExportStatement, ExportDefaultStatement, ExpressionStatement, ForStatement, IfStatement, ImportStatement, InstanceOfExpression, ReturnStatement, SwitchStatement, ThrowStatement, TryStatement, VariableStatement, WhileStatement, ClassDeclaration, EnumDeclaration, EnumValueDeclaration, FieldDeclaration, FunctionDeclaration, ImportDeclaration, IndexSignatureDeclaration, InterfaceDeclaration, MethodDeclaration, NamespaceDeclaration, TypeDeclaration, VariableDeclaration, DecoratorNode, ParameterNode, ExportMember, SwitchCase, DeclarationStatement } from 'assemblyscript/src/ast'; + /** An AST builder. */ + export class ASTBuilder { + /** Rebuilds the textual source from the specified AST, as far as possible. */ + static build(node: Node): string; + private sb; + private indentLevel; + visitNode(node: Node): void; + visitSource(source: Source): void; + visitTypeNode(node: TypeNode): void; + visitTypeName(node: TypeName): void; + visitNamedTypeNode(node: NamedTypeNode): void; + visitFunctionTypeNode(node: FunctionTypeNode): void; + visitTypeParameter(node: TypeParameterNode): void; + visitIdentifierExpression(node: IdentifierExpression): void; + visitArrayLiteralExpression(node: ArrayLiteralExpression): void; + visitObjectLiteralExpression(node: ObjectLiteralExpression): void; + visitAssertionExpression(node: AssertionExpression): void; + visitBinaryExpression(node: BinaryExpression): void; + visitCallExpression(node: CallExpression): void; + visitClassExpression(node: ClassExpression): void; + visitCommaExpression(node: CommaExpression): void; + visitElementAccessExpression(node: ElementAccessExpression): void; + visitFunctionExpression(node: FunctionExpression): void; + visitLiteralExpression(node: LiteralExpression): void; + visitFloatLiteralExpression(node: FloatLiteralExpression): void; + visitInstanceOfExpression(node: InstanceOfExpression): void; + visitIntegerLiteralExpression(node: IntegerLiteralExpression): void; + visitStringLiteral(str: string, singleQuoted?: bool): void; + visitStringLiteralExpression(node: StringLiteralExpression): void; + visitRegexpLiteralExpression(node: RegexpLiteralExpression): void; + visitNewExpression(node: NewExpression): void; + visitParenthesizedExpression(node: ParenthesizedExpression): void; + visitPropertyAccessExpression(node: PropertyAccessExpression): void; + visitTernaryExpression(node: TernaryExpression): void; + visitUnaryExpression(node: UnaryExpression): void; + visitUnaryPostfixExpression(node: UnaryPostfixExpression): void; + visitUnaryPrefixExpression(node: UnaryPrefixExpression): void; + visitNodeAndTerminate(statement: Statement): void; + visitBlockStatement(node: BlockStatement): void; + visitBreakStatement(node: BreakStatement): void; + visitContinueStatement(node: ContinueStatement): void; + visitClassDeclaration(node: ClassDeclaration, isDefault?: bool): void; + visitDoStatement(node: DoStatement): void; + visitEmptyStatement(node: EmptyStatement): void; + visitEnumDeclaration(node: EnumDeclaration, isDefault?: bool): void; + visitEnumValueDeclaration(node: EnumValueDeclaration): void; + visitExportImportStatement(node: ExportImportStatement): void; + visitExportMember(node: ExportMember): void; + visitExportStatement(node: ExportStatement): void; + visitExportDefaultStatement(node: ExportDefaultStatement): void; + visitExpressionStatement(node: ExpressionStatement): void; + visitFieldDeclaration(node: FieldDeclaration): void; + visitForStatement(node: ForStatement): void; + visitFunctionDeclaration(node: FunctionDeclaration, isDefault?: bool): void; + visitFunctionCommon(node: FunctionDeclaration): void; + visitIfStatement(node: IfStatement): void; + visitImportDeclaration(node: ImportDeclaration): void; + visitImportStatement(node: ImportStatement): void; + visitIndexSignatureDeclaration(node: IndexSignatureDeclaration): void; + visitInterfaceDeclaration(node: InterfaceDeclaration, isDefault?: bool): void; + visitMethodDeclaration(node: MethodDeclaration): void; + visitNamespaceDeclaration(node: NamespaceDeclaration, isDefault?: bool): void; + visitReturnStatement(node: ReturnStatement): void; + visitSwitchCase(node: SwitchCase): void; + visitSwitchStatement(node: SwitchStatement): void; + visitThrowStatement(node: ThrowStatement): void; + visitTryStatement(node: TryStatement): void; + visitTypeDeclaration(node: TypeDeclaration): void; + visitVariableDeclaration(node: VariableDeclaration): void; + visitVariableStatement(node: VariableStatement): void; + visitWhileStatement(node: WhileStatement): void; + serializeDecorator(node: DecoratorNode): void; + serializeParameter(node: ParameterNode): void; + serializeExternalModifiers(node: DeclarationStatement): void; + serializeAccessModifiers(node: DeclarationStatement): void; + finish(): string; + } + +} +/** + * TypeScript definitions for Binaryen's C-API. + * + * See: https://github.com/WebAssembly/binaryen/blob/master/src/binaryen-c.h + * + * @module glue/binaryen + *//***/ + +declare function _malloc(size: usize): usize; +declare function _free(ptr: usize): void; + +declare type BinaryenIndex = u32; + +declare type BinaryenType = i32; + +declare function _BinaryenTypeNone(): BinaryenType; +declare function _BinaryenTypeInt32(): BinaryenType; +declare function _BinaryenTypeInt64(): BinaryenType; +declare function _BinaryenTypeFloat32(): BinaryenType; +declare function _BinaryenTypeFloat64(): BinaryenType; +declare function _BinaryenTypeVec128(): BinaryenType; +declare function _BinaryenTypeUnreachable(): BinaryenType; +declare function _BinaryenTypeAuto(): BinaryenType; + +declare type BinaryenFeatureFlags = u32; + +declare function _BinaryenFeatureAtomics(): BinaryenFeatureFlags; +declare function _BinaryenFeatureMutableGlobals(): BinaryenFeatureFlags; +declare function _BinaryenFeatureNontrappingFPToInt(): BinaryenFeatureFlags; +declare function _BinaryenFeatureSIMD128(): BinaryenFeatureFlags; +declare function _BinaryenFeatureBulkMemory(): BinaryenFeatureFlags; +declare function _BinaryenFeatureSignExt(): BinaryenFeatureFlags; +declare function _BinaryenFeatureExceptionHandling(): BinaryenFeatureFlags; + +declare type BinaryenExpressionId = i32; + +declare function _BinaryenInvalidId(): BinaryenExpressionId; +declare function _BinaryenBlockId(): BinaryenExpressionId; +declare function _BinaryenIfId(): BinaryenExpressionId; +declare function _BinaryenLoopId(): BinaryenExpressionId; +declare function _BinaryenBreakId(): BinaryenExpressionId; +declare function _BinaryenSwitchId(): BinaryenExpressionId; +declare function _BinaryenCallId(): BinaryenExpressionId; +declare function _BinaryenCallIndirectId(): BinaryenExpressionId; +declare function _BinaryenLocalGetId(): BinaryenExpressionId; +declare function _BinaryenLocalSetId(): BinaryenExpressionId; +declare function _BinaryenGlobalGetId(): BinaryenExpressionId; +declare function _BinaryenGlobalSetId(): BinaryenExpressionId; +declare function _BinaryenLoadId(): BinaryenExpressionId; +declare function _BinaryenStoreId(): BinaryenExpressionId; +declare function _BinaryenConstId(): BinaryenExpressionId; +declare function _BinaryenUnaryId(): BinaryenExpressionId; +declare function _BinaryenBinaryId(): BinaryenExpressionId; +declare function _BinaryenSelectId(): BinaryenExpressionId; +declare function _BinaryenDropId(): BinaryenExpressionId; +declare function _BinaryenReturnId(): BinaryenExpressionId; +declare function _BinaryenHostId(): BinaryenExpressionId; +declare function _BinaryenNopId(): BinaryenExpressionId; +declare function _BinaryenUnreachableId(): BinaryenExpressionId; +declare function _BinaryenAtomicCmpxchgId(): BinaryenExpressionId; +declare function _BinaryenAtomicRMWId(): BinaryenExpressionId; +declare function _BinaryenAtomicWaitId(): BinaryenExpressionId; +declare function _BinaryenAtomicNotifyId(): BinaryenExpressionId; +declare function _BinaryenSIMDExtractId(): BinaryenExpressionId; +declare function _BinaryenSIMDReplaceId(): BinaryenExpressionId; +declare function _BinaryenSIMDShuffleId(): BinaryenExpressionId; +declare function _BinaryenSIMDBitselectId(): BinaryenExpressionId; +declare function _BinaryenSIMDShiftId(): BinaryenExpressionId; +declare function _BinaryenMemoryInitId(): BinaryenExpressionId; +declare function _BinaryenDataDropId(): BinaryenExpressionId; +declare function _BinaryenMemoryCopyId(): BinaryenExpressionId; +declare function _BinaryenMemoryFillId(): BinaryenExpressionId; + +declare type BinaryenModuleRef = usize; +declare type v128ptr = usize; // TODO: LLVM C-abi for const uint8_t[16]? + +declare function _BinaryenModuleCreate(): BinaryenModuleRef; +declare function _BinaryenModuleDispose(module: BinaryenModuleRef): void; + +// LLVM C ABI with `out` being a large enough buffer receiving the +// BinaryenLiteral struct of size `_BinaryenSizeofLiteral()`. +declare function _BinaryenSizeofLiteral(): usize; +declare function _BinaryenLiteralInt32(out: usize, x: i32): void; +declare function _BinaryenLiteralInt64(out: usize, x: i32, y: i32): void; +declare function _BinaryenLiteralFloat32(out: usize, x: f32): void; +declare function _BinaryenLiteralFloat64(out: usize, x: f64): void; +declare function _BinaryenLiteralVec128(out: usize, x: v128ptr): void; +declare function _BinaryenLiteralFloat32Bits(out: usize, x: i32): void; +declare function _BinaryenLiteralFloat64Bits(out: usize, x: i32, y: i32): void; + +declare type BinaryenOp = i32; + +declare function _BinaryenClzInt32(): BinaryenOp; +declare function _BinaryenCtzInt32(): BinaryenOp; +declare function _BinaryenPopcntInt32(): BinaryenOp; +declare function _BinaryenNegFloat32(): BinaryenOp; +declare function _BinaryenAbsFloat32(): BinaryenOp; +declare function _BinaryenCeilFloat32(): BinaryenOp; +declare function _BinaryenFloorFloat32(): BinaryenOp; +declare function _BinaryenTruncFloat32(): BinaryenOp; +declare function _BinaryenNearestFloat32(): BinaryenOp; +declare function _BinaryenSqrtFloat32(): BinaryenOp; +declare function _BinaryenEqZInt32(): BinaryenOp; +declare function _BinaryenClzInt64(): BinaryenOp; +declare function _BinaryenCtzInt64(): BinaryenOp; +declare function _BinaryenPopcntInt64(): BinaryenOp; +declare function _BinaryenNegFloat64(): BinaryenOp; +declare function _BinaryenAbsFloat64(): BinaryenOp; +declare function _BinaryenCeilFloat64(): BinaryenOp; +declare function _BinaryenFloorFloat64(): BinaryenOp; +declare function _BinaryenTruncFloat64(): BinaryenOp; +declare function _BinaryenNearestFloat64(): BinaryenOp; +declare function _BinaryenSqrtFloat64(): BinaryenOp; +declare function _BinaryenEqZInt64(): BinaryenOp; +declare function _BinaryenExtendSInt32(): BinaryenOp; +declare function _BinaryenExtendUInt32(): BinaryenOp; +declare function _BinaryenWrapInt64(): BinaryenOp; +declare function _BinaryenTruncSFloat32ToInt32(): BinaryenOp; +declare function _BinaryenTruncSFloat32ToInt64(): BinaryenOp; +declare function _BinaryenTruncUFloat32ToInt32(): BinaryenOp; +declare function _BinaryenTruncUFloat32ToInt64(): BinaryenOp; +declare function _BinaryenTruncSFloat64ToInt32(): BinaryenOp; +declare function _BinaryenTruncSFloat64ToInt64(): BinaryenOp; +declare function _BinaryenTruncUFloat64ToInt32(): BinaryenOp; +declare function _BinaryenTruncUFloat64ToInt64(): BinaryenOp; +declare function _BinaryenReinterpretFloat32(): BinaryenOp; +declare function _BinaryenReinterpretFloat64(): BinaryenOp; +declare function _BinaryenConvertSInt32ToFloat32(): BinaryenOp; +declare function _BinaryenConvertSInt32ToFloat64(): BinaryenOp; +declare function _BinaryenConvertUInt32ToFloat32(): BinaryenOp; +declare function _BinaryenConvertUInt32ToFloat64(): BinaryenOp; +declare function _BinaryenConvertSInt64ToFloat32(): BinaryenOp; +declare function _BinaryenConvertSInt64ToFloat64(): BinaryenOp; +declare function _BinaryenConvertUInt64ToFloat32(): BinaryenOp; +declare function _BinaryenConvertUInt64ToFloat64(): BinaryenOp; +declare function _BinaryenPromoteFloat32(): BinaryenOp; +declare function _BinaryenDemoteFloat64(): BinaryenOp; +declare function _BinaryenReinterpretInt32(): BinaryenOp; +declare function _BinaryenReinterpretInt64(): BinaryenOp; +declare function _BinaryenExtendS8Int32(): BinaryenOp; +declare function _BinaryenExtendS16Int32(): BinaryenOp; +declare function _BinaryenExtendS8Int64(): BinaryenOp; +declare function _BinaryenExtendS16Int64(): BinaryenOp; +declare function _BinaryenExtendS32Int64(): BinaryenOp; +declare function _BinaryenAddInt32(): BinaryenOp; +declare function _BinaryenSubInt32(): BinaryenOp; +declare function _BinaryenMulInt32(): BinaryenOp; +declare function _BinaryenDivSInt32(): BinaryenOp; +declare function _BinaryenDivUInt32(): BinaryenOp; +declare function _BinaryenRemSInt32(): BinaryenOp; +declare function _BinaryenRemUInt32(): BinaryenOp; +declare function _BinaryenAndInt32(): BinaryenOp; +declare function _BinaryenOrInt32(): BinaryenOp; +declare function _BinaryenXorInt32(): BinaryenOp; +declare function _BinaryenShlInt32(): BinaryenOp; +declare function _BinaryenShrUInt32(): BinaryenOp; +declare function _BinaryenShrSInt32(): BinaryenOp; +declare function _BinaryenRotLInt32(): BinaryenOp; +declare function _BinaryenRotRInt32(): BinaryenOp; +declare function _BinaryenEqInt32(): BinaryenOp; +declare function _BinaryenNeInt32(): BinaryenOp; +declare function _BinaryenLtSInt32(): BinaryenOp; +declare function _BinaryenLtUInt32(): BinaryenOp; +declare function _BinaryenLeSInt32(): BinaryenOp; +declare function _BinaryenLeUInt32(): BinaryenOp; +declare function _BinaryenGtSInt32(): BinaryenOp; +declare function _BinaryenGtUInt32(): BinaryenOp; +declare function _BinaryenGeSInt32(): BinaryenOp; +declare function _BinaryenGeUInt32(): BinaryenOp; +declare function _BinaryenAddInt64(): BinaryenOp; +declare function _BinaryenSubInt64(): BinaryenOp; +declare function _BinaryenMulInt64(): BinaryenOp; +declare function _BinaryenDivSInt64(): BinaryenOp; +declare function _BinaryenDivUInt64(): BinaryenOp; +declare function _BinaryenRemSInt64(): BinaryenOp; +declare function _BinaryenRemUInt64(): BinaryenOp; +declare function _BinaryenAndInt64(): BinaryenOp; +declare function _BinaryenOrInt64(): BinaryenOp; +declare function _BinaryenXorInt64(): BinaryenOp; +declare function _BinaryenShlInt64(): BinaryenOp; +declare function _BinaryenShrUInt64(): BinaryenOp; +declare function _BinaryenShrSInt64(): BinaryenOp; +declare function _BinaryenRotLInt64(): BinaryenOp; +declare function _BinaryenRotRInt64(): BinaryenOp; +declare function _BinaryenEqInt64(): BinaryenOp; +declare function _BinaryenNeInt64(): BinaryenOp; +declare function _BinaryenLtSInt64(): BinaryenOp; +declare function _BinaryenLtUInt64(): BinaryenOp; +declare function _BinaryenLeSInt64(): BinaryenOp; +declare function _BinaryenLeUInt64(): BinaryenOp; +declare function _BinaryenGtSInt64(): BinaryenOp; +declare function _BinaryenGtUInt64(): BinaryenOp; +declare function _BinaryenGeSInt64(): BinaryenOp; +declare function _BinaryenGeUInt64(): BinaryenOp; +declare function _BinaryenAddFloat32(): BinaryenOp; +declare function _BinaryenSubFloat32(): BinaryenOp; +declare function _BinaryenMulFloat32(): BinaryenOp; +declare function _BinaryenDivFloat32(): BinaryenOp; +declare function _BinaryenCopySignFloat32(): BinaryenOp; +declare function _BinaryenMinFloat32(): BinaryenOp; +declare function _BinaryenMaxFloat32(): BinaryenOp; +declare function _BinaryenEqFloat32(): BinaryenOp; +declare function _BinaryenNeFloat32(): BinaryenOp; +declare function _BinaryenLtFloat32(): BinaryenOp; +declare function _BinaryenLeFloat32(): BinaryenOp; +declare function _BinaryenGtFloat32(): BinaryenOp; +declare function _BinaryenGeFloat32(): BinaryenOp; +declare function _BinaryenAddFloat64(): BinaryenOp; +declare function _BinaryenSubFloat64(): BinaryenOp; +declare function _BinaryenMulFloat64(): BinaryenOp; +declare function _BinaryenDivFloat64(): BinaryenOp; +declare function _BinaryenCopySignFloat64(): BinaryenOp; +declare function _BinaryenMinFloat64(): BinaryenOp; +declare function _BinaryenMaxFloat64(): BinaryenOp; +declare function _BinaryenEqFloat64(): BinaryenOp; +declare function _BinaryenNeFloat64(): BinaryenOp; +declare function _BinaryenLtFloat64(): BinaryenOp; +declare function _BinaryenLeFloat64(): BinaryenOp; +declare function _BinaryenGtFloat64(): BinaryenOp; +declare function _BinaryenGeFloat64(): BinaryenOp; + +declare type BinaryenHostOp = BinaryenOp; + +declare function _BinaryenMemorySize(): BinaryenHostOp; +declare function _BinaryenMemoryGrow(): BinaryenHostOp; + +declare type BinaryenAtomicRMWOp = BinaryenOp; + +declare function _BinaryenAtomicRMWAdd(): BinaryenAtomicRMWOp; +declare function _BinaryenAtomicRMWSub(): BinaryenAtomicRMWOp; +declare function _BinaryenAtomicRMWAnd(): BinaryenAtomicRMWOp; +declare function _BinaryenAtomicRMWOr(): BinaryenAtomicRMWOp; +declare function _BinaryenAtomicRMWXor(): BinaryenAtomicRMWOp; +declare function _BinaryenAtomicRMWXchg(): BinaryenAtomicRMWOp; + +declare type BinaryenSIMDOp = BinaryenOp; + +declare function _BinaryenSplatVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenExtractLaneSVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenExtractLaneUVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenReplaceLaneVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenSplatVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenExtractLaneSVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenExtractLaneUVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenReplaceLaneVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenSplatVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenExtractLaneVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenReplaceLaneVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenSplatVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenExtractLaneVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenReplaceLaneVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenSplatVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenExtractLaneVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenReplaceLaneVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenSplatVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenExtractLaneVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenReplaceLaneVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenEqVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenNeVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenLtSVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenLtUVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenGtSVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenGtUVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenLeSVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenLeUVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenGeSVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenGeUVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenEqVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenNeVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenLtSVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenLtUVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenGtSVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenGtUVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenLeSVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenLeUVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenGeSVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenGeUVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenEqVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenNeVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenLtSVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenLtUVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenGtSVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenGtUVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenLeSVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenLeUVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenGeSVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenGeUVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenEqVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenNeVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenLtVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenGtVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenLeVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenGeVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenEqVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenNeVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenLtVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenGtVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenLeVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenGeVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenNotVec128(): BinaryenSIMDOp; +declare function _BinaryenAndVec128(): BinaryenSIMDOp; +declare function _BinaryenOrVec128(): BinaryenSIMDOp; +declare function _BinaryenXorVec128(): BinaryenSIMDOp; +declare function _BinaryenNegVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenAnyTrueVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenAllTrueVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenShlVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenShrSVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenShrUVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenAddVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenAddSatSVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenAddSatUVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenSubVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenSubSatSVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenSubSatUVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenMulVecI8x16(): BinaryenSIMDOp; +declare function _BinaryenNegVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenAnyTrueVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenAllTrueVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenShlVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenShrSVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenShrUVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenAddVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenAddSatSVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenAddSatUVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenSubVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenSubSatSVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenSubSatUVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenMulVecI16x8(): BinaryenSIMDOp; +declare function _BinaryenNegVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenAnyTrueVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenAllTrueVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenShlVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenShrSVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenShrUVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenAddVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenSubVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenMulVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenNegVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenAnyTrueVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenAllTrueVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenShlVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenShrSVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenShrUVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenAddVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenSubVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenAbsVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenNegVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenSqrtVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenAddVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenSubVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenMulVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenDivVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenMinVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenMaxVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenAbsVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenNegVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenSqrtVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenAddVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenSubVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenMulVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenDivVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenMinVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenMaxVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenTruncSatSVecF32x4ToVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenTruncSatUVecF32x4ToVecI32x4(): BinaryenSIMDOp; +declare function _BinaryenTruncSatSVecF64x2ToVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenTruncSatUVecF64x2ToVecI64x2(): BinaryenSIMDOp; +declare function _BinaryenConvertSVecI32x4ToVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenConvertUVecI32x4ToVecF32x4(): BinaryenSIMDOp; +declare function _BinaryenConvertSVecI64x2ToVecF64x2(): BinaryenSIMDOp; +declare function _BinaryenConvertUVecI64x2ToVecF64x2(): BinaryenSIMDOp; + +declare type BinaryenExpressionRef = usize; + +declare function _BinaryenBlock(module: BinaryenModuleRef, name: usize, children: usize, numChildren: BinaryenIndex, type: BinaryenType): BinaryenExpressionRef; +declare function _BinaryenIf(module: BinaryenModuleRef, condition: BinaryenExpressionRef, ifTrue: BinaryenExpressionRef, ifFalse: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenLoop(module: BinaryenModuleRef, name: usize, body: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenBreak(module: BinaryenModuleRef, name: usize, condition: BinaryenExpressionRef, value: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSwitch(module: BinaryenModuleRef, names: usize, numNames: BinaryenIndex, defaultName: usize, condition: BinaryenExpressionRef, value: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenCall(module: BinaryenModuleRef, target: usize, operands: usize, numOperands: BinaryenIndex, returnType: BinaryenType): BinaryenExpressionRef; +declare function _BinaryenCallIndirect(module: BinaryenModuleRef, target: BinaryenExpressionRef, operands: usize, numOperands: BinaryenIndex, type: usize): BinaryenExpressionRef; +declare function _BinaryenLocalGet(module: BinaryenModuleRef, index: BinaryenIndex, type: BinaryenType): BinaryenExpressionRef; +declare function _BinaryenLocalSet(module: BinaryenModuleRef, index: BinaryenIndex, value: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenLocalTee(module: BinaryenModuleRef, index: BinaryenIndex, value: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenGlobalGet(module: BinaryenModuleRef, name: usize, type: BinaryenType): BinaryenExpressionRef; +declare function _BinaryenGlobalSet(module: BinaryenModuleRef, name: usize, value: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenLoad(module: BinaryenModuleRef, bytes: u32, signed: i8, offset: u32, align: u32, type: BinaryenType, ptr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenStore(module: BinaryenModuleRef, bytes: u32, offset: u32, align: u32, ptr: BinaryenExpressionRef, value: BinaryenExpressionRef, type: BinaryenType): BinaryenExpressionRef; +declare function _BinaryenConst(module: BinaryenModuleRef, value: usize): BinaryenExpressionRef; +declare function _BinaryenUnary(module: BinaryenModuleRef, op: BinaryenOp, value: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenBinary(module: BinaryenModuleRef, op: BinaryenOp, left: BinaryenExpressionRef, right: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSelect(module: BinaryenModuleRef, condition: BinaryenExpressionRef, ifTrue: BinaryenExpressionRef, ifFalse: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenDrop(module: BinaryenModuleRef, value: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenReturn(module: BinaryenModuleRef, value: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenHost(module: BinaryenModuleRef, op: BinaryenOp, name: usize | 0, operands: usize, numOperands: BinaryenIndex): BinaryenExpressionRef; +declare function _BinaryenNop(module: BinaryenModuleRef): BinaryenExpressionRef; +declare function _BinaryenUnreachable(module: BinaryenModuleRef): BinaryenExpressionRef; + +declare function _BinaryenAtomicLoad(module: BinaryenModuleRef, bytes: BinaryenIndex, offset: BinaryenIndex, type: BinaryenType, ptr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenAtomicStore(module: BinaryenModuleRef, bytes: BinaryenIndex, offset: BinaryenIndex, ptr: BinaryenExpressionRef, value: BinaryenExpressionRef, type: BinaryenType): BinaryenExpressionRef; +declare function _BinaryenAtomicRMW(module: BinaryenModuleRef, op: BinaryenAtomicRMWOp, bytes: i32, offset: i32, ptr: BinaryenExpressionRef, value: BinaryenExpressionRef, type: BinaryenType): BinaryenExpressionRef; +declare function _BinaryenAtomicCmpxchg(module: BinaryenModuleRef, bytes: i32, offset: i32, ptr: BinaryenExpressionRef, expected: BinaryenExpressionRef, replacement: BinaryenExpressionRef, type: BinaryenType): BinaryenExpressionRef; +declare function _BinaryenAtomicWait(module: BinaryenModuleRef, ptr: BinaryenExpressionRef, expected: BinaryenExpressionRef, timeout: BinaryenExpressionRef, expectedType: BinaryenType): BinaryenExpressionRef; +declare function _BinaryenAtomicNotify(module: BinaryenModuleRef, ptr: BinaryenExpressionRef, notifyCount: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenSIMDExtract(module: BinaryenModuleRef, op: BinaryenSIMDOp, vec: BinaryenExpressionRef, idx: u8): BinaryenExpressionRef; +declare function _BinaryenSIMDReplace(module: BinaryenModuleRef, op: BinaryenSIMDOp, vec: BinaryenExpressionRef, idx: u8, value: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSIMDShuffle(module: BinaryenModuleRef, left: BinaryenExpressionRef, right: BinaryenExpressionRef, mask: v128ptr): BinaryenExpressionRef; +declare function _BinaryenSIMDBitselect(module: BinaryenModuleRef, left: BinaryenExpressionRef, right: BinaryenExpressionRef, cond: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSIMDShift(module: BinaryenModuleRef, op: BinaryenSIMDOp, vec: BinaryenExpressionRef, shift: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenMemoryInit(module: BinaryenModuleRef, segment: u32, dest: BinaryenExpressionRef, offset: BinaryenExpressionRef, size: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenDataDrop(module: BinaryenModuleRef, segment: u32): BinaryenExpressionRef; +declare function _BinaryenMemoryCopy(module: BinaryenModuleRef, dest: BinaryenExpressionRef, source: BinaryenExpressionRef, size: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenMemoryFill(module: BinaryenModuleRef, dest: BinaryenExpressionRef, value: BinaryenExpressionRef, size: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenExpressionGetId(expr: BinaryenExpressionRef): BinaryenExpressionId; +declare function _BinaryenExpressionGetType(expr: BinaryenExpressionRef): BinaryenType; +declare function _BinaryenExpressionPrint(expr: BinaryenExpressionRef): void; + +declare function _BinaryenBlockGetName(expr: BinaryenExpressionRef): usize; +declare function _BinaryenBlockGetNumChildren(expr: BinaryenExpressionRef): BinaryenIndex; +declare function _BinaryenBlockGetChild(expr: BinaryenExpressionRef, index: BinaryenIndex): BinaryenExpressionRef; + +declare function _BinaryenIfGetCondition(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenIfGetIfTrue(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenIfGetIfFalse(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenLoopGetName(expr: BinaryenExpressionRef): usize; +declare function _BinaryenLoopGetBody(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenBreakGetName(expr: BinaryenExpressionRef): usize; +declare function _BinaryenBreakGetCondition(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenBreakGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenSwitchGetNumNames(expr: BinaryenExpressionRef): BinaryenIndex; +declare function _BinaryenSwitchGetName(expr: BinaryenExpressionRef, index: BinaryenIndex): usize; +declare function _BinaryenSwitchGetDefaultName(expr: BinaryenExpressionRef): usize; +declare function _BinaryenSwitchGetCondition(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSwitchGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenCallGetTarget(expr: BinaryenExpressionRef): usize; +declare function _BinaryenCallGetNumOperands(expr: BinaryenExpressionRef): BinaryenIndex; +declare function _BinaryenCallGetOperand(expr: BinaryenExpressionRef, index: BinaryenIndex): BinaryenExpressionRef; + +declare function _BinaryenCallIndirectGetTarget(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenCallIndirectGetNumOperands(expr: BinaryenExpressionRef): BinaryenIndex; +declare function _BinaryenCallIndirectGetOperand(expr: BinaryenExpressionRef, index: BinaryenIndex): BinaryenExpressionRef; + +declare function _BinaryenLocalGetGetIndex(expr: BinaryenExpressionRef): BinaryenIndex; + +declare function _BinaryenLocalSetIsTee(expr: BinaryenExpressionRef): bool; +declare function _BinaryenLocalSetGetIndex(expr: BinaryenExpressionRef): BinaryenIndex; +declare function _BinaryenLocalSetGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenGlobalGetGetName(expr: BinaryenExpressionRef): usize; + +declare function _BinaryenGlobalSetGetName(expr: BinaryenExpressionRef): usize; +declare function _BinaryenGlobalSetGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenHostGetOp(expr: BinaryenExpressionRef): BinaryenOp; +declare function _BinaryenHostGetNameOperand(expr: BinaryenExpressionRef): usize; +declare function _BinaryenHostGetNumOperands(expr: BinaryenExpressionRef): BinaryenIndex; +declare function _BinaryenHostGetOperand(expr: BinaryenExpressionRef, index: BinaryenIndex): BinaryenExpressionRef; + +declare function _BinaryenLoadIsAtomic(expr: BinaryenExpressionRef): bool; +declare function _BinaryenLoadIsSigned(expr: BinaryenExpressionRef): bool; +declare function _BinaryenLoadGetBytes(expr: BinaryenExpressionRef): u32; +declare function _BinaryenLoadGetOffset(expr: BinaryenExpressionRef): u32; +declare function _BinaryenLoadGetAlign(expr: BinaryenExpressionRef): u32; +declare function _BinaryenLoadGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenStoreIsAtomic(expr: BinaryenExpressionRef): bool; +declare function _BinaryenStoreGetBytes(expr: BinaryenExpressionRef): u32; +declare function _BinaryenStoreGetOffset(expr: BinaryenExpressionRef): u32; +declare function _BinaryenStoreGetAlign(expr: BinaryenExpressionRef): u32; +declare function _BinaryenStoreGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenStoreGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenConstGetValueI32(expr: BinaryenExpressionRef): i32; +declare function _BinaryenConstGetValueI64Low(expr: BinaryenExpressionRef): i32; +declare function _BinaryenConstGetValueI64High(expr: BinaryenExpressionRef): i32; +declare function _BinaryenConstGetValueF32(expr: BinaryenExpressionRef): f32; +declare function _BinaryenConstGetValueF64(expr: BinaryenExpressionRef): f64; + +declare function _BinaryenUnaryGetOp(expr: BinaryenExpressionRef): BinaryenOp; +declare function _BinaryenUnaryGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenBinaryGetOp(expr: BinaryenExpressionRef): BinaryenOp; +declare function _BinaryenBinaryGetLeft(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenBinaryGetRight(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenSelectGetIfTrue(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSelectGetIfFalse(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSelectGetCondition(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenDropGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenReturnGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenAtomicRMWGetOp(expr: BinaryenExpressionRef): BinaryenOp; +declare function _BinaryenAtomicRMWGetBytes(expr: BinaryenExpressionRef): u32; +declare function _BinaryenAtomicRMWGetOffset(expr: BinaryenExpressionRef): u32; +declare function _BinaryenAtomicRMWGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenAtomicRMWGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenAtomicCmpxchgGetBytes(expr: BinaryenExpressionRef): u32; +declare function _BinaryenAtomicCmpxchgGetOffset(expr: BinaryenExpressionRef): u32; +declare function _BinaryenAtomicCmpxchgGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenAtomicCmpxchgGetExpected(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenAtomicCmpxchgGetReplacement(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenAtomicWaitGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenAtomicWaitGetExpected(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenAtomicWaitGetTimeout(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenAtomicWaitGetExpectedType(expr: BinaryenExpressionRef): BinaryenType; + +declare function _BinaryenAtomicNotifyGetPtr(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenAtomicNotifyGetNotifyCount(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenSIMDExtractGetOp(expr: BinaryenExpressionRef): BinaryenSIMDOp; +declare function _BinaryenSIMDExtractGetVec(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSIMDExtractGetIdx(expr: BinaryenExpressionRef): u8; + +declare function _BinaryenSIMDReplaceGetOp(expr: BinaryenExpressionRef): BinaryenSIMDOp; +declare function _BinaryenSIMDReplaceGetVec(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSIMDReplaceGetIdx(expr: BinaryenExpressionRef): u8; +declare function _BinaryenSIMDReplaceGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenSIMDShuffleGetLeft(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSIMDShuffleGetRight(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSIMDShuffleGetMask(expr: BinaryenExpressionRef, out: v128ptr): void; + +declare function _BinaryenSIMDBitselectGetLeft(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSIMDBitselectGetRight(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSIMDBitselectGetCond(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenSIMDShiftGetOp(expr: BinaryenExpressionRef): BinaryenSIMDOp; +declare function _BinaryenSIMDShiftGetVec(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenSIMDShiftGetShift(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenMemoryInitGetSegment(expr: BinaryenExpressionRef): u32; +declare function _BinaryenMemoryInitGetDest(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenMemoryInitGetOffset(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenMemoryInitGetSize(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenDataDropGetSegment(expr: BinaryenExpressionRef): u32; + +declare function _BinaryenMemoryCopyGetDest(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenMemoryCopyGetSource(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenMemoryCopyGetSize(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare function _BinaryenMemoryFillGetDest(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenMemoryFillGetValue(expr: BinaryenExpressionRef): BinaryenExpressionRef; +declare function _BinaryenMemoryFillGetSize(expr: BinaryenExpressionRef): BinaryenExpressionRef; + +declare type BinaryenFunctionTypeRef = usize; + +declare function _BinaryenAddFunctionType(module: BinaryenModuleRef, name: usize, result: BinaryenType, paramTypes: usize, numParams: BinaryenIndex): BinaryenFunctionTypeRef; +declare function _BinaryenGetFunctionTypeBySignature(module: BinaryenModuleRef, result: BinaryenType, paramTypes: usize, numParams: BinaryenIndex): BinaryenFunctionTypeRef; +declare function _BinaryenRemoveFunctionType(module: BinaryenModuleRef, name: usize): void; + +declare function _BinaryenFunctionTypeGetName(ftype: BinaryenFunctionTypeRef): usize; +declare function _BinaryenFunctionTypeGetNumParams(ftype: BinaryenFunctionTypeRef): BinaryenIndex; +declare function _BinaryenFunctionTypeGetParam(ftype: BinaryenFunctionTypeRef, index: BinaryenIndex): BinaryenType; +declare function _BinaryenFunctionTypeGetResult(ftype: BinaryenFunctionTypeRef): BinaryenType; + +declare type BinaryenFunctionRef = usize; + +declare function _BinaryenAddFunction(module: BinaryenModuleRef, name: usize, type: BinaryenFunctionTypeRef, varTypes: usize, numVarTypes: BinaryenIndex, body: BinaryenExpressionRef): BinaryenFunctionRef; +declare function _BinaryenGetFunction(module: BinaryenModuleRef, name: usize): BinaryenFunctionRef; +declare function _BinaryenRemoveFunction(module: BinaryenModuleRef, name: usize): void; + +declare function _BinaryenFunctionGetName(func: BinaryenFunctionRef): usize; +declare function _BinaryenFunctionGetType(func: BinaryenFunctionRef): BinaryenFunctionTypeRef; +declare function _BinaryenFunctionGetNumParams(func: BinaryenFunctionRef): BinaryenIndex; +declare function _BinaryenFunctionGetParam(func: BinaryenFunctionRef, index: BinaryenIndex): BinaryenType; +declare function _BinaryenFunctionGetResult(func: BinaryenFunctionRef): BinaryenType; +declare function _BinaryenFunctionGetNumVars(func: BinaryenFunctionRef): BinaryenIndex; +declare function _BinaryenFunctionGetVar(func: BinaryenFunctionRef, index: BinaryenIndex): BinaryenType; +declare function _BinaryenFunctionGetBody(func: BinaryenFunctionRef): BinaryenExpressionRef; +declare function _BinaryenFunctionOptimize(func: BinaryenFunctionRef, module: BinaryenModuleRef): void; +declare function _BinaryenFunctionRunPasses(func: BinaryenFunctionRef, module: BinaryenModuleRef, passes: usize, numPasses: BinaryenIndex): void; +declare function _BinaryenFunctionSetDebugLocation(func: BinaryenFunctionRef, expr: BinaryenExpressionRef, fileIndex: BinaryenIndex, lineNumber: BinaryenIndex, columnNumber: BinaryenIndex): void; + +declare type BinaryenImportRef = usize; + +declare function _BinaryenAddFunctionImport(module: BinaryenModuleRef, internalName: usize, externalModuleName: usize, externalBaseName: usize, functionType: BinaryenFunctionTypeRef): BinaryenImportRef; +declare function _BinaryenAddTableImport(module: BinaryenModuleRef, internalName: usize, externalModuleName: usize, externalBaseName: usize): BinaryenImportRef; +declare function _BinaryenAddMemoryImport(module: BinaryenModuleRef, internalName: usize, externalModuleName: usize, externalBaseName: usize, shared:bool): BinaryenImportRef; +declare function _BinaryenAddGlobalImport(module: BinaryenModuleRef, internalName: usize, externalModuleName: usize, externalBaseName: usize, globalType: BinaryenType): BinaryenImportRef; + +declare type BinaryenExportRef = usize; + +declare function _BinaryenAddFunctionExport(module: BinaryenModuleRef, internalName: usize, externalName: usize): BinaryenExportRef; +declare function _BinaryenAddTableExport(module: BinaryenModuleRef, internalName: usize, externalName: usize): BinaryenExportRef; +declare function _BinaryenAddMemoryExport(module: BinaryenModuleRef, internalName: usize, externalName: usize): BinaryenExportRef; +declare function _BinaryenAddGlobalExport(module: BinaryenModuleRef, internalName: usize, externalName: usize): BinaryenExportRef; +declare function _BinaryenRemoveExport(module: BinaryenModuleRef, externalName: usize): void; + +declare type BinaryenGlobalRef = usize; + +declare function _BinaryenAddGlobal(module: BinaryenModuleRef, name: usize, type: BinaryenType, mutable: i8, init: BinaryenExpressionRef): BinaryenGlobalRef; +declare function _BinaryenRemoveGlobal(module: BinaryenModuleRef, name: usize): void; + +declare function _BinaryenSetFunctionTable(module: BinaryenModuleRef, initial: BinaryenIndex, maximum: BinaryenIndex, funcs: usize, numFuncs: BinaryenIndex): void; + +declare function _BinaryenSetMemory(module: BinaryenModuleRef, initial: BinaryenIndex, maximum: BinaryenIndex, exportName: usize, segments: usize, segmentPassive: usize, segmentOffsets: usize, segmentSizes: usize, numSegments: BinaryenIndex, shared: bool): void; + +declare function _BinaryenSetStart(module: BinaryenModuleRef, start: BinaryenFunctionRef): void; + +declare function _BinaryenModuleParse(text: usize): BinaryenModuleRef; +declare function _BinaryenModulePrint(module: BinaryenModuleRef): void; +declare function _BinaryenModulePrintAsmjs(module: BinaryenModuleRef): void; +declare function _BinaryenModuleValidate(module: BinaryenModuleRef): i32; +declare function _BinaryenModuleOptimize(module: BinaryenModuleRef): void; +declare function _BinaryenModuleRunPasses(module: BinaryenModuleRef, passes: usize, numPasses: BinaryenIndex): void; +declare function _BinaryenModuleAutoDrop(module: BinaryenModuleRef): void; +declare function _BinaryenModuleAllocateAndWrite(out: usize, module: BinaryenModuleRef, sourceMapUrl: usize): void; +declare function _BinaryenModuleRead(input: usize, inputSize: usize): BinaryenModuleRef; +declare function _BinaryenModuleInterpret(module: BinaryenModuleRef): void; +declare function _BinaryenModuleAddDebugInfoFileName(module: BinaryenModuleRef, filename: usize): BinaryenIndex; +declare function _BinaryenModuleGetDebugInfoFileName(module: BinaryenModuleRef, index: BinaryenIndex): usize; +declare function _BinaryenModuleGetFeatures(module: BinaryenModuleRef): BinaryenFeatureFlags; +declare function _BinaryenModuleSetFeatures(module: BinaryenModuleRef, featureFlags: BinaryenFeatureFlags): void; + +declare type BinaryenRelooperRef = usize; +declare type BinaryenRelooperBlockRef = usize; + +declare function _RelooperCreate(module: BinaryenModuleRef): BinaryenRelooperRef; +declare function _RelooperAddBlock(relooper: BinaryenRelooperRef, code: BinaryenExpressionRef): BinaryenRelooperBlockRef; +declare function _RelooperAddBranch(from: BinaryenRelooperBlockRef, to: BinaryenRelooperBlockRef, condition: BinaryenExpressionRef, code: BinaryenExpressionRef): void; +declare function _RelooperAddBlockWithSwitch(relooper: BinaryenRelooperRef, code: BinaryenExpressionRef, condition: BinaryenExpressionRef): BinaryenRelooperBlockRef; +declare function _RelooperAddBranchForSwitch(from: BinaryenRelooperBlockRef, to: BinaryenRelooperBlockRef, indexes: usize, numIndexes: BinaryenIndex, code: BinaryenExpressionRef): void; +declare function _RelooperRenderAndDispose(relooper: BinaryenRelooperRef, entry: BinaryenRelooperBlockRef, labelHelper: BinaryenIndex): BinaryenExpressionRef; + +declare function _BinaryenGetOptimizeLevel(): i32; +declare function _BinaryenSetOptimizeLevel(level: i32): void; +declare function _BinaryenGetShrinkLevel(): i32; +declare function _BinaryenSetShrinkLevel(level: i32): void; +declare function _BinaryenGetDebugInfo(): bool; +declare function _BinaryenSetDebugInfo(on: bool): void; + +declare function _BinaryenSetAPITracing(on: i32): void; +/** @module glue/js *//***/ + + +declare namespace binaryen { + class Module { + constructor(); + emitStackIR(optimize?: boolean): string; + emitAsmjs(): string; + } + function wrapModule(ptr: number): Module; +} +/** @module glue/js *//***/ + +declare function f32_as_i32(value: f32): i32; +declare function i32_as_f32(value: i32): f32; +declare function f64_as_i64(value: f64): I64; +declare function i64_as_f64(value: I64): f64; +/** @module glue/js *//***/ + +declare type I64 = { __Long__: true }; // opaque + +declare const i64_zero: I64; +declare const i64_one: I64; + +declare function i64_new(lo: i32, hi?: i32): I64; +declare function i64_low(value: I64): i32; +declare function i64_high(value: I64): i32; + +declare function i64_add(left: I64, right: I64): I64; +declare function i64_sub(left: I64, right: I64): I64; +declare function i64_mul(left: I64, right: I64): I64; +declare function i64_div(left: I64, right: I64): I64; +declare function i64_div_u(left: I64, right: I64): I64; +declare function i64_rem(left: I64, right: I64): I64; +declare function i64_rem_u(left: I64, right: I64): I64; +declare function i64_and(left: I64, right: I64): I64; +declare function i64_or(left: I64, right: I64): I64; +declare function i64_xor(left: I64, right: I64): I64; +declare function i64_shl(left: I64, right: I64): I64; +declare function i64_shr(left: I64, right: I64): I64; +declare function i64_shr_u(left: I64, right: I64): I64; +declare function i64_not(value: I64): I64; + +declare function i64_eq(left: I64, right: I64): bool; +declare function i64_ne(left: I64, right: I64): bool; + +declare function i64_align(value: I64, alignment: i32): I64; + +declare function i64_is_i8(value: I64): bool; +declare function i64_is_i16(value: I64): bool; +declare function i64_is_i32(value: I64): bool; +declare function i64_is_u8(value: I64): bool; +declare function i64_is_u16(value: I64): bool; +declare function i64_is_u32(value: I64): bool; +declare function i64_is_bool(value: I64): bool; +declare function i64_is_f32(value: I64): bool; +declare function i64_is_f64(value: I64): bool; + +declare function i64_to_f32(value: I64): f64; +declare function i64_to_f64(value: I64): f64; +declare function i64_to_string(value: I64, unsigned?: bool): string; diff --git a/dist/assemblyscript.js b/dist/assemblyscript.js index 42dc7527e7..5dd36f8984 100644 --- a/dist/assemblyscript.js +++ b/dist/assemblyscript.js @@ -1,2 +1,2 @@ -!function(e,r){"object"==typeof exports&&"object"==typeof module?module.exports=r(require("binaryen")):"function"==typeof define&&define.amd?define(["binaryen"],r):"object"==typeof exports?exports.assemblyscript=r(require("binaryen")):e.assemblyscript=r(e.binaryen)}("undefined"!=typeof self?self:this,function(e){return function(e){var r={};function t(n){if(r[n])return r[n].exports;var i=r[n]={i:n,l:!1,exports:{}};return e[n].call(i.exports,i,i.exports,t),i.l=!0,i.exports}return t.m=e,t.c=r,t.d=function(e,r,n){t.o(e,r)||Object.defineProperty(e,r,{enumerable:!0,get:n})},t.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},t.t=function(e,r){if(1&r&&(e=t(e)),8&r)return e;if(4&r&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(t.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&r&&"string"!=typeof e)for(var i in e)t.d(n,i,function(r){return e[r]}.bind(null,i));return n},t.n=function(e){var r=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(r,"a",r),r},t.o=function(e,r){return Object.prototype.hasOwnProperty.call(e,r)},t.p="",t(t.s=17)}([function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),function(e){e[e.NONE=0]="NONE",e[e.IMPORT=1]="IMPORT",e[e.EXPORT=2]="EXPORT",e[e.DECLARE=4]="DECLARE",e[e.CONST=8]="CONST",e[e.LET=16]="LET",e[e.STATIC=32]="STATIC",e[e.READONLY=64]="READONLY",e[e.ABSTRACT=128]="ABSTRACT",e[e.PUBLIC=256]="PUBLIC",e[e.PRIVATE=512]="PRIVATE",e[e.PROTECTED=1024]="PROTECTED",e[e.GET=2048]="GET",e[e.SET=4096]="SET",e[e.DEFINITE_ASSIGNMENT=8192]="DEFINITE_ASSIGNMENT",e[e.AMBIENT=16384]="AMBIENT",e[e.GENERIC=32768]="GENERIC",e[e.GENERIC_CONTEXT=65536]="GENERIC_CONTEXT",e[e.INSTANCE=131072]="INSTANCE",e[e.CONSTRUCTOR=262144]="CONSTRUCTOR",e[e.MODULE_EXPORT=524288]="MODULE_EXPORT",e[e.MODULE_IMPORT=1048576]="MODULE_IMPORT",e[e.RESOLVED=2097152]="RESOLVED",e[e.COMPILED=4194304]="COMPILED",e[e.INLINED=8388608]="INLINED",e[e.SCOPED=16777216]="SCOPED",e[e.TRAMPOLINE=33554432]="TRAMPOLINE",e[e.VIRTUAL=67108864]="VIRTUAL",e[e.MAIN=134217728]="MAIN",e[e.QUOTED=268435456]="QUOTED"}(r.CommonFlags||(r.CommonFlags={})),r.PATH_DELIMITER="/",r.PARENT_SUBST="..",r.GETTER_PREFIX="get:",r.SETTER_PREFIX="set:",r.INSTANCE_DELIMITER="#",r.STATIC_DELIMITER=".",r.INNER_DELIMITER="~",r.LIBRARY_SUBST="~lib",r.LIBRARY_PREFIX=r.LIBRARY_SUBST+r.PATH_DELIMITER,r.INDEX_SUFFIX=r.PATH_DELIMITER+"index",function(e){e.EMPTY="",e.i8="i8",e.i16="i16",e.i32="i32",e.i64="i64",e.isize="isize",e.u8="u8",e.u16="u16",e.u32="u32",e.u64="u64",e.usize="usize",e.bool="bool",e.f32="f32",e.f64="f64",e.v128="v128",e.i8x16="i8x16",e.u8x16="u8x16",e.i16x8="i16x8",e.u16x8="u16x8",e.i32x4="i32x4",e.u32x4="u32x4",e.i64x2="i64x2",e.u64x2="u64x2",e.f32x4="f32x4",e.f64x2="f64x2",e.void_="void",e.number="number",e.boolean="boolean",e.string="string",e.native="native",e.null_="null",e.true_="true",e.false_="false",e.this_="this",e.super_="super",e.constructor="constructor",e.ASC_TARGET="ASC_TARGET",e.ASC_NO_TREESHAKING="ASC_NO_TREESHAKING",e.ASC_NO_ASSERT="ASC_NO_ASSERT",e.ASC_MEMORY_BASE="ASC_MEMORY_BASE",e.ASC_OPTIMIZE_LEVEL="ASC_OPTIMIZE_LEVEL",e.ASC_SHRINK_LEVEL="ASC_SHRINK_LEVEL",e.ASC_FEATURE_MUTABLE_GLOBAL="ASC_FEATURE_MUTABLE_GLOBAL",e.ASC_FEATURE_SIGN_EXTENSION="ASC_FEATURE_SIGN_EXTENSION",e.ASC_FEATURE_BULK_MEMORY="ASC_FEATURE_BULK_MEMORY",e.ASC_FEATURE_SIMD="ASC_FEATURE_SIMD",e.ASC_FEATURE_THREADS="ASC_FEATURE_THREADS",e.I8="I8",e.I16="I16",e.I32="I32",e.I64="I64",e.Isize="Isize",e.U8="U8",e.U16="U16",e.U32="U32",e.U64="U64",e.Usize="Usize",e.Bool="Bool",e.F32="F32",e.F64="F64",e.V128="V128",e.String="String",e.Array="Array",e.FixedArray="FixedArray",e.Set="Set",e.Map="Map",e.ArrayBufferView="ArrayBufferView",e.ArrayBuffer="ArrayBuffer",e.Math="Math",e.Mathf="Mathf",e.Int8Array="Int8Array",e.Int16Array="Int16Array",e.Int32Array="Int32Array",e.Int64Array="Int64Array",e.Uint8Array="Uint8Array",e.Uint8ClampedArray="Uint8ClampedArray",e.Uint16Array="Uint16Array",e.Uint32Array="Uint32Array",e.Uint64Array="Uint64Array",e.Float32Array="Float32Array",e.Float64Array="Float64Array",e.abort="abort",e.pow="pow",e.mod="mod",e.alloc="__alloc",e.realloc="__realloc",e.free="__free",e.retain="__retain",e.release="__release",e.collect="__collect",e.typeinfo="__typeinfo",e.instanceof_="__instanceof",e.visit="__visit",e.allocArray="__allocArray"}(r.CommonSymbols||(r.CommonSymbols={}));var n=t(25);r.Feature=n.Feature;var i=t(26);r.Target=i.Target;var a=t(27);r.Typeinfo=a.Typeinfo,r.TypeinfoFlags=a.TypeinfoFlags},function(e,r,t){"use strict";function n(e){for(var t in e)r.hasOwnProperty(t)||(r[t]=e[t])}Object.defineProperty(r,"__esModule",{value:!0}),n(t(29)),n(t(30)),n(t(31)),n(t(32)),n(t(33)),n(t(34)),r.isPowerOf2=function(e){return 0!=e&&0==(e&e-1)}},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n,i=t(12),a=t(1),s=t(12);function o(e){switch(e){case n.INFO:return"INFO";case n.WARNING:return"WARNING";case n.ERROR:return"ERROR";default:return assert(!1),""}}function c(e){switch(e){case n.INFO:return r.COLOR_BLUE;case n.WARNING:return r.COLOR_YELLOW;case n.ERROR:return r.COLOR_RED;default:return assert(!1),""}}r.DiagnosticCode=s.DiagnosticCode,r.diagnosticCodeToString=s.diagnosticCodeToString,function(e){e[e.INFO=0]="INFO",e[e.WARNING=1]="WARNING",e[e.ERROR=2]="ERROR"}(n=r.DiagnosticCategory||(r.DiagnosticCategory={})),r.diagnosticCategoryToString=o,r.COLOR_BLUE="",r.COLOR_YELLOW="",r.COLOR_RED="",r.COLOR_RESET="",r.diagnosticCategoryToColor=c;var l=function(){function e(e,r,t){this.range=null,this.relatedRange=null,this.code=e,this.category=r,this.message=t}return e.create=function(r,t,n,a,s){void 0===n&&(n=null),void 0===a&&(a=null),void 0===s&&(s=null);var o=i.diagnosticCodeToString(r);return null!=n&&(o=o.replace("{0}",n)),null!=a&&(o=o.replace("{1}",a)),null!=s&&(o=o.replace("{2}",s)),new e(r,t,o)},e.createInfo=function(r,t,i){return void 0===t&&(t=null),void 0===i&&(i=null),e.create(r,n.INFO,t,i)},e.createWarning=function(r,t,i){return void 0===t&&(t=null),void 0===i&&(i=null),e.create(r,n.WARNING,t,i)},e.createError=function(r,t,i){return void 0===t&&(t=null),void 0===i&&(i=null),e.create(r,n.ERROR,t,i)},e.prototype.withRange=function(e){return this.range=e,this},e.prototype.withRelatedRange=function(e){return this.relatedRange=e,this},e.prototype.toString=function(){return this.range?o(this.category)+" "+this.code.toString(10)+': "'+this.message+'" in '+this.range.source.normalizedPath+":"+this.range.line.toString(10)+":"+this.range.column.toString(10):o(this.category)+" "+this.code.toString(10)+": "+this.message},e}();function u(e,t){void 0===t&&(t=!1);for(var n=e.source.text,i=n.length,s=e.start,o=e.end;s>0&&!a.isLineBreak(n.charCodeAt(s-1));)s--;for(;o=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},s=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0});var o,c=t(0),l=t(2),u=t(6),p=t(5),_=t(1),h=t(9),d=t(10),y=function(){return function(e,r,t,n,i){this.localFile=e,this.localIdentifier=r,this.foreignIdentifier=t,this.foreignPath=n,this.foreignPathAlt=i}}(),m=function(){return function(e,r,t,n){this.localIdentifier=e,this.foreignIdentifier=r,this.foreignPath=t,this.foreignPathAlt=n}}(),f=function(){return function(e,r,t){this.foreignPath=e,this.foreignPathAlt=r,this.pathLiteral=t}}();function T(e,r){switch(assert(r.length),e){case p.DecoratorKind.OPERATOR:case p.DecoratorKind.OPERATOR_BINARY:switch(r.charCodeAt(0)){case 91:if("[]"==r)return o.INDEXED_GET;if("[]="==r)return o.INDEXED_SET;break;case 123:if("{}"==r)return o.UNCHECKED_INDEXED_GET;if("{}="==r)return o.UNCHECKED_INDEXED_SET;break;case 43:if("+"==r)return o.ADD;break;case 45:if("-"==r)return o.SUB;break;case 42:if("*"==r)return o.MUL;if("**"==r)return o.POW;break;case 47:if("/"==r)return o.DIV;break;case 37:if("%"==r)return o.REM;break;case 38:if("&"==r)return o.BITWISE_AND;break;case 124:if("|"==r)return o.BITWISE_OR;break;case 94:if("^"==r)return o.BITWISE_XOR;break;case 61:if("=="==r)return o.EQ;break;case 33:if("!="==r)return o.NE;break;case 62:if(">"==r)return o.GT;if(">="==r)return o.GE;if(">>"==r)return o.BITWISE_SHR;if(">>>"==r)return o.BITWISE_SHR_U;break;case 60:if("<"==r)return o.LT;if("<="==r)return o.LE;if("<<"==r)return o.BITWISE_SHL}break;case p.DecoratorKind.OPERATOR_PREFIX:switch(r.charCodeAt(0)){case 43:if("+"==r)return o.PLUS;if("++"==r)return o.PREFIX_INC;break;case 45:if("-"==r)return o.MINUS;if("--"==r)return o.PREFIX_DEC;break;case 33:if("!"==r)return o.NOT;break;case 126:if("~"==r)return o.BITWISE_NOT}break;case p.DecoratorKind.OPERATOR_POSTFIX:switch(r.charCodeAt(0)){case 43:if("++"==r)return o.POSTFIX_INC;break;case 45:if("--"==r)return o.POSTFIX_DEC}}return o.INVALID}!function(e){e[e.INVALID=0]="INVALID",e[e.INDEXED_GET=1]="INDEXED_GET",e[e.INDEXED_SET=2]="INDEXED_SET",e[e.UNCHECKED_INDEXED_GET=3]="UNCHECKED_INDEXED_GET",e[e.UNCHECKED_INDEXED_SET=4]="UNCHECKED_INDEXED_SET",e[e.ADD=5]="ADD",e[e.SUB=6]="SUB",e[e.MUL=7]="MUL",e[e.DIV=8]="DIV",e[e.REM=9]="REM",e[e.POW=10]="POW",e[e.BITWISE_AND=11]="BITWISE_AND",e[e.BITWISE_OR=12]="BITWISE_OR",e[e.BITWISE_XOR=13]="BITWISE_XOR",e[e.BITWISE_SHL=14]="BITWISE_SHL",e[e.BITWISE_SHR=15]="BITWISE_SHR",e[e.BITWISE_SHR_U=16]="BITWISE_SHR_U",e[e.EQ=17]="EQ",e[e.NE=18]="NE",e[e.GT=19]="GT",e[e.GE=20]="GE",e[e.LT=21]="LT",e[e.LE=22]="LE",e[e.PLUS=23]="PLUS",e[e.MINUS=24]="MINUS",e[e.NOT=25]="NOT",e[e.BITWISE_NOT=26]="BITWISE_NOT",e[e.PREFIX_INC=27]="PREFIX_INC",e[e.PREFIX_DEC=28]="PREFIX_DEC",e[e.POSTFIX_INC=29]="POSTFIX_INC",e[e.POSTFIX_DEC=30]="POSTFIX_DEC"}(o=r.OperatorKind||(r.OperatorKind={}));var g,E,v=function(e){function r(r){void 0===r&&(r=null);var t=e.call(this,r)||this;t.sources=[],t.diagnosticsOffset=0,t.filesByName=new Map,t.elementsByName=new Map,t.elementsByDeclaration=new Map,t.instancesByName=new Map,t.typeClasses=new Map,t.managedClasses=new Map,t.nextClassId=0,t.nativeDummySignature=null;var n=new p.Source(c.LIBRARY_SUBST,"[native code]",p.SourceKind.LIBRARY);t.nativeSource=n;var i=new N(t,n);return t.nativeFile=i,t.filesByName.set(i.internalName,i),t.resolver=new h.Resolver(t),t}return i(r,e),r.prototype.writeRuntimeHeader=function(e,r,t,n){assert(n<1<<28),_.writeI32(n,e,r),_.writeI32(1,e,r+4),_.writeI32(t.id,e,r+8),_.writeI32(n,e,r+12)},Object.defineProperty(r.prototype,"runtimeHeaderSize",{get:function(){return 16},enumerable:!0,configurable:!0}),r.prototype.makeNativeVariableDeclaration=function(e,r){void 0===r&&(r=c.CommonFlags.NONE);var t=this.nativeSource.range;return p.Node.createVariableDeclaration(p.Node.createIdentifierExpression(e,t),null,null,null,r,t)},r.prototype.makeNativeTypeDeclaration=function(e,r){void 0===r&&(r=c.CommonFlags.NONE);var t=this.nativeSource.range,n=p.Node.createIdentifierExpression(e,t);return p.Node.createTypeDeclaration(n,null,p.Node.createOmittedType(t),null,r,t)},r.prototype.makeNativeFunctionDeclaration=function(e,r){void 0===r&&(r=c.CommonFlags.NONE);var t=this.nativeSource.range;return p.Node.createFunctionDeclaration(p.Node.createIdentifierExpression(e,t),null,this.nativeDummySignature||(this.nativeDummySignature=p.Node.createSignature([],p.Node.createType(p.Node.createSimpleTypeName(c.CommonSymbols.void_,t),null,!1,t),null,!1,t)),null,null,r,0,t)},r.prototype.makeNativeNamespaceDeclaration=function(e,r){void 0===r&&(r=c.CommonFlags.NONE);var t=this.nativeSource.range;return p.Node.createNamespaceDeclaration(p.Node.createIdentifierExpression(e,t),[],null,r,t)},r.prototype.makeNativeFunction=function(e,r,t,n,i){return void 0===t&&(t=this.nativeFile),void 0===n&&(n=c.CommonFlags.NONE),void 0===i&&(i=E.NONE),new P(e,new D(e,t,this.makeNativeFunctionDeclaration(e,n),i),r)},r.prototype.getElementByDeclaration=function(e){var r=this.elementsByDeclaration;return assert(r.has(e)),r.get(e)},r.prototype.initialize=function(e){var r,t,n,i,o,_,h,d,y,m,f,T;this.options=e,this.registerNativeType(c.CommonSymbols.i8,u.Type.i8),this.registerNativeType(c.CommonSymbols.i16,u.Type.i16),this.registerNativeType(c.CommonSymbols.i32,u.Type.i32),this.registerNativeType(c.CommonSymbols.i64,u.Type.i64),this.registerNativeType(c.CommonSymbols.isize,e.isizeType),this.registerNativeType(c.CommonSymbols.u8,u.Type.u8),this.registerNativeType(c.CommonSymbols.u16,u.Type.u16),this.registerNativeType(c.CommonSymbols.u32,u.Type.u32),this.registerNativeType(c.CommonSymbols.u64,u.Type.u64),this.registerNativeType(c.CommonSymbols.usize,e.usizeType),this.registerNativeType(c.CommonSymbols.bool,u.Type.bool),this.registerNativeType(c.CommonSymbols.f32,u.Type.f32),this.registerNativeType(c.CommonSymbols.f64,u.Type.f64),this.registerNativeType(c.CommonSymbols.void_,u.Type.void),this.registerNativeType(c.CommonSymbols.number,u.Type.f64),this.registerNativeType(c.CommonSymbols.boolean,u.Type.bool),this.nativeFile.add(c.CommonSymbols.native,new S(c.CommonSymbols.native,this.nativeFile,this.makeNativeTypeDeclaration(c.CommonSymbols.native,c.CommonFlags.EXPORT|c.CommonFlags.GENERIC),E.BUILTIN)),e.hasFeature(8)&&this.registerNativeType(c.CommonSymbols.v128,u.Type.v128),this.registerConstantInteger(c.CommonSymbols.ASC_TARGET,u.Type.i32,i64_new(e.isWasm64?c.Target.WASM64:c.Target.WASM32)),this.registerConstantInteger(c.CommonSymbols.ASC_NO_ASSERT,u.Type.bool,i64_new(e.noAssert?1:0,0)),this.registerConstantInteger(c.CommonSymbols.ASC_MEMORY_BASE,u.Type.i32,i64_new(e.memoryBase,0)),this.registerConstantInteger(c.CommonSymbols.ASC_OPTIMIZE_LEVEL,u.Type.i32,i64_new(e.optimizeLevelHint,0)),this.registerConstantInteger(c.CommonSymbols.ASC_SHRINK_LEVEL,u.Type.i32,i64_new(e.shrinkLevelHint,0)),this.registerConstantInteger(c.CommonSymbols.ASC_FEATURE_MUTABLE_GLOBAL,u.Type.bool,i64_new(e.hasFeature(2)?1:0,0)),this.registerConstantInteger(c.CommonSymbols.ASC_FEATURE_SIGN_EXTENSION,u.Type.bool,i64_new(e.hasFeature(1)?1:0,0)),this.registerConstantInteger(c.CommonSymbols.ASC_FEATURE_BULK_MEMORY,u.Type.bool,i64_new(e.hasFeature(4)?1:0,0)),this.registerConstantInteger(c.CommonSymbols.ASC_FEATURE_SIMD,u.Type.bool,i64_new(e.hasFeature(8)?1:0,0)),this.registerConstantInteger(c.CommonSymbols.ASC_FEATURE_THREADS,u.Type.bool,i64_new(e.hasFeature(16)?1:0,0));for(var v=new Array,b=new Map,I=new Map,A=new Array,O=new Array,C=0,k=this.sources.length;C=48&&ye<=57)this.registerConstantInteger(he,u.Type.i32,i64_new(parseInt(de,10)));else{var me=this.elementsByName;if(!(ve=me.get(de)))throw new Error("no such global element: "+de);if(me.has(he))throw new Error("duplicate global element: "+de);me.set(he,ve)}}}}catch(e){h={error:e}}finally{try{pe&&!pe.done&&(d=ue.return)&&d.call(ue)}finally{if(h)throw h.error}}this.arrayPrototype=this.require(c.CommonSymbols.Array,g.CLASS_PROTOTYPE),this.fixedArrayPrototype=this.require(c.CommonSymbols.FixedArray,g.CLASS_PROTOTYPE),this.setPrototype=this.require(c.CommonSymbols.Set,g.CLASS_PROTOTYPE),this.mapPrototype=this.require(c.CommonSymbols.Map,g.CLASS_PROTOTYPE),this.abortInstance=this.requireFunction(c.CommonSymbols.abort),this.allocInstance=this.requireFunction(c.CommonSymbols.alloc),this.reallocInstance=this.requireFunction(c.CommonSymbols.realloc),this.freeInstance=this.requireFunction(c.CommonSymbols.free),this.retainInstance=this.requireFunction(c.CommonSymbols.retain),this.releaseInstance=this.requireFunction(c.CommonSymbols.release),this.collectInstance=this.requireFunction(c.CommonSymbols.collect),this.typeinfoInstance=this.requireFunction(c.CommonSymbols.typeinfo),this.instanceofInstance=this.requireFunction(c.CommonSymbols.instanceof_),this.visitInstance=this.requireFunction(c.CommonSymbols.visit),this.allocArrayInstance=this.requireFunction(c.CommonSymbols.allocArray);try{for(var fe=a(this.filesByName.values()),Te=fe.next();!Te.done;Te=fe.next()){j=(R=Te.value).exports;if(R.source.isEntry&&j)try{for(var ge=(f=void 0,a(j.values())),Ee=ge.next();!Ee.done;Ee=ge.next()){var ve=Ee.value;this.markModuleExport(ve)}}catch(e){f={error:e}}finally{try{Ee&&!Ee.done&&(T=ge.return)&&T.call(ge)}finally{if(f)throw f.error}}}}catch(e){y={error:e}}finally{try{Te&&!Te.done&&(m=fe.return)&&m.call(fe)}finally{if(y)throw y.error}}},r.prototype.require=function(e,r){var t=this.lookupGlobal(e);if(!t)throw new Error("missing "+e);if(t.kind!=r)throw new Error("unexpected "+e);return t},r.prototype.requireClass=function(e){var r=this.require(e,g.CLASS_PROTOTYPE),t=this.resolver.resolveClass(r,null);if(!t)throw new Error("invalid "+e);return t},r.prototype.requireFunction=function(e){var r=this.require(e,g.FUNCTION_PROTOTYPE),t=this.resolver.resolveFunction(r,null);if(!t)throw new Error("invalid "+e);return t},r.prototype.markModuleExport=function(e){var r,t,n,i;switch(e.set(c.CommonFlags.MODULE_EXPORT),e.kind){case g.CLASS_PROTOTYPE:var s=e.instanceMembers;if(s)try{for(var o=a(s.values()),l=o.next();!l.done;l=o.next()){var u=l.value;this.markModuleExport(u)}}catch(e){r={error:e}}finally{try{l&&!l.done&&(t=o.return)&&t.call(o)}finally{if(r)throw r.error}}break;case g.PROPERTY_PROTOTYPE:var p=e.getterPrototype;p&&this.markModuleExport(p);var _=e.setterPrototype;_&&this.markModuleExport(_);break;case g.PROPERTY:case g.FUNCTION:case g.FIELD:case g.CLASS:assert(!1)}var h=e.members;if(h)try{for(var d=a(h.values()),y=d.next();!y.done;y=d.next()){u=y.value;this.markModuleExport(u)}}catch(e){n={error:e}}finally{try{y&&!y.done&&(i=d.return)&&i.call(d)}finally{if(n)throw n.error}}},r.prototype.registerNativeType=function(e,r){var t=new S(e,this.nativeFile,this.makeNativeTypeDeclaration(e,c.CommonFlags.EXPORT),E.BUILTIN);t.setType(r),this.nativeFile.add(e,t)},r.prototype.registerNativeTypeClass=function(e,r){assert(!this.typeClasses.has(e));var t=this.lookupGlobal(r);if(t){assert(t.kind==g.CLASS_PROTOTYPE);var n=this.resolver.resolveClass(t,null);n&&this.typeClasses.set(e,n)}},r.prototype.registerConstantInteger=function(e,r,t){assert(r.is(4));var n=new R(e,this.nativeFile,E.NONE,this.makeNativeVariableDeclaration(e,c.CommonFlags.CONST|c.CommonFlags.EXPORT));n.setConstantIntegerValue(t,r),this.nativeFile.add(e,n)},r.prototype.registerConstantFloat=function(e,r,t){assert(r.is(8));var n=new R(e,this.nativeFile,E.NONE,this.makeNativeVariableDeclaration(e,c.CommonFlags.CONST|c.CommonFlags.EXPORT));n.setConstantFloatValue(t,r),this.nativeFile.add(e,n)},r.prototype.ensureGlobal=function(e,r){var t=this.elementsByName;if(t.has(e)&&t.get(e)!==r){var n=q(t.get(e),r);if(!n)return this.error(l.DiagnosticCode.Duplicate_identifier_0,r.identifierNode.range,e),r;r=n}return t.set(e,r),r},r.prototype.lookupGlobal=function(e){var r=this.elementsByName;return r.has(e)?r.get(e):null},r.prototype.requireGlobal=function(e){var r=this.elementsByName;if(r.has(e))return r.get(e);throw new Error("missing global")},r.prototype.lookupForeignFile=function(e,r){var t=this.filesByName;return t.has(e)?t.get(e):t.has(r)?t.get(r):null},r.prototype.lookupForeign=function(e,r,t,n){for(;;){var i=this.lookupForeignFile(r,t);if(!i)return null;var a=i.lookupExport(e);if(a)return a;if(n.has(i)){var s=n.get(i);if(s.has(e)){var o=s.get(e);if(o.foreignPath){e=o.localIdentifier.text,r=o.foreignPath,t=assert(o.foreignPathAlt);continue}if(a=i.lookupInSelf(o.localIdentifier.text))return a}}break}return null},r.prototype.checkDecorators=function(e,r){var t=E.NONE;if(e)for(var n=0,i=e.length;n=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}};Object.defineProperty(r,"__esModule",{value:!0});var i,a,s=t(0);!function(e){e[e.None=_BinaryenTypeNone()]="None",e[e.I32=_BinaryenTypeInt32()]="I32",e[e.I64=_BinaryenTypeInt64()]="I64",e[e.F32=_BinaryenTypeFloat32()]="F32",e[e.F64=_BinaryenTypeFloat64()]="F64",e[e.V128=_BinaryenTypeVec128()]="V128",e[e.Unreachable=_BinaryenTypeUnreachable()]="Unreachable",e[e.Auto=_BinaryenTypeAuto()]="Auto"}(i=r.NativeType||(r.NativeType={})),function(e){e[e.Atomics=_BinaryenFeatureAtomics()]="Atomics",e[e.MutableGloabls=_BinaryenFeatureMutableGlobals()]="MutableGloabls",e[e.NontrappingFPToInt=_BinaryenFeatureNontrappingFPToInt()]="NontrappingFPToInt",e[e.SIMD128=_BinaryenFeatureSIMD128()]="SIMD128",e[e.BulkMemory=_BinaryenFeatureBulkMemory()]="BulkMemory",e[e.SignExt=_BinaryenFeatureSignExt()]="SignExt",e[e.ExceptionHandling=_BinaryenFeatureExceptionHandling()]="ExceptionHandling"}(r.FeatureFlags||(r.FeatureFlags={})),function(e){e[e.Invalid=_BinaryenInvalidId()]="Invalid",e[e.Block=_BinaryenBlockId()]="Block",e[e.If=_BinaryenIfId()]="If",e[e.Loop=_BinaryenLoopId()]="Loop",e[e.Break=_BinaryenBreakId()]="Break",e[e.Switch=_BinaryenSwitchId()]="Switch",e[e.Call=_BinaryenCallId()]="Call",e[e.CallIndirect=_BinaryenCallIndirectId()]="CallIndirect",e[e.LocalGet=_BinaryenLocalGetId()]="LocalGet",e[e.LocalSet=_BinaryenLocalSetId()]="LocalSet",e[e.GlobalGet=_BinaryenGlobalGetId()]="GlobalGet",e[e.GlobalSet=_BinaryenGlobalSetId()]="GlobalSet",e[e.Load=_BinaryenLoadId()]="Load",e[e.Store=_BinaryenStoreId()]="Store",e[e.Const=_BinaryenConstId()]="Const",e[e.Unary=_BinaryenUnaryId()]="Unary",e[e.Binary=_BinaryenBinaryId()]="Binary",e[e.Select=_BinaryenSelectId()]="Select",e[e.Drop=_BinaryenDropId()]="Drop",e[e.Return=_BinaryenReturnId()]="Return",e[e.Host=_BinaryenHostId()]="Host",e[e.Nop=_BinaryenNopId()]="Nop",e[e.Unreachable=_BinaryenUnreachableId()]="Unreachable",e[e.AtomicCmpxchg=_BinaryenAtomicCmpxchgId()]="AtomicCmpxchg",e[e.AtomicRMW=_BinaryenAtomicRMWId()]="AtomicRMW",e[e.AtomicWait=_BinaryenAtomicWaitId()]="AtomicWait",e[e.AtomicNotify=_BinaryenAtomicNotifyId()]="AtomicNotify",e[e.SIMDExtract=_BinaryenSIMDExtractId()]="SIMDExtract",e[e.SIMDReplace=_BinaryenSIMDReplaceId()]="SIMDReplace",e[e.SIMDShuffle=_BinaryenSIMDShuffleId()]="SIMDShuffle",e[e.SIMDBitselect=_BinaryenSIMDBitselectId()]="SIMDBitselect",e[e.SIMDShift=_BinaryenSIMDShiftId()]="SIMDShift",e[e.MemoryInit=_BinaryenMemoryInitId()]="MemoryInit",e[e.DataDrop=_BinaryenDataDropId()]="DataDrop",e[e.MemoryCopy=_BinaryenMemoryCopyId()]="MemoryCopy",e[e.MemoryFill=_BinaryenMemoryFillId()]="MemoryFill"}(a=r.ExpressionId||(r.ExpressionId={})),function(e){e[e.ClzI32=_BinaryenClzInt32()]="ClzI32",e[e.CtzI32=_BinaryenCtzInt32()]="CtzI32",e[e.PopcntI32=_BinaryenPopcntInt32()]="PopcntI32",e[e.NegF32=_BinaryenNegFloat32()]="NegF32",e[e.AbsF32=_BinaryenAbsFloat32()]="AbsF32",e[e.CeilF32=_BinaryenCeilFloat32()]="CeilF32",e[e.FloorF32=_BinaryenFloorFloat32()]="FloorF32",e[e.TruncF32=_BinaryenTruncFloat32()]="TruncF32",e[e.NearestF32=_BinaryenNearestFloat32()]="NearestF32",e[e.SqrtF32=_BinaryenSqrtFloat32()]="SqrtF32",e[e.EqzI32=_BinaryenEqZInt32()]="EqzI32",e[e.ClzI64=_BinaryenClzInt64()]="ClzI64",e[e.CtzI64=_BinaryenCtzInt64()]="CtzI64",e[e.PopcntI64=_BinaryenPopcntInt64()]="PopcntI64",e[e.NegF64=_BinaryenNegFloat64()]="NegF64",e[e.AbsF64=_BinaryenAbsFloat64()]="AbsF64",e[e.CeilF64=_BinaryenCeilFloat64()]="CeilF64",e[e.FloorF64=_BinaryenFloorFloat64()]="FloorF64",e[e.TruncF64=_BinaryenTruncFloat64()]="TruncF64",e[e.NearestF64=_BinaryenNearestFloat64()]="NearestF64",e[e.SqrtF64=_BinaryenSqrtFloat64()]="SqrtF64",e[e.EqzI64=_BinaryenEqZInt64()]="EqzI64",e[e.ExtendI32=_BinaryenExtendSInt32()]="ExtendI32",e[e.ExtendU32=_BinaryenExtendUInt32()]="ExtendU32",e[e.WrapI64=_BinaryenWrapInt64()]="WrapI64",e[e.TruncF32ToI32=_BinaryenTruncSFloat32ToInt32()]="TruncF32ToI32",e[e.TruncF32ToI64=_BinaryenTruncSFloat32ToInt64()]="TruncF32ToI64",e[e.TruncF32ToU32=_BinaryenTruncUFloat32ToInt32()]="TruncF32ToU32",e[e.TruncF32ToU64=_BinaryenTruncUFloat32ToInt64()]="TruncF32ToU64",e[e.TruncF64ToI32=_BinaryenTruncSFloat64ToInt32()]="TruncF64ToI32",e[e.TruncF64ToI64=_BinaryenTruncSFloat64ToInt64()]="TruncF64ToI64",e[e.TruncF64ToU32=_BinaryenTruncUFloat64ToInt32()]="TruncF64ToU32",e[e.TruncF64ToU64=_BinaryenTruncUFloat64ToInt64()]="TruncF64ToU64",e[e.ReinterpretF32=_BinaryenReinterpretFloat32()]="ReinterpretF32",e[e.ReinterpretF64=_BinaryenReinterpretFloat64()]="ReinterpretF64",e[e.ConvertI32ToF32=_BinaryenConvertSInt32ToFloat32()]="ConvertI32ToF32",e[e.ConvertI32ToF64=_BinaryenConvertSInt32ToFloat64()]="ConvertI32ToF64",e[e.ConvertU32ToF32=_BinaryenConvertUInt32ToFloat32()]="ConvertU32ToF32",e[e.ConvertU32ToF64=_BinaryenConvertUInt32ToFloat64()]="ConvertU32ToF64",e[e.ConvertI64ToF32=_BinaryenConvertSInt64ToFloat32()]="ConvertI64ToF32",e[e.ConvertI64ToF64=_BinaryenConvertSInt64ToFloat64()]="ConvertI64ToF64",e[e.ConvertU64ToF32=_BinaryenConvertUInt64ToFloat32()]="ConvertU64ToF32",e[e.ConvertU64ToF64=_BinaryenConvertUInt64ToFloat64()]="ConvertU64ToF64",e[e.PromoteF32=_BinaryenPromoteFloat32()]="PromoteF32",e[e.DemoteF64=_BinaryenDemoteFloat64()]="DemoteF64",e[e.ReinterpretI32=_BinaryenReinterpretInt32()]="ReinterpretI32",e[e.ReinterpretI64=_BinaryenReinterpretInt64()]="ReinterpretI64",e[e.ExtendI8ToI32=_BinaryenExtendS8Int32()]="ExtendI8ToI32",e[e.ExtendI16ToI32=_BinaryenExtendS16Int32()]="ExtendI16ToI32",e[e.ExtendI8ToI64=_BinaryenExtendS8Int64()]="ExtendI8ToI64",e[e.ExtendI16ToI64=_BinaryenExtendS16Int64()]="ExtendI16ToI64",e[e.ExtendI32ToI64=_BinaryenExtendS32Int64()]="ExtendI32ToI64",e[e.SplatVecI8x16=_BinaryenSplatVecI8x16()]="SplatVecI8x16",e[e.SplatVecI16x8=_BinaryenSplatVecI16x8()]="SplatVecI16x8",e[e.SplatVecI32x4=_BinaryenSplatVecI32x4()]="SplatVecI32x4",e[e.SplatVecI64x2=_BinaryenSplatVecI64x2()]="SplatVecI64x2",e[e.SplatVecF32x4=_BinaryenSplatVecF32x4()]="SplatVecF32x4",e[e.SplatVecF64x2=_BinaryenSplatVecF64x2()]="SplatVecF64x2",e[e.NotVec128=_BinaryenNotVec128()]="NotVec128",e[e.NegVecI8x16=_BinaryenNegVecI8x16()]="NegVecI8x16",e[e.AnyTrueVecI8x16=_BinaryenAnyTrueVecI8x16()]="AnyTrueVecI8x16",e[e.AllTrueVecI8x16=_BinaryenAllTrueVecI8x16()]="AllTrueVecI8x16",e[e.NegVecI16x8=_BinaryenNegVecI16x8()]="NegVecI16x8",e[e.AnyTrueVecI16x8=_BinaryenAnyTrueVecI16x8()]="AnyTrueVecI16x8",e[e.AllTrueVecI16x8=_BinaryenAllTrueVecI16x8()]="AllTrueVecI16x8",e[e.NegVecI32x4=_BinaryenNegVecI32x4()]="NegVecI32x4",e[e.AnyTrueVecI32x4=_BinaryenAnyTrueVecI32x4()]="AnyTrueVecI32x4",e[e.AllTrueVecI32x4=_BinaryenAllTrueVecI32x4()]="AllTrueVecI32x4",e[e.NegVecI64x2=_BinaryenNegVecI64x2()]="NegVecI64x2",e[e.AnyTrueVecI64x2=_BinaryenAnyTrueVecI64x2()]="AnyTrueVecI64x2",e[e.AllTrueVecI64x2=_BinaryenAllTrueVecI64x2()]="AllTrueVecI64x2",e[e.AbsVecF32x4=_BinaryenAbsVecF32x4()]="AbsVecF32x4",e[e.NegVecF32x4=_BinaryenNegVecF32x4()]="NegVecF32x4",e[e.SqrtVecF32x4=_BinaryenSqrtVecF32x4()]="SqrtVecF32x4",e[e.AbsVecF64x2=_BinaryenAbsVecF64x2()]="AbsVecF64x2",e[e.NegVecF64x2=_BinaryenNegVecF64x2()]="NegVecF64x2",e[e.SqrtVecF64x2=_BinaryenSqrtVecF64x2()]="SqrtVecF64x2",e[e.TruncSatSVecF32x4ToVecI32x4=_BinaryenTruncSatSVecF32x4ToVecI32x4()]="TruncSatSVecF32x4ToVecI32x4",e[e.TruncSatUVecF32x4ToVecI32x4=_BinaryenTruncSatUVecF32x4ToVecI32x4()]="TruncSatUVecF32x4ToVecI32x4",e[e.TruncSatSVecF64x2ToVecI64x2=_BinaryenTruncSatSVecF64x2ToVecI64x2()]="TruncSatSVecF64x2ToVecI64x2",e[e.TruncSatUVecF64x2ToVecI64x2=_BinaryenTruncSatUVecF64x2ToVecI64x2()]="TruncSatUVecF64x2ToVecI64x2",e[e.ConvertSVecI32x4ToVecF32x4=_BinaryenConvertSVecI32x4ToVecF32x4()]="ConvertSVecI32x4ToVecF32x4",e[e.ConvertUVecI32x4ToVecF32x4=_BinaryenConvertUVecI32x4ToVecF32x4()]="ConvertUVecI32x4ToVecF32x4",e[e.ConvertSVecI64x2ToVecF64x2=_BinaryenConvertSVecI64x2ToVecF64x2()]="ConvertSVecI64x2ToVecF64x2",e[e.ConvertUVecI64x2ToVecF64x2=_BinaryenConvertUVecI64x2ToVecF64x2()]="ConvertUVecI64x2ToVecF64x2"}(r.UnaryOp||(r.UnaryOp={})),function(e){e[e.AddI32=_BinaryenAddInt32()]="AddI32",e[e.SubI32=_BinaryenSubInt32()]="SubI32",e[e.MulI32=_BinaryenMulInt32()]="MulI32",e[e.DivI32=_BinaryenDivSInt32()]="DivI32",e[e.DivU32=_BinaryenDivUInt32()]="DivU32",e[e.RemI32=_BinaryenRemSInt32()]="RemI32",e[e.RemU32=_BinaryenRemUInt32()]="RemU32",e[e.AndI32=_BinaryenAndInt32()]="AndI32",e[e.OrI32=_BinaryenOrInt32()]="OrI32",e[e.XorI32=_BinaryenXorInt32()]="XorI32",e[e.ShlI32=_BinaryenShlInt32()]="ShlI32",e[e.ShrU32=_BinaryenShrUInt32()]="ShrU32",e[e.ShrI32=_BinaryenShrSInt32()]="ShrI32",e[e.RotlI32=_BinaryenRotLInt32()]="RotlI32",e[e.RotrI32=_BinaryenRotRInt32()]="RotrI32",e[e.EqI32=_BinaryenEqInt32()]="EqI32",e[e.NeI32=_BinaryenNeInt32()]="NeI32",e[e.LtI32=_BinaryenLtSInt32()]="LtI32",e[e.LtU32=_BinaryenLtUInt32()]="LtU32",e[e.LeI32=_BinaryenLeSInt32()]="LeI32",e[e.LeU32=_BinaryenLeUInt32()]="LeU32",e[e.GtI32=_BinaryenGtSInt32()]="GtI32",e[e.GtU32=_BinaryenGtUInt32()]="GtU32",e[e.GeI32=_BinaryenGeSInt32()]="GeI32",e[e.GeU32=_BinaryenGeUInt32()]="GeU32",e[e.AddI64=_BinaryenAddInt64()]="AddI64",e[e.SubI64=_BinaryenSubInt64()]="SubI64",e[e.MulI64=_BinaryenMulInt64()]="MulI64",e[e.DivI64=_BinaryenDivSInt64()]="DivI64",e[e.DivU64=_BinaryenDivUInt64()]="DivU64",e[e.RemI64=_BinaryenRemSInt64()]="RemI64",e[e.RemU64=_BinaryenRemUInt64()]="RemU64",e[e.AndI64=_BinaryenAndInt64()]="AndI64",e[e.OrI64=_BinaryenOrInt64()]="OrI64",e[e.XorI64=_BinaryenXorInt64()]="XorI64",e[e.ShlI64=_BinaryenShlInt64()]="ShlI64",e[e.ShrU64=_BinaryenShrUInt64()]="ShrU64",e[e.ShrI64=_BinaryenShrSInt64()]="ShrI64",e[e.RotlI64=_BinaryenRotLInt64()]="RotlI64",e[e.RotrI64=_BinaryenRotRInt64()]="RotrI64",e[e.EqI64=_BinaryenEqInt64()]="EqI64",e[e.NeI64=_BinaryenNeInt64()]="NeI64",e[e.LtI64=_BinaryenLtSInt64()]="LtI64",e[e.LtU64=_BinaryenLtUInt64()]="LtU64",e[e.LeI64=_BinaryenLeSInt64()]="LeI64",e[e.LeU64=_BinaryenLeUInt64()]="LeU64",e[e.GtI64=_BinaryenGtSInt64()]="GtI64",e[e.GtU64=_BinaryenGtUInt64()]="GtU64",e[e.GeI64=_BinaryenGeSInt64()]="GeI64",e[e.GeU64=_BinaryenGeUInt64()]="GeU64",e[e.AddF32=_BinaryenAddFloat32()]="AddF32",e[e.SubF32=_BinaryenSubFloat32()]="SubF32",e[e.MulF32=_BinaryenMulFloat32()]="MulF32",e[e.DivF32=_BinaryenDivFloat32()]="DivF32",e[e.CopysignF32=_BinaryenCopySignFloat32()]="CopysignF32",e[e.MinF32=_BinaryenMinFloat32()]="MinF32",e[e.MaxF32=_BinaryenMaxFloat32()]="MaxF32",e[e.EqF32=_BinaryenEqFloat32()]="EqF32",e[e.NeF32=_BinaryenNeFloat32()]="NeF32",e[e.LtF32=_BinaryenLtFloat32()]="LtF32",e[e.LeF32=_BinaryenLeFloat32()]="LeF32",e[e.GtF32=_BinaryenGtFloat32()]="GtF32",e[e.GeF32=_BinaryenGeFloat32()]="GeF32",e[e.AddF64=_BinaryenAddFloat64()]="AddF64",e[e.SubF64=_BinaryenSubFloat64()]="SubF64",e[e.MulF64=_BinaryenMulFloat64()]="MulF64",e[e.DivF64=_BinaryenDivFloat64()]="DivF64",e[e.CopysignF64=_BinaryenCopySignFloat64()]="CopysignF64",e[e.MinF64=_BinaryenMinFloat64()]="MinF64",e[e.MaxF64=_BinaryenMaxFloat64()]="MaxF64",e[e.EqF64=_BinaryenEqFloat64()]="EqF64",e[e.NeF64=_BinaryenNeFloat64()]="NeF64",e[e.LtF64=_BinaryenLtFloat64()]="LtF64",e[e.LeF64=_BinaryenLeFloat64()]="LeF64",e[e.GtF64=_BinaryenGtFloat64()]="GtF64",e[e.GeF64=_BinaryenGeFloat64()]="GeF64",e[e.EqVecI8x16=_BinaryenEqVecI8x16()]="EqVecI8x16",e[e.NeVecI8x16=_BinaryenNeVecI8x16()]="NeVecI8x16",e[e.LtSVecI8x16=_BinaryenLtSVecI8x16()]="LtSVecI8x16",e[e.LtUVecI8x16=_BinaryenLtUVecI8x16()]="LtUVecI8x16",e[e.LeSVecI8x16=_BinaryenLeSVecI8x16()]="LeSVecI8x16",e[e.LeUVecI8x16=_BinaryenLeUVecI8x16()]="LeUVecI8x16",e[e.GtSVecI8x16=_BinaryenGtSVecI8x16()]="GtSVecI8x16",e[e.GtUVecI8x16=_BinaryenGtUVecI8x16()]="GtUVecI8x16",e[e.GeSVecI8x16=_BinaryenGeSVecI8x16()]="GeSVecI8x16",e[e.GeUVecI8x16=_BinaryenGeUVecI8x16()]="GeUVecI8x16",e[e.EqVecI16x8=_BinaryenEqVecI16x8()]="EqVecI16x8",e[e.NeVecI16x8=_BinaryenNeVecI16x8()]="NeVecI16x8",e[e.LtSVecI16x8=_BinaryenLtSVecI16x8()]="LtSVecI16x8",e[e.LtUVecI16x8=_BinaryenLtUVecI16x8()]="LtUVecI16x8",e[e.LeSVecI16x8=_BinaryenLeSVecI16x8()]="LeSVecI16x8",e[e.LeUVecI16x8=_BinaryenLeUVecI16x8()]="LeUVecI16x8",e[e.GtSVecI16x8=_BinaryenGtSVecI16x8()]="GtSVecI16x8",e[e.GtUVecI16x8=_BinaryenGtUVecI16x8()]="GtUVecI16x8",e[e.GeSVecI16x8=_BinaryenGeSVecI16x8()]="GeSVecI16x8",e[e.GeUVecI16x8=_BinaryenGeUVecI16x8()]="GeUVecI16x8",e[e.EqVecI32x4=_BinaryenEqVecI32x4()]="EqVecI32x4",e[e.NeVecI32x4=_BinaryenNeVecI32x4()]="NeVecI32x4",e[e.LtSVecI32x4=_BinaryenLtSVecI32x4()]="LtSVecI32x4",e[e.LtUVecI32x4=_BinaryenLtUVecI32x4()]="LtUVecI32x4",e[e.LeSVecI32x4=_BinaryenLeSVecI32x4()]="LeSVecI32x4",e[e.LeUVecI32x4=_BinaryenLeUVecI32x4()]="LeUVecI32x4",e[e.GtSVecI32x4=_BinaryenGtSVecI32x4()]="GtSVecI32x4",e[e.GtUVecI32x4=_BinaryenGtUVecI32x4()]="GtUVecI32x4",e[e.GeSVecI32x4=_BinaryenGeSVecI32x4()]="GeSVecI32x4",e[e.GeUVecI32x4=_BinaryenGeUVecI32x4()]="GeUVecI32x4",e[e.EqVecF32x4=_BinaryenEqVecF32x4()]="EqVecF32x4",e[e.NeVecF32x4=_BinaryenNeVecF32x4()]="NeVecF32x4",e[e.LtVecF32x4=_BinaryenLtVecF32x4()]="LtVecF32x4",e[e.LeVecF32x4=_BinaryenLeVecF32x4()]="LeVecF32x4",e[e.GtVecF32x4=_BinaryenGtVecF32x4()]="GtVecF32x4",e[e.GeVecF32x4=_BinaryenGeVecF32x4()]="GeVecF32x4",e[e.EqVecF64x2=_BinaryenEqVecF64x2()]="EqVecF64x2",e[e.NeVecF64x2=_BinaryenNeVecF64x2()]="NeVecF64x2",e[e.LtVecF64x2=_BinaryenLtVecF64x2()]="LtVecF64x2",e[e.LeVecF64x2=_BinaryenLeVecF64x2()]="LeVecF64x2",e[e.GtVecF64x2=_BinaryenGtVecF64x2()]="GtVecF64x2",e[e.GeVecF64x2=_BinaryenGeVecF64x2()]="GeVecF64x2",e[e.AndVec128=_BinaryenAndVec128()]="AndVec128",e[e.OrVec128=_BinaryenOrVec128()]="OrVec128",e[e.XorVec128=_BinaryenXorVec128()]="XorVec128",e[e.AddVecI8x16=_BinaryenAddVecI8x16()]="AddVecI8x16",e[e.AddSatSVecI8x16=_BinaryenAddSatSVecI8x16()]="AddSatSVecI8x16",e[e.AddSatUVecI8x16=_BinaryenAddSatUVecI8x16()]="AddSatUVecI8x16",e[e.SubVecI8x16=_BinaryenSubVecI8x16()]="SubVecI8x16",e[e.SubSatSVecI8x16=_BinaryenSubSatSVecI8x16()]="SubSatSVecI8x16",e[e.SubSatUVecI8x16=_BinaryenSubSatUVecI8x16()]="SubSatUVecI8x16",e[e.MulVecI8x16=_BinaryenMulVecI8x16()]="MulVecI8x16",e[e.AddVecI16x8=_BinaryenAddVecI16x8()]="AddVecI16x8",e[e.AddSatSVecI16x8=_BinaryenAddSatSVecI16x8()]="AddSatSVecI16x8",e[e.AddSatUVecI16x8=_BinaryenAddSatUVecI16x8()]="AddSatUVecI16x8",e[e.SubVecI16x8=_BinaryenSubVecI16x8()]="SubVecI16x8",e[e.SubSatSVecI16x8=_BinaryenSubSatSVecI16x8()]="SubSatSVecI16x8",e[e.SubSatUVecI16x8=_BinaryenSubSatUVecI16x8()]="SubSatUVecI16x8",e[e.MulVecI16x8=_BinaryenMulVecI16x8()]="MulVecI16x8",e[e.AddVecI32x4=_BinaryenAddVecI32x4()]="AddVecI32x4",e[e.SubVecI32x4=_BinaryenSubVecI32x4()]="SubVecI32x4",e[e.MulVecI32x4=_BinaryenMulVecI32x4()]="MulVecI32x4",e[e.AddVecI64x2=_BinaryenAddVecI64x2()]="AddVecI64x2",e[e.SubVecI64x2=_BinaryenSubVecI64x2()]="SubVecI64x2",e[e.AddVecF32x4=_BinaryenAddVecF32x4()]="AddVecF32x4",e[e.SubVecF32x4=_BinaryenSubVecF32x4()]="SubVecF32x4",e[e.MulVecF32x4=_BinaryenMulVecF32x4()]="MulVecF32x4",e[e.DivVecF32x4=_BinaryenDivVecF32x4()]="DivVecF32x4",e[e.MinVecF32x4=_BinaryenMinVecF32x4()]="MinVecF32x4",e[e.MaxVecF32x4=_BinaryenMaxVecF32x4()]="MaxVecF32x4",e[e.AddVecF64x2=_BinaryenAddVecF64x2()]="AddVecF64x2",e[e.SubVecF64x2=_BinaryenSubVecF64x2()]="SubVecF64x2",e[e.MulVecF64x2=_BinaryenMulVecF64x2()]="MulVecF64x2",e[e.DivVecF64x2=_BinaryenDivVecF64x2()]="DivVecF64x2",e[e.MinVecF64x2=_BinaryenMinVecF64x2()]="MinVecF64x2",e[e.MaxVecF64x2=_BinaryenMaxVecF64x2()]="MaxVecF64x2"}(r.BinaryOp||(r.BinaryOp={})),function(e){e[e.MemorySize=_BinaryenMemorySize()]="MemorySize",e[e.MemoryGrow=_BinaryenMemoryGrow()]="MemoryGrow"}(r.HostOp||(r.HostOp={})),function(e){e[e.Add=_BinaryenAtomicRMWAdd()]="Add",e[e.Sub=_BinaryenAtomicRMWSub()]="Sub",e[e.And=_BinaryenAtomicRMWAnd()]="And",e[e.Or=_BinaryenAtomicRMWOr()]="Or",e[e.Xor=_BinaryenAtomicRMWXor()]="Xor",e[e.Xchg=_BinaryenAtomicRMWXchg()]="Xchg"}(r.AtomicRMWOp||(r.AtomicRMWOp={})),function(e){e[e.ExtractLaneSVecI8x16=_BinaryenExtractLaneSVecI8x16()]="ExtractLaneSVecI8x16",e[e.ExtractLaneUVecI8x16=_BinaryenExtractLaneUVecI8x16()]="ExtractLaneUVecI8x16",e[e.ExtractLaneSVecI16x8=_BinaryenExtractLaneSVecI16x8()]="ExtractLaneSVecI16x8",e[e.ExtractLaneUVecI16x8=_BinaryenExtractLaneUVecI16x8()]="ExtractLaneUVecI16x8",e[e.ExtractLaneVecI32x4=_BinaryenExtractLaneVecI32x4()]="ExtractLaneVecI32x4",e[e.ExtractLaneVecI64x2=_BinaryenExtractLaneVecI64x2()]="ExtractLaneVecI64x2",e[e.ExtractLaneVecF32x4=_BinaryenExtractLaneVecF32x4()]="ExtractLaneVecF32x4",e[e.ExtractLaneVecF64x2=_BinaryenExtractLaneVecF64x2()]="ExtractLaneVecF64x2"}(r.SIMDExtractOp||(r.SIMDExtractOp={})),function(e){e[e.ReplaceLaneVecI8x16=_BinaryenReplaceLaneVecI8x16()]="ReplaceLaneVecI8x16",e[e.ReplaceLaneVecI16x8=_BinaryenReplaceLaneVecI16x8()]="ReplaceLaneVecI16x8",e[e.ReplaceLaneVecI32x4=_BinaryenReplaceLaneVecI32x4()]="ReplaceLaneVecI32x4",e[e.ReplaceLaneVecI64x2=_BinaryenReplaceLaneVecI64x2()]="ReplaceLaneVecI64x2",e[e.ReplaceLaneVecF32x4=_BinaryenReplaceLaneVecF32x4()]="ReplaceLaneVecF32x4",e[e.ReplaceLaneVecF64x2=_BinaryenReplaceLaneVecF64x2()]="ReplaceLaneVecF64x2"}(r.SIMDReplaceOp||(r.SIMDReplaceOp={})),function(e){e[e.ShlVecI8x16=_BinaryenShlVecI8x16()]="ShlVecI8x16",e[e.ShrSVecI8x16=_BinaryenShrSVecI8x16()]="ShrSVecI8x16",e[e.ShrUVecI8x16=_BinaryenShrUVecI8x16()]="ShrUVecI8x16",e[e.ShlVecI16x8=_BinaryenShlVecI16x8()]="ShlVecI16x8",e[e.ShrSVecI16x8=_BinaryenShrSVecI16x8()]="ShrSVecI16x8",e[e.ShrUVecI16x8=_BinaryenShrUVecI16x8()]="ShrUVecI16x8",e[e.ShlVecI32x4=_BinaryenShlVecI32x4()]="ShlVecI32x4",e[e.ShrSVecI32x4=_BinaryenShrSVecI32x4()]="ShrSVecI32x4",e[e.ShrUVecI32x4=_BinaryenShrUVecI32x4()]="ShrUVecI32x4",e[e.ShlVecI64x2=_BinaryenShlVecI64x2()]="ShlVecI64x2",e[e.ShrSVecI64x2=_BinaryenShrSVecI64x2()]="ShrSVecI64x2",e[e.ShrUVecI64x2=_BinaryenShrUVecI64x2()]="ShrUVecI64x2"}(r.SIMDShiftOp||(r.SIMDShiftOp={}));var o=function(){function e(){}return e.create=function(r,t){var n=new e;return n.buffer=r,n.offset=t,n},e}();r.MemorySegment=o;var c=function(){function e(){this.hasTemporaryFunction=!1,this.cachedPrecomputeNames=0,this.cachedStrings=new Map}return e.create=function(){var r=new e;return r.ref=_BinaryenModuleCreate(),r.lit=memory.allocate(_BinaryenSizeofLiteral()),r},e.createFrom=function(r){var t=p(r);try{var n=new e;return n.ref=_BinaryenModuleRead(t,r.length),n.lit=memory.allocate(_BinaryenSizeofLiteral()),n}finally{memory.free(changetype(t))}},e.prototype.addFunctionType=function(e,r,t){var n=this.allocStringCached(e),i=_(t);try{return _BinaryenAddFunctionType(this.ref,n,r,i,t?t.length:0)}finally{memory.free(i)}},e.prototype.getFunctionTypeBySignature=function(e,r){var t=_(r);try{return _BinaryenGetFunctionTypeBySignature(this.ref,e,t,r?r.length:0)}finally{memory.free(t)}},e.prototype.removeFunctionType=function(e){var r=this.allocStringCached(e);_BinaryenRemoveFunctionType(this.ref,r)},e.prototype.i32=function(e){var r=this.lit;return _BinaryenLiteralInt32(r,e),_BinaryenConst(this.ref,r)},e.prototype.i64=function(e,r){void 0===r&&(r=0);var t=this.lit;return _BinaryenLiteralInt64(t,e,r),_BinaryenConst(this.ref,t)},e.prototype.f32=function(e){var r=this.lit;return _BinaryenLiteralFloat32(r,e),_BinaryenConst(this.ref,r)},e.prototype.f64=function(e){var r=this.lit;return _BinaryenLiteralFloat64(r,e),_BinaryenConst(this.ref,r)},e.prototype.v128=function(e){assert(16==e.length);for(var r=this.lit,t=0;t<16;++t)store(r+t,e[t]);return _BinaryenLiteralVec128(r,r),_BinaryenConst(this.ref,r)},e.prototype.unary=function(e,r){return _BinaryenUnary(this.ref,e,r)},e.prototype.binary=function(e,r,t){return _BinaryenBinary(this.ref,e,r,t)},e.prototype.host=function(e,r,t){void 0===r&&(r=null),void 0===t&&(t=null);var n=this.allocStringCached(r),i=h(t);try{return _BinaryenHost(this.ref,e,n,i,t?t.length:0)}finally{memory.free(i)}},e.prototype.local_get=function(e,r){return _BinaryenLocalGet(this.ref,e,r)},e.prototype.local_tee=function(e,r){return _BinaryenLocalTee(this.ref,e,r)},e.prototype.global_get=function(e,r){var t=this.allocStringCached(e);return _BinaryenGlobalGet(this.ref,t,r)},e.prototype.load=function(e,r,t,n,i,a){return void 0===i&&(i=0),void 0===a&&(a=e),_BinaryenLoad(this.ref,e,r?1:0,i,a,n,t)},e.prototype.store=function(e,r,t,n,a,s){if(void 0===a&&(a=0),void 0===s&&(s=e),ni.V128)throw new Error("here: "+n);return _BinaryenStore(this.ref,e,a,s,r,t,n)},e.prototype.atomic_load=function(e,r,t,n){return void 0===n&&(n=0),_BinaryenAtomicLoad(this.ref,e,n,t,r)},e.prototype.atomic_store=function(e,r,t,n,i){return void 0===i&&(i=0),_BinaryenAtomicStore(this.ref,e,i,r,t,n)},e.prototype.atomic_rmw=function(e,r,t,n,i,a){return _BinaryenAtomicRMW(this.ref,e,r,t,n,i,a)},e.prototype.atomic_cmpxchg=function(e,r,t,n,i,a){return _BinaryenAtomicCmpxchg(this.ref,e,r,t,n,i,a)},e.prototype.atomic_wait=function(e,r,t,n){return _BinaryenAtomicWait(this.ref,e,r,t,n)},e.prototype.atomic_notify=function(e,r){return _BinaryenAtomicNotify(this.ref,e,r)},e.prototype.local_set=function(e,r){return _BinaryenLocalSet(this.ref,e,r)},e.prototype.global_set=function(e,r){var t=this.allocStringCached(e);return _BinaryenGlobalSet(this.ref,t,r)},e.prototype.block=function(e,r,t){void 0===t&&(t=i.None);var n=this.allocStringCached(e),a=h(r);try{return _BinaryenBlock(this.ref,n,a,r.length,t)}finally{memory.free(a)}},e.prototype.br=function(e,r,t){void 0===r&&(r=0),void 0===t&&(t=0);var n=this.allocStringCached(e);return _BinaryenBreak(this.ref,n,r,t)},e.prototype.drop=function(e){return _BinaryenDrop(this.ref,e)},e.prototype.loop=function(e,r){var t=this.allocStringCached(e);return _BinaryenLoop(this.ref,t,r)},e.prototype.if=function(e,r,t){return void 0===t&&(t=0),_BinaryenIf(this.ref,e,r,t)},e.prototype.nop=function(){return _BinaryenNop(this.ref)},e.prototype.return=function(e){return void 0===e&&(e=0),_BinaryenReturn(this.ref,e)},e.prototype.select=function(e,r,t){return _BinaryenSelect(this.ref,t,e,r)},e.prototype.switch=function(e,r,t,n){void 0===n&&(n=0);for(var i=e.length,a=new Array(i),s=0;s=0;--y)memory.free(l[y])}},e.prototype.setFunctionTable=function(e,r,t){for(var n=t.length,i=new Array(n),a=0;a=0;--i)memory.free(n[i])}},e.prototype.precomputeExpression=function(e){var r=_BinaryenGetOptimizeLevel(),t=_BinaryenGetShrinkLevel(),n=_BinaryenGetDebugInfo();_BinaryenSetOptimizeLevel(4),_BinaryenSetShrinkLevel(0),_BinaryenSetDebugInfo(!1);var i=_BinaryenExpressionGetType(e),a=this.addTemporaryFunction(i,null,e),s=this.cachedPrecomputeNames;return s||(this.cachedPrecomputeNames=s=_([this.allocStringCached("precompute")])),_BinaryenFunctionRunPasses(a,this.ref,s,1),e=_BinaryenFunctionGetBody(a),this.removeTemporaryFunction(),_BinaryenSetOptimizeLevel(r),_BinaryenSetShrinkLevel(t),_BinaryenSetDebugInfo(n),e},e.prototype.validate=function(){return 1==_BinaryenModuleValidate(this.ref)},e.prototype.interpret=function(){_BinaryenModuleInterpret(this.ref)},e.prototype.toBinary=function(e){var r=this.lit;assert(_BinaryenSizeofLiteral()>=12);var t=d(e),n=0,i=0;try{_BinaryenModuleAllocateAndWrite(r,this.ref,t),n=y(r);var a=y(r+4);i=y(r+8);var s=new f;return s.output=function(e,r){for(var t=new Uint8Array(r),n=0;n>8&255),store(t+2,a>>16&255),store(t+3,a>>>24),t+=4}return r}function h(e){return _(e)}function d(e){if(null==e)return 0;for(var r=memory.allocate(function(e){for(var r=0,t=0,n=e.length;t=55296&&i<=57343&&t+1=55296&&a<=57343&&n+1>>6),store(t++,128|63&a)):a<=65535?(store(t++,224|a>>>12),store(t++,128|a>>>6&63),store(t++,128|63&a)):a<=2097151?(store(t++,240|a>>>18),store(t++,128|a>>>12&63),store(t++,128|a>>>6&63),store(t++,128|63&a)):a<=67108863?(store(t++,248|a>>>24),store(t++,128|a>>>18&63),store(t++,128|a>>>12&63),store(t++,128|a>>>6&63),store(t++,128|63&a)):(store(t++,252|a>>>30),store(t++,128|a>>>24&63),store(t++,128|a>>>18&63),store(t++,128|a>>>12&63),store(t++,128|a>>>6&63),store(t++,128|63&a))}return store(t,0),r}function y(e){return load(e)|load(e+1)<<8|load(e+2)<<16|load(e+3)<<24}function m(e){if(!e)return null;for(var r,t,n,i,a,s=new Array;r=load(e++);)128&r?(t=63&load(e++),192!=(224&r)?(n=63&load(e++),224==(240&r)?r=(15&r)<<12|t<<6|n:(i=63&load(e++),240==(248&r)?r=(7&r)<<18|t<<12|n<<6|i:(a=63&load(e++),r=248==(252&r)?(3&r)<<24|t<<18|n<<12|i<<6|a:(1&r)<<30|t<<24|n<<18|i<<12|a<<6|63&load(e++))),s.push(r)):s.push((31&r)<<6|t)):s.push(r);return String.fromCodePoints(s)}r.Relooper=u,r.readString=m;var f=function(){return function(){}}();r.BinaryModule=f,r.needsExplicitUnreachable=function e(r){if(_BinaryenExpressionGetType(r)!=i.Unreachable)return!1;switch(_BinaryenExpressionGetId(r)){case a.Unreachable:case a.Return:return!1;case a.Break:return 0!=_BinaryenBreakGetCondition(r);case a.Block:if(!_BinaryenBlockGetName(r)){var t=_BinaryenBlockGetNumChildren(r);return t>0&&e(_BinaryenBlockGetChild(r,t-1))}}return!0},r.traverse=function(e,r,t){switch(l(e)){case a.Block:for(var n=0,i=_BinaryenBlockGetNumChildren(e);n=0?c.substring(l+1):c,i.statements=new Array,i.range=new s.Range(i,0,t.length),i.text=t,i}return i(r,e),Object.defineProperty(r.prototype,"isEntry",{get:function(){return this.sourceKind==Z.ENTRY},enumerable:!0,configurable:!0}),Object.defineProperty(r.prototype,"isLibrary",{get:function(){return this.sourceKind==Z.LIBRARY},enumerable:!0,configurable:!0}),r}(l);r.Source=$;var ee=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.decorators=null,r.flags=a.CommonFlags.NONE,r}return i(r,e),r.prototype.is=function(e){return(this.flags&e)==e},r.prototype.isAny=function(e){return 0!=(this.flags&e)},r.prototype.set=function(e){this.flags|=e},r}(J);r.DeclarationStatement=ee;var re=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.INDEXSIGNATUREDECLARATION,r}return i(r,e),r}(ee);r.IndexSignatureDeclaration=re;var te=function(e){function r(){return null!==e&&e.apply(this,arguments)||this}return i(r,e),r}(ee);r.VariableLikeDeclarationStatement=te;var ne=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.BLOCK,r}return i(r,e),r}(J);r.BlockStatement=ne;var ie=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.BREAK,r}return i(r,e),r}(J);r.BreakStatement=ie;var ae=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.CLASSDECLARATION,r}return i(r,e),Object.defineProperty(r.prototype,"isGeneric",{get:function(){var e=this.typeParameters;return null!=e&&e.length>0},enumerable:!0,configurable:!0}),r}(ee);r.ClassDeclaration=ae;var se=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.CONTINUE,r}return i(r,e),r}(J);r.ContinueStatement=se;var oe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.DO,r}return i(r,e),r}(J);r.DoStatement=oe;var ce=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EMPTY,r}return i(r,e),r}(J);r.EmptyStatement=ce;var le=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.ENUMDECLARATION,r}return i(r,e),r}(ee);r.EnumDeclaration=le;var ue=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.ENUMVALUEDECLARATION,r}return i(r,e),r}(te);r.EnumValueDeclaration=ue;var pe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EXPORTIMPORT,r}return i(r,e),r}(l);r.ExportImportStatement=pe;var _e=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EXPORTMEMBER,r}return i(r,e),r}(l);r.ExportMember=_e;var he=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EXPORT,r}return i(r,e),r}(J);r.ExportStatement=he;var de=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EXPORTDEFAULT,r}return i(r,e),r}(J);r.ExportDefaultStatement=de;var ye=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EXPRESSION,r}return i(r,e),r}(J);r.ExpressionStatement=ye;var me=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.FIELDDECLARATION,r.parameterIndex=-1,r}return i(r,e),r}(te);r.FieldDeclaration=me;var fe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.FOR,r}return i(r,e),r}(J);r.ForStatement=fe,function(e){e[e.NONE=0]="NONE",e[e.ARROW_PARENTHESIZED=1]="ARROW_PARENTHESIZED",e[e.ARROW_SINGLE=2]="ARROW_SINGLE"}(r.ArrowKind||(r.ArrowKind={}));var Te=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.FUNCTIONDECLARATION,r}return i(r,e),Object.defineProperty(r.prototype,"isGeneric",{get:function(){var e=this.typeParameters;return null!=e&&e.length>0},enumerable:!0,configurable:!0}),r.prototype.clone=function(){return l.createFunctionDeclaration(this.name,this.typeParameters,this.signature,this.body,this.decorators,this.flags,this.arrowKind,this.range)},r}(ee);r.FunctionDeclaration=Te;var ge=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.IF,r}return i(r,e),r}(J);r.IfStatement=ge;var Ee=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.IMPORTDECLARATION,r}return i(r,e),r}(ee);r.ImportDeclaration=Ee;var ve=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.IMPORT,r}return i(r,e),r}(J);r.ImportStatement=ve;var be=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.INTERFACEDECLARATION,r}return i(r,e),r}(ae);r.InterfaceDeclaration=be;var Ie=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.METHODDECLARATION,r}return i(r,e),r}(Te);r.MethodDeclaration=Ie;var xe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.NAMESPACEDECLARATION,r}return i(r,e),r}(ee);r.NamespaceDeclaration=xe;var Ae=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.RETURN,r}return i(r,e),r}(J);r.ReturnStatement=Ae;var Ne=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.SWITCHCASE,r}return i(r,e),r}(l);r.SwitchCase=Ne;var Se=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.SWITCH,r}return i(r,e),r}(J);r.SwitchStatement=Se;var Oe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.THROW,r}return i(r,e),r}(J);r.ThrowStatement=Oe;var Ce=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.TRY,r}return i(r,e),r}(J);r.TryStatement=Ce;var ke=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.TYPEDECLARATION,r}return i(r,e),r}(ee);r.TypeDeclaration=ke;var Le=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.VARIABLEDECLARATION,r}return i(r,e),r}(te);r.VariableDeclaration=Le;var Re=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.VARIABLE,r}return i(r,e),r}(J);r.VariableStatement=Re;var Fe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.VOID,r}return i(r,e),r}(J);r.VoidStatement=Fe;var Be=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.WHILE,r}return i(r,e),r}(J);function De(e){return e.endsWith(".ts")&&(e=e.substring(0,e.length-3)),e}r.WhileStatement=Be,r.findDecorator=function(e,r){if(r)for(var t=0,n=r.length;t>>e.size-r},e.prototype.is=function(e){return(this.flags&e)==e},e.prototype.isAny=function(e){return 0!=(this.flags&e)},e.prototype.asClass=function(r){assert(9==this.kind&&!this.classReference);var t=new e(this.kind,-129&this.flags|256,this.size);return t.classReference=r,t},e.prototype.asFunction=function(r){assert(7==this.kind&&!this.signatureReference);var t=new e(this.kind,-129&this.flags|256,this.size);return t.signatureReference=r,t},e.prototype.asNullable=function(){return assert(this.is(256)),this.cachedNullableType||(assert(!this.is(512)),this.cachedNullableType=new e(this.kind,512|this.flags,this.size),this.cachedNullableType.nonNullableType=this,this.cachedNullableType.classReference=this.classReference,this.cachedNullableType.signatureReference=this.signatureReference),this.cachedNullableType},e.prototype.isAssignableTo=function(r,t){var n,i,a,s;if(void 0===t&&(t=!1),this.is(256)){if(r.is(256)&&(!this.is(512)||r.is(512)))if(n=this.classReference){if(i=r.classReference)return n.isAssignableTo(i)}else if((a=this.signatureReference)&&(s=r.signatureReference))return a.isAssignableTo(s)}else if(!r.is(256))if(this.is(4))if(r.is(4)){if(!t||this==e.bool||this.is(1)==r.is(1))return this.size<=r.size}else{if(11==r.kind)return this.size<=23;if(12==r.kind)return this.size<=52}else if(this.is(8)){if(r.is(8))return this.size<=r.size}else if(this.is(1024)&&r.is(1024))return this.size==r.size;return!1},e.prototype.isStrictlyAssignableTo=function(e,r){return void 0===r&&(r=!1),this.is(256)?this.isAssignableTo(e):!e.is(256)&&(this.is(4)?e.is(4)&&e.size==this.size&&(!r||this.is(1)==e.is(1)):this.kind==e.kind)},e.commonDenominator=function(e,r,t){return r.isAssignableTo(e,t)?e:e.isAssignableTo(r,t)?r:null},e.prototype.toString=function(){if(this.is(256)){var e=this.classReference;if(e)return this.is(512)?e.internalName+" | null":e.internalName;var r=this.signatureReference;if(r)return this.is(512)?"("+r.toString()+") | null":r.toString();assert(!1)}switch(this.kind){case 0:return"i8";case 1:return"i16";case 2:return"i32";case 3:return"i64";case 4:return"isize";case 5:return"u8";case 6:return"u16";case 7:return"u32";case 8:return"u64";case 9:return"usize";case 10:return"bool";case 11:return"f32";case 12:return"f64";case 13:return"v128";default:assert(!1);case 14:return"void"}},e.prototype.toNativeType=function(){switch(this.kind){default:return i.NativeType.I32;case 3:case 8:return i.NativeType.I64;case 4:case 9:return 64==this.size?i.NativeType.I64:i.NativeType.I32;case 11:return i.NativeType.F32;case 12:return i.NativeType.F64;case 13:return i.NativeType.V128;case 14:return i.NativeType.None}},e.prototype.toNativeZero=function(e){switch(this.kind){case 14:assert(!1);default:return e.i32(0);case 4:case 9:if(64!=this.size)return e.i32(0);case 3:case 8:return e.i64(0);case 11:return e.f32(0);case 12:return e.f64(0);case 13:return e.v128(a)}},e.prototype.toNativeOne=function(e){switch(this.kind){case 13:case 14:assert(!1);default:return e.i32(1);case 4:case 9:if(64!=this.size)return e.i32(1);case 3:case 8:return e.i64(1);case 11:return e.f32(1);case 12:return e.f64(1)}},e.prototype.toNativeNegOne=function(e){switch(this.kind){case 13:case 14:assert(!1);default:return e.i32(-1);case 4:case 9:if(64!=this.size)return e.i32(-1);case 3:case 8:return e.i64(-1,-1);case 11:return e.f32(-1);case 12:return e.f64(-1)}},e.prototype.toSignatureString=function(){switch(this.kind){case 0:case 5:case 1:case 6:case 2:case 7:case 10:return"i";case 3:case 8:return"j";case 4:case 9:return 64==this.size?"j":"i";case 11:return"f";case 12:return"d";case 13:return"V";case 14:return"v";default:assert(!1)}return"i"},e.i8=new e(0,165,8),e.i16=new e(1,165,16),e.i32=new e(2,133,32),e.i64=new e(3,197,64),e.isize32=new e(4,149,32),e.isize64=new e(4,213,64),e.u8=new e(5,166,8),e.u16=new e(6,166,16),e.u32=new e(7,134,32),e.u64=new e(8,198,64),e.usize32=new e(9,150,32),e.usize64=new e(9,214,64),e.bool=new e(10,166,1),e.f32=new e(11,137,32),e.f64=new e(12,201,64),e.v128=new e(13,1152,128),e.void=new e(14,0,0),e.auto=new e(e.i32.kind,e.i32.flags,e.i32.size),e}();r.Type=s,r.typesToNativeTypes=function(e){for(var r=e.length,t=new Array(r),n=0;ne?r[e]:l(e)},e.prototype.isAssignableTo=function(e){var r=this.thisType,t=e.thisType;if(r){if(!t||!r.isAssignableTo(t))return!1}else if(t)return!1;if(this.hasRest!=e.hasRest)return!1;var n=this.parameterTypes,i=e.parameterTypes,a=n.length;if(a!=i.length)return!1;for(var s=0;s=o&&u!=c?e.push("?: "):e.push(": "),e.push(n[u].toString());return e.push(") => "),e.push(this.returnType.toString()),e.join("")},e}();r.Signature=o;var c=null;function l(e){c||(c=[]);for(var r=c.length;r<=e;++r)c.push("arg$"+r.toString(10));return c[e-1]}r.getDefaultParameterName=l},function(e,r,t){"use strict";var n,i=this&&this.__extends||(n=function(e,r){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,r){e.__proto__=r}||function(e,r){for(var t in r)r.hasOwnProperty(t)&&(e[t]=r[t])})(e,r)},function(e,r){function t(){this.constructor=e}n(e,r),e.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)});Object.defineProperty(r,"__esModule",{value:!0});var a,s,o=t(2),c=t(5),l=t(1);function u(e){switch(assert(e.length),e.charCodeAt(0)){case 97:switch(e){case"abstract":return a.ABSTRACT;case"as":return a.AS;case"async":return a.ASYNC;case"await":return a.AWAIT}break;case 98:switch(e){case"break":return a.BREAK}break;case 99:switch(e){case"case":return a.CASE;case"catch":return a.CATCH;case"class":return a.CLASS;case"continue":return a.CONTINUE;case"const":return a.CONST;case"constructor":return a.CONSTRUCTOR}break;case 100:switch(e){case"debugger":return a.DEBUGGER;case"declare":return a.DECLARE;case"default":return a.DEFAULT;case"delete":return a.DELETE;case"do":return a.DO}break;case 101:switch(e){case"else":return a.ELSE;case"enum":return a.ENUM;case"export":return a.EXPORT;case"extends":return a.EXTENDS}break;case 102:switch(e){case"false":return a.FALSE;case"finally":return a.FINALLY;case"for":return a.FOR;case"from":return a.FROM;case"function":return a.FUNCTION}break;case 103:switch(e){case"get":return a.GET}break;case 105:switch(e){case"if":return a.IF;case"implements":return a.IMPLEMENTS;case"import":return a.IMPORT;case"in":return a.IN;case"instanceof":return a.INSTANCEOF;case"interface":return a.INTERFACE;case"is":return a.IS}break;case 107:switch(e){case"keyof":return a.KEYOF}break;case 108:switch(e){case"let":return a.LET}break;case 109:switch(e){case"module":return a.MODULE}break;case 110:switch(e){case"namespace":return a.NAMESPACE;case"new":return a.NEW;case"null":return a.NULL}break;case 111:switch(e){case"of":return a.OF}break;case 112:switch(e){case"package":return a.PACKAGE;case"private":return a.PRIVATE;case"protected":return a.PROTECTED;case"public":return a.PUBLIC}break;case 114:switch(e){case"readonly":return a.READONLY;case"return":return a.RETURN}break;case 115:switch(e){case"set":return a.SET;case"static":return a.STATIC;case"super":return a.SUPER;case"switch":return a.SWITCH}break;case 116:switch(e){case"this":return a.THIS;case"throw":return a.THROW;case"true":return a.TRUE;case"try":return a.TRY;case"type":return a.TYPE;case"typeof":return a.TYPEOF}break;case 118:switch(e){case"var":return a.VAR;case"void":return a.VOID}break;case 119:switch(e){case"while":return a.WHILE;case"with":return a.WITH}break;case 121:switch(e){case"yield":return a.YIELD}}return a.INVALID}function p(e){switch(e){case a.ABSTRACT:case a.AS:case a.CONSTRUCTOR:case a.DECLARE:case a.DELETE:case a.FROM:case a.FOR:case a.GET:case a.INSTANCEOF:case a.IS:case a.KEYOF:case a.MODULE:case a.NAMESPACE:case a.READONLY:case a.SET:case a.TYPE:case a.VOID:return!0;default:return!1}}!function(e){e[e.ABSTRACT=0]="ABSTRACT",e[e.AS=1]="AS",e[e.ASYNC=2]="ASYNC",e[e.AWAIT=3]="AWAIT",e[e.BREAK=4]="BREAK",e[e.CASE=5]="CASE",e[e.CATCH=6]="CATCH",e[e.CLASS=7]="CLASS",e[e.CONST=8]="CONST",e[e.CONTINUE=9]="CONTINUE",e[e.CONSTRUCTOR=10]="CONSTRUCTOR",e[e.DEBUGGER=11]="DEBUGGER",e[e.DECLARE=12]="DECLARE",e[e.DEFAULT=13]="DEFAULT",e[e.DELETE=14]="DELETE",e[e.DO=15]="DO",e[e.ELSE=16]="ELSE",e[e.ENUM=17]="ENUM",e[e.EXPORT=18]="EXPORT",e[e.EXTENDS=19]="EXTENDS",e[e.FALSE=20]="FALSE",e[e.FINALLY=21]="FINALLY",e[e.FOR=22]="FOR",e[e.FROM=23]="FROM",e[e.FUNCTION=24]="FUNCTION",e[e.GET=25]="GET",e[e.IF=26]="IF",e[e.IMPLEMENTS=27]="IMPLEMENTS",e[e.IMPORT=28]="IMPORT",e[e.IN=29]="IN",e[e.INSTANCEOF=30]="INSTANCEOF",e[e.INTERFACE=31]="INTERFACE",e[e.IS=32]="IS",e[e.KEYOF=33]="KEYOF",e[e.LET=34]="LET",e[e.MODULE=35]="MODULE",e[e.NAMESPACE=36]="NAMESPACE",e[e.NEW=37]="NEW",e[e.NULL=38]="NULL",e[e.OF=39]="OF",e[e.PACKAGE=40]="PACKAGE",e[e.PRIVATE=41]="PRIVATE",e[e.PROTECTED=42]="PROTECTED",e[e.PUBLIC=43]="PUBLIC",e[e.READONLY=44]="READONLY",e[e.RETURN=45]="RETURN",e[e.SET=46]="SET",e[e.STATIC=47]="STATIC",e[e.SUPER=48]="SUPER",e[e.SWITCH=49]="SWITCH",e[e.THIS=50]="THIS",e[e.THROW=51]="THROW",e[e.TRUE=52]="TRUE",e[e.TRY=53]="TRY",e[e.TYPE=54]="TYPE",e[e.TYPEOF=55]="TYPEOF",e[e.VAR=56]="VAR",e[e.VOID=57]="VOID",e[e.WHILE=58]="WHILE",e[e.WITH=59]="WITH",e[e.YIELD=60]="YIELD",e[e.OPENBRACE=61]="OPENBRACE",e[e.CLOSEBRACE=62]="CLOSEBRACE",e[e.OPENPAREN=63]="OPENPAREN",e[e.CLOSEPAREN=64]="CLOSEPAREN",e[e.OPENBRACKET=65]="OPENBRACKET",e[e.CLOSEBRACKET=66]="CLOSEBRACKET",e[e.DOT=67]="DOT",e[e.DOT_DOT_DOT=68]="DOT_DOT_DOT",e[e.SEMICOLON=69]="SEMICOLON",e[e.COMMA=70]="COMMA",e[e.LESSTHAN=71]="LESSTHAN",e[e.GREATERTHAN=72]="GREATERTHAN",e[e.LESSTHAN_EQUALS=73]="LESSTHAN_EQUALS",e[e.GREATERTHAN_EQUALS=74]="GREATERTHAN_EQUALS",e[e.EQUALS_EQUALS=75]="EQUALS_EQUALS",e[e.EXCLAMATION_EQUALS=76]="EXCLAMATION_EQUALS",e[e.EQUALS_EQUALS_EQUALS=77]="EQUALS_EQUALS_EQUALS",e[e.EXCLAMATION_EQUALS_EQUALS=78]="EXCLAMATION_EQUALS_EQUALS",e[e.EQUALS_GREATERTHAN=79]="EQUALS_GREATERTHAN",e[e.PLUS=80]="PLUS",e[e.MINUS=81]="MINUS",e[e.ASTERISK_ASTERISK=82]="ASTERISK_ASTERISK",e[e.ASTERISK=83]="ASTERISK",e[e.SLASH=84]="SLASH",e[e.PERCENT=85]="PERCENT",e[e.PLUS_PLUS=86]="PLUS_PLUS",e[e.MINUS_MINUS=87]="MINUS_MINUS",e[e.LESSTHAN_LESSTHAN=88]="LESSTHAN_LESSTHAN",e[e.GREATERTHAN_GREATERTHAN=89]="GREATERTHAN_GREATERTHAN",e[e.GREATERTHAN_GREATERTHAN_GREATERTHAN=90]="GREATERTHAN_GREATERTHAN_GREATERTHAN",e[e.AMPERSAND=91]="AMPERSAND",e[e.BAR=92]="BAR",e[e.CARET=93]="CARET",e[e.EXCLAMATION=94]="EXCLAMATION",e[e.TILDE=95]="TILDE",e[e.AMPERSAND_AMPERSAND=96]="AMPERSAND_AMPERSAND",e[e.BAR_BAR=97]="BAR_BAR",e[e.QUESTION=98]="QUESTION",e[e.COLON=99]="COLON",e[e.EQUALS=100]="EQUALS",e[e.PLUS_EQUALS=101]="PLUS_EQUALS",e[e.MINUS_EQUALS=102]="MINUS_EQUALS",e[e.ASTERISK_EQUALS=103]="ASTERISK_EQUALS",e[e.ASTERISK_ASTERISK_EQUALS=104]="ASTERISK_ASTERISK_EQUALS",e[e.SLASH_EQUALS=105]="SLASH_EQUALS",e[e.PERCENT_EQUALS=106]="PERCENT_EQUALS",e[e.LESSTHAN_LESSTHAN_EQUALS=107]="LESSTHAN_LESSTHAN_EQUALS",e[e.GREATERTHAN_GREATERTHAN_EQUALS=108]="GREATERTHAN_GREATERTHAN_EQUALS",e[e.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS=109]="GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS",e[e.AMPERSAND_EQUALS=110]="AMPERSAND_EQUALS",e[e.BAR_EQUALS=111]="BAR_EQUALS",e[e.CARET_EQUALS=112]="CARET_EQUALS",e[e.AT=113]="AT",e[e.IDENTIFIER=114]="IDENTIFIER",e[e.STRINGLITERAL=115]="STRINGLITERAL",e[e.INTEGERLITERAL=116]="INTEGERLITERAL",e[e.FLOATLITERAL=117]="FLOATLITERAL",e[e.INVALID=118]="INVALID",e[e.ENDOFFILE=119]="ENDOFFILE"}(a=r.Token||(r.Token={})),function(e){e[e.DEFAULT=0]="DEFAULT",e[e.PREFER=1]="PREFER",e[e.ALWAYS=2]="ALWAYS"}(s=r.IdentifierHandling||(r.IdentifierHandling={})),r.tokenFromKeyword=u,r.tokenIsAlsoIdentifier=p,r.operatorTokenToString=function(e){switch(e){case a.DELETE:return"delete";case a.IN:return"in";case a.INSTANCEOF:return"instanceof";case a.NEW:return"new";case a.TYPEOF:return"typeof";case a.VOID:return"void";case a.YIELD:return"yield";case a.DOT_DOT_DOT:return"...";case a.COMMA:return",";case a.LESSTHAN:return"<";case a.GREATERTHAN:return">";case a.LESSTHAN_EQUALS:return"<=";case a.GREATERTHAN_EQUALS:return">=";case a.EQUALS_EQUALS:return"==";case a.EXCLAMATION_EQUALS:return"!=";case a.EQUALS_EQUALS_EQUALS:return"===";case a.EXCLAMATION_EQUALS_EQUALS:return"!==";case a.PLUS:return"+";case a.MINUS:return"-";case a.ASTERISK_ASTERISK:return"**";case a.ASTERISK:return"*";case a.SLASH:return"/";case a.PERCENT:return"%";case a.PLUS_PLUS:return"++";case a.MINUS_MINUS:return"--";case a.LESSTHAN_LESSTHAN:return"<<";case a.GREATERTHAN_GREATERTHAN:return">>";case a.GREATERTHAN_GREATERTHAN_GREATERTHAN:return">>>";case a.AMPERSAND:return"&";case a.BAR:return"|";case a.CARET:return"^";case a.EXCLAMATION:return"!";case a.TILDE:return"~";case a.AMPERSAND_AMPERSAND:return"&&";case a.BAR_BAR:return"||";case a.EQUALS:return"=";case a.PLUS_EQUALS:return"+=";case a.MINUS_EQUALS:return"-=";case a.ASTERISK_EQUALS:return"*=";case a.ASTERISK_ASTERISK_EQUALS:return"**=";case a.SLASH_EQUALS:return"/=";case a.PERCENT_EQUALS:return"%=";case a.LESSTHAN_LESSTHAN_EQUALS:return"<<=";case a.GREATERTHAN_GREATERTHAN_EQUALS:return">>=";case a.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:return">>>=";case a.AMPERSAND_EQUALS:return"&=";case a.BAR_EQUALS:return"|=";case a.CARET_EQUALS:return"^=";default:return assert(!1),""}};var _=function(){function e(e,r,t){this.debugInfoRef=0,this.source=e,this.start=r,this.end=t}return e.join=function(r,t){if(r.source!=t.source)throw new Error("source mismatch");return new e(r.source,r.startt.end?r.end:t.end)},Object.defineProperty(e.prototype,"atStart",{get:function(){return new e(this.source,this.start,this.start)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"atEnd",{get:function(){return new e(this.source,this.end,this.end)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"line",{get:function(){for(var e=this.source.text,r=1,t=this.start;t>=0;--t)10==e.charCodeAt(t)&&r++;return r},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"column",{get:function(){for(var e=this.source.text,r=0,t=this.start-1;t>=0&&10!=e.charCodeAt(t);--t)++r;return r},enumerable:!0,configurable:!0}),e.prototype.toString=function(){return this.source.text.substring(this.start,this.end)},e}();r.Range=_;var h=function(e){function r(r,t){void 0===t&&(t=null);var n=e.call(this,t)||this;n.end=0,n.pos=0,n.token=-1,n.tokenPos=0,n.nextToken=-1,n.nextTokenPos=0,n.nextTokenOnNewLine=!1,n.onComment=null,n.source=r,n.pos=0,n.end=r.text.length,n.diagnostics=t||new Array;var i=n.end,a=r.text;if(n.pos1&&this.pos2&&this.pos1&&this.pos1&&this.pos1&&this.pos2&&this.pos1&&this.pos1&&this.pos1&&this.pos2&&this.pos+11&&this.pos1&&this.pos2&&this.pos1&&this.pos2&&this.pos1&&this.pos2&&this.pos3&&this.pos1&&this.pos1&&this.pos=n){i+=e.substring(t,this.pos),this.error(o.DiagnosticCode.Unterminated_string_literal,this.range(t-1,n));break}var a=e.charCodeAt(this.pos);if(a==r){i+=e.substring(t,this.pos++);break}if(92!=a){if(l.isLineBreak(a)){i+=e.substring(t,this.pos),this.error(o.DiagnosticCode.Unterminated_string_literal,this.range(t-1,this.pos));break}++this.pos}else i+=e.substring(t,this.pos),i+=this.readEscapeSequence(),t=this.pos}return i},r.prototype.readEscapeSequence=function(){var e=this.end;if(++this.pos>=e)return this.error(o.DiagnosticCode.Unexpected_end_of_text,this.range(e)),"";var r=this.source.text,t=r.charCodeAt(this.pos++);switch(t){case 48:return"\0";case 98:return"\b";case 116:return"\t";case 110:return"\n";case 118:return"\v";case 102:return"\f";case 114:return"\r";case 39:return"'";case 34:return'"';case 117:return this.pos=t){this.error(o.DiagnosticCode.Unterminated_regular_expression_literal,this.range(r,t));break}if(92!=e.charCodeAt(this.pos)){var i=e.charCodeAt(this.pos);if(!n&&47==i)break;if(l.isLineBreak(i)){this.error(o.DiagnosticCode.Unterminated_regular_expression_literal,this.range(r,this.pos));break}++this.pos,n=!1}else++this.pos,n=!0}return e.substring(r,this.pos)},r.prototype.readRegexpFlags=function(){for(var e=this.source.text,r=this.pos,t=this.end,n=0;this.pos57)&&95!=n)break;t++}return!0},r.prototype.readInteger=function(){var e=this.source.text;if(this.pos+2=48&&c<=57)t=i64_add(i64_shl(t,n),i64_new(c-48));else if(c>=65&&c<=70)t=i64_add(i64_shl(t,n),i64_new(10+c-65));else if(c>=97&&c<=102)t=i64_add(i64_shl(t,n),i64_new(10+c-97));else{if(95!=c)break;i==s&&this.error(i==r?o.DiagnosticCode.Numeric_separators_are_not_allowed_here:o.DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,this.range(s)),i=s+1}this.pos=s+1}return this.pos==r?this.error(o.DiagnosticCode.Hexadecimal_digit_expected,this.range(r)):i==this.pos&&this.error(o.DiagnosticCode.Numeric_separators_are_not_allowed_here,this.range(i-1)),t},r.prototype.readDecimalInteger=function(){for(var e=this.source.text,r=this.pos,t=this.end,n=i64_new(0),i=i64_new(10),a=r;this.pos=48&&c<=57)n=i64_add(i64_mul(n,i),i64_new(c-48));else{if(95!=c)break;a==s&&this.error(a==r?o.DiagnosticCode.Numeric_separators_are_not_allowed_here:o.DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,this.range(s)),a=s+1}this.pos=s+1}return this.pos==r?this.error(o.DiagnosticCode.Digit_expected,this.range(r)):a==this.pos&&this.error(o.DiagnosticCode.Numeric_separators_are_not_allowed_here,this.range(a-1)),n},r.prototype.readOctalInteger=function(){for(var e=this.source.text,r=this.pos,t=i64_new(0),n=i64_new(3),i=r,a=this.end;this.pos=48&&c<=55)t=i64_add(i64_shl(t,n),i64_new(c-48));else{if(95!=c)break;i==s&&this.error(i==r?o.DiagnosticCode.Numeric_separators_are_not_allowed_here:o.DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,this.range(s)),i=s+1}++this.pos}return this.pos==r?this.error(o.DiagnosticCode.Octal_digit_expected,this.range(r)):i==this.pos&&this.error(o.DiagnosticCode.Numeric_separators_are_not_allowed_here,this.range(i-1)),t},r.prototype.readBinaryInteger=function(){for(var e=this.source.text,r=this.pos,t=i64_new(0),n=i64_new(1),i=r,a=this.end;this.pos=48&&i<=57)r=(r<<4)+i-48;else if(i>=65&&i<=70)r=(r<<4)+i+-55;else{if(!(i>=97&&i<=102))return this.error(o.DiagnosticCode.Hexadecimal_digit_expected,this.range(this.pos-1,this.pos)),"";r=(r<<4)+i+-87}if(0==--e)break}return e?(this.error(o.DiagnosticCode.Unexpected_end_of_text,this.range(this.pos)),""):String.fromCharCode(r)},r.prototype.readExtendedUnicodeEscape=function(){var e=this.pos,r=this.readHexInteger(),t=i64_low(r),n=!1;assert(!i64_high(r)),t>1114111&&(this.error(o.DiagnosticCode.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive,this.range(e,this.pos)),n=!0);var i=this.end,a=this.source.text;return this.pos>=i?(this.error(o.DiagnosticCode.Unexpected_end_of_text,this.range(e,i)),n=!0):125==a.charCodeAt(this.pos)?++this.pos:(this.error(o.DiagnosticCode.Unterminated_Unicode_escape_sequence,this.range(e,this.pos)),n=!0),n?"":t<65536?String.fromCharCode(t):String.fromCharCode(55296+(t-65536>>>10),56320+(t-65536&1023))},r.prototype.finish=function(){},r}(o.DiagnosticEmitter);r.Tokenizer=h;var d=function(){return function(){}}();r.State=d;var y=null},function(e,r){var t;t=function(){return this}();try{t=t||new Function("return this")()}catch(e){"object"==typeof window&&(t=window)}e.exports=t},function(e,r,t){"use strict";var n,i=this&&this.__extends||(n=function(e,r){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,r){e.__proto__=r}||function(e,r){for(var t in r)r.hasOwnProperty(t)&&(e[t]=r[t])})(e,r)},function(e,r){function t(){this.constructor=e}n(e,r),e.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)}),a=this&&this.__values||function(e){var r="function"==typeof Symbol&&e[Symbol.iterator],t=0;return r?r.call(e):{next:function(){return e&&t>=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},s=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0});var o,c=t(2),l=t(3),u=t(5),p=t(6),_=t(0),h=t(1),d=t(7),y=t(13);!function(e){e[e.REPORT=0]="REPORT",e[e.SWALLOW=1]="SWALLOW"}(o=r.ReportMode||(r.ReportMode={}));var m=function(e){function r(r){var t=e.call(this,r.diagnostics)||this;return t.currentThisExpression=null,t.currentElementExpression=null,t.program=r,t}return i(r,e),r.prototype.resolveType=function(e,r,t,n){if(void 0===t&&(t=null),void 0===n&&(n=o.REPORT),e.kind==u.NodeKind.SIGNATURE){var i=e.explicitThisType,a=null;if(i&&!(a=this.resolveType(i,r,t,n)))return null;for(var s=e.parameters,d=s.length,y=new Array(d),m=new Array(d),f=0,T=!1,g=0;gl)return this.error(c.DiagnosticCode.Expected_0_type_arguments_but_got_1,d?u.Range.join(r[0].range,r[d-1].range):assert(i).range,(d0)return this.resolveExpression(e.arguments[0],r,t,n);var s=this.resolveFunctionInclTypeArguments(a,e.typeArguments,r.actualFunction,h.makeMap(r.contextualTypeArguments),e,n);if(!s)return null;var u=s.signature.returnType,_=u.classReference;if(_)return _;var d=u.signatureReference;return d?d.asFunctionTarget(this.program):(n==o.REPORT&&this.error(c.DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,i.range,a.internalName),null)}return n==o.REPORT&&this.error(c.DiagnosticCode.Operation_not_supported,e.range),null},r.prototype.resolveFunction=function(e,r,t,n){void 0===t&&(t=h.makeMap()),void 0===n&&(n=o.REPORT);var i=e.parent.kind==l.ElementKind.PROPERTY_PROTOTYPE?e.parent.parent:e.parent,a=null,s=r?p.typesToString(r):"";if(e.is(_.CommonFlags.INSTANCE)){if(assert(i.kind==l.ElementKind.CLASS),a=i,g=e.getResolvedInstance(s))return g;var d=a.typeArguments;if(d){var y=assert(a.prototype.typeParameterNodes),m=y.length;assert(m==y.length);for(var f=0;f");var w=new l.Function(P,e,D,t);return e.setResolvedInstance(s,w),w},r.prototype.resolveFunctionInclTypeArguments=function(e,r,t,n,i,a){void 0===a&&(a=o.REPORT);var s=e.parent.kind==l.ElementKind.PROPERTY_PROTOTYPE?e.parent.parent:e.parent,u=null;if(e.is(_.CommonFlags.GENERIC)){if(e.is(_.CommonFlags.INSTANCE)){assert(s.kind==l.ElementKind.CLASS);var p=s.typeArguments;if(p){var h=assert(s.prototype.typeParameterNodes),d=p.length;assert(d==h.length);for(var y=0;y"),(g=new l.Class(S,e,r,A)).contextualTypeArguments=t,e.setResolvedInstance(T,g);var O=0;if(A){if(G=A.members){(U=g.members)||(g.members=U=new Map);try{for(var C=a(G),k=C.next();!k.done;k=C.next()){var L=s(k.value,2),R=L[0],F=L[1];U.set(R,F)}}catch(e){i={error:e}}finally{try{k&&!k.done&&(u=C.return)&&u.call(C)}finally{if(i)throw i.error}}}O=A.currentMemoryOffset}var B=e.instanceMembers;if(B)try{for(var D=a(B.values()),P=D.next();!P.done;P=D.next()){var w=P.value;switch(w.kind){case l.ElementKind.FIELD_PROTOTYPE:var U;if(U=g.members){if(U.has(w.name)){this.error(c.DiagnosticCode.Duplicate_identifier_0,w.identifierNode.range,w.name);break}}else g.members=U=new Map;var M=w.typeNode,V=null;if(M)V=this.resolveType(M,e.parent,g.contextualTypeArguments,n);else{var G;if(A)if((G=A.members)&&G.has(w.name)){var K=G.get(w.name);K.is(_.CommonFlags.PRIVATE)||(assert(K.kind==l.ElementKind.FIELD),V=K.type)}V||n==o.REPORT&&this.error(c.DiagnosticCode.Type_expected,w.identifierNode.range.atEnd)}if(!V)break;var z=new l.Field(w,g,V);assert(h.isPowerOf2(V.byteSize));var Y=V.byteSize-1;O&Y&&(O=1+(O|Y)),z.memoryOffset=O,O+=V.byteSize,g.add(w.name,z);break;case l.ElementKind.FUNCTION_PROTOTYPE:var H=w.toBound(g);g.add(H.name,H);break;case l.ElementKind.PROPERTY_PROTOTYPE:var W=new l.Property(w,g),X=w.getterPrototype;if(X){var q=this.resolveFunction(X.toBound(g),null,h.makeMap(g.contextualTypeArguments),n);q&&(W.getterInstance=q,W.setType(q.signature.returnType))}var Q=w.setterPrototype;if(Q){var j=this.resolveFunction(Q.toBound(g),null,h.makeMap(g.contextualTypeArguments),n);j&&(W.setterInstance=j,W.is(_.CommonFlags.RESOLVED)||(assert(1==j.signature.parameterTypes.length),W.setType(j.signature.parameterTypes[0])))}g.add(W.name,W);break;default:assert(!1)}}}catch(e){d={error:e}}finally{try{P&&!P.done&&(y=D.return)&&y.call(D)}finally{if(d)throw d.error}}g.currentMemoryOffset=O;var Z=g.lookupInSelf(_.CommonSymbols.constructor);if(Z&&Z.parent===g){assert(Z.kind==l.ElementKind.FUNCTION_PROTOTYPE);var J=this.resolveFunction(Z,null,g.contextualTypeArguments,n);J&&(g.constructorInstance=J)}try{for(var $=a(e.overloadPrototypes),ee=$.next();!ee.done;ee=$.next()){var re=s(ee.value,2),te=re[0],ne=re[1];assert(te!=l.OperatorKind.INVALID);var ie=void 0;if(ne.is(_.CommonFlags.INSTANCE)){H=ne.toBound(g);ie=this.resolveFunction(H,null,h.makeMap(),n)}else ie=this.resolveFunction(ne,null,h.makeMap(),n);if(ie){var ae=g.overloads;ae||(g.overloads=ae=new Map),ae.set(te,ie)}}}catch(e){m={error:e}}finally{try{ee&&!ee.done&&(f=$.return)&&f.call($)}finally{if(m)throw m.error}}return g},r.prototype.resolveClassInclTypeArguments=function(e,r,t,n,i,a){void 0===a&&(a=o.REPORT);var s=null;if(e.is(_.CommonFlags.GENERIC)){if(!(s=this.resolveTypeArguments(assert(e.typeParameterNodes),r,t,n,i,a)))return null}else if(null!==r&&r.length)return a==o.REPORT&&this.error(c.DiagnosticCode.Type_0_is_not_generic,i.range,e.internalName),null;return this.resolveClass(e,s,n,a)},r}(c.DiagnosticEmitter);r.Resolver=m},function(e,r,t){"use strict";var n=this&&this.__values||function(e){var r="function"==typeof Symbol&&e[Symbol.iterator],t=0;return r?r.call(e):{next:function(){return e&&t>=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}};Object.defineProperty(r,"__esModule",{value:!0});var i,a=t(6),s=t(3),o=t(4),c=t(0),l=t(2);!function(e){e[e.NONE=0]="NONE",e[e.RETURNS=1]="RETURNS",e[e.RETURNS_WRAPPED=2]="RETURNS_WRAPPED",e[e.RETURNS_NONNULL=4]="RETURNS_NONNULL",e[e.THROWS=8]="THROWS",e[e.BREAKS=16]="BREAKS",e[e.CONTINUES=32]="CONTINUES",e[e.ALLOCATES=64]="ALLOCATES",e[e.CALLS_SUPER=128]="CALLS_SUPER",e[e.TERMINATES=256]="TERMINATES",e[e.CONDITIONALLY_RETURNS=512]="CONDITIONALLY_RETURNS",e[e.CONDITIONALLY_THROWS=1024]="CONDITIONALLY_THROWS",e[e.CONDITIONALLY_TERMINATES=2048]="CONDITIONALLY_TERMINATES",e[e.CONDITIONALLY_BREAKS=4096]="CONDITIONALLY_BREAKS",e[e.CONDITIONALLY_CONTINUES=8192]="CONDITIONALLY_CONTINUES",e[e.CONDITIONALLY_ALLOCATES=16384]="CONDITIONALLY_ALLOCATES",e[e.INLINE_CONTEXT=32768]="INLINE_CONTEXT",e[e.UNCHECKED_CONTEXT=65536]="UNCHECKED_CONTEXT",e[e.ANY_CATEGORICAL=511]="ANY_CATEGORICAL",e[e.ANY_CONDITIONAL=30208]="ANY_CONDITIONAL"}(r.FlowFlags||(r.FlowFlags={})),function(e){e[e.NONE=0]="NONE",e[e.CONSTANT=1]="CONSTANT",e[e.WRAPPED=2]="WRAPPED",e[e.NONNULL=4]="NONNULL",e[e.READFROM=8]="READFROM",e[e.WRITTENTO=16]="WRITTENTO",e[e.RETAINED=32]="RETAINED",e[e.CONDITIONALLY_READFROM=64]="CONDITIONALLY_READFROM",e[e.CONDITIONALLY_WRITTENTO=128]="CONDITIONALLY_WRITTENTO",e[e.CONDITIONALLY_RETAINED=256]="CONDITIONALLY_RETAINED",e[e.ANY_CATEGORICAL=63]="ANY_CATEGORICAL",e[e.ANY_CONDITIONAL=480]="ANY_CONDITIONAL",e[e.ANY_RETAINED=288]="ANY_RETAINED"}(i=r.LocalFlags||(r.LocalFlags={})),function(e){e.join=function(r,t){return r&e.ANY_CATEGORICAL&t&e.ANY_CATEGORICAL|r&e.ANY_CONDITIONAL|t&e.ANY_CONDITIONAL}}(i=r.LocalFlags||(r.LocalFlags={})),function(e){e[e.NONE=0]="NONE",e[e.INITIALIZED=1]="INITIALIZED",e[e.CONDITIONALLY_INITIALIZED=2]="CONDITIONALLY_INITIALIZED",e[e.ANY_CATEGORICAL=1]="ANY_CATEGORICAL",e[e.ANY_CONDITIONAL=2]="ANY_CONDITIONAL"}(r.FieldFlags||(r.FieldFlags={})),function(e){e.join=function(r,t){return r&e.ANY_CATEGORICAL&t&e.ANY_CATEGORICAL|r&e.ANY_CONDITIONAL|t&e.ANY_CONDITIONAL}}(r.FieldFlags||(r.FieldFlags={}));var u=function(){function e(){this.scopedLocals=null,this.fieldFlags=null}return e.create=function(r){var t=new e;return t.parent=null,t.flags=0,t.parentFunction=r,t.continueLabel=null,t.breakLabel=null,t.returnType=r.signature.returnType,t.contextualTypeArguments=r.contextualTypeArguments,t.localFlags=[],t.inlineFunction=null,t.inlineReturnLabel=null,t},e.createInline=function(r,t){var n=e.create(r);return n.set(32768),n.inlineFunction=t,n.inlineReturnLabel=t.internalName+"|inlined."+(t.nextInlineId++).toString(10),n.returnType=t.signature.returnType,n.contextualTypeArguments=t.contextualTypeArguments,n},Object.defineProperty(e.prototype,"actualFunction",{get:function(){return this.inlineFunction||this.parentFunction},enumerable:!0,configurable:!0}),e.prototype.is=function(e){return(this.flags&e)==e},e.prototype.isAny=function(e){return 0!=(this.flags&e)},e.prototype.set=function(e){this.flags|=e},e.prototype.unset=function(e){this.flags&=~e},e.prototype.fork=function(){var r=new e;return r.parent=this,r.flags=this.flags,r.parentFunction=this.parentFunction,r.continueLabel=this.continueLabel,r.breakLabel=this.breakLabel,r.returnType=this.returnType,r.contextualTypeArguments=this.contextualTypeArguments,r.localFlags=this.localFlags.slice(),r.inlineFunction=this.inlineFunction,r.inlineReturnLabel=this.inlineReturnLabel,r},e.prototype.getTempLocal=function(e,r){void 0===r&&(r=null);var t,n,i=this.parentFunction;switch(e.toNativeType()){case o.NativeType.I32:t=i.tempI32s;break;case o.NativeType.I64:t=i.tempI64s;break;case o.NativeType.F32:t=i.tempF32s;break;case o.NativeType.F64:t=i.tempF64s;break;case o.NativeType.V128:t=i.tempV128s;break;default:throw new Error("concrete type expected")}if(r){if(t&&t.length)for(var a=0,s=t.length;a=0);var r,t=this.parentFunction;switch(assert(null!=e.type),e.type.toNativeType()){case o.NativeType.I32:r=t.tempI32s||(t.tempI32s=[]);break;case o.NativeType.I64:r=t.tempI64s||(t.tempI64s=[]);break;case o.NativeType.F32:r=t.tempF32s||(t.tempF32s=[]);break;case o.NativeType.F64:r=t.tempF64s||(t.tempF64s=[]);break;case o.NativeType.V128:r=t.tempV128s||(t.tempV128s=[]);break;default:throw new Error("concrete type expected")}assert(e.index>=0),r.push(e)}},e.prototype.getAndFreeTempLocal=function(e,r){void 0===r&&(r=null);var t=this.getTempLocal(e,r);return this.freeTempLocal(t),t},e.prototype.getScopedLocal=function(e){var r=this.scopedLocals;return r&&r.has(e)?r.get(e):null},e.prototype.addScopedLocal=function(e,r,t){void 0===t&&(t=null);var n=this.getTempLocal(r,t),i=this.scopedLocals;return i?assert(!i.has(e)):this.scopedLocals=i=new Map,n.set(c.CommonFlags.SCOPED),i.set(e,n),n},e.prototype.addScopedAlias=function(e,r,t,n){if(void 0===n&&(n=null),this.scopedLocals){var i=this.scopedLocals.get(e);if(i)return n&&this.parentFunction.program.error(l.DiagnosticCode.Duplicate_identifier_0,n.range),i}else this.scopedLocals=new Map;assert(t1?e.breakLabel=r[t-2].toString(10):(e.breakLabel=null,e.breakStack=null)},e.prototype.inherit=function(e){this.flags|=30719&e.flags,this.localFlags=e.localFlags},e.prototype.inheritConditional=function(e){e.is(1)&&this.set(512),e.is(8)&&this.set(1024),e.is(16)&&e.breakLabel==this.breakLabel&&this.set(4096),e.is(32)&&e.continueLabel==this.continueLabel&&this.set(8192),e.is(64)&&this.set(16384);for(var r=e.localFlags,t=0,n=r.length;tl):this.canOverflow(o.getBinaryLeft(e),r)&&!(o.getExpressionId(t=o.getBinaryRight(e))==o.ExpressionId.Const&&o.getConstValueI32(t)>=l);case o.BinaryOp.DivU32:case o.BinaryOp.RemI32:case o.BinaryOp.RemU32:return this.canOverflow(o.getBinaryLeft(e),r)||this.canOverflow(o.getBinaryRight(e),r)}break;case o.ExpressionId.Unary:switch(o.getUnaryOp(e)){case o.UnaryOp.EqzI32:case o.UnaryOp.EqzI64:return!1;case o.UnaryOp.ClzI32:case o.UnaryOp.CtzI32:case o.UnaryOp.PopcntI32:return r.size<7}break;case o.ExpressionId.Const:var u=0;switch(o.getExpressionType(e)){case o.NativeType.I32:u=o.getConstValueI32(e);break;case o.NativeType.I64:u=o.getConstValueI64Low(e);break;case o.NativeType.F32:u=i32(o.getConstValueF32(e));break;case o.NativeType.F64:u=i32(o.getConstValueF64(e));break;default:assert(!1)}switch(r.kind){case 0:return ui8.MAX_VALUE;case 1:return ui16.MAX_VALUE;case 5:return u<0||u>u8.MAX_VALUE;case 6:return u<0||u>u16.MAX_VALUE;case 10:return 0!=(-2&u)}break;case o.ExpressionId.Load:var _=void 0,h=o.isLoadSigned(e);switch(o.getLoadBytes(e)){case 1:_=h?a.Type.i8:a.Type.u8;break;case 2:_=h?a.Type.i16:a.Type.u16;break;default:_=h?a.Type.i32:a.Type.u32}return p(_,r);case o.ExpressionId.Block:if(!o.getBlockName(e)){var d=assert(o.getBlockChildCount(e)),y=o.getBlockChild(e,d-1);return this.canOverflow(y,r)}break;case o.ExpressionId.If:return this.canOverflow(o.getIfTrue(e),r)||this.canOverflow(assert(o.getIfFalse(e)),r);case o.ExpressionId.Select:return this.canOverflow(o.getSelectThen(e),r)||this.canOverflow(o.getSelectElse(e),r);case o.ExpressionId.Call:var m=this.parentFunction.program.instancesByName,f=assert(o.getCallTarget(e));if(m.has(f)){var T=m.get(f);assert(T.kind==s.ElementKind.FUNCTION);var g=T.signature.returnType;return!T.flow.is(2)||p(g,r)}return!1;case o.ExpressionId.Unreachable:return!1}return!0},e.prototype.toString=function(){for(var e=0,r=this.parent;r;)r=r.parent,++e;return"Flow("+this.actualFunction+")["+e.toString()+"]"},e}();function p(e,r){return!e.is(4)||e.size>r.size||e.is(1)!=r.is(1)}function _(e,r){switch(o.getExpressionId(e)){case o.ExpressionId.LocalGet:r.add(o.getLocalGetIndex(e));break;case o.ExpressionId.LocalSet:r.add(o.getLocalSetIndex(e));default:o.traverse(e,r,_)}}r.Flow=u,r.findUsedLocals=function(e,r){return void 0===r&&(r=new Set),o.traverse(e,r,_),r}},function(e,r,t){"use strict";var n,i=this&&this.__extends||(n=function(e,r){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,r){e.__proto__=r}||function(e,r){for(var t in r)r.hasOwnProperty(t)&&(e[t]=r[t])})(e,r)},function(e,r){function t(){this.constructor=e}n(e,r),e.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)}),a=this&&this.__values||function(e){var r="function"==typeof Symbol&&e[Symbol.iterator],t=0;return r?r.call(e):{next:function(){return e&&t>=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},s=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0});var o=t(13),c=t(2),l=t(4),u=t(0),p=t(3),_=t(10),h=t(9),d=t(7),y=t(5),m=t(6),f=t(1),T=function(){function e(){this.target=u.Target.WASM32,this.noAssert=!1,this.importMemory=!1,this.sharedMemory=0,this.importTable=!1,this.sourceMap=!1,this.explicitStart=!1,this.memoryBase=0,this.globalAliases=null,this.features=0,this.optimizeLevelHint=0,this.shrinkLevelHint=0}return Object.defineProperty(e.prototype,"isWasm64",{get:function(){return this.target==u.Target.WASM64},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"usizeType",{get:function(){return this.target==u.Target.WASM64?m.Type.usize64:m.Type.usize32},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isizeType",{get:function(){return this.target==u.Target.WASM64?m.Type.isize64:m.Type.isize32},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"nativeSizeType",{get:function(){return this.target==u.Target.WASM64?l.NativeType.I64:l.NativeType.I32},enumerable:!0,configurable:!0}),e.prototype.hasFeature=function(e){return 0!=(this.features&e)},e}();r.Options=T,function(e){e[e.NONE=0]="NONE",e[e.CONV_IMPLICIT=1]="CONV_IMPLICIT",e[e.CONV_EXPLICIT=2]="CONV_EXPLICIT",e[e.MUST_WRAP=4]="MUST_WRAP",e[e.WILL_DROP=8]="WILL_DROP",e[e.WILL_RETAIN=16]="WILL_RETAIN",e[e.PREFER_STATIC=32]="PREFER_STATIC"}(r.Constraints||(r.Constraints={})),function(e){e[e.NONE=0]="NONE",e[e.HEAP=1]="HEAP",e[e.RTTI=2]="RTTI",e[e.visitGlobals=4]="visitGlobals",e[e.visitMembers=8]="visitMembers"}(r.RuntimeFeatures||(r.RuntimeFeatures={}));var g,E,v=function(e){function r(r,t){void 0===t&&(t=null);var n=e.call(this,r.diagnostics)||this;n.currentInlineFunctions=[],n.currentEnum=null,n.currentType=m.Type.void,n.memorySegments=[],n.stringSegments=new Map,n.functionTable=["null"],n.argcVar=0,n.argcSet=0,n.runtimeFeatures=0,n.skippedAutoreleases=new Set,n.f32ModInstance=null,n.f64ModInstance=null,n.f32PowInstance=null,n.f64PowInstance=null,n.program=r,n.resolver=r.resolver,t||(t=new T),n.options=t,n.memoryOffset=i64_new(max(t.memoryBase,8)),n.module=l.Module.create();var i=0;return n.options.hasFeature(16)&&(i|=l.FeatureFlags.Atomics),n.options.hasFeature(2)&&(i|=l.FeatureFlags.MutableGloabls),n.options.hasFeature(8)&&(i|=l.FeatureFlags.SIMD128),n.options.hasFeature(4)&&(i|=l.FeatureFlags.BulkMemory),n.options.hasFeature(1)&&(i|=l.FeatureFlags.SignExt),n.module.setFeatures(i),n}return i(r,e),r.compile=function(e,t){return void 0===t&&(t=null),new r(e,t).compile()},r.prototype.compile=function(){var e,r,t,n,i=this.options,s=this.module,c=this.program;c.initialize(i);var u=c.makeNativeFunction("start",new m.Signature([],m.Type.void));u.internalName="start";var p=new Array;this.currentFlow=u.flow,this.currentBody=p,i.isWasm64?(s.addGlobal(o.BuiltinSymbols.heap_base,l.NativeType.I64,!0,s.i64(0)),s.addGlobal(o.BuiltinSymbols.rtti_base,l.NativeType.I64,!0,s.i64(0))):(s.addGlobal(o.BuiltinSymbols.heap_base,l.NativeType.I32,!0,s.i32(0)),s.addGlobal(o.BuiltinSymbols.rtti_base,l.NativeType.I32,!0,s.i32(0)));var _=c.filesByName;try{for(var h=a(_.values()),d=h.next();!d.done;d=h.next()){(A=d.value).source.isEntry&&(this.compileFile(A),this.compileExports(A))}}catch(r){e={error:r}}finally{try{d&&!d.done&&(r=h.return)&&r.call(h)}finally{if(e)throw e.error}}var y=!p.length,f=i.explicitStart;if(!y||f){var T=u.signature;!y&&f&&(s.addGlobal(o.BuiltinSymbols.started,l.NativeType.I32,!0,s.i32(0)),p.unshift(s.if(s.global_get(o.BuiltinSymbols.started,l.NativeType.I32),s.return(),s.global_set(o.BuiltinSymbols.started,s.i32(1)))));var g=s.addFunction(u.internalName,this.ensureFunctionType(T.parameterTypes,T.returnType,T.thisType),m.typesToNativeTypes(u.additionalLocals),s.block(null,p));u.finalize(s,g),f?s.addFunctionExport(u.internalName,"__start"):s.setStart(g)}4&this.runtimeFeatures&&o.compileVisitGlobals(this),8&this.runtimeFeatures&&o.compileVisitMembers(this),s.removeGlobal(o.BuiltinSymbols.rtti_base),2&this.runtimeFeatures&&o.compileRTTI(this);var E=this.memoryOffset;E=i64_align(E,i.usizeType.byteSize),this.memoryOffset=E,s.removeGlobal(o.BuiltinSymbols.heap_base),1&this.runtimeFeatures&&(i.isWasm64?s.addGlobal(o.BuiltinSymbols.heap_base,l.NativeType.I64,!1,s.i64(i64_low(E),i64_high(E))):s.addGlobal(o.BuiltinSymbols.heap_base,l.NativeType.I32,!1,s.i32(i64_low(E))));var v=i.hasFeature(16)&&i.sharedMemory>0;s.setMemory(this.options.memoryBase||this.memorySegments.length?i64_low(i64_shr_u(i64_align(E,65536),i64_new(16,0))):0,v?i.sharedMemory:l.Module.UNLIMITED_MEMORY,this.memorySegments,i.target,"memory",v),i.importMemory&&s.addMemoryImport("0","env","memory",v);var b=this.functionTable;s.setFunctionTable(b.length,4294967295,b),s.addFunction("null",this.ensureFunctionType(null,m.Type.void),null,s.block(null,[])),i.importTable&&s.addTableImport("0","env","table");try{for(var I=a(this.program.filesByName.values()),x=I.next();!x.done;x=I.next()){var A;(A=x.value).source.isEntry&&this.ensureModuleExports(A)}}catch(e){t={error:e}}finally{try{x&&!x.done&&(n=I.return)&&n.call(I)}finally{if(t)throw t.error}}return s},r.prototype.ensureModuleExports=function(e){var r,t,n=e.exports;if(n)try{for(var i=a(n),o=i.next();!o.done;o=i.next()){var c=s(o.value,2),l=c[0],u=c[1];this.ensureModuleExport(l,u)}}catch(e){r={error:e}}finally{try{o&&!o.done&&(t=i.return)&&t.call(i)}finally{if(r)throw r.error}}var p=e.exportsStar;if(p)for(var _=0,h=p.length;_1?p.block(null,n):n[0]),t.push(p.call(r.internalName,null,l.NativeType.None))}}},r.prototype.compileGlobal=function(e){if(e.is(u.CommonFlags.COMPILED))return!0;e.set(u.CommonFlags.COMPILED);var r=this.module,t=0,n=!1,i=e.typeNode,a=e.initializerNode;if(!e.is(u.CommonFlags.RESOLVED))if(i){var s=this.resolver.resolveType(i,e.parent);if(!s)return!1;if(s==m.Type.void)return this.error(c.DiagnosticCode.Type_expected,i.range),!1;e.setType(s)}else{if(!a)return this.error(c.DiagnosticCode.Type_expected,e.identifierNode.range.atEnd),!1;var _=this.currentFlow;if(e.hasDecorator(p.DecoratorFlags.LAZY)&&(this.currentFlow=e.file.startFunction.flow),t=this.compileExpression(a,m.Type.auto,20),this.skippedAutoreleases.has(t)&&(n=!0),this.currentFlow=_,this.currentType==m.Type.void)return this.error(c.DiagnosticCode.Type_0_is_not_assignable_to_type_1,a.range,this.currentType.toString(),""),!1;e.setType(this.currentType)}if(e.is(u.CommonFlags.AMBIENT)&&e.hasDecorator(p.DecoratorFlags.BUILTIN))return e.internalName==o.BuiltinSymbols.heap_base?this.runtimeFeatures|=1:e.internalName==o.BuiltinSymbols.rtti_base&&(this.runtimeFeatures|=2),!0;var h=e.type,d=h.toNativeType(),f=e.is(u.CommonFlags.CONST)||e.is(u.CommonFlags.STATIC|u.CommonFlags.READONLY),T=e.hasDecorator(p.DecoratorFlags.INLINE);if(e.is(u.CommonFlags.AMBIENT))return f||this.options.hasFeature(2)?(e.set(u.CommonFlags.MODULE_IMPORT),b(e,e.declaration),r.addGlobalImport(e.internalName,g,E,d),e.set(u.CommonFlags.COMPILED),!0):(this.error(c.DiagnosticCode.Operation_not_supported,e.declaration.range),!1);var v=!1;if(a){if(!t){_=this.currentFlow;e.hasDecorator(p.DecoratorFlags.LAZY)&&(this.currentFlow=e.file.startFunction.flow),t=this.compileExpression(a,h,53),this.skippedAutoreleases.has(t)&&(n=!0),this.currentFlow=_}if(l.getExpressionId(t)!=l.ExpressionId.Const&&(f?(t=r.precomputeExpression(t),l.getExpressionId(t)!=l.ExpressionId.Const&&(v=!0)):v=!0),T)if(v)this.warning(c.DiagnosticCode.Mutable_value_cannot_be_inlined,a.range);else{switch(assert(l.getExpressionId(t)==l.ExpressionId.Const),l.getExpressionType(t)){case l.NativeType.I32:e.constantValueKind=1,e.constantIntegerValue=i64_new(l.getConstValueI32(t),0);break;case l.NativeType.I64:e.constantValueKind=1,e.constantIntegerValue=i64_new(l.getConstValueI64Low(t),l.getConstValueI64High(t));break;case l.NativeType.F32:e.constantValueKind=2,e.constantFloatValue=l.getConstValueF32(t);break;case l.NativeType.F64:e.constantValueKind=2,e.constantFloatValue=l.getConstValueF64(t);break;default:return assert(!1),!1}e.set(u.CommonFlags.INLINED)}}else t=h.toNativeZero(r);var I=e.internalName;return v?(T&&this.error(c.DiagnosticCode.Decorator_0_is_not_valid_here,assert(y.findDecorator(y.DecoratorKind.INLINE,e.decoratorNodes)).range,"inline"),r.addGlobal(I,d,!0,h.toNativeZero(r)),h.isManaged&&!n&&(t=this.makeRetain(t)),this.currentBody.push(r.global_set(I,t))):T||r.addGlobal(I,d,!f,t),!0},r.prototype.compileEnum=function(e){var r,t;if(e.is(u.CommonFlags.COMPILED))return!0;e.set(u.CommonFlags.COMPILED);var n=this.module;this.currentEnum=e;var i=null,s=!1,o=e.is(u.CommonFlags.CONST)||e.hasDecorator(p.DecoratorFlags.INLINE);if(e.members)try{for(var _=a(e.members.values()),h=_.next();!h.done;h=_.next()){var d=h.value;if(d.kind==p.ElementKind.ENUMVALUE){var y=!1,f=d,T=f.valueNode;f.set(u.CommonFlags.COMPILED);var g=this.currentFlow;e.hasDecorator(p.DecoratorFlags.LAZY)&&(this.currentFlow=e.file.startFunction.flow);var E=void 0;T?(E=this.compileExpression(T,m.Type.i32,1),l.getExpressionId(E)!=l.ExpressionId.Const&&(E=n.precomputeExpression(E),l.getExpressionId(E)!=l.ExpressionId.Const&&(e.is(u.CommonFlags.CONST)&&this.error(c.DiagnosticCode.In_const_enum_declarations_member_initializer_must_be_constant_expression,T.range),y=!0))):null==i?E=n.i32(0):(s&&this.error(c.DiagnosticCode.Enum_member_must_have_initializer,d.identifierNode.range.atEnd),E=n.binary(l.BinaryOp.AddI32,n.global_get(i.internalName,l.NativeType.I32),n.i32(1)),E=n.precomputeExpression(E),l.getExpressionId(E)!=l.ExpressionId.Const&&(e.is(u.CommonFlags.CONST)&&this.error(c.DiagnosticCode.In_const_enum_declarations_member_initializer_must_be_constant_expression,d.declaration.range),y=!0)),this.currentFlow=g,y?(n.addGlobal(f.internalName,l.NativeType.I32,!0,n.i32(0)),this.currentBody.push(this.makeGlobalAssignment(f,E,!1)),s=!0):(o?(f.setConstantIntegerValue(i64_new(l.getConstValueI32(E)),m.Type.i32),f.is(u.CommonFlags.MODULE_EXPORT)&&n.addGlobal(f.internalName,l.NativeType.I32,!1,E)):n.addGlobal(f.internalName,l.NativeType.I32,!1,E),f.isImmutable=!0,s=!1),i=f}}}catch(e){r={error:e}}finally{try{h&&!h.done&&(t=_.return)&&t.call(_)}finally{if(r)throw r.error}}return this.currentEnum=null,!0},r.prototype.compileFunctionUsingTypeArguments=function(e,r,t,n){if(void 0===t&&(t=f.makeMap()),void 0===n&&(n=null),e.hasDecorator(p.DecoratorFlags.BUILTIN))return null;var i=this.resolver.resolveFunctionInclTypeArguments(e,r,e.parent,t,n||e.declaration);return i&&this.compileFunction(i)?i:null},r.prototype.ensureFunctionType=function(e,r,t){void 0===t&&(t=null);var n,i=e?e.length:0,a=0;if(t?((n=new Array(1+i))[0]=t.toNativeType(),a=1):n=new Array(i),e)for(var s=0;so){var f=a.getAndFreeTempLocal(i);h||a.setLocalFlag(f.index,_.LocalFlags.WRAPPED),d&&a.setLocalFlag(f.index,_.LocalFlags.NONNULL),r[o-1]=t.local_set(f.index,s),r.push(t.local_get(f.index,i.toNativeType()))}h||a.set(2),d&&a.set(4),a.set(257)}}if(e.is(u.CommonFlags.CONSTRUCTOR)){var T=this.options.nativeSizeType;assert(e.is(u.CommonFlags.INSTANCE));var g=assert(e.parent);if(assert(g.kind==p.ElementKind.CLASS),!a.is(256)){var E=assert(a.lookupLocal(u.CommonSymbols.this_));a.is(64)||(r.push(t.if(t.unary(T==l.NativeType.I64?l.UnaryOp.EqzI64:l.UnaryOp.EqzI32,t.local_get(E.index,T)),t.local_set(E.index,this.makeRetain(this.makeAllocation(g))))),this.makeFieldInitialization(g,r)),this.performAutoreleases(a,r),this.finishAutoreleases(a,r),r.push(t.local_get(E.index,this.options.nativeSizeType)),a.set(261)}g.base&&!a.is(128)&&this.error(c.DiagnosticCode.Constructors_for_derived_classes_must_contain_a_super_call,e.prototype.declaration.range)}else i==m.Type.void||a.is(256)||this.error(c.DiagnosticCode.A_function_whose_declared_type_is_not_void_must_return_a_value,e.prototype.signatureNode.returnType.range);return r},r.prototype.compileFunction=function(e){if(e.is(u.CommonFlags.COMPILED))return!0;assert(!(e.is(u.CommonFlags.AMBIENT)&&e.hasDecorator(p.DecoratorFlags.BUILTIN)));var r=this.currentType;e.set(u.CommonFlags.COMPILED);var t,n=this.module,i=e.signature,a=e.prototype.bodyNode,s=this.ensureFunctionType(i.parameterTypes,i.returnType,i.thisType);if(a){if(e.is(u.CommonFlags.AMBIENT)&&this.error(c.DiagnosticCode.An_implementation_cannot_be_declared_in_ambient_contexts,e.identifierNode.range),e.hasDecorator(p.DecoratorFlags.EXTERNAL)){var o=e.decoratorNodes,l=assert(y.findDecorator(y.DecoratorKind.EXTERNAL,o));this.error(c.DiagnosticCode.Operation_not_supported,l.range)}var h=this.currentFlow,d=e.flow;this.currentFlow=d;var f=new Array,T=0;i.thisType&&++T;for(var v=i.parameterTypes,x=0,A=v.length;x=0)return e.functionTableIndex;var r=this.functionTable,t=r.length;return!e.is(u.CommonFlags.TRAMPOLINE)&&e.signature.requiredParameters1||l.getExpressionId(g[0])!=l.ExpressionId.Break)&&S.push(r.block(d,g));else for(var O=0,C=g.length;O=0?"case"+p.toString(10):"break")+"|"+a);var d=r.block("case0|"+a,c,l.NativeType.None),y=511,f=0;for(_=0;_=0&&(i.flags|=-17&y),i.flags|=-4097&f,d},r.prototype.compileThrowStatement=function(e){var r=this.currentFlow;r.set(264);var t=new Array;this.finishAutoreleases(r,t);var n=e.value,i=null;if(n.kind==y.NodeKind.NEW){var a=n.arguments;a.length&&(i=a[0])}return t.push(o.compileAbort(this,i,e)),I(this.module,t,l.NativeType.None)},r.prototype.compileTryStatement=function(e){return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()},r.prototype.compileVariableStatement=function(e){for(var r=this.module,t=e.declarations,n=t.length,i=this.currentFlow,a=new Array,s=this.resolver,o=0;o");continue}y=this.currentType}var g=h.is(u.CommonFlags.CONST),E=!1;if(g)if(f){if(f=r.precomputeExpression(f),l.getExpressionId(f)==l.ExpressionId.Const){var v=new p.Local(d,-1,y,i.parentFunction);switch(l.getExpressionType(f)){case l.NativeType.I32:v.setConstantIntegerValue(i64_new(l.getConstValueI32(f),0),y);break;case l.NativeType.I64:v.setConstantIntegerValue(i64_new(l.getConstValueI64Low(f),l.getConstValueI64High(f)),y);break;case l.NativeType.F32:v.setConstantFloatValue(l.getConstValueF32(f),y);break;case l.NativeType.F64:v.setConstantFloatValue(l.getConstValueF64(f),y);break;default:return assert(!1),r.unreachable()}var b=i.scopedLocals;if(b){if(b.has(d))return this.error(c.DiagnosticCode.Duplicate_identifier_0,h.name.range,d),this.module.unreachable()}else i.scopedLocals=b=new Map;b.set(d,v),E=!0}}else this.error(c.DiagnosticCode._const_declarations_must_be_initialized,h.range);if(!E){v=void 0;if(h.isAny(u.CommonFlags.LET|u.CommonFlags.CONST)||i.is(32768)){var x=i.getScopedLocal(d);x?(this.error(c.DiagnosticCode.Duplicate_identifier_0,h.name.range,h.name.text),v=x):v=i.addScopedLocal(d,y),g&&i.setLocalFlag(v.index,_.LocalFlags.CONSTANT)}else{if(i.lookupLocal(d)){this.error(c.DiagnosticCode.Duplicate_identifier_0,h.name.range,d);continue}v=i.parentFunction.addLocal(y,d,h),g&&i.setLocalFlag(v.index,_.LocalFlags.CONSTANT)}var A=y.isManaged;f?(i.isNonnull(f,y)&&i.setLocalFlag(v.index,_.LocalFlags.NONNULL),A?(i.setLocalFlag(v.index,_.LocalFlags.RETAINED),a.push(r.local_set(v.index,T?f:this.makeRetain(f)))):(a.push(r.local_set(v.index,f)),v.type.is(36)&&(i.canOverflow(f,y)?i.unsetLocalFlag(v.index,_.LocalFlags.WRAPPED):i.setLocalFlag(v.index,_.LocalFlags.WRAPPED)))):A?(a.push(r.local_set(v.index,y.toNativeZero(r))),i.setLocalFlag(v.index,_.LocalFlags.CONDITIONALLY_RETAINED)):v.type.is(36)&&i.setLocalFlag(v.index,_.LocalFlags.WRAPPED)}}return 0==a.length?0:I(r,a,l.NativeType.None)},r.prototype.compileVoidStatement=function(e){return this.compileExpression(e.expression,m.Type.void,10)},r.prototype.compileWhileStatement=function(e){var r=this.module,t=this.currentFlow,n=r.precomputeExpression(this.makeIsTrueish(this.compileExpression(e.condition,m.Type.bool),this.currentType)),i=!1;if(l.getExpressionId(n)==l.ExpressionId.Const){if(assert(l.getExpressionType(n)==l.NativeType.I32),!l.getConstValueI32(n))return r.nop();i=!0}var a=t.pushBreakLabel(),s=t.fork();this.currentFlow=s;var o="break|"+a;s.breakLabel=o;var c="continue|"+a;s.continueLabel=c,s.inheritNonnullIfTrue(n);var u=new Array;e.statement.kind==y.NodeKind.BLOCK?this.compileStatements(e.statement.statements,!1,u):u.push(this.compileStatement(e.statement));var p=!s.is(256)&&!s.is(16);p&&(this.performAutoreleases(s,u),u.push(r.br(c))),i||u.unshift(r.br(o,r.unary(l.UnaryOp.EqzI32,n)));var _=I(r,u,l.NativeType.None);return(p||s.isAny(8224))&&(_=r.loop(c,_)),i&&!s.isAny(4112)||(_=r.block(o,[_])),s.freeScopedLocals(),t.popBreakLabel(),s.unset(12336),i?t.inherit(s):t.inheritConditional(s),this.currentFlow=t,_},r.prototype.compileInlineConstant=function(e,r,t){assert(e.is(u.CommonFlags.INLINED));var n=e.type;switch(!(3&t)&&n.is(4)&&r.is(4)&&n.size>i:0);case 5:case 6:case 10:var a=e.type.computeSmallIntegerMask(m.Type.i32);return this.module.i32(1==e.constantValueKind?i64_low(e.constantIntegerValue)&a:0);case 2:case 7:return this.module.i32(1==e.constantValueKind?i64_low(e.constantIntegerValue):0);case 4:case 9:if(!e.program.options.isWasm64)return this.module.i32(1==e.constantValueKind?i64_low(e.constantIntegerValue):0);case 3:case 8:return 1==e.constantValueKind?this.module.i64(i64_low(e.constantIntegerValue),i64_high(e.constantIntegerValue)):this.module.i64(0);case 12:if(!e.hasDecorator(p.DecoratorFlags.BUILTIN)||r!=m.Type.f32)return this.module.f64(e.constantFloatValue);this.currentType=m.Type.f32;case 11:return this.module.f32(e.constantFloatValue);default:return assert(!1),this.module.unreachable()}},r.prototype.compileExpression=function(e,r,t){var n;switch(void 0===t&&(t=0),this.currentType=r,r==m.Type.void&&(t|=8),e.kind){case y.NodeKind.ASSERTION:n=this.compileAssertionExpression(e,r,t);break;case y.NodeKind.BINARY:n=this.compileBinaryExpression(e,r,t);break;case y.NodeKind.CALL:n=this.compileCallExpression(e,r,t);break;case y.NodeKind.COMMA:n=this.compileCommaExpression(e,r,t);break;case y.NodeKind.ELEMENTACCESS:n=this.compileElementAccessExpression(e,r,t);break;case y.NodeKind.FUNCTION:n=this.compileFunctionExpression(e,r.signatureReference,t);break;case y.NodeKind.IDENTIFIER:case y.NodeKind.FALSE:case y.NodeKind.NULL:case y.NodeKind.THIS:case y.NodeKind.SUPER:case y.NodeKind.TRUE:n=this.compileIdentifierExpression(e,r,t);break;case y.NodeKind.INSTANCEOF:n=this.compileInstanceOfExpression(e,r,t);break;case y.NodeKind.LITERAL:n=this.compileLiteralExpression(e,r,t);break;case y.NodeKind.NEW:n=this.compileNewExpression(e,r,t);break;case y.NodeKind.PARENTHESIZED:n=this.compileExpression(e.expression,r,t);break;case y.NodeKind.PROPERTYACCESS:n=this.compilePropertyAccessExpression(e,r,t);break;case y.NodeKind.TERNARY:n=this.compileTernaryExpression(e,r,t);break;case y.NodeKind.UNARYPOSTFIX:n=this.compileUnaryPostfixExpression(e,r,t);break;case y.NodeKind.UNARYPREFIX:n=this.compileUnaryPrefixExpression(e,r,t);break;default:this.error(c.DiagnosticCode.Operation_not_supported,e.range),n=this.module.unreachable()}var i=this.currentType,a=0!=(4&t);return i!=r&&(2&t?(n=this.convertExpression(n,i,r,!0,a,e),a=!1,this.currentType=r):1&t&&(n=this.convertExpression(n,i,r,!1,a,e),a=!1,this.currentType=r)),a&&(n=this.ensureSmallIntegerWrap(n,i)),this.options.sourceMap&&this.addDebugLocation(n,e.range),n},r.prototype.precomputeExpression=function(e,r,t){return void 0===t&&(t=0),this.module.precomputeExpression(this.compileExpression(e,r,t))},r.prototype.convertExpression=function(e,r,t,n,i,a){var s=this.module;return 14==r.kind?(assert(14!=t.kind),this.error(c.DiagnosticCode.Type_0_is_not_assignable_to_type_1,a.range,r.toString(),t.toString()),s.unreachable()):14==t.kind?s.drop(e):(this.currentFlow.isNonnull(e,r)&&(r=r.nonNullableType),r.isAssignableTo(t)||n||(r.nonNullableType==t?this.error(c.DiagnosticCode.Object_is_possibly_null,a.range):this.error(c.DiagnosticCode.Conversion_from_type_0_to_1_requires_an_explicit_cast,a.range,r.toString(),t.toString())),r.is(8)?t.is(8)?11==r.kind?12==t.kind&&(e=s.unary(l.UnaryOp.PromoteF32,e)):11==t.kind&&(e=s.unary(l.UnaryOp.DemoteF64,e)):t.is(4)?11==r.kind?t==m.Type.bool?(e=s.binary(l.BinaryOp.NeF32,e,s.f32(0)),i=!1):e=t.is(1)?t.is(64)?s.unary(l.UnaryOp.TruncF32ToI64,e):s.unary(l.UnaryOp.TruncF32ToI32,e):t.is(64)?s.unary(l.UnaryOp.TruncF32ToU64,e):s.unary(l.UnaryOp.TruncF32ToU32,e):t==m.Type.bool?(e=s.binary(l.BinaryOp.NeF64,e,s.f64(0)),i=!1):e=t.is(1)?t.is(64)?s.unary(l.UnaryOp.TruncF64ToI64,e):s.unary(l.UnaryOp.TruncF64ToI32,e):t.is(64)?s.unary(l.UnaryOp.TruncF64ToU64,e):s.unary(l.UnaryOp.TruncF64ToU32,e):(assert(0==t.flags,"void type expected"),e=s.drop(e)):r.is(4)&&t.is(8)?e=11==t.kind?r.is(64)?s.unary(r.is(1)?l.UnaryOp.ConvertI64ToF32:l.UnaryOp.ConvertU64ToF32,e):s.unary(r.is(1)?l.UnaryOp.ConvertI32ToF32:l.UnaryOp.ConvertU32ToF32,e):r.is(64)?s.unary(r.is(1)?l.UnaryOp.ConvertI64ToF64:l.UnaryOp.ConvertU64ToF64,e):s.unary(r.is(1)?l.UnaryOp.ConvertI32ToF64:l.UnaryOp.ConvertU32ToF64,e):r.is(64)?t==m.Type.bool?(e=s.binary(l.BinaryOp.NeI64,e,s.i64(0)),i=!1):t.is(64)||(e=s.unary(l.UnaryOp.WrapI64,e)):t.is(64)?(e=s.unary(r.is(1)?l.UnaryOp.ExtendI32:l.UnaryOp.ExtendU32,this.ensureSmallIntegerWrap(e,r)),i=!1):r.is(32)&&r.size",i.toString(),s.toString()),this.currentType=r,y.unreachable();switch(n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T),o.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.GtI32,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.GtI64:l.BinaryOp.GtI32,n,a);break;case 3:h=y.binary(l.BinaryOp.GtI64,n,a);break;case 5:case 6:case 7:case 10:h=y.binary(l.BinaryOp.GtU32,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.GtU64:l.BinaryOp.GtU32,n,a);break;case 8:h=y.binary(l.BinaryOp.GtU64,n,a);break;case 11:h=y.binary(l.BinaryOp.GtF32,n,a);break;case 12:h=y.binary(l.BinaryOp.GtF64,n,a);break;default:assert(!1),h=y.unreachable()}this.currentType=m.Type.bool;break;case d.Token.LESSTHAN_EQUALS:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.LE)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!0)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"<=",i.toString(),s.toString()),this.currentType=r,y.unreachable();switch(n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T),o.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.LeI32,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.LeI64:l.BinaryOp.LeI32,n,a);break;case 3:h=y.binary(l.BinaryOp.LeI64,n,a);break;case 5:case 6:case 7:case 10:h=y.binary(l.BinaryOp.LeU32,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.LeU64:l.BinaryOp.LeU32,n,a);break;case 8:h=y.binary(l.BinaryOp.LeU64,n,a);break;case 11:h=y.binary(l.BinaryOp.LeF32,n,a);break;case 12:h=y.binary(l.BinaryOp.LeF64,n,a);break;default:assert(!1),h=y.unreachable()}this.currentType=m.Type.bool;break;case d.Token.GREATERTHAN_EQUALS:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.GE)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!0)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,">=",i.toString(),s.toString()),this.currentType=r,y.unreachable();switch(n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T),o.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.GeI32,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.GeI64:l.BinaryOp.GeI32,n,a);break;case 3:h=y.binary(l.BinaryOp.GeI64,n,a);break;case 5:case 6:case 7:case 10:h=y.binary(l.BinaryOp.GeU32,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.GeU64:l.BinaryOp.GeU32,n,a);break;case 8:h=y.binary(l.BinaryOp.GeU64,n,a);break;case 11:h=y.binary(l.BinaryOp.GeF32,n,a);break;case 12:h=y.binary(l.BinaryOp.GeF64,n,a);break;default:assert(!1),h=y.unreachable()}this.currentType=m.Type.bool;break;case d.Token.EQUALS_EQUALS_EQUALS:case d.Token.EQUALS_EQUALS:if(n=this.compileExpression(f,r),i=this.currentType,E==d.Token.EQUALS_EQUALS&&this.currentType.is(256))if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.EQ)){h=this.compileBinaryOverload(A,f,n,T,e);break}if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,d.operatorTokenToString(e.operator),i.toString(),s.toString()),this.currentType=r,y.unreachable();switch(n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T),o.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:h=y.binary(l.BinaryOp.EqI32,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.EqI64:l.BinaryOp.EqI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.EqI64,n,a);break;case 11:h=y.binary(l.BinaryOp.EqF32,n,a);break;case 12:h=y.binary(l.BinaryOp.EqF64,n,a);break;case 13:h=y.unary(l.UnaryOp.AllTrueVecI8x16,y.binary(l.BinaryOp.EqVecI8x16,n,a));break;default:assert(!1),h=y.unreachable()}this.currentType=m.Type.bool;break;case d.Token.EXCLAMATION_EQUALS_EQUALS:case d.Token.EXCLAMATION_EQUALS:if(n=this.compileExpression(f,r),i=this.currentType,E==d.Token.EXCLAMATION_EQUALS&&this.currentType.is(256))if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.NE)){h=this.compileBinaryOverload(A,f,n,T,e);break}if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,d.operatorTokenToString(e.operator),i.toString(),s.toString()),this.currentType=r,y.unreachable();switch(n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T),o.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:h=y.binary(l.BinaryOp.NeI32,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.NeI64:l.BinaryOp.NeI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.NeI64,n,a);break;case 11:h=y.binary(l.BinaryOp.NeF32,n,a);break;case 12:h=y.binary(l.BinaryOp.NeF64,n,a);break;case 13:h=y.unary(l.UnaryOp.AnyTrueVecI8x16,y.binary(l.BinaryOp.NeVecI8x16,n,a));break;default:assert(!1),h=y.unreachable()}this.currentType=m.Type.bool;break;case d.Token.EQUALS:return this.compileAssignment(f,T,r);case d.Token.PLUS_EQUALS:g=!0;case d.Token.PLUS:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.ADD)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)a=this.compileExpression(T,i,1);else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"+",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 5:case 6:case 10:case 2:case 7:h=y.binary(l.BinaryOp.AddI32,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.AddI64:l.BinaryOp.AddI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.AddI64,n,a);break;case 11:h=y.binary(l.BinaryOp.AddF32,n,a);break;case 12:h=y.binary(l.BinaryOp.AddF64,n,a);break;default:assert(!1),h=y.unreachable()}break;case d.Token.MINUS_EQUALS:g=!0;case d.Token.MINUS:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.SUB)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"-",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 5:case 6:case 10:case 2:case 7:h=y.binary(l.BinaryOp.SubI32,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.SubI64:l.BinaryOp.SubI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.SubI64,n,a);break;case 11:h=y.binary(l.BinaryOp.SubF32,n,a);break;case 12:h=y.binary(l.BinaryOp.SubF64,n,a);break;default:assert(!1),h=y.unreachable()}break;case d.Token.ASTERISK_EQUALS:g=!0;case d.Token.ASTERISK:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.MUL)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)n=this.ensureSmallIntegerWrap(n,i),a=this.compileExpression(T,i,1);else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"*",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 5:case 6:case 10:case 2:case 7:h=y.binary(l.BinaryOp.MulI32,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.MulI64:l.BinaryOp.MulI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.MulI64,n,a);break;case 11:h=y.binary(l.BinaryOp.MulF32,n,a);break;case 12:h=y.binary(l.BinaryOp.MulF64,n,a);break;default:assert(!1),h=y.unreachable()}break;case d.Token.ASTERISK_ASTERISK_EQUALS:g=!0;case d.Token.ASTERISK_ASTERISK:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.POW)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}var v=void 0;if(11==this.currentType.kind){if(a=this.compileExpression(T,m.Type.f32,1),s=this.currentType,!(v=this.f32PowInstance)){if(!(b=this.program.lookupGlobal(u.CommonSymbols.Mathf))){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Mathf"),h=y.unreachable();break}if(!(I=b.members?b.members.get(u.CommonSymbols.pow):null)){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Mathf.pow"),h=y.unreachable();break}assert(I.kind==p.ElementKind.FUNCTION_PROTOTYPE),this.f32PowInstance=v=this.resolver.resolveFunction(I,null)}}else if(n=this.convertExpression(n,this.currentType,m.Type.f64,!1,!1,f),i=this.currentType,a=this.compileExpression(T,m.Type.f64,1),s=this.currentType,!(v=this.f64PowInstance)){if(!(b=this.program.lookupGlobal(u.CommonSymbols.Math))){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Math"),h=y.unreachable();break}if(!(I=b.members?b.members.get(u.CommonSymbols.pow):null)){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Math.pow"),h=y.unreachable();break}assert(I.kind==p.ElementKind.FUNCTION_PROTOTYPE),this.f64PowInstance=v=this.resolver.resolveFunction(I,null)}h=v&&this.compileFunction(v)?this.makeCallDirect(v,[n,a],e):y.unreachable();break;case d.Token.SLASH_EQUALS:g=!0;case d.Token.SLASH:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.DIV)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)n=this.ensureSmallIntegerWrap(n,i),a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"/",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T)}switch(this.currentType.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.DivI32,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.DivI64:l.BinaryOp.DivI32,n,a);break;case 3:h=y.binary(l.BinaryOp.DivI64,n,a);break;case 5:case 6:case 10:case 7:h=y.binary(l.BinaryOp.DivU32,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.DivU64:l.BinaryOp.DivU32,n,a);break;case 8:h=y.binary(l.BinaryOp.DivU64,n,a);break;case 11:h=y.binary(l.BinaryOp.DivF32,n,a);break;case 12:h=y.binary(l.BinaryOp.DivF64,n,a);break;default:assert(!1),h=y.unreachable()}break;case d.Token.PERCENT_EQUALS:g=!0;case d.Token.PERCENT:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.REM)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)n=this.ensureSmallIntegerWrap(n,i),a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"%",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T)}switch(this.currentType.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.RemI32,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.RemI64:l.BinaryOp.RemI32,n,a);break;case 3:h=y.binary(l.BinaryOp.RemI64,n,a);break;case 5:case 6:case 10:case 7:h=y.binary(l.BinaryOp.RemU32,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.RemU64:l.BinaryOp.RemU32,n,a);break;case 8:h=y.binary(l.BinaryOp.RemU64,n,a);break;case 11:if(!(v=this.f32ModInstance)){if(!(b=this.program.lookupGlobal(u.CommonSymbols.Mathf))){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Mathf"),h=y.unreachable();break}if(!(I=b.members?b.members.get(u.CommonSymbols.mod):null)){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Mathf.mod"),h=y.unreachable();break}assert(I.kind==p.ElementKind.FUNCTION_PROTOTYPE),this.f32ModInstance=v=this.resolver.resolveFunction(I,null)}h=v&&this.compileFunction(v)?this.makeCallDirect(v,[n,a],e):y.unreachable();break;case 12:if(!(v=this.f64ModInstance)){var b,I;if(!(b=this.program.lookupGlobal(u.CommonSymbols.Math))){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Math"),h=y.unreachable();break}if(!(I=b.members?b.members.get(u.CommonSymbols.mod):null)){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Math.mod"),h=y.unreachable();break}assert(I.kind==p.ElementKind.FUNCTION_PROTOTYPE),this.f64ModInstance=v=this.resolver.resolveFunction(I,null)}h=v&&this.compileFunction(v)?this.makeCallDirect(v,[n,a],e):y.unreachable();break;default:assert(!1),h=y.unreachable()}break;case d.Token.LESSTHAN_LESSTHAN_EQUALS:g=!0;case d.Token.LESSTHAN_LESSTHAN:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_SHL)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}switch(a=this.compileExpression(T,i,1),s=this.currentType,this.currentType.kind){case 0:case 1:case 5:case 6:case 10:case 2:case 7:h=y.binary(l.BinaryOp.ShlI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.ShlI64,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.ShlI64:l.BinaryOp.ShlI32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.GREATERTHAN_GREATERTHAN_EQUALS:g=!0;case d.Token.GREATERTHAN_GREATERTHAN:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_SHR)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}switch(n=this.ensureSmallIntegerWrap(n,i),a=this.compileExpression(T,i,1),s=this.currentType,this.currentType.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.ShrI32,n,a);break;case 3:h=y.binary(l.BinaryOp.ShrI64,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.ShrI64:l.BinaryOp.ShrI32,n,a);break;case 5:case 6:case 10:case 7:h=y.binary(l.BinaryOp.ShrU32,n,a);break;case 8:h=y.binary(l.BinaryOp.ShrU64,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.ShrU64:l.BinaryOp.ShrU32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:g=!0;case d.Token.GREATERTHAN_GREATERTHAN_GREATERTHAN:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_SHR_U)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}switch(n=this.ensureSmallIntegerWrap(n,i),a=this.compileExpression(T,i,1),s=this.currentType,this.currentType.kind){case 5:case 6:case 10:h=y.binary(l.BinaryOp.ShrU32,n,a);case 0:case 1:case 2:case 7:h=y.binary(l.BinaryOp.ShrU32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.ShrU64,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.ShrU64:l.BinaryOp.ShrU32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.AMPERSAND_EQUALS:g=!0;case d.Token.AMPERSAND:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_AND)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"&",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 10:case 7:h=y.binary(l.BinaryOp.AndI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.AndI64,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.AndI64:l.BinaryOp.AndI32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.BAR_EQUALS:g=!0;case d.Token.BAR:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_OR)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"|",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 5:case 6:case 10:h=y.binary(l.BinaryOp.OrI32,n,a);break;case 2:case 7:h=y.binary(l.BinaryOp.OrI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.OrI64,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.OrI64:l.BinaryOp.OrI32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.CARET_EQUALS:g=!0;case d.Token.CARET:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){var x,A;if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_XOR)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"^",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 5:case 6:case 10:h=y.binary(l.BinaryOp.XorI32,n,a);break;case 2:case 7:h=y.binary(l.BinaryOp.XorI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.XorI64,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.XorI64:l.BinaryOp.XorI32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.AMPERSAND_AMPERSAND:var N=this.currentFlow,S=20&t;n=this.compileExpression(f,r.exceptVoid,S),i=this.currentType;var O=N.fork();if(this.currentFlow=O,O.inheritNonnullIfTrue(n),a=this.compileExpression(T,i,1|S),s=i,r==m.Type.bool||r==m.Type.void)a=this.performAutoreleasesWithValue(O,a,s),O.freeScopedLocals(),this.currentFlow=N,this.currentType=m.Type.bool,h=y.if(this.makeIsTrueish(n,i),this.makeIsTrueish(a,s),y.i32(0));else if(i.isManaged){var C=this.skippedAutoreleases.has(n),k=this.skippedAutoreleases.has(a),L=N.getTempLocal(i);n=y.local_tee(L.index,n);var R=!1;C!=k?C?(a=this.makeRetain(a),k=!0):R=!0:16&t||(a=this.moveAutorelease(a,O,N));var F=new Array;C&&F.unshift(this.makeRelease(y.local_get(L.index,i.toNativeType()))),a=this.performAutoreleasesWithValue(O,a,s,F),O.freeScopedLocals(),this.currentFlow=N,h=y.if(this.makeIsTrueish(n,i),a,R?this.makeRetain(y.local_get(L.index,i.toNativeType())):y.local_get(L.index,i.toNativeType())),(C||k)&&this.skippedAutoreleases.add(h),L&&N.freeTempLocal(L)}else if(a=this.performAutoreleasesWithValue(O,a,s),O.freeScopedLocals(),this.currentFlow=N,h=y.cloneExpression(n,!0,0))h=y.if(this.makeIsTrueish(n,this.currentType),a,h);else{var B=N.getTempLocal(i);N.canOverflow(n,i)||N.setLocalFlag(B.index,_.LocalFlags.WRAPPED),N.isNonnull(n,i)&&N.setLocalFlag(B.index,_.LocalFlags.NONNULL),h=y.if(this.makeIsTrueish(y.local_tee(B.index,n),i),a,y.local_get(B.index,i.toNativeType()))}this.currentType=i;break;case d.Token.BAR_BAR:N=this.currentFlow,S=20&t;n=this.compileExpression(f,r.exceptVoid,S),i=this.currentType;O=N.fork();if(this.currentFlow=O,O.inheritNonnullIfFalse(n),a=this.compileExpression(T,i,1|S),s=i,r==m.Type.bool||r==m.Type.void)a=this.performAutoreleasesWithValue(O,a,i),O.freeScopedLocals(),this.currentFlow=N,this.currentType=m.Type.bool,h=y.if(this.makeIsTrueish(n,i),y.i32(1),this.makeIsTrueish(a,s));else if(i.isManaged){C=this.skippedAutoreleases.has(n),k=this.skippedAutoreleases.has(a),L=N.getTempLocal(i);n=y.local_tee(L.index,n);var D=!1;C!=k?C?(a=this.makeRetain(a),k=!0):D=!0:16&t||(a=this.moveAutorelease(a,O,N));F=new Array;C&&F.unshift(this.makeRelease(y.local_get(L.index,i.toNativeType()))),a=this.performAutoreleasesWithValue(O,a,s,F),O.freeScopedLocals(),this.currentFlow=N,h=y.if(this.makeIsTrueish(n,i),D?this.makeRetain(y.local_get(L.index,i.toNativeType())):y.local_get(L.index,i.toNativeType()),a),(C||k)&&this.skippedAutoreleases.add(h),L&&N.freeTempLocal(L)}else if(a=this.performAutoreleasesWithValue(O,a,s),O.freeScopedLocals(),this.currentFlow=N,h=y.cloneExpression(n,!0,0))h=y.if(this.makeIsTrueish(n,i),h,a);else{B=N.getAndFreeTempLocal(i);N.canOverflow(n,i)||N.setLocalFlag(B.index,_.LocalFlags.WRAPPED),N.isNonnull(n,i)&&N.setLocalFlag(B.index,_.LocalFlags.NONNULL),h=y.if(this.makeIsTrueish(y.local_tee(B.index,n),i),y.local_get(B.index,i.toNativeType()),a)}this.currentType=i;break;default:assert(!1),h=this.module.unreachable()}if(!g)return h;var P=this.resolver,w=this.resolver.resolveExpression(f,this.currentFlow);return w?this.makeAssignment(w,h,f,P.currentThisExpression,P.currentElementExpression,r!=m.Type.void):y.unreachable()},r.prototype.compileUnaryOverload=function(e,r,t,n){return this.makeCallDirect(e,[t],n,!1)},r.prototype.compileBinaryOverload=function(e,r,t,n,i){var a;if(e.is(u.CommonFlags.INSTANCE)){var s=assert(e.parent);assert(s.kind==p.ElementKind.CLASS),a=e.signature.parameterTypes[0]}else a=e.signature.parameterTypes[1];var o=this.compileExpression(n,a,1);return this.makeCallDirect(e,[t,o],i)},r.prototype.compileAssignment=function(e,r,t){var n=this.program.resolver,i=this.currentFlow,a=n.resolveExpression(e,i);if(!a)return this.module.unreachable();var s,o=n.currentThisExpression,l=n.currentElementExpression;switch(a.kind){case p.ElementKind.GLOBAL:if(!this.compileGlobal(a))return this.module.unreachable();case p.ElementKind.FIELD:case p.ElementKind.LOCAL:s=a.type;break;case p.ElementKind.PROPERTY_PROTOTYPE:var u=a.setterPrototype;if(!u)return this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,e.range,a.internalName),this.module.unreachable();if(!(_=this.resolver.resolveFunction(u,null,f.makeMap(),h.ReportMode.REPORT)))return this.module.unreachable();assert(1==_.signature.parameterTypes.length),s=_.signature.parameterTypes[0];break;case p.ElementKind.PROPERTY:var _;if(!(_=a.setterInstance))return this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,e.range,a.internalName),this.module.unreachable();assert(1==_.signature.parameterTypes.length),s=_.signature.parameterTypes[0];break;case p.ElementKind.CLASS:if(l){var d=i.is(65536),y=a.lookupOverload(p.OperatorKind.INDEXED_SET,d);if(!y)return a.lookupOverload(p.OperatorKind.INDEXED_GET,d)?this.error(c.DiagnosticCode.Index_signature_in_type_0_only_permits_reading,e.range,a.internalName):this.error(c.DiagnosticCode.Index_signature_is_missing_in_type_0,e.range,a.internalName),this.module.unreachable();assert(2==y.signature.parameterTypes.length),s=y.signature.parameterTypes[1];break}default:return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}return assert(s!=m.Type.void),this.makeAssignment(a,this.compileExpression(r,s,17),e,o,l,t!=m.Type.void)},r.prototype.makeAssignment=function(e,r,t,n,i,a){var s=this.module,o=this.currentFlow;switch(e.kind){case p.ElementKind.LOCAL:return o.isLocalFlag(e.index,_.LocalFlags.CONSTANT,!0)?(this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,t.range,e.internalName),this.currentType=a?e.type:m.Type.void,s.unreachable()):this.makeLocalAssignment(e,r,a);case p.ElementKind.GLOBAL:return this.compileGlobal(e)?e.isAny(u.CommonFlags.CONST|u.CommonFlags.READONLY)?(this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,t.range,e.internalName),this.currentType=a?e.type:m.Type.void,s.unreachable()):this.makeGlobalAssignment(e,r,a):s.unreachable();case p.ElementKind.FIELD:var l=e.initializerNode;return!e.is(u.CommonFlags.READONLY)||o.actualFunction.is(u.CommonFlags.CONSTRUCTOR)||l?this.makeFieldAssignment(e,r,this.compileExpression(assert(n),this.options.usizeType),a):(this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,t.range,e.internalName),s.unreachable());case p.ElementKind.PROPERTY_PROTOTYPE:this.skippedAutoreleases.has(r)&&(r=this.makeAutorelease(r,o));var d=e.setterPrototype;if(!d)return this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,t.range,e.internalName),s.unreachable();if(!(g=this.resolver.resolveFunction(d,null,f.makeMap(),h.ReportMode.REPORT)))return s.unreachable();if(!a)return this.makeCallDirect(g,[r],t);var y=assert(e.getterPrototype);if(!(v=this.resolver.resolveFunction(y,null,f.makeMap(),h.ReportMode.REPORT)))return s.unreachable();var T=(L=v.signature.returnType).toNativeType();return s.block(null,[this.makeCallDirect(g,[r],t),this.makeCallDirect(v,null,t)],T);case p.ElementKind.PROPERTY:var g;if(this.skippedAutoreleases.has(r)&&(r=this.makeAutorelease(r,o)),!(g=e.setterInstance))return this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,t.range,e.internalName),s.unreachable();if(!a){var E=this.compileExpression(assert(n),this.options.usizeType);return this.makeCallDirect(g,[E,r],t)}T=(L=(v=assert(e.getterInstance)).signature.returnType).toNativeType();var v,b=this.compileExpression(assert(n),this.options.usizeType),I=o.getAndFreeTempLocal(L).index;return s.block(null,[this.makeCallDirect(g,[s.local_tee(I,b),r],t),this.makeCallDirect(v,[s.local_get(I,T)],t)],T);case p.ElementKind.CLASS:if(this.skippedAutoreleases.has(r)&&(r=this.makeAutorelease(r,o)),i){var x=o.is(65536),A=e.lookupOverload(p.OperatorKind.INDEXED_GET,x);if(!A)return this.error(c.DiagnosticCode.Index_signature_is_missing_in_type_0,t.range,e.internalName),s.unreachable();var N=e.lookupOverload(p.OperatorKind.INDEXED_SET,x);if(!N)return this.error(c.DiagnosticCode.Index_signature_in_type_0_only_permits_reading,t.range,e.internalName),this.currentType=a?A.signature.returnType:m.Type.void,s.unreachable();var S=e.type,O=(b=this.compileExpression(assert(n),this.options.usizeType),this.compileExpression(i,m.Type.i32,1));if(a){var C=o.getTempLocal(S),k=o.getAndFreeTempLocal(this.currentType),L=A.signature.returnType;return o.freeTempLocal(C),s.block(null,[this.makeCallDirect(N,[s.local_tee(C.index,b),s.local_tee(k.index,O),r],t),this.makeCallDirect(A,[s.local_get(C.index,C.type.toNativeType()),s.local_get(k.index,k.type.toNativeType())],t)],L.toNativeType())}return this.makeCallDirect(N,[b,O,r],t)}}return this.error(c.DiagnosticCode.Operation_not_supported,t.range),s.unreachable()},r.prototype.makeLocalAssignment=function(e,r,t){var n=e.type;assert(n!=m.Type.void);var i=this.currentFlow,a=e.index;if(n.is(512)&&(i.isNonnull(r,n)?i.setLocalFlag(a,_.LocalFlags.NONNULL):i.unsetLocalFlag(a,_.LocalFlags.NONNULL)),i.setLocalFlag(a,_.LocalFlags.WRITTENTO),n.isManaged){var s=this.module,o=n.toNativeType();return i.isAnyLocalFlag(a,_.LocalFlags.ANY_RETAINED)?this.skippedAutoreleases.has(r)?(r=this.makeSkippedRelease(s.local_get(a,o),r),t?(this.currentType=n,s.local_tee(a,r)):(this.currentType=m.Type.void,s.local_set(a,r))):(r=this.makeRetainRelease(s.local_get(a,o),r),t?(this.currentType=n,s.local_tee(a,r)):(this.currentType=m.Type.void,s.local_set(a,r))):(i.unsetLocalFlag(a,_.LocalFlags.CONDITIONALLY_RETAINED),i.setLocalFlag(a,_.LocalFlags.RETAINED),this.skippedAutoreleases.has(r)||(r=this.makeRetain(r)),t?(this.currentType=n,s.local_tee(a,r)):(this.currentType=m.Type.void,s.local_set(a,r)))}return n.is(36)&&(i.canOverflow(r,n)?i.unsetLocalFlag(a,_.LocalFlags.WRAPPED):i.setLocalFlag(a,_.LocalFlags.WRAPPED)),t?(this.currentType=n,this.module.local_tee(a,r)):(this.currentType=m.Type.void,this.module.local_set(a,r))},r.prototype.makeGlobalAssignment=function(e,r,t){var n=this.module,i=e.type;assert(i!=m.Type.void);var a=i.toNativeType();return i.isManaged?this.skippedAutoreleases.has(r)?t?(this.currentType=i,n.block(null,[n.global_set(e.internalName,this.makeSkippedRelease(n.global_get(e.internalName,a),r)),n.global_get(e.internalName,a)],a)):(this.currentType=m.Type.void,n.global_set(e.internalName,this.makeSkippedRelease(n.global_get(e.internalName,a),r))):t?(this.currentType=i,n.block(null,[n.global_set(e.internalName,this.makeRetainRelease(n.global_get(e.internalName,a),r)),n.global_get(e.internalName,a)],a)):(this.currentType=m.Type.void,n.global_set(e.internalName,this.makeRetainRelease(n.global_get(e.internalName,a),r))):(r=this.ensureSmallIntegerWrap(r,i),t?(this.currentType=i,n.block(null,[n.global_set(e.internalName,r),n.global_get(e.internalName,a)],a)):(this.currentType=m.Type.void,n.global_set(e.internalName,r)))},r.prototype.makeFieldAssignment=function(e,r,t,n){var i=this.module,a=this.currentFlow,s=e.type,o=s.toNativeType();assert(e.parent.kind==p.ElementKind.CLASS);var c=e.parent.type,l=c.toNativeType();if(s.isManaged&&c.isManaged){var u=a.getTempLocal(c);if(this.skippedAutoreleases.has(r)){if(n){var h=a.getAndFreeTempLocal(s);return a.canOverflow(r,s)||a.setLocalFlag(h.index,_.LocalFlags.WRAPPED),a.isNonnull(r,s)&&a.setLocalFlag(h.index,_.LocalFlags.NONNULL),a.freeTempLocal(u),this.currentType=s,i.block(null,[i.store(s.byteSize,i.local_tee(u.index,t),this.makeSkippedRelease(i.load(s.byteSize,s.is(1),i.local_get(u.index,l),o,e.memoryOffset),i.local_tee(h.index,r)),o,e.memoryOffset),i.local_get(h.index,o)],o)}return a.freeTempLocal(u),this.currentType=m.Type.void,i.store(s.byteSize,i.local_tee(u.index,t),this.makeSkippedRelease(i.load(s.byteSize,s.is(1),i.local_get(u.index,l),o,e.memoryOffset),r),o,e.memoryOffset)}if(n){h=a.getAndFreeTempLocal(s);return a.canOverflow(r,s)||a.setLocalFlag(h.index,_.LocalFlags.WRAPPED),a.isNonnull(r,s)&&a.setLocalFlag(h.index,_.LocalFlags.NONNULL),a.freeTempLocal(u),this.currentType=s,i.block(null,[i.store(s.byteSize,i.local_tee(u.index,t),this.makeRetainRelease(i.load(s.byteSize,s.is(1),i.local_get(u.index,l),o,e.memoryOffset),i.local_tee(h.index,r)),o,e.memoryOffset),i.local_get(h.index,o)],o)}return a.freeTempLocal(u),this.currentType=m.Type.void,i.store(s.byteSize,i.local_tee(u.index,t),this.makeRetainRelease(i.load(s.byteSize,s.is(1),i.local_get(u.index,l),o,e.memoryOffset),r),o,e.memoryOffset)}if(n){h=a.getAndFreeTempLocal(s);return a.canOverflow(r,s)||a.setLocalFlag(h.index,_.LocalFlags.WRAPPED),a.isNonnull(r,s)&&a.setLocalFlag(h.index,_.LocalFlags.NONNULL),this.currentType=s,i.block(null,[i.store(s.byteSize,t,i.local_tee(h.index,r),o,e.memoryOffset),i.local_get(h.index,o)],o)}return this.currentType=m.Type.void,i.store(s.byteSize,t,r,o,e.memoryOffset)},r.prototype.compileCallExpression=function(e,r,t){var n=this.module,i=this.currentFlow;if(e.expression.kind==y.NodeKind.SUPER){var a=this.currentFlow,s=a.actualFunction;if(!s.is(u.CommonFlags.CONSTRUCTOR))return this.error(c.DiagnosticCode.Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors,e.range),n.unreachable();var o=assert(s.parent);assert(o.kind==p.ElementKind.CLASS);var _=assert(o.base),h=assert(a.lookupLocal(u.CommonSymbols.this_)),d=this.options.nativeSizeType,T=this.compileCallDirect(this.ensureConstructor(_,e),e.arguments,e,n.if(n.local_get(h.index,d),n.local_get(h.index,d),this.makeRetain(this.makeAllocation(o))),16);assert(this.skippedAutoreleases.has(T));var g=[n.local_set(h.index,T)];return this.makeFieldInitialization(o,g),a.isAny(16448)?(this.error(c.DiagnosticCode._super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class,e.range),n.unreachable()):(a.set(192),this.currentType=m.Type.void,n.block(null,g))}var E,v,b=this.resolver.resolveExpression(e.expression,i);if(!b)return n.unreachable();switch(b.kind){case p.ElementKind.FUNCTION_PROTOTYPE:var I=b,x=e.typeArguments;if(I.hasDecorator(p.DecoratorFlags.BUILTIN))return this.compileCallExpressionBuiltin(I,e,r);var A=null;if(x){if(!I.is(u.CommonFlags.GENERIC))return this.error(c.DiagnosticCode.Type_0_is_not_generic,e.expression.range,I.internalName),n.unreachable();A=this.resolver.resolveFunctionInclTypeArguments(I,x,i.actualFunction.parent,f.makeMap(i.contextualTypeArguments),e)}else{if(I.is(u.CommonFlags.GENERIC)){for(var N=new Map,S=assert(I.typeParameterNodes),O=S.length,C=0;Cs&&!i)||(this.error(c.DiagnosticCode.Expected_0_arguments_but_got_1,n.range,s.toString(),r.toString()),!1)},r.prototype.compileCallDirect=function(e,r,t,n,i){void 0===n&&(n=0),void 0===i&&(i=0);var a=r.length,s=e.signature;if(!this.checkCallSignature(s,a,0!=n,t))return this.currentType=s.returnType,this.module.unreachable();if(e.hasDecorator(p.DecoratorFlags.INLINE)){if(assert(!e.is(u.CommonFlags.TRAMPOLINE)),!this.currentInlineFunctions.includes(e)){this.currentInlineFunctions.push(e);var o=s.parameterTypes;assert(a<=o.length);for(var l=new Array(a),_=0;_=0;--f){var T=r[f],g=o[f],E=h.addScopedLocal(s.getParameterName(f),g,y);_.findUsedLocals(T,y),l.canOverflow(T,g)||h.setLocalFlag(E.index,_.LocalFlags.WRAPPED),h.isNonnull(T,g)&&h.setLocalFlag(E.index,_.LocalFlags.NONNULL),g.isManaged&&(this.skippedAutoreleases.has(T)||(T=this.makeRetain(T)),h.setLocalFlag(E.index,_.LocalFlags.RETAINED)),d.unshift(i.local_set(E.index,T))}if(t){var v=assert(e.parent);assert(v.kind==p.ElementKind.CLASS);var b=assert(e.signature.thisType),I=h.addScopedLocal(u.CommonSymbols.this_,b,y);d.unshift(i.local_set(I.index,t));var x=v.base;x&&h.addScopedAlias(u.CommonSymbols.super_,x.type,I.index)}else assert(!e.signature.thisType);this.currentFlow=h;for(f=a;fa){var s=t.toNativeType(),o=e.getAndFreeTempLocal(t);e.canOverflow(r,t)||e.setLocalFlag(o.index,_.LocalFlags.WRAPPED),e.isNonnull(r,t)&&e.setLocalFlag(o.index,_.LocalFlags.NONNULL);var c=this.module;return n[a-1]=c.local_set(o.index,r),n.push(c.local_get(o.index,s)),c.block(null,n,s)}return n.length>1?(n[a-1]=r,this.module.block(null,n,t.toNativeType())):r},r.prototype.finishAutoreleases=function(e,r){var t,n,i=this.module;if(e.is(32768)){for(var s=void 0;s=e.parent;)e=s;this.performAutoreleases(e,r,!1)}else try{for(var o=a(e.parentFunction.localsByIndex),c=o.next();!c.done;c=o.next()){var l=c.value,u=l.index;e.isAnyLocalFlag(u,_.LocalFlags.ANY_RETAINED)&&(e.unsetLocalFlag(u,_.LocalFlags.ANY_RETAINED),r.push(this.makeRelease(i.local_get(u,l.type.toNativeType()))))}}catch(e){t={error:e}}finally{try{c&&!c.done&&(n=o.return)&&n.call(o)}finally{if(t)throw t.error}}},r.prototype.makeCallDirect=function(e,r,t,n,i){void 0===n&&(n=!1),void 0===i&&(i=!1),e.hasDecorator(p.DecoratorFlags.INLINE)&&this.warning(c.DiagnosticCode.TODO_Cannot_inline_inferred_calls_and_specific_internals_yet,t.range,e.internalName);var a=r?r.length:0,s=a,o=e.signature.requiredParameters,l=e.signature.parameterTypes.length,_=l;e.is(u.CommonFlags.INSTANCE)&&(++o,++_,--s),assert(a>=o);var h=this.module;if(!this.compileFunction(e))return h.unreachable();var d=e.signature.returnType,f=e.is(u.CommonFlags.MODULE_IMPORT);if(a<_){r||((r=new Array(_)).length=0);var T=e.signature.parameterTypes,g=e.prototype.signatureNode.parameters;assert(g.length==T.length);for(var E=!0,v=s;v=s),this.ensureFunctionType(e.parameterTypes,e.returnType,e.thisType);var l=this.module;if(iT)return this.error(c.DiagnosticCode.Expected_0_arguments_but_got_1,e.range,T.toString(),h.toString()),this.module.unreachable();for(var g=new Array(h),E=0;E=0),S.is(512)&&i.isLocalFlag(O,_.LocalFlags.NONNULL,!1)&&(S=S.nonNullableType),this.currentType=S,this.module.local_get(O,S.toNativeType());case p.ElementKind.GLOBAL:if(!this.compileGlobal(N))return this.module.unreachable();S=N.type;return assert(S!=m.Type.void),N.is(u.CommonFlags.INLINED)?this.compileInlineConstant(N,r,t):(this.currentType=S,this.module.global_get(N.internalName,S.toNativeType()));case p.ElementKind.ENUMVALUE:return N.is(u.CommonFlags.COMPILED)?(this.currentType=m.Type.i32,N.is(u.CommonFlags.INLINED)?(assert(1==N.constantValueKind),this.module.i32(i64_low(N.constantIntegerValue))):this.module.global_get(N.internalName,l.NativeType.I32)):(this.error(c.DiagnosticCode.A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums,e.range),this.currentType=m.Type.i32,this.module.unreachable());case p.ElementKind.FUNCTION_PROTOTYPE:var C=this.resolver.resolveFunction(N,null,f.makeMap(i.contextualTypeArguments));if(!C||!this.compileFunction(C))return n.unreachable();var k=this.ensureFunctionTableEntry(C);return this.currentType=C.signature.type,this.module.i32(k)}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()},r.prototype.compileInstanceOfExpression=function(e,r,t){var n=this.module,i=this.compileExpression(e.expression,this.options.usizeType),a=this.currentType,s=this.resolver.resolveType(e.isType,this.currentFlow.actualFunction);if(this.currentType=m.Type.bool,!s)return n.unreachable();if(!s.is(256))return n.block(null,[n.drop(i),n.i32(a==s?1:0)],l.NativeType.I32);if(!a.is(256))return n.block(null,[n.drop(i),n.i32(0)],l.NativeType.I32);var o=a.toNativeType();if(a.is(512)&&!s.is(512)){if(a.nonNullableType.isAssignableTo(s))return n.binary(o==l.NativeType.I64?l.BinaryOp.NeI64:l.BinaryOp.NeI32,i,a.toNativeZero(n));if(s.isAssignableTo(a)){var u=this.program;if(!a.isUnmanaged&&!s.isUnmanaged){var p=this.currentFlow.getAndFreeTempLocal(a),_=assert(u.instanceofInstance);return this.compileFunction(_),n.if(n.unary(o==l.NativeType.I64?l.UnaryOp.EqzI64:l.UnaryOp.EqzI32,n.local_tee(p.index,i)),n.i32(0),this.makeCallDirect(_,[n.local_get(p.index,o),n.i32(s.classReference.id)],e))}this.error(c.DiagnosticCode.Operation_not_supported,e.range)}}else{if(a.isAssignableTo(s))return n.block(null,[this.convertExpression(i,a,m.Type.void,!1,!1,e.expression),n.i32(1)],l.NativeType.I32);if(s.isAssignableTo(a)){u=this.program;if(!a.isUnmanaged&&!s.isUnmanaged){p=this.currentFlow.getAndFreeTempLocal(a),_=assert(u.instanceofInstance);return this.compileFunction(_),n.if(n.unary(o==l.NativeType.I64?l.UnaryOp.EqzI64:l.UnaryOp.EqzI32,n.local_tee(p.index,i)),n.i32(0),this.makeCallDirect(_,[n.local_get(p.index,o),n.i32(s.classReference.id)],e))}this.error(c.DiagnosticCode.Operation_not_supported,e.range)}}return n.block(null,[n.drop(i),n.i32(0)],l.NativeType.I32)},r.prototype.compileLiteralExpression=function(e,r,t,n){void 0===n&&(n=!1);var i=this.module;switch(e.literalKind){case y.LiteralKind.ARRAY:assert(!n);var a=r.classReference;return a&&a.prototype==this.program.arrayPrototype?this.compileArrayLiteral(assert(a.typeArguments)[0],e.elementExpressions,t,e):(this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable());case y.LiteralKind.FLOAT:var s=e.value;return n&&(s=-s),r==m.Type.f32?i.f32(s):(this.currentType=m.Type.f64,i.f64(s));case y.LiteralKind.INTEGER:var o=e.value;n&&(o=i64_sub(i64_new(0),o));var l=this.resolver.determineIntegerLiteralType(o,r);switch(this.currentType=l,l.kind){case 4:if(!this.options.isWasm64)return i.i32(i64_low(o));case 3:return i.i64(i64_low(o),i64_high(o));case 9:if(!this.options.isWasm64)return i.i32(i64_low(o));case 8:return i.i64(i64_low(o),i64_high(o));case 11:return i.f32(i64_to_f32(o));case 12:return i.f64(i64_to_f64(o));default:return i.i32(i64_low(o))}case y.LiteralKind.STRING:return assert(!n),this.compileStringLiteral(e);case y.LiteralKind.OBJECT:return assert(!n),this.compileObjectLiteral(e,r)}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.currentType=r,i.unreachable()},r.prototype.compileStringLiteral=function(e){return this.ensureStaticString(e.value)},r.prototype.compileArrayLiteral=function(e,r,t,n){for(var i=this.module,a=this.program,s=assert(a.arrayPrototype),o=assert(this.resolver.resolveClass(s,[e])),u=assert(a.arrayBufferInstance),_=o.type,h=this.currentFlow,d=h.getTempLocal(_),y=h.getTempLocal(u.type),m=r.length,f=new Array(m),T=!0,g=e.toNativeType(),E=0;E",r.toString()),t.unreachable();var i=n.constructorInstance;if(i){if(i.signature.requiredParameters)return this.error(c.DiagnosticCode.Constructor_of_class_0_must_not_require_any_arguments,e.range,n.toString()),t.unreachable();if(i.is(u.CommonFlags.PRIVATE))return this.error(c.DiagnosticCode.Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration,e.range,n.toString()),t.unreachable();if(i.is(u.CommonFlags.PROTECTED))return this.error(c.DiagnosticCode.Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration,e.range,n.toString()),t.unreachable()}var a=e.names,s=a.length,o=e.values,l=n.members,_=!1,h=new Array(s+2),d=this.currentFlow.getAutoreleaseLocal(this.options.usizeType);assert(s==o.length);for(var y=0,m=s;yI)for(T=I;T=0);var _=this.compileExpression(assert(this.resolver.currentThisExpression),this.options.usizeType);return this.currentType=a.type,n.load(a.type.byteSize,a.type.is(5),_,a.type.toNativeType(),a.memoryOffset);case p.ElementKind.PROPERTY_PROTOTYPE:var h=a.getterPrototype;if(h){var d=this.resolver.resolveFunction(h,null);if(d)return this.compileCallDirect(d,[],e,0)}return n.unreachable();case p.ElementKind.PROPERTY:var y=assert(a.getterInstance);return this.compileCallDirect(y,[],e,this.compileExpression(assert(this.resolver.currentThisExpression),this.options.usizeType));case p.ElementKind.FUNCTION_PROTOTYPE:return this.error(c.DiagnosticCode.Cannot_access_method_0_without_calling_it_as_it_requires_this_to_be_set,e.range,a.name),n.unreachable()}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),n.unreachable()},r.prototype.compileTernaryExpression=function(e,r,t){var n=e.ifThen,i=e.ifElse,a=this.currentFlow,s=this.module.precomputeExpression(this.makeIsTrueish(this.compileExpression(e.condition,m.Type.bool),this.currentType));if(l.getExpressionId(s)==l.ExpressionId.Const&&l.getExpressionType(s)==l.NativeType.I32)return l.getConstValueI32(s)?this.compileExpression(n,r):this.compileExpression(i,r);var o=16&t,u=a.fork();this.currentFlow=u;var p=this.compileExpression(n,r,o),_=this.currentType,h=this.skippedAutoreleases.has(p),d=a.fork();this.currentFlow=d;var y=this.compileExpression(i,r,o),f=this.currentType,T=this.skippedAutoreleases.has(y),g=m.Type.commonDenominator(_,f,!1);if(!g)return this.error(c.DiagnosticCode.Type_0_is_not_assignable_to_type_1,i.range,f.toString(),_.toString()),this.currentType=r,this.module.unreachable();p=this.convertExpression(p,_,g,!1,!1,n),y=this.convertExpression(y,f,g,!1,!1,i),this.currentType=g,h!=T?h?(y=this.makeRetain(y),T=!0):(p=this.makeRetain(p),h=!0):!h&&g.isManaged&&(p=this.moveAutorelease(p,u,a),y=this.moveAutorelease(y,d,a)),p=this.performAutoreleasesWithValue(u,p,g),u.freeScopedLocals(),y=this.performAutoreleasesWithValue(d,y,g),d.freeScopedLocals(),this.currentFlow=a,a.inheritMutual(u,d);var E=this.module.if(s,p,y);return assert(h==T),h&&this.skippedAutoreleases.add(E),E},r.prototype.compileUnaryPostfixExpression=function(e,r,t){var n=this.module,i=this.currentFlow,a=this.compileExpression(e.operand,r.exceptVoid,0);if(l.getExpressionId(a)==l.ExpressionId.Unreachable)return a;var s,o=null;switch(r!=m.Type.void&&(o=i.getTempLocal(this.currentType),a=n.local_tee(o.index,a)),e.operator){case d.Token.PLUS_PLUS:switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:s=n.binary(l.BinaryOp.AddI32,a,n.i32(1));break;case 9:if(this.currentType.is(256)){if(_=this.currentType.classReference)if(h=_.lookupOverload(p.OperatorKind.POSTFIX_INC)){s=this.compileUnaryOverload(h,e.operand,a,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),n.unreachable()}case 4:var u=this.options;s=n.binary(u.isWasm64?l.BinaryOp.AddI64:l.BinaryOp.AddI32,a,this.currentType.toNativeOne(n));break;case 3:case 8:s=n.binary(l.BinaryOp.AddI64,a,n.i64(1));break;case 11:s=n.binary(l.BinaryOp.AddF32,a,n.f32(1));break;case 12:s=n.binary(l.BinaryOp.AddF64,a,n.f64(1));break;default:return assert(!1),n.unreachable()}break;case d.Token.MINUS_MINUS:switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:s=n.binary(l.BinaryOp.SubI32,a,n.i32(1));break;case 9:if(this.currentType.is(256)){var _,h;if(_=this.currentType.classReference)if(h=_.lookupOverload(p.OperatorKind.POSTFIX_DEC)){s=this.compileUnaryOverload(h,e.operand,a,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),n.unreachable()}case 4:u=this.options;s=n.binary(u.isWasm64?l.BinaryOp.SubI64:l.BinaryOp.SubI32,a,this.currentType.toNativeOne(n));break;case 3:case 8:s=n.binary(l.BinaryOp.SubI64,a,n.i64(1));break;case 11:s=n.binary(l.BinaryOp.SubF32,a,n.f32(1));break;case 12:s=n.binary(l.BinaryOp.SubF64,a,n.f64(1));break;default:return assert(!1),n.unreachable()}break;default:return assert(!1),n.unreachable()}var y=this.resolver,f=y.resolveExpression(e.operand,i);if(!o)return this.currentType=m.Type.void,f?this.makeAssignment(f,s,e.operand,y.currentThisExpression,y.currentElementExpression,!1):n.unreachable();if(!f)return n.unreachable();var T=this.makeAssignment(f,s,e.operand,y.currentThisExpression,y.currentElementExpression,!1);this.currentType=o.type,i.freeTempLocal(o);var g=o.type.toNativeType();return n.block(null,[T,n.local_get(o.index,g)],g)},r.prototype.compileUnaryPrefixExpression=function(e,r,t){var n,i=this.module,a=!1;switch(e.operator){case d.Token.PLUS:if(n=this.compileExpression(e.operand,r.exceptVoid,0),this.currentType.is(256)){if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.PLUS)){n=this.compileUnaryOverload(o,e.operand,n,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable()}break;case d.Token.MINUS:if(e.operand.kind==y.NodeKind.LITERAL&&(e.operand.literalKind==y.LiteralKind.INTEGER||e.operand.literalKind==y.LiteralKind.FLOAT)){n=this.compileLiteralExpression(e.operand,r,0,!0),this.options.sourceMap&&this.addDebugLocation(n,e.range);break}if(n=this.compileExpression(e.operand,r.exceptVoid,0),this.currentType.is(256)){if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.MINUS)){n=this.compileUnaryOverload(o,e.operand,n,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable()}switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:n=i.binary(l.BinaryOp.SubI32,i.i32(0),n);break;case 9:case 4:n=i.binary(this.options.isWasm64?l.BinaryOp.SubI64:l.BinaryOp.SubI32,this.currentType.toNativeZero(i),n);break;case 3:case 8:n=i.binary(l.BinaryOp.SubI64,i.i64(0),n);break;case 11:n=i.unary(l.UnaryOp.NegF32,n);break;case 12:n=i.unary(l.UnaryOp.NegF64,n);break;default:assert(!1),n=i.unreachable()}break;case d.Token.PLUS_PLUS:if(a=!0,n=this.compileExpression(e.operand,r.exceptVoid,0),this.currentType.is(256)){if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.PREFIX_INC)){n=this.compileUnaryOverload(o,e.operand,n,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable()}switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:n=i.binary(l.BinaryOp.AddI32,n,this.module.i32(1));break;case 9:case 4:n=i.binary(this.options.isWasm64?l.BinaryOp.AddI64:l.BinaryOp.AddI32,n,this.currentType.toNativeOne(i));break;case 3:case 8:n=i.binary(l.BinaryOp.AddI64,n,i.i64(1));break;case 11:n=i.binary(l.BinaryOp.AddF32,n,i.f32(1));break;case 12:n=i.binary(l.BinaryOp.AddF64,n,i.f64(1));break;default:assert(!1),n=i.unreachable()}break;case d.Token.MINUS_MINUS:if(a=!0,n=this.compileExpression(e.operand,r.exceptVoid,0),this.currentType.is(256)){if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.PREFIX_DEC)){n=this.compileUnaryOverload(o,e.operand,n,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable()}switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:n=i.binary(l.BinaryOp.SubI32,n,i.i32(1));break;case 9:case 4:n=i.binary(this.options.isWasm64?l.BinaryOp.SubI64:l.BinaryOp.SubI32,n,this.currentType.toNativeOne(i));break;case 3:case 8:n=i.binary(l.BinaryOp.SubI64,n,i.i64(1));break;case 11:n=i.binary(l.BinaryOp.SubF32,n,i.f32(1));break;case 12:n=i.binary(l.BinaryOp.SubF64,n,i.f64(1));break;default:assert(!1),n=i.unreachable()}break;case d.Token.EXCLAMATION:if(n=this.compileExpression(e.operand,r.exceptVoid,0),this.currentType.is(256))if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.NOT)){n=this.compileUnaryOverload(o,e.operand,n,e);break}n=this.makeIsFalseish(n,this.currentType),this.currentType=m.Type.bool;break;case d.Token.TILDE:if(n=this.compileExpression(e.operand,r==m.Type.void?m.Type.i32:r.is(8)?m.Type.i64:r,0),this.currentType.is(256)){var s,o;if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.BITWISE_NOT)){n=this.compileUnaryOverload(o,e.operand,n,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable()}switch(n=this.convertExpression(n,this.currentType,this.currentType.intType,!1,!1,e.operand),this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:n=i.binary(l.BinaryOp.XorI32,n,i.i32(-1));break;case 9:case 4:n=i.binary(this.options.isWasm64?l.BinaryOp.XorI64:l.BinaryOp.XorI32,n,this.currentType.toNativeNegOne(i));break;case 3:case 8:n=i.binary(l.BinaryOp.XorI64,n,i.i64(-1,-1));break;default:assert(!1),n=i.unreachable()}break;case d.Token.TYPEOF:return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable();default:return assert(!1),i.unreachable()}if(!a)return n;var u=this.resolver,_=u.resolveExpression(e.operand,this.currentFlow);return _?this.makeAssignment(_,n,e.operand,u.currentThisExpression,u.currentElementExpression,r!=m.Type.void):i.unreachable()},r.prototype.ensureSmallIntegerWrap=function(e,r){var t=this.module,n=this.currentFlow;switch(r.kind){case 0:n.canOverflow(e,r)&&(e=this.options.hasFeature(1)?t.unary(l.UnaryOp.ExtendI8ToI32,e):t.binary(l.BinaryOp.ShrI32,t.binary(l.BinaryOp.ShlI32,e,t.i32(24)),t.i32(24)));break;case 1:n.canOverflow(e,r)&&(e=this.options.hasFeature(1)?t.unary(l.UnaryOp.ExtendI16ToI32,e):t.binary(l.BinaryOp.ShrI32,t.binary(l.BinaryOp.ShlI32,e,t.i32(16)),t.i32(16)));break;case 5:n.canOverflow(e,r)&&(e=t.binary(l.BinaryOp.AndI32,e,t.i32(255)));break;case 6:n.canOverflow(e,r)&&(e=t.binary(l.BinaryOp.AndI32,e,t.i32(65535)));break;case 10:n.canOverflow(e,r)&&(e=t.binary(l.BinaryOp.NeI32,e,t.i32(0)))}return e},r.prototype.addDebugLocation=function(e,r){var t=this.currentFlow.parentFunction,n=r.source;n.debugInfoIndex<0&&(n.debugInfoIndex=this.module.addDebugInfoFile(n.normalizedPath)),r.debugInfoRef=e,t.debugLocations.push(r)},r.prototype.makeIsFalseish=function(e,r){var t=this.module;switch(r.kind){case 0:case 1:case 5:case 6:case 10:e=this.ensureSmallIntegerWrap(e,r);case 2:case 7:return t.unary(l.UnaryOp.EqzI32,e);case 3:case 8:return t.unary(l.UnaryOp.EqzI64,e);case 9:this.skippedAutoreleases.has(e)&&(e=this.makeAutorelease(e));case 4:return t.unary(64==r.size?l.UnaryOp.EqzI64:l.UnaryOp.EqzI32,e);case 11:return t.binary(l.BinaryOp.EqF32,e,t.f32(0));case 12:return t.binary(l.BinaryOp.EqF64,e,t.f64(0));default:return assert(!1),t.i32(1)}},r.prototype.makeIsTrueish=function(e,r){var t=this.module;switch(r.kind){case 0:case 1:case 5:case 6:e=this.ensureSmallIntegerWrap(e,r);case 10:case 2:case 7:return e;case 3:case 8:return t.binary(l.BinaryOp.NeI64,e,t.i64(0));case 9:this.skippedAutoreleases.has(e)&&(e=this.makeAutorelease(e));case 4:return 64==r.size?t.binary(l.BinaryOp.NeI64,e,t.i64(0)):e;case 11:return t.binary(l.BinaryOp.NeF32,e,t.f32(0));case 12:return t.binary(l.BinaryOp.NeF64,e,t.f64(0));default:return assert(!1),t.i32(0)}},r.prototype.makeAllocation=function(e){var r=this.program;assert(e.program==r);var t=this.module,n=this.options;this.currentType=e.type;var i=r.allocInstance;return this.compileFunction(i),t.call(i.internalName,[n.isWasm64?t.i64(e.currentMemoryOffset):t.i32(e.currentMemoryOffset),t.i32(e.hasDecorator(p.DecoratorFlags.UNMANAGED)?0:e.id)],n.nativeSizeType)},r.prototype.makeFieldInitialization=function(e,r){var t,n;void 0===r&&(r=[]);var i=e.members;if(!i)return[];var s=this.module,o=this.currentFlow,c=o.is(32768),l=c?assert(o.lookupLocal(u.CommonSymbols.this_)).index:0,_=this.options.nativeSizeType;try{for(var h=a(i.values()),d=h.next();!d.done;d=h.next()){var y=d.value;if(y.kind==p.ElementKind.FIELD&&y.parent==e){var m=y;assert(!m.isAny(u.CommonFlags.CONST));var f=m.type,T=f.toNativeType(),g=m.prototype.initializerNode;if(g){var E=this.compileExpression(g,f,17);f.isManaged&&!this.skippedAutoreleases.has(E)&&(E=this.makeRetain(E)),r.push(s.store(f.byteSize,s.local_get(l,_),E,T,m.memoryOffset))}else{var v=m.prototype.parameterIndex;r.push(s.store(f.byteSize,s.local_get(l,_),v>=0?s.local_get(c?assert(o.lookupLocal(m.name)).index:1+v,T):f.toNativeZero(s),T,m.memoryOffset))}}}}catch(e){t={error:e}}finally{try{d&&!d.done&&(n=h.return)&&n.call(h)}finally{if(t)throw t.error}}return r},r.prototype.makeInstanceOfClass=function(e,r){var t=this.module,n=this.currentFlow,i=n.getTempLocal(m.Type.i32),a=t.load(4,!1,t.binary(l.BinaryOp.SubI32,e,t.i32(this.program.runtimeHeaderSize)),l.NativeType.I32),s="instanceof_"+r.name+"|"+n.pushBreakLabel(),o=[];return o.push(t.drop(t.br(s,t.binary(l.BinaryOp.EqI32,t.local_tee(i.index,a),t.i32(r.id)),t.i32(1)))),o.push(t.i32(0)),n.freeTempLocal(i),n.popBreakLabel(),t.block(s,o,l.NativeType.I32)},r}(c.DiagnosticEmitter);function b(e,r){if(g=r.range.source.simplePath,E=p.mangleInternalName(e.name,e.parent,e.is(u.CommonFlags.INSTANCE),!0),e.hasDecorator(p.DecoratorFlags.EXTERNAL)){var t=e.program,n=assert(y.findDecorator(y.DecoratorKind.EXTERNAL,r.decorators)),i=n.arguments;if(i&&i.length){var a=i[0];a.kind==y.NodeKind.LITERAL&&a.literalKind==y.LiteralKind.STRING?(E=a.value,i.length>=2&&((a=i[1]).kind==y.NodeKind.LITERAL&&a.literalKind==y.LiteralKind.STRING?(g=E,E=a.value,i.length>2&&t.error(c.DiagnosticCode.Expected_0_arguments_but_got_1,n.range,"2",i.length.toString())):t.error(c.DiagnosticCode.String_literal_expected,a.range))):t.error(c.DiagnosticCode.String_literal_expected,a.range)}else t.error(c.DiagnosticCode.Expected_at_least_0_arguments_but_got_1,n.range,"1","0")}}function I(e,r,t){var n=r.length;if(0==n)return e.nop();if(1==n){var i=r[0];if(l.getExpressionType(i)==t)return i;if(l.getExpressionId(i)==l.ExpressionId.Block){for(var a=l.getBlockChildCount(i),s=new Array(a),o=0;o=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},i=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0});var a,s=t(11),o=t(2),c=t(5),l=t(6),u=t(4),p=t(3),_=t(10),h=t(9),d=t(0),y=t(1);function m(e,r,t,n,i,s,d){void 0===d&&(d=!1);var m=e.module,g=!1;switch(r.internalName){case a.isInteger:var S=E(e,t,n,s);return e.currentType=l.Type.bool,S?S.is(4)&&!S.is(256)?m.i32(1):m.i32(0):m.unreachable();case a.isFloat:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?S.is(8)?m.i32(1):m.i32(0):m.unreachable();case a.isBoolean:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?S==l.Type.bool?m.i32(1):m.i32(0):m.unreachable();case a.isSigned:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?S.is(1)?m.i32(1):m.i32(0):m.unreachable();case a.isReference:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?S.is(256)?m.i32(1):m.i32(0):m.unreachable();case a.isString:S=E(e,t,n,s);if(e.currentType=l.Type.bool,!S)return m.unreachable();if(B=S.classReference){var O=e.program.stringInstance;if(O&&B.isAssignableTo(O))return m.i32(1)}return m.i32(0);case a.isArray:S=E(e,t,n,s);if(e.currentType=l.Type.bool,!S)return m.unreachable();if(!(De=S.classReference))return m.i32(0);var C=De.prototype;return m.i32(C.extends(e.program.arrayPrototype)?1:0);case a.isArrayLike:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?(De=S.classReference)?m.i32(De.isArrayLike?1:0):m.i32(0):m.unreachable();case a.isFunction:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?m.i32(S.signatureReference?1:0):m.unreachable();case a.isNullable:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?m.i32(S.is(512)?1:0):m.unreachable();case a.isDefined:if(e.currentType=l.Type.bool,x(t,s,r)|A(n,1,s,e))return m.unreachable();var k=e.resolver.resolveExpression(n[0],e.currentFlow,l.Type.void,h.ReportMode.SWALLOW);return m.i32(k?1:0);case a.isConstant:if(e.currentType=l.Type.bool,x(t,s,r)|A(n,1,s,e))return m.unreachable();var L=e.compileExpression(n[0],l.Type.auto);return e.currentType=l.Type.bool,m.i32(u.getExpressionId(L)==u.ExpressionId.Const?1:0);case a.isManaged:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?m.i32(S.isManaged?1:0):m.unreachable();case a.sizeof:if(e.currentType=e.options.usizeType,b(t,s,e)|A(n,0,s,e))return m.unreachable();var R=t[0].byteSize,L=void 0;return e.options.isWasm64?i.is(4)&&i.size<=32?(e.currentType=l.Type.u32,L=m.i32(R)):L=m.i64(R,0):i.is(4)&&64==i.size?(e.currentType=l.Type.u64,L=m.i64(R,0)):L=m.i32(R),L;case a.alignof:if(e.currentType=e.options.usizeType,b(t,s,e)|A(n,0,s,e))return m.unreachable();R=t[0].byteSize;assert(y.isPowerOf2(R));var F=ctz(R);L=void 0;return e.options.isWasm64?i.is(4)&&i.size<=32?(e.currentType=l.Type.u32,L=m.i32(F)):L=m.i64(F,0):i.is(4)&&64==i.size?(e.currentType=l.Type.u64,L=m.i64(F,0)):L=m.i32(F),L;case a.offsetof:if(e.currentType=e.options.usizeType,b(t,s,e)|N(n,0,1,s,e))return m.unreachable();var B;if(!(B=t[0].classReference))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();var D=void 0;if(n.length){if(n[0].kind!=c.NodeKind.LITERAL||n[0].literalKind!=c.LiteralKind.STRING)return e.error(o.DiagnosticCode.String_literal_expected,n[0].range),m.unreachable();var P=n[0].value,w=B.members?B.members.get(P):null;if(!w||w.kind!=p.ElementKind.FIELD)return e.error(o.DiagnosticCode.Type_0_has_no_property_1,n[0].range,B.internalName,P),m.unreachable();D=w.memoryOffset}else D=B.currentMemoryOffset;return e.options.isWasm64?i.is(4)&&i.size<=32?(e.currentType=l.Type.u32,m.i32(D)):m.i64(D):i.is(4)&&64==i.size?(e.currentType=l.Type.u64,m.i64(D)):m.i32(D);case a.clz:case a.ctz:case a.popcnt:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();var U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.i32,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();var M=-1;switch(r.internalName){case a.clz:switch(S.kind){case 10:case 0:case 5:case 1:case 6:case 2:case 7:M=u.UnaryOp.ClzI32;break;case 9:case 4:M=e.options.isWasm64?u.UnaryOp.ClzI64:u.UnaryOp.ClzI32;break;case 3:case 8:M=u.UnaryOp.ClzI64}break;case a.ctz:switch(S.kind){case 10:case 0:case 5:case 1:case 6:case 2:case 7:M=u.UnaryOp.CtzI32;break;case 9:case 4:M=e.options.isWasm64?u.UnaryOp.CtzI64:u.UnaryOp.CtzI32;break;case 3:case 8:M=u.UnaryOp.CtzI64}break;case a.popcnt:switch(e.currentType.kind){case 10:case 0:case 5:case 1:case 6:case 2:case 7:M=u.UnaryOp.PopcntI32;break;case 9:case 4:M=e.options.isWasm64?u.UnaryOp.PopcntI64:u.UnaryOp.PopcntI32;break;case 3:case 8:M=u.UnaryOp.PopcntI64}}return-1==M?(e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable()):m.unary(M,U);case a.rotl:if(I(t,s,e,!0)|A(n,2,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.i32,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();var V=e.compileExpression(n[1],S,1);L=void 0;switch(S.kind){case 0:case 1:case 5:case 6:case 10:L=e.ensureSmallIntegerWrap(m.binary(u.BinaryOp.RotlI32,U,V),S);case 2:case 7:L=m.binary(u.BinaryOp.RotlI32,U,V);break;case 9:case 4:L=m.binary(e.options.isWasm64?u.BinaryOp.RotlI64:u.BinaryOp.RotlI32,U,V);break;case 3:case 8:L=m.binary(u.BinaryOp.RotlI64,U,V);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.rotr:if(I(t,s,e,!0)|A(n,2,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.i32,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();V=e.compileExpression(n[1],S,1),L=void 0;switch(S.kind){case 0:case 1:case 5:case 6:case 10:L=e.ensureSmallIntegerWrap(m.binary(u.BinaryOp.RotrI32,U,V),S);break;case 2:case 7:L=m.binary(u.BinaryOp.RotrI32,U,V);break;case 9:case 4:L=m.binary(e.options.isWasm64?u.BinaryOp.RotrI64:u.BinaryOp.RotrI32,U,V);break;case 3:case 8:L=m.binary(u.BinaryOp.RotrI64,U,V);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.abs:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.f64,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();L=void 0;switch(S.kind){case 0:case 1:case 2:var G=(H=e.currentFlow).getTempLocal(l.Type.i32),K=H.getAndFreeTempLocal(l.Type.i32).index,z=G.index;L=m.binary(u.BinaryOp.XorI32,m.binary(u.BinaryOp.AddI32,m.local_tee(K,m.binary(u.BinaryOp.ShrI32,m.local_tee(z,U),m.i32(31))),m.local_get(z,u.NativeType.I32)),m.local_get(K,u.NativeType.I32)),H.freeTempLocal(G);break;case 4:var Y=e.options,H=e.currentFlow,W=Y.isWasm64;G=H.getTempLocal(Y.usizeType),K=H.getAndFreeTempLocal(Y.usizeType).index,z=G.index;L=m.binary(W?u.BinaryOp.XorI64:u.BinaryOp.XorI32,m.binary(W?u.BinaryOp.AddI64:u.BinaryOp.AddI32,m.local_tee(K,m.binary(W?u.BinaryOp.ShrI64:u.BinaryOp.ShrI32,m.local_tee(z,U),W?m.i64(63):m.i32(31))),m.local_get(z,Y.nativeSizeType)),m.local_get(K,Y.nativeSizeType)),H.freeTempLocal(G);break;case 3:G=(H=e.currentFlow).getTempLocal(l.Type.i64),K=H.getAndFreeTempLocal(l.Type.i64).index,z=G.index;L=m.binary(u.BinaryOp.XorI64,m.binary(u.BinaryOp.AddI64,m.local_tee(K,m.binary(u.BinaryOp.ShrI64,m.local_tee(z,U),m.i64(63))),m.local_get(z,u.NativeType.I64)),m.local_get(K,u.NativeType.I64)),H.freeTempLocal(G);break;case 9:case 5:case 6:case 7:case 8:case 10:L=U;break;case 11:L=m.unary(u.UnaryOp.AbsF32,U);break;case 12:L=m.unary(u.UnaryOp.AbsF64,U);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.max:if(I(t,s,e,!0)|A(n,2,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.f64,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();V=e.compileExpression(n[1],S,5),M=void 0;switch(S.kind){case 0:case 1:case 2:M=u.BinaryOp.GtI32;break;case 5:case 6:case 7:case 10:M=u.BinaryOp.GtU32;break;case 3:M=u.BinaryOp.GtI64;break;case 8:M=u.BinaryOp.GtU64;break;case 4:M=e.options.isWasm64?u.BinaryOp.GtI64:u.BinaryOp.GtI32;break;case 9:M=e.options.isWasm64?u.BinaryOp.GtU64:u.BinaryOp.GtU32;break;case 11:return m.binary(u.BinaryOp.MaxF32,U,V);case 12:return m.binary(u.BinaryOp.MaxF64,U,V);default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable()}H=e.currentFlow;var X=S.toNativeType(),q=H.getTempLocal(S);H.setLocalFlag(q.index,_.LocalFlags.WRAPPED);G=H.getAndFreeTempLocal(S);return H.setLocalFlag(G.index,_.LocalFlags.WRAPPED),H.freeTempLocal(q),m.select(m.local_tee(q.index,U),m.local_tee(G.index,V),m.binary(M,m.local_get(q.index,X),m.local_get(G.index,X)));case a.min:if(I(t,s,e,!0)|A(n,2,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.f64,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();V=e.compileExpression(n[1],S,5),M=void 0;switch(S.kind){case 0:case 1:case 2:M=u.BinaryOp.LtI32;break;case 5:case 6:case 7:case 10:M=u.BinaryOp.LtU32;break;case 3:M=u.BinaryOp.LtI64;break;case 8:M=u.BinaryOp.LtU64;break;case 4:M=e.options.isWasm64?u.BinaryOp.LtI64:u.BinaryOp.LtI32;break;case 9:M=e.options.isWasm64?u.BinaryOp.LtU64:u.BinaryOp.LtU32;break;case 11:return m.binary(u.BinaryOp.MinF32,U,V);case 12:return m.binary(u.BinaryOp.MinF64,U,V);default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable()}H=e.currentFlow,X=S.toNativeType(),q=H.getTempLocal(S);H.setLocalFlag(q.index,_.LocalFlags.WRAPPED);G=H.getAndFreeTempLocal(S);return H.setLocalFlag(G.index,_.LocalFlags.WRAPPED),H.freeTempLocal(q),m.select(m.local_tee(q.index,U),m.local_tee(G.index,V),m.binary(M,m.local_get(q.index,X),m.local_get(G.index,X)));case a.ceil:case a.floor:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],1):e.compileExpression(n[0],l.Type.f64,0);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();M=void 0;switch(S.kind){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:return U;case 11:M=r.internalName==a.ceil?u.UnaryOp.CeilF32:u.UnaryOp.FloorF32;break;case 12:M=r.internalName==a.ceil?u.UnaryOp.CeilF64:u.UnaryOp.FloorF64;break;default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable()}return m.unary(M,U);case a.copysign:if(I(t,s,e,!0)|A(n,2,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],1):e.compileExpression(n[0],l.Type.f64,0);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();V=e.compileExpression(n[1],S,1),M=void 0;switch(S.kind){case 11:M=u.BinaryOp.CopysignF32;break;case 12:M=u.BinaryOp.CopysignF64;break;default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable()}return m.binary(M,U,V);case a.nearest:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],1):e.compileExpression(n[0],l.Type.f64,0);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();L=void 0;switch(S.kind){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:L=U;break;case 11:L=m.unary(u.UnaryOp.NearestF32,U);break;case 12:L=m.unary(u.UnaryOp.NearestF64,U);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.reinterpret:if(b(t,s,e,!0)|A(n,1,s,e))return m.unreachable();if((S=t[0]).is(256))return e.currentType=S,e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();L=void 0;switch(S.kind){case 2:case 7:U=e.compileExpression(n[0],l.Type.f32,1);L=m.unary(u.UnaryOp.ReinterpretF32,U);break;case 3:case 8:U=e.compileExpression(n[0],l.Type.f64,1);L=m.unary(u.UnaryOp.ReinterpretF64,U);break;case 4:case 9:U=e.compileExpression(n[0],e.options.isWasm64?l.Type.f64:l.Type.f32,1);L=m.unary(e.options.isWasm64?u.UnaryOp.ReinterpretF64:u.UnaryOp.ReinterpretF32,U);break;case 11:U=e.compileExpression(n[0],l.Type.i32,1);L=m.unary(u.UnaryOp.ReinterpretI32,U);break;case 12:U=e.compileExpression(n[0],l.Type.i64,1);L=m.unary(u.UnaryOp.ReinterpretI64,U);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return e.currentType=S,L;case a.sqrt:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],1):e.compileExpression(n[0],l.Type.f64,0);if((S=e.currentType).is(256))return e.currentType=S,e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();L=void 0;switch(S.kind){case 11:L=m.unary(u.UnaryOp.SqrtF32,U);break;case 12:L=m.unary(u.UnaryOp.SqrtF64,U);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.trunc:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],1):e.compileExpression(n[0],l.Type.f64,0);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.range),m.unreachable();L=void 0;switch(S.kind){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:L=U;break;case 11:L=m.unary(u.UnaryOp.TruncF32,U);break;case 12:L=m.unary(u.UnaryOp.TruncF64,U);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.load:if(b(t,s,e,!0)|N(n,1,3,s,e))return m.unreachable();S=t[0];var Q=i!=l.Type.auto&&S.is(4)&&i.is(4)&&i.size>S.size?i:S;U=e.compileExpression(n[0],e.options.usizeType,1);if(($=(ue=n.length)>=2?v(n[1],e):0)<0)return e.currentType=Q,m.unreachable();var j=void 0,Z=S.byteSize;if(3==ue){if((j=v(n[2],e))<0)return e.currentType=Q,m.unreachable();if(j>Z)return e.error(o.DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,n[2].range,"Alignment","0",Z.toString()),e.currentType=Q,m.unreachable();if(!y.isPowerOf2(j))return e.error(o.DiagnosticCode._0_must_be_a_power_of_two,n[2].range,"Alignment"),e.currentType=Q,m.unreachable()}else j=Z;return e.currentType=Q,m.load(S.byteSize,S.is(5),U,Q.toNativeType(),$,j);case a.store:if(e.currentType=l.Type.void,b(t,s,e)|N(n,2,4,s,e))return m.unreachable();S=t[0],U=e.compileExpression(n[0],e.options.usizeType,1),V=d?e.compileExpression(n[1],i,1):e.compileExpression(n[1],S,S.is(4)?0:1);var J=e.currentType;if(S.is(4)&&(!J.is(4)||J.size=3?v(n[2],e):0)<0)return e.currentType=l.Type.void,m.unreachable();j=void 0,Z=S.byteSize;if(4==n.length){if((j=v(n[3],e))<0)return e.currentType=l.Type.void,m.unreachable();if(j>Z)return e.error(o.DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,n[3].range,"Alignment","0",Z.toString()),e.currentType=l.Type.void,m.unreachable();if(!y.isPowerOf2(j))return e.error(o.DiagnosticCode._0_must_be_a_power_of_two,n[3].range,"Alignment"),e.currentType=l.Type.void,m.unreachable()}else j=Z;return e.currentType=l.Type.void,m.store(S.byteSize,U,V,J.toNativeType(),$,j);case a.atomic_load:if(!e.options.hasFeature(16))break;if(b(t,s,e,!0)|N(n,1,2,s,e))return m.unreachable();Q=(S=t[0]).is(4)&&i.is(4)&&i.size>S.size?i:S;if(!S.is(4))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=Q,m.unreachable();U=e.compileExpression(n[0],e.options.usizeType,1);return($=2==n.length?v(n[1],e):0)<0?(e.currentType=Q,m.unreachable()):(e.currentType=Q,m.atomic_load(S.byteSize,U,Q.toNativeType(),$));case a.atomic_store:if(!e.options.hasFeature(16))break;if(e.currentType=l.Type.void,b(t,s,e)|N(n,2,3,s,e))return m.unreachable();if(!(S=t[0]).is(4)||S.size<8)return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();U=e.compileExpression(n[0],e.options.usizeType,1),V=d?e.compileExpression(n[1],i,1):e.compileExpression(n[1],S,S.is(4)?0:1),J=e.currentType;return S.is(4)&&(!J.is(4)||J.size=0&&geNe?(e.error(o.DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,n[1].range,"Lane index","0",Ne.toString()),m.unreachable()):m.simd_extract(M,U,ke);case a.v128_replace_lane:if(!e.options.hasFeature(8))break;if(b(t,s,e)|A(n,3,s,e))return e.currentType=l.Type.v128,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();M=void 0;switch(S.kind){case 0:case 5:M=u.SIMDReplaceOp.ReplaceLaneVecI8x16;break;case 1:case 6:M=u.SIMDReplaceOp.ReplaceLaneVecI16x8;break;case 2:case 7:M=u.SIMDReplaceOp.ReplaceLaneVecI32x4;break;case 3:case 8:M=u.SIMDReplaceOp.ReplaceLaneVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.SIMDReplaceOp.ReplaceLaneVecI64x2:u.SIMDReplaceOp.ReplaceLaneVecI32x4;break;case 11:M=u.SIMDReplaceOp.ReplaceLaneVecF32x4;break;case 12:M=u.SIMDReplaceOp.ReplaceLaneVecF64x2;break;default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable()}U=e.compileExpression(n[0],l.Type.v128,1),V=e.precomputeExpression(n[1],l.Type.u8,1);if(u.getExpressionId(V)!=u.ExpressionId.Const)return e.error(o.DiagnosticCode.Expression_must_be_a_compile_time_constant,n[1].range),e.currentType=l.Type.v128,m.unreachable();assert(u.getExpressionType(V)==u.NativeType.I32);Ne=16/S.byteSize-1;if((ke=u.getConstValueI32(V))<0||ke>Ne)return e.error(o.DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,n[1].range,"Lane index","0",Ne.toString()),m.unreachable();ee=e.compileExpression(n[2],S,1);return e.currentType=l.Type.v128,m.simd_replace(M,U,ke,ee);case a.v128_shuffle:if(!e.options.hasFeature(8))break;if(b(t,s,e))return e.currentType=l.Type.v128,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();var Se=S.byteSize,Oe=16/Se;if(assert(isInteger(Oe)&&y.isPowerOf2(Oe)),A(n,2+Oe,s,e))return e.currentType=l.Type.v128,m.unreachable();switch(S.kind){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 11:case 12:break;default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable()}U=e.compileExpression(n[0],l.Type.v128,1),V=e.compileExpression(n[1],l.Type.v128,1);var Ce=new Uint8Array(16);for(Ne=(Oe<<1)-1,ye=0;yeNe)return e.error(o.DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,Le.range,"Lane index","0",Ne.toString()),e.currentType=l.Type.v128,m.unreachable();switch(Se){case 1:y.writeI8(ke,Ce,ye);break;case 2:var Fe=ye<<1,Be=ke<<1;y.writeI8(Be,Ce,Fe),y.writeI8(Be+1,Ce,Fe+1);break;case 4:Fe=ye<<2,Be=ke<<2;y.writeI8(Be,Ce,Fe),y.writeI8(Be+1,Ce,Fe+1),y.writeI8(Be+2,Ce,Fe+2),y.writeI8(Be+3,Ce,Fe+3);break;case 8:Fe=ye<<3,Be=ke<<3;y.writeI8(Be,Ce,Fe),y.writeI8(Be+1,Ce,Fe+1),y.writeI8(Be+2,Ce,Fe+2),y.writeI8(Be+3,Ce,Fe+3),y.writeI8(Be+4,Ce,Fe+4),y.writeI8(Be+5,Ce,Fe+5),y.writeI8(Be+6,Ce,Fe+6),y.writeI8(Be+7,Ce,Fe+7);break;default:assert(!1)}}return e.currentType=l.Type.v128,m.simd_shuffle(U,V,Ce);case a.v128_add:case a.v128_sub:case a.v128_mul:case a.v128_div:case a.v128_add_saturate:case a.v128_sub_saturate:case a.v128_min:case a.v128_max:case a.v128_eq:case a.v128_ne:case a.v128_lt:case a.v128_le:case a.v128_gt:case a.v128_ge:if(!e.options.hasFeature(8))break;if(b(t,s,e)|A(n,2,s,e))return e.currentType=l.Type.v128,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();M=-1;switch(r.internalName){case a.v128_add:switch(S.kind){case 0:case 5:M=u.BinaryOp.AddVecI8x16;break;case 1:case 6:M=u.BinaryOp.AddVecI16x8;break;case 2:case 7:M=u.BinaryOp.AddVecI32x4;break;case 3:case 8:M=u.BinaryOp.AddVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.BinaryOp.AddVecI64x2:u.BinaryOp.AddVecI32x4;break;case 11:M=u.BinaryOp.AddVecF32x4;break;case 12:M=u.BinaryOp.AddVecF64x2}break;case a.v128_sub:switch(S.kind){case 0:case 5:M=u.BinaryOp.SubVecI8x16;break;case 1:case 6:M=u.BinaryOp.SubVecI16x8;break;case 2:case 7:M=u.BinaryOp.SubVecI32x4;break;case 3:case 8:M=u.BinaryOp.SubVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.BinaryOp.SubVecI64x2:u.BinaryOp.SubVecI32x4;break;case 11:M=u.BinaryOp.SubVecF32x4;break;case 12:M=u.BinaryOp.SubVecF64x2}break;case a.v128_mul:switch(S.kind){case 0:case 5:M=u.BinaryOp.MulVecI8x16;break;case 1:case 6:M=u.BinaryOp.MulVecI16x8;break;case 2:case 7:M=u.BinaryOp.MulVecI32x4;break;case 11:M=u.BinaryOp.MulVecF32x4;break;case 12:M=u.BinaryOp.MulVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=u.BinaryOp.MulVecI32x4)}break;case a.v128_div:switch(S.kind){case 11:M=u.BinaryOp.DivVecF32x4;break;case 12:M=u.BinaryOp.DivVecF64x2}break;case a.v128_add_saturate:switch(S.kind){case 0:M=u.BinaryOp.AddSatSVecI8x16;break;case 5:M=u.BinaryOp.AddSatUVecI8x16;break;case 1:M=u.BinaryOp.AddSatSVecI16x8;break;case 6:M=u.BinaryOp.AddSatUVecI16x8}break;case a.v128_sub_saturate:switch(S.kind){case 0:M=u.BinaryOp.SubSatSVecI8x16;break;case 5:M=u.BinaryOp.SubSatUVecI8x16;break;case 1:M=u.BinaryOp.SubSatSVecI16x8;break;case 6:M=u.BinaryOp.SubSatUVecI16x8}break;case a.v128_min:switch(S.kind){case 11:M=u.BinaryOp.MinVecF32x4;break;case 12:M=u.BinaryOp.MinVecF64x2}break;case a.v128_max:switch(S.kind){case 11:M=u.BinaryOp.MaxVecF32x4;break;case 12:M=u.BinaryOp.MaxVecF64x2}break;case a.v128_eq:switch(S.kind){case 0:case 5:M=u.BinaryOp.EqVecI8x16;break;case 1:case 6:M=u.BinaryOp.EqVecI16x8;break;case 2:case 7:M=u.BinaryOp.EqVecI32x4;break;case 11:M=u.BinaryOp.EqVecF32x4;break;case 12:M=u.BinaryOp.EqVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=u.BinaryOp.EqVecI32x4)}break;case a.v128_ne:switch(S.kind){case 0:case 5:M=u.BinaryOp.NeVecI8x16;break;case 1:case 6:M=u.BinaryOp.NeVecI16x8;break;case 2:case 7:M=u.BinaryOp.NeVecI32x4;break;case 11:M=u.BinaryOp.NeVecF32x4;break;case 12:M=u.BinaryOp.NeVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=u.BinaryOp.NeVecI32x4)}break;case a.v128_lt:switch(S.kind){case 0:M=u.BinaryOp.LtSVecI8x16;break;case 5:M=u.BinaryOp.LtUVecI8x16;break;case 1:M=u.BinaryOp.LtSVecI16x8;break;case 6:M=u.BinaryOp.LtUVecI16x8;break;case 2:M=u.BinaryOp.LtSVecI32x4;break;case 7:M=u.BinaryOp.LtUVecI32x4;break;case 11:M=u.BinaryOp.LtVecF32x4;break;case 12:M=u.BinaryOp.LtVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=4==S.kind?u.BinaryOp.LtSVecI32x4:u.BinaryOp.LtUVecI32x4)}break;case a.v128_le:switch(S.kind){case 0:M=u.BinaryOp.LeSVecI8x16;break;case 5:M=u.BinaryOp.LeUVecI8x16;break;case 1:M=u.BinaryOp.LeSVecI16x8;break;case 6:M=u.BinaryOp.LeUVecI16x8;break;case 2:M=u.BinaryOp.LeSVecI32x4;break;case 7:M=u.BinaryOp.LeUVecI32x4;break;case 11:M=u.BinaryOp.LeVecF32x4;break;case 12:M=u.BinaryOp.LeVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=4==S.kind?u.BinaryOp.LeSVecI32x4:u.BinaryOp.LeUVecI32x4)}break;case a.v128_gt:switch(S.kind){case 0:M=u.BinaryOp.GtSVecI8x16;break;case 5:M=u.BinaryOp.GtUVecI8x16;break;case 1:M=u.BinaryOp.GtSVecI16x8;break;case 6:M=u.BinaryOp.GtUVecI16x8;break;case 2:M=u.BinaryOp.GtSVecI32x4;break;case 7:M=u.BinaryOp.GtUVecI32x4;break;case 11:M=u.BinaryOp.GtVecF32x4;break;case 12:M=u.BinaryOp.GtVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=4==S.kind?u.BinaryOp.GtSVecI32x4:u.BinaryOp.GtUVecI32x4)}break;case a.v128_ge:switch(S.kind){case 0:M=u.BinaryOp.GeSVecI8x16;break;case 5:M=u.BinaryOp.GeUVecI8x16;break;case 1:M=u.BinaryOp.GeSVecI16x8;break;case 6:M=u.BinaryOp.GeUVecI16x8;break;case 2:M=u.BinaryOp.GeSVecI32x4;break;case 7:M=u.BinaryOp.GeUVecI32x4;break;case 11:M=u.BinaryOp.GeVecF32x4;break;case 12:M=u.BinaryOp.GeVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=4==S.kind?u.BinaryOp.GeSVecI32x4:u.BinaryOp.GeUVecI32x4)}}if(-1==M)return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1),V=e.compileExpression(n[1],l.Type.v128,1);return e.currentType=l.Type.v128,m.binary(M,U,V);case a.v128_neg:case a.v128_abs:case a.v128_sqrt:case a.v128_convert:case a.v128_trunc:if(!e.options.hasFeature(8))break;if(b(t,s,e)|A(n,1,s,e))return e.currentType=l.Type.v128,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.range),e.currentType=l.Type.v128,m.unreachable();M=-1;switch(r.internalName){case a.v128_neg:switch(S.kind){case 0:case 5:M=u.UnaryOp.NegVecI8x16;break;case 1:case 6:M=u.UnaryOp.NegVecI16x8;break;case 2:case 7:M=u.UnaryOp.NegVecI32x4;break;case 3:case 8:M=u.UnaryOp.NegVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.UnaryOp.NegVecI64x2:u.UnaryOp.NegVecI32x4;break;case 11:M=u.UnaryOp.NegVecF32x4;break;case 12:M=u.UnaryOp.NegVecF64x2}break;case a.v128_abs:switch(S.kind){case 11:M=u.UnaryOp.AbsVecF32x4;break;case 12:M=u.UnaryOp.AbsVecF64x2}break;case a.v128_sqrt:switch(S.kind){case 11:M=u.UnaryOp.SqrtVecF32x4;break;case 12:M=u.UnaryOp.SqrtVecF64x2}break;case a.v128_convert:switch(S.kind){case 2:M=u.UnaryOp.ConvertSVecI32x4ToVecF32x4;break;case 7:M=u.UnaryOp.ConvertUVecI32x4ToVecF32x4;break;case 3:M=u.UnaryOp.ConvertSVecI64x2ToVecF64x2;break;case 8:M=u.UnaryOp.ConvertUVecI64x2ToVecF64x2}break;case a.v128_trunc:switch(S.kind){case 2:M=u.UnaryOp.TruncSatSVecF32x4ToVecI32x4;break;case 7:M=u.UnaryOp.TruncSatUVecF32x4ToVecI32x4;break;case 3:M=u.UnaryOp.TruncSatSVecF64x2ToVecI64x2;break;case 8:M=u.UnaryOp.TruncSatUVecF64x2ToVecI64x2}}if(-1==M)return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1);return e.currentType=l.Type.v128,m.unary(M,U);case a.v128_shl:case a.v128_shr:if(!e.options.hasFeature(8))break;if(b(t,s,e)|A(n,2,s,e))return e.currentType=l.Type.v128,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();M=-1;switch(r.internalName){case a.v128_shl:switch(S.kind){case 0:case 5:M=u.SIMDShiftOp.ShlVecI8x16;break;case 1:case 6:M=u.SIMDShiftOp.ShlVecI16x8;break;case 2:case 7:M=u.SIMDShiftOp.ShlVecI32x4;break;case 3:case 8:M=u.SIMDShiftOp.ShlVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.SIMDShiftOp.ShlVecI64x2:u.SIMDShiftOp.ShlVecI32x4}break;case a.v128_shr:switch(S.kind){case 0:M=u.SIMDShiftOp.ShrSVecI8x16;break;case 5:M=u.SIMDShiftOp.ShrUVecI8x16;break;case 1:M=u.SIMDShiftOp.ShrSVecI16x8;break;case 6:M=u.SIMDShiftOp.ShrUVecI16x8;break;case 2:M=u.SIMDShiftOp.ShrSVecI32x4;break;case 7:M=u.SIMDShiftOp.ShrUVecI32x4;break;case 3:M=u.SIMDShiftOp.ShrSVecI64x2;break;case 8:M=u.SIMDShiftOp.ShrUVecI64x2;break;case 4:M=e.options.isWasm64?u.SIMDShiftOp.ShrSVecI64x2:u.SIMDShiftOp.ShrSVecI32x4;break;case 9:M=e.options.isWasm64?u.SIMDShiftOp.ShrUVecI64x2:u.SIMDShiftOp.ShrUVecI32x4}}if(-1==M)return e.error(o.DiagnosticCode.Operation_not_supported,s.range),e.currentType=l.Type.v128,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1),V=e.compileExpression(n[1],l.Type.i32,1);return e.currentType=l.Type.v128,m.simd_shift(M,U,V);case a.v128_and:case a.v128_or:case a.v128_xor:if(!e.options.hasFeature(8))break;if(x(t,s,r)|A(n,2,s,e))return e.currentType=l.Type.v128,m.unreachable();M=-1;switch(r.internalName){default:assert(!1);case a.v128_and:M=u.BinaryOp.AndVec128;break;case a.v128_or:M=u.BinaryOp.OrVec128;break;case a.v128_xor:M=u.BinaryOp.XorVec128}U=e.compileExpression(n[0],l.Type.v128,1),V=e.compileExpression(n[1],l.Type.v128,1);return m.binary(M,U,V);case a.v128_not:if(!e.options.hasFeature(8))break;if(x(t,s,r)|A(n,1,s,e))return e.currentType=l.Type.v128,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1);return m.unary(u.UnaryOp.NotVec128,U);case a.v128_bitselect:if(!e.options.hasFeature(8))break;if(x(t,s,r)|A(n,3,s,e))return e.currentType=l.Type.v128,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1),V=e.compileExpression(n[1],l.Type.v128,1),ee=e.compileExpression(n[2],l.Type.v128,1);return m.simd_bitselect(U,V,ee);case a.v128_any_true:case a.v128_all_true:if(!e.options.hasFeature(8))break;if(b(t,s,e)|A(n,1,s,e))return e.currentType=l.Type.bool,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();M=-1;switch(r.internalName){default:assert(!1);case a.v128_any_true:switch(S.kind){case 0:case 5:M=u.UnaryOp.AnyTrueVecI8x16;break;case 1:case 6:M=u.UnaryOp.AnyTrueVecI16x8;break;case 2:case 7:M=u.UnaryOp.AnyTrueVecI32x4;break;case 3:case 8:M=u.UnaryOp.AnyTrueVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.UnaryOp.AnyTrueVecI64x2:u.UnaryOp.AnyTrueVecI32x4}break;case a.v128_all_true:switch(S.kind){case 0:case 5:M=u.UnaryOp.AllTrueVecI8x16;break;case 1:case 6:M=u.UnaryOp.AllTrueVecI16x8;break;case 2:case 7:M=u.UnaryOp.AllTrueVecI32x4;break;case 3:case 8:M=u.UnaryOp.AllTrueVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.UnaryOp.AllTrueVecI64x2:u.UnaryOp.AllTrueVecI32x4}}if(-1==M)return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.bool,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1);return e.currentType=l.Type.bool,m.unary(M,U);case a.idof:var De;S=E(e,t,n,s);return e.currentType=l.Type.u32,S?!(De=S.classReference)||De.hasDecorator(p.DecoratorFlags.UNMANAGED)?(e.error(o.DiagnosticCode.Operation_not_supported,s.range),m.unreachable()):m.i32(De.id):m.unreachable();case a.visit_globals:if(x(t,s,r)|A(n,1,s,e))return e.currentType=l.Type.void,m.unreachable();U=e.compileExpression(n[0],l.Type.u32,1);return e.runtimeFeatures|=4,e.currentType=l.Type.void,m.call(a.visit_globals,[U],u.NativeType.None);case a.visit_members:if(x(t,s,r)|A(n,2,s,e))return e.currentType=l.Type.void,m.unreachable();U=e.compileExpression(n[0],e.options.usizeType,1),V=e.compileExpression(n[1],l.Type.u32,1);return e.runtimeFeatures|=8,e.currentType=l.Type.void,m.call(a.visit_members,[U,V],u.NativeType.None)}return(L=function(e,r,t,n){switch(r.internalName){case a.i32_clz:return f(a.clz,e,l.Type.i32,t,l.Type.i32,n);case a.i64_clz:return f(a.clz,e,l.Type.i64,t,l.Type.i64,n);case a.i32_ctz:return f(a.ctz,e,l.Type.i32,t,l.Type.i32,n);case a.i64_ctz:return f(a.ctz,e,l.Type.i64,t,l.Type.i64,n);case a.i32_popcnt:return f(a.popcnt,e,l.Type.i32,t,l.Type.i32,n);case a.i64_popcnt:return f(a.popcnt,e,l.Type.i64,t,l.Type.i64,n);case a.i32_rotl:return f(a.rotl,e,l.Type.i32,t,l.Type.i32,n);case a.i64_rotl:return f(a.rotl,e,l.Type.i64,t,l.Type.i64,n);case a.i32_rotr:return f(a.rotr,e,l.Type.i32,t,l.Type.i32,n);case a.i64_rotr:return f(a.rotr,e,l.Type.i64,t,l.Type.i64,n);case a.f32_abs:return f(a.abs,e,l.Type.f32,t,l.Type.f32,n);case a.f64_abs:return f(a.abs,e,l.Type.f64,t,l.Type.f64,n);case a.f32_max:return f(a.max,e,l.Type.f32,t,l.Type.f32,n);case a.f64_max:return f(a.max,e,l.Type.f64,t,l.Type.f64,n);case a.f32_min:return f(a.min,e,l.Type.f32,t,l.Type.f32,n);case a.f64_min:return f(a.min,e,l.Type.f64,t,l.Type.f64,n);case a.f32_ceil:return f(a.ceil,e,l.Type.f32,t,l.Type.f32,n);case a.f64_ceil:return f(a.ceil,e,l.Type.f64,t,l.Type.f64,n);case a.f32_floor:return f(a.floor,e,l.Type.f32,t,l.Type.f32,n);case a.f64_floor:return f(a.floor,e,l.Type.f64,t,l.Type.f64,n);case a.f32_copysign:return f(a.copysign,e,l.Type.f32,t,l.Type.f32,n);case a.f64_copysign:return f(a.copysign,e,l.Type.f64,t,l.Type.f64,n);case a.f32_nearest:return f(a.nearest,e,l.Type.f32,t,l.Type.f32,n);case a.f64_nearest:return f(a.nearest,e,l.Type.f64,t,l.Type.f64,n);case a.i32_reinterpret_f32:return f(a.reinterpret,e,l.Type.i32,t,l.Type.f32,n);case a.i64_reinterpret_f64:return f(a.reinterpret,e,l.Type.i64,t,l.Type.f64,n);case a.f32_reinterpret_i32:return f(a.reinterpret,e,l.Type.f32,t,l.Type.i32,n);case a.f64_reinterpret_i64:return f(a.reinterpret,e,l.Type.f64,t,l.Type.i64,n);case a.f32_sqrt:return f(a.sqrt,e,l.Type.f32,t,l.Type.f32,n);case a.f64_sqrt:return f(a.sqrt,e,l.Type.f64,t,l.Type.f64,n);case a.f32_trunc:return f(a.trunc,e,l.Type.f32,t,l.Type.f32,n);case a.f64_trunc:return f(a.trunc,e,l.Type.f64,t,l.Type.f64,n);case a.i32_load8_s:return f(a.load,e,l.Type.i8,t,l.Type.i32,n);case a.i32_load8_u:return f(a.load,e,l.Type.u8,t,l.Type.i32,n);case a.i32_load16_s:return f(a.load,e,l.Type.i16,t,l.Type.i32,n);case a.i32_load16_u:return f(a.load,e,l.Type.u16,t,l.Type.i32,n);case a.i32_load:return f(a.load,e,l.Type.i32,t,l.Type.i32,n);case a.i64_load8_s:return f(a.load,e,l.Type.i8,t,l.Type.i64,n);case a.i64_load8_u:return f(a.load,e,l.Type.u8,t,l.Type.i64,n);case a.i64_load16_s:return f(a.load,e,l.Type.i16,t,l.Type.i64,n);case a.i64_load16_u:return f(a.load,e,l.Type.u16,t,l.Type.i64,n);case a.i64_load32_s:return f(a.load,e,l.Type.i32,t,l.Type.i64,n);case a.i64_load32_u:return f(a.load,e,l.Type.u32,t,l.Type.i64,n);case a.i64_load:return f(a.load,e,l.Type.i64,t,l.Type.i64,n);case a.f32_load:return f(a.load,e,l.Type.f32,t,l.Type.f32,n);case a.f64_load:return f(a.load,e,l.Type.f64,t,l.Type.f64,n);case a.i32_store8:return f(a.store,e,l.Type.i8,t,l.Type.i32,n);case a.i32_store16:return f(a.store,e,l.Type.i16,t,l.Type.i32,n);case a.i32_store:return f(a.store,e,l.Type.i32,t,l.Type.i32,n);case a.i64_store8:return f(a.store,e,l.Type.i8,t,l.Type.i64,n);case a.i64_store16:return f(a.store,e,l.Type.i16,t,l.Type.i64,n);case a.i64_store32:return f(a.store,e,l.Type.i32,t,l.Type.i64,n);case a.i64_store:return f(a.store,e,l.Type.i64,t,l.Type.i64,n);case a.f32_store:return f(a.store,e,l.Type.f32,t,l.Type.f32,n);case a.f64_store:return f(a.store,e,l.Type.f64,t,l.Type.f64,n)}if(e.options.hasFeature(16))switch(r.internalName){case a.i32_atomic_load8_u:return f(a.atomic_load,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_load16_u:return f(a.atomic_load,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_load:return f(a.atomic_load,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_load8_u:return f(a.atomic_load,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_load16_u:return f(a.atomic_load,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_load32_u:return f(a.atomic_load,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_load:return f(a.atomic_load,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_store8:return f(a.atomic_store,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_store16:return f(a.atomic_store,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_store:return f(a.atomic_store,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_store8:return f(a.atomic_store,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_store16:return f(a.atomic_store,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_store32:return f(a.atomic_store,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_store:return f(a.atomic_store,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_add_u:return f(a.atomic_add,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_add_u:return f(a.atomic_add,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_add:return f(a.atomic_add,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_add_u:return f(a.atomic_add,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_add_u:return f(a.atomic_add,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_add_u:return f(a.atomic_add,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_add:return f(a.atomic_add,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_sub_u:return f(a.atomic_sub,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_sub_u:return f(a.atomic_sub,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_sub:return f(a.atomic_sub,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_sub_u:return f(a.atomic_sub,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_sub_u:return f(a.atomic_sub,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_sub_u:return f(a.atomic_sub,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_sub:return f(a.atomic_sub,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_and_u:return f(a.atomic_and,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_and_u:return f(a.atomic_and,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_and:return f(a.atomic_and,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_and_u:return f(a.atomic_and,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_and_u:return f(a.atomic_and,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_and_u:return f(a.atomic_and,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_and:return f(a.atomic_and,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_or_u:return f(a.atomic_or,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_or_u:return f(a.atomic_or,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_or:return f(a.atomic_or,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_or_u:return f(a.atomic_or,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_or_u:return f(a.atomic_or,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_or_u:return f(a.atomic_or,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_or:return f(a.atomic_or,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_u_xor:return f(a.atomic_xor,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_u_xor:return f(a.atomic_xor,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_xor:return f(a.atomic_xor,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_xor_u:return f(a.atomic_xor,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_xor_u:return f(a.atomic_xor,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_xor_u:return f(a.atomic_xor,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_xor:return f(a.atomic_xor,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_xchg_u:return f(a.atomic_xchg,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_xchg_u:return f(a.atomic_xchg,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_xchg:return f(a.atomic_xchg,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_xchg_u:return f(a.atomic_xchg,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_xchg_u:return f(a.atomic_xchg,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_xchg_u:return f(a.atomic_xchg,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_xchg:return f(a.atomic_xchg,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_cmpxchg_u:return f(a.atomic_cmpxchg,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_cmpxchg_u:return f(a.atomic_cmpxchg,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_cmpxchg:return f(a.atomic_cmpxchg,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_cmpxchg_u:return f(a.atomic_cmpxchg,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_cmpxchg_u:return f(a.atomic_cmpxchg,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_cmpxchg_u:return f(a.atomic_cmpxchg,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_cmpxchg:return f(a.atomic_cmpxchg,e,l.Type.i64,t,l.Type.i64,n);case a.i32_wait:return f(a.atomic_wait,e,l.Type.i32,t,l.Type.i32,n);case a.i64_wait:return f(a.atomic_wait,e,l.Type.i64,t,l.Type.i32,n)}if(e.options.hasFeature(8))switch(r.internalName){case a.v128_load:return f(a.load,e,l.Type.v128,t,l.Type.v128,n);case a.v128_store:return f(a.store,e,l.Type.v128,t,l.Type.void,n);case a.i8x16_splat:return f(a.v128_splat,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_extract_lane_s:return f(a.v128_extract_lane,e,l.Type.i8,t,l.Type.i8,n);case a.i8x16_extract_lane_u:return f(a.v128_extract_lane,e,l.Type.u8,t,l.Type.u8,n);case a.i8x16_replace_lane:return f(a.v128_replace_lane,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_add:return f(a.v128_add,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_sub:return f(a.v128_sub,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_mul:return f(a.v128_mul,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_neg:return f(a.v128_neg,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_add_saturate_s:return f(a.v128_add_saturate,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_add_saturate_u:return f(a.v128_add_saturate,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_sub_saturate_s:return f(a.v128_sub_saturate,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_sub_saturate_u:return f(a.v128_sub_saturate,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_shl:return f(a.v128_shl,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_shr_s:return f(a.v128_shr,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_shr_u:return f(a.v128_shr,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_any_true:return f(a.v128_any_true,e,l.Type.i8,t,l.Type.i32,n);case a.i8x16_all_true:return f(a.v128_all_true,e,l.Type.i8,t,l.Type.i32,n);case a.i8x16_eq:return f(a.v128_eq,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_ne:return f(a.v128_ne,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_lt_s:return f(a.v128_lt,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_lt_u:return f(a.v128_lt,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_le_s:return f(a.v128_le,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_le_u:return f(a.v128_le,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_gt_s:return f(a.v128_gt,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_gt_u:return f(a.v128_gt,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_ge_s:return f(a.v128_ge,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_ge_u:return f(a.v128_ge,e,l.Type.u8,t,l.Type.v128,n);case a.i16x8_splat:return f(a.v128_splat,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_extract_lane_s:return f(a.v128_extract_lane,e,l.Type.i16,t,l.Type.i16,n);case a.i16x8_extract_lane_u:return f(a.v128_extract_lane,e,l.Type.u16,t,l.Type.u16,n);case a.i16x8_replace_lane:return f(a.v128_replace_lane,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_add:return f(a.v128_add,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_sub:return f(a.v128_sub,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_mul:return f(a.v128_mul,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_neg:return f(a.v128_neg,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_add_saturate_s:return f(a.v128_add_saturate,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_add_saturate_u:return f(a.v128_add_saturate,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_sub_saturate_s:return f(a.v128_sub_saturate,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_sub_saturate_u:return f(a.v128_sub_saturate,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_shl:return f(a.v128_shl,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_shr_s:return f(a.v128_shr,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_shr_u:return f(a.v128_shr,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_any_true:return f(a.v128_any_true,e,l.Type.i16,t,l.Type.i32,n);case a.i16x8_all_true:return f(a.v128_all_true,e,l.Type.i16,t,l.Type.i32,n);case a.i16x8_eq:return f(a.v128_eq,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_ne:return f(a.v128_ne,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_lt_s:return f(a.v128_lt,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_lt_u:return f(a.v128_lt,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_le_s:return f(a.v128_le,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_le_u:return f(a.v128_le,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_gt_s:return f(a.v128_gt,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_gt_u:return f(a.v128_gt,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_ge_s:return f(a.v128_ge,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_ge_u:return f(a.v128_ge,e,l.Type.u16,t,l.Type.v128,n);case a.i32x4_splat:return f(a.v128_splat,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_extract_lane:return f(a.v128_extract_lane,e,l.Type.i32,t,l.Type.i32,n);case a.i32x4_replace_lane:return f(a.v128_replace_lane,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_add:return f(a.v128_add,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_sub:return f(a.v128_sub,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_mul:return f(a.v128_mul,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_neg:return f(a.v128_neg,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_shl:return f(a.v128_shl,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_shr_s:return f(a.v128_shr,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_shr_u:return f(a.v128_shr,e,l.Type.u32,t,l.Type.v128,n);case a.i32x4_any_true:return f(a.v128_any_true,e,l.Type.i32,t,l.Type.i32,n);case a.i32x4_all_true:return f(a.v128_all_true,e,l.Type.i32,t,l.Type.i32,n);case a.i32x4_eq:return f(a.v128_eq,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_ne:return f(a.v128_ne,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_lt_s:return f(a.v128_lt,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_lt_u:return f(a.v128_lt,e,l.Type.u32,t,l.Type.v128,n);case a.i32x4_le_s:return f(a.v128_le,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_le_u:return f(a.v128_le,e,l.Type.u32,t,l.Type.v128,n);case a.i32x4_gt_s:return f(a.v128_gt,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_gt_u:return f(a.v128_gt,e,l.Type.u32,t,l.Type.v128,n);case a.i32x4_ge_s:return f(a.v128_ge,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_ge_u:return f(a.v128_ge,e,l.Type.u32,t,l.Type.v128,n);case a.i32x4_trunc_s_f32x4_sat:return f(a.v128_trunc,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_trunc_u_f32x4_sat:return f(a.v128_trunc,e,l.Type.u32,t,l.Type.v128,n);case a.i64x2_splat:return f(a.v128_splat,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_extract_lane:return f(a.v128_extract_lane,e,l.Type.i64,t,l.Type.i64,n);case a.i64x2_replace_lane:return f(a.v128_replace_lane,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_add:return f(a.v128_add,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_sub:return f(a.v128_sub,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_neg:return f(a.v128_neg,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_shl:return f(a.v128_shl,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_shr_s:return f(a.v128_shr,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_shr_u:return f(a.v128_shr,e,l.Type.u64,t,l.Type.v128,n);case a.i64x2_any_true:return f(a.v128_any_true,e,l.Type.i64,t,l.Type.i32,n);case a.i64x2_all_true:return f(a.v128_all_true,e,l.Type.i64,t,l.Type.i32,n);case a.i64x2_trunc_s_f64x2_sat:return f(a.v128_trunc,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_trunc_u_f64x2_sat:return f(a.v128_trunc,e,l.Type.u64,t,l.Type.v128,n);case a.f32x4_splat:return f(a.v128_splat,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_extract_lane:return f(a.v128_extract_lane,e,l.Type.f32,t,l.Type.f32,n);case a.f32x4_replace_lane:return f(a.v128_replace_lane,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_add:return f(a.v128_add,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_sub:return f(a.v128_sub,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_mul:return f(a.v128_mul,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_div:return f(a.v128_div,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_neg:return f(a.v128_neg,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_min:return f(a.v128_min,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_max:return f(a.v128_max,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_abs:return f(a.v128_abs,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_sqrt:return f(a.v128_sqrt,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_eq:return f(a.v128_eq,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_ne:return f(a.v128_ne,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_lt:return f(a.v128_lt,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_le:return f(a.v128_le,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_gt:return f(a.v128_gt,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_ge:return f(a.v128_ge,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_convert_s_i32x4:return f(a.v128_convert,e,l.Type.i32,t,l.Type.v128,n);case a.f32x4_convert_u_i32x4:return f(a.v128_convert,e,l.Type.u32,t,l.Type.v128,n);case a.f64x2_splat:return f(a.v128_splat,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_extract_lane:return f(a.v128_extract_lane,e,l.Type.f64,t,l.Type.f64,n);case a.f64x2_replace_lane:return f(a.v128_replace_lane,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_add:return f(a.v128_add,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_sub:return f(a.v128_sub,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_mul:return f(a.v128_mul,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_div:return f(a.v128_div,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_neg:return f(a.v128_neg,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_min:return f(a.v128_min,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_max:return f(a.v128_max,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_abs:return f(a.v128_abs,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_sqrt:return f(a.v128_sqrt,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_eq:return f(a.v128_eq,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_ne:return f(a.v128_ne,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_lt:return f(a.v128_lt,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_le:return f(a.v128_le,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_gt:return f(a.v128_gt,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_ge:return f(a.v128_ge,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_convert_s_i64x2:return f(a.v128_convert,e,l.Type.i64,t,l.Type.v128,n);case a.f64x2_convert_u_i64x2:return f(a.v128_convert,e,l.Type.u64,t,l.Type.v128,n);case a.v8x16_shuffle:return f(a.v128_shuffle,e,l.Type.i8,t,l.Type.v128,n)}return 0}(e,r,n,s))?(t&&e.error(o.DiagnosticCode.Type_0_is_not_generic,s.typeArgumentsRange,r.internalName),L):(e.error(o.DiagnosticCode.Cannot_find_name_0,s.expression.range,r.internalName),m.unreachable())}function f(e,r,t,n,i,a){assert(r.program.elementsByName.has(e));var s=r.program.elementsByName.get(e);return assert(s.kind==p.ElementKind.FUNCTION_PROTOTYPE),m(r,s,[t],n,i,a,!0)}function T(e,r,t){var n=e.program,i=e.module,a=e.program.stringInstance;if(!a)return i.unreachable();var s,o=n.abortInstance;if(!o||!e.compileFunction(o))return i.unreachable();s=null!==r?e.compileExpression(r,a.type,17):a.type.toNativeZero(i);var c=e.ensureStaticString(t.range.source.normalizedPath);return e.currentType=l.Type.void,i.block(null,[i.call(o.internalName,[s,c,i.i32(t.range.line),i.i32(t.range.column)],u.NativeType.None),i.unreachable()])}function g(e){var r=32*(1<1)return e.error(o.DiagnosticCode.Expected_0_type_arguments_but_got_1,n.typeArgumentsRange,"1",r.length.toString(10)),null;e.compileExpression(t[0],r[0],1)}else e.compileExpression(t[0],l.Type.auto);return e.currentType}return r&&r.length>1&&e.error(o.DiagnosticCode.Expected_0_type_arguments_but_got_1,n.typeArgumentsRange,"1",r.length.toString(10)),e.error(o.DiagnosticCode.Expected_0_arguments_but_got_1,n.argumentsRange,"1",t.length.toString(10)),null}function v(e,r){var t,n;return r.options.isWasm64?(t=r.precomputeExpression(e,l.Type.usize64,1),(u.getExpressionId(t)!=u.ExpressionId.Const||u.getExpressionType(t)!=u.NativeType.I64||0!=u.getConstValueI64High(t)||(n=u.getConstValueI64Low(t))<0)&&(r.error(o.DiagnosticCode.Expression_must_be_a_compile_time_constant,e.range),n=-1)):(t=r.precomputeExpression(e,l.Type.usize32,1),(u.getExpressionId(t)!=u.ExpressionId.Const||u.getExpressionType(t)!=u.NativeType.I32||(n=u.getConstValueI32(t))<0)&&(r.error(o.DiagnosticCode.Expression_must_be_a_compile_time_constant,e.range),n=-1)),n}function b(e,r,t,n){if(void 0===n&&(n=!1),e){var i=e.length;if(1==i)return 0;assert(i),n&&(t.currentType=e[0]),t.error(o.DiagnosticCode.Expected_0_type_arguments_but_got_1,r.typeArgumentsRange,"1",i.toString())}else t.error(o.DiagnosticCode.Expected_0_type_arguments_but_got_1,r.range,"1","0");return 1}function I(e,r,t,n){if(void 0===n&&(n=!1),e){var i=e.length;return 1==i?0:(assert(i),n&&(t.currentType=e[0]),t.error(o.DiagnosticCode.Expected_0_type_arguments_but_got_1,r.typeArgumentsRange,"1",i.toString()),1)}return 0}function x(e,r,t){return e?(t.program.error(o.DiagnosticCode.Type_0_is_not_generic,r.typeArgumentsRange,t.internalName),1):0}function A(e,r,t,n){return e.length!=r?(n.error(o.DiagnosticCode.Expected_0_arguments_but_got_1,t.range,r.toString(),e.length.toString()),1):0}function N(e,r,t,n,i){var a=e.length;return at?(i.error(o.DiagnosticCode.Expected_0_arguments_but_got_1,n.range,t.toString(),a.toString()),1):0}!function(e){e.isInteger="~lib/builtins/isInteger",e.isFloat="~lib/builtins/isFloat",e.isBoolean="~lib/builtins/isBoolean",e.isSigned="~lib/builtins/isSigned",e.isReference="~lib/builtins/isReference",e.isString="~lib/builtins/isString",e.isArray="~lib/builtins/isArray",e.isArrayLike="~lib/builtins/isArrayLike",e.isFunction="~lib/builtins/isFunction",e.isNullable="~lib/builtins/isNullable",e.isDefined="~lib/builtins/isDefined",e.isConstant="~lib/builtins/isConstant",e.isManaged="~lib/builtins/isManaged",e.clz="~lib/builtins/clz",e.ctz="~lib/builtins/ctz",e.popcnt="~lib/builtins/popcnt",e.rotl="~lib/builtins/rotl",e.rotr="~lib/builtins/rotr",e.abs="~lib/builtins/abs",e.max="~lib/builtins/max",e.min="~lib/builtins/min",e.ceil="~lib/builtins/ceil",e.floor="~lib/builtins/floor",e.copysign="~lib/builtins/copysign",e.nearest="~lib/builtins/nearest",e.reinterpret="~lib/builtins/reinterpret",e.sqrt="~lib/builtins/sqrt",e.trunc="~lib/builtins/trunc",e.load="~lib/builtins/load",e.store="~lib/builtins/store",e.atomic_load="~lib/builtins/atomic.load",e.atomic_store="~lib/builtins/atomic.store",e.atomic_add="~lib/builtins/atomic.add",e.atomic_sub="~lib/builtins/atomic.sub",e.atomic_and="~lib/builtins/atomic.and",e.atomic_or="~lib/builtins/atomic.or",e.atomic_xor="~lib/builtins/atomic.xor",e.atomic_xchg="~lib/builtins/atomic.xchg",e.atomic_cmpxchg="~lib/builtins/atomic.cmpxchg",e.atomic_wait="~lib/builtins/atomic.wait",e.atomic_notify="~lib/builtins/atomic.notify",e.sizeof="~lib/builtins/sizeof",e.alignof="~lib/builtins/alignof",e.offsetof="~lib/builtins/offsetof",e.select="~lib/builtins/select",e.unreachable="~lib/builtins/unreachable",e.changetype="~lib/builtins/changetype",e.assert="~lib/builtins/assert",e.unchecked="~lib/builtins/unchecked",e.call_direct="~lib/builtins/call_direct",e.call_indirect="~lib/builtins/call_indirect",e.instantiate="~lib/builtins/instantiate",e.idof="~lib/builtins/idof",e.i8="~lib/builtins/i8",e.i16="~lib/builtins/i16",e.i32="~lib/builtins/i32",e.i64="~lib/builtins/i64",e.isize="~lib/builtins/isize",e.u8="~lib/builtins/u8",e.u16="~lib/builtins/u16",e.u32="~lib/builtins/u32",e.u64="~lib/builtins/u64",e.usize="~lib/builtins/usize",e.bool="~lib/builtins/bool",e.f32="~lib/builtins/f32",e.f64="~lib/builtins/f64",e.v128="~lib/builtins/v128",e.void_="~lib/builtins/void",e.i32_clz="~lib/builtins/i32.clz",e.i64_clz="~lib/builtins/i64.clz",e.i32_ctz="~lib/builtins/i32.ctz",e.i64_ctz="~lib/builtins/i64.ctz",e.i32_popcnt="~lib/builtins/i32.popcnt",e.i64_popcnt="~lib/builtins/i64.popcnt",e.i32_rotl="~lib/builtins/i32.rotl",e.i64_rotl="~lib/builtins/i64.rotl",e.i32_rotr="~lib/builtins/i32.rotr",e.i64_rotr="~lib/builtins/i64.rotr",e.f32_abs="~lib/builtins/f32.abs",e.f64_abs="~lib/builtins/f64.abs",e.f32_max="~lib/builtins/f32.max",e.f64_max="~lib/builtins/f64.max",e.f32_min="~lib/builtins/f32.min",e.f64_min="~lib/builtins/f64.min",e.f32_ceil="~lib/builtins/f32.ceil",e.f64_ceil="~lib/builtins/f64.ceil",e.f32_floor="~lib/builtins/f32.floor",e.f64_floor="~lib/builtins/f64.floor",e.f32_copysign="~lib/builtins/f32.copysign",e.f64_copysign="~lib/builtins/f64.copysign",e.f32_nearest="~lib/builtins/f32.nearest",e.f64_nearest="~lib/builtins/f64.nearest",e.i32_reinterpret_f32="~lib/builtins/i32.reinterpret_f32",e.i64_reinterpret_f64="~lib/builtins/i64.reinterpret_f64",e.f32_reinterpret_i32="~lib/builtins/f32.reinterpret_i32",e.f64_reinterpret_i64="~lib/builtins/f64.reinterpret_i64",e.f32_sqrt="~lib/builtins/f32.sqrt",e.f64_sqrt="~lib/builtins/f64.sqrt",e.f32_trunc="~lib/builtins/f32.trunc",e.f64_trunc="~lib/builtins/f64.trunc",e.i32_load8_s="~lib/builtins/i32.load8_s",e.i32_load8_u="~lib/builtins/i32.load8_u",e.i32_load16_s="~lib/builtins/i32.load16_s",e.i32_load16_u="~lib/builtins/i32.load16_u",e.i32_load="~lib/builtins/i32.load",e.i64_load8_s="~lib/builtins/i64.load8_s",e.i64_load8_u="~lib/builtins/i64.load8_u",e.i64_load16_s="~lib/builtins/i64.load16_s",e.i64_load16_u="~lib/builtins/i64.load16_u",e.i64_load32_s="~lib/builtins/i64.load32_s",e.i64_load32_u="~lib/builtins/i64.load32_u",e.i64_load="~lib/builtins/i64.load",e.f32_load="~lib/builtins/f32.load",e.f64_load="~lib/builtins/f64.load",e.i32_store8="~lib/builtins/i32.store8",e.i32_store16="~lib/builtins/i32.store16",e.i32_store="~lib/builtins/i32.store",e.i64_store8="~lib/builtins/i64.store8",e.i64_store16="~lib/builtins/i64.store16",e.i64_store32="~lib/builtins/i64.store32",e.i64_store="~lib/builtins/i64.store",e.f32_store="~lib/builtins/f32.store",e.f64_store="~lib/builtins/f64.store",e.i32_atomic_load8_u="~lib/builtins/i32.atomic.load8_u",e.i32_atomic_load16_u="~lib/builtins/i32.atomic.load16_u",e.i32_atomic_load="~lib/builtins/i32.atomic.load",e.i64_atomic_load8_u="~lib/builtins/i64.atomic.load8_u",e.i64_atomic_load16_u="~lib/builtins/i64.atomic.load16_u",e.i64_atomic_load32_u="~lib/builtins/i64.atomic.load32_u",e.i64_atomic_load="~lib/builtins/i64.atomic.load",e.i32_atomic_store8="~lib/builtins/i32.atomic.store8",e.i32_atomic_store16="~lib/builtins/i32.atomic.store16",e.i32_atomic_store="~lib/builtins/i32.atomic.store",e.i64_atomic_store8="~lib/builtins/i64.atomic.store8",e.i64_atomic_store16="~lib/builtins/i64.atomic.store16",e.i64_atomic_store32="~lib/builtins/i64.atomic.store32",e.i64_atomic_store="~lib/builtins/i64.atomic.store",e.i32_atomic_rmw8_add_u="~lib/builtins/i32.atomic.rmw8.add_u",e.i32_atomic_rmw16_add_u="~lib/builtins/i32.atomic.rmw16.add_u",e.i32_atomic_rmw_add="~lib/builtins/i32.atomic.rmw.add",e.i64_atomic_rmw8_add_u="~lib/builtins/i64.atomic.rmw8.add_u",e.i64_atomic_rmw16_add_u="~lib/builtins/i64.atomic.rmw16.add_u",e.i64_atomic_rmw32_add_u="~lib/builtins/i64.atomic.rmw32.add_u",e.i64_atomic_rmw_add="~lib/builtins/i64.atomic.rmw.add",e.i32_atomic_rmw8_sub_u="~lib/builtins/i32.atomic.rmw8.sub_u",e.i32_atomic_rmw16_sub_u="~lib/builtins/i32.atomic.rmw16.sub_u",e.i32_atomic_rmw_sub="~lib/builtins/i32.atomic.rmw.sub",e.i64_atomic_rmw8_sub_u="~lib/builtins/i64.atomic.rmw8.sub_u",e.i64_atomic_rmw16_sub_u="~lib/builtins/i64.atomic.rmw16.sub_u",e.i64_atomic_rmw32_sub_u="~lib/builtins/i64.atomic.rmw32.sub_u",e.i64_atomic_rmw_sub="~lib/builtins/i64.atomic.rmw.sub",e.i32_atomic_rmw8_and_u="~lib/builtins/i32.atomic.rmw8.and_u",e.i32_atomic_rmw16_and_u="~lib/builtins/i32.atomic.rmw16.and_u",e.i32_atomic_rmw_and="~lib/builtins/i32.atomic.rmw.and",e.i64_atomic_rmw8_and_u="~lib/builtins/i64.atomic.rmw8.and_u",e.i64_atomic_rmw16_and_u="~lib/builtins/i64.atomic.rmw16.and_u",e.i64_atomic_rmw32_and_u="~lib/builtins/i64.atomic.rmw32.and_u",e.i64_atomic_rmw_and="~lib/builtins/i64.atomic.rmw.and",e.i32_atomic_rmw8_or_u="~lib/builtins/i32.atomic.rmw8.or_u",e.i32_atomic_rmw16_or_u="~lib/builtins/i32.atomic.rmw16.or_u",e.i32_atomic_rmw_or="~lib/builtins/i32.atomic.rmw.or",e.i64_atomic_rmw8_or_u="~lib/builtins/i64.atomic.rmw8.or_u",e.i64_atomic_rmw16_or_u="~lib/builtins/i64.atomic.rmw16.or_u",e.i64_atomic_rmw32_or_u="~lib/builtins/i64.atomic.rmw32.or_u",e.i64_atomic_rmw_or="~lib/builtins/i64.atomic.rmw.or",e.i32_atomic_rmw8_u_xor="~lib/builtins/i32.atomic.rmw8.xor_u",e.i32_atomic_rmw16_u_xor="~lib/builtins/i32.atomic.rmw16.xor_u",e.i32_atomic_rmw_xor="~lib/builtins/i32.atomic.rmw.xor",e.i64_atomic_rmw8_xor_u="~lib/builtins/i64.atomic.rmw8.xor_u",e.i64_atomic_rmw16_xor_u="~lib/builtins/i64.atomic.rmw16.xor_u",e.i64_atomic_rmw32_xor_u="~lib/builtins/i64.atomic.rmw32.xor_u",e.i64_atomic_rmw_xor="~lib/builtins/i64.atomic.rmw.xor",e.i32_atomic_rmw8_xchg_u="~lib/builtins/i32.atomic.rmw8.xchg_u",e.i32_atomic_rmw16_xchg_u="~lib/builtins/i32.atomic.rmw16.xchg_u",e.i32_atomic_rmw_xchg="~lib/builtins/i32.atomic.rmw.xchg",e.i64_atomic_rmw8_xchg_u="~lib/builtins/i64.atomic.rmw8.xchg_u",e.i64_atomic_rmw16_xchg_u="~lib/builtins/i64.atomic.rmw16.xchg_u",e.i64_atomic_rmw32_xchg_u="~lib/builtins/i64.atomic.rmw32.xchg_u",e.i64_atomic_rmw_xchg="~lib/builtins/i64.atomic.rmw.xchg",e.i32_atomic_rmw8_cmpxchg_u="~lib/builtins/i32.atomic.rmw8.cmpxchg_u",e.i32_atomic_rmw16_cmpxchg_u="~lib/builtins/i32.atomic.rmw16.cmpxchg_u",e.i32_atomic_rmw_cmpxchg="~lib/builtins/i32.atomic.rmw.cmpxchg",e.i64_atomic_rmw8_cmpxchg_u="~lib/builtins/i64.atomic.rmw8.cmpxchg_u",e.i64_atomic_rmw16_cmpxchg_u="~lib/builtins/i64.atomic.rmw16.cmpxchg_u",e.i64_atomic_rmw32_cmpxchg_u="~lib/builtins/i64.atomic.rmw32.cmpxchg_u",e.i64_atomic_rmw_cmpxchg="~lib/builtins/i64.atomic.rmw.cmpxchg",e.i32_wait="~lib/builtins/i32.wait",e.i64_wait="~lib/builtins/i64.wait",e.v128_splat="~lib/builtins/v128.splat",e.v128_extract_lane="~lib/builtins/v128.extract_lane",e.v128_replace_lane="~lib/builtins/v128.replace_lane",e.v128_shuffle="~lib/builtins/v128.shuffle",e.v128_load="~lib/builtins/v128.load",e.v128_store="~lib/builtins/v128.store",e.v128_add="~lib/builtins/v128.add",e.v128_sub="~lib/builtins/v128.sub",e.v128_mul="~lib/builtins/v128.mul",e.v128_div="~lib/builtins/v128.div",e.v128_neg="~lib/builtins/v128.neg",e.v128_add_saturate="~lib/builtins/v128.add_saturate",e.v128_sub_saturate="~lib/builtins/v128.sub_saturate",e.v128_shl="~lib/builtins/v128.shl",e.v128_shr="~lib/builtins/v128.shr",e.v128_and="~lib/builtins/v128.and",e.v128_or="~lib/builtins/v128.or",e.v128_xor="~lib/builtins/v128.xor",e.v128_not="~lib/builtins/v128.not",e.v128_bitselect="~lib/builtins/v128.bitselect",e.v128_any_true="~lib/builtins/v128.any_true",e.v128_all_true="~lib/builtins/v128.all_true",e.v128_min="~lib/builtins/v128.min",e.v128_max="~lib/builtins/v128.max",e.v128_abs="~lib/builtins/v128.abs",e.v128_sqrt="~lib/builtins/v128.sqrt",e.v128_eq="~lib/builtins/v128.eq",e.v128_ne="~lib/builtins/v128.ne",e.v128_lt="~lib/builtins/v128.lt",e.v128_le="~lib/builtins/v128.le",e.v128_gt="~lib/builtins/v128.gt",e.v128_ge="~lib/builtins/v128.ge",e.v128_convert="~lib/builtins/v128.convert",e.v128_trunc="~lib/builtins/v128.trunc",e.i8x16="~lib/builtins/i8x16",e.i16x8="~lib/builtins/i16x8",e.i32x4="~lib/builtins/i32x4",e.i64x2="~lib/builtins/i64x2",e.f32x4="~lib/builtins/f32x4",e.f64x2="~lib/builtins/f64x2",e.i8x16_splat="~lib/builtins/i8x16.splat",e.i8x16_extract_lane_s="~lib/builtins/i8x16.extract_lane_s",e.i8x16_extract_lane_u="~lib/builtins/i8x16.extract_lane_u",e.i8x16_replace_lane="~lib/builtins/i8x16.replace_lane",e.i8x16_add="~lib/builtins/i8x16.add",e.i8x16_sub="~lib/builtins/i8x16.sub",e.i8x16_mul="~lib/builtins/i8x16.mul",e.i8x16_neg="~lib/builtins/i8x16.neg",e.i8x16_add_saturate_s="~lib/builtins/i8x16.add_saturate_s",e.i8x16_add_saturate_u="~lib/builtins/i8x16.add_saturate_u",e.i8x16_sub_saturate_s="~lib/builtins/i8x16.sub_saturate_s",e.i8x16_sub_saturate_u="~lib/builtins/i8x16.sub_saturate_u",e.i8x16_shl="~lib/builtins/i8x16.shl",e.i8x16_shr_s="~lib/builtins/i8x16.shr_s",e.i8x16_shr_u="~lib/builtins/i8x16.shr_u",e.i8x16_any_true="~lib/builtins/i8x16.any_true",e.i8x16_all_true="~lib/builtins/i8x16.all_true",e.i8x16_eq="~lib/builtins/i8x16.eq",e.i8x16_ne="~lib/builtins/i8x16.ne",e.i8x16_lt_s="~lib/builtins/i8x16.lt_s",e.i8x16_lt_u="~lib/builtins/i8x16.lt_u",e.i8x16_le_s="~lib/builtins/i8x16.le_s",e.i8x16_le_u="~lib/builtins/i8x16.le_u",e.i8x16_gt_s="~lib/builtins/i8x16.gt_s",e.i8x16_gt_u="~lib/builtins/i8x16.gt_u",e.i8x16_ge_s="~lib/builtins/i8x16.ge_s",e.i8x16_ge_u="~lib/builtins/i8x16.ge_u",e.i16x8_splat="~lib/builtins/i16x8.splat",e.i16x8_extract_lane_s="~lib/builtins/i16x8.extract_lane_s",e.i16x8_extract_lane_u="~lib/builtins/i16x8.extract_lane_u",e.i16x8_replace_lane="~lib/builtins/i16x8.replace_lane",e.i16x8_add="~lib/builtins/i16x8.add",e.i16x8_sub="~lib/builtins/i16x8.sub",e.i16x8_mul="~lib/builtins/i16x8.mul",e.i16x8_neg="~lib/builtins/i16x8.neg",e.i16x8_add_saturate_s="~lib/builtins/i16x8.add_saturate_s",e.i16x8_add_saturate_u="~lib/builtins/i16x8.add_saturate_u",e.i16x8_sub_saturate_s="~lib/builtins/i16x8.sub_saturate_s",e.i16x8_sub_saturate_u="~lib/builtins/i16x8.sub_saturate_u",e.i16x8_shl="~lib/builtins/i16x8.shl",e.i16x8_shr_s="~lib/builtins/i16x8.shr_s",e.i16x8_shr_u="~lib/builtins/i16x8.shr_u",e.i16x8_any_true="~lib/builtins/i16x8.any_true",e.i16x8_all_true="~lib/builtins/i16x8.all_true",e.i16x8_eq="~lib/builtins/i16x8.eq",e.i16x8_ne="~lib/builtins/i16x8.ne",e.i16x8_lt_s="~lib/builtins/i16x8.lt_s",e.i16x8_lt_u="~lib/builtins/i16x8.lt_u",e.i16x8_le_s="~lib/builtins/i16x8.le_s",e.i16x8_le_u="~lib/builtins/i16x8.le_u",e.i16x8_gt_s="~lib/builtins/i16x8.gt_s",e.i16x8_gt_u="~lib/builtins/i16x8.gt_u",e.i16x8_ge_s="~lib/builtins/i16x8.ge_s",e.i16x8_ge_u="~lib/builtins/i16x8.ge_u",e.i32x4_splat="~lib/builtins/i32x4.splat",e.i32x4_extract_lane="~lib/builtins/i32x4.extract_lane",e.i32x4_replace_lane="~lib/builtins/i32x4.replace_lane",e.i32x4_add="~lib/builtins/i32x4.add",e.i32x4_sub="~lib/builtins/i32x4.sub",e.i32x4_mul="~lib/builtins/i32x4.mul",e.i32x4_neg="~lib/builtins/i32x4.neg",e.i32x4_shl="~lib/builtins/i32x4.shl",e.i32x4_shr_s="~lib/builtins/i32x4.shr_s",e.i32x4_shr_u="~lib/builtins/i32x4.shr_u",e.i32x4_any_true="~lib/builtins/i32x4.any_true",e.i32x4_all_true="~lib/builtins/i32x4.all_true",e.i32x4_eq="~lib/builtins/i32x4.eq",e.i32x4_ne="~lib/builtins/i32x4.ne",e.i32x4_lt_s="~lib/builtins/i32x4.lt_s",e.i32x4_lt_u="~lib/builtins/i32x4.lt_u",e.i32x4_le_s="~lib/builtins/i32x4.le_s",e.i32x4_le_u="~lib/builtins/i32x4.le_u",e.i32x4_gt_s="~lib/builtins/i32x4.gt_s",e.i32x4_gt_u="~lib/builtins/i32x4.gt_u",e.i32x4_ge_s="~lib/builtins/i32x4.ge_s",e.i32x4_ge_u="~lib/builtins/i32x4.ge_u",e.i32x4_trunc_s_f32x4_sat="~lib/builtins/i32x4.trunc_s_f32x4_sat",e.i32x4_trunc_u_f32x4_sat="~lib/builtins/i32x4.trunc_u_f32x4_sat",e.i64x2_splat="~lib/builtins/i64x2.splat",e.i64x2_extract_lane="~lib/builtins/i64x2.extract_lane",e.i64x2_replace_lane="~lib/builtins/i64x2.replace_lane",e.i64x2_add="~lib/builtins/i64x2.add",e.i64x2_sub="~lib/builtins/i64x2.sub",e.i64x2_neg="~lib/builtins/i64x2.neg",e.i64x2_shl="~lib/builtins/i64x2.shl",e.i64x2_shr_s="~lib/builtins/i64x2.shr_s",e.i64x2_shr_u="~lib/builtins/i64x2.shr_u",e.i64x2_any_true="~lib/builtins/i64x2.any_true",e.i64x2_all_true="~lib/builtins/i64x2.all_true",e.i64x2_trunc_s_f64x2_sat="~lib/builtins/i64x2.trunc_s_f64x2_sat",e.i64x2_trunc_u_f64x2_sat="~lib/builtins/i64x2.trunc_u_f64x2_sat",e.f32x4_splat="~lib/builtins/f32x4.splat",e.f32x4_extract_lane="~lib/builtins/f32x4.extract_lane",e.f32x4_replace_lane="~lib/builtins/f32x4.replace_lane",e.f32x4_add="~lib/builtins/f32x4.add",e.f32x4_sub="~lib/builtins/f32x4.sub",e.f32x4_mul="~lib/builtins/f32x4.mul",e.f32x4_div="~lib/builtins/f32x4.div",e.f32x4_neg="~lib/builtins/f32x4.neg",e.f32x4_min="~lib/builtins/f32x4.min",e.f32x4_max="~lib/builtins/f32x4.max",e.f32x4_abs="~lib/builtins/f32x4.abs",e.f32x4_sqrt="~lib/builtins/f32x4.sqrt",e.f32x4_eq="~lib/builtins/f32x4.eq",e.f32x4_ne="~lib/builtins/f32x4.ne",e.f32x4_lt="~lib/builtins/f32x4.lt",e.f32x4_le="~lib/builtins/f32x4.le",e.f32x4_gt="~lib/builtins/f32x4.gt",e.f32x4_ge="~lib/builtins/f32x4.ge",e.f32x4_convert_s_i32x4="~lib/builtins/f32x4.convert_s_i32x4",e.f32x4_convert_u_i32x4="~lib/builtins/f32x4.convert_u_i32x4",e.f64x2_splat="~lib/builtins/f64x2.splat",e.f64x2_extract_lane="~lib/builtins/f64x2.extract_lane",e.f64x2_replace_lane="~lib/builtins/f64x2.replace_lane",e.f64x2_add="~lib/builtins/f64x2.add",e.f64x2_sub="~lib/builtins/f64x2.sub",e.f64x2_mul="~lib/builtins/f64x2.mul",e.f64x2_div="~lib/builtins/f64x2.div",e.f64x2_neg="~lib/builtins/f64x2.neg",e.f64x2_min="~lib/builtins/f64x2.min",e.f64x2_max="~lib/builtins/f64x2.max",e.f64x2_abs="~lib/builtins/f64x2.abs",e.f64x2_sqrt="~lib/builtins/f64x2.sqrt",e.f64x2_eq="~lib/builtins/f64x2.eq",e.f64x2_ne="~lib/builtins/f64x2.ne",e.f64x2_lt="~lib/builtins/f64x2.lt",e.f64x2_le="~lib/builtins/f64x2.le",e.f64x2_gt="~lib/builtins/f64x2.gt",e.f64x2_ge="~lib/builtins/f64x2.ge",e.f64x2_convert_s_i64x2="~lib/builtins/f64x2.convert_s_i64x2",e.f64x2_convert_u_i64x2="~lib/builtins/f64x2.convert_u_i64x2",e.v8x16_shuffle="~lib/builtins/v8x16.shuffle",e.heap_base="~lib/heap/__heap_base",e.rtti_base="~lib/rt/__rtti_base",e.visit_globals="~lib/rt/__visit_globals",e.visit_members="~lib/rt/__visit_members",e.ERROR="~lib/diagnostics/ERROR",e.WARNING="~lib/diagnostics/WARNING",e.INFO="~lib/diagnostics/INFO",e.memory_size="~lib/memory/memory.size",e.memory_grow="~lib/memory/memory.grow",e.memory_copy="~lib/memory/memory.copy",e.memory_fill="~lib/memory/memory.fill",e.memory_allocate="~lib/memory/memory.allocate",e.memory_free="~lib/memory/memory.free",e.memory_reset="~lib/memory/memory.reset",e.runtime_instanceof="~lib/runtime/runtime.instanceof",e.runtime_flags="~lib/runtime/runtime.flags",e.runtime_allocate="~lib/util/runtime/allocate",e.runtime_reallocate="~lib/util/runtime/reallocate",e.runtime_register="~lib/util/runtime/register",e.runtime_discard="~lib/util/runtime/discard",e.runtime_makeArray="~lib/util/runtime/makeArray",e.Int8Array="~lib/typedarray/Int8Array",e.Uint8Array="~lib/typedarray/Uint8Array",e.Int16Array="~lib/typedarray/Int16Array",e.Uint16Array="~lib/typedarray/Uint16Array",e.Int32Array="~lib/typedarray/Int32Array",e.Uint32Array="~lib/typedarray/Uint32Array",e.Int64Array="~lib/typedarray/Int64Array",e.Uint64Array="~lib/typedarray/Uint64Array",e.Uint8ClampedArray="~lib/typedarray/Uint8ClampedArray",e.Float32Array="~lib/typedarray/Float32Array",e.Float64Array="~lib/typedarray/Float64Array",e.started="~lib/started",e.argc="~lib/argc",e.setargc="~lib/setargc",e.capabilities="~lib/capabilities"}(a=r.BuiltinSymbols||(r.BuiltinSymbols={})),r.compileCall=m,r.compileAbort=T,r.compileVisitGlobals=function(e){var r,t,i=e.module,s=new Array,o=e.ensureFunctionType([l.Type.u32],l.Type.void),c=e.options.nativeSizeType,_=assert(e.program.visitInstance);e.compileFunction(_);try{for(var h=n(e.program.elementsByName.values()),y=h.next();!y.done;y=h.next()){var m=y.value;if(m.kind==p.ElementKind.GLOBAL){var f=m,T=f.type.classReference;if(f.is(d.CommonFlags.COMPILED)&&null!==T&&!T.hasDecorator(p.DecoratorFlags.UNMANAGED))if(f.is(d.CommonFlags.INLINED)){var g=f.constantIntegerValue;(i64_low(g)||i64_high(g))&&s.push(i.call(_.internalName,[e.options.isWasm64?i.i64(i64_low(g),i64_high(g)):i.i32(i64_low(g))],u.NativeType.None))}else s.push(i.if(i.local_tee(1,i.global_get(f.internalName,c)),i.call(_.internalName,[i.local_get(1,c),i.local_get(0,u.NativeType.I32)],u.NativeType.None)))}}}catch(e){r={error:e}}finally{try{y&&!y.done&&(t=h.return)&&t.call(h)}finally{if(r)throw r.error}}i.addFunction(a.visit_globals,o,[c],s.length?i.block(null,s):i.nop())},r.compileVisitMembers=function(e){var r,t,o,c,_,h,d=e.program,y=e.module,m=d.options.usizeType,f=m.toNativeType(),T=m.byteSize,g=e.ensureFunctionType([m,l.Type.i32],l.Type.void),E=d.managedClasses,v=assert(d.visitInstance),b=new Array,I=u.Relooper.create(y),x=I.addBlockWithSwitch(y.nop(),y.load(T,!1,f==u.NativeType.I64?y.binary(u.BinaryOp.SubI64,y.local_get(0,f),y.i64(8)):y.binary(u.BinaryOp.SubI32,y.local_get(0,f),y.i32(8)),u.NativeType.I32,0)),A=0;try{for(var N=n(E),S=N.next();!S.done;S=N.next()){var O=i(S.value,2),C=O[0],k=O[1];assert(k.type.isManaged),assert(C==A++);var L=void 0;if(k.isDeclaredInLibrary&&(L=k.lookupInSelf("__visit_impl"))){assert(L.kind==p.ElementKind.FUNCTION_PROTOTYPE);var R=d.resolver.resolveFunction(L,null),F=void 0;if(R&&e.compileFunction(R)){var B=R.signature;assert(1==B.parameterTypes.length&&B.parameterTypes[0]==l.Type.u32&&B.returnType==l.Type.void&&B.thisType==k.type);var D=y.call(R.internalName,[y.local_get(0,f),y.local_get(1,u.NativeType.I32)],u.NativeType.None);F=I.addBlock(k.base?D:y.block(null,[D,y.return()]))}else F=I.addBlock(y.unreachable());I.addBranchForSwitch(x,F,[C]),b.push(F)}else{var P=new Array,w=k.members;if(w)try{for(var U=(o=void 0,n(w.values())),M=U.next();!M.done;M=U.next()){var V=M.value;if(V.kind==p.ElementKind.FIELD&&V.parent===k&&V.type.isManaged){var G=V.memoryOffset;assert(G>=0),P.push(y.if(y.local_tee(2,y.load(T,!1,y.local_get(0,f),f,G)),y.call(v.internalName,[y.local_get(2,f),y.local_get(1,u.NativeType.I32)],u.NativeType.None)))}}}catch(e){o={error:e}}finally{try{M&&!M.done&&(c=U.return)&&c.call(U)}finally{if(o)throw o.error}}k.base||P.push(y.return()),F=I.addBlock(s.flatten(y,P,u.NativeType.None)),I.addBranchForSwitch(x,F,[C]),b.push(F)}}}catch(e){r={error:e}}finally{try{S&&!S.done&&(t=N.return)&&t.call(N)}finally{if(r)throw r.error}}try{for(var K=n(E),z=K.next();!z.done;z=K.next()){var Y=i(z.value,2),H=(C=Y[0],(k=Y[1]).base);H&&I.addBranch(b[C],b[H.id])}}catch(e){_={error:e}}finally{try{z&&!z.done&&(h=K.return)&&h.call(K)}finally{if(_)throw _.error}}b.push(I.addBlock(y.unreachable())),I.addBranchForSwitch(x,b[b.length-1],[]),e.compileFunction(v),y.addFunction(a.visit_members,g,[f],I.renderAndDispose(x,2))},r.compileRTTI=function(e){var r,t,s=e.program,o=e.module,c=s.managedClasses,l=c.size,p=4+8*l,_=new Uint8Array(p);y.writeI32(l,_,0);var h=4,d=s.arrayBufferViewInstance,m=d.prototype,f=s.arrayPrototype,T=s.setPrototype,E=s.mapPrototype,v=0;try{for(var b=n(c),I=b.next();!I.done;I=b.next()){var x=i(I.value,2),A=x[0],N=x[1];assert(A==v++);var S=0;if(N.isAcyclic&&(S|=16),N!==d&&N.extends(m)){var O=N.getArrayValueType();S|=1,N.extends(f)&&(S|=2),S|=32*g(O)}else if(N.extends(T)){var C=assert(N.getTypeArgumentsTo(T));assert(1==C.length),S|=4,S|=32*g(C[0])}else N.extends(E)&&(C=assert(N.getTypeArgumentsTo(E)),assert(2==C.length),S|=8,S|=16384*g(C[0]),S|=32*g(C[1]));y.writeI32(S,_,h),h+=4,N.rttiFlags=S;var k=N.base;y.writeI32(k?k.id:0,_,h),h+=4}}catch(e){r={error:e}}finally{try{I&&!I.done&&(t=b.return)&&t.call(b)}finally{if(r)throw r.error}}assert(h==p);var L=s.options.usizeType,R=e.addMemorySegment(_);if(8==L.size){var F=R.offset;o.addGlobal(a.rtti_base,u.NativeType.I64,!1,o.i64(i64_low(F),i64_high(F)))}else o.addGlobal(a.rtti_base,u.NativeType.I32,!1,o.i32(i64_low(R.offset)))}},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n=t(4),i=function(){function e(){this.text=[],this.functionId=0}return e.decompile=function(r){var t=new e;return t.decompile(r),t.finish()},e.prototype.decompile=function(e){throw new Error("not implemented")},e.prototype.decompileFunction=function(e){var r=n.getFunctionName(e)||"$"+this.functionId.toString(10),t=n.getFunctionBody(e);this.push("function "),this.push(r),this.push("(");for(var i=0,s=n.getFunctionParamCount(e);i0&&this.push(", "),this.push("$"),this.push(i.toString(10)),this.push(": "),this.push(a(n.getFunctionParamType(e,i)));this.push("): "),this.push(a(n.getFunctionResultType(e))),this.push(" "),n.getExpressionId(t)!=n.ExpressionId.Block&&this.push("{\n"),this.decompileExpression(t),n.getExpressionId(t)!=n.ExpressionId.Block&&this.push("\n}\n"),++this.functionId},e.prototype.decompileExpression=function(e){var r,t,i,s,o=n.getExpressionId(e),c=n.getExpressionType(e);switch(o){case n.ExpressionId.Block:for(null!=(t=n.getBlockName(e))&&(this.push(t),this.push(": ")),this.push("{\n"),s=n.getBlockChildCount(e),i=0;i("),this.push(n.getLoadOffset(e).toString(10)),this.push(" + "),this.decompileExpression(n.getLoadPtr(e)),void this.push(")");case n.ExpressionId.Store:return this.push("store<"),this.push(a(c)),this.push(">("),this.push(n.getStoreOffset(e).toString(10)),this.push(" + "),this.decompileExpression(n.getStorePtr(e)),this.push(", "),this.decompileExpression(n.getStoreValue(e)),void this.push(")");case n.ExpressionId.Const:switch(c){case n.NativeType.I32:return void this.push(n.getConstValueI32(e).toString(10));case n.NativeType.I64:return void this.push(i64_to_string(i64_new(n.getConstValueI64Low(e),n.getConstValueI64High(e))));case n.NativeType.F32:return void this.push(n.getConstValueF32(e).toString(10));case n.NativeType.F64:return void this.push(n.getConstValueF64(e).toString(10))}break;case n.ExpressionId.Unary:switch(n.getUnaryOp(e)){case n.UnaryOp.ClzI32:return this.push("clz("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.CtzI32:return this.push("ctz("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.PopcntI32:return this.push("popcnt("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.NegF32:case n.UnaryOp.NegF64:return this.push("-"),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.AbsF32:return this.push("abs("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.CeilF32:return this.push("ceil("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.FloorF32:return this.push("floor("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.TruncF32:return this.push("trunc("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.NearestF32:return this.push("nearest("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.SqrtF32:return this.push("sqrt("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.EqzI32:case n.UnaryOp.EqzI64:return this.push("!"),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ClzI64:return this.push("clz("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.CtzI64:return this.push("ctz("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.PopcntI64:return this.push("popcnt("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.AbsF64:return this.push("abs("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.CeilF64:return this.push("ceil("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.FloorF64:return this.push("floor("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.TruncF64:return this.push("trunc("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.NearestF64:return this.push("nearest("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.SqrtF64:return this.push("sqrt("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.ExtendI32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ExtendU32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.WrapI64:case n.UnaryOp.TruncF32ToI32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF32ToI64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF32ToU32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF32ToU64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF64ToI32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF64ToI64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF64ToU32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF64ToU64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ReinterpretF32:return this.push("reinterpret("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.ReinterpretF64:return this.push("reinterpret("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.ConvertI32ToF32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertI32ToF64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertU32ToF32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertU32ToF64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertI64ToF32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertI64ToF64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertU64ToF32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertU64ToF64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.PromoteF32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.DemoteF64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ReinterpretI32:return this.push("reinterpret("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.ReinterpretI64:return this.push("reinterpret("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")")}break;case n.ExpressionId.Binary:switch(n.getBinaryOp(e)){case n.BinaryOp.AddI32:case n.BinaryOp.AddI64:case n.BinaryOp.AddF32:case n.BinaryOp.AddF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" + "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.SubI32:case n.BinaryOp.SubI64:case n.BinaryOp.SubF32:case n.BinaryOp.SubF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" - "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.MulI32:case n.BinaryOp.MulI64:case n.BinaryOp.MulF32:case n.BinaryOp.MulF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" * "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.DivI32:case n.BinaryOp.DivI64:case n.BinaryOp.DivF32:case n.BinaryOp.DivF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" / "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.DivU32:return this.push("("),this.decompileExpression(n.getBinaryLeft(e)),this.push(" / "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.RemI32:case n.BinaryOp.RemI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" % "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.RemU32:return this.push("("),this.decompileExpression(n.getBinaryLeft(e)),this.push(" / "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.AndI32:case n.BinaryOp.AndI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" & "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.OrI32:case n.BinaryOp.OrI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" | "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.XorI32:case n.BinaryOp.XorI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" ^ "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.ShlI32:case n.BinaryOp.ShlI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" << "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.ShrU32:case n.BinaryOp.ShrU64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" >>> "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.ShrI32:case n.BinaryOp.ShrI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" >> "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.RotlI32:return this.push("rotl("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.RotrI32:return this.push("rotr("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.EqI32:case n.BinaryOp.EqI64:case n.BinaryOp.EqF32:case n.BinaryOp.EqF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" == "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.NeI32:case n.BinaryOp.NeI64:case n.BinaryOp.NeF32:case n.BinaryOp.NeF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" != "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.LtI32:case n.BinaryOp.LtI64:case n.BinaryOp.LtF32:case n.BinaryOp.LtF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" < "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.LtU32:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" < "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.LeI32:case n.BinaryOp.LeI64:case n.BinaryOp.LeF32:case n.BinaryOp.LeF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" <= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.LeU32:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" <= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GtI32:case n.BinaryOp.GtI64:case n.BinaryOp.GtF32:case n.BinaryOp.GtF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" > "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GtU32:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" > "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GeI32:case n.BinaryOp.GeI64:case n.BinaryOp.GeF32:case n.BinaryOp.GeF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" >= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GeU32:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" >= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.DivU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" / "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.RemU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" % "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.RotlI64:return this.push("rotl("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.RotrI64:return this.push("rotr("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.LtU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" < "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.LeU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" <= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GtU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" > "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GeU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" >= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.CopysignF32:return this.push("copysign("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.MinF32:return this.push("min("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.MaxF32:return this.push("max("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.CopysignF64:return this.push("copysign("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.MinF64:return this.push("min("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.MaxF64:return this.push("max("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")")}return;case n.ExpressionId.Select:return this.push("select<"),this.push(a(c)),this.push(">("),this.decompileExpression(n.getSelectThen(e)),this.push(", "),this.decompileExpression(n.getSelectElse(e)),this.push(", "),this.decompileExpression(n.getSelectCondition(e)),void this.push(")");case n.ExpressionId.Drop:return this.decompileExpression(n.getDropValue(e)),void this.push(";\n");case n.ExpressionId.Return:return void((r=n.getReturnValue(e))?(this.push("return "),this.decompileExpression(r),this.push(";\n")):this.push("return;\n"));case n.ExpressionId.Host:switch(n.getHostOp(e)){case n.HostOp.MemorySize:return void this.push("memory.size()");case n.HostOp.MemoryGrow:return this.push("memory.grow("),this.decompileExpression(n.getHostOperand(e,0)),void this.push(")")}break;case n.ExpressionId.Nop:return void this.push(";\n");case n.ExpressionId.Unreachable:return void this.push("unreachable()");case n.ExpressionId.AtomicCmpxchg:case n.ExpressionId.AtomicRMW:case n.ExpressionId.AtomicWait:case n.ExpressionId.AtomicNotify:}throw new Error("not implemented")},e.prototype.push=function(e){this.text.push(e)},e.prototype.finish=function(){var e=this.text.join("");return this.text=[],e},e}();function a(e){switch(e){case n.NativeType.None:return"void";case n.NativeType.I32:return"i32";case n.NativeType.I64:return"i64";case n.NativeType.F32:return"f32";case n.NativeType.F64:return"f64";case n.NativeType.V128:return"v128";case n.NativeType.Unreachable:throw new Error("unreachable type");case n.NativeType.Auto:throw new Error("auto type");default:throw new Error("unexpected type")}}r.Decompiler=i},function(e,r,t){"use strict";var n,i=this&&this.__extends||(n=function(e,r){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,r){e.__proto__=r}||function(e,r){for(var t in r)r.hasOwnProperty(t)&&(e[t]=r[t])})(e,r)},function(e,r){function t(){this.constructor=e}n(e,r),e.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)}),a=this&&this.__values||function(e){var r="function"==typeof Symbol&&e[Symbol.iterator],t=0;return r?r.call(e):{next:function(){return e&&t>=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},s=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0});var o=t(0),c=t(3),l=t(1),u=function(){function e(e,r){void 0===r&&(r=!1),this.seen=new Map,this.program=e,this.includePrivate}return e.prototype.walk=function(){var e,r;try{for(var t=a(this.program.filesByName.values()),n=t.next();!n.done;n=t.next()){var i=n.value;i.source.isEntry&&this.visitFile(i)}}catch(r){e={error:r}}finally{try{n&&!n.done&&(r=t.return)&&r.call(t)}finally{if(e)throw e.error}}},e.prototype.visitFile=function(e){var r,t,n,i,o=e.exports;if(o)try{for(var c=a(o),l=c.next();!l.done;l=c.next()){var u=s(l.value,2),p=u[0],_=u[1];this.visitElement(p,_)}}catch(e){r={error:e}}finally{try{l&&!l.done&&(t=c.return)&&t.call(c)}finally{if(r)throw r.error}}var h=e.exportsStar;if(h)try{for(var d=a(h),y=d.next();!y.done;y=d.next()){var m=y.value;this.visitFile(m)}}catch(e){n={error:e}}finally{try{y&&!y.done&&(i=d.return)&&i.call(d)}finally{if(n)throw n.error}}},e.prototype.visitElement=function(e,r){if(!r.is(o.CommonFlags.PRIVATE)||this.includePrivate){var t=this.seen;if(t.has(r))this.visitAlias(e,r,t.get(r));else switch(t.set(r,e),r.kind){case c.ElementKind.GLOBAL:r.is(o.CommonFlags.COMPILED)&&this.visitGlobal(e,r);break;case c.ElementKind.ENUM:r.is(o.CommonFlags.COMPILED)&&this.visitEnum(e,r);break;case c.ElementKind.FUNCTION_PROTOTYPE:this.visitFunctionInstances(e,r);break;case c.ElementKind.CLASS_PROTOTYPE:this.visitClassInstances(e,r);break;case c.ElementKind.FIELD:r.is(o.CommonFlags.COMPILED)&&this.visitField(e,r);break;case c.ElementKind.PROPERTY_PROTOTYPE:this.visitPropertyInstances(e,r);break;case c.ElementKind.PROPERTY:var n=r,i=n.getterInstance;i&&this.visitFunction(e,i);var s=n.setterInstance;s&&this.visitFunction(e,s);break;case c.ElementKind.NAMESPACE:(function e(r){var t,n,i,s,l,u;var p=r.members;if(p)try{for(var _=a(p.values()),h=_.next();!h.done;h=_.next()){var d=h.value;switch(d.kind){case c.ElementKind.FUNCTION_PROTOTYPE:var y=d.instances;if(y)try{for(var m=(i=void 0,a(y.values())),f=m.next();!f.done;f=m.next()){var T=f.value;if(T.is(o.CommonFlags.COMPILED))return!0}}catch(e){i={error:e}}finally{try{f&&!f.done&&(s=m.return)&&s.call(m)}finally{if(i)throw i.error}}break;case c.ElementKind.CLASS_PROTOTYPE:var y=d.instances;if(y)try{for(var g=(l=void 0,a(y.values())),E=g.next();!E.done;E=g.next()){var T=E.value;if(T.is(o.CommonFlags.COMPILED))return!0}}catch(e){l={error:e}}finally{try{E&&!E.done&&(u=g.return)&&u.call(g)}finally{if(l)throw l.error}}break;default:if(d.is(o.CommonFlags.COMPILED)||e(d))return!0}}}catch(e){t={error:e}}finally{try{h&&!h.done&&(n=_.return)&&n.call(_)}finally{if(t)throw t.error}}return!1})(r)&&this.visitNamespace(e,r);break;case c.ElementKind.TYPEDEFINITION:break;default:assert(!1)}}},e.prototype.visitFunctionInstances=function(e,r){var t,n,i=r.instances;if(i)try{for(var s=a(i.values()),c=s.next();!c.done;c=s.next()){var l=c.value;l.is(o.CommonFlags.COMPILED)&&this.visitFunction(e,l)}}catch(e){t={error:e}}finally{try{c&&!c.done&&(n=s.return)&&n.call(s)}finally{if(t)throw t.error}}},e.prototype.visitClassInstances=function(e,r){var t,n,i=r.instances;if(i)try{for(var s=a(i.values()),c=s.next();!c.done;c=s.next()){var l=c.value;l.is(o.CommonFlags.COMPILED)&&this.visitClass(e,l)}}catch(e){t={error:e}}finally{try{c&&!c.done&&(n=s.return)&&n.call(s)}finally{if(t)throw t.error}}},e.prototype.visitPropertyInstances=function(e,r){assert(!1)},e}(),p=function(e){function r(r,t){void 0===t&&(t=!1);var n=e.call(this,r,t)||this;return n.sb=[],n.indentLevel=0,n}return i(r,e),r.build=function(e){return new r(e).build()},r.prototype.visitGlobal=function(e,r){var t=this.sb,n=r.is(o.CommonFlags.INLINED);if(l.indent(t,this.indentLevel),n&&t.push("const "),t.push(this.typeToString(r.type)),t.push(" "),t.push(e),n)switch(r.constantValueKind){case 1:t.push(" = "),t.push(i64_to_string(r.constantIntegerValue));break;case 2:t.push(" = "),t.push(r.constantFloatValue.toString());break;default:assert(!1)}t.push(";\n")},r.prototype.visitEnum=function(e,r){var t,n,i,u,p=this.sb;l.indent(p,this.indentLevel++),p.push("interface "),p.push(e),p.push(" {\n");var _=r.members;if(_){try{for(var h=a(_),d=h.next();!d.done;d=h.next()){var y=s(d.value,2),m=y[0];if((E=y[1]).kind==c.ElementKind.ENUMVALUE){var f=E.is(o.CommonFlags.INLINED);l.indent(p,this.indentLevel),f?p.push("const "):p.push("readonly "),p.push("unsigned long "),p.push(m),f&&(p.push(" = "),assert(1==E.constantValueKind),p.push(i64_low(E.constantIntegerValue).toString(10))),p.push(";\n")}}}catch(e){t={error:e}}finally{try{d&&!d.done&&(n=h.return)&&n.call(h)}finally{if(t)throw t.error}}try{for(var T=a(_.values()),g=T.next();!g.done;g=T.next()){var E;(E=g.value).kind!=c.ElementKind.ENUMVALUE&&this.visitElement(E.name,E)}}catch(e){i={error:e}}finally{try{g&&!g.done&&(u=T.return)&&u.call(T)}finally{if(i)throw i.error}}}l.indent(p,--this.indentLevel),p.push("}\n")},r.prototype.visitFunction=function(e,r){var t,n,i=this.sb,s=r.signature;l.indent(i,this.indentLevel),i.push(this.typeToString(s.returnType)),i.push(" "),i.push(e),i.push("(");for(var o=s.parameterTypes,c=o.length,u=0;u"),null}for(;e.skip(o.Token.BAR);){if(!e.skip(o.Token.NULL))return t||this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"null"),null;y=!0}n=u.Node.createType(_,d||[],y,e.range(a,e.pos))}for(;e.skip(o.Token.OPENBRACKET);){var T=e.tokenPos;if(!e.skip(o.Token.CLOSEBRACKET))return t||this.error(c.DiagnosticCode._0_expected,e.range(),"]"),null;var g=e.range(T,e.pos);y=!1;if(e.skip(o.Token.BAR)){if(!e.skip(o.Token.NULL))return t||this.error(c.DiagnosticCode._0_expected,e.range(),"null"),null;y=!0}if(n=u.Node.createType(u.Node.createSimpleTypeName("Array",g),[n],y,e.range(a,e.pos)),y)break}return n},r.prototype.tryParseSignature=function(e){var r,t=e.mark(),n=e.tokenPos,i=null,a=null,s=!1;if(e.skip(o.Token.CLOSEPAREN))s=!0,e.discard(t),i=[];else{s=!1;do{var l=u.ParameterKind.DEFAULT;if(e.skip(o.Token.DOT_DOT_DOT)&&(s=!0,e.discard(t),l=u.ParameterKind.REST),e.skip(o.Token.THIS)){if(!e.skip(o.Token.COLON))return e.reset(t),this.tryParseSignatureIsSignature=!1,null;s=!0,e.discard(t);var p=this.parseType(e,!1);if(!p)return null;if(p.kind!=u.NodeKind.TYPE)return this.error(c.DiagnosticCode.Operation_not_supported,p.range),this.tryParseSignatureIsSignature=!0,null;a=p}else{if(!e.skipIdentifier())return s?this.error(c.DiagnosticCode.Identifier_expected,e.range()):e.reset(t),this.tryParseSignatureIsSignature=s,null;var _=u.Node.createIdentifierExpression(e.readIdentifier(),e.range(e.tokenPos,e.pos));if(e.skip(o.Token.QUESTION)&&(s=!0,e.discard(t),l==u.ParameterKind.REST?this.error(c.DiagnosticCode.A_rest_parameter_cannot_be_optional,e.range()):l=u.ParameterKind.OPTIONAL),e.skip(o.Token.COLON)){s=!0,e.discard(t);var h=this.parseType(e);if(!h)return this.tryParseSignatureIsSignature=s,null;var d=new u.ParameterNode;d.parameterKind=l,d.name=_,d.type=h,i?i.push(d):i=[d]}else s&&this.error(c.DiagnosticCode.Type_expected,e.range())}}while(e.skip(o.Token.COMMA));if(!e.skip(o.Token.CLOSEPAREN))return s?this.error(c.DiagnosticCode._0_expected,e.range(),")"):e.reset(t),this.tryParseSignatureIsSignature=s,null}return e.skip(o.Token.EQUALS_GREATERTHAN)?(s=!0,e.discard(t),(r=this.parseType(e))?(this.tryParseSignatureIsSignature=!0,u.Node.createSignature(i||[],r,a,!1,e.range(n,e.pos))):(this.tryParseSignatureIsSignature=s,null)):(s?this.error(c.DiagnosticCode._0_expected,e.range(),"=>"):e.reset(t),this.tryParseSignatureIsSignature=s,null)},r.prototype.parseDecorator=function(e){var r=e.tokenPos;if(e.skipIdentifier()){for(var t=e.readIdentifier(),n=u.Node.createIdentifierExpression(t,e.range(r,e.pos));e.skip(o.Token.DOT);){if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;t=e.readIdentifier(),n=u.Node.createPropertyAccessExpression(n,u.Node.createIdentifierExpression(t,e.range()),e.range(r,e.pos))}var i=void 0;if(!e.skip(o.Token.OPENPAREN))return u.Node.createDecorator(n,null,e.range(r,e.pos));if(i=this.parseArguments(e))return u.Node.createDecorator(n,i,e.range(r,e.pos))}else this.error(c.DiagnosticCode.Identifier_expected,e.range());return null},r.prototype.parseVariable=function(e,r,t,n){var i=new Array;do{var a=this.parseVariableDeclaration(e,r,t);if(!a)return null;i.push(a)}while(e.skip(o.Token.COMMA));var s=u.Node.createVariableStatement(i,t,e.range(n,e.pos));return e.skip(o.Token.SEMICOLON),s},r.prototype.parseVariableDeclaration=function(e,r,t){if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;var n=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),i=r;e.skip(o.Token.EXCLAMATION)&&(i|=a.CommonFlags.DEFINITE_ASSIGNMENT);var s=null;e.skip(o.Token.COLON)&&(s=this.parseType(e));var l=null;if(e.skip(o.Token.EQUALS)){if(i&a.CommonFlags.AMBIENT&&this.error(c.DiagnosticCode.Initializers_are_not_allowed_in_ambient_contexts,e.range()),!(l=this.parseExpression(e,2)))return null}else i&a.CommonFlags.CONST?i&a.CommonFlags.AMBIENT||this.error(c.DiagnosticCode._const_declarations_must_be_initialized,n.range):s||this.error(c.DiagnosticCode.Type_expected,e.range(e.pos));var p=o.Range.join(n.range,e.range());return i&a.CommonFlags.DEFINITE_ASSIGNMENT&&l&&this.error(c.DiagnosticCode.A_definite_assignment_assertion_is_not_permitted_in_this_context,p),u.Node.createVariableDeclaration(n,s,l,t,i,p)},r.prototype.parseEnum=function(e,r,t,n){if(e.next()!=o.Token.IDENTIFIER)return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;var i=u.Node.createIdentifierExpression(e.readIdentifier(),e.range());if(e.next()!=o.Token.OPENBRACE)return this.error(c.DiagnosticCode._0_expected,e.range(),"{"),null;for(var s=new Array;!e.skip(o.Token.CLOSEBRACE);){var l=this.parseEnumValue(e,a.CommonFlags.NONE);if(!l)return null;if(s.push(l),!e.skip(o.Token.COMMA)){if(e.skip(o.Token.CLOSEBRACE))break;return this.error(c.DiagnosticCode._0_expected,e.range(),"}"),null}}var p=u.Node.createEnumDeclaration(i,s,t,r,e.range(n,e.pos));return e.skip(o.Token.SEMICOLON),p},r.prototype.parseEnumValue=function(e,r){if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;var t=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),n=null;return e.skip(o.Token.EQUALS)&&!(n=this.parseExpression(e,2))?null:u.Node.createEnumValueDeclaration(t,n,r,o.Range.join(t.range,e.range()))},r.prototype.parseReturn=function(e){var r=null;if(e.peek(!0)!=o.Token.SEMICOLON&&e.nextToken!=o.Token.CLOSEBRACE&&!e.nextTokenOnNewLine&&!(r=this.parseExpression(e)))return null;var t=u.Node.createReturnStatement(r,e.range());return e.skip(o.Token.SEMICOLON),t},r.prototype.parseTypeParameters=function(e){for(var r=null,t=!1;!e.skip(o.Token.GREATERTHAN);){var n=this.parseTypeParameter(e);if(!n)return null;if(null!==n.defaultType?t=!0:t&&(this.error(c.DiagnosticCode.Required_type_parameters_may_not_follow_optional_type_parameters,n.range),n.defaultType=null),r?r.push(n):r=[n],!e.skip(o.Token.COMMA)){if(e.skip(o.Token.GREATERTHAN))break;return this.error(c.DiagnosticCode._0_expected,e.range(),">"),null}}return r&&r.length||this.error(c.DiagnosticCode.Type_parameter_list_cannot_be_empty,e.range()),r},r.prototype.parseTypeParameter=function(e){if(e.next()==o.Token.IDENTIFIER){var r=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),t=null;if(e.skip(o.Token.EXTENDS)){if(!(i=this.parseType(e)))return null;if(i.kind!=u.NodeKind.TYPE)return this.error(c.DiagnosticCode.Operation_not_supported,i.range),null;t=i}var n=null;if(e.skip(o.Token.EQUALS)){var i;if(!(i=this.parseType(e)))return null;if(i.kind!=u.NodeKind.TYPE)return this.error(c.DiagnosticCode.Operation_not_supported,i.range),null;n=i}return u.Node.createTypeParameter(r,t,n,o.Range.join(r.range,e.range()))}return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null},r.prototype.parseParameters=function(e,r){void 0===r&&(r=!1);var t=new Array,n=null,i=!1,a=!1,s=null;if(this.parseParametersThis=null,e.skip(o.Token.THIS)){if(!e.skip(o.Token.COLON))return this.error(c.DiagnosticCode._0_expected,e.range(),":"),null;if(!(s=this.parseType(e)))return null;if(s.kind==u.NodeKind.TYPE?this.parseParametersThis=s:this.error(c.DiagnosticCode.Operation_not_supported,s.range),!e.skip(o.Token.COMMA))return e.skip(o.Token.CLOSEPAREN)?t:(this.error(c.DiagnosticCode._0_expected,e.range(),")"),null)}for(;!e.skip(o.Token.CLOSEPAREN);){var l=this.parseParameter(e,r);if(!l)return null;switch(n&&!a&&(this.error(c.DiagnosticCode.A_rest_parameter_must_be_last_in_a_parameter_list,n.name.range),a=!0),l.parameterKind){default:i&&this.error(c.DiagnosticCode.A_required_parameter_cannot_follow_an_optional_parameter,l.name.range);break;case u.ParameterKind.OPTIONAL:i=!0;break;case u.ParameterKind.REST:n=l}if(t.push(l),!e.skip(o.Token.COMMA)){if(e.skip(o.Token.CLOSEPAREN))break;return this.error(c.DiagnosticCode._0_expected,e.range(),")"),null}}return t},r.prototype.parseParameter=function(e,r){void 0===r&&(r=!1);var t=!1,n=!1,i=null,s=a.CommonFlags.NONE;if(r&&(e.skip(o.Token.PUBLIC)?(i=e.range(),s|=a.CommonFlags.PUBLIC):e.skip(o.Token.PROTECTED)?(i=e.range(),s|=a.CommonFlags.PROTECTED):e.skip(o.Token.PRIVATE)&&(i=e.range(),s|=a.CommonFlags.PRIVATE),e.peek()==o.Token.READONLY)){var l=e.mark();e.next(),e.peek()!=o.Token.COLON?(e.discard(l),i||(i=e.range()),s|=a.CommonFlags.READONLY):e.reset(l)}if(e.skip(o.Token.DOT_DOT_DOT)&&(s?this.error(c.DiagnosticCode.A_parameter_property_cannot_be_declared_using_a_rest_parameter,e.range()):i=e.range(),t=!0),e.skipIdentifier()){t||(i=e.range());var p=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),_=null;if((n=e.skip(o.Token.QUESTION))&&t&&this.error(c.DiagnosticCode.A_rest_parameter_cannot_be_optional,p.range),e.skip(o.Token.COLON)){if(!(_=this.parseType(e)))return null}else _=u.Node.createOmittedType(e.range(e.pos));var h=null;if(e.skip(o.Token.EQUALS)&&(t&&this.error(c.DiagnosticCode.A_rest_parameter_cannot_have_an_initializer,p.range),n?this.error(c.DiagnosticCode.Parameter_cannot_have_question_mark_and_initializer,p.range):n=!0,!(h=this.parseExpression(e,2))))return null;var d=u.Node.createParameter(p,_,h,t?u.ParameterKind.REST:n?u.ParameterKind.OPTIONAL:u.ParameterKind.DEFAULT,o.Range.join(i,e.range()));return d.flags|=s,d}return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null},r.prototype.parseFunction=function(e,r,t,n){if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range(e.pos)),null;var i=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),s=-1,l=null;if(e.skip(o.Token.LESSTHAN)){if(s=e.tokenPos,!(l=this.parseTypeParameters(e)))return null;r|=a.CommonFlags.GENERIC}if(!e.skip(o.Token.OPENPAREN))return this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"("),null;s<0&&(s=e.tokenPos);var p=this.parseParameters(e);if(!p)return null;var _=this.parseParametersThis,h=0!=(r&a.CommonFlags.SET);h&&(1!=p.length&&this.error(c.DiagnosticCode.A_set_accessor_must_have_exactly_one_parameter,i.range),p.length&&p[0].initializer&&this.error(c.DiagnosticCode.A_set_accessor_parameter_cannot_have_an_initializer,i.range)),r&a.CommonFlags.GET&&p.length&&this.error(c.DiagnosticCode.A_get_accessor_cannot_have_parameters,i.range);var d=null;if(e.skip(o.Token.COLON)&&!(d=this.parseType(e,!0,h)))return null;d||(d=u.Node.createOmittedType(e.range(e.pos)),h||this.error(c.DiagnosticCode.Type_expected,d.range));var y=u.Node.createSignature(p,d,_,!1,e.range(s,e.pos)),m=null;if(e.skip(o.Token.OPENBRACE)){if(r&a.CommonFlags.AMBIENT&&this.error(c.DiagnosticCode.An_implementation_cannot_be_declared_in_ambient_contexts,e.range()),!(m=this.parseBlockStatement(e,!1)))return null}else r&a.CommonFlags.AMBIENT||this.error(c.DiagnosticCode.Function_implementation_is_missing_or_not_immediately_following_the_declaration,e.range(e.pos));var f=u.Node.createFunctionDeclaration(i,l,y,m,t,r,0,e.range(n,e.pos));return e.skip(o.Token.SEMICOLON),f},r.prototype.parseFunctionExpression=function(e){var r,t=e.tokenPos,n=0;if(e.token==o.Token.FUNCTION){if(r=e.skipIdentifier()?u.Node.createIdentifierExpression(e.readIdentifier(),e.range()):u.Node.createEmptyIdentifierExpression(e.range(e.pos)),!e.skip(o.Token.OPENPAREN))return this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"("),null}else n=1,assert(e.token==o.Token.OPENPAREN),r=u.Node.createEmptyIdentifierExpression(e.range(e.tokenPos));var i=e.pos,a=this.parseParameters(e);return a?this.parseFunctionExpressionCommon(e,r,a,n,t,i):null},r.prototype.parseFunctionExpressionCommon=function(e,r,t,n,i,s){void 0===i&&(i=-1),void 0===s&&(s=-1),i<0&&(i=r.range.start),s<0&&(s=i);var l=null;if(2!=n&&e.skip(o.Token.COLON)){if(!(l=this.parseType(e)))return null}else l=u.Node.createOmittedType(e.range(e.pos));if(n&&!e.skip(o.Token.EQUALS_GREATERTHAN))return this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"=>"),null;var p=u.Node.createSignature(t,l,null,!1,e.range(s,e.pos)),_=null;if(n)if(e.skip(o.Token.OPENBRACE))_=this.parseBlockStatement(e,!1);else{var h=this.parseExpression(e,2);h&&(_=u.Node.createExpressionStatement(h))}else{if(!e.skip(o.Token.OPENBRACE))return this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"{"),null;_=this.parseBlockStatement(e,!1)}if(!_)return null;var d=u.Node.createFunctionDeclaration(r,null,p,_,null,a.CommonFlags.NONE,n,e.range(i,e.pos));return u.Node.createFunctionExpression(d)},r.prototype.parseClassOrInterface=function(e,r,t,n){var i=e.token==o.Token.INTERFACE;if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;var s=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),l=null;if(e.skip(o.Token.LESSTHAN)){if(!(l=this.parseTypeParameters(e)))return null;r|=a.CommonFlags.GENERIC}var p=null;if(e.skip(o.Token.EXTENDS)){var _=this.parseType(e);if(!_)return null;if(_.kind!=u.NodeKind.TYPE)return this.error(c.DiagnosticCode.Operation_not_supported,_.range),null;p=_}var h=null;if(e.skip(o.Token.IMPLEMENTS)){i&&this.error(c.DiagnosticCode.Interface_declaration_cannot_have_implements_clause,e.range());do{var d=this.parseType(e);if(!d)return null;i||(h?h.push(d):h=[d])}while(e.skip(o.Token.COMMA))}if(!e.skip(o.Token.OPENBRACE))return this.error(c.DiagnosticCode._0_expected,e.range(),"{"),null;var y,m=new Array;if(i?(assert(!h),y=u.Node.createInterfaceDeclaration(s,l,p,m,t,r,e.range(n,e.pos))):y=u.Node.createClassDeclaration(s,l,p,h,m,t,r,e.range(n,e.pos)),!e.skip(o.Token.CLOSEBRACE))do{var f=this.parseClassMember(e,y);if(f)m.push(f);else if(this.skipStatement(e),e.skip(o.Token.ENDOFFILE))return this.error(c.DiagnosticCode._0_expected,e.range(),"}"),null}while(!e.skip(o.Token.CLOSEBRACE));return y.range.end=e.pos,y},r.prototype.parseClassExpression=function(e){var r,t=e.tokenPos;if(r=e.skipIdentifier()?u.Node.createIdentifierExpression(e.readIdentifier(),e.range()):u.Node.createEmptyIdentifierExpression(e.range(e.pos)),!e.skip(o.Token.OPENBRACE))return this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"{"),null;var n=new Array,i=u.Node.createClassDeclaration(r,[],null,null,n,null,a.CommonFlags.NONE,e.range(t,e.pos));if(!e.skip(o.Token.CLOSEBRACE))do{var s=this.parseClassMember(e,i);if(s)n.push(s);else if(this.skipStatement(e),e.skip(o.Token.ENDOFFILE))return this.error(c.DiagnosticCode._0_expected,e.range(),"}"),null}while(!e.skip(o.Token.CLOSEBRACE));return i.range.end=e.pos,u.Node.createClassExpression(i)},r.prototype.parseClassMember=function(e,r){var t=e.pos,n=r.kind==u.NodeKind.INTERFACEDECLARATION,i=null;if(e.skip(o.Token.AT)){do{var s=this.parseDecorator(e);if(!s)break;i?i.push(s):i=[s]}while(e.skip(o.Token.AT));i&&n&&this.error(c.DiagnosticCode.Decorators_are_not_valid_here,o.Range.join(i[0].range,i[i.length-1].range))}var l=r.flags&a.CommonFlags.AMBIENT;n&&(l|=a.CommonFlags.VIRTUAL);var p=0,_=0;e.skip(o.Token.PUBLIC)?(n&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(),"public"),l|=a.CommonFlags.PUBLIC,p=e.tokenPos,_=e.pos):e.skip(o.Token.PRIVATE)?(n&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(),"private"),l|=a.CommonFlags.PRIVATE,p=e.tokenPos,_=e.pos):e.skip(o.Token.PROTECTED)&&(n&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(),"protected"),l|=a.CommonFlags.PROTECTED,p=e.tokenPos,_=e.pos);var h=0,d=0,y=0,m=0;e.skip(o.Token.STATIC)?(n&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(),"static"),l|=a.CommonFlags.STATIC,h=e.tokenPos,d=e.pos):(l|=a.CommonFlags.INSTANCE,e.skip(o.Token.ABSTRACT)&&(n&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(),"abstract"),l|=a.CommonFlags.ABSTRACT,y=e.tokenPos,m=e.pos),r.flags&a.CommonFlags.GENERIC&&(l|=a.CommonFlags.GENERIC_CONTEXT));var f=0,T=0;e.skip(o.Token.READONLY)&&(l|=a.CommonFlags.READONLY,f=e.tokenPos,T=e.pos);var g,E=e.mark(),v=!1,b=!1,I=!1,x=0,A=0;if(n||(e.skip(o.Token.GET)?e.peek(!0,o.IdentifierHandling.PREFER)!=o.Token.IDENTIFIER||e.nextTokenOnNewLine?e.reset(E):(l|=a.CommonFlags.GET,b=!0,x=e.tokenPos,A=e.pos,l&a.CommonFlags.READONLY&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(f,T),"readonly")):e.skip(o.Token.SET)?e.peek(!0,o.IdentifierHandling.PREFER)!=o.Token.IDENTIFIER||e.nextTokenOnNewLine?e.reset(E):(l|=a.CommonFlags.SET,I=!0,x=e.tokenPos,A=e.pos,l&a.CommonFlags.READONLY&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(f,T),"readonly")):e.skip(o.Token.CONSTRUCTOR)&&(v=!0,(l|=a.CommonFlags.CONSTRUCTOR)&a.CommonFlags.STATIC&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(h,d),"static"),l&a.CommonFlags.ABSTRACT&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(y,m),"abstract"),l&a.CommonFlags.READONLY&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(f,T),"readonly"))),v)g=u.Node.createConstructorExpression(e.range());else{if(!b&&!I&&e.skip(o.Token.OPENBRACKET)){l&a.CommonFlags.PUBLIC?this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(p,_),"public"):l&a.CommonFlags.PROTECTED?this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(p,_),"protected"):l&a.CommonFlags.PRIVATE&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(p,_),"protected"),l&a.CommonFlags.STATIC&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(h,d),"static"),l&a.CommonFlags.ABSTRACT&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(y,m),"abstract"),l&a.CommonFlags.READONLY&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(f,T),"readonly");var N=this.parseIndexSignatureDeclaration(e,i);return N?(e.skip(o.Token.SEMICOLON),N):null}if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;g=u.Node.createIdentifierExpression(e.readIdentifier(),e.range())}var S=null;if(e.skip(o.Token.LESSTHAN)){var O=e.tokenPos;if(!(S=this.parseTypeParameters(e)))return null;v?this.error(c.DiagnosticCode.Type_parameters_cannot_appear_on_a_constructor_declaration,e.range(O,e.pos)):b||I?this.error(c.DiagnosticCode.An_accessor_cannot_have_type_parameters,e.range(O,e.pos)):l|=a.CommonFlags.GENERIC}if(e.skip(o.Token.OPENPAREN)){var C=e.tokenPos,k=this.parseParameters(e,v);if(!k)return null;var L=this.parseParametersThis;if(v)for(var R=0,F=k.length;R"),null):null;case o.Token.IDENTIFIER:var T=u.Node.createIdentifierExpression(e.readIdentifier(),e.range(t,e.pos));return e.peek(!0)!=o.Token.EQUALS_GREATERTHAN||e.nextTokenOnNewLine?T:this.parseFunctionExpressionCommon(e,u.Node.createEmptyIdentifierExpression(e.range(t)),[u.Node.createParameter(T,u.Node.createOmittedType(T.range.atEnd),null,u.ParameterKind.DEFAULT,T.range)],2,t);case o.Token.THIS:return u.Node.createThisExpression(e.range(t,e.pos));case o.Token.CONSTRUCTOR:return u.Node.createConstructorExpression(e.range(t,e.pos));case o.Token.SUPER:return e.peek()!=o.Token.DOT&&e.nextToken!=o.Token.OPENPAREN&&this.error(c.DiagnosticCode._super_must_be_followed_by_an_argument_list_or_member_access,e.range()),u.Node.createSuperExpression(e.range(t,e.pos));case o.Token.STRINGLITERAL:return u.Node.createStringLiteralExpression(e.readString(),e.range(t,e.pos));case o.Token.INTEGERLITERAL:return u.Node.createIntegerLiteralExpression(e.readInteger(),e.range(t,e.pos));case o.Token.FLOATLITERAL:return u.Node.createFloatLiteralExpression(e.readFloat(),e.range(t,e.pos));case o.Token.SLASH:var g=e.readRegexpPattern();return e.skip(o.Token.SLASH)?u.Node.createRegexpLiteralExpression(g,e.readRegexpFlags(),e.range(t,e.pos)):(this.error(c.DiagnosticCode._0_expected,e.range(),"/"),null);case o.Token.FUNCTION:return this.parseFunctionExpression(e);case o.Token.CLASS:return this.parseClassExpression(e);default:return r==o.Token.ENDOFFILE?this.error(c.DiagnosticCode.Unexpected_end_of_text,e.range(t)):this.error(c.DiagnosticCode.Expression_expected,e.range()),null}},r.prototype.tryParseTypeArgumentsBeforeArguments=function(e){var r=e.mark();if(!e.skip(o.Token.LESSTHAN))return null;var t=null;do{if(e.peek()===o.Token.GREATERTHAN)break;var n=this.parseType(e,!0,!0);if(!n)return e.reset(r),null;t?t.push(n):t=[n]}while(e.skip(o.Token.COMMA));return e.skip(o.Token.GREATERTHAN)&&e.skip(o.Token.OPENPAREN)?t:(e.reset(r),null)},r.prototype.parseArguments=function(e){for(var r=new Array;!e.skip(o.Token.CLOSEPAREN);){var t=this.parseExpression(e,2);if(!t)return null;if(r.push(t),!e.skip(o.Token.COMMA)){if(e.skip(o.Token.CLOSEPAREN))break;return this.error(c.DiagnosticCode._0_expected,e.range(),")"),null}}return r},r.prototype.parseExpression=function(e,r){void 0===r&&(r=1),assert(0!=r);var t=this.parseExpressionStart(e);if(!t)return null;for(var n,i,a=(t=this.maybeParseCallExpression(e,t)).range.start,s=null;(i=_(n=e.peek()))>=r;){switch(e.next(),n){case o.Token.AS:var l=this.parseType(e);if(!l)return null;t=u.Node.createAssertionExpression(u.AssertionKind.AS,t,l,e.range(a,e.pos));break;case o.Token.EXCLAMATION:t=u.Node.createAssertionExpression(u.AssertionKind.NONNULL,t,null,e.range(a,e.pos));break;case o.Token.INSTANCEOF:var p=this.parseType(e);if(!p)return null;t=u.Node.createInstanceOfExpression(t,p,e.range(a,e.pos));break;case o.Token.OPENBRACKET:if(!(s=this.parseExpression(e)))return null;if(!e.skip(o.Token.CLOSEBRACKET))return this.error(c.DiagnosticCode._0_expected,e.range(),"]"),null;t=u.Node.createElementAccessExpression(t,s,e.range(a,e.pos));break;case o.Token.PLUS_PLUS:case o.Token.MINUS_MINUS:t.kind!=u.NodeKind.IDENTIFIER&&t.kind!=u.NodeKind.ELEMENTACCESS&&t.kind!=u.NodeKind.PROPERTYACCESS&&this.error(c.DiagnosticCode.The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access,t.range),t=u.Node.createUnaryPostfixExpression(n,t,e.range(a,e.pos));break;case o.Token.QUESTION:var d=this.parseExpression(e);if(!d)return null;if(!e.skip(o.Token.COLON))return this.error(c.DiagnosticCode._0_expected,e.range(),":"),null;var y=this.parseExpression(e,r>1?2:1);if(!y)return null;t=u.Node.createTernaryExpression(t,d,y,e.range(a,e.pos));break;case o.Token.COMMA:var m=[t];do{if(!(t=this.parseExpression(e,2)))return null;m.push(t)}while(e.skip(o.Token.COMMA));t=u.Node.createCommaExpression(m,e.range(a,e.pos));break;default:if(n==o.Token.DOT){if(e.skipIdentifier())s=u.Node.createIdentifierExpression(e.readIdentifier(),e.range());else if(!(s=this.parseExpression(e,h(n)?i:i+1)))return null;if(s.kind==u.NodeKind.IDENTIFIER)t=u.Node.createPropertyAccessExpression(t,s,e.range(a,e.pos));else{if(s.kind!=u.NodeKind.CALL)return this.error(c.DiagnosticCode.Identifier_expected,s.range),null;if(!(t=this.joinPropertyCall(e,a,t,s)))return null}}else{if(!(s=this.parseExpression(e,h(n)?i:i+1)))return null;t=u.Node.createBinaryExpression(n,t,s,e.range(a,e.pos))}}t=this.maybeParseCallExpression(e,t)}return t},r.prototype.joinPropertyCall=function(e,r,t,n){var i=n.expression;switch(i.kind){case u.NodeKind.IDENTIFIER:n.expression=u.Node.createPropertyAccessExpression(t,i,e.range(r,e.pos));break;case u.NodeKind.CALL:var a=this.joinPropertyCall(e,r,t,i);if(!a)return null;n.expression=a,n.range=e.range(r,e.pos);break;default:return this.error(c.DiagnosticCode.Identifier_expected,n.range),null}return n},r.prototype.maybeParseCallExpression=function(e,r){if(u.nodeIsCallable(r.kind))for(var t=null;e.skip(o.Token.OPENPAREN)||u.nodeIsGenericCallable(r.kind)&&null!==(t=this.tryParseTypeArgumentsBeforeArguments(e));){var n=this.parseArguments(e);if(!n)break;r=u.Node.createCallExpression(r,t,n,e.range(r.range.start,e.pos))}return r},r.prototype.skipStatement=function(e){for(e.peek(!0),e.nextTokenOnNewLine&&e.next();;){var r=e.peek(!0);if(r==o.Token.ENDOFFILE||r==o.Token.SEMICOLON){e.next();break}if(e.nextTokenOnNewLine)break;switch(e.next()){case o.Token.IDENTIFIER:e.readIdentifier();break;case o.Token.STRINGLITERAL:e.readString();break;case o.Token.INTEGERLITERAL:e.readInteger();break;case o.Token.FLOATLITERAL:e.readFloat();break;case o.Token.OPENBRACE:this.skipBlock(e)}}},r.prototype.skipBlock=function(e){var r=1,t=!0;do{switch(e.next()){case o.Token.ENDOFFILE:this.error(c.DiagnosticCode._0_expected,e.range(),"}"),t=!1;break;case o.Token.OPENBRACE:++r;break;case o.Token.CLOSEBRACE:--r||(t=!1);break;case o.Token.IDENTIFIER:e.readIdentifier();break;case o.Token.STRINGLITERAL:e.readString();break;case o.Token.INTEGERLITERAL:e.readInteger();break;case o.Token.FLOATLITERAL:e.readFloat()}}while(t)},r}(c.DiagnosticEmitter);function _(e){switch(e){case o.Token.COMMA:return 1;case o.Token.EQUALS:case o.Token.PLUS_EQUALS:case o.Token.MINUS_EQUALS:case o.Token.ASTERISK_ASTERISK_EQUALS:case o.Token.ASTERISK_EQUALS:case o.Token.SLASH_EQUALS:case o.Token.PERCENT_EQUALS:case o.Token.LESSTHAN_LESSTHAN_EQUALS:case o.Token.GREATERTHAN_GREATERTHAN_EQUALS:case o.Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:case o.Token.AMPERSAND_EQUALS:case o.Token.CARET_EQUALS:case o.Token.BAR_EQUALS:return 4;case o.Token.QUESTION:return 5;case o.Token.BAR_BAR:return 6;case o.Token.AMPERSAND_AMPERSAND:return 7;case o.Token.BAR:return 8;case o.Token.CARET:return 9;case o.Token.AMPERSAND:return 10;case o.Token.EQUALS_EQUALS:case o.Token.EXCLAMATION_EQUALS:case o.Token.EQUALS_EQUALS_EQUALS:case o.Token.EXCLAMATION_EQUALS_EQUALS:return 11;case o.Token.AS:case o.Token.IN:case o.Token.INSTANCEOF:case o.Token.LESSTHAN:case o.Token.GREATERTHAN:case o.Token.LESSTHAN_EQUALS:case o.Token.GREATERTHAN_EQUALS:return 12;case o.Token.LESSTHAN_LESSTHAN:case o.Token.GREATERTHAN_GREATERTHAN:case o.Token.GREATERTHAN_GREATERTHAN_GREATERTHAN:return 13;case o.Token.PLUS:case o.Token.MINUS:return 14;case o.Token.ASTERISK:case o.Token.SLASH:case o.Token.PERCENT:return 15;case o.Token.ASTERISK_ASTERISK:return 16;case o.Token.PLUS_PLUS:case o.Token.MINUS_MINUS:return 18;case o.Token.DOT:case o.Token.NEW:case o.Token.OPENBRACKET:case o.Token.EXCLAMATION:return 20}return 0}function h(e){switch(e){case o.Token.EQUALS:case o.Token.PLUS_EQUALS:case o.Token.MINUS_EQUALS:case o.Token.ASTERISK_ASTERISK_EQUALS:case o.Token.ASTERISK_EQUALS:case o.Token.SLASH_EQUALS:case o.Token.PERCENT_EQUALS:case o.Token.LESSTHAN_LESSTHAN_EQUALS:case o.Token.GREATERTHAN_GREATERTHAN_EQUALS:case o.Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:case o.Token.AMPERSAND_EQUALS:case o.Token.CARET_EQUALS:case o.Token.BAR_EQUALS:case o.Token.QUESTION:case o.Token.ASTERISK_ASTERISK:return!0;default:return!1}}r.Parser=p,function(e){e[e.NONE=0]="NONE",e[e.COMMA=1]="COMMA",e[e.SPREAD=2]="SPREAD",e[e.YIELD=3]="YIELD",e[e.ASSIGNMENT=4]="ASSIGNMENT",e[e.CONDITIONAL=5]="CONDITIONAL",e[e.LOGICAL_OR=6]="LOGICAL_OR",e[e.LOGICAL_AND=7]="LOGICAL_AND",e[e.BITWISE_OR=8]="BITWISE_OR",e[e.BITWISE_XOR=9]="BITWISE_XOR",e[e.BITWISE_AND=10]="BITWISE_AND",e[e.EQUALITY=11]="EQUALITY",e[e.RELATIONAL=12]="RELATIONAL",e[e.SHIFT=13]="SHIFT",e[e.ADDITIVE=14]="ADDITIVE",e[e.MULTIPLICATIVE=15]="MULTIPLICATIVE",e[e.EXPONENTIATED=16]="EXPONENTIATED",e[e.UNARY_PREFIX=17]="UNARY_PREFIX",e[e.UNARY_POSTFIX=18]="UNARY_POSTFIX",e[e.CALL=19]="CALL",e[e.MEMBERACCESS=20]="MEMBERACCESS",e[e.GROUPING=21]="GROUPING"}(r.Precedence||(r.Precedence={}))},function(e,r,t){t(18),e.exports=t(28)},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),t(19),t(21),t(22),t(23);var n=t(4);n.Module.prototype.toText=function(){return binaryen.wrapModule(this.ref).emitStackIR(!0)},n.Module.prototype.toAsmjs=function(){return binaryen.wrapModule(this.ref).emitAsmjs()}},function(e,r,t){(function(e){const r=e.Binaryen||t(20);for(var n in e.binaryen=r,r)(n.startsWith("_Binaryen")||n.startsWith("_Relooper"))&&(e[n]=r[n]);e.__memory_allocate=r._malloc,e.__memory_free=r._free,e.__memory_copy=r._memmove,e.__store=function(e,t){r.HEAPU8[e]=t},e.__load=function(e){return r.HEAPU8[e]}}).call(this,t(8))},function(r,t){r.exports=e},function(e,r,t){(function(e){var r="undefined"!=typeof window&&window||void 0!==e&&e||self;r.ASC_TARGET=2,r.ASC_NO_ASSERT=!1,r.ASC_MEMORY_BASE=0,r.ASC_OPTIMIZE_LEVEL=3,r.ASC_SHRINK_LEVEL=0,r.ASC_FEATURE_MUTABLE_GLOBAL=!1,r.ASC_FEATURE_SIGN_EXTENSION=!1,r.ASC_FEATURE_BULK_MEMORY=!1,r.ASC_FEATURE_SIMD=!1,r.ASC_FEATURE_THREADS=!1;var t=new Float64Array(1),n=new Uint32Array(t.buffer);function i(){Error.captureStackTrace?Error.captureStackTrace(this,i):this.stack=this.name+": "+this.message+"\n"+(new Error).stack}function a(e){this.message=e||"assertion failed",Error.captureStackTrace?Error.captureStackTrace(this,a):this.stack=this.name+": "+this.message+"\n"+(new Error).stack}Object.defineProperties(r.i8=function(e){return e<<24>>24},{MIN_VALUE:{value:-128,writable:!1},MAX_VALUE:{value:127,writable:!1}}),Object.defineProperties(r.i16=function(e){return e<<16>>16},{MIN_VALUE:{value:-32768,writable:!1},MAX_VALUE:{value:32767,writable:!1}}),Object.defineProperties(r.i32=r.isize=function(e){return 0|e},{MIN_VALUE:{value:-2147483648,writable:!1},MAX_VALUE:{value:2147483647,writable:!1}}),Object.defineProperties(r.u8=function(e){return 255&e},{MIN_VALUE:{value:0,writable:!1},MAX_VALUE:{value:255,writable:!1}}),Object.defineProperties(r.u16=function(e){return 65535&e},{MIN_VALUE:{value:0,writable:!1},MAX_VALUE:{value:65535,writable:!1}}),Object.defineProperties(r.u32=r.usize=function(e){return e>>>0},{MIN_VALUE:{value:0,writable:!1},MAX_VALUE:{value:4294967295,writable:!1}}),Object.defineProperties(r.bool=function(e){return!!e},{MIN_VALUE:{value:!1,writable:!1},MAX_VALUE:{value:!0,writable:!1}}),Object.defineProperties(r.f32=function(e){return Math.fround(e)},{EPSILON:{value:Math.fround(1.1920929e-7),writable:!1},MIN_VALUE:{value:Math.fround(1.4012985e-45),writable:!1},MAX_VALUE:{value:Math.fround(3.4028235e38),writable:!1},MIN_NORMAL_VALUE:{value:Math.fround(1.17549435e-38),writable:!1},MIN_SAFE_INTEGER:{value:-16777215,writable:!1},MAX_SAFE_INTEGER:{value:16777215,writable:!1}}),Object.defineProperties(r.f64=function(e){return+e},{EPSILON:{value:2.220446049250313e-16,writable:!1},MIN_VALUE:{value:5e-324,writable:!1},MAX_VALUE:{value:1.7976931348623157e308,writable:!1},MIN_NORMAL_VALUE:{value:2.2250738585072014e-308,writable:!1},MIN_SAFE_INTEGER:{value:-9007199254740991,writable:!1},MAX_SAFE_INTEGER:{value:9007199254740991,writable:!1}}),r.clz=Math.clz32,r.ctz=function(e){var r=Math.clz32(e&-e);return e?31-r:r},r.popcnt=function(e){return 16843009*((e=(858993459&(e-=e>>>1&1431655765))+(e>>>2&858993459))+(e>>>4)&252645135)>>>24},r.rotl=function(e,r){return e<<(r&=31)|e>>>32-r},r.rotr=function(e,r){return e>>>(r&=31)|e<<32-r},r.abs=Math.abs,r.max=Math.max,r.min=Math.min,r.ceil=Math.ceil,r.floor=Math.floor,r.nearest=function(e){return.5===Math.abs(e-Math.trunc(e))?2*Math.round(.5*e):Math.round(e)},r.select=function(e,r,t){return t?e:r},r.sqrt=Math.sqrt,r.trunc=Math.trunc,r.copysign=function(e,r){return Math.abs(e)*Math.sign(r)},r.bswap=function(e){var r=e>>8&16711935,t=(16711935&e)<<8;return(r=(e=r|t)>>16&65535)|(t=(65535&e)<<16)},r.bswap16=function(e){return e<<8&65280|e>>8&255|4294901760&e},i.prototype=Object.create(Error.prototype),i.prototype.name="UnreachableError",i.prototype.message="unreachable",r.unreachable=function(){throw new i},a.prototype=Object.create(Error.prototype),a.prototype.name="AssertionError",r.assert=function(e,r){if(e)return e;throw new a(r)},r.changetype=function(e){return e},String.fromCharCodes=function(e){return String.fromCharCode.apply(String,e)},String.fromCodePoints=function(e){return String.fromCodePoint.apply(String,e)},String.prototype.replaceAll||Object.defineProperty(String.prototype,"replaceAll",{value:function(e,r){var t=this.split(e).join(r);return e.length||(t=r+t+r),t}}),r.isInteger=Number.isInteger,r.isFloat=function(e){return"number"==typeof e},r.isNullable=function(e){return!0},r.isReference=function(e){return"object"==typeof e||"string"==typeof e},r.isFunction=function(e){return"function"==typeof e},r.isString=function(e){return"string"==typeof e||e instanceof String},r.isArray=Array.isArray,r.isArrayLike=function(e){return e&&"object"==typeof e&&"number"==typeof e.length&&e.length>=0&&Math.trunc(e.length)===e.length},Array.create=function(e){var r=new Array(e);return r.length=0,r},r.isDefined=function(e){return void 0!==e},r.isConstant=function(e){return!1},r.unchecked=function(e){return e},r.fmod=function(e,r){return e%r},r.fmodf=function(e,r){return Math.fround(e%r)},r.JSMath=Math,Object.defineProperties(r.JSMath,{sincos_sin:{value:0,writable:!0},sincos_cos:{value:0,writable:!0},signbit:{value:function(e){return t[0]=e,Boolean(n[1]>>>31&e==e)}},sincos:{value:function(e){this.sincos_sin=Math.sin(e),this.sincos_cos=Math.cos(e)}}}),r.memory=(()=>{var e=new Uint8Array(0),t=0;return{allocate:r.__memory_allocate||function(r){if(!(r>>>=0))return 0;if(t+r>e.length){var n=e;(e=new Uint8Array(Math.max(65536,e.length+r,2*e.length))).set(n)}var i=t;return 7&(t+=r)&&(t=1+(7|t)),i},fill:r.__memory_fill||function(r,t,n){e.fill(t,r,r+n)},free:r.__memory_free||function(e){},copy:r.__memory_copy||function(r,t,n){e.copyWithin(r,t,t+n)},reset:r.__memory_reset||function(){e=new Uint8Array(0),t=0}}})(),r.store=r.__store||function(e,r,t){HEAP[(0|e)+(0|t)]=r},r.load=r.__load||function(e,r){return HEAP[(0|e)+(0|r)]},r.unmanaged=function(){}}).call(this,t(8))},function(e,r,t){(function(e){const r=new Float64Array(1),t=new Float32Array(r.buffer),n=new Int32Array(r.buffer);e.f32_as_i32=function(e){return t[0]=e,n[0]},e.i32_as_f32=function(e){return n[0]=e,t[0]},e.f64_as_i64=function(e){return r[0]=e,i64_new(n[0],n[1])},e.i64_as_f64=function(e){return n[0]=i64_low(e),n[1]=i64_high(e),r[0]}}).call(this,t(8))},function(e,r,t){(function(e){const r=e.Long||t(24);e.i64_zero=r.ZERO,e.i64_one=r.ONE,e.i64_new=function(e,t){return r.fromBits(e,t)},e.i64_low=function(e){return e.low},e.i64_high=function(e){return e.high},e.i64_add=function(e,r){return e.add(r)},e.i64_sub=function(e,r){return e.sub(r)},e.i64_mul=function(e,r){return e.mul(r)},e.i64_div=function(e,r){return e.div(r)},e.i64_div_u=function(e,r){return e.toUnsigned().div(r.toUnsigned()).toSigned()},e.i64_rem=function(e,r){return e.mod(r)},e.i64_rem_u=function(e,r){return e.toUnsigned().mod(r.toUnsigned()).toSigned()},e.i64_and=function(e,r){return e.and(r)},e.i64_or=function(e,r){return e.or(r)},e.i64_xor=function(e,r){return e.xor(r)},e.i64_shl=function(e,r){return e.shl(r)},e.i64_shr=function(e,r){return e.shr(r)},e.i64_shr_u=function(e,r){return e.shru(r)},e.i64_not=function(e){return e.not()},e.i64_eq=function(e,r){return e.eq(r)},e.i64_ne=function(e,r){return e.ne(r)},e.i64_align=function(e,t){assert(t&&0==(t&t-1));var n=r.fromInt(t-1);return e.add(n).and(n.not())},e.i64_is_i8=function(e){return 0===e.high&&e.low>=0&&e.low<=i8.MAX_VALUE||-1===e.high&&e.low>=i8.MIN_VALUE&&e.low<0},e.i64_is_i16=function(e){return 0===e.high&&e.low>=0&&e.low<=i16.MAX_VALUE||-1===e.high&&e.low>=i16.MIN_VALUE&&e.low<0},e.i64_is_i32=function(e){return 0===e.high&&e.low>=0||-1===e.high&&e.low<0},e.i64_is_u8=function(e){return 0===e.high&&e.low>=0&&e.low<=u8.MAX_VALUE},e.i64_is_u16=function(e){return 0===e.high&&e.low>=0&&e.low<=u16.MAX_VALUE},e.i64_is_u32=function(e){return 0===e.high},e.i64_is_bool=function(e){return 0===e.high&&(0===e.low||1===e.low)};const n=r.fromNumber(f32.MIN_SAFE_INTEGER),i=r.fromNumber(f32.MAX_SAFE_INTEGER);e.i64_is_f32=function(e){return e.gte(n)&&e.lte(i)};const a=r.fromNumber(f64.MIN_SAFE_INTEGER),s=r.fromNumber(f64.MAX_SAFE_INTEGER);e.i64_is_f64=function(e){return e.gte(a)&&e.lte(s)},e.i64_to_f32=function(r){return e.Math.fround(r.toNumber())},e.i64_to_f64=function(e){return e.toNumber()},e.i64_to_string=function(e,r){return(r?e.toUnsigned():e).toString(10)}}).call(this,t(8))},function(e,r){e.exports=n;var t=null;try{t=new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([0,97,115,109,1,0,0,0,1,13,2,96,0,1,127,96,4,127,127,127,127,1,127,3,7,6,0,1,1,1,1,1,6,6,1,127,1,65,0,11,7,50,6,3,109,117,108,0,1,5,100,105,118,95,115,0,2,5,100,105,118,95,117,0,3,5,114,101,109,95,115,0,4,5,114,101,109,95,117,0,5,8,103,101,116,95,104,105,103,104,0,0,10,191,1,6,4,0,35,0,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,126,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,127,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,128,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,129,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,130,34,4,66,32,135,167,36,0,32,4,167,11])),{}).exports}catch(e){}function n(e,r,t){this.low=0|e,this.high=0|r,this.unsigned=!!t}function i(e){return!0===(e&&e.__isLong__)}n.prototype.__isLong__,Object.defineProperty(n.prototype,"__isLong__",{value:!0}),n.isLong=i;var a={},s={};function o(e,r){var t,n,i;return r?(i=0<=(e>>>=0)&&e<256)&&(n=s[e])?n:(t=l(e,(0|e)<0?-1:0,!0),i&&(s[e]=t),t):(i=-128<=(e|=0)&&e<128)&&(n=a[e])?n:(t=l(e,e<0?-1:0,!1),i&&(a[e]=t),t)}function c(e,r){if(isNaN(e))return r?T:f;if(r){if(e<0)return T;if(e>=d)return I}else{if(e<=-y)return x;if(e+1>=y)return b}return e<0?c(-e,r).neg():l(e%h|0,e/h|0,r)}function l(e,r,t){return new n(e,r,t)}n.fromInt=o,n.fromNumber=c,n.fromBits=l;var u=Math.pow;function p(e,r,t){if(0===e.length)throw Error("empty string");if("NaN"===e||"Infinity"===e||"+Infinity"===e||"-Infinity"===e)return f;if("number"==typeof r?(t=r,r=!1):r=!!r,(t=t||10)<2||360)throw Error("interior hyphen");if(0===n)return p(e.substring(1),r,t).neg();for(var i=c(u(t,8)),a=f,s=0;s>>0:this.low},A.toNumber=function(){return this.unsigned?(this.high>>>0)*h+(this.low>>>0):this.high*h+(this.low>>>0)},A.toString=function(e){if((e=e||10)<2||36>>0).toString(e);if((a=o).isZero())return l+s;for(;l.length<6;)l="0"+l;s=""+l+s}},A.getHighBits=function(){return this.high},A.getHighBitsUnsigned=function(){return this.high>>>0},A.getLowBits=function(){return this.low},A.getLowBitsUnsigned=function(){return this.low>>>0},A.getNumBitsAbs=function(){if(this.isNegative())return this.eq(x)?64:this.neg().getNumBitsAbs();for(var e=0!=this.high?this.high:this.low,r=31;r>0&&0==(e&1<=0},A.isOdd=function(){return 1==(1&this.low)},A.isEven=function(){return 0==(1&this.low)},A.equals=function(e){return i(e)||(e=_(e)),(this.unsigned===e.unsigned||this.high>>>31!=1||e.high>>>31!=1)&&(this.high===e.high&&this.low===e.low)},A.eq=A.equals,A.notEquals=function(e){return!this.eq(e)},A.neq=A.notEquals,A.ne=A.notEquals,A.lessThan=function(e){return this.comp(e)<0},A.lt=A.lessThan,A.lessThanOrEqual=function(e){return this.comp(e)<=0},A.lte=A.lessThanOrEqual,A.le=A.lessThanOrEqual,A.greaterThan=function(e){return this.comp(e)>0},A.gt=A.greaterThan,A.greaterThanOrEqual=function(e){return this.comp(e)>=0},A.gte=A.greaterThanOrEqual,A.ge=A.greaterThanOrEqual,A.compare=function(e){if(i(e)||(e=_(e)),this.eq(e))return 0;var r=this.isNegative(),t=e.isNegative();return r&&!t?-1:!r&&t?1:this.unsigned?e.high>>>0>this.high>>>0||e.high===this.high&&e.low>>>0>this.low>>>0?-1:1:this.sub(e).isNegative()?-1:1},A.comp=A.compare,A.negate=function(){return!this.unsigned&&this.eq(x)?x:this.not().add(g)},A.neg=A.negate,A.add=function(e){i(e)||(e=_(e));var r=this.high>>>16,t=65535&this.high,n=this.low>>>16,a=65535&this.low,s=e.high>>>16,o=65535&e.high,c=e.low>>>16,u=0,p=0,h=0,d=0;return h+=(d+=a+(65535&e.low))>>>16,p+=(h+=n+c)>>>16,u+=(p+=t+o)>>>16,u+=r+s,l((h&=65535)<<16|(d&=65535),(u&=65535)<<16|(p&=65535),this.unsigned)},A.subtract=function(e){return i(e)||(e=_(e)),this.add(e.neg())},A.sub=A.subtract,A.multiply=function(e){if(this.isZero())return f;if(i(e)||(e=_(e)),t)return l(t.mul(this.low,this.high,e.low,e.high),t.get_high(),this.unsigned);if(e.isZero())return f;if(this.eq(x))return e.isOdd()?x:f;if(e.eq(x))return this.isOdd()?x:f;if(this.isNegative())return e.isNegative()?this.neg().mul(e.neg()):this.neg().mul(e).neg();if(e.isNegative())return this.mul(e.neg()).neg();if(this.lt(m)&&e.lt(m))return c(this.toNumber()*e.toNumber(),this.unsigned);var r=this.high>>>16,n=65535&this.high,a=this.low>>>16,s=65535&this.low,o=e.high>>>16,u=65535&e.high,p=e.low>>>16,h=65535&e.low,d=0,y=0,T=0,g=0;return T+=(g+=s*h)>>>16,y+=(T+=a*h)>>>16,T&=65535,y+=(T+=s*p)>>>16,d+=(y+=n*h)>>>16,y&=65535,d+=(y+=a*p)>>>16,y&=65535,d+=(y+=s*u)>>>16,d+=r*h+n*p+a*u+s*o,l((T&=65535)<<16|(g&=65535),(d&=65535)<<16|(y&=65535),this.unsigned)},A.mul=A.multiply,A.divide=function(e){if(i(e)||(e=_(e)),e.isZero())throw Error("division by zero");var r,n,a;if(t)return this.unsigned||-2147483648!==this.high||-1!==e.low||-1!==e.high?l((this.unsigned?t.div_u:t.div_s)(this.low,this.high,e.low,e.high),t.get_high(),this.unsigned):this;if(this.isZero())return this.unsigned?T:f;if(this.unsigned){if(e.unsigned||(e=e.toUnsigned()),e.gt(this))return T;if(e.gt(this.shru(1)))return E;a=T}else{if(this.eq(x))return e.eq(g)||e.eq(v)?x:e.eq(x)?g:(r=this.shr(1).div(e).shl(1)).eq(f)?e.isNegative()?g:v:(n=this.sub(e.mul(r)),a=r.add(n.div(e)));if(e.eq(x))return this.unsigned?T:f;if(this.isNegative())return e.isNegative()?this.neg().div(e.neg()):this.neg().div(e).neg();if(e.isNegative())return this.div(e.neg()).neg();a=f}for(n=this;n.gte(e);){r=Math.max(1,Math.floor(n.toNumber()/e.toNumber()));for(var s=Math.ceil(Math.log(r)/Math.LN2),o=s<=48?1:u(2,s-48),p=c(r),h=p.mul(e);h.isNegative()||h.gt(n);)h=(p=c(r-=o,this.unsigned)).mul(e);p.isZero()&&(p=g),a=a.add(p),n=n.sub(h)}return a},A.div=A.divide,A.modulo=function(e){return i(e)||(e=_(e)),t?l((this.unsigned?t.rem_u:t.rem_s)(this.low,this.high,e.low,e.high),t.get_high(),this.unsigned):this.sub(this.div(e).mul(e))},A.mod=A.modulo,A.rem=A.modulo,A.not=function(){return l(~this.low,~this.high,this.unsigned)},A.and=function(e){return i(e)||(e=_(e)),l(this.low&e.low,this.high&e.high,this.unsigned)},A.or=function(e){return i(e)||(e=_(e)),l(this.low|e.low,this.high|e.high,this.unsigned)},A.xor=function(e){return i(e)||(e=_(e)),l(this.low^e.low,this.high^e.high,this.unsigned)},A.shiftLeft=function(e){return i(e)&&(e=e.toInt()),0==(e&=63)?this:e<32?l(this.low<>>32-e,this.unsigned):l(0,this.low<>>e|this.high<<32-e,this.high>>e,this.unsigned):l(this.high>>e-32,this.high>=0?0:-1,this.unsigned)},A.shr=A.shiftRight,A.shiftRightUnsigned=function(e){if(i(e)&&(e=e.toInt()),0===(e&=63))return this;var r=this.high;return e<32?l(this.low>>>e|r<<32-e,r>>>e,this.unsigned):l(32===e?r:r>>>e-32,0,this.unsigned)},A.shru=A.shiftRightUnsigned,A.shr_u=A.shiftRightUnsigned,A.toSigned=function(){return this.unsigned?l(this.low,this.high,!1):this},A.toUnsigned=function(){return this.unsigned?this:l(this.low,this.high,!0)},A.toBytes=function(e){return e?this.toBytesLE():this.toBytesBE()},A.toBytesLE=function(){var e=this.high,r=this.low;return[255&r,r>>>8&255,r>>>16&255,r>>>24,255&e,e>>>8&255,e>>>16&255,e>>>24]},A.toBytesBE=function(){var e=this.high,r=this.low;return[e>>>24,e>>>16&255,e>>>8&255,255&e,r>>>24,r>>>16&255,r>>>8&255,255&r]},n.fromBytes=function(e,r,t){return t?n.fromBytesLE(e,r):n.fromBytesBE(e,r)},n.fromBytesLE=function(e,r){return new n(e[0]|e[1]<<8|e[2]<<16|e[3]<<24,e[4]|e[5]<<8|e[6]<<16|e[7]<<24,r)},n.fromBytesBE=function(e,r){return new n(e[4]<<24|e[5]<<16|e[6]<<8|e[7],e[0]<<24|e[1]<<16|e[2]<<8|e[3],r)}},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),function(e){e[e.NONE=0]="NONE",e[e.SIGN_EXTENSION=1]="SIGN_EXTENSION",e[e.MUTABLE_GLOBAL=2]="MUTABLE_GLOBAL",e[e.BULK_MEMORY=4]="BULK_MEMORY",e[e.SIMD=8]="SIMD",e[e.THREADS=16]="THREADS"}(r.Feature||(r.Feature={}))},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),function(e){e[e.WASM32=0]="WASM32",e[e.WASM64=1]="WASM64",e[e.JS=2]="JS"}(r.Target||(r.Target={}))},function(e,r,t){"use strict";var n=this&&this.__decorate||function(e,r,t,n){var i,a=arguments.length,s=a<3?r:null===n?n=Object.getOwnPropertyDescriptor(r,t):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,r,t,n);else for(var o=e.length-1;o>=0;o--)(i=e[o])&&(s=(a<3?i(s):a>3?i(r,t,s):i(r,t))||s);return a>3&&s&&Object.defineProperty(r,t,s),s};Object.defineProperty(r,"__esModule",{value:!0});var i=function(){function e(){}return e=n([unmanaged],e)}();r.Typeinfo=i,function(e){e[e.NONE=0]="NONE",e[e.ARRAYBUFFERVIEW=1]="ARRAYBUFFERVIEW",e[e.ARRAY=2]="ARRAY",e[e.SET=4]="SET",e[e.MAP=8]="MAP",e[e.ACYCLIC=16]="ACYCLIC",e[e.VALUE_ALIGN_0=32]="VALUE_ALIGN_0",e[e.VALUE_ALIGN_1=64]="VALUE_ALIGN_1",e[e.VALUE_ALIGN_2=128]="VALUE_ALIGN_2",e[e.VALUE_ALIGN_3=256]="VALUE_ALIGN_3",e[e.VALUE_ALIGN_4=512]="VALUE_ALIGN_4",e[e.VALUE_SIGNED=1024]="VALUE_SIGNED",e[e.VALUE_FLOAT=2048]="VALUE_FLOAT",e[e.VALUE_NULLABLE=4096]="VALUE_NULLABLE",e[e.VALUE_MANAGED=8192]="VALUE_MANAGED",e[e.KEY_ALIGN_0=16384]="KEY_ALIGN_0",e[e.KEY_ALIGN_1=32768]="KEY_ALIGN_1",e[e.KEY_ALIGN_2=65536]="KEY_ALIGN_2",e[e.KEY_ALIGN_3=131072]="KEY_ALIGN_3",e[e.KEY_ALIGN_4=262144]="KEY_ALIGN_4",e[e.KEY_SIGNED=524288]="KEY_SIGNED",e[e.KEY_FLOAT=1048576]="KEY_FLOAT",e[e.KEY_NULLABLE=2097152]="KEY_NULLABLE",e[e.KEY_MANAGED=4194304]="KEY_MANAGED"}(r.TypeinfoFlags||(r.TypeinfoFlags={}))},function(e,r,t){"use strict";var n=this&&this.__values||function(e){var r="function"==typeof Symbol&&e[Symbol.iterator],t=0;return r?r.call(e):{next:function(){return e&&t>=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}};function i(e){for(var t in e)r.hasOwnProperty(t)||(r[t]=e[t])}Object.defineProperty(r,"__esModule",{value:!0});var a=t(11),s=t(14),o=t(15),c=t(2);r.formatDiagnostic=c.formatDiagnosticMessage;var l=t(16);r.parseFile=function(e,r,t,n){return void 0===t&&(t=!1),void 0===n&&(n=null),n||(n=new l.Parser),n.parseFile(e,r,t),n},r.nextFile=function(e){return e.nextFile()},r.nextDiagnostic=function(e){var r=e.program;return r.diagnosticsOffset=0&&r<64),i64_ne(i64_and(e,i64_shl(i64_one,i64_new(r))),i64_zero)},r.bitsetSet=function(e,r,t){return assert(r>=0&&r<64),t?i64_or(e,i64_shl(i64_one,i64_new(r))):i64_and(e,i64_not(i64_shl(i64_one,i64_new(r))))}},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),function(e){e[e.NULL=0]="NULL",e[e.LINEFEED=10]="LINEFEED",e[e.CARRIAGERETURN=13]="CARRIAGERETURN",e[e.LINESEPARATOR=8232]="LINESEPARATOR",e[e.PARAGRAPHSEPARATOR=8233]="PARAGRAPHSEPARATOR",e[e.NEXTLINE=133]="NEXTLINE",e[e.SPACE=32]="SPACE",e[e.NONBREAKINGSPACE=160]="NONBREAKINGSPACE",e[e.ENQUAD=8192]="ENQUAD",e[e.EMQUAD=8193]="EMQUAD",e[e.ENSPACE=8194]="ENSPACE",e[e.EMSPACE=8195]="EMSPACE",e[e.THREEPEREMSPACE=8196]="THREEPEREMSPACE",e[e.FOURPEREMSPACE=8197]="FOURPEREMSPACE",e[e.SIXPEREMSPACE=8198]="SIXPEREMSPACE",e[e.FIGURESPACE=8199]="FIGURESPACE",e[e.PUNCTUATIONSPACE=8200]="PUNCTUATIONSPACE",e[e.THINSPACE=8201]="THINSPACE",e[e.HAIRSPACE=8202]="HAIRSPACE",e[e.ZEROWIDTHSPACE=8203]="ZEROWIDTHSPACE",e[e.NARROWNOBREAKSPACE=8239]="NARROWNOBREAKSPACE",e[e.IDEOGRAPHICSPACE=12288]="IDEOGRAPHICSPACE",e[e.MATHEMATICALSPACE=8287]="MATHEMATICALSPACE",e[e.OGHAM=5760]="OGHAM",e[e._=95]="_",e[e._0=48]="_0",e[e._1=49]="_1",e[e._2=50]="_2",e[e._3=51]="_3",e[e._4=52]="_4",e[e._5=53]="_5",e[e._6=54]="_6",e[e._7=55]="_7",e[e._8=56]="_8",e[e._9=57]="_9",e[e.a=97]="a",e[e.b=98]="b",e[e.c=99]="c",e[e.d=100]="d",e[e.e=101]="e",e[e.f=102]="f",e[e.g=103]="g",e[e.h=104]="h",e[e.i=105]="i",e[e.j=106]="j",e[e.k=107]="k",e[e.l=108]="l",e[e.m=109]="m",e[e.n=110]="n",e[e.o=111]="o",e[e.p=112]="p",e[e.q=113]="q",e[e.r=114]="r",e[e.s=115]="s",e[e.t=116]="t",e[e.u=117]="u",e[e.v=118]="v",e[e.w=119]="w",e[e.x=120]="x",e[e.y=121]="y",e[e.z=122]="z",e[e.A=65]="A",e[e.B=66]="B",e[e.C=67]="C",e[e.D=68]="D",e[e.E=69]="E",e[e.F=70]="F",e[e.G=71]="G",e[e.H=72]="H",e[e.I=73]="I",e[e.J=74]="J",e[e.K=75]="K",e[e.L=76]="L",e[e.M=77]="M",e[e.N=78]="N",e[e.O=79]="O",e[e.P=80]="P",e[e.Q=81]="Q",e[e.R=82]="R",e[e.S=83]="S",e[e.T=84]="T",e[e.U=85]="U",e[e.V=86]="V",e[e.W=87]="W",e[e.X=88]="X",e[e.Y=89]="Y",e[e.Z=90]="Z",e[e.AMPERSAND=38]="AMPERSAND",e[e.ASTERISK=42]="ASTERISK",e[e.AT=64]="AT",e[e.BACKSLASH=92]="BACKSLASH",e[e.BACKTICK=96]="BACKTICK",e[e.BAR=124]="BAR",e[e.CARET=94]="CARET",e[e.CLOSEBRACE=125]="CLOSEBRACE",e[e.CLOSEBRACKET=93]="CLOSEBRACKET",e[e.CLOSEPAREN=41]="CLOSEPAREN",e[e.COLON=58]="COLON",e[e.COMMA=44]="COMMA",e[e.DOLLAR=36]="DOLLAR",e[e.DOT=46]="DOT",e[e.DOUBLEQUOTE=34]="DOUBLEQUOTE",e[e.EQUALS=61]="EQUALS",e[e.EXCLAMATION=33]="EXCLAMATION",e[e.GREATERTHAN=62]="GREATERTHAN",e[e.HASH=35]="HASH",e[e.LESSTHAN=60]="LESSTHAN",e[e.MINUS=45]="MINUS",e[e.OPENBRACE=123]="OPENBRACE",e[e.OPENBRACKET=91]="OPENBRACKET",e[e.OPENPAREN=40]="OPENPAREN",e[e.PERCENT=37]="PERCENT",e[e.PLUS=43]="PLUS",e[e.QUESTION=63]="QUESTION",e[e.SEMICOLON=59]="SEMICOLON",e[e.SINGLEQUOTE=39]="SINGLEQUOTE",e[e.SLASH=47]="SLASH",e[e.TILDE=126]="TILDE",e[e.BACKSPACE=8]="BACKSPACE",e[e.FORMFEED=12]="FORMFEED",e[e.BYTEORDERMARK=65279]="BYTEORDERMARK",e[e.TAB=9]="TAB",e[e.VERTICALTAB=11]="VERTICALTAB"}(r.CharCode||(r.CharCode={})),r.isLineBreak=function(e){switch(e){case 10:case 13:case 8232:case 8233:return!0;default:return!1}},r.isWhiteSpace=function(e){switch(e){case 32:case 9:case 11:case 12:case 160:case 133:case 5760:case 8239:case 8287:case 12288:case 65279:return!0;default:return e>=8192&&e<=8203}},r.isDecimalDigit=function(e){return e>=48&&e<=57},r.isOctalDigit=function(e){return e>=48&&e<=55},r.isIdentifierStart=function(e){return e>=97&&e<=122||e>=65&&e<=90||95==e||36==e||e>127&&!((r=e)<0||r>65535)&&a(r,n);var r},r.isKeywordCharacter=function(e){return e>=97&&e<=122},r.isIdentifierPart=function(e){return e>=97&&e<=122||e>=65&&e<=90||e>=48&&e<=57||95==e||36==e||e>127&&!((r=e)<0||r>65535)&&a(r,i);var r};var n=[170,170,181,181,186,186,192,214,216,246,248,705,710,721,736,740,748,748,750,750,880,884,886,887,890,893,902,902,904,906,908,908,910,929,931,1013,1015,1153,1162,1319,1329,1366,1369,1369,1377,1415,1488,1514,1520,1522,1568,1610,1646,1647,1649,1747,1749,1749,1765,1766,1774,1775,1786,1788,1791,1791,1808,1808,1810,1839,1869,1957,1969,1969,1994,2026,2036,2037,2042,2042,2048,2069,2074,2074,2084,2084,2088,2088,2112,2136,2208,2208,2210,2220,2308,2361,2365,2365,2384,2384,2392,2401,2417,2423,2425,2431,2437,2444,2447,2448,2451,2472,2474,2480,2482,2482,2486,2489,2493,2493,2510,2510,2524,2525,2527,2529,2544,2545,2565,2570,2575,2576,2579,2600,2602,2608,2610,2611,2613,2614,2616,2617,2649,2652,2654,2654,2674,2676,2693,2701,2703,2705,2707,2728,2730,2736,2738,2739,2741,2745,2749,2749,2768,2768,2784,2785,2821,2828,2831,2832,2835,2856,2858,2864,2866,2867,2869,2873,2877,2877,2908,2909,2911,2913,2929,2929,2947,2947,2949,2954,2958,2960,2962,2965,2969,2970,2972,2972,2974,2975,2979,2980,2984,2986,2990,3001,3024,3024,3077,3084,3086,3088,3090,3112,3114,3123,3125,3129,3133,3133,3160,3161,3168,3169,3205,3212,3214,3216,3218,3240,3242,3251,3253,3257,3261,3261,3294,3294,3296,3297,3313,3314,3333,3340,3342,3344,3346,3386,3389,3389,3406,3406,3424,3425,3450,3455,3461,3478,3482,3505,3507,3515,3517,3517,3520,3526,3585,3632,3634,3635,3648,3654,3713,3714,3716,3716,3719,3720,3722,3722,3725,3725,3732,3735,3737,3743,3745,3747,3749,3749,3751,3751,3754,3755,3757,3760,3762,3763,3773,3773,3776,3780,3782,3782,3804,3807,3840,3840,3904,3911,3913,3948,3976,3980,4096,4138,4159,4159,4176,4181,4186,4189,4193,4193,4197,4198,4206,4208,4213,4225,4238,4238,4256,4293,4295,4295,4301,4301,4304,4346,4348,4680,4682,4685,4688,4694,4696,4696,4698,4701,4704,4744,4746,4749,4752,4784,4786,4789,4792,4798,4800,4800,4802,4805,4808,4822,4824,4880,4882,4885,4888,4954,4992,5007,5024,5108,5121,5740,5743,5759,5761,5786,5792,5866,5870,5872,5888,5900,5902,5905,5920,5937,5952,5969,5984,5996,5998,6e3,6016,6067,6103,6103,6108,6108,6176,6263,6272,6312,6314,6314,6320,6389,6400,6428,6480,6509,6512,6516,6528,6571,6593,6599,6656,6678,6688,6740,6823,6823,6917,6963,6981,6987,7043,7072,7086,7087,7098,7141,7168,7203,7245,7247,7258,7293,7401,7404,7406,7409,7413,7414,7424,7615,7680,7957,7960,7965,7968,8005,8008,8013,8016,8023,8025,8025,8027,8027,8029,8029,8031,8061,8064,8116,8118,8124,8126,8126,8130,8132,8134,8140,8144,8147,8150,8155,8160,8172,8178,8180,8182,8188,8305,8305,8319,8319,8336,8348,8450,8450,8455,8455,8458,8467,8469,8469,8473,8477,8484,8484,8486,8486,8488,8488,8490,8493,8495,8505,8508,8511,8517,8521,8526,8526,8544,8584,11264,11310,11312,11358,11360,11492,11499,11502,11506,11507,11520,11557,11559,11559,11565,11565,11568,11623,11631,11631,11648,11670,11680,11686,11688,11694,11696,11702,11704,11710,11712,11718,11720,11726,11728,11734,11736,11742,11823,11823,12293,12295,12321,12329,12337,12341,12344,12348,12353,12438,12445,12447,12449,12538,12540,12543,12549,12589,12593,12686,12704,12730,12784,12799,13312,19893,19968,40908,40960,42124,42192,42237,42240,42508,42512,42527,42538,42539,42560,42606,42623,42647,42656,42735,42775,42783,42786,42888,42891,42894,42896,42899,42912,42922,43e3,43009,43011,43013,43015,43018,43020,43042,43072,43123,43138,43187,43250,43255,43259,43259,43274,43301,43312,43334,43360,43388,43396,43442,43471,43471,43520,43560,43584,43586,43588,43595,43616,43638,43642,43642,43648,43695,43697,43697,43701,43702,43705,43709,43712,43712,43714,43714,43739,43741,43744,43754,43762,43764,43777,43782,43785,43790,43793,43798,43808,43814,43816,43822,43968,44002,44032,55203,55216,55238,55243,55291,63744,64109,64112,64217,64256,64262,64275,64279,64285,64285,64287,64296,64298,64310,64312,64316,64318,64318,64320,64321,64323,64324,64326,64433,64467,64829,64848,64911,64914,64967,65008,65019,65136,65140,65142,65276,65313,65338,65345,65370,65382,65470,65474,65479,65482,65487,65490,65495,65498,65500],i=[170,170,181,181,186,186,192,214,216,246,248,705,710,721,736,740,748,748,750,750,768,884,886,887,890,893,902,902,904,906,908,908,910,929,931,1013,1015,1153,1155,1159,1162,1319,1329,1366,1369,1369,1377,1415,1425,1469,1471,1471,1473,1474,1476,1477,1479,1479,1488,1514,1520,1522,1552,1562,1568,1641,1646,1747,1749,1756,1759,1768,1770,1788,1791,1791,1808,1866,1869,1969,1984,2037,2042,2042,2048,2093,2112,2139,2208,2208,2210,2220,2276,2302,2304,2403,2406,2415,2417,2423,2425,2431,2433,2435,2437,2444,2447,2448,2451,2472,2474,2480,2482,2482,2486,2489,2492,2500,2503,2504,2507,2510,2519,2519,2524,2525,2527,2531,2534,2545,2561,2563,2565,2570,2575,2576,2579,2600,2602,2608,2610,2611,2613,2614,2616,2617,2620,2620,2622,2626,2631,2632,2635,2637,2641,2641,2649,2652,2654,2654,2662,2677,2689,2691,2693,2701,2703,2705,2707,2728,2730,2736,2738,2739,2741,2745,2748,2757,2759,2761,2763,2765,2768,2768,2784,2787,2790,2799,2817,2819,2821,2828,2831,2832,2835,2856,2858,2864,2866,2867,2869,2873,2876,2884,2887,2888,2891,2893,2902,2903,2908,2909,2911,2915,2918,2927,2929,2929,2946,2947,2949,2954,2958,2960,2962,2965,2969,2970,2972,2972,2974,2975,2979,2980,2984,2986,2990,3001,3006,3010,3014,3016,3018,3021,3024,3024,3031,3031,3046,3055,3073,3075,3077,3084,3086,3088,3090,3112,3114,3123,3125,3129,3133,3140,3142,3144,3146,3149,3157,3158,3160,3161,3168,3171,3174,3183,3202,3203,3205,3212,3214,3216,3218,3240,3242,3251,3253,3257,3260,3268,3270,3272,3274,3277,3285,3286,3294,3294,3296,3299,3302,3311,3313,3314,3330,3331,3333,3340,3342,3344,3346,3386,3389,3396,3398,3400,3402,3406,3415,3415,3424,3427,3430,3439,3450,3455,3458,3459,3461,3478,3482,3505,3507,3515,3517,3517,3520,3526,3530,3530,3535,3540,3542,3542,3544,3551,3570,3571,3585,3642,3648,3662,3664,3673,3713,3714,3716,3716,3719,3720,3722,3722,3725,3725,3732,3735,3737,3743,3745,3747,3749,3749,3751,3751,3754,3755,3757,3769,3771,3773,3776,3780,3782,3782,3784,3789,3792,3801,3804,3807,3840,3840,3864,3865,3872,3881,3893,3893,3895,3895,3897,3897,3902,3911,3913,3948,3953,3972,3974,3991,3993,4028,4038,4038,4096,4169,4176,4253,4256,4293,4295,4295,4301,4301,4304,4346,4348,4680,4682,4685,4688,4694,4696,4696,4698,4701,4704,4744,4746,4749,4752,4784,4786,4789,4792,4798,4800,4800,4802,4805,4808,4822,4824,4880,4882,4885,4888,4954,4957,4959,4992,5007,5024,5108,5121,5740,5743,5759,5761,5786,5792,5866,5870,5872,5888,5900,5902,5908,5920,5940,5952,5971,5984,5996,5998,6e3,6002,6003,6016,6099,6103,6103,6108,6109,6112,6121,6155,6157,6160,6169,6176,6263,6272,6314,6320,6389,6400,6428,6432,6443,6448,6459,6470,6509,6512,6516,6528,6571,6576,6601,6608,6617,6656,6683,6688,6750,6752,6780,6783,6793,6800,6809,6823,6823,6912,6987,6992,7001,7019,7027,7040,7155,7168,7223,7232,7241,7245,7293,7376,7378,7380,7414,7424,7654,7676,7957,7960,7965,7968,8005,8008,8013,8016,8023,8025,8025,8027,8027,8029,8029,8031,8061,8064,8116,8118,8124,8126,8126,8130,8132,8134,8140,8144,8147,8150,8155,8160,8172,8178,8180,8182,8188,8204,8205,8255,8256,8276,8276,8305,8305,8319,8319,8336,8348,8400,8412,8417,8417,8421,8432,8450,8450,8455,8455,8458,8467,8469,8469,8473,8477,8484,8484,8486,8486,8488,8488,8490,8493,8495,8505,8508,8511,8517,8521,8526,8526,8544,8584,11264,11310,11312,11358,11360,11492,11499,11507,11520,11557,11559,11559,11565,11565,11568,11623,11631,11631,11647,11670,11680,11686,11688,11694,11696,11702,11704,11710,11712,11718,11720,11726,11728,11734,11736,11742,11744,11775,11823,11823,12293,12295,12321,12335,12337,12341,12344,12348,12353,12438,12441,12442,12445,12447,12449,12538,12540,12543,12549,12589,12593,12686,12704,12730,12784,12799,13312,19893,19968,40908,40960,42124,42192,42237,42240,42508,42512,42539,42560,42607,42612,42621,42623,42647,42655,42737,42775,42783,42786,42888,42891,42894,42896,42899,42912,42922,43e3,43047,43072,43123,43136,43204,43216,43225,43232,43255,43259,43259,43264,43309,43312,43347,43360,43388,43392,43456,43471,43481,43520,43574,43584,43597,43600,43609,43616,43638,43642,43643,43648,43714,43739,43741,43744,43759,43762,43766,43777,43782,43785,43790,43793,43798,43808,43814,43816,43822,43968,44010,44012,44013,44016,44025,44032,55203,55216,55238,55243,55291,63744,64109,64112,64217,64256,64262,64275,64279,64285,64296,64298,64310,64312,64316,64318,64318,64320,64321,64323,64324,64326,64433,64467,64829,64848,64911,64914,64967,65008,65019,65024,65039,65056,65062,65075,65076,65101,65103,65136,65140,65142,65276,65296,65305,65313,65338,65343,65343,65345,65370,65382,65470,65474,65479,65482,65487,65490,65495,65498,65500];function a(e,r){if(e>1),(n=r[t-=1&t])<=e&&e<=r[t+1])return!0;e=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},i=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0}),r.makeArray=function(e){if(void 0===e&&(e=null),e){for(var r=new Array(e.length),t=0,n=e.length;t0||n=0;)if(e.charCodeAt(a)==i){t-a==3&&46==e.charCodeAt(a+1)&&46==e.charCodeAt(a+2)||(e=r?e.substring(0,a):e.substring(0,a)+e.substring(t+3),n-=t+3-a,t=a-1);break}if(a<0&&t>0&&(2!=t||46!=e.charCodeAt(0)||46!=e.charCodeAt(1))){n=(e=e.substring(t+4)).length;continue}}}t++}return n>0?e:"."}function s(e){var r=e.length;if(r<=1){if(0==r)return".";if(e.charCodeAt(0)==i)return e}for(;--r>0;)if(e.charCodeAt(r)==i)return e.substring(0,r);return"."}r.normalizePath=a,r.resolvePath=function(e,r){return e.startsWith("std/")?e:a(s(r)+n.PATH_DELIMITER+e)},r.dirname=s},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n=" ",i=" ",a=" ";r.indent=function(e,r){for(;r>=4;)e.push(a),r-=4;r>=2&&(e.push(i),r-=2),r&&e.push(n)}},function(e,r,t){"use strict";function n(e,r){return e[r]|e[r+1]<<8|e[r+2]<<16|e[r+3]<<24}function i(e,r,t){r[t]=e,r[t+1]=e>>>8,r[t+2]=e>>>16,r[t+3]=e>>>24}function a(e,r){var t=n(e,r),i=n(e,r+4);return i64_new(t,i)}Object.defineProperty(r,"__esModule",{value:!0}),r.readI8=function(e,r){return e[r]},r.writeI8=function(e,r,t){r[t]=e},r.readI16=function(e,r){return e[r]|e[r+1]<<8},r.writeI16=function(e,r,t){r[t]=e,r[t+1]=e>>>8},r.readI32=n,r.writeI32=i,r.readI64=a,r.writeI64=function(e,r,t){i(i64_low(e),r,t),i(i64_high(e),r,t+4)},r.readF32=function(e,r){return i32_as_f32(n(e,r))},r.writeF32=function(e,r,t){i(f32_as_i32(e),r,t)},r.readF64=function(e,r){return i64_as_f64(a(e,r))},r.writeF64=function(e,r,t){var n=f64_as_i64(e);i(i64_low(n),r,t),i(i64_high(n),r,t+4)}}])}); +!function(e,r){"object"==typeof exports&&"object"==typeof module?module.exports=r(require("binaryen")):"function"==typeof define&&define.amd?define(["binaryen"],r):"object"==typeof exports?exports.assemblyscript=r(require("binaryen")):e.assemblyscript=r(e.binaryen)}("undefined"!=typeof self?self:this,function(e){return function(e){var r={};function t(n){if(r[n])return r[n].exports;var i=r[n]={i:n,l:!1,exports:{}};return e[n].call(i.exports,i,i.exports,t),i.l=!0,i.exports}return t.m=e,t.c=r,t.d=function(e,r,n){t.o(e,r)||Object.defineProperty(e,r,{enumerable:!0,get:n})},t.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},t.t=function(e,r){if(1&r&&(e=t(e)),8&r)return e;if(4&r&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(t.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&r&&"string"!=typeof e)for(var i in e)t.d(n,i,function(r){return e[r]}.bind(null,i));return n},t.n=function(e){var r=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(r,"a",r),r},t.o=function(e,r){return Object.prototype.hasOwnProperty.call(e,r)},t.p="",t(t.s=17)}([function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),function(e){e[e.NONE=0]="NONE",e[e.IMPORT=1]="IMPORT",e[e.EXPORT=2]="EXPORT",e[e.DECLARE=4]="DECLARE",e[e.CONST=8]="CONST",e[e.LET=16]="LET",e[e.STATIC=32]="STATIC",e[e.READONLY=64]="READONLY",e[e.ABSTRACT=128]="ABSTRACT",e[e.PUBLIC=256]="PUBLIC",e[e.PRIVATE=512]="PRIVATE",e[e.PROTECTED=1024]="PROTECTED",e[e.GET=2048]="GET",e[e.SET=4096]="SET",e[e.DEFINITE_ASSIGNMENT=8192]="DEFINITE_ASSIGNMENT",e[e.AMBIENT=16384]="AMBIENT",e[e.GENERIC=32768]="GENERIC",e[e.GENERIC_CONTEXT=65536]="GENERIC_CONTEXT",e[e.INSTANCE=131072]="INSTANCE",e[e.CONSTRUCTOR=262144]="CONSTRUCTOR",e[e.MODULE_EXPORT=524288]="MODULE_EXPORT",e[e.MODULE_IMPORT=1048576]="MODULE_IMPORT",e[e.RESOLVED=2097152]="RESOLVED",e[e.COMPILED=4194304]="COMPILED",e[e.INLINED=8388608]="INLINED",e[e.SCOPED=16777216]="SCOPED",e[e.TRAMPOLINE=33554432]="TRAMPOLINE",e[e.VIRTUAL=67108864]="VIRTUAL",e[e.MAIN=134217728]="MAIN",e[e.QUOTED=268435456]="QUOTED"}(r.CommonFlags||(r.CommonFlags={})),r.PATH_DELIMITER="/",r.PARENT_SUBST="..",r.GETTER_PREFIX="get:",r.SETTER_PREFIX="set:",r.INSTANCE_DELIMITER="#",r.STATIC_DELIMITER=".",r.INNER_DELIMITER="~",r.LIBRARY_SUBST="~lib",r.LIBRARY_PREFIX=r.LIBRARY_SUBST+r.PATH_DELIMITER,r.INDEX_SUFFIX=r.PATH_DELIMITER+"index",function(e){e.EMPTY="",e.i8="i8",e.i16="i16",e.i32="i32",e.i64="i64",e.isize="isize",e.u8="u8",e.u16="u16",e.u32="u32",e.u64="u64",e.usize="usize",e.bool="bool",e.f32="f32",e.f64="f64",e.v128="v128",e.i8x16="i8x16",e.u8x16="u8x16",e.i16x8="i16x8",e.u16x8="u16x8",e.i32x4="i32x4",e.u32x4="u32x4",e.i64x2="i64x2",e.u64x2="u64x2",e.f32x4="f32x4",e.f64x2="f64x2",e.void_="void",e.number="number",e.boolean="boolean",e.string="string",e.native="native",e.indexof="indexof",e.valueof="valueof",e.null_="null",e.true_="true",e.false_="false",e.this_="this",e.super_="super",e.constructor="constructor",e.ASC_TARGET="ASC_TARGET",e.ASC_NO_TREESHAKING="ASC_NO_TREESHAKING",e.ASC_NO_ASSERT="ASC_NO_ASSERT",e.ASC_MEMORY_BASE="ASC_MEMORY_BASE",e.ASC_OPTIMIZE_LEVEL="ASC_OPTIMIZE_LEVEL",e.ASC_SHRINK_LEVEL="ASC_SHRINK_LEVEL",e.ASC_FEATURE_MUTABLE_GLOBAL="ASC_FEATURE_MUTABLE_GLOBAL",e.ASC_FEATURE_SIGN_EXTENSION="ASC_FEATURE_SIGN_EXTENSION",e.ASC_FEATURE_BULK_MEMORY="ASC_FEATURE_BULK_MEMORY",e.ASC_FEATURE_SIMD="ASC_FEATURE_SIMD",e.ASC_FEATURE_THREADS="ASC_FEATURE_THREADS",e.I8="I8",e.I16="I16",e.I32="I32",e.I64="I64",e.Isize="Isize",e.U8="U8",e.U16="U16",e.U32="U32",e.U64="U64",e.Usize="Usize",e.Bool="Bool",e.F32="F32",e.F64="F64",e.V128="V128",e.String="String",e.Array="Array",e.FixedArray="FixedArray",e.Set="Set",e.Map="Map",e.ArrayBufferView="ArrayBufferView",e.ArrayBuffer="ArrayBuffer",e.Math="Math",e.Mathf="Mathf",e.Int8Array="Int8Array",e.Int16Array="Int16Array",e.Int32Array="Int32Array",e.Int64Array="Int64Array",e.Uint8Array="Uint8Array",e.Uint8ClampedArray="Uint8ClampedArray",e.Uint16Array="Uint16Array",e.Uint32Array="Uint32Array",e.Uint64Array="Uint64Array",e.Float32Array="Float32Array",e.Float64Array="Float64Array",e.abort="abort",e.pow="pow",e.mod="mod",e.alloc="__alloc",e.realloc="__realloc",e.free="__free",e.retain="__retain",e.release="__release",e.collect="__collect",e.typeinfo="__typeinfo",e.instanceof_="__instanceof",e.visit="__visit",e.allocArray="__allocArray"}(r.CommonSymbols||(r.CommonSymbols={}));var n=t(25);r.Feature=n.Feature;var i=t(26);r.Target=i.Target;var a=t(27);r.Typeinfo=a.Typeinfo,r.TypeinfoFlags=a.TypeinfoFlags},function(e,r,t){"use strict";function n(e){for(var t in e)r.hasOwnProperty(t)||(r[t]=e[t])}Object.defineProperty(r,"__esModule",{value:!0}),n(t(29)),n(t(30)),n(t(31)),n(t(32)),n(t(33)),n(t(34)),r.isPowerOf2=function(e){return 0!=e&&0==(e&e-1)}},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n,i=t(12),a=t(1),s=t(12);function o(e){switch(e){case n.INFO:return"INFO";case n.WARNING:return"WARNING";case n.ERROR:return"ERROR";default:return assert(!1),""}}function c(e){switch(e){case n.INFO:return r.COLOR_BLUE;case n.WARNING:return r.COLOR_YELLOW;case n.ERROR:return r.COLOR_RED;default:return assert(!1),""}}r.DiagnosticCode=s.DiagnosticCode,r.diagnosticCodeToString=s.diagnosticCodeToString,function(e){e[e.INFO=0]="INFO",e[e.WARNING=1]="WARNING",e[e.ERROR=2]="ERROR"}(n=r.DiagnosticCategory||(r.DiagnosticCategory={})),r.diagnosticCategoryToString=o,r.COLOR_BLUE="",r.COLOR_YELLOW="",r.COLOR_RED="",r.COLOR_RESET="",r.diagnosticCategoryToColor=c;var l=function(){function e(e,r,t){this.range=null,this.relatedRange=null,this.code=e,this.category=r,this.message=t}return e.create=function(r,t,n,a,s){void 0===n&&(n=null),void 0===a&&(a=null),void 0===s&&(s=null);var o=i.diagnosticCodeToString(r);return null!=n&&(o=o.replace("{0}",n)),null!=a&&(o=o.replace("{1}",a)),null!=s&&(o=o.replace("{2}",s)),new e(r,t,o)},e.createInfo=function(r,t,i){return void 0===t&&(t=null),void 0===i&&(i=null),e.create(r,n.INFO,t,i)},e.createWarning=function(r,t,i){return void 0===t&&(t=null),void 0===i&&(i=null),e.create(r,n.WARNING,t,i)},e.createError=function(r,t,i){return void 0===t&&(t=null),void 0===i&&(i=null),e.create(r,n.ERROR,t,i)},e.prototype.withRange=function(e){return this.range=e,this},e.prototype.withRelatedRange=function(e){return this.relatedRange=e,this},e.prototype.toString=function(){return this.range?o(this.category)+" "+this.code.toString(10)+': "'+this.message+'" in '+this.range.source.normalizedPath+":"+this.range.line.toString(10)+":"+this.range.column.toString(10):o(this.category)+" "+this.code.toString(10)+": "+this.message},e}();function u(e,t){void 0===t&&(t=!1);for(var n=e.source.text,i=n.length,s=e.start,o=e.end;s>0&&!a.isLineBreak(n.charCodeAt(s-1));)s--;for(;o=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},s=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0});var o,c=t(0),l=t(2),u=t(6),p=t(5),_=t(1),h=t(9),d=t(10),y=function(){return function(e,r,t,n,i){this.localFile=e,this.localIdentifier=r,this.foreignIdentifier=t,this.foreignPath=n,this.foreignPathAlt=i}}(),m=function(){return function(e,r,t,n){this.localIdentifier=e,this.foreignIdentifier=r,this.foreignPath=t,this.foreignPathAlt=n}}(),f=function(){return function(e,r,t){this.foreignPath=e,this.foreignPathAlt=r,this.pathLiteral=t}}();function T(e,r){switch(assert(r.length),e){case p.DecoratorKind.OPERATOR:case p.DecoratorKind.OPERATOR_BINARY:switch(r.charCodeAt(0)){case 91:if("[]"==r)return o.INDEXED_GET;if("[]="==r)return o.INDEXED_SET;break;case 123:if("{}"==r)return o.UNCHECKED_INDEXED_GET;if("{}="==r)return o.UNCHECKED_INDEXED_SET;break;case 43:if("+"==r)return o.ADD;break;case 45:if("-"==r)return o.SUB;break;case 42:if("*"==r)return o.MUL;if("**"==r)return o.POW;break;case 47:if("/"==r)return o.DIV;break;case 37:if("%"==r)return o.REM;break;case 38:if("&"==r)return o.BITWISE_AND;break;case 124:if("|"==r)return o.BITWISE_OR;break;case 94:if("^"==r)return o.BITWISE_XOR;break;case 61:if("=="==r)return o.EQ;break;case 33:if("!="==r)return o.NE;break;case 62:if(">"==r)return o.GT;if(">="==r)return o.GE;if(">>"==r)return o.BITWISE_SHR;if(">>>"==r)return o.BITWISE_SHR_U;break;case 60:if("<"==r)return o.LT;if("<="==r)return o.LE;if("<<"==r)return o.BITWISE_SHL}break;case p.DecoratorKind.OPERATOR_PREFIX:switch(r.charCodeAt(0)){case 43:if("+"==r)return o.PLUS;if("++"==r)return o.PREFIX_INC;break;case 45:if("-"==r)return o.MINUS;if("--"==r)return o.PREFIX_DEC;break;case 33:if("!"==r)return o.NOT;break;case 126:if("~"==r)return o.BITWISE_NOT}break;case p.DecoratorKind.OPERATOR_POSTFIX:switch(r.charCodeAt(0)){case 43:if("++"==r)return o.POSTFIX_INC;break;case 45:if("--"==r)return o.POSTFIX_DEC}}return o.INVALID}!function(e){e[e.INVALID=0]="INVALID",e[e.INDEXED_GET=1]="INDEXED_GET",e[e.INDEXED_SET=2]="INDEXED_SET",e[e.UNCHECKED_INDEXED_GET=3]="UNCHECKED_INDEXED_GET",e[e.UNCHECKED_INDEXED_SET=4]="UNCHECKED_INDEXED_SET",e[e.ADD=5]="ADD",e[e.SUB=6]="SUB",e[e.MUL=7]="MUL",e[e.DIV=8]="DIV",e[e.REM=9]="REM",e[e.POW=10]="POW",e[e.BITWISE_AND=11]="BITWISE_AND",e[e.BITWISE_OR=12]="BITWISE_OR",e[e.BITWISE_XOR=13]="BITWISE_XOR",e[e.BITWISE_SHL=14]="BITWISE_SHL",e[e.BITWISE_SHR=15]="BITWISE_SHR",e[e.BITWISE_SHR_U=16]="BITWISE_SHR_U",e[e.EQ=17]="EQ",e[e.NE=18]="NE",e[e.GT=19]="GT",e[e.GE=20]="GE",e[e.LT=21]="LT",e[e.LE=22]="LE",e[e.PLUS=23]="PLUS",e[e.MINUS=24]="MINUS",e[e.NOT=25]="NOT",e[e.BITWISE_NOT=26]="BITWISE_NOT",e[e.PREFIX_INC=27]="PREFIX_INC",e[e.PREFIX_DEC=28]="PREFIX_DEC",e[e.POSTFIX_INC=29]="POSTFIX_INC",e[e.POSTFIX_DEC=30]="POSTFIX_DEC"}(o=r.OperatorKind||(r.OperatorKind={}));var g,E,v=function(e){function r(r){void 0===r&&(r=null);var t=e.call(this,r)||this;t.sources=[],t.diagnosticsOffset=0,t.filesByName=new Map,t.elementsByName=new Map,t.elementsByDeclaration=new Map,t.instancesByName=new Map,t.typeClasses=new Map,t.managedClasses=new Map,t.nextClassId=0,t.nativeDummySignature=null;var n=new p.Source(c.LIBRARY_SUBST,"[native code]",p.SourceKind.LIBRARY);t.nativeSource=n;var i=new N(t,n);return t.nativeFile=i,t.filesByName.set(i.internalName,i),t.resolver=new h.Resolver(t),t}return i(r,e),r.prototype.writeRuntimeHeader=function(e,r,t,n){assert(n<1<<28),_.writeI32(n,e,r),_.writeI32(1,e,r+4),_.writeI32(t.id,e,r+8),_.writeI32(n,e,r+12)},Object.defineProperty(r.prototype,"runtimeHeaderSize",{get:function(){return 16},enumerable:!0,configurable:!0}),r.prototype.makeNativeVariableDeclaration=function(e,r){void 0===r&&(r=c.CommonFlags.NONE);var t=this.nativeSource.range;return p.Node.createVariableDeclaration(p.Node.createIdentifierExpression(e,t),null,null,null,r,t)},r.prototype.makeNativeTypeDeclaration=function(e,r){void 0===r&&(r=c.CommonFlags.NONE);var t=this.nativeSource.range,n=p.Node.createIdentifierExpression(e,t);return p.Node.createTypeDeclaration(n,null,p.Node.createOmittedType(t),null,r,t)},r.prototype.makeNativeFunctionDeclaration=function(e,r){void 0===r&&(r=c.CommonFlags.NONE);var t=this.nativeSource.range;return p.Node.createFunctionDeclaration(p.Node.createIdentifierExpression(e,t),null,this.nativeDummySignature||(this.nativeDummySignature=p.Node.createFunctionType([],p.Node.createNamedType(p.Node.createSimpleTypeName(c.CommonSymbols.void_,t),null,!1,t),null,!1,t)),null,null,r,0,t)},r.prototype.makeNativeNamespaceDeclaration=function(e,r){void 0===r&&(r=c.CommonFlags.NONE);var t=this.nativeSource.range;return p.Node.createNamespaceDeclaration(p.Node.createIdentifierExpression(e,t),[],null,r,t)},r.prototype.makeNativeFunction=function(e,r,t,n,i){return void 0===t&&(t=this.nativeFile),void 0===n&&(n=c.CommonFlags.NONE),void 0===i&&(i=E.NONE),new P(e,new D(e,t,this.makeNativeFunctionDeclaration(e,n),i),r)},r.prototype.getElementByDeclaration=function(e){var r=this.elementsByDeclaration;return assert(r.has(e)),r.get(e)},r.prototype.initialize=function(e){var r,t,n,i,o,_,h,d,y,m,f,T;this.options=e,this.registerNativeType(c.CommonSymbols.i8,u.Type.i8),this.registerNativeType(c.CommonSymbols.i16,u.Type.i16),this.registerNativeType(c.CommonSymbols.i32,u.Type.i32),this.registerNativeType(c.CommonSymbols.i64,u.Type.i64),this.registerNativeType(c.CommonSymbols.isize,e.isizeType),this.registerNativeType(c.CommonSymbols.u8,u.Type.u8),this.registerNativeType(c.CommonSymbols.u16,u.Type.u16),this.registerNativeType(c.CommonSymbols.u32,u.Type.u32),this.registerNativeType(c.CommonSymbols.u64,u.Type.u64),this.registerNativeType(c.CommonSymbols.usize,e.usizeType),this.registerNativeType(c.CommonSymbols.bool,u.Type.bool),this.registerNativeType(c.CommonSymbols.f32,u.Type.f32),this.registerNativeType(c.CommonSymbols.f64,u.Type.f64),this.registerNativeType(c.CommonSymbols.void_,u.Type.void),this.registerNativeType(c.CommonSymbols.number,u.Type.f64),this.registerNativeType(c.CommonSymbols.boolean,u.Type.bool),this.nativeFile.add(c.CommonSymbols.native,new S(c.CommonSymbols.native,this.nativeFile,this.makeNativeTypeDeclaration(c.CommonSymbols.native,c.CommonFlags.EXPORT|c.CommonFlags.GENERIC),E.BUILTIN)),this.nativeFile.add(c.CommonSymbols.indexof,new S(c.CommonSymbols.indexof,this.nativeFile,this.makeNativeTypeDeclaration(c.CommonSymbols.indexof,c.CommonFlags.EXPORT|c.CommonFlags.GENERIC),E.BUILTIN)),this.nativeFile.add(c.CommonSymbols.valueof,new S(c.CommonSymbols.valueof,this.nativeFile,this.makeNativeTypeDeclaration(c.CommonSymbols.valueof,c.CommonFlags.EXPORT|c.CommonFlags.GENERIC),E.BUILTIN)),e.hasFeature(8)&&this.registerNativeType(c.CommonSymbols.v128,u.Type.v128),this.registerConstantInteger(c.CommonSymbols.ASC_TARGET,u.Type.i32,i64_new(e.isWasm64?c.Target.WASM64:c.Target.WASM32)),this.registerConstantInteger(c.CommonSymbols.ASC_NO_ASSERT,u.Type.bool,i64_new(e.noAssert?1:0,0)),this.registerConstantInteger(c.CommonSymbols.ASC_MEMORY_BASE,u.Type.i32,i64_new(e.memoryBase,0)),this.registerConstantInteger(c.CommonSymbols.ASC_OPTIMIZE_LEVEL,u.Type.i32,i64_new(e.optimizeLevelHint,0)),this.registerConstantInteger(c.CommonSymbols.ASC_SHRINK_LEVEL,u.Type.i32,i64_new(e.shrinkLevelHint,0)),this.registerConstantInteger(c.CommonSymbols.ASC_FEATURE_MUTABLE_GLOBAL,u.Type.bool,i64_new(e.hasFeature(2)?1:0,0)),this.registerConstantInteger(c.CommonSymbols.ASC_FEATURE_SIGN_EXTENSION,u.Type.bool,i64_new(e.hasFeature(1)?1:0,0)),this.registerConstantInteger(c.CommonSymbols.ASC_FEATURE_BULK_MEMORY,u.Type.bool,i64_new(e.hasFeature(4)?1:0,0)),this.registerConstantInteger(c.CommonSymbols.ASC_FEATURE_SIMD,u.Type.bool,i64_new(e.hasFeature(8)?1:0,0)),this.registerConstantInteger(c.CommonSymbols.ASC_FEATURE_THREADS,u.Type.bool,i64_new(e.hasFeature(16)?1:0,0));for(var v=new Array,b=new Map,I=new Map,A=new Array,O=new Array,C=0,k=this.sources.length;C=48&&ye<=57)this.registerConstantInteger(he,u.Type.i32,i64_new(parseInt(de,10)));else{var me=this.elementsByName;if(!(ve=me.get(de)))throw new Error("no such global element: "+de);if(me.has(he))throw new Error("duplicate global element: "+de);me.set(he,ve)}}}}catch(e){h={error:e}}finally{try{pe&&!pe.done&&(d=ue.return)&&d.call(ue)}finally{if(h)throw h.error}}this.arrayPrototype=this.require(c.CommonSymbols.Array,g.CLASS_PROTOTYPE),this.fixedArrayPrototype=this.require(c.CommonSymbols.FixedArray,g.CLASS_PROTOTYPE),this.setPrototype=this.require(c.CommonSymbols.Set,g.CLASS_PROTOTYPE),this.mapPrototype=this.require(c.CommonSymbols.Map,g.CLASS_PROTOTYPE),this.abortInstance=this.lookupFunction(c.CommonSymbols.abort),this.allocInstance=this.requireFunction(c.CommonSymbols.alloc),this.reallocInstance=this.requireFunction(c.CommonSymbols.realloc),this.freeInstance=this.requireFunction(c.CommonSymbols.free),this.retainInstance=this.requireFunction(c.CommonSymbols.retain),this.releaseInstance=this.requireFunction(c.CommonSymbols.release),this.collectInstance=this.requireFunction(c.CommonSymbols.collect),this.typeinfoInstance=this.requireFunction(c.CommonSymbols.typeinfo),this.instanceofInstance=this.requireFunction(c.CommonSymbols.instanceof_),this.visitInstance=this.requireFunction(c.CommonSymbols.visit),this.allocArrayInstance=this.requireFunction(c.CommonSymbols.allocArray);try{for(var fe=a(this.filesByName.values()),Te=fe.next();!Te.done;Te=fe.next()){j=(R=Te.value).exports;if(R.source.isEntry&&j)try{for(var ge=(f=void 0,a(j.values())),Ee=ge.next();!Ee.done;Ee=ge.next()){var ve=Ee.value;this.markModuleExport(ve)}}catch(e){f={error:e}}finally{try{Ee&&!Ee.done&&(T=ge.return)&&T.call(ge)}finally{if(f)throw f.error}}}}catch(e){y={error:e}}finally{try{Te&&!Te.done&&(m=fe.return)&&m.call(fe)}finally{if(y)throw y.error}}},r.prototype.require=function(e,r){var t=this.lookupGlobal(e);if(!t)throw new Error("missing "+e);if(t.kind!=r)throw new Error("unexpected "+e);return t},r.prototype.requireClass=function(e){var r=this.require(e,g.CLASS_PROTOTYPE),t=this.resolver.resolveClass(r,null);if(!t)throw new Error("invalid "+e);return t},r.prototype.lookupFunction=function(e){var r=this.lookupGlobal(e);return r&&r.kind==g.FUNCTION_PROTOTYPE?this.resolver.resolveFunction(r,null):null},r.prototype.requireFunction=function(e){var r=this.require(e,g.FUNCTION_PROTOTYPE),t=this.resolver.resolveFunction(r,null);if(!t)throw new Error("invalid "+e);return t},r.prototype.markModuleExport=function(e){var r,t,n,i;switch(e.set(c.CommonFlags.MODULE_EXPORT),e.kind){case g.CLASS_PROTOTYPE:var s=e.instanceMembers;if(s)try{for(var o=a(s.values()),l=o.next();!l.done;l=o.next()){var u=l.value;this.markModuleExport(u)}}catch(e){r={error:e}}finally{try{l&&!l.done&&(t=o.return)&&t.call(o)}finally{if(r)throw r.error}}break;case g.PROPERTY_PROTOTYPE:var p=e.getterPrototype;p&&this.markModuleExport(p);var _=e.setterPrototype;_&&this.markModuleExport(_);break;case g.PROPERTY:case g.FUNCTION:case g.FIELD:case g.CLASS:assert(!1)}var h=e.members;if(h)try{for(var d=a(h.values()),y=d.next();!y.done;y=d.next()){u=y.value;this.markModuleExport(u)}}catch(e){n={error:e}}finally{try{y&&!y.done&&(i=d.return)&&i.call(d)}finally{if(n)throw n.error}}},r.prototype.registerNativeType=function(e,r){var t=new S(e,this.nativeFile,this.makeNativeTypeDeclaration(e,c.CommonFlags.EXPORT),E.BUILTIN);t.setType(r),this.nativeFile.add(e,t)},r.prototype.registerNativeTypeClass=function(e,r){assert(!this.typeClasses.has(e));var t=this.lookupGlobal(r);if(t){assert(t.kind==g.CLASS_PROTOTYPE);var n=this.resolver.resolveClass(t,null);n&&this.typeClasses.set(e,n)}},r.prototype.registerConstantInteger=function(e,r,t){assert(r.is(4));var n=new R(e,this.nativeFile,E.NONE,this.makeNativeVariableDeclaration(e,c.CommonFlags.CONST|c.CommonFlags.EXPORT));n.setConstantIntegerValue(t,r),this.nativeFile.add(e,n)},r.prototype.registerConstantFloat=function(e,r,t){assert(r.is(8));var n=new R(e,this.nativeFile,E.NONE,this.makeNativeVariableDeclaration(e,c.CommonFlags.CONST|c.CommonFlags.EXPORT));n.setConstantFloatValue(t,r),this.nativeFile.add(e,n)},r.prototype.ensureGlobal=function(e,r){var t=this.elementsByName;if(t.has(e)&&t.get(e)!==r){var n=q(t.get(e),r);if(!n)return this.error(l.DiagnosticCode.Duplicate_identifier_0,r.identifierNode.range,e),r;r=n}return t.set(e,r),r},r.prototype.lookupGlobal=function(e){var r=this.elementsByName;return r.has(e)?r.get(e):null},r.prototype.requireGlobal=function(e){var r=this.elementsByName;if(r.has(e))return r.get(e);throw new Error("missing global")},r.prototype.lookupForeignFile=function(e,r){var t=this.filesByName;return t.has(e)?t.get(e):t.has(r)?t.get(r):null},r.prototype.lookupForeign=function(e,r,t,n){for(;;){var i=this.lookupForeignFile(r,t);if(!i)return null;var a=i.lookupExport(e);if(a)return a;if(n.has(i)){var s=n.get(i);if(s.has(e)){var o=s.get(e);if(o.foreignPath){e=o.localIdentifier.text,r=o.foreignPath,t=assert(o.foreignPathAlt);continue}if(a=i.lookupInSelf(o.localIdentifier.text))return a}}break}return null},r.prototype.checkDecorators=function(e,r){var t=E.NONE;if(e)for(var n=0,i=e.length;n=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}};Object.defineProperty(r,"__esModule",{value:!0});var i,a,s=t(0);!function(e){e[e.None=_BinaryenTypeNone()]="None",e[e.I32=_BinaryenTypeInt32()]="I32",e[e.I64=_BinaryenTypeInt64()]="I64",e[e.F32=_BinaryenTypeFloat32()]="F32",e[e.F64=_BinaryenTypeFloat64()]="F64",e[e.V128=_BinaryenTypeVec128()]="V128",e[e.Unreachable=_BinaryenTypeUnreachable()]="Unreachable",e[e.Auto=_BinaryenTypeAuto()]="Auto"}(i=r.NativeType||(r.NativeType={})),function(e){e[e.Atomics=_BinaryenFeatureAtomics()]="Atomics",e[e.MutableGloabls=_BinaryenFeatureMutableGlobals()]="MutableGloabls",e[e.NontrappingFPToInt=_BinaryenFeatureNontrappingFPToInt()]="NontrappingFPToInt",e[e.SIMD128=_BinaryenFeatureSIMD128()]="SIMD128",e[e.BulkMemory=_BinaryenFeatureBulkMemory()]="BulkMemory",e[e.SignExt=_BinaryenFeatureSignExt()]="SignExt",e[e.ExceptionHandling=_BinaryenFeatureExceptionHandling()]="ExceptionHandling"}(r.FeatureFlags||(r.FeatureFlags={})),function(e){e[e.Invalid=_BinaryenInvalidId()]="Invalid",e[e.Block=_BinaryenBlockId()]="Block",e[e.If=_BinaryenIfId()]="If",e[e.Loop=_BinaryenLoopId()]="Loop",e[e.Break=_BinaryenBreakId()]="Break",e[e.Switch=_BinaryenSwitchId()]="Switch",e[e.Call=_BinaryenCallId()]="Call",e[e.CallIndirect=_BinaryenCallIndirectId()]="CallIndirect",e[e.LocalGet=_BinaryenLocalGetId()]="LocalGet",e[e.LocalSet=_BinaryenLocalSetId()]="LocalSet",e[e.GlobalGet=_BinaryenGlobalGetId()]="GlobalGet",e[e.GlobalSet=_BinaryenGlobalSetId()]="GlobalSet",e[e.Load=_BinaryenLoadId()]="Load",e[e.Store=_BinaryenStoreId()]="Store",e[e.Const=_BinaryenConstId()]="Const",e[e.Unary=_BinaryenUnaryId()]="Unary",e[e.Binary=_BinaryenBinaryId()]="Binary",e[e.Select=_BinaryenSelectId()]="Select",e[e.Drop=_BinaryenDropId()]="Drop",e[e.Return=_BinaryenReturnId()]="Return",e[e.Host=_BinaryenHostId()]="Host",e[e.Nop=_BinaryenNopId()]="Nop",e[e.Unreachable=_BinaryenUnreachableId()]="Unreachable",e[e.AtomicCmpxchg=_BinaryenAtomicCmpxchgId()]="AtomicCmpxchg",e[e.AtomicRMW=_BinaryenAtomicRMWId()]="AtomicRMW",e[e.AtomicWait=_BinaryenAtomicWaitId()]="AtomicWait",e[e.AtomicNotify=_BinaryenAtomicNotifyId()]="AtomicNotify",e[e.SIMDExtract=_BinaryenSIMDExtractId()]="SIMDExtract",e[e.SIMDReplace=_BinaryenSIMDReplaceId()]="SIMDReplace",e[e.SIMDShuffle=_BinaryenSIMDShuffleId()]="SIMDShuffle",e[e.SIMDBitselect=_BinaryenSIMDBitselectId()]="SIMDBitselect",e[e.SIMDShift=_BinaryenSIMDShiftId()]="SIMDShift",e[e.MemoryInit=_BinaryenMemoryInitId()]="MemoryInit",e[e.DataDrop=_BinaryenDataDropId()]="DataDrop",e[e.MemoryCopy=_BinaryenMemoryCopyId()]="MemoryCopy",e[e.MemoryFill=_BinaryenMemoryFillId()]="MemoryFill"}(a=r.ExpressionId||(r.ExpressionId={})),function(e){e[e.ClzI32=_BinaryenClzInt32()]="ClzI32",e[e.CtzI32=_BinaryenCtzInt32()]="CtzI32",e[e.PopcntI32=_BinaryenPopcntInt32()]="PopcntI32",e[e.NegF32=_BinaryenNegFloat32()]="NegF32",e[e.AbsF32=_BinaryenAbsFloat32()]="AbsF32",e[e.CeilF32=_BinaryenCeilFloat32()]="CeilF32",e[e.FloorF32=_BinaryenFloorFloat32()]="FloorF32",e[e.TruncF32=_BinaryenTruncFloat32()]="TruncF32",e[e.NearestF32=_BinaryenNearestFloat32()]="NearestF32",e[e.SqrtF32=_BinaryenSqrtFloat32()]="SqrtF32",e[e.EqzI32=_BinaryenEqZInt32()]="EqzI32",e[e.ClzI64=_BinaryenClzInt64()]="ClzI64",e[e.CtzI64=_BinaryenCtzInt64()]="CtzI64",e[e.PopcntI64=_BinaryenPopcntInt64()]="PopcntI64",e[e.NegF64=_BinaryenNegFloat64()]="NegF64",e[e.AbsF64=_BinaryenAbsFloat64()]="AbsF64",e[e.CeilF64=_BinaryenCeilFloat64()]="CeilF64",e[e.FloorF64=_BinaryenFloorFloat64()]="FloorF64",e[e.TruncF64=_BinaryenTruncFloat64()]="TruncF64",e[e.NearestF64=_BinaryenNearestFloat64()]="NearestF64",e[e.SqrtF64=_BinaryenSqrtFloat64()]="SqrtF64",e[e.EqzI64=_BinaryenEqZInt64()]="EqzI64",e[e.ExtendI32=_BinaryenExtendSInt32()]="ExtendI32",e[e.ExtendU32=_BinaryenExtendUInt32()]="ExtendU32",e[e.WrapI64=_BinaryenWrapInt64()]="WrapI64",e[e.TruncF32ToI32=_BinaryenTruncSFloat32ToInt32()]="TruncF32ToI32",e[e.TruncF32ToI64=_BinaryenTruncSFloat32ToInt64()]="TruncF32ToI64",e[e.TruncF32ToU32=_BinaryenTruncUFloat32ToInt32()]="TruncF32ToU32",e[e.TruncF32ToU64=_BinaryenTruncUFloat32ToInt64()]="TruncF32ToU64",e[e.TruncF64ToI32=_BinaryenTruncSFloat64ToInt32()]="TruncF64ToI32",e[e.TruncF64ToI64=_BinaryenTruncSFloat64ToInt64()]="TruncF64ToI64",e[e.TruncF64ToU32=_BinaryenTruncUFloat64ToInt32()]="TruncF64ToU32",e[e.TruncF64ToU64=_BinaryenTruncUFloat64ToInt64()]="TruncF64ToU64",e[e.ReinterpretF32=_BinaryenReinterpretFloat32()]="ReinterpretF32",e[e.ReinterpretF64=_BinaryenReinterpretFloat64()]="ReinterpretF64",e[e.ConvertI32ToF32=_BinaryenConvertSInt32ToFloat32()]="ConvertI32ToF32",e[e.ConvertI32ToF64=_BinaryenConvertSInt32ToFloat64()]="ConvertI32ToF64",e[e.ConvertU32ToF32=_BinaryenConvertUInt32ToFloat32()]="ConvertU32ToF32",e[e.ConvertU32ToF64=_BinaryenConvertUInt32ToFloat64()]="ConvertU32ToF64",e[e.ConvertI64ToF32=_BinaryenConvertSInt64ToFloat32()]="ConvertI64ToF32",e[e.ConvertI64ToF64=_BinaryenConvertSInt64ToFloat64()]="ConvertI64ToF64",e[e.ConvertU64ToF32=_BinaryenConvertUInt64ToFloat32()]="ConvertU64ToF32",e[e.ConvertU64ToF64=_BinaryenConvertUInt64ToFloat64()]="ConvertU64ToF64",e[e.PromoteF32=_BinaryenPromoteFloat32()]="PromoteF32",e[e.DemoteF64=_BinaryenDemoteFloat64()]="DemoteF64",e[e.ReinterpretI32=_BinaryenReinterpretInt32()]="ReinterpretI32",e[e.ReinterpretI64=_BinaryenReinterpretInt64()]="ReinterpretI64",e[e.ExtendI8ToI32=_BinaryenExtendS8Int32()]="ExtendI8ToI32",e[e.ExtendI16ToI32=_BinaryenExtendS16Int32()]="ExtendI16ToI32",e[e.ExtendI8ToI64=_BinaryenExtendS8Int64()]="ExtendI8ToI64",e[e.ExtendI16ToI64=_BinaryenExtendS16Int64()]="ExtendI16ToI64",e[e.ExtendI32ToI64=_BinaryenExtendS32Int64()]="ExtendI32ToI64",e[e.SplatVecI8x16=_BinaryenSplatVecI8x16()]="SplatVecI8x16",e[e.SplatVecI16x8=_BinaryenSplatVecI16x8()]="SplatVecI16x8",e[e.SplatVecI32x4=_BinaryenSplatVecI32x4()]="SplatVecI32x4",e[e.SplatVecI64x2=_BinaryenSplatVecI64x2()]="SplatVecI64x2",e[e.SplatVecF32x4=_BinaryenSplatVecF32x4()]="SplatVecF32x4",e[e.SplatVecF64x2=_BinaryenSplatVecF64x2()]="SplatVecF64x2",e[e.NotVec128=_BinaryenNotVec128()]="NotVec128",e[e.NegVecI8x16=_BinaryenNegVecI8x16()]="NegVecI8x16",e[e.AnyTrueVecI8x16=_BinaryenAnyTrueVecI8x16()]="AnyTrueVecI8x16",e[e.AllTrueVecI8x16=_BinaryenAllTrueVecI8x16()]="AllTrueVecI8x16",e[e.NegVecI16x8=_BinaryenNegVecI16x8()]="NegVecI16x8",e[e.AnyTrueVecI16x8=_BinaryenAnyTrueVecI16x8()]="AnyTrueVecI16x8",e[e.AllTrueVecI16x8=_BinaryenAllTrueVecI16x8()]="AllTrueVecI16x8",e[e.NegVecI32x4=_BinaryenNegVecI32x4()]="NegVecI32x4",e[e.AnyTrueVecI32x4=_BinaryenAnyTrueVecI32x4()]="AnyTrueVecI32x4",e[e.AllTrueVecI32x4=_BinaryenAllTrueVecI32x4()]="AllTrueVecI32x4",e[e.NegVecI64x2=_BinaryenNegVecI64x2()]="NegVecI64x2",e[e.AnyTrueVecI64x2=_BinaryenAnyTrueVecI64x2()]="AnyTrueVecI64x2",e[e.AllTrueVecI64x2=_BinaryenAllTrueVecI64x2()]="AllTrueVecI64x2",e[e.AbsVecF32x4=_BinaryenAbsVecF32x4()]="AbsVecF32x4",e[e.NegVecF32x4=_BinaryenNegVecF32x4()]="NegVecF32x4",e[e.SqrtVecF32x4=_BinaryenSqrtVecF32x4()]="SqrtVecF32x4",e[e.AbsVecF64x2=_BinaryenAbsVecF64x2()]="AbsVecF64x2",e[e.NegVecF64x2=_BinaryenNegVecF64x2()]="NegVecF64x2",e[e.SqrtVecF64x2=_BinaryenSqrtVecF64x2()]="SqrtVecF64x2",e[e.TruncSatSVecF32x4ToVecI32x4=_BinaryenTruncSatSVecF32x4ToVecI32x4()]="TruncSatSVecF32x4ToVecI32x4",e[e.TruncSatUVecF32x4ToVecI32x4=_BinaryenTruncSatUVecF32x4ToVecI32x4()]="TruncSatUVecF32x4ToVecI32x4",e[e.TruncSatSVecF64x2ToVecI64x2=_BinaryenTruncSatSVecF64x2ToVecI64x2()]="TruncSatSVecF64x2ToVecI64x2",e[e.TruncSatUVecF64x2ToVecI64x2=_BinaryenTruncSatUVecF64x2ToVecI64x2()]="TruncSatUVecF64x2ToVecI64x2",e[e.ConvertSVecI32x4ToVecF32x4=_BinaryenConvertSVecI32x4ToVecF32x4()]="ConvertSVecI32x4ToVecF32x4",e[e.ConvertUVecI32x4ToVecF32x4=_BinaryenConvertUVecI32x4ToVecF32x4()]="ConvertUVecI32x4ToVecF32x4",e[e.ConvertSVecI64x2ToVecF64x2=_BinaryenConvertSVecI64x2ToVecF64x2()]="ConvertSVecI64x2ToVecF64x2",e[e.ConvertUVecI64x2ToVecF64x2=_BinaryenConvertUVecI64x2ToVecF64x2()]="ConvertUVecI64x2ToVecF64x2"}(r.UnaryOp||(r.UnaryOp={})),function(e){e[e.AddI32=_BinaryenAddInt32()]="AddI32",e[e.SubI32=_BinaryenSubInt32()]="SubI32",e[e.MulI32=_BinaryenMulInt32()]="MulI32",e[e.DivI32=_BinaryenDivSInt32()]="DivI32",e[e.DivU32=_BinaryenDivUInt32()]="DivU32",e[e.RemI32=_BinaryenRemSInt32()]="RemI32",e[e.RemU32=_BinaryenRemUInt32()]="RemU32",e[e.AndI32=_BinaryenAndInt32()]="AndI32",e[e.OrI32=_BinaryenOrInt32()]="OrI32",e[e.XorI32=_BinaryenXorInt32()]="XorI32",e[e.ShlI32=_BinaryenShlInt32()]="ShlI32",e[e.ShrU32=_BinaryenShrUInt32()]="ShrU32",e[e.ShrI32=_BinaryenShrSInt32()]="ShrI32",e[e.RotlI32=_BinaryenRotLInt32()]="RotlI32",e[e.RotrI32=_BinaryenRotRInt32()]="RotrI32",e[e.EqI32=_BinaryenEqInt32()]="EqI32",e[e.NeI32=_BinaryenNeInt32()]="NeI32",e[e.LtI32=_BinaryenLtSInt32()]="LtI32",e[e.LtU32=_BinaryenLtUInt32()]="LtU32",e[e.LeI32=_BinaryenLeSInt32()]="LeI32",e[e.LeU32=_BinaryenLeUInt32()]="LeU32",e[e.GtI32=_BinaryenGtSInt32()]="GtI32",e[e.GtU32=_BinaryenGtUInt32()]="GtU32",e[e.GeI32=_BinaryenGeSInt32()]="GeI32",e[e.GeU32=_BinaryenGeUInt32()]="GeU32",e[e.AddI64=_BinaryenAddInt64()]="AddI64",e[e.SubI64=_BinaryenSubInt64()]="SubI64",e[e.MulI64=_BinaryenMulInt64()]="MulI64",e[e.DivI64=_BinaryenDivSInt64()]="DivI64",e[e.DivU64=_BinaryenDivUInt64()]="DivU64",e[e.RemI64=_BinaryenRemSInt64()]="RemI64",e[e.RemU64=_BinaryenRemUInt64()]="RemU64",e[e.AndI64=_BinaryenAndInt64()]="AndI64",e[e.OrI64=_BinaryenOrInt64()]="OrI64",e[e.XorI64=_BinaryenXorInt64()]="XorI64",e[e.ShlI64=_BinaryenShlInt64()]="ShlI64",e[e.ShrU64=_BinaryenShrUInt64()]="ShrU64",e[e.ShrI64=_BinaryenShrSInt64()]="ShrI64",e[e.RotlI64=_BinaryenRotLInt64()]="RotlI64",e[e.RotrI64=_BinaryenRotRInt64()]="RotrI64",e[e.EqI64=_BinaryenEqInt64()]="EqI64",e[e.NeI64=_BinaryenNeInt64()]="NeI64",e[e.LtI64=_BinaryenLtSInt64()]="LtI64",e[e.LtU64=_BinaryenLtUInt64()]="LtU64",e[e.LeI64=_BinaryenLeSInt64()]="LeI64",e[e.LeU64=_BinaryenLeUInt64()]="LeU64",e[e.GtI64=_BinaryenGtSInt64()]="GtI64",e[e.GtU64=_BinaryenGtUInt64()]="GtU64",e[e.GeI64=_BinaryenGeSInt64()]="GeI64",e[e.GeU64=_BinaryenGeUInt64()]="GeU64",e[e.AddF32=_BinaryenAddFloat32()]="AddF32",e[e.SubF32=_BinaryenSubFloat32()]="SubF32",e[e.MulF32=_BinaryenMulFloat32()]="MulF32",e[e.DivF32=_BinaryenDivFloat32()]="DivF32",e[e.CopysignF32=_BinaryenCopySignFloat32()]="CopysignF32",e[e.MinF32=_BinaryenMinFloat32()]="MinF32",e[e.MaxF32=_BinaryenMaxFloat32()]="MaxF32",e[e.EqF32=_BinaryenEqFloat32()]="EqF32",e[e.NeF32=_BinaryenNeFloat32()]="NeF32",e[e.LtF32=_BinaryenLtFloat32()]="LtF32",e[e.LeF32=_BinaryenLeFloat32()]="LeF32",e[e.GtF32=_BinaryenGtFloat32()]="GtF32",e[e.GeF32=_BinaryenGeFloat32()]="GeF32",e[e.AddF64=_BinaryenAddFloat64()]="AddF64",e[e.SubF64=_BinaryenSubFloat64()]="SubF64",e[e.MulF64=_BinaryenMulFloat64()]="MulF64",e[e.DivF64=_BinaryenDivFloat64()]="DivF64",e[e.CopysignF64=_BinaryenCopySignFloat64()]="CopysignF64",e[e.MinF64=_BinaryenMinFloat64()]="MinF64",e[e.MaxF64=_BinaryenMaxFloat64()]="MaxF64",e[e.EqF64=_BinaryenEqFloat64()]="EqF64",e[e.NeF64=_BinaryenNeFloat64()]="NeF64",e[e.LtF64=_BinaryenLtFloat64()]="LtF64",e[e.LeF64=_BinaryenLeFloat64()]="LeF64",e[e.GtF64=_BinaryenGtFloat64()]="GtF64",e[e.GeF64=_BinaryenGeFloat64()]="GeF64",e[e.EqVecI8x16=_BinaryenEqVecI8x16()]="EqVecI8x16",e[e.NeVecI8x16=_BinaryenNeVecI8x16()]="NeVecI8x16",e[e.LtSVecI8x16=_BinaryenLtSVecI8x16()]="LtSVecI8x16",e[e.LtUVecI8x16=_BinaryenLtUVecI8x16()]="LtUVecI8x16",e[e.LeSVecI8x16=_BinaryenLeSVecI8x16()]="LeSVecI8x16",e[e.LeUVecI8x16=_BinaryenLeUVecI8x16()]="LeUVecI8x16",e[e.GtSVecI8x16=_BinaryenGtSVecI8x16()]="GtSVecI8x16",e[e.GtUVecI8x16=_BinaryenGtUVecI8x16()]="GtUVecI8x16",e[e.GeSVecI8x16=_BinaryenGeSVecI8x16()]="GeSVecI8x16",e[e.GeUVecI8x16=_BinaryenGeUVecI8x16()]="GeUVecI8x16",e[e.EqVecI16x8=_BinaryenEqVecI16x8()]="EqVecI16x8",e[e.NeVecI16x8=_BinaryenNeVecI16x8()]="NeVecI16x8",e[e.LtSVecI16x8=_BinaryenLtSVecI16x8()]="LtSVecI16x8",e[e.LtUVecI16x8=_BinaryenLtUVecI16x8()]="LtUVecI16x8",e[e.LeSVecI16x8=_BinaryenLeSVecI16x8()]="LeSVecI16x8",e[e.LeUVecI16x8=_BinaryenLeUVecI16x8()]="LeUVecI16x8",e[e.GtSVecI16x8=_BinaryenGtSVecI16x8()]="GtSVecI16x8",e[e.GtUVecI16x8=_BinaryenGtUVecI16x8()]="GtUVecI16x8",e[e.GeSVecI16x8=_BinaryenGeSVecI16x8()]="GeSVecI16x8",e[e.GeUVecI16x8=_BinaryenGeUVecI16x8()]="GeUVecI16x8",e[e.EqVecI32x4=_BinaryenEqVecI32x4()]="EqVecI32x4",e[e.NeVecI32x4=_BinaryenNeVecI32x4()]="NeVecI32x4",e[e.LtSVecI32x4=_BinaryenLtSVecI32x4()]="LtSVecI32x4",e[e.LtUVecI32x4=_BinaryenLtUVecI32x4()]="LtUVecI32x4",e[e.LeSVecI32x4=_BinaryenLeSVecI32x4()]="LeSVecI32x4",e[e.LeUVecI32x4=_BinaryenLeUVecI32x4()]="LeUVecI32x4",e[e.GtSVecI32x4=_BinaryenGtSVecI32x4()]="GtSVecI32x4",e[e.GtUVecI32x4=_BinaryenGtUVecI32x4()]="GtUVecI32x4",e[e.GeSVecI32x4=_BinaryenGeSVecI32x4()]="GeSVecI32x4",e[e.GeUVecI32x4=_BinaryenGeUVecI32x4()]="GeUVecI32x4",e[e.EqVecF32x4=_BinaryenEqVecF32x4()]="EqVecF32x4",e[e.NeVecF32x4=_BinaryenNeVecF32x4()]="NeVecF32x4",e[e.LtVecF32x4=_BinaryenLtVecF32x4()]="LtVecF32x4",e[e.LeVecF32x4=_BinaryenLeVecF32x4()]="LeVecF32x4",e[e.GtVecF32x4=_BinaryenGtVecF32x4()]="GtVecF32x4",e[e.GeVecF32x4=_BinaryenGeVecF32x4()]="GeVecF32x4",e[e.EqVecF64x2=_BinaryenEqVecF64x2()]="EqVecF64x2",e[e.NeVecF64x2=_BinaryenNeVecF64x2()]="NeVecF64x2",e[e.LtVecF64x2=_BinaryenLtVecF64x2()]="LtVecF64x2",e[e.LeVecF64x2=_BinaryenLeVecF64x2()]="LeVecF64x2",e[e.GtVecF64x2=_BinaryenGtVecF64x2()]="GtVecF64x2",e[e.GeVecF64x2=_BinaryenGeVecF64x2()]="GeVecF64x2",e[e.AndVec128=_BinaryenAndVec128()]="AndVec128",e[e.OrVec128=_BinaryenOrVec128()]="OrVec128",e[e.XorVec128=_BinaryenXorVec128()]="XorVec128",e[e.AddVecI8x16=_BinaryenAddVecI8x16()]="AddVecI8x16",e[e.AddSatSVecI8x16=_BinaryenAddSatSVecI8x16()]="AddSatSVecI8x16",e[e.AddSatUVecI8x16=_BinaryenAddSatUVecI8x16()]="AddSatUVecI8x16",e[e.SubVecI8x16=_BinaryenSubVecI8x16()]="SubVecI8x16",e[e.SubSatSVecI8x16=_BinaryenSubSatSVecI8x16()]="SubSatSVecI8x16",e[e.SubSatUVecI8x16=_BinaryenSubSatUVecI8x16()]="SubSatUVecI8x16",e[e.MulVecI8x16=_BinaryenMulVecI8x16()]="MulVecI8x16",e[e.AddVecI16x8=_BinaryenAddVecI16x8()]="AddVecI16x8",e[e.AddSatSVecI16x8=_BinaryenAddSatSVecI16x8()]="AddSatSVecI16x8",e[e.AddSatUVecI16x8=_BinaryenAddSatUVecI16x8()]="AddSatUVecI16x8",e[e.SubVecI16x8=_BinaryenSubVecI16x8()]="SubVecI16x8",e[e.SubSatSVecI16x8=_BinaryenSubSatSVecI16x8()]="SubSatSVecI16x8",e[e.SubSatUVecI16x8=_BinaryenSubSatUVecI16x8()]="SubSatUVecI16x8",e[e.MulVecI16x8=_BinaryenMulVecI16x8()]="MulVecI16x8",e[e.AddVecI32x4=_BinaryenAddVecI32x4()]="AddVecI32x4",e[e.SubVecI32x4=_BinaryenSubVecI32x4()]="SubVecI32x4",e[e.MulVecI32x4=_BinaryenMulVecI32x4()]="MulVecI32x4",e[e.AddVecI64x2=_BinaryenAddVecI64x2()]="AddVecI64x2",e[e.SubVecI64x2=_BinaryenSubVecI64x2()]="SubVecI64x2",e[e.AddVecF32x4=_BinaryenAddVecF32x4()]="AddVecF32x4",e[e.SubVecF32x4=_BinaryenSubVecF32x4()]="SubVecF32x4",e[e.MulVecF32x4=_BinaryenMulVecF32x4()]="MulVecF32x4",e[e.DivVecF32x4=_BinaryenDivVecF32x4()]="DivVecF32x4",e[e.MinVecF32x4=_BinaryenMinVecF32x4()]="MinVecF32x4",e[e.MaxVecF32x4=_BinaryenMaxVecF32x4()]="MaxVecF32x4",e[e.AddVecF64x2=_BinaryenAddVecF64x2()]="AddVecF64x2",e[e.SubVecF64x2=_BinaryenSubVecF64x2()]="SubVecF64x2",e[e.MulVecF64x2=_BinaryenMulVecF64x2()]="MulVecF64x2",e[e.DivVecF64x2=_BinaryenDivVecF64x2()]="DivVecF64x2",e[e.MinVecF64x2=_BinaryenMinVecF64x2()]="MinVecF64x2",e[e.MaxVecF64x2=_BinaryenMaxVecF64x2()]="MaxVecF64x2"}(r.BinaryOp||(r.BinaryOp={})),function(e){e[e.MemorySize=_BinaryenMemorySize()]="MemorySize",e[e.MemoryGrow=_BinaryenMemoryGrow()]="MemoryGrow"}(r.HostOp||(r.HostOp={})),function(e){e[e.Add=_BinaryenAtomicRMWAdd()]="Add",e[e.Sub=_BinaryenAtomicRMWSub()]="Sub",e[e.And=_BinaryenAtomicRMWAnd()]="And",e[e.Or=_BinaryenAtomicRMWOr()]="Or",e[e.Xor=_BinaryenAtomicRMWXor()]="Xor",e[e.Xchg=_BinaryenAtomicRMWXchg()]="Xchg"}(r.AtomicRMWOp||(r.AtomicRMWOp={})),function(e){e[e.ExtractLaneSVecI8x16=_BinaryenExtractLaneSVecI8x16()]="ExtractLaneSVecI8x16",e[e.ExtractLaneUVecI8x16=_BinaryenExtractLaneUVecI8x16()]="ExtractLaneUVecI8x16",e[e.ExtractLaneSVecI16x8=_BinaryenExtractLaneSVecI16x8()]="ExtractLaneSVecI16x8",e[e.ExtractLaneUVecI16x8=_BinaryenExtractLaneUVecI16x8()]="ExtractLaneUVecI16x8",e[e.ExtractLaneVecI32x4=_BinaryenExtractLaneVecI32x4()]="ExtractLaneVecI32x4",e[e.ExtractLaneVecI64x2=_BinaryenExtractLaneVecI64x2()]="ExtractLaneVecI64x2",e[e.ExtractLaneVecF32x4=_BinaryenExtractLaneVecF32x4()]="ExtractLaneVecF32x4",e[e.ExtractLaneVecF64x2=_BinaryenExtractLaneVecF64x2()]="ExtractLaneVecF64x2"}(r.SIMDExtractOp||(r.SIMDExtractOp={})),function(e){e[e.ReplaceLaneVecI8x16=_BinaryenReplaceLaneVecI8x16()]="ReplaceLaneVecI8x16",e[e.ReplaceLaneVecI16x8=_BinaryenReplaceLaneVecI16x8()]="ReplaceLaneVecI16x8",e[e.ReplaceLaneVecI32x4=_BinaryenReplaceLaneVecI32x4()]="ReplaceLaneVecI32x4",e[e.ReplaceLaneVecI64x2=_BinaryenReplaceLaneVecI64x2()]="ReplaceLaneVecI64x2",e[e.ReplaceLaneVecF32x4=_BinaryenReplaceLaneVecF32x4()]="ReplaceLaneVecF32x4",e[e.ReplaceLaneVecF64x2=_BinaryenReplaceLaneVecF64x2()]="ReplaceLaneVecF64x2"}(r.SIMDReplaceOp||(r.SIMDReplaceOp={})),function(e){e[e.ShlVecI8x16=_BinaryenShlVecI8x16()]="ShlVecI8x16",e[e.ShrSVecI8x16=_BinaryenShrSVecI8x16()]="ShrSVecI8x16",e[e.ShrUVecI8x16=_BinaryenShrUVecI8x16()]="ShrUVecI8x16",e[e.ShlVecI16x8=_BinaryenShlVecI16x8()]="ShlVecI16x8",e[e.ShrSVecI16x8=_BinaryenShrSVecI16x8()]="ShrSVecI16x8",e[e.ShrUVecI16x8=_BinaryenShrUVecI16x8()]="ShrUVecI16x8",e[e.ShlVecI32x4=_BinaryenShlVecI32x4()]="ShlVecI32x4",e[e.ShrSVecI32x4=_BinaryenShrSVecI32x4()]="ShrSVecI32x4",e[e.ShrUVecI32x4=_BinaryenShrUVecI32x4()]="ShrUVecI32x4",e[e.ShlVecI64x2=_BinaryenShlVecI64x2()]="ShlVecI64x2",e[e.ShrSVecI64x2=_BinaryenShrSVecI64x2()]="ShrSVecI64x2",e[e.ShrUVecI64x2=_BinaryenShrUVecI64x2()]="ShrUVecI64x2"}(r.SIMDShiftOp||(r.SIMDShiftOp={}));var o=function(){function e(){}return e.create=function(r,t){var n=new e;return n.buffer=r,n.offset=t,n},e}();r.MemorySegment=o;var c=function(){function e(){this.hasTemporaryFunction=!1,this.cachedPrecomputeNames=0,this.cachedStrings=new Map}return e.create=function(){var r=new e;return r.ref=_BinaryenModuleCreate(),r.lit=memory.allocate(_BinaryenSizeofLiteral()),r},e.createFrom=function(r){var t=p(r);try{var n=new e;return n.ref=_BinaryenModuleRead(t,r.length),n.lit=memory.allocate(_BinaryenSizeofLiteral()),n}finally{memory.free(changetype(t))}},e.prototype.addFunctionType=function(e,r,t){var n=this.allocStringCached(e),i=_(t);try{return _BinaryenAddFunctionType(this.ref,n,r,i,t?t.length:0)}finally{memory.free(i)}},e.prototype.getFunctionTypeBySignature=function(e,r){var t=_(r);try{return _BinaryenGetFunctionTypeBySignature(this.ref,e,t,r?r.length:0)}finally{memory.free(t)}},e.prototype.removeFunctionType=function(e){var r=this.allocStringCached(e);_BinaryenRemoveFunctionType(this.ref,r)},e.prototype.i32=function(e){var r=this.lit;return _BinaryenLiteralInt32(r,e),_BinaryenConst(this.ref,r)},e.prototype.i64=function(e,r){void 0===r&&(r=0);var t=this.lit;return _BinaryenLiteralInt64(t,e,r),_BinaryenConst(this.ref,t)},e.prototype.f32=function(e){var r=this.lit;return _BinaryenLiteralFloat32(r,e),_BinaryenConst(this.ref,r)},e.prototype.f64=function(e){var r=this.lit;return _BinaryenLiteralFloat64(r,e),_BinaryenConst(this.ref,r)},e.prototype.v128=function(e){assert(16==e.length);for(var r=this.lit,t=0;t<16;++t)store(r+t,e[t]);return _BinaryenLiteralVec128(r,r),_BinaryenConst(this.ref,r)},e.prototype.unary=function(e,r){return _BinaryenUnary(this.ref,e,r)},e.prototype.binary=function(e,r,t){return _BinaryenBinary(this.ref,e,r,t)},e.prototype.host=function(e,r,t){void 0===r&&(r=null),void 0===t&&(t=null);var n=this.allocStringCached(r),i=h(t);try{return _BinaryenHost(this.ref,e,n,i,t?t.length:0)}finally{memory.free(i)}},e.prototype.local_get=function(e,r){return _BinaryenLocalGet(this.ref,e,r)},e.prototype.local_tee=function(e,r){return _BinaryenLocalTee(this.ref,e,r)},e.prototype.global_get=function(e,r){var t=this.allocStringCached(e);return _BinaryenGlobalGet(this.ref,t,r)},e.prototype.load=function(e,r,t,n,i,a){return void 0===i&&(i=0),void 0===a&&(a=e),_BinaryenLoad(this.ref,e,r?1:0,i,a,n,t)},e.prototype.store=function(e,r,t,n,a,s){if(void 0===a&&(a=0),void 0===s&&(s=e),ni.V128)throw new Error("here: "+n);return _BinaryenStore(this.ref,e,a,s,r,t,n)},e.prototype.atomic_load=function(e,r,t,n){return void 0===n&&(n=0),_BinaryenAtomicLoad(this.ref,e,n,t,r)},e.prototype.atomic_store=function(e,r,t,n,i){return void 0===i&&(i=0),_BinaryenAtomicStore(this.ref,e,i,r,t,n)},e.prototype.atomic_rmw=function(e,r,t,n,i,a){return _BinaryenAtomicRMW(this.ref,e,r,t,n,i,a)},e.prototype.atomic_cmpxchg=function(e,r,t,n,i,a){return _BinaryenAtomicCmpxchg(this.ref,e,r,t,n,i,a)},e.prototype.atomic_wait=function(e,r,t,n){return _BinaryenAtomicWait(this.ref,e,r,t,n)},e.prototype.atomic_notify=function(e,r){return _BinaryenAtomicNotify(this.ref,e,r)},e.prototype.local_set=function(e,r){return _BinaryenLocalSet(this.ref,e,r)},e.prototype.global_set=function(e,r){var t=this.allocStringCached(e);return _BinaryenGlobalSet(this.ref,t,r)},e.prototype.block=function(e,r,t){void 0===t&&(t=i.None);var n=this.allocStringCached(e),a=h(r);try{return _BinaryenBlock(this.ref,n,a,r.length,t)}finally{memory.free(a)}},e.prototype.br=function(e,r,t){void 0===r&&(r=0),void 0===t&&(t=0);var n=this.allocStringCached(e);return _BinaryenBreak(this.ref,n,r,t)},e.prototype.drop=function(e){return _BinaryenDrop(this.ref,e)},e.prototype.loop=function(e,r){var t=this.allocStringCached(e);return _BinaryenLoop(this.ref,t,r)},e.prototype.if=function(e,r,t){return void 0===t&&(t=0),_BinaryenIf(this.ref,e,r,t)},e.prototype.nop=function(){return _BinaryenNop(this.ref)},e.prototype.return=function(e){return void 0===e&&(e=0),_BinaryenReturn(this.ref,e)},e.prototype.select=function(e,r,t){return _BinaryenSelect(this.ref,t,e,r)},e.prototype.switch=function(e,r,t,n){void 0===n&&(n=0);for(var i=e.length,a=new Array(i),s=0;s=0;--y)memory.free(l[y])}},e.prototype.setFunctionTable=function(e,r,t){for(var n=t.length,i=new Array(n),a=0;a=0;--i)memory.free(n[i])}},e.prototype.precomputeExpression=function(e){var r=_BinaryenGetOptimizeLevel(),t=_BinaryenGetShrinkLevel(),n=_BinaryenGetDebugInfo();_BinaryenSetOptimizeLevel(4),_BinaryenSetShrinkLevel(0),_BinaryenSetDebugInfo(!1);var i=_BinaryenExpressionGetType(e),a=this.addTemporaryFunction(i,null,e),s=this.cachedPrecomputeNames;return s||(this.cachedPrecomputeNames=s=_([this.allocStringCached("precompute")])),_BinaryenFunctionRunPasses(a,this.ref,s,1),e=_BinaryenFunctionGetBody(a),this.removeTemporaryFunction(),_BinaryenSetOptimizeLevel(r),_BinaryenSetShrinkLevel(t),_BinaryenSetDebugInfo(n),e},e.prototype.validate=function(){return 1==_BinaryenModuleValidate(this.ref)},e.prototype.interpret=function(){_BinaryenModuleInterpret(this.ref)},e.prototype.toBinary=function(e){var r=this.lit;assert(_BinaryenSizeofLiteral()>=12);var t=d(e),n=0,i=0;try{_BinaryenModuleAllocateAndWrite(r,this.ref,t),n=y(r);var a=y(r+4);i=y(r+8);var s=new f;return s.output=function(e,r){for(var t=new Uint8Array(r),n=0;n>8&255),store(t+2,a>>16&255),store(t+3,a>>>24),t+=4}return r}function h(e){return _(e)}function d(e){if(null==e)return 0;for(var r=memory.allocate(function(e){for(var r=0,t=0,n=e.length;t=55296&&i<=57343&&t+1=55296&&a<=57343&&n+1>>6),store(t++,128|63&a)):a<=65535?(store(t++,224|a>>>12),store(t++,128|a>>>6&63),store(t++,128|63&a)):a<=2097151?(store(t++,240|a>>>18),store(t++,128|a>>>12&63),store(t++,128|a>>>6&63),store(t++,128|63&a)):a<=67108863?(store(t++,248|a>>>24),store(t++,128|a>>>18&63),store(t++,128|a>>>12&63),store(t++,128|a>>>6&63),store(t++,128|63&a)):(store(t++,252|a>>>30),store(t++,128|a>>>24&63),store(t++,128|a>>>18&63),store(t++,128|a>>>12&63),store(t++,128|a>>>6&63),store(t++,128|63&a))}return store(t,0),r}function y(e){return load(e)|load(e+1)<<8|load(e+2)<<16|load(e+3)<<24}function m(e){if(!e)return null;for(var r,t,n,i,a,s=new Array;r=load(e++);)128&r?(t=63&load(e++),192!=(224&r)?(n=63&load(e++),224==(240&r)?r=(15&r)<<12|t<<6|n:(i=63&load(e++),240==(248&r)?r=(7&r)<<18|t<<12|n<<6|i:(a=63&load(e++),r=248==(252&r)?(3&r)<<24|t<<18|n<<12|i<<6|a:(1&r)<<30|t<<24|n<<18|i<<12|a<<6|63&load(e++))),s.push(r)):s.push((31&r)<<6|t)):s.push(r);return String.fromCodePoints(s)}r.Relooper=u,r.readString=m;var f=function(){return function(){}}();r.BinaryModule=f,r.needsExplicitUnreachable=function e(r){if(_BinaryenExpressionGetType(r)!=i.Unreachable)return!1;switch(_BinaryenExpressionGetId(r)){case a.Unreachable:case a.Return:return!1;case a.Break:return 0!=_BinaryenBreakGetCondition(r);case a.Block:if(!_BinaryenBlockGetName(r)){var t=_BinaryenBlockGetNumChildren(r);return t>0&&e(_BinaryenBlockGetChild(r,t-1))}}return!0},r.traverse=function(e,r,t){switch(l(e)){case a.Block:for(var n=0,i=_BinaryenBlockGetNumChildren(e);n=0?c.substring(l+1):c,i.statements=new Array,i.range=new s.Range(i,0,t.length),i.text=t,i}return i(r,e),Object.defineProperty(r.prototype,"isEntry",{get:function(){return this.sourceKind==Z.ENTRY},enumerable:!0,configurable:!0}),Object.defineProperty(r.prototype,"isLibrary",{get:function(){return this.sourceKind==Z.LIBRARY},enumerable:!0,configurable:!0}),r}(l);r.Source=$;var ee=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.decorators=null,r.flags=a.CommonFlags.NONE,r}return i(r,e),r.prototype.is=function(e){return(this.flags&e)==e},r.prototype.isAny=function(e){return 0!=(this.flags&e)},r.prototype.set=function(e){this.flags|=e},r}(J);r.DeclarationStatement=ee;var re=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.INDEXSIGNATUREDECLARATION,r}return i(r,e),r}(ee);r.IndexSignatureDeclaration=re;var te=function(e){function r(){return null!==e&&e.apply(this,arguments)||this}return i(r,e),r}(ee);r.VariableLikeDeclarationStatement=te;var ne=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.BLOCK,r}return i(r,e),r}(J);r.BlockStatement=ne;var ie=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.BREAK,r}return i(r,e),r}(J);r.BreakStatement=ie;var ae=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.CLASSDECLARATION,r}return i(r,e),Object.defineProperty(r.prototype,"isGeneric",{get:function(){var e=this.typeParameters;return null!=e&&e.length>0},enumerable:!0,configurable:!0}),r}(ee);r.ClassDeclaration=ae;var se=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.CONTINUE,r}return i(r,e),r}(J);r.ContinueStatement=se;var oe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.DO,r}return i(r,e),r}(J);r.DoStatement=oe;var ce=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EMPTY,r}return i(r,e),r}(J);r.EmptyStatement=ce;var le=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.ENUMDECLARATION,r}return i(r,e),r}(ee);r.EnumDeclaration=le;var ue=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.ENUMVALUEDECLARATION,r}return i(r,e),r}(te);r.EnumValueDeclaration=ue;var pe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EXPORTIMPORT,r}return i(r,e),r}(l);r.ExportImportStatement=pe;var _e=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EXPORTMEMBER,r}return i(r,e),r}(l);r.ExportMember=_e;var he=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EXPORT,r}return i(r,e),r}(J);r.ExportStatement=he;var de=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EXPORTDEFAULT,r}return i(r,e),r}(J);r.ExportDefaultStatement=de;var ye=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.EXPRESSION,r}return i(r,e),r}(J);r.ExpressionStatement=ye;var me=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.FIELDDECLARATION,r.parameterIndex=-1,r}return i(r,e),r}(te);r.FieldDeclaration=me;var fe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.FOR,r}return i(r,e),r}(J);r.ForStatement=fe,function(e){e[e.NONE=0]="NONE",e[e.ARROW_PARENTHESIZED=1]="ARROW_PARENTHESIZED",e[e.ARROW_SINGLE=2]="ARROW_SINGLE"}(r.ArrowKind||(r.ArrowKind={}));var Te=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.FUNCTIONDECLARATION,r}return i(r,e),Object.defineProperty(r.prototype,"isGeneric",{get:function(){var e=this.typeParameters;return null!=e&&e.length>0},enumerable:!0,configurable:!0}),r.prototype.clone=function(){return l.createFunctionDeclaration(this.name,this.typeParameters,this.signature,this.body,this.decorators,this.flags,this.arrowKind,this.range)},r}(ee);r.FunctionDeclaration=Te;var ge=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.IF,r}return i(r,e),r}(J);r.IfStatement=ge;var Ee=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.IMPORTDECLARATION,r}return i(r,e),r}(ee);r.ImportDeclaration=Ee;var ve=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.IMPORT,r}return i(r,e),r}(J);r.ImportStatement=ve;var be=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.INTERFACEDECLARATION,r}return i(r,e),r}(ae);r.InterfaceDeclaration=be;var Ie=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.METHODDECLARATION,r}return i(r,e),r}(Te);r.MethodDeclaration=Ie;var xe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.NAMESPACEDECLARATION,r}return i(r,e),r}(ee);r.NamespaceDeclaration=xe;var Ae=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.RETURN,r}return i(r,e),r}(J);r.ReturnStatement=Ae;var Ne=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.SWITCHCASE,r}return i(r,e),r}(l);r.SwitchCase=Ne;var Se=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.SWITCH,r}return i(r,e),r}(J);r.SwitchStatement=Se;var Oe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.THROW,r}return i(r,e),r}(J);r.ThrowStatement=Oe;var Ce=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.TRY,r}return i(r,e),r}(J);r.TryStatement=Ce;var ke=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.TYPEDECLARATION,r}return i(r,e),r}(ee);r.TypeDeclaration=ke;var Le=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.VARIABLEDECLARATION,r}return i(r,e),r}(te);r.VariableDeclaration=Le;var Re=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.VARIABLE,r}return i(r,e),r}(J);r.VariableStatement=Re;var Fe=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.VOID,r}return i(r,e),r}(J);r.VoidStatement=Fe;var Be=function(e){function r(){var r=null!==e&&e.apply(this,arguments)||this;return r.kind=o.WHILE,r}return i(r,e),r}(J);function De(e){return e.endsWith(".ts")&&(e=e.substring(0,e.length-3)),e}r.WhileStatement=Be,r.findDecorator=function(e,r){if(r)for(var t=0,n=r.length;t>>e.size-r},e.prototype.is=function(e){return(this.flags&e)==e},e.prototype.isAny=function(e){return 0!=(this.flags&e)},e.prototype.asClass=function(r){assert(9==this.kind&&!this.classReference);var t=new e(this.kind,-129&this.flags|256,this.size);return t.classReference=r,t},e.prototype.asFunction=function(r){assert(7==this.kind&&!this.signatureReference);var t=new e(this.kind,-129&this.flags|256,this.size);return t.signatureReference=r,t},e.prototype.asNullable=function(){return assert(this.is(256)),this.cachedNullableType||(assert(!this.is(512)),this.cachedNullableType=new e(this.kind,512|this.flags,this.size),this.cachedNullableType.nonNullableType=this,this.cachedNullableType.classReference=this.classReference,this.cachedNullableType.signatureReference=this.signatureReference),this.cachedNullableType},e.prototype.isAssignableTo=function(r,t){var n,i,a,s;if(void 0===t&&(t=!1),this.is(256)){if(r.is(256)&&(!this.is(512)||r.is(512)))if(n=this.classReference){if(i=r.classReference)return n.isAssignableTo(i)}else if((a=this.signatureReference)&&(s=r.signatureReference))return a.isAssignableTo(s)}else if(!r.is(256))if(this.is(4))if(r.is(4)){if(!t||this==e.bool||this.is(1)==r.is(1))return this.size<=r.size}else{if(11==r.kind)return this.size<=23;if(12==r.kind)return this.size<=52}else if(this.is(8)){if(r.is(8))return this.size<=r.size}else if(this.is(1024)&&r.is(1024))return this.size==r.size;return!1},e.prototype.isStrictlyAssignableTo=function(e,r){return void 0===r&&(r=!1),this.is(256)?this.isAssignableTo(e):!e.is(256)&&(this.is(4)?e.is(4)&&e.size==this.size&&(!r||this.is(1)==e.is(1)):this.kind==e.kind)},e.commonDenominator=function(e,r,t){return r.isAssignableTo(e,t)?e:e.isAssignableTo(r,t)?r:null},e.prototype.toString=function(){if(this.is(256)){var e=this.classReference;if(e)return this.is(512)?e.internalName+" | null":e.internalName;var r=this.signatureReference;if(r)return this.is(512)?"("+r.toString()+") | null":r.toString();assert(!1)}switch(this.kind){case 0:return"i8";case 1:return"i16";case 2:return"i32";case 3:return"i64";case 4:return"isize";case 5:return"u8";case 6:return"u16";case 7:return"u32";case 8:return"u64";case 9:return"usize";case 10:return"bool";case 11:return"f32";case 12:return"f64";case 13:return"v128";default:assert(!1);case 14:return"void"}},e.prototype.toNativeType=function(){switch(this.kind){default:return i.NativeType.I32;case 3:case 8:return i.NativeType.I64;case 4:case 9:return 64==this.size?i.NativeType.I64:i.NativeType.I32;case 11:return i.NativeType.F32;case 12:return i.NativeType.F64;case 13:return i.NativeType.V128;case 14:return i.NativeType.None}},e.prototype.toNativeZero=function(e){switch(this.kind){case 14:assert(!1);default:return e.i32(0);case 4:case 9:if(64!=this.size)return e.i32(0);case 3:case 8:return e.i64(0);case 11:return e.f32(0);case 12:return e.f64(0);case 13:return e.v128(a)}},e.prototype.toNativeOne=function(e){switch(this.kind){case 13:case 14:assert(!1);default:return e.i32(1);case 4:case 9:if(64!=this.size)return e.i32(1);case 3:case 8:return e.i64(1);case 11:return e.f32(1);case 12:return e.f64(1)}},e.prototype.toNativeNegOne=function(e){switch(this.kind){case 13:case 14:assert(!1);default:return e.i32(-1);case 4:case 9:if(64!=this.size)return e.i32(-1);case 3:case 8:return e.i64(-1,-1);case 11:return e.f32(-1);case 12:return e.f64(-1)}},e.prototype.toSignatureString=function(){switch(this.kind){case 0:case 5:case 1:case 6:case 2:case 7:case 10:return"i";case 3:case 8:return"j";case 4:case 9:return 64==this.size?"j":"i";case 11:return"f";case 12:return"d";case 13:return"V";case 14:return"v";default:assert(!1)}return"i"},e.i8=new e(0,165,8),e.i16=new e(1,165,16),e.i32=new e(2,133,32),e.i64=new e(3,197,64),e.isize32=new e(4,149,32),e.isize64=new e(4,213,64),e.u8=new e(5,166,8),e.u16=new e(6,166,16),e.u32=new e(7,134,32),e.u64=new e(8,198,64),e.usize32=new e(9,150,32),e.usize64=new e(9,214,64),e.bool=new e(10,166,1),e.f32=new e(11,137,32),e.f64=new e(12,201,64),e.v128=new e(13,1152,128),e.void=new e(14,0,0),e.auto=new e(e.i32.kind,e.i32.flags,e.i32.size),e}();r.Type=s,r.typesToNativeTypes=function(e){for(var r=e.length,t=new Array(r),n=0;ne?r[e]:l(e)},e.prototype.isAssignableTo=function(e){var r=this.thisType,t=e.thisType;if(r){if(!t||!r.isAssignableTo(t))return!1}else if(t)return!1;if(this.hasRest!=e.hasRest)return!1;var n=this.parameterTypes,i=e.parameterTypes,a=n.length;if(a!=i.length)return!1;for(var s=0;s=o&&u!=c?e.push("?: "):e.push(": "),e.push(n[u].toString());return e.push(") => "),e.push(this.returnType.toString()),e.join("")},e}();r.Signature=o;var c=null;function l(e){c||(c=[]);for(var r=c.length;r<=e;++r)c.push("arg$"+r.toString(10));return c[e-1]}r.getDefaultParameterName=l},function(e,r,t){"use strict";var n,i=this&&this.__extends||(n=function(e,r){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,r){e.__proto__=r}||function(e,r){for(var t in r)r.hasOwnProperty(t)&&(e[t]=r[t])})(e,r)},function(e,r){function t(){this.constructor=e}n(e,r),e.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)});Object.defineProperty(r,"__esModule",{value:!0});var a,s,o=t(2),c=t(5),l=t(1);function u(e){switch(assert(e.length),e.charCodeAt(0)){case 97:switch(e){case"abstract":return a.ABSTRACT;case"as":return a.AS;case"async":return a.ASYNC;case"await":return a.AWAIT}break;case 98:switch(e){case"break":return a.BREAK}break;case 99:switch(e){case"case":return a.CASE;case"catch":return a.CATCH;case"class":return a.CLASS;case"continue":return a.CONTINUE;case"const":return a.CONST;case"constructor":return a.CONSTRUCTOR}break;case 100:switch(e){case"debugger":return a.DEBUGGER;case"declare":return a.DECLARE;case"default":return a.DEFAULT;case"delete":return a.DELETE;case"do":return a.DO}break;case 101:switch(e){case"else":return a.ELSE;case"enum":return a.ENUM;case"export":return a.EXPORT;case"extends":return a.EXTENDS}break;case 102:switch(e){case"false":return a.FALSE;case"finally":return a.FINALLY;case"for":return a.FOR;case"from":return a.FROM;case"function":return a.FUNCTION}break;case 103:switch(e){case"get":return a.GET}break;case 105:switch(e){case"if":return a.IF;case"implements":return a.IMPLEMENTS;case"import":return a.IMPORT;case"in":return a.IN;case"instanceof":return a.INSTANCEOF;case"interface":return a.INTERFACE;case"is":return a.IS}break;case 107:switch(e){case"keyof":return a.KEYOF}break;case 108:switch(e){case"let":return a.LET}break;case 109:switch(e){case"module":return a.MODULE}break;case 110:switch(e){case"namespace":return a.NAMESPACE;case"new":return a.NEW;case"null":return a.NULL}break;case 111:switch(e){case"of":return a.OF}break;case 112:switch(e){case"package":return a.PACKAGE;case"private":return a.PRIVATE;case"protected":return a.PROTECTED;case"public":return a.PUBLIC}break;case 114:switch(e){case"readonly":return a.READONLY;case"return":return a.RETURN}break;case 115:switch(e){case"set":return a.SET;case"static":return a.STATIC;case"super":return a.SUPER;case"switch":return a.SWITCH}break;case 116:switch(e){case"this":return a.THIS;case"throw":return a.THROW;case"true":return a.TRUE;case"try":return a.TRY;case"type":return a.TYPE;case"typeof":return a.TYPEOF}break;case 118:switch(e){case"var":return a.VAR;case"void":return a.VOID}break;case 119:switch(e){case"while":return a.WHILE;case"with":return a.WITH}break;case 121:switch(e){case"yield":return a.YIELD}}return a.INVALID}function p(e){switch(e){case a.ABSTRACT:case a.AS:case a.CONSTRUCTOR:case a.DECLARE:case a.DELETE:case a.FROM:case a.FOR:case a.GET:case a.INSTANCEOF:case a.IS:case a.KEYOF:case a.MODULE:case a.NAMESPACE:case a.NULL:case a.READONLY:case a.SET:case a.TYPE:case a.VOID:return!0;default:return!1}}!function(e){e[e.ABSTRACT=0]="ABSTRACT",e[e.AS=1]="AS",e[e.ASYNC=2]="ASYNC",e[e.AWAIT=3]="AWAIT",e[e.BREAK=4]="BREAK",e[e.CASE=5]="CASE",e[e.CATCH=6]="CATCH",e[e.CLASS=7]="CLASS",e[e.CONST=8]="CONST",e[e.CONTINUE=9]="CONTINUE",e[e.CONSTRUCTOR=10]="CONSTRUCTOR",e[e.DEBUGGER=11]="DEBUGGER",e[e.DECLARE=12]="DECLARE",e[e.DEFAULT=13]="DEFAULT",e[e.DELETE=14]="DELETE",e[e.DO=15]="DO",e[e.ELSE=16]="ELSE",e[e.ENUM=17]="ENUM",e[e.EXPORT=18]="EXPORT",e[e.EXTENDS=19]="EXTENDS",e[e.FALSE=20]="FALSE",e[e.FINALLY=21]="FINALLY",e[e.FOR=22]="FOR",e[e.FROM=23]="FROM",e[e.FUNCTION=24]="FUNCTION",e[e.GET=25]="GET",e[e.IF=26]="IF",e[e.IMPLEMENTS=27]="IMPLEMENTS",e[e.IMPORT=28]="IMPORT",e[e.IN=29]="IN",e[e.INSTANCEOF=30]="INSTANCEOF",e[e.INTERFACE=31]="INTERFACE",e[e.IS=32]="IS",e[e.KEYOF=33]="KEYOF",e[e.LET=34]="LET",e[e.MODULE=35]="MODULE",e[e.NAMESPACE=36]="NAMESPACE",e[e.NEW=37]="NEW",e[e.NULL=38]="NULL",e[e.OF=39]="OF",e[e.PACKAGE=40]="PACKAGE",e[e.PRIVATE=41]="PRIVATE",e[e.PROTECTED=42]="PROTECTED",e[e.PUBLIC=43]="PUBLIC",e[e.READONLY=44]="READONLY",e[e.RETURN=45]="RETURN",e[e.SET=46]="SET",e[e.STATIC=47]="STATIC",e[e.SUPER=48]="SUPER",e[e.SWITCH=49]="SWITCH",e[e.THIS=50]="THIS",e[e.THROW=51]="THROW",e[e.TRUE=52]="TRUE",e[e.TRY=53]="TRY",e[e.TYPE=54]="TYPE",e[e.TYPEOF=55]="TYPEOF",e[e.VAR=56]="VAR",e[e.VOID=57]="VOID",e[e.WHILE=58]="WHILE",e[e.WITH=59]="WITH",e[e.YIELD=60]="YIELD",e[e.OPENBRACE=61]="OPENBRACE",e[e.CLOSEBRACE=62]="CLOSEBRACE",e[e.OPENPAREN=63]="OPENPAREN",e[e.CLOSEPAREN=64]="CLOSEPAREN",e[e.OPENBRACKET=65]="OPENBRACKET",e[e.CLOSEBRACKET=66]="CLOSEBRACKET",e[e.DOT=67]="DOT",e[e.DOT_DOT_DOT=68]="DOT_DOT_DOT",e[e.SEMICOLON=69]="SEMICOLON",e[e.COMMA=70]="COMMA",e[e.LESSTHAN=71]="LESSTHAN",e[e.GREATERTHAN=72]="GREATERTHAN",e[e.LESSTHAN_EQUALS=73]="LESSTHAN_EQUALS",e[e.GREATERTHAN_EQUALS=74]="GREATERTHAN_EQUALS",e[e.EQUALS_EQUALS=75]="EQUALS_EQUALS",e[e.EXCLAMATION_EQUALS=76]="EXCLAMATION_EQUALS",e[e.EQUALS_EQUALS_EQUALS=77]="EQUALS_EQUALS_EQUALS",e[e.EXCLAMATION_EQUALS_EQUALS=78]="EXCLAMATION_EQUALS_EQUALS",e[e.EQUALS_GREATERTHAN=79]="EQUALS_GREATERTHAN",e[e.PLUS=80]="PLUS",e[e.MINUS=81]="MINUS",e[e.ASTERISK_ASTERISK=82]="ASTERISK_ASTERISK",e[e.ASTERISK=83]="ASTERISK",e[e.SLASH=84]="SLASH",e[e.PERCENT=85]="PERCENT",e[e.PLUS_PLUS=86]="PLUS_PLUS",e[e.MINUS_MINUS=87]="MINUS_MINUS",e[e.LESSTHAN_LESSTHAN=88]="LESSTHAN_LESSTHAN",e[e.GREATERTHAN_GREATERTHAN=89]="GREATERTHAN_GREATERTHAN",e[e.GREATERTHAN_GREATERTHAN_GREATERTHAN=90]="GREATERTHAN_GREATERTHAN_GREATERTHAN",e[e.AMPERSAND=91]="AMPERSAND",e[e.BAR=92]="BAR",e[e.CARET=93]="CARET",e[e.EXCLAMATION=94]="EXCLAMATION",e[e.TILDE=95]="TILDE",e[e.AMPERSAND_AMPERSAND=96]="AMPERSAND_AMPERSAND",e[e.BAR_BAR=97]="BAR_BAR",e[e.QUESTION=98]="QUESTION",e[e.COLON=99]="COLON",e[e.EQUALS=100]="EQUALS",e[e.PLUS_EQUALS=101]="PLUS_EQUALS",e[e.MINUS_EQUALS=102]="MINUS_EQUALS",e[e.ASTERISK_EQUALS=103]="ASTERISK_EQUALS",e[e.ASTERISK_ASTERISK_EQUALS=104]="ASTERISK_ASTERISK_EQUALS",e[e.SLASH_EQUALS=105]="SLASH_EQUALS",e[e.PERCENT_EQUALS=106]="PERCENT_EQUALS",e[e.LESSTHAN_LESSTHAN_EQUALS=107]="LESSTHAN_LESSTHAN_EQUALS",e[e.GREATERTHAN_GREATERTHAN_EQUALS=108]="GREATERTHAN_GREATERTHAN_EQUALS",e[e.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS=109]="GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS",e[e.AMPERSAND_EQUALS=110]="AMPERSAND_EQUALS",e[e.BAR_EQUALS=111]="BAR_EQUALS",e[e.CARET_EQUALS=112]="CARET_EQUALS",e[e.AT=113]="AT",e[e.IDENTIFIER=114]="IDENTIFIER",e[e.STRINGLITERAL=115]="STRINGLITERAL",e[e.INTEGERLITERAL=116]="INTEGERLITERAL",e[e.FLOATLITERAL=117]="FLOATLITERAL",e[e.INVALID=118]="INVALID",e[e.ENDOFFILE=119]="ENDOFFILE"}(a=r.Token||(r.Token={})),function(e){e[e.DEFAULT=0]="DEFAULT",e[e.PREFER=1]="PREFER",e[e.ALWAYS=2]="ALWAYS"}(s=r.IdentifierHandling||(r.IdentifierHandling={})),r.tokenFromKeyword=u,r.tokenIsAlsoIdentifier=p,r.isIllegalVariableIdentifier=function(e){switch(assert(e.length),e.charCodeAt(0)){case 100:return"delete"==e;case 102:return"for"==e;case 105:return"instanceof"==e;case 110:return"null"==e;case 118:return"void"==e}return!1},r.operatorTokenToString=function(e){switch(e){case a.DELETE:return"delete";case a.IN:return"in";case a.INSTANCEOF:return"instanceof";case a.NEW:return"new";case a.TYPEOF:return"typeof";case a.VOID:return"void";case a.YIELD:return"yield";case a.DOT_DOT_DOT:return"...";case a.COMMA:return",";case a.LESSTHAN:return"<";case a.GREATERTHAN:return">";case a.LESSTHAN_EQUALS:return"<=";case a.GREATERTHAN_EQUALS:return">=";case a.EQUALS_EQUALS:return"==";case a.EXCLAMATION_EQUALS:return"!=";case a.EQUALS_EQUALS_EQUALS:return"===";case a.EXCLAMATION_EQUALS_EQUALS:return"!==";case a.PLUS:return"+";case a.MINUS:return"-";case a.ASTERISK_ASTERISK:return"**";case a.ASTERISK:return"*";case a.SLASH:return"/";case a.PERCENT:return"%";case a.PLUS_PLUS:return"++";case a.MINUS_MINUS:return"--";case a.LESSTHAN_LESSTHAN:return"<<";case a.GREATERTHAN_GREATERTHAN:return">>";case a.GREATERTHAN_GREATERTHAN_GREATERTHAN:return">>>";case a.AMPERSAND:return"&";case a.BAR:return"|";case a.CARET:return"^";case a.EXCLAMATION:return"!";case a.TILDE:return"~";case a.AMPERSAND_AMPERSAND:return"&&";case a.BAR_BAR:return"||";case a.EQUALS:return"=";case a.PLUS_EQUALS:return"+=";case a.MINUS_EQUALS:return"-=";case a.ASTERISK_EQUALS:return"*=";case a.ASTERISK_ASTERISK_EQUALS:return"**=";case a.SLASH_EQUALS:return"/=";case a.PERCENT_EQUALS:return"%=";case a.LESSTHAN_LESSTHAN_EQUALS:return"<<=";case a.GREATERTHAN_GREATERTHAN_EQUALS:return">>=";case a.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:return">>>=";case a.AMPERSAND_EQUALS:return"&=";case a.BAR_EQUALS:return"|=";case a.CARET_EQUALS:return"^=";default:return assert(!1),""}};var _=function(){function e(e,r,t){this.debugInfoRef=0,this.source=e,this.start=r,this.end=t}return e.join=function(r,t){if(r.source!=t.source)throw new Error("source mismatch");return new e(r.source,r.startt.end?r.end:t.end)},Object.defineProperty(e.prototype,"atStart",{get:function(){return new e(this.source,this.start,this.start)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"atEnd",{get:function(){return new e(this.source,this.end,this.end)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"line",{get:function(){for(var e=this.source.text,r=1,t=this.start;t>=0;--t)10==e.charCodeAt(t)&&r++;return r},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"column",{get:function(){for(var e=this.source.text,r=0,t=this.start-1;t>=0&&10!=e.charCodeAt(t);--t)++r;return r},enumerable:!0,configurable:!0}),e.prototype.toString=function(){return this.source.text.substring(this.start,this.end)},e}();r.Range=_;var h=function(e){function r(r,t){void 0===t&&(t=null);var n=e.call(this,t)||this;n.end=0,n.pos=0,n.token=-1,n.tokenPos=0,n.nextToken=-1,n.nextTokenPos=0,n.nextTokenOnNewLine=!1,n.onComment=null,n.source=r,n.pos=0,n.end=r.text.length,n.diagnostics=t||new Array;var i=n.end,a=r.text;if(n.pos1&&this.pos2&&this.pos1&&this.pos1&&this.pos1&&this.pos2&&this.pos1&&this.pos1&&this.pos1&&this.pos2&&this.pos+11&&this.pos1&&this.pos2&&this.pos1&&this.pos2&&this.pos1&&this.pos2&&this.pos3&&this.pos1&&this.pos1&&this.pos=n){i+=e.substring(t,this.pos),this.error(o.DiagnosticCode.Unterminated_string_literal,this.range(t-1,n));break}var a=e.charCodeAt(this.pos);if(a==r){i+=e.substring(t,this.pos++);break}if(92!=a){if(l.isLineBreak(a)){i+=e.substring(t,this.pos),this.error(o.DiagnosticCode.Unterminated_string_literal,this.range(t-1,this.pos));break}++this.pos}else i+=e.substring(t,this.pos),i+=this.readEscapeSequence(),t=this.pos}return i},r.prototype.readEscapeSequence=function(){var e=this.end;if(++this.pos>=e)return this.error(o.DiagnosticCode.Unexpected_end_of_text,this.range(e)),"";var r=this.source.text,t=r.charCodeAt(this.pos++);switch(t){case 48:return"\0";case 98:return"\b";case 116:return"\t";case 110:return"\n";case 118:return"\v";case 102:return"\f";case 114:return"\r";case 39:return"'";case 34:return'"';case 117:return this.pos=t){this.error(o.DiagnosticCode.Unterminated_regular_expression_literal,this.range(r,t));break}if(92!=e.charCodeAt(this.pos)){var i=e.charCodeAt(this.pos);if(!n&&47==i)break;if(l.isLineBreak(i)){this.error(o.DiagnosticCode.Unterminated_regular_expression_literal,this.range(r,this.pos));break}++this.pos,n=!1}else++this.pos,n=!0}return e.substring(r,this.pos)},r.prototype.readRegexpFlags=function(){for(var e=this.source.text,r=this.pos,t=this.end,n=0;this.pos57)&&95!=n)break;t++}return!0},r.prototype.readInteger=function(){var e=this.source.text;if(this.pos+2=48&&c<=57)t=i64_add(i64_shl(t,n),i64_new(c-48));else if(c>=65&&c<=70)t=i64_add(i64_shl(t,n),i64_new(10+c-65));else if(c>=97&&c<=102)t=i64_add(i64_shl(t,n),i64_new(10+c-97));else{if(95!=c)break;i==s&&this.error(i==r?o.DiagnosticCode.Numeric_separators_are_not_allowed_here:o.DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,this.range(s)),i=s+1}this.pos=s+1}return this.pos==r?this.error(o.DiagnosticCode.Hexadecimal_digit_expected,this.range(r)):i==this.pos&&this.error(o.DiagnosticCode.Numeric_separators_are_not_allowed_here,this.range(i-1)),t},r.prototype.readDecimalInteger=function(){for(var e=this.source.text,r=this.pos,t=this.end,n=i64_new(0),i=i64_new(10),a=r;this.pos=48&&c<=57)n=i64_add(i64_mul(n,i),i64_new(c-48));else{if(95!=c)break;a==s&&this.error(a==r?o.DiagnosticCode.Numeric_separators_are_not_allowed_here:o.DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,this.range(s)),a=s+1}this.pos=s+1}return this.pos==r?this.error(o.DiagnosticCode.Digit_expected,this.range(r)):a==this.pos&&this.error(o.DiagnosticCode.Numeric_separators_are_not_allowed_here,this.range(a-1)),n},r.prototype.readOctalInteger=function(){for(var e=this.source.text,r=this.pos,t=i64_new(0),n=i64_new(3),i=r,a=this.end;this.pos=48&&c<=55)t=i64_add(i64_shl(t,n),i64_new(c-48));else{if(95!=c)break;i==s&&this.error(i==r?o.DiagnosticCode.Numeric_separators_are_not_allowed_here:o.DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,this.range(s)),i=s+1}++this.pos}return this.pos==r?this.error(o.DiagnosticCode.Octal_digit_expected,this.range(r)):i==this.pos&&this.error(o.DiagnosticCode.Numeric_separators_are_not_allowed_here,this.range(i-1)),t},r.prototype.readBinaryInteger=function(){for(var e=this.source.text,r=this.pos,t=i64_new(0),n=i64_new(1),i=r,a=this.end;this.pos=48&&i<=57)r=(r<<4)+i-48;else if(i>=65&&i<=70)r=(r<<4)+i+-55;else{if(!(i>=97&&i<=102))return this.error(o.DiagnosticCode.Hexadecimal_digit_expected,this.range(this.pos-1,this.pos)),"";r=(r<<4)+i+-87}if(0==--e)break}return e?(this.error(o.DiagnosticCode.Unexpected_end_of_text,this.range(this.pos)),""):String.fromCharCode(r)},r.prototype.readExtendedUnicodeEscape=function(){var e=this.pos,r=this.readHexInteger(),t=i64_low(r),n=!1;assert(!i64_high(r)),t>1114111&&(this.error(o.DiagnosticCode.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive,this.range(e,this.pos)),n=!0);var i=this.end,a=this.source.text;return this.pos>=i?(this.error(o.DiagnosticCode.Unexpected_end_of_text,this.range(e,i)),n=!0):125==a.charCodeAt(this.pos)?++this.pos:(this.error(o.DiagnosticCode.Unterminated_Unicode_escape_sequence,this.range(e,this.pos)),n=!0),n?"":t<65536?String.fromCharCode(t):String.fromCharCode(55296+(t-65536>>>10),56320+(t-65536&1023))},r.prototype.finish=function(){},r}(o.DiagnosticEmitter);r.Tokenizer=h;var d=function(){return function(){}}();r.State=d;var y=null},function(e,r){var t;t=function(){return this}();try{t=t||new Function("return this")()}catch(e){"object"==typeof window&&(t=window)}e.exports=t},function(e,r,t){"use strict";var n,i=this&&this.__extends||(n=function(e,r){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,r){e.__proto__=r}||function(e,r){for(var t in r)r.hasOwnProperty(t)&&(e[t]=r[t])})(e,r)},function(e,r){function t(){this.constructor=e}n(e,r),e.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)}),a=this&&this.__values||function(e){var r="function"==typeof Symbol&&e[Symbol.iterator],t=0;return r?r.call(e):{next:function(){return e&&t>=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},s=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0});var o,c=t(2),l=t(3),u=t(5),p=t(6),_=t(0),h=t(1),d=t(7),y=t(13);!function(e){e[e.REPORT=0]="REPORT",e[e.SWALLOW=1]="SWALLOW"}(o=r.ReportMode||(r.ReportMode={}));var m=function(e){function r(r){var t=e.call(this,r.diagnostics)||this;return t.currentThisExpression=null,t.currentElementExpression=null,t.program=r,t}return i(r,e),r.prototype.resolveType=function(e,r,t,n){if(void 0===t&&(t=null),void 0===n&&(n=o.REPORT),e.kind==u.NodeKind.FUNCTIONTYPE){var i=e.explicitThisType,a=null;if(i&&!(a=this.resolveType(i,r,t,n)))return null;for(var s=e.parameters,d=s.length,y=new Array(d),m=new Array(d),f=0,T=!1,g=0;gl)return this.error(c.DiagnosticCode.Expected_0_type_arguments_but_got_1,d?u.Range.join(r[0].range,r[d-1].range):assert(i).range,(d0)return this.resolveExpression(e.arguments[0],r,t,n);var s=this.resolveFunctionInclTypeArguments(a,e.typeArguments,r.actualFunction,h.makeMap(r.contextualTypeArguments),e,n);if(!s)return null;var u=s.signature.returnType,_=u.classReference;if(_)return _;var d=u.signatureReference;if(d)return d.asFunctionTarget(this.program);var m=this.program.typeClasses;return!u.is(256)&&m.has(u.kind)?m.get(u.kind):(n==o.REPORT&&this.error(c.DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,i.range,a.internalName),null)}return n==o.REPORT&&this.error(c.DiagnosticCode.Operation_not_supported,e.range),null},r.prototype.resolveFunction=function(e,r,t,n){void 0===t&&(t=h.makeMap()),void 0===n&&(n=o.REPORT);var i=e.parent.kind==l.ElementKind.PROPERTY_PROTOTYPE?e.parent.parent:e.parent,a=null,s=r?p.typesToString(r):"";if(e.is(_.CommonFlags.INSTANCE)){if(assert(i.kind==l.ElementKind.CLASS),a=i,g=e.getResolvedInstance(s))return g;var d=a.typeArguments;if(d){var y=assert(a.prototype.typeParameterNodes),m=y.length;assert(m==y.length);for(var f=0;f");var w=new l.Function(P,e,D,t);return e.setResolvedInstance(s,w),w},r.prototype.resolveFunctionInclTypeArguments=function(e,r,t,n,i,a){void 0===a&&(a=o.REPORT);var s=e.parent.kind==l.ElementKind.PROPERTY_PROTOTYPE?e.parent.parent:e.parent,u=null;if(e.is(_.CommonFlags.GENERIC)){if(e.is(_.CommonFlags.INSTANCE)){assert(s.kind==l.ElementKind.CLASS);var p=s.typeArguments;if(p){var h=assert(s.prototype.typeParameterNodes),d=p.length;assert(d==h.length);for(var y=0;y"),(g=new l.Class(S,e,r,A)).contextualTypeArguments=t,e.setResolvedInstance(T,g);var O=0;if(A){if(G=A.members){(U=g.members)||(g.members=U=new Map);try{for(var C=a(G),k=C.next();!k.done;k=C.next()){var L=s(k.value,2),R=L[0],F=L[1];U.set(R,F)}}catch(e){i={error:e}}finally{try{k&&!k.done&&(u=C.return)&&u.call(C)}finally{if(i)throw i.error}}}O=A.currentMemoryOffset}var B=e.instanceMembers;if(B)try{for(var D=a(B.values()),P=D.next();!P.done;P=D.next()){var w=P.value;switch(w.kind){case l.ElementKind.FIELD_PROTOTYPE:var U;if(U=g.members){if(U.has(w.name)){this.error(c.DiagnosticCode.Duplicate_identifier_0,w.identifierNode.range,w.name);break}}else g.members=U=new Map;var M=w.typeNode,V=null;if(M)V=this.resolveType(M,e.parent,g.contextualTypeArguments,n);else{var G;if(A)if((G=A.members)&&G.has(w.name)){var K=G.get(w.name);K.is(_.CommonFlags.PRIVATE)||(assert(K.kind==l.ElementKind.FIELD),V=K.type)}V||n==o.REPORT&&this.error(c.DiagnosticCode.Type_expected,w.identifierNode.range.atEnd)}if(!V)break;var z=new l.Field(w,g,V);assert(h.isPowerOf2(V.byteSize));var Y=V.byteSize-1;O&Y&&(O=1+(O|Y)),z.memoryOffset=O,O+=V.byteSize,g.add(w.name,z);break;case l.ElementKind.FUNCTION_PROTOTYPE:var H=w.toBound(g);g.add(H.name,H);break;case l.ElementKind.PROPERTY_PROTOTYPE:var W=new l.Property(w,g),X=w.getterPrototype;if(X){var q=this.resolveFunction(X.toBound(g),null,h.makeMap(g.contextualTypeArguments),n);q&&(W.getterInstance=q,W.setType(q.signature.returnType))}var Q=w.setterPrototype;if(Q){var j=this.resolveFunction(Q.toBound(g),null,h.makeMap(g.contextualTypeArguments),n);j&&(W.setterInstance=j,W.is(_.CommonFlags.RESOLVED)||(assert(1==j.signature.parameterTypes.length),W.setType(j.signature.parameterTypes[0])))}g.add(W.name,W);break;default:assert(!1)}}}catch(e){d={error:e}}finally{try{P&&!P.done&&(y=D.return)&&y.call(D)}finally{if(d)throw d.error}}g.currentMemoryOffset=O;var Z=g.lookupInSelf(_.CommonSymbols.constructor);if(Z&&Z.parent===g){assert(Z.kind==l.ElementKind.FUNCTION_PROTOTYPE);var J=this.resolveFunction(Z,null,g.contextualTypeArguments,n);J&&(g.constructorInstance=J)}try{for(var $=a(e.overloadPrototypes),ee=$.next();!ee.done;ee=$.next()){var re=s(ee.value,2),te=re[0],ne=re[1];assert(te!=l.OperatorKind.INVALID);var ie=void 0;if(ne.is(_.CommonFlags.INSTANCE)){H=ne.toBound(g);ie=this.resolveFunction(H,null,h.makeMap(),n)}else ie=this.resolveFunction(ne,null,h.makeMap(),n);if(ie){var ae=g.overloads;ae||(g.overloads=ae=new Map),ae.set(te,ie)}}}catch(e){m={error:e}}finally{try{ee&&!ee.done&&(f=$.return)&&f.call($)}finally{if(m)throw m.error}}return g},r.prototype.resolveClassInclTypeArguments=function(e,r,t,n,i,a){void 0===a&&(a=o.REPORT);var s=null;if(e.is(_.CommonFlags.GENERIC)){if(!(s=this.resolveTypeArguments(assert(e.typeParameterNodes),r,t,n,i,a)))return null}else if(null!==r&&r.length)return a==o.REPORT&&this.error(c.DiagnosticCode.Type_0_is_not_generic,i.range,e.internalName),null;return this.resolveClass(e,s,n,a)},r}(c.DiagnosticEmitter);r.Resolver=m},function(e,r,t){"use strict";var n=this&&this.__values||function(e){var r="function"==typeof Symbol&&e[Symbol.iterator],t=0;return r?r.call(e):{next:function(){return e&&t>=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}};Object.defineProperty(r,"__esModule",{value:!0});var i,a=t(6),s=t(3),o=t(4),c=t(0),l=t(2);!function(e){e[e.NONE=0]="NONE",e[e.RETURNS=1]="RETURNS",e[e.RETURNS_WRAPPED=2]="RETURNS_WRAPPED",e[e.RETURNS_NONNULL=4]="RETURNS_NONNULL",e[e.THROWS=8]="THROWS",e[e.BREAKS=16]="BREAKS",e[e.CONTINUES=32]="CONTINUES",e[e.ALLOCATES=64]="ALLOCATES",e[e.CALLS_SUPER=128]="CALLS_SUPER",e[e.TERMINATES=256]="TERMINATES",e[e.CONDITIONALLY_RETURNS=512]="CONDITIONALLY_RETURNS",e[e.CONDITIONALLY_THROWS=1024]="CONDITIONALLY_THROWS",e[e.CONDITIONALLY_TERMINATES=2048]="CONDITIONALLY_TERMINATES",e[e.CONDITIONALLY_BREAKS=4096]="CONDITIONALLY_BREAKS",e[e.CONDITIONALLY_CONTINUES=8192]="CONDITIONALLY_CONTINUES",e[e.CONDITIONALLY_ALLOCATES=16384]="CONDITIONALLY_ALLOCATES",e[e.INLINE_CONTEXT=32768]="INLINE_CONTEXT",e[e.UNCHECKED_CONTEXT=65536]="UNCHECKED_CONTEXT",e[e.ANY_CATEGORICAL=511]="ANY_CATEGORICAL",e[e.ANY_CONDITIONAL=30208]="ANY_CONDITIONAL"}(r.FlowFlags||(r.FlowFlags={})),function(e){e[e.NONE=0]="NONE",e[e.CONSTANT=1]="CONSTANT",e[e.WRAPPED=2]="WRAPPED",e[e.NONNULL=4]="NONNULL",e[e.READFROM=8]="READFROM",e[e.WRITTENTO=16]="WRITTENTO",e[e.RETAINED=32]="RETAINED",e[e.CONDITIONALLY_READFROM=64]="CONDITIONALLY_READFROM",e[e.CONDITIONALLY_WRITTENTO=128]="CONDITIONALLY_WRITTENTO",e[e.CONDITIONALLY_RETAINED=256]="CONDITIONALLY_RETAINED",e[e.ANY_CATEGORICAL=63]="ANY_CATEGORICAL",e[e.ANY_CONDITIONAL=480]="ANY_CONDITIONAL",e[e.ANY_RETAINED=288]="ANY_RETAINED"}(i=r.LocalFlags||(r.LocalFlags={})),function(e){e.join=function(r,t){return r&e.ANY_CATEGORICAL&t&e.ANY_CATEGORICAL|r&e.ANY_CONDITIONAL|t&e.ANY_CONDITIONAL}}(i=r.LocalFlags||(r.LocalFlags={})),function(e){e[e.NONE=0]="NONE",e[e.INITIALIZED=1]="INITIALIZED",e[e.CONDITIONALLY_INITIALIZED=2]="CONDITIONALLY_INITIALIZED",e[e.ANY_CATEGORICAL=1]="ANY_CATEGORICAL",e[e.ANY_CONDITIONAL=2]="ANY_CONDITIONAL"}(r.FieldFlags||(r.FieldFlags={})),function(e){e.join=function(r,t){return r&e.ANY_CATEGORICAL&t&e.ANY_CATEGORICAL|r&e.ANY_CONDITIONAL|t&e.ANY_CONDITIONAL}}(r.FieldFlags||(r.FieldFlags={}));var u=function(){function e(){this.scopedLocals=null,this.fieldFlags=null}return e.create=function(r){var t=new e;return t.parent=null,t.flags=0,t.parentFunction=r,t.continueLabel=null,t.breakLabel=null,t.returnType=r.signature.returnType,t.contextualTypeArguments=r.contextualTypeArguments,t.localFlags=[],t.inlineFunction=null,t.inlineReturnLabel=null,t},e.createInline=function(r,t){var n=e.create(r);return n.set(32768),n.inlineFunction=t,n.inlineReturnLabel=t.internalName+"|inlined."+(t.nextInlineId++).toString(10),n.returnType=t.signature.returnType,n.contextualTypeArguments=t.contextualTypeArguments,n},Object.defineProperty(e.prototype,"actualFunction",{get:function(){return this.inlineFunction||this.parentFunction},enumerable:!0,configurable:!0}),e.prototype.is=function(e){return(this.flags&e)==e},e.prototype.isAny=function(e){return 0!=(this.flags&e)},e.prototype.set=function(e){this.flags|=e},e.prototype.unset=function(e){this.flags&=~e},e.prototype.fork=function(){var r=new e;return r.parent=this,r.flags=this.flags,r.parentFunction=this.parentFunction,r.continueLabel=this.continueLabel,r.breakLabel=this.breakLabel,r.returnType=this.returnType,r.contextualTypeArguments=this.contextualTypeArguments,r.localFlags=this.localFlags.slice(),r.inlineFunction=this.inlineFunction,r.inlineReturnLabel=this.inlineReturnLabel,r},e.prototype.getTempLocal=function(e,r){void 0===r&&(r=null);var t,n,i=this.parentFunction;switch(e.toNativeType()){case o.NativeType.I32:t=i.tempI32s;break;case o.NativeType.I64:t=i.tempI64s;break;case o.NativeType.F32:t=i.tempF32s;break;case o.NativeType.F64:t=i.tempF64s;break;case o.NativeType.V128:t=i.tempV128s;break;default:throw new Error("concrete type expected")}if(r){if(t&&t.length)for(var a=0,s=t.length;a=0);var r,t=this.parentFunction;switch(assert(null!=e.type),e.type.toNativeType()){case o.NativeType.I32:r=t.tempI32s||(t.tempI32s=[]);break;case o.NativeType.I64:r=t.tempI64s||(t.tempI64s=[]);break;case o.NativeType.F32:r=t.tempF32s||(t.tempF32s=[]);break;case o.NativeType.F64:r=t.tempF64s||(t.tempF64s=[]);break;case o.NativeType.V128:r=t.tempV128s||(t.tempV128s=[]);break;default:throw new Error("concrete type expected")}assert(e.index>=0),r.push(e)}},e.prototype.getAndFreeTempLocal=function(e,r){void 0===r&&(r=null);var t=this.getTempLocal(e,r);return this.freeTempLocal(t),t},e.prototype.getScopedLocal=function(e){var r=this.scopedLocals;return r&&r.has(e)?r.get(e):null},e.prototype.addScopedLocal=function(e,r,t){void 0===t&&(t=null);var n=this.getTempLocal(r,t),i=this.scopedLocals;return i?assert(!i.has(e)):this.scopedLocals=i=new Map,n.set(c.CommonFlags.SCOPED),i.set(e,n),n},e.prototype.addScopedAlias=function(e,r,t,n){if(void 0===n&&(n=null),this.scopedLocals){var i=this.scopedLocals.get(e);if(i)return n&&this.parentFunction.program.error(l.DiagnosticCode.Duplicate_identifier_0,n.range),i}else this.scopedLocals=new Map;assert(t1?e.breakLabel=r[t-2].toString(10):(e.breakLabel=null,e.breakStack=null)},e.prototype.inherit=function(e){this.flags|=30719&e.flags,this.localFlags=e.localFlags},e.prototype.inheritConditional=function(e){e.is(1)&&this.set(512),e.is(8)&&this.set(1024),e.is(16)&&e.breakLabel==this.breakLabel&&this.set(4096),e.is(32)&&e.continueLabel==this.continueLabel&&this.set(8192),e.is(64)&&this.set(16384);for(var r=e.localFlags,t=0,n=r.length;tl):this.canOverflow(o.getBinaryLeft(e),r)&&!(o.getExpressionId(t=o.getBinaryRight(e))==o.ExpressionId.Const&&o.getConstValueI32(t)>=l);case o.BinaryOp.DivU32:case o.BinaryOp.RemI32:case o.BinaryOp.RemU32:return this.canOverflow(o.getBinaryLeft(e),r)||this.canOverflow(o.getBinaryRight(e),r)}break;case o.ExpressionId.Unary:switch(o.getUnaryOp(e)){case o.UnaryOp.EqzI32:case o.UnaryOp.EqzI64:return!1;case o.UnaryOp.ClzI32:case o.UnaryOp.CtzI32:case o.UnaryOp.PopcntI32:return r.size<7}break;case o.ExpressionId.Const:var u=0;switch(o.getExpressionType(e)){case o.NativeType.I32:u=o.getConstValueI32(e);break;case o.NativeType.I64:u=o.getConstValueI64Low(e);break;case o.NativeType.F32:u=i32(o.getConstValueF32(e));break;case o.NativeType.F64:u=i32(o.getConstValueF64(e));break;default:assert(!1)}switch(r.kind){case 0:return ui8.MAX_VALUE;case 1:return ui16.MAX_VALUE;case 5:return u<0||u>u8.MAX_VALUE;case 6:return u<0||u>u16.MAX_VALUE;case 10:return 0!=(-2&u)}break;case o.ExpressionId.Load:var _=void 0,h=o.isLoadSigned(e);switch(o.getLoadBytes(e)){case 1:_=h?a.Type.i8:a.Type.u8;break;case 2:_=h?a.Type.i16:a.Type.u16;break;default:_=h?a.Type.i32:a.Type.u32}return p(_,r);case o.ExpressionId.Block:if(!o.getBlockName(e)){var d=assert(o.getBlockChildCount(e)),y=o.getBlockChild(e,d-1);return this.canOverflow(y,r)}break;case o.ExpressionId.If:return this.canOverflow(o.getIfTrue(e),r)||this.canOverflow(assert(o.getIfFalse(e)),r);case o.ExpressionId.Select:return this.canOverflow(o.getSelectThen(e),r)||this.canOverflow(o.getSelectElse(e),r);case o.ExpressionId.Call:var m=this.parentFunction.program.instancesByName,f=assert(o.getCallTarget(e));if(m.has(f)){var T=m.get(f);assert(T.kind==s.ElementKind.FUNCTION);var g=T.signature.returnType;return!T.flow.is(2)||p(g,r)}return!1;case o.ExpressionId.Unreachable:return!1}return!0},e.prototype.toString=function(){for(var e=0,r=this.parent;r;)r=r.parent,++e;return"Flow("+this.actualFunction+")["+e.toString()+"]"},e}();function p(e,r){return!e.is(4)||e.size>r.size||e.is(1)!=r.is(1)}function _(e,r){switch(o.getExpressionId(e)){case o.ExpressionId.LocalGet:r.add(o.getLocalGetIndex(e));break;case o.ExpressionId.LocalSet:r.add(o.getLocalSetIndex(e));default:o.traverse(e,r,_)}}r.Flow=u,r.findUsedLocals=function(e,r){return void 0===r&&(r=new Set),o.traverse(e,r,_),r}},function(e,r,t){"use strict";var n,i=this&&this.__extends||(n=function(e,r){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,r){e.__proto__=r}||function(e,r){for(var t in r)r.hasOwnProperty(t)&&(e[t]=r[t])})(e,r)},function(e,r){function t(){this.constructor=e}n(e,r),e.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)}),a=this&&this.__values||function(e){var r="function"==typeof Symbol&&e[Symbol.iterator],t=0;return r?r.call(e):{next:function(){return e&&t>=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},s=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0});var o=t(13),c=t(2),l=t(4),u=t(0),p=t(3),_=t(10),h=t(9),d=t(7),y=t(5),m=t(6),f=t(1),T=function(){function e(){this.target=u.Target.WASM32,this.noAssert=!1,this.importMemory=!1,this.sharedMemory=0,this.importTable=!1,this.sourceMap=!1,this.explicitStart=!1,this.memoryBase=0,this.globalAliases=null,this.features=0,this.optimizeLevelHint=0,this.shrinkLevelHint=0}return Object.defineProperty(e.prototype,"isWasm64",{get:function(){return this.target==u.Target.WASM64},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"usizeType",{get:function(){return this.target==u.Target.WASM64?m.Type.usize64:m.Type.usize32},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isizeType",{get:function(){return this.target==u.Target.WASM64?m.Type.isize64:m.Type.isize32},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"nativeSizeType",{get:function(){return this.target==u.Target.WASM64?l.NativeType.I64:l.NativeType.I32},enumerable:!0,configurable:!0}),e.prototype.hasFeature=function(e){return 0!=(this.features&e)},e}();r.Options=T,function(e){e[e.NONE=0]="NONE",e[e.CONV_IMPLICIT=1]="CONV_IMPLICIT",e[e.CONV_EXPLICIT=2]="CONV_EXPLICIT",e[e.MUST_WRAP=4]="MUST_WRAP",e[e.WILL_DROP=8]="WILL_DROP",e[e.WILL_RETAIN=16]="WILL_RETAIN",e[e.PREFER_STATIC=32]="PREFER_STATIC"}(r.Constraints||(r.Constraints={})),function(e){e[e.NONE=0]="NONE",e[e.HEAP=1]="HEAP",e[e.RTTI=2]="RTTI",e[e.visitGlobals=4]="visitGlobals",e[e.visitMembers=8]="visitMembers"}(r.RuntimeFeatures||(r.RuntimeFeatures={}));var g,E,v=function(e){function r(r,t){void 0===t&&(t=null);var n=e.call(this,r.diagnostics)||this;n.currentInlineFunctions=[],n.currentEnum=null,n.currentType=m.Type.void,n.memorySegments=[],n.stringSegments=new Map,n.functionTable=["null"],n.argcVar=0,n.argcSet=0,n.runtimeFeatures=0,n.skippedAutoreleases=new Set,n.f32ModInstance=null,n.f64ModInstance=null,n.f32PowInstance=null,n.f64PowInstance=null,n.program=r,n.resolver=r.resolver,t||(t=new T),n.options=t,n.memoryOffset=i64_new(max(t.memoryBase,8)),n.module=l.Module.create();var i=0;return n.options.hasFeature(16)&&(i|=l.FeatureFlags.Atomics),n.options.hasFeature(2)&&(i|=l.FeatureFlags.MutableGloabls),n.options.hasFeature(8)&&(i|=l.FeatureFlags.SIMD128),n.options.hasFeature(4)&&(i|=l.FeatureFlags.BulkMemory),n.options.hasFeature(1)&&(i|=l.FeatureFlags.SignExt),n.module.setFeatures(i),n}return i(r,e),r.compile=function(e,t){return void 0===t&&(t=null),new r(e,t).compile()},r.prototype.compile=function(){var e,r,t,n,i=this.options,s=this.module,c=this.program;c.initialize(i);var u=c.makeNativeFunction("start",new m.Signature([],m.Type.void));u.internalName="start";var p=new Array;this.currentFlow=u.flow,this.currentBody=p,i.isWasm64?(s.addGlobal(o.BuiltinSymbols.heap_base,l.NativeType.I64,!0,s.i64(0)),s.addGlobal(o.BuiltinSymbols.rtti_base,l.NativeType.I64,!0,s.i64(0))):(s.addGlobal(o.BuiltinSymbols.heap_base,l.NativeType.I32,!0,s.i32(0)),s.addGlobal(o.BuiltinSymbols.rtti_base,l.NativeType.I32,!0,s.i32(0)));var _=c.filesByName;try{for(var h=a(_.values()),d=h.next();!d.done;d=h.next()){(A=d.value).source.isEntry&&(this.compileFile(A),this.compileExports(A))}}catch(r){e={error:r}}finally{try{d&&!d.done&&(r=h.return)&&r.call(h)}finally{if(e)throw e.error}}var y=!p.length,f=i.explicitStart;if(!y||f){var T=u.signature;!y&&f&&(s.addGlobal(o.BuiltinSymbols.started,l.NativeType.I32,!0,s.i32(0)),p.unshift(s.if(s.global_get(o.BuiltinSymbols.started,l.NativeType.I32),s.return(),s.global_set(o.BuiltinSymbols.started,s.i32(1)))));var g=s.addFunction(u.internalName,this.ensureFunctionType(T.parameterTypes,T.returnType,T.thisType),m.typesToNativeTypes(u.additionalLocals),s.block(null,p));u.finalize(s,g),f?s.addFunctionExport(u.internalName,"__start"):s.setStart(g)}4&this.runtimeFeatures&&o.compileVisitGlobals(this),8&this.runtimeFeatures&&o.compileVisitMembers(this),s.removeGlobal(o.BuiltinSymbols.rtti_base),2&this.runtimeFeatures&&o.compileRTTI(this);var E=this.memoryOffset;E=i64_align(E,i.usizeType.byteSize),this.memoryOffset=E,s.removeGlobal(o.BuiltinSymbols.heap_base),1&this.runtimeFeatures&&(i.isWasm64?s.addGlobal(o.BuiltinSymbols.heap_base,l.NativeType.I64,!1,s.i64(i64_low(E),i64_high(E))):s.addGlobal(o.BuiltinSymbols.heap_base,l.NativeType.I32,!1,s.i32(i64_low(E))));var v=i.hasFeature(16)&&i.sharedMemory>0;s.setMemory(this.options.memoryBase||this.memorySegments.length?i64_low(i64_shr_u(i64_align(E,65536),i64_new(16,0))):0,v?i.sharedMemory:l.Module.UNLIMITED_MEMORY,this.memorySegments,i.target,"memory",v),i.importMemory&&s.addMemoryImport("0","env","memory",v);var b=this.functionTable;s.setFunctionTable(b.length,4294967295,b),s.addFunction("null",this.ensureFunctionType(null,m.Type.void),null,s.block(null,[])),i.importTable&&s.addTableImport("0","env","table");try{for(var I=a(this.program.filesByName.values()),x=I.next();!x.done;x=I.next()){var A;(A=x.value).source.isEntry&&this.ensureModuleExports(A)}}catch(e){t={error:e}}finally{try{x&&!x.done&&(n=I.return)&&n.call(I)}finally{if(t)throw t.error}}return s},r.prototype.ensureModuleExports=function(e){var r,t,n=e.exports;if(n)try{for(var i=a(n),o=i.next();!o.done;o=i.next()){var c=s(o.value,2),l=c[0],u=c[1];this.ensureModuleExport(l,u)}}catch(e){r={error:e}}finally{try{o&&!o.done&&(t=i.return)&&t.call(i)}finally{if(r)throw r.error}}var p=e.exportsStar;if(p)for(var _=0,h=p.length;_1?p.block(null,n):n[0]),t.push(p.call(r.internalName,null,l.NativeType.None))}}},r.prototype.compileGlobal=function(e){if(e.is(u.CommonFlags.COMPILED))return!0;e.set(u.CommonFlags.COMPILED);var r=this.module,t=0,n=!1,i=e.typeNode,a=e.initializerNode;if(!e.is(u.CommonFlags.RESOLVED))if(i){var s=this.resolver.resolveType(i,e.parent);if(!s)return!1;if(s==m.Type.void)return this.error(c.DiagnosticCode.Type_expected,i.range),!1;e.setType(s)}else{if(!a)return this.error(c.DiagnosticCode.Type_expected,e.identifierNode.range.atEnd),!1;var _=this.currentFlow;if(e.hasDecorator(p.DecoratorFlags.LAZY)&&(this.currentFlow=e.file.startFunction.flow),t=this.compileExpression(a,m.Type.auto,20),this.skippedAutoreleases.has(t)&&(n=!0),this.currentFlow=_,this.currentType==m.Type.void)return this.error(c.DiagnosticCode.Type_0_is_not_assignable_to_type_1,a.range,this.currentType.toString(),""),!1;e.setType(this.currentType)}if(e.is(u.CommonFlags.AMBIENT)&&e.hasDecorator(p.DecoratorFlags.BUILTIN))return e.internalName==o.BuiltinSymbols.heap_base?this.runtimeFeatures|=1:e.internalName==o.BuiltinSymbols.rtti_base&&(this.runtimeFeatures|=2),!0;var h=e.type,d=h.toNativeType(),f=e.is(u.CommonFlags.CONST)||e.is(u.CommonFlags.STATIC|u.CommonFlags.READONLY),T=e.hasDecorator(p.DecoratorFlags.INLINE);if(e.is(u.CommonFlags.AMBIENT))return f||this.options.hasFeature(2)?(e.set(u.CommonFlags.MODULE_IMPORT),b(e,e.declaration),r.addGlobalImport(e.internalName,g,E,d),e.set(u.CommonFlags.COMPILED),!0):(this.error(c.DiagnosticCode.Operation_not_supported,e.declaration.range),!1);var v=!1;if(a){if(!t){_=this.currentFlow;e.hasDecorator(p.DecoratorFlags.LAZY)&&(this.currentFlow=e.file.startFunction.flow),t=this.compileExpression(a,h,53),this.skippedAutoreleases.has(t)&&(n=!0),this.currentFlow=_}if(l.getExpressionId(t)!=l.ExpressionId.Const&&(f?(t=r.precomputeExpression(t),l.getExpressionId(t)!=l.ExpressionId.Const&&(v=!0)):v=!0),T)if(v)this.warning(c.DiagnosticCode.Mutable_value_cannot_be_inlined,a.range);else{switch(assert(l.getExpressionId(t)==l.ExpressionId.Const),l.getExpressionType(t)){case l.NativeType.I32:e.constantValueKind=1,e.constantIntegerValue=i64_new(l.getConstValueI32(t),0);break;case l.NativeType.I64:e.constantValueKind=1,e.constantIntegerValue=i64_new(l.getConstValueI64Low(t),l.getConstValueI64High(t));break;case l.NativeType.F32:e.constantValueKind=2,e.constantFloatValue=l.getConstValueF32(t);break;case l.NativeType.F64:e.constantValueKind=2,e.constantFloatValue=l.getConstValueF64(t);break;default:return assert(!1),!1}e.set(u.CommonFlags.INLINED)}}else t=h.toNativeZero(r);var I=e.internalName;return v?(T&&this.error(c.DiagnosticCode.Decorator_0_is_not_valid_here,assert(y.findDecorator(y.DecoratorKind.INLINE,e.decoratorNodes)).range,"inline"),r.addGlobal(I,d,!0,h.toNativeZero(r)),h.isManaged&&!n&&(t=this.makeRetain(t)),this.currentBody.push(r.global_set(I,t))):T||r.addGlobal(I,d,!f,t),!0},r.prototype.compileEnum=function(e){var r,t;if(e.is(u.CommonFlags.COMPILED))return!0;e.set(u.CommonFlags.COMPILED);var n=this.module;this.currentEnum=e;var i=null,s=!1,o=e.is(u.CommonFlags.CONST)||e.hasDecorator(p.DecoratorFlags.INLINE);if(e.members)try{for(var _=a(e.members.values()),h=_.next();!h.done;h=_.next()){var d=h.value;if(d.kind==p.ElementKind.ENUMVALUE){var y=!1,f=d,T=f.valueNode;f.set(u.CommonFlags.COMPILED);var g=this.currentFlow;e.hasDecorator(p.DecoratorFlags.LAZY)&&(this.currentFlow=e.file.startFunction.flow);var E=void 0;T?(E=this.compileExpression(T,m.Type.i32,1),l.getExpressionId(E)!=l.ExpressionId.Const&&(E=n.precomputeExpression(E),l.getExpressionId(E)!=l.ExpressionId.Const&&(e.is(u.CommonFlags.CONST)&&this.error(c.DiagnosticCode.In_const_enum_declarations_member_initializer_must_be_constant_expression,T.range),y=!0))):null==i?E=n.i32(0):(s&&this.error(c.DiagnosticCode.Enum_member_must_have_initializer,d.identifierNode.range.atEnd),E=n.binary(l.BinaryOp.AddI32,n.global_get(i.internalName,l.NativeType.I32),n.i32(1)),E=n.precomputeExpression(E),l.getExpressionId(E)!=l.ExpressionId.Const&&(e.is(u.CommonFlags.CONST)&&this.error(c.DiagnosticCode.In_const_enum_declarations_member_initializer_must_be_constant_expression,d.declaration.range),y=!0)),this.currentFlow=g,y?(n.addGlobal(f.internalName,l.NativeType.I32,!0,n.i32(0)),this.currentBody.push(this.makeGlobalAssignment(f,E,!1)),s=!0):(o?(f.setConstantIntegerValue(i64_new(l.getConstValueI32(E)),m.Type.i32),f.is(u.CommonFlags.MODULE_EXPORT)&&n.addGlobal(f.internalName,l.NativeType.I32,!1,E)):n.addGlobal(f.internalName,l.NativeType.I32,!1,E),f.isImmutable=!0,s=!1),i=f}}}catch(e){r={error:e}}finally{try{h&&!h.done&&(t=_.return)&&t.call(_)}finally{if(r)throw r.error}}return this.currentEnum=null,!0},r.prototype.compileFunctionUsingTypeArguments=function(e,r,t,n){if(void 0===t&&(t=f.makeMap()),void 0===n&&(n=null),e.hasDecorator(p.DecoratorFlags.BUILTIN))return null;var i=this.resolver.resolveFunctionInclTypeArguments(e,r,e.parent,t,n||e.declaration);return i&&this.compileFunction(i)?i:null},r.prototype.ensureFunctionType=function(e,r,t){void 0===t&&(t=null);var n,i=e?e.length:0,a=0;if(t?((n=new Array(1+i))[0]=t.toNativeType(),a=1):n=new Array(i),e)for(var s=0;so){var f=a.getAndFreeTempLocal(i);h||a.setLocalFlag(f.index,_.LocalFlags.WRAPPED),d&&a.setLocalFlag(f.index,_.LocalFlags.NONNULL),r[o-1]=t.local_set(f.index,s),r.push(t.local_get(f.index,i.toNativeType()))}h||a.set(2),d&&a.set(4),a.set(257)}}if(e.is(u.CommonFlags.CONSTRUCTOR)){var T=this.options.nativeSizeType;assert(e.is(u.CommonFlags.INSTANCE));var g=assert(e.parent);if(assert(g.kind==p.ElementKind.CLASS),!a.is(256)){var E=assert(a.lookupLocal(u.CommonSymbols.this_));a.is(64)||(r.push(t.if(t.unary(T==l.NativeType.I64?l.UnaryOp.EqzI64:l.UnaryOp.EqzI32,t.local_get(E.index,T)),t.local_set(E.index,this.makeRetain(this.makeAllocation(g))))),this.makeFieldInitialization(g,r)),this.performAutoreleases(a,r),this.finishAutoreleases(a,r),r.push(t.local_get(E.index,this.options.nativeSizeType)),a.set(261)}g.base&&!a.is(128)&&this.error(c.DiagnosticCode.Constructors_for_derived_classes_must_contain_a_super_call,e.prototype.declaration.range)}else i==m.Type.void||a.is(256)||this.error(c.DiagnosticCode.A_function_whose_declared_type_is_not_void_must_return_a_value,e.prototype.functionTypeNode.returnType.range);return r},r.prototype.compileFunction=function(e){if(e.is(u.CommonFlags.COMPILED))return!0;assert(!(e.is(u.CommonFlags.AMBIENT)&&e.hasDecorator(p.DecoratorFlags.BUILTIN)));var r=this.currentType;e.set(u.CommonFlags.COMPILED);var t,n=this.module,i=e.signature,a=e.prototype.bodyNode,s=this.ensureFunctionType(i.parameterTypes,i.returnType,i.thisType);if(a){if(e.is(u.CommonFlags.AMBIENT)&&this.error(c.DiagnosticCode.An_implementation_cannot_be_declared_in_ambient_contexts,e.identifierNode.range),e.hasDecorator(p.DecoratorFlags.EXTERNAL)){var o=e.decoratorNodes,l=assert(y.findDecorator(y.DecoratorKind.EXTERNAL,o));this.error(c.DiagnosticCode.Operation_not_supported,l.range)}var h=this.currentFlow,d=e.flow;this.currentFlow=d;var f=new Array,T=0;i.thisType&&++T;for(var v=i.parameterTypes,x=0,A=v.length;x=0)return e.functionTableIndex;var r=this.functionTable,t=r.length;return!e.is(u.CommonFlags.TRAMPOLINE)&&e.signature.requiredParameters1||l.getExpressionId(g[0])!=l.ExpressionId.Break)&&S.push(r.block(d,g));else for(var O=0,C=g.length;O=0?"case"+p.toString(10):"break")+"|"+a);var d=r.block("case0|"+a,c,l.NativeType.None),y=511,f=0;for(_=0;_=0&&(i.flags|=-17&y),i.flags|=-4097&f,d},r.prototype.compileThrowStatement=function(e){var r=this.currentFlow;r.set(264);var t=new Array;this.finishAutoreleases(r,t);var n=e.value,i=null;if(n.kind==y.NodeKind.NEW){var a=n.arguments;a.length&&(i=a[0])}return t.push(o.compileAbort(this,i,e)),I(this.module,t,l.NativeType.None)},r.prototype.compileTryStatement=function(e){return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()},r.prototype.compileVariableStatement=function(e){for(var r=this.module,t=e.declarations,n=t.length,i=this.currentFlow,a=new Array,s=this.resolver,o=0;o");continue}y=this.currentType}var g=h.is(u.CommonFlags.CONST),E=!1;if(g)if(f){if(f=r.precomputeExpression(f),l.getExpressionId(f)==l.ExpressionId.Const){var v=new p.Local(d,-1,y,i.parentFunction);switch(l.getExpressionType(f)){case l.NativeType.I32:v.setConstantIntegerValue(i64_new(l.getConstValueI32(f),0),y);break;case l.NativeType.I64:v.setConstantIntegerValue(i64_new(l.getConstValueI64Low(f),l.getConstValueI64High(f)),y);break;case l.NativeType.F32:v.setConstantFloatValue(l.getConstValueF32(f),y);break;case l.NativeType.F64:v.setConstantFloatValue(l.getConstValueF64(f),y);break;default:return assert(!1),r.unreachable()}var b=i.scopedLocals;if(b){if(b.has(d))return this.error(c.DiagnosticCode.Duplicate_identifier_0,h.name.range,d),this.module.unreachable()}else i.scopedLocals=b=new Map;b.set(d,v),E=!0}}else this.error(c.DiagnosticCode._const_declarations_must_be_initialized,h.range);if(!E){v=void 0;if(h.isAny(u.CommonFlags.LET|u.CommonFlags.CONST)||i.is(32768)){var x=i.getScopedLocal(d);x?(this.error(c.DiagnosticCode.Duplicate_identifier_0,h.name.range,h.name.text),v=x):v=i.addScopedLocal(d,y),g&&i.setLocalFlag(v.index,_.LocalFlags.CONSTANT)}else{if(i.lookupLocal(d)){this.error(c.DiagnosticCode.Duplicate_identifier_0,h.name.range,d);continue}v=i.parentFunction.addLocal(y,d,h),g&&i.setLocalFlag(v.index,_.LocalFlags.CONSTANT)}var A=y.isManaged;f?(i.isNonnull(f,y)&&i.setLocalFlag(v.index,_.LocalFlags.NONNULL),A?(i.setLocalFlag(v.index,_.LocalFlags.RETAINED),a.push(r.local_set(v.index,T?f:this.makeRetain(f)))):(a.push(r.local_set(v.index,f)),v.type.is(36)&&(i.canOverflow(f,y)?i.unsetLocalFlag(v.index,_.LocalFlags.WRAPPED):i.setLocalFlag(v.index,_.LocalFlags.WRAPPED)))):A?(a.push(r.local_set(v.index,y.toNativeZero(r))),i.setLocalFlag(v.index,_.LocalFlags.CONDITIONALLY_RETAINED)):v.type.is(36)&&i.setLocalFlag(v.index,_.LocalFlags.WRAPPED)}}return 0==a.length?0:I(r,a,l.NativeType.None)},r.prototype.compileVoidStatement=function(e){return this.compileExpression(e.expression,m.Type.void,10)},r.prototype.compileWhileStatement=function(e){var r=this.module,t=this.currentFlow,n=r.precomputeExpression(this.makeIsTrueish(this.compileExpression(e.condition,m.Type.bool),this.currentType)),i=!1;if(l.getExpressionId(n)==l.ExpressionId.Const){if(assert(l.getExpressionType(n)==l.NativeType.I32),!l.getConstValueI32(n))return r.nop();i=!0}var a=t.pushBreakLabel(),s=t.fork();this.currentFlow=s;var o="break|"+a;s.breakLabel=o;var c="continue|"+a;s.continueLabel=c,s.inheritNonnullIfTrue(n);var u=new Array;e.statement.kind==y.NodeKind.BLOCK?this.compileStatements(e.statement.statements,!1,u):u.push(this.compileStatement(e.statement));var p=!s.is(256)&&!s.is(16);p&&(this.performAutoreleases(s,u),u.push(r.br(c))),i||u.unshift(r.br(o,r.unary(l.UnaryOp.EqzI32,n)));var _=I(r,u,l.NativeType.None);return(p||s.isAny(8224))&&(_=r.loop(c,_)),i&&!s.isAny(4112)||(_=r.block(o,[_])),s.freeScopedLocals(),t.popBreakLabel(),s.unset(12336),i?t.inherit(s):t.inheritConditional(s),this.currentFlow=t,_},r.prototype.compileInlineConstant=function(e,r,t){assert(e.is(u.CommonFlags.INLINED));var n=e.type;switch(!(3&t)&&n.is(4)&&r.is(4)&&n.size>i:0);case 5:case 6:case 10:var a=e.type.computeSmallIntegerMask(m.Type.i32);return this.module.i32(1==e.constantValueKind?i64_low(e.constantIntegerValue)&a:0);case 2:case 7:return this.module.i32(1==e.constantValueKind?i64_low(e.constantIntegerValue):0);case 4:case 9:if(!e.program.options.isWasm64)return this.module.i32(1==e.constantValueKind?i64_low(e.constantIntegerValue):0);case 3:case 8:return 1==e.constantValueKind?this.module.i64(i64_low(e.constantIntegerValue),i64_high(e.constantIntegerValue)):this.module.i64(0);case 12:if(!e.hasDecorator(p.DecoratorFlags.BUILTIN)||r!=m.Type.f32)return this.module.f64(e.constantFloatValue);this.currentType=m.Type.f32;case 11:return this.module.f32(e.constantFloatValue);default:return assert(!1),this.module.unreachable()}},r.prototype.compileExpression=function(e,r,t){var n;switch(void 0===t&&(t=0),this.currentType=r,r==m.Type.void&&(t|=8),e.kind){case y.NodeKind.ASSERTION:n=this.compileAssertionExpression(e,r,t);break;case y.NodeKind.BINARY:n=this.compileBinaryExpression(e,r,t);break;case y.NodeKind.CALL:n=this.compileCallExpression(e,r,t);break;case y.NodeKind.COMMA:n=this.compileCommaExpression(e,r,t);break;case y.NodeKind.ELEMENTACCESS:n=this.compileElementAccessExpression(e,r,t);break;case y.NodeKind.FUNCTION:n=this.compileFunctionExpression(e,r.signatureReference,t);break;case y.NodeKind.IDENTIFIER:case y.NodeKind.FALSE:case y.NodeKind.NULL:case y.NodeKind.THIS:case y.NodeKind.SUPER:case y.NodeKind.TRUE:n=this.compileIdentifierExpression(e,r,t);break;case y.NodeKind.INSTANCEOF:n=this.compileInstanceOfExpression(e,r,t);break;case y.NodeKind.LITERAL:n=this.compileLiteralExpression(e,r,t);break;case y.NodeKind.NEW:n=this.compileNewExpression(e,r,t);break;case y.NodeKind.PARENTHESIZED:n=this.compileExpression(e.expression,r,t);break;case y.NodeKind.PROPERTYACCESS:n=this.compilePropertyAccessExpression(e,r,t);break;case y.NodeKind.TERNARY:n=this.compileTernaryExpression(e,r,t);break;case y.NodeKind.UNARYPOSTFIX:n=this.compileUnaryPostfixExpression(e,r,t);break;case y.NodeKind.UNARYPREFIX:n=this.compileUnaryPrefixExpression(e,r,t);break;default:this.error(c.DiagnosticCode.Operation_not_supported,e.range),n=this.module.unreachable()}var i=this.currentType,a=0!=(4&t);return i!=r&&(2&t?(n=this.convertExpression(n,i,r,!0,a,e),a=!1,this.currentType=r):1&t&&(n=this.convertExpression(n,i,r,!1,a,e),a=!1,this.currentType=r)),a&&(n=this.ensureSmallIntegerWrap(n,i)),this.options.sourceMap&&this.addDebugLocation(n,e.range),n},r.prototype.precomputeExpression=function(e,r,t){return void 0===t&&(t=0),this.module.precomputeExpression(this.compileExpression(e,r,t))},r.prototype.convertExpression=function(e,r,t,n,i,a){var s=this.module;return 14==r.kind?(assert(14!=t.kind),this.error(c.DiagnosticCode.Type_0_is_not_assignable_to_type_1,a.range,r.toString(),t.toString()),s.unreachable()):14==t.kind?s.drop(e):(this.currentFlow.isNonnull(e,r)&&(r=r.nonNullableType),r.isAssignableTo(t)||n||(r.nonNullableType==t?this.error(c.DiagnosticCode.Object_is_possibly_null,a.range):this.error(c.DiagnosticCode.Conversion_from_type_0_to_1_requires_an_explicit_cast,a.range,r.toString(),t.toString())),r.is(8)?t.is(8)?11==r.kind?12==t.kind&&(e=s.unary(l.UnaryOp.PromoteF32,e)):11==t.kind&&(e=s.unary(l.UnaryOp.DemoteF64,e)):t.is(4)?11==r.kind?t==m.Type.bool?(e=s.binary(l.BinaryOp.NeF32,e,s.f32(0)),i=!1):e=t.is(1)?t.is(64)?s.unary(l.UnaryOp.TruncF32ToI64,e):s.unary(l.UnaryOp.TruncF32ToI32,e):t.is(64)?s.unary(l.UnaryOp.TruncF32ToU64,e):s.unary(l.UnaryOp.TruncF32ToU32,e):t==m.Type.bool?(e=s.binary(l.BinaryOp.NeF64,e,s.f64(0)),i=!1):e=t.is(1)?t.is(64)?s.unary(l.UnaryOp.TruncF64ToI64,e):s.unary(l.UnaryOp.TruncF64ToI32,e):t.is(64)?s.unary(l.UnaryOp.TruncF64ToU64,e):s.unary(l.UnaryOp.TruncF64ToU32,e):(assert(0==t.flags,"void type expected"),e=s.drop(e)):r.is(4)&&t.is(8)?e=11==t.kind?r.is(64)?s.unary(r.is(1)?l.UnaryOp.ConvertI64ToF32:l.UnaryOp.ConvertU64ToF32,e):s.unary(r.is(1)?l.UnaryOp.ConvertI32ToF32:l.UnaryOp.ConvertU32ToF32,e):r.is(64)?s.unary(r.is(1)?l.UnaryOp.ConvertI64ToF64:l.UnaryOp.ConvertU64ToF64,e):s.unary(r.is(1)?l.UnaryOp.ConvertI32ToF64:l.UnaryOp.ConvertU32ToF64,e):r.is(64)?t==m.Type.bool?(e=s.binary(l.BinaryOp.NeI64,e,s.i64(0)),i=!1):t.is(64)||(e=s.unary(l.UnaryOp.WrapI64,e)):t.is(64)?(e=s.unary(r.is(1)?l.UnaryOp.ExtendI32:l.UnaryOp.ExtendU32,this.ensureSmallIntegerWrap(e,r)),i=!1):r.is(32)&&r.size",i.toString(),s.toString()),this.currentType=r,y.unreachable();switch(n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T),o.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.GtI32,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.GtI64:l.BinaryOp.GtI32,n,a);break;case 3:h=y.binary(l.BinaryOp.GtI64,n,a);break;case 5:case 6:case 7:case 10:h=y.binary(l.BinaryOp.GtU32,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.GtU64:l.BinaryOp.GtU32,n,a);break;case 8:h=y.binary(l.BinaryOp.GtU64,n,a);break;case 11:h=y.binary(l.BinaryOp.GtF32,n,a);break;case 12:h=y.binary(l.BinaryOp.GtF64,n,a);break;default:assert(!1),h=y.unreachable()}this.currentType=m.Type.bool;break;case d.Token.LESSTHAN_EQUALS:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.LE)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!0)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"<=",i.toString(),s.toString()),this.currentType=r,y.unreachable();switch(n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T),o.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.LeI32,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.LeI64:l.BinaryOp.LeI32,n,a);break;case 3:h=y.binary(l.BinaryOp.LeI64,n,a);break;case 5:case 6:case 7:case 10:h=y.binary(l.BinaryOp.LeU32,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.LeU64:l.BinaryOp.LeU32,n,a);break;case 8:h=y.binary(l.BinaryOp.LeU64,n,a);break;case 11:h=y.binary(l.BinaryOp.LeF32,n,a);break;case 12:h=y.binary(l.BinaryOp.LeF64,n,a);break;default:assert(!1),h=y.unreachable()}this.currentType=m.Type.bool;break;case d.Token.GREATERTHAN_EQUALS:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.GE)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!0)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,">=",i.toString(),s.toString()),this.currentType=r,y.unreachable();switch(n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T),o.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.GeI32,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.GeI64:l.BinaryOp.GeI32,n,a);break;case 3:h=y.binary(l.BinaryOp.GeI64,n,a);break;case 5:case 6:case 7:case 10:h=y.binary(l.BinaryOp.GeU32,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.GeU64:l.BinaryOp.GeU32,n,a);break;case 8:h=y.binary(l.BinaryOp.GeU64,n,a);break;case 11:h=y.binary(l.BinaryOp.GeF32,n,a);break;case 12:h=y.binary(l.BinaryOp.GeF64,n,a);break;default:assert(!1),h=y.unreachable()}this.currentType=m.Type.bool;break;case d.Token.EQUALS_EQUALS_EQUALS:case d.Token.EQUALS_EQUALS:if(n=this.compileExpression(f,r),i=this.currentType,E==d.Token.EQUALS_EQUALS&&this.currentType.is(256))if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.EQ)){h=this.compileBinaryOverload(A,f,n,T,e);break}if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,d.operatorTokenToString(e.operator),i.toString(),s.toString()),this.currentType=r,y.unreachable();switch(n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T),o.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:h=y.binary(l.BinaryOp.EqI32,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.EqI64:l.BinaryOp.EqI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.EqI64,n,a);break;case 11:h=y.binary(l.BinaryOp.EqF32,n,a);break;case 12:h=y.binary(l.BinaryOp.EqF64,n,a);break;case 13:h=y.unary(l.UnaryOp.AllTrueVecI8x16,y.binary(l.BinaryOp.EqVecI8x16,n,a));break;default:assert(!1),h=y.unreachable()}this.currentType=m.Type.bool;break;case d.Token.EXCLAMATION_EQUALS_EQUALS:case d.Token.EXCLAMATION_EQUALS:if(n=this.compileExpression(f,r),i=this.currentType,E==d.Token.EXCLAMATION_EQUALS&&this.currentType.is(256))if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.NE)){h=this.compileBinaryOverload(A,f,n,T,e);break}if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,d.operatorTokenToString(e.operator),i.toString(),s.toString()),this.currentType=r,y.unreachable();switch(n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T),o.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:h=y.binary(l.BinaryOp.NeI32,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.NeI64:l.BinaryOp.NeI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.NeI64,n,a);break;case 11:h=y.binary(l.BinaryOp.NeF32,n,a);break;case 12:h=y.binary(l.BinaryOp.NeF64,n,a);break;case 13:h=y.unary(l.UnaryOp.AnyTrueVecI8x16,y.binary(l.BinaryOp.NeVecI8x16,n,a));break;default:assert(!1),h=y.unreachable()}this.currentType=m.Type.bool;break;case d.Token.EQUALS:return this.compileAssignment(f,T,r);case d.Token.PLUS_EQUALS:g=!0;case d.Token.PLUS:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.ADD)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)a=this.compileExpression(T,i,1);else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"+",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 5:case 6:case 10:case 2:case 7:h=y.binary(l.BinaryOp.AddI32,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.AddI64:l.BinaryOp.AddI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.AddI64,n,a);break;case 11:h=y.binary(l.BinaryOp.AddF32,n,a);break;case 12:h=y.binary(l.BinaryOp.AddF64,n,a);break;default:assert(!1),h=y.unreachable()}break;case d.Token.MINUS_EQUALS:g=!0;case d.Token.MINUS:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.SUB)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"-",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 5:case 6:case 10:case 2:case 7:h=y.binary(l.BinaryOp.SubI32,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.SubI64:l.BinaryOp.SubI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.SubI64,n,a);break;case 11:h=y.binary(l.BinaryOp.SubF32,n,a);break;case 12:h=y.binary(l.BinaryOp.SubF64,n,a);break;default:assert(!1),h=y.unreachable()}break;case d.Token.ASTERISK_EQUALS:g=!0;case d.Token.ASTERISK:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.MUL)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)n=this.ensureSmallIntegerWrap(n,i),a=this.compileExpression(T,i,1);else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"*",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 5:case 6:case 10:case 2:case 7:h=y.binary(l.BinaryOp.MulI32,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.MulI64:l.BinaryOp.MulI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.MulI64,n,a);break;case 11:h=y.binary(l.BinaryOp.MulF32,n,a);break;case 12:h=y.binary(l.BinaryOp.MulF64,n,a);break;default:assert(!1),h=y.unreachable()}break;case d.Token.ASTERISK_ASTERISK_EQUALS:g=!0;case d.Token.ASTERISK_ASTERISK:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.POW)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}var v=void 0;if(11==this.currentType.kind){if(a=this.compileExpression(T,m.Type.f32,1),s=this.currentType,!(v=this.f32PowInstance)){if(!(b=this.program.lookupGlobal(u.CommonSymbols.Mathf))){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Mathf"),h=y.unreachable();break}if(!(I=b.members?b.members.get(u.CommonSymbols.pow):null)){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Mathf.pow"),h=y.unreachable();break}assert(I.kind==p.ElementKind.FUNCTION_PROTOTYPE),this.f32PowInstance=v=this.resolver.resolveFunction(I,null)}}else if(n=this.convertExpression(n,this.currentType,m.Type.f64,!1,!1,f),i=this.currentType,a=this.compileExpression(T,m.Type.f64,1),s=this.currentType,!(v=this.f64PowInstance)){if(!(b=this.program.lookupGlobal(u.CommonSymbols.Math))){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Math"),h=y.unreachable();break}if(!(I=b.members?b.members.get(u.CommonSymbols.pow):null)){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Math.pow"),h=y.unreachable();break}assert(I.kind==p.ElementKind.FUNCTION_PROTOTYPE),this.f64PowInstance=v=this.resolver.resolveFunction(I,null)}h=v&&this.compileFunction(v)?this.makeCallDirect(v,[n,a],e):y.unreachable();break;case d.Token.SLASH_EQUALS:g=!0;case d.Token.SLASH:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.DIV)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)n=this.ensureSmallIntegerWrap(n,i),a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"/",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T)}switch(this.currentType.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.DivI32,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.DivI64:l.BinaryOp.DivI32,n,a);break;case 3:h=y.binary(l.BinaryOp.DivI64,n,a);break;case 5:case 6:case 10:case 7:h=y.binary(l.BinaryOp.DivU32,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.DivU64:l.BinaryOp.DivU32,n,a);break;case 8:h=y.binary(l.BinaryOp.DivU64,n,a);break;case 11:h=y.binary(l.BinaryOp.DivF32,n,a);break;case 12:h=y.binary(l.BinaryOp.DivF64,n,a);break;default:assert(!1),h=y.unreachable()}break;case d.Token.PERCENT_EQUALS:g=!0;case d.Token.PERCENT:if(n=this.compileExpression(f,r),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.REM)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)n=this.ensureSmallIntegerWrap(n,i),a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"%",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!0,f),a=this.convertExpression(a,s,s=o,!1,!0,T)}switch(this.currentType.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.RemI32,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.RemI64:l.BinaryOp.RemI32,n,a);break;case 3:h=y.binary(l.BinaryOp.RemI64,n,a);break;case 5:case 6:case 10:case 7:h=y.binary(l.BinaryOp.RemU32,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.RemU64:l.BinaryOp.RemU32,n,a);break;case 8:h=y.binary(l.BinaryOp.RemU64,n,a);break;case 11:if(!(v=this.f32ModInstance)){if(!(b=this.program.lookupGlobal(u.CommonSymbols.Mathf))){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Mathf"),h=y.unreachable();break}if(!(I=b.members?b.members.get(u.CommonSymbols.mod):null)){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Mathf.mod"),h=y.unreachable();break}assert(I.kind==p.ElementKind.FUNCTION_PROTOTYPE),this.f32ModInstance=v=this.resolver.resolveFunction(I,null)}h=v&&this.compileFunction(v)?this.makeCallDirect(v,[n,a],e):y.unreachable();break;case 12:if(!(v=this.f64ModInstance)){var b,I;if(!(b=this.program.lookupGlobal(u.CommonSymbols.Math))){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Math"),h=y.unreachable();break}if(!(I=b.members?b.members.get(u.CommonSymbols.mod):null)){this.error(c.DiagnosticCode.Cannot_find_name_0,e.range,"Math.mod"),h=y.unreachable();break}assert(I.kind==p.ElementKind.FUNCTION_PROTOTYPE),this.f64ModInstance=v=this.resolver.resolveFunction(I,null)}h=v&&this.compileFunction(v)?this.makeCallDirect(v,[n,a],e):y.unreachable();break;default:assert(!1),h=y.unreachable()}break;case d.Token.LESSTHAN_LESSTHAN_EQUALS:g=!0;case d.Token.LESSTHAN_LESSTHAN:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_SHL)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}switch(a=this.compileExpression(T,i,1),s=this.currentType,this.currentType.kind){case 0:case 1:case 5:case 6:case 10:case 2:case 7:h=y.binary(l.BinaryOp.ShlI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.ShlI64,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.ShlI64:l.BinaryOp.ShlI32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.GREATERTHAN_GREATERTHAN_EQUALS:g=!0;case d.Token.GREATERTHAN_GREATERTHAN:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_SHR)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}switch(n=this.ensureSmallIntegerWrap(n,i),a=this.compileExpression(T,i,1),s=this.currentType,this.currentType.kind){case 0:case 1:case 2:h=y.binary(l.BinaryOp.ShrI32,n,a);break;case 3:h=y.binary(l.BinaryOp.ShrI64,n,a);break;case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.ShrI64:l.BinaryOp.ShrI32,n,a);break;case 5:case 6:case 10:case 7:h=y.binary(l.BinaryOp.ShrU32,n,a);break;case 8:h=y.binary(l.BinaryOp.ShrU64,n,a);break;case 9:h=y.binary(this.options.isWasm64?l.BinaryOp.ShrU64:l.BinaryOp.ShrU32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:g=!0;case d.Token.GREATERTHAN_GREATERTHAN_GREATERTHAN:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_SHR_U)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}switch(n=this.ensureSmallIntegerWrap(n,i),a=this.compileExpression(T,i,1),s=this.currentType,this.currentType.kind){case 5:case 6:case 10:h=y.binary(l.BinaryOp.ShrU32,n,a);case 0:case 1:case 2:case 7:h=y.binary(l.BinaryOp.ShrU32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.ShrU64,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.ShrU64:l.BinaryOp.ShrU32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.AMPERSAND_EQUALS:g=!0;case d.Token.AMPERSAND:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_AND)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"&",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 10:case 7:h=y.binary(l.BinaryOp.AndI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.AndI64,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.AndI64:l.BinaryOp.AndI32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.BAR_EQUALS:g=!0;case d.Token.BAR:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_OR)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"|",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 5:case 6:case 10:h=y.binary(l.BinaryOp.OrI32,n,a);break;case 2:case 7:h=y.binary(l.BinaryOp.OrI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.OrI64,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.OrI64:l.BinaryOp.OrI32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.CARET_EQUALS:g=!0;case d.Token.CARET:if(n=this.compileExpression(f,r.intType),i=this.currentType,this.currentType.is(256)){var x,A;if(x=i.classReference)if(A=x.lookupOverload(p.OperatorKind.BITWISE_XOR)){h=this.compileBinaryOverload(A,f,n,T,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}if(g)a=this.compileExpression(T,i,1),s=this.currentType;else{if(a=this.compileExpression(T,i),s=this.currentType,!(o=m.Type.commonDenominator(i,s,!1)))return this.error(c.DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,e.range,"^",i.toString(),s.toString()),this.currentType=r,y.unreachable();n=this.convertExpression(n,i,i=o,!1,!1,f),a=this.convertExpression(a,s,s=o,!1,!1,T)}switch(this.currentType.kind){case 0:case 1:case 5:case 6:case 10:h=y.binary(l.BinaryOp.XorI32,n,a);break;case 2:case 7:h=y.binary(l.BinaryOp.XorI32,n,a);break;case 3:case 8:h=y.binary(l.BinaryOp.XorI64,n,a);break;case 9:case 4:h=y.binary(this.options.isWasm64?l.BinaryOp.XorI64:l.BinaryOp.XorI32,n,a);break;case 11:case 12:return this.error(c.DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,e.range,d.operatorTokenToString(e.operator),this.currentType.toString()),y.unreachable();default:assert(!1),h=y.unreachable()}break;case d.Token.AMPERSAND_AMPERSAND:var N=this.currentFlow,S=20&t;n=this.compileExpression(f,r.exceptVoid,S),i=this.currentType;var O=N.fork();if(this.currentFlow=O,O.inheritNonnullIfTrue(n),a=this.compileExpression(T,i,1|S),s=i,r==m.Type.bool||r==m.Type.void)a=this.performAutoreleasesWithValue(O,a,s),O.freeScopedLocals(),this.currentFlow=N,this.currentType=m.Type.bool,h=y.if(this.makeIsTrueish(n,i),this.makeIsTrueish(a,s),y.i32(0));else if(i.isManaged){var C=this.skippedAutoreleases.has(n),k=this.skippedAutoreleases.has(a),L=N.getTempLocal(i);n=y.local_tee(L.index,n);var R=!1;C!=k?C?(a=this.makeRetain(a),k=!0):R=!0:16&t||(a=this.moveAutorelease(a,O,N));var F=new Array;C&&F.unshift(this.makeRelease(y.local_get(L.index,i.toNativeType()))),a=this.performAutoreleasesWithValue(O,a,s,F),O.freeScopedLocals(),this.currentFlow=N,h=y.if(this.makeIsTrueish(n,i),a,R?this.makeRetain(y.local_get(L.index,i.toNativeType())):y.local_get(L.index,i.toNativeType())),(C||k)&&this.skippedAutoreleases.add(h),L&&N.freeTempLocal(L)}else if(a=this.performAutoreleasesWithValue(O,a,s),O.freeScopedLocals(),this.currentFlow=N,h=y.cloneExpression(n,!0,0))h=y.if(this.makeIsTrueish(n,this.currentType),a,h);else{var B=N.getTempLocal(i);N.canOverflow(n,i)||N.setLocalFlag(B.index,_.LocalFlags.WRAPPED),N.isNonnull(n,i)&&N.setLocalFlag(B.index,_.LocalFlags.NONNULL),h=y.if(this.makeIsTrueish(y.local_tee(B.index,n),i),a,y.local_get(B.index,i.toNativeType()))}this.currentType=i;break;case d.Token.BAR_BAR:N=this.currentFlow,S=20&t;n=this.compileExpression(f,r.exceptVoid,S),i=this.currentType;O=N.fork();if(this.currentFlow=O,O.inheritNonnullIfFalse(n),a=this.compileExpression(T,i,1|S),s=i,r==m.Type.bool||r==m.Type.void)a=this.performAutoreleasesWithValue(O,a,i),O.freeScopedLocals(),this.currentFlow=N,this.currentType=m.Type.bool,h=y.if(this.makeIsTrueish(n,i),y.i32(1),this.makeIsTrueish(a,s));else if(i.isManaged){C=this.skippedAutoreleases.has(n),k=this.skippedAutoreleases.has(a),L=N.getTempLocal(i);n=y.local_tee(L.index,n);var D=!1;C!=k?C?(a=this.makeRetain(a),k=!0):D=!0:16&t||(a=this.moveAutorelease(a,O,N));F=new Array;C&&F.unshift(this.makeRelease(y.local_get(L.index,i.toNativeType()))),a=this.performAutoreleasesWithValue(O,a,s,F),O.freeScopedLocals(),this.currentFlow=N,h=y.if(this.makeIsTrueish(n,i),D?this.makeRetain(y.local_get(L.index,i.toNativeType())):y.local_get(L.index,i.toNativeType()),a),(C||k)&&this.skippedAutoreleases.add(h),L&&N.freeTempLocal(L)}else if(a=this.performAutoreleasesWithValue(O,a,s),O.freeScopedLocals(),this.currentFlow=N,h=y.cloneExpression(n,!0,0))h=y.if(this.makeIsTrueish(n,i),h,a);else{B=N.getAndFreeTempLocal(i);N.canOverflow(n,i)||N.setLocalFlag(B.index,_.LocalFlags.WRAPPED),N.isNonnull(n,i)&&N.setLocalFlag(B.index,_.LocalFlags.NONNULL),h=y.if(this.makeIsTrueish(y.local_tee(B.index,n),i),y.local_get(B.index,i.toNativeType()),a)}this.currentType=i;break;default:assert(!1),h=this.module.unreachable()}if(!g)return h;var P=this.resolver,w=this.resolver.resolveExpression(f,this.currentFlow);return w?this.makeAssignment(w,h,f,P.currentThisExpression,P.currentElementExpression,r!=m.Type.void):y.unreachable()},r.prototype.compileUnaryOverload=function(e,r,t,n){return this.makeCallDirect(e,[t],n,!1)},r.prototype.compileBinaryOverload=function(e,r,t,n,i){var a;if(e.is(u.CommonFlags.INSTANCE)){var s=assert(e.parent);assert(s.kind==p.ElementKind.CLASS),a=e.signature.parameterTypes[0]}else a=e.signature.parameterTypes[1];var o=this.compileExpression(n,a,1);return this.makeCallDirect(e,[t,o],i)},r.prototype.compileAssignment=function(e,r,t){var n=this.program.resolver,i=this.currentFlow,a=n.resolveExpression(e,i);if(!a)return this.module.unreachable();var s,o=n.currentThisExpression,l=n.currentElementExpression;switch(a.kind){case p.ElementKind.GLOBAL:if(!this.compileGlobal(a))return this.module.unreachable();case p.ElementKind.FIELD:case p.ElementKind.LOCAL:s=a.type;break;case p.ElementKind.PROPERTY_PROTOTYPE:var u=a.setterPrototype;if(!u)return this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,e.range,a.internalName),this.module.unreachable();if(!(_=this.resolver.resolveFunction(u,null,f.makeMap(),h.ReportMode.REPORT)))return this.module.unreachable();assert(1==_.signature.parameterTypes.length),s=_.signature.parameterTypes[0];break;case p.ElementKind.PROPERTY:var _;if(!(_=a.setterInstance))return this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,e.range,a.internalName),this.module.unreachable();assert(1==_.signature.parameterTypes.length),s=_.signature.parameterTypes[0];break;case p.ElementKind.CLASS:if(l){var d=i.is(65536),y=a.lookupOverload(p.OperatorKind.INDEXED_SET,d);if(!y)return a.lookupOverload(p.OperatorKind.INDEXED_GET,d)?this.error(c.DiagnosticCode.Index_signature_in_type_0_only_permits_reading,e.range,a.internalName):this.error(c.DiagnosticCode.Index_signature_is_missing_in_type_0,e.range,a.internalName),this.module.unreachable();assert(2==y.signature.parameterTypes.length),s=y.signature.parameterTypes[1];break}default:return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()}return assert(s!=m.Type.void),this.makeAssignment(a,this.compileExpression(r,s,17),e,o,l,t!=m.Type.void)},r.prototype.makeAssignment=function(e,r,t,n,i,a){var s=this.module,o=this.currentFlow;switch(e.kind){case p.ElementKind.LOCAL:return o.isLocalFlag(e.index,_.LocalFlags.CONSTANT,!0)?(this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,t.range,e.internalName),this.currentType=a?e.type:m.Type.void,s.unreachable()):this.makeLocalAssignment(e,r,a);case p.ElementKind.GLOBAL:return this.compileGlobal(e)?e.isAny(u.CommonFlags.CONST|u.CommonFlags.READONLY)?(this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,t.range,e.internalName),this.currentType=a?e.type:m.Type.void,s.unreachable()):this.makeGlobalAssignment(e,r,a):s.unreachable();case p.ElementKind.FIELD:var l=e.initializerNode;return!e.is(u.CommonFlags.READONLY)||o.actualFunction.is(u.CommonFlags.CONSTRUCTOR)||l?this.makeFieldAssignment(e,r,this.compileExpression(assert(n),this.options.usizeType),a):(this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,t.range,e.internalName),s.unreachable());case p.ElementKind.PROPERTY_PROTOTYPE:this.skippedAutoreleases.has(r)&&(r=this.makeAutorelease(r,o));var d=e.setterPrototype;if(!d)return this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,t.range,e.internalName),s.unreachable();if(!(g=this.resolver.resolveFunction(d,null,f.makeMap(),h.ReportMode.REPORT)))return s.unreachable();if(!a)return this.makeCallDirect(g,[r],t);var y=assert(e.getterPrototype);if(!(v=this.resolver.resolveFunction(y,null,f.makeMap(),h.ReportMode.REPORT)))return s.unreachable();var T=(L=v.signature.returnType).toNativeType();return s.block(null,[this.makeCallDirect(g,[r],t),this.makeCallDirect(v,null,t)],T);case p.ElementKind.PROPERTY:var g;if(this.skippedAutoreleases.has(r)&&(r=this.makeAutorelease(r,o)),!(g=e.setterInstance))return this.error(c.DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,t.range,e.internalName),s.unreachable();if(!a){var E=this.compileExpression(assert(n),this.options.usizeType);return this.makeCallDirect(g,[E,r],t)}T=(L=(v=assert(e.getterInstance)).signature.returnType).toNativeType();var v,b=this.compileExpression(assert(n),this.options.usizeType),I=o.getAndFreeTempLocal(L).index;return s.block(null,[this.makeCallDirect(g,[s.local_tee(I,b),r],t),this.makeCallDirect(v,[s.local_get(I,T)],t)],T);case p.ElementKind.CLASS:if(this.skippedAutoreleases.has(r)&&(r=this.makeAutorelease(r,o)),i){var x=o.is(65536),A=e.lookupOverload(p.OperatorKind.INDEXED_GET,x);if(!A)return this.error(c.DiagnosticCode.Index_signature_is_missing_in_type_0,t.range,e.internalName),s.unreachable();var N=e.lookupOverload(p.OperatorKind.INDEXED_SET,x);if(!N)return this.error(c.DiagnosticCode.Index_signature_in_type_0_only_permits_reading,t.range,e.internalName),this.currentType=a?A.signature.returnType:m.Type.void,s.unreachable();var S=e.type,O=(b=this.compileExpression(assert(n),this.options.usizeType),this.compileExpression(i,m.Type.i32,1));if(a){var C=o.getTempLocal(S),k=o.getAndFreeTempLocal(this.currentType),L=A.signature.returnType;return o.freeTempLocal(C),s.block(null,[this.makeCallDirect(N,[s.local_tee(C.index,b),s.local_tee(k.index,O),r],t),this.makeCallDirect(A,[s.local_get(C.index,C.type.toNativeType()),s.local_get(k.index,k.type.toNativeType())],t)],L.toNativeType())}return this.makeCallDirect(N,[b,O,r],t)}}return this.error(c.DiagnosticCode.Operation_not_supported,t.range),s.unreachable()},r.prototype.makeLocalAssignment=function(e,r,t){var n=e.type;assert(n!=m.Type.void);var i=this.currentFlow,a=e.index;if(n.is(512)&&(i.isNonnull(r,n)?i.setLocalFlag(a,_.LocalFlags.NONNULL):i.unsetLocalFlag(a,_.LocalFlags.NONNULL)),i.setLocalFlag(a,_.LocalFlags.WRITTENTO),n.isManaged){var s=this.module,o=n.toNativeType();return i.isAnyLocalFlag(a,_.LocalFlags.ANY_RETAINED)?this.skippedAutoreleases.has(r)?(r=this.makeSkippedRelease(s.local_get(a,o),r),t?(this.currentType=n,s.local_tee(a,r)):(this.currentType=m.Type.void,s.local_set(a,r))):(r=this.makeRetainRelease(s.local_get(a,o),r),t?(this.currentType=n,s.local_tee(a,r)):(this.currentType=m.Type.void,s.local_set(a,r))):(i.unsetLocalFlag(a,_.LocalFlags.CONDITIONALLY_RETAINED),i.setLocalFlag(a,_.LocalFlags.RETAINED),this.skippedAutoreleases.has(r)||(r=this.makeRetain(r)),t?(this.currentType=n,s.local_tee(a,r)):(this.currentType=m.Type.void,s.local_set(a,r)))}return n.is(36)&&(i.canOverflow(r,n)?i.unsetLocalFlag(a,_.LocalFlags.WRAPPED):i.setLocalFlag(a,_.LocalFlags.WRAPPED)),t?(this.currentType=n,this.module.local_tee(a,r)):(this.currentType=m.Type.void,this.module.local_set(a,r))},r.prototype.makeGlobalAssignment=function(e,r,t){var n=this.module,i=e.type;assert(i!=m.Type.void);var a=i.toNativeType();return i.isManaged?this.skippedAutoreleases.has(r)?t?(this.currentType=i,n.block(null,[n.global_set(e.internalName,this.makeSkippedRelease(n.global_get(e.internalName,a),r)),n.global_get(e.internalName,a)],a)):(this.currentType=m.Type.void,n.global_set(e.internalName,this.makeSkippedRelease(n.global_get(e.internalName,a),r))):t?(this.currentType=i,n.block(null,[n.global_set(e.internalName,this.makeRetainRelease(n.global_get(e.internalName,a),r)),n.global_get(e.internalName,a)],a)):(this.currentType=m.Type.void,n.global_set(e.internalName,this.makeRetainRelease(n.global_get(e.internalName,a),r))):(r=this.ensureSmallIntegerWrap(r,i),t?(this.currentType=i,n.block(null,[n.global_set(e.internalName,r),n.global_get(e.internalName,a)],a)):(this.currentType=m.Type.void,n.global_set(e.internalName,r)))},r.prototype.makeFieldAssignment=function(e,r,t,n){var i=this.module,a=this.currentFlow,s=e.type,o=s.toNativeType();assert(e.parent.kind==p.ElementKind.CLASS);var c=e.parent.type,l=c.toNativeType();if(s.isManaged&&c.isManaged){var u=a.getTempLocal(c);if(this.skippedAutoreleases.has(r)){if(n){var h=a.getAndFreeTempLocal(s);return a.canOverflow(r,s)||a.setLocalFlag(h.index,_.LocalFlags.WRAPPED),a.isNonnull(r,s)&&a.setLocalFlag(h.index,_.LocalFlags.NONNULL),a.freeTempLocal(u),this.currentType=s,i.block(null,[i.store(s.byteSize,i.local_tee(u.index,t),this.makeSkippedRelease(i.load(s.byteSize,s.is(1),i.local_get(u.index,l),o,e.memoryOffset),i.local_tee(h.index,r)),o,e.memoryOffset),i.local_get(h.index,o)],o)}return a.freeTempLocal(u),this.currentType=m.Type.void,i.store(s.byteSize,i.local_tee(u.index,t),this.makeSkippedRelease(i.load(s.byteSize,s.is(1),i.local_get(u.index,l),o,e.memoryOffset),r),o,e.memoryOffset)}if(n){h=a.getAndFreeTempLocal(s);return a.canOverflow(r,s)||a.setLocalFlag(h.index,_.LocalFlags.WRAPPED),a.isNonnull(r,s)&&a.setLocalFlag(h.index,_.LocalFlags.NONNULL),a.freeTempLocal(u),this.currentType=s,i.block(null,[i.store(s.byteSize,i.local_tee(u.index,t),this.makeRetainRelease(i.load(s.byteSize,s.is(1),i.local_get(u.index,l),o,e.memoryOffset),i.local_tee(h.index,r)),o,e.memoryOffset),i.local_get(h.index,o)],o)}return a.freeTempLocal(u),this.currentType=m.Type.void,i.store(s.byteSize,i.local_tee(u.index,t),this.makeRetainRelease(i.load(s.byteSize,s.is(1),i.local_get(u.index,l),o,e.memoryOffset),r),o,e.memoryOffset)}if(n){h=a.getAndFreeTempLocal(s);return a.canOverflow(r,s)||a.setLocalFlag(h.index,_.LocalFlags.WRAPPED),a.isNonnull(r,s)&&a.setLocalFlag(h.index,_.LocalFlags.NONNULL),this.currentType=s,i.block(null,[i.store(s.byteSize,t,i.local_tee(h.index,r),o,e.memoryOffset),i.local_get(h.index,o)],o)}return this.currentType=m.Type.void,i.store(s.byteSize,t,r,o,e.memoryOffset)},r.prototype.compileCallExpression=function(e,r,t){var n=this.module,i=this.currentFlow;if(e.expression.kind==y.NodeKind.SUPER){var a=this.currentFlow,s=a.actualFunction;if(!s.is(u.CommonFlags.CONSTRUCTOR))return this.error(c.DiagnosticCode.Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors,e.range),n.unreachable();var o=assert(s.parent);assert(o.kind==p.ElementKind.CLASS);var _=assert(o.base),h=assert(a.lookupLocal(u.CommonSymbols.this_)),d=this.options.nativeSizeType,T=this.compileCallDirect(this.ensureConstructor(_,e),e.arguments,e,n.if(n.local_get(h.index,d),n.local_get(h.index,d),this.makeRetain(this.makeAllocation(o))),16);assert(this.skippedAutoreleases.has(T));var g=[n.local_set(h.index,T)];return this.makeFieldInitialization(o,g),a.isAny(16448)?(this.error(c.DiagnosticCode._super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class,e.range),n.unreachable()):(a.set(192),this.currentType=m.Type.void,n.block(null,g))}var E,v,b=this.resolver.resolveExpression(e.expression,i);if(!b)return n.unreachable();switch(b.kind){case p.ElementKind.FUNCTION_PROTOTYPE:var I=b,x=e.typeArguments;if(I.hasDecorator(p.DecoratorFlags.BUILTIN))return this.compileCallExpressionBuiltin(I,e,r);var A=null;if(x){if(!I.is(u.CommonFlags.GENERIC))return this.error(c.DiagnosticCode.Type_0_is_not_generic,e.expression.range,I.internalName),n.unreachable();A=this.resolver.resolveFunctionInclTypeArguments(I,x,i.actualFunction.parent,f.makeMap(i.contextualTypeArguments),e)}else{if(I.is(u.CommonFlags.GENERIC)){for(var N=new Map,S=assert(I.typeParameterNodes),O=S.length,C=0;Cs&&!i)||(this.error(c.DiagnosticCode.Expected_0_arguments_but_got_1,n.range,s.toString(),r.toString()),!1)},r.prototype.compileCallDirect=function(e,r,t,n,i){void 0===n&&(n=0),void 0===i&&(i=0);var a=r.length,s=e.signature;if(!this.checkCallSignature(s,a,0!=n,t))return this.currentType=s.returnType,this.module.unreachable();if(e.hasDecorator(p.DecoratorFlags.INLINE)){if(assert(!e.is(u.CommonFlags.TRAMPOLINE)),!this.currentInlineFunctions.includes(e)){this.currentInlineFunctions.push(e);var o=s.parameterTypes;assert(a<=o.length);for(var l=new Array(a),_=0;_=0;--f){var T=r[f],g=o[f],E=h.addScopedLocal(s.getParameterName(f),g,y);_.findUsedLocals(T,y),l.canOverflow(T,g)||h.setLocalFlag(E.index,_.LocalFlags.WRAPPED),h.isNonnull(T,g)&&h.setLocalFlag(E.index,_.LocalFlags.NONNULL),g.isManaged&&(this.skippedAutoreleases.has(T)||(T=this.makeRetain(T)),h.setLocalFlag(E.index,_.LocalFlags.RETAINED)),d.unshift(i.local_set(E.index,T))}if(t){var v=assert(e.parent);assert(v.kind==p.ElementKind.CLASS);var b=assert(e.signature.thisType),I=h.addScopedLocal(u.CommonSymbols.this_,b,y);d.unshift(i.local_set(I.index,t));var x=v.base;x&&h.addScopedAlias(u.CommonSymbols.super_,x.type,I.index)}else assert(!e.signature.thisType);this.currentFlow=h;for(f=a;fa){var s=t.toNativeType(),o=e.getAndFreeTempLocal(t);e.canOverflow(r,t)||e.setLocalFlag(o.index,_.LocalFlags.WRAPPED),e.isNonnull(r,t)&&e.setLocalFlag(o.index,_.LocalFlags.NONNULL);var c=this.module;return n[a-1]=c.local_set(o.index,r),n.push(c.local_get(o.index,s)),c.block(null,n,s)}return n.length>1?(n[a-1]=r,this.module.block(null,n,t.toNativeType())):r},r.prototype.finishAutoreleases=function(e,r){var t,n,i=this.module;if(e.is(32768)){for(var s=void 0;s=e.parent;)e=s;this.performAutoreleases(e,r,!1)}else try{for(var o=a(e.parentFunction.localsByIndex),c=o.next();!c.done;c=o.next()){var l=c.value,u=l.index;e.isAnyLocalFlag(u,_.LocalFlags.ANY_RETAINED)&&(e.unsetLocalFlag(u,_.LocalFlags.ANY_RETAINED),r.push(this.makeRelease(i.local_get(u,l.type.toNativeType()))))}}catch(e){t={error:e}}finally{try{c&&!c.done&&(n=o.return)&&n.call(o)}finally{if(t)throw t.error}}},r.prototype.makeCallDirect=function(e,r,t,n,i){void 0===n&&(n=!1),void 0===i&&(i=!1),e.hasDecorator(p.DecoratorFlags.INLINE)&&this.warning(c.DiagnosticCode.TODO_Cannot_inline_inferred_calls_and_specific_internals_yet,t.range,e.internalName);var a=r?r.length:0,s=a,o=e.signature.requiredParameters,l=e.signature.parameterTypes.length,_=l;e.is(u.CommonFlags.INSTANCE)&&(++o,++_,--s),assert(a>=o);var h=this.module;if(!this.compileFunction(e))return h.unreachable();var d=e.signature.returnType,f=e.is(u.CommonFlags.MODULE_IMPORT);if(a<_){r||((r=new Array(_)).length=0);var T=e.signature.parameterTypes,g=e.prototype.functionTypeNode.parameters;assert(g.length==T.length);for(var E=!0,v=s;v=s),this.ensureFunctionType(e.parameterTypes,e.returnType,e.thisType);var l=this.module;if(iT)return this.error(c.DiagnosticCode.Expected_0_arguments_but_got_1,e.range,T.toString(),h.toString()),this.module.unreachable();for(var g=new Array(h),E=0;E=0),S.is(512)&&i.isLocalFlag(O,_.LocalFlags.NONNULL,!1)&&(S=S.nonNullableType),this.currentType=S,this.module.local_get(O,S.toNativeType());case p.ElementKind.GLOBAL:if(!this.compileGlobal(N))return this.module.unreachable();S=N.type;return assert(S!=m.Type.void),N.is(u.CommonFlags.INLINED)?this.compileInlineConstant(N,r,t):(this.currentType=S,this.module.global_get(N.internalName,S.toNativeType()));case p.ElementKind.ENUMVALUE:return N.is(u.CommonFlags.COMPILED)?(this.currentType=m.Type.i32,N.is(u.CommonFlags.INLINED)?(assert(1==N.constantValueKind),this.module.i32(i64_low(N.constantIntegerValue))):this.module.global_get(N.internalName,l.NativeType.I32)):(this.error(c.DiagnosticCode.A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums,e.range),this.currentType=m.Type.i32,this.module.unreachable());case p.ElementKind.FUNCTION_PROTOTYPE:var C=this.resolver.resolveFunction(N,null,f.makeMap(i.contextualTypeArguments));if(!C||!this.compileFunction(C))return n.unreachable();var k=this.ensureFunctionTableEntry(C);return this.currentType=C.signature.type,this.module.i32(k)}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.module.unreachable()},r.prototype.compileInstanceOfExpression=function(e,r,t){var n=this.module,i=this.compileExpression(e.expression,this.options.usizeType),a=this.currentType,s=this.resolver.resolveType(e.isType,this.currentFlow.actualFunction);if(this.currentType=m.Type.bool,!s)return n.unreachable();if(!s.is(256))return n.block(null,[n.drop(i),n.i32(a==s?1:0)],l.NativeType.I32);if(!a.is(256))return n.block(null,[n.drop(i),n.i32(0)],l.NativeType.I32);var o=a.toNativeType();if(a.is(512)&&!s.is(512)){if(a.nonNullableType.isAssignableTo(s))return n.binary(o==l.NativeType.I64?l.BinaryOp.NeI64:l.BinaryOp.NeI32,i,a.toNativeZero(n));if(s.isAssignableTo(a)){var u=this.program;if(!a.isUnmanaged&&!s.isUnmanaged){var p=this.currentFlow.getAndFreeTempLocal(a),_=assert(u.instanceofInstance);return this.compileFunction(_),n.if(n.unary(o==l.NativeType.I64?l.UnaryOp.EqzI64:l.UnaryOp.EqzI32,n.local_tee(p.index,i)),n.i32(0),this.makeCallDirect(_,[n.local_get(p.index,o),n.i32(s.classReference.id)],e))}this.error(c.DiagnosticCode.Operation_not_supported,e.range)}}else{if(a.isAssignableTo(s))return n.block(null,[this.convertExpression(i,a,m.Type.void,!1,!1,e.expression),n.i32(1)],l.NativeType.I32);if(s.isAssignableTo(a)){u=this.program;if(!a.isUnmanaged&&!s.isUnmanaged){p=this.currentFlow.getAndFreeTempLocal(a),_=assert(u.instanceofInstance);return this.compileFunction(_),n.if(n.unary(o==l.NativeType.I64?l.UnaryOp.EqzI64:l.UnaryOp.EqzI32,n.local_tee(p.index,i)),n.i32(0),this.makeCallDirect(_,[n.local_get(p.index,o),n.i32(s.classReference.id)],e))}this.error(c.DiagnosticCode.Operation_not_supported,e.range)}}return n.block(null,[n.drop(i),n.i32(0)],l.NativeType.I32)},r.prototype.compileLiteralExpression=function(e,r,t,n){void 0===n&&(n=!1);var i=this.module;switch(e.literalKind){case y.LiteralKind.ARRAY:assert(!n);var a=r.classReference;return a&&a.prototype==this.program.arrayPrototype?this.compileArrayLiteral(assert(a.typeArguments)[0],e.elementExpressions,t,e):(this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable());case y.LiteralKind.FLOAT:var s=e.value;return n&&(s=-s),r==m.Type.f32?i.f32(s):(this.currentType=m.Type.f64,i.f64(s));case y.LiteralKind.INTEGER:var o=e.value;n&&(o=i64_sub(i64_new(0),o));var l=this.resolver.determineIntegerLiteralType(o,r);switch(this.currentType=l,l.kind){case 4:if(!this.options.isWasm64)return i.i32(i64_low(o));case 3:return i.i64(i64_low(o),i64_high(o));case 9:if(!this.options.isWasm64)return i.i32(i64_low(o));case 8:return i.i64(i64_low(o),i64_high(o));case 11:return i.f32(i64_to_f32(o));case 12:return i.f64(i64_to_f64(o));default:return i.i32(i64_low(o))}case y.LiteralKind.STRING:return assert(!n),this.compileStringLiteral(e);case y.LiteralKind.OBJECT:return assert(!n),this.compileObjectLiteral(e,r)}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),this.currentType=r,i.unreachable()},r.prototype.compileStringLiteral=function(e){return this.ensureStaticString(e.value)},r.prototype.compileArrayLiteral=function(e,r,t,n){for(var i=this.module,a=this.program,s=assert(a.arrayPrototype),o=assert(this.resolver.resolveClass(s,[e])),u=assert(a.arrayBufferInstance),_=o.type,h=this.currentFlow,d=h.getTempLocal(_),y=h.getTempLocal(u.type),m=r.length,f=new Array(m),T=!0,g=e.toNativeType(),E=0;E",r.toString()),t.unreachable();var i=n.constructorInstance;if(i){if(i.signature.requiredParameters)return this.error(c.DiagnosticCode.Constructor_of_class_0_must_not_require_any_arguments,e.range,n.toString()),t.unreachable();if(i.is(u.CommonFlags.PRIVATE))return this.error(c.DiagnosticCode.Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration,e.range,n.toString()),t.unreachable();if(i.is(u.CommonFlags.PROTECTED))return this.error(c.DiagnosticCode.Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration,e.range,n.toString()),t.unreachable()}var a=e.names,s=a.length,o=e.values,l=n.members,_=!1,h=new Array(s+2),d=this.currentFlow.getAutoreleaseLocal(this.options.usizeType);assert(s==o.length);for(var y=0,m=s;yI)for(T=I;T=0);var _=this.compileExpression(assert(this.resolver.currentThisExpression),this.options.usizeType);return this.currentType=a.type,n.load(a.type.byteSize,a.type.is(5),_,a.type.toNativeType(),a.memoryOffset);case p.ElementKind.PROPERTY_PROTOTYPE:var h=a.getterPrototype;if(h){var d=this.resolver.resolveFunction(h,null);if(d)return this.compileCallDirect(d,[],e,0)}return n.unreachable();case p.ElementKind.PROPERTY:var y=assert(a.getterInstance);return this.compileCallDirect(y,[],e,this.compileExpression(assert(this.resolver.currentThisExpression),this.options.usizeType));case p.ElementKind.FUNCTION_PROTOTYPE:return this.error(c.DiagnosticCode.Cannot_access_method_0_without_calling_it_as_it_requires_this_to_be_set,e.range,a.name),n.unreachable()}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),n.unreachable()},r.prototype.compileTernaryExpression=function(e,r,t){var n=e.ifThen,i=e.ifElse,a=this.currentFlow,s=this.module.precomputeExpression(this.makeIsTrueish(this.compileExpression(e.condition,m.Type.bool),this.currentType));if(l.getExpressionId(s)==l.ExpressionId.Const&&l.getExpressionType(s)==l.NativeType.I32)return l.getConstValueI32(s)?this.compileExpression(n,r):this.compileExpression(i,r);var o=16&t,u=a.fork();this.currentFlow=u;var p=this.compileExpression(n,r,o),_=this.currentType,h=this.skippedAutoreleases.has(p),d=a.fork();this.currentFlow=d;var y=this.compileExpression(i,r,o),f=this.currentType,T=this.skippedAutoreleases.has(y),g=m.Type.commonDenominator(_,f,!1);if(!g)return this.error(c.DiagnosticCode.Type_0_is_not_assignable_to_type_1,i.range,f.toString(),_.toString()),this.currentType=r,this.module.unreachable();p=this.convertExpression(p,_,g,!1,!1,n),y=this.convertExpression(y,f,g,!1,!1,i),this.currentType=g,h!=T?h?(y=this.makeRetain(y),T=!0):(p=this.makeRetain(p),h=!0):!h&&g.isManaged&&(p=this.moveAutorelease(p,u,a),y=this.moveAutorelease(y,d,a)),p=this.performAutoreleasesWithValue(u,p,g),u.freeScopedLocals(),y=this.performAutoreleasesWithValue(d,y,g),d.freeScopedLocals(),this.currentFlow=a,a.inheritMutual(u,d);var E=this.module.if(s,p,y);return assert(h==T),h&&this.skippedAutoreleases.add(E),E},r.prototype.compileUnaryPostfixExpression=function(e,r,t){var n=this.module,i=this.currentFlow,a=this.compileExpression(e.operand,r.exceptVoid,0);if(l.getExpressionId(a)==l.ExpressionId.Unreachable)return a;var s,o=null;switch(r!=m.Type.void&&(o=i.getTempLocal(this.currentType),a=n.local_tee(o.index,a)),e.operator){case d.Token.PLUS_PLUS:switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:s=n.binary(l.BinaryOp.AddI32,a,n.i32(1));break;case 9:if(this.currentType.is(256)){if(_=this.currentType.classReference)if(h=_.lookupOverload(p.OperatorKind.POSTFIX_INC)){s=this.compileUnaryOverload(h,e.operand,a,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),n.unreachable()}case 4:var u=this.options;s=n.binary(u.isWasm64?l.BinaryOp.AddI64:l.BinaryOp.AddI32,a,this.currentType.toNativeOne(n));break;case 3:case 8:s=n.binary(l.BinaryOp.AddI64,a,n.i64(1));break;case 11:s=n.binary(l.BinaryOp.AddF32,a,n.f32(1));break;case 12:s=n.binary(l.BinaryOp.AddF64,a,n.f64(1));break;default:return assert(!1),n.unreachable()}break;case d.Token.MINUS_MINUS:switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:s=n.binary(l.BinaryOp.SubI32,a,n.i32(1));break;case 9:if(this.currentType.is(256)){var _,h;if(_=this.currentType.classReference)if(h=_.lookupOverload(p.OperatorKind.POSTFIX_DEC)){s=this.compileUnaryOverload(h,e.operand,a,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),n.unreachable()}case 4:u=this.options;s=n.binary(u.isWasm64?l.BinaryOp.SubI64:l.BinaryOp.SubI32,a,this.currentType.toNativeOne(n));break;case 3:case 8:s=n.binary(l.BinaryOp.SubI64,a,n.i64(1));break;case 11:s=n.binary(l.BinaryOp.SubF32,a,n.f32(1));break;case 12:s=n.binary(l.BinaryOp.SubF64,a,n.f64(1));break;default:return assert(!1),n.unreachable()}break;default:return assert(!1),n.unreachable()}var y=this.resolver,f=y.resolveExpression(e.operand,i);if(!o)return this.currentType=m.Type.void,f?this.makeAssignment(f,s,e.operand,y.currentThisExpression,y.currentElementExpression,!1):n.unreachable();if(!f)return n.unreachable();var T=this.makeAssignment(f,s,e.operand,y.currentThisExpression,y.currentElementExpression,!1);this.currentType=o.type,i.freeTempLocal(o);var g=o.type.toNativeType();return n.block(null,[T,n.local_get(o.index,g)],g)},r.prototype.compileUnaryPrefixExpression=function(e,r,t){var n,i=this.module,a=!1;switch(e.operator){case d.Token.PLUS:if(n=this.compileExpression(e.operand,r.exceptVoid,0),this.currentType.is(256)){if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.PLUS)){n=this.compileUnaryOverload(o,e.operand,n,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable()}break;case d.Token.MINUS:if(e.operand.kind==y.NodeKind.LITERAL&&(e.operand.literalKind==y.LiteralKind.INTEGER||e.operand.literalKind==y.LiteralKind.FLOAT)){n=this.compileLiteralExpression(e.operand,r,0,!0),this.options.sourceMap&&this.addDebugLocation(n,e.range);break}if(n=this.compileExpression(e.operand,r.exceptVoid,0),this.currentType.is(256)){if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.MINUS)){n=this.compileUnaryOverload(o,e.operand,n,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable()}switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:n=i.binary(l.BinaryOp.SubI32,i.i32(0),n);break;case 9:case 4:n=i.binary(this.options.isWasm64?l.BinaryOp.SubI64:l.BinaryOp.SubI32,this.currentType.toNativeZero(i),n);break;case 3:case 8:n=i.binary(l.BinaryOp.SubI64,i.i64(0),n);break;case 11:n=i.unary(l.UnaryOp.NegF32,n);break;case 12:n=i.unary(l.UnaryOp.NegF64,n);break;default:assert(!1),n=i.unreachable()}break;case d.Token.PLUS_PLUS:if(a=!0,n=this.compileExpression(e.operand,r.exceptVoid,0),this.currentType.is(256)){if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.PREFIX_INC)){n=this.compileUnaryOverload(o,e.operand,n,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable()}switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:n=i.binary(l.BinaryOp.AddI32,n,this.module.i32(1));break;case 9:case 4:n=i.binary(this.options.isWasm64?l.BinaryOp.AddI64:l.BinaryOp.AddI32,n,this.currentType.toNativeOne(i));break;case 3:case 8:n=i.binary(l.BinaryOp.AddI64,n,i.i64(1));break;case 11:n=i.binary(l.BinaryOp.AddF32,n,i.f32(1));break;case 12:n=i.binary(l.BinaryOp.AddF64,n,i.f64(1));break;default:assert(!1),n=i.unreachable()}break;case d.Token.MINUS_MINUS:if(a=!0,n=this.compileExpression(e.operand,r.exceptVoid,0),this.currentType.is(256)){if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.PREFIX_DEC)){n=this.compileUnaryOverload(o,e.operand,n,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable()}switch(this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:n=i.binary(l.BinaryOp.SubI32,n,i.i32(1));break;case 9:case 4:n=i.binary(this.options.isWasm64?l.BinaryOp.SubI64:l.BinaryOp.SubI32,n,this.currentType.toNativeOne(i));break;case 3:case 8:n=i.binary(l.BinaryOp.SubI64,n,i.i64(1));break;case 11:n=i.binary(l.BinaryOp.SubF32,n,i.f32(1));break;case 12:n=i.binary(l.BinaryOp.SubF64,n,i.f64(1));break;default:assert(!1),n=i.unreachable()}break;case d.Token.EXCLAMATION:if(n=this.compileExpression(e.operand,r.exceptVoid,0),this.currentType.is(256))if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.NOT)){n=this.compileUnaryOverload(o,e.operand,n,e);break}n=this.makeIsFalseish(n,this.currentType),this.currentType=m.Type.bool;break;case d.Token.TILDE:if(n=this.compileExpression(e.operand,r==m.Type.void?m.Type.i32:r.is(8)?m.Type.i64:r,0),this.currentType.is(256)){var s,o;if(s=this.currentType.classReference)if(o=s.lookupOverload(p.OperatorKind.BITWISE_NOT)){n=this.compileUnaryOverload(o,e.operand,n,e);break}return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable()}switch(n=this.convertExpression(n,this.currentType,this.currentType.intType,!1,!1,e.operand),this.currentType.kind){case 0:case 1:case 2:case 5:case 6:case 7:case 10:n=i.binary(l.BinaryOp.XorI32,n,i.i32(-1));break;case 9:case 4:n=i.binary(this.options.isWasm64?l.BinaryOp.XorI64:l.BinaryOp.XorI32,n,this.currentType.toNativeNegOne(i));break;case 3:case 8:n=i.binary(l.BinaryOp.XorI64,n,i.i64(-1,-1));break;default:assert(!1),n=i.unreachable()}break;case d.Token.TYPEOF:return this.error(c.DiagnosticCode.Operation_not_supported,e.range),i.unreachable();default:return assert(!1),i.unreachable()}if(!a)return n;var u=this.resolver,_=u.resolveExpression(e.operand,this.currentFlow);return _?this.makeAssignment(_,n,e.operand,u.currentThisExpression,u.currentElementExpression,r!=m.Type.void):i.unreachable()},r.prototype.ensureSmallIntegerWrap=function(e,r){var t=this.module,n=this.currentFlow;switch(r.kind){case 0:n.canOverflow(e,r)&&(e=this.options.hasFeature(1)?t.unary(l.UnaryOp.ExtendI8ToI32,e):t.binary(l.BinaryOp.ShrI32,t.binary(l.BinaryOp.ShlI32,e,t.i32(24)),t.i32(24)));break;case 1:n.canOverflow(e,r)&&(e=this.options.hasFeature(1)?t.unary(l.UnaryOp.ExtendI16ToI32,e):t.binary(l.BinaryOp.ShrI32,t.binary(l.BinaryOp.ShlI32,e,t.i32(16)),t.i32(16)));break;case 5:n.canOverflow(e,r)&&(e=t.binary(l.BinaryOp.AndI32,e,t.i32(255)));break;case 6:n.canOverflow(e,r)&&(e=t.binary(l.BinaryOp.AndI32,e,t.i32(65535)));break;case 10:n.canOverflow(e,r)&&(e=t.binary(l.BinaryOp.NeI32,e,t.i32(0)))}return e},r.prototype.addDebugLocation=function(e,r){var t=this.currentFlow.parentFunction,n=r.source;n.debugInfoIndex<0&&(n.debugInfoIndex=this.module.addDebugInfoFile(n.normalizedPath)),r.debugInfoRef=e,t.debugLocations.push(r)},r.prototype.makeIsFalseish=function(e,r){var t=this.module;switch(r.kind){case 0:case 1:case 5:case 6:case 10:e=this.ensureSmallIntegerWrap(e,r);case 2:case 7:return t.unary(l.UnaryOp.EqzI32,e);case 3:case 8:return t.unary(l.UnaryOp.EqzI64,e);case 9:this.skippedAutoreleases.has(e)&&(e=this.makeAutorelease(e));case 4:return t.unary(64==r.size?l.UnaryOp.EqzI64:l.UnaryOp.EqzI32,e);case 11:return t.binary(l.BinaryOp.EqF32,e,t.f32(0));case 12:return t.binary(l.BinaryOp.EqF64,e,t.f64(0));default:return assert(!1),t.i32(1)}},r.prototype.makeIsTrueish=function(e,r){var t=this.module;switch(r.kind){case 0:case 1:case 5:case 6:e=this.ensureSmallIntegerWrap(e,r);case 10:case 2:case 7:return e;case 3:case 8:return t.binary(l.BinaryOp.NeI64,e,t.i64(0));case 9:this.skippedAutoreleases.has(e)&&(e=this.makeAutorelease(e));case 4:return 64==r.size?t.binary(l.BinaryOp.NeI64,e,t.i64(0)):e;case 11:return t.binary(l.BinaryOp.NeF32,e,t.f32(0));case 12:return t.binary(l.BinaryOp.NeF64,e,t.f64(0));default:return assert(!1),t.i32(0)}},r.prototype.makeAllocation=function(e){var r=this.program;assert(e.program==r);var t=this.module,n=this.options;this.currentType=e.type;var i=r.allocInstance;return this.compileFunction(i),t.call(i.internalName,[n.isWasm64?t.i64(e.currentMemoryOffset):t.i32(e.currentMemoryOffset),t.i32(e.hasDecorator(p.DecoratorFlags.UNMANAGED)?0:e.id)],n.nativeSizeType)},r.prototype.makeFieldInitialization=function(e,r){var t,n;void 0===r&&(r=[]);var i=e.members;if(!i)return[];var s=this.module,o=this.currentFlow,c=o.is(32768),l=c?assert(o.lookupLocal(u.CommonSymbols.this_)).index:0,_=this.options.nativeSizeType;try{for(var h=a(i.values()),d=h.next();!d.done;d=h.next()){var y=d.value;if(y.kind==p.ElementKind.FIELD&&y.parent==e){var m=y;assert(!m.isAny(u.CommonFlags.CONST));var f=m.type,T=f.toNativeType(),g=m.prototype.initializerNode;if(g){var E=this.compileExpression(g,f,17);f.isManaged&&!this.skippedAutoreleases.has(E)&&(E=this.makeRetain(E)),r.push(s.store(f.byteSize,s.local_get(l,_),E,T,m.memoryOffset))}else{var v=m.prototype.parameterIndex;r.push(s.store(f.byteSize,s.local_get(l,_),v>=0?s.local_get(c?assert(o.lookupLocal(m.name)).index:1+v,T):f.toNativeZero(s),T,m.memoryOffset))}}}}catch(e){t={error:e}}finally{try{d&&!d.done&&(n=h.return)&&n.call(h)}finally{if(t)throw t.error}}return r},r.prototype.makeInstanceOfClass=function(e,r){var t=this.module,n=this.currentFlow,i=n.getTempLocal(m.Type.i32),a=t.load(4,!1,t.binary(l.BinaryOp.SubI32,e,t.i32(this.program.runtimeHeaderSize)),l.NativeType.I32),s="instanceof_"+r.name+"|"+n.pushBreakLabel(),o=[];return o.push(t.drop(t.br(s,t.binary(l.BinaryOp.EqI32,t.local_tee(i.index,a),t.i32(r.id)),t.i32(1)))),o.push(t.i32(0)),n.freeTempLocal(i),n.popBreakLabel(),t.block(s,o,l.NativeType.I32)},r}(c.DiagnosticEmitter);function b(e,r){if(g=r.range.source.simplePath,E=p.mangleInternalName(e.name,e.parent,e.is(u.CommonFlags.INSTANCE),!0),e.hasDecorator(p.DecoratorFlags.EXTERNAL)){var t=e.program,n=assert(y.findDecorator(y.DecoratorKind.EXTERNAL,r.decorators)),i=n.arguments;if(i&&i.length){var a=i[0];a.kind==y.NodeKind.LITERAL&&a.literalKind==y.LiteralKind.STRING?(E=a.value,i.length>=2&&((a=i[1]).kind==y.NodeKind.LITERAL&&a.literalKind==y.LiteralKind.STRING?(g=E,E=a.value,i.length>2&&t.error(c.DiagnosticCode.Expected_0_arguments_but_got_1,n.range,"2",i.length.toString())):t.error(c.DiagnosticCode.String_literal_expected,a.range))):t.error(c.DiagnosticCode.String_literal_expected,a.range)}else t.error(c.DiagnosticCode.Expected_at_least_0_arguments_but_got_1,n.range,"1","0")}}function I(e,r,t){var n=r.length;if(0==n)return e.nop();if(1==n){var i=r[0];if(l.getExpressionType(i)==t)return i;if(l.getExpressionId(i)==l.ExpressionId.Block){for(var a=l.getBlockChildCount(i),s=new Array(a),o=0;o=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},i=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0});var a,s=t(11),o=t(2),c=t(5),l=t(6),u=t(4),p=t(3),_=t(10),h=t(9),d=t(0),y=t(1);function m(e,r,t,n,i,s,d){void 0===d&&(d=!1);var m=e.module,g=!1;switch(r.internalName){case a.isInteger:var S=E(e,t,n,s);return e.currentType=l.Type.bool,S?S.is(4)&&!S.is(256)?m.i32(1):m.i32(0):m.unreachable();case a.isFloat:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?S.is(8)?m.i32(1):m.i32(0):m.unreachable();case a.isBoolean:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?S==l.Type.bool?m.i32(1):m.i32(0):m.unreachable();case a.isSigned:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?S.is(1)?m.i32(1):m.i32(0):m.unreachable();case a.isReference:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?S.is(256)?m.i32(1):m.i32(0):m.unreachable();case a.isString:S=E(e,t,n,s);if(e.currentType=l.Type.bool,!S)return m.unreachable();if(B=S.classReference){var O=e.program.stringInstance;if(O&&B.isAssignableTo(O))return m.i32(1)}return m.i32(0);case a.isArray:S=E(e,t,n,s);if(e.currentType=l.Type.bool,!S)return m.unreachable();if(!(De=S.classReference))return m.i32(0);var C=De.prototype;return m.i32(C.extends(e.program.arrayPrototype)?1:0);case a.isArrayLike:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?(De=S.classReference)?m.i32(De.isArrayLike?1:0):m.i32(0):m.unreachable();case a.isFunction:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?m.i32(S.signatureReference?1:0):m.unreachable();case a.isNullable:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?m.i32(S.is(512)?1:0):m.unreachable();case a.isDefined:if(e.currentType=l.Type.bool,x(t,s,r)|A(n,1,s,e))return m.unreachable();var k=e.resolver.resolveExpression(n[0],e.currentFlow,l.Type.void,h.ReportMode.SWALLOW);return m.i32(k?1:0);case a.isConstant:if(e.currentType=l.Type.bool,x(t,s,r)|A(n,1,s,e))return m.unreachable();var L=e.compileExpression(n[0],l.Type.auto);return e.currentType=l.Type.bool,m.i32(u.getExpressionId(L)==u.ExpressionId.Const?1:0);case a.isManaged:S=E(e,t,n,s);return e.currentType=l.Type.bool,S?m.i32(S.isManaged?1:0):m.unreachable();case a.sizeof:if(e.currentType=e.options.usizeType,b(t,s,e)|A(n,0,s,e))return m.unreachable();var R=t[0].byteSize,L=void 0;return e.options.isWasm64?i.is(4)&&i.size<=32?(e.currentType=l.Type.u32,L=m.i32(R)):L=m.i64(R,0):i.is(4)&&64==i.size?(e.currentType=l.Type.u64,L=m.i64(R,0)):L=m.i32(R),L;case a.alignof:if(e.currentType=e.options.usizeType,b(t,s,e)|A(n,0,s,e))return m.unreachable();R=t[0].byteSize;assert(y.isPowerOf2(R));var F=ctz(R);L=void 0;return e.options.isWasm64?i.is(4)&&i.size<=32?(e.currentType=l.Type.u32,L=m.i32(F)):L=m.i64(F,0):i.is(4)&&64==i.size?(e.currentType=l.Type.u64,L=m.i64(F,0)):L=m.i32(F),L;case a.offsetof:if(e.currentType=e.options.usizeType,b(t,s,e)|N(n,0,1,s,e))return m.unreachable();var B;if(!(B=t[0].classReference))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();var D=void 0;if(n.length){if(n[0].kind!=c.NodeKind.LITERAL||n[0].literalKind!=c.LiteralKind.STRING)return e.error(o.DiagnosticCode.String_literal_expected,n[0].range),m.unreachable();var P=n[0].value,w=B.members?B.members.get(P):null;if(!w||w.kind!=p.ElementKind.FIELD)return e.error(o.DiagnosticCode.Type_0_has_no_property_1,n[0].range,B.internalName,P),m.unreachable();D=w.memoryOffset}else D=B.currentMemoryOffset;return e.options.isWasm64?i.is(4)&&i.size<=32?(e.currentType=l.Type.u32,m.i32(D)):m.i64(D):i.is(4)&&64==i.size?(e.currentType=l.Type.u64,m.i64(D)):m.i32(D);case a.clz:case a.ctz:case a.popcnt:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();var U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.i32,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();var M=-1;switch(r.internalName){case a.clz:switch(S.kind){case 10:case 0:case 5:case 1:case 6:case 2:case 7:M=u.UnaryOp.ClzI32;break;case 9:case 4:M=e.options.isWasm64?u.UnaryOp.ClzI64:u.UnaryOp.ClzI32;break;case 3:case 8:M=u.UnaryOp.ClzI64}break;case a.ctz:switch(S.kind){case 10:case 0:case 5:case 1:case 6:case 2:case 7:M=u.UnaryOp.CtzI32;break;case 9:case 4:M=e.options.isWasm64?u.UnaryOp.CtzI64:u.UnaryOp.CtzI32;break;case 3:case 8:M=u.UnaryOp.CtzI64}break;case a.popcnt:switch(e.currentType.kind){case 10:case 0:case 5:case 1:case 6:case 2:case 7:M=u.UnaryOp.PopcntI32;break;case 9:case 4:M=e.options.isWasm64?u.UnaryOp.PopcntI64:u.UnaryOp.PopcntI32;break;case 3:case 8:M=u.UnaryOp.PopcntI64}}return-1==M?(e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable()):m.unary(M,U);case a.rotl:if(I(t,s,e,!0)|A(n,2,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.i32,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();var V=e.compileExpression(n[1],S,1);L=void 0;switch(S.kind){case 0:case 1:case 5:case 6:case 10:L=e.ensureSmallIntegerWrap(m.binary(u.BinaryOp.RotlI32,U,V),S);case 2:case 7:L=m.binary(u.BinaryOp.RotlI32,U,V);break;case 9:case 4:L=m.binary(e.options.isWasm64?u.BinaryOp.RotlI64:u.BinaryOp.RotlI32,U,V);break;case 3:case 8:L=m.binary(u.BinaryOp.RotlI64,U,V);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.rotr:if(I(t,s,e,!0)|A(n,2,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.i32,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();V=e.compileExpression(n[1],S,1),L=void 0;switch(S.kind){case 0:case 1:case 5:case 6:case 10:L=e.ensureSmallIntegerWrap(m.binary(u.BinaryOp.RotrI32,U,V),S);break;case 2:case 7:L=m.binary(u.BinaryOp.RotrI32,U,V);break;case 9:case 4:L=m.binary(e.options.isWasm64?u.BinaryOp.RotrI64:u.BinaryOp.RotrI32,U,V);break;case 3:case 8:L=m.binary(u.BinaryOp.RotrI64,U,V);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.abs:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.f64,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();L=void 0;switch(S.kind){case 0:case 1:case 2:var G=(H=e.currentFlow).getTempLocal(l.Type.i32),K=H.getAndFreeTempLocal(l.Type.i32).index,z=G.index;L=m.binary(u.BinaryOp.XorI32,m.binary(u.BinaryOp.AddI32,m.local_tee(K,m.binary(u.BinaryOp.ShrI32,m.local_tee(z,U),m.i32(31))),m.local_get(z,u.NativeType.I32)),m.local_get(K,u.NativeType.I32)),H.freeTempLocal(G);break;case 4:var Y=e.options,H=e.currentFlow,W=Y.isWasm64;G=H.getTempLocal(Y.usizeType),K=H.getAndFreeTempLocal(Y.usizeType).index,z=G.index;L=m.binary(W?u.BinaryOp.XorI64:u.BinaryOp.XorI32,m.binary(W?u.BinaryOp.AddI64:u.BinaryOp.AddI32,m.local_tee(K,m.binary(W?u.BinaryOp.ShrI64:u.BinaryOp.ShrI32,m.local_tee(z,U),W?m.i64(63):m.i32(31))),m.local_get(z,Y.nativeSizeType)),m.local_get(K,Y.nativeSizeType)),H.freeTempLocal(G);break;case 3:G=(H=e.currentFlow).getTempLocal(l.Type.i64),K=H.getAndFreeTempLocal(l.Type.i64).index,z=G.index;L=m.binary(u.BinaryOp.XorI64,m.binary(u.BinaryOp.AddI64,m.local_tee(K,m.binary(u.BinaryOp.ShrI64,m.local_tee(z,U),m.i64(63))),m.local_get(z,u.NativeType.I64)),m.local_get(K,u.NativeType.I64)),H.freeTempLocal(G);break;case 9:case 5:case 6:case 7:case 8:case 10:L=U;break;case 11:L=m.unary(u.UnaryOp.AbsF32,U);break;case 12:L=m.unary(u.UnaryOp.AbsF64,U);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.max:if(I(t,s,e,!0)|A(n,2,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.f64,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();V=e.compileExpression(n[1],S,5),M=void 0;switch(S.kind){case 0:case 1:case 2:M=u.BinaryOp.GtI32;break;case 5:case 6:case 7:case 10:M=u.BinaryOp.GtU32;break;case 3:M=u.BinaryOp.GtI64;break;case 8:M=u.BinaryOp.GtU64;break;case 4:M=e.options.isWasm64?u.BinaryOp.GtI64:u.BinaryOp.GtI32;break;case 9:M=e.options.isWasm64?u.BinaryOp.GtU64:u.BinaryOp.GtU32;break;case 11:return m.binary(u.BinaryOp.MaxF32,U,V);case 12:return m.binary(u.BinaryOp.MaxF64,U,V);default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable()}H=e.currentFlow;var X=S.toNativeType(),q=H.getTempLocal(S);H.setLocalFlag(q.index,_.LocalFlags.WRAPPED);G=H.getAndFreeTempLocal(S);return H.setLocalFlag(G.index,_.LocalFlags.WRAPPED),H.freeTempLocal(q),m.select(m.local_tee(q.index,U),m.local_tee(G.index,V),m.binary(M,m.local_get(q.index,X),m.local_get(G.index,X)));case a.min:if(I(t,s,e,!0)|A(n,2,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],5):e.compileExpression(n[0],l.Type.f64,4);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();V=e.compileExpression(n[1],S,5),M=void 0;switch(S.kind){case 0:case 1:case 2:M=u.BinaryOp.LtI32;break;case 5:case 6:case 7:case 10:M=u.BinaryOp.LtU32;break;case 3:M=u.BinaryOp.LtI64;break;case 8:M=u.BinaryOp.LtU64;break;case 4:M=e.options.isWasm64?u.BinaryOp.LtI64:u.BinaryOp.LtI32;break;case 9:M=e.options.isWasm64?u.BinaryOp.LtU64:u.BinaryOp.LtU32;break;case 11:return m.binary(u.BinaryOp.MinF32,U,V);case 12:return m.binary(u.BinaryOp.MinF64,U,V);default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable()}H=e.currentFlow,X=S.toNativeType(),q=H.getTempLocal(S);H.setLocalFlag(q.index,_.LocalFlags.WRAPPED);G=H.getAndFreeTempLocal(S);return H.setLocalFlag(G.index,_.LocalFlags.WRAPPED),H.freeTempLocal(q),m.select(m.local_tee(q.index,U),m.local_tee(G.index,V),m.binary(M,m.local_get(q.index,X),m.local_get(G.index,X)));case a.ceil:case a.floor:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],1):e.compileExpression(n[0],l.Type.f64,0);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();M=void 0;switch(S.kind){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:return U;case 11:M=r.internalName==a.ceil?u.UnaryOp.CeilF32:u.UnaryOp.FloorF32;break;case 12:M=r.internalName==a.ceil?u.UnaryOp.CeilF64:u.UnaryOp.FloorF64;break;default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable()}return m.unary(M,U);case a.copysign:if(I(t,s,e,!0)|A(n,2,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],1):e.compileExpression(n[0],l.Type.f64,0);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();V=e.compileExpression(n[1],S,1),M=void 0;switch(S.kind){case 11:M=u.BinaryOp.CopysignF32;break;case 12:M=u.BinaryOp.CopysignF64;break;default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable()}return m.binary(M,U,V);case a.nearest:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],1):e.compileExpression(n[0],l.Type.f64,0);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();L=void 0;switch(S.kind){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:L=U;break;case 11:L=m.unary(u.UnaryOp.NearestF32,U);break;case 12:L=m.unary(u.UnaryOp.NearestF64,U);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.reinterpret:if(b(t,s,e,!0)|A(n,1,s,e))return m.unreachable();if((S=t[0]).is(256))return e.currentType=S,e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();L=void 0;switch(S.kind){case 2:case 7:U=e.compileExpression(n[0],l.Type.f32,1);L=m.unary(u.UnaryOp.ReinterpretF32,U);break;case 3:case 8:U=e.compileExpression(n[0],l.Type.f64,1);L=m.unary(u.UnaryOp.ReinterpretF64,U);break;case 4:case 9:U=e.compileExpression(n[0],e.options.isWasm64?l.Type.f64:l.Type.f32,1);L=m.unary(e.options.isWasm64?u.UnaryOp.ReinterpretF64:u.UnaryOp.ReinterpretF32,U);break;case 11:U=e.compileExpression(n[0],l.Type.i32,1);L=m.unary(u.UnaryOp.ReinterpretI32,U);break;case 12:U=e.compileExpression(n[0],l.Type.i64,1);L=m.unary(u.UnaryOp.ReinterpretI64,U);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return e.currentType=S,L;case a.sqrt:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],1):e.compileExpression(n[0],l.Type.f64,0);if((S=e.currentType).is(256))return e.currentType=S,e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();L=void 0;switch(S.kind){case 11:L=m.unary(u.UnaryOp.SqrtF32,U);break;case 12:L=m.unary(u.UnaryOp.SqrtF64,U);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.trunc:if(I(t,s,e,!0)|A(n,1,s,e))return m.unreachable();U=t?e.compileExpression(n[0],t[0],1):e.compileExpression(n[0],l.Type.f64,0);if((S=e.currentType).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.range),m.unreachable();L=void 0;switch(S.kind){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:L=U;break;case 11:L=m.unary(u.UnaryOp.TruncF32,U);break;case 12:L=m.unary(u.UnaryOp.TruncF64,U);break;default:e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),L=m.unreachable()}return L;case a.load:if(b(t,s,e,!0)|N(n,1,3,s,e))return m.unreachable();S=t[0];var Q=i!=l.Type.auto&&S.is(4)&&i.is(4)&&i.size>S.size?i:S;U=e.compileExpression(n[0],e.options.usizeType,1);if(($=(ue=n.length)>=2?v(n[1],e):0)<0)return e.currentType=Q,m.unreachable();var j=void 0,Z=S.byteSize;if(3==ue){if((j=v(n[2],e))<0)return e.currentType=Q,m.unreachable();if(j>Z)return e.error(o.DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,n[2].range,"Alignment","0",Z.toString()),e.currentType=Q,m.unreachable();if(!y.isPowerOf2(j))return e.error(o.DiagnosticCode._0_must_be_a_power_of_two,n[2].range,"Alignment"),e.currentType=Q,m.unreachable()}else j=Z;return e.currentType=Q,m.load(S.byteSize,S.is(5),U,Q.toNativeType(),$,j);case a.store:if(e.currentType=l.Type.void,b(t,s,e)|N(n,2,4,s,e))return m.unreachable();S=t[0],U=e.compileExpression(n[0],e.options.usizeType,1),V=d?e.compileExpression(n[1],i,1):e.compileExpression(n[1],S,S.is(4)?0:1);var J=e.currentType;if(S.is(4)&&(!J.is(4)||J.size=3?v(n[2],e):0)<0)return e.currentType=l.Type.void,m.unreachable();j=void 0,Z=S.byteSize;if(4==n.length){if((j=v(n[3],e))<0)return e.currentType=l.Type.void,m.unreachable();if(j>Z)return e.error(o.DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,n[3].range,"Alignment","0",Z.toString()),e.currentType=l.Type.void,m.unreachable();if(!y.isPowerOf2(j))return e.error(o.DiagnosticCode._0_must_be_a_power_of_two,n[3].range,"Alignment"),e.currentType=l.Type.void,m.unreachable()}else j=Z;return e.currentType=l.Type.void,m.store(S.byteSize,U,V,J.toNativeType(),$,j);case a.atomic_load:if(!e.options.hasFeature(16))break;if(b(t,s,e,!0)|N(n,1,2,s,e))return m.unreachable();Q=(S=t[0]).is(4)&&i.is(4)&&i.size>S.size?i:S;if(!S.is(4))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=Q,m.unreachable();U=e.compileExpression(n[0],e.options.usizeType,1);return($=2==n.length?v(n[1],e):0)<0?(e.currentType=Q,m.unreachable()):(e.currentType=Q,m.atomic_load(S.byteSize,U,Q.toNativeType(),$));case a.atomic_store:if(!e.options.hasFeature(16))break;if(e.currentType=l.Type.void,b(t,s,e)|N(n,2,3,s,e))return m.unreachable();if(!(S=t[0]).is(4)||S.size<8)return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();U=e.compileExpression(n[0],e.options.usizeType,1),V=d?e.compileExpression(n[1],i,1):e.compileExpression(n[1],S,S.is(4)?0:1),J=e.currentType;return S.is(4)&&(!J.is(4)||J.size=0&&geNe?(e.error(o.DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,n[1].range,"Lane index","0",Ne.toString()),m.unreachable()):m.simd_extract(M,U,ke);case a.v128_replace_lane:if(!e.options.hasFeature(8))break;if(b(t,s,e)|A(n,3,s,e))return e.currentType=l.Type.v128,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();M=void 0;switch(S.kind){case 0:case 5:M=u.SIMDReplaceOp.ReplaceLaneVecI8x16;break;case 1:case 6:M=u.SIMDReplaceOp.ReplaceLaneVecI16x8;break;case 2:case 7:M=u.SIMDReplaceOp.ReplaceLaneVecI32x4;break;case 3:case 8:M=u.SIMDReplaceOp.ReplaceLaneVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.SIMDReplaceOp.ReplaceLaneVecI64x2:u.SIMDReplaceOp.ReplaceLaneVecI32x4;break;case 11:M=u.SIMDReplaceOp.ReplaceLaneVecF32x4;break;case 12:M=u.SIMDReplaceOp.ReplaceLaneVecF64x2;break;default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable()}U=e.compileExpression(n[0],l.Type.v128,1),V=e.precomputeExpression(n[1],l.Type.u8,1);if(u.getExpressionId(V)!=u.ExpressionId.Const)return e.error(o.DiagnosticCode.Expression_must_be_a_compile_time_constant,n[1].range),e.currentType=l.Type.v128,m.unreachable();assert(u.getExpressionType(V)==u.NativeType.I32);Ne=16/S.byteSize-1;if((ke=u.getConstValueI32(V))<0||ke>Ne)return e.error(o.DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,n[1].range,"Lane index","0",Ne.toString()),m.unreachable();ee=e.compileExpression(n[2],S,1);return e.currentType=l.Type.v128,m.simd_replace(M,U,ke,ee);case a.v128_shuffle:if(!e.options.hasFeature(8))break;if(b(t,s,e))return e.currentType=l.Type.v128,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();var Se=S.byteSize,Oe=16/Se;if(assert(isInteger(Oe)&&y.isPowerOf2(Oe)),A(n,2+Oe,s,e))return e.currentType=l.Type.v128,m.unreachable();switch(S.kind){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 11:case 12:break;default:return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable()}U=e.compileExpression(n[0],l.Type.v128,1),V=e.compileExpression(n[1],l.Type.v128,1);var Ce=new Uint8Array(16);for(Ne=(Oe<<1)-1,ye=0;yeNe)return e.error(o.DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,Le.range,"Lane index","0",Ne.toString()),e.currentType=l.Type.v128,m.unreachable();switch(Se){case 1:y.writeI8(ke,Ce,ye);break;case 2:var Fe=ye<<1,Be=ke<<1;y.writeI8(Be,Ce,Fe),y.writeI8(Be+1,Ce,Fe+1);break;case 4:Fe=ye<<2,Be=ke<<2;y.writeI8(Be,Ce,Fe),y.writeI8(Be+1,Ce,Fe+1),y.writeI8(Be+2,Ce,Fe+2),y.writeI8(Be+3,Ce,Fe+3);break;case 8:Fe=ye<<3,Be=ke<<3;y.writeI8(Be,Ce,Fe),y.writeI8(Be+1,Ce,Fe+1),y.writeI8(Be+2,Ce,Fe+2),y.writeI8(Be+3,Ce,Fe+3),y.writeI8(Be+4,Ce,Fe+4),y.writeI8(Be+5,Ce,Fe+5),y.writeI8(Be+6,Ce,Fe+6),y.writeI8(Be+7,Ce,Fe+7);break;default:assert(!1)}}return e.currentType=l.Type.v128,m.simd_shuffle(U,V,Ce);case a.v128_add:case a.v128_sub:case a.v128_mul:case a.v128_div:case a.v128_add_saturate:case a.v128_sub_saturate:case a.v128_min:case a.v128_max:case a.v128_eq:case a.v128_ne:case a.v128_lt:case a.v128_le:case a.v128_gt:case a.v128_ge:if(!e.options.hasFeature(8))break;if(b(t,s,e)|A(n,2,s,e))return e.currentType=l.Type.v128,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();M=-1;switch(r.internalName){case a.v128_add:switch(S.kind){case 0:case 5:M=u.BinaryOp.AddVecI8x16;break;case 1:case 6:M=u.BinaryOp.AddVecI16x8;break;case 2:case 7:M=u.BinaryOp.AddVecI32x4;break;case 3:case 8:M=u.BinaryOp.AddVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.BinaryOp.AddVecI64x2:u.BinaryOp.AddVecI32x4;break;case 11:M=u.BinaryOp.AddVecF32x4;break;case 12:M=u.BinaryOp.AddVecF64x2}break;case a.v128_sub:switch(S.kind){case 0:case 5:M=u.BinaryOp.SubVecI8x16;break;case 1:case 6:M=u.BinaryOp.SubVecI16x8;break;case 2:case 7:M=u.BinaryOp.SubVecI32x4;break;case 3:case 8:M=u.BinaryOp.SubVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.BinaryOp.SubVecI64x2:u.BinaryOp.SubVecI32x4;break;case 11:M=u.BinaryOp.SubVecF32x4;break;case 12:M=u.BinaryOp.SubVecF64x2}break;case a.v128_mul:switch(S.kind){case 0:case 5:M=u.BinaryOp.MulVecI8x16;break;case 1:case 6:M=u.BinaryOp.MulVecI16x8;break;case 2:case 7:M=u.BinaryOp.MulVecI32x4;break;case 11:M=u.BinaryOp.MulVecF32x4;break;case 12:M=u.BinaryOp.MulVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=u.BinaryOp.MulVecI32x4)}break;case a.v128_div:switch(S.kind){case 11:M=u.BinaryOp.DivVecF32x4;break;case 12:M=u.BinaryOp.DivVecF64x2}break;case a.v128_add_saturate:switch(S.kind){case 0:M=u.BinaryOp.AddSatSVecI8x16;break;case 5:M=u.BinaryOp.AddSatUVecI8x16;break;case 1:M=u.BinaryOp.AddSatSVecI16x8;break;case 6:M=u.BinaryOp.AddSatUVecI16x8}break;case a.v128_sub_saturate:switch(S.kind){case 0:M=u.BinaryOp.SubSatSVecI8x16;break;case 5:M=u.BinaryOp.SubSatUVecI8x16;break;case 1:M=u.BinaryOp.SubSatSVecI16x8;break;case 6:M=u.BinaryOp.SubSatUVecI16x8}break;case a.v128_min:switch(S.kind){case 11:M=u.BinaryOp.MinVecF32x4;break;case 12:M=u.BinaryOp.MinVecF64x2}break;case a.v128_max:switch(S.kind){case 11:M=u.BinaryOp.MaxVecF32x4;break;case 12:M=u.BinaryOp.MaxVecF64x2}break;case a.v128_eq:switch(S.kind){case 0:case 5:M=u.BinaryOp.EqVecI8x16;break;case 1:case 6:M=u.BinaryOp.EqVecI16x8;break;case 2:case 7:M=u.BinaryOp.EqVecI32x4;break;case 11:M=u.BinaryOp.EqVecF32x4;break;case 12:M=u.BinaryOp.EqVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=u.BinaryOp.EqVecI32x4)}break;case a.v128_ne:switch(S.kind){case 0:case 5:M=u.BinaryOp.NeVecI8x16;break;case 1:case 6:M=u.BinaryOp.NeVecI16x8;break;case 2:case 7:M=u.BinaryOp.NeVecI32x4;break;case 11:M=u.BinaryOp.NeVecF32x4;break;case 12:M=u.BinaryOp.NeVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=u.BinaryOp.NeVecI32x4)}break;case a.v128_lt:switch(S.kind){case 0:M=u.BinaryOp.LtSVecI8x16;break;case 5:M=u.BinaryOp.LtUVecI8x16;break;case 1:M=u.BinaryOp.LtSVecI16x8;break;case 6:M=u.BinaryOp.LtUVecI16x8;break;case 2:M=u.BinaryOp.LtSVecI32x4;break;case 7:M=u.BinaryOp.LtUVecI32x4;break;case 11:M=u.BinaryOp.LtVecF32x4;break;case 12:M=u.BinaryOp.LtVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=4==S.kind?u.BinaryOp.LtSVecI32x4:u.BinaryOp.LtUVecI32x4)}break;case a.v128_le:switch(S.kind){case 0:M=u.BinaryOp.LeSVecI8x16;break;case 5:M=u.BinaryOp.LeUVecI8x16;break;case 1:M=u.BinaryOp.LeSVecI16x8;break;case 6:M=u.BinaryOp.LeUVecI16x8;break;case 2:M=u.BinaryOp.LeSVecI32x4;break;case 7:M=u.BinaryOp.LeUVecI32x4;break;case 11:M=u.BinaryOp.LeVecF32x4;break;case 12:M=u.BinaryOp.LeVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=4==S.kind?u.BinaryOp.LeSVecI32x4:u.BinaryOp.LeUVecI32x4)}break;case a.v128_gt:switch(S.kind){case 0:M=u.BinaryOp.GtSVecI8x16;break;case 5:M=u.BinaryOp.GtUVecI8x16;break;case 1:M=u.BinaryOp.GtSVecI16x8;break;case 6:M=u.BinaryOp.GtUVecI16x8;break;case 2:M=u.BinaryOp.GtSVecI32x4;break;case 7:M=u.BinaryOp.GtUVecI32x4;break;case 11:M=u.BinaryOp.GtVecF32x4;break;case 12:M=u.BinaryOp.GtVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=4==S.kind?u.BinaryOp.GtSVecI32x4:u.BinaryOp.GtUVecI32x4)}break;case a.v128_ge:switch(S.kind){case 0:M=u.BinaryOp.GeSVecI8x16;break;case 5:M=u.BinaryOp.GeUVecI8x16;break;case 1:M=u.BinaryOp.GeSVecI16x8;break;case 6:M=u.BinaryOp.GeUVecI16x8;break;case 2:M=u.BinaryOp.GeSVecI32x4;break;case 7:M=u.BinaryOp.GeUVecI32x4;break;case 11:M=u.BinaryOp.GeVecF32x4;break;case 12:M=u.BinaryOp.GeVecF64x2;break;case 4:case 9:e.options.isWasm64||(M=4==S.kind?u.BinaryOp.GeSVecI32x4:u.BinaryOp.GeUVecI32x4)}}if(-1==M)return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1),V=e.compileExpression(n[1],l.Type.v128,1);return e.currentType=l.Type.v128,m.binary(M,U,V);case a.v128_neg:case a.v128_abs:case a.v128_sqrt:case a.v128_convert:case a.v128_trunc:if(!e.options.hasFeature(8))break;if(b(t,s,e)|A(n,1,s,e))return e.currentType=l.Type.v128,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.range),e.currentType=l.Type.v128,m.unreachable();M=-1;switch(r.internalName){case a.v128_neg:switch(S.kind){case 0:case 5:M=u.UnaryOp.NegVecI8x16;break;case 1:case 6:M=u.UnaryOp.NegVecI16x8;break;case 2:case 7:M=u.UnaryOp.NegVecI32x4;break;case 3:case 8:M=u.UnaryOp.NegVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.UnaryOp.NegVecI64x2:u.UnaryOp.NegVecI32x4;break;case 11:M=u.UnaryOp.NegVecF32x4;break;case 12:M=u.UnaryOp.NegVecF64x2}break;case a.v128_abs:switch(S.kind){case 11:M=u.UnaryOp.AbsVecF32x4;break;case 12:M=u.UnaryOp.AbsVecF64x2}break;case a.v128_sqrt:switch(S.kind){case 11:M=u.UnaryOp.SqrtVecF32x4;break;case 12:M=u.UnaryOp.SqrtVecF64x2}break;case a.v128_convert:switch(S.kind){case 2:M=u.UnaryOp.ConvertSVecI32x4ToVecF32x4;break;case 7:M=u.UnaryOp.ConvertUVecI32x4ToVecF32x4;break;case 3:M=u.UnaryOp.ConvertSVecI64x2ToVecF64x2;break;case 8:M=u.UnaryOp.ConvertUVecI64x2ToVecF64x2}break;case a.v128_trunc:switch(S.kind){case 2:M=u.UnaryOp.TruncSatSVecF32x4ToVecI32x4;break;case 7:M=u.UnaryOp.TruncSatUVecF32x4ToVecI32x4;break;case 3:M=u.UnaryOp.TruncSatSVecF64x2ToVecI64x2;break;case 8:M=u.UnaryOp.TruncSatUVecF64x2ToVecI64x2}}if(-1==M)return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1);return e.currentType=l.Type.v128,m.unary(M,U);case a.v128_shl:case a.v128_shr:if(!e.options.hasFeature(8))break;if(b(t,s,e)|A(n,2,s,e))return e.currentType=l.Type.v128,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.v128,m.unreachable();M=-1;switch(r.internalName){case a.v128_shl:switch(S.kind){case 0:case 5:M=u.SIMDShiftOp.ShlVecI8x16;break;case 1:case 6:M=u.SIMDShiftOp.ShlVecI16x8;break;case 2:case 7:M=u.SIMDShiftOp.ShlVecI32x4;break;case 3:case 8:M=u.SIMDShiftOp.ShlVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.SIMDShiftOp.ShlVecI64x2:u.SIMDShiftOp.ShlVecI32x4}break;case a.v128_shr:switch(S.kind){case 0:M=u.SIMDShiftOp.ShrSVecI8x16;break;case 5:M=u.SIMDShiftOp.ShrUVecI8x16;break;case 1:M=u.SIMDShiftOp.ShrSVecI16x8;break;case 6:M=u.SIMDShiftOp.ShrUVecI16x8;break;case 2:M=u.SIMDShiftOp.ShrSVecI32x4;break;case 7:M=u.SIMDShiftOp.ShrUVecI32x4;break;case 3:M=u.SIMDShiftOp.ShrSVecI64x2;break;case 8:M=u.SIMDShiftOp.ShrUVecI64x2;break;case 4:M=e.options.isWasm64?u.SIMDShiftOp.ShrSVecI64x2:u.SIMDShiftOp.ShrSVecI32x4;break;case 9:M=e.options.isWasm64?u.SIMDShiftOp.ShrUVecI64x2:u.SIMDShiftOp.ShrUVecI32x4}}if(-1==M)return e.error(o.DiagnosticCode.Operation_not_supported,s.range),e.currentType=l.Type.v128,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1),V=e.compileExpression(n[1],l.Type.i32,1);return e.currentType=l.Type.v128,m.simd_shift(M,U,V);case a.v128_and:case a.v128_or:case a.v128_xor:if(!e.options.hasFeature(8))break;if(x(t,s,r)|A(n,2,s,e))return e.currentType=l.Type.v128,m.unreachable();M=-1;switch(r.internalName){default:assert(!1);case a.v128_and:M=u.BinaryOp.AndVec128;break;case a.v128_or:M=u.BinaryOp.OrVec128;break;case a.v128_xor:M=u.BinaryOp.XorVec128}U=e.compileExpression(n[0],l.Type.v128,1),V=e.compileExpression(n[1],l.Type.v128,1);return m.binary(M,U,V);case a.v128_not:if(!e.options.hasFeature(8))break;if(x(t,s,r)|A(n,1,s,e))return e.currentType=l.Type.v128,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1);return m.unary(u.UnaryOp.NotVec128,U);case a.v128_bitselect:if(!e.options.hasFeature(8))break;if(x(t,s,r)|A(n,3,s,e))return e.currentType=l.Type.v128,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1),V=e.compileExpression(n[1],l.Type.v128,1),ee=e.compileExpression(n[2],l.Type.v128,1);return m.simd_bitselect(U,V,ee);case a.v128_any_true:case a.v128_all_true:if(!e.options.hasFeature(8))break;if(b(t,s,e)|A(n,1,s,e))return e.currentType=l.Type.bool,m.unreachable();if((S=t[0]).is(256))return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),m.unreachable();M=-1;switch(r.internalName){default:assert(!1);case a.v128_any_true:switch(S.kind){case 0:case 5:M=u.UnaryOp.AnyTrueVecI8x16;break;case 1:case 6:M=u.UnaryOp.AnyTrueVecI16x8;break;case 2:case 7:M=u.UnaryOp.AnyTrueVecI32x4;break;case 3:case 8:M=u.UnaryOp.AnyTrueVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.UnaryOp.AnyTrueVecI64x2:u.UnaryOp.AnyTrueVecI32x4}break;case a.v128_all_true:switch(S.kind){case 0:case 5:M=u.UnaryOp.AllTrueVecI8x16;break;case 1:case 6:M=u.UnaryOp.AllTrueVecI16x8;break;case 2:case 7:M=u.UnaryOp.AllTrueVecI32x4;break;case 3:case 8:M=u.UnaryOp.AllTrueVecI64x2;break;case 4:case 9:M=e.options.isWasm64?u.UnaryOp.AllTrueVecI64x2:u.UnaryOp.AllTrueVecI32x4}}if(-1==M)return e.error(o.DiagnosticCode.Operation_not_supported,s.typeArgumentsRange),e.currentType=l.Type.bool,m.unreachable();U=e.compileExpression(n[0],l.Type.v128,1);return e.currentType=l.Type.bool,m.unary(M,U);case a.idof:var De;S=E(e,t,n,s);return e.currentType=l.Type.u32,S?!(De=S.classReference)||De.hasDecorator(p.DecoratorFlags.UNMANAGED)?(e.error(o.DiagnosticCode.Operation_not_supported,s.range),m.unreachable()):m.i32(De.id):m.unreachable();case a.visit_globals:if(x(t,s,r)|A(n,1,s,e))return e.currentType=l.Type.void,m.unreachable();U=e.compileExpression(n[0],l.Type.u32,1);return e.runtimeFeatures|=4,e.currentType=l.Type.void,m.call(a.visit_globals,[U],u.NativeType.None);case a.visit_members:if(x(t,s,r)|A(n,2,s,e))return e.currentType=l.Type.void,m.unreachable();U=e.compileExpression(n[0],e.options.usizeType,1),V=e.compileExpression(n[1],l.Type.u32,1);return e.runtimeFeatures|=8,e.currentType=l.Type.void,m.call(a.visit_members,[U,V],u.NativeType.None)}return(L=function(e,r,t,n){switch(r.internalName){case a.i32_clz:return f(a.clz,e,l.Type.i32,t,l.Type.i32,n);case a.i64_clz:return f(a.clz,e,l.Type.i64,t,l.Type.i64,n);case a.i32_ctz:return f(a.ctz,e,l.Type.i32,t,l.Type.i32,n);case a.i64_ctz:return f(a.ctz,e,l.Type.i64,t,l.Type.i64,n);case a.i32_popcnt:return f(a.popcnt,e,l.Type.i32,t,l.Type.i32,n);case a.i64_popcnt:return f(a.popcnt,e,l.Type.i64,t,l.Type.i64,n);case a.i32_rotl:return f(a.rotl,e,l.Type.i32,t,l.Type.i32,n);case a.i64_rotl:return f(a.rotl,e,l.Type.i64,t,l.Type.i64,n);case a.i32_rotr:return f(a.rotr,e,l.Type.i32,t,l.Type.i32,n);case a.i64_rotr:return f(a.rotr,e,l.Type.i64,t,l.Type.i64,n);case a.f32_abs:return f(a.abs,e,l.Type.f32,t,l.Type.f32,n);case a.f64_abs:return f(a.abs,e,l.Type.f64,t,l.Type.f64,n);case a.f32_max:return f(a.max,e,l.Type.f32,t,l.Type.f32,n);case a.f64_max:return f(a.max,e,l.Type.f64,t,l.Type.f64,n);case a.f32_min:return f(a.min,e,l.Type.f32,t,l.Type.f32,n);case a.f64_min:return f(a.min,e,l.Type.f64,t,l.Type.f64,n);case a.f32_ceil:return f(a.ceil,e,l.Type.f32,t,l.Type.f32,n);case a.f64_ceil:return f(a.ceil,e,l.Type.f64,t,l.Type.f64,n);case a.f32_floor:return f(a.floor,e,l.Type.f32,t,l.Type.f32,n);case a.f64_floor:return f(a.floor,e,l.Type.f64,t,l.Type.f64,n);case a.f32_copysign:return f(a.copysign,e,l.Type.f32,t,l.Type.f32,n);case a.f64_copysign:return f(a.copysign,e,l.Type.f64,t,l.Type.f64,n);case a.f32_nearest:return f(a.nearest,e,l.Type.f32,t,l.Type.f32,n);case a.f64_nearest:return f(a.nearest,e,l.Type.f64,t,l.Type.f64,n);case a.i32_reinterpret_f32:return f(a.reinterpret,e,l.Type.i32,t,l.Type.f32,n);case a.i64_reinterpret_f64:return f(a.reinterpret,e,l.Type.i64,t,l.Type.f64,n);case a.f32_reinterpret_i32:return f(a.reinterpret,e,l.Type.f32,t,l.Type.i32,n);case a.f64_reinterpret_i64:return f(a.reinterpret,e,l.Type.f64,t,l.Type.i64,n);case a.f32_sqrt:return f(a.sqrt,e,l.Type.f32,t,l.Type.f32,n);case a.f64_sqrt:return f(a.sqrt,e,l.Type.f64,t,l.Type.f64,n);case a.f32_trunc:return f(a.trunc,e,l.Type.f32,t,l.Type.f32,n);case a.f64_trunc:return f(a.trunc,e,l.Type.f64,t,l.Type.f64,n);case a.i32_load8_s:return f(a.load,e,l.Type.i8,t,l.Type.i32,n);case a.i32_load8_u:return f(a.load,e,l.Type.u8,t,l.Type.i32,n);case a.i32_load16_s:return f(a.load,e,l.Type.i16,t,l.Type.i32,n);case a.i32_load16_u:return f(a.load,e,l.Type.u16,t,l.Type.i32,n);case a.i32_load:return f(a.load,e,l.Type.i32,t,l.Type.i32,n);case a.i64_load8_s:return f(a.load,e,l.Type.i8,t,l.Type.i64,n);case a.i64_load8_u:return f(a.load,e,l.Type.u8,t,l.Type.i64,n);case a.i64_load16_s:return f(a.load,e,l.Type.i16,t,l.Type.i64,n);case a.i64_load16_u:return f(a.load,e,l.Type.u16,t,l.Type.i64,n);case a.i64_load32_s:return f(a.load,e,l.Type.i32,t,l.Type.i64,n);case a.i64_load32_u:return f(a.load,e,l.Type.u32,t,l.Type.i64,n);case a.i64_load:return f(a.load,e,l.Type.i64,t,l.Type.i64,n);case a.f32_load:return f(a.load,e,l.Type.f32,t,l.Type.f32,n);case a.f64_load:return f(a.load,e,l.Type.f64,t,l.Type.f64,n);case a.i32_store8:return f(a.store,e,l.Type.i8,t,l.Type.i32,n);case a.i32_store16:return f(a.store,e,l.Type.i16,t,l.Type.i32,n);case a.i32_store:return f(a.store,e,l.Type.i32,t,l.Type.i32,n);case a.i64_store8:return f(a.store,e,l.Type.i8,t,l.Type.i64,n);case a.i64_store16:return f(a.store,e,l.Type.i16,t,l.Type.i64,n);case a.i64_store32:return f(a.store,e,l.Type.i32,t,l.Type.i64,n);case a.i64_store:return f(a.store,e,l.Type.i64,t,l.Type.i64,n);case a.f32_store:return f(a.store,e,l.Type.f32,t,l.Type.f32,n);case a.f64_store:return f(a.store,e,l.Type.f64,t,l.Type.f64,n)}if(e.options.hasFeature(16))switch(r.internalName){case a.i32_atomic_load8_u:return f(a.atomic_load,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_load16_u:return f(a.atomic_load,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_load:return f(a.atomic_load,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_load8_u:return f(a.atomic_load,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_load16_u:return f(a.atomic_load,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_load32_u:return f(a.atomic_load,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_load:return f(a.atomic_load,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_store8:return f(a.atomic_store,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_store16:return f(a.atomic_store,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_store:return f(a.atomic_store,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_store8:return f(a.atomic_store,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_store16:return f(a.atomic_store,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_store32:return f(a.atomic_store,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_store:return f(a.atomic_store,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_add_u:return f(a.atomic_add,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_add_u:return f(a.atomic_add,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_add:return f(a.atomic_add,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_add_u:return f(a.atomic_add,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_add_u:return f(a.atomic_add,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_add_u:return f(a.atomic_add,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_add:return f(a.atomic_add,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_sub_u:return f(a.atomic_sub,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_sub_u:return f(a.atomic_sub,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_sub:return f(a.atomic_sub,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_sub_u:return f(a.atomic_sub,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_sub_u:return f(a.atomic_sub,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_sub_u:return f(a.atomic_sub,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_sub:return f(a.atomic_sub,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_and_u:return f(a.atomic_and,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_and_u:return f(a.atomic_and,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_and:return f(a.atomic_and,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_and_u:return f(a.atomic_and,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_and_u:return f(a.atomic_and,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_and_u:return f(a.atomic_and,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_and:return f(a.atomic_and,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_or_u:return f(a.atomic_or,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_or_u:return f(a.atomic_or,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_or:return f(a.atomic_or,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_or_u:return f(a.atomic_or,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_or_u:return f(a.atomic_or,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_or_u:return f(a.atomic_or,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_or:return f(a.atomic_or,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_u_xor:return f(a.atomic_xor,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_u_xor:return f(a.atomic_xor,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_xor:return f(a.atomic_xor,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_xor_u:return f(a.atomic_xor,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_xor_u:return f(a.atomic_xor,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_xor_u:return f(a.atomic_xor,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_xor:return f(a.atomic_xor,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_xchg_u:return f(a.atomic_xchg,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_xchg_u:return f(a.atomic_xchg,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_xchg:return f(a.atomic_xchg,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_xchg_u:return f(a.atomic_xchg,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_xchg_u:return f(a.atomic_xchg,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_xchg_u:return f(a.atomic_xchg,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_xchg:return f(a.atomic_xchg,e,l.Type.i64,t,l.Type.i64,n);case a.i32_atomic_rmw8_cmpxchg_u:return f(a.atomic_cmpxchg,e,l.Type.u8,t,l.Type.i32,n);case a.i32_atomic_rmw16_cmpxchg_u:return f(a.atomic_cmpxchg,e,l.Type.u16,t,l.Type.i32,n);case a.i32_atomic_rmw_cmpxchg:return f(a.atomic_cmpxchg,e,l.Type.i32,t,l.Type.i32,n);case a.i64_atomic_rmw8_cmpxchg_u:return f(a.atomic_cmpxchg,e,l.Type.u8,t,l.Type.i64,n);case a.i64_atomic_rmw16_cmpxchg_u:return f(a.atomic_cmpxchg,e,l.Type.u16,t,l.Type.i64,n);case a.i64_atomic_rmw32_cmpxchg_u:return f(a.atomic_cmpxchg,e,l.Type.u32,t,l.Type.i64,n);case a.i64_atomic_rmw_cmpxchg:return f(a.atomic_cmpxchg,e,l.Type.i64,t,l.Type.i64,n);case a.i32_wait:return f(a.atomic_wait,e,l.Type.i32,t,l.Type.i32,n);case a.i64_wait:return f(a.atomic_wait,e,l.Type.i64,t,l.Type.i32,n)}if(e.options.hasFeature(8))switch(r.internalName){case a.v128_load:return f(a.load,e,l.Type.v128,t,l.Type.v128,n);case a.v128_store:return f(a.store,e,l.Type.v128,t,l.Type.void,n);case a.i8x16_splat:return f(a.v128_splat,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_extract_lane_s:return f(a.v128_extract_lane,e,l.Type.i8,t,l.Type.i8,n);case a.i8x16_extract_lane_u:return f(a.v128_extract_lane,e,l.Type.u8,t,l.Type.u8,n);case a.i8x16_replace_lane:return f(a.v128_replace_lane,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_add:return f(a.v128_add,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_sub:return f(a.v128_sub,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_mul:return f(a.v128_mul,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_neg:return f(a.v128_neg,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_add_saturate_s:return f(a.v128_add_saturate,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_add_saturate_u:return f(a.v128_add_saturate,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_sub_saturate_s:return f(a.v128_sub_saturate,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_sub_saturate_u:return f(a.v128_sub_saturate,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_shl:return f(a.v128_shl,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_shr_s:return f(a.v128_shr,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_shr_u:return f(a.v128_shr,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_any_true:return f(a.v128_any_true,e,l.Type.i8,t,l.Type.i32,n);case a.i8x16_all_true:return f(a.v128_all_true,e,l.Type.i8,t,l.Type.i32,n);case a.i8x16_eq:return f(a.v128_eq,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_ne:return f(a.v128_ne,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_lt_s:return f(a.v128_lt,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_lt_u:return f(a.v128_lt,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_le_s:return f(a.v128_le,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_le_u:return f(a.v128_le,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_gt_s:return f(a.v128_gt,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_gt_u:return f(a.v128_gt,e,l.Type.u8,t,l.Type.v128,n);case a.i8x16_ge_s:return f(a.v128_ge,e,l.Type.i8,t,l.Type.v128,n);case a.i8x16_ge_u:return f(a.v128_ge,e,l.Type.u8,t,l.Type.v128,n);case a.i16x8_splat:return f(a.v128_splat,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_extract_lane_s:return f(a.v128_extract_lane,e,l.Type.i16,t,l.Type.i16,n);case a.i16x8_extract_lane_u:return f(a.v128_extract_lane,e,l.Type.u16,t,l.Type.u16,n);case a.i16x8_replace_lane:return f(a.v128_replace_lane,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_add:return f(a.v128_add,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_sub:return f(a.v128_sub,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_mul:return f(a.v128_mul,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_neg:return f(a.v128_neg,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_add_saturate_s:return f(a.v128_add_saturate,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_add_saturate_u:return f(a.v128_add_saturate,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_sub_saturate_s:return f(a.v128_sub_saturate,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_sub_saturate_u:return f(a.v128_sub_saturate,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_shl:return f(a.v128_shl,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_shr_s:return f(a.v128_shr,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_shr_u:return f(a.v128_shr,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_any_true:return f(a.v128_any_true,e,l.Type.i16,t,l.Type.i32,n);case a.i16x8_all_true:return f(a.v128_all_true,e,l.Type.i16,t,l.Type.i32,n);case a.i16x8_eq:return f(a.v128_eq,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_ne:return f(a.v128_ne,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_lt_s:return f(a.v128_lt,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_lt_u:return f(a.v128_lt,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_le_s:return f(a.v128_le,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_le_u:return f(a.v128_le,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_gt_s:return f(a.v128_gt,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_gt_u:return f(a.v128_gt,e,l.Type.u16,t,l.Type.v128,n);case a.i16x8_ge_s:return f(a.v128_ge,e,l.Type.i16,t,l.Type.v128,n);case a.i16x8_ge_u:return f(a.v128_ge,e,l.Type.u16,t,l.Type.v128,n);case a.i32x4_splat:return f(a.v128_splat,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_extract_lane:return f(a.v128_extract_lane,e,l.Type.i32,t,l.Type.i32,n);case a.i32x4_replace_lane:return f(a.v128_replace_lane,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_add:return f(a.v128_add,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_sub:return f(a.v128_sub,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_mul:return f(a.v128_mul,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_neg:return f(a.v128_neg,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_shl:return f(a.v128_shl,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_shr_s:return f(a.v128_shr,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_shr_u:return f(a.v128_shr,e,l.Type.u32,t,l.Type.v128,n);case a.i32x4_any_true:return f(a.v128_any_true,e,l.Type.i32,t,l.Type.i32,n);case a.i32x4_all_true:return f(a.v128_all_true,e,l.Type.i32,t,l.Type.i32,n);case a.i32x4_eq:return f(a.v128_eq,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_ne:return f(a.v128_ne,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_lt_s:return f(a.v128_lt,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_lt_u:return f(a.v128_lt,e,l.Type.u32,t,l.Type.v128,n);case a.i32x4_le_s:return f(a.v128_le,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_le_u:return f(a.v128_le,e,l.Type.u32,t,l.Type.v128,n);case a.i32x4_gt_s:return f(a.v128_gt,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_gt_u:return f(a.v128_gt,e,l.Type.u32,t,l.Type.v128,n);case a.i32x4_ge_s:return f(a.v128_ge,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_ge_u:return f(a.v128_ge,e,l.Type.u32,t,l.Type.v128,n);case a.i32x4_trunc_s_f32x4_sat:return f(a.v128_trunc,e,l.Type.i32,t,l.Type.v128,n);case a.i32x4_trunc_u_f32x4_sat:return f(a.v128_trunc,e,l.Type.u32,t,l.Type.v128,n);case a.i64x2_splat:return f(a.v128_splat,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_extract_lane:return f(a.v128_extract_lane,e,l.Type.i64,t,l.Type.i64,n);case a.i64x2_replace_lane:return f(a.v128_replace_lane,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_add:return f(a.v128_add,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_sub:return f(a.v128_sub,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_neg:return f(a.v128_neg,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_shl:return f(a.v128_shl,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_shr_s:return f(a.v128_shr,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_shr_u:return f(a.v128_shr,e,l.Type.u64,t,l.Type.v128,n);case a.i64x2_any_true:return f(a.v128_any_true,e,l.Type.i64,t,l.Type.i32,n);case a.i64x2_all_true:return f(a.v128_all_true,e,l.Type.i64,t,l.Type.i32,n);case a.i64x2_trunc_s_f64x2_sat:return f(a.v128_trunc,e,l.Type.i64,t,l.Type.v128,n);case a.i64x2_trunc_u_f64x2_sat:return f(a.v128_trunc,e,l.Type.u64,t,l.Type.v128,n);case a.f32x4_splat:return f(a.v128_splat,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_extract_lane:return f(a.v128_extract_lane,e,l.Type.f32,t,l.Type.f32,n);case a.f32x4_replace_lane:return f(a.v128_replace_lane,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_add:return f(a.v128_add,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_sub:return f(a.v128_sub,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_mul:return f(a.v128_mul,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_div:return f(a.v128_div,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_neg:return f(a.v128_neg,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_min:return f(a.v128_min,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_max:return f(a.v128_max,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_abs:return f(a.v128_abs,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_sqrt:return f(a.v128_sqrt,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_eq:return f(a.v128_eq,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_ne:return f(a.v128_ne,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_lt:return f(a.v128_lt,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_le:return f(a.v128_le,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_gt:return f(a.v128_gt,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_ge:return f(a.v128_ge,e,l.Type.f32,t,l.Type.v128,n);case a.f32x4_convert_s_i32x4:return f(a.v128_convert,e,l.Type.i32,t,l.Type.v128,n);case a.f32x4_convert_u_i32x4:return f(a.v128_convert,e,l.Type.u32,t,l.Type.v128,n);case a.f64x2_splat:return f(a.v128_splat,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_extract_lane:return f(a.v128_extract_lane,e,l.Type.f64,t,l.Type.f64,n);case a.f64x2_replace_lane:return f(a.v128_replace_lane,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_add:return f(a.v128_add,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_sub:return f(a.v128_sub,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_mul:return f(a.v128_mul,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_div:return f(a.v128_div,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_neg:return f(a.v128_neg,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_min:return f(a.v128_min,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_max:return f(a.v128_max,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_abs:return f(a.v128_abs,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_sqrt:return f(a.v128_sqrt,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_eq:return f(a.v128_eq,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_ne:return f(a.v128_ne,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_lt:return f(a.v128_lt,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_le:return f(a.v128_le,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_gt:return f(a.v128_gt,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_ge:return f(a.v128_ge,e,l.Type.f64,t,l.Type.v128,n);case a.f64x2_convert_s_i64x2:return f(a.v128_convert,e,l.Type.i64,t,l.Type.v128,n);case a.f64x2_convert_u_i64x2:return f(a.v128_convert,e,l.Type.u64,t,l.Type.v128,n);case a.v8x16_shuffle:return f(a.v128_shuffle,e,l.Type.i8,t,l.Type.v128,n)}return 0}(e,r,n,s))?(t&&e.error(o.DiagnosticCode.Type_0_is_not_generic,s.typeArgumentsRange,r.internalName),L):(e.error(o.DiagnosticCode.Cannot_find_name_0,s.expression.range,r.internalName),m.unreachable())}function f(e,r,t,n,i,a){assert(r.program.elementsByName.has(e));var s=r.program.elementsByName.get(e);return assert(s.kind==p.ElementKind.FUNCTION_PROTOTYPE),m(r,s,[t],n,i,a,!0)}function T(e,r,t){var n=e.program,i=e.module,a=e.program.stringInstance;if(!a)return i.unreachable();var s,o=n.abortInstance;if(!o||!e.compileFunction(o))return i.unreachable();s=null!==r?e.compileExpression(r,a.type,17):a.type.toNativeZero(i);var c=e.ensureStaticString(t.range.source.normalizedPath);return e.currentType=l.Type.void,i.block(null,[i.call(o.internalName,[s,c,i.i32(t.range.line),i.i32(t.range.column)],u.NativeType.None),i.unreachable()])}function g(e){var r=32*(1<1)return e.error(o.DiagnosticCode.Expected_0_type_arguments_but_got_1,n.typeArgumentsRange,"1",r.length.toString(10)),null;e.compileExpression(t[0],r[0],1)}else e.compileExpression(t[0],l.Type.auto);return e.currentType}return r&&r.length>1&&e.error(o.DiagnosticCode.Expected_0_type_arguments_but_got_1,n.typeArgumentsRange,"1",r.length.toString(10)),e.error(o.DiagnosticCode.Expected_0_arguments_but_got_1,n.argumentsRange,"1",t.length.toString(10)),null}function v(e,r){var t,n;return r.options.isWasm64?(t=r.precomputeExpression(e,l.Type.usize64,1),(u.getExpressionId(t)!=u.ExpressionId.Const||u.getExpressionType(t)!=u.NativeType.I64||0!=u.getConstValueI64High(t)||(n=u.getConstValueI64Low(t))<0)&&(r.error(o.DiagnosticCode.Expression_must_be_a_compile_time_constant,e.range),n=-1)):(t=r.precomputeExpression(e,l.Type.usize32,1),(u.getExpressionId(t)!=u.ExpressionId.Const||u.getExpressionType(t)!=u.NativeType.I32||(n=u.getConstValueI32(t))<0)&&(r.error(o.DiagnosticCode.Expression_must_be_a_compile_time_constant,e.range),n=-1)),n}function b(e,r,t,n){if(void 0===n&&(n=!1),e){var i=e.length;if(1==i)return 0;assert(i),n&&(t.currentType=e[0]),t.error(o.DiagnosticCode.Expected_0_type_arguments_but_got_1,r.typeArgumentsRange,"1",i.toString())}else t.error(o.DiagnosticCode.Expected_0_type_arguments_but_got_1,r.range,"1","0");return 1}function I(e,r,t,n){if(void 0===n&&(n=!1),e){var i=e.length;return 1==i?0:(assert(i),n&&(t.currentType=e[0]),t.error(o.DiagnosticCode.Expected_0_type_arguments_but_got_1,r.typeArgumentsRange,"1",i.toString()),1)}return 0}function x(e,r,t){return e?(t.program.error(o.DiagnosticCode.Type_0_is_not_generic,r.typeArgumentsRange,t.internalName),1):0}function A(e,r,t,n){return e.length!=r?(n.error(o.DiagnosticCode.Expected_0_arguments_but_got_1,t.range,r.toString(),e.length.toString()),1):0}function N(e,r,t,n,i){var a=e.length;return at?(i.error(o.DiagnosticCode.Expected_0_arguments_but_got_1,n.range,t.toString(),a.toString()),1):0}!function(e){e.isInteger="~lib/builtins/isInteger",e.isFloat="~lib/builtins/isFloat",e.isBoolean="~lib/builtins/isBoolean",e.isSigned="~lib/builtins/isSigned",e.isReference="~lib/builtins/isReference",e.isString="~lib/builtins/isString",e.isArray="~lib/builtins/isArray",e.isArrayLike="~lib/builtins/isArrayLike",e.isFunction="~lib/builtins/isFunction",e.isNullable="~lib/builtins/isNullable",e.isDefined="~lib/builtins/isDefined",e.isConstant="~lib/builtins/isConstant",e.isManaged="~lib/builtins/isManaged",e.clz="~lib/builtins/clz",e.ctz="~lib/builtins/ctz",e.popcnt="~lib/builtins/popcnt",e.rotl="~lib/builtins/rotl",e.rotr="~lib/builtins/rotr",e.abs="~lib/builtins/abs",e.max="~lib/builtins/max",e.min="~lib/builtins/min",e.ceil="~lib/builtins/ceil",e.floor="~lib/builtins/floor",e.copysign="~lib/builtins/copysign",e.nearest="~lib/builtins/nearest",e.reinterpret="~lib/builtins/reinterpret",e.sqrt="~lib/builtins/sqrt",e.trunc="~lib/builtins/trunc",e.load="~lib/builtins/load",e.store="~lib/builtins/store",e.atomic_load="~lib/builtins/atomic.load",e.atomic_store="~lib/builtins/atomic.store",e.atomic_add="~lib/builtins/atomic.add",e.atomic_sub="~lib/builtins/atomic.sub",e.atomic_and="~lib/builtins/atomic.and",e.atomic_or="~lib/builtins/atomic.or",e.atomic_xor="~lib/builtins/atomic.xor",e.atomic_xchg="~lib/builtins/atomic.xchg",e.atomic_cmpxchg="~lib/builtins/atomic.cmpxchg",e.atomic_wait="~lib/builtins/atomic.wait",e.atomic_notify="~lib/builtins/atomic.notify",e.sizeof="~lib/builtins/sizeof",e.alignof="~lib/builtins/alignof",e.offsetof="~lib/builtins/offsetof",e.select="~lib/builtins/select",e.unreachable="~lib/builtins/unreachable",e.changetype="~lib/builtins/changetype",e.assert="~lib/builtins/assert",e.unchecked="~lib/builtins/unchecked",e.call_direct="~lib/builtins/call_direct",e.call_indirect="~lib/builtins/call_indirect",e.instantiate="~lib/builtins/instantiate",e.idof="~lib/builtins/idof",e.i8="~lib/builtins/i8",e.i16="~lib/builtins/i16",e.i32="~lib/builtins/i32",e.i64="~lib/builtins/i64",e.isize="~lib/builtins/isize",e.u8="~lib/builtins/u8",e.u16="~lib/builtins/u16",e.u32="~lib/builtins/u32",e.u64="~lib/builtins/u64",e.usize="~lib/builtins/usize",e.bool="~lib/builtins/bool",e.f32="~lib/builtins/f32",e.f64="~lib/builtins/f64",e.v128="~lib/builtins/v128",e.void_="~lib/builtins/void",e.i32_clz="~lib/builtins/i32.clz",e.i64_clz="~lib/builtins/i64.clz",e.i32_ctz="~lib/builtins/i32.ctz",e.i64_ctz="~lib/builtins/i64.ctz",e.i32_popcnt="~lib/builtins/i32.popcnt",e.i64_popcnt="~lib/builtins/i64.popcnt",e.i32_rotl="~lib/builtins/i32.rotl",e.i64_rotl="~lib/builtins/i64.rotl",e.i32_rotr="~lib/builtins/i32.rotr",e.i64_rotr="~lib/builtins/i64.rotr",e.f32_abs="~lib/builtins/f32.abs",e.f64_abs="~lib/builtins/f64.abs",e.f32_max="~lib/builtins/f32.max",e.f64_max="~lib/builtins/f64.max",e.f32_min="~lib/builtins/f32.min",e.f64_min="~lib/builtins/f64.min",e.f32_ceil="~lib/builtins/f32.ceil",e.f64_ceil="~lib/builtins/f64.ceil",e.f32_floor="~lib/builtins/f32.floor",e.f64_floor="~lib/builtins/f64.floor",e.f32_copysign="~lib/builtins/f32.copysign",e.f64_copysign="~lib/builtins/f64.copysign",e.f32_nearest="~lib/builtins/f32.nearest",e.f64_nearest="~lib/builtins/f64.nearest",e.i32_reinterpret_f32="~lib/builtins/i32.reinterpret_f32",e.i64_reinterpret_f64="~lib/builtins/i64.reinterpret_f64",e.f32_reinterpret_i32="~lib/builtins/f32.reinterpret_i32",e.f64_reinterpret_i64="~lib/builtins/f64.reinterpret_i64",e.f32_sqrt="~lib/builtins/f32.sqrt",e.f64_sqrt="~lib/builtins/f64.sqrt",e.f32_trunc="~lib/builtins/f32.trunc",e.f64_trunc="~lib/builtins/f64.trunc",e.i32_load8_s="~lib/builtins/i32.load8_s",e.i32_load8_u="~lib/builtins/i32.load8_u",e.i32_load16_s="~lib/builtins/i32.load16_s",e.i32_load16_u="~lib/builtins/i32.load16_u",e.i32_load="~lib/builtins/i32.load",e.i64_load8_s="~lib/builtins/i64.load8_s",e.i64_load8_u="~lib/builtins/i64.load8_u",e.i64_load16_s="~lib/builtins/i64.load16_s",e.i64_load16_u="~lib/builtins/i64.load16_u",e.i64_load32_s="~lib/builtins/i64.load32_s",e.i64_load32_u="~lib/builtins/i64.load32_u",e.i64_load="~lib/builtins/i64.load",e.f32_load="~lib/builtins/f32.load",e.f64_load="~lib/builtins/f64.load",e.i32_store8="~lib/builtins/i32.store8",e.i32_store16="~lib/builtins/i32.store16",e.i32_store="~lib/builtins/i32.store",e.i64_store8="~lib/builtins/i64.store8",e.i64_store16="~lib/builtins/i64.store16",e.i64_store32="~lib/builtins/i64.store32",e.i64_store="~lib/builtins/i64.store",e.f32_store="~lib/builtins/f32.store",e.f64_store="~lib/builtins/f64.store",e.i32_atomic_load8_u="~lib/builtins/i32.atomic.load8_u",e.i32_atomic_load16_u="~lib/builtins/i32.atomic.load16_u",e.i32_atomic_load="~lib/builtins/i32.atomic.load",e.i64_atomic_load8_u="~lib/builtins/i64.atomic.load8_u",e.i64_atomic_load16_u="~lib/builtins/i64.atomic.load16_u",e.i64_atomic_load32_u="~lib/builtins/i64.atomic.load32_u",e.i64_atomic_load="~lib/builtins/i64.atomic.load",e.i32_atomic_store8="~lib/builtins/i32.atomic.store8",e.i32_atomic_store16="~lib/builtins/i32.atomic.store16",e.i32_atomic_store="~lib/builtins/i32.atomic.store",e.i64_atomic_store8="~lib/builtins/i64.atomic.store8",e.i64_atomic_store16="~lib/builtins/i64.atomic.store16",e.i64_atomic_store32="~lib/builtins/i64.atomic.store32",e.i64_atomic_store="~lib/builtins/i64.atomic.store",e.i32_atomic_rmw8_add_u="~lib/builtins/i32.atomic.rmw8.add_u",e.i32_atomic_rmw16_add_u="~lib/builtins/i32.atomic.rmw16.add_u",e.i32_atomic_rmw_add="~lib/builtins/i32.atomic.rmw.add",e.i64_atomic_rmw8_add_u="~lib/builtins/i64.atomic.rmw8.add_u",e.i64_atomic_rmw16_add_u="~lib/builtins/i64.atomic.rmw16.add_u",e.i64_atomic_rmw32_add_u="~lib/builtins/i64.atomic.rmw32.add_u",e.i64_atomic_rmw_add="~lib/builtins/i64.atomic.rmw.add",e.i32_atomic_rmw8_sub_u="~lib/builtins/i32.atomic.rmw8.sub_u",e.i32_atomic_rmw16_sub_u="~lib/builtins/i32.atomic.rmw16.sub_u",e.i32_atomic_rmw_sub="~lib/builtins/i32.atomic.rmw.sub",e.i64_atomic_rmw8_sub_u="~lib/builtins/i64.atomic.rmw8.sub_u",e.i64_atomic_rmw16_sub_u="~lib/builtins/i64.atomic.rmw16.sub_u",e.i64_atomic_rmw32_sub_u="~lib/builtins/i64.atomic.rmw32.sub_u",e.i64_atomic_rmw_sub="~lib/builtins/i64.atomic.rmw.sub",e.i32_atomic_rmw8_and_u="~lib/builtins/i32.atomic.rmw8.and_u",e.i32_atomic_rmw16_and_u="~lib/builtins/i32.atomic.rmw16.and_u",e.i32_atomic_rmw_and="~lib/builtins/i32.atomic.rmw.and",e.i64_atomic_rmw8_and_u="~lib/builtins/i64.atomic.rmw8.and_u",e.i64_atomic_rmw16_and_u="~lib/builtins/i64.atomic.rmw16.and_u",e.i64_atomic_rmw32_and_u="~lib/builtins/i64.atomic.rmw32.and_u",e.i64_atomic_rmw_and="~lib/builtins/i64.atomic.rmw.and",e.i32_atomic_rmw8_or_u="~lib/builtins/i32.atomic.rmw8.or_u",e.i32_atomic_rmw16_or_u="~lib/builtins/i32.atomic.rmw16.or_u",e.i32_atomic_rmw_or="~lib/builtins/i32.atomic.rmw.or",e.i64_atomic_rmw8_or_u="~lib/builtins/i64.atomic.rmw8.or_u",e.i64_atomic_rmw16_or_u="~lib/builtins/i64.atomic.rmw16.or_u",e.i64_atomic_rmw32_or_u="~lib/builtins/i64.atomic.rmw32.or_u",e.i64_atomic_rmw_or="~lib/builtins/i64.atomic.rmw.or",e.i32_atomic_rmw8_u_xor="~lib/builtins/i32.atomic.rmw8.xor_u",e.i32_atomic_rmw16_u_xor="~lib/builtins/i32.atomic.rmw16.xor_u",e.i32_atomic_rmw_xor="~lib/builtins/i32.atomic.rmw.xor",e.i64_atomic_rmw8_xor_u="~lib/builtins/i64.atomic.rmw8.xor_u",e.i64_atomic_rmw16_xor_u="~lib/builtins/i64.atomic.rmw16.xor_u",e.i64_atomic_rmw32_xor_u="~lib/builtins/i64.atomic.rmw32.xor_u",e.i64_atomic_rmw_xor="~lib/builtins/i64.atomic.rmw.xor",e.i32_atomic_rmw8_xchg_u="~lib/builtins/i32.atomic.rmw8.xchg_u",e.i32_atomic_rmw16_xchg_u="~lib/builtins/i32.atomic.rmw16.xchg_u",e.i32_atomic_rmw_xchg="~lib/builtins/i32.atomic.rmw.xchg",e.i64_atomic_rmw8_xchg_u="~lib/builtins/i64.atomic.rmw8.xchg_u",e.i64_atomic_rmw16_xchg_u="~lib/builtins/i64.atomic.rmw16.xchg_u",e.i64_atomic_rmw32_xchg_u="~lib/builtins/i64.atomic.rmw32.xchg_u",e.i64_atomic_rmw_xchg="~lib/builtins/i64.atomic.rmw.xchg",e.i32_atomic_rmw8_cmpxchg_u="~lib/builtins/i32.atomic.rmw8.cmpxchg_u",e.i32_atomic_rmw16_cmpxchg_u="~lib/builtins/i32.atomic.rmw16.cmpxchg_u",e.i32_atomic_rmw_cmpxchg="~lib/builtins/i32.atomic.rmw.cmpxchg",e.i64_atomic_rmw8_cmpxchg_u="~lib/builtins/i64.atomic.rmw8.cmpxchg_u",e.i64_atomic_rmw16_cmpxchg_u="~lib/builtins/i64.atomic.rmw16.cmpxchg_u",e.i64_atomic_rmw32_cmpxchg_u="~lib/builtins/i64.atomic.rmw32.cmpxchg_u",e.i64_atomic_rmw_cmpxchg="~lib/builtins/i64.atomic.rmw.cmpxchg",e.i32_wait="~lib/builtins/i32.wait",e.i64_wait="~lib/builtins/i64.wait",e.v128_splat="~lib/builtins/v128.splat",e.v128_extract_lane="~lib/builtins/v128.extract_lane",e.v128_replace_lane="~lib/builtins/v128.replace_lane",e.v128_shuffle="~lib/builtins/v128.shuffle",e.v128_load="~lib/builtins/v128.load",e.v128_store="~lib/builtins/v128.store",e.v128_add="~lib/builtins/v128.add",e.v128_sub="~lib/builtins/v128.sub",e.v128_mul="~lib/builtins/v128.mul",e.v128_div="~lib/builtins/v128.div",e.v128_neg="~lib/builtins/v128.neg",e.v128_add_saturate="~lib/builtins/v128.add_saturate",e.v128_sub_saturate="~lib/builtins/v128.sub_saturate",e.v128_shl="~lib/builtins/v128.shl",e.v128_shr="~lib/builtins/v128.shr",e.v128_and="~lib/builtins/v128.and",e.v128_or="~lib/builtins/v128.or",e.v128_xor="~lib/builtins/v128.xor",e.v128_not="~lib/builtins/v128.not",e.v128_bitselect="~lib/builtins/v128.bitselect",e.v128_any_true="~lib/builtins/v128.any_true",e.v128_all_true="~lib/builtins/v128.all_true",e.v128_min="~lib/builtins/v128.min",e.v128_max="~lib/builtins/v128.max",e.v128_abs="~lib/builtins/v128.abs",e.v128_sqrt="~lib/builtins/v128.sqrt",e.v128_eq="~lib/builtins/v128.eq",e.v128_ne="~lib/builtins/v128.ne",e.v128_lt="~lib/builtins/v128.lt",e.v128_le="~lib/builtins/v128.le",e.v128_gt="~lib/builtins/v128.gt",e.v128_ge="~lib/builtins/v128.ge",e.v128_convert="~lib/builtins/v128.convert",e.v128_trunc="~lib/builtins/v128.trunc",e.i8x16="~lib/builtins/i8x16",e.i16x8="~lib/builtins/i16x8",e.i32x4="~lib/builtins/i32x4",e.i64x2="~lib/builtins/i64x2",e.f32x4="~lib/builtins/f32x4",e.f64x2="~lib/builtins/f64x2",e.i8x16_splat="~lib/builtins/i8x16.splat",e.i8x16_extract_lane_s="~lib/builtins/i8x16.extract_lane_s",e.i8x16_extract_lane_u="~lib/builtins/i8x16.extract_lane_u",e.i8x16_replace_lane="~lib/builtins/i8x16.replace_lane",e.i8x16_add="~lib/builtins/i8x16.add",e.i8x16_sub="~lib/builtins/i8x16.sub",e.i8x16_mul="~lib/builtins/i8x16.mul",e.i8x16_neg="~lib/builtins/i8x16.neg",e.i8x16_add_saturate_s="~lib/builtins/i8x16.add_saturate_s",e.i8x16_add_saturate_u="~lib/builtins/i8x16.add_saturate_u",e.i8x16_sub_saturate_s="~lib/builtins/i8x16.sub_saturate_s",e.i8x16_sub_saturate_u="~lib/builtins/i8x16.sub_saturate_u",e.i8x16_shl="~lib/builtins/i8x16.shl",e.i8x16_shr_s="~lib/builtins/i8x16.shr_s",e.i8x16_shr_u="~lib/builtins/i8x16.shr_u",e.i8x16_any_true="~lib/builtins/i8x16.any_true",e.i8x16_all_true="~lib/builtins/i8x16.all_true",e.i8x16_eq="~lib/builtins/i8x16.eq",e.i8x16_ne="~lib/builtins/i8x16.ne",e.i8x16_lt_s="~lib/builtins/i8x16.lt_s",e.i8x16_lt_u="~lib/builtins/i8x16.lt_u",e.i8x16_le_s="~lib/builtins/i8x16.le_s",e.i8x16_le_u="~lib/builtins/i8x16.le_u",e.i8x16_gt_s="~lib/builtins/i8x16.gt_s",e.i8x16_gt_u="~lib/builtins/i8x16.gt_u",e.i8x16_ge_s="~lib/builtins/i8x16.ge_s",e.i8x16_ge_u="~lib/builtins/i8x16.ge_u",e.i16x8_splat="~lib/builtins/i16x8.splat",e.i16x8_extract_lane_s="~lib/builtins/i16x8.extract_lane_s",e.i16x8_extract_lane_u="~lib/builtins/i16x8.extract_lane_u",e.i16x8_replace_lane="~lib/builtins/i16x8.replace_lane",e.i16x8_add="~lib/builtins/i16x8.add",e.i16x8_sub="~lib/builtins/i16x8.sub",e.i16x8_mul="~lib/builtins/i16x8.mul",e.i16x8_neg="~lib/builtins/i16x8.neg",e.i16x8_add_saturate_s="~lib/builtins/i16x8.add_saturate_s",e.i16x8_add_saturate_u="~lib/builtins/i16x8.add_saturate_u",e.i16x8_sub_saturate_s="~lib/builtins/i16x8.sub_saturate_s",e.i16x8_sub_saturate_u="~lib/builtins/i16x8.sub_saturate_u",e.i16x8_shl="~lib/builtins/i16x8.shl",e.i16x8_shr_s="~lib/builtins/i16x8.shr_s",e.i16x8_shr_u="~lib/builtins/i16x8.shr_u",e.i16x8_any_true="~lib/builtins/i16x8.any_true",e.i16x8_all_true="~lib/builtins/i16x8.all_true",e.i16x8_eq="~lib/builtins/i16x8.eq",e.i16x8_ne="~lib/builtins/i16x8.ne",e.i16x8_lt_s="~lib/builtins/i16x8.lt_s",e.i16x8_lt_u="~lib/builtins/i16x8.lt_u",e.i16x8_le_s="~lib/builtins/i16x8.le_s",e.i16x8_le_u="~lib/builtins/i16x8.le_u",e.i16x8_gt_s="~lib/builtins/i16x8.gt_s",e.i16x8_gt_u="~lib/builtins/i16x8.gt_u",e.i16x8_ge_s="~lib/builtins/i16x8.ge_s",e.i16x8_ge_u="~lib/builtins/i16x8.ge_u",e.i32x4_splat="~lib/builtins/i32x4.splat",e.i32x4_extract_lane="~lib/builtins/i32x4.extract_lane",e.i32x4_replace_lane="~lib/builtins/i32x4.replace_lane",e.i32x4_add="~lib/builtins/i32x4.add",e.i32x4_sub="~lib/builtins/i32x4.sub",e.i32x4_mul="~lib/builtins/i32x4.mul",e.i32x4_neg="~lib/builtins/i32x4.neg",e.i32x4_shl="~lib/builtins/i32x4.shl",e.i32x4_shr_s="~lib/builtins/i32x4.shr_s",e.i32x4_shr_u="~lib/builtins/i32x4.shr_u",e.i32x4_any_true="~lib/builtins/i32x4.any_true",e.i32x4_all_true="~lib/builtins/i32x4.all_true",e.i32x4_eq="~lib/builtins/i32x4.eq",e.i32x4_ne="~lib/builtins/i32x4.ne",e.i32x4_lt_s="~lib/builtins/i32x4.lt_s",e.i32x4_lt_u="~lib/builtins/i32x4.lt_u",e.i32x4_le_s="~lib/builtins/i32x4.le_s",e.i32x4_le_u="~lib/builtins/i32x4.le_u",e.i32x4_gt_s="~lib/builtins/i32x4.gt_s",e.i32x4_gt_u="~lib/builtins/i32x4.gt_u",e.i32x4_ge_s="~lib/builtins/i32x4.ge_s",e.i32x4_ge_u="~lib/builtins/i32x4.ge_u",e.i32x4_trunc_s_f32x4_sat="~lib/builtins/i32x4.trunc_s_f32x4_sat",e.i32x4_trunc_u_f32x4_sat="~lib/builtins/i32x4.trunc_u_f32x4_sat",e.i64x2_splat="~lib/builtins/i64x2.splat",e.i64x2_extract_lane="~lib/builtins/i64x2.extract_lane",e.i64x2_replace_lane="~lib/builtins/i64x2.replace_lane",e.i64x2_add="~lib/builtins/i64x2.add",e.i64x2_sub="~lib/builtins/i64x2.sub",e.i64x2_neg="~lib/builtins/i64x2.neg",e.i64x2_shl="~lib/builtins/i64x2.shl",e.i64x2_shr_s="~lib/builtins/i64x2.shr_s",e.i64x2_shr_u="~lib/builtins/i64x2.shr_u",e.i64x2_any_true="~lib/builtins/i64x2.any_true",e.i64x2_all_true="~lib/builtins/i64x2.all_true",e.i64x2_trunc_s_f64x2_sat="~lib/builtins/i64x2.trunc_s_f64x2_sat",e.i64x2_trunc_u_f64x2_sat="~lib/builtins/i64x2.trunc_u_f64x2_sat",e.f32x4_splat="~lib/builtins/f32x4.splat",e.f32x4_extract_lane="~lib/builtins/f32x4.extract_lane",e.f32x4_replace_lane="~lib/builtins/f32x4.replace_lane",e.f32x4_add="~lib/builtins/f32x4.add",e.f32x4_sub="~lib/builtins/f32x4.sub",e.f32x4_mul="~lib/builtins/f32x4.mul",e.f32x4_div="~lib/builtins/f32x4.div",e.f32x4_neg="~lib/builtins/f32x4.neg",e.f32x4_min="~lib/builtins/f32x4.min",e.f32x4_max="~lib/builtins/f32x4.max",e.f32x4_abs="~lib/builtins/f32x4.abs",e.f32x4_sqrt="~lib/builtins/f32x4.sqrt",e.f32x4_eq="~lib/builtins/f32x4.eq",e.f32x4_ne="~lib/builtins/f32x4.ne",e.f32x4_lt="~lib/builtins/f32x4.lt",e.f32x4_le="~lib/builtins/f32x4.le",e.f32x4_gt="~lib/builtins/f32x4.gt",e.f32x4_ge="~lib/builtins/f32x4.ge",e.f32x4_convert_s_i32x4="~lib/builtins/f32x4.convert_s_i32x4",e.f32x4_convert_u_i32x4="~lib/builtins/f32x4.convert_u_i32x4",e.f64x2_splat="~lib/builtins/f64x2.splat",e.f64x2_extract_lane="~lib/builtins/f64x2.extract_lane",e.f64x2_replace_lane="~lib/builtins/f64x2.replace_lane",e.f64x2_add="~lib/builtins/f64x2.add",e.f64x2_sub="~lib/builtins/f64x2.sub",e.f64x2_mul="~lib/builtins/f64x2.mul",e.f64x2_div="~lib/builtins/f64x2.div",e.f64x2_neg="~lib/builtins/f64x2.neg",e.f64x2_min="~lib/builtins/f64x2.min",e.f64x2_max="~lib/builtins/f64x2.max",e.f64x2_abs="~lib/builtins/f64x2.abs",e.f64x2_sqrt="~lib/builtins/f64x2.sqrt",e.f64x2_eq="~lib/builtins/f64x2.eq",e.f64x2_ne="~lib/builtins/f64x2.ne",e.f64x2_lt="~lib/builtins/f64x2.lt",e.f64x2_le="~lib/builtins/f64x2.le",e.f64x2_gt="~lib/builtins/f64x2.gt",e.f64x2_ge="~lib/builtins/f64x2.ge",e.f64x2_convert_s_i64x2="~lib/builtins/f64x2.convert_s_i64x2",e.f64x2_convert_u_i64x2="~lib/builtins/f64x2.convert_u_i64x2",e.v8x16_shuffle="~lib/builtins/v8x16.shuffle",e.heap_base="~lib/heap/__heap_base",e.rtti_base="~lib/rt/__rtti_base",e.visit_globals="~lib/rt/__visit_globals",e.visit_members="~lib/rt/__visit_members",e.ERROR="~lib/diagnostics/ERROR",e.WARNING="~lib/diagnostics/WARNING",e.INFO="~lib/diagnostics/INFO",e.memory_size="~lib/memory/memory.size",e.memory_grow="~lib/memory/memory.grow",e.memory_copy="~lib/memory/memory.copy",e.memory_fill="~lib/memory/memory.fill",e.memory_allocate="~lib/memory/memory.allocate",e.memory_free="~lib/memory/memory.free",e.memory_reset="~lib/memory/memory.reset",e.runtime_instanceof="~lib/runtime/runtime.instanceof",e.runtime_flags="~lib/runtime/runtime.flags",e.runtime_allocate="~lib/util/runtime/allocate",e.runtime_reallocate="~lib/util/runtime/reallocate",e.runtime_register="~lib/util/runtime/register",e.runtime_discard="~lib/util/runtime/discard",e.runtime_makeArray="~lib/util/runtime/makeArray",e.Int8Array="~lib/typedarray/Int8Array",e.Uint8Array="~lib/typedarray/Uint8Array",e.Int16Array="~lib/typedarray/Int16Array",e.Uint16Array="~lib/typedarray/Uint16Array",e.Int32Array="~lib/typedarray/Int32Array",e.Uint32Array="~lib/typedarray/Uint32Array",e.Int64Array="~lib/typedarray/Int64Array",e.Uint64Array="~lib/typedarray/Uint64Array",e.Uint8ClampedArray="~lib/typedarray/Uint8ClampedArray",e.Float32Array="~lib/typedarray/Float32Array",e.Float64Array="~lib/typedarray/Float64Array",e.started="~lib/started",e.argc="~lib/argc",e.setargc="~lib/setargc",e.capabilities="~lib/capabilities"}(a=r.BuiltinSymbols||(r.BuiltinSymbols={})),r.compileCall=m,r.compileAbort=T,r.compileVisitGlobals=function(e){var r,t,i=e.module,s=new Array,o=e.ensureFunctionType([l.Type.u32],l.Type.void),c=e.options.nativeSizeType,_=assert(e.program.visitInstance);e.compileFunction(_);try{for(var h=n(e.program.elementsByName.values()),y=h.next();!y.done;y=h.next()){var m=y.value;if(m.kind==p.ElementKind.GLOBAL){var f=m,T=f.type.classReference;if(f.is(d.CommonFlags.COMPILED)&&null!==T&&!T.hasDecorator(p.DecoratorFlags.UNMANAGED))if(f.is(d.CommonFlags.INLINED)){var g=f.constantIntegerValue;(i64_low(g)||i64_high(g))&&s.push(i.call(_.internalName,[e.options.isWasm64?i.i64(i64_low(g),i64_high(g)):i.i32(i64_low(g))],u.NativeType.None))}else s.push(i.if(i.local_tee(1,i.global_get(f.internalName,c)),i.call(_.internalName,[i.local_get(1,c),i.local_get(0,u.NativeType.I32)],u.NativeType.None)))}}}catch(e){r={error:e}}finally{try{y&&!y.done&&(t=h.return)&&t.call(h)}finally{if(r)throw r.error}}i.addFunction(a.visit_globals,o,[c],s.length?i.block(null,s):i.nop())},r.compileVisitMembers=function(e){var r,t,o,c,_,h,d=e.program,y=e.module,m=d.options.usizeType,f=m.toNativeType(),T=m.byteSize,g=e.ensureFunctionType([m,l.Type.i32],l.Type.void),E=d.managedClasses,v=assert(d.visitInstance),b=new Array,I=u.Relooper.create(y),x=I.addBlockWithSwitch(y.nop(),y.load(T,!1,f==u.NativeType.I64?y.binary(u.BinaryOp.SubI64,y.local_get(0,f),y.i64(8)):y.binary(u.BinaryOp.SubI32,y.local_get(0,f),y.i32(8)),u.NativeType.I32,0)),A=0;try{for(var N=n(E),S=N.next();!S.done;S=N.next()){var O=i(S.value,2),C=O[0],k=O[1];assert(k.type.isManaged),assert(C==A++);var L=void 0,R=new Array;if(k.isDeclaredInLibrary&&(L=k.lookupInSelf("__visit_impl"))){assert(L.kind==p.ElementKind.FUNCTION_PROTOTYPE);var F=d.resolver.resolveFunction(L,null);if(F&&e.compileFunction(F)){var B=F.signature;assert(1==B.parameterTypes.length&&B.parameterTypes[0]==l.Type.u32&&B.returnType==l.Type.void&&B.thisType==k.type),R.push(y.call(F.internalName,[y.local_get(0,f),y.local_get(1,u.NativeType.I32)],u.NativeType.None))}else R.push(y.unreachable())}else{var D=k.members;if(D)try{for(var P=(o=void 0,n(D.values())),w=P.next();!w.done;w=P.next()){var U=w.value;if(U.kind==p.ElementKind.FIELD&&U.parent===k&&U.type.isManaged){var M=U.memoryOffset;assert(M>=0),R.push(y.if(y.local_tee(2,y.load(T,!1,y.local_get(0,f),f,M)),y.call(v.internalName,[y.local_get(2,f),y.local_get(1,u.NativeType.I32)],u.NativeType.None)))}}}catch(e){o={error:e}}finally{try{w&&!w.done&&(c=P.return)&&c.call(P)}finally{if(o)throw o.error}}}k.base||R.push(y.return());var V=I.addBlock(s.flatten(y,R,u.NativeType.None));I.addBranchForSwitch(x,V,[C]),b.push(V)}}catch(e){r={error:e}}finally{try{S&&!S.done&&(t=N.return)&&t.call(N)}finally{if(r)throw r.error}}try{for(var G=n(E),K=G.next();!K.done;K=G.next()){var z=i(K.value,2),Y=(C=z[0],(k=z[1]).base);Y&&I.addBranch(b[C],b[Y.id])}}catch(e){_={error:e}}finally{try{K&&!K.done&&(h=G.return)&&h.call(G)}finally{if(_)throw _.error}}b.push(I.addBlock(y.unreachable())),I.addBranchForSwitch(x,b[b.length-1],[]),e.compileFunction(v),y.addFunction(a.visit_members,g,[f],I.renderAndDispose(x,2))},r.compileRTTI=function(e){var r,t,s=e.program,o=e.module,c=s.managedClasses,l=c.size,p=4+8*l,_=new Uint8Array(p);y.writeI32(l,_,0);var h=4,d=s.arrayBufferViewInstance,m=d.prototype,f=s.arrayPrototype,T=s.setPrototype,E=s.mapPrototype,v=0;try{for(var b=n(c),I=b.next();!I.done;I=b.next()){var x=i(I.value,2),A=x[0],N=x[1];assert(A==v++);var S=0;if(N.isAcyclic&&(S|=16),N!==d&&N.extends(m)){var O=N.getArrayValueType();S|=1,N.extends(f)&&(S|=2),S|=32*g(O)}else if(N.extends(T)){var C=assert(N.getTypeArgumentsTo(T));assert(1==C.length),S|=4,S|=32*g(C[0])}else N.extends(E)&&(C=assert(N.getTypeArgumentsTo(E)),assert(2==C.length),S|=8,S|=16384*g(C[0]),S|=32*g(C[1]));y.writeI32(S,_,h),h+=4,N.rttiFlags=S;var k=N.base;y.writeI32(k?k.id:0,_,h),h+=4}}catch(e){r={error:e}}finally{try{I&&!I.done&&(t=b.return)&&t.call(b)}finally{if(r)throw r.error}}assert(h==p);var L=s.options.usizeType,R=e.addMemorySegment(_);if(8==L.size){var F=R.offset;o.addGlobal(a.rtti_base,u.NativeType.I64,!1,o.i64(i64_low(F),i64_high(F)))}else o.addGlobal(a.rtti_base,u.NativeType.I32,!1,o.i32(i64_low(R.offset)))}},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n=t(4),i=function(){function e(){this.text=[],this.functionId=0}return e.decompile=function(r){var t=new e;return t.decompile(r),t.finish()},e.prototype.decompile=function(e){throw new Error("not implemented")},e.prototype.decompileFunction=function(e){var r=n.getFunctionName(e)||"$"+this.functionId.toString(10),t=n.getFunctionBody(e);this.push("function "),this.push(r),this.push("(");for(var i=0,s=n.getFunctionParamCount(e);i0&&this.push(", "),this.push("$"),this.push(i.toString(10)),this.push(": "),this.push(a(n.getFunctionParamType(e,i)));this.push("): "),this.push(a(n.getFunctionResultType(e))),this.push(" "),n.getExpressionId(t)!=n.ExpressionId.Block&&this.push("{\n"),this.decompileExpression(t),n.getExpressionId(t)!=n.ExpressionId.Block&&this.push("\n}\n"),++this.functionId},e.prototype.decompileExpression=function(e){var r,t,i,s,o=n.getExpressionId(e),c=n.getExpressionType(e);switch(o){case n.ExpressionId.Block:for(null!=(t=n.getBlockName(e))&&(this.push(t),this.push(": ")),this.push("{\n"),s=n.getBlockChildCount(e),i=0;i("),this.push(n.getLoadOffset(e).toString(10)),this.push(" + "),this.decompileExpression(n.getLoadPtr(e)),void this.push(")");case n.ExpressionId.Store:return this.push("store<"),this.push(a(c)),this.push(">("),this.push(n.getStoreOffset(e).toString(10)),this.push(" + "),this.decompileExpression(n.getStorePtr(e)),this.push(", "),this.decompileExpression(n.getStoreValue(e)),void this.push(")");case n.ExpressionId.Const:switch(c){case n.NativeType.I32:return void this.push(n.getConstValueI32(e).toString(10));case n.NativeType.I64:return void this.push(i64_to_string(i64_new(n.getConstValueI64Low(e),n.getConstValueI64High(e))));case n.NativeType.F32:return void this.push(n.getConstValueF32(e).toString(10));case n.NativeType.F64:return void this.push(n.getConstValueF64(e).toString(10))}break;case n.ExpressionId.Unary:switch(n.getUnaryOp(e)){case n.UnaryOp.ClzI32:return this.push("clz("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.CtzI32:return this.push("ctz("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.PopcntI32:return this.push("popcnt("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.NegF32:case n.UnaryOp.NegF64:return this.push("-"),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.AbsF32:return this.push("abs("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.CeilF32:return this.push("ceil("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.FloorF32:return this.push("floor("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.TruncF32:return this.push("trunc("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.NearestF32:return this.push("nearest("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.SqrtF32:return this.push("sqrt("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.EqzI32:case n.UnaryOp.EqzI64:return this.push("!"),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ClzI64:return this.push("clz("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.CtzI64:return this.push("ctz("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.PopcntI64:return this.push("popcnt("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.AbsF64:return this.push("abs("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.CeilF64:return this.push("ceil("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.FloorF64:return this.push("floor("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.TruncF64:return this.push("trunc("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.NearestF64:return this.push("nearest("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.SqrtF64:return this.push("sqrt("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.ExtendI32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ExtendU32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.WrapI64:case n.UnaryOp.TruncF32ToI32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF32ToI64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF32ToU32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF32ToU64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF64ToI32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF64ToI64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF64ToU32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.TruncF64ToU64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ReinterpretF32:return this.push("reinterpret("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.ReinterpretF64:return this.push("reinterpret("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.ConvertI32ToF32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertI32ToF64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertU32ToF32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertU32ToF64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertI64ToF32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertI64ToF64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertU64ToF32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ConvertU64ToF64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.PromoteF32:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.DemoteF64:return this.push(""),void this.decompileExpression(n.getUnaryValue(e));case n.UnaryOp.ReinterpretI32:return this.push("reinterpret("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")");case n.UnaryOp.ReinterpretI64:return this.push("reinterpret("),this.decompileExpression(n.getUnaryValue(e)),void this.push(")")}break;case n.ExpressionId.Binary:switch(n.getBinaryOp(e)){case n.BinaryOp.AddI32:case n.BinaryOp.AddI64:case n.BinaryOp.AddF32:case n.BinaryOp.AddF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" + "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.SubI32:case n.BinaryOp.SubI64:case n.BinaryOp.SubF32:case n.BinaryOp.SubF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" - "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.MulI32:case n.BinaryOp.MulI64:case n.BinaryOp.MulF32:case n.BinaryOp.MulF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" * "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.DivI32:case n.BinaryOp.DivI64:case n.BinaryOp.DivF32:case n.BinaryOp.DivF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" / "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.DivU32:return this.push("("),this.decompileExpression(n.getBinaryLeft(e)),this.push(" / "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.RemI32:case n.BinaryOp.RemI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" % "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.RemU32:return this.push("("),this.decompileExpression(n.getBinaryLeft(e)),this.push(" / "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.AndI32:case n.BinaryOp.AndI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" & "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.OrI32:case n.BinaryOp.OrI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" | "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.XorI32:case n.BinaryOp.XorI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" ^ "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.ShlI32:case n.BinaryOp.ShlI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" << "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.ShrU32:case n.BinaryOp.ShrU64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" >>> "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.ShrI32:case n.BinaryOp.ShrI64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" >> "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.RotlI32:return this.push("rotl("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.RotrI32:return this.push("rotr("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.EqI32:case n.BinaryOp.EqI64:case n.BinaryOp.EqF32:case n.BinaryOp.EqF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" == "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.NeI32:case n.BinaryOp.NeI64:case n.BinaryOp.NeF32:case n.BinaryOp.NeF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" != "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.LtI32:case n.BinaryOp.LtI64:case n.BinaryOp.LtF32:case n.BinaryOp.LtF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" < "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.LtU32:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" < "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.LeI32:case n.BinaryOp.LeI64:case n.BinaryOp.LeF32:case n.BinaryOp.LeF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" <= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.LeU32:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" <= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GtI32:case n.BinaryOp.GtI64:case n.BinaryOp.GtF32:case n.BinaryOp.GtF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" > "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GtU32:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" > "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GeI32:case n.BinaryOp.GeI64:case n.BinaryOp.GeF32:case n.BinaryOp.GeF64:return this.decompileExpression(n.getBinaryLeft(e)),this.push(" >= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GeU32:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" >= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.DivU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" / "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.RemU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" % "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.RotlI64:return this.push("rotl("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.RotrI64:return this.push("rotr("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.LtU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" < "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.LeU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" <= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GtU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" > "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.GeU64:return this.push(""),this.decompileExpression(n.getBinaryLeft(e)),this.push(" >= "),void this.decompileExpression(n.getBinaryRight(e));case n.BinaryOp.CopysignF32:return this.push("copysign("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.MinF32:return this.push("min("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.MaxF32:return this.push("max("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.CopysignF64:return this.push("copysign("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.MinF64:return this.push("min("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")");case n.BinaryOp.MaxF64:return this.push("max("),this.decompileExpression(n.getBinaryLeft(e)),this.push(", "),this.decompileExpression(n.getBinaryRight(e)),void this.push(")")}return;case n.ExpressionId.Select:return this.push("select<"),this.push(a(c)),this.push(">("),this.decompileExpression(n.getSelectThen(e)),this.push(", "),this.decompileExpression(n.getSelectElse(e)),this.push(", "),this.decompileExpression(n.getSelectCondition(e)),void this.push(")");case n.ExpressionId.Drop:return this.decompileExpression(n.getDropValue(e)),void this.push(";\n");case n.ExpressionId.Return:return void((r=n.getReturnValue(e))?(this.push("return "),this.decompileExpression(r),this.push(";\n")):this.push("return;\n"));case n.ExpressionId.Host:switch(n.getHostOp(e)){case n.HostOp.MemorySize:return void this.push("memory.size()");case n.HostOp.MemoryGrow:return this.push("memory.grow("),this.decompileExpression(n.getHostOperand(e,0)),void this.push(")")}break;case n.ExpressionId.Nop:return void this.push(";\n");case n.ExpressionId.Unreachable:return void this.push("unreachable()");case n.ExpressionId.AtomicCmpxchg:case n.ExpressionId.AtomicRMW:case n.ExpressionId.AtomicWait:case n.ExpressionId.AtomicNotify:}throw new Error("not implemented")},e.prototype.push=function(e){this.text.push(e)},e.prototype.finish=function(){var e=this.text.join("");return this.text=[],e},e}();function a(e){switch(e){case n.NativeType.None:return"void";case n.NativeType.I32:return"i32";case n.NativeType.I64:return"i64";case n.NativeType.F32:return"f32";case n.NativeType.F64:return"f64";case n.NativeType.V128:return"v128";case n.NativeType.Unreachable:throw new Error("unreachable type");case n.NativeType.Auto:throw new Error("auto type");default:throw new Error("unexpected type")}}r.Decompiler=i},function(e,r,t){"use strict";var n,i=this&&this.__extends||(n=function(e,r){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,r){e.__proto__=r}||function(e,r){for(var t in r)r.hasOwnProperty(t)&&(e[t]=r[t])})(e,r)},function(e,r){function t(){this.constructor=e}n(e,r),e.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)}),a=this&&this.__values||function(e){var r="function"==typeof Symbol&&e[Symbol.iterator],t=0;return r?r.call(e):{next:function(){return e&&t>=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},s=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0});var o=t(0),c=t(3),l=t(1),u=function(){function e(e,r){void 0===r&&(r=!1),this.seen=new Map,this.program=e,this.includePrivate}return e.prototype.walk=function(){var e,r;try{for(var t=a(this.program.filesByName.values()),n=t.next();!n.done;n=t.next()){var i=n.value;i.source.isEntry&&this.visitFile(i)}}catch(r){e={error:r}}finally{try{n&&!n.done&&(r=t.return)&&r.call(t)}finally{if(e)throw e.error}}},e.prototype.visitFile=function(e){var r,t,n,i,o=e.exports;if(o)try{for(var c=a(o),l=c.next();!l.done;l=c.next()){var u=s(l.value,2),p=u[0],_=u[1];this.visitElement(p,_)}}catch(e){r={error:e}}finally{try{l&&!l.done&&(t=c.return)&&t.call(c)}finally{if(r)throw r.error}}var h=e.exportsStar;if(h)try{for(var d=a(h),y=d.next();!y.done;y=d.next()){var m=y.value;this.visitFile(m)}}catch(e){n={error:e}}finally{try{y&&!y.done&&(i=d.return)&&i.call(d)}finally{if(n)throw n.error}}},e.prototype.visitElement=function(e,r){if(!r.is(o.CommonFlags.PRIVATE)||this.includePrivate){var t=this.seen;if(t.has(r))this.visitAlias(e,r,t.get(r));else switch(t.set(r,e),r.kind){case c.ElementKind.GLOBAL:r.is(o.CommonFlags.COMPILED)&&this.visitGlobal(e,r);break;case c.ElementKind.ENUM:r.is(o.CommonFlags.COMPILED)&&this.visitEnum(e,r);break;case c.ElementKind.FUNCTION_PROTOTYPE:this.visitFunctionInstances(e,r);break;case c.ElementKind.CLASS_PROTOTYPE:this.visitClassInstances(e,r);break;case c.ElementKind.FIELD:r.is(o.CommonFlags.COMPILED)&&this.visitField(e,r);break;case c.ElementKind.PROPERTY_PROTOTYPE:this.visitPropertyInstances(e,r);break;case c.ElementKind.PROPERTY:var n=r,i=n.getterInstance;i&&this.visitFunction(e,i);var s=n.setterInstance;s&&this.visitFunction(e,s);break;case c.ElementKind.NAMESPACE:(function e(r){var t,n,i,s,l,u;var p=r.members;if(p)try{for(var _=a(p.values()),h=_.next();!h.done;h=_.next()){var d=h.value;switch(d.kind){case c.ElementKind.FUNCTION_PROTOTYPE:var y=d.instances;if(y)try{for(var m=(i=void 0,a(y.values())),f=m.next();!f.done;f=m.next()){var T=f.value;if(T.is(o.CommonFlags.COMPILED))return!0}}catch(e){i={error:e}}finally{try{f&&!f.done&&(s=m.return)&&s.call(m)}finally{if(i)throw i.error}}break;case c.ElementKind.CLASS_PROTOTYPE:var y=d.instances;if(y)try{for(var g=(l=void 0,a(y.values())),E=g.next();!E.done;E=g.next()){var T=E.value;if(T.is(o.CommonFlags.COMPILED))return!0}}catch(e){l={error:e}}finally{try{E&&!E.done&&(u=g.return)&&u.call(g)}finally{if(l)throw l.error}}break;default:if(d.is(o.CommonFlags.COMPILED)||e(d))return!0}}}catch(e){t={error:e}}finally{try{h&&!h.done&&(n=_.return)&&n.call(_)}finally{if(t)throw t.error}}return!1})(r)&&this.visitNamespace(e,r);break;case c.ElementKind.TYPEDEFINITION:break;default:assert(!1)}}},e.prototype.visitFunctionInstances=function(e,r){var t,n,i=r.instances;if(i)try{for(var s=a(i.values()),c=s.next();!c.done;c=s.next()){var l=c.value;l.is(o.CommonFlags.COMPILED)&&this.visitFunction(e,l)}}catch(e){t={error:e}}finally{try{c&&!c.done&&(n=s.return)&&n.call(s)}finally{if(t)throw t.error}}},e.prototype.visitClassInstances=function(e,r){var t,n,i=r.instances;if(i)try{for(var s=a(i.values()),c=s.next();!c.done;c=s.next()){var l=c.value;l.is(o.CommonFlags.COMPILED)&&this.visitClass(e,l)}}catch(e){t={error:e}}finally{try{c&&!c.done&&(n=s.return)&&n.call(s)}finally{if(t)throw t.error}}},e.prototype.visitPropertyInstances=function(e,r){assert(!1)},e}(),p=function(e){function r(r,t){void 0===t&&(t=!1);var n=e.call(this,r,t)||this;return n.sb=[],n.indentLevel=0,n}return i(r,e),r.build=function(e){return new r(e).build()},r.prototype.visitGlobal=function(e,r){var t=this.sb,n=r.is(o.CommonFlags.INLINED);if(l.indent(t,this.indentLevel),n&&t.push("const "),t.push(this.typeToString(r.type)),t.push(" "),t.push(e),n)switch(r.constantValueKind){case 1:t.push(" = "),t.push(i64_to_string(r.constantIntegerValue));break;case 2:t.push(" = "),t.push(r.constantFloatValue.toString());break;default:assert(!1)}t.push(";\n")},r.prototype.visitEnum=function(e,r){var t,n,i,u,p=this.sb;l.indent(p,this.indentLevel++),p.push("interface "),p.push(e),p.push(" {\n");var _=r.members;if(_){try{for(var h=a(_),d=h.next();!d.done;d=h.next()){var y=s(d.value,2),m=y[0];if((E=y[1]).kind==c.ElementKind.ENUMVALUE){var f=E.is(o.CommonFlags.INLINED);l.indent(p,this.indentLevel),f?p.push("const "):p.push("readonly "),p.push("unsigned long "),p.push(m),f&&(p.push(" = "),assert(1==E.constantValueKind),p.push(i64_low(E.constantIntegerValue).toString(10))),p.push(";\n")}}}catch(e){t={error:e}}finally{try{d&&!d.done&&(n=h.return)&&n.call(h)}finally{if(t)throw t.error}}try{for(var T=a(_.values()),g=T.next();!g.done;g=T.next()){var E;(E=g.value).kind!=c.ElementKind.ENUMVALUE&&this.visitElement(E.name,E)}}catch(e){i={error:e}}finally{try{g&&!g.done&&(u=T.return)&&u.call(T)}finally{if(i)throw i.error}}}l.indent(p,--this.indentLevel),p.push("}\n")},r.prototype.visitFunction=function(e,r){var t,n,i=this.sb,s=r.signature;l.indent(i,this.indentLevel),i.push(this.typeToString(s.returnType)),i.push(" "),i.push(e),i.push("(");for(var o=s.parameterTypes,c=o.length,u=0;u"),null}for(;e.skip(o.Token.BAR);){if(!e.skip(o.Token.NULL))return t||this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"null"),null;y=!0}n=u.Node.createNamedType(_,d||[],y,e.range(a,e.pos))}for(;e.skip(o.Token.OPENBRACKET);){var T=e.tokenPos;if(!e.skip(o.Token.CLOSEBRACKET))return t||this.error(c.DiagnosticCode._0_expected,e.range(),"]"),null;var g=e.range(T,e.pos);y=!1;if(e.skip(o.Token.BAR)){if(!e.skip(o.Token.NULL))return t||this.error(c.DiagnosticCode._0_expected,e.range(),"null"),null;y=!0}if(n=u.Node.createNamedType(u.Node.createSimpleTypeName("Array",g),[n],y,e.range(a,e.pos)),y)break}return n},r.prototype.tryParseFunctionType=function(e){var r,t=e.mark(),n=e.tokenPos,i=null,a=null,s=!1;if(e.skip(o.Token.CLOSEPAREN))s=!0,e.discard(t),i=[];else{s=!1;do{var l=u.ParameterKind.DEFAULT;if(e.skip(o.Token.DOT_DOT_DOT)&&(s=!0,e.discard(t),l=u.ParameterKind.REST),e.skip(o.Token.THIS)){if(!e.skip(o.Token.COLON))return e.reset(t),this.tryParseSignatureIsSignature=!1,null;s=!0,e.discard(t);var p=this.parseType(e,!1);if(!p)return null;if(p.kind!=u.NodeKind.NAMEDTYPE)return this.error(c.DiagnosticCode.Operation_not_supported,p.range),this.tryParseSignatureIsSignature=!0,null;a=p}else{if(!e.skipIdentifier())return s?this.error(c.DiagnosticCode.Identifier_expected,e.range()):e.reset(t),this.tryParseSignatureIsSignature=s,null;var _=u.Node.createIdentifierExpression(e.readIdentifier(),e.range(e.tokenPos,e.pos));if(e.skip(o.Token.QUESTION)&&(s=!0,e.discard(t),l==u.ParameterKind.REST?this.error(c.DiagnosticCode.A_rest_parameter_cannot_be_optional,e.range()):l=u.ParameterKind.OPTIONAL),e.skip(o.Token.COLON)){s=!0,e.discard(t);var h=this.parseType(e);if(!h)return this.tryParseSignatureIsSignature=s,null;var d=new u.ParameterNode;d.parameterKind=l,d.name=_,d.type=h,i?i.push(d):i=[d]}else s&&this.error(c.DiagnosticCode.Type_expected,e.range())}}while(e.skip(o.Token.COMMA));if(!e.skip(o.Token.CLOSEPAREN))return s?this.error(c.DiagnosticCode._0_expected,e.range(),")"):e.reset(t),this.tryParseSignatureIsSignature=s,null}return e.skip(o.Token.EQUALS_GREATERTHAN)?(s=!0,e.discard(t),(r=this.parseType(e))?(this.tryParseSignatureIsSignature=!0,u.Node.createFunctionType(i||[],r,a,!1,e.range(n,e.pos))):(this.tryParseSignatureIsSignature=s,null)):(s?this.error(c.DiagnosticCode._0_expected,e.range(),"=>"):e.reset(t),this.tryParseSignatureIsSignature=s,null)},r.prototype.parseDecorator=function(e){var r=e.tokenPos;if(e.skipIdentifier()){for(var t=e.readIdentifier(),n=u.Node.createIdentifierExpression(t,e.range(r,e.pos));e.skip(o.Token.DOT);){if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;t=e.readIdentifier(),n=u.Node.createPropertyAccessExpression(n,u.Node.createIdentifierExpression(t,e.range()),e.range(r,e.pos))}var i=void 0;if(!e.skip(o.Token.OPENPAREN))return u.Node.createDecorator(n,null,e.range(r,e.pos));if(i=this.parseArguments(e))return u.Node.createDecorator(n,i,e.range(r,e.pos))}else this.error(c.DiagnosticCode.Identifier_expected,e.range());return null},r.prototype.parseVariable=function(e,r,t,n){var i=new Array;do{var a=this.parseVariableDeclaration(e,r,t);if(!a)return null;i.push(a)}while(e.skip(o.Token.COMMA));var s=u.Node.createVariableStatement(i,t,e.range(n,e.pos));return e.skip(o.Token.SEMICOLON),s},r.prototype.parseVariableDeclaration=function(e,r,t){if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;var n=u.Node.createIdentifierExpression(e.readIdentifier(),e.range());o.isIllegalVariableIdentifier(n.text)&&this.error(c.DiagnosticCode.Identifier_expected,n.range);var i=r;e.skip(o.Token.EXCLAMATION)&&(i|=a.CommonFlags.DEFINITE_ASSIGNMENT);var s=null;e.skip(o.Token.COLON)&&(s=this.parseType(e));var l=null;if(e.skip(o.Token.EQUALS)){if(i&a.CommonFlags.AMBIENT&&this.error(c.DiagnosticCode.Initializers_are_not_allowed_in_ambient_contexts,e.range()),!(l=this.parseExpression(e,2)))return null}else i&a.CommonFlags.CONST?i&a.CommonFlags.AMBIENT||this.error(c.DiagnosticCode._const_declarations_must_be_initialized,n.range):s||this.error(c.DiagnosticCode.Type_expected,e.range(e.pos));var p=o.Range.join(n.range,e.range());return i&a.CommonFlags.DEFINITE_ASSIGNMENT&&l&&this.error(c.DiagnosticCode.A_definite_assignment_assertion_is_not_permitted_in_this_context,p),u.Node.createVariableDeclaration(n,s,l,t,i,p)},r.prototype.parseEnum=function(e,r,t,n){if(e.next()!=o.Token.IDENTIFIER)return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;var i=u.Node.createIdentifierExpression(e.readIdentifier(),e.range());if(e.next()!=o.Token.OPENBRACE)return this.error(c.DiagnosticCode._0_expected,e.range(),"{"),null;for(var s=new Array;!e.skip(o.Token.CLOSEBRACE);){var l=this.parseEnumValue(e,a.CommonFlags.NONE);if(!l)return null;if(s.push(l),!e.skip(o.Token.COMMA)){if(e.skip(o.Token.CLOSEBRACE))break;return this.error(c.DiagnosticCode._0_expected,e.range(),"}"),null}}var p=u.Node.createEnumDeclaration(i,s,t,r,e.range(n,e.pos));return e.skip(o.Token.SEMICOLON),p},r.prototype.parseEnumValue=function(e,r){if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;var t=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),n=null;return e.skip(o.Token.EQUALS)&&!(n=this.parseExpression(e,2))?null:u.Node.createEnumValueDeclaration(t,n,r,o.Range.join(t.range,e.range()))},r.prototype.parseReturn=function(e){var r=null;if(e.peek(!0)!=o.Token.SEMICOLON&&e.nextToken!=o.Token.CLOSEBRACE&&!e.nextTokenOnNewLine&&!(r=this.parseExpression(e)))return null;var t=u.Node.createReturnStatement(r,e.range());return e.skip(o.Token.SEMICOLON),t},r.prototype.parseTypeParameters=function(e){for(var r=null,t=!1;!e.skip(o.Token.GREATERTHAN);){var n=this.parseTypeParameter(e);if(!n)return null;if(null!==n.defaultType?t=!0:t&&(this.error(c.DiagnosticCode.Required_type_parameters_may_not_follow_optional_type_parameters,n.range),n.defaultType=null),r?r.push(n):r=[n],!e.skip(o.Token.COMMA)){if(e.skip(o.Token.GREATERTHAN))break;return this.error(c.DiagnosticCode._0_expected,e.range(),">"),null}}return r&&r.length||this.error(c.DiagnosticCode.Type_parameter_list_cannot_be_empty,e.range()),r},r.prototype.parseTypeParameter=function(e){if(e.next()==o.Token.IDENTIFIER){var r=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),t=null;if(e.skip(o.Token.EXTENDS)){if(!(i=this.parseType(e)))return null;if(i.kind!=u.NodeKind.NAMEDTYPE)return this.error(c.DiagnosticCode.Operation_not_supported,i.range),null;t=i}var n=null;if(e.skip(o.Token.EQUALS)){var i;if(!(i=this.parseType(e)))return null;if(i.kind!=u.NodeKind.NAMEDTYPE)return this.error(c.DiagnosticCode.Operation_not_supported,i.range),null;n=i}return u.Node.createTypeParameter(r,t,n,o.Range.join(r.range,e.range()))}return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null},r.prototype.parseParameters=function(e,r){void 0===r&&(r=!1);var t=new Array,n=null,i=!1,a=!1,s=null;if(this.parseParametersThis=null,e.skip(o.Token.THIS)){if(!e.skip(o.Token.COLON))return this.error(c.DiagnosticCode._0_expected,e.range(),":"),null;if(!(s=this.parseType(e)))return null;if(s.kind==u.NodeKind.NAMEDTYPE?this.parseParametersThis=s:this.error(c.DiagnosticCode.Operation_not_supported,s.range),!e.skip(o.Token.COMMA))return e.skip(o.Token.CLOSEPAREN)?t:(this.error(c.DiagnosticCode._0_expected,e.range(),")"),null)}for(;!e.skip(o.Token.CLOSEPAREN);){var l=this.parseParameter(e,r);if(!l)return null;switch(n&&!a&&(this.error(c.DiagnosticCode.A_rest_parameter_must_be_last_in_a_parameter_list,n.name.range),a=!0),l.parameterKind){default:i&&this.error(c.DiagnosticCode.A_required_parameter_cannot_follow_an_optional_parameter,l.name.range);break;case u.ParameterKind.OPTIONAL:i=!0;break;case u.ParameterKind.REST:n=l}if(t.push(l),!e.skip(o.Token.COMMA)){if(e.skip(o.Token.CLOSEPAREN))break;return this.error(c.DiagnosticCode._0_expected,e.range(),")"),null}}return t},r.prototype.parseParameter=function(e,r){void 0===r&&(r=!1);var t=!1,n=!1,i=null,s=a.CommonFlags.NONE;if(r&&(e.skip(o.Token.PUBLIC)?(i=e.range(),s|=a.CommonFlags.PUBLIC):e.skip(o.Token.PROTECTED)?(i=e.range(),s|=a.CommonFlags.PROTECTED):e.skip(o.Token.PRIVATE)&&(i=e.range(),s|=a.CommonFlags.PRIVATE),e.peek()==o.Token.READONLY)){var l=e.mark();e.next(),e.peek()!=o.Token.COLON?(e.discard(l),i||(i=e.range()),s|=a.CommonFlags.READONLY):e.reset(l)}if(e.skip(o.Token.DOT_DOT_DOT)&&(s?this.error(c.DiagnosticCode.A_parameter_property_cannot_be_declared_using_a_rest_parameter,e.range()):i=e.range(),t=!0),e.skipIdentifier()){t||(i=e.range());var p=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),_=null;if((n=e.skip(o.Token.QUESTION))&&t&&this.error(c.DiagnosticCode.A_rest_parameter_cannot_be_optional,p.range),e.skip(o.Token.COLON)){if(!(_=this.parseType(e)))return null}else _=u.Node.createOmittedType(e.range(e.pos));var h=null;if(e.skip(o.Token.EQUALS)&&(t&&this.error(c.DiagnosticCode.A_rest_parameter_cannot_have_an_initializer,p.range),n?this.error(c.DiagnosticCode.Parameter_cannot_have_question_mark_and_initializer,p.range):n=!0,!(h=this.parseExpression(e,2))))return null;var d=u.Node.createParameter(p,_,h,t?u.ParameterKind.REST:n?u.ParameterKind.OPTIONAL:u.ParameterKind.DEFAULT,o.Range.join(i,e.range()));return d.flags|=s,d}return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null},r.prototype.parseFunction=function(e,r,t,n){if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range(e.pos)),null;var i=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),s=-1,l=null;if(e.skip(o.Token.LESSTHAN)){if(s=e.tokenPos,!(l=this.parseTypeParameters(e)))return null;r|=a.CommonFlags.GENERIC}if(!e.skip(o.Token.OPENPAREN))return this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"("),null;s<0&&(s=e.tokenPos);var p=this.parseParameters(e);if(!p)return null;var _=this.parseParametersThis,h=0!=(r&a.CommonFlags.SET);h&&(1!=p.length&&this.error(c.DiagnosticCode.A_set_accessor_must_have_exactly_one_parameter,i.range),p.length&&p[0].initializer&&this.error(c.DiagnosticCode.A_set_accessor_parameter_cannot_have_an_initializer,i.range)),r&a.CommonFlags.GET&&p.length&&this.error(c.DiagnosticCode.A_get_accessor_cannot_have_parameters,i.range);var d=null;if(e.skip(o.Token.COLON)&&!(d=this.parseType(e,!0,h)))return null;d||(d=u.Node.createOmittedType(e.range(e.pos)),h||this.error(c.DiagnosticCode.Type_expected,d.range));var y=u.Node.createFunctionType(p,d,_,!1,e.range(s,e.pos)),m=null;if(e.skip(o.Token.OPENBRACE)){if(r&a.CommonFlags.AMBIENT&&this.error(c.DiagnosticCode.An_implementation_cannot_be_declared_in_ambient_contexts,e.range()),!(m=this.parseBlockStatement(e,!1)))return null}else r&a.CommonFlags.AMBIENT||this.error(c.DiagnosticCode.Function_implementation_is_missing_or_not_immediately_following_the_declaration,e.range(e.pos));var f=u.Node.createFunctionDeclaration(i,l,y,m,t,r,0,e.range(n,e.pos));return e.skip(o.Token.SEMICOLON),f},r.prototype.parseFunctionExpression=function(e){var r,t=e.tokenPos,n=0;if(e.token==o.Token.FUNCTION){if(r=e.skipIdentifier()?u.Node.createIdentifierExpression(e.readIdentifier(),e.range()):u.Node.createEmptyIdentifierExpression(e.range(e.pos)),!e.skip(o.Token.OPENPAREN))return this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"("),null}else n=1,assert(e.token==o.Token.OPENPAREN),r=u.Node.createEmptyIdentifierExpression(e.range(e.tokenPos));var i=e.pos,a=this.parseParameters(e);return a?this.parseFunctionExpressionCommon(e,r,a,n,t,i):null},r.prototype.parseFunctionExpressionCommon=function(e,r,t,n,i,s){void 0===i&&(i=-1),void 0===s&&(s=-1),i<0&&(i=r.range.start),s<0&&(s=i);var l=null;if(2!=n&&e.skip(o.Token.COLON)){if(!(l=this.parseType(e)))return null}else l=u.Node.createOmittedType(e.range(e.pos));if(n&&!e.skip(o.Token.EQUALS_GREATERTHAN))return this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"=>"),null;var p=u.Node.createFunctionType(t,l,null,!1,e.range(s,e.pos)),_=null;if(n)if(e.skip(o.Token.OPENBRACE))_=this.parseBlockStatement(e,!1);else{var h=this.parseExpression(e,2);h&&(_=u.Node.createExpressionStatement(h))}else{if(!e.skip(o.Token.OPENBRACE))return this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"{"),null;_=this.parseBlockStatement(e,!1)}if(!_)return null;var d=u.Node.createFunctionDeclaration(r,null,p,_,null,a.CommonFlags.NONE,n,e.range(i,e.pos));return u.Node.createFunctionExpression(d)},r.prototype.parseClassOrInterface=function(e,r,t,n){var i=e.token==o.Token.INTERFACE;if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;var s=u.Node.createIdentifierExpression(e.readIdentifier(),e.range()),l=null;if(e.skip(o.Token.LESSTHAN)){if(!(l=this.parseTypeParameters(e)))return null;r|=a.CommonFlags.GENERIC}var p=null;if(e.skip(o.Token.EXTENDS)){var _=this.parseType(e);if(!_)return null;if(_.kind!=u.NodeKind.NAMEDTYPE)return this.error(c.DiagnosticCode.Operation_not_supported,_.range),null;p=_}var h=null;if(e.skip(o.Token.IMPLEMENTS)){i&&this.error(c.DiagnosticCode.Interface_declaration_cannot_have_implements_clause,e.range());do{var d=this.parseType(e);if(!d)return null;i||(h?h.push(d):h=[d])}while(e.skip(o.Token.COMMA))}if(!e.skip(o.Token.OPENBRACE))return this.error(c.DiagnosticCode._0_expected,e.range(),"{"),null;var y,m=new Array;if(i?(assert(!h),y=u.Node.createInterfaceDeclaration(s,l,p,m,t,r,e.range(n,e.pos))):y=u.Node.createClassDeclaration(s,l,p,h,m,t,r,e.range(n,e.pos)),!e.skip(o.Token.CLOSEBRACE))do{var f=this.parseClassMember(e,y);if(f)m.push(f);else if(this.skipStatement(e),e.skip(o.Token.ENDOFFILE))return this.error(c.DiagnosticCode._0_expected,e.range(),"}"),null}while(!e.skip(o.Token.CLOSEBRACE));return y.range.end=e.pos,y},r.prototype.parseClassExpression=function(e){var r,t=e.tokenPos;if(r=e.skipIdentifier()?u.Node.createIdentifierExpression(e.readIdentifier(),e.range()):u.Node.createEmptyIdentifierExpression(e.range(e.pos)),!e.skip(o.Token.OPENBRACE))return this.error(c.DiagnosticCode._0_expected,e.range(e.pos),"{"),null;var n=new Array,i=u.Node.createClassDeclaration(r,[],null,null,n,null,a.CommonFlags.NONE,e.range(t,e.pos));if(!e.skip(o.Token.CLOSEBRACE))do{var s=this.parseClassMember(e,i);if(s)n.push(s);else if(this.skipStatement(e),e.skip(o.Token.ENDOFFILE))return this.error(c.DiagnosticCode._0_expected,e.range(),"}"),null}while(!e.skip(o.Token.CLOSEBRACE));return i.range.end=e.pos,u.Node.createClassExpression(i)},r.prototype.parseClassMember=function(e,r){var t=e.pos,n=r.kind==u.NodeKind.INTERFACEDECLARATION,i=null;if(e.skip(o.Token.AT)){do{var s=this.parseDecorator(e);if(!s)break;i?i.push(s):i=[s]}while(e.skip(o.Token.AT));i&&n&&this.error(c.DiagnosticCode.Decorators_are_not_valid_here,o.Range.join(i[0].range,i[i.length-1].range))}var l=r.flags&a.CommonFlags.AMBIENT;n&&(l|=a.CommonFlags.VIRTUAL);var p=0,_=0;e.skip(o.Token.PUBLIC)?(n&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(),"public"),l|=a.CommonFlags.PUBLIC,p=e.tokenPos,_=e.pos):e.skip(o.Token.PRIVATE)?(n&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(),"private"),l|=a.CommonFlags.PRIVATE,p=e.tokenPos,_=e.pos):e.skip(o.Token.PROTECTED)&&(n&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(),"protected"),l|=a.CommonFlags.PROTECTED,p=e.tokenPos,_=e.pos);var h=0,d=0,y=0,m=0;e.skip(o.Token.STATIC)?(n&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(),"static"),l|=a.CommonFlags.STATIC,h=e.tokenPos,d=e.pos):(l|=a.CommonFlags.INSTANCE,e.skip(o.Token.ABSTRACT)&&(n&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(),"abstract"),l|=a.CommonFlags.ABSTRACT,y=e.tokenPos,m=e.pos),r.flags&a.CommonFlags.GENERIC&&(l|=a.CommonFlags.GENERIC_CONTEXT));var f=0,T=0;if(e.peek()==o.Token.READONLY){var g=e.mark();e.next(),e.peek()!=o.Token.COLON?(e.discard(g),l|=a.CommonFlags.READONLY,f=e.tokenPos,T=e.pos):e.reset(g)}var E,v=e.mark(),b=!1,I=!1,x=!1,A=0,N=0;if(n||(e.skip(o.Token.GET)?e.peek(!0,o.IdentifierHandling.PREFER)!=o.Token.IDENTIFIER||e.nextTokenOnNewLine?e.reset(v):(l|=a.CommonFlags.GET,I=!0,A=e.tokenPos,N=e.pos,l&a.CommonFlags.READONLY&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(f,T),"readonly")):e.skip(o.Token.SET)?e.peek(!0,o.IdentifierHandling.PREFER)!=o.Token.IDENTIFIER||e.nextTokenOnNewLine?e.reset(v):(l|=a.CommonFlags.SET,x=!0,A=e.tokenPos,N=e.pos,l&a.CommonFlags.READONLY&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(f,T),"readonly")):e.skip(o.Token.CONSTRUCTOR)&&(b=!0,(l|=a.CommonFlags.CONSTRUCTOR)&a.CommonFlags.STATIC&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(h,d),"static"),l&a.CommonFlags.ABSTRACT&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(y,m),"abstract"),l&a.CommonFlags.READONLY&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(f,T),"readonly"))),b)E=u.Node.createConstructorExpression(e.range());else{if(!I&&!x&&e.skip(o.Token.OPENBRACKET)){l&a.CommonFlags.PUBLIC?this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(p,_),"public"):l&a.CommonFlags.PROTECTED?this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(p,_),"protected"):l&a.CommonFlags.PRIVATE&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(p,_),"protected"),l&a.CommonFlags.STATIC&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(h,d),"static"),l&a.CommonFlags.ABSTRACT&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(y,m),"abstract"),l&a.CommonFlags.READONLY&&this.error(c.DiagnosticCode._0_modifier_cannot_be_used_here,e.range(f,T),"readonly");var S=this.parseIndexSignatureDeclaration(e,i);return S?(e.skip(o.Token.SEMICOLON),S):null}if(!e.skipIdentifier())return this.error(c.DiagnosticCode.Identifier_expected,e.range()),null;E=u.Node.createIdentifierExpression(e.readIdentifier(),e.range())}var O=null;if(e.skip(o.Token.LESSTHAN)){var C=e.tokenPos;if(!(O=this.parseTypeParameters(e)))return null;b?this.error(c.DiagnosticCode.Type_parameters_cannot_appear_on_a_constructor_declaration,e.range(C,e.pos)):I||x?this.error(c.DiagnosticCode.An_accessor_cannot_have_type_parameters,e.range(C,e.pos)):l|=a.CommonFlags.GENERIC}if(e.skip(o.Token.OPENPAREN)){var k=e.tokenPos,L=this.parseParameters(e,b);if(!L)return null;var R=this.parseParametersThis;if(b)for(var F=0,B=L.length;F"),null):null;case o.Token.IDENTIFIER:var T=e.readIdentifier();if("null"==T)return u.Node.createNullExpression(e.range());var g=u.Node.createIdentifierExpression(T,e.range(t,e.pos));return e.peek(!0)!=o.Token.EQUALS_GREATERTHAN||e.nextTokenOnNewLine?g:this.parseFunctionExpressionCommon(e,u.Node.createEmptyIdentifierExpression(e.range(t)),[u.Node.createParameter(g,u.Node.createOmittedType(g.range.atEnd),null,u.ParameterKind.DEFAULT,g.range)],2,t);case o.Token.THIS:return u.Node.createThisExpression(e.range(t,e.pos));case o.Token.CONSTRUCTOR:return u.Node.createConstructorExpression(e.range(t,e.pos));case o.Token.SUPER:return e.peek()!=o.Token.DOT&&e.nextToken!=o.Token.OPENPAREN&&this.error(c.DiagnosticCode._super_must_be_followed_by_an_argument_list_or_member_access,e.range()),u.Node.createSuperExpression(e.range(t,e.pos));case o.Token.STRINGLITERAL:return u.Node.createStringLiteralExpression(e.readString(),e.range(t,e.pos));case o.Token.INTEGERLITERAL:return u.Node.createIntegerLiteralExpression(e.readInteger(),e.range(t,e.pos));case o.Token.FLOATLITERAL:return u.Node.createFloatLiteralExpression(e.readFloat(),e.range(t,e.pos));case o.Token.SLASH:var E=e.readRegexpPattern();return e.skip(o.Token.SLASH)?u.Node.createRegexpLiteralExpression(E,e.readRegexpFlags(),e.range(t,e.pos)):(this.error(c.DiagnosticCode._0_expected,e.range(),"/"),null);case o.Token.FUNCTION:return this.parseFunctionExpression(e);case o.Token.CLASS:return this.parseClassExpression(e);default:return r==o.Token.ENDOFFILE?this.error(c.DiagnosticCode.Unexpected_end_of_text,e.range(t)):this.error(c.DiagnosticCode.Expression_expected,e.range()),null}},r.prototype.tryParseTypeArgumentsBeforeArguments=function(e){var r=e.mark();if(!e.skip(o.Token.LESSTHAN))return null;var t=null;do{if(e.peek()===o.Token.GREATERTHAN)break;var n=this.parseType(e,!0,!0);if(!n)return e.reset(r),null;t?t.push(n):t=[n]}while(e.skip(o.Token.COMMA));return e.skip(o.Token.GREATERTHAN)&&e.skip(o.Token.OPENPAREN)?t:(e.reset(r),null)},r.prototype.parseArguments=function(e){for(var r=new Array;!e.skip(o.Token.CLOSEPAREN);){var t=this.parseExpression(e,2);if(!t)return null;if(r.push(t),!e.skip(o.Token.COMMA)){if(e.skip(o.Token.CLOSEPAREN))break;return this.error(c.DiagnosticCode._0_expected,e.range(),")"),null}}return r},r.prototype.parseExpression=function(e,r){void 0===r&&(r=1),assert(0!=r);var t=this.parseExpressionStart(e);if(!t)return null;for(var n,i,a=(t=this.maybeParseCallExpression(e,t)).range.start,s=null;(i=_(n=e.peek()))>=r;){switch(e.next(),n){case o.Token.AS:var l=this.parseType(e);if(!l)return null;t=u.Node.createAssertionExpression(u.AssertionKind.AS,t,l,e.range(a,e.pos));break;case o.Token.EXCLAMATION:t=u.Node.createAssertionExpression(u.AssertionKind.NONNULL,t,null,e.range(a,e.pos));break;case o.Token.INSTANCEOF:var p=this.parseType(e);if(!p)return null;t=u.Node.createInstanceOfExpression(t,p,e.range(a,e.pos));break;case o.Token.OPENBRACKET:if(!(s=this.parseExpression(e)))return null;if(!e.skip(o.Token.CLOSEBRACKET))return this.error(c.DiagnosticCode._0_expected,e.range(),"]"),null;t=u.Node.createElementAccessExpression(t,s,e.range(a,e.pos));break;case o.Token.PLUS_PLUS:case o.Token.MINUS_MINUS:t.kind!=u.NodeKind.IDENTIFIER&&t.kind!=u.NodeKind.ELEMENTACCESS&&t.kind!=u.NodeKind.PROPERTYACCESS&&this.error(c.DiagnosticCode.The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access,t.range),t=u.Node.createUnaryPostfixExpression(n,t,e.range(a,e.pos));break;case o.Token.QUESTION:var d=this.parseExpression(e);if(!d)return null;if(!e.skip(o.Token.COLON))return this.error(c.DiagnosticCode._0_expected,e.range(),":"),null;var y=this.parseExpression(e,r>1?2:1);if(!y)return null;t=u.Node.createTernaryExpression(t,d,y,e.range(a,e.pos));break;case o.Token.COMMA:var m=[t];do{if(!(t=this.parseExpression(e,2)))return null;m.push(t)}while(e.skip(o.Token.COMMA));t=u.Node.createCommaExpression(m,e.range(a,e.pos));break;default:if(n==o.Token.DOT){if(e.skipIdentifier())s=u.Node.createIdentifierExpression(e.readIdentifier(),e.range());else if(!(s=this.parseExpression(e,h(n)?i:i+1)))return null;if(s.kind==u.NodeKind.IDENTIFIER)t=u.Node.createPropertyAccessExpression(t,s,e.range(a,e.pos));else{if(s.kind!=u.NodeKind.CALL)return this.error(c.DiagnosticCode.Identifier_expected,s.range),null;if(!(t=this.joinPropertyCall(e,a,t,s)))return null}}else{if(!(s=this.parseExpression(e,h(n)?i:i+1)))return null;t=u.Node.createBinaryExpression(n,t,s,e.range(a,e.pos))}}t=this.maybeParseCallExpression(e,t)}return t},r.prototype.joinPropertyCall=function(e,r,t,n){var i=n.expression;switch(i.kind){case u.NodeKind.IDENTIFIER:n.expression=u.Node.createPropertyAccessExpression(t,i,e.range(r,e.pos));break;case u.NodeKind.CALL:var a=this.joinPropertyCall(e,r,t,i);if(!a)return null;n.expression=a,n.range=e.range(r,e.pos);break;default:return this.error(c.DiagnosticCode.Identifier_expected,n.range),null}return n},r.prototype.maybeParseCallExpression=function(e,r){if(u.nodeIsCallable(r.kind))for(var t=null;e.skip(o.Token.OPENPAREN)||u.nodeIsGenericCallable(r.kind)&&null!==(t=this.tryParseTypeArgumentsBeforeArguments(e));){var n=this.parseArguments(e);if(!n)break;r=u.Node.createCallExpression(r,t,n,e.range(r.range.start,e.pos))}return r},r.prototype.skipStatement=function(e){for(e.peek(!0),e.nextTokenOnNewLine&&e.next();;){var r=e.peek(!0);if(r==o.Token.ENDOFFILE||r==o.Token.SEMICOLON){e.next();break}if(e.nextTokenOnNewLine)break;switch(e.next()){case o.Token.IDENTIFIER:e.readIdentifier();break;case o.Token.STRINGLITERAL:e.readString();break;case o.Token.INTEGERLITERAL:e.readInteger();break;case o.Token.FLOATLITERAL:e.readFloat();break;case o.Token.OPENBRACE:this.skipBlock(e)}}},r.prototype.skipBlock=function(e){var r=1,t=!0;do{switch(e.next()){case o.Token.ENDOFFILE:this.error(c.DiagnosticCode._0_expected,e.range(),"}"),t=!1;break;case o.Token.OPENBRACE:++r;break;case o.Token.CLOSEBRACE:--r||(t=!1);break;case o.Token.IDENTIFIER:e.readIdentifier();break;case o.Token.STRINGLITERAL:e.readString();break;case o.Token.INTEGERLITERAL:e.readInteger();break;case o.Token.FLOATLITERAL:e.readFloat()}}while(t)},r}(c.DiagnosticEmitter);function _(e){switch(e){case o.Token.COMMA:return 1;case o.Token.EQUALS:case o.Token.PLUS_EQUALS:case o.Token.MINUS_EQUALS:case o.Token.ASTERISK_ASTERISK_EQUALS:case o.Token.ASTERISK_EQUALS:case o.Token.SLASH_EQUALS:case o.Token.PERCENT_EQUALS:case o.Token.LESSTHAN_LESSTHAN_EQUALS:case o.Token.GREATERTHAN_GREATERTHAN_EQUALS:case o.Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:case o.Token.AMPERSAND_EQUALS:case o.Token.CARET_EQUALS:case o.Token.BAR_EQUALS:return 4;case o.Token.QUESTION:return 5;case o.Token.BAR_BAR:return 6;case o.Token.AMPERSAND_AMPERSAND:return 7;case o.Token.BAR:return 8;case o.Token.CARET:return 9;case o.Token.AMPERSAND:return 10;case o.Token.EQUALS_EQUALS:case o.Token.EXCLAMATION_EQUALS:case o.Token.EQUALS_EQUALS_EQUALS:case o.Token.EXCLAMATION_EQUALS_EQUALS:return 11;case o.Token.AS:case o.Token.IN:case o.Token.INSTANCEOF:case o.Token.LESSTHAN:case o.Token.GREATERTHAN:case o.Token.LESSTHAN_EQUALS:case o.Token.GREATERTHAN_EQUALS:return 12;case o.Token.LESSTHAN_LESSTHAN:case o.Token.GREATERTHAN_GREATERTHAN:case o.Token.GREATERTHAN_GREATERTHAN_GREATERTHAN:return 13;case o.Token.PLUS:case o.Token.MINUS:return 14;case o.Token.ASTERISK:case o.Token.SLASH:case o.Token.PERCENT:return 15;case o.Token.ASTERISK_ASTERISK:return 16;case o.Token.PLUS_PLUS:case o.Token.MINUS_MINUS:return 18;case o.Token.DOT:case o.Token.NEW:case o.Token.OPENBRACKET:case o.Token.EXCLAMATION:return 20}return 0}function h(e){switch(e){case o.Token.EQUALS:case o.Token.PLUS_EQUALS:case o.Token.MINUS_EQUALS:case o.Token.ASTERISK_ASTERISK_EQUALS:case o.Token.ASTERISK_EQUALS:case o.Token.SLASH_EQUALS:case o.Token.PERCENT_EQUALS:case o.Token.LESSTHAN_LESSTHAN_EQUALS:case o.Token.GREATERTHAN_GREATERTHAN_EQUALS:case o.Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:case o.Token.AMPERSAND_EQUALS:case o.Token.CARET_EQUALS:case o.Token.BAR_EQUALS:case o.Token.QUESTION:case o.Token.ASTERISK_ASTERISK:return!0;default:return!1}}r.Parser=p,function(e){e[e.NONE=0]="NONE",e[e.COMMA=1]="COMMA",e[e.SPREAD=2]="SPREAD",e[e.YIELD=3]="YIELD",e[e.ASSIGNMENT=4]="ASSIGNMENT",e[e.CONDITIONAL=5]="CONDITIONAL",e[e.LOGICAL_OR=6]="LOGICAL_OR",e[e.LOGICAL_AND=7]="LOGICAL_AND",e[e.BITWISE_OR=8]="BITWISE_OR",e[e.BITWISE_XOR=9]="BITWISE_XOR",e[e.BITWISE_AND=10]="BITWISE_AND",e[e.EQUALITY=11]="EQUALITY",e[e.RELATIONAL=12]="RELATIONAL",e[e.SHIFT=13]="SHIFT",e[e.ADDITIVE=14]="ADDITIVE",e[e.MULTIPLICATIVE=15]="MULTIPLICATIVE",e[e.EXPONENTIATED=16]="EXPONENTIATED",e[e.UNARY_PREFIX=17]="UNARY_PREFIX",e[e.UNARY_POSTFIX=18]="UNARY_POSTFIX",e[e.CALL=19]="CALL",e[e.MEMBERACCESS=20]="MEMBERACCESS",e[e.GROUPING=21]="GROUPING"}(r.Precedence||(r.Precedence={}))},function(e,r,t){t(18),e.exports=t(28)},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),t(19),t(21),t(22),t(23);var n=t(4);n.Module.prototype.toText=function(){return binaryen.wrapModule(this.ref).emitStackIR(!0)},n.Module.prototype.toAsmjs=function(){return binaryen.wrapModule(this.ref).emitAsmjs()}},function(e,r,t){(function(e){const r=e.Binaryen||t(20);for(var n in e.binaryen=r,r)(n.startsWith("_Binaryen")||n.startsWith("_Relooper"))&&(e[n]=r[n]);e.__memory_allocate=r._malloc,e.__memory_free=r._free,e.__memory_copy=r._memmove,e.__store=function(e,t){r.HEAPU8[e]=t},e.__load=function(e){return r.HEAPU8[e]}}).call(this,t(8))},function(r,t){r.exports=e},function(e,r,t){(function(e){var r="undefined"!=typeof window&&window||void 0!==e&&e||self;r.ASC_TARGET=2,r.ASC_NO_ASSERT=!1,r.ASC_MEMORY_BASE=0,r.ASC_OPTIMIZE_LEVEL=3,r.ASC_SHRINK_LEVEL=0,r.ASC_FEATURE_MUTABLE_GLOBAL=!1,r.ASC_FEATURE_SIGN_EXTENSION=!1,r.ASC_FEATURE_BULK_MEMORY=!1,r.ASC_FEATURE_SIMD=!1,r.ASC_FEATURE_THREADS=!1;var t=new Float64Array(1),n=new Uint32Array(t.buffer);function i(){Error.captureStackTrace?Error.captureStackTrace(this,i):this.stack=this.name+": "+this.message+"\n"+(new Error).stack}function a(e){this.message=e||"assertion failed",Error.captureStackTrace?Error.captureStackTrace(this,a):this.stack=this.name+": "+this.message+"\n"+(new Error).stack}Object.defineProperties(r.i8=function(e){return e<<24>>24},{MIN_VALUE:{value:-128,writable:!1},MAX_VALUE:{value:127,writable:!1}}),Object.defineProperties(r.i16=function(e){return e<<16>>16},{MIN_VALUE:{value:-32768,writable:!1},MAX_VALUE:{value:32767,writable:!1}}),Object.defineProperties(r.i32=r.isize=function(e){return 0|e},{MIN_VALUE:{value:-2147483648,writable:!1},MAX_VALUE:{value:2147483647,writable:!1}}),Object.defineProperties(r.u8=function(e){return 255&e},{MIN_VALUE:{value:0,writable:!1},MAX_VALUE:{value:255,writable:!1}}),Object.defineProperties(r.u16=function(e){return 65535&e},{MIN_VALUE:{value:0,writable:!1},MAX_VALUE:{value:65535,writable:!1}}),Object.defineProperties(r.u32=r.usize=function(e){return e>>>0},{MIN_VALUE:{value:0,writable:!1},MAX_VALUE:{value:4294967295,writable:!1}}),Object.defineProperties(r.bool=function(e){return!!e},{MIN_VALUE:{value:!1,writable:!1},MAX_VALUE:{value:!0,writable:!1}}),Object.defineProperties(r.f32=function(e){return Math.fround(e)},{EPSILON:{value:Math.fround(1.1920929e-7),writable:!1},MIN_VALUE:{value:Math.fround(1.4012985e-45),writable:!1},MAX_VALUE:{value:Math.fround(3.4028235e38),writable:!1},MIN_NORMAL_VALUE:{value:Math.fround(1.17549435e-38),writable:!1},MIN_SAFE_INTEGER:{value:-16777215,writable:!1},MAX_SAFE_INTEGER:{value:16777215,writable:!1}}),Object.defineProperties(r.f64=function(e){return+e},{EPSILON:{value:2.220446049250313e-16,writable:!1},MIN_VALUE:{value:5e-324,writable:!1},MAX_VALUE:{value:1.7976931348623157e308,writable:!1},MIN_NORMAL_VALUE:{value:2.2250738585072014e-308,writable:!1},MIN_SAFE_INTEGER:{value:-9007199254740991,writable:!1},MAX_SAFE_INTEGER:{value:9007199254740991,writable:!1}}),r.clz=Math.clz32,r.ctz=function(e){var r=Math.clz32(e&-e);return e?31-r:r},r.popcnt=function(e){return 16843009*((e=(858993459&(e-=e>>>1&1431655765))+(e>>>2&858993459))+(e>>>4)&252645135)>>>24},r.rotl=function(e,r){return e<<(r&=31)|e>>>32-r},r.rotr=function(e,r){return e>>>(r&=31)|e<<32-r},r.abs=Math.abs,r.max=Math.max,r.min=Math.min,r.ceil=Math.ceil,r.floor=Math.floor,r.nearest=function(e){return.5===Math.abs(e-Math.trunc(e))?2*Math.round(.5*e):Math.round(e)},r.select=function(e,r,t){return t?e:r},r.sqrt=Math.sqrt,r.trunc=Math.trunc,r.copysign=function(e,r){return Math.abs(e)*Math.sign(r)},r.bswap=function(e){var r=e>>8&16711935,t=(16711935&e)<<8;return(r=(e=r|t)>>16&65535)|(t=(65535&e)<<16)},r.bswap16=function(e){return e<<8&65280|e>>8&255|4294901760&e},i.prototype=Object.create(Error.prototype),i.prototype.name="UnreachableError",i.prototype.message="unreachable",r.unreachable=function(){throw new i},a.prototype=Object.create(Error.prototype),a.prototype.name="AssertionError",r.assert=function(e,r){if(e)return e;throw new a(r)},r.changetype=function(e){return e},String.fromCharCodes=function(e){return String.fromCharCode.apply(String,e)},String.fromCodePoints=function(e){return String.fromCodePoint.apply(String,e)},String.prototype.replaceAll||Object.defineProperty(String.prototype,"replaceAll",{value:function(e,r){var t=this.split(e).join(r);return e.length||(t=r+t+r),t}}),r.isInteger=Number.isInteger,r.isFloat=function(e){return"number"==typeof e},r.isNullable=function(e){return!0},r.isReference=function(e){return"object"==typeof e||"string"==typeof e},r.isFunction=function(e){return"function"==typeof e},r.isString=function(e){return"string"==typeof e||e instanceof String},r.isArray=Array.isArray,r.isArrayLike=function(e){return e&&"object"==typeof e&&"number"==typeof e.length&&e.length>=0&&Math.trunc(e.length)===e.length},Array.create=function(e){var r=new Array(e);return r.length=0,r},r.isDefined=function(e){return void 0!==e},r.isConstant=function(e){return!1},r.unchecked=function(e){return e},r.fmod=function(e,r){return e%r},r.fmodf=function(e,r){return Math.fround(e%r)},r.JSMath=Math,Object.defineProperties(r.JSMath,{sincos_sin:{value:0,writable:!0},sincos_cos:{value:0,writable:!0},signbit:{value:function(e){return t[0]=e,Boolean(n[1]>>>31&e==e)}},sincos:{value:function(e){this.sincos_sin=Math.sin(e),this.sincos_cos=Math.cos(e)}}}),r.memory=(()=>{var e=new Uint8Array(0),t=0;return{allocate:r.__memory_allocate||function(r){if(!(r>>>=0))return 0;if(t+r>e.length){var n=e;(e=new Uint8Array(Math.max(65536,e.length+r,2*e.length))).set(n)}var i=t;return 7&(t+=r)&&(t=1+(7|t)),i},fill:r.__memory_fill||function(r,t,n){e.fill(t,r,r+n)},free:r.__memory_free||function(e){},copy:r.__memory_copy||function(r,t,n){e.copyWithin(r,t,t+n)},reset:r.__memory_reset||function(){e=new Uint8Array(0),t=0}}})(),r.store=r.__store||function(e,r,t){HEAP[(0|e)+(0|t)]=r},r.load=r.__load||function(e,r){return HEAP[(0|e)+(0|r)]},r.unmanaged=function(){}}).call(this,t(8))},function(e,r,t){(function(e){const r=new Float64Array(1),t=new Float32Array(r.buffer),n=new Int32Array(r.buffer);e.f32_as_i32=function(e){return t[0]=e,n[0]},e.i32_as_f32=function(e){return n[0]=e,t[0]},e.f64_as_i64=function(e){return r[0]=e,i64_new(n[0],n[1])},e.i64_as_f64=function(e){return n[0]=i64_low(e),n[1]=i64_high(e),r[0]}}).call(this,t(8))},function(e,r,t){(function(e){const r=e.Long||t(24);e.i64_zero=r.ZERO,e.i64_one=r.ONE,e.i64_new=function(e,t){return r.fromBits(e,t)},e.i64_low=function(e){return e.low},e.i64_high=function(e){return e.high},e.i64_add=function(e,r){return e.add(r)},e.i64_sub=function(e,r){return e.sub(r)},e.i64_mul=function(e,r){return e.mul(r)},e.i64_div=function(e,r){return e.div(r)},e.i64_div_u=function(e,r){return e.toUnsigned().div(r.toUnsigned()).toSigned()},e.i64_rem=function(e,r){return e.mod(r)},e.i64_rem_u=function(e,r){return e.toUnsigned().mod(r.toUnsigned()).toSigned()},e.i64_and=function(e,r){return e.and(r)},e.i64_or=function(e,r){return e.or(r)},e.i64_xor=function(e,r){return e.xor(r)},e.i64_shl=function(e,r){return e.shl(r)},e.i64_shr=function(e,r){return e.shr(r)},e.i64_shr_u=function(e,r){return e.shru(r)},e.i64_not=function(e){return e.not()},e.i64_eq=function(e,r){return e.eq(r)},e.i64_ne=function(e,r){return e.ne(r)},e.i64_align=function(e,t){assert(t&&0==(t&t-1));var n=r.fromInt(t-1);return e.add(n).and(n.not())},e.i64_is_i8=function(e){return 0===e.high&&e.low>=0&&e.low<=i8.MAX_VALUE||-1===e.high&&e.low>=i8.MIN_VALUE&&e.low<0},e.i64_is_i16=function(e){return 0===e.high&&e.low>=0&&e.low<=i16.MAX_VALUE||-1===e.high&&e.low>=i16.MIN_VALUE&&e.low<0},e.i64_is_i32=function(e){return 0===e.high&&e.low>=0||-1===e.high&&e.low<0},e.i64_is_u8=function(e){return 0===e.high&&e.low>=0&&e.low<=u8.MAX_VALUE},e.i64_is_u16=function(e){return 0===e.high&&e.low>=0&&e.low<=u16.MAX_VALUE},e.i64_is_u32=function(e){return 0===e.high},e.i64_is_bool=function(e){return 0===e.high&&(0===e.low||1===e.low)};const n=r.fromNumber(f32.MIN_SAFE_INTEGER),i=r.fromNumber(f32.MAX_SAFE_INTEGER);e.i64_is_f32=function(e){return e.gte(n)&&e.lte(i)};const a=r.fromNumber(f64.MIN_SAFE_INTEGER),s=r.fromNumber(f64.MAX_SAFE_INTEGER);e.i64_is_f64=function(e){return e.gte(a)&&e.lte(s)},e.i64_to_f32=function(r){return e.Math.fround(r.toNumber())},e.i64_to_f64=function(e){return e.toNumber()},e.i64_to_string=function(e,r){return(r?e.toUnsigned():e).toString(10)}}).call(this,t(8))},function(e,r){e.exports=n;var t=null;try{t=new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([0,97,115,109,1,0,0,0,1,13,2,96,0,1,127,96,4,127,127,127,127,1,127,3,7,6,0,1,1,1,1,1,6,6,1,127,1,65,0,11,7,50,6,3,109,117,108,0,1,5,100,105,118,95,115,0,2,5,100,105,118,95,117,0,3,5,114,101,109,95,115,0,4,5,114,101,109,95,117,0,5,8,103,101,116,95,104,105,103,104,0,0,10,191,1,6,4,0,35,0,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,126,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,127,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,128,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,129,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,130,34,4,66,32,135,167,36,0,32,4,167,11])),{}).exports}catch(e){}function n(e,r,t){this.low=0|e,this.high=0|r,this.unsigned=!!t}function i(e){return!0===(e&&e.__isLong__)}n.prototype.__isLong__,Object.defineProperty(n.prototype,"__isLong__",{value:!0}),n.isLong=i;var a={},s={};function o(e,r){var t,n,i;return r?(i=0<=(e>>>=0)&&e<256)&&(n=s[e])?n:(t=l(e,(0|e)<0?-1:0,!0),i&&(s[e]=t),t):(i=-128<=(e|=0)&&e<128)&&(n=a[e])?n:(t=l(e,e<0?-1:0,!1),i&&(a[e]=t),t)}function c(e,r){if(isNaN(e))return r?T:f;if(r){if(e<0)return T;if(e>=d)return I}else{if(e<=-y)return x;if(e+1>=y)return b}return e<0?c(-e,r).neg():l(e%h|0,e/h|0,r)}function l(e,r,t){return new n(e,r,t)}n.fromInt=o,n.fromNumber=c,n.fromBits=l;var u=Math.pow;function p(e,r,t){if(0===e.length)throw Error("empty string");if("NaN"===e||"Infinity"===e||"+Infinity"===e||"-Infinity"===e)return f;if("number"==typeof r?(t=r,r=!1):r=!!r,(t=t||10)<2||360)throw Error("interior hyphen");if(0===n)return p(e.substring(1),r,t).neg();for(var i=c(u(t,8)),a=f,s=0;s>>0:this.low},A.toNumber=function(){return this.unsigned?(this.high>>>0)*h+(this.low>>>0):this.high*h+(this.low>>>0)},A.toString=function(e){if((e=e||10)<2||36>>0).toString(e);if((a=o).isZero())return l+s;for(;l.length<6;)l="0"+l;s=""+l+s}},A.getHighBits=function(){return this.high},A.getHighBitsUnsigned=function(){return this.high>>>0},A.getLowBits=function(){return this.low},A.getLowBitsUnsigned=function(){return this.low>>>0},A.getNumBitsAbs=function(){if(this.isNegative())return this.eq(x)?64:this.neg().getNumBitsAbs();for(var e=0!=this.high?this.high:this.low,r=31;r>0&&0==(e&1<=0},A.isOdd=function(){return 1==(1&this.low)},A.isEven=function(){return 0==(1&this.low)},A.equals=function(e){return i(e)||(e=_(e)),(this.unsigned===e.unsigned||this.high>>>31!=1||e.high>>>31!=1)&&(this.high===e.high&&this.low===e.low)},A.eq=A.equals,A.notEquals=function(e){return!this.eq(e)},A.neq=A.notEquals,A.ne=A.notEquals,A.lessThan=function(e){return this.comp(e)<0},A.lt=A.lessThan,A.lessThanOrEqual=function(e){return this.comp(e)<=0},A.lte=A.lessThanOrEqual,A.le=A.lessThanOrEqual,A.greaterThan=function(e){return this.comp(e)>0},A.gt=A.greaterThan,A.greaterThanOrEqual=function(e){return this.comp(e)>=0},A.gte=A.greaterThanOrEqual,A.ge=A.greaterThanOrEqual,A.compare=function(e){if(i(e)||(e=_(e)),this.eq(e))return 0;var r=this.isNegative(),t=e.isNegative();return r&&!t?-1:!r&&t?1:this.unsigned?e.high>>>0>this.high>>>0||e.high===this.high&&e.low>>>0>this.low>>>0?-1:1:this.sub(e).isNegative()?-1:1},A.comp=A.compare,A.negate=function(){return!this.unsigned&&this.eq(x)?x:this.not().add(g)},A.neg=A.negate,A.add=function(e){i(e)||(e=_(e));var r=this.high>>>16,t=65535&this.high,n=this.low>>>16,a=65535&this.low,s=e.high>>>16,o=65535&e.high,c=e.low>>>16,u=0,p=0,h=0,d=0;return h+=(d+=a+(65535&e.low))>>>16,p+=(h+=n+c)>>>16,u+=(p+=t+o)>>>16,u+=r+s,l((h&=65535)<<16|(d&=65535),(u&=65535)<<16|(p&=65535),this.unsigned)},A.subtract=function(e){return i(e)||(e=_(e)),this.add(e.neg())},A.sub=A.subtract,A.multiply=function(e){if(this.isZero())return f;if(i(e)||(e=_(e)),t)return l(t.mul(this.low,this.high,e.low,e.high),t.get_high(),this.unsigned);if(e.isZero())return f;if(this.eq(x))return e.isOdd()?x:f;if(e.eq(x))return this.isOdd()?x:f;if(this.isNegative())return e.isNegative()?this.neg().mul(e.neg()):this.neg().mul(e).neg();if(e.isNegative())return this.mul(e.neg()).neg();if(this.lt(m)&&e.lt(m))return c(this.toNumber()*e.toNumber(),this.unsigned);var r=this.high>>>16,n=65535&this.high,a=this.low>>>16,s=65535&this.low,o=e.high>>>16,u=65535&e.high,p=e.low>>>16,h=65535&e.low,d=0,y=0,T=0,g=0;return T+=(g+=s*h)>>>16,y+=(T+=a*h)>>>16,T&=65535,y+=(T+=s*p)>>>16,d+=(y+=n*h)>>>16,y&=65535,d+=(y+=a*p)>>>16,y&=65535,d+=(y+=s*u)>>>16,d+=r*h+n*p+a*u+s*o,l((T&=65535)<<16|(g&=65535),(d&=65535)<<16|(y&=65535),this.unsigned)},A.mul=A.multiply,A.divide=function(e){if(i(e)||(e=_(e)),e.isZero())throw Error("division by zero");var r,n,a;if(t)return this.unsigned||-2147483648!==this.high||-1!==e.low||-1!==e.high?l((this.unsigned?t.div_u:t.div_s)(this.low,this.high,e.low,e.high),t.get_high(),this.unsigned):this;if(this.isZero())return this.unsigned?T:f;if(this.unsigned){if(e.unsigned||(e=e.toUnsigned()),e.gt(this))return T;if(e.gt(this.shru(1)))return E;a=T}else{if(this.eq(x))return e.eq(g)||e.eq(v)?x:e.eq(x)?g:(r=this.shr(1).div(e).shl(1)).eq(f)?e.isNegative()?g:v:(n=this.sub(e.mul(r)),a=r.add(n.div(e)));if(e.eq(x))return this.unsigned?T:f;if(this.isNegative())return e.isNegative()?this.neg().div(e.neg()):this.neg().div(e).neg();if(e.isNegative())return this.div(e.neg()).neg();a=f}for(n=this;n.gte(e);){r=Math.max(1,Math.floor(n.toNumber()/e.toNumber()));for(var s=Math.ceil(Math.log(r)/Math.LN2),o=s<=48?1:u(2,s-48),p=c(r),h=p.mul(e);h.isNegative()||h.gt(n);)h=(p=c(r-=o,this.unsigned)).mul(e);p.isZero()&&(p=g),a=a.add(p),n=n.sub(h)}return a},A.div=A.divide,A.modulo=function(e){return i(e)||(e=_(e)),t?l((this.unsigned?t.rem_u:t.rem_s)(this.low,this.high,e.low,e.high),t.get_high(),this.unsigned):this.sub(this.div(e).mul(e))},A.mod=A.modulo,A.rem=A.modulo,A.not=function(){return l(~this.low,~this.high,this.unsigned)},A.and=function(e){return i(e)||(e=_(e)),l(this.low&e.low,this.high&e.high,this.unsigned)},A.or=function(e){return i(e)||(e=_(e)),l(this.low|e.low,this.high|e.high,this.unsigned)},A.xor=function(e){return i(e)||(e=_(e)),l(this.low^e.low,this.high^e.high,this.unsigned)},A.shiftLeft=function(e){return i(e)&&(e=e.toInt()),0==(e&=63)?this:e<32?l(this.low<>>32-e,this.unsigned):l(0,this.low<>>e|this.high<<32-e,this.high>>e,this.unsigned):l(this.high>>e-32,this.high>=0?0:-1,this.unsigned)},A.shr=A.shiftRight,A.shiftRightUnsigned=function(e){if(i(e)&&(e=e.toInt()),0===(e&=63))return this;var r=this.high;return e<32?l(this.low>>>e|r<<32-e,r>>>e,this.unsigned):l(32===e?r:r>>>e-32,0,this.unsigned)},A.shru=A.shiftRightUnsigned,A.shr_u=A.shiftRightUnsigned,A.toSigned=function(){return this.unsigned?l(this.low,this.high,!1):this},A.toUnsigned=function(){return this.unsigned?this:l(this.low,this.high,!0)},A.toBytes=function(e){return e?this.toBytesLE():this.toBytesBE()},A.toBytesLE=function(){var e=this.high,r=this.low;return[255&r,r>>>8&255,r>>>16&255,r>>>24,255&e,e>>>8&255,e>>>16&255,e>>>24]},A.toBytesBE=function(){var e=this.high,r=this.low;return[e>>>24,e>>>16&255,e>>>8&255,255&e,r>>>24,r>>>16&255,r>>>8&255,255&r]},n.fromBytes=function(e,r,t){return t?n.fromBytesLE(e,r):n.fromBytesBE(e,r)},n.fromBytesLE=function(e,r){return new n(e[0]|e[1]<<8|e[2]<<16|e[3]<<24,e[4]|e[5]<<8|e[6]<<16|e[7]<<24,r)},n.fromBytesBE=function(e,r){return new n(e[4]<<24|e[5]<<16|e[6]<<8|e[7],e[0]<<24|e[1]<<16|e[2]<<8|e[3],r)}},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),function(e){e[e.NONE=0]="NONE",e[e.SIGN_EXTENSION=1]="SIGN_EXTENSION",e[e.MUTABLE_GLOBAL=2]="MUTABLE_GLOBAL",e[e.BULK_MEMORY=4]="BULK_MEMORY",e[e.SIMD=8]="SIMD",e[e.THREADS=16]="THREADS"}(r.Feature||(r.Feature={}))},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),function(e){e[e.WASM32=0]="WASM32",e[e.WASM64=1]="WASM64",e[e.JS=2]="JS"}(r.Target||(r.Target={}))},function(e,r,t){"use strict";var n=this&&this.__decorate||function(e,r,t,n){var i,a=arguments.length,s=a<3?r:null===n?n=Object.getOwnPropertyDescriptor(r,t):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,r,t,n);else for(var o=e.length-1;o>=0;o--)(i=e[o])&&(s=(a<3?i(s):a>3?i(r,t,s):i(r,t))||s);return a>3&&s&&Object.defineProperty(r,t,s),s};Object.defineProperty(r,"__esModule",{value:!0});var i=function(){function e(){}return e=n([unmanaged],e)}();r.Typeinfo=i,function(e){e[e.NONE=0]="NONE",e[e.ARRAYBUFFERVIEW=1]="ARRAYBUFFERVIEW",e[e.ARRAY=2]="ARRAY",e[e.SET=4]="SET",e[e.MAP=8]="MAP",e[e.ACYCLIC=16]="ACYCLIC",e[e.VALUE_ALIGN_0=32]="VALUE_ALIGN_0",e[e.VALUE_ALIGN_1=64]="VALUE_ALIGN_1",e[e.VALUE_ALIGN_2=128]="VALUE_ALIGN_2",e[e.VALUE_ALIGN_3=256]="VALUE_ALIGN_3",e[e.VALUE_ALIGN_4=512]="VALUE_ALIGN_4",e[e.VALUE_SIGNED=1024]="VALUE_SIGNED",e[e.VALUE_FLOAT=2048]="VALUE_FLOAT",e[e.VALUE_NULLABLE=4096]="VALUE_NULLABLE",e[e.VALUE_MANAGED=8192]="VALUE_MANAGED",e[e.KEY_ALIGN_0=16384]="KEY_ALIGN_0",e[e.KEY_ALIGN_1=32768]="KEY_ALIGN_1",e[e.KEY_ALIGN_2=65536]="KEY_ALIGN_2",e[e.KEY_ALIGN_3=131072]="KEY_ALIGN_3",e[e.KEY_ALIGN_4=262144]="KEY_ALIGN_4",e[e.KEY_SIGNED=524288]="KEY_SIGNED",e[e.KEY_FLOAT=1048576]="KEY_FLOAT",e[e.KEY_NULLABLE=2097152]="KEY_NULLABLE",e[e.KEY_MANAGED=4194304]="KEY_MANAGED"}(r.TypeinfoFlags||(r.TypeinfoFlags={}))},function(e,r,t){"use strict";var n=this&&this.__values||function(e){var r="function"==typeof Symbol&&e[Symbol.iterator],t=0;return r?r.call(e):{next:function(){return e&&t>=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}};function i(e){for(var t in e)r.hasOwnProperty(t)||(r[t]=e[t])}Object.defineProperty(r,"__esModule",{value:!0});var a=t(11),s=t(14),o=t(15),c=t(2);r.formatDiagnostic=c.formatDiagnosticMessage;var l=t(16);r.parseFile=function(e,r,t,n){return void 0===t&&(t=!1),void 0===n&&(n=null),n||(n=new l.Parser),n.parseFile(e,r,t),n},r.nextFile=function(e){return e.nextFile()},r.nextDiagnostic=function(e){var r=e.program;return r.diagnosticsOffset=0&&r<64),i64_ne(i64_and(e,i64_shl(i64_one,i64_new(r))),i64_zero)},r.bitsetSet=function(e,r,t){return assert(r>=0&&r<64),t?i64_or(e,i64_shl(i64_one,i64_new(r))):i64_and(e,i64_not(i64_shl(i64_one,i64_new(r))))}},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),function(e){e[e.NULL=0]="NULL",e[e.LINEFEED=10]="LINEFEED",e[e.CARRIAGERETURN=13]="CARRIAGERETURN",e[e.LINESEPARATOR=8232]="LINESEPARATOR",e[e.PARAGRAPHSEPARATOR=8233]="PARAGRAPHSEPARATOR",e[e.NEXTLINE=133]="NEXTLINE",e[e.SPACE=32]="SPACE",e[e.NONBREAKINGSPACE=160]="NONBREAKINGSPACE",e[e.ENQUAD=8192]="ENQUAD",e[e.EMQUAD=8193]="EMQUAD",e[e.ENSPACE=8194]="ENSPACE",e[e.EMSPACE=8195]="EMSPACE",e[e.THREEPEREMSPACE=8196]="THREEPEREMSPACE",e[e.FOURPEREMSPACE=8197]="FOURPEREMSPACE",e[e.SIXPEREMSPACE=8198]="SIXPEREMSPACE",e[e.FIGURESPACE=8199]="FIGURESPACE",e[e.PUNCTUATIONSPACE=8200]="PUNCTUATIONSPACE",e[e.THINSPACE=8201]="THINSPACE",e[e.HAIRSPACE=8202]="HAIRSPACE",e[e.ZEROWIDTHSPACE=8203]="ZEROWIDTHSPACE",e[e.NARROWNOBREAKSPACE=8239]="NARROWNOBREAKSPACE",e[e.IDEOGRAPHICSPACE=12288]="IDEOGRAPHICSPACE",e[e.MATHEMATICALSPACE=8287]="MATHEMATICALSPACE",e[e.OGHAM=5760]="OGHAM",e[e._=95]="_",e[e._0=48]="_0",e[e._1=49]="_1",e[e._2=50]="_2",e[e._3=51]="_3",e[e._4=52]="_4",e[e._5=53]="_5",e[e._6=54]="_6",e[e._7=55]="_7",e[e._8=56]="_8",e[e._9=57]="_9",e[e.a=97]="a",e[e.b=98]="b",e[e.c=99]="c",e[e.d=100]="d",e[e.e=101]="e",e[e.f=102]="f",e[e.g=103]="g",e[e.h=104]="h",e[e.i=105]="i",e[e.j=106]="j",e[e.k=107]="k",e[e.l=108]="l",e[e.m=109]="m",e[e.n=110]="n",e[e.o=111]="o",e[e.p=112]="p",e[e.q=113]="q",e[e.r=114]="r",e[e.s=115]="s",e[e.t=116]="t",e[e.u=117]="u",e[e.v=118]="v",e[e.w=119]="w",e[e.x=120]="x",e[e.y=121]="y",e[e.z=122]="z",e[e.A=65]="A",e[e.B=66]="B",e[e.C=67]="C",e[e.D=68]="D",e[e.E=69]="E",e[e.F=70]="F",e[e.G=71]="G",e[e.H=72]="H",e[e.I=73]="I",e[e.J=74]="J",e[e.K=75]="K",e[e.L=76]="L",e[e.M=77]="M",e[e.N=78]="N",e[e.O=79]="O",e[e.P=80]="P",e[e.Q=81]="Q",e[e.R=82]="R",e[e.S=83]="S",e[e.T=84]="T",e[e.U=85]="U",e[e.V=86]="V",e[e.W=87]="W",e[e.X=88]="X",e[e.Y=89]="Y",e[e.Z=90]="Z",e[e.AMPERSAND=38]="AMPERSAND",e[e.ASTERISK=42]="ASTERISK",e[e.AT=64]="AT",e[e.BACKSLASH=92]="BACKSLASH",e[e.BACKTICK=96]="BACKTICK",e[e.BAR=124]="BAR",e[e.CARET=94]="CARET",e[e.CLOSEBRACE=125]="CLOSEBRACE",e[e.CLOSEBRACKET=93]="CLOSEBRACKET",e[e.CLOSEPAREN=41]="CLOSEPAREN",e[e.COLON=58]="COLON",e[e.COMMA=44]="COMMA",e[e.DOLLAR=36]="DOLLAR",e[e.DOT=46]="DOT",e[e.DOUBLEQUOTE=34]="DOUBLEQUOTE",e[e.EQUALS=61]="EQUALS",e[e.EXCLAMATION=33]="EXCLAMATION",e[e.GREATERTHAN=62]="GREATERTHAN",e[e.HASH=35]="HASH",e[e.LESSTHAN=60]="LESSTHAN",e[e.MINUS=45]="MINUS",e[e.OPENBRACE=123]="OPENBRACE",e[e.OPENBRACKET=91]="OPENBRACKET",e[e.OPENPAREN=40]="OPENPAREN",e[e.PERCENT=37]="PERCENT",e[e.PLUS=43]="PLUS",e[e.QUESTION=63]="QUESTION",e[e.SEMICOLON=59]="SEMICOLON",e[e.SINGLEQUOTE=39]="SINGLEQUOTE",e[e.SLASH=47]="SLASH",e[e.TILDE=126]="TILDE",e[e.BACKSPACE=8]="BACKSPACE",e[e.FORMFEED=12]="FORMFEED",e[e.BYTEORDERMARK=65279]="BYTEORDERMARK",e[e.TAB=9]="TAB",e[e.VERTICALTAB=11]="VERTICALTAB"}(r.CharCode||(r.CharCode={})),r.isLineBreak=function(e){switch(e){case 10:case 13:case 8232:case 8233:return!0;default:return!1}},r.isWhiteSpace=function(e){switch(e){case 32:case 9:case 11:case 12:case 160:case 133:case 5760:case 8239:case 8287:case 12288:case 65279:return!0;default:return e>=8192&&e<=8203}},r.isDecimalDigit=function(e){return e>=48&&e<=57},r.isOctalDigit=function(e){return e>=48&&e<=55},r.isIdentifierStart=function(e){return e>=97&&e<=122||e>=65&&e<=90||95==e||36==e||e>127&&!((r=e)<0||r>65535)&&a(r,n);var r},r.isKeywordCharacter=function(e){return e>=97&&e<=122},r.isIdentifierPart=function(e){return e>=97&&e<=122||e>=65&&e<=90||e>=48&&e<=57||95==e||36==e||e>127&&!((r=e)<0||r>65535)&&a(r,i);var r};var n=[170,170,181,181,186,186,192,214,216,246,248,705,710,721,736,740,748,748,750,750,880,884,886,887,890,893,902,902,904,906,908,908,910,929,931,1013,1015,1153,1162,1319,1329,1366,1369,1369,1377,1415,1488,1514,1520,1522,1568,1610,1646,1647,1649,1747,1749,1749,1765,1766,1774,1775,1786,1788,1791,1791,1808,1808,1810,1839,1869,1957,1969,1969,1994,2026,2036,2037,2042,2042,2048,2069,2074,2074,2084,2084,2088,2088,2112,2136,2208,2208,2210,2220,2308,2361,2365,2365,2384,2384,2392,2401,2417,2423,2425,2431,2437,2444,2447,2448,2451,2472,2474,2480,2482,2482,2486,2489,2493,2493,2510,2510,2524,2525,2527,2529,2544,2545,2565,2570,2575,2576,2579,2600,2602,2608,2610,2611,2613,2614,2616,2617,2649,2652,2654,2654,2674,2676,2693,2701,2703,2705,2707,2728,2730,2736,2738,2739,2741,2745,2749,2749,2768,2768,2784,2785,2821,2828,2831,2832,2835,2856,2858,2864,2866,2867,2869,2873,2877,2877,2908,2909,2911,2913,2929,2929,2947,2947,2949,2954,2958,2960,2962,2965,2969,2970,2972,2972,2974,2975,2979,2980,2984,2986,2990,3001,3024,3024,3077,3084,3086,3088,3090,3112,3114,3123,3125,3129,3133,3133,3160,3161,3168,3169,3205,3212,3214,3216,3218,3240,3242,3251,3253,3257,3261,3261,3294,3294,3296,3297,3313,3314,3333,3340,3342,3344,3346,3386,3389,3389,3406,3406,3424,3425,3450,3455,3461,3478,3482,3505,3507,3515,3517,3517,3520,3526,3585,3632,3634,3635,3648,3654,3713,3714,3716,3716,3719,3720,3722,3722,3725,3725,3732,3735,3737,3743,3745,3747,3749,3749,3751,3751,3754,3755,3757,3760,3762,3763,3773,3773,3776,3780,3782,3782,3804,3807,3840,3840,3904,3911,3913,3948,3976,3980,4096,4138,4159,4159,4176,4181,4186,4189,4193,4193,4197,4198,4206,4208,4213,4225,4238,4238,4256,4293,4295,4295,4301,4301,4304,4346,4348,4680,4682,4685,4688,4694,4696,4696,4698,4701,4704,4744,4746,4749,4752,4784,4786,4789,4792,4798,4800,4800,4802,4805,4808,4822,4824,4880,4882,4885,4888,4954,4992,5007,5024,5108,5121,5740,5743,5759,5761,5786,5792,5866,5870,5872,5888,5900,5902,5905,5920,5937,5952,5969,5984,5996,5998,6e3,6016,6067,6103,6103,6108,6108,6176,6263,6272,6312,6314,6314,6320,6389,6400,6428,6480,6509,6512,6516,6528,6571,6593,6599,6656,6678,6688,6740,6823,6823,6917,6963,6981,6987,7043,7072,7086,7087,7098,7141,7168,7203,7245,7247,7258,7293,7401,7404,7406,7409,7413,7414,7424,7615,7680,7957,7960,7965,7968,8005,8008,8013,8016,8023,8025,8025,8027,8027,8029,8029,8031,8061,8064,8116,8118,8124,8126,8126,8130,8132,8134,8140,8144,8147,8150,8155,8160,8172,8178,8180,8182,8188,8305,8305,8319,8319,8336,8348,8450,8450,8455,8455,8458,8467,8469,8469,8473,8477,8484,8484,8486,8486,8488,8488,8490,8493,8495,8505,8508,8511,8517,8521,8526,8526,8544,8584,11264,11310,11312,11358,11360,11492,11499,11502,11506,11507,11520,11557,11559,11559,11565,11565,11568,11623,11631,11631,11648,11670,11680,11686,11688,11694,11696,11702,11704,11710,11712,11718,11720,11726,11728,11734,11736,11742,11823,11823,12293,12295,12321,12329,12337,12341,12344,12348,12353,12438,12445,12447,12449,12538,12540,12543,12549,12589,12593,12686,12704,12730,12784,12799,13312,19893,19968,40908,40960,42124,42192,42237,42240,42508,42512,42527,42538,42539,42560,42606,42623,42647,42656,42735,42775,42783,42786,42888,42891,42894,42896,42899,42912,42922,43e3,43009,43011,43013,43015,43018,43020,43042,43072,43123,43138,43187,43250,43255,43259,43259,43274,43301,43312,43334,43360,43388,43396,43442,43471,43471,43520,43560,43584,43586,43588,43595,43616,43638,43642,43642,43648,43695,43697,43697,43701,43702,43705,43709,43712,43712,43714,43714,43739,43741,43744,43754,43762,43764,43777,43782,43785,43790,43793,43798,43808,43814,43816,43822,43968,44002,44032,55203,55216,55238,55243,55291,63744,64109,64112,64217,64256,64262,64275,64279,64285,64285,64287,64296,64298,64310,64312,64316,64318,64318,64320,64321,64323,64324,64326,64433,64467,64829,64848,64911,64914,64967,65008,65019,65136,65140,65142,65276,65313,65338,65345,65370,65382,65470,65474,65479,65482,65487,65490,65495,65498,65500],i=[170,170,181,181,186,186,192,214,216,246,248,705,710,721,736,740,748,748,750,750,768,884,886,887,890,893,902,902,904,906,908,908,910,929,931,1013,1015,1153,1155,1159,1162,1319,1329,1366,1369,1369,1377,1415,1425,1469,1471,1471,1473,1474,1476,1477,1479,1479,1488,1514,1520,1522,1552,1562,1568,1641,1646,1747,1749,1756,1759,1768,1770,1788,1791,1791,1808,1866,1869,1969,1984,2037,2042,2042,2048,2093,2112,2139,2208,2208,2210,2220,2276,2302,2304,2403,2406,2415,2417,2423,2425,2431,2433,2435,2437,2444,2447,2448,2451,2472,2474,2480,2482,2482,2486,2489,2492,2500,2503,2504,2507,2510,2519,2519,2524,2525,2527,2531,2534,2545,2561,2563,2565,2570,2575,2576,2579,2600,2602,2608,2610,2611,2613,2614,2616,2617,2620,2620,2622,2626,2631,2632,2635,2637,2641,2641,2649,2652,2654,2654,2662,2677,2689,2691,2693,2701,2703,2705,2707,2728,2730,2736,2738,2739,2741,2745,2748,2757,2759,2761,2763,2765,2768,2768,2784,2787,2790,2799,2817,2819,2821,2828,2831,2832,2835,2856,2858,2864,2866,2867,2869,2873,2876,2884,2887,2888,2891,2893,2902,2903,2908,2909,2911,2915,2918,2927,2929,2929,2946,2947,2949,2954,2958,2960,2962,2965,2969,2970,2972,2972,2974,2975,2979,2980,2984,2986,2990,3001,3006,3010,3014,3016,3018,3021,3024,3024,3031,3031,3046,3055,3073,3075,3077,3084,3086,3088,3090,3112,3114,3123,3125,3129,3133,3140,3142,3144,3146,3149,3157,3158,3160,3161,3168,3171,3174,3183,3202,3203,3205,3212,3214,3216,3218,3240,3242,3251,3253,3257,3260,3268,3270,3272,3274,3277,3285,3286,3294,3294,3296,3299,3302,3311,3313,3314,3330,3331,3333,3340,3342,3344,3346,3386,3389,3396,3398,3400,3402,3406,3415,3415,3424,3427,3430,3439,3450,3455,3458,3459,3461,3478,3482,3505,3507,3515,3517,3517,3520,3526,3530,3530,3535,3540,3542,3542,3544,3551,3570,3571,3585,3642,3648,3662,3664,3673,3713,3714,3716,3716,3719,3720,3722,3722,3725,3725,3732,3735,3737,3743,3745,3747,3749,3749,3751,3751,3754,3755,3757,3769,3771,3773,3776,3780,3782,3782,3784,3789,3792,3801,3804,3807,3840,3840,3864,3865,3872,3881,3893,3893,3895,3895,3897,3897,3902,3911,3913,3948,3953,3972,3974,3991,3993,4028,4038,4038,4096,4169,4176,4253,4256,4293,4295,4295,4301,4301,4304,4346,4348,4680,4682,4685,4688,4694,4696,4696,4698,4701,4704,4744,4746,4749,4752,4784,4786,4789,4792,4798,4800,4800,4802,4805,4808,4822,4824,4880,4882,4885,4888,4954,4957,4959,4992,5007,5024,5108,5121,5740,5743,5759,5761,5786,5792,5866,5870,5872,5888,5900,5902,5908,5920,5940,5952,5971,5984,5996,5998,6e3,6002,6003,6016,6099,6103,6103,6108,6109,6112,6121,6155,6157,6160,6169,6176,6263,6272,6314,6320,6389,6400,6428,6432,6443,6448,6459,6470,6509,6512,6516,6528,6571,6576,6601,6608,6617,6656,6683,6688,6750,6752,6780,6783,6793,6800,6809,6823,6823,6912,6987,6992,7001,7019,7027,7040,7155,7168,7223,7232,7241,7245,7293,7376,7378,7380,7414,7424,7654,7676,7957,7960,7965,7968,8005,8008,8013,8016,8023,8025,8025,8027,8027,8029,8029,8031,8061,8064,8116,8118,8124,8126,8126,8130,8132,8134,8140,8144,8147,8150,8155,8160,8172,8178,8180,8182,8188,8204,8205,8255,8256,8276,8276,8305,8305,8319,8319,8336,8348,8400,8412,8417,8417,8421,8432,8450,8450,8455,8455,8458,8467,8469,8469,8473,8477,8484,8484,8486,8486,8488,8488,8490,8493,8495,8505,8508,8511,8517,8521,8526,8526,8544,8584,11264,11310,11312,11358,11360,11492,11499,11507,11520,11557,11559,11559,11565,11565,11568,11623,11631,11631,11647,11670,11680,11686,11688,11694,11696,11702,11704,11710,11712,11718,11720,11726,11728,11734,11736,11742,11744,11775,11823,11823,12293,12295,12321,12335,12337,12341,12344,12348,12353,12438,12441,12442,12445,12447,12449,12538,12540,12543,12549,12589,12593,12686,12704,12730,12784,12799,13312,19893,19968,40908,40960,42124,42192,42237,42240,42508,42512,42539,42560,42607,42612,42621,42623,42647,42655,42737,42775,42783,42786,42888,42891,42894,42896,42899,42912,42922,43e3,43047,43072,43123,43136,43204,43216,43225,43232,43255,43259,43259,43264,43309,43312,43347,43360,43388,43392,43456,43471,43481,43520,43574,43584,43597,43600,43609,43616,43638,43642,43643,43648,43714,43739,43741,43744,43759,43762,43766,43777,43782,43785,43790,43793,43798,43808,43814,43816,43822,43968,44010,44012,44013,44016,44025,44032,55203,55216,55238,55243,55291,63744,64109,64112,64217,64256,64262,64275,64279,64285,64296,64298,64310,64312,64316,64318,64318,64320,64321,64323,64324,64326,64433,64467,64829,64848,64911,64914,64967,65008,65019,65024,65039,65056,65062,65075,65076,65101,65103,65136,65140,65142,65276,65296,65305,65313,65338,65343,65343,65345,65370,65382,65470,65474,65479,65482,65487,65490,65495,65498,65500];function a(e,r){if(e>1),(n=r[t-=1&t])<=e&&e<=r[t+1])return!0;e=e.length&&(e=void 0),{value:e&&e[t++],done:!e}}}},i=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,i,a=t.call(e),s=[];try{for(;(void 0===r||r-- >0)&&!(n=a.next()).done;)s.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(t=a.return)&&t.call(a)}finally{if(i)throw i.error}}return s};Object.defineProperty(r,"__esModule",{value:!0}),r.makeArray=function(e){if(void 0===e&&(e=null),e){for(var r=new Array(e.length),t=0,n=e.length;t0||n=0;)if(e.charCodeAt(a)==i){t-a==3&&46==e.charCodeAt(a+1)&&46==e.charCodeAt(a+2)||(e=r?e.substring(0,a):e.substring(0,a)+e.substring(t+3),n-=t+3-a,t=a-1);break}if(a<0&&t>0&&(2!=t||46!=e.charCodeAt(0)||46!=e.charCodeAt(1))){n=(e=e.substring(t+4)).length;continue}}}t++}return n>0?e:"."}function s(e){var r=e.length;if(r<=1){if(0==r)return".";if(e.charCodeAt(0)==i)return e}for(;--r>0;)if(e.charCodeAt(r)==i)return e.substring(0,r);return"."}r.normalizePath=a,r.resolvePath=function(e,r){return e.startsWith("std/")?e:a(s(r)+n.PATH_DELIMITER+e)},r.dirname=s},function(e,r,t){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n=" ",i=" ",a=" ";r.indent=function(e,r){for(;r>=4;)e.push(a),r-=4;r>=2&&(e.push(i),r-=2),r&&e.push(n)}},function(e,r,t){"use strict";function n(e,r){return e[r]|e[r+1]<<8|e[r+2]<<16|e[r+3]<<24}function i(e,r,t){r[t]=e,r[t+1]=e>>>8,r[t+2]=e>>>16,r[t+3]=e>>>24}function a(e,r){var t=n(e,r),i=n(e,r+4);return i64_new(t,i)}Object.defineProperty(r,"__esModule",{value:!0}),r.readI8=function(e,r){return e[r]},r.writeI8=function(e,r,t){r[t]=e},r.readI16=function(e,r){return e[r]|e[r+1]<<8},r.writeI16=function(e,r,t){r[t]=e,r[t+1]=e>>>8},r.readI32=n,r.writeI32=i,r.readI64=a,r.writeI64=function(e,r,t){i(i64_low(e),r,t),i(i64_high(e),r,t+4)},r.readF32=function(e,r){return i32_as_f32(n(e,r))},r.writeF32=function(e,r,t){i(f32_as_i32(e),r,t)},r.readF64=function(e,r){return i64_as_f64(a(e,r))},r.writeF64=function(e,r,t){var n=f64_as_i64(e);i(i64_low(n),r,t),i(i64_high(n),r,t+4)}}])}); //# sourceMappingURL=assemblyscript.js.map \ No newline at end of file diff --git a/dist/assemblyscript.js.map b/dist/assemblyscript.js.map index c9ff4809f9..dc5c791a75 100644 --- a/dist/assemblyscript.js.map +++ b/dist/assemblyscript.js.map @@ -1 +1 @@ -{"version":3,"sources":["webpack://assemblyscript/webpack/universalModuleDefinition","webpack://assemblyscript/webpack/bootstrap","webpack://assemblyscript/./src/common.ts","webpack://assemblyscript/./src/util/index.ts","webpack://assemblyscript/./src/diagnostics.ts","webpack://assemblyscript/./src/program.ts","webpack://assemblyscript/./src/module.ts","webpack://assemblyscript/./src/ast.ts","webpack://assemblyscript/./src/types.ts","webpack://assemblyscript/./src/tokenizer.ts","webpack://assemblyscript/(webpack)/buildin/global.js","webpack://assemblyscript/./src/resolver.ts","webpack://assemblyscript/./src/flow.ts","webpack://assemblyscript/./src/compiler.ts","webpack://assemblyscript/./src/diagnosticMessages.generated.ts","webpack://assemblyscript/./src/builtins.ts","webpack://assemblyscript/./src/decompiler.ts","webpack://assemblyscript/./src/definitions.ts","webpack://assemblyscript/./src/parser.ts","webpack://assemblyscript/./src/glue/js/index.ts","webpack://assemblyscript/./src/glue/js/binaryen.js","webpack://assemblyscript/external \"binaryen\"","webpack://assemblyscript/./std/portable/index.js","webpack://assemblyscript/./src/glue/js/float.js","webpack://assemblyscript/./src/glue/js/i64.js","webpack://assemblyscript/./node_modules/long/src/long.js","webpack://assemblyscript/./std/assembly/shared/feature.ts","webpack://assemblyscript/./std/assembly/shared/target.ts","webpack://assemblyscript/./std/assembly/shared/typeinfo.ts","webpack://assemblyscript/./src/index.ts","webpack://assemblyscript/./src/util/bitset.ts","webpack://assemblyscript/./src/util/charcode.ts","webpack://assemblyscript/./src/util/collections.ts","webpack://assemblyscript/./src/util/path.ts","webpack://assemblyscript/./src/util/text.ts","webpack://assemblyscript/./src/util/binary.ts"],"names":["root","factory","exports","module","require","define","amd","self","this","__WEBPACK_EXTERNAL_MODULE__20__","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","CommonFlags","PATH_DELIMITER","PARENT_SUBST","GETTER_PREFIX","SETTER_PREFIX","INSTANCE_DELIMITER","STATIC_DELIMITER","INNER_DELIMITER","LIBRARY_SUBST","LIBRARY_PREFIX","INDEX_SUFFIX","CommonSymbols","EMPTY","i8","i16","i32","i64","isize","u8","u16","u32","u64","usize","bool","f32","f64","v128","i8x16","u8x16","i16x8","u16x8","i32x4","u32x4","i64x2","u64x2","f32x4","f64x2","void_","number","boolean","string","native","null_","true_","false_","this_","super_","constructor","ASC_TARGET","ASC_NO_TREESHAKING","ASC_NO_ASSERT","ASC_MEMORY_BASE","ASC_OPTIMIZE_LEVEL","ASC_SHRINK_LEVEL","ASC_FEATURE_MUTABLE_GLOBAL","ASC_FEATURE_SIGN_EXTENSION","ASC_FEATURE_BULK_MEMORY","ASC_FEATURE_SIMD","ASC_FEATURE_THREADS","I8","I16","I32","I64","Isize","U8","U16","U32","U64","Usize","Bool","F32","F64","V128","String","Array","FixedArray","Set","Map","ArrayBufferView","ArrayBuffer","Math","Mathf","Int8Array","Int16Array","Int32Array","Int64Array","Uint8Array","Uint8ClampedArray","Uint16Array","Uint32Array","Uint64Array","Float32Array","Float64Array","abort","pow","mod","alloc","realloc","free","retain","release","collect","typeinfo","instanceof_","visit","allocArray","feature_1","Feature","target_1","Target","typeinfo_1","Typeinfo","TypeinfoFlags","__export","isPowerOf2","x","DiagnosticCategory","diagnosticMessages_generated_1","util_1","diagnosticMessages_generated_2","diagnosticCategoryToString","category","INFO","WARNING","ERROR","assert","diagnosticCategoryToColor","COLOR_BLUE","COLOR_YELLOW","COLOR_RED","DiagnosticCode","diagnosticCodeToString","COLOR_RESET","DiagnosticMessage","code","message","range","relatedRange","arg0","arg1","arg2","replace","createInfo","createWarning","createError","withRange","withRelatedRange","toString","source","normalizedPath","line","column","formatDiagnosticContext","useColors","text","len","length","start","end","isLineBreak","charCodeAt","sb","substring","push","join","formatDiagnosticMessage","showContext","DiagnosticEmitter","diagnostics","emitDiagnostic","info","infoRelated","warning","warningRelated","error","errorRelated","OperatorKind","common_1","diagnostics_1","types_1","ast_1","resolver_1","flow_1","QueuedImport","localFile","localIdentifier","foreignIdentifier","foreignPath","foreignPathAlt","QueuedExport","QueuedExportStar","pathLiteral","operatorKindFromDecorator","decoratorKind","arg","DecoratorKind","OPERATOR","OPERATOR_BINARY","INDEXED_GET","INDEXED_SET","UNCHECKED_INDEXED_GET","UNCHECKED_INDEXED_SET","ADD","SUB","MUL","POW","DIV","REM","BITWISE_AND","BITWISE_OR","BITWISE_XOR","EQ","NE","GT","GE","BITWISE_SHR","BITWISE_SHR_U","LT","LE","BITWISE_SHL","OPERATOR_PREFIX","PLUS","PREFIX_INC","MINUS","PREFIX_DEC","NOT","BITWISE_NOT","OPERATOR_POSTFIX","POSTFIX_INC","POSTFIX_DEC","INVALID","ElementKind","DecoratorFlags","Program","_super","_this","sources","diagnosticsOffset","filesByName","elementsByName","elementsByDeclaration","instancesByName","typeClasses","managedClasses","nextClassId","nativeDummySignature","nativeSource","Source","SourceKind","LIBRARY","nativeFile","File","set","internalName","resolver","Resolver","__extends","writeRuntimeHeader","buffer","offset","classInstance","payloadSize","writeI32","id","makeNativeVariableDeclaration","flags","NONE","Node","createVariableDeclaration","createIdentifierExpression","makeNativeTypeDeclaration","identifier","createTypeDeclaration","createOmittedType","makeNativeFunctionDeclaration","createFunctionDeclaration","createSignature","createType","createSimpleTypeName","makeNativeNamespaceDeclaration","createNamespaceDeclaration","makeNativeFunction","signature","parent","decoratorFlags","Function","FunctionPrototype","getElementByDeclaration","declaration","has","initialize","options","registerNativeType","Type","isizeType","usizeType","void","add","TypeDefinition","EXPORT","GENERIC","BUILTIN","hasFeature","registerConstantInteger","i64_new","isWasm64","WASM64","WASM32","noAssert","memoryBase","optimizeLevelHint","shrinkLevelHint","queuedImports","queuedExports","queuedExportsStar","queuedExtends","queuedImplements","k","file","statements","j","statement","kind","NodeKind","initializeExports","EXPORTDEFAULT","initializeExportDefault","IMPORT","initializeImports","VARIABLE","initializeVariables","CLASSDECLARATION","initializeClass","ENUMDECLARATION","initializeEnum","FUNCTIONDECLARATION","initializeFunction","INTERFACEDECLARATION","initializeInterface","NAMESPACEDECLARATION","initializeNamespace","TYPEDECLARATION","initializeTypeDefinition","queuedExportsStar_1","__values","queuedExportsStar_1_1","next","done","_g","__read","exportsStar","exportStar","foreignFile","lookupForeignFile","ensureExportStar","File_0_not_found","queuedImport","element","lookupForeign","Module_0_has_no_exported_member_1","localName","asImportedNamespace","queuedExports_1","queuedExports_1_1","_h","exports_1","e_3","exports_1_1","_j","exportName","queuedExport","ensureExport","lookupInSelf","globalElement","lookupGlobal","DeclaredElement","arrayBufferInstance","requireClass","stringInstance","arrayBufferViewInstance","registerNativeTypeClass","i8ArrayPrototype","CLASS_PROTOTYPE","i16ArrayPrototype","i32ArrayPrototype","i64ArrayPrototype","u8ArrayPrototype","u8ClampedArrayPrototype","u16ArrayPrototype","u32ArrayPrototype","u64ArrayPrototype","f32ArrayPrototype","f64ArrayPrototype","thisPrototype","extendsNode","baseElement","resolveTypeName","basePrototype","hasDecorator","SEALED","Class_0_is_sealed_and_cannot_be_extended","identifierNode","UNMANAGED","Unmanaged_classes_cannot_extend_managed_classes_and_vice_versa","Range","A_class_may_only_extend_another_class","globalAliases","globalAliases_1","globalAliases_1_1","_k","alias","firstChar","parseInt","Error","arrayPrototype","fixedArrayPrototype","setPrototype","mapPrototype","abortInstance","requireFunction","allocInstance","reallocInstance","freeInstance","retainInstance","releaseInstance","collectInstance","typeinfoInstance","instanceofInstance","visitInstance","allocArrayInstance","_l","values","_m","isEntry","_o","e_6","_p","markModuleExport","resolved","resolveClass","FUNCTION_PROTOTYPE","resolveFunction","MODULE_EXPORT","instanceMembers","_c","_d","member","PROPERTY_PROTOTYPE","getterPrototype","setterPrototype","PROPERTY","FUNCTION","FIELD","CLASS","members","_e","_f","type","setType","typeKind","className","classElement","is","global","Global","CONST","setConstantIntegerValue","registerConstantFloat","setConstantFloatValue","ensureGlobal","merged","tryMerge","Duplicate_identifier_0","elements","requireGlobal","foreignName","lookupExport","fileQueuedExports","checkDecorators","decorators","acceptedFlags","decorator","flag","decoratorKindToFlag","decoratorNameToKind","isLibrary","Decorator_0_is_not_valid_here","Duplicate_decorator","ClassPrototype","GLOBAL","implementsTypes","numImplementsTypes","Unmanaged_classes_cannot_implement_interfaces","Operation_not_supported","extendsType","memberDeclarations","memberDeclaration","FIELDDECLARATION","initializeField","METHODDECLARATION","isAny","GET","SET","initializeProperty","initializeMethod","INDEXSIGNATUREDECLARATION","STATIC","INTERFACE_PROTOTYPE","READONLY","INLINE","LAZY","UNSAFE","ABSTRACT","FieldPrototype","addInstance","isStatic","CONSTRUCTOR","checkOperatorOverloads","classPrototype","numArgs","arguments","firstArg","LITERAL","literalKind","LiteralKind","STRING","overloads","overloadPrototypes","Duplicate_function_implementation","operatorKind","String_literal_expected","Expected_0_arguments_but_got_1","ensureProperty","parentMembers","PropertyPrototype","Duplicate_property_0","isGetter","Enum","initializeEnumValue","EnumValue","initializeExport","internalPath","queued","endsWith","path","exportedName","Export_declaration_conflicts_with_exported_declaration_of_0","declarations","initializeImport","namespaceName","validDecorators","AMBIENT","EXTERNAL","INSTANCE","InterfacePrototype","original","Namespace","copyMembers","DECLARE","Element","program","shadowType","FILE","current","unset","originalDeclaration","actual","isBound","TypedElement","apply","RESOLVED","startFunction","Signature","isImport","lookup","includes","exports_2","exports_2_1","_b","memberName","TYPEDEFINITION","mangleInternalName","typeParameters","NAMESPACE","ENUM","ConstantValueKind","VariableLikeElement","constantValueKind","initializer","constantIntegerValue","INLINED","constantFloatValue","ENUMVALUE","isImmutable","Parameter","Local","index","LOCAL","instances","boundPrototypes","body","arrowKind","toBound","bound","getResolvedInstance","instanceKey","setResolvedInstance","instance","nameInclTypeParameters","contextualTypeArguments","localsByName","localsByIndex","additionalLocals","debugLocations","ref","functionTableIndex","trampoline","nextInlineId","nextAnonymousId","nextAutoreleaseId","tempI32s","tempI64s","tempF32s","tempF64s","tempV128s","nextBreakId","breakStack","breakLabel","asFunction","localIndex","local","thisType","parameterTypes","parameterType","parameterName","getParameterName","flow","Flow","registerConcreteElement","addLocal","locals","finalize","sourceMap","debugLocation","setDebugLocation","debugInfoRef","debugInfoIndex","FunctionTarget","__s","FUNCTION_TARGET","toSignatureString","FIELD_PROTOTYPE","parameterIndex","Field","memoryOffset","firstDeclaration","Property","getterInstance","setterInstance","AcyclicState","_isInterface","constructorPrototype","extends","basePtototype","Class","typeArguments","base","INTERFACE","currentMemoryOffset","constructorInstance","_id","_acyclic","rttiFlags","asClass","inheritedTypeArguments","inheritedTypeArguments_1","inheritedTypeArguments_1_1","baseName","baseType","typeParameterNodes","numTypeArguments","isBuiltinArray","lengthField","lookupOverload","isAssignableTo","target","unchecked","uncheckedOverload","overload","offsetof","fieldName","field","writeField","baseOffset","writeI8","writeI16","writeF32","writeF64","getTypeArgumentsTo","extendedPrototype","getArrayValueType","abvInstance","acyclic","hasCycle","cyclesTo","other","except","classReference","Interface","older","newer","Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local","src","dest","srcMembers","destMembers","srcMembers_1","srcMembers_1_1","isInstance","asGlobal","NativeType","ExpressionId","_BinaryenTypeNone","_BinaryenTypeInt32","_BinaryenTypeInt64","_BinaryenTypeFloat32","_BinaryenTypeFloat64","_BinaryenTypeVec128","_BinaryenTypeUnreachable","_BinaryenTypeAuto","FeatureFlags","_BinaryenFeatureAtomics","_BinaryenFeatureMutableGlobals","_BinaryenFeatureNontrappingFPToInt","_BinaryenFeatureSIMD128","_BinaryenFeatureBulkMemory","_BinaryenFeatureSignExt","_BinaryenFeatureExceptionHandling","_BinaryenInvalidId","_BinaryenBlockId","_BinaryenIfId","_BinaryenLoopId","_BinaryenBreakId","_BinaryenSwitchId","_BinaryenCallId","_BinaryenCallIndirectId","_BinaryenLocalGetId","_BinaryenLocalSetId","_BinaryenGlobalGetId","_BinaryenGlobalSetId","_BinaryenLoadId","_BinaryenStoreId","_BinaryenConstId","_BinaryenUnaryId","_BinaryenBinaryId","_BinaryenSelectId","_BinaryenDropId","_BinaryenReturnId","_BinaryenHostId","_BinaryenNopId","_BinaryenUnreachableId","_BinaryenAtomicCmpxchgId","_BinaryenAtomicRMWId","_BinaryenAtomicWaitId","_BinaryenAtomicNotifyId","_BinaryenSIMDExtractId","_BinaryenSIMDReplaceId","_BinaryenSIMDShuffleId","_BinaryenSIMDBitselectId","_BinaryenSIMDShiftId","_BinaryenMemoryInitId","_BinaryenDataDropId","_BinaryenMemoryCopyId","_BinaryenMemoryFillId","UnaryOp","_BinaryenClzInt32","_BinaryenCtzInt32","_BinaryenPopcntInt32","_BinaryenNegFloat32","_BinaryenAbsFloat32","_BinaryenCeilFloat32","_BinaryenFloorFloat32","_BinaryenTruncFloat32","_BinaryenNearestFloat32","_BinaryenSqrtFloat32","_BinaryenEqZInt32","_BinaryenClzInt64","_BinaryenCtzInt64","_BinaryenPopcntInt64","_BinaryenNegFloat64","_BinaryenAbsFloat64","_BinaryenCeilFloat64","_BinaryenFloorFloat64","_BinaryenTruncFloat64","_BinaryenNearestFloat64","_BinaryenSqrtFloat64","_BinaryenEqZInt64","_BinaryenExtendSInt32","_BinaryenExtendUInt32","_BinaryenWrapInt64","_BinaryenTruncSFloat32ToInt32","_BinaryenTruncSFloat32ToInt64","_BinaryenTruncUFloat32ToInt32","_BinaryenTruncUFloat32ToInt64","_BinaryenTruncSFloat64ToInt32","_BinaryenTruncSFloat64ToInt64","_BinaryenTruncUFloat64ToInt32","_BinaryenTruncUFloat64ToInt64","_BinaryenReinterpretFloat32","_BinaryenReinterpretFloat64","_BinaryenConvertSInt32ToFloat32","_BinaryenConvertSInt32ToFloat64","_BinaryenConvertUInt32ToFloat32","_BinaryenConvertUInt32ToFloat64","_BinaryenConvertSInt64ToFloat32","_BinaryenConvertSInt64ToFloat64","_BinaryenConvertUInt64ToFloat32","_BinaryenConvertUInt64ToFloat64","_BinaryenPromoteFloat32","_BinaryenDemoteFloat64","_BinaryenReinterpretInt32","_BinaryenReinterpretInt64","_BinaryenExtendS8Int32","_BinaryenExtendS16Int32","_BinaryenExtendS8Int64","_BinaryenExtendS16Int64","_BinaryenExtendS32Int64","_BinaryenSplatVecI8x16","_BinaryenSplatVecI16x8","_BinaryenSplatVecI32x4","_BinaryenSplatVecI64x2","_BinaryenSplatVecF32x4","_BinaryenSplatVecF64x2","_BinaryenNotVec128","_BinaryenNegVecI8x16","_BinaryenAnyTrueVecI8x16","_BinaryenAllTrueVecI8x16","_BinaryenNegVecI16x8","_BinaryenAnyTrueVecI16x8","_BinaryenAllTrueVecI16x8","_BinaryenNegVecI32x4","_BinaryenAnyTrueVecI32x4","_BinaryenAllTrueVecI32x4","_BinaryenNegVecI64x2","_BinaryenAnyTrueVecI64x2","_BinaryenAllTrueVecI64x2","_BinaryenAbsVecF32x4","_BinaryenNegVecF32x4","_BinaryenSqrtVecF32x4","_BinaryenAbsVecF64x2","_BinaryenNegVecF64x2","_BinaryenSqrtVecF64x2","_BinaryenTruncSatSVecF32x4ToVecI32x4","_BinaryenTruncSatUVecF32x4ToVecI32x4","_BinaryenTruncSatSVecF64x2ToVecI64x2","_BinaryenTruncSatUVecF64x2ToVecI64x2","_BinaryenConvertSVecI32x4ToVecF32x4","_BinaryenConvertUVecI32x4ToVecF32x4","_BinaryenConvertSVecI64x2ToVecF64x2","_BinaryenConvertUVecI64x2ToVecF64x2","BinaryOp","_BinaryenAddInt32","_BinaryenSubInt32","_BinaryenMulInt32","_BinaryenDivSInt32","_BinaryenDivUInt32","_BinaryenRemSInt32","_BinaryenRemUInt32","_BinaryenAndInt32","_BinaryenOrInt32","_BinaryenXorInt32","_BinaryenShlInt32","_BinaryenShrUInt32","_BinaryenShrSInt32","_BinaryenRotLInt32","_BinaryenRotRInt32","_BinaryenEqInt32","_BinaryenNeInt32","_BinaryenLtSInt32","_BinaryenLtUInt32","_BinaryenLeSInt32","_BinaryenLeUInt32","_BinaryenGtSInt32","_BinaryenGtUInt32","_BinaryenGeSInt32","_BinaryenGeUInt32","_BinaryenAddInt64","_BinaryenSubInt64","_BinaryenMulInt64","_BinaryenDivSInt64","_BinaryenDivUInt64","_BinaryenRemSInt64","_BinaryenRemUInt64","_BinaryenAndInt64","_BinaryenOrInt64","_BinaryenXorInt64","_BinaryenShlInt64","_BinaryenShrUInt64","_BinaryenShrSInt64","_BinaryenRotLInt64","_BinaryenRotRInt64","_BinaryenEqInt64","_BinaryenNeInt64","_BinaryenLtSInt64","_BinaryenLtUInt64","_BinaryenLeSInt64","_BinaryenLeUInt64","_BinaryenGtSInt64","_BinaryenGtUInt64","_BinaryenGeSInt64","_BinaryenGeUInt64","_BinaryenAddFloat32","_BinaryenSubFloat32","_BinaryenMulFloat32","_BinaryenDivFloat32","_BinaryenCopySignFloat32","_BinaryenMinFloat32","_BinaryenMaxFloat32","_BinaryenEqFloat32","_BinaryenNeFloat32","_BinaryenLtFloat32","_BinaryenLeFloat32","_BinaryenGtFloat32","_BinaryenGeFloat32","_BinaryenAddFloat64","_BinaryenSubFloat64","_BinaryenMulFloat64","_BinaryenDivFloat64","_BinaryenCopySignFloat64","_BinaryenMinFloat64","_BinaryenMaxFloat64","_BinaryenEqFloat64","_BinaryenNeFloat64","_BinaryenLtFloat64","_BinaryenLeFloat64","_BinaryenGtFloat64","_BinaryenGeFloat64","_BinaryenEqVecI8x16","_BinaryenNeVecI8x16","_BinaryenLtSVecI8x16","_BinaryenLtUVecI8x16","_BinaryenLeSVecI8x16","_BinaryenLeUVecI8x16","_BinaryenGtSVecI8x16","_BinaryenGtUVecI8x16","_BinaryenGeSVecI8x16","_BinaryenGeUVecI8x16","_BinaryenEqVecI16x8","_BinaryenNeVecI16x8","_BinaryenLtSVecI16x8","_BinaryenLtUVecI16x8","_BinaryenLeSVecI16x8","_BinaryenLeUVecI16x8","_BinaryenGtSVecI16x8","_BinaryenGtUVecI16x8","_BinaryenGeSVecI16x8","_BinaryenGeUVecI16x8","_BinaryenEqVecI32x4","_BinaryenNeVecI32x4","_BinaryenLtSVecI32x4","_BinaryenLtUVecI32x4","_BinaryenLeSVecI32x4","_BinaryenLeUVecI32x4","_BinaryenGtSVecI32x4","_BinaryenGtUVecI32x4","_BinaryenGeSVecI32x4","_BinaryenGeUVecI32x4","_BinaryenEqVecF32x4","_BinaryenNeVecF32x4","_BinaryenLtVecF32x4","_BinaryenLeVecF32x4","_BinaryenGtVecF32x4","_BinaryenGeVecF32x4","_BinaryenEqVecF64x2","_BinaryenNeVecF64x2","_BinaryenLtVecF64x2","_BinaryenLeVecF64x2","_BinaryenGtVecF64x2","_BinaryenGeVecF64x2","_BinaryenAndVec128","_BinaryenOrVec128","_BinaryenXorVec128","_BinaryenAddVecI8x16","_BinaryenAddSatSVecI8x16","_BinaryenAddSatUVecI8x16","_BinaryenSubVecI8x16","_BinaryenSubSatSVecI8x16","_BinaryenSubSatUVecI8x16","_BinaryenMulVecI8x16","_BinaryenAddVecI16x8","_BinaryenAddSatSVecI16x8","_BinaryenAddSatUVecI16x8","_BinaryenSubVecI16x8","_BinaryenSubSatSVecI16x8","_BinaryenSubSatUVecI16x8","_BinaryenMulVecI16x8","_BinaryenAddVecI32x4","_BinaryenSubVecI32x4","_BinaryenMulVecI32x4","_BinaryenAddVecI64x2","_BinaryenSubVecI64x2","_BinaryenAddVecF32x4","_BinaryenSubVecF32x4","_BinaryenMulVecF32x4","_BinaryenDivVecF32x4","_BinaryenMinVecF32x4","_BinaryenMaxVecF32x4","_BinaryenAddVecF64x2","_BinaryenSubVecF64x2","_BinaryenMulVecF64x2","_BinaryenDivVecF64x2","_BinaryenMinVecF64x2","_BinaryenMaxVecF64x2","HostOp","_BinaryenMemorySize","_BinaryenMemoryGrow","AtomicRMWOp","_BinaryenAtomicRMWAdd","_BinaryenAtomicRMWSub","_BinaryenAtomicRMWAnd","_BinaryenAtomicRMWOr","_BinaryenAtomicRMWXor","_BinaryenAtomicRMWXchg","SIMDExtractOp","_BinaryenExtractLaneSVecI8x16","_BinaryenExtractLaneUVecI8x16","_BinaryenExtractLaneSVecI16x8","_BinaryenExtractLaneUVecI16x8","_BinaryenExtractLaneVecI32x4","_BinaryenExtractLaneVecI64x2","_BinaryenExtractLaneVecF32x4","_BinaryenExtractLaneVecF64x2","SIMDReplaceOp","_BinaryenReplaceLaneVecI8x16","_BinaryenReplaceLaneVecI16x8","_BinaryenReplaceLaneVecI32x4","_BinaryenReplaceLaneVecI64x2","_BinaryenReplaceLaneVecF32x4","_BinaryenReplaceLaneVecF64x2","SIMDShiftOp","_BinaryenShlVecI8x16","_BinaryenShrSVecI8x16","_BinaryenShrUVecI8x16","_BinaryenShlVecI16x8","_BinaryenShrSVecI16x8","_BinaryenShrUVecI16x8","_BinaryenShlVecI32x4","_BinaryenShrSVecI32x4","_BinaryenShrUVecI32x4","_BinaryenShlVecI64x2","_BinaryenShrSVecI64x2","_BinaryenShrUVecI64x2","MemorySegment","segment","Module","hasTemporaryFunction","cachedPrecomputeNames","cachedStrings","_BinaryenModuleCreate","lit","memory","allocate","_BinaryenSizeofLiteral","createFrom","cArr","allocU8Array","_BinaryenModuleRead","changetype","addFunctionType","result","paramTypes","cStr","allocStringCached","allocI32Array","_BinaryenAddFunctionType","getFunctionTypeBySignature","_BinaryenGetFunctionTypeBySignature","removeFunctionType","_BinaryenRemoveFunctionType","out","_BinaryenLiteralInt32","_BinaryenConst","valueLow","valueHigh","_BinaryenLiteralInt64","_BinaryenLiteralFloat32","_BinaryenLiteralFloat64","bytes","store","_BinaryenLiteralVec128","unary","op","expr","_BinaryenUnary","binary","left","right","_BinaryenBinary","host","operands","allocPtrArray","_BinaryenHost","local_get","_BinaryenLocalGet","local_tee","_BinaryenLocalTee","global_get","_BinaryenGlobalGet","load","signed","ptr","align","_BinaryenLoad","None","_BinaryenStore","atomic_load","_BinaryenAtomicLoad","atomic_store","_BinaryenAtomicStore","atomic_rmw","_BinaryenAtomicRMW","atomic_cmpxchg","expected","replacement","_BinaryenAtomicCmpxchg","atomic_wait","timeout","expectedType","_BinaryenAtomicWait","atomic_notify","notifyCount","_BinaryenAtomicNotify","local_set","_BinaryenLocalSet","global_set","_BinaryenGlobalSet","block","label","children","_BinaryenBlock","br","condition","_BinaryenBreak","drop","expression","_BinaryenDrop","loop","_BinaryenLoop","if","ifTrue","ifFalse","_BinaryenIf","nop","_BinaryenNop","return","_BinaryenReturn","select","_BinaryenSelect","switch","names","defaultName","numNames","strs","_BinaryenSwitch","returnType","_BinaryenCall","call_indirect","typeName","_BinaryenCallIndirect","unreachable","_BinaryenUnreachable","memory_copy","size","_BinaryenMemoryCopy","memory_fill","_BinaryenMemoryFill","simd_extract","vec","idx","_BinaryenSIMDExtract","simd_replace","_BinaryenSIMDReplace","simd_shuffle","vec1","vec2","mask","_BinaryenSIMDShuffle","simd_bitselect","cond","_BinaryenSIMDBitselect","simd_shift","shift","_BinaryenSIMDShift","addGlobal","mutable","_BinaryenAddGlobal","removeGlobal","_BinaryenRemoveGlobal","addFunction","varTypes","_BinaryenAddFunction","removeFunction","_BinaryenRemoveFunction","addTemporaryFunction","tempName","typeRef","removeTemporaryFunction","addFunctionExport","externalName","cStr1","cStr2","_BinaryenAddFunctionExport","addTableExport","_BinaryenAddTableExport","addMemoryExport","_BinaryenAddMemoryExport","addGlobalExport","_BinaryenAddGlobalExport","removeExport","_BinaryenRemoveExport","addFunctionImport","externalModuleName","externalBaseName","functionType","cStr3","_BinaryenAddFunctionImport","addTableImport","_BinaryenAddTableImport","addMemoryImport","shared","_BinaryenAddMemoryImport","addGlobalImport","globalType","_BinaryenAddGlobalImport","setMemory","initial","maximum","segments","segs","psvs","offs","sizs","i64_low","i64_high","cArr1","cArr2","cArr3","cArr4","_BinaryenSetMemory","setFunctionTable","funcs","_BinaryenSetFunctionTable","setStart","func","_BinaryenSetStart","getOptimizeLevel","_BinaryenGetOptimizeLevel","setOptimizeLevel","level","_BinaryenSetOptimizeLevel","getShrinkLevel","_BinaryenGetShrinkLevel","setShrinkLevel","_BinaryenSetShrinkLevel","setDebugInfo","on","_BinaryenSetDebugInfo","getFeatures","_BinaryenModuleGetFeatures","setFeatures","featureFlags","_BinaryenModuleSetFeatures","optimize","_BinaryenFunctionOptimize","_BinaryenModuleOptimize","runPasses","passes","allocString","_BinaryenFunctionRunPasses","_BinaryenModuleRunPasses","precomputeExpression","previousOptimizeLevel","previousShrinkLevel","previousDebugInfo","_BinaryenGetDebugInfo","_BinaryenExpressionGetType","_BinaryenFunctionGetBody","validate","_BinaryenModuleValidate","interpret","_BinaryenModuleInterpret","toBinary","sourceMapUrl","binaryPtr","sourceMapPtr","_BinaryenModuleAllocateAndWrite","readInt","binaryBytes","ret","BinaryModule","output","readBuffer","readString","toText","toAsmjs","str","dispose","_BinaryenModuleDispose","createRelooper","Relooper","cloneExpression","noSideEffects","maxDepth","MAX_VALUE","nested1","nested2","_BinaryenExpressionGetId","Const","_BinaryenConstGetValueI32","_BinaryenConstGetValueI64Low","_BinaryenConstGetValueI64High","_BinaryenConstGetValueF32","_BinaryenConstGetValueF64","LocalGet","_BinaryenLocalGetGetIndex","GlobalGet","globalName","_BinaryenGlobalGetGetName","Load","_BinaryenLoadGetPtr","_BinaryenLoadIsAtomic","_BinaryenLoadGetBytes","_BinaryenLoadGetOffset","_BinaryenLoadIsSigned","_BinaryenLoadGetAlign","Unary","_BinaryenUnaryGetValue","_BinaryenUnaryGetOp","Binary","_BinaryenBinaryGetLeft","_BinaryenBinaryGetRight","_BinaryenBinaryGetOp","addDebugInfoFile","_BinaryenModuleAddDebugInfoFileName","getDebugInfoFile","_BinaryenModuleGetDebugInfoFileName","fileIndex","lineNumber","columnNumber","_BinaryenFunctionSetDebugLocation","UNLIMITED_MEMORY","getExpressionId","getExpressionType","getConstValueI32","getConstValueI64Low","getConstValueI64High","getConstValueF32","getConstValueF64","getLocalGetIndex","getLocalSetIndex","_BinaryenLocalSetGetIndex","getLocalSetValue","_BinaryenLocalSetGetValue","isLocalTee","_BinaryenLocalSetIsTee","getGlobalGetName","getBinaryOp","getBinaryLeft","getBinaryRight","getUnaryOp","getUnaryValue","getLoadBytes","getLoadOffset","getLoadPtr","isLoadSigned","getStoreBytes","_BinaryenStoreGetBytes","getStoreOffset","_BinaryenStoreGetOffset","getStorePtr","_BinaryenStoreGetPtr","getStoreValue","_BinaryenStoreGetValue","getBlockName","_BinaryenBlockGetName","getBlockChildCount","_BinaryenBlockGetNumChildren","getBlockChild","_BinaryenBlockGetChild","getIfCondition","_BinaryenIfGetCondition","getIfTrue","_BinaryenIfGetIfTrue","getIfFalse","_BinaryenIfGetIfFalse","getLoopName","_BinaryenLoopGetName","getLoopBody","_BinaryenLoopGetBody","getBreakName","_BinaryenBreakGetName","getBreakCondition","_BinaryenBreakGetCondition","getSelectThen","_BinaryenSelectGetIfTrue","getSelectElse","_BinaryenSelectGetIfFalse","getSelectCondition","_BinaryenSelectGetCondition","getDropValue","_BinaryenDropGetValue","getReturnValue","_BinaryenReturnGetValue","getCallTarget","_BinaryenCallGetTarget","getCallOperandCount","_BinaryenCallGetNumOperands","getCallOperand","_BinaryenCallGetOperand","getHostOp","_BinaryenHostGetOp","getHostOperandCount","_BinaryenHostGetNumOperands","getHostOperand","_BinaryenHostGetOperand","getHostName","_BinaryenHostGetNameOperand","getFunctionBody","getFunctionName","_BinaryenFunctionGetName","getFunctionParamCount","_BinaryenFunctionGetNumParams","getFunctionParamType","_BinaryenFunctionGetParam","getFunctionResultType","_BinaryenFunctionGetResult","relooper","_RelooperCreate","addBlock","_RelooperAddBlock","addBranch","from","to","_RelooperAddBranch","addBlockWithSwitch","_RelooperAddBlockWithSwitch","addBranchForSwitch","indexes","_RelooperAddBranchForSwitch","renderAndDispose","entry","labelHelper","_RelooperRenderAndDispose","u8s","numValues","i32s","val","ptrs","u","stringLengthUTF8","cp","u1","u2","u3","u4","arr","fromCodePoints","needsExplicitUnreachable","Unreachable","Return","Break","Block","numChildren","traverse","data","If","Loop","Switch","_BinaryenSwitchGetCondition","Call","CallIndirect","_BinaryenCallIndirectGetNumOperands","_BinaryenCallIndirectGetOperand","LocalSet","GlobalSet","_BinaryenGlobalSetGetValue","Store","AtomicRMW","_BinaryenAtomicRMWGetPtr","_BinaryenAtomicRMWGetValue","AtomicCmpxchg","_BinaryenAtomicCmpxchgGetPtr","_BinaryenAtomicCmpxchgGetExpected","_BinaryenAtomicCmpxchgGetReplacement","AtomicWait","_BinaryenAtomicWaitGetPtr","_BinaryenAtomicWaitGetExpected","_BinaryenAtomicWaitGetTimeout","AtomicNotify","_BinaryenAtomicNotifyGetPtr","SIMDExtract","_BinaryenSIMDExtractGetVec","SIMDReplace","_BinaryenSIMDReplaceGetVec","_BinaryenSIMDReplaceGetValue","SIMDShuffle","_BinaryenSIMDShuffleGetLeft","_BinaryenSIMDShuffleGetRight","SIMDBitselect","_BinaryenSIMDBitselectGetLeft","_BinaryenSIMDBitselectGetRight","_BinaryenSIMDBitselectGetCond","SIMDShift","_BinaryenSIMDShiftGetVec","_BinaryenSIMDShiftGetShift","MemoryInit","_BinaryenMemoryInitGetDest","_BinaryenMemoryInitGetOffset","_BinaryenMemoryInitGetSize","DataDrop","MemoryCopy","_BinaryenMemoryCopyGetDest","_BinaryenMemoryCopyGetSource","_BinaryenMemoryCopyGetSize","MemoryFill","_BinaryenMemoryFillGetDest","_BinaryenMemoryFillGetValue","_BinaryenMemoryFillGetSize","Select","Drop","Host","Nop","tokenizer_1","Token","nodeIsConstantValue","NULL","TRUE","FALSE","nodeIsCallable","IDENTIFIER","ASSERTION","CALL","ELEMENTACCESS","PARENTHESIZED","PROPERTYACCESS","SUPER","nodeIsGenericCallable","createTypeName","TypeName","isNullable","TypeNode","createTypeParameter","defaultType","elem","TypeParameterNode","createParameter","ParameterNode","parameterKind","parameters","explicitThisType","sig","SignatureNode","createDecorator","args","stmt","DecoratorNode","createComment","node","CommentNode","commentKind","isQuoted","IdentifierExpression","symbol","createEmptyIdentifierExpression","createArrayLiteralExpression","ArrayLiteralExpression","elementExpressions","createAssertionExpression","assertionKind","toType","AssertionExpression","createBinaryExpression","operator","BinaryExpression","createCallExpression","typeArgs","CallExpression","createClassExpression","ClassExpression","createCommaExpression","expressions","CommaExpression","createConstructorExpression","ConstructorExpression","createElementAccessExpression","ElementAccessExpression","elementExpression","createFalseExpression","FalseExpression","createFloatLiteralExpression","FloatLiteralExpression","createFunctionExpression","FunctionExpression","createInstanceOfExpression","isType","InstanceOfExpression","createIntegerLiteralExpression","IntegerLiteralExpression","createNewExpression","NewExpression","createNullExpression","NullExpression","createObjectLiteralExpression","ObjectLiteralExpression","createParenthesizedExpression","ParenthesizedExpression","createPropertyAccessExpression","PropertyAccessExpression","createRegexpLiteralExpression","pattern","RegexpLiteralExpression","patternFlags","createTernaryExpression","ifThen","ifElse","TernaryExpression","createStringLiteralExpression","StringLiteralExpression","createSuperExpression","SuperExpression","createThisExpression","ThisExpression","createTrueExpression","TrueExpression","createUnaryPostfixExpression","operand","UnaryPostfixExpression","createUnaryPrefixExpression","UnaryPrefixExpression","createBlockStatement","BlockStatement","createBreakStatement","BreakStatement","createClassDeclaration","ClassDeclaration","createContinueStatement","ContinueStatement","createDoStatement","DoStatement","createEmptyStatement","EmptyStatement","createEnumDeclaration","EnumDeclaration","createEnumValueDeclaration","EnumValueDeclaration","createExportStatement","isDeclare","ExportStatement","normalizePath","startsWith","resolvePath","mangleInternalPath","createExportDefaultStatement","ExportDefaultStatement","createExportImportStatement","ExportImportStatement","createExportMember","ExportMember","createExpressionStatement","ExpressionStatement","createIfStatement","IfStatement","createImportStatement","decls","ImportStatement","createImportStatementWithWildcard","createImportDeclaration","ImportDeclaration","createInterfaceDeclaration","InterfaceDeclaration","createFieldDeclaration","FieldDeclaration","createForStatement","incrementor","ForStatement","FunctionDeclaration","createIndexSignatureDeclaration","keyType","valueType","IndexSignatureDeclaration","createMethodDeclaration","MethodDeclaration","NamespaceDeclaration","createReturnStatement","ReturnStatement","createSwitchStatement","cases","SwitchStatement","createSwitchCase","SwitchCase","createThrowStatement","ThrowStatement","createTryStatement","catchVariable","catchStatements","finallyStatements","TryStatement","TypeDeclaration","createVariableStatement","VariableStatement","VariableDeclaration","createVoidStatement","VoidStatement","createWhileStatement","WhileStatement","CommonTypeNode","TYPENAME","TYPE","TYPEPARAMETER","ParameterKind","PARAMETER","implicitFieldDeclaration","SIGNATURE","nameStr","propStr","CUSTOM","DECORATOR","CommentKind","COMMENT","Expression","LiteralExpression","ARRAY","AssertionKind","BINARY","numArguments","COMMA","FLOAT","INSTANCEOF","INTEGER","NEW","OBJECT","REGEXP","TERNARY","THIS","UnaryExpression","UNARYPOSTFIX","UNARYPREFIX","Statement","SOURCE","tokenizer","exportPaths","sourceKind","pos","lastIndexOf","simplePath","ENTRY","DeclarationStatement","VariableLikeDeclarationStatement","BLOCK","BREAK","CONTINUE","DO","ENUMVALUEDECLARATION","EXPORTIMPORT","EXPORTMEMBER","EXPRESSION","FOR","ArrowKind","clone","IF","IMPORTDECLARATION","RETURN","SWITCHCASE","SWITCH","THROW","TRY","VARIABLEDECLARATION","VOID","WHILE","findDecorator","isTypeOmitted","program_1","module_1","TypeKind","TypeFlags","v128_zero","cachedNullableType","byteSize","ceil","signatureReference","nonNullableType","isize64","isize32","usize64","usize32","auto","clz","computeSmallIntegerShift","targetType","computeSmallIntegerMask","classType","asNullable","signednessIsRelevant","currentClass","targetClass","currentFunction","targetFunction","isStrictlyAssignableTo","commonDenominator","signednessIsImportant","toNativeType","toNativeZero","toNativeOne","toNativeNegOne","typesToNativeTypes","types","numTypes","typesToString","cachedFunctionTarget","parameterNames","requiredParameters","hasRest","asFunctionTarget","getDefaultParameterName","thisThisType","targetThisType","thisParameterTypes","targetParameterTypes","numParameters","thisParameterType","targetParameterType","thisReturnType","targetReturnType","makeSignatureString","optionalStart","restIndex","cachedDefaultParameterNames","IdentifierHandling","tokenFromKeyword","AS","ASYNC","AWAIT","CASE","CATCH","DEBUGGER","DEFAULT","DELETE","ELSE","EXTENDS","FINALLY","FROM","IMPLEMENTS","IN","IS","KEYOF","LET","MODULE","OF","PACKAGE","PRIVATE","PROTECTED","PUBLIC","TYPEOF","VAR","WITH","YIELD","tokenIsAlsoIdentifier","token","operatorTokenToString","DOT_DOT_DOT","LESSTHAN","GREATERTHAN","LESSTHAN_EQUALS","GREATERTHAN_EQUALS","EQUALS_EQUALS","EXCLAMATION_EQUALS","EQUALS_EQUALS_EQUALS","EXCLAMATION_EQUALS_EQUALS","ASTERISK_ASTERISK","ASTERISK","SLASH","PERCENT","PLUS_PLUS","MINUS_MINUS","LESSTHAN_LESSTHAN","GREATERTHAN_GREATERTHAN","GREATERTHAN_GREATERTHAN_GREATERTHAN","AMPERSAND","BAR","CARET","EXCLAMATION","TILDE","AMPERSAND_AMPERSAND","BAR_BAR","EQUALS","PLUS_EQUALS","MINUS_EQUALS","ASTERISK_EQUALS","ASTERISK_ASTERISK_EQUALS","SLASH_EQUALS","PERCENT_EQUALS","LESSTHAN_LESSTHAN_EQUALS","GREATERTHAN_GREATERTHAN_EQUALS","GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS","AMPERSAND_EQUALS","BAR_EQUALS","CARET_EQUALS","a","b","Tokenizer","tokenPos","nextToken","nextTokenPos","nextTokenOnNewLine","onComment","identifierHandling","unsafeNext","maxTokenLength","STRINGLITERAL","chr","OPENPAREN","CLOSEPAREN","isDecimalDigit","FLOATLITERAL","DOT","commentStartPos","LINE","TRIPLE","closed","_0_expected","testInteger","INTEGERLITERAL","COLON","SEMICOLON","EQUALS_GREATERTHAN","QUESTION","OPENBRACKET","CLOSEBRACKET","OPENBRACE","CLOSEBRACE","AT","isIdentifierStart","isKeywordCharacter","posBefore","isIdentifierPart","keywordToken","ALWAYS","PREFER","isWhiteSpace","Invalid_character","ENDOFFILE","peek","checkOnNewLine","maxCompoundLength","tokenBefore","tokenPosBefore","skipIdentifier","skip","mark","state","reusableState","State","discard","reset","readIdentifier","quote","Unterminated_string_literal","readEscapeSequence","Unexpected_end_of_text","readExtendedUnicodeEscape","readUnicodeEscape","fromCharCode","readRegexpPattern","escaped","Unterminated_regular_expression_literal","readRegexpFlags","Invalid_regular_expression_flags","readInteger","readHexInteger","readBinaryInteger","readOctalInteger","isOctalDigit","Octal_literals_are_not_allowed_in_strict_mode","readDecimalInteger","i64_4","sepEnd","i64_add","i64_shl","Numeric_separators_are_not_allowed_here","Multiple_consecutive_numeric_separators_are_not_permitted","Hexadecimal_digit_expected","i64_10","i64_mul","Digit_expected","i64_3","Octal_digit_expected","i64_1","Binary_digit_expected","readFloat","readDecimalFloat","parseFloat","readHexFloat","remain","value32","invalid","An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive","Unterminated_Unicode_escape_sequence","finish","g","e","window","ReportMode","builtins_1","currentThisExpression","currentElementExpression","resolveType","context","reportMode","REPORT","parameterNodes","parameterNode","REST","parameterTypeNode","Type_expected","returnTypeNode","typeNode","typeArgumentNodes","possiblyPlaceholder","Type_0_is_not_generic","Basic_type_0_cannot_be_nullable","resolveClassInclTypeArguments","makeMap","type_1","Expected_0_type_arguments_but_got_1","typeArgument","resolveTypeArguments","Cannot_find_name_0","prev","Property_0_does_not_exist_on_type_1","alternativeReportNode","minParameterCount","maxParameterCount","argumentCount","resolveIdentifier","ensureResolvedLazyGlobal","resolvePropertyAccessExpression","propertyAccess","contextualType","targetExpression","resolveExpression","propertyName","indexedGet","Index_signature_is_missing_in_type_0","arrayType","resolvedType","resolveElementAccessExpression","elementAccess","determineIntegerLiteralType","intValue","i64_is_i8","i64_is_u8","i64_is_i16","i64_is_u16","i64_is_i32","i64_is_u32","i64_is_bool","resolveAssertionExpression","resolveUnaryPrefixExpression","resolveUnaryPostfixExpression","resolveBinaryExpression","resolveThisExpression","resolveSuperExpression","actualFunction","resolveLiteralExpression","resolveCallExpression","NONNULL","i64_sub","i64_zero","thisLocal","lookupLocal","_this_cannot_be_referenced_in_current_location","superLocal","_super_can_only_be_referenced_in_a_derived_class","literalType","BuiltinSymbols","resolveFunctionInclTypeArguments","Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures","actualParent","resolvedInstance","classTypeArguments","classTypeParameters","numClassTypeArguments","classTypeParameterName","numFunctionTypeArguments","signatureNode","signatureParameters","numSignatureParameters","parameterDeclaration","reportNode","resolvedTypeArguments","numTypeParameters","baseClass","nameInclTypeParamters","baseMembers","baseMembers_1","baseMembers_1_1","baseMemberName","baseMember","instanceMemberPrototypes","fieldTypeNode","fieldType","baseField","atEnd","fieldInstance","boundPrototype","propertyInstance","ctorPrototype","ctorInstance","overloadPrototype","operatorInstance","LocalFlags","FlowFlags","ANY_CATEGORICAL","ANY_CONDITIONAL","FieldFlags","scopedLocals","fieldFlags","parentFunction","continueLabel","localFlags","inlineFunction","inlineReturnLabel","createInline","fork","branch","slice","getTempLocal","temps","k_1","unsetLocalFlag","pop","getAutoreleaseLocal","SCOPED","setLocalFlag","RETAINED","freeTempLocal","getAndFreeTempLocal","getScopedLocal","addScopedLocal","scopedLocal","addScopedAlias","existingLocal","scopedAlias","freeScopedLocals","scope","isLocalFlag","defaultIfInlined","isAnyLocalFlag","pushBreakLabel","stack","popBreakLabel","inherit","inheritConditional","CONDITIONALLY_RETAINED","READFROM","CONDITIONALLY_READFROM","WRITTENTO","CONDITIONALLY_WRITTENTO","inheritMutual","leftLocalFlags","numLeftLocalFlags","rightLocalFlags","numRightLocalFlags","combinedFlags","max","isNonnull","inheritNonnullIfTrue","EqzI32","EqzI64","inheritNonnullIfFalse","EqI32","EqI64","NeI32","NeI64","canOverflow","WRAPPED","canConversionOverflow","global_1","EqF32","EqF64","NeF32","NeF64","LtI32","LtU32","LtI64","LtU64","LtF32","LtF64","LeI32","LeU32","LeI64","LeU64","LeF32","LeF64","GtI32","GtU32","GtI64","GtU64","GtF32","GtF64","GeI32","GeU32","GeI64","GeU64","GeF32","GeF64","MulI32","AndI32","ShlI32","ShrI32","ShrU32","DivU32","RemI32","RemU32","ClzI32","CtzI32","PopcntI32","MIN_VALUE","fromType","last","instanceName","levels","findUsedLocalsVisit","used","findUsedLocals","Options","importMemory","sharedMemory","importTable","explicitStart","features","feature","Constraints","RuntimeFeatures","mangleImportName_moduleName","mangleImportName_elementName","Compiler","currentInlineFunctions","currentEnum","currentType","memorySegments","stringSegments","functionTable","argcVar","argcSet","runtimeFeatures","skippedAutoreleases","f32ModInstance","f64ModInstance","f32PowInstance","f64PowInstance","Atomics","MutableGloabls","SIMD128","BulkMemory","SignExt","compile","startFunctionInstance","startFunctionBody","currentFlow","currentBody","heap_base","rtti_base","files","compileFile","compileExports","startIsEmpty","started","unshift","funcRef","ensureFunctionType","compileVisitGlobals","compileVisitMembers","compileRTTI","i64_align","isSharedMemory","i64_shr_u","ensureModuleExports","members_1","members_1_1","ensureModuleExport","prefix","fullName","setter","Cannot_export_a_mutable_global","ensureTrampoline","ensureArgcSet","COMPILED","ensureModuleFieldGetter","ensureModuleFieldSetter","isUnmanaged","subPrefix","loadExpr","isManaged","makeRetain","nativeType","nativeSizeType","valueExpr","makeRetainRelease","compileElement","compileMembers","compileGlobal","compileEnum","compileFunctionUsingTypeArguments","compileClassUsingTypeArguments","element_1","exportsStar_1","exportsStar_1_1","compileFileByPath","normalizedPathWithoutExtension","pathWithIndex","previousBody","previousFlow","compileTopLevelStatement","finishAutoreleases","numLocals","initExpr","initAutoreleaseSkipped","initializerNode","compileExpression","Type_0_is_not_assignable_to_type_1","isDeclaredConstant","isDeclaredInline","MODULE_IMPORT","mangleImportName","initializeInStart","Mutable_value_cannot_be_inlined","decoratorNodes","previousValue","previousValueIsMut","isInline","initInStart","valueNode","In_const_enum_declarations_member_initializer_must_be_constant_expression","Enum_member_must_have_initializer","AddI32","makeGlobalAssignment","compileFunction","resultType","compileFunctionBody","stmts","bodyNode","compileStatements","MAIN","indexBefore","performAutoreleases","nonNull","temp","makeAllocation","makeFieldInitialization","Constructors_for_derived_classes_must_contain_a_super_call","A_function_whose_declared_type_is_not_void_must_return_a_value","previousType","An_implementation_cannot_be_declared_in_ambient_contexts","flatten","Function_implementation_is_missing_or_not_immediately_following_the_declaration","compileClass","staticMembers","compileInterfaceDeclaration","addMemorySegment","alignment","ensureStaticString","stringValue","stringSegment","rtHeaderSize","runtimeHeaderSize","ensureStaticArrayBuffer","elementType","byteLength","bufferInstance","buf","writeI64","ensureStaticArrayHeader","bufferSegment","arrayInstance","arrayInstanceSize","bufferLength","arrayLength","bufferAddress32","ensureFunctionTableEntry","TRAMPOLINE","memberStatements","compileStatement","isLastInBody","compileBlockStatement","compileBreakStatement","compileContinueStatement","compileDoStatement","compileEmptyStatement","compileExpressionStatement","compileForStatement","compileIfStatement","compileReturnStatement","compileSwitchStatement","compileThrowStatement","compileTryStatement","compileVariableStatement","compileVoidStatement","compileWhileStatement","addDebugLocation","isBody","numStatements","outerFlow","innerFlow","A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement","A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement","condExpr","makeIsTrueish","alwaysFalse","terminates","continues","breaks","fallsThrough","alwaysTrue","stmts_1","incrExpr","loopLabel","bodyStatement","needsLabel","ifTrueStmts","ifTrueFlow","ifFalseFlow","ifFalseStmts","valueExpression","constraints","ANY_RETAINED","numCases","tempLocal","tempLocalIndex","breakIndex","defaultIndex","currentBlock","commonCategorical","commonConditional","isLast","nextLabel","count","newArgs","compileAbort","numDeclarations","initializers","isConst","_const_declarations_must_be_initialized","CONSTANT","compileInlineConstant","compileAssertionExpression","compileBinaryExpression","compileCallExpression","compileCommaExpression","compileElementAccessExpression","compileFunctionExpression","compileIdentifierExpression","compileInstanceOfExpression","compileLiteralExpression","compileNewExpression","compilePropertyAccessExpression","compileTernaryExpression","compileUnaryPostfixExpression","compileUnaryPrefixExpression","wrap","convertExpression","ensureSmallIntegerWrap","explicit","Object_is_possibly_null","Conversion_from_type_0_to_1_requires_an_explicit_cast","PromoteF32","DemoteF64","TruncF32ToI64","TruncF32ToI32","TruncF32ToU64","TruncF32ToU32","TruncF64ToI64","TruncF64ToI32","TruncF64ToU64","TruncF64ToU32","ConvertI64ToF32","ConvertU64ToF32","ConvertI32ToF32","ConvertU32ToF32","ConvertI64ToF64","ConvertU64ToF64","ConvertI32ToF64","ConvertU32ToF64","WrapI64","ExtendI32","ExtendU32","inheritedConstraints","PREFIX","exceptVoid","Expression_is_never_null","tempIndex","leftExpr","leftType","rightExpr","rightType","commonType","compound","compileBinaryOverload","Operator_0_cannot_be_applied_to_types_1_and_2","AllTrueVecI8x16","EqVecI8x16","AnyTrueVecI8x16","NeVecI8x16","compileAssignment","AddI64","AddF32","AddF64","SubI32","SubI64","SubF32","SubF64","MulI64","MulF32","MulF64","namespace","makeCallDirect","DivI32","DivI64","DivU64","DivF32","DivF64","RemI64","RemU64","intType","ShlI64","The_0_operator_cannot_be_applied_to_type_1","ShrI64","ShrU64","AndI64","OrI32","OrI64","XorI32","XorI64","rightFlow","performAutoreleasesWithValue","leftAutoreleaseSkipped","rightAutoreleaseSkipped","retainLeftInElse","moveAutorelease","rightStmts","makeRelease","retainLeftInThen","makeAssignment","compileUnaryOverload","thisExpression","Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property","isUnchecked","indexedSet","Index_signature_in_type_0_only_permits_reading","indexExpression","tee","makeLocalAssignment","makeFieldAssignment","makeAutorelease","nativeReturnType","thisExpr_1","thisExpr","elementExpr","tempLocalTarget","tempLocalElement","makeSkippedRelease","nativeFieldType","nativeThisType","tempThis","tempValue","flow_2","Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors","baseClassInstance","theCall","compileCallDirect","ensureConstructor","_super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class","indexArg","compileCallExpressionBuiltin","inferredTypes","argumentNodes","argumentExprs","templateName","argumentExpression","inferredType","concreteType","compileCallIndirect","compileCall","checkCallSignature","hasThis","minimum","Expected_at_least_0_arguments_but_got_1","argumentExpressions","thisArg","parameterTypes_1","makeCallInline","Function_0_cannot_be_inlined_into_itself","numArgumentsInclThis","immediatelyDropped","usedLocals","paramExpr","paramType","argumentLocal","baseInstance","initType","originalSignature","originalName","originalParameterTypes","originalParameterDeclarations","minArguments","minOperands","maxArguments","maxOperands","numOptional","forwardedOperands","operandIndex","trampolineSignature","ofN","argc","Optional_parameter_must_have_an_initializer","ensureArgcVar","setargc","oldExpr","newExpr","temp1","temp2","undoAutorelease","fromInnerFlow","toOuterFlow","clearFlags","lengthBefore","skipAutorelease","TODO_Cannot_inline_inferred_calls_and_specific_internals_yet","numOperands","isCallImport","allOptionalsAreConstant","expr_1","makeCallIndirect","numExpressions","exprs","contextualSignature","numPresentParameters","thisTypeNode","maybeCompileEnclosingSource","flow_3","actualFunction_1","_super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class","scopedThis","superType","A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums","actualType","implicitlyNegate","compileArrayLiteral","floatValue","i64_to_f32","i64_to_f64","compileStringLiteral","compileObjectLiteral","tempDataStart","nativeElementType","bufferAddress","arraySegment","arrayAddress","alignLog2","nativeArrayType","dataStart","ctor","Constructor_of_class_0_must_not_require_any_arguments","Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration","Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration","hasErrors","Cannot_use_new_with_an_expression_whose_type_lacks_a_construct_signature","compileInstantiate","baseCtor","theEnum","Cannot_access_method_0_without_calling_it_as_it_requires_this_to_be_set","ifThenFlow","ifThenExpr","ifThenType","IfThenAutoreleaseSkipped","ifElseFlow","ifElseExpr","ifElseType","ifElseAutoreleaseSkipped","getValue","setValue","NegF32","NegF64","makeIsFalseish","ExtendI8ToI32","ExtendI16ToI32","thisLocalIndex","makeInstanceOfClass","idTemp","idExpr","conditions","single","Auto","compiler_1","compiler","isAsm","directize","isInteger","evaluateConstantType","isFloat","isBoolean","isSigned","isReference","isString","isArray","isArrayLike","isFunction","isDefined","checkTypeAbsent","checkArgsRequired","SWALLOW","isConstant","sizeof","checkTypeRequired","alignof","ctz","checkArgsOptional","typeArgumentsRange","Type_0_has_no_property_1","popcnt","checkTypeOptional","ClzI64","CtzI64","PopcntI64","rotl","RotlI32","RotlI64","rotr","RotrI32","RotrI64","abs","tempLocal1","tempLocalIndex2","tempLocalIndex1","wasm64","AbsF32","AbsF64","MaxF32","MaxF64","tempLocal0","min","MinF32","MinF64","floor","CeilF32","FloorF32","CeilF64","FloorF64","copysign","CopysignF32","CopysignF64","nearest","NearestF32","NearestF64","reinterpret","ReinterpretF32","ReinterpretF64","ReinterpretI32","ReinterpretI64","sqrt","SqrtF32","SqrtF64","trunc","TruncF32","TruncF64","outType","immOffset","evaluateImmediateOffset","immAlign","naturalAlign","_0_must_be_a_value_between_1_and_2_inclusive","_0_must_be_a_power_of_two","inType","atomic_add","atomic_sub","atomic_and","atomic_or","atomic_xor","atomic_xchg","Add","Sub","And","Or","Xor","Xchg","memory_size","MemorySize","memory_grow","MemoryGrow","alreadyUnchecked","call_direct","arg0Type","operandExprs","nativeParamTypes","operandType","instantiate","User_defined_0","Expression_must_be_a_compile_time_constant","off","v128_splat","SplatVecI8x16","SplatVecI16x8","SplatVecI32x4","SplatVecI64x2","SplatVecF32x4","SplatVecF64x2","v128_extract_lane","ExtractLaneSVecI8x16","ExtractLaneUVecI8x16","ExtractLaneSVecI16x8","ExtractLaneUVecI16x8","ExtractLaneVecI32x4","ExtractLaneVecI64x2","ExtractLaneVecF32x4","ExtractLaneVecF64x2","maxIdx","v128_replace_lane","ReplaceLaneVecI8x16","ReplaceLaneVecI16x8","ReplaceLaneVecI32x4","ReplaceLaneVecI64x2","ReplaceLaneVecF32x4","ReplaceLaneVecF64x2","v128_shuffle","laneWidth","laneCount","argN","off8","idx8","v128_add","v128_sub","v128_mul","v128_div","v128_add_saturate","v128_sub_saturate","v128_min","v128_max","v128_eq","v128_ne","v128_lt","v128_le","v128_gt","v128_ge","AddVecI8x16","AddVecI16x8","AddVecI32x4","AddVecI64x2","AddVecF32x4","AddVecF64x2","SubVecI8x16","SubVecI16x8","SubVecI32x4","SubVecI64x2","SubVecF32x4","SubVecF64x2","MulVecI8x16","MulVecI16x8","MulVecI32x4","MulVecF32x4","MulVecF64x2","DivVecF32x4","DivVecF64x2","AddSatSVecI8x16","AddSatUVecI8x16","AddSatSVecI16x8","AddSatUVecI16x8","SubSatSVecI8x16","SubSatUVecI8x16","SubSatSVecI16x8","SubSatUVecI16x8","MinVecF32x4","MinVecF64x2","MaxVecF32x4","MaxVecF64x2","EqVecI16x8","EqVecI32x4","EqVecF32x4","EqVecF64x2","NeVecI16x8","NeVecI32x4","NeVecF32x4","NeVecF64x2","LtSVecI8x16","LtUVecI8x16","LtSVecI16x8","LtUVecI16x8","LtSVecI32x4","LtUVecI32x4","LtVecF32x4","LtVecF64x2","LeSVecI8x16","LeUVecI8x16","LeSVecI16x8","LeUVecI16x8","LeSVecI32x4","LeUVecI32x4","LeVecF32x4","LeVecF64x2","GtSVecI8x16","GtUVecI8x16","GtSVecI16x8","GtUVecI16x8","GtSVecI32x4","GtUVecI32x4","GtVecF32x4","GtVecF64x2","GeSVecI8x16","GeUVecI8x16","GeSVecI16x8","GeUVecI16x8","GeSVecI32x4","GeUVecI32x4","GeVecF32x4","GeVecF64x2","v128_neg","v128_abs","v128_sqrt","v128_convert","v128_trunc","NegVecI8x16","NegVecI16x8","NegVecI32x4","NegVecI64x2","NegVecF32x4","NegVecF64x2","AbsVecF32x4","AbsVecF64x2","SqrtVecF32x4","SqrtVecF64x2","ConvertSVecI32x4ToVecF32x4","ConvertUVecI32x4ToVecF32x4","ConvertSVecI64x2ToVecF64x2","ConvertUVecI64x2ToVecF64x2","TruncSatSVecF32x4ToVecI32x4","TruncSatUVecF32x4ToVecI32x4","TruncSatSVecF64x2ToVecI64x2","TruncSatUVecF64x2ToVecI64x2","v128_shl","v128_shr","ShlVecI8x16","ShlVecI16x8","ShlVecI32x4","ShlVecI64x2","ShrSVecI8x16","ShrUVecI8x16","ShrSVecI16x8","ShrUVecI16x8","ShrSVecI32x4","ShrUVecI32x4","ShrSVecI64x2","ShrUVecI64x2","v128_and","v128_or","v128_xor","AndVec128","OrVec128","XorVec128","v128_not","NotVec128","v128_bitselect","v128_any_true","v128_all_true","AnyTrueVecI16x8","AnyTrueVecI32x4","AnyTrueVecI64x2","AllTrueVecI16x8","AllTrueVecI32x4","AllTrueVecI64x2","idof","visit_globals","visit_members","i32_clz","deferASM","i64_clz","i32_ctz","i64_ctz","i32_popcnt","i64_popcnt","i32_rotl","i64_rotl","i32_rotr","i64_rotr","f32_abs","f64_abs","f32_max","f64_max","f32_min","f64_min","f32_ceil","f64_ceil","f32_floor","f64_floor","f32_copysign","f64_copysign","f32_nearest","f64_nearest","i32_reinterpret_f32","i64_reinterpret_f64","f32_reinterpret_i32","f64_reinterpret_i64","f32_sqrt","f64_sqrt","f32_trunc","f64_trunc","i32_load8_s","i32_load8_u","i32_load16_s","i32_load16_u","i32_load","i64_load8_s","i64_load8_u","i64_load16_s","i64_load16_u","i64_load32_s","i64_load32_u","i64_load","f32_load","f64_load","i32_store8","i32_store16","i32_store","i64_store8","i64_store16","i64_store32","i64_store","f32_store","f64_store","i32_atomic_load8_u","i32_atomic_load16_u","i32_atomic_load","i64_atomic_load8_u","i64_atomic_load16_u","i64_atomic_load32_u","i64_atomic_load","i32_atomic_store8","i32_atomic_store16","i32_atomic_store","i64_atomic_store8","i64_atomic_store16","i64_atomic_store32","i64_atomic_store","i32_atomic_rmw8_add_u","i32_atomic_rmw16_add_u","i32_atomic_rmw_add","i64_atomic_rmw8_add_u","i64_atomic_rmw16_add_u","i64_atomic_rmw32_add_u","i64_atomic_rmw_add","i32_atomic_rmw8_sub_u","i32_atomic_rmw16_sub_u","i32_atomic_rmw_sub","i64_atomic_rmw8_sub_u","i64_atomic_rmw16_sub_u","i64_atomic_rmw32_sub_u","i64_atomic_rmw_sub","i32_atomic_rmw8_and_u","i32_atomic_rmw16_and_u","i32_atomic_rmw_and","i64_atomic_rmw8_and_u","i64_atomic_rmw16_and_u","i64_atomic_rmw32_and_u","i64_atomic_rmw_and","i32_atomic_rmw8_or_u","i32_atomic_rmw16_or_u","i32_atomic_rmw_or","i64_atomic_rmw8_or_u","i64_atomic_rmw16_or_u","i64_atomic_rmw32_or_u","i64_atomic_rmw_or","i32_atomic_rmw8_u_xor","i32_atomic_rmw16_u_xor","i32_atomic_rmw_xor","i64_atomic_rmw8_xor_u","i64_atomic_rmw16_xor_u","i64_atomic_rmw32_xor_u","i64_atomic_rmw_xor","i32_atomic_rmw8_xchg_u","i32_atomic_rmw16_xchg_u","i32_atomic_rmw_xchg","i64_atomic_rmw8_xchg_u","i64_atomic_rmw16_xchg_u","i64_atomic_rmw32_xchg_u","i64_atomic_rmw_xchg","i32_atomic_rmw8_cmpxchg_u","i32_atomic_rmw16_cmpxchg_u","i32_atomic_rmw_cmpxchg","i64_atomic_rmw8_cmpxchg_u","i64_atomic_rmw16_cmpxchg_u","i64_atomic_rmw32_cmpxchg_u","i64_atomic_rmw_cmpxchg","i32_wait","i64_wait","v128_load","v128_store","i8x16_splat","i8x16_extract_lane_s","i8x16_extract_lane_u","i8x16_replace_lane","i8x16_add","i8x16_sub","i8x16_mul","i8x16_neg","i8x16_add_saturate_s","i8x16_add_saturate_u","i8x16_sub_saturate_s","i8x16_sub_saturate_u","i8x16_shl","i8x16_shr_s","i8x16_shr_u","i8x16_any_true","i8x16_all_true","i8x16_eq","i8x16_ne","i8x16_lt_s","i8x16_lt_u","i8x16_le_s","i8x16_le_u","i8x16_gt_s","i8x16_gt_u","i8x16_ge_s","i8x16_ge_u","i16x8_splat","i16x8_extract_lane_s","i16x8_extract_lane_u","i16x8_replace_lane","i16x8_add","i16x8_sub","i16x8_mul","i16x8_neg","i16x8_add_saturate_s","i16x8_add_saturate_u","i16x8_sub_saturate_s","i16x8_sub_saturate_u","i16x8_shl","i16x8_shr_s","i16x8_shr_u","i16x8_any_true","i16x8_all_true","i16x8_eq","i16x8_ne","i16x8_lt_s","i16x8_lt_u","i16x8_le_s","i16x8_le_u","i16x8_gt_s","i16x8_gt_u","i16x8_ge_s","i16x8_ge_u","i32x4_splat","i32x4_extract_lane","i32x4_replace_lane","i32x4_add","i32x4_sub","i32x4_mul","i32x4_neg","i32x4_shl","i32x4_shr_s","i32x4_shr_u","i32x4_any_true","i32x4_all_true","i32x4_eq","i32x4_ne","i32x4_lt_s","i32x4_lt_u","i32x4_le_s","i32x4_le_u","i32x4_gt_s","i32x4_gt_u","i32x4_ge_s","i32x4_ge_u","i32x4_trunc_s_f32x4_sat","i32x4_trunc_u_f32x4_sat","i64x2_splat","i64x2_extract_lane","i64x2_replace_lane","i64x2_add","i64x2_sub","i64x2_neg","i64x2_shl","i64x2_shr_s","i64x2_shr_u","i64x2_any_true","i64x2_all_true","i64x2_trunc_s_f64x2_sat","i64x2_trunc_u_f64x2_sat","f32x4_splat","f32x4_extract_lane","f32x4_replace_lane","f32x4_add","f32x4_sub","f32x4_mul","f32x4_div","f32x4_neg","f32x4_min","f32x4_max","f32x4_abs","f32x4_sqrt","f32x4_eq","f32x4_ne","f32x4_lt","f32x4_le","f32x4_gt","f32x4_ge","f32x4_convert_s_i32x4","f32x4_convert_u_i32x4","f64x2_splat","f64x2_extract_lane","f64x2_replace_lane","f64x2_add","f64x2_sub","f64x2_mul","f64x2_div","f64x2_neg","f64x2_min","f64x2_max","f64x2_abs","f64x2_sqrt","f64x2_eq","f64x2_ne","f64x2_lt","f64x2_le","f64x2_gt","f64x2_ge","f64x2_convert_s_i64x2","f64x2_convert_u_i64x2","v8x16_shuffle","tryDeferASM","messageArg","filenameArg","typeToRuntimeFlags","argumentsRange","setCurrentTypeOnError","expectedMinimum","expectedMaximum","memory_allocate","memory_free","memory_reset","runtime_instanceof","runtime_flags","runtime_allocate","runtime_reallocate","runtime_register","runtime_discard","runtime_makeArray","capabilities","nativeSizeSize","ftype","blocks","outer","lastId","managedClasses_1","managedClasses_1_1","visitImpl","isDeclaredInLibrary","visitFunc","visitSig","callExpr","fieldOffset","managedClasses_2","managedClasses_2_1","abvPrototype","managedClasses_3","managedClasses_3_1","isAcyclic","Decompiler","functionId","decompile","decompiler","decompileFunction","nativeTypeToType","decompileExpression","nested","i64_to_string","ExportsWalker","includePrivate","seen","walk","visitFile","visitElement","visitAlias","visitGlobal","visitEnum","visitFunctionInstances","visitClassInstances","visitField","visitPropertyInstances","prop","visitFunction","hasCompiledMember","e_15","e_16","visitNamespace","visitClass","IDLBuilder","indentLevel","build","indent","typeToString","members_2","members_2_1","name_1","visitInterface","TSDBuilder","unknown","numMembers","members_3","members_3_1","name_2","isInterface","Parser","backlog","seenlog","donelog","tryParseSignatureIsSignature","parseParametersThis","parseFile","indexOf","tn","parseTopLevelStatement","startPos","parseDecorator","skipStatement","exportStart","exportEnd","defaultStart","defaultEnd","declareStart","declareEnd","contextIsAmbient","A_declare_modifier_cannot_be_used_in_an_already_ambient_context","first","parseEnum","parseVariable","parseFunction","parseStatement","parseClassOrInterface","parseNamespace","parseExportImport","parseImport","parseTypeDeclaration","An_export_assignment_cannot_have_modifiers","parseExportDefaultAlias","parseExport","_0_modifier_cannot_be_used_here","Decorators_are_not_valid_here","nextFile","clear","parseType","acceptParenthesized","suppressErrors","isNullableSignature","tryParseSignature","Unexpected_token","innerType","Identifier_expected","nullable","parameter","bracketStart","bracketRange","isSignature","A_rest_parameter_cannot_be_optional","OPTIONAL","param","parseArguments","parseVariableDeclaration","parentFlags","parentDecorators","DEFINITE_ASSIGNMENT","Initializers_are_not_allowed_in_ambient_contexts","parseExpression","A_definite_assignment_assertion_is_not_permitted_in_this_context","parseEnumValue","parseReturn","parseTypeParameters","seenOptional","typeParameter","parseTypeParameter","Required_type_parameters_may_not_follow_optional_type_parameters","Type_parameter_list_cannot_be_empty","parseParameters","isConstructor","seenRest","reportedRest","parseParameter","A_rest_parameter_must_be_last_in_a_parameter_list","A_required_parameter_cannot_follow_an_optional_parameter","isRest","isOptional","startRange","accessFlags","A_parameter_property_cannot_be_declared_using_a_rest_parameter","A_rest_parameter_cannot_have_an_initializer","Parameter_cannot_have_question_mark_and_initializer","signatureStart","isSetter","A_set_accessor_must_have_exactly_one_parameter","A_set_accessor_parameter_cannot_have_an_initializer","A_get_accessor_cannot_have_parameters","parseBlockStatement","parseFunctionExpression","parseFunctionExpressionCommon","bodyExpression","Interface_declaration_cannot_have_implements_clause","parseClassMember","parseClassExpression","VIRTUAL","accessStart","accessEnd","staticStart","staticEnd","abstractStart","abstractEnd","GENERIC_CONTEXT","readonlyStart","readonlyEnd","setEnd","retIndex","parseIndexSignatureDeclaration","typeParametersStart","Type_parameters_cannot_appear_on_a_constructor_declaration","An_accessor_cannot_have_type_parameters","Type_annotation_cannot_appear_on_a_constructor_declaration","A_set_accessor_cannot_have_a_return_type_annotation","Method_0_cannot_have_an_implementation_because_it_is_marked_abstract","retMethod","Constructor_implementation_is_missing","Optional_properties_are_not_supported","retField","parseExportMember","asIdentifier","skipFrom","parseImportDeclaration","topLevel","parseBreak","parseContinue","parseDoStatement","parseForStatement","parseIfStatement","A_return_statement_can_only_be_used_within_a_function_body","parseSwitchStatement","parseThrowStatement","parseTryStatement","parseVoidStatement","parseWhileStatement","parseExpressionStatement","elseStatement","case_","parseSwitchCase","_case_or_default_expected","parseExpressionStart","precedence","determinePrecedenceStart","The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access","again","startPos_1","_super_must_be_followed_by_an_argument_list_or_member_access","regexpPattern","Expression_expected","tryParseTypeArgumentsBeforeArguments","nextPrecedence","maybeParseCallExpression","determinePrecedence","commaExprs","isRightAssociative","joinPropertyCall","callee","inner","skipBlock","depth","Precedence","binaryen","wrapModule","emitStackIR","emitAsmjs","Binaryen","__memory_allocate","_malloc","__memory_free","_free","__memory_copy","_memmove","__store","HEAPU8","__load","globalScope","UnreachableError","captureStackTrace","AssertionError","defineProperties","writable","fround","EPSILON","MIN_NORMAL_VALUE","MIN_SAFE_INTEGER","MAX_SAFE_INTEGER","clz32","round","y","sign","isTrueish","fromCodePoint","replaceAll","search","replacment","res","split","Number","capacity","sincos_sin","sincos_cos","signbit","Boolean","sincos","sin","cos","HEAP","HEAP_OFFSET","oldHeap","fill","copy","copyWithin","f32_as_i32","i32_as_f32","f64_as_i64","i64_as_f64","Long","ZERO","i64_one","ONE","lo","hi","fromBits","low","high","sub","mul","i64_div","div","i64_div_u","toUnsigned","toSigned","i64_rem","i64_rem_u","i64_and","and","i64_or","or","i64_xor","xor","shl","i64_shr","shr","shru","i64_not","not","i64_eq","eq","i64_ne","ne","fromInt","minSafeF32","fromNumber","maxSafeF32","i64_is_f32","gte","lte","minSafeF64","maxSafeF64","i64_is_f64","toNumber","unsigned","wasm","WebAssembly","Instance","isLong","obj","__isLong__","INT_CACHE","UINT_CACHE","cachedObj","cache","isNaN","UZERO","TWO_PWR_64_DBL","MAX_UNSIGNED_VALUE","TWO_PWR_63_DBL","neg","TWO_PWR_32_DBL","lowBits","highBits","pow_dbl","fromString","radix","RangeError","radixToPower","power","fromValue","TWO_PWR_16_DBL","TWO_PWR_24","UONE","NEG_ONE","LongPrototype","toInt","isZero","isNegative","radixLong","rem1","rem","remDiv","digits","getHighBits","getHighBitsUnsigned","getLowBits","getLowBitsUnsigned","getNumBitsAbs","bit","eqz","isPositive","isOdd","isEven","equals","notEquals","neq","lessThan","comp","lt","lessThanOrEqual","le","greaterThan","gt","greaterThanOrEqual","ge","compare","thisNeg","otherNeg","negate","addend","a48","a32","a16","a00","b48","b32","b16","c48","c32","c16","c00","subtract","subtrahend","multiply","multiplier","get_high","b00","divide","divisor","approx","div_u","div_s","log2","log","LN2","delta","approxRes","approxRem","modulo","rem_u","rem_s","shiftLeft","numBits","shiftRight","shiftRightUnsigned","shr_u","toBytes","toBytesLE","toBytesBE","fromBytes","fromBytesLE","fromBytesBE","__decorate","unmanaged","decompiler_1","definitions_1","formatDiagnostic","parser_1","parser","nextDiagnostic","isInfo","isWarning","isError","createOptions","setTarget","setNoAssert","setImportMemory","setSharedMemory","setImportTable","setSourceMap","setMemoryBase","setGlobalAlias","setExplicitStart","FEATURE_SIGN_EXTENSION","FEATURE_MUTABLE_GLOBAL","FEATURE_BULK_MEMORY","FEATURE_SIMD","FEATURE_THREADS","enableFeature","setOptimizeLevelHints","optimizeLevel","shrinkLevel","finishParsing","compileProgram","decompileModule","buildIDL","buildTSD","buildRTTI","cls","bitsetIs","map","bitsetSet","isSet","CharCode","lookupInUnicodeMap","unicodeIdentifierStart","unicodeIdentifierPart","mid","midVal","makeArray","cloned","makeSet","original_1","original_1_1","v","overrides","original_2","original_2_1","overrides_1","overrides_1_1","overrides_2","overrides_2_1","separator","ipos","dirname","origin","indentX1","indentX2","indentX4","readI32","readI64","readI8","readI16","readF32","readF64","valueI64"],"mappings":"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M,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAC1C,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,KAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,OAEtCC,EAA+B,CACnC,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACtE,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACtE,IAAK,IAAK,IAAK,IAAK,IACpB,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KACxB,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,KAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO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","file":"assemblyscript.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"binaryen\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"binaryen\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"assemblyscript\"] = factory(require(\"binaryen\"));\n\telse\n\t\troot[\"assemblyscript\"] = factory(root[\"binaryen\"]);\n})(typeof self !== 'undefined' ? self : this, function(__WEBPACK_EXTERNAL_MODULE__20__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 17);\n","/**\r\n * Common constants.\r\n * @module common\r\n *//***/\r\n\r\n/** Indicates traits of a {@link Node} or {@link Element}. */\r\nexport enum CommonFlags {\r\n /** No flags set. */\r\n NONE = 0,\r\n\r\n // Basic modifiers\r\n\r\n /** Has an `import` modifier. */\r\n IMPORT = 1 << 0,\r\n /** Has an `export` modifier. */\r\n EXPORT = 1 << 1,\r\n /** Has a `declare` modifier. */\r\n DECLARE = 1 << 2,\r\n /** Has a `const` modifier. */\r\n CONST = 1 << 3,\r\n /** Has a `let` modifier. */\r\n LET = 1 << 4,\r\n /** Has a `static` modifier. */\r\n STATIC = 1 << 5,\r\n /** Has a `readonly` modifier. */\r\n READONLY = 1 << 6,\r\n /** Has an `abstract` modifier. */\r\n ABSTRACT = 1 << 7,\r\n /** Has a `public` modifier. */\r\n PUBLIC = 1 << 8,\r\n /** Has a `private` modifier. */\r\n PRIVATE = 1 << 9,\r\n /** Has a `protected` modifier. */\r\n PROTECTED = 1 << 10,\r\n /** Has a `get` modifier. */\r\n GET = 1 << 11,\r\n /** Has a `set` modifier. */\r\n SET = 1 << 12,\r\n /** Has a definite assignment assertion `!` as in `x!: i32;`. */\r\n DEFINITE_ASSIGNMENT = 1 << 13,\r\n\r\n // Extended modifiers usually derived from basic modifiers\r\n\r\n /** Is ambient, that is either declared or nested in a declared element. */\r\n AMBIENT = 1 << 14,\r\n /** Is generic. */\r\n GENERIC = 1 << 15,\r\n /** Is part of a generic context. */\r\n GENERIC_CONTEXT = 1 << 16,\r\n /** Is an instance member. */\r\n INSTANCE = 1 << 17,\r\n /** Is a constructor. */\r\n CONSTRUCTOR = 1 << 18,\r\n /** Is a module export. */\r\n MODULE_EXPORT = 1 << 19,\r\n /** Is a module import. */\r\n MODULE_IMPORT = 1 << 20,\r\n\r\n // Compilation states\r\n\r\n /** Is resolved. */\r\n RESOLVED = 1 << 21,\r\n /** Is compiled. */\r\n COMPILED = 1 << 22,\r\n /** Has a constant value and is therefore inlined. */\r\n INLINED = 1 << 23,\r\n /** Is scoped. */\r\n SCOPED = 1 << 24,\r\n /** Is a trampoline. */\r\n TRAMPOLINE = 1 << 25,\r\n /** Is a virtual method. */\r\n VIRTUAL = 1 << 26,\r\n /** Is the main function. */\r\n MAIN = 1 << 27,\r\n\r\n // Other\r\n\r\n /** Is quoted. */\r\n QUOTED = 1 << 28\r\n}\r\n\r\n/** Path delimiter inserted between file system levels. */\r\nexport const PATH_DELIMITER = \"/\";\r\n/** Substitution used to indicate the parent directory. */\r\nexport const PARENT_SUBST = \"..\";\r\n/** Function name prefix used for getters. */\r\nexport const GETTER_PREFIX = \"get:\";\r\n/** Function name prefix used for setters. */\r\nexport const SETTER_PREFIX = \"set:\";\r\n/** Delimiter used between class names and instance members. */\r\nexport const INSTANCE_DELIMITER = \"#\";\r\n/** Delimiter used between class and namespace names and static members. */\r\nexport const STATIC_DELIMITER = \".\";\r\n/** Delimiter used between a function and its inner elements. */\r\nexport const INNER_DELIMITER = \"~\";\r\n/** Substitution used to indicate a library directory. */\r\nexport const LIBRARY_SUBST = \"~lib\";\r\n/** Library directory prefix. */\r\nexport const LIBRARY_PREFIX = LIBRARY_SUBST + PATH_DELIMITER;\r\n/** Path index suffix. */\r\nexport const INDEX_SUFFIX = PATH_DELIMITER + \"index\";\r\n\r\n/** Common compiler symbols. */\r\nexport namespace CommonSymbols {\r\n // special\r\n export const EMPTY = \"\";\r\n // types\r\n export const i8 = \"i8\";\r\n export const i16 = \"i16\";\r\n export const i32 = \"i32\";\r\n export const i64 = \"i64\";\r\n export const isize = \"isize\";\r\n export const u8 = \"u8\";\r\n export const u16 = \"u16\";\r\n export const u32 = \"u32\";\r\n export const u64 = \"u64\";\r\n export const usize = \"usize\";\r\n export const bool = \"bool\";\r\n export const f32 = \"f32\";\r\n export const f64 = \"f64\";\r\n export const v128 = \"v128\";\r\n export const i8x16 = \"i8x16\";\r\n export const u8x16 = \"u8x16\";\r\n export const i16x8 = \"i16x8\";\r\n export const u16x8 = \"u16x8\";\r\n export const i32x4 = \"i32x4\";\r\n export const u32x4 = \"u32x4\";\r\n export const i64x2 = \"i64x2\";\r\n export const u64x2 = \"u64x2\";\r\n export const f32x4 = \"f32x4\";\r\n export const f64x2 = \"f64x2\";\r\n export const void_ = \"void\";\r\n export const number = \"number\";\r\n export const boolean = \"boolean\";\r\n export const string = \"string\";\r\n export const native = \"native\";\r\n // aliases\r\n export const null_ = \"null\";\r\n export const true_ = \"true\";\r\n export const false_ = \"false\";\r\n // objects\r\n export const this_ = \"this\";\r\n export const super_ = \"super\";\r\n export const constructor = \"constructor\";\r\n // constants\r\n export const ASC_TARGET = \"ASC_TARGET\";\r\n export const ASC_NO_TREESHAKING = \"ASC_NO_TREESHAKING\";\r\n export const ASC_NO_ASSERT = \"ASC_NO_ASSERT\";\r\n export const ASC_MEMORY_BASE = \"ASC_MEMORY_BASE\";\r\n export const ASC_OPTIMIZE_LEVEL = \"ASC_OPTIMIZE_LEVEL\";\r\n export const ASC_SHRINK_LEVEL = \"ASC_SHRINK_LEVEL\";\r\n export const ASC_FEATURE_MUTABLE_GLOBAL = \"ASC_FEATURE_MUTABLE_GLOBAL\";\r\n export const ASC_FEATURE_SIGN_EXTENSION = \"ASC_FEATURE_SIGN_EXTENSION\";\r\n export const ASC_FEATURE_BULK_MEMORY = \"ASC_FEATURE_BULK_MEMORY\";\r\n export const ASC_FEATURE_SIMD = \"ASC_FEATURE_SIMD\";\r\n export const ASC_FEATURE_THREADS = \"ASC_FEATURE_THREADS\";\r\n // classes\r\n export const I8 = \"I8\";\r\n export const I16 = \"I16\";\r\n export const I32 = \"I32\";\r\n export const I64 = \"I64\";\r\n export const Isize = \"Isize\";\r\n export const U8 = \"U8\";\r\n export const U16 = \"U16\";\r\n export const U32 = \"U32\";\r\n export const U64 = \"U64\";\r\n export const Usize = \"Usize\";\r\n export const Bool = \"Bool\";\r\n export const F32 = \"F32\";\r\n export const F64 = \"F64\";\r\n export const V128 = \"V128\";\r\n export const String = \"String\";\r\n export const Array = \"Array\";\r\n export const FixedArray = \"FixedArray\";\r\n export const Set = \"Set\";\r\n export const Map = \"Map\";\r\n export const ArrayBufferView = \"ArrayBufferView\";\r\n export const ArrayBuffer = \"ArrayBuffer\";\r\n export const Math = \"Math\";\r\n export const Mathf = \"Mathf\";\r\n export const Int8Array = \"Int8Array\";\r\n export const Int16Array = \"Int16Array\";\r\n export const Int32Array = \"Int32Array\";\r\n export const Int64Array = \"Int64Array\";\r\n export const Uint8Array = \"Uint8Array\";\r\n export const Uint8ClampedArray = \"Uint8ClampedArray\";\r\n export const Uint16Array = \"Uint16Array\";\r\n export const Uint32Array = \"Uint32Array\";\r\n export const Uint64Array = \"Uint64Array\";\r\n export const Float32Array = \"Float32Array\";\r\n export const Float64Array = \"Float64Array\";\r\n // runtime\r\n export const abort = \"abort\";\r\n export const pow = \"pow\";\r\n export const mod = \"mod\";\r\n export const alloc = \"__alloc\";\r\n export const realloc = \"__realloc\";\r\n export const free = \"__free\";\r\n export const retain = \"__retain\";\r\n export const release = \"__release\";\r\n export const collect = \"__collect\";\r\n export const typeinfo = \"__typeinfo\";\r\n export const instanceof_ = \"__instanceof\";\r\n export const visit = \"__visit\";\r\n export const allocArray = \"__allocArray\";\r\n}\r\n\r\n// shared\r\nexport { Feature } from \"../std/assembly/shared/feature\";\r\nexport { Target } from \"../std/assembly/shared/target\";\r\nexport { Typeinfo, TypeinfoFlags } from \"../std/assembly/shared/typeinfo\";\r\n","/**\r\n * Various compiler utilities.\r\n * @module util\r\n * @preferred\r\n *//***/\r\n\r\nexport * from \"./bitset\";\r\nexport * from \"./charcode\";\r\nexport * from \"./collections\";\r\nexport * from \"./path\";\r\nexport * from \"./text\";\r\nexport * from \"./binary\";\r\n\r\n/** Tests if `x` is a power of two. */\r\nexport function isPowerOf2(x: i32): bool {\r\n return x != 0 && (x & (x - 1)) == 0;\r\n}\r\n","/**\r\n * Shared diagnostic handling inherited by the parser and the compiler.\r\n * @module diagnostics\r\n * @preferred\r\n *//***/\r\n\r\nimport {\r\n Range\r\n} from \"./ast\";\r\n\r\nimport {\r\n DiagnosticCode,\r\n diagnosticCodeToString\r\n} from \"./diagnosticMessages.generated\";\r\n\r\nimport {\r\n isLineBreak, CharCode\r\n} from \"./util\";\r\n\r\nexport {\r\n DiagnosticCode,\r\n diagnosticCodeToString\r\n} from \"./diagnosticMessages.generated\";\r\n\r\n/** Indicates the category of a {@link DiagnosticMessage}. */\r\nexport enum DiagnosticCategory {\r\n /** Informatory message. */\r\n INFO,\r\n /** Warning message. */\r\n WARNING,\r\n /** Error message. */\r\n ERROR\r\n}\r\n\r\n/** Returns the string representation of the specified diagnostic category. */\r\nexport function diagnosticCategoryToString(category: DiagnosticCategory): string {\r\n switch (category) {\r\n case DiagnosticCategory.INFO: return \"INFO\";\r\n case DiagnosticCategory.WARNING: return \"WARNING\";\r\n case DiagnosticCategory.ERROR: return \"ERROR\";\r\n default: {\r\n assert(false);\r\n return \"\";\r\n }\r\n }\r\n}\r\n\r\n/** ANSI escape sequence for blue foreground. */\r\nexport const COLOR_BLUE: string = \"\\u001b[96m\";\r\n/** ANSI escape sequence for yellow foreground. */\r\nexport const COLOR_YELLOW: string = \"\\u001b[93m\";\r\n/** ANSI escape sequence for red foreground. */\r\nexport const COLOR_RED: string = \"\\u001b[91m\";\r\n/** ANSI escape sequence to reset the foreground color. */\r\nexport const COLOR_RESET: string = \"\\u001b[0m\";\r\n\r\n/** Returns the ANSI escape sequence for the specified category. */\r\nexport function diagnosticCategoryToColor(category: DiagnosticCategory): string {\r\n switch (category) {\r\n case DiagnosticCategory.INFO: return COLOR_BLUE;\r\n case DiagnosticCategory.WARNING: return COLOR_YELLOW;\r\n case DiagnosticCategory.ERROR: return COLOR_RED;\r\n default: {\r\n assert(false);\r\n return \"\";\r\n }\r\n }\r\n}\r\n\r\n/** Represents a diagnostic message. */\r\nexport class DiagnosticMessage {\r\n\r\n /** Message code. */\r\n code: i32;\r\n /** Message category. */\r\n category: DiagnosticCategory;\r\n /** Message text. */\r\n message: string;\r\n /** Respective source range, if any. */\r\n range: Range | null = null;\r\n /** Related range, if any. */\r\n relatedRange: Range | null = null;\r\n\r\n /** Constructs a new diagnostic message. */\r\n private constructor(code: i32, category: DiagnosticCategory, message: string) {\r\n this.code = code;\r\n this.category = category;\r\n this.message = message;\r\n }\r\n\r\n /** Creates a new diagnostic message of the specified category. */\r\n static create(\r\n code: DiagnosticCode,\r\n category: DiagnosticCategory,\r\n arg0: string | null = null,\r\n arg1: string | null = null,\r\n arg2: string | null = null\r\n ): DiagnosticMessage {\r\n var message = diagnosticCodeToString(code);\r\n if (arg0 != null) message = message.replace(\"{0}\", arg0);\r\n if (arg1 != null) message = message.replace(\"{1}\", arg1);\r\n if (arg2 != null) message = message.replace(\"{2}\", arg2);\r\n return new DiagnosticMessage(code, category, message);\r\n }\r\n\r\n /** Creates a new informatory diagnostic message. */\r\n static createInfo(\r\n code: DiagnosticCode,\r\n arg0: string | null = null,\r\n arg1: string | null = null\r\n ): DiagnosticMessage {\r\n return DiagnosticMessage.create(code, DiagnosticCategory.INFO, arg0, arg1);\r\n }\r\n\r\n /** Creates a new warning diagnostic message. */\r\n static createWarning(\r\n code: DiagnosticCode,\r\n arg0: string | null = null,\r\n arg1: string | null = null\r\n ): DiagnosticMessage {\r\n return DiagnosticMessage.create(code, DiagnosticCategory.WARNING, arg0, arg1);\r\n }\r\n\r\n /** Creates a new error diagnostic message. */\r\n static createError(\r\n code: DiagnosticCode,\r\n arg0: string | null = null,\r\n arg1: string | null = null\r\n ): DiagnosticMessage {\r\n return DiagnosticMessage.create(code, DiagnosticCategory.ERROR, arg0, arg1);\r\n }\r\n\r\n /** Adds a source range to this message. */\r\n withRange(range: Range): this {\r\n this.range = range;\r\n return this;\r\n }\r\n\r\n /** Adds a related source range to this message. */\r\n withRelatedRange(range: Range): this {\r\n this.relatedRange = range;\r\n return this;\r\n }\r\n\r\n /** Converts this message to a string. */\r\n toString(): string {\r\n if (this.range) {\r\n return (\r\n diagnosticCategoryToString(this.category) +\r\n \" \" +\r\n this.code.toString(10) +\r\n \": \\\"\" +\r\n this.message +\r\n \"\\\" in \" +\r\n this.range.source.normalizedPath +\r\n \":\" +\r\n this.range.line.toString(10) +\r\n \":\" +\r\n this.range.column.toString(10)\r\n );\r\n }\r\n return (\r\n diagnosticCategoryToString(this.category) +\r\n \" \" +\r\n this.code.toString(10) +\r\n \": \" +\r\n this.message\r\n );\r\n }\r\n}\r\n\r\n/** Formats a diagnostic message, optionally with terminal colors and source context. */\r\nexport function formatDiagnosticMessage(\r\n message: DiagnosticMessage,\r\n useColors: bool = false,\r\n showContext: bool = false\r\n): string {\r\n\r\n // general information\r\n var sb: string[] = [];\r\n if (useColors) sb.push(diagnosticCategoryToColor(message.category));\r\n sb.push(diagnosticCategoryToString(message.category));\r\n if (useColors) sb.push(COLOR_RESET);\r\n sb.push(message.code < 1000 ? \" AS\" : \" TS\");\r\n sb.push(message.code.toString(10));\r\n sb.push(\": \");\r\n sb.push(message.message);\r\n\r\n // include range information if available\r\n if (message.range) {\r\n\r\n // include context information if requested\r\n let range = message.range;\r\n if (showContext) {\r\n sb.push(\"\\n\");\r\n sb.push(formatDiagnosticContext(range, useColors));\r\n }\r\n sb.push(\"\\n\");\r\n sb.push(\" in \");\r\n sb.push(range.source.normalizedPath);\r\n sb.push(\"(\");\r\n sb.push(range.line.toString(10));\r\n sb.push(\",\");\r\n sb.push(range.column.toString(10));\r\n sb.push(\")\");\r\n\r\n let relatedRange = message.relatedRange;\r\n if (relatedRange) {\r\n if (showContext) {\r\n sb.push(\"\\n\");\r\n sb.push(formatDiagnosticContext(relatedRange, useColors));\r\n }\r\n sb.push(\"\\n\");\r\n sb.push(\" in \");\r\n sb.push(range.source.normalizedPath);\r\n sb.push(\"(\");\r\n sb.push(range.line.toString(10));\r\n sb.push(\",\");\r\n sb.push(range.column.toString(10));\r\n sb.push(\")\");\r\n }\r\n }\r\n return sb.join(\"\");\r\n}\r\n\r\n/** Formats the diagnostic context for the specified range, optionally with terminal colors. */\r\nexport function formatDiagnosticContext(range: Range, useColors: bool = false): string {\r\n var text = range.source.text;\r\n var len = text.length;\r\n var start = range.start;\r\n var end = range.end;\r\n while (start > 0 && !isLineBreak(text.charCodeAt(start - 1))) start--;\r\n while (end < len && !isLineBreak(text.charCodeAt(end))) end++;\r\n var sb: string[] = [\r\n \"\\n \",\r\n text.substring(start, end),\r\n \"\\n \"\r\n ];\r\n while (start < range.start) {\r\n sb.push(\" \");\r\n start++;\r\n }\r\n if (useColors) sb.push(COLOR_RED);\r\n if (range.start == range.end) {\r\n sb.push(\"^\");\r\n } else {\r\n while (start++ < range.end) {\r\n if (isLineBreak(text.charCodeAt(start))) {\r\n sb.push(start == range.start + 1 ? \"^\" : \"~\");\r\n break;\r\n }\r\n sb.push(\"~\");\r\n }\r\n }\r\n if (useColors) sb.push(COLOR_RESET);\r\n return sb.join(\"\");\r\n}\r\n\r\n/** Base class of all diagnostic emitters. */\r\nexport abstract class DiagnosticEmitter {\r\n\r\n /** Diagnostic messages emitted so far. */\r\n diagnostics: DiagnosticMessage[];\r\n\r\n /** Initializes this diagnostic emitter. */\r\n protected constructor(diagnostics: DiagnosticMessage[] | null = null) {\r\n this.diagnostics = diagnostics ? diagnostics : new Array();\r\n }\r\n\r\n /** Emits a diagnostic message of the specified category. */\r\n emitDiagnostic(\r\n code: DiagnosticCode,\r\n category: DiagnosticCategory,\r\n range: Range,\r\n relatedRange: Range | null,\r\n arg0: string | null = null,\r\n arg1: string | null = null,\r\n arg2: string | null = null\r\n ): void {\r\n var message = DiagnosticMessage.create(code, category, arg0, arg1, arg2).withRange(range);\r\n if (relatedRange) message.relatedRange = relatedRange;\r\n this.diagnostics.push(message);\r\n // console.log(formatDiagnosticMessage(message, true, true) + \"\\n\"); // temporary\r\n // console.log(new Error(\"stack\").stack);\r\n }\r\n\r\n /** Emits an informatory diagnostic message. */\r\n info(\r\n code: DiagnosticCode,\r\n range: Range,\r\n arg0: string | null = null,\r\n arg1: string | null = null,\r\n arg2: string | null = null\r\n ): void {\r\n this.emitDiagnostic(code, DiagnosticCategory.INFO, range, null, arg0, arg1, arg2);\r\n }\r\n\r\n /** Emits an informatory diagnostic message with a related range. */\r\n infoRelated(\r\n code: DiagnosticCode,\r\n range: Range,\r\n relatedRange: Range,\r\n arg0: string | null = null,\r\n arg1: string | null = null,\r\n arg2: string | null = null\r\n ): void {\r\n this.emitDiagnostic(code, DiagnosticCategory.INFO, range, relatedRange, arg0, arg1, arg2);\r\n }\r\n\r\n /** Emits a warning diagnostic message. */\r\n warning(\r\n code: DiagnosticCode,\r\n range: Range,\r\n arg0: string | null = null,\r\n arg1: string | null = null,\r\n arg2: string | null = null\r\n ): void {\r\n this.emitDiagnostic(code, DiagnosticCategory.WARNING, range, null, arg0, arg1, arg2);\r\n }\r\n\r\n /** Emits a warning diagnostic message with a related range. */\r\n warningRelated(\r\n code: DiagnosticCode,\r\n range: Range,\r\n relatedRange: Range,\r\n arg0: string | null = null,\r\n arg1: string | null = null,\r\n arg2: string | null = null\r\n ): void {\r\n this.emitDiagnostic(code, DiagnosticCategory.WARNING, range, relatedRange, arg0, arg1, arg2);\r\n }\r\n\r\n /** Emits an error diagnostic message. */\r\n error(\r\n code: DiagnosticCode,\r\n range: Range,\r\n arg0: string | null = null,\r\n arg1: string | null = null,\r\n arg2: string | null = null\r\n ): void {\r\n this.emitDiagnostic(code, DiagnosticCategory.ERROR, range, null, arg0, arg1, arg2);\r\n }\r\n\r\n /** Emits an error diagnostic message with a related range. */\r\n errorRelated(\r\n code: DiagnosticCode,\r\n range: Range,\r\n relatedRange: Range,\r\n arg0: string | null = null,\r\n arg1: string | null = null,\r\n arg2: string | null = null\r\n ): void {\r\n this.emitDiagnostic(code, DiagnosticCategory.ERROR, range, relatedRange, arg0, arg1, arg2);\r\n }\r\n}\r\n","/**\r\n * AssemblyScript's intermediate representation describing a program's elements.\r\n * @module program\r\n *//***/\r\n\r\nimport {\r\n CommonFlags,\r\n PATH_DELIMITER,\r\n STATIC_DELIMITER,\r\n INSTANCE_DELIMITER,\r\n GETTER_PREFIX,\r\n SETTER_PREFIX,\r\n INNER_DELIMITER,\r\n LIBRARY_SUBST,\r\n INDEX_SUFFIX,\r\n CommonSymbols,\r\n Feature,\r\n Target\r\n} from \"./common\";\r\n\r\nimport {\r\n Options\r\n} from \"./compiler\";\r\n\r\nimport {\r\n DiagnosticCode,\r\n DiagnosticMessage,\r\n DiagnosticEmitter\r\n} from \"./diagnostics\";\r\n\r\nimport {\r\n Type,\r\n TypeKind,\r\n TypeFlags,\r\n Signature\r\n} from \"./types\";\r\n\r\nimport {\r\n Node,\r\n NodeKind,\r\n Source,\r\n SourceKind,\r\n Range,\r\n DecoratorNode,\r\n DecoratorKind,\r\n SignatureNode,\r\n TypeParameterNode,\r\n CommonTypeNode,\r\n TypeNode,\r\n ArrowKind,\r\n\r\n Expression,\r\n IdentifierExpression,\r\n LiteralExpression,\r\n LiteralKind,\r\n StringLiteralExpression,\r\n\r\n Statement,\r\n ClassDeclaration,\r\n DeclarationStatement,\r\n EnumDeclaration,\r\n EnumValueDeclaration,\r\n ExportMember,\r\n ExportStatement,\r\n FieldDeclaration,\r\n FunctionDeclaration,\r\n ImportDeclaration,\r\n ImportStatement,\r\n InterfaceDeclaration,\r\n MethodDeclaration,\r\n NamespaceDeclaration,\r\n TypeDeclaration,\r\n VariableDeclaration,\r\n VariableLikeDeclarationStatement,\r\n VariableStatement,\r\n\r\n decoratorNameToKind,\r\n findDecorator,\r\n ExportDefaultStatement\r\n} from \"./ast\";\r\n\r\nimport {\r\n Module,\r\n FunctionRef\r\n} from \"./module\";\r\n\r\nimport {\r\n CharCode,\r\n writeI8,\r\n writeI16,\r\n writeI32,\r\n writeF32,\r\n writeF64\r\n} from \"./util\";\r\n\r\nimport {\r\n Resolver\r\n} from \"./resolver\";\r\n\r\nimport {\r\n Flow\r\n} from \"./flow\";\r\n\r\n/** Represents a yet unresolved `import`. */\r\nclass QueuedImport {\r\n constructor(\r\n /** File being imported into. */\r\n public localFile: File,\r\n /** Identifier within the local file. */\r\n public localIdentifier: IdentifierExpression,\r\n /** Identifier within the other file. Is an `import *` if not set. */\r\n public foreignIdentifier: IdentifierExpression | null,\r\n /** Path to the other file. */\r\n public foreignPath: string,\r\n /** Alternative path to the other file. */\r\n public foreignPathAlt: string\r\n ) {}\r\n}\r\n\r\n/** Represents a yet unresolved `export`. */\r\nclass QueuedExport {\r\n constructor(\r\n /** Identifier within the local file. */\r\n public localIdentifier: IdentifierExpression,\r\n /** Identifier within the other file. */\r\n public foreignIdentifier: IdentifierExpression,\r\n /** Path to the other file if a re-export. */\r\n public foreignPath: string | null,\r\n /** Alternative path to the other file if a re-export. */\r\n public foreignPathAlt: string | null\r\n ) {}\r\n}\r\n\r\n/** Represents a yet unresolved `export *`. */\r\nclass QueuedExportStar {\r\n // stored in a map with localFile as the key\r\n constructor(\r\n /** Path to the other file. */\r\n public foreignPath: string,\r\n /** Alternative path to the other file. */\r\n public foreignPathAlt: string,\r\n /** Reference to the path literal for reporting. */\r\n public pathLiteral: StringLiteralExpression\r\n ) {}\r\n}\r\n\r\n/** Represents the kind of an operator overload. */\r\nexport enum OperatorKind {\r\n INVALID,\r\n\r\n // indexed access\r\n INDEXED_GET, // a[]\r\n INDEXED_SET, // a[]=b\r\n UNCHECKED_INDEXED_GET, // unchecked(a[])\r\n UNCHECKED_INDEXED_SET, // unchecked(a[]=b)\r\n\r\n // binary\r\n ADD, // a + b\r\n SUB, // a - b\r\n MUL, // a * b\r\n DIV, // a / b\r\n REM, // a % b\r\n POW, // a ** b\r\n BITWISE_AND, // a & b\r\n BITWISE_OR, // a | b\r\n BITWISE_XOR, // a ^ b\r\n BITWISE_SHL, // a << b\r\n BITWISE_SHR, // a >> b\r\n BITWISE_SHR_U, // a >>> b\r\n EQ, // a == b\r\n NE, // a != b\r\n GT, // a > b\r\n GE, // a >= b\r\n LT, // a < b\r\n LE, // a <= b\r\n\r\n // unary prefix\r\n PLUS, // +a\r\n MINUS, // -a\r\n NOT, // !a\r\n BITWISE_NOT, // ~a\r\n PREFIX_INC, // ++a\r\n PREFIX_DEC, // --a\r\n\r\n // unary postfix\r\n POSTFIX_INC, // a++\r\n POSTFIX_DEC // a--\r\n\r\n // not overridable:\r\n // IDENTITY // a === b\r\n // LOGICAL_AND // a && b\r\n // LOGICAL_OR // a || b\r\n}\r\n\r\n/** Returns the operator kind represented by the specified decorator and string argument. */\r\nfunction operatorKindFromDecorator(decoratorKind: DecoratorKind, arg: string): OperatorKind {\r\n assert(arg.length);\r\n switch (decoratorKind) {\r\n case DecoratorKind.OPERATOR:\r\n case DecoratorKind.OPERATOR_BINARY: {\r\n switch (arg.charCodeAt(0)) {\r\n case CharCode.OPENBRACKET: {\r\n if (arg == \"[]\") return OperatorKind.INDEXED_GET;\r\n if (arg == \"[]=\") return OperatorKind.INDEXED_SET;\r\n break;\r\n }\r\n case CharCode.OPENBRACE: {\r\n if (arg == \"{}\") return OperatorKind.UNCHECKED_INDEXED_GET;\r\n if (arg == \"{}=\") return OperatorKind.UNCHECKED_INDEXED_SET;\r\n break;\r\n }\r\n case CharCode.PLUS: {\r\n if (arg == \"+\") return OperatorKind.ADD;\r\n break;\r\n }\r\n case CharCode.MINUS: {\r\n if (arg == \"-\") return OperatorKind.SUB;\r\n break;\r\n }\r\n case CharCode.ASTERISK: {\r\n if (arg == \"*\") return OperatorKind.MUL;\r\n if (arg == \"**\") return OperatorKind.POW;\r\n break;\r\n }\r\n case CharCode.SLASH: {\r\n if (arg == \"/\") return OperatorKind.DIV;\r\n break;\r\n }\r\n case CharCode.PERCENT: {\r\n if (arg == \"%\") return OperatorKind.REM;\r\n break;\r\n }\r\n case CharCode.AMPERSAND: {\r\n if (arg == \"&\") return OperatorKind.BITWISE_AND;\r\n break;\r\n }\r\n case CharCode.BAR: {\r\n if (arg == \"|\") return OperatorKind.BITWISE_OR;\r\n break;\r\n }\r\n case CharCode.CARET: {\r\n if (arg == \"^\") return OperatorKind.BITWISE_XOR;\r\n break;\r\n }\r\n case CharCode.EQUALS: {\r\n if (arg == \"==\") return OperatorKind.EQ;\r\n break;\r\n }\r\n case CharCode.EXCLAMATION: {\r\n if (arg == \"!=\") return OperatorKind.NE;\r\n break;\r\n }\r\n case CharCode.GREATERTHAN: {\r\n if (arg == \">\") return OperatorKind.GT;\r\n if (arg == \">=\") return OperatorKind.GE;\r\n if (arg == \">>\") return OperatorKind.BITWISE_SHR;\r\n if (arg == \">>>\") return OperatorKind.BITWISE_SHR_U;\r\n break;\r\n }\r\n case CharCode.LESSTHAN: {\r\n if (arg == \"<\") return OperatorKind.LT;\r\n if (arg == \"<=\") return OperatorKind.LE;\r\n if (arg == \"<<\") return OperatorKind.BITWISE_SHL;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case DecoratorKind.OPERATOR_PREFIX: {\r\n switch (arg.charCodeAt(0)) {\r\n case CharCode.PLUS: {\r\n if (arg == \"+\") return OperatorKind.PLUS;\r\n if (arg == \"++\") return OperatorKind.PREFIX_INC;\r\n break;\r\n }\r\n case CharCode.MINUS: {\r\n if (arg == \"-\") return OperatorKind.MINUS;\r\n if (arg == \"--\") return OperatorKind.PREFIX_DEC;\r\n break;\r\n }\r\n case CharCode.EXCLAMATION: {\r\n if (arg == \"!\") return OperatorKind.NOT;\r\n break;\r\n }\r\n case CharCode.TILDE: {\r\n if (arg == \"~\") return OperatorKind.BITWISE_NOT;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case DecoratorKind.OPERATOR_POSTFIX: {\r\n switch (arg.charCodeAt(0)) {\r\n case CharCode.PLUS: {\r\n if (arg == \"++\") return OperatorKind.POSTFIX_INC;\r\n break;\r\n }\r\n case CharCode.MINUS: {\r\n if (arg == \"--\") return OperatorKind.POSTFIX_DEC;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n return OperatorKind.INVALID;\r\n}\r\n\r\n/** Represents an AssemblyScript program. */\r\nexport class Program extends DiagnosticEmitter {\r\n\r\n /** Resolver instance. */\r\n resolver: Resolver;\r\n /** Array of sources. */\r\n sources: Source[] = [];\r\n /** Diagnostic offset used where successively obtaining the next diagnostic. */\r\n diagnosticsOffset: i32 = 0;\r\n /** Compiler options. */\r\n options: Options;\r\n /** Special native code source. */\r\n nativeSource: Source;\r\n /** Special native code file. */\r\n nativeFile: File;\r\n\r\n // lookup maps\r\n\r\n /** Files by unique internal name. */\r\n filesByName: Map = new Map();\r\n /** Elements by unique internal name in element space. */\r\n elementsByName: Map = new Map();\r\n /** Elements by declaration. */\r\n elementsByDeclaration: Map = new Map();\r\n /** Element instances by unique internal name. */\r\n instancesByName: Map = new Map();\r\n /** Classes backing basic types like `i32`. */\r\n typeClasses: Map = new Map();\r\n /** Managed classes contained in the program, by id. */\r\n managedClasses: Map = new Map();\r\n\r\n // standard references\r\n\r\n /** ArrayBufferView reference. */\r\n arrayBufferViewInstance: Class;\r\n /** ArrayBuffer instance reference. */\r\n arrayBufferInstance: Class;\r\n /** Array prototype reference. */\r\n arrayPrototype: ClassPrototype;\r\n /** Set prototype reference. */\r\n setPrototype: ClassPrototype;\r\n /** Map prototype reference. */\r\n mapPrototype: ClassPrototype;\r\n /** Fixed array prototype reference. */\r\n fixedArrayPrototype: ClassPrototype;\r\n /** Int8Array prototype. */\r\n i8ArrayPrototype: ClassPrototype;\r\n /** Int16Array prototype. */\r\n i16ArrayPrototype: ClassPrototype;\r\n /** Int32Array prototype. */\r\n i32ArrayPrototype: ClassPrototype;\r\n /** Int64Array prototype. */\r\n i64ArrayPrototype: ClassPrototype;\r\n /** Uint8Array prototype. */\r\n u8ArrayPrototype: ClassPrototype;\r\n /** Uint8ClampedArray prototype. */\r\n u8ClampedArrayPrototype: ClassPrototype;\r\n /** Uint16Array prototype. */\r\n u16ArrayPrototype: ClassPrototype;\r\n /** Uint32Array prototype. */\r\n u32ArrayPrototype: ClassPrototype;\r\n /** Uint64Array prototype. */\r\n u64ArrayPrototype: ClassPrototype;\r\n /** Float32Array prototype. */\r\n f32ArrayPrototype: ClassPrototype;\r\n /** Float64Array prototype. */\r\n f64ArrayPrototype: ClassPrototype;\r\n /** String instance reference. */\r\n stringInstance: Class;\r\n /** Abort function reference, if present. */\r\n abortInstance: Function;\r\n\r\n // runtime references\r\n\r\n /** RT `__alloc(size: usize, id: u32): usize` */\r\n allocInstance: Function;\r\n /** RT `__realloc(ref: usize, newSize: usize): usize` */\r\n reallocInstance: Function;\r\n /** RT `__free(ref: usize): void` */\r\n freeInstance: Function;\r\n /** RT `__retain(ref: usize): usize` */\r\n retainInstance: Function;\r\n /** RT `__release(ref: usize): void` */\r\n releaseInstance: Function;\r\n /** RT `__collect(): void` */\r\n collectInstance: Function;\r\n /** RT `__visit(ref: usize, cookie: u32): void` */\r\n visitInstance: Function;\r\n /** RT `__typeinfo(id: u32): RTTIFlags` */\r\n typeinfoInstance: Function;\r\n /** RT `__instanceof(ref: usize, superId: u32): bool` */\r\n instanceofInstance: Function;\r\n /** RT `__allocArray(length: i32, alignLog2: usize, id: u32, data: usize = 0): usize` */\r\n allocArrayInstance: Function;\r\n\r\n /** Next class id. */\r\n nextClassId: u32 = 0;\r\n\r\n /** Constructs a new program, optionally inheriting parser diagnostics. */\r\n constructor(\r\n /** Shared array of diagnostic messages (emitted so far). */\r\n diagnostics: DiagnosticMessage[] | null = null\r\n ) {\r\n super(diagnostics);\r\n var nativeSource = new Source(LIBRARY_SUBST, \"[native code]\", SourceKind.LIBRARY);\r\n this.nativeSource = nativeSource;\r\n var nativeFile = new File(this, nativeSource);\r\n this.nativeFile = nativeFile;\r\n this.filesByName.set(nativeFile.internalName, nativeFile);\r\n this.resolver = new Resolver(this);\r\n }\r\n\r\n /** Writes a common runtime header to the specified buffer. */\r\n writeRuntimeHeader(buffer: Uint8Array, offset: i32, classInstance: Class, payloadSize: u32): void {\r\n // BLOCK {\r\n // mmInfo: usize // WASM64 TODO\r\n // gcInfo: u32\r\n // rtId: u32\r\n // rtSize: u32\r\n // }\r\n assert(payloadSize < (1 << 28)); // 1 bit BUFFERED + 3 bits color\r\n writeI32(payloadSize, buffer, offset);\r\n writeI32(1, buffer, offset + 4); // RC=1\r\n writeI32(classInstance.id, buffer, offset + 8);\r\n writeI32(payloadSize, buffer, offset + 12);\r\n }\r\n\r\n /** Gets the size of a runtime header. */\r\n get runtimeHeaderSize(): i32 {\r\n return 16;\r\n }\r\n\r\n /** Creates a native variable declaration. */\r\n makeNativeVariableDeclaration(\r\n /** The simple name of the variable */\r\n name: string,\r\n /** Flags indicating specific traits, e.g. `CONST`. */\r\n flags: CommonFlags = CommonFlags.NONE\r\n ): VariableDeclaration {\r\n var range = this.nativeSource.range;\r\n return Node.createVariableDeclaration(\r\n Node.createIdentifierExpression(name, range),\r\n null, null, null, flags, range\r\n );\r\n }\r\n\r\n /** Creates a native type declaration. */\r\n makeNativeTypeDeclaration(\r\n /** The simple name of the type. */\r\n name: string,\r\n /** Flags indicating specific traits, e.g. `GENERIC`. */\r\n flags: CommonFlags = CommonFlags.NONE\r\n ): TypeDeclaration {\r\n var range = this.nativeSource.range;\r\n var identifier = Node.createIdentifierExpression(name, range);\r\n return Node.createTypeDeclaration(\r\n identifier,\r\n null,\r\n Node.createOmittedType(range),\r\n null, flags, range\r\n );\r\n }\r\n\r\n // a dummy signature for programmatically generated native functions\r\n private nativeDummySignature: SignatureNode | null = null;\r\n\r\n /** Creates a native function declaration. */\r\n makeNativeFunctionDeclaration(\r\n /** The simple name of the function. */\r\n name: string,\r\n /** Flags indicating specific traits, e.g. `DECLARE`. */\r\n flags: CommonFlags = CommonFlags.NONE\r\n ): FunctionDeclaration {\r\n var range = this.nativeSource.range;\r\n return Node.createFunctionDeclaration(\r\n Node.createIdentifierExpression(name, range),\r\n null,\r\n this.nativeDummySignature || (this.nativeDummySignature = Node.createSignature([],\r\n Node.createType( // ^ AST signature doesn't really matter, is overridden anyway\r\n Node.createSimpleTypeName(CommonSymbols.void_, range),\r\n null, false, range\r\n ),\r\n null, false, range)\r\n ),\r\n null, null, flags, ArrowKind.NONE, range\r\n );\r\n }\r\n\r\n /** Creates a native namespace declaration. */\r\n makeNativeNamespaceDeclaration(\r\n /** The simple name of the namespace. */\r\n name: string,\r\n /** Flags indicating specific traits, e.g. `EXPORT`. */\r\n flags: CommonFlags = CommonFlags.NONE\r\n ): NamespaceDeclaration {\r\n var range = this.nativeSource.range;\r\n return Node.createNamespaceDeclaration(\r\n Node.createIdentifierExpression(name, range),\r\n [], null, flags, range\r\n );\r\n }\r\n\r\n /** Creates a native function. */\r\n makeNativeFunction(\r\n /** The simple name of the function. */\r\n name: string,\r\n /** Concrete function signature. */\r\n signature: Signature,\r\n /** Parent element, usually a file, class or namespace. */\r\n parent: Element = this.nativeFile,\r\n /** Flags indicating specific traits, e.g. `GENERIC`. */\r\n flags: CommonFlags = CommonFlags.NONE,\r\n /** Decorator flags representing built-in decorators. */\r\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\r\n ): Function {\r\n return new Function(\r\n name,\r\n new FunctionPrototype(\r\n name,\r\n parent,\r\n this.makeNativeFunctionDeclaration(name, flags),\r\n decoratorFlags\r\n ),\r\n signature\r\n );\r\n }\r\n\r\n /** Gets the (possibly merged) program element linked to the specified declaration. */\r\n getElementByDeclaration(declaration: DeclarationStatement): DeclaredElement {\r\n var elementsByDeclaration = this.elementsByDeclaration;\r\n assert(elementsByDeclaration.has(declaration));\r\n return elementsByDeclaration.get(declaration)!;\r\n }\r\n\r\n /** Initializes the program and its elements prior to compilation. */\r\n initialize(options: Options): void {\r\n this.options = options;\r\n\r\n // register native types\r\n this.registerNativeType(CommonSymbols.i8, Type.i8);\r\n this.registerNativeType(CommonSymbols.i16, Type.i16);\r\n this.registerNativeType(CommonSymbols.i32, Type.i32);\r\n this.registerNativeType(CommonSymbols.i64, Type.i64);\r\n this.registerNativeType(CommonSymbols.isize, options.isizeType);\r\n this.registerNativeType(CommonSymbols.u8, Type.u8);\r\n this.registerNativeType(CommonSymbols.u16, Type.u16);\r\n this.registerNativeType(CommonSymbols.u32, Type.u32);\r\n this.registerNativeType(CommonSymbols.u64, Type.u64);\r\n this.registerNativeType(CommonSymbols.usize, options.usizeType);\r\n this.registerNativeType(CommonSymbols.bool, Type.bool);\r\n this.registerNativeType(CommonSymbols.f32, Type.f32);\r\n this.registerNativeType(CommonSymbols.f64, Type.f64);\r\n this.registerNativeType(CommonSymbols.void_, Type.void);\r\n this.registerNativeType(CommonSymbols.number, Type.f64); // alias\r\n this.registerNativeType(CommonSymbols.boolean, Type.bool); // alias\r\n this.nativeFile.add(CommonSymbols.native, new TypeDefinition(\r\n CommonSymbols.native,\r\n this.nativeFile,\r\n this.makeNativeTypeDeclaration(CommonSymbols.native, CommonFlags.EXPORT | CommonFlags.GENERIC),\r\n DecoratorFlags.BUILTIN\r\n ));\r\n if (options.hasFeature(Feature.SIMD)) this.registerNativeType(CommonSymbols.v128, Type.v128);\r\n\r\n // register compiler hints\r\n this.registerConstantInteger(CommonSymbols.ASC_TARGET, Type.i32,\r\n i64_new(options.isWasm64 ? Target.WASM64 : Target.WASM32));\r\n this.registerConstantInteger(CommonSymbols.ASC_NO_ASSERT, Type.bool,\r\n i64_new(options.noAssert ? 1 : 0, 0));\r\n this.registerConstantInteger(CommonSymbols.ASC_MEMORY_BASE, Type.i32,\r\n i64_new(options.memoryBase, 0));\r\n this.registerConstantInteger(CommonSymbols.ASC_OPTIMIZE_LEVEL, Type.i32,\r\n i64_new(options.optimizeLevelHint, 0));\r\n this.registerConstantInteger(CommonSymbols.ASC_SHRINK_LEVEL, Type.i32,\r\n i64_new(options.shrinkLevelHint, 0));\r\n this.registerConstantInteger(CommonSymbols.ASC_FEATURE_MUTABLE_GLOBAL, Type.bool,\r\n i64_new(options.hasFeature(Feature.MUTABLE_GLOBAL) ? 1 : 0, 0));\r\n this.registerConstantInteger(CommonSymbols.ASC_FEATURE_SIGN_EXTENSION, Type.bool,\r\n i64_new(options.hasFeature(Feature.SIGN_EXTENSION) ? 1 : 0, 0));\r\n this.registerConstantInteger(CommonSymbols.ASC_FEATURE_BULK_MEMORY, Type.bool,\r\n i64_new(options.hasFeature(Feature.BULK_MEMORY) ? 1 : 0, 0));\r\n this.registerConstantInteger(CommonSymbols.ASC_FEATURE_SIMD, Type.bool,\r\n i64_new(options.hasFeature(Feature.SIMD) ? 1 : 0, 0));\r\n this.registerConstantInteger(CommonSymbols.ASC_FEATURE_THREADS, Type.bool,\r\n i64_new(options.hasFeature(Feature.THREADS) ? 1 : 0, 0));\r\n\r\n // remember deferred elements\r\n var queuedImports = new Array();\r\n var queuedExports = new Map>();\r\n var queuedExportsStar = new Map();\r\n var queuedExtends = new Array();\r\n var queuedImplements = new Array();\r\n\r\n // initialize relevant declaration-like statements of the entire program\r\n for (let i = 0, k = this.sources.length; i < k; ++i) {\r\n let source = this.sources[i];\r\n let file = new File(this, source);\r\n this.filesByName.set(file.internalName, file);\r\n let statements = source.statements;\r\n for (let j = 0, l = statements.length; j < l; ++j) {\r\n let statement = statements[j];\r\n switch (statement.kind) {\r\n case NodeKind.EXPORT: {\r\n this.initializeExports(statement, file, queuedExports, queuedExportsStar);\r\n break;\r\n }\r\n case NodeKind.EXPORTDEFAULT: {\r\n this.initializeExportDefault(statement, file, queuedExtends, queuedImplements);\r\n break;\r\n }\r\n case NodeKind.IMPORT: {\r\n this.initializeImports(statement, file, queuedImports, queuedExports);\r\n break;\r\n }\r\n case NodeKind.VARIABLE: {\r\n this.initializeVariables(statement, file);\r\n break;\r\n }\r\n case NodeKind.CLASSDECLARATION: {\r\n this.initializeClass(statement, file, queuedExtends, queuedImplements);\r\n break;\r\n }\r\n case NodeKind.ENUMDECLARATION: {\r\n this.initializeEnum(statement, file);\r\n break;\r\n }\r\n case NodeKind.FUNCTIONDECLARATION: {\r\n this.initializeFunction(statement, file);\r\n break;\r\n }\r\n case NodeKind.INTERFACEDECLARATION: {\r\n this.initializeInterface(statement, file);\r\n break;\r\n }\r\n case NodeKind.NAMESPACEDECLARATION: {\r\n this.initializeNamespace(statement, file, queuedExtends, queuedImplements);\r\n break;\r\n }\r\n case NodeKind.TYPEDECLARATION: {\r\n this.initializeTypeDefinition(statement, file);\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n\r\n // queued exports * should be linkable now that all files have been processed\r\n for (let [file, exportsStar] of queuedExportsStar) {\r\n for (let i = 0, k = exportsStar.length; i < k; ++i) {\r\n let exportStar = exportsStar[i];\r\n let foreignFile = this.lookupForeignFile(exportStar.foreignPath, exportStar.foreignPathAlt);\r\n if (!foreignFile) {\r\n this.error(\r\n DiagnosticCode.File_0_not_found,\r\n exportStar.pathLiteral.range, exportStar.pathLiteral.value\r\n );\r\n continue;\r\n }\r\n file.ensureExportStar(foreignFile);\r\n }\r\n }\r\n\r\n // queued imports should be resolvable now through traversing exports and queued exports\r\n for (let i = 0, k = queuedImports.length; i < k; ++i) {\r\n let queuedImport = queuedImports[i];\r\n let foreignIdentifier = queuedImport.foreignIdentifier;\r\n if (foreignIdentifier) { // i.e. import { foo [as bar] } from \"./baz\"\r\n let element = this.lookupForeign(\r\n foreignIdentifier.text,\r\n queuedImport.foreignPath,\r\n queuedImport.foreignPathAlt,\r\n queuedExports\r\n );\r\n if (element) {\r\n queuedImport.localFile.add(\r\n queuedImport.localIdentifier.text,\r\n element,\r\n true // isImport\r\n );\r\n } else {\r\n // FIXME: file not found is not reported if this happens?\r\n this.error(\r\n DiagnosticCode.Module_0_has_no_exported_member_1,\r\n foreignIdentifier.range, queuedImport.foreignPath, foreignIdentifier.text\r\n );\r\n }\r\n } else { // i.e. import * as bar from \"./bar\"\r\n let foreignFile = this.lookupForeignFile(queuedImport.foreignPath, queuedImport.foreignPathAlt);\r\n if (foreignFile) {\r\n let localFile = queuedImport.localFile;\r\n let localName = queuedImport.localIdentifier.text;\r\n localFile.add(\r\n localName,\r\n foreignFile.asImportedNamespace(\r\n localName,\r\n localFile\r\n ),\r\n true // isImport\r\n );\r\n } else {\r\n assert(false); // already reported by the parser not finding the file\r\n }\r\n }\r\n }\r\n\r\n // queued exports should be resolvable now that imports are finalized\r\n for (let [file, exports] of queuedExports) {\r\n for (let [exportName, queuedExport] of exports) {\r\n let localName = queuedExport.localIdentifier.text;\r\n let foreignPath = queuedExport.foreignPath;\r\n if (foreignPath) { // i.e. export { foo [as bar] } from \"./baz\"\r\n let element = this.lookupForeign(\r\n localName,\r\n foreignPath,\r\n assert(queuedExport.foreignPathAlt), // must be set if foreignPath is\r\n queuedExports\r\n );\r\n if (element) {\r\n file.ensureExport(exportName, element);\r\n } else {\r\n this.error(\r\n DiagnosticCode.Module_0_has_no_exported_member_1,\r\n queuedExport.localIdentifier.range,\r\n foreignPath, localName\r\n );\r\n }\r\n } else { // i.e. export { foo [as bar] }\r\n let element = file.lookupInSelf(localName);\r\n if (element) {\r\n file.ensureExport(exportName, element);\r\n } else {\r\n let globalElement = this.lookupGlobal(localName);\r\n if (globalElement && globalElement instanceof DeclaredElement) { // export { memory }\r\n file.ensureExport(exportName, globalElement);\r\n } else {\r\n this.error(\r\n DiagnosticCode.Module_0_has_no_exported_member_1,\r\n queuedExport.foreignIdentifier.range,\r\n file.internalName, queuedExport.foreignIdentifier.text\r\n );\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n // register ArrayBuffer (id=0), String (id=1), ArrayBufferView (id=2)\r\n assert(this.nextClassId == 0);\r\n this.arrayBufferInstance = this.requireClass(CommonSymbols.ArrayBuffer);\r\n assert(this.arrayBufferInstance.id == 0);\r\n this.stringInstance = this.requireClass(CommonSymbols.String);\r\n assert(this.stringInstance.id == 1);\r\n this.arrayBufferViewInstance = this.requireClass(CommonSymbols.ArrayBufferView);\r\n assert(this.arrayBufferViewInstance.id == 2);\r\n\r\n // register classes backing basic types\r\n this.registerNativeTypeClass(TypeKind.I8, CommonSymbols.I8);\r\n this.registerNativeTypeClass(TypeKind.I16, CommonSymbols.I16);\r\n this.registerNativeTypeClass(TypeKind.I32, CommonSymbols.I32);\r\n this.registerNativeTypeClass(TypeKind.I64, CommonSymbols.I64);\r\n this.registerNativeTypeClass(TypeKind.ISIZE, CommonSymbols.Isize);\r\n this.registerNativeTypeClass(TypeKind.U8, CommonSymbols.U8);\r\n this.registerNativeTypeClass(TypeKind.U16, CommonSymbols.U16);\r\n this.registerNativeTypeClass(TypeKind.U32, CommonSymbols.U32);\r\n this.registerNativeTypeClass(TypeKind.U64, CommonSymbols.U64);\r\n this.registerNativeTypeClass(TypeKind.USIZE, CommonSymbols.Usize);\r\n this.registerNativeTypeClass(TypeKind.BOOL, CommonSymbols.Bool);\r\n this.registerNativeTypeClass(TypeKind.F32, CommonSymbols.F32);\r\n this.registerNativeTypeClass(TypeKind.F64, CommonSymbols.F64);\r\n if (options.hasFeature(Feature.SIMD)) this.registerNativeTypeClass(TypeKind.V128, CommonSymbols.V128);\r\n\r\n // register views but don't instantiate them yet\r\n this.i8ArrayPrototype = this.require(CommonSymbols.Int8Array, ElementKind.CLASS_PROTOTYPE);\r\n this.i16ArrayPrototype = this.require(CommonSymbols.Int16Array, ElementKind.CLASS_PROTOTYPE);\r\n this.i32ArrayPrototype = this.require(CommonSymbols.Int32Array, ElementKind.CLASS_PROTOTYPE);\r\n this.i64ArrayPrototype = this.require(CommonSymbols.Int64Array, ElementKind.CLASS_PROTOTYPE);\r\n this.u8ArrayPrototype = this.require(CommonSymbols.Uint8Array, ElementKind.CLASS_PROTOTYPE);\r\n this.u8ClampedArrayPrototype = this.require(CommonSymbols.Uint8ClampedArray, ElementKind.CLASS_PROTOTYPE);\r\n this.u16ArrayPrototype = this.require(CommonSymbols.Uint16Array, ElementKind.CLASS_PROTOTYPE);\r\n this.u32ArrayPrototype = this.require(CommonSymbols.Uint32Array, ElementKind.CLASS_PROTOTYPE);\r\n this.u64ArrayPrototype = this.require(CommonSymbols.Uint64Array, ElementKind.CLASS_PROTOTYPE);\r\n this.f32ArrayPrototype = this.require(CommonSymbols.Float32Array, ElementKind.CLASS_PROTOTYPE);\r\n this.f64ArrayPrototype = this.require(CommonSymbols.Float64Array, ElementKind.CLASS_PROTOTYPE);\r\n\r\n // resolve base prototypes of derived classes\r\n var resolver = this.resolver;\r\n for (let i = 0, k = queuedExtends.length; i < k; ++i) {\r\n let thisPrototype = queuedExtends[i];\r\n let extendsNode = assert(thisPrototype.extendsNode); // must be present if in queuedExtends\r\n let baseElement = resolver.resolveTypeName(extendsNode.name, thisPrototype.parent); // reports\r\n if (!baseElement) continue;\r\n if (baseElement.kind == ElementKind.CLASS_PROTOTYPE) {\r\n let basePrototype = baseElement;\r\n if (basePrototype.hasDecorator(DecoratorFlags.SEALED)) {\r\n this.error(\r\n DiagnosticCode.Class_0_is_sealed_and_cannot_be_extended,\r\n extendsNode.range, (baseElement).identifierNode.text\r\n );\r\n }\r\n if (\r\n basePrototype.hasDecorator(DecoratorFlags.UNMANAGED) !=\r\n thisPrototype.hasDecorator(DecoratorFlags.UNMANAGED)\r\n ) {\r\n this.error(\r\n DiagnosticCode.Unmanaged_classes_cannot_extend_managed_classes_and_vice_versa,\r\n Range.join(thisPrototype.identifierNode.range, extendsNode.range)\r\n );\r\n }\r\n thisPrototype.basePrototype = basePrototype;\r\n } else {\r\n this.error(\r\n DiagnosticCode.A_class_may_only_extend_another_class,\r\n extendsNode.range\r\n );\r\n }\r\n }\r\n\r\n // set up global aliases\r\n {\r\n let globalAliases = options.globalAliases;\r\n if (globalAliases) {\r\n for (let [alias, name] of globalAliases) {\r\n if (!name.length) continue; // explicitly disabled\r\n let firstChar = name.charCodeAt(0);\r\n if (firstChar >= CharCode._0 && firstChar <= CharCode._9) {\r\n this.registerConstantInteger(alias, Type.i32, i64_new(parseInt(name, 10)));\r\n } else {\r\n let elementsByName = this.elementsByName;\r\n let element = elementsByName.get(name);\r\n if (element) {\r\n if (elementsByName.has(alias)) throw new Error(\"duplicate global element: \" + name);\r\n elementsByName.set(alias, element);\r\n }\r\n else throw new Error(\"no such global element: \" + name);\r\n }\r\n }\r\n }\r\n }\r\n\r\n // register stdlib components\r\n this.arrayPrototype = this.require(CommonSymbols.Array, ElementKind.CLASS_PROTOTYPE);\r\n this.fixedArrayPrototype = this.require(CommonSymbols.FixedArray, ElementKind.CLASS_PROTOTYPE);\r\n this.setPrototype = this.require(CommonSymbols.Set, ElementKind.CLASS_PROTOTYPE);\r\n this.mapPrototype = this.require(CommonSymbols.Map, ElementKind.CLASS_PROTOTYPE);\r\n this.abortInstance = this.requireFunction(CommonSymbols.abort);\r\n this.allocInstance = this.requireFunction(CommonSymbols.alloc);\r\n this.reallocInstance = this.requireFunction(CommonSymbols.realloc);\r\n this.freeInstance = this.requireFunction(CommonSymbols.free);\r\n this.retainInstance = this.requireFunction(CommonSymbols.retain);\r\n this.releaseInstance = this.requireFunction(CommonSymbols.release);\r\n this.collectInstance = this.requireFunction(CommonSymbols.collect);\r\n this.typeinfoInstance = this.requireFunction(CommonSymbols.typeinfo);\r\n this.instanceofInstance = this.requireFunction(CommonSymbols.instanceof_);\r\n this.visitInstance = this.requireFunction(CommonSymbols.visit);\r\n this.allocArrayInstance = this.requireFunction(CommonSymbols.allocArray);\r\n\r\n // mark module exports, i.e. to apply proper wrapping behavior on the boundaries\r\n for (let file of this.filesByName.values()) {\r\n let exports = file.exports;\r\n if (!(file.source.isEntry && exports)) continue;\r\n for (let element of exports.values()) this.markModuleExport(element);\r\n }\r\n }\r\n\r\n /** Requires that a global library element of the specified kind is present and returns it. */\r\n private require(name: string, kind: ElementKind): Element {\r\n var element = this.lookupGlobal(name);\r\n if (!element) throw new Error(\"missing \" + name);\r\n if (element.kind != kind) throw new Error(\"unexpected \" + name);\r\n return element;\r\n }\r\n\r\n /** Requires that a non-generic global class is present and returns it. */\r\n private requireClass(name: string): Class {\r\n var prototype = this.require(name, ElementKind.CLASS_PROTOTYPE);\r\n var resolved = this.resolver.resolveClass(prototype, null);\r\n if (!resolved) throw new Error(\"invalid \" + name);\r\n return resolved;\r\n }\r\n\r\n /** Requires that a non-generic global function is present and returns it. */\r\n private requireFunction(name: string): Function {\r\n var prototype = this.require(name, ElementKind.FUNCTION_PROTOTYPE);\r\n var resolved = this.resolver.resolveFunction(prototype, null);\r\n if (!resolved) throw new Error(\"invalid \" + name);\r\n return resolved;\r\n }\r\n\r\n /** Marks an element and its children as a module export. */\r\n private markModuleExport(element: Element): void {\r\n element.set(CommonFlags.MODULE_EXPORT);\r\n switch (element.kind) {\r\n case ElementKind.CLASS_PROTOTYPE: {\r\n let instanceMembers = (element).instanceMembers;\r\n if (instanceMembers) for (let member of instanceMembers.values()) this.markModuleExport(member);\r\n break;\r\n }\r\n case ElementKind.PROPERTY_PROTOTYPE: {\r\n let getterPrototype = (element).getterPrototype;\r\n if (getterPrototype) this.markModuleExport(getterPrototype);\r\n let setterPrototype = (element).setterPrototype;\r\n if (setterPrototype) this.markModuleExport(setterPrototype);\r\n break;\r\n }\r\n case ElementKind.PROPERTY:\r\n case ElementKind.FUNCTION:\r\n case ElementKind.FIELD:\r\n case ElementKind.CLASS: assert(false); // assumes that there are no instances yet\r\n }\r\n {\r\n let members = element.members;\r\n if (members) for (let member of members.values()) this.markModuleExport(member);\r\n }\r\n }\r\n\r\n /** Registers a native type with the program. */\r\n private registerNativeType(name: string, type: Type): void {\r\n var element = new TypeDefinition(\r\n name,\r\n this.nativeFile,\r\n this.makeNativeTypeDeclaration(name, CommonFlags.EXPORT),\r\n DecoratorFlags.BUILTIN\r\n );\r\n element.setType(type);\r\n this.nativeFile.add(name, element);\r\n }\r\n\r\n /** Registers the backing class of a native type. */\r\n private registerNativeTypeClass(typeKind: TypeKind, className: string): void {\r\n assert(!this.typeClasses.has(typeKind));\r\n var element = this.lookupGlobal(className);\r\n if (element) {\r\n assert(element.kind == ElementKind.CLASS_PROTOTYPE);\r\n let classElement = this.resolver.resolveClass(element, null);\r\n if (classElement) this.typeClasses.set(typeKind, classElement);\r\n }\r\n }\r\n\r\n /** Registers a constant integer value within the global scope. */\r\n private registerConstantInteger(name: string, type: Type, value: I64): void {\r\n assert(type.is(TypeFlags.INTEGER)); // must be an integer type\r\n var global = new Global(\r\n name,\r\n this.nativeFile,\r\n DecoratorFlags.NONE,\r\n this.makeNativeVariableDeclaration(name, CommonFlags.CONST | CommonFlags.EXPORT)\r\n );\r\n global.setConstantIntegerValue(value, type);\r\n this.nativeFile.add(name, global);\r\n }\r\n\r\n /** Registers a constant float value within the global scope. */\r\n private registerConstantFloat(name: string, type: Type, value: f64): void {\r\n assert(type.is(TypeFlags.FLOAT)); // must be a float type\r\n var global = new Global(\r\n name,\r\n this.nativeFile,\r\n DecoratorFlags.NONE,\r\n this.makeNativeVariableDeclaration(name, CommonFlags.CONST | CommonFlags.EXPORT)\r\n );\r\n global.setConstantFloatValue(value, type);\r\n this.nativeFile.add(name, global);\r\n }\r\n\r\n /** Ensures that the given global element exists. Attempts to merge duplicates. */\r\n ensureGlobal(name: string, element: DeclaredElement): DeclaredElement {\r\n var elementsByName = this.elementsByName;\r\n if (elementsByName.has(name)) {\r\n let actual = elementsByName.get(name)!;\r\n // NOTE: this is effectively only performed when merging native types with\r\n // their respective namespaces in std/builtins, but can also trigger when a\r\n // user has multiple global elements of the same name in different files,\r\n // which might result in unexpected shared symbols accross files. considering\r\n // this a wonky feature for now that we might want to revisit later.\r\n if (actual !== element) {\r\n let merged = tryMerge(elementsByName.get(name)!, element);\r\n if (!merged) {\r\n this.error(\r\n DiagnosticCode.Duplicate_identifier_0,\r\n element.identifierNode.range, name\r\n );\r\n return element;\r\n }\r\n element = merged;\r\n }\r\n }\r\n elementsByName.set(name, element);\r\n return element;\r\n }\r\n\r\n /** Looks up the element of the specified name in the global scope. */\r\n lookupGlobal(name: string): Element | null {\r\n var elements = this.elementsByName;\r\n if (elements.has(name)) return elements.get(name);\r\n return null;\r\n }\r\n\r\n /** Looks up the element of the specified name in the global scope. Errors if not present. */\r\n requireGlobal(name: string): Element {\r\n var elements = this.elementsByName;\r\n if (elements.has(name)) return elements.get(name)!;\r\n throw new Error(\"missing global\");\r\n }\r\n\r\n /** Tries to locate a foreign file given its normalized path. */\r\n private lookupForeignFile(\r\n /** Normalized path to the other file. */\r\n foreignPath: string,\r\n /** Alternative normalized path to the other file. */\r\n foreignPathAlt: string\r\n ): File | null {\r\n var filesByName = this.filesByName;\r\n return filesByName.has(foreignPath)\r\n ? filesByName.get(foreignPath)!\r\n : filesByName.has(foreignPathAlt)\r\n ? filesByName.get(foreignPathAlt)!\r\n : null;\r\n }\r\n\r\n /** Tries to locate a foreign element by traversing exports and queued exports. */\r\n private lookupForeign(\r\n /** Identifier within the other file. */\r\n foreignName: string,\r\n /** Normalized path to the other file. */\r\n foreignPath: string,\r\n /** Alternative normalized path to the other file. */\r\n foreignPathAlt: string,\r\n /** So far queued exports. */\r\n queuedExports: Map>\r\n ): DeclaredElement | null {\r\n do {\r\n let foreignFile = this.lookupForeignFile(foreignPath, foreignPathAlt);\r\n if (!foreignFile) return null; // no such file\r\n\r\n // search already resolved exports\r\n let element = foreignFile.lookupExport(foreignName);\r\n if (element) return element;\r\n\r\n // otherwise traverse queued exports\r\n if (queuedExports.has(foreignFile)) {\r\n let fileQueuedExports = queuedExports.get(foreignFile)!;\r\n if (fileQueuedExports.has(foreignName)) {\r\n let queuedExport = fileQueuedExports.get(foreignName)!;\r\n if (queuedExport.foreignPath) { // imported from another file\r\n foreignName = queuedExport.localIdentifier.text;\r\n foreignPath = queuedExport.foreignPath;\r\n foreignPathAlt = assert(queuedExport.foreignPathAlt);\r\n continue;\r\n } else { // local element of this file\r\n element = foreignFile.lookupInSelf(queuedExport.localIdentifier.text);\r\n if (element) return element;\r\n }\r\n }\r\n }\r\n break;\r\n } while (true);\r\n return null;\r\n }\r\n\r\n /** Validates that only supported decorators are present. */\r\n private checkDecorators(\r\n /** Decorators present on an element. */\r\n decorators: DecoratorNode[] | null,\r\n /** Accepted decorator flags. Emits diagnostics if any other decorators are present. */\r\n acceptedFlags: DecoratorFlags\r\n ): DecoratorFlags {\r\n var flags = DecoratorFlags.NONE;\r\n if (decorators) {\r\n for (let i = 0, k = decorators.length; i < k; ++i) {\r\n let decorator = decorators[i];\r\n let kind = decoratorNameToKind(decorator.name);\r\n let flag = decoratorKindToFlag(kind);\r\n if (flag) {\r\n if (flag == DecoratorFlags.BUILTIN) {\r\n if (!(acceptedFlags & flag) && !decorator.range.source.isLibrary) {\r\n this.error(\r\n DiagnosticCode.Decorator_0_is_not_valid_here,\r\n decorator.range, decorator.name.range.toString()\r\n );\r\n } else {\r\n flags |= flag;\r\n }\r\n } else if (!(acceptedFlags & flag)) {\r\n this.error(\r\n DiagnosticCode.Decorator_0_is_not_valid_here,\r\n decorator.range, decorator.name.range.toString()\r\n );\r\n } else if (flags & flag) {\r\n this.error(\r\n DiagnosticCode.Duplicate_decorator,\r\n decorator.range, decorator.name.range.toString()\r\n );\r\n } else {\r\n flags |= flag;\r\n }\r\n }\r\n }\r\n }\r\n return flags;\r\n }\r\n\r\n /** Initializes a class declaration. */\r\n private initializeClass(\r\n /** The declaration to initialize. */\r\n declaration: ClassDeclaration,\r\n /** Parent element, usually a file or namespace. */\r\n parent: Element,\r\n /** So far queued `extends` clauses. */\r\n queuedExtends: ClassPrototype[],\r\n /** So far queued `implements` clauses. */\r\n queuedImplements: ClassPrototype[]\r\n ): ClassPrototype | null {\r\n var name = declaration.name.text;\r\n var element = new ClassPrototype(\r\n name,\r\n parent,\r\n declaration,\r\n this.checkDecorators(declaration.decorators,\r\n DecoratorFlags.GLOBAL |\r\n DecoratorFlags.SEALED |\r\n DecoratorFlags.UNMANAGED\r\n )\r\n );\r\n if (!parent.add(name, element)) return null;\r\n\r\n var implementsTypes = declaration.implementsTypes;\r\n if (implementsTypes) {\r\n let numImplementsTypes = implementsTypes.length;\r\n // cannot implement interfaces when unmanaged\r\n if (element.hasDecorator(DecoratorFlags.UNMANAGED)) {\r\n if (numImplementsTypes) {\r\n this.error(\r\n DiagnosticCode.Unmanaged_classes_cannot_implement_interfaces,\r\n Range.join(\r\n declaration.name.range,\r\n implementsTypes[numImplementsTypes - 1].range\r\n )\r\n );\r\n }\r\n } else if (numImplementsTypes) {\r\n // remember classes that implement interfaces\r\n for (let i = 0; i < numImplementsTypes; ++i) {\r\n this.warning( // TODO: not yet supported\r\n DiagnosticCode.Operation_not_supported,\r\n implementsTypes[i].range\r\n );\r\n }\r\n queuedImplements.push(element);\r\n }\r\n }\r\n // remember classes that extend another class\r\n if (declaration.extendsType) queuedExtends.push(element);\r\n\r\n // initialize members\r\n var memberDeclarations = declaration.members;\r\n for (let i = 0, k = memberDeclarations.length; i < k; ++i) {\r\n let memberDeclaration = memberDeclarations[i];\r\n switch (memberDeclaration.kind) {\r\n case NodeKind.FIELDDECLARATION: {\r\n this.initializeField(memberDeclaration, element);\r\n break;\r\n }\r\n case NodeKind.METHODDECLARATION: {\r\n if (memberDeclaration.isAny(CommonFlags.GET | CommonFlags.SET)) {\r\n this.initializeProperty(memberDeclaration, element);\r\n } else {\r\n this.initializeMethod(memberDeclaration, element);\r\n }\r\n break;\r\n }\r\n case NodeKind.INDEXSIGNATUREDECLARATION: break; // ignored for now\r\n default: assert(false); // class member expected\r\n }\r\n }\r\n return element;\r\n }\r\n\r\n /** Initializes a field of a class or interface. */\r\n private initializeField(\r\n /** The declaration to initialize. */\r\n declaration: FieldDeclaration,\r\n /** Parent class. */\r\n parent: ClassPrototype\r\n ): void {\r\n var name = declaration.name.text;\r\n var decorators = declaration.decorators;\r\n var element: DeclaredElement;\r\n if (declaration.is(CommonFlags.STATIC)) { // global variable\r\n assert(parent.kind != ElementKind.INTERFACE_PROTOTYPE);\r\n element = new Global(\r\n name,\r\n parent,\r\n this.checkDecorators(decorators,\r\n (declaration.is(CommonFlags.READONLY)\r\n ? DecoratorFlags.INLINE\r\n : DecoratorFlags.NONE\r\n ) | DecoratorFlags.LAZY | DecoratorFlags.UNSAFE\r\n ),\r\n declaration\r\n );\r\n if (!parent.add(name, element)) return;\r\n } else { // actual instance field\r\n assert(!declaration.isAny(CommonFlags.ABSTRACT | CommonFlags.GET | CommonFlags.SET));\r\n element = new FieldPrototype(\r\n name,\r\n parent,\r\n declaration,\r\n this.checkDecorators(decorators, DecoratorFlags.UNSAFE)\r\n );\r\n if (!parent.addInstance(name, element)) return;\r\n }\r\n }\r\n\r\n /** Initializes a method of a class or interface. */\r\n private initializeMethod(\r\n /** The declaration to initialize. */\r\n declaration: MethodDeclaration,\r\n /** Parent class. */\r\n parent: ClassPrototype\r\n ): void {\r\n var name = declaration.name.text;\r\n var isStatic = declaration.is(CommonFlags.STATIC);\r\n var acceptedFlags = DecoratorFlags.INLINE | DecoratorFlags.UNSAFE;\r\n if (!declaration.is(CommonFlags.GENERIC)) {\r\n acceptedFlags |= DecoratorFlags.OPERATOR_BINARY\r\n | DecoratorFlags.OPERATOR_PREFIX\r\n | DecoratorFlags.OPERATOR_POSTFIX;\r\n }\r\n var element = new FunctionPrototype(\r\n name,\r\n parent,\r\n declaration,\r\n this.checkDecorators(declaration.decorators, acceptedFlags)\r\n );\r\n if (isStatic) { // global function\r\n assert(declaration.name.kind != NodeKind.CONSTRUCTOR);\r\n if (!parent.add(name, element)) return;\r\n } else { // actual instance method\r\n if (!parent.addInstance(name, element)) return;\r\n }\r\n this.checkOperatorOverloads(declaration.decorators, element, parent);\r\n }\r\n\r\n /** Checks that operator overloads are generally valid, if present. */\r\n private checkOperatorOverloads(\r\n /** Decorators to check. */\r\n decorators: DecoratorNode[] | null,\r\n /** Decorated method. */\r\n prototype: FunctionPrototype,\r\n /** Parent class. */\r\n classPrototype: ClassPrototype\r\n ): void {\r\n if (decorators) {\r\n for (let i = 0, k = decorators.length; i < k; ++i) {\r\n let decorator = decorators[i];\r\n switch (decorator.decoratorKind) {\r\n case DecoratorKind.OPERATOR:\r\n case DecoratorKind.OPERATOR_BINARY:\r\n case DecoratorKind.OPERATOR_PREFIX:\r\n case DecoratorKind.OPERATOR_POSTFIX: {\r\n let numArgs = decorator.arguments && decorator.arguments.length || 0;\r\n if (numArgs == 1) {\r\n let firstArg = (decorator.arguments)[0];\r\n if (\r\n firstArg.kind == NodeKind.LITERAL &&\r\n (firstArg).literalKind == LiteralKind.STRING\r\n ) {\r\n let kind = operatorKindFromDecorator(\r\n decorator.decoratorKind,\r\n (firstArg).value\r\n );\r\n if (kind == OperatorKind.INVALID) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n firstArg.range\r\n );\r\n } else {\r\n let overloads = classPrototype.overloadPrototypes;\r\n if (overloads.has(kind)) {\r\n this.error(\r\n DiagnosticCode.Duplicate_function_implementation,\r\n firstArg.range\r\n );\r\n } else {\r\n prototype.operatorKind = kind;\r\n overloads.set(kind, prototype);\r\n }\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode.String_literal_expected,\r\n firstArg.range\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode.Expected_0_arguments_but_got_1,\r\n decorator.range, \"1\", numArgs.toString(10)\r\n );\r\n }\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n /** Ensures that the property introduced by the specified getter or setter exists.*/\r\n private ensureProperty(\r\n /** The declaration of the getter or setter introducing the property. */\r\n declaration: MethodDeclaration,\r\n /** Parent class. */\r\n parent: ClassPrototype\r\n ): PropertyPrototype | null {\r\n var name = declaration.name.text;\r\n if (declaration.is(CommonFlags.STATIC)) {\r\n let parentMembers = parent.members;\r\n if (parentMembers && parentMembers.has(name)) {\r\n let element = parentMembers.get(name)!;\r\n if (element.kind == ElementKind.PROPERTY_PROTOTYPE) return element;\r\n } else {\r\n let element = new PropertyPrototype(name, parent, declaration);\r\n if (!parent.add(name, element)) return null;\r\n return element;\r\n }\r\n } else {\r\n let parentMembers = parent.instanceMembers;\r\n if (parentMembers && parentMembers.has(name)) {\r\n let element = parentMembers.get(name);\r\n if (element.kind == ElementKind.PROPERTY_PROTOTYPE) return element;\r\n } else {\r\n let element = new PropertyPrototype(name, parent, declaration);\r\n if (!parent.addInstance(name, element)) return null;\r\n return element;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Duplicate_property_0,\r\n declaration.name.range, name\r\n );\r\n return null;\r\n }\r\n\r\n /** Initializes a property of a class. */\r\n private initializeProperty(\r\n /** The declaration of the getter or setter. */\r\n declaration: MethodDeclaration,\r\n /** Parent class. */\r\n parent: ClassPrototype\r\n ): void {\r\n var property = this.ensureProperty(declaration, parent);\r\n if (!property) return;\r\n var name = declaration.name.text;\r\n var isGetter = declaration.is(CommonFlags.GET);\r\n if (isGetter) {\r\n if (property.getterPrototype) {\r\n this.error(\r\n DiagnosticCode.Duplicate_property_0,\r\n declaration.name.range, name\r\n );\r\n return;\r\n }\r\n } else {\r\n if (property.setterPrototype) {\r\n this.error(\r\n DiagnosticCode.Duplicate_property_0,\r\n declaration.name.range, name\r\n );\r\n return;\r\n }\r\n }\r\n var element = new FunctionPrototype(\r\n (isGetter ? GETTER_PREFIX : SETTER_PREFIX) + name,\r\n property,\r\n declaration,\r\n this.checkDecorators(declaration.decorators,\r\n DecoratorFlags.INLINE | DecoratorFlags.UNSAFE\r\n )\r\n );\r\n if (isGetter) {\r\n property.getterPrototype = element;\r\n } else {\r\n property.setterPrototype = element;\r\n }\r\n }\r\n\r\n /** Initializes an enum. */\r\n private initializeEnum(\r\n /** The declaration to initialize. */\r\n declaration: EnumDeclaration,\r\n /** Parent element, usually a file or namespace. */\r\n parent: Element\r\n ): Enum | null {\r\n var name = declaration.name.text;\r\n var element = new Enum(\r\n name,\r\n parent,\r\n declaration,\r\n this.checkDecorators(declaration.decorators,\r\n DecoratorFlags.GLOBAL |\r\n DecoratorFlags.INLINE |\r\n DecoratorFlags.LAZY\r\n )\r\n );\r\n if (!parent.add(name, element)) return null;\r\n var values = declaration.values;\r\n for (let i = 0, k = values.length; i < k; ++i) {\r\n this.initializeEnumValue(values[i], element);\r\n }\r\n return element;\r\n }\r\n\r\n /** Initializes an enum value. */\r\n private initializeEnumValue(\r\n /** The declaration to initialize. */\r\n declaration: EnumValueDeclaration,\r\n /** Parent enum. */\r\n parent: Enum\r\n ): void {\r\n var name = declaration.name.text;\r\n var element = new EnumValue(\r\n name,\r\n parent,\r\n declaration,\r\n this.checkDecorators(declaration.decorators,\r\n DecoratorFlags.NONE\r\n )\r\n );\r\n if (!parent.add(name, element)) return;\r\n }\r\n\r\n /** Initializes an `export` statement. */\r\n private initializeExports(\r\n /** The statement to initialize. */\r\n statement: ExportStatement,\r\n /** Parent file. */\r\n parent: File,\r\n /** So far queued `export`s. */\r\n queuedExports: Map>,\r\n /** So far queued `export *`s. */\r\n queuedExportsStar: Map\r\n ): void {\r\n var members = statement.members;\r\n if (members) { // export { foo, bar } [from \"./baz\"]\r\n for (let i = 0, k = members.length; i < k; ++i) {\r\n this.initializeExport(members[i], parent, statement.internalPath, queuedExports);\r\n }\r\n } else { // export * from \"./baz\"\r\n let queued: QueuedExportStar[];\r\n if (queuedExportsStar.has(parent)) queued = queuedExportsStar.get(parent)!;\r\n else queuedExportsStar.set(parent, queued = []);\r\n let foreignPath = assert(statement.internalPath); // must be set for export *\r\n queued.push(new QueuedExportStar(\r\n foreignPath,\r\n foreignPath.endsWith(INDEX_SUFFIX) // strip or add index depending on what's already present\r\n ? foreignPath.substring(0, foreignPath.length - INDEX_SUFFIX.length)\r\n : foreignPath + INDEX_SUFFIX,\r\n assert(statement.path)\r\n ));\r\n }\r\n }\r\n\r\n /** Initializes a single `export` member. Does not handle `export *`. */\r\n private initializeExport(\r\n /** The member to initialize. */\r\n member: ExportMember,\r\n /** Local file. */\r\n localFile: File,\r\n /** Path to the other file, if present. */\r\n foreignPath: string | null,\r\n /** So far queued `export`s. */\r\n queuedExports: Map>\r\n ): void {\r\n var localName = member.localName.text;\r\n var foreignName = member.exportedName.text;\r\n\r\n // check for duplicates\r\n var element = localFile.lookupExport(foreignName);\r\n if (element) {\r\n this.error(\r\n DiagnosticCode.Export_declaration_conflicts_with_exported_declaration_of_0,\r\n member.exportedName.range, foreignName\r\n );\r\n return;\r\n }\r\n // local element, i.e. export { foo [as bar] }\r\n if (foreignPath === null) {\r\n\r\n // resolve right away if the local element already exists\r\n if (element = localFile.lookupInSelf(localName)) {\r\n localFile.ensureExport(foreignName, element);\r\n\r\n // otherwise queue it\r\n } else {\r\n let queued: Map;\r\n if (queuedExports.has(localFile)) queued = queuedExports.get(localFile)!;\r\n else queuedExports.set(localFile, queued = new Map());\r\n queued.set(foreignName, new QueuedExport(\r\n member.localName,\r\n member.exportedName,\r\n null, null\r\n ));\r\n }\r\n\r\n // foreign element, i.e. export { foo } from \"./bar\"\r\n } else {\r\n let queued: Map;\r\n if (queuedExports.has(localFile)) queued = queuedExports.get(localFile)!;\r\n else queuedExports.set(localFile, queued = new Map());\r\n queued.set(foreignName, new QueuedExport(\r\n member.localName,\r\n member.exportedName,\r\n foreignPath,\r\n foreignPath.endsWith(INDEX_SUFFIX) // strip or add index depending on what's already present\r\n ? foreignPath.substring(0, foreignPath.length - INDEX_SUFFIX.length)\r\n : foreignPath + INDEX_SUFFIX\r\n ));\r\n }\r\n }\r\n\r\n private initializeExportDefault(\r\n /** The statement to initialize. */\r\n statement: ExportDefaultStatement,\r\n /** Parent file. */\r\n parent: File,\r\n /** So far queued `extends` clauses. */\r\n queuedExtends: Array,\r\n /** So far queued `implements` clauses. */\r\n queuedImplements: ClassPrototype[]\r\n ): void {\r\n var declaration = statement.declaration;\r\n var element: DeclaredElement | null = null;\r\n switch (declaration.kind) {\r\n case NodeKind.ENUMDECLARATION: {\r\n element = this.initializeEnum(declaration, parent);\r\n break;\r\n }\r\n case NodeKind.FUNCTIONDECLARATION: {\r\n element = this.initializeFunction(declaration, parent);\r\n break;\r\n }\r\n case NodeKind.CLASSDECLARATION: {\r\n element = this.initializeClass(declaration, parent, queuedExtends, queuedImplements);\r\n break;\r\n }\r\n case NodeKind.INTERFACEDECLARATION: {\r\n element = this.initializeInterface(declaration, parent);\r\n break;\r\n }\r\n case NodeKind.NAMESPACEDECLARATION: {\r\n element = this.initializeNamespace(declaration, parent, queuedExtends, queuedImplements);\r\n break;\r\n }\r\n default: assert(false);\r\n }\r\n if (element) {\r\n let exports = parent.exports;\r\n if (!exports) parent.exports = exports = new Map();\r\n else if (exports.has(\"default\")) {\r\n this.error(\r\n DiagnosticCode.Duplicate_identifier_0,\r\n declaration.name.range, \"default\"\r\n );\r\n return;\r\n }\r\n exports.set(\"default\", element);\r\n }\r\n }\r\n\r\n /** Initializes an `import` statement. */\r\n private initializeImports(\r\n /** The statement to initialize. */\r\n statement: ImportStatement,\r\n /** Parent file. */\r\n parent: File,\r\n /** So far queued `import`s. */\r\n queuedImports: QueuedImport[],\r\n /** So far queued `export`s. */\r\n queuedExports: Map>\r\n ): void {\r\n var declarations = statement.declarations;\r\n if (declarations) { // import { foo [as bar] } from \"./baz\"\r\n for (let i = 0, k = declarations.length; i < k; ++i) {\r\n this.initializeImport(\r\n declarations[i],\r\n parent,\r\n statement.internalPath,\r\n queuedImports,\r\n queuedExports\r\n );\r\n }\r\n } else if (statement.namespaceName) { // import * as foo from \"./bar\"\r\n queuedImports.push(new QueuedImport(\r\n parent,\r\n statement.namespaceName,\r\n null, // indicates import *\r\n statement.internalPath,\r\n statement.internalPath + INDEX_SUFFIX\r\n ));\r\n } else {\r\n // import \"./foo\"\r\n }\r\n }\r\n\r\n /** Initializes a single `import` declaration. Does not handle `import *`. */\r\n private initializeImport( // { foo [as bar] }\r\n /** The declaration to initialize. */\r\n declaration: ImportDeclaration,\r\n /** Parent file. */\r\n parent: File,\r\n /** Path to the other file. */\r\n foreignPath: string,\r\n /** So far queued `import`s. */\r\n queuedImports: QueuedImport[],\r\n /** So far queued `export`s. */\r\n queuedExports: Map>\r\n ): void {\r\n var foreignPathAlt = foreignPath.endsWith(INDEX_SUFFIX) // strip or add index depending on what's already present\r\n ? foreignPath.substring(0, foreignPath.length - INDEX_SUFFIX.length)\r\n : foreignPath + INDEX_SUFFIX;\r\n\r\n // resolve right away if the element exists\r\n var element = this.lookupForeign(declaration.foreignName.text, foreignPath, foreignPathAlt, queuedExports);\r\n if (element) {\r\n parent.add(declaration.name.text, element, true);\r\n return;\r\n }\r\n\r\n // otherwise queue it\r\n queuedImports.push(new QueuedImport(\r\n parent,\r\n declaration.name,\r\n declaration.foreignName,\r\n foreignPath,\r\n foreignPathAlt\r\n ));\r\n }\r\n\r\n /** Initializes a function. Does not handle methods. */\r\n private initializeFunction(\r\n /** The declaration to initialize. */\r\n declaration: FunctionDeclaration,\r\n /** Parent element, usually a file or namespace. */\r\n parent: Element\r\n ): FunctionPrototype | null {\r\n var name = declaration.name.text;\r\n var validDecorators = DecoratorFlags.UNSAFE | DecoratorFlags.BUILTIN;\r\n if (declaration.is(CommonFlags.AMBIENT)) {\r\n validDecorators |= DecoratorFlags.EXTERNAL;\r\n } else {\r\n validDecorators |= DecoratorFlags.INLINE;\r\n }\r\n if (!declaration.is(CommonFlags.INSTANCE)) {\r\n if (parent.kind != ElementKind.CLASS_PROTOTYPE) {\r\n validDecorators |= DecoratorFlags.GLOBAL;\r\n }\r\n }\r\n var element = new FunctionPrototype(\r\n name,\r\n parent,\r\n declaration,\r\n this.checkDecorators(declaration.decorators, validDecorators)\r\n );\r\n if (!parent.add(name, element)) return null;\r\n return element;\r\n }\r\n\r\n /** Initializes an interface. */\r\n private initializeInterface(\r\n /** The declaration to initialize. */\r\n declaration: InterfaceDeclaration,\r\n /** Parent element, usually a file or namespace. */\r\n parent: Element\r\n ): InterfacePrototype | null {\r\n var name = declaration.name.text;\r\n var element = new InterfacePrototype(\r\n name,\r\n parent,\r\n declaration,\r\n this.checkDecorators(declaration.decorators,\r\n DecoratorFlags.GLOBAL\r\n )\r\n );\r\n if (!parent.add(name, element)) return null;\r\n var memberDeclarations = declaration.members;\r\n for (let i = 0, k = memberDeclarations.length; i < k; ++i) {\r\n let memberDeclaration = memberDeclarations[i];\r\n switch (memberDeclaration.kind) {\r\n case NodeKind.FIELDDECLARATION: {\r\n this.initializeField(memberDeclaration, element);\r\n break;\r\n }\r\n case NodeKind.METHODDECLARATION: {\r\n if (memberDeclaration.isAny(CommonFlags.GET | CommonFlags.SET)) {\r\n this.initializeProperty(memberDeclaration, element);\r\n } else {\r\n this.initializeMethod(memberDeclaration, element);\r\n }\r\n break;\r\n }\r\n default: assert(false); // interface member expected\r\n }\r\n }\r\n return element;\r\n }\r\n\r\n /** Initializes a namespace. */\r\n private initializeNamespace(\r\n /** The declaration to initialize. */\r\n declaration: NamespaceDeclaration,\r\n /** Parent element, usually a file or another namespace. */\r\n parent: Element,\r\n /** So far queued `extends` clauses. */\r\n queuedExtends: ClassPrototype[],\r\n /** So far queued `implements` clauses. */\r\n queuedImplements: ClassPrototype[]\r\n ): Namespace | null {\r\n var name = declaration.name.text;\r\n var original = new Namespace(\r\n name,\r\n parent,\r\n declaration,\r\n this.checkDecorators(declaration.decorators, DecoratorFlags.GLOBAL)\r\n );\r\n if (!parent.add(name, original)) return null;\r\n var element = assert(parent.lookupInSelf(name)); // possibly merged\r\n var members = declaration.members;\r\n for (let i = 0, k = members.length; i < k; ++i) {\r\n let member = members[i];\r\n switch (member.kind) {\r\n case NodeKind.CLASSDECLARATION: {\r\n this.initializeClass(member, original, queuedExtends, queuedImplements);\r\n break;\r\n }\r\n case NodeKind.ENUMDECLARATION: {\r\n this.initializeEnum(member, original);\r\n break;\r\n }\r\n case NodeKind.FUNCTIONDECLARATION: {\r\n this.initializeFunction(member, original);\r\n break;\r\n }\r\n case NodeKind.INTERFACEDECLARATION: {\r\n this.initializeInterface(member, original);\r\n break;\r\n }\r\n case NodeKind.NAMESPACEDECLARATION: {\r\n this.initializeNamespace(member, original, queuedExtends, queuedImplements);\r\n break;\r\n }\r\n case NodeKind.TYPEDECLARATION: {\r\n this.initializeTypeDefinition(member, original);\r\n break;\r\n }\r\n case NodeKind.VARIABLE: {\r\n this.initializeVariables(member, original);\r\n break;\r\n }\r\n default: assert(false); // namespace member expected\r\n }\r\n }\r\n if (original != element) copyMembers(original, element); // retain original parent\r\n return element;\r\n }\r\n\r\n /** Initializes a `type` definition. */\r\n private initializeTypeDefinition(\r\n /** The declaration to initialize. */\r\n declaration: TypeDeclaration,\r\n /** Parent element, usually a file or namespace. */\r\n parent: Element\r\n ): void {\r\n var name = declaration.name.text;\r\n var element = new TypeDefinition(\r\n name,\r\n parent,\r\n declaration,\r\n this.checkDecorators(declaration.decorators, DecoratorFlags.NONE)\r\n );\r\n parent.add(name, element); // reports\r\n }\r\n\r\n /** Initializes a variable statement. */\r\n private initializeVariables(\r\n /** The statement to initialize. */\r\n statement: VariableStatement,\r\n /** Parent element, usually a file or namespace. */\r\n parent: Element\r\n ): void {\r\n var declarations = statement.declarations;\r\n for (let i = 0, k = declarations.length; i < k; ++i) {\r\n let declaration = declarations[i];\r\n let name = declaration.name.text;\r\n let acceptedFlags = DecoratorFlags.GLOBAL | DecoratorFlags.LAZY;\r\n if (declaration.is(CommonFlags.DECLARE)) {\r\n acceptedFlags |= DecoratorFlags.EXTERNAL;\r\n }\r\n if (declaration.is(CommonFlags.CONST)) {\r\n acceptedFlags |= DecoratorFlags.INLINE;\r\n }\r\n let element = new Global(\r\n name,\r\n parent,\r\n this.checkDecorators(declaration.decorators, acceptedFlags),\r\n declaration\r\n );\r\n if (!parent.add(name, element)) continue; // reports\r\n }\r\n }\r\n\r\n /** Determines the element type of a built-in array. */\r\n // determineBuiltinArrayType(target: Class): Type | null {\r\n // switch (target.internalName) {\r\n // case BuiltinSymbols.Int8Array: return Type.i8;\r\n // case BuiltinSymbols.Uint8ClampedArray:\r\n // case BuiltinSymbols.Uint8Array: return Type.u8;\r\n // case BuiltinSymbols.Int16Array: return Type.i16;\r\n // case BuiltinSymbols.Uint16Array: return Type.u16;\r\n // case BuiltinSymbols.Int32Array: return Type.i32;\r\n // case BuiltinSymbols.Uint32Array: return Type.u32;\r\n // case BuiltinSymbols.Int64Array: return Type.i64;\r\n // case BuiltinSymbols.Uint64Array: return Type.u64;\r\n // case BuiltinSymbols.Float32Array: return Type.f32;\r\n // case BuiltinSymbols.Float64Array: return Type.f64;\r\n // }\r\n // var current: Class | null = target;\r\n // var arrayPrototype = this.arrayPrototype;\r\n // do {\r\n // if (current.prototype == arrayPrototype) { // Array\r\n // let typeArguments = assert(current.typeArguments);\r\n // assert(typeArguments.length == 1);\r\n // return typeArguments[0];\r\n // }\r\n // } while (current = current.base);\r\n // return null;\r\n // }\r\n}\r\n\r\n/** Indicates the specific kind of an {@link Element}. */\r\nexport enum ElementKind {\r\n /** A {@link Global}. */\r\n GLOBAL,\r\n /** A {@link Local}. */\r\n LOCAL,\r\n /** An {@link Enum}. */\r\n ENUM,\r\n /** An {@link EnumValue}. */\r\n ENUMVALUE,\r\n /** A {@link FunctionPrototype}. */\r\n FUNCTION_PROTOTYPE,\r\n /** A {@link Function}. */\r\n FUNCTION,\r\n /** A {@link FunctionTarget}. */\r\n FUNCTION_TARGET,\r\n /** A {@link ClassPrototype}. */\r\n CLASS_PROTOTYPE,\r\n /** A {@link Class}. */\r\n CLASS,\r\n /** An {@link InterfacePrototype}. */\r\n INTERFACE_PROTOTYPE,\r\n /** An {@link Interface}. */\r\n INTERFACE,\r\n /** A {@link FieldPrototype}. */\r\n FIELD_PROTOTYPE,\r\n /** A {@link Field}. */\r\n FIELD,\r\n /** A {@link PropertyPrototype}. */\r\n PROPERTY_PROTOTYPE,\r\n /** A {@link Property}. */\r\n PROPERTY,\r\n /** A {@link Namespace}. */\r\n NAMESPACE,\r\n /** A {@link File}. */\r\n FILE,\r\n /** A {@link TypeDefinition}. */\r\n TYPEDEFINITION,\r\n}\r\n\r\n/** Indicates built-in decorators that are present. */\r\nexport enum DecoratorFlags {\r\n /** No flags set. */\r\n NONE = 0,\r\n /** Is a program global. */\r\n GLOBAL = 1 << 0,\r\n /** Is a binary operator overload. */\r\n OPERATOR_BINARY = 1 << 1,\r\n /** Is a unary prefix operator overload. */\r\n OPERATOR_PREFIX = 1 << 2,\r\n /** Is a unary postfix operator overload. */\r\n OPERATOR_POSTFIX = 1 << 3,\r\n /** Is an unmanaged class. */\r\n UNMANAGED = 1 << 4,\r\n /** Is a sealed class. */\r\n SEALED = 1 << 5,\r\n /** Is always inlined. */\r\n INLINE = 1 << 6,\r\n /** Is using a different external name. */\r\n EXTERNAL = 1 << 7,\r\n /** Is a builtin. */\r\n BUILTIN = 1 << 8,\r\n /** Is compiled lazily. */\r\n LAZY = 1 << 9,\r\n /** Is considered unsafe code. */\r\n UNSAFE = 1 << 10\r\n}\r\n\r\n/** Translates a decorator kind to the respective decorator flag. */\r\nexport function decoratorKindToFlag(kind: DecoratorKind): DecoratorFlags {\r\n switch (kind) {\r\n case DecoratorKind.GLOBAL: return DecoratorFlags.GLOBAL;\r\n case DecoratorKind.OPERATOR:\r\n case DecoratorKind.OPERATOR_BINARY: return DecoratorFlags.OPERATOR_BINARY;\r\n case DecoratorKind.OPERATOR_PREFIX: return DecoratorFlags.OPERATOR_PREFIX;\r\n case DecoratorKind.OPERATOR_POSTFIX: return DecoratorFlags.OPERATOR_POSTFIX;\r\n case DecoratorKind.UNMANAGED: return DecoratorFlags.UNMANAGED;\r\n case DecoratorKind.SEALED: return DecoratorFlags.SEALED;\r\n case DecoratorKind.INLINE: return DecoratorFlags.INLINE;\r\n case DecoratorKind.EXTERNAL: return DecoratorFlags.EXTERNAL;\r\n case DecoratorKind.BUILTIN: return DecoratorFlags.BUILTIN;\r\n case DecoratorKind.LAZY: return DecoratorFlags.LAZY;\r\n case DecoratorKind.UNSAFE: return DecoratorFlags.UNSAFE;\r\n default: return DecoratorFlags.NONE;\r\n }\r\n}\r\n\r\n/** Base class of all program elements. */\r\nexport abstract class Element {\r\n\r\n /** Parent element. */\r\n parent: Element;\r\n /** Common flags indicating specific traits. */\r\n flags: CommonFlags = CommonFlags.NONE;\r\n /** Decorator flags indicating annotated traits. */\r\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE;\r\n /** Member elements. */\r\n members: Map | null = null;\r\n /** Shadowing type in type space, if any. */\r\n shadowType: TypeDefinition | null = null;\r\n\r\n /** Constructs a new program element. */\r\n protected constructor(\r\n /** Specific element kind. */\r\n public kind: ElementKind,\r\n /** Simple name. */\r\n public name: string,\r\n /** Internal name referring to this element. */\r\n public internalName: string,\r\n /** Containing {@link Program}. */\r\n public program: Program,\r\n /** Parent element. */\r\n parent: Element | null\r\n ) {\r\n this.program = program;\r\n this.name = name;\r\n this.internalName = internalName;\r\n if (parent) {\r\n this.parent = parent;\r\n } else {\r\n assert(this.kind == ElementKind.FILE);\r\n this.parent = this; // special case to keep this.parent non-nullable\r\n }\r\n }\r\n\r\n /** Gets the enclosing file. */\r\n get file(): File {\r\n var current: Element = this;\r\n do if ((current = current.parent).kind == ElementKind.FILE) return current;\r\n while (true);\r\n }\r\n\r\n /** Tests if this element has a specific flag or flags. */\r\n is(flag: CommonFlags): bool { return (this.flags & flag) == flag; }\r\n /** Tests if this element has any of the specified flags. */\r\n isAny(flags: CommonFlags): bool { return (this.flags & flags) != 0; }\r\n /** Sets a specific flag or flags. */\r\n set(flag: CommonFlags): void { this.flags |= flag; }\r\n /** Unsets the specific flag or flags. */\r\n unset(flag: CommonFlags): void {this.flags &= ~flag; }\r\n /** Tests if this element has a specific decorator flag or flags. */\r\n hasDecorator(flag: DecoratorFlags): bool { return (this.decoratorFlags & flag) == flag; }\r\n\r\n /** Looks up the element with the specified name within this element. */\r\n lookupInSelf(name: string): DeclaredElement | null {\r\n var members = this.members;\r\n if (members && members.has(name)) return members.get(name)!;\r\n return null;\r\n }\r\n\r\n /** Looks up the element with the specified name relative to this element, like in JS. */\r\n abstract lookup(name: string): Element | null;\r\n\r\n /** Adds an element as a member of this one. Reports and returns `false` if a duplicate. */\r\n add(name: string, element: DeclaredElement): bool {\r\n var originalDeclaration = element.declaration;\r\n var members = this.members;\r\n if (!members) this.members = members = new Map();\r\n else if (members.has(name)) {\r\n let actual = members.get(name)!;\r\n if (actual.parent !== this) {\r\n // override non-own element\r\n } else {\r\n let merged = tryMerge(actual, element);\r\n if (merged) {\r\n element = merged; // use merged element\r\n } else {\r\n this.program.error(\r\n DiagnosticCode.Duplicate_identifier_0,\r\n element.identifierNode.range, element.identifierNode.text\r\n );\r\n return false;\r\n }\r\n }\r\n }\r\n members.set(name, element);\r\n var program = this.program;\r\n if (element.kind != ElementKind.FUNCTION_PROTOTYPE || !(element).isBound) {\r\n // prefer unbound prototypes in global lookup maps\r\n program.elementsByName.set(element.internalName, element);\r\n program.elementsByDeclaration.set(originalDeclaration, element);\r\n }\r\n return true;\r\n }\r\n\r\n /** Returns a string representation of this element. */\r\n toString(): string {\r\n return ElementKind[this.kind] + \":\" + this.internalName;\r\n }\r\n}\r\n\r\n/** Base class of elements with an associated declaration statement. */\r\nexport abstract class DeclaredElement extends Element {\r\n\r\n /** Constructs a new declared program element. */\r\n protected constructor(\r\n /** Specific element kind. */\r\n kind: ElementKind,\r\n /** Simple name. */\r\n name: string,\r\n /** Internal name referring to this element. */\r\n internalName: string,\r\n /** Containing {@link Program}. */\r\n program: Program,\r\n /** Parent element. */\r\n parent: Element | null,\r\n /** Declaration reference. */\r\n public declaration: DeclarationStatement\r\n ) {\r\n super(kind, name, internalName, program, parent);\r\n // It is necessary to have access to identifiers of all members and exports\r\n // for reporting purposes and this is the lowest common denominator. Comes\r\n // at the expense of not having more specific type information in derived\r\n // classes, though. Instead, derived classes implement getters for other\r\n // important AST nodes directly through manual casting, allowing the resolver\r\n // etc. to not worry about actual declarations.\r\n this.declaration = declaration;\r\n this.flags = declaration.flags; // inherit\r\n }\r\n\r\n /** Tests if this element is a library element. */\r\n get isDeclaredInLibrary(): bool {\r\n return this.declaration.range.source.isLibrary;\r\n }\r\n\r\n /** Gets the associated identifier node. */\r\n get identifierNode(): IdentifierExpression {\r\n return this.declaration.name;\r\n }\r\n\r\n /** Gets the assiciated decorator nodes. */\r\n get decoratorNodes(): DecoratorNode[] | null {\r\n return this.declaration.decorators;\r\n }\r\n}\r\n\r\n/** Base class of elements that can be resolved to a concrete type. */\r\nexport abstract class TypedElement extends DeclaredElement {\r\n\r\n /** Resolved type. Set once `is(RESOLVED)`, otherwise void. */\r\n type: Type = Type.void;\r\n\r\n /** Sets the resolved type of this element. */\r\n setType(type: Type): void {\r\n assert(!this.is(CommonFlags.RESOLVED));\r\n this.type = type;\r\n this.set(CommonFlags.RESOLVED);\r\n }\r\n}\r\n\r\n/** A file representing the implicit top-level namespace of a source. */\r\nexport class File extends Element {\r\n\r\n /** File exports. */\r\n exports: Map | null = null;\r\n /** File re-exports. */\r\n exportsStar: File[] | null = null;\r\n /** Top-level start function of this file. */\r\n startFunction: Function;\r\n\r\n /** Constructs a new file. */\r\n constructor(\r\n /** Program this file belongs to. */\r\n program: Program,\r\n /** Source of this file. */\r\n public source: Source\r\n ) {\r\n super(\r\n ElementKind.FILE,\r\n source.normalizedPath,\r\n source.internalPath,\r\n program,\r\n null // special case for files\r\n );\r\n this.source = source;\r\n assert(!program.filesByName.has(this.internalName));\r\n program.filesByName.set(this.internalName, this);\r\n var startFunction = this.program.makeNativeFunction(\r\n \"start:\" + this.internalName,\r\n new Signature(null, Type.void),\r\n this\r\n );\r\n startFunction.internalName = startFunction.name;\r\n this.startFunction = startFunction;\r\n }\r\n\r\n /* @override */\r\n add(name: string, element: DeclaredElement, isImport: bool = false): bool {\r\n if (element.hasDecorator(DecoratorFlags.GLOBAL)) {\r\n element = this.program.ensureGlobal(name, element); // possibly merged globally\r\n }\r\n if (!super.add(name, element)) return false;\r\n element = assert(this.lookupInSelf(name)); // possibly merged locally\r\n if (element.is(CommonFlags.EXPORT) && !isImport) {\r\n this.ensureExport(\r\n element.name,\r\n element\r\n );\r\n }\r\n return true;\r\n }\r\n\r\n /* @override */\r\n lookupInSelf(name: string): DeclaredElement | null {\r\n var element = super.lookupInSelf(name);\r\n if (element) return element;\r\n var exportsStar = this.exportsStar;\r\n if (exportsStar) {\r\n for (let i = 0, k = exportsStar.length; i < k; ++i) {\r\n if (element = exportsStar[i].lookupInSelf(name)) return element;\r\n }\r\n }\r\n return null;\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n var element = this.lookupInSelf(name);\r\n if (element) return element;\r\n return this.program.lookupGlobal(name);\r\n }\r\n\r\n /** Ensures that an element is an export of this file. */\r\n ensureExport(name: string, element: DeclaredElement): void {\r\n var exports = this.exports;\r\n if (!exports) this.exports = exports = new Map();\r\n exports.set(name, element);\r\n if (this.source.isLibrary) this.program.ensureGlobal(name, element);\r\n }\r\n\r\n /** Ensures that another file is a re-export of this file. */\r\n ensureExportStar(file: File): void {\r\n var exportsStar = this.exportsStar;\r\n if (!exportsStar) this.exportsStar = exportsStar = [];\r\n else if (exportsStar.includes(file)) return;\r\n exportsStar.push(file);\r\n }\r\n\r\n /** Looks up the export of the specified name. */\r\n lookupExport(name: string): DeclaredElement | null {\r\n var exports = this.exports;\r\n if (exports && exports.has(name)) return exports.get(name)!;\r\n var exportsStar = this.exportsStar;\r\n if (exportsStar) {\r\n for (let i = 0, k = exportsStar.length; i < k; ++i) {\r\n let element = exportsStar[i].lookupExport(name);\r\n if (element) return element;\r\n }\r\n }\r\n return null;\r\n }\r\n\r\n /** Creates an imported namespace from this file. */\r\n asImportedNamespace(name: string, parent: Element): Namespace {\r\n var ns = new Namespace(\r\n name,\r\n parent,\r\n this.program.makeNativeNamespaceDeclaration(name)\r\n );\r\n var exports = this.exports;\r\n if (exports) {\r\n for (let [memberName, member] of exports) {\r\n ns.add(memberName, member);\r\n }\r\n }\r\n return ns;\r\n }\r\n}\r\n\r\n/** A type definition. */\r\nexport class TypeDefinition extends TypedElement {\r\n\r\n /** Constructs a new type definition. */\r\n constructor(\r\n /** Simple name. */\r\n name: string,\r\n /** Parent element, usually a file or namespace. */\r\n parent: Element,\r\n /** Declaration reference. */\r\n declaration: TypeDeclaration,\r\n /** Pre-checked flags indicating built-in decorators. */\r\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\r\n ) {\r\n super(\r\n ElementKind.TYPEDEFINITION,\r\n name,\r\n mangleInternalName(name, parent, false),\r\n parent.program,\r\n parent,\r\n declaration\r\n );\r\n this.decoratorFlags = decoratorFlags;\r\n }\r\n\r\n /** Gets the associated type parameter nodes. */\r\n get typeParameterNodes(): TypeParameterNode[] | null {\r\n return (this.declaration).typeParameters;\r\n }\r\n\r\n /** Gets the associated type node. */\r\n get typeNode(): CommonTypeNode {\r\n return (this.declaration).type;\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return this.parent.lookup(name);\r\n }\r\n}\r\n\r\n/** A namespace that differs from a file in being user-declared with a name. */\r\nexport class Namespace extends DeclaredElement {\r\n\r\n /** Constructs a new namespace. */\r\n constructor(\r\n /** Simple name. */\r\n name: string,\r\n /** Parent element, usually a file or another namespace. */\r\n parent: Element,\r\n /** Declaration reference. */\r\n declaration: NamespaceDeclaration,\r\n /** Pre-checked flags indicating built-in decorators. */\r\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\r\n ) {\r\n super(\r\n ElementKind.NAMESPACE,\r\n name,\r\n mangleInternalName(name, parent, false),\r\n parent.program,\r\n parent,\r\n declaration\r\n );\r\n this.decoratorFlags = decoratorFlags;\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return this.lookupInSelf(name)\r\n || this.parent.lookup(name);\r\n }\r\n}\r\n\r\n/** An enum. */\r\nexport class Enum extends TypedElement {\r\n\r\n /** Constructs a new enum. */\r\n constructor(\r\n /** Simple name. */\r\n name: string,\r\n /** Parent element, usually a file or namespace. */\r\n parent: Element,\r\n /** Declaration reference. */\r\n declaration: EnumDeclaration,\r\n /** Pre-checked flags indicating built-in decorators. */\r\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\r\n ) {\r\n super(\r\n ElementKind.ENUM,\r\n name,\r\n mangleInternalName(name, parent, false),\r\n parent.program,\r\n parent,\r\n declaration\r\n );\r\n this.decoratorFlags = decoratorFlags;\r\n this.setType(Type.i32);\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return this.lookupInSelf(name)\r\n || this.parent.lookup(name);\r\n }\r\n}\r\n\r\n/** Indicates the kind of an inlined constant value. */\r\nexport const enum ConstantValueKind {\r\n /** No constant value. */\r\n NONE,\r\n /** Constant integer value. */\r\n INTEGER,\r\n /** Constant float value. */\r\n FLOAT\r\n}\r\n\r\n/** Base class of all variable-like program elements. */\r\nexport abstract class VariableLikeElement extends TypedElement {\r\n\r\n /** Constant value kind. */\r\n constantValueKind: ConstantValueKind = ConstantValueKind.NONE;\r\n /** Constant integer value, if applicable. */\r\n constantIntegerValue: I64;\r\n /** Constant float value, if applicable. */\r\n constantFloatValue: f64;\r\n\r\n /** Constructs a new variable-like element. */\r\n protected constructor(\r\n /** Specific element kind. */\r\n kind: ElementKind,\r\n /** Simple name. */\r\n name: string,\r\n /** Parent element, usually a file, namespace or class. */\r\n parent: Element,\r\n /** Declaration reference. Creates a native declaration if omitted. */\r\n declaration: VariableLikeDeclarationStatement = parent.program.makeNativeVariableDeclaration(name)\r\n ) {\r\n super(\r\n kind,\r\n name,\r\n mangleInternalName(name, parent, false),\r\n parent.program,\r\n parent,\r\n declaration\r\n );\r\n this.flags = declaration.flags;\r\n }\r\n\r\n /** Gets the associated type node.s */\r\n get typeNode(): CommonTypeNode | null {\r\n return (this.declaration).type;\r\n }\r\n\r\n /** Gets the associated initializer node. */\r\n get initializerNode(): Expression | null {\r\n return (this.declaration).initializer;\r\n }\r\n\r\n /** Applies a constant integer value to this element. */\r\n setConstantIntegerValue(value: I64, type: Type): void {\r\n assert(type.is(TypeFlags.INTEGER));\r\n this.type = type;\r\n this.constantValueKind = ConstantValueKind.INTEGER;\r\n this.constantIntegerValue = value;\r\n this.set(CommonFlags.CONST | CommonFlags.INLINED | CommonFlags.RESOLVED);\r\n }\r\n\r\n /** Applies a constant float value to this element. */\r\n setConstantFloatValue(value: f64, type: Type): void {\r\n assert(type.is(TypeFlags.FLOAT));\r\n this.type = type;\r\n this.constantValueKind = ConstantValueKind.FLOAT;\r\n this.constantFloatValue = value;\r\n this.set(CommonFlags.CONST | CommonFlags.INLINED | CommonFlags.RESOLVED);\r\n }\r\n\r\n /** @override */\r\n lookup(name: string): Element | null {\r\n return this.parent.lookup(name);\r\n }\r\n}\r\n\r\n/** An enum value. */\r\nexport class EnumValue extends VariableLikeElement {\r\n\r\n /** Constructs a new enum value. */\r\n constructor(\r\n /** Simple name. */\r\n name: string,\r\n /** Parent enum. */\r\n parent: Enum,\r\n /** Declaration reference. */\r\n declaration: EnumValueDeclaration,\r\n /** Pre-checked flags indicating built-in decorators. */\r\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\r\n ) {\r\n super(\r\n ElementKind.ENUMVALUE,\r\n name,\r\n parent,\r\n declaration\r\n );\r\n this.decoratorFlags = decoratorFlags;\r\n this.setType(Type.i32);\r\n }\r\n\r\n /** Whether this enum value is immutable. */\r\n isImmutable: bool = false;\r\n\r\n /** Gets the associated value node. */\r\n get valueNode(): Expression | null {\r\n return (this.declaration).value;\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return this.parent.lookup(name);\r\n }\r\n}\r\n\r\n/** A global variable. */\r\nexport class Global extends VariableLikeElement {\r\n\r\n /** Constructs a new global variable. */\r\n constructor(\r\n /** Simple name. */\r\n name: string,\r\n /** Parent element, usually a file, namespace or static class. */\r\n parent: Element,\r\n /** Pre-checked flags indicating built-in decorators. */\r\n decoratorFlags: DecoratorFlags,\r\n /** Declaration reference. Creates a native declaration if omitted. */\r\n declaration: VariableLikeDeclarationStatement = parent.program.makeNativeVariableDeclaration(name)\r\n ) {\r\n super(\r\n ElementKind.GLOBAL,\r\n name,\r\n parent,\r\n declaration\r\n );\r\n this.decoratorFlags = decoratorFlags;\r\n }\r\n}\r\n\r\n/** A function parameter. */\r\nexport class Parameter {\r\n /** Constructs a new function parameter. */\r\n constructor(\r\n /** Parameter name. */\r\n public name: string,\r\n /** Parameter type. */\r\n public type: Type,\r\n /** Parameter initializer, if present. */\r\n public initializer: Expression | null = null\r\n ) {}\r\n}\r\n\r\n/** A local variable. */\r\nexport class Local extends VariableLikeElement {\r\n\r\n /** Constructs a new local variable. */\r\n constructor(\r\n /** Simple name. */\r\n name: string,\r\n /** Zero-based index within the enclosing function. `-1` indicates a virtual local. */\r\n public index: i32,\r\n /** Resolved type. */\r\n type: Type,\r\n /** Parent function. */\r\n parent: Function,\r\n /** Declaration reference. */\r\n declaration: VariableLikeDeclarationStatement = parent.program.makeNativeVariableDeclaration(name)\r\n ) {\r\n super(\r\n ElementKind.LOCAL,\r\n name,\r\n parent,\r\n declaration\r\n );\r\n this.index = index;\r\n assert(type != Type.void);\r\n this.setType(type);\r\n }\r\n}\r\n\r\n/** A yet unresolved function prototype. */\r\nexport class FunctionPrototype extends DeclaredElement {\r\n\r\n /** Operator kind, if an overload. */\r\n operatorKind: OperatorKind = OperatorKind.INVALID;\r\n /** Already resolved instances. */\r\n instances: Map | null = null;\r\n\r\n /** Clones of this prototype that are bounds to specific classes. */\r\n private boundPrototypes: Map | null = null;\r\n\r\n /** Constructs a new function prototype. */\r\n constructor(\r\n /** Simple name */\r\n name: string,\r\n /** Parent element, usually a file, namespace or class (if a method). */\r\n parent: Element,\r\n /** Declaration reference. */\r\n declaration: FunctionDeclaration,\r\n /** Pre-checked flags indicating built-in decorators. */\r\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\r\n ) {\r\n super(\r\n ElementKind.FUNCTION_PROTOTYPE,\r\n name,\r\n mangleInternalName(name, parent, declaration.is(CommonFlags.INSTANCE)),\r\n parent.program,\r\n parent,\r\n declaration\r\n );\r\n this.decoratorFlags = decoratorFlags;\r\n }\r\n\r\n /** Gets the associated type parameter nodes. */\r\n get typeParameterNodes(): TypeParameterNode[] | null {\r\n return (this.declaration).typeParameters;\r\n }\r\n\r\n /** Gets the associated signature node. */\r\n get signatureNode(): SignatureNode {\r\n return (this.declaration).signature;\r\n }\r\n\r\n /** Gets the associated body node. */\r\n get bodyNode(): Statement | null {\r\n return (this.declaration).body;\r\n }\r\n\r\n /** Gets the arrow function kind. */\r\n get arrowKind(): ArrowKind {\r\n return (this.declaration).arrowKind;\r\n }\r\n\r\n /** Tests if this prototype is bound to a class. */\r\n get isBound(): bool {\r\n var parent = this.parent;\r\n return parent.kind == ElementKind.CLASS\r\n || parent.kind == ElementKind.PROPERTY_PROTOTYPE && parent.parent.kind == ElementKind.CLASS;\r\n }\r\n\r\n /** Creates a clone of this prototype that is bound to a concrete class instead. */\r\n toBound(classInstance: Class): FunctionPrototype {\r\n assert(this.is(CommonFlags.INSTANCE));\r\n assert(!this.isBound);\r\n var boundPrototypes = this.boundPrototypes;\r\n if (!boundPrototypes) this.boundPrototypes = boundPrototypes = new Map();\r\n else if (boundPrototypes.has(classInstance)) return boundPrototypes.get(classInstance)!;\r\n var declaration = this.declaration; assert(declaration.kind == NodeKind.METHODDECLARATION);\r\n var bound = new FunctionPrototype(\r\n this.name,\r\n classInstance, // !\r\n declaration,\r\n this.decoratorFlags\r\n );\r\n bound.flags = this.flags;\r\n bound.operatorKind = this.operatorKind;\r\n // NOTE: this.instances holds instances per bound class / unbound\r\n boundPrototypes.set(classInstance, bound);\r\n return bound;\r\n }\r\n\r\n /** Gets the resolved instance for the specified instance key, if already resolved. */\r\n getResolvedInstance(instanceKey: string): Function | null {\r\n var instances = this.instances;\r\n if (instances && instances.has(instanceKey)) return instances.get(instanceKey);\r\n return null;\r\n }\r\n\r\n /** Sets the resolved instance for the specified instance key. */\r\n setResolvedInstance(instanceKey: string, instance: Function): void {\r\n var instances = this.instances;\r\n if (!instances) this.instances = instances = new Map();\r\n else assert(!instances.has(instanceKey));\r\n instances.set(instanceKey, instance);\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return this.parent.lookup(name);\r\n }\r\n}\r\n\r\n/** A resolved function. */\r\nexport class Function extends TypedElement {\r\n\r\n /** Function prototype. */\r\n prototype: FunctionPrototype;\r\n /** Function signature. */\r\n signature: Signature;\r\n /** Map of locals by name. */\r\n localsByName: Map = new Map();\r\n /** Array of locals by index. */\r\n localsByIndex: Local[] = [];\r\n /** List of additional non-parameter locals. */\r\n additionalLocals: Type[] = [];\r\n /** Contextual type arguments. */\r\n contextualTypeArguments: Map | null;\r\n /** Default control flow. */\r\n flow: Flow;\r\n /** Remembered debug locations. */\r\n debugLocations: Range[] = [];\r\n /** Function reference, if compiled. */\r\n ref: FunctionRef = 0;\r\n /** Function table index, if any. */\r\n functionTableIndex: i32 = -1;\r\n /** Trampoline function for calling with omitted arguments. */\r\n trampoline: Function | null = null;\r\n\r\n /** Counting id of inline operations involving this function. */\r\n nextInlineId: i32 = 0;\r\n /** Counting id of anonymous inner functions. */\r\n nextAnonymousId: i32 = 0;\r\n /** Counting id of autorelease variables. */\r\n nextAutoreleaseId: i32 = 0;\r\n\r\n /** Constructs a new concrete function. */\r\n constructor(\r\n /** Name incl. type parameters, i.e. `foo`. */\r\n nameInclTypeParameters: string,\r\n /** Respective function prototype. */\r\n prototype: FunctionPrototype,\r\n /** Concrete signature. */\r\n signature: Signature, // pre-resolved\r\n /** Contextual type arguments inherited from its parent class, if any. */\r\n contextualTypeArguments: Map | null = null\r\n ) {\r\n super(\r\n ElementKind.FUNCTION,\r\n nameInclTypeParameters,\r\n mangleInternalName(nameInclTypeParameters, prototype.parent, prototype.is(CommonFlags.INSTANCE)),\r\n prototype.program,\r\n prototype.parent,\r\n prototype.declaration\r\n );\r\n this.prototype = prototype;\r\n this.signature = signature;\r\n this.flags = prototype.flags | CommonFlags.RESOLVED;\r\n this.decoratorFlags = prototype.decoratorFlags;\r\n this.contextualTypeArguments = contextualTypeArguments;\r\n this.type = Type.u32.asFunction(signature);\r\n if (!prototype.is(CommonFlags.AMBIENT)) {\r\n let localIndex = 0;\r\n if (this.is(CommonFlags.INSTANCE)) {\r\n let local = new Local(\r\n CommonSymbols.this_,\r\n localIndex++,\r\n assert(signature.thisType),\r\n this\r\n );\r\n this.localsByName.set(CommonSymbols.this_, local);\r\n this.localsByIndex[local.index] = local;\r\n }\r\n let parameterTypes = signature.parameterTypes;\r\n for (let i = 0, k = parameterTypes.length; i < k; ++i) {\r\n let parameterType = parameterTypes[i];\r\n let parameterName = signature.getParameterName(i);\r\n let local = new Local(\r\n parameterName,\r\n localIndex++,\r\n parameterType,\r\n this\r\n );\r\n this.localsByName.set(parameterName, local);\r\n this.localsByIndex[local.index] = local;\r\n }\r\n }\r\n this.flow = Flow.create(this);\r\n registerConcreteElement(this.program, this);\r\n }\r\n\r\n /** Adds a local of the specified type, with an optional name. */\r\n addLocal(type: Type, name: string | null = null, declaration: VariableDeclaration | null = null): Local {\r\n // if it has a name, check previously as this method will throw otherwise\r\n var localIndex = this.signature.parameterTypes.length + this.additionalLocals.length;\r\n if (this.is(CommonFlags.INSTANCE)) ++localIndex;\r\n var localName = name !== null\r\n ? name\r\n : \"var$\" + localIndex.toString();\r\n var local = new Local(\r\n localName,\r\n localIndex,\r\n type,\r\n this,\r\n declaration || this.program.makeNativeVariableDeclaration(localName)\r\n );\r\n if (name) {\r\n if (this.localsByName.has(name)) throw new Error(\"duplicate local name\");\r\n this.localsByName.set(name, local);\r\n }\r\n this.localsByIndex[local.index] = local;\r\n this.additionalLocals.push(type);\r\n return local;\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n var locals = this.localsByName;\r\n if (locals.has(name)) return locals.get(name);\r\n return this.parent.lookup(name);\r\n }\r\n\r\n // used by flows to keep track of temporary locals\r\n tempI32s: Local[] | null = null;\r\n tempI64s: Local[] | null = null;\r\n tempF32s: Local[] | null = null;\r\n tempF64s: Local[] | null = null;\r\n tempV128s: Local[] | null = null;\r\n\r\n // used by flows to keep track of break labels\r\n nextBreakId: i32 = 0;\r\n breakStack: i32[] | null = null;\r\n breakLabel: string | null = null;\r\n\r\n /** Finalizes the function once compiled, releasing no longer needed resources. */\r\n finalize(module: Module, ref: FunctionRef): void {\r\n this.ref = ref;\r\n assert(!this.breakStack || !this.breakStack.length); // internal error\r\n this.breakStack = null;\r\n this.breakLabel = null;\r\n this.tempI32s = this.tempI64s = this.tempF32s = this.tempF64s = null;\r\n if (this.program.options.sourceMap) {\r\n let debugLocations = this.debugLocations;\r\n for (let i = 0, k = debugLocations.length; i < k; ++i) {\r\n let debugLocation = debugLocations[i];\r\n module.setDebugLocation(\r\n ref,\r\n debugLocation.debugInfoRef,\r\n debugLocation.source.debugInfoIndex,\r\n debugLocation.line,\r\n debugLocation.column\r\n );\r\n }\r\n }\r\n }\r\n}\r\n\r\n/** A resolved function target, that is a function called indirectly by an index and signature. */\r\nexport class FunctionTarget extends Element {\r\n\r\n /** Underlying signature. */\r\n signature: Signature;\r\n /** Function type. */\r\n type: Type;\r\n\r\n /** Constructs a new function target. */\r\n constructor(\r\n /** Concrete signature. */\r\n signature: Signature,\r\n /** Program reference. */\r\n program: Program,\r\n __s: string = \"\" // FIXME: current TS limitation workaround, but a fix seems underway\r\n ) {\r\n super(\r\n ElementKind.FUNCTION_TARGET,\r\n __s = \"sig:\" + signature.toSignatureString(),\r\n __s,\r\n program,\r\n program.nativeFile\r\n );\r\n this.signature = signature;\r\n this.flags = CommonFlags.RESOLVED;\r\n this.type = Type.u32.asFunction(signature);\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return null;\r\n }\r\n}\r\n\r\n/** A yet unresolved instance field prototype. */\r\nexport class FieldPrototype extends DeclaredElement {\r\n\r\n /** Constructs a new field prototype. */\r\n constructor(\r\n /** Simple name. */\r\n name: string,\r\n /** Parent class. */\r\n parent: ClassPrototype,\r\n /** Declaration reference. */\r\n declaration: FieldDeclaration,\r\n /** Pre-checked flags indicating built-in decorators. */\r\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\r\n ) {\r\n super(\r\n ElementKind.FIELD_PROTOTYPE,\r\n name,\r\n mangleInternalName(name, parent, assert(declaration.is(CommonFlags.INSTANCE))),\r\n parent.program,\r\n parent,\r\n declaration\r\n );\r\n this.decoratorFlags = decoratorFlags;\r\n }\r\n\r\n /** Gets the associated type node. */\r\n get typeNode(): CommonTypeNode | null {\r\n return (this.declaration).type;\r\n }\r\n\r\n /** Gets the associated initializer node. */\r\n get initializerNode(): Expression | null {\r\n return (this.declaration).initializer;\r\n }\r\n\r\n /** Gets the associated parameter index. Set if declared as a constructor parameter, otherwise `-1`. */\r\n get parameterIndex(): i32 {\r\n return (this.declaration).parameterIndex;\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return this.parent.lookup(name);\r\n }\r\n}\r\n\r\n/** A resolved instance field. */\r\nexport class Field extends VariableLikeElement {\r\n\r\n /** Field prototype reference. */\r\n prototype: FieldPrototype;\r\n /** Field memory offset, if an instance field. */\r\n memoryOffset: i32 = -1;\r\n\r\n /** Constructs a new field. */\r\n constructor(\r\n /** Respective field prototype. */\r\n prototype: FieldPrototype,\r\n /** Parent class. */\r\n parent: Class,\r\n /** Concrete type. */\r\n type: Type\r\n ) {\r\n super(\r\n ElementKind.FIELD,\r\n prototype.name,\r\n parent,\r\n prototype.declaration\r\n );\r\n this.prototype = prototype;\r\n this.flags = prototype.flags;\r\n assert(type != Type.void);\r\n this.setType(type);\r\n registerConcreteElement(this.program, this);\r\n }\r\n}\r\n\r\n/** A property comprised of a getter and a setter function. */\r\nexport class PropertyPrototype extends DeclaredElement {\r\n\r\n /** Getter prototype. */\r\n getterPrototype: FunctionPrototype | null = null;\r\n /** Setter prototype. */\r\n setterPrototype: FunctionPrototype | null = null;\r\n\r\n /** Constructs a new property prototype. */\r\n constructor(\r\n /** Simple name. */\r\n name: string,\r\n /** Parent class. */\r\n parent: ClassPrototype,\r\n /** Declaration of the getter or setter introducing the property. */\r\n firstDeclaration: FunctionDeclaration\r\n ) {\r\n super(\r\n ElementKind.PROPERTY_PROTOTYPE,\r\n name,\r\n mangleInternalName(name, parent, firstDeclaration.is(CommonFlags.INSTANCE)),\r\n parent.program,\r\n parent,\r\n firstDeclaration\r\n );\r\n this.flags &= ~(CommonFlags.GET | CommonFlags.SET);\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return this.parent.lookup(name);\r\n }\r\n}\r\n\r\n/** A resolved property. */\r\nexport class Property extends VariableLikeElement {\r\n\r\n /** Prototype reference. */\r\n prototype: PropertyPrototype;\r\n /** Getter instance. */\r\n getterInstance: Function | null = null;\r\n /** Setter instance. */\r\n setterInstance: Function | null = null;\r\n\r\n /** Constructs a new property prototype. */\r\n constructor(\r\n /** Respective property prototype. */\r\n prototype: PropertyPrototype,\r\n /** Parent element, usually a static class prototype or class instance. */\r\n parent: Element\r\n ) {\r\n super(\r\n ElementKind.PROPERTY,\r\n prototype.name,\r\n parent,\r\n prototype.program.makeNativeVariableDeclaration(\r\n prototype.name,\r\n prototype.is(CommonFlags.INSTANCE)\r\n ? CommonFlags.INSTANCE\r\n : CommonFlags.NONE\r\n )\r\n );\r\n this.prototype = prototype;\r\n registerConcreteElement(this.program, this);\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return this.parent.lookup(name);\r\n }\r\n}\r\n\r\n/** A yet unresolved class prototype. */\r\nexport class ClassPrototype extends DeclaredElement {\r\n\r\n /** Instance member prototypes. */\r\n instanceMembers: Map | null = null;\r\n /** Base class prototype, if applicable. */\r\n basePrototype: ClassPrototype | null = null; // set in Program#initialize\r\n /** Constructor prototype. */\r\n constructorPrototype: FunctionPrototype | null = null;\r\n /** Operator overload prototypes. */\r\n overloadPrototypes: Map = new Map();\r\n /** Already resolved instances. */\r\n instances: Map | null = null;\r\n\r\n constructor(\r\n /** Simple name. */\r\n name: string,\r\n /** Parent element, usually a file or namespace. */\r\n parent: Element,\r\n /** Declaration reference. */\r\n declaration: ClassDeclaration,\r\n /** Pre-checked flags indicating built-in decorators. */\r\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE,\r\n _isInterface: bool = false // FIXME\r\n ) {\r\n super(\r\n _isInterface ? ElementKind.INTERFACE_PROTOTYPE : ElementKind.CLASS_PROTOTYPE,\r\n name,\r\n mangleInternalName(name, parent, declaration.is(CommonFlags.INSTANCE)),\r\n parent.program,\r\n parent,\r\n declaration\r\n );\r\n this.decoratorFlags = decoratorFlags;\r\n }\r\n\r\n /** Gets the associated type parameter nodes. */\r\n get typeParameterNodes(): TypeParameterNode[] | null {\r\n return (this.declaration).typeParameters;\r\n }\r\n /** Gets the associated extends node. */\r\n get extendsNode(): TypeNode | null {\r\n return (this.declaration).extendsType;\r\n }\r\n /** Gets the associated implements nodes. */\r\n get implementsNodes(): TypeNode[] | null {\r\n return (this.declaration).implementsTypes;\r\n }\r\n\r\n /** Tests if this prototype is of a builtin array type (Array/TypedArray). */\r\n get isBuiltinArray(): bool {\r\n var arrayBufferViewInstance = this.program.arrayBufferViewInstance;\r\n return arrayBufferViewInstance !== null\r\n && this.extends(arrayBufferViewInstance.prototype);\r\n }\r\n\r\n /** Tests if this prototype extends the specified. */\r\n extends(basePtototype: ClassPrototype | null): bool {\r\n var current: ClassPrototype | null = this;\r\n do if (current === basePtototype) return true;\r\n while (current = current.basePrototype);\r\n return false;\r\n }\r\n\r\n /** Adds an element as an instance member of this one. Returns the previous element if a duplicate. */\r\n addInstance(name: string, element: DeclaredElement): bool {\r\n var originalDeclaration = element.declaration;\r\n var instanceMembers = this.instanceMembers;\r\n if (!instanceMembers) this.instanceMembers = instanceMembers = new Map();\r\n else if (instanceMembers.has(name)) {\r\n let merged = tryMerge(instanceMembers.get(name)!, element);\r\n if (!merged) {\r\n this.program.error(\r\n DiagnosticCode.Duplicate_identifier_0,\r\n element.identifierNode.range, element.identifierNode.text\r\n );\r\n return false;\r\n }\r\n element = merged;\r\n }\r\n instanceMembers.set(name, element);\r\n if (element.is(CommonFlags.EXPORT) && this.is(CommonFlags.MODULE_EXPORT)) {\r\n element.set(CommonFlags.MODULE_EXPORT); // propagate\r\n }\r\n this.program.elementsByDeclaration.set(originalDeclaration, element);\r\n return true;\r\n }\r\n\r\n /** Gets the resolved instance for the specified instance key, if already resolved. */\r\n getResolvedInstance(instanceKey: string): Class | null {\r\n var instances = this.instances;\r\n if (instances && instances.has(instanceKey)) return instances.get(instanceKey);\r\n return null;\r\n }\r\n\r\n /** Sets the resolved instance for the specified instance key. */\r\n setResolvedInstance(instanceKey: string, instance: Class): void {\r\n var instances = this.instances;\r\n if (!instances) this.instances = instances = new Map();\r\n else assert(!instances.has(instanceKey));\r\n instances.set(instanceKey, instance);\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return this.parent.lookup(name);\r\n }\r\n}\r\n\r\nconst enum AcyclicState {\r\n UNKNOWN,\r\n ACYCLIC,\r\n NOT_ACYCLIC\r\n}\r\n\r\n/** A resolved class. */\r\nexport class Class extends TypedElement {\r\n\r\n /** Class prototype. */\r\n prototype: ClassPrototype;\r\n /** Resolved type arguments. */\r\n typeArguments: Type[] | null;\r\n /** Base class, if applicable. */\r\n base: Class | null;\r\n /** Contextual type arguments for fields and methods. */\r\n contextualTypeArguments: Map | null = null;\r\n /** Current member memory offset. */\r\n currentMemoryOffset: u32 = 0;\r\n /** Constructor instance. */\r\n constructorInstance: Function | null = null;\r\n /** Operator overloads. */\r\n overloads: Map | null = null;\r\n /** Unique class id. */\r\n private _id: u32 = 0;\r\n /** Remembers acyclic state. */\r\n private _acyclic: AcyclicState = AcyclicState.UNKNOWN;\r\n /** Runtime type information flags. */\r\n rttiFlags: u32 = 0;\r\n\r\n /** Gets the unique runtime id of this class. */\r\n get id(): u32 {\r\n return this._id; // unmanaged remains 0 (=ArrayBuffer)\r\n }\r\n\r\n /** Tests if this class is of a builtin array type (Array/TypedArray). */\r\n get isBuiltinArray(): bool {\r\n return this.prototype.isBuiltinArray;\r\n }\r\n\r\n /** Tests if this class is array-like. */\r\n get isArrayLike(): bool {\r\n if (this.isBuiltinArray) return true;\r\n var lengthField = this.lookupInSelf(\"length\");\r\n return lengthField !== null && (\r\n lengthField.kind == ElementKind.FIELD ||\r\n (\r\n lengthField.kind == ElementKind.PROPERTY &&\r\n (lengthField).getterInstance !== null // TODO: resolve & check type?\r\n )\r\n ) && (\r\n this.lookupOverload(OperatorKind.INDEXED_GET) !== null ||\r\n this.lookupOverload(OperatorKind.UNCHECKED_INDEXED_GET) !== null\r\n );\r\n }\r\n\r\n /** Constructs a new class. */\r\n constructor(\r\n /** Name incl. type parameters, i.e. `Foo`. */\r\n nameInclTypeParameters: string,\r\n /** The respective class prototype. */\r\n prototype: ClassPrototype,\r\n /** Concrete type arguments, if any. */\r\n typeArguments: Type[] | null = null,\r\n /** Base class, if derived. */\r\n base: Class | null = null,\r\n _isInterface: bool = false // FIXME\r\n ) {\r\n super(\r\n _isInterface ? ElementKind.INTERFACE : ElementKind.CLASS,\r\n nameInclTypeParameters,\r\n mangleInternalName(nameInclTypeParameters, prototype.parent, prototype.is(CommonFlags.INSTANCE)),\r\n prototype.program,\r\n prototype.parent,\r\n prototype.declaration\r\n );\r\n var program = this.program;\r\n this.prototype = prototype;\r\n this.flags = prototype.flags;\r\n this.decoratorFlags = prototype.decoratorFlags;\r\n this.typeArguments = typeArguments;\r\n this.setType(program.options.usizeType.asClass(this));\r\n this.base = base;\r\n\r\n if (!this.hasDecorator(DecoratorFlags.UNMANAGED)) {\r\n let id = program.nextClassId++;\r\n this._id = id;\r\n program.managedClasses.set(id, this);\r\n }\r\n\r\n // inherit static members and contextual type arguments from base class\r\n if (base) {\r\n let inheritedTypeArguments = base.contextualTypeArguments;\r\n if (inheritedTypeArguments) {\r\n let contextualTypeArguments = this.contextualTypeArguments;\r\n for (let [baseName, baseType] of inheritedTypeArguments) {\r\n if (!contextualTypeArguments) this.contextualTypeArguments = contextualTypeArguments = new Map();\r\n contextualTypeArguments.set(baseName, baseType);\r\n }\r\n }\r\n }\r\n\r\n // apply pre-checked instance-specific contextual type arguments\r\n var typeParameters = prototype.typeParameterNodes;\r\n if (typeArguments) {\r\n let numTypeArguments = typeArguments.length;\r\n if (!typeParameters || numTypeArguments != typeParameters.length) {\r\n throw new Error(\"type argument count mismatch\");\r\n }\r\n if (numTypeArguments) {\r\n if (!this.contextualTypeArguments) this.contextualTypeArguments = new Map();\r\n for (let i = 0; i < numTypeArguments; ++i) {\r\n this.contextualTypeArguments.set(typeParameters[i].name.text, typeArguments[i]);\r\n }\r\n }\r\n } else if (typeParameters && typeParameters.length) {\r\n throw new Error(\"type argument count mismatch\");\r\n }\r\n registerConcreteElement(program, this);\r\n }\r\n\r\n /** Tests if a value of this class type is assignable to a target of the specified class type. */\r\n isAssignableTo(target: Class): bool {\r\n var current: Class | null = this;\r\n do if (current == target) return true;\r\n while (current = current.base);\r\n return false;\r\n }\r\n\r\n /** Looks up the operator overload of the specified kind. */\r\n lookupOverload(kind: OperatorKind, unchecked: bool = false): Function | null {\r\n if (unchecked) {\r\n switch (kind) {\r\n case OperatorKind.INDEXED_GET: {\r\n let uncheckedOverload = this.lookupOverload(OperatorKind.UNCHECKED_INDEXED_GET);\r\n if (uncheckedOverload) return uncheckedOverload;\r\n break;\r\n }\r\n case OperatorKind.INDEXED_SET: {\r\n let uncheckedOverload = this.lookupOverload(OperatorKind.UNCHECKED_INDEXED_SET);\r\n if (uncheckedOverload) return uncheckedOverload;\r\n break;\r\n }\r\n default: assert(false);\r\n }\r\n }\r\n var instance: Class | null = this;\r\n do {\r\n let overloads = instance.overloads;\r\n if (overloads) {\r\n let overload = overloads.get(kind);\r\n if (overload) return overload;\r\n }\r\n } while (instance = instance.base);\r\n return null;\r\n }\r\n\r\n /* @override */\r\n lookup(name: string): Element | null {\r\n return this.parent.lookup(name);\r\n }\r\n\r\n /** Calculates the memory offset of the specified field. */\r\n offsetof(fieldName: string): u32 {\r\n var members = assert(this.members);\r\n assert(members.has(fieldName));\r\n var field = members.get(fieldName);\r\n assert(field.kind == ElementKind.FIELD);\r\n return (field).memoryOffset;\r\n }\r\n\r\n /** Writes a field value to a buffer and returns the number of bytes written. */\r\n writeField(name: string, value: T, buffer: Uint8Array, baseOffset: i32): i32 {\r\n var field = this.lookupInSelf(name);\r\n if (field && field.kind == ElementKind.FIELD) {\r\n let offset = baseOffset + (field).memoryOffset;\r\n switch ((field).type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: {\r\n writeI8(i32(value), buffer, offset);\r\n return 1;\r\n }\r\n case TypeKind.I16:\r\n case TypeKind.U16: {\r\n writeI16(i32(value), buffer, offset);\r\n return 2;\r\n }\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n writeI32(i32(value), buffer, offset);\r\n return 4;\r\n }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n assert(!this.program.options.isWasm64); // TODO\r\n writeI32(i32(value), buffer, offset);\r\n return 4;\r\n }\r\n case TypeKind.F32: {\r\n writeF32(f32(value), buffer, offset);\r\n return 4;\r\n }\r\n case TypeKind.F64: {\r\n writeF64(f64(value), buffer, offset);\r\n return 8;\r\n }\r\n }\r\n }\r\n assert(false);\r\n return 0;\r\n }\r\n\r\n /** Tests if this class extends the specified prototype. */\r\n extends(prototype: ClassPrototype): bool {\r\n return this.prototype.extends(prototype);\r\n }\r\n\r\n /** Gets the concrete type arguments to the specified extendend prototype. */\r\n getTypeArgumentsTo(extendedPrototype: ClassPrototype): Type[] | null {\r\n var current: Class | null = this;\r\n do if (current.prototype === extendedPrototype) return current.typeArguments;\r\n while (current = current.base);\r\n return null;\r\n }\r\n\r\n /** Gets the value type of an array. Must be an array. */\r\n getArrayValueType(): Type {\r\n var current: Class = this;\r\n var program = this.program;\r\n var abvInstance = program.arrayBufferViewInstance;\r\n while (current.base !== abvInstance) {\r\n current = assert(current.base);\r\n }\r\n switch (current.prototype) {\r\n case program.i8ArrayPrototype: return Type.i8;\r\n case program.i16ArrayPrototype: return Type.i16;\r\n case program.i32ArrayPrototype: return Type.i32;\r\n case program.i64ArrayPrototype: return Type.i64;\r\n case program.u8ArrayPrototype:\r\n case program.u8ClampedArrayPrototype: return Type.u8;\r\n case program.u16ArrayPrototype: return Type.u16;\r\n case program.u32ArrayPrototype: return Type.u32;\r\n case program.u64ArrayPrototype: return Type.u64;\r\n case program.f32ArrayPrototype: return Type.f32;\r\n case program.f64ArrayPrototype: return Type.f64;\r\n case program.arrayPrototype: return assert(this.getTypeArgumentsTo(program.arrayPrototype))[0];\r\n default: assert(false);\r\n }\r\n return Type.void;\r\n }\r\n\r\n /** Tests if this class is inherently acyclic. */\r\n get isAcyclic(): bool {\r\n var acyclic = this._acyclic;\r\n if (acyclic == AcyclicState.UNKNOWN) {\r\n let hasCycle = this.cyclesTo(this);\r\n if (hasCycle) this._acyclic = acyclic = AcyclicState.NOT_ACYCLIC;\r\n else this._acyclic = acyclic = AcyclicState.ACYCLIC;\r\n }\r\n return acyclic == AcyclicState.ACYCLIC;\r\n }\r\n\r\n /** Tests if this class potentially forms a reference cycle to another one. */\r\n private cyclesTo(other: Class, except: Set = new Set()): bool {\r\n // TODO: The pure RC paper describes acyclic data structures as classes that may contain\r\n //\r\n // - scalars\r\n // - references to classes that are both acyclic and final (here: Java); and\r\n // - arrays (in our case: also sets, maps) of either of the above\r\n //\r\n // Our implementation, however, treats all objects that do not reference themselves directly\r\n // or indirectly as acylic, allowing them to contain inner cycles of other non-acyclic objects.\r\n // This contradicts the second assumption and must be revisited when actually implementing RC.\r\n\r\n if (except.has(this)) return false;\r\n except.add(this); // don't recurse indefinitely\r\n\r\n // Find out if any field references 'other' directly or indirectly\r\n var current: Class | null;\r\n var members = this.members;\r\n if (members) {\r\n for (let member of members.values()) {\r\n if (\r\n member.kind == ElementKind.FIELD &&\r\n (current = (member).type.classReference) !== null &&\r\n (\r\n current === other ||\r\n current.cyclesTo(other, except)\r\n )\r\n ) return true;\r\n }\r\n }\r\n\r\n // Do the same for non-field data\r\n var basePrototype: ClassPrototype | null;\r\n\r\n // Arrayother?>\r\n if ((basePrototype = this.program.arrayPrototype) && this.prototype.extends(basePrototype)) {\r\n let typeArguments = assert(this.getTypeArgumentsTo(basePrototype));\r\n assert(typeArguments.length == 1);\r\n if (\r\n (current = typeArguments[0].classReference) !== null &&\r\n (\r\n current === other ||\r\n current.cyclesTo(other, except)\r\n )\r\n ) return true;\r\n\r\n // Setother?>\r\n } else if ((basePrototype = this.program.setPrototype) && this.prototype.extends(basePrototype)) {\r\n let typeArguments = assert(this.getTypeArgumentsTo(basePrototype));\r\n assert(typeArguments.length == 1);\r\n if (\r\n (current = typeArguments[0].classReference) !== null &&\r\n (\r\n current === other ||\r\n current.cyclesTo(other, except)\r\n )\r\n ) return true;\r\n\r\n // Mapother?,V->other?>\r\n } else if ((basePrototype = this.program.mapPrototype) && this.prototype.extends(basePrototype)) {\r\n let typeArguments = assert(this.getTypeArgumentsTo(basePrototype));\r\n assert(typeArguments.length == 2);\r\n if (\r\n (current = typeArguments[0].classReference) !== null &&\r\n (\r\n current === other ||\r\n current.cyclesTo(other, except)\r\n )\r\n ) return true;\r\n if (\r\n (current = typeArguments[1].classReference) !== null &&\r\n (\r\n current === other ||\r\n current.cyclesTo(other, except)\r\n )\r\n ) return true;\r\n }\r\n return false;\r\n }\r\n}\r\n\r\n/** A yet unresolved interface. */\r\nexport class InterfacePrototype extends ClassPrototype { // FIXME\r\n\r\n /** Constructs a new interface prototype. */\r\n constructor(\r\n name: string,\r\n parent: Element,\r\n declaration: InterfaceDeclaration,\r\n decoratorFlags: DecoratorFlags\r\n ) {\r\n super(\r\n name,\r\n parent,\r\n declaration,\r\n decoratorFlags,\r\n true\r\n );\r\n }\r\n}\r\n\r\n/** A resolved interface. */\r\nexport class Interface extends Class { // FIXME\r\n\r\n /** Constructs a new interface. */\r\n constructor(\r\n nameInclTypeParameters: string,\r\n prototype: InterfacePrototype,\r\n typeArguments: Type[] = [],\r\n base: Interface | null = null\r\n ) {\r\n super(\r\n nameInclTypeParameters,\r\n prototype,\r\n typeArguments,\r\n base,\r\n true\r\n );\r\n }\r\n}\r\n\r\n/** Registers a concrete element with a program. */\r\nfunction registerConcreteElement(program: Program, element: Element): void {\r\n assert(!program.instancesByName.has(element.internalName));\r\n program.instancesByName.set(element.internalName, element);\r\n}\r\n\r\n/** Attempts to merge two elements. Returns the merged element on success. */\r\nfunction tryMerge(older: Element, newer: Element): DeclaredElement | null {\r\n // NOTE: some of the following cases are not supported by TS, not sure why exactly.\r\n // suggesting to just merge what seems to be possible for now and revisit later.\r\n assert(older.program === newer.program);\r\n assert(!newer.members);\r\n var merged: DeclaredElement | null = null;\r\n switch (older.kind) {\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n switch (newer.kind) {\r\n case ElementKind.NAMESPACE: {\r\n copyMembers(newer, older);\r\n merged = older;\r\n break;\r\n }\r\n case ElementKind.TYPEDEFINITION: {\r\n if (!older.shadowType) {\r\n older.shadowType = newer;\r\n copyMembers(newer, older);\r\n merged = older;\r\n }\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case ElementKind.CLASS_PROTOTYPE:\r\n case ElementKind.ENUM: {\r\n if (newer.kind == ElementKind.NAMESPACE) {\r\n copyMembers(newer, older);\r\n merged = older;\r\n break;\r\n }\r\n break;\r\n }\r\n case ElementKind.NAMESPACE: {\r\n switch (newer.kind) {\r\n case ElementKind.ENUM:\r\n case ElementKind.CLASS_PROTOTYPE: // TS2434\r\n case ElementKind.FUNCTION_PROTOTYPE: { // TS2434\r\n copyMembers(older, newer);\r\n merged = newer;\r\n break;\r\n }\r\n case ElementKind.NAMESPACE: {\r\n copyMembers(newer, older);\r\n merged = older;\r\n break;\r\n }\r\n case ElementKind.TYPEDEFINITION: {\r\n if (!older.shadowType) {\r\n older.shadowType = newer;\r\n copyMembers(newer, older);\r\n merged = older;\r\n }\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case ElementKind.GLOBAL: {\r\n if (newer.kind == ElementKind.TYPEDEFINITION) {\r\n if (!older.shadowType) {\r\n older.shadowType = newer;\r\n copyMembers(newer, older);\r\n merged = older;\r\n }\r\n }\r\n break;\r\n }\r\n case ElementKind.TYPEDEFINITION: {\r\n switch (newer.kind) {\r\n case ElementKind.GLOBAL:\r\n case ElementKind.FUNCTION_PROTOTYPE:\r\n case ElementKind.NAMESPACE: {\r\n if (!newer.shadowType) {\r\n newer.shadowType = older;\r\n copyMembers(older, newer);\r\n merged = newer;\r\n }\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n if (merged) {\r\n let olderIsExport = older.is(CommonFlags.EXPORT) || older.hasDecorator(DecoratorFlags.GLOBAL);\r\n let newerIsExport = newer.is(CommonFlags.EXPORT) || newer.hasDecorator(DecoratorFlags.GLOBAL);\r\n if (olderIsExport != newerIsExport) {\r\n older.program.error(\r\n DiagnosticCode.Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local,\r\n merged.identifierNode.range, merged.identifierNode.text\r\n );\r\n }\r\n }\r\n return merged;\r\n}\r\n\r\n/** Copies the members of `src` to `dest`. */\r\nfunction copyMembers(src: Element, dest: Element): void {\r\n var srcMembers = src.members;\r\n if (srcMembers) {\r\n let destMembers = dest.members;\r\n if (!destMembers) dest.members = destMembers = new Map();\r\n for (let [memberName, member] of srcMembers) {\r\n destMembers.set(memberName, member);\r\n }\r\n }\r\n}\r\n\r\n/** Mangles the internal name of an element with the specified name that is a child of the given parent. */\r\nexport function mangleInternalName(name: string, parent: Element, isInstance: bool, asGlobal: bool = false): string {\r\n switch (parent.kind) {\r\n case ElementKind.FILE: {\r\n if (asGlobal) return name;\r\n return parent.internalName + PATH_DELIMITER + name;\r\n }\r\n case ElementKind.FUNCTION: {\r\n if (asGlobal) return name;\r\n assert(!isInstance);\r\n return parent.internalName + INNER_DELIMITER + name;\r\n }\r\n default: {\r\n return mangleInternalName(parent.name, parent.parent, parent.is(CommonFlags.INSTANCE), asGlobal)\r\n + (isInstance ? INSTANCE_DELIMITER : STATIC_DELIMITER) + name;\r\n }\r\n }\r\n}\r\n","/**\r\n * A thin wrapper around Binaryen's C-API.\r\n * @module module\r\n *//***/\r\n\r\nimport { Target } from \"./common\";\r\n\r\nexport type ModuleRef = usize;\r\nexport type FunctionTypeRef = usize;\r\nexport type FunctionRef = usize;\r\nexport type ExpressionRef = usize;\r\nexport type GlobalRef = usize;\r\nexport type ImportRef = usize;\r\nexport type ExportRef = usize;\r\nexport type RelooperRef = usize;\r\nexport type RelooperBlockRef = usize;\r\nexport type Index = u32;\r\n\r\nexport enum NativeType {\r\n None = _BinaryenTypeNone(),\r\n I32 = _BinaryenTypeInt32(),\r\n I64 = _BinaryenTypeInt64(),\r\n F32 = _BinaryenTypeFloat32(),\r\n F64 = _BinaryenTypeFloat64(),\r\n V128 = _BinaryenTypeVec128(),\r\n Unreachable = _BinaryenTypeUnreachable(),\r\n Auto = _BinaryenTypeAuto()\r\n}\r\n\r\nexport enum FeatureFlags {\r\n Atomics = _BinaryenFeatureAtomics(),\r\n MutableGloabls = _BinaryenFeatureMutableGlobals(),\r\n NontrappingFPToInt = _BinaryenFeatureNontrappingFPToInt(),\r\n SIMD128 = _BinaryenFeatureSIMD128(),\r\n BulkMemory = _BinaryenFeatureBulkMemory(),\r\n SignExt = _BinaryenFeatureSignExt(),\r\n ExceptionHandling = _BinaryenFeatureExceptionHandling()\r\n}\r\n\r\nexport enum ExpressionId {\r\n Invalid = _BinaryenInvalidId(),\r\n Block = _BinaryenBlockId(),\r\n If = _BinaryenIfId(),\r\n Loop = _BinaryenLoopId(),\r\n Break = _BinaryenBreakId(),\r\n Switch = _BinaryenSwitchId(),\r\n Call = _BinaryenCallId(),\r\n CallIndirect = _BinaryenCallIndirectId(),\r\n LocalGet = _BinaryenLocalGetId(),\r\n LocalSet = _BinaryenLocalSetId(),\r\n GlobalGet = _BinaryenGlobalGetId(),\r\n GlobalSet = _BinaryenGlobalSetId(),\r\n Load = _BinaryenLoadId(),\r\n Store = _BinaryenStoreId(),\r\n Const = _BinaryenConstId(),\r\n Unary = _BinaryenUnaryId(),\r\n Binary = _BinaryenBinaryId(),\r\n Select = _BinaryenSelectId(),\r\n Drop = _BinaryenDropId(),\r\n Return = _BinaryenReturnId(),\r\n Host = _BinaryenHostId(),\r\n Nop = _BinaryenNopId(),\r\n Unreachable = _BinaryenUnreachableId(),\r\n AtomicCmpxchg = _BinaryenAtomicCmpxchgId(),\r\n AtomicRMW = _BinaryenAtomicRMWId(),\r\n AtomicWait = _BinaryenAtomicWaitId(),\r\n AtomicNotify = _BinaryenAtomicNotifyId(),\r\n SIMDExtract = _BinaryenSIMDExtractId(),\r\n SIMDReplace = _BinaryenSIMDReplaceId(),\r\n SIMDShuffle = _BinaryenSIMDShuffleId(),\r\n SIMDBitselect = _BinaryenSIMDBitselectId(),\r\n SIMDShift = _BinaryenSIMDShiftId(),\r\n MemoryInit = _BinaryenMemoryInitId(),\r\n DataDrop = _BinaryenDataDropId(),\r\n MemoryCopy = _BinaryenMemoryCopyId(),\r\n MemoryFill = _BinaryenMemoryFillId()\r\n}\r\n\r\nexport enum UnaryOp {\r\n ClzI32 = _BinaryenClzInt32(),\r\n CtzI32 = _BinaryenCtzInt32(),\r\n PopcntI32 = _BinaryenPopcntInt32(),\r\n NegF32 = _BinaryenNegFloat32(),\r\n AbsF32 = _BinaryenAbsFloat32(),\r\n CeilF32 = _BinaryenCeilFloat32(),\r\n FloorF32 = _BinaryenFloorFloat32(),\r\n TruncF32 = _BinaryenTruncFloat32(),\r\n NearestF32 = _BinaryenNearestFloat32(),\r\n SqrtF32 = _BinaryenSqrtFloat32(),\r\n EqzI32 = _BinaryenEqZInt32(),\r\n ClzI64 = _BinaryenClzInt64(),\r\n CtzI64 = _BinaryenCtzInt64(),\r\n PopcntI64 = _BinaryenPopcntInt64(),\r\n NegF64 = _BinaryenNegFloat64(),\r\n AbsF64 = _BinaryenAbsFloat64(),\r\n CeilF64 = _BinaryenCeilFloat64(),\r\n FloorF64 = _BinaryenFloorFloat64(),\r\n TruncF64 = _BinaryenTruncFloat64(),\r\n NearestF64 = _BinaryenNearestFloat64(),\r\n SqrtF64 = _BinaryenSqrtFloat64(),\r\n EqzI64 = _BinaryenEqZInt64(),\r\n ExtendI32 = _BinaryenExtendSInt32(),\r\n ExtendU32 = _BinaryenExtendUInt32(),\r\n WrapI64 = _BinaryenWrapInt64(),\r\n TruncF32ToI32 = _BinaryenTruncSFloat32ToInt32(),\r\n TruncF32ToI64 = _BinaryenTruncSFloat32ToInt64(),\r\n TruncF32ToU32 = _BinaryenTruncUFloat32ToInt32(),\r\n TruncF32ToU64 = _BinaryenTruncUFloat32ToInt64(),\r\n TruncF64ToI32 = _BinaryenTruncSFloat64ToInt32(),\r\n TruncF64ToI64 = _BinaryenTruncSFloat64ToInt64(),\r\n TruncF64ToU32 = _BinaryenTruncUFloat64ToInt32(),\r\n TruncF64ToU64 = _BinaryenTruncUFloat64ToInt64(),\r\n ReinterpretF32 = _BinaryenReinterpretFloat32(),\r\n ReinterpretF64 = _BinaryenReinterpretFloat64(),\r\n ConvertI32ToF32 = _BinaryenConvertSInt32ToFloat32(),\r\n ConvertI32ToF64 = _BinaryenConvertSInt32ToFloat64(),\r\n ConvertU32ToF32 = _BinaryenConvertUInt32ToFloat32(),\r\n ConvertU32ToF64 = _BinaryenConvertUInt32ToFloat64(),\r\n ConvertI64ToF32 = _BinaryenConvertSInt64ToFloat32(),\r\n ConvertI64ToF64 = _BinaryenConvertSInt64ToFloat64(),\r\n ConvertU64ToF32 = _BinaryenConvertUInt64ToFloat32(),\r\n ConvertU64ToF64 = _BinaryenConvertUInt64ToFloat64(),\r\n PromoteF32 = _BinaryenPromoteFloat32(),\r\n DemoteF64 = _BinaryenDemoteFloat64(),\r\n ReinterpretI32 = _BinaryenReinterpretInt32(),\r\n ReinterpretI64 = _BinaryenReinterpretInt64(),\r\n\r\n // see: https://github.com/WebAssembly/sign-extension-ops\r\n ExtendI8ToI32 = _BinaryenExtendS8Int32(),\r\n ExtendI16ToI32 = _BinaryenExtendS16Int32(),\r\n ExtendI8ToI64 = _BinaryenExtendS8Int64(),\r\n ExtendI16ToI64 = _BinaryenExtendS16Int64(),\r\n ExtendI32ToI64 = _BinaryenExtendS32Int64(),\r\n\r\n // see: https://github.com/WebAssembly/nontrapping-float-to-int-conversions\r\n // TruncF32ToI32Sat\r\n // TruncF32ToU32Sat\r\n // TruncF64ToI32Sat\r\n // TruncF64ToU32Sat\r\n // TruncF32ToI64Sat\r\n // TruncF32ToU64Sat\r\n // TruncF64ToI64Sat\r\n // TruncF64ToU64Sat\r\n\r\n // see: https://github.com/WebAssembly/simd\r\n SplatVecI8x16 = _BinaryenSplatVecI8x16(),\r\n SplatVecI16x8 = _BinaryenSplatVecI16x8(),\r\n SplatVecI32x4 = _BinaryenSplatVecI32x4(),\r\n SplatVecI64x2 = _BinaryenSplatVecI64x2(),\r\n SplatVecF32x4 = _BinaryenSplatVecF32x4(),\r\n SplatVecF64x2 = _BinaryenSplatVecF64x2(),\r\n NotVec128 = _BinaryenNotVec128(),\r\n NegVecI8x16 = _BinaryenNegVecI8x16(),\r\n AnyTrueVecI8x16 = _BinaryenAnyTrueVecI8x16(),\r\n AllTrueVecI8x16 = _BinaryenAllTrueVecI8x16(),\r\n NegVecI16x8 = _BinaryenNegVecI16x8(),\r\n AnyTrueVecI16x8 = _BinaryenAnyTrueVecI16x8(),\r\n AllTrueVecI16x8 = _BinaryenAllTrueVecI16x8(),\r\n NegVecI32x4 = _BinaryenNegVecI32x4(),\r\n AnyTrueVecI32x4 = _BinaryenAnyTrueVecI32x4(),\r\n AllTrueVecI32x4 = _BinaryenAllTrueVecI32x4(),\r\n NegVecI64x2 = _BinaryenNegVecI64x2(),\r\n AnyTrueVecI64x2 = _BinaryenAnyTrueVecI64x2(),\r\n AllTrueVecI64x2 = _BinaryenAllTrueVecI64x2(),\r\n AbsVecF32x4 = _BinaryenAbsVecF32x4(),\r\n NegVecF32x4 = _BinaryenNegVecF32x4(),\r\n SqrtVecF32x4 = _BinaryenSqrtVecF32x4(),\r\n AbsVecF64x2 = _BinaryenAbsVecF64x2(),\r\n NegVecF64x2 = _BinaryenNegVecF64x2(),\r\n SqrtVecF64x2 = _BinaryenSqrtVecF64x2(),\r\n TruncSatSVecF32x4ToVecI32x4 = _BinaryenTruncSatSVecF32x4ToVecI32x4(),\r\n TruncSatUVecF32x4ToVecI32x4 = _BinaryenTruncSatUVecF32x4ToVecI32x4(),\r\n TruncSatSVecF64x2ToVecI64x2 = _BinaryenTruncSatSVecF64x2ToVecI64x2(),\r\n TruncSatUVecF64x2ToVecI64x2 = _BinaryenTruncSatUVecF64x2ToVecI64x2(),\r\n ConvertSVecI32x4ToVecF32x4 = _BinaryenConvertSVecI32x4ToVecF32x4(),\r\n ConvertUVecI32x4ToVecF32x4 = _BinaryenConvertUVecI32x4ToVecF32x4(),\r\n ConvertSVecI64x2ToVecF64x2 = _BinaryenConvertSVecI64x2ToVecF64x2(),\r\n ConvertUVecI64x2ToVecF64x2 = _BinaryenConvertUVecI64x2ToVecF64x2()\r\n}\r\n\r\nexport enum BinaryOp {\r\n AddI32 = _BinaryenAddInt32(),\r\n SubI32 = _BinaryenSubInt32(),\r\n MulI32 = _BinaryenMulInt32(),\r\n DivI32 = _BinaryenDivSInt32(),\r\n DivU32 = _BinaryenDivUInt32(),\r\n RemI32 = _BinaryenRemSInt32(),\r\n RemU32 = _BinaryenRemUInt32(),\r\n AndI32 = _BinaryenAndInt32(),\r\n OrI32 = _BinaryenOrInt32(),\r\n XorI32 = _BinaryenXorInt32(),\r\n ShlI32 = _BinaryenShlInt32(),\r\n ShrU32 = _BinaryenShrUInt32(),\r\n ShrI32 = _BinaryenShrSInt32(),\r\n RotlI32 = _BinaryenRotLInt32(),\r\n RotrI32 = _BinaryenRotRInt32(),\r\n EqI32 = _BinaryenEqInt32(),\r\n NeI32 = _BinaryenNeInt32(),\r\n LtI32 = _BinaryenLtSInt32(),\r\n LtU32 = _BinaryenLtUInt32(),\r\n LeI32 = _BinaryenLeSInt32(),\r\n LeU32 = _BinaryenLeUInt32(),\r\n GtI32 = _BinaryenGtSInt32(),\r\n GtU32 = _BinaryenGtUInt32(),\r\n GeI32 = _BinaryenGeSInt32(),\r\n GeU32 = _BinaryenGeUInt32(),\r\n AddI64 = _BinaryenAddInt64(),\r\n SubI64 = _BinaryenSubInt64(),\r\n MulI64 = _BinaryenMulInt64(),\r\n DivI64 = _BinaryenDivSInt64(),\r\n DivU64 = _BinaryenDivUInt64(),\r\n RemI64 = _BinaryenRemSInt64(),\r\n RemU64 = _BinaryenRemUInt64(),\r\n AndI64 = _BinaryenAndInt64(),\r\n OrI64 = _BinaryenOrInt64(),\r\n XorI64 = _BinaryenXorInt64(),\r\n ShlI64 = _BinaryenShlInt64(),\r\n ShrU64 = _BinaryenShrUInt64(),\r\n ShrI64 = _BinaryenShrSInt64(),\r\n RotlI64 = _BinaryenRotLInt64(),\r\n RotrI64 = _BinaryenRotRInt64(),\r\n EqI64 = _BinaryenEqInt64(),\r\n NeI64 = _BinaryenNeInt64(),\r\n LtI64 = _BinaryenLtSInt64(),\r\n LtU64 = _BinaryenLtUInt64(),\r\n LeI64 = _BinaryenLeSInt64(),\r\n LeU64 = _BinaryenLeUInt64(),\r\n GtI64 = _BinaryenGtSInt64(),\r\n GtU64 = _BinaryenGtUInt64(),\r\n GeI64 = _BinaryenGeSInt64(),\r\n GeU64 = _BinaryenGeUInt64(),\r\n AddF32 = _BinaryenAddFloat32(),\r\n SubF32 = _BinaryenSubFloat32(),\r\n MulF32 = _BinaryenMulFloat32(),\r\n DivF32 = _BinaryenDivFloat32(),\r\n CopysignF32 = _BinaryenCopySignFloat32(),\r\n MinF32 = _BinaryenMinFloat32(),\r\n MaxF32 = _BinaryenMaxFloat32(),\r\n EqF32 = _BinaryenEqFloat32(),\r\n NeF32 = _BinaryenNeFloat32(),\r\n LtF32 = _BinaryenLtFloat32(),\r\n LeF32 = _BinaryenLeFloat32(),\r\n GtF32 = _BinaryenGtFloat32(),\r\n GeF32 = _BinaryenGeFloat32(),\r\n AddF64 = _BinaryenAddFloat64(),\r\n SubF64 = _BinaryenSubFloat64(),\r\n MulF64 = _BinaryenMulFloat64(),\r\n DivF64 = _BinaryenDivFloat64(),\r\n CopysignF64 = _BinaryenCopySignFloat64(),\r\n MinF64 = _BinaryenMinFloat64(),\r\n MaxF64 = _BinaryenMaxFloat64(),\r\n EqF64 = _BinaryenEqFloat64(),\r\n NeF64 = _BinaryenNeFloat64(),\r\n LtF64 = _BinaryenLtFloat64(),\r\n LeF64 = _BinaryenLeFloat64(),\r\n GtF64 = _BinaryenGtFloat64(),\r\n GeF64 = _BinaryenGeFloat64(),\r\n\r\n // see: https://github.com/WebAssembly/simd\r\n EqVecI8x16 = _BinaryenEqVecI8x16(),\r\n NeVecI8x16 = _BinaryenNeVecI8x16(),\r\n LtSVecI8x16 = _BinaryenLtSVecI8x16(),\r\n LtUVecI8x16 = _BinaryenLtUVecI8x16(),\r\n LeSVecI8x16 = _BinaryenLeSVecI8x16(),\r\n LeUVecI8x16 = _BinaryenLeUVecI8x16(),\r\n GtSVecI8x16 = _BinaryenGtSVecI8x16(),\r\n GtUVecI8x16 = _BinaryenGtUVecI8x16(),\r\n GeSVecI8x16 = _BinaryenGeSVecI8x16(),\r\n GeUVecI8x16 = _BinaryenGeUVecI8x16(),\r\n EqVecI16x8 = _BinaryenEqVecI16x8(),\r\n NeVecI16x8 = _BinaryenNeVecI16x8(),\r\n LtSVecI16x8 = _BinaryenLtSVecI16x8(),\r\n LtUVecI16x8 = _BinaryenLtUVecI16x8(),\r\n LeSVecI16x8 = _BinaryenLeSVecI16x8(),\r\n LeUVecI16x8 = _BinaryenLeUVecI16x8(),\r\n GtSVecI16x8 = _BinaryenGtSVecI16x8(),\r\n GtUVecI16x8 = _BinaryenGtUVecI16x8(),\r\n GeSVecI16x8 = _BinaryenGeSVecI16x8(),\r\n GeUVecI16x8 = _BinaryenGeUVecI16x8(),\r\n EqVecI32x4 = _BinaryenEqVecI32x4(),\r\n NeVecI32x4 = _BinaryenNeVecI32x4(),\r\n LtSVecI32x4 = _BinaryenLtSVecI32x4(),\r\n LtUVecI32x4 = _BinaryenLtUVecI32x4(),\r\n LeSVecI32x4 = _BinaryenLeSVecI32x4(),\r\n LeUVecI32x4 = _BinaryenLeUVecI32x4(),\r\n GtSVecI32x4 = _BinaryenGtSVecI32x4(),\r\n GtUVecI32x4 = _BinaryenGtUVecI32x4(),\r\n GeSVecI32x4 = _BinaryenGeSVecI32x4(),\r\n GeUVecI32x4 = _BinaryenGeUVecI32x4(),\r\n EqVecF32x4 = _BinaryenEqVecF32x4(),\r\n NeVecF32x4 = _BinaryenNeVecF32x4(),\r\n LtVecF32x4 = _BinaryenLtVecF32x4(),\r\n LeVecF32x4 = _BinaryenLeVecF32x4(),\r\n GtVecF32x4 = _BinaryenGtVecF32x4(),\r\n GeVecF32x4 = _BinaryenGeVecF32x4(),\r\n EqVecF64x2 = _BinaryenEqVecF64x2(),\r\n NeVecF64x2 = _BinaryenNeVecF64x2(),\r\n LtVecF64x2 = _BinaryenLtVecF64x2(),\r\n LeVecF64x2 = _BinaryenLeVecF64x2(),\r\n GtVecF64x2 = _BinaryenGtVecF64x2(),\r\n GeVecF64x2 = _BinaryenGeVecF64x2(),\r\n AndVec128 = _BinaryenAndVec128(),\r\n OrVec128 = _BinaryenOrVec128(),\r\n XorVec128 = _BinaryenXorVec128(),\r\n AddVecI8x16 = _BinaryenAddVecI8x16(),\r\n AddSatSVecI8x16 = _BinaryenAddSatSVecI8x16(),\r\n AddSatUVecI8x16 = _BinaryenAddSatUVecI8x16(),\r\n SubVecI8x16 = _BinaryenSubVecI8x16(),\r\n SubSatSVecI8x16 = _BinaryenSubSatSVecI8x16(),\r\n SubSatUVecI8x16 = _BinaryenSubSatUVecI8x16(),\r\n MulVecI8x16 = _BinaryenMulVecI8x16(),\r\n AddVecI16x8 = _BinaryenAddVecI16x8(),\r\n AddSatSVecI16x8 = _BinaryenAddSatSVecI16x8(),\r\n AddSatUVecI16x8 = _BinaryenAddSatUVecI16x8(),\r\n SubVecI16x8 = _BinaryenSubVecI16x8(),\r\n SubSatSVecI16x8 = _BinaryenSubSatSVecI16x8(),\r\n SubSatUVecI16x8 = _BinaryenSubSatUVecI16x8(),\r\n MulVecI16x8 = _BinaryenMulVecI16x8(),\r\n AddVecI32x4 = _BinaryenAddVecI32x4(),\r\n SubVecI32x4 = _BinaryenSubVecI32x4(),\r\n MulVecI32x4 = _BinaryenMulVecI32x4(),\r\n AddVecI64x2 = _BinaryenAddVecI64x2(),\r\n SubVecI64x2 = _BinaryenSubVecI64x2(),\r\n AddVecF32x4 = _BinaryenAddVecF32x4(),\r\n SubVecF32x4 = _BinaryenSubVecF32x4(),\r\n MulVecF32x4 = _BinaryenMulVecF32x4(),\r\n DivVecF32x4 = _BinaryenDivVecF32x4(),\r\n MinVecF32x4 = _BinaryenMinVecF32x4(),\r\n MaxVecF32x4 = _BinaryenMaxVecF32x4(),\r\n AddVecF64x2 = _BinaryenAddVecF64x2(),\r\n SubVecF64x2 = _BinaryenSubVecF64x2(),\r\n MulVecF64x2 = _BinaryenMulVecF64x2(),\r\n DivVecF64x2 = _BinaryenDivVecF64x2(),\r\n MinVecF64x2 = _BinaryenMinVecF64x2(),\r\n MaxVecF64x2 = _BinaryenMaxVecF64x2()\r\n}\r\n\r\nexport enum HostOp {\r\n MemorySize = _BinaryenMemorySize(),\r\n MemoryGrow = _BinaryenMemoryGrow(),\r\n}\r\n\r\nexport enum AtomicRMWOp {\r\n Add = _BinaryenAtomicRMWAdd(),\r\n Sub = _BinaryenAtomicRMWSub(),\r\n And = _BinaryenAtomicRMWAnd(),\r\n Or = _BinaryenAtomicRMWOr(),\r\n Xor = _BinaryenAtomicRMWXor(),\r\n Xchg = _BinaryenAtomicRMWXchg()\r\n}\r\n\r\nexport enum SIMDExtractOp {\r\n ExtractLaneSVecI8x16 = _BinaryenExtractLaneSVecI8x16(),\r\n ExtractLaneUVecI8x16 = _BinaryenExtractLaneUVecI8x16(),\r\n ExtractLaneSVecI16x8 = _BinaryenExtractLaneSVecI16x8(),\r\n ExtractLaneUVecI16x8 = _BinaryenExtractLaneUVecI16x8(),\r\n ExtractLaneVecI32x4 = _BinaryenExtractLaneVecI32x4(),\r\n ExtractLaneVecI64x2 = _BinaryenExtractLaneVecI64x2(),\r\n ExtractLaneVecF32x4 = _BinaryenExtractLaneVecF32x4(),\r\n ExtractLaneVecF64x2 = _BinaryenExtractLaneVecF64x2(),\r\n}\r\n\r\nexport enum SIMDReplaceOp {\r\n ReplaceLaneVecI8x16 = _BinaryenReplaceLaneVecI8x16(),\r\n ReplaceLaneVecI16x8 = _BinaryenReplaceLaneVecI16x8(),\r\n ReplaceLaneVecI32x4 = _BinaryenReplaceLaneVecI32x4(),\r\n ReplaceLaneVecI64x2 = _BinaryenReplaceLaneVecI64x2(),\r\n ReplaceLaneVecF32x4 = _BinaryenReplaceLaneVecF32x4(),\r\n ReplaceLaneVecF64x2 = _BinaryenReplaceLaneVecF64x2()\r\n}\r\n\r\nexport enum SIMDShiftOp {\r\n ShlVecI8x16 = _BinaryenShlVecI8x16(),\r\n ShrSVecI8x16 = _BinaryenShrSVecI8x16(),\r\n ShrUVecI8x16 = _BinaryenShrUVecI8x16(),\r\n ShlVecI16x8 = _BinaryenShlVecI16x8(),\r\n ShrSVecI16x8 = _BinaryenShrSVecI16x8(),\r\n ShrUVecI16x8 = _BinaryenShrUVecI16x8(),\r\n ShlVecI32x4 = _BinaryenShlVecI32x4(),\r\n ShrSVecI32x4 = _BinaryenShrSVecI32x4(),\r\n ShrUVecI32x4 = _BinaryenShrUVecI32x4(),\r\n ShlVecI64x2 = _BinaryenShlVecI64x2(),\r\n ShrSVecI64x2 = _BinaryenShrSVecI64x2(),\r\n ShrUVecI64x2 = _BinaryenShrUVecI64x2()\r\n}\r\n\r\nexport class MemorySegment {\r\n\r\n buffer: Uint8Array;\r\n offset: I64;\r\n\r\n static create(buffer: Uint8Array, offset: I64): MemorySegment {\r\n var segment = new MemorySegment();\r\n segment.buffer = buffer;\r\n segment.offset = offset;\r\n return segment;\r\n }\r\n}\r\n\r\nexport class Module {\r\n\r\n ref: ModuleRef;\r\n\r\n private lit: usize;\r\n\r\n static create(): Module {\r\n var module = new Module();\r\n module.ref = _BinaryenModuleCreate();\r\n module.lit = memory.allocate(_BinaryenSizeofLiteral());\r\n return module;\r\n }\r\n\r\n static createFrom(buffer: Uint8Array): Module {\r\n var cArr = allocU8Array(buffer);\r\n try {\r\n let module = new Module();\r\n module.ref = _BinaryenModuleRead(cArr, buffer.length);\r\n module.lit = memory.allocate(_BinaryenSizeofLiteral());\r\n return module;\r\n } finally {\r\n memory.free(changetype(cArr));\r\n }\r\n }\r\n\r\n private constructor() { }\r\n\r\n // types\r\n\r\n addFunctionType(\r\n name: string,\r\n result: NativeType,\r\n paramTypes: NativeType[] | null\r\n ): FunctionRef {\r\n var cStr = this.allocStringCached(name);\r\n var cArr = allocI32Array(paramTypes);\r\n try {\r\n return _BinaryenAddFunctionType(this.ref, cStr, result, cArr, paramTypes ? paramTypes.length : 0);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n getFunctionTypeBySignature(\r\n result: NativeType,\r\n paramTypes: NativeType[] | null\r\n ): FunctionTypeRef {\r\n var cArr = allocI32Array(paramTypes);\r\n try {\r\n return _BinaryenGetFunctionTypeBySignature(this.ref, result, cArr, paramTypes ? paramTypes.length : 0);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n removeFunctionType(name: string): void {\r\n var cStr = this.allocStringCached(name);\r\n _BinaryenRemoveFunctionType(this.ref, cStr);\r\n }\r\n\r\n // constants\r\n\r\n i32(value: i32): ExpressionRef {\r\n var out = this.lit;\r\n _BinaryenLiteralInt32(out, value);\r\n return _BinaryenConst(this.ref, out);\r\n }\r\n\r\n i64(valueLow: i32, valueHigh: i32 = 0): ExpressionRef {\r\n var out = this.lit;\r\n _BinaryenLiteralInt64(out, valueLow, valueHigh);\r\n return _BinaryenConst(this.ref, out);\r\n }\r\n\r\n f32(value: f32): ExpressionRef {\r\n var out = this.lit;\r\n _BinaryenLiteralFloat32(out, value);\r\n return _BinaryenConst(this.ref, out);\r\n }\r\n\r\n f64(value: f64): ExpressionRef {\r\n var out = this.lit;\r\n _BinaryenLiteralFloat64(out, value);\r\n return _BinaryenConst(this.ref, out);\r\n }\r\n\r\n v128(bytes: Uint8Array): ExpressionRef {\r\n assert(bytes.length == 16);\r\n var out = this.lit;\r\n for (let i = 0; i < 16; ++i) store(out + i, bytes[i]);\r\n _BinaryenLiteralVec128(out, out);\r\n return _BinaryenConst(this.ref, out);\r\n }\r\n\r\n // expressions\r\n\r\n unary(\r\n op: UnaryOp,\r\n expr: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenUnary(this.ref, op, expr);\r\n }\r\n\r\n binary(\r\n op: BinaryOp,\r\n left: ExpressionRef,\r\n right: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenBinary(this.ref, op, left, right);\r\n }\r\n\r\n host(\r\n op: HostOp,\r\n name: string | null = null,\r\n operands: ExpressionRef[] | null = null\r\n ): ExpressionRef {\r\n var cStr = this.allocStringCached(name);\r\n var cArr = allocPtrArray(operands);\r\n try {\r\n return _BinaryenHost(this.ref, op, cStr, cArr, operands ? (operands).length : 0);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n local_get(\r\n index: i32,\r\n type: NativeType\r\n ): ExpressionRef {\r\n return _BinaryenLocalGet(this.ref, index, type);\r\n }\r\n\r\n local_tee(\r\n index: i32,\r\n value: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenLocalTee(this.ref, index, value);\r\n }\r\n\r\n global_get(\r\n name: string,\r\n type: NativeType\r\n ): ExpressionRef {\r\n var cStr = this.allocStringCached(name);\r\n return _BinaryenGlobalGet(this.ref, cStr, type);\r\n }\r\n\r\n load(\r\n bytes: Index,\r\n signed: bool,\r\n ptr: ExpressionRef,\r\n type: NativeType,\r\n offset: Index = 0,\r\n align: Index = bytes // naturally aligned by default\r\n ): ExpressionRef {\r\n return _BinaryenLoad(this.ref, bytes, signed ? 1 : 0, offset, align, type, ptr);\r\n }\r\n\r\n store(\r\n bytes: Index,\r\n ptr: ExpressionRef,\r\n value: ExpressionRef,\r\n type: NativeType,\r\n offset: Index = 0,\r\n align: Index = bytes // naturally aligned by default\r\n ): ExpressionRef {\r\n if (type < NativeType.None || type > NativeType.V128) throw new Error(\"here: \" + type);\r\n return _BinaryenStore(this.ref, bytes, offset, align, ptr, value, type);\r\n }\r\n\r\n atomic_load(\r\n bytes: Index,\r\n ptr: ExpressionRef,\r\n type: NativeType,\r\n offset: Index = 0\r\n ): ExpressionRef {\r\n return _BinaryenAtomicLoad(this.ref, bytes, offset, type, ptr);\r\n }\r\n\r\n atomic_store(\r\n bytes: Index,\r\n ptr: ExpressionRef,\r\n value: ExpressionRef,\r\n type: NativeType,\r\n offset: Index = 0\r\n ): ExpressionRef {\r\n return _BinaryenAtomicStore(this.ref, bytes, offset, ptr, value, type);\r\n }\r\n\r\n atomic_rmw(\r\n op: AtomicRMWOp,\r\n bytes: Index,\r\n offset: Index,\r\n ptr: ExpressionRef,\r\n value: ExpressionRef,\r\n type: NativeType\r\n ): ExpressionRef {\r\n return _BinaryenAtomicRMW(this.ref, op, bytes, offset, ptr, value, type);\r\n }\r\n\r\n atomic_cmpxchg(\r\n bytes: Index,\r\n offset: Index,\r\n ptr: ExpressionRef,\r\n expected: ExpressionRef,\r\n replacement: ExpressionRef,\r\n type: NativeType\r\n ): ExpressionRef {\r\n return _BinaryenAtomicCmpxchg(this.ref, bytes, offset, ptr, expected, replacement, type);\r\n }\r\n\r\n atomic_wait(\r\n ptr: ExpressionRef,\r\n expected: ExpressionRef,\r\n timeout: ExpressionRef,\r\n expectedType: NativeType\r\n ): ExpressionRef {\r\n return _BinaryenAtomicWait(this.ref, ptr, expected, timeout, expectedType);\r\n }\r\n\r\n atomic_notify(\r\n ptr: ExpressionRef,\r\n notifyCount: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenAtomicNotify(this.ref, ptr, notifyCount);\r\n }\r\n\r\n // statements\r\n\r\n local_set(\r\n index: Index,\r\n value: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenLocalSet(this.ref, index, value);\r\n }\r\n\r\n global_set(\r\n name: string,\r\n value: ExpressionRef\r\n ): ExpressionRef {\r\n var cStr = this.allocStringCached(name);\r\n return _BinaryenGlobalSet(this.ref, cStr, value);\r\n }\r\n\r\n block(\r\n label: string | null,\r\n children: ExpressionRef[],\r\n type: NativeType = NativeType.None\r\n ): ExpressionRef {\r\n var cStr = this.allocStringCached(label);\r\n var cArr = allocPtrArray(children);\r\n try {\r\n return _BinaryenBlock(this.ref, cStr, cArr, children.length, type);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n br(\r\n label: string | null,\r\n condition: ExpressionRef = 0,\r\n value: ExpressionRef = 0\r\n ): ExpressionRef {\r\n var cStr = this.allocStringCached(label);\r\n return _BinaryenBreak(this.ref, cStr, condition, value);\r\n }\r\n\r\n drop(\r\n expression: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenDrop(this.ref, expression);\r\n }\r\n\r\n loop(\r\n label: string | null,\r\n body: ExpressionRef\r\n ): ExpressionRef {\r\n var cStr = this.allocStringCached(label);\r\n return _BinaryenLoop(this.ref, cStr, body);\r\n }\r\n\r\n if(\r\n condition: ExpressionRef,\r\n ifTrue: ExpressionRef,\r\n ifFalse: ExpressionRef = 0\r\n ): ExpressionRef {\r\n return _BinaryenIf(this.ref, condition, ifTrue, ifFalse);\r\n }\r\n\r\n nop(): ExpressionRef {\r\n return _BinaryenNop(this.ref);\r\n }\r\n\r\n return(\r\n expression: ExpressionRef = 0\r\n ): ExpressionRef {\r\n return _BinaryenReturn(this.ref, expression);\r\n }\r\n\r\n select(\r\n ifTrue: ExpressionRef,\r\n ifFalse: ExpressionRef,\r\n condition: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenSelect(this.ref, condition, ifTrue, ifFalse);\r\n }\r\n\r\n switch(\r\n names: string[],\r\n defaultName: string | null,\r\n condition: ExpressionRef,\r\n value: ExpressionRef = 0\r\n ): ExpressionRef {\r\n var numNames = names.length;\r\n var strs = new Array(numNames);\r\n for (let i = 0; i < numNames; ++i) {\r\n strs[i] = this.allocStringCached(names[i]);\r\n }\r\n var cArr = allocI32Array(strs);\r\n var cStr = this.allocStringCached(defaultName);\r\n try {\r\n return _BinaryenSwitch(this.ref, cArr, numNames, cStr, condition, value);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n call(\r\n target: string,\r\n operands: ExpressionRef[] | null,\r\n returnType: NativeType\r\n ): ExpressionRef {\r\n var cStr = this.allocStringCached(target);\r\n var cArr = allocPtrArray(operands);\r\n try {\r\n return _BinaryenCall(this.ref, cStr, cArr, operands && operands.length || 0, returnType);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n call_indirect(\r\n index: ExpressionRef,\r\n operands: ExpressionRef[] | null,\r\n typeName: string\r\n ): ExpressionRef {\r\n var cStr = this.allocStringCached(typeName);\r\n var cArr = allocPtrArray(operands);\r\n try {\r\n return _BinaryenCallIndirect(this.ref, index, cArr, operands && operands.length || 0, cStr);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n unreachable(): ExpressionRef {\r\n return _BinaryenUnreachable(this.ref);\r\n }\r\n\r\n // bulk memory\r\n\r\n memory_copy(\r\n dest: ExpressionRef,\r\n source: ExpressionRef,\r\n size: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenMemoryCopy(this.ref, dest, source, size);\r\n }\r\n\r\n memory_fill(\r\n dest: ExpressionRef,\r\n value: ExpressionRef,\r\n size: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenMemoryFill(this.ref, dest, value, size);\r\n }\r\n\r\n // simd\r\n\r\n simd_extract(\r\n op: SIMDExtractOp,\r\n vec: ExpressionRef,\r\n idx: u8\r\n ): ExpressionRef {\r\n return _BinaryenSIMDExtract(this.ref, op, vec, idx);\r\n }\r\n\r\n simd_replace(\r\n op: SIMDReplaceOp,\r\n vec: ExpressionRef,\r\n idx: u8,\r\n value: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenSIMDReplace(this.ref, op, vec, idx, value);\r\n }\r\n\r\n simd_shuffle(\r\n vec1: ExpressionRef,\r\n vec2: ExpressionRef,\r\n mask: Uint8Array\r\n ): ExpressionRef {\r\n assert(mask.length == 16);\r\n var cArr = allocU8Array(mask);\r\n try {\r\n return _BinaryenSIMDShuffle(this.ref, vec1, vec2, cArr);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n simd_bitselect(\r\n vec1: ExpressionRef,\r\n vec2: ExpressionRef,\r\n cond: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenSIMDBitselect(this.ref, vec1, vec2, cond);\r\n }\r\n\r\n simd_shift(\r\n op: SIMDShiftOp,\r\n vec: ExpressionRef,\r\n shift: ExpressionRef\r\n ): ExpressionRef {\r\n return _BinaryenSIMDShift(this.ref, op, vec, shift);\r\n }\r\n\r\n // meta\r\n\r\n addGlobal(\r\n name: string,\r\n type: NativeType,\r\n mutable: bool,\r\n initializer: ExpressionRef\r\n ): GlobalRef {\r\n var cStr = this.allocStringCached(name);\r\n return _BinaryenAddGlobal(this.ref, cStr, type, mutable ? 1 : 0, initializer);\r\n }\r\n\r\n removeGlobal(\r\n name: string\r\n ): void {\r\n var cStr = this.allocStringCached(name);\r\n _BinaryenRemoveGlobal(this.ref, cStr);\r\n }\r\n\r\n addFunction(\r\n name: string,\r\n type: FunctionTypeRef,\r\n varTypes: NativeType[] | null,\r\n body: ExpressionRef\r\n ): FunctionRef {\r\n var cStr = this.allocStringCached(name);\r\n var cArr = allocI32Array(varTypes);\r\n try {\r\n return _BinaryenAddFunction(this.ref, cStr, type, cArr, varTypes ? varTypes.length : 0, body);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n removeFunction(name: string): void {\r\n var cStr = this.allocStringCached(name);\r\n _BinaryenRemoveFunction(this.ref, cStr);\r\n }\r\n\r\n private hasTemporaryFunction: bool = false;\r\n\r\n addTemporaryFunction(result: NativeType, paramTypes: NativeType[] | null, body: ExpressionRef): FunctionRef {\r\n this.hasTemporaryFunction = assert(!this.hasTemporaryFunction);\r\n var tempName = this.allocStringCached(\"\");\r\n var cArr = allocI32Array(paramTypes);\r\n try {\r\n let typeRef = _BinaryenAddFunctionType(this.ref, tempName, result, cArr, paramTypes ? paramTypes.length : 0);\r\n return _BinaryenAddFunction(this.ref, tempName, typeRef, 0, 0, body);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n removeTemporaryFunction(): void {\r\n this.hasTemporaryFunction = !assert(this.hasTemporaryFunction);\r\n var tempName = this.allocStringCached(\"\");\r\n _BinaryenRemoveFunction(this.ref, tempName);\r\n _BinaryenRemoveFunctionType(this.ref, tempName);\r\n }\r\n\r\n addFunctionExport(\r\n internalName: string,\r\n externalName: string\r\n ): ExportRef {\r\n var cStr1 = this.allocStringCached(internalName);\r\n var cStr2 = this.allocStringCached(externalName);\r\n return _BinaryenAddFunctionExport(this.ref, cStr1, cStr2);\r\n }\r\n\r\n addTableExport(\r\n internalName: string,\r\n externalName: string\r\n ): ExportRef {\r\n var cStr1 = this.allocStringCached(internalName);\r\n var cStr2 = this.allocStringCached(externalName);\r\n return _BinaryenAddTableExport(this.ref, cStr1, cStr2);\r\n }\r\n\r\n addMemoryExport(\r\n internalName: string,\r\n externalName: string\r\n ): ExportRef {\r\n var cStr1 = this.allocStringCached(internalName);\r\n var cStr2 = this.allocStringCached(externalName);\r\n return _BinaryenAddMemoryExport(this.ref, cStr1, cStr2);\r\n }\r\n\r\n addGlobalExport(\r\n internalName: string,\r\n externalName: string\r\n ): ExportRef {\r\n var cStr1 = this.allocStringCached(internalName);\r\n var cStr2 = this.allocStringCached(externalName);\r\n return _BinaryenAddGlobalExport(this.ref, cStr1, cStr2);\r\n }\r\n\r\n removeExport(externalName: string): void {\r\n var cStr = this.allocStringCached(externalName);\r\n _BinaryenRemoveExport(this.ref, cStr);\r\n }\r\n\r\n addFunctionImport(\r\n internalName: string,\r\n externalModuleName: string,\r\n externalBaseName: string,\r\n functionType: FunctionTypeRef\r\n ): ImportRef {\r\n var cStr1 = this.allocStringCached(internalName);\r\n var cStr2 = this.allocStringCached(externalModuleName);\r\n var cStr3 = this.allocStringCached(externalBaseName);\r\n return _BinaryenAddFunctionImport(this.ref, cStr1, cStr2, cStr3, functionType);\r\n }\r\n\r\n addTableImport(\r\n internalName: string,\r\n externalModuleName: string,\r\n externalBaseName: string\r\n ): ImportRef {\r\n var cStr1 = this.allocStringCached(internalName);\r\n var cStr2 = this.allocStringCached(externalModuleName);\r\n var cStr3 = this.allocStringCached(externalBaseName);\r\n return _BinaryenAddTableImport(this.ref, cStr1, cStr2, cStr3);\r\n }\r\n\r\n addMemoryImport(\r\n internalName: string,\r\n externalModuleName: string,\r\n externalBaseName: string,\r\n shared: bool = false,\r\n ): ImportRef {\r\n var cStr1 = this.allocStringCached(internalName);\r\n var cStr2 = this.allocStringCached(externalModuleName);\r\n var cStr3 = this.allocStringCached(externalBaseName);\r\n return _BinaryenAddMemoryImport(this.ref, cStr1, cStr2, cStr3, shared);\r\n }\r\n\r\n addGlobalImport(\r\n internalName: string,\r\n externalModuleName: string,\r\n externalBaseName: string,\r\n globalType: NativeType\r\n ): ImportRef {\r\n var cStr1 = this.allocStringCached(internalName);\r\n var cStr2 = this.allocStringCached(externalModuleName);\r\n var cStr3 = this.allocStringCached(externalBaseName);\r\n return _BinaryenAddGlobalImport(this.ref, cStr1, cStr2, cStr3, globalType);\r\n }\r\n\r\n /** Unlimited memory constant. */\r\n static readonly UNLIMITED_MEMORY: Index = -1;\r\n\r\n setMemory(\r\n initial: Index,\r\n maximum: Index,\r\n segments: MemorySegment[],\r\n target: Target,\r\n exportName: string | null = null,\r\n shared: bool = false\r\n ): void {\r\n var cStr = this.allocStringCached(exportName);\r\n var k = segments.length;\r\n var segs = new Array(k);\r\n var psvs = new Array(k);\r\n var offs = new Array(k);\r\n var sizs = new Array(k);\r\n for (let i = 0; i < k; ++i) {\r\n let buffer = segments[i].buffer;\r\n let offset = segments[i].offset;\r\n segs[i] = allocU8Array(buffer);\r\n psvs[i] = 0; // no passive segments currently\r\n offs[i] = target == Target.WASM64\r\n ? this.i64(i64_low(offset), i64_high(offset))\r\n : this.i32(i64_low(offset));\r\n sizs[i] = buffer.length;\r\n }\r\n var cArr1 = allocI32Array(segs);\r\n var cArr2 = allocU8Array(psvs);\r\n var cArr3 = allocI32Array(offs);\r\n var cArr4 = allocI32Array(sizs);\r\n try {\r\n _BinaryenSetMemory(this.ref, initial, maximum, cStr, cArr1, cArr2, cArr3, cArr4, k, shared);\r\n } finally {\r\n memory.free(cArr4);\r\n memory.free(cArr3);\r\n memory.free(cArr2);\r\n memory.free(cArr1);\r\n for (let i = k - 1; i >= 0; --i) memory.free(segs[i]);\r\n }\r\n }\r\n\r\n setFunctionTable(\r\n initial: Index,\r\n maximum: Index,\r\n funcs: string[]\r\n ): void {\r\n var numNames = funcs.length;\r\n var names = new Array(numNames);\r\n for (let i = 0; i < numNames; ++i) {\r\n names[i] = this.allocStringCached(funcs[i]);\r\n }\r\n var cArr = allocI32Array(names);\r\n try {\r\n _BinaryenSetFunctionTable(this.ref, initial, maximum, cArr, numNames);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n setStart(func: FunctionRef): void {\r\n _BinaryenSetStart(this.ref, func);\r\n }\r\n\r\n getOptimizeLevel(): i32 {\r\n return _BinaryenGetOptimizeLevel();\r\n }\r\n\r\n setOptimizeLevel(level: i32 = 2): void {\r\n _BinaryenSetOptimizeLevel(level);\r\n }\r\n\r\n getShrinkLevel(): i32 {\r\n return _BinaryenGetShrinkLevel();\r\n }\r\n\r\n setShrinkLevel(level: i32 = 1): void {\r\n _BinaryenSetShrinkLevel(level);\r\n }\r\n\r\n setDebugInfo(on: bool = false): void {\r\n _BinaryenSetDebugInfo(on);\r\n }\r\n\r\n getFeatures(): BinaryenFeatureFlags {\r\n return _BinaryenModuleGetFeatures(this.ref);\r\n }\r\n\r\n setFeatures(featureFlags: BinaryenFeatureFlags): void {\r\n _BinaryenModuleSetFeatures(this.ref, featureFlags);\r\n }\r\n\r\n optimize(func: FunctionRef = 0): void {\r\n if (func) {\r\n _BinaryenFunctionOptimize(func, this.ref);\r\n } else {\r\n _BinaryenModuleOptimize(this.ref);\r\n }\r\n }\r\n\r\n runPasses(passes: string[], func: FunctionRef = 0): void {\r\n var numNames = passes.length;\r\n var names = new Array(numNames);\r\n for (let i = 0; i < numNames; ++i) {\r\n names[i] = allocString(passes[i]);\r\n }\r\n var cArr = allocI32Array(names);\r\n try {\r\n if (func) {\r\n _BinaryenFunctionRunPasses(func, this.ref, cArr, numNames);\r\n } else {\r\n _BinaryenModuleRunPasses(this.ref, cArr, numNames);\r\n }\r\n } finally {\r\n memory.free(cArr);\r\n for (let i = numNames; i >= 0; --i) memory.free(names[i]);\r\n }\r\n }\r\n\r\n private cachedPrecomputeNames: usize = 0;\r\n\r\n precomputeExpression(expr: ExpressionRef): ExpressionRef {\r\n // remember the previous optimize levels and set to max instead, to be sure\r\n var previousOptimizeLevel = _BinaryenGetOptimizeLevel();\r\n var previousShrinkLevel = _BinaryenGetShrinkLevel();\r\n var previousDebugInfo = _BinaryenGetDebugInfo();\r\n _BinaryenSetOptimizeLevel(4);\r\n _BinaryenSetShrinkLevel(0);\r\n _BinaryenSetDebugInfo(false);\r\n\r\n // wrap the expression in a temp. function and run the precompute pass on it\r\n var type = _BinaryenExpressionGetType(expr);\r\n var func = this.addTemporaryFunction(type, null, expr);\r\n var names = this.cachedPrecomputeNames;\r\n if (!names) {\r\n this.cachedPrecomputeNames = names = allocI32Array([ this.allocStringCached(\"precompute\") ]);\r\n }\r\n _BinaryenFunctionRunPasses(func, this.ref, names, 1);\r\n expr = _BinaryenFunctionGetBody(func);\r\n this.removeTemporaryFunction();\r\n\r\n // reset optimize levels to previous\r\n _BinaryenSetOptimizeLevel(previousOptimizeLevel);\r\n _BinaryenSetShrinkLevel(previousShrinkLevel);\r\n _BinaryenSetDebugInfo(previousDebugInfo);\r\n return expr;\r\n }\r\n\r\n validate(): bool {\r\n return _BinaryenModuleValidate(this.ref) == 1;\r\n }\r\n\r\n interpret(): void {\r\n _BinaryenModuleInterpret(this.ref);\r\n }\r\n\r\n toBinary(sourceMapUrl: string | null): BinaryModule {\r\n var out = this.lit; // safe to reuse as long as..\r\n assert(_BinaryenSizeofLiteral() >= 12);\r\n var cStr = allocString(sourceMapUrl);\r\n var binaryPtr: usize = 0;\r\n var sourceMapPtr: usize = 0;\r\n try {\r\n _BinaryenModuleAllocateAndWrite(out, this.ref, cStr);\r\n binaryPtr = readInt(out);\r\n let binaryBytes = readInt(out + 4);\r\n sourceMapPtr = readInt(out + 4 * 2);\r\n let ret = new BinaryModule();\r\n ret.output = readBuffer(binaryPtr, binaryBytes);\r\n ret.sourceMap = readString(sourceMapPtr);\r\n return ret;\r\n } finally {\r\n if (cStr) memory.free(cStr);\r\n if (binaryPtr) memory.free(binaryPtr);\r\n if (sourceMapPtr) memory.free(sourceMapPtr);\r\n }\r\n }\r\n\r\n toText(): string {\r\n throw new Error(\"not implemented\"); // JS glue overrides this\r\n }\r\n\r\n toAsmjs(): string {\r\n throw new Error(\"not implemented\"); // JS glue overrides this\r\n }\r\n\r\n private cachedStrings: Map = new Map();\r\n\r\n private allocStringCached(str: string | null): usize {\r\n if (str == null) return 0;\r\n var cachedStrings = this.cachedStrings;\r\n if (cachedStrings.has(str)) return cachedStrings.get(str);\r\n var ptr = allocString(str);\r\n cachedStrings.set(str, ptr);\r\n return ptr;\r\n }\r\n\r\n dispose(): void {\r\n assert(this.ref);\r\n for (let ptr of this.cachedStrings.values()) memory.free(ptr);\r\n this.cachedStrings = new Map();\r\n memory.free(this.lit);\r\n memory.free(this.cachedPrecomputeNames);\r\n this.cachedPrecomputeNames = 0;\r\n _BinaryenModuleDispose(this.ref);\r\n this.ref = 0;\r\n }\r\n\r\n createRelooper(): Relooper {\r\n return Relooper.create(this);\r\n }\r\n\r\n cloneExpression(\r\n expr: ExpressionRef,\r\n noSideEffects: bool = false,\r\n maxDepth: i32 = i32.MAX_VALUE\r\n ): ExpressionRef { // currently supports side effect free expressions only\r\n if (maxDepth < 0) return 0;\r\n maxDepth -= 1;\r\n\r\n var nested1: ExpressionRef,\r\n nested2: ExpressionRef;\r\n\r\n switch (_BinaryenExpressionGetId(expr)) {\r\n case ExpressionId.Const: {\r\n switch (_BinaryenExpressionGetType(expr)) {\r\n case NativeType.I32: {\r\n return this.i32(_BinaryenConstGetValueI32(expr));\r\n }\r\n case NativeType.I64: {\r\n return this.i64(\r\n _BinaryenConstGetValueI64Low(expr),\r\n _BinaryenConstGetValueI64High(expr)\r\n );\r\n }\r\n case NativeType.F32: {\r\n return this.f32(_BinaryenConstGetValueF32(expr));\r\n }\r\n case NativeType.F64: {\r\n return this.f64(_BinaryenConstGetValueF64(expr));\r\n }\r\n case NativeType.V128: {\r\n // TODO\r\n return 0;\r\n }\r\n default: {\r\n throw new Error(\"concrete type expected\");\r\n }\r\n }\r\n }\r\n case ExpressionId.LocalGet: {\r\n return _BinaryenLocalGet(this.ref,\r\n _BinaryenLocalGetGetIndex(expr),\r\n _BinaryenExpressionGetType(expr)\r\n );\r\n }\r\n case ExpressionId.GlobalGet: {\r\n let globalName = _BinaryenGlobalGetGetName(expr);\r\n if (!globalName) break;\r\n return _BinaryenGlobalGet(this.ref, globalName, _BinaryenExpressionGetType(expr));\r\n }\r\n case ExpressionId.Load: {\r\n if (!(nested1 = this.cloneExpression(_BinaryenLoadGetPtr(expr), noSideEffects, maxDepth))) {\r\n break;\r\n }\r\n return (\r\n _BinaryenLoadIsAtomic(expr)\r\n ? _BinaryenAtomicLoad(this.ref,\r\n _BinaryenLoadGetBytes(expr),\r\n _BinaryenLoadGetOffset(expr),\r\n _BinaryenExpressionGetType(expr),\r\n nested1\r\n )\r\n : _BinaryenLoad(this.ref,\r\n _BinaryenLoadGetBytes(expr),\r\n _BinaryenLoadIsSigned(expr) ? 1 : 0,\r\n _BinaryenLoadGetOffset(expr),\r\n _BinaryenLoadGetAlign(expr),\r\n _BinaryenExpressionGetType(expr),\r\n nested1\r\n )\r\n );\r\n }\r\n case ExpressionId.Unary: {\r\n if (!(nested1 = this.cloneExpression(_BinaryenUnaryGetValue(expr), noSideEffects, maxDepth))) {\r\n break;\r\n }\r\n return _BinaryenUnary(this.ref, _BinaryenUnaryGetOp(expr), nested1);\r\n }\r\n case ExpressionId.Binary: {\r\n if (!(nested1 = this.cloneExpression(_BinaryenBinaryGetLeft(expr), noSideEffects, maxDepth))) {\r\n break;\r\n }\r\n if (!(nested2 = this.cloneExpression(_BinaryenBinaryGetRight(expr), noSideEffects, maxDepth))) {\r\n break;\r\n }\r\n return _BinaryenBinary(this.ref, _BinaryenBinaryGetOp(expr), nested1, nested2);\r\n }\r\n }\r\n return 0;\r\n }\r\n\r\n // source map generation\r\n\r\n addDebugInfoFile(name: string): Index {\r\n var cStr = allocString(name);\r\n try {\r\n return _BinaryenModuleAddDebugInfoFileName(this.ref, cStr);\r\n } finally {\r\n memory.free(cStr);\r\n }\r\n }\r\n\r\n getDebugInfoFile(index: Index): string | null {\r\n return readString(_BinaryenModuleGetDebugInfoFileName(this.ref, index));\r\n }\r\n\r\n setDebugLocation(\r\n func: FunctionRef,\r\n expr: ExpressionRef,\r\n fileIndex: Index,\r\n lineNumber: Index,\r\n columnNumber: Index\r\n ): void {\r\n _BinaryenFunctionSetDebugLocation(func, expr, fileIndex, lineNumber, columnNumber);\r\n }\r\n}\r\n\r\n// expressions\r\n\r\nexport function getExpressionId(expr: ExpressionRef): ExpressionId {\r\n return _BinaryenExpressionGetId(expr);\r\n}\r\n\r\nexport function getExpressionType(expr: ExpressionRef): NativeType {\r\n return _BinaryenExpressionGetType(expr);\r\n}\r\n\r\nexport function getConstValueI32(expr: ExpressionRef): i32 {\r\n return _BinaryenConstGetValueI32(expr);\r\n}\r\n\r\nexport function getConstValueI64Low(expr: ExpressionRef): i32 {\r\n return _BinaryenConstGetValueI64Low(expr);\r\n}\r\n\r\nexport function getConstValueI64High(expr: ExpressionRef): i32 {\r\n return _BinaryenConstGetValueI64High(expr);\r\n}\r\n\r\nexport function getConstValueF32(expr: ExpressionRef): f32 {\r\n return _BinaryenConstGetValueF32(expr);\r\n}\r\n\r\nexport function getConstValueF64(expr: ExpressionRef): f32 {\r\n return _BinaryenConstGetValueF64(expr);\r\n}\r\n\r\nexport function getLocalGetIndex(expr: ExpressionRef): Index {\r\n return _BinaryenLocalGetGetIndex(expr);\r\n}\r\n\r\nexport function getLocalSetIndex(expr: ExpressionRef): Index {\r\n return _BinaryenLocalSetGetIndex(expr);\r\n}\r\n\r\nexport function getLocalSetValue(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenLocalSetGetValue(expr);\r\n}\r\n\r\nexport function isLocalTee(expr: ExpressionRef): bool {\r\n return _BinaryenLocalSetIsTee(expr);\r\n}\r\n\r\nexport function getGlobalGetName(expr: ExpressionRef): string | null {\r\n return readString(_BinaryenGlobalGetGetName(expr));\r\n}\r\n\r\nexport function getBinaryOp(expr: ExpressionRef): BinaryOp {\r\n return _BinaryenBinaryGetOp(expr);\r\n}\r\n\r\nexport function getBinaryLeft(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenBinaryGetLeft(expr);\r\n}\r\n\r\nexport function getBinaryRight(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenBinaryGetRight(expr);\r\n}\r\n\r\nexport function getUnaryOp(expr: ExpressionRef): UnaryOp {\r\n return _BinaryenUnaryGetOp(expr);\r\n}\r\n\r\nexport function getUnaryValue(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenUnaryGetValue(expr);\r\n}\r\n\r\nexport function getLoadBytes(expr: ExpressionRef): u32 {\r\n return _BinaryenLoadGetBytes(expr);\r\n}\r\n\r\nexport function getLoadOffset(expr: ExpressionRef): u32 {\r\n return _BinaryenLoadGetOffset(expr);\r\n}\r\n\r\nexport function getLoadPtr(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenLoadGetPtr(expr);\r\n}\r\n\r\nexport function isLoadSigned(expr: ExpressionRef): bool {\r\n return _BinaryenLoadIsSigned(expr);\r\n}\r\n\r\nexport function getStoreBytes(expr: ExpressionRef): u32 {\r\n return _BinaryenStoreGetBytes(expr);\r\n}\r\n\r\nexport function getStoreOffset(expr: ExpressionRef): u32 {\r\n return _BinaryenStoreGetOffset(expr);\r\n}\r\n\r\nexport function getStorePtr(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenStoreGetPtr(expr);\r\n}\r\n\r\nexport function getStoreValue(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenStoreGetValue(expr);\r\n}\r\n\r\nexport function getBlockName(expr: ExpressionRef): string | null {\r\n return readString(_BinaryenBlockGetName(expr));\r\n}\r\n\r\nexport function getBlockChildCount(expr: ExpressionRef): Index {\r\n return _BinaryenBlockGetNumChildren(expr);\r\n}\r\n\r\nexport function getBlockChild(expr: ExpressionRef, index: Index): ExpressionRef {\r\n return _BinaryenBlockGetChild(expr, index);\r\n}\r\n\r\nexport function getIfCondition(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenIfGetCondition(expr);\r\n}\r\n\r\nexport function getIfTrue(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenIfGetIfTrue(expr);\r\n}\r\n\r\nexport function getIfFalse(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenIfGetIfFalse(expr);\r\n}\r\n\r\nexport function getLoopName(expr: ExpressionRef): string | null {\r\n return readString(_BinaryenLoopGetName(expr));\r\n}\r\n\r\nexport function getLoopBody(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenLoopGetBody(expr);\r\n}\r\n\r\nexport function getBreakName(expr: ExpressionRef): string | null {\r\n return readString(_BinaryenBreakGetName(expr));\r\n}\r\n\r\nexport function getBreakCondition(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenBreakGetCondition(expr);\r\n}\r\n\r\nexport function getSelectThen(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenSelectGetIfTrue(expr);\r\n}\r\n\r\nexport function getSelectElse(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenSelectGetIfFalse(expr);\r\n}\r\n\r\nexport function getSelectCondition(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenSelectGetCondition(expr);\r\n}\r\n\r\nexport function getDropValue(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenDropGetValue(expr);\r\n}\r\n\r\nexport function getReturnValue(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenReturnGetValue(expr);\r\n}\r\n\r\nexport function getCallTarget(expr: ExpressionRef): string | null {\r\n return readString(_BinaryenCallGetTarget(expr));\r\n}\r\n\r\nexport function getCallOperandCount(expr: ExpressionRef): i32 {\r\n return _BinaryenCallGetNumOperands(expr);\r\n}\r\n\r\nexport function getCallOperand(expr: ExpressionRef, index: Index): ExpressionRef {\r\n return _BinaryenCallGetOperand(expr, index);\r\n}\r\n\r\nexport function getHostOp(expr: ExpressionRef): ExpressionRef {\r\n return _BinaryenHostGetOp(expr);\r\n}\r\n\r\nexport function getHostOperandCount(expr: ExpressionRef): Index {\r\n return _BinaryenHostGetNumOperands(expr);\r\n}\r\n\r\nexport function getHostOperand(expr: ExpressionRef, index: Index): ExpressionRef {\r\n return _BinaryenHostGetOperand(expr, index);\r\n}\r\n\r\nexport function getHostName(expr: ExpressionRef): string | null {\r\n return readString(_BinaryenHostGetNameOperand(expr));\r\n}\r\n\r\n// functions\r\n\r\nexport function getFunctionBody(func: FunctionRef): ExpressionRef {\r\n return _BinaryenFunctionGetBody(func);\r\n}\r\n\r\nexport function getFunctionName(func: FunctionRef): string | null {\r\n return readString(_BinaryenFunctionGetName(func));\r\n}\r\n\r\nexport function getFunctionParamCount(func: FunctionRef): Index {\r\n return _BinaryenFunctionGetNumParams(func);\r\n}\r\n\r\nexport function getFunctionParamType(func: FunctionRef, index: Index): NativeType {\r\n return _BinaryenFunctionGetParam(func, index);\r\n}\r\n\r\nexport function getFunctionResultType(func: FunctionRef): NativeType {\r\n return _BinaryenFunctionGetResult(func);\r\n}\r\n\r\nexport class Relooper {\r\n\r\n module: Module;\r\n ref: RelooperRef;\r\n\r\n static create(module: Module): Relooper {\r\n var relooper = new Relooper();\r\n relooper.module = module;\r\n relooper.ref = _RelooperCreate(module.ref);\r\n return relooper;\r\n }\r\n\r\n private constructor() {}\r\n\r\n addBlock(code: ExpressionRef): RelooperBlockRef {\r\n return _RelooperAddBlock(this.ref, code);\r\n }\r\n\r\n addBranch(\r\n from: RelooperBlockRef,\r\n to: RelooperBlockRef,\r\n condition: ExpressionRef = 0,\r\n code: ExpressionRef = 0\r\n ): void {\r\n _RelooperAddBranch(from, to, condition, code);\r\n }\r\n\r\n addBlockWithSwitch(code: ExpressionRef, condition: ExpressionRef): RelooperBlockRef {\r\n return _RelooperAddBlockWithSwitch(this.ref, code, condition);\r\n }\r\n\r\n addBranchForSwitch(\r\n from: RelooperBlockRef,\r\n to: RelooperBlockRef,\r\n indexes: i32[],\r\n code: ExpressionRef = 0\r\n ): void {\r\n var cArr = allocI32Array(indexes);\r\n try {\r\n _RelooperAddBranchForSwitch(from, to, cArr, indexes.length, code);\r\n } finally {\r\n memory.free(cArr);\r\n }\r\n }\r\n\r\n renderAndDispose(entry: RelooperBlockRef, labelHelper: Index): ExpressionRef {\r\n return _RelooperRenderAndDispose(this.ref, entry, labelHelper);\r\n }\r\n}\r\n\r\n// export function hasSideEffects(expr: ExpressionRef): bool {\r\n// switch (_BinaryenExpressionGetId(expr = getPtr(expr))) {\r\n// case ExpressionId.GetLocal:\r\n// case ExpressionId.GetGlobal:\r\n// case ExpressionId.Const:\r\n// case ExpressionId.Nop:\r\n// case ExpressionId.Unreachable: {\r\n// return false;\r\n// }\r\n// case ExpressionId.Block: {\r\n// for (let i = 0, k = _BinaryenBlockGetNumChildren(expr); i < k; ++i) {\r\n// if (hasSideEffects(_BinaryenBlockGetChild(expr, i))) return true;\r\n// }\r\n// return false;\r\n// }\r\n// case ExpressionId.If: {\r\n// return hasSideEffects(_BinaryenIfGetCondition(expr))\r\n// || hasSideEffects(_BinaryenIfGetIfTrue(expr))\r\n// || hasSideEffects(_BinaryenIfGetIfFalse(expr));\r\n// }\r\n// case ExpressionId.Unary: {\r\n// return hasSideEffects(_BinaryenUnaryGetValue(expr));\r\n// }\r\n// case ExpressionId.Binary: {\r\n// return hasSideEffects(_BinaryenBinaryGetLeft(expr))\r\n// || hasSideEffects(_BinaryenBinaryGetRight(expr));\r\n// }\r\n// case ExpressionId.Drop: {\r\n// return hasSideEffects(_BinaryenDropGetValue(expr));\r\n// }\r\n// case ExpressionId.Select: {\r\n// return hasSideEffects(_BinaryenSelectGetIfTrue(expr))\r\n// || hasSideEffects(_BinaryenSelectGetIfFalse(expr))\r\n// || hasSideEffects(_BinaryenSelectGetCondition(expr));\r\n// }\r\n// }\r\n// return true;\r\n// }\r\n\r\n// helpers\r\n// can't do stack allocation here: STACKTOP is a global in WASM but a hidden variable in asm.js\r\n\r\nfunction allocU8Array(u8s: Uint8Array | null): usize {\r\n if (!u8s) return 0;\r\n var numValues = u8s.length;\r\n var ptr = memory.allocate(numValues);\r\n var idx = ptr;\r\n for (let i = 0; i < numValues; ++i) {\r\n store(idx++, u8s[i]);\r\n }\r\n return ptr;\r\n}\r\n\r\nfunction allocI32Array(i32s: i32[] | null): usize {\r\n if (!i32s) return 0;\r\n var ptr = memory.allocate(i32s.length << 2);\r\n var idx = ptr;\r\n for (let i = 0, k = i32s.length; i < k; ++i) {\r\n let val = i32s[i];\r\n // store(idx, val) is not portable\r\n store(idx , ( val & 0xff) as u8);\r\n store(idx + 1, ((val >> 8) & 0xff) as u8);\r\n store(idx + 2, ((val >> 16) & 0xff) as u8);\r\n store(idx + 3, ( val >>> 24 ) as u8);\r\n idx += 4;\r\n }\r\n return ptr;\r\n}\r\n\r\nfunction allocPtrArray(ptrs: usize[] | null): usize {\r\n return allocI32Array(ptrs); // TODO: WASM64 one day\r\n}\r\n\r\nfunction stringLengthUTF8(str: string): usize {\r\n var len = 0;\r\n for (let i = 0, k = str.length; i < k; ++i) {\r\n let u = str.charCodeAt(i);\r\n if (u >= 0xD800 && u <= 0xDFFF && i + 1 < k) {\r\n u = 0x10000 + ((u & 0x3FF) << 10) | (str.charCodeAt(++i) & 0x3FF);\r\n }\r\n if (u <= 0x7F) {\r\n ++len;\r\n } else if (u <= 0x7FF) {\r\n len += 2;\r\n } else if (u <= 0xFFFF) {\r\n len += 3;\r\n } else if (u <= 0x1FFFFF) {\r\n len += 4;\r\n } else if (u <= 0x3FFFFFF) {\r\n len += 5;\r\n } else {\r\n len += 6;\r\n }\r\n }\r\n return len;\r\n}\r\n\r\nfunction allocString(str: string | null): usize {\r\n if (str == null) return 0;\r\n var ptr = memory.allocate(stringLengthUTF8(str) + 1);\r\n // the following is based on Emscripten's stringToUTF8Array\r\n var idx = ptr;\r\n for (let i = 0, k = str.length; i < k; ++i) {\r\n let u = str.charCodeAt(i);\r\n if (u >= 0xD800 && u <= 0xDFFF && i + 1 < k) {\r\n u = 0x10000 + ((u & 0x3FF) << 10) | (str.charCodeAt(++i) & 0x3FF);\r\n }\r\n if (u <= 0x7F) {\r\n store(idx++, u as u8);\r\n } else if (u <= 0x7FF) {\r\n store(idx++, (0xC0 | (u >>> 6) ) as u8);\r\n store(idx++, (0x80 | ( u & 63)) as u8);\r\n } else if (u <= 0xFFFF) {\r\n store(idx++, (0xE0 | (u >>> 12) ) as u8);\r\n store(idx++, (0x80 | ((u >>> 6) & 63)) as u8);\r\n store(idx++, (0x80 | ( u & 63)) as u8);\r\n } else if (u <= 0x1FFFFF) {\r\n store(idx++, (0xF0 | (u >>> 18) ) as u8);\r\n store(idx++, (0x80 | ((u >>> 12) & 63)) as u8);\r\n store(idx++, (0x80 | ((u >>> 6) & 63)) as u8);\r\n store(idx++, (0x80 | ( u & 63)) as u8);\r\n } else if (u <= 0x3FFFFFF) {\r\n store(idx++, (0xF8 | (u >>> 24) ) as u8);\r\n store(idx++, (0x80 | ((u >>> 18) & 63)) as u8);\r\n store(idx++, (0x80 | ((u >>> 12) & 63)) as u8);\r\n store(idx++, (0x80 | ((u >>> 6) & 63)) as u8);\r\n store(idx++, (0x80 | ( u & 63)) as u8);\r\n } else {\r\n store(idx++, (0xFC | (u >>> 30) ) as u8);\r\n store(idx++, (0x80 | ((u >>> 24) & 63)) as u8);\r\n store(idx++, (0x80 | ((u >>> 18) & 63)) as u8);\r\n store(idx++, (0x80 | ((u >>> 12) & 63)) as u8);\r\n store(idx++, (0x80 | ((u >>> 6) & 63)) as u8);\r\n store(idx++, (0x80 | ( u & 63)) as u8);\r\n }\r\n }\r\n store(idx, 0);\r\n return ptr;\r\n}\r\n\r\nfunction readInt(ptr: usize): i32 {\r\n return (\r\n load(ptr ) |\r\n (load(ptr + 1) << 8) |\r\n (load(ptr + 2) << 16) |\r\n (load(ptr + 3) << 24)\r\n );\r\n}\r\n\r\nfunction readBuffer(ptr: usize, length: usize): Uint8Array {\r\n var ret = new Uint8Array(length);\r\n for (let i: usize = 0; i < length; ++i) {\r\n ret[i] = load(ptr + i);\r\n }\r\n return ret;\r\n}\r\n\r\nexport function readString(ptr: usize): string | null {\r\n if (!ptr) return null;\r\n var arr = new Array();\r\n // the following is based on Emscripten's UTF8ArrayToString\r\n var cp: u32;\r\n var u1: u32, u2: u32, u3: u32, u4: u32, u5: u32;\r\n while (cp = load(ptr++)) {\r\n if (!(cp & 0x80)) {\r\n arr.push(cp);\r\n continue;\r\n }\r\n u1 = load(ptr++) & 63;\r\n if ((cp & 0xE0) == 0xC0) {\r\n arr.push(((cp & 31) << 6) | u1);\r\n continue;\r\n }\r\n u2 = load(ptr++) & 63;\r\n if ((cp & 0xF0) == 0xE0) {\r\n cp = ((cp & 15) << 12) | (u1 << 6) | u2;\r\n } else {\r\n u3 = load(ptr++) & 63;\r\n if ((cp & 0xF8) == 0xF0) {\r\n cp = ((cp & 7) << 18) | (u1 << 12) | (u2 << 6) | u3;\r\n } else {\r\n u4 = load(ptr++) & 63;\r\n if ((cp & 0xFC) == 0xF8) {\r\n cp = ((cp & 3) << 24) | (u1 << 18) | (u2 << 12) | (u3 << 6) | u4;\r\n } else {\r\n u5 = load(ptr++) & 63;\r\n cp = ((cp & 1) << 30) | (u1 << 24) | (u2 << 18) | (u3 << 12) | (u4 << 6) | u5;\r\n }\r\n }\r\n }\r\n arr.push(cp);\r\n // if (cp < 0x10000) {\r\n // arr.push(cp);\r\n // } else {\r\n // var ch = cp - 0x10000;\r\n // arr.push(0xD800 | (ch >> 10));\r\n // arr.push(0xDC00 | (ch & 0x3FF));\r\n // }\r\n }\r\n // return String.fromCharCodes(arr);\r\n return String.fromCodePoints(arr);\r\n}\r\n\r\n/** Result structure of {@link Module#toBinary}. */\r\nexport class BinaryModule {\r\n /** WebAssembly binary. */\r\n output: Uint8Array;\r\n /** Source map, if generated. */\r\n sourceMap: string | null;\r\n}\r\n\r\n/** Tests if an expression needs an explicit 'unreachable' when it is the terminating statement. */\r\nexport function needsExplicitUnreachable(expr: ExpressionRef): bool {\r\n // not applicable if pushing a value to the stack\r\n if (_BinaryenExpressionGetType(expr) != NativeType.Unreachable) return false;\r\n\r\n switch (_BinaryenExpressionGetId(expr)) {\r\n case ExpressionId.Unreachable:\r\n case ExpressionId.Return: return false;\r\n case ExpressionId.Break: return _BinaryenBreakGetCondition(expr) != 0;\r\n case ExpressionId.Block: {\r\n if (!_BinaryenBlockGetName(expr)) { // can't break out of it\r\n let numChildren = _BinaryenBlockGetNumChildren(expr); // last child needs unreachable\r\n return numChildren > 0 && needsExplicitUnreachable(_BinaryenBlockGetChild(expr, numChildren - 1));\r\n }\r\n }\r\n }\r\n return true;\r\n}\r\n\r\n/** Traverses all expression members of an expression, calling the given visitor. */\r\nexport function traverse(expr: ExpressionRef, data: T, visit: (expr: ExpressionRef, data: T) => void): bool {\r\n switch (getExpressionId(expr)) {\r\n case ExpressionId.Block: {\r\n for (let i = 0, n = _BinaryenBlockGetNumChildren(expr); i < n; ++i) {\r\n visit(_BinaryenBlockGetChild(expr, i), data);\r\n }\r\n break;\r\n }\r\n case ExpressionId.If: {\r\n visit(_BinaryenIfGetCondition(expr), data);\r\n visit(_BinaryenIfGetIfTrue(expr), data);\r\n let ifFalse = _BinaryenIfGetIfFalse(expr);\r\n if (ifFalse) visit(ifFalse, data);\r\n break;\r\n }\r\n case ExpressionId.Loop: {\r\n visit(_BinaryenLoopGetBody(expr), data);\r\n break;\r\n }\r\n case ExpressionId.Break: {\r\n let condition = _BinaryenBreakGetCondition(expr);\r\n if (condition) visit(condition, data);\r\n break;\r\n }\r\n case ExpressionId.Switch: {\r\n visit(_BinaryenSwitchGetCondition(expr), data);\r\n break;\r\n }\r\n case ExpressionId.Call: {\r\n for (let i = 0, n = _BinaryenCallGetNumOperands(expr); i < n; ++i) {\r\n visit(_BinaryenCallGetOperand(expr, i), data);\r\n }\r\n break;\r\n }\r\n case ExpressionId.CallIndirect: {\r\n for (let i = 0, n = _BinaryenCallIndirectGetNumOperands(expr); i < n; ++i) {\r\n visit(_BinaryenCallIndirectGetOperand(expr, i), data);\r\n }\r\n break;\r\n }\r\n case ExpressionId.LocalGet: {\r\n break;\r\n }\r\n case ExpressionId.LocalSet: {\r\n visit(_BinaryenLocalSetGetValue(expr), data);\r\n break;\r\n }\r\n case ExpressionId.GlobalGet: {\r\n break;\r\n }\r\n case ExpressionId.GlobalSet: {\r\n visit(_BinaryenGlobalSetGetValue(expr), data);\r\n break;\r\n }\r\n case ExpressionId.Load: {\r\n visit(_BinaryenLoadGetPtr(expr), data);\r\n break;\r\n }\r\n case ExpressionId.Store: {\r\n visit(_BinaryenStoreGetPtr(expr), data);\r\n visit(_BinaryenStoreGetValue(expr), data);\r\n break;\r\n }\r\n case ExpressionId.AtomicRMW: {\r\n visit(_BinaryenAtomicRMWGetPtr(expr), data);\r\n visit(_BinaryenAtomicRMWGetValue(expr), data);\r\n break;\r\n }\r\n case ExpressionId.AtomicCmpxchg: {\r\n visit(_BinaryenAtomicCmpxchgGetPtr(expr), data);\r\n visit(_BinaryenAtomicCmpxchgGetExpected(expr), data);\r\n visit(_BinaryenAtomicCmpxchgGetReplacement(expr), data);\r\n break;\r\n }\r\n case ExpressionId.AtomicWait: {\r\n visit(_BinaryenAtomicWaitGetPtr(expr), data);\r\n visit(_BinaryenAtomicWaitGetExpected(expr), data);\r\n visit(_BinaryenAtomicWaitGetTimeout(expr), data);\r\n break;\r\n }\r\n case ExpressionId.AtomicNotify: {\r\n visit(_BinaryenAtomicNotifyGetPtr(expr), data);\r\n break;\r\n }\r\n case ExpressionId.SIMDExtract: {\r\n visit(_BinaryenSIMDExtractGetVec(expr), data);\r\n break;\r\n }\r\n case ExpressionId.SIMDReplace: {\r\n visit(_BinaryenSIMDReplaceGetVec(expr), data);\r\n visit(_BinaryenSIMDReplaceGetValue(expr), data);\r\n break;\r\n }\r\n case ExpressionId.SIMDShuffle: {\r\n visit(_BinaryenSIMDShuffleGetLeft(expr), data);\r\n visit(_BinaryenSIMDShuffleGetRight(expr), data);\r\n break;\r\n }\r\n case ExpressionId.SIMDBitselect: {\r\n visit(_BinaryenSIMDBitselectGetLeft(expr), data);\r\n visit(_BinaryenSIMDBitselectGetRight(expr), data);\r\n visit(_BinaryenSIMDBitselectGetCond(expr), data);\r\n break;\r\n }\r\n case ExpressionId.SIMDShift: {\r\n visit(_BinaryenSIMDShiftGetVec(expr), data);\r\n visit(_BinaryenSIMDShiftGetShift(expr), data);\r\n break;\r\n }\r\n case ExpressionId.MemoryInit: {\r\n visit(_BinaryenMemoryInitGetDest(expr), data);\r\n visit(_BinaryenMemoryInitGetOffset(expr), data);\r\n visit(_BinaryenMemoryInitGetSize(expr), data);\r\n break;\r\n }\r\n case ExpressionId.DataDrop: {\r\n break;\r\n }\r\n case ExpressionId.MemoryCopy: {\r\n visit(_BinaryenMemoryCopyGetDest(expr), data);\r\n visit(_BinaryenMemoryCopyGetSource(expr), data);\r\n visit(_BinaryenMemoryCopyGetSize(expr), data);\r\n break;\r\n }\r\n case ExpressionId.MemoryFill: {\r\n visit(_BinaryenMemoryFillGetDest(expr), data);\r\n visit(_BinaryenMemoryFillGetValue(expr), data);\r\n visit(_BinaryenMemoryFillGetSize(expr), data);\r\n break;\r\n }\r\n case ExpressionId.Const: {\r\n break;\r\n }\r\n case ExpressionId.Unary: {\r\n visit(_BinaryenUnaryGetValue(expr), data);\r\n break;\r\n }\r\n case ExpressionId.Binary: {\r\n visit(_BinaryenBinaryGetLeft(expr), data);\r\n visit(_BinaryenBinaryGetRight(expr), data);\r\n break;\r\n }\r\n case ExpressionId.Select: {\r\n visit(_BinaryenSelectGetIfTrue(expr), data);\r\n visit(_BinaryenSelectGetIfFalse(expr), data);\r\n visit(_BinaryenSelectGetCondition(expr), data);\r\n break;\r\n }\r\n case ExpressionId.Drop: {\r\n visit(_BinaryenDropGetValue(expr), data);\r\n break;\r\n }\r\n case ExpressionId.Return: {\r\n visit(_BinaryenReturnGetValue(expr), data);\r\n break;\r\n }\r\n case ExpressionId.Host: {\r\n for (let i = 0, n = _BinaryenHostGetNumOperands(expr); i < n; ++i) {\r\n visit(_BinaryenHostGetOperand(expr, i), data);\r\n }\r\n break;\r\n }\r\n case ExpressionId.Nop: {\r\n break;\r\n }\r\n case ExpressionId.Unreachable: {\r\n break;\r\n }\r\n default: assert(false);\r\n }\r\n return true;\r\n}\r\n","/**\r\n * Abstract syntax tree representing a source file once parsed.\r\n * @module ast\r\n *//***/\r\n\r\nimport {\r\n CommonFlags,\r\n CommonSymbols,\r\n PATH_DELIMITER,\r\n LIBRARY_PREFIX\r\n} from \"./common\";\r\n\r\nimport {\r\n Token,\r\n Tokenizer,\r\n Range\r\n} from \"./tokenizer\";\r\n\r\nimport {\r\n normalizePath,\r\n resolvePath,\r\n CharCode\r\n} from \"./util\";\r\n\r\nexport { Token, Range };\r\n\r\n/** Indicates the kind of a node. */\r\nexport enum NodeKind {\r\n\r\n SOURCE,\r\n\r\n // types\r\n TYPE,\r\n TYPENAME,\r\n TYPEPARAMETER,\r\n PARAMETER,\r\n SIGNATURE,\r\n\r\n // expressions\r\n IDENTIFIER,\r\n ASSERTION,\r\n BINARY,\r\n CALL,\r\n CLASS,\r\n COMMA,\r\n ELEMENTACCESS,\r\n FALSE,\r\n FUNCTION,\r\n INSTANCEOF,\r\n LITERAL,\r\n NEW,\r\n NULL,\r\n PARENTHESIZED,\r\n PROPERTYACCESS,\r\n TERNARY,\r\n SUPER,\r\n THIS,\r\n TRUE,\r\n CONSTRUCTOR,\r\n UNARYPOSTFIX,\r\n UNARYPREFIX,\r\n\r\n // statements\r\n BLOCK,\r\n BREAK,\r\n CONTINUE,\r\n DO,\r\n EMPTY,\r\n EXPORT,\r\n EXPORTDEFAULT,\r\n EXPORTIMPORT,\r\n EXPRESSION,\r\n FOR,\r\n IF,\r\n IMPORT,\r\n RETURN,\r\n SWITCH,\r\n THROW,\r\n TRY,\r\n VARIABLE,\r\n VOID,\r\n WHILE,\r\n\r\n // declaration statements\r\n CLASSDECLARATION,\r\n ENUMDECLARATION,\r\n ENUMVALUEDECLARATION,\r\n FIELDDECLARATION,\r\n FUNCTIONDECLARATION,\r\n IMPORTDECLARATION,\r\n INDEXSIGNATUREDECLARATION,\r\n INTERFACEDECLARATION,\r\n METHODDECLARATION,\r\n NAMESPACEDECLARATION,\r\n TYPEDECLARATION,\r\n VARIABLEDECLARATION,\r\n\r\n // special\r\n DECORATOR,\r\n EXPORTMEMBER,\r\n SWITCHCASE,\r\n COMMENT\r\n}\r\n\r\n/** Checks if a node represents a constant value. */\r\nexport function nodeIsConstantValue(kind: NodeKind): bool {\r\n switch (kind) {\r\n case NodeKind.LITERAL:\r\n case NodeKind.NULL:\r\n case NodeKind.TRUE:\r\n case NodeKind.FALSE: return true;\r\n }\r\n return false;\r\n}\r\n\r\n/** Checks if a node might be callable. */\r\nexport function nodeIsCallable(kind: NodeKind): bool {\r\n switch (kind) {\r\n case NodeKind.IDENTIFIER:\r\n case NodeKind.ASSERTION: // if kind=NONNULL\r\n case NodeKind.CALL:\r\n case NodeKind.ELEMENTACCESS:\r\n case NodeKind.PARENTHESIZED:\r\n case NodeKind.PROPERTYACCESS:\r\n case NodeKind.SUPER: return true;\r\n }\r\n return false;\r\n}\r\n\r\n/** Checks if a node might be callable with generic arguments. */\r\nexport function nodeIsGenericCallable(kind: NodeKind): bool {\r\n switch (kind) {\r\n case NodeKind.IDENTIFIER:\r\n case NodeKind.PROPERTYACCESS: return true;\r\n }\r\n return false;\r\n}\r\n\r\n/** Base class of all nodes. */\r\nexport abstract class Node {\r\n\r\n /** Node kind indicator. */\r\n kind: NodeKind;\r\n /** Source range. */\r\n range: Range;\r\n\r\n // types\r\n\r\n static createTypeName(\r\n name: IdentifierExpression,\r\n range: Range\r\n ): TypeName {\r\n var typeName = new TypeName();\r\n typeName.range = range;\r\n typeName.identifier = name;\r\n typeName.next = null;\r\n return typeName;\r\n }\r\n\r\n static createSimpleTypeName(\r\n name: string,\r\n range: Range\r\n ): TypeName {\r\n return Node.createTypeName(Node.createIdentifierExpression(name, range), range);\r\n }\r\n\r\n static createType(\r\n name: TypeName,\r\n typeArguments: CommonTypeNode[] | null,\r\n isNullable: bool,\r\n range: Range\r\n ): TypeNode {\r\n var type = new TypeNode();\r\n type.range = range;\r\n type.name = name;\r\n type.typeArguments = typeArguments;\r\n type.isNullable = isNullable;\r\n return type;\r\n }\r\n\r\n static createOmittedType(\r\n range: Range\r\n ): TypeNode {\r\n return Node.createType(\r\n Node.createSimpleTypeName(\"\", range),\r\n null,\r\n false,\r\n range\r\n );\r\n }\r\n\r\n static createTypeParameter(\r\n name: IdentifierExpression,\r\n extendsType: TypeNode | null,\r\n defaultType: TypeNode | null,\r\n range: Range\r\n ): TypeParameterNode {\r\n var elem = new TypeParameterNode();\r\n elem.range = range;\r\n elem.name = name;\r\n elem.extendsType = extendsType;\r\n elem.defaultType = defaultType;\r\n return elem;\r\n }\r\n\r\n static createParameter(\r\n name: IdentifierExpression,\r\n type: CommonTypeNode,\r\n initializer: Expression | null,\r\n kind: ParameterKind,\r\n range: Range\r\n ): ParameterNode {\r\n var elem = new ParameterNode();\r\n elem.range = range;\r\n elem.name = name;\r\n elem.type = type;\r\n elem.initializer = initializer;\r\n elem.parameterKind = kind;\r\n return elem;\r\n }\r\n\r\n static createSignature(\r\n parameters: ParameterNode[],\r\n returnType: CommonTypeNode,\r\n explicitThisType: TypeNode | null,\r\n isNullable: bool,\r\n range: Range\r\n ): SignatureNode {\r\n var sig = new SignatureNode();\r\n sig.range = range;\r\n sig.parameters = parameters;\r\n sig.returnType = returnType;\r\n sig.explicitThisType = explicitThisType;\r\n sig.isNullable = isNullable;\r\n return sig;\r\n }\r\n\r\n // special\r\n\r\n static createDecorator(\r\n name: Expression,\r\n args: Expression[] | null,\r\n range: Range\r\n ): DecoratorNode {\r\n var stmt = new DecoratorNode();\r\n stmt.range = range;\r\n stmt.name = name;\r\n stmt.arguments = args;\r\n stmt.decoratorKind = decoratorNameToKind(name);\r\n return stmt;\r\n }\r\n\r\n static createComment(\r\n text: string,\r\n kind: CommentKind,\r\n range: Range\r\n ): CommentNode {\r\n var node = new CommentNode();\r\n node.range = range;\r\n node.commentKind = kind;\r\n node.text = text;\r\n return node;\r\n }\r\n\r\n // expressions\r\n\r\n static createIdentifierExpression(\r\n name: string,\r\n range: Range,\r\n isQuoted: bool = false\r\n ): IdentifierExpression {\r\n var expr = new IdentifierExpression();\r\n expr.range = range;\r\n expr.text = name; // TODO: extract from range\r\n expr.symbol = name; // TODO: Symbol.for(name)\r\n expr.isQuoted = isQuoted;\r\n return expr;\r\n }\r\n\r\n static createEmptyIdentifierExpression(\r\n range: Range\r\n ): IdentifierExpression {\r\n var expr = new IdentifierExpression();\r\n expr.range = range;\r\n expr.text = \"\";\r\n return expr;\r\n }\r\n\r\n static createArrayLiteralExpression(\r\n elements: (Expression | null)[],\r\n range: Range\r\n ): ArrayLiteralExpression {\r\n var expr = new ArrayLiteralExpression();\r\n expr.range = range;\r\n expr.elementExpressions = elements;\r\n return expr;\r\n }\r\n\r\n static createAssertionExpression(\r\n assertionKind: AssertionKind,\r\n expression: Expression,\r\n toType: CommonTypeNode | null,\r\n range: Range\r\n ): AssertionExpression {\r\n var expr = new AssertionExpression();\r\n expr.range = range;\r\n expr.assertionKind = assertionKind;\r\n expr.expression = expression;\r\n expr.toType = toType;\r\n return expr;\r\n }\r\n\r\n static createBinaryExpression(\r\n operator: Token,\r\n left: Expression,\r\n right: Expression,\r\n range: Range\r\n ): BinaryExpression {\r\n var expr = new BinaryExpression();\r\n expr.range = range;\r\n expr.operator = operator;\r\n expr.left = left;\r\n expr.right = right;\r\n return expr;\r\n }\r\n\r\n static createCallExpression(\r\n expression: Expression,\r\n typeArgs: CommonTypeNode[] | null,\r\n args: Expression[],\r\n range: Range\r\n ): CallExpression {\r\n var expr = new CallExpression();\r\n expr.range = range;\r\n expr.expression = expression;\r\n expr.typeArguments = typeArgs;\r\n expr.arguments = args;\r\n return expr;\r\n }\r\n\r\n static createClassExpression(\r\n declaration: ClassDeclaration\r\n ): ClassExpression {\r\n var expr = new ClassExpression();\r\n expr.range = declaration.range;\r\n expr.declaration = declaration;\r\n return expr;\r\n }\r\n\r\n static createCommaExpression(\r\n expressions: Expression[],\r\n range: Range\r\n ): CommaExpression {\r\n var expr = new CommaExpression();\r\n expr.range = range;\r\n expr.expressions = expressions;\r\n return expr;\r\n }\r\n\r\n static createConstructorExpression(\r\n range: Range\r\n ): ConstructorExpression {\r\n var expr = new ConstructorExpression();\r\n expr.range = range;\r\n return expr;\r\n }\r\n\r\n static createElementAccessExpression(\r\n expression: Expression,\r\n element: Expression,\r\n range: Range\r\n ): ElementAccessExpression {\r\n var expr = new ElementAccessExpression();\r\n expr.range = range;\r\n expr.expression = expression;\r\n expr.elementExpression = element;\r\n return expr;\r\n }\r\n\r\n static createFalseExpression(\r\n range: Range\r\n ): FalseExpression {\r\n var expr = new FalseExpression();\r\n expr.range = range;\r\n return expr;\r\n }\r\n\r\n static createFloatLiteralExpression(\r\n value: f64,\r\n range: Range\r\n ): FloatLiteralExpression {\r\n var expr = new FloatLiteralExpression();\r\n expr.range = range;\r\n expr.value = value;\r\n return expr;\r\n }\r\n\r\n static createFunctionExpression(\r\n declaration: FunctionDeclaration\r\n ): FunctionExpression {\r\n var expr = new FunctionExpression();\r\n expr.range = declaration.range;\r\n expr.declaration = declaration;\r\n return expr;\r\n }\r\n\r\n static createInstanceOfExpression(\r\n expression: Expression,\r\n isType: CommonTypeNode,\r\n range: Range\r\n ): InstanceOfExpression {\r\n var expr = new InstanceOfExpression();\r\n expr.range = range;\r\n expr.expression = expression;\r\n expr.isType = isType;\r\n return expr;\r\n }\r\n\r\n static createIntegerLiteralExpression(\r\n value: I64,\r\n range: Range\r\n ): IntegerLiteralExpression {\r\n var expr = new IntegerLiteralExpression();\r\n expr.range = range;\r\n expr.value = value;\r\n return expr;\r\n }\r\n\r\n static createNewExpression(\r\n expression: Expression,\r\n typeArgs: CommonTypeNode[] | null,\r\n args: Expression[],\r\n range: Range\r\n ): NewExpression {\r\n var expr = new NewExpression();\r\n expr.range = range;\r\n expr.expression = expression;\r\n expr.typeArguments = typeArgs;\r\n expr.arguments = args;\r\n return expr;\r\n }\r\n\r\n static createNullExpression(\r\n range: Range\r\n ): NullExpression {\r\n var expr = new NullExpression();\r\n expr.range = range;\r\n return expr;\r\n }\r\n\r\n static createObjectLiteralExpression(\r\n names: IdentifierExpression[],\r\n values: Expression[],\r\n range: Range\r\n ): ObjectLiteralExpression {\r\n var expr = new ObjectLiteralExpression();\r\n expr.range = range;\r\n expr.names = names;\r\n expr.values = values;\r\n return expr;\r\n }\r\n\r\n static createParenthesizedExpression(\r\n expression: Expression,\r\n range: Range\r\n ): ParenthesizedExpression {\r\n var expr = new ParenthesizedExpression();\r\n expr.range = range;\r\n expr.expression = expression;\r\n return expr;\r\n }\r\n\r\n static createPropertyAccessExpression(\r\n expression: Expression,\r\n property: IdentifierExpression,\r\n range: Range\r\n ): PropertyAccessExpression {\r\n var expr = new PropertyAccessExpression();\r\n expr.range = range;\r\n expr.expression = expression;\r\n expr.property = property;\r\n return expr;\r\n }\r\n\r\n static createRegexpLiteralExpression(\r\n pattern: string,\r\n flags: string,\r\n range: Range\r\n ): RegexpLiteralExpression {\r\n var expr = new RegexpLiteralExpression();\r\n expr.range = range;\r\n expr.pattern = pattern;\r\n expr.patternFlags = flags;\r\n return expr;\r\n }\r\n\r\n static createTernaryExpression(\r\n condition: Expression,\r\n ifThen: Expression,\r\n ifElse: Expression,\r\n range: Range\r\n ): TernaryExpression {\r\n var expr = new TernaryExpression();\r\n expr.range = range;\r\n expr.condition = condition;\r\n expr.ifThen = ifThen;\r\n expr.ifElse = ifElse;\r\n return expr;\r\n }\r\n\r\n static createStringLiteralExpression(\r\n value: string,\r\n range: Range\r\n ): StringLiteralExpression {\r\n var expr = new StringLiteralExpression();\r\n expr.range = range;\r\n expr.value = value;\r\n return expr;\r\n }\r\n\r\n static createSuperExpression(\r\n range: Range\r\n ): SuperExpression {\r\n var expr = new SuperExpression();\r\n expr.range = range;\r\n return expr;\r\n }\r\n\r\n static createThisExpression(\r\n range: Range\r\n ): ThisExpression {\r\n var expr = new ThisExpression();\r\n expr.range = range;\r\n return expr;\r\n }\r\n\r\n static createTrueExpression(\r\n range: Range\r\n ): TrueExpression {\r\n var expr = new TrueExpression();\r\n expr.range = range;\r\n return expr;\r\n }\r\n\r\n static createUnaryPostfixExpression(\r\n operator: Token,\r\n operand: Expression,\r\n range: Range\r\n ): UnaryPostfixExpression {\r\n var expr = new UnaryPostfixExpression();\r\n expr.range = range;\r\n expr.operator = operator;\r\n expr.operand = operand;\r\n return expr;\r\n }\r\n\r\n static createUnaryPrefixExpression(\r\n operator: Token,\r\n operand: Expression,\r\n range: Range\r\n ): UnaryPrefixExpression {\r\n var expr = new UnaryPrefixExpression();\r\n expr.range = range;\r\n expr.operator = operator;\r\n expr.operand = operand;\r\n return expr;\r\n }\r\n\r\n // statements\r\n\r\n static createBlockStatement(\r\n statements: Statement[],\r\n range: Range\r\n ): BlockStatement {\r\n var stmt = new BlockStatement();\r\n stmt.range = range;\r\n stmt.statements = statements;\r\n return stmt;\r\n }\r\n\r\n static createBreakStatement(\r\n label: IdentifierExpression | null,\r\n range: Range\r\n ): BreakStatement {\r\n var stmt = new BreakStatement();\r\n stmt.range = range;\r\n stmt.label = label;\r\n return stmt;\r\n }\r\n\r\n static createClassDeclaration(\r\n identifier: IdentifierExpression,\r\n typeParameters: TypeParameterNode[] | null,\r\n extendsType: TypeNode | null, // can't be a function\r\n implementsTypes: TypeNode[] | null, // can't be functions\r\n members: DeclarationStatement[],\r\n decorators: DecoratorNode[] | null,\r\n flags: CommonFlags,\r\n range: Range\r\n ): ClassDeclaration {\r\n var stmt = new ClassDeclaration();\r\n stmt.range = range;\r\n stmt.flags = flags;\r\n stmt.name = identifier;\r\n stmt.typeParameters = typeParameters;\r\n stmt.extendsType = extendsType;\r\n stmt.implementsTypes = implementsTypes;\r\n stmt.members = members;\r\n stmt.decorators = decorators;\r\n return stmt;\r\n }\r\n\r\n static createContinueStatement(\r\n label: IdentifierExpression | null,\r\n range: Range\r\n ): ContinueStatement {\r\n var stmt = new ContinueStatement();\r\n stmt.range = range;\r\n stmt.label = label;\r\n return stmt;\r\n }\r\n\r\n static createDoStatement(\r\n statement: Statement,\r\n condition: Expression,\r\n range: Range\r\n ): DoStatement {\r\n var stmt = new DoStatement();\r\n stmt.range = range;\r\n stmt.statement = statement;\r\n stmt.condition = condition;\r\n return stmt;\r\n }\r\n\r\n static createEmptyStatement(\r\n range: Range\r\n ): EmptyStatement {\r\n var stmt = new EmptyStatement();\r\n stmt.range = range;\r\n return stmt;\r\n }\r\n\r\n static createEnumDeclaration(\r\n name: IdentifierExpression,\r\n members: EnumValueDeclaration[],\r\n decorators: DecoratorNode[] | null,\r\n flags: CommonFlags,\r\n range: Range\r\n ): EnumDeclaration {\r\n var stmt = new EnumDeclaration();\r\n stmt.range = range;\r\n stmt.flags = flags;\r\n stmt.name = name;\r\n stmt.values = members;\r\n stmt.decorators = decorators;\r\n return stmt;\r\n }\r\n\r\n static createEnumValueDeclaration(\r\n name: IdentifierExpression,\r\n value: Expression | null,\r\n flags: CommonFlags,\r\n range: Range\r\n ): EnumValueDeclaration {\r\n var stmt = new EnumValueDeclaration();\r\n stmt.range = range;\r\n stmt.flags = flags;\r\n stmt.name = name;\r\n stmt.value = value;\r\n return stmt;\r\n }\r\n\r\n static createExportStatement(\r\n members: ExportMember[] | null,\r\n path: StringLiteralExpression | null,\r\n isDeclare: bool,\r\n range: Range\r\n ): ExportStatement {\r\n var stmt = new ExportStatement();\r\n stmt.range = range;\r\n stmt.members = members;\r\n stmt.path = path;\r\n if (path) {\r\n let normalizedPath = normalizePath(path.value);\r\n if (path.value.startsWith(\".\")) { // relative\r\n stmt.normalizedPath = resolvePath(\r\n normalizedPath,\r\n range.source.normalizedPath\r\n );\r\n } else { // absolute\r\n if (!normalizedPath.startsWith(LIBRARY_PREFIX)) {\r\n normalizedPath = LIBRARY_PREFIX + normalizedPath;\r\n }\r\n stmt.normalizedPath = normalizedPath;\r\n }\r\n stmt.internalPath = mangleInternalPath(stmt.normalizedPath);\r\n } else {\r\n stmt.normalizedPath = null;\r\n stmt.internalPath = null;\r\n }\r\n stmt.isDeclare = isDeclare;\r\n return stmt;\r\n }\r\n\r\n static createExportDefaultStatement(\r\n declaration: DeclarationStatement,\r\n range: Range\r\n ): ExportDefaultStatement {\r\n var stmt = new ExportDefaultStatement();\r\n stmt.declaration = declaration;\r\n stmt.range = range;\r\n return stmt;\r\n }\r\n\r\n static createExportImportStatement(\r\n name: IdentifierExpression,\r\n externalName: IdentifierExpression,\r\n range: Range\r\n ): ExportImportStatement {\r\n var stmt = new ExportImportStatement();\r\n stmt.range = range;\r\n stmt.name = name;\r\n stmt.externalName = externalName;\r\n return stmt;\r\n }\r\n\r\n static createExportMember(\r\n name: IdentifierExpression,\r\n externalName: IdentifierExpression | null,\r\n range: Range\r\n ): ExportMember {\r\n var elem = new ExportMember();\r\n elem.range = range;\r\n elem.localName = name;\r\n if (!externalName) externalName = name;\r\n elem.exportedName = externalName;\r\n return elem;\r\n }\r\n\r\n static createExpressionStatement(\r\n expression: Expression\r\n ): ExpressionStatement {\r\n var stmt = new ExpressionStatement();\r\n stmt.range = expression.range;\r\n stmt.expression = expression;\r\n return stmt;\r\n }\r\n\r\n static createIfStatement(\r\n condition: Expression,\r\n ifTrue: Statement,\r\n ifFalse: Statement | null,\r\n range: Range\r\n ): IfStatement {\r\n var stmt = new IfStatement();\r\n stmt.range = range;\r\n stmt.condition = condition;\r\n stmt.ifTrue = ifTrue;\r\n stmt.ifFalse = ifFalse;\r\n return stmt;\r\n }\r\n\r\n static createImportStatement(\r\n decls: ImportDeclaration[] | null,\r\n path: StringLiteralExpression,\r\n range: Range\r\n ): ImportStatement {\r\n var stmt = new ImportStatement();\r\n stmt.range = range;\r\n stmt.declarations = decls;\r\n stmt.namespaceName = null;\r\n stmt.path = path;\r\n var normalizedPath = normalizePath(path.value);\r\n if (path.value.startsWith(\".\")) { // relative in project\r\n stmt.normalizedPath = resolvePath(\r\n normalizedPath,\r\n range.source.normalizedPath\r\n );\r\n } else { // absolute in library\r\n if (!normalizedPath.startsWith(LIBRARY_PREFIX)) {\r\n normalizedPath = LIBRARY_PREFIX + normalizedPath;\r\n }\r\n stmt.normalizedPath = normalizedPath;\r\n }\r\n stmt.internalPath = mangleInternalPath(stmt.normalizedPath);\r\n return stmt;\r\n }\r\n\r\n static createImportStatementWithWildcard(\r\n identifier: IdentifierExpression,\r\n path: StringLiteralExpression,\r\n range: Range\r\n ): ImportStatement {\r\n var stmt = new ImportStatement();\r\n stmt.range = range;\r\n stmt.declarations = null;\r\n stmt.namespaceName = identifier;\r\n stmt.path = path;\r\n var normalizedPath = normalizePath(path.value);\r\n if (path.value.startsWith(\".\")) {\r\n stmt.normalizedPath = resolvePath(\r\n normalizedPath,\r\n range.source.normalizedPath\r\n );\r\n } else {\r\n if (!normalizedPath.startsWith(LIBRARY_PREFIX)) {\r\n normalizedPath = LIBRARY_PREFIX + normalizedPath;\r\n }\r\n stmt.normalizedPath = normalizedPath;\r\n }\r\n stmt.internalPath = mangleInternalPath(stmt.normalizedPath);\r\n return stmt;\r\n }\r\n\r\n static createImportDeclaration(\r\n foreignName: IdentifierExpression,\r\n name: IdentifierExpression | null,\r\n range: Range\r\n ): ImportDeclaration {\r\n var elem = new ImportDeclaration();\r\n elem.range = range;\r\n elem.foreignName = foreignName;\r\n if (!name) name = foreignName;\r\n elem.name = name;\r\n return elem;\r\n }\r\n\r\n static createInterfaceDeclaration(\r\n name: IdentifierExpression,\r\n typeParameters: TypeParameterNode[] | null,\r\n extendsType: TypeNode | null, // can't be a function\r\n members: DeclarationStatement[],\r\n decorators: DecoratorNode[] | null,\r\n flags: CommonFlags,\r\n range: Range\r\n ): InterfaceDeclaration {\r\n var stmt = new InterfaceDeclaration();\r\n stmt.range = range;\r\n stmt.flags = flags;\r\n stmt.name = name;\r\n stmt.typeParameters = typeParameters;\r\n stmt.extendsType = extendsType;\r\n stmt.members = members;\r\n stmt.decorators = decorators;\r\n return stmt;\r\n }\r\n\r\n static createFieldDeclaration(\r\n name: IdentifierExpression,\r\n type: CommonTypeNode | null,\r\n initializer: Expression | null,\r\n decorators: DecoratorNode[] | null,\r\n flags: CommonFlags,\r\n range: Range\r\n ): FieldDeclaration {\r\n var stmt = new FieldDeclaration();\r\n stmt.range = range;\r\n stmt.flags = flags;\r\n stmt.name = name;\r\n stmt.type = type;\r\n stmt.initializer = initializer;\r\n stmt.decorators = decorators;\r\n return stmt;\r\n }\r\n\r\n static createForStatement(\r\n initializer: Statement | null,\r\n condition: Expression | null,\r\n incrementor: Expression | null,\r\n statement: Statement,\r\n range: Range\r\n ): ForStatement {\r\n var stmt = new ForStatement();\r\n stmt.range = range;\r\n stmt.initializer = initializer;\r\n stmt.condition = condition;\r\n stmt.incrementor = incrementor;\r\n stmt.statement = statement;\r\n return stmt;\r\n }\r\n\r\n static createFunctionDeclaration(\r\n name: IdentifierExpression,\r\n typeParameters: TypeParameterNode[] | null,\r\n signature: SignatureNode,\r\n body: Statement | null,\r\n decorators: DecoratorNode[] | null,\r\n flags: CommonFlags,\r\n arrowKind: ArrowKind,\r\n range: Range\r\n ): FunctionDeclaration {\r\n var stmt = new FunctionDeclaration();\r\n stmt.range = range;\r\n stmt.flags = flags;\r\n stmt.name = name;\r\n stmt.typeParameters = typeParameters;\r\n stmt.signature = signature;\r\n stmt.body = body;\r\n stmt.decorators = decorators;\r\n stmt.arrowKind = arrowKind;\r\n return stmt;\r\n }\r\n\r\n static createIndexSignatureDeclaration(\r\n keyType: TypeNode,\r\n valueType: CommonTypeNode,\r\n range: Range\r\n ): IndexSignatureDeclaration {\r\n var elem = new IndexSignatureDeclaration();\r\n elem.range = range;\r\n elem.keyType = keyType;\r\n elem.valueType = valueType;\r\n return elem;\r\n }\r\n\r\n static createMethodDeclaration(\r\n name: IdentifierExpression,\r\n typeParameters: TypeParameterNode[] | null,\r\n signature: SignatureNode,\r\n body: Statement | null,\r\n decorators: DecoratorNode[] | null,\r\n flags: CommonFlags,\r\n range: Range\r\n ): MethodDeclaration {\r\n var stmt = new MethodDeclaration();\r\n stmt.range = range;\r\n stmt.flags = flags;\r\n stmt.name = name;\r\n stmt.typeParameters = typeParameters;\r\n stmt.signature = signature;\r\n stmt.body = body;\r\n stmt.decorators = decorators;\r\n return stmt;\r\n }\r\n\r\n static createNamespaceDeclaration(\r\n name: IdentifierExpression,\r\n members: Statement[],\r\n decorators: DecoratorNode[] | null,\r\n flags: CommonFlags,\r\n range: Range\r\n ): NamespaceDeclaration {\r\n var stmt = new NamespaceDeclaration();\r\n stmt.range = range;\r\n stmt.flags = flags;\r\n stmt.name = name;\r\n stmt.members = members;\r\n stmt.decorators = decorators;\r\n return stmt;\r\n }\r\n\r\n static createReturnStatement(\r\n value: Expression | null,\r\n range: Range\r\n ): ReturnStatement {\r\n var stmt = new ReturnStatement();\r\n stmt.range = range;\r\n stmt.value = value;\r\n return stmt;\r\n }\r\n\r\n static createSwitchStatement(\r\n condition: Expression,\r\n cases: SwitchCase[],\r\n range: Range\r\n ): SwitchStatement {\r\n var stmt = new SwitchStatement();\r\n stmt.range = range;\r\n stmt.condition = condition;\r\n stmt.cases = cases;\r\n return stmt;\r\n }\r\n\r\n static createSwitchCase(\r\n label: Expression | null,\r\n statements: Statement[],\r\n range: Range\r\n ): SwitchCase {\r\n var elem = new SwitchCase();\r\n elem.range = range;\r\n elem.label = label;\r\n elem.statements = statements;\r\n return elem;\r\n }\r\n\r\n static createThrowStatement(\r\n value: Expression,\r\n range: Range\r\n ): ThrowStatement {\r\n var stmt = new ThrowStatement();\r\n stmt.range = range;\r\n stmt.value = value;\r\n return stmt;\r\n }\r\n\r\n static createTryStatement(\r\n statements: Statement[],\r\n catchVariable: IdentifierExpression | null,\r\n catchStatements: Statement[] | null,\r\n finallyStatements: Statement[] | null,\r\n range: Range\r\n ): TryStatement {\r\n var stmt = new TryStatement();\r\n stmt.range = range;\r\n stmt.statements = statements;\r\n stmt.catchVariable = catchVariable;\r\n stmt.catchStatements = catchStatements;\r\n stmt.finallyStatements = finallyStatements;\r\n return stmt;\r\n }\r\n\r\n static createTypeDeclaration(\r\n name: IdentifierExpression,\r\n typeParameters: TypeParameterNode[] | null,\r\n alias: CommonTypeNode,\r\n decorators: DecoratorNode[] | null,\r\n flags: CommonFlags,\r\n range: Range\r\n ): TypeDeclaration {\r\n var stmt = new TypeDeclaration();\r\n stmt.range = range;\r\n stmt.flags = flags;\r\n stmt.name = name;\r\n stmt.typeParameters = typeParameters;\r\n stmt.type = alias;\r\n stmt.decorators = decorators;\r\n return stmt;\r\n }\r\n\r\n static createVariableStatement(\r\n declarations: VariableDeclaration[],\r\n decorators: DecoratorNode[] | null,\r\n range: Range\r\n ): VariableStatement {\r\n var stmt = new VariableStatement();\r\n stmt.range = range;\r\n stmt.declarations = declarations;\r\n stmt.decorators = decorators;\r\n return stmt;\r\n }\r\n\r\n static createVariableDeclaration(\r\n name: IdentifierExpression,\r\n type: CommonTypeNode | null,\r\n initializer: Expression | null,\r\n decorators: DecoratorNode[] | null,\r\n flags: CommonFlags,\r\n range: Range\r\n ): VariableDeclaration {\r\n var elem = new VariableDeclaration();\r\n elem.range = range;\r\n elem.flags = flags;\r\n elem.name = name;\r\n elem.type = type;\r\n elem.initializer = initializer;\r\n elem.decorators = decorators; // inherited\r\n return elem;\r\n }\r\n\r\n static createVoidStatement(\r\n expression: Expression,\r\n range: Range\r\n ): VoidStatement {\r\n var stmt = new VoidStatement();\r\n stmt.range = range;\r\n stmt.expression = expression;\r\n return stmt;\r\n }\r\n\r\n static createWhileStatement(\r\n condition: Expression,\r\n statement: Statement,\r\n range: Range\r\n ): WhileStatement {\r\n var stmt = new WhileStatement();\r\n stmt.range = range;\r\n stmt.condition = condition;\r\n stmt.statement = statement;\r\n return stmt;\r\n }\r\n}\r\n\r\n// types\r\n\r\nexport abstract class CommonTypeNode extends Node {\r\n // kind varies\r\n\r\n /** Whether nullable or not. */\r\n isNullable: bool;\r\n}\r\n\r\n/** Represents a type name. */\r\nexport class TypeName extends Node {\r\n kind = NodeKind.TYPENAME;\r\n\r\n /** Identifier of this part. */\r\n identifier: IdentifierExpression;\r\n /** Next part of the type name or `null` if this is the last part. */\r\n next: TypeName | null;\r\n}\r\n\r\n/** Represents a type annotation. */\r\nexport class TypeNode extends CommonTypeNode {\r\n kind = NodeKind.TYPE;\r\n\r\n /** Type name. */\r\n name: TypeName;\r\n /** Type argument references. */\r\n typeArguments: CommonTypeNode[] | null;\r\n}\r\n\r\n/** Represents a type parameter. */\r\nexport class TypeParameterNode extends Node {\r\n kind = NodeKind.TYPEPARAMETER;\r\n\r\n /** Identifier reference. */\r\n name: IdentifierExpression;\r\n /** Extended type reference, if any. */\r\n extendsType: TypeNode | null; // can't be a function\r\n /** Default type if omitted, if any. */\r\n defaultType: TypeNode | null; // can't be a function\r\n}\r\n\r\n/** Represents the kind of a parameter. */\r\nexport enum ParameterKind {\r\n /** No specific flags. */\r\n DEFAULT,\r\n /** Is an optional parameter. */\r\n OPTIONAL,\r\n /** Is a rest parameter. */\r\n REST\r\n}\r\n\r\n/** Represents a function parameter. */\r\nexport class ParameterNode extends Node {\r\n kind = NodeKind.PARAMETER;\r\n\r\n /** Parameter kind. */\r\n parameterKind: ParameterKind;\r\n /** Parameter name. */\r\n name: IdentifierExpression;\r\n /** Parameter type. */\r\n type: CommonTypeNode;\r\n /** Initializer expression, if present. */\r\n initializer: Expression | null;\r\n /** Implicit field declaration, if applicable. */\r\n implicitFieldDeclaration: FieldDeclaration | null = null;\r\n /** Common flags indicating specific traits. */\r\n flags: CommonFlags = CommonFlags.NONE;\r\n\r\n /** Tests if this node has the specified flag or flags. */\r\n is(flag: CommonFlags): bool { return (this.flags & flag) == flag; }\r\n /** Tests if this node has one of the specified flags. */\r\n isAny(flag: CommonFlags): bool { return (this.flags & flag) != 0; }\r\n /** Sets a specific flag or flags. */\r\n set(flag: CommonFlags): void { this.flags |= flag; }\r\n}\r\n\r\n/** Represents a function signature. */\r\nexport class SignatureNode extends CommonTypeNode {\r\n kind = NodeKind.SIGNATURE;\r\n\r\n /** Accepted parameters. */\r\n parameters: ParameterNode[];\r\n /** Return type. */\r\n returnType: CommonTypeNode;\r\n /** Explicitly provided this type, if any. */\r\n explicitThisType: TypeNode | null; // can't be a function\r\n}\r\n\r\n// special\r\n\r\n/** Built-in decorator kinds. */\r\nexport enum DecoratorKind {\r\n CUSTOM,\r\n GLOBAL,\r\n OPERATOR,\r\n OPERATOR_BINARY,\r\n OPERATOR_PREFIX,\r\n OPERATOR_POSTFIX,\r\n UNMANAGED,\r\n SEALED,\r\n INLINE,\r\n EXTERNAL,\r\n BUILTIN,\r\n LAZY,\r\n UNSAFE\r\n}\r\n\r\n/** Returns the kind of the specified decorator. Defaults to {@link DecoratorKind.CUSTOM}. */\r\nexport function decoratorNameToKind(name: Expression): DecoratorKind {\r\n // @global, @inline, @operator, @sealed, @unmanaged\r\n if (name.kind == NodeKind.IDENTIFIER) {\r\n let nameStr = (name).text;\r\n assert(nameStr.length);\r\n switch (nameStr.charCodeAt(0)) {\r\n case CharCode.b: {\r\n if (nameStr == \"builtin\") return DecoratorKind.BUILTIN;\r\n break;\r\n }\r\n case CharCode.e: {\r\n if (nameStr == \"external\") return DecoratorKind.EXTERNAL;\r\n break;\r\n }\r\n case CharCode.g: {\r\n if (nameStr == \"global\") return DecoratorKind.GLOBAL;\r\n break;\r\n }\r\n case CharCode.i: {\r\n if (nameStr == \"inline\") return DecoratorKind.INLINE;\r\n break;\r\n }\r\n case CharCode.l: {\r\n if (nameStr == \"lazy\") return DecoratorKind.LAZY;\r\n break;\r\n }\r\n case CharCode.o: {\r\n if (nameStr == \"operator\") return DecoratorKind.OPERATOR;\r\n break;\r\n }\r\n case CharCode.s: {\r\n if (nameStr == \"sealed\") return DecoratorKind.SEALED;\r\n break;\r\n }\r\n case CharCode.u: {\r\n if (nameStr == \"unmanaged\") return DecoratorKind.UNMANAGED;\r\n if (nameStr == \"unsafe\") return DecoratorKind.UNSAFE;\r\n break;\r\n }\r\n }\r\n } else if (\r\n name.kind == NodeKind.PROPERTYACCESS &&\r\n (name).expression.kind == NodeKind.IDENTIFIER\r\n ) {\r\n let nameStr = ((name).expression).text;\r\n assert(nameStr.length);\r\n let propStr = (name).property.text;\r\n assert(propStr.length);\r\n // @operator.binary, @operator.prefix, @operator.postfix\r\n if (nameStr == \"operator\") {\r\n switch (propStr.charCodeAt(0)) {\r\n case CharCode.b: {\r\n if (propStr == \"binary\") return DecoratorKind.OPERATOR_BINARY;\r\n break;\r\n }\r\n case CharCode.p: {\r\n switch (propStr) {\r\n case \"prefix\": return DecoratorKind.OPERATOR_PREFIX;\r\n case \"postfix\": return DecoratorKind.OPERATOR_POSTFIX;\r\n }\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n return DecoratorKind.CUSTOM;\r\n}\r\n\r\n/** Represents a decorator. */\r\nexport class DecoratorNode extends Node {\r\n kind = NodeKind.DECORATOR;\r\n\r\n /** Built-in kind, if applicable. */\r\n decoratorKind: DecoratorKind;\r\n /** Name expression. */\r\n name: Expression;\r\n /** Argument expressions. */\r\n arguments: Expression[] | null;\r\n}\r\n\r\n/** Comment kinds. */\r\nexport enum CommentKind {\r\n /** Line comment. */\r\n LINE,\r\n /** Triple-slash comment. */\r\n TRIPLE,\r\n /** Block comment. */\r\n BLOCK\r\n}\r\n\r\n/** Represents a comment. */\r\nexport class CommentNode extends Node {\r\n kind = NodeKind.COMMENT;\r\n\r\n /** Comment kind. */\r\n commentKind: CommentKind;\r\n /** Comment text. */\r\n text: string;\r\n}\r\n\r\n// expressions\r\n\r\n/** Base class of all expression nodes. */\r\nexport abstract class Expression extends Node { }\r\n\r\n/** Represents an identifier expression. */\r\nexport class IdentifierExpression extends Expression {\r\n kind = NodeKind.IDENTIFIER;\r\n\r\n /** Textual name. */\r\n text: string;\r\n /** Symbol. */\r\n symbol: string; // TODO: symbol\r\n /** Whether quoted or not. */\r\n isQuoted: bool;\r\n}\r\n\r\n/** Indicates the kind of a literal. */\r\nexport enum LiteralKind {\r\n FLOAT,\r\n INTEGER,\r\n STRING,\r\n REGEXP,\r\n ARRAY,\r\n OBJECT\r\n}\r\n\r\n/** Base class of all literal expressions. */\r\nexport abstract class LiteralExpression extends Expression {\r\n kind = NodeKind.LITERAL;\r\n\r\n /** Specific literal kind. */\r\n literalKind: LiteralKind;\r\n}\r\n\r\n/** Represents an `[]` literal expression. */\r\nexport class ArrayLiteralExpression extends LiteralExpression {\r\n literalKind = LiteralKind.ARRAY;\r\n\r\n /** Nested element expressions. */\r\n elementExpressions: (Expression | null)[];\r\n}\r\n\r\n/** Indicates the kind of an assertion. */\r\nexport enum AssertionKind {\r\n PREFIX,\r\n AS,\r\n NONNULL\r\n}\r\n\r\n/** Represents an assertion expression. */\r\nexport class AssertionExpression extends Expression {\r\n kind = NodeKind.ASSERTION;\r\n\r\n /** Specific kind of this assertion. */\r\n assertionKind: AssertionKind;\r\n /** Expression being asserted. */\r\n expression: Expression;\r\n /** Target type. */\r\n toType: CommonTypeNode | null;\r\n}\r\n\r\n/** Represents a binary expression. */\r\nexport class BinaryExpression extends Expression {\r\n kind = NodeKind.BINARY;\r\n\r\n /** Operator token. */\r\n operator: Token;\r\n /** Left-hand side expression */\r\n left: Expression;\r\n /** Right-hand side expression. */\r\n right: Expression;\r\n}\r\n\r\n/** Represents a call expression. */\r\nexport class CallExpression extends Expression {\r\n kind = NodeKind.CALL;\r\n\r\n /** Called expression. Usually an identifier or property access expression. */\r\n expression: Expression;\r\n /** Provided type arguments. */\r\n typeArguments: CommonTypeNode[] | null;\r\n /** Provided arguments. */\r\n arguments: Expression[];\r\n\r\n /** Gets the type arguments range for reporting. */\r\n get typeArgumentsRange(): Range {\r\n var typeArguments = this.typeArguments;\r\n var numTypeArguments: i32;\r\n if (typeArguments && (numTypeArguments = typeArguments.length)) {\r\n return Range.join(typeArguments[0].range, typeArguments[numTypeArguments - 1].range);\r\n }\r\n return this.expression.range;\r\n }\r\n\r\n /** Gets the arguments range for reporting. */\r\n get argumentsRange(): Range {\r\n var args = this.arguments;\r\n var numArguments = args.length;\r\n if (numArguments) {\r\n return Range.join(args[0].range, args[numArguments - 1].range);\r\n }\r\n return this.expression.range;\r\n }\r\n}\r\n\r\n/** Represents a class expression using the 'class' keyword. */\r\nexport class ClassExpression extends Expression {\r\n kind = NodeKind.CLASS;\r\n\r\n /** Inline class declaration. */\r\n declaration: ClassDeclaration;\r\n}\r\n\r\n/** Represents a comma expression composed of multiple expressions. */\r\nexport class CommaExpression extends Expression {\r\n kind = NodeKind.COMMA;\r\n\r\n /** Sequential expressions. */\r\n expressions: Expression[];\r\n}\r\n\r\n/** Represents a `constructor` expression. */\r\nexport class ConstructorExpression extends IdentifierExpression {\r\n kind = NodeKind.CONSTRUCTOR;\r\n text = \"constructor\";\r\n symbol = CommonSymbols.constructor;\r\n}\r\n\r\n/** Represents an element access expression, e.g., array access. */\r\nexport class ElementAccessExpression extends Expression {\r\n kind = NodeKind.ELEMENTACCESS;\r\n\r\n /** Expression being accessed. */\r\n expression: Expression;\r\n /** Element of the expression being accessed. */\r\n elementExpression: Expression;\r\n}\r\n\r\n/** Represents a float literal expression. */\r\nexport class FloatLiteralExpression extends LiteralExpression {\r\n literalKind = LiteralKind.FLOAT;\r\n\r\n /** Float value. */\r\n value: f64;\r\n}\r\n\r\n/** Represents a function expression using the 'function' keyword. */\r\nexport class FunctionExpression extends Expression {\r\n kind = NodeKind.FUNCTION;\r\n\r\n /** Inline function declaration. */\r\n declaration: FunctionDeclaration;\r\n}\r\n\r\n/** Represents an `instanceof` expression. */\r\nexport class InstanceOfExpression extends Expression {\r\n kind = NodeKind.INSTANCEOF;\r\n\r\n /** Expression being asserted. */\r\n expression: Expression;\r\n /** Type to test for. */\r\n isType: CommonTypeNode;\r\n}\r\n\r\n/** Represents an integer literal expression. */\r\nexport class IntegerLiteralExpression extends LiteralExpression {\r\n literalKind = LiteralKind.INTEGER;\r\n\r\n /** Integer value. */\r\n value: I64;\r\n}\r\n\r\n/** Represents a `new` expression. Like a call but with its own kind. */\r\nexport class NewExpression extends CallExpression {\r\n kind = NodeKind.NEW;\r\n}\r\n\r\n/** Represents a `null` expression. */\r\nexport class NullExpression extends IdentifierExpression {\r\n kind = NodeKind.NULL;\r\n text = \"null\";\r\n symbol = CommonSymbols.null_;\r\n}\r\n\r\n/** Represents an object literal expression. */\r\nexport class ObjectLiteralExpression extends LiteralExpression {\r\n literalKind = LiteralKind.OBJECT;\r\n\r\n /** Field names. */\r\n names: IdentifierExpression[];\r\n /** Field values. */\r\n values: Expression[];\r\n}\r\n\r\n/** Represents a parenthesized expression. */\r\nexport class ParenthesizedExpression extends Expression {\r\n kind = NodeKind.PARENTHESIZED;\r\n\r\n /** Expression in parenthesis. */\r\n expression: Expression;\r\n}\r\n\r\n/** Represents a property access expression. */\r\nexport class PropertyAccessExpression extends Expression {\r\n kind = NodeKind.PROPERTYACCESS;\r\n\r\n /** Expression being accessed. */\r\n expression: Expression;\r\n /** Property of the expression being accessed. */\r\n property: IdentifierExpression;\r\n}\r\n\r\n/** Represents a regular expression literal expression. */\r\nexport class RegexpLiteralExpression extends LiteralExpression {\r\n literalKind = LiteralKind.REGEXP;\r\n\r\n /** Regular expression pattern. */\r\n pattern: string;\r\n /** Regular expression flags. */\r\n patternFlags: string;\r\n}\r\n\r\n/** Represents a ternary expression, i.e., short if notation. */\r\nexport class TernaryExpression extends Expression {\r\n kind = NodeKind.TERNARY;\r\n\r\n /** Condition expression. */\r\n condition: Expression;\r\n /** Expression executed when condition is `true`. */\r\n ifThen: Expression;\r\n /** Expression executed when condition is `false`. */\r\n ifElse: Expression;\r\n}\r\n\r\n/** Represents a string literal expression. */\r\nexport class StringLiteralExpression extends LiteralExpression {\r\n literalKind = LiteralKind.STRING;\r\n\r\n /** String value without quotes. */\r\n value: string;\r\n}\r\n\r\n/** Represents a `super` expression. */\r\nexport class SuperExpression extends IdentifierExpression {\r\n kind = NodeKind.SUPER;\r\n text = \"super\";\r\n symbol = CommonSymbols.super_;\r\n}\r\n\r\n/** Represents a `this` expression. */\r\nexport class ThisExpression extends IdentifierExpression {\r\n kind = NodeKind.THIS;\r\n text = \"this\";\r\n symbol = CommonSymbols.this_;\r\n}\r\n\r\n/** Represents a `true` expression. */\r\nexport class TrueExpression extends IdentifierExpression {\r\n kind = NodeKind.TRUE;\r\n text = \"true\";\r\n symbol = CommonSymbols.true_;\r\n}\r\n\r\n/** Represents a `false` expression. */\r\nexport class FalseExpression extends IdentifierExpression {\r\n kind = NodeKind.FALSE;\r\n text = \"false\";\r\n symbol = CommonSymbols.false_;\r\n}\r\n\r\n/** Base class of all unary expressions. */\r\nexport abstract class UnaryExpression extends Expression {\r\n\r\n /** Operator token. */\r\n operator: Token;\r\n /** Operand expression. */\r\n operand: Expression;\r\n}\r\n\r\n/** Represents a unary postfix expression, e.g. a postfix increment. */\r\nexport class UnaryPostfixExpression extends UnaryExpression {\r\n kind = NodeKind.UNARYPOSTFIX;\r\n}\r\n\r\n/** Represents a unary prefix expression, e.g. a negation. */\r\nexport class UnaryPrefixExpression extends UnaryExpression {\r\n kind = NodeKind.UNARYPREFIX;\r\n}\r\n\r\n// statements\r\n\r\n/** Base class of all statement nodes. */\r\nexport abstract class Statement extends Node { }\r\n\r\n/** Indicates the specific kind of a source. */\r\nexport enum SourceKind {\r\n /** Default source. Usually imported from an entry file. */\r\n DEFAULT,\r\n /** Entry file. */\r\n ENTRY,\r\n /** Library file. */\r\n LIBRARY\r\n}\r\n\r\n/** A top-level source node. */\r\nexport class Source extends Node {\r\n kind = NodeKind.SOURCE;\r\n parent = null;\r\n\r\n /** Source kind. */\r\n sourceKind: SourceKind;\r\n /** Normalized path. */\r\n normalizedPath: string;\r\n /** Path used internally. */\r\n internalPath: string;\r\n /** Simple path (last part without extension). */\r\n simplePath: string;\r\n /** Contained statements. */\r\n statements: Statement[];\r\n /** Full source text. */\r\n text: string;\r\n /** Tokenizer reference. */\r\n tokenizer: Tokenizer | null = null;\r\n /** Source map index. */\r\n debugInfoIndex: i32 = -1;\r\n /** Re-exported sources. */\r\n exportPaths: Set | null = null;\r\n\r\n /** Constructs a new source node. */\r\n constructor(normalizedPath: string, text: string, kind: SourceKind) {\r\n super();\r\n this.sourceKind = kind;\r\n this.normalizedPath = normalizedPath;\r\n var internalPath = mangleInternalPath(this.normalizedPath);\r\n this.internalPath = internalPath;\r\n var pos = internalPath.lastIndexOf(PATH_DELIMITER);\r\n this.simplePath = pos >= 0 ? internalPath.substring(pos + 1) : internalPath;\r\n this.statements = new Array();\r\n this.range = new Range(this, 0, text.length);\r\n this.text = text;\r\n }\r\n\r\n /** Tests if this source is an entry file. */\r\n get isEntry(): bool { return this.sourceKind == SourceKind.ENTRY; }\r\n /** Tests if this source is a stdlib file. */\r\n get isLibrary(): bool { return this.sourceKind == SourceKind.LIBRARY; }\r\n}\r\n\r\n/** Base class of all declaration statements. */\r\nexport abstract class DeclarationStatement extends Statement {\r\n /** Simple name being declared. */\r\n name: IdentifierExpression;\r\n /** Array of decorators. */\r\n decorators: DecoratorNode[] | null = null;\r\n /** Common flags indicating specific traits. */\r\n flags: CommonFlags = CommonFlags.NONE;\r\n\r\n /** Tests if this node has the specified flag or flags. */\r\n is(flag: CommonFlags): bool { return (this.flags & flag) == flag; }\r\n /** Tests if this node has one of the specified flags. */\r\n isAny(flag: CommonFlags): bool { return (this.flags & flag) != 0; }\r\n /** Sets a specific flag or flags. */\r\n set(flag: CommonFlags): void { this.flags |= flag; }\r\n}\r\n\r\n/** Represents an index signature declaration. */\r\nexport class IndexSignatureDeclaration extends DeclarationStatement {\r\n kind = NodeKind.INDEXSIGNATUREDECLARATION;\r\n\r\n /** Key type. */\r\n keyType: TypeNode;\r\n /** Value type. */\r\n valueType: CommonTypeNode;\r\n}\r\n\r\n/** Base class of all variable-like declaration statements. */\r\nexport abstract class VariableLikeDeclarationStatement extends DeclarationStatement {\r\n\r\n /** Variable type. */\r\n type: CommonTypeNode | null;\r\n /** Variable initializer. */\r\n initializer: Expression | null;\r\n}\r\n\r\n/** Represents a block statement. */\r\nexport class BlockStatement extends Statement {\r\n kind = NodeKind.BLOCK;\r\n\r\n /** Contained statements. */\r\n statements: Statement[];\r\n}\r\n\r\n/** Represents a `break` statement. */\r\nexport class BreakStatement extends Statement {\r\n kind = NodeKind.BREAK;\r\n\r\n /** Target label, if applicable. */\r\n label: IdentifierExpression | null;\r\n}\r\n\r\n/** Represents a `class` declaration. */\r\nexport class ClassDeclaration extends DeclarationStatement {\r\n kind = NodeKind.CLASSDECLARATION;\r\n\r\n /** Accepted type parameters. */\r\n typeParameters: TypeParameterNode[] | null;\r\n /** Base class type being extended, if any. */\r\n extendsType: TypeNode | null; // can't be a function\r\n /** Interface types being implemented, if any. */\r\n implementsTypes: TypeNode[] | null; // can't be functions\r\n /** Class member declarations. */\r\n members: DeclarationStatement[];\r\n\r\n get isGeneric(): bool {\r\n var typeParameters = this.typeParameters;\r\n return typeParameters != null && typeParameters.length > 0;\r\n }\r\n}\r\n\r\n/** Represents a `continue` statement. */\r\nexport class ContinueStatement extends Statement {\r\n kind = NodeKind.CONTINUE;\r\n\r\n /** Target label, if applicable. */\r\n label: IdentifierExpression | null;\r\n}\r\n\r\n/** Represents a `do` statement. */\r\nexport class DoStatement extends Statement {\r\n kind = NodeKind.DO;\r\n\r\n /** Statement being looped over. */\r\n statement: Statement;\r\n /** Condition when to repeat. */\r\n condition: Expression;\r\n}\r\n\r\n/** Represents an empty statement, i.e., a semicolon terminating nothing. */\r\nexport class EmptyStatement extends Statement {\r\n kind = NodeKind.EMPTY;\r\n}\r\n\r\n/** Represents an `enum` declaration. */\r\nexport class EnumDeclaration extends DeclarationStatement {\r\n kind = NodeKind.ENUMDECLARATION;\r\n\r\n /** Enum value declarations. */\r\n values: EnumValueDeclaration[];\r\n}\r\n\r\n/** Represents a value of an `enum` declaration. */\r\nexport class EnumValueDeclaration extends VariableLikeDeclarationStatement {\r\n kind = NodeKind.ENUMVALUEDECLARATION;\r\n // name is inherited\r\n\r\n /** Value expression. */\r\n value: Expression | null;\r\n}\r\n\r\n/** Represents an `export import` statement of an interface. */\r\nexport class ExportImportStatement extends Node {\r\n kind = NodeKind.EXPORTIMPORT;\r\n\r\n /** Identifier being imported. */\r\n name: IdentifierExpression;\r\n /** Identifier being exported. */\r\n externalName: IdentifierExpression;\r\n}\r\n\r\n/** Represents a member of an `export` statement. */\r\nexport class ExportMember extends Node {\r\n kind = NodeKind.EXPORTMEMBER;\r\n\r\n /** Local identifier. */\r\n localName: IdentifierExpression;\r\n /** Exported identifier. */\r\n exportedName: IdentifierExpression;\r\n}\r\n\r\n/** Represents an `export` statement. */\r\nexport class ExportStatement extends Statement {\r\n kind = NodeKind.EXPORT;\r\n\r\n /** Array of members if a set of named exports, or `null` if a file export. */\r\n members: ExportMember[] | null;\r\n /** Path being exported from, if applicable. */\r\n path: StringLiteralExpression | null;\r\n /** Normalized path, if `path` is set. */\r\n normalizedPath: string | null;\r\n /** Mangled internal path being referenced, if `path` is set. */\r\n internalPath: string | null;\r\n /** Whether this is a declared export. */\r\n isDeclare: bool;\r\n}\r\n\r\n/** Represents an `export default` statement. */\r\nexport class ExportDefaultStatement extends Statement {\r\n kind = NodeKind.EXPORTDEFAULT;\r\n\r\n /** Declaration being exported as default. */\r\n declaration: DeclarationStatement;\r\n}\r\n\r\n/** Represents an expression that is used as a statement. */\r\nexport class ExpressionStatement extends Statement {\r\n kind = NodeKind.EXPRESSION;\r\n\r\n /** Expression being used as a statement.*/\r\n expression: Expression;\r\n}\r\n\r\n/** Represents a field declaration within a `class`. */\r\nexport class FieldDeclaration extends VariableLikeDeclarationStatement {\r\n kind = NodeKind.FIELDDECLARATION;\r\n\r\n /** Parameter index if declared as a constructor parameter, otherwise `-1`. */\r\n parameterIndex: i32 = -1;\r\n}\r\n\r\n/** Represents a `for` statement. */\r\nexport class ForStatement extends Statement {\r\n kind = NodeKind.FOR;\r\n\r\n /**\r\n * Initializer statement, if present.\r\n * Either a {@link VariableStatement} or {@link ExpressionStatement}.\r\n */\r\n initializer: Statement | null;\r\n /** Condition expression, if present. */\r\n condition: Expression | null;\r\n /** Incrementor expression, if present. */\r\n incrementor: Expression | null;\r\n /** Statement being looped over. */\r\n statement: Statement;\r\n}\r\n\r\n/** Indicates the kind of an array function. */\r\nexport const enum ArrowKind {\r\n /** Not an arrow function. */\r\n NONE,\r\n /** Parenthesized parameter list. */\r\n ARROW_PARENTHESIZED,\r\n /** Single parameter without parenthesis. */\r\n ARROW_SINGLE\r\n}\r\n\r\n/** Represents a `function` declaration. */\r\nexport class FunctionDeclaration extends DeclarationStatement {\r\n kind = NodeKind.FUNCTIONDECLARATION;\r\n\r\n /** Type parameters, if any. */\r\n typeParameters: TypeParameterNode[] | null;\r\n /** Function signature. */\r\n signature: SignatureNode;\r\n /** Body statement. Usually a block. */\r\n body: Statement | null;\r\n /** Arrow function kind, if applicable. */\r\n arrowKind: ArrowKind;\r\n\r\n get isGeneric(): bool {\r\n var typeParameters = this.typeParameters;\r\n return typeParameters != null && typeParameters.length > 0;\r\n }\r\n\r\n /** Clones this function declaration. */\r\n clone(): FunctionDeclaration {\r\n return Node.createFunctionDeclaration(\r\n this.name,\r\n this.typeParameters,\r\n this.signature,\r\n this.body,\r\n this.decorators,\r\n this.flags,\r\n this.arrowKind,\r\n this.range\r\n );\r\n }\r\n}\r\n\r\n/** Represents an `if` statement. */\r\nexport class IfStatement extends Statement {\r\n kind = NodeKind.IF;\r\n\r\n /** Condition. */\r\n condition: Expression;\r\n /** Statement executed when condition is `true`. */\r\n ifTrue: Statement;\r\n /** Statement executed when condition is `false`. */\r\n ifFalse: Statement | null;\r\n}\r\n\r\n/** Represents an `import` declaration part of an {@link ImportStatement}. */\r\nexport class ImportDeclaration extends DeclarationStatement {\r\n kind = NodeKind.IMPORTDECLARATION;\r\n\r\n /** Identifier being imported. */\r\n foreignName: IdentifierExpression;\r\n}\r\n\r\n/** Represents an `import` statement. */\r\nexport class ImportStatement extends Statement {\r\n kind = NodeKind.IMPORT;\r\n\r\n /** Array of member declarations or `null` if an asterisk import. */\r\n declarations: ImportDeclaration[] | null;\r\n /** Name of the local namespace, if an asterisk import. */\r\n namespaceName: IdentifierExpression | null;\r\n /** Path being imported from. */\r\n path: StringLiteralExpression;\r\n /** Normalized path. */\r\n normalizedPath: string;\r\n /** Mangled internal path being referenced. */\r\n internalPath: string;\r\n}\r\n\r\n/** Represents an `interfarce` declaration. */\r\nexport class InterfaceDeclaration extends ClassDeclaration {\r\n kind = NodeKind.INTERFACEDECLARATION;\r\n}\r\n\r\n/** Represents a method declaration within a `class`. */\r\nexport class MethodDeclaration extends FunctionDeclaration {\r\n kind = NodeKind.METHODDECLARATION;\r\n}\r\n\r\n/** Represents a `namespace` declaration. */\r\nexport class NamespaceDeclaration extends DeclarationStatement {\r\n kind = NodeKind.NAMESPACEDECLARATION;\r\n\r\n /** Array of namespace members. */\r\n members: Statement[];\r\n}\r\n\r\n/** Represents a `return` statement. */\r\nexport class ReturnStatement extends Statement {\r\n kind = NodeKind.RETURN;\r\n\r\n /** Value expression being returned, if present. */\r\n value: Expression | null;\r\n}\r\n\r\n/** Represents a single `case` within a `switch` statement. */\r\nexport class SwitchCase extends Node {\r\n kind = NodeKind.SWITCHCASE;\r\n\r\n /** Label expression. `null` indicates the default case. */\r\n label: Expression | null;\r\n /** Contained statements. */\r\n statements: Statement[];\r\n}\r\n\r\n/** Represents a `switch` statement. */\r\nexport class SwitchStatement extends Statement {\r\n kind = NodeKind.SWITCH;\r\n\r\n /** Condition expression. */\r\n condition: Expression;\r\n /** Contained cases. */\r\n cases: SwitchCase[];\r\n}\r\n\r\n/** Represents a `throw` statement. */\r\nexport class ThrowStatement extends Statement {\r\n kind = NodeKind.THROW;\r\n\r\n /** Value expression being thrown. */\r\n value: Expression;\r\n}\r\n\r\n/** Represents a `try` statement. */\r\nexport class TryStatement extends Statement {\r\n kind = NodeKind.TRY;\r\n\r\n /** Contained statements. */\r\n statements: Statement[];\r\n /** Exception variable name, if a `catch` clause is present. */\r\n catchVariable: IdentifierExpression | null;\r\n /** Statements being executed on catch, if a `catch` clause is present. */\r\n catchStatements: Statement[] | null;\r\n /** Statements being executed afterwards, if a `finally` clause is present. */\r\n finallyStatements: Statement[] | null;\r\n}\r\n\r\n/** Represents a `type` declaration. */\r\nexport class TypeDeclaration extends DeclarationStatement {\r\n kind = NodeKind.TYPEDECLARATION;\r\n\r\n /** Type parameters, if any. */\r\n typeParameters: TypeParameterNode[] | null;\r\n /** Type being aliased. */\r\n type: CommonTypeNode;\r\n}\r\n\r\n/** Represents a variable declaration part of a {@link VariableStatement}. */\r\nexport class VariableDeclaration extends VariableLikeDeclarationStatement {\r\n kind = NodeKind.VARIABLEDECLARATION;\r\n}\r\n\r\n/** Represents a variable statement wrapping {@link VariableDeclaration}s. */\r\nexport class VariableStatement extends Statement {\r\n kind = NodeKind.VARIABLE;\r\n\r\n /** Array of decorators. */\r\n decorators: DecoratorNode[] | null;\r\n /** Array of member declarations. */\r\n declarations: VariableDeclaration[];\r\n}\r\n\r\n/** Represents a void statement dropping an expression's value. */\r\nexport class VoidStatement extends Statement {\r\n kind = NodeKind.VOID;\r\n\r\n /** Expression being dropped. */\r\n expression: Expression;\r\n}\r\n\r\n/** Represents a `while` statement. */\r\nexport class WhileStatement extends Statement {\r\n kind = NodeKind.WHILE;\r\n\r\n /** Condition expression. */\r\n condition: Expression;\r\n /** Statement being looped over. */\r\n statement: Statement;\r\n}\r\n\r\n/** Finds the first decorator matching the specified kind. */\r\nexport function findDecorator(kind: DecoratorKind, decorators: DecoratorNode[] | null): DecoratorNode | null {\r\n if (decorators) {\r\n for (let i = 0, k = decorators.length; i < k; ++i) {\r\n let decorator = decorators[i];\r\n if (decorator.decoratorKind == kind) return decorator;\r\n }\r\n }\r\n return null;\r\n}\r\n\r\n/** Mangles an external to an internal path. */\r\nexport function mangleInternalPath(path: string): string {\r\n if (path.endsWith(\".ts\")) path = path.substring(0, path.length - 3);\r\n return path;\r\n}\r\n\r\n/** Tests if the specified type node represents an omitted type. */\r\nexport function isTypeOmitted(type: CommonTypeNode): bool {\r\n if (type.kind == NodeKind.TYPE) {\r\n let name = (type).name;\r\n return !(name.next || name.identifier.text.length);\r\n }\r\n return false;\r\n}\r\n","/**\r\n * Mappings from AssemblyScript types to WebAssembly types.\r\n * @module types\r\n *//***/\r\n\r\nimport {\r\n Class,\r\n FunctionTarget,\r\n Program,\r\n DecoratorFlags\r\n} from \"./program\";\r\n\r\nimport {\r\n NativeType,\r\n ExpressionRef,\r\n Module\r\n} from \"./module\";\r\n\r\n/** Indicates the kind of a type. */\r\nexport const enum TypeKind {\r\n\r\n // signed integers\r\n\r\n /** An 8-bit signed integer. */\r\n I8,\r\n /** A 16-bit signed integer. */\r\n I16,\r\n /** A 32-bit signed integer. */\r\n I32,\r\n /** A 64-bit signed integer. */\r\n I64,\r\n /** A 32-bit/64-bit signed integer, depending on the target. */\r\n ISIZE,\r\n\r\n // unsigned integers\r\n\r\n /** An 8-bit unsigned integer. */\r\n U8,\r\n /** A 16-bit unsigned integer. */\r\n U16,\r\n /** A 32-bit unsigned integer. Also the base of function types. */\r\n U32,\r\n /** A 64-bit unsigned integer. */\r\n U64,\r\n /** A 32-bit/64-bit unsigned integer, depending on the target. Also the base of class types. */\r\n USIZE,\r\n /** A 1-bit unsigned integer. */\r\n BOOL, // sic\r\n\r\n // floats\r\n\r\n /** A 32-bit float. */\r\n F32,\r\n /** A 64-bit double. */\r\n F64,\r\n\r\n // vectors\r\n\r\n /** A 128-bit vector. */\r\n V128,\r\n\r\n // other\r\n\r\n /** No return type. */\r\n VOID\r\n}\r\n\r\n/** Indicates capabilities of a type. */\r\nexport const enum TypeFlags {\r\n NONE = 0,\r\n /** Is a signed type that can represent negative values. */\r\n SIGNED = 1 << 0,\r\n /** Is an unsigned type that cannot represent negative values. */\r\n UNSIGNED = 1 << 1,\r\n /** Is an integer type. */\r\n INTEGER = 1 << 2,\r\n /** Is a floating point type. */\r\n FLOAT = 1 << 3,\r\n /** Is a pointer type. */\r\n POINTER = 1 << 4,\r\n /** Is smaller than 32-bits. */\r\n SHORT = 1 << 5,\r\n /** Is larger than 32-bits. */\r\n LONG = 1 << 6,\r\n /** Is a value type. */\r\n VALUE = 1 << 7,\r\n /** Is a reference type. */\r\n REFERENCE = 1 << 8,\r\n /** Is a nullable type. */\r\n NULLABLE = 1 << 9,\r\n /** Is a vector type. */\r\n VECTOR = 1 << 10\r\n}\r\n\r\nconst v128_zero = new Uint8Array(16);\r\n\r\n/** Represents a resolved type. */\r\nexport class Type {\r\n\r\n /** Type kind. */\r\n kind: TypeKind;\r\n /** Type flags. */\r\n flags: TypeFlags;\r\n /** Size in bits. */\r\n size: u32;\r\n /** Size in bytes. */\r\n byteSize: i32;\r\n /** Underlying class reference, if a class type. */\r\n classReference: Class | null;\r\n /** Underlying signature reference, if a function type. */\r\n signatureReference: Signature | null;\r\n /** Respective non-nullable type, if nullable. */\r\n nonNullableType: Type;\r\n /** Cached nullable type, if non-nullable. */\r\n private cachedNullableType: Type | null = null;\r\n\r\n /** Constructs a new resolved type. */\r\n constructor(kind: TypeKind, flags: TypeFlags, size: u32) {\r\n this.kind = kind;\r\n this.flags = flags;\r\n this.size = size;\r\n this.byteSize = ceil(size / 8);\r\n this.classReference = null;\r\n this.signatureReference = null;\r\n this.nonNullableType = this;\r\n }\r\n\r\n /** Returns the closest int type representing this type. */\r\n get intType(): Type {\r\n switch (this.kind) {\r\n case TypeKind.I8: return Type.i8;\r\n case TypeKind.I16: return Type.i16;\r\n case TypeKind.F32:\r\n case TypeKind.I32: return Type.i32;\r\n case TypeKind.F64:\r\n case TypeKind.I64: return Type.i64;\r\n case TypeKind.ISIZE: return this.size == 64 ? Type.isize64 : Type.isize32;\r\n case TypeKind.U8: return Type.u8;\r\n case TypeKind.U16: return Type.u16;\r\n case TypeKind.U32: return Type.u32;\r\n case TypeKind.U64: return Type.u64;\r\n case TypeKind.USIZE: return this.size == 64 ? Type.usize64 : Type.usize32;\r\n case TypeKind.BOOL:\r\n default: return Type.i32;\r\n }\r\n }\r\n\r\n /** Substitutes this type with the auto type if this type is void. */\r\n get exceptVoid(): Type {\r\n if (this.kind == TypeKind.VOID) return Type.auto;\r\n return this;\r\n }\r\n\r\n /** Gets this type's logarithmic alignment in memory. */\r\n get alignLog2(): i32 {\r\n return 31 - clz(this.byteSize);\r\n }\r\n\r\n /** Tests if this is a managed type that needs GC hooks. */\r\n get isManaged(): bool {\r\n var classReference = this.classReference;\r\n return classReference !== null && !classReference.hasDecorator(DecoratorFlags.UNMANAGED);\r\n }\r\n\r\n /** Tests if this is a class type explicitly annotated as unmanaged. */\r\n get isUnmanaged(): bool {\r\n var classReference = this.classReference;\r\n return classReference !== null && classReference.hasDecorator(DecoratorFlags.UNMANAGED);\r\n }\r\n\r\n /** Computes the sign-extending shift in the target type. */\r\n computeSmallIntegerShift(targetType: Type): u32 {\r\n return targetType.size - this.size;\r\n }\r\n\r\n /** Computes the truncating mask in the target type. */\r\n computeSmallIntegerMask(targetType: Type): u32 {\r\n var size = this.is(TypeFlags.UNSIGNED) ? this.size : this.size - 1;\r\n return ~0 >>> (targetType.size - size);\r\n }\r\n\r\n /** Tests if this type has (all of) the specified flags. */\r\n is(flags: TypeFlags): bool { return (this.flags & flags) == flags; }\r\n /** Tests if this type has any of the specified flags. */\r\n isAny(flags: TypeFlags): bool { return (this.flags & flags) != 0; }\r\n\r\n /** Composes a class type from this type and a class. */\r\n asClass(classType: Class): Type {\r\n assert(this.kind == TypeKind.USIZE && !this.classReference);\r\n var ret = new Type(this.kind, this.flags & ~TypeFlags.VALUE | TypeFlags.REFERENCE, this.size);\r\n ret.classReference = classType;\r\n return ret;\r\n }\r\n\r\n /** Composes a function type from this type and a function. */\r\n asFunction(signature: Signature): Type {\r\n assert(this.kind == TypeKind.U32 && !this.signatureReference);\r\n var ret = new Type(this.kind, this.flags & ~TypeFlags.VALUE | TypeFlags.REFERENCE, this.size);\r\n ret.signatureReference = signature;\r\n return ret;\r\n }\r\n\r\n /** Composes the respective nullable type of this type. */\r\n asNullable(): Type {\r\n assert(this.is(TypeFlags.REFERENCE));\r\n if (!this.cachedNullableType) {\r\n assert(!this.is(TypeFlags.NULLABLE));\r\n this.cachedNullableType = new Type(this.kind, this.flags | TypeFlags.NULLABLE, this.size);\r\n this.cachedNullableType.nonNullableType = this;\r\n this.cachedNullableType.classReference = this.classReference; // either a class reference\r\n this.cachedNullableType.signatureReference = this.signatureReference; // or a function reference\r\n }\r\n return this.cachedNullableType;\r\n }\r\n\r\n /** Tests if a value of this type is assignable to the target type incl. implicit conversion. */\r\n isAssignableTo(target: Type, signednessIsRelevant: bool = false): bool {\r\n var currentClass: Class | null;\r\n var targetClass: Class | null;\r\n var currentFunction: Signature | null;\r\n var targetFunction: Signature | null;\r\n if (this.is(TypeFlags.REFERENCE)) {\r\n if (target.is(TypeFlags.REFERENCE)) {\r\n if (!this.is(TypeFlags.NULLABLE) || target.is(TypeFlags.NULLABLE)) {\r\n if (currentClass = this.classReference) {\r\n if (targetClass = target.classReference) {\r\n return currentClass.isAssignableTo(targetClass);\r\n }\r\n } else if (currentFunction = this.signatureReference) {\r\n if (targetFunction = target.signatureReference) {\r\n return currentFunction.isAssignableTo(targetFunction);\r\n }\r\n }\r\n }\r\n }\r\n } else if (!target.is(TypeFlags.REFERENCE)) {\r\n if (this.is(TypeFlags.INTEGER)) {\r\n if (target.is(TypeFlags.INTEGER)) {\r\n if (\r\n !signednessIsRelevant ||\r\n this == Type.bool || // a bool (0 or 1) can be safely assigned to all sorts of integers\r\n this.is(TypeFlags.SIGNED) == target.is(TypeFlags.SIGNED)\r\n ) {\r\n return this.size <= target.size;\r\n }\r\n } else if (target.kind == TypeKind.F32) {\r\n return this.size <= 23; // mantissa bits\r\n } else if (target.kind == TypeKind.F64) {\r\n return this.size <= 52; // ^\r\n }\r\n } else if (this.is(TypeFlags.FLOAT)) {\r\n if (target.is(TypeFlags.FLOAT)) {\r\n return this.size <= target.size;\r\n }\r\n } else if (this.is(TypeFlags.VECTOR)) {\r\n if (target.is(TypeFlags.VECTOR)) {\r\n return this.size == target.size;\r\n }\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n /** Tests if a value of this type is assignable to the target type excl. implicit conversion. */\r\n isStrictlyAssignableTo(target: Type, signednessIsRelevant: bool = false): bool {\r\n if (this.is(TypeFlags.REFERENCE)) return this.isAssignableTo(target);\r\n else if (target.is(TypeFlags.REFERENCE)) return false;\r\n if (this.is(TypeFlags.INTEGER)) {\r\n return target.is(TypeFlags.INTEGER) && target.size == this.size && (\r\n !signednessIsRelevant || this.is(TypeFlags.SIGNED) == target.is(TypeFlags.SIGNED)\r\n );\r\n }\r\n return this.kind == target.kind;\r\n }\r\n\r\n /** Determines the common denominator type of two types, if there is any. */\r\n static commonDenominator(left: Type, right: Type, signednessIsImportant: bool): Type | null {\r\n if (right.isAssignableTo(left, signednessIsImportant)) return left;\r\n else if (left.isAssignableTo(right, signednessIsImportant)) return right;\r\n return null;\r\n }\r\n\r\n /** Converts this type to a string. */\r\n toString(): string {\r\n if (this.is(TypeFlags.REFERENCE)) {\r\n let classReference = this.classReference;\r\n if (classReference) {\r\n return this.is(TypeFlags.NULLABLE)\r\n ? classReference.internalName + \" | null\"\r\n : classReference.internalName;\r\n }\r\n let signatureReference = this.signatureReference;\r\n if (signatureReference) {\r\n return this.is(TypeFlags.NULLABLE)\r\n ? \"(\" + signatureReference.toString() + \") | null\"\r\n : signatureReference.toString();\r\n }\r\n assert(false);\r\n }\r\n switch (this.kind) {\r\n case TypeKind.I8: return \"i8\";\r\n case TypeKind.I16: return \"i16\";\r\n case TypeKind.I32: return \"i32\";\r\n case TypeKind.I64: return \"i64\";\r\n case TypeKind.ISIZE: return \"isize\";\r\n case TypeKind.U8: return \"u8\";\r\n case TypeKind.U16: return \"u16\";\r\n case TypeKind.U32: return \"u32\";\r\n case TypeKind.U64: return \"u64\";\r\n case TypeKind.USIZE: return \"usize\";\r\n case TypeKind.BOOL: return \"bool\";\r\n case TypeKind.F32: return \"f32\";\r\n case TypeKind.F64: return \"f64\";\r\n case TypeKind.V128: return \"v128\";\r\n default: assert(false);\r\n case TypeKind.VOID: return \"void\";\r\n }\r\n }\r\n\r\n // Binaryen specific\r\n\r\n /** Converts this type to its respective native type. */\r\n toNativeType(): NativeType {\r\n switch (this.kind) {\r\n default: return NativeType.I32;\r\n case TypeKind.I64:\r\n case TypeKind.U64: return NativeType.I64;\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: return this.size == 64 ? NativeType.I64 : NativeType.I32;\r\n case TypeKind.F32: return NativeType.F32;\r\n case TypeKind.F64: return NativeType.F64;\r\n case TypeKind.V128: return NativeType.V128;\r\n case TypeKind.VOID: return NativeType.None;\r\n }\r\n }\r\n\r\n /** Converts this type to its native `0` value. */\r\n toNativeZero(module: Module): ExpressionRef {\r\n switch (this.kind) {\r\n case TypeKind.VOID: assert(false);\r\n default: return module.i32(0);\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: if (this.size != 64) return module.i32(0);\r\n case TypeKind.I64:\r\n case TypeKind.U64: return module.i64(0);\r\n case TypeKind.F32: return module.f32(0);\r\n case TypeKind.F64: return module.f64(0);\r\n case TypeKind.V128: return module.v128(v128_zero);\r\n }\r\n }\r\n\r\n /** Converts this type to its native `1` value. */\r\n toNativeOne(module: Module): ExpressionRef {\r\n switch (this.kind) {\r\n case TypeKind.V128:\r\n case TypeKind.VOID: assert(false);\r\n default: return module.i32(1);\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: if (this.size != 64) return module.i32(1);\r\n case TypeKind.I64:\r\n case TypeKind.U64: return module.i64(1);\r\n case TypeKind.F32: return module.f32(1);\r\n case TypeKind.F64: return module.f64(1);\r\n }\r\n }\r\n\r\n /** Converts this type to its native `-1` value. */\r\n toNativeNegOne(module: Module): ExpressionRef {\r\n switch (this.kind) {\r\n case TypeKind.V128:\r\n case TypeKind.VOID: assert(false);\r\n default: return module.i32(-1);\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: if (this.size != 64) return module.i32(-1);\r\n case TypeKind.I64:\r\n case TypeKind.U64: return module.i64(-1, -1);\r\n case TypeKind.F32: return module.f32(-1);\r\n case TypeKind.F64: return module.f64(-1);\r\n }\r\n }\r\n\r\n /** Converts this type to its signature string. */\r\n toSignatureString(): string {\r\n switch (this.kind) {\r\n // same naming scheme as Binaryen\r\n case TypeKind.I8:\r\n case TypeKind.U8:\r\n case TypeKind.I16:\r\n case TypeKind.U16:\r\n case TypeKind.I32:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: return \"i\";\r\n case TypeKind.I64:\r\n case TypeKind.U64: return \"j\";\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: return this.size == 64 ? \"j\" : \"i\";\r\n case TypeKind.F32: return \"f\";\r\n case TypeKind.F64: return \"d\";\r\n case TypeKind.V128: return \"V\";\r\n case TypeKind.VOID: return \"v\";\r\n default: assert(false);\r\n }\r\n return \"i\";\r\n }\r\n\r\n // Types\r\n\r\n /** An 8-bit signed integer. */\r\n static readonly i8: Type = new Type(TypeKind.I8,\r\n TypeFlags.SIGNED |\r\n TypeFlags.SHORT |\r\n TypeFlags.INTEGER |\r\n TypeFlags.VALUE, 8\r\n );\r\n\r\n /** A 16-bit signed integer. */\r\n static readonly i16: Type = new Type(TypeKind.I16,\r\n TypeFlags.SIGNED |\r\n TypeFlags.SHORT |\r\n TypeFlags.INTEGER |\r\n TypeFlags.VALUE, 16\r\n );\r\n\r\n /** A 32-bit signed integer. */\r\n static readonly i32: Type = new Type(TypeKind.I32,\r\n TypeFlags.SIGNED |\r\n TypeFlags.INTEGER |\r\n TypeFlags.VALUE, 32\r\n );\r\n\r\n /** A 64-bit signed integer. */\r\n static readonly i64: Type = new Type(TypeKind.I64,\r\n TypeFlags.SIGNED |\r\n TypeFlags.LONG |\r\n TypeFlags.INTEGER |\r\n TypeFlags.VALUE, 64\r\n );\r\n\r\n /** A 32-bit signed size. WASM32 only. */\r\n static readonly isize32: Type = new Type(TypeKind.ISIZE,\r\n TypeFlags.SIGNED |\r\n TypeFlags.INTEGER |\r\n TypeFlags.POINTER |\r\n TypeFlags.VALUE, 32\r\n );\r\n\r\n /** A 64-bit signed size. WASM64 only. */\r\n static readonly isize64: Type = new Type(TypeKind.ISIZE,\r\n TypeFlags.SIGNED |\r\n TypeFlags.LONG |\r\n TypeFlags.INTEGER |\r\n TypeFlags.POINTER |\r\n TypeFlags.VALUE, 64\r\n );\r\n\r\n /** An 8-bit unsigned integer. */\r\n static readonly u8: Type = new Type(TypeKind.U8,\r\n TypeFlags.UNSIGNED |\r\n TypeFlags.SHORT |\r\n TypeFlags.INTEGER |\r\n TypeFlags.VALUE, 8\r\n );\r\n\r\n /** A 16-bit unsigned integer. */\r\n static readonly u16: Type = new Type(TypeKind.U16,\r\n TypeFlags.UNSIGNED |\r\n TypeFlags.SHORT |\r\n TypeFlags.INTEGER |\r\n TypeFlags.VALUE, 16\r\n );\r\n\r\n /** A 32-bit unsigned integer. */\r\n static readonly u32: Type = new Type(TypeKind.U32,\r\n TypeFlags.UNSIGNED |\r\n TypeFlags.INTEGER |\r\n TypeFlags.VALUE, 32\r\n );\r\n\r\n /** A 64-bit unsigned integer. */\r\n static readonly u64: Type = new Type(TypeKind.U64,\r\n TypeFlags.UNSIGNED |\r\n TypeFlags.LONG |\r\n TypeFlags.INTEGER |\r\n TypeFlags.VALUE, 64\r\n );\r\n\r\n /** A 32-bit unsigned size. WASM32 only. */\r\n static readonly usize32: Type = new Type(TypeKind.USIZE,\r\n TypeFlags.UNSIGNED |\r\n TypeFlags.INTEGER |\r\n TypeFlags.POINTER |\r\n TypeFlags.VALUE, 32\r\n );\r\n\r\n /** A 64-bit unsigned size. WASM64 only. */\r\n static readonly usize64: Type = new Type(TypeKind.USIZE,\r\n TypeFlags.UNSIGNED |\r\n TypeFlags.LONG |\r\n TypeFlags.INTEGER |\r\n TypeFlags.POINTER |\r\n TypeFlags.VALUE, 64\r\n );\r\n\r\n /** A 1-bit unsigned integer. */\r\n static readonly bool: Type = new Type(TypeKind.BOOL,\r\n TypeFlags.UNSIGNED |\r\n TypeFlags.SHORT |\r\n TypeFlags.INTEGER |\r\n TypeFlags.VALUE, 1\r\n );\r\n\r\n /** A 32-bit float. */\r\n static readonly f32: Type = new Type(TypeKind.F32,\r\n TypeFlags.SIGNED |\r\n TypeFlags.FLOAT |\r\n TypeFlags.VALUE, 32\r\n );\r\n\r\n /** A 64-bit float. */\r\n static readonly f64: Type = new Type(TypeKind.F64,\r\n TypeFlags.SIGNED |\r\n TypeFlags.LONG |\r\n TypeFlags.FLOAT |\r\n TypeFlags.VALUE, 64\r\n );\r\n\r\n /** A 128-bit vector. */\r\n static readonly v128: Type = new Type(TypeKind.V128,\r\n TypeFlags.VECTOR |\r\n TypeFlags.VALUE, 128\r\n );\r\n\r\n /** No return type. */\r\n static readonly void: Type = new Type(TypeKind.VOID, TypeFlags.NONE, 0);\r\n\r\n /** Alias of i32 indicating type inference of locals and globals with just an initializer. */\r\n static readonly auto: Type = new Type(Type.i32.kind, Type.i32.flags, Type.i32.size);\r\n}\r\n\r\n/** Converts an array of types to an array of native types. */\r\nexport function typesToNativeTypes(types: Type[]): NativeType[] {\r\n var numTypes = types.length;\r\n var ret = new Array(numTypes);\r\n for (let i = 0; i < numTypes; ++i) ret[i] = types[i].toNativeType();\r\n return ret;\r\n}\r\n\r\n/** Converts an array of types to its combined string representation. */\r\nexport function typesToString(types: Type[]): string {\r\n var numTypes = types.length;\r\n if (!numTypes) return \"\";\r\n var sb = new Array(numTypes);\r\n for (let i = 0; i < numTypes; ++i) sb[i] = types[i].toString();\r\n return sb.join(\",\");\r\n}\r\n\r\n/** Represents a fully resolved function signature. */\r\nexport class Signature {\r\n\r\n /** Parameter types, if any, excluding `this`. */\r\n parameterTypes: Type[];\r\n /** Parameter names, if known, excluding `this`. */\r\n parameterNames: string[] | null;\r\n /** Number of required parameters excluding `this`. Other parameters are considered optional. */\r\n requiredParameters: i32;\r\n /** Return type. */\r\n returnType: Type;\r\n /** This type, if an instance signature. */\r\n thisType: Type | null;\r\n /** Whether the last parameter is a rest parameter. */\r\n hasRest: bool;\r\n /** Cached {@link FunctionTarget}. */\r\n cachedFunctionTarget: FunctionTarget | null = null;\r\n /** Respective function type. */\r\n type: Type;\r\n\r\n /** Constructs a new signature. */\r\n constructor(\r\n parameterTypes: Type[] | null = null,\r\n returnType: Type | null = null,\r\n thisType: Type | null = null\r\n ) {\r\n this.parameterTypes = parameterTypes ? parameterTypes : [];\r\n this.parameterNames = null;\r\n this.requiredParameters = 0;\r\n this.returnType = returnType ? returnType : Type.void;\r\n this.thisType = thisType;\r\n this.hasRest = false;\r\n this.type = Type.u32.asFunction(this);\r\n }\r\n\r\n asFunctionTarget(program: Program): FunctionTarget {\r\n var target = this.cachedFunctionTarget;\r\n if (!target) this.cachedFunctionTarget = target = new FunctionTarget(this, program);\r\n else assert(target.program == program);\r\n return target;\r\n }\r\n\r\n /** Gets the known or, alternatively, generic parameter name at the specified index. */\r\n getParameterName(index: i32): string {\r\n var parameterNames = this.parameterNames;\r\n return parameterNames && parameterNames.length > index\r\n ? parameterNames[index]\r\n : getDefaultParameterName(index);\r\n }\r\n\r\n /** Tests if a value of this function type is assignable to a target of the specified function type. */\r\n isAssignableTo(target: Signature): bool {\r\n // TODO: maybe cache results?\r\n\r\n // check `this` type\r\n var thisThisType = this.thisType;\r\n var targetThisType = target.thisType;\r\n if (thisThisType) {\r\n if (!(targetThisType && thisThisType.isAssignableTo(targetThisType))) return false;\r\n } else if (targetThisType) {\r\n return false;\r\n }\r\n\r\n // check rest parameter\r\n if (this.hasRest != target.hasRest) return false; // TODO\r\n\r\n // check parameter types\r\n var thisParameterTypes = this.parameterTypes;\r\n var targetParameterTypes = target.parameterTypes;\r\n var numParameters = thisParameterTypes.length;\r\n if (numParameters != targetParameterTypes.length) return false;\r\n for (let i = 0; i < numParameters; ++i) {\r\n let thisParameterType = thisParameterTypes[i];\r\n let targetParameterType = targetParameterTypes[i];\r\n if (!thisParameterType.isAssignableTo(targetParameterType)) return false;\r\n }\r\n\r\n // check return type\r\n var thisReturnType = this.returnType;\r\n var targetReturnType = target.returnType;\r\n return thisReturnType == targetReturnType || thisReturnType.isAssignableTo(targetReturnType);\r\n }\r\n\r\n /** Converts a signature to a function type string. */\r\n static makeSignatureString(parameterTypes: Type[] | null, returnType: Type, thisType: Type | null = null): string {\r\n var sb = [];\r\n sb.push(returnType.toSignatureString());\r\n if (thisType) sb.push(thisType.toSignatureString());\r\n if (parameterTypes) {\r\n for (let i = 0, k = parameterTypes.length; i < k; ++i) sb.push(parameterTypes[i].toSignatureString());\r\n }\r\n return \"FUNCSIG$\" + sb.join(\"\");\r\n }\r\n\r\n /** Converts this signature to a function type string. */\r\n toSignatureString(): string {\r\n return Signature.makeSignatureString(this.parameterTypes, this.returnType, this.thisType);\r\n }\r\n\r\n /** Converts this signature to a string. */\r\n toString(): string {\r\n var sb = new Array();\r\n sb.push(\"(\");\r\n var index = 0;\r\n var thisType = this.thisType;\r\n if (thisType) {\r\n sb.push(\"this: \");\r\n assert(!thisType.signatureReference);\r\n sb.push(thisType.toString());\r\n index = 1;\r\n }\r\n var parameters = this.parameterTypes;\r\n var numParameters = parameters.length;\r\n if (numParameters) {\r\n let names = this.parameterNames;\r\n let numNames = names ? names.length : 0;\r\n let optionalStart = this.requiredParameters;\r\n let restIndex = this.hasRest ? numParameters - 1 : -1;\r\n for (let i = 0; i < numParameters; ++i, ++index) {\r\n if (index) sb.push(\", \");\r\n if (i == restIndex) sb.push(\"...\");\r\n if (i < numNames) sb.push((names)[i]);\r\n else sb.push(getDefaultParameterName(i));\r\n if (i >= optionalStart && i != restIndex) sb.push(\"?: \");\r\n else sb.push(\": \");\r\n sb.push(parameters[i].toString());\r\n }\r\n }\r\n sb.push(\") => \");\r\n sb.push(this.returnType.toString());\r\n return sb.join(\"\");\r\n }\r\n}\r\n\r\n// helpers\r\n\r\n// Cached default parameter names used where names are unknown.\r\nvar cachedDefaultParameterNames: string[] | null = null;\r\n\r\n/** Gets the cached default parameter name for the specified index. */\r\nexport function getDefaultParameterName(index: i32): string {\r\n if (!cachedDefaultParameterNames) cachedDefaultParameterNames = [];\r\n for (let i = cachedDefaultParameterNames.length; i <= index; ++i) {\r\n cachedDefaultParameterNames.push(\"arg$\" + i.toString(10));\r\n }\r\n return cachedDefaultParameterNames[index - 1];\r\n}\r\n","/**\r\n * A TypeScript tokenizer modified for AssemblyScript.\r\n *\r\n * Skips over trivia and provides a general mark/reset mechanism for the parser to utilize on\r\n * ambiguous tokens.\r\n *\r\n * @module tokenizer\r\n *//***/\r\n\r\nimport {\r\n DiagnosticCode,\r\n DiagnosticMessage,\r\n DiagnosticEmitter\r\n} from \"./diagnostics\";\r\n\r\nimport {\r\n Source,\r\n CommentKind\r\n} from \"./ast\";\r\n\r\nimport {\r\n CharCode,\r\n isLineBreak,\r\n isWhiteSpace,\r\n isIdentifierStart,\r\n isIdentifierPart,\r\n isDecimalDigit,\r\n isOctalDigit,\r\n isKeywordCharacter\r\n} from \"./util\";\r\n\r\n/** Named token types. */\r\nexport enum Token {\r\n\r\n // keywords\r\n // discarded: ANY, BOOLEAN, NEVER, NUMBER, STRING, SYMBOL, UNDEFINED, LESSTHAN_SLASH\r\n\r\n ABSTRACT,\r\n AS,\r\n ASYNC,\r\n AWAIT, // ES2017\r\n BREAK, // ES2017\r\n CASE, // ES2017\r\n CATCH, // ES2017\r\n CLASS, // ES2017\r\n CONST, // ES2017\r\n CONTINUE, // ES2017\r\n CONSTRUCTOR,\r\n DEBUGGER, // ES2017\r\n DECLARE,\r\n DEFAULT, // ES2017\r\n DELETE, // ES2017\r\n DO, // ES2017\r\n ELSE, // ES2017\r\n ENUM, // ES2017 future\r\n EXPORT, // ES2017\r\n EXTENDS, // ES2017\r\n FALSE, // ES\r\n FINALLY, // ES2017\r\n FOR, // ES2017\r\n FROM, // AS possible identifier\r\n FUNCTION, // ES2017\r\n GET,\r\n IF, // ES2017\r\n IMPLEMENTS, // ES2017 non-lexical\r\n IMPORT, // ES2017\r\n IN, // ES2017\r\n INSTANCEOF, // ES2017\r\n INTERFACE, // ES2017 non-lexical\r\n IS,\r\n KEYOF,\r\n LET, // ES2017 non-lexical\r\n MODULE, // AS possible identifier\r\n NAMESPACE, // AS possible identifier\r\n NEW, // ES2017\r\n NULL, // ES\r\n OF,\r\n PACKAGE, // ES2017 non-lexical\r\n PRIVATE, // ES2017 non-lexical\r\n PROTECTED, // ES2017 non-lexical\r\n PUBLIC, // ES2017 non-lexical\r\n READONLY,\r\n RETURN, // ES2017\r\n SET,\r\n STATIC, // ES2017 non-lexical\r\n SUPER, // ES2017\r\n SWITCH, // ES2017\r\n THIS, // ES2017\r\n THROW, // ES2017\r\n TRUE, // ES\r\n TRY, // ES2017\r\n TYPE, // AS possible identifier\r\n TYPEOF, // ES2017\r\n VAR, // ES2017\r\n VOID, // ES2017\r\n WHILE, // ES2017\r\n WITH, // ES2017\r\n YIELD, // ES2017\r\n\r\n // punctuation\r\n\r\n OPENBRACE,\r\n CLOSEBRACE,\r\n OPENPAREN,\r\n CLOSEPAREN,\r\n OPENBRACKET,\r\n CLOSEBRACKET,\r\n DOT,\r\n DOT_DOT_DOT,\r\n SEMICOLON,\r\n COMMA,\r\n LESSTHAN,\r\n GREATERTHAN,\r\n LESSTHAN_EQUALS,\r\n GREATERTHAN_EQUALS,\r\n EQUALS_EQUALS,\r\n EXCLAMATION_EQUALS,\r\n EQUALS_EQUALS_EQUALS,\r\n EXCLAMATION_EQUALS_EQUALS,\r\n EQUALS_GREATERTHAN,\r\n PLUS,\r\n MINUS,\r\n ASTERISK_ASTERISK,\r\n ASTERISK,\r\n SLASH,\r\n PERCENT,\r\n PLUS_PLUS,\r\n MINUS_MINUS,\r\n LESSTHAN_LESSTHAN,\r\n GREATERTHAN_GREATERTHAN,\r\n GREATERTHAN_GREATERTHAN_GREATERTHAN,\r\n AMPERSAND,\r\n BAR,\r\n CARET,\r\n EXCLAMATION,\r\n TILDE,\r\n AMPERSAND_AMPERSAND,\r\n BAR_BAR,\r\n QUESTION,\r\n COLON,\r\n EQUALS,\r\n PLUS_EQUALS,\r\n MINUS_EQUALS,\r\n ASTERISK_EQUALS,\r\n ASTERISK_ASTERISK_EQUALS,\r\n SLASH_EQUALS,\r\n PERCENT_EQUALS,\r\n LESSTHAN_LESSTHAN_EQUALS,\r\n GREATERTHAN_GREATERTHAN_EQUALS,\r\n GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS,\r\n AMPERSAND_EQUALS,\r\n BAR_EQUALS,\r\n CARET_EQUALS,\r\n AT,\r\n\r\n // literals\r\n\r\n IDENTIFIER,\r\n STRINGLITERAL,\r\n INTEGERLITERAL,\r\n FLOATLITERAL,\r\n\r\n // meta\r\n\r\n INVALID,\r\n ENDOFFILE\r\n}\r\n\r\nexport enum IdentifierHandling {\r\n DEFAULT,\r\n PREFER,\r\n ALWAYS\r\n}\r\n\r\nexport function tokenFromKeyword(text: string): Token {\r\n assert(text.length);\r\n switch (text.charCodeAt(0)) {\r\n case CharCode.a: {\r\n switch (text) {\r\n case \"abstract\": return Token.ABSTRACT;\r\n case \"as\": return Token.AS;\r\n case \"async\": return Token.ASYNC;\r\n case \"await\": return Token.AWAIT;\r\n }\r\n break;\r\n }\r\n case CharCode.b: {\r\n switch (text) {\r\n case \"break\": return Token.BREAK;\r\n }\r\n break;\r\n }\r\n case CharCode.c: {\r\n switch (text) {\r\n case \"case\": return Token.CASE;\r\n case \"catch\": return Token.CATCH;\r\n case \"class\": return Token.CLASS;\r\n case \"continue\": return Token.CONTINUE;\r\n case \"const\": return Token.CONST;\r\n case \"constructor\": return Token.CONSTRUCTOR;\r\n }\r\n break;\r\n }\r\n case CharCode.d: {\r\n switch (text) {\r\n case \"debugger\": return Token.DEBUGGER;\r\n case \"declare\": return Token.DECLARE;\r\n case \"default\": return Token.DEFAULT;\r\n case \"delete\": return Token.DELETE;\r\n case \"do\": return Token.DO;\r\n }\r\n break;\r\n }\r\n case CharCode.e: {\r\n switch (text) {\r\n case \"else\": return Token.ELSE;\r\n case \"enum\": return Token.ENUM;\r\n case \"export\": return Token.EXPORT;\r\n case \"extends\": return Token.EXTENDS;\r\n }\r\n break;\r\n }\r\n case CharCode.f: {\r\n switch (text) {\r\n case \"false\": return Token.FALSE;\r\n case \"finally\": return Token.FINALLY;\r\n case \"for\": return Token.FOR;\r\n case \"from\": return Token.FROM;\r\n case \"function\": return Token.FUNCTION;\r\n }\r\n break;\r\n }\r\n case CharCode.g: {\r\n switch (text) {\r\n case \"get\": return Token.GET;\r\n }\r\n break;\r\n }\r\n case CharCode.i: {\r\n switch (text) {\r\n case \"if\": return Token.IF;\r\n case \"implements\": return Token.IMPLEMENTS;\r\n case \"import\": return Token.IMPORT;\r\n case \"in\": return Token.IN;\r\n case \"instanceof\": return Token.INSTANCEOF;\r\n case \"interface\": return Token.INTERFACE;\r\n case \"is\": return Token.IS;\r\n }\r\n break;\r\n }\r\n case CharCode.k: {\r\n switch (text) {\r\n case \"keyof\": return Token.KEYOF;\r\n }\r\n break;\r\n }\r\n case CharCode.l: {\r\n switch (text) {\r\n case \"let\": return Token.LET;\r\n }\r\n break;\r\n }\r\n case CharCode.m: {\r\n switch (text) {\r\n case \"module\": return Token.MODULE;\r\n }\r\n break;\r\n }\r\n case CharCode.n: {\r\n switch (text) {\r\n case \"namespace\": return Token.NAMESPACE;\r\n case \"new\": return Token.NEW;\r\n case \"null\": return Token.NULL;\r\n }\r\n break;\r\n }\r\n case CharCode.o: {\r\n switch (text) {\r\n case \"of\": return Token.OF;\r\n }\r\n break;\r\n }\r\n case CharCode.p: {\r\n switch (text) {\r\n case \"package\": return Token.PACKAGE;\r\n case \"private\": return Token.PRIVATE;\r\n case \"protected\": return Token.PROTECTED;\r\n case \"public\": return Token.PUBLIC;\r\n }\r\n break;\r\n }\r\n case CharCode.r: {\r\n switch (text) {\r\n case \"readonly\": return Token.READONLY;\r\n case \"return\": return Token.RETURN;\r\n }\r\n break;\r\n }\r\n case CharCode.s: {\r\n switch (text) {\r\n case \"set\": return Token.SET;\r\n case \"static\": return Token.STATIC;\r\n case \"super\": return Token.SUPER;\r\n case \"switch\": return Token.SWITCH;\r\n }\r\n break;\r\n }\r\n case CharCode.t: {\r\n switch (text) {\r\n case \"this\": return Token.THIS;\r\n case \"throw\": return Token.THROW;\r\n case \"true\": return Token.TRUE;\r\n case \"try\": return Token.TRY;\r\n case \"type\": return Token.TYPE;\r\n case \"typeof\": return Token.TYPEOF;\r\n }\r\n break;\r\n }\r\n case CharCode.v: {\r\n switch (text) {\r\n case \"var\": return Token.VAR;\r\n case \"void\": return Token.VOID;\r\n }\r\n break;\r\n }\r\n case CharCode.w: {\r\n switch (text) {\r\n case \"while\": return Token.WHILE;\r\n case \"with\": return Token.WITH;\r\n }\r\n break;\r\n }\r\n case CharCode.y: {\r\n switch (text) {\r\n case \"yield\": return Token.YIELD;\r\n }\r\n break;\r\n }\r\n }\r\n return Token.INVALID;\r\n}\r\n\r\nexport function tokenIsAlsoIdentifier(token: Token): bool {\r\n switch (token) {\r\n case Token.ABSTRACT:\r\n case Token.AS:\r\n case Token.CONSTRUCTOR:\r\n case Token.DECLARE:\r\n case Token.DELETE:\r\n case Token.FROM:\r\n case Token.FOR:\r\n case Token.GET:\r\n case Token.INSTANCEOF:\r\n case Token.IS:\r\n case Token.KEYOF:\r\n case Token.MODULE:\r\n case Token.NAMESPACE:\r\n case Token.READONLY:\r\n case Token.SET:\r\n case Token.TYPE:\r\n case Token.VOID: return true;\r\n default: return false;\r\n }\r\n}\r\n\r\nexport function operatorTokenToString(token: Token): string {\r\n switch (token) {\r\n case Token.DELETE: return \"delete\";\r\n case Token.IN: return \"in\";\r\n case Token.INSTANCEOF: return \"instanceof\";\r\n case Token.NEW: return \"new\";\r\n case Token.TYPEOF: return \"typeof\";\r\n case Token.VOID: return \"void\";\r\n case Token.YIELD: return \"yield\";\r\n case Token.DOT_DOT_DOT: return \"...\";\r\n case Token.COMMA: return \",\";\r\n case Token.LESSTHAN: return \"<\";\r\n case Token.GREATERTHAN: return \">\";\r\n case Token.LESSTHAN_EQUALS: return \"<=\";\r\n case Token.GREATERTHAN_EQUALS: return \">=\";\r\n case Token.EQUALS_EQUALS: return \"==\";\r\n case Token.EXCLAMATION_EQUALS: return \"!=\";\r\n case Token.EQUALS_EQUALS_EQUALS: return \"===\";\r\n case Token.EXCLAMATION_EQUALS_EQUALS: return \"!==\";\r\n case Token.PLUS: return \"+\";\r\n case Token.MINUS: return \"-\";\r\n case Token.ASTERISK_ASTERISK: return \"**\";\r\n case Token.ASTERISK: return \"*\";\r\n case Token.SLASH: return \"/\";\r\n case Token.PERCENT: return \"%\";\r\n case Token.PLUS_PLUS: return \"++\";\r\n case Token.MINUS_MINUS: return \"--\";\r\n case Token.LESSTHAN_LESSTHAN: return \"<<\";\r\n case Token.GREATERTHAN_GREATERTHAN: return \">>\";\r\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN: return \">>>\";\r\n case Token.AMPERSAND: return \"&\";\r\n case Token.BAR: return \"|\";\r\n case Token.CARET: return \"^\";\r\n case Token.EXCLAMATION: return \"!\";\r\n case Token.TILDE: return \"~\";\r\n case Token.AMPERSAND_AMPERSAND: return \"&&\";\r\n case Token.BAR_BAR: return \"||\";\r\n case Token.EQUALS: return \"=\";\r\n case Token.PLUS_EQUALS: return \"+=\";\r\n case Token.MINUS_EQUALS: return \"-=\";\r\n case Token.ASTERISK_EQUALS: return \"*=\";\r\n case Token.ASTERISK_ASTERISK_EQUALS: return \"**=\";\r\n case Token.SLASH_EQUALS: return \"/=\";\r\n case Token.PERCENT_EQUALS: return \"%=\";\r\n case Token.LESSTHAN_LESSTHAN_EQUALS: return \"<<=\";\r\n case Token.GREATERTHAN_GREATERTHAN_EQUALS: return \">>=\";\r\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS: return \">>>=\";\r\n case Token.AMPERSAND_EQUALS: return \"&=\";\r\n case Token.BAR_EQUALS: return \"|=\";\r\n case Token.CARET_EQUALS: return \"^=\";\r\n default: {\r\n assert(false);\r\n return \"\";\r\n }\r\n }\r\n}\r\n\r\nexport class Range {\r\n\r\n source: Source;\r\n start: i32;\r\n end: i32;\r\n\r\n // TODO: set these while tokenizing\r\n // line: i32;\r\n // column: i32;\r\n\r\n constructor(source: Source, start: i32, end: i32) {\r\n this.source = source;\r\n this.start = start;\r\n this.end = end;\r\n }\r\n\r\n static join(a: Range, b: Range): Range {\r\n if (a.source != b.source) throw new Error(\"source mismatch\");\r\n return new Range(a.source,\r\n a.start < b.start ? a.start : b.start,\r\n a.end > b.end ? a.end : b.end\r\n );\r\n }\r\n\r\n get atStart(): Range {\r\n return new Range(this.source, this.start, this.start);\r\n }\r\n\r\n get atEnd(): Range {\r\n return new Range(this.source, this.end, this.end);\r\n }\r\n\r\n get line(): i32 {\r\n var text = this.source.text;\r\n var line = 1;\r\n for (let pos = this.start; pos >= 0; --pos) {\r\n if (text.charCodeAt(pos) == CharCode.LINEFEED) line++;\r\n }\r\n return line;\r\n }\r\n\r\n get column(): i32 {\r\n var text = this.source.text;\r\n var column = 0;\r\n for (let pos = this.start - 1; pos >= 0; --pos) {\r\n if (text.charCodeAt(pos) == CharCode.LINEFEED) break;\r\n ++column;\r\n }\r\n return column;\r\n }\r\n\r\n toString(): string {\r\n return this.source.text.substring(this.start, this.end);\r\n }\r\n\r\n debugInfoRef: usize = 0;\r\n}\r\n\r\ndeclare function parseFloat(str: string): f64;\r\n\r\n/** Handler for intercepting comments while tokenizing. */\r\nexport type CommentHandler = (kind: CommentKind, text: string, range: Range) => void;\r\n\r\n/** Tokenizes a source to individual {@link Token}s. */\r\nexport class Tokenizer extends DiagnosticEmitter {\r\n\r\n source: Source;\r\n end: i32 = 0;\r\n\r\n pos: i32 = 0;\r\n token: Token = -1;\r\n tokenPos: i32 = 0;\r\n\r\n nextToken: Token = -1;\r\n nextTokenPos: i32 = 0;\r\n nextTokenOnNewLine: bool = false;\r\n\r\n onComment: CommentHandler | null = null;\r\n\r\n /** Constructs a new tokenizer. */\r\n constructor(source: Source, diagnostics: DiagnosticMessage[] | null = null) {\r\n super(diagnostics);\r\n\r\n this.source = source;\r\n this.pos = 0;\r\n this.end = source.text.length;\r\n this.diagnostics = diagnostics || new Array();\r\n\r\n var end = this.end;\r\n var text = source.text;\r\n\r\n // skip bom\r\n if (\r\n this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.BYTEORDERMARK\r\n ) {\r\n ++this.pos;\r\n }\r\n\r\n // skip shebang\r\n if (\r\n this.pos + 1 < end &&\r\n text.charCodeAt(this.pos) == CharCode.HASH &&\r\n text.charCodeAt(this.pos + 1) == CharCode.EXCLAMATION\r\n ) {\r\n this.pos += 2;\r\n while (\r\n this.pos < end &&\r\n text.charCodeAt(this.pos) != CharCode.LINEFEED\r\n ) {\r\n ++this.pos;\r\n }\r\n // 'next' now starts at lf or eof\r\n }\r\n }\r\n\r\n next(identifierHandling: IdentifierHandling = IdentifierHandling.DEFAULT): Token {\r\n this.nextToken = -1;\r\n return this.token = this.unsafeNext(identifierHandling);\r\n }\r\n\r\n private unsafeNext(\r\n identifierHandling: IdentifierHandling = IdentifierHandling.DEFAULT,\r\n maxTokenLength: i32 = i32.MAX_VALUE\r\n ): Token {\r\n var end = this.end;\r\n var text = this.source.text;\r\n while (this.pos < end) {\r\n this.tokenPos = this.pos;\r\n let c = text.charCodeAt(this.pos);\r\n switch (c) {\r\n case CharCode.CARRIAGERETURN: {\r\n if (!(\r\n ++this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.LINEFEED\r\n )) break;\r\n // otherwise fall-through\r\n }\r\n case CharCode.LINEFEED:\r\n case CharCode.TAB:\r\n case CharCode.VERTICALTAB:\r\n case CharCode.FORMFEED:\r\n case CharCode.SPACE: {\r\n ++this.pos;\r\n break;\r\n }\r\n case CharCode.EXCLAMATION: {\r\n ++this.pos;\r\n if (\r\n maxTokenLength > 1 && this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.EQUALS\r\n ) {\r\n ++this.pos;\r\n if (\r\n maxTokenLength > 2 && this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.EQUALS\r\n ) {\r\n ++this.pos;\r\n return Token.EXCLAMATION_EQUALS_EQUALS;\r\n }\r\n return Token.EXCLAMATION_EQUALS;\r\n }\r\n return Token.EXCLAMATION;\r\n }\r\n case CharCode.DOUBLEQUOTE:\r\n case CharCode.SINGLEQUOTE:\r\n case CharCode.BACKTICK: { // TODO\r\n return Token.STRINGLITERAL; // expects a call to readString\r\n }\r\n case CharCode.PERCENT: {\r\n ++this.pos;\r\n if (\r\n maxTokenLength > 1 && this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.EQUALS\r\n ) {\r\n ++this.pos;\r\n return Token.PERCENT_EQUALS;\r\n }\r\n return Token.PERCENT;\r\n }\r\n case CharCode.AMPERSAND: {\r\n ++this.pos;\r\n if (maxTokenLength > 1 && this.pos < end) {\r\n let chr = text.charCodeAt(this.pos);\r\n if (chr == CharCode.AMPERSAND) {\r\n ++this.pos;\r\n return Token.AMPERSAND_AMPERSAND;\r\n }\r\n if (chr == CharCode.EQUALS) {\r\n ++this.pos;\r\n return Token.AMPERSAND_EQUALS;\r\n }\r\n }\r\n return Token.AMPERSAND;\r\n }\r\n case CharCode.OPENPAREN: {\r\n ++this.pos;\r\n return Token.OPENPAREN;\r\n }\r\n case CharCode.CLOSEPAREN: {\r\n ++this.pos;\r\n return Token.CLOSEPAREN;\r\n }\r\n case CharCode.ASTERISK: {\r\n ++this.pos;\r\n if (maxTokenLength > 1 && this.pos < end) {\r\n let chr = text.charCodeAt(this.pos);\r\n if (chr == CharCode.EQUALS) {\r\n ++this.pos;\r\n return Token.ASTERISK_EQUALS;\r\n }\r\n if (chr == CharCode.ASTERISK) {\r\n ++this.pos;\r\n if (\r\n maxTokenLength > 2 && this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.EQUALS\r\n ) {\r\n ++this.pos;\r\n return Token.ASTERISK_ASTERISK_EQUALS;\r\n }\r\n return Token.ASTERISK_ASTERISK;\r\n }\r\n }\r\n return Token.ASTERISK;\r\n }\r\n case CharCode.PLUS: {\r\n ++this.pos;\r\n if (maxTokenLength > 1 && this.pos < end) {\r\n let chr = text.charCodeAt(this.pos);\r\n if (chr == CharCode.PLUS) {\r\n ++this.pos;\r\n return Token.PLUS_PLUS;\r\n }\r\n if (chr == CharCode.EQUALS) {\r\n ++this.pos;\r\n return Token.PLUS_EQUALS;\r\n }\r\n }\r\n return Token.PLUS;\r\n }\r\n case CharCode.COMMA: {\r\n ++this.pos;\r\n return Token.COMMA;\r\n }\r\n case CharCode.MINUS: {\r\n ++this.pos;\r\n if (maxTokenLength > 1 && this.pos < end) {\r\n let chr = text.charCodeAt(this.pos);\r\n if (chr == CharCode.MINUS) {\r\n ++this.pos;\r\n return Token.MINUS_MINUS;\r\n }\r\n if (chr == CharCode.EQUALS) {\r\n ++this.pos;\r\n return Token.MINUS_EQUALS;\r\n }\r\n }\r\n return Token.MINUS;\r\n }\r\n case CharCode.DOT: {\r\n ++this.pos;\r\n if (maxTokenLength > 1 && this.pos < end) {\r\n let chr = text.charCodeAt(this.pos);\r\n if (isDecimalDigit(chr)) {\r\n --this.pos;\r\n return Token.FLOATLITERAL; // expects a call to readFloat\r\n }\r\n if (\r\n maxTokenLength > 2 && this.pos + 1 < end &&\r\n chr == CharCode.DOT &&\r\n text.charCodeAt(this.pos + 1) == CharCode.DOT\r\n ) {\r\n this.pos += 2;\r\n return Token.DOT_DOT_DOT;\r\n }\r\n }\r\n return Token.DOT;\r\n }\r\n case CharCode.SLASH: {\r\n let commentStartPos = this.pos;\r\n ++this.pos;\r\n if (maxTokenLength > 1 && this.pos < end) {\r\n let chr = text.charCodeAt(this.pos);\r\n if (chr == CharCode.SLASH) { // single-line\r\n let commentKind = CommentKind.LINE;\r\n if (\r\n this.pos + 1 < end &&\r\n text.charCodeAt(this.pos + 1) == CharCode.SLASH\r\n ) {\r\n ++this.pos;\r\n commentKind = CommentKind.TRIPLE;\r\n }\r\n while (++this.pos < end) {\r\n if (text.charCodeAt(this.pos) == CharCode.LINEFEED) {\r\n ++this.pos;\r\n break;\r\n }\r\n }\r\n if (this.onComment) {\r\n this.onComment(\r\n commentKind,\r\n text.substring(commentStartPos, this.pos),\r\n this.range(commentStartPos, this.pos)\r\n );\r\n }\r\n break;\r\n }\r\n if (chr == CharCode.ASTERISK) { // multi-line\r\n let closed = false;\r\n while (++this.pos < end) {\r\n c = text.charCodeAt(this.pos);\r\n if (\r\n c == CharCode.ASTERISK &&\r\n this.pos + 1 < end &&\r\n text.charCodeAt(this.pos + 1) == CharCode.SLASH\r\n ) {\r\n this.pos += 2;\r\n closed = true;\r\n break;\r\n }\r\n }\r\n if (!closed) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n this.range(this.pos), \"*/\"\r\n );\r\n } else if (this.onComment) {\r\n this.onComment(\r\n CommentKind.BLOCK,\r\n text.substring(commentStartPos, this.pos),\r\n this.range(commentStartPos, this.pos)\r\n );\r\n }\r\n break;\r\n }\r\n if (chr == CharCode.EQUALS) {\r\n ++this.pos;\r\n return Token.SLASH_EQUALS;\r\n }\r\n }\r\n return Token.SLASH;\r\n }\r\n case CharCode._0:\r\n case CharCode._1:\r\n case CharCode._2:\r\n case CharCode._3:\r\n case CharCode._4:\r\n case CharCode._5:\r\n case CharCode._6:\r\n case CharCode._7:\r\n case CharCode._8:\r\n case CharCode._9: {\r\n return this.testInteger()\r\n ? Token.INTEGERLITERAL // expects a call to readInteger\r\n : Token.FLOATLITERAL; // expects a call to readFloat\r\n }\r\n case CharCode.COLON: {\r\n ++this.pos;\r\n return Token.COLON;\r\n }\r\n case CharCode.SEMICOLON: {\r\n ++this.pos;\r\n return Token.SEMICOLON;\r\n }\r\n case CharCode.LESSTHAN: {\r\n ++this.pos;\r\n if (maxTokenLength > 1 && this.pos < end) {\r\n let chr = text.charCodeAt(this.pos);\r\n if (chr == CharCode.LESSTHAN) {\r\n ++this.pos;\r\n if (\r\n maxTokenLength > 2 &&\r\n this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.EQUALS\r\n ) {\r\n ++this.pos;\r\n return Token.LESSTHAN_LESSTHAN_EQUALS;\r\n }\r\n return Token.LESSTHAN_LESSTHAN;\r\n }\r\n if (chr == CharCode.EQUALS) {\r\n ++this.pos;\r\n return Token.LESSTHAN_EQUALS;\r\n }\r\n }\r\n return Token.LESSTHAN;\r\n }\r\n case CharCode.EQUALS: {\r\n ++this.pos;\r\n if (maxTokenLength > 1 && this.pos < end) {\r\n let chr = text.charCodeAt(this.pos);\r\n if (chr == CharCode.EQUALS) {\r\n ++this.pos;\r\n if (\r\n maxTokenLength > 2 &&\r\n this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.EQUALS\r\n ) {\r\n ++this.pos;\r\n return Token.EQUALS_EQUALS_EQUALS;\r\n }\r\n return Token.EQUALS_EQUALS;\r\n }\r\n if (chr == CharCode.GREATERTHAN) {\r\n ++this.pos;\r\n return Token.EQUALS_GREATERTHAN;\r\n }\r\n }\r\n return Token.EQUALS;\r\n }\r\n case CharCode.GREATERTHAN: {\r\n ++this.pos;\r\n if (maxTokenLength > 1 && this.pos < end) {\r\n let chr = text.charCodeAt(this.pos);\r\n if (chr == CharCode.GREATERTHAN) {\r\n ++this.pos;\r\n if (maxTokenLength > 2 && this.pos < end) {\r\n chr = text.charCodeAt(this.pos);\r\n if (chr == CharCode.GREATERTHAN) {\r\n ++this.pos;\r\n if (\r\n maxTokenLength > 3 && this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.EQUALS\r\n ) {\r\n ++this.pos;\r\n return Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS;\r\n }\r\n return Token.GREATERTHAN_GREATERTHAN_GREATERTHAN;\r\n }\r\n if (chr == CharCode.EQUALS) {\r\n ++this.pos;\r\n return Token.GREATERTHAN_GREATERTHAN_EQUALS;\r\n }\r\n }\r\n return Token.GREATERTHAN_GREATERTHAN;\r\n }\r\n if (chr == CharCode.EQUALS) {\r\n ++this.pos;\r\n return Token.GREATERTHAN_EQUALS;\r\n }\r\n }\r\n return Token.GREATERTHAN;\r\n }\r\n case CharCode.QUESTION: {\r\n ++this.pos;\r\n return Token.QUESTION;\r\n }\r\n case CharCode.OPENBRACKET: {\r\n ++this.pos;\r\n return Token.OPENBRACKET;\r\n }\r\n case CharCode.CLOSEBRACKET: {\r\n ++this.pos;\r\n return Token.CLOSEBRACKET;\r\n }\r\n case CharCode.CARET: {\r\n ++this.pos;\r\n if (\r\n maxTokenLength > 1 && this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.EQUALS\r\n ) {\r\n ++this.pos;\r\n return Token.CARET_EQUALS;\r\n }\r\n return Token.CARET;\r\n }\r\n case CharCode.OPENBRACE: {\r\n ++this.pos;\r\n return Token.OPENBRACE;\r\n }\r\n case CharCode.BAR: {\r\n ++this.pos;\r\n if (maxTokenLength > 1 && this.pos < end) {\r\n let chr = text.charCodeAt(this.pos);\r\n if (chr == CharCode.BAR) {\r\n ++this.pos;\r\n return Token.BAR_BAR;\r\n }\r\n if (chr == CharCode.EQUALS) {\r\n ++this.pos;\r\n return Token.BAR_EQUALS;\r\n }\r\n }\r\n return Token.BAR;\r\n }\r\n case CharCode.CLOSEBRACE: {\r\n ++this.pos;\r\n return Token.CLOSEBRACE;\r\n }\r\n case CharCode.TILDE: {\r\n ++this.pos;\r\n return Token.TILDE;\r\n }\r\n case CharCode.AT: {\r\n ++this.pos;\r\n return Token.AT;\r\n }\r\n default: {\r\n if (isIdentifierStart(c)) {\r\n if (isKeywordCharacter(c)) {\r\n let posBefore = this.pos;\r\n while (\r\n ++this.pos < end &&\r\n isIdentifierPart(c = text.charCodeAt(this.pos))\r\n ) {\r\n if (!isKeywordCharacter(c)) {\r\n this.pos = posBefore;\r\n return Token.IDENTIFIER;\r\n }\r\n }\r\n let keywordText = text.substring(posBefore, this.pos);\r\n let keywordToken = tokenFromKeyword(keywordText);\r\n if (\r\n keywordToken !== Token.INVALID &&\r\n identifierHandling !== IdentifierHandling.ALWAYS &&\r\n !(\r\n identifierHandling === IdentifierHandling.PREFER &&\r\n tokenIsAlsoIdentifier(keywordToken)\r\n )\r\n ) {\r\n return keywordToken;\r\n }\r\n this.pos = posBefore;\r\n }\r\n return Token.IDENTIFIER; // expects a call to readIdentifier\r\n } else if (isWhiteSpace(c)) {\r\n ++this.pos;\r\n break;\r\n }\r\n this.error(\r\n DiagnosticCode.Invalid_character,\r\n this.range(this.pos, this.pos + 1)\r\n );\r\n ++this.pos;\r\n return Token.INVALID;\r\n }\r\n }\r\n }\r\n return Token.ENDOFFILE;\r\n }\r\n\r\n peek(\r\n checkOnNewLine: bool = false,\r\n identifierHandling: IdentifierHandling = IdentifierHandling.DEFAULT,\r\n maxCompoundLength: i32 = i32.MAX_VALUE\r\n ): Token {\r\n var text = this.source.text;\r\n if (this.nextToken < 0) {\r\n let posBefore = this.pos;\r\n let tokenBefore = this.token;\r\n let tokenPosBefore = this.tokenPos;\r\n this.nextToken = this.unsafeNext(identifierHandling, maxCompoundLength);\r\n this.nextTokenPos = this.tokenPos;\r\n if (checkOnNewLine) {\r\n this.nextTokenOnNewLine = false;\r\n for (let pos = posBefore, end = this.nextTokenPos; pos < end; ++pos) {\r\n if (isLineBreak(text.charCodeAt(pos))) {\r\n this.nextTokenOnNewLine = true;\r\n break;\r\n }\r\n }\r\n }\r\n this.pos = posBefore;\r\n this.token = tokenBefore;\r\n this.tokenPos = tokenPosBefore;\r\n }\r\n return this.nextToken;\r\n }\r\n\r\n skipIdentifier(identifierHandling: IdentifierHandling = IdentifierHandling.PREFER): bool {\r\n return this.skip(Token.IDENTIFIER, identifierHandling);\r\n }\r\n\r\n skip(token: Token, identifierHandling: IdentifierHandling = IdentifierHandling.DEFAULT): bool {\r\n var posBefore = this.pos;\r\n var tokenBefore = this.token;\r\n var tokenPosBefore = this.tokenPos;\r\n var maxCompoundLength = i32.MAX_VALUE;\r\n switch (token) {\r\n case Token.GREATERTHAN: { // where parsing type arguments\r\n maxCompoundLength = 1;\r\n break;\r\n }\r\n }\r\n this.token = this.unsafeNext(identifierHandling, maxCompoundLength);\r\n if (this.token == token) {\r\n this.nextToken = -1;\r\n return true;\r\n } else {\r\n this.pos = posBefore;\r\n this.token = tokenBefore;\r\n this.tokenPos = tokenPosBefore;\r\n return false;\r\n }\r\n }\r\n\r\n mark(): State {\r\n var state: State;\r\n if (reusableState) {\r\n state = reusableState;\r\n reusableState = null;\r\n } else {\r\n state = new State();\r\n }\r\n state.pos = this.pos;\r\n state.token = this.token;\r\n state.tokenPos = this.tokenPos;\r\n return state;\r\n }\r\n\r\n discard(state: State): void {\r\n reusableState = state;\r\n }\r\n\r\n reset(state: State): void {\r\n this.pos = state.pos;\r\n this.token = state.token;\r\n this.tokenPos = state.tokenPos;\r\n this.nextToken = -1;\r\n }\r\n\r\n range(start: i32 = -1, end: i32 = -1): Range {\r\n if (start < 0) {\r\n start = this.tokenPos;\r\n end = this.pos;\r\n } else if (end < 0) {\r\n end = start;\r\n }\r\n return new Range(this.source, start, end);\r\n }\r\n\r\n readIdentifier(): string {\r\n var text = this.source.text;\r\n var start = this.pos;\r\n var end = this.end;\r\n while (\r\n ++this.pos < end &&\r\n isIdentifierPart(text.charCodeAt(this.pos))\r\n );\r\n return text.substring(start, this.pos);\r\n }\r\n\r\n readString(): string {\r\n var text = this.source.text;\r\n var quote = text.charCodeAt(this.pos++);\r\n var start = this.pos;\r\n var end = this.end;\r\n var result = \"\";\r\n while (true) {\r\n if (this.pos >= end) {\r\n result += text.substring(start, this.pos);\r\n this.error(\r\n DiagnosticCode.Unterminated_string_literal,\r\n this.range(start - 1, end)\r\n );\r\n break;\r\n }\r\n let c = text.charCodeAt(this.pos);\r\n if (c == quote) {\r\n result += text.substring(start, this.pos++);\r\n break;\r\n }\r\n if (c == CharCode.BACKSLASH) {\r\n result += text.substring(start, this.pos);\r\n result += this.readEscapeSequence();\r\n start = this.pos;\r\n continue;\r\n }\r\n if (isLineBreak(c)) {\r\n result += text.substring(start, this.pos);\r\n this.error(\r\n DiagnosticCode.Unterminated_string_literal,\r\n this.range(start - 1, this.pos)\r\n );\r\n break;\r\n }\r\n ++this.pos;\r\n }\r\n return result;\r\n }\r\n\r\n readEscapeSequence(): string {\r\n var end = this.end;\r\n if (++this.pos >= end) {\r\n this.error(\r\n DiagnosticCode.Unexpected_end_of_text,\r\n this.range(end)\r\n );\r\n return \"\";\r\n }\r\n\r\n var text = this.source.text;\r\n var c = text.charCodeAt(this.pos++);\r\n switch (c) {\r\n case CharCode._0: return \"\\0\";\r\n case CharCode.b: return \"\\b\";\r\n case CharCode.t: return \"\\t\";\r\n case CharCode.n: return \"\\n\";\r\n case CharCode.v: return \"\\v\";\r\n case CharCode.f: return \"\\f\";\r\n case CharCode.r: return \"\\r\";\r\n case CharCode.SINGLEQUOTE: return \"'\";\r\n case CharCode.DOUBLEQUOTE: return \"\\\"\";\r\n case CharCode.u: {\r\n if (\r\n this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.OPENBRACE\r\n ) {\r\n ++this.pos;\r\n return this.readExtendedUnicodeEscape(); // \\u{DDDDDDDD}\r\n }\r\n return this.readUnicodeEscape(); // \\uDDDD\r\n }\r\n case CharCode.CARRIAGERETURN: {\r\n if (\r\n this.pos < end &&\r\n text.charCodeAt(this.pos) == CharCode.LINEFEED\r\n ) {\r\n ++this.pos;\r\n }\r\n // fall through\r\n }\r\n case CharCode.LINEFEED:\r\n case CharCode.LINESEPARATOR:\r\n case CharCode.PARAGRAPHSEPARATOR: return \"\";\r\n default: return String.fromCharCode(c);\r\n }\r\n }\r\n\r\n readRegexpPattern(): string {\r\n var text = this.source.text;\r\n var start = this.pos;\r\n var end = this.end;\r\n var escaped = false;\r\n while (true) {\r\n if (this.pos >= end) {\r\n this.error(\r\n DiagnosticCode.Unterminated_regular_expression_literal,\r\n this.range(start, end)\r\n );\r\n break;\r\n }\r\n if (text.charCodeAt(this.pos) == CharCode.BACKSLASH) {\r\n ++this.pos;\r\n escaped = true;\r\n continue;\r\n }\r\n let c = text.charCodeAt(this.pos);\r\n if (!escaped && c == CharCode.SLASH) break;\r\n if (isLineBreak(c)) {\r\n this.error(\r\n DiagnosticCode.Unterminated_regular_expression_literal,\r\n this.range(start, this.pos)\r\n );\r\n break;\r\n }\r\n ++this.pos;\r\n escaped = false;\r\n }\r\n return text.substring(start, this.pos);\r\n }\r\n\r\n readRegexpFlags(): string {\r\n var text = this.source.text;\r\n var start = this.pos;\r\n var end = this.end;\r\n var flags = 0;\r\n while (this.pos < end) {\r\n let c: i32 = text.charCodeAt(this.pos);\r\n if (!isIdentifierPart(c)) break;\r\n ++this.pos;\r\n\r\n // make sure each supported flag is unique\r\n switch (c) {\r\n case CharCode.g: {\r\n flags |= flags & 1 ? -1 : 1;\r\n break;\r\n }\r\n case CharCode.i: {\r\n flags |= flags & 2 ? -1 : 2;\r\n break;\r\n }\r\n case CharCode.m: {\r\n flags |= flags & 4 ? -1 : 4;\r\n break;\r\n }\r\n default: {\r\n flags = -1;\r\n break;\r\n }\r\n }\r\n }\r\n if (flags == -1) {\r\n this.error(\r\n DiagnosticCode.Invalid_regular_expression_flags,\r\n this.range(start, this.pos)\r\n );\r\n }\r\n return text.substring(start, this.pos);\r\n }\r\n\r\n testInteger(): bool {\r\n var end = this.end;\r\n var text = this.source.text;\r\n if (this.pos + 1 < end && text.charCodeAt(this.pos) == CharCode._0) {\r\n switch (text.charCodeAt(this.pos + 2)) {\r\n case CharCode.x:\r\n case CharCode.X:\r\n case CharCode.b:\r\n case CharCode.B:\r\n case CharCode.o:\r\n case CharCode.O: return true;\r\n }\r\n }\r\n var pos = this.pos;\r\n while (pos < end) {\r\n let c = text.charCodeAt(pos);\r\n if (c == CharCode.DOT || c == CharCode.e || c == CharCode.E) return false;\r\n if ((c < CharCode._0 || c > CharCode._9) && c != CharCode._) break;\r\n // does not validate separator placement (this is done in readXYInteger)\r\n pos++;\r\n }\r\n return true;\r\n }\r\n\r\n readInteger(): I64 {\r\n var text = this.source.text;\r\n if (this.pos + 2 < this.end && text.charCodeAt(this.pos) == CharCode._0) {\r\n switch (text.charCodeAt(this.pos + 1)) {\r\n case CharCode.x:\r\n case CharCode.X: {\r\n this.pos += 2;\r\n return this.readHexInteger();\r\n }\r\n case CharCode.b:\r\n case CharCode.B: {\r\n this.pos += 2;\r\n return this.readBinaryInteger();\r\n }\r\n case CharCode.o:\r\n case CharCode.O: {\r\n this.pos += 2;\r\n return this.readOctalInteger();\r\n }\r\n }\r\n if (isOctalDigit(text.charCodeAt(this.pos + 1))) {\r\n let start = this.pos;\r\n ++this.pos;\r\n let value = this.readOctalInteger();\r\n this.error(\r\n DiagnosticCode.Octal_literals_are_not_allowed_in_strict_mode,\r\n this.range(start, this.pos)\r\n );\r\n return value;\r\n }\r\n }\r\n return this.readDecimalInteger();\r\n }\r\n\r\n readHexInteger(): I64 {\r\n var text = this.source.text;\r\n var start = this.pos;\r\n var value = i64_new(0);\r\n var i64_4 = i64_new(4);\r\n var sepEnd = start;\r\n var end = this.end;\r\n while (this.pos < end) {\r\n let pos = this.pos;\r\n let c = text.charCodeAt(pos);\r\n if (c >= CharCode._0 && c <= CharCode._9) {\r\n // value = (value << 4) + c - CharCode._0;\r\n value = i64_add(\r\n i64_shl(value, i64_4),\r\n i64_new(c - CharCode._0)\r\n );\r\n } else if (c >= CharCode.A && c <= CharCode.F) {\r\n // value = (value << 4) + 10 + c - CharCode.A;\r\n value = i64_add(\r\n i64_shl(value, i64_4),\r\n i64_new(10 + c - CharCode.A)\r\n );\r\n } else if (c >= CharCode.a && c <= CharCode.f) {\r\n // value = (value << 4) + 10 + c - CharCode.a;\r\n value = i64_add(\r\n i64_shl(value, i64_4),\r\n i64_new(10 + c - CharCode.a)\r\n );\r\n } else if (c == CharCode._) {\r\n if (sepEnd == pos) {\r\n this.error(\r\n sepEnd == start\r\n ? DiagnosticCode.Numeric_separators_are_not_allowed_here\r\n : DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,\r\n this.range(pos)\r\n );\r\n }\r\n sepEnd = pos + 1;\r\n } else {\r\n break;\r\n }\r\n this.pos = pos + 1;\r\n }\r\n if (this.pos == start) {\r\n this.error(\r\n DiagnosticCode.Hexadecimal_digit_expected,\r\n this.range(start)\r\n );\r\n } else if (sepEnd == this.pos) {\r\n this.error(\r\n DiagnosticCode.Numeric_separators_are_not_allowed_here,\r\n this.range(sepEnd - 1)\r\n );\r\n }\r\n return value;\r\n }\r\n\r\n readDecimalInteger(): I64 {\r\n var text = this.source.text;\r\n var start = this.pos;\r\n var end = this.end;\r\n var value = i64_new(0);\r\n var i64_10 = i64_new(10);\r\n var sepEnd = start;\r\n while (this.pos < end) {\r\n let pos = this.pos;\r\n let c = text.charCodeAt(pos);\r\n if (c >= CharCode._0 && c <= CharCode._9) {\r\n // value = value * 10 + c - CharCode._0;\r\n value = i64_add(\r\n i64_mul(value, i64_10),\r\n i64_new(c - CharCode._0)\r\n );\r\n } else if (c == CharCode._) {\r\n if (sepEnd == pos) {\r\n this.error(\r\n sepEnd == start\r\n ? DiagnosticCode.Numeric_separators_are_not_allowed_here\r\n : DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,\r\n this.range(pos)\r\n );\r\n }\r\n sepEnd = pos + 1;\r\n } else {\r\n break;\r\n }\r\n this.pos = pos + 1;\r\n }\r\n if (this.pos == start) {\r\n this.error(\r\n DiagnosticCode.Digit_expected,\r\n this.range(start)\r\n );\r\n } else if (sepEnd == this.pos) {\r\n this.error(\r\n DiagnosticCode.Numeric_separators_are_not_allowed_here,\r\n this.range(sepEnd - 1)\r\n );\r\n }\r\n return value;\r\n }\r\n\r\n readOctalInteger(): I64 {\r\n var text = this.source.text;\r\n var start = this.pos;\r\n var value = i64_new(0);\r\n var i64_3 = i64_new(3);\r\n var sepEnd = start;\r\n var end = this.end;\r\n while (this.pos < end) {\r\n let pos = this.pos;\r\n let c = text.charCodeAt(pos);\r\n if (c >= CharCode._0 && c <= CharCode._7) {\r\n // value = (value << 3) + c - CharCode._0;\r\n value = i64_add(\r\n i64_shl(value, i64_3),\r\n i64_new(c - CharCode._0)\r\n );\r\n } else if (c == CharCode._) {\r\n if (sepEnd == pos) {\r\n this.error(\r\n sepEnd == start\r\n ? DiagnosticCode.Numeric_separators_are_not_allowed_here\r\n : DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,\r\n this.range(pos)\r\n );\r\n }\r\n sepEnd = pos + 1;\r\n } else {\r\n break;\r\n }\r\n ++this.pos;\r\n }\r\n if (this.pos == start) {\r\n this.error(\r\n DiagnosticCode.Octal_digit_expected,\r\n this.range(start)\r\n );\r\n } else if (sepEnd == this.pos) {\r\n this.error(\r\n DiagnosticCode.Numeric_separators_are_not_allowed_here,\r\n this.range(sepEnd - 1)\r\n );\r\n }\r\n return value;\r\n }\r\n\r\n readBinaryInteger(): I64 {\r\n var text = this.source.text;\r\n var start = this.pos;\r\n var value = i64_new(0);\r\n var i64_1 = i64_new(1);\r\n var sepEnd = start;\r\n var end = this.end;\r\n while (this.pos < end) {\r\n let pos = this.pos;\r\n let c = text.charCodeAt(pos);\r\n if (c == CharCode._0) {\r\n // value = (value << 1);\r\n value = i64_shl(value, i64_1);\r\n } else if (c == CharCode._1) {\r\n // value = (value << 1) + 1;\r\n value = i64_add(\r\n i64_shl(value, i64_1),\r\n i64_1\r\n );\r\n } else if (c == CharCode._) {\r\n if (sepEnd == pos) {\r\n this.error(\r\n sepEnd == start\r\n ? DiagnosticCode.Numeric_separators_are_not_allowed_here\r\n : DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,\r\n this.range(pos)\r\n );\r\n }\r\n sepEnd = pos + 1;\r\n } else {\r\n break;\r\n }\r\n this.pos = pos + 1;\r\n }\r\n if (this.pos == start) {\r\n this.error(\r\n DiagnosticCode.Binary_digit_expected,\r\n this.range(start)\r\n );\r\n } else if (sepEnd == this.pos) {\r\n this.error(\r\n DiagnosticCode.Numeric_separators_are_not_allowed_here,\r\n this.range(sepEnd - 1)\r\n );\r\n }\r\n return value;\r\n }\r\n\r\n readFloat(): f64 {\r\n // var text = this.source.text;\r\n // if (text.charCodeAt(this.pos) == CharCode._0 && this.pos + 2 < this.end) {\r\n // switch (text.charCodeAt(this.pos + 1)) {\r\n // case CharCode.X:\r\n // case CharCode.x: {\r\n // this.pos += 2;\r\n // return this.readHexFloat();\r\n // }\r\n // }\r\n // }\r\n return this.readDecimalFloat();\r\n }\r\n\r\n readDecimalFloat(): f64 {\r\n // TODO: numeric separators (parseFloat can't handle these)\r\n var start = this.pos;\r\n var end = this.end;\r\n var text = this.source.text;\r\n while (this.pos < end && isDecimalDigit(text.charCodeAt(this.pos))) {\r\n ++this.pos;\r\n }\r\n if (this.pos < end && text.charCodeAt(this.pos) == CharCode.DOT) {\r\n ++this.pos;\r\n while (this.pos < end && isDecimalDigit(text.charCodeAt(this.pos))) {\r\n ++this.pos;\r\n }\r\n }\r\n if (this.pos < end) {\r\n let c = text.charCodeAt(this.pos);\r\n if (c == CharCode.e || c == CharCode.E) {\r\n if (\r\n ++this.pos < end &&\r\n (c = text.charCodeAt(this.pos)) == CharCode.MINUS || c == CharCode.PLUS &&\r\n isDecimalDigit(text.charCodeAt(this.pos + 1))\r\n ) {\r\n ++this.pos;\r\n }\r\n while (this.pos < end && isDecimalDigit(text.charCodeAt(this.pos))) {\r\n ++this.pos;\r\n }\r\n }\r\n }\r\n return parseFloat(text.substring(start, this.pos));\r\n }\r\n\r\n readHexFloat(): f64 {\r\n throw new Error(\"not implemented\"); // TBD\r\n }\r\n\r\n readUnicodeEscape(): string {\r\n var remain = 4;\r\n var value = 0;\r\n var end = this.end;\r\n var text = this.source.text;\r\n while (this.pos < end) {\r\n let c = text.charCodeAt(this.pos++);\r\n if (c >= CharCode._0 && c <= CharCode._9) {\r\n value = (value << 4) + c - CharCode._0;\r\n } else if (c >= CharCode.A && c <= CharCode.F) {\r\n value = (value << 4) + c + (10 - CharCode.A);\r\n } else if (c >= CharCode.a && c <= CharCode.f) {\r\n value = (value << 4) + c + (10 - CharCode.a);\r\n } else {\r\n this.error(\r\n DiagnosticCode.Hexadecimal_digit_expected,\r\n this.range(this.pos - 1, this.pos)\r\n );\r\n return \"\";\r\n }\r\n if (--remain == 0) break;\r\n }\r\n if (remain) {\r\n this.error(\r\n DiagnosticCode.Unexpected_end_of_text,\r\n this.range(this.pos)\r\n );\r\n return \"\";\r\n }\r\n return String.fromCharCode(value);\r\n }\r\n\r\n private readExtendedUnicodeEscape(): string {\r\n var start = this.pos;\r\n var value = this.readHexInteger();\r\n var value32 = i64_low(value);\r\n var invalid = false;\r\n\r\n assert(!i64_high(value));\r\n if (value32 > 0x10FFFF) {\r\n this.error(\r\n DiagnosticCode.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive,\r\n this.range(start, this.pos)\r\n );\r\n invalid = true;\r\n }\r\n\r\n var end = this.end;\r\n var text = this.source.text;\r\n if (this.pos >= end) {\r\n this.error(\r\n DiagnosticCode.Unexpected_end_of_text,\r\n this.range(start, end)\r\n );\r\n invalid = true;\r\n } else if (text.charCodeAt(this.pos) == CharCode.CLOSEBRACE) {\r\n ++this.pos;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Unterminated_Unicode_escape_sequence,\r\n this.range(start, this.pos)\r\n );\r\n invalid = true;\r\n }\r\n\r\n if (invalid) return \"\";\r\n return value32 < 65536\r\n ? String.fromCharCode(value32)\r\n : String.fromCharCode(\r\n ((value32 - 65536) >>> 10) + 0xD800,\r\n ((value32 - 65536) & 1023) + 0xDC00\r\n );\r\n }\r\n\r\n finish(): void {\r\n }\r\n}\r\n\r\n/** Tokenizer state as returned by {@link Tokenizer#mark} and consumed by {@link Tokenizer#reset}. */\r\nexport class State {\r\n /** Current position. */\r\n pos: i32;\r\n /** Current token. */\r\n token: Token;\r\n /** Current token's position. */\r\n tokenPos: i32;\r\n}\r\n\r\n// Reusable state object to reduce allocations\r\nvar reusableState: State | null = null;\r\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","/**\r\n * Resolve infrastructure to obtain types and elements.\r\n * @module resolver\r\n *//***/\r\n\r\nimport {\r\n DiagnosticEmitter,\r\n DiagnosticCode\r\n} from \"./diagnostics\";\r\n\r\nimport {\r\n Program,\r\n ElementKind,\r\n OperatorKind,\r\n Element,\r\n Class,\r\n ClassPrototype,\r\n Function,\r\n FunctionPrototype,\r\n VariableLikeElement,\r\n Property,\r\n PropertyPrototype,\r\n Field,\r\n FieldPrototype,\r\n Global,\r\n TypeDefinition\r\n} from \"./program\";\r\n\r\nimport {\r\n FlowFlags,\r\n Flow\r\n} from \"./flow\";\r\n\r\nimport {\r\n SignatureNode,\r\n ParameterKind,\r\n CommonTypeNode,\r\n NodeKind,\r\n TypeNode,\r\n TypeName,\r\n TypeParameterNode,\r\n Node,\r\n Range,\r\n IdentifierExpression,\r\n CallExpression,\r\n ElementAccessExpression,\r\n PropertyAccessExpression,\r\n LiteralExpression,\r\n LiteralKind,\r\n ParenthesizedExpression,\r\n AssertionExpression,\r\n Expression,\r\n IntegerLiteralExpression,\r\n UnaryPrefixExpression,\r\n UnaryPostfixExpression,\r\n AssertionKind,\r\n BinaryExpression,\r\n ThisExpression,\r\n SuperExpression,\r\n isTypeOmitted\r\n} from \"./ast\";\r\n\r\nimport {\r\n Type,\r\n Signature,\r\n typesToString,\r\n TypeKind,\r\n TypeFlags\r\n} from \"./types\";\r\n\r\nimport {\r\n CommonFlags,\r\n CommonSymbols\r\n} from \"./common\";\r\n\r\nimport {\r\n makeMap,\r\n isPowerOf2\r\n} from \"./util\";\r\n\r\nimport {\r\n Token\r\n} from \"./tokenizer\";\r\n\r\nimport {\r\n BuiltinSymbols\r\n} from \"./builtins\";\r\n\r\n/** Indicates whether errors are reported or not. */\r\nexport enum ReportMode {\r\n /** Report errors. */\r\n REPORT,\r\n /** Swallow errors. */\r\n SWALLOW\r\n}\r\n\r\n/** Provides tools to resolve types and expressions. */\r\nexport class Resolver extends DiagnosticEmitter {\r\n\r\n /** The program this resolver belongs to. */\r\n program: Program;\r\n\r\n /** Target expression of the previously resolved property or element access. */\r\n currentThisExpression: Expression | null = null;\r\n /** Element expression of the previously resolved element access. */\r\n currentElementExpression : Expression | null = null;\r\n\r\n /** Constructs the resolver for the specified program. */\r\n constructor(\r\n /** The program to construct a resolver for. */\r\n program: Program\r\n ) {\r\n super(program.diagnostics);\r\n this.program = program;\r\n }\r\n\r\n /** Resolves a {@link CommonTypeNode} to a concrete {@link Type}. */\r\n resolveType(\r\n /** The type to resolve. */\r\n node: CommonTypeNode,\r\n /** Relative context. */\r\n context: Element,\r\n /** Type arguments inherited through context, i.e. `T`. */\r\n contextualTypeArguments: Map | null = null,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Type | null {\r\n\r\n // handle signature\r\n if (node.kind == NodeKind.SIGNATURE) {\r\n let explicitThisType = (node).explicitThisType;\r\n let thisType: Type | null = null;\r\n if (explicitThisType) {\r\n thisType = this.resolveType(\r\n explicitThisType,\r\n context,\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n if (!thisType) return null;\r\n }\r\n let parameterNodes = (node).parameters;\r\n let numParameters = parameterNodes.length;\r\n let parameterTypes = new Array(numParameters);\r\n let parameterNames = new Array(numParameters);\r\n let requiredParameters = 0;\r\n let hasRest = false;\r\n for (let i = 0; i < numParameters; ++i) {\r\n let parameterNode = parameterNodes[i];\r\n switch (parameterNode.parameterKind) {\r\n case ParameterKind.DEFAULT: {\r\n requiredParameters = i + 1;\r\n break;\r\n }\r\n case ParameterKind.REST: {\r\n assert(i == numParameters);\r\n hasRest = true;\r\n break;\r\n }\r\n }\r\n let parameterTypeNode = parameterNode.type;\r\n if (isTypeOmitted(parameterTypeNode)) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n parameterTypeNode.range\r\n );\r\n }\r\n return null;\r\n }\r\n let parameterType = this.resolveType(\r\n parameterTypeNode,\r\n context,\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n if (!parameterType) return null;\r\n parameterTypes[i] = parameterType;\r\n parameterNames[i] = parameterNode.name.text;\r\n }\r\n let returnTypeNode = (node).returnType;\r\n if (isTypeOmitted(returnTypeNode)) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n returnTypeNode.range\r\n );\r\n }\r\n return null;\r\n }\r\n let returnType: Type | null;\r\n if (returnTypeNode) {\r\n returnType = this.resolveType(\r\n returnTypeNode,\r\n context,\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n if (!returnType) return null;\r\n } else {\r\n returnType = Type.void;\r\n }\r\n let signature = new Signature(parameterTypes, returnType, thisType);\r\n signature.parameterNames = parameterNames;\r\n signature.requiredParameters = requiredParameters;\r\n signature.hasRest = hasRest;\r\n return node.isNullable ? signature.type.asNullable() : signature.type;\r\n }\r\n\r\n // now dealing with TypeNode\r\n assert(node.kind == NodeKind.TYPE);\r\n var typeNode = node;\r\n var typeName = typeNode.name;\r\n var typeArgumentNodes = typeNode.typeArguments;\r\n var possiblyPlaceholder = !typeName.next;\r\n\r\n // look up in contextual type arguments if possibly a placeholder\r\n if (possiblyPlaceholder) {\r\n if (contextualTypeArguments && contextualTypeArguments.has(typeName.identifier.text)) {\r\n let type = contextualTypeArguments.get(typeName.identifier.text)!;\r\n if (typeArgumentNodes !== null && typeArgumentNodes.length) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n node.range, type.toString()\r\n );\r\n }\r\n }\r\n if (node.isNullable) {\r\n if (!type.is(TypeFlags.REFERENCE)) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Basic_type_0_cannot_be_nullable,\r\n node.range, type.toString()\r\n );\r\n }\r\n }\r\n return type.asNullable();\r\n }\r\n return type;\r\n }\r\n }\r\n\r\n // look up in context\r\n var element = this.resolveTypeName(typeName, context, reportMode);\r\n if (!element) return null;\r\n\r\n // use shadow type if present (i.e. namespace sharing a type)\r\n if (element.shadowType) {\r\n element = element.shadowType;\r\n\r\n } else {\r\n // handle enums (become i32)\r\n if (element.kind == ElementKind.ENUM) {\r\n if (typeArgumentNodes !== null && typeArgumentNodes.length) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n node.range, element.internalName\r\n );\r\n }\r\n }\r\n if (node.isNullable) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Basic_type_0_cannot_be_nullable,\r\n node.range, element.name\r\n );\r\n }\r\n }\r\n return Type.i32;\r\n }\r\n\r\n // handle classes\r\n if (element.kind == ElementKind.CLASS_PROTOTYPE) {\r\n let instance = this.resolveClassInclTypeArguments(\r\n element,\r\n typeArgumentNodes,\r\n context,\r\n makeMap(contextualTypeArguments), // don't inherit\r\n node\r\n ); // reports\r\n if (!instance) return null;\r\n return node.isNullable ? instance.type.asNullable() : instance.type;\r\n }\r\n }\r\n\r\n // handle type definitions\r\n if (element.kind == ElementKind.TYPEDEFINITION) {\r\n\r\n // shortcut already resolved (mostly builtins)\r\n if (element.is(CommonFlags.RESOLVED)) {\r\n if (typeArgumentNodes !== null && typeArgumentNodes.length) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n node.range, element.internalName\r\n );\r\n }\r\n }\r\n let type = (element).type;\r\n if (node.isNullable) {\r\n if (!type.is(TypeFlags.REFERENCE)) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Basic_type_0_cannot_be_nullable,\r\n typeNode.name.range, typeName.identifier.text\r\n );\r\n }\r\n } else {\r\n return type.asNullable();\r\n }\r\n }\r\n return type;\r\n }\r\n\r\n // handle special native type\r\n if (possiblyPlaceholder && typeName.identifier.text == CommonSymbols.native) {\r\n if (!(typeArgumentNodes && typeArgumentNodes.length == 1)) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\r\n typeNode.range, \"1\", (typeArgumentNodes ? typeArgumentNodes.length : 1).toString(10)\r\n );\r\n }\r\n return null;\r\n }\r\n let typeArgument = this.resolveType(\r\n typeArgumentNodes[0],\r\n context,\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n if (!typeArgument) return null;\r\n switch (typeArgument.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32: return Type.i32;\r\n case TypeKind.ISIZE: if (!this.program.options.isWasm64) return Type.i32;\r\n case TypeKind.I64: return Type.i64;\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: return Type.u32;\r\n case TypeKind.USIZE: if (!this.program.options.isWasm64) return Type.u32;\r\n case TypeKind.U64: return Type.u64;\r\n case TypeKind.F32: return Type.f32;\r\n case TypeKind.F64: return Type.f64;\r\n case TypeKind.V128: return Type.v128;\r\n case TypeKind.VOID: return Type.void;\r\n default: assert(false);\r\n }\r\n }\r\n\r\n // resolve normally\r\n let typeParameterNodes = (element).typeParameterNodes;\r\n let typeArguments: Type[] | null = null;\r\n if (typeParameterNodes) {\r\n typeArguments = this.resolveTypeArguments(\r\n typeParameterNodes,\r\n typeArgumentNodes,\r\n context,\r\n contextualTypeArguments = makeMap(contextualTypeArguments), // inherit\r\n node,\r\n reportMode\r\n );\r\n if (!typeArguments) return null;\r\n } else if (typeArgumentNodes && typeArgumentNodes.length) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n typeNode.range, typeName.identifier.text\r\n );\r\n // recoverable\r\n }\r\n let type = this.resolveType(\r\n (element).typeNode,\r\n element,\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n if (!type) return null;\r\n if (node.isNullable) {\r\n if (!type.is(TypeFlags.REFERENCE)) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Basic_type_0_cannot_be_nullable,\r\n typeNode.name.range, typeName.identifier.text\r\n );\r\n }\r\n } else {\r\n return type.asNullable();\r\n }\r\n }\r\n return type;\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n typeNode.name.range, typeName.identifier.text\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Resolves a type name to the program element it refers to. */\r\n resolveTypeName(\r\n /** The type name to resolve. */\r\n typeName: TypeName,\r\n /** Relative context. */\r\n context: Element,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode = ReportMode.REPORT\r\n ): Element | null {\r\n var element = context.lookup(typeName.identifier.text);\r\n if (!element) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n typeName.range, typeName.identifier.text\r\n );\r\n }\r\n return null;\r\n }\r\n var prev = typeName;\r\n var next = typeName.next;\r\n while (next) {\r\n if (!(element = element.lookupInSelf(next.identifier.text))) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\r\n next.range, next.identifier.text, prev.identifier.text\r\n );\r\n }\r\n return null;\r\n }\r\n prev = next;\r\n next = next.next;\r\n }\r\n return element;\r\n }\r\n\r\n /** Resolves an array of type arguments to concrete types. */\r\n resolveTypeArguments(\r\n /** Actual type parameter nodes. */\r\n typeParameters: TypeParameterNode[],\r\n /** Type arguments provided. */\r\n typeArgumentNodes: CommonTypeNode[] | null,\r\n /** Relative context. */\r\n context: Element,\r\n /** Type arguments inherited through context, i.e. `T`. */\r\n contextualTypeArguments: Map = makeMap(),\r\n /** Alternative report node in case of empty type arguments. */\r\n alternativeReportNode: Node | null = null,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Type[] | null {\r\n var minParameterCount = 0;\r\n var maxParameterCount = 0;\r\n for (let i = 0, k = typeParameters.length; i < k; ++i) {\r\n if (!typeParameters[i].defaultType) ++minParameterCount;\r\n ++maxParameterCount;\r\n }\r\n var argumentCount = typeArgumentNodes ? typeArgumentNodes.length : 0;\r\n if (argumentCount < minParameterCount || argumentCount > maxParameterCount) {\r\n this.error(\r\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\r\n argumentCount\r\n ? Range.join(\r\n (typeArgumentNodes)[0].range,\r\n (typeArgumentNodes)[argumentCount - 1].range\r\n )\r\n : assert(alternativeReportNode).range,\r\n (argumentCount < minParameterCount ? minParameterCount : maxParameterCount).toString(10),\r\n argumentCount.toString(10)\r\n );\r\n return null;\r\n }\r\n var typeArguments = new Array(maxParameterCount);\r\n for (let i = 0; i < maxParameterCount; ++i) {\r\n let type = i < argumentCount\r\n ? this.resolveType( // reports\r\n (typeArgumentNodes)[i],\r\n context,\r\n contextualTypeArguments,\r\n reportMode\r\n )\r\n : this.resolveType( // reports\r\n assert(typeParameters[i].defaultType),\r\n context,\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n if (!type) return null;\r\n // TODO: check extendsType\r\n contextualTypeArguments.set(typeParameters[i].name.text, type);\r\n typeArguments[i] = type;\r\n }\r\n return typeArguments;\r\n }\r\n\r\n /** Resolves an identifier to the program element it refers to. */\r\n resolveIdentifier(\r\n /** The expression to resolve. */\r\n identifier: IdentifierExpression,\r\n /** Optional flow to search for scoped locals. */\r\n flow: Flow | null,\r\n /** Optional context to search. */\r\n context: Element | null,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n var name = identifier.text;\r\n var element: Element | null;\r\n if (flow) {\r\n if (element = flow.lookup(name)) {\r\n this.currentThisExpression = null;\r\n this.currentElementExpression = null;\r\n return element;\r\n }\r\n }\r\n if (context) {\r\n if (element = context.lookup(name)) {\r\n this.currentThisExpression = null;\r\n this.currentElementExpression = null;\r\n return element;\r\n }\r\n }\r\n if (element = this.program.lookupGlobal(name)) {\r\n this.currentThisExpression = null;\r\n this.currentElementExpression = null;\r\n return element;\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n identifier.range, name\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Resolves a lazily compiled global, i.e. a static class field. */\r\n ensureResolvedLazyGlobal(global: Global, reportMode: ReportMode = ReportMode.REPORT): bool {\r\n if (global.is(CommonFlags.RESOLVED)) return true;\r\n var typeNode = global.typeNode;\r\n if (!typeNode) return false;\r\n var type = this.resolveType( // reports\r\n typeNode,\r\n global.parent,\r\n null,\r\n reportMode\r\n );\r\n if (!type) return false;\r\n global.setType(type);\r\n return true;\r\n }\r\n\r\n /** Resolves a property access expression to the program element it refers to. */\r\n resolvePropertyAccessExpression(\r\n /** The expression to resolve. */\r\n propertyAccess: PropertyAccessExpression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n var targetExpression = propertyAccess.expression;\r\n var target = this.resolveExpression(targetExpression, flow, contextualType, reportMode); // reports\r\n if (!target) return null;\r\n var propertyName = propertyAccess.property.text;\r\n\r\n // Resolve variable-likes to their class type first\r\n switch (target.kind) {\r\n case ElementKind.GLOBAL: if (!this.ensureResolvedLazyGlobal(target, reportMode)) return null;\r\n case ElementKind.LOCAL:\r\n case ElementKind.FIELD: {\r\n let type = (target).type; assert(type != Type.void);\r\n let classReference = type.classReference;\r\n if (!classReference) {\r\n let typeClasses = this.program.typeClasses;\r\n if (!type.is(TypeFlags.REFERENCE) && typeClasses.has(type.kind)) {\r\n classReference = typeClasses.get(type.kind)!;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\r\n propertyAccess.property.range, propertyName, (target).type.toString()\r\n );\r\n return null;\r\n }\r\n }\r\n target = classReference;\r\n break;\r\n }\r\n case ElementKind.PROPERTY_PROTOTYPE: { // static\r\n let getterInstance = this.resolveFunction( // reports\r\n assert((target).getterPrototype), // must have a getter\r\n null,\r\n makeMap(),\r\n reportMode\r\n );\r\n if (!getterInstance) return null;\r\n let classReference = getterInstance.signature.returnType.classReference;\r\n if (!classReference) {\r\n this.error(\r\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\r\n propertyAccess.property.range, propertyName, getterInstance.signature.returnType.toString()\r\n );\r\n return null;\r\n }\r\n target = classReference;\r\n break;\r\n }\r\n case ElementKind.PROPERTY: { // instance\r\n let getterInstance = assert((target).getterInstance); // must have a getter\r\n let classReference = getterInstance.signature.returnType.classReference;\r\n if (!classReference) {\r\n this.error(\r\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\r\n propertyAccess.property.range, propertyName, getterInstance.signature.returnType.toString()\r\n );\r\n return null;\r\n }\r\n target = classReference;\r\n break;\r\n }\r\n case ElementKind.CLASS: { // property access on element access?\r\n let elementExpression = this.currentElementExpression;\r\n if (elementExpression) {\r\n // let arrayType = this.program.determineBuiltinArrayType(target);\r\n // if (!arrayType) {\r\n let indexedGet = (target).lookupOverload(OperatorKind.INDEXED_GET);\r\n if (!indexedGet) {\r\n this.error(\r\n DiagnosticCode.Index_signature_is_missing_in_type_0,\r\n elementExpression.range, (target).internalName\r\n );\r\n return null;\r\n }\r\n let arrayType = indexedGet.signature.returnType;\r\n // }\r\n if (!(target = arrayType.classReference)) {\r\n this.error(\r\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\r\n propertyAccess.property.range, propertyName, arrayType.toString()\r\n );\r\n return null;\r\n }\r\n }\r\n break;\r\n }\r\n case ElementKind.FUNCTION_PROTOTYPE: { // function Symbol() + type Symbol = _Symbol\r\n let shadowType = target.shadowType;\r\n if (shadowType) {\r\n if (!shadowType.is(CommonFlags.RESOLVED)) {\r\n let resolvedType = this.resolveType(shadowType.typeNode, shadowType.parent, null, reportMode);\r\n if (resolvedType) shadowType.setType(resolvedType);\r\n }\r\n let classReference = shadowType.type.classReference;\r\n if (classReference) target = classReference.prototype;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n // Look up the member within\r\n switch (target.kind) {\r\n case ElementKind.CLASS_PROTOTYPE:\r\n case ElementKind.CLASS: {\r\n do {\r\n let members = target.members;\r\n if (members && members.has(propertyName)) {\r\n this.currentThisExpression = targetExpression;\r\n this.currentElementExpression = null;\r\n return members.get(propertyName)!; // instance FIELD, static GLOBAL, FUNCTION_PROTOTYPE...\r\n }\r\n // traverse inherited static members on the base prototype if target is a class prototype\r\n if (target.kind == ElementKind.CLASS_PROTOTYPE) {\r\n if ((target).basePrototype) {\r\n target = (target).basePrototype;\r\n } else {\r\n break;\r\n }\r\n // traverse inherited instance members on the base class if target is a class instance\r\n } else if (target.kind == ElementKind.CLASS) {\r\n if ((target).base) {\r\n target = (target).base;\r\n } else {\r\n break;\r\n }\r\n } else {\r\n break;\r\n }\r\n } while (true);\r\n break;\r\n }\r\n default: { // enums or other namespace-like elements\r\n let members = target.members;\r\n if (members && members.has(propertyName)) {\r\n this.currentThisExpression = targetExpression;\r\n this.currentElementExpression = null;\r\n return members.get(propertyName)!; // static ENUMVALUE, static GLOBAL, static FUNCTION_PROTOTYPE...\r\n }\r\n break;\r\n }\r\n }\r\n\r\n this.error(\r\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\r\n propertyAccess.property.range, propertyName, target.internalName\r\n );\r\n return null;\r\n }\r\n\r\n /** Resolves an element access expression to the program element it refers to. */\r\n resolveElementAccessExpression(\r\n /** The expression to resolve. */\r\n elementAccess: ElementAccessExpression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n var targetExpression = elementAccess.expression;\r\n var target = this.resolveExpression(targetExpression, flow, contextualType, reportMode); // reports\r\n if (!target) return null;\r\n switch (target.kind) {\r\n case ElementKind.GLOBAL: if (!this.ensureResolvedLazyGlobal(target, reportMode)) return null;\r\n case ElementKind.LOCAL:\r\n case ElementKind.FIELD: {\r\n let type = (target).type;\r\n if (target = type.classReference) {\r\n this.currentThisExpression = targetExpression;\r\n this.currentElementExpression = elementAccess.elementExpression;\r\n return target;\r\n }\r\n break;\r\n }\r\n case ElementKind.CLASS: {\r\n // let arrayType = this.program.determineBuiltinArrayType(target);\r\n // if (!arrayType) {\r\n let indexedGet = (target).lookupOverload(OperatorKind.INDEXED_GET);\r\n if (!indexedGet) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Index_signature_is_missing_in_type_0,\r\n elementAccess.range, (target).internalName\r\n );\r\n }\r\n return null;\r\n }\r\n let arrayType = indexedGet.signature.returnType;\r\n // }\r\n if (targetExpression.kind == NodeKind.ELEMENTACCESS) { // nested element access\r\n if (target = arrayType.classReference) {\r\n this.currentThisExpression = targetExpression;\r\n this.currentElementExpression = elementAccess.elementExpression;\r\n return target;\r\n }\r\n return null;\r\n }\r\n this.currentThisExpression = targetExpression;\r\n this.currentElementExpression = elementAccess.elementExpression;\r\n return target;\r\n }\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n targetExpression.range\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Determines the final type of an integer literal given the specified contextual type. */\r\n determineIntegerLiteralType(\r\n /** Integer literal value. */\r\n intValue: I64,\r\n /** Current contextual type. */\r\n contextualType: Type\r\n ): Type {\r\n if (!contextualType.is(TypeFlags.REFERENCE)) {\r\n // compile to contextualType if matching\r\n switch (contextualType.kind) {\r\n case TypeKind.I8: {\r\n if (i64_is_i8(intValue)) return Type.i8;\r\n break;\r\n }\r\n case TypeKind.U8: {\r\n if (i64_is_u8(intValue)) return Type.u8;\r\n break;\r\n }\r\n case TypeKind.I16: {\r\n if (i64_is_i16(intValue)) return Type.i16;\r\n break;\r\n }\r\n case TypeKind.U16: {\r\n if (i64_is_u16(intValue)) return Type.u16;\r\n break;\r\n }\r\n case TypeKind.I32: {\r\n if (i64_is_i32(intValue)) return Type.i32;\r\n break;\r\n }\r\n case TypeKind.U32: {\r\n if (i64_is_u32(intValue)) return Type.u32;\r\n break;\r\n }\r\n case TypeKind.BOOL: {\r\n if (i64_is_bool(intValue)) return Type.bool;\r\n break;\r\n }\r\n case TypeKind.ISIZE: {\r\n if (!this.program.options.isWasm64) {\r\n if (i64_is_i32(intValue)) return Type.isize32;\r\n break;\r\n }\r\n return Type.isize64;\r\n }\r\n case TypeKind.USIZE: {\r\n if (!this.program.options.isWasm64) {\r\n if (i64_is_u32(intValue)) return Type.usize32;\r\n break;\r\n }\r\n return Type.usize64;\r\n }\r\n case TypeKind.I64: return Type.i64;\r\n case TypeKind.U64: return Type.u64;\r\n case TypeKind.F32: return Type.f32;\r\n case TypeKind.F64: return Type.f64;\r\n case TypeKind.VOID: break; // best fitting below\r\n default: assert(false);\r\n }\r\n }\r\n // otherwise compile to best fitting native type\r\n if (i64_is_i32(intValue)) return Type.i32;\r\n if (i64_is_u32(intValue)) return Type.u32;\r\n return Type.i64;\r\n }\r\n\r\n /** Resolves any expression to the program element it refers to. */\r\n resolveExpression(\r\n /** The expression to resolve. */\r\n expression: Expression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type = Type.void,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n while (expression.kind == NodeKind.PARENTHESIZED) { // simply skip\r\n expression = (expression).expression;\r\n }\r\n switch (expression.kind) {\r\n case NodeKind.ASSERTION: {\r\n return this.resolveAssertionExpression(\r\n expression,\r\n flow, contextualType, reportMode\r\n );\r\n }\r\n case NodeKind.UNARYPREFIX: {\r\n return this.resolveUnaryPrefixExpression(\r\n expression,\r\n flow, contextualType, reportMode\r\n );\r\n }\r\n case NodeKind.UNARYPOSTFIX: {\r\n return this.resolveUnaryPostfixExpression(\r\n expression,\r\n flow, contextualType, reportMode\r\n );\r\n }\r\n case NodeKind.BINARY: {\r\n return this.resolveBinaryExpression(\r\n expression,\r\n flow, contextualType, reportMode\r\n );\r\n }\r\n case NodeKind.THIS: {\r\n return this.resolveThisExpression(\r\n expression,\r\n flow, contextualType, reportMode\r\n );\r\n }\r\n case NodeKind.SUPER: {\r\n return this.resolveSuperExpression(\r\n expression,\r\n flow, contextualType, reportMode\r\n );\r\n }\r\n case NodeKind.IDENTIFIER: {\r\n return this.resolveIdentifier(\r\n expression,\r\n flow, flow.actualFunction, reportMode\r\n );\r\n }\r\n case NodeKind.LITERAL: {\r\n return this.resolveLiteralExpression(\r\n expression,\r\n flow, contextualType, reportMode\r\n );\r\n }\r\n case NodeKind.PROPERTYACCESS: {\r\n return this.resolvePropertyAccessExpression(\r\n expression,\r\n flow, contextualType, reportMode\r\n );\r\n }\r\n case NodeKind.ELEMENTACCESS: {\r\n return this.resolveElementAccessExpression(\r\n expression,\r\n flow, contextualType, reportMode\r\n );\r\n }\r\n case NodeKind.CALL: {\r\n return this.resolveCallExpression(\r\n expression,\r\n flow, contextualType, reportMode\r\n );\r\n }\r\n // TODO: everything else\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Resolves an assertion expression to the program element it refers to. */\r\n resolveAssertionExpression(\r\n /** The expression to resolve. */\r\n expression: AssertionExpression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type = Type.void,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n if (expression.assertionKind == AssertionKind.NONNULL) {\r\n return this.resolveExpression(\r\n expression.expression,\r\n flow,\r\n contextualType,\r\n reportMode\r\n );\r\n }\r\n var type = this.resolveType(\r\n assert(expression.toType), // must be set if not NONNULL\r\n flow.actualFunction,\r\n flow.contextualTypeArguments,\r\n reportMode\r\n );\r\n if (!type) return null;\r\n var element: Element | null = type.classReference;\r\n if (!element) {\r\n let signature = type.signatureReference;\r\n if (!signature) return null;\r\n element = signature.asFunctionTarget(this.program);\r\n }\r\n this.currentThisExpression = null;\r\n this.currentElementExpression = null;\r\n return element;\r\n }\r\n\r\n /** Resolves an unary prefix expression to the program element it refers to. */\r\n resolveUnaryPrefixExpression(\r\n /** The expression to resolve. */\r\n expression: UnaryPrefixExpression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type = Type.void,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n var operand = expression.operand;\r\n // TODO: operator overloads\r\n switch (expression.operator) {\r\n case Token.MINUS: {\r\n // implicitly negate if an integer literal to distinguish between i32/u32/i64\r\n if (operand.kind == NodeKind.LITERAL && (operand).literalKind == LiteralKind.INTEGER) {\r\n let type = this.determineIntegerLiteralType(\r\n i64_sub(i64_zero, (operand).value),\r\n contextualType\r\n );\r\n let typeClasses = this.program.typeClasses;\r\n return typeClasses.has(type.kind) ? typeClasses.get(type.kind)! : null;\r\n }\r\n return this.resolveExpression(\r\n operand,\r\n flow,\r\n contextualType,\r\n reportMode\r\n );\r\n }\r\n case Token.PLUS:\r\n case Token.PLUS_PLUS:\r\n case Token.MINUS_MINUS: {\r\n return this.resolveExpression(\r\n expression.operand,\r\n flow,\r\n contextualType,\r\n reportMode\r\n );\r\n }\r\n case Token.EXCLAMATION: {\r\n let typeClasses = this.program.typeClasses;\r\n return typeClasses.has(TypeKind.BOOL) ? typeClasses.get(TypeKind.BOOL)! : null;\r\n }\r\n case Token.TILDE: {\r\n let resolvedOperand = this.resolveExpression(\r\n expression.operand,\r\n flow,\r\n contextualType,\r\n reportMode\r\n );\r\n if (!resolvedOperand) return null;\r\n // TODO\r\n break;\r\n }\r\n default: assert(false);\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Resolves an unary postfix expression to the program element it refers to. */\r\n resolveUnaryPostfixExpression(\r\n /** The expression to resolve. */\r\n expression: UnaryPostfixExpression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type = Type.void,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n // TODO: operator overloads\r\n switch (expression.operator) {\r\n case Token.PLUS_PLUS:\r\n case Token.MINUS_MINUS: {\r\n return this.resolveExpression(\r\n expression.operand,\r\n flow,\r\n contextualType,\r\n reportMode\r\n );\r\n }\r\n default: assert(false);\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Resolves a binary expression to the program element it refers to. */\r\n resolveBinaryExpression(\r\n /** The expression to resolve. */\r\n expression: BinaryExpression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type = Type.void,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n // TODO\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Resolves a this expression to the program element it refers to. */\r\n resolveThisExpression(\r\n /** The expression to resolve. */\r\n expression: ThisExpression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type = Type.void,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n if (flow.is(FlowFlags.INLINE_CONTEXT)) {\r\n let thisLocal = flow.lookupLocal(CommonSymbols.this_);\r\n if (thisLocal) {\r\n this.currentThisExpression = null;\r\n this.currentElementExpression = null;\r\n return thisLocal;\r\n }\r\n }\r\n var parent = flow.actualFunction.parent;\r\n if (parent) {\r\n this.currentThisExpression = null;\r\n this.currentElementExpression = null;\r\n return parent;\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode._this_cannot_be_referenced_in_current_location,\r\n expression.range\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Resolves a super expression to the program element it refers to. */\r\n resolveSuperExpression(\r\n /** The expression to resolve. */\r\n expression: SuperExpression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type = Type.void,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n if (flow.is(FlowFlags.INLINE_CONTEXT)) {\r\n let superLocal = flow.lookupLocal(CommonSymbols.super_);\r\n if (superLocal) {\r\n this.currentThisExpression = null;\r\n this.currentElementExpression = null;\r\n return superLocal;\r\n }\r\n }\r\n var parent: Element | null = flow.actualFunction.parent;\r\n if (parent && parent.kind == ElementKind.CLASS && (parent = (parent).base)) {\r\n this.currentThisExpression = null;\r\n this.currentElementExpression = null;\r\n return parent;\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode._super_can_only_be_referenced_in_a_derived_class,\r\n expression.range\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Resolves a literal expression to the program element it refers to. */\r\n resolveLiteralExpression(\r\n /** The expression to resolve. */\r\n expression: LiteralExpression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type = Type.void,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n switch (expression.literalKind) {\r\n case LiteralKind.INTEGER: {\r\n this.currentThisExpression = expression;\r\n this.currentElementExpression = null;\r\n let literalType = this.determineIntegerLiteralType(\r\n (expression).value,\r\n contextualType\r\n );\r\n let typeClasses = this.program.typeClasses;\r\n return typeClasses.has(literalType.kind) ? typeClasses.get(literalType.kind)! : null;\r\n }\r\n case LiteralKind.FLOAT: {\r\n this.currentThisExpression = expression;\r\n this.currentElementExpression = null;\r\n let literalType = contextualType == Type.f32 ? Type.f32 : Type.f64;\r\n let typeClasses = this.program.typeClasses;\r\n return typeClasses.has(literalType.kind) ? typeClasses.get(literalType.kind)! : null;\r\n }\r\n case LiteralKind.STRING: {\r\n this.currentThisExpression = expression;\r\n this.currentElementExpression = null;\r\n return this.program.stringInstance;\r\n }\r\n // TODO\r\n // case LiteralKind.ARRAY:\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Resolves a call expression to the program element it refers to. */\r\n resolveCallExpression(\r\n /** The expression to resolve. */\r\n expression: CallExpression,\r\n /** Current flow. */\r\n flow: Flow,\r\n /** Current contextual type. */\r\n contextualType: Type = Type.void,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Element | null {\r\n var targetExpression = expression.expression;\r\n var target = this.resolveExpression( // reports\r\n targetExpression,\r\n flow,\r\n contextualType,\r\n reportMode\r\n );\r\n if (!target) return null;\r\n if (target.kind == ElementKind.FUNCTION_PROTOTYPE) {\r\n // `unchecked(expr: *): *` is special\r\n if (\r\n (target).internalName == BuiltinSymbols.unchecked &&\r\n expression.arguments.length > 0\r\n ) {\r\n return this.resolveExpression(expression.arguments[0], flow, contextualType, reportMode);\r\n }\r\n // otherwise resolve normally\r\n let instance = this.resolveFunctionInclTypeArguments(\r\n target,\r\n expression.typeArguments,\r\n flow.actualFunction,\r\n makeMap(flow.contextualTypeArguments), // don't inherit\r\n expression,\r\n reportMode\r\n );\r\n if (!instance) return null;\r\n let returnType = instance.signature.returnType;\r\n let classType = returnType.classReference;\r\n if (classType) {\r\n // reuse resolvedThisExpression (might be property access)\r\n // reuse resolvedElementExpression (might be element access)\r\n return classType;\r\n } else {\r\n let signature = returnType.signatureReference;\r\n if (signature) {\r\n let functionTarget = signature.asFunctionTarget(this.program);\r\n // reuse resolvedThisExpression (might be property access)\r\n // reuse resolvedElementExpression (might be element access)\r\n return functionTarget;\r\n }\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\r\n targetExpression.range, target.internalName\r\n );\r\n }\r\n return null;\r\n }\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n /** Resolves a function prototype using the specified concrete type arguments. */\r\n resolveFunction(\r\n /** The prototype of the function. */\r\n prototype: FunctionPrototype,\r\n /** Concrete type arguments. */\r\n typeArguments: Type[] | null,\r\n /** Type arguments inherited through context, i.e. `T`. */\r\n contextualTypeArguments: Map = makeMap(),\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Function | null {\r\n var actualParent = prototype.parent.kind == ElementKind.PROPERTY_PROTOTYPE\r\n ? prototype.parent.parent\r\n : prototype.parent;\r\n var classInstance: Class | null = null; // if an instance method\r\n var instanceKey = typeArguments ? typesToString(typeArguments) : \"\";\r\n\r\n // Instance method prototypes are pre-bound to their concrete class as their parent\r\n if (prototype.is(CommonFlags.INSTANCE)) {\r\n assert(actualParent.kind == ElementKind.CLASS);\r\n classInstance = actualParent;\r\n\r\n // check if this exact concrete class and function combination is known already\r\n let resolvedInstance = prototype.getResolvedInstance(instanceKey);\r\n if (resolvedInstance) return resolvedInstance;\r\n\r\n // inherit class specific type arguments\r\n let classTypeArguments = classInstance.typeArguments;\r\n if (classTypeArguments) {\r\n let classTypeParameters = assert(classInstance.prototype.typeParameterNodes);\r\n let numClassTypeArguments = classTypeParameters.length;\r\n assert(numClassTypeArguments == classTypeParameters.length);\r\n for (let i = 0; i < numClassTypeArguments; ++i) {\r\n let classTypeParameterName = classTypeParameters[i].name.text;\r\n if (!contextualTypeArguments.has(classTypeParameterName)) {\r\n contextualTypeArguments.set(\r\n classTypeParameterName,\r\n classTypeArguments[i]\r\n );\r\n }\r\n }\r\n }\r\n } else {\r\n assert(actualParent.kind != ElementKind.CLASS); // must not be pre-bound\r\n let resolvedInstance = prototype.getResolvedInstance(instanceKey);\r\n if (resolvedInstance) return resolvedInstance;\r\n }\r\n\r\n // override whatever is contextual with actual function type arguments\r\n var signatureNode = prototype.signatureNode;\r\n var typeParameterNodes = prototype.typeParameterNodes;\r\n var numFunctionTypeArguments: i32;\r\n if (typeArguments && (numFunctionTypeArguments = typeArguments.length)) {\r\n assert(typeParameterNodes && numFunctionTypeArguments == typeParameterNodes.length);\r\n for (let i = 0; i < numFunctionTypeArguments; ++i) {\r\n contextualTypeArguments.set(\r\n (typeParameterNodes)[i].name.text,\r\n typeArguments[i]\r\n );\r\n }\r\n } else {\r\n assert(!typeParameterNodes || typeParameterNodes.length == 0);\r\n }\r\n\r\n // resolve `this` type if applicable\r\n var thisType: Type | null = null;\r\n var explicitThisType = signatureNode.explicitThisType;\r\n if (explicitThisType) {\r\n thisType = this.resolveType(\r\n explicitThisType,\r\n prototype.parent, // relative to function\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n if (!thisType) return null;\r\n contextualTypeArguments.set(CommonSymbols.this_, thisType);\r\n } else if (classInstance) {\r\n thisType = classInstance.type;\r\n contextualTypeArguments.set(CommonSymbols.this_, thisType);\r\n }\r\n\r\n // resolve parameter types\r\n var signatureParameters = signatureNode.parameters;\r\n var numSignatureParameters = signatureParameters.length;\r\n var parameterTypes = new Array(numSignatureParameters);\r\n var parameterNames = new Array(numSignatureParameters);\r\n var requiredParameters = 0;\r\n for (let i = 0; i < numSignatureParameters; ++i) {\r\n let parameterDeclaration = signatureParameters[i];\r\n if (parameterDeclaration.parameterKind == ParameterKind.DEFAULT) {\r\n requiredParameters = i + 1;\r\n }\r\n let typeNode = parameterDeclaration.type;\r\n if (isTypeOmitted(typeNode)) {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n typeNode.range\r\n );\r\n return null;\r\n }\r\n let parameterType = this.resolveType(\r\n typeNode,\r\n prototype.parent, // relative to function\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n if (!parameterType) return null;\r\n parameterTypes[i] = parameterType;\r\n parameterNames[i] = parameterDeclaration.name.text;\r\n }\r\n\r\n // resolve return type\r\n var returnType: Type;\r\n if (prototype.is(CommonFlags.SET)) {\r\n returnType = Type.void; // not annotated\r\n } else if (prototype.is(CommonFlags.CONSTRUCTOR)) {\r\n returnType = assert(classInstance).type; // not annotated\r\n } else {\r\n let typeNode = signatureNode.returnType;\r\n if (isTypeOmitted(typeNode)) {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n typeNode.range\r\n );\r\n return null;\r\n }\r\n let type = this.resolveType(\r\n typeNode,\r\n prototype.parent, // relative to function\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n if (!type) return null;\r\n returnType = type;\r\n }\r\n\r\n var signature = new Signature(parameterTypes, returnType, thisType);\r\n signature.parameterNames = parameterNames;\r\n signature.requiredParameters = requiredParameters;\r\n\r\n var nameInclTypeParameters = prototype.name;\r\n if (instanceKey.length) nameInclTypeParameters += \"<\" + instanceKey + \">\";\r\n var instance = new Function(\r\n nameInclTypeParameters,\r\n prototype,\r\n signature,\r\n contextualTypeArguments\r\n );\r\n prototype.setResolvedInstance(instanceKey, instance);\r\n return instance;\r\n }\r\n\r\n /** Resolves a function prototypeby first resolving the specified type arguments. */\r\n resolveFunctionInclTypeArguments(\r\n /** The prototype of the function. */\r\n prototype: FunctionPrototype,\r\n /** Type arguments provided. */\r\n typeArgumentNodes: CommonTypeNode[] | null,\r\n /** Relative context. Type arguments are resolved from here. */\r\n context: Element,\r\n /** Type arguments inherited through context, i.e. `T`. */\r\n contextualTypeArguments: Map,\r\n /** The node to use when reporting intermediate errors. */\r\n reportNode: Node,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Function | null {\r\n var actualParent = prototype.parent.kind == ElementKind.PROPERTY_PROTOTYPE\r\n ? prototype.parent.parent\r\n : prototype.parent;\r\n var resolvedTypeArguments: Type[] | null = null;\r\n\r\n // Resolve type arguments if generic\r\n if (prototype.is(CommonFlags.GENERIC)) {\r\n\r\n // If this is an instance method, first apply the class's type arguments\r\n if (prototype.is(CommonFlags.INSTANCE)) {\r\n assert(actualParent.kind == ElementKind.CLASS);\r\n let classTypeArguments = (actualParent).typeArguments;\r\n if (classTypeArguments) {\r\n let typeParameterNodes = assert((actualParent).prototype.typeParameterNodes);\r\n let numClassTypeArguments = classTypeArguments.length;\r\n assert(numClassTypeArguments == typeParameterNodes.length);\r\n for (let i = 0; i < numClassTypeArguments; ++i) {\r\n contextualTypeArguments.set(\r\n typeParameterNodes[i].name.text,\r\n classTypeArguments[i]\r\n );\r\n }\r\n }\r\n }\r\n\r\n resolvedTypeArguments = this.resolveTypeArguments( // reports\r\n assert(prototype.typeParameterNodes),\r\n typeArgumentNodes,\r\n context,\r\n contextualTypeArguments,\r\n reportNode,\r\n reportMode\r\n );\r\n if (!resolvedTypeArguments) return null;\r\n\r\n // Otherwise make sure that no type arguments have been specified\r\n } else {\r\n if (typeArgumentNodes !== null && typeArgumentNodes.length) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n reportNode.range, prototype.internalName\r\n );\r\n }\r\n return null;\r\n }\r\n }\r\n\r\n // Continue with concrete types\r\n return this.resolveFunction(\r\n prototype,\r\n resolvedTypeArguments,\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n }\r\n\r\n /** Resolves a class prototype using the specified concrete type arguments. */\r\n resolveClass(\r\n /** The prototype of the class. */\r\n prototype: ClassPrototype,\r\n /** Concrete type arguments. */\r\n typeArguments: Type[] | null,\r\n /** Type arguments inherited through context, i.e. `T`. */\r\n contextualTypeArguments: Map = makeMap(),\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Class | null {\r\n var instanceKey = typeArguments ? typesToString(typeArguments) : \"\";\r\n\r\n // Check if this exact instance has already been resolved\r\n var instance = prototype.getResolvedInstance(instanceKey);\r\n if (instance) return instance;\r\n\r\n // Insert contextual type arguments for this operation. Internally, this method is always\r\n // called with matching type parameter / argument counts.\r\n if (typeArguments) {\r\n let typeParameterNodes = assert(prototype.typeParameterNodes);\r\n let numTypeParameters = typeParameterNodes.length;\r\n let numTypeArguments = typeArguments.length;\r\n assert(numTypeArguments == numTypeParameters);\r\n for (let i = 0; i < numTypeArguments; ++i) {\r\n contextualTypeArguments.set(typeParameterNodes[i].name.text, typeArguments[i]);\r\n }\r\n } else {\r\n let typeParameterNodes = prototype.typeParameterNodes;\r\n assert(!(typeParameterNodes && typeParameterNodes.length));\r\n }\r\n\r\n // Resolve base class if applicable\r\n var basePrototype = prototype.basePrototype;\r\n var baseClass: Class | null = null;\r\n if (basePrototype) {\r\n let extendsNode = assert(prototype.extendsNode); // must be present if it has a base prototype\r\n baseClass = this.resolveClassInclTypeArguments(\r\n basePrototype,\r\n extendsNode.typeArguments,\r\n prototype.parent, // relative to derived class\r\n makeMap(contextualTypeArguments), // don't inherit\r\n extendsNode,\r\n reportMode\r\n );\r\n if (!baseClass) return null;\r\n }\r\n\r\n // Construct the instance and remember that it has been resolved already\r\n var nameInclTypeParamters = prototype.name;\r\n if (instanceKey.length) nameInclTypeParamters += \"<\" + instanceKey + \">\";\r\n instance = new Class(nameInclTypeParamters, prototype, typeArguments, baseClass);\r\n instance.contextualTypeArguments = contextualTypeArguments;\r\n prototype.setResolvedInstance(instanceKey, instance);\r\n\r\n // Inherit base class members and set up the initial memory offset for own fields\r\n var memoryOffset: u32 = 0;\r\n if (baseClass) {\r\n let baseMembers = baseClass.members;\r\n if (baseMembers) {\r\n let instanceMembers = instance.members;\r\n if (!instanceMembers) instance.members = instanceMembers = new Map();\r\n for (let [baseMemberName, baseMember] of baseMembers) {\r\n instanceMembers.set(baseMemberName, baseMember);\r\n }\r\n }\r\n memoryOffset = baseClass.currentMemoryOffset;\r\n }\r\n\r\n // Resolve instance members\r\n var instanceMemberPrototypes = prototype.instanceMembers;\r\n if (instanceMemberPrototypes) {\r\n for (let member of instanceMemberPrototypes.values()) {\r\n switch (member.kind) {\r\n\r\n // Lay out fields in advance\r\n case ElementKind.FIELD_PROTOTYPE: {\r\n let instanceMembers = instance.members;\r\n if (!instanceMembers) instance.members = instanceMembers = new Map();\r\n else if (instanceMembers.has(member.name)) {\r\n this.error(\r\n DiagnosticCode.Duplicate_identifier_0,\r\n (member).identifierNode.range,\r\n member.name\r\n );\r\n break;\r\n }\r\n let fieldTypeNode = (member).typeNode;\r\n let fieldType: Type | null = null;\r\n // TODO: handle duplicate non-private fields specifically?\r\n if (!fieldTypeNode) {\r\n if (baseClass) {\r\n let baseMembers = baseClass.members;\r\n if (baseMembers && baseMembers.has((member).name)) {\r\n let baseField = baseMembers.get((member).name)!;\r\n if (!baseField.is(CommonFlags.PRIVATE)) {\r\n assert(baseField.kind == ElementKind.FIELD);\r\n fieldType = (baseField).type;\r\n }\r\n }\r\n }\r\n if (!fieldType) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n (member).identifierNode.range.atEnd\r\n );\r\n }\r\n }\r\n } else {\r\n fieldType = this.resolveType(\r\n fieldTypeNode,\r\n prototype.parent, // relative to class\r\n instance.contextualTypeArguments,\r\n reportMode\r\n );\r\n }\r\n if (!fieldType) break; // did report above\r\n let fieldInstance = new Field(member, instance, fieldType);\r\n assert(isPowerOf2(fieldType.byteSize));\r\n let mask = fieldType.byteSize - 1;\r\n if (memoryOffset & mask) memoryOffset = (memoryOffset | mask) + 1;\r\n fieldInstance.memoryOffset = memoryOffset;\r\n memoryOffset += fieldType.byteSize;\r\n instance.add(member.name, fieldInstance); // reports\r\n break;\r\n }\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n let boundPrototype = (member).toBound(instance);\r\n instance.add(boundPrototype.name, boundPrototype); // reports\r\n break;\r\n }\r\n case ElementKind.PROPERTY_PROTOTYPE: {\r\n let propertyInstance = new Property(member, instance);\r\n let getterPrototype = (member).getterPrototype;\r\n if (getterPrototype) {\r\n let getterInstance = this.resolveFunction(\r\n getterPrototype.toBound(instance),\r\n null,\r\n makeMap(instance.contextualTypeArguments),\r\n reportMode\r\n );\r\n if (getterInstance) {\r\n propertyInstance.getterInstance = getterInstance;\r\n propertyInstance.setType(getterInstance.signature.returnType);\r\n }\r\n }\r\n let setterPrototype = (member).setterPrototype;\r\n if (setterPrototype) {\r\n let setterInstance = this.resolveFunction(\r\n setterPrototype.toBound(instance),\r\n null,\r\n makeMap(instance.contextualTypeArguments),\r\n reportMode\r\n );\r\n if (setterInstance) {\r\n propertyInstance.setterInstance = setterInstance;\r\n if (!propertyInstance.is(CommonFlags.RESOLVED)) {\r\n assert(setterInstance.signature.parameterTypes.length == 1);\r\n propertyInstance.setType(setterInstance.signature.parameterTypes[0]);\r\n }\r\n }\r\n }\r\n instance.add(propertyInstance.name, propertyInstance); // reports\r\n break;\r\n }\r\n default: assert(false);\r\n }\r\n }\r\n }\r\n\r\n // Finalize memory offset\r\n instance.currentMemoryOffset = memoryOffset;\r\n\r\n // Link _own_ constructor if present\r\n {\r\n let ctorPrototype = instance.lookupInSelf(CommonSymbols.constructor);\r\n if (ctorPrototype && ctorPrototype.parent === instance) {\r\n assert(ctorPrototype.kind == ElementKind.FUNCTION_PROTOTYPE);\r\n let ctorInstance = this.resolveFunction(\r\n ctorPrototype,\r\n null,\r\n instance.contextualTypeArguments,\r\n reportMode\r\n );\r\n if (ctorInstance) instance.constructorInstance = ctorInstance;\r\n }\r\n }\r\n\r\n // Fully resolve operator overloads (don't have type parameters on their own)\r\n for (let [kind, overloadPrototype] of prototype.overloadPrototypes) {\r\n assert(kind != OperatorKind.INVALID);\r\n let operatorInstance: Function | null;\r\n if (overloadPrototype.is(CommonFlags.INSTANCE)) {\r\n let boundPrototype = overloadPrototype.toBound(instance);\r\n operatorInstance = this.resolveFunction(\r\n boundPrototype,\r\n null,\r\n makeMap(),\r\n reportMode\r\n );\r\n } else {\r\n operatorInstance = this.resolveFunction(\r\n overloadPrototype,\r\n null,\r\n makeMap(),\r\n reportMode\r\n );\r\n }\r\n if (!operatorInstance) continue;\r\n let overloads = instance.overloads;\r\n if (!overloads) instance.overloads = overloads = new Map();\r\n overloads.set(kind, operatorInstance);\r\n }\r\n return instance;\r\n }\r\n\r\n /** Resolves a class prototype by first resolving the specified type arguments. */\r\n resolveClassInclTypeArguments(\r\n /** The prototype of the class. */\r\n prototype: ClassPrototype,\r\n /** Type argument nodes provided. */\r\n typeArgumentNodes: CommonTypeNode[] | null,\r\n /** Relative context. Type arguments are resolved from here. */\r\n context: Element,\r\n /** Type arguments inherited through context, i.e. `T`. */\r\n contextualTypeArguments: Map,\r\n /** The node to use when reporting intermediate errors. */\r\n reportNode: Node,\r\n /** How to proceed with eventualy diagnostics. */\r\n reportMode: ReportMode = ReportMode.REPORT\r\n ): Class | null {\r\n var resolvedTypeArguments: Type[] | null = null;\r\n\r\n // Resolve type arguments if generic\r\n if (prototype.is(CommonFlags.GENERIC)) {\r\n resolvedTypeArguments = this.resolveTypeArguments( // reports\r\n assert(prototype.typeParameterNodes), // must be present if generic\r\n typeArgumentNodes,\r\n context,\r\n contextualTypeArguments,\r\n reportNode,\r\n reportMode\r\n );\r\n if (!resolvedTypeArguments) return null;\r\n\r\n // Otherwise make sure that no type arguments have been specified\r\n } else {\r\n if (typeArgumentNodes !== null && typeArgumentNodes.length) {\r\n if (reportMode == ReportMode.REPORT) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n reportNode.range, prototype.internalName\r\n );\r\n }\r\n return null;\r\n }\r\n }\r\n\r\n // Continue with concrete types\r\n return this.resolveClass(\r\n prototype,\r\n resolvedTypeArguments,\r\n contextualTypeArguments,\r\n reportMode\r\n );\r\n }\r\n}\r\n","/**\r\n * A control flow analyzer.\r\n * @module flow\r\n *//***/\r\n\r\nimport {\r\n Type,\r\n TypeFlags,\r\n TypeKind\r\n} from \"./types\";\r\n\r\nimport {\r\n Local,\r\n Function,\r\n Element,\r\n ElementKind,\r\n Global\r\n} from \"./program\";\r\n\r\nimport {\r\n NativeType,\r\n ExpressionId,\r\n ExpressionRef,\r\n\r\n getExpressionId,\r\n getLocalGetIndex,\r\n isLocalTee,\r\n getLocalSetValue,\r\n getGlobalGetName,\r\n getBinaryOp,\r\n BinaryOp,\r\n getBinaryLeft,\r\n getConstValueI32,\r\n getBinaryRight,\r\n getUnaryOp,\r\n UnaryOp,\r\n getExpressionType,\r\n getConstValueI64Low,\r\n getConstValueF32,\r\n getConstValueF64,\r\n getLoadBytes,\r\n isLoadSigned,\r\n getBlockName,\r\n getBlockChildCount,\r\n getBlockChild,\r\n getIfTrue,\r\n getIfFalse,\r\n getSelectThen,\r\n getSelectElse,\r\n getCallTarget,\r\n getLocalSetIndex,\r\n getIfCondition,\r\n getConstValueI64High,\r\n getUnaryValue,\r\n getCallOperand,\r\n traverse\r\n} from \"./module\";\r\n\r\nimport {\r\n CommonFlags\r\n} from \"./common\";\r\n\r\nimport {\r\n DiagnosticCode\r\n} from \"./diagnostics\";\r\n\r\nimport {\r\n Node\r\n} from \"./ast\";\r\n\r\n/** Control flow flags indicating specific conditions. */\r\nexport const enum FlowFlags {\r\n /** No specific conditions. */\r\n NONE = 0,\r\n\r\n // categorical\r\n\r\n /** This flow returns. */\r\n RETURNS = 1 << 0,\r\n /** This flow returns a wrapped value. */\r\n RETURNS_WRAPPED = 1 << 1,\r\n /** This flow returns a non-null value. */\r\n RETURNS_NONNULL = 1 << 2,\r\n /** This flow throws. */\r\n THROWS = 1 << 3,\r\n /** This flow breaks. */\r\n BREAKS = 1 << 4,\r\n /** This flow continues. */\r\n CONTINUES = 1 << 5,\r\n /** This flow allocates. Constructors only. */\r\n ALLOCATES = 1 << 6,\r\n /** This flow calls super. Constructors only. */\r\n CALLS_SUPER = 1 << 7,\r\n /** This flow terminates (returns, throws or continues). */\r\n TERMINATES = 1 << 8,\r\n\r\n // conditional\r\n\r\n /** This flow conditionally returns in a child flow. */\r\n CONDITIONALLY_RETURNS = 1 << 9,\r\n /** This flow conditionally throws in a child flow. */\r\n CONDITIONALLY_THROWS = 1 << 10,\r\n /** This flow conditionally terminates in a child flow. */\r\n CONDITIONALLY_TERMINATES = 1 << 11,\r\n /** This flow conditionally breaks in a child flow. */\r\n CONDITIONALLY_BREAKS = 1 << 12,\r\n /** This flow conditionally continues in a child flow. */\r\n CONDITIONALLY_CONTINUES = 1 << 13,\r\n /** This flow conditionally allocates in a child flow. Constructors only. */\r\n CONDITIONALLY_ALLOCATES = 1 << 14,\r\n\r\n // special\r\n\r\n /** This is an inlining flow. */\r\n INLINE_CONTEXT = 1 << 15,\r\n /** This is a flow with explicitly disabled bounds checking. */\r\n UNCHECKED_CONTEXT = 1 << 16,\r\n\r\n // masks\r\n\r\n /** Any categorical flag. */\r\n ANY_CATEGORICAL = FlowFlags.RETURNS\r\n | FlowFlags.RETURNS_WRAPPED\r\n | FlowFlags.RETURNS_NONNULL\r\n | FlowFlags.THROWS\r\n | FlowFlags.BREAKS\r\n | FlowFlags.CONTINUES\r\n | FlowFlags.ALLOCATES\r\n | FlowFlags.CALLS_SUPER\r\n | FlowFlags.TERMINATES,\r\n\r\n /** Any conditional flag. */\r\n ANY_CONDITIONAL = FlowFlags.CONDITIONALLY_RETURNS\r\n | FlowFlags.CONDITIONALLY_THROWS\r\n | FlowFlags.CONDITIONALLY_BREAKS\r\n | FlowFlags.CONDITIONALLY_CONTINUES\r\n | FlowFlags.CONDITIONALLY_ALLOCATES\r\n}\r\n\r\n/** Flags indicating the current state of a local. */\r\nexport enum LocalFlags {\r\n /** No specific conditions. */\r\n NONE = 0,\r\n\r\n /** Local is constant. */\r\n CONSTANT = 1 << 0,\r\n /** Local is properly wrapped. Relevant for small integers. */\r\n WRAPPED = 1 << 1,\r\n /** Local is non-null. */\r\n NONNULL = 1 << 2,\r\n /** Local is read from. */\r\n READFROM = 1 << 3,\r\n /** Local is written to. */\r\n WRITTENTO = 1 << 4,\r\n /** Local is retained. */\r\n RETAINED = 1 << 5,\r\n\r\n /** Local is conditionally read from. */\r\n CONDITIONALLY_READFROM = 1 << 6,\r\n /** Local is conditionally written to. */\r\n CONDITIONALLY_WRITTENTO = 1 << 7,\r\n /** Local must be conditionally retained. */\r\n CONDITIONALLY_RETAINED = 1 << 8,\r\n\r\n /** Any categorical flag. */\r\n ANY_CATEGORICAL = CONSTANT\r\n | WRAPPED\r\n | NONNULL\r\n | READFROM\r\n | WRITTENTO\r\n | RETAINED,\r\n\r\n /** Any conditional flag. */\r\n ANY_CONDITIONAL = RETAINED\r\n | CONDITIONALLY_READFROM\r\n | CONDITIONALLY_WRITTENTO\r\n | CONDITIONALLY_RETAINED,\r\n\r\n /** Any retained flag. */\r\n ANY_RETAINED = RETAINED\r\n | CONDITIONALLY_RETAINED\r\n}\r\nexport namespace LocalFlags {\r\n export function join(left: LocalFlags, right: LocalFlags): LocalFlags {\r\n return ((left & LocalFlags.ANY_CATEGORICAL) & (right & LocalFlags.ANY_CATEGORICAL))\r\n | (left & LocalFlags.ANY_CONDITIONAL) | (right & LocalFlags.ANY_CONDITIONAL);\r\n }\r\n}\r\n\r\n/** Flags indicating the current state of a field. */\r\nexport enum FieldFlags {\r\n /** No specific conditions. */\r\n NONE = 0,\r\n\r\n /** Field is initialized. Relevant in constructors. */\r\n INITIALIZED = 1 << 0,\r\n /** Field is conditionally initialized. Relevant in constructors. */\r\n CONDITIONALLY_INITIALIZED = 1 << 1,\r\n\r\n /** Any categorical flag. */\r\n ANY_CATEGORICAL = INITIALIZED,\r\n\r\n /** Any conditional flag. */\r\n ANY_CONDITIONAL = CONDITIONALLY_INITIALIZED\r\n}\r\nexport namespace FieldFlags {\r\n export function join(left: FieldFlags, right: FieldFlags): FieldFlags {\r\n return ((left & FieldFlags.ANY_CATEGORICAL) & (right & FieldFlags.ANY_CATEGORICAL))\r\n | (left & FieldFlags.ANY_CONDITIONAL) | (right & FieldFlags.ANY_CONDITIONAL);\r\n }\r\n}\r\n\r\n/** A control flow evaluator. */\r\nexport class Flow {\r\n\r\n /** Parent flow. */\r\n parent: Flow | null;\r\n /** Flow flags indicating specific conditions. */\r\n flags: FlowFlags;\r\n /** Function this flow belongs to. */\r\n parentFunction: Function;\r\n /** The label we break to when encountering a continue statement. */\r\n continueLabel: string | null;\r\n /** The label we break to when encountering a break statement. */\r\n breakLabel: string | null;\r\n /** The current return type. */\r\n returnType: Type;\r\n /** The current contextual type arguments. */\r\n contextualTypeArguments: Map | null;\r\n /** Scoped local variables. */\r\n scopedLocals: Map | null = null;\r\n /** Local flags. */\r\n localFlags: LocalFlags[];\r\n /** Field flags. Relevant in constructors. */\r\n fieldFlags: Map | null = null;\r\n /** Function being inlined, when inlining. */\r\n inlineFunction: Function | null;\r\n /** The label we break to when encountering a return statement, when inlining. */\r\n inlineReturnLabel: string | null;\r\n\r\n /** Creates the parent flow of the specified function. */\r\n static create(parentFunction: Function): Flow {\r\n var flow = new Flow();\r\n flow.parent = null;\r\n flow.flags = FlowFlags.NONE;\r\n flow.parentFunction = parentFunction;\r\n flow.continueLabel = null;\r\n flow.breakLabel = null;\r\n flow.returnType = parentFunction.signature.returnType;\r\n flow.contextualTypeArguments = parentFunction.contextualTypeArguments;\r\n flow.localFlags = [];\r\n flow.inlineFunction = null;\r\n flow.inlineReturnLabel = null;\r\n return flow;\r\n }\r\n\r\n /** Creates an inline flow within `parentFunction`. */\r\n static createInline(parentFunction: Function, inlineFunction: Function): Flow {\r\n var flow = Flow.create(parentFunction);\r\n flow.set(FlowFlags.INLINE_CONTEXT);\r\n flow.inlineFunction = inlineFunction;\r\n flow.inlineReturnLabel = inlineFunction.internalName + \"|inlined.\" + (inlineFunction.nextInlineId++).toString(10);\r\n flow.returnType = inlineFunction.signature.returnType;\r\n flow.contextualTypeArguments = inlineFunction.contextualTypeArguments;\r\n return flow;\r\n }\r\n\r\n private constructor() { }\r\n\r\n /** Gets the actual function being compiled, The inlined function when inlining, otherwise the parent function. */\r\n get actualFunction(): Function {\r\n return this.inlineFunction || this.parentFunction;\r\n }\r\n\r\n /** Tests if this flow has the specified flag or flags. */\r\n is(flag: FlowFlags): bool { return (this.flags & flag) == flag; }\r\n /** Tests if this flow has one of the specified flags. */\r\n isAny(flag: FlowFlags): bool { return (this.flags & flag) != 0; }\r\n /** Sets the specified flag or flags. */\r\n set(flag: FlowFlags): void { this.flags |= flag; }\r\n /** Unsets the specified flag or flags. */\r\n unset(flag: FlowFlags): void { this.flags &= ~flag; }\r\n\r\n /** Forks this flow to a child flow. */\r\n fork(): Flow {\r\n var branch = new Flow();\r\n branch.parent = this;\r\n branch.flags = this.flags;\r\n branch.parentFunction = this.parentFunction;\r\n branch.continueLabel = this.continueLabel;\r\n branch.breakLabel = this.breakLabel;\r\n branch.returnType = this.returnType;\r\n branch.contextualTypeArguments = this.contextualTypeArguments;\r\n branch.localFlags = this.localFlags.slice();\r\n branch.inlineFunction = this.inlineFunction;\r\n branch.inlineReturnLabel = this.inlineReturnLabel;\r\n return branch;\r\n }\r\n\r\n /** Gets a free temporary local of the specified type. */\r\n getTempLocal(type: Type, except: Set | null = null): Local {\r\n var parentFunction = this.parentFunction;\r\n var temps: Local[] | null;\r\n switch (type.toNativeType()) {\r\n case NativeType.I32: { temps = parentFunction.tempI32s; break; }\r\n case NativeType.I64: { temps = parentFunction.tempI64s; break; }\r\n case NativeType.F32: { temps = parentFunction.tempF32s; break; }\r\n case NativeType.F64: { temps = parentFunction.tempF64s; break; }\r\n case NativeType.V128: { temps = parentFunction.tempV128s; break; }\r\n default: throw new Error(\"concrete type expected\");\r\n }\r\n var local: Local;\r\n if (except) {\r\n if (temps && temps.length) {\r\n for (let i = 0, k = temps.length; i < k; ++i) {\r\n if (!except.has(temps[i].index)) {\r\n local = temps[i];\r\n let k = temps.length - 1;\r\n while (i < k) unchecked(temps[i] = temps[i++ + 1]);\r\n temps.length = k;\r\n local.type = type;\r\n local.flags = CommonFlags.NONE;\r\n this.unsetLocalFlag(local.index, ~0);\r\n return local;\r\n }\r\n }\r\n }\r\n local = parentFunction.addLocal(type);\r\n } else {\r\n if (temps && temps.length) {\r\n local = temps.pop();\r\n local.type = type;\r\n local.flags = CommonFlags.NONE;\r\n } else {\r\n local = parentFunction.addLocal(type);\r\n }\r\n }\r\n this.unsetLocalFlag(local.index, ~0);\r\n return local;\r\n }\r\n\r\n /** Gets a local that sticks around until this flow is exited, and then released. */\r\n getAutoreleaseLocal(type: Type, except: Set | null = null): Local {\r\n var local = this.getTempLocal(type, except);\r\n local.set(CommonFlags.SCOPED);\r\n var scopedLocals = this.scopedLocals;\r\n if (!scopedLocals) this.scopedLocals = scopedLocals = new Map();\r\n scopedLocals.set(\"~auto\" + (this.parentFunction.nextAutoreleaseId++), local);\r\n this.setLocalFlag(local.index, LocalFlags.RETAINED);\r\n return local;\r\n }\r\n\r\n /** Frees the temporary local for reuse. */\r\n freeTempLocal(local: Local): void {\r\n if (local.is(CommonFlags.INLINED)) return;\r\n assert(local.index >= 0);\r\n var parentFunction = this.parentFunction;\r\n var temps: Local[];\r\n assert(local.type != null); // internal error\r\n switch ((local.type).toNativeType()) {\r\n case NativeType.I32: {\r\n temps = parentFunction.tempI32s || (parentFunction.tempI32s = []);\r\n break;\r\n }\r\n case NativeType.I64: {\r\n temps = parentFunction.tempI64s || (parentFunction.tempI64s = []);\r\n break;\r\n }\r\n case NativeType.F32: {\r\n temps = parentFunction.tempF32s || (parentFunction.tempF32s = []);\r\n break;\r\n }\r\n case NativeType.F64: {\r\n temps = parentFunction.tempF64s || (parentFunction.tempF64s = []);\r\n break;\r\n }\r\n case NativeType.V128: {\r\n temps = parentFunction.tempV128s || (parentFunction.tempV128s = []);\r\n break;\r\n }\r\n default: throw new Error(\"concrete type expected\");\r\n }\r\n assert(local.index >= 0);\r\n temps.push(local);\r\n }\r\n\r\n /** Gets and immediately frees a temporary local of the specified type. */\r\n getAndFreeTempLocal(type: Type, except: Set | null = null): Local {\r\n var local = this.getTempLocal(type, except);\r\n this.freeTempLocal(local);\r\n return local;\r\n }\r\n\r\n /** Gets the scoped local of the specified name. */\r\n getScopedLocal(name: string): Local | null {\r\n var scopedLocals = this.scopedLocals;\r\n if (scopedLocals && scopedLocals.has(name)) return scopedLocals.get(name);\r\n return null;\r\n }\r\n\r\n /** Adds a new scoped local of the specified name. */\r\n addScopedLocal(name: string, type: Type, except: Set | null = null): Local {\r\n var scopedLocal = this.getTempLocal(type, except);\r\n var scopedLocals = this.scopedLocals;\r\n if (!scopedLocals) this.scopedLocals = scopedLocals = new Map();\r\n else assert(!scopedLocals.has(name));\r\n scopedLocal.set(CommonFlags.SCOPED);\r\n scopedLocals.set(name, scopedLocal);\r\n return scopedLocal;\r\n }\r\n\r\n /** Adds a new scoped alias for the specified local. For example `super` aliased to the `this` local. */\r\n addScopedAlias(name: string, type: Type, index: i32, reportNode: Node | null = null): Local {\r\n if (!this.scopedLocals) this.scopedLocals = new Map();\r\n else {\r\n let existingLocal = this.scopedLocals.get(name);\r\n if (existingLocal) {\r\n if (reportNode) {\r\n this.parentFunction.program.error(\r\n DiagnosticCode.Duplicate_identifier_0,\r\n reportNode.range\r\n );\r\n }\r\n return existingLocal;\r\n }\r\n }\r\n assert(index < this.parentFunction.localsByIndex.length);\r\n var scopedAlias = new Local(name, index, type, this.parentFunction);\r\n // not flagged as SCOPED as it must not be free'd when the flow is finalized\r\n this.scopedLocals.set(name, scopedAlias);\r\n return scopedAlias;\r\n }\r\n\r\n /** Frees this flow's scoped variables and returns its parent flow. */\r\n freeScopedLocals(): void {\r\n if (this.scopedLocals) {\r\n for (let scopedLocal of this.scopedLocals.values()) {\r\n if (scopedLocal.is(CommonFlags.SCOPED)) { // otherwise an alias\r\n this.freeTempLocal(scopedLocal);\r\n }\r\n }\r\n this.scopedLocals = null;\r\n }\r\n }\r\n\r\n /** Looks up the local of the specified name in the current scope. */\r\n lookupLocal(name: string): Local | null {\r\n var current: Flow | null = this;\r\n var scope: Map | null;\r\n do if ((scope = current.scopedLocals) && (scope.has(name))) return scope.get(name);\r\n while (current = current.parent);\r\n return this.parentFunction.localsByName.get(name);\r\n }\r\n\r\n /** Looks up the element with the specified name relative to the scope of this flow. */\r\n lookup(name: string): Element | null {\r\n var element = this.lookupLocal(name);\r\n if (element) return element;\r\n return this.actualFunction.lookup(name);\r\n }\r\n\r\n /** Tests if the local at the specified index has the specified flag or flags. */\r\n isLocalFlag(index: i32, flag: LocalFlags, defaultIfInlined: bool = true): bool {\r\n if (index < 0) return defaultIfInlined;\r\n var localFlags = this.localFlags;\r\n return index < localFlags.length && (unchecked(this.localFlags[index]) & flag) == flag;\r\n }\r\n\r\n /** Tests if the local at the specified index has any of the specified flags. */\r\n isAnyLocalFlag(index: i32, flag: LocalFlags, defaultIfInlined: bool = true): bool {\r\n if (index < 0) return defaultIfInlined;\r\n var localFlags = this.localFlags;\r\n return index < localFlags.length && (unchecked(this.localFlags[index]) & flag) != 0;\r\n }\r\n\r\n /** Sets the specified flag or flags on the local at the specified index. */\r\n setLocalFlag(index: i32, flag: LocalFlags): void {\r\n if (index < 0) return;\r\n var localFlags = this.localFlags;\r\n var flags = index < localFlags.length ? unchecked(localFlags[index]) : 0;\r\n this.localFlags[index] = flags | flag;\r\n }\r\n\r\n /** Unsets the specified flag or flags on the local at the specified index. */\r\n unsetLocalFlag(index: i32, flag: LocalFlags): void {\r\n if (index < 0) return;\r\n var localFlags = this.localFlags;\r\n var flags = index < localFlags.length ? unchecked(localFlags[index]) : 0;\r\n this.localFlags[index] = flags & ~flag;\r\n }\r\n\r\n /** Pushes a new break label to the stack, for example when entering a loop that one can `break` from. */\r\n pushBreakLabel(): string {\r\n var parentFunction = this.parentFunction;\r\n var id = parentFunction.nextBreakId++;\r\n var stack = parentFunction.breakStack;\r\n if (!stack) parentFunction.breakStack = [ id ];\r\n else stack.push(id);\r\n return parentFunction.breakLabel = id.toString(10);\r\n }\r\n\r\n /** Pops the most recent break label from the stack. */\r\n popBreakLabel(): void {\r\n var parentFunction = this.parentFunction;\r\n var stack = assert(parentFunction.breakStack);\r\n var length = assert(stack.length);\r\n stack.pop();\r\n if (length > 1) {\r\n parentFunction.breakLabel = stack[length - 2].toString(10);\r\n } else {\r\n parentFunction.breakLabel = null;\r\n parentFunction.breakStack = null;\r\n }\r\n }\r\n\r\n /** Inherits flags and local wrap states from the specified flow (e.g. blocks). */\r\n inherit(other: Flow): void {\r\n this.flags |= other.flags & (FlowFlags.ANY_CATEGORICAL | FlowFlags.ANY_CONDITIONAL);\r\n this.localFlags = other.localFlags; // no need to slice because other flow is finished\r\n }\r\n\r\n /** Inherits categorical flags as conditional flags from the specified flow (e.g. then without else). */\r\n inheritConditional(other: Flow): void {\r\n if (other.is(FlowFlags.RETURNS)) {\r\n this.set(FlowFlags.CONDITIONALLY_RETURNS);\r\n }\r\n if (other.is(FlowFlags.THROWS)) {\r\n this.set(FlowFlags.CONDITIONALLY_THROWS);\r\n }\r\n if (other.is(FlowFlags.BREAKS) && other.breakLabel == this.breakLabel) {\r\n this.set(FlowFlags.CONDITIONALLY_BREAKS);\r\n }\r\n if (other.is(FlowFlags.CONTINUES) && other.continueLabel == this.continueLabel) {\r\n this.set(FlowFlags.CONDITIONALLY_CONTINUES);\r\n }\r\n if (other.is(FlowFlags.ALLOCATES)) {\r\n this.set(FlowFlags.CONDITIONALLY_ALLOCATES);\r\n }\r\n var localFlags = other.localFlags;\r\n for (let i = 0, k = localFlags.length; i < k; ++i) {\r\n let flags = localFlags[i];\r\n if (flags & LocalFlags.RETAINED) this.setLocalFlag(i, LocalFlags.CONDITIONALLY_RETAINED);\r\n if (flags & LocalFlags.READFROM) this.setLocalFlag(i, LocalFlags.CONDITIONALLY_READFROM);\r\n if (flags & LocalFlags.WRITTENTO) this.setLocalFlag(i, LocalFlags.CONDITIONALLY_WRITTENTO);\r\n }\r\n }\r\n\r\n /** Inherits mutual flags and local wrap states from the specified flows (e.g. then with else). */\r\n inheritMutual(left: Flow, right: Flow): void {\r\n // categorical flags set in both arms\r\n this.set(left.flags & right.flags & FlowFlags.ANY_CATEGORICAL);\r\n\r\n // conditional flags set in any arm\r\n this.set(left.flags & FlowFlags.ANY_CONDITIONAL);\r\n this.set(right.flags & FlowFlags.ANY_CONDITIONAL);\r\n\r\n // categorical flags in either arm as conditional\r\n this.inheritConditional(left);\r\n this.inheritConditional(right);\r\n\r\n // categorical local flags set in both arms / conditional local flags set in at least one arm\r\n var leftLocalFlags = left.localFlags;\r\n var numLeftLocalFlags = leftLocalFlags.length;\r\n var rightLocalFlags = right.localFlags;\r\n var numRightLocalFlags = rightLocalFlags.length;\r\n var combinedFlags = new Array(max(numLeftLocalFlags, numRightLocalFlags));\r\n for (let i = 0; i < numLeftLocalFlags; ++i) {\r\n combinedFlags[i] = LocalFlags.join(\r\n unchecked(leftLocalFlags[i]),\r\n i < numRightLocalFlags\r\n ? unchecked(rightLocalFlags[i])\r\n : 0\r\n );\r\n }\r\n for (let i = numLeftLocalFlags; i < numRightLocalFlags; ++i) {\r\n combinedFlags[i] = LocalFlags.join(\r\n 0,\r\n unchecked(rightLocalFlags[i])\r\n );\r\n }\r\n this.localFlags = combinedFlags;\r\n }\r\n\r\n /** Checks if an expression of the specified type is known to be non-null, even if the type might be nullable. */\r\n isNonnull(expr: ExpressionRef, type: Type): bool {\r\n if (!type.is(TypeFlags.NULLABLE)) return true;\r\n // below, only teeLocal/getLocal are relevant because these are the only expressions that\r\n // depend on a dynamic nullable state (flag = LocalFlags.NONNULL), while everything else\r\n // has already been handled by the nullable type check above.\r\n switch (getExpressionId(expr)) {\r\n case ExpressionId.LocalSet: {\r\n if (!isLocalTee(expr)) break;\r\n let local = this.parentFunction.localsByIndex[getLocalSetIndex(expr)];\r\n return !local.type.is(TypeFlags.NULLABLE) || this.isLocalFlag(local.index, LocalFlags.NONNULL, false);\r\n }\r\n case ExpressionId.LocalGet: {\r\n let local = this.parentFunction.localsByIndex[getLocalGetIndex(expr)];\r\n return !local.type.is(TypeFlags.NULLABLE) || this.isLocalFlag(local.index, LocalFlags.NONNULL, false);\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n /** Updates local states to reflect that this branch is only taken when `expr` is true-ish. */\r\n inheritNonnullIfTrue(expr: ExpressionRef): void {\r\n // A: `expr` is true-ish -> Q: how did that happen?\r\n switch (getExpressionId(expr)) {\r\n case ExpressionId.LocalSet: {\r\n if (!isLocalTee(expr)) break;\r\n let local = this.parentFunction.localsByIndex[getLocalSetIndex(expr)];\r\n this.setLocalFlag(local.index, LocalFlags.NONNULL);\r\n this.inheritNonnullIfTrue(getLocalSetValue(expr)); // must have been true-ish as well\r\n break;\r\n }\r\n case ExpressionId.LocalGet: {\r\n let local = this.parentFunction.localsByIndex[getLocalGetIndex(expr)];\r\n this.setLocalFlag(local.index, LocalFlags.NONNULL);\r\n break;\r\n }\r\n case ExpressionId.If: {\r\n let ifFalse = getIfFalse(expr);\r\n if (!ifFalse) break;\r\n if (getExpressionId(ifFalse) == ExpressionId.Const) {\r\n // Logical AND: (if (condition ifTrue 0))\r\n // the only way this had become true is if condition and ifTrue are true\r\n if (\r\n (getExpressionType(ifFalse) == NativeType.I32 && getConstValueI32(ifFalse) == 0) ||\r\n (getExpressionType(ifFalse) == NativeType.I64 && getConstValueI64Low(ifFalse) == 0 && getConstValueI64High(ifFalse) == 0)\r\n ) {\r\n this.inheritNonnullIfTrue(getIfCondition(expr));\r\n this.inheritNonnullIfTrue(getIfTrue(expr));\r\n }\r\n }\r\n break;\r\n }\r\n case ExpressionId.Unary: {\r\n switch (getUnaryOp(expr)) {\r\n case UnaryOp.EqzI32:\r\n case UnaryOp.EqzI64: {\r\n this.inheritNonnullIfFalse(getUnaryValue(expr)); // !value -> value must have been false\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case ExpressionId.Binary: {\r\n switch (getBinaryOp(expr)) {\r\n case BinaryOp.EqI32: {\r\n let left = getBinaryLeft(expr);\r\n let right = getBinaryRight(expr);\r\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI32(left) != 0) {\r\n this.inheritNonnullIfTrue(right); // TRUE == right -> right must have been true\r\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI32(right) != 0) {\r\n this.inheritNonnullIfTrue(left); // left == TRUE -> left must have been true\r\n }\r\n break;\r\n }\r\n case BinaryOp.EqI64: {\r\n let left = getBinaryLeft(expr);\r\n let right = getBinaryRight(expr);\r\n if (getExpressionId(left) == ExpressionId.Const && (getConstValueI64Low(left) != 0 || getConstValueI64High(left) != 0)) {\r\n this.inheritNonnullIfTrue(right); // TRUE == right -> right must have been true\r\n } else if (getExpressionId(right) == ExpressionId.Const && (getConstValueI64Low(right) != 0 && getConstValueI64High(right) != 0)) {\r\n this.inheritNonnullIfTrue(left); // left == TRUE -> left must have been true\r\n }\r\n break;\r\n }\r\n case BinaryOp.NeI32: {\r\n let left = getBinaryLeft(expr);\r\n let right = getBinaryRight(expr);\r\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI32(left) == 0) {\r\n this.inheritNonnullIfTrue(right); // FALSE != right -> right must have been true\r\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI32(right) == 0) {\r\n this.inheritNonnullIfTrue(left); // left != FALSE -> left must have been true\r\n }\r\n break;\r\n }\r\n case BinaryOp.NeI64: {\r\n let left = getBinaryLeft(expr);\r\n let right = getBinaryRight(expr);\r\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI64Low(left) == 0 && getConstValueI64High(left) == 0) {\r\n this.inheritNonnullIfTrue(right); // FALSE != right -> right must have been true\r\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI64Low(right) == 0 && getConstValueI64High(right) == 0) {\r\n this.inheritNonnullIfTrue(left); // left != FALSE -> left must have been true\r\n }\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case ExpressionId.Call: {\r\n let name = getCallTarget(expr);\r\n let program = this.parentFunction.program;\r\n switch (name) {\r\n case program.retainInstance.internalName: {\r\n this.inheritNonnullIfTrue(getCallOperand(expr, 0));\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n }\r\n\r\n /** Updates local states to reflect that this branch is only taken when `expr` is false-ish. */\r\n inheritNonnullIfFalse(expr: ExpressionRef): void {\r\n // A: `expr` is false-ish -> Q: how did that happen?\r\n switch (getExpressionId(expr)) {\r\n case ExpressionId.Unary: {\r\n switch (getUnaryOp(expr)) {\r\n case UnaryOp.EqzI32:\r\n case UnaryOp.EqzI64: {\r\n this.inheritNonnullIfTrue(getUnaryValue(expr)); // !value -> value must have been true\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case ExpressionId.If: {\r\n let ifTrue = getIfTrue(expr);\r\n if (getExpressionId(ifTrue) == ExpressionId.Const) {\r\n let ifFalse = getIfFalse(expr);\r\n if (!ifFalse) break;\r\n // Logical OR: (if (condition 1 ifFalse))\r\n // the only way this had become false is if condition and ifFalse are false\r\n if (\r\n (getExpressionType(ifTrue) == NativeType.I32 && getConstValueI32(ifTrue) != 0) ||\r\n (getExpressionType(ifTrue) == NativeType.I64 && (getConstValueI64Low(ifTrue) != 0 || getConstValueI64High(ifTrue) != 0))\r\n ) {\r\n this.inheritNonnullIfFalse(getIfCondition(expr));\r\n this.inheritNonnullIfFalse(getIfFalse(expr));\r\n }\r\n\r\n }\r\n break;\r\n }\r\n case ExpressionId.Binary: {\r\n switch (getBinaryOp(expr)) {\r\n // remember: we want to know how the _entire_ expression became FALSE (!)\r\n case BinaryOp.EqI32: {\r\n let left = getBinaryLeft(expr);\r\n let right = getBinaryRight(expr);\r\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI32(left) == 0) {\r\n this.inheritNonnullIfTrue(right); // FALSE == right -> right must have been true\r\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI32(right) == 0) {\r\n this.inheritNonnullIfTrue(left); // left == FALSE -> left must have been true\r\n }\r\n break;\r\n }\r\n case BinaryOp.EqI64: {\r\n let left = getBinaryLeft(expr);\r\n let right = getBinaryRight(expr);\r\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI64Low(left) == 0 && getConstValueI64High(left) == 0) {\r\n this.inheritNonnullIfTrue(right); // FALSE == right -> right must have been true\r\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI64Low(right) == 0 && getConstValueI64High(right) == 0) {\r\n this.inheritNonnullIfTrue(left); // left == FALSE -> left must have been true\r\n }\r\n break;\r\n }\r\n case BinaryOp.NeI32: {\r\n let left = getBinaryLeft(expr);\r\n let right = getBinaryRight(expr);\r\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI32(left) != 0) {\r\n this.inheritNonnullIfTrue(right); // TRUE != right -> right must have been true\r\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI32(right) != 0) {\r\n this.inheritNonnullIfTrue(left); // left != TRUE -> left must have been true\r\n }\r\n break;\r\n }\r\n case BinaryOp.NeI64: {\r\n let left = getBinaryLeft(expr);\r\n let right = getBinaryRight(expr);\r\n if (getExpressionId(left) == ExpressionId.Const && (getConstValueI64Low(left) != 0 || getConstValueI64High(left) != 0)) {\r\n this.inheritNonnullIfTrue(right); // TRUE != right -> right must have been true for this to become false\r\n } else if (getExpressionId(right) == ExpressionId.Const && (getConstValueI64Low(right) != 0 || getConstValueI64High(right) != 0)) {\r\n this.inheritNonnullIfTrue(left); // left != TRUE -> left must have been true for this to become false\r\n }\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Tests if an expression can possibly overflow in the context of this flow. Assumes that the\r\n * expression might already have overflown and returns `false` only if the operation neglects\r\n * any possible combination of garbage bits being present.\r\n */\r\n canOverflow(expr: ExpressionRef, type: Type): bool {\r\n // TODO: the following catches most common and a few uncommon cases, but there are additional\r\n // opportunities here, obviously.\r\n assert(type != Type.void);\r\n\r\n // types other than i8, u8, i16, u16 and bool do not overflow\r\n if (!type.is(TypeFlags.SHORT | TypeFlags.INTEGER)) return false;\r\n\r\n var operand: ExpressionRef;\r\n switch (getExpressionId(expr)) {\r\n\r\n // overflows if the local isn't wrapped or the conversion does\r\n case ExpressionId.LocalGet: {\r\n let local = this.parentFunction.localsByIndex[getLocalGetIndex(expr)];\r\n return !this.isLocalFlag(local.index, LocalFlags.WRAPPED, true)\r\n || canConversionOverflow(local.type, type);\r\n }\r\n\r\n // overflows if the value does\r\n case ExpressionId.LocalSet: { // tee\r\n assert(isLocalTee(expr));\r\n return this.canOverflow(getLocalSetValue(expr), type);\r\n }\r\n\r\n // overflows if the conversion does (globals are wrapped on set)\r\n case ExpressionId.GlobalGet: {\r\n // TODO: this is inefficient because it has to read a string\r\n let global = assert(this.parentFunction.program.elementsByName.get(assert(getGlobalGetName(expr))));\r\n assert(global.kind == ElementKind.GLOBAL);\r\n return canConversionOverflow(assert((global).type), type);\r\n }\r\n\r\n case ExpressionId.Binary: {\r\n switch (getBinaryOp(expr)) {\r\n\r\n // comparisons do not overflow (result is 0 or 1)\r\n case BinaryOp.EqI32:\r\n case BinaryOp.EqI64:\r\n case BinaryOp.EqF32:\r\n case BinaryOp.EqF64:\r\n case BinaryOp.NeI32:\r\n case BinaryOp.NeI64:\r\n case BinaryOp.NeF32:\r\n case BinaryOp.NeF64:\r\n case BinaryOp.LtI32:\r\n case BinaryOp.LtU32:\r\n case BinaryOp.LtI64:\r\n case BinaryOp.LtU64:\r\n case BinaryOp.LtF32:\r\n case BinaryOp.LtF64:\r\n case BinaryOp.LeI32:\r\n case BinaryOp.LeU32:\r\n case BinaryOp.LeI64:\r\n case BinaryOp.LeU64:\r\n case BinaryOp.LeF32:\r\n case BinaryOp.LeF64:\r\n case BinaryOp.GtI32:\r\n case BinaryOp.GtU32:\r\n case BinaryOp.GtI64:\r\n case BinaryOp.GtU64:\r\n case BinaryOp.GtF32:\r\n case BinaryOp.GtF64:\r\n case BinaryOp.GeI32:\r\n case BinaryOp.GeU32:\r\n case BinaryOp.GeI64:\r\n case BinaryOp.GeU64:\r\n case BinaryOp.GeF32:\r\n case BinaryOp.GeF64: return false;\r\n\r\n // result won't overflow if one side is 0 or if one side is 1 and the other wrapped\r\n case BinaryOp.MulI32: {\r\n return !(\r\n (\r\n getExpressionId(operand = getBinaryLeft(expr)) == ExpressionId.Const &&\r\n (\r\n getConstValueI32(operand) == 0 ||\r\n (\r\n getConstValueI32(operand) == 1 &&\r\n !this.canOverflow(getBinaryRight(expr), type)\r\n )\r\n )\r\n ) || (\r\n getExpressionId(operand = getBinaryRight(expr)) == ExpressionId.Const &&\r\n (\r\n getConstValueI32(operand) == 0 ||\r\n (\r\n getConstValueI32(operand) == 1 &&\r\n !this.canOverflow(getBinaryLeft(expr), type)\r\n )\r\n )\r\n )\r\n );\r\n }\r\n\r\n // result won't overflow if one side is a constant less than this type's mask or one side\r\n // is wrapped\r\n case BinaryOp.AndI32: {\r\n // note that computeSmallIntegerMask returns the mask minus the MSB for signed types\r\n // because signed value garbage bits must be guaranteed to be equal to the MSB.\r\n return !(\r\n (\r\n (\r\n getExpressionId(operand = getBinaryLeft(expr)) == ExpressionId.Const &&\r\n getConstValueI32(operand) <= type.computeSmallIntegerMask(Type.i32)\r\n ) || !this.canOverflow(operand, type)\r\n ) || (\r\n (\r\n getExpressionId(operand = getBinaryRight(expr)) == ExpressionId.Const &&\r\n getConstValueI32(operand) <= type.computeSmallIntegerMask(Type.i32)\r\n ) || !this.canOverflow(operand, type)\r\n )\r\n );\r\n }\r\n\r\n // overflows if the shift doesn't clear potential garbage bits\r\n case BinaryOp.ShlI32: {\r\n let shift = 32 - type.size;\r\n return getExpressionId(operand = getBinaryRight(expr)) != ExpressionId.Const\r\n || getConstValueI32(operand) < shift;\r\n }\r\n\r\n // overflows if the value does and the shift doesn't clear potential garbage bits\r\n case BinaryOp.ShrI32: {\r\n let shift = 32 - type.size;\r\n return this.canOverflow(getBinaryLeft(expr), type) && (\r\n getExpressionId(operand = getBinaryRight(expr)) != ExpressionId.Const ||\r\n getConstValueI32(operand) < shift\r\n );\r\n }\r\n\r\n // overflows if the shift does not clear potential garbage bits. if an unsigned value is\r\n // wrapped, it can't overflow.\r\n case BinaryOp.ShrU32: {\r\n let shift = 32 - type.size;\r\n return type.is(TypeFlags.SIGNED)\r\n ? !(\r\n getExpressionId(operand = getBinaryRight(expr)) == ExpressionId.Const &&\r\n getConstValueI32(operand) > shift // must clear MSB\r\n )\r\n : this.canOverflow(getBinaryLeft(expr), type) && !(\r\n getExpressionId(operand = getBinaryRight(expr)) == ExpressionId.Const &&\r\n getConstValueI32(operand) >= shift // can leave MSB\r\n );\r\n }\r\n\r\n // overflows if any side does\r\n case BinaryOp.DivU32:\r\n case BinaryOp.RemI32:\r\n case BinaryOp.RemU32: {\r\n return this.canOverflow(getBinaryLeft(expr), type)\r\n || this.canOverflow(getBinaryRight(expr), type);\r\n }\r\n }\r\n break;\r\n }\r\n\r\n case ExpressionId.Unary: {\r\n switch (getUnaryOp(expr)) {\r\n\r\n // comparisons do not overflow (result is 0 or 1)\r\n case UnaryOp.EqzI32:\r\n case UnaryOp.EqzI64: return false;\r\n\r\n // overflow if the maximum result (32) cannot be represented in the target type\r\n case UnaryOp.ClzI32:\r\n case UnaryOp.CtzI32:\r\n case UnaryOp.PopcntI32: return type.size < 7;\r\n }\r\n break;\r\n }\r\n\r\n // overflows if the value cannot be represented in the target type\r\n case ExpressionId.Const: {\r\n let value: i32 = 0;\r\n switch (getExpressionType(expr)) {\r\n case NativeType.I32: { value = getConstValueI32(expr); break; }\r\n case NativeType.I64: { value = getConstValueI64Low(expr); break; } // discards upper bits\r\n case NativeType.F32: { value = i32(getConstValueF32(expr)); break; }\r\n case NativeType.F64: { value = i32(getConstValueF64(expr)); break; }\r\n default: assert(false);\r\n }\r\n switch (type.kind) {\r\n case TypeKind.I8: return value < i8.MIN_VALUE || value > i8.MAX_VALUE;\r\n case TypeKind.I16: return value < i16.MIN_VALUE || value > i16.MAX_VALUE;\r\n case TypeKind.U8: return value < 0 || value > u8.MAX_VALUE;\r\n case TypeKind.U16: return value < 0 || value > u16.MAX_VALUE;\r\n case TypeKind.BOOL: return (value & ~1) != 0;\r\n }\r\n break;\r\n }\r\n\r\n // overflows if the conversion does\r\n case ExpressionId.Load: {\r\n let fromType: Type;\r\n let signed = isLoadSigned(expr);\r\n switch (getLoadBytes(expr)) {\r\n case 1: { fromType = signed ? Type.i8 : Type.u8; break; }\r\n case 2: { fromType = signed ? Type.i16 : Type.u16; break; }\r\n default: { fromType = signed ? Type.i32 : Type.u32; break; }\r\n }\r\n return canConversionOverflow(fromType, type);\r\n }\r\n\r\n // overflows if the result does, which is either\r\n // - the last expression of the block, by contract, if the block doesn't have a label\r\n // - the last expression or the value of an inner br if the block has a label (TODO)\r\n case ExpressionId.Block: {\r\n if (!getBlockName(expr)) {\r\n let size = assert(getBlockChildCount(expr));\r\n let last = getBlockChild(expr, size - 1);\r\n return this.canOverflow(last, type);\r\n }\r\n break;\r\n }\r\n\r\n // overflows if either side does\r\n case ExpressionId.If: {\r\n return this.canOverflow(getIfTrue(expr), type)\r\n || this.canOverflow(assert(getIfFalse(expr)), type);\r\n }\r\n\r\n // overflows if either side does\r\n case ExpressionId.Select: {\r\n return this.canOverflow(getSelectThen(expr), type)\r\n || this.canOverflow(getSelectElse(expr), type);\r\n }\r\n\r\n // overflows if the call does not return a wrapped value or the conversion does\r\n case ExpressionId.Call: {\r\n let program = this.parentFunction.program;\r\n let instancesByName = program.instancesByName;\r\n let instanceName = assert(getCallTarget(expr));\r\n if (instancesByName.has(instanceName)) {\r\n let instance = instancesByName.get(instanceName)!;\r\n assert(instance.kind == ElementKind.FUNCTION);\r\n let returnType = (instance).signature.returnType;\r\n return !(instance).flow.is(FlowFlags.RETURNS_WRAPPED)\r\n || canConversionOverflow(returnType, type);\r\n }\r\n return false; // assume no overflow for builtins\r\n }\r\n\r\n // doesn't technically overflow\r\n case ExpressionId.Unreachable: return false;\r\n }\r\n return true;\r\n }\r\n\r\n toString(): string {\r\n var levels = 0;\r\n var parent = this.parent;\r\n while (parent) {\r\n parent = parent.parent;\r\n ++levels;\r\n }\r\n return \"Flow(\" + this.actualFunction + \")[\" + levels.toString() + \"]\";\r\n }\r\n}\r\n\r\n/** Tests if a conversion from one type to another can technically overflow. */\r\nfunction canConversionOverflow(fromType: Type, toType: Type): bool {\r\n return !fromType.is(TypeFlags.INTEGER) // non-i32 locals or returns\r\n || fromType.size > toType.size\r\n || fromType.is(TypeFlags.SIGNED) != toType.is(TypeFlags.SIGNED);\r\n}\r\n\r\n/** Finds all indexes of locals used in the specified expression. */\r\nexport function findUsedLocals(expr: ExpressionRef, used: Set = new Set()): Set {\r\n traverse(expr, used, findUsedLocalsVisit);\r\n return used;\r\n}\r\n\r\n/** A visitor function for use with `traverse` that finds all indexes of used locals. */\r\nfunction findUsedLocalsVisit(expr: ExpressionRef, used: Set): void {\r\n switch (getExpressionId(expr)) {\r\n case ExpressionId.LocalGet: {\r\n used.add(getLocalGetIndex(expr));\r\n break;\r\n }\r\n case ExpressionId.LocalSet: {\r\n used.add(getLocalSetIndex(expr));\r\n // fall-through for value\r\n }\r\n default: traverse(expr, used, findUsedLocalsVisit);\r\n }\r\n}\r\n","/**\r\n * The AssemblyScript compiler.\r\n * @module compiler\r\n *//***/\r\n\r\nimport {\r\n BuiltinSymbols,\r\n compileCall as compileBuiltinCall,\r\n compileAbort,\r\n compileVisitGlobals,\r\n compileVisitMembers,\r\n compileRTTI,\r\n} from \"./builtins\";\r\n\r\nimport {\r\n DiagnosticCode,\r\n DiagnosticEmitter\r\n} from \"./diagnostics\";\r\n\r\nimport {\r\n Module,\r\n MemorySegment,\r\n ExpressionRef,\r\n UnaryOp,\r\n BinaryOp,\r\n NativeType,\r\n FunctionRef,\r\n ExpressionId,\r\n FunctionTypeRef,\r\n GlobalRef,\r\n getExpressionId,\r\n getExpressionType,\r\n getConstValueI32,\r\n getConstValueI64Low,\r\n getConstValueI64High,\r\n getConstValueF32,\r\n getConstValueF64,\r\n getBlockChildCount,\r\n getBlockChild,\r\n getBlockName,\r\n getLocalGetIndex,\r\n isLocalTee,\r\n getLocalSetIndex,\r\n FeatureFlags,\r\n needsExplicitUnreachable\r\n} from \"./module\";\r\n\r\nimport {\r\n CommonFlags,\r\n INSTANCE_DELIMITER,\r\n STATIC_DELIMITER,\r\n GETTER_PREFIX,\r\n SETTER_PREFIX,\r\n CommonSymbols,\r\n INDEX_SUFFIX,\r\n Feature,\r\n Target\r\n} from \"./common\";\r\n\r\nimport {\r\n Program,\r\n ClassPrototype,\r\n Class,\r\n Element,\r\n ElementKind,\r\n Enum,\r\n Field,\r\n FunctionPrototype,\r\n Function,\r\n FunctionTarget,\r\n Global,\r\n Local,\r\n EnumValue,\r\n Property,\r\n VariableLikeElement,\r\n ConstantValueKind,\r\n OperatorKind,\r\n DecoratorFlags,\r\n PropertyPrototype,\r\n File,\r\n mangleInternalName\r\n} from \"./program\";\r\n\r\nimport {\r\n FlowFlags,\r\n Flow,\r\n LocalFlags,\r\n findUsedLocals\r\n} from \"./flow\";\r\n\r\nimport {\r\n Resolver, ReportMode\r\n} from \"./resolver\";\r\n\r\nimport {\r\n Token,\r\n operatorTokenToString\r\n} from \"./tokenizer\";\r\n\r\nimport {\r\n Node,\r\n NodeKind,\r\n TypeNode,\r\n Range,\r\n DecoratorKind,\r\n AssertionKind,\r\n\r\n Statement,\r\n BlockStatement,\r\n BreakStatement,\r\n ClassDeclaration,\r\n ContinueStatement,\r\n DeclarationStatement,\r\n DoStatement,\r\n EmptyStatement,\r\n EnumDeclaration,\r\n ExportStatement,\r\n ExpressionStatement,\r\n FieldDeclaration,\r\n ForStatement,\r\n FunctionDeclaration,\r\n IfStatement,\r\n ImportStatement,\r\n InstanceOfExpression,\r\n InterfaceDeclaration,\r\n NamespaceDeclaration,\r\n ReturnStatement,\r\n SwitchStatement,\r\n ThrowStatement,\r\n TryStatement,\r\n VariableStatement,\r\n VoidStatement,\r\n WhileStatement,\r\n\r\n Expression,\r\n AssertionExpression,\r\n BinaryExpression,\r\n CallExpression,\r\n CommaExpression,\r\n ElementAccessExpression,\r\n FloatLiteralExpression,\r\n FunctionExpression,\r\n IdentifierExpression,\r\n IntegerLiteralExpression,\r\n LiteralExpression,\r\n LiteralKind,\r\n NewExpression,\r\n ObjectLiteralExpression,\r\n ParenthesizedExpression,\r\n PropertyAccessExpression,\r\n TernaryExpression,\r\n ArrayLiteralExpression,\r\n StringLiteralExpression,\r\n UnaryPostfixExpression,\r\n UnaryPrefixExpression,\r\n\r\n nodeIsConstantValue,\r\n findDecorator,\r\n isTypeOmitted,\r\n ExportDefaultStatement\r\n} from \"./ast\";\r\n\r\nimport {\r\n Type,\r\n TypeKind,\r\n TypeFlags,\r\n Signature,\r\n typesToNativeTypes\r\n} from \"./types\";\r\n\r\nimport {\r\n writeI8,\r\n writeI16,\r\n writeI32,\r\n writeI64,\r\n writeF32,\r\n writeF64,\r\n makeMap\r\n} from \"./util\";\r\n\r\n/** Compiler options. */\r\nexport class Options {\r\n\r\n /** WebAssembly target. Defaults to {@link Target.WASM32}. */\r\n target: Target = Target.WASM32;\r\n /** If true, replaces assertions with nops. */\r\n noAssert: bool = false;\r\n /** If true, imports the memory provided by the embedder. */\r\n importMemory: bool = false;\r\n /** If greater than zero, declare memory as shared by setting max memory to sharedMemory. */\r\n sharedMemory: i32 = 0;\r\n /** If true, imports the function table provided by the embedder. */\r\n importTable: bool = false;\r\n /** If true, generates information necessary for source maps. */\r\n sourceMap: bool = false;\r\n /** If true, generates an explicit start function. */\r\n explicitStart: bool = false;\r\n /** Static memory start offset. */\r\n memoryBase: i32 = 0;\r\n /** Global aliases. */\r\n globalAliases: Map | null = null;\r\n /** Additional features to activate. */\r\n features: Feature = Feature.NONE;\r\n\r\n /** Hinted optimize level. Not applied by the compiler itself. */\r\n optimizeLevelHint: i32 = 0;\r\n /** Hinted shrink level. Not applied by the compiler itself. */\r\n shrinkLevelHint: i32 = 0;\r\n\r\n /** Tests if the target is WASM64 or, otherwise, WASM32. */\r\n get isWasm64(): bool {\r\n return this.target == Target.WASM64;\r\n }\r\n\r\n /** Gets the unsigned size type matching the target. */\r\n get usizeType(): Type {\r\n return this.target == Target.WASM64 ? Type.usize64 : Type.usize32;\r\n }\r\n\r\n /** Gets the signed size type matching the target. */\r\n get isizeType(): Type {\r\n return this.target == Target.WASM64 ? Type.isize64 : Type.isize32;\r\n }\r\n\r\n /** Gets the native size type matching the target. */\r\n get nativeSizeType(): NativeType {\r\n return this.target == Target.WASM64 ? NativeType.I64 : NativeType.I32;\r\n }\r\n\r\n /** Tests if a specific feature is activated. */\r\n hasFeature(feature: Feature): bool {\r\n return (this.features & feature) != 0;\r\n }\r\n}\r\n\r\n/** Various constraints in expression compilation. */\r\nexport const enum Constraints {\r\n NONE = 0,\r\n\r\n /** Must implicitly convert to the target type. */\r\n CONV_IMPLICIT = 1 << 0,\r\n /** Must explicitly convert to the target type. */\r\n CONV_EXPLICIT = 1 << 1,\r\n /** Must wrap small integer values to match the target type. */\r\n MUST_WRAP = 1 << 2,\r\n\r\n /** Indicates that the value will be dropped immediately. */\r\n WILL_DROP = 1 << 3,\r\n /** Indicates that the value will be retained immediately. */\r\n WILL_RETAIN = 1 << 4,\r\n /** Indicates that static data is preferred. */\r\n PREFER_STATIC = 1 << 5\r\n}\r\n\r\n/** Runtime features to be activated by the compiler. */\r\nexport const enum RuntimeFeatures {\r\n NONE = 0,\r\n /** Requires heap setup. */\r\n HEAP = 1 << 0,\r\n /** Requires runtime type information setup. */\r\n RTTI = 1 << 1,\r\n /** Requires the built-in globals visitor. */\r\n visitGlobals = 1 << 2,\r\n /** Requires the built-in members visitor. */\r\n visitMembers = 1 << 3\r\n}\r\n\r\n/** Compiler interface. */\r\nexport class Compiler extends DiagnosticEmitter {\r\n\r\n /** Program reference. */\r\n program: Program;\r\n /** Resolver reference. */\r\n resolver: Resolver;\r\n /** Provided options. */\r\n options: Options;\r\n /** Module instance being compiled. */\r\n module: Module;\r\n /** Current control flow. */\r\n currentFlow: Flow;\r\n /** Current inline functions stack. */\r\n currentInlineFunctions: Function[] = [];\r\n /** Current enum in compilation. */\r\n currentEnum: Enum | null = null;\r\n /** Current type in compilation. */\r\n currentType: Type = Type.void;\r\n /** Start function statements. */\r\n currentBody: ExpressionRef[];\r\n /** Counting memory offset. */\r\n memoryOffset: I64;\r\n /** Memory segments being compiled. */\r\n memorySegments: MemorySegment[] = [];\r\n /** Map of already compiled static string segments. */\r\n stringSegments: Map = new Map();\r\n /** Function table being compiled. */\r\n functionTable: string[] = [ \"null\" ];\r\n /** Argument count helper global. */\r\n argcVar: GlobalRef = 0;\r\n /** Argument count helper setter. */\r\n argcSet: FunctionRef = 0;\r\n /** Requires runtime features. */\r\n runtimeFeatures: RuntimeFeatures = RuntimeFeatures.NONE;\r\n /** Expressions known to have skipped an autorelease. Usually function returns. */\r\n skippedAutoreleases: Set = new Set();\r\n\r\n /** Compiles a {@link Program} to a {@link Module} using the specified options. */\r\n static compile(program: Program, options: Options | null = null): Module {\r\n return new Compiler(program, options).compile();\r\n }\r\n\r\n /** Constructs a new compiler for a {@link Program} using the specified options. */\r\n constructor(program: Program, options: Options | null = null) {\r\n super(program.diagnostics);\r\n this.program = program;\r\n this.resolver = program.resolver;\r\n if (!options) options = new Options();\r\n this.options = options;\r\n this.memoryOffset = i64_new(\r\n // leave space for `null`. also functions as a sentinel for erroneous stores at offset 0.\r\n // note that Binaryen's asm.js output utilizes the first 8 bytes for reinterpretations (#1547)\r\n max(options.memoryBase, 8)\r\n );\r\n this.module = Module.create();\r\n var featureFlags: BinaryenFeatureFlags = 0;\r\n if (this.options.hasFeature(Feature.THREADS)) featureFlags |= FeatureFlags.Atomics;\r\n if (this.options.hasFeature(Feature.MUTABLE_GLOBAL)) featureFlags |= FeatureFlags.MutableGloabls;\r\n // if (this.options.hasFeature(Feature.TRUNC_SAT)) featureFlags |= FeatureFlags.NontrappingFPToInt;\r\n if (this.options.hasFeature(Feature.SIMD)) featureFlags |= FeatureFlags.SIMD128;\r\n if (this.options.hasFeature(Feature.BULK_MEMORY)) featureFlags |= FeatureFlags.BulkMemory;\r\n if (this.options.hasFeature(Feature.SIGN_EXTENSION)) featureFlags |= FeatureFlags.SignExt;\r\n // if (this.options.hasFeature(Feature.EXCEPTION_HANDLING)) featureFlags |= FeatureFlags.ExceptionHandling;\r\n this.module.setFeatures(featureFlags);\r\n }\r\n\r\n /** Performs compilation of the underlying {@link Program} to a {@link Module}. */\r\n compile(): Module {\r\n var options = this.options;\r\n var module = this.module;\r\n var program = this.program;\r\n\r\n // initialize lookup maps, built-ins, imports, exports, etc.\r\n program.initialize(options);\r\n\r\n // set up the main start function\r\n var startFunctionInstance = program.makeNativeFunction(\"start\", new Signature([], Type.void));\r\n startFunctionInstance.internalName = \"start\";\r\n var startFunctionBody = new Array();\r\n this.currentFlow = startFunctionInstance.flow;\r\n this.currentBody = startFunctionBody;\r\n\r\n // add a mutable heap and rtti base dummies\r\n if (options.isWasm64) {\r\n module.addGlobal(BuiltinSymbols.heap_base, NativeType.I64, true, module.i64(0));\r\n module.addGlobal(BuiltinSymbols.rtti_base, NativeType.I64, true, module.i64(0));\r\n } else {\r\n module.addGlobal(BuiltinSymbols.heap_base, NativeType.I32, true, module.i32(0));\r\n module.addGlobal(BuiltinSymbols.rtti_base, NativeType.I32, true, module.i32(0));\r\n }\r\n\r\n // compile entry file(s) while traversing reachable elements\r\n var files = program.filesByName;\r\n for (let file of files.values()) {\r\n if (file.source.isEntry) {\r\n this.compileFile(file);\r\n this.compileExports(file);\r\n }\r\n }\r\n\r\n // compile the start function if not empty or explicitly requested\r\n var startIsEmpty = !startFunctionBody.length;\r\n var explicitStart = options.explicitStart;\r\n if (!startIsEmpty || explicitStart) {\r\n let signature = startFunctionInstance.signature;\r\n if (!startIsEmpty && explicitStart) {\r\n module.addGlobal(BuiltinSymbols.started, NativeType.I32, true, module.i32(0));\r\n startFunctionBody.unshift(\r\n module.if(\r\n module.global_get(BuiltinSymbols.started, NativeType.I32),\r\n module.return(),\r\n module.global_set(BuiltinSymbols.started, module.i32(1))\r\n )\r\n );\r\n }\r\n let funcRef = module.addFunction(\r\n startFunctionInstance.internalName,\r\n this.ensureFunctionType(\r\n signature.parameterTypes,\r\n signature.returnType,\r\n signature.thisType\r\n ),\r\n typesToNativeTypes(startFunctionInstance.additionalLocals),\r\n module.block(null, startFunctionBody)\r\n );\r\n startFunctionInstance.finalize(module, funcRef);\r\n if (!explicitStart) module.setStart(funcRef);\r\n else module.addFunctionExport(startFunctionInstance.internalName, \"__start\");\r\n }\r\n\r\n // compile runtime features\r\n if (this.runtimeFeatures & RuntimeFeatures.visitGlobals) compileVisitGlobals(this);\r\n if (this.runtimeFeatures & RuntimeFeatures.visitMembers) compileVisitMembers(this);\r\n module.removeGlobal(BuiltinSymbols.rtti_base);\r\n if (this.runtimeFeatures & RuntimeFeatures.RTTI) compileRTTI(this);\r\n\r\n // update the heap base pointer\r\n var memoryOffset = this.memoryOffset;\r\n memoryOffset = i64_align(memoryOffset, options.usizeType.byteSize);\r\n this.memoryOffset = memoryOffset;\r\n module.removeGlobal(BuiltinSymbols.heap_base);\r\n if (this.runtimeFeatures & RuntimeFeatures.HEAP) {\r\n if (options.isWasm64) {\r\n module.addGlobal(\r\n BuiltinSymbols.heap_base,\r\n NativeType.I64,\r\n false,\r\n module.i64(i64_low(memoryOffset), i64_high(memoryOffset))\r\n );\r\n } else {\r\n module.addGlobal(\r\n BuiltinSymbols.heap_base,\r\n NativeType.I32,\r\n false,\r\n module.i32(i64_low(memoryOffset))\r\n );\r\n }\r\n }\r\n\r\n // set up memory\r\n var isSharedMemory = options.hasFeature(Feature.THREADS) && options.sharedMemory > 0;\r\n module.setMemory(\r\n this.options.memoryBase /* is specified */ || this.memorySegments.length\r\n ? i64_low(i64_shr_u(i64_align(memoryOffset, 0x10000), i64_new(16, 0)))\r\n : 0,\r\n isSharedMemory ? options.sharedMemory : Module.UNLIMITED_MEMORY,\r\n this.memorySegments,\r\n options.target,\r\n \"memory\",\r\n isSharedMemory\r\n );\r\n\r\n // import memory if requested (default memory is named '0' by Binaryen)\r\n if (options.importMemory) module.addMemoryImport(\"0\", \"env\", \"memory\", isSharedMemory);\r\n\r\n // set up function table\r\n var functionTable = this.functionTable;\r\n module.setFunctionTable(functionTable.length, 0xffffffff, functionTable);\r\n module.addFunction(\"null\", this.ensureFunctionType(null, Type.void), null, module.block(null, []));\r\n\r\n // import table if requested (default table is named '0' by Binaryen)\r\n if (options.importTable) module.addTableImport(\"0\", \"env\", \"table\");\r\n\r\n // set up module exports\r\n for (let file of this.program.filesByName.values()) {\r\n if (file.source.isEntry) this.ensureModuleExports(file);\r\n }\r\n return module;\r\n }\r\n\r\n /** Applies the respective module exports for the specified file. */\r\n private ensureModuleExports(file: File): void {\r\n var members = file.exports;\r\n if (members) for (let [name, member] of members) this.ensureModuleExport(name, member);\r\n var exportsStar = file.exportsStar;\r\n if (exportsStar) {\r\n for (let i = 0, k = exportsStar.length; i < k; ++i) this.ensureModuleExports(exportsStar[i]);\r\n }\r\n }\r\n\r\n /** Applies the respective module export(s) for the specified element. */\r\n private ensureModuleExport(name: string, element: Element, prefix: string = \"\"): void {\r\n switch (element.kind) {\r\n\r\n // traverse instances\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n let instances = (element).instances;\r\n if (instances) {\r\n for (let instance of instances.values()) {\r\n let instanceName = name;\r\n if (instance.is(CommonFlags.GENERIC)) {\r\n let fullName = instance.internalName;\r\n instanceName += fullName.substring(fullName.lastIndexOf(\"<\"));\r\n }\r\n this.ensureModuleExport(instanceName, instance, prefix);\r\n }\r\n }\r\n break;\r\n }\r\n case ElementKind.CLASS_PROTOTYPE: {\r\n let instances = (element).instances;\r\n if (instances) {\r\n for (let instance of instances.values()) {\r\n let instanceName = name;\r\n if (instance.is(CommonFlags.GENERIC)) {\r\n let fullName = instance.internalName;\r\n instanceName += fullName.substring(fullName.lastIndexOf(\"<\"));\r\n }\r\n this.ensureModuleExport(instanceName, instance, prefix);\r\n }\r\n }\r\n break;\r\n }\r\n case ElementKind.PROPERTY_PROTOTYPE: {\r\n let getter = (element).getterPrototype;\r\n let setter = (element).setterPrototype;\r\n if (getter) this.ensureModuleExport(GETTER_PREFIX + name, getter, prefix);\r\n if (setter) this.ensureModuleExport(SETTER_PREFIX + name, setter, prefix);\r\n break;\r\n }\r\n\r\n // export concrete elements\r\n case ElementKind.GLOBAL: {\r\n let isConst = element.is(CommonFlags.CONST) || element.is(CommonFlags.STATIC | CommonFlags.READONLY);\r\n if (!isConst && !this.options.hasFeature(Feature.MUTABLE_GLOBAL)) {\r\n this.error(\r\n DiagnosticCode.Cannot_export_a_mutable_global,\r\n (element).identifierNode.range\r\n );\r\n } else {\r\n this.module.addGlobalExport(element.internalName, prefix + name);\r\n }\r\n break;\r\n }\r\n case ElementKind.ENUMVALUE: {\r\n if (!(element).isImmutable && !this.options.hasFeature(Feature.MUTABLE_GLOBAL)) {\r\n this.error(\r\n DiagnosticCode.Cannot_export_a_mutable_global,\r\n (element).identifierNode.range\r\n );\r\n } else {\r\n this.module.addGlobalExport(element.internalName, prefix + name);\r\n }\r\n break;\r\n }\r\n case ElementKind.FUNCTION: {\r\n let instance = element;\r\n let signature = instance.signature;\r\n if (signature.requiredParameters < signature.parameterTypes.length) {\r\n // utilize trampoline to fill in omitted arguments\r\n instance = this.ensureTrampoline(instance);\r\n this.ensureArgcSet();\r\n }\r\n if (instance.is(CommonFlags.COMPILED)) this.module.addFunctionExport(instance.internalName, prefix + name);\r\n break;\r\n }\r\n case ElementKind.PROPERTY: {\r\n let getter = (element).getterInstance;\r\n if (getter) this.ensureModuleExport(GETTER_PREFIX + name, getter, prefix);\r\n let setter = (element).setterInstance;\r\n if (setter) this.ensureModuleExport(SETTER_PREFIX + name, setter, prefix);\r\n break;\r\n }\r\n case ElementKind.FIELD: {\r\n this.ensureModuleFieldGetter(prefix + GETTER_PREFIX + name, element);\r\n if (!element.is(CommonFlags.READONLY)) {\r\n this.ensureModuleFieldSetter(prefix + SETTER_PREFIX + name, element);\r\n }\r\n break;\r\n }\r\n case ElementKind.CLASS: {\r\n // make the class name itself represent its runtime id\r\n if (!(element).type.isUnmanaged) {\r\n let module = this.module;\r\n let internalName = (element).internalName;\r\n module.addGlobal(internalName, NativeType.I32, false, module.i32((element).id));\r\n module.addGlobalExport(internalName, prefix + name);\r\n }\r\n break;\r\n }\r\n\r\n // just traverse members below\r\n case ElementKind.ENUM:\r\n case ElementKind.NAMESPACE:\r\n case ElementKind.FILE:\r\n case ElementKind.TYPEDEFINITION: break;\r\n\r\n default: assert(false); // unexpected module export\r\n }\r\n\r\n // traverse members\r\n var members = element.members;\r\n if (members) {\r\n let subPrefix = prefix + name + (element.kind == ElementKind.CLASS\r\n ? INSTANCE_DELIMITER\r\n : STATIC_DELIMITER\r\n );\r\n if (\r\n element.kind == ElementKind.NAMESPACE ||\r\n element.kind == ElementKind.FILE\r\n ) {\r\n for (let member of members.values()) {\r\n if (!member.is(CommonFlags.EXPORT)) continue;\r\n this.ensureModuleExport(member.name, member, subPrefix);\r\n }\r\n } else {\r\n for (let member of members.values()) {\r\n if (member.is(CommonFlags.PRIVATE)) continue;\r\n this.ensureModuleExport(member.name, member, subPrefix);\r\n }\r\n }\r\n }\r\n }\r\n\r\n /** Makes a function to get the value of a field of an exported class. */\r\n private ensureModuleFieldGetter(name: string, field: Field): void {\r\n var module = this.module;\r\n var type = field.type;\r\n var usizeType = this.options.usizeType;\r\n var loadExpr = module.load(type.byteSize, type.is(TypeFlags.SIGNED),\r\n module.local_get(0, usizeType.toNativeType()),\r\n type.toNativeType(), field.memoryOffset\r\n );\r\n // a user-defined getter would return a retained value, so:\r\n if (type.isManaged) loadExpr = this.makeRetain(loadExpr);\r\n module.addFunction(\r\n name,\r\n this.ensureFunctionType(null, type, usizeType),\r\n null,\r\n loadExpr\r\n );\r\n module.addFunctionExport(name, name);\r\n }\r\n\r\n /** Makes a function to set the value of a field of an exported class. */\r\n private ensureModuleFieldSetter(name: string, field: Field): void {\r\n var module = this.module;\r\n var type = field.type;\r\n var nativeType = type.toNativeType();\r\n var usizeType = this.options.usizeType;\r\n var nativeSizeType = usizeType.toNativeType();\r\n var valueExpr = module.local_get(1, nativeType);\r\n if (type.isManaged) {\r\n valueExpr = this.makeRetainRelease(\r\n module.load(type.byteSize, false, // oldRef\r\n module.local_get(0, nativeSizeType),\r\n nativeType, field.memoryOffset\r\n ),\r\n valueExpr // newRef\r\n );\r\n }\r\n module.addFunction(\r\n name,\r\n this.ensureFunctionType([ type ], Type.void, usizeType),\r\n null,\r\n module.store(\r\n type.byteSize,\r\n module.local_get(0, nativeSizeType),\r\n valueExpr,\r\n nativeType,\r\n field.memoryOffset\r\n )\r\n );\r\n module.addFunctionExport(name, name);\r\n }\r\n\r\n // === Elements =================================================================================\r\n\r\n /** Compiles any element. */\r\n compileElement(element: Element, compileMembers: bool = true): void {\r\n switch (element.kind) {\r\n case ElementKind.GLOBAL: {\r\n this.compileGlobal(element);\r\n break;\r\n }\r\n case ElementKind.ENUM: {\r\n this.compileEnum(element);\r\n break;\r\n }\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n if (!element.is(CommonFlags.GENERIC)) {\r\n this.compileFunctionUsingTypeArguments(element, []);\r\n }\r\n break;\r\n }\r\n case ElementKind.CLASS_PROTOTYPE: {\r\n if (!element.is(CommonFlags.GENERIC)) {\r\n this.compileClassUsingTypeArguments(element, []);\r\n }\r\n break;\r\n }\r\n case ElementKind.PROPERTY_PROTOTYPE: {\r\n let getterPrototype = (element).getterPrototype;\r\n if (getterPrototype) {\r\n this.compileFunctionUsingTypeArguments(getterPrototype, []);\r\n }\r\n let setterPrototype = (element).setterPrototype;\r\n if (setterPrototype) {\r\n this.compileFunctionUsingTypeArguments(setterPrototype, []);\r\n }\r\n break;\r\n }\r\n case ElementKind.NAMESPACE:\r\n case ElementKind.TYPEDEFINITION:\r\n case ElementKind.ENUMVALUE: break;\r\n default: assert(false, ElementKind[element.kind]);\r\n }\r\n if (compileMembers) this.compileMembers(element);\r\n }\r\n\r\n /** Compiles an element's members. */\r\n compileMembers(element: Element): void {\r\n var members = element.members;\r\n if (members) for (let element of members.values()) this.compileElement(element);\r\n }\r\n\r\n /** Compiles a file's exports. */\r\n compileExports(file: File): void {\r\n var exports = file.exports;\r\n if (exports) for (let element of exports.values()) this.compileElement(element);\r\n var exportsStar = file.exportsStar;\r\n if (exportsStar) {\r\n for (let exportStar of exportsStar) {\r\n this.compileFile(exportStar);\r\n this.compileExports(exportStar);\r\n }\r\n }\r\n }\r\n\r\n // files\r\n\r\n /** Compiles the file matching the specified path. */\r\n compileFileByPath(normalizedPathWithoutExtension: string, reportNode: Node): void {\r\n var file: File;\r\n var filesByName = this.program.filesByName;\r\n var pathWithIndex: string;\r\n if (filesByName.has(normalizedPathWithoutExtension)) {\r\n file = filesByName.get(normalizedPathWithoutExtension)!;\r\n } else if (filesByName.has(pathWithIndex = normalizedPathWithoutExtension + INDEX_SUFFIX)) {\r\n file = filesByName.get(pathWithIndex)!;\r\n } else {\r\n this.error(\r\n DiagnosticCode.File_0_not_found,\r\n reportNode.range, normalizedPathWithoutExtension\r\n );\r\n return;\r\n }\r\n this.compileFile(file);\r\n }\r\n\r\n /** Compiles the specified file. */\r\n compileFile(file: File): void {\r\n if (file.is(CommonFlags.COMPILED)) return;\r\n file.set(CommonFlags.COMPILED);\r\n\r\n // compile top-level statements within the file's start function\r\n var startFunction = file.startFunction;\r\n var previousBody = this.currentBody;\r\n var startFunctionBody = new Array();\r\n this.currentBody = startFunctionBody;\r\n\r\n // compile top-level statements\r\n var previousFlow = this.currentFlow;\r\n var flow = startFunction.flow;\r\n this.currentFlow = flow;\r\n for (let statements = file.source.statements, i = 0, k = statements.length; i < k; ++i) {\r\n this.compileTopLevelStatement(statements[i], startFunctionBody);\r\n }\r\n this.finishAutoreleases(flow, startFunctionBody);\r\n this.currentFlow = previousFlow;\r\n this.currentBody = previousBody;\r\n\r\n // if top-level statements are present, make the per-file start function and call it in start\r\n if (startFunctionBody.length) {\r\n let module = this.module;\r\n let locals = startFunction.localsByIndex;\r\n let numLocals = locals.length;\r\n let varTypes = new Array(numLocals);\r\n for (let i = 0; i < numLocals; ++i) varTypes[i] = locals[i].type.toNativeType();\r\n module.addFunction(\r\n startFunction.internalName,\r\n this.ensureFunctionType(startFunction.signature.parameterTypes, startFunction.signature.returnType),\r\n varTypes,\r\n startFunctionBody.length > 1\r\n ? module.block(null, startFunctionBody)\r\n : startFunctionBody[0]\r\n );\r\n previousBody.push(\r\n module.call(startFunction.internalName, null, NativeType.None)\r\n );\r\n }\r\n }\r\n\r\n // === Globals ==================================================================================\r\n\r\n compileGlobal(global: Global): bool {\r\n if (global.is(CommonFlags.COMPILED)) return true;\r\n global.set(CommonFlags.COMPILED);\r\n\r\n var module = this.module;\r\n var initExpr: ExpressionRef = 0;\r\n var initAutoreleaseSkipped: bool = false;\r\n var typeNode = global.typeNode;\r\n var initializerNode = global.initializerNode;\r\n\r\n if (!global.is(CommonFlags.RESOLVED)) {\r\n\r\n // Resolve type if annotated\r\n if (typeNode) {\r\n let resolvedType = this.resolver.resolveType(typeNode, global.parent); // reports\r\n if (!resolvedType) return false;\r\n if (resolvedType == Type.void) {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n typeNode.range\r\n );\r\n return false;\r\n }\r\n global.setType(resolvedType);\r\n\r\n // Otherwise infer type from initializer\r\n } else if (initializerNode) {\r\n let previousFlow = this.currentFlow;\r\n if (global.hasDecorator(DecoratorFlags.LAZY)) {\r\n this.currentFlow = global.file.startFunction.flow;\r\n }\r\n initExpr = this.compileExpression(initializerNode, Type.auto, // reports\r\n Constraints.MUST_WRAP | Constraints.WILL_RETAIN\r\n );\r\n if (this.skippedAutoreleases.has(initExpr)) initAutoreleaseSkipped = true;\r\n this.currentFlow = previousFlow;\r\n if (this.currentType == Type.void) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n initializerNode.range, this.currentType.toString(), \"\"\r\n );\r\n return false;\r\n }\r\n global.setType(this.currentType);\r\n\r\n // Error if there's neither a type nor an initializer\r\n } else {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n global.identifierNode.range.atEnd\r\n );\r\n return false;\r\n }\r\n }\r\n\r\n // Handle ambient builtins like '__heap_base' that need to be resolved but are added explicitly\r\n if (global.is(CommonFlags.AMBIENT) && global.hasDecorator(DecoratorFlags.BUILTIN)) {\r\n if (global.internalName == BuiltinSymbols.heap_base) this.runtimeFeatures |= RuntimeFeatures.HEAP;\r\n else if (global.internalName == BuiltinSymbols.rtti_base) this.runtimeFeatures |= RuntimeFeatures.RTTI;\r\n return true;\r\n }\r\n\r\n var type = global.type;\r\n var nativeType = type.toNativeType();\r\n var isDeclaredConstant = global.is(CommonFlags.CONST) || global.is(CommonFlags.STATIC | CommonFlags.READONLY);\r\n var isDeclaredInline = global.hasDecorator(DecoratorFlags.INLINE);\r\n\r\n // Handle imports\r\n if (global.is(CommonFlags.AMBIENT)) {\r\n\r\n // Constant global or mutable globals enabled\r\n if (isDeclaredConstant || this.options.hasFeature(Feature.MUTABLE_GLOBAL)) {\r\n global.set(CommonFlags.MODULE_IMPORT);\r\n mangleImportName(global, global.declaration);\r\n module.addGlobalImport(\r\n global.internalName,\r\n mangleImportName_moduleName,\r\n mangleImportName_elementName,\r\n nativeType\r\n );\r\n global.set(CommonFlags.COMPILED);\r\n return true;\r\n\r\n // Importing mutable globals is not supported in the MVP\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n global.declaration.range\r\n );\r\n }\r\n return false;\r\n }\r\n\r\n // The MVP does not yet support initializer expressions other than constant values (and constant\r\n // get_globals), hence such initializations must be performed in the start function for now.\r\n var initializeInStart = false;\r\n\r\n // Evaluate initializer if present\r\n if (initializerNode) {\r\n if (!initExpr) {\r\n let previousFlow = this.currentFlow;\r\n if (global.hasDecorator(DecoratorFlags.LAZY)) {\r\n this.currentFlow = global.file.startFunction.flow;\r\n }\r\n initExpr = this.compileExpression(initializerNode, type,\r\n Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP | Constraints.WILL_RETAIN | Constraints.PREFER_STATIC\r\n );\r\n if (this.skippedAutoreleases.has(initExpr)) initAutoreleaseSkipped = true;\r\n this.currentFlow = previousFlow;\r\n }\r\n\r\n if (getExpressionId(initExpr) != ExpressionId.Const) {\r\n if (isDeclaredConstant) {\r\n initExpr = module.precomputeExpression(initExpr);\r\n if (getExpressionId(initExpr) != ExpressionId.Const) initializeInStart = true;\r\n } else {\r\n initializeInStart = true;\r\n }\r\n }\r\n\r\n // Explicitly inline if annotated\r\n if (isDeclaredInline) {\r\n if (initializeInStart) {\r\n this.warning(\r\n DiagnosticCode.Mutable_value_cannot_be_inlined,\r\n initializerNode.range\r\n );\r\n } else {\r\n assert(getExpressionId(initExpr) == ExpressionId.Const);\r\n let exprType = getExpressionType(initExpr);\r\n switch (exprType) {\r\n case NativeType.I32: {\r\n global.constantValueKind = ConstantValueKind.INTEGER;\r\n global.constantIntegerValue = i64_new(getConstValueI32(initExpr), 0);\r\n break;\r\n }\r\n case NativeType.I64: {\r\n global.constantValueKind = ConstantValueKind.INTEGER;\r\n global.constantIntegerValue = i64_new(\r\n getConstValueI64Low(initExpr),\r\n getConstValueI64High(initExpr)\r\n );\r\n break;\r\n }\r\n case NativeType.F32: {\r\n global.constantValueKind = ConstantValueKind.FLOAT;\r\n global.constantFloatValue = getConstValueF32(initExpr);\r\n break;\r\n }\r\n case NativeType.F64: {\r\n global.constantValueKind = ConstantValueKind.FLOAT;\r\n global.constantFloatValue = getConstValueF64(initExpr);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n return false;\r\n }\r\n }\r\n global.set(CommonFlags.INLINED); // inline the value from now on\r\n }\r\n }\r\n\r\n // Initialize to zero if there's no initializer\r\n } else {\r\n initExpr = type.toNativeZero(module);\r\n }\r\n\r\n var internalName = global.internalName;\r\n\r\n if (initializeInStart) { // initialize to mutable zero and set the actual value in start\r\n if (isDeclaredInline) {\r\n this.error(\r\n DiagnosticCode.Decorator_0_is_not_valid_here,\r\n assert(findDecorator(DecoratorKind.INLINE, global.decoratorNodes)).range, \"inline\"\r\n );\r\n }\r\n module.addGlobal(internalName, nativeType, true, type.toNativeZero(module));\r\n if (type.isManaged && !initAutoreleaseSkipped) initExpr = this.makeRetain(initExpr);\r\n this.currentBody.push(\r\n module.global_set(internalName, initExpr)\r\n );\r\n } else if (!isDeclaredInline) { // compile normally\r\n module.addGlobal(internalName, nativeType, !isDeclaredConstant, initExpr);\r\n }\r\n return true;\r\n }\r\n\r\n // === Enums ====================================================================================\r\n\r\n compileEnum(element: Enum): bool {\r\n if (element.is(CommonFlags.COMPILED)) return true;\r\n element.set(CommonFlags.COMPILED);\r\n\r\n var module = this.module;\r\n this.currentEnum = element;\r\n var previousValue: EnumValue | null = null;\r\n var previousValueIsMut = false;\r\n var isInline = element.is(CommonFlags.CONST) || element.hasDecorator(DecoratorFlags.INLINE);\r\n\r\n if (element.members) {\r\n for (let member of element.members.values()) {\r\n if (member.kind != ElementKind.ENUMVALUE) continue; // happens if an enum is also a namespace\r\n let initInStart = false;\r\n let val = member;\r\n let valueNode = val.valueNode;\r\n val.set(CommonFlags.COMPILED);\r\n let previousFlow = this.currentFlow;\r\n if (element.hasDecorator(DecoratorFlags.LAZY)) {\r\n this.currentFlow = element.file.startFunction.flow;\r\n }\r\n let initExpr: ExpressionRef;\r\n if (valueNode) {\r\n initExpr = this.compileExpression(valueNode, Type.i32,\r\n Constraints.CONV_IMPLICIT // autorelease is not applicable in i32 context\r\n );\r\n if (getExpressionId(initExpr) != ExpressionId.Const) {\r\n initExpr = module.precomputeExpression(initExpr);\r\n if (getExpressionId(initExpr) != ExpressionId.Const) {\r\n if (element.is(CommonFlags.CONST)) {\r\n this.error(\r\n DiagnosticCode.In_const_enum_declarations_member_initializer_must_be_constant_expression,\r\n valueNode.range\r\n );\r\n }\r\n initInStart = true;\r\n }\r\n }\r\n } else if (previousValue == null) {\r\n initExpr = module.i32(0);\r\n } else {\r\n if (previousValueIsMut) {\r\n this.error(\r\n DiagnosticCode.Enum_member_must_have_initializer,\r\n (member).identifierNode.range.atEnd\r\n );\r\n }\r\n initExpr = module.binary(BinaryOp.AddI32,\r\n module.global_get(previousValue.internalName, NativeType.I32),\r\n module.i32(1)\r\n );\r\n initExpr = module.precomputeExpression(initExpr);\r\n if (getExpressionId(initExpr) != ExpressionId.Const) {\r\n if (element.is(CommonFlags.CONST)) {\r\n this.error(\r\n DiagnosticCode.In_const_enum_declarations_member_initializer_must_be_constant_expression,\r\n member.declaration.range\r\n );\r\n }\r\n initInStart = true;\r\n }\r\n }\r\n this.currentFlow = previousFlow;\r\n if (initInStart) {\r\n module.addGlobal(val.internalName, NativeType.I32, true, module.i32(0));\r\n this.currentBody.push(\r\n this.makeGlobalAssignment(val, initExpr, false)\r\n );\r\n previousValueIsMut = true;\r\n } else {\r\n if (isInline) {\r\n val.setConstantIntegerValue(i64_new(getConstValueI32(initExpr)), Type.i32);\r\n if (val.is(CommonFlags.MODULE_EXPORT)) {\r\n module.addGlobal(val.internalName, NativeType.I32, false, initExpr);\r\n }\r\n } else {\r\n module.addGlobal(val.internalName, NativeType.I32, false, initExpr);\r\n }\r\n val.isImmutable = true;\r\n previousValueIsMut = false;\r\n }\r\n previousValue = val;\r\n }\r\n }\r\n this.currentEnum = null;\r\n return true;\r\n }\r\n\r\n // === Functions ================================================================================\r\n\r\n /** Resolves the specified type arguments prior to compiling the resulting function instance. */\r\n compileFunctionUsingTypeArguments(\r\n prototype: FunctionPrototype,\r\n typeArguments: TypeNode[],\r\n contextualTypeArguments: Map = makeMap(),\r\n alternativeReportNode: Node | null = null\r\n ): Function | null {\r\n if (prototype.hasDecorator(DecoratorFlags.BUILTIN)) return null;\r\n var instance = this.resolver.resolveFunctionInclTypeArguments(\r\n prototype,\r\n typeArguments,\r\n prototype.parent, // relative to itself\r\n contextualTypeArguments,\r\n alternativeReportNode || prototype.declaration\r\n );\r\n if (!instance) return null;\r\n if (!this.compileFunction(instance)) return null; // reports\r\n return instance;\r\n }\r\n\r\n /** Either reuses or creates the function type matching the specified signature. */\r\n ensureFunctionType(\r\n parameterTypes: Type[] | null,\r\n returnType: Type,\r\n thisType: Type | null = null\r\n ): FunctionTypeRef {\r\n var numParameters = parameterTypes ? parameterTypes.length : 0;\r\n var paramTypes: NativeType[];\r\n var index = 0;\r\n if (thisType) {\r\n paramTypes = new Array(1 + numParameters);\r\n paramTypes[0] = thisType.toNativeType();\r\n index = 1;\r\n } else {\r\n paramTypes = new Array(numParameters);\r\n }\r\n if (parameterTypes) {\r\n for (let i = 0; i < numParameters; ++i, ++index) {\r\n paramTypes[index] = parameterTypes[i].toNativeType();\r\n }\r\n }\r\n var resultType = returnType.toNativeType();\r\n var module = this.module;\r\n var typeRef = module.getFunctionTypeBySignature(resultType, paramTypes);\r\n if (!typeRef) {\r\n let name = Signature.makeSignatureString(parameterTypes, returnType, thisType);\r\n typeRef = module.addFunctionType(name, resultType, paramTypes);\r\n }\r\n return typeRef;\r\n }\r\n\r\n /** Compiles the body of a function within the specified flow. */\r\n compileFunctionBody(\r\n /** Function to compile. */\r\n instance: Function,\r\n /** Target array of statements. */\r\n stmts: ExpressionRef[] | null = null\r\n ): ExpressionRef[] {\r\n var module = this.module;\r\n var bodyNode = assert(instance.prototype.bodyNode);\r\n var returnType = instance.signature.returnType;\r\n var flow = this.currentFlow;\r\n\r\n // compile statements\r\n if (bodyNode.kind == NodeKind.BLOCK) {\r\n stmts = this.compileStatements((bodyNode).statements, true, stmts);\r\n } else {\r\n // must be an expression statement if not a block\r\n assert(bodyNode.kind == NodeKind.EXPRESSION);\r\n\r\n // must be an arrow function\r\n assert(instance.prototype.arrowKind);\r\n\r\n // none of the following can be an arrow function\r\n assert(!instance.isAny(CommonFlags.CONSTRUCTOR | CommonFlags.GET | CommonFlags.SET | CommonFlags.MAIN));\r\n\r\n let expr = this.compileExpression((bodyNode).expression, returnType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n if (!stmts) stmts = [ expr ];\r\n else stmts.push(expr);\r\n if (!flow.is(FlowFlags.TERMINATES)) { // TODO: detect if returning an autorelease local?\r\n let indexBefore = stmts.length;\r\n this.performAutoreleases(flow, stmts);\r\n this.finishAutoreleases(flow, stmts);\r\n let canOverflow = flow.canOverflow(expr, returnType);\r\n let nonNull = flow.isNonnull(expr, returnType);\r\n if (stmts.length > indexBefore) {\r\n let temp = flow.getAndFreeTempLocal(returnType);\r\n if (!canOverflow) flow.setLocalFlag(temp.index, LocalFlags.WRAPPED);\r\n if (nonNull) flow.setLocalFlag(temp.index, LocalFlags.NONNULL);\r\n stmts[indexBefore - 1] = module.local_set(temp.index, expr);\r\n stmts.push(module.local_get(temp.index, returnType.toNativeType()));\r\n }\r\n if (!canOverflow) flow.set(FlowFlags.RETURNS_WRAPPED);\r\n if (nonNull) flow.set(FlowFlags.RETURNS_NONNULL);\r\n flow.set(FlowFlags.RETURNS | FlowFlags.TERMINATES);\r\n }\r\n }\r\n\r\n // make constructors return their instance pointer\r\n if (instance.is(CommonFlags.CONSTRUCTOR)) {\r\n let nativeSizeType = this.options.nativeSizeType;\r\n assert(instance.is(CommonFlags.INSTANCE));\r\n let classInstance = assert(instance.parent); assert(classInstance.kind == ElementKind.CLASS);\r\n\r\n if (!flow.is(FlowFlags.TERMINATES)) {\r\n let thisLocal = assert(flow.lookupLocal(CommonSymbols.this_));\r\n\r\n // if `this` wasn't accessed before, allocate if necessary and initialize `this`\r\n if (!flow.is(FlowFlags.ALLOCATES)) {\r\n // {\r\n // if (!this) this = \r\n // this.a = X\r\n // this.b = Y\r\n // }\r\n stmts.push(\r\n module.if(\r\n module.unary(nativeSizeType == NativeType.I64 ? UnaryOp.EqzI64 : UnaryOp.EqzI32,\r\n module.local_get(thisLocal.index, nativeSizeType)\r\n ),\r\n module.local_set(thisLocal.index,\r\n this.makeRetain(\r\n this.makeAllocation(classInstance)\r\n ),\r\n )\r\n )\r\n );\r\n this.makeFieldInitialization(classInstance, stmts);\r\n }\r\n this.performAutoreleases(flow, stmts); // `this` is excluded anyway\r\n this.finishAutoreleases(flow, stmts);\r\n stmts.push(module.local_get(thisLocal.index, this.options.nativeSizeType));\r\n flow.set(FlowFlags.RETURNS | FlowFlags.RETURNS_NONNULL | FlowFlags.TERMINATES);\r\n }\r\n\r\n // check that super has been called if this is a derived class\r\n if ((classInstance).base && !flow.is(FlowFlags.CALLS_SUPER)) {\r\n this.error(\r\n DiagnosticCode.Constructors_for_derived_classes_must_contain_a_super_call,\r\n instance.prototype.declaration.range\r\n );\r\n }\r\n\r\n // if this is a normal function, make sure that all branches terminate\r\n } else if (returnType != Type.void && !flow.is(FlowFlags.TERMINATES)) {\r\n this.error(\r\n DiagnosticCode.A_function_whose_declared_type_is_not_void_must_return_a_value,\r\n instance.prototype.signatureNode.returnType.range\r\n );\r\n }\r\n\r\n return stmts;\r\n }\r\n\r\n /** Compiles a readily resolved function instance. */\r\n compileFunction(instance: Function): bool {\r\n if (instance.is(CommonFlags.COMPILED)) return true;\r\n assert(!(instance.is(CommonFlags.AMBIENT) && instance.hasDecorator(DecoratorFlags.BUILTIN)));\r\n\r\n var previousType = this.currentType; // remember to retain it if compiling a function lazily\r\n instance.set(CommonFlags.COMPILED);\r\n\r\n var module = this.module;\r\n var signature = instance.signature;\r\n var bodyNode = instance.prototype.bodyNode;\r\n\r\n var typeRef = this.ensureFunctionType(signature.parameterTypes, signature.returnType, signature.thisType);\r\n var funcRef: FunctionRef;\r\n\r\n // concrete function\r\n if (bodyNode) {\r\n\r\n // must not be ambient\r\n if (instance.is(CommonFlags.AMBIENT)) {\r\n this.error(\r\n DiagnosticCode.An_implementation_cannot_be_declared_in_ambient_contexts,\r\n instance.identifierNode.range\r\n );\r\n }\r\n\r\n // cannot have an annotated external name\r\n if (instance.hasDecorator(DecoratorFlags.EXTERNAL)) {\r\n let decoratorNodes = instance.decoratorNodes;\r\n let decorator = assert(findDecorator(DecoratorKind.EXTERNAL, decoratorNodes));\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n decorator.range\r\n );\r\n }\r\n\r\n // compile body in this function's context\r\n let previousFlow = this.currentFlow;\r\n let flow = instance.flow;\r\n this.currentFlow = flow;\r\n let stmts = new Array();\r\n\r\n // retain each argument for as long as the function lives\r\n let index = 0;\r\n let thisType = signature.thisType;\r\n if (thisType) {\r\n // No need to retain `this` as it can't be reassigned and thus can't become prematurely released\r\n ++index;\r\n }\r\n let parameterTypes = signature.parameterTypes;\r\n for (let i = 0, k = parameterTypes.length; i < k; ++i, ++index) {\r\n let type = parameterTypes[i];\r\n if (type.isManaged) {\r\n stmts.push(\r\n module.drop(\r\n this.makeRetain(\r\n module.local_get(index, type.toNativeType())\r\n )\r\n )\r\n );\r\n flow.setLocalFlag(index, LocalFlags.RETAINED);\r\n }\r\n }\r\n\r\n this.compileFunctionBody(instance, stmts);\r\n if (!flow.is(FlowFlags.TERMINATES)) {\r\n this.performAutoreleases(flow, stmts);\r\n this.finishAutoreleases(flow, stmts);\r\n }\r\n this.currentFlow = previousFlow;\r\n\r\n // create the function\r\n funcRef = module.addFunction(\r\n instance.internalName,\r\n typeRef,\r\n typesToNativeTypes(instance.additionalLocals),\r\n flatten(module, stmts, instance.signature.returnType.toNativeType())\r\n );\r\n\r\n // imported function\r\n } else {\r\n if (!instance.is(CommonFlags.AMBIENT)) {\r\n this.error(\r\n DiagnosticCode.Function_implementation_is_missing_or_not_immediately_following_the_declaration,\r\n instance.identifierNode.range\r\n );\r\n }\r\n\r\n instance.set(CommonFlags.MODULE_IMPORT);\r\n mangleImportName(instance, instance.declaration); // TODO: check for duplicates\r\n\r\n // create the import\r\n funcRef = module.addFunctionImport(\r\n instance.internalName,\r\n mangleImportName_moduleName,\r\n mangleImportName_elementName,\r\n typeRef\r\n );\r\n }\r\n\r\n instance.finalize(module, funcRef);\r\n this.currentType = previousType;\r\n return true;\r\n }\r\n\r\n // === Classes ==================================================================================\r\n\r\n compileClassUsingTypeArguments(\r\n prototype: ClassPrototype,\r\n typeArguments: TypeNode[],\r\n contextualTypeArguments: Map = makeMap(),\r\n alternativeReportNode: Node | null = null\r\n ): void {\r\n var instance = this.resolver.resolveClassInclTypeArguments(\r\n prototype,\r\n typeArguments,\r\n prototype.parent, // relative to itself\r\n contextualTypeArguments,\r\n alternativeReportNode || prototype.declaration\r\n );\r\n if (!instance) return;\r\n this.compileClass(instance);\r\n }\r\n\r\n compileClass(instance: Class): bool {\r\n if (instance.is(CommonFlags.COMPILED)) return true;\r\n instance.set(CommonFlags.COMPILED);\r\n var prototype = instance.prototype;\r\n var staticMembers = (prototype).members;\r\n if (staticMembers) {\r\n for (let element of staticMembers.values()) {\r\n switch (element.kind) {\r\n case ElementKind.GLOBAL: {\r\n this.compileGlobal(element);\r\n break;\r\n }\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n if (\r\n !(element).is(CommonFlags.GENERIC)\r\n ) {\r\n this.compileFunctionUsingTypeArguments(\r\n element,\r\n [],\r\n makeMap(),\r\n (element).identifierNode\r\n );\r\n }\r\n break;\r\n }\r\n case ElementKind.PROPERTY_PROTOTYPE: {\r\n let getter = (element).getterPrototype;\r\n if (getter) {\r\n this.compileFunctionUsingTypeArguments(\r\n getter,\r\n [],\r\n makeMap(),\r\n getter.identifierNode\r\n );\r\n }\r\n let setter = (element).setterPrototype;\r\n if (setter) {\r\n this.compileFunctionUsingTypeArguments(\r\n setter,\r\n [],\r\n makeMap(),\r\n setter.identifierNode\r\n );\r\n }\r\n break;\r\n }\r\n case ElementKind.PROPERTY: {\r\n }\r\n }\r\n }\r\n }\r\n var ctorInstance = instance.constructorInstance;\r\n if (ctorInstance) this.compileFunction(ctorInstance);\r\n var instanceMembers = instance.members;\r\n if (instanceMembers) {\r\n for (let element of instanceMembers.values()) {\r\n switch (element.kind) {\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n if (\r\n !(element).is(CommonFlags.GENERIC)\r\n ) {\r\n this.compileFunctionUsingTypeArguments(\r\n element,\r\n [],\r\n makeMap(instance.contextualTypeArguments),\r\n (element).declaration.name\r\n );\r\n }\r\n break;\r\n }\r\n case ElementKind.FIELD_PROTOTYPE: {\r\n element.set(CommonFlags.COMPILED);\r\n break;\r\n }\r\n case ElementKind.PROPERTY: {\r\n let getter = (element).getterInstance;\r\n if (getter) this.compileFunction(getter);\r\n let setter = (element).setterInstance;\r\n if (setter) this.compileFunction(setter);\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n return true;\r\n }\r\n\r\n compileInterfaceDeclaration(\r\n declaration: InterfaceDeclaration,\r\n typeArguments: TypeNode[],\r\n contextualTypeArguments: Map | null = null,\r\n alternativeReportNode: Node | null = null\r\n ): void {\r\n // TODO\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n declaration.range\r\n );\r\n }\r\n\r\n // === Memory ===================================================================================\r\n\r\n /** Adds a static memory segment with the specified data. */\r\n addMemorySegment(buffer: Uint8Array, alignment: i32 = 8): MemorySegment {\r\n var memoryOffset = i64_align(this.memoryOffset, alignment);\r\n var segment = MemorySegment.create(buffer, memoryOffset);\r\n this.memorySegments.push(segment);\r\n this.memoryOffset = i64_add(memoryOffset, i64_new(buffer.length, 0));\r\n return segment;\r\n }\r\n\r\n /** Ensures that the specified string exists in static memory and returns a pointer to it. */\r\n ensureStaticString(stringValue: string): ExpressionRef {\r\n var program = this.program;\r\n var rtHeaderSize = program.runtimeHeaderSize;\r\n var stringInstance = assert(program.stringInstance);\r\n var stringSegment: MemorySegment;\r\n var segments = this.stringSegments;\r\n if (segments.has(stringValue)) {\r\n stringSegment = segments.get(stringValue)!; // reuse\r\n } else {\r\n let length = stringValue.length;\r\n let buffer = new Uint8Array(rtHeaderSize + (length << 1));\r\n program.writeRuntimeHeader(buffer, 0, stringInstance, length << 1);\r\n for (let i = 0; i < length; ++i) {\r\n writeI16(stringValue.charCodeAt(i), buffer, rtHeaderSize + (i << 1));\r\n }\r\n stringSegment = this.addMemorySegment(buffer);\r\n segments.set(stringValue, stringSegment);\r\n }\r\n var ref = i64_add(stringSegment.offset, i64_new(rtHeaderSize));\r\n this.currentType = stringInstance.type;\r\n if (this.options.isWasm64) {\r\n return this.module.i64(i64_low(ref), i64_high(ref));\r\n } else {\r\n assert(i64_is_u32(ref));\r\n return this.module.i32(i64_low(ref));\r\n }\r\n }\r\n\r\n ensureStaticArrayBuffer(elementType: Type, values: ExpressionRef[]): MemorySegment {\r\n var program = this.program;\r\n var length = values.length;\r\n var byteSize = elementType.byteSize;\r\n var byteLength = length * byteSize;\r\n var bufferInstance = assert(program.arrayBufferInstance);\r\n var runtimeHeaderSize = program.runtimeHeaderSize;\r\n\r\n var buf = new Uint8Array(runtimeHeaderSize + byteLength);\r\n program.writeRuntimeHeader(buf, 0, bufferInstance, byteLength);\r\n var pos = runtimeHeaderSize;\r\n var nativeType = elementType.toNativeType();\r\n switch (nativeType) {\r\n case NativeType.I32: {\r\n switch (byteSize) {\r\n case 1: {\r\n for (let i = 0; i < length; ++i) {\r\n let value = values[i];\r\n assert(getExpressionType(value) == nativeType);\r\n assert(getExpressionId(value) == ExpressionId.Const);\r\n writeI8(getConstValueI32(value), buf, pos);\r\n pos += 1;\r\n }\r\n break;\r\n }\r\n case 2: {\r\n for (let i = 0; i < length; ++i) {\r\n let value = values[i];\r\n assert(getExpressionType(value) == nativeType);\r\n assert(getExpressionId(value) == ExpressionId.Const);\r\n writeI16(getConstValueI32(value), buf, pos);\r\n pos += 2;\r\n }\r\n break;\r\n }\r\n case 4: {\r\n for (let i = 0; i < length; ++i) {\r\n let value = values[i];\r\n assert(getExpressionType(value) == nativeType);\r\n assert(getExpressionId(value) == ExpressionId.Const);\r\n writeI32(getConstValueI32(value), buf, pos);\r\n pos += 4;\r\n }\r\n break;\r\n }\r\n default: assert(false);\r\n }\r\n break;\r\n }\r\n case NativeType.I64: {\r\n for (let i = 0; i < length; ++i) {\r\n let value = values[i];\r\n assert(getExpressionType(value) == nativeType);\r\n assert(getExpressionId(value) == ExpressionId.Const);\r\n writeI64(i64_new(getConstValueI64Low(value), getConstValueI64High(value)), buf, pos);\r\n pos += 8;\r\n }\r\n break;\r\n }\r\n case NativeType.F32: {\r\n for (let i = 0; i < length; ++i) {\r\n let value = values[i];\r\n assert(getExpressionType(value) == nativeType);\r\n assert(getExpressionId(value) == ExpressionId.Const);\r\n writeF32(getConstValueF32(value), buf, pos);\r\n pos += 4;\r\n }\r\n break;\r\n }\r\n case NativeType.F64: {\r\n for (let i = 0; i < length; ++i) {\r\n let value = values[i];\r\n assert(getExpressionType(value) == nativeType);\r\n assert(getExpressionId(value) == ExpressionId.Const);\r\n writeF64(getConstValueF64(value), buf, pos);\r\n pos += 8;\r\n }\r\n break;\r\n }\r\n default: assert(false);\r\n }\r\n assert(pos == buf.length);\r\n\r\n return this.addMemorySegment(buf);\r\n }\r\n\r\n ensureStaticArrayHeader(elementType: Type, bufferSegment: MemorySegment): MemorySegment {\r\n var program = this.program;\r\n var runtimeHeaderSize = program.runtimeHeaderSize;\r\n var arrayPrototype = assert(program.arrayPrototype);\r\n var arrayInstance = assert(this.resolver.resolveClass(arrayPrototype, [ elementType ]));\r\n var arrayInstanceSize = arrayInstance.currentMemoryOffset;\r\n var bufferLength = bufferSegment.buffer.length - runtimeHeaderSize;\r\n var arrayLength = i32(bufferLength / elementType.byteSize);\r\n\r\n var buf = new Uint8Array(runtimeHeaderSize + arrayInstanceSize);\r\n program.writeRuntimeHeader(buf, 0, arrayInstance, arrayInstanceSize);\r\n\r\n var bufferAddress32 = i64_low(bufferSegment.offset) + runtimeHeaderSize;\r\n assert(!program.options.isWasm64); // TODO\r\n assert(arrayInstance.writeField(\"data\", bufferAddress32, buf, runtimeHeaderSize));\r\n assert(arrayInstance.writeField(\"dataStart\", bufferAddress32, buf, runtimeHeaderSize));\r\n assert(arrayInstance.writeField(\"dataLength\", bufferLength, buf, runtimeHeaderSize));\r\n assert(arrayInstance.writeField(\"length_\", arrayLength, buf, runtimeHeaderSize));\r\n\r\n return this.addMemorySegment(buf);\r\n }\r\n\r\n // === Table ====================================================================================\r\n\r\n /** Ensures that a table entry exists for the specified function and returns its index. */\r\n ensureFunctionTableEntry(func: Function): i32 {\r\n assert(func.is(CommonFlags.COMPILED));\r\n if (func.functionTableIndex >= 0) {\r\n return func.functionTableIndex;\r\n }\r\n var functionTable = this.functionTable;\r\n var index = functionTable.length;\r\n if (!func.is(CommonFlags.TRAMPOLINE) && func.signature.requiredParameters < func.signature.parameterTypes.length) {\r\n // insert the trampoline if the function has optional parameters\r\n func = this.ensureTrampoline(func);\r\n }\r\n functionTable.push(func.internalName);\r\n func.functionTableIndex = index;\r\n return index;\r\n }\r\n\r\n // === Statements ===============================================================================\r\n\r\n compileTopLevelStatement(statement: Statement, body: ExpressionRef[]): void {\r\n if (statement.kind == NodeKind.EXPORTDEFAULT) {\r\n statement = (statement).declaration;\r\n }\r\n switch (statement.kind) {\r\n case NodeKind.CLASSDECLARATION: {\r\n let memberStatements = (statement).members;\r\n for (let i = 0, k = memberStatements.length; i < k; ++i) {\r\n this.compileTopLevelStatement(memberStatements[i], body);\r\n }\r\n break;\r\n }\r\n case NodeKind.ENUMDECLARATION: {\r\n let element = this.program.getElementByDeclaration(statement);\r\n assert(element.kind == ElementKind.ENUM);\r\n if (!element.hasDecorator(DecoratorFlags.LAZY)) this.compileEnum(element);\r\n break;\r\n }\r\n case NodeKind.NAMESPACEDECLARATION: {\r\n let memberStatements = (statement).members;\r\n for (let i = 0, k = memberStatements.length; i < k; ++i) {\r\n this.compileTopLevelStatement(memberStatements[i], body);\r\n }\r\n break;\r\n }\r\n case NodeKind.VARIABLE: {\r\n let declarations = (statement).declarations;\r\n for (let i = 0, k = declarations.length; i < k; ++i) {\r\n let element = this.program.getElementByDeclaration(declarations[i]);\r\n assert(element.kind == ElementKind.GLOBAL);\r\n if (\r\n !element.is(CommonFlags.AMBIENT) && // delay imports\r\n !element.hasDecorator(DecoratorFlags.LAZY)\r\n ) this.compileGlobal(element);\r\n }\r\n break;\r\n }\r\n case NodeKind.FIELDDECLARATION: {\r\n let element = this.program.getElementByDeclaration(statement);\r\n if (element.kind == ElementKind.GLOBAL) { // static\r\n if (!element.hasDecorator(DecoratorFlags.LAZY)) this.compileGlobal(element);\r\n }\r\n break;\r\n }\r\n case NodeKind.EXPORT: {\r\n if ((statement).normalizedPath != null) {\r\n this.compileFileByPath(\r\n (statement).normalizedPath,\r\n (statement).path\r\n );\r\n }\r\n break;\r\n }\r\n case NodeKind.IMPORT: {\r\n this.compileFileByPath(\r\n (statement).normalizedPath,\r\n (statement).path\r\n );\r\n break;\r\n }\r\n case NodeKind.FUNCTIONDECLARATION:\r\n case NodeKind.METHODDECLARATION:\r\n case NodeKind.INTERFACEDECLARATION:\r\n case NodeKind.INDEXSIGNATUREDECLARATION:\r\n case NodeKind.TYPEDECLARATION: break;\r\n default: { // otherwise a top-level statement that is part of the start function's body\r\n let stmt = this.compileStatement(statement);\r\n if (getExpressionId(stmt) != ExpressionId.Nop) body.push(stmt);\r\n break;\r\n }\r\n }\r\n }\r\n\r\n compileStatement(\r\n statement: Statement,\r\n isLastInBody: bool = false\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var stmt: ExpressionRef;\r\n switch (statement.kind) {\r\n case NodeKind.BLOCK: {\r\n stmt = this.compileBlockStatement(statement);\r\n break;\r\n }\r\n case NodeKind.BREAK: {\r\n stmt = this.compileBreakStatement(statement);\r\n break;\r\n }\r\n case NodeKind.CONTINUE: {\r\n stmt = this.compileContinueStatement(statement);\r\n break;\r\n }\r\n case NodeKind.DO: {\r\n stmt = this.compileDoStatement(statement);\r\n break;\r\n }\r\n case NodeKind.EMPTY: {\r\n stmt = this.compileEmptyStatement(statement);\r\n break;\r\n }\r\n case NodeKind.EXPRESSION: {\r\n stmt = this.compileExpressionStatement(statement);\r\n break;\r\n }\r\n case NodeKind.FOR: {\r\n stmt = this.compileForStatement(statement);\r\n break;\r\n }\r\n case NodeKind.IF: {\r\n stmt = this.compileIfStatement(statement);\r\n break;\r\n }\r\n case NodeKind.RETURN: {\r\n stmt = this.compileReturnStatement(statement, isLastInBody);\r\n break;\r\n }\r\n case NodeKind.SWITCH: {\r\n stmt = this.compileSwitchStatement(statement);\r\n break;\r\n }\r\n case NodeKind.THROW: {\r\n stmt = this.compileThrowStatement(statement);\r\n break;\r\n }\r\n case NodeKind.TRY: {\r\n stmt = this.compileTryStatement(statement);\r\n break;\r\n }\r\n case NodeKind.VARIABLE: {\r\n stmt = this.compileVariableStatement(statement);\r\n if (!stmt) stmt = module.nop();\r\n break;\r\n }\r\n case NodeKind.VOID: {\r\n stmt = this.compileVoidStatement(statement);\r\n break;\r\n }\r\n case NodeKind.WHILE: {\r\n stmt = this.compileWhileStatement(statement);\r\n break;\r\n }\r\n case NodeKind.TYPEDECLARATION: {\r\n // TODO: integrate inner type declaration into flow\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n statement.range\r\n );\r\n stmt = module.unreachable();\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n stmt = module.unreachable();\r\n }\r\n }\r\n if (this.options.sourceMap) this.addDebugLocation(stmt, statement.range);\r\n return stmt;\r\n }\r\n\r\n compileStatements(\r\n statements: Statement[],\r\n isBody: bool = false,\r\n stmts: ExpressionRef[] | null = null\r\n ): ExpressionRef[] {\r\n var numStatements = statements.length;\r\n if (!stmts) {\r\n stmts = new Array(numStatements);\r\n stmts.length = 0;\r\n }\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n for (let i = 0; i < numStatements; ++i) {\r\n let stmt = this.compileStatement(statements[i], isBody && i == numStatements - 1);\r\n switch (getExpressionId(stmt)) {\r\n case ExpressionId.Block: {\r\n if (!getBlockName(stmt)) {\r\n for (let j = 0, k = getBlockChildCount(stmt); j < k; ++j) stmts.push(getBlockChild(stmt, j));\r\n break;\r\n }\r\n // fall-through\r\n }\r\n default: stmts.push(stmt);\r\n case ExpressionId.Nop:\r\n }\r\n if (flow.isAny(FlowFlags.TERMINATES | FlowFlags.BREAKS)) {\r\n if (needsExplicitUnreachable(stmt)) stmts.push(module.unreachable());\r\n break;\r\n }\r\n }\r\n return stmts;\r\n }\r\n\r\n compileBlockStatement(\r\n statement: BlockStatement\r\n ): ExpressionRef {\r\n var statements = statement.statements;\r\n var outerFlow = this.currentFlow;\r\n var innerFlow = outerFlow.fork();\r\n this.currentFlow = innerFlow;\r\n\r\n var stmts = this.compileStatements(statements);\r\n if (!innerFlow.isAny(FlowFlags.TERMINATES | FlowFlags.BREAKS)) this.performAutoreleases(innerFlow, stmts);\r\n innerFlow.freeScopedLocals();\r\n outerFlow.inherit(innerFlow); // TODO: only if not terminated?\r\n this.currentFlow = outerFlow;\r\n return flatten(this.module, stmts, NativeType.None);\r\n }\r\n\r\n compileBreakStatement(\r\n statement: BreakStatement\r\n ): ExpressionRef {\r\n var module = this.module;\r\n if (statement.label) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n statement.label.range\r\n );\r\n return module.unreachable();\r\n }\r\n var flow = this.currentFlow;\r\n var breakLabel = flow.breakLabel;\r\n if (breakLabel == null) {\r\n this.error(\r\n DiagnosticCode.A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement,\r\n statement.range\r\n );\r\n return module.unreachable();\r\n }\r\n var stmts = new Array();\r\n this.performAutoreleases(flow, stmts);\r\n var parent = flow.parent;\r\n while (parent !== null && parent.breakLabel == breakLabel) {\r\n this.performAutoreleases(parent, stmts, /* clearFlags */ false);\r\n parent = parent.parent;\r\n }\r\n flow.freeScopedLocals();\r\n stmts.push(module.br(breakLabel));\r\n flow.set(FlowFlags.BREAKS);\r\n return flatten(module, stmts, NativeType.None);\r\n }\r\n\r\n compileContinueStatement(\r\n statement: ContinueStatement\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var label = statement.label;\r\n if (label) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n label.range\r\n );\r\n return module.unreachable();\r\n }\r\n // Check if 'continue' is allowed here\r\n var flow = this.currentFlow;\r\n var continueLabel = flow.continueLabel;\r\n if (continueLabel == null) {\r\n this.error(\r\n DiagnosticCode.A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement,\r\n statement.range\r\n );\r\n return module.unreachable();\r\n }\r\n flow.set(FlowFlags.CONTINUES | FlowFlags.TERMINATES);\r\n var stmts = new Array();\r\n this.performAutoreleases(flow, stmts);\r\n var current: Flow | null = flow.parent;\r\n while (current && current.continueLabel === continueLabel) {\r\n this.performAutoreleases(current, stmts, /* clearFlags */ false);\r\n current = current.parent;\r\n }\r\n flow.freeScopedLocals();\r\n stmts.push(module.br(continueLabel));\r\n return flatten(module, stmts, NativeType.None);\r\n }\r\n\r\n compileDoStatement(\r\n statement: DoStatement\r\n ): ExpressionRef {\r\n var module = this.module;\r\n\r\n var outerFlow = this.currentFlow;\r\n var label = outerFlow.pushBreakLabel();\r\n var innerFlow = outerFlow.fork();\r\n this.currentFlow = innerFlow;\r\n var breakLabel = \"break|\" + label;\r\n innerFlow.breakLabel = breakLabel;\r\n var continueLabel = \"continue|\" + label;\r\n innerFlow.continueLabel = continueLabel;\r\n\r\n var stmts = new Array();\r\n if (statement.statement.kind == NodeKind.BLOCK) {\r\n this.compileStatements((statement.statement).statements, false, stmts);\r\n } else {\r\n stmts.push(\r\n this.compileStatement(statement.statement)\r\n );\r\n }\r\n var condExpr = module.precomputeExpression(\r\n this.makeIsTrueish(\r\n this.compileExpression(statement.condition, Type.i32),\r\n this.currentType\r\n )\r\n );\r\n var alwaysFalse = false;\r\n if (getExpressionId(condExpr) == ExpressionId.Const) {\r\n assert(getExpressionType(condExpr) == NativeType.I32);\r\n if (!getConstValueI32(condExpr)) alwaysFalse = true;\r\n }\r\n var terminates = innerFlow.is(FlowFlags.TERMINATES);\r\n var continues = innerFlow.isAny(FlowFlags.CONTINUES | FlowFlags.CONDITIONALLY_CONTINUES);\r\n var breaks = innerFlow.isAny(FlowFlags.BREAKS | FlowFlags.CONDITIONALLY_BREAKS);\r\n\r\n // (block $break ;; (1) skip if no breaks\r\n // (loop $continue ;; (2) skip if skipping (4) + no continues\r\n // (...) ;; (3)\r\n // (br_if cond $continue) ;; (4) skip if (3) does not fall through or always false\r\n // )\r\n // )\r\n var fallsThrough = !terminates && !innerFlow.is(FlowFlags.BREAKS);\r\n\r\n if (fallsThrough && !alwaysFalse) { // (4)\r\n stmts.push(module.br(continueLabel, condExpr));\r\n }\r\n var expr = flatten(module, stmts, NativeType.None);\r\n if (fallsThrough && !alwaysFalse || continues) { // (2)\r\n expr = module.loop(continueLabel, expr);\r\n }\r\n if (breaks) { // (1)\r\n expr = module.block(breakLabel, [ expr ]);\r\n }\r\n\r\n // Switch back to the parent flow\r\n if (!terminates) this.performAutoreleases(innerFlow, stmts);\r\n innerFlow.freeScopedLocals();\r\n outerFlow.popBreakLabel();\r\n innerFlow.unset(\r\n FlowFlags.BREAKS |\r\n FlowFlags.CONDITIONALLY_BREAKS |\r\n FlowFlags.CONTINUES |\r\n FlowFlags.CONDITIONALLY_CONTINUES\r\n );\r\n outerFlow.inherit(innerFlow);\r\n this.currentFlow = outerFlow;\r\n return expr;\r\n }\r\n\r\n compileEmptyStatement(\r\n statement: EmptyStatement\r\n ): ExpressionRef {\r\n return this.module.nop();\r\n }\r\n\r\n compileExpressionStatement(\r\n statement: ExpressionStatement\r\n ): ExpressionRef {\r\n return this.compileExpression(statement.expression, Type.void, Constraints.CONV_IMPLICIT);\r\n }\r\n\r\n compileForStatement(\r\n statement: ForStatement\r\n ): ExpressionRef {\r\n var module = this.module;\r\n\r\n // Set up and use the inner flow\r\n var outerFlow = this.currentFlow;\r\n var label = outerFlow.pushBreakLabel();\r\n var innerFlow = outerFlow.fork();\r\n this.currentFlow = innerFlow;\r\n\r\n // Compile the initializer\r\n var initializer = statement.initializer;\r\n var initExpr: ExpressionRef = 0;\r\n if (initializer) initExpr = this.compileStatement(initializer);\r\n\r\n // Compile the condition\r\n var condExpr: ExpressionRef = 0;\r\n var alwaysTrue = false;\r\n if (statement.condition) {\r\n condExpr = module.precomputeExpression(\r\n this.makeIsTrueish(\r\n this.compileExpression(statement.condition, Type.bool),\r\n this.currentType\r\n )\r\n );\r\n // Simplify if the condition is constant\r\n if (getExpressionId(condExpr) == ExpressionId.Const) {\r\n assert(getExpressionType(condExpr) == NativeType.I32);\r\n if (getConstValueI32(condExpr) == /* false */ 0) {\r\n let stmts = new Array();\r\n if (initExpr) stmts.push(initExpr);\r\n this.performAutoreleases(innerFlow, stmts);\r\n innerFlow.freeScopedLocals();\r\n outerFlow.popBreakLabel();\r\n this.currentFlow = outerFlow;\r\n return flatten(module, stmts, NativeType.None);\r\n }\r\n alwaysTrue = true;\r\n }\r\n } else { // Omitted condition is always true\r\n condExpr = module.i32(1);\r\n alwaysTrue = true;\r\n }\r\n innerFlow.inheritNonnullIfTrue(condExpr);\r\n\r\n // Compile incrementor\r\n var incrementor = statement.incrementor;\r\n var incrExpr: ExpressionRef = 0;\r\n if (incrementor) incrExpr = this.compileExpression(incrementor, Type.void, Constraints.CONV_IMPLICIT | Constraints.WILL_DROP);\r\n\r\n // Compile body (break: drop out, continue: fall through to incrementor, + loop)\r\n var breakLabel = innerFlow.breakLabel = \"break|\" + label; innerFlow.breakLabel = breakLabel;\r\n innerFlow.breakLabel = breakLabel;\r\n var continueLabel = \"continue|\" + label;\r\n innerFlow.continueLabel = continueLabel;\r\n var loopLabel = \"loop|\" + label;\r\n var bodyStatement = statement.statement;\r\n var stmts = new Array();\r\n if (bodyStatement.kind == NodeKind.BLOCK) {\r\n this.compileStatements((bodyStatement).statements, false, stmts);\r\n } else {\r\n stmts.push(this.compileStatement(bodyStatement));\r\n }\r\n var terminates = innerFlow.is(FlowFlags.TERMINATES);\r\n var continues = innerFlow.isAny(FlowFlags.CONTINUES | FlowFlags.CONDITIONALLY_CONTINUES);\r\n var breaks = innerFlow.isAny(FlowFlags.BREAKS | FlowFlags.CONDITIONALLY_BREAKS);\r\n\r\n // (block $break ;; (1) skip label (needed anyway) if skipping (4) + no breaks\r\n // (initializer) ;; (2) [may be empty]\r\n // (loop $loop ;; (3) skip if (6) does not fall through + no continues\r\n // (br_if !cond $break) ;; (4) skip if always true\r\n // (block $continue ;; (5) skip if no continues or nothing else than continue\r\n // (...) ;; (6)\r\n // )\r\n // (incrementor) ;; (7) skip if skipping (3) [may be empty]\r\n // (br $loop) ;; (8) skip if skipping (3)\r\n // )\r\n // )\r\n var fallsThrough = !terminates && !innerFlow.is(FlowFlags.BREAKS);\r\n var needsLabel = !alwaysTrue || breaks;\r\n\r\n var loop = new Array();\r\n if (!alwaysTrue) { // (4)\r\n loop.push(module.br(breakLabel, module.unary(UnaryOp.EqzI32, condExpr)));\r\n }\r\n if (continues) { // (5)\r\n if (stmts.length > 1 || getExpressionId(stmts[0]) != ExpressionId.Break) { // otherwise lonely continue\r\n loop.push(module.block(continueLabel, stmts));\r\n }\r\n } else {\r\n for (let i = 0, k = stmts.length; i < k; ++i) loop.push(stmts[i]);\r\n }\r\n var expr: ExpressionRef;\r\n if (fallsThrough || continues) { // (3)\r\n if (incrExpr) loop.push(incrExpr); // (7)\r\n this.performAutoreleases(innerFlow, loop);\r\n loop.push(module.br(loopLabel)); // (8)\r\n if (initExpr) { // (2)\r\n expr = module.block(needsLabel ? breakLabel : null, [\r\n initExpr,\r\n module.loop(loopLabel, module.block(null, loop))\r\n ]);\r\n } else {\r\n expr = module.block(needsLabel ? breakLabel : null, [\r\n module.loop(loopLabel, flatten(module, loop, NativeType.None))\r\n ]);\r\n }\r\n } else {\r\n if (initExpr) loop.unshift(initExpr); // (2)\r\n this.performAutoreleases(innerFlow, loop);\r\n expr = module.block(needsLabel ? breakLabel : null, loop);\r\n }\r\n\r\n // Switch back to the parent flow\r\n innerFlow.freeScopedLocals();\r\n outerFlow.popBreakLabel();\r\n innerFlow.unset(\r\n FlowFlags.BREAKS |\r\n FlowFlags.CONDITIONALLY_BREAKS |\r\n FlowFlags.CONTINUES |\r\n FlowFlags.CONDITIONALLY_CONTINUES\r\n );\r\n if (alwaysTrue) outerFlow.inherit(innerFlow);\r\n else outerFlow.inheritConditional(innerFlow);\r\n this.currentFlow = outerFlow;\r\n return expr;\r\n }\r\n\r\n compileIfStatement(\r\n statement: IfStatement\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var ifTrue = statement.ifTrue;\r\n var ifFalse = statement.ifFalse;\r\n var outerFlow = this.currentFlow;\r\n\r\n // The condition doesn't initiate a branch yet\r\n var condExpr = module.precomputeExpression(\r\n this.makeIsTrueish(\r\n this.compileExpression(statement.condition, Type.bool),\r\n this.currentType\r\n )\r\n );\r\n\r\n // Try to eliminate unnecesssary branches if the condition is constant\r\n if (\r\n getExpressionId(condExpr) == ExpressionId.Const &&\r\n getExpressionType(condExpr) == NativeType.I32\r\n ) {\r\n return getConstValueI32(condExpr)\r\n ? this.compileStatement(ifTrue)\r\n : ifFalse\r\n ? this.compileStatement(ifFalse)\r\n : module.nop();\r\n }\r\n\r\n // Each arm initiates a branch\r\n var ifTrueStmts = new Array();\r\n var ifTrueFlow = outerFlow.fork();\r\n this.currentFlow = ifTrueFlow;\r\n ifTrueFlow.inheritNonnullIfTrue(condExpr);\r\n if (ifTrue.kind == NodeKind.BLOCK) {\r\n this.compileStatements((ifTrue).statements, false, ifTrueStmts);\r\n } else {\r\n ifTrueStmts.push(this.compileStatement(ifTrue));\r\n }\r\n if (!ifTrueFlow.isAny(FlowFlags.TERMINATES | FlowFlags.BREAKS)) this.performAutoreleases(ifTrueFlow, ifTrueStmts);\r\n ifTrueFlow.freeScopedLocals();\r\n this.currentFlow = outerFlow;\r\n\r\n if (ifFalse) {\r\n let ifFalseFlow = outerFlow.fork();\r\n this.currentFlow = ifFalseFlow;\r\n ifFalseFlow.inheritNonnullIfFalse(condExpr);\r\n let ifFalseStmts = new Array();\r\n if (ifFalse.kind == NodeKind.BLOCK) {\r\n this.compileStatements((ifFalse).statements, false, ifFalseStmts);\r\n } else {\r\n ifFalseStmts.push(this.compileStatement(ifFalse));\r\n }\r\n if (!ifFalseFlow.isAny(FlowFlags.TERMINATES | FlowFlags.BREAKS)) this.performAutoreleases(ifFalseFlow, ifFalseStmts);\r\n ifFalseFlow.freeScopedLocals();\r\n this.currentFlow = outerFlow;\r\n outerFlow.inheritMutual(ifTrueFlow, ifFalseFlow);\r\n return module.if(condExpr,\r\n flatten(module, ifTrueStmts, NativeType.None),\r\n flatten(module, ifFalseStmts, NativeType.None)\r\n );\r\n } else {\r\n outerFlow.inheritConditional(ifTrueFlow);\r\n if (ifTrueFlow.is(FlowFlags.TERMINATES)) outerFlow.inheritNonnullIfFalse(condExpr);\r\n return module.if(condExpr,\r\n flatten(module, ifTrueStmts, NativeType.None)\r\n );\r\n }\r\n // TODO: Detect neglected condition\r\n // if (!foo) {\r\n // foo = [notNull]\r\n // }\r\n // foo // is possibly null\r\n }\r\n\r\n compileReturnStatement(\r\n statement: ReturnStatement,\r\n isLastInBody: bool\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var expr: ExpressionRef = 0;\r\n var flow = this.currentFlow;\r\n var returnType = flow.returnType;\r\n\r\n // Remember that this flow returns\r\n flow.set(FlowFlags.RETURNS | FlowFlags.TERMINATES);\r\n\r\n var valueExpression = statement.value;\r\n if (valueExpression) {\r\n if (returnType == Type.void) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n valueExpression.range, this.currentType.toString(), returnType.toString()\r\n );\r\n this.currentType = Type.void;\r\n return module.unreachable();\r\n }\r\n let constraints = Constraints.CONV_IMPLICIT;\r\n if (flow.actualFunction.is(CommonFlags.MODULE_EXPORT)) constraints |= Constraints.MUST_WRAP;\r\n expr = this.compileExpression(valueExpression, returnType, constraints | Constraints.WILL_RETAIN);\r\n\r\n // when returning a local, and it is already retained, skip the final set\r\n // of retaining it as the return value and releasing it as a variable\r\n if (!this.skippedAutoreleases.has(expr)) {\r\n if (returnType.isManaged) {\r\n if (getExpressionId(expr) == ExpressionId.LocalGet) {\r\n if (flow.isAnyLocalFlag(getLocalGetIndex(expr), LocalFlags.ANY_RETAINED)) {\r\n flow.unsetLocalFlag(getLocalGetIndex(expr), LocalFlags.ANY_RETAINED);\r\n this.skippedAutoreleases.add(expr);\r\n }\r\n }\r\n }\r\n }\r\n\r\n // remember return states\r\n if (!flow.canOverflow(expr, returnType)) flow.set(FlowFlags.RETURNS_WRAPPED);\r\n if (flow.isNonnull(expr, returnType)) flow.set(FlowFlags.RETURNS_NONNULL);\r\n\r\n } else if (returnType != Type.void) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n statement.range, \"void\", returnType.toString()\r\n );\r\n expr = module.unreachable();\r\n }\r\n\r\n var stmts = new Array();\r\n this.performAutoreleases(flow, stmts);\r\n this.finishAutoreleases(flow, stmts);\r\n\r\n // Make sure that the return value is retained for the caller\r\n if (returnType.isManaged && !this.skippedAutoreleases.has(expr)) expr = this.makeRetain(expr);\r\n\r\n if (returnType != Type.void && stmts.length) {\r\n let temp = flow.getAndFreeTempLocal(returnType);\r\n if (flow.isNonnull(expr, returnType)) flow.setLocalFlag(temp.index, LocalFlags.NONNULL);\r\n stmts.unshift(\r\n module.local_set(temp.index, expr)\r\n );\r\n expr = module.local_get(temp.index, returnType.toNativeType());\r\n }\r\n flow.freeScopedLocals();\r\n\r\n // If the last statement anyway, make it the block's return value\r\n if (isLastInBody && expr && returnType != Type.void) {\r\n if (!stmts.length) return expr;\r\n stmts.push(expr);\r\n return module.block(null, stmts, returnType.toNativeType());\r\n }\r\n\r\n // When inlining, break to the end of the inlined function's block (no need to wrap)\r\n if (flow.is(FlowFlags.INLINE_CONTEXT)) {\r\n if (!stmts.length) return module.br(assert(flow.inlineReturnLabel), 0, expr);\r\n stmts.push(module.br(assert(flow.inlineReturnLabel), 0, expr));\r\n // stmts.push(module.createUnreachable());\r\n return module.block(null, stmts);\r\n }\r\n\r\n // Otherwise emit a normal return\r\n if (!stmts.length) return module.return(expr);\r\n stmts.push(module.return(expr));\r\n return module.block(null, stmts);\r\n }\r\n\r\n compileSwitchStatement(\r\n statement: SwitchStatement\r\n ): ExpressionRef {\r\n var module = this.module;\r\n\r\n var cases = statement.cases;\r\n var numCases = cases.length;\r\n if (!numCases) {\r\n return this.compileExpression(statement.condition, Type.void,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n }\r\n\r\n // Everything within a switch uses the same break context\r\n var outerFlow = this.currentFlow;\r\n var context = outerFlow.pushBreakLabel();\r\n\r\n // introduce a local for evaluating the condition (exactly once)\r\n var tempLocal = outerFlow.getTempLocal(Type.u32);\r\n var tempLocalIndex = tempLocal.index;\r\n\r\n // Prepend initializer to inner block. Does not initiate a new branch, yet.\r\n var breaks = new Array(1 + numCases);\r\n breaks[0] = module.local_set( // initializer\r\n tempLocalIndex,\r\n this.compileExpression(statement.condition, Type.u32,\r\n Constraints.CONV_IMPLICIT\r\n )\r\n );\r\n\r\n // make one br_if per (possibly dynamic) labeled case (binaryen optimizes to br_table where possible)\r\n var breakIndex = 1;\r\n var defaultIndex = -1;\r\n for (let i = 0; i < numCases; ++i) {\r\n let case_ = cases[i];\r\n let label = case_.label;\r\n if (label) {\r\n breaks[breakIndex++] = module.br(\"case\" + i.toString(10) + \"|\" + context,\r\n module.binary(BinaryOp.EqI32,\r\n module.local_get(tempLocalIndex, NativeType.I32),\r\n this.compileExpression(label, Type.u32,\r\n Constraints.CONV_IMPLICIT\r\n )\r\n )\r\n );\r\n } else {\r\n defaultIndex = i;\r\n }\r\n }\r\n\r\n outerFlow.freeTempLocal(tempLocal);\r\n\r\n // otherwise br to default respectively out of the switch if there is no default case\r\n breaks[breakIndex] = module.br((defaultIndex >= 0\r\n ? \"case\" + defaultIndex.toString(10)\r\n : \"break\"\r\n ) + \"|\" + context);\r\n\r\n // nest blocks in order\r\n var currentBlock = module.block(\"case0|\" + context, breaks, NativeType.None);\r\n var commonCategorical = FlowFlags.ANY_CATEGORICAL;\r\n var commonConditional = 0;\r\n for (let i = 0; i < numCases; ++i) {\r\n let case_ = cases[i];\r\n let statements = case_.statements;\r\n let numStatements = statements.length;\r\n\r\n // Each switch case initiates a new branch\r\n let innerFlow = outerFlow.fork();\r\n this.currentFlow = innerFlow;\r\n let breakLabel = \"break|\" + context;\r\n innerFlow.breakLabel = breakLabel;\r\n\r\n let isLast = i == numCases - 1;\r\n let nextLabel = isLast ? breakLabel : \"case\" + (i + 1).toString(10) + \"|\" + context;\r\n let stmts = new Array(1 + numStatements);\r\n stmts[0] = currentBlock;\r\n let count = 1;\r\n let terminates = false;\r\n for (let j = 0; j < numStatements; ++j) {\r\n let stmt = this.compileStatement(statements[j]);\r\n if (getExpressionId(stmt) != ExpressionId.Nop) {\r\n stmts[count++] = stmt;\r\n }\r\n if (innerFlow.isAny(FlowFlags.TERMINATES | FlowFlags.BREAKS)) {\r\n if (innerFlow.is(FlowFlags.TERMINATES)) terminates = true;\r\n break;\r\n }\r\n }\r\n stmts.length = count;\r\n if (terminates || isLast || innerFlow.isAny(FlowFlags.BREAKS | FlowFlags.CONDITIONALLY_BREAKS)) {\r\n commonCategorical &= innerFlow.flags;\r\n }\r\n commonConditional |= innerFlow.flags & FlowFlags.ANY_CONDITIONAL;\r\n\r\n // Switch back to the parent flow\r\n if (!terminates) this.performAutoreleases(innerFlow, stmts);\r\n innerFlow.unset(\r\n FlowFlags.BREAKS |\r\n FlowFlags.CONDITIONALLY_BREAKS\r\n );\r\n innerFlow.freeScopedLocals();\r\n this.currentFlow = outerFlow;\r\n currentBlock = module.block(nextLabel, stmts, NativeType.None); // must be a labeled block\r\n }\r\n outerFlow.popBreakLabel();\r\n\r\n // If the switch has a default (guaranteed to handle any value), propagate common flags\r\n if (defaultIndex >= 0) outerFlow.flags |= commonCategorical & ~FlowFlags.BREAKS;\r\n outerFlow.flags |= commonConditional & ~FlowFlags.CONDITIONALLY_BREAKS;\r\n // TODO: what about local states?\r\n return currentBlock;\r\n }\r\n\r\n compileThrowStatement(\r\n statement: ThrowStatement\r\n ): ExpressionRef {\r\n var flow = this.currentFlow;\r\n\r\n // Remember that this branch throws\r\n flow.set(FlowFlags.THROWS | FlowFlags.TERMINATES);\r\n\r\n var stmts = new Array();\r\n this.finishAutoreleases(flow, stmts);\r\n\r\n // TODO: requires exception-handling spec.\r\n var value = statement.value;\r\n var message: Expression | null = null;\r\n if (value.kind == NodeKind.NEW) {\r\n let newArgs = (value).arguments;\r\n if (newArgs.length) message = newArgs[0]; // FIXME: naively assumes type string\r\n }\r\n stmts.push(compileAbort(this, message, statement));\r\n\r\n return flatten(this.module, stmts, NativeType.None);\r\n }\r\n\r\n compileTryStatement(\r\n statement: TryStatement\r\n ): ExpressionRef {\r\n // TODO: can't yet support something like: try { return ... } finally { ... }\r\n // worthwhile to investigate lowering returns to block results (here)?\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n statement.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n /** Compiles a variable statement. Returns `0` if an initializer is not necessary. */\r\n compileVariableStatement(\r\n statement: VariableStatement\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var declarations = statement.declarations;\r\n var numDeclarations = declarations.length;\r\n var flow = this.currentFlow;\r\n var initializers = new Array();\r\n var resolver = this.resolver;\r\n\r\n for (let i = 0; i < numDeclarations; ++i) {\r\n let declaration = declarations[i];\r\n let name = declaration.name.text;\r\n let type: Type | null = null;\r\n let initExpr: ExpressionRef = 0;\r\n let initAutoreleaseSkipped = false;\r\n\r\n // Resolve type if annotated\r\n if (declaration.type) {\r\n type = resolver.resolveType( // reports\r\n declaration.type,\r\n flow.actualFunction,\r\n flow.contextualTypeArguments\r\n );\r\n if (!type) continue;\r\n if (declaration.initializer) {\r\n initExpr = this.compileExpression(declaration.initializer, type, // reports\r\n Constraints.CONV_IMPLICIT | Constraints.WILL_RETAIN\r\n );\r\n initAutoreleaseSkipped = this.skippedAutoreleases.has(initExpr);\r\n }\r\n\r\n // Otherwise infer type from initializer\r\n } else if (declaration.initializer) {\r\n initExpr = this.compileExpression(declaration.initializer, Type.auto,\r\n Constraints.WILL_RETAIN\r\n ); // reports\r\n initAutoreleaseSkipped = this.skippedAutoreleases.has(initExpr);\r\n if (this.currentType == Type.void) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n declaration.range, this.currentType.toString(), \"\"\r\n );\r\n continue;\r\n }\r\n type = this.currentType;\r\n\r\n // Error if there's neither a type nor an initializer\r\n } else {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n declaration.name.range.atEnd\r\n );\r\n continue;\r\n }\r\n\r\n // Handle constants, and try to inline if value is static\r\n let isConst = declaration.is(CommonFlags.CONST);\r\n let isStatic = false;\r\n if (isConst) {\r\n if (initExpr) {\r\n initExpr = module.precomputeExpression(initExpr);\r\n if (getExpressionId(initExpr) == ExpressionId.Const) {\r\n let local = new Local(name, -1, type, flow.parentFunction);\r\n switch (getExpressionType(initExpr)) {\r\n case NativeType.I32: {\r\n local.setConstantIntegerValue(\r\n i64_new(\r\n getConstValueI32(initExpr),\r\n 0\r\n ),\r\n type\r\n );\r\n break;\r\n }\r\n case NativeType.I64: {\r\n local.setConstantIntegerValue(\r\n i64_new(\r\n getConstValueI64Low(initExpr),\r\n getConstValueI64High(initExpr)\r\n ),\r\n type\r\n );\r\n break;\r\n }\r\n case NativeType.F32: {\r\n local.setConstantFloatValue(getConstValueF32(initExpr), type);\r\n break;\r\n }\r\n case NativeType.F64: {\r\n local.setConstantFloatValue(getConstValueF64(initExpr), type);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n return module.unreachable();\r\n }\r\n }\r\n // Create a virtual local that doesn't actually exist in WebAssembly\r\n let scopedLocals = flow.scopedLocals;\r\n if (!scopedLocals) flow.scopedLocals = scopedLocals = new Map();\r\n else if (scopedLocals.has(name)) {\r\n this.error(\r\n DiagnosticCode.Duplicate_identifier_0,\r\n declaration.name.range, name\r\n );\r\n return this.module.unreachable();\r\n }\r\n scopedLocals.set(name, local);\r\n isStatic = true;\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._const_declarations_must_be_initialized,\r\n declaration.range\r\n );\r\n }\r\n }\r\n\r\n // Otherwise compile as mutable\r\n if (!isStatic) {\r\n let local: Local;\r\n if (\r\n declaration.isAny(CommonFlags.LET | CommonFlags.CONST) ||\r\n flow.is(FlowFlags.INLINE_CONTEXT)\r\n ) { // here: not top-level\r\n let existingLocal = flow.getScopedLocal(name);\r\n if (existingLocal) {\r\n this.error(\r\n DiagnosticCode.Duplicate_identifier_0,\r\n declaration.name.range, declaration.name.text\r\n );\r\n local = existingLocal;\r\n } else {\r\n local = flow.addScopedLocal(name, type);\r\n }\r\n if (isConst) flow.setLocalFlag(local.index, LocalFlags.CONSTANT);\r\n } else {\r\n if (flow.lookupLocal(name)) {\r\n this.error(\r\n DiagnosticCode.Duplicate_identifier_0,\r\n declaration.name.range, name\r\n );\r\n continue;\r\n }\r\n local = flow.parentFunction.addLocal(type, name, declaration);\r\n if (isConst) flow.setLocalFlag(local.index, LocalFlags.CONSTANT);\r\n }\r\n let isManaged = type.isManaged;\r\n if (initExpr) {\r\n if (flow.isNonnull(initExpr, type)) flow.setLocalFlag(local.index, LocalFlags.NONNULL);\r\n if (isManaged) {\r\n flow.setLocalFlag(local.index, LocalFlags.RETAINED);\r\n initializers.push(\r\n module.local_set(local.index,\r\n initAutoreleaseSkipped\r\n ? initExpr\r\n : this.makeRetain(initExpr)\r\n )\r\n );\r\n } else {\r\n initializers.push(\r\n module.local_set(local.index, initExpr)\r\n );\r\n if (local.type.is(TypeFlags.SHORT | TypeFlags.INTEGER)) {\r\n if (!flow.canOverflow(initExpr, type)) flow.setLocalFlag(local.index, LocalFlags.WRAPPED);\r\n else flow.unsetLocalFlag(local.index, LocalFlags.WRAPPED);\r\n }\r\n }\r\n } else {\r\n if (isManaged) {\r\n // This is necessary because the first use (and assign) of the local could be taking place\r\n // in a loop, subsequently marking it retained, but the second iteration of the loop\r\n // still wouldn't release whatever is assigned in the first. Likewise, if the variable wasn't\r\n // initialized but becomes released later on, whatever was stored before would be released.\r\n // TODO: Detect this condition inside of a loop instead?\r\n initializers.push(\r\n module.local_set(local.index,\r\n type.toNativeZero(module)\r\n )\r\n );\r\n flow.setLocalFlag(local.index, LocalFlags.CONDITIONALLY_RETAINED);\r\n } else if (local.type.is(TypeFlags.SHORT | TypeFlags.INTEGER)) {\r\n flow.setLocalFlag(local.index, LocalFlags.WRAPPED);\r\n }\r\n }\r\n }\r\n }\r\n return initializers.length == 0\r\n ? 0\r\n : flatten(module, initializers, NativeType.None);\r\n }\r\n\r\n compileVoidStatement(\r\n statement: VoidStatement\r\n ): ExpressionRef {\r\n return this.compileExpression(statement.expression, Type.void,\r\n Constraints.CONV_EXPLICIT | Constraints.WILL_DROP\r\n );\r\n }\r\n\r\n compileWhileStatement(\r\n statement: WhileStatement\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var outerFlow = this.currentFlow;\r\n\r\n // Compile condition\r\n var condExpr = module.precomputeExpression(\r\n this.makeIsTrueish(\r\n this.compileExpression(statement.condition, Type.bool),\r\n this.currentType\r\n )\r\n );\r\n\r\n // Simplify if the condition is constant\r\n var alwaysTrue = false;\r\n if (getExpressionId(condExpr) == ExpressionId.Const) {\r\n assert(getExpressionType(condExpr) == NativeType.I32);\r\n if (!getConstValueI32(condExpr)) return module.nop(); // simplify\r\n alwaysTrue = true;\r\n }\r\n\r\n // Compile body\r\n var label = outerFlow.pushBreakLabel();\r\n var innerFlow = outerFlow.fork();\r\n this.currentFlow = innerFlow;\r\n var breakLabel = \"break|\" + label;\r\n innerFlow.breakLabel = breakLabel;\r\n var continueLabel = \"continue|\" + label;\r\n innerFlow.continueLabel = continueLabel;\r\n innerFlow.inheritNonnullIfTrue(condExpr);\r\n var stmts = new Array();\r\n if (statement.statement.kind == NodeKind.BLOCK) {\r\n this.compileStatements((statement.statement).statements, false, stmts);\r\n } else {\r\n stmts.push(this.compileStatement(statement.statement));\r\n }\r\n var terminates = innerFlow.is(FlowFlags.TERMINATES);\r\n\r\n // (block $break ;; (1) skip if skipping (3) + no breaks\r\n // (loop $continue ;; (2) skip if skipping (5) + no continues\r\n // (br_if !cond $break) ;; (3) skip if always true\r\n // (...) ;; (4)\r\n // (br $continue) ;; (5) skip if (4) does not fall through\r\n // )\r\n // )\r\n var fallsThrough = !terminates && !innerFlow.is(FlowFlags.BREAKS);\r\n\r\n if (fallsThrough) { // (5)\r\n this.performAutoreleases(innerFlow, stmts);\r\n stmts.push(module.br(continueLabel));\r\n }\r\n if (!alwaysTrue) { // (3)\r\n stmts.unshift(module.br(breakLabel, module.unary(UnaryOp.EqzI32, condExpr)));\r\n }\r\n var expr = flatten(module, stmts, NativeType.None);\r\n if (fallsThrough || innerFlow.isAny(FlowFlags.CONTINUES | FlowFlags.CONDITIONALLY_CONTINUES)) { // (2)\r\n expr = module.loop(continueLabel, expr);\r\n }\r\n if (!alwaysTrue || innerFlow.isAny(FlowFlags.BREAKS | FlowFlags.CONDITIONALLY_BREAKS)) { // (1)\r\n expr = module.block(breakLabel, [ expr ]);\r\n }\r\n\r\n // Switch back to the parent flow\r\n innerFlow.freeScopedLocals();\r\n outerFlow.popBreakLabel();\r\n innerFlow.unset(\r\n FlowFlags.BREAKS |\r\n FlowFlags.CONDITIONALLY_BREAKS |\r\n FlowFlags.CONTINUES |\r\n FlowFlags.CONDITIONALLY_CONTINUES\r\n );\r\n if (alwaysTrue) outerFlow.inherit(innerFlow);\r\n else outerFlow.inheritConditional(innerFlow);\r\n this.currentFlow = outerFlow;\r\n return expr;\r\n }\r\n\r\n // === Expressions ==============================================================================\r\n\r\n /** Compiles the value of an inlined constant element. */\r\n compileInlineConstant(\r\n element: VariableLikeElement,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n assert(element.is(CommonFlags.INLINED));\r\n var type = element.type;\r\n switch (\r\n !(constraints & (Constraints.CONV_IMPLICIT | Constraints.CONV_EXPLICIT)) &&\r\n type.is(TypeFlags.INTEGER) &&\r\n contextualType.is(TypeFlags.INTEGER) &&\r\n type.size < contextualType.size\r\n ? (this.currentType = contextualType).kind // essentially precomputes a (sign-)extension\r\n : (this.currentType = type).kind\r\n ) {\r\n case TypeKind.I8:\r\n case TypeKind.I16: {\r\n let shift = type.computeSmallIntegerShift(Type.i32);\r\n return this.module.i32(\r\n element.constantValueKind == ConstantValueKind.INTEGER\r\n ? i64_low(element.constantIntegerValue) << shift >> shift\r\n : 0\r\n ); // recognized by canOverflow\r\n }\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL: {\r\n let mask = element.type.computeSmallIntegerMask(Type.i32);\r\n return this.module.i32(\r\n element.constantValueKind == ConstantValueKind.INTEGER\r\n ? i64_low(element.constantIntegerValue) & mask\r\n : 0\r\n ); // recognized by canOverflow\r\n }\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n return this.module.i32(\r\n element.constantValueKind == ConstantValueKind.INTEGER\r\n ? i64_low(element.constantIntegerValue)\r\n : 0\r\n );\r\n }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n if (!element.program.options.isWasm64) {\r\n return this.module.i32(\r\n element.constantValueKind == ConstantValueKind.INTEGER\r\n ? i64_low(element.constantIntegerValue)\r\n : 0\r\n );\r\n }\r\n // fall-through\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n return element.constantValueKind == ConstantValueKind.INTEGER\r\n ? this.module.i64(\r\n i64_low(element.constantIntegerValue),\r\n i64_high(element.constantIntegerValue)\r\n )\r\n : this.module.i64(0);\r\n }\r\n case TypeKind.F64: {\r\n // monkey-patch for converting built-in floats to f32 implicitly\r\n if (!(element.hasDecorator(DecoratorFlags.BUILTIN) && contextualType == Type.f32)) {\r\n return this.module.f64((element).constantFloatValue);\r\n }\r\n // otherwise fall-through: basically precomputes f32.demote/f64 of NaN / Infinity\r\n this.currentType = Type.f32;\r\n }\r\n case TypeKind.F32: {\r\n return this.module.f32((element).constantFloatValue);\r\n }\r\n default: {\r\n assert(false);\r\n return this.module.unreachable();\r\n }\r\n }\r\n }\r\n\r\n compileExpression(\r\n expression: Expression,\r\n contextualType: Type,\r\n constraints: Constraints = Constraints.NONE\r\n ): ExpressionRef {\r\n this.currentType = contextualType;\r\n var expr: ExpressionRef;\r\n if (contextualType == Type.void) constraints |= Constraints.WILL_DROP;\r\n switch (expression.kind) {\r\n case NodeKind.ASSERTION: {\r\n expr = this.compileAssertionExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.BINARY: {\r\n expr = this.compileBinaryExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.CALL: {\r\n expr = this.compileCallExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.COMMA: {\r\n expr = this.compileCommaExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.ELEMENTACCESS: {\r\n expr = this.compileElementAccessExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.FUNCTION: {\r\n expr = this.compileFunctionExpression(expression, contextualType.signatureReference, constraints);\r\n break;\r\n }\r\n case NodeKind.IDENTIFIER:\r\n case NodeKind.FALSE:\r\n case NodeKind.NULL:\r\n case NodeKind.THIS:\r\n case NodeKind.SUPER:\r\n case NodeKind.TRUE: {\r\n expr = this.compileIdentifierExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.INSTANCEOF: {\r\n expr = this.compileInstanceOfExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.LITERAL: {\r\n expr = this.compileLiteralExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.NEW: {\r\n expr = this.compileNewExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.PARENTHESIZED: {\r\n expr = this.compileExpression((expression).expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.PROPERTYACCESS: {\r\n expr = this.compilePropertyAccessExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.TERNARY: {\r\n expr = this.compileTernaryExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.UNARYPOSTFIX: {\r\n expr = this.compileUnaryPostfixExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n case NodeKind.UNARYPREFIX: {\r\n expr = this.compileUnaryPrefixExpression(expression, contextualType, constraints);\r\n break;\r\n }\r\n default: {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n expr = this.module.unreachable();\r\n }\r\n }\r\n // ensure conversion and wrapping in case the respective function doesn't on its own\r\n var currentType = this.currentType;\r\n var wrap = (constraints & Constraints.MUST_WRAP) != 0;\r\n if (currentType != contextualType) {\r\n if (constraints & Constraints.CONV_EXPLICIT) {\r\n expr = this.convertExpression(expr, currentType, contextualType, true, wrap, expression);\r\n wrap = false;\r\n this.currentType = contextualType;\r\n } else if (constraints & Constraints.CONV_IMPLICIT) {\r\n expr = this.convertExpression(expr, currentType, contextualType, false, wrap, expression);\r\n wrap = false;\r\n this.currentType = contextualType;\r\n }\r\n }\r\n if (wrap) expr = this.ensureSmallIntegerWrap(expr, currentType);\r\n // debug location is added here so the caller doesn't have to. means: compilation of an expression\r\n // must go through this function, with the respective per-kind functions not being used directly.\r\n if (this.options.sourceMap) this.addDebugLocation(expr, expression.range);\r\n return expr;\r\n }\r\n\r\n /** Compiles and precomputes an expression, possibly yielding a costant value. */\r\n precomputeExpression(\r\n expression: Expression,\r\n contextualType: Type,\r\n constraints: Constraints = Constraints.NONE\r\n ): ExpressionRef {\r\n return this.module.precomputeExpression(\r\n this.compileExpression(expression, contextualType, constraints)\r\n );\r\n }\r\n\r\n convertExpression(\r\n expr: ExpressionRef,\r\n /** Original type. */\r\n fromType: Type,\r\n /** New type. */\r\n toType: Type,\r\n /** Whether the conversion is explicit.*/\r\n explicit: bool,\r\n /** Whether the result should be wrapped, if a small integer. */\r\n wrap: bool,\r\n reportNode: Node\r\n ): ExpressionRef {\r\n var module = this.module;\r\n\r\n // void to any\r\n if (fromType.kind == TypeKind.VOID) {\r\n assert(toType.kind != TypeKind.VOID); // convertExpression should not be called with void -> void\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n reportNode.range, fromType.toString(), toType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n\r\n // any to void\r\n if (toType.kind == TypeKind.VOID) return module.drop(expr);\r\n\r\n if (this.currentFlow.isNonnull(expr, fromType)) fromType = fromType.nonNullableType;\r\n\r\n if (!fromType.isAssignableTo(toType)) {\r\n if (!explicit) {\r\n if (fromType.nonNullableType == toType) {\r\n this.error(\r\n DiagnosticCode.Object_is_possibly_null,\r\n reportNode.range\r\n ); // recoverable\r\n } else {\r\n this.error(\r\n DiagnosticCode.Conversion_from_type_0_to_1_requires_an_explicit_cast,\r\n reportNode.range, fromType.toString(), toType.toString()\r\n ); // recoverable\r\n }\r\n }\r\n }\r\n\r\n if (fromType.is(TypeFlags.FLOAT)) {\r\n\r\n // float to float\r\n if (toType.is(TypeFlags.FLOAT)) {\r\n if (fromType.kind == TypeKind.F32) {\r\n\r\n // f32 to f64\r\n if (toType.kind == TypeKind.F64) {\r\n expr = module.unary(UnaryOp.PromoteF32, expr);\r\n }\r\n\r\n // otherwise f32 to f32\r\n\r\n // f64 to f32\r\n } else if (toType.kind == TypeKind.F32) {\r\n expr = module.unary(UnaryOp.DemoteF64, expr);\r\n }\r\n\r\n // otherwise f64 to f64\r\n\r\n // float to int\r\n } else if (toType.is(TypeFlags.INTEGER)) {\r\n\r\n // f32 to int\r\n if (fromType.kind == TypeKind.F32) {\r\n if (toType == Type.bool) {\r\n expr = module.binary(BinaryOp.NeF32, expr, module.f32(0));\r\n wrap = false;\r\n } else if (toType.is(TypeFlags.SIGNED)) {\r\n if (toType.is(TypeFlags.LONG)) {\r\n expr = module.unary(UnaryOp.TruncF32ToI64, expr);\r\n } else {\r\n expr = module.unary(UnaryOp.TruncF32ToI32, expr);\r\n }\r\n } else {\r\n if (toType.is(TypeFlags.LONG)) {\r\n expr = module.unary(UnaryOp.TruncF32ToU64, expr);\r\n } else {\r\n expr = module.unary(UnaryOp.TruncF32ToU32, expr);\r\n }\r\n }\r\n\r\n // f64 to int\r\n } else {\r\n if (toType == Type.bool) {\r\n expr = module.binary(BinaryOp.NeF64, expr, module.f64(0));\r\n wrap = false;\r\n } else if (toType.is(TypeFlags.SIGNED)) {\r\n if (toType.is(TypeFlags.LONG)) {\r\n expr = module.unary(UnaryOp.TruncF64ToI64, expr);\r\n } else {\r\n expr = module.unary(UnaryOp.TruncF64ToI32, expr);\r\n }\r\n } else {\r\n if (toType.is(TypeFlags.LONG)) {\r\n expr = module.unary(UnaryOp.TruncF64ToU64, expr);\r\n } else {\r\n expr = module.unary(UnaryOp.TruncF64ToU32, expr);\r\n }\r\n }\r\n }\r\n\r\n // float to void\r\n } else {\r\n assert(toType.flags == TypeFlags.NONE, \"void type expected\");\r\n expr = module.drop(expr);\r\n }\r\n\r\n // int to float\r\n } else if (fromType.is(TypeFlags.INTEGER) && toType.is(TypeFlags.FLOAT)) {\r\n\r\n // int to f32\r\n if (toType.kind == TypeKind.F32) {\r\n if (fromType.is(TypeFlags.LONG)) {\r\n expr = module.unary(\r\n fromType.is(TypeFlags.SIGNED)\r\n ? UnaryOp.ConvertI64ToF32\r\n : UnaryOp.ConvertU64ToF32,\r\n expr\r\n );\r\n } else {\r\n expr = module.unary(\r\n fromType.is(TypeFlags.SIGNED)\r\n ? UnaryOp.ConvertI32ToF32\r\n : UnaryOp.ConvertU32ToF32,\r\n expr\r\n );\r\n }\r\n\r\n // int to f64\r\n } else {\r\n if (fromType.is(TypeFlags.LONG)) {\r\n expr = module.unary(\r\n fromType.is(TypeFlags.SIGNED)\r\n ? UnaryOp.ConvertI64ToF64\r\n : UnaryOp.ConvertU64ToF64,\r\n expr\r\n );\r\n } else {\r\n expr = module.unary(\r\n fromType.is(TypeFlags.SIGNED)\r\n ? UnaryOp.ConvertI32ToF64\r\n : UnaryOp.ConvertU32ToF64,\r\n expr\r\n );\r\n }\r\n }\r\n\r\n // int to int\r\n } else {\r\n // i64 to ...\r\n if (fromType.is(TypeFlags.LONG)) {\r\n\r\n // i64 to i32 or smaller\r\n if (toType == Type.bool) {\r\n expr = module.binary(BinaryOp.NeI64, expr, module.i64(0));\r\n wrap = false;\r\n } else if (!toType.is(TypeFlags.LONG)) {\r\n expr = module.unary(UnaryOp.WrapI64, expr); // discards upper bits\r\n }\r\n\r\n // i32 or smaller to i64\r\n } else if (toType.is(TypeFlags.LONG)) {\r\n expr = module.unary(\r\n fromType.is(TypeFlags.SIGNED) ? UnaryOp.ExtendI32 : UnaryOp.ExtendU32,\r\n this.ensureSmallIntegerWrap(expr, fromType) // must clear garbage bits\r\n );\r\n wrap = false;\r\n\r\n // i32 to i32\r\n } else {\r\n // small i32 to ...\r\n if (fromType.is(TypeFlags.SHORT)) {\r\n // small i32 to larger i32\r\n if (fromType.size < toType.size) {\r\n expr = this.ensureSmallIntegerWrap(expr, fromType); // must clear garbage bits\r\n wrap = false;\r\n }\r\n }\r\n }\r\n }\r\n\r\n this.currentType = toType;\r\n return wrap\r\n ? this.ensureSmallIntegerWrap(expr, toType)\r\n : expr;\r\n }\r\n\r\n compileAssertionExpression(\r\n expression: AssertionExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var inheritedConstraints = constraints & ~(Constraints.CONV_IMPLICIT | Constraints.CONV_EXPLICIT);\r\n switch (expression.assertionKind) {\r\n case AssertionKind.PREFIX:\r\n case AssertionKind.AS: {\r\n let flow = this.currentFlow;\r\n let toType = this.resolver.resolveType( // reports\r\n assert(expression.toType),\r\n flow.actualFunction,\r\n flow.contextualTypeArguments\r\n );\r\n if (!toType) return this.module.unreachable();\r\n return this.compileExpression(expression.expression, toType, inheritedConstraints | Constraints.CONV_EXPLICIT);\r\n }\r\n case AssertionKind.NONNULL: {\r\n assert(!expression.toType);\r\n let expr = this.compileExpression(expression.expression, contextualType.exceptVoid, inheritedConstraints);\r\n let type = this.currentType;\r\n if (this.currentFlow.isNonnull(expr, type)) {\r\n this.info(\r\n DiagnosticCode.Expression_is_never_null,\r\n expression.expression.range\r\n );\r\n } else if (!this.options.noAssert) {\r\n let module = this.module;\r\n let flow = this.currentFlow;\r\n let tempIndex = flow.getAndFreeTempLocal(type).index;\r\n if (!flow.canOverflow(expr, type)) flow.setLocalFlag(tempIndex, LocalFlags.WRAPPED);\r\n flow.setLocalFlag(tempIndex, LocalFlags.NONNULL);\r\n expr = module.if(\r\n module.local_tee(tempIndex, expr),\r\n module.local_get(tempIndex, type.toNativeType()),\r\n module.unreachable()\r\n );\r\n }\r\n this.currentType = this.currentType.nonNullableType;\r\n return expr;\r\n }\r\n default: assert(false);\r\n }\r\n return this.module.unreachable();\r\n }\r\n\r\n private f32ModInstance: Function | null = null;\r\n private f64ModInstance: Function | null = null;\r\n private f32PowInstance: Function | null = null;\r\n private f64PowInstance: Function | null = null;\r\n\r\n compileBinaryExpression(\r\n expression: BinaryExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var left = expression.left;\r\n var right = expression.right;\r\n\r\n var leftExpr: ExpressionRef;\r\n var leftType: Type;\r\n var rightExpr: ExpressionRef;\r\n var rightType: Type;\r\n var commonType: Type | null;\r\n\r\n var expr: ExpressionRef;\r\n var compound = false;\r\n\r\n var operator = expression.operator;\r\n switch (operator) {\r\n case Token.LESSTHAN: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.LT);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, true)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, true, // !\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, true, // !\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \"<\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n switch (commonType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32: {\r\n expr = module.binary(BinaryOp.LtI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I64: {\r\n expr = module.binary(BinaryOp.LtI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.LtI64\r\n : BinaryOp.LtI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.LtU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.LtU64\r\n : BinaryOp.LtU32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.LtU64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.LtF32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.LtF64, leftExpr, rightExpr);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n this.currentType = Type.bool;\r\n break;\r\n }\r\n case Token.GREATERTHAN: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.GT);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, true)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, true, // !\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, true, // !\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \">\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n switch (commonType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32: {\r\n expr = module.binary(BinaryOp.GtI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.GtI64\r\n : BinaryOp.GtI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64: {\r\n expr = module.binary(BinaryOp.GtI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.GtU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.GtU64\r\n : BinaryOp.GtU32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.GtU64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.GtF32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.GtF64, leftExpr, rightExpr);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n this.currentType = Type.bool;\r\n break;\r\n }\r\n case Token.LESSTHAN_EQUALS: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.LE);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, true)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, true, // !\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, true, // !\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \"<=\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n switch (commonType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32: {\r\n expr = module.binary(BinaryOp.LeI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.LeI64\r\n : BinaryOp.LeI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64: {\r\n expr = module.binary(BinaryOp.LeI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.LeU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.LeU64\r\n : BinaryOp.LeU32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.LeU64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.LeF32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.LeF64, leftExpr, rightExpr);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n this.currentType = Type.bool;\r\n break;\r\n }\r\n case Token.GREATERTHAN_EQUALS: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.GE);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, true)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, true, // !\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, true, // !\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \">=\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n switch (commonType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32: {\r\n expr = module.binary(BinaryOp.GeI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.GeI64\r\n : BinaryOp.GeI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64: {\r\n expr = module.binary(BinaryOp.GeI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.GeU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.GeU64\r\n : BinaryOp.GeU32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.GeU64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.GeF32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.GeF64, leftExpr, rightExpr);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n this.currentType = Type.bool;\r\n break;\r\n }\r\n\r\n case Token.EQUALS_EQUALS_EQUALS:\r\n case Token.EQUALS_EQUALS: {\r\n\r\n // NOTE that this favors correctness, in terms of emitting a binary expression, over\r\n // checking for a possible use of unary EQZ. while the most classic of all optimizations,\r\n // that's not what the source told us to do. for reference, `!left` emits unary EQZ.\r\n\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (operator == Token.EQUALS_EQUALS && this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.EQ);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n // still allow '==' with references\r\n }\r\n\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, true, // !\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, true, // !\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, operatorTokenToString(expression.operator), leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n switch (commonType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.EqI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.EqI64\r\n : BinaryOp.EqI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.EqI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.EqF32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.EqF64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.V128: {\r\n expr = module.unary(UnaryOp.AllTrueVecI8x16,\r\n module.binary(BinaryOp.EqVecI8x16, leftExpr, rightExpr)\r\n );\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n this.currentType = Type.bool;\r\n break;\r\n }\r\n case Token.EXCLAMATION_EQUALS_EQUALS:\r\n case Token.EXCLAMATION_EQUALS: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (operator == Token.EXCLAMATION_EQUALS && this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.NE);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n // still allow '!=' with references\r\n }\r\n\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, true, // !\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, true, // !\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, operatorTokenToString(expression.operator), leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n switch (commonType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.NeI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.NeI64\r\n : BinaryOp.NeI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.NeI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.NeF32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.NeF64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.V128: {\r\n expr = module.unary(UnaryOp.AnyTrueVecI8x16,\r\n module.binary(BinaryOp.NeVecI8x16, leftExpr, rightExpr)\r\n );\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n this.currentType = Type.bool;\r\n break;\r\n }\r\n case Token.EQUALS: {\r\n return this.compileAssignment(left, right, contextualType);\r\n }\r\n case Token.PLUS_EQUALS: compound = true;\r\n case Token.PLUS: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.ADD);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n if (compound) {\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n } else {\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, false,\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, false,\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \"+\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n }\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8: // addition might overflow\r\n case TypeKind.I16: // ^\r\n case TypeKind.U8: // ^\r\n case TypeKind.U16: // ^\r\n case TypeKind.BOOL: // ^\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.AddI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.AddI64\r\n : BinaryOp.AddI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.AddI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.AddF32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.AddF64, leftExpr, rightExpr);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.MINUS_EQUALS: compound = true;\r\n case Token.MINUS: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.SUB);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n if (compound) {\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n } else {\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, false,\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, false,\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \"-\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n }\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8: // subtraction might overflow\r\n case TypeKind.I16: // ^\r\n case TypeKind.U8: // ^\r\n case TypeKind.U16: // ^\r\n case TypeKind.BOOL: // ^\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.SubI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.SubI64\r\n : BinaryOp.SubI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.SubI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.SubF32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.SubF64, leftExpr, rightExpr);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.ASTERISK_EQUALS: compound = true;\r\n case Token.ASTERISK: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.MUL);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n if (compound) {\r\n leftExpr = this.ensureSmallIntegerWrap(leftExpr, leftType);\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n } else {\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, false,\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, false,\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \"*\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n }\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL:\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.MulI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.MulI64\r\n : BinaryOp.MulI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.MulI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.MulF32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.MulF64, leftExpr, rightExpr);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.ASTERISK_ASTERISK_EQUALS: compound = true;\r\n case Token.ASTERISK_ASTERISK: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.POW);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n let instance: Function | null;\r\n\r\n // Mathf.pow if lhs is f32 (result is f32)\r\n if (this.currentType.kind == TypeKind.F32) {\r\n rightExpr = this.compileExpression(right, Type.f32, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n if (!(instance = this.f32PowInstance)) {\r\n let namespace = this.program.lookupGlobal(CommonSymbols.Mathf);\r\n if (!namespace) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n expression.range, \"Mathf\"\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n let prototype = namespace.members ? namespace.members.get(CommonSymbols.pow) : null;\r\n if (!prototype) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n expression.range, \"Mathf.pow\"\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n assert(prototype.kind == ElementKind.FUNCTION_PROTOTYPE);\r\n this.f32PowInstance = instance = this.resolver.resolveFunction(prototype, null);\r\n }\r\n\r\n // Math.pow otherwise (result is f64)\r\n // TODO: should the result be converted back?\r\n } else {\r\n leftExpr = this.convertExpression(leftExpr,\r\n this.currentType, Type.f64,\r\n false, false,\r\n left\r\n );\r\n leftType = this.currentType;\r\n rightExpr = this.compileExpression(right, Type.f64, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n if (!(instance = this.f64PowInstance)) {\r\n let namespace = this.program.lookupGlobal(CommonSymbols.Math);\r\n if (!namespace) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n expression.range, \"Math\"\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n let prototype = namespace.members ? namespace.members.get(CommonSymbols.pow) : null;\r\n if (!prototype) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n expression.range, \"Math.pow\"\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n assert(prototype.kind == ElementKind.FUNCTION_PROTOTYPE);\r\n this.f64PowInstance = instance = this.resolver.resolveFunction(prototype, null);\r\n }\r\n }\r\n if (!(instance && this.compileFunction(instance))) {\r\n expr = module.unreachable();\r\n } else {\r\n expr = this.makeCallDirect(instance, [ leftExpr, rightExpr ], expression);\r\n }\r\n break;\r\n }\r\n case Token.SLASH_EQUALS: compound = true;\r\n case Token.SLASH: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.DIV);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n if (compound) {\r\n leftExpr = this.ensureSmallIntegerWrap(leftExpr, leftType);\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n } else {\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, true, // !\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, true, // !\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \"/\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n }\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8: // signed div on signed small integers might overflow, e.g. -128/-1\r\n case TypeKind.I16: // ^\r\n case TypeKind.I32: {\r\n expr = module.binary(BinaryOp.DivI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.DivI64\r\n : BinaryOp.DivI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64: {\r\n expr = module.binary(BinaryOp.DivI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.DivU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.DivU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.DivU64\r\n : BinaryOp.DivU32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.DivU64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.DivF32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.DivF64, leftExpr, rightExpr);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.PERCENT_EQUALS: compound = true;\r\n case Token.PERCENT: {\r\n leftExpr = this.compileExpression(left, contextualType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.REM);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n if (compound) {\r\n leftExpr = this.ensureSmallIntegerWrap(leftExpr, leftType);\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n } else {\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, true, // !\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, true, // !\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \"%\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n }\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16: {\r\n expr = module.binary(BinaryOp.RemI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I32: {\r\n expr = module.binary(BinaryOp.RemI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.RemI64\r\n : BinaryOp.RemI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64: {\r\n expr = module.binary(BinaryOp.RemI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.RemU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.RemU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.RemU64\r\n : BinaryOp.RemU32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.RemU64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n let instance = this.f32ModInstance;\r\n if (!instance) {\r\n let namespace = this.program.lookupGlobal(CommonSymbols.Mathf);\r\n if (!namespace) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n expression.range, \"Mathf\"\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n let prototype = namespace.members ? namespace.members.get(CommonSymbols.mod) : null;\r\n if (!prototype) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n expression.range, \"Mathf.mod\"\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n assert(prototype.kind == ElementKind.FUNCTION_PROTOTYPE);\r\n this.f32ModInstance = instance = this.resolver.resolveFunction(prototype, null);\r\n }\r\n if (!(instance && this.compileFunction(instance))) {\r\n expr = module.unreachable();\r\n } else {\r\n expr = this.makeCallDirect(instance, [ leftExpr, rightExpr ], expression);\r\n }\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n let instance = this.f64ModInstance;\r\n if (!instance) {\r\n let namespace = this.program.lookupGlobal(CommonSymbols.Math);\r\n if (!namespace) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n expression.range, \"Math\"\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n let prototype = namespace.members ? namespace.members.get(CommonSymbols.mod) : null;\r\n if (!prototype) {\r\n this.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n expression.range, \"Math.mod\"\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n assert(prototype.kind == ElementKind.FUNCTION_PROTOTYPE);\r\n this.f64ModInstance = instance = this.resolver.resolveFunction(prototype, null);\r\n }\r\n if (!(instance && this.compileFunction(instance))) {\r\n expr = module.unreachable();\r\n } else {\r\n expr = this.makeCallDirect(instance, [ leftExpr, rightExpr ], expression);\r\n }\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.LESSTHAN_LESSTHAN_EQUALS: compound = true;\r\n case Token.LESSTHAN_LESSTHAN: {\r\n leftExpr = this.compileExpression(left, contextualType.intType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_SHL);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL:\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.ShlI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.ShlI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.ShlI64\r\n : BinaryOp.ShlI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.F32:\r\n case TypeKind.F64: {\r\n this.error(\r\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\r\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.GREATERTHAN_GREATERTHAN_EQUALS: compound = true;\r\n case Token.GREATERTHAN_GREATERTHAN: {\r\n leftExpr = this.compileExpression(left, contextualType.intType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_SHR);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n leftExpr = this.ensureSmallIntegerWrap(leftExpr, leftType); // must clear garbage bits\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16: {\r\n expr = module.binary(BinaryOp.ShrI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I32: {\r\n expr = module.binary(BinaryOp.ShrI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I64: {\r\n expr = module.binary(BinaryOp.ShrI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.ShrI64\r\n : BinaryOp.ShrI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.ShrU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.ShrU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.ShrU64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.ShrU64\r\n : BinaryOp.ShrU32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.F32:\r\n case TypeKind.F64: {\r\n this.error(\r\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\r\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS: compound = true;\r\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN: {\r\n leftExpr = this.compileExpression(left, contextualType.intType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_SHR_U);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n leftExpr = this.ensureSmallIntegerWrap(leftExpr, leftType); // must clear garbage bits\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n switch (this.currentType.kind) {\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL: { // assumes that unsigned shr on unsigned small integers does not overflow\r\n expr = module.binary(BinaryOp.ShrU32, leftExpr, rightExpr);\r\n }\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.ShrU32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.ShrU64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.ShrU64\r\n : BinaryOp.ShrU32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.F32:\r\n case TypeKind.F64: {\r\n this.error(\r\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\r\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.AMPERSAND_EQUALS: compound = true;\r\n case Token.AMPERSAND: {\r\n leftExpr = this.compileExpression(left, contextualType.intType);\r\n leftType = this.currentType;\r\n\r\n // check operator overloadd\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_AND);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n if (compound) {\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n } else {\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, false,\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, false,\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \"&\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n }\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL:\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.AndI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.AndI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.AndI64\r\n : BinaryOp.AndI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.F32:\r\n case TypeKind.F64: {\r\n this.error(\r\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\r\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.BAR_EQUALS: compound = true;\r\n case Token.BAR: {\r\n leftExpr = this.compileExpression(left, contextualType.intType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_OR);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n if (compound) {\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n } else {\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, false,\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, false,\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \"|\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n }\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.OrI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.OrI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.OrI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.OrI64\r\n : BinaryOp.OrI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.F32:\r\n case TypeKind.F64: {\r\n this.error(\r\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\r\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.CARET_EQUALS: compound = true;\r\n case Token.CARET: {\r\n leftExpr = this.compileExpression(left, contextualType.intType);\r\n leftType = this.currentType;\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = leftType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_XOR);\r\n if (overload) {\r\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n if (compound) {\r\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\r\n rightType = this.currentType;\r\n } else {\r\n rightExpr = this.compileExpression(right, leftType);\r\n rightType = this.currentType;\r\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\r\n leftExpr = this.convertExpression(leftExpr,\r\n leftType, leftType = commonType,\r\n false, false,\r\n left\r\n );\r\n rightExpr = this.convertExpression(rightExpr,\r\n rightType, rightType = commonType,\r\n false, false,\r\n right\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\r\n expression.range, \"^\", leftType.toString(), rightType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n }\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.XorI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.XorI32, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.XorI64, leftExpr, rightExpr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.XorI64\r\n : BinaryOp.XorI32,\r\n leftExpr,\r\n rightExpr\r\n );\r\n break;\r\n }\r\n case TypeKind.F32:\r\n case TypeKind.F64: {\r\n this.error(\r\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\r\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n\r\n // logical (no overloading)\r\n\r\n case Token.AMPERSAND_AMPERSAND: { // left && right -> (t = left) ? right : t\r\n let flow = this.currentFlow;\r\n let inheritedConstraints = constraints & (Constraints.WILL_RETAIN | Constraints.MUST_WRAP);\r\n leftExpr = this.compileExpression(left, contextualType.exceptVoid, inheritedConstraints);\r\n leftType = this.currentType;\r\n\r\n let rightFlow = flow.fork();\r\n this.currentFlow = rightFlow;\r\n rightFlow.inheritNonnullIfTrue(leftExpr);\r\n rightExpr = this.compileExpression(right, leftType, inheritedConstraints | Constraints.CONV_IMPLICIT);\r\n rightType = leftType;\r\n\r\n // simplify if only interested in true or false\r\n if (contextualType == Type.bool || contextualType == Type.void) {\r\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, rightType);\r\n rightFlow.freeScopedLocals();\r\n this.currentFlow = flow;\r\n this.currentType = Type.bool;\r\n expr = module.if(\r\n this.makeIsTrueish(leftExpr, leftType),\r\n this.makeIsTrueish(rightExpr, rightType),\r\n module.i32(0)\r\n );\r\n\r\n // references must properly retain and release, with the same outcome independent of the branch taken\r\n } else if (leftType.isManaged) {\r\n let leftAutoreleaseSkipped = this.skippedAutoreleases.has(leftExpr);\r\n let rightAutoreleaseSkipped = this.skippedAutoreleases.has(rightExpr);\r\n let temp = flow.getTempLocal(leftType);\r\n leftExpr = module.local_tee(temp.index, leftExpr);\r\n\r\n // instead of retaining left and releasing it again in right when right\r\n // is taken, we can also just retain left if right is not taken\r\n let retainLeftInElse = false;\r\n if (leftAutoreleaseSkipped != rightAutoreleaseSkipped) { // xor\r\n if (!leftAutoreleaseSkipped) {\r\n retainLeftInElse = true;\r\n } else {\r\n rightExpr = this.makeRetain(rightExpr);\r\n rightAutoreleaseSkipped = true;\r\n }\r\n } else if (!(constraints & Constraints.WILL_RETAIN)) { // otherwise keep right alive a little longer\r\n rightExpr = this.moveAutorelease(rightExpr, rightFlow, flow);\r\n }\r\n\r\n let rightStmts = new Array();\r\n if (leftAutoreleaseSkipped) { // left turned out to be true'ish and is dropped\r\n rightStmts.unshift(\r\n this.makeRelease(\r\n module.local_get(temp.index, leftType.toNativeType())\r\n )\r\n );\r\n }\r\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, rightType, rightStmts);\r\n rightFlow.freeScopedLocals();\r\n this.currentFlow = flow;\r\n\r\n expr = module.if(\r\n this.makeIsTrueish(leftExpr, leftType),\r\n rightExpr,\r\n retainLeftInElse\r\n ? this.makeRetain(\r\n module.local_get(temp.index, leftType.toNativeType())\r\n )\r\n : module.local_get(temp.index, leftType.toNativeType())\r\n );\r\n if (leftAutoreleaseSkipped || rightAutoreleaseSkipped) this.skippedAutoreleases.add(expr);\r\n if (temp) flow.freeTempLocal(temp);\r\n\r\n // basic values can use more aggressive optimizations\r\n } else {\r\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, rightType);\r\n rightFlow.freeScopedLocals();\r\n this.currentFlow = flow;\r\n\r\n // simplify if cloning left without side effects is possible\r\n if (expr = module.cloneExpression(leftExpr, true, 0)) {\r\n expr = module.if(\r\n this.makeIsTrueish(leftExpr, this.currentType),\r\n rightExpr,\r\n expr\r\n );\r\n\r\n // if not possible, tee left to a temp\r\n } else {\r\n let tempLocal = flow.getTempLocal(leftType);\r\n if (!flow.canOverflow(leftExpr, leftType)) flow.setLocalFlag(tempLocal.index, LocalFlags.WRAPPED);\r\n if (flow.isNonnull(leftExpr, leftType)) flow.setLocalFlag(tempLocal.index, LocalFlags.NONNULL);\r\n expr = module.if(\r\n this.makeIsTrueish(module.local_tee(tempLocal.index, leftExpr), leftType),\r\n rightExpr,\r\n module.local_get(tempLocal.index, leftType.toNativeType())\r\n );\r\n }\r\n }\r\n this.currentType = leftType;\r\n break;\r\n }\r\n case Token.BAR_BAR: { // left || right -> ((t = left) ? t : right)\r\n let flow = this.currentFlow;\r\n let inheritedConstraints = constraints & (Constraints.WILL_RETAIN | Constraints.MUST_WRAP);\r\n leftExpr = this.compileExpression(left, contextualType.exceptVoid, inheritedConstraints);\r\n leftType = this.currentType;\r\n\r\n let rightFlow = flow.fork();\r\n this.currentFlow = rightFlow;\r\n rightFlow.inheritNonnullIfFalse(leftExpr);\r\n rightExpr = this.compileExpression(right, leftType, inheritedConstraints | Constraints.CONV_IMPLICIT);\r\n rightType = leftType;\r\n\r\n // simplify if only interested in true or false\r\n if (contextualType == Type.bool || contextualType == Type.void) {\r\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, leftType);\r\n rightFlow.freeScopedLocals();\r\n this.currentFlow = flow;\r\n this.currentType = Type.bool;\r\n expr = module.if(\r\n this.makeIsTrueish(leftExpr, leftType),\r\n module.i32(1),\r\n this.makeIsTrueish(rightExpr, rightType)\r\n );\r\n\r\n // references must properly retain and release, with the same outcome independent of the branch taken\r\n } else if (leftType.isManaged) {\r\n let leftAutoreleaseSkipped = this.skippedAutoreleases.has(leftExpr);\r\n let rightAutoreleaseSkipped = this.skippedAutoreleases.has(rightExpr);\r\n let temp = flow.getTempLocal(leftType);\r\n leftExpr = module.local_tee(temp.index, leftExpr);\r\n\r\n // instead of retaining left and releasing it again in right when right\r\n // is taken, we can also just retain left if right is not taken\r\n let retainLeftInThen = false;\r\n if (leftAutoreleaseSkipped != rightAutoreleaseSkipped) { // xor\r\n if (!leftAutoreleaseSkipped) {\r\n retainLeftInThen = true;\r\n } else {\r\n rightExpr = this.makeRetain(rightExpr);\r\n rightAutoreleaseSkipped = true;\r\n }\r\n } else if (!(constraints & Constraints.WILL_RETAIN)) { // otherwise keep right alive a little longer\r\n rightExpr = this.moveAutorelease(rightExpr, rightFlow, flow);\r\n }\r\n\r\n let rightStmts = new Array();\r\n if (leftAutoreleaseSkipped) { // left turned out to be false'ish and is dropped\r\n // TODO: usually, false'ish means left is null, but this might not hold\r\n // once implicit conversion with strings is performed and left is \"\", so:\r\n rightStmts.unshift(\r\n this.makeRelease(\r\n module.local_get(temp.index, leftType.toNativeType())\r\n )\r\n );\r\n }\r\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, rightType, rightStmts);\r\n rightFlow.freeScopedLocals();\r\n this.currentFlow = flow;\r\n\r\n expr = module.if(\r\n this.makeIsTrueish(leftExpr, leftType),\r\n retainLeftInThen\r\n ? this.makeRetain(\r\n module.local_get(temp.index, leftType.toNativeType())\r\n )\r\n : module.local_get(temp.index, leftType.toNativeType()),\r\n rightExpr\r\n );\r\n if (leftAutoreleaseSkipped || rightAutoreleaseSkipped) this.skippedAutoreleases.add(expr);\r\n if (temp) flow.freeTempLocal(temp);\r\n\r\n // basic values can use more aggressive optimizations\r\n } else {\r\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, rightType);\r\n rightFlow.freeScopedLocals();\r\n this.currentFlow = flow;\r\n\r\n // simplify if cloning left without side effects is possible\r\n if (expr = module.cloneExpression(leftExpr, true, 0)) {\r\n expr = module.if(\r\n this.makeIsTrueish(leftExpr, leftType),\r\n expr,\r\n rightExpr\r\n );\r\n\r\n // if not possible, tee left to a temp. local\r\n } else {\r\n let tempLocal = flow.getAndFreeTempLocal(leftType);\r\n if (!flow.canOverflow(leftExpr, leftType)) flow.setLocalFlag(tempLocal.index, LocalFlags.WRAPPED);\r\n if (flow.isNonnull(leftExpr, leftType)) flow.setLocalFlag(tempLocal.index, LocalFlags.NONNULL);\r\n expr = module.if(\r\n this.makeIsTrueish(module.local_tee(tempLocal.index, leftExpr), leftType),\r\n module.local_get(tempLocal.index, leftType.toNativeType()),\r\n rightExpr\r\n );\r\n }\r\n }\r\n this.currentType = leftType;\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = this.module.unreachable();\r\n }\r\n }\r\n if (!compound) return expr;\r\n var resolver = this.resolver;\r\n var target = this.resolver.resolveExpression(left, this.currentFlow);\r\n if (!target) return module.unreachable();\r\n return this.makeAssignment(\r\n target,\r\n expr, // TODO: delay release above if possible?\r\n left,\r\n resolver.currentThisExpression,\r\n resolver.currentElementExpression,\r\n contextualType != Type.void\r\n );\r\n }\r\n\r\n compileUnaryOverload(\r\n operatorInstance: Function,\r\n value: Expression,\r\n valueExpr: ExpressionRef,\r\n reportNode: Node\r\n ): ExpressionRef {\r\n // FIXME: see comment in compileBinaryOverload below why recompiling on type mismatch\r\n // is a bad idea currently. so this assumes that the type matches.\r\n return this.makeCallDirect(operatorInstance, [ valueExpr ], reportNode, false);\r\n }\r\n\r\n compileBinaryOverload(\r\n operatorInstance: Function,\r\n left: Expression,\r\n leftExpr: ExpressionRef,\r\n right: Expression,\r\n reportNode: Node\r\n ): ExpressionRef {\r\n var rightType: Type;\r\n if (operatorInstance.is(CommonFlags.INSTANCE)) {\r\n let classInstance = assert(operatorInstance.parent); assert(classInstance.kind == ElementKind.CLASS);\r\n rightType = operatorInstance.signature.parameterTypes[0];\r\n } else {\r\n // FIXME: if LHS type differs we can't recompile left because that'd completely confuse\r\n // local states, like having retained locals that actually do not even exist, possibly\r\n // releasing something random in that local before and evil things like that. Hence this\r\n // assumes that LHS type matches, which in turn means that static overloads must be\r\n // guaranteed to never mismatch LHS type, which in turn means that we can't have shiny\r\n // things like multiple static overloads for different combinations of LHS/RHS types.\r\n // We might want that at some point of course, but requires to complete the resolver so\r\n // it can actually resolve every kind of expression without ever having to recompile.\r\n rightType = operatorInstance.signature.parameterTypes[1];\r\n }\r\n var rightExpr = this.compileExpression(right, rightType, Constraints.CONV_IMPLICIT);\r\n return this.makeCallDirect(operatorInstance, [ leftExpr, rightExpr ], reportNode);\r\n }\r\n\r\n compileAssignment(expression: Expression, valueExpression: Expression, contextualType: Type): ExpressionRef {\r\n var program = this.program;\r\n var resolver = program.resolver;\r\n var flow = this.currentFlow;\r\n var target = resolver.resolveExpression(expression, flow); // reports\r\n if (!target) return this.module.unreachable();\r\n var thisExpression = resolver.currentThisExpression;\r\n var elementExpression = resolver.currentElementExpression;\r\n\r\n // to compile just the value, we need to know the target's type\r\n var targetType: Type;\r\n switch (target.kind) {\r\n case ElementKind.GLOBAL: {\r\n // not yet compiled if a static field compiled as a global\r\n if (!this.compileGlobal(target)) return this.module.unreachable(); // reports\r\n // fall-through\r\n }\r\n case ElementKind.FIELD: {\r\n targetType = (target).type;\r\n break;\r\n }\r\n case ElementKind.LOCAL: {\r\n targetType = (target).type;\r\n break;\r\n }\r\n case ElementKind.PROPERTY_PROTOTYPE: { // static property\r\n let setterPrototype = (target).setterPrototype;\r\n if (!setterPrototype) {\r\n this.error(\r\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\r\n expression.range, (target).internalName\r\n );\r\n return this.module.unreachable();\r\n }\r\n let setterInstance = this.resolver.resolveFunction(setterPrototype, null, makeMap(), ReportMode.REPORT);\r\n if (!setterInstance) return this.module.unreachable();\r\n assert(setterInstance.signature.parameterTypes.length == 1); // parser must guarantee this\r\n targetType = setterInstance.signature.parameterTypes[0];\r\n break;\r\n }\r\n case ElementKind.PROPERTY: { // instance property\r\n let setterInstance = (target).setterInstance;\r\n if (!setterInstance) {\r\n this.error(\r\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\r\n expression.range, (target).internalName\r\n );\r\n return this.module.unreachable();\r\n }\r\n assert(setterInstance.signature.parameterTypes.length == 1); // parser must guarantee this\r\n targetType = setterInstance.signature.parameterTypes[0];\r\n break;\r\n }\r\n case ElementKind.CLASS: {\r\n if (elementExpression) { // indexed access\r\n let isUnchecked = flow.is(FlowFlags.UNCHECKED_CONTEXT);\r\n // if (isUnchecked) {\r\n // let arrayType = this.program.determineBuiltinArrayType(target);\r\n // if (arrayType) {\r\n // return compileBuiltinArraySet(\r\n // this,\r\n // target,\r\n // assert(this.resolver.currentThisExpression),\r\n // elementExpression,\r\n // valueExpression,\r\n // contextualType\r\n // );\r\n // }\r\n // }\r\n let indexedSet = (target).lookupOverload(OperatorKind.INDEXED_SET, isUnchecked);\r\n if (!indexedSet) {\r\n let indexedGet = (target).lookupOverload(OperatorKind.INDEXED_GET, isUnchecked);\r\n if (!indexedGet) {\r\n this.error(\r\n DiagnosticCode.Index_signature_is_missing_in_type_0,\r\n expression.range, (target).internalName\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Index_signature_in_type_0_only_permits_reading,\r\n expression.range, (target).internalName\r\n );\r\n }\r\n return this.module.unreachable();\r\n }\r\n assert(indexedSet.signature.parameterTypes.length == 2); // parser must guarantee this\r\n targetType = indexedSet.signature.parameterTypes[1]; // 2nd parameter is the element\r\n break;\r\n }\r\n // fall-through\r\n }\r\n default: {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n }\r\n\r\n // compile the value and do the assignment\r\n assert(targetType != Type.void);\r\n return this.makeAssignment(\r\n target,\r\n this.compileExpression(valueExpression, targetType, Constraints.CONV_IMPLICIT | Constraints.WILL_RETAIN),\r\n expression,\r\n thisExpression,\r\n elementExpression,\r\n contextualType != Type.void\r\n );\r\n }\r\n\r\n /** Makes an assignment expression or block, assigning a value to a target. */\r\n makeAssignment(\r\n /** Target element, e.g. a Local. */\r\n target: Element,\r\n /** Value expression that has been compiled in a previous step already. */\r\n valueExpr: ExpressionRef,\r\n /** Expression reference. Has already been compiled to `valueExpr`. */\r\n valueExpression: Expression,\r\n /** `this` expression reference if a field or property set. */\r\n thisExpression: Expression | null,\r\n /** Index expression reference if an indexed set. */\r\n indexExpression: Expression | null,\r\n /** Whether to tee the value. */\r\n tee: bool\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n\r\n // NOTE: Only locals, globals and fields can make use of skipped autoreleases while\r\n // everything else must insert the skipped autorelease now. See (*)\r\n\r\n switch (target.kind) {\r\n case ElementKind.LOCAL: {\r\n if (flow.isLocalFlag((target).index, LocalFlags.CONSTANT, true)) {\r\n this.error(\r\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\r\n valueExpression.range, target.internalName\r\n );\r\n this.currentType = tee ? (target).type : Type.void;\r\n return module.unreachable();\r\n }\r\n return this.makeLocalAssignment(target, valueExpr, tee);\r\n }\r\n case ElementKind.GLOBAL: {\r\n if (!this.compileGlobal(target)) return module.unreachable();\r\n if (target.isAny(CommonFlags.CONST | CommonFlags.READONLY)) {\r\n this.error(\r\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\r\n valueExpression.range,\r\n target.internalName\r\n );\r\n this.currentType = tee ? (target).type : Type.void;\r\n return module.unreachable();\r\n }\r\n return this.makeGlobalAssignment(target, valueExpr, tee);\r\n }\r\n case ElementKind.FIELD: {\r\n let initializerNode = (target).initializerNode;\r\n if (\r\n (target).is(CommonFlags.READONLY) &&\r\n !(\r\n flow.actualFunction.is(CommonFlags.CONSTRUCTOR) ||\r\n initializerNode\r\n )\r\n ) {\r\n this.error(\r\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\r\n valueExpression.range, (target).internalName\r\n );\r\n return module.unreachable();\r\n }\r\n return this.makeFieldAssignment(target,\r\n valueExpr,\r\n // FIXME: explicit type (currently fails due to missing null checking)\r\n this.compileExpression(assert(thisExpression), this.options.usizeType),\r\n tee\r\n );\r\n }\r\n case ElementKind.PROPERTY_PROTOTYPE: { // static property\r\n if (this.skippedAutoreleases.has(valueExpr)) valueExpr = this.makeAutorelease(valueExpr, flow); // (*)\r\n let setterPrototype = (target).setterPrototype;\r\n if (!setterPrototype) {\r\n this.error(\r\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\r\n valueExpression.range, target.internalName\r\n );\r\n return module.unreachable();\r\n }\r\n let setterInstance = this.resolver.resolveFunction(setterPrototype, null, makeMap(), ReportMode.REPORT);\r\n if (!setterInstance) return module.unreachable();\r\n // call just the setter if the return value isn't of interest\r\n if (!tee) return this.makeCallDirect(setterInstance, [ valueExpr ], valueExpression);\r\n // otherwise call the setter first, then the getter\r\n let getterPrototype = assert((target).getterPrototype); // must be present\r\n let getterInstance = this.resolver.resolveFunction(getterPrototype, null, makeMap(), ReportMode.REPORT);\r\n if (!getterInstance) return module.unreachable();\r\n let returnType = getterInstance.signature.returnType;\r\n let nativeReturnType = returnType.toNativeType();\r\n return module.block(null, [\r\n this.makeCallDirect(setterInstance, [ valueExpr ], valueExpression),\r\n this.makeCallDirect(getterInstance, null, valueExpression) // sets currentType\r\n ], nativeReturnType);\r\n }\r\n case ElementKind.PROPERTY: { // instance property\r\n if (this.skippedAutoreleases.has(valueExpr)) valueExpr = this.makeAutorelease(valueExpr, flow); // (*)\r\n let setterInstance = (target).setterInstance;\r\n if (!setterInstance) {\r\n this.error(\r\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\r\n valueExpression.range, target.internalName\r\n );\r\n return module.unreachable();\r\n }\r\n // call just the setter if the return value isn't of interest\r\n if (!tee) {\r\n let thisExpr = this.compileExpression(assert(thisExpression), this.options.usizeType);\r\n return this.makeCallDirect(setterInstance, [ thisExpr, valueExpr ], valueExpression);\r\n }\r\n // otherwise call the setter first, then the getter\r\n let getterInstance = assert((target).getterInstance); // must be present\r\n let returnType = getterInstance.signature.returnType;\r\n let nativeReturnType = returnType.toNativeType();\r\n let thisExpr = this.compileExpression(assert(thisExpression), this.options.usizeType);\r\n let tempLocal = flow.getAndFreeTempLocal(returnType);\r\n let tempLocalIndex = tempLocal.index;\r\n return module.block(null, [\r\n this.makeCallDirect(setterInstance, [ // set and remember the target\r\n module.local_tee(tempLocalIndex, thisExpr),\r\n valueExpr\r\n ], valueExpression),\r\n this.makeCallDirect(getterInstance, [ // get from remembered target\r\n module.local_get(tempLocalIndex, nativeReturnType)\r\n ], valueExpression)\r\n ], nativeReturnType);\r\n }\r\n case ElementKind.CLASS: {\r\n if (this.skippedAutoreleases.has(valueExpr)) valueExpr = this.makeAutorelease(valueExpr, flow); // (*)\r\n if (indexExpression) {\r\n let isUnchecked = flow.is(FlowFlags.UNCHECKED_CONTEXT);\r\n let indexedGet = (target).lookupOverload(OperatorKind.INDEXED_GET, isUnchecked);\r\n if (!indexedGet) {\r\n this.error(\r\n DiagnosticCode.Index_signature_is_missing_in_type_0,\r\n valueExpression.range, target.internalName\r\n );\r\n return module.unreachable();\r\n }\r\n let indexedSet = (target).lookupOverload(OperatorKind.INDEXED_SET, isUnchecked);\r\n if (!indexedSet) {\r\n this.error(\r\n DiagnosticCode.Index_signature_in_type_0_only_permits_reading,\r\n valueExpression.range, target.internalName\r\n );\r\n this.currentType = tee ? indexedGet.signature.returnType : Type.void;\r\n return module.unreachable();\r\n }\r\n let targetType = (target).type;\r\n let thisExpr = this.compileExpression(assert(thisExpression), this.options.usizeType);\r\n let elementExpr = this.compileExpression(indexExpression, Type.i32, Constraints.CONV_IMPLICIT);\r\n if (tee) {\r\n let tempLocalTarget = flow.getTempLocal(targetType);\r\n let tempLocalElement = flow.getAndFreeTempLocal(this.currentType);\r\n let returnType = indexedGet.signature.returnType;\r\n flow.freeTempLocal(tempLocalTarget);\r\n return module.block(null, [\r\n this.makeCallDirect(indexedSet, [\r\n module.local_tee(tempLocalTarget.index, thisExpr),\r\n module.local_tee(tempLocalElement.index, elementExpr),\r\n valueExpr\r\n ], valueExpression),\r\n this.makeCallDirect(indexedGet, [\r\n module.local_get(tempLocalTarget.index, tempLocalTarget.type.toNativeType()),\r\n module.local_get(tempLocalElement.index, tempLocalElement.type.toNativeType())\r\n ], valueExpression)\r\n ], returnType.toNativeType());\r\n } else {\r\n return this.makeCallDirect(indexedSet, [\r\n thisExpr,\r\n elementExpr,\r\n valueExpr\r\n ], valueExpression);\r\n }\r\n }\r\n // fall-through\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n valueExpression.range\r\n );\r\n return module.unreachable();\r\n }\r\n\r\n /** Makes an assignment to a local, possibly retaining and releasing affected references and keeping track of wrap and null states. */\r\n private makeLocalAssignment(\r\n /** The local to assign to. */\r\n local: Local,\r\n /** The value to assign. */\r\n valueExpr: ExpressionRef,\r\n /** Whether to tee the value. */\r\n tee: bool\r\n ): ExpressionRef {\r\n var type = local.type;\r\n assert(type != Type.void);\r\n var flow = this.currentFlow;\r\n var localIndex = local.index;\r\n\r\n if (type.is(TypeFlags.NULLABLE)) {\r\n if (flow.isNonnull(valueExpr, type)) flow.setLocalFlag(localIndex, LocalFlags.NONNULL);\r\n else flow.unsetLocalFlag(localIndex, LocalFlags.NONNULL);\r\n }\r\n flow.setLocalFlag(localIndex, LocalFlags.WRITTENTO);\r\n\r\n if (type.isManaged) {\r\n let module = this.module;\r\n let nativeType = type.toNativeType();\r\n\r\n if (flow.isAnyLocalFlag(localIndex, LocalFlags.ANY_RETAINED)) {\r\n if (this.skippedAutoreleases.has(valueExpr)) {\r\n valueExpr = this.makeSkippedRelease(\r\n module.local_get(localIndex, nativeType), // oldRef\r\n valueExpr // newRef\r\n );\r\n if (tee) { // TEE(local = __skippedRelease(local, value))\r\n this.currentType = type;\r\n return module.local_tee(localIndex, valueExpr);\r\n } else { // local = __skippedRelease(local, value)\r\n this.currentType = Type.void;\r\n return module.local_set(localIndex, valueExpr);\r\n }\r\n } else {\r\n valueExpr = this.makeRetainRelease(\r\n module.local_get(localIndex, nativeType), // oldRef\r\n valueExpr // newRef\r\n );\r\n if (tee) { // TEE(local = __retainRelease(local, value))\r\n this.currentType = type;\r\n return module.local_tee(localIndex, valueExpr);\r\n } else { // local = __retainRelease(local, value)\r\n this.currentType = Type.void;\r\n return module.local_set(localIndex, valueExpr);\r\n }\r\n }\r\n } else {\r\n flow.unsetLocalFlag(localIndex, LocalFlags.CONDITIONALLY_RETAINED);\r\n flow.setLocalFlag(localIndex, LocalFlags.RETAINED);\r\n if (!this.skippedAutoreleases.has(valueExpr)) valueExpr = this.makeRetain(valueExpr);\r\n if (tee) { // TEE(local = __retain(value, local))\r\n this.currentType = type;\r\n return module.local_tee(localIndex, valueExpr);\r\n } else { // local = __retain(value, local)\r\n this.currentType = Type.void;\r\n return module.local_set(localIndex, valueExpr);\r\n }\r\n }\r\n } else {\r\n if (type.is(TypeFlags.SHORT | TypeFlags.INTEGER)) {\r\n if (!flow.canOverflow(valueExpr, type)) flow.setLocalFlag(localIndex, LocalFlags.WRAPPED);\r\n else flow.unsetLocalFlag(localIndex, LocalFlags.WRAPPED);\r\n }\r\n if (tee) { // TEE(local = value)\r\n this.currentType = type;\r\n return this.module.local_tee(localIndex, valueExpr);\r\n } else { // local = value\r\n this.currentType = Type.void;\r\n return this.module.local_set(localIndex, valueExpr);\r\n }\r\n }\r\n }\r\n\r\n /** Makes an assignment to a global, possibly retaining and releasing affected references. */\r\n private makeGlobalAssignment(\r\n /** The global to assign to. */\r\n global: Global,\r\n /** The value to assign. */\r\n valueExpr: ExpressionRef,\r\n /** Whether to tee the value. */\r\n tee: bool\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var type = global.type;\r\n assert(type != Type.void);\r\n var nativeType = type.toNativeType();\r\n\r\n if (type.isManaged) {\r\n if (this.skippedAutoreleases.has(valueExpr)) {\r\n if (tee) { // (global = __skippedRelease(global, value)), global\r\n this.currentType = type;\r\n return module.block(null, [\r\n module.global_set(global.internalName,\r\n this.makeSkippedRelease(\r\n module.global_get(global.internalName, nativeType), // oldRef\r\n valueExpr // newRef\r\n )\r\n ),\r\n module.global_get(global.internalName, nativeType)\r\n ], nativeType);\r\n } else { // global = __skippedRelease(global, value)\r\n this.currentType = Type.void;\r\n return module.global_set(global.internalName,\r\n this.makeSkippedRelease(\r\n module.global_get(global.internalName, nativeType), // oldRef\r\n valueExpr // newRef\r\n )\r\n );\r\n }\r\n } else {\r\n if (tee) { // (global = __retainRelease(global, value)), global\r\n this.currentType = type;\r\n return module.block(null, [\r\n module.global_set(global.internalName,\r\n this.makeRetainRelease(\r\n module.global_get(global.internalName, nativeType), // oldRef\r\n valueExpr // newRef\r\n )\r\n ),\r\n module.global_get(global.internalName, nativeType)\r\n ], nativeType);\r\n } else { // global = __retainRelease(global, value)\r\n this.currentType = Type.void;\r\n return module.global_set(global.internalName,\r\n this.makeRetainRelease(\r\n module.global_get(global.internalName, nativeType), // oldRef\r\n valueExpr // newRef\r\n )\r\n );\r\n }\r\n }\r\n } else {\r\n valueExpr = this.ensureSmallIntegerWrap(valueExpr, type); // globals must be wrapped\r\n if (tee) { // (global = value), global\r\n this.currentType = type;\r\n return module.block(null, [\r\n module.global_set(global.internalName, valueExpr),\r\n module.global_get(global.internalName, nativeType)\r\n ], nativeType);\r\n } else { // global = value\r\n this.currentType = Type.void;\r\n return module.global_set(global.internalName,\r\n valueExpr\r\n );\r\n }\r\n }\r\n }\r\n\r\n /** Makes an assignment to a field, possibly retaining and releasing affected references. */\r\n makeFieldAssignment(\r\n /** The field to assign to. */\r\n field: Field,\r\n /** The value to assign. */\r\n valueExpr: ExpressionRef,\r\n /** The value of `this`. */\r\n thisExpr: ExpressionRef,\r\n /** Whether to tee the value. */\r\n tee: bool\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n var fieldType = field.type;\r\n var nativeFieldType = fieldType.toNativeType();\r\n assert(field.parent.kind == ElementKind.CLASS);\r\n var thisType = (field.parent).type;\r\n var nativeThisType = thisType.toNativeType();\r\n\r\n if (fieldType.isManaged && thisType.isManaged) {\r\n let tempThis = flow.getTempLocal(thisType);\r\n if (this.skippedAutoreleases.has(valueExpr)) {\r\n if (tee) { // ((t1 = this).field = __skippedRelease(t1.field, t2 = value)), t2\r\n let tempValue = flow.getAndFreeTempLocal(fieldType);\r\n if (!flow.canOverflow(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.WRAPPED);\r\n if (flow.isNonnull(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.NONNULL);\r\n flow.freeTempLocal(tempThis);\r\n this.currentType = fieldType;\r\n return module.block(null, [\r\n module.store(fieldType.byteSize,\r\n module.local_tee(tempThis.index, thisExpr),\r\n this.makeSkippedRelease(\r\n module.load(fieldType.byteSize, fieldType.is(TypeFlags.SIGNED), // oldRef\r\n module.local_get(tempThis.index, nativeThisType),\r\n nativeFieldType, field.memoryOffset\r\n ),\r\n module.local_tee(tempValue.index, valueExpr), // newRef\r\n ),\r\n nativeFieldType, field.memoryOffset\r\n ),\r\n module.local_get(tempValue.index, nativeFieldType)\r\n ], nativeFieldType);\r\n } else { // (t1 = this).field = __skippedRelease(t1.field, value)\r\n flow.freeTempLocal(tempThis);\r\n this.currentType = Type.void;\r\n return module.store(fieldType.byteSize,\r\n module.local_tee(tempThis.index, thisExpr),\r\n this.makeSkippedRelease(\r\n module.load(fieldType.byteSize, fieldType.is(TypeFlags.SIGNED), // oldRef\r\n module.local_get(tempThis.index, nativeThisType),\r\n nativeFieldType, field.memoryOffset\r\n ),\r\n valueExpr, // newRef\r\n ),\r\n nativeFieldType, field.memoryOffset\r\n );\r\n }\r\n } else {\r\n if (tee) { // ((t1 = this).field = __retainRelease(t1.field, t2 = value)), t2\r\n let tempValue = flow.getAndFreeTempLocal(fieldType);\r\n if (!flow.canOverflow(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.WRAPPED);\r\n if (flow.isNonnull(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.NONNULL);\r\n flow.freeTempLocal(tempThis);\r\n this.currentType = fieldType;\r\n return module.block(null, [\r\n module.store(fieldType.byteSize,\r\n module.local_tee(tempThis.index, thisExpr),\r\n this.makeRetainRelease(\r\n module.load(fieldType.byteSize, fieldType.is(TypeFlags.SIGNED), // oldRef\r\n module.local_get(tempThis.index, nativeThisType),\r\n nativeFieldType, field.memoryOffset\r\n ),\r\n module.local_tee(tempValue.index, valueExpr) // newRef\r\n ),\r\n nativeFieldType, field.memoryOffset\r\n ),\r\n module.local_get(tempValue.index, nativeFieldType)\r\n ], nativeFieldType);\r\n } else { // (t1 = this).field = __retainRelease(t1.field, value)\r\n flow.freeTempLocal(tempThis);\r\n this.currentType = Type.void;\r\n return module.store(fieldType.byteSize,\r\n module.local_tee(tempThis.index, thisExpr),\r\n this.makeRetainRelease(\r\n module.load(fieldType.byteSize, fieldType.is(TypeFlags.SIGNED), // oldRef\r\n module.local_get(tempThis.index, nativeThisType),\r\n nativeFieldType, field.memoryOffset\r\n ),\r\n valueExpr // newRef\r\n ),\r\n nativeFieldType, field.memoryOffset\r\n );\r\n }\r\n }\r\n } else {\r\n if (tee) { // (this.field = (t1 = value)), t1\r\n let tempValue = flow.getAndFreeTempLocal(fieldType);\r\n if (!flow.canOverflow(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.WRAPPED);\r\n if (flow.isNonnull(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.NONNULL);\r\n this.currentType = fieldType;\r\n return module.block(null, [\r\n module.store(fieldType.byteSize,\r\n thisExpr,\r\n module.local_tee(tempValue.index, valueExpr),\r\n nativeFieldType, field.memoryOffset\r\n ),\r\n module.local_get(tempValue.index, nativeFieldType)\r\n ], nativeFieldType);\r\n } else { // this.field = value\r\n this.currentType = Type.void;\r\n return module.store(fieldType.byteSize,\r\n thisExpr,\r\n valueExpr,\r\n nativeFieldType, field.memoryOffset\r\n );\r\n }\r\n }\r\n }\r\n\r\n /** Compiles a call expression according to the specified context. */\r\n compileCallExpression(\r\n /** Call expression to compile. */\r\n expression: CallExpression,\r\n /** Contextual type indicating the return type the caller expects, if any. */\r\n contextualType: Type,\r\n /** Constraints indicating contextual conditions. */\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n\r\n // handle call to super\r\n if (expression.expression.kind == NodeKind.SUPER) {\r\n let flow = this.currentFlow;\r\n let actualFunction = flow.actualFunction;\r\n if (!actualFunction.is(CommonFlags.CONSTRUCTOR)) {\r\n this.error(\r\n DiagnosticCode.Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n\r\n let classInstance = assert(actualFunction.parent); assert(classInstance.kind == ElementKind.CLASS);\r\n let baseClassInstance = assert((classInstance).base);\r\n let thisLocal = assert(flow.lookupLocal(CommonSymbols.this_));\r\n let nativeSizeType = this.options.nativeSizeType;\r\n\r\n // {\r\n // this = super(this || , ...args)\r\n // this.a = X\r\n // this.b = Y\r\n // }\r\n let theCall = this.compileCallDirect(\r\n this.ensureConstructor(baseClassInstance, expression),\r\n expression.arguments,\r\n expression,\r\n module.if(\r\n module.local_get(thisLocal.index, nativeSizeType),\r\n module.local_get(thisLocal.index, nativeSizeType),\r\n this.makeRetain(\r\n this.makeAllocation(classInstance)\r\n )\r\n ),\r\n Constraints.WILL_RETAIN\r\n );\r\n assert(this.skippedAutoreleases.has(theCall)); // guaranteed\r\n let stmts: ExpressionRef[] = [\r\n module.local_set(thisLocal.index, theCall)\r\n ];\r\n this.makeFieldInitialization(classInstance, stmts);\r\n\r\n // check that super had been called before accessing `this`\r\n if (flow.isAny(\r\n FlowFlags.ALLOCATES |\r\n FlowFlags.CONDITIONALLY_ALLOCATES\r\n )) {\r\n this.error(\r\n DiagnosticCode._super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n flow.set(FlowFlags.ALLOCATES | FlowFlags.CALLS_SUPER);\r\n this.currentType = Type.void;\r\n return module.block(null, stmts);\r\n }\r\n\r\n // otherwise resolve normally\r\n var target = this.resolver.resolveExpression(expression.expression, flow); // reports\r\n if (!target) return module.unreachable();\r\n\r\n var signature: Signature | null;\r\n var indexArg: ExpressionRef;\r\n switch (target.kind) {\r\n\r\n // direct call: concrete function\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n let prototype = target;\r\n let typeArguments = expression.typeArguments;\r\n\r\n // builtins handle present respectively omitted type arguments on their own\r\n if (prototype.hasDecorator(DecoratorFlags.BUILTIN)) {\r\n return this.compileCallExpressionBuiltin(prototype, expression, contextualType);\r\n }\r\n\r\n let instance: Function | null = null;\r\n\r\n // resolve generic call if type arguments have been provided\r\n if (typeArguments) {\r\n if (!prototype.is(CommonFlags.GENERIC)) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n expression.expression.range, prototype.internalName\r\n );\r\n return module.unreachable();\r\n }\r\n instance = this.resolver.resolveFunctionInclTypeArguments(\r\n prototype,\r\n typeArguments,\r\n flow.actualFunction.parent, // relative to caller\r\n makeMap(flow.contextualTypeArguments),\r\n expression\r\n );\r\n\r\n // infer generic call if type arguments have been omitted\r\n } else if (prototype.is(CommonFlags.GENERIC)) {\r\n let inferredTypes = new Map();\r\n let typeParameterNodes = assert(prototype.typeParameterNodes);\r\n let numTypeParameters = typeParameterNodes.length;\r\n for (let i = 0; i < numTypeParameters; ++i) {\r\n inferredTypes.set(typeParameterNodes[i].name.text, null);\r\n }\r\n // let numInferred = 0;\r\n let parameterNodes = prototype.signatureNode.parameters;\r\n let numParameters = parameterNodes.length;\r\n let argumentNodes = expression.arguments;\r\n let numArguments = argumentNodes.length;\r\n let argumentExprs = new Array(numArguments);\r\n for (let i = 0; i < numParameters; ++i) {\r\n let typeNode = parameterNodes[i].type;\r\n let templateName = typeNode.kind == NodeKind.TYPE && !(typeNode).name.next\r\n ? (typeNode).name.identifier.text\r\n : null;\r\n let argumentExpression = i < numArguments\r\n ? argumentNodes[i]\r\n : parameterNodes[i].initializer;\r\n if (!argumentExpression) { // missing initializer -> too few arguments\r\n this.error(\r\n DiagnosticCode.Expected_0_arguments_but_got_1,\r\n expression.range, numParameters.toString(10), numArguments.toString(10)\r\n );\r\n return module.unreachable();\r\n }\r\n if (templateName !== null && inferredTypes.has(templateName)) {\r\n let inferredType = inferredTypes.get(templateName);\r\n if (inferredType) {\r\n argumentExprs[i] = this.compileExpression(argumentExpression, inferredType);\r\n let commonType: Type | null;\r\n if (!(commonType = Type.commonDenominator(inferredType, this.currentType, true))) {\r\n if (!(commonType = Type.commonDenominator(inferredType, this.currentType, false))) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n parameterNodes[i].type.range, this.currentType.toString(), inferredType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n inferredType = commonType;\r\n } else {\r\n argumentExprs[i] = this.compileExpression(argumentExpression, Type.auto);\r\n inferredType = this.currentType;\r\n // ++numInferred;\r\n }\r\n inferredTypes.set(templateName, inferredType);\r\n } else {\r\n let concreteType = this.resolver.resolveType(\r\n parameterNodes[i].type,\r\n flow.actualFunction,\r\n flow.contextualTypeArguments\r\n );\r\n if (!concreteType) return module.unreachable();\r\n argumentExprs[i] = this.compileExpression(argumentExpression, concreteType, Constraints.CONV_IMPLICIT);\r\n }\r\n }\r\n let resolvedTypeArguments = new Array(numTypeParameters);\r\n for (let i = 0; i < numTypeParameters; ++i) {\r\n let inferredType = assert(inferredTypes.get(typeParameterNodes[i].name.text)); // TODO\r\n resolvedTypeArguments[i] = inferredType;\r\n }\r\n instance = this.resolver.resolveFunction(\r\n prototype,\r\n resolvedTypeArguments,\r\n makeMap(flow.contextualTypeArguments)\r\n );\r\n if (!instance) return this.module.unreachable();\r\n return this.makeCallDirect(instance, argumentExprs, expression, contextualType == Type.void);\r\n // TODO: this skips inlining because inlining requires compiling its temporary locals in\r\n // the scope of the inlined flow. might need another mechanism to lock temp. locals early,\r\n // so inlining can be performed in `makeCallDirect` instead?\r\n\r\n // otherwise resolve the non-generic call as usual\r\n } else {\r\n instance = this.resolver.resolveFunction(prototype, null);\r\n }\r\n if (!instance) return this.module.unreachable();\r\n\r\n // compile 'this' expression if an instance method\r\n let thisExpr: ExpressionRef = 0;\r\n if (instance.is(CommonFlags.INSTANCE)) {\r\n thisExpr = this.compileExpression(assert(this.resolver.currentThisExpression), this.options.usizeType);\r\n }\r\n\r\n return this.compileCallDirect(\r\n instance,\r\n expression.arguments,\r\n expression,\r\n thisExpr,\r\n constraints\r\n );\r\n }\r\n\r\n // indirect call: index argument with signature (non-generic, can't be inlined)\r\n case ElementKind.LOCAL: {\r\n if (signature = (target).type.signatureReference) {\r\n if ((target).is(CommonFlags.INLINED)) {\r\n indexArg = module.i32(i64_low((target).constantIntegerValue));\r\n } else {\r\n indexArg = module.local_get((target).index, NativeType.I32);\r\n }\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\r\n expression.range, (target).type.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n case ElementKind.GLOBAL: {\r\n if (signature = (target).type.signatureReference) {\r\n indexArg = module.global_get((target).internalName, (target).type.toNativeType());\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\r\n expression.range, (target).type.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n case ElementKind.FIELD: {\r\n let type = (target).type;\r\n if (signature = type.signatureReference) {\r\n let thisExpression = assert(this.resolver.currentThisExpression);\r\n let thisExpr = this.compileExpression(thisExpression, this.options.usizeType);\r\n indexArg = module.load(\r\n 4,\r\n false,\r\n thisExpr,\r\n NativeType.I32,\r\n (target).memoryOffset\r\n );\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\r\n expression.range, type.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n case ElementKind.FUNCTION_TARGET: {\r\n signature = (target).signature;\r\n indexArg = this.compileExpression(expression.expression, (target).type, Constraints.CONV_IMPLICIT);\r\n break;\r\n }\r\n\r\n case ElementKind.PROPERTY_PROTOTYPE: { // static property\r\n let getterPrototype = assert((target).getterPrototype);\r\n let getterInstance = this.resolver.resolveFunction(getterPrototype, null);\r\n if (!getterInstance) return module.unreachable();\r\n indexArg = this.compileCallDirect(getterInstance, [], expression.expression);\r\n signature = this.currentType.signatureReference;\r\n if (!signature) {\r\n this.error(\r\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\r\n expression.range, this.currentType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n break;\r\n }\r\n case ElementKind.PROPERTY: { // instance property\r\n let getterInstance = assert((target).getterInstance);\r\n indexArg = this.compileCallDirect(getterInstance, [], expression.expression,\r\n this.compileExpression(assert(this.resolver.currentThisExpression), this.options.usizeType)\r\n );\r\n signature = this.currentType.signatureReference;\r\n if (!signature) {\r\n this.error(\r\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\r\n expression.range, this.currentType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n break;\r\n }\r\n\r\n // not supported\r\n default: {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n return this.compileCallIndirect(\r\n signature,\r\n indexArg,\r\n expression.arguments,\r\n expression,\r\n 0,\r\n contextualType == Type.void\r\n );\r\n }\r\n\r\n private compileCallExpressionBuiltin(\r\n prototype: FunctionPrototype,\r\n expression: CallExpression,\r\n contextualType: Type\r\n ): ExpressionRef {\r\n var typeArguments: Type[] | null = null;\r\n\r\n // builtins handle omitted type arguments on their own. if present, however, resolve them here\r\n // and pass them to the builtin, even if it's still up to the builtin how to handle them.\r\n var typeParameterNodes = prototype.typeParameterNodes;\r\n var typeArgumentNodes = expression.typeArguments;\r\n if (expression.typeArguments) {\r\n if (!prototype.is(CommonFlags.GENERIC)) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n expression.range, prototype.internalName\r\n );\r\n }\r\n typeArguments = this.resolver.resolveTypeArguments(\r\n assert(typeParameterNodes),\r\n typeArgumentNodes,\r\n this.currentFlow.actualFunction.parent,\r\n makeMap(this.currentFlow.contextualTypeArguments),\r\n expression\r\n );\r\n }\r\n\r\n // now compile the builtin, which usually returns a block of code that replaces the call.\r\n var expr = compileBuiltinCall(\r\n this,\r\n prototype,\r\n typeArguments,\r\n expression.arguments,\r\n contextualType,\r\n expression\r\n );\r\n if (!expr) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n return expr;\r\n }\r\n\r\n /**\r\n * Checks that a call with the given number as arguments can be performed according to the\r\n * specified signature.\r\n */\r\n checkCallSignature(\r\n signature: Signature,\r\n numArguments: i32,\r\n hasThis: bool,\r\n reportNode: Node\r\n ): bool {\r\n\r\n // cannot call an instance method without a `this` argument (TODO: `.call`?)\r\n var thisType = signature.thisType;\r\n if (hasThis != (thisType != null)) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported, // TODO: better message?\r\n reportNode.range\r\n );\r\n return false;\r\n }\r\n\r\n // not yet implemented (TODO: maybe some sort of an unmanaged/lightweight array?)\r\n var hasRest = signature.hasRest;\r\n if (hasRest) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.range\r\n );\r\n return false;\r\n }\r\n\r\n var minimum = signature.requiredParameters;\r\n var maximum = signature.parameterTypes.length;\r\n\r\n // must at least be called with required arguments\r\n if (numArguments < minimum) {\r\n this.error(\r\n minimum < maximum\r\n ? DiagnosticCode.Expected_at_least_0_arguments_but_got_1\r\n : DiagnosticCode.Expected_0_arguments_but_got_1,\r\n reportNode.range, minimum.toString(), numArguments.toString()\r\n );\r\n return false;\r\n }\r\n\r\n // must not be called with more than the maximum arguments\r\n if (numArguments > maximum && !hasRest) {\r\n this.error(\r\n DiagnosticCode.Expected_0_arguments_but_got_1,\r\n reportNode.range, maximum.toString(), numArguments.toString()\r\n );\r\n return false;\r\n }\r\n\r\n return true;\r\n }\r\n\r\n /** Compiles a direct call to a concrete function. */\r\n compileCallDirect(\r\n instance: Function,\r\n argumentExpressions: Expression[],\r\n reportNode: Node,\r\n thisArg: ExpressionRef = 0,\r\n constraints: Constraints = Constraints.NONE\r\n ): ExpressionRef {\r\n var numArguments = argumentExpressions.length;\r\n var signature = instance.signature;\r\n if (!this.checkCallSignature( // reports\r\n signature,\r\n numArguments,\r\n thisArg != 0,\r\n reportNode\r\n )) {\r\n this.currentType = signature.returnType;\r\n return this.module.unreachable();\r\n }\r\n\r\n // Inline if explicitly requested\r\n if (instance.hasDecorator(DecoratorFlags.INLINE)) {\r\n assert(!instance.is(CommonFlags.TRAMPOLINE)); // doesn't make sense\r\n if (this.currentInlineFunctions.includes(instance)) {\r\n this.warning(\r\n DiagnosticCode.Function_0_cannot_be_inlined_into_itself,\r\n reportNode.range, instance.internalName\r\n );\r\n } else {\r\n this.currentInlineFunctions.push(instance);\r\n let parameterTypes = signature.parameterTypes;\r\n assert(numArguments <= parameterTypes.length);\r\n // compile argument expressions\r\n let args = new Array(numArguments);\r\n for (let i = 0; i < numArguments; ++i) {\r\n args[i] = this.compileExpression(argumentExpressions[i], parameterTypes[i],\r\n Constraints.CONV_IMPLICIT | Constraints.WILL_RETAIN\r\n );\r\n }\r\n // make the inlined call (is aware of autoreleases)\r\n let expr = this.makeCallInline(instance, args, thisArg, (constraints & Constraints.WILL_DROP) != 0);\r\n if (this.currentType.isManaged) {\r\n if (!(constraints & Constraints.WILL_RETAIN)) {\r\n expr = this.makeAutorelease(expr, this.currentFlow);\r\n } else {\r\n this.skippedAutoreleases.add(expr);\r\n }\r\n }\r\n this.currentInlineFunctions.pop();\r\n return expr;\r\n }\r\n }\r\n\r\n // Otherwise compile to just a call\r\n var numArgumentsInclThis = thisArg ? numArguments + 1 : numArguments;\r\n var operands = new Array(numArgumentsInclThis);\r\n var index = 0;\r\n if (thisArg) {\r\n operands[0] = thisArg;\r\n index = 1;\r\n }\r\n var parameterTypes = signature.parameterTypes;\r\n for (let i = 0; i < numArguments; ++i, ++index) {\r\n operands[index] = this.compileExpression(argumentExpressions[i], parameterTypes[i],\r\n Constraints.CONV_IMPLICIT\r\n );\r\n }\r\n assert(index == numArgumentsInclThis);\r\n if (signature.returnType.isManaged) {\r\n if (constraints & Constraints.WILL_DROP) {\r\n // Skip autorelease and simply release\r\n return this.makeCallDirect(instance, operands, reportNode, true);\r\n } else if (constraints & Constraints.WILL_RETAIN) {\r\n // Skip autorelease and remember\r\n let expr = this.makeCallDirect(instance, operands, reportNode, false, true);\r\n this.skippedAutoreleases.add(expr);\r\n return expr;\r\n } else {\r\n return this.makeCallDirect(instance, operands, reportNode, false, false);\r\n }\r\n }\r\n return this.makeCallDirect(instance, operands, reportNode,\r\n (constraints & Constraints.WILL_DROP) != 0\r\n );\r\n }\r\n\r\n makeCallInline(\r\n instance: Function,\r\n operands: ExpressionRef[] | null,\r\n thisArg: ExpressionRef = 0,\r\n immediatelyDropped: bool = false\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var numArguments = operands ? operands.length : 0;\r\n var signature = instance.signature;\r\n var parameterTypes = signature.parameterTypes;\r\n var numParameters = parameterTypes.length;\r\n\r\n // Create a new inline flow and use it to compile the function as a block\r\n var previousFlow = this.currentFlow;\r\n var flow = Flow.createInline(previousFlow.parentFunction, instance);\r\n var body = [];\r\n var usedLocals = new Set();\r\n\r\n // Prepare compiled arguments right to left, keeping track of used locals.\r\n for (let i = numArguments - 1; i >= 0; --i) {\r\n // This is necessary because a later expression must not set an earlier argument local, which\r\n // is also just a temporary, when being executed. Take for example `t1=1, t2=(t1 = 2)`, where\r\n // the right expression would reassign the foregoing argument local. So, we iterate from right\r\n // to left, remembering what's used later, and don't use these for earlier arguments, making\r\n // the example above essentially `t2=1, t1=(t1 = 2)`.\r\n let paramExpr = operands![i];\r\n let paramType = parameterTypes[i];\r\n let argumentLocal = flow.addScopedLocal(signature.getParameterName(i), paramType, usedLocals);\r\n findUsedLocals(paramExpr, usedLocals);\r\n // inlining is aware of wrap/nonnull states:\r\n if (!previousFlow.canOverflow(paramExpr, paramType)) flow.setLocalFlag(argumentLocal.index, LocalFlags.WRAPPED);\r\n if (flow.isNonnull(paramExpr, paramType)) flow.setLocalFlag(argumentLocal.index, LocalFlags.NONNULL);\r\n // inlining is aware of skipped autoreleases:\r\n if (paramType.isManaged) {\r\n if (!this.skippedAutoreleases.has(paramExpr)) paramExpr = this.makeRetain(paramExpr);\r\n flow.setLocalFlag(argumentLocal.index, LocalFlags.RETAINED);\r\n }\r\n body.unshift(\r\n module.local_set(argumentLocal.index, paramExpr)\r\n );\r\n }\r\n if (thisArg) {\r\n let classInstance = assert(instance.parent); assert(classInstance.kind == ElementKind.CLASS);\r\n let thisType = assert(instance.signature.thisType);\r\n let thisLocal = flow.addScopedLocal(CommonSymbols.this_, thisType, usedLocals);\r\n // No need to retain `this` as it can't be reassigned and thus can't become prematurely released\r\n body.unshift(\r\n module.local_set(thisLocal.index, thisArg)\r\n );\r\n let baseInstance = (classInstance).base;\r\n if (baseInstance) flow.addScopedAlias(CommonSymbols.super_, baseInstance.type, thisLocal.index);\r\n } else {\r\n assert(!instance.signature.thisType);\r\n }\r\n\r\n // Compile omitted arguments with final argument locals blocked. Doesn't need to take care of\r\n // side-effects within earlier expressions because these already happened on set.\r\n this.currentFlow = flow;\r\n for (let i = numArguments; i < numParameters; ++i) {\r\n let initType = parameterTypes[i];\r\n let initExpr = this.compileExpression(\r\n assert(instance.prototype.signatureNode.parameters[i].initializer),\r\n initType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n let argumentLocal = flow.addScopedLocal(signature.getParameterName(i), initType);\r\n if (!flow.canOverflow(initExpr, initType)) flow.setLocalFlag(argumentLocal.index, LocalFlags.WRAPPED);\r\n if (flow.isNonnull(initExpr, initType)) flow.setLocalFlag(argumentLocal.index, LocalFlags.NONNULL);\r\n if (initType.isManaged) {\r\n flow.setLocalFlag(argumentLocal.index, LocalFlags.RETAINED);\r\n body.push(\r\n module.local_set(argumentLocal.index,\r\n this.makeRetain(initExpr)\r\n )\r\n );\r\n } else {\r\n body.push(\r\n module.local_set(argumentLocal.index, initExpr)\r\n );\r\n }\r\n }\r\n\r\n // Compile the called function's body in the scope of the inlined flow\r\n this.compileFunctionBody(instance, body);\r\n\r\n // Free any new scoped locals and reset to the original flow\r\n if (!flow.is(FlowFlags.TERMINATES)) {\r\n this.performAutoreleases(flow, body);\r\n this.finishAutoreleases(flow, body);\r\n }\r\n flow.freeScopedLocals();\r\n var returnType = flow.returnType;\r\n this.currentFlow = previousFlow;\r\n\r\n // Create an outer block that we can break to when returning a value out of order\r\n var expr = module.block(flow.inlineReturnLabel, body, returnType.toNativeType());\r\n this.currentType = returnType;\r\n if (returnType.isManaged) {\r\n if (immediatelyDropped) {\r\n expr = this.makeRelease(expr);\r\n this.currentType = Type.void;\r\n }\r\n }\r\n return expr;\r\n }\r\n\r\n /** Gets the trampoline for the specified function. */\r\n ensureTrampoline(original: Function): Function {\r\n // A trampoline is a function that takes a fixed amount of operands with some of them possibly\r\n // being zeroed. It takes one additional argument denoting the number of actual operands\r\n // provided to the call, and takes appropriate steps to initialize zeroed operands to their\r\n // default values using the optional parameter initializers of the original function. Doing so\r\n // allows calls to functions with optional parameters to circumvent the trampoline when all\r\n // parameters are provided as a fast route, respectively setting up omitted operands in a proper\r\n // context otherwise.\r\n var trampoline = original.trampoline;\r\n if (trampoline) return trampoline;\r\n\r\n var originalSignature = original.signature;\r\n var originalName = original.internalName;\r\n var originalParameterTypes = originalSignature.parameterTypes;\r\n var originalParameterDeclarations = original.prototype.signatureNode.parameters;\r\n var returnType = originalSignature.returnType;\r\n var thisType = originalSignature.thisType;\r\n var isInstance = original.is(CommonFlags.INSTANCE);\r\n\r\n // arguments excl. `this`, operands incl. `this`\r\n var minArguments = originalSignature.requiredParameters;\r\n var minOperands = minArguments;\r\n var maxArguments = originalParameterTypes.length;\r\n var maxOperands = maxArguments;\r\n if (isInstance) {\r\n ++minOperands;\r\n ++maxOperands;\r\n }\r\n var numOptional = assert(maxOperands - minOperands);\r\n\r\n var forwardedOperands = new Array(minOperands);\r\n var operandIndex = 0;\r\n\r\n // forward `this` if applicable\r\n var module = this.module;\r\n if (isInstance) {\r\n forwardedOperands[0] = module.local_get(0, this.options.nativeSizeType);\r\n operandIndex = 1;\r\n }\r\n\r\n // forward required arguments\r\n for (let i = 0; i < minArguments; ++i, ++operandIndex) {\r\n forwardedOperands[operandIndex] = module.local_get(operandIndex, originalParameterTypes[i].toNativeType());\r\n }\r\n assert(operandIndex == minOperands);\r\n\r\n // create the trampoline element\r\n var trampolineSignature = new Signature(originalParameterTypes, returnType, thisType);\r\n trampolineSignature.requiredParameters = maxArguments;\r\n trampolineSignature.parameterNames = originalSignature.parameterNames;\r\n trampoline = new Function(\r\n original.name + \"|trampoline\",\r\n original.prototype,\r\n trampolineSignature,\r\n original.contextualTypeArguments\r\n );\r\n trampoline.set(original.flags | CommonFlags.TRAMPOLINE | CommonFlags.COMPILED);\r\n original.trampoline = trampoline;\r\n\r\n // compile initializers of omitted arguments in scope of the trampoline function\r\n // this is necessary because initializers might need additional locals and a proper this context\r\n var previousFlow = this.currentFlow;\r\n var flow = trampoline.flow;\r\n this.currentFlow = flow;\r\n\r\n // create a br_table switching over the number of optional parameters provided\r\n var numNames = numOptional + 1; // incl. outer block\r\n var names = new Array(numNames);\r\n var ofN = \"of\" + numOptional.toString(10);\r\n for (let i = 0; i < numNames; ++i) {\r\n let label = i.toString(10) + ofN;\r\n names[i] = label;\r\n }\r\n var body = module.block(names[0], [\r\n module.block(\"outOfRange\", [\r\n module.switch(names, \"outOfRange\",\r\n // condition is number of provided optional arguments, so subtract required arguments\r\n minArguments\r\n ? module.binary(\r\n BinaryOp.SubI32,\r\n module.global_get(BuiltinSymbols.argc, NativeType.I32),\r\n module.i32(minArguments)\r\n )\r\n : module.global_get(BuiltinSymbols.argc, NativeType.I32)\r\n )\r\n ]),\r\n module.unreachable()\r\n ]);\r\n for (let i = 0; i < numOptional; ++i, ++operandIndex) {\r\n let type = originalParameterTypes[minArguments + i];\r\n let declaration = originalParameterDeclarations[minArguments + i];\r\n let initializer = declaration.initializer;\r\n let initExpr: ExpressionRef;\r\n if (initializer) {\r\n initExpr = module.local_set(operandIndex,\r\n this.compileExpression(\r\n initializer,\r\n type,\r\n Constraints.CONV_IMPLICIT\r\n )\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Optional_parameter_must_have_an_initializer,\r\n declaration.range\r\n );\r\n initExpr = module.unreachable();\r\n }\r\n body = module.block(names[i + 1], [\r\n body,\r\n initExpr,\r\n ]);\r\n forwardedOperands[operandIndex] = module.local_get(operandIndex, type.toNativeType());\r\n }\r\n assert(operandIndex == maxOperands);\r\n\r\n var stmts: ExpressionRef[] = [ body ];\r\n var theCall = module.call(originalName, forwardedOperands, returnType.toNativeType());\r\n if (returnType != Type.void) {\r\n this.performAutoreleasesWithValue(flow, theCall, returnType, stmts);\r\n } else {\r\n stmts.push(theCall);\r\n this.performAutoreleases(flow, stmts);\r\n }\r\n flow.freeScopedLocals();\r\n this.currentFlow = previousFlow;\r\n\r\n var funcRef = module.addFunction(\r\n trampoline.internalName,\r\n this.ensureFunctionType(\r\n trampolineSignature.parameterTypes,\r\n returnType,\r\n thisType\r\n ),\r\n typesToNativeTypes(trampoline.additionalLocals),\r\n module.block(null, stmts, returnType.toNativeType())\r\n );\r\n trampoline.finalize(module, funcRef);\r\n return trampoline;\r\n }\r\n\r\n /** Makes sure that the argument count helper global is present and returns its name. */\r\n private ensureArgcVar(): string {\r\n if (!this.argcVar) {\r\n let module = this.module;\r\n this.argcVar = module.addGlobal(\r\n BuiltinSymbols.argc,\r\n NativeType.I32,\r\n true,\r\n module.i32(0)\r\n );\r\n }\r\n return BuiltinSymbols.argc;\r\n }\r\n\r\n /** Makes sure that the argument count helper setter is present and returns its name. */\r\n private ensureArgcSet(): string {\r\n if (!this.argcSet) {\r\n let module = this.module;\r\n this.argcSet = module.addFunction(BuiltinSymbols.setargc,\r\n this.ensureFunctionType([ Type.u32 ], Type.void),\r\n null,\r\n module.global_set(this.ensureArgcVar(),\r\n module.local_get(0, NativeType.I32)\r\n )\r\n );\r\n module.addFunctionExport(BuiltinSymbols.setargc, \"__setargc\");\r\n }\r\n return BuiltinSymbols.setargc;\r\n }\r\n\r\n // \r\n\r\n /** Makes retain call, retaining the expression's value. */\r\n makeRetain(expr: ExpressionRef): ExpressionRef {\r\n var retainInstance = this.program.retainInstance;\r\n this.compileFunction(retainInstance);\r\n return this.module.call(retainInstance.internalName, [ expr ], this.options.nativeSizeType);\r\n }\r\n\r\n /** Makes a retainRelease call, retaining the new expression's value and releasing the old expression's value, in this order. */\r\n makeRetainRelease(oldExpr: ExpressionRef, newExpr: ExpressionRef): ExpressionRef {\r\n // if ((t1=newExpr) != (t2=oldExpr)) {\r\n // __retain(t1);\r\n // __release(t2);\r\n // }, t1\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n var usizeType = this.options.usizeType;\r\n var nativeSizeType = this.options.nativeSizeType;\r\n var temp1 = flow.getTempLocal(usizeType, findUsedLocals(oldExpr));\r\n var temp2 = flow.getAndFreeTempLocal(usizeType);\r\n flow.freeTempLocal(temp1);\r\n return module.block(null, [\r\n module.if(\r\n module.binary(nativeSizeType == NativeType.I64 ? BinaryOp.NeI64 : BinaryOp.NeI32,\r\n module.local_tee(temp1.index, newExpr),\r\n module.local_tee(temp2.index, oldExpr)\r\n ),\r\n module.block(null, [\r\n module.drop(\r\n this.makeRetain(module.local_get(temp1.index, nativeSizeType))\r\n ),\r\n this.makeRelease(module.local_get(temp2.index, nativeSizeType))\r\n ])\r\n ),\r\n module.local_get(temp1.index, nativeSizeType)\r\n ], nativeSizeType);\r\n }\r\n\r\n /** Makes a skippedRelease call, ignoring the new expression's value and releasing the old expression's value, in this order. */\r\n makeSkippedRelease(oldExpr: ExpressionRef, newExpr: ExpressionRef): ExpressionRef {\r\n // TODO: this helper can be eliminated altogether if the current logic holds\r\n // (t1=newExpr), __release(oldExpr), t1\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n var usizeType = this.options.usizeType;\r\n var nativeSizeType = this.options.nativeSizeType;\r\n var temp = flow.getAndFreeTempLocal(usizeType, findUsedLocals(oldExpr));\r\n return module.block(null, [\r\n module.local_set(temp.index, newExpr),\r\n this.makeRelease(oldExpr),\r\n module.local_get(temp.index, nativeSizeType)\r\n ], nativeSizeType);\r\n }\r\n\r\n /** Makes a release call, releasing the expression's value. Changes the current type to void.*/\r\n makeRelease(expr: ExpressionRef): ExpressionRef {\r\n var releaseInstance = this.program.releaseInstance;\r\n this.compileFunction(releaseInstance);\r\n return this.module.call(releaseInstance.internalName, [ expr ], NativeType.None);\r\n }\r\n\r\n /** Makes an automatic release call at the end of the current flow. */\r\n makeAutorelease(expr: ExpressionRef, flow: Flow = this.currentFlow): ExpressionRef {\r\n // FIXME: loses track of nonNull state?\r\n return this.module.local_tee(flow.getAutoreleaseLocal(this.options.usizeType).index, expr);\r\n }\r\n\r\n /** Attempts to undo a final autorelease, returning the index of the previously retaining variable or -1 if not possible. */\r\n undoAutorelease(expr: ExpressionRef, flow: Flow): i32 {\r\n // NOTE: Can't remove the local.tee completely because it's already compiled\r\n // and a child of something else. Preventing the final release however should\r\n // make it optimize away.\r\n switch (getExpressionId(expr)) {\r\n case ExpressionId.LocalSet: { // local.tee(__retain(expr))\r\n if (isLocalTee(expr)) {\r\n let index = getLocalSetIndex(expr);\r\n if (flow.isAnyLocalFlag(index, LocalFlags.ANY_RETAINED)) {\r\n // Assumes that the expression actually belongs to the flow and that\r\n // top-level autoreleases are never undone. While that's true, it's\r\n // not necessary to check presence in scopedLocals.\r\n flow.unsetLocalFlag(index, LocalFlags.ANY_RETAINED);\r\n return index;\r\n }\r\n }\r\n break;\r\n }\r\n case ExpressionId.Block: { // { ..., local.tee(__retain(expr)) }\r\n if (getBlockName(expr) === null) { // must not be a break target\r\n let count = getBlockChildCount(expr);\r\n if (count) {\r\n return this.undoAutorelease(getBlockChild(expr, count - 1), flow);\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n return -1;\r\n }\r\n\r\n /**\r\n * Attemps to move a final autorelease from one flow to a parent.\r\n * It is crucial that from flow hasn't processed autoreleases yet because otherwise the final\r\n * retain would have been written already.\r\n */\r\n moveAutorelease(expr: ExpressionRef, fromInnerFlow: Flow, toOuterFlow: Flow): ExpressionRef {\r\n // NOTE: While this avoids an unnecessary set of retain and release, it cannot\r\n // eliminate the now unnecessary temporary local.tee because it is already part of\r\n // another expression in the tree. But optimizing should collapse locals again.\r\n var index = this.undoAutorelease(expr, fromInnerFlow);\r\n return ~index\r\n ? this.makeAutorelease(expr, toOuterFlow) // undone, can skip the retain\r\n : this.makeAutorelease(this.makeRetain(expr), toOuterFlow);\r\n }\r\n\r\n /** Performs any queued autoreleases in the specified flow. */\r\n performAutoreleases(flow: Flow, stmts: ExpressionRef[], clearFlags: bool = true): void {\r\n var scopedLocals = flow.scopedLocals;\r\n if (scopedLocals) {\r\n let module = this.module;\r\n for (let local of scopedLocals.values()) {\r\n if (local.is(CommonFlags.SCOPED)) { // otherwise an alias\r\n let localIndex = local.index;\r\n if (flow.isAnyLocalFlag(localIndex, LocalFlags.ANY_RETAINED)) {\r\n if (clearFlags) flow.unsetLocalFlag(localIndex, LocalFlags.ANY_RETAINED);\r\n stmts.push(\r\n this.makeRelease(\r\n module.local_get(localIndex, local.type.toNativeType())\r\n )\r\n );\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n /** Performs any queued autoreleases in the specified flow and returns the value. */\r\n performAutoreleasesWithValue(\r\n flow: Flow,\r\n valueExpr: ExpressionRef,\r\n valueType: Type,\r\n stmts: ExpressionRef[] | null = null,\r\n clearFlags: bool = true\r\n ): ExpressionRef {\r\n if (!stmts) stmts = new Array();\r\n stmts.push(\r\n this.module.nop()\r\n );\r\n var lengthBefore = stmts.length;\r\n this.performAutoreleases(flow, stmts, clearFlags);\r\n if (stmts.length > lengthBefore) {\r\n let nativeType = valueType.toNativeType();\r\n let temp = flow.getAndFreeTempLocal(valueType);\r\n if (!flow.canOverflow(valueExpr, valueType)) flow.setLocalFlag(temp.index, LocalFlags.WRAPPED);\r\n if (flow.isNonnull(valueExpr, valueType)) flow.setLocalFlag(temp.index, LocalFlags.NONNULL);\r\n let module = this.module;\r\n stmts[lengthBefore - 1] = module.local_set(temp.index, valueExpr); // nop -> set\r\n stmts.push(\r\n module.local_get(temp.index, nativeType) // append get\r\n );\r\n return module.block(null, stmts, nativeType);\r\n } else if (stmts.length > 1) {\r\n stmts[lengthBefore - 1] = valueExpr; // nop -> value\r\n return this.module.block(null, stmts, valueType.toNativeType());\r\n }\r\n return valueExpr;\r\n }\r\n\r\n /** Finishes any queued top-level autoreleases in the actual function of the specified flow. */\r\n finishAutoreleases(flow: Flow, stmts: ExpressionRef[]): void {\r\n var module = this.module;\r\n if (flow.is(FlowFlags.INLINE_CONTEXT)) {\r\n // traverse to the top-most flow containing the inlined function's\r\n // locals as scoped locals and release these instead.\r\n let parent: Flow | null;\r\n while (parent = flow.parent) flow = parent;\r\n this.performAutoreleases(flow, stmts, false);\r\n } else {\r\n for (let local of flow.parentFunction.localsByIndex) {\r\n let localIndex = local.index;\r\n if (flow.isAnyLocalFlag(localIndex, LocalFlags.ANY_RETAINED)) {\r\n flow.unsetLocalFlag(localIndex, LocalFlags.ANY_RETAINED);\r\n stmts.push(\r\n this.makeRelease(\r\n module.local_get(localIndex, local.type.toNativeType())\r\n )\r\n );\r\n }\r\n }\r\n }\r\n }\r\n\r\n // \r\n\r\n /** Creates a direct call to the specified function. */\r\n makeCallDirect(\r\n instance: Function,\r\n operands: ExpressionRef[] | null,\r\n reportNode: Node,\r\n immediatelyDropped: bool = false,\r\n /** Skip the usual autorelease and manage this at the callsite instead. */\r\n skipAutorelease: bool = false\r\n ): ExpressionRef {\r\n if (instance.hasDecorator(DecoratorFlags.INLINE)) {\r\n this.warning(\r\n DiagnosticCode.TODO_Cannot_inline_inferred_calls_and_specific_internals_yet,\r\n reportNode.range, instance.internalName\r\n );\r\n }\r\n var numOperands = operands ? operands.length : 0;\r\n var numArguments = numOperands;\r\n var minArguments = instance.signature.requiredParameters;\r\n var minOperands = minArguments;\r\n var maxArguments = instance.signature.parameterTypes.length;\r\n var maxOperands = maxArguments;\r\n if (instance.is(CommonFlags.INSTANCE)) {\r\n ++minOperands;\r\n ++maxOperands;\r\n --numArguments;\r\n }\r\n assert(numOperands >= minOperands);\r\n\r\n var module = this.module;\r\n if (!this.compileFunction(instance)) return module.unreachable();\r\n var returnType = instance.signature.returnType;\r\n var isCallImport = instance.is(CommonFlags.MODULE_IMPORT);\r\n\r\n // fill up omitted arguments with their initializers, if constant, otherwise with zeroes.\r\n if (numOperands < maxOperands) {\r\n if (!operands) {\r\n operands = new Array(maxOperands);\r\n operands.length = 0;\r\n }\r\n let parameterTypes = instance.signature.parameterTypes;\r\n let parameterNodes = instance.prototype.signatureNode.parameters;\r\n assert(parameterNodes.length == parameterTypes.length);\r\n let allOptionalsAreConstant = true;\r\n for (let i = numArguments; i < maxArguments; ++i) {\r\n let initializer = parameterNodes[i].initializer;\r\n if (initializer) {\r\n if (nodeIsConstantValue(initializer.kind)) {\r\n operands.push(this.compileExpression(\r\n parameterNodes[i].initializer,\r\n parameterTypes[i],\r\n Constraints.CONV_IMPLICIT\r\n ));\r\n continue;\r\n }\r\n let resolved = this.resolver.resolveExpression(initializer, instance.flow, parameterTypes[i]);\r\n if (resolved) {\r\n if (resolved.kind == ElementKind.GLOBAL) {\r\n let global = resolved;\r\n if (this.compileGlobal(global)) {\r\n if (global.is(CommonFlags.INLINED)) {\r\n operands.push(\r\n this.compileInlineConstant(global, parameterTypes[i], Constraints.CONV_IMPLICIT)\r\n );\r\n } else {\r\n operands.push(\r\n this.convertExpression(\r\n module.global_get(global.internalName, global.type.toNativeType()),\r\n global.type, parameterTypes[i], false, false, initializer\r\n )\r\n );\r\n }\r\n continue;\r\n }\r\n }\r\n }\r\n }\r\n operands.push(parameterTypes[i].toNativeZero(module));\r\n allOptionalsAreConstant = false;\r\n }\r\n if (!allOptionalsAreConstant) {\r\n if (!isCallImport) {\r\n let original = instance;\r\n instance = this.ensureTrampoline(instance);\r\n if (!this.compileFunction(instance)) return module.unreachable();\r\n instance.flow.flags = original.flow.flags;\r\n let nativeReturnType = returnType.toNativeType();\r\n let expr = module.call(instance.internalName, operands, nativeReturnType);\r\n this.currentType = returnType;\r\n if (returnType.isManaged) {\r\n if (immediatelyDropped) {\r\n expr = this.makeRelease(expr);\r\n this.currentType = Type.void;\r\n } else if (!skipAutorelease) {\r\n expr = this.makeAutorelease(expr);\r\n } else {\r\n this.skippedAutoreleases.add(expr);\r\n }\r\n }\r\n return module.block(null, [\r\n module.global_set(this.ensureArgcVar(), module.i32(numArguments)),\r\n expr\r\n ], this.currentType.toNativeType());\r\n }\r\n }\r\n }\r\n\r\n // If the return value is of a reference type it has not yet been released but is in flight\r\n // which is equivalent to a skipped autorelease. Hence, insert either a release if it is\r\n // dropped anyway, preserve the skipped autorelease if explicitly requested or autorelease now.\r\n var expr = module.call(instance.internalName, operands, returnType.toNativeType());\r\n this.currentType = returnType;\r\n if (returnType.isManaged) {\r\n if (immediatelyDropped) {\r\n expr = this.makeRelease(expr);\r\n this.currentType = Type.void;\r\n } else if (!skipAutorelease) {\r\n expr = this.makeAutorelease(expr);\r\n }\r\n }\r\n return expr;\r\n }\r\n\r\n /** Compiles an indirect call using an index argument and a signature. */\r\n compileCallIndirect(\r\n signature: Signature,\r\n indexArg: ExpressionRef,\r\n argumentExpressions: Expression[],\r\n reportNode: Node,\r\n thisArg: ExpressionRef = 0,\r\n immediatelyDropped: bool = false\r\n ): ExpressionRef {\r\n var numArguments = argumentExpressions.length;\r\n\r\n if (!this.checkCallSignature( // reports\r\n signature,\r\n numArguments,\r\n thisArg != 0,\r\n reportNode\r\n )) {\r\n return this.module.unreachable();\r\n }\r\n\r\n var numArgumentsInclThis = thisArg ? numArguments + 1 : numArguments;\r\n var operands = new Array(numArgumentsInclThis);\r\n var index = 0;\r\n if (thisArg) {\r\n operands[0] = thisArg;\r\n index = 1;\r\n }\r\n var parameterTypes = signature.parameterTypes;\r\n for (let i = 0; i < numArguments; ++i, ++index) {\r\n operands[index] = this.compileExpression(argumentExpressions[i], parameterTypes[i],\r\n Constraints.CONV_IMPLICIT\r\n );\r\n }\r\n assert(index == numArgumentsInclThis);\r\n return this.makeCallIndirect(signature, indexArg, operands, immediatelyDropped);\r\n }\r\n\r\n /** Creates an indirect call to the function at `indexArg` in the function table. */\r\n makeCallIndirect(\r\n signature: Signature,\r\n indexArg: ExpressionRef,\r\n operands: ExpressionRef[] | null = null,\r\n immediatelyDropped: bool = false\r\n ): ExpressionRef {\r\n var numOperands = operands ? operands.length : 0;\r\n var numArguments = numOperands;\r\n var minArguments = signature.requiredParameters;\r\n var minOperands = minArguments;\r\n var maxArguments = signature.parameterTypes.length;\r\n var maxOperands = maxArguments;\r\n if (signature.thisType) {\r\n ++minOperands;\r\n ++maxOperands;\r\n --numArguments;\r\n }\r\n assert(numOperands >= minOperands);\r\n\r\n this.ensureFunctionType(signature.parameterTypes, signature.returnType, signature.thisType);\r\n var module = this.module;\r\n\r\n // fill up omitted arguments with zeroes\r\n if (numOperands < maxOperands) {\r\n if (!operands) {\r\n operands = new Array(maxOperands);\r\n operands.length = 0;\r\n }\r\n let parameterTypes = signature.parameterTypes;\r\n for (let i = numArguments; i < maxArguments; ++i) {\r\n operands.push(parameterTypes[i].toNativeZero(module));\r\n }\r\n }\r\n\r\n var returnType = signature.returnType;\r\n var expr = module.call_indirect(indexArg, operands, signature.toSignatureString());\r\n this.currentType = returnType;\r\n if (returnType.isManaged) {\r\n if (immediatelyDropped) {\r\n expr = this.makeRelease(expr);\r\n this.currentType = Type.void;\r\n } else {\r\n expr = this.makeAutorelease(expr);\r\n }\r\n }\r\n return module.block(null, [\r\n module.global_set(this.ensureArgcVar(), // might be calling a trampoline\r\n module.i32(numArguments)\r\n ),\r\n expr\r\n ], this.currentType.toNativeType()); // not necessarily wrapped\r\n }\r\n\r\n compileCommaExpression(\r\n expression: CommaExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var expressions = expression.expressions;\r\n var numExpressions = expressions.length;\r\n var exprs = new Array(numExpressions--);\r\n for (let i = 0; i < numExpressions; ++i) {\r\n exprs[i] = this.compileExpression(expressions[i], Type.void, // drop all except last\r\n Constraints.CONV_IMPLICIT | Constraints.WILL_DROP\r\n );\r\n }\r\n exprs[numExpressions] = this.compileExpression(expressions[numExpressions], contextualType, constraints);\r\n return this.module.block(null, exprs, this.currentType.toNativeType());\r\n }\r\n\r\n compileElementAccessExpression(\r\n expression: ElementAccessExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var target = this.resolver.resolveElementAccessExpression(\r\n expression,\r\n this.currentFlow,\r\n contextualType\r\n ); // reports\r\n if (!target) return this.module.unreachable();\r\n switch (target.kind) {\r\n case ElementKind.CLASS: {\r\n let indexedGet = (target).lookupOverload(OperatorKind.INDEXED_GET, this.currentFlow.is(FlowFlags.UNCHECKED_CONTEXT));\r\n if (!indexedGet) {\r\n this.error(\r\n DiagnosticCode.Index_signature_is_missing_in_type_0,\r\n expression.expression.range, (target).internalName\r\n );\r\n return this.module.unreachable();\r\n }\r\n let thisArg = this.compileExpression(expression.expression, (target).type,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n return this.compileCallDirect(indexedGet, [\r\n expression.elementExpression\r\n ], expression, thisArg, constraints);\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n compileFunctionExpression(\r\n expression: FunctionExpression,\r\n contextualSignature: Signature | null,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var declaration = expression.declaration.clone(); // generic contexts can have multiple\r\n assert(!declaration.typeParameters); // function expression cannot be generic\r\n var flow = this.currentFlow;\r\n var actualFunction = flow.actualFunction;\r\n var prototype = new FunctionPrototype(\r\n declaration.name.text.length\r\n ? declaration.name.text\r\n : \"anonymous|\" + (actualFunction.nextAnonymousId++).toString(10),\r\n actualFunction,\r\n declaration,\r\n DecoratorFlags.NONE\r\n );\r\n var instance: Function | null;\r\n var contextualTypeArguments = makeMap(flow.contextualTypeArguments);\r\n\r\n // compile according to context. this differs from a normal function in that omitted parameter\r\n // and return types can be inferred and omitted arguments can be replaced with dummies.\r\n if (contextualSignature) {\r\n let signatureNode = prototype.signatureNode;\r\n let parameterNodes = signatureNode.parameters;\r\n let numPresentParameters = parameterNodes.length;\r\n\r\n // must not require more than the maximum number of parameters\r\n let parameterTypes = contextualSignature.parameterTypes;\r\n let numParameters = parameterTypes.length;\r\n if (numPresentParameters > numParameters) {\r\n this.error(\r\n DiagnosticCode.Expected_0_arguments_but_got_1,\r\n expression.range, numParameters.toString(), numPresentParameters.toString()\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n // check non-omitted parameter types\r\n let parameterNames = new Array(numPresentParameters);\r\n for (let i = 0; i < numPresentParameters; ++i) {\r\n let parameterNode = parameterNodes[i];\r\n parameterNames[i] = parameterNode.name.text; // use actual name\r\n if (!isTypeOmitted(parameterNode.type)) {\r\n let resolvedType = this.resolver.resolveType(\r\n parameterNode.type,\r\n actualFunction.parent,\r\n contextualTypeArguments\r\n );\r\n if (!resolvedType) return this.module.unreachable();\r\n if (!parameterTypes[i].isStrictlyAssignableTo(resolvedType)) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n parameterNode.range, parameterTypes[i].toString(), resolvedType.toString()\r\n );\r\n return this.module.unreachable();\r\n }\r\n }\r\n // any unused parameters are inherited but ignored\r\n }\r\n\r\n // check non-omitted return type\r\n let returnType = contextualSignature.returnType;\r\n if (!isTypeOmitted(signatureNode.returnType)) {\r\n let resolvedType = this.resolver.resolveType(\r\n signatureNode.returnType,\r\n actualFunction.parent,\r\n contextualTypeArguments\r\n );\r\n if (!resolvedType) return this.module.unreachable();\r\n if (\r\n returnType == Type.void\r\n ? resolvedType != Type.void\r\n : !resolvedType.isStrictlyAssignableTo(returnType)\r\n ) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n signatureNode.returnType.range, resolvedType.toString(), returnType.toString()\r\n );\r\n return this.module.unreachable();\r\n }\r\n }\r\n\r\n // check explicit this type\r\n let thisType = contextualSignature.thisType;\r\n let thisTypeNode = signatureNode.explicitThisType;\r\n if (thisTypeNode) {\r\n if (!thisType) {\r\n this.error(\r\n DiagnosticCode._this_cannot_be_referenced_in_current_location,\r\n thisTypeNode.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n let resolvedType = this.resolver.resolveType(\r\n thisTypeNode,\r\n actualFunction.parent,\r\n contextualTypeArguments\r\n );\r\n if (!resolvedType) return this.module.unreachable();\r\n if (!thisType.isStrictlyAssignableTo(resolvedType)) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n thisTypeNode.range, thisType.toString(), resolvedType.toString()\r\n );\r\n return this.module.unreachable();\r\n }\r\n }\r\n\r\n let signature = new Signature(parameterTypes, returnType, thisType);\r\n signature.requiredParameters = numParameters; // !\r\n signature.parameterNames = parameterNames;\r\n instance = new Function(\r\n prototype.name,\r\n prototype,\r\n signature,\r\n contextualTypeArguments\r\n );\r\n if (!this.compileFunction(instance)) return this.module.unreachable();\r\n this.currentType = contextualSignature.type;\r\n\r\n // otherwise compile like a normal function\r\n } else {\r\n instance = this.compileFunctionUsingTypeArguments(\r\n prototype,\r\n [],\r\n contextualTypeArguments\r\n );\r\n if (!instance) return this.module.unreachable();\r\n this.currentType = instance.signature.type;\r\n }\r\n\r\n var index = this.ensureFunctionTableEntry(instance); // reports\r\n return index < 0\r\n ? this.module.unreachable()\r\n : this.module.i32(index);\r\n }\r\n\r\n /** Makes sure the enclosing source file of the specified expression has been compiled. */\r\n private maybeCompileEnclosingSource(expression: Expression): void {\r\n var internalPath = expression.range.source.internalPath;\r\n var filesByName = this.program.filesByName;\r\n assert(filesByName.has(internalPath));\r\n var enclosingFile = filesByName.get(internalPath)!;\r\n if (!enclosingFile.is(CommonFlags.COMPILED)) {\r\n this.compileFileByPath(internalPath, expression);\r\n }\r\n }\r\n\r\n /**\r\n * Compiles an identifier in the specified context.\r\n * @param retainConstantType Retains the type of inlined constants if `true`, otherwise\r\n * precomputes them according to context.\r\n */\r\n compileIdentifierExpression(\r\n expression: IdentifierExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n var actualFunction = flow.actualFunction;\r\n\r\n // check special keywords first\r\n switch (expression.kind) {\r\n case NodeKind.NULL: {\r\n let options = this.options;\r\n if (!contextualType.classReference) {\r\n this.currentType = options.usizeType;\r\n }\r\n return options.isWasm64\r\n ? module.i64(0)\r\n : module.i32(0);\r\n }\r\n case NodeKind.TRUE: {\r\n this.currentType = Type.bool;\r\n return module.i32(1);\r\n }\r\n case NodeKind.FALSE: {\r\n this.currentType = Type.bool;\r\n return module.i32(0);\r\n }\r\n case NodeKind.THIS: {\r\n if (actualFunction.is(CommonFlags.INSTANCE)) {\r\n let thisLocal = assert(flow.lookupLocal(CommonSymbols.this_));\r\n let classInstance = assert(actualFunction.parent); assert(classInstance.kind == ElementKind.CLASS);\r\n let nativeSizeType = this.options.nativeSizeType;\r\n if (actualFunction.is(CommonFlags.CONSTRUCTOR)) {\r\n if (!flow.is(FlowFlags.ALLOCATES)) {\r\n flow.set(FlowFlags.ALLOCATES);\r\n // {\r\n // if (!this) this = \r\n // this.a = X\r\n // this.b = Y\r\n // return this\r\n // }\r\n let stmts: ExpressionRef[] = [\r\n module.if(\r\n module.unary(nativeSizeType == NativeType.I64 ? UnaryOp.EqzI64 : UnaryOp.EqzI32,\r\n module.local_get(thisLocal.index, nativeSizeType)\r\n ),\r\n module.local_set(thisLocal.index,\r\n this.makeRetain(\r\n this.makeAllocation(classInstance)\r\n )\r\n )\r\n )\r\n ];\r\n this.makeFieldInitialization(classInstance, stmts);\r\n stmts.push(\r\n module.local_get(thisLocal.index, nativeSizeType)\r\n );\r\n this.currentType = thisLocal.type;\r\n return module.block(null, stmts, nativeSizeType);\r\n }\r\n }\r\n // if not a constructor, `this` type can differ\r\n let thisType = assert(actualFunction.signature.thisType);\r\n this.currentType = thisType;\r\n return module.local_get(thisLocal.index, thisType.toNativeType());\r\n }\r\n this.error(\r\n DiagnosticCode._this_cannot_be_referenced_in_current_location,\r\n expression.range\r\n );\r\n this.currentType = this.options.usizeType;\r\n return module.unreachable();\r\n }\r\n case NodeKind.SUPER: {\r\n let flow = this.currentFlow;\r\n let actualFunction = flow.actualFunction;\r\n if (actualFunction.is(CommonFlags.CONSTRUCTOR)) {\r\n if (!flow.is(FlowFlags.CALLS_SUPER)) {\r\n // TS1034 in the parser effectively limits this to property accesses\r\n this.error(\r\n DiagnosticCode._super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class,\r\n expression.range\r\n );\r\n }\r\n }\r\n if (flow.is(FlowFlags.INLINE_CONTEXT)) {\r\n let scopedThis = flow.lookupLocal(CommonSymbols.this_);\r\n if (scopedThis) {\r\n let scopedThisClass = assert(scopedThis.type.classReference);\r\n let base = scopedThisClass.base;\r\n if (base) {\r\n this.currentType = base.type;\r\n return module.local_get(scopedThis.index, base.type.toNativeType());\r\n }\r\n }\r\n }\r\n if (actualFunction.is(CommonFlags.INSTANCE)) {\r\n let classInstance = assert(actualFunction.parent); assert(classInstance.kind == ElementKind.CLASS);\r\n let baseClassInstance = (classInstance).base;\r\n if (baseClassInstance) {\r\n let superType = baseClassInstance.type;\r\n this.currentType = superType;\r\n return module.local_get(0, superType.toNativeType());\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode._super_can_only_be_referenced_in_a_derived_class,\r\n expression.range\r\n );\r\n this.currentType = this.options.usizeType;\r\n return module.unreachable();\r\n }\r\n }\r\n\r\n this.maybeCompileEnclosingSource(expression);\r\n\r\n // otherwise resolve\r\n var target = this.resolver.resolveIdentifier( // reports\r\n expression,\r\n flow,\r\n this.currentEnum || actualFunction\r\n );\r\n if (!target) return module.unreachable();\r\n\r\n switch (target.kind) {\r\n case ElementKind.LOCAL: {\r\n let type = (target).type;\r\n assert(type != Type.void);\r\n if ((target).is(CommonFlags.INLINED)) {\r\n return this.compileInlineConstant(target, contextualType, constraints);\r\n }\r\n let localIndex = (target).index;\r\n assert(localIndex >= 0);\r\n if (type.is(TypeFlags.NULLABLE) && flow.isLocalFlag(localIndex, LocalFlags.NONNULL, false)) {\r\n type = type.nonNullableType;\r\n }\r\n this.currentType = type;\r\n return this.module.local_get(localIndex, type.toNativeType());\r\n }\r\n case ElementKind.GLOBAL: {\r\n if (!this.compileGlobal(target)) { // reports; not yet compiled if a static field\r\n return this.module.unreachable();\r\n }\r\n let type = (target).type;\r\n assert(type != Type.void);\r\n if ((target).is(CommonFlags.INLINED)) {\r\n return this.compileInlineConstant(target, contextualType, constraints);\r\n }\r\n this.currentType = type;\r\n return this.module.global_get((target).internalName, type.toNativeType());\r\n }\r\n case ElementKind.ENUMVALUE: { // here: if referenced from within the same enum\r\n if (!target.is(CommonFlags.COMPILED)) {\r\n this.error(\r\n DiagnosticCode.A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums,\r\n expression.range\r\n );\r\n this.currentType = Type.i32;\r\n return this.module.unreachable();\r\n }\r\n this.currentType = Type.i32;\r\n if ((target).is(CommonFlags.INLINED)) {\r\n assert((target).constantValueKind == ConstantValueKind.INTEGER);\r\n return this.module.i32(i64_low((target).constantIntegerValue));\r\n }\r\n return this.module.global_get((target).internalName, NativeType.I32);\r\n }\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n let instance = this.resolver.resolveFunction(\r\n target,\r\n null,\r\n makeMap(flow.contextualTypeArguments)\r\n );\r\n if (!(instance && this.compileFunction(instance))) return module.unreachable();\r\n let index = this.ensureFunctionTableEntry(instance);\r\n this.currentType = instance.signature.type;\r\n return this.module.i32(index);\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n\r\n compileInstanceOfExpression(\r\n expression: InstanceOfExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var module = this.module;\r\n // NOTE that this differs from TypeScript in that the rhs is a type, not an expression. at the\r\n // time of implementation, this seemed more useful because dynamic rhs expressions are not\r\n // possible in AS anyway. also note that the code generated below must preserve side-effects of\r\n // the LHS expression even when the result is a constant, i.e. return a block dropping `expr`.\r\n var expr = this.compileExpression(expression.expression, this.options.usizeType);\r\n var actualType = this.currentType;\r\n var expectedType = this.resolver.resolveType(expression.isType, this.currentFlow.actualFunction);\r\n this.currentType = Type.bool;\r\n if (!expectedType) return module.unreachable();\r\n\r\n // instanceof - must be exact\r\n if (!expectedType.is(TypeFlags.REFERENCE)) {\r\n return module.block(null, [\r\n module.drop(expr),\r\n module.i32(actualType == expectedType ? 1 : 0)\r\n ], NativeType.I32);\r\n }\r\n\r\n // instanceof - always false\r\n if (!actualType.is(TypeFlags.REFERENCE)) {\r\n return module.block(null, [\r\n module.drop(expr),\r\n module.i32(0)\r\n ], NativeType.I32);\r\n }\r\n\r\n // both LHS and RHS are references now\r\n var nativeSizeType = actualType.toNativeType();\r\n\r\n // instanceof - LHS must be != 0\r\n if (actualType.is(TypeFlags.NULLABLE) && !expectedType.is(TypeFlags.NULLABLE)) {\r\n\r\n // downcast - check statically\r\n if (actualType.nonNullableType.isAssignableTo(expectedType)) {\r\n return module.binary(\r\n nativeSizeType == NativeType.I64\r\n ? BinaryOp.NeI64\r\n : BinaryOp.NeI32,\r\n expr,\r\n actualType.toNativeZero(module)\r\n );\r\n }\r\n\r\n // upcast - check dynamically\r\n if (expectedType.isAssignableTo(actualType)) {\r\n let program = this.program;\r\n if (!(actualType.isUnmanaged || expectedType.isUnmanaged)) {\r\n let flow = this.currentFlow;\r\n let tempLocal = flow.getAndFreeTempLocal(actualType);\r\n let instanceofInstance = assert(program.instanceofInstance);\r\n this.compileFunction(instanceofInstance);\r\n return module.if(\r\n module.unary(\r\n nativeSizeType == NativeType.I64\r\n ? UnaryOp.EqzI64\r\n : UnaryOp.EqzI32,\r\n module.local_tee(tempLocal.index, expr),\r\n ),\r\n module.i32(0),\r\n this.makeCallDirect(instanceofInstance, [\r\n module.local_get(tempLocal.index, nativeSizeType),\r\n module.i32(expectedType.classReference!.id)\r\n ], expression)\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n }\r\n }\r\n\r\n // either none or both nullable\r\n } else {\r\n\r\n // downcast - check statically\r\n if (actualType.isAssignableTo(expectedType)) {\r\n return module.block(null, [\r\n this.convertExpression(expr, actualType, Type.void, false, false, expression.expression),\r\n module.i32(1)\r\n ], NativeType.I32);\r\n\r\n // upcast - check dynamically\r\n } else if (expectedType.isAssignableTo(actualType)) {\r\n let program = this.program;\r\n if (!(actualType.isUnmanaged || expectedType.isUnmanaged)) {\r\n // FIXME: the temp local and the if can be removed here once flows\r\n // perform null checking, which would error earlier when checking\r\n // uninitialized (thus zero) `var a: A` to be an instance of something.\r\n let flow = this.currentFlow;\r\n let tempLocal = flow.getAndFreeTempLocal(actualType);\r\n let instanceofInstance = assert(program.instanceofInstance);\r\n this.compileFunction(instanceofInstance);\r\n return module.if(\r\n module.unary(\r\n nativeSizeType == NativeType.I64\r\n ? UnaryOp.EqzI64\r\n : UnaryOp.EqzI32,\r\n module.local_tee(tempLocal.index, expr),\r\n ),\r\n module.i32(0),\r\n this.makeCallDirect(instanceofInstance, [\r\n module.local_get(tempLocal.index, nativeSizeType),\r\n module.i32(expectedType.classReference!.id)\r\n ], expression)\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n }\r\n }\r\n }\r\n\r\n // false\r\n return module.block(null, [\r\n module.drop(expr),\r\n module.i32(0)\r\n ], NativeType.I32);\r\n }\r\n\r\n compileLiteralExpression(\r\n expression: LiteralExpression,\r\n contextualType: Type,\r\n constraints: Constraints,\r\n implicitlyNegate: bool = false\r\n ): ExpressionRef {\r\n var module = this.module;\r\n switch (expression.literalKind) {\r\n case LiteralKind.ARRAY: {\r\n assert(!implicitlyNegate);\r\n let classType = contextualType.classReference;\r\n if (classType) {\r\n if (classType.prototype == this.program.arrayPrototype) {\r\n return this.compileArrayLiteral(\r\n assert(classType.typeArguments)[0],\r\n (expression).elementExpressions,\r\n constraints,\r\n expression\r\n );\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n case LiteralKind.FLOAT: {\r\n let floatValue = (expression).value;\r\n if (implicitlyNegate) {\r\n floatValue = -floatValue;\r\n }\r\n if (contextualType == Type.f32) {\r\n return module.f32(floatValue);\r\n }\r\n this.currentType = Type.f64;\r\n return module.f64(floatValue);\r\n }\r\n case LiteralKind.INTEGER: {\r\n let intValue = (expression).value;\r\n if (implicitlyNegate) {\r\n intValue = i64_sub(\r\n i64_new(0),\r\n intValue\r\n );\r\n }\r\n let type = this.resolver.determineIntegerLiteralType(intValue, contextualType);\r\n this.currentType = type;\r\n switch (type.kind) {\r\n case TypeKind.ISIZE: if (!this.options.isWasm64) return module.i32(i64_low(intValue));\r\n case TypeKind.I64: return module.i64(i64_low(intValue), i64_high(intValue));\r\n case TypeKind.USIZE: if (!this.options.isWasm64) return module.i32(i64_low(intValue));\r\n case TypeKind.U64: return module.i64(i64_low(intValue), i64_high(intValue));\r\n case TypeKind.F32: return module.f32(i64_to_f32(intValue));\r\n case TypeKind.F64: return module.f64(i64_to_f64(intValue));\r\n default: return module.i32(i64_low(intValue));\r\n }\r\n }\r\n case LiteralKind.STRING: {\r\n assert(!implicitlyNegate);\r\n return this.compileStringLiteral(expression);\r\n }\r\n case LiteralKind.OBJECT: {\r\n assert(!implicitlyNegate);\r\n return this.compileObjectLiteral(expression, contextualType);\r\n }\r\n // case LiteralKind.REGEXP:\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n this.currentType = contextualType;\r\n return module.unreachable();\r\n }\r\n\r\n compileStringLiteral(expression: StringLiteralExpression): ExpressionRef {\r\n return this.ensureStaticString(expression.value);\r\n }\r\n\r\n compileArrayLiteral(\r\n elementType: Type,\r\n expressions: (Expression | null)[],\r\n constraints: Constraints,\r\n reportNode: Node\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var program = this.program;\r\n var arrayPrototype = assert(program.arrayPrototype);\r\n var arrayInstance = assert(this.resolver.resolveClass(arrayPrototype, [ elementType ]));\r\n var arrayBufferInstance = assert(program.arrayBufferInstance);\r\n var arrayType = arrayInstance.type;\r\n var flow = this.currentFlow;\r\n\r\n // block those here so compiling expressions doesn't conflict\r\n var tempThis = flow.getTempLocal(arrayType);\r\n var tempDataStart = flow.getTempLocal(arrayBufferInstance.type);\r\n\r\n // compile value expressions and find out whether all are constant\r\n var length = expressions.length;\r\n var values = new Array(length);\r\n var isStatic = true;\r\n var nativeElementType = elementType.toNativeType();\r\n for (let i = 0; i < length; ++i) {\r\n let expression = expressions[i];\r\n let expr = expression\r\n ? module.precomputeExpression(\r\n this.compileExpression(expression, elementType,\r\n Constraints.CONV_IMPLICIT\r\n )\r\n )\r\n : elementType.toNativeZero(module);\r\n if (getExpressionId(expr) == ExpressionId.Const) {\r\n assert(getExpressionType(expr) == nativeElementType);\r\n } else {\r\n isStatic = false;\r\n }\r\n values[i] = expr;\r\n }\r\n\r\n // if the array is static, make a static arraybuffer segment\r\n if (isStatic) {\r\n flow.freeTempLocal(tempThis);\r\n flow.freeTempLocal(tempDataStart);\r\n\r\n let runtimeHeaderSize = program.runtimeHeaderSize;\r\n let bufferSegment = this.ensureStaticArrayBuffer(elementType, values);\r\n let bufferAddress = i64_add(bufferSegment.offset, i64_new(runtimeHeaderSize));\r\n\r\n // make both the buffer and array header static if assigned to a global. this can't be done\r\n // if inside of a function because each invocation must create a new array reference then.\r\n if (constraints & Constraints.PREFER_STATIC) {\r\n let arraySegment = this.ensureStaticArrayHeader(elementType, bufferSegment);\r\n let arrayAddress = i64_add(arraySegment.offset, i64_new(runtimeHeaderSize));\r\n this.currentType = arrayType;\r\n return program.options.isWasm64\r\n ? this.module.i64(i64_low(arrayAddress), i64_high(arrayAddress))\r\n : this.module.i32(i64_low(arrayAddress));\r\n\r\n // otherwise allocate a new array header and make it wrap a copy of the static buffer\r\n } else {\r\n // makeArray(length, alignLog2, classId, staticBuffer)\r\n let expr = this.makeCallDirect(program.allocArrayInstance, [\r\n module.i32(length),\r\n program.options.isWasm64\r\n ? module.i64(elementType.alignLog2)\r\n : module.i32(elementType.alignLog2),\r\n module.i32(arrayInstance.id),\r\n program.options.isWasm64\r\n ? module.i64(i64_low(bufferAddress), i64_high(bufferAddress))\r\n : module.i32(i64_low(bufferAddress))\r\n ], reportNode);\r\n this.currentType = arrayType;\r\n return this.makeAutorelease(this.makeRetain(expr));\r\n }\r\n }\r\n\r\n // otherwise compile an explicit instantiation with indexed sets\r\n var setter = arrayInstance.lookupOverload(OperatorKind.INDEXED_SET, true);\r\n if (!setter) {\r\n flow.freeTempLocal(tempThis);\r\n flow.freeTempLocal(tempDataStart);\r\n this.error(\r\n DiagnosticCode.Index_signature_in_type_0_only_permits_reading,\r\n reportNode.range, arrayInstance.internalName\r\n );\r\n this.currentType = arrayType;\r\n return module.unreachable();\r\n }\r\n var nativeArrayType = arrayType.toNativeType();\r\n\r\n var stmts = new Array();\r\n // tempThis = makeArray(length, alignLog2, classId, source = 0)\r\n stmts.push(\r\n module.local_set(tempThis.index,\r\n this.makeCallDirect(program.allocArrayInstance, [\r\n module.i32(length),\r\n program.options.isWasm64\r\n ? module.i64(elementType.alignLog2)\r\n : module.i32(elementType.alignLog2),\r\n module.i32(arrayInstance.id),\r\n program.options.isWasm64\r\n ? module.i64(0)\r\n : module.i32(0)\r\n ], reportNode),\r\n )\r\n );\r\n // tempData = tempThis.dataStart\r\n var dataStart = assert(arrayInstance.lookupInSelf(\"dataStart\"));\r\n assert(dataStart.kind == ElementKind.FIELD);\r\n stmts.push(\r\n module.local_set(tempDataStart.index,\r\n module.load(arrayType.byteSize, false,\r\n module.local_get(tempThis.index, nativeArrayType),\r\n nativeArrayType,\r\n (dataStart).memoryOffset\r\n )\r\n )\r\n );\r\n var isManaged = elementType.isManaged;\r\n for (let i = 0, alignLog2 = elementType.alignLog2; i < length; ++i) {\r\n let valueExpr = values[i];\r\n if (isManaged) {\r\n // value = __retain(value)\r\n valueExpr = this.makeRetain(valueExpr);\r\n }\r\n // store(tempData, value, immOffset)\r\n stmts.push(\r\n module.store(elementType.byteSize,\r\n module.local_get(tempDataStart.index, nativeArrayType),\r\n valueExpr,\r\n nativeElementType,\r\n i << alignLog2\r\n )\r\n );\r\n }\r\n // -> tempThis\r\n stmts.push(\r\n module.local_get(tempThis.index, nativeArrayType)\r\n );\r\n flow.freeTempLocal(tempThis);\r\n flow.freeTempLocal(tempDataStart);\r\n this.currentType = arrayType;\r\n return module.block(null, stmts, nativeArrayType);\r\n }\r\n\r\n compileObjectLiteral(expression: ObjectLiteralExpression, contextualType: Type): ExpressionRef {\r\n var module = this.module;\r\n\r\n // contextual type must be a class\r\n var classReference = contextualType.classReference;\r\n if (!classReference || classReference.is(CommonFlags.ABSTRACT)) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n expression.range, \"\", contextualType.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n\r\n // if present, check that the constructor is compatible with object literals\r\n var ctor = classReference.constructorInstance;\r\n if (ctor) {\r\n // TODO: if the constructor requires parameters, check whether these are given as part of the\r\n // object literal and use them to call the ctor while not generating a store.\r\n if (ctor.signature.requiredParameters) {\r\n this.error(\r\n DiagnosticCode.Constructor_of_class_0_must_not_require_any_arguments,\r\n expression.range, classReference.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n if (ctor.is(CommonFlags.PRIVATE)) {\r\n this.error(\r\n DiagnosticCode.Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration,\r\n expression.range, classReference.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n if (ctor.is(CommonFlags.PROTECTED)) {\r\n this.error(\r\n DiagnosticCode.Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration,\r\n expression.range, classReference.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n\r\n // check and compile field values\r\n var names = expression.names;\r\n var numNames = names.length;\r\n var values = expression.values;\r\n var members = classReference.members;\r\n var hasErrors = false;\r\n var exprs = new Array(numNames + 2);\r\n var flow = this.currentFlow;\r\n var tempLocal = flow.getAutoreleaseLocal(this.options.usizeType);\r\n assert(numNames == values.length);\r\n for (let i = 0, k = numNames; i < k; ++i) {\r\n let member = members ? members.get(names[i].text) : null;\r\n if (!member || member.kind != ElementKind.FIELD) {\r\n this.error(\r\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\r\n names[i].range, names[i].text, classReference.toString()\r\n );\r\n hasErrors = true;\r\n continue;\r\n }\r\n let type = (member).type;\r\n exprs[i + 1] = this.module.store( // TODO: handle setters as well\r\n type.byteSize,\r\n this.module.local_get(tempLocal.index, this.options.nativeSizeType),\r\n this.compileExpression(values[i], (member).type, Constraints.CONV_IMPLICIT),\r\n type.toNativeType(),\r\n (member).memoryOffset\r\n );\r\n }\r\n this.currentType = classReference.type.nonNullableType;\r\n if (hasErrors) return module.unreachable();\r\n\r\n // allocate a new instance first and assign 'this' to the temp. local\r\n exprs[0] = module.local_set(\r\n tempLocal.index,\r\n this.makeRetain(\r\n this.makeAllocation(classReference)\r\n )\r\n );\r\n\r\n // once all field values have been set, return 'this'\r\n exprs[exprs.length - 1] = module.local_get(tempLocal.index, this.options.nativeSizeType);\r\n\r\n this.currentType = classReference.type;\r\n return module.block(null, exprs, this.options.nativeSizeType);\r\n }\r\n\r\n compileNewExpression(\r\n expression: NewExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n\r\n // obtain the class being instantiated\r\n var target = this.resolver.resolveExpression( // reports\r\n expression.expression,\r\n flow\r\n );\r\n if (!target) return module.unreachable();\r\n if (target.kind != ElementKind.CLASS_PROTOTYPE) {\r\n this.error(\r\n DiagnosticCode.Cannot_use_new_with_an_expression_whose_type_lacks_a_construct_signature,\r\n expression.expression.range\r\n );\r\n return this.module.unreachable();\r\n }\r\n var classPrototype = target;\r\n var classInstance: Class | null = null;\r\n var typeArguments = expression.typeArguments;\r\n var classReference: Class | null;\r\n if (\r\n !typeArguments &&\r\n (classReference = contextualType.classReference) !== null &&\r\n classReference.is(CommonFlags.GENERIC)\r\n ) {\r\n classInstance = this.resolver.resolveClass(\r\n classPrototype,\r\n classReference.typeArguments,\r\n makeMap(flow.contextualTypeArguments)\r\n );\r\n } else {\r\n classInstance = this.resolver.resolveClassInclTypeArguments(\r\n classPrototype,\r\n typeArguments,\r\n flow.actualFunction.parent, // relative to caller\r\n makeMap(flow.contextualTypeArguments),\r\n expression\r\n );\r\n }\r\n if (!classInstance) return module.unreachable();\r\n if (contextualType == Type.void) constraints |= Constraints.WILL_DROP;\r\n return this.compileInstantiate(classInstance, expression.arguments, constraints, expression);\r\n }\r\n\r\n /** Gets the compiled constructor of the specified class or generates one if none is present. */\r\n ensureConstructor(classInstance: Class, reportNode: Node): Function {\r\n var instance = classInstance.constructorInstance;\r\n if (instance) {\r\n // do not attempt to compile it if inlined anyway\r\n if (!instance.hasDecorator(DecoratorFlags.INLINE)) this.compileFunction(instance);\r\n return instance;\r\n }\r\n\r\n // clone base constructor if a derived class\r\n var baseClass = classInstance.base;\r\n if (baseClass) {\r\n let baseCtor = this.ensureConstructor(baseClass, reportNode);\r\n instance = new Function(\r\n CommonSymbols.constructor,\r\n new FunctionPrototype(\r\n CommonSymbols.constructor,\r\n classInstance,\r\n // declaration is important, i.e. to access optional parameter initializers\r\n (baseCtor.declaration).clone()\r\n ),\r\n baseCtor.signature,\r\n null\r\n );\r\n\r\n // otherwise make a default constructor\r\n } else {\r\n instance = new Function(\r\n CommonSymbols.constructor,\r\n new FunctionPrototype(\r\n CommonSymbols.constructor,\r\n classInstance,\r\n this.program.makeNativeFunctionDeclaration(CommonSymbols.constructor,\r\n CommonFlags.INSTANCE | CommonFlags.CONSTRUCTOR\r\n )\r\n ),\r\n new Signature(null, classInstance.type, classInstance.type),\r\n null\r\n );\r\n }\r\n\r\n instance.internalName = classInstance.internalName + INSTANCE_DELIMITER + \"constructor\";\r\n instance.set(CommonFlags.COMPILED);\r\n instance.prototype.setResolvedInstance(\"\", instance);\r\n classInstance.constructorInstance = instance;\r\n var previousFlow = this.currentFlow;\r\n var flow = instance.flow;\r\n this.currentFlow = flow;\r\n\r\n // generate body\r\n var signature = instance.signature;\r\n var module = this.module;\r\n var nativeSizeType = this.options.nativeSizeType;\r\n var stmts = new Array();\r\n\r\n // {\r\n // if (!this) this = \r\n // IF_DERIVED: this = super(this, ...args)\r\n // this.a = X\r\n // this.b = Y\r\n // return this\r\n // }\r\n stmts.push(\r\n module.if(\r\n module.unary(nativeSizeType == NativeType.I64 ? UnaryOp.EqzI64 : UnaryOp.EqzI32,\r\n module.local_get(0, nativeSizeType)\r\n ),\r\n module.local_set(0,\r\n this.makeRetain(\r\n this.makeAllocation(classInstance)\r\n )\r\n )\r\n )\r\n );\r\n if (baseClass) {\r\n let parameterTypes = signature.parameterTypes;\r\n let numParameters = parameterTypes.length;\r\n let operands = new Array(1 + numParameters);\r\n operands[0] = module.local_get(0, nativeSizeType);\r\n for (let i = 0; i < numParameters; ++i) {\r\n operands[i + 1] = module.local_get(i + 1, parameterTypes[i].toNativeType());\r\n }\r\n // TODO: base constructor might be inlined, but makeCallDirect can't do this\r\n stmts.push(\r\n module.local_set(0,\r\n this.makeCallDirect(assert(baseClass.constructorInstance), operands, reportNode)\r\n )\r\n );\r\n }\r\n this.makeFieldInitialization(classInstance, stmts);\r\n var body = this.performAutoreleasesWithValue(flow, module.local_get(0, nativeSizeType), classInstance.type, stmts);\r\n flow.freeScopedLocals();\r\n this.currentFlow = previousFlow;\r\n\r\n // make the function\r\n var typeRef = this.ensureFunctionType(signature.parameterTypes, signature.returnType, signature.thisType);\r\n var locals = instance.localsByIndex;\r\n var varTypes = new Array(); // of temp. vars added while compiling initializers\r\n var numOperands = 1 + signature.parameterTypes.length;\r\n var numLocals = locals.length;\r\n if (numLocals > numOperands) {\r\n for (let i = numOperands; i < numLocals; ++i) varTypes.push(locals[i].type.toNativeType());\r\n }\r\n var funcRef = module.addFunction(instance.internalName, typeRef, varTypes, body);\r\n instance.finalize(module, funcRef);\r\n return instance;\r\n }\r\n\r\n compileInstantiate(\r\n /** Class to instantiate. */\r\n classInstance: Class,\r\n /** Constructor arguments. */\r\n argumentExpressions: Expression[],\r\n /** Contextual flags. */\r\n constraints: Constraints,\r\n /** Node to report on. */\r\n reportNode: Node\r\n ): ExpressionRef {\r\n var ctor = this.ensureConstructor(classInstance, reportNode);\r\n var expr = this.compileCallDirect( // no need for another autoreleased local\r\n ctor,\r\n argumentExpressions,\r\n reportNode,\r\n this.options.usizeType.toNativeZero(this.module),\r\n constraints\r\n );\r\n if (getExpressionType(expr) != NativeType.None) { // possibly IMM_DROPPED\r\n this.currentType = classInstance.type; // important because a super ctor could be called\r\n }\r\n return expr;\r\n }\r\n\r\n /**\r\n * Compiles a property access in the specified context.\r\n * @param retainConstantType Retains the type of inlined constants if `true`, otherwise\r\n * precomputes them according to context.\r\n */\r\n compilePropertyAccessExpression(\r\n propertyAccess: PropertyAccessExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n\r\n this.maybeCompileEnclosingSource(propertyAccess);\r\n\r\n var target = this.resolver.resolvePropertyAccessExpression(propertyAccess, flow, contextualType); // reports\r\n if (!target) return module.unreachable();\r\n\r\n switch (target.kind) {\r\n case ElementKind.GLOBAL: { // static field\r\n if (!this.compileGlobal(target)) { // reports; not yet compiled if a static field\r\n return module.unreachable();\r\n }\r\n let globalType = (target).type;\r\n assert(globalType != Type.void);\r\n if ((target).is(CommonFlags.INLINED)) {\r\n return this.compileInlineConstant(target, contextualType, constraints);\r\n }\r\n this.currentType = globalType;\r\n return module.global_get((target).internalName, globalType.toNativeType());\r\n }\r\n case ElementKind.ENUMVALUE: { // enum value\r\n let theEnum = assert((target).parent); assert(theEnum.kind == ElementKind.ENUM);\r\n if (!this.compileEnum(theEnum)) {\r\n this.currentType = Type.i32;\r\n return this.module.unreachable();\r\n }\r\n this.currentType = Type.i32;\r\n if ((target).is(CommonFlags.INLINED)) {\r\n assert((target).constantValueKind == ConstantValueKind.INTEGER);\r\n return module.i32(i64_low((target).constantIntegerValue));\r\n }\r\n return module.global_get((target).internalName, NativeType.I32);\r\n }\r\n case ElementKind.FIELD: { // instance field\r\n assert((target).memoryOffset >= 0);\r\n let thisExpr = this.compileExpression(assert(this.resolver.currentThisExpression), this.options.usizeType);\r\n this.currentType = (target).type;\r\n return module.load(\r\n (target).type.byteSize,\r\n (target).type.is(TypeFlags.SIGNED | TypeFlags.INTEGER),\r\n thisExpr,\r\n (target).type.toNativeType(),\r\n (target).memoryOffset\r\n );\r\n }\r\n case ElementKind.PROPERTY_PROTOTYPE: {// static property\r\n let getterPrototype = (target).getterPrototype;\r\n if (getterPrototype) {\r\n let getter = this.resolver.resolveFunction(getterPrototype, null);\r\n if (getter) return this.compileCallDirect(getter, [], propertyAccess, 0);\r\n }\r\n return module.unreachable();\r\n }\r\n case ElementKind.PROPERTY: { // instance property\r\n let getterInstance = assert((target).getterInstance);\r\n return this.compileCallDirect(getterInstance, [], propertyAccess,\r\n this.compileExpression(assert(this.resolver.currentThisExpression), this.options.usizeType)\r\n );\r\n }\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n this.error(\r\n DiagnosticCode.Cannot_access_method_0_without_calling_it_as_it_requires_this_to_be_set,\r\n propertyAccess.range, (target).name\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n propertyAccess.range\r\n );\r\n return module.unreachable();\r\n }\r\n\r\n compileTernaryExpression(\r\n expression: TernaryExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var ifThen = expression.ifThen;\r\n var ifElse = expression.ifElse;\r\n var outerFlow = this.currentFlow;\r\n\r\n var condExpr = this.module.precomputeExpression(\r\n this.makeIsTrueish(\r\n this.compileExpression(expression.condition, Type.bool),\r\n this.currentType\r\n )\r\n );\r\n\r\n // Try to eliminate unnecesssary branches if the condition is constant\r\n if (\r\n getExpressionId(condExpr) == ExpressionId.Const &&\r\n getExpressionType(condExpr) == NativeType.I32\r\n ) {\r\n return getConstValueI32(condExpr)\r\n ? this.compileExpression(ifThen, contextualType)\r\n : this.compileExpression(ifElse, contextualType);\r\n }\r\n\r\n var inheritedConstraints = constraints & Constraints.WILL_RETAIN;\r\n\r\n var ifThenFlow = outerFlow.fork();\r\n this.currentFlow = ifThenFlow;\r\n var ifThenExpr = this.compileExpression(ifThen, contextualType, inheritedConstraints);\r\n var ifThenType = this.currentType;\r\n var IfThenAutoreleaseSkipped = this.skippedAutoreleases.has(ifThenExpr);\r\n\r\n var ifElseFlow = outerFlow.fork();\r\n this.currentFlow = ifElseFlow;\r\n var ifElseExpr = this.compileExpression(ifElse, contextualType, inheritedConstraints);\r\n var ifElseType = this.currentType;\r\n var ifElseAutoreleaseSkipped = this.skippedAutoreleases.has(ifElseExpr);\r\n\r\n var commonType = Type.commonDenominator(ifThenType, ifElseType, false);\r\n if (!commonType) {\r\n this.error(\r\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\r\n ifElse.range, ifElseType.toString(), ifThenType.toString()\r\n );\r\n this.currentType = contextualType;\r\n return this.module.unreachable();\r\n }\r\n ifThenExpr = this.convertExpression(\r\n ifThenExpr,\r\n ifThenType, commonType,\r\n false, false,\r\n ifThen\r\n );\r\n ifElseExpr = this.convertExpression(\r\n ifElseExpr,\r\n ifElseType, commonType,\r\n false, false,\r\n ifElse\r\n );\r\n this.currentType = commonType;\r\n\r\n if (IfThenAutoreleaseSkipped != ifElseAutoreleaseSkipped) { // unify to both skipped\r\n if (!IfThenAutoreleaseSkipped) {\r\n ifThenExpr = this.makeRetain(ifThenExpr);\r\n IfThenAutoreleaseSkipped = true;\r\n } else {\r\n ifElseExpr = this.makeRetain(ifElseExpr);\r\n ifElseAutoreleaseSkipped = true;\r\n }\r\n } else if (!IfThenAutoreleaseSkipped && commonType.isManaged) { // keep alive a little longer\r\n // if (!(constraints & Constraints.WILL_RETAIN)) {\r\n ifThenExpr = this.moveAutorelease(ifThenExpr, ifThenFlow, outerFlow);\r\n ifElseExpr = this.moveAutorelease(ifElseExpr, ifElseFlow, outerFlow);\r\n // }\r\n }\r\n\r\n ifThenExpr = this.performAutoreleasesWithValue(ifThenFlow, ifThenExpr, commonType);\r\n ifThenFlow.freeScopedLocals();\r\n\r\n ifElseExpr = this.performAutoreleasesWithValue(ifElseFlow, ifElseExpr, commonType);\r\n ifElseFlow.freeScopedLocals();\r\n\r\n this.currentFlow = outerFlow;\r\n outerFlow.inheritMutual(ifThenFlow, ifElseFlow);\r\n\r\n var expr = this.module.if(condExpr, ifThenExpr, ifElseExpr);\r\n assert(IfThenAutoreleaseSkipped == ifElseAutoreleaseSkipped);\r\n if (IfThenAutoreleaseSkipped) this.skippedAutoreleases.add(expr);\r\n return expr;\r\n }\r\n\r\n compileUnaryPostfixExpression(\r\n expression: UnaryPostfixExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n\r\n // make a getter for the expression (also obtains the type)\r\n var getValue = this.compileExpression( // reports\r\n expression.operand,\r\n contextualType.exceptVoid,\r\n Constraints.NONE\r\n );\r\n\r\n // shortcut if compiling the getter already failed\r\n if (getExpressionId(getValue) == ExpressionId.Unreachable) return getValue;\r\n\r\n // if the value isn't dropped, a temp. local is required to remember the original value\r\n var tempLocal: Local | null = null;\r\n if (contextualType != Type.void) {\r\n tempLocal = flow.getTempLocal(this.currentType);\r\n getValue = module.local_tee(\r\n tempLocal.index,\r\n getValue\r\n );\r\n }\r\n\r\n var expr: ExpressionRef;\r\n\r\n switch (expression.operator) {\r\n case Token.PLUS_PLUS: {\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(\r\n BinaryOp.AddI32,\r\n getValue,\r\n module.i32(1)\r\n );\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = this.currentType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.POSTFIX_INC);\r\n if (overload) {\r\n expr = this.compileUnaryOverload(overload, expression.operand, getValue, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n case TypeKind.ISIZE: {\r\n let options = this.options;\r\n expr = module.binary(\r\n options.isWasm64\r\n ? BinaryOp.AddI64\r\n : BinaryOp.AddI32,\r\n getValue,\r\n this.currentType.toNativeOne(module)\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(\r\n BinaryOp.AddI64,\r\n getValue,\r\n module.i64(1)\r\n );\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(\r\n BinaryOp.AddF32,\r\n getValue,\r\n module.f32(1)\r\n );\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(\r\n BinaryOp.AddF64,\r\n getValue,\r\n module.f64(1)\r\n );\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n return module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.MINUS_MINUS: {\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(\r\n BinaryOp.SubI32,\r\n getValue,\r\n module.i32(1)\r\n );\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = this.currentType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.POSTFIX_DEC);\r\n if (overload) {\r\n expr = this.compileUnaryOverload(overload, expression.operand, getValue, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n case TypeKind.ISIZE: {\r\n let options = this.options;\r\n expr = module.binary(\r\n options.isWasm64\r\n ? BinaryOp.SubI64\r\n : BinaryOp.SubI32,\r\n getValue,\r\n this.currentType.toNativeOne(module)\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(\r\n BinaryOp.SubI64,\r\n getValue,\r\n module.i64(1)\r\n );\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(\r\n BinaryOp.SubF32,\r\n getValue,\r\n module.f32(1)\r\n );\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(\r\n BinaryOp.SubF64,\r\n getValue,\r\n module.f64(1)\r\n );\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n return module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n return module.unreachable();\r\n }\r\n }\r\n\r\n var resolver = this.resolver;\r\n var target = resolver.resolveExpression(expression.operand, flow); // reports\r\n\r\n // simplify if dropped anyway\r\n if (!tempLocal) {\r\n this.currentType = Type.void;\r\n if (!target) return module.unreachable();\r\n return this.makeAssignment(\r\n target,\r\n expr,\r\n expression.operand,\r\n resolver.currentThisExpression,\r\n resolver.currentElementExpression,\r\n false\r\n );\r\n } else if (!target) {\r\n return module.unreachable();\r\n }\r\n\r\n // otherwise use the temp. local for the intermediate value (always possibly overflows)\r\n var setValue = this.makeAssignment(\r\n target,\r\n expr, // includes a tee of getValue to tempLocal\r\n expression.operand,\r\n resolver.currentThisExpression,\r\n resolver.currentElementExpression,\r\n false\r\n );\r\n\r\n this.currentType = tempLocal.type;\r\n flow.freeTempLocal(tempLocal);\r\n var nativeType = tempLocal.type.toNativeType();\r\n\r\n return module.block(null, [\r\n setValue,\r\n module.local_get(tempLocal.index, nativeType)\r\n ], nativeType); // result of 'x++' / 'x--' might overflow\r\n }\r\n\r\n compileUnaryPrefixExpression(\r\n expression: UnaryPrefixExpression,\r\n contextualType: Type,\r\n constraints: Constraints\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var compound = false;\r\n var expr: ExpressionRef;\r\n\r\n switch (expression.operator) {\r\n case Token.PLUS: {\r\n expr = this.compileExpression(\r\n expression.operand,\r\n contextualType.exceptVoid,\r\n Constraints.NONE\r\n );\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = this.currentType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.PLUS);\r\n if (overload) {\r\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n\r\n // nop\r\n break;\r\n }\r\n case Token.MINUS: {\r\n if (expression.operand.kind == NodeKind.LITERAL && (\r\n (expression.operand).literalKind == LiteralKind.INTEGER ||\r\n (expression.operand).literalKind == LiteralKind.FLOAT\r\n )) {\r\n // implicitly negate integer and float literals. also enables proper checking of literal ranges.\r\n expr = this.compileLiteralExpression(expression.operand, contextualType, Constraints.NONE, true);\r\n // compileExpression normally does this:\r\n if (this.options.sourceMap) this.addDebugLocation(expr, expression.range);\r\n break;\r\n }\r\n\r\n expr = this.compileExpression(\r\n expression.operand,\r\n contextualType.exceptVoid,\r\n Constraints.NONE\r\n );\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = this.currentType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.MINUS);\r\n if (overload) {\r\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.SubI32, module.i32(0), expr);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.SubI64\r\n : BinaryOp.SubI32,\r\n this.currentType.toNativeZero(module),\r\n expr\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.SubI64, module.i64(0), expr);\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.unary(UnaryOp.NegF32, expr);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.unary(UnaryOp.NegF64, expr);\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.PLUS_PLUS: {\r\n compound = true;\r\n expr = this.compileExpression(\r\n expression.operand,\r\n contextualType.exceptVoid,\r\n Constraints.NONE\r\n );\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = this.currentType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.PREFIX_INC);\r\n if (overload) {\r\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.AddI32, expr, this.module.i32(1));\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.AddI64\r\n : BinaryOp.AddI32,\r\n expr,\r\n this.currentType.toNativeOne(module)\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.AddI64, expr, module.i64(1));\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.AddF32, expr, module.f32(1));\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.AddF64, expr, module.f64(1));\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.MINUS_MINUS: {\r\n compound = true;\r\n expr = this.compileExpression(\r\n expression.operand,\r\n contextualType.exceptVoid,\r\n Constraints.NONE\r\n );\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = this.currentType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.PREFIX_DEC);\r\n if (overload) {\r\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.SubI32, expr, module.i32(1));\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.SubI64\r\n : BinaryOp.SubI32,\r\n expr,\r\n this.currentType.toNativeOne(module)\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.SubI64, expr, module.i64(1));\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.binary(BinaryOp.SubF32, expr, module.f32(1));\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.binary(BinaryOp.SubF64, expr, module.f64(1));\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.EXCLAMATION: {\r\n expr = this.compileExpression(\r\n expression.operand,\r\n contextualType.exceptVoid,\r\n Constraints.NONE\r\n );\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = this.currentType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.NOT);\r\n if (overload) {\r\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\r\n break;\r\n }\r\n }\r\n // allow '!' for references even without an overload\r\n }\r\n\r\n expr = this.makeIsFalseish(expr, this.currentType);\r\n this.currentType = Type.bool;\r\n break;\r\n }\r\n case Token.TILDE: {\r\n expr = this.compileExpression(\r\n expression.operand,\r\n contextualType == Type.void\r\n ? Type.i32\r\n : contextualType.is(TypeFlags.FLOAT)\r\n ? Type.i64\r\n : contextualType,\r\n Constraints.NONE\r\n );\r\n\r\n // check operator overload\r\n if (this.currentType.is(TypeFlags.REFERENCE)) {\r\n let classReference = this.currentType.classReference;\r\n if (classReference) {\r\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_NOT);\r\n if (overload) {\r\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\r\n break;\r\n }\r\n }\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n } else {\r\n expr = this.convertExpression(expr,\r\n this.currentType, this.currentType.intType,\r\n false, false,\r\n expression.operand\r\n );\r\n }\r\n\r\n switch (this.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.binary(BinaryOp.XorI32, expr, module.i32(-1));\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n this.options.isWasm64\r\n ? BinaryOp.XorI64\r\n : BinaryOp.XorI32,\r\n expr,\r\n this.currentType.toNativeNegOne(module)\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.XorI64, expr, module.i64(-1, -1));\r\n break;\r\n }\r\n default: {\r\n assert(false);\r\n expr = module.unreachable();\r\n }\r\n }\r\n break;\r\n }\r\n case Token.TYPEOF: {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n expression.range\r\n );\r\n return module.unreachable();\r\n }\r\n default: {\r\n assert(false);\r\n return module.unreachable();\r\n }\r\n }\r\n if (!compound) return expr;\r\n var resolver = this.resolver;\r\n var target = resolver.resolveExpression(expression.operand, this.currentFlow);\r\n if (!target) return module.unreachable();\r\n return this.makeAssignment(\r\n target,\r\n expr,\r\n expression.operand,\r\n resolver.currentThisExpression,\r\n resolver.currentElementExpression,\r\n contextualType != Type.void\r\n );\r\n }\r\n\r\n /** Makes sure that a 32-bit integer value is wrapped to a valid value of the specified type. */\r\n ensureSmallIntegerWrap(expr: ExpressionRef, type: Type): ExpressionRef {\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n switch (type.kind) {\r\n case TypeKind.I8: {\r\n if (flow.canOverflow(expr, type)) {\r\n expr = this.options.hasFeature(Feature.SIGN_EXTENSION)\r\n ? module.unary(UnaryOp.ExtendI8ToI32, expr)\r\n : module.binary(BinaryOp.ShrI32,\r\n module.binary(BinaryOp.ShlI32,\r\n expr,\r\n module.i32(24)\r\n ),\r\n module.i32(24)\r\n );\r\n }\r\n break;\r\n }\r\n case TypeKind.I16: {\r\n if (flow.canOverflow(expr, type)) {\r\n expr = this.options.hasFeature(Feature.SIGN_EXTENSION)\r\n ? module.unary(UnaryOp.ExtendI16ToI32, expr)\r\n : module.binary(BinaryOp.ShrI32,\r\n module.binary(BinaryOp.ShlI32,\r\n expr,\r\n module.i32(16)\r\n ),\r\n module.i32(16)\r\n );\r\n }\r\n break;\r\n }\r\n case TypeKind.U8: {\r\n if (flow.canOverflow(expr, type)) {\r\n expr = module.binary(BinaryOp.AndI32,\r\n expr,\r\n module.i32(0xff)\r\n );\r\n }\r\n break;\r\n }\r\n case TypeKind.U16: {\r\n if (flow.canOverflow(expr, type)) {\r\n expr = module.binary(BinaryOp.AndI32,\r\n expr,\r\n module.i32(0xffff)\r\n );\r\n }\r\n break;\r\n }\r\n case TypeKind.BOOL: {\r\n if (flow.canOverflow(expr, type)) {\r\n // bool is special in that it compares to 0 instead of masking with 0x1\r\n expr = module.binary(BinaryOp.NeI32,\r\n expr,\r\n module.i32(0)\r\n );\r\n }\r\n break;\r\n }\r\n }\r\n return expr;\r\n }\r\n\r\n /** Adds the debug location of the specified expression at the specified range to the source map. */\r\n addDebugLocation(expr: ExpressionRef, range: Range): void {\r\n var parentFunction = this.currentFlow.parentFunction;\r\n var source = range.source;\r\n if (source.debugInfoIndex < 0) source.debugInfoIndex = this.module.addDebugInfoFile(source.normalizedPath);\r\n range.debugInfoRef = expr;\r\n parentFunction.debugLocations.push(range);\r\n }\r\n\r\n // === Specialized code generation ==============================================================\r\n\r\n /** Creates a comparison whether an expression is 'false' in a broader sense. */\r\n makeIsFalseish(expr: ExpressionRef, type: Type): ExpressionRef {\r\n var module = this.module;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL: {\r\n expr = this.ensureSmallIntegerWrap(expr, type);\r\n // fall-through\r\n }\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n return module.unary(UnaryOp.EqzI32, expr);\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n return module.unary(UnaryOp.EqzI64, expr);\r\n }\r\n case TypeKind.USIZE: if (this.skippedAutoreleases.has(expr)) expr = this.makeAutorelease(expr);\r\n case TypeKind.ISIZE: {\r\n return module.unary(type.size == 64 ? UnaryOp.EqzI64 : UnaryOp.EqzI32, expr);\r\n }\r\n case TypeKind.F32: {\r\n return module.binary(BinaryOp.EqF32, expr, module.f32(0));\r\n }\r\n case TypeKind.F64: {\r\n return module.binary(BinaryOp.EqF64, expr, module.f64(0));\r\n }\r\n default: {\r\n assert(false);\r\n return module.i32(1);\r\n }\r\n }\r\n }\r\n\r\n /** Creates a comparison whether an expression is 'true' in a broader sense. */\r\n makeIsTrueish(expr: ExpressionRef, type: Type): ExpressionRef {\r\n var module = this.module;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.U8:\r\n case TypeKind.U16: {\r\n expr = this.ensureSmallIntegerWrap(expr, type);\r\n // fall-through\r\n }\r\n case TypeKind.BOOL: // not a mask, just != 0\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n return expr;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n return module.binary(BinaryOp.NeI64, expr, module.i64(0));\r\n }\r\n case TypeKind.USIZE: if (this.skippedAutoreleases.has(expr)) expr = this.makeAutorelease(expr);\r\n case TypeKind.ISIZE: {\r\n return type.size == 64\r\n ? module.binary(BinaryOp.NeI64, expr, module.i64(0))\r\n : expr;\r\n }\r\n case TypeKind.F32: {\r\n return module.binary(BinaryOp.NeF32, expr, module.f32(0));\r\n }\r\n case TypeKind.F64: {\r\n return module.binary(BinaryOp.NeF64, expr, module.f64(0));\r\n }\r\n default: {\r\n assert(false);\r\n return module.i32(0);\r\n }\r\n }\r\n }\r\n\r\n /** Makes an allocation suitable to hold the data of an instance of the given class. */\r\n makeAllocation(\r\n classInstance: Class\r\n ): ExpressionRef {\r\n // TODO: investigate if it's possible to allocate with RC=1 immediately\r\n var program = this.program;\r\n assert(classInstance.program == program);\r\n var module = this.module;\r\n var options = this.options;\r\n this.currentType = classInstance.type;\r\n var allocInstance = program.allocInstance;\r\n this.compileFunction(allocInstance);\r\n return module.call(allocInstance.internalName, [\r\n options.isWasm64\r\n ? module.i64(classInstance.currentMemoryOffset)\r\n : module.i32(classInstance.currentMemoryOffset),\r\n module.i32(\r\n classInstance.hasDecorator(DecoratorFlags.UNMANAGED)\r\n ? 0\r\n : classInstance.id\r\n )\r\n ], options.nativeSizeType);\r\n }\r\n\r\n /** Makes the initializers for a class's fields. */\r\n makeFieldInitialization(\r\n classInstance: Class,\r\n stmts: ExpressionRef[] = []\r\n ): ExpressionRef[] {\r\n var members = classInstance.members;\r\n if (!members) return [];\r\n\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n var isInline = flow.is(FlowFlags.INLINE_CONTEXT);\r\n var thisLocalIndex = isInline\r\n ? assert(flow.lookupLocal(CommonSymbols.this_)).index\r\n : 0;\r\n var nativeSizeType = this.options.nativeSizeType;\r\n\r\n for (let member of members.values()) {\r\n if (\r\n member.kind != ElementKind.FIELD || // not a field\r\n member.parent != classInstance // inherited field\r\n ) continue;\r\n\r\n let field = member; assert(!field.isAny(CommonFlags.CONST));\r\n let fieldType = field.type;\r\n let nativeFieldType = fieldType.toNativeType();\r\n let initializerNode = field.prototype.initializerNode;\r\n if (initializerNode) { // use initializer\r\n let initExpr = this.compileExpression(initializerNode, fieldType, // reports\r\n Constraints.CONV_IMPLICIT | Constraints.WILL_RETAIN\r\n );\r\n if (fieldType.isManaged && !this.skippedAutoreleases.has(initExpr)) {\r\n initExpr = this.makeRetain(initExpr);\r\n }\r\n stmts.push(\r\n module.store(fieldType.byteSize,\r\n module.local_get(thisLocalIndex, nativeSizeType),\r\n initExpr,\r\n nativeFieldType,\r\n field.memoryOffset\r\n )\r\n );\r\n } else {\r\n let parameterIndex = field.prototype.parameterIndex;\r\n stmts.push(\r\n module.store(fieldType.byteSize,\r\n module.local_get(thisLocalIndex, nativeSizeType),\r\n parameterIndex >= 0 // initialized via parameter (here: a local)\r\n ? module.local_get(\r\n isInline\r\n ? assert(flow.lookupLocal(field.name)).index\r\n : 1 + parameterIndex, // this is local 0\r\n nativeFieldType\r\n )\r\n : fieldType.toNativeZero(module),\r\n nativeFieldType,\r\n field.memoryOffset\r\n )\r\n );\r\n }\r\n }\r\n return stmts;\r\n }\r\n\r\n makeInstanceOfClass(\r\n expr: ExpressionRef,\r\n classInstance: Class\r\n ): ExpressionRef {\r\n var module = this.module;\r\n var flow = this.currentFlow;\r\n var idTemp = flow.getTempLocal(Type.i32);\r\n var idExpr = module.load(4, false,\r\n module.binary(BinaryOp.SubI32,\r\n expr,\r\n module.i32(this.program.runtimeHeaderSize)\r\n ),\r\n NativeType.I32\r\n );\r\n var label = \"instanceof_\" + classInstance.name + \"|\" + flow.pushBreakLabel();\r\n var conditions: ExpressionRef[] = [];\r\n conditions.push(\r\n module.drop( // br_if returns the value too\r\n module.br(label,\r\n module.binary(BinaryOp.EqI32, // classId == class.id\r\n module.local_tee(idTemp.index, idExpr),\r\n module.i32(classInstance.id)\r\n ),\r\n module.i32(1) // ? true\r\n )\r\n )\r\n );\r\n // TODO: insert conditions for all possible subclasses (i.e. cat is also animal)\r\n // TODO: simplify if there are none\r\n conditions.push(\r\n module.i32(0) // : false\r\n );\r\n flow.freeTempLocal(idTemp);\r\n flow.popBreakLabel();\r\n return module.block(label, conditions, NativeType.I32);\r\n }\r\n}\r\n\r\n// helpers\r\n\r\nfunction mangleImportName(\r\n element: Element,\r\n declaration: DeclarationStatement\r\n): void {\r\n // by default, use the file name as the module name\r\n mangleImportName_moduleName = declaration.range.source.simplePath;\r\n // and the internal name of the element within that file as the element name\r\n mangleImportName_elementName = mangleInternalName(\r\n element.name, element.parent, element.is(CommonFlags.INSTANCE), true\r\n );\r\n if (!element.hasDecorator(DecoratorFlags.EXTERNAL)) return;\r\n\r\n var program = element.program;\r\n var decorator = assert(findDecorator(DecoratorKind.EXTERNAL, declaration.decorators));\r\n var args = decorator.arguments;\r\n if (args && args.length) {\r\n let arg = args[0];\r\n // if one argument is given, override just the element name\r\n // if two arguments are given, override both module and element name\r\n if (arg.kind == NodeKind.LITERAL && (arg).literalKind == LiteralKind.STRING) {\r\n mangleImportName_elementName = (arg).value;\r\n if (args.length >= 2) {\r\n arg = args[1];\r\n if (arg.kind == NodeKind.LITERAL && (arg).literalKind == LiteralKind.STRING) {\r\n mangleImportName_moduleName = mangleImportName_elementName;\r\n mangleImportName_elementName = (arg).value;\r\n if (args.length > 2) {\r\n program.error(\r\n DiagnosticCode.Expected_0_arguments_but_got_1,\r\n decorator.range, \"2\", args.length.toString()\r\n );\r\n }\r\n } else {\r\n program.error(\r\n DiagnosticCode.String_literal_expected,\r\n arg.range\r\n );\r\n }\r\n }\r\n } else {\r\n program.error(\r\n DiagnosticCode.String_literal_expected,\r\n arg.range\r\n );\r\n }\r\n } else {\r\n program.error(\r\n DiagnosticCode.Expected_at_least_0_arguments_but_got_1,\r\n decorator.range, \"1\", \"0\"\r\n );\r\n }\r\n}\r\n\r\nvar mangleImportName_moduleName: string;\r\nvar mangleImportName_elementName: string;\r\n\r\n/** Flattens a series of expressions to a nop, a single statement or a block depending on statement count. */\r\nexport function flatten(module: Module, stmts: ExpressionRef[], type: NativeType): ExpressionRef {\r\n var length = stmts.length;\r\n if (length == 0) return module.nop(); // usually filtered out again\r\n if (length == 1) {\r\n let single = stmts[0];\r\n if (getExpressionType(single) == type) return single;\r\n if (getExpressionId(single) == ExpressionId.Block) {\r\n let count = getBlockChildCount(single);\r\n let children = new Array(count);\r\n for (let i = 0; i < count; ++i) children[i] = getBlockChild(single, i);\r\n return module.block(getBlockName(single), children, type);\r\n }\r\n }\r\n return module.block(null, stmts,\r\n type == NativeType.Auto\r\n ? getExpressionType(stmts[length - 1])\r\n : type\r\n );\r\n}\r\n","/**\r\n * Generated from diagnosticsMessages.json. Do not edit.\r\n * @module diagnostics\r\n *//***/\r\n\r\n/* tslint:disable:max-line-length */\r\n\r\n/** Enum of available diagnostic codes. */\r\nexport enum DiagnosticCode {\r\n Operation_not_supported = 100,\r\n Operation_is_unsafe = 101,\r\n User_defined_0 = 102,\r\n Conversion_from_type_0_to_1_requires_an_explicit_cast = 200,\r\n Conversion_from_type_0_to_1_will_require_an_explicit_cast_when_switching_between_32_64_bit = 201,\r\n Type_0_cannot_be_changed_to_type_1 = 202,\r\n Type_0_cannot_be_reinterpreted_as_type_1 = 203,\r\n Basic_type_0_cannot_be_nullable = 204,\r\n Cannot_export_a_mutable_global = 205,\r\n Mutable_value_cannot_be_inlined = 206,\r\n Unmanaged_classes_cannot_extend_managed_classes_and_vice_versa = 207,\r\n Unmanaged_classes_cannot_implement_interfaces = 208,\r\n Invalid_regular_expression_flags = 209,\r\n Implementation_0_must_match_the_signature_1 = 210,\r\n Class_0_is_sealed_and_cannot_be_extended = 211,\r\n Decorator_0_is_not_valid_here = 212,\r\n Duplicate_decorator = 213,\r\n An_allocator_must_be_present_to_use_0 = 214,\r\n Optional_parameter_must_have_an_initializer = 215,\r\n Constructor_of_class_0_must_not_require_any_arguments = 216,\r\n Function_0_cannot_be_inlined_into_itself = 217,\r\n Cannot_access_method_0_without_calling_it_as_it_requires_this_to_be_set = 218,\r\n Optional_properties_are_not_supported = 219,\r\n Expression_must_be_a_compile_time_constant = 220,\r\n Module_cannot_have_multiple_start_functions = 221,\r\n _0_must_be_a_value_between_1_and_2_inclusive = 222,\r\n _0_must_be_a_power_of_two = 223,\r\n TODO_Cannot_inline_inferred_calls_and_specific_internals_yet = 224,\r\n Expression_is_never_null = 225,\r\n Unterminated_string_literal = 1002,\r\n Identifier_expected = 1003,\r\n _0_expected = 1005,\r\n A_file_cannot_have_a_reference_to_itself = 1006,\r\n Trailing_comma_not_allowed = 1009,\r\n Unexpected_token = 1012,\r\n A_rest_parameter_must_be_last_in_a_parameter_list = 1014,\r\n Parameter_cannot_have_question_mark_and_initializer = 1015,\r\n A_required_parameter_cannot_follow_an_optional_parameter = 1016,\r\n Statements_are_not_allowed_in_ambient_contexts = 1036,\r\n Initializers_are_not_allowed_in_ambient_contexts = 1039,\r\n _0_modifier_cannot_be_used_here = 1042,\r\n A_rest_parameter_cannot_be_optional = 1047,\r\n A_rest_parameter_cannot_have_an_initializer = 1048,\r\n A_set_accessor_must_have_exactly_one_parameter = 1049,\r\n A_set_accessor_parameter_cannot_have_an_initializer = 1052,\r\n A_get_accessor_cannot_have_parameters = 1054,\r\n Enum_member_must_have_initializer = 1061,\r\n Type_parameters_cannot_appear_on_a_constructor_declaration = 1092,\r\n Type_annotation_cannot_appear_on_a_constructor_declaration = 1093,\r\n An_accessor_cannot_have_type_parameters = 1094,\r\n A_set_accessor_cannot_have_a_return_type_annotation = 1095,\r\n Type_parameter_list_cannot_be_empty = 1098,\r\n A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement = 1104,\r\n A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement = 1105,\r\n A_return_statement_can_only_be_used_within_a_function_body = 1108,\r\n Expression_expected = 1109,\r\n Type_expected = 1110,\r\n A_default_clause_cannot_appear_more_than_once_in_a_switch_statement = 1113,\r\n Duplicate_label_0 = 1114,\r\n An_export_assignment_cannot_have_modifiers = 1120,\r\n Octal_literals_are_not_allowed_in_strict_mode = 1121,\r\n Digit_expected = 1124,\r\n Hexadecimal_digit_expected = 1125,\r\n Unexpected_end_of_text = 1126,\r\n Invalid_character = 1127,\r\n _case_or_default_expected = 1130,\r\n _super_must_be_followed_by_an_argument_list_or_member_access = 1034,\r\n A_declare_modifier_cannot_be_used_in_an_already_ambient_context = 1038,\r\n Type_argument_expected = 1140,\r\n String_literal_expected = 1141,\r\n Line_break_not_permitted_here = 1142,\r\n Declaration_expected = 1146,\r\n _const_declarations_must_be_initialized = 1155,\r\n Unterminated_regular_expression_literal = 1161,\r\n Interface_declaration_cannot_have_implements_clause = 1176,\r\n Binary_digit_expected = 1177,\r\n Octal_digit_expected = 1178,\r\n An_implementation_cannot_be_declared_in_ambient_contexts = 1183,\r\n An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive = 1198,\r\n Unterminated_Unicode_escape_sequence = 1199,\r\n Decorators_are_not_valid_here = 1206,\r\n _abstract_modifier_can_only_appear_on_a_class_method_or_property_declaration = 1242,\r\n Method_0_cannot_have_an_implementation_because_it_is_marked_abstract = 1245,\r\n A_definite_assignment_assertion_is_not_permitted_in_this_context = 1255,\r\n A_class_may_only_extend_another_class = 1311,\r\n A_parameter_property_cannot_be_declared_using_a_rest_parameter = 1317,\r\n Duplicate_identifier_0 = 2300,\r\n Cannot_find_name_0 = 2304,\r\n Module_0_has_no_exported_member_1 = 2305,\r\n Generic_type_0_requires_1_type_argument_s = 2314,\r\n Type_0_is_not_generic = 2315,\r\n Type_0_is_not_assignable_to_type_1 = 2322,\r\n Index_signature_is_missing_in_type_0 = 2329,\r\n _this_cannot_be_referenced_in_current_location = 2332,\r\n _super_can_only_be_referenced_in_a_derived_class = 2335,\r\n Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors = 2337,\r\n Property_0_does_not_exist_on_type_1 = 2339,\r\n Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures = 2349,\r\n Cannot_use_new_with_an_expression_whose_type_lacks_a_construct_signature = 2351,\r\n A_function_whose_declared_type_is_not_void_must_return_a_value = 2355,\r\n The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access = 2357,\r\n The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access = 2364,\r\n Operator_0_cannot_be_applied_to_types_1_and_2 = 2365,\r\n A_super_call_must_be_the_first_statement_in_the_constructor = 2376,\r\n Constructors_for_derived_classes_must_contain_a_super_call = 2377,\r\n _get_and_set_accessor_must_have_the_same_type = 2380,\r\n Constructor_implementation_is_missing = 2390,\r\n Function_implementation_is_missing_or_not_immediately_following_the_declaration = 2391,\r\n Multiple_constructor_implementations_are_not_allowed = 2392,\r\n Duplicate_function_implementation = 2393,\r\n Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local = 2395,\r\n A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged = 2434,\r\n Type_0_has_no_property_1 = 2460,\r\n The_0_operator_cannot_be_applied_to_type_1 = 2469,\r\n In_const_enum_declarations_member_initializer_must_be_constant_expression = 2474,\r\n Export_declaration_conflicts_with_exported_declaration_of_0 = 2484,\r\n Object_is_possibly_null = 2531,\r\n Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property = 2540,\r\n The_target_of_an_assignment_must_be_a_variable_or_a_property_access = 2541,\r\n Index_signature_in_type_0_only_permits_reading = 2542,\r\n Expected_0_arguments_but_got_1 = 2554,\r\n Expected_at_least_0_arguments_but_got_1 = 2555,\r\n Expected_0_type_arguments_but_got_1 = 2558,\r\n A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums = 2651,\r\n Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration = 2673,\r\n Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration = 2674,\r\n Namespace_0_has_no_exported_member_1 = 2694,\r\n Required_type_parameters_may_not_follow_optional_type_parameters = 2706,\r\n Duplicate_property_0 = 2718,\r\n File_0_not_found = 6054,\r\n Numeric_separators_are_not_allowed_here = 6188,\r\n Multiple_consecutive_numeric_separators_are_not_permitted = 6189,\r\n _super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class = 17009,\r\n _super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class = 17011\r\n}\r\n\r\n/** Translates a diagnostic code to its respective string. */\r\nexport function diagnosticCodeToString(code: DiagnosticCode): string {\r\n switch (code) {\r\n case 100: return \"Operation not supported.\";\r\n case 101: return \"Operation is unsafe.\";\r\n case 102: return \"User-defined: {0}\";\r\n case 200: return \"Conversion from type '{0}' to '{1}' requires an explicit cast.\";\r\n case 201: return \"Conversion from type '{0}' to '{1}' will require an explicit cast when switching between 32/64-bit.\";\r\n case 202: return \"Type '{0}' cannot be changed to type '{1}'.\";\r\n case 203: return \"Type '{0}' cannot be reinterpreted as type '{1}'.\";\r\n case 204: return \"Basic type '{0}' cannot be nullable.\";\r\n case 205: return \"Cannot export a mutable global.\";\r\n case 206: return \"Mutable value cannot be inlined.\";\r\n case 207: return \"Unmanaged classes cannot extend managed classes and vice-versa.\";\r\n case 208: return \"Unmanaged classes cannot implement interfaces.\";\r\n case 209: return \"Invalid regular expression flags.\";\r\n case 210: return \"Implementation '{0}' must match the signature '{1}'.\";\r\n case 211: return \"Class '{0}' is sealed and cannot be extended.\";\r\n case 212: return \"Decorator '{0}' is not valid here.\";\r\n case 213: return \"Duplicate decorator.\";\r\n case 214: return \"An allocator must be present to use '{0}'.\";\r\n case 215: return \"Optional parameter must have an initializer.\";\r\n case 216: return \"Constructor of class '{0}' must not require any arguments.\";\r\n case 217: return \"Function '{0}' cannot be inlined into itself.\";\r\n case 218: return \"Cannot access method '{0}' without calling it as it requires 'this' to be set.\";\r\n case 219: return \"Optional properties are not supported.\";\r\n case 220: return \"Expression must be a compile-time constant.\";\r\n case 221: return \"Module cannot have multiple start functions.\";\r\n case 222: return \"'{0}' must be a value between '{1}' and '{2}' inclusive.\";\r\n case 223: return \"'{0}' must be a power of two.\";\r\n case 224: return \"TODO: Cannot inline inferred calls and specific internals yet.\";\r\n case 225: return \"Expression is never 'null'.\";\r\n case 1002: return \"Unterminated string literal.\";\r\n case 1003: return \"Identifier expected.\";\r\n case 1005: return \"'{0}' expected.\";\r\n case 1006: return \"A file cannot have a reference to itself.\";\r\n case 1009: return \"Trailing comma not allowed.\";\r\n case 1012: return \"Unexpected token.\";\r\n case 1014: return \"A rest parameter must be last in a parameter list.\";\r\n case 1015: return \"Parameter cannot have question mark and initializer.\";\r\n case 1016: return \"A required parameter cannot follow an optional parameter.\";\r\n case 1036: return \"Statements are not allowed in ambient contexts.\";\r\n case 1039: return \"Initializers are not allowed in ambient contexts.\";\r\n case 1042: return \"'{0}' modifier cannot be used here.\";\r\n case 1047: return \"A rest parameter cannot be optional.\";\r\n case 1048: return \"A rest parameter cannot have an initializer.\";\r\n case 1049: return \"A 'set' accessor must have exactly one parameter.\";\r\n case 1052: return \"A 'set' accessor parameter cannot have an initializer.\";\r\n case 1054: return \"A 'get' accessor cannot have parameters.\";\r\n case 1061: return \"Enum member must have initializer.\";\r\n case 1092: return \"Type parameters cannot appear on a constructor declaration.\";\r\n case 1093: return \"Type annotation cannot appear on a constructor declaration.\";\r\n case 1094: return \"An accessor cannot have type parameters.\";\r\n case 1095: return \"A 'set' accessor cannot have a return type annotation.\";\r\n case 1098: return \"Type parameter list cannot be empty.\";\r\n case 1104: return \"A 'continue' statement can only be used within an enclosing iteration statement.\";\r\n case 1105: return \"A 'break' statement can only be used within an enclosing iteration or switch statement.\";\r\n case 1108: return \"A 'return' statement can only be used within a function body.\";\r\n case 1109: return \"Expression expected.\";\r\n case 1110: return \"Type expected.\";\r\n case 1113: return \"A 'default' clause cannot appear more than once in a 'switch' statement.\";\r\n case 1114: return \"Duplicate label '{0}'.\";\r\n case 1120: return \"An export assignment cannot have modifiers.\";\r\n case 1121: return \"Octal literals are not allowed in strict mode.\";\r\n case 1124: return \"Digit expected.\";\r\n case 1125: return \"Hexadecimal digit expected.\";\r\n case 1126: return \"Unexpected end of text.\";\r\n case 1127: return \"Invalid character.\";\r\n case 1130: return \"'case' or 'default' expected.\";\r\n case 1034: return \"'super' must be followed by an argument list or member access.\";\r\n case 1038: return \"A 'declare' modifier cannot be used in an already ambient context.\";\r\n case 1140: return \"Type argument expected.\";\r\n case 1141: return \"String literal expected.\";\r\n case 1142: return \"Line break not permitted here.\";\r\n case 1146: return \"Declaration expected.\";\r\n case 1155: return \"'const' declarations must be initialized.\";\r\n case 1161: return \"Unterminated regular expression literal.\";\r\n case 1176: return \"Interface declaration cannot have 'implements' clause.\";\r\n case 1177: return \"Binary digit expected.\";\r\n case 1178: return \"Octal digit expected.\";\r\n case 1183: return \"An implementation cannot be declared in ambient contexts.\";\r\n case 1198: return \"An extended Unicode escape value must be between 0x0 and 0x10FFFF inclusive.\";\r\n case 1199: return \"Unterminated Unicode escape sequence.\";\r\n case 1206: return \"Decorators are not valid here.\";\r\n case 1242: return \"'abstract' modifier can only appear on a class, method, or property declaration.\";\r\n case 1245: return \"Method '{0}' cannot have an implementation because it is marked abstract.\";\r\n case 1255: return \"A definite assignment assertion '!' is not permitted in this context.\";\r\n case 1311: return \"A class may only extend another class.\";\r\n case 1317: return \"A parameter property cannot be declared using a rest parameter.\";\r\n case 2300: return \"Duplicate identifier '{0}'.\";\r\n case 2304: return \"Cannot find name '{0}'.\";\r\n case 2305: return \"Module '{0}' has no exported member '{1}'.\";\r\n case 2314: return \"Generic type '{0}' requires {1} type argument(s).\";\r\n case 2315: return \"Type '{0}' is not generic.\";\r\n case 2322: return \"Type '{0}' is not assignable to type '{1}'.\";\r\n case 2329: return \"Index signature is missing in type '{0}'.\";\r\n case 2332: return \"'this' cannot be referenced in current location.\";\r\n case 2335: return \"'super' can only be referenced in a derived class.\";\r\n case 2337: return \"Super calls are not permitted outside constructors or in nested functions inside constructors.\";\r\n case 2339: return \"Property '{0}' does not exist on type '{1}'.\";\r\n case 2349: return \"Cannot invoke an expression whose type lacks a call signature. Type '{0}' has no compatible call signatures.\";\r\n case 2351: return \"Cannot use 'new' with an expression whose type lacks a construct signature.\";\r\n case 2355: return \"A function whose declared type is not 'void' must return a value.\";\r\n case 2357: return \"The operand of an increment or decrement operator must be a variable or a property access.\";\r\n case 2364: return \"The left-hand side of an assignment expression must be a variable or a property access.\";\r\n case 2365: return \"Operator '{0}' cannot be applied to types '{1}' and '{2}'.\";\r\n case 2376: return \"A 'super' call must be the first statement in the constructor.\";\r\n case 2377: return \"Constructors for derived classes must contain a 'super' call.\";\r\n case 2380: return \"'get' and 'set' accessor must have the same type.\";\r\n case 2390: return \"Constructor implementation is missing.\";\r\n case 2391: return \"Function implementation is missing or not immediately following the declaration.\";\r\n case 2392: return \"Multiple constructor implementations are not allowed.\";\r\n case 2393: return \"Duplicate function implementation.\";\r\n case 2395: return \"Individual declarations in merged declaration '{0}' must be all exported or all local.\";\r\n case 2434: return \"A namespace declaration cannot be located prior to a class or function with which it is merged.\";\r\n case 2460: return \"Type '{0}' has no property '{1}'.\";\r\n case 2469: return \"The '{0}' operator cannot be applied to type '{1}'.\";\r\n case 2474: return \"In 'const' enum declarations member initializer must be constant expression.\";\r\n case 2484: return \"Export declaration conflicts with exported declaration of '{0}'.\";\r\n case 2531: return \"Object is possibly 'null'.\";\r\n case 2540: return \"Cannot assign to '{0}' because it is a constant or a read-only property.\";\r\n case 2541: return \"The target of an assignment must be a variable or a property access.\";\r\n case 2542: return \"Index signature in type '{0}' only permits reading.\";\r\n case 2554: return \"Expected {0} arguments, but got {1}.\";\r\n case 2555: return \"Expected at least {0} arguments, but got {1}.\";\r\n case 2558: return \"Expected {0} type arguments, but got {1}.\";\r\n case 2651: return \"A member initializer in a enum declaration cannot reference members declared after it, including members defined in other enums.\";\r\n case 2673: return \"Constructor of class '{0}' is private and only accessible within the class declaration.\";\r\n case 2674: return \"Constructor of class '{0}' is protected and only accessible within the class declaration.\";\r\n case 2694: return \"Namespace '{0}' has no exported member '{1}'.\";\r\n case 2706: return \"Required type parameters may not follow optional type parameters.\";\r\n case 2718: return \"Duplicate property '{0}'.\";\r\n case 6054: return \"File '{0}' not found.\";\r\n case 6188: return \"Numeric separators are not allowed here.\";\r\n case 6189: return \"Multiple consecutive numeric separators are not permitted.\";\r\n case 17009: return \"'super' must be called before accessing 'this' in the constructor of a derived class.\";\r\n case 17011: return \"'super' must be called before accessing a property of 'super' in the constructor of a derived class.\";\r\n default: return \"\";\r\n }\r\n}\r\n","/**\r\n * Built-in elements providing WebAssembly core functionality.\r\n * @module builtins\r\n *//***/\r\n\r\n import {\r\n Compiler,\r\n Constraints,\r\n RuntimeFeatures,\r\n flatten\r\n} from \"./compiler\";\r\n\r\nimport {\r\n DiagnosticCode\r\n} from \"./diagnostics\";\r\n\r\nimport {\r\n Node,\r\n NodeKind,\r\n Expression,\r\n LiteralKind,\r\n LiteralExpression,\r\n StringLiteralExpression,\r\n CallExpression\r\n} from \"./ast\";\r\n\r\nimport {\r\n Type,\r\n TypeKind,\r\n TypeFlags,\r\n Signature\r\n} from \"./types\";\r\n\r\nimport {\r\n BinaryOp,\r\n UnaryOp,\r\n HostOp,\r\n AtomicRMWOp,\r\n SIMDExtractOp,\r\n SIMDReplaceOp,\r\n SIMDShiftOp,\r\n NativeType,\r\n ExpressionRef,\r\n ExpressionId,\r\n getExpressionId,\r\n getExpressionType,\r\n getConstValueI64High,\r\n getConstValueI64Low,\r\n getConstValueI32,\r\n getConstValueF32,\r\n getConstValueF64,\r\n Relooper,\r\n RelooperBlockRef\r\n} from \"./module\";\r\n\r\nimport {\r\n ElementKind,\r\n FunctionPrototype,\r\n Field,\r\n Global,\r\n DecoratorFlags,\r\n Element\r\n} from \"./program\";\r\n\r\nimport {\r\n FlowFlags,\r\n LocalFlags\r\n} from \"./flow\";\r\n\r\nimport {\r\n ReportMode\r\n} from \"./resolver\";\r\n\r\nimport {\r\n CommonFlags,\r\n Feature,\r\n TypeinfoFlags\r\n} from \"./common\";\r\n\r\nimport {\r\n writeI8,\r\n writeI16,\r\n writeI32,\r\n writeF32,\r\n writeF64,\r\n isPowerOf2\r\n} from \"./util\";\r\n\r\n/** Symbols of various compiler built-ins. */\r\nexport namespace BuiltinSymbols {\r\n // std/builtins.ts\r\n export const isInteger = \"~lib/builtins/isInteger\";\r\n export const isFloat = \"~lib/builtins/isFloat\";\r\n export const isBoolean = \"~lib/builtins/isBoolean\";\r\n export const isSigned = \"~lib/builtins/isSigned\";\r\n export const isReference = \"~lib/builtins/isReference\";\r\n export const isString = \"~lib/builtins/isString\";\r\n export const isArray = \"~lib/builtins/isArray\";\r\n export const isArrayLike = \"~lib/builtins/isArrayLike\";\r\n export const isFunction = \"~lib/builtins/isFunction\";\r\n export const isNullable = \"~lib/builtins/isNullable\";\r\n export const isDefined = \"~lib/builtins/isDefined\";\r\n export const isConstant = \"~lib/builtins/isConstant\";\r\n export const isManaged = \"~lib/builtins/isManaged\";\r\n\r\n export const clz = \"~lib/builtins/clz\";\r\n export const ctz = \"~lib/builtins/ctz\";\r\n export const popcnt = \"~lib/builtins/popcnt\";\r\n export const rotl = \"~lib/builtins/rotl\";\r\n export const rotr = \"~lib/builtins/rotr\";\r\n export const abs = \"~lib/builtins/abs\";\r\n export const max = \"~lib/builtins/max\";\r\n export const min = \"~lib/builtins/min\";\r\n export const ceil = \"~lib/builtins/ceil\";\r\n export const floor = \"~lib/builtins/floor\";\r\n export const copysign = \"~lib/builtins/copysign\";\r\n export const nearest = \"~lib/builtins/nearest\";\r\n export const reinterpret = \"~lib/builtins/reinterpret\";\r\n export const sqrt = \"~lib/builtins/sqrt\";\r\n export const trunc = \"~lib/builtins/trunc\";\r\n export const load = \"~lib/builtins/load\";\r\n export const store = \"~lib/builtins/store\";\r\n export const atomic_load = \"~lib/builtins/atomic.load\";\r\n export const atomic_store = \"~lib/builtins/atomic.store\";\r\n export const atomic_add = \"~lib/builtins/atomic.add\";\r\n export const atomic_sub = \"~lib/builtins/atomic.sub\";\r\n export const atomic_and = \"~lib/builtins/atomic.and\";\r\n export const atomic_or = \"~lib/builtins/atomic.or\";\r\n export const atomic_xor = \"~lib/builtins/atomic.xor\";\r\n export const atomic_xchg = \"~lib/builtins/atomic.xchg\";\r\n export const atomic_cmpxchg = \"~lib/builtins/atomic.cmpxchg\";\r\n export const atomic_wait = \"~lib/builtins/atomic.wait\";\r\n export const atomic_notify = \"~lib/builtins/atomic.notify\";\r\n\r\n export const sizeof = \"~lib/builtins/sizeof\";\r\n export const alignof = \"~lib/builtins/alignof\";\r\n export const offsetof = \"~lib/builtins/offsetof\";\r\n export const select = \"~lib/builtins/select\";\r\n export const unreachable = \"~lib/builtins/unreachable\";\r\n export const changetype = \"~lib/builtins/changetype\";\r\n export const assert = \"~lib/builtins/assert\";\r\n export const unchecked = \"~lib/builtins/unchecked\";\r\n export const call_direct = \"~lib/builtins/call_direct\";\r\n export const call_indirect = \"~lib/builtins/call_indirect\";\r\n export const instantiate = \"~lib/builtins/instantiate\";\r\n export const idof = \"~lib/builtins/idof\";\r\n\r\n export const i8 = \"~lib/builtins/i8\";\r\n export const i16 = \"~lib/builtins/i16\";\r\n export const i32 = \"~lib/builtins/i32\";\r\n export const i64 = \"~lib/builtins/i64\";\r\n export const isize = \"~lib/builtins/isize\";\r\n export const u8 = \"~lib/builtins/u8\";\r\n export const u16 = \"~lib/builtins/u16\";\r\n export const u32 = \"~lib/builtins/u32\";\r\n export const u64 = \"~lib/builtins/u64\";\r\n export const usize = \"~lib/builtins/usize\";\r\n export const bool = \"~lib/builtins/bool\";\r\n export const f32 = \"~lib/builtins/f32\";\r\n export const f64 = \"~lib/builtins/f64\";\r\n export const v128 = \"~lib/builtins/v128\";\r\n export const void_ = \"~lib/builtins/void\";\r\n\r\n export const i32_clz = \"~lib/builtins/i32.clz\";\r\n export const i64_clz = \"~lib/builtins/i64.clz\";\r\n export const i32_ctz = \"~lib/builtins/i32.ctz\";\r\n export const i64_ctz = \"~lib/builtins/i64.ctz\";\r\n export const i32_popcnt = \"~lib/builtins/i32.popcnt\";\r\n export const i64_popcnt = \"~lib/builtins/i64.popcnt\";\r\n export const i32_rotl = \"~lib/builtins/i32.rotl\";\r\n export const i64_rotl = \"~lib/builtins/i64.rotl\";\r\n export const i32_rotr = \"~lib/builtins/i32.rotr\";\r\n export const i64_rotr = \"~lib/builtins/i64.rotr\";\r\n\r\n export const f32_abs = \"~lib/builtins/f32.abs\";\r\n export const f64_abs = \"~lib/builtins/f64.abs\";\r\n export const f32_max = \"~lib/builtins/f32.max\";\r\n export const f64_max = \"~lib/builtins/f64.max\";\r\n export const f32_min = \"~lib/builtins/f32.min\";\r\n export const f64_min = \"~lib/builtins/f64.min\";\r\n export const f32_ceil = \"~lib/builtins/f32.ceil\";\r\n export const f64_ceil = \"~lib/builtins/f64.ceil\";\r\n export const f32_floor = \"~lib/builtins/f32.floor\";\r\n export const f64_floor = \"~lib/builtins/f64.floor\";\r\n export const f32_copysign = \"~lib/builtins/f32.copysign\";\r\n export const f64_copysign = \"~lib/builtins/f64.copysign\";\r\n export const f32_nearest = \"~lib/builtins/f32.nearest\";\r\n export const f64_nearest = \"~lib/builtins/f64.nearest\";\r\n export const i32_reinterpret_f32 = \"~lib/builtins/i32.reinterpret_f32\";\r\n export const i64_reinterpret_f64 = \"~lib/builtins/i64.reinterpret_f64\";\r\n export const f32_reinterpret_i32 = \"~lib/builtins/f32.reinterpret_i32\";\r\n export const f64_reinterpret_i64 = \"~lib/builtins/f64.reinterpret_i64\";\r\n export const f32_sqrt = \"~lib/builtins/f32.sqrt\";\r\n export const f64_sqrt = \"~lib/builtins/f64.sqrt\";\r\n export const f32_trunc = \"~lib/builtins/f32.trunc\";\r\n export const f64_trunc = \"~lib/builtins/f64.trunc\";\r\n\r\n export const i32_load8_s = \"~lib/builtins/i32.load8_s\";\r\n export const i32_load8_u = \"~lib/builtins/i32.load8_u\";\r\n export const i32_load16_s = \"~lib/builtins/i32.load16_s\";\r\n export const i32_load16_u = \"~lib/builtins/i32.load16_u\";\r\n export const i32_load = \"~lib/builtins/i32.load\";\r\n export const i64_load8_s = \"~lib/builtins/i64.load8_s\";\r\n export const i64_load8_u = \"~lib/builtins/i64.load8_u\";\r\n export const i64_load16_s = \"~lib/builtins/i64.load16_s\";\r\n export const i64_load16_u = \"~lib/builtins/i64.load16_u\";\r\n export const i64_load32_s = \"~lib/builtins/i64.load32_s\";\r\n export const i64_load32_u = \"~lib/builtins/i64.load32_u\";\r\n export const i64_load = \"~lib/builtins/i64.load\";\r\n export const f32_load = \"~lib/builtins/f32.load\";\r\n export const f64_load = \"~lib/builtins/f64.load\";\r\n export const i32_store8 = \"~lib/builtins/i32.store8\";\r\n export const i32_store16 = \"~lib/builtins/i32.store16\";\r\n export const i32_store = \"~lib/builtins/i32.store\";\r\n export const i64_store8 = \"~lib/builtins/i64.store8\";\r\n export const i64_store16 = \"~lib/builtins/i64.store16\";\r\n export const i64_store32 = \"~lib/builtins/i64.store32\";\r\n export const i64_store = \"~lib/builtins/i64.store\";\r\n export const f32_store = \"~lib/builtins/f32.store\";\r\n export const f64_store = \"~lib/builtins/f64.store\";\r\n\r\n export const i32_atomic_load8_u = \"~lib/builtins/i32.atomic.load8_u\";\r\n export const i32_atomic_load16_u = \"~lib/builtins/i32.atomic.load16_u\";\r\n export const i32_atomic_load = \"~lib/builtins/i32.atomic.load\";\r\n export const i64_atomic_load8_u = \"~lib/builtins/i64.atomic.load8_u\";\r\n export const i64_atomic_load16_u = \"~lib/builtins/i64.atomic.load16_u\";\r\n export const i64_atomic_load32_u = \"~lib/builtins/i64.atomic.load32_u\";\r\n export const i64_atomic_load = \"~lib/builtins/i64.atomic.load\";\r\n export const i32_atomic_store8 = \"~lib/builtins/i32.atomic.store8\";\r\n export const i32_atomic_store16 = \"~lib/builtins/i32.atomic.store16\";\r\n export const i32_atomic_store = \"~lib/builtins/i32.atomic.store\";\r\n export const i64_atomic_store8 = \"~lib/builtins/i64.atomic.store8\";\r\n export const i64_atomic_store16 = \"~lib/builtins/i64.atomic.store16\";\r\n export const i64_atomic_store32 = \"~lib/builtins/i64.atomic.store32\";\r\n export const i64_atomic_store = \"~lib/builtins/i64.atomic.store\";\r\n export const i32_atomic_rmw8_add_u = \"~lib/builtins/i32.atomic.rmw8.add_u\";\r\n export const i32_atomic_rmw16_add_u = \"~lib/builtins/i32.atomic.rmw16.add_u\";\r\n export const i32_atomic_rmw_add = \"~lib/builtins/i32.atomic.rmw.add\";\r\n export const i64_atomic_rmw8_add_u = \"~lib/builtins/i64.atomic.rmw8.add_u\";\r\n export const i64_atomic_rmw16_add_u = \"~lib/builtins/i64.atomic.rmw16.add_u\";\r\n export const i64_atomic_rmw32_add_u = \"~lib/builtins/i64.atomic.rmw32.add_u\";\r\n export const i64_atomic_rmw_add = \"~lib/builtins/i64.atomic.rmw.add\";\r\n export const i32_atomic_rmw8_sub_u = \"~lib/builtins/i32.atomic.rmw8.sub_u\";\r\n export const i32_atomic_rmw16_sub_u = \"~lib/builtins/i32.atomic.rmw16.sub_u\";\r\n export const i32_atomic_rmw_sub = \"~lib/builtins/i32.atomic.rmw.sub\";\r\n export const i64_atomic_rmw8_sub_u = \"~lib/builtins/i64.atomic.rmw8.sub_u\";\r\n export const i64_atomic_rmw16_sub_u = \"~lib/builtins/i64.atomic.rmw16.sub_u\";\r\n export const i64_atomic_rmw32_sub_u = \"~lib/builtins/i64.atomic.rmw32.sub_u\";\r\n export const i64_atomic_rmw_sub = \"~lib/builtins/i64.atomic.rmw.sub\";\r\n export const i32_atomic_rmw8_and_u = \"~lib/builtins/i32.atomic.rmw8.and_u\";\r\n export const i32_atomic_rmw16_and_u = \"~lib/builtins/i32.atomic.rmw16.and_u\";\r\n export const i32_atomic_rmw_and = \"~lib/builtins/i32.atomic.rmw.and\";\r\n export const i64_atomic_rmw8_and_u = \"~lib/builtins/i64.atomic.rmw8.and_u\";\r\n export const i64_atomic_rmw16_and_u = \"~lib/builtins/i64.atomic.rmw16.and_u\";\r\n export const i64_atomic_rmw32_and_u = \"~lib/builtins/i64.atomic.rmw32.and_u\";\r\n export const i64_atomic_rmw_and = \"~lib/builtins/i64.atomic.rmw.and\";\r\n export const i32_atomic_rmw8_or_u = \"~lib/builtins/i32.atomic.rmw8.or_u\";\r\n export const i32_atomic_rmw16_or_u = \"~lib/builtins/i32.atomic.rmw16.or_u\";\r\n export const i32_atomic_rmw_or = \"~lib/builtins/i32.atomic.rmw.or\";\r\n export const i64_atomic_rmw8_or_u = \"~lib/builtins/i64.atomic.rmw8.or_u\";\r\n export const i64_atomic_rmw16_or_u = \"~lib/builtins/i64.atomic.rmw16.or_u\";\r\n export const i64_atomic_rmw32_or_u = \"~lib/builtins/i64.atomic.rmw32.or_u\";\r\n export const i64_atomic_rmw_or = \"~lib/builtins/i64.atomic.rmw.or\";\r\n export const i32_atomic_rmw8_u_xor = \"~lib/builtins/i32.atomic.rmw8.xor_u\";\r\n export const i32_atomic_rmw16_u_xor = \"~lib/builtins/i32.atomic.rmw16.xor_u\";\r\n export const i32_atomic_rmw_xor = \"~lib/builtins/i32.atomic.rmw.xor\";\r\n export const i64_atomic_rmw8_xor_u = \"~lib/builtins/i64.atomic.rmw8.xor_u\";\r\n export const i64_atomic_rmw16_xor_u = \"~lib/builtins/i64.atomic.rmw16.xor_u\";\r\n export const i64_atomic_rmw32_xor_u = \"~lib/builtins/i64.atomic.rmw32.xor_u\";\r\n export const i64_atomic_rmw_xor = \"~lib/builtins/i64.atomic.rmw.xor\";\r\n export const i32_atomic_rmw8_xchg_u = \"~lib/builtins/i32.atomic.rmw8.xchg_u\";\r\n export const i32_atomic_rmw16_xchg_u = \"~lib/builtins/i32.atomic.rmw16.xchg_u\";\r\n export const i32_atomic_rmw_xchg = \"~lib/builtins/i32.atomic.rmw.xchg\";\r\n export const i64_atomic_rmw8_xchg_u = \"~lib/builtins/i64.atomic.rmw8.xchg_u\";\r\n export const i64_atomic_rmw16_xchg_u = \"~lib/builtins/i64.atomic.rmw16.xchg_u\";\r\n export const i64_atomic_rmw32_xchg_u = \"~lib/builtins/i64.atomic.rmw32.xchg_u\";\r\n export const i64_atomic_rmw_xchg = \"~lib/builtins/i64.atomic.rmw.xchg\";\r\n export const i32_atomic_rmw8_cmpxchg_u = \"~lib/builtins/i32.atomic.rmw8.cmpxchg_u\";\r\n export const i32_atomic_rmw16_cmpxchg_u = \"~lib/builtins/i32.atomic.rmw16.cmpxchg_u\";\r\n export const i32_atomic_rmw_cmpxchg = \"~lib/builtins/i32.atomic.rmw.cmpxchg\";\r\n export const i64_atomic_rmw8_cmpxchg_u = \"~lib/builtins/i64.atomic.rmw8.cmpxchg_u\";\r\n export const i64_atomic_rmw16_cmpxchg_u = \"~lib/builtins/i64.atomic.rmw16.cmpxchg_u\";\r\n export const i64_atomic_rmw32_cmpxchg_u = \"~lib/builtins/i64.atomic.rmw32.cmpxchg_u\";\r\n export const i64_atomic_rmw_cmpxchg = \"~lib/builtins/i64.atomic.rmw.cmpxchg\";\r\n export const i32_wait = \"~lib/builtins/i32.wait\";\r\n export const i64_wait = \"~lib/builtins/i64.wait\";\r\n\r\n export const v128_splat = \"~lib/builtins/v128.splat\";\r\n export const v128_extract_lane = \"~lib/builtins/v128.extract_lane\";\r\n export const v128_replace_lane = \"~lib/builtins/v128.replace_lane\";\r\n export const v128_shuffle = \"~lib/builtins/v128.shuffle\";\r\n export const v128_load = \"~lib/builtins/v128.load\";\r\n export const v128_store = \"~lib/builtins/v128.store\";\r\n export const v128_add = \"~lib/builtins/v128.add\";\r\n export const v128_sub = \"~lib/builtins/v128.sub\";\r\n export const v128_mul = \"~lib/builtins/v128.mul\";\r\n export const v128_div = \"~lib/builtins/v128.div\";\r\n export const v128_neg = \"~lib/builtins/v128.neg\";\r\n export const v128_add_saturate = \"~lib/builtins/v128.add_saturate\";\r\n export const v128_sub_saturate = \"~lib/builtins/v128.sub_saturate\";\r\n export const v128_shl = \"~lib/builtins/v128.shl\";\r\n export const v128_shr = \"~lib/builtins/v128.shr\";\r\n export const v128_and = \"~lib/builtins/v128.and\";\r\n export const v128_or = \"~lib/builtins/v128.or\";\r\n export const v128_xor = \"~lib/builtins/v128.xor\";\r\n export const v128_not = \"~lib/builtins/v128.not\";\r\n export const v128_bitselect = \"~lib/builtins/v128.bitselect\";\r\n export const v128_any_true = \"~lib/builtins/v128.any_true\";\r\n export const v128_all_true = \"~lib/builtins/v128.all_true\";\r\n export const v128_min = \"~lib/builtins/v128.min\";\r\n export const v128_max = \"~lib/builtins/v128.max\";\r\n export const v128_abs = \"~lib/builtins/v128.abs\";\r\n export const v128_sqrt = \"~lib/builtins/v128.sqrt\";\r\n export const v128_eq = \"~lib/builtins/v128.eq\";\r\n export const v128_ne = \"~lib/builtins/v128.ne\";\r\n export const v128_lt = \"~lib/builtins/v128.lt\";\r\n export const v128_le = \"~lib/builtins/v128.le\";\r\n export const v128_gt = \"~lib/builtins/v128.gt\";\r\n export const v128_ge = \"~lib/builtins/v128.ge\";\r\n export const v128_convert = \"~lib/builtins/v128.convert\";\r\n export const v128_trunc = \"~lib/builtins/v128.trunc\";\r\n\r\n export const i8x16 = \"~lib/builtins/i8x16\";\r\n export const i16x8 = \"~lib/builtins/i16x8\";\r\n export const i32x4 = \"~lib/builtins/i32x4\";\r\n export const i64x2 = \"~lib/builtins/i64x2\";\r\n export const f32x4 = \"~lib/builtins/f32x4\";\r\n export const f64x2 = \"~lib/builtins/f64x2\";\r\n\r\n export const i8x16_splat = \"~lib/builtins/i8x16.splat\";\r\n export const i8x16_extract_lane_s = \"~lib/builtins/i8x16.extract_lane_s\";\r\n export const i8x16_extract_lane_u = \"~lib/builtins/i8x16.extract_lane_u\";\r\n export const i8x16_replace_lane = \"~lib/builtins/i8x16.replace_lane\";\r\n export const i8x16_add = \"~lib/builtins/i8x16.add\";\r\n export const i8x16_sub = \"~lib/builtins/i8x16.sub\";\r\n export const i8x16_mul = \"~lib/builtins/i8x16.mul\";\r\n export const i8x16_neg = \"~lib/builtins/i8x16.neg\";\r\n export const i8x16_add_saturate_s = \"~lib/builtins/i8x16.add_saturate_s\";\r\n export const i8x16_add_saturate_u = \"~lib/builtins/i8x16.add_saturate_u\";\r\n export const i8x16_sub_saturate_s = \"~lib/builtins/i8x16.sub_saturate_s\";\r\n export const i8x16_sub_saturate_u = \"~lib/builtins/i8x16.sub_saturate_u\";\r\n export const i8x16_shl = \"~lib/builtins/i8x16.shl\";\r\n export const i8x16_shr_s = \"~lib/builtins/i8x16.shr_s\";\r\n export const i8x16_shr_u = \"~lib/builtins/i8x16.shr_u\";\r\n export const i8x16_any_true = \"~lib/builtins/i8x16.any_true\";\r\n export const i8x16_all_true = \"~lib/builtins/i8x16.all_true\";\r\n export const i8x16_eq = \"~lib/builtins/i8x16.eq\";\r\n export const i8x16_ne = \"~lib/builtins/i8x16.ne\";\r\n export const i8x16_lt_s = \"~lib/builtins/i8x16.lt_s\";\r\n export const i8x16_lt_u = \"~lib/builtins/i8x16.lt_u\";\r\n export const i8x16_le_s = \"~lib/builtins/i8x16.le_s\";\r\n export const i8x16_le_u = \"~lib/builtins/i8x16.le_u\";\r\n export const i8x16_gt_s = \"~lib/builtins/i8x16.gt_s\";\r\n export const i8x16_gt_u = \"~lib/builtins/i8x16.gt_u\";\r\n export const i8x16_ge_s = \"~lib/builtins/i8x16.ge_s\";\r\n export const i8x16_ge_u = \"~lib/builtins/i8x16.ge_u\";\r\n\r\n export const i16x8_splat = \"~lib/builtins/i16x8.splat\";\r\n export const i16x8_extract_lane_s = \"~lib/builtins/i16x8.extract_lane_s\";\r\n export const i16x8_extract_lane_u = \"~lib/builtins/i16x8.extract_lane_u\";\r\n export const i16x8_replace_lane = \"~lib/builtins/i16x8.replace_lane\";\r\n export const i16x8_add = \"~lib/builtins/i16x8.add\";\r\n export const i16x8_sub = \"~lib/builtins/i16x8.sub\";\r\n export const i16x8_mul = \"~lib/builtins/i16x8.mul\";\r\n export const i16x8_neg = \"~lib/builtins/i16x8.neg\";\r\n export const i16x8_add_saturate_s = \"~lib/builtins/i16x8.add_saturate_s\";\r\n export const i16x8_add_saturate_u = \"~lib/builtins/i16x8.add_saturate_u\";\r\n export const i16x8_sub_saturate_s = \"~lib/builtins/i16x8.sub_saturate_s\";\r\n export const i16x8_sub_saturate_u = \"~lib/builtins/i16x8.sub_saturate_u\";\r\n export const i16x8_shl = \"~lib/builtins/i16x8.shl\";\r\n export const i16x8_shr_s = \"~lib/builtins/i16x8.shr_s\";\r\n export const i16x8_shr_u = \"~lib/builtins/i16x8.shr_u\";\r\n export const i16x8_any_true = \"~lib/builtins/i16x8.any_true\";\r\n export const i16x8_all_true = \"~lib/builtins/i16x8.all_true\";\r\n export const i16x8_eq = \"~lib/builtins/i16x8.eq\";\r\n export const i16x8_ne = \"~lib/builtins/i16x8.ne\";\r\n export const i16x8_lt_s = \"~lib/builtins/i16x8.lt_s\";\r\n export const i16x8_lt_u = \"~lib/builtins/i16x8.lt_u\";\r\n export const i16x8_le_s = \"~lib/builtins/i16x8.le_s\";\r\n export const i16x8_le_u = \"~lib/builtins/i16x8.le_u\";\r\n export const i16x8_gt_s = \"~lib/builtins/i16x8.gt_s\";\r\n export const i16x8_gt_u = \"~lib/builtins/i16x8.gt_u\";\r\n export const i16x8_ge_s = \"~lib/builtins/i16x8.ge_s\";\r\n export const i16x8_ge_u = \"~lib/builtins/i16x8.ge_u\";\r\n\r\n export const i32x4_splat = \"~lib/builtins/i32x4.splat\";\r\n export const i32x4_extract_lane = \"~lib/builtins/i32x4.extract_lane\";\r\n export const i32x4_replace_lane = \"~lib/builtins/i32x4.replace_lane\";\r\n export const i32x4_add = \"~lib/builtins/i32x4.add\";\r\n export const i32x4_sub = \"~lib/builtins/i32x4.sub\";\r\n export const i32x4_mul = \"~lib/builtins/i32x4.mul\";\r\n export const i32x4_neg = \"~lib/builtins/i32x4.neg\";\r\n export const i32x4_shl = \"~lib/builtins/i32x4.shl\";\r\n export const i32x4_shr_s = \"~lib/builtins/i32x4.shr_s\";\r\n export const i32x4_shr_u = \"~lib/builtins/i32x4.shr_u\";\r\n export const i32x4_any_true = \"~lib/builtins/i32x4.any_true\";\r\n export const i32x4_all_true = \"~lib/builtins/i32x4.all_true\";\r\n export const i32x4_eq = \"~lib/builtins/i32x4.eq\";\r\n export const i32x4_ne = \"~lib/builtins/i32x4.ne\";\r\n export const i32x4_lt_s = \"~lib/builtins/i32x4.lt_s\";\r\n export const i32x4_lt_u = \"~lib/builtins/i32x4.lt_u\";\r\n export const i32x4_le_s = \"~lib/builtins/i32x4.le_s\";\r\n export const i32x4_le_u = \"~lib/builtins/i32x4.le_u\";\r\n export const i32x4_gt_s = \"~lib/builtins/i32x4.gt_s\";\r\n export const i32x4_gt_u = \"~lib/builtins/i32x4.gt_u\";\r\n export const i32x4_ge_s = \"~lib/builtins/i32x4.ge_s\";\r\n export const i32x4_ge_u = \"~lib/builtins/i32x4.ge_u\";\r\n export const i32x4_trunc_s_f32x4_sat = \"~lib/builtins/i32x4.trunc_s_f32x4_sat\";\r\n export const i32x4_trunc_u_f32x4_sat = \"~lib/builtins/i32x4.trunc_u_f32x4_sat\";\r\n\r\n export const i64x2_splat = \"~lib/builtins/i64x2.splat\";\r\n export const i64x2_extract_lane = \"~lib/builtins/i64x2.extract_lane\";\r\n export const i64x2_replace_lane = \"~lib/builtins/i64x2.replace_lane\";\r\n export const i64x2_add = \"~lib/builtins/i64x2.add\";\r\n export const i64x2_sub = \"~lib/builtins/i64x2.sub\"; // i64x2 has no .mul\r\n export const i64x2_neg = \"~lib/builtins/i64x2.neg\";\r\n export const i64x2_shl = \"~lib/builtins/i64x2.shl\";\r\n export const i64x2_shr_s = \"~lib/builtins/i64x2.shr_s\";\r\n export const i64x2_shr_u = \"~lib/builtins/i64x2.shr_u\";\r\n export const i64x2_any_true = \"~lib/builtins/i64x2.any_true\";\r\n export const i64x2_all_true = \"~lib/builtins/i64x2.all_true\"; // i64x2 has no .eq etc.\r\n export const i64x2_trunc_s_f64x2_sat = \"~lib/builtins/i64x2.trunc_s_f64x2_sat\";\r\n export const i64x2_trunc_u_f64x2_sat = \"~lib/builtins/i64x2.trunc_u_f64x2_sat\";\r\n\r\n export const f32x4_splat = \"~lib/builtins/f32x4.splat\";\r\n export const f32x4_extract_lane = \"~lib/builtins/f32x4.extract_lane\";\r\n export const f32x4_replace_lane = \"~lib/builtins/f32x4.replace_lane\";\r\n export const f32x4_add = \"~lib/builtins/f32x4.add\";\r\n export const f32x4_sub = \"~lib/builtins/f32x4.sub\";\r\n export const f32x4_mul = \"~lib/builtins/f32x4.mul\";\r\n export const f32x4_div = \"~lib/builtins/f32x4.div\";\r\n export const f32x4_neg = \"~lib/builtins/f32x4.neg\";\r\n export const f32x4_min = \"~lib/builtins/f32x4.min\";\r\n export const f32x4_max = \"~lib/builtins/f32x4.max\";\r\n export const f32x4_abs = \"~lib/builtins/f32x4.abs\";\r\n export const f32x4_sqrt = \"~lib/builtins/f32x4.sqrt\";\r\n export const f32x4_eq = \"~lib/builtins/f32x4.eq\";\r\n export const f32x4_ne = \"~lib/builtins/f32x4.ne\";\r\n export const f32x4_lt = \"~lib/builtins/f32x4.lt\";\r\n export const f32x4_le = \"~lib/builtins/f32x4.le\";\r\n export const f32x4_gt = \"~lib/builtins/f32x4.gt\";\r\n export const f32x4_ge = \"~lib/builtins/f32x4.ge\";\r\n export const f32x4_convert_s_i32x4 = \"~lib/builtins/f32x4.convert_s_i32x4\";\r\n export const f32x4_convert_u_i32x4 = \"~lib/builtins/f32x4.convert_u_i32x4\";\r\n\r\n export const f64x2_splat = \"~lib/builtins/f64x2.splat\";\r\n export const f64x2_extract_lane = \"~lib/builtins/f64x2.extract_lane\";\r\n export const f64x2_replace_lane = \"~lib/builtins/f64x2.replace_lane\";\r\n export const f64x2_add = \"~lib/builtins/f64x2.add\";\r\n export const f64x2_sub = \"~lib/builtins/f64x2.sub\";\r\n export const f64x2_mul = \"~lib/builtins/f64x2.mul\";\r\n export const f64x2_div = \"~lib/builtins/f64x2.div\";\r\n export const f64x2_neg = \"~lib/builtins/f64x2.neg\";\r\n export const f64x2_min = \"~lib/builtins/f64x2.min\";\r\n export const f64x2_max = \"~lib/builtins/f64x2.max\";\r\n export const f64x2_abs = \"~lib/builtins/f64x2.abs\";\r\n export const f64x2_sqrt = \"~lib/builtins/f64x2.sqrt\";\r\n export const f64x2_eq = \"~lib/builtins/f64x2.eq\";\r\n export const f64x2_ne = \"~lib/builtins/f64x2.ne\";\r\n export const f64x2_lt = \"~lib/builtins/f64x2.lt\";\r\n export const f64x2_le = \"~lib/builtins/f64x2.le\";\r\n export const f64x2_gt = \"~lib/builtins/f64x2.gt\";\r\n export const f64x2_ge = \"~lib/builtins/f64x2.ge\";\r\n export const f64x2_convert_s_i64x2 = \"~lib/builtins/f64x2.convert_s_i64x2\";\r\n export const f64x2_convert_u_i64x2 = \"~lib/builtins/f64x2.convert_u_i64x2\";\r\n\r\n export const v8x16_shuffle = \"~lib/builtins/v8x16.shuffle\";\r\n\r\n // internals\r\n export const heap_base = \"~lib/heap/__heap_base\";\r\n export const rtti_base = \"~lib/rt/__rtti_base\";\r\n export const visit_globals = \"~lib/rt/__visit_globals\";\r\n export const visit_members = \"~lib/rt/__visit_members\";\r\n\r\n // std/diagnostics.ts\r\n export const ERROR = \"~lib/diagnostics/ERROR\";\r\n export const WARNING = \"~lib/diagnostics/WARNING\";\r\n export const INFO = \"~lib/diagnostics/INFO\";\r\n\r\n // std/memory.ts\r\n export const memory_size = \"~lib/memory/memory.size\";\r\n export const memory_grow = \"~lib/memory/memory.grow\";\r\n export const memory_copy = \"~lib/memory/memory.copy\";\r\n export const memory_fill = \"~lib/memory/memory.fill\";\r\n export const memory_allocate = \"~lib/memory/memory.allocate\";\r\n export const memory_free = \"~lib/memory/memory.free\";\r\n export const memory_reset = \"~lib/memory/memory.reset\";\r\n\r\n // std/runtime.ts\r\n export const runtime_instanceof = \"~lib/runtime/runtime.instanceof\";\r\n export const runtime_flags = \"~lib/runtime/runtime.flags\";\r\n export const runtime_allocate = \"~lib/util/runtime/allocate\";\r\n export const runtime_reallocate = \"~lib/util/runtime/reallocate\";\r\n export const runtime_register = \"~lib/util/runtime/register\";\r\n export const runtime_discard = \"~lib/util/runtime/discard\";\r\n export const runtime_makeArray = \"~lib/util/runtime/makeArray\";\r\n\r\n // std/typedarray.ts\r\n export const Int8Array = \"~lib/typedarray/Int8Array\";\r\n export const Uint8Array = \"~lib/typedarray/Uint8Array\";\r\n export const Int16Array = \"~lib/typedarray/Int16Array\";\r\n export const Uint16Array = \"~lib/typedarray/Uint16Array\";\r\n export const Int32Array = \"~lib/typedarray/Int32Array\";\r\n export const Uint32Array = \"~lib/typedarray/Uint32Array\";\r\n export const Int64Array = \"~lib/typedarray/Int64Array\";\r\n export const Uint64Array = \"~lib/typedarray/Uint64Array\";\r\n export const Uint8ClampedArray = \"~lib/typedarray/Uint8ClampedArray\";\r\n export const Float32Array = \"~lib/typedarray/Float32Array\";\r\n export const Float64Array = \"~lib/typedarray/Float64Array\";\r\n\r\n // compiler generated\r\n export const started = \"~lib/started\";\r\n export const argc = \"~lib/argc\";\r\n export const setargc = \"~lib/setargc\";\r\n export const capabilities = \"~lib/capabilities\";\r\n}\r\n\r\n/** Compiles a call to a built-in function. */\r\nexport function compileCall(\r\n /* Compiler reference. */\r\n compiler: Compiler,\r\n /** Respective function prototype. */\r\n prototype: FunctionPrototype,\r\n /** Pre-resolved type arguments. */\r\n typeArguments: Type[] | null,\r\n /** Operand expressions. */\r\n operands: Expression[],\r\n /** Contextual type. */\r\n contextualType: Type,\r\n /** Respective call expression. */\r\n reportNode: CallExpression,\r\n /** Indicates that contextual type is ASM type. */\r\n isAsm: bool = false\r\n): ExpressionRef {\r\n var module = compiler.module;\r\n\r\n // NOTE that some implementations below make use of the select expression where straight-forward.\r\n // whether worth or not should probably be tested once it's known if/how embedders handle it.\r\n // search: createSelect\r\n\r\n // NOTE that consolidation of individual instructions into a single case isn't exactly scientific\r\n // below, but rather done to make this file easier to work with. If there was a general rule it'd\r\n // most likely be \"three or more instructions that only differ in their actual opcode\".\r\n\r\n var directize = false;\r\n\r\n switch (prototype.internalName) {\r\n\r\n // === Static type evaluation =================================================================\r\n\r\n case BuiltinSymbols.isInteger: { // isInteger() / isInteger(value: T) -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n return type.is(TypeFlags.INTEGER) && !type.is(TypeFlags.REFERENCE)\r\n ? module.i32(1)\r\n : module.i32(0);\r\n }\r\n case BuiltinSymbols.isFloat: { // isFloat() / isFloat(value: T) -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n return type.is(TypeFlags.FLOAT)\r\n ? module.i32(1)\r\n : module.i32(0);\r\n }\r\n case BuiltinSymbols.isBoolean: { // isBoolean() / isBoolean(value: T) -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n return type == Type.bool\r\n ? module.i32(1)\r\n : module.i32(0);\r\n }\r\n case BuiltinSymbols.isSigned: { // isSigned() / isSigned(value: T) -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n return type.is(TypeFlags.SIGNED)\r\n ? module.i32(1)\r\n : module.i32(0);\r\n }\r\n case BuiltinSymbols.isReference: { // isReference() / isReference(value: T) -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n return type.is(TypeFlags.REFERENCE)\r\n ? module.i32(1)\r\n : module.i32(0);\r\n }\r\n case BuiltinSymbols.isString: { // isString() / isString(value: T) -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n let classType = type.classReference;\r\n if (classType) {\r\n let stringInstance = compiler.program.stringInstance;\r\n if (stringInstance && classType.isAssignableTo(stringInstance)) return module.i32(1);\r\n }\r\n return module.i32(0);\r\n }\r\n case BuiltinSymbols.isArray: { // isArray() / isArray(value: T) -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n let classReference = type.classReference;\r\n if (!classReference) return module.i32(0);\r\n let classPrototype = classReference.prototype;\r\n return module.i32(classPrototype.extends(compiler.program.arrayPrototype) ? 1 : 0);\r\n }\r\n case BuiltinSymbols.isArrayLike: { // isArrayLike() / isArrayLike(value: T) -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n let classReference = type.classReference;\r\n if (!classReference) return module.i32(0);\r\n return module.i32(classReference.isArrayLike ? 1 : 0);\r\n }\r\n case BuiltinSymbols.isFunction: { // isFunction / isFunction(value: T) -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n return module.i32(type.signatureReference ? 1 : 0);\r\n }\r\n case BuiltinSymbols.isNullable: { // isNullable / isNullable(value: T) -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n return module.i32(type.is(TypeFlags.NULLABLE) ? 1 : 0);\r\n }\r\n case BuiltinSymbols.isDefined: { // isDefined(expression) -> bool\r\n compiler.currentType = Type.bool;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let element = compiler.resolver.resolveExpression(\r\n operands[0],\r\n compiler.currentFlow,\r\n Type.void,\r\n ReportMode.SWALLOW\r\n );\r\n return module.i32(element ? 1 : 0);\r\n }\r\n case BuiltinSymbols.isConstant: { // isConstant(expression) -> bool\r\n compiler.currentType = Type.bool;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let expr = compiler.compileExpression(operands[0], Type.auto);\r\n compiler.currentType = Type.bool;\r\n return module.i32(getExpressionId(expr) == ExpressionId.Const ? 1 : 0);\r\n }\r\n case BuiltinSymbols.isManaged: { // isManaged() -> bool\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.bool;\r\n if (!type) return module.unreachable();\r\n return module.i32(type.isManaged ? 1 : 0);\r\n }\r\n case BuiltinSymbols.sizeof: { // sizeof() -> usize\r\n compiler.currentType = compiler.options.usizeType;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsRequired(operands, 0, reportNode, compiler)\r\n ) return module.unreachable();\r\n let byteSize = (typeArguments)[0].byteSize;\r\n let expr: ExpressionRef;\r\n if (compiler.options.isWasm64) {\r\n // implicitly wrap if contextual type is a 32-bit integer\r\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size <= 32) {\r\n compiler.currentType = Type.u32;\r\n expr = module.i32(byteSize);\r\n } else {\r\n expr = module.i64(byteSize, 0);\r\n }\r\n } else {\r\n // implicitly extend if contextual type is a 64-bit integer\r\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size == 64) {\r\n compiler.currentType = Type.u64;\r\n expr = module.i64(byteSize, 0);\r\n } else {\r\n expr = module.i32(byteSize);\r\n }\r\n }\r\n return expr;\r\n }\r\n case BuiltinSymbols.alignof: { // alignof() -> usize\r\n compiler.currentType = compiler.options.usizeType;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsRequired(operands, 0, reportNode, compiler)\r\n ) return module.unreachable();\r\n let byteSize = (typeArguments)[0].byteSize;\r\n assert(isPowerOf2(byteSize));\r\n let alignLog2 = ctz(byteSize);\r\n let expr: ExpressionRef;\r\n if (compiler.options.isWasm64) {\r\n // implicitly wrap if contextual type is a 32-bit integer\r\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size <= 32) {\r\n compiler.currentType = Type.u32;\r\n expr = module.i32(alignLog2);\r\n } else {\r\n expr = module.i64(alignLog2, 0);\r\n }\r\n } else {\r\n // implicitly extend if contextual type is a 64-bit integer\r\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size == 64) {\r\n compiler.currentType = Type.u64;\r\n expr = module.i64(alignLog2, 0);\r\n } else {\r\n expr = module.i32(alignLog2);\r\n }\r\n }\r\n return expr;\r\n }\r\n case BuiltinSymbols.offsetof: { // offsetof(fieldName?: string) -> usize\r\n compiler.currentType = compiler.options.usizeType;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsOptional(operands, 0, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let classType = typeArguments![0].classReference;\r\n if (!classType) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let offset: i32;\r\n if (operands.length) {\r\n if (\r\n operands[0].kind != NodeKind.LITERAL ||\r\n (operands[0]).literalKind != LiteralKind.STRING\r\n ) {\r\n compiler.error(\r\n DiagnosticCode.String_literal_expected,\r\n operands[0].range\r\n );\r\n return module.unreachable();\r\n }\r\n let fieldName = (operands[0]).value;\r\n let field = classType.members ? classType.members.get(fieldName) : null;\r\n if (!(field && field.kind == ElementKind.FIELD)) {\r\n compiler.error(\r\n DiagnosticCode.Type_0_has_no_property_1,\r\n operands[0].range, classType.internalName, fieldName\r\n );\r\n return module.unreachable();\r\n }\r\n offset = (field).memoryOffset;\r\n } else {\r\n offset = classType.currentMemoryOffset;\r\n }\r\n if (compiler.options.isWasm64) {\r\n // implicitly wrap if contextual type is a 32-bit integer\r\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size <= 32) {\r\n compiler.currentType = Type.u32;\r\n return module.i32(offset);\r\n } else {\r\n return module.i64(offset);\r\n }\r\n } else {\r\n // implicitly extend if contextual type is a 64-bit integer\r\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size == 64) {\r\n compiler.currentType = Type.u64;\r\n return module.i64(offset);\r\n } else {\r\n return module.i32(offset);\r\n }\r\n }\r\n }\r\n\r\n // === Math ===================================================================================\r\n\r\n case BuiltinSymbols.clz: // any_bitcount(value: T) -> T\r\n case BuiltinSymbols.ctz:\r\n case BuiltinSymbols.popcnt: {\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\r\n : compiler.compileExpression(operands[0], Type.i32, Constraints.MUST_WRAP);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let op: UnaryOp = -1;\r\n switch (prototype.internalName) {\r\n case BuiltinSymbols.clz: {\r\n switch (type.kind) {\r\n case TypeKind.BOOL:\r\n case TypeKind.I8:\r\n case TypeKind.U8:\r\n case TypeKind.I16:\r\n case TypeKind.U16:\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = UnaryOp.ClzI32; break; }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n op = compiler.options.isWasm64\r\n ? UnaryOp.ClzI64\r\n : UnaryOp.ClzI32;\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = UnaryOp.ClzI64; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.ctz: {\r\n switch (type.kind) {\r\n case TypeKind.BOOL:\r\n case TypeKind.I8:\r\n case TypeKind.U8:\r\n case TypeKind.I16:\r\n case TypeKind.U16:\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = UnaryOp.CtzI32; break; }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n op = compiler.options.isWasm64\r\n ? UnaryOp.CtzI64\r\n : UnaryOp.CtzI32;\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = UnaryOp.CtzI64; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.popcnt: {\r\n switch (compiler.currentType.kind) {\r\n case TypeKind.BOOL:\r\n case TypeKind.I8:\r\n case TypeKind.U8:\r\n case TypeKind.I16:\r\n case TypeKind.U16:\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = UnaryOp.PopcntI32; break; }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n op = compiler.options.isWasm64\r\n ? UnaryOp.PopcntI64\r\n : UnaryOp.PopcntI32;\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = UnaryOp.PopcntI64; break; }\r\n }\r\n break;\r\n }\r\n }\r\n if (op == -1) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n return module.unary(op, arg0);\r\n }\r\n case BuiltinSymbols.rotl: { // rotl(value: T, shift: T) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\r\n : compiler.compileExpression(operands[0], Type.i32, Constraints.MUST_WRAP);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT);\r\n let expr: ExpressionRef;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL: {\r\n expr = compiler.ensureSmallIntegerWrap(\r\n module.binary(BinaryOp.RotlI32, arg0, arg1),\r\n type\r\n );\r\n // fall-through\r\n }\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.RotlI32, arg0, arg1);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n compiler.options.isWasm64\r\n ? BinaryOp.RotlI64\r\n : BinaryOp.RotlI32,\r\n arg0, arg1\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.RotlI64, arg0, arg1);\r\n break;\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n }\r\n return expr; // possibly overflows\r\n }\r\n case BuiltinSymbols.rotr: { // rotr(value: T, shift: T) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\r\n : compiler.compileExpression(operands[0], Type.i32, Constraints.MUST_WRAP);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT);\r\n let expr: ExpressionRef;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.BOOL: {\r\n expr = compiler.ensureSmallIntegerWrap(\r\n module.binary(BinaryOp.RotrI32, arg0, arg1),\r\n type\r\n );\r\n break;\r\n }\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n expr = module.binary(BinaryOp.RotrI32, arg0, arg1);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.ISIZE: {\r\n expr = module.binary(\r\n compiler.options.isWasm64\r\n ? BinaryOp.RotrI64\r\n : BinaryOp.RotrI32,\r\n arg0, arg1\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.binary(BinaryOp.RotrI64, arg0, arg1);\r\n break;\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n }\r\n return expr; // possibly overflowws\r\n }\r\n case BuiltinSymbols.abs: { // abs(value: T) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\r\n : compiler.compileExpression(operands[0], Type.f64, Constraints.MUST_WRAP);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let expr: ExpressionRef;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32: {\r\n let flow = compiler.currentFlow;\r\n\r\n // possibly overflows, e.g. abs(-128) == 128\r\n let tempLocal1 = flow.getTempLocal(Type.i32);\r\n let tempLocalIndex2 = flow.getAndFreeTempLocal(Type.i32).index;\r\n let tempLocalIndex1 = tempLocal1.index;\r\n\r\n // (x + (x >> 31)) ^ (x >> 31)\r\n expr = module.binary(BinaryOp.XorI32,\r\n module.binary(BinaryOp.AddI32,\r\n module.local_tee(\r\n tempLocalIndex2,\r\n module.binary(BinaryOp.ShrI32,\r\n module.local_tee(tempLocalIndex1, arg0),\r\n module.i32(31)\r\n )\r\n ),\r\n module.local_get(tempLocalIndex1, NativeType.I32)\r\n ),\r\n module.local_get(tempLocalIndex2, NativeType.I32)\r\n );\r\n\r\n flow.freeTempLocal(tempLocal1);\r\n break;\r\n }\r\n case TypeKind.ISIZE: {\r\n let options = compiler.options;\r\n let flow = compiler.currentFlow;\r\n let wasm64 = options.isWasm64;\r\n\r\n let tempLocal1 = flow.getTempLocal(options.usizeType);\r\n let tempLocalIndex2 = flow.getAndFreeTempLocal(options.usizeType).index;\r\n let tempLocalIndex1 = tempLocal1.index;\r\n\r\n expr = module.binary(wasm64 ? BinaryOp.XorI64 : BinaryOp.XorI32,\r\n module.binary(wasm64 ? BinaryOp.AddI64 : BinaryOp.AddI32,\r\n module.local_tee(\r\n tempLocalIndex2,\r\n module.binary(wasm64 ? BinaryOp.ShrI64 : BinaryOp.ShrI32,\r\n module.local_tee(tempLocalIndex1, arg0),\r\n wasm64 ? module.i64(63) : module.i32(31)\r\n )\r\n ),\r\n module.local_get(tempLocalIndex1, options.nativeSizeType)\r\n ),\r\n module.local_get(tempLocalIndex2, options.nativeSizeType)\r\n );\r\n\r\n flow.freeTempLocal(tempLocal1);\r\n break;\r\n }\r\n case TypeKind.I64: {\r\n let flow = compiler.currentFlow;\r\n\r\n let tempLocal1 = flow.getTempLocal(Type.i64);\r\n let tempLocalIndex2 = flow.getAndFreeTempLocal(Type.i64).index;\r\n let tempLocalIndex1 = tempLocal1.index;\r\n\r\n // (x + (x >> 63)) ^ (x >> 63)\r\n expr = module.binary(BinaryOp.XorI64,\r\n module.binary(BinaryOp.AddI64,\r\n module.local_tee(\r\n tempLocalIndex2,\r\n module.binary(BinaryOp.ShrI64,\r\n module.local_tee(tempLocalIndex1, arg0),\r\n module.i64(63)\r\n )\r\n ),\r\n module.local_get(tempLocalIndex1, NativeType.I64)\r\n ),\r\n module.local_get(tempLocalIndex2, NativeType.I64)\r\n );\r\n\r\n flow.freeTempLocal(tempLocal1);\r\n break;\r\n }\r\n case TypeKind.USIZE:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.U64:\r\n case TypeKind.BOOL: {\r\n expr = arg0;\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.unary(UnaryOp.AbsF32, arg0);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.unary(UnaryOp.AbsF64, arg0);\r\n break;\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n }\r\n return expr;\r\n }\r\n case BuiltinSymbols.max: { // max(left: T, right: T) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\r\n : compiler.compileExpression(operands[0], Type.f64, Constraints.MUST_WRAP);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP);\r\n let op: BinaryOp;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32: { op = BinaryOp.GtI32; break; }\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: { op = BinaryOp.GtU32; break; }\r\n case TypeKind.I64: { op = BinaryOp.GtI64; break; }\r\n case TypeKind.U64: { op = BinaryOp.GtU64; break; }\r\n case TypeKind.ISIZE: {\r\n op = compiler.options.isWasm64\r\n ? BinaryOp.GtI64\r\n : BinaryOp.GtI32;\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? BinaryOp.GtU64\r\n : BinaryOp.GtU32;\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n return module.binary(BinaryOp.MaxF32, arg0, arg1);\r\n }\r\n case TypeKind.F64: {\r\n return module.binary(BinaryOp.MaxF64, arg0, arg1);\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n let flow = compiler.currentFlow;\r\n let nativeType = type.toNativeType();\r\n let tempLocal0 = flow.getTempLocal(type);\r\n flow.setLocalFlag(tempLocal0.index, LocalFlags.WRAPPED);\r\n let tempLocal1 = flow.getAndFreeTempLocal(type);\r\n flow.setLocalFlag(tempLocal1.index, LocalFlags.WRAPPED);\r\n flow.freeTempLocal(tempLocal0);\r\n return module.select(\r\n module.local_tee(tempLocal0.index, arg0),\r\n module.local_tee(tempLocal1.index, arg1),\r\n module.binary(op,\r\n module.local_get(tempLocal0.index, nativeType),\r\n module.local_get(tempLocal1.index, nativeType)\r\n )\r\n );\r\n }\r\n case BuiltinSymbols.min: { // min(left: T, right: T) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\r\n : compiler.compileExpression(operands[0], Type.f64, Constraints.MUST_WRAP);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP);\r\n let op: BinaryOp;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32: { op = BinaryOp.LtI32; break; }\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: { op = BinaryOp.LtU32; break; }\r\n case TypeKind.I64: { op = BinaryOp.LtI64; break; }\r\n case TypeKind.U64: { op = BinaryOp.LtU64; break; }\r\n case TypeKind.ISIZE: {\r\n op = compiler.options.isWasm64\r\n ? BinaryOp.LtI64\r\n : BinaryOp.LtI32;\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? BinaryOp.LtU64\r\n : BinaryOp.LtU32;\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n return module.binary(BinaryOp.MinF32, arg0, arg1);\r\n }\r\n case TypeKind.F64: {\r\n return module.binary(BinaryOp.MinF64, arg0, arg1);\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n let flow = compiler.currentFlow;\r\n let nativeType = type.toNativeType();\r\n let tempLocal0 = flow.getTempLocal(type);\r\n flow.setLocalFlag(tempLocal0.index, LocalFlags.WRAPPED);\r\n let tempLocal1 = flow.getAndFreeTempLocal(type);\r\n flow.setLocalFlag(tempLocal1.index, LocalFlags.WRAPPED);\r\n flow.freeTempLocal(tempLocal0);\r\n return module.select(\r\n module.local_tee(tempLocal0.index, arg0),\r\n module.local_tee(tempLocal1.index, arg1),\r\n module.binary(op,\r\n module.local_get(tempLocal0.index, nativeType),\r\n module.local_get(tempLocal1.index, nativeType)\r\n )\r\n );\r\n }\r\n case BuiltinSymbols.ceil: // any_rounding(value: T) -> T\r\n case BuiltinSymbols.floor: {\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\r\n : compiler.compileExpression(operands[0], Type.f64, Constraints.NONE);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let op: UnaryOp;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.I64:\r\n case TypeKind.ISIZE:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.U64:\r\n case TypeKind.USIZE:\r\n case TypeKind.BOOL: return arg0; // considered rounded\r\n case TypeKind.F32: {\r\n op = prototype.internalName == BuiltinSymbols.ceil\r\n ? UnaryOp.CeilF32\r\n : UnaryOp.FloorF32;\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n op = prototype.internalName == BuiltinSymbols.ceil\r\n ? UnaryOp.CeilF64\r\n : UnaryOp.FloorF64;\r\n break;\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n return module.unary(op, arg0);\r\n }\r\n case BuiltinSymbols.copysign: { // copysign(left: T, right: T) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\r\n : compiler.compileExpression(operands[0], Type.f64, Constraints.NONE);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT);\r\n let op: BinaryOp;\r\n switch (type.kind) {\r\n // TODO: does an integer version make sense?\r\n case TypeKind.F32: { op = BinaryOp.CopysignF32; break; }\r\n case TypeKind.F64: { op = BinaryOp.CopysignF64; break; }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n }\r\n return module.binary(op, arg0, arg1);\r\n }\r\n case BuiltinSymbols.nearest: { // nearest(value: T) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\r\n : compiler.compileExpression(operands[0], Type.f64, Constraints.NONE);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let expr: ExpressionRef;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.I64:\r\n case TypeKind.ISIZE:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.U64:\r\n case TypeKind.USIZE:\r\n case TypeKind.BOOL: {\r\n expr = arg0;\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n expr = module.unary(UnaryOp.NearestF32, arg0);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.unary(UnaryOp.NearestF64, arg0);\r\n break;\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n }\r\n return expr;\r\n }\r\n case BuiltinSymbols.reinterpret: { // reinterpret(value: *) -> T\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let type = typeArguments![0];\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.currentType = type;\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let expr: ExpressionRef;\r\n switch (type.kind) {\r\n case TypeKind.I32:\r\n case TypeKind.U32: {\r\n let arg0 = compiler.compileExpression(operands[0], Type.f32, Constraints.CONV_IMPLICIT);\r\n expr = module.unary(UnaryOp.ReinterpretF32, arg0);\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n let arg0 = compiler.compileExpression(operands[0], Type.f64, Constraints.CONV_IMPLICIT);\r\n expr = module.unary(UnaryOp.ReinterpretF64, arg0);\r\n break;\r\n }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n let arg0 = compiler.compileExpression(operands[0],\r\n compiler.options.isWasm64\r\n ? Type.f64\r\n : Type.f32,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n expr = module.unary(\r\n compiler.options.isWasm64\r\n ? UnaryOp.ReinterpretF64\r\n : UnaryOp.ReinterpretF32,\r\n arg0\r\n );\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n let arg0 = compiler.compileExpression(operands[0], Type.i32, Constraints.CONV_IMPLICIT);\r\n expr = module.unary(UnaryOp.ReinterpretI32, arg0);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n let arg0 = compiler.compileExpression(operands[0], Type.i64, Constraints.CONV_IMPLICIT);\r\n expr = module.unary(UnaryOp.ReinterpretI64, arg0);\r\n break;\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n }\r\n compiler.currentType = type;\r\n return expr;\r\n }\r\n case BuiltinSymbols.sqrt: { // sqrt(value: T) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\r\n : compiler.compileExpression(operands[0], Type.f64, Constraints.NONE);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.currentType = type;\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let expr: ExpressionRef;\r\n switch (type.kind) { // TODO: integer versions (that return f64 or convert)?\r\n case TypeKind.F32: {\r\n expr = module.unary(UnaryOp.SqrtF32, arg0);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.unary(UnaryOp.SqrtF64, arg0);\r\n break;\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n }\r\n return expr;\r\n }\r\n case BuiltinSymbols.trunc: { // trunc(value: T) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\r\n : compiler.compileExpression(operands[0], Type.f64, Constraints.NONE);\r\n let type = compiler.currentType;\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.range\r\n );\r\n return module.unreachable();\r\n }\r\n let expr: ExpressionRef;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.I64:\r\n case TypeKind.ISIZE:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.U64:\r\n case TypeKind.USIZE:\r\n case TypeKind.BOOL: {\r\n expr = arg0;\r\n break;\r\n }\r\n // TODO: truncate to contextual type directly (if not void etc.)?\r\n case TypeKind.F32: {\r\n expr = module.unary(UnaryOp.TruncF32, arg0);\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.unary(UnaryOp.TruncF64, arg0);\r\n break;\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n expr = module.unreachable();\r\n break;\r\n }\r\n }\r\n return expr;\r\n }\r\n\r\n // === Memory access ==========================================================================\r\n\r\n case BuiltinSymbols.load: { // load(offset: usize, immOffset?: usize, immAlign?: usize) -> T*\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\r\n checkArgsOptional(operands, 1, 3, reportNode, compiler)\r\n ) return module.unreachable();\r\n let type = typeArguments![0];\r\n let outType = (\r\n contextualType != Type.auto &&\r\n type.is(TypeFlags.INTEGER) &&\r\n contextualType.is(TypeFlags.INTEGER) &&\r\n contextualType.size > type.size\r\n ) ? contextualType : type;\r\n let arg0 = compiler.compileExpression(operands[0],\r\n compiler.options.usizeType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n let numOperands = operands.length;\r\n let immOffset = numOperands >= 2 ? evaluateImmediateOffset(operands[1], compiler) : 0; // reports\r\n if (immOffset < 0) {\r\n compiler.currentType = outType;\r\n return module.unreachable();\r\n }\r\n let immAlign: i32;\r\n let naturalAlign = type.byteSize;\r\n if (numOperands == 3) {\r\n immAlign = evaluateImmediateOffset(operands[2], compiler);\r\n if (immAlign < 0) {\r\n compiler.currentType = outType;\r\n return module.unreachable();\r\n }\r\n if (immAlign > naturalAlign) {\r\n compiler.error(\r\n DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,\r\n operands[2].range, \"Alignment\", \"0\", naturalAlign.toString()\r\n );\r\n compiler.currentType = outType;\r\n return module.unreachable();\r\n }\r\n if (!isPowerOf2(immAlign)) {\r\n compiler.error(\r\n DiagnosticCode._0_must_be_a_power_of_two,\r\n operands[2].range, \"Alignment\"\r\n );\r\n compiler.currentType = outType;\r\n return module.unreachable();\r\n }\r\n } else {\r\n immAlign = naturalAlign;\r\n }\r\n compiler.currentType = outType;\r\n return module.load(\r\n type.byteSize,\r\n type.is(TypeFlags.SIGNED | TypeFlags.INTEGER),\r\n arg0,\r\n outType.toNativeType(),\r\n immOffset,\r\n immAlign\r\n );\r\n }\r\n case BuiltinSymbols.store: { // store(offset: usize, value: T*, offset?: usize, align?: usize) -> void\r\n compiler.currentType = Type.void;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsOptional(operands, 2, 4, reportNode, compiler)\r\n ) return module.unreachable();\r\n let type = typeArguments![0];\r\n let arg0 = compiler.compileExpression(operands[0],\r\n compiler.options.usizeType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n let arg1 = isAsm\r\n ? compiler.compileExpression(operands[1],\r\n contextualType,\r\n Constraints.CONV_IMPLICIT\r\n )\r\n : compiler.compileExpression(\r\n operands[1],\r\n type,\r\n type.is(TypeFlags.INTEGER)\r\n ? Constraints.NONE // no need to convert to small int (but now might result in a float)\r\n : Constraints.CONV_IMPLICIT\r\n );\r\n let inType = compiler.currentType;\r\n if (\r\n type.is(TypeFlags.INTEGER) &&\r\n (\r\n !inType.is(TypeFlags.INTEGER) || // float to int\r\n inType.size < type.size // int to larger int (clear garbage bits)\r\n )\r\n ) {\r\n arg1 = compiler.convertExpression(arg1,\r\n inType, type,\r\n false, false, // still clears garbage bits when not wrapping\r\n operands[1]\r\n );\r\n inType = type;\r\n }\r\n let immOffset = operands.length >= 3 ? evaluateImmediateOffset(operands[2], compiler) : 0; // reports\r\n if (immOffset < 0) {\r\n compiler.currentType = Type.void;\r\n return module.unreachable();\r\n }\r\n let immAlign: i32;\r\n let naturalAlign = type.byteSize;\r\n if (operands.length == 4) {\r\n immAlign = evaluateImmediateOffset(operands[3], compiler);\r\n if (immAlign < 0) {\r\n compiler.currentType = Type.void;\r\n return module.unreachable();\r\n }\r\n if (immAlign > naturalAlign) {\r\n compiler.error(\r\n DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,\r\n operands[3].range, \"Alignment\", \"0\", naturalAlign.toString()\r\n );\r\n compiler.currentType = Type.void;\r\n return module.unreachable();\r\n }\r\n if (!isPowerOf2(immAlign)) {\r\n compiler.error(\r\n DiagnosticCode._0_must_be_a_power_of_two,\r\n operands[3].range, \"Alignment\"\r\n );\r\n compiler.currentType = Type.void;\r\n return module.unreachable();\r\n }\r\n } else {\r\n immAlign = naturalAlign;\r\n }\r\n compiler.currentType = Type.void;\r\n return module.store(type.byteSize, arg0, arg1, inType.toNativeType(), immOffset, immAlign);\r\n }\r\n\r\n // === Atomics ================================================================================\r\n\r\n case BuiltinSymbols.atomic_load: { // load(offset: usize, immOffset?: usize) -> T*\r\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\r\n checkArgsOptional(operands, 1, 2, reportNode, compiler)\r\n ) return module.unreachable();\r\n let type = typeArguments![0];\r\n let outType = (\r\n type.is(TypeFlags.INTEGER) &&\r\n contextualType.is(TypeFlags.INTEGER) &&\r\n contextualType.size > type.size\r\n ) ? contextualType : type;\r\n if (!type.is(TypeFlags.INTEGER)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = outType;\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0],\r\n compiler.options.usizeType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n let immOffset = operands.length == 2 ? evaluateImmediateOffset(operands[1], compiler) : 0; // reports\r\n if (immOffset < 0) {\r\n compiler.currentType = outType;\r\n return module.unreachable();\r\n }\r\n compiler.currentType = outType;\r\n return module.atomic_load(\r\n type.byteSize,\r\n arg0,\r\n outType.toNativeType(),\r\n immOffset\r\n );\r\n }\r\n case BuiltinSymbols.atomic_store: { // store(offset: usize, value: T*, immOffset?: usize) -> void\r\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\r\n compiler.currentType = Type.void;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsOptional(operands, 2, 3, reportNode, compiler)\r\n ) return module.unreachable();\r\n let type = typeArguments![0];\r\n if (!type.is(TypeFlags.INTEGER) || type.size < 8) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0],\r\n compiler.options.usizeType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n let arg1 = isAsm\r\n ? compiler.compileExpression(\r\n operands[1],\r\n contextualType,\r\n Constraints.CONV_IMPLICIT\r\n )\r\n : compiler.compileExpression(\r\n operands[1],\r\n type,\r\n type.is(TypeFlags.INTEGER)\r\n ? Constraints.NONE // no need to convert to small int (but now might result in a float)\r\n : Constraints.CONV_IMPLICIT\r\n );\r\n let inType = compiler.currentType;\r\n if (\r\n type.is(TypeFlags.INTEGER) &&\r\n (\r\n !inType.is(TypeFlags.INTEGER) || // float to int\r\n inType.size < type.size // int to larger int (clear garbage bits)\r\n )\r\n ) {\r\n arg1 = compiler.convertExpression(arg1,\r\n inType, type,\r\n false, false, // still clears garbage bits when not wrapping\r\n operands[1]\r\n );\r\n inType = type;\r\n }\r\n let immOffset = operands.length == 3 ? evaluateImmediateOffset(operands[2], compiler) : 0; // reports\r\n if (immOffset < 0) {\r\n compiler.currentType = Type.void;\r\n return module.unreachable();\r\n }\r\n compiler.currentType = Type.void;\r\n return module.atomic_store(type.byteSize, arg0, arg1, inType.toNativeType(), immOffset);\r\n }\r\n case BuiltinSymbols.atomic_add: // any_atomic_binary(ptr, value: T, immOffset?: usize) -> T\r\n case BuiltinSymbols.atomic_sub:\r\n case BuiltinSymbols.atomic_and:\r\n case BuiltinSymbols.atomic_or:\r\n case BuiltinSymbols.atomic_xor:\r\n case BuiltinSymbols.atomic_xchg: {\r\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\r\n checkArgsOptional(operands, 2, 3, reportNode, compiler)\r\n ) return module.unreachable();\r\n let type = typeArguments![0];\r\n if (!type.is(TypeFlags.INTEGER) || type.size < 8) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0],\r\n compiler.options.usizeType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n let arg1 = isAsm\r\n ? compiler.compileExpression(operands[1],\r\n contextualType,\r\n Constraints.CONV_IMPLICIT\r\n )\r\n : compiler.compileExpression(\r\n operands[1],\r\n type,\r\n type.is(TypeFlags.INTEGER)\r\n ? Constraints.NONE // no need to convert to small int (but now might result in a float)\r\n : Constraints.CONV_IMPLICIT\r\n );\r\n let inType = compiler.currentType;\r\n if (\r\n type.is(TypeFlags.INTEGER) &&\r\n (\r\n !inType.is(TypeFlags.INTEGER) || // float to int\r\n inType.size < type.size // int to larger int (clear garbage bits)\r\n )\r\n ) {\r\n arg1 = compiler.convertExpression(arg1,\r\n inType, type,\r\n false, false, // still clears garbage bits when not wrapping\r\n operands[1]\r\n );\r\n inType = type;\r\n }\r\n let immOffset = operands.length == 3 ? evaluateImmediateOffset(operands[2], compiler) : 0; // reports\r\n if (immOffset < 0) {\r\n compiler.currentType = inType;\r\n return module.unreachable();\r\n }\r\n let op: AtomicRMWOp;\r\n switch (prototype.internalName) {\r\n default: assert(false);\r\n case BuiltinSymbols.atomic_add: { op = AtomicRMWOp.Add; break; }\r\n case BuiltinSymbols.atomic_sub: { op = AtomicRMWOp.Sub; break; }\r\n case BuiltinSymbols.atomic_and: { op = AtomicRMWOp.And; break; }\r\n case BuiltinSymbols.atomic_or: { op = AtomicRMWOp.Or; break; }\r\n case BuiltinSymbols.atomic_xor: { op = AtomicRMWOp.Xor; break; }\r\n case BuiltinSymbols.atomic_xchg: { op = AtomicRMWOp.Xchg; break; }\r\n }\r\n compiler.currentType = inType;\r\n return module.atomic_rmw(\r\n op, type.byteSize, immOffset, arg0, arg1, inType.toNativeType()\r\n );\r\n }\r\n case BuiltinSymbols.atomic_cmpxchg: { // cmpxchg(ptr: usize, expected: T, replacement: T, off?: usize): T\r\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\r\n checkArgsOptional(operands, 3, 4, reportNode, compiler)\r\n ) return module.unreachable();\r\n let type = typeArguments![0];\r\n if (!type.is(TypeFlags.INTEGER) || type.size < 8) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0],\r\n compiler.options.usizeType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n let arg1 = isAsm\r\n ? compiler.compileExpression(operands[1],\r\n contextualType,\r\n Constraints.CONV_IMPLICIT\r\n )\r\n : compiler.compileExpression(\r\n operands[1],\r\n type,\r\n type.is(TypeFlags.INTEGER)\r\n ? Constraints.NONE // no need to convert to small int (but now might result in a float)\r\n : Constraints.CONV_IMPLICIT\r\n );\r\n let inType = compiler.currentType;\r\n let arg2 = compiler.compileExpression(operands[2],\r\n inType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n if (\r\n type.is(TypeFlags.INTEGER) &&\r\n (\r\n !inType.is(TypeFlags.INTEGER) || // float to int\r\n inType.size < type.size // int to larger int (clear garbage bits)\r\n )\r\n ) {\r\n arg1 = compiler.convertExpression(arg1,\r\n inType, type,\r\n false, false, // still clears garbage bits when not wrapping\r\n operands[1]\r\n );\r\n arg2 = compiler.convertExpression(arg2,\r\n inType, type,\r\n false, false, // still clears garbage bits when not wrapping\r\n operands[2]\r\n );\r\n inType = type;\r\n }\r\n let immOffset = operands.length == 4 ? evaluateImmediateOffset(operands[3], compiler) : 0; // reports\r\n if (immOffset < 0) {\r\n compiler.currentType = inType;\r\n return module.unreachable();\r\n }\r\n compiler.currentType = inType;\r\n return module.atomic_cmpxchg(\r\n type.byteSize, immOffset, arg0, arg1, arg2, inType.toNativeType()\r\n );\r\n }\r\n case BuiltinSymbols.atomic_wait: { // wait(ptr: usize, expected: T, timeout: i64): i32;\r\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\r\n compiler.currentType = Type.i32;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsRequired(operands, 3, reportNode, compiler)\r\n ) return module.unreachable();\r\n let type = typeArguments![0];\r\n if (!type.is(TypeFlags.INTEGER) || type.size < 32) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0],\r\n compiler.options.usizeType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n let arg1 = compiler.compileExpression(operands[1], type,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n let arg2 = compiler.compileExpression(operands[2],\r\n Type.i64,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n compiler.currentType = Type.i32;\r\n return module.atomic_wait(arg0, arg1, arg2, type.toNativeType());\r\n }\r\n case BuiltinSymbols.atomic_notify: { // notify(ptr: usize, count: i32): i32;\r\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\r\n compiler.currentType = Type.i32;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = compiler.compileExpression(operands[0],\r\n compiler.options.usizeType,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n let arg1 = compiler.compileExpression(operands[1],\r\n Type.i32,\r\n Constraints.CONV_IMPLICIT\r\n );\r\n compiler.currentType = Type.i32;\r\n return module.atomic_notify(arg0, arg1);\r\n }\r\n\r\n // === Control flow ===========================================================================\r\n\r\n case BuiltinSymbols.select: { // select(ifTrue: T, ifFalse: T, condition: bool) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 3, reportNode, compiler)\r\n ) return module.unreachable();\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\r\n : compiler.compileExpression(operands[0], Type.auto);\r\n let type = compiler.currentType;\r\n if (!type.isAny(TypeFlags.VALUE | TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT);\r\n let arg2 = compiler.makeIsTrueish(\r\n compiler.compileExpression(operands[2], Type.bool),\r\n compiler.currentType // ^\r\n );\r\n compiler.currentType = type;\r\n return module.select(arg0, arg1, arg2);\r\n }\r\n case BuiltinSymbols.unreachable: { // unreachable() -> *\r\n if (typeArguments) {\r\n compiler.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n reportNode.typeArgumentsRange, prototype.internalName\r\n );\r\n }\r\n checkArgsRequired(operands, 0, reportNode, compiler);\r\n return module.unreachable();\r\n }\r\n\r\n // === Memory =================================================================================\r\n\r\n case BuiltinSymbols.memory_size: { // memory.size() -> i32\r\n compiler.currentType = Type.i32;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 0, reportNode, compiler)\r\n ) return module.unreachable();\r\n return module.host(HostOp.MemorySize);\r\n }\r\n case BuiltinSymbols.memory_grow: { // memory.grow(pages: i32) -> i32\r\n compiler.currentType = Type.i32;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n return module.host(HostOp.MemoryGrow, null, [\r\n compiler.compileExpression(operands[0], Type.i32, Constraints.CONV_IMPLICIT)\r\n ]);\r\n }\r\n case BuiltinSymbols.memory_copy: { // memory.copy(dest: usize, src: usize: n: usize) -> void\r\n compiler.currentType = Type.void;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 3, reportNode, compiler)\r\n ) return module.unreachable();\r\n if (!compiler.options.hasFeature(Feature.BULK_MEMORY)) {\r\n let instance = compiler.resolver.resolveFunction(prototype, null); // reports\r\n compiler.currentType = Type.void;\r\n if (!instance) return module.unreachable();\r\n return compiler.compileCallDirect(instance, operands, reportNode);\r\n }\r\n let usizeType = compiler.options.usizeType;\r\n let arg0 = compiler.compileExpression(operands[0], usizeType, Constraints.CONV_IMPLICIT);\r\n let arg1 = compiler.compileExpression(operands[1], usizeType, Constraints.CONV_IMPLICIT);\r\n let arg2 = compiler.compileExpression(operands[2], usizeType, Constraints.CONV_IMPLICIT);\r\n compiler.currentType = Type.void;\r\n return module.memory_copy(arg0, arg1, arg2);\r\n }\r\n case BuiltinSymbols.memory_fill: { // memory.fill(dest: usize, value: u8, n: usize) -> void\r\n compiler.currentType = Type.void;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 3, reportNode, compiler)\r\n ) return module.unreachable();\r\n if (!compiler.options.hasFeature(Feature.BULK_MEMORY)) {\r\n let instance = compiler.resolver.resolveFunction(prototype, null); // reports\r\n compiler.currentType = Type.void;\r\n if (!instance) return module.unreachable();\r\n return compiler.compileCallDirect(instance, operands, reportNode);\r\n }\r\n let usizeType = compiler.options.usizeType;\r\n let arg0 = compiler.compileExpression(operands[0], usizeType, Constraints.CONV_IMPLICIT);\r\n let arg1 = compiler.compileExpression(operands[1], Type.u8, Constraints.CONV_IMPLICIT);\r\n let arg2 = compiler.compileExpression(operands[2], usizeType, Constraints.CONV_IMPLICIT);\r\n compiler.currentType = Type.void;\r\n return module.memory_fill(arg0, arg1, arg2);\r\n }\r\n\r\n // === Helpers ================================================================================\r\n\r\n case BuiltinSymbols.changetype: { // changetype(value: *) -> T\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let toType = typeArguments![0];\r\n let arg0 = compiler.compileExpression(operands[0], toType);\r\n let fromType = compiler.currentType;\r\n compiler.currentType = toType;\r\n if (fromType.size != toType.size) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.range\r\n );\r\n return module.unreachable();\r\n }\r\n return arg0;\r\n }\r\n case BuiltinSymbols.assert: { // assert(isTrueish: T, message?: string) -> T{!= null}\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler) |\r\n checkArgsOptional(operands, 1, 2, reportNode, compiler)\r\n ) {\r\n if (typeArguments) {\r\n assert(typeArguments.length); // otherwise invalid, should not been set at all\r\n compiler.currentType = typeArguments[0].nonNullableType;\r\n }\r\n return module.unreachable();\r\n }\r\n let arg0 = typeArguments\r\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\r\n : compiler.compileExpression(operands[0], Type.bool, Constraints.MUST_WRAP);\r\n let type = compiler.currentType;\r\n compiler.currentType = type.nonNullableType;\r\n\r\n // return ifTrueish if assertions are disabled\r\n if (compiler.options.noAssert) {\r\n if (contextualType == Type.void) { // simplify if dropped anyway\r\n compiler.currentType = Type.void;\r\n return module.nop();\r\n }\r\n return arg0;\r\n }\r\n\r\n // otherwise call abort if the assertion is false-ish\r\n let abort = compileAbort(compiler, operands.length == 2 ? operands[1] : null, reportNode);\r\n compiler.currentType = type.nonNullableType;\r\n let expr: ExpressionRef;\r\n if (contextualType == Type.void) { // simplify if dropped anyway\r\n compiler.currentType = Type.void;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n expr = module.if(\r\n module.unary(UnaryOp.EqzI32, arg0),\r\n abort\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n expr = module.if(\r\n module.unary(UnaryOp.EqzI64, arg0),\r\n abort\r\n );\r\n break;\r\n }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n expr = module.if(\r\n module.unary(\r\n compiler.options.isWasm64\r\n ? UnaryOp.EqzI64\r\n : UnaryOp.EqzI32,\r\n arg0\r\n ),\r\n abort\r\n );\r\n break;\r\n }\r\n // TODO: also check for NaN in float assertions, as in `Boolean(NaN) -> false`?\r\n case TypeKind.F32: {\r\n expr = module.if(\r\n module.binary(BinaryOp.EqF32,\r\n arg0,\r\n module.f32(0)\r\n ),\r\n abort\r\n );\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n expr = module.if(\r\n module.binary(BinaryOp.EqF64,\r\n arg0,\r\n module.f64(0)\r\n ),\r\n abort\r\n );\r\n break;\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n expr = abort;\r\n break;\r\n }\r\n }\r\n } else {\r\n compiler.currentType = type.nonNullableType;\r\n switch (compiler.currentType.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.BOOL: {\r\n let flow = compiler.currentFlow;\r\n let tempLocal = flow.getAndFreeTempLocal(type);\r\n flow.setLocalFlag(tempLocal.index, LocalFlags.WRAPPED); // arg0 is wrapped\r\n expr = module.if(\r\n module.local_tee(tempLocal.index, arg0),\r\n module.local_get(tempLocal.index, NativeType.I32),\r\n abort\r\n );\r\n break;\r\n }\r\n case TypeKind.I64:\r\n case TypeKind.U64: {\r\n let tempLocal = compiler.currentFlow.getAndFreeTempLocal(Type.i64);\r\n expr = module.if(\r\n module.unary(UnaryOp.EqzI64,\r\n module.local_tee(tempLocal.index, arg0)\r\n ),\r\n abort,\r\n module.local_get(tempLocal.index, NativeType.I64)\r\n );\r\n break;\r\n }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n let tempLocal = compiler.currentFlow.getAndFreeTempLocal(compiler.options.usizeType);\r\n expr = module.if(\r\n module.unary(\r\n compiler.options.isWasm64\r\n ? UnaryOp.EqzI64\r\n : UnaryOp.EqzI32,\r\n module.local_tee(tempLocal.index, arg0)\r\n ),\r\n abort,\r\n module.local_get(tempLocal.index, compiler.options.nativeSizeType)\r\n );\r\n break;\r\n }\r\n case TypeKind.F32: {\r\n let tempLocal = compiler.currentFlow.getAndFreeTempLocal(Type.f32);\r\n expr = module.if(\r\n module.binary(BinaryOp.EqF32,\r\n module.local_tee(tempLocal.index, arg0),\r\n module.f32(0)\r\n ),\r\n abort,\r\n module.local_get(tempLocal.index, NativeType.F32)\r\n );\r\n break;\r\n }\r\n case TypeKind.F64: {\r\n let tempLocal = compiler.currentFlow.getAndFreeTempLocal(Type.f64);\r\n expr = module.if(\r\n module.binary(BinaryOp.EqF64,\r\n module.local_tee(tempLocal.index, arg0),\r\n module.f64(0)\r\n ),\r\n abort,\r\n module.local_get(tempLocal.index, NativeType.F64)\r\n );\r\n break;\r\n }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n expr = abort;\r\n break;\r\n }\r\n }\r\n }\r\n return expr;\r\n }\r\n case BuiltinSymbols.unchecked: { // unchecked(expr: *) -> *\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) return module.unreachable();\r\n let flow = compiler.currentFlow;\r\n let alreadyUnchecked = flow.is(FlowFlags.UNCHECKED_CONTEXT);\r\n flow.set(FlowFlags.UNCHECKED_CONTEXT);\r\n // eliminate unnecessary tees by preferring contextualType(=void):\r\n let expr = compiler.compileExpression(operands[0], contextualType);\r\n if (!alreadyUnchecked) flow.unset(FlowFlags.UNCHECKED_CONTEXT);\r\n return expr;\r\n }\r\n case BuiltinSymbols.call_direct: directize = true;\r\n case BuiltinSymbols.call_indirect: { // call_indirect(target: Function | u32, ...args: *[]) -> T\r\n if (\r\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\r\n checkArgsOptional(operands, 1, i32.MAX_VALUE, reportNode, compiler)\r\n ) return module.unreachable();\r\n let returnType = typeArguments ? typeArguments[0] : contextualType;\r\n let arg0 = compiler.compileExpression(operands[0], Type.u32);\r\n let arg0Type = compiler.currentType;\r\n if (!(\r\n arg0Type == Type.u32 || // either plain index\r\n arg0Type.kind == TypeKind.U32 && arg0Type.signatureReference // or function reference\r\n )) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n operands[0].range\r\n );\r\n return module.unreachable();\r\n }\r\n let numOperands = operands.length - 1;\r\n let operandExprs = new Array(numOperands);\r\n let nativeReturnType = returnType.toNativeType();\r\n let parameterTypes = new Array(numOperands);\r\n let nativeParamTypes = new Array(numOperands);\r\n for (let i = 0; i < numOperands; ++i) {\r\n operandExprs[i] = compiler.compileExpression(operands[1 + i], Type.i32);\r\n let operandType = compiler.currentType;\r\n parameterTypes[i] = operandType;\r\n nativeParamTypes[i] = operandType.toNativeType();\r\n }\r\n let typeName = Signature.makeSignatureString(parameterTypes, returnType);\r\n let typeRef = module.getFunctionTypeBySignature(nativeReturnType, nativeParamTypes);\r\n if (!typeRef) typeRef = module.addFunctionType(typeName, nativeReturnType, nativeParamTypes);\r\n compiler.currentType = returnType;\r\n if (directize) {\r\n // if the index expression is precomputable to a constant value, emit a direct call\r\n if (getExpressionId(arg0 = module.precomputeExpression(arg0)) == ExpressionId.Const) {\r\n assert(getExpressionType(arg0) == NativeType.I32);\r\n let index = getConstValueI32(arg0);\r\n let functionTable = compiler.functionTable;\r\n if (index >= 0 && index < functionTable.length) {\r\n return module.call(functionTable[index], operandExprs, nativeReturnType);\r\n }\r\n }\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n operands[0].range\r\n );\r\n return module.unreachable();\r\n }\r\n // of course this can easily result in a 'RuntimeError: function signature mismatch' trap and\r\n // thus must be used with care. it exists because it *might* be useful in specific scenarios.\r\n return module.call_indirect(arg0, operandExprs, typeName);\r\n }\r\n case BuiltinSymbols.instantiate: { // instantiate(...args: *[]) -> T\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler, true)\r\n ) return module.unreachable();\r\n let classInstance = typeArguments![0].classReference;\r\n if (!classInstance) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n compiler.currentType = classInstance.type;\r\n return compiler.compileInstantiate(classInstance, operands, Constraints.NONE, reportNode);\r\n }\r\n\r\n // === User-defined diagnostics ===============================================================\r\n\r\n case BuiltinSymbols.ERROR: {\r\n checkTypeAbsent(typeArguments, reportNode, prototype);\r\n compiler.error(\r\n DiagnosticCode.User_defined_0,\r\n reportNode.range, (operands.length ? operands[0] : reportNode).range.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n case BuiltinSymbols.WARNING: {\r\n checkTypeAbsent(typeArguments, reportNode, prototype);\r\n compiler.warning(\r\n DiagnosticCode.User_defined_0,\r\n reportNode.range, (operands.length ? operands[0] : reportNode).range.toString()\r\n );\r\n return module.nop();\r\n }\r\n case BuiltinSymbols.INFO: {\r\n checkTypeAbsent(typeArguments, reportNode, prototype);\r\n compiler.info(\r\n DiagnosticCode.User_defined_0,\r\n reportNode.range, (operands.length ? operands[0] : reportNode).range.toString()\r\n );\r\n return module.nop();\r\n }\r\n\r\n // === Portable type conversions ==============================================================\r\n\r\n case BuiltinSymbols.i8: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.i8;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.i8, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.i16: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.i16;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.i16, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.i32: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.i32;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.i32, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.i64: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.i64;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.i64, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.isize: {\r\n let isizeType = compiler.options.isizeType;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = isizeType;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], isizeType, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.u8: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.u8;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.u8, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.u16: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.u16;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.u16, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.u32: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.u32;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.u32, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.u64: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.u64;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.u64, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.usize: {\r\n let usizeType = compiler.options.usizeType;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = usizeType;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], usizeType, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.bool: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.bool;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.bool, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.f32: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.f32;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.f32, Constraints.CONV_EXPLICIT);\r\n }\r\n case BuiltinSymbols.f64: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.f64;\r\n return module.unreachable();\r\n }\r\n return compiler.compileExpression(operands[0], Type.f64, Constraints.CONV_EXPLICIT);\r\n }\r\n\r\n // === SIMD ===================================================================================\r\n\r\n case BuiltinSymbols.v128: // alias for now\r\n case BuiltinSymbols.i8x16: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 16, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let bytes = new Uint8Array(16);\r\n for (let i = 0; i < 16; ++i) {\r\n let value = operands[i];\r\n if (value) {\r\n let expr = compiler.precomputeExpression(value, Type.i8, Constraints.CONV_IMPLICIT);\r\n if (getExpressionId(expr) != ExpressionId.Const) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n value.range\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n assert(getExpressionType(expr) == NativeType.I32);\r\n writeI8(getConstValueI32(expr), bytes, i);\r\n }\r\n }\r\n compiler.currentType = Type.v128;\r\n return module.v128(bytes);\r\n }\r\n case BuiltinSymbols.i16x8: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 8, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let bytes = new Uint8Array(16);\r\n for (let i = 0; i < 8; ++i) {\r\n let value = operands[i];\r\n if (value) {\r\n let expr = compiler.precomputeExpression(value, Type.i16, Constraints.CONV_IMPLICIT);\r\n if (getExpressionId(expr) != ExpressionId.Const) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n value.range\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n assert(getExpressionType(expr) == NativeType.I32);\r\n writeI16(getConstValueI32(expr), bytes, i << 1);\r\n }\r\n }\r\n compiler.currentType = Type.v128;\r\n return module.v128(bytes);\r\n }\r\n case BuiltinSymbols.i32x4: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 4, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let bytes = new Uint8Array(16);\r\n for (let i = 0; i < 4; ++i) {\r\n let value = operands[i];\r\n if (value) {\r\n let expr = compiler.precomputeExpression(value, Type.i32, Constraints.CONV_IMPLICIT);\r\n if (getExpressionId(expr) != ExpressionId.Const) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n value.range\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n assert(getExpressionType(expr) == NativeType.I32);\r\n writeI32(getConstValueI32(expr), bytes, i << 2);\r\n }\r\n }\r\n compiler.currentType = Type.v128;\r\n return module.v128(bytes);\r\n }\r\n case BuiltinSymbols.i64x2: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let bytes = new Uint8Array(16);\r\n for (let i = 0; i < 2; ++i) {\r\n let value = operands[i];\r\n if (value) {\r\n let expr = compiler.precomputeExpression(value, Type.i64, Constraints.CONV_IMPLICIT);\r\n if (getExpressionId(expr) != ExpressionId.Const) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n value.range\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n assert(getExpressionType(expr) == NativeType.I64);\r\n let off = i << 3;\r\n writeI32(getConstValueI64Low(expr), bytes, off);\r\n writeI32(getConstValueI64High(expr), bytes, off + 4);\r\n }\r\n }\r\n compiler.currentType = Type.v128;\r\n return module.v128(bytes);\r\n }\r\n case BuiltinSymbols.f32x4: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 4, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let bytes = new Uint8Array(16);\r\n for (let i = 0; i < 4; ++i) {\r\n let value = operands[i];\r\n if (value) {\r\n let expr = compiler.precomputeExpression(value, Type.f32, Constraints.CONV_IMPLICIT);\r\n if (getExpressionId(expr) != ExpressionId.Const) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n value.range\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n assert(getExpressionType(expr) == NativeType.F32);\r\n writeF32(getConstValueF32(expr), bytes, i << 2);\r\n }\r\n }\r\n compiler.currentType = Type.v128;\r\n return module.v128(bytes);\r\n }\r\n case BuiltinSymbols.f64x2: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let bytes = new Uint8Array(16);\r\n for (let i = 0; i < 2; ++i) {\r\n let value = operands[i];\r\n if (value) {\r\n let expr = compiler.precomputeExpression(value, Type.f64, Constraints.CONV_IMPLICIT);\r\n if (getExpressionId(expr) != ExpressionId.Const) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n value.range\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n assert(getExpressionType(expr) == NativeType.F64);\r\n writeF64(getConstValueF64(expr), bytes, i << 3);\r\n }\r\n }\r\n compiler.currentType = Type.v128;\r\n return module.v128(bytes);\r\n }\r\n case BuiltinSymbols.v128_splat: { // splat(x: T) -> v128\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let type = typeArguments![0];\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let op: UnaryOp;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = UnaryOp.SplatVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = UnaryOp.SplatVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = UnaryOp.SplatVecI32x4; break; }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = UnaryOp.SplatVecI64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? UnaryOp.SplatVecI64x2\r\n : UnaryOp.SplatVecI32x4;\r\n break;\r\n }\r\n case TypeKind.F32: { op = UnaryOp.SplatVecF32x4; break; }\r\n case TypeKind.F64: { op = UnaryOp.SplatVecF64x2; break; }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], type, Constraints.CONV_IMPLICIT);\r\n compiler.currentType = Type.v128;\r\n return module.unary(op, arg0);\r\n }\r\n case BuiltinSymbols.v128_extract_lane: { // extract_lane(x: v128, idx: u8) -> T\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) return module.unreachable();\r\n let type = typeArguments![0];\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = type;\r\n return module.unreachable();\r\n }\r\n let op: SIMDExtractOp;\r\n switch (type.kind) {\r\n case TypeKind.I8: { op = SIMDExtractOp.ExtractLaneSVecI8x16; break; }\r\n case TypeKind.U8: { op = SIMDExtractOp.ExtractLaneUVecI8x16; break; }\r\n case TypeKind.I16: { op = SIMDExtractOp.ExtractLaneSVecI16x8; break; }\r\n case TypeKind.U16: { op = SIMDExtractOp.ExtractLaneUVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = SIMDExtractOp.ExtractLaneVecI32x4; break; }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = SIMDExtractOp.ExtractLaneVecI64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? SIMDExtractOp.ExtractLaneVecI64x2\r\n : SIMDExtractOp.ExtractLaneVecI32x4;\r\n break;\r\n }\r\n case TypeKind.F32: { op = SIMDExtractOp.ExtractLaneVecF32x4; break; }\r\n case TypeKind.F64: { op = SIMDExtractOp.ExtractLaneVecF64x2; break; }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = type;\r\n return module.unreachable();\r\n }\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\r\n let arg1 = compiler.precomputeExpression(operands[1], Type.u8, Constraints.CONV_IMPLICIT);\r\n compiler.currentType = type;\r\n if (getExpressionId(arg1) != ExpressionId.Const) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n operands[1].range\r\n );\r\n return module.unreachable();\r\n }\r\n assert(getExpressionType(arg1) == NativeType.I32);\r\n let maxIdx = (16 / type.byteSize) - 1;\r\n let idx = getConstValueI32(arg1);\r\n if (idx < 0 || idx > maxIdx) {\r\n compiler.error(\r\n DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,\r\n operands[1].range, \"Lane index\", \"0\", maxIdx.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n return module.simd_extract(op, arg0, idx);\r\n }\r\n case BuiltinSymbols.v128_replace_lane: { // replace_lane(x: v128, idx: u8, value: T) -> v128\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsRequired(operands, 3, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let type = typeArguments![0];\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let op: SIMDReplaceOp;\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = SIMDReplaceOp.ReplaceLaneVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = SIMDReplaceOp.ReplaceLaneVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = SIMDReplaceOp.ReplaceLaneVecI32x4; break; }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = SIMDReplaceOp.ReplaceLaneVecI64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? SIMDReplaceOp.ReplaceLaneVecI64x2\r\n : SIMDReplaceOp.ReplaceLaneVecI32x4;\r\n break;\r\n }\r\n case TypeKind.F32: { op = SIMDReplaceOp.ReplaceLaneVecF32x4; break; }\r\n case TypeKind.F64: { op = SIMDReplaceOp.ReplaceLaneVecF64x2; break; }\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\r\n let arg1 = compiler.precomputeExpression(operands[1], Type.u8, Constraints.CONV_IMPLICIT);\r\n if (getExpressionId(arg1) != ExpressionId.Const) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n operands[1].range\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n assert(getExpressionType(arg1) == NativeType.I32);\r\n let maxIdx = (16 / type.byteSize) - 1;\r\n let idx = getConstValueI32(arg1);\r\n if (idx < 0 || idx > maxIdx) {\r\n compiler.error(\r\n DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,\r\n operands[1].range, \"Lane index\", \"0\", maxIdx.toString()\r\n );\r\n return module.unreachable();\r\n }\r\n let arg2 = compiler.compileExpression(operands[2], type, Constraints.CONV_IMPLICIT);\r\n compiler.currentType = Type.v128;\r\n return module.simd_replace(op, arg0, idx, arg2);\r\n }\r\n case BuiltinSymbols.v128_shuffle: { // shuffle(a: v128, b: v128, ...lanes: u8[]) -> v128\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let type = typeArguments![0];\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let laneWidth = type.byteSize;\r\n let laneCount = 16 / laneWidth;\r\n assert(isInteger(laneCount) && isPowerOf2(laneCount));\r\n if (\r\n checkArgsRequired(operands, 2 + laneCount, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.I16:\r\n case TypeKind.I32:\r\n case TypeKind.I64:\r\n case TypeKind.ISIZE:\r\n case TypeKind.U8:\r\n case TypeKind.U16:\r\n case TypeKind.U32:\r\n case TypeKind.U64:\r\n case TypeKind.USIZE:\r\n case TypeKind.F32:\r\n case TypeKind.F64: break;\r\n default: {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\r\n let arg1 = compiler.compileExpression(operands[1], Type.v128, Constraints.CONV_IMPLICIT);\r\n let mask = new Uint8Array(16);\r\n let maxIdx = (laneCount << 1) - 1;\r\n for (let i = 0; i < laneCount; ++i) {\r\n let operand = operands[2 + i];\r\n let argN = compiler.precomputeExpression(operand, Type.u8, Constraints.CONV_IMPLICIT);\r\n if (getExpressionId(argN) != ExpressionId.Const) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n operand.range\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n assert(getExpressionType(argN) == NativeType.I32);\r\n let idx = getConstValueI32(argN);\r\n if (idx < 0 || idx > maxIdx) {\r\n compiler.error(\r\n DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,\r\n operand.range, \"Lane index\", \"0\", maxIdx.toString()\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n switch (laneWidth) {\r\n case 1: {\r\n writeI8(idx, mask, i);\r\n break;\r\n }\r\n case 2: {\r\n let off8 = i << 1;\r\n let idx8 = idx << 1;\r\n writeI8(idx8 , mask, off8);\r\n writeI8(idx8 + 1, mask, off8 + 1);\r\n break;\r\n }\r\n case 4: {\r\n let off8 = i << 2;\r\n let idx8 = idx << 2;\r\n writeI8(idx8 , mask, off8);\r\n writeI8(idx8 + 1, mask, off8 + 1);\r\n writeI8(idx8 + 2, mask, off8 + 2);\r\n writeI8(idx8 + 3, mask, off8 + 3);\r\n break;\r\n }\r\n case 8: {\r\n let off8 = i << 3;\r\n let idx8 = idx << 3;\r\n writeI8(idx8 , mask, off8);\r\n writeI8(idx8 + 1, mask, off8 + 1);\r\n writeI8(idx8 + 2, mask, off8 + 2);\r\n writeI8(idx8 + 3, mask, off8 + 3);\r\n writeI8(idx8 + 4, mask, off8 + 4);\r\n writeI8(idx8 + 5, mask, off8 + 5);\r\n writeI8(idx8 + 6, mask, off8 + 6);\r\n writeI8(idx8 + 7, mask, off8 + 7);\r\n break;\r\n }\r\n default: assert(false);\r\n }\r\n }\r\n compiler.currentType = Type.v128;\r\n return module.simd_shuffle(arg0, arg1, mask);\r\n }\r\n case BuiltinSymbols.v128_add: // any_binary(a: v128, b: v128) -> v128\r\n case BuiltinSymbols.v128_sub:\r\n case BuiltinSymbols.v128_mul:\r\n case BuiltinSymbols.v128_div:\r\n case BuiltinSymbols.v128_add_saturate:\r\n case BuiltinSymbols.v128_sub_saturate:\r\n case BuiltinSymbols.v128_min:\r\n case BuiltinSymbols.v128_max:\r\n case BuiltinSymbols.v128_eq:\r\n case BuiltinSymbols.v128_ne:\r\n case BuiltinSymbols.v128_lt:\r\n case BuiltinSymbols.v128_le:\r\n case BuiltinSymbols.v128_gt:\r\n case BuiltinSymbols.v128_ge: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let type = typeArguments![0];\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let op: BinaryOp = -1;\r\n switch (prototype.internalName) {\r\n case BuiltinSymbols.v128_add: {\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = BinaryOp.AddVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = BinaryOp.AddVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = BinaryOp.AddVecI32x4; break; }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = BinaryOp.AddVecI64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? BinaryOp.AddVecI64x2\r\n : BinaryOp.AddVecI32x4;\r\n break;\r\n }\r\n case TypeKind.F32: { op = BinaryOp.AddVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.AddVecF64x2; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_sub: {\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = BinaryOp.SubVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = BinaryOp.SubVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = BinaryOp.SubVecI32x4; break; }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = BinaryOp.SubVecI64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? BinaryOp.SubVecI64x2\r\n : BinaryOp.SubVecI32x4;\r\n break;\r\n }\r\n case TypeKind.F32: { op = BinaryOp.SubVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.SubVecF64x2; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_mul: {\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = BinaryOp.MulVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = BinaryOp.MulVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = BinaryOp.MulVecI32x4; break; }\r\n case TypeKind.F32: { op = BinaryOp.MulVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.MulVecF64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n if (!compiler.options.isWasm64) op = BinaryOp.MulVecI32x4;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_div: {\r\n switch (type.kind) {\r\n case TypeKind.F32: { op = BinaryOp.DivVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.DivVecF64x2; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_add_saturate: {\r\n switch (type.kind) {\r\n case TypeKind.I8: { op = BinaryOp.AddSatSVecI8x16; break; }\r\n case TypeKind.U8: { op = BinaryOp.AddSatUVecI8x16; break; }\r\n case TypeKind.I16: { op = BinaryOp.AddSatSVecI16x8; break; }\r\n case TypeKind.U16: { op = BinaryOp.AddSatUVecI16x8; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_sub_saturate: {\r\n switch (type.kind) {\r\n case TypeKind.I8: { op = BinaryOp.SubSatSVecI8x16; break; }\r\n case TypeKind.U8: { op = BinaryOp.SubSatUVecI8x16; break; }\r\n case TypeKind.I16: { op = BinaryOp.SubSatSVecI16x8; break; }\r\n case TypeKind.U16: { op = BinaryOp.SubSatUVecI16x8; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_min: {\r\n switch (type.kind) {\r\n case TypeKind.F32: { op = BinaryOp.MinVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.MinVecF64x2; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_max: {\r\n switch (type.kind) {\r\n case TypeKind.F32: { op = BinaryOp.MaxVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.MaxVecF64x2; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_eq: {\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = BinaryOp.EqVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = BinaryOp.EqVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = BinaryOp.EqVecI32x4; break; }\r\n case TypeKind.F32: { op = BinaryOp.EqVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.EqVecF64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n if (!compiler.options.isWasm64) op = BinaryOp.EqVecI32x4;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_ne: {\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = BinaryOp.NeVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = BinaryOp.NeVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = BinaryOp.NeVecI32x4; break; }\r\n case TypeKind.F32: { op = BinaryOp.NeVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.NeVecF64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n if (!compiler.options.isWasm64) op = BinaryOp.NeVecI32x4;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_lt: {\r\n switch (type.kind) {\r\n case TypeKind.I8: { op = BinaryOp.LtSVecI8x16; break; }\r\n case TypeKind.U8: { op = BinaryOp.LtUVecI8x16; break; }\r\n case TypeKind.I16: { op = BinaryOp.LtSVecI16x8; break; }\r\n case TypeKind.U16: { op = BinaryOp.LtUVecI16x8; break; }\r\n case TypeKind.I32: { op = BinaryOp.LtSVecI32x4; break; }\r\n case TypeKind.U32: { op = BinaryOp.LtUVecI32x4; break; }\r\n case TypeKind.F32: { op = BinaryOp.LtVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.LtVecF64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n if (!compiler.options.isWasm64) {\r\n op = type.kind == TypeKind.ISIZE\r\n ? BinaryOp.LtSVecI32x4\r\n : BinaryOp.LtUVecI32x4;\r\n }\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_le: {\r\n switch (type.kind) {\r\n case TypeKind.I8: { op = BinaryOp.LeSVecI8x16; break; }\r\n case TypeKind.U8: { op = BinaryOp.LeUVecI8x16; break; }\r\n case TypeKind.I16: { op = BinaryOp.LeSVecI16x8; break; }\r\n case TypeKind.U16: { op = BinaryOp.LeUVecI16x8; break; }\r\n case TypeKind.I32: { op = BinaryOp.LeSVecI32x4; break; }\r\n case TypeKind.U32: { op = BinaryOp.LeUVecI32x4; break; }\r\n case TypeKind.F32: { op = BinaryOp.LeVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.LeVecF64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n if (!compiler.options.isWasm64) {\r\n op = type.kind == TypeKind.ISIZE\r\n ? BinaryOp.LeSVecI32x4\r\n : BinaryOp.LeUVecI32x4;\r\n }\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_gt: {\r\n switch (type.kind) {\r\n case TypeKind.I8: { op = BinaryOp.GtSVecI8x16; break; }\r\n case TypeKind.U8: { op = BinaryOp.GtUVecI8x16; break; }\r\n case TypeKind.I16: { op = BinaryOp.GtSVecI16x8; break; }\r\n case TypeKind.U16: { op = BinaryOp.GtUVecI16x8; break; }\r\n case TypeKind.I32: { op = BinaryOp.GtSVecI32x4; break; }\r\n case TypeKind.U32: { op = BinaryOp.GtUVecI32x4; break; }\r\n case TypeKind.F32: { op = BinaryOp.GtVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.GtVecF64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n if (!compiler.options.isWasm64) {\r\n op = type.kind == TypeKind.ISIZE\r\n ? BinaryOp.GtSVecI32x4\r\n : BinaryOp.GtUVecI32x4;\r\n }\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_ge: {\r\n switch (type.kind) {\r\n case TypeKind.I8: { op = BinaryOp.GeSVecI8x16; break; }\r\n case TypeKind.U8: { op = BinaryOp.GeUVecI8x16; break; }\r\n case TypeKind.I16: { op = BinaryOp.GeSVecI16x8; break; }\r\n case TypeKind.U16: { op = BinaryOp.GeUVecI16x8; break; }\r\n case TypeKind.I32: { op = BinaryOp.GeSVecI32x4; break; }\r\n case TypeKind.U32: { op = BinaryOp.GeUVecI32x4; break; }\r\n case TypeKind.F32: { op = BinaryOp.GeVecF32x4; break; }\r\n case TypeKind.F64: { op = BinaryOp.GeVecF64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n if (!compiler.options.isWasm64) {\r\n op = type.kind == TypeKind.ISIZE\r\n ? BinaryOp.GeSVecI32x4\r\n : BinaryOp.GeUVecI32x4;\r\n }\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n if (op == -1) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\r\n let arg1 = compiler.compileExpression(operands[1], Type.v128, Constraints.CONV_IMPLICIT);\r\n compiler.currentType = Type.v128;\r\n return module.binary(op, arg0, arg1);\r\n }\r\n case BuiltinSymbols.v128_neg: // any_unary(a: v128) -> v128\r\n case BuiltinSymbols.v128_abs:\r\n case BuiltinSymbols.v128_sqrt:\r\n case BuiltinSymbols.v128_convert:\r\n case BuiltinSymbols.v128_trunc: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let type = typeArguments![0];\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.range\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let op: UnaryOp = -1;\r\n switch (prototype.internalName) {\r\n case BuiltinSymbols.v128_neg: {\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = UnaryOp.NegVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = UnaryOp.NegVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = UnaryOp.NegVecI32x4; break; }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = UnaryOp.NegVecI64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? UnaryOp.NegVecI64x2\r\n : UnaryOp.NegVecI32x4;\r\n break;\r\n }\r\n case TypeKind.F32: { op = UnaryOp.NegVecF32x4; break; }\r\n case TypeKind.F64: { op = UnaryOp.NegVecF64x2; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_abs: {\r\n switch (type.kind) {\r\n case TypeKind.F32: { op = UnaryOp.AbsVecF32x4; break; }\r\n case TypeKind.F64: { op = UnaryOp.AbsVecF64x2; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_sqrt: {\r\n switch (type.kind) {\r\n case TypeKind.F32: { op = UnaryOp.SqrtVecF32x4; break; }\r\n case TypeKind.F64: { op = UnaryOp.SqrtVecF64x2; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_convert: {\r\n switch (type.kind) {\r\n case TypeKind.I32: { op = UnaryOp.ConvertSVecI32x4ToVecF32x4; break; }\r\n case TypeKind.U32: { op = UnaryOp.ConvertUVecI32x4ToVecF32x4; break; }\r\n case TypeKind.I64: { op = UnaryOp.ConvertSVecI64x2ToVecF64x2; break; }\r\n case TypeKind.U64: { op = UnaryOp.ConvertUVecI64x2ToVecF64x2; break; }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_trunc: {\r\n switch (type.kind) {\r\n case TypeKind.I32: { op = UnaryOp.TruncSatSVecF32x4ToVecI32x4; break; }\r\n case TypeKind.U32: { op = UnaryOp.TruncSatUVecF32x4ToVecI32x4; break; }\r\n case TypeKind.I64: { op = UnaryOp.TruncSatSVecF64x2ToVecI64x2; break; }\r\n case TypeKind.U64: { op = UnaryOp.TruncSatUVecF64x2ToVecI64x2; break; }\r\n }\r\n break;\r\n }\r\n }\r\n if (op == -1) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\r\n compiler.currentType = Type.v128;\r\n return module.unary(op, arg0);\r\n }\r\n case BuiltinSymbols.v128_shl: // any_shift(a: v128, b: i32) -> v128\r\n case BuiltinSymbols.v128_shr: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let type = typeArguments![0];\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let op: SIMDShiftOp = -1;\r\n switch (prototype.internalName) {\r\n case BuiltinSymbols.v128_shl: {\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = SIMDShiftOp.ShlVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = SIMDShiftOp.ShlVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = SIMDShiftOp.ShlVecI32x4; break; }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = SIMDShiftOp.ShlVecI64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? SIMDShiftOp.ShlVecI64x2\r\n : SIMDShiftOp.ShlVecI32x4;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_shr: {\r\n switch (type.kind) {\r\n case TypeKind.I8: { op = SIMDShiftOp.ShrSVecI8x16; break; }\r\n case TypeKind.U8: { op = SIMDShiftOp.ShrUVecI8x16; break; }\r\n case TypeKind.I16: { op = SIMDShiftOp.ShrSVecI16x8; break; }\r\n case TypeKind.U16: { op = SIMDShiftOp.ShrUVecI16x8; break; }\r\n case TypeKind.I32: { op = SIMDShiftOp.ShrSVecI32x4; break; }\r\n case TypeKind.U32: { op = SIMDShiftOp.ShrUVecI32x4; break; }\r\n case TypeKind.I64: { op = SIMDShiftOp.ShrSVecI64x2; break; }\r\n case TypeKind.U64: { op = SIMDShiftOp.ShrUVecI64x2; break; }\r\n case TypeKind.ISIZE: {\r\n op = compiler.options.isWasm64\r\n ? SIMDShiftOp.ShrSVecI64x2\r\n : SIMDShiftOp.ShrSVecI32x4;\r\n break;\r\n }\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? SIMDShiftOp.ShrUVecI64x2\r\n : SIMDShiftOp.ShrUVecI32x4;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n if (op == -1) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.range\r\n );\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\r\n let arg1 = compiler.compileExpression(operands[1], Type.i32, Constraints.CONV_IMPLICIT);\r\n compiler.currentType = Type.v128;\r\n return module.simd_shift(op, arg0, arg1);\r\n }\r\n case BuiltinSymbols.v128_and: // any_bitwise_binary(a: v128, b: v128) -> v128\r\n case BuiltinSymbols.v128_or:\r\n case BuiltinSymbols.v128_xor: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 2, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let op: BinaryOp = -1;\r\n switch (prototype.internalName) {\r\n default: assert(false);\r\n case BuiltinSymbols.v128_and: { op = BinaryOp.AndVec128; break; }\r\n case BuiltinSymbols.v128_or: { op = BinaryOp.OrVec128; break; }\r\n case BuiltinSymbols.v128_xor: { op = BinaryOp.XorVec128; break; }\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\r\n let arg1 = compiler.compileExpression(operands[1], Type.v128, Constraints.CONV_IMPLICIT);\r\n return module.binary(op, arg0, arg1);\r\n }\r\n case BuiltinSymbols.v128_not: { // any_bitwise_unary(a: v128) -> v128\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\r\n return module.unary(UnaryOp.NotVec128, arg0);\r\n }\r\n case BuiltinSymbols.v128_bitselect: { // bitselect(v1: v128, v2: v128, c: v128) -> v128\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 3, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.v128;\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\r\n let arg1 = compiler.compileExpression(operands[1], Type.v128, Constraints.CONV_IMPLICIT);\r\n let arg2 = compiler.compileExpression(operands[2], Type.v128, Constraints.CONV_IMPLICIT);\r\n return module.simd_bitselect(arg0, arg1, arg2);\r\n }\r\n case BuiltinSymbols.v128_any_true: // any_test(a: v128) -> bool\r\n case BuiltinSymbols.v128_all_true: {\r\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\r\n if (\r\n checkTypeRequired(typeArguments, reportNode, compiler) |\r\n checkArgsRequired(operands, 1, reportNode, compiler)\r\n ) {\r\n compiler.currentType = Type.bool;\r\n return module.unreachable();\r\n }\r\n let type = typeArguments![0];\r\n if (type.is(TypeFlags.REFERENCE)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n return module.unreachable();\r\n }\r\n let op: UnaryOp = -1;\r\n switch (prototype.internalName) {\r\n default: assert(false);\r\n case BuiltinSymbols.v128_any_true: {\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = UnaryOp.AnyTrueVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = UnaryOp.AnyTrueVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = UnaryOp.AnyTrueVecI32x4; break; }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = UnaryOp.AnyTrueVecI64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? UnaryOp.AnyTrueVecI64x2\r\n : UnaryOp.AnyTrueVecI32x4;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n case BuiltinSymbols.v128_all_true: {\r\n switch (type.kind) {\r\n case TypeKind.I8:\r\n case TypeKind.U8: { op = UnaryOp.AllTrueVecI8x16; break; }\r\n case TypeKind.I16:\r\n case TypeKind.U16: { op = UnaryOp.AllTrueVecI16x8; break; }\r\n case TypeKind.I32:\r\n case TypeKind.U32: { op = UnaryOp.AllTrueVecI32x4; break; }\r\n case TypeKind.I64:\r\n case TypeKind.U64: { op = UnaryOp.AllTrueVecI64x2; break; }\r\n case TypeKind.ISIZE:\r\n case TypeKind.USIZE: {\r\n op = compiler.options.isWasm64\r\n ? UnaryOp.AllTrueVecI64x2\r\n : UnaryOp.AllTrueVecI32x4;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n if (op == -1) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.typeArgumentsRange\r\n );\r\n compiler.currentType = Type.bool;\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\r\n compiler.currentType = Type.bool;\r\n return module.unary(op, arg0);\r\n }\r\n\r\n // === Internal runtime =======================================================================\r\n\r\n case BuiltinSymbols.idof: {\r\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\r\n compiler.currentType = Type.u32;\r\n if (!type) return module.unreachable();\r\n let classReference = type.classReference;\r\n if (!classReference || classReference.hasDecorator(DecoratorFlags.UNMANAGED)) {\r\n compiler.error(\r\n DiagnosticCode.Operation_not_supported,\r\n reportNode.range\r\n );\r\n return module.unreachable();\r\n }\r\n return module.i32(classReference.id);\r\n }\r\n case BuiltinSymbols.visit_globals: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 1, reportNode, compiler) // cookie\r\n ) {\r\n compiler.currentType = Type.void;\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], Type.u32, Constraints.CONV_IMPLICIT);\r\n compiler.runtimeFeatures |= RuntimeFeatures.visitGlobals;\r\n compiler.currentType = Type.void;\r\n return module.call(BuiltinSymbols.visit_globals, [ arg0 ], NativeType.None);\r\n }\r\n case BuiltinSymbols.visit_members: {\r\n if (\r\n checkTypeAbsent(typeArguments, reportNode, prototype) |\r\n checkArgsRequired(operands, 2, reportNode, compiler) // ref, cookie\r\n ) {\r\n compiler.currentType = Type.void;\r\n return module.unreachable();\r\n }\r\n let arg0 = compiler.compileExpression(operands[0], compiler.options.usizeType, Constraints.CONV_IMPLICIT);\r\n let arg1 = compiler.compileExpression(operands[1], Type.u32, Constraints.CONV_IMPLICIT);\r\n compiler.runtimeFeatures |= RuntimeFeatures.visitMembers;\r\n compiler.currentType = Type.void;\r\n return module.call(BuiltinSymbols.visit_members, [ arg0, arg1 ], NativeType.None);\r\n }\r\n }\r\n\r\n // try to defer inline asm to a concrete built-in\r\n {\r\n let expr = tryDeferASM(compiler, prototype, operands, reportNode);\r\n if (expr) {\r\n if (typeArguments) {\r\n compiler.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n reportNode.typeArgumentsRange, prototype.internalName\r\n );\r\n }\r\n return expr;\r\n }\r\n }\r\n compiler.error(\r\n DiagnosticCode.Cannot_find_name_0,\r\n reportNode.expression.range, prototype.internalName\r\n );\r\n return module.unreachable();\r\n}\r\n\r\n/** Tries to defer an inline-assembler-like call to a built-in function. */\r\nfunction tryDeferASM(\r\n compiler: Compiler,\r\n prototype: FunctionPrototype,\r\n operands: Expression[],\r\n reportNode: CallExpression\r\n): ExpressionRef {\r\n /* tslint:disable:max-line-length */\r\n switch (prototype.internalName) {\r\n\r\n // TODO: Operators can't be just deferred (don't have a corresponding generic built-in)\r\n // add, sub, mul, div_s, div_u, rem_s, rem_u\r\n // and, or, xor, shl, shr_u, shr_s\r\n // eq, eqz, ne, lt_s, lt_u, le_s, le_u, gt_s, gt_u, ge_s, ge_u\r\n\r\n case BuiltinSymbols.i32_clz: return deferASM(BuiltinSymbols.clz, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_clz: return deferASM(BuiltinSymbols.clz, compiler, Type.i64, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i32_ctz: return deferASM(BuiltinSymbols.ctz, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_ctz: return deferASM(BuiltinSymbols.ctz, compiler, Type.i64, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i32_popcnt: return deferASM(BuiltinSymbols.popcnt, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_popcnt: return deferASM(BuiltinSymbols.popcnt, compiler, Type.i64, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i32_rotl: return deferASM(BuiltinSymbols.rotl, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_rotl: return deferASM(BuiltinSymbols.rotl, compiler, Type.i64, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i32_rotr: return deferASM(BuiltinSymbols.rotr, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_rotr: return deferASM(BuiltinSymbols.rotr, compiler, Type.i64, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.f32_abs: return deferASM(BuiltinSymbols.abs, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_abs: return deferASM(BuiltinSymbols.abs, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.f32_max: return deferASM(BuiltinSymbols.max, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_max: return deferASM(BuiltinSymbols.max, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.f32_min: return deferASM(BuiltinSymbols.min, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_min: return deferASM(BuiltinSymbols.min, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.f32_ceil: return deferASM(BuiltinSymbols.ceil, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_ceil: return deferASM(BuiltinSymbols.ceil, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.f32_floor: return deferASM(BuiltinSymbols.floor, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_floor: return deferASM(BuiltinSymbols.floor, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.f32_copysign: return deferASM(BuiltinSymbols.copysign, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_copysign: return deferASM(BuiltinSymbols.copysign, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.f32_nearest: return deferASM(BuiltinSymbols.nearest, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_nearest: return deferASM(BuiltinSymbols.nearest, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.i32_reinterpret_f32: return deferASM(BuiltinSymbols.reinterpret, compiler, Type.i32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.i64_reinterpret_f64: return deferASM(BuiltinSymbols.reinterpret, compiler, Type.i64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.f32_reinterpret_i32: return deferASM(BuiltinSymbols.reinterpret, compiler, Type.f32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.f64_reinterpret_i64: return deferASM(BuiltinSymbols.reinterpret, compiler, Type.f64, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.f32_sqrt: return deferASM(BuiltinSymbols.sqrt, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_sqrt: return deferASM(BuiltinSymbols.sqrt, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.f32_trunc: return deferASM(BuiltinSymbols.trunc, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_trunc: return deferASM(BuiltinSymbols.trunc, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.i32_load8_s: return deferASM(BuiltinSymbols.load, compiler, Type.i8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_load8_u: return deferASM(BuiltinSymbols.load, compiler, Type.u8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_load16_s: return deferASM(BuiltinSymbols.load, compiler, Type.i16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_load16_u: return deferASM(BuiltinSymbols.load, compiler, Type.u16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_load: return deferASM(BuiltinSymbols.load, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_load8_s: return deferASM(BuiltinSymbols.load, compiler, Type.i8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_load8_u: return deferASM(BuiltinSymbols.load, compiler, Type.u8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_load16_s: return deferASM(BuiltinSymbols.load, compiler, Type.i16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_load16_u: return deferASM(BuiltinSymbols.load, compiler, Type.u16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_load32_s: return deferASM(BuiltinSymbols.load, compiler, Type.i32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_load32_u: return deferASM(BuiltinSymbols.load, compiler, Type.u32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_load: return deferASM(BuiltinSymbols.load, compiler, Type.i64, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.f32_load: return deferASM(BuiltinSymbols.load, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_load: return deferASM(BuiltinSymbols.load, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.i32_store8: return deferASM(BuiltinSymbols.store, compiler, Type.i8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_store16: return deferASM(BuiltinSymbols.store, compiler, Type.i16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_store: return deferASM(BuiltinSymbols.store, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_store8: return deferASM(BuiltinSymbols.store, compiler, Type.i8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_store16: return deferASM(BuiltinSymbols.store, compiler, Type.i16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_store32: return deferASM(BuiltinSymbols.store, compiler, Type.i32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_store: return deferASM(BuiltinSymbols.store, compiler, Type.i64, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.f32_store: return deferASM(BuiltinSymbols.store, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f64_store: return deferASM(BuiltinSymbols.store, compiler, Type.f64, operands, Type.f64, reportNode);\r\n }\r\n if (compiler.options.hasFeature(Feature.THREADS)) {\r\n switch (prototype.internalName) {\r\n\r\n case BuiltinSymbols.i32_atomic_load8_u: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.u8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_load16_u: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.u16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_load: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_atomic_load8_u: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.u8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_load16_u: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.u16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_load32_u: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.u32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_load: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.i64, operands, Type.i64, reportNode);\r\n\r\n case BuiltinSymbols.i32_atomic_store8: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.u8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_store16: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.u16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_store: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_atomic_store8: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.u8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_store16: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.u16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_store32: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.u32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_store: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.i64, operands, Type.i64, reportNode);\r\n\r\n case BuiltinSymbols.i32_atomic_rmw8_add_u: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.u8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw16_add_u: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.u16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw_add: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw8_add_u: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.u8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw16_add_u: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.u16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw32_add_u: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.u32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw_add: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.i64, operands, Type.i64, reportNode);\r\n\r\n case BuiltinSymbols.i32_atomic_rmw8_sub_u: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.u8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw16_sub_u: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.u16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw_sub: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw8_sub_u: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.u8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw16_sub_u: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.u16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw32_sub_u: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.u32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw_sub: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.i64, operands, Type.i64, reportNode);\r\n\r\n case BuiltinSymbols.i32_atomic_rmw8_and_u: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.u8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw16_and_u: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.u16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw_and: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw8_and_u: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.u8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw16_and_u: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.u16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw32_and_u: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.u32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw_and: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.i64, operands, Type.i64, reportNode);\r\n\r\n case BuiltinSymbols.i32_atomic_rmw8_or_u: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.u8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw16_or_u: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.u16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw_or: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw8_or_u: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.u8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw16_or_u: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.u16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw32_or_u: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.u32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw_or: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.i64, operands, Type.i64, reportNode);\r\n\r\n case BuiltinSymbols.i32_atomic_rmw8_u_xor: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.u8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw16_u_xor: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.u16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw_xor: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw8_xor_u: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.u8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw16_xor_u: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.u16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw32_xor_u: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.u32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw_xor: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.i64, operands, Type.i64, reportNode);\r\n\r\n case BuiltinSymbols.i32_atomic_rmw8_xchg_u: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.u8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw16_xchg_u: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.u16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw_xchg: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw8_xchg_u: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.u8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw16_xchg_u: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.u16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw32_xchg_u: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.u32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw_xchg: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.i64, operands, Type.i64, reportNode);\r\n\r\n case BuiltinSymbols.i32_atomic_rmw8_cmpxchg_u: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.u8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw16_cmpxchg_u: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.u16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32_atomic_rmw_cmpxchg: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw8_cmpxchg_u: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.u8, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw16_cmpxchg_u: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.u16, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw32_cmpxchg_u: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.u32, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64_atomic_rmw_cmpxchg: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.i64, operands, Type.i64, reportNode);\r\n\r\n case BuiltinSymbols.i32_wait: return deferASM(BuiltinSymbols.atomic_wait, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64_wait: return deferASM(BuiltinSymbols.atomic_wait, compiler, Type.i64, operands, Type.i32, reportNode);\r\n }\r\n }\r\n if (compiler.options.hasFeature(Feature.SIMD)) {\r\n switch (prototype.internalName) {\r\n\r\n case BuiltinSymbols.v128_load: return deferASM(BuiltinSymbols.load, compiler, Type.v128, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.v128_store: return deferASM(BuiltinSymbols.store, compiler, Type.v128, operands, Type.void, reportNode);\r\n\r\n case BuiltinSymbols.i8x16_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_extract_lane_s: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.i8, operands, Type.i8, reportNode);\r\n case BuiltinSymbols.i8x16_extract_lane_u: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.u8, operands, Type.u8, reportNode);\r\n case BuiltinSymbols.i8x16_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_mul: return deferASM(BuiltinSymbols.v128_mul, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_add_saturate_s: return deferASM(BuiltinSymbols.v128_add_saturate, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_add_saturate_u: return deferASM(BuiltinSymbols.v128_add_saturate, compiler, Type.u8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_sub_saturate_s: return deferASM(BuiltinSymbols.v128_sub_saturate, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_sub_saturate_u: return deferASM(BuiltinSymbols.v128_sub_saturate, compiler, Type.u8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_shl: return deferASM(BuiltinSymbols.v128_shl, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_shr_s: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_shr_u: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.u8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_any_true: return deferASM(BuiltinSymbols.v128_any_true, compiler, Type.i8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i8x16_all_true: return deferASM(BuiltinSymbols.v128_all_true, compiler, Type.i8, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i8x16_eq: return deferASM(BuiltinSymbols.v128_eq, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_ne: return deferASM(BuiltinSymbols.v128_ne, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_lt_s: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_lt_u: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.u8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_le_s: return deferASM(BuiltinSymbols.v128_le, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_le_u: return deferASM(BuiltinSymbols.v128_le, compiler, Type.u8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_gt_s: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_gt_u: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.u8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_ge_s: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.i8, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i8x16_ge_u: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.u8, operands, Type.v128, reportNode);\r\n\r\n case BuiltinSymbols.i16x8_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_extract_lane_s: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.i16, operands, Type.i16, reportNode);\r\n case BuiltinSymbols.i16x8_extract_lane_u: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.u16, operands, Type.u16, reportNode);\r\n case BuiltinSymbols.i16x8_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_mul: return deferASM(BuiltinSymbols.v128_mul, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_add_saturate_s: return deferASM(BuiltinSymbols.v128_add_saturate, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_add_saturate_u: return deferASM(BuiltinSymbols.v128_add_saturate, compiler, Type.u16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_sub_saturate_s: return deferASM(BuiltinSymbols.v128_sub_saturate, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_sub_saturate_u: return deferASM(BuiltinSymbols.v128_sub_saturate, compiler, Type.u16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_shl: return deferASM(BuiltinSymbols.v128_shl, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_shr_s: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_shr_u: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.u16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_any_true: return deferASM(BuiltinSymbols.v128_any_true, compiler, Type.i16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i16x8_all_true: return deferASM(BuiltinSymbols.v128_all_true, compiler, Type.i16, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i16x8_eq: return deferASM(BuiltinSymbols.v128_eq, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_ne: return deferASM(BuiltinSymbols.v128_ne, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_lt_s: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_lt_u: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.u16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_le_s: return deferASM(BuiltinSymbols.v128_le, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_le_u: return deferASM(BuiltinSymbols.v128_le, compiler, Type.u16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_gt_s: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_gt_u: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.u16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_ge_s: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.i16, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i16x8_ge_u: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.u16, operands, Type.v128, reportNode);\r\n\r\n case BuiltinSymbols.i32x4_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_extract_lane: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32x4_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_mul: return deferASM(BuiltinSymbols.v128_mul, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_shl: return deferASM(BuiltinSymbols.v128_shl, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_shr_s: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_shr_u: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.u32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_any_true: return deferASM(BuiltinSymbols.v128_any_true, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32x4_all_true: return deferASM(BuiltinSymbols.v128_all_true, compiler, Type.i32, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i32x4_eq: return deferASM(BuiltinSymbols.v128_eq, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_ne: return deferASM(BuiltinSymbols.v128_ne, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_lt_s: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_lt_u: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.u32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_le_s: return deferASM(BuiltinSymbols.v128_le, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_le_u: return deferASM(BuiltinSymbols.v128_le, compiler, Type.u32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_gt_s: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_gt_u: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.u32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_ge_s: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_ge_u: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.u32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_trunc_s_f32x4_sat: return deferASM(BuiltinSymbols.v128_trunc, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i32x4_trunc_u_f32x4_sat: return deferASM(BuiltinSymbols.v128_trunc, compiler, Type.u32, operands, Type.v128, reportNode);\r\n\r\n case BuiltinSymbols.i64x2_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.i64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i64x2_extract_lane: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.i64, operands, Type.i64, reportNode);\r\n case BuiltinSymbols.i64x2_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.i64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i64x2_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.i64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i64x2_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.i64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i64x2_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.i64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i64x2_shl: return deferASM(BuiltinSymbols.v128_shl, compiler, Type.i64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i64x2_shr_s: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.i64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i64x2_shr_u: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.u64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i64x2_any_true: return deferASM(BuiltinSymbols.v128_any_true, compiler, Type.i64, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64x2_all_true: return deferASM(BuiltinSymbols.v128_all_true, compiler, Type.i64, operands, Type.i32, reportNode);\r\n case BuiltinSymbols.i64x2_trunc_s_f64x2_sat: return deferASM(BuiltinSymbols.v128_trunc, compiler, Type.i64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.i64x2_trunc_u_f64x2_sat: return deferASM(BuiltinSymbols.v128_trunc, compiler, Type.u64, operands, Type.v128, reportNode);\r\n\r\n case BuiltinSymbols.f32x4_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_extract_lane: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.f32, operands, Type.f32, reportNode);\r\n case BuiltinSymbols.f32x4_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_mul: return deferASM(BuiltinSymbols.v128_mul, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_div: return deferASM(BuiltinSymbols.v128_div, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_min: return deferASM(BuiltinSymbols.v128_min, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_max: return deferASM(BuiltinSymbols.v128_max, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_abs: return deferASM(BuiltinSymbols.v128_abs, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_sqrt: return deferASM(BuiltinSymbols.v128_sqrt, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_eq: return deferASM(BuiltinSymbols.v128_eq, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_ne: return deferASM(BuiltinSymbols.v128_ne, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_lt: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_le: return deferASM(BuiltinSymbols.v128_le, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_gt: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_ge: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.f32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_convert_s_i32x4: return deferASM(BuiltinSymbols.v128_convert, compiler, Type.i32, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f32x4_convert_u_i32x4: return deferASM(BuiltinSymbols.v128_convert, compiler, Type.u32, operands, Type.v128, reportNode);\r\n\r\n case BuiltinSymbols.f64x2_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_extract_lane: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.f64, operands, Type.f64, reportNode);\r\n case BuiltinSymbols.f64x2_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_mul: return deferASM(BuiltinSymbols.v128_mul, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_div: return deferASM(BuiltinSymbols.v128_div, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_min: return deferASM(BuiltinSymbols.v128_min, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_max: return deferASM(BuiltinSymbols.v128_max, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_abs: return deferASM(BuiltinSymbols.v128_abs, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_sqrt: return deferASM(BuiltinSymbols.v128_sqrt, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_eq: return deferASM(BuiltinSymbols.v128_eq, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_ne: return deferASM(BuiltinSymbols.v128_ne, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_lt: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_le: return deferASM(BuiltinSymbols.v128_le, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_gt: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_ge: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.f64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_convert_s_i64x2: return deferASM(BuiltinSymbols.v128_convert, compiler, Type.i64, operands, Type.v128, reportNode);\r\n case BuiltinSymbols.f64x2_convert_u_i64x2: return deferASM(BuiltinSymbols.v128_convert, compiler, Type.u64, operands, Type.v128, reportNode);\r\n\r\n case BuiltinSymbols.v8x16_shuffle: return deferASM(BuiltinSymbols.v128_shuffle, compiler, Type.i8, operands, Type.v128, reportNode);\r\n }\r\n }\r\n /* tslint:enable:max-line-length */\r\n return 0;\r\n}\r\n\r\n/** A helper for deferring inline-assembler-like calls to built-in functions. */\r\nfunction deferASM(\r\n name: string,\r\n compiler: Compiler,\r\n typeArgument: Type,\r\n operands: Expression[],\r\n contextualType: Type,\r\n reportNode: CallExpression\r\n): ExpressionRef {\r\n assert(compiler.program.elementsByName.has(name));\r\n var prototype = compiler.program.elementsByName.get(name)!;\r\n assert(prototype.kind == ElementKind.FUNCTION_PROTOTYPE);\r\n return compileCall(\r\n compiler,\r\n prototype,\r\n [ typeArgument ],\r\n operands,\r\n contextualType,\r\n reportNode,\r\n /* isAsm */ true\r\n );\r\n}\r\n\r\n/** Compiles an abort wired to the conditionally imported 'abort' function. */\r\nexport function compileAbort(\r\n compiler: Compiler,\r\n message: Expression | null,\r\n reportNode: Node\r\n): ExpressionRef {\r\n var program = compiler.program;\r\n var module = compiler.module;\r\n\r\n var stringInstance = compiler.program.stringInstance;\r\n if (!stringInstance) return module.unreachable();\r\n\r\n var abortInstance = program.abortInstance;\r\n if (!(abortInstance && compiler.compileFunction(abortInstance))) return module.unreachable();\r\n\r\n var messageArg: ExpressionRef;\r\n if (message !== null) {\r\n // The message argument works much like an arm of an IF that does not become executed if the\r\n // assertion succeeds respectively is only being computed if the program actually crashes.\r\n // Hence, let's make it so that the autorelease is skipped at the end of the current block,\r\n // essentially ignoring the message GC-wise. Doesn't matter anyway on a crash.\r\n messageArg = compiler.compileExpression(message, stringInstance.type, Constraints.CONV_IMPLICIT | Constraints.WILL_RETAIN);\r\n } else {\r\n messageArg = stringInstance.type.toNativeZero(module);\r\n }\r\n\r\n var filenameArg = compiler.ensureStaticString(reportNode.range.source.normalizedPath);\r\n\r\n compiler.currentType = Type.void;\r\n return module.block(null, [\r\n module.call(\r\n abortInstance.internalName, [\r\n messageArg,\r\n filenameArg,\r\n module.i32(reportNode.range.line),\r\n module.i32(reportNode.range.column)\r\n ],\r\n NativeType.None\r\n ),\r\n module.unreachable()\r\n ]);\r\n}\r\n\r\n/** Compiles the `visit_globals` function. */\r\nexport function compileVisitGlobals(compiler: Compiler): void {\r\n var module = compiler.module;\r\n var exprs = new Array();\r\n var typeRef = compiler.ensureFunctionType([ Type.u32 ], Type.void); // cookie\r\n var nativeSizeType = compiler.options.nativeSizeType;\r\n var visitInstance = assert(compiler.program.visitInstance);\r\n\r\n compiler.compileFunction(visitInstance);\r\n\r\n for (let element of compiler.program.elementsByName.values()) {\r\n if (element.kind != ElementKind.GLOBAL) continue;\r\n let global = element;\r\n let classReference = global.type.classReference;\r\n if (\r\n global.is(CommonFlags.COMPILED) &&\r\n classReference !== null &&\r\n !classReference.hasDecorator(DecoratorFlags.UNMANAGED)\r\n ) {\r\n if (global.is(CommonFlags.INLINED)) {\r\n let value = global.constantIntegerValue;\r\n if (i64_low(value) || i64_high(value)) {\r\n exprs.push(\r\n module.call(visitInstance.internalName, [\r\n compiler.options.isWasm64\r\n ? module.i64(i64_low(value), i64_high(value))\r\n : module.i32(i64_low(value))\r\n ], NativeType.None)\r\n );\r\n }\r\n } else {\r\n exprs.push(\r\n module.if(\r\n module.local_tee(1,\r\n module.global_get(global.internalName, nativeSizeType)\r\n ),\r\n module.call(visitInstance.internalName, [\r\n module.local_get(1, nativeSizeType), // tempRef != null\r\n module.local_get(0, NativeType.I32) // cookie\r\n ], NativeType.None)\r\n )\r\n );\r\n }\r\n }\r\n }\r\n module.addFunction(BuiltinSymbols.visit_globals, typeRef, [ nativeSizeType ],\r\n exprs.length\r\n ? module.block(null, exprs)\r\n : module.nop()\r\n );\r\n}\r\n\r\n/** Compiles the `visit_members` function. */\r\nexport function compileVisitMembers(compiler: Compiler): void {\r\n var program = compiler.program;\r\n var module = compiler.module;\r\n var usizeType = program.options.usizeType;\r\n var nativeSizeType = usizeType.toNativeType();\r\n var nativeSizeSize = usizeType.byteSize;\r\n var ftype = compiler.ensureFunctionType([ usizeType, Type.i32 ], Type.void); // ref, cookie\r\n var managedClasses = program.managedClasses;\r\n var visitInstance = assert(program.visitInstance);\r\n var blocks = new Array();\r\n var relooper = Relooper.create(module);\r\n\r\n var outer = relooper.addBlockWithSwitch(\r\n module.nop(),\r\n module.load(nativeSizeSize, false,\r\n nativeSizeType == NativeType.I64\r\n ? module.binary(BinaryOp.SubI64,\r\n module.local_get(0, nativeSizeType),\r\n module.i64(8)\r\n )\r\n : module.binary(BinaryOp.SubI32,\r\n module.local_get(0, nativeSizeType),\r\n module.i32(8) // rtId is at -8\r\n ),\r\n NativeType.I32,\r\n 0\r\n )\r\n );\r\n\r\n var lastId = 0;\r\n for (let [id, instance] of managedClasses) {\r\n assert(instance.type.isManaged);\r\n assert(id == lastId++);\r\n\r\n let visitImpl: Element | null;\r\n\r\n // if a library element, check if it implements a custom traversal function\r\n if (instance.isDeclaredInLibrary && (visitImpl = instance.lookupInSelf(\"__visit_impl\"))) {\r\n assert(visitImpl.kind == ElementKind.FUNCTION_PROTOTYPE);\r\n let visitFunc = program.resolver.resolveFunction(visitImpl, null);\r\n let block: RelooperBlockRef;\r\n if (!visitFunc || !compiler.compileFunction(visitFunc)) {\r\n block = relooper.addBlock(\r\n module.unreachable()\r\n );\r\n } else {\r\n let visitSig = visitFunc.signature;\r\n assert(\r\n visitSig.parameterTypes.length == 1 &&\r\n visitSig.parameterTypes[0] == Type.u32 &&\r\n visitSig.returnType == Type.void &&\r\n visitSig.thisType == instance.type\r\n );\r\n let callExpr = module.call(visitFunc.internalName, [\r\n module.local_get(0, nativeSizeType), // ref\r\n module.local_get(1, NativeType.I32) // cookie\r\n ], NativeType.None);\r\n block = relooper.addBlock(\r\n instance.base\r\n ? callExpr // branch will be added later\r\n : module.block(null, [\r\n callExpr,\r\n module.return()\r\n ])\r\n );\r\n }\r\n relooper.addBranchForSwitch(outer, block, [ id ]);\r\n blocks.push(block);\r\n\r\n // otherwise generate one\r\n } else {\r\n // traverse references assigned to own fields\r\n let code = new Array();\r\n let members = instance.members;\r\n if (members) {\r\n for (let member of members.values()) {\r\n if (member.kind == ElementKind.FIELD) {\r\n if ((member).parent === instance) {\r\n let fieldType = (member).type;\r\n if (fieldType.isManaged) {\r\n let fieldOffset = (member).memoryOffset;\r\n assert(fieldOffset >= 0);\r\n code.push(\r\n // if ($2 = value) FIELDCLASS~traverse($2)\r\n module.if(\r\n module.local_tee(2,\r\n module.load(nativeSizeSize, false,\r\n module.local_get(0, nativeSizeType),\r\n nativeSizeType, fieldOffset\r\n )\r\n ),\r\n module.call(visitInstance.internalName, [\r\n module.local_get(2, nativeSizeType), // ref\r\n module.local_get(1, NativeType.I32) // cookie\r\n ], NativeType.None)\r\n )\r\n );\r\n }\r\n }\r\n }\r\n }\r\n }\r\n if (!instance.base) code.push(module.return());\r\n let block = relooper.addBlock(\r\n flatten(module, code, NativeType.None)\r\n );\r\n relooper.addBranchForSwitch(outer, block, [ id ]);\r\n blocks.push(block);\r\n }\r\n }\r\n for (let [id, instance] of managedClasses) {\r\n let base = instance.base;\r\n if (base) {\r\n relooper.addBranch(blocks[id], blocks[base.id]);\r\n }\r\n }\r\n blocks.push(\r\n relooper.addBlock(\r\n module.unreachable()\r\n )\r\n );\r\n relooper.addBranchForSwitch(outer, blocks[blocks.length - 1], []); // default\r\n compiler.compileFunction(visitInstance);\r\n module.addFunction(BuiltinSymbols.visit_members, ftype, [ nativeSizeType ], relooper.renderAndDispose(outer, 2));\r\n}\r\n\r\nfunction typeToRuntimeFlags(type: Type): TypeinfoFlags {\r\n var flags = TypeinfoFlags.VALUE_ALIGN_0 * (1 << type.alignLog2);\r\n if (type.is(TypeFlags.SIGNED)) flags |= TypeinfoFlags.VALUE_SIGNED;\r\n if (type.is(TypeFlags.FLOAT)) flags |= TypeinfoFlags.VALUE_FLOAT;\r\n if (type.is(TypeFlags.NULLABLE)) flags |= TypeinfoFlags.VALUE_NULLABLE;\r\n if (type.isManaged) flags |= TypeinfoFlags.VALUE_MANAGED;\r\n return flags / TypeinfoFlags.VALUE_ALIGN_0;\r\n}\r\n\r\n/** Compiles runtime type information for use by stdlib. */\r\nexport function compileRTTI(compiler: Compiler): void {\r\n var program = compiler.program;\r\n var module = compiler.module;\r\n var managedClasses = program.managedClasses;\r\n var count = managedClasses.size;\r\n var size = 4 + 8 * count;\r\n var data = new Uint8Array(size);\r\n writeI32(count, data, 0);\r\n var off = 4;\r\n var abvInstance = program.arrayBufferViewInstance;\r\n var abvPrototype = abvInstance.prototype;\r\n var arrayPrototype = program.arrayPrototype;\r\n var setPrototype = program.setPrototype;\r\n var mapPrototype = program.mapPrototype;\r\n var lastId = 0;\r\n for (let [id, instance] of managedClasses) {\r\n assert(id == lastId++);\r\n let flags: TypeinfoFlags = 0;\r\n if (instance.isAcyclic) flags |= TypeinfoFlags.ACYCLIC;\r\n if (instance !== abvInstance && instance.extends(abvPrototype)) {\r\n let valueType = instance.getArrayValueType();\r\n flags |= TypeinfoFlags.ARRAYBUFFERVIEW;\r\n if (instance.extends(arrayPrototype)) flags |= TypeinfoFlags.ARRAY;\r\n flags |= TypeinfoFlags.VALUE_ALIGN_0 * typeToRuntimeFlags(valueType);\r\n } else if (instance.extends(setPrototype)) {\r\n let typeArguments = assert(instance.getTypeArgumentsTo(setPrototype));\r\n assert(typeArguments.length == 1);\r\n flags |= TypeinfoFlags.SET;\r\n flags |= TypeinfoFlags.VALUE_ALIGN_0 * typeToRuntimeFlags(typeArguments[0]);\r\n } else if (instance.extends(mapPrototype)) {\r\n let typeArguments = assert(instance.getTypeArgumentsTo(mapPrototype));\r\n assert(typeArguments.length == 2);\r\n flags |= TypeinfoFlags.MAP;\r\n flags |= TypeinfoFlags.KEY_ALIGN_0 * typeToRuntimeFlags(typeArguments[0]);\r\n flags |= TypeinfoFlags.VALUE_ALIGN_0 * typeToRuntimeFlags(typeArguments[1]);\r\n }\r\n writeI32(flags, data, off); off += 4;\r\n instance.rttiFlags = flags;\r\n let base = instance.base;\r\n writeI32(base ? base.id : 0, data, off); off += 4;\r\n }\r\n assert(off == size);\r\n var usizeType = program.options.usizeType;\r\n var segment = compiler.addMemorySegment(data);\r\n if (usizeType.size == 8) {\r\n let offset = segment.offset;\r\n module.addGlobal(BuiltinSymbols.rtti_base, NativeType.I64, false, module.i64(i64_low(offset), i64_high(offset)));\r\n } else {\r\n module.addGlobal(BuiltinSymbols.rtti_base, NativeType.I32, false, module.i32(i64_low(segment.offset)));\r\n }\r\n}\r\n\r\n// Helpers\r\n\r\n/** Evaluates the constant type of a type argument *or* expression. */\r\nfunction evaluateConstantType(\r\n compiler: Compiler,\r\n typeArguments: Type[] | null,\r\n operands: Expression[],\r\n reportNode: CallExpression\r\n): Type | null {\r\n if (operands.length == 0) { // requires type argument\r\n if (!typeArguments || typeArguments.length != 1) {\r\n compiler.error(\r\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\r\n reportNode.typeArgumentsRange, \"1\", typeArguments ? typeArguments.length.toString(10) : \"0\"\r\n );\r\n return null;\r\n }\r\n return typeArguments[0];\r\n }\r\n if (operands.length == 1) { // optional type argument\r\n if (typeArguments !== null && typeArguments.length) {\r\n if (typeArguments.length > 1) {\r\n compiler.error(\r\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\r\n reportNode.typeArgumentsRange, \"1\", typeArguments.length.toString(10)\r\n );\r\n return null;\r\n }\r\n compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT);\r\n } else {\r\n compiler.compileExpression(operands[0], Type.auto);\r\n }\r\n return compiler.currentType;\r\n }\r\n if (typeArguments && typeArguments.length > 1) {\r\n compiler.error(\r\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\r\n reportNode.typeArgumentsRange, \"1\", typeArguments.length.toString(10)\r\n );\r\n }\r\n compiler.error(\r\n DiagnosticCode.Expected_0_arguments_but_got_1,\r\n reportNode.argumentsRange, \"1\", operands.length.toString(10)\r\n );\r\n return null;\r\n}\r\n\r\n/** Evaluates a compile-time constant immediate offset argument.*/\r\nfunction evaluateImmediateOffset(expression: Expression, compiler: Compiler): i32 {\r\n var expr: ExpressionRef;\r\n var value: i32;\r\n if (compiler.options.isWasm64) {\r\n expr = compiler.precomputeExpression(expression, Type.usize64, Constraints.CONV_IMPLICIT);\r\n if (\r\n getExpressionId(expr) != ExpressionId.Const ||\r\n getExpressionType(expr) != NativeType.I64 ||\r\n getConstValueI64High(expr) != 0 ||\r\n (value = getConstValueI64Low(expr)) < 0\r\n ) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n expression.range\r\n );\r\n value = -1;\r\n }\r\n } else {\r\n expr = compiler.precomputeExpression(expression, Type.usize32, Constraints.CONV_IMPLICIT);\r\n if (\r\n getExpressionId(expr) != ExpressionId.Const ||\r\n getExpressionType(expr) != NativeType.I32 ||\r\n (value = getConstValueI32(expr)) < 0\r\n ) {\r\n compiler.error(\r\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\r\n expression.range\r\n );\r\n value = -1;\r\n }\r\n }\r\n return value;\r\n}\r\n\r\n/** Checks a call with a single required type argument. Returns `1` on error. */\r\nfunction checkTypeRequired(\r\n typeArguments: Type[] | null,\r\n reportNode: CallExpression,\r\n compiler: Compiler,\r\n setCurrentTypeOnError: bool = false\r\n): i32 {\r\n if (typeArguments) {\r\n let numTypeArguments = typeArguments.length;\r\n if (numTypeArguments == 1) return 0;\r\n assert(numTypeArguments); // invalid if 0, must not be set at all instead\r\n if (setCurrentTypeOnError) compiler.currentType = typeArguments[0];\r\n compiler.error(\r\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\r\n reportNode.typeArgumentsRange, \"1\", numTypeArguments.toString()\r\n );\r\n } else {\r\n compiler.error(\r\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\r\n reportNode.range, \"1\", \"0\"\r\n );\r\n }\r\n return 1;\r\n}\r\n\r\n/** Checks a call with a single optional type argument. Returns `1` on error. */\r\nfunction checkTypeOptional(\r\n typeArguments: Type[] | null,\r\n reportNode: CallExpression,\r\n compiler: Compiler,\r\n setCurrentTypeOnError: bool = false\r\n): i32 {\r\n if (typeArguments) {\r\n let numTypeArguments = typeArguments.length;\r\n if (numTypeArguments == 1) return 0;\r\n assert(numTypeArguments); // invalid if 0, must not be set at all instead\r\n if (setCurrentTypeOnError) compiler.currentType = typeArguments[0];\r\n compiler.error(\r\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\r\n reportNode.typeArgumentsRange, \"1\", numTypeArguments.toString()\r\n );\r\n return 1;\r\n }\r\n return 0;\r\n}\r\n\r\n/** Checks a call that is not generic. Returns `1` on error. */\r\nfunction checkTypeAbsent(\r\n typeArguments: Type[] | null,\r\n reportNode: CallExpression,\r\n prototype: FunctionPrototype\r\n): i32 {\r\n if (typeArguments) {\r\n prototype.program.error(\r\n DiagnosticCode.Type_0_is_not_generic,\r\n reportNode.typeArgumentsRange, prototype.internalName\r\n );\r\n return 1;\r\n }\r\n return 0;\r\n}\r\n\r\n/** Checks a call that requires a fixed number of arguments. Returns `1` on error. */\r\nfunction checkArgsRequired(\r\n operands: Expression[],\r\n expected: i32,\r\n reportNode: CallExpression,\r\n compiler: Compiler\r\n): i32 {\r\n if (operands.length != expected) {\r\n compiler.error(\r\n DiagnosticCode.Expected_0_arguments_but_got_1,\r\n reportNode.range, expected.toString(), operands.length.toString()\r\n );\r\n return 1;\r\n }\r\n return 0;\r\n}\r\n\r\n/** Checks a call that requires a variable number of arguments. Returns `1` on error. */\r\nfunction checkArgsOptional(\r\n operands: Expression[],\r\n expectedMinimum: i32,\r\n expectedMaximum: i32,\r\n reportNode: CallExpression,\r\n compiler: Compiler\r\n): i32 {\r\n var numOperands = operands.length;\r\n if (numOperands < expectedMinimum) {\r\n compiler.error(\r\n DiagnosticCode.Expected_at_least_0_arguments_but_got_1,\r\n reportNode.range, expectedMinimum.toString(), numOperands.toString()\r\n );\r\n return 1;\r\n } else if (numOperands > expectedMaximum) {\r\n compiler.error(\r\n DiagnosticCode.Expected_0_arguments_but_got_1,\r\n reportNode.range, expectedMaximum.toString(), numOperands.toString()\r\n );\r\n return 1;\r\n }\r\n return 0;\r\n}\r\n","/**\r\n * A decompiler that generates low-level AssemblyScript from WebAssembly binaries.\r\n * @module decompiler\r\n *//***/\r\n\r\nimport {\r\n Module,\r\n NativeType,\r\n ExpressionId,\r\n UnaryOp,\r\n BinaryOp,\r\n HostOp,\r\n FunctionRef,\r\n ExpressionRef,\r\n Index,\r\n getFunctionName,\r\n getFunctionBody,\r\n getFunctionParamCount,\r\n getFunctionParamType,\r\n getFunctionResultType,\r\n getExpressionId,\r\n getExpressionType,\r\n getBlockName,\r\n getBlockChildCount,\r\n getBlockChild,\r\n getIfCondition,\r\n getIfTrue,\r\n getIfFalse,\r\n getLoopName,\r\n getLoopBody,\r\n getBreakName,\r\n getBreakCondition,\r\n getLocalGetIndex,\r\n getLocalSetIndex,\r\n getLocalSetValue,\r\n getLoadOffset,\r\n getLoadPtr,\r\n getStoreOffset,\r\n getStorePtr,\r\n getStoreValue,\r\n getConstValueI32,\r\n getConstValueI64Low,\r\n getConstValueI64High,\r\n getConstValueF32,\r\n getConstValueF64,\r\n getUnaryOp,\r\n getUnaryValue,\r\n getBinaryOp,\r\n getBinaryLeft,\r\n getBinaryRight,\r\n getSelectThen,\r\n getSelectElse,\r\n getSelectCondition,\r\n getDropValue,\r\n getReturnValue,\r\n getHostOp,\r\n getHostOperand\r\n} from \"./module\";\r\n\r\n// TODO :-)\r\n\r\nexport class Decompiler {\r\n\r\n static decompile(module: Module): string {\r\n var decompiler = new Decompiler();\r\n decompiler.decompile(module);\r\n return decompiler.finish();\r\n }\r\n\r\n text: string[] = [];\r\n functionId: i32 = 0;\r\n\r\n constructor() { }\r\n\r\n /** Decompiles a module to an AST that can then be serialized. */\r\n decompile(module: Module): void {\r\n throw new Error(\"not implemented\");\r\n }\r\n\r\n decompileFunction(func: FunctionRef): void {\r\n var name = getFunctionName(func) || \"$\" + this.functionId.toString(10);\r\n var body = getFunctionBody(func);\r\n this.push(\"function \");\r\n this.push(name);\r\n this.push(\"(\");\r\n for (let i: Index = 0, k: Index = getFunctionParamCount(func); i < k; ++i) {\r\n if (i > 0) this.push(\", \");\r\n this.push(\"$\");\r\n this.push(i.toString(10));\r\n this.push(\": \");\r\n this.push(nativeTypeToType(getFunctionParamType(func, i)));\r\n }\r\n this.push(\"): \");\r\n this.push(nativeTypeToType(getFunctionResultType(func)));\r\n this.push(\" \");\r\n if (getExpressionId(body) != ExpressionId.Block) {\r\n this.push(\"{\\n\");\r\n }\r\n this.decompileExpression(body);\r\n if (getExpressionId(body) != ExpressionId.Block) {\r\n this.push(\"\\n}\\n\");\r\n }\r\n ++this.functionId;\r\n }\r\n\r\n decompileExpression(expr: ExpressionRef): void {\r\n var id = getExpressionId(expr);\r\n var type = getExpressionType(expr);\r\n\r\n var nested: ExpressionRef;\r\n var string: string | null;\r\n var i: Index, k: Index;\r\n\r\n switch (id) {\r\n case ExpressionId.Block: { // TODO: magic\r\n if ((string = getBlockName(expr)) != null) {\r\n this.push(string);\r\n this.push(\": \");\r\n }\r\n this.push(\"{\\n\");\r\n k = getBlockChildCount(expr);\r\n for (i = 0; i < k; ++i) {\r\n this.decompileExpression(getBlockChild(expr, i));\r\n }\r\n this.push(\"}\\n\");\r\n return;\r\n }\r\n case ExpressionId.If: {\r\n if (type == NativeType.None) {\r\n this.push(\"if (\");\r\n this.decompileExpression(getIfCondition(expr));\r\n this.push(\") \");\r\n this.decompileExpression(getIfTrue(expr));\r\n if (nested = getIfFalse(expr)) {\r\n this.push(\" else \");\r\n this.decompileExpression(nested);\r\n }\r\n } else {\r\n this.decompileExpression(getIfCondition(expr));\r\n this.push(\" ? \");\r\n this.decompileExpression(getIfTrue(expr));\r\n this.push(\" : \");\r\n this.decompileExpression(getIfFalse(expr));\r\n }\r\n return;\r\n }\r\n case ExpressionId.Loop: {\r\n if ((string = getLoopName(expr)) != null) {\r\n this.push(string);\r\n this.push(\": \");\r\n }\r\n this.push(\"do \");\r\n this.decompileExpression(getLoopBody(expr));\r\n this.push(\"while (0);\\n\");\r\n }\r\n case ExpressionId.Break: {\r\n if (nested = getBreakCondition(expr)) {\r\n this.push(\"if (\");\r\n this.decompileExpression(nested);\r\n this.push(\") \");\r\n }\r\n if ((string = getBreakName(expr)) != null) {\r\n this.push(\"break \");\r\n this.push(string);\r\n this.push(\";\\n\");\r\n } else {\r\n this.push(\"break;\\n\");\r\n }\r\n return;\r\n }\r\n case ExpressionId.Switch:\r\n case ExpressionId.Call:\r\n case ExpressionId.CallIndirect: {\r\n throw new Error(\"not implemented\");\r\n }\r\n case ExpressionId.LocalGet: {\r\n this.push(\"$\");\r\n this.push(getLocalGetIndex(expr).toString(10));\r\n return;\r\n }\r\n case ExpressionId.LocalSet: {\r\n this.push(\"$\");\r\n this.push(getLocalSetIndex(expr).toString(10));\r\n this.push(\" = \");\r\n this.decompileExpression(getLocalSetValue(expr));\r\n return;\r\n }\r\n case ExpressionId.GlobalGet:\r\n case ExpressionId.GlobalSet: {\r\n throw new Error(\"not implemented\");\r\n }\r\n case ExpressionId.Load: {\r\n this.push(\"load<\");\r\n this.push(nativeTypeToType(type));\r\n this.push(\">(\");\r\n this.push(getLoadOffset(expr).toString(10));\r\n this.push(\" + \");\r\n this.decompileExpression(getLoadPtr(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case ExpressionId.Store: {\r\n this.push(\"store<\");\r\n this.push(nativeTypeToType(type));\r\n this.push(\">(\");\r\n this.push(getStoreOffset(expr).toString(10));\r\n this.push(\" + \");\r\n this.decompileExpression(getStorePtr(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getStoreValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case ExpressionId.Const: {\r\n switch (type) {\r\n case NativeType.I32: {\r\n this.push(getConstValueI32(expr).toString(10));\r\n return;\r\n }\r\n case NativeType.I64: {\r\n this.push(\r\n i64_to_string(\r\n i64_new(\r\n getConstValueI64Low(expr),\r\n getConstValueI64High(expr)\r\n )\r\n )\r\n );\r\n return;\r\n }\r\n case NativeType.F32: {\r\n this.push(getConstValueF32(expr).toString(10));\r\n return;\r\n }\r\n case NativeType.F64: {\r\n this.push(getConstValueF64(expr).toString(10));\r\n return;\r\n }\r\n }\r\n break;\r\n }\r\n case ExpressionId.Unary: {\r\n switch (getUnaryOp(expr)) {\r\n case UnaryOp.ClzI32: {\r\n this.push(\"clz(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.CtzI32: {\r\n this.push(\"ctz(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.PopcntI32: {\r\n this.push(\"popcnt(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.NegF32:\r\n case UnaryOp.NegF64: {\r\n this.push(\"-\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.AbsF32: {\r\n this.push(\"abs(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.CeilF32: {\r\n this.push(\"ceil(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.FloorF32: {\r\n this.push(\"floor(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.TruncF32: {\r\n this.push(\"trunc(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.NearestF32: {\r\n this.push(\"nearest(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.SqrtF32: {\r\n this.push(\"sqrt(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.EqzI32:\r\n case UnaryOp.EqzI64: {\r\n this.push(\"!\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ClzI64: {\r\n this.push(\"clz(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.CtzI64: {\r\n this.push(\"ctz(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.PopcntI64: {\r\n this.push(\"popcnt(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.AbsF64: {\r\n this.push(\"abs(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.CeilF64: {\r\n this.push(\"ceil(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.FloorF64: {\r\n this.push(\"floor(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.TruncF64: {\r\n this.push(\"trunc(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.NearestF64: {\r\n this.push(\"nearest(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.SqrtF64: {\r\n this.push(\"sqrt(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.ExtendI32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ExtendU32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.WrapI64: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.TruncF32ToI32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.TruncF32ToI64: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.TruncF32ToU32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.TruncF32ToU64: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.TruncF64ToI32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.TruncF64ToI64: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.TruncF64ToU32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.TruncF64ToU64: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ReinterpretF32: {\r\n this.push(\"reinterpret(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.ReinterpretF64: {\r\n this.push(\"reinterpret(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.ConvertI32ToF32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ConvertI32ToF64: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ConvertU32ToF32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ConvertU32ToF64: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ConvertI64ToF32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ConvertI64ToF64: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ConvertU64ToF32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ConvertU64ToF64: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.PromoteF32: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.DemoteF64: {\r\n this.push(\"\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n return;\r\n }\r\n case UnaryOp.ReinterpretI32: {\r\n this.push(\"reinterpret(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case UnaryOp.ReinterpretI64: {\r\n this.push(\"reinterpret(\");\r\n this.decompileExpression(getUnaryValue(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n }\r\n break;\r\n }\r\n case ExpressionId.Binary: { // TODO: precedence\r\n switch (getBinaryOp(expr)) {\r\n case BinaryOp.AddI32:\r\n case BinaryOp.AddI64:\r\n case BinaryOp.AddF32:\r\n case BinaryOp.AddF64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" + \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.SubI32:\r\n case BinaryOp.SubI64:\r\n case BinaryOp.SubF32:\r\n case BinaryOp.SubF64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" - \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.MulI32:\r\n case BinaryOp.MulI64:\r\n case BinaryOp.MulF32:\r\n case BinaryOp.MulF64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" * \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.DivI32:\r\n case BinaryOp.DivI64:\r\n case BinaryOp.DivF32:\r\n case BinaryOp.DivF64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" / \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.DivU32: {\r\n this.push(\"(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" / \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.RemI32:\r\n case BinaryOp.RemI64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" % \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.RemU32: {\r\n this.push(\"(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" / \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.AndI32:\r\n case BinaryOp.AndI64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" & \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.OrI32:\r\n case BinaryOp.OrI64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" | \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.XorI32:\r\n case BinaryOp.XorI64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" ^ \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.ShlI32:\r\n case BinaryOp.ShlI64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" << \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.ShrU32:\r\n case BinaryOp.ShrU64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" >>> \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.ShrI32:\r\n case BinaryOp.ShrI64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" >> \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.RotlI32: {\r\n this.push(\"rotl(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.RotrI32: {\r\n this.push(\"rotr(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.EqI32:\r\n case BinaryOp.EqI64:\r\n case BinaryOp.EqF32:\r\n case BinaryOp.EqF64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" == \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.NeI32:\r\n case BinaryOp.NeI64:\r\n case BinaryOp.NeF32:\r\n case BinaryOp.NeF64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" != \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.LtI32:\r\n case BinaryOp.LtI64:\r\n case BinaryOp.LtF32:\r\n case BinaryOp.LtF64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" < \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.LtU32: {\r\n this.push(\"\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" < \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.LeI32:\r\n case BinaryOp.LeI64:\r\n case BinaryOp.LeF32:\r\n case BinaryOp.LeF64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" <= \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.LeU32: {\r\n this.push(\"\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" <= \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.GtI32:\r\n case BinaryOp.GtI64:\r\n case BinaryOp.GtF32:\r\n case BinaryOp.GtF64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" > \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.GtU32: {\r\n this.push(\"\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" > \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.GeI32:\r\n case BinaryOp.GeI64:\r\n case BinaryOp.GeF32:\r\n case BinaryOp.GeF64: {\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" >= \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.GeU32: {\r\n this.push(\"\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" >= \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.DivU64: {\r\n this.push(\"\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" / \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.RemU64: {\r\n this.push(\"\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" % \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.RotlI64: {\r\n this.push(\"rotl(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.RotrI64: {\r\n this.push(\"rotr(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.LtU64: {\r\n this.push(\"\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" < \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.LeU64: {\r\n this.push(\"\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" <= \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.GtU64: {\r\n this.push(\"\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" > \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.GeU64: {\r\n this.push(\"\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\" >= \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n return;\r\n }\r\n case BinaryOp.CopysignF32: {\r\n this.push(\"copysign(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.MinF32: {\r\n this.push(\"min(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.MaxF32: {\r\n this.push(\"max(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.CopysignF64: {\r\n this.push(\"copysign(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.MinF64: {\r\n this.push(\"min(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case BinaryOp.MaxF64: {\r\n this.push(\"max(\");\r\n this.decompileExpression(getBinaryLeft(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getBinaryRight(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n }\r\n return;\r\n }\r\n case ExpressionId.Select: {\r\n this.push(\"select<\");\r\n this.push(nativeTypeToType(type));\r\n this.push(\">(\");\r\n this.decompileExpression(getSelectThen(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getSelectElse(expr));\r\n this.push(\", \");\r\n this.decompileExpression(getSelectCondition(expr));\r\n this.push(\")\");\r\n return;\r\n }\r\n case ExpressionId.Drop: {\r\n this.decompileExpression(getDropValue(expr));\r\n this.push(\";\\n\");\r\n return;\r\n }\r\n case ExpressionId.Return: {\r\n if (nested = getReturnValue(expr)) {\r\n this.push(\"return \");\r\n this.decompileExpression(nested);\r\n this.push(\";\\n\");\r\n } else {\r\n this.push(\"return;\\n\");\r\n }\r\n return;\r\n }\r\n case ExpressionId.Host: {\r\n switch (getHostOp(expr)) {\r\n case HostOp.MemorySize: {\r\n this.push(\"memory.size()\");\r\n return;\r\n }\r\n case HostOp.MemoryGrow: {\r\n this.push(\"memory.grow(\");\r\n this.decompileExpression(getHostOperand(expr, 0));\r\n this.push(\")\");\r\n return;\r\n }\r\n }\r\n break;\r\n }\r\n case ExpressionId.Nop: {\r\n this.push(\";\\n\");\r\n return;\r\n }\r\n case ExpressionId.Unreachable: {\r\n this.push(\"unreachable()\");\r\n return;\r\n }\r\n case ExpressionId.AtomicCmpxchg:\r\n case ExpressionId.AtomicRMW:\r\n case ExpressionId.AtomicWait:\r\n case ExpressionId.AtomicNotify:\r\n }\r\n throw new Error(\"not implemented\");\r\n }\r\n\r\n private push(text: string): void {\r\n // mostly here so we can add debugging if necessary\r\n this.text.push(text);\r\n }\r\n\r\n finish(): string {\r\n var ret = this.text.join(\"\");\r\n this.text = [];\r\n return ret;\r\n }\r\n}\r\n\r\nfunction nativeTypeToType(type: NativeType): string {\r\n switch (type) {\r\n case NativeType.None: return \"void\";\r\n case NativeType.I32: return \"i32\";\r\n case NativeType.I64: return \"i64\";\r\n case NativeType.F32: return \"f32\";\r\n case NativeType.F64: return \"f64\";\r\n case NativeType.V128: return \"v128\";\r\n case NativeType.Unreachable: throw new Error(\"unreachable type\");\r\n case NativeType.Auto: throw new Error(\"auto type\");\r\n default: throw new Error(\"unexpected type\");\r\n }\r\n}\r\n","/**\r\n * Definition builders for WebIDL and TypeScript.\r\n * @module definitions\r\n *//***/\r\n\r\n import {\r\n CommonFlags\r\n} from \"./common\";\r\n\r\nimport {\r\n Program,\r\n Element,\r\n ElementKind,\r\n Global,\r\n Enum,\r\n EnumValue,\r\n Field,\r\n Function,\r\n FunctionPrototype,\r\n Class,\r\n ClassPrototype,\r\n Namespace,\r\n ConstantValueKind,\r\n Interface,\r\n Property,\r\n PropertyPrototype,\r\n File\r\n} from \"./program\";\r\n\r\nimport {\r\n Type,\r\n TypeKind\r\n} from \"./types\";\r\n\r\nimport {\r\n indent\r\n} from \"./util\";\r\n\r\n/** Walker base class. */\r\nabstract class ExportsWalker {\r\n\r\n /** Program reference. */\r\n program: Program;\r\n /** Whether to include private members */\r\n includePrivate: bool;\r\n /** Already seen elements. */\r\n seen: Map = new Map();\r\n\r\n /** Constructs a new Element walker. */\r\n constructor(program: Program, includePrivate: bool = false) {\r\n this.program = program;\r\n this.includePrivate;\r\n }\r\n\r\n /** Walks all elements and calls the respective handlers. */\r\n walk(): void {\r\n for (let file of this.program.filesByName.values()) {\r\n if (file.source.isEntry) this.visitFile(file);\r\n }\r\n }\r\n\r\n /** Visits all exported elements of a file. */\r\n visitFile(file: File): void {\r\n var members = file.exports;\r\n if (members) {\r\n for (let [name, member] of members) this.visitElement(name, member);\r\n }\r\n var exportsStar = file.exportsStar;\r\n if (exportsStar) {\r\n for (let exportStar of exportsStar) this.visitFile(exportStar);\r\n }\r\n }\r\n\r\n /** Visits an element.*/\r\n visitElement(name: string, element: Element): void {\r\n if (element.is(CommonFlags.PRIVATE) && !this.includePrivate) return;\r\n var seen = this.seen;\r\n if (seen.has(element)) {\r\n this.visitAlias(name, element, seen.get(element));\r\n return;\r\n }\r\n seen.set(element, name);\r\n switch (element.kind) {\r\n case ElementKind.GLOBAL: {\r\n if (element.is(CommonFlags.COMPILED)) this.visitGlobal(name, element);\r\n break;\r\n }\r\n case ElementKind.ENUM: {\r\n if (element.is(CommonFlags.COMPILED)) this.visitEnum(name, element);\r\n break;\r\n }\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n this.visitFunctionInstances(name, element);\r\n break;\r\n }\r\n case ElementKind.CLASS_PROTOTYPE: {\r\n this.visitClassInstances(name, element);\r\n break;\r\n }\r\n case ElementKind.FIELD: {\r\n if ((element).is(CommonFlags.COMPILED)) this.visitField(name, element);\r\n break;\r\n }\r\n case ElementKind.PROPERTY_PROTOTYPE: {\r\n this.visitPropertyInstances(name, element);\r\n break;\r\n }\r\n case ElementKind.PROPERTY: {\r\n let prop = element;\r\n let getter = prop.getterInstance;\r\n if (getter) this.visitFunction(name, getter);\r\n let setter = prop.setterInstance;\r\n if (setter) this.visitFunction(name, setter);\r\n break;\r\n }\r\n case ElementKind.NAMESPACE: {\r\n if (hasCompiledMember(element)) this.visitNamespace(name, element);\r\n break;\r\n }\r\n case ElementKind.TYPEDEFINITION: break;\r\n default: assert(false);\r\n }\r\n }\r\n\r\n private visitFunctionInstances(name: string, element: FunctionPrototype): void {\r\n var instances = element.instances;\r\n if (instances) {\r\n for (let instance of instances.values()) {\r\n if (instance.is(CommonFlags.COMPILED)) this.visitFunction(name, instance);\r\n }\r\n }\r\n }\r\n\r\n private visitClassInstances(name: string, element: ClassPrototype): void {\r\n var instances = element.instances;\r\n if (instances) {\r\n for (let instance of instances.values()) {\r\n if (instance.is(CommonFlags.COMPILED)) this.visitClass(name, instance);\r\n }\r\n }\r\n }\r\n\r\n private visitPropertyInstances(name: string, element: PropertyPrototype): void {\r\n // var instances = element.instances;\r\n // if (instances) {\r\n // for (let instance of instances.values()) {\r\n // if (instance.is(CommonFlags.COMPILED)) this.visitProperty(instance);\r\n // }\r\n // }\r\n assert(false);\r\n }\r\n\r\n abstract visitGlobal(name: string, element: Global): void;\r\n abstract visitEnum(name: string, element: Enum): void;\r\n abstract visitFunction(name: string, element: Function): void;\r\n abstract visitClass(name: string, element: Class): void;\r\n abstract visitInterface(name: string, element: Interface): void;\r\n abstract visitField(name: string, element: Field): void;\r\n abstract visitNamespace(name: string, element: Element): void;\r\n abstract visitAlias(name: string, element: Element, originalName: string): void;\r\n}\r\n\r\n/** A WebIDL definitions builder. */\r\nexport class IDLBuilder extends ExportsWalker {\r\n\r\n /** Builds WebIDL definitions for the specified program. */\r\n static build(program: Program): string {\r\n return new IDLBuilder(program).build();\r\n }\r\n\r\n private sb: string[] = [];\r\n private indentLevel: i32 = 0;\r\n\r\n /** Constructs a new WebIDL builder. */\r\n constructor(program: Program, includePrivate: bool = false) {\r\n super(program, includePrivate);\r\n }\r\n\r\n visitGlobal(name: string, element: Global): void {\r\n var sb = this.sb;\r\n var isConst = element.is(CommonFlags.INLINED);\r\n indent(sb, this.indentLevel);\r\n if (isConst) sb.push(\"const \");\r\n sb.push(this.typeToString(element.type));\r\n sb.push(\" \");\r\n sb.push(name);\r\n if (isConst) {\r\n switch (element.constantValueKind) {\r\n case ConstantValueKind.INTEGER: {\r\n sb.push(\" = \");\r\n sb.push(i64_to_string(element.constantIntegerValue));\r\n break;\r\n }\r\n case ConstantValueKind.FLOAT: {\r\n sb.push(\" = \");\r\n sb.push(element.constantFloatValue.toString());\r\n break;\r\n }\r\n default: assert(false);\r\n }\r\n }\r\n sb.push(\";\\n\");\r\n }\r\n\r\n visitEnum(name: string, element: Enum): void {\r\n var sb = this.sb;\r\n indent(sb, this.indentLevel++);\r\n sb.push(\"interface \");\r\n sb.push(name);\r\n sb.push(\" {\\n\");\r\n var members = element.members;\r\n if (members) {\r\n for (let [name, member] of members) {\r\n if (member.kind == ElementKind.ENUMVALUE) {\r\n let isConst = (member).is(CommonFlags.INLINED);\r\n indent(sb, this.indentLevel);\r\n if (isConst) sb.push(\"const \");\r\n else sb.push(\"readonly \");\r\n sb.push(\"unsigned long \");\r\n sb.push(name);\r\n if (isConst) {\r\n sb.push(\" = \");\r\n assert((member).constantValueKind == ConstantValueKind.INTEGER);\r\n sb.push(i64_low((member).constantIntegerValue).toString(10));\r\n }\r\n sb.push(\";\\n\");\r\n }\r\n }\r\n for (let member of members.values()) {\r\n if (member.kind != ElementKind.ENUMVALUE) this.visitElement(member.name, member);\r\n }\r\n }\r\n indent(sb, --this.indentLevel);\r\n sb.push(\"}\\n\");\r\n }\r\n\r\n visitFunction(name: string, element: Function): void {\r\n var sb = this.sb;\r\n var signature = element.signature;\r\n indent(sb, this.indentLevel);\r\n sb.push(this.typeToString(signature.returnType));\r\n sb.push(\" \");\r\n sb.push(name);\r\n sb.push(\"(\");\r\n var parameters = signature.parameterTypes;\r\n var numParameters = parameters.length;\r\n // var requiredParameters = signature.requiredParameters;\r\n for (let i = 0; i < numParameters; ++i) {\r\n if (i) sb.push(\", \");\r\n // if (i >= requiredParameters) sb.push(\"optional \");\r\n sb.push(this.typeToString(parameters[i]));\r\n sb.push(\" \");\r\n sb.push(signature.getParameterName(i));\r\n }\r\n sb.push(\");\\n\");\r\n var members = element.members;\r\n if (members && members.size) {\r\n indent(sb, this.indentLevel);\r\n sb.push(\"interface \");\r\n sb.push(element.name);\r\n sb.push(\" {\\n\");\r\n for (let member of members.values()) this.visitElement(member.name, member);\r\n indent(sb, --this.indentLevel);\r\n sb.push(\"}\\n\");\r\n }\r\n }\r\n\r\n visitClass(name: string, element: Class): void {\r\n var sb = this.sb;\r\n indent(sb, this.indentLevel++);\r\n sb.push(\"interface \");\r\n sb.push(name);\r\n sb.push(\" {\\n\");\r\n // TODO\r\n indent(sb, --this.indentLevel);\r\n sb.push(\"}\\n\");\r\n }\r\n\r\n visitInterface(name: string, element: Interface): void {\r\n this.visitClass(name, element);\r\n }\r\n\r\n visitField(name: string, element: Field): void {\r\n // TODO\r\n }\r\n\r\n visitNamespace(name: string, element: Namespace): void {\r\n var sb = this.sb;\r\n indent(sb, this.indentLevel++);\r\n sb.push(\"interface \");\r\n sb.push(name);\r\n sb.push(\" {\\n\");\r\n var members = element.members;\r\n if (members) {\r\n for (let member of members.values()) this.visitElement(member.name, member);\r\n }\r\n indent(sb, --this.indentLevel);\r\n sb.push(\"}\\n\");\r\n }\r\n\r\n visitAlias(name: string, element: Element, originalName: string): void {\r\n // TODO\r\n }\r\n\r\n typeToString(type: Type): string {\r\n switch (type.kind) {\r\n case TypeKind.I8: return \"byte\";\r\n case TypeKind.I16: return \"short\";\r\n case TypeKind.I32: return \"long\";\r\n case TypeKind.I64: return \"long long\";\r\n case TypeKind.ISIZE: return this.program.options.isWasm64 ? \"long long\" : \"long\";\r\n case TypeKind.U8: return \"octet\";\r\n case TypeKind.U16: return \"unsigned short\";\r\n case TypeKind.U32: return \"unsigned long\";\r\n // ^ TODO: function types\r\n case TypeKind.U64: return \"unsigned long long\";\r\n case TypeKind.USIZE: return this.program.options.isWasm64 ? \"unsigned long long\" : \"unsigned long\";\r\n // ^ TODO: class types\r\n case TypeKind.BOOL: return \"boolean\";\r\n case TypeKind.F32: return \"unrestricted float\";\r\n case TypeKind.F64: return \"unrestricted double\";\r\n case TypeKind.VOID: return \"void\";\r\n default: {\r\n assert(false);\r\n return \"\";\r\n }\r\n }\r\n }\r\n\r\n build(): string {\r\n var sb = this.sb;\r\n sb.push(\"interface ASModule {\\n\");\r\n ++this.indentLevel;\r\n this.walk();\r\n --this.indentLevel;\r\n sb.push(\"}\\n\");\r\n return sb.join(\"\");\r\n }\r\n}\r\n\r\n/** A TypeScript definitions builder. */\r\nexport class TSDBuilder extends ExportsWalker {\r\n\r\n /** Builds TypeScript definitions for the specified program. */\r\n static build(program: Program): string {\r\n return new TSDBuilder(program).build();\r\n }\r\n\r\n private sb: string[] = [];\r\n private indentLevel: i32 = 0;\r\n private unknown: Set = new Set();\r\n\r\n /** Constructs a new WebIDL builder. */\r\n constructor(program: Program, includePrivate: bool = false) {\r\n super(program, includePrivate);\r\n }\r\n\r\n visitGlobal(name: string, element: Global): void {\r\n var sb = this.sb;\r\n var isConst = element.is(CommonFlags.INLINED);\r\n indent(sb, this.indentLevel);\r\n if (element.is(CommonFlags.STATIC)) {\r\n if (isConst) sb.push(\"static readonly \");\r\n else sb.push(\"static \");\r\n } else {\r\n if (isConst) sb.push(\"export const \");\r\n else sb.push(\"export var \");\r\n }\r\n sb.push(name);\r\n sb.push(\": \");\r\n sb.push(this.typeToString(element.type));\r\n sb.push(\";\\n\");\r\n this.visitNamespace(name, element);\r\n }\r\n\r\n visitEnum(name: string, element: Enum): void {\r\n var sb = this.sb;\r\n indent(sb, this.indentLevel++);\r\n sb.push(\"export enum \");\r\n sb.push(name);\r\n sb.push(\" {\\n\");\r\n var members = element.members;\r\n if (members) {\r\n let numMembers = members.size;\r\n for (let [name, member] of members) {\r\n if (member.kind == ElementKind.ENUMVALUE) {\r\n indent(sb, this.indentLevel);\r\n sb.push(name);\r\n if (member.is(CommonFlags.INLINED)) {\r\n sb.push(\" = \");\r\n assert((member).constantValueKind == ConstantValueKind.INTEGER);\r\n sb.push(i64_low((member).constantIntegerValue).toString(10));\r\n }\r\n sb.push(\",\\n\");\r\n --numMembers;\r\n }\r\n }\r\n if (numMembers) this.visitNamespace(name, element);\r\n }\r\n indent(sb, --this.indentLevel);\r\n sb.push(\"}\\n\");\r\n }\r\n\r\n visitFunction(name: string, element: Function): void {\r\n if (element.isAny(CommonFlags.PRIVATE | CommonFlags.SET)) return;\r\n var sb = this.sb;\r\n var signature = element.signature;\r\n indent(sb, this.indentLevel);\r\n if (element.is(CommonFlags.PROTECTED)) sb.push(\"protected \");\r\n if (element.is(CommonFlags.STATIC)) sb.push(\"static \");\r\n if (element.is(CommonFlags.GET)) {\r\n sb.push(\"get \");\r\n sb.push(name); // 'get:funcName' internally\r\n sb.push(\"(): \");\r\n sb.push(this.typeToString(signature.returnType));\r\n sb.push(\";\\n\");\r\n return;\r\n } else {\r\n if (!element.isAny(CommonFlags.STATIC | CommonFlags.INSTANCE)) sb.push(\"export function \");\r\n sb.push(name);\r\n }\r\n sb.push(\"(\");\r\n var parameters = signature.parameterTypes;\r\n var numParameters = parameters.length;\r\n // var requiredParameters = signature.requiredParameters;\r\n for (let i = 0; i < numParameters; ++i) {\r\n if (i) sb.push(\", \");\r\n // if (i >= requiredParameters) sb.push(\"optional \");\r\n sb.push(signature.getParameterName(i));\r\n sb.push(\": \");\r\n sb.push(this.typeToString(parameters[i]));\r\n }\r\n if (element.isAny(CommonFlags.CONSTRUCTOR | CommonFlags.SET)) {\r\n sb.push(\")\");\r\n } else {\r\n sb.push(\"): \");\r\n sb.push(this.typeToString(signature.returnType));\r\n }\r\n sb.push(\";\\n\");\r\n this.visitNamespace(name, element);\r\n }\r\n\r\n visitClass(name: string, element: Class): void {\r\n var sb = this.sb;\r\n var isInterface = element.kind == ElementKind.INTERFACE;\r\n indent(sb, this.indentLevel++);\r\n if (isInterface) {\r\n sb.push(\"export interface \");\r\n } else {\r\n if (element.is(CommonFlags.ABSTRACT)) sb.push(\"abstract \");\r\n sb.push(\"export class \");\r\n }\r\n sb.push(name);\r\n // var base = element.base;\r\n // if (base && base.is(CommonFlags.COMPILED | CommonFlags.MODULE_EXPORT)) {\r\n // sb.push(\" extends \");\r\n // sb.push(base.name); // TODO: fqn\r\n // }\r\n sb.push(\" {\\n\");\r\n var staticMembers = element.prototype.members;\r\n if (staticMembers) {\r\n for (let member of staticMembers.values()) this.visitElement(member.name, member);\r\n }\r\n var instanceMembers = element.members;\r\n if (instanceMembers) {\r\n for (let member of instanceMembers.values()) this.visitElement(member.name, member);\r\n }\r\n indent(sb, --this.indentLevel);\r\n sb.push(\"}\\n\");\r\n }\r\n\r\n visitInterface(name: string, element: Interface): void {\r\n this.visitClass(name, element);\r\n }\r\n\r\n visitField(name: string, element: Field): void {\r\n if (element.is(CommonFlags.PRIVATE)) return;\r\n var sb = this.sb;\r\n indent(sb, this.indentLevel);\r\n if (element.is(CommonFlags.PROTECTED)) sb.push(\"protected \");\r\n if (element.is(CommonFlags.STATIC)) sb.push(\"static \");\r\n if (element.is(CommonFlags.READONLY)) sb.push(\"readonly \");\r\n sb.push(name);\r\n sb.push(\": \");\r\n sb.push(this.typeToString(element.type));\r\n sb.push(\";\\n\");\r\n }\r\n\r\n visitNamespace(name: string, element: Element): void {\r\n var members = element.members;\r\n if (members && members.size) {\r\n let sb = this.sb;\r\n indent(sb, this.indentLevel++);\r\n sb.push(\"export namespace \");\r\n sb.push(name);\r\n sb.push(\" {\\n\");\r\n for (let member of members.values()) this.visitElement(member.name, member);\r\n indent(sb, --this.indentLevel);\r\n sb.push(\"}\\n\");\r\n }\r\n }\r\n\r\n visitAlias(name: string, element: Element, originalName: string): void {\r\n var sb = this.sb;\r\n indent(sb, this.indentLevel);\r\n sb.push(\"export const \");\r\n sb.push(name);\r\n sb.push(\" = typeof \");\r\n sb.push(originalName);\r\n sb.push(\";\\n\");\r\n }\r\n\r\n typeToString(type: Type): string {\r\n switch (type.kind) {\r\n case TypeKind.I8: return \"i8\";\r\n case TypeKind.I16: return \"i16\";\r\n case TypeKind.I32: return \"i32\";\r\n case TypeKind.I64: return \"I64\";\r\n case TypeKind.ISIZE: return this.program.options.isWasm64 ? \"I64\" : \"i32\";\r\n case TypeKind.U8: return \"u8\";\r\n case TypeKind.U16: return \"u16\";\r\n case TypeKind.U32: return \"u32\";\r\n // ^ TODO: function types\r\n case TypeKind.U64: return \"U64\";\r\n case TypeKind.USIZE: return this.program.options.isWasm64 ? \"U64\" : \"u32\";\r\n // ^ TODO: class types\r\n case TypeKind.BOOL: return \"bool\";\r\n case TypeKind.F32: return \"f32\";\r\n case TypeKind.F64: return \"f64\";\r\n case TypeKind.V128: return \"v128\";\r\n case TypeKind.VOID: return \"void\";\r\n default: {\r\n assert(false);\r\n return \"any\";\r\n }\r\n }\r\n }\r\n\r\n build(): string {\r\n var sb = this.sb;\r\n sb.push(\"declare module ASModule {\\n\");\r\n sb.push(\" type i8 = number;\\n\");\r\n sb.push(\" type i16 = number;\\n\");\r\n sb.push(\" type i32 = number;\\n\");\r\n sb.push(\" type u8 = number;\\n\");\r\n sb.push(\" type u16 = number;\\n\");\r\n sb.push(\" type u32 = number;\\n\");\r\n sb.push(\" type f32 = number;\\n\");\r\n sb.push(\" type f64 = number;\\n\");\r\n sb.push(\" type bool = any;\\n\");\r\n ++this.indentLevel;\r\n this.walk();\r\n --this.indentLevel;\r\n sb.push(\"}\\n\");\r\n sb.push(\"export default ASModule;\\n\");\r\n return this.sb.join(\"\");\r\n }\r\n}\r\n\r\n// helpers\r\n\r\n/** Tests if a namespace-like element has at least one compiled member. */\r\nfunction hasCompiledMember(element: Element): bool {\r\n var members = element.members;\r\n if (members) {\r\n for (let member of members.values()) {\r\n switch (member.kind) {\r\n case ElementKind.FUNCTION_PROTOTYPE: {\r\n let instances = (member).instances;\r\n if (instances) {\r\n for (let instance of instances.values()) {\r\n if (instance.is(CommonFlags.COMPILED)) return true;\r\n }\r\n }\r\n break;\r\n }\r\n case ElementKind.CLASS_PROTOTYPE: {\r\n let instances = (member).instances;\r\n if (instances) {\r\n for (let instance of instances.values()) {\r\n if (instance.is(CommonFlags.COMPILED)) return true;\r\n }\r\n }\r\n break;\r\n }\r\n default: {\r\n if (member.is(CommonFlags.COMPILED) || hasCompiledMember(member)) return true;\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n return false;\r\n}\r\n","/**\r\n * A TypeScript parser for the AssemblyScript subset.\r\n * @module parser\r\n *//***/\r\n\r\nimport {\r\n CommonFlags,\r\n LIBRARY_PREFIX,\r\n PATH_DELIMITER\r\n} from \"./common\";\r\n\r\nimport {\r\n Program\r\n} from \"./program\";\r\n\r\nimport {\r\n Tokenizer,\r\n Token,\r\n Range,\r\n CommentHandler,\r\n IdentifierHandling\r\n} from \"./tokenizer\";\r\n\r\nimport {\r\n DiagnosticCode,\r\n DiagnosticEmitter\r\n} from \"./diagnostics\";\r\n\r\nimport {\r\n normalizePath\r\n} from \"./util\";\r\n\r\nimport {\r\n Node,\r\n NodeKind,\r\n Source,\r\n SourceKind,\r\n CommonTypeNode,\r\n TypeNode,\r\n SignatureNode,\r\n ArrowKind,\r\n\r\n Expression,\r\n AssertionKind,\r\n CallExpression,\r\n ClassExpression,\r\n FunctionExpression,\r\n IdentifierExpression,\r\n StringLiteralExpression,\r\n\r\n Statement,\r\n BlockStatement,\r\n BreakStatement,\r\n ClassDeclaration,\r\n ContinueStatement,\r\n DeclarationStatement,\r\n DecoratorNode,\r\n DoStatement,\r\n EnumDeclaration,\r\n EnumValueDeclaration,\r\n ExportImportStatement,\r\n ExportMember,\r\n ExportStatement,\r\n ExpressionStatement,\r\n ForStatement,\r\n FunctionDeclaration,\r\n IfStatement,\r\n ImportDeclaration,\r\n ImportStatement,\r\n IndexSignatureDeclaration,\r\n NamespaceDeclaration,\r\n ParameterNode,\r\n ParameterKind,\r\n ReturnStatement,\r\n SwitchCase,\r\n SwitchStatement,\r\n ThrowStatement,\r\n TryStatement,\r\n TypeDeclaration,\r\n TypeParameterNode,\r\n VariableStatement,\r\n VariableDeclaration,\r\n VoidStatement,\r\n WhileStatement,\r\n\r\n mangleInternalPath,\r\n nodeIsCallable,\r\n nodeIsGenericCallable\r\n} from \"./ast\";\r\n\r\n/** Parser interface. */\r\nexport class Parser extends DiagnosticEmitter {\r\n\r\n /** Program being created. */\r\n program: Program;\r\n /** Source file names to be requested next. */\r\n backlog: string[] = new Array();\r\n /** Source file names already seen, that is processed or backlogged. */\r\n seenlog: Set = new Set();\r\n /** Source file names already completely processed. */\r\n donelog: Set = new Set();\r\n /** Optional handler to intercept comments while tokenizing. */\r\n onComment: CommentHandler | null = null;\r\n\r\n /** Constructs a new parser. */\r\n constructor() {\r\n super();\r\n this.program = new Program(this.diagnostics);\r\n }\r\n\r\n /** Parses a file and adds its definitions to the program. */\r\n parseFile(\r\n text: string,\r\n path: string,\r\n isEntry: bool\r\n ): void {\r\n var normalizedPath = normalizePath(path);\r\n var internalPath = mangleInternalPath(normalizedPath);\r\n\r\n // check if already processed\r\n if (this.donelog.has(internalPath)) return;\r\n this.donelog.add(internalPath); // do not parse again\r\n this.seenlog.add(internalPath); // do not request again\r\n\r\n // create the source element\r\n var source = new Source(\r\n normalizedPath,\r\n text,\r\n isEntry\r\n ? SourceKind.ENTRY\r\n : path.startsWith(LIBRARY_PREFIX) && path.indexOf(PATH_DELIMITER, LIBRARY_PREFIX.length) < 0\r\n ? SourceKind.LIBRARY\r\n : SourceKind.DEFAULT\r\n );\r\n var program = this.program;\r\n program.sources.push(source);\r\n\r\n // tokenize and parse\r\n var tn = new Tokenizer(source, program.diagnostics);\r\n tn.onComment = this.onComment;\r\n source.tokenizer = tn;\r\n var statements = source.statements;\r\n while (!tn.skip(Token.ENDOFFILE)) {\r\n let statement = this.parseTopLevelStatement(tn, null);\r\n if (statement) statements.push(statement);\r\n }\r\n tn.finish();\r\n }\r\n\r\n /** Parses a top-level statement. */\r\n parseTopLevelStatement(\r\n tn: Tokenizer,\r\n namespace: NamespaceDeclaration | null = null\r\n ): Statement | null {\r\n var flags = CommonFlags.NONE;\r\n var startPos: i32 = -1;\r\n\r\n // check decorators\r\n var decorators: DecoratorNode[] | null = null;\r\n while (tn.skip(Token.AT)) {\r\n if (startPos < 0) startPos = tn.tokenPos;\r\n let decorator = this.parseDecorator(tn);\r\n if (!decorator) {\r\n this.skipStatement(tn);\r\n continue;\r\n }\r\n if (!decorators) decorators = [decorator];\r\n else decorators.push(decorator);\r\n }\r\n\r\n // check modifiers\r\n var exportStart: i32 = 0;\r\n var exportEnd: i32 = 0;\r\n var defaultStart: i32 = 0;\r\n var defaultEnd: i32 = 0;\r\n if (tn.skip(Token.EXPORT)) {\r\n if (startPos < 0) startPos = tn.tokenPos;\r\n flags |= CommonFlags.EXPORT;\r\n exportStart = tn.tokenPos;\r\n exportEnd = tn.pos;\r\n if (tn.skip(Token.DEFAULT)) {\r\n defaultStart = tn.tokenPos;\r\n defaultEnd = tn.pos;\r\n }\r\n }\r\n\r\n var declareStart: i32 = 0;\r\n var declareEnd: i32 = 0;\r\n var contextIsAmbient = namespace != null && namespace.is(CommonFlags.AMBIENT);\r\n if (tn.skip(Token.DECLARE)) {\r\n if (contextIsAmbient) {\r\n this.error(\r\n DiagnosticCode.A_declare_modifier_cannot_be_used_in_an_already_ambient_context,\r\n tn.range()\r\n ); // recoverable\r\n } else {\r\n if (startPos < 0) startPos = tn.tokenPos;\r\n declareStart = startPos;\r\n declareEnd = tn.pos;\r\n flags |= CommonFlags.DECLARE | CommonFlags.AMBIENT;\r\n }\r\n } else if (contextIsAmbient) {\r\n flags |= CommonFlags.AMBIENT;\r\n }\r\n\r\n // parse the statement\r\n var statement: Statement | null = null;\r\n\r\n // handle declarations\r\n var first = tn.peek();\r\n if (startPos < 0) startPos = tn.nextTokenPos;\r\n switch (first) {\r\n case Token.CONST: {\r\n tn.next();\r\n flags |= CommonFlags.CONST;\r\n if (tn.skip(Token.ENUM)) {\r\n statement = this.parseEnum(tn, flags, decorators, startPos);\r\n } else {\r\n statement = this.parseVariable(tn, flags, decorators, startPos);\r\n }\r\n decorators = null;\r\n break;\r\n }\r\n case Token.LET: flags |= CommonFlags.LET;\r\n case Token.VAR: {\r\n tn.next();\r\n statement = this.parseVariable(tn, flags, decorators, startPos);\r\n decorators = null;\r\n break;\r\n }\r\n case Token.ENUM: {\r\n tn.next();\r\n statement = this.parseEnum(tn, flags, decorators, startPos);\r\n decorators = null;\r\n break;\r\n }\r\n case Token.FUNCTION: {\r\n tn.next();\r\n statement = this.parseFunction(tn, flags, decorators, startPos);\r\n decorators = null;\r\n break;\r\n }\r\n case Token.ABSTRACT: {\r\n let state = tn.mark();\r\n tn.next();\r\n if (!tn.skip(Token.CLASS)) {\r\n tn.reset(state);\r\n statement = this.parseStatement(tn, true);\r\n break;\r\n } else {\r\n tn.discard(state);\r\n }\r\n flags |= CommonFlags.ABSTRACT;\r\n // fall through\r\n }\r\n case Token.CLASS:\r\n case Token.INTERFACE: {\r\n tn.next();\r\n statement = this.parseClassOrInterface(tn, flags, decorators, startPos);\r\n decorators = null;\r\n break;\r\n }\r\n case Token.NAMESPACE: {\r\n let state = tn.mark();\r\n tn.next();\r\n if (tn.peek(false, IdentifierHandling.PREFER) == Token.IDENTIFIER) {\r\n tn.discard(state);\r\n statement = this.parseNamespace(tn, flags, decorators, startPos);\r\n decorators = null;\r\n } else {\r\n tn.reset(state);\r\n statement = this.parseStatement(tn, true);\r\n }\r\n break;\r\n }\r\n case Token.IMPORT: {\r\n tn.next();\r\n flags |= CommonFlags.IMPORT;\r\n if (flags & CommonFlags.EXPORT) {\r\n statement = this.parseExportImport(tn, startPos);\r\n } else {\r\n statement = this.parseImport(tn);\r\n }\r\n break;\r\n }\r\n case Token.TYPE: { // also identifier\r\n let state = tn.mark();\r\n tn.next();\r\n if (tn.peek(false, IdentifierHandling.PREFER) == Token.IDENTIFIER) {\r\n tn.discard(state);\r\n statement = this.parseTypeDeclaration(tn, flags, decorators, startPos);\r\n decorators = null;\r\n } else {\r\n tn.reset(state);\r\n statement = this.parseStatement(tn, true);\r\n }\r\n break;\r\n }\r\n default: {\r\n\r\n // handle plain exports\r\n if (flags & CommonFlags.EXPORT) {\r\n if (defaultEnd && tn.skipIdentifier(IdentifierHandling.PREFER)) {\r\n if (declareEnd) {\r\n this.error(\r\n DiagnosticCode.An_export_assignment_cannot_have_modifiers,\r\n tn.range(declareStart, declareEnd)\r\n );\r\n }\r\n statement = this.parseExportDefaultAlias(tn, startPos, defaultStart, defaultEnd);\r\n defaultStart = defaultEnd = 0; // consume\r\n } else {\r\n statement = this.parseExport(tn, startPos, (flags & CommonFlags.DECLARE) != 0);\r\n }\r\n\r\n // handle non-declaration statements\r\n } else {\r\n if (exportEnd) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(exportStart, exportEnd), \"export\"\r\n ); // recoverable\r\n }\r\n if (declareEnd) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(declareStart, declareEnd), \"declare\"\r\n ); // recoverable\r\n }\r\n if (!namespace) {\r\n statement = this.parseStatement(tn, true);\r\n } // TODO: else?\r\n }\r\n break;\r\n }\r\n }\r\n\r\n // check for decorators that weren't consumed\r\n if (decorators) {\r\n for (let i = 0, k = decorators.length; i < k; ++i) {\r\n this.error(\r\n DiagnosticCode.Decorators_are_not_valid_here,\r\n decorators[i].range\r\n );\r\n }\r\n }\r\n\r\n // check if this an `export default` declaration\r\n if (defaultEnd && statement !== null) {\r\n switch (statement.kind) {\r\n case NodeKind.ENUMDECLARATION:\r\n case NodeKind.FUNCTIONDECLARATION:\r\n case NodeKind.CLASSDECLARATION:\r\n case NodeKind.INTERFACEDECLARATION:\r\n case NodeKind.NAMESPACEDECLARATION: {\r\n return Node.createExportDefaultStatement(statement, tn.range(startPos, tn.pos));\r\n }\r\n default: {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(defaultStart, defaultEnd), \"default\"\r\n );\r\n }\r\n }\r\n }\r\n return statement;\r\n }\r\n\r\n /** Obtains the next file to parse. */\r\n nextFile(): string | null {\r\n var backlog = this.backlog;\r\n return backlog.length ? backlog.shift() : null;\r\n }\r\n\r\n /** Finishes parsing and returns the program. */\r\n finish(): Program {\r\n if (this.backlog.length) throw new Error(\"backlog is not empty\");\r\n this.backlog = [];\r\n this.seenlog.clear();\r\n this.donelog.clear();\r\n return this.program;\r\n }\r\n\r\n /** Parses a type. */\r\n parseType(\r\n tn: Tokenizer,\r\n acceptParenthesized: bool = true,\r\n suppressErrors: bool = false\r\n ): CommonTypeNode | null {\r\n\r\n // NOTE: this parses our limited subset\r\n var token = tn.next();\r\n var startPos = tn.tokenPos;\r\n\r\n var type: CommonTypeNode;\r\n\r\n // '(' ...\r\n if (token == Token.OPENPAREN) {\r\n\r\n // '(' FunctionSignature ')' '|' 'null'?\r\n let isNullableSignature = tn.skip(Token.OPENPAREN);\r\n // FunctionSignature?\r\n let signature = this.tryParseSignature(tn);\r\n if (signature) {\r\n if (isNullableSignature) {\r\n if (!tn.skip(Token.CLOSEPAREN)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n return null;\r\n }\r\n if (!tn.skip(Token.BAR)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"|\"\r\n );\r\n return null;\r\n }\r\n if (!tn.skip(Token.NULL)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"null\"\r\n );\r\n }\r\n signature.isNullable = true;\r\n }\r\n return signature;\r\n } else if (isNullableSignature || this.tryParseSignatureIsSignature) {\r\n this.error(\r\n DiagnosticCode.Unexpected_token,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n\r\n // Type (',' Type)* ')'\r\n if (acceptParenthesized) {\r\n let innerType = this.parseType(tn, false, suppressErrors);\r\n if (!innerType) return null;\r\n if (!tn.skip(Token.CLOSEPAREN)) {\r\n if (!suppressErrors) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(tn.pos), \"}\"\r\n );\r\n }\r\n return null;\r\n }\r\n type = innerType;\r\n type.range.start = startPos;\r\n type.range.end = tn.pos;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Unexpected_token,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n\r\n // 'void'\r\n } else if (token == Token.VOID) {\r\n type = Node.createType(\r\n Node.createSimpleTypeName(\"void\", tn.range()), [], false, tn.range(startPos, tn.pos)\r\n );\r\n\r\n // 'this'\r\n } else if (token == Token.THIS) {\r\n type = Node.createType(\r\n Node.createSimpleTypeName(\"this\", tn.range()), [], false, tn.range(startPos, tn.pos)\r\n );\r\n\r\n // 'true'\r\n } else if (token == Token.TRUE || token == Token.FALSE) {\r\n type = Node.createType(\r\n Node.createSimpleTypeName(\"bool\", tn.range()), [], false, tn.range(startPos, tn.pos)\r\n );\r\n\r\n // StringLiteral\r\n } else if (token == Token.STRINGLITERAL) {\r\n tn.readString();\r\n type = Node.createType(\r\n Node.createSimpleTypeName(\"string\", tn.range()), [], false, tn.range(startPos, tn.pos)\r\n );\r\n\r\n // Identifier\r\n } else if (token == Token.IDENTIFIER) {\r\n let first = Node.createSimpleTypeName(tn.readIdentifier(), tn.range());\r\n let current = first;\r\n let parameters: TypeNode[] | null = null;\r\n let nullable = false;\r\n\r\n // Identifier ('.' Identifier)+\r\n while (tn.skip(Token.DOT)) {\r\n if (tn.skip(Token.IDENTIFIER)) {\r\n let next = Node.createSimpleTypeName(tn.readIdentifier(), tn.range());\r\n current.next = next;\r\n current = next;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range(tn.pos)\r\n );\r\n return null;\r\n }\r\n }\r\n\r\n // Name\r\n if (tn.skip(Token.LESSTHAN)) {\r\n do {\r\n let parameter = this.parseType(tn, true, suppressErrors);\r\n if (!parameter) return null;\r\n if (!parameters) parameters = [parameter];\r\n else parameters.push(parameter);\r\n } while (tn.skip(Token.COMMA));\r\n if (!tn.skip(Token.GREATERTHAN)) {\r\n if (!suppressErrors) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(tn.pos), \">\"\r\n );\r\n }\r\n return null;\r\n }\r\n }\r\n // ... | null\r\n while (tn.skip(Token.BAR)) {\r\n if (tn.skip(Token.NULL)) {\r\n nullable = true;\r\n } else {\r\n if (!suppressErrors) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(tn.pos), \"null\"\r\n );\r\n }\r\n return null;\r\n }\r\n }\r\n type = Node.createType(first, parameters || [], nullable, tn.range(startPos, tn.pos));\r\n } else {\r\n if (!suppressErrors) {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n // ... [][]\r\n while (tn.skip(Token.OPENBRACKET)) {\r\n let bracketStart = tn.tokenPos;\r\n if (!tn.skip(Token.CLOSEBRACKET)) {\r\n if (!suppressErrors) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"]\"\r\n );\r\n }\r\n return null;\r\n }\r\n let bracketRange = tn.range(bracketStart, tn.pos);\r\n\r\n // ...[] | null\r\n let nullable = false;\r\n if (tn.skip(Token.BAR)) {\r\n if (tn.skip(Token.NULL)) {\r\n nullable = true;\r\n } else {\r\n if (!suppressErrors) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"null\"\r\n );\r\n }\r\n return null;\r\n }\r\n }\r\n type = Node.createType(\r\n Node.createSimpleTypeName(\"Array\", bracketRange),\r\n [ type ],\r\n nullable,\r\n tn.range(startPos, tn.pos)\r\n );\r\n if (nullable) break;\r\n }\r\n\r\n return type;\r\n }\r\n\r\n // Indicates whether tryParseSignature determined that it is handling a Signature\r\n private tryParseSignatureIsSignature: bool = false;\r\n\r\n /** Parses a function signature, as used in type declarations. */\r\n tryParseSignature(\r\n tn: Tokenizer\r\n ): SignatureNode | null {\r\n\r\n // at '(': ('...'? Identifier '?'? ':' Type (',' '...'? Identifier '?'? ':' Type)* )? ')' '=>' Type\r\n\r\n var state = tn.mark();\r\n var startPos = tn.tokenPos;\r\n var parameters: ParameterNode[] | null = null;\r\n var thisType: TypeNode | null = null;\r\n var isSignature: bool = false;\r\n\r\n if (tn.skip(Token.CLOSEPAREN)) {\r\n isSignature = true;\r\n tn.discard(state);\r\n parameters = [];\r\n\r\n } else {\r\n isSignature = false; // not yet known\r\n do {\r\n let kind = ParameterKind.DEFAULT;\r\n if (tn.skip(Token.DOT_DOT_DOT)) {\r\n isSignature = true;\r\n tn.discard(state);\r\n kind = ParameterKind.REST;\r\n }\r\n if (tn.skip(Token.THIS)) {\r\n if (tn.skip(Token.COLON)) {\r\n isSignature = true;\r\n tn.discard(state);\r\n let t = this.parseType(tn, false);\r\n if (!t) return null;\r\n if (t.kind != NodeKind.TYPE) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n t.range\r\n );\r\n this.tryParseSignatureIsSignature = true;\r\n return null;\r\n }\r\n thisType = t;\r\n } else {\r\n tn.reset(state);\r\n this.tryParseSignatureIsSignature = false;\r\n return null;\r\n }\r\n } else if (tn.skipIdentifier()) {\r\n let name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range(tn.tokenPos, tn.pos));\r\n if (tn.skip(Token.QUESTION)) {\r\n isSignature = true;\r\n tn.discard(state);\r\n if (kind == ParameterKind.REST) {\r\n this.error(\r\n DiagnosticCode.A_rest_parameter_cannot_be_optional,\r\n tn.range()\r\n ); // recoverable\r\n } else {\r\n kind = ParameterKind.OPTIONAL;\r\n }\r\n }\r\n if (tn.skip(Token.COLON)) {\r\n isSignature = true;\r\n tn.discard(state);\r\n let type = this.parseType(tn); // not suppressing errors because known\r\n if (!type) {\r\n this.tryParseSignatureIsSignature = isSignature;\r\n return null;\r\n }\r\n let param = new ParameterNode();\r\n param.parameterKind = kind;\r\n param.name = name;\r\n param.type = type;\r\n if (!parameters) parameters = [ param ];\r\n else parameters.push(param);\r\n } else {\r\n if (isSignature) {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n tn.range()\r\n ); // recoverable\r\n }\r\n }\r\n } else {\r\n if (isSignature) {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n } else {\r\n tn.reset(state);\r\n }\r\n this.tryParseSignatureIsSignature = isSignature;\r\n return null;\r\n }\r\n } while (tn.skip(Token.COMMA));\r\n if (!tn.skip(Token.CLOSEPAREN)) {\r\n if (isSignature) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n } else {\r\n tn.reset(state);\r\n }\r\n this.tryParseSignatureIsSignature = isSignature;\r\n return null;\r\n }\r\n }\r\n\r\n var returnType: CommonTypeNode | null;\r\n if (tn.skip(Token.EQUALS_GREATERTHAN)) {\r\n isSignature = true;\r\n tn.discard(state);\r\n returnType = this.parseType(tn);\r\n if (!returnType) {\r\n this.tryParseSignatureIsSignature = isSignature;\r\n return null;\r\n }\r\n } else {\r\n if (isSignature) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"=>\"\r\n );\r\n } else {\r\n tn.reset(state);\r\n }\r\n this.tryParseSignatureIsSignature = isSignature;\r\n return null;\r\n }\r\n this.tryParseSignatureIsSignature = true;\r\n return Node.createSignature(\r\n parameters || [],\r\n returnType,\r\n thisType,\r\n false,\r\n tn.range(startPos, tn.pos)\r\n );\r\n }\r\n\r\n // statements\r\n\r\n parseDecorator(\r\n tn: Tokenizer\r\n ): DecoratorNode | null {\r\n\r\n // at '@': Identifier ('.' Identifier)* '(' Arguments\r\n\r\n var startPos = tn.tokenPos;\r\n if (tn.skipIdentifier()) {\r\n let name = tn.readIdentifier();\r\n let expression: Expression = Node.createIdentifierExpression(name, tn.range(startPos, tn.pos));\r\n while (tn.skip(Token.DOT)) {\r\n if (tn.skipIdentifier()) {\r\n name = tn.readIdentifier();\r\n expression = Node.createPropertyAccessExpression(\r\n expression,\r\n Node.createIdentifierExpression(name, tn.range()),\r\n tn.range(startPos, tn.pos)\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n }\r\n let args: Expression[] | null;\r\n if (tn.skip(Token.OPENPAREN)) {\r\n args = this.parseArguments(tn);\r\n if (args) {\r\n return Node.createDecorator(expression, args, tn.range(startPos, tn.pos));\r\n }\r\n } else {\r\n return Node.createDecorator(expression, null, tn.range(startPos, tn.pos));\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseVariable(\r\n tn: Tokenizer,\r\n flags: CommonFlags,\r\n decorators: DecoratorNode[] | null,\r\n startPos: i32\r\n ): VariableStatement | null {\r\n\r\n // at ('const' | 'let' | 'var'): VariableDeclaration (',' VariableDeclaration)* ';'?\r\n\r\n var members = new Array();\r\n do {\r\n let member = this.parseVariableDeclaration(tn, flags, decorators);\r\n if (!member) return null;\r\n members.push(member);\r\n } while (tn.skip(Token.COMMA));\r\n\r\n var ret = Node.createVariableStatement(members, decorators, tn.range(startPos, tn.pos));\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseVariableDeclaration(\r\n tn: Tokenizer,\r\n parentFlags: CommonFlags,\r\n parentDecorators: DecoratorNode[] | null\r\n ): VariableDeclaration | null {\r\n\r\n // before: Identifier (':' Type)? ('=' Expression)?\r\n\r\n if (!tn.skipIdentifier()) {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n var identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n var flags = parentFlags;\r\n if (tn.skip(Token.EXCLAMATION)) {\r\n flags |= CommonFlags.DEFINITE_ASSIGNMENT;\r\n }\r\n\r\n var type: CommonTypeNode | null = null;\r\n if (tn.skip(Token.COLON)) {\r\n type = this.parseType(tn);\r\n }\r\n\r\n var initializer: Expression | null = null;\r\n if (tn.skip(Token.EQUALS)) {\r\n if (flags & CommonFlags.AMBIENT) {\r\n this.error(\r\n DiagnosticCode.Initializers_are_not_allowed_in_ambient_contexts,\r\n tn.range()\r\n ); // recoverable\r\n }\r\n initializer = this.parseExpression(tn, Precedence.COMMA + 1);\r\n if (!initializer) return null;\r\n } else {\r\n if (flags & CommonFlags.CONST) {\r\n if (!(flags & CommonFlags.AMBIENT)) {\r\n this.error(\r\n DiagnosticCode._const_declarations_must_be_initialized,\r\n identifier.range\r\n ); // recoverable\r\n }\r\n } else if (!type) { // neither type nor initializer\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n tn.range(tn.pos)\r\n ); // recoverable\r\n }\r\n }\r\n var range = Range.join(identifier.range, tn.range());\r\n if ((flags & CommonFlags.DEFINITE_ASSIGNMENT) && initializer) {\r\n this.error(\r\n DiagnosticCode.A_definite_assignment_assertion_is_not_permitted_in_this_context,\r\n range);\r\n }\r\n return Node.createVariableDeclaration(\r\n identifier,\r\n type,\r\n initializer,\r\n parentDecorators,\r\n flags,\r\n range\r\n );\r\n }\r\n\r\n parseEnum(\r\n tn: Tokenizer,\r\n flags: CommonFlags,\r\n decorators: DecoratorNode[] | null,\r\n startPos: i32\r\n ): EnumDeclaration | null {\r\n\r\n // at 'enum': Identifier '{' (EnumValueDeclaration (',' EnumValueDeclaration )*)? '}' ';'?\r\n\r\n if (tn.next() != Token.IDENTIFIER) {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n var identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n if (tn.next() != Token.OPENBRACE) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"{\"\r\n );\r\n return null;\r\n }\r\n var members = new Array();\r\n while (!tn.skip(Token.CLOSEBRACE)) {\r\n let member = this.parseEnumValue(tn, CommonFlags.NONE);\r\n if (!member) return null;\r\n members.push(member);\r\n if (!tn.skip(Token.COMMA)) {\r\n if (tn.skip(Token.CLOSEBRACE)) {\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"}\"\r\n );\r\n return null;\r\n }\r\n }\r\n }\r\n var ret = Node.createEnumDeclaration(\r\n identifier,\r\n members,\r\n decorators,\r\n flags,\r\n tn.range(startPos, tn.pos)\r\n );\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseEnumValue(\r\n tn: Tokenizer,\r\n parentFlags: CommonFlags\r\n ): EnumValueDeclaration | null {\r\n\r\n // before: Identifier ('=' Expression)?\r\n\r\n if (!tn.skipIdentifier()) {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n var identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n var value: Expression | null = null;\r\n if (tn.skip(Token.EQUALS)) {\r\n value = this.parseExpression(tn, Precedence.COMMA + 1);\r\n if (!value) return null;\r\n }\r\n return Node.createEnumValueDeclaration(\r\n identifier,\r\n value,\r\n parentFlags,\r\n Range.join(identifier.range, tn.range())\r\n );\r\n }\r\n\r\n parseReturn(\r\n tn: Tokenizer\r\n ): ReturnStatement | null {\r\n\r\n // at 'return': Expression | (';' | '}' | ...'\\n')\r\n\r\n var expr: Expression | null = null;\r\n if (\r\n tn.peek(true) != Token.SEMICOLON &&\r\n tn.nextToken != Token.CLOSEBRACE &&\r\n !tn.nextTokenOnNewLine\r\n ) {\r\n if (!(expr = this.parseExpression(tn))) return null;\r\n }\r\n\r\n var ret = Node.createReturnStatement(expr, tn.range());\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseTypeParameters(\r\n tn: Tokenizer\r\n ): TypeParameterNode[] | null {\r\n\r\n // at '<': TypeParameter (',' TypeParameter)* '>'\r\n\r\n var typeParameters: TypeParameterNode[] | null = null;\r\n var seenOptional = false;\r\n while (!tn.skip(Token.GREATERTHAN)) {\r\n let typeParameter = this.parseTypeParameter(tn);\r\n if (!typeParameter) return null;\r\n if (typeParameter.defaultType !== null) {\r\n seenOptional = true;\r\n } else if (seenOptional) {\r\n this.error(\r\n DiagnosticCode.Required_type_parameters_may_not_follow_optional_type_parameters,\r\n typeParameter.range\r\n );\r\n typeParameter.defaultType = null;\r\n }\r\n if (!typeParameters) typeParameters = [ typeParameter ];\r\n else typeParameters.push(typeParameter);\r\n if (!tn.skip(Token.COMMA)) {\r\n if (tn.skip(Token.GREATERTHAN)) {\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \">\"\r\n );\r\n return null;\r\n }\r\n }\r\n }\r\n if (!(typeParameters && typeParameters.length)) {\r\n this.error(\r\n DiagnosticCode.Type_parameter_list_cannot_be_empty,\r\n tn.range()\r\n ); // recoverable\r\n }\r\n return typeParameters;\r\n }\r\n\r\n parseTypeParameter(\r\n tn: Tokenizer\r\n ): TypeParameterNode | null {\r\n\r\n // before: Identifier ('extends' Type)? ('=' Type)?\r\n\r\n if (tn.next() == Token.IDENTIFIER) {\r\n let identifier = Node.createIdentifierExpression(\r\n tn.readIdentifier(),\r\n tn.range()\r\n );\r\n let extendsType: TypeNode | null = null;\r\n if (tn.skip(Token.EXTENDS)) {\r\n let t = this.parseType(tn);\r\n if (!t) return null;\r\n if (t.kind != NodeKind.TYPE) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n t.range\r\n );\r\n return null;\r\n }\r\n extendsType = t;\r\n }\r\n let defaultType: TypeNode | null = null;\r\n if (tn.skip(Token.EQUALS)) {\r\n let t = this.parseType(tn);\r\n if (!t) return null;\r\n if (t.kind != NodeKind.TYPE) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n t.range\r\n );\r\n return null;\r\n }\r\n defaultType = t;\r\n }\r\n return Node.createTypeParameter(\r\n identifier,\r\n extendsType,\r\n defaultType,\r\n Range.join(identifier.range, tn.range())\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n private parseParametersThis: TypeNode | null = null;\r\n\r\n parseParameters(\r\n tn: Tokenizer,\r\n isConstructor: bool = false\r\n ): ParameterNode[] | null {\r\n\r\n // at '(': (Parameter (',' Parameter)*)? ')'\r\n\r\n var parameters = new Array();\r\n var seenRest: ParameterNode | null = null;\r\n var seenOptional = false;\r\n var reportedRest = false;\r\n var thisType: CommonTypeNode | null = null;\r\n\r\n // check if there is a leading `this` parameter\r\n this.parseParametersThis = null;\r\n if (tn.skip(Token.THIS)) {\r\n if (tn.skip(Token.COLON)) {\r\n thisType = this.parseType(tn); // reports\r\n if (!thisType) return null;\r\n if (thisType.kind == NodeKind.TYPE) {\r\n this.parseParametersThis = thisType;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n thisType.range\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \":\"\r\n );\r\n return null;\r\n }\r\n if (!tn.skip(Token.COMMA)) {\r\n if (tn.skip(Token.CLOSEPAREN)) {\r\n return parameters;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n return null;\r\n }\r\n }\r\n }\r\n\r\n while (!tn.skip(Token.CLOSEPAREN)) {\r\n let param = this.parseParameter(tn, isConstructor); // reports\r\n if (!param) return null;\r\n if (seenRest && !reportedRest) {\r\n this.error(\r\n DiagnosticCode.A_rest_parameter_must_be_last_in_a_parameter_list,\r\n seenRest.name.range\r\n );\r\n reportedRest = true;\r\n }\r\n switch (param.parameterKind) {\r\n default: {\r\n if (seenOptional) {\r\n this.error(\r\n DiagnosticCode.A_required_parameter_cannot_follow_an_optional_parameter,\r\n param.name.range\r\n );\r\n }\r\n break;\r\n }\r\n case ParameterKind.OPTIONAL: {\r\n seenOptional = true;\r\n break;\r\n }\r\n case ParameterKind.REST: {\r\n seenRest = param;\r\n break;\r\n }\r\n }\r\n parameters.push(param);\r\n if (!tn.skip(Token.COMMA)) {\r\n if (tn.skip(Token.CLOSEPAREN)) {\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n return null;\r\n }\r\n }\r\n }\r\n return parameters;\r\n }\r\n\r\n parseParameter(\r\n tn: Tokenizer,\r\n isConstructor: bool = false\r\n ): ParameterNode | null {\r\n\r\n // before: ('public' | 'private' | 'protected' | '...')? Identifier '?'? (':' Type)? ('=' Expression)?\r\n\r\n var isRest = false;\r\n var isOptional = false;\r\n var startRange: Range | null = null;\r\n var accessFlags: CommonFlags = CommonFlags.NONE;\r\n if (isConstructor) {\r\n if (tn.skip(Token.PUBLIC)) {\r\n startRange = tn.range();\r\n accessFlags |= CommonFlags.PUBLIC;\r\n } else if (tn.skip(Token.PROTECTED)) {\r\n startRange = tn.range();\r\n accessFlags |= CommonFlags.PROTECTED;\r\n } else if (tn.skip(Token.PRIVATE)) {\r\n startRange = tn.range();\r\n accessFlags |= CommonFlags.PRIVATE;\r\n }\r\n if (tn.peek() == Token.READONLY) {\r\n let state = tn.mark();\r\n tn.next();\r\n if (tn.peek() != Token.COLON) { // modifier\r\n tn.discard(state);\r\n if (!startRange) startRange = tn.range();\r\n accessFlags |= CommonFlags.READONLY;\r\n } else { // identifier\r\n tn.reset(state);\r\n }\r\n }\r\n }\r\n if (tn.skip(Token.DOT_DOT_DOT)) {\r\n if (accessFlags) {\r\n this.error(\r\n DiagnosticCode.A_parameter_property_cannot_be_declared_using_a_rest_parameter,\r\n tn.range()\r\n );\r\n } else {\r\n startRange = tn.range();\r\n }\r\n isRest = true;\r\n }\r\n if (tn.skipIdentifier()) {\r\n if (!isRest) startRange = tn.range();\r\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n let type: CommonTypeNode | null = null;\r\n if (isOptional = tn.skip(Token.QUESTION)) {\r\n if (isRest) {\r\n this.error(\r\n DiagnosticCode.A_rest_parameter_cannot_be_optional,\r\n identifier.range\r\n );\r\n }\r\n }\r\n if (tn.skip(Token.COLON)) {\r\n type = this.parseType(tn);\r\n if (!type) return null;\r\n } else {\r\n type = Node.createOmittedType(tn.range(tn.pos));\r\n }\r\n let initializer: Expression | null = null;\r\n if (tn.skip(Token.EQUALS)) {\r\n if (isRest) {\r\n this.error(\r\n DiagnosticCode.A_rest_parameter_cannot_have_an_initializer,\r\n identifier.range\r\n );\r\n }\r\n if (isOptional) {\r\n this.error(\r\n DiagnosticCode.Parameter_cannot_have_question_mark_and_initializer,\r\n identifier.range\r\n );\r\n } else {\r\n isOptional = true;\r\n }\r\n initializer = this.parseExpression(tn, Precedence.COMMA + 1);\r\n if (!initializer) return null;\r\n }\r\n let param = Node.createParameter(\r\n identifier,\r\n type,\r\n initializer,\r\n isRest\r\n ? ParameterKind.REST\r\n : isOptional\r\n ? ParameterKind.OPTIONAL\r\n : ParameterKind.DEFAULT,\r\n Range.join(startRange, tn.range())\r\n );\r\n param.flags |= accessFlags;\r\n return param;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseFunction(\r\n tn: Tokenizer,\r\n flags: CommonFlags,\r\n decorators: DecoratorNode[] | null,\r\n startPos: i32\r\n ): FunctionDeclaration | null {\r\n\r\n // at 'function':\r\n // Identifier\r\n // ('<' TypeParameters)?\r\n // '(' Parameters (':' Type)?\r\n // '{' Statement* '}'\r\n // ';'?\r\n\r\n if (!tn.skipIdentifier()) {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range(tn.pos)\r\n );\r\n return null;\r\n }\r\n\r\n var name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n var signatureStart: i32 = -1;\r\n\r\n var typeParameters: TypeParameterNode[] | null = null;\r\n if (tn.skip(Token.LESSTHAN)) {\r\n signatureStart = tn.tokenPos;\r\n typeParameters = this.parseTypeParameters(tn);\r\n if (!typeParameters) return null;\r\n flags |= CommonFlags.GENERIC;\r\n }\r\n\r\n if (!tn.skip(Token.OPENPAREN)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(tn.pos), \"(\"\r\n );\r\n return null;\r\n }\r\n\r\n if (signatureStart < 0) {\r\n signatureStart = tn.tokenPos;\r\n }\r\n\r\n var parameters = this.parseParameters(tn);\r\n if (!parameters) return null;\r\n var thisType = this.parseParametersThis;\r\n\r\n var isSetter = (flags & CommonFlags.SET) != 0;\r\n if (isSetter) {\r\n if (parameters.length != 1) {\r\n this.error(\r\n DiagnosticCode.A_set_accessor_must_have_exactly_one_parameter,\r\n name.range\r\n ); // recoverable\r\n }\r\n if (parameters.length && parameters[0].initializer) {\r\n this.error(\r\n DiagnosticCode.A_set_accessor_parameter_cannot_have_an_initializer,\r\n name.range\r\n ); // recoverable\r\n }\r\n }\r\n\r\n if (flags & CommonFlags.GET) {\r\n if (parameters.length) {\r\n this.error(\r\n DiagnosticCode.A_get_accessor_cannot_have_parameters,\r\n name.range\r\n ); // recoverable\r\n }\r\n }\r\n\r\n var returnType: CommonTypeNode | null = null;\r\n if (tn.skip(Token.COLON)) {\r\n returnType = this.parseType(tn, true, isSetter);\r\n if (!returnType) return null;\r\n }\r\n\r\n if (!returnType) {\r\n returnType = Node.createOmittedType(\r\n tn.range(tn.pos)\r\n );\r\n if (!isSetter) {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n returnType.range\r\n ); // recoverable\r\n }\r\n }\r\n\r\n var signature = Node.createSignature(\r\n parameters,\r\n returnType,\r\n thisType,\r\n false,\r\n tn.range(signatureStart, tn.pos)\r\n );\r\n\r\n var body: Statement | null = null;\r\n if (tn.skip(Token.OPENBRACE)) {\r\n if (flags & CommonFlags.AMBIENT) {\r\n this.error(\r\n DiagnosticCode.An_implementation_cannot_be_declared_in_ambient_contexts,\r\n tn.range()\r\n ); // recoverable\r\n }\r\n\r\n body = this.parseBlockStatement(tn, false);\r\n if (!body) return null;\r\n } else if (!(flags & CommonFlags.AMBIENT)) {\r\n this.error(\r\n DiagnosticCode.Function_implementation_is_missing_or_not_immediately_following_the_declaration,\r\n tn.range(tn.pos)\r\n );\r\n }\r\n\r\n var ret = Node.createFunctionDeclaration(\r\n name,\r\n typeParameters,\r\n signature,\r\n body,\r\n decorators,\r\n flags,\r\n ArrowKind.NONE,\r\n tn.range(startPos, tn.pos)\r\n );\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseFunctionExpression(tn: Tokenizer): FunctionExpression | null {\r\n var startPos = tn.tokenPos;\r\n var name: IdentifierExpression;\r\n var arrowKind = ArrowKind.NONE;\r\n\r\n // either at 'function':\r\n // Identifier?\r\n // '(' Parameters (':' Type)?\r\n // Statement\r\n\r\n if (tn.token == Token.FUNCTION) {\r\n if (tn.skipIdentifier()) {\r\n name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n } else { // empty name\r\n name = Node.createEmptyIdentifierExpression(tn.range(tn.pos));\r\n }\r\n if (!tn.skip(Token.OPENPAREN)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(tn.pos), \"(\"\r\n );\r\n return null;\r\n }\r\n\r\n // or at '(' of arrow function:\r\n // Parameters (':' Type)?\r\n // Statement\r\n\r\n } else {\r\n arrowKind = ArrowKind.ARROW_PARENTHESIZED;\r\n assert(tn.token == Token.OPENPAREN);\r\n name = Node.createEmptyIdentifierExpression(tn.range(tn.tokenPos));\r\n }\r\n\r\n // TODO: type parameters? doesn't seem worth it.\r\n\r\n var signatureStart = tn.pos;\r\n var parameters = this.parseParameters(tn);\r\n if (!parameters) return null;\r\n\r\n return this.parseFunctionExpressionCommon(tn, name, parameters, arrowKind, startPos, signatureStart);\r\n }\r\n\r\n private parseFunctionExpressionCommon(\r\n tn: Tokenizer,\r\n name: IdentifierExpression,\r\n parameters: ParameterNode[],\r\n arrowKind: ArrowKind,\r\n startPos: i32 = -1,\r\n signatureStart: i32 = -1\r\n ): FunctionExpression | null {\r\n if (startPos < 0) startPos = name.range.start;\r\n if (signatureStart < 0) signatureStart = startPos;\r\n\r\n var returnType: CommonTypeNode | null = null;\r\n if (arrowKind != ArrowKind.ARROW_SINGLE && tn.skip(Token.COLON)) {\r\n returnType = this.parseType(tn);\r\n if (!returnType) return null;\r\n } else {\r\n returnType = Node.createOmittedType(tn.range(tn.pos));\r\n }\r\n\r\n if (arrowKind) {\r\n if (!tn.skip(Token.EQUALS_GREATERTHAN)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(tn.pos), \"=>\"\r\n );\r\n return null;\r\n }\r\n }\r\n\r\n var signature = Node.createSignature(\r\n parameters,\r\n returnType,\r\n null, // TODO?\r\n false,\r\n tn.range(signatureStart, tn.pos)\r\n );\r\n\r\n var body: Statement | null = null;\r\n if (arrowKind) {\r\n if (tn.skip(Token.OPENBRACE)) {\r\n body = this.parseBlockStatement(tn, false);\r\n } else {\r\n let bodyExpression = this.parseExpression(tn, Precedence.COMMA + 1);\r\n if (bodyExpression) body = Node.createExpressionStatement(bodyExpression);\r\n }\r\n } else {\r\n if (!tn.skip(Token.OPENBRACE)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(tn.pos), \"{\"\r\n );\r\n return null;\r\n }\r\n body = this.parseBlockStatement(tn, false);\r\n }\r\n if (!body) return null;\r\n\r\n var declaration = Node.createFunctionDeclaration(\r\n name,\r\n null,\r\n signature,\r\n body,\r\n null,\r\n CommonFlags.NONE,\r\n arrowKind,\r\n tn.range(startPos, tn.pos)\r\n );\r\n return Node.createFunctionExpression(declaration);\r\n }\r\n\r\n parseClassOrInterface(\r\n tn: Tokenizer,\r\n flags: CommonFlags,\r\n decorators: DecoratorNode[] | null,\r\n startPos: i32\r\n ): ClassDeclaration | null {\r\n\r\n // at ('class' | 'interface'):\r\n // Identifier\r\n // ('<' TypeParameters)?\r\n // ('extends' Type)?\r\n // ('implements' Type (',' Type)*)?\r\n // '{' ClassMember* '}'\r\n\r\n var isInterface = tn.token == Token.INTERFACE;\r\n\r\n if (!tn.skipIdentifier()) {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n\r\n var identifier = Node.createIdentifierExpression(\r\n tn.readIdentifier(),\r\n tn.range()\r\n );\r\n\r\n var typeParameters: TypeParameterNode[] | null = null;\r\n if (tn.skip(Token.LESSTHAN)) {\r\n typeParameters = this.parseTypeParameters(tn);\r\n if (!typeParameters) return null;\r\n flags |= CommonFlags.GENERIC;\r\n }\r\n\r\n var extendsType: TypeNode | null = null;\r\n if (tn.skip(Token.EXTENDS)) {\r\n let t = this.parseType(tn);\r\n if (!t) return null;\r\n if (t.kind != NodeKind.TYPE) {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n t.range\r\n );\r\n return null;\r\n }\r\n extendsType = t;\r\n }\r\n\r\n var implementsTypes: TypeNode[] | null = null;\r\n if (tn.skip(Token.IMPLEMENTS)) {\r\n if (isInterface) {\r\n this.error(\r\n DiagnosticCode.Interface_declaration_cannot_have_implements_clause,\r\n tn.range()\r\n ); // recoverable\r\n }\r\n do {\r\n let type = this.parseType(tn);\r\n if (!type) return null;\r\n if (!isInterface) {\r\n if (!implementsTypes) implementsTypes = [type];\r\n else implementsTypes.push(type);\r\n }\r\n } while (tn.skip(Token.COMMA));\r\n }\r\n\r\n if (!tn.skip(Token.OPENBRACE)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"{\"\r\n );\r\n return null;\r\n }\r\n\r\n var members = new Array();\r\n var declaration: ClassDeclaration;\r\n if (isInterface) {\r\n assert(!implementsTypes);\r\n declaration = Node.createInterfaceDeclaration(\r\n identifier,\r\n typeParameters,\r\n extendsType,\r\n members,\r\n decorators,\r\n flags,\r\n tn.range(startPos, tn.pos)\r\n );\r\n } else {\r\n declaration = Node.createClassDeclaration(\r\n identifier,\r\n typeParameters,\r\n extendsType,\r\n implementsTypes,\r\n members,\r\n decorators,\r\n flags,\r\n tn.range(startPos, tn.pos)\r\n );\r\n }\r\n if (!tn.skip(Token.CLOSEBRACE)) {\r\n do {\r\n let member = this.parseClassMember(tn, declaration);\r\n if (member) members.push(member);\r\n else {\r\n this.skipStatement(tn);\r\n if (tn.skip(Token.ENDOFFILE)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"}\"\r\n );\r\n return null;\r\n }\r\n }\r\n } while (!tn.skip(Token.CLOSEBRACE));\r\n }\r\n declaration.range.end = tn.pos;\r\n return declaration;\r\n }\r\n\r\n parseClassExpression(tn: Tokenizer): ClassExpression | null {\r\n\r\n // at 'class': Identifier? '{' ... '}'\r\n\r\n var startPos = tn.tokenPos;\r\n var name: IdentifierExpression;\r\n\r\n if (tn.skipIdentifier()) {\r\n name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n } else {\r\n name = Node.createEmptyIdentifierExpression(tn.range(tn.pos));\r\n }\r\n\r\n if (!tn.skip(Token.OPENBRACE)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(tn.pos), \"{\"\r\n );\r\n return null;\r\n }\r\n\r\n var members = new Array();\r\n var declaration = Node.createClassDeclaration(\r\n name,\r\n [],\r\n null,\r\n null,\r\n members,\r\n null,\r\n CommonFlags.NONE,\r\n tn.range(startPos, tn.pos)\r\n );\r\n if (!tn.skip(Token.CLOSEBRACE)) {\r\n do {\r\n let member = this.parseClassMember(tn, declaration);\r\n if (member) members.push(member);\r\n else {\r\n this.skipStatement(tn);\r\n if (tn.skip(Token.ENDOFFILE)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"}\"\r\n );\r\n return null;\r\n }\r\n }\r\n } while (!tn.skip(Token.CLOSEBRACE));\r\n }\r\n declaration.range.end = tn.pos;\r\n return Node.createClassExpression(declaration);\r\n }\r\n\r\n parseClassMember(\r\n tn: Tokenizer,\r\n parent: ClassDeclaration\r\n ): DeclarationStatement | null {\r\n\r\n // before:\r\n // ('public' | 'private' | 'protected')?\r\n // ('static' | 'abstract')?\r\n // 'readonly'?\r\n // ('get' | 'set')?\r\n // Identifier ...\r\n\r\n var startPos = tn.pos;\r\n var isInterface = parent.kind == NodeKind.INTERFACEDECLARATION;\r\n\r\n var decorators: DecoratorNode[] | null = null;\r\n if (tn.skip(Token.AT)) {\r\n do {\r\n let decorator = this.parseDecorator(tn);\r\n if (!decorator) break;\r\n if (!decorators) decorators = [decorator];\r\n else decorators.push(decorator);\r\n } while (tn.skip(Token.AT));\r\n if (decorators && isInterface) {\r\n this.error(\r\n DiagnosticCode.Decorators_are_not_valid_here,\r\n Range.join(decorators[0].range, decorators[decorators.length - 1].range)\r\n );\r\n }\r\n }\r\n\r\n // inherit ambient status\r\n var flags = parent.flags & CommonFlags.AMBIENT;\r\n\r\n // implemented methods are virtual\r\n if (isInterface) flags |= CommonFlags.VIRTUAL;\r\n\r\n var accessStart = 0;\r\n var accessEnd = 0;\r\n if (tn.skip(Token.PUBLIC)) {\r\n if (isInterface) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(), \"public\"\r\n );\r\n }\r\n flags |= CommonFlags.PUBLIC;\r\n accessStart = tn.tokenPos;\r\n accessEnd = tn.pos;\r\n } else if (tn.skip(Token.PRIVATE)) {\r\n if (isInterface) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(), \"private\"\r\n );\r\n }\r\n flags |= CommonFlags.PRIVATE;\r\n accessStart = tn.tokenPos;\r\n accessEnd = tn.pos;\r\n } else if (tn.skip(Token.PROTECTED)) {\r\n if (isInterface) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(), \"protected\"\r\n );\r\n }\r\n flags |= CommonFlags.PROTECTED;\r\n accessStart = tn.tokenPos;\r\n accessEnd = tn.pos;\r\n }\r\n\r\n var staticStart = 0;\r\n var staticEnd = 0;\r\n var abstractStart = 0;\r\n var abstractEnd = 0;\r\n if (tn.skip(Token.STATIC)) {\r\n if (isInterface) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(), \"static\"\r\n );\r\n }\r\n flags |= CommonFlags.STATIC;\r\n staticStart = tn.tokenPos;\r\n staticEnd = tn.pos;\r\n } else {\r\n flags |= CommonFlags.INSTANCE;\r\n if (tn.skip(Token.ABSTRACT)) {\r\n if (isInterface) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(), \"abstract\"\r\n );\r\n }\r\n flags |= CommonFlags.ABSTRACT;\r\n abstractStart = tn.tokenPos;\r\n abstractEnd = tn.pos;\r\n }\r\n if (parent.flags & CommonFlags.GENERIC) flags |= CommonFlags.GENERIC_CONTEXT;\r\n }\r\n\r\n var readonlyStart: i32 = 0;\r\n var readonlyEnd: i32 = 0;\r\n if (tn.skip(Token.READONLY)) {\r\n flags |= CommonFlags.READONLY;\r\n readonlyStart = tn.tokenPos;\r\n readonlyEnd = tn.pos;\r\n }\r\n\r\n // check if accessor: ('get' | 'set') ^\\n Identifier\r\n var state = tn.mark();\r\n var isConstructor = false;\r\n var isGetter = false;\r\n var getStart: i32 = 0;\r\n var getEnd: i32 = 0;\r\n var isSetter = false;\r\n var setStart: i32 = 0;\r\n var setEnd: i32 = 0;\r\n if (!isInterface) {\r\n if (tn.skip(Token.GET)) {\r\n if (tn.peek(true, IdentifierHandling.PREFER) == Token.IDENTIFIER && !tn.nextTokenOnNewLine) {\r\n flags |= CommonFlags.GET;\r\n isGetter = true;\r\n setStart = tn.tokenPos;\r\n setEnd = tn.pos;\r\n if (flags & CommonFlags.READONLY) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(readonlyStart, readonlyEnd), \"readonly\"\r\n ); // recoverable\r\n }\r\n } else {\r\n tn.reset(state);\r\n }\r\n } else if (tn.skip(Token.SET)) {\r\n if (tn.peek(true, IdentifierHandling.PREFER) == Token.IDENTIFIER && !tn.nextTokenOnNewLine) {\r\n flags |= CommonFlags.SET;\r\n isSetter = true;\r\n setStart = tn.tokenPos;\r\n setEnd = tn.pos;\r\n if (flags & CommonFlags.READONLY) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(readonlyStart, readonlyEnd), \"readonly\"\r\n ); // recoverable\r\n }\r\n } else {\r\n tn.reset(state);\r\n }\r\n } else if (tn.skip(Token.CONSTRUCTOR)) {\r\n flags |= CommonFlags.CONSTRUCTOR;\r\n isConstructor = true;\r\n if (flags & CommonFlags.STATIC) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(staticStart, staticEnd), \"static\"\r\n ); // recoverable\r\n }\r\n if (flags & CommonFlags.ABSTRACT) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(abstractStart, abstractEnd), \"abstract\"\r\n ); // recoverable\r\n }\r\n if (flags & CommonFlags.READONLY) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(readonlyStart, readonlyEnd), \"readonly\"\r\n ); // recoverable\r\n }\r\n }\r\n }\r\n\r\n var name: IdentifierExpression;\r\n if (isConstructor) {\r\n name = Node.createConstructorExpression(tn.range());\r\n } else {\r\n if (!(isGetter || isSetter) && tn.skip(Token.OPENBRACKET)) {\r\n // TODO: also handle symbols, which might have some of these modifiers\r\n if (flags & CommonFlags.PUBLIC) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(accessStart, accessEnd), \"public\"\r\n ); // recoverable\r\n } else if (flags & CommonFlags.PROTECTED) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(accessStart, accessEnd), \"protected\"\r\n ); // recoverable\r\n } else if (flags & CommonFlags.PRIVATE) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(accessStart, accessEnd), \"protected\"\r\n ); // recoverable\r\n }\r\n if (flags & CommonFlags.STATIC) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(staticStart, staticEnd), \"static\"\r\n ); // recoverable\r\n }\r\n if (flags & CommonFlags.ABSTRACT) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(abstractStart, abstractEnd), \"abstract\"\r\n ); // recoverable\r\n }\r\n if (flags & CommonFlags.READONLY) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(readonlyStart, readonlyEnd), \"readonly\"\r\n ); // recoverable\r\n }\r\n let retIndex = this.parseIndexSignatureDeclaration(tn, decorators);\r\n if (!retIndex) return null;\r\n tn.skip(Token.SEMICOLON);\r\n return retIndex;\r\n }\r\n if (!tn.skipIdentifier()) {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n }\r\n var typeParameters: TypeParameterNode[] | null = null;\r\n if (tn.skip(Token.LESSTHAN)) {\r\n let typeParametersStart = tn.tokenPos;\r\n typeParameters = this.parseTypeParameters(tn);\r\n if (!typeParameters) return null;\r\n if (isConstructor) {\r\n this.error(\r\n DiagnosticCode.Type_parameters_cannot_appear_on_a_constructor_declaration,\r\n tn.range(typeParametersStart, tn.pos)\r\n ); // recoverable\r\n } else if (isGetter || isSetter) {\r\n this.error(\r\n DiagnosticCode.An_accessor_cannot_have_type_parameters,\r\n tn.range(typeParametersStart, tn.pos)\r\n ); // recoverable\r\n } else {\r\n flags |= CommonFlags.GENERIC;\r\n }\r\n }\r\n\r\n // method: '(' Parameters (':' Type)? '{' Statement* '}' ';'?\r\n if (tn.skip(Token.OPENPAREN)) {\r\n let signatureStart = tn.tokenPos;\r\n let parameters = this.parseParameters(tn, isConstructor);\r\n if (!parameters) return null;\r\n let thisType = this.parseParametersThis;\r\n if (isConstructor) {\r\n for (let i = 0, k = parameters.length; i < k; ++i) {\r\n let parameter = parameters[i];\r\n if (parameter.isAny(\r\n CommonFlags.PUBLIC |\r\n CommonFlags.PROTECTED |\r\n CommonFlags.PRIVATE |\r\n CommonFlags.READONLY\r\n )) {\r\n let implicitFieldDeclaration = Node.createFieldDeclaration(\r\n parameter.name,\r\n parameter.type,\r\n null, // initialized via parameter\r\n null,\r\n parameter.flags | CommonFlags.INSTANCE,\r\n parameter.range\r\n );\r\n implicitFieldDeclaration.parameterIndex = i;\r\n parameter.implicitFieldDeclaration = implicitFieldDeclaration;\r\n parent.members.push(implicitFieldDeclaration);\r\n }\r\n }\r\n } else if (isGetter) {\r\n if (parameters.length) {\r\n this.error(\r\n DiagnosticCode.A_get_accessor_cannot_have_parameters,\r\n name.range\r\n );\r\n }\r\n } else if (isSetter) {\r\n if (parameters.length != 1) {\r\n this.error(\r\n DiagnosticCode.A_set_accessor_must_have_exactly_one_parameter,\r\n name.range\r\n );\r\n }\r\n if (parameters.length && parameters[0].initializer) {\r\n this.error(\r\n DiagnosticCode.A_set_accessor_parameter_cannot_have_an_initializer,\r\n name.range\r\n );\r\n }\r\n }\r\n\r\n let returnType: CommonTypeNode | null = null;\r\n if (tn.skip(Token.COLON)) {\r\n if (name.kind == NodeKind.CONSTRUCTOR) {\r\n this.error(\r\n DiagnosticCode.Type_annotation_cannot_appear_on_a_constructor_declaration,\r\n tn.range()\r\n );\r\n } else if (isSetter) {\r\n this.error(\r\n DiagnosticCode.A_set_accessor_cannot_have_a_return_type_annotation,\r\n tn.range()\r\n );\r\n }\r\n returnType = this.parseType(tn, name.kind == NodeKind.CONSTRUCTOR || isSetter);\r\n if (!returnType) return null;\r\n } else {\r\n returnType = Node.createOmittedType(tn.range(tn.pos));\r\n if (!isSetter && name.kind != NodeKind.CONSTRUCTOR) {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n returnType.range\r\n ); // recoverable\r\n }\r\n }\r\n\r\n let signature = Node.createSignature(\r\n parameters,\r\n returnType,\r\n thisType,\r\n false,\r\n tn.range(signatureStart, tn.pos)\r\n );\r\n\r\n let body: Statement | null = null;\r\n if (tn.skip(Token.OPENBRACE)) {\r\n if (flags & CommonFlags.AMBIENT) {\r\n this.error(\r\n DiagnosticCode.An_implementation_cannot_be_declared_in_ambient_contexts,\r\n tn.range()\r\n ); // recoverable\r\n } else if (flags & CommonFlags.ABSTRACT) {\r\n this.error(\r\n DiagnosticCode.Method_0_cannot_have_an_implementation_because_it_is_marked_abstract,\r\n tn.range(), name.text\r\n ); // recoverable\r\n }\r\n body = this.parseBlockStatement(tn, false);\r\n if (!body) return null;\r\n } else if (!(flags & CommonFlags.AMBIENT) && !isInterface) {\r\n this.error(\r\n DiagnosticCode.Function_implementation_is_missing_or_not_immediately_following_the_declaration,\r\n tn.range()\r\n ); // recoverable\r\n }\r\n\r\n let retMethod = Node.createMethodDeclaration(\r\n name,\r\n typeParameters,\r\n signature,\r\n body,\r\n decorators,\r\n flags,\r\n tn.range(startPos, tn.pos)\r\n );\r\n tn.skip(Token.SEMICOLON);\r\n return retMethod;\r\n\r\n } else if (isConstructor) {\r\n this.error(\r\n DiagnosticCode.Constructor_implementation_is_missing,\r\n name.range\r\n );\r\n\r\n } else if (isGetter || isSetter) {\r\n this.error(\r\n DiagnosticCode.Function_implementation_is_missing_or_not_immediately_following_the_declaration,\r\n name.range\r\n );\r\n\r\n // field: (':' Type)? ('=' Expression)? ';'?\r\n } else {\r\n if (flags & CommonFlags.ABSTRACT) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(abstractStart, abstractEnd), \"abstract\"\r\n ); // recoverable\r\n }\r\n\r\n if (flags & CommonFlags.GET) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(getStart, getEnd), \"get\"\r\n ); // recoverable\r\n }\r\n\r\n if (flags & CommonFlags.SET) {\r\n this.error(\r\n DiagnosticCode._0_modifier_cannot_be_used_here,\r\n tn.range(setStart, setEnd), \"set\"\r\n ); // recoverable\r\n }\r\n\r\n let type: CommonTypeNode | null = null;\r\n if (tn.skip(Token.QUESTION)) {\r\n this.error(\r\n DiagnosticCode.Optional_properties_are_not_supported,\r\n tn.range(startPos, tn.pos)\r\n );\r\n }\r\n if (tn.skip(Token.EXCLAMATION)) {\r\n flags |= CommonFlags.DEFINITE_ASSIGNMENT;\r\n }\r\n if (tn.skip(Token.COLON)) {\r\n type = this.parseType(tn);\r\n if (!type) return null;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n tn.range()\r\n ); // recoverable\r\n }\r\n let initializer: Expression | null = null;\r\n if (tn.skip(Token.EQUALS)) {\r\n initializer = this.parseExpression(tn);\r\n if (!initializer) return null;\r\n }\r\n let range = tn.range(startPos, tn.pos);\r\n if ((flags & CommonFlags.DEFINITE_ASSIGNMENT) && ((flags & CommonFlags.STATIC) || isInterface || initializer)) {\r\n this.error(\r\n DiagnosticCode.A_definite_assignment_assertion_is_not_permitted_in_this_context,\r\n range\r\n );\r\n }\r\n let retField = Node.createFieldDeclaration(\r\n name,\r\n type,\r\n initializer,\r\n decorators,\r\n flags,\r\n range\r\n );\r\n tn.skip(Token.SEMICOLON);\r\n return retField;\r\n }\r\n return null;\r\n }\r\n\r\n parseIndexSignatureDeclaration(tn: Tokenizer, decorators: DecoratorNode[] | null): IndexSignatureDeclaration | null {\r\n\r\n // at: '[': 'key' ':' Type ']' ':' Type\r\n\r\n if (decorators && decorators.length) {\r\n this.error(\r\n DiagnosticCode.Decorators_are_not_valid_here,\r\n Range.join(decorators[0].range, decorators[decorators.length - 1].range)\r\n ); // recoverable\r\n }\r\n\r\n var start = tn.tokenPos;\r\n if (tn.skipIdentifier()) {\r\n let id = tn.readIdentifier();\r\n if (id == \"key\") {\r\n if (tn.skip(Token.COLON)) {\r\n let keyType = this.parseType(tn);\r\n if (!keyType) return null;\r\n if (keyType.kind != NodeKind.TYPE) {\r\n this.error(\r\n DiagnosticCode.Type_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n if (tn.skip(Token.CLOSEBRACKET)) {\r\n if (tn.skip(Token.COLON)) {\r\n let valueType = this.parseType(tn);\r\n if (!valueType) return null;\r\n return Node.createIndexSignatureDeclaration(keyType, valueType, tn.range(start, tn.pos));\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \":\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"]\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \":\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"key\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseNamespace(\r\n tn: Tokenizer,\r\n flags: CommonFlags,\r\n decorators: DecoratorNode[] | null,\r\n startPos: i32\r\n ): NamespaceDeclaration | null {\r\n\r\n // at 'namespace': Identifier '{' (Variable | Function)* '}'\r\n\r\n if (tn.skipIdentifier()) {\r\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n if (tn.skip(Token.OPENBRACE)) {\r\n let members = new Array();\r\n let declaration = Node.createNamespaceDeclaration(\r\n identifier,\r\n members,\r\n decorators,\r\n flags,\r\n tn.range(startPos, tn.pos)\r\n );\r\n while (!tn.skip(Token.CLOSEBRACE)) {\r\n let member = this.parseTopLevelStatement(tn, declaration);\r\n if (member) members.push(member);\r\n else {\r\n this.skipStatement(tn);\r\n if (tn.skip(Token.ENDOFFILE)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"}\"\r\n );\r\n return null;\r\n }\r\n }\r\n }\r\n declaration.range.end = tn.pos;\r\n tn.skip(Token.SEMICOLON);\r\n return declaration;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"{\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseExport(\r\n tn: Tokenizer,\r\n startPos: i32,\r\n isDeclare: bool\r\n ): ExportStatement | null {\r\n\r\n // at 'export': '{' ExportMember (',' ExportMember)* }' ('from' StringLiteral)? ';'?\r\n\r\n var path: StringLiteralExpression | null = null;\r\n if (tn.skip(Token.OPENBRACE)) {\r\n let members = new Array();\r\n while (!tn.skip(Token.CLOSEBRACE)) {\r\n let member = this.parseExportMember(tn);\r\n if (!member) return null;\r\n members.push(member);\r\n if (!tn.skip(Token.COMMA)) {\r\n if (tn.skip(Token.CLOSEBRACE)) {\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"}\"\r\n );\r\n return null;\r\n }\r\n }\r\n }\r\n if (tn.skip(Token.FROM)) {\r\n if (tn.skip(Token.STRINGLITERAL)) {\r\n path = Node.createStringLiteralExpression(tn.readString(), tn.range());\r\n } else {\r\n this.error(\r\n DiagnosticCode.String_literal_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n }\r\n let ret = Node.createExportStatement(members, path, isDeclare, tn.range(startPos, tn.pos));\r\n let internalPath = ret.internalPath;\r\n if (internalPath !== null && !this.seenlog.has(internalPath)) {\r\n this.backlog.push(internalPath);\r\n this.seenlog.add(internalPath);\r\n }\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n } else if (tn.skip(Token.ASTERISK)) {\r\n if (tn.skip(Token.FROM)) {\r\n if (tn.skip(Token.STRINGLITERAL)) {\r\n path = Node.createStringLiteralExpression(tn.readString(), tn.range());\r\n let ret = Node.createExportStatement(null, path, isDeclare, tn.range(startPos, tn.pos));\r\n let internalPath = assert(ret.internalPath);\r\n let source = tn.source;\r\n if (!source.exportPaths) source.exportPaths = new Set();\r\n source.exportPaths.add(internalPath);\r\n if (!this.seenlog.has(internalPath)) {\r\n this.backlog.push(internalPath);\r\n this.seenlog.add(internalPath);\r\n }\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n } else {\r\n this.error(\r\n DiagnosticCode.String_literal_expected,\r\n tn.range()\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"from\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"{\"\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseExportMember(\r\n tn: Tokenizer\r\n ): ExportMember | null {\r\n\r\n // before: Identifier ('as' Identifier)?\r\n\r\n if (tn.skipIdentifier()) {\r\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n let asIdentifier: IdentifierExpression | null = null;\r\n if (tn.skip(Token.AS)) {\r\n if (tn.skipIdentifier(IdentifierHandling.ALWAYS)) {\r\n asIdentifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n }\r\n return Node.createExportMember(\r\n identifier,\r\n asIdentifier,\r\n asIdentifier\r\n ? Range.join(identifier.range, asIdentifier.range)\r\n : identifier.range\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseExportDefaultAlias(\r\n tn: Tokenizer,\r\n startPos: i32,\r\n defaultStart: i32,\r\n defaultEnd: i32\r\n ): ExportStatement {\r\n\r\n // at 'export' 'default': [Known-To-Be-]Identifier\r\n\r\n var name = tn.readIdentifier();\r\n var range = tn.range();\r\n var ret = Node.createExportStatement([\r\n Node.createExportMember(\r\n Node.createIdentifierExpression(name, range),\r\n Node.createIdentifierExpression(\"default\", tn.range(defaultStart, defaultEnd)),\r\n range\r\n )\r\n ], null, false, tn.range(startPos, tn.pos));\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseImport(\r\n tn: Tokenizer\r\n ): ImportStatement | null {\r\n\r\n // at 'import':\r\n // ('{' (ImportMember (',' ImportMember)* '}') | ('*' 'as' Identifier)?\r\n // 'from' StringLiteral ';'?\r\n\r\n var startPos = tn.tokenPos;\r\n var members: ImportDeclaration[] | null = null;\r\n var namespaceName: IdentifierExpression | null = null;\r\n var skipFrom = false;\r\n if (tn.skip(Token.OPENBRACE)) { // import { ... } from \"file\"\r\n members = new Array();\r\n while (!tn.skip(Token.CLOSEBRACE)) {\r\n let member = this.parseImportDeclaration(tn);\r\n if (!member) return null;\r\n members.push(member);\r\n if (!tn.skip(Token.COMMA)) {\r\n if (tn.skip(Token.CLOSEBRACE)) {\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"}\"\r\n );\r\n return null;\r\n }\r\n }\r\n }\r\n } else if (tn.skip(Token.ASTERISK)) { // import * from \"file\"\r\n if (tn.skip(Token.AS)) {\r\n if (tn.skipIdentifier()) {\r\n namespaceName = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"as\"\r\n );\r\n return null;\r\n }\r\n } else if (tn.skip(Token.IDENTIFIER, IdentifierHandling.PREFER)) { // import Name from \"file\"\r\n let name = tn.readIdentifier();\r\n let range = tn.range();\r\n members = [\r\n Node.createImportDeclaration(\r\n Node.createIdentifierExpression(\"default\", range),\r\n Node.createIdentifierExpression(name, range),\r\n range\r\n )\r\n ];\r\n if (tn.skip(Token.COMMA)) {\r\n // TODO: default + star, default + members\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n } else { // import \"file\"\r\n skipFrom = true;\r\n }\r\n\r\n if (skipFrom || tn.skip(Token.FROM)) {\r\n if (tn.skip(Token.STRINGLITERAL)) {\r\n let path = Node.createStringLiteralExpression(tn.readString(), tn.range());\r\n let ret: ImportStatement;\r\n if (namespaceName) {\r\n assert(!members);\r\n ret = Node.createImportStatementWithWildcard(namespaceName, path, tn.range(startPos, tn.pos));\r\n } else {\r\n ret = Node.createImportStatement(members, path, tn.range(startPos, tn.pos));\r\n }\r\n let internalPath = ret.internalPath;\r\n if (!this.seenlog.has(internalPath)) {\r\n this.backlog.push(internalPath);\r\n this.seenlog.add(internalPath);\r\n }\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n } else {\r\n this.error(\r\n DiagnosticCode.String_literal_expected,\r\n tn.range()\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"from\"\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseImportDeclaration(\r\n tn: Tokenizer\r\n ): ImportDeclaration | null {\r\n\r\n // before: Identifier ('as' Identifier)?\r\n\r\n if (tn.skipIdentifier(IdentifierHandling.ALWAYS)) {\r\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n let asIdentifier: IdentifierExpression | null = null;\r\n if (tn.skip(Token.AS)) {\r\n if (tn.skipIdentifier()) {\r\n asIdentifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n }\r\n return Node.createImportDeclaration(\r\n identifier,\r\n asIdentifier,\r\n asIdentifier\r\n ? Range.join(identifier.range, asIdentifier.range)\r\n : identifier.range\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseExportImport(\r\n tn: Tokenizer,\r\n startPos: i32\r\n ): ExportImportStatement | null {\r\n\r\n // at 'export' 'import': Identifier ('=' Identifier)? ';'?\r\n\r\n if (tn.skipIdentifier()) {\r\n let asIdentifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n if (tn.skip(Token.EQUALS)) {\r\n if (tn.skipIdentifier()) {\r\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n let ret = Node.createExportImportStatement(identifier, asIdentifier, tn.range(startPos, tn.pos));\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"=\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseStatement(\r\n tn: Tokenizer,\r\n topLevel: bool = false\r\n ): Statement | null {\r\n\r\n // at previous token\r\n\r\n var state = tn.mark();\r\n var token = tn.next();\r\n var statement: Statement | null = null;\r\n switch (token) {\r\n case Token.BREAK: {\r\n statement = this.parseBreak(tn);\r\n break;\r\n }\r\n case Token.CONST: {\r\n statement = this.parseVariable(tn, CommonFlags.CONST, null, tn.tokenPos);\r\n break;\r\n }\r\n case Token.CONTINUE: {\r\n statement = this.parseContinue(tn);\r\n break;\r\n }\r\n case Token.DO: {\r\n statement = this.parseDoStatement(tn);\r\n break;\r\n }\r\n case Token.FOR: {\r\n statement = this.parseForStatement(tn);\r\n break;\r\n }\r\n case Token.IF: {\r\n statement = this.parseIfStatement(tn);\r\n break;\r\n }\r\n case Token.LET: {\r\n statement = this.parseVariable(tn, CommonFlags.LET, null, tn.tokenPos);\r\n break;\r\n }\r\n case Token.VAR: {\r\n statement = this.parseVariable(tn, CommonFlags.NONE, null, tn.tokenPos);\r\n break;\r\n }\r\n case Token.OPENBRACE: {\r\n statement = this.parseBlockStatement(tn, topLevel);\r\n break;\r\n }\r\n case Token.RETURN: {\r\n if (topLevel) {\r\n this.error(\r\n DiagnosticCode.A_return_statement_can_only_be_used_within_a_function_body,\r\n tn.range()\r\n ); // recoverable\r\n }\r\n statement = this.parseReturn(tn);\r\n break;\r\n }\r\n case Token.SEMICOLON: {\r\n return Node.createEmptyStatement(tn.range(tn.tokenPos));\r\n }\r\n case Token.SWITCH: {\r\n statement = this.parseSwitchStatement(tn);\r\n break;\r\n }\r\n case Token.THROW: {\r\n statement = this.parseThrowStatement(tn);\r\n break;\r\n }\r\n case Token.TRY: {\r\n statement = this.parseTryStatement(tn);\r\n break;\r\n }\r\n case Token.VOID: {\r\n statement = this.parseVoidStatement(tn);\r\n break;\r\n }\r\n case Token.WHILE: {\r\n statement = this.parseWhileStatement(tn);\r\n break;\r\n }\r\n case Token.TYPE: { // also identifier\r\n if (tn.peek(false, IdentifierHandling.PREFER) == Token.IDENTIFIER) {\r\n statement = this.parseTypeDeclaration(tn, CommonFlags.NONE, null, tn.tokenPos);\r\n break;\r\n }\r\n // fall-through\r\n }\r\n default: {\r\n tn.reset(state);\r\n statement = this.parseExpressionStatement(tn);\r\n break;\r\n }\r\n }\r\n if (!statement) { // has been reported\r\n tn.reset(state);\r\n this.skipStatement(tn);\r\n } else {\r\n tn.discard(state);\r\n }\r\n return statement;\r\n }\r\n\r\n parseBlockStatement(\r\n tn: Tokenizer,\r\n topLevel: bool\r\n ): BlockStatement | null {\r\n\r\n // at '{': Statement* '}' ';'?\r\n\r\n var startPos = tn.tokenPos;\r\n var statements = new Array();\r\n while (!tn.skip(Token.CLOSEBRACE)) {\r\n let state = tn.mark();\r\n let statement = this.parseStatement(tn, topLevel);\r\n if (!statement) {\r\n if (tn.token == Token.ENDOFFILE) return null;\r\n tn.reset(state);\r\n this.skipStatement(tn);\r\n } else {\r\n tn.discard(state);\r\n statements.push(statement);\r\n }\r\n }\r\n var ret = Node.createBlockStatement(statements, tn.range(startPos, tn.pos));\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseBreak(\r\n tn: Tokenizer\r\n ): BreakStatement | null {\r\n\r\n // at 'break': Identifier? ';'?\r\n\r\n var identifier: IdentifierExpression | null = null;\r\n if (tn.peek(true) == Token.IDENTIFIER && !tn.nextTokenOnNewLine) {\r\n tn.next(IdentifierHandling.PREFER);\r\n identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n }\r\n var ret = Node.createBreakStatement(identifier, tn.range());\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseContinue(\r\n tn: Tokenizer\r\n ): ContinueStatement | null {\r\n\r\n // at 'continue': Identifier? ';'?\r\n\r\n var identifier: IdentifierExpression | null = null;\r\n if (tn.peek(true) == Token.IDENTIFIER && !tn.nextTokenOnNewLine) {\r\n tn.next(IdentifierHandling.PREFER);\r\n identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n }\r\n var ret = Node.createContinueStatement(identifier, tn.range());\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseDoStatement(\r\n tn: Tokenizer\r\n ): DoStatement | null {\r\n\r\n // at 'do': Statement 'while' '(' Expression ')' ';'?\r\n\r\n var startPos = tn.tokenPos;\r\n var statement = this.parseStatement(tn);\r\n if (!statement) return null;\r\n\r\n if (tn.skip(Token.WHILE)) {\r\n\r\n if (tn.skip(Token.OPENPAREN)) {\r\n let condition = this.parseExpression(tn);\r\n if (!condition) return null;\r\n\r\n if (tn.skip(Token.CLOSEPAREN)) {\r\n let ret = Node.createDoStatement(statement, condition, tn.range(startPos, tn.pos));\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"(\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"while\"\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseExpressionStatement(\r\n tn: Tokenizer\r\n ): ExpressionStatement | null {\r\n\r\n // at previous token\r\n\r\n var expr = this.parseExpression(tn);\r\n if (!expr) return null;\r\n\r\n var ret = Node.createExpressionStatement(expr);\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseForStatement(\r\n tn: Tokenizer\r\n ): ForStatement | null {\r\n\r\n // at 'for': '(' Statement? Expression? ';' Expression? ')' Statement\r\n\r\n var startPos = tn.tokenPos;\r\n\r\n if (tn.skip(Token.OPENPAREN)) {\r\n let initializer: Statement | null = null;\r\n\r\n if (tn.skip(Token.CONST)) {\r\n initializer = this.parseVariable(tn, CommonFlags.CONST, null, tn.tokenPos);\r\n } else if (tn.skip(Token.LET)) {\r\n initializer = this.parseVariable(tn, CommonFlags.LET, null, tn.tokenPos);\r\n } else if (tn.skip(Token.VAR)) {\r\n initializer = this.parseVariable(tn, CommonFlags.NONE, null, tn.tokenPos);\r\n\r\n } else if (!tn.skip(Token.SEMICOLON)) {\r\n initializer = this.parseExpressionStatement(tn);\r\n if (!initializer) return null;\r\n }\r\n\r\n if (tn.token == Token.SEMICOLON) {\r\n let condition: ExpressionStatement | null = null;\r\n if (!tn.skip(Token.SEMICOLON)) {\r\n condition = this.parseExpressionStatement(tn);\r\n if (!condition) return null;\r\n }\r\n\r\n if (tn.token == Token.SEMICOLON) {\r\n let incrementor: Expression | null = null;\r\n if (!tn.skip(Token.CLOSEPAREN)) {\r\n incrementor = this.parseExpression(tn);\r\n if (!incrementor) return null;\r\n\r\n if (!tn.skip(Token.CLOSEPAREN)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n return null;\r\n }\r\n }\r\n\r\n let statement = this.parseStatement(tn);\r\n if (!statement) return null;\r\n\r\n return Node.createForStatement(\r\n initializer,\r\n condition\r\n ? condition.expression\r\n : null,\r\n incrementor,\r\n statement,\r\n tn.range(startPos, tn.pos)\r\n );\r\n\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \";\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \";\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"(\"\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseIfStatement(\r\n tn: Tokenizer\r\n ): IfStatement | null {\r\n\r\n // at 'if': '(' Expression ')' Statement ('else' Statement)?\r\n\r\n var startPos = tn.tokenPos;\r\n if (tn.skip(Token.OPENPAREN)) {\r\n let condition = this.parseExpression(tn);\r\n if (!condition) return null;\r\n if (tn.skip(Token.CLOSEPAREN)) {\r\n let statement = this.parseStatement(tn);\r\n if (!statement) return null;\r\n let elseStatement: Statement | null = null;\r\n if (tn.skip(Token.ELSE)) {\r\n elseStatement = this.parseStatement(tn);\r\n if (!elseStatement) return null;\r\n }\r\n return Node.createIfStatement(\r\n condition,\r\n statement,\r\n elseStatement,\r\n tn.range(startPos, tn.pos)\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"(\"\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseSwitchStatement(\r\n tn: Tokenizer\r\n ): SwitchStatement | null {\r\n\r\n // at 'switch': '(' Expression ')' '{' SwitchCase* '}' ';'?\r\n\r\n var startPos = tn.tokenPos;\r\n if (tn.skip(Token.OPENPAREN)) {\r\n let condition = this.parseExpression(tn);\r\n if (!condition) return null;\r\n if (tn.skip(Token.CLOSEPAREN)) {\r\n if (tn.skip(Token.OPENBRACE)) {\r\n let cases = new Array();\r\n while (!tn.skip(Token.CLOSEBRACE)) {\r\n let case_ = this.parseSwitchCase(tn);\r\n if (!case_) return null;\r\n cases.push(case_);\r\n }\r\n let ret = Node.createSwitchStatement(condition, cases, tn.range(startPos, tn.pos));\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"{\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"(\"\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseSwitchCase(\r\n tn: Tokenizer\r\n ): SwitchCase | null {\r\n\r\n var startPos = tn.tokenPos;\r\n var statements: Statement[],\r\n statement: Statement | null;\r\n\r\n // 'case' Expression ':' Statement*\r\n\r\n if (tn.skip(Token.CASE)) {\r\n let label = this.parseExpression(tn);\r\n if (!label) return null;\r\n if (tn.skip(Token.COLON)) {\r\n statements = new Array();\r\n while (tn.peek() != Token.CASE && tn.nextToken != Token.DEFAULT && tn.nextToken != Token.CLOSEBRACE) {\r\n statement = this.parseStatement(tn);\r\n if (!statement) return null;\r\n statements.push(statement);\r\n }\r\n return Node.createSwitchCase(label, statements, tn.range(startPos, tn.pos));\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \":\"\r\n );\r\n }\r\n\r\n // 'default' ':' Statement*\r\n\r\n } else if (tn.skip(Token.DEFAULT)) {\r\n if (tn.skip(Token.COLON)) {\r\n statements = new Array();\r\n while (tn.peek() != Token.CASE && tn.nextToken != Token.DEFAULT && tn.nextToken != Token.CLOSEBRACE) {\r\n statement = this.parseStatement(tn);\r\n if (!statement) return null;\r\n statements.push(statement);\r\n }\r\n return Node.createSwitchCase(null, statements, tn.range(startPos, tn.pos));\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \":\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._case_or_default_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseThrowStatement(\r\n tn: Tokenizer\r\n ): ThrowStatement | null {\r\n\r\n // at 'throw': Expression ';'?\r\n\r\n var startPos = tn.tokenPos;\r\n var expression = this.parseExpression(tn);\r\n if (!expression) return null;\r\n var ret = Node.createThrowStatement(expression, tn.range(startPos, tn.pos));\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseTryStatement(\r\n tn: Tokenizer\r\n ): TryStatement | null {\r\n\r\n // at 'try':\r\n // '{' Statement* '}'\r\n // ('catch' '(' VariableMember ')' '{' Statement* '}')?\r\n // ('finally' '{' Statement* '}'? ';'?\r\n\r\n var startPos = tn.tokenPos;\r\n var stmt: Statement | null;\r\n if (tn.skip(Token.OPENBRACE)) {\r\n let statements = new Array();\r\n while (!tn.skip(Token.CLOSEBRACE)) {\r\n stmt = this.parseStatement(tn);\r\n if (!stmt) return null;\r\n statements.push(stmt);\r\n }\r\n let catchVariable: IdentifierExpression | null = null;\r\n let catchStatements: Statement[] | null = null;\r\n let finallyStatements: Statement[] | null = null;\r\n if (tn.skip(Token.CATCH)) {\r\n if (!tn.skip(Token.OPENPAREN)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"(\"\r\n );\r\n return null;\r\n }\r\n if (!tn.skipIdentifier()) {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n return null;\r\n }\r\n catchVariable = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n if (!tn.skip(Token.CLOSEPAREN)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n return null;\r\n }\r\n if (!tn.skip(Token.OPENBRACE)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"{\"\r\n );\r\n return null;\r\n }\r\n catchStatements = [];\r\n while (!tn.skip(Token.CLOSEBRACE)) {\r\n stmt = this.parseStatement(tn);\r\n if (!stmt) return null;\r\n catchStatements.push(stmt);\r\n }\r\n }\r\n if (tn.skip(Token.FINALLY)) {\r\n if (!tn.skip(Token.OPENBRACE)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"{\"\r\n );\r\n return null;\r\n }\r\n finallyStatements = [];\r\n while (!tn.skip(Token.CLOSEBRACE)) {\r\n stmt = this.parseStatement(tn);\r\n if (!stmt) return null;\r\n finallyStatements.push(stmt);\r\n }\r\n }\r\n if (!(catchStatements || finallyStatements)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"catch\"\r\n );\r\n return null;\r\n }\r\n let ret = Node.createTryStatement(\r\n statements,\r\n catchVariable,\r\n catchStatements,\r\n finallyStatements,\r\n tn.range(startPos, tn.pos)\r\n );\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"{\"\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseTypeDeclaration(\r\n tn: Tokenizer,\r\n flags: CommonFlags,\r\n decorators: DecoratorNode[] | null,\r\n startPos: i32\r\n ): TypeDeclaration | null {\r\n\r\n // at 'type': Identifier ('<' TypeParameters '>')? '=' Type ';'?\r\n\r\n if (tn.skipIdentifier()) {\r\n let name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n let typeParameters: TypeParameterNode[] | null = null;\r\n if (tn.skip(Token.LESSTHAN)) {\r\n typeParameters = this.parseTypeParameters(tn);\r\n if (!typeParameters) return null;\r\n flags |= CommonFlags.GENERIC;\r\n }\r\n if (tn.skip(Token.EQUALS)) {\r\n let type = this.parseType(tn);\r\n if (!type) return null;\r\n let ret = Node.createTypeDeclaration(\r\n name,\r\n typeParameters,\r\n type,\r\n decorators,\r\n flags,\r\n tn.range(startPos, tn.pos)\r\n );\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"=\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n parseVoidStatement(\r\n tn: Tokenizer\r\n ): VoidStatement | null {\r\n\r\n // at 'void': Expression ';'?\r\n\r\n var startPos = tn.tokenPos;\r\n var expression = this.parseExpression(tn, Precedence.GROUPING);\r\n if (!expression) return null;\r\n var ret = Node.createVoidStatement(expression, tn.range(startPos, tn.pos));\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n }\r\n\r\n parseWhileStatement(\r\n tn: Tokenizer\r\n ): WhileStatement | null {\r\n\r\n // at 'while': '(' Expression ')' Statement ';'?\r\n\r\n var startPos = tn.tokenPos;\r\n if (tn.skip(Token.OPENPAREN)) {\r\n let expression = this.parseExpression(tn);\r\n if (!expression) return null;\r\n if (tn.skip(Token.CLOSEPAREN)) {\r\n let statement = this.parseStatement(tn);\r\n if (!statement) return null;\r\n let ret = Node.createWhileStatement(expression, statement, tn.range(startPos, tn.pos));\r\n tn.skip(Token.SEMICOLON);\r\n return ret;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n }\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"(\"\r\n );\r\n }\r\n return null;\r\n }\r\n\r\n // expressions\r\n // see: http://www.engr.mun.ca/~theo/Misc/exp_parsing.htm#climbing\r\n\r\n parseExpressionStart(\r\n tn: Tokenizer\r\n ): Expression | null {\r\n\r\n var token = tn.next(IdentifierHandling.PREFER);\r\n var startPos = tn.tokenPos;\r\n var precedence = determinePrecedenceStart(token);\r\n if (precedence != Precedence.NONE) {\r\n let operand: Expression | null;\r\n\r\n // TODO: SpreadExpression, YieldExpression (currently become unsupported UnaryPrefixExpressions)\r\n\r\n // NewExpression\r\n if (token == Token.NEW) {\r\n operand = this.parseExpression(tn, Precedence.CALL);\r\n if (!operand) return null;\r\n if (operand.kind == NodeKind.CALL) {\r\n return Node.createNewExpression(\r\n (operand).expression,\r\n (operand).typeArguments,\r\n (operand).arguments,\r\n tn.range(startPos, tn.pos)\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Operation_not_supported,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n } else {\r\n operand = this.parseExpression(tn, precedence);\r\n if (!operand) return null;\r\n }\r\n\r\n // UnaryPrefixExpression\r\n if (token == Token.PLUS_PLUS || token == Token.MINUS_MINUS) {\r\n if (\r\n operand.kind != NodeKind.IDENTIFIER &&\r\n operand.kind != NodeKind.ELEMENTACCESS &&\r\n operand.kind != NodeKind.PROPERTYACCESS\r\n ) {\r\n this.error(\r\n DiagnosticCode.The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access,\r\n operand.range\r\n );\r\n }\r\n }\r\n return Node.createUnaryPrefixExpression(token, operand, tn.range(startPos, tn.pos));\r\n }\r\n\r\n var expr: Expression | null = null;\r\n switch (token) {\r\n\r\n case Token.NULL: return Node.createNullExpression(tn.range());\r\n case Token.TRUE: return Node.createTrueExpression(tn.range());\r\n case Token.FALSE: return Node.createFalseExpression(tn.range());\r\n\r\n // ParenthesizedExpression\r\n // FunctionExpression\r\n case Token.OPENPAREN: {\r\n\r\n // determine whether this is a function expression\r\n if (tn.skip(Token.CLOSEPAREN)) { // must be a function expression (fast route)\r\n return this.parseFunctionExpressionCommon(\r\n tn,\r\n Node.createEmptyIdentifierExpression(tn.range(startPos)),\r\n [],\r\n ArrowKind.ARROW_PARENTHESIZED\r\n );\r\n }\r\n let state = tn.mark();\r\n let again = true;\r\n do {\r\n switch (tn.next(IdentifierHandling.PREFER)) {\r\n\r\n // function expression\r\n case Token.DOT_DOT_DOT: {\r\n tn.reset(state);\r\n return this.parseFunctionExpression(tn);\r\n }\r\n // can be both\r\n case Token.IDENTIFIER: {\r\n tn.readIdentifier();\r\n switch (tn.next()) {\r\n\r\n // if we got here, check for arrow\r\n case Token.CLOSEPAREN: {\r\n if (\r\n !tn.skip(Token.COLON) &&\r\n !tn.skip(Token.EQUALS_GREATERTHAN)\r\n ) {\r\n again = false;\r\n break;\r\n }\r\n // fall-through\r\n }\r\n // function expression\r\n case Token.COLON: { // type annotation\r\n tn.reset(state);\r\n return this.parseFunctionExpression(tn);\r\n }\r\n // optional parameter or parenthesized\r\n case Token.QUESTION: {\r\n if (\r\n tn.skip(Token.COLON) || // optional parameter with type\r\n tn.skip(Token.COMMA) || // optional parameter without type\r\n tn.skip(Token.CLOSEPAREN) // last optional parameter without type\r\n ) {\r\n tn.reset(state);\r\n return this.parseFunctionExpression(tn);\r\n }\r\n again = false; // parenthesized\r\n break;\r\n }\r\n case Token.COMMA: {\r\n break; // continue\r\n }\r\n // parenthesized expression\r\n // case Token.EQUALS: // missing type annotation for simplicity\r\n default: {\r\n again = false;\r\n break;\r\n }\r\n }\r\n break;\r\n }\r\n // parenthesized expression\r\n default: {\r\n again = false;\r\n break;\r\n }\r\n }\r\n } while (again);\r\n tn.reset(state);\r\n\r\n // parse parenthesized\r\n expr = this.parseExpression(tn);\r\n if (!expr) return null;\r\n if (!tn.skip(Token.CLOSEPAREN)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n return null;\r\n }\r\n return Node.createParenthesizedExpression(expr, tn.range(startPos, tn.pos));\r\n }\r\n // ArrayLiteralExpression\r\n case Token.OPENBRACKET: {\r\n let elementExpressions = new Array();\r\n while (!tn.skip(Token.CLOSEBRACKET)) {\r\n if (tn.peek() == Token.COMMA) {\r\n expr = null; // omitted\r\n } else {\r\n expr = this.parseExpression(tn, Precedence.COMMA + 1);\r\n if (!expr) return null;\r\n }\r\n elementExpressions.push(expr);\r\n if (!tn.skip(Token.COMMA)) {\r\n if (tn.skip(Token.CLOSEBRACKET)) {\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"]\"\r\n );\r\n return null;\r\n }\r\n }\r\n }\r\n return Node.createArrayLiteralExpression(elementExpressions, tn.range(startPos, tn.pos));\r\n }\r\n // ObjectLiteralExpression\r\n case Token.OPENBRACE: {\r\n let startPos = tn.tokenPos;\r\n let names = new Array();\r\n let values = new Array();\r\n let name: IdentifierExpression;\r\n while (!tn.skip(Token.CLOSEBRACE)) {\r\n if (!tn.skipIdentifier()) {\r\n if (!tn.skip(Token.STRINGLITERAL)) {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n tn.range(),\r\n );\r\n return null;\r\n }\r\n name = Node.createIdentifierExpression(tn.readString(), tn.range());\r\n name.isQuoted = true;\r\n } else {\r\n name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n }\r\n names.push(name);\r\n if (tn.skip(Token.COLON)) {\r\n let value = this.parseExpression(tn, Precedence.COMMA + 1);\r\n if (!value) return null;\r\n values.push(value);\r\n } else if (!name.isQuoted) {\r\n values.push(name);\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \":\"\r\n );\r\n return null;\r\n }\r\n if (!tn.skip(Token.COMMA)) {\r\n if (tn.skip(Token.CLOSEBRACE)) {\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"}\"\r\n );\r\n return null;\r\n }\r\n }\r\n }\r\n return Node.createObjectLiteralExpression(names, values, tn.range(startPos, tn.pos));\r\n }\r\n // AssertionExpression (unary prefix)\r\n case Token.LESSTHAN: {\r\n let toType = this.parseType(tn);\r\n if (!toType) return null;\r\n if (!tn.skip(Token.GREATERTHAN)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \">\"\r\n );\r\n return null;\r\n }\r\n expr = this.parseExpression(tn, Precedence.CALL);\r\n if (!expr) return null;\r\n return Node.createAssertionExpression(\r\n AssertionKind.PREFIX,\r\n expr,\r\n toType,\r\n tn.range(startPos, tn.pos)\r\n );\r\n }\r\n case Token.IDENTIFIER: {\r\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range(startPos, tn.pos));\r\n if (tn.peek(true) == Token.EQUALS_GREATERTHAN && !tn.nextTokenOnNewLine) {\r\n return this.parseFunctionExpressionCommon(\r\n tn,\r\n Node.createEmptyIdentifierExpression(tn.range(startPos)),\r\n [\r\n Node.createParameter(\r\n identifier,\r\n Node.createOmittedType(identifier.range.atEnd),\r\n null,\r\n ParameterKind.DEFAULT,\r\n identifier.range\r\n )\r\n ],\r\n ArrowKind.ARROW_SINGLE,\r\n startPos\r\n );\r\n }\r\n return identifier;\r\n }\r\n case Token.THIS: {\r\n return Node.createThisExpression(tn.range(startPos, tn.pos));\r\n }\r\n case Token.CONSTRUCTOR: {\r\n return Node.createConstructorExpression(tn.range(startPos, tn.pos));\r\n }\r\n case Token.SUPER: {\r\n if (tn.peek() != Token.DOT && tn.nextToken != Token.OPENPAREN) {\r\n this.error(\r\n DiagnosticCode._super_must_be_followed_by_an_argument_list_or_member_access,\r\n tn.range()\r\n );\r\n }\r\n return Node.createSuperExpression(tn.range(startPos, tn.pos));\r\n }\r\n case Token.STRINGLITERAL: {\r\n return Node.createStringLiteralExpression(tn.readString(), tn.range(startPos, tn.pos));\r\n }\r\n case Token.INTEGERLITERAL: {\r\n return Node.createIntegerLiteralExpression(tn.readInteger(), tn.range(startPos, tn.pos));\r\n }\r\n case Token.FLOATLITERAL: {\r\n return Node.createFloatLiteralExpression(tn.readFloat(), tn.range(startPos, tn.pos));\r\n }\r\n // RegexpLiteralExpression\r\n // note that this also continues on invalid ones so the surrounding AST remains intact\r\n case Token.SLASH: {\r\n let regexpPattern = tn.readRegexpPattern(); // also reports\r\n if (!tn.skip(Token.SLASH)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"/\"\r\n );\r\n return null;\r\n }\r\n return Node.createRegexpLiteralExpression(\r\n regexpPattern,\r\n tn.readRegexpFlags(), // also reports\r\n tn.range(startPos, tn.pos)\r\n );\r\n }\r\n case Token.FUNCTION: {\r\n return this.parseFunctionExpression(tn);\r\n }\r\n case Token.CLASS: {\r\n return this.parseClassExpression(tn);\r\n }\r\n default: {\r\n if (token == Token.ENDOFFILE) {\r\n this.error(\r\n DiagnosticCode.Unexpected_end_of_text,\r\n tn.range(startPos)\r\n );\r\n } else {\r\n this.error(\r\n DiagnosticCode.Expression_expected,\r\n tn.range()\r\n );\r\n }\r\n return null;\r\n }\r\n }\r\n }\r\n\r\n tryParseTypeArgumentsBeforeArguments(\r\n tn: Tokenizer\r\n ): CommonTypeNode[] | null {\r\n\r\n // at '<': Type (',' Type)* '>' '('\r\n\r\n var state = tn.mark();\r\n if (!tn.skip(Token.LESSTHAN)) return null;\r\n var typeArguments: CommonTypeNode[] | null = null;\r\n do {\r\n if (tn.peek() === Token.GREATERTHAN) {\r\n break;\r\n }\r\n let type = this.parseType(tn, true, true);\r\n if (!type) {\r\n tn.reset(state);\r\n return null;\r\n }\r\n if (!typeArguments) typeArguments = [ type ];\r\n else typeArguments.push(type);\r\n } while (tn.skip(Token.COMMA));\r\n if (tn.skip(Token.GREATERTHAN) && tn.skip(Token.OPENPAREN)) {\r\n return typeArguments;\r\n }\r\n tn.reset(state);\r\n return null;\r\n }\r\n\r\n parseArguments(\r\n tn: Tokenizer\r\n ): Expression[] | null {\r\n\r\n // at '(': (Expression (',' Expression)*)? ')'\r\n\r\n var args = new Array();\r\n while (!tn.skip(Token.CLOSEPAREN)) {\r\n let expr = this.parseExpression(tn, Precedence.COMMA + 1);\r\n if (!expr) return null;\r\n args.push(expr);\r\n if (!tn.skip(Token.COMMA)) {\r\n if (tn.skip(Token.CLOSEPAREN)) {\r\n break;\r\n } else {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \")\"\r\n );\r\n return null;\r\n }\r\n }\r\n }\r\n return args;\r\n }\r\n\r\n parseExpression(\r\n tn: Tokenizer,\r\n precedence: Precedence = Precedence.COMMA\r\n ): Expression | null {\r\n assert(precedence != Precedence.NONE);\r\n\r\n var expr = this.parseExpressionStart(tn);\r\n if (!expr) return null;\r\n expr = this.maybeParseCallExpression(tn, expr); // simple call like on an Identifier\r\n\r\n var startPos = expr.range.start;\r\n var token: Token;\r\n var next: Expression | null = null;\r\n var nextPrecedence: Precedence;\r\n while (\r\n (nextPrecedence = determinePrecedence(token = tn.peek())) >= precedence\r\n ) { // precedence climbing\r\n tn.next();\r\n switch (token) {\r\n // AssertionExpression\r\n case Token.AS: {\r\n let toType = this.parseType(tn); // reports\r\n if (!toType) return null;\r\n expr = Node.createAssertionExpression(\r\n AssertionKind.AS,\r\n expr,\r\n toType,\r\n tn.range(startPos, tn.pos)\r\n );\r\n break;\r\n }\r\n case Token.EXCLAMATION: {\r\n expr = Node.createAssertionExpression(\r\n AssertionKind.NONNULL,\r\n expr,\r\n null,\r\n tn.range(startPos, tn.pos)\r\n );\r\n break;\r\n }\r\n // InstanceOfExpression\r\n case Token.INSTANCEOF: {\r\n let isType = this.parseType(tn); // reports\r\n if (!isType) return null;\r\n expr = Node.createInstanceOfExpression(\r\n expr,\r\n isType,\r\n tn.range(startPos, tn.pos)\r\n );\r\n break;\r\n }\r\n // ElementAccessExpression\r\n case Token.OPENBRACKET: {\r\n next = this.parseExpression(tn); // reports\r\n if (!next) return null;\r\n if (!tn.skip(Token.CLOSEBRACKET)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"]\"\r\n );\r\n return null;\r\n }\r\n expr = Node.createElementAccessExpression(\r\n expr,\r\n next,\r\n tn.range(startPos, tn.pos)\r\n );\r\n break;\r\n }\r\n // UnaryPostfixExpression\r\n case Token.PLUS_PLUS:\r\n case Token.MINUS_MINUS: {\r\n if (\r\n expr.kind != NodeKind.IDENTIFIER &&\r\n expr.kind != NodeKind.ELEMENTACCESS &&\r\n expr.kind != NodeKind.PROPERTYACCESS\r\n ) {\r\n this.error(\r\n DiagnosticCode.The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access,\r\n expr.range\r\n );\r\n }\r\n expr = Node.createUnaryPostfixExpression(\r\n token,\r\n expr,\r\n tn.range(startPos, tn.pos)\r\n );\r\n break;\r\n }\r\n // TernaryExpression\r\n case Token.QUESTION: {\r\n let ifThen = this.parseExpression(tn);\r\n if (!ifThen) return null;\r\n if (!tn.skip(Token.COLON)) {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \":\"\r\n );\r\n return null;\r\n }\r\n let ifElse = this.parseExpression(tn, precedence > Precedence.COMMA\r\n ? Precedence.COMMA + 1\r\n : Precedence.COMMA\r\n );\r\n if (!ifElse) return null;\r\n expr = Node.createTernaryExpression(\r\n expr,\r\n ifThen,\r\n ifElse,\r\n tn.range(startPos, tn.pos)\r\n );\r\n break;\r\n }\r\n // CommaExpression\r\n case Token.COMMA: {\r\n let commaExprs: Expression[] = [ expr ];\r\n do {\r\n expr = this.parseExpression(tn, Precedence.COMMA + 1);\r\n if (!expr) return null;\r\n commaExprs.push(expr);\r\n } while (tn.skip(Token.COMMA));\r\n expr = Node.createCommaExpression(commaExprs, tn.range(startPos, tn.pos));\r\n break;\r\n }\r\n default: {\r\n\r\n // PropertyAccessExpression\r\n if (token == Token.DOT) {\r\n if (tn.skipIdentifier()) {\r\n next = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\r\n } else {\r\n next = this.parseExpression(tn,\r\n isRightAssociative(token)\r\n ? nextPrecedence\r\n : nextPrecedence + 1\r\n );\r\n if (!next) return null;\r\n }\r\n if (next.kind == NodeKind.IDENTIFIER) { // expr '.' Identifier\r\n expr = Node.createPropertyAccessExpression(\r\n expr,\r\n next,\r\n tn.range(startPos, tn.pos)\r\n );\r\n } else if (next.kind == NodeKind.CALL) { // expr '.' CallExpression\r\n expr = this.joinPropertyCall(tn, startPos, expr, next);\r\n if (!expr) return null;\r\n } else {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n next.range\r\n );\r\n return null;\r\n }\r\n\r\n // BinaryExpression\r\n } else {\r\n next = this.parseExpression(tn,\r\n isRightAssociative(token)\r\n ? nextPrecedence\r\n : nextPrecedence + 1\r\n );\r\n if (!next) return null;\r\n expr = Node.createBinaryExpression(token, expr, next, tn.range(startPos, tn.pos));\r\n }\r\n break;\r\n }\r\n }\r\n expr = this.maybeParseCallExpression(tn, expr); // compound call like on an ElementAccess\r\n }\r\n return expr;\r\n }\r\n\r\n private joinPropertyCall(\r\n tn: Tokenizer,\r\n startPos: i32,\r\n expr: Expression,\r\n call: CallExpression\r\n ): Expression | null {\r\n var callee = call.expression;\r\n switch (callee.kind) {\r\n case NodeKind.IDENTIFIER: { // join property access and use as call target\r\n call.expression = Node.createPropertyAccessExpression(\r\n expr,\r\n callee,\r\n tn.range(startPos, tn.pos)\r\n );\r\n break;\r\n }\r\n case NodeKind.CALL: { // join call target und wrap the original call around it\r\n let inner = this.joinPropertyCall(tn, startPos, expr, callee);\r\n if (!inner) return null;\r\n call.expression = inner;\r\n call.range = tn.range(startPos, tn.pos);\r\n break;\r\n }\r\n default: {\r\n this.error(\r\n DiagnosticCode.Identifier_expected,\r\n call.range\r\n );\r\n return null;\r\n }\r\n }\r\n return call;\r\n }\r\n\r\n private maybeParseCallExpression(\r\n tn: Tokenizer,\r\n expr: Expression\r\n ): Expression {\r\n if (nodeIsCallable(expr.kind)) {\r\n let typeArguments: CommonTypeNode[] | null = null;\r\n while (\r\n tn.skip(Token.OPENPAREN)\r\n ||\r\n nodeIsGenericCallable(expr.kind) && (typeArguments = this.tryParseTypeArgumentsBeforeArguments(tn)) !== null\r\n ) {\r\n let args = this.parseArguments(tn);\r\n if (!args) break;\r\n expr = Node.createCallExpression( // is again callable\r\n expr,\r\n typeArguments,\r\n args,\r\n tn.range(expr.range.start, tn.pos)\r\n );\r\n }\r\n }\r\n return expr;\r\n }\r\n\r\n /** Skips over a statement on errors in an attempt to reduce unnecessary diagnostic noise. */\r\n skipStatement(tn: Tokenizer): void {\r\n tn.peek(true);\r\n if (tn.nextTokenOnNewLine) tn.next(); // if reset() to the previous line\r\n do {\r\n let nextToken = tn.peek(true);\r\n if (\r\n nextToken == Token.ENDOFFILE || // next step should handle this\r\n nextToken == Token.SEMICOLON // end of the statement for sure\r\n ) {\r\n tn.next();\r\n break;\r\n }\r\n if (tn.nextTokenOnNewLine) break; // end of the statement maybe\r\n switch (tn.next()) {\r\n case Token.IDENTIFIER: {\r\n tn.readIdentifier();\r\n break;\r\n }\r\n case Token.STRINGLITERAL: {\r\n tn.readString();\r\n break;\r\n }\r\n case Token.INTEGERLITERAL: {\r\n tn.readInteger();\r\n break;\r\n }\r\n case Token.FLOATLITERAL: {\r\n tn.readFloat();\r\n break;\r\n }\r\n case Token.OPENBRACE: {\r\n this.skipBlock(tn);\r\n break;\r\n }\r\n }\r\n } while (true);\r\n }\r\n\r\n /** Skips over a block on errors in an attempt to reduce unnecessary diagnostic noise. */\r\n skipBlock(tn: Tokenizer): void {\r\n // at '{': ... '}'\r\n var depth = 1;\r\n var again = true;\r\n do {\r\n switch (tn.next()) {\r\n case Token.ENDOFFILE: {\r\n this.error(\r\n DiagnosticCode._0_expected,\r\n tn.range(), \"}\"\r\n );\r\n again = false;\r\n break;\r\n }\r\n case Token.OPENBRACE: {\r\n ++depth;\r\n break;\r\n }\r\n case Token.CLOSEBRACE: {\r\n --depth;\r\n if (!depth) again = false;\r\n break;\r\n }\r\n case Token.IDENTIFIER: {\r\n tn.readIdentifier();\r\n break;\r\n }\r\n case Token.STRINGLITERAL: {\r\n tn.readString();\r\n break;\r\n }\r\n case Token.INTEGERLITERAL: {\r\n tn.readInteger();\r\n break;\r\n }\r\n case Token.FLOATLITERAL: {\r\n tn.readFloat();\r\n break;\r\n }\r\n }\r\n } while (again);\r\n }\r\n}\r\n\r\n/** Operator precedence from least to largest. */\r\nexport const enum Precedence {\r\n NONE,\r\n COMMA,\r\n SPREAD,\r\n YIELD,\r\n ASSIGNMENT,\r\n CONDITIONAL,\r\n LOGICAL_OR,\r\n LOGICAL_AND,\r\n BITWISE_OR,\r\n BITWISE_XOR,\r\n BITWISE_AND,\r\n EQUALITY,\r\n RELATIONAL,\r\n SHIFT,\r\n ADDITIVE,\r\n MULTIPLICATIVE,\r\n EXPONENTIATED,\r\n UNARY_PREFIX,\r\n UNARY_POSTFIX,\r\n CALL,\r\n MEMBERACCESS,\r\n GROUPING\r\n}\r\n\r\n/** Determines the precedence of a starting token. */\r\nfunction determinePrecedenceStart(kind: Token): Precedence {\r\n switch (kind) {\r\n case Token.DOT_DOT_DOT: return Precedence.SPREAD;\r\n case Token.YIELD: return Precedence.YIELD;\r\n case Token.EXCLAMATION:\r\n case Token.TILDE:\r\n case Token.PLUS:\r\n case Token.MINUS:\r\n case Token.PLUS_PLUS:\r\n case Token.MINUS_MINUS:\r\n case Token.TYPEOF:\r\n case Token.VOID:\r\n case Token.DELETE: return Precedence.UNARY_PREFIX;\r\n case Token.NEW: return Precedence.MEMBERACCESS;\r\n }\r\n return Precedence.NONE;\r\n}\r\n\r\n/** Determines the precende of a non-starting token. */\r\nfunction determinePrecedence(kind: Token): Precedence {\r\n switch (kind) {\r\n case Token.COMMA: return Precedence.COMMA;\r\n case Token.EQUALS:\r\n case Token.PLUS_EQUALS:\r\n case Token.MINUS_EQUALS:\r\n case Token.ASTERISK_ASTERISK_EQUALS:\r\n case Token.ASTERISK_EQUALS:\r\n case Token.SLASH_EQUALS:\r\n case Token.PERCENT_EQUALS:\r\n case Token.LESSTHAN_LESSTHAN_EQUALS:\r\n case Token.GREATERTHAN_GREATERTHAN_EQUALS:\r\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:\r\n case Token.AMPERSAND_EQUALS:\r\n case Token.CARET_EQUALS:\r\n case Token.BAR_EQUALS: return Precedence.ASSIGNMENT;\r\n case Token.QUESTION: return Precedence.CONDITIONAL;\r\n case Token.BAR_BAR: return Precedence.LOGICAL_OR;\r\n case Token.AMPERSAND_AMPERSAND: return Precedence.LOGICAL_AND;\r\n case Token.BAR: return Precedence.BITWISE_OR;\r\n case Token.CARET: return Precedence.BITWISE_XOR;\r\n case Token.AMPERSAND: return Precedence.BITWISE_AND;\r\n case Token.EQUALS_EQUALS:\r\n case Token.EXCLAMATION_EQUALS:\r\n case Token.EQUALS_EQUALS_EQUALS:\r\n case Token.EXCLAMATION_EQUALS_EQUALS: return Precedence.EQUALITY;\r\n case Token.AS:\r\n case Token.IN:\r\n case Token.INSTANCEOF:\r\n case Token.LESSTHAN:\r\n case Token.GREATERTHAN:\r\n case Token.LESSTHAN_EQUALS:\r\n case Token.GREATERTHAN_EQUALS: return Precedence.RELATIONAL;\r\n case Token.LESSTHAN_LESSTHAN:\r\n case Token.GREATERTHAN_GREATERTHAN:\r\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN: return Precedence.SHIFT;\r\n case Token.PLUS:\r\n case Token.MINUS: return Precedence.ADDITIVE;\r\n case Token.ASTERISK:\r\n case Token.SLASH:\r\n case Token.PERCENT: return Precedence.MULTIPLICATIVE;\r\n case Token.ASTERISK_ASTERISK: return Precedence.EXPONENTIATED;\r\n case Token.PLUS_PLUS:\r\n case Token.MINUS_MINUS: return Precedence.UNARY_POSTFIX;\r\n case Token.DOT:\r\n case Token.NEW:\r\n case Token.OPENBRACKET:\r\n case Token.EXCLAMATION: return Precedence.MEMBERACCESS;\r\n }\r\n return Precedence.NONE;\r\n}\r\n\r\n/** Determines whether a non-starting token is right associative. */\r\nfunction isRightAssociative(kind: Token): bool {\r\n switch (kind) {\r\n case Token.EQUALS:\r\n case Token.PLUS_EQUALS:\r\n case Token.MINUS_EQUALS:\r\n case Token.ASTERISK_ASTERISK_EQUALS:\r\n case Token.ASTERISK_EQUALS:\r\n case Token.SLASH_EQUALS:\r\n case Token.PERCENT_EQUALS:\r\n case Token.LESSTHAN_LESSTHAN_EQUALS:\r\n case Token.GREATERTHAN_GREATERTHAN_EQUALS:\r\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:\r\n case Token.AMPERSAND_EQUALS:\r\n case Token.CARET_EQUALS:\r\n case Token.BAR_EQUALS:\r\n case Token.QUESTION:\r\n case Token.ASTERISK_ASTERISK: return true;\r\n default: return false;\r\n }\r\n}\r\n","/**\r\n * JavaScript glue code.\r\n * @module glue/js\r\n * @preferred\r\n *//***/\r\n\r\n/// \r\n\r\nimport \"./binaryen\"; // must be first so portable can pick up the memory implementation\r\nimport \"../../../std/portable/index\";\r\nimport \"./float\";\r\nimport \"./i64\";\r\n\r\nimport { Module } from \"../../module\";\r\n\r\nModule.prototype.toText = function(this: Module) {\r\n // NOTE: Conversion to StackIR can yield conversion artifacts like sequences\r\n // of unreachable statements not actually emitted by the compiler. Optimizing\r\n // StackIR removes these again, but may also suppress useless code emitted by\r\n // the compiler that's then no longer visible in tests. Both not ideal.\r\n return binaryen.wrapModule(this.ref).emitStackIR(/* optimize-stack-ir */ true);\r\n};\r\n\r\nModule.prototype.toAsmjs = function(this: Module) {\r\n return binaryen.wrapModule(this.ref).emitAsmjs();\r\n};\r\n","// Copy Binaryen exports to global scope\r\n\r\nconst binaryen = global.Binaryen || require(\"binaryen\");\r\nglobal.binaryen = binaryen;\r\n\r\nfor (var key in binaryen) {\r\n if (key.startsWith(\"_Binaryen\") || key.startsWith(\"_Relooper\")) global[key] = binaryen[key];\r\n}\r\n\r\n// Utilize Binaryen's heap\r\n\r\nglobal.__memory_allocate = binaryen._malloc;\r\nglobal.__memory_free = binaryen._free;\r\nglobal.__memory_copy = binaryen._memmove;\r\nglobal.__store = function(ptr, val) { binaryen.HEAPU8[ptr] = val; };\r\nglobal.__load = function(ptr) { return binaryen.HEAPU8[ptr]; };\r\n","module.exports = __WEBPACK_EXTERNAL_MODULE__20__;","/** @module std/portable *//***/\r\n\r\nvar globalScope = typeof window !== \"undefined\" && window || typeof global !== \"undefined\" && global || self;\r\n\r\nglobalScope.ASC_TARGET = 2; // Target.JS\r\nglobalScope.ASC_NO_ASSERT = false;\r\nglobalScope.ASC_MEMORY_BASE = 0;\r\nglobalScope.ASC_OPTIMIZE_LEVEL = 3;\r\nglobalScope.ASC_SHRINK_LEVEL = 0;\r\nglobalScope.ASC_FEATURE_MUTABLE_GLOBAL = false;\r\nglobalScope.ASC_FEATURE_SIGN_EXTENSION = false;\r\nglobalScope.ASC_FEATURE_BULK_MEMORY = false;\r\nglobalScope.ASC_FEATURE_SIMD = false;\r\nglobalScope.ASC_FEATURE_THREADS = false;\r\n\r\nvar F64 = new Float64Array(1);\r\nvar U64 = new Uint32Array(F64.buffer);\r\n\r\nObject.defineProperties(\r\n globalScope[\"i8\"] = function i8(value) { return value << 24 >> 24; }\r\n, {\r\n \"MIN_VALUE\": { value: -128, writable: false },\r\n \"MAX_VALUE\": { value: 127, writable: false }\r\n});\r\n\r\nObject.defineProperties(\r\n globalScope[\"i16\"] = function i16(value) { return value << 16 >> 16; }\r\n, {\r\n \"MIN_VALUE\": { value: -32768, writable: false },\r\n \"MAX_VALUE\": { value: 32767, writable: false }\r\n});\r\n\r\nObject.defineProperties(\r\n globalScope[\"i32\"] = globalScope[\"isize\"] = function i32(value) { return value | 0; }\r\n, {\r\n \"MIN_VALUE\": { value: -2147483648, writable: false },\r\n \"MAX_VALUE\": { value: 2147483647, writable: false }\r\n});\r\n\r\nObject.defineProperties(\r\n globalScope[\"u8\"] = function u8(value) { return value & 0xff; }\r\n, {\r\n \"MIN_VALUE\": { value: 0, writable: false },\r\n \"MAX_VALUE\": { value: 255, writable: false }\r\n});\r\n\r\nObject.defineProperties(\r\n globalScope[\"u16\"] = function u16(value) { return value & 0xffff; }\r\n, {\r\n \"MIN_VALUE\": { value: 0, writable: false },\r\n \"MAX_VALUE\": { value: 65535, writable: false }\r\n});\r\n\r\nObject.defineProperties(\r\n globalScope[\"u32\"] = globalScope[\"usize\"] = function u32(value) { return value >>> 0; }\r\n, {\r\n \"MIN_VALUE\": { value: 0, writable: false },\r\n \"MAX_VALUE\": { value: 4294967295, writable: false }\r\n});\r\n\r\nObject.defineProperties(\r\n globalScope[\"bool\"] = function bool(value) { return !!value; }\r\n, {\r\n \"MIN_VALUE\": { value: false, writable: false },\r\n \"MAX_VALUE\": { value: true, writable: false }\r\n});\r\n\r\nObject.defineProperties(\r\n globalScope[\"f32\"] = function f32(value) { return Math.fround(value); }\r\n, {\r\n \"EPSILON\": { value: Math.fround(1.1920929e-07), writable: false },\r\n \"MIN_VALUE\": { value: Math.fround(1.4012985e-45), writable: false },\r\n \"MAX_VALUE\": { value: Math.fround(3.4028235e+38), writable: false },\r\n \"MIN_NORMAL_VALUE\": { value: Math.fround(1.17549435e-38), writable: false },\r\n \"MIN_SAFE_INTEGER\": { value: -16777215, writable: false },\r\n \"MAX_SAFE_INTEGER\": { value: 16777215, writable: false }\r\n});\r\n\r\nObject.defineProperties(\r\n globalScope[\"f64\"] = function f64(value) { return +value; }\r\n, {\r\n \"EPSILON\": { value: 2.2204460492503131e-16, writable: false },\r\n \"MIN_VALUE\": { value: 5e-324, writable: false },\r\n \"MAX_VALUE\": { value: 1.7976931348623157e+308, writable: false },\r\n \"MIN_NORMAL_VALUE\": { value: 2.2250738585072014e-308 , writable: false },\r\n \"MIN_SAFE_INTEGER\": { value: -9007199254740991, writable: false },\r\n \"MAX_SAFE_INTEGER\": { value: 9007199254740991, writable: false }\r\n});\r\n\r\nglobalScope[\"clz\"] = Math.clz32;\r\n\r\nglobalScope[\"ctz\"] = function ctz(value) {\r\n var c = Math.clz32(value & -value);\r\n return value ? 31 - c : c;\r\n};\r\n\r\nglobalScope[\"popcnt\"] = function popcnt(value) {\r\n value -= value >>> 1 & 0x55555555;\r\n value = (value & 0x33333333) + (value >>> 2 & 0x33333333);\r\n return (((value + (value >>> 4)) & 0x0F0F0F0F) * 0x01010101) >>> 24;\r\n};\r\n\r\nglobalScope[\"rotl\"] = function rotl(value, shift) {\r\n shift &= 31;\r\n return (value << shift) | (value >>> (32 - shift));\r\n};\r\n\r\nglobalScope[\"rotr\"] = function rotr(value, shift) {\r\n shift &= 31;\r\n return (value >>> shift) | (value << (32 - shift));\r\n};\r\n\r\nglobalScope[\"abs\"] = Math.abs;\r\n\r\nglobalScope[\"max\"] = Math.max;\r\n\r\nglobalScope[\"min\"] = Math.min;\r\n\r\nglobalScope[\"ceil\"] = Math.ceil;\r\n\r\nglobalScope[\"floor\"] = Math.floor;\r\n\r\n// Adopt code from https://github.com/rfk/wasm-polyfill\r\nglobalScope[\"nearest\"] = function nearest(value) {\r\n if (Math.abs(value - Math.trunc(value)) === 0.5) {\r\n return 2.0 * Math.round(value * 0.5);\r\n }\r\n return Math.round(value);\r\n};\r\n\r\nglobalScope[\"select\"] = function select(ifTrue, ifFalse, condition) {\r\n return condition ? ifTrue : ifFalse;\r\n};\r\n\r\nglobalScope[\"sqrt\"] = Math.sqrt;\r\n\r\nglobalScope[\"trunc\"] = Math.trunc;\r\n\r\nglobalScope[\"copysign\"] = function copysign(x, y) {\r\n return Math.abs(x) * Math.sign(y);\r\n};\r\n\r\nglobalScope[\"bswap\"] = function bswap(value) {\r\n var a = value >> 8 & 0x00FF00FF;\r\n var b = (value & 0x00FF00FF) << 8;\r\n value = a | b;\r\n a = value >> 16 & 0x0000FFFF;\r\n b = (value & 0x0000FFFF) << 16;\r\n return a | b;\r\n};\r\n\r\nglobalScope[\"bswap16\"] = function bswap16(value) {\r\n return ((value << 8) & 0xFF00) | ((value >> 8) & 0x00FF) | (value & 0xFFFF0000);\r\n};\r\n\r\nfunction UnreachableError() {\r\n if (Error.captureStackTrace) {\r\n Error.captureStackTrace(this, UnreachableError);\r\n } else {\r\n this.stack = this.name + \": \" + this.message + \"\\n\" + new Error().stack;\r\n }\r\n}\r\nUnreachableError.prototype = Object.create(Error.prototype);\r\nUnreachableError.prototype.name = \"UnreachableError\";\r\nUnreachableError.prototype.message = \"unreachable\";\r\n\r\nglobalScope[\"unreachable\"] = function unreachable() {\r\n throw new UnreachableError();\r\n};\r\n\r\nfunction AssertionError(message) {\r\n this.message = message || \"assertion failed\";\r\n if (Error.captureStackTrace) {\r\n Error.captureStackTrace(this, AssertionError);\r\n } else {\r\n this.stack = this.name + \": \" + this.message + \"\\n\" + new Error().stack;\r\n }\r\n}\r\nAssertionError.prototype = Object.create(Error.prototype);\r\nAssertionError.prototype.name = \"AssertionError\";\r\n\r\nglobalScope[\"assert\"] = function assert(isTrueish, message) {\r\n if (isTrueish) return isTrueish;\r\n throw new AssertionError(message);\r\n};\r\n\r\nglobalScope[\"changetype\"] = function changetype(value) {\r\n return value;\r\n};\r\n\r\nString[\"fromCharCodes\"] = function fromCharCodes(arr) {\r\n return String.fromCharCode.apply(String, arr);\r\n};\r\n\r\nString[\"fromCodePoints\"] = function fromCodePoints(arr) {\r\n return String.fromCodePoint.apply(String, arr);\r\n};\r\n\r\nif (!String.prototype.replaceAll) {\r\n Object.defineProperty(String.prototype, \"replaceAll\", {\r\n value: function replaceAll(search, replacment) {\r\n var res = this.split(search).join(replacment);\r\n if (!search.length) res = replacment + res + replacment;\r\n return res;\r\n }\r\n });\r\n}\r\n\r\nglobalScope[\"isInteger\"] = Number.isInteger;\r\n\r\nglobalScope[\"isFloat\"] = function isFloat(arg) {\r\n return typeof arg === \"number\";\r\n};\r\n\r\nglobalScope[\"isNullable\"] = function isNullable(arg) {\r\n return true;\r\n}\r\n\r\nglobalScope[\"isReference\"] = function isReference(arg) {\r\n return typeof arg === \"object\" || typeof arg === \"string\";\r\n};\r\n\r\nglobalScope[\"isFunction\"] = function isFunction(arg) {\r\n return typeof arg === \"function\";\r\n}\r\n\r\nglobalScope[\"isString\"] = function isString(arg) {\r\n return typeof arg === \"string\" || arg instanceof String;\r\n};\r\n\r\nglobalScope[\"isArray\"] = Array.isArray;\r\nglobalScope[\"isArrayLike\"] = function isArrayLike(expr) {\r\n return expr\r\n && typeof expr === 'object'\r\n && typeof expr.length === 'number'\r\n && expr.length >= 0\r\n && Math.trunc(expr.length) === expr.length;\r\n};\r\n\r\nArray.create = function(capacity) {\r\n var arr = new Array(capacity);\r\n arr.length = 0;\r\n return arr;\r\n};\r\n\r\nglobalScope[\"isDefined\"] = function isDefined(expr) {\r\n return typeof expr !== \"undefined\";\r\n}\r\n\r\nglobalScope[\"isConstant\"] = function isConstant(expr) {\r\n return false;\r\n};\r\n\r\nglobalScope[\"unchecked\"] = function unchecked(expr) {\r\n return expr;\r\n};\r\n\r\nglobalScope[\"fmod\"] = function fmod(x, y) {\r\n return x % y;\r\n};\r\n\r\nglobalScope[\"fmodf\"] = function fmodf(x, y) {\r\n return Math.fround(x % y);\r\n};\r\n\r\nglobalScope[\"JSMath\"] = Math;\r\n\r\nObject.defineProperties(globalScope[\"JSMath\"], {\r\n sincos_sin: { value: 0.0, writable: true },\r\n sincos_cos: { value: 0.0, writable: true },\r\n signbit: {\r\n value: function signbit(x) {\r\n F64[0] = x; return Boolean((U64[1] >>> 31) & (x == x));\r\n }\r\n },\r\n sincos: {\r\n value: function sincos(x) {\r\n this.sincos_sin = Math.sin(x);\r\n this.sincos_cos = Math.cos(x);\r\n }\r\n }\r\n});\r\n\r\nglobalScope[\"memory\"] = (() => {\r\n var HEAP = new Uint8Array(0);\r\n var HEAP_OFFSET = 0;\r\n return {\r\n allocate: globalScope[\"__memory_allocate\"] || function allocate(size) {\r\n if (!(size >>>= 0)) return 0;\r\n if (HEAP_OFFSET + size > HEAP.length) {\r\n var oldHeap = HEAP;\r\n HEAP = new Uint8Array(Math.max(65536, HEAP.length + size, HEAP.length * 2));\r\n HEAP.set(oldHeap);\r\n }\r\n var ptr = HEAP_OFFSET;\r\n if ((HEAP_OFFSET += size) & 7) HEAP_OFFSET = (HEAP_OFFSET | 7) + 1;\r\n return ptr;\r\n },\r\n fill: globalScope[\"__memory_fill\"] || function fill(dest, value, size) {\r\n HEAP.fill(value, dest, dest + size);\r\n },\r\n free: globalScope[\"__memory_free\"] || function free(ptr) { },\r\n copy: globalScope[\"__memory_copy\"] || function copy(dest, src, size) {\r\n HEAP.copyWithin(dest, src, src + size);\r\n },\r\n reset: globalScope[\"__memory_reset\"] || function reset() {\r\n HEAP = new Uint8Array(0);\r\n HEAP_OFFSET = 0;\r\n }\r\n };\r\n})();\r\n\r\nglobalScope[\"store\"] = globalScope[\"__store\"] || function store(ptr, value, offset) {\r\n HEAP[(ptr | 0) + (offset | 0)] = value;\r\n};\r\n\r\nglobalScope[\"load\"] = globalScope[\"__load\"] || function load(ptr, offset) {\r\n return HEAP[(ptr | 0) + (offset | 0)];\r\n};\r\n\r\nglobalScope[\"unmanaged\"] = function() {};\r\n","const F64 = new Float64Array(1);\r\nconst F32 = new Float32Array(F64.buffer);\r\nconst I32 = new Int32Array(F64.buffer);\r\n\r\nglobal.f32_as_i32 = function(value) {\r\n F32[0] = value;\r\n return I32[0];\r\n};\r\n\r\nglobal.i32_as_f32 = function(value) {\r\n I32[0] = value;\r\n return F32[0];\r\n};\r\n\r\nglobal.f64_as_i64 = function(value) {\r\n F64[0] = value;\r\n return i64_new(I32[0], I32[1]);\r\n};\r\n\r\nglobal.i64_as_f64 = function(value) {\r\n I32[0] = i64_low(value);\r\n I32[1] = i64_high(value);\r\n return F64[0];\r\n};\r\n","const Long = global.Long || require(\"long\");\r\n\r\nglobal.i64_zero = Long.ZERO;\r\n\r\nglobal.i64_one = Long.ONE;\r\n\r\nglobal.i64_new = function(lo, hi) {\r\n return Long.fromBits(lo, hi);\r\n};\r\n\r\nglobal.i64_low = function(value) {\r\n return value.low;\r\n};\r\n\r\nglobal.i64_high = function(value) {\r\n return value.high;\r\n};\r\n\r\nglobal.i64_add = function(left, right) {\r\n return left.add(right);\r\n};\r\n\r\nglobal.i64_sub = function(left, right) {\r\n return left.sub(right);\r\n};\r\n\r\nglobal.i64_mul = function(left, right) {\r\n return left.mul(right);\r\n};\r\n\r\nglobal.i64_div = function(left, right) {\r\n return left.div(right);\r\n};\r\n\r\nglobal.i64_div_u = function(left, right) {\r\n return left.toUnsigned().div(right.toUnsigned()).toSigned();\r\n};\r\n\r\nglobal.i64_rem = function(left, right) {\r\n return left.mod(right);\r\n};\r\n\r\nglobal.i64_rem_u = function(left, right) {\r\n return left.toUnsigned().mod(right.toUnsigned()).toSigned();\r\n};\r\n\r\nglobal.i64_and = function(left, right) {\r\n return left.and(right);\r\n};\r\n\r\nglobal.i64_or = function(left, right) {\r\n return left.or(right);\r\n};\r\n\r\nglobal.i64_xor = function(left, right) {\r\n return left.xor(right);\r\n};\r\n\r\nglobal.i64_shl = function(left, right) {\r\n return left.shl(right);\r\n};\r\n\r\nglobal.i64_shr = function(left, right) {\r\n return left.shr(right);\r\n};\r\n\r\nglobal.i64_shr_u = function(left, right) {\r\n return left.shru(right);\r\n};\r\n\r\nglobal.i64_not = function(value) {\r\n return value.not();\r\n};\r\n\r\nglobal.i64_eq = function(left, right) {\r\n return left.eq(right);\r\n};\r\n\r\nglobal.i64_ne = function(left, right) {\r\n return left.ne(right);\r\n};\r\n\r\nglobal.i64_align = function(value, alignment) {\r\n assert(alignment && (alignment & (alignment - 1)) == 0);\r\n var mask = Long.fromInt(alignment - 1);\r\n return value.add(mask).and(mask.not());\r\n};\r\n\r\nglobal.i64_is_i8 = function(value) {\r\n return value.high === 0 && (value.low >= 0 && value.low <= i8.MAX_VALUE)\r\n || value.high === -1 && (value.low >= i8.MIN_VALUE && value.low < 0);\r\n};\r\n\r\nglobal.i64_is_i16 = function(value) {\r\n return value.high === 0 && (value.low >= 0 && value.low <= i16.MAX_VALUE)\r\n || value.high === -1 && (value.low >= i16.MIN_VALUE && value.low < 0);\r\n};\r\n\r\nglobal.i64_is_i32 = function(value) {\r\n return (value.high === 0 && value.low >= 0)\r\n || (value.high === -1 && value.low < 0);\r\n};\r\n\r\nglobal.i64_is_u8 = function(value) {\r\n return value.high === 0 && value.low >= 0 && value.low <= u8.MAX_VALUE;\r\n};\r\n\r\nglobal.i64_is_u16 = function(value) {\r\n return value.high === 0 && value.low >= 0 && value.low <= u16.MAX_VALUE;\r\n};\r\n\r\nglobal.i64_is_u32 = function(value) {\r\n return value.high === 0;\r\n};\r\n\r\nglobal.i64_is_bool = function(value) {\r\n return value.high === 0 && (value.low === 0 || value.low === 1);\r\n};\r\n\r\nconst minSafeF32 = Long.fromNumber(f32.MIN_SAFE_INTEGER);\r\nconst maxSafeF32 = Long.fromNumber(f32.MAX_SAFE_INTEGER);\r\n\r\nglobal.i64_is_f32 = function(value) {\r\n return value.gte(minSafeF32) && value.lte(maxSafeF32);\r\n};\r\n\r\nconst minSafeF64 = Long.fromNumber(f64.MIN_SAFE_INTEGER);\r\nconst maxSafeF64 = Long.fromNumber(f64.MAX_SAFE_INTEGER);\r\n\r\nglobal.i64_is_f64 = function(value) {\r\n return value.gte(minSafeF64) && value.lte(maxSafeF64);\r\n};\r\n\r\nglobal.i64_to_f32 = function(value) {\r\n return global.Math.fround(value.toNumber());\r\n};\r\n\r\nglobal.i64_to_f64 = function(value) {\r\n return value.toNumber();\r\n};\r\n\r\nglobal.i64_to_string = function(value, unsigned) {\r\n return (unsigned ? value.toUnsigned() : value).toString(10);\r\n};\r\n","module.exports = Long;\r\n\r\n/**\r\n * wasm optimizations, to do native i64 multiplication and divide\r\n */\r\nvar wasm = null;\r\n\r\ntry {\r\n wasm = new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([\r\n 0, 97, 115, 109, 1, 0, 0, 0, 1, 13, 2, 96, 0, 1, 127, 96, 4, 127, 127, 127, 127, 1, 127, 3, 7, 6, 0, 1, 1, 1, 1, 1, 6, 6, 1, 127, 1, 65, 0, 11, 7, 50, 6, 3, 109, 117, 108, 0, 1, 5, 100, 105, 118, 95, 115, 0, 2, 5, 100, 105, 118, 95, 117, 0, 3, 5, 114, 101, 109, 95, 115, 0, 4, 5, 114, 101, 109, 95, 117, 0, 5, 8, 103, 101, 116, 95, 104, 105, 103, 104, 0, 0, 10, 191, 1, 6, 4, 0, 35, 0, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 126, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 127, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 128, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 129, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 130, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11\r\n ])), {}).exports;\r\n} catch (e) {\r\n // no wasm support :(\r\n}\r\n\r\n/**\r\n * Constructs a 64 bit two's-complement integer, given its low and high 32 bit values as *signed* integers.\r\n * See the from* functions below for more convenient ways of constructing Longs.\r\n * @exports Long\r\n * @class A Long class for representing a 64 bit two's-complement integer value.\r\n * @param {number} low The low (signed) 32 bits of the long\r\n * @param {number} high The high (signed) 32 bits of the long\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @constructor\r\n */\r\nfunction Long(low, high, unsigned) {\r\n\r\n /**\r\n * The low 32 bits as a signed value.\r\n * @type {number}\r\n */\r\n this.low = low | 0;\r\n\r\n /**\r\n * The high 32 bits as a signed value.\r\n * @type {number}\r\n */\r\n this.high = high | 0;\r\n\r\n /**\r\n * Whether unsigned or not.\r\n * @type {boolean}\r\n */\r\n this.unsigned = !!unsigned;\r\n}\r\n\r\n// The internal representation of a long is the two given signed, 32-bit values.\r\n// We use 32-bit pieces because these are the size of integers on which\r\n// Javascript performs bit-operations. For operations like addition and\r\n// multiplication, we split each number into 16 bit pieces, which can easily be\r\n// multiplied within Javascript's floating-point representation without overflow\r\n// or change in sign.\r\n//\r\n// In the algorithms below, we frequently reduce the negative case to the\r\n// positive case by negating the input(s) and then post-processing the result.\r\n// Note that we must ALWAYS check specially whether those values are MIN_VALUE\r\n// (-2^63) because -MIN_VALUE == MIN_VALUE (since 2^63 cannot be represented as\r\n// a positive number, it overflows back into a negative). Not handling this\r\n// case would often result in infinite recursion.\r\n//\r\n// Common constant values ZERO, ONE, NEG_ONE, etc. are defined below the from*\r\n// methods on which they depend.\r\n\r\n/**\r\n * An indicator used to reliably determine if an object is a Long or not.\r\n * @type {boolean}\r\n * @const\r\n * @private\r\n */\r\nLong.prototype.__isLong__;\r\n\r\nObject.defineProperty(Long.prototype, \"__isLong__\", { value: true });\r\n\r\n/**\r\n * @function\r\n * @param {*} obj Object\r\n * @returns {boolean}\r\n * @inner\r\n */\r\nfunction isLong(obj) {\r\n return (obj && obj[\"__isLong__\"]) === true;\r\n}\r\n\r\n/**\r\n * Tests if the specified object is a Long.\r\n * @function\r\n * @param {*} obj Object\r\n * @returns {boolean}\r\n */\r\nLong.isLong = isLong;\r\n\r\n/**\r\n * A cache of the Long representations of small integer values.\r\n * @type {!Object}\r\n * @inner\r\n */\r\nvar INT_CACHE = {};\r\n\r\n/**\r\n * A cache of the Long representations of small unsigned integer values.\r\n * @type {!Object}\r\n * @inner\r\n */\r\nvar UINT_CACHE = {};\r\n\r\n/**\r\n * @param {number} value\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromInt(value, unsigned) {\r\n var obj, cachedObj, cache;\r\n if (unsigned) {\r\n value >>>= 0;\r\n if (cache = (0 <= value && value < 256)) {\r\n cachedObj = UINT_CACHE[value];\r\n if (cachedObj)\r\n return cachedObj;\r\n }\r\n obj = fromBits(value, (value | 0) < 0 ? -1 : 0, true);\r\n if (cache)\r\n UINT_CACHE[value] = obj;\r\n return obj;\r\n } else {\r\n value |= 0;\r\n if (cache = (-128 <= value && value < 128)) {\r\n cachedObj = INT_CACHE[value];\r\n if (cachedObj)\r\n return cachedObj;\r\n }\r\n obj = fromBits(value, value < 0 ? -1 : 0, false);\r\n if (cache)\r\n INT_CACHE[value] = obj;\r\n return obj;\r\n }\r\n}\r\n\r\n/**\r\n * Returns a Long representing the given 32 bit integer value.\r\n * @function\r\n * @param {number} value The 32 bit integer in question\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromInt = fromInt;\r\n\r\n/**\r\n * @param {number} value\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromNumber(value, unsigned) {\r\n if (isNaN(value))\r\n return unsigned ? UZERO : ZERO;\r\n if (unsigned) {\r\n if (value < 0)\r\n return UZERO;\r\n if (value >= TWO_PWR_64_DBL)\r\n return MAX_UNSIGNED_VALUE;\r\n } else {\r\n if (value <= -TWO_PWR_63_DBL)\r\n return MIN_VALUE;\r\n if (value + 1 >= TWO_PWR_63_DBL)\r\n return MAX_VALUE;\r\n }\r\n if (value < 0)\r\n return fromNumber(-value, unsigned).neg();\r\n return fromBits((value % TWO_PWR_32_DBL) | 0, (value / TWO_PWR_32_DBL) | 0, unsigned);\r\n}\r\n\r\n/**\r\n * Returns a Long representing the given value, provided that it is a finite number. Otherwise, zero is returned.\r\n * @function\r\n * @param {number} value The number in question\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromNumber = fromNumber;\r\n\r\n/**\r\n * @param {number} lowBits\r\n * @param {number} highBits\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromBits(lowBits, highBits, unsigned) {\r\n return new Long(lowBits, highBits, unsigned);\r\n}\r\n\r\n/**\r\n * Returns a Long representing the 64 bit integer that comes by concatenating the given low and high bits. Each is\r\n * assumed to use 32 bits.\r\n * @function\r\n * @param {number} lowBits The low 32 bits\r\n * @param {number} highBits The high 32 bits\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromBits = fromBits;\r\n\r\n/**\r\n * @function\r\n * @param {number} base\r\n * @param {number} exponent\r\n * @returns {number}\r\n * @inner\r\n */\r\nvar pow_dbl = Math.pow; // Used 4 times (4*8 to 15+4)\r\n\r\n/**\r\n * @param {string} str\r\n * @param {(boolean|number)=} unsigned\r\n * @param {number=} radix\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromString(str, unsigned, radix) {\r\n if (str.length === 0)\r\n throw Error('empty string');\r\n if (str === \"NaN\" || str === \"Infinity\" || str === \"+Infinity\" || str === \"-Infinity\")\r\n return ZERO;\r\n if (typeof unsigned === 'number') {\r\n // For goog.math.long compatibility\r\n radix = unsigned,\r\n unsigned = false;\r\n } else {\r\n unsigned = !! unsigned;\r\n }\r\n radix = radix || 10;\r\n if (radix < 2 || 36 < radix)\r\n throw RangeError('radix');\r\n\r\n var p;\r\n if ((p = str.indexOf('-')) > 0)\r\n throw Error('interior hyphen');\r\n else if (p === 0) {\r\n return fromString(str.substring(1), unsigned, radix).neg();\r\n }\r\n\r\n // Do several (8) digits each time through the loop, so as to\r\n // minimize the calls to the very expensive emulated div.\r\n var radixToPower = fromNumber(pow_dbl(radix, 8));\r\n\r\n var result = ZERO;\r\n for (var i = 0; i < str.length; i += 8) {\r\n var size = Math.min(8, str.length - i),\r\n value = parseInt(str.substring(i, i + size), radix);\r\n if (size < 8) {\r\n var power = fromNumber(pow_dbl(radix, size));\r\n result = result.mul(power).add(fromNumber(value));\r\n } else {\r\n result = result.mul(radixToPower);\r\n result = result.add(fromNumber(value));\r\n }\r\n }\r\n result.unsigned = unsigned;\r\n return result;\r\n}\r\n\r\n/**\r\n * Returns a Long representation of the given string, written using the specified radix.\r\n * @function\r\n * @param {string} str The textual representation of the Long\r\n * @param {(boolean|number)=} unsigned Whether unsigned or not, defaults to signed\r\n * @param {number=} radix The radix in which the text is written (2-36), defaults to 10\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromString = fromString;\r\n\r\n/**\r\n * @function\r\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromValue(val, unsigned) {\r\n if (typeof val === 'number')\r\n return fromNumber(val, unsigned);\r\n if (typeof val === 'string')\r\n return fromString(val, unsigned);\r\n // Throws for non-objects, converts non-instanceof Long:\r\n return fromBits(val.low, val.high, typeof unsigned === 'boolean' ? unsigned : val.unsigned);\r\n}\r\n\r\n/**\r\n * Converts the specified value to a Long using the appropriate from* function for its type.\r\n * @function\r\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val Value\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long}\r\n */\r\nLong.fromValue = fromValue;\r\n\r\n// NOTE: the compiler should inline these constant values below and then remove these variables, so there should be\r\n// no runtime penalty for these.\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_16_DBL = 1 << 16;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_24_DBL = 1 << 24;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_32_DBL = TWO_PWR_16_DBL * TWO_PWR_16_DBL;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_64_DBL = TWO_PWR_32_DBL * TWO_PWR_32_DBL;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_63_DBL = TWO_PWR_64_DBL / 2;\r\n\r\n/**\r\n * @type {!Long}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_24 = fromInt(TWO_PWR_24_DBL);\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar ZERO = fromInt(0);\r\n\r\n/**\r\n * Signed zero.\r\n * @type {!Long}\r\n */\r\nLong.ZERO = ZERO;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar UZERO = fromInt(0, true);\r\n\r\n/**\r\n * Unsigned zero.\r\n * @type {!Long}\r\n */\r\nLong.UZERO = UZERO;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar ONE = fromInt(1);\r\n\r\n/**\r\n * Signed one.\r\n * @type {!Long}\r\n */\r\nLong.ONE = ONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar UONE = fromInt(1, true);\r\n\r\n/**\r\n * Unsigned one.\r\n * @type {!Long}\r\n */\r\nLong.UONE = UONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar NEG_ONE = fromInt(-1);\r\n\r\n/**\r\n * Signed negative one.\r\n * @type {!Long}\r\n */\r\nLong.NEG_ONE = NEG_ONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MAX_VALUE = fromBits(0xFFFFFFFF|0, 0x7FFFFFFF|0, false);\r\n\r\n/**\r\n * Maximum signed value.\r\n * @type {!Long}\r\n */\r\nLong.MAX_VALUE = MAX_VALUE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MAX_UNSIGNED_VALUE = fromBits(0xFFFFFFFF|0, 0xFFFFFFFF|0, true);\r\n\r\n/**\r\n * Maximum unsigned value.\r\n * @type {!Long}\r\n */\r\nLong.MAX_UNSIGNED_VALUE = MAX_UNSIGNED_VALUE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MIN_VALUE = fromBits(0, 0x80000000|0, false);\r\n\r\n/**\r\n * Minimum signed value.\r\n * @type {!Long}\r\n */\r\nLong.MIN_VALUE = MIN_VALUE;\r\n\r\n/**\r\n * @alias Long.prototype\r\n * @inner\r\n */\r\nvar LongPrototype = Long.prototype;\r\n\r\n/**\r\n * Converts the Long to a 32 bit integer, assuming it is a 32 bit integer.\r\n * @returns {number}\r\n */\r\nLongPrototype.toInt = function toInt() {\r\n return this.unsigned ? this.low >>> 0 : this.low;\r\n};\r\n\r\n/**\r\n * Converts the Long to a the nearest floating-point representation of this value (double, 53 bit mantissa).\r\n * @returns {number}\r\n */\r\nLongPrototype.toNumber = function toNumber() {\r\n if (this.unsigned)\r\n return ((this.high >>> 0) * TWO_PWR_32_DBL) + (this.low >>> 0);\r\n return this.high * TWO_PWR_32_DBL + (this.low >>> 0);\r\n};\r\n\r\n/**\r\n * Converts the Long to a string written in the specified radix.\r\n * @param {number=} radix Radix (2-36), defaults to 10\r\n * @returns {string}\r\n * @override\r\n * @throws {RangeError} If `radix` is out of range\r\n */\r\nLongPrototype.toString = function toString(radix) {\r\n radix = radix || 10;\r\n if (radix < 2 || 36 < radix)\r\n throw RangeError('radix');\r\n if (this.isZero())\r\n return '0';\r\n if (this.isNegative()) { // Unsigned Longs are never negative\r\n if (this.eq(MIN_VALUE)) {\r\n // We need to change the Long value before it can be negated, so we remove\r\n // the bottom-most digit in this base and then recurse to do the rest.\r\n var radixLong = fromNumber(radix),\r\n div = this.div(radixLong),\r\n rem1 = div.mul(radixLong).sub(this);\r\n return div.toString(radix) + rem1.toInt().toString(radix);\r\n } else\r\n return '-' + this.neg().toString(radix);\r\n }\r\n\r\n // Do several (6) digits each time through the loop, so as to\r\n // minimize the calls to the very expensive emulated div.\r\n var radixToPower = fromNumber(pow_dbl(radix, 6), this.unsigned),\r\n rem = this;\r\n var result = '';\r\n while (true) {\r\n var remDiv = rem.div(radixToPower),\r\n intval = rem.sub(remDiv.mul(radixToPower)).toInt() >>> 0,\r\n digits = intval.toString(radix);\r\n rem = remDiv;\r\n if (rem.isZero())\r\n return digits + result;\r\n else {\r\n while (digits.length < 6)\r\n digits = '0' + digits;\r\n result = '' + digits + result;\r\n }\r\n }\r\n};\r\n\r\n/**\r\n * Gets the high 32 bits as a signed integer.\r\n * @returns {number} Signed high bits\r\n */\r\nLongPrototype.getHighBits = function getHighBits() {\r\n return this.high;\r\n};\r\n\r\n/**\r\n * Gets the high 32 bits as an unsigned integer.\r\n * @returns {number} Unsigned high bits\r\n */\r\nLongPrototype.getHighBitsUnsigned = function getHighBitsUnsigned() {\r\n return this.high >>> 0;\r\n};\r\n\r\n/**\r\n * Gets the low 32 bits as a signed integer.\r\n * @returns {number} Signed low bits\r\n */\r\nLongPrototype.getLowBits = function getLowBits() {\r\n return this.low;\r\n};\r\n\r\n/**\r\n * Gets the low 32 bits as an unsigned integer.\r\n * @returns {number} Unsigned low bits\r\n */\r\nLongPrototype.getLowBitsUnsigned = function getLowBitsUnsigned() {\r\n return this.low >>> 0;\r\n};\r\n\r\n/**\r\n * Gets the number of bits needed to represent the absolute value of this Long.\r\n * @returns {number}\r\n */\r\nLongPrototype.getNumBitsAbs = function getNumBitsAbs() {\r\n if (this.isNegative()) // Unsigned Longs are never negative\r\n return this.eq(MIN_VALUE) ? 64 : this.neg().getNumBitsAbs();\r\n var val = this.high != 0 ? this.high : this.low;\r\n for (var bit = 31; bit > 0; bit--)\r\n if ((val & (1 << bit)) != 0)\r\n break;\r\n return this.high != 0 ? bit + 33 : bit + 1;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals zero.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isZero = function isZero() {\r\n return this.high === 0 && this.low === 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals zero. This is an alias of {@link Long#isZero}.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.eqz = LongPrototype.isZero;\r\n\r\n/**\r\n * Tests if this Long's value is negative.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isNegative = function isNegative() {\r\n return !this.unsigned && this.high < 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is positive.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isPositive = function isPositive() {\r\n return this.unsigned || this.high >= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is odd.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isOdd = function isOdd() {\r\n return (this.low & 1) === 1;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is even.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isEven = function isEven() {\r\n return (this.low & 1) === 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.equals = function equals(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n if (this.unsigned !== other.unsigned && (this.high >>> 31) === 1 && (other.high >>> 31) === 1)\r\n return false;\r\n return this.high === other.high && this.low === other.low;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals the specified's. This is an alias of {@link Long#equals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.eq = LongPrototype.equals;\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.notEquals = function notEquals(other) {\r\n return !this.eq(/* validates */ other);\r\n};\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.neq = LongPrototype.notEquals;\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.ne = LongPrototype.notEquals;\r\n\r\n/**\r\n * Tests if this Long's value is less than the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lessThan = function lessThan(other) {\r\n return this.comp(/* validates */ other) < 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is less than the specified's. This is an alias of {@link Long#lessThan}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lt = LongPrototype.lessThan;\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lessThanOrEqual = function lessThanOrEqual(other) {\r\n return this.comp(/* validates */ other) <= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lte = LongPrototype.lessThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.le = LongPrototype.lessThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is greater than the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.greaterThan = function greaterThan(other) {\r\n return this.comp(/* validates */ other) > 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is greater than the specified's. This is an alias of {@link Long#greaterThan}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.gt = LongPrototype.greaterThan;\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.greaterThanOrEqual = function greaterThanOrEqual(other) {\r\n return this.comp(/* validates */ other) >= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.gte = LongPrototype.greaterThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.ge = LongPrototype.greaterThanOrEqual;\r\n\r\n/**\r\n * Compares this Long's value with the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\r\n * if the given one is greater\r\n */\r\nLongPrototype.compare = function compare(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n if (this.eq(other))\r\n return 0;\r\n var thisNeg = this.isNegative(),\r\n otherNeg = other.isNegative();\r\n if (thisNeg && !otherNeg)\r\n return -1;\r\n if (!thisNeg && otherNeg)\r\n return 1;\r\n // At this point the sign bits are the same\r\n if (!this.unsigned)\r\n return this.sub(other).isNegative() ? -1 : 1;\r\n // Both are positive if at least one is unsigned\r\n return (other.high >>> 0) > (this.high >>> 0) || (other.high === this.high && (other.low >>> 0) > (this.low >>> 0)) ? -1 : 1;\r\n};\r\n\r\n/**\r\n * Compares this Long's value with the specified's. This is an alias of {@link Long#compare}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\r\n * if the given one is greater\r\n */\r\nLongPrototype.comp = LongPrototype.compare;\r\n\r\n/**\r\n * Negates this Long's value.\r\n * @returns {!Long} Negated Long\r\n */\r\nLongPrototype.negate = function negate() {\r\n if (!this.unsigned && this.eq(MIN_VALUE))\r\n return MIN_VALUE;\r\n return this.not().add(ONE);\r\n};\r\n\r\n/**\r\n * Negates this Long's value. This is an alias of {@link Long#negate}.\r\n * @function\r\n * @returns {!Long} Negated Long\r\n */\r\nLongPrototype.neg = LongPrototype.negate;\r\n\r\n/**\r\n * Returns the sum of this and the specified Long.\r\n * @param {!Long|number|string} addend Addend\r\n * @returns {!Long} Sum\r\n */\r\nLongPrototype.add = function add(addend) {\r\n if (!isLong(addend))\r\n addend = fromValue(addend);\r\n\r\n // Divide each number into 4 chunks of 16 bits, and then sum the chunks.\r\n\r\n var a48 = this.high >>> 16;\r\n var a32 = this.high & 0xFFFF;\r\n var a16 = this.low >>> 16;\r\n var a00 = this.low & 0xFFFF;\r\n\r\n var b48 = addend.high >>> 16;\r\n var b32 = addend.high & 0xFFFF;\r\n var b16 = addend.low >>> 16;\r\n var b00 = addend.low & 0xFFFF;\r\n\r\n var c48 = 0, c32 = 0, c16 = 0, c00 = 0;\r\n c00 += a00 + b00;\r\n c16 += c00 >>> 16;\r\n c00 &= 0xFFFF;\r\n c16 += a16 + b16;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c32 += a32 + b32;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c48 += a48 + b48;\r\n c48 &= 0xFFFF;\r\n return fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the difference of this and the specified Long.\r\n * @param {!Long|number|string} subtrahend Subtrahend\r\n * @returns {!Long} Difference\r\n */\r\nLongPrototype.subtract = function subtract(subtrahend) {\r\n if (!isLong(subtrahend))\r\n subtrahend = fromValue(subtrahend);\r\n return this.add(subtrahend.neg());\r\n};\r\n\r\n/**\r\n * Returns the difference of this and the specified Long. This is an alias of {@link Long#subtract}.\r\n * @function\r\n * @param {!Long|number|string} subtrahend Subtrahend\r\n * @returns {!Long} Difference\r\n */\r\nLongPrototype.sub = LongPrototype.subtract;\r\n\r\n/**\r\n * Returns the product of this and the specified Long.\r\n * @param {!Long|number|string} multiplier Multiplier\r\n * @returns {!Long} Product\r\n */\r\nLongPrototype.multiply = function multiply(multiplier) {\r\n if (this.isZero())\r\n return ZERO;\r\n if (!isLong(multiplier))\r\n multiplier = fromValue(multiplier);\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n var low = wasm.mul(this.low,\r\n this.high,\r\n multiplier.low,\r\n multiplier.high);\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n if (multiplier.isZero())\r\n return ZERO;\r\n if (this.eq(MIN_VALUE))\r\n return multiplier.isOdd() ? MIN_VALUE : ZERO;\r\n if (multiplier.eq(MIN_VALUE))\r\n return this.isOdd() ? MIN_VALUE : ZERO;\r\n\r\n if (this.isNegative()) {\r\n if (multiplier.isNegative())\r\n return this.neg().mul(multiplier.neg());\r\n else\r\n return this.neg().mul(multiplier).neg();\r\n } else if (multiplier.isNegative())\r\n return this.mul(multiplier.neg()).neg();\r\n\r\n // If both longs are small, use float multiplication\r\n if (this.lt(TWO_PWR_24) && multiplier.lt(TWO_PWR_24))\r\n return fromNumber(this.toNumber() * multiplier.toNumber(), this.unsigned);\r\n\r\n // Divide each long into 4 chunks of 16 bits, and then add up 4x4 products.\r\n // We can skip products that would overflow.\r\n\r\n var a48 = this.high >>> 16;\r\n var a32 = this.high & 0xFFFF;\r\n var a16 = this.low >>> 16;\r\n var a00 = this.low & 0xFFFF;\r\n\r\n var b48 = multiplier.high >>> 16;\r\n var b32 = multiplier.high & 0xFFFF;\r\n var b16 = multiplier.low >>> 16;\r\n var b00 = multiplier.low & 0xFFFF;\r\n\r\n var c48 = 0, c32 = 0, c16 = 0, c00 = 0;\r\n c00 += a00 * b00;\r\n c16 += c00 >>> 16;\r\n c00 &= 0xFFFF;\r\n c16 += a16 * b00;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c16 += a00 * b16;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c32 += a32 * b00;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c32 += a16 * b16;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c32 += a00 * b32;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c48 += a48 * b00 + a32 * b16 + a16 * b32 + a00 * b48;\r\n c48 &= 0xFFFF;\r\n return fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the product of this and the specified Long. This is an alias of {@link Long#multiply}.\r\n * @function\r\n * @param {!Long|number|string} multiplier Multiplier\r\n * @returns {!Long} Product\r\n */\r\nLongPrototype.mul = LongPrototype.multiply;\r\n\r\n/**\r\n * Returns this Long divided by the specified. The result is signed if this Long is signed or\r\n * unsigned if this Long is unsigned.\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Quotient\r\n */\r\nLongPrototype.divide = function divide(divisor) {\r\n if (!isLong(divisor))\r\n divisor = fromValue(divisor);\r\n if (divisor.isZero())\r\n throw Error('division by zero');\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n // guard against signed division overflow: the largest\r\n // negative number / -1 would be 1 larger than the largest\r\n // positive number, due to two's complement.\r\n if (!this.unsigned &&\r\n this.high === -0x80000000 &&\r\n divisor.low === -1 && divisor.high === -1) {\r\n // be consistent with non-wasm code path\r\n return this;\r\n }\r\n var low = (this.unsigned ? wasm.div_u : wasm.div_s)(\r\n this.low,\r\n this.high,\r\n divisor.low,\r\n divisor.high\r\n );\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n if (this.isZero())\r\n return this.unsigned ? UZERO : ZERO;\r\n var approx, rem, res;\r\n if (!this.unsigned) {\r\n // This section is only relevant for signed longs and is derived from the\r\n // closure library as a whole.\r\n if (this.eq(MIN_VALUE)) {\r\n if (divisor.eq(ONE) || divisor.eq(NEG_ONE))\r\n return MIN_VALUE; // recall that -MIN_VALUE == MIN_VALUE\r\n else if (divisor.eq(MIN_VALUE))\r\n return ONE;\r\n else {\r\n // At this point, we have |other| >= 2, so |this/other| < |MIN_VALUE|.\r\n var halfThis = this.shr(1);\r\n approx = halfThis.div(divisor).shl(1);\r\n if (approx.eq(ZERO)) {\r\n return divisor.isNegative() ? ONE : NEG_ONE;\r\n } else {\r\n rem = this.sub(divisor.mul(approx));\r\n res = approx.add(rem.div(divisor));\r\n return res;\r\n }\r\n }\r\n } else if (divisor.eq(MIN_VALUE))\r\n return this.unsigned ? UZERO : ZERO;\r\n if (this.isNegative()) {\r\n if (divisor.isNegative())\r\n return this.neg().div(divisor.neg());\r\n return this.neg().div(divisor).neg();\r\n } else if (divisor.isNegative())\r\n return this.div(divisor.neg()).neg();\r\n res = ZERO;\r\n } else {\r\n // The algorithm below has not been made for unsigned longs. It's therefore\r\n // required to take special care of the MSB prior to running it.\r\n if (!divisor.unsigned)\r\n divisor = divisor.toUnsigned();\r\n if (divisor.gt(this))\r\n return UZERO;\r\n if (divisor.gt(this.shru(1))) // 15 >>> 1 = 7 ; with divisor = 8 ; true\r\n return UONE;\r\n res = UZERO;\r\n }\r\n\r\n // Repeat the following until the remainder is less than other: find a\r\n // floating-point that approximates remainder / other *from below*, add this\r\n // into the result, and subtract it from the remainder. It is critical that\r\n // the approximate value is less than or equal to the real value so that the\r\n // remainder never becomes negative.\r\n rem = this;\r\n while (rem.gte(divisor)) {\r\n // Approximate the result of division. This may be a little greater or\r\n // smaller than the actual value.\r\n approx = Math.max(1, Math.floor(rem.toNumber() / divisor.toNumber()));\r\n\r\n // We will tweak the approximate result by changing it in the 48-th digit or\r\n // the smallest non-fractional digit, whichever is larger.\r\n var log2 = Math.ceil(Math.log(approx) / Math.LN2),\r\n delta = (log2 <= 48) ? 1 : pow_dbl(2, log2 - 48),\r\n\r\n // Decrease the approximation until it is smaller than the remainder. Note\r\n // that if it is too large, the product overflows and is negative.\r\n approxRes = fromNumber(approx),\r\n approxRem = approxRes.mul(divisor);\r\n while (approxRem.isNegative() || approxRem.gt(rem)) {\r\n approx -= delta;\r\n approxRes = fromNumber(approx, this.unsigned);\r\n approxRem = approxRes.mul(divisor);\r\n }\r\n\r\n // We know the answer can't be zero... and actually, zero would cause\r\n // infinite recursion since we would make no progress.\r\n if (approxRes.isZero())\r\n approxRes = ONE;\r\n\r\n res = res.add(approxRes);\r\n rem = rem.sub(approxRem);\r\n }\r\n return res;\r\n};\r\n\r\n/**\r\n * Returns this Long divided by the specified. This is an alias of {@link Long#divide}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Quotient\r\n */\r\nLongPrototype.div = LongPrototype.divide;\r\n\r\n/**\r\n * Returns this Long modulo the specified.\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.modulo = function modulo(divisor) {\r\n if (!isLong(divisor))\r\n divisor = fromValue(divisor);\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n var low = (this.unsigned ? wasm.rem_u : wasm.rem_s)(\r\n this.low,\r\n this.high,\r\n divisor.low,\r\n divisor.high\r\n );\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n return this.sub(this.div(divisor).mul(divisor));\r\n};\r\n\r\n/**\r\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.mod = LongPrototype.modulo;\r\n\r\n/**\r\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.rem = LongPrototype.modulo;\r\n\r\n/**\r\n * Returns the bitwise NOT of this Long.\r\n * @returns {!Long}\r\n */\r\nLongPrototype.not = function not() {\r\n return fromBits(~this.low, ~this.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise AND of this Long and the specified.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.and = function and(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low & other.low, this.high & other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise OR of this Long and the specified.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.or = function or(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low | other.low, this.high | other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise XOR of this Long and the given one.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.xor = function xor(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low ^ other.low, this.high ^ other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits shifted to the left by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftLeft = function shiftLeft(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n if ((numBits &= 63) === 0)\r\n return this;\r\n else if (numBits < 32)\r\n return fromBits(this.low << numBits, (this.high << numBits) | (this.low >>> (32 - numBits)), this.unsigned);\r\n else\r\n return fromBits(0, this.low << (numBits - 32), this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits shifted to the left by the given amount. This is an alias of {@link Long#shiftLeft}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shl = LongPrototype.shiftLeft;\r\n\r\n/**\r\n * Returns this Long with bits arithmetically shifted to the right by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftRight = function shiftRight(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n if ((numBits &= 63) === 0)\r\n return this;\r\n else if (numBits < 32)\r\n return fromBits((this.low >>> numBits) | (this.high << (32 - numBits)), this.high >> numBits, this.unsigned);\r\n else\r\n return fromBits(this.high >> (numBits - 32), this.high >= 0 ? 0 : -1, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits arithmetically shifted to the right by the given amount. This is an alias of {@link Long#shiftRight}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shr = LongPrototype.shiftRight;\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftRightUnsigned = function shiftRightUnsigned(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n numBits &= 63;\r\n if (numBits === 0)\r\n return this;\r\n else {\r\n var high = this.high;\r\n if (numBits < 32) {\r\n var low = this.low;\r\n return fromBits((low >>> numBits) | (high << (32 - numBits)), high >>> numBits, this.unsigned);\r\n } else if (numBits === 32)\r\n return fromBits(high, 0, this.unsigned);\r\n else\r\n return fromBits(high >>> (numBits - 32), 0, this.unsigned);\r\n }\r\n};\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shru = LongPrototype.shiftRightUnsigned;\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shr_u = LongPrototype.shiftRightUnsigned;\r\n\r\n/**\r\n * Converts this Long to signed.\r\n * @returns {!Long} Signed long\r\n */\r\nLongPrototype.toSigned = function toSigned() {\r\n if (!this.unsigned)\r\n return this;\r\n return fromBits(this.low, this.high, false);\r\n};\r\n\r\n/**\r\n * Converts this Long to unsigned.\r\n * @returns {!Long} Unsigned long\r\n */\r\nLongPrototype.toUnsigned = function toUnsigned() {\r\n if (this.unsigned)\r\n return this;\r\n return fromBits(this.low, this.high, true);\r\n};\r\n\r\n/**\r\n * Converts this Long to its byte representation.\r\n * @param {boolean=} le Whether little or big endian, defaults to big endian\r\n * @returns {!Array.} Byte representation\r\n */\r\nLongPrototype.toBytes = function toBytes(le) {\r\n return le ? this.toBytesLE() : this.toBytesBE();\r\n};\r\n\r\n/**\r\n * Converts this Long to its little endian byte representation.\r\n * @returns {!Array.} Little endian byte representation\r\n */\r\nLongPrototype.toBytesLE = function toBytesLE() {\r\n var hi = this.high,\r\n lo = this.low;\r\n return [\r\n lo & 0xff,\r\n lo >>> 8 & 0xff,\r\n lo >>> 16 & 0xff,\r\n lo >>> 24 ,\r\n hi & 0xff,\r\n hi >>> 8 & 0xff,\r\n hi >>> 16 & 0xff,\r\n hi >>> 24\r\n ];\r\n};\r\n\r\n/**\r\n * Converts this Long to its big endian byte representation.\r\n * @returns {!Array.} Big endian byte representation\r\n */\r\nLongPrototype.toBytesBE = function toBytesBE() {\r\n var hi = this.high,\r\n lo = this.low;\r\n return [\r\n hi >>> 24 ,\r\n hi >>> 16 & 0xff,\r\n hi >>> 8 & 0xff,\r\n hi & 0xff,\r\n lo >>> 24 ,\r\n lo >>> 16 & 0xff,\r\n lo >>> 8 & 0xff,\r\n lo & 0xff\r\n ];\r\n};\r\n\r\n/**\r\n * Creates a Long from its byte representation.\r\n * @param {!Array.} bytes Byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @param {boolean=} le Whether little or big endian, defaults to big endian\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytes = function fromBytes(bytes, unsigned, le) {\r\n return le ? Long.fromBytesLE(bytes, unsigned) : Long.fromBytesBE(bytes, unsigned);\r\n};\r\n\r\n/**\r\n * Creates a Long from its little endian byte representation.\r\n * @param {!Array.} bytes Little endian byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytesLE = function fromBytesLE(bytes, unsigned) {\r\n return new Long(\r\n bytes[0] |\r\n bytes[1] << 8 |\r\n bytes[2] << 16 |\r\n bytes[3] << 24,\r\n bytes[4] |\r\n bytes[5] << 8 |\r\n bytes[6] << 16 |\r\n bytes[7] << 24,\r\n unsigned\r\n );\r\n};\r\n\r\n/**\r\n * Creates a Long from its big endian byte representation.\r\n * @param {!Array.} bytes Big endian byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytesBE = function fromBytesBE(bytes, unsigned) {\r\n return new Long(\r\n bytes[4] << 24 |\r\n bytes[5] << 16 |\r\n bytes[6] << 8 |\r\n bytes[7],\r\n bytes[0] << 24 |\r\n bytes[1] << 16 |\r\n bytes[2] << 8 |\r\n bytes[3],\r\n unsigned\r\n );\r\n};\r\n","// This file is shared with the compiler and must remain portable\r\n\r\n/** Indicates specific features to activate. */\r\nexport const enum Feature {\r\n /** No additional features. */\r\n NONE = 0,\r\n /** Sign extension operations. */\r\n SIGN_EXTENSION = 1 << 0, // see: https://github.com/WebAssembly/sign-extension-ops\r\n /** Mutable global imports and exports. */\r\n MUTABLE_GLOBAL = 1 << 1, // see: https://github.com/WebAssembly/mutable-global\r\n /** Bulk memory operations. */\r\n BULK_MEMORY = 1 << 2, // see: https://github.com/WebAssembly/bulk-memory-operations\r\n /** SIMD types and operations. */\r\n SIMD = 1 << 3, // see: https://github.com/WebAssembly/simd\r\n /** Threading and atomic operations. */\r\n THREADS = 1 << 4 // see: https://github.com/WebAssembly/threads\r\n}\r\n","// This file is shared with the compiler and must remain portable\r\n\r\n/** Compilation target. */\r\nexport enum Target {\r\n /** WebAssembly with 32-bit pointers. */\r\n WASM32,\r\n /** WebAssembly with 64-bit pointers. Experimental and not supported by any runtime yet. */\r\n WASM64,\r\n /** Portable. */\r\n JS\r\n}\r\n","// This file is shared with the compiler and must remain portable\r\n\r\n// ╒═══════════════════ Typeinfo interpretation ═══════════════════╕\r\n// 3 2 1\r\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\r\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤ ◄─ __rtti_base\r\n// │ count │\r\n// ╞═══════════════════════════════════════════════════════════════╡ ┐\r\n// │ Typeinfo#flags [id=0] │ id < count\r\n// ├ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ┤\r\n// │ Typeinfo#base [id=0] │\r\n// ├───────────────────────────────────────────────────────────────┤\r\n// │ ... │\r\n\r\n/** Runtime type information data structure. */\r\n@unmanaged\r\nexport class Typeinfo {\r\n /** Flags describing the shape of this class type. */\r\n flags: TypeinfoFlags;\r\n /** Base class id or `0` if none. */\r\n base: u32;\r\n}\r\n\r\n/** Runtime type information flags. */\r\nexport const enum TypeinfoFlags {\r\n /** No specific flags. */\r\n NONE = 0,\r\n /** Type is an `ArrayBufferView`. */\r\n ARRAYBUFFERVIEW = 1 << 0,\r\n /** Type is an `Array`. */\r\n ARRAY = 1 << 1,\r\n /** Type is a `Set`. */\r\n SET = 1 << 2,\r\n /** Type is a `Map`. */\r\n MAP = 1 << 3,\r\n /** Type is inherently acyclic. */\r\n ACYCLIC = 1 << 4,\r\n /** Value alignment of 1 byte. */\r\n VALUE_ALIGN_0 = 1 << 5,\r\n /** Value alignment of 2 bytes. */\r\n VALUE_ALIGN_1 = 1 << 6,\r\n /** Value alignment of 4 bytes. */\r\n VALUE_ALIGN_2 = 1 << 7,\r\n /** Value alignment of 8 bytes. */\r\n VALUE_ALIGN_3 = 1 << 8,\r\n /** Value alignment of 16 bytes. */\r\n VALUE_ALIGN_4 = 1 << 9,\r\n /** Value is a signed type. */\r\n VALUE_SIGNED = 1 << 10,\r\n /** Value is a float type. */\r\n VALUE_FLOAT = 1 << 11,\r\n /** Value type is nullable. */\r\n VALUE_NULLABLE = 1 << 12,\r\n /** Value type is managed. */\r\n VALUE_MANAGED = 1 << 13,\r\n /** Key alignment of 1 byte. */\r\n KEY_ALIGN_0 = 1 << 14,\r\n /** Key alignment of 2 bytes. */\r\n KEY_ALIGN_1 = 1 << 15,\r\n /** Key alignment of 4 bytes. */\r\n KEY_ALIGN_2 = 1 << 16,\r\n /** Key alignment of 8 bytes. */\r\n KEY_ALIGN_3 = 1 << 17,\r\n /** Key alignment of 16 bytes. */\r\n KEY_ALIGN_4 = 1 << 18,\r\n /** Value is a signed type. */\r\n KEY_SIGNED = 1 << 19,\r\n /** Value is a float type. */\r\n KEY_FLOAT = 1 << 20,\r\n /** Key type is nullable. */\r\n KEY_NULLABLE = 1 << 21,\r\n /** Key type is managed. */\r\n KEY_MANAGED = 1 << 22\r\n}\r\n","/**\r\n * Low-level C-like compiler API.\r\n * @module index\r\n *//***/\r\n\r\nimport { Target, Feature } from \"./common\";\r\nimport { Compiler, Options } from \"./compiler\";\r\nimport { Decompiler } from \"./decompiler\";\r\nimport { IDLBuilder, TSDBuilder } from \"./definitions\";\r\nimport { DiagnosticMessage, DiagnosticCategory, formatDiagnosticMessage } from \"./diagnostics\";\r\nimport { Module } from \"./module\";\r\nimport { Parser } from \"./parser\";\r\nimport { Program } from \"./program\";\r\n\r\n/** Parses a source file. If `parser` has been omitted a new one is created. */\r\nexport function parseFile(text: string, path: string, isEntry: bool = false,\r\n parser: Parser | null = null\r\n): Parser {\r\n if (!parser) parser = new Parser();\r\n parser.parseFile(text, path, isEntry);\r\n return parser;\r\n}\r\n\r\n/** Obtains the next required file's path. Returns `null` once complete. */\r\nexport function nextFile(parser: Parser): string | null {\r\n return parser.nextFile();\r\n}\r\n\r\n/** Obtains the next diagnostic message. Returns `null` once complete. */\r\nexport function nextDiagnostic(parser: Parser): DiagnosticMessage | null {\r\n var program = parser.program;\r\n return program.diagnosticsOffset < program.diagnostics.length\r\n ? program.diagnostics[program.diagnosticsOffset++]\r\n : null;\r\n}\r\n\r\n/** Formats a diagnostic message to a string. */\r\nexport { formatDiagnosticMessage as formatDiagnostic };\r\n\r\n/** Tests whether a diagnostic is informatory. */\r\nexport function isInfo(message: DiagnosticMessage): bool {\r\n return message.category == DiagnosticCategory.INFO;\r\n}\r\n\r\n/** Tests whether a diagnostic is a warning. */\r\nexport function isWarning(message: DiagnosticMessage): bool {\r\n return message.category == DiagnosticCategory.WARNING;\r\n}\r\n\r\n/** Tests whether a diagnostic is an error. */\r\nexport function isError(message: DiagnosticMessage): bool {\r\n return message.category == DiagnosticCategory.ERROR;\r\n}\r\n\r\n/** Creates a new set of compiler options. */\r\nexport function createOptions(): Options {\r\n return new Options();\r\n}\r\n\r\n/** Sets the `target` option. */\r\nexport function setTarget(options: Options, target: Target): void {\r\n options.target = target;\r\n}\r\n\r\n/** Sets the `noAssert` option. */\r\nexport function setNoAssert(options: Options, noAssert: bool): void {\r\n options.noAssert = noAssert;\r\n}\r\n\r\n/** Sets the `importMemory` option. */\r\nexport function setImportMemory(options: Options, importMemory: bool): void {\r\n options.importMemory = importMemory;\r\n}\r\n\r\n/** Sets the `sharedMemory` option. */\r\nexport function setSharedMemory(options: Options, sharedMemory: i32): void {\r\n options.sharedMemory = sharedMemory;\r\n}\r\n\r\n/** Sets the `importTable` option. */\r\nexport function setImportTable(options: Options, importTable: bool): void {\r\n options.importTable = importTable;\r\n}\r\n\r\n/** Sets the `sourceMap` option. */\r\nexport function setSourceMap(options: Options, sourceMap: bool): void {\r\n options.sourceMap = sourceMap;\r\n}\r\n\r\n/** Sets the `memoryBase` option. */\r\nexport function setMemoryBase(options: Options, memoryBase: u32): void {\r\n options.memoryBase = memoryBase;\r\n}\r\n\r\n/** Sets a 'globalAliases' value. */\r\nexport function setGlobalAlias(options: Options, name: string, alias: string): void {\r\n var globalAliases = options.globalAliases;\r\n if (!globalAliases) options.globalAliases = globalAliases = new Map();\r\n globalAliases.set(name, alias);\r\n}\r\n\r\n/** Sets the `explicitStart` option. */\r\nexport function setExplicitStart(options: Options, explicitStart: bool): void {\r\n options.explicitStart = explicitStart;\r\n}\r\n\r\n/** Sign extension operations. */\r\nexport const FEATURE_SIGN_EXTENSION = Feature.SIGN_EXTENSION;\r\n/** Mutable global imports and exports. */\r\nexport const FEATURE_MUTABLE_GLOBAL = Feature.MUTABLE_GLOBAL;\r\n/** Bulk memory operations. */\r\nexport const FEATURE_BULK_MEMORY = Feature.BULK_MEMORY;\r\n/** SIMD types and operations. */\r\nexport const FEATURE_SIMD = Feature.SIMD;\r\n/** Threading and atomic operations. */\r\nexport const FEATURE_THREADS = Feature.THREADS;\r\n\r\n/** Enables a specific feature. */\r\nexport function enableFeature(options: Options, feature: Feature): void {\r\n options.features |= feature;\r\n}\r\n\r\n/** Gives the compiler a hint at the optimize levels that will be used later on. */\r\nexport function setOptimizeLevelHints(options: Options, optimizeLevel: i32, shrinkLevel: i32): void {\r\n options.optimizeLevelHint = optimizeLevel;\r\n options.shrinkLevelHint = shrinkLevel;\r\n}\r\n\r\n/** Finishes parsing. */\r\nexport function finishParsing(parser: Parser): Program {\r\n return parser.finish();\r\n}\r\n\r\n/** Compiles the sources computed by the parser to a module. */\r\nexport function compileProgram(program: Program, options: Options | null = null): Module {\r\n return new Compiler(program, options).compile();\r\n}\r\n\r\n/** Decompiles a module to its (low level) source. */\r\nexport function decompileModule(module: Module): string {\r\n var decompiler = new Decompiler();\r\n decompiler.decompile(module);\r\n return decompiler.finish();\r\n}\r\n\r\n/** Builds WebIDL definitions for the specified program. */\r\nexport function buildIDL(program: Program): string {\r\n return IDLBuilder.build(program);\r\n}\r\n\r\n/** Builds TypeScript definitions for the specified program. */\r\nexport function buildTSD(program: Program): string {\r\n return TSDBuilder.build(program);\r\n}\r\n\r\n/** Builds a JSON file of a program's runtime type information. */\r\nexport function buildRTTI(program: Program): string {\r\n var sb = new Array();\r\n sb.push(\"{\\n \\\"names\\\": [\\n\");\r\n for (let cls of program.managedClasses.values()) {\r\n sb.push(\" \\\"\");\r\n sb.push(cls.internalName);\r\n sb.push(\"\\\",\\n\");\r\n }\r\n sb.push(\" ],\\n \\\"base\\\": [\\n\");\r\n for (let cls of program.managedClasses.values()) {\r\n let base = cls.base;\r\n sb.push(\" \");\r\n sb.push(base ? base.id.toString() : \"0\");\r\n sb.push(\",\\n\");\r\n }\r\n sb.push(\" ],\\n \\\"flags\\\": [\\n\");\r\n for (let cls of program.managedClasses.values()) {\r\n sb.push(\" \");\r\n sb.push(cls.rttiFlags.toString());\r\n sb.push(\",\\n\");\r\n }\r\n sb.push(\" ]\\n}\\n\");\r\n return sb.join(\"\");\r\n}\r\n\r\n/** Prefix indicating a library file. */\r\nexport { LIBRARY_PREFIX } from \"./common\";\r\n\r\n// Full API\r\nexport * from \"./ast\";\r\n// export * from \"./binary\";\r\nexport * from \"./common\";\r\nexport * from \"./compiler\";\r\nexport * from \"./decompiler\";\r\nexport * from \"./definitions\";\r\nexport * from \"./diagnosticMessages.generated\";\r\nexport * from \"./diagnostics\";\r\nexport * from \"./flow\";\r\nexport * from \"./module\";\r\nexport * from \"./parser\";\r\nexport * from \"./program\";\r\nexport * from \"./resolver\";\r\nexport * from \"./tokenizer\";\r\nexport * from \"./types\";\r\nexport * from \"./util\";\r\n","/** @module util *//***/\r\n\r\n/** Tests if the bit at the specified index is set within a 64-bit map. */\r\nexport function bitsetIs(map: I64, index: i32): bool {\r\n assert(index >= 0 && index < 64);\r\n return i64_ne(\r\n i64_and(\r\n map,\r\n i64_shl(\r\n i64_one,\r\n i64_new(index)\r\n )\r\n ),\r\n i64_zero\r\n );\r\n}\r\n\r\n/** Sets or unsets the bit at the specified index within a 64-bit map and returns the new map. */\r\nexport function bitsetSet(map: I64, index: i32, isSet: bool): I64 {\r\n assert(index >= 0 && index < 64);\r\n return isSet\r\n ? i64_or(\r\n map,\r\n i64_shl(\r\n i64_one,\r\n i64_new(index)\r\n )\r\n )\r\n : i64_and(\r\n map,\r\n i64_not(\r\n i64_shl(\r\n i64_one,\r\n i64_new(index)\r\n )\r\n )\r\n );\r\n}\r\n","/** @module util *//***/\r\n\r\n/** An enum of named character codes. */\r\nexport const enum CharCode {\r\n\r\n NULL = 0,\r\n LINEFEED = 0x0A,\r\n CARRIAGERETURN = 0x0D,\r\n LINESEPARATOR = 0x2028,\r\n PARAGRAPHSEPARATOR = 0x2029,\r\n NEXTLINE = 0x0085,\r\n\r\n SPACE = 0x20,\r\n NONBREAKINGSPACE = 0xA0,\r\n ENQUAD = 0x2000,\r\n EMQUAD = 0x2001,\r\n ENSPACE = 0x2002,\r\n EMSPACE = 0x2003,\r\n THREEPEREMSPACE = 0x2004,\r\n FOURPEREMSPACE = 0x2005,\r\n SIXPEREMSPACE = 0x2006,\r\n FIGURESPACE = 0x2007,\r\n PUNCTUATIONSPACE = 0x2008,\r\n THINSPACE = 0x2009,\r\n HAIRSPACE = 0x200A,\r\n ZEROWIDTHSPACE = 0x200B,\r\n NARROWNOBREAKSPACE = 0x202F,\r\n IDEOGRAPHICSPACE = 0x3000,\r\n MATHEMATICALSPACE = 0x205F,\r\n OGHAM = 0x1680,\r\n\r\n _ = 0x5F,\r\n\r\n _0 = 0x30,\r\n _1 = 0x31,\r\n _2 = 0x32,\r\n _3 = 0x33,\r\n _4 = 0x34,\r\n _5 = 0x35,\r\n _6 = 0x36,\r\n _7 = 0x37,\r\n _8 = 0x38,\r\n _9 = 0x39,\r\n\r\n a = 0x61,\r\n b = 0x62,\r\n c = 0x63,\r\n d = 0x64,\r\n e = 0x65,\r\n f = 0x66,\r\n g = 0x67,\r\n h = 0x68,\r\n i = 0x69,\r\n j = 0x6A,\r\n k = 0x6B,\r\n l = 0x6C,\r\n m = 0x6D,\r\n n = 0x6E,\r\n o = 0x6F,\r\n p = 0x70,\r\n q = 0x71,\r\n r = 0x72,\r\n s = 0x73,\r\n t = 0x74,\r\n u = 0x75,\r\n v = 0x76,\r\n w = 0x77,\r\n x = 0x78,\r\n y = 0x79,\r\n z = 0x7A,\r\n\r\n A = 0x41,\r\n B = 0x42,\r\n C = 0x43,\r\n D = 0x44,\r\n E = 0x45,\r\n F = 0x46,\r\n G = 0x47,\r\n H = 0x48,\r\n I = 0x49,\r\n J = 0x4A,\r\n K = 0x4B,\r\n L = 0x4C,\r\n M = 0x4D,\r\n N = 0x4E,\r\n O = 0x4F,\r\n P = 0x50,\r\n Q = 0x51,\r\n R = 0x52,\r\n S = 0x53,\r\n T = 0x54,\r\n U = 0x55,\r\n V = 0x56,\r\n W = 0x57,\r\n X = 0x58,\r\n Y = 0x59,\r\n Z = 0x5a,\r\n\r\n AMPERSAND = 0x26,\r\n ASTERISK = 0x2A,\r\n AT = 0x40,\r\n BACKSLASH = 0x5C,\r\n BACKTICK = 0x60,\r\n BAR = 0x7C,\r\n CARET = 0x5E,\r\n CLOSEBRACE = 0x7D,\r\n CLOSEBRACKET = 0x5D,\r\n CLOSEPAREN = 0x29,\r\n COLON = 0x3A,\r\n COMMA = 0x2C,\r\n DOLLAR = 0x24,\r\n DOT = 0x2E,\r\n DOUBLEQUOTE = 0x22,\r\n EQUALS = 0x3D,\r\n EXCLAMATION = 0x21,\r\n GREATERTHAN = 0x3E,\r\n HASH = 0x23,\r\n LESSTHAN = 0x3C,\r\n MINUS = 0x2D,\r\n OPENBRACE = 0x7B,\r\n OPENBRACKET = 0x5B,\r\n OPENPAREN = 0x28,\r\n PERCENT = 0x25,\r\n PLUS = 0x2B,\r\n QUESTION = 0x3F,\r\n SEMICOLON = 0x3B,\r\n SINGLEQUOTE = 0x27,\r\n SLASH = 0x2F,\r\n TILDE = 0x7E,\r\n\r\n BACKSPACE = 0x08,\r\n FORMFEED = 0x0C,\r\n BYTEORDERMARK = 0xFEFF,\r\n TAB = 0x09,\r\n VERTICALTAB = 0x0B\r\n}\r\n\r\n/** Tests if the specified character code is some sort of line break. */\r\nexport function isLineBreak(c: CharCode): bool {\r\n switch (c) {\r\n case CharCode.LINEFEED:\r\n case CharCode.CARRIAGERETURN:\r\n case CharCode.LINESEPARATOR:\r\n case CharCode.PARAGRAPHSEPARATOR: {\r\n return true;\r\n }\r\n default: {\r\n return false;\r\n }\r\n }\r\n}\r\n\r\n/** Tests if the specified character code is some sort of white space. */\r\nexport function isWhiteSpace(c: i32): bool {\r\n switch (c) {\r\n case CharCode.SPACE:\r\n case CharCode.TAB:\r\n case CharCode.VERTICALTAB:\r\n case CharCode.FORMFEED:\r\n case CharCode.NONBREAKINGSPACE:\r\n case CharCode.NEXTLINE:\r\n case CharCode.OGHAM:\r\n case CharCode.NARROWNOBREAKSPACE:\r\n case CharCode.MATHEMATICALSPACE:\r\n case CharCode.IDEOGRAPHICSPACE:\r\n case CharCode.BYTEORDERMARK: {\r\n return true;\r\n }\r\n default: {\r\n return c >= CharCode.ENQUAD && c <= CharCode.ZEROWIDTHSPACE;\r\n }\r\n }\r\n}\r\n\r\n/** Tests if the specified character code is a valid decimal digit. */\r\nexport function isDecimalDigit(c: i32): bool {\r\n return c >= CharCode._0 && c <= CharCode._9;\r\n}\r\n\r\n/** Tests if the specified character code is a valid octal digit. */\r\nexport function isOctalDigit(c: i32): bool {\r\n return c >= CharCode._0 && c <= CharCode._7;\r\n}\r\n\r\n/** Tests if the specified character code is a valid start of an identifier. */\r\nexport function isIdentifierStart(c: i32): bool {\r\n return c >= CharCode.a && c <= CharCode.z\r\n || c >= CharCode.A && c <= CharCode.Z\r\n || c == CharCode._\r\n || c == CharCode.DOLLAR\r\n || c > 0x7f && isUnicodeIdentifierStart(c);\r\n}\r\n\r\n/** Tests if the specified character code is a valid keyword character. */\r\nexport function isKeywordCharacter(c: i32): bool {\r\n return c >= CharCode.a && c <= CharCode.z;\r\n}\r\n\r\n/** Tests if the specified character code is a valid part of an identifier. */\r\nexport function isIdentifierPart(c: i32): bool {\r\n return c >= CharCode.a && c <= CharCode.z\r\n || c >= CharCode.A && c <= CharCode.Z\r\n || c >= CharCode._0 && c <= CharCode._9\r\n || c == CharCode._\r\n || c == CharCode.DOLLAR\r\n || c > 0x7f && isUnicodeIdentifierPart(c);\r\n}\r\n\r\n// storing as u16 to save memory\r\nconst unicodeIdentifierStart: u16[] = [\r\n 170, 170, 181, 181, 186, 186, 192, 214, 216, 246, 248, 705, 710, 721, 736,\r\n 740, 748, 748, 750, 750, 880, 884, 886, 887, 890, 893, 902, 902, 904, 906,\r\n 908, 908, 910, 929, 931,\r\n 1013, 1015, 1153, 1162, 1319, 1329, 1366, 1369, 1369, 1377, 1415, 1488, 1514,\r\n 1520, 1522, 1568, 1610, 1646, 1647, 1649, 1747, 1749, 1749, 1765, 1766, 1774,\r\n 1775, 1786, 1788, 1791, 1791, 1808, 1808, 1810, 1839, 1869, 1957, 1969, 1969,\r\n 1994, 2026, 2036, 2037, 2042, 2042, 2048, 2069, 2074, 2074, 2084, 2084, 2088,\r\n 2088, 2112, 2136, 2208, 2208, 2210, 2220, 2308, 2361, 2365, 2365, 2384, 2384,\r\n 2392, 2401, 2417, 2423, 2425, 2431, 2437, 2444, 2447, 2448, 2451, 2472, 2474,\r\n 2480, 2482, 2482, 2486, 2489, 2493, 2493, 2510, 2510, 2524, 2525, 2527, 2529,\r\n 2544, 2545, 2565, 2570, 2575, 2576, 2579, 2600, 2602, 2608, 2610, 2611, 2613,\r\n 2614, 2616, 2617, 2649, 2652, 2654, 2654, 2674, 2676, 2693, 2701, 2703, 2705,\r\n 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2749, 2749, 2768, 2768, 2784,\r\n 2785, 2821, 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2869, 2873,\r\n 2877, 2877, 2908, 2909, 2911, 2913, 2929, 2929, 2947, 2947, 2949, 2954, 2958,\r\n 2960, 2962, 2965, 2969, 2970, 2972, 2972, 2974, 2975, 2979, 2980, 2984, 2986,\r\n 2990, 3001, 3024, 3024, 3077, 3084, 3086, 3088, 3090, 3112, 3114, 3123, 3125,\r\n 3129, 3133, 3133, 3160, 3161, 3168, 3169, 3205, 3212, 3214, 3216, 3218, 3240,\r\n 3242, 3251, 3253, 3257, 3261, 3261, 3294, 3294, 3296, 3297, 3313, 3314, 3333,\r\n 3340, 3342, 3344, 3346, 3386, 3389, 3389, 3406, 3406, 3424, 3425, 3450, 3455,\r\n 3461, 3478, 3482, 3505, 3507, 3515, 3517, 3517, 3520, 3526, 3585, 3632, 3634,\r\n 3635, 3648, 3654, 3713, 3714, 3716, 3716, 3719, 3720, 3722, 3722, 3725, 3725,\r\n 3732, 3735, 3737, 3743, 3745, 3747, 3749, 3749, 3751, 3751, 3754, 3755, 3757,\r\n 3760, 3762, 3763, 3773, 3773, 3776, 3780, 3782, 3782, 3804, 3807, 3840, 3840,\r\n 3904, 3911, 3913, 3948, 3976, 3980, 4096, 4138, 4159, 4159, 4176, 4181, 4186,\r\n 4189, 4193, 4193, 4197, 4198, 4206, 4208, 4213, 4225, 4238, 4238, 4256, 4293,\r\n 4295, 4295, 4301, 4301, 4304, 4346, 4348, 4680, 4682, 4685, 4688, 4694, 4696,\r\n 4696, 4698, 4701, 4704, 4744, 4746, 4749, 4752, 4784, 4786, 4789, 4792, 4798,\r\n 4800, 4800, 4802, 4805, 4808, 4822, 4824, 4880, 4882, 4885, 4888, 4954, 4992,\r\n 5007, 5024, 5108, 5121, 5740, 5743, 5759, 5761, 5786, 5792, 5866, 5870, 5872,\r\n 5888, 5900, 5902, 5905, 5920, 5937, 5952, 5969, 5984, 5996, 5998, 6000, 6016,\r\n 6067, 6103, 6103, 6108, 6108, 6176, 6263, 6272, 6312, 6314, 6314, 6320, 6389,\r\n 6400, 6428, 6480, 6509, 6512, 6516, 6528, 6571, 6593, 6599, 6656, 6678, 6688,\r\n 6740, 6823, 6823, 6917, 6963, 6981, 6987, 7043, 7072, 7086, 7087, 7098, 7141,\r\n 7168, 7203, 7245, 7247, 7258, 7293, 7401, 7404, 7406, 7409, 7413, 7414, 7424,\r\n 7615, 7680, 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025,\r\n 8027, 8027, 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130,\r\n 8132, 8134, 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188,\r\n 8305, 8305, 8319, 8319, 8336, 8348, 8450, 8450, 8455, 8455, 8458, 8467, 8469,\r\n 8469, 8473, 8477, 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8493, 8495, 8505,\r\n 8508, 8511, 8517, 8521, 8526, 8526, 8544, 8584,\r\n 11264, 11310, 11312, 11358, 11360, 11492, 11499, 11502, 11506, 11507, 11520,\r\n 11557, 11559, 11559, 11565, 11565, 11568, 11623, 11631, 11631, 11648, 11670,\r\n 11680, 11686, 11688, 11694, 11696, 11702, 11704, 11710, 11712, 11718, 11720,\r\n 11726, 11728, 11734, 11736, 11742, 11823, 11823, 12293, 12295, 12321, 12329,\r\n 12337, 12341, 12344, 12348, 12353, 12438, 12445, 12447, 12449, 12538, 12540,\r\n 12543, 12549, 12589, 12593, 12686, 12704, 12730, 12784, 12799, 13312, 19893,\r\n 19968, 40908, 40960, 42124, 42192, 42237, 42240, 42508, 42512, 42527, 42538,\r\n 42539, 42560, 42606, 42623, 42647, 42656, 42735, 42775, 42783, 42786, 42888,\r\n 42891, 42894, 42896, 42899, 42912, 42922, 43000, 43009, 43011, 43013, 43015,\r\n 43018, 43020, 43042, 43072, 43123, 43138, 43187, 43250, 43255, 43259, 43259,\r\n 43274, 43301, 43312, 43334, 43360, 43388, 43396, 43442, 43471, 43471, 43520,\r\n 43560, 43584, 43586, 43588, 43595, 43616, 43638, 43642, 43642, 43648, 43695,\r\n 43697, 43697, 43701, 43702, 43705, 43709, 43712, 43712, 43714, 43714, 43739,\r\n 43741, 43744, 43754, 43762, 43764, 43777, 43782, 43785, 43790, 43793, 43798,\r\n 43808, 43814, 43816, 43822, 43968, 44002, 44032, 55203, 55216, 55238, 55243,\r\n 55291, 63744, 64109, 64112, 64217, 64256, 64262, 64275, 64279, 64285, 64285,\r\n 64287, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321, 64323,\r\n 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008, 65019,\r\n 65136, 65140, 65142, 65276, 65313, 65338, 65345, 65370, 65382, 65470, 65474,\r\n 65479, 65482, 65487, 65490, 65495, 65498, 65500,\r\n];\r\nconst unicodeIdentifierPart: u16[] = [\r\n 170, 170, 181, 181, 186, 186, 192, 214, 216, 246, 248, 705, 710, 721, 736,\r\n 740, 748, 748, 750, 750, 768, 884, 886, 887, 890, 893, 902, 902, 904, 906,\r\n 908, 908, 910, 929, 931,\r\n 1013, 1015, 1153, 1155, 1159, 1162, 1319, 1329, 1366, 1369, 1369, 1377, 1415,\r\n 1425, 1469, 1471, 1471, 1473, 1474, 1476, 1477, 1479, 1479, 1488, 1514, 1520,\r\n 1522, 1552, 1562, 1568, 1641, 1646, 1747, 1749, 1756, 1759, 1768, 1770, 1788,\r\n 1791, 1791, 1808, 1866, 1869, 1969, 1984, 2037, 2042, 2042, 2048, 2093, 2112,\r\n 2139, 2208, 2208, 2210, 2220, 2276, 2302, 2304, 2403, 2406, 2415, 2417, 2423,\r\n 2425, 2431, 2433, 2435, 2437, 2444, 2447, 2448, 2451, 2472, 2474, 2480, 2482,\r\n 2482, 2486, 2489, 2492, 2500, 2503, 2504, 2507, 2510, 2519, 2519, 2524, 2525,\r\n 2527, 2531, 2534, 2545, 2561, 2563, 2565, 2570, 2575, 2576, 2579, 2600, 2602,\r\n 2608, 2610, 2611, 2613, 2614, 2616, 2617, 2620, 2620, 2622, 2626, 2631, 2632,\r\n 2635, 2637, 2641, 2641, 2649, 2652, 2654, 2654, 2662, 2677, 2689, 2691, 2693,\r\n 2701, 2703, 2705, 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2748, 2757,\r\n 2759, 2761, 2763, 2765, 2768, 2768, 2784, 2787, 2790, 2799, 2817, 2819, 2821,\r\n 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2869, 2873, 2876, 2884,\r\n 2887, 2888, 2891, 2893, 2902, 2903, 2908, 2909, 2911, 2915, 2918, 2927, 2929,\r\n 2929, 2946, 2947, 2949, 2954, 2958, 2960, 2962, 2965, 2969, 2970, 2972, 2972,\r\n 2974, 2975, 2979, 2980, 2984, 2986, 2990, 3001, 3006, 3010, 3014, 3016, 3018,\r\n 3021, 3024, 3024, 3031, 3031, 3046, 3055, 3073, 3075, 3077, 3084, 3086, 3088,\r\n 3090, 3112, 3114, 3123, 3125, 3129, 3133, 3140, 3142, 3144, 3146, 3149, 3157,\r\n 3158, 3160, 3161, 3168, 3171, 3174, 3183, 3202, 3203, 3205, 3212, 3214, 3216,\r\n 3218, 3240, 3242, 3251, 3253, 3257, 3260, 3268, 3270, 3272, 3274, 3277, 3285,\r\n 3286, 3294, 3294, 3296, 3299, 3302, 3311, 3313, 3314, 3330, 3331, 3333, 3340,\r\n 3342, 3344, 3346, 3386, 3389, 3396, 3398, 3400, 3402, 3406, 3415, 3415, 3424,\r\n 3427, 3430, 3439, 3450, 3455, 3458, 3459, 3461, 3478, 3482, 3505, 3507, 3515,\r\n 3517, 3517, 3520, 3526, 3530, 3530, 3535, 3540, 3542, 3542, 3544, 3551, 3570,\r\n 3571, 3585, 3642, 3648, 3662, 3664, 3673, 3713, 3714, 3716, 3716, 3719, 3720,\r\n 3722, 3722, 3725, 3725, 3732, 3735, 3737, 3743, 3745, 3747, 3749, 3749, 3751,\r\n 3751, 3754, 3755, 3757, 3769, 3771, 3773, 3776, 3780, 3782, 3782, 3784, 3789,\r\n 3792, 3801, 3804, 3807, 3840, 3840, 3864, 3865, 3872, 3881, 3893, 3893, 3895,\r\n 3895, 3897, 3897, 3902, 3911, 3913, 3948, 3953, 3972, 3974, 3991, 3993, 4028,\r\n 4038, 4038, 4096, 4169, 4176, 4253, 4256, 4293, 4295, 4295, 4301, 4301, 4304,\r\n 4346, 4348, 4680, 4682, 4685, 4688, 4694, 4696, 4696, 4698, 4701, 4704, 4744,\r\n 4746, 4749, 4752, 4784, 4786, 4789, 4792, 4798, 4800, 4800, 4802, 4805, 4808,\r\n 4822, 4824, 4880, 4882, 4885, 4888, 4954, 4957, 4959, 4992, 5007, 5024, 5108,\r\n 5121, 5740, 5743, 5759, 5761, 5786, 5792, 5866, 5870, 5872, 5888, 5900, 5902,\r\n 5908, 5920, 5940, 5952, 5971, 5984, 5996, 5998, 6000, 6002, 6003, 6016, 6099,\r\n 6103, 6103, 6108, 6109, 6112, 6121, 6155, 6157, 6160, 6169, 6176, 6263, 6272,\r\n 6314, 6320, 6389, 6400, 6428, 6432, 6443, 6448, 6459, 6470, 6509, 6512, 6516,\r\n 6528, 6571, 6576, 6601, 6608, 6617, 6656, 6683, 6688, 6750, 6752, 6780, 6783,\r\n 6793, 6800, 6809, 6823, 6823, 6912, 6987, 6992, 7001, 7019, 7027, 7040, 7155,\r\n 7168, 7223, 7232, 7241, 7245, 7293, 7376, 7378, 7380, 7414, 7424, 7654, 7676,\r\n 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025, 8027, 8027,\r\n 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130, 8132, 8134,\r\n 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188, 8204, 8205,\r\n 8255, 8256, 8276, 8276, 8305, 8305, 8319, 8319, 8336, 8348, 8400, 8412, 8417,\r\n 8417, 8421, 8432, 8450, 8450, 8455, 8455, 8458, 8467, 8469, 8469, 8473, 8477,\r\n 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8493, 8495, 8505, 8508, 8511, 8517,\r\n 8521, 8526, 8526, 8544, 8584,\r\n 11264, 11310, 11312, 11358, 11360, 11492, 11499, 11507, 11520, 11557, 11559,\r\n 11559, 11565, 11565, 11568, 11623, 11631, 11631, 11647, 11670, 11680, 11686,\r\n 11688, 11694, 11696, 11702, 11704, 11710, 11712, 11718, 11720, 11726, 11728,\r\n 11734, 11736, 11742, 11744, 11775, 11823, 11823, 12293, 12295, 12321, 12335,\r\n 12337, 12341, 12344, 12348, 12353, 12438, 12441, 12442, 12445, 12447, 12449,\r\n 12538, 12540, 12543, 12549, 12589, 12593, 12686, 12704, 12730, 12784, 12799,\r\n 13312, 19893, 19968, 40908, 40960, 42124, 42192, 42237, 42240, 42508, 42512,\r\n 42539, 42560, 42607, 42612, 42621, 42623, 42647, 42655, 42737, 42775, 42783,\r\n 42786, 42888, 42891, 42894, 42896, 42899, 42912, 42922, 43000, 43047, 43072,\r\n 43123, 43136, 43204, 43216, 43225, 43232, 43255, 43259, 43259, 43264, 43309,\r\n 43312, 43347, 43360, 43388, 43392, 43456, 43471, 43481, 43520, 43574, 43584,\r\n 43597, 43600, 43609, 43616, 43638, 43642, 43643, 43648, 43714, 43739, 43741,\r\n 43744, 43759, 43762, 43766, 43777, 43782, 43785, 43790, 43793, 43798, 43808,\r\n 43814, 43816, 43822, 43968, 44010, 44012, 44013, 44016, 44025, 44032, 55203,\r\n 55216, 55238, 55243, 55291, 63744, 64109, 64112, 64217, 64256, 64262, 64275,\r\n 64279, 64285, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321,\r\n 64323, 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008,\r\n 65019, 65024, 65039, 65056, 65062, 65075, 65076, 65101, 65103, 65136, 65140,\r\n 65142, 65276, 65296, 65305, 65313, 65338, 65343, 65343, 65345, 65370, 65382,\r\n 65470, 65474, 65479, 65482, 65487, 65490, 65495, 65498, 65500,\r\n];\r\n\r\nfunction lookupInUnicodeMap(code: u16, map: u16[]): bool {\r\n if (code < map[0]) return false;\r\n\r\n var lo = 0;\r\n var hi = map.length;\r\n var mid: i32;\r\n var midVal: u16;\r\n\r\n while (lo + 1 < hi) {\r\n mid = lo + ((hi - lo) >> 1);\r\n mid -= (mid & 1);\r\n midVal = map[mid];\r\n if (midVal <= code && code <= map[mid + 1]) {\r\n return true;\r\n }\r\n if (code < midVal) {\r\n hi = mid;\r\n } else {\r\n lo = mid + 2;\r\n }\r\n }\r\n return false;\r\n}\r\n\r\nfunction isUnicodeIdentifierStart(code: i32): bool {\r\n return code < 0 || code > 0xffff ? false\r\n : lookupInUnicodeMap(code as u16, unicodeIdentifierStart);\r\n}\r\n\r\nfunction isUnicodeIdentifierPart(code: i32): bool {\r\n return code < 0 || code > 0xffff ? false\r\n : lookupInUnicodeMap(code as u16, unicodeIdentifierPart);\r\n}\r\n","export function makeArray(original: Array | null = null): Array {\r\n if (original) {\r\n let cloned = new Array(original.length);\r\n for (let i = 0, k = original.length; i < k; ++i) unchecked(cloned[i] = original[i]);\r\n return cloned;\r\n }\r\n return new Array();\r\n}\r\n\r\nexport function makeSet(original: Set | null = null): Set {\r\n if (original) {\r\n let cloned = new Set();\r\n for (let v of original) cloned.add(v);\r\n return cloned;\r\n }\r\n return new Set();\r\n}\r\n\r\nexport function makeMap(original: Map | null = null, overrides: Map | null = null): Map {\r\n var cloned = new Map();\r\n if (original) {\r\n for (let [k, v] of original) cloned.set(k, v);\r\n if (overrides) for (let [k, v] of overrides) cloned.set(k, v);\r\n } else if (overrides) {\r\n for (let [k, v] of overrides) cloned.set(k, v);\r\n }\r\n return cloned;\r\n}\r\n","/** @module util *//***/\r\n\r\nimport {\r\n CharCode\r\n} from \"./charcode\";\r\n\r\nimport {\r\n PATH_DELIMITER\r\n} from \"../common\";\r\n\r\nconst separator = CharCode.SLASH;\r\n\r\n/**\r\n * Normalizes the specified path, removing interior placeholders.\r\n * Expects a posix-compatible relative path (not Windows compatible).\r\n */\r\nexport function normalizePath(path: string): string {\r\n var pos = 0;\r\n var len = path.length;\r\n\r\n // trim leading './'\r\n while (pos + 1 < len &&\r\n path.charCodeAt(pos) == CharCode.DOT &&\r\n path.charCodeAt(pos + 1) == separator\r\n ) {\r\n pos += 2;\r\n }\r\n\r\n if (pos > 0 || len < path.length) {\r\n path = path.substring(pos, len);\r\n len -= pos;\r\n pos = 0;\r\n }\r\n\r\n var atEnd: bool;\r\n while (pos + 1 < len) {\r\n atEnd = false;\r\n\r\n // we are only interested in '/.' sequences ...\r\n if (\r\n path.charCodeAt(pos) == separator &&\r\n path.charCodeAt(pos + 1) == CharCode.DOT\r\n ) {\r\n // '/.' ( '/' | $ )\r\n atEnd = pos + 2 == len;\r\n if (atEnd ||\r\n pos + 2 < len &&\r\n path.charCodeAt(pos + 2) == separator\r\n ) {\r\n path = atEnd\r\n ? path.substring(0, pos)\r\n : path.substring(0, pos) + path.substring(pos + 2);\r\n len -= 2;\r\n continue;\r\n }\r\n\r\n // '/.' ( './' | '.' $ )\r\n atEnd = pos + 3 == len;\r\n if (atEnd && path.charCodeAt(pos + 2) == CharCode.DOT ||\r\n pos + 3 < len &&\r\n path.charCodeAt(pos + 2) == CharCode.DOT &&\r\n path.charCodeAt(pos + 3) == separator\r\n ) {\r\n // find preceeding '/'\r\n let ipos = pos;\r\n while (--ipos >= 0) {\r\n if (path.charCodeAt(ipos) == separator) {\r\n if (pos - ipos != 3 ||\r\n path.charCodeAt(ipos + 1) != CharCode.DOT ||\r\n path.charCodeAt(ipos + 2) != CharCode.DOT\r\n ) { // exclude '..' itself\r\n path = atEnd\r\n ? path.substring(0, ipos)\r\n : path.substring(0, ipos) + path.substring(pos + 3);\r\n len -= pos + 3 - ipos;\r\n pos = ipos - 1; // incremented again at end of loop\r\n }\r\n break;\r\n }\r\n }\r\n\r\n // if there's no preceeding '/', trim start if non-empty\r\n if (ipos < 0 && pos > 0) {\r\n if (pos != 2 ||\r\n path.charCodeAt(0) != CharCode.DOT ||\r\n path.charCodeAt(1) != CharCode.DOT\r\n ) { // exclude '..' itself\r\n path = path.substring(pos + 4);\r\n len = path.length;\r\n continue;\r\n }\r\n }\r\n }\r\n }\r\n pos++;\r\n }\r\n return len > 0 ? path : \".\";\r\n}\r\n\r\n/** Resolves the specified path relative to the specified origin. */\r\nexport function resolvePath(normalizedPath: string, origin: string): string {\r\n if (normalizedPath.startsWith(\"std/\")) {\r\n return normalizedPath;\r\n }\r\n return normalizePath(\r\n dirname(origin) + PATH_DELIMITER + normalizedPath\r\n );\r\n}\r\n\r\n/** Obtains the directory portion of a normalized path. */\r\nexport function dirname(normalizedPath: string): string {\r\n var pos = normalizedPath.length;\r\n if (pos <= 1) {\r\n if (pos == 0) return \".\";\r\n if (normalizedPath.charCodeAt(0) == separator) {\r\n return normalizedPath;\r\n }\r\n }\r\n while (--pos > 0) {\r\n if (normalizedPath.charCodeAt(pos) == separator) {\r\n return normalizedPath.substring(0, pos);\r\n }\r\n }\r\n return \".\";\r\n}\r\n","/** @module util *//***/\r\n\r\nconst indentX1 = \" \";\r\nconst indentX2 = \" \";\r\nconst indentX4 = \" \";\r\n\r\n/** Creates an indentation matching the number of specified levels. */\r\nexport function indent(sb: string[], level: i32): void {\r\n while (level >= 4) {\r\n sb.push(indentX4);\r\n level -= 4;\r\n }\r\n if (level >= 2) {\r\n sb.push(indentX2);\r\n level -= 2;\r\n }\r\n if (level) {\r\n sb.push(indentX1);\r\n }\r\n}\r\n","/** @module util *//***/\r\n\r\n/** Reads an 8-bit integer from the specified buffer. */\r\nexport function readI8(buffer: Uint8Array, offset: i32): i32 {\r\n return buffer[offset];\r\n}\r\n\r\n/** Writes an 8-bit integer to the specified buffer. */\r\nexport function writeI8(value: i32, buffer: Uint8Array, offset: i32): void {\r\n buffer[offset] = value;\r\n}\r\n\r\n/** Reads a 16-bit integer from the specified buffer. */\r\nexport function readI16(buffer: Uint8Array, offset: i32): i32 {\r\n return buffer[offset ]\r\n | buffer[offset + 1] << 8;\r\n}\r\n\r\n/** Writes a 16-bit integer to the specified buffer. */\r\nexport function writeI16(value: i32, buffer: Uint8Array, offset: i32): void {\r\n buffer[offset ] = value;\r\n buffer[offset + 1] = value >>> 8;\r\n}\r\n\r\n/** Reads a 32-bit integer from the specified buffer. */\r\nexport function readI32(buffer: Uint8Array, offset: i32): i32 {\r\n return buffer[offset ]\r\n | buffer[offset + 1] << 8\r\n | buffer[offset + 2] << 16\r\n | buffer[offset + 3] << 24;\r\n}\r\n\r\n/** Writes a 32-bit integer to the specified buffer. */\r\nexport function writeI32(value: i32, buffer: Uint8Array, offset: i32): void {\r\n buffer[offset ] = value;\r\n buffer[offset + 1] = value >>> 8;\r\n buffer[offset + 2] = value >>> 16;\r\n buffer[offset + 3] = value >>> 24;\r\n}\r\n\r\n/** Reads a 64-bit integer from the specified buffer. */\r\nexport function readI64(buffer: Uint8Array, offset: i32): I64 {\r\n var lo = readI32(buffer, offset);\r\n var hi = readI32(buffer, offset + 4);\r\n return i64_new(lo, hi);\r\n}\r\n\r\n/** Writes a 64-bit integer to the specified buffer. */\r\nexport function writeI64(value: I64, buffer: Uint8Array, offset: i32): void {\r\n writeI32(i64_low(value), buffer, offset);\r\n writeI32(i64_high(value), buffer, offset + 4);\r\n}\r\n\r\n/** Reads a 32-bit float from the specified buffer. */\r\nexport function readF32(buffer: Uint8Array, offset: i32): f32 {\r\n return i32_as_f32(readI32(buffer, offset));\r\n}\r\n\r\n/** Writes a 32-bit float to the specified buffer. */\r\nexport function writeF32(value: f32, buffer: Uint8Array, offset: i32): void {\r\n writeI32(f32_as_i32(value), buffer, offset);\r\n}\r\n\r\n/** Reads a 64-bit float from the specified buffer. */\r\nexport function readF64(buffer: Uint8Array, offset: i32): f64 {\r\n return i64_as_f64(readI64(buffer, offset));\r\n}\r\n\r\n/** Writes a 64-bit float to the specified buffer. */\r\nexport function writeF64(value: f64, buffer: Uint8Array, offset: i32): void {\r\n var valueI64 = f64_as_i64(value);\r\n writeI32(i64_low(valueI64), buffer, offset);\r\n writeI32(i64_high(valueI64), buffer, offset + 4);\r\n}\r\n"],"sourceRoot":""} \ No newline at end of file +{"version":3,"sources":["webpack://assemblyscript/webpack/universalModuleDefinition","webpack://assemblyscript/webpack/bootstrap","webpack://assemblyscript/./src/common.ts","webpack://assemblyscript/./src/util/index.ts","webpack://assemblyscript/./src/diagnostics.ts","webpack://assemblyscript/./src/program.ts","webpack://assemblyscript/./src/module.ts","webpack://assemblyscript/./src/ast.ts","webpack://assemblyscript/./src/types.ts","webpack://assemblyscript/./src/tokenizer.ts","webpack://assemblyscript/(webpack)/buildin/global.js","webpack://assemblyscript/./src/resolver.ts","webpack://assemblyscript/./src/flow.ts","webpack://assemblyscript/./src/compiler.ts","webpack://assemblyscript/./src/diagnosticMessages.generated.ts","webpack://assemblyscript/./src/builtins.ts","webpack://assemblyscript/./src/decompiler.ts","webpack://assemblyscript/./src/definitions.ts","webpack://assemblyscript/./src/parser.ts","webpack://assemblyscript/./src/glue/js/index.ts","webpack://assemblyscript/./src/glue/js/binaryen.js","webpack://assemblyscript/external \"binaryen\"","webpack://assemblyscript/./std/portable/index.js","webpack://assemblyscript/./src/glue/js/float.js","webpack://assemblyscript/./src/glue/js/i64.js","webpack://assemblyscript/./node_modules/long/src/long.js","webpack://assemblyscript/./std/assembly/shared/feature.ts","webpack://assemblyscript/./std/assembly/shared/target.ts","webpack://assemblyscript/./std/assembly/shared/typeinfo.ts","webpack://assemblyscript/./src/index.ts","webpack://assemblyscript/./src/util/bitset.ts","webpack://assemblyscript/./src/util/charcode.ts","webpack://assemblyscript/./src/util/collections.ts","webpack://assemblyscript/./src/util/path.ts","webpack://assemblyscript/./src/util/text.ts","webpack://assemblyscript/./src/util/binary.ts"],"names":["root","factory","exports","module","require","define","amd","self","this","__WEBPACK_EXTERNAL_MODULE__20__","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","CommonFlags","PATH_DELIMITER","PARENT_SUBST","GETTER_PREFIX","SETTER_PREFIX","INSTANCE_DELIMITER","STATIC_DELIMITER","INNER_DELIMITER","LIBRARY_SUBST","LIBRARY_PREFIX","INDEX_SUFFIX","CommonSymbols","EMPTY","i8","i16","i32","i64","isize","u8","u16","u32","u64","usize","bool","f32","f64","v128","i8x16","u8x16","i16x8","u16x8","i32x4","u32x4","i64x2","u64x2","f32x4","f64x2","void_","number","boolean","string","native","indexof","valueof","null_","true_","false_","this_","super_","constructor","ASC_TARGET","ASC_NO_TREESHAKING","ASC_NO_ASSERT","ASC_MEMORY_BASE","ASC_OPTIMIZE_LEVEL","ASC_SHRINK_LEVEL","ASC_FEATURE_MUTABLE_GLOBAL","ASC_FEATURE_SIGN_EXTENSION","ASC_FEATURE_BULK_MEMORY","ASC_FEATURE_SIMD","ASC_FEATURE_THREADS","I8","I16","I32","I64","Isize","U8","U16","U32","U64","Usize","Bool","F32","F64","V128","String","Array","FixedArray","Set","Map","ArrayBufferView","ArrayBuffer","Math","Mathf","Int8Array","Int16Array","Int32Array","Int64Array","Uint8Array","Uint8ClampedArray","Uint16Array","Uint32Array","Uint64Array","Float32Array","Float64Array","abort","pow","mod","alloc","realloc","free","retain","release","collect","typeinfo","instanceof_","visit","allocArray","feature_1","Feature","target_1","Target","typeinfo_1","Typeinfo","TypeinfoFlags","__export","isPowerOf2","x","DiagnosticCategory","diagnosticMessages_generated_1","util_1","diagnosticMessages_generated_2","diagnosticCategoryToString","category","INFO","WARNING","ERROR","assert","diagnosticCategoryToColor","COLOR_BLUE","COLOR_YELLOW","COLOR_RED","DiagnosticCode","diagnosticCodeToString","COLOR_RESET","DiagnosticMessage","code","message","range","relatedRange","arg0","arg1","arg2","replace","createInfo","createWarning","createError","withRange","withRelatedRange","toString","source","normalizedPath","line","column","formatDiagnosticContext","useColors","text","len","length","start","end","isLineBreak","charCodeAt","sb","substring","push","join","formatDiagnosticMessage","showContext","DiagnosticEmitter","diagnostics","emitDiagnostic","info","infoRelated","warning","warningRelated","error","errorRelated","OperatorKind","common_1","diagnostics_1","types_1","ast_1","resolver_1","flow_1","QueuedImport","localFile","localIdentifier","foreignIdentifier","foreignPath","foreignPathAlt","QueuedExport","QueuedExportStar","pathLiteral","operatorKindFromDecorator","decoratorKind","arg","DecoratorKind","OPERATOR","OPERATOR_BINARY","INDEXED_GET","INDEXED_SET","UNCHECKED_INDEXED_GET","UNCHECKED_INDEXED_SET","ADD","SUB","MUL","POW","DIV","REM","BITWISE_AND","BITWISE_OR","BITWISE_XOR","EQ","NE","GT","GE","BITWISE_SHR","BITWISE_SHR_U","LT","LE","BITWISE_SHL","OPERATOR_PREFIX","PLUS","PREFIX_INC","MINUS","PREFIX_DEC","NOT","BITWISE_NOT","OPERATOR_POSTFIX","POSTFIX_INC","POSTFIX_DEC","INVALID","ElementKind","DecoratorFlags","Program","_super","_this","sources","diagnosticsOffset","filesByName","elementsByName","elementsByDeclaration","instancesByName","typeClasses","managedClasses","nextClassId","nativeDummySignature","nativeSource","Source","SourceKind","LIBRARY","nativeFile","File","set","internalName","resolver","Resolver","__extends","writeRuntimeHeader","buffer","offset","classInstance","payloadSize","writeI32","id","makeNativeVariableDeclaration","flags","NONE","Node","createVariableDeclaration","createIdentifierExpression","makeNativeTypeDeclaration","identifier","createTypeDeclaration","createOmittedType","makeNativeFunctionDeclaration","createFunctionDeclaration","createFunctionType","createNamedType","createSimpleTypeName","makeNativeNamespaceDeclaration","createNamespaceDeclaration","makeNativeFunction","signature","parent","decoratorFlags","Function","FunctionPrototype","getElementByDeclaration","declaration","has","initialize","options","registerNativeType","Type","isizeType","usizeType","void","add","TypeDefinition","EXPORT","GENERIC","BUILTIN","hasFeature","registerConstantInteger","i64_new","isWasm64","WASM64","WASM32","noAssert","memoryBase","optimizeLevelHint","shrinkLevelHint","queuedImports","queuedExports","queuedExportsStar","queuedExtends","queuedImplements","k","file","statements","j","statement","kind","NodeKind","initializeExports","EXPORTDEFAULT","initializeExportDefault","IMPORT","initializeImports","VARIABLE","initializeVariables","CLASSDECLARATION","initializeClass","ENUMDECLARATION","initializeEnum","FUNCTIONDECLARATION","initializeFunction","INTERFACEDECLARATION","initializeInterface","NAMESPACEDECLARATION","initializeNamespace","TYPEDECLARATION","initializeTypeDefinition","queuedExportsStar_1","__values","queuedExportsStar_1_1","next","done","_g","__read","exportsStar","exportStar","foreignFile","lookupForeignFile","ensureExportStar","File_0_not_found","queuedImport","element","lookupForeign","Module_0_has_no_exported_member_1","localName","asImportedNamespace","queuedExports_1","queuedExports_1_1","_h","exports_1","e_3","exports_1_1","_j","exportName","queuedExport","ensureExport","lookupInSelf","globalElement","lookupGlobal","DeclaredElement","arrayBufferInstance","requireClass","stringInstance","arrayBufferViewInstance","registerNativeTypeClass","i8ArrayPrototype","CLASS_PROTOTYPE","i16ArrayPrototype","i32ArrayPrototype","i64ArrayPrototype","u8ArrayPrototype","u8ClampedArrayPrototype","u16ArrayPrototype","u32ArrayPrototype","u64ArrayPrototype","f32ArrayPrototype","f64ArrayPrototype","thisPrototype","extendsNode","baseElement","resolveTypeName","basePrototype","hasDecorator","SEALED","Class_0_is_sealed_and_cannot_be_extended","identifierNode","UNMANAGED","Unmanaged_classes_cannot_extend_managed_classes_and_vice_versa","Range","A_class_may_only_extend_another_class","globalAliases","globalAliases_1","globalAliases_1_1","_k","alias","firstChar","parseInt","Error","arrayPrototype","fixedArrayPrototype","setPrototype","mapPrototype","abortInstance","lookupFunction","allocInstance","requireFunction","reallocInstance","freeInstance","retainInstance","releaseInstance","collectInstance","typeinfoInstance","instanceofInstance","visitInstance","allocArrayInstance","_l","values","_m","isEntry","_o","e_6","_p","markModuleExport","resolved","resolveClass","FUNCTION_PROTOTYPE","resolveFunction","MODULE_EXPORT","instanceMembers","_c","_d","member","PROPERTY_PROTOTYPE","getterPrototype","setterPrototype","PROPERTY","FUNCTION","FIELD","CLASS","members","_e","_f","type","setType","typeKind","className","classElement","is","global","Global","CONST","setConstantIntegerValue","registerConstantFloat","setConstantFloatValue","ensureGlobal","merged","tryMerge","Duplicate_identifier_0","elements","requireGlobal","foreignName","lookupExport","fileQueuedExports","checkDecorators","decorators","acceptedFlags","decorator","flag","decoratorKindToFlag","decoratorNameToKind","isLibrary","Decorator_0_is_not_valid_here","Duplicate_decorator","ClassPrototype","GLOBAL","implementsTypes","numImplementsTypes","Unmanaged_classes_cannot_implement_interfaces","Operation_not_supported","extendsType","memberDeclarations","memberDeclaration","FIELDDECLARATION","initializeField","METHODDECLARATION","isAny","GET","SET","initializeProperty","initializeMethod","INDEXSIGNATUREDECLARATION","STATIC","INTERFACE_PROTOTYPE","READONLY","INLINE","LAZY","UNSAFE","ABSTRACT","FieldPrototype","addInstance","isStatic","CONSTRUCTOR","checkOperatorOverloads","classPrototype","numArgs","arguments","firstArg","LITERAL","literalKind","LiteralKind","STRING","overloads","overloadPrototypes","Duplicate_function_implementation","operatorKind","String_literal_expected","Expected_0_arguments_but_got_1","ensureProperty","parentMembers","PropertyPrototype","Duplicate_property_0","isGetter","Enum","initializeEnumValue","EnumValue","initializeExport","internalPath","queued","endsWith","path","exportedName","Export_declaration_conflicts_with_exported_declaration_of_0","declarations","initializeImport","namespaceName","validDecorators","AMBIENT","EXTERNAL","INSTANCE","InterfacePrototype","original","Namespace","copyMembers","DECLARE","Element","program","shadowType","FILE","current","unset","originalDeclaration","actual","isBound","TypedElement","apply","RESOLVED","startFunction","Signature","isImport","lookup","includes","exports_2","exports_2_1","_b","memberName","TYPEDEFINITION","mangleInternalName","typeParameters","NAMESPACE","ENUM","ConstantValueKind","VariableLikeElement","constantValueKind","initializer","constantIntegerValue","INLINED","constantFloatValue","ENUMVALUE","isImmutable","Parameter","Local","index","LOCAL","instances","boundPrototypes","body","arrowKind","toBound","bound","getResolvedInstance","instanceKey","setResolvedInstance","instance","nameInclTypeParameters","contextualTypeArguments","localsByName","localsByIndex","additionalLocals","debugLocations","ref","functionTableIndex","trampoline","nextInlineId","nextAnonymousId","nextAutoreleaseId","tempI32s","tempI64s","tempF32s","tempF64s","tempV128s","nextBreakId","breakStack","breakLabel","asFunction","localIndex","local","thisType","parameterTypes","parameterType","parameterName","getParameterName","flow","Flow","registerConcreteElement","addLocal","locals","finalize","sourceMap","debugLocation","setDebugLocation","debugInfoRef","debugInfoIndex","FunctionTarget","__s","FUNCTION_TARGET","toSignatureString","FIELD_PROTOTYPE","parameterIndex","Field","memoryOffset","firstDeclaration","Property","getterInstance","setterInstance","AcyclicState","_isInterface","constructorPrototype","extends","basePtototype","Class","typeArguments","base","INTERFACE","currentMemoryOffset","constructorInstance","_id","_acyclic","rttiFlags","asClass","inheritedTypeArguments","inheritedTypeArguments_1","inheritedTypeArguments_1_1","baseName","baseType","typeParameterNodes","numTypeArguments","isBuiltinArray","lengthField","lookupOverload","isAssignableTo","target","unchecked","uncheckedOverload","overload","offsetof","fieldName","field","writeField","baseOffset","writeI8","writeI16","writeF32","writeF64","getTypeArgumentsTo","extendedPrototype","getArrayValueType","abvInstance","acyclic","hasCycle","cyclesTo","other","except","classReference","Interface","older","newer","Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local","src","dest","srcMembers","destMembers","srcMembers_1","srcMembers_1_1","isInstance","asGlobal","NativeType","ExpressionId","_BinaryenTypeNone","_BinaryenTypeInt32","_BinaryenTypeInt64","_BinaryenTypeFloat32","_BinaryenTypeFloat64","_BinaryenTypeVec128","_BinaryenTypeUnreachable","_BinaryenTypeAuto","FeatureFlags","_BinaryenFeatureAtomics","_BinaryenFeatureMutableGlobals","_BinaryenFeatureNontrappingFPToInt","_BinaryenFeatureSIMD128","_BinaryenFeatureBulkMemory","_BinaryenFeatureSignExt","_BinaryenFeatureExceptionHandling","_BinaryenInvalidId","_BinaryenBlockId","_BinaryenIfId","_BinaryenLoopId","_BinaryenBreakId","_BinaryenSwitchId","_BinaryenCallId","_BinaryenCallIndirectId","_BinaryenLocalGetId","_BinaryenLocalSetId","_BinaryenGlobalGetId","_BinaryenGlobalSetId","_BinaryenLoadId","_BinaryenStoreId","_BinaryenConstId","_BinaryenUnaryId","_BinaryenBinaryId","_BinaryenSelectId","_BinaryenDropId","_BinaryenReturnId","_BinaryenHostId","_BinaryenNopId","_BinaryenUnreachableId","_BinaryenAtomicCmpxchgId","_BinaryenAtomicRMWId","_BinaryenAtomicWaitId","_BinaryenAtomicNotifyId","_BinaryenSIMDExtractId","_BinaryenSIMDReplaceId","_BinaryenSIMDShuffleId","_BinaryenSIMDBitselectId","_BinaryenSIMDShiftId","_BinaryenMemoryInitId","_BinaryenDataDropId","_BinaryenMemoryCopyId","_BinaryenMemoryFillId","UnaryOp","_BinaryenClzInt32","_BinaryenCtzInt32","_BinaryenPopcntInt32","_BinaryenNegFloat32","_BinaryenAbsFloat32","_BinaryenCeilFloat32","_BinaryenFloorFloat32","_BinaryenTruncFloat32","_BinaryenNearestFloat32","_BinaryenSqrtFloat32","_BinaryenEqZInt32","_BinaryenClzInt64","_BinaryenCtzInt64","_BinaryenPopcntInt64","_BinaryenNegFloat64","_BinaryenAbsFloat64","_BinaryenCeilFloat64","_BinaryenFloorFloat64","_BinaryenTruncFloat64","_BinaryenNearestFloat64","_BinaryenSqrtFloat64","_BinaryenEqZInt64","_BinaryenExtendSInt32","_BinaryenExtendUInt32","_BinaryenWrapInt64","_BinaryenTruncSFloat32ToInt32","_BinaryenTruncSFloat32ToInt64","_BinaryenTruncUFloat32ToInt32","_BinaryenTruncUFloat32ToInt64","_BinaryenTruncSFloat64ToInt32","_BinaryenTruncSFloat64ToInt64","_BinaryenTruncUFloat64ToInt32","_BinaryenTruncUFloat64ToInt64","_BinaryenReinterpretFloat32","_BinaryenReinterpretFloat64","_BinaryenConvertSInt32ToFloat32","_BinaryenConvertSInt32ToFloat64","_BinaryenConvertUInt32ToFloat32","_BinaryenConvertUInt32ToFloat64","_BinaryenConvertSInt64ToFloat32","_BinaryenConvertSInt64ToFloat64","_BinaryenConvertUInt64ToFloat32","_BinaryenConvertUInt64ToFloat64","_BinaryenPromoteFloat32","_BinaryenDemoteFloat64","_BinaryenReinterpretInt32","_BinaryenReinterpretInt64","_BinaryenExtendS8Int32","_BinaryenExtendS16Int32","_BinaryenExtendS8Int64","_BinaryenExtendS16Int64","_BinaryenExtendS32Int64","_BinaryenSplatVecI8x16","_BinaryenSplatVecI16x8","_BinaryenSplatVecI32x4","_BinaryenSplatVecI64x2","_BinaryenSplatVecF32x4","_BinaryenSplatVecF64x2","_BinaryenNotVec128","_BinaryenNegVecI8x16","_BinaryenAnyTrueVecI8x16","_BinaryenAllTrueVecI8x16","_BinaryenNegVecI16x8","_BinaryenAnyTrueVecI16x8","_BinaryenAllTrueVecI16x8","_BinaryenNegVecI32x4","_BinaryenAnyTrueVecI32x4","_BinaryenAllTrueVecI32x4","_BinaryenNegVecI64x2","_BinaryenAnyTrueVecI64x2","_BinaryenAllTrueVecI64x2","_BinaryenAbsVecF32x4","_BinaryenNegVecF32x4","_BinaryenSqrtVecF32x4","_BinaryenAbsVecF64x2","_BinaryenNegVecF64x2","_BinaryenSqrtVecF64x2","_BinaryenTruncSatSVecF32x4ToVecI32x4","_BinaryenTruncSatUVecF32x4ToVecI32x4","_BinaryenTruncSatSVecF64x2ToVecI64x2","_BinaryenTruncSatUVecF64x2ToVecI64x2","_BinaryenConvertSVecI32x4ToVecF32x4","_BinaryenConvertUVecI32x4ToVecF32x4","_BinaryenConvertSVecI64x2ToVecF64x2","_BinaryenConvertUVecI64x2ToVecF64x2","BinaryOp","_BinaryenAddInt32","_BinaryenSubInt32","_BinaryenMulInt32","_BinaryenDivSInt32","_BinaryenDivUInt32","_BinaryenRemSInt32","_BinaryenRemUInt32","_BinaryenAndInt32","_BinaryenOrInt32","_BinaryenXorInt32","_BinaryenShlInt32","_BinaryenShrUInt32","_BinaryenShrSInt32","_BinaryenRotLInt32","_BinaryenRotRInt32","_BinaryenEqInt32","_BinaryenNeInt32","_BinaryenLtSInt32","_BinaryenLtUInt32","_BinaryenLeSInt32","_BinaryenLeUInt32","_BinaryenGtSInt32","_BinaryenGtUInt32","_BinaryenGeSInt32","_BinaryenGeUInt32","_BinaryenAddInt64","_BinaryenSubInt64","_BinaryenMulInt64","_BinaryenDivSInt64","_BinaryenDivUInt64","_BinaryenRemSInt64","_BinaryenRemUInt64","_BinaryenAndInt64","_BinaryenOrInt64","_BinaryenXorInt64","_BinaryenShlInt64","_BinaryenShrUInt64","_BinaryenShrSInt64","_BinaryenRotLInt64","_BinaryenRotRInt64","_BinaryenEqInt64","_BinaryenNeInt64","_BinaryenLtSInt64","_BinaryenLtUInt64","_BinaryenLeSInt64","_BinaryenLeUInt64","_BinaryenGtSInt64","_BinaryenGtUInt64","_BinaryenGeSInt64","_BinaryenGeUInt64","_BinaryenAddFloat32","_BinaryenSubFloat32","_BinaryenMulFloat32","_BinaryenDivFloat32","_BinaryenCopySignFloat32","_BinaryenMinFloat32","_BinaryenMaxFloat32","_BinaryenEqFloat32","_BinaryenNeFloat32","_BinaryenLtFloat32","_BinaryenLeFloat32","_BinaryenGtFloat32","_BinaryenGeFloat32","_BinaryenAddFloat64","_BinaryenSubFloat64","_BinaryenMulFloat64","_BinaryenDivFloat64","_BinaryenCopySignFloat64","_BinaryenMinFloat64","_BinaryenMaxFloat64","_BinaryenEqFloat64","_BinaryenNeFloat64","_BinaryenLtFloat64","_BinaryenLeFloat64","_BinaryenGtFloat64","_BinaryenGeFloat64","_BinaryenEqVecI8x16","_BinaryenNeVecI8x16","_BinaryenLtSVecI8x16","_BinaryenLtUVecI8x16","_BinaryenLeSVecI8x16","_BinaryenLeUVecI8x16","_BinaryenGtSVecI8x16","_BinaryenGtUVecI8x16","_BinaryenGeSVecI8x16","_BinaryenGeUVecI8x16","_BinaryenEqVecI16x8","_BinaryenNeVecI16x8","_BinaryenLtSVecI16x8","_BinaryenLtUVecI16x8","_BinaryenLeSVecI16x8","_BinaryenLeUVecI16x8","_BinaryenGtSVecI16x8","_BinaryenGtUVecI16x8","_BinaryenGeSVecI16x8","_BinaryenGeUVecI16x8","_BinaryenEqVecI32x4","_BinaryenNeVecI32x4","_BinaryenLtSVecI32x4","_BinaryenLtUVecI32x4","_BinaryenLeSVecI32x4","_BinaryenLeUVecI32x4","_BinaryenGtSVecI32x4","_BinaryenGtUVecI32x4","_BinaryenGeSVecI32x4","_BinaryenGeUVecI32x4","_BinaryenEqVecF32x4","_BinaryenNeVecF32x4","_BinaryenLtVecF32x4","_BinaryenLeVecF32x4","_BinaryenGtVecF32x4","_BinaryenGeVecF32x4","_BinaryenEqVecF64x2","_BinaryenNeVecF64x2","_BinaryenLtVecF64x2","_BinaryenLeVecF64x2","_BinaryenGtVecF64x2","_BinaryenGeVecF64x2","_BinaryenAndVec128","_BinaryenOrVec128","_BinaryenXorVec128","_BinaryenAddVecI8x16","_BinaryenAddSatSVecI8x16","_BinaryenAddSatUVecI8x16","_BinaryenSubVecI8x16","_BinaryenSubSatSVecI8x16","_BinaryenSubSatUVecI8x16","_BinaryenMulVecI8x16","_BinaryenAddVecI16x8","_BinaryenAddSatSVecI16x8","_BinaryenAddSatUVecI16x8","_BinaryenSubVecI16x8","_BinaryenSubSatSVecI16x8","_BinaryenSubSatUVecI16x8","_BinaryenMulVecI16x8","_BinaryenAddVecI32x4","_BinaryenSubVecI32x4","_BinaryenMulVecI32x4","_BinaryenAddVecI64x2","_BinaryenSubVecI64x2","_BinaryenAddVecF32x4","_BinaryenSubVecF32x4","_BinaryenMulVecF32x4","_BinaryenDivVecF32x4","_BinaryenMinVecF32x4","_BinaryenMaxVecF32x4","_BinaryenAddVecF64x2","_BinaryenSubVecF64x2","_BinaryenMulVecF64x2","_BinaryenDivVecF64x2","_BinaryenMinVecF64x2","_BinaryenMaxVecF64x2","HostOp","_BinaryenMemorySize","_BinaryenMemoryGrow","AtomicRMWOp","_BinaryenAtomicRMWAdd","_BinaryenAtomicRMWSub","_BinaryenAtomicRMWAnd","_BinaryenAtomicRMWOr","_BinaryenAtomicRMWXor","_BinaryenAtomicRMWXchg","SIMDExtractOp","_BinaryenExtractLaneSVecI8x16","_BinaryenExtractLaneUVecI8x16","_BinaryenExtractLaneSVecI16x8","_BinaryenExtractLaneUVecI16x8","_BinaryenExtractLaneVecI32x4","_BinaryenExtractLaneVecI64x2","_BinaryenExtractLaneVecF32x4","_BinaryenExtractLaneVecF64x2","SIMDReplaceOp","_BinaryenReplaceLaneVecI8x16","_BinaryenReplaceLaneVecI16x8","_BinaryenReplaceLaneVecI32x4","_BinaryenReplaceLaneVecI64x2","_BinaryenReplaceLaneVecF32x4","_BinaryenReplaceLaneVecF64x2","SIMDShiftOp","_BinaryenShlVecI8x16","_BinaryenShrSVecI8x16","_BinaryenShrUVecI8x16","_BinaryenShlVecI16x8","_BinaryenShrSVecI16x8","_BinaryenShrUVecI16x8","_BinaryenShlVecI32x4","_BinaryenShrSVecI32x4","_BinaryenShrUVecI32x4","_BinaryenShlVecI64x2","_BinaryenShrSVecI64x2","_BinaryenShrUVecI64x2","MemorySegment","segment","Module","hasTemporaryFunction","cachedPrecomputeNames","cachedStrings","_BinaryenModuleCreate","lit","memory","allocate","_BinaryenSizeofLiteral","createFrom","cArr","allocU8Array","_BinaryenModuleRead","changetype","addFunctionType","result","paramTypes","cStr","allocStringCached","allocI32Array","_BinaryenAddFunctionType","getFunctionTypeBySignature","_BinaryenGetFunctionTypeBySignature","removeFunctionType","_BinaryenRemoveFunctionType","out","_BinaryenLiteralInt32","_BinaryenConst","valueLow","valueHigh","_BinaryenLiteralInt64","_BinaryenLiteralFloat32","_BinaryenLiteralFloat64","bytes","store","_BinaryenLiteralVec128","unary","op","expr","_BinaryenUnary","binary","left","right","_BinaryenBinary","host","operands","allocPtrArray","_BinaryenHost","local_get","_BinaryenLocalGet","local_tee","_BinaryenLocalTee","global_get","_BinaryenGlobalGet","load","signed","ptr","align","_BinaryenLoad","None","_BinaryenStore","atomic_load","_BinaryenAtomicLoad","atomic_store","_BinaryenAtomicStore","atomic_rmw","_BinaryenAtomicRMW","atomic_cmpxchg","expected","replacement","_BinaryenAtomicCmpxchg","atomic_wait","timeout","expectedType","_BinaryenAtomicWait","atomic_notify","notifyCount","_BinaryenAtomicNotify","local_set","_BinaryenLocalSet","global_set","_BinaryenGlobalSet","block","label","children","_BinaryenBlock","br","condition","_BinaryenBreak","drop","expression","_BinaryenDrop","loop","_BinaryenLoop","if","ifTrue","ifFalse","_BinaryenIf","nop","_BinaryenNop","return","_BinaryenReturn","select","_BinaryenSelect","switch","names","defaultName","numNames","strs","_BinaryenSwitch","returnType","_BinaryenCall","call_indirect","typeName","_BinaryenCallIndirect","unreachable","_BinaryenUnreachable","memory_copy","size","_BinaryenMemoryCopy","memory_fill","_BinaryenMemoryFill","simd_extract","vec","idx","_BinaryenSIMDExtract","simd_replace","_BinaryenSIMDReplace","simd_shuffle","vec1","vec2","mask","_BinaryenSIMDShuffle","simd_bitselect","cond","_BinaryenSIMDBitselect","simd_shift","shift","_BinaryenSIMDShift","addGlobal","mutable","_BinaryenAddGlobal","removeGlobal","_BinaryenRemoveGlobal","addFunction","varTypes","_BinaryenAddFunction","removeFunction","_BinaryenRemoveFunction","addTemporaryFunction","tempName","typeRef","removeTemporaryFunction","addFunctionExport","externalName","cStr1","cStr2","_BinaryenAddFunctionExport","addTableExport","_BinaryenAddTableExport","addMemoryExport","_BinaryenAddMemoryExport","addGlobalExport","_BinaryenAddGlobalExport","removeExport","_BinaryenRemoveExport","addFunctionImport","externalModuleName","externalBaseName","functionType","cStr3","_BinaryenAddFunctionImport","addTableImport","_BinaryenAddTableImport","addMemoryImport","shared","_BinaryenAddMemoryImport","addGlobalImport","globalType","_BinaryenAddGlobalImport","setMemory","initial","maximum","segments","segs","psvs","offs","sizs","i64_low","i64_high","cArr1","cArr2","cArr3","cArr4","_BinaryenSetMemory","setFunctionTable","funcs","_BinaryenSetFunctionTable","setStart","func","_BinaryenSetStart","getOptimizeLevel","_BinaryenGetOptimizeLevel","setOptimizeLevel","level","_BinaryenSetOptimizeLevel","getShrinkLevel","_BinaryenGetShrinkLevel","setShrinkLevel","_BinaryenSetShrinkLevel","setDebugInfo","on","_BinaryenSetDebugInfo","getFeatures","_BinaryenModuleGetFeatures","setFeatures","featureFlags","_BinaryenModuleSetFeatures","optimize","_BinaryenFunctionOptimize","_BinaryenModuleOptimize","runPasses","passes","allocString","_BinaryenFunctionRunPasses","_BinaryenModuleRunPasses","precomputeExpression","previousOptimizeLevel","previousShrinkLevel","previousDebugInfo","_BinaryenGetDebugInfo","_BinaryenExpressionGetType","_BinaryenFunctionGetBody","validate","_BinaryenModuleValidate","interpret","_BinaryenModuleInterpret","toBinary","sourceMapUrl","binaryPtr","sourceMapPtr","_BinaryenModuleAllocateAndWrite","readInt","binaryBytes","ret","BinaryModule","output","readBuffer","readString","toText","toAsmjs","str","dispose","_BinaryenModuleDispose","createRelooper","Relooper","cloneExpression","noSideEffects","maxDepth","MAX_VALUE","nested1","nested2","_BinaryenExpressionGetId","Const","_BinaryenConstGetValueI32","_BinaryenConstGetValueI64Low","_BinaryenConstGetValueI64High","_BinaryenConstGetValueF32","_BinaryenConstGetValueF64","LocalGet","_BinaryenLocalGetGetIndex","GlobalGet","globalName","_BinaryenGlobalGetGetName","Load","_BinaryenLoadGetPtr","_BinaryenLoadIsAtomic","_BinaryenLoadGetBytes","_BinaryenLoadGetOffset","_BinaryenLoadIsSigned","_BinaryenLoadGetAlign","Unary","_BinaryenUnaryGetValue","_BinaryenUnaryGetOp","Binary","_BinaryenBinaryGetLeft","_BinaryenBinaryGetRight","_BinaryenBinaryGetOp","addDebugInfoFile","_BinaryenModuleAddDebugInfoFileName","getDebugInfoFile","_BinaryenModuleGetDebugInfoFileName","fileIndex","lineNumber","columnNumber","_BinaryenFunctionSetDebugLocation","UNLIMITED_MEMORY","getExpressionId","getExpressionType","getConstValueI32","getConstValueI64Low","getConstValueI64High","getConstValueF32","getConstValueF64","getLocalGetIndex","getLocalSetIndex","_BinaryenLocalSetGetIndex","getLocalSetValue","_BinaryenLocalSetGetValue","isLocalTee","_BinaryenLocalSetIsTee","getGlobalGetName","getBinaryOp","getBinaryLeft","getBinaryRight","getUnaryOp","getUnaryValue","getLoadBytes","getLoadOffset","getLoadPtr","isLoadSigned","getStoreBytes","_BinaryenStoreGetBytes","getStoreOffset","_BinaryenStoreGetOffset","getStorePtr","_BinaryenStoreGetPtr","getStoreValue","_BinaryenStoreGetValue","getBlockName","_BinaryenBlockGetName","getBlockChildCount","_BinaryenBlockGetNumChildren","getBlockChild","_BinaryenBlockGetChild","getIfCondition","_BinaryenIfGetCondition","getIfTrue","_BinaryenIfGetIfTrue","getIfFalse","_BinaryenIfGetIfFalse","getLoopName","_BinaryenLoopGetName","getLoopBody","_BinaryenLoopGetBody","getBreakName","_BinaryenBreakGetName","getBreakCondition","_BinaryenBreakGetCondition","getSelectThen","_BinaryenSelectGetIfTrue","getSelectElse","_BinaryenSelectGetIfFalse","getSelectCondition","_BinaryenSelectGetCondition","getDropValue","_BinaryenDropGetValue","getReturnValue","_BinaryenReturnGetValue","getCallTarget","_BinaryenCallGetTarget","getCallOperandCount","_BinaryenCallGetNumOperands","getCallOperand","_BinaryenCallGetOperand","getHostOp","_BinaryenHostGetOp","getHostOperandCount","_BinaryenHostGetNumOperands","getHostOperand","_BinaryenHostGetOperand","getHostName","_BinaryenHostGetNameOperand","getFunctionBody","getFunctionName","_BinaryenFunctionGetName","getFunctionParamCount","_BinaryenFunctionGetNumParams","getFunctionParamType","_BinaryenFunctionGetParam","getFunctionResultType","_BinaryenFunctionGetResult","relooper","_RelooperCreate","addBlock","_RelooperAddBlock","addBranch","from","to","_RelooperAddBranch","addBlockWithSwitch","_RelooperAddBlockWithSwitch","addBranchForSwitch","indexes","_RelooperAddBranchForSwitch","renderAndDispose","entry","labelHelper","_RelooperRenderAndDispose","u8s","numValues","i32s","val","ptrs","u","stringLengthUTF8","cp","u1","u2","u3","u4","arr","fromCodePoints","needsExplicitUnreachable","Unreachable","Return","Break","Block","numChildren","traverse","data","If","Loop","Switch","_BinaryenSwitchGetCondition","Call","CallIndirect","_BinaryenCallIndirectGetNumOperands","_BinaryenCallIndirectGetOperand","LocalSet","GlobalSet","_BinaryenGlobalSetGetValue","Store","AtomicRMW","_BinaryenAtomicRMWGetPtr","_BinaryenAtomicRMWGetValue","AtomicCmpxchg","_BinaryenAtomicCmpxchgGetPtr","_BinaryenAtomicCmpxchgGetExpected","_BinaryenAtomicCmpxchgGetReplacement","AtomicWait","_BinaryenAtomicWaitGetPtr","_BinaryenAtomicWaitGetExpected","_BinaryenAtomicWaitGetTimeout","AtomicNotify","_BinaryenAtomicNotifyGetPtr","SIMDExtract","_BinaryenSIMDExtractGetVec","SIMDReplace","_BinaryenSIMDReplaceGetVec","_BinaryenSIMDReplaceGetValue","SIMDShuffle","_BinaryenSIMDShuffleGetLeft","_BinaryenSIMDShuffleGetRight","SIMDBitselect","_BinaryenSIMDBitselectGetLeft","_BinaryenSIMDBitselectGetRight","_BinaryenSIMDBitselectGetCond","SIMDShift","_BinaryenSIMDShiftGetVec","_BinaryenSIMDShiftGetShift","MemoryInit","_BinaryenMemoryInitGetDest","_BinaryenMemoryInitGetOffset","_BinaryenMemoryInitGetSize","DataDrop","MemoryCopy","_BinaryenMemoryCopyGetDest","_BinaryenMemoryCopyGetSource","_BinaryenMemoryCopyGetSize","MemoryFill","_BinaryenMemoryFillGetDest","_BinaryenMemoryFillGetValue","_BinaryenMemoryFillGetSize","Select","Drop","Host","Nop","tokenizer_1","Token","nodeIsConstantValue","NULL","TRUE","FALSE","nodeIsCallable","IDENTIFIER","ASSERTION","CALL","ELEMENTACCESS","PARENTHESIZED","PROPERTYACCESS","SUPER","nodeIsGenericCallable","createTypeName","TypeName","isNullable","NamedTypeNode","parameters","explicitThisType","FunctionTypeNode","createTypeParameter","defaultType","elem","TypeParameterNode","createParameter","ParameterNode","parameterKind","createDecorator","args","stmt","DecoratorNode","createComment","node","CommentNode","commentKind","isQuoted","IdentifierExpression","symbol","createEmptyIdentifierExpression","createArrayLiteralExpression","ArrayLiteralExpression","elementExpressions","createAssertionExpression","assertionKind","toType","AssertionExpression","createBinaryExpression","operator","BinaryExpression","createCallExpression","typeArgs","CallExpression","createClassExpression","ClassExpression","createCommaExpression","expressions","CommaExpression","createConstructorExpression","ConstructorExpression","createElementAccessExpression","ElementAccessExpression","elementExpression","createFalseExpression","FalseExpression","createFloatLiteralExpression","FloatLiteralExpression","createFunctionExpression","FunctionExpression","createInstanceOfExpression","isType","InstanceOfExpression","createIntegerLiteralExpression","IntegerLiteralExpression","createNewExpression","NewExpression","createNullExpression","NullExpression","createObjectLiteralExpression","ObjectLiteralExpression","createParenthesizedExpression","ParenthesizedExpression","createPropertyAccessExpression","PropertyAccessExpression","createRegexpLiteralExpression","pattern","RegexpLiteralExpression","patternFlags","createTernaryExpression","ifThen","ifElse","TernaryExpression","createStringLiteralExpression","StringLiteralExpression","createSuperExpression","SuperExpression","createThisExpression","ThisExpression","createTrueExpression","TrueExpression","createUnaryPostfixExpression","operand","UnaryPostfixExpression","createUnaryPrefixExpression","UnaryPrefixExpression","createBlockStatement","BlockStatement","createBreakStatement","BreakStatement","createClassDeclaration","ClassDeclaration","createContinueStatement","ContinueStatement","createDoStatement","DoStatement","createEmptyStatement","EmptyStatement","createEnumDeclaration","EnumDeclaration","createEnumValueDeclaration","EnumValueDeclaration","createExportStatement","isDeclare","ExportStatement","normalizePath","startsWith","resolvePath","mangleInternalPath","createExportDefaultStatement","ExportDefaultStatement","createExportImportStatement","ExportImportStatement","createExportMember","ExportMember","createExpressionStatement","ExpressionStatement","createIfStatement","IfStatement","createImportStatement","decls","ImportStatement","createImportStatementWithWildcard","createImportDeclaration","ImportDeclaration","createInterfaceDeclaration","InterfaceDeclaration","createFieldDeclaration","FieldDeclaration","createForStatement","incrementor","ForStatement","FunctionDeclaration","createIndexSignatureDeclaration","keyType","valueType","IndexSignatureDeclaration","createMethodDeclaration","MethodDeclaration","NamespaceDeclaration","createReturnStatement","ReturnStatement","createSwitchStatement","cases","SwitchStatement","createSwitchCase","SwitchCase","createThrowStatement","ThrowStatement","createTryStatement","catchVariable","catchStatements","finallyStatements","TryStatement","TypeDeclaration","createVariableStatement","VariableStatement","VariableDeclaration","createVoidStatement","VoidStatement","createWhileStatement","WhileStatement","TypeNode","TYPENAME","NAMEDTYPE","FUNCTIONTYPE","TYPEPARAMETER","ParameterKind","PARAMETER","implicitFieldDeclaration","nameStr","propStr","CUSTOM","DECORATOR","CommentKind","COMMENT","Expression","LiteralExpression","ARRAY","AssertionKind","BINARY","numArguments","COMMA","FLOAT","INSTANCEOF","INTEGER","NEW","OBJECT","REGEXP","TERNARY","THIS","UnaryExpression","UNARYPOSTFIX","UNARYPREFIX","Statement","SOURCE","tokenizer","exportPaths","sourceKind","pos","lastIndexOf","simplePath","ENTRY","DeclarationStatement","VariableLikeDeclarationStatement","BLOCK","BREAK","CONTINUE","DO","ENUMVALUEDECLARATION","EXPORTIMPORT","EXPORTMEMBER","EXPRESSION","FOR","ArrowKind","clone","IF","IMPORTDECLARATION","RETURN","SWITCHCASE","SWITCH","THROW","TRY","VARIABLEDECLARATION","VOID","WHILE","findDecorator","isTypeOmitted","program_1","module_1","TypeKind","TypeFlags","v128_zero","cachedNullableType","byteSize","ceil","signatureReference","nonNullableType","isize64","isize32","usize64","usize32","auto","clz","computeSmallIntegerShift","targetType","computeSmallIntegerMask","classType","asNullable","signednessIsRelevant","currentClass","targetClass","currentFunction","targetFunction","isStrictlyAssignableTo","commonDenominator","signednessIsImportant","toNativeType","toNativeZero","toNativeOne","toNativeNegOne","typesToNativeTypes","types","numTypes","typesToString","cachedFunctionTarget","parameterNames","requiredParameters","hasRest","asFunctionTarget","getDefaultParameterName","thisThisType","targetThisType","thisParameterTypes","targetParameterTypes","numParameters","thisParameterType","targetParameterType","thisReturnType","targetReturnType","makeSignatureString","optionalStart","restIndex","cachedDefaultParameterNames","IdentifierHandling","tokenFromKeyword","AS","ASYNC","AWAIT","CASE","CATCH","DEBUGGER","DEFAULT","DELETE","ELSE","EXTENDS","FINALLY","FROM","IMPLEMENTS","IN","IS","KEYOF","LET","MODULE","OF","PACKAGE","PRIVATE","PROTECTED","PUBLIC","TYPE","TYPEOF","VAR","WITH","YIELD","tokenIsAlsoIdentifier","token","isIllegalVariableIdentifier","operatorTokenToString","DOT_DOT_DOT","LESSTHAN","GREATERTHAN","LESSTHAN_EQUALS","GREATERTHAN_EQUALS","EQUALS_EQUALS","EXCLAMATION_EQUALS","EQUALS_EQUALS_EQUALS","EXCLAMATION_EQUALS_EQUALS","ASTERISK_ASTERISK","ASTERISK","SLASH","PERCENT","PLUS_PLUS","MINUS_MINUS","LESSTHAN_LESSTHAN","GREATERTHAN_GREATERTHAN","GREATERTHAN_GREATERTHAN_GREATERTHAN","AMPERSAND","BAR","CARET","EXCLAMATION","TILDE","AMPERSAND_AMPERSAND","BAR_BAR","EQUALS","PLUS_EQUALS","MINUS_EQUALS","ASTERISK_EQUALS","ASTERISK_ASTERISK_EQUALS","SLASH_EQUALS","PERCENT_EQUALS","LESSTHAN_LESSTHAN_EQUALS","GREATERTHAN_GREATERTHAN_EQUALS","GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS","AMPERSAND_EQUALS","BAR_EQUALS","CARET_EQUALS","a","b","Tokenizer","tokenPos","nextToken","nextTokenPos","nextTokenOnNewLine","onComment","identifierHandling","unsafeNext","maxTokenLength","STRINGLITERAL","chr","OPENPAREN","CLOSEPAREN","isDecimalDigit","FLOATLITERAL","DOT","commentStartPos","LINE","TRIPLE","closed","_0_expected","testInteger","INTEGERLITERAL","COLON","SEMICOLON","EQUALS_GREATERTHAN","QUESTION","OPENBRACKET","CLOSEBRACKET","OPENBRACE","CLOSEBRACE","AT","isIdentifierStart","isKeywordCharacter","posBefore","isIdentifierPart","keywordToken","ALWAYS","PREFER","isWhiteSpace","Invalid_character","ENDOFFILE","peek","checkOnNewLine","maxCompoundLength","tokenBefore","tokenPosBefore","skipIdentifier","skip","mark","state","reusableState","State","discard","reset","readIdentifier","quote","Unterminated_string_literal","readEscapeSequence","Unexpected_end_of_text","readExtendedUnicodeEscape","readUnicodeEscape","fromCharCode","readRegexpPattern","escaped","Unterminated_regular_expression_literal","readRegexpFlags","Invalid_regular_expression_flags","readInteger","readHexInteger","readBinaryInteger","readOctalInteger","isOctalDigit","Octal_literals_are_not_allowed_in_strict_mode","readDecimalInteger","i64_4","sepEnd","i64_add","i64_shl","Numeric_separators_are_not_allowed_here","Multiple_consecutive_numeric_separators_are_not_permitted","Hexadecimal_digit_expected","i64_10","i64_mul","Digit_expected","i64_3","Octal_digit_expected","i64_1","Binary_digit_expected","readFloat","readDecimalFloat","parseFloat","readHexFloat","remain","value32","invalid","An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive","Unterminated_Unicode_escape_sequence","finish","g","e","window","ReportMode","builtins_1","currentThisExpression","currentElementExpression","resolveType","context","reportMode","REPORT","parameterNodes","parameterNode","REST","parameterTypeNode","Type_expected","returnTypeNode","typeNode","typeArgumentNodes","isSimpleType","Type_0_is_not_generic","Basic_type_0_cannot_be_nullable","resolveClassInclTypeArguments","makeMap","type_1","resolveBuiltinNativeType","resolveBuiltinIndexofType","resolveBuiltinValueofType","resolveTypeArguments","Cannot_find_name_0","Expected_0_type_arguments_but_got_1","typeArgument","Index_signature_is_missing_in_type_0","prev","Property_0_does_not_exist_on_type_1","alternativeReportNode","minParameterCount","maxParameterCount","argumentCount","resolveIdentifier","ensureResolvedLazyGlobal","resolvePropertyAccessExpression","propertyAccess","contextualType","targetExpression","resolveExpression","propertyName","indexedGet","arrayType","resolvedType","resolveElementAccessExpression","elementAccess","determineIntegerLiteralType","intValue","i64_is_i8","i64_is_u8","i64_is_i16","i64_is_u16","i64_is_i32","i64_is_u32","i64_is_bool","resolveAssertionExpression","resolveUnaryPrefixExpression","resolveUnaryPostfixExpression","resolveBinaryExpression","resolveThisExpression","resolveSuperExpression","actualFunction","resolveLiteralExpression","resolveCallExpression","NONNULL","i64_sub","i64_zero","thisLocal","lookupLocal","_this_cannot_be_referenced_in_current_location","superLocal","_super_can_only_be_referenced_in_a_derived_class","literalType","BuiltinSymbols","resolveFunctionInclTypeArguments","Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures","actualParent","resolvedInstance","classTypeArguments","classTypeParameters","numClassTypeArguments","classTypeParameterName","numFunctionTypeArguments","signatureNode","functionTypeNode","signatureParameters","numSignatureParameters","parameterDeclaration","reportNode","resolvedTypeArguments","numTypeParameters","baseClass","nameInclTypeParamters","baseMembers","baseMembers_1","baseMembers_1_1","baseMemberName","baseMember","instanceMemberPrototypes","fieldTypeNode","fieldType","baseField","atEnd","fieldInstance","boundPrototype","propertyInstance","ctorPrototype","ctorInstance","overloadPrototype","operatorInstance","LocalFlags","FlowFlags","ANY_CATEGORICAL","ANY_CONDITIONAL","FieldFlags","scopedLocals","fieldFlags","parentFunction","continueLabel","localFlags","inlineFunction","inlineReturnLabel","createInline","fork","branch","slice","getTempLocal","temps","k_1","unsetLocalFlag","pop","getAutoreleaseLocal","SCOPED","setLocalFlag","RETAINED","freeTempLocal","getAndFreeTempLocal","getScopedLocal","addScopedLocal","scopedLocal","addScopedAlias","existingLocal","scopedAlias","freeScopedLocals","scope","isLocalFlag","defaultIfInlined","isAnyLocalFlag","pushBreakLabel","stack","popBreakLabel","inherit","inheritConditional","CONDITIONALLY_RETAINED","READFROM","CONDITIONALLY_READFROM","WRITTENTO","CONDITIONALLY_WRITTENTO","inheritMutual","leftLocalFlags","numLeftLocalFlags","rightLocalFlags","numRightLocalFlags","combinedFlags","max","isNonnull","inheritNonnullIfTrue","EqzI32","EqzI64","inheritNonnullIfFalse","EqI32","EqI64","NeI32","NeI64","canOverflow","WRAPPED","canConversionOverflow","global_1","EqF32","EqF64","NeF32","NeF64","LtI32","LtU32","LtI64","LtU64","LtF32","LtF64","LeI32","LeU32","LeI64","LeU64","LeF32","LeF64","GtI32","GtU32","GtI64","GtU64","GtF32","GtF64","GeI32","GeU32","GeI64","GeU64","GeF32","GeF64","MulI32","AndI32","ShlI32","ShrI32","ShrU32","DivU32","RemI32","RemU32","ClzI32","CtzI32","PopcntI32","MIN_VALUE","fromType","last","instanceName","levels","findUsedLocalsVisit","used","findUsedLocals","Options","importMemory","sharedMemory","importTable","explicitStart","features","feature","Constraints","RuntimeFeatures","mangleImportName_moduleName","mangleImportName_elementName","Compiler","currentInlineFunctions","currentEnum","currentType","memorySegments","stringSegments","functionTable","argcVar","argcSet","runtimeFeatures","skippedAutoreleases","f32ModInstance","f64ModInstance","f32PowInstance","f64PowInstance","Atomics","MutableGloabls","SIMD128","BulkMemory","SignExt","compile","startFunctionInstance","startFunctionBody","currentFlow","currentBody","heap_base","rtti_base","files","compileFile","compileExports","startIsEmpty","started","unshift","funcRef","ensureFunctionType","compileVisitGlobals","compileVisitMembers","compileRTTI","i64_align","isSharedMemory","i64_shr_u","ensureModuleExports","members_1","members_1_1","ensureModuleExport","prefix","fullName","setter","Cannot_export_a_mutable_global","ensureTrampoline","ensureArgcSet","COMPILED","ensureModuleFieldGetter","ensureModuleFieldSetter","isUnmanaged","subPrefix","loadExpr","isManaged","makeRetain","nativeType","nativeSizeType","valueExpr","makeRetainRelease","compileElement","compileMembers","compileGlobal","compileEnum","compileFunctionUsingTypeArguments","compileClassUsingTypeArguments","element_1","exportsStar_1","exportsStar_1_1","compileFileByPath","normalizedPathWithoutExtension","pathWithIndex","previousBody","previousFlow","compileTopLevelStatement","finishAutoreleases","numLocals","initExpr","initAutoreleaseSkipped","initializerNode","compileExpression","Type_0_is_not_assignable_to_type_1","isDeclaredConstant","isDeclaredInline","MODULE_IMPORT","mangleImportName","initializeInStart","Mutable_value_cannot_be_inlined","decoratorNodes","previousValue","previousValueIsMut","isInline","initInStart","valueNode","In_const_enum_declarations_member_initializer_must_be_constant_expression","Enum_member_must_have_initializer","AddI32","makeGlobalAssignment","compileFunction","resultType","compileFunctionBody","stmts","bodyNode","compileStatements","MAIN","indexBefore","performAutoreleases","nonNull","temp","makeAllocation","makeFieldInitialization","Constructors_for_derived_classes_must_contain_a_super_call","A_function_whose_declared_type_is_not_void_must_return_a_value","previousType","An_implementation_cannot_be_declared_in_ambient_contexts","flatten","Function_implementation_is_missing_or_not_immediately_following_the_declaration","compileClass","staticMembers","compileInterfaceDeclaration","addMemorySegment","alignment","ensureStaticString","stringValue","stringSegment","rtHeaderSize","runtimeHeaderSize","ensureStaticArrayBuffer","elementType","byteLength","bufferInstance","buf","writeI64","ensureStaticArrayHeader","bufferSegment","arrayInstance","arrayInstanceSize","bufferLength","arrayLength","bufferAddress32","ensureFunctionTableEntry","TRAMPOLINE","memberStatements","compileStatement","isLastInBody","compileBlockStatement","compileBreakStatement","compileContinueStatement","compileDoStatement","compileEmptyStatement","compileExpressionStatement","compileForStatement","compileIfStatement","compileReturnStatement","compileSwitchStatement","compileThrowStatement","compileTryStatement","compileVariableStatement","compileVoidStatement","compileWhileStatement","addDebugLocation","isBody","numStatements","outerFlow","innerFlow","A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement","A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement","condExpr","makeIsTrueish","alwaysFalse","terminates","continues","breaks","fallsThrough","alwaysTrue","stmts_1","incrExpr","loopLabel","bodyStatement","needsLabel","ifTrueStmts","ifTrueFlow","ifFalseFlow","ifFalseStmts","valueExpression","constraints","ANY_RETAINED","numCases","tempLocal","tempLocalIndex","breakIndex","defaultIndex","currentBlock","commonCategorical","commonConditional","isLast","nextLabel","count","newArgs","compileAbort","numDeclarations","initializers","isConst","_const_declarations_must_be_initialized","CONSTANT","compileInlineConstant","compileAssertionExpression","compileBinaryExpression","compileCallExpression","compileCommaExpression","compileElementAccessExpression","compileFunctionExpression","compileIdentifierExpression","compileInstanceOfExpression","compileLiteralExpression","compileNewExpression","compilePropertyAccessExpression","compileTernaryExpression","compileUnaryPostfixExpression","compileUnaryPrefixExpression","wrap","convertExpression","ensureSmallIntegerWrap","explicit","Object_is_possibly_null","Conversion_from_type_0_to_1_requires_an_explicit_cast","PromoteF32","DemoteF64","TruncF32ToI64","TruncF32ToI32","TruncF32ToU64","TruncF32ToU32","TruncF64ToI64","TruncF64ToI32","TruncF64ToU64","TruncF64ToU32","ConvertI64ToF32","ConvertU64ToF32","ConvertI32ToF32","ConvertU32ToF32","ConvertI64ToF64","ConvertU64ToF64","ConvertI32ToF64","ConvertU32ToF64","WrapI64","ExtendI32","ExtendU32","inheritedConstraints","PREFIX","exceptVoid","Expression_is_never_null","tempIndex","leftExpr","leftType","rightExpr","rightType","commonType","compound","compileBinaryOverload","Operator_0_cannot_be_applied_to_types_1_and_2","AllTrueVecI8x16","EqVecI8x16","AnyTrueVecI8x16","NeVecI8x16","compileAssignment","AddI64","AddF32","AddF64","SubI32","SubI64","SubF32","SubF64","MulI64","MulF32","MulF64","namespace","makeCallDirect","DivI32","DivI64","DivU64","DivF32","DivF64","RemI64","RemU64","intType","ShlI64","The_0_operator_cannot_be_applied_to_type_1","ShrI64","ShrU64","AndI64","OrI32","OrI64","XorI32","XorI64","rightFlow","performAutoreleasesWithValue","leftAutoreleaseSkipped","rightAutoreleaseSkipped","retainLeftInElse","moveAutorelease","rightStmts","makeRelease","retainLeftInThen","makeAssignment","compileUnaryOverload","thisExpression","Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property","isUnchecked","indexedSet","Index_signature_in_type_0_only_permits_reading","indexExpression","tee","makeLocalAssignment","makeFieldAssignment","makeAutorelease","nativeReturnType","thisExpr_1","thisExpr","elementExpr","tempLocalTarget","tempLocalElement","makeSkippedRelease","nativeFieldType","nativeThisType","tempThis","tempValue","flow_2","Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors","baseClassInstance","theCall","compileCallDirect","ensureConstructor","_super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class","indexArg","compileCallExpressionBuiltin","inferredTypes","argumentNodes","argumentExprs","templateName","argumentExpression","inferredType","concreteType","compileCallIndirect","compileCall","checkCallSignature","hasThis","minimum","Expected_at_least_0_arguments_but_got_1","argumentExpressions","thisArg","parameterTypes_1","makeCallInline","Function_0_cannot_be_inlined_into_itself","numArgumentsInclThis","immediatelyDropped","usedLocals","paramExpr","paramType","argumentLocal","baseInstance","initType","originalSignature","originalName","originalParameterTypes","originalParameterDeclarations","minArguments","minOperands","maxArguments","maxOperands","numOptional","forwardedOperands","operandIndex","trampolineSignature","ofN","argc","Optional_parameter_must_have_an_initializer","ensureArgcVar","setargc","oldExpr","newExpr","temp1","temp2","undoAutorelease","fromInnerFlow","toOuterFlow","clearFlags","lengthBefore","skipAutorelease","TODO_Cannot_inline_inferred_calls_and_specific_internals_yet","numOperands","isCallImport","allOptionalsAreConstant","expr_1","makeCallIndirect","numExpressions","exprs","contextualSignature","numPresentParameters","thisTypeNode","maybeCompileEnclosingSource","flow_3","actualFunction_1","_super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class","scopedThis","superType","A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums","actualType","implicitlyNegate","compileArrayLiteral","floatValue","i64_to_f32","i64_to_f64","compileStringLiteral","compileObjectLiteral","tempDataStart","nativeElementType","bufferAddress","arraySegment","arrayAddress","alignLog2","nativeArrayType","dataStart","ctor","Constructor_of_class_0_must_not_require_any_arguments","Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration","Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration","hasErrors","Cannot_use_new_with_an_expression_whose_type_lacks_a_construct_signature","compileInstantiate","baseCtor","theEnum","Cannot_access_method_0_without_calling_it_as_it_requires_this_to_be_set","ifThenFlow","ifThenExpr","ifThenType","IfThenAutoreleaseSkipped","ifElseFlow","ifElseExpr","ifElseType","ifElseAutoreleaseSkipped","getValue","setValue","NegF32","NegF64","makeIsFalseish","ExtendI8ToI32","ExtendI16ToI32","thisLocalIndex","makeInstanceOfClass","idTemp","idExpr","conditions","single","Auto","compiler_1","compiler","isAsm","directize","isInteger","evaluateConstantType","isFloat","isBoolean","isSigned","isReference","isString","isArray","isArrayLike","isFunction","isDefined","checkTypeAbsent","checkArgsRequired","SWALLOW","isConstant","sizeof","checkTypeRequired","alignof","ctz","checkArgsOptional","typeArgumentsRange","Type_0_has_no_property_1","popcnt","checkTypeOptional","ClzI64","CtzI64","PopcntI64","rotl","RotlI32","RotlI64","rotr","RotrI32","RotrI64","abs","tempLocal1","tempLocalIndex2","tempLocalIndex1","wasm64","AbsF32","AbsF64","MaxF32","MaxF64","tempLocal0","min","MinF32","MinF64","floor","CeilF32","FloorF32","CeilF64","FloorF64","copysign","CopysignF32","CopysignF64","nearest","NearestF32","NearestF64","reinterpret","ReinterpretF32","ReinterpretF64","ReinterpretI32","ReinterpretI64","sqrt","SqrtF32","SqrtF64","trunc","TruncF32","TruncF64","outType","immOffset","evaluateImmediateOffset","immAlign","naturalAlign","_0_must_be_a_value_between_1_and_2_inclusive","_0_must_be_a_power_of_two","inType","atomic_add","atomic_sub","atomic_and","atomic_or","atomic_xor","atomic_xchg","Add","Sub","And","Or","Xor","Xchg","memory_size","MemorySize","memory_grow","MemoryGrow","alreadyUnchecked","call_direct","arg0Type","operandExprs","nativeParamTypes","operandType","instantiate","User_defined_0","Expression_must_be_a_compile_time_constant","off","v128_splat","SplatVecI8x16","SplatVecI16x8","SplatVecI32x4","SplatVecI64x2","SplatVecF32x4","SplatVecF64x2","v128_extract_lane","ExtractLaneSVecI8x16","ExtractLaneUVecI8x16","ExtractLaneSVecI16x8","ExtractLaneUVecI16x8","ExtractLaneVecI32x4","ExtractLaneVecI64x2","ExtractLaneVecF32x4","ExtractLaneVecF64x2","maxIdx","v128_replace_lane","ReplaceLaneVecI8x16","ReplaceLaneVecI16x8","ReplaceLaneVecI32x4","ReplaceLaneVecI64x2","ReplaceLaneVecF32x4","ReplaceLaneVecF64x2","v128_shuffle","laneWidth","laneCount","argN","off8","idx8","v128_add","v128_sub","v128_mul","v128_div","v128_add_saturate","v128_sub_saturate","v128_min","v128_max","v128_eq","v128_ne","v128_lt","v128_le","v128_gt","v128_ge","AddVecI8x16","AddVecI16x8","AddVecI32x4","AddVecI64x2","AddVecF32x4","AddVecF64x2","SubVecI8x16","SubVecI16x8","SubVecI32x4","SubVecI64x2","SubVecF32x4","SubVecF64x2","MulVecI8x16","MulVecI16x8","MulVecI32x4","MulVecF32x4","MulVecF64x2","DivVecF32x4","DivVecF64x2","AddSatSVecI8x16","AddSatUVecI8x16","AddSatSVecI16x8","AddSatUVecI16x8","SubSatSVecI8x16","SubSatUVecI8x16","SubSatSVecI16x8","SubSatUVecI16x8","MinVecF32x4","MinVecF64x2","MaxVecF32x4","MaxVecF64x2","EqVecI16x8","EqVecI32x4","EqVecF32x4","EqVecF64x2","NeVecI16x8","NeVecI32x4","NeVecF32x4","NeVecF64x2","LtSVecI8x16","LtUVecI8x16","LtSVecI16x8","LtUVecI16x8","LtSVecI32x4","LtUVecI32x4","LtVecF32x4","LtVecF64x2","LeSVecI8x16","LeUVecI8x16","LeSVecI16x8","LeUVecI16x8","LeSVecI32x4","LeUVecI32x4","LeVecF32x4","LeVecF64x2","GtSVecI8x16","GtUVecI8x16","GtSVecI16x8","GtUVecI16x8","GtSVecI32x4","GtUVecI32x4","GtVecF32x4","GtVecF64x2","GeSVecI8x16","GeUVecI8x16","GeSVecI16x8","GeUVecI16x8","GeSVecI32x4","GeUVecI32x4","GeVecF32x4","GeVecF64x2","v128_neg","v128_abs","v128_sqrt","v128_convert","v128_trunc","NegVecI8x16","NegVecI16x8","NegVecI32x4","NegVecI64x2","NegVecF32x4","NegVecF64x2","AbsVecF32x4","AbsVecF64x2","SqrtVecF32x4","SqrtVecF64x2","ConvertSVecI32x4ToVecF32x4","ConvertUVecI32x4ToVecF32x4","ConvertSVecI64x2ToVecF64x2","ConvertUVecI64x2ToVecF64x2","TruncSatSVecF32x4ToVecI32x4","TruncSatUVecF32x4ToVecI32x4","TruncSatSVecF64x2ToVecI64x2","TruncSatUVecF64x2ToVecI64x2","v128_shl","v128_shr","ShlVecI8x16","ShlVecI16x8","ShlVecI32x4","ShlVecI64x2","ShrSVecI8x16","ShrUVecI8x16","ShrSVecI16x8","ShrUVecI16x8","ShrSVecI32x4","ShrUVecI32x4","ShrSVecI64x2","ShrUVecI64x2","v128_and","v128_or","v128_xor","AndVec128","OrVec128","XorVec128","v128_not","NotVec128","v128_bitselect","v128_any_true","v128_all_true","AnyTrueVecI16x8","AnyTrueVecI32x4","AnyTrueVecI64x2","AllTrueVecI16x8","AllTrueVecI32x4","AllTrueVecI64x2","idof","visit_globals","visit_members","i32_clz","deferASM","i64_clz","i32_ctz","i64_ctz","i32_popcnt","i64_popcnt","i32_rotl","i64_rotl","i32_rotr","i64_rotr","f32_abs","f64_abs","f32_max","f64_max","f32_min","f64_min","f32_ceil","f64_ceil","f32_floor","f64_floor","f32_copysign","f64_copysign","f32_nearest","f64_nearest","i32_reinterpret_f32","i64_reinterpret_f64","f32_reinterpret_i32","f64_reinterpret_i64","f32_sqrt","f64_sqrt","f32_trunc","f64_trunc","i32_load8_s","i32_load8_u","i32_load16_s","i32_load16_u","i32_load","i64_load8_s","i64_load8_u","i64_load16_s","i64_load16_u","i64_load32_s","i64_load32_u","i64_load","f32_load","f64_load","i32_store8","i32_store16","i32_store","i64_store8","i64_store16","i64_store32","i64_store","f32_store","f64_store","i32_atomic_load8_u","i32_atomic_load16_u","i32_atomic_load","i64_atomic_load8_u","i64_atomic_load16_u","i64_atomic_load32_u","i64_atomic_load","i32_atomic_store8","i32_atomic_store16","i32_atomic_store","i64_atomic_store8","i64_atomic_store16","i64_atomic_store32","i64_atomic_store","i32_atomic_rmw8_add_u","i32_atomic_rmw16_add_u","i32_atomic_rmw_add","i64_atomic_rmw8_add_u","i64_atomic_rmw16_add_u","i64_atomic_rmw32_add_u","i64_atomic_rmw_add","i32_atomic_rmw8_sub_u","i32_atomic_rmw16_sub_u","i32_atomic_rmw_sub","i64_atomic_rmw8_sub_u","i64_atomic_rmw16_sub_u","i64_atomic_rmw32_sub_u","i64_atomic_rmw_sub","i32_atomic_rmw8_and_u","i32_atomic_rmw16_and_u","i32_atomic_rmw_and","i64_atomic_rmw8_and_u","i64_atomic_rmw16_and_u","i64_atomic_rmw32_and_u","i64_atomic_rmw_and","i32_atomic_rmw8_or_u","i32_atomic_rmw16_or_u","i32_atomic_rmw_or","i64_atomic_rmw8_or_u","i64_atomic_rmw16_or_u","i64_atomic_rmw32_or_u","i64_atomic_rmw_or","i32_atomic_rmw8_u_xor","i32_atomic_rmw16_u_xor","i32_atomic_rmw_xor","i64_atomic_rmw8_xor_u","i64_atomic_rmw16_xor_u","i64_atomic_rmw32_xor_u","i64_atomic_rmw_xor","i32_atomic_rmw8_xchg_u","i32_atomic_rmw16_xchg_u","i32_atomic_rmw_xchg","i64_atomic_rmw8_xchg_u","i64_atomic_rmw16_xchg_u","i64_atomic_rmw32_xchg_u","i64_atomic_rmw_xchg","i32_atomic_rmw8_cmpxchg_u","i32_atomic_rmw16_cmpxchg_u","i32_atomic_rmw_cmpxchg","i64_atomic_rmw8_cmpxchg_u","i64_atomic_rmw16_cmpxchg_u","i64_atomic_rmw32_cmpxchg_u","i64_atomic_rmw_cmpxchg","i32_wait","i64_wait","v128_load","v128_store","i8x16_splat","i8x16_extract_lane_s","i8x16_extract_lane_u","i8x16_replace_lane","i8x16_add","i8x16_sub","i8x16_mul","i8x16_neg","i8x16_add_saturate_s","i8x16_add_saturate_u","i8x16_sub_saturate_s","i8x16_sub_saturate_u","i8x16_shl","i8x16_shr_s","i8x16_shr_u","i8x16_any_true","i8x16_all_true","i8x16_eq","i8x16_ne","i8x16_lt_s","i8x16_lt_u","i8x16_le_s","i8x16_le_u","i8x16_gt_s","i8x16_gt_u","i8x16_ge_s","i8x16_ge_u","i16x8_splat","i16x8_extract_lane_s","i16x8_extract_lane_u","i16x8_replace_lane","i16x8_add","i16x8_sub","i16x8_mul","i16x8_neg","i16x8_add_saturate_s","i16x8_add_saturate_u","i16x8_sub_saturate_s","i16x8_sub_saturate_u","i16x8_shl","i16x8_shr_s","i16x8_shr_u","i16x8_any_true","i16x8_all_true","i16x8_eq","i16x8_ne","i16x8_lt_s","i16x8_lt_u","i16x8_le_s","i16x8_le_u","i16x8_gt_s","i16x8_gt_u","i16x8_ge_s","i16x8_ge_u","i32x4_splat","i32x4_extract_lane","i32x4_replace_lane","i32x4_add","i32x4_sub","i32x4_mul","i32x4_neg","i32x4_shl","i32x4_shr_s","i32x4_shr_u","i32x4_any_true","i32x4_all_true","i32x4_eq","i32x4_ne","i32x4_lt_s","i32x4_lt_u","i32x4_le_s","i32x4_le_u","i32x4_gt_s","i32x4_gt_u","i32x4_ge_s","i32x4_ge_u","i32x4_trunc_s_f32x4_sat","i32x4_trunc_u_f32x4_sat","i64x2_splat","i64x2_extract_lane","i64x2_replace_lane","i64x2_add","i64x2_sub","i64x2_neg","i64x2_shl","i64x2_shr_s","i64x2_shr_u","i64x2_any_true","i64x2_all_true","i64x2_trunc_s_f64x2_sat","i64x2_trunc_u_f64x2_sat","f32x4_splat","f32x4_extract_lane","f32x4_replace_lane","f32x4_add","f32x4_sub","f32x4_mul","f32x4_div","f32x4_neg","f32x4_min","f32x4_max","f32x4_abs","f32x4_sqrt","f32x4_eq","f32x4_ne","f32x4_lt","f32x4_le","f32x4_gt","f32x4_ge","f32x4_convert_s_i32x4","f32x4_convert_u_i32x4","f64x2_splat","f64x2_extract_lane","f64x2_replace_lane","f64x2_add","f64x2_sub","f64x2_mul","f64x2_div","f64x2_neg","f64x2_min","f64x2_max","f64x2_abs","f64x2_sqrt","f64x2_eq","f64x2_ne","f64x2_lt","f64x2_le","f64x2_gt","f64x2_ge","f64x2_convert_s_i64x2","f64x2_convert_u_i64x2","v8x16_shuffle","tryDeferASM","messageArg","filenameArg","typeToRuntimeFlags","argumentsRange","setCurrentTypeOnError","expectedMinimum","expectedMaximum","memory_allocate","memory_free","memory_reset","runtime_instanceof","runtime_flags","runtime_allocate","runtime_reallocate","runtime_register","runtime_discard","runtime_makeArray","capabilities","nativeSizeSize","ftype","blocks","outer","lastId","managedClasses_1","managedClasses_1_1","visitImpl","isDeclaredInLibrary","visitFunc","visitSig","fieldOffset","managedClasses_2","managedClasses_2_1","abvPrototype","managedClasses_3","managedClasses_3_1","isAcyclic","Decompiler","functionId","decompile","decompiler","decompileFunction","nativeTypeToType","decompileExpression","nested","i64_to_string","ExportsWalker","includePrivate","seen","walk","visitFile","visitElement","visitAlias","visitGlobal","visitEnum","visitFunctionInstances","visitClassInstances","visitField","visitPropertyInstances","prop","visitFunction","hasCompiledMember","e_15","e_16","visitNamespace","visitClass","IDLBuilder","indentLevel","build","indent","typeToString","members_2","members_2_1","name_1","visitInterface","TSDBuilder","unknown","numMembers","members_3","members_3_1","name_2","isInterface","Parser","backlog","seenlog","donelog","tryParseSignatureIsSignature","parseParametersThis","parseFile","indexOf","tn","parseTopLevelStatement","startPos","parseDecorator","skipStatement","exportStart","exportEnd","defaultStart","defaultEnd","declareStart","declareEnd","contextIsAmbient","A_declare_modifier_cannot_be_used_in_an_already_ambient_context","first","parseEnum","parseVariable","parseFunction","parseStatement","parseClassOrInterface","parseNamespace","parseExportImport","parseImport","parseTypeDeclaration","An_export_assignment_cannot_have_modifiers","parseExportDefaultAlias","parseExport","_0_modifier_cannot_be_used_here","Decorators_are_not_valid_here","nextFile","clear","parseType","acceptParenthesized","suppressErrors","isNullableSignature","tryParseFunctionType","Unexpected_token","innerType","Identifier_expected","nullable","parameter","bracketStart","bracketRange","isSignature","A_rest_parameter_cannot_be_optional","OPTIONAL","param","parseArguments","parseVariableDeclaration","parentFlags","parentDecorators","DEFINITE_ASSIGNMENT","Initializers_are_not_allowed_in_ambient_contexts","parseExpression","A_definite_assignment_assertion_is_not_permitted_in_this_context","parseEnumValue","parseReturn","parseTypeParameters","seenOptional","typeParameter","parseTypeParameter","Required_type_parameters_may_not_follow_optional_type_parameters","Type_parameter_list_cannot_be_empty","parseParameters","isConstructor","seenRest","reportedRest","parseParameter","A_rest_parameter_must_be_last_in_a_parameter_list","A_required_parameter_cannot_follow_an_optional_parameter","isRest","isOptional","startRange","accessFlags","A_parameter_property_cannot_be_declared_using_a_rest_parameter","A_rest_parameter_cannot_have_an_initializer","Parameter_cannot_have_question_mark_and_initializer","signatureStart","isSetter","A_set_accessor_must_have_exactly_one_parameter","A_set_accessor_parameter_cannot_have_an_initializer","A_get_accessor_cannot_have_parameters","parseBlockStatement","parseFunctionExpression","parseFunctionExpressionCommon","bodyExpression","Interface_declaration_cannot_have_implements_clause","parseClassMember","parseClassExpression","VIRTUAL","accessStart","accessEnd","staticStart","staticEnd","abstractStart","abstractEnd","GENERIC_CONTEXT","readonlyStart","readonlyEnd","state_1","setEnd","retIndex","parseIndexSignatureDeclaration","typeParametersStart","Type_parameters_cannot_appear_on_a_constructor_declaration","An_accessor_cannot_have_type_parameters","Type_annotation_cannot_appear_on_a_constructor_declaration","A_set_accessor_cannot_have_a_return_type_annotation","Method_0_cannot_have_an_implementation_because_it_is_marked_abstract","retMethod","Constructor_implementation_is_missing","Optional_properties_are_not_supported","retField","parseExportMember","asIdentifier","skipFrom","parseImportDeclaration","topLevel","parseBreak","parseContinue","parseDoStatement","parseForStatement","parseIfStatement","A_return_statement_can_only_be_used_within_a_function_body","parseSwitchStatement","parseThrowStatement","parseTryStatement","parseVoidStatement","parseWhileStatement","parseExpressionStatement","elseStatement","case_","parseSwitchCase","_case_or_default_expected","parseExpressionStart","precedence","determinePrecedenceStart","The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access","again","startPos_1","identifierText","_super_must_be_followed_by_an_argument_list_or_member_access","regexpPattern","Expression_expected","tryParseTypeArgumentsBeforeArguments","nextPrecedence","maybeParseCallExpression","determinePrecedence","commaExprs","isRightAssociative","joinPropertyCall","callee","inner","skipBlock","depth","Precedence","binaryen","wrapModule","emitStackIR","emitAsmjs","Binaryen","__memory_allocate","_malloc","__memory_free","_free","__memory_copy","_memmove","__store","HEAPU8","__load","globalScope","UnreachableError","captureStackTrace","AssertionError","defineProperties","writable","fround","EPSILON","MIN_NORMAL_VALUE","MIN_SAFE_INTEGER","MAX_SAFE_INTEGER","clz32","round","y","sign","isTrueish","fromCodePoint","replaceAll","search","replacment","res","split","Number","capacity","sincos_sin","sincos_cos","signbit","Boolean","sincos","sin","cos","HEAP","HEAP_OFFSET","oldHeap","fill","copy","copyWithin","f32_as_i32","i32_as_f32","f64_as_i64","i64_as_f64","Long","ZERO","i64_one","ONE","lo","hi","fromBits","low","high","sub","mul","i64_div","div","i64_div_u","toUnsigned","toSigned","i64_rem","i64_rem_u","i64_and","and","i64_or","or","i64_xor","xor","shl","i64_shr","shr","shru","i64_not","not","i64_eq","eq","i64_ne","ne","fromInt","minSafeF32","fromNumber","maxSafeF32","i64_is_f32","gte","lte","minSafeF64","maxSafeF64","i64_is_f64","toNumber","unsigned","wasm","WebAssembly","Instance","isLong","obj","__isLong__","INT_CACHE","UINT_CACHE","cachedObj","cache","isNaN","UZERO","TWO_PWR_64_DBL","MAX_UNSIGNED_VALUE","TWO_PWR_63_DBL","neg","TWO_PWR_32_DBL","lowBits","highBits","pow_dbl","fromString","radix","RangeError","radixToPower","power","fromValue","TWO_PWR_16_DBL","TWO_PWR_24","UONE","NEG_ONE","LongPrototype","toInt","isZero","isNegative","radixLong","rem1","rem","remDiv","digits","getHighBits","getHighBitsUnsigned","getLowBits","getLowBitsUnsigned","getNumBitsAbs","bit","eqz","isPositive","isOdd","isEven","equals","notEquals","neq","lessThan","comp","lt","lessThanOrEqual","le","greaterThan","gt","greaterThanOrEqual","ge","compare","thisNeg","otherNeg","negate","addend","a48","a32","a16","a00","b48","b32","b16","c48","c32","c16","c00","subtract","subtrahend","multiply","multiplier","get_high","b00","divide","divisor","approx","div_u","div_s","log2","log","LN2","delta","approxRes","approxRem","modulo","rem_u","rem_s","shiftLeft","numBits","shiftRight","shiftRightUnsigned","shr_u","toBytes","toBytesLE","toBytesBE","fromBytes","fromBytesLE","fromBytesBE","__decorate","unmanaged","decompiler_1","definitions_1","formatDiagnostic","parser_1","parser","nextDiagnostic","isInfo","isWarning","isError","createOptions","setTarget","setNoAssert","setImportMemory","setSharedMemory","setImportTable","setSourceMap","setMemoryBase","setGlobalAlias","setExplicitStart","FEATURE_SIGN_EXTENSION","FEATURE_MUTABLE_GLOBAL","FEATURE_BULK_MEMORY","FEATURE_SIMD","FEATURE_THREADS","enableFeature","setOptimizeLevelHints","optimizeLevel","shrinkLevel","finishParsing","compileProgram","decompileModule","buildIDL","buildTSD","buildRTTI","cls","bitsetIs","map","bitsetSet","isSet","CharCode","lookupInUnicodeMap","unicodeIdentifierStart","unicodeIdentifierPart","mid","midVal","makeArray","cloned","makeSet","original_1","original_1_1","v","overrides","original_2","original_2_1","overrides_1","overrides_1_1","overrides_2","overrides_2_1","separator","ipos","dirname","origin","indentX1","indentX2","indentX4","readI32","readI64","readI8","readI16","readF32","readF64","valueI64"],"mappings":"CAAA,SAAAA,EAAAC,GACA,iBAAAC,SAAA,iBAAAC,OACAA,OAAAD,QAAAD,EAAAG,QAAA,aACA,mBAAAC,eAAAC,IACAD,OAAA,aAAAJ,GACA,iBAAAC,QACAA,QAAA,eAAAD,EAAAG,QAAA,aAEAJ,EAAA,eAAAC,EAAAD,EAAA,UARA,CASC,oBAAAO,UAAAC,KAAA,SAAAC,GACD,mBCTA,IAAAC,EAAA,GAGA,SAAAC,EAAAC,GAGA,GAAAF,EAAAE,GACA,OAAAF,EAAAE,GAAAV,QAGA,IAAAC,EAAAO,EAAAE,GAAA,CACAC,EAAAD,EACAE,GAAA,EACAZ,QAAA,IAUA,OANAa,EAAAH,GAAAI,KAAAb,EAAAD,QAAAC,IAAAD,QAAAS,GAGAR,EAAAW,GAAA,EAGAX,EAAAD,QA0DA,OArDAS,EAAAM,EAAAF,EAGAJ,EAAAO,EAAAR,EAGAC,EAAAQ,EAAA,SAAAjB,EAAAkB,EAAAC,GACAV,EAAAW,EAAApB,EAAAkB,IACAG,OAAAC,eAAAtB,EAAAkB,EAAA,CAA0CK,YAAA,EAAAC,IAAAL,KAK1CV,EAAAgB,EAAA,SAAAzB,GACA,oBAAA0B,eAAAC,aACAN,OAAAC,eAAAtB,EAAA0B,OAAAC,YAAA,CAAwDC,MAAA,WAExDP,OAAAC,eAAAtB,EAAA,cAAiD4B,OAAA,KAQjDnB,EAAAoB,EAAA,SAAAD,EAAAE,GAEA,GADA,EAAAA,IAAAF,EAAAnB,EAAAmB,IACA,EAAAE,EAAA,OAAAF,EACA,KAAAE,GAAA,iBAAAF,QAAAG,WAAA,OAAAH,EACA,IAAAI,EAAAX,OAAAY,OAAA,MAGA,GAFAxB,EAAAgB,EAAAO,GACAX,OAAAC,eAAAU,EAAA,WAAyCT,YAAA,EAAAK,UACzC,EAAAE,GAAA,iBAAAF,EAAA,QAAAM,KAAAN,EAAAnB,EAAAQ,EAAAe,EAAAE,EAAA,SAAAA,GAAgH,OAAAN,EAAAM,IAAqBC,KAAA,KAAAD,IACrI,OAAAF,GAIAvB,EAAA2B,EAAA,SAAAnC,GACA,IAAAkB,EAAAlB,KAAA8B,WACA,WAA2B,OAAA9B,EAAA,SAC3B,WAAiC,OAAAA,GAEjC,OADAQ,EAAAQ,EAAAE,EAAA,IAAAA,GACAA,GAIAV,EAAAW,EAAA,SAAAiB,EAAAC,GAAsD,OAAAjB,OAAAkB,UAAAC,eAAA1B,KAAAuB,EAAAC,IAGtD7B,EAAAgC,EAAA,GAIAhC,IAAAiC,EAAA,oFC5EA,SAAYC,GAEVA,IAAA,eAKAA,IAAA,mBAEAA,IAAA,mBAEAA,IAAA,qBAEAA,IAAA,iBAEAA,IAAA,cAEAA,IAAA,oBAEAA,IAAA,wBAEAA,IAAA,yBAEAA,IAAA,qBAEAA,IAAA,uBAEAA,IAAA,4BAEAA,IAAA,gBAEAA,IAAA,gBAEAA,IAAA,gDAKAA,IAAA,yBAEAA,IAAA,yBAEAA,IAAA,yCAEAA,IAAA,4BAEAA,IAAA,kCAEAA,IAAA,sCAEAA,IAAA,uCAKAA,IAAA,6BAEAA,IAAA,6BAEAA,IAAA,2BAEAA,IAAA,0BAEAA,IAAA,kCAEAA,IAAA,4BAEAA,IAAA,uBAKAA,IAAA,2BAxEF,CAAY3C,EAAA2C,cAAA3C,EAAA2C,YAAW,KA4EV3C,EAAA4C,eAAiB,IAEjB5C,EAAA6C,aAAe,KAEf7C,EAAA8C,cAAgB,OAEhB9C,EAAA+C,cAAgB,OAEhB/C,EAAAgD,mBAAqB,IAErBhD,EAAAiD,iBAAmB,IAEnBjD,EAAAkD,gBAAkB,IAElBlD,EAAAmD,cAAgB,OAEhBnD,EAAAoD,eAAiBpD,EAAAmD,cAAgBnD,EAAA4C,eAEjC5C,EAAAqD,aAAerD,EAAA4C,eAAiB,QAG7C,SAAiBU,GAEFA,EAAAC,MAAQ,GAERD,EAAAE,GAAK,KACLF,EAAAG,IAAM,MACNH,EAAAI,IAAM,MACNJ,EAAAK,IAAM,MACNL,EAAAM,MAAQ,QACRN,EAAAO,GAAK,KACLP,EAAAQ,IAAM,MACNR,EAAAS,IAAM,MACNT,EAAAU,IAAM,MACNV,EAAAW,MAAQ,QACRX,EAAAY,KAAO,OACPZ,EAAAa,IAAM,MACNb,EAAAc,IAAM,MACNd,EAAAe,KAAO,OACPf,EAAAgB,MAAQ,QACRhB,EAAAiB,MAAQ,QACRjB,EAAAkB,MAAQ,QACRlB,EAAAmB,MAAQ,QACRnB,EAAAoB,MAAQ,QACRpB,EAAAqB,MAAQ,QACRrB,EAAAsB,MAAQ,QACRtB,EAAAuB,MAAQ,QACRvB,EAAAwB,MAAQ,QACRxB,EAAAyB,MAAQ,QACRzB,EAAA0B,MAAQ,OACR1B,EAAA2B,OAAS,SACT3B,EAAA4B,QAAU,UACV5B,EAAA6B,OAAS,SACT7B,EAAA8B,OAAS,SACT9B,EAAA+B,QAAU,UACV/B,EAAAgC,QAAU,UAEVhC,EAAAiC,MAAQ,OACRjC,EAAAkC,MAAQ,OACRlC,EAAAmC,OAAS,QAETnC,EAAAoC,MAAQ,OACRpC,EAAAqC,OAAS,QACTrC,EAAAsC,YAAc,cAEdtC,EAAAuC,WAAa,aACbvC,EAAAwC,mBAAqB,qBACrBxC,EAAAyC,cAAgB,gBAChBzC,EAAA0C,gBAAkB,kBAClB1C,EAAA2C,mBAAqB,qBACrB3C,EAAA4C,iBAAmB,mBACnB5C,EAAA6C,2BAA6B,6BAC7B7C,EAAA8C,2BAA6B,6BAC7B9C,EAAA+C,wBAA0B,0BAC1B/C,EAAAgD,iBAAmB,mBACnBhD,EAAAiD,oBAAsB,sBAEtBjD,EAAAkD,GAAK,KACLlD,EAAAmD,IAAM,MACNnD,EAAAoD,IAAM,MACNpD,EAAAqD,IAAM,MACNrD,EAAAsD,MAAQ,QACRtD,EAAAuD,GAAK,KACLvD,EAAAwD,IAAM,MACNxD,EAAAyD,IAAM,MACNzD,EAAA0D,IAAM,MACN1D,EAAA2D,MAAQ,QACR3D,EAAA4D,KAAO,OACP5D,EAAA6D,IAAM,MACN7D,EAAA8D,IAAM,MACN9D,EAAA+D,KAAO,OACP/D,EAAAgE,OAAS,SACThE,EAAAiE,MAAQ,QACRjE,EAAAkE,WAAa,aACblE,EAAAmE,IAAM,MACNnE,EAAAoE,IAAM,MACNpE,EAAAqE,gBAAkB,kBAClBrE,EAAAsE,YAAc,cACdtE,EAAAuE,KAAO,OACPvE,EAAAwE,MAAQ,QACRxE,EAAAyE,UAAY,YACZzE,EAAA0E,WAAa,aACb1E,EAAA2E,WAAa,aACb3E,EAAA4E,WAAa,aACb5E,EAAA6E,WAAa,aACb7E,EAAA8E,kBAAoB,oBACpB9E,EAAA+E,YAAc,cACd/E,EAAAgF,YAAc,cACdhF,EAAAiF,YAAc,cACdjF,EAAAkF,aAAe,eACflF,EAAAmF,aAAe,eAEfnF,EAAAoF,MAAQ,QACRpF,EAAAqF,IAAM,MACNrF,EAAAsF,IAAM,MACNtF,EAAAuF,MAAQ,UACRvF,EAAAwF,QAAU,YACVxF,EAAAyF,KAAO,SACPzF,EAAA0F,OAAS,WACT1F,EAAA2F,QAAU,YACV3F,EAAA4F,QAAU,YACV5F,EAAA6F,SAAW,aACX7F,EAAA8F,YAAc,eACd9F,EAAA+F,MAAQ,UACR/F,EAAAgG,WAAa,eAvG5B,CAAiBtJ,EAAAsD,gBAAAtD,EAAAsD,cAAa,KA2G9B,IAAAiG,EAAA9I,EAAA,IAAST,EAAAwJ,QAAAD,EAAAC,QACT,IAAAC,EAAAhJ,EAAA,IAAST,EAAA0J,OAAAD,EAAAC,OACT,IAAAC,EAAAlJ,EAAA,IAAST,EAAA4J,SAAAD,EAAAC,SAAU5J,EAAA6J,cAAAF,EAAAE,2JC9MnBC,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,KAGAT,EAAA+J,WAAA,SAA2BC,GACzB,OAAY,GAALA,GAA2B,IAAhBA,EAAKA,EAAI,mFCL7B,IAeYC,EAfZC,EAAAzJ,EAAA,IAKA0J,EAAA1J,EAAA,GAIA2J,EAAA3J,EAAA,IAgBA,SAAgB4J,EAA2BC,GACzC,OAAQA,GACN,KAAKL,EAAmBM,KAAM,MAAO,OACrC,KAAKN,EAAmBO,QAAS,MAAO,UACxC,KAAKP,EAAmBQ,MAAO,MAAO,QACtC,QAEE,OADAC,QAAO,GACA,IAeb,SAAgBC,EAA0BL,GACxC,OAAQA,GACN,KAAKL,EAAmBM,KAAM,OAAOvK,EAAA4K,WACrC,KAAKX,EAAmBO,QAAS,OAAOxK,EAAA6K,aACxC,KAAKZ,EAAmBQ,MAAO,OAAOzK,EAAA8K,UACtC,QAEE,OADAJ,QAAO,GACA,IA5CX1K,EAAA+K,eAAAX,EAAAW,eACA/K,EAAAgL,uBAAAZ,EAAAY,uBAIF,SAAYf,GAEVA,IAAA,eAEAA,IAAA,qBAEAA,IAAA,iBANF,CAAYA,EAAAjK,EAAAiK,qBAAAjK,EAAAiK,mBAAkB,KAU9BjK,EAAAqK,6BAaarK,EAAA4K,WAAqB,QAErB5K,EAAA6K,aAAuB,QAEvB7K,EAAA8K,UAAoB,QAEpB9K,EAAAiL,YAAsB,OAGnCjL,EAAA2K,4BAaA,IAAAO,EAAA,WAcE,SAAAA,EAAoBC,EAAWb,EAA8Bc,GAL7D9K,KAAA+K,MAAsB,KAEtB/K,KAAAgL,aAA6B,KAI3BhL,KAAK6K,KAAOA,EACZ7K,KAAKgK,SAAWA,EAChBhK,KAAK8K,QAAUA,EAkFnB,OA9ESF,EAAAjJ,OAAP,SACEkJ,EACAb,EACAiB,EACAC,EACAC,QAFA,IAAAF,MAAA,WACA,IAAAC,MAAA,WACA,IAAAC,MAAA,MAEA,IAAIL,EAAUlB,EAAAc,uBAAuBG,GAIrC,OAHY,MAARI,IAAcH,EAAUA,EAAQM,QAAQ,MAAOH,IACvC,MAARC,IAAcJ,EAAUA,EAAQM,QAAQ,MAAOF,IACvC,MAARC,IAAcL,EAAUA,EAAQM,QAAQ,MAAOD,IAC5C,IAAIP,EAAkBC,EAAMb,EAAUc,IAIxCF,EAAAS,WAAP,SACER,EACAI,EACAC,GAEA,YAHA,IAAAD,MAAA,WACA,IAAAC,MAAA,MAEON,EAAkBjJ,OAAOkJ,EAAMlB,EAAmBM,KAAMgB,EAAMC,IAIhEN,EAAAU,cAAP,SACET,EACAI,EACAC,GAEA,YAHA,IAAAD,MAAA,WACA,IAAAC,MAAA,MAEON,EAAkBjJ,OAAOkJ,EAAMlB,EAAmBO,QAASe,EAAMC,IAInEN,EAAAW,YAAP,SACEV,EACAI,EACAC,GAEA,YAHA,IAAAD,MAAA,WACA,IAAAC,MAAA,MAEON,EAAkBjJ,OAAOkJ,EAAMlB,EAAmBQ,MAAOc,EAAMC,IAIxEN,EAAA3I,UAAAuJ,UAAA,SAAUT,GAER,OADA/K,KAAK+K,MAAQA,EACN/K,MAIT4K,EAAA3I,UAAAwJ,iBAAA,SAAiBV,GAEf,OADA/K,KAAKgL,aAAeD,EACb/K,MAIT4K,EAAA3I,UAAAyJ,SAAA,WACE,OAAI1L,KAAK+K,MAELhB,EAA2B/J,KAAKgK,UAChC,IACAhK,KAAK6K,KAAKa,SAAS,IACnB,MACA1L,KAAK8K,QACL,QACA9K,KAAK+K,MAAMY,OAAOC,eAClB,IACA5L,KAAK+K,MAAMc,KAAKH,SAAS,IACzB,IACA1L,KAAK+K,MAAMe,OAAOJ,SAAS,IAI7B3B,EAA2B/J,KAAKgK,UAChC,IACAhK,KAAK6K,KAAKa,SAAS,IACnB,KACA1L,KAAK8K,SAGXF,EAnGA,GA4JA,SAAgBmB,EAAwBhB,EAAciB,QAAA,IAAAA,OAAA,GAKpD,IAJA,IAAIC,EAAOlB,EAAMY,OAAOM,KACpBC,EAAMD,EAAKE,OACXC,EAAQrB,EAAMqB,MACdC,EAAMtB,EAAMsB,IACTD,EAAQ,IAAMvC,EAAAyC,YAAYL,EAAKM,WAAWH,EAAQ,KAAKA,IAC9D,KAAOC,EAAMH,IAAQrC,EAAAyC,YAAYL,EAAKM,WAAWF,KAAOA,IAMxD,IALA,IAAIG,EAAe,CACjB,MACAP,EAAKQ,UAAUL,EAAOC,GACtB,OAEKD,EAAQrB,EAAMqB,OACnBI,EAAGE,KAAK,KACRN,IAGF,GADIJ,GAAWQ,EAAGE,KAAKhN,EAAA8K,WACnBO,EAAMqB,OAASrB,EAAMsB,IACvBG,EAAGE,KAAK,UAER,KAAON,IAAUrB,EAAMsB,KAAK,CAC1B,GAAIxC,EAAAyC,YAAYL,EAAKM,WAAWH,IAAS,CACvCI,EAAGE,KAAKN,GAASrB,EAAMqB,MAAQ,EAAI,IAAM,KACzC,MAEFI,EAAGE,KAAK,KAIZ,OADIV,GAAWQ,EAAGE,KAAKhN,EAAAiL,aAChB6B,EAAGG,KAAK,IAzLJjN,EAAAkL,oBAsGblL,EAAAkN,wBAAA,SACE9B,EACAkB,EACAa,QADA,IAAAb,OAAA,QACA,IAAAa,OAAA,GAIA,IAAIL,EAAe,GAUnB,GATIR,GAAWQ,EAAGE,KAAKrC,EAA0BS,EAAQd,WACzDwC,EAAGE,KAAK3C,EAA2Be,EAAQd,WACvCgC,GAAWQ,EAAGE,KAAKhN,EAAAiL,aACvB6B,EAAGE,KAAK5B,EAAQD,KAAO,IAAO,MAAQ,OACtC2B,EAAGE,KAAK5B,EAAQD,KAAKa,SAAS,KAC9Bc,EAAGE,KAAK,MACRF,EAAGE,KAAK5B,EAAQA,SAGZA,EAAQC,MAAO,CAGjB,IAAIA,EAAQD,EAAQC,MAChB8B,IACFL,EAAGE,KAAK,MACRF,EAAGE,KAAKX,EAAwBhB,EAAOiB,KAEzCQ,EAAGE,KAAK,MACRF,EAAGE,KAAK,QACRF,EAAGE,KAAK3B,EAAMY,OAAOC,gBACrBY,EAAGE,KAAK,KACRF,EAAGE,KAAK3B,EAAMc,KAAKH,SAAS,KAC5Bc,EAAGE,KAAK,KACRF,EAAGE,KAAK3B,EAAMe,OAAOJ,SAAS,KAC9Bc,EAAGE,KAAK,KAER,IAAI1B,EAAeF,EAAQE,aACvBA,IACE6B,IACFL,EAAGE,KAAK,MACRF,EAAGE,KAAKX,EAAwBf,EAAcgB,KAEhDQ,EAAGE,KAAK,MACRF,EAAGE,KAAK,QACRF,EAAGE,KAAK3B,EAAMY,OAAOC,gBACrBY,EAAGE,KAAK,KACRF,EAAGE,KAAK3B,EAAMc,KAAKH,SAAS,KAC5Bc,EAAGE,KAAK,KACRF,EAAGE,KAAK3B,EAAMe,OAAOJ,SAAS,KAC9Bc,EAAGE,KAAK,MAGZ,OAAOF,EAAGG,KAAK,KAIjBjN,EAAAqM,0BAiCA,IAAAe,EAAA,WAME,SAAAA,EAAsBC,QAAA,IAAAA,MAAA,MACpB/M,KAAK+M,YAAcA,GAAiD,IAAI9F,MAwF5E,OApFE6F,EAAA7K,UAAA+K,eAAA,SACEnC,EACAb,EACAe,EACAC,EACAC,EACAC,EACAC,QAFA,IAAAF,MAAA,WACA,IAAAC,MAAA,WACA,IAAAC,MAAA,MAEA,IAAIL,EAAUF,EAAkBjJ,OAAOkJ,EAAMb,EAAUiB,EAAMC,EAAMC,GAAMK,UAAUT,GAC/EC,IAAcF,EAAQE,aAAeA,GACzChL,KAAK+M,YAAYL,KAAK5B,IAMxBgC,EAAA7K,UAAAgL,KAAA,SACEpC,EACAE,EACAE,EACAC,EACAC,QAFA,IAAAF,MAAA,WACA,IAAAC,MAAA,WACA,IAAAC,MAAA,MAEAnL,KAAKgN,eAAenC,EAAMlB,EAAmBM,KAAMc,EAAO,KAAME,EAAMC,EAAMC,IAI9E2B,EAAA7K,UAAAiL,YAAA,SACErC,EACAE,EACAC,EACAC,EACAC,EACAC,QAFA,IAAAF,MAAA,WACA,IAAAC,MAAA,WACA,IAAAC,MAAA,MAEAnL,KAAKgN,eAAenC,EAAMlB,EAAmBM,KAAMc,EAAOC,EAAcC,EAAMC,EAAMC,IAItF2B,EAAA7K,UAAAkL,QAAA,SACEtC,EACAE,EACAE,EACAC,EACAC,QAFA,IAAAF,MAAA,WACA,IAAAC,MAAA,WACA,IAAAC,MAAA,MAEAnL,KAAKgN,eAAenC,EAAMlB,EAAmBO,QAASa,EAAO,KAAME,EAAMC,EAAMC,IAIjF2B,EAAA7K,UAAAmL,eAAA,SACEvC,EACAE,EACAC,EACAC,EACAC,EACAC,QAFA,IAAAF,MAAA,WACA,IAAAC,MAAA,WACA,IAAAC,MAAA,MAEAnL,KAAKgN,eAAenC,EAAMlB,EAAmBO,QAASa,EAAOC,EAAcC,EAAMC,EAAMC,IAIzF2B,EAAA7K,UAAAoL,MAAA,SACExC,EACAE,EACAE,EACAC,EACAC,QAFA,IAAAF,MAAA,WACA,IAAAC,MAAA,WACA,IAAAC,MAAA,MAEAnL,KAAKgN,eAAenC,EAAMlB,EAAmBQ,MAAOY,EAAO,KAAME,EAAMC,EAAMC,IAI/E2B,EAAA7K,UAAAqL,aAAA,SACEzC,EACAE,EACAC,EACAC,EACAC,EACAC,QAFA,IAAAF,MAAA,WACA,IAAAC,MAAA,WACA,IAAAC,MAAA,MAEAnL,KAAKgN,eAAenC,EAAMlB,EAAmBQ,MAAOY,EAAOC,EAAcC,EAAMC,EAAMC,IAEzF2B,EA/FA,GAAsBpN,EAAAoN,85BC9PtB,IA8IYS,EA9IZC,EAAArN,EAAA,GAmBAsN,EAAAtN,EAAA,GAMAuN,EAAAvN,EAAA,GAOAwN,EAAAxN,EAAA,GAiDA0J,EAAA1J,EAAA,GASAyN,EAAAzN,EAAA,GAIA0N,EAAA1N,EAAA,IAKA2N,EAAA,WAaA,OAZE,SAESC,EAEAC,EAEAC,EAEAC,EAEAC,GARAnO,KAAA+N,YAEA/N,KAAAgO,kBAEAhO,KAAAiO,oBAEAjO,KAAAkO,cAEAlO,KAAAmO,kBAXX,GAgBAC,EAAA,WAWA,OAVE,SAESJ,EAEAC,EAEAC,EAEAC,GANAnO,KAAAgO,kBAEAhO,KAAAiO,oBAEAjO,KAAAkO,cAEAlO,KAAAmO,kBATX,GAcAE,EAAA,WAUA,OARE,SAESH,EAEAC,EAEAG,GAJAtO,KAAAkO,cAEAlO,KAAAmO,iBAEAnO,KAAAsO,eARX,GA6DA,SAASC,EAA0BC,EAA8BC,GAE/D,OADArE,OAAOqE,EAAItC,QACHqC,GACN,KAAKb,EAAAe,cAAcC,SACnB,KAAKhB,EAAAe,cAAcE,gBACjB,OAAQH,EAAIlC,WAAW,IACrB,QACE,GAAW,MAAPkC,EAAa,OAAOlB,EAAasB,YACrC,GAAW,OAAPJ,EAAc,OAAOlB,EAAauB,YACtC,MAEF,SACE,GAAW,MAAPL,EAAa,OAAOlB,EAAawB,sBACrC,GAAW,OAAPN,EAAc,OAAOlB,EAAayB,sBACtC,MAEF,QACE,GAAW,KAAPP,EAAY,OAAOlB,EAAa0B,IACpC,MAEF,QACE,GAAW,KAAPR,EAAY,OAAOlB,EAAa2B,IACpC,MAEF,QACE,GAAW,KAAPT,EAAY,OAAOlB,EAAa4B,IACpC,GAAW,MAAPV,EAAa,OAAOlB,EAAa6B,IACrC,MAEF,QACE,GAAW,KAAPX,EAAY,OAAOlB,EAAa8B,IACpC,MAEF,QACE,GAAW,KAAPZ,EAAY,OAAOlB,EAAa+B,IACpC,MAEF,QACE,GAAW,KAAPb,EAAY,OAAOlB,EAAagC,YACpC,MAEF,SACE,GAAW,KAAPd,EAAY,OAAOlB,EAAaiC,WACpC,MAEF,QACE,GAAW,KAAPf,EAAY,OAAOlB,EAAakC,YACpC,MAEF,QACE,GAAW,MAAPhB,EAAa,OAAOlB,EAAamC,GACrC,MAEF,QACE,GAAW,MAAPjB,EAAa,OAAOlB,EAAaoC,GACrC,MAEF,QACE,GAAW,KAAPlB,EAAY,OAAOlB,EAAaqC,GACpC,GAAW,MAAPnB,EAAa,OAAOlB,EAAasC,GACrC,GAAW,MAAPpB,EAAa,OAAOlB,EAAauC,YACrC,GAAW,OAAPrB,EAAc,OAAOlB,EAAawC,cACtC,MAEF,QACE,GAAW,KAAPtB,EAAY,OAAOlB,EAAayC,GACpC,GAAW,MAAPvB,EAAa,OAAOlB,EAAa0C,GACrC,GAAW,MAAPxB,EAAa,OAAOlB,EAAa2C,YAIzC,MAEF,KAAKvC,EAAAe,cAAcyB,gBACjB,OAAQ1B,EAAIlC,WAAW,IACrB,QACE,GAAW,KAAPkC,EAAY,OAAOlB,EAAa6C,KACpC,GAAW,MAAP3B,EAAa,OAAOlB,EAAa8C,WACrC,MAEF,QACE,GAAW,KAAP5B,EAAY,OAAOlB,EAAa+C,MACpC,GAAW,MAAP7B,EAAa,OAAOlB,EAAagD,WACrC,MAEF,QACE,GAAW,KAAP9B,EAAY,OAAOlB,EAAaiD,IACpC,MAEF,SACE,GAAW,KAAP/B,EAAY,OAAOlB,EAAakD,YAIxC,MAEF,KAAK9C,EAAAe,cAAcgC,iBACjB,OAAQjC,EAAIlC,WAAW,IACrB,QACE,GAAW,MAAPkC,EAAa,OAAOlB,EAAaoD,YACrC,MAEF,QACE,GAAW,MAAPlC,EAAa,OAAOlB,EAAaqD,aAO7C,OAAOrD,EAAasD,SA9JtB,SAAYtD,GACVA,IAAA,qBAGAA,IAAA,6BACAA,IAAA,6BACAA,IAAA,iDACAA,IAAA,iDAGAA,IAAA,aACAA,IAAA,aACAA,IAAA,aACAA,IAAA,aACAA,IAAA,aACAA,IAAA,cACAA,IAAA,8BACAA,IAAA,4BACAA,IAAA,8BACAA,IAAA,8BACAA,IAAA,8BACAA,IAAA,kCACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YAGAA,IAAA,gBACAA,IAAA,kBACAA,IAAA,cACAA,IAAA,8BACAA,IAAA,4BACAA,IAAA,4BAGAA,IAAA,8BACAA,IAAA,8BAvCF,CAAYA,EAAA7N,EAAA6N,eAAA7N,EAAA6N,aAAY,KAkKxB,IAmhDYuD,EAwCAC,EA3jDZC,EAAA,SAAAC,GAkGE,SAAAD,EAEEjE,QAAA,IAAAA,MAAA,MAFF,IAAAmE,EAIED,EAAAzQ,KAAAR,KAAM+M,IAAY/M,KAjGpBkR,EAAAC,QAAoB,GAEpBD,EAAAE,kBAAyB,EAWzBF,EAAAG,YAAgC,IAAIjK,IAEpC8J,EAAAI,eAAsC,IAAIlK,IAE1C8J,EAAAK,sBAAmE,IAAInK,IAEvE8J,EAAAM,gBAAuC,IAAIpK,IAE3C8J,EAAAO,YAAmC,IAAIrK,IAEvC8J,EAAAQ,eAAiC,IAAItK,IAmErC8J,EAAAS,YAAmB,EAoEXT,EAAAU,qBAAgD,KA5DtD,IAAIC,EAAe,IAAIlE,EAAAmE,OAAOtE,EAAA3K,cAAe,gBAAiB8K,EAAAoE,WAAWC,SACzEd,EAAKW,aAAeA,EACpB,IAAII,EAAa,IAAIC,EAAKhB,EAAMW,UAChCX,EAAKe,WAAaA,EAClBf,EAAKG,YAAYc,IAAIF,EAAWG,aAAcH,GAC9Cf,EAAKmB,SAAW,IAAIzE,EAAA0E,SAASpB,KAo6CjC,OAhhD6BqB,EAAAvB,EAAAC,GAgH3BD,EAAA/O,UAAAuQ,mBAAA,SAAmBC,EAAoBC,EAAaC,EAAsBC,GAOxExI,OAAOwI,EAAe,GAAK,IAC3B/I,EAAAgJ,SAASD,EAAaH,EAAQC,GAC9B7I,EAAAgJ,SAAS,EAAGJ,EAAQC,EAAS,GAC7B7I,EAAAgJ,SAASF,EAAcG,GAAIL,EAAQC,EAAS,GAC5C7I,EAAAgJ,SAASD,EAAaH,EAAQC,EAAS,KAIzC3R,OAAAC,eAAIgQ,EAAA/O,UAAA,oBAAiB,KAArB,WACE,OAAO,oCAIT+O,EAAA/O,UAAA8Q,8BAAA,SAEEnS,EAEAoS,QAAA,IAAAA,MAAqBxF,EAAAnL,YAAY4Q,MAEjC,IAAIlI,EAAQ/K,KAAK6R,aAAa9G,MAC9B,OAAO4C,EAAAuF,KAAKC,0BACVxF,EAAAuF,KAAKE,2BAA2BxS,EAAMmK,GACtC,KAAM,KAAM,KAAMiI,EAAOjI,IAK7BiG,EAAA/O,UAAAoR,0BAAA,SAEEzS,EAEAoS,QAAA,IAAAA,MAAqBxF,EAAAnL,YAAY4Q,MAEjC,IAAIlI,EAAQ/K,KAAK6R,aAAa9G,MAC1BuI,EAAa3F,EAAAuF,KAAKE,2BAA2BxS,EAAMmK,GACvD,OAAO4C,EAAAuF,KAAKK,sBACVD,EACA,KACA3F,EAAAuF,KAAKM,kBAAkBzI,GACvB,KAAMiI,EAAOjI,IAQjBiG,EAAA/O,UAAAwR,8BAAA,SAEE7S,EAEAoS,QAAA,IAAAA,MAAqBxF,EAAAnL,YAAY4Q,MAEjC,IAAIlI,EAAQ/K,KAAK6R,aAAa9G,MAC9B,OAAO4C,EAAAuF,KAAKQ,0BACV/F,EAAAuF,KAAKE,2BAA2BxS,EAAMmK,GACtC,KACA/K,KAAK4R,uBAAyB5R,KAAK4R,qBAAuBjE,EAAAuF,KAAKS,mBAAmB,GAChFhG,EAAAuF,KAAKU,gBACHjG,EAAAuF,KAAKW,qBAAqBrG,EAAAxK,cAAc0B,MAAOqG,GAC/C,MAAM,EAAOA,GAEf,MAAM,EAAOA,IAEf,KAAM,KAAMiI,EAAK,EAAkBjI,IAKvCiG,EAAA/O,UAAA6R,+BAAA,SAEElT,EAEAoS,QAAA,IAAAA,MAAqBxF,EAAAnL,YAAY4Q,MAEjC,IAAIlI,EAAQ/K,KAAK6R,aAAa9G,MAC9B,OAAO4C,EAAAuF,KAAKa,2BACVpG,EAAAuF,KAAKE,2BAA2BxS,EAAMmK,GACtC,GAAI,KAAMiI,EAAOjI,IAKrBiG,EAAA/O,UAAA+R,mBAAA,SAEEpT,EAEAqT,EAEAC,EAEAlB,EAEAmB,GAEA,YANA,IAAAD,MAAkBlU,KAAKiS,iBAEvB,IAAAe,MAAqBxF,EAAAnL,YAAY4Q,WAEjC,IAAAkB,MAAiCpD,EAAekC,MAEzC,IAAImB,EACTxT,EACA,IAAIyT,EACFzT,EACAsT,EACAlU,KAAKyT,8BAA8B7S,EAAMoS,GACzCmB,GAEFF,IAKJjD,EAAA/O,UAAAqS,wBAAA,SAAwBC,GACtB,IAAIhD,EAAwBvR,KAAKuR,sBAEjC,OADAnH,OAAOmH,EAAsBiD,IAAID,IAC1BhD,EAAsBrQ,IAAIqT,IAInCvD,EAAA/O,UAAAwS,WAAA,SAAWC,+BACT1U,KAAK0U,QAAUA,EAGf1U,KAAK2U,mBAAmBnH,EAAAxK,cAAcE,GAAIwK,EAAAkH,KAAK1R,IAC/ClD,KAAK2U,mBAAmBnH,EAAAxK,cAAcG,IAAKuK,EAAAkH,KAAKzR,KAChDnD,KAAK2U,mBAAmBnH,EAAAxK,cAAcI,IAAKsK,EAAAkH,KAAKxR,KAChDpD,KAAK2U,mBAAmBnH,EAAAxK,cAAcK,IAAKqK,EAAAkH,KAAKvR,KAChDrD,KAAK2U,mBAAmBnH,EAAAxK,cAAcM,MAAOoR,EAAQG,WACrD7U,KAAK2U,mBAAmBnH,EAAAxK,cAAcO,GAAImK,EAAAkH,KAAKrR,IAC/CvD,KAAK2U,mBAAmBnH,EAAAxK,cAAcQ,IAAKkK,EAAAkH,KAAKpR,KAChDxD,KAAK2U,mBAAmBnH,EAAAxK,cAAcS,IAAKiK,EAAAkH,KAAKnR,KAChDzD,KAAK2U,mBAAmBnH,EAAAxK,cAAcU,IAAKgK,EAAAkH,KAAKlR,KAChD1D,KAAK2U,mBAAmBnH,EAAAxK,cAAcW,MAAO+Q,EAAQI,WACrD9U,KAAK2U,mBAAmBnH,EAAAxK,cAAcY,KAAM8J,EAAAkH,KAAKhR,MACjD5D,KAAK2U,mBAAmBnH,EAAAxK,cAAca,IAAK6J,EAAAkH,KAAK/Q,KAChD7D,KAAK2U,mBAAmBnH,EAAAxK,cAAcc,IAAK4J,EAAAkH,KAAK9Q,KAChD9D,KAAK2U,mBAAmBnH,EAAAxK,cAAc0B,MAAOgJ,EAAAkH,KAAKG,MAClD/U,KAAK2U,mBAAmBnH,EAAAxK,cAAc2B,OAAQ+I,EAAAkH,KAAK9Q,KACnD9D,KAAK2U,mBAAmBnH,EAAAxK,cAAc4B,QAAS8I,EAAAkH,KAAKhR,MACpD5D,KAAKiS,WAAW+C,IAAIxH,EAAAxK,cAAc8B,OAAQ,IAAImQ,EAC5CzH,EAAAxK,cAAc8B,OACd9E,KAAKiS,WACLjS,KAAKqT,0BAA0B7F,EAAAxK,cAAc8B,OAAQ0I,EAAAnL,YAAY6S,OAAS1H,EAAAnL,YAAY8S,SACtFpE,EAAeqE,UAEjBpV,KAAKiS,WAAW+C,IAAIxH,EAAAxK,cAAc+B,QAAS,IAAIkQ,EAC7CzH,EAAAxK,cAAc+B,QACd/E,KAAKiS,WACLjS,KAAKqT,0BAA0B7F,EAAAxK,cAAc+B,QAASyI,EAAAnL,YAAY6S,OAAS1H,EAAAnL,YAAY8S,SACvFpE,EAAeqE,UAEjBpV,KAAKiS,WAAW+C,IAAIxH,EAAAxK,cAAcgC,QAAS,IAAIiQ,EAC7CzH,EAAAxK,cAAcgC,QACdhF,KAAKiS,WACLjS,KAAKqT,0BAA0B7F,EAAAxK,cAAcgC,QAASwI,EAAAnL,YAAY6S,OAAS1H,EAAAnL,YAAY8S,SACvFpE,EAAeqE,UAEbV,EAAQW,WAAU,IAAgBrV,KAAK2U,mBAAmBnH,EAAAxK,cAAce,KAAM2J,EAAAkH,KAAK7Q,MAGvF/D,KAAKsV,wBAAwB9H,EAAAxK,cAAcuC,WAAYmI,EAAAkH,KAAKxR,IAC1DmS,QAAQb,EAAQc,SAAWhI,EAAApE,OAAOqM,OAASjI,EAAApE,OAAOsM,SACpD1V,KAAKsV,wBAAwB9H,EAAAxK,cAAcyC,cAAeiI,EAAAkH,KAAKhR,KAC7D2R,QAAQb,EAAQiB,SAAW,EAAI,EAAG,IACpC3V,KAAKsV,wBAAwB9H,EAAAxK,cAAc0C,gBAAiBgI,EAAAkH,KAAKxR,IAC/DmS,QAAQb,EAAQkB,WAAY,IAC9B5V,KAAKsV,wBAAwB9H,EAAAxK,cAAc2C,mBAAoB+H,EAAAkH,KAAKxR,IAClEmS,QAAQb,EAAQmB,kBAAmB,IACrC7V,KAAKsV,wBAAwB9H,EAAAxK,cAAc4C,iBAAkB8H,EAAAkH,KAAKxR,IAChEmS,QAAQb,EAAQoB,gBAAiB,IACnC9V,KAAKsV,wBAAwB9H,EAAAxK,cAAc6C,2BAA4B6H,EAAAkH,KAAKhR,KAC1E2R,QAAQb,EAAQW,WAAU,GAA2B,EAAI,EAAG,IAC9DrV,KAAKsV,wBAAwB9H,EAAAxK,cAAc8C,2BAA4B4H,EAAAkH,KAAKhR,KAC1E2R,QAAQb,EAAQW,WAAU,GAA2B,EAAI,EAAG,IAC9DrV,KAAKsV,wBAAwB9H,EAAAxK,cAAc+C,wBAAyB2H,EAAAkH,KAAKhR,KACvE2R,QAAQb,EAAQW,WAAU,GAAwB,EAAI,EAAG,IAC3DrV,KAAKsV,wBAAwB9H,EAAAxK,cAAcgD,iBAAkB0H,EAAAkH,KAAKhR,KAChE2R,QAAQb,EAAQW,WAAU,GAAiB,EAAI,EAAG,IACpDrV,KAAKsV,wBAAwB9H,EAAAxK,cAAciD,oBAAqByH,EAAAkH,KAAKhR,KACnE2R,QAAQb,EAAQW,WAAU,IAAoB,EAAI,EAAG,IAUvD,IAPA,IAAIU,EAAgB,IAAI9O,MACpB+O,EAAgB,IAAI5O,IACpB6O,EAAoB,IAAI7O,IACxB8O,EAAgB,IAAIjP,MACpBkP,EAAmB,IAAIlP,MAGlB5G,EAAI,EAAG+V,EAAIpW,KAAKmR,QAAQhF,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACnD,IAAIsL,EAAS3L,KAAKmR,QAAQ9Q,GACtBgW,EAAO,IAAInE,EAAKlS,KAAM2L,GAC1B3L,KAAKqR,YAAYc,IAAIkE,EAAKjE,aAAciE,GAExC,IADA,IAAIC,EAAa3K,EAAO2K,WACfC,EAAI,EAAGjW,EAAIgW,EAAWnK,OAAQoK,EAAIjW,IAAKiW,EAAG,CACjD,IAAIC,EAAYF,EAAWC,GAC3B,OAAQC,EAAUC,MAChB,KAAK9I,EAAA+I,SAASxB,OACZlV,KAAK2W,kBAAmCH,EAAWH,EAAML,EAAeC,GACxE,MAEF,KAAKtI,EAAA+I,SAASE,cACZ5W,KAAK6W,wBAAgDL,EAAWH,EAAMH,EAAeC,GACrF,MAEF,KAAKxI,EAAA+I,SAASI,OACZ9W,KAAK+W,kBAAmCP,EAAWH,EAAMN,EAAeC,GACxE,MAEF,KAAKrI,EAAA+I,SAASM,SACZhX,KAAKiX,oBAAuCT,EAAWH,GACvD,MAEF,KAAK1I,EAAA+I,SAASQ,iBACZlX,KAAKmX,gBAAkCX,EAAWH,EAAMH,EAAeC,GACvE,MAEF,KAAKxI,EAAA+I,SAASU,gBACZpX,KAAKqX,eAAgCb,EAAWH,GAChD,MAEF,KAAK1I,EAAA+I,SAASY,oBACZtX,KAAKuX,mBAAwCf,EAAWH,GACxD,MAEF,KAAK1I,EAAA+I,SAASc,qBACZxX,KAAKyX,oBAA0CjB,EAAWH,GAC1D,MAEF,KAAK1I,EAAA+I,SAASgB,qBACZ1X,KAAK2X,oBAA0CnB,EAAWH,EAAMH,EAAeC,GAC/E,MAEF,KAAKxI,EAAA+I,SAASkB,gBACZ5X,KAAK6X,yBAA0CrB,EAAWH,SAQlE,IAAgC,IAAAyB,EAAAC,EAAA9B,GAAiB+B,EAAAF,EAAAG,QAAAD,EAAAE,KAAAF,EAAAF,EAAAG,OAAxC,KAAAE,EAAAC,EAAAJ,EAAA1W,MAAA,GAAO+W,GAANhC,EAAA8B,EAAA,GAAMA,EAAA,IACd,IAAS9X,EAAI,EAAG+V,EAAIiC,EAAYlM,OAAQ9L,EAAI+V,IAAK/V,EAAG,CAClD,IAAIiY,EAAaD,EAAYhY,IACzBkY,EAAcvY,KAAKwY,kBAAkBF,EAAWpK,YAAaoK,EAAWnK,iBAQ5EkI,EAAKoC,iBAAiBF,GANpBvY,KAAKqN,MACHI,EAAAhD,eAAeiO,iBACfJ,EAAWhK,YAAYvD,MAAOuN,EAAWhK,YAAYhN,0GAS7D,IAASjB,EAAI,EAAG+V,EAAIL,EAAc5J,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACpD,IAuBMkY,EAvBFI,EAAe5C,EAAc1V,GAC7B4N,EAAoB0K,EAAa1K,kBACrC,GAAIA,GACE2K,GAAU5Y,KAAK6Y,cACjB5K,EAAkBhC,KAClB0M,EAAazK,YACbyK,EAAaxK,eACb6H,IAGA2C,EAAa5K,UAAUiH,IACrB2D,EAAa3K,gBAAgB/B,KAC7B2M,IACA,GAIF5Y,KAAKqN,MACHI,EAAAhD,eAAeqO,kCACf7K,EAAkBlD,MAAO4N,EAAazK,YAAaD,EAAkBhC,WAKzE,GADIsM,EAAcvY,KAAKwY,kBAAkBG,EAAazK,YAAayK,EAAaxK,gBAC/D,CACf,IAAIJ,EAAY4K,EAAa5K,UACzBgL,EAAYJ,EAAa3K,gBAAgB/B,KAC7C8B,EAAUiH,IACR+D,EACAR,EAAYS,oBACVD,EACAhL,IAEF,QAGF3D,QAAO,OAMb,IAA4B,IAAA6O,EAAAlB,EAAA/B,GAAakD,EAAAD,EAAAhB,QAAAiB,EAAAhB,KAAAgB,EAAAD,EAAAhB,OAAE,CAAlC,IAAAkB,EAAAf,EAAAc,EAAA5X,MAAA,GAAO5B,GAAN2W,EAAA8C,EAAA,GAAMA,EAAA,QACd,IAAuC,IAAAC,GAAAC,OAAA,EAAAtB,EAAArY,IAAO4Z,EAAAF,EAAAnB,QAAAqB,EAAApB,KAAAoB,EAAAF,EAAAnB,OAAE,CAAvC,IAAAsB,EAAAnB,EAAAkB,EAAAhY,MAAA,GAACkY,GAAAD,EAAA,GAAYE,GAAAF,EAAA,GAEhBrL,IADA6K,EAAYU,GAAazL,gBAAgB/B,KAC3BwN,GAAavL,aAC/B,GAAIA,IACE0K,GAAU5Y,KAAK6Y,cACjBE,EACA7K,GACA9D,OAAOqP,GAAatL,gBACpB6H,IAGAK,EAAKqD,aAAaF,GAAYZ,IAE9B5Y,KAAKqN,MACHI,EAAAhD,eAAeqO,kCACfW,GAAazL,gBAAgBjD,MAC7BmD,GAAa6K,QAKjB,GADIH,GAAUvC,EAAKsD,aAAaZ,GAE9B1C,EAAKqD,aAAaF,GAAYZ,QACzB,CACL,IAAIgB,GAAgB5Z,KAAK6Z,aAAad,GAClCa,IAAiBA,cAAyBE,EAC5CzD,EAAKqD,aAAaF,GAA6BI,IAE/C5Z,KAAKqN,MACHI,EAAAhD,eAAeqO,kCACfW,GAAaxL,kBAAkBlD,MAC/BsL,EAAKjE,aAAcqH,GAAaxL,kBAAkBhC,4MAS9D7B,OAA2B,GAApBpK,KAAK2R,aACZ3R,KAAK+Z,oBAAsB/Z,KAAKga,aAAaxM,EAAAxK,cAAcsE,aAC3D8C,OAAsC,GAA/BpK,KAAK+Z,oBAAoBjH,IAChC9S,KAAKia,eAAiBja,KAAKga,aAAaxM,EAAAxK,cAAcgE,QACtDoD,OAAiC,GAA1BpK,KAAKia,eAAenH,IAC3B9S,KAAKka,wBAA0Bla,KAAKga,aAAaxM,EAAAxK,cAAcqE,iBAC/D+C,OAA0C,GAAnCpK,KAAKka,wBAAwBpH,IAGpC9S,KAAKma,wBAAuB,EAAc3M,EAAAxK,cAAckD,IACxDlG,KAAKma,wBAAuB,EAAe3M,EAAAxK,cAAcmD,KACzDnG,KAAKma,wBAAuB,EAAe3M,EAAAxK,cAAcoD,KACzDpG,KAAKma,wBAAuB,EAAe3M,EAAAxK,cAAcqD,KACzDrG,KAAKma,wBAAuB,EAAiB3M,EAAAxK,cAAcsD,OAC3DtG,KAAKma,wBAAuB,EAAc3M,EAAAxK,cAAcuD,IACxDvG,KAAKma,wBAAuB,EAAe3M,EAAAxK,cAAcwD,KACzDxG,KAAKma,wBAAuB,EAAe3M,EAAAxK,cAAcyD,KACzDzG,KAAKma,wBAAuB,EAAe3M,EAAAxK,cAAc0D,KACzD1G,KAAKma,wBAAuB,EAAiB3M,EAAAxK,cAAc2D,OAC3D3G,KAAKma,wBAAuB,GAAgB3M,EAAAxK,cAAc4D,MAC1D5G,KAAKma,wBAAuB,GAAe3M,EAAAxK,cAAc6D,KACzD7G,KAAKma,wBAAuB,GAAe3M,EAAAxK,cAAc8D,KACrD4N,EAAQW,WAAU,IAAgBrV,KAAKma,wBAAuB,GAAgB3M,EAAAxK,cAAc+D,MAGhG/G,KAAKoa,iBAAmCpa,KAAKJ,QAAQ4N,EAAAxK,cAAcyE,UAAWqJ,EAAYuJ,iBAC1Fra,KAAKsa,kBAAoCta,KAAKJ,QAAQ4N,EAAAxK,cAAc0E,WAAYoJ,EAAYuJ,iBAC5Fra,KAAKua,kBAAoCva,KAAKJ,QAAQ4N,EAAAxK,cAAc2E,WAAYmJ,EAAYuJ,iBAC5Fra,KAAKwa,kBAAoCxa,KAAKJ,QAAQ4N,EAAAxK,cAAc4E,WAAYkJ,EAAYuJ,iBAC5Fra,KAAKya,iBAAmCza,KAAKJ,QAAQ4N,EAAAxK,cAAc6E,WAAYiJ,EAAYuJ,iBAC3Fra,KAAK0a,wBAA0C1a,KAAKJ,QAAQ4N,EAAAxK,cAAc8E,kBAAmBgJ,EAAYuJ,iBACzGra,KAAK2a,kBAAoC3a,KAAKJ,QAAQ4N,EAAAxK,cAAc+E,YAAa+I,EAAYuJ,iBAC7Fra,KAAK4a,kBAAoC5a,KAAKJ,QAAQ4N,EAAAxK,cAAcgF,YAAa8I,EAAYuJ,iBAC7Fra,KAAK6a,kBAAoC7a,KAAKJ,QAAQ4N,EAAAxK,cAAciF,YAAa6I,EAAYuJ,iBAC7Fra,KAAK8a,kBAAoC9a,KAAKJ,QAAQ4N,EAAAxK,cAAckF,aAAc4I,EAAYuJ,iBAC9Fra,KAAK+a,kBAAoC/a,KAAKJ,QAAQ4N,EAAAxK,cAAcmF,aAAc2I,EAAYuJ,iBAG9F,IAAIhI,GAAWrS,KAAKqS,SACpB,IAAShS,EAAI,EAAG+V,EAAIF,EAAc/J,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACpD,IAAI2a,GAAgB9E,EAAc7V,GAC9B4a,GAAc7Q,OAAO4Q,GAAcC,aACnCC,GAAc7I,GAAS8I,gBAAgBF,GAAYra,KAAMoa,GAAc9G,QAC3E,GAAKgH,GACL,GAAIA,GAAYzE,MAAQ3F,EAAYuJ,gBAAiB,CACnD,IAAIe,GAAgCF,GAChCE,GAAcC,aAAatK,EAAeuK,SAC5Ctb,KAAKqN,MACHI,EAAAhD,eAAe8Q,yCACfN,GAAYlQ,MAAwBmQ,GAAaM,eAAevP,MAIlEmP,GAAcC,aAAatK,EAAe0K,YAC1CT,GAAcK,aAAatK,EAAe0K,YAE1Czb,KAAKqN,MACHI,EAAAhD,eAAeiR,+DACf/N,EAAAgO,MAAMhP,KAAKqO,GAAcQ,eAAezQ,MAAOkQ,GAAYlQ,QAG/DiQ,GAAcI,cAAgBA,QAE9Bpb,KAAKqN,MACHI,EAAAhD,eAAemR,sCACfX,GAAYlQ,OAOhB,IAAI8Q,GAAgBnH,EAAQmH,cAC5B,GAAIA,OACF,IAA0B,IAAAC,GAAA/D,EAAA8D,IAAaE,GAAAD,GAAA7D,QAAA8D,GAAA7D,KAAA6D,GAAAD,GAAA7D,OAAE,CAAhC,IAAA+D,GAAA5D,EAAA2D,GAAAza,MAAA,GAAC2a,GAAAD,GAAA,GAAOpb,GAAAob,GAAA,GACf,GAAKpb,GAAKuL,OAAV,CACA,IAAI+P,GAAYtb,GAAK2L,WAAW,GAChC,GAAI2P,IAAS,IAAmBA,IAAS,GACvClc,KAAKsV,wBAAwB2G,GAAOvO,EAAAkH,KAAKxR,IAAKmS,QAAa4G,SAASvb,GAAM,UACrE,CACL,IAAI0Q,GAAiBtR,KAAKsR,eAE1B,KADIsH,GAAUtH,GAAepQ,IAAIN,KAK5B,MAAM,IAAIwb,MAAM,2BAA6Bxb,IAHhD,GAAI0Q,GAAekD,IAAIyH,IAAQ,MAAM,IAAIG,MAAM,6BAA+Bxb,IAC9E0Q,GAAea,IAAI8J,GAAOrD,4GASpC5Y,KAAKqc,eAAiCrc,KAAKJ,QAAQ4N,EAAAxK,cAAciE,MAAO6J,EAAYuJ,iBACpFra,KAAKsc,oBAAsCtc,KAAKJ,QAAQ4N,EAAAxK,cAAckE,WAAY4J,EAAYuJ,iBAC9Fra,KAAKuc,aAA+Bvc,KAAKJ,QAAQ4N,EAAAxK,cAAcmE,IAAK2J,EAAYuJ,iBAChFra,KAAKwc,aAA+Bxc,KAAKJ,QAAQ4N,EAAAxK,cAAcoE,IAAK0J,EAAYuJ,iBAChFra,KAAKyc,cAAgBzc,KAAK0c,eAAelP,EAAAxK,cAAcoF,OACvDpI,KAAK2c,cAAgB3c,KAAK4c,gBAAgBpP,EAAAxK,cAAcuF,OACxDvI,KAAK6c,gBAAkB7c,KAAK4c,gBAAgBpP,EAAAxK,cAAcwF,SAC1DxI,KAAK8c,aAAe9c,KAAK4c,gBAAgBpP,EAAAxK,cAAcyF,MACvDzI,KAAK+c,eAAiB/c,KAAK4c,gBAAgBpP,EAAAxK,cAAc0F,QACzD1I,KAAKgd,gBAAkBhd,KAAK4c,gBAAgBpP,EAAAxK,cAAc2F,SAC1D3I,KAAKid,gBAAkBjd,KAAK4c,gBAAgBpP,EAAAxK,cAAc4F,SAC1D5I,KAAKkd,iBAAmBld,KAAK4c,gBAAgBpP,EAAAxK,cAAc6F,UAC3D7I,KAAKmd,mBAAqBnd,KAAK4c,gBAAgBpP,EAAAxK,cAAc8F,aAC7D9I,KAAKod,cAAgBpd,KAAK4c,gBAAgBpP,EAAAxK,cAAc+F,OACxD/I,KAAKqd,mBAAqBrd,KAAK4c,gBAAgBpP,EAAAxK,cAAcgG,gBAG7D,IAAiB,IAAAsU,GAAAvF,EAAA/X,KAAKqR,YAAYkM,UAAQC,GAAAF,GAAArF,QAAAuF,GAAAtF,KAAAsF,GAAAF,GAAArF,OAAE,CACtCvY,GADG2W,EAAImH,GAAAlc,OACQ5B,QACnB,GAAM2W,EAAK1K,OAAO8R,SAAW/d,MAC7B,IAAoB,IAAAge,IAAAC,OAAA,EAAA5F,EAAArY,EAAQ6d,WAAQK,GAAAF,GAAAzF,QAAA2F,GAAA1F,KAAA0F,GAAAF,GAAAzF,OAAA,CAA/B,IAAIW,GAAOgF,GAAAtc,MAAsBtB,KAAK6d,iBAAiBjF,mNAKxD5H,EAAA/O,UAAArC,QAAR,SAAgBgB,EAAc6V,GAC5B,IAAImC,EAAU5Y,KAAK6Z,aAAajZ,GAChC,IAAKgY,EAAS,MAAM,IAAIwD,MAAM,WAAaxb,GAC3C,GAAIgY,EAAQnC,MAAQA,EAAM,MAAM,IAAI2F,MAAM,cAAgBxb,GAC1D,OAAOgY,GAID5H,EAAA/O,UAAA+X,aAAR,SAAqBpZ,GACnB,IAAIqB,EAAYjC,KAAKJ,QAAQgB,EAAMkQ,EAAYuJ,iBAC3CyD,EAAW9d,KAAKqS,SAAS0L,aAA6B9b,EAAW,MACrE,IAAK6b,EAAU,MAAM,IAAI1B,MAAM,WAAaxb,GAC5C,OAAOkd,GAID9M,EAAA/O,UAAAya,eAAR,SAAuB9b,GACrB,IAAIqB,EAAYjC,KAAK6Z,aAAajZ,GAClC,OAAKqB,GAAaA,EAAUwU,MAAQ3F,EAAYkN,mBACzChe,KAAKqS,SAAS4L,gBAAmChc,EAAW,MADQ,MAKrE+O,EAAA/O,UAAA2a,gBAAR,SAAwBhc,GACtB,IAAIqB,EAAYjC,KAAKJ,QAAQgB,EAAMkQ,EAAYkN,oBAC3CF,EAAW9d,KAAKqS,SAAS4L,gBAAmChc,EAAW,MAC3E,IAAK6b,EAAU,MAAM,IAAI1B,MAAM,WAAaxb,GAC5C,OAAOkd,GAID9M,EAAA/O,UAAA4b,iBAAR,SAAyBjF,eAEvB,OADAA,EAAQzG,IAAI3E,EAAAnL,YAAY6b,eAChBtF,EAAQnC,MACd,KAAK3F,EAAYuJ,gBACf,IAAI8D,EAAmCvF,EAASuF,gBAChD,GAAIA,MAAiB,IAAmB,IAAAC,EAAArG,EAAAoG,EAAgBZ,UAAQc,EAAAD,EAAAnG,QAAAoG,EAAAnG,KAAAmG,EAAAD,EAAAnG,OAAA,CAAtC,IAAIqG,EAAMD,EAAA/c,MAA8BtB,KAAK6d,iBAAiBS,qGACxF,MAEF,KAAKxN,EAAYyN,mBACf,IAAIC,EAAsC5F,EAAS4F,gBAC/CA,GAAiBxe,KAAK6d,iBAAiBW,GAC3C,IAAIC,EAAsC7F,EAAS6F,gBAC/CA,GAAiBze,KAAK6d,iBAAiBY,GAC3C,MAEF,KAAK3N,EAAY4N,SACjB,KAAK5N,EAAY6N,SACjB,KAAK7N,EAAY8N,MACjB,KAAK9N,EAAY+N,MAAOzU,QAAO,GAG/B,IAAI0U,EAAUlG,EAAQkG,QACtB,GAAIA,MAAS,IAAmB,IAAAC,EAAAhH,EAAA+G,EAAQvB,UAAQyB,EAAAD,EAAA9G,QAAA+G,EAAA9G,KAAA8G,EAAAD,EAAA9G,OAAA,CAA1BqG,EAAMU,EAAA1d,MAAsBtB,KAAK6d,iBAAiBS,uGAKpEtN,EAAA/O,UAAA0S,mBAAR,SAA2B/T,EAAcqe,GACvC,IAAIrG,EAAU,IAAI3D,EAChBrU,EACAZ,KAAKiS,WACLjS,KAAKqT,0BAA0BzS,EAAM4M,EAAAnL,YAAY6S,QACjDnE,EAAeqE,SAEjBwD,EAAQsG,QAAQD,GAChBjf,KAAKiS,WAAW+C,IAAIpU,EAAMgY,IAIpB5H,EAAA/O,UAAAkY,wBAAR,SAAgCgF,EAAoBC,GAClDhV,QAAQpK,KAAKyR,YAAY+C,IAAI2K,IAC7B,IAAIvG,EAAU5Y,KAAK6Z,aAAauF,GAChC,GAAIxG,EAAS,CACXxO,OAAOwO,EAAQnC,MAAQ3F,EAAYuJ,iBACnC,IAAIgF,EAAerf,KAAKqS,SAAS0L,aAA6BnF,EAAS,MACnEyG,GAAcrf,KAAKyR,YAAYU,IAAIgN,EAAUE,KAK7CrO,EAAA/O,UAAAqT,wBAAR,SAAgC1U,EAAcqe,EAAY3d,GACxD8I,OAAO6U,EAAKK,GAAE,IACd,IAAIC,EAAS,IAAIC,EACf5e,EACAZ,KAAKiS,WACLlB,EAAekC,KACfjT,KAAK+S,8BAA8BnS,EAAM4M,EAAAnL,YAAYod,MAAQjS,EAAAnL,YAAY6S,SAE3EqK,EAAOG,wBAAwBpe,EAAO2d,GACtCjf,KAAKiS,WAAW+C,IAAIpU,EAAM2e,IAIpBvO,EAAA/O,UAAA0d,sBAAR,SAA8B/e,EAAcqe,EAAY3d,GACtD8I,OAAO6U,EAAKK,GAAE,IACd,IAAIC,EAAS,IAAIC,EACf5e,EACAZ,KAAKiS,WACLlB,EAAekC,KACfjT,KAAK+S,8BAA8BnS,EAAM4M,EAAAnL,YAAYod,MAAQjS,EAAAnL,YAAY6S,SAE3EqK,EAAOK,sBAAsBte,EAAO2d,GACpCjf,KAAKiS,WAAW+C,IAAIpU,EAAM2e,IAI5BvO,EAAA/O,UAAA4d,aAAA,SAAajf,EAAcgY,GACzB,IAAItH,EAAiBtR,KAAKsR,eAC1B,GAAIA,EAAekD,IAAI5T,IACR0Q,EAAepQ,IAAIN,KAMjBgY,EAAS,CACtB,IAAIkH,EAASC,EAASzO,EAAepQ,IAAIN,GAAQgY,GACjD,IAAKkH,EAKH,OAJA9f,KAAKqN,MACHI,EAAAhD,eAAeuV,uBACfpH,EAAQ4C,eAAezQ,MAAOnK,GAEzBgY,EAETA,EAAUkH,EAId,OADAxO,EAAea,IAAIvR,EAAMgY,GAClBA,GAIT5H,EAAA/O,UAAA4X,aAAA,SAAajZ,GACX,IAAIqf,EAAWjgB,KAAKsR,eACpB,OAAI2O,EAASzL,IAAI5T,GAAcqf,EAAS/e,IAAIN,GACrC,MAIToQ,EAAA/O,UAAAie,cAAA,SAActf,GACZ,IAAIqf,EAAWjgB,KAAKsR,eACpB,GAAI2O,EAASzL,IAAI5T,GAAO,OAAOqf,EAAS/e,IAAIN,GAC5C,MAAM,IAAIwb,MAAM,mBAIVpL,EAAA/O,UAAAuW,kBAAR,SAEEtK,EAEAC,GAEA,IAAIkD,EAAcrR,KAAKqR,YACvB,OAAOA,EAAYmD,IAAItG,GAChBmD,EAAYnQ,IAAIgN,GAChBmD,EAAYmD,IAAIrG,GAChBkD,EAAYnQ,IAAIiN,GAChB,MAID6C,EAAA/O,UAAA4W,cAAR,SAEEsH,EAEAjS,EAEAC,EAEA6H,GAEA,OAAG,CACD,IAAIuC,EAAcvY,KAAKwY,kBAAkBtK,EAAaC,GACtD,IAAKoK,EAAa,OAAO,KAGzB,IAAIK,EAAUL,EAAY6H,aAAaD,GACvC,GAAIvH,EAAS,OAAOA,EAGpB,GAAI5C,EAAcxB,IAAI+D,GAAc,CAClC,IAAI8H,EAAoBrK,EAAc9U,IAAIqX,GAC1C,GAAI8H,EAAkB7L,IAAI2L,GAAc,CACtC,IAAI1G,EAAe4G,EAAkBnf,IAAIif,GACzC,GAAI1G,EAAavL,YAAa,CAC5BiS,EAAc1G,EAAazL,gBAAgB/B,KAC3CiC,EAAcuL,EAAavL,YAC3BC,EAAiB/D,OAAOqP,EAAatL,gBACrC,SAGA,GADAyK,EAAUL,EAAYoB,aAAaF,EAAazL,gBAAgB/B,MACnD,OAAO2M,GAI1B,MAEF,OAAO,MAID5H,EAAA/O,UAAAqe,gBAAR,SAEEC,EAEAC,GAEA,IAAIxN,EAAQjC,EAAekC,KAC3B,GAAIsN,EACF,IAAK,IAAIlgB,EAAI,EAAG+V,EAAImK,EAAWpU,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACjD,IAAIogB,EAAYF,EAAWlgB,GAEvBqgB,EAAOC,EADAhT,EAAAiT,oBAAoBH,EAAU7f,OAErC8f,IACEA,GAAQ3P,EAAeqE,QACnBoL,EAAgBE,GAAUD,EAAU1V,MAAMY,OAAOkV,UAMrD7N,GAAS0N,EALT1gB,KAAKqN,MACHI,EAAAhD,eAAeqW,8BACfL,EAAU1V,MAAO0V,EAAU7f,KAAKmK,MAAMW,YAK/B8U,EAAgBE,EAKlB1N,EAAQ0N,EACjB1gB,KAAKqN,MACHI,EAAAhD,eAAesW,oBACfN,EAAU1V,MAAO0V,EAAU7f,KAAKmK,MAAMW,YAGxCsH,GAAS0N,EAVT1gB,KAAKqN,MACHI,EAAAhD,eAAeqW,8BACfL,EAAU1V,MAAO0V,EAAU7f,KAAKmK,MAAMW,aAahD,OAAOsH,GAIDhC,EAAA/O,UAAAkV,gBAAR,SAEE5C,EAEAL,EAEAgC,EAEAC,GAEA,IAAIvV,EAAO2T,EAAY3T,KAAKqL,KACxB2M,EAAU,IAAIoI,EAChBpgB,EACAsT,EACAK,EACAvU,KAAKsgB,gBAAgB/L,EAAYgM,WAC/BxP,EAAekQ,OACflQ,EAAeuK,OACfvK,EAAe0K,YAGnB,IAAKvH,EAAOc,IAAIpU,EAAMgY,GAAU,OAAO,KAEvC,IAAIsI,EAAkB3M,EAAY2M,gBAClC,GAAIA,EAAiB,CACnB,IAAIC,EAAqBD,EAAgB/U,OAEzC,GAAIyM,EAAQyC,aAAatK,EAAe0K,WAClC0F,GACFnhB,KAAKqN,MACHI,EAAAhD,eAAe2W,8CACfzT,EAAAgO,MAAMhP,KACJ4H,EAAY3T,KAAKmK,MACjBmW,EAAgBC,EAAqB,GAAGpW,aAIzC,GAAIoW,EAAoB,CAE7B,IAAK,IAAI9gB,EAAI,EAAGA,EAAI8gB,IAAsB9gB,EACxCL,KAAKmN,QACHM,EAAAhD,eAAe4W,wBACfH,EAAgB7gB,GAAG0K,OAGvBoL,EAAiBzJ,KAAKkM,IAItBrE,EAAY+M,aAAapL,EAAcxJ,KAAKkM,GAIhD,IADA,IAAI2I,EAAqBhN,EAAYuK,QACrB1I,GAAP/V,EAAI,EAAOkhB,EAAmBpV,QAAQ9L,EAAI+V,IAAK/V,EAAG,CACzD,IAAImhB,EAAoBD,EAAmBlhB,GAC3C,OAAQmhB,EAAkB/K,MACxB,KAAK9I,EAAA+I,SAAS+K,iBACZzhB,KAAK0hB,gBAAkCF,EAAmB5I,GAC1D,MAEF,KAAKjL,EAAA+I,SAASiL,kBACRH,EAAkBI,MAAMpU,EAAAnL,YAAYwf,IAAMrU,EAAAnL,YAAYyf,KACxD9hB,KAAK+hB,mBAAsCP,EAAmB5I,GAE9D5Y,KAAKgiB,iBAAoCR,EAAmB5I,GAE9D,MAEF,KAAKjL,EAAA+I,SAASuL,0BAA2B,MACzC,QAAS7X,QAAO,IAGpB,OAAOwO,GAID5H,EAAA/O,UAAAyf,gBAAR,SAEEnN,EAEAL,GAEA,IAEI0E,EAFAhY,EAAO2T,EAAY3T,KAAKqL,KACxBsU,EAAahM,EAAYgM,WAE7B,GAAIhM,EAAY+K,GAAG9R,EAAAnL,YAAY6f,SAa7B,GAZA9X,OAAO8J,EAAOuC,MAAQ3F,EAAYqR,qBAClCvJ,EAAU,IAAI4G,EACZ5e,EACAsT,EACAlU,KAAKsgB,gBAAgBC,GAClBhM,EAAY+K,GAAG9R,EAAAnL,YAAY+f,UACxBrR,EAAesR,OACftR,EAAekC,MACflC,EAAeuR,KAAOvR,EAAewR,QAE3ChO,IAEGL,EAAOc,IAAIpU,EAAMgY,GAAU,YAShC,GAPAxO,QAAQmK,EAAYqN,MAAMpU,EAAAnL,YAAYmgB,SAAWhV,EAAAnL,YAAYwf,IAAMrU,EAAAnL,YAAYyf,MAC/ElJ,EAAU,IAAI6J,EACZ7hB,EACAsT,EACAK,EACAvU,KAAKsgB,gBAAgBC,EAAYxP,EAAewR,UAE7CrO,EAAOwO,YAAY9hB,EAAMgY,GAAU,QAKpC5H,EAAA/O,UAAA+f,iBAAR,SAEEzN,EAEAL,GAEA,IAAItT,EAAO2T,EAAY3T,KAAKqL,KACxB0W,EAAWpO,EAAY+K,GAAG9R,EAAAnL,YAAY6f,QACtC1B,EAAgBzP,EAAesR,OAAStR,EAAewR,OACtDhO,EAAY+K,GAAG9R,EAAAnL,YAAY8S,WAC9BqL,GAAiBzP,EAAenC,gBACfmC,EAAeZ,gBACfY,EAAeL,kBAElC,IAAIkI,EAAU,IAAIvE,EAChBzT,EACAsT,EACAK,EACAvU,KAAKsgB,gBAAgB/L,EAAYgM,WAAYC,IAE/C,GAAImC,GAEF,GADAvY,OAAOmK,EAAY3T,KAAK6V,MAAQ9I,EAAA+I,SAASkM,cACpC1O,EAAOc,IAAIpU,EAAMgY,GAAU,YAEhC,IAAK1E,EAAOwO,YAAY9hB,EAAMgY,GAAU,OAE1C5Y,KAAK6iB,uBAAuBtO,EAAYgM,WAAY3H,EAAS1E,IAIvDlD,EAAA/O,UAAA4gB,uBAAR,SAEEtC,EAEAte,EAEA6gB,GAEA,GAAIvC,EACF,IAAK,IAAIlgB,EAAI,EAAG+V,EAAImK,EAAWpU,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACjD,IAAIogB,EAAYF,EAAWlgB,GAC3B,OAAQogB,EAAUjS,eAChB,KAAKb,EAAAe,cAAcC,SACnB,KAAKhB,EAAAe,cAAcE,gBACnB,KAAKjB,EAAAe,cAAcyB,gBACnB,KAAKxC,EAAAe,cAAcgC,iBACjB,IAAIqS,EAAUtC,EAAUuC,WAAavC,EAAUuC,UAAU7W,QAAU,EACnE,GAAe,GAAX4W,EAAc,CAChB,IAAIE,EAA0BxC,EAAUuC,UAAW,GACnD,GACEC,EAASxM,MAAQ9I,EAAA+I,SAASwM,SACND,EAAUE,aAAexV,EAAAyV,YAAYC,OACzD,CACA,IAAI5M,EAAOlI,EACTkS,EAAUjS,cACgByU,EAAU3hB,OAEtC,GAAImV,GAAQlJ,EAAasD,QACvB7Q,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf4B,EAASlY,WAEN,CACL,IAAIuY,EAAYR,EAAeS,mBAC3BD,EAAU9O,IAAIiC,GAChBzW,KAAKqN,MACHI,EAAAhD,eAAe+Y,kCACfP,EAASlY,QAGX9I,EAAUwhB,aAAehN,EACzB6M,EAAUnR,IAAIsE,EAAMxU,UAIxBjC,KAAKqN,MACHI,EAAAhD,eAAeiZ,wBACfT,EAASlY,YAIb/K,KAAKqN,MACHI,EAAAhD,eAAekZ,+BACflD,EAAU1V,MAAO,IAAKgY,EAAQrX,SAAS,QAU7CsF,EAAA/O,UAAA2hB,eAAR,SAEErP,EAEAL,GAEA,IAAItT,EAAO2T,EAAY3T,KAAKqL,KAC5B,GAAIsI,EAAY+K,GAAG9R,EAAAnL,YAAY6f,QAAS,CAEtC,KADI2B,EAAgB3P,EAAO4K,WACN+E,EAAcrP,IAAI5T,GAGhC,CACL,IAAIgY,EAAU,IAAIkL,EAAkBljB,EAAMsT,EAAQK,GAClD,OAAKL,EAAOc,IAAIpU,EAAMgY,GACfA,EADgC,KAHvC,IADIA,EAAmBiL,EAAc3iB,IAAIN,IAC7B6V,MAAQ3F,EAAYyN,mBAAoB,OAA0B3F,MAM3E,CACL,IAAIiL,EACJ,KADIA,EAAgB3P,EAAOiK,mBACN0F,EAAcrP,IAAI5T,GAGhC,CACDgY,EAAU,IAAIkL,EAAkBljB,EAAMsT,EAAQK,GAClD,OAAKL,EAAOwO,YAAY9hB,EAAMgY,GACvBA,EADwC,KAH/C,IADIA,EAAmBiL,EAAc3iB,IAAIN,IAC7B6V,MAAQ3F,EAAYyN,mBAAoB,OAA0B3F,EAWlF,OAJA5Y,KAAKqN,MACHI,EAAAhD,eAAesZ,qBACfxP,EAAY3T,KAAKmK,MAAOnK,GAEnB,MAIDoQ,EAAA/O,UAAA8f,mBAAR,SAEExN,EAEAL,GAEA,IAAIlS,EAAWhC,KAAK4jB,eAAerP,EAAaL,GAChD,GAAKlS,EAAL,CACA,IAAIpB,EAAO2T,EAAY3T,KAAKqL,KACxB+X,EAAWzP,EAAY+K,GAAG9R,EAAAnL,YAAYwf,KAC1C,GAAImC,GACF,GAAIhiB,EAASwc,gBAKX,YAJAxe,KAAKqN,MACHI,EAAAhD,eAAesZ,qBACfxP,EAAY3T,KAAKmK,MAAOnK,QAK5B,GAAIoB,EAASyc,gBAKX,YAJAze,KAAKqN,MACHI,EAAAhD,eAAesZ,qBACfxP,EAAY3T,KAAKmK,MAAOnK,GAK9B,IAAIgY,EAAU,IAAIvE,GACf2P,EAAWxW,EAAAhL,cAAgBgL,EAAA/K,eAAiB7B,EAC7CoB,EACAuS,EACAvU,KAAKsgB,gBAAgB/L,EAAYgM,WAC/BxP,EAAesR,OAAStR,EAAewR,SAGvCyB,EACFhiB,EAASwc,gBAAkB5F,EAE3B5W,EAASyc,gBAAkB7F,IAKvB5H,EAAA/O,UAAAoV,eAAR,SAEE9C,EAEAL,GAEA,IAAItT,EAAO2T,EAAY3T,KAAKqL,KACxB2M,EAAU,IAAIqL,EAChBrjB,EACAsT,EACAK,EACAvU,KAAKsgB,gBAAgB/L,EAAYgM,WAC/BxP,EAAekQ,OACflQ,EAAesR,OACftR,EAAeuR,OAGnB,IAAKpO,EAAOc,IAAIpU,EAAMgY,GAAU,OAAO,KAEvC,IADA,IAAI2E,EAAShJ,EAAYgJ,OAChBld,EAAI,EAAG+V,EAAImH,EAAOpR,OAAQ9L,EAAI+V,IAAK/V,EAC1CL,KAAKkkB,oBAAoB3G,EAAOld,GAAIuY,GAEtC,OAAOA,GAID5H,EAAA/O,UAAAiiB,oBAAR,SAEE3P,EAEAL,GAEA,IAAItT,EAAO2T,EAAY3T,KAAKqL,KACxB2M,EAAU,IAAIuL,EAChBvjB,EACAsT,EACAK,EACAvU,KAAKsgB,gBAAgB/L,EAAYgM,WAC/BxP,EAAekC,OAGdiB,EAAOc,IAAIpU,EAAMgY,IAIhB5H,EAAA/O,UAAA0U,kBAAR,SAEEH,EAEAtC,EAEA8B,EAEAC,GAEA,IAAI6I,EAAUtI,EAAUsI,QACxB,GAAIA,EACF,IAAK,IAAIze,EAAI,EAAG+V,EAAI0I,EAAQ3S,OAAQ9L,EAAI+V,IAAK/V,EAC3CL,KAAKokB,iBAAiBtF,EAAQze,GAAI6T,EAAQsC,EAAU6N,aAAcrO,OAE/D,CACL,IAAIsO,OAAM,EACNrO,EAAkBzB,IAAIN,GAASoQ,EAASrO,EAAkB/U,IAAIgT,GAC7D+B,EAAkB9D,IAAI+B,EAAQoQ,EAAS,IAC5C,IAAIpW,EAAc9D,OAAOoM,EAAU6N,cACnCC,EAAO5X,KAAK,IAAI2B,EACdH,EACAA,EAAYqW,SAAS/W,EAAAzK,cACjBmL,EAAYzB,UAAU,EAAGyB,EAAY/B,OAASqB,EAAAzK,aAAaoJ,QAC3D+B,EAAcV,EAAAzK,aAClBqH,OAAOoM,EAAUgO,UAMfxT,EAAA/O,UAAAmiB,iBAAR,SAEE9F,EAEAvQ,EAEAG,EAEA8H,GAEA,IAAI+C,EAAYuF,EAAOvF,UAAU9M,KAC7BkU,EAAc7B,EAAOmG,aAAaxY,KAGlC2M,EAAU7K,EAAUqS,aAAaD,GACrC,GAAIvH,EACF5Y,KAAKqN,MACHI,EAAAhD,eAAeia,4DACfpG,EAAOmG,aAAa1Z,MAAOoV,QAK/B,GAAoB,OAAhBjS,EAGF,GAAI0K,EAAU7K,EAAU4L,aAAaZ,GACnChL,EAAU2L,aAAayG,EAAavH,OAG/B,CACL,IAAI0L,OAAM,EACNtO,EAAcxB,IAAIzG,GAAYuW,EAAStO,EAAc9U,IAAI6M,GACxDiI,EAAc7D,IAAIpE,EAAWuW,EAAS,IAAIld,KAC/Ckd,EAAOnS,IAAIgO,EAAa,IAAI/R,EAC1BkQ,EAAOvF,UACPuF,EAAOmG,aACP,KAAM,WAKL,CACDH,OAAM,EACNtO,EAAcxB,IAAIzG,GAAYuW,EAAStO,EAAc9U,IAAI6M,GACxDiI,EAAc7D,IAAIpE,EAAWuW,EAAS,IAAIld,KAC/Ckd,EAAOnS,IAAIgO,EAAa,IAAI/R,EAC1BkQ,EAAOvF,UACPuF,EAAOmG,aACPvW,EACAA,EAAYqW,SAAS/W,EAAAzK,cACjBmL,EAAYzB,UAAU,EAAGyB,EAAY/B,OAASqB,EAAAzK,aAAaoJ,QAC3D+B,EAAcV,EAAAzK,iBAKhBiO,EAAA/O,UAAA4U,wBAAR,SAEEL,EAEAtC,EAEAgC,EAEAC,GAEA,IAAI5B,EAAciC,EAAUjC,YACxBqE,EAAkC,KACtC,OAAQrE,EAAYkC,MAClB,KAAK9I,EAAA+I,SAASU,gBACZwB,EAAU5Y,KAAKqX,eAAgC9C,EAAaL,GAC5D,MAEF,KAAKvG,EAAA+I,SAASY,oBACZsB,EAAU5Y,KAAKuX,mBAAwChD,EAAaL,GACpE,MAEF,KAAKvG,EAAA+I,SAASQ,iBACZ0B,EAAU5Y,KAAKmX,gBAAkC5C,EAAaL,EAAQgC,EAAeC,GACrF,MAEF,KAAKxI,EAAA+I,SAASc,qBACZoB,EAAU5Y,KAAKyX,oBAA0ClD,EAAaL,GACtE,MAEF,KAAKvG,EAAA+I,SAASgB,qBACZkB,EAAU5Y,KAAK2X,oBAA0CpD,EAAaL,EAAQgC,EAAeC,GAC7F,MAEF,QAAS/L,QAAO,GAElB,GAAIwO,EAAS,CACX,IAAIlZ,EAAUwU,EAAOxU,QACrB,GAAKA,GACA,GAAIA,EAAQ8U,IAAI,WAKnB,YAJAxU,KAAKqN,MACHI,EAAAhD,eAAeuV,uBACfzL,EAAY3T,KAAKmK,MAAO,gBAJdmJ,EAAOxU,QAAUA,EAAU,IAAI0H,IAQ7C1H,EAAQyS,IAAI,UAAWyG,KAKnB5H,EAAA/O,UAAA8U,kBAAR,SAEEP,EAEAtC,EAEA6B,EAEAC,GAEA,IAAI2O,EAAenO,EAAUmO,aAC7B,GAAIA,EACF,IAAK,IAAItkB,EAAI,EAAG+V,EAAIuO,EAAaxY,OAAQ9L,EAAI+V,IAAK/V,EAChDL,KAAK4kB,iBACHD,EAAatkB,GACb6T,EACAsC,EAAU6N,aACVtO,EACAC,QAGKQ,EAAUqO,eACnB9O,EAAcrJ,KAAK,IAAIoB,EACrBoG,EACAsC,EAAUqO,cACV,KACArO,EAAU6N,aACV7N,EAAU6N,aAAe7W,EAAAzK,gBAQvBiO,EAAA/O,UAAA2iB,iBAAR,SAEErQ,EAEAL,EAEAhG,EAEA6H,EAEAC,GAEA,IAAI7H,EAAiBD,EAAYqW,SAAS/W,EAAAzK,cACtCmL,EAAYzB,UAAU,EAAGyB,EAAY/B,OAASqB,EAAAzK,aAAaoJ,QAC3D+B,EAAcV,EAAAzK,aAGd6V,EAAU5Y,KAAK6Y,cAActE,EAAY4L,YAAYlU,KAAMiC,EAAaC,EAAgB6H,GACxF4C,EACF1E,EAAOc,IAAIT,EAAY3T,KAAKqL,KAAM2M,GAAS,GAK7C7C,EAAcrJ,KAAK,IAAIoB,EACrBoG,EACAK,EAAY3T,KACZ2T,EAAY4L,YACZjS,EACAC,KAKI6C,EAAA/O,UAAAsV,mBAAR,SAEEhD,EAEAL,GAEA,IAAItT,EAAO2T,EAAY3T,KAAKqL,KACxB6Y,EAAkB/T,EAAewR,OAASxR,EAAeqE,QACzDb,EAAY+K,GAAG9R,EAAAnL,YAAY0iB,SAC7BD,GAAmB/T,EAAeiU,SAElCF,GAAmB/T,EAAesR,OAE/B9N,EAAY+K,GAAG9R,EAAAnL,YAAY4iB,WAC1B/Q,EAAOuC,MAAQ3F,EAAYuJ,kBAC7ByK,GAAmB/T,EAAekQ,QAGtC,IAAIrI,EAAU,IAAIvE,EAChBzT,EACAsT,EACAK,EACAvU,KAAKsgB,gBAAgB/L,EAAYgM,WAAYuE,IAE/C,OAAK5Q,EAAOc,IAAIpU,EAAMgY,GACfA,EADgC,MAKjC5H,EAAA/O,UAAAwV,oBAAR,SAEElD,EAEAL,GAEA,IAAItT,EAAO2T,EAAY3T,KAAKqL,KACxB2M,EAAU,IAAIsM,EAChBtkB,EACAsT,EACAK,EACAvU,KAAKsgB,gBAAgB/L,EAAYgM,WAC/BxP,EAAekQ,SAGnB,IAAK/M,EAAOc,IAAIpU,EAAMgY,GAAU,OAAO,KAEvC,IADA,IAAI2I,EAAqBhN,EAAYuK,QAC5Bze,EAAI,EAAG+V,EAAImL,EAAmBpV,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACzD,IAAImhB,EAAoBD,EAAmBlhB,GAC3C,OAAQmhB,EAAkB/K,MACxB,KAAK9I,EAAA+I,SAAS+K,iBACZzhB,KAAK0hB,gBAAkCF,EAAmB5I,GAC1D,MAEF,KAAKjL,EAAA+I,SAASiL,kBACRH,EAAkBI,MAAMpU,EAAAnL,YAAYwf,IAAMrU,EAAAnL,YAAYyf,KACxD9hB,KAAK+hB,mBAAsCP,EAAmB5I,GAE9D5Y,KAAKgiB,iBAAoCR,EAAmB5I,GAE9D,MAEF,QAASxO,QAAO,IAGpB,OAAOwO,GAID5H,EAAA/O,UAAA0V,oBAAR,SAEEpD,EAEAL,EAEAgC,EAEAC,GAEA,IAAIvV,EAAO2T,EAAY3T,KAAKqL,KACxBkZ,EAAW,IAAIC,EACjBxkB,EACAsT,EACAK,EACAvU,KAAKsgB,gBAAgB/L,EAAYgM,WAAYxP,EAAekQ,SAE9D,IAAK/M,EAAOc,IAAIpU,EAAMukB,GAAW,OAAO,KAGxC,IAFA,IAAIvM,EAAUxO,OAAO8J,EAAOyF,aAAa/Y,IACrCke,EAAUvK,EAAYuK,QACjBze,EAAI,EAAG+V,EAAI0I,EAAQ3S,OAAQ9L,EAAI+V,IAAK/V,EAAG,CAC9C,IAAIie,EAASQ,EAAQze,GACrB,OAAQie,EAAO7H,MACb,KAAK9I,EAAA+I,SAASQ,iBACZlX,KAAKmX,gBAAkCmH,EAAQ6G,EAAUjP,EAAeC,GACxE,MAEF,KAAKxI,EAAA+I,SAASU,gBACZpX,KAAKqX,eAAgCiH,EAAQ6G,GAC7C,MAEF,KAAKxX,EAAA+I,SAASY,oBACZtX,KAAKuX,mBAAwC+G,EAAQ6G,GACrD,MAEF,KAAKxX,EAAA+I,SAASc,qBACZxX,KAAKyX,oBAA0C6G,EAAQ6G,GACvD,MAEF,KAAKxX,EAAA+I,SAASgB,qBACZ1X,KAAK2X,oBAA0C2G,EAAQ6G,EAAUjP,EAAeC,GAChF,MAEF,KAAKxI,EAAA+I,SAASkB,gBACZ5X,KAAK6X,yBAA0CyG,EAAQ6G,GACvD,MAEF,KAAKxX,EAAA+I,SAASM,SACZhX,KAAKiX,oBAAuCqH,EAAQ6G,GACpD,MAEF,QAAS/a,QAAO,IAIpB,OADI+a,GAAYvM,GAASyM,EAAYF,EAAUvM,GACxCA,GAID5H,EAAA/O,UAAA4V,yBAAR,SAEEtD,EAEAL,GAEA,IAAItT,EAAO2T,EAAY3T,KAAKqL,KACxB2M,EAAU,IAAI3D,EAChBrU,EACAsT,EACAK,EACAvU,KAAKsgB,gBAAgB/L,EAAYgM,WAAYxP,EAAekC,OAE9DiB,EAAOc,IAAIpU,EAAMgY,IAIX5H,EAAA/O,UAAAgV,oBAAR,SAEET,EAEAtC,GAGA,IADA,IAAIyQ,EAAenO,EAAUmO,aACpBtkB,EAAI,EAAG+V,EAAIuO,EAAaxY,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACnD,IAAIkU,EAAcoQ,EAAatkB,GAC3BO,EAAO2T,EAAY3T,KAAKqL,KACxBuU,EAAgBzP,EAAekQ,OAASlQ,EAAeuR,KACvD/N,EAAY+K,GAAG9R,EAAAnL,YAAYijB,WAC7B9E,GAAiBzP,EAAeiU,UAE9BzQ,EAAY+K,GAAG9R,EAAAnL,YAAYod,SAC7Be,GAAiBzP,EAAesR,QAElC,IAAIzJ,EAAU,IAAI4G,EAChB5e,EACAsT,EACAlU,KAAKsgB,gBAAgB/L,EAAYgM,WAAYC,GAC7CjM,GAEGL,EAAOc,IAAIpU,EAAMgY,KA8B5B5H,EAhhDA,CAA6BvD,EAAAX,mBAulD7B,SAAgB6T,EAAoBlK,GAClC,OAAQA,GACN,KAAK9I,EAAAe,cAAcuS,OAAQ,OAAOlQ,EAAekQ,OACjD,KAAKtT,EAAAe,cAAcC,SACnB,KAAKhB,EAAAe,cAAcE,gBAAiB,OAAOmC,EAAenC,gBAC1D,KAAKjB,EAAAe,cAAcyB,gBAAiB,OAAOY,EAAeZ,gBAC1D,KAAKxC,EAAAe,cAAcgC,iBAAkB,OAAOK,EAAeL,iBAC3D,KAAK/C,EAAAe,cAAc+M,UAAW,OAAO1K,EAAe0K,UACpD,KAAK9N,EAAAe,cAAc4M,OAAQ,OAAOvK,EAAeuK,OACjD,KAAK3N,EAAAe,cAAc2T,OAAQ,OAAOtR,EAAesR,OACjD,KAAK1U,EAAAe,cAAcsW,SAAU,OAAOjU,EAAeiU,SACnD,KAAKrX,EAAAe,cAAc0G,QAAS,OAAOrE,EAAeqE,QAClD,KAAKzH,EAAAe,cAAc4T,KAAM,OAAOvR,EAAeuR,KAC/C,KAAK3U,EAAAe,cAAc6T,OAAQ,OAAOxR,EAAewR,OACjD,QAAS,OAAOxR,EAAekC,MArmDtBvT,EAAAsR,UAmhDb,SAAYF,GAEVA,IAAA,mBAEAA,IAAA,iBAEAA,IAAA,eAEAA,IAAA,yBAEAA,IAAA,2CAEAA,IAAA,uBAEAA,IAAA,qCAEAA,IAAA,qCAEAA,IAAA,iBAEAA,IAAA,6CAEAA,IAAA,0BAEAA,IAAA,sCAEAA,IAAA,kBAEAA,IAAA,4CAEAA,IAAA,wBAEAA,IAAA,0BAEAA,IAAA,gBAEAA,IAAA,oCApCF,CAAYA,EAAApR,EAAAoR,cAAApR,EAAAoR,YAAW,KAwCvB,SAAYC,GAEVA,IAAA,eAEAA,IAAA,mBAEAA,IAAA,qCAEAA,IAAA,qCAEAA,IAAA,uCAEAA,IAAA,0BAEAA,IAAA,oBAEAA,IAAA,oBAEAA,IAAA,yBAEAA,IAAA,uBAEAA,IAAA,iBAEAA,IAAA,sBAxBF,CAAYA,EAAArR,EAAAqR,iBAAArR,EAAAqR,eAAc,KA4B1BrR,EAAAihB,sBAmBA,IAAA4E,EAAA,WAcE,SAAAA,EAES9O,EAEA7V,EAEAwR,EAEAoT,EAEPtR,GAROlU,KAAAyW,OAEAzW,KAAAY,OAEAZ,KAAAoS,eAEApS,KAAAwlB,UAjBTxlB,KAAAgT,MAAqBxF,EAAAnL,YAAY4Q,KAEjCjT,KAAAmU,eAAiCpD,EAAekC,KAEhDjT,KAAA8e,QAA8C,KAE9C9e,KAAAylB,WAAoC,KAelCzlB,KAAKwlB,QAAUA,EACfxlB,KAAKY,KAAOA,EACZZ,KAAKoS,aAAeA,EAChB8B,EACFlU,KAAKkU,OAASA,GAEd9J,OAAOpK,KAAKyW,MAAQ3F,EAAY4U,MAChC1lB,KAAKkU,OAASlU,MAoEpB,OA/DEe,OAAAC,eAAIukB,EAAAtjB,UAAA,OAAI,KAAR,WAEE,IADA,IAAI0jB,EAAmB3lB,OACpB,IAAK2lB,EAAUA,EAAQzR,QAAQuC,MAAQ3F,EAAY4U,KAAM,OAAaC,mCAK3EJ,EAAAtjB,UAAAqd,GAAA,SAAGoB,GAA2B,OAAQ1gB,KAAKgT,MAAQ0N,IAASA,GAE5D6E,EAAAtjB,UAAA2f,MAAA,SAAM5O,GAA4B,OAA+B,IAAvBhT,KAAKgT,MAAQA,IAEvDuS,EAAAtjB,UAAAkQ,IAAA,SAAIuO,GAA2B1gB,KAAKgT,OAAS0N,GAE7C6E,EAAAtjB,UAAA2jB,MAAA,SAAMlF,GAA0B1gB,KAAKgT,QAAU0N,GAE/C6E,EAAAtjB,UAAAoZ,aAAA,SAAaqF,GAA8B,OAAQ1gB,KAAKmU,eAAiBuM,IAASA,GAGlF6E,EAAAtjB,UAAA0X,aAAA,SAAa/Y,GACX,IAAIke,EAAU9e,KAAK8e,QACnB,OAAIA,GAAWA,EAAQtK,IAAI5T,GAAcke,EAAQ5d,IAAIN,GAC9C,MAOT2kB,EAAAtjB,UAAA+S,IAAA,SAAIpU,EAAcgY,GAChB,IAAIiN,EAAsBjN,EAAQrE,YAC9BuK,EAAU9e,KAAK8e,QACnB,GAAKA,GACA,GAAIA,EAAQtK,IAAI5T,GAAO,CAC1B,IAAIklB,EAAShH,EAAQ5d,IAAIN,GACzB,GAAIklB,EAAO5R,SAAWlU,UAEf,CACL,IAAI8f,EAASC,EAAS+F,EAAQlN,GAC9B,IAAIkH,EAOF,OAJA9f,KAAKwlB,QAAQnY,MACXI,EAAAhD,eAAeuV,uBACfpH,EAAQ4C,eAAezQ,MAAO6N,EAAQ4C,eAAevP,OAEhD,EANP2M,EAAUkH,SARF9f,KAAK8e,QAAUA,EAAU,IAAI1X,IAkB3C0X,EAAQ3M,IAAIvR,EAAMgY,GAClB,IAAI4M,EAAUxlB,KAAKwlB,QAMnB,OALI5M,EAAQnC,MAAQ3F,EAAYkN,oBAA2CpF,EAASmN,UAElFP,EAAQlU,eAAea,IAAIyG,EAAQxG,aAAcwG,GACjD4M,EAAQjU,sBAAsBY,IAAI0T,EAAqBjN,KAElD,GAIT2M,EAAAtjB,UAAAyJ,SAAA,WACE,OAAOoF,EAAY9Q,KAAKyW,MAAQ,IAAMzW,KAAKoS,cAE/CmT,EArGA,GAAsB7lB,EAAA6lB,UAwGtB,IAAAzL,EAAA,SAAA7I,GAGE,SAAA6I,EAEErD,EAEA7V,EAEAwR,EAEAoT,EAEAtR,EAEOK,GAZT,IAAArD,EAcED,EAAAzQ,KAAAR,KAAMyW,EAAM7V,EAAMwR,EAAcoT,EAAStR,IAAOlU,YAFzCkR,EAAAqD,cASPrD,EAAKqD,YAAcA,EACnBrD,EAAK8B,MAAQuB,EAAYvB,QAiB7B,OA1C8CT,EAAAuH,EAAA7I,GA6B5ClQ,OAAAC,eAAI8Y,EAAA7X,UAAA,sBAAmB,KAAvB,WACE,OAAOjC,KAAKuU,YAAYxJ,MAAMY,OAAOkV,2CAIvC9f,OAAAC,eAAI8Y,EAAA7X,UAAA,iBAAc,KAAlB,WACE,OAAOjC,KAAKuU,YAAY3T,sCAI1BG,OAAAC,eAAI8Y,EAAA7X,UAAA,iBAAc,KAAlB,WACE,OAAOjC,KAAKuU,YAAYgM,4CAE5BzG,EA1CA,CAA8CyL,GAAxB7lB,EAAAoa,kBA6CtB,IAAAkM,EAAA,SAAA/U,GAAA,SAAA+U,IAAA,IAAA9U,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YAGEkR,EAAA+N,KAAavR,EAAAkH,KAAKG,OAQpB,OAX2CxC,EAAAyT,EAAA/U,GAMzC+U,EAAA/jB,UAAAid,QAAA,SAAQD,GACN7U,QAAQpK,KAAKsf,GAAG9R,EAAAnL,YAAY6jB,WAC5BlmB,KAAKif,KAAOA,EACZjf,KAAKmS,IAAI3E,EAAAnL,YAAY6jB,WAEzBF,EAXA,CAA2ClM,GAArBpa,EAAAsmB,eActB,IAAA9T,EAAA,SAAAjB,GAUE,SAAAiB,EAEEsT,EAEO7Z,GAJT,IAAAuF,EAMED,EAAAzQ,KAAAR,KACE8Q,EAAY4U,KACZ/Z,EAAOC,eACPD,EAAO0Y,aACPmB,EACA,OACDxlB,KARMkR,EAAAvF,SAXTuF,EAAAxR,QAA8C,KAE9CwR,EAAAmH,YAA6B,KAkB3BnH,EAAKvF,OAASA,EACdvB,QAAQob,EAAQnU,YAAYmD,IAAItD,EAAKkB,eACrCoT,EAAQnU,YAAYc,IAAIjB,EAAKkB,aAAclB,GAC3C,IAAIiV,EAAgBjV,EAAKsU,QAAQxR,mBAC/B,SAAW9C,EAAKkB,aAChB,IAAI1E,EAAA0Y,UAAU,KAAM1Y,EAAAkH,KAAKG,MACzB7D,UAEFiV,EAAc/T,aAAe+T,EAAcvlB,KAC3CsQ,EAAKiV,cAAgBA,IAoFzB,OApH0B5T,EAAAL,EAAAjB,GAoCxBiB,EAAAjQ,UAAA+S,IAAA,SAAIpU,EAAcgY,EAA0ByN,GAI1C,YAJ0C,IAAAA,OAAA,GACtCzN,EAAQyC,aAAatK,EAAekQ,UACtCrI,EAAU5Y,KAAKwlB,QAAQ3F,aAAajf,EAAMgY,MAEvC3H,EAAAhP,UAAM+S,IAAGxU,KAAAR,KAACY,EAAMgY,MACrBA,EAAUxO,OAAOpK,KAAK2Z,aAAa/Y,KACvB0e,GAAG9R,EAAAnL,YAAY6S,UAAYmR,GACrCrmB,KAAK0Z,aACHd,EAAQhY,KACRgY,IAGG,IAIT1G,EAAAjQ,UAAA0X,aAAA,SAAa/Y,GACX,IAAIgY,EAAU3H,EAAAhP,UAAM0X,aAAYnZ,KAAAR,KAACY,GACjC,GAAIgY,EAAS,OAAOA,EACpB,IAAIP,EAAcrY,KAAKqY,YACvB,GAAIA,EACF,IAAK,IAAIhY,EAAI,EAAG+V,EAAIiC,EAAYlM,OAAQ9L,EAAI+V,IAAK/V,EAC/C,GAAIuY,EAAUP,EAAYhY,GAAGsZ,aAAa/Y,GAAO,OAAOgY,EAG5D,OAAO,MAIT1G,EAAAjQ,UAAAqkB,OAAA,SAAO1lB,GACL,IAAIgY,EAAU5Y,KAAK2Z,aAAa/Y,GAChC,OAAIgY,GACG5Y,KAAKwlB,QAAQ3L,aAAajZ,IAInCsR,EAAAjQ,UAAAyX,aAAA,SAAa9Y,EAAcgY,GACzB,IAAIlZ,EAAUM,KAAKN,QACdA,IAASM,KAAKN,QAAUA,EAAU,IAAI0H,KAC3C1H,EAAQyS,IAAIvR,EAAMgY,GACd5Y,KAAK2L,OAAOkV,WAAW7gB,KAAKwlB,QAAQ3F,aAAajf,EAAMgY,IAI7D1G,EAAAjQ,UAAAwW,iBAAA,SAAiBpC,GACf,IAAIgC,EAAcrY,KAAKqY,YACvB,GAAKA,GACA,GAAIA,EAAYkO,SAASlQ,GAAO,YADnBrW,KAAKqY,YAAcA,EAAc,GAEnDA,EAAY3L,KAAK2J,IAInBnE,EAAAjQ,UAAAme,aAAA,SAAaxf,GACX,IAAIlB,EAAUM,KAAKN,QACnB,GAAIA,GAAWA,EAAQ8U,IAAI5T,GAAO,OAAOlB,EAAQwB,IAAIN,GACrD,IAAIyX,EAAcrY,KAAKqY,YACvB,GAAIA,EACF,IAAK,IAAIhY,EAAI,EAAG+V,EAAIiC,EAAYlM,OAAQ9L,EAAI+V,IAAK/V,EAAG,CAClD,IAAIuY,EAAUP,EAAYhY,GAAG+f,aAAaxf,GAC1C,GAAIgY,EAAS,OAAOA,EAGxB,OAAO,MAIT1G,EAAAjQ,UAAA+W,oBAAA,SAAoBpY,EAAcsT,WAC5BxS,EAAK,IAAI0jB,EACXxkB,EACAsT,EACAlU,KAAKwlB,QAAQ1R,+BAA+BlT,IAE1ClB,EAAUM,KAAKN,QACnB,GAAIA,MACF,IAAiC,IAAA8mB,EAAAzO,EAAArY,GAAO+mB,EAAAD,EAAAvO,QAAAwO,EAAAvO,KAAAuO,EAAAD,EAAAvO,OAAE,CAAjC,IAAAyO,EAAAtO,EAAAqO,EAAAnlB,MAAA,GAACqlB,EAAAD,EAAA,GAAYpI,EAAAoI,EAAA,GACpBhlB,EAAGsT,IAAI2R,EAAYrI,qGAGvB,OAAO5c,GAEXwQ,EApHA,CAA0BqT,GAAb7lB,EAAAwS,OAuHb,IAAA+C,EAAA,SAAAhE,GAGE,SAAAgE,EAEErU,EAEAsT,EAEAK,EAEAJ,QAAA,IAAAA,MAAiCpD,EAAekC,MARlD,IAAA/B,EAUED,EAAAzQ,KAAAR,KACE8Q,EAAY8V,eACZhmB,EACAimB,EAAmBjmB,EAAMsT,GAAQ,GACjCA,EAAOsR,QACPtR,EACAK,IACDvU,YACDkR,EAAKiD,eAAiBA,IAiB1B,OAtCoC5B,EAAA0C,EAAAhE,GAyBlClQ,OAAAC,eAAIiU,EAAAhT,UAAA,qBAAkB,KAAtB,WACE,OAAyBjC,KAAKuU,YAAauS,gDAI7C/lB,OAAAC,eAAIiU,EAAAhT,UAAA,WAAQ,KAAZ,WACE,OAAyBjC,KAAKuU,YAAa0K,sCAI7ChK,EAAAhT,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAKkU,OAAOoS,OAAO1lB,IAE9BqU,EAtCA,CAAoC+Q,GAAvBtmB,EAAAuV,iBAyCb,IAAAmQ,EAAA,SAAAnU,GAGE,SAAAmU,EAEExkB,EAEAsT,EAEAK,EAEAJ,QAAA,IAAAA,MAAiCpD,EAAekC,MARlD,IAAA/B,EAUED,EAAAzQ,KAAAR,KACE8Q,EAAYiW,UACZnmB,EACAimB,EAAmBjmB,EAAMsT,GAAQ,GACjCA,EAAOsR,QACPtR,EACAK,IACDvU,YACDkR,EAAKiD,eAAiBA,IAQ1B,OA7B+B5B,EAAA6S,EAAAnU,GAyB7BmU,EAAAnjB,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAK2Z,aAAa/Y,IAClBZ,KAAKkU,OAAOoS,OAAO1lB,IAE9BwkB,EA7BA,CAA+BtL,GAAlBpa,EAAA0lB,YAgCb,IAAAnB,EAAA,SAAAhT,GAGE,SAAAgT,EAEErjB,EAEAsT,EAEAK,EAEAJ,QAAA,IAAAA,MAAiCpD,EAAekC,MARlD,IAAA/B,EAUED,EAAAzQ,KAAAR,KACE8Q,EAAYkW,KACZpmB,EACAimB,EAAmBjmB,EAAMsT,GAAQ,GACjCA,EAAOsR,QACPtR,EACAK,IACDvU,YACDkR,EAAKiD,eAAiBA,EACtBjD,EAAKgO,QAAQxR,EAAAkH,KAAKxR,OAQtB,OA9B0BmP,EAAA0R,EAAAhT,GA0BxBgT,EAAAhiB,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAK2Z,aAAa/Y,IAClBZ,KAAKkU,OAAOoS,OAAO1lB,IAE9BqjB,EA9BA,CAA0B+B,GAAbtmB,EAAAukB,OAiCb,SAAkBgD,GAEhBA,IAAA,eAEAA,IAAA,qBAEAA,IAAA,iBANF,CAAkBvnB,EAAAunB,oBAAAvnB,EAAAunB,kBAAiB,KAUnC,IAAAC,EAAA,SAAAjW,GAUE,SAAAiW,EAEEzQ,EAEA7V,EAEAsT,EAEAK,QAAA,IAAAA,MAAgDL,EAAOsR,QAAQzS,8BAA8BnS,IAR/F,IAAAsQ,EAUED,EAAAzQ,KAAAR,KACEyW,EACA7V,EACAimB,EAAmBjmB,EAAMsT,GAAQ,GACjCA,EAAOsR,QACPtR,EACAK,IACDvU,YAxBHkR,EAAAiW,kBAAiB,EAyBfjW,EAAK8B,MAAQuB,EAAYvB,QAmC7B,OA/DkDT,EAAA2U,EAAAjW,GAgChDlQ,OAAAC,eAAIkmB,EAAAjlB,UAAA,WAAQ,KAAZ,WACE,OAA0CjC,KAAKuU,YAAa0K,sCAI9Dle,OAAAC,eAAIkmB,EAAAjlB,UAAA,kBAAe,KAAnB,WACE,OAA0CjC,KAAKuU,YAAa6S,6CAI9DF,EAAAjlB,UAAAyd,wBAAA,SAAwBpe,EAAY2d,GAClC7U,OAAO6U,EAAKK,GAAE,IACdtf,KAAKif,KAAOA,EACZjf,KAAKmnB,kBAAiB,EACtBnnB,KAAKqnB,qBAAuB/lB,EAC5BtB,KAAKmS,IAAI3E,EAAAnL,YAAYod,MAAQjS,EAAAnL,YAAYilB,QAAU9Z,EAAAnL,YAAY6jB,WAIjEgB,EAAAjlB,UAAA2d,sBAAA,SAAsBte,EAAY2d,GAChC7U,OAAO6U,EAAKK,GAAE,IACdtf,KAAKif,KAAOA,EACZjf,KAAKmnB,kBAAiB,EACtBnnB,KAAKunB,mBAAqBjmB,EAC1BtB,KAAKmS,IAAI3E,EAAAnL,YAAYod,MAAQjS,EAAAnL,YAAYilB,QAAU9Z,EAAAnL,YAAY6jB,WAIjEgB,EAAAjlB,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAKkU,OAAOoS,OAAO1lB,IAE9BsmB,EA/DA,CAAkDlB,GAA5BtmB,EAAAwnB,sBAkEtB,IAAA/C,EAAA,SAAAlT,GAGE,SAAAkT,EAEEvjB,EAEAsT,EAEAK,EAEAJ,QAAA,IAAAA,MAAiCpD,EAAekC,MARlD,IAAA/B,EAUED,EAAAzQ,KAAAR,KACE8Q,EAAY0W,UACZ5mB,EACAsT,EACAK,IACDvU,YAMHkR,EAAAuW,aAAoB,EALlBvW,EAAKiD,eAAiBA,EACtBjD,EAAKgO,QAAQxR,EAAAkH,KAAKxR,OAetB,OAnC+BmP,EAAA4R,EAAAlT,GA2B7BlQ,OAAAC,eAAImjB,EAAAliB,UAAA,YAAS,KAAb,WACE,OAA8BjC,KAAKuU,YAAajT,uCAIlD6iB,EAAAliB,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAKkU,OAAOoS,OAAO1lB,IAE9BujB,EAnCA,CAA+B+C,GAAlBxnB,EAAAykB,YAsCb,IAAA3E,EAAA,SAAAvO,GAGE,SAAAuO,EAEE5e,EAEAsT,EAEAC,EAEAI,QAAA,IAAAA,MAAgDL,EAAOsR,QAAQzS,8BAA8BnS,IAR/F,IAAAsQ,EAUED,EAAAzQ,KAAAR,KACE8Q,EAAYmQ,OACZrgB,EACAsT,EACAK,IACDvU,YACDkR,EAAKiD,eAAiBA,IAE1B,OArB4B5B,EAAAiN,EAAAvO,GAqB5BuO,EArBA,CAA4B0H,GAAfxnB,EAAA8f,SAwBb,IAAAkI,EAAA,WAUA,OARE,SAES9mB,EAEAqe,EAEAmI,QAAA,IAAAA,MAAA,MAJApnB,KAAAY,OAEAZ,KAAAif,OAEAjf,KAAAonB,eARX,GAAa1nB,EAAAgoB,YAab,IAAAC,EAAA,SAAA1W,GAGE,SAAA0W,EAEE/mB,EAEOgnB,EAEP3I,EAEA/K,EAEAK,QAAA,IAAAA,MAAgDL,EAAOsR,QAAQzS,8BAA8BnS,IAV/F,IAAAsQ,EAYED,EAAAzQ,KAAAR,KACE8Q,EAAY+W,MACZjnB,EACAsT,EACAK,IACDvU,YAbMkR,EAAA0W,QAcP1W,EAAK0W,MAAQA,EACbxd,OAAO6U,GAAQvR,EAAAkH,KAAKG,MACpB7D,EAAKgO,QAAQD,KAEjB,OAzB2B1M,EAAAoV,EAAA1W,GAyB3B0W,EAzBA,CAA2BT,GAAdxnB,EAAAioB,QA4Bb,IAAAtT,EAAA,SAAApD,GAWE,SAAAoD,EAEEzT,EAEAsT,EAEAK,EAEAJ,QAAA,IAAAA,MAAiCpD,EAAekC,MARlD,IAAA/B,EAUED,EAAAzQ,KAAAR,KACE8Q,EAAYkN,mBACZpd,EACAimB,EAAmBjmB,EAAMsT,EAAQK,EAAY+K,GAAG9R,EAAAnL,YAAY4iB,WAC5D/Q,EAAOsR,QACPtR,EACAK,IACDvU,YAzBHkR,EAAAuS,aAA6BlW,EAAasD,QAE1CK,EAAA4W,UAAyC,KAGjC5W,EAAA6W,gBAAuD,KAqB7D7W,EAAKiD,eAAiBA,IAsE1B,OAnGuC5B,EAAA8B,EAAApD,GAiCrClQ,OAAAC,eAAIqT,EAAApS,UAAA,qBAAkB,KAAtB,WACE,OAA6BjC,KAAKuU,YAAauS,gDAIjD/lB,OAAAC,eAAIqT,EAAApS,UAAA,mBAAgB,KAApB,WACE,OAA6BjC,KAAKuU,YAAaN,2CAIjDlT,OAAAC,eAAIqT,EAAApS,UAAA,WAAQ,KAAZ,WACE,OAA6BjC,KAAKuU,YAAayT,sCAIjDjnB,OAAAC,eAAIqT,EAAApS,UAAA,YAAS,KAAb,WACE,OAA6BjC,KAAKuU,YAAa0T,2CAIjDlnB,OAAAC,eAAIqT,EAAApS,UAAA,UAAO,KAAX,WACE,IAAIiS,EAASlU,KAAKkU,OAClB,OAAOA,EAAOuC,MAAQ3F,EAAY+N,OAC3B3K,EAAOuC,MAAQ3F,EAAYyN,oBAAsBrK,EAAOA,OAAOuC,MAAQ3F,EAAY+N,uCAI5FxK,EAAApS,UAAAimB,QAAA,SAAQvV,GACNvI,OAAOpK,KAAKsf,GAAG9R,EAAAnL,YAAY4iB,WAC3B7a,QAAQpK,KAAK+lB,SACb,IAAIgC,EAAkB/nB,KAAK+nB,gBAC3B,GAAKA,GACA,GAAIA,EAAgBvT,IAAI7B,GAAgB,OAAOoV,EAAgB7mB,IAAIyR,QADlD3S,KAAK+nB,gBAAkBA,EAAkB,IAAI3gB,IAEnE,IAAImN,EAAcvU,KAAKuU,YAAanK,OAAOmK,EAAYkC,MAAQ9I,EAAA+I,SAASiL,mBACxE,IAAIwG,EAAQ,IAAI9T,EACdrU,KAAKY,KACL+R,EACmB4B,EACnBvU,KAAKmU,gBAMP,OAJAgU,EAAMnV,MAAQhT,KAAKgT,MACnBmV,EAAM1E,aAAezjB,KAAKyjB,aAE1BsE,EAAgB5V,IAAIQ,EAAewV,GAC5BA,GAIT9T,EAAApS,UAAAmmB,oBAAA,SAAoBC,GAClB,IAAIP,EAAY9nB,KAAK8nB,UACrB,OAAIA,GAAaA,EAAUtT,IAAI6T,GAA+BP,EAAU5mB,IAAImnB,GACrE,MAIThU,EAAApS,UAAAqmB,oBAAA,SAAoBD,EAAqBE,GACvC,IAAIT,EAAY9nB,KAAK8nB,UAChBA,EACA1d,QAAQ0d,EAAUtT,IAAI6T,IADXroB,KAAK8nB,UAAYA,EAAY,IAAI1gB,IAEjD0gB,EAAU3V,IAAIkW,EAAaE,IAI7BlU,EAAApS,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAKkU,OAAOoS,OAAO1lB,IAE9ByT,EAnGA,CAAuCyF,GAA1Bpa,EAAA2U,oBAsGb,IAAAD,EAAA,SAAAnD,GAiCE,SAAAmD,EAEEoU,EAEAvmB,EAEAgS,EAEAwU,QAAA,IAAAA,MAAA,MARF,IAAAvX,EAUED,EAAAzQ,KAAAR,KACE8Q,EAAY6N,SACZ6J,EACA3B,EAAmB2B,EAAwBvmB,EAAUiS,OAAQjS,EAAUqd,GAAG9R,EAAAnL,YAAY4iB,WACtFhjB,EAAUujB,QACVvjB,EAAUiS,OACVjS,EAAUsS,cACXvU,KAOD,GAlDFkR,EAAAwX,aAAkC,IAAIthB,IAEtC8J,EAAAyX,cAAyB,GAEzBzX,EAAA0X,iBAA2B,GAM3B1X,EAAA2X,eAA0B,GAE1B3X,EAAA4X,IAAmB,EAEnB5X,EAAA6X,oBAA2B,EAE3B7X,EAAA8X,WAA8B,KAG9B9X,EAAA+X,aAAoB,EAEpB/X,EAAAgY,gBAAuB,EAEvBhY,EAAAiY,kBAAyB,EAyFzBjY,EAAAkY,SAA2B,KAC3BlY,EAAAmY,SAA2B,KAC3BnY,EAAAoY,SAA2B,KAC3BpY,EAAAqY,SAA2B,KAC3BrY,EAAAsY,UAA4B,KAG5BtY,EAAAuY,YAAmB,EACnBvY,EAAAwY,WAA2B,KAC3BxY,EAAAyY,WAA4B,KA7E1BzY,EAAKjP,UAAYA,EACjBiP,EAAK+C,UAAYA,EACjB/C,EAAK8B,MAAQ/Q,EAAU+Q,MAAQxF,EAAAnL,YAAY6jB,SAC3ChV,EAAKiD,eAAiBlS,EAAUkS,eAChCjD,EAAKuX,wBAA0BA,EAC/BvX,EAAK+N,KAAOvR,EAAAkH,KAAKnR,IAAImmB,WAAW3V,IAC3BhS,EAAUqd,GAAG9R,EAAAnL,YAAY0iB,SAAU,CACtC,IAAI8E,EAAa,EACjB,GAAI3Y,EAAKoO,GAAG9R,EAAAnL,YAAY4iB,UAAW,CACjC,IAAI6E,EAAQ,IAAInC,EACdna,EAAAxK,cAAcoC,MACdykB,IACAzf,OAAO6J,EAAU8V,UACjB7Y,GAEFA,EAAKwX,aAAavW,IAAI3E,EAAAxK,cAAcoC,MAAO0kB,GAC3C5Y,EAAKyX,cAAcmB,EAAMlC,OAASkC,EAGpC,IADA,IAAIE,EAAiB/V,EAAU+V,eACtB3pB,EAAI,EAAG+V,EAAI4T,EAAe7d,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACrD,IAAI4pB,EAAgBD,EAAe3pB,GAC/B6pB,EAAgBjW,EAAUkW,iBAAiB9pB,GAC3CypB,EAAQ,IAAInC,EACduC,EACAL,IACAI,EACA/Y,GAEFA,EAAKwX,aAAavW,IAAI+X,EAAeJ,GACrC5Y,EAAKyX,cAAcmB,EAAMlC,OAASkC,UAGtC5Y,EAAKkZ,KAAOvc,EAAAwc,KAAK1oB,OAAOuP,GACxBoZ,EAAwBpZ,EAAKsU,QAAStU,KAmE1C,OAvJ8BqB,EAAA6B,EAAAnD,GAwF5BmD,EAAAnS,UAAAsoB,SAAA,SAAStL,EAAYre,EAA4B2T,QAA5B,IAAA3T,MAAA,WAA4B,IAAA2T,MAAA,MAE/C,IAAIsV,EAAa7pB,KAAKiU,UAAU+V,eAAe7d,OAASnM,KAAK4oB,iBAAiBzc,OAC1EnM,KAAKsf,GAAG9R,EAAAnL,YAAY4iB,aAAa4E,EACrC,IAAI9Q,EAAqB,OAATnY,EACZA,EACA,OAASipB,EAAWne,WACpBoe,EAAQ,IAAInC,EACd5O,EACA8Q,EACA5K,EACAjf,KACAuU,GAAevU,KAAKwlB,QAAQzS,8BAA8BgG,IAE5D,GAAInY,EAAM,CACR,GAAIZ,KAAK0oB,aAAalU,IAAI5T,GAAO,MAAM,IAAIwb,MAAM,wBACjDpc,KAAK0oB,aAAavW,IAAIvR,EAAMkpB,GAI9B,OAFA9pB,KAAK2oB,cAAcmB,EAAMlC,OAASkC,EAClC9pB,KAAK4oB,iBAAiBlc,KAAKuS,GACpB6K,GAIT1V,EAAAnS,UAAAqkB,OAAA,SAAO1lB,GACL,IAAI4pB,EAASxqB,KAAK0oB,aAClB,OAAI8B,EAAOhW,IAAI5T,GAAc4pB,EAAOtpB,IAAIN,GACjCZ,KAAKkU,OAAOoS,OAAO1lB,IAgB5BwT,EAAAnS,UAAAwoB,SAAA,SAAS9qB,EAAgBmpB,GAMvB,GALA9oB,KAAK8oB,IAAMA,EACX1e,QAAQpK,KAAK0pB,aAAe1pB,KAAK0pB,WAAWvd,QAC5CnM,KAAK0pB,WAAa,KAClB1pB,KAAK2pB,WAAa,KAClB3pB,KAAKopB,SAAWppB,KAAKqpB,SAAWrpB,KAAKspB,SAAWtpB,KAAKupB,SAAW,KAC5DvpB,KAAKwlB,QAAQ9Q,QAAQgW,UAEvB,IADA,IAAI7B,EAAiB7oB,KAAK6oB,eACjBxoB,EAAI,EAAG+V,EAAIyS,EAAe1c,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACrD,IAAIsqB,EAAgB9B,EAAexoB,GACnCV,EAAOirB,iBACL9B,EACA6B,EAAcE,aACdF,EAAchf,OAAOmf,eACrBH,EAAc9e,KACd8e,EAAc7e,UAKxBsI,EAvJA,CAA8B4R,GAAjBtmB,EAAA0U,WA0Jb,IAAA2W,EAAA,SAAA9Z,GAQE,SAAA8Z,EAEE9W,EAEAuR,EACAwF,QAAA,IAAAA,MAAA,IALF,IAAA9Z,EAOED,EAAAzQ,KAAAR,KACE8Q,EAAYma,gBACZD,EAAM,OAAS/W,EAAUiX,oBACzBF,EACAxF,EACAA,EAAQvT,aACTjS,YACDkR,EAAK+C,UAAYA,EACjB/C,EAAK8B,MAAQxF,EAAAnL,YAAY6jB,SACzBhV,EAAK+N,KAAOvR,EAAAkH,KAAKnR,IAAImmB,WAAW3V,KAOpC,OA/BoC1B,EAAAwY,EAAA9Z,GA4BlC8Z,EAAA9oB,UAAAqkB,OAAA,SAAO1lB,GACL,OAAO,MAEXmqB,EA/BA,CAAoCxF,GAAvB7lB,EAAAqrB,iBAkCb,IAAAtI,EAAA,SAAAxR,GAGE,SAAAwR,EAEE7hB,EAEAsT,EAEAK,EAEAJ,QAAA,IAAAA,MAAiCpD,EAAekC,MARlD,IAAA/B,EAUED,EAAAzQ,KAAAR,KACE8Q,EAAYqa,gBACZvqB,EACAimB,EAAmBjmB,EAAMsT,EAAQ9J,OAAOmK,EAAY+K,GAAG9R,EAAAnL,YAAY4iB,YACnE/Q,EAAOsR,QACPtR,EACAK,IACDvU,YACDkR,EAAKiD,eAAiBA,IAsB1B,OA3CoC5B,EAAAkQ,EAAAxR,GAyBlClQ,OAAAC,eAAIyhB,EAAAxgB,UAAA,WAAQ,KAAZ,WACE,OAA0BjC,KAAKuU,YAAa0K,sCAI9Cle,OAAAC,eAAIyhB,EAAAxgB,UAAA,kBAAe,KAAnB,WACE,OAA0BjC,KAAKuU,YAAa6S,6CAI9CrmB,OAAAC,eAAIyhB,EAAAxgB,UAAA,iBAAc,KAAlB,WACE,OAA0BjC,KAAKuU,YAAa6W,gDAI9C3I,EAAAxgB,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAKkU,OAAOoS,OAAO1lB,IAE9B6hB,EA3CA,CAAoC3I,GAAvBpa,EAAA+iB,iBA8Cb,IAAA4I,EAAA,SAAApa,GAQE,SAAAoa,EAEEppB,EAEAiS,EAEA+K,GANF,IAAA/N,EAQED,EAAAzQ,KAAAR,KACE8Q,EAAY8N,MACZ3c,EAAUrB,KACVsT,EACkCjS,EAAUsS,cAC7CvU,YAhBHkR,EAAAoa,cAAqB,EAiBnBpa,EAAKjP,UAAYA,EACjBiP,EAAK8B,MAAQ/Q,EAAU+Q,MACvB5I,OAAO6U,GAAQvR,EAAAkH,KAAKG,MACpB7D,EAAKgO,QAAQD,GACbqL,EAAwBpZ,EAAKsU,QAAStU,KAE1C,OA5B2BqB,EAAA8Y,EAAApa,GA4B3Boa,EA5BA,CAA2BnE,GAAdxnB,EAAA2rB,QA+Bb,IAAAvH,EAAA,SAAA7S,GAQE,SAAA6S,EAEEljB,EAEAsT,EAEAqX,GANF,IAAAra,EAQED,EAAAzQ,KAAAR,KACE8Q,EAAYyN,mBACZ3d,EACAimB,EAAmBjmB,EAAMsT,EAAQqX,EAAiBjM,GAAG9R,EAAAnL,YAAY4iB,WACjE/Q,EAAOsR,QACPtR,EACAqX,IACDvrB,YApBHkR,EAAAsN,gBAA4C,KAE5CtN,EAAAuN,gBAA4C,KAmB1CvN,EAAK8B,SAAWxF,EAAAnL,YAAYwf,IAAMrU,EAAAnL,YAAYyf,OAOlD,OA/BuCvP,EAAAuR,EAAA7S,GA4BrC6S,EAAA7hB,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAKkU,OAAOoS,OAAO1lB,IAE9BkjB,EA/BA,CAAuChK,GAA1Bpa,EAAAokB,oBAkCb,IAAA0H,EAAA,SAAAva,GAUE,SAAAua,EAEEvpB,EAEAiS,GAJF,IAAAhD,EAMED,EAAAzQ,KAAAR,KACE8Q,EAAY4N,SACZzc,EAAUrB,KACVsT,EACAjS,EAAUujB,QAAQzS,8BAChB9Q,EAAUrB,KACVqB,EAAUqd,GAAG9R,EAAAnL,YAAY4iB,UACrBzX,EAAAnL,YAAY4iB,SACZzX,EAAAnL,YAAY4Q,QAEnBjT,YArBHkR,EAAAua,eAAkC,KAElCva,EAAAwa,eAAkC,KAoBhCxa,EAAKjP,UAAYA,EACjBqoB,EAAwBpZ,EAAKsU,QAAStU,KAO1C,OAnC8BqB,EAAAiZ,EAAAva,GAgC5Bua,EAAAvpB,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAKkU,OAAOoS,OAAO1lB,IAE9B4qB,EAnCA,CAA8BtE,GAAjBxnB,EAAA8rB,WAsCb,IA4GWG,EA5GX3K,EAAA,SAAA/P,GAaE,SAAA+P,EAEEpgB,EAEAsT,EAEAK,EAEAJ,EACAyX,QADA,IAAAzX,MAAiCpD,EAAekC,WAChD,IAAA2Y,OAAA,GATF,IAAA1a,EAWED,EAAAzQ,KAAAR,KACE4rB,EAAe9a,EAAYqR,oBAAsBrR,EAAYuJ,gBAC7DzZ,EACAimB,EAAmBjmB,EAAMsT,EAAQK,EAAY+K,GAAG9R,EAAAnL,YAAY4iB,WAC5D/Q,EAAOsR,QACPtR,EACAK,IACDvU,YA5BHkR,EAAAiN,gBAA8C,KAE9CjN,EAAAkK,cAAuC,KAEvClK,EAAA2a,qBAAiD,KAEjD3a,EAAAqS,mBAA2D,IAAInc,IAE/D8J,EAAA4W,UAAsC,KAqBpC5W,EAAKiD,eAAiBA,IA0E1B,OA1GoC5B,EAAAyO,EAAA/P,GAoClClQ,OAAAC,eAAIggB,EAAA/e,UAAA,qBAAkB,KAAtB,WACE,OAA0BjC,KAAKuU,YAAauS,gDAG9C/lB,OAAAC,eAAIggB,EAAA/e,UAAA,cAAW,KAAf,WACE,OAA0BjC,KAAKuU,YAAa+M,6CAG9CvgB,OAAAC,eAAIggB,EAAA/e,UAAA,kBAAe,KAAnB,WACE,OAA0BjC,KAAKuU,YAAa2M,iDAI9CngB,OAAAC,eAAIggB,EAAA/e,UAAA,iBAAc,KAAlB,WACE,IAAIiY,EAA0Bla,KAAKwlB,QAAQtL,wBAC3C,OAAmC,OAA5BA,GACAla,KAAK8rB,QAAQ5R,EAAwBjY,4CAI9C+e,EAAA/e,UAAA6pB,QAAA,SAAQC,GACN,IAAIpG,EAAiC3lB,KACrC,GAAG,GAAI2lB,IAAYoG,EAAe,OAAO,QAClCpG,EAAUA,EAAQvK,eACzB,OAAO,GAIT4F,EAAA/e,UAAAygB,YAAA,SAAY9hB,EAAcgY,GACxB,IAAIiN,EAAsBjN,EAAQrE,YAC9B4J,EAAkBne,KAAKme,gBAC3B,GAAKA,GACA,GAAIA,EAAgB3J,IAAI5T,GAAO,CAClC,IAAIkf,EAASC,EAAS5B,EAAgBjd,IAAIN,GAAQgY,GAClD,IAAKkH,EAKH,OAJA9f,KAAKwlB,QAAQnY,MACXI,EAAAhD,eAAeuV,uBACfpH,EAAQ4C,eAAezQ,MAAO6N,EAAQ4C,eAAevP,OAEhD,EAET2M,EAAUkH,QAVU9f,KAAKme,gBAAkBA,EAAkB,IAAI/W,IAiBnE,OALA+W,EAAgBhM,IAAIvR,EAAMgY,GACtBA,EAAQ0G,GAAG9R,EAAAnL,YAAY6S,SAAWlV,KAAKsf,GAAG9R,EAAAnL,YAAY6b,gBACxDtF,EAAQzG,IAAI3E,EAAAnL,YAAY6b,eAE1Ble,KAAKwlB,QAAQjU,sBAAsBY,IAAI0T,EAAqBjN,IACrD,GAIToI,EAAA/e,UAAAmmB,oBAAA,SAAoBC,GAClB,IAAIP,EAAY9nB,KAAK8nB,UACrB,OAAIA,GAAaA,EAAUtT,IAAI6T,GAA4BP,EAAU5mB,IAAImnB,GAClE,MAITrH,EAAA/e,UAAAqmB,oBAAA,SAAoBD,EAAqBE,GACvC,IAAIT,EAAY9nB,KAAK8nB,UAChBA,EACA1d,QAAQ0d,EAAUtT,IAAI6T,IADXroB,KAAK8nB,UAAYA,EAAY,IAAI1gB,IAEjD0gB,EAAU3V,IAAIkW,EAAaE,IAI7BvH,EAAA/e,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAKkU,OAAOoS,OAAO1lB,IAE9BogB,EA1GA,CAAoClH,GAAvBpa,EAAAshB,iBA4Gb,SAAW2K,GACTA,IAAA,qBACAA,IAAA,qBACAA,IAAA,6BAHF,CAAWA,MAAY,KAOvB,IAAAK,EAAA,SAAA/a,GAkDE,SAAA+a,EAEExD,EAEAvmB,EAEAgqB,EAEAC,EACAN,gBAHA,IAAAK,MAAA,WAEA,IAAAC,MAAA,WACA,IAAAN,OAAA,GATF,IAAA1a,EAWED,EAAAzQ,KAAAR,KACE4rB,EAAe9a,EAAYqb,UAAYrb,EAAY+N,MACnD2J,EACA3B,EAAmB2B,EAAwBvmB,EAAUiS,OAAQjS,EAAUqd,GAAG9R,EAAAnL,YAAY4iB,WACtFhjB,EAAUujB,QACVvjB,EAAUiS,OACVjS,EAAUsS,cACXvU,KA3DHkR,EAAAuX,wBAAmD,KAEnDvX,EAAAkb,oBAA2B,EAE3Blb,EAAAmb,oBAAuC,KAEvCnb,EAAAoS,UAA+C,KAEvCpS,EAAAob,IAAW,EAEXpb,EAAAqb,SAAQ,EAEhBrb,EAAAsb,UAAiB,EAgDf,IAAIhH,EAAUtU,EAAKsU,QAQnB,GAPAtU,EAAKjP,UAAYA,EACjBiP,EAAK8B,MAAQ/Q,EAAU+Q,MACvB9B,EAAKiD,eAAiBlS,EAAUkS,eAChCjD,EAAK+a,cAAgBA,EACrB/a,EAAKgO,QAAQsG,EAAQ9Q,QAAQI,UAAU2X,QAAQvb,IAC/CA,EAAKgb,KAAOA,GAEPhb,EAAKmK,aAAatK,EAAe0K,WAAY,CAChD,IAAI3I,EAAK0S,EAAQ7T,cACjBT,EAAKob,IAAMxZ,EACX0S,EAAQ9T,eAAeS,IAAIW,EAAI5B,GAIjC,GAAIgb,EAAM,CACR,IAAIQ,EAAyBR,EAAKzD,wBAClC,GAAIiE,EAAwB,CAC1B,IAAIjE,EAA0BvX,EAAKuX,4BACnC,IAAiC,IAAAkE,EAAA5U,EAAA2U,GAAsBE,EAAAD,EAAA1U,QAAA2U,EAAA1U,KAAA0U,EAAAD,EAAA1U,OAAE,CAAhD,IAAAyO,EAAAtO,EAAAwU,EAAAtrB,MAAA,GAACurB,EAAAnG,EAAA,GAAUoG,EAAApG,EAAA,GACb+B,IAAyBvX,EAAKuX,wBAA0BA,EAA0B,IAAIrhB,KAC3FqhB,EAAwBtW,IAAI0a,EAAUC,uGAM5C,IAAIhG,EAAiB7kB,EAAU8qB,mBAC/B,GAAId,EAAe,CACjB,IAAIe,EAAmBf,EAAc9f,OACrC,IAAK2a,GAAkBkG,GAAoBlG,EAAe3a,OACxD,MAAM,IAAIiQ,MAAM,gCAElB,GAAI4Q,EAAkB,CACf9b,EAAKuX,0BAAyBvX,EAAKuX,wBAA0B,IAAIrhB,KACtE,IAAK,IAAI/G,EAAI,EAAGA,EAAI2sB,IAAoB3sB,EACtC6Q,EAAKuX,wBAAwBtW,IAAI2U,EAAezmB,GAAGO,KAAKqL,KAAMggB,EAAc5rB,UAG3E,GAAIymB,GAAkBA,EAAe3a,OAC1C,MAAM,IAAIiQ,MAAM,uCAElBkO,EAAwB9E,EAAStU,KA+NrC,OA9U2BqB,EAAAyZ,EAAA/a,GAwBzBlQ,OAAAC,eAAIgrB,EAAA/pB,UAAA,KAAE,KAAN,WACE,OAAOjC,KAAKssB,qCAIdvrB,OAAAC,eAAIgrB,EAAA/pB,UAAA,iBAAc,KAAlB,WACE,OAAOjC,KAAKiC,UAAUgrB,gDAIxBlsB,OAAAC,eAAIgrB,EAAA/pB,UAAA,cAAW,KAAf,WACE,GAAIjC,KAAKitB,eAAgB,OAAO,EAChC,IAAIC,EAAcltB,KAAK2Z,aAAa,UACpC,OAAuB,OAAhBuT,IACLA,EAAYzW,MAAQ3F,EAAY8N,OAE9BsO,EAAYzW,MAAQ3F,EAAY4N,UACW,OAAhCwO,EAAazB,kBAGwB,OAAlDzrB,KAAKmtB,eAAe5f,EAAasB,cAC2B,OAA5D7O,KAAKmtB,eAAe5f,EAAawB,yDAsErCid,EAAA/pB,UAAAmrB,eAAA,SAAeC,GACb,IAAI1H,EAAwB3lB,KAC5B,GAAG,GAAI2lB,GAAW0H,EAAQ,OAAO,QAC1B1H,EAAUA,EAAQuG,MACzB,OAAO,GAITF,EAAA/pB,UAAAkrB,eAAA,SAAe1W,EAAoB6W,GACjC,QADiC,IAAAA,OAAA,GAC7BA,EACF,OAAQ7W,GACN,KAAKlJ,EAAasB,YAEhB,GADI0e,EAAoBvtB,KAAKmtB,eAAe5f,EAAawB,uBAClC,OAAOwe,EAC9B,MAEF,KAAKhgB,EAAauB,YAChB,IAAIye,EACJ,GADIA,EAAoBvtB,KAAKmtB,eAAe5f,EAAayB,uBAClC,OAAOue,EAC9B,MAEF,QAASnjB,QAAO,GAGpB,IAAIme,EAAyBvoB,KAC7B,EAAG,CACD,IAAIsjB,EAAYiF,EAASjF,UACzB,GAAIA,EAAW,CACb,IAAIkK,EAAWlK,EAAUpiB,IAAIuV,GAC7B,GAAI+W,EAAU,OAAOA,SAEhBjF,EAAWA,EAAS2D,MAC7B,OAAO,MAITF,EAAA/pB,UAAAqkB,OAAA,SAAO1lB,GACL,OAAOZ,KAAKkU,OAAOoS,OAAO1lB,IAI5BorB,EAAA/pB,UAAAwrB,SAAA,SAASC,GACP,IAAI5O,EAAU1U,OAAOpK,KAAK8e,SAC1B1U,OAAO0U,EAAQtK,IAAIkZ,IACnB,IAAIC,EAAiB7O,EAAQ5d,IAAIwsB,GAEjC,OADAtjB,OAAOujB,EAAMlX,MAAQ3F,EAAY8N,OAClB+O,EAAOrC,cAIxBU,EAAA/pB,UAAA2rB,WAAA,SAAchtB,EAAcU,EAAUmR,EAAoBob,GACxD,IAAIF,EAAQ3tB,KAAK2Z,aAAa/Y,GAC9B,GAAI+sB,GAASA,EAAMlX,MAAQ3F,EAAY8N,MAAO,CAC5C,IAAIlM,EAASmb,EAAqBF,EAAOrC,aACzC,OAAgBqC,EAAO1O,KAAKxI,MAC1B,OACA,OAEE,OADA5M,EAAAikB,QAAQ1qB,IAAI9B,GAAQmR,EAAQC,GACrB,EAET,OACA,OAEE,OADA7I,EAAAkkB,SAAS3qB,IAAI9B,GAAQmR,EAAQC,GACtB,EAET,OACA,OAEE,OADA7I,EAAAgJ,SAASzP,IAAI9B,GAAQmR,EAAQC,GACtB,EAET,OACA,OAGE,OAFAtI,QAAQpK,KAAKwlB,QAAQ9Q,QAAQc,UAC7B3L,EAAAgJ,SAASzP,IAAI9B,GAAQmR,EAAQC,GACtB,EAET,QAEE,OADA7I,EAAAmkB,SAASnqB,IAAIvC,GAAQmR,EAAQC,GACtB,EAET,QAEE,OADA7I,EAAAokB,SAASnqB,IAAIxC,GAAQmR,EAAQC,GACtB,GAKb,OADAtI,QAAO,GACA,GAIT4hB,EAAA/pB,UAAA6pB,QAAA,SAAQ7pB,GACN,OAAOjC,KAAKiC,UAAU6pB,QAAQ7pB,IAIhC+pB,EAAA/pB,UAAAisB,mBAAA,SAAmBC,GACjB,IAAIxI,EAAwB3lB,KAC5B,GAAG,GAAI2lB,EAAQ1jB,YAAcksB,EAAmB,OAAOxI,EAAQsG,oBACxDtG,EAAUA,EAAQuG,MACzB,OAAO,MAITF,EAAA/pB,UAAAmsB,kBAAA,WAIE,IAHA,IAAIzI,EAAiB3lB,KACjBwlB,EAAUxlB,KAAKwlB,QACf6I,EAAc7I,EAAQtL,wBACnByL,EAAQuG,OAASmC,GACtB1I,EAAUvb,OAAOub,EAAQuG,MAE3B,OAAQvG,EAAQ1jB,WACd,KAAKujB,EAAQpL,iBAAkB,OAAO1M,EAAAkH,KAAK1R,GAC3C,KAAKsiB,EAAQlL,kBAAmB,OAAO5M,EAAAkH,KAAKzR,IAC5C,KAAKqiB,EAAQjL,kBAAmB,OAAO7M,EAAAkH,KAAKxR,IAC5C,KAAKoiB,EAAQhL,kBAAmB,OAAO9M,EAAAkH,KAAKvR,IAC5C,KAAKmiB,EAAQ/K,iBACb,KAAK+K,EAAQ9K,wBAAyB,OAAOhN,EAAAkH,KAAKrR,GAClD,KAAKiiB,EAAQ7K,kBAAmB,OAAOjN,EAAAkH,KAAKpR,IAC5C,KAAKgiB,EAAQ5K,kBAAmB,OAAOlN,EAAAkH,KAAKnR,IAC5C,KAAK+hB,EAAQ3K,kBAAmB,OAAOnN,EAAAkH,KAAKlR,IAC5C,KAAK8hB,EAAQ1K,kBAAmB,OAAOpN,EAAAkH,KAAK/Q,IAC5C,KAAK2hB,EAAQzK,kBAAmB,OAAOrN,EAAAkH,KAAK9Q,IAC5C,KAAK0hB,EAAQnJ,eAAgB,OAAOjS,OAAOpK,KAAKkuB,mBAAmB1I,EAAQnJ,iBAAiB,GAC5F,QAASjS,QAAO,GAElB,OAAOsD,EAAAkH,KAAKG,MAIdhU,OAAAC,eAAIgrB,EAAA/pB,UAAA,YAAS,KAAb,WACE,IAAIqsB,EAAUtuB,KAAKusB,SACnB,GAAW,GAAP+B,EAAiC,CACnC,IAAIC,EAAWvuB,KAAKwuB,SAASxuB,MACfA,KAAKusB,SAAW+B,EAA1BC,EAAiC,EACT,EAE9B,OAAc,GAAPD,mCAIDtC,EAAA/pB,UAAAusB,SAAR,SAAiBC,EAAcC,WAezB/I,EAJJ,QAX6B,IAAA+I,MAAA,IAAyBvnB,KAWlDunB,EAAOla,IAAIxU,MAAO,OAAO,EAC7B0uB,EAAO1Z,IAAIhV,MAIX,IAeIob,EAfA0D,EAAU9e,KAAK8e,QACnB,GAAIA,MACF,IAAmB,IAAA4H,EAAA3O,EAAA+G,EAAQvB,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAE,CAAhC,IAAIqG,EAAMF,EAAA9c,MACb,GACEgd,EAAO7H,MAAQ3F,EAAY8N,OACyB,QAAnD+G,EAAkBrH,EAAQW,KAAK0P,kBAE9BhJ,IAAY8I,GACZ9I,EAAQ6I,SAASC,EAAOC,IAE1B,OAAO,oGAQb,IAAKtT,EAAgBpb,KAAKwlB,QAAQnJ,iBAAmBrc,KAAKiC,UAAU6pB,QAAQ1Q,GAAgB,CAC1F,IAAI6Q,EAAgB7hB,OAAOpK,KAAKkuB,mBAAmB9S,IAEnD,GADAhR,OAA+B,GAAxB6hB,EAAc9f,QAE6B,QAA/CwZ,EAAUsG,EAAc,GAAG0C,kBAE1BhJ,IAAY8I,GACZ9I,EAAQ6I,SAASC,EAAOC,IAE1B,OAAO,OAGJ,IAAKtT,EAAgBpb,KAAKwlB,QAAQjJ,eAAiBvc,KAAKiC,UAAU6pB,QAAQ1Q,GAAgB,CAC3F6Q,EAAgB7hB,OAAOpK,KAAKkuB,mBAAmB9S,IAEnD,GADAhR,OAA+B,GAAxB6hB,EAAc9f,QAE6B,QAA/CwZ,EAAUsG,EAAc,GAAG0C,kBAE1BhJ,IAAY8I,GACZ9I,EAAQ6I,SAASC,EAAOC,IAE1B,OAAO,OAGJ,IAAKtT,EAAgBpb,KAAKwlB,QAAQhJ,eAAiBxc,KAAKiC,UAAU6pB,QAAQ1Q,GAAgB,CAC3F6Q,EAAgB7hB,OAAOpK,KAAKkuB,mBAAmB9S,IAEnD,GADAhR,OAA+B,GAAxB6hB,EAAc9f,QAE6B,QAA/CwZ,EAAUsG,EAAc,GAAG0C,kBAE1BhJ,IAAY8I,GACZ9I,EAAQ6I,SAASC,EAAOC,IAE1B,OAAO,EACT,GACkD,QAA/C/I,EAAUsG,EAAc,GAAG0C,kBAE1BhJ,IAAY8I,GACZ9I,EAAQ6I,SAASC,EAAOC,IAE1B,OAAO,EAEX,OAAO,GAEX1C,EA9UA,CAA2BhG,GAAdtmB,EAAAssB,QAiVb,IAAA9G,EAAA,SAAAjU,GAGE,SAAAiU,EACEtkB,EACAsT,EACAK,EACAJ,UAEAlD,EAAAzQ,KAAAR,KACEY,EACAsT,EACAK,EACAJ,GACA,IACDnU,KAEL,OAjBwCuS,EAAA2S,EAAAjU,GAiBxCiU,EAjBA,CAAwClE,GAA3BthB,EAAAwlB,qBAoBb,IAAA0J,EAAA,SAAA3d,GAGE,SAAA2d,EACEpG,EACAvmB,EACAgqB,EACAC,eADA,IAAAD,MAAA,SACA,IAAAC,MAAA,MAEAjb,EAAAzQ,KAAAR,KACEwoB,EACAvmB,EACAgqB,EACAC,GACA,IACDlsB,KAEL,OAjB+BuS,EAAAqc,EAAA3d,GAiB/B2d,EAjBA,CAA+B5C,GAoB/B,SAAS1B,EAAwB9E,EAAkB5M,GACjDxO,QAAQob,EAAQhU,gBAAgBgD,IAAIoE,EAAQxG,eAC5CoT,EAAQhU,gBAAgBW,IAAIyG,EAAQxG,aAAcwG,GAIpD,SAASmH,EAAS8O,EAAgBC,GAGhC1kB,OAAOykB,EAAMrJ,UAAYsJ,EAAMtJ,SAC/Bpb,QAAQ0kB,EAAMhQ,SACd,IAAIgB,EAAiC,KACrC,OAAQ+O,EAAMpY,MACZ,KAAK3F,EAAYkN,mBACf,OAAQ8Q,EAAMrY,MACZ,KAAK3F,EAAYiW,UACf1B,EAAYyJ,EAAOD,GACnB/O,EAA0B+O,EAC1B,MAEF,KAAK/d,EAAY8V,eACViI,EAAMpJ,aACToJ,EAAMpJ,WAA6BqJ,EACnCzJ,EAAYyJ,EAAOD,GACnB/O,EAA0B+O,GAKhC,MAEF,KAAK/d,EAAYuJ,gBACjB,KAAKvJ,EAAYkW,KACf,GAAI8H,EAAMrY,MAAQ3F,EAAYiW,UAAW,CACvC1B,EAAYyJ,EAAOD,GACnB/O,EAA0B+O,EAC1B,MAEF,MAEF,KAAK/d,EAAYiW,UACf,OAAQ+H,EAAMrY,MACZ,KAAK3F,EAAYkW,KACjB,KAAKlW,EAAYuJ,gBACjB,KAAKvJ,EAAYkN,mBACfqH,EAAYwJ,EAAOC,GACnBhP,EAA0BgP,EAC1B,MAEF,KAAKhe,EAAYiW,UACf1B,EAAYyJ,EAAOD,GACnB/O,EAA0B+O,EAC1B,MAEF,KAAK/d,EAAY8V,eACViI,EAAMpJ,aACToJ,EAAMpJ,WAA6BqJ,EACnCzJ,EAAYyJ,EAAOD,GACnB/O,EAA0B+O,GAKhC,MAEF,KAAK/d,EAAYmQ,OACX6N,EAAMrY,MAAQ3F,EAAY8V,iBACvBiI,EAAMpJ,aACToJ,EAAMpJ,WAA6BqJ,EACnCzJ,EAAYyJ,EAAOD,GACnB/O,EAA0B+O,IAG9B,MAEF,KAAK/d,EAAY8V,eACf,OAAQkI,EAAMrY,MACZ,KAAK3F,EAAYmQ,OACjB,KAAKnQ,EAAYkN,mBACjB,KAAKlN,EAAYiW,UACV+H,EAAMrJ,aACTqJ,EAAMrJ,WAA6BoJ,EACnCxJ,EAAYwJ,EAAOC,GACnBhP,EAA0BgP,IAQhChP,KACkB+O,EAAMvP,GAAG9R,EAAAnL,YAAY6S,SAAW2Z,EAAMxT,aAAatK,EAAekQ,WAClE6N,EAAMxP,GAAG9R,EAAAnL,YAAY6S,SAAW4Z,EAAMzT,aAAatK,EAAekQ,UAEpF4N,EAAMrJ,QAAQnY,MACZI,EAAAhD,eAAeskB,kFACfjP,EAAOtE,eAAezQ,MAAO+U,EAAOtE,eAAevP,OAIzD,OAAO6T,EAIT,SAASuF,EAAY2J,EAAcC,WAC7BC,EAAaF,EAAIlQ,QACrB,GAAIoQ,EAAY,CACd,IAAIC,EAAcF,EAAKnQ,QAClBqQ,IAAaF,EAAKnQ,QAAUqQ,EAAc,IAAI/nB,SACnD,IAAiC,IAAAgoB,EAAArX,EAAAmX,GAAUG,EAAAD,EAAAnX,QAAAoX,EAAAnX,KAAAmX,EAAAD,EAAAnX,OAAE,CAApC,IAAAyO,EAAAtO,EAAAiX,EAAA/tB,MAAA,GAACqlB,EAAAD,EAAA,GAAYpI,EAAAoI,EAAA,GACpByI,EAAYhd,IAAIwU,EAAYrI,uGAMlC,SAAgBuI,EAAmBjmB,EAAcsT,EAAiBob,EAAkBC,GAClF,YADkF,IAAAA,OAAA,GAC1Erb,EAAOuC,MACb,KAAK3F,EAAY4U,KACf,OAAI6J,EAAiB3uB,EACdsT,EAAO9B,aAAe5E,EAAAlL,eAAiB1B,EAEhD,KAAKkQ,EAAY6N,SACf,OAAI4Q,EAAiB3uB,GACrBwJ,QAAQklB,GACDpb,EAAO9B,aAAe5E,EAAA5K,gBAAkBhC,GAEjD,QACE,OAAOimB,EAAmB3S,EAAOtT,KAAMsT,EAAOA,OAAQA,EAAOoL,GAAG9R,EAAAnL,YAAY4iB,UAAWsK,IAC/ED,EAAa9hB,EAAA9K,mBAAqB8K,EAAA7K,kBAAoB/B,GAtJvDlB,EAAAkvB,YAyIblvB,EAAAmnB,sSCz+GA,IAaY2I,EAqBAC,EAlCZjiB,EAAArN,EAAA,IAaA,SAAYqvB,GACVA,IAAA,KAAOE,qBAAmB,OAC1BF,IAAA,IAAOG,sBAAoB,MAC3BH,IAAA,IAAOI,sBAAoB,MAC3BJ,IAAA,IAAOK,wBAAsB,MAC7BL,IAAA,IAAOM,wBAAsB,MAC7BN,IAAA,KAAOO,uBAAqB,OAC5BP,IAAA,YAAcQ,4BAA0B,cACxCR,IAAA,KAAOS,qBAAmB,OAR5B,CAAYT,EAAA9vB,EAAA8vB,aAAA9vB,EAAA8vB,WAAU,KAWtB,SAAYU,GACVA,IAAA,QAAUC,2BAAyB,UACnCD,IAAA,eAAiBE,kCAAgC,iBACjDF,IAAA,mBAAqBG,sCAAoC,qBACzDH,IAAA,QAAUI,2BAAyB,UACnCJ,IAAA,WAAaK,8BAA4B,aACzCL,IAAA,QAAUM,2BAAyB,UACnCN,IAAA,kBAAoBO,qCAAmC,oBAPzD,CAAY/wB,EAAAwwB,eAAAxwB,EAAAwwB,aAAY,KAUxB,SAAYT,GACVA,IAAA,QAAUiB,sBAAoB,UAC9BjB,IAAA,MAAQkB,oBAAkB,QAC1BlB,IAAA,GAAKmB,iBAAe,KACpBnB,IAAA,KAAOoB,mBAAiB,OACxBpB,IAAA,MAAQqB,oBAAkB,QAC1BrB,IAAA,OAASsB,qBAAmB,SAC5BtB,IAAA,KAAOuB,mBAAiB,OACxBvB,IAAA,aAAewB,2BAAyB,eACxCxB,IAAA,SAAWyB,uBAAqB,WAChCzB,IAAA,SAAW0B,uBAAqB,WAChC1B,IAAA,UAAY2B,wBAAsB,YAClC3B,IAAA,UAAY4B,wBAAsB,YAClC5B,IAAA,KAAO6B,mBAAiB,OACxB7B,IAAA,MAAQ8B,oBAAkB,QAC1B9B,IAAA,MAAQ+B,oBAAkB,QAC1B/B,IAAA,MAAQgC,oBAAkB,QAC1BhC,IAAA,OAASiC,qBAAmB,SAC5BjC,IAAA,OAASkC,qBAAmB,SAC5BlC,IAAA,KAAOmC,mBAAiB,OACxBnC,IAAA,OAASoC,qBAAmB,SAC5BpC,IAAA,KAAOqC,mBAAiB,OACxBrC,IAAA,IAAMsC,kBAAgB,MACtBtC,IAAA,YAAcuC,0BAAwB,cACtCvC,IAAA,cAAgBwC,4BAA0B,gBAC1CxC,IAAA,UAAYyC,wBAAsB,YAClCzC,IAAA,WAAa0C,yBAAuB,aACpC1C,IAAA,aAAe2C,2BAAyB,eACxC3C,IAAA,YAAc4C,0BAAwB,cACtC5C,IAAA,YAAc6C,0BAAwB,cACtC7C,IAAA,YAAc8C,0BAAwB,cACtC9C,IAAA,cAAgB+C,4BAA0B,gBAC1C/C,IAAA,UAAYgD,wBAAsB,YAClChD,IAAA,WAAaiD,yBAAuB,aACpCjD,IAAA,SAAWkD,uBAAqB,WAChClD,IAAA,WAAamD,yBAAuB,aACpCnD,IAAA,WAAaoD,yBAAuB,aApCtC,CAAYpD,EAAA/vB,EAAA+vB,eAAA/vB,EAAA+vB,aAAY,KAuCxB,SAAYqD,GACVA,IAAA,OAASC,qBAAmB,SAC5BD,IAAA,OAASE,qBAAmB,SAC5BF,IAAA,UAAYG,wBAAsB,YAClCH,IAAA,OAASI,uBAAqB,SAC9BJ,IAAA,OAASK,uBAAqB,SAC9BL,IAAA,QAAUM,wBAAsB,UAChCN,IAAA,SAAWO,yBAAuB,WAClCP,IAAA,SAAWQ,yBAAuB,WAClCR,IAAA,WAAaS,2BAAyB,aACtCT,IAAA,QAAUU,wBAAsB,UAChCV,IAAA,OAASW,qBAAmB,SAC5BX,IAAA,OAASY,qBAAmB,SAC5BZ,IAAA,OAASa,qBAAmB,SAC5Bb,IAAA,UAAYc,wBAAsB,YAClCd,IAAA,OAASe,uBAAqB,SAC9Bf,IAAA,OAASgB,uBAAqB,SAC9BhB,IAAA,QAAUiB,wBAAsB,UAChCjB,IAAA,SAAWkB,yBAAuB,WAClClB,IAAA,SAAWmB,yBAAuB,WAClCnB,IAAA,WAAaoB,2BAAyB,aACtCpB,IAAA,QAAUqB,wBAAsB,UAChCrB,IAAA,OAASsB,qBAAmB,SAC5BtB,IAAA,UAAYuB,yBAAuB,YACnCvB,IAAA,UAAYwB,yBAAuB,YACnCxB,IAAA,QAAUyB,sBAAoB,UAC9BzB,IAAA,cAAgB0B,iCAA+B,gBAC/C1B,IAAA,cAAgB2B,iCAA+B,gBAC/C3B,IAAA,cAAgB4B,iCAA+B,gBAC/C5B,IAAA,cAAgB6B,iCAA+B,gBAC/C7B,IAAA,cAAgB8B,iCAA+B,gBAC/C9B,IAAA,cAAgB+B,iCAA+B,gBAC/C/B,IAAA,cAAgBgC,iCAA+B,gBAC/ChC,IAAA,cAAgBiC,iCAA+B,gBAC/CjC,IAAA,eAAiBkC,+BAA6B,iBAC9ClC,IAAA,eAAiBmC,+BAA6B,iBAC9CnC,IAAA,gBAAkBoC,mCAAiC,kBACnDpC,IAAA,gBAAkBqC,mCAAiC,kBACnDrC,IAAA,gBAAkBsC,mCAAiC,kBACnDtC,IAAA,gBAAkBuC,mCAAiC,kBACnDvC,IAAA,gBAAkBwC,mCAAiC,kBACnDxC,IAAA,gBAAkByC,mCAAiC,kBACnDzC,IAAA,gBAAkB0C,mCAAiC,kBACnD1C,IAAA,gBAAkB2C,mCAAiC,kBACnD3C,IAAA,WAAa4C,2BAAyB,aACtC5C,IAAA,UAAY6C,0BAAwB,YACpC7C,IAAA,eAAiB8C,6BAA2B,iBAC5C9C,IAAA,eAAiB+C,6BAA2B,iBAG5C/C,IAAA,cAAgBgD,0BAAwB,gBACxChD,IAAA,eAAiBiD,2BAAyB,iBAC1CjD,IAAA,cAAgBkD,0BAAwB,gBACxClD,IAAA,eAAiBmD,2BAAyB,iBAC1CnD,IAAA,eAAiBoD,2BAAyB,iBAa1CpD,IAAA,cAAgBqD,0BAAwB,gBACxCrD,IAAA,cAAgBsD,0BAAwB,gBACxCtD,IAAA,cAAgBuD,0BAAwB,gBACxCvD,IAAA,cAAgBwD,0BAAwB,gBACxCxD,IAAA,cAAgByD,0BAAwB,gBACxCzD,IAAA,cAAgB0D,0BAAwB,gBACxC1D,IAAA,UAAY2D,sBAAoB,YAChC3D,IAAA,YAAc4D,wBAAsB,cACpC5D,IAAA,gBAAkB6D,4BAA0B,kBAC5C7D,IAAA,gBAAkB8D,4BAA0B,kBAC5C9D,IAAA,YAAc+D,wBAAsB,cACpC/D,IAAA,gBAAkBgE,4BAA0B,kBAC5ChE,IAAA,gBAAkBiE,4BAA0B,kBAC5CjE,IAAA,YAAckE,wBAAsB,cACpClE,IAAA,gBAAkBmE,4BAA0B,kBAC5CnE,IAAA,gBAAkBoE,4BAA0B,kBAC5CpE,IAAA,YAAcqE,wBAAsB,cACpCrE,IAAA,gBAAkBsE,4BAA0B,kBAC5CtE,IAAA,gBAAkBuE,4BAA0B,kBAC5CvE,IAAA,YAAcwE,wBAAsB,cACpCxE,IAAA,YAAcyE,wBAAsB,cACpCzE,IAAA,aAAe0E,yBAAuB,eACtC1E,IAAA,YAAc2E,wBAAsB,cACpC3E,IAAA,YAAc4E,wBAAsB,cACpC5E,IAAA,aAAe6E,yBAAuB,eACtC7E,IAAA,4BAA8B8E,wCAAsC,8BACpE9E,IAAA,4BAA8B+E,wCAAsC,8BACpE/E,IAAA,4BAA8BgF,wCAAsC,8BACpEhF,IAAA,4BAA8BiF,wCAAsC,8BACpEjF,IAAA,2BAA6BkF,uCAAqC,6BAClElF,IAAA,2BAA6BmF,uCAAqC,6BAClEnF,IAAA,2BAA6BoF,uCAAqC,6BAClEpF,IAAA,2BAA6BqF,uCAAqC,6BAnGpE,CAAYz4B,EAAAozB,UAAApzB,EAAAozB,QAAO,KAsGnB,SAAYsF,GACVA,IAAA,OAASC,qBAAmB,SAC5BD,IAAA,OAASE,qBAAmB,SAC5BF,IAAA,OAASG,qBAAmB,SAC5BH,IAAA,OAASI,sBAAoB,SAC7BJ,IAAA,OAASK,sBAAoB,SAC7BL,IAAA,OAASM,sBAAoB,SAC7BN,IAAA,OAASO,sBAAoB,SAC7BP,IAAA,OAASQ,qBAAmB,SAC5BR,IAAA,MAAQS,oBAAkB,QAC1BT,IAAA,OAASU,qBAAmB,SAC5BV,IAAA,OAASW,qBAAmB,SAC5BX,IAAA,OAASY,sBAAoB,SAC7BZ,IAAA,OAASa,sBAAoB,SAC7Bb,IAAA,QAAUc,sBAAoB,UAC9Bd,IAAA,QAAUe,sBAAoB,UAC9Bf,IAAA,MAAQgB,oBAAkB,QAC1BhB,IAAA,MAAQiB,oBAAkB,QAC1BjB,IAAA,MAAQkB,qBAAmB,QAC3BlB,IAAA,MAAQmB,qBAAmB,QAC3BnB,IAAA,MAAQoB,qBAAmB,QAC3BpB,IAAA,MAAQqB,qBAAmB,QAC3BrB,IAAA,MAAQsB,qBAAmB,QAC3BtB,IAAA,MAAQuB,qBAAmB,QAC3BvB,IAAA,MAAQwB,qBAAmB,QAC3BxB,IAAA,MAAQyB,qBAAmB,QAC3BzB,IAAA,OAAS0B,qBAAmB,SAC5B1B,IAAA,OAAS2B,qBAAmB,SAC5B3B,IAAA,OAAS4B,qBAAmB,SAC5B5B,IAAA,OAAS6B,sBAAoB,SAC7B7B,IAAA,OAAS8B,sBAAoB,SAC7B9B,IAAA,OAAS+B,sBAAoB,SAC7B/B,IAAA,OAASgC,sBAAoB,SAC7BhC,IAAA,OAASiC,qBAAmB,SAC5BjC,IAAA,MAAQkC,oBAAkB,QAC1BlC,IAAA,OAASmC,qBAAmB,SAC5BnC,IAAA,OAASoC,qBAAmB,SAC5BpC,IAAA,OAASqC,sBAAoB,SAC7BrC,IAAA,OAASsC,sBAAoB,SAC7BtC,IAAA,QAAUuC,sBAAoB,UAC9BvC,IAAA,QAAUwC,sBAAoB,UAC9BxC,IAAA,MAAQyC,oBAAkB,QAC1BzC,IAAA,MAAQ0C,oBAAkB,QAC1B1C,IAAA,MAAQ2C,qBAAmB,QAC3B3C,IAAA,MAAQ4C,qBAAmB,QAC3B5C,IAAA,MAAQ6C,qBAAmB,QAC3B7C,IAAA,MAAQ8C,qBAAmB,QAC3B9C,IAAA,MAAQ+C,qBAAmB,QAC3B/C,IAAA,MAAQgD,qBAAmB,QAC3BhD,IAAA,MAAQiD,qBAAmB,QAC3BjD,IAAA,MAAQkD,qBAAmB,QAC3BlD,IAAA,OAASmD,uBAAqB,SAC9BnD,IAAA,OAASoD,uBAAqB,SAC9BpD,IAAA,OAASqD,uBAAqB,SAC9BrD,IAAA,OAASsD,uBAAqB,SAC9BtD,IAAA,YAAcuD,4BAA0B,cACxCvD,IAAA,OAASwD,uBAAqB,SAC9BxD,IAAA,OAASyD,uBAAqB,SAC9BzD,IAAA,MAAQ0D,sBAAoB,QAC5B1D,IAAA,MAAQ2D,sBAAoB,QAC5B3D,IAAA,MAAQ4D,sBAAoB,QAC5B5D,IAAA,MAAQ6D,sBAAoB,QAC5B7D,IAAA,MAAQ8D,sBAAoB,QAC5B9D,IAAA,MAAQ+D,sBAAoB,QAC5B/D,IAAA,OAASgE,uBAAqB,SAC9BhE,IAAA,OAASiE,uBAAqB,SAC9BjE,IAAA,OAASkE,uBAAqB,SAC9BlE,IAAA,OAASmE,uBAAqB,SAC9BnE,IAAA,YAAcoE,4BAA0B,cACxCpE,IAAA,OAASqE,uBAAqB,SAC9BrE,IAAA,OAASsE,uBAAqB,SAC9BtE,IAAA,MAAQuE,sBAAoB,QAC5BvE,IAAA,MAAQwE,sBAAoB,QAC5BxE,IAAA,MAAQyE,sBAAoB,QAC5BzE,IAAA,MAAQ0E,sBAAoB,QAC5B1E,IAAA,MAAQ2E,sBAAoB,QAC5B3E,IAAA,MAAQ4E,sBAAoB,QAG5B5E,IAAA,WAAa6E,uBAAqB,aAClC7E,IAAA,WAAa8E,uBAAqB,aAClC9E,IAAA,YAAc+E,wBAAsB,cACpC/E,IAAA,YAAcgF,wBAAsB,cACpChF,IAAA,YAAciF,wBAAsB,cACpCjF,IAAA,YAAckF,wBAAsB,cACpClF,IAAA,YAAcmF,wBAAsB,cACpCnF,IAAA,YAAcoF,wBAAsB,cACpCpF,IAAA,YAAcqF,wBAAsB,cACpCrF,IAAA,YAAcsF,wBAAsB,cACpCtF,IAAA,WAAauF,uBAAqB,aAClCvF,IAAA,WAAawF,uBAAqB,aAClCxF,IAAA,YAAcyF,wBAAsB,cACpCzF,IAAA,YAAc0F,wBAAsB,cACpC1F,IAAA,YAAc2F,wBAAsB,cACpC3F,IAAA,YAAc4F,wBAAsB,cACpC5F,IAAA,YAAc6F,wBAAsB,cACpC7F,IAAA,YAAc8F,wBAAsB,cACpC9F,IAAA,YAAc+F,wBAAsB,cACpC/F,IAAA,YAAcgG,wBAAsB,cACpChG,IAAA,WAAaiG,uBAAqB,aAClCjG,IAAA,WAAakG,uBAAqB,aAClClG,IAAA,YAAcmG,wBAAsB,cACpCnG,IAAA,YAAcoG,wBAAsB,cACpCpG,IAAA,YAAcqG,wBAAsB,cACpCrG,IAAA,YAAcsG,wBAAsB,cACpCtG,IAAA,YAAcuG,wBAAsB,cACpCvG,IAAA,YAAcwG,wBAAsB,cACpCxG,IAAA,YAAcyG,wBAAsB,cACpCzG,IAAA,YAAc0G,wBAAsB,cACpC1G,IAAA,WAAa2G,uBAAqB,aAClC3G,IAAA,WAAa4G,uBAAqB,aAClC5G,IAAA,WAAa6G,uBAAqB,aAClC7G,IAAA,WAAa8G,uBAAqB,aAClC9G,IAAA,WAAa+G,uBAAqB,aAClC/G,IAAA,WAAagH,uBAAqB,aAClChH,IAAA,WAAaiH,uBAAqB,aAClCjH,IAAA,WAAakH,uBAAqB,aAClClH,IAAA,WAAamH,uBAAqB,aAClCnH,IAAA,WAAaoH,uBAAqB,aAClCpH,IAAA,WAAaqH,uBAAqB,aAClCrH,IAAA,WAAasH,uBAAqB,aAClCtH,IAAA,UAAYuH,sBAAoB,YAChCvH,IAAA,SAAWwH,qBAAmB,WAC9BxH,IAAA,UAAYyH,sBAAoB,YAChCzH,IAAA,YAAc0H,wBAAsB,cACpC1H,IAAA,gBAAkB2H,4BAA0B,kBAC5C3H,IAAA,gBAAkB4H,4BAA0B,kBAC5C5H,IAAA,YAAc6H,wBAAsB,cACpC7H,IAAA,gBAAkB8H,4BAA0B,kBAC5C9H,IAAA,gBAAkB+H,4BAA0B,kBAC5C/H,IAAA,YAAcgI,wBAAsB,cACpChI,IAAA,YAAciI,wBAAsB,cACpCjI,IAAA,gBAAkBkI,4BAA0B,kBAC5ClI,IAAA,gBAAkBmI,4BAA0B,kBAC5CnI,IAAA,YAAcoI,wBAAsB,cACpCpI,IAAA,gBAAkBqI,4BAA0B,kBAC5CrI,IAAA,gBAAkBsI,4BAA0B,kBAC5CtI,IAAA,YAAcuI,wBAAsB,cACpCvI,IAAA,YAAcwI,wBAAsB,cACpCxI,IAAA,YAAcyI,wBAAsB,cACpCzI,IAAA,YAAc0I,wBAAsB,cACpC1I,IAAA,YAAc2I,wBAAsB,cACpC3I,IAAA,YAAc4I,wBAAsB,cACpC5I,IAAA,YAAc6I,wBAAsB,cACpC7I,IAAA,YAAc8I,wBAAsB,cACpC9I,IAAA,YAAc+I,wBAAsB,cACpC/I,IAAA,YAAcgJ,wBAAsB,cACpChJ,IAAA,YAAciJ,wBAAsB,cACpCjJ,IAAA,YAAckJ,wBAAsB,cACpClJ,IAAA,YAAcmJ,wBAAsB,cACpCnJ,IAAA,YAAcoJ,wBAAsB,cACpCpJ,IAAA,YAAcqJ,wBAAsB,cACpCrJ,IAAA,YAAcsJ,wBAAsB,cACpCtJ,IAAA,YAAcuJ,wBAAsB,cACpCvJ,IAAA,YAAcwJ,wBAAsB,cA1JtC,CAAYliC,EAAA04B,WAAA14B,EAAA04B,SAAQ,KA6JpB,SAAYyJ,GACVA,IAAA,WAAaC,uBAAqB,aAClCD,IAAA,WAAaE,uBAAqB,aAFpC,CAAYriC,EAAAmiC,SAAAniC,EAAAmiC,OAAM,KAKlB,SAAYG,GACVA,IAAA,IAAMC,yBAAuB,MAC7BD,IAAA,IAAME,yBAAuB,MAC7BF,IAAA,IAAMG,yBAAuB,MAC7BH,IAAA,GAAKI,wBAAsB,KAC3BJ,IAAA,IAAMK,yBAAuB,MAC7BL,IAAA,KAAOM,0BAAwB,OANjC,CAAY5iC,EAAAsiC,cAAAtiC,EAAAsiC,YAAW,KASvB,SAAYO,GACVA,IAAA,qBAAuBC,iCAA+B,uBACtDD,IAAA,qBAAuBE,iCAA+B,uBACtDF,IAAA,qBAAuBG,iCAA+B,uBACtDH,IAAA,qBAAuBI,iCAA+B,uBACtDJ,IAAA,oBAAsBK,gCAA8B,sBACpDL,IAAA,oBAAsBM,gCAA8B,sBACpDN,IAAA,oBAAsBO,gCAA8B,sBACpDP,IAAA,oBAAsBQ,gCAA8B,sBARtD,CAAYrjC,EAAA6iC,gBAAA7iC,EAAA6iC,cAAa,KAWzB,SAAYS,GACVA,IAAA,oBAAsBC,gCAA8B,sBACpDD,IAAA,oBAAsBE,gCAA8B,sBACpDF,IAAA,oBAAsBG,gCAA8B,sBACpDH,IAAA,oBAAsBI,gCAA8B,sBACpDJ,IAAA,oBAAsBK,gCAA8B,sBACpDL,IAAA,oBAAsBM,gCAA8B,sBANtD,CAAY5jC,EAAAsjC,gBAAAtjC,EAAAsjC,cAAa,KASzB,SAAYO,GACVA,IAAA,YAAcC,wBAAsB,cACpCD,IAAA,aAAeE,yBAAuB,eACtCF,IAAA,aAAeG,yBAAuB,eACtCH,IAAA,YAAcI,wBAAsB,cACpCJ,IAAA,aAAeK,yBAAuB,eACtCL,IAAA,aAAeM,yBAAuB,eACtCN,IAAA,YAAcO,wBAAsB,cACpCP,IAAA,aAAeQ,yBAAuB,eACtCR,IAAA,aAAeS,yBAAuB,eACtCT,IAAA,YAAcU,wBAAsB,cACpCV,IAAA,aAAeW,yBAAuB,eACtCX,IAAA,aAAeY,yBAAuB,eAZxC,CAAYzkC,EAAA6jC,cAAA7jC,EAAA6jC,YAAW,KAevB,IAAAa,EAAA,oBAAAA,KAWA,OANSA,EAAAziC,OAAP,SAAc8Q,EAAoBC,GAChC,IAAI2xB,EAAU,IAAID,EAGlB,OAFAC,EAAQ5xB,OAASA,EACjB4xB,EAAQ3xB,OAASA,EACV2xB,GAEXD,EAXA,GAAa1kC,EAAA0kC,gBAab,IAAAE,EAAA,WAyBE,SAAAA,IAwbQtkC,KAAAukC,sBAA6B,EAoO7BvkC,KAAAwkC,sBAA+B,EAmE/BxkC,KAAAykC,cAAmC,IAAIr9B,IA4IjD,OA93BSk9B,EAAA3iC,OAAP,WACE,IAAIhC,EAAS,IAAI2kC,EAGjB,OAFA3kC,EAAOmpB,IAAM4b,wBACb/kC,EAAOglC,IAAMC,OAAOC,SAASC,0BACtBnlC,GAGF2kC,EAAAS,WAAP,SAAkBtyB,GAChB,IAAIuyB,EAAOC,EAAaxyB,GACxB,IACE,IAAI9S,EAAS,IAAI2kC,EAGjB,OAFA3kC,EAAOmpB,IAAMoc,oBAAoBF,EAAMvyB,EAAOtG,QAC9CxM,EAAOglC,IAAMC,OAAOC,SAASC,0BACtBnlC,UAEPilC,OAAOn8B,KAAK08B,WAAkBH,MAQlCV,EAAAriC,UAAAmjC,gBAAA,SACExkC,EACAykC,EACAC,GAEA,IAAIC,EAAOvlC,KAAKwlC,kBAAkB5kC,GAC9BokC,EAAOS,EAAcH,GACzB,IACE,OAAOI,yBAAyB1lC,KAAK8oB,IAAKyc,EAAMF,EAAQL,EAAMM,EAAaA,EAAWn5B,OAAS,WAE/Fy4B,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAA0jC,2BAAA,SACEN,EACAC,GAEA,IAAIN,EAAOS,EAAcH,GACzB,IACE,OAAOM,oCAAoC5lC,KAAK8oB,IAAKuc,EAAQL,EAAMM,EAAaA,EAAWn5B,OAAS,WAEpGy4B,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAA4jC,mBAAA,SAAmBjlC,GACjB,IAAI2kC,EAAOvlC,KAAKwlC,kBAAkB5kC,GAClCklC,4BAA4B9lC,KAAK8oB,IAAKyc,IAKxCjB,EAAAriC,UAAAmB,IAAA,SAAI9B,GACF,IAAIykC,EAAM/lC,KAAK2kC,IAEf,OADAqB,sBAAsBD,EAAKzkC,GACpB2kC,eAAejmC,KAAK8oB,IAAKid,IAGlCzB,EAAAriC,UAAAoB,IAAA,SAAI6iC,EAAeC,QAAA,IAAAA,MAAA,GACjB,IAAIJ,EAAM/lC,KAAK2kC,IAEf,OADAyB,sBAAsBL,EAAKG,EAAUC,GAC9BF,eAAejmC,KAAK8oB,IAAKid,IAGlCzB,EAAAriC,UAAA4B,IAAA,SAAIvC,GACF,IAAIykC,EAAM/lC,KAAK2kC,IAEf,OADA0B,wBAAwBN,EAAKzkC,GACtB2kC,eAAejmC,KAAK8oB,IAAKid,IAGlCzB,EAAAriC,UAAA6B,IAAA,SAAIxC,GACF,IAAIykC,EAAM/lC,KAAK2kC,IAEf,OADA2B,wBAAwBP,EAAKzkC,GACtB2kC,eAAejmC,KAAK8oB,IAAKid,IAGlCzB,EAAAriC,UAAA8B,KAAA,SAAKwiC,GACHn8B,OAAuB,IAAhBm8B,EAAMp6B,QAEb,IADA,IAAI45B,EAAM/lC,KAAK2kC,IACNtkC,EAAI,EAAGA,EAAI,KAAMA,EAAGmmC,MAAUT,EAAM1lC,EAAGkmC,EAAMlmC,IAEtD,OADAomC,uBAAuBV,EAAKA,GACrBE,eAAejmC,KAAK8oB,IAAKid,IAKlCzB,EAAAriC,UAAAykC,MAAA,SACEC,EACAC,GAEA,OAAOC,eAAe7mC,KAAK8oB,IAAK6d,EAAIC,IAGtCtC,EAAAriC,UAAA6kC,OAAA,SACEH,EACAI,EACAC,GAEA,OAAOC,gBAAgBjnC,KAAK8oB,IAAK6d,EAAII,EAAMC,IAG7C1C,EAAAriC,UAAAilC,KAAA,SACEP,EACA/lC,EACAumC,QADA,IAAAvmC,MAAA,WACA,IAAAumC,MAAA,MAEA,IAAI5B,EAAOvlC,KAAKwlC,kBAAkB5kC,GAC9BokC,EAAOoC,EAAcD,GACzB,IACE,OAAOE,cAAcrnC,KAAK8oB,IAAK6d,EAAIpB,EAAMP,EAAMmC,EAA6BA,EAAUh7B,OAAS,WAE/Fy4B,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAAqlC,UAAA,SACE1f,EACA3I,GAEA,OAAOsoB,kBAAkBvnC,KAAK8oB,IAAKlB,EAAO3I,IAG5CqlB,EAAAriC,UAAAulC,UAAA,SACE5f,EACAtmB,GAEA,OAAOmmC,kBAAkBznC,KAAK8oB,IAAKlB,EAAOtmB,IAG5CgjC,EAAAriC,UAAAylC,WAAA,SACE9mC,EACAqe,GAEA,IAAIsmB,EAAOvlC,KAAKwlC,kBAAkB5kC,GAClC,OAAO+mC,mBAAmB3nC,KAAK8oB,IAAKyc,EAAMtmB,IAG5CqlB,EAAAriC,UAAA2lC,KAAA,SACErB,EACAsB,EACAC,EACA7oB,EACAvM,EACAq1B,GAEA,YAHA,IAAAr1B,MAAA,QACA,IAAAq1B,MAAAxB,GAEOyB,cAAchoC,KAAK8oB,IAAKyd,EAAOsB,EAAS,EAAI,EAAGn1B,EAAQq1B,EAAO9oB,EAAM6oB,IAG7ExD,EAAAriC,UAAAukC,MAAA,SACED,EACAuB,EACAxmC,EACA2d,EACAvM,EACAq1B,GAEA,QAHA,IAAAr1B,MAAA,QACA,IAAAq1B,MAAAxB,GAEItnB,EAAOuQ,EAAWyY,MAAQhpB,EAAOuQ,EAAWzoB,KAAM,MAAM,IAAIqV,MAAM,SAAW6C,GACjF,OAAOipB,eAAeloC,KAAK8oB,IAAKyd,EAAO7zB,EAAQq1B,EAAOD,EAAKxmC,EAAO2d,IAGpEqlB,EAAAriC,UAAAkmC,YAAA,SACE5B,EACAuB,EACA7oB,EACAvM,GAEA,YAFA,IAAAA,MAAA,GAEO01B,oBAAoBpoC,KAAK8oB,IAAKyd,EAAO7zB,EAAQuM,EAAM6oB,IAG5DxD,EAAAriC,UAAAomC,aAAA,SACE9B,EACAuB,EACAxmC,EACA2d,EACAvM,GAEA,YAFA,IAAAA,MAAA,GAEO41B,qBAAqBtoC,KAAK8oB,IAAKyd,EAAO7zB,EAAQo1B,EAAKxmC,EAAO2d,IAGnEqlB,EAAAriC,UAAAsmC,WAAA,SACE5B,EACAJ,EACA7zB,EACAo1B,EACAxmC,EACA2d,GAEA,OAAOupB,mBAAmBxoC,KAAK8oB,IAAK6d,EAAIJ,EAAO7zB,EAAQo1B,EAAKxmC,EAAO2d,IAGrEqlB,EAAAriC,UAAAwmC,eAAA,SACElC,EACA7zB,EACAo1B,EACAY,EACAC,EACA1pB,GAEA,OAAO2pB,uBAAuB5oC,KAAK8oB,IAAKyd,EAAO7zB,EAAQo1B,EAAKY,EAAUC,EAAa1pB,IAGrFqlB,EAAAriC,UAAA4mC,YAAA,SACEf,EACAY,EACAI,EACAC,GAEA,OAAOC,oBAAoBhpC,KAAK8oB,IAAKgf,EAAKY,EAAUI,EAASC,IAG/DzE,EAAAriC,UAAAgnC,cAAA,SACEnB,EACAoB,GAEA,OAAOC,sBAAsBnpC,KAAK8oB,IAAKgf,EAAKoB,IAK9C5E,EAAAriC,UAAAmnC,UAAA,SACExhB,EACAtmB,GAEA,OAAO+nC,kBAAkBrpC,KAAK8oB,IAAKlB,EAAOtmB,IAG5CgjC,EAAAriC,UAAAqnC,WAAA,SACE1oC,EACAU,GAEA,IAAIikC,EAAOvlC,KAAKwlC,kBAAkB5kC,GAClC,OAAO2oC,mBAAmBvpC,KAAK8oB,IAAKyc,EAAMjkC,IAG5CgjC,EAAAriC,UAAAunC,MAAA,SACEC,EACAC,EACAzqB,QAAA,IAAAA,MAAmBuQ,EAAWyY,MAE9B,IAAI1C,EAAOvlC,KAAKwlC,kBAAkBiE,GAC9BzE,EAAOoC,EAAcsC,GACzB,IACE,OAAOC,eAAe3pC,KAAK8oB,IAAKyc,EAAMP,EAAM0E,EAASv9B,OAAQ8S,WAE7D2lB,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAA2nC,GAAA,SACEH,EACAI,EACAvoC,QADA,IAAAuoC,MAAA,QACA,IAAAvoC,MAAA,GAEA,IAAIikC,EAAOvlC,KAAKwlC,kBAAkBiE,GAClC,OAAOK,eAAe9pC,KAAK8oB,IAAKyc,EAAMsE,EAAWvoC,IAGnDgjC,EAAAriC,UAAA8nC,KAAA,SACEC,GAEA,OAAOC,cAAcjqC,KAAK8oB,IAAKkhB,IAGjC1F,EAAAriC,UAAAioC,KAAA,SACET,EACAzhB,GAEA,IAAIud,EAAOvlC,KAAKwlC,kBAAkBiE,GAClC,OAAOU,cAAcnqC,KAAK8oB,IAAKyc,EAAMvd,IAGvCsc,EAAAriC,UAAAmoC,GAAA,SACEP,EACAQ,EACAC,GAEA,YAFA,IAAAA,MAAA,GAEOC,YAAYvqC,KAAK8oB,IAAK+gB,EAAWQ,EAAQC,IAGlDhG,EAAAriC,UAAAuoC,IAAA,WACE,OAAOC,aAAazqC,KAAK8oB,MAG3Bwb,EAAAriC,UAAAyoC,OAAA,SACEV,GAEA,YAFA,IAAAA,MAAA,GAEOW,gBAAgB3qC,KAAK8oB,IAAKkhB,IAGnC1F,EAAAriC,UAAA2oC,OAAA,SACEP,EACAC,EACAT,GAEA,OAAOgB,gBAAgB7qC,KAAK8oB,IAAK+gB,EAAWQ,EAAQC,IAGtDhG,EAAAriC,UAAA6oC,OAAA,SACEC,EACAC,EACAnB,EACAvoC,QAAA,IAAAA,MAAA,GAIA,IAFA,IAAI2pC,EAAWF,EAAM5+B,OACjB++B,EAAO,IAAIjkC,MAAagkC,GACnB5qC,EAAI,EAAGA,EAAI4qC,IAAY5qC,EAC9B6qC,EAAK7qC,GAAKL,KAAKwlC,kBAAkBuF,EAAM1qC,IAEzC,IAAI2kC,EAAOS,EAAcyF,GACrB3F,EAAOvlC,KAAKwlC,kBAAkBwF,GAClC,IACE,OAAOG,gBAAgBnrC,KAAK8oB,IAAKkc,EAAMiG,EAAU1F,EAAMsE,EAAWvoC,WAElEsjC,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAAzB,KAAA,SACE6sB,EACA8Z,EACAiE,GAEA,IAAI7F,EAAOvlC,KAAKwlC,kBAAkBnY,GAC9B2X,EAAOoC,EAAcD,GACzB,IACE,OAAOkE,cAAcrrC,KAAK8oB,IAAKyc,EAAMP,EAAMmC,GAAYA,EAASh7B,QAAU,EAAGi/B,WAE7ExG,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAAqpC,cAAA,SACE1jB,EACAuf,EACAoE,GAEA,IAAIhG,EAAOvlC,KAAKwlC,kBAAkB+F,GAC9BvG,EAAOoC,EAAcD,GACzB,IACE,OAAOqE,sBAAsBxrC,KAAK8oB,IAAKlB,EAAOod,EAAMmC,GAAYA,EAASh7B,QAAU,EAAGo5B,WAEtFX,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAAwpC,YAAA,WACE,OAAOC,qBAAqB1rC,KAAK8oB,MAKnCwb,EAAAriC,UAAA0pC,YAAA,SACE1c,EACAtjB,EACAigC,GAEA,OAAOC,oBAAoB7rC,KAAK8oB,IAAKmG,EAAMtjB,EAAQigC,IAGrDtH,EAAAriC,UAAA6pC,YAAA,SACE7c,EACA3tB,EACAsqC,GAEA,OAAOG,oBAAoB/rC,KAAK8oB,IAAKmG,EAAM3tB,EAAOsqC,IAKpDtH,EAAAriC,UAAA+pC,aAAA,SACErF,EACAsF,EACAC,GAEA,OAAOC,qBAAqBnsC,KAAK8oB,IAAK6d,EAAIsF,EAAKC,IAGjD5H,EAAAriC,UAAAmqC,aAAA,SACEzF,EACAsF,EACAC,EACA5qC,GAEA,OAAO+qC,qBAAqBrsC,KAAK8oB,IAAK6d,EAAIsF,EAAKC,EAAK5qC,IAGtDgjC,EAAAriC,UAAAqqC,aAAA,SACEC,EACAC,EACAC,GAEAriC,OAAsB,IAAfqiC,EAAKtgC,QACZ,IAAI64B,EAAOC,EAAawH,GACxB,IACE,OAAOC,qBAAqB1sC,KAAK8oB,IAAKyjB,EAAMC,EAAMxH,WAElDJ,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAA0qC,eAAA,SACEJ,EACAC,EACAI,GAEA,OAAOC,uBAAuB7sC,KAAK8oB,IAAKyjB,EAAMC,EAAMI,IAGtDtI,EAAAriC,UAAA6qC,WAAA,SACEnG,EACAsF,EACAc,GAEA,OAAOC,mBAAmBhtC,KAAK8oB,IAAK6d,EAAIsF,EAAKc,IAK/CzI,EAAAriC,UAAAgrC,UAAA,SACErsC,EACAqe,EACAiuB,EACA9lB,GAEA,IAAIme,EAAOvlC,KAAKwlC,kBAAkB5kC,GAClC,OAAOusC,mBAAmBntC,KAAK8oB,IAAKyc,EAAMtmB,EAAMiuB,EAAU,EAAI,EAAG9lB,IAGnEkd,EAAAriC,UAAAmrC,aAAA,SACExsC,GAEA,IAAI2kC,EAAOvlC,KAAKwlC,kBAAkB5kC,GAClCysC,sBAAsBrtC,KAAK8oB,IAAKyc,IAGlCjB,EAAAriC,UAAAqrC,YAAA,SACE1sC,EACAqe,EACAsuB,EACAvlB,GAEA,IAAIud,EAAOvlC,KAAKwlC,kBAAkB5kC,GAC9BokC,EAAOS,EAAc8H,GACzB,IACE,OAAOC,qBAAqBxtC,KAAK8oB,IAAKyc,EAAMtmB,EAAM+lB,EAAMuI,EAAWA,EAASphC,OAAS,EAAG6b,WAExF4c,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAAwrC,eAAA,SAAe7sC,GACb,IAAI2kC,EAAOvlC,KAAKwlC,kBAAkB5kC,GAClC8sC,wBAAwB1tC,KAAK8oB,IAAKyc,IAKpCjB,EAAAriC,UAAA0rC,qBAAA,SAAqBtI,EAAoBC,EAAiCtd,GACxEhoB,KAAKukC,qBAAuBn6B,QAAQpK,KAAKukC,sBACzC,IAAIqJ,EAAW5tC,KAAKwlC,kBAAkB,IAClCR,EAAOS,EAAcH,GACzB,IACE,IAAIuI,EAAUnI,yBAAyB1lC,KAAK8oB,IAAK8kB,EAAUvI,EAAQL,EAAMM,EAAaA,EAAWn5B,OAAS,GAC1G,OAAOqhC,qBAAqBxtC,KAAK8oB,IAAK8kB,EAAUC,EAAS,EAAG,EAAG7lB,WAE/D4c,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAA6rC,wBAAA,WACE9tC,KAAKukC,sBAAwBn6B,OAAOpK,KAAKukC,sBACzC,IAAIqJ,EAAW5tC,KAAKwlC,kBAAkB,IACtCkI,wBAAwB1tC,KAAK8oB,IAAK8kB,GAClC9H,4BAA4B9lC,KAAK8oB,IAAK8kB,IAGxCtJ,EAAAriC,UAAA8rC,kBAAA,SACE37B,EACA47B,GAEA,IAAIC,EAAQjuC,KAAKwlC,kBAAkBpzB,GAC/B87B,EAAQluC,KAAKwlC,kBAAkBwI,GACnC,OAAOG,2BAA2BnuC,KAAK8oB,IAAKmlB,EAAOC,IAGrD5J,EAAAriC,UAAAmsC,eAAA,SACEh8B,EACA47B,GAEA,IAAIC,EAAQjuC,KAAKwlC,kBAAkBpzB,GAC/B87B,EAAQluC,KAAKwlC,kBAAkBwI,GACnC,OAAOK,wBAAwBruC,KAAK8oB,IAAKmlB,EAAOC,IAGlD5J,EAAAriC,UAAAqsC,gBAAA,SACEl8B,EACA47B,GAEA,IAAIC,EAAQjuC,KAAKwlC,kBAAkBpzB,GAC/B87B,EAAQluC,KAAKwlC,kBAAkBwI,GACnC,OAAOO,yBAAyBvuC,KAAK8oB,IAAKmlB,EAAOC,IAGnD5J,EAAAriC,UAAAusC,gBAAA,SACEp8B,EACA47B,GAEA,IAAIC,EAAQjuC,KAAKwlC,kBAAkBpzB,GAC/B87B,EAAQluC,KAAKwlC,kBAAkBwI,GACnC,OAAOS,yBAAyBzuC,KAAK8oB,IAAKmlB,EAAOC,IAGnD5J,EAAAriC,UAAAysC,aAAA,SAAaV,GACX,IAAIzI,EAAOvlC,KAAKwlC,kBAAkBwI,GAClCW,sBAAsB3uC,KAAK8oB,IAAKyc,IAGlCjB,EAAAriC,UAAA2sC,kBAAA,SACEx8B,EACAy8B,EACAC,EACAC,GAEA,IAAId,EAAQjuC,KAAKwlC,kBAAkBpzB,GAC/B87B,EAAQluC,KAAKwlC,kBAAkBqJ,GAC/BG,EAAQhvC,KAAKwlC,kBAAkBsJ,GACnC,OAAOG,2BAA2BjvC,KAAK8oB,IAAKmlB,EAAOC,EAAOc,EAAOD,IAGnEzK,EAAAriC,UAAAitC,eAAA,SACE98B,EACAy8B,EACAC,GAEA,IAAIb,EAAQjuC,KAAKwlC,kBAAkBpzB,GAC/B87B,EAAQluC,KAAKwlC,kBAAkBqJ,GAC/BG,EAAQhvC,KAAKwlC,kBAAkBsJ,GACnC,OAAOK,wBAAwBnvC,KAAK8oB,IAAKmlB,EAAOC,EAAOc,IAGzD1K,EAAAriC,UAAAmtC,gBAAA,SACEh9B,EACAy8B,EACAC,EACAO,QAAA,IAAAA,OAAA,GAEA,IAAIpB,EAAQjuC,KAAKwlC,kBAAkBpzB,GAC/B87B,EAAQluC,KAAKwlC,kBAAkBqJ,GAC/BG,EAAQhvC,KAAKwlC,kBAAkBsJ,GACnC,OAAOQ,yBAAyBtvC,KAAK8oB,IAAKmlB,EAAOC,EAAOc,EAAOK,IAGjE/K,EAAAriC,UAAAstC,gBAAA,SACEn9B,EACAy8B,EACAC,EACAU,GAEA,IAAIvB,EAAQjuC,KAAKwlC,kBAAkBpzB,GAC/B87B,EAAQluC,KAAKwlC,kBAAkBqJ,GAC/BG,EAAQhvC,KAAKwlC,kBAAkBsJ,GACnC,OAAOW,yBAAyBzvC,KAAK8oB,IAAKmlB,EAAOC,EAAOc,EAAOQ,IAMjElL,EAAAriC,UAAAytC,UAAA,SACEC,EACAC,EACAC,EACAxiB,EACA7T,EACA61B,QADA,IAAA71B,MAAA,WACA,IAAA61B,OAAA,GAQA,IANA,IAAI9J,EAAOvlC,KAAKwlC,kBAAkBhsB,GAC9BpD,EAAIy5B,EAAS1jC,OACb2jC,EAAO,IAAI7oC,MAAamP,GACxB25B,EAAO,IAAI9oC,MAAUmP,GACrB45B,EAAO,IAAI/oC,MAAqBmP,GAChC65B,EAAO,IAAIhpC,MAAamP,GACnB/V,EAAI,EAAGA,EAAI+V,IAAK/V,EAAG,CAC1B,IAAIoS,EAASo9B,EAASxvC,GAAGoS,OACrBC,EAASm9B,EAASxvC,GAAGqS,OACzBo9B,EAAKzvC,GAAK4kC,EAAaxyB,GACvBs9B,EAAK1vC,GAAK,EACV2vC,EAAK3vC,GAAKgtB,GAAU7f,EAAApE,OAAOqM,OACvBzV,KAAKqD,IAAI6sC,QAAQx9B,GAASy9B,SAASz9B,IACnC1S,KAAKoD,IAAI8sC,QAAQx9B,IACrBu9B,EAAK5vC,GAAKoS,EAAOtG,OAEnB,IAAIikC,EAAQ3K,EAAcqK,GACtBO,EAAQpL,EAAa8K,GACrBO,EAAQ7K,EAAcuK,GACtBO,EAAQ9K,EAAcwK,GAC1B,IACEO,mBAAmBxwC,KAAK8oB,IAAK6mB,EAASC,EAASrK,EAAM6K,EAAOC,EAAOC,EAAOC,EAAOn6B,EAAGi5B,WAEpFzK,OAAOn8B,KAAK8nC,GACZ3L,OAAOn8B,KAAK6nC,GACZ1L,OAAOn8B,KAAK4nC,GACZzL,OAAOn8B,KAAK2nC,GACZ,IAAS/vC,EAAI+V,EAAI,EAAG/V,GAAK,IAAKA,EAAGukC,OAAOn8B,KAAKqnC,EAAKzvC,MAItDikC,EAAAriC,UAAAwuC,iBAAA,SACEd,EACAC,EACAc,GAIA,IAFA,IAAIzF,EAAWyF,EAAMvkC,OACjB4+B,EAAQ,IAAI9jC,MAAagkC,GACpB5qC,EAAI,EAAGA,EAAI4qC,IAAY5qC,EAC9B0qC,EAAM1qC,GAAKL,KAAKwlC,kBAAkBkL,EAAMrwC,IAE1C,IAAI2kC,EAAOS,EAAcsF,GACzB,IACE4F,0BAA0B3wC,KAAK8oB,IAAK6mB,EAASC,EAAS5K,EAAMiG,WAE5DrG,OAAOn8B,KAAKu8B,KAIhBV,EAAAriC,UAAA2uC,SAAA,SAASC,GACPC,kBAAkB9wC,KAAK8oB,IAAK+nB,IAG9BvM,EAAAriC,UAAA8uC,iBAAA,WACE,OAAOC,6BAGT1M,EAAAriC,UAAAgvC,iBAAA,SAAiBC,QAAA,IAAAA,MAAA,GACfC,0BAA0BD,IAG5B5M,EAAAriC,UAAAmvC,eAAA,WACE,OAAOC,2BAGT/M,EAAAriC,UAAAqvC,eAAA,SAAeJ,QAAA,IAAAA,MAAA,GACbK,wBAAwBL,IAG1B5M,EAAAriC,UAAAuvC,aAAA,SAAaC,QAAA,IAAAA,OAAA,GACXC,sBAAsBD,IAGxBnN,EAAAriC,UAAA0vC,YAAA,WACE,OAAOC,2BAA2B5xC,KAAK8oB,MAGzCwb,EAAAriC,UAAA4vC,YAAA,SAAYC,GACVC,2BAA2B/xC,KAAK8oB,IAAKgpB,IAGvCxN,EAAAriC,UAAA+vC,SAAA,SAASnB,QAAA,IAAAA,MAAA,GACHA,EACFoB,0BAA0BpB,EAAM7wC,KAAK8oB,KAErCopB,wBAAwBlyC,KAAK8oB,MAIjCwb,EAAAriC,UAAAkwC,UAAA,SAAUC,EAAkBvB,QAAA,IAAAA,MAAA,GAG1B,IAFA,IAAI5F,EAAWmH,EAAOjmC,OAClB4+B,EAAQ,IAAI9jC,MAAagkC,GACpB5qC,EAAI,EAAGA,EAAI4qC,IAAY5qC,EAC9B0qC,EAAM1qC,GAAKgyC,EAAYD,EAAO/xC,IAEhC,IAAI2kC,EAAOS,EAAcsF,GACzB,IACM8F,EACFyB,2BAA2BzB,EAAM7wC,KAAK8oB,IAAKkc,EAAMiG,GAEjDsH,yBAAyBvyC,KAAK8oB,IAAKkc,EAAMiG,WAG3CrG,OAAOn8B,KAAKu8B,GACZ,IAAS3kC,EAAI4qC,EAAU5qC,GAAK,IAAKA,EAAGukC,OAAOn8B,KAAKsiC,EAAM1qC,MAM1DikC,EAAAriC,UAAAuwC,qBAAA,SAAqB5L,GAEnB,IAAI6L,EAAwBzB,4BACxB0B,EAAsBrB,0BACtBsB,EAAoBC,wBACxBzB,0BAA0B,GAC1BI,wBAAwB,GACxBG,uBAAsB,GAGtB,IAAIzyB,EAAO4zB,2BAA2BjM,GAClCiK,EAAO7wC,KAAK2tC,qBAAqB1uB,EAAM,KAAM2nB,GAC7CmE,EAAQ/qC,KAAKwkC,sBAYjB,OAXKuG,IACH/qC,KAAKwkC,sBAAwBuG,EAAQtF,EAAc,CAAEzlC,KAAKwlC,kBAAkB,iBAE9E8M,2BAA2BzB,EAAM7wC,KAAK8oB,IAAKiiB,EAAO,GAClDnE,EAAOkM,yBAAyBjC,GAChC7wC,KAAK8tC,0BAGLqD,0BAA0BsB,GAC1BlB,wBAAwBmB,GACxBhB,sBAAsBiB,GACf/L,GAGTtC,EAAAriC,UAAA8wC,SAAA,WACE,OAA4C,GAArCC,wBAAwBhzC,KAAK8oB,MAGtCwb,EAAAriC,UAAAgxC,UAAA,WACEC,yBAAyBlzC,KAAK8oB,MAGhCwb,EAAAriC,UAAAkxC,SAAA,SAASC,GACP,IAAIrN,EAAM/lC,KAAK2kC,IACfv6B,OAAO06B,0BAA4B,IACnC,IAAIS,EAAO8M,EAAYe,GACnBC,EAAmB,EACnBC,EAAsB,EAC1B,IACEC,gCAAgCxN,EAAK/lC,KAAK8oB,IAAKyc,GAC/C8N,EAAYG,EAAQzN,GACpB,IAAI0N,EAAcD,EAAQzN,EAAM,GAChCuN,EAAeE,EAAQzN,EAAM,GAC7B,IAAI2N,EAAM,IAAIC,EAGd,OAFAD,EAAIE,OA2jBV,SAAoB9L,EAAY37B,GAE9B,IADA,IAAIunC,EAAM,IAAI7rC,WAAWsE,GAChB9L,EAAW,EAAGA,EAAI8L,IAAU9L,EACnCqzC,EAAIrzC,GAAKunC,KAASE,EAAMznC,GAE1B,OAAOqzC,EAhkBUG,CAAWR,EAAWI,GACnCC,EAAIhpB,UAAYopB,EAAWR,GACpBI,UAEHnO,GAAMX,OAAOn8B,KAAK88B,GAClB8N,GAAWzO,OAAOn8B,KAAK4qC,GACvBC,GAAc1O,OAAOn8B,KAAK6qC,KAIlChP,EAAAriC,UAAA8xC,OAAA,WACE,MAAM,IAAI33B,MAAM,oBAGlBkoB,EAAAriC,UAAA+xC,QAAA,WACE,MAAM,IAAI53B,MAAM,oBAKVkoB,EAAAriC,UAAAujC,kBAAR,SAA0ByO,GACxB,GAAW,MAAPA,EAAa,OAAO,EACxB,IAAIxP,EAAgBzkC,KAAKykC,cACzB,GAAIA,EAAcjwB,IAAIy/B,GAAM,OAAcxP,EAAcvjC,IAAI+yC,GAC5D,IAAInM,EAAMuK,EAAY4B,GAEtB,OADAxP,EAActyB,IAAI8hC,EAAKnM,GAChBA,GAGTxD,EAAAriC,UAAAiyC,QAAA,mBACE9pC,OAAOpK,KAAK8oB,SACZ,IAAgB,IAAApC,EAAA3O,EAAA/X,KAAKykC,cAAclnB,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAA,CAAtC,IAAI6vB,EAAG1pB,EAAA9c,MAAiCsjC,OAAOn8B,KAAKq/B,qGACzD9nC,KAAKykC,cAAgB,IAAIr9B,IACzBw9B,OAAOn8B,KAAKzI,KAAK2kC,KACjBC,OAAOn8B,KAAKzI,KAAKwkC,uBACjBxkC,KAAKwkC,sBAAwB,EAC7B2P,uBAAuBn0C,KAAK8oB,KAC5B9oB,KAAK8oB,IAAM,GAGbwb,EAAAriC,UAAAmyC,eAAA,WACE,OAAOC,EAAS1yC,OAAO3B,OAGzBskC,EAAAriC,UAAAqyC,gBAAA,SACE1N,EACA2N,EACAC,GAEA,QAHA,IAAAD,OAAA,QACA,IAAAC,MAAgBpxC,IAAIqxC,WAEhBD,EAAW,EAAG,OAAO,EAGzB,IAAIE,EACAC,EAEA,OALJH,GAAY,EAKAI,yBAAyBhO,IACnC,KAAKnX,EAAaolB,MAChB,OAAQhC,2BAA2BjM,IACjC,KAAKpX,EAAWppB,IACd,OAAOpG,KAAKoD,IAAI0xC,0BAA0BlO,IAE5C,KAAKpX,EAAWnpB,IACd,OAAOrG,KAAKqD,IACV0xC,6BAA6BnO,GAC7BoO,8BAA8BpO,IAGlC,KAAKpX,EAAW3oB,IACd,OAAO7G,KAAK6D,IAAIoxC,0BAA0BrO,IAE5C,KAAKpX,EAAW1oB,IACd,OAAO9G,KAAK8D,IAAIoxC,0BAA0BtO,IAE5C,KAAKpX,EAAWzoB,KAEd,OAAO,EAET,QACE,MAAM,IAAIqV,MAAM,0BAItB,KAAKqT,EAAa0lB,SAChB,OAAO5N,kBAAkBvnC,KAAK8oB,IAC5BssB,0BAA0BxO,GAC1BiM,2BAA2BjM,IAG/B,KAAKnX,EAAa4lB,UAChB,IAAIC,EAAaC,0BAA0B3O,GAC3C,IAAK0O,EAAY,MACjB,OAAO3N,mBAAmB3nC,KAAK8oB,IAAKwsB,EAAYzC,2BAA2BjM,IAE7E,KAAKnX,EAAa+lB,KAChB,KAAMd,EAAU10C,KAAKs0C,gBAAgBmB,oBAAoB7O,GAAO2N,EAAeC,IAC7E,MAEF,OACEkB,sBAAsB9O,GAClBwB,oBAAoBpoC,KAAK8oB,IACvB6sB,sBAAsB/O,GACtBgP,uBAAuBhP,GACvBiM,2BAA2BjM,GAC3B8N,GAEF1M,cAAchoC,KAAK8oB,IACjB6sB,sBAAsB/O,GACtBiP,sBAAsBjP,GAAQ,EAAI,EAClCgP,uBAAuBhP,GACvBkP,sBAAsBlP,GACtBiM,2BAA2BjM,GAC3B8N,GAIV,KAAKjlB,EAAasmB,MAChB,KAAMrB,EAAU10C,KAAKs0C,gBAAgB0B,uBAAuBpP,GAAO2N,EAAeC,IAChF,MAEF,OAAO3N,eAAe7mC,KAAK8oB,IAAKmtB,oBAAoBrP,GAAO8N,GAE7D,KAAKjlB,EAAaymB,OAChB,KAAMxB,EAAU10C,KAAKs0C,gBAAgB6B,uBAAuBvP,GAAO2N,EAAeC,IAChF,MAEF,KAAMG,EAAU30C,KAAKs0C,gBAAgB8B,wBAAwBxP,GAAO2N,EAAeC,IACjF,MAEF,OAAOvN,gBAAgBjnC,KAAK8oB,IAAKutB,qBAAqBzP,GAAO8N,EAASC,GAG1E,OAAO,GAKTrQ,EAAAriC,UAAAq0C,iBAAA,SAAiB11C,GACf,IAAI2kC,EAAO8M,EAAYzxC,GACvB,IACE,OAAO21C,oCAAoCv2C,KAAK8oB,IAAKyc,WAErDX,OAAOn8B,KAAK88B,KAIhBjB,EAAAriC,UAAAu0C,iBAAA,SAAiB5uB,GACf,OAAOksB,EAAW2C,oCAAoCz2C,KAAK8oB,IAAKlB,KAGlE0c,EAAAriC,UAAA2oB,iBAAA,SACEimB,EACAjK,EACA8P,EACAC,EACAC,GAEAC,kCAAkChG,EAAMjK,EAAM8P,EAAWC,EAAYC,IAnUvDtS,EAAAwS,kBAAkC,EAqUpDxS,EAp4BA,GAw4BA,SAAgByS,EAAgBnQ,GAC9B,OAAOgO,yBAAyBhO,GAz4BrBlnC,EAAA4kC,SAw4Bb5kC,EAAAq3C,kBAIAr3C,EAAAs3C,kBAAA,SAAkCpQ,GAChC,OAAOiM,2BAA2BjM,IAGpClnC,EAAAu3C,iBAAA,SAAiCrQ,GAC/B,OAAOkO,0BAA0BlO,IAGnClnC,EAAAw3C,oBAAA,SAAoCtQ,GAClC,OAAOmO,6BAA6BnO,IAGtClnC,EAAAy3C,qBAAA,SAAqCvQ,GACnC,OAAOoO,8BAA8BpO,IAGvClnC,EAAA03C,iBAAA,SAAiCxQ,GAC/B,OAAOqO,0BAA0BrO,IAGnClnC,EAAA23C,iBAAA,SAAiCzQ,GAC/B,OAAOsO,0BAA0BtO,IAGnClnC,EAAA43C,iBAAA,SAAiC1Q,GAC/B,OAAOwO,0BAA0BxO,IAGnClnC,EAAA63C,iBAAA,SAAiC3Q,GAC/B,OAAO4Q,0BAA0B5Q,IAGnClnC,EAAA+3C,iBAAA,SAAiC7Q,GAC/B,OAAO8Q,0BAA0B9Q,IAGnClnC,EAAAi4C,WAAA,SAA2B/Q,GACzB,OAAOgR,uBAAuBhR,IAGhClnC,EAAAm4C,iBAAA,SAAiCjR,GAC/B,OAAOkN,EAAWyB,0BAA0B3O,KAG9ClnC,EAAAo4C,YAAA,SAA4BlR,GAC1B,OAAOyP,qBAAqBzP,IAG9BlnC,EAAAq4C,cAAA,SAA8BnR,GAC5B,OAAOuP,uBAAuBvP,IAGhClnC,EAAAs4C,eAAA,SAA+BpR,GAC7B,OAAOwP,wBAAwBxP,IAGjClnC,EAAAu4C,WAAA,SAA2BrR,GACzB,OAAOqP,oBAAoBrP,IAG7BlnC,EAAAw4C,cAAA,SAA8BtR,GAC5B,OAAOoP,uBAAuBpP,IAGhClnC,EAAAy4C,aAAA,SAA6BvR,GAC3B,OAAO+O,sBAAsB/O,IAG/BlnC,EAAA04C,cAAA,SAA8BxR,GAC5B,OAAOgP,uBAAuBhP,IAGhClnC,EAAA24C,WAAA,SAA2BzR,GACzB,OAAO6O,oBAAoB7O,IAG7BlnC,EAAA44C,aAAA,SAA6B1R,GAC3B,OAAOiP,sBAAsBjP,IAG/BlnC,EAAA64C,cAAA,SAA8B3R,GAC5B,OAAO4R,uBAAuB5R,IAGhClnC,EAAA+4C,eAAA,SAA+B7R,GAC7B,OAAO8R,wBAAwB9R,IAGjClnC,EAAAi5C,YAAA,SAA4B/R,GAC1B,OAAOgS,qBAAqBhS,IAG9BlnC,EAAAm5C,cAAA,SAA8BjS,GAC5B,OAAOkS,uBAAuBlS,IAGhClnC,EAAAq5C,aAAA,SAA6BnS,GAC3B,OAAOkN,EAAWkF,sBAAsBpS,KAG1ClnC,EAAAu5C,mBAAA,SAAmCrS,GACjC,OAAOsS,6BAA6BtS,IAGtClnC,EAAAy5C,cAAA,SAA8BvS,EAAqBhf,GACjD,OAAOwxB,uBAAuBxS,EAAMhf,IAGtCloB,EAAA25C,eAAA,SAA+BzS,GAC7B,OAAO0S,wBAAwB1S,IAGjClnC,EAAA65C,UAAA,SAA0B3S,GACxB,OAAO4S,qBAAqB5S,IAG9BlnC,EAAA+5C,WAAA,SAA2B7S,GACzB,OAAO8S,sBAAsB9S,IAG/BlnC,EAAAi6C,YAAA,SAA4B/S,GAC1B,OAAOkN,EAAW8F,qBAAqBhT,KAGzClnC,EAAAm6C,YAAA,SAA4BjT,GAC1B,OAAOkT,qBAAqBlT,IAG9BlnC,EAAAq6C,aAAA,SAA6BnT,GAC3B,OAAOkN,EAAWkG,sBAAsBpT,KAG1ClnC,EAAAu6C,kBAAA,SAAkCrT,GAChC,OAAOsT,2BAA2BtT,IAGpClnC,EAAAy6C,cAAA,SAA8BvT,GAC5B,OAAOwT,yBAAyBxT,IAGlClnC,EAAA26C,cAAA,SAA8BzT,GAC5B,OAAO0T,0BAA0B1T,IAGnClnC,EAAA66C,mBAAA,SAAmC3T,GACjC,OAAO4T,4BAA4B5T,IAGrClnC,EAAA+6C,aAAA,SAA6B7T,GAC3B,OAAO8T,sBAAsB9T,IAG/BlnC,EAAAi7C,eAAA,SAA+B/T,GAC7B,OAAOgU,wBAAwBhU,IAGjClnC,EAAAm7C,cAAA,SAA8BjU,GAC5B,OAAOkN,EAAWgH,uBAAuBlU,KAG3ClnC,EAAAq7C,oBAAA,SAAoCnU,GAClC,OAAOoU,4BAA4BpU,IAGrClnC,EAAAu7C,eAAA,SAA+BrU,EAAqBhf,GAClD,OAAOszB,wBAAwBtU,EAAMhf,IAGvCloB,EAAAy7C,UAAA,SAA0BvU,GACxB,OAAOwU,mBAAmBxU,IAG5BlnC,EAAA27C,oBAAA,SAAoCzU,GAClC,OAAO0U,4BAA4B1U,IAGrClnC,EAAA67C,eAAA,SAA+B3U,EAAqBhf,GAClD,OAAO4zB,wBAAwB5U,EAAMhf,IAGvCloB,EAAA+7C,YAAA,SAA4B7U,GAC1B,OAAOkN,EAAW4H,4BAA4B9U,KAKhDlnC,EAAAi8C,gBAAA,SAAgC9K,GAC9B,OAAOiC,yBAAyBjC,IAGlCnxC,EAAAk8C,gBAAA,SAAgC/K,GAC9B,OAAOiD,EAAW+H,yBAAyBhL,KAG7CnxC,EAAAo8C,sBAAA,SAAsCjL,GACpC,OAAOkL,8BAA8BlL,IAGvCnxC,EAAAs8C,qBAAA,SAAqCnL,EAAmBjpB,GACtD,OAAOq0B,0BAA0BpL,EAAMjpB,IAGzCloB,EAAAw8C,sBAAA,SAAsCrL,GACpC,OAAOsL,2BAA2BtL,IAGpC,IAAAwD,EAAA,WAYE,SAAAA,KAoCF,OA3CSA,EAAA1yC,OAAP,SAAchC,GACZ,IAAIy8C,EAAW,IAAI/H,EAGnB,OAFA+H,EAASz8C,OAASA,EAClBy8C,EAAStzB,IAAMuzB,gBAAgB18C,EAAOmpB,KAC/BszB,GAKT/H,EAAApyC,UAAAq6C,SAAA,SAASzxC,GACP,OAAO0xC,kBAAkBv8C,KAAK8oB,IAAKje,IAGrCwpC,EAAApyC,UAAAu6C,UAAA,SACEC,EACAC,EACA7S,EACAh/B,QADA,IAAAg/B,MAAA,QACA,IAAAh/B,MAAA,GAEA8xC,mBAAmBF,EAAMC,EAAI7S,EAAWh/B,IAG1CwpC,EAAApyC,UAAA26C,mBAAA,SAAmB/xC,EAAqBg/B,GACtC,OAAOgT,4BAA4B78C,KAAK8oB,IAAKje,EAAMg/B,IAGrDwK,EAAApyC,UAAA66C,mBAAA,SACEL,EACAC,EACAK,EACAlyC,QAAA,IAAAA,MAAA,GAEA,IAAIm6B,EAAOS,EAAcsX,GACzB,IACEC,4BAA4BP,EAAMC,EAAI1X,EAAM+X,EAAQ5wC,OAAQtB,WAE5D+5B,OAAOn8B,KAAKu8B,KAIhBqP,EAAApyC,UAAAg7C,iBAAA,SAAiBC,EAAyBC,GACxC,OAAOC,0BAA0Bp9C,KAAK8oB,IAAKo0B,EAAOC,IAEtD9I,EAhDA,GA4FA,SAASpP,EAAaoY,GACpB,IAAKA,EAAK,OAAO,EAIjB,IAHA,IAAIC,EAAYD,EAAIlxC,OAChB27B,EAAMlD,OAAOC,SAASyY,GACtBpR,EAAMpE,EACDznC,EAAI,EAAGA,EAAIi9C,IAAaj9C,EAC/BmmC,MAAU0F,IAAOmR,EAAIh9C,IAEvB,OAAOynC,EAGT,SAASrC,EAAc8X,GACrB,IAAKA,EAAM,OAAO,EAGlB,IAFA,IAAIzV,EAAMlD,OAAOC,SAAS0Y,EAAKpxC,QAAU,GACrC+/B,EAAMpE,EACDznC,EAAI,EAAG+V,EAAImnC,EAAKpxC,OAAQ9L,EAAI+V,IAAK/V,EAAG,CAC3C,IAAIm9C,EAAMD,EAAKl9C,GAEfmmC,MAAU0F,EAAyB,IAAdsR,GACrBhX,MAAU0F,EAAM,EAAKsR,GAAS,EAAK,KACnChX,MAAU0F,EAAM,EAAKsR,GAAQ,GAAM,KACnChX,MAAU0F,EAAM,EAAKsR,IAAQ,IAC7BtR,GAAO,EAET,OAAOpE,EAGT,SAASV,EAAcqW,GACrB,OAAOhY,EAAcgY,GA2BvB,SAASpL,EAAY4B,GACnB,GAAW,MAAPA,EAAa,OAAO,EAIxB,IAHA,IAAInM,EAAMlD,OAAOC,SA1BnB,SAA0BoP,GAExB,IADA,IAAI/nC,EAAM,EACD7L,EAAI,EAAG+V,EAAI69B,EAAI9nC,OAAQ9L,EAAI+V,IAAK/V,EAAG,CAC1C,IAAIq9C,EAAIzJ,EAAI1nC,WAAWlM,GACnBq9C,GAAK,OAAUA,GAAK,OAAUr9C,EAAI,EAAI+V,IACxCsnC,EAAI,QAAgB,KAAJA,IAAc,IAA6B,KAAtBzJ,EAAI1nC,aAAalM,IAEpDq9C,GAAK,MACLxxC,EAEFA,GADSwxC,GAAK,KACP,EACEA,GAAK,MACP,EACEA,GAAK,QACP,EACEA,GAAK,SACP,EAEA,EAGX,OAAOxxC,EAKmByxC,CAAiB1J,GAAO,GAE9C/H,EAAMpE,EACDznC,EAAI,EAAG+V,EAAI69B,EAAI9nC,OAAQ9L,EAAI+V,IAAK/V,EAAG,CAC1C,IAAIq9C,EAAIzJ,EAAI1nC,WAAWlM,GACnBq9C,GAAK,OAAUA,GAAK,OAAUr9C,EAAI,EAAI+V,IACxCsnC,EAAI,QAAgB,KAAJA,IAAc,IAA6B,KAAtBzJ,EAAI1nC,aAAalM,IAEpDq9C,GAAK,IACPlX,MAAU0F,IAAOwR,GACRA,GAAK,MACdlX,MAAU0F,IAAQ,IAASwR,IAAM,GACjClX,MAAU0F,IAAQ,IAAqB,GAAZwR,IAClBA,GAAK,OACdlX,MAAU0F,IAAQ,IAASwR,IAAM,IACjClX,MAAU0F,IAAQ,IAASwR,IAAO,EAAK,IACvClX,MAAU0F,IAAQ,IAAqB,GAAZwR,IAClBA,GAAK,SACdlX,MAAU0F,IAAQ,IAASwR,IAAM,IACjClX,MAAU0F,IAAQ,IAASwR,IAAM,GAAM,IACvClX,MAAU0F,IAAQ,IAASwR,IAAO,EAAK,IACvClX,MAAU0F,IAAQ,IAAqB,GAAZwR,IAClBA,GAAK,UACdlX,MAAU0F,IAAQ,IAASwR,IAAM,IACjClX,MAAU0F,IAAQ,IAASwR,IAAM,GAAM,IACvClX,MAAU0F,IAAQ,IAASwR,IAAM,GAAM,IACvClX,MAAU0F,IAAQ,IAASwR,IAAO,EAAK,IACvClX,MAAU0F,IAAQ,IAAqB,GAAZwR,KAE3BlX,MAAU0F,IAAQ,IAASwR,IAAM,IACjClX,MAAU0F,IAAQ,IAASwR,IAAM,GAAM,IACvClX,MAAU0F,IAAQ,IAASwR,IAAM,GAAM,IACvClX,MAAU0F,IAAQ,IAASwR,IAAM,GAAM,IACvClX,MAAU0F,IAAQ,IAASwR,IAAO,EAAK,IACvClX,MAAU0F,IAAQ,IAAqB,GAAZwR,IAI/B,OADAlX,MAAU0F,EAAK,GACRpE,EAGT,SAAS0L,EAAQ1L,GACf,OACGF,KAASE,GACTF,KAASE,EAAM,IAAO,EACtBF,KAASE,EAAM,IAAM,GACrBF,KAASE,EAAM,IAAM,GAY1B,SAAgBgM,EAAWhM,GACzB,IAAKA,EAAK,OAAO,KAKjB,IAJA,IAEI8V,EACAC,EAASC,EAASC,EAASC,EAH3BC,EAAM,IAAIh3C,MAIP22C,EAAKhW,KAASE,MACR,IAAL8V,GAINC,EAAuB,GAAlBjW,KAASE,KACK,MAAT,IAAL8V,IAILE,EAAuB,GAAlBlW,KAASE,KACK,MAAT,IAAL8V,GACHA,GAAY,GAALA,IAAY,GAAOC,GAAM,EAAKC,GAErCC,EAAuB,GAAlBnW,KAASE,KACK,MAAT,IAAL8V,GACHA,GAAY,EAALA,IAAW,GAAOC,GAAM,GAAOC,GAAM,EAAKC,GAEjDC,EAAuB,GAAlBpW,KAASE,KAEZ8V,EADiB,MAAT,IAALA,IACS,EAALA,IAAW,GAAOC,GAAM,GAAOC,GAAM,GAAOC,GAAM,EAAKC,GAGlD,EAALJ,IAAW,GAAOC,GAAM,GAAOC,GAAM,GAAOC,GAAM,GAAOC,GAAM,EAD/C,GAAlBpW,KAASE,OAKpBmW,EAAIvxC,KAAKkxC,IApBPK,EAAIvxC,MAAY,GAALkxC,IAAY,EAAKC,IAL5BI,EAAIvxC,KAAKkxC,GAmCb,OAAO52C,OAAOk3C,eAAeD,GA1PlBv+C,EAAA20C,WA+Mb30C,EAAAo0C,aA+CA,IAAAH,EAAA,WAKA,OALA,gBAAaj0C,EAAAi0C,eAQbj0C,EAAAy+C,yBAAA,SAAgBA,EAAyBvX,GAEvC,GAAIiM,2BAA2BjM,IAASpX,EAAW4uB,YAAa,OAAO,EAEvE,OAAQxJ,yBAAyBhO,IAC/B,KAAKnX,EAAa2uB,YAClB,KAAK3uB,EAAa4uB,OAAQ,OAAO,EACjC,KAAK5uB,EAAa6uB,MAAO,OAA2C,GAApCpE,2BAA2BtT,GAC3D,KAAKnX,EAAa8uB,MAChB,IAAKvF,sBAAsBpS,GAAO,CAChC,IAAI4X,EAActF,6BAA6BtS,GAC/C,OAAO4X,EAAc,GAAKL,EAAyB/E,uBAAuBxS,EAAM4X,EAAc,KAIpG,OAAO,GAIT9+C,EAAA++C,SAAA,SAA4B7X,EAAqB8X,EAAS31C,GACxD,OAAQguC,EAAgBnQ,IACtB,KAAKnX,EAAa8uB,MAChB,IAAK,IAAIl+C,EAAI,EAAGyB,EAAIo3C,6BAA6BtS,GAAOvmC,EAAIyB,IAAKzB,EAC/D0I,EAAMqwC,uBAAuBxS,EAAMvmC,GAAIq+C,GAEzC,MAEF,KAAKjvB,EAAakvB,GAChB51C,EAAMuwC,wBAAwB1S,GAAO8X,GACrC31C,EAAMywC,qBAAqB5S,GAAO8X,GAClC,IAAIpU,EAAUoP,sBAAsB9S,GAChC0D,GAASvhC,EAAMuhC,EAASoU,GAC5B,MAEF,KAAKjvB,EAAamvB,KAChB71C,EAAM+wC,qBAAqBlT,GAAO8X,GAClC,MAEF,KAAKjvB,EAAa6uB,MAChB,IAAIzU,EAAYqQ,2BAA2BtT,GACvCiD,GAAW9gC,EAAM8gC,EAAW6U,GAChC,MAEF,KAAKjvB,EAAaovB,OAChB91C,EAAM+1C,4BAA4BlY,GAAO8X,GACzC,MAEF,KAAKjvB,EAAasvB,KAChB,IAAS1+C,EAAI,EAAGyB,EAAIk5C,4BAA4BpU,GAAOvmC,EAAIyB,IAAKzB,EAC9D0I,EAAMmyC,wBAAwBtU,EAAMvmC,GAAIq+C,GAE1C,MAEF,KAAKjvB,EAAauvB,aAChB,IAAS3+C,EAAI,EAAGyB,EAAIm9C,oCAAoCrY,GAAOvmC,EAAIyB,IAAKzB,EACtE0I,EAAMm2C,gCAAgCtY,EAAMvmC,GAAIq+C,GAElD,MAEF,KAAKjvB,EAAa0lB,SAChB,MAEF,KAAK1lB,EAAa0vB,SAChBp2C,EAAM2uC,0BAA0B9Q,GAAO8X,GACvC,MAEF,KAAKjvB,EAAa4lB,UAChB,MAEF,KAAK5lB,EAAa2vB,UAChBr2C,EAAMs2C,2BAA2BzY,GAAO8X,GACxC,MAEF,KAAKjvB,EAAa+lB,KAChBzsC,EAAM0sC,oBAAoB7O,GAAO8X,GACjC,MAEF,KAAKjvB,EAAa6vB,MAChBv2C,EAAM6vC,qBAAqBhS,GAAO8X,GAClC31C,EAAM+vC,uBAAuBlS,GAAO8X,GACpC,MAEF,KAAKjvB,EAAa8vB,UAChBx2C,EAAMy2C,yBAAyB5Y,GAAO8X,GACtC31C,EAAM02C,2BAA2B7Y,GAAO8X,GACxC,MAEF,KAAKjvB,EAAaiwB,cAChB32C,EAAM42C,6BAA6B/Y,GAAO8X,GAC1C31C,EAAM62C,kCAAkChZ,GAAO8X,GAC/C31C,EAAM82C,qCAAqCjZ,GAAO8X,GAClD,MAEF,KAAKjvB,EAAaqwB,WAChB/2C,EAAMg3C,0BAA0BnZ,GAAO8X,GACvC31C,EAAMi3C,+BAA+BpZ,GAAO8X,GAC5C31C,EAAMk3C,8BAA8BrZ,GAAO8X,GAC3C,MAEF,KAAKjvB,EAAaywB,aAChBn3C,EAAMo3C,4BAA4BvZ,GAAO8X,GACzC,MAEF,KAAKjvB,EAAa2wB,YAChBr3C,EAAMs3C,2BAA2BzZ,GAAO8X,GACxC,MAEF,KAAKjvB,EAAa6wB,YAChBv3C,EAAMw3C,2BAA2B3Z,GAAO8X,GACxC31C,EAAMy3C,6BAA6B5Z,GAAO8X,GAC1C,MAEF,KAAKjvB,EAAagxB,YAChB13C,EAAM23C,4BAA4B9Z,GAAO8X,GACzC31C,EAAM43C,6BAA6B/Z,GAAO8X,GAC1C,MAEF,KAAKjvB,EAAamxB,cAChB73C,EAAM83C,8BAA8Bja,GAAO8X,GAC3C31C,EAAM+3C,+BAA+Bla,GAAO8X,GAC5C31C,EAAMg4C,8BAA8Bna,GAAO8X,GAC3C,MAEF,KAAKjvB,EAAauxB,UAChBj4C,EAAMk4C,yBAAyBra,GAAO8X,GACtC31C,EAAMm4C,2BAA2Bta,GAAO8X,GACxC,MAEF,KAAKjvB,EAAa0xB,WAChBp4C,EAAMq4C,2BAA2Bxa,GAAO8X,GACxC31C,EAAMs4C,6BAA6Bza,GAAO8X,GAC1C31C,EAAMu4C,2BAA2B1a,GAAO8X,GACxC,MAEF,KAAKjvB,EAAa8xB,SAChB,MAEF,KAAK9xB,EAAa+xB,WAChBz4C,EAAM04C,2BAA2B7a,GAAO8X,GACxC31C,EAAM24C,6BAA6B9a,GAAO8X,GAC1C31C,EAAM44C,2BAA2B/a,GAAO8X,GACxC,MAEF,KAAKjvB,EAAamyB,WAChB74C,EAAM84C,2BAA2Bjb,GAAO8X,GACxC31C,EAAM+4C,4BAA4Blb,GAAO8X,GACzC31C,EAAMg5C,2BAA2Bnb,GAAO8X,GACxC,MAEF,KAAKjvB,EAAaolB,MAChB,MAEF,KAAKplB,EAAasmB,MAChBhtC,EAAMitC,uBAAuBpP,GAAO8X,GACpC,MAEF,KAAKjvB,EAAaymB,OAChBntC,EAAMotC,uBAAuBvP,GAAO8X,GACpC31C,EAAMqtC,wBAAwBxP,GAAO8X,GACrC,MAEF,KAAKjvB,EAAauyB,OAChBj5C,EAAMqxC,yBAAyBxT,GAAO8X,GACtC31C,EAAMuxC,0BAA0B1T,GAAO8X,GACvC31C,EAAMyxC,4BAA4B5T,GAAO8X,GACzC,MAEF,KAAKjvB,EAAawyB,KAChBl5C,EAAM2xC,sBAAsB9T,GAAO8X,GACnC,MAEF,KAAKjvB,EAAa4uB,OAChBt1C,EAAM6xC,wBAAwBhU,GAAO8X,GACrC,MAEF,KAAKjvB,EAAayyB,KAChB,IAAS7hD,EAAI,EAAGyB,EAAIw5C,4BAA4B1U,GAAOvmC,EAAIyB,IAAKzB,EAC9D0I,EAAMyyC,wBAAwB5U,EAAMvmC,GAAIq+C,GAE1C,MAEF,KAAKjvB,EAAa0yB,IAGlB,KAAK1yB,EAAa2uB,YAChB,MAEF,QAASh0C,QAAO,GAElB,OAAO,kaCv6DT,IAAAoD,EAAArN,EAAA,GAOAiiD,EAAAjiD,EAAA,GAYST,EAAA2iD,MAXPD,EAAAC,MAWc3iD,EAAAic,MATdymC,EAAAzmC,MAGF,IASYjF,EATZ7M,EAAA1J,EAAA,IASA,SAAYuW,GAEVA,IAAA,mBAGAA,IAAA,yBACAA,IAAA,+BACAA,IAAA,uBACAA,IAAA,iCACAA,IAAA,yBAGAA,IAAA,2BACAA,IAAA,yBACAA,IAAA,mBACAA,IAAA,eACAA,IAAA,kBACAA,IAAA,kBACAA,IAAA,kCACAA,IAAA,kBACAA,IAAA,wBACAA,IAAA,4BACAA,IAAA,sBACAA,IAAA,cACAA,IAAA,gBACAA,IAAA,kCACAA,IAAA,oCACAA,IAAA,sBACAA,IAAA,kBACAA,IAAA,gBACAA,IAAA,gBACAA,IAAA,8BACAA,IAAA,gCACAA,IAAA,8BAGAA,IAAA,kBACAA,IAAA,kBACAA,IAAA,wBACAA,IAAA,YACAA,IAAA,kBACAA,IAAA,oBACAA,IAAA,kCACAA,IAAA,gCACAA,IAAA,4BACAA,IAAA,cACAA,IAAA,YACAA,IAAA,oBACAA,IAAA,oBACAA,IAAA,oBACAA,IAAA,kBACAA,IAAA,cACAA,IAAA,wBACAA,IAAA,gBACAA,IAAA,kBAGAA,IAAA,wCACAA,IAAA,sCACAA,IAAA,gDACAA,IAAA,wCACAA,IAAA,8CACAA,IAAA,0CACAA,IAAA,0DACAA,IAAA,gDACAA,IAAA,0CACAA,IAAA,gDACAA,IAAA,sCACAA,IAAA,8CAGAA,IAAA,0BACAA,IAAA,gCACAA,IAAA,4BACAA,IAAA,sBA1EF,CAAYA,EAAAhX,EAAAgX,WAAAhX,EAAAgX,SAAQ,KA8EpBhX,EAAA4iD,oBAAA,SAAoC7rC,GAClC,OAAQA,GACN,KAAKC,EAASwM,QACd,KAAKxM,EAAS6rC,KACd,KAAK7rC,EAAS8rC,KACd,KAAK9rC,EAAS+rC,MAAO,OAAO,EAE9B,OAAO,GAIT/iD,EAAAgjD,eAAA,SAA+BjsC,GAC7B,OAAQA,GACN,KAAKC,EAASisC,WACd,KAAKjsC,EAASksC,UACd,KAAKlsC,EAASmsC,KACd,KAAKnsC,EAASosC,cACd,KAAKpsC,EAASqsC,cACd,KAAKrsC,EAASssC,eACd,KAAKtsC,EAASusC,MAAO,OAAO,EAE9B,OAAO,GAITvjD,EAAAwjD,sBAAA,SAAsCzsC,GACpC,OAAQA,GACN,KAAKC,EAASisC,WACd,KAAKjsC,EAASssC,eAAgB,OAAO,EAEvC,OAAO,GAIT,IAAA9vC,EAAA,oBAAAA,KA66BA,OAp6BSA,EAAAiwC,eAAP,SACEviD,EACAmK,GAEA,IAAIwgC,EAAW,IAAI6X,EAInB,OAHA7X,EAASxgC,MAAQA,EACjBwgC,EAASj4B,WAAa1S,EACtB2qC,EAAStzB,KAAO,KACTszB,GAGFr4B,EAAAW,qBAAP,SACEjT,EACAmK,GAEA,OAAOmI,EAAKiwC,eAAejwC,EAAKE,2BAA2BxS,EAAMmK,GAAQA,IAGpEmI,EAAAU,gBAAP,SACEhT,EACAqrB,EACAo3B,EACAt4C,GAEA,IAAIkU,EAAO,IAAIqkC,EAKf,OAJArkC,EAAKlU,MAAQA,EACbkU,EAAKre,KAAOA,EACZqe,EAAKgN,cAAgBA,EACrBhN,EAAKokC,WAAaA,EACXpkC,GAGF/L,EAAAS,mBAAP,SACE4vC,EACAnY,EACAoY,EACAH,EACAt4C,GAEA,IAAIkU,EAAO,IAAIwkC,EAMf,OALAxkC,EAAKlU,MAAQA,EACbkU,EAAKskC,WAAaA,EAClBtkC,EAAKmsB,WAAaA,EAClBnsB,EAAKukC,iBAAmBA,EACxBvkC,EAAKokC,WAAaA,EACXpkC,GAGF/L,EAAAM,kBAAP,SACEzI,GAEA,OAAOmI,EAAKU,gBACVV,EAAKW,qBAAqB,GAAI9I,GAC9B,MACA,EACAA,IAIGmI,EAAAwwC,oBAAP,SACE9iD,EACA0gB,EACAqiC,EACA54C,GAEA,IAAI64C,EAAO,IAAIC,EAKf,OAJAD,EAAK74C,MAAQA,EACb64C,EAAKhjD,KAAOA,EACZgjD,EAAKtiC,YAAcA,EACnBsiC,EAAKD,YAAcA,EACZC,GAGF1wC,EAAA4wC,gBAAP,SACEljD,EACAqe,EACAmI,EACA3Q,EACA1L,GAEA,IAAI64C,EAAO,IAAIG,EAMf,OALAH,EAAK74C,MAAQA,EACb64C,EAAKhjD,KAAOA,EACZgjD,EAAK3kC,KAAOA,EACZ2kC,EAAKx8B,YAAcA,EACnBw8B,EAAKI,cAAgBvtC,EACdmtC,GAKF1wC,EAAA+wC,gBAAP,SACErjD,EACAsjD,EACAn5C,GAEA,IAAIo5C,EAAO,IAAIC,EAKf,OAJAD,EAAKp5C,MAAQA,EACbo5C,EAAKvjD,KAAOA,EACZujD,EAAKnhC,UAAYkhC,EACjBC,EAAK31C,cAAgBoS,EAAoBhgB,GAClCujD,GAGFjxC,EAAAmxC,cAAP,SACEp4C,EACAwK,EACA1L,GAEA,IAAIu5C,EAAO,IAAIC,EAIf,OAHAD,EAAKv5C,MAAQA,EACbu5C,EAAKE,YAAc/tC,EACnB6tC,EAAKr4C,KAAOA,EACLq4C,GAKFpxC,EAAAE,2BAAP,SACExS,EACAmK,EACA05C,QAAA,IAAAA,OAAA,GAEA,IAAI7d,EAAO,IAAI8d,EAKf,OAJA9d,EAAK77B,MAAQA,EACb67B,EAAK36B,KAAOrL,EACZgmC,EAAK+d,OAAS/jD,EACdgmC,EAAK6d,SAAWA,EACT7d,GAGF1zB,EAAA0xC,gCAAP,SACE75C,GAEA,IAAI67B,EAAO,IAAI8d,EAGf,OAFA9d,EAAK77B,MAAQA,EACb67B,EAAK36B,KAAO,GACL26B,GAGF1zB,EAAA2xC,6BAAP,SACE5kC,EACAlV,GAEA,IAAI67B,EAAO,IAAIke,EAGf,OAFAle,EAAK77B,MAAQA,EACb67B,EAAKme,mBAAqB9kC,EACnB2mB,GAGF1zB,EAAA8xC,0BAAP,SACEC,EACAjb,EACAkb,EACAn6C,GAEA,IAAI67B,EAAO,IAAIue,EAKf,OAJAve,EAAK77B,MAAQA,EACb67B,EAAKqe,cAAgBA,EACrBre,EAAKoD,WAAaA,EAClBpD,EAAKse,OAASA,EACPte,GAGF1zB,EAAAkyC,uBAAP,SACEC,EACAte,EACAC,EACAj8B,GAEA,IAAI67B,EAAO,IAAI0e,EAKf,OAJA1e,EAAK77B,MAAQA,EACb67B,EAAKye,SAAWA,EAChBze,EAAKG,KAAOA,EACZH,EAAKI,MAAQA,EACNJ,GAGF1zB,EAAAqyC,qBAAP,SACEvb,EACAwb,EACAtB,EACAn5C,GAEA,IAAI67B,EAAO,IAAI6e,EAKf,OAJA7e,EAAK77B,MAAQA,EACb67B,EAAKoD,WAAaA,EAClBpD,EAAK3a,cAAgBu5B,EACrB5e,EAAK5jB,UAAYkhC,EACVtd,GAGF1zB,EAAAwyC,sBAAP,SACEnxC,GAEA,IAAIqyB,EAAO,IAAI+e,EAGf,OAFA/e,EAAK77B,MAAQwJ,EAAYxJ,MACzB67B,EAAKryB,YAAcA,EACZqyB,GAGF1zB,EAAA0yC,sBAAP,SACEC,EACA96C,GAEA,IAAI67B,EAAO,IAAIkf,EAGf,OAFAlf,EAAK77B,MAAQA,EACb67B,EAAKif,YAAcA,EACZjf,GAGF1zB,EAAA6yC,4BAAP,SACEh7C,GAEA,IAAI67B,EAAO,IAAIof,EAEf,OADApf,EAAK77B,MAAQA,EACN67B,GAGF1zB,EAAA+yC,8BAAP,SACEjc,EACApxB,EACA7N,GAEA,IAAI67B,EAAO,IAAIsf,EAIf,OAHAtf,EAAK77B,MAAQA,EACb67B,EAAKoD,WAAaA,EAClBpD,EAAKuf,kBAAoBvtC,EAClBguB,GAGF1zB,EAAAkzC,sBAAP,SACEr7C,GAEA,IAAI67B,EAAO,IAAIyf,EAEf,OADAzf,EAAK77B,MAAQA,EACN67B,GAGF1zB,EAAAozC,6BAAP,SACEhlD,EACAyJ,GAEA,IAAI67B,EAAO,IAAI2f,EAGf,OAFA3f,EAAK77B,MAAQA,EACb67B,EAAKtlC,MAAQA,EACNslC,GAGF1zB,EAAAszC,yBAAP,SACEjyC,GAEA,IAAIqyB,EAAO,IAAI6f,EAGf,OAFA7f,EAAK77B,MAAQwJ,EAAYxJ,MACzB67B,EAAKryB,YAAcA,EACZqyB,GAGF1zB,EAAAwzC,2BAAP,SACE1c,EACA2c,EACA57C,GAEA,IAAI67B,EAAO,IAAIggB,EAIf,OAHAhgB,EAAK77B,MAAQA,EACb67B,EAAKoD,WAAaA,EAClBpD,EAAK+f,OAASA,EACP/f,GAGF1zB,EAAA2zC,+BAAP,SACEvlD,EACAyJ,GAEA,IAAI67B,EAAO,IAAIkgB,EAGf,OAFAlgB,EAAK77B,MAAQA,EACb67B,EAAKtlC,MAAQA,EACNslC,GAGF1zB,EAAA6zC,oBAAP,SACE/c,EACAwb,EACAtB,EACAn5C,GAEA,IAAI67B,EAAO,IAAIogB,EAKf,OAJApgB,EAAK77B,MAAQA,EACb67B,EAAKoD,WAAaA,EAClBpD,EAAK3a,cAAgBu5B,EACrB5e,EAAK5jB,UAAYkhC,EACVtd,GAGF1zB,EAAA+zC,qBAAP,SACEl8C,GAEA,IAAI67B,EAAO,IAAIsgB,EAEf,OADAtgB,EAAK77B,MAAQA,EACN67B,GAGF1zB,EAAAi0C,8BAAP,SACEpc,EACAxtB,EACAxS,GAEA,IAAI67B,EAAO,IAAIwgB,EAIf,OAHAxgB,EAAK77B,MAAQA,EACb67B,EAAKmE,MAAQA,EACbnE,EAAKrpB,OAASA,EACPqpB,GAGF1zB,EAAAm0C,8BAAP,SACErd,EACAj/B,GAEA,IAAI67B,EAAO,IAAI0gB,EAGf,OAFA1gB,EAAK77B,MAAQA,EACb67B,EAAKoD,WAAaA,EACXpD,GAGF1zB,EAAAq0C,+BAAP,SACEvd,EACAhoC,EACA+I,GAEA,IAAI67B,EAAO,IAAI4gB,EAIf,OAHA5gB,EAAK77B,MAAQA,EACb67B,EAAKoD,WAAaA,EAClBpD,EAAK5kC,SAAWA,EACT4kC,GAGF1zB,EAAAu0C,8BAAP,SACEC,EACA10C,EACAjI,GAEA,IAAI67B,EAAO,IAAI+gB,EAIf,OAHA/gB,EAAK77B,MAAQA,EACb67B,EAAK8gB,QAAUA,EACf9gB,EAAKghB,aAAe50C,EACb4zB,GAGF1zB,EAAA20C,wBAAP,SACEhe,EACAie,EACAC,EACAh9C,GAEA,IAAI67B,EAAO,IAAIohB,EAKf,OAJAphB,EAAK77B,MAAQA,EACb67B,EAAKiD,UAAYA,EACjBjD,EAAKkhB,OAASA,EACdlhB,EAAKmhB,OAASA,EACPnhB,GAGF1zB,EAAA+0C,8BAAP,SACE3mD,EACAyJ,GAEA,IAAI67B,EAAO,IAAIshB,EAGf,OAFAthB,EAAK77B,MAAQA,EACb67B,EAAKtlC,MAAQA,EACNslC,GAGF1zB,EAAAi1C,sBAAP,SACEp9C,GAEA,IAAI67B,EAAO,IAAIwhB,EAEf,OADAxhB,EAAK77B,MAAQA,EACN67B,GAGF1zB,EAAAm1C,qBAAP,SACEt9C,GAEA,IAAI67B,EAAO,IAAI0hB,EAEf,OADA1hB,EAAK77B,MAAQA,EACN67B,GAGF1zB,EAAAq1C,qBAAP,SACEx9C,GAEA,IAAI67B,EAAO,IAAI4hB,EAEf,OADA5hB,EAAK77B,MAAQA,EACN67B,GAGF1zB,EAAAu1C,6BAAP,SACEpD,EACAqD,EACA39C,GAEA,IAAI67B,EAAO,IAAI+hB,EAIf,OAHA/hB,EAAK77B,MAAQA,EACb67B,EAAKye,SAAWA,EAChBze,EAAK8hB,QAAUA,EACR9hB,GAGF1zB,EAAA01C,4BAAP,SACEvD,EACAqD,EACA39C,GAEA,IAAI67B,EAAO,IAAIiiB,EAIf,OAHAjiB,EAAK77B,MAAQA,EACb67B,EAAKye,SAAWA,EAChBze,EAAK8hB,QAAUA,EACR9hB,GAKF1zB,EAAA41C,qBAAP,SACExyC,EACAvL,GAEA,IAAIo5C,EAAO,IAAI4E,GAGf,OAFA5E,EAAKp5C,MAAQA,EACbo5C,EAAK7tC,WAAaA,EACX6tC,GAGFjxC,EAAA81C,qBAAP,SACEvf,EACA1+B,GAEA,IAAIo5C,EAAO,IAAI8E,GAGf,OAFA9E,EAAKp5C,MAAQA,EACbo5C,EAAK1a,MAAQA,EACN0a,GAGFjxC,EAAAg2C,uBAAP,SACE51C,EACAwT,EACAxF,EACAJ,EACApC,EACAyB,EACAvN,EACAjI,GAEA,IAAIo5C,EAAO,IAAIgF,GASf,OARAhF,EAAKp5C,MAAQA,EACbo5C,EAAKnxC,MAAQA,EACbmxC,EAAKvjD,KAAO0S,EACZ6wC,EAAKr9B,eAAiBA,EACtBq9B,EAAK7iC,YAAcA,EACnB6iC,EAAKjjC,gBAAkBA,EACvBijC,EAAKrlC,QAAUA,EACfqlC,EAAK5jC,WAAaA,EACX4jC,GAGFjxC,EAAAk2C,wBAAP,SACE3f,EACA1+B,GAEA,IAAIo5C,EAAO,IAAIkF,GAGf,OAFAlF,EAAKp5C,MAAQA,EACbo5C,EAAK1a,MAAQA,EACN0a,GAGFjxC,EAAAo2C,kBAAP,SACE9yC,EACAqzB,EACA9+B,GAEA,IAAIo5C,EAAO,IAAIoF,GAIf,OAHApF,EAAKp5C,MAAQA,EACbo5C,EAAK3tC,UAAYA,EACjB2tC,EAAKta,UAAYA,EACVsa,GAGFjxC,EAAAs2C,qBAAP,SACEz+C,GAEA,IAAIo5C,EAAO,IAAIsF,GAEf,OADAtF,EAAKp5C,MAAQA,EACNo5C,GAGFjxC,EAAAw2C,sBAAP,SACE9oD,EACAke,EACAyB,EACAvN,EACAjI,GAEA,IAAIo5C,EAAO,IAAIwF,GAMf,OALAxF,EAAKp5C,MAAQA,EACbo5C,EAAKnxC,MAAQA,EACbmxC,EAAKvjD,KAAOA,EACZujD,EAAK5mC,OAASuB,EACdqlC,EAAK5jC,WAAaA,EACX4jC,GAGFjxC,EAAA02C,2BAAP,SACEhpD,EACAU,EACA0R,EACAjI,GAEA,IAAIo5C,EAAO,IAAI0F,GAKf,OAJA1F,EAAKp5C,MAAQA,EACbo5C,EAAKnxC,MAAQA,EACbmxC,EAAKvjD,KAAOA,EACZujD,EAAK7iD,MAAQA,EACN6iD,GAGFjxC,EAAA42C,sBAAP,SACEhrC,EACA0F,EACAulC,EACAh/C,GAEA,IAAIo5C,EAAO,IAAI6F,GAIf,GAHA7F,EAAKp5C,MAAQA,EACbo5C,EAAKrlC,QAAUA,EACfqlC,EAAK3/B,KAAOA,EACRA,EAAM,CACR,IAAI5Y,EAAiB/B,EAAAogD,cAAczlC,EAAKljB,OACpCkjB,EAAKljB,MAAM4oD,WAAW,KACxB/F,EAAKv4C,eAAiB/B,EAAAsgD,YACpBv+C,EACAb,EAAMY,OAAOC,iBAGVA,EAAes+C,WAAW18C,EAAA1K,kBAC7B8I,EAAiB4B,EAAA1K,eAAiB8I,GAEpCu4C,EAAKv4C,eAAiBA,GAExBu4C,EAAK9/B,aAAe+lC,GAAmBjG,EAAKv4C,qBAE5Cu4C,EAAKv4C,eAAiB,KACtBu4C,EAAK9/B,aAAe,KAGtB,OADA8/B,EAAK4F,UAAYA,EACV5F,GAGFjxC,EAAAm3C,6BAAP,SACE91C,EACAxJ,GAEA,IAAIo5C,EAAO,IAAImG,GAGf,OAFAnG,EAAK5vC,YAAcA,EACnB4vC,EAAKp5C,MAAQA,EACNo5C,GAGFjxC,EAAAq3C,4BAAP,SACE3pD,EACAotC,EACAjjC,GAEA,IAAIo5C,EAAO,IAAIqG,GAIf,OAHArG,EAAKp5C,MAAQA,EACbo5C,EAAKvjD,KAAOA,EACZujD,EAAKnW,aAAeA,EACbmW,GAGFjxC,EAAAu3C,mBAAP,SACE7pD,EACAotC,EACAjjC,GAEA,IAAI64C,EAAO,IAAI8G,GAKf,OAJA9G,EAAK74C,MAAQA,EACb64C,EAAK7qC,UAAYnY,EACZotC,IAAcA,EAAeptC,GAClCgjD,EAAKn/B,aAAeupB,EACb4V,GAGF1wC,EAAAy3C,0BAAP,SACE3gB,GAEA,IAAIma,EAAO,IAAIyG,GAGf,OAFAzG,EAAKp5C,MAAQi/B,EAAWj/B,MACxBo5C,EAAKna,WAAaA,EACXma,GAGFjxC,EAAA23C,kBAAP,SACEhhB,EACAQ,EACAC,EACAv/B,GAEA,IAAIo5C,EAAO,IAAI2G,GAKf,OAJA3G,EAAKp5C,MAAQA,EACbo5C,EAAKta,UAAYA,EACjBsa,EAAK9Z,OAASA,EACd8Z,EAAK7Z,QAAUA,EACR6Z,GAGFjxC,EAAA63C,sBAAP,SACEC,EACAxmC,EACAzZ,GAEA,IAAIo5C,EAAO,IAAI8G,GACf9G,EAAKp5C,MAAQA,EACbo5C,EAAKx/B,aAAeqmC,EACpB7G,EAAKt/B,cAAgB,KACrBs/B,EAAK3/B,KAAOA,EACZ,IAAI5Y,EAAiB/B,EAAAogD,cAAczlC,EAAKljB,OAaxC,OAZIkjB,EAAKljB,MAAM4oD,WAAW,KACxB/F,EAAKv4C,eAAiB/B,EAAAsgD,YACpBv+C,EACAb,EAAMY,OAAOC,iBAGVA,EAAes+C,WAAW18C,EAAA1K,kBAC7B8I,EAAiB4B,EAAA1K,eAAiB8I,GAEpCu4C,EAAKv4C,eAAiBA,GAExBu4C,EAAK9/B,aAAe+lC,GAAmBjG,EAAKv4C,gBACrCu4C,GAGFjxC,EAAAg4C,kCAAP,SACE53C,EACAkR,EACAzZ,GAEA,IAAIo5C,EAAO,IAAI8G,GACf9G,EAAKp5C,MAAQA,EACbo5C,EAAKx/B,aAAe,KACpBw/B,EAAKt/B,cAAgBvR,EACrB6wC,EAAK3/B,KAAOA,EACZ,IAAI5Y,EAAiB/B,EAAAogD,cAAczlC,EAAKljB,OAaxC,OAZIkjB,EAAKljB,MAAM4oD,WAAW,KACxB/F,EAAKv4C,eAAiB/B,EAAAsgD,YACpBv+C,EACAb,EAAMY,OAAOC,iBAGVA,EAAes+C,WAAW18C,EAAA1K,kBAC7B8I,EAAiB4B,EAAA1K,eAAiB8I,GAEpCu4C,EAAKv4C,eAAiBA,GAExBu4C,EAAK9/B,aAAe+lC,GAAmBjG,EAAKv4C,gBACrCu4C,GAGFjxC,EAAAi4C,wBAAP,SACEhrC,EACAvf,EACAmK,GAEA,IAAI64C,EAAO,IAAIwH,GAKf,OAJAxH,EAAK74C,MAAQA,EACb64C,EAAKzjC,YAAcA,EACdvf,IAAMA,EAAOuf,GAClByjC,EAAKhjD,KAAOA,EACLgjD,GAGF1wC,EAAAm4C,2BAAP,SACEzqD,EACAkmB,EACAxF,EACAxC,EACAyB,EACAvN,EACAjI,GAEA,IAAIo5C,EAAO,IAAImH,GAQf,OAPAnH,EAAKp5C,MAAQA,EACbo5C,EAAKnxC,MAAQA,EACbmxC,EAAKvjD,KAAOA,EACZujD,EAAKr9B,eAAiBA,EACtBq9B,EAAK7iC,YAAcA,EACnB6iC,EAAKrlC,QAAUA,EACfqlC,EAAK5jC,WAAaA,EACX4jC,GAGFjxC,EAAAq4C,uBAAP,SACE3qD,EACAqe,EACAmI,EACA7G,EACAvN,EACAjI,GAEA,IAAIo5C,EAAO,IAAIqH,GAOf,OANArH,EAAKp5C,MAAQA,EACbo5C,EAAKnxC,MAAQA,EACbmxC,EAAKvjD,KAAOA,EACZujD,EAAKllC,KAAOA,EACZklC,EAAK/8B,YAAcA,EACnB+8B,EAAK5jC,WAAaA,EACX4jC,GAGFjxC,EAAAu4C,mBAAP,SACErkC,EACAyiB,EACA6hB,EACAl1C,EACAzL,GAEA,IAAIo5C,EAAO,IAAIwH,GAMf,OALAxH,EAAKp5C,MAAQA,EACbo5C,EAAK/8B,YAAcA,EACnB+8B,EAAKta,UAAYA,EACjBsa,EAAKuH,YAAcA,EACnBvH,EAAK3tC,UAAYA,EACV2tC,GAGFjxC,EAAAQ,0BAAP,SACE9S,EACAkmB,EACA7S,EACA+T,EACAzH,EACAvN,EACAiV,EACAld,GAEA,IAAIo5C,EAAO,IAAIyH,GASf,OARAzH,EAAKp5C,MAAQA,EACbo5C,EAAKnxC,MAAQA,EACbmxC,EAAKvjD,KAAOA,EACZujD,EAAKr9B,eAAiBA,EACtBq9B,EAAKlwC,UAAYA,EACjBkwC,EAAKn8B,KAAOA,EACZm8B,EAAK5jC,WAAaA,EAClB4jC,EAAKl8B,UAAYA,EACVk8B,GAGFjxC,EAAA24C,gCAAP,SACEC,EACAC,EACAhhD,GAEA,IAAI64C,EAAO,IAAIoI,GAIf,OAHApI,EAAK74C,MAAQA,EACb64C,EAAKkI,QAAUA,EACflI,EAAKmI,UAAYA,EACVnI,GAGF1wC,EAAA+4C,wBAAP,SACErrD,EACAkmB,EACA7S,EACA+T,EACAzH,EACAvN,EACAjI,GAEA,IAAIo5C,EAAO,IAAI+H,GAQf,OAPA/H,EAAKp5C,MAAQA,EACbo5C,EAAKnxC,MAAQA,EACbmxC,EAAKvjD,KAAOA,EACZujD,EAAKr9B,eAAiBA,EACtBq9B,EAAKlwC,UAAYA,EACjBkwC,EAAKn8B,KAAOA,EACZm8B,EAAK5jC,WAAaA,EACX4jC,GAGFjxC,EAAAa,2BAAP,SACEnT,EACAke,EACAyB,EACAvN,EACAjI,GAEA,IAAIo5C,EAAO,IAAIgI,GAMf,OALAhI,EAAKp5C,MAAQA,EACbo5C,EAAKnxC,MAAQA,EACbmxC,EAAKvjD,KAAOA,EACZujD,EAAKrlC,QAAUA,EACfqlC,EAAK5jC,WAAaA,EACX4jC,GAGFjxC,EAAAk5C,sBAAP,SACE9qD,EACAyJ,GAEA,IAAIo5C,EAAO,IAAIkI,GAGf,OAFAlI,EAAKp5C,MAAQA,EACbo5C,EAAK7iD,MAAQA,EACN6iD,GAGFjxC,EAAAo5C,sBAAP,SACEziB,EACA0iB,EACAxhD,GAEA,IAAIo5C,EAAO,IAAIqI,GAIf,OAHArI,EAAKp5C,MAAQA,EACbo5C,EAAKta,UAAYA,EACjBsa,EAAKoI,MAAQA,EACNpI,GAGFjxC,EAAAu5C,iBAAP,SACEhjB,EACAnzB,EACAvL,GAEA,IAAI64C,EAAO,IAAI8I,GAIf,OAHA9I,EAAK74C,MAAQA,EACb64C,EAAKna,MAAQA,EACbma,EAAKttC,WAAaA,EACXstC,GAGF1wC,EAAAy5C,qBAAP,SACErrD,EACAyJ,GAEA,IAAIo5C,EAAO,IAAIyI,GAGf,OAFAzI,EAAKp5C,MAAQA,EACbo5C,EAAK7iD,MAAQA,EACN6iD,GAGFjxC,EAAA25C,mBAAP,SACEv2C,EACAw2C,EACAC,EACAC,EACAjiD,GAEA,IAAIo5C,EAAO,IAAI8I,GAMf,OALA9I,EAAKp5C,MAAQA,EACbo5C,EAAK7tC,WAAaA,EAClB6tC,EAAK2I,cAAgBA,EACrB3I,EAAK4I,gBAAkBA,EACvB5I,EAAK6I,kBAAoBA,EAClB7I,GAGFjxC,EAAAK,sBAAP,SACE3S,EACAkmB,EACA7K,EACAsE,EACAvN,EACAjI,GAEA,IAAIo5C,EAAO,IAAI+I,GAOf,OANA/I,EAAKp5C,MAAQA,EACbo5C,EAAKnxC,MAAQA,EACbmxC,EAAKvjD,KAAOA,EACZujD,EAAKr9B,eAAiBA,EACtBq9B,EAAKllC,KAAOhD,EACZkoC,EAAK5jC,WAAaA,EACX4jC,GAGFjxC,EAAAi6C,wBAAP,SACExoC,EACApE,EACAxV,GAEA,IAAIo5C,EAAO,IAAIiJ,GAIf,OAHAjJ,EAAKp5C,MAAQA,EACbo5C,EAAKx/B,aAAeA,EACpBw/B,EAAK5jC,WAAaA,EACX4jC,GAGFjxC,EAAAC,0BAAP,SACEvS,EACAqe,EACAmI,EACA7G,EACAvN,EACAjI,GAEA,IAAI64C,EAAO,IAAIyJ,GAOf,OANAzJ,EAAK74C,MAAQA,EACb64C,EAAK5wC,MAAQA,EACb4wC,EAAKhjD,KAAOA,EACZgjD,EAAK3kC,KAAOA,EACZ2kC,EAAKx8B,YAAcA,EACnBw8B,EAAKrjC,WAAaA,EACXqjC,GAGF1wC,EAAAo6C,oBAAP,SACEtjB,EACAj/B,GAEA,IAAIo5C,EAAO,IAAIoJ,GAGf,OAFApJ,EAAKp5C,MAAQA,EACbo5C,EAAKna,WAAaA,EACXma,GAGFjxC,EAAAs6C,qBAAP,SACE3jB,EACArzB,EACAzL,GAEA,IAAIo5C,EAAO,IAAIsJ,GAIf,OAHAtJ,EAAKp5C,MAAQA,EACbo5C,EAAKta,UAAYA,EACjBsa,EAAK3tC,UAAYA,EACV2tC,GAEXjxC,EA76BA,GAAsBxT,EAAAwT,OAi7BtB,IAAAw6C,EAAA,SAAAz8C,GAAA,SAAAy8C,mDAKA,OALuCn7C,EAAAm7C,EAAAz8C,GAKvCy8C,EALA,CAAuCx6C,GAAjBxT,EAAAguD,WAQtB,IAAAtK,EAAA,SAAAnyC,GAAA,SAAAmyC,IAAA,IAAAlyC,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASi3C,WAMlB,OAP8Bp7C,EAAA6wC,EAAAnyC,GAO9BmyC,EAPA,CAA8BlwC,GAAjBxT,EAAA0jD,WAUb,IAAAE,EAAA,SAAAryC,GAAA,SAAAqyC,IAAA,IAAApyC,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASk3C,YAMlB,OAPmCr7C,EAAA+wC,EAAAryC,GAOnCqyC,EAPA,CAAmCoK,GAAtBhuD,EAAA4jD,gBAUb,IAAAG,EAAA,SAAAxyC,GAAA,SAAAwyC,IAAA,IAAAvyC,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASm3C,eAQlB,OATsCt7C,EAAAkxC,EAAAxyC,GAStCwyC,EATA,CAAsCiK,GAAzBhuD,EAAA+jD,mBAYb,IAAAI,EAAA,SAAA5yC,GAAA,SAAA4yC,IAAA,IAAA3yC,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASo3C,gBAQlB,OATuCv7C,EAAAsxC,EAAA5yC,GASvC4yC,EATA,CAAuC3wC,GAA1BxT,EAAAmkD,oBAYb,SAAYkK,GAEVA,IAAA,qBAEAA,IAAA,uBAEAA,IAAA,eANF,CAAYruD,EAAAquD,gBAAAruD,EAAAquD,cAAa,KAUzB,IA2BYr/C,EA3BZq1C,EAAA,SAAA9yC,GAAA,SAAA8yC,IAAA,IAAA7yC,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASs3C,UAWhB98C,EAAA+8C,yBAAoD,KAEpD/8C,EAAA8B,MAAqBxF,EAAAnL,YAAY4Q,OAQnC,OAtBmCV,EAAAwxC,EAAA9yC,GAiBjC8yC,EAAA9hD,UAAAqd,GAAA,SAAGoB,GAA2B,OAAQ1gB,KAAKgT,MAAQ0N,IAASA,GAE5DqjC,EAAA9hD,UAAA2f,MAAA,SAAMlB,GAA2B,OAA8B,IAAtB1gB,KAAKgT,MAAQ0N,IAEtDqjC,EAAA9hD,UAAAkQ,IAAA,SAAIuO,GAA2B1gB,KAAKgT,OAAS0N,GAC/CqjC,EAtBA,CAAmC7wC,GA4CnC,SAAgB0N,EAAoBhgB,GAElC,GAAIA,EAAK6V,MAAQC,EAASisC,WAAY,CACpC,IAAIuL,EAAiCttD,EAAMqL,KAE3C,OADA7B,OAAO8jD,EAAQ/hD,QACP+hD,EAAQ3hD,WAAW,IACzB,QACE,GAAe,WAAX2hD,EAAsB,OAAOx/C,EAAc0G,QAC/C,MAEF,SACE,GAAe,YAAX84C,EAAuB,OAAOx/C,EAAcsW,SAChD,MAEF,SACE,GAAe,UAAXkpC,EAAqB,OAAOx/C,EAAcuS,OAC9C,MAEF,SACE,GAAe,UAAXitC,EAAqB,OAAOx/C,EAAc2T,OAC9C,MAEF,SACE,GAAe,QAAX6rC,EAAmB,OAAOx/C,EAAc4T,KAC5C,MAEF,SACE,GAAe,YAAX4rC,EAAuB,OAAOx/C,EAAcC,SAChD,MAEF,SACE,GAAe,UAAXu/C,EAAqB,OAAOx/C,EAAc4M,OAC9C,MAEF,SACE,GAAe,aAAX4yC,EAAwB,OAAOx/C,EAAc+M,UACjD,GAAe,UAAXyyC,EAAqB,OAAOx/C,EAAc6T,aAI7C,GACL3hB,EAAK6V,MAAQC,EAASssC,gBACKpiD,EAAMopC,WAAWvzB,MAAQC,EAASisC,WAC7D,CACIuL,EAA4DttD,EAAMopC,WAAY/9B,KAClF7B,OAAO8jD,EAAQ/hD,QACf,IAAIgiD,EAAqCvtD,EAAMoB,SAASiK,KAGxD,GAFA7B,OAAO+jD,EAAQhiD,QAEA,YAAX+hD,EACF,OAAQC,EAAQ5hD,WAAW,IACzB,QACE,GAAe,UAAX4hD,EAAqB,OAAOz/C,EAAcE,gBAC9C,MAEF,SACE,OAAQu/C,GACN,IAAK,SAAU,OAAOz/C,EAAcyB,gBACpC,IAAK,UAAW,OAAOzB,EAAcgC,mBAO/C,OAAOhC,EAAc0/C,OA7GV1uD,EAAAqkD,gBA2Bb,SAAYr1C,GACVA,IAAA,mBACAA,IAAA,mBACAA,IAAA,uBACAA,IAAA,qCACAA,IAAA,qCACAA,IAAA,uCACAA,IAAA,yBACAA,IAAA,mBACAA,IAAA,mBACAA,IAAA,uBACAA,IAAA,sBACAA,IAAA,gBACAA,IAAA,oBAbF,CAAYA,EAAAhP,EAAAgP,gBAAAhP,EAAAgP,cAAa,KAiBzBhP,EAAAkhB,sBAqEA,IAAAwjC,EAAA,SAAAnzC,GAAA,SAAAmzC,IAAA,IAAAlzC,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS23C,YAQlB,OATmC97C,EAAA6xC,EAAAnzC,GASnCmzC,EATA,CAAmClxC,GAAtBxT,EAAA0kD,gBAYb,SAAYkK,GAEVA,IAAA,eAEAA,IAAA,mBAEAA,IAAA,iBANF,CAAY5uD,EAAA4uD,cAAA5uD,EAAA4uD,YAAW,KAUvB,IAAA/J,EAAA,SAAAtzC,GAAA,SAAAszC,IAAA,IAAArzC,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS63C,UAMlB,OAPiCh8C,EAAAgyC,EAAAtzC,GAOjCszC,EAPA,CAAiCrxC,GAApBxT,EAAA6kD,cAYb,IAAAiK,EAAA,SAAAv9C,GAAA,SAAAu9C,mDAAgD,OAAPj8C,EAAAi8C,EAAAv9C,GAAOu9C,EAAhD,CAAyCt7C,GAAnBxT,EAAA8uD,aAGtB,IAYYprC,EAZZshC,EAAA,SAAAzzC,GAAA,SAAAyzC,IAAA,IAAAxzC,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASisC,aAQlB,OAT0CpwC,EAAAmyC,EAAAzzC,GAS1CyzC,EATA,CAA0C8J,GAA7B9uD,EAAAglD,uBAYb,SAAYthC,GACVA,IAAA,iBACAA,IAAA,qBACAA,IAAA,mBACAA,IAAA,mBACAA,IAAA,iBACAA,IAAA,mBANF,CAAYA,EAAA1jB,EAAA0jB,cAAA1jB,EAAA0jB,YAAW,KAUvB,IAAAqrC,EAAA,SAAAx9C,GAAA,SAAAw9C,IAAA,IAAAv9C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASwM,UAIlB,OALgD3Q,EAAAk8C,EAAAx9C,GAKhDw9C,EALA,CAAgDD,GAA1B9uD,EAAA+uD,oBAQtB,IAAA3J,EAAA,SAAA7zC,GAAA,SAAA6zC,IAAA,IAAA5zC,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAiS,YAAcC,EAAYsrC,QAI5B,OAL4Cn8C,EAAAuyC,EAAA7zC,GAK5C6zC,EALA,CAA4C2J,GAA/B/uD,EAAAolD,yBAQb,SAAY6J,GACVA,IAAA,mBACAA,IAAA,WACAA,IAAA,qBAHF,CAAYjvD,EAAAivD,gBAAAjvD,EAAAivD,cAAa,KAOzB,IAAAxJ,EAAA,SAAAl0C,GAAA,SAAAk0C,IAAA,IAAAj0C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASksC,YAQlB,OATyCrwC,EAAA4yC,EAAAl0C,GASzCk0C,EATA,CAAyCqJ,GAA5B9uD,EAAAylD,sBAYb,IAAAG,EAAA,SAAAr0C,GAAA,SAAAq0C,IAAA,IAAAp0C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASk4C,SAQlB,OATsCr8C,EAAA+yC,EAAAr0C,GAStCq0C,EATA,CAAsCkJ,GAAzB9uD,EAAA4lD,mBAYb,IAAAG,EAAA,SAAAx0C,GAAA,SAAAw0C,IAAA,IAAAv0C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASmsC,OA4BlB,OA7BoCtwC,EAAAkzC,EAAAx0C,GAWlClQ,OAAAC,eAAIykD,EAAAxjD,UAAA,qBAAkB,KAAtB,WACE,IACI+qB,EADAf,EAAgBjsB,KAAKisB,cAEzB,OAAIA,IAAkBe,EAAmBf,EAAc9f,QAC9Ci2C,EAAAzmC,MAAMhP,KAAKsf,EAAc,GAAGlhB,MAAOkhB,EAAce,EAAmB,GAAGjiB,OAEzE/K,KAAKgqC,WAAWj/B,uCAIzBhK,OAAAC,eAAIykD,EAAAxjD,UAAA,iBAAc,KAAlB,WACE,IAAIiiD,EAAOlkD,KAAKgjB,UACZ6rC,EAAe3K,EAAK/3C,OACxB,OAAI0iD,EACKzM,EAAAzmC,MAAMhP,KAAKu3C,EAAK,GAAGn5C,MAAOm5C,EAAK2K,EAAe,GAAG9jD,OAEnD/K,KAAKgqC,WAAWj/B,uCAE3B06C,EA7BA,CAAoC+I,GAAvB9uD,EAAA+lD,iBAgCb,IAAAE,EAAA,SAAA10C,GAAA,SAAA00C,IAAA,IAAAz0C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASmI,QAIlB,OALqCtM,EAAAozC,EAAA10C,GAKrC00C,EALA,CAAqC6I,GAAxB9uD,EAAAimD,kBAQb,IAAAG,EAAA,SAAA70C,GAAA,SAAA60C,IAAA,IAAA50C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASo4C,QAIlB,OALqCv8C,EAAAuzC,EAAA70C,GAKrC60C,EALA,CAAqC0I,GAAxB9uD,EAAAomD,kBAQb,IAAAE,EAAA,SAAA/0C,GAAA,SAAA+0C,IAAA,IAAA90C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASkM,YAChB1R,EAAAjF,KAAO,cACPiF,EAAAyzC,OAASn3C,EAAAxK,cAAcsC,cACzB,OAJ2CiN,EAAAyzC,EAAA/0C,GAI3C+0C,EAJA,CAA2CtB,GAA9BhlD,EAAAsmD,wBAOb,IAAAE,EAAA,SAAAj1C,GAAA,SAAAi1C,IAAA,IAAAh1C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASosC,gBAMlB,OAP6CvwC,EAAA2zC,EAAAj1C,GAO7Ci1C,EAPA,CAA6CsI,GAAhC9uD,EAAAwmD,0BAUb,IAAAK,EAAA,SAAAt1C,GAAA,SAAAs1C,IAAA,IAAAr1C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAiS,YAAcC,EAAY2rC,QAI5B,OAL4Cx8C,EAAAg0C,EAAAt1C,GAK5Cs1C,EALA,CAA4CkI,GAA/B/uD,EAAA6mD,yBAQb,IAAAE,EAAA,SAAAx1C,GAAA,SAAAw1C,IAAA,IAAAv1C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASiI,WAIlB,OALwCpM,EAAAk0C,EAAAx1C,GAKxCw1C,EALA,CAAwC+H,GAA3B9uD,EAAA+mD,qBAQb,IAAAG,EAAA,SAAA31C,GAAA,SAAA21C,IAAA,IAAA11C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASs4C,aAMlB,OAP0Cz8C,EAAAq0C,EAAA31C,GAO1C21C,EAPA,CAA0C4H,GAA7B9uD,EAAAknD,uBAUb,IAAAE,EAAA,SAAA71C,GAAA,SAAA61C,IAAA,IAAA51C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAiS,YAAcC,EAAY6rC,UAI5B,OAL8C18C,EAAAu0C,EAAA71C,GAK9C61C,EALA,CAA8C2H,GAAjC/uD,EAAAonD,2BAQb,IAAAE,EAAA,SAAA/1C,GAAA,SAAA+1C,IAAA,IAAA91C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASw4C,MAClB,OAFmC38C,EAAAy0C,EAAA/1C,GAEnC+1C,EAFA,CAAmCvB,GAAtB/lD,EAAAsnD,gBAKb,IAAAE,EAAA,SAAAj2C,GAAA,SAAAi2C,IAAA,IAAAh2C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS6rC,KAChBrxC,EAAAjF,KAAO,OACPiF,EAAAyzC,OAASn3C,EAAAxK,cAAciC,QACzB,OAJoCsN,EAAA20C,EAAAj2C,GAIpCi2C,EAJA,CAAoCxC,GAAvBhlD,EAAAwnD,iBAOb,IAAAE,EAAA,SAAAn2C,GAAA,SAAAm2C,IAAA,IAAAl2C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAiS,YAAcC,EAAY+rC,SAM5B,OAP6C58C,EAAA60C,EAAAn2C,GAO7Cm2C,EAPA,CAA6CqH,GAAhC/uD,EAAA0nD,0BAUb,IAAAE,EAAA,SAAAr2C,GAAA,SAAAq2C,IAAA,IAAAp2C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASqsC,gBAIlB,OAL6CxwC,EAAA+0C,EAAAr2C,GAK7Cq2C,EALA,CAA6CkH,GAAhC9uD,EAAA4nD,0BAQb,IAAAE,EAAA,SAAAv2C,GAAA,SAAAu2C,IAAA,IAAAt2C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASssC,iBAMlB,OAP8CzwC,EAAAi1C,EAAAv2C,GAO9Cu2C,EAPA,CAA8CgH,GAAjC9uD,EAAA8nD,2BAUb,IAAAG,EAAA,SAAA12C,GAAA,SAAA02C,IAAA,IAAAz2C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAiS,YAAcC,EAAYgsC,SAM5B,OAP6C78C,EAAAo1C,EAAA12C,GAO7C02C,EAPA,CAA6C8G,GAAhC/uD,EAAAioD,0BAUb,IAAAK,EAAA,SAAA/2C,GAAA,SAAA+2C,IAAA,IAAA92C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS24C,UAQlB,OATuC98C,EAAAy1C,EAAA/2C,GASvC+2C,EATA,CAAuCwG,GAA1B9uD,EAAAsoD,oBAYb,IAAAE,EAAA,SAAAj3C,GAAA,SAAAi3C,IAAA,IAAAh3C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAiS,YAAcC,EAAYC,SAI5B,OAL6C9Q,EAAA21C,EAAAj3C,GAK7Ci3C,EALA,CAA6CuG,GAAhC/uD,EAAAwoD,0BAQb,IAAAE,EAAA,SAAAn3C,GAAA,SAAAm3C,IAAA,IAAAl3C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASusC,MAChB/xC,EAAAjF,KAAO,QACPiF,EAAAyzC,OAASn3C,EAAAxK,cAAcqC,SACzB,OAJqCkN,EAAA61C,EAAAn3C,GAIrCm3C,EAJA,CAAqC1D,GAAxBhlD,EAAA0oD,kBAOb,IAAAE,EAAA,SAAAr3C,GAAA,SAAAq3C,IAAA,IAAAp3C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS44C,KAChBp+C,EAAAjF,KAAO,OACPiF,EAAAyzC,OAASn3C,EAAAxK,cAAcoC,QACzB,OAJoCmN,EAAA+1C,EAAAr3C,GAIpCq3C,EAJA,CAAoC5D,GAAvBhlD,EAAA4oD,iBAOb,IAAAE,EAAA,SAAAv3C,GAAA,SAAAu3C,IAAA,IAAAt3C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS8rC,KAChBtxC,EAAAjF,KAAO,OACPiF,EAAAyzC,OAASn3C,EAAAxK,cAAckC,QACzB,OAJoCqN,EAAAi2C,EAAAv3C,GAIpCu3C,EAJA,CAAoC9D,GAAvBhlD,EAAA8oD,iBAOb,IAAAnC,EAAA,SAAAp1C,GAAA,SAAAo1C,IAAA,IAAAn1C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS+rC,MAChBvxC,EAAAjF,KAAO,QACPiF,EAAAyzC,OAASn3C,EAAAxK,cAAcmC,SACzB,OAJqCoN,EAAA8zC,EAAAp1C,GAIrCo1C,EAJA,CAAqC3B,GAAxBhlD,EAAA2mD,kBAOb,IAAAkJ,EAAA,SAAAt+C,GAAA,SAAAs+C,mDAMA,OAN8Ch9C,EAAAg9C,EAAAt+C,GAM9Cs+C,EANA,CAA8Cf,GAAxB9uD,EAAA6vD,kBAStB,IAAA5G,EAAA,SAAA13C,GAAA,SAAA03C,IAAA,IAAAz3C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS84C,eAClB,OAF4Cj9C,EAAAo2C,EAAA13C,GAE5C03C,EAFA,CAA4C4G,GAA/B7vD,EAAAipD,yBAKb,IAAAE,EAAA,SAAA53C,GAAA,SAAA43C,IAAA,IAAA33C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS+4C,cAClB,OAF2Cl9C,EAAAs2C,EAAA53C,GAE3C43C,EAFA,CAA2C0G,GAA9B7vD,EAAAmpD,wBAOb,IAGY92C,EAHZ29C,EAAA,SAAAz+C,GAAA,SAAAy+C,mDAA+C,OAAPn9C,EAAAm9C,EAAAz+C,GAAOy+C,EAA/C,CAAwCx8C,GAAlBxT,EAAAgwD,YAGtB,SAAY39C,GAEVA,IAAA,qBAEAA,IAAA,iBAEAA,IAAA,qBANF,CAAYA,EAAArS,EAAAqS,aAAArS,EAAAqS,WAAU,KAUtB,IAAAD,EAAA,SAAAb,GAwBE,SAAAa,EAAYlG,EAAwBK,EAAcwK,GAAlD,IAAAvF,EACED,EAAAzQ,KAAAR,OAAOA,KAxBTkR,EAAAuF,KAAOC,EAASi5C,OAChBz+C,EAAAgD,OAAS,KAeThD,EAAA0+C,UAA8B,KAE9B1+C,EAAA4Z,gBAAuB,EAEvB5Z,EAAA2+C,YAAkC,KAKhC3+C,EAAK4+C,WAAar5C,EAClBvF,EAAKtF,eAAiBA,EACtB,IAAIyY,EAAe+lC,GAAmBl5C,EAAKtF,gBAC3CsF,EAAKmT,aAAeA,EACpB,IAAI0rC,EAAM1rC,EAAa2rC,YAAYxiD,EAAAlL,uBACnC4O,EAAK++C,WAAaF,GAAO,EAAI1rC,EAAa5X,UAAUsjD,EAAM,GAAK1rC,EAC/DnT,EAAKoF,WAAa,IAAIrP,MACtBiK,EAAKnG,MAAQ,IAAIq3C,EAAAzmC,MAAMzK,EAAM,EAAGjF,EAAKE,QACrC+E,EAAKjF,KAAOA,IAOhB,OAzC4BsG,EAAAT,EAAAb,GAsC1BlQ,OAAAC,eAAI8Q,EAAA7P,UAAA,UAAO,KAAX,WAAsB,OAAOjC,KAAK8vD,YAAc/9C,EAAWm+C,uCAE3DnvD,OAAAC,eAAI8Q,EAAA7P,UAAA,YAAS,KAAb,WAAwB,OAAOjC,KAAK8vD,YAAc/9C,EAAWC,yCAC/DF,EAzCA,CAA4BoB,GAAfxT,EAAAoS,SA4Cb,IAAAq+C,GAAA,SAAAl/C,GAAA,SAAAk/C,IAAA,IAAAj/C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YAIEkR,EAAAqP,WAAqC,KAErCrP,EAAA8B,MAAqBxF,EAAAnL,YAAY4Q,OAQnC,OAdmDV,EAAA49C,EAAAl/C,GASjDk/C,EAAAluD,UAAAqd,GAAA,SAAGoB,GAA2B,OAAQ1gB,KAAKgT,MAAQ0N,IAASA,GAE5DyvC,EAAAluD,UAAA2f,MAAA,SAAMlB,GAA2B,OAA8B,IAAtB1gB,KAAKgT,MAAQ0N,IAEtDyvC,EAAAluD,UAAAkQ,IAAA,SAAIuO,GAA2B1gB,KAAKgT,OAAS0N,GAC/CyvC,EAdA,CAAmDT,GAA7BhwD,EAAAywD,wBAiBtB,IAAAnE,GAAA,SAAA/6C,GAAA,SAAA+6C,IAAA,IAAA96C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASuL,4BAMlB,OAP+C1P,EAAAy5C,EAAA/6C,GAO/C+6C,EAPA,CAA+CmE,IAAlCzwD,EAAAssD,6BAUb,IAAAoE,GAAA,SAAAn/C,GAAA,SAAAm/C,mDAMA,OAN+D79C,EAAA69C,EAAAn/C,GAM/Dm/C,EANA,CAA+DD,IAAzCzwD,EAAA0wD,oCAStB,IAAArH,GAAA,SAAA93C,GAAA,SAAA83C,IAAA,IAAA73C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS25C,QAIlB,OALoC99C,EAAAw2C,EAAA93C,GAKpC83C,EALA,CAAoC2G,GAAvBhwD,EAAAqpD,kBAQb,IAAAE,GAAA,SAAAh4C,GAAA,SAAAg4C,IAAA,IAAA/3C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS45C,QAIlB,OALoC/9C,EAAA02C,EAAAh4C,GAKpCg4C,EALA,CAAoCyG,GAAvBhwD,EAAAupD,kBAQb,IAAAE,GAAA,SAAAl4C,GAAA,SAAAk4C,IAAA,IAAAj4C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASQ,mBAelB,OAhBsC3E,EAAA42C,EAAAl4C,GAYpClQ,OAAAC,eAAImoD,EAAAlnD,UAAA,YAAS,KAAb,WACE,IAAI6kB,EAAiB9mB,KAAK8mB,eAC1B,OAAyB,MAAlBA,GAA0BA,EAAe3a,OAAS,mCAE7Dg9C,EAhBA,CAAsCgH,IAAzBzwD,EAAAypD,oBAmBb,IAAAE,GAAA,SAAAp4C,GAAA,SAAAo4C,IAAA,IAAAn4C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS65C,WAIlB,OALuCh+C,EAAA82C,EAAAp4C,GAKvCo4C,EALA,CAAuCqG,GAA1BhwD,EAAA2pD,qBAQb,IAAAE,GAAA,SAAAt4C,GAAA,SAAAs4C,IAAA,IAAAr4C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS85C,KAMlB,OAPiCj+C,EAAAg3C,EAAAt4C,GAOjCs4C,EAPA,CAAiCmG,GAApBhwD,EAAA6pD,eAUb,IAAAE,GAAA,SAAAx4C,GAAA,SAAAw4C,IAAA,IAAAv4C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASzT,QAClB,OAFoCsP,EAAAk3C,EAAAx4C,GAEpCw4C,EAFA,CAAoCiG,GAAvBhwD,EAAA+pD,kBAKb,IAAAE,GAAA,SAAA14C,GAAA,SAAA04C,IAAA,IAAAz4C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASU,kBAIlB,OALqC7E,EAAAo3C,EAAA14C,GAKrC04C,EALA,CAAqCwG,IAAxBzwD,EAAAiqD,mBAQb,IAAAE,GAAA,SAAA54C,GAAA,SAAA44C,IAAA,IAAA34C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS+5C,uBAKlB,OAN0Cl+C,EAAAs3C,EAAA54C,GAM1C44C,EANA,CAA0CuG,IAA7B1wD,EAAAmqD,wBASb,IAAAW,GAAA,SAAAv5C,GAAA,SAAAu5C,IAAA,IAAAt5C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASg6C,eAMlB,OAP2Cn+C,EAAAi4C,EAAAv5C,GAO3Cu5C,EAPA,CAA2Ct3C,GAA9BxT,EAAA8qD,yBAUb,IAAAE,GAAA,SAAAz5C,GAAA,SAAAy5C,IAAA,IAAAx5C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASi6C,eAMlB,OAPkCp+C,EAAAm4C,EAAAz5C,GAOlCy5C,EAPA,CAAkCx3C,GAArBxT,EAAAgrD,gBAUb,IAAAV,GAAA,SAAA/4C,GAAA,SAAA+4C,IAAA,IAAA94C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASxB,SAYlB,OAbqC3C,EAAAy3C,EAAA/4C,GAarC+4C,EAbA,CAAqC0F,GAAxBhwD,EAAAsqD,mBAgBb,IAAAM,GAAA,SAAAr5C,GAAA,SAAAq5C,IAAA,IAAAp5C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASE,gBAIlB,OAL4CrE,EAAA+3C,EAAAr5C,GAK5Cq5C,EALA,CAA4CoF,GAA/BhwD,EAAA4qD,0BAQb,IAAAM,GAAA,SAAA35C,GAAA,SAAA25C,IAAA,IAAA15C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASk6C,aAIlB,OALyCr+C,EAAAq4C,EAAA35C,GAKzC25C,EALA,CAAyC8E,GAA5BhwD,EAAAkrD,uBAQb,IAAAY,GAAA,SAAAv6C,GAAA,SAAAu6C,IAAA,IAAAt6C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS+K,iBAGhBvQ,EAAAka,gBAAuB,IACzB,OALsC7Y,EAAAi5C,EAAAv6C,GAKtCu6C,EALA,CAAsC4E,IAAzB1wD,EAAA8rD,oBAQb,IAAAG,GAAA,SAAA16C,GAAA,SAAA06C,IAAA,IAAAz6C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASm6C,MAalB,OAdkCt+C,EAAAo5C,EAAA16C,GAclC06C,EAdA,CAAkC+D,GAArBhwD,EAAAisD,gBAiBb,SAAkBmF,GAEhBA,IAAA,eAEAA,IAAA,6CAEAA,IAAA,+BANF,CAAkBpxD,EAAAoxD,YAAApxD,EAAAoxD,UAAS,KAU3B,IAAAlF,GAAA,SAAA36C,GAAA,SAAA26C,IAAA,IAAA16C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASY,sBA6BlB,OA9ByC/E,EAAAq5C,EAAA36C,GAYvClQ,OAAAC,eAAI4qD,EAAA3pD,UAAA,YAAS,KAAb,WACE,IAAI6kB,EAAiB9mB,KAAK8mB,eAC1B,OAAyB,MAAlBA,GAA0BA,EAAe3a,OAAS,mCAI3Dy/C,EAAA3pD,UAAA8uD,MAAA,WACE,OAAO79C,EAAKQ,0BACV1T,KAAKY,KACLZ,KAAK8mB,eACL9mB,KAAKiU,UACLjU,KAAKgoB,KACLhoB,KAAKugB,WACLvgB,KAAKgT,MACLhT,KAAKioB,UACLjoB,KAAK+K,QAGX6gD,EA9BA,CAAyCuE,IAA5BzwD,EAAAksD,uBAiCb,IAAAd,GAAA,SAAA75C,GAAA,SAAA65C,IAAA,IAAA55C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASs6C,KAQlB,OATiCz+C,EAAAu4C,EAAA75C,GASjC65C,EATA,CAAiC4E,GAApBhwD,EAAAorD,eAYb,IAAAM,GAAA,SAAAn6C,GAAA,SAAAm6C,IAAA,IAAAl6C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASu6C,oBAIlB,OALuC1+C,EAAA64C,EAAAn6C,GAKvCm6C,EALA,CAAuC+E,IAA1BzwD,EAAA0rD,qBAQb,IAAAH,GAAA,SAAAh6C,GAAA,SAAAg6C,IAAA,IAAA/5C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASI,SAYlB,OAbqCvE,EAAA04C,EAAAh6C,GAarCg6C,EAbA,CAAqCyE,GAAxBhwD,EAAAurD,mBAgBb,IAAAK,GAAA,SAAAr6C,GAAA,SAAAq6C,IAAA,IAAAp6C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASc,uBAClB,OAF0CjF,EAAA+4C,EAAAr6C,GAE1Cq6C,EAFA,CAA0CnC,IAA7BzpD,EAAA4rD,wBAKb,IAAAY,GAAA,SAAAj7C,GAAA,SAAAi7C,IAAA,IAAAh7C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASiL,oBAClB,OAFuCpP,EAAA25C,EAAAj7C,GAEvCi7C,EAFA,CAAuCN,IAA1BlsD,EAAAwsD,qBAKb,IAAAC,GAAA,SAAAl7C,GAAA,SAAAk7C,IAAA,IAAAj7C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASgB,uBAIlB,OAL0CnF,EAAA45C,EAAAl7C,GAK1Ck7C,EALA,CAA0CgE,IAA7BzwD,EAAAysD,wBAQb,IAAAE,GAAA,SAAAp7C,GAAA,SAAAo7C,IAAA,IAAAn7C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASw6C,SAIlB,OALqC3+C,EAAA85C,EAAAp7C,GAKrCo7C,EALA,CAAqCqD,GAAxBhwD,EAAA2sD,mBAQb,IAAAK,GAAA,SAAAz7C,GAAA,SAAAy7C,IAAA,IAAAx7C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASy6C,aAMlB,OAPgC5+C,EAAAm6C,EAAAz7C,GAOhCy7C,EAPA,CAAgCx5C,GAAnBxT,EAAAgtD,cAUb,IAAAF,GAAA,SAAAv7C,GAAA,SAAAu7C,IAAA,IAAAt7C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS06C,SAMlB,OAPqC7+C,EAAAi6C,EAAAv7C,GAOrCu7C,EAPA,CAAqCkD,GAAxBhwD,EAAA8sD,mBAUb,IAAAI,GAAA,SAAA37C,GAAA,SAAA27C,IAAA,IAAA17C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS26C,QAIlB,OALoC9+C,EAAAq6C,EAAA37C,GAKpC27C,EALA,CAAoC8C,GAAvBhwD,EAAAktD,kBAQb,IAAAK,GAAA,SAAAh8C,GAAA,SAAAg8C,IAAA,IAAA/7C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS46C,MAUlB,OAXkC/+C,EAAA06C,EAAAh8C,GAWlCg8C,EAXA,CAAkCyC,GAArBhwD,EAAAutD,gBAcb,IAAAC,GAAA,SAAAj8C,GAAA,SAAAi8C,IAAA,IAAAh8C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASkB,kBAMlB,OAPqCrF,EAAA26C,EAAAj8C,GAOrCi8C,EAPA,CAAqCiD,IAAxBzwD,EAAAwtD,mBAUb,IAAAG,GAAA,SAAAp8C,GAAA,SAAAo8C,IAAA,IAAAn8C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS66C,sBAClB,OAFyCh/C,EAAA86C,EAAAp8C,GAEzCo8C,EAFA,CAAyC+C,IAA5B1wD,EAAA2tD,uBAKb,IAAAD,GAAA,SAAAn8C,GAAA,SAAAm8C,IAAA,IAAAl8C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAASM,WAMlB,OAPuCzE,EAAA66C,EAAAn8C,GAOvCm8C,EAPA,CAAuCsC,GAA1BhwD,EAAA0tD,qBAUb,IAAAG,GAAA,SAAAt8C,GAAA,SAAAs8C,IAAA,IAAAr8C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS86C,OAIlB,OALmCj/C,EAAAg7C,EAAAt8C,GAKnCs8C,EALA,CAAmCmC,GAAtBhwD,EAAA6tD,iBAQb,IAAAE,GAAA,SAAAx8C,GAAA,SAAAw8C,IAAA,IAAAv8C,EAAA,OAAAD,KAAAgV,MAAAjmB,KAAAgjB,YAAAhjB,YACEkR,EAAAuF,KAAOC,EAAS+6C,QAMlB,OAPoCl/C,EAAAk7C,EAAAx8C,GAOpCw8C,EAPA,CAAoCiC,GAqBpC,SAAgBtF,GAAmB5lC,GAEjC,OADIA,EAAKD,SAAS,SAAQC,EAAOA,EAAK/X,UAAU,EAAG+X,EAAKrY,OAAS,IAC1DqY,EAvBI9kB,EAAA+tD,kBAUb/tD,EAAAgyD,cAAA,SAA8Bj7C,EAAqB8J,GACjD,GAAIA,EACF,IAAK,IAAIlgB,EAAI,EAAG+V,EAAImK,EAAWpU,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACjD,IAAIogB,EAAYF,EAAWlgB,GAC3B,GAAIogB,EAAUjS,eAAiBiI,EAAM,OAAOgK,EAGhD,OAAO,MAIT/gB,EAAA0qD,sBAMA1qD,EAAAiyD,cAAA,SAA8B1yC,GAC5B,GAAIA,EAAKxI,MAAQC,EAASk3C,UAAW,CACnC,IAAIhtD,EAAuBqe,EAAMre,KACjC,QAASA,EAAKqX,MAAQrX,EAAK0S,WAAWrH,KAAKE,QAE7C,OAAO,kFCn/DT,IAAAylD,EAAAzxD,EAAA,GAOA0xD,EAAA1xD,EAAA,IAOA,SAAkB2xD,GAKhBA,IAAA,WAEAA,IAAA,aAEAA,IAAA,aAEAA,IAAA,aAEAA,IAAA,iBAKAA,IAAA,WAEAA,IAAA,aAEAA,IAAA,aAEAA,IAAA,aAEAA,IAAA,iBAEAA,IAAA,gBAKAA,IAAA,cAEAA,IAAA,cAKAA,IAAA,gBAKAA,IAAA,gBA7CF,CAAkBpyD,EAAAoyD,WAAApyD,EAAAoyD,SAAQ,KAiD1B,SAAkBC,GAChBA,IAAA,eAEAA,IAAA,mBAEAA,IAAA,uBAEAA,IAAA,qBAEAA,IAAA,iBAEAA,IAAA,sBAEAA,IAAA,kBAEAA,IAAA,gBAEAA,IAAA,mBAEAA,IAAA,2BAEAA,IAAA,yBAEAA,IAAA,sBAvBF,CAAkBryD,EAAAqyD,YAAAryD,EAAAqyD,UAAS,KA0B3B,IAAMC,EAAY,IAAInqD,WAAW,IAGjC+M,EAAA,WAoBE,SAAAA,EAAY6B,EAAgBzD,EAAkB44B,GAHtC5rC,KAAAiyD,mBAAkC,KAIxCjyD,KAAKyW,KAAOA,EACZzW,KAAKgT,MAAQA,EACbhT,KAAK4rC,KAAOA,EACZ5rC,KAAKkyD,SAAgBC,KAAevmB,EAAO,GAC3C5rC,KAAK2uB,eAAiB,KACtB3uB,KAAKoyD,mBAAqB,KAC1BpyD,KAAKqyD,gBAAkBryD,KA6Z3B,OAzZEe,OAAAC,eAAI4T,EAAA3S,UAAA,UAAO,KAAX,WACE,OAAQjC,KAAKyW,MACX,OAAkB,OAAO7B,EAAK1R,GAC9B,OAAmB,OAAO0R,EAAKzR,IAC/B,QACA,OAAmB,OAAOyR,EAAKxR,IAC/B,QACA,OAAmB,OAAOwR,EAAKvR,IAC/B,OAAqB,OAAoB,IAAbrD,KAAK4rC,KAAah3B,EAAK09C,QAAU19C,EAAK29C,QAClE,OAAkB,OAAO39C,EAAKrR,GAC9B,OAAmB,OAAOqR,EAAKpR,IAC/B,OAAmB,OAAOoR,EAAKnR,IAC/B,OAAmB,OAAOmR,EAAKlR,IAC/B,OAAqB,OAAoB,IAAb1D,KAAK4rC,KAAah3B,EAAK49C,QAAU59C,EAAK69C,QAClE,QACA,QAAS,OAAO79C,EAAKxR,sCAKzBrC,OAAAC,eAAI4T,EAAA3S,UAAA,aAAU,KAAd,WACE,OAAa,IAATjC,KAAKyW,KAA8B7B,EAAK89C,KACrC1yD,sCAITe,OAAAC,eAAI4T,EAAA3S,UAAA,YAAS,KAAb,WACE,OAAO,GAAK0wD,IAAS3yD,KAAKkyD,2CAI5BnxD,OAAAC,eAAI4T,EAAA3S,UAAA,YAAS,KAAb,WACE,IAAI0sB,EAAiB3uB,KAAK2uB,eAC1B,OAA0B,OAAnBA,IAA4BA,EAAetT,aAAau2C,EAAA7gD,eAAe0K,4CAIhF1a,OAAAC,eAAI4T,EAAA3S,UAAA,cAAW,KAAf,WACE,IAAI0sB,EAAiB3uB,KAAK2uB,eAC1B,OAA0B,OAAnBA,GAA2BA,EAAetT,aAAau2C,EAAA7gD,eAAe0K,4CAI/E7G,EAAA3S,UAAA2wD,yBAAA,SAAyBC,GACvB,OAAOA,EAAWjnB,KAAO5rC,KAAK4rC,MAIhCh3B,EAAA3S,UAAA6wD,wBAAA,SAAwBD,GACtB,IAAIjnB,EAAO5rC,KAAKsf,GAAE,GAAuBtf,KAAK4rC,KAAO5rC,KAAK4rC,KAAO,EACjE,OAAO,IAAQinB,EAAWjnB,KAAOA,GAInCh3B,EAAA3S,UAAAqd,GAAA,SAAGtM,GAA0B,OAAQhT,KAAKgT,MAAQA,IAAUA,GAE5D4B,EAAA3S,UAAA2f,MAAA,SAAM5O,GAA0B,OAA+B,IAAvBhT,KAAKgT,MAAQA,IAGrD4B,EAAA3S,UAAAwqB,QAAA,SAAQsmC,GACN3oD,OAAgB,GAATpK,KAAKyW,OAA2BzW,KAAK2uB,gBAC5C,IAAI+kB,EAAM,IAAI9+B,EAAK5U,KAAKyW,MAAmB,IAAbzW,KAAKgT,MAAwB,IAAwBhT,KAAK4rC,MAExF,OADA8H,EAAI/kB,eAAiBokC,EACdrf,GAIT9+B,EAAA3S,UAAA2nB,WAAA,SAAW3V,GACT7J,OAAgB,GAATpK,KAAKyW,OAAyBzW,KAAKoyD,oBAC1C,IAAI1e,EAAM,IAAI9+B,EAAK5U,KAAKyW,MAAmB,IAAbzW,KAAKgT,MAAwB,IAAwBhT,KAAK4rC,MAExF,OADA8H,EAAI0e,mBAAqBn+C,EAClBy/B,GAIT9+B,EAAA3S,UAAA+wD,WAAA,WASE,OARA5oD,OAAOpK,KAAKsf,GAAE,MACTtf,KAAKiyD,qBACR7nD,QAAQpK,KAAKsf,GAAE,MACftf,KAAKiyD,mBAAqB,IAAIr9C,EAAK5U,KAAKyW,KAAgB,IAAVzW,KAAKgT,MAA4BhT,KAAK4rC,MACpF5rC,KAAKiyD,mBAAmBI,gBAAkBryD,KAC1CA,KAAKiyD,mBAAmBtjC,eAAiB3uB,KAAK2uB,eAC9C3uB,KAAKiyD,mBAAmBG,mBAAqBpyD,KAAKoyD,oBAE7CpyD,KAAKiyD,oBAIdr9C,EAAA3S,UAAAmrB,eAAA,SAAeC,EAAc4lC,GAC3B,IAAIC,EACAC,EACAC,EACAC,EACJ,QAL2B,IAAAJ,OAAA,GAKvBjzD,KAAKsf,GAAE,MACT,GAAI+N,EAAO/N,GAAE,QACNtf,KAAKsf,GAAE,MAAwB+N,EAAO/N,GAAE,MAC3C,GAAI4zC,EAAelzD,KAAK2uB,gBACtB,GAAIwkC,EAAc9lC,EAAOsB,eACvB,OAAOukC,EAAa9lC,eAAe+lC,QAEhC,IAAIC,EAAkBpzD,KAAKoyD,sBAC5BiB,EAAiBhmC,EAAO+kC,oBAC1B,OAAOgB,EAAgBhmC,eAAeimC,QAKzC,IAAKhmC,EAAO/N,GAAE,KACnB,GAAItf,KAAKsf,GAAE,GACT,GAAI+N,EAAO/N,GAAE,IACX,IACG2zC,GACDjzD,MAAQ4U,EAAKhR,MACb5D,KAAKsf,GAAE,IAAsB+N,EAAO/N,GAAE,GAEtC,OAAOtf,KAAK4rC,MAAQve,EAAOue,SAExB,IAAe,IAAXve,EAAO5W,KAChB,OAAOzW,KAAK4rC,MAAQ,GACf,GAAe,IAAXve,EAAO5W,KAChB,OAAOzW,KAAK4rC,MAAQ,QAEjB,GAAI5rC,KAAKsf,GAAE,IAChB,GAAI+N,EAAO/N,GAAE,GACX,OAAOtf,KAAK4rC,MAAQve,EAAOue,UAExB,GAAI5rC,KAAKsf,GAAE,OACZ+N,EAAO/N,GAAE,MACX,OAAOtf,KAAK4rC,MAAQve,EAAOue,KAIjC,OAAO,GAITh3B,EAAA3S,UAAAqxD,uBAAA,SAAuBjmC,EAAc4lC,GACnC,YADmC,IAAAA,OAAA,GAC/BjzD,KAAKsf,GAAE,KAA8Btf,KAAKotB,eAAeC,IACpDA,EAAO/N,GAAE,OACdtf,KAAKsf,GAAE,GACF+N,EAAO/N,GAAE,IAAuB+N,EAAOue,MAAQ5rC,KAAK4rC,QACxDqnB,GAAwBjzD,KAAKsf,GAAE,IAAsB+N,EAAO/N,GAAE,IAG5Dtf,KAAKyW,MAAQ4W,EAAO5W,OAItB7B,EAAA2+C,kBAAP,SAAyBxsB,EAAYC,EAAawsB,GAChD,OAAIxsB,EAAM5Z,eAAe2Z,EAAMysB,GAA+BzsB,EACrDA,EAAK3Z,eAAe4Z,EAAOwsB,GAA+BxsB,EAC5D,MAITpyB,EAAA3S,UAAAyJ,SAAA,WACE,GAAI1L,KAAKsf,GAAE,KAAuB,CAChC,IAAIqP,EAAiB3uB,KAAK2uB,eAC1B,GAAIA,EACF,OAAO3uB,KAAKsf,GAAE,KACVqP,EAAevc,aAAe,UAC9Buc,EAAevc,aAErB,IAAIggD,EAAqBpyD,KAAKoyD,mBAC9B,GAAIA,EACF,OAAOpyD,KAAKsf,GAAE,KACV,IAAM8yC,EAAmB1mD,WAAa,WACtC0mD,EAAmB1mD,WAEzBtB,QAAO,GAET,OAAQpK,KAAKyW,MACX,OAAkB,MAAO,KACzB,OAAmB,MAAO,MAC1B,OAAmB,MAAO,MAC1B,OAAmB,MAAO,MAC1B,OAAqB,MAAO,QAC5B,OAAkB,MAAO,KACzB,OAAmB,MAAO,MAC1B,OAAmB,MAAO,MAC1B,OAAmB,MAAO,MAC1B,OAAqB,MAAO,QAC5B,QAAoB,MAAO,OAC3B,QAAmB,MAAO,MAC1B,QAAmB,MAAO,MAC1B,QAAoB,MAAO,OAC3B,QAASrM,QAAO,GAChB,QAAoB,MAAO,SAO/BwK,EAAA3S,UAAAwxD,aAAA,WACE,OAAQzzD,KAAKyW,MACX,QAAS,OAAOo7C,EAAAriC,WAAWppB,IAC3B,OACA,OAAmB,OAAOyrD,EAAAriC,WAAWnpB,IACrC,OACA,OAAqB,OAAoB,IAAbrG,KAAK4rC,KAAaimB,EAAAriC,WAAWnpB,IAAMwrD,EAAAriC,WAAWppB,IAC1E,QAAmB,OAAOyrD,EAAAriC,WAAW3oB,IACrC,QAAmB,OAAOgrD,EAAAriC,WAAW1oB,IACrC,QAAoB,OAAO+qD,EAAAriC,WAAWzoB,KACtC,QAAqB,OAAO8qD,EAAAriC,WAAWyY,OAK3CrzB,EAAA3S,UAAAyxD,aAAA,SAAa/zD,GACX,OAAQK,KAAKyW,MACX,QAAoBrM,QAAO,GAC3B,QAAS,OAAOzK,EAAOyD,IAAI,GAC3B,OACA,OAAqB,GAAiB,IAAbpD,KAAK4rC,KAAY,OAAOjsC,EAAOyD,IAAI,GAC5D,OACA,OAAmB,OAAOzD,EAAO0D,IAAI,GACrC,QAAmB,OAAO1D,EAAOkE,IAAI,GACrC,QAAmB,OAAOlE,EAAOmE,IAAI,GACrC,QAAoB,OAAOnE,EAAOoE,KAAKiuD,KAK3Cp9C,EAAA3S,UAAA0xD,YAAA,SAAYh0D,GACV,OAAQK,KAAKyW,MACX,QACA,QAAoBrM,QAAO,GAC3B,QAAS,OAAOzK,EAAOyD,IAAI,GAC3B,OACA,OAAqB,GAAiB,IAAbpD,KAAK4rC,KAAY,OAAOjsC,EAAOyD,IAAI,GAC5D,OACA,OAAmB,OAAOzD,EAAO0D,IAAI,GACrC,QAAmB,OAAO1D,EAAOkE,IAAI,GACrC,QAAmB,OAAOlE,EAAOmE,IAAI,KAKzC8Q,EAAA3S,UAAA2xD,eAAA,SAAej0D,GACb,OAAQK,KAAKyW,MACX,QACA,QAAoBrM,QAAO,GAC3B,QAAS,OAAOzK,EAAOyD,KAAK,GAC5B,OACA,OAAqB,GAAiB,IAAbpD,KAAK4rC,KAAY,OAAOjsC,EAAOyD,KAAK,GAC7D,OACA,OAAmB,OAAOzD,EAAO0D,KAAK,GAAI,GAC1C,QAAmB,OAAO1D,EAAOkE,KAAK,GACtC,QAAmB,OAAOlE,EAAOmE,KAAK,KAK1C8Q,EAAA3S,UAAAipB,kBAAA,WACE,OAAQlrB,KAAKyW,MAEX,OACA,OACA,OACA,OACA,OACA,OACA,QAAoB,MAAO,IAC3B,OACA,OAAmB,MAAO,IAC1B,OACA,OAAqB,OAAoB,IAAbzW,KAAK4rC,KAAa,IAAM,IACpD,QAAmB,MAAO,IAC1B,QAAmB,MAAO,IAC1B,QAAoB,MAAO,IAC3B,QAAoB,MAAO,IAC3B,QAASxhC,QAAO,GAElB,MAAO,KAMOwK,EAAA1R,GAAY,IAAI0R,EAAI,EAClC,IAGmB,GAILA,EAAAzR,IAAY,IAAIyR,EAAI,EAClC,IAGkB,IAIJA,EAAAxR,IAAY,IAAIwR,EAAI,EAClC,IAEkB,IAIJA,EAAAvR,IAAY,IAAIuR,EAAI,EAClC,IAGkB,IAIJA,EAAA29C,QAAgB,IAAI39C,EAAI,EACtC,IAGkB,IAIJA,EAAA09C,QAAgB,IAAI19C,EAAI,EACtC,IAIkB,IAIJA,EAAArR,GAAW,IAAIqR,EAAI,EACjC,IAGmB,GAILA,EAAApR,IAAY,IAAIoR,EAAI,EAClC,IAGkB,IAIJA,EAAAnR,IAAY,IAAImR,EAAI,EAClC,IAEkB,IAIJA,EAAAlR,IAAY,IAAIkR,EAAI,EAClC,IAGkB,IAIJA,EAAA69C,QAAgB,IAAI79C,EAAI,EACtC,IAGkB,IAIJA,EAAA49C,QAAgB,IAAI59C,EAAI,EACtC,IAIkB,IAIJA,EAAAhR,KAAa,IAAIgR,EAAI,GACnC,IAGmB,GAILA,EAAA/Q,IAAY,IAAI+Q,EAAI,GAClC,IAEkB,IAIJA,EAAA9Q,IAAY,IAAI8Q,EAAI,GAClC,IAGkB,IAIJA,EAAA7Q,KAAa,IAAI6Q,EAAI,GACnC,KACiB,KAIHA,EAAAG,KAAa,IAAIH,EAAI,KAAgC,GAGrDA,EAAA89C,KAAa,IAAI99C,EAAKA,EAAKxR,IAAIqT,KAAM7B,EAAKxR,IAAI4P,MAAO4B,EAAKxR,IAAIwoC,MAChFh3B,EAxbA,GAAalV,EAAAkV,OA2bblV,EAAAm0D,mBAAA,SAAmCC,GAGjC,IAFA,IAAIC,EAAWD,EAAM3nD,OACjBunC,EAAM,IAAIzsC,MAAkB8sD,GACvB1zD,EAAI,EAAGA,EAAI0zD,IAAY1zD,EAAGqzC,EAAIrzC,GAAKyzD,EAAMzzD,GAAGozD,eACrD,OAAO/f,GAITh0C,EAAAs0D,cAAA,SAA8BF,GAC5B,IAAIC,EAAWD,EAAM3nD,OACrB,IAAK4nD,EAAU,MAAO,GAEtB,IADA,IAAIvnD,EAAK,IAAIvF,MAAc8sD,GAClB1zD,EAAI,EAAGA,EAAI0zD,IAAY1zD,EAAGmM,EAAGnM,GAAKyzD,EAAMzzD,GAAGqL,WACpD,OAAOc,EAAGG,KAAK,MAIjB,IAAAyZ,EAAA,WAoBE,SAAAA,EACE4D,EACAohB,EACArhB,QAFA,IAAAC,MAAA,WACA,IAAAohB,MAAA,WACA,IAAArhB,MAAA,MARF/pB,KAAAi0D,qBAA8C,KAU5Cj0D,KAAKgqB,eAAiBA,GAAkC,GACxDhqB,KAAKk0D,eAAiB,KACtBl0D,KAAKm0D,mBAAqB,EAC1Bn0D,KAAKorC,WAAaA,GAA0Bx2B,EAAKG,KACjD/U,KAAK+pB,SAAWA,EAChB/pB,KAAKo0D,SAAU,EACfp0D,KAAKif,KAAOrK,EAAKnR,IAAImmB,WAAW5pB,MAoGpC,OAjGEomB,EAAAnkB,UAAAoyD,iBAAA,SAAiB7uC,GACf,IAAI6H,EAASrtB,KAAKi0D,qBAGlB,OAFK5mC,EACAjjB,OAAOijB,EAAO7H,SAAWA,GADjBxlB,KAAKi0D,qBAAuB5mC,EAAS,IAAIukC,EAAA7mC,eAAe/qB,KAAMwlB,GAEpE6H,GAITjH,EAAAnkB,UAAAkoB,iBAAA,SAAiBvC,GACf,IAAIssC,EAAiBl0D,KAAKk0D,eAC1B,OAAOA,GAAkBA,EAAe/nD,OAASyb,EAC7CssC,EAAetsC,GACf0sC,EAAwB1sC,IAI9BxB,EAAAnkB,UAAAmrB,eAAA,SAAeC,GAIb,IAAIknC,EAAev0D,KAAK+pB,SACpByqC,EAAiBnnC,EAAOtD,SAC5B,GAAIwqC,GACF,IAAMC,IAAkBD,EAAannC,eAAeonC,GAAkB,OAAO,OACxE,GAAIA,EACT,OAAO,EAIT,GAAIx0D,KAAKo0D,SAAW/mC,EAAO+mC,QAAS,OAAO,EAG3C,IAAIK,EAAqBz0D,KAAKgqB,eAC1B0qC,EAAuBrnC,EAAOrD,eAC9B2qC,EAAgBF,EAAmBtoD,OACvC,GAAIwoD,GAAiBD,EAAqBvoD,OAAQ,OAAO,EACzD,IAAK,IAAI9L,EAAI,EAAGA,EAAIs0D,IAAiBt0D,EAAG,CACtC,IAAIu0D,EAAoBH,EAAmBp0D,GACvCw0D,EAAsBH,EAAqBr0D,GAC/C,IAAKu0D,EAAkBxnC,eAAeynC,GAAsB,OAAO,EAIrE,IAAIC,EAAiB90D,KAAKorC,WACtB2pB,EAAmB1nC,EAAO+d,WAC9B,OAAO0pB,GAAkBC,GAAoBD,EAAe1nC,eAAe2nC,IAItE3uC,EAAA4uC,oBAAP,SAA2BhrC,EAA+BohB,EAAkBrhB,QAAA,IAAAA,MAAA,MAC1E,IAAIvd,EAAK,GAGT,GAFAA,EAAGE,KAAK0+B,EAAWlgB,qBACfnB,GAAUvd,EAAGE,KAAKqd,EAASmB,qBAC3BlB,EACF,IAAK,IAAI3pB,EAAI,EAAG+V,EAAI4T,EAAe7d,OAAQ9L,EAAI+V,IAAK/V,EAAGmM,EAAGE,KAAKsd,EAAe3pB,GAAG6qB,qBAEnF,MAAO,WAAa1e,EAAGG,KAAK,KAI9ByZ,EAAAnkB,UAAAipB,kBAAA,WACE,OAAO9E,EAAU4uC,oBAAoBh1D,KAAKgqB,eAAgBhqB,KAAKorC,WAAYprC,KAAK+pB,WAIlF3D,EAAAnkB,UAAAyJ,SAAA,WACE,IAAIc,EAAK,IAAIvF,MACbuF,EAAGE,KAAK,KACR,IAAIkb,EAAQ,EACRmC,EAAW/pB,KAAK+pB,SAChBA,IACFvd,EAAGE,KAAK,UACRtC,QAAQ2f,EAASqoC,oBACjB5lD,EAAGE,KAAKqd,EAASre,YACjBkc,EAAQ,GAEV,IAAI27B,EAAavjD,KAAKgqB,eAClB2qC,EAAgBpR,EAAWp3C,OAC/B,GAAIwoD,EAKF,IAJA,IAAI5pB,EAAQ/qC,KAAKk0D,eACbjpB,EAAWF,EAAQA,EAAM5+B,OAAS,EAClC8oD,EAAgBj1D,KAAKm0D,mBACrBe,EAAYl1D,KAAKo0D,QAAUO,EAAgB,GAAK,EAC3Ct0D,EAAI,EAAGA,EAAIs0D,IAAiBt0D,IAAKunB,EACpCA,GAAOpb,EAAGE,KAAK,MACfrM,GAAK60D,GAAW1oD,EAAGE,KAAK,OACxBrM,EAAI4qC,EAAUz+B,EAAGE,KAAgBq+B,EAAO1qC,IACvCmM,EAAGE,KAAK4nD,EAAwBj0D,IACjCA,GAAK40D,GAAiB50D,GAAK60D,EAAW1oD,EAAGE,KAAK,OAC7CF,EAAGE,KAAK,MACbF,EAAGE,KAAK62C,EAAWljD,GAAGqL,YAK1B,OAFAc,EAAGE,KAAK,SACRF,EAAGE,KAAK1M,KAAKorC,WAAW1/B,YACjBc,EAAGG,KAAK,KAEnByZ,EAnIA,GAAa1mB,EAAA0mB,YAwIb,IAAI+uC,EAA+C,KAGnD,SAAgBb,EAAwB1sC,GACjCutC,IAA6BA,EAA8B,IAChE,IAAK,IAAI90D,EAAI80D,EAA4BhpD,OAAQ9L,GAAKunB,IAASvnB,EAC7D80D,EAA4BzoD,KAAK,OAASrM,EAAEqL,SAAS,KAEvD,OAAOypD,EAA4BvtC,EAAQ,GAL7CloB,EAAA40D,ybC/qBA,IAuBYjS,EAwIA+S,EA/JZ3nD,EAAAtN,EAAA,GAMAwN,EAAAxN,EAAA,GAKA0J,EAAA1J,EAAA,GA0JA,SAAgBk1D,EAAiBppD,GAE/B,OADA7B,OAAO6B,EAAKE,QACJF,EAAKM,WAAW,IACtB,QACE,OAAQN,GACN,IAAK,WAAY,OAAOo2C,EAAM7/B,SAC9B,IAAK,KAAM,OAAO6/B,EAAMiT,GACxB,IAAK,QAAS,OAAOjT,EAAMkT,MAC3B,IAAK,QAAS,OAAOlT,EAAMmT,MAE7B,MAEF,QACE,OAAQvpD,GACN,IAAK,QAAS,OAAOo2C,EAAMiO,MAE7B,MAEF,QACE,OAAQrkD,GACN,IAAK,OAAQ,OAAOo2C,EAAMoT,KAC1B,IAAK,QAAS,OAAOpT,EAAMqT,MAC3B,IAAK,QAAS,OAAOrT,EAAMxjC,MAC3B,IAAK,WAAY,OAAOwjC,EAAMkO,SAC9B,IAAK,QAAS,OAAOlO,EAAM5iC,MAC3B,IAAK,cAAe,OAAO4iC,EAAMz/B,YAEnC,MAEF,SACE,OAAQ3W,GACN,IAAK,WAAY,OAAOo2C,EAAMsT,SAC9B,IAAK,UAAW,OAAOtT,EAAM/8B,QAC7B,IAAK,UAAW,OAAO+8B,EAAMuT,QAC7B,IAAK,SAAU,OAAOvT,EAAMwT,OAC5B,IAAK,KAAM,OAAOxT,EAAMmO,GAE1B,MAEF,SACE,OAAQvkD,GACN,IAAK,OAAQ,OAAOo2C,EAAMyT,KAC1B,IAAK,OAAQ,OAAOzT,EAAMr7B,KAC1B,IAAK,SAAU,OAAOq7B,EAAMntC,OAC5B,IAAK,UAAW,OAAOmtC,EAAM0T,QAE/B,MAEF,SACE,OAAQ9pD,GACN,IAAK,QAAS,OAAOo2C,EAAMI,MAC3B,IAAK,UAAW,OAAOJ,EAAM2T,QAC7B,IAAK,MAAO,OAAO3T,EAAMwO,IACzB,IAAK,OAAQ,OAAOxO,EAAM4T,KAC1B,IAAK,WAAY,OAAO5T,EAAM1jC,SAEhC,MAEF,SACE,OAAQ1S,GACN,IAAK,MAAO,OAAOo2C,EAAMxgC,IAE3B,MAEF,SACE,OAAQ5V,GACN,IAAK,KAAM,OAAOo2C,EAAM2O,GACxB,IAAK,aAAc,OAAO3O,EAAM6T,WAChC,IAAK,SAAU,OAAO7T,EAAMvrC,OAC5B,IAAK,KAAM,OAAOurC,EAAM8T,GACxB,IAAK,aAAc,OAAO9T,EAAM2M,WAChC,IAAK,YAAa,OAAO3M,EAAMl2B,UAC/B,IAAK,KAAM,OAAOk2B,EAAM+T,GAE1B,MAEF,SACE,OAAQnqD,GACN,IAAK,QAAS,OAAOo2C,EAAMgU,MAE7B,MAEF,SACE,OAAQpqD,GACN,IAAK,MAAO,OAAOo2C,EAAMiU,IAE3B,MAEF,SACE,OAAQrqD,GACN,IAAK,SAAU,OAAOo2C,EAAMkU,OAE9B,MAEF,SACE,OAAQtqD,GACN,IAAK,YAAa,OAAOo2C,EAAMt7B,UAC/B,IAAK,MAAO,OAAOs7B,EAAM6M,IACzB,IAAK,OAAQ,OAAO7M,EAAME,KAE5B,MAEF,SACE,OAAQt2C,GACN,IAAK,KAAM,OAAOo2C,EAAMmU,GAE1B,MAEF,SACE,OAAQvqD,GACN,IAAK,UAAW,OAAOo2C,EAAMoU,QAC7B,IAAK,UAAW,OAAOpU,EAAMqU,QAC7B,IAAK,YAAa,OAAOrU,EAAMsU,UAC/B,IAAK,SAAU,OAAOtU,EAAMuU,OAE9B,MAEF,SACE,OAAQ3qD,GACN,IAAK,WAAY,OAAOo2C,EAAMjgC,SAC9B,IAAK,SAAU,OAAOigC,EAAM6O,OAE9B,MAEF,SACE,OAAQjlD,GACN,IAAK,MAAO,OAAOo2C,EAAMvgC,IACzB,IAAK,SAAU,OAAOugC,EAAMngC,OAC5B,IAAK,QAAS,OAAOmgC,EAAMY,MAC3B,IAAK,SAAU,OAAOZ,EAAM+O,OAE9B,MAEF,SACE,OAAQnlD,GACN,IAAK,OAAQ,OAAOo2C,EAAMiN,KAC1B,IAAK,QAAS,OAAOjN,EAAMgP,MAC3B,IAAK,OAAQ,OAAOhP,EAAMG,KAC1B,IAAK,MAAO,OAAOH,EAAMiP,IACzB,IAAK,OAAQ,OAAOjP,EAAMwU,KAC1B,IAAK,SAAU,OAAOxU,EAAMyU,OAE9B,MAEF,SACE,OAAQ7qD,GACN,IAAK,MAAO,OAAOo2C,EAAM0U,IACzB,IAAK,OAAQ,OAAO1U,EAAMmP,KAE5B,MAEF,SACE,OAAQvlD,GACN,IAAK,QAAS,OAAOo2C,EAAMoP,MAC3B,IAAK,OAAQ,OAAOpP,EAAM2U,KAE5B,MAEF,SACE,OAAQ/qD,GACN,IAAK,QAAS,OAAOo2C,EAAM4U,OAKjC,OAAO5U,EAAMxxC,QAGf,SAAgBqmD,EAAsBC,GACpC,OAAQA,GACN,KAAK9U,EAAM7/B,SACX,KAAK6/B,EAAMiT,GACX,KAAKjT,EAAMz/B,YACX,KAAKy/B,EAAM/8B,QACX,KAAK+8B,EAAMwT,OACX,KAAKxT,EAAM4T,KACX,KAAK5T,EAAMwO,IACX,KAAKxO,EAAMxgC,IACX,KAAKwgC,EAAM2M,WACX,KAAK3M,EAAM+T,GACX,KAAK/T,EAAMgU,MACX,KAAKhU,EAAMkU,OACX,KAAKlU,EAAMt7B,UACX,KAAKs7B,EAAME,KACX,KAAKF,EAAMjgC,SACX,KAAKigC,EAAMvgC,IACX,KAAKugC,EAAMwU,KACX,KAAKxU,EAAMmP,KAAM,OAAO,EACxB,QAAS,OAAO,IA1UpB,SAAYnP,GAKVA,IAAA,uBACAA,IAAA,WACAA,IAAA,iBACAA,IAAA,iBACAA,IAAA,iBACAA,IAAA,eACAA,IAAA,iBACAA,IAAA,iBACAA,IAAA,iBACAA,IAAA,uBACAA,IAAA,8BACAA,IAAA,wBACAA,IAAA,sBACAA,IAAA,sBACAA,IAAA,oBACAA,IAAA,YACAA,IAAA,gBACAA,IAAA,gBACAA,IAAA,oBACAA,IAAA,sBACAA,IAAA,kBACAA,IAAA,sBACAA,IAAA,cACAA,IAAA,gBACAA,IAAA,wBACAA,IAAA,cACAA,IAAA,YACAA,IAAA,4BACAA,IAAA,oBACAA,IAAA,YACAA,IAAA,4BACAA,IAAA,0BACAA,IAAA,YACAA,IAAA,kBACAA,IAAA,cACAA,IAAA,oBACAA,IAAA,0BACAA,IAAA,cACAA,IAAA,gBACAA,IAAA,YACAA,IAAA,sBACAA,IAAA,sBACAA,IAAA,0BACAA,IAAA,oBACAA,IAAA,wBACAA,IAAA,oBACAA,IAAA,cACAA,IAAA,oBACAA,IAAA,kBACAA,IAAA,oBACAA,IAAA,gBACAA,IAAA,kBACAA,IAAA,gBACAA,IAAA,cACAA,IAAA,gBACAA,IAAA,oBACAA,IAAA,cACAA,IAAA,gBACAA,IAAA,kBACAA,IAAA,gBACAA,IAAA,kBAIAA,IAAA,0BACAA,IAAA,4BACAA,IAAA,0BACAA,IAAA,4BACAA,IAAA,8BACAA,IAAA,gCACAA,IAAA,cACAA,IAAA,8BACAA,IAAA,0BACAA,IAAA,kBACAA,IAAA,wBACAA,IAAA,8BACAA,IAAA,sCACAA,IAAA,4CACAA,IAAA,kCACAA,IAAA,4CACAA,IAAA,gDACAA,IAAA,0DACAA,IAAA,4CACAA,IAAA,gBACAA,IAAA,kBACAA,IAAA,0CACAA,IAAA,wBACAA,IAAA,kBACAA,IAAA,sBACAA,IAAA,0BACAA,IAAA,8BACAA,IAAA,0CACAA,IAAA,sDACAA,IAAA,8EACAA,IAAA,0BACAA,IAAA,cACAA,IAAA,kBACAA,IAAA,8BACAA,IAAA,kBACAA,IAAA,8CACAA,IAAA,sBACAA,IAAA,wBACAA,IAAA,kBACAA,IAAA,qBACAA,IAAA,+BACAA,IAAA,iCACAA,IAAA,uCACAA,IAAA,yDACAA,IAAA,iCACAA,IAAA,qCACAA,IAAA,yDACAA,IAAA,qEACAA,IAAA,6FACAA,IAAA,yCACAA,IAAA,6BACAA,IAAA,iCACAA,IAAA,aAIAA,IAAA,6BACAA,IAAA,mCACAA,IAAA,qCACAA,IAAA,iCAIAA,IAAA,uBACAA,IAAA,2BArIF,CAAYA,EAAA3iD,EAAA2iD,QAAA3iD,EAAA2iD,MAAK,KAwIjB,SAAY+S,GACVA,IAAA,qBACAA,IAAA,mBACAA,IAAA,mBAHF,CAAYA,EAAA11D,EAAA01D,qBAAA11D,EAAA01D,mBAAkB,KAM9B11D,EAAA21D,mBAwKA31D,EAAAw3D,wBAwBAx3D,EAAA03D,4BAAA,SAA4Cx2D,GAE1C,OADAwJ,OAAOxJ,EAAKuL,QACJvL,EAAK2L,WAAW,IACtB,SAAiB,MAAe,UAAR3L,EACxB,SAAiB,MAAe,OAARA,EACxB,SAAiB,MAAe,cAARA,EACxB,SAAiB,MAAe,QAARA,EACxB,SAAiB,MAAe,QAARA,EAE1B,OAAO,GAGTlB,EAAA23D,sBAAA,SAAsCF,GACpC,OAAQA,GACN,KAAK9U,EAAMwT,OAAQ,MAAO,SAC1B,KAAKxT,EAAM8T,GAAI,MAAO,KACtB,KAAK9T,EAAM2M,WAAY,MAAO,aAC9B,KAAK3M,EAAM6M,IAAK,MAAO,MACvB,KAAK7M,EAAMyU,OAAQ,MAAO,SAC1B,KAAKzU,EAAMmP,KAAM,MAAO,OACxB,KAAKnP,EAAM4U,MAAO,MAAO,QACzB,KAAK5U,EAAMiV,YAAa,MAAO,MAC/B,KAAKjV,EAAMyM,MAAO,MAAO,IACzB,KAAKzM,EAAMkV,SAAU,MAAO,IAC5B,KAAKlV,EAAMmV,YAAa,MAAO,IAC/B,KAAKnV,EAAMoV,gBAAiB,MAAO,KACnC,KAAKpV,EAAMqV,mBAAoB,MAAO,KACtC,KAAKrV,EAAMsV,cAAe,MAAO,KACjC,KAAKtV,EAAMuV,mBAAoB,MAAO,KACtC,KAAKvV,EAAMwV,qBAAsB,MAAO,MACxC,KAAKxV,EAAMyV,0BAA2B,MAAO,MAC7C,KAAKzV,EAAMjyC,KAAM,MAAO,IACxB,KAAKiyC,EAAM/xC,MAAO,MAAO,IACzB,KAAK+xC,EAAM0V,kBAAmB,MAAO,KACrC,KAAK1V,EAAM2V,SAAU,MAAO,IAC5B,KAAK3V,EAAM4V,MAAO,MAAO,IACzB,KAAK5V,EAAM6V,QAAS,MAAO,IAC3B,KAAK7V,EAAM8V,UAAW,MAAO,KAC7B,KAAK9V,EAAM+V,YAAa,MAAO,KAC/B,KAAK/V,EAAMgW,kBAAmB,MAAO,KACrC,KAAKhW,EAAMiW,wBAAyB,MAAO,KAC3C,KAAKjW,EAAMkW,oCAAqC,MAAO,MACvD,KAAKlW,EAAMmW,UAAW,MAAO,IAC7B,KAAKnW,EAAMoW,IAAK,MAAO,IACvB,KAAKpW,EAAMqW,MAAO,MAAO,IACzB,KAAKrW,EAAMsW,YAAa,MAAO,IAC/B,KAAKtW,EAAMuW,MAAO,MAAO,IACzB,KAAKvW,EAAMwW,oBAAqB,MAAO,KACvC,KAAKxW,EAAMyW,QAAS,MAAO,KAC3B,KAAKzW,EAAM0W,OAAQ,MAAO,IAC1B,KAAK1W,EAAM2W,YAAa,MAAO,KAC/B,KAAK3W,EAAM4W,aAAc,MAAO,KAChC,KAAK5W,EAAM6W,gBAAiB,MAAO,KACnC,KAAK7W,EAAM8W,yBAA0B,MAAO,MAC5C,KAAK9W,EAAM+W,aAAc,MAAO,KAChC,KAAK/W,EAAMgX,eAAgB,MAAO,KAClC,KAAKhX,EAAMiX,yBAA0B,MAAO,MAC5C,KAAKjX,EAAMkX,+BAAgC,MAAO,MAClD,KAAKlX,EAAMmX,2CAA4C,MAAO,OAC9D,KAAKnX,EAAMoX,iBAAkB,MAAO,KACpC,KAAKpX,EAAMqX,WAAY,MAAO,KAC9B,KAAKrX,EAAMsX,aAAc,MAAO,KAChC,QAEE,OADAvvD,QAAO,GACA,KAKb,IAAAuR,EAAA,WAUE,SAAAA,EAAYhQ,EAAgBS,EAAYC,GA6CxCrM,KAAA6qB,aAAsB,EA5CpB7qB,KAAK2L,OAASA,EACd3L,KAAKoM,MAAQA,EACbpM,KAAKqM,IAAMA,EA2Cf,OAxCSsP,EAAAhP,KAAP,SAAYitD,EAAUC,GACpB,GAAID,EAAEjuD,QAAUkuD,EAAEluD,OAAQ,MAAM,IAAIyQ,MAAM,mBAC1C,OAAO,IAAIT,EAAMi+C,EAAEjuD,OACjBiuD,EAAExtD,MAAQytD,EAAEztD,MAAQwtD,EAAExtD,MAAQytD,EAAEztD,MAChCwtD,EAAEvtD,IAAMwtD,EAAExtD,IAAMutD,EAAEvtD,IAAMwtD,EAAExtD,MAI9BtL,OAAAC,eAAI2a,EAAA1Z,UAAA,UAAO,KAAX,WACE,OAAO,IAAI0Z,EAAM3b,KAAK2L,OAAQ3L,KAAKoM,MAAOpM,KAAKoM,wCAGjDrL,OAAAC,eAAI2a,EAAA1Z,UAAA,QAAK,KAAT,WACE,OAAO,IAAI0Z,EAAM3b,KAAK2L,OAAQ3L,KAAKqM,IAAKrM,KAAKqM,sCAG/CtL,OAAAC,eAAI2a,EAAA1Z,UAAA,OAAI,KAAR,WAGE,IAFA,IAAIgK,EAAOjM,KAAK2L,OAAOM,KACnBJ,EAAO,EACFkkD,EAAM/vD,KAAKoM,MAAO2jD,GAAO,IAAKA,EACb,IAApB9jD,EAAKM,WAAWwjD,IAA2BlkD,IAEjD,OAAOA,mCAGT9K,OAAAC,eAAI2a,EAAA1Z,UAAA,SAAM,KAAV,WAGE,IAFA,IAAIgK,EAAOjM,KAAK2L,OAAOM,KACnBH,EAAS,EACJikD,EAAM/vD,KAAKoM,MAAQ,EAAG2jD,GAAO,GACZ,IAApB9jD,EAAKM,WAAWwjD,KADqBA,IAEvCjkD,EAEJ,OAAOA,mCAGT6P,EAAA1Z,UAAAyJ,SAAA,WACE,OAAO1L,KAAK2L,OAAOM,KAAKQ,UAAUzM,KAAKoM,MAAOpM,KAAKqM,MAIvDsP,EAxDA,GAAajc,EAAAic,QAgEb,IAAAm+C,EAAA,SAAA7oD,GAgBE,SAAA6oD,EAAYnuD,EAAgBoB,QAAA,IAAAA,MAAA,MAA5B,IAAAmE,EACED,EAAAzQ,KAAAR,KAAM+M,IAAY/M,KAdpBkR,EAAA7E,IAAW,EAEX6E,EAAA6+C,IAAW,EACX7+C,EAAAimD,OAAgB,EAChBjmD,EAAA6oD,SAAgB,EAEhB7oD,EAAA8oD,WAAoB,EACpB9oD,EAAA+oD,aAAoB,EACpB/oD,EAAAgpD,oBAA2B,EAE3BhpD,EAAAipD,UAAmC,KAMjCjpD,EAAKvF,OAASA,EACduF,EAAK6+C,IAAM,EACX7+C,EAAK7E,IAAMV,EAAOM,KAAKE,OACvB+E,EAAKnE,YAAcA,GAAe,IAAI9F,MAEtC,IAAIoF,EAAM6E,EAAK7E,IACXJ,EAAON,EAAOM,KAWlB,GAPEiF,EAAK6+C,IAAM1jD,GACc,OAAzBJ,EAAKM,WAAW2E,EAAK6+C,QAEnB7+C,EAAK6+C,IAKP7+C,EAAK6+C,IAAM,EAAI1jD,GACU,IAAzBJ,EAAKM,WAAW2E,EAAK6+C,MACQ,IAA7B9jD,EAAKM,WAAW2E,EAAK6+C,IAAM,GAG3B,IADA7+C,EAAK6+C,KAAO,EAEV7+C,EAAK6+C,IAAM1jD,GACc,IAAzBJ,EAAKM,WAAW2E,EAAK6+C,QAEnB7+C,EAAK6+C,aA8iCf,OA5lC+Bx9C,EAAAunD,EAAA7oD,GAoD7B6oD,EAAA73D,UAAAgW,KAAA,SAAKmiD,GAEH,YAFG,IAAAA,MAAyChF,EAAmBQ,SAC/D51D,KAAKg6D,WAAa,EACXh6D,KAAKm3D,MAAQn3D,KAAKq6D,WAAWD,IAG9BN,EAAA73D,UAAAo4D,WAAR,SACED,EACAE,QADA,IAAAF,MAAyChF,EAAmBQ,cAC5D,IAAA0E,MAAsBl3D,IAAIqxC,WAI1B,IAFA,IAAIpoC,EAAMrM,KAAKqM,IACXJ,EAAOjM,KAAK2L,OAAOM,KAChBjM,KAAK+vD,IAAM1jD,GAAK,CACrBrM,KAAK+5D,SAAW/5D,KAAK+vD,IACrB,IAAIrvD,EAAIuL,EAAKM,WAAWvM,KAAK+vD,KAC7B,OAAQrvD,GACN,QACE,OACIV,KAAK+vD,IAAM1jD,GACY,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,MACpB,MAGL,QACA,OACA,QACA,QACA,UACI/vD,KAAK+vD,IACP,MAEF,QAEE,QADE/vD,KAAK+vD,IAELuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,GACR,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,QAEnB/vD,KAAK+vD,IAELuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,GACR,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,QAEnB/vD,KAAK+vD,IACA1N,EAAMyV,2BAERzV,EAAMuV,oBAERvV,EAAMsW,YAEf,QACA,QACA,QACE,OAAOtW,EAAMkY,cAEf,QAEE,QADEv6D,KAAK+vD,IAELuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,GACR,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,QAEnB/vD,KAAK+vD,IACA1N,EAAMgX,gBAERhX,EAAM6V,QAEf,QAEE,KADEl4D,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CAExC,GAAO,KADHmuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,MAG7B,QADE/vD,KAAK+vD,IACA1N,EAAMwW,oBAEf,GAAO,IAAH2B,EAEF,QADEx6D,KAAK+vD,IACA1N,EAAMoX,iBAGjB,OAAOpX,EAAMmW,UAEf,QAEE,QADEx4D,KAAK+vD,IACA1N,EAAMoY,UAEf,QAEE,QADEz6D,KAAK+vD,IACA1N,EAAMqY,WAEf,QAEE,KADE16D,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CAExC,GAAO,KADHmuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,MAG7B,QADE/vD,KAAK+vD,IACA1N,EAAM6W,gBAEf,GAAO,IAAHsB,EAEF,QADEx6D,KAAK+vD,IAELuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,GACR,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,QAEnB/vD,KAAK+vD,IACA1N,EAAM8W,0BAER9W,EAAM0V,kBAGjB,OAAO1V,EAAM2V,SAEf,QAEE,KADEh4D,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CAExC,GAAO,KADHmuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,MAG7B,QADE/vD,KAAK+vD,IACA1N,EAAM8V,UAEf,GAAO,IAAHqC,EAEF,QADEx6D,KAAK+vD,IACA1N,EAAM2W,YAGjB,OAAO3W,EAAMjyC,KAEf,QAEE,QADEpQ,KAAK+vD,IACA1N,EAAMyM,MAEf,QAEE,KADE9uD,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CAExC,GAAO,KADHmuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,MAG7B,QADE/vD,KAAK+vD,IACA1N,EAAM+V,YAEf,GAAO,IAAHoC,EAEF,QADEx6D,KAAK+vD,IACA1N,EAAM4W,aAGjB,OAAO5W,EAAM/xC,MAEf,QAEE,KADEtQ,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CACxC,IAAImuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,KAC/B,GAAIlmD,EAAA8wD,eAAeH,GAEjB,QADEx6D,KAAK+vD,IACA1N,EAAMuY,aAEf,GACEN,EAAiB,GAAKt6D,KAAK+vD,IAAM,EAAI1jD,GAClC,IAAHmuD,GAC6B,IAA7BvuD,EAAKM,WAAWvM,KAAK+vD,IAAM,GAG3B,OADA/vD,KAAK+vD,KAAO,EACL1N,EAAMiV,YAGjB,OAAOjV,EAAMwY,IAEf,QACE,IAAIC,EAAkB96D,KAAK+vD,IAE3B,KADE/vD,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CAExC,GAAO,KADHmuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,MACJ,CACzB,IAAIvL,EAAc72C,EAAA2gD,YAAYyM,KAQ9B,IANE/6D,KAAK+vD,IAAM,EAAI1jD,GACc,IAA7BJ,EAAKM,WAAWvM,KAAK+vD,IAAM,OAEzB/vD,KAAK+vD,IACPvL,EAAc72C,EAAA2gD,YAAY0M,UAEnBh7D,KAAK+vD,IAAM1jD,GAClB,GAA6B,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,KAA2B,GAChD/vD,KAAK+vD,IACP,MAGA/vD,KAAKm6D,WACPn6D,KAAKm6D,UACH3V,EACAv4C,EAAKQ,UAAUquD,EAAiB96D,KAAK+vD,KACrC/vD,KAAK+K,MAAM+vD,EAAiB96D,KAAK+vD,MAGrC,MAEF,GAAO,IAAHyK,EAA0B,CAE5B,IADA,IAAIS,GAAS,IACJj7D,KAAK+vD,IAAM1jD,GAElB,GACG,KAFH3L,EAAIuL,EAAKM,WAAWvM,KAAK+vD,OAGvB/vD,KAAK+vD,IAAM,EAAI1jD,GACc,IAA7BJ,EAAKM,WAAWvM,KAAK+vD,IAAM,GAC3B,CACA/vD,KAAK+vD,KAAO,EACZkL,GAAS,EACT,MAGCA,EAKMj7D,KAAKm6D,WACdn6D,KAAKm6D,UACHxsD,EAAA2gD,YAAY+B,MACZpkD,EAAKQ,UAAUquD,EAAiB96D,KAAK+vD,KACrC/vD,KAAK+K,MAAM+vD,EAAiB96D,KAAK+vD,MARnC/vD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfl7D,KAAK+K,MAAM/K,KAAK+vD,KAAM,MAS1B,MAEF,GAAO,IAAHyK,EAEF,QADEx6D,KAAK+vD,IACA1N,EAAM+W,aAGjB,OAAO/W,EAAM4V,MAEf,QACA,QACA,QACA,QACA,QACA,QACA,QACA,QACA,QACA,QACE,OAAOj4D,KAAKm7D,cACR9Y,EAAM+Y,eACN/Y,EAAMuY,aAEZ,QAEE,QADE56D,KAAK+vD,IACA1N,EAAMgZ,MAEf,QAEE,QADEr7D,KAAK+vD,IACA1N,EAAMiZ,UAEf,QAEE,KADEt7D,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CAExC,GAAO,KADHmuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,MAG7B,QADE/vD,KAAK+vD,IAELuK,EAAiB,GACjBt6D,KAAK+vD,IAAM1jD,GACc,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,QAEnB/vD,KAAK+vD,IACA1N,EAAMiX,0BAERjX,EAAMgW,kBAEf,GAAO,IAAHmC,EAEF,QADEx6D,KAAK+vD,IACA1N,EAAMoV,gBAGjB,OAAOpV,EAAMkV,SAEf,QAEE,KADEv3D,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CAExC,GAAO,KADHmuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,MAG7B,QADE/vD,KAAK+vD,IAELuK,EAAiB,GACjBt6D,KAAK+vD,IAAM1jD,GACc,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,QAEnB/vD,KAAK+vD,IACA1N,EAAMwV,sBAERxV,EAAMsV,cAEf,GAAO,IAAH6C,EAEF,QADEx6D,KAAK+vD,IACA1N,EAAMkZ,mBAGjB,OAAOlZ,EAAM0W,OAEf,QAEE,KADE/4D,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CAExC,GAAO,KADHmuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,MACE,CAE/B,KADE/vD,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CAExC,GAAO,KADPmuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,MAGzB,QADE/vD,KAAK+vD,IAELuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,GACR,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,QAEnB/vD,KAAK+vD,IACA1N,EAAMmX,4CAERnX,EAAMkW,oCAEf,GAAO,IAAHiC,EAEF,QADEx6D,KAAK+vD,IACA1N,EAAMkX,+BAGjB,OAAOlX,EAAMiW,wBAEf,GAAO,IAAHkC,EAEF,QADEx6D,KAAK+vD,IACA1N,EAAMqV,mBAGjB,OAAOrV,EAAMmV,YAEf,QAEE,QADEx3D,KAAK+vD,IACA1N,EAAMmZ,SAEf,QAEE,QADEx7D,KAAK+vD,IACA1N,EAAMoZ,YAEf,QAEE,QADEz7D,KAAK+vD,IACA1N,EAAMqZ,aAEf,QAEE,QADE17D,KAAK+vD,IAELuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,GACR,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,QAEnB/vD,KAAK+vD,IACA1N,EAAMsX,cAERtX,EAAMqW,MAEf,SAEE,QADE14D,KAAK+vD,IACA1N,EAAMsZ,UAEf,SAEE,KADE37D,KAAK+vD,IACHuK,EAAiB,GAAKt6D,KAAK+vD,IAAM1jD,EAAK,CAExC,GAAO,MADHmuD,EAAMvuD,EAAKM,WAAWvM,KAAK+vD,MAG7B,QADE/vD,KAAK+vD,IACA1N,EAAMyW,QAEf,GAAO,IAAH0B,EAEF,QADEx6D,KAAK+vD,IACA1N,EAAMqX,WAGjB,OAAOrX,EAAMoW,IAEf,SAEE,QADEz4D,KAAK+vD,IACA1N,EAAMuZ,WAEf,SAEE,QADE57D,KAAK+vD,IACA1N,EAAMuW,MAEf,QAEE,QADE54D,KAAK+vD,IACA1N,EAAMwZ,GAEf,QACE,GAAIhyD,EAAAiyD,kBAAkBp7D,GAAI,CACxB,GAAImJ,EAAAkyD,mBAAmBr7D,GAAI,CAEzB,IADA,IAAIs7D,EAAYh8D,KAAK+vD,MAEjB/vD,KAAK+vD,IAAM1jD,GACbxC,EAAAoyD,iBAAiBv7D,EAAIuL,EAAKM,WAAWvM,KAAK+vD,OAE1C,IAAKlmD,EAAAkyD,mBAAmBr7D,GAEtB,OADAV,KAAK+vD,IAAMiM,EACJ3Z,EAAMM,WAGjB,IACIuZ,EAAe7G,EADDppD,EAAKQ,UAAUuvD,EAAWh8D,KAAK+vD,MAEjD,GACEmM,IAAiB7Z,EAAMxxC,SACvBupD,IAAuBhF,EAAmB+G,SAExC/B,IAAuBhF,EAAmBgH,SAC1ClF,EAAsBgF,IAGxB,OAAOA,EAETl8D,KAAK+vD,IAAMiM,EAEb,OAAO3Z,EAAMM,WACR,GAAI94C,EAAAwyD,aAAa37D,GAAI,GACxBV,KAAK+vD,IACP,MAOF,OALA/vD,KAAKqN,MACHI,EAAAhD,eAAe6xD,kBACft8D,KAAK+K,MAAM/K,KAAK+vD,IAAK/vD,KAAK+vD,IAAM,MAEhC/vD,KAAK+vD,IACA1N,EAAMxxC,SAInB,OAAOwxC,EAAMka,WAGfzC,EAAA73D,UAAAu6D,KAAA,SACEC,EACArC,EACAsC,QAFA,IAAAD,OAAA,QACA,IAAArC,MAAyChF,EAAmBQ,cAC5D,IAAA8G,MAAyBt5D,IAAIqxC,WAE7B,IAAIxoC,EAAOjM,KAAK2L,OAAOM,KACvB,GAAIjM,KAAKg6D,UAAY,EAAG,CACtB,IAAIgC,EAAYh8D,KAAK+vD,IACjB4M,EAAc38D,KAAKm3D,MACnByF,EAAiB58D,KAAK+5D,SAG1B,GAFA/5D,KAAKg6D,UAAYh6D,KAAKq6D,WAAWD,EAAoBsC,GACrD18D,KAAKi6D,aAAej6D,KAAK+5D,SACrB0C,EAAgB,CAClBz8D,KAAKk6D,oBAAqB,EAC1B,IAAK,IAAInK,EAAMiM,EAAW3vD,EAAMrM,KAAKi6D,aAAclK,EAAM1jD,IAAO0jD,EAC9D,GAAIlmD,EAAAyC,YAAYL,EAAKM,WAAWwjD,IAAO,CACrC/vD,KAAKk6D,oBAAqB,EAC1B,OAINl6D,KAAK+vD,IAAMiM,EACXh8D,KAAKm3D,MAAQwF,EACb38D,KAAK+5D,SAAW6C,EAElB,OAAO58D,KAAKg6D,WAGdF,EAAA73D,UAAA46D,eAAA,SAAezC,GACb,YADa,IAAAA,MAAyChF,EAAmBgH,QAClEp8D,KAAK88D,KAAKza,EAAMM,WAAYyX,IAGrCN,EAAA73D,UAAA66D,KAAA,SAAK3F,EAAciD,QAAA,IAAAA,MAAyChF,EAAmBQ,SAC7E,IAAIoG,EAAYh8D,KAAK+vD,IACjB4M,EAAc38D,KAAKm3D,MACnByF,EAAiB58D,KAAK+5D,SACtB2C,EAAoBt5D,IAAIqxC,UAC5B,OAAQ0iB,GACN,KAAK9U,EAAMmV,YACTkF,EAAoB,EAKxB,OADA18D,KAAKm3D,MAAQn3D,KAAKq6D,WAAWD,EAAoBsC,GAC7C18D,KAAKm3D,OAASA,GAChBn3D,KAAKg6D,WAAa,GACX,IAEPh6D,KAAK+vD,IAAMiM,EACXh8D,KAAKm3D,MAAQwF,EACb38D,KAAK+5D,SAAW6C,GACT,IAIX9C,EAAA73D,UAAA86D,KAAA,WACE,IAAIC,EAUJ,OATIC,GACFD,EAAQC,EACRA,EAAgB,MAEhBD,EAAQ,IAAIE,EAEdF,EAAMjN,IAAM/vD,KAAK+vD,IACjBiN,EAAM7F,MAAQn3D,KAAKm3D,MACnB6F,EAAMjD,SAAW/5D,KAAK+5D,SACfiD,GAGTlD,EAAA73D,UAAAk7D,QAAA,SAAQH,GACNC,EAAgBD,GAGlBlD,EAAA73D,UAAAm7D,MAAA,SAAMJ,GACJh9D,KAAK+vD,IAAMiN,EAAMjN,IACjB/vD,KAAKm3D,MAAQ6F,EAAM7F,MACnBn3D,KAAK+5D,SAAWiD,EAAMjD,SACtB/5D,KAAKg6D,WAAa,GAGpBF,EAAA73D,UAAA8I,MAAA,SAAMqB,EAAiBC,GAOrB,YAPI,IAAAD,OAAc,QAAG,IAAAC,OAAY,GAC7BD,EAAQ,GACVA,EAAQpM,KAAK+5D,SACb1tD,EAAMrM,KAAK+vD,KACF1jD,EAAM,IACfA,EAAMD,GAED,IAAIuP,EAAM3b,KAAK2L,OAAQS,EAAOC,IAGvCytD,EAAA73D,UAAAo7D,eAAA,WAIE,IAHA,IAAIpxD,EAAOjM,KAAK2L,OAAOM,KACnBG,EAAQpM,KAAK+vD,IACb1jD,EAAMrM,KAAKqM,MAEXrM,KAAK+vD,IAAM1jD,GACbxC,EAAAoyD,iBAAiBhwD,EAAKM,WAAWvM,KAAK+vD,QAExC,OAAO9jD,EAAKQ,UAAUL,EAAOpM,KAAK+vD,MAGpC+J,EAAA73D,UAAA6xC,WAAA,WAME,IALA,IAAI7nC,EAAOjM,KAAK2L,OAAOM,KACnBqxD,EAAQrxD,EAAKM,WAAWvM,KAAK+vD,OAC7B3jD,EAAQpM,KAAK+vD,IACb1jD,EAAMrM,KAAKqM,IACXg5B,EAAS,KACA,CACX,GAAIrlC,KAAK+vD,KAAO1jD,EAAK,CACnBg5B,GAAUp5B,EAAKQ,UAAUL,EAAOpM,KAAK+vD,KACrC/vD,KAAKqN,MACHI,EAAAhD,eAAe8yD,4BACfv9D,KAAK+K,MAAMqB,EAAQ,EAAGC,IAExB,MAEF,IAAI3L,EAAIuL,EAAKM,WAAWvM,KAAK+vD,KAC7B,GAAIrvD,GAAK48D,EAAO,CACdj4B,GAAUp5B,EAAKQ,UAAUL,EAAOpM,KAAK+vD,OACrC,MAEF,GAAK,IAADrvD,EAAJ,CAMA,GAAImJ,EAAAyC,YAAY5L,GAAI,CAClB2kC,GAAUp5B,EAAKQ,UAAUL,EAAOpM,KAAK+vD,KACrC/vD,KAAKqN,MACHI,EAAAhD,eAAe8yD,4BACfv9D,KAAK+K,MAAMqB,EAAQ,EAAGpM,KAAK+vD,MAE7B,QAEA/vD,KAAK+vD,SAbL1qB,GAAUp5B,EAAKQ,UAAUL,EAAOpM,KAAK+vD,KACrC1qB,GAAUrlC,KAAKw9D,qBACfpxD,EAAQpM,KAAK+vD,IAajB,OAAO1qB,GAGTy0B,EAAA73D,UAAAu7D,mBAAA,WACE,IAAInxD,EAAMrM,KAAKqM,IACf,KAAMrM,KAAK+vD,KAAO1jD,EAKhB,OAJArM,KAAKqN,MACHI,EAAAhD,eAAegzD,uBACfz9D,KAAK+K,MAAMsB,IAEN,GAGT,IAAIJ,EAAOjM,KAAK2L,OAAOM,KACnBvL,EAAIuL,EAAKM,WAAWvM,KAAK+vD,OAC7B,OAAQrvD,GACN,QAAkB,MAAO,KACzB,QAAiB,MAAO,KACxB,SAAiB,MAAO,KACxB,SAAiB,MAAO,KACxB,SAAiB,MAAO,KACxB,SAAiB,MAAO,KACxB,SAAiB,MAAO,KACxB,QAA2B,MAAO,IAClC,QAA2B,MAAO,IAClC,SACE,OACEV,KAAK+vD,IAAM1jD,GACc,KAAzBJ,EAAKM,WAAWvM,KAAK+vD,QAEnB/vD,KAAK+vD,IACA/vD,KAAK09D,6BAEP19D,KAAK29D,oBAEd,QAEI39D,KAAK+vD,IAAM1jD,GACc,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,QAEnB/vD,KAAK+vD,IAIX,QACA,UACA,UAAkC,MAAO,GACzC,QAAS,OAAO/oD,OAAO42D,aAAal9D,KAIxCo5D,EAAA73D,UAAA47D,kBAAA,WAKE,IAJA,IAAI5xD,EAAOjM,KAAK2L,OAAOM,KACnBG,EAAQpM,KAAK+vD,IACb1jD,EAAMrM,KAAKqM,IACXyxD,GAAU,IACD,CACX,GAAI99D,KAAK+vD,KAAO1jD,EAAK,CACnBrM,KAAKqN,MACHI,EAAAhD,eAAeszD,wCACf/9D,KAAK+K,MAAMqB,EAAOC,IAEpB,MAEF,GAA6B,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,KAAzB,CAKA,IAAIrvD,EAAIuL,EAAKM,WAAWvM,KAAK+vD,KAC7B,IAAK+N,GAAY,IAADp9D,EAAqB,MACrC,GAAImJ,EAAAyC,YAAY5L,GAAI,CAClBV,KAAKqN,MACHI,EAAAhD,eAAeszD,wCACf/9D,KAAK+K,MAAMqB,EAAOpM,KAAK+vD,MAEzB,QAEA/vD,KAAK+vD,IACP+N,GAAU,QAdN99D,KAAK+vD,IACP+N,GAAU,EAed,OAAO7xD,EAAKQ,UAAUL,EAAOpM,KAAK+vD,MAGpC+J,EAAA73D,UAAA+7D,gBAAA,WAKE,IAJA,IAAI/xD,EAAOjM,KAAK2L,OAAOM,KACnBG,EAAQpM,KAAK+vD,IACb1jD,EAAMrM,KAAKqM,IACX2G,EAAQ,EACLhT,KAAK+vD,IAAM1jD,GAAK,CACrB,IAAI3L,EAASuL,EAAKM,WAAWvM,KAAK+vD,KAClC,IAAKlmD,EAAAoyD,iBAAiBv7D,GAAI,MAI1B,SAHEV,KAAK+vD,IAGCrvD,GACN,SACEsS,GAAiB,EAARA,GAAa,EAAI,EAC1B,MAEF,SACEA,GAAiB,EAARA,GAAa,EAAI,EAC1B,MAEF,SACEA,GAAiB,EAARA,GAAa,EAAI,EAC1B,MAEF,QACEA,GAAS,GAWf,OANc,GAAVA,GACFhT,KAAKqN,MACHI,EAAAhD,eAAewzD,iCACfj+D,KAAK+K,MAAMqB,EAAOpM,KAAK+vD,MAGpB9jD,EAAKQ,UAAUL,EAAOpM,KAAK+vD,MAGpC+J,EAAA73D,UAAAk5D,YAAA,WACE,IAAI9uD,EAAMrM,KAAKqM,IACXJ,EAAOjM,KAAK2L,OAAOM,KACvB,GAAIjM,KAAK+vD,IAAM,EAAI1jD,GAAgC,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,KAC7C,OAAQ9jD,EAAKM,WAAWvM,KAAK+vD,IAAM,IACjC,SACA,QACA,QACA,QACA,SACA,QAAiB,OAAO,EAI5B,IADA,IAAIA,EAAM/vD,KAAK+vD,IACRA,EAAM1jD,GAAK,CAChB,IAAI3L,EAAIuL,EAAKM,WAAWwjD,GACxB,GAAK,IAADrvD,GAAsB,KAADA,GAAoB,IAADA,EAAiB,OAAO,EACpE,IAAKA,EAAC,IAAkBA,EAAC,KAAoB,IAADA,EAAiB,MAE7DqvD,IAEF,OAAO,GAGT+J,EAAA73D,UAAAi8D,YAAA,WACE,IAAIjyD,EAAOjM,KAAK2L,OAAOM,KACvB,GAAIjM,KAAK+vD,IAAM,EAAI/vD,KAAKqM,KAAgC,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,KAAqB,CACvE,OAAQ9jD,EAAKM,WAAWvM,KAAK+vD,IAAM,IACjC,SACA,QAEE,OADA/vD,KAAK+vD,KAAO,EACL/vD,KAAKm+D,iBAEd,QACA,QAEE,OADAn+D,KAAK+vD,KAAO,EACL/vD,KAAKo+D,oBAEd,SACA,QAEE,OADAp+D,KAAK+vD,KAAO,EACL/vD,KAAKq+D,mBAGhB,GAAIx0D,EAAAy0D,aAAaryD,EAAKM,WAAWvM,KAAK+vD,IAAM,IAAK,CAC/C,IAAI3jD,EAAQpM,KAAK+vD,MACf/vD,KAAK+vD,IACP,IAAIzuD,EAAQtB,KAAKq+D,mBAKjB,OAJAr+D,KAAKqN,MACHI,EAAAhD,eAAe8zD,8CACfv+D,KAAK+K,MAAMqB,EAAOpM,KAAK+vD,MAElBzuD,GAGX,OAAOtB,KAAKw+D,sBAGd1E,EAAA73D,UAAAk8D,eAAA,WAOE,IANA,IAAIlyD,EAAOjM,KAAK2L,OAAOM,KACnBG,EAAQpM,KAAK+vD,IACbzuD,EAAQiU,QAAQ,GAChBkpD,EAAQlpD,QAAQ,GAChBmpD,EAAStyD,EACTC,EAAMrM,KAAKqM,IACRrM,KAAK+vD,IAAM1jD,GAAK,CACrB,IAAI0jD,EAAM/vD,KAAK+vD,IACXrvD,EAAIuL,EAAKM,WAAWwjD,GACxB,GAAIrvD,GAAC,IAAmBA,GAAC,GAEvBY,EAAQq9D,QACNC,QAAQt9D,EAAOm9D,GACflpD,QAAQ7U,EAAC,UAEL,GAAIA,GAAC,IAAkBA,GAAC,GAE9BY,EAAQq9D,QACNC,QAAQt9D,EAAOm9D,GACflpD,QAAQ,GAAK7U,EAAC,UAEX,GAAIA,GAAC,IAAkBA,GAAC,IAE7BY,EAAQq9D,QACNC,QAAQt9D,EAAOm9D,GACflpD,QAAQ,GAAK7U,EAAC,SAEX,IAAK,IAADA,EAWT,MAVIg+D,GAAU3O,GACZ/vD,KAAKqN,MACHqxD,GAAUtyD,EACNqB,EAAAhD,eAAeo0D,wCACfpxD,EAAAhD,eAAeq0D,0DACnB9+D,KAAK+K,MAAMglD,IAGf2O,EAAS3O,EAAM,EAIjB/vD,KAAK+vD,IAAMA,EAAM,EAanB,OAXI/vD,KAAK+vD,KAAO3jD,EACdpM,KAAKqN,MACHI,EAAAhD,eAAes0D,2BACf/+D,KAAK+K,MAAMqB,IAEJsyD,GAAU1+D,KAAK+vD,KACxB/vD,KAAKqN,MACHI,EAAAhD,eAAeo0D,wCACf7+D,KAAK+K,MAAM2zD,EAAS,IAGjBp9D,GAGTw4D,EAAA73D,UAAAu8D,mBAAA,WAOE,IANA,IAAIvyD,EAAOjM,KAAK2L,OAAOM,KACnBG,EAAQpM,KAAK+vD,IACb1jD,EAAMrM,KAAKqM,IACX/K,EAAQiU,QAAQ,GAChBypD,EAASzpD,QAAQ,IACjBmpD,EAAStyD,EACNpM,KAAK+vD,IAAM1jD,GAAK,CACrB,IAAI0jD,EAAM/vD,KAAK+vD,IACXrvD,EAAIuL,EAAKM,WAAWwjD,GACxB,GAAIrvD,GAAC,IAAmBA,GAAC,GAEvBY,EAAQq9D,QACNM,QAAQ39D,EAAO09D,GACfzpD,QAAQ7U,EAAC,SAEN,IAAK,IAADA,EAWT,MAVIg+D,GAAU3O,GACZ/vD,KAAKqN,MACHqxD,GAAUtyD,EACNqB,EAAAhD,eAAeo0D,wCACfpxD,EAAAhD,eAAeq0D,0DACnB9+D,KAAK+K,MAAMglD,IAGf2O,EAAS3O,EAAM,EAIjB/vD,KAAK+vD,IAAMA,EAAM,EAanB,OAXI/vD,KAAK+vD,KAAO3jD,EACdpM,KAAKqN,MACHI,EAAAhD,eAAey0D,eACfl/D,KAAK+K,MAAMqB,IAEJsyD,GAAU1+D,KAAK+vD,KACxB/vD,KAAKqN,MACHI,EAAAhD,eAAeo0D,wCACf7+D,KAAK+K,MAAM2zD,EAAS,IAGjBp9D,GAGTw4D,EAAA73D,UAAAo8D,iBAAA,WAOE,IANA,IAAIpyD,EAAOjM,KAAK2L,OAAOM,KACnBG,EAAQpM,KAAK+vD,IACbzuD,EAAQiU,QAAQ,GAChB4pD,EAAQ5pD,QAAQ,GAChBmpD,EAAStyD,EACTC,EAAMrM,KAAKqM,IACRrM,KAAK+vD,IAAM1jD,GAAK,CACrB,IAAI0jD,EAAM/vD,KAAK+vD,IACXrvD,EAAIuL,EAAKM,WAAWwjD,GACxB,GAAIrvD,GAAC,IAAmBA,GAAC,GAEvBY,EAAQq9D,QACNC,QAAQt9D,EAAO69D,GACf5pD,QAAQ7U,EAAC,SAEN,IAAK,IAADA,EAWT,MAVIg+D,GAAU3O,GACZ/vD,KAAKqN,MACHqxD,GAAUtyD,EACNqB,EAAAhD,eAAeo0D,wCACfpxD,EAAAhD,eAAeq0D,0DACnB9+D,KAAK+K,MAAMglD,IAGf2O,EAAS3O,EAAM,IAIf/vD,KAAK+vD,IAaT,OAXI/vD,KAAK+vD,KAAO3jD,EACdpM,KAAKqN,MACHI,EAAAhD,eAAe20D,qBACfp/D,KAAK+K,MAAMqB,IAEJsyD,GAAU1+D,KAAK+vD,KACxB/vD,KAAKqN,MACHI,EAAAhD,eAAeo0D,wCACf7+D,KAAK+K,MAAM2zD,EAAS,IAGjBp9D,GAGTw4D,EAAA73D,UAAAm8D,kBAAA,WAOE,IANA,IAAInyD,EAAOjM,KAAK2L,OAAOM,KACnBG,EAAQpM,KAAK+vD,IACbzuD,EAAQiU,QAAQ,GAChB8pD,EAAQ9pD,QAAQ,GAChBmpD,EAAStyD,EACTC,EAAMrM,KAAKqM,IACRrM,KAAK+vD,IAAM1jD,GAAK,CACrB,IAAI0jD,EAAM/vD,KAAK+vD,IACXrvD,EAAIuL,EAAKM,WAAWwjD,GACxB,GAAK,IAADrvD,EAEFY,EAAQs9D,QAAQt9D,EAAO+9D,QAClB,GAAK,IAAD3+D,EAETY,EAAQq9D,QACNC,QAAQt9D,EAAO+9D,GACfA,OAEG,IAAK,IAAD3+D,EAWT,MAVIg+D,GAAU3O,GACZ/vD,KAAKqN,MACHqxD,GAAUtyD,EACNqB,EAAAhD,eAAeo0D,wCACfpxD,EAAAhD,eAAeq0D,0DACnB9+D,KAAK+K,MAAMglD,IAGf2O,EAAS3O,EAAM,EAIjB/vD,KAAK+vD,IAAMA,EAAM,EAanB,OAXI/vD,KAAK+vD,KAAO3jD,EACdpM,KAAKqN,MACHI,EAAAhD,eAAe60D,sBACft/D,KAAK+K,MAAMqB,IAEJsyD,GAAU1+D,KAAK+vD,KACxB/vD,KAAKqN,MACHI,EAAAhD,eAAeo0D,wCACf7+D,KAAK+K,MAAM2zD,EAAS,IAGjBp9D,GAGTw4D,EAAA73D,UAAAs9D,UAAA,WAWE,OAAOv/D,KAAKw/D,oBAGd1F,EAAA73D,UAAAu9D,iBAAA,WAKE,IAHA,IAAIpzD,EAAQpM,KAAK+vD,IACb1jD,EAAMrM,KAAKqM,IACXJ,EAAOjM,KAAK2L,OAAOM,KAChBjM,KAAK+vD,IAAM1jD,GAAOxC,EAAA8wD,eAAe1uD,EAAKM,WAAWvM,KAAK+vD,SACzD/vD,KAAK+vD,IAET,GAAI/vD,KAAK+vD,IAAM1jD,GAAgC,IAAzBJ,EAAKM,WAAWvM,KAAK+vD,KAEzC,MADE/vD,KAAK+vD,IACA/vD,KAAK+vD,IAAM1jD,GAAOxC,EAAA8wD,eAAe1uD,EAAKM,WAAWvM,KAAK+vD,SACzD/vD,KAAK+vD,IAGX,GAAI/vD,KAAK+vD,IAAM1jD,EAAK,CAClB,IAAI3L,EAAIuL,EAAKM,WAAWvM,KAAK+vD,KAC7B,GAAK,KAADrvD,GAAoB,IAADA,EAQrB,OANIV,KAAK+vD,IAAM1jD,GACkB,KAA9B3L,EAAIuL,EAAKM,WAAWvM,KAAK+vD,OAA4B,IAADrvD,GACrDmJ,EAAA8wD,eAAe1uD,EAAKM,WAAWvM,KAAK+vD,IAAM,QAExC/vD,KAAK+vD,IAEF/vD,KAAK+vD,IAAM1jD,GAAOxC,EAAA8wD,eAAe1uD,EAAKM,WAAWvM,KAAK+vD,SACzD/vD,KAAK+vD,IAIb,OAAO0P,WAAWxzD,EAAKQ,UAAUL,EAAOpM,KAAK+vD,OAG/C+J,EAAA73D,UAAAy9D,aAAA,WACE,MAAM,IAAItjD,MAAM,oBAGlB09C,EAAA73D,UAAA07D,kBAAA,WAKE,IAJA,IAAIgC,EAAS,EACTr+D,EAAQ,EACR+K,EAAMrM,KAAKqM,IACXJ,EAAOjM,KAAK2L,OAAOM,KAChBjM,KAAK+vD,IAAM1jD,GAAK,CACrB,IAAI3L,EAAIuL,EAAKM,WAAWvM,KAAK+vD,OAC7B,GAAIrvD,GAAC,IAAmBA,GAAC,GACvBY,GAASA,GAAS,GAAKZ,EAAC,QACnB,GAAIA,GAAC,IAAkBA,GAAC,GAC7BY,GAASA,GAAS,GAAKZ,GAAI,OACtB,MAAIA,GAAC,IAAkBA,GAAC,KAO7B,OAJAV,KAAKqN,MACHI,EAAAhD,eAAes0D,2BACf/+D,KAAK+K,MAAM/K,KAAK+vD,IAAM,EAAG/vD,KAAK+vD,MAEzB,GANPzuD,GAASA,GAAS,GAAKZ,GAAI,GAQ7B,GAAgB,KAAVi/D,EAAa,MAErB,OAAIA,GACF3/D,KAAKqN,MACHI,EAAAhD,eAAegzD,uBACfz9D,KAAK+K,MAAM/K,KAAK+vD,MAEX,IAEF/oD,OAAO42D,aAAat8D,IAGrBw4D,EAAA73D,UAAAy7D,0BAAR,WACE,IAAItxD,EAAQpM,KAAK+vD,IACbzuD,EAAQtB,KAAKm+D,iBACbyB,EAAU1vB,QAAQ5uC,GAClBu+D,GAAU,EAEdz1D,QAAQ+lC,SAAS7uC,IACbs+D,EAAU,UACZ5/D,KAAKqN,MACHI,EAAAhD,eAAeq1D,4EACf9/D,KAAK+K,MAAMqB,EAAOpM,KAAK+vD,MAEzB8P,GAAU,GAGZ,IAAIxzD,EAAMrM,KAAKqM,IACXJ,EAAOjM,KAAK2L,OAAOM,KAiBvB,OAhBIjM,KAAK+vD,KAAO1jD,GACdrM,KAAKqN,MACHI,EAAAhD,eAAegzD,uBACfz9D,KAAK+K,MAAMqB,EAAOC,IAEpBwzD,GAAU,GACwB,KAAzB5zD,EAAKM,WAAWvM,KAAK+vD,OAC5B/vD,KAAK+vD,KAEP/vD,KAAKqN,MACHI,EAAAhD,eAAes1D,qCACf//D,KAAK+K,MAAMqB,EAAOpM,KAAK+vD,MAEzB8P,GAAU,GAGRA,EAAgB,GACbD,EAAU,MACb54D,OAAO42D,aAAagC,GACpB54D,OAAO42D,aACsB,OAA3BgC,EAAU,QAAW,IACM,OAA3BA,EAAU,MAAS,QAI3B9F,EAAA73D,UAAA+9D,OAAA,aAEFlG,EA5lCA,CAA+BrsD,EAAAX,mBAAlBpN,EAAAo6D,YA+lCb,IAAAoD,EAAA,WAOA,OAPA,gBAAax9D,EAAAw9D,QAUb,IAAID,EAA8B,oBC5lDlC,IAAAgD,EAGAA,EAAA,WACA,OAAAjgE,KADA,GAIA,IAEAigE,KAAA,IAAA7rD,SAAA,iBACC,MAAA8rD,GAED,iBAAAC,SAAAF,EAAAE,QAOAxgE,EAAAD,QAAAugE,44BCdA,IAoFYG,EApFZ3yD,EAAAtN,EAAA,GAKAyxD,EAAAzxD,EAAA,GAuBAwN,EAAAxN,EAAA,GA6BAuN,EAAAvN,EAAA,GAQAqN,EAAArN,EAAA,GAKA0J,EAAA1J,EAAA,GAKAiiD,EAAAjiD,EAAA,GAIAkgE,EAAAlgE,EAAA,KAKA,SAAYigE,GAEVA,IAAA,mBAEAA,IAAA,qBAJF,CAAYA,EAAA1gE,EAAA0gE,aAAA1gE,EAAA0gE,WAAU,KAQtB,IAAA9tD,EAAA,SAAArB,GAWE,SAAAqB,EAEEkT,GAFF,IAAAtU,EAIED,EAAAzQ,KAAAR,KAAMwlB,EAAQzY,cAAY/M,YAT5BkR,EAAAovD,sBAA2C,KAE3CpvD,EAAAqvD,yBAA+C,KAQ7CrvD,EAAKsU,QAAUA,IAkvDnB,OAlwD8BjT,EAAAD,EAAArB,GAoB5BqB,EAAArQ,UAAAu+D,YAAA,SAEElc,EAEAmc,EAEAh4C,EAEAi4C,GAIA,QANA,IAAAj4C,MAAA,WAEA,IAAAi4C,MAAyBN,EAAWO,QAIhCrc,EAAK7tC,MAAQ9I,EAAA+I,SAASm3C,aAAc,CACtC,IAAIrK,EAAsCc,EAAMd,iBAC5Cz5B,EAAwB,KAC5B,GAAIy5B,KACFz5B,EAAW/pB,KAAKwgE,YACdhd,EACAid,EACAh4C,EACAi4C,IAEa,OAAO,KAQxB,IANA,IAAIE,EAAoCtc,EAAMf,WAC1CoR,EAAgBiM,EAAez0D,OAC/B6d,EAAiB,IAAI/iB,MAAY0tD,GACjCT,EAAiB,IAAIjtD,MAAc0tD,GACnCR,EAAqB,EACrBC,GAAU,EACL/zD,EAAI,EAAGA,EAAIs0D,IAAiBt0D,EAAG,CACtC,IAAIwgE,EAAgBD,EAAevgE,GACnC,OAAQwgE,EAAc7c,eACpB,KAAKr2C,EAAAogD,cAAc6H,QACjBzB,EAAqB9zD,EAAI,EACzB,MAEF,KAAKsN,EAAAogD,cAAc+S,KACjB12D,OAAO/J,GAAKs0D,GACZP,GAAU,EAId,IAAI2M,EAAoBF,EAAc5hD,KACtC,GAAItR,EAAAgkD,cAAcoP,GAOhB,OANIL,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACfD,EAAkBh2D,OAGf,KAET,IAAIkf,EAAgBjqB,KAAKwgE,YACvBO,EACAN,EACAh4C,EACAi4C,GAEF,IAAKz2C,EAAe,OAAO,KAC3BD,EAAe3pB,GAAK4pB,EACpBiqC,EAAe7zD,GAAKwgE,EAAcjgE,KAAKqL,KAEzC,IAAIg1D,EAAoC3c,EAAMlZ,WAC9C,GAAIz9B,EAAAgkD,cAAcsP,GAOhB,OANIP,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACfC,EAAel2D,OAGZ,KAET,IAAIqgC,OAAU,EACd,GAAI61B,GAOF,KANA71B,EAAaprC,KAAKwgE,YAChBS,EACAR,EACAh4C,EACAi4C,IAEe,OAAO,UAExBt1B,EAAa19B,EAAAkH,KAAKG,KAEpB,IAAId,EAAY,IAAIvG,EAAA0Y,UAAU4D,EAAgBohB,EAAYrhB,GAI1D,OAHA9V,EAAUigD,eAAiBA,EAC3BjgD,EAAUkgD,mBAAqBA,EAC/BlgD,EAAUmgD,QAAUA,EACb9P,EAAKjB,WAAapvC,EAAUgL,KAAK+zC,aAAe/+C,EAAUgL,KAInE7U,OAAOk6C,EAAK7tC,MAAQ9I,EAAA+I,SAASk3C,WAC7B,IAAIsT,EAA0B5c,EAC1B/Y,EAAW21B,EAAStgE,KACpBugE,EAAoBD,EAASj1C,cAC7Bm1C,GAAgB71B,EAAStzB,KAG7B,GAAImpD,GACE34C,GAA2BA,EAAwBjU,IAAI+2B,EAASj4B,WAAWrH,MAAO,CACpF,IAAIgT,EAAOwJ,EAAwBvnB,IAAIqqC,EAASj4B,WAAWrH,MAS3D,OAR0B,OAAtBk1D,GAA8BA,EAAkBh1D,QAC9Cu0D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe42D,sBACf/c,EAAKv5C,MAAOkU,EAAKvT,YAInB44C,EAAKjB,YACFpkC,EAAKK,GAAE,MACNohD,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe62D,gCACfhd,EAAKv5C,MAAOkU,EAAKvT,YAIhBuT,EAAK+zC,cAEP/zC,EAKX,IAAIrG,EAAU5Y,KAAKmb,gBAAgBowB,EAAUk1B,EAASC,GACtD,IAAK9nD,EAAS,OAAO,KAGrB,GAAIA,EAAQ6M,WACV7M,EAAUA,EAAQ6M,eAEb,CAEL,GAAI7M,EAAQnC,MAAQm7C,EAAA9gD,YAAYkW,KAiB9B,OAhB0B,OAAtBm6C,GAA8BA,EAAkBh1D,QAC9Cu0D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe42D,sBACf/c,EAAKv5C,MAAO6N,EAAQxG,cAItBkyC,EAAKjB,YACHqd,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe62D,gCACfhd,EAAKv5C,MAAO6N,EAAQhY,MAInB8M,EAAAkH,KAAKxR,IAId,GAAIwV,EAAQnC,MAAQm7C,EAAA9gD,YAAYuJ,gBAAiB,CAC/C,IAAIkO,EAAWvoB,KAAKuhE,8BACF3oD,EAChBuoD,EACAV,EACA52D,EAAA23D,QAAqB/4C,GACrB67B,GAEF,OAAK/7B,EACE+7B,EAAKjB,WAAa96B,EAAStJ,KAAK+zC,aAAezqC,EAAStJ,KADzC,MAM1B,GAAIrG,EAAQnC,MAAQm7C,EAAA9gD,YAAY8V,eAAgB,CAG9C,GAAIhO,EAAQ0G,GAAG9R,EAAAnL,YAAY6jB,UAAW,CACV,OAAtBi7C,GAA8BA,EAAkBh1D,QAC9Cu0D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe42D,sBACf/c,EAAKv5C,MAAO6N,EAAQxG,cAI1B,IAAIqvD,EAAwB7oD,EAASqG,KACrC,GAAIqlC,EAAKjB,WAAY,CACnB,GAAKoe,EAAKniD,GAAE,KAQV,OAAOmiD,EAAKzO,aAPR0N,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe62D,gCACfJ,EAAStgE,KAAKmK,MAAOwgC,EAASj4B,WAAWrH,MAOjD,OAAOw1D,EAIT,GAAIL,EACF,OAAQ71B,EAASj4B,WAAWqxC,QAC1B,KAAKn3C,EAAAxK,cAAc8B,OAAQ,OAAO9E,KAAK0hE,yBAAyBR,EAAUT,EAASh4C,EAAyBi4C,GAC5G,KAAKlzD,EAAAxK,cAAc+B,QAAS,OAAO/E,KAAK2hE,0BAA0BT,EAAUT,EAASh4C,EAAyBi4C,GAC9G,KAAKlzD,EAAAxK,cAAcgC,QAAS,OAAOhF,KAAK4hE,0BAA0BV,EAAUT,EAASh4C,EAAyBi4C,GAKlH,IAAI3zC,EAAsCnU,EAASmU,mBAEnD,GAAIA,GASF,IARgB/sB,KAAK6hE,qBACnB90C,EACAo0C,EACAV,EACAh4C,EAA0B5e,EAAA23D,QAAQ/4C,GAClC67B,EACAoc,GAEkB,OAAO,UAClBS,GAAqBA,EAAkBh1D,QAChDnM,KAAKqN,MACHI,EAAAhD,eAAe42D,sBACfH,EAASn2D,MAAOwgC,EAASj4B,WAAWrH,MAUxC,KANIgT,EAAOjf,KAAKwgE,YACG5nD,EAASsoD,SAC1BtoD,EACA6P,EACAi4C,IAES,OAAO,KAClB,GAAIpc,EAAKjB,WAAY,CACnB,GAAKpkC,EAAKK,GAAE,KAQV,OAAOL,EAAK+zC,aAPR0N,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe62D,gCACfJ,EAAStgE,KAAKmK,MAAOwgC,EAASj4B,WAAWrH,MAOjD,OAAOgT,EAQT,OANIyhD,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACfZ,EAAStgE,KAAKmK,MAAOwgC,EAASj4B,WAAWrH,MAGtC,MAGDqG,EAAArQ,UAAAy/D,yBAAR,SAEER,EAEAT,EAEAh4C,EAEAi4C,QAFA,IAAAj4C,MAAA,WAEA,IAAAi4C,MAAyBN,EAAWO,QAEpC,IAAIQ,EAAoBD,EAASj1C,cACjC,IAAMk1C,GAAiD,GAA5BA,EAAkBh1D,OAO3C,OANIu0D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAes3D,oCACfb,EAASn2D,MAAO,KAAMo2D,EAAoBA,EAAkBh1D,OAAS,GAAGT,SAAS,KAG9E,KAET,IAAIs2D,EAAehiE,KAAKwgE,YAAYW,EAAkB,GAAIV,EAASh4C,EAAyBi4C,GAC5F,IAAKsB,EAAc,OAAO,KAC1B,OAAQA,EAAavrD,MACnB,OACA,OACA,OAAmB,OAAO/I,EAAAkH,KAAKxR,IAC/B,OAAqB,IAAKpD,KAAKwlB,QAAQ9Q,QAAQc,SAAU,OAAO9H,EAAAkH,KAAKxR,IACrE,OAAmB,OAAOsK,EAAAkH,KAAKvR,IAC/B,OACA,OACA,OACA,QAAoB,OAAOqK,EAAAkH,KAAKnR,IAChC,OAAqB,IAAKzD,KAAKwlB,QAAQ9Q,QAAQc,SAAU,OAAO9H,EAAAkH,KAAKnR,IACrE,OAAmB,OAAOiK,EAAAkH,KAAKlR,IAC/B,QAAmB,OAAOgK,EAAAkH,KAAK/Q,IAC/B,QAAmB,OAAO6J,EAAAkH,KAAK9Q,IAC/B,QAAoB,OAAO4J,EAAAkH,KAAK7Q,KAChC,QAAoB,OAAO2J,EAAAkH,KAAKG,KAChC,QAAS3K,QAAO,GAElB,OAAO,MAGDkI,EAAArQ,UAAA0/D,0BAAR,SAEET,EAEAT,EAEAh4C,EAEAi4C,QAFA,IAAAj4C,MAAA,WAEA,IAAAi4C,MAAyBN,EAAWO,QAEpC,IAAIQ,EAAoBD,EAASj1C,cACjC,IAAMk1C,GAAiD,GAA5BA,EAAkBh1D,OAO3C,OANIu0D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAes3D,oCACfb,EAASn2D,MAAO,KAAMo2D,EAAoBA,EAAkBh1D,OAAS,GAAGT,SAAS,KAG9E,KAET,IAAIs2D,EAAehiE,KAAKwgE,YAAYW,EAAkB,GAAIV,EAASh4C,EAAyBi4C,GAC5F,IAAKsB,EAAc,OAAO,KAC1B,IAAIrzC,EAAiBqzC,EAAarzC,eAClC,IAAKA,EAOH,OANI+xC,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAew3D,qCACfd,EAAkB,GAAGp2D,MAAOi3D,EAAat2D,YAGtC,KAET,IAAI8hB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAasB,aAC1D,OAAI2e,EACEA,EAASlO,GAAG9R,EAAAnL,YAAY6f,SAC1B9X,OAAmD,GAA5CojB,EAASvZ,UAAU+V,eAAe7d,QAClCqhB,EAASvZ,UAAU+V,eAAe,KAEzC5f,OAAmD,GAA5CojB,EAASvZ,UAAU+V,eAAe7d,QAClCqhB,EAASvZ,UAAU+V,eAAe,KAGzC02C,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAew3D,qCACfd,EAAkB,GAAGp2D,MAAOi3D,EAAat2D,YAGtC,OAGD4G,EAAArQ,UAAA2/D,0BAAR,SAEEV,EAEAT,EAEAh4C,EAEAi4C,QAFA,IAAAj4C,MAAA,WAEA,IAAAi4C,MAAyBN,EAAWO,QAEpC,IAAIQ,EAAoBD,EAASj1C,cACjC,IAAMk1C,GAAiD,GAA5BA,EAAkBh1D,OAO3C,OANIu0D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAes3D,oCACfb,EAASn2D,MAAO,KAAMo2D,EAAoBA,EAAkBh1D,OAAS,GAAGT,SAAS,KAG9E,KAET,IAAIs2D,EAAehiE,KAAKwgE,YAAYW,EAAkB,GAAIV,EAASh4C,EAAyBi4C,GAC5F,IAAKsB,EAAc,OAAO,KAC1B,IAAIrzC,EAAiBqzC,EAAarzC,eAClC,IAAKA,EAOH,OANI+xC,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAew3D,qCACfd,EAAkB,GAAGp2D,MAAOi3D,EAAat2D,YAGtC,KAGT,IAAI8hB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAasB,aAC1D,OAAI2e,EAAiBA,EAASvZ,UAAUm3B,YACpCs1B,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAew3D,qCACfd,EAAkB,GAAGp2D,MAAOi3D,EAAat2D,YAGtC,OAIT4G,EAAArQ,UAAAkZ,gBAAA,SAEEowB,EAEAk1B,EAEAC,QAAA,IAAAA,MAAaN,EAAWO,QAExB,IAAI/nD,EAAU6nD,EAAQn6C,OAAOilB,EAASj4B,WAAWrH,MACjD,IAAK2M,EAOH,OANI8nD,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACfv2B,EAASxgC,MAAOwgC,EAASj4B,WAAWrH,MAGjC,KAIT,IAFA,IAAIi2D,EAAO32B,EACPtzB,EAAOszB,EAAStzB,KACbA,GAAM,CACX,KAAMW,EAAUA,EAAQe,aAAa1B,EAAK3E,WAAWrH,OAOnD,OANIy0D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe03D,oCACflqD,EAAKlN,MAAOkN,EAAK3E,WAAWrH,KAAMi2D,EAAK5uD,WAAWrH,MAG/C,KAETi2D,EAAOjqD,EACPA,EAAOA,EAAKA,KAEd,OAAOW,GAITtG,EAAArQ,UAAA4/D,qBAAA,SAEE/6C,EAEAq6C,EAEAV,EAEAh4C,EAEA25C,EAEA1B,QAJA,IAAAj4C,MAA4C5e,EAAA23D,gBAE5C,IAAAY,MAAA,WAEA,IAAA1B,MAAyBN,EAAWO,QAIpC,IAFA,IAAI0B,EAAoB,EACpBC,EAAoB,EACfjiE,EAAI,EAAG+V,EAAI0Q,EAAe3a,OAAQ9L,EAAI+V,IAAK/V,EAC7CymB,EAAezmB,GAAGsjD,eAAe0e,IACpCC,EAEJ,IAAIC,EAAgBpB,EAAoBA,EAAkBh1D,OAAS,EACnE,GAAIo2D,EAAgBF,GAAqBE,EAAgBD,EAYvD,OAXAtiE,KAAKqN,MACHI,EAAAhD,eAAes3D,oCACfQ,EACI50D,EAAAgO,MAAMhP,KACcw0D,EAAmB,GAAGp2D,MACtBo2D,EAAmBoB,EAAgB,GAAGx3D,OAE1DX,OAAOg4D,GAAuBr3D,OACjCw3D,EAAgBF,EAAoBA,EAAoBC,GAAmB52D,SAAS,IACrF62D,EAAc72D,SAAS,KAElB,KAET,IAAIugB,EAAgB,IAAIhlB,MAAYq7D,GACpC,IAASjiE,EAAI,EAAGA,EAAIiiE,IAAqBjiE,EAAG,CAC1C,IAAI4e,EAAO5e,EAAIkiE,EACXviE,KAAKwgE,YACeW,EAAmB9gE,GACrCogE,EACAh4C,EACAi4C,GAEF1gE,KAAKwgE,YACHp2D,OAAO0c,EAAezmB,GAAGsjD,aACzB8c,EACAh4C,EACAi4C,GAEN,IAAKzhD,EAAM,OAAO,KAElBwJ,EAAwBtW,IAAI2U,EAAezmB,GAAGO,KAAKqL,KAAMgT,GACzDgN,EAAc5rB,GAAK4e,EAErB,OAAOgN,GAIT3Z,EAAArQ,UAAAugE,kBAAA,SAEElvD,EAEA8W,EAEAq2C,EAEAC,QAAA,IAAAA,MAAyBN,EAAWO,QAEpC,IACI/nD,EADAhY,EAAO0S,EAAWrH,KAEtB,OAAIme,IACExR,EAAUwR,EAAK9D,OAAO1lB,KACxBZ,KAAKsgE,sBAAwB,KAC7BtgE,KAAKugE,yBAA2B,KACzB3nD,GAGP6nD,IACE7nD,EAAU6nD,EAAQn6C,OAAO1lB,KAC3BZ,KAAKsgE,sBAAwB,KAC7BtgE,KAAKugE,yBAA2B,KACzB3nD,IAGPA,EAAU5Y,KAAKwlB,QAAQ3L,aAAajZ,KACtCZ,KAAKsgE,sBAAwB,KAC7BtgE,KAAKugE,yBAA2B,KACzB3nD,IAEL8nD,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACfxuD,EAAWvI,MAAOnK,GAGf,OAIT0R,EAAArQ,UAAAwgE,yBAAA,SAAyBljD,EAAgBmhD,GACvC,QADuC,IAAAA,MAAyBN,EAAWO,QACvEphD,EAAOD,GAAG9R,EAAAnL,YAAY6jB,UAAW,OAAO,EAC5C,IAAIg7C,EAAW3hD,EAAO2hD,SACtB,IAAKA,EAAU,OAAO,EACtB,IAAIjiD,EAAOjf,KAAKwgE,YACdU,EACA3hD,EAAOrL,OACP,KACAwsD,GAEF,QAAKzhD,IACLM,EAAOL,QAAQD,IACR,IAIT3M,EAAArQ,UAAAygE,gCAAA,SAEEC,EAEAv4C,EAEAw4C,EAEAlC,QAAA,IAAAA,MAAyBN,EAAWO,QAEpC,IAAIkC,EAAmBF,EAAe34B,WAClC3c,EAASrtB,KAAK8iE,kBAAkBD,EAAkBz4C,EAAMw4C,EAAgBlC,GAC5E,IAAKrzC,EAAQ,OAAO,KACpB,IAAI01C,EAAeJ,EAAe3gE,SAASiK,KAG3C,OAAQohB,EAAO5W,MACb,KAAKm7C,EAAA9gD,YAAYmQ,OAAQ,IAAKjhB,KAAKyiE,yBAAiCp1C,EAAQqzC,GAAa,OAAO,KAChG,KAAK9O,EAAA9gD,YAAY+W,MACjB,KAAK+pC,EAAA9gD,YAAY8N,MACf,IAAIK,EAA6BoO,EAAQpO,KAEzC,GAF+C7U,OAAO6U,GAAQvR,EAAAkH,KAAKG,QAC/D4Z,EAAiB1P,EAAK0P,gBACL,CACnB,IAAIld,EAAczR,KAAKwlB,QAAQ/T,YAC/B,GAAKwN,EAAKK,GAAE,OAAyB7N,EAAY+C,IAAIyK,EAAKxI,MAOxD,OAJAzW,KAAKqN,MACHI,EAAAhD,eAAe03D,oCACfQ,EAAe3gE,SAAS+I,MAAOg4D,EAAoC11C,EAAQpO,KAAKvT,YAE3E,KANPijB,EAAiBld,EAAYvQ,IAAI+d,EAAKxI,MAS1C4W,EAASsB,EACT,MAEF,KAAKijC,EAAA9gD,YAAYyN,mBAOf,KANIkN,EAAiBzrB,KAAKie,gBACxB7T,OAA2BijB,EAAQ7O,iBACnC,KACA3U,EAAA23D,UACAd,IAEmB,OAAO,KAE5B,KADI/xC,EAAiBlD,EAAexX,UAAUm3B,WAAWzc,gBAMvD,OAJA3uB,KAAKqN,MACHI,EAAAhD,eAAe03D,oCACfQ,EAAe3gE,SAAS+I,MAAOg4D,EAAct3C,EAAexX,UAAUm3B,WAAW1/B,YAE5E,KAET2hB,EAASsB,EACT,MAEF,KAAKijC,EAAA9gD,YAAY4N,SACf,IAAI+M,EAEJ,KADIkD,GADAlD,EAAiBrhB,OAAkBijB,EAAQ5B,iBACXxX,UAAUm3B,WAAWzc,gBAMvD,OAJA3uB,KAAKqN,MACHI,EAAAhD,eAAe03D,oCACfQ,EAAe3gE,SAAS+I,MAAOg4D,EAAct3C,EAAexX,UAAUm3B,WAAW1/B,YAE5E,KAET2hB,EAASsB,EACT,MAEF,KAAKijC,EAAA9gD,YAAY+N,MACf,IAAIsnC,EAAoBnmD,KAAKugE,yBAC7B,GAAIpa,EAAmB,CAGnB,IAAI6c,EAAqB31C,EAAQF,eAAeykC,EAAArkD,aAAasB,aAC7D,IAAKm0D,EAKH,OAJAhjE,KAAKqN,MACHI,EAAAhD,eAAew3D,qCACf9b,EAAkBp7C,MAAesiB,EAAQjb,cAEpC,KAET,IAAI6wD,EAAYD,EAAW/uD,UAAUm3B,WAIvC,KADIzc,EAAiBs0C,EAAUt0C,gBACV,CACfld,EAAczR,KAAKwlB,QAAQ/T,YAC/B,GAAKwxD,EAAU3jD,GAAE,OAAyB7N,EAAY+C,IAAIyuD,EAAUxsD,MAOlE,OAJAzW,KAAKqN,MACDI,EAAAhD,eAAe03D,oCACfQ,EAAe3gE,SAAS+I,MAAOg4D,EAAcE,EAAUv3D,YAEpD,KANPijB,EAAiBld,EAAYvQ,IAAI+hE,EAAUxsD,MAS/C4W,EAASsB,EAEX,MAEF,KAAKijC,EAAA9gD,YAAYkN,mBACf,IAAIyH,EAAa4H,EAAO5H,WACxB,GAAIA,EAAY,CACd,IAAKA,EAAWnG,GAAG9R,EAAAnL,YAAY6jB,UAAW,CACxC,IAAIg9C,EAAeljE,KAAKwgE,YAAY/6C,EAAWy7C,SAAUz7C,EAAWvR,OAAQ,KAAMwsD,GAC9EwC,GAAcz9C,EAAWvG,QAAQgkD,GAEvC,IAAIv0C,KAAiBlJ,EAAWxG,KAAK0P,kBACjBtB,EAASsB,EAAe1sB,WAC5C,OAMN,OAAQorB,EAAO5W,MACb,KAAKm7C,EAAA9gD,YAAYuJ,gBACjB,KAAKu3C,EAAA9gD,YAAY+N,MACf,OAAG,CAED,IADIC,EAAUuO,EAAOvO,UACNA,EAAQtK,IAAIuuD,GAGzB,OAFA/iE,KAAKsgE,sBAAwBuC,EAC7B7iE,KAAKugE,yBAA2B,KACzBzhD,EAAQ5d,IAAI6hE,GAGrB,GAAI11C,EAAO5W,MAAQm7C,EAAA9gD,YAAYuJ,gBAAiB,CAC9C,IAAqBgT,EAAQjS,cAG3B,MAFAiS,EAA0CA,EAAQjS,kBAK/C,IAAIiS,EAAO5W,MAAQm7C,EAAA9gD,YAAY+N,MAOpC,MANA,IAAYwO,EAAQnB,KAGlB,MAFAmB,EAAwBA,EAAQnB,MAQtC,MAEF,QACE,IAAIpN,EACJ,IADIA,EAAUuO,EAAOvO,UACNA,EAAQtK,IAAIuuD,GAGzB,OAFA/iE,KAAKsgE,sBAAwBuC,EAC7B7iE,KAAKugE,yBAA2B,KACzBzhD,EAAQ5d,IAAI6hE,GAUzB,OAJA/iE,KAAKqN,MACHI,EAAAhD,eAAe03D,oCACfQ,EAAe3gE,SAAS+I,MAAOg4D,EAAc11C,EAAOjb,cAE/C,MAITE,EAAArQ,UAAAkhE,+BAAA,SAEEC,EAEAh5C,EAEAw4C,EAEAlC,QAAA,IAAAA,MAAyBN,EAAWO,QAEpC,IAAIkC,EAAmBO,EAAcp5B,WACjC3c,EAASrtB,KAAK8iE,kBAAkBD,EAAkBz4C,EAAMw4C,EAAgBlC,GAC5E,IAAKrzC,EAAQ,OAAO,KACpB,OAAQA,EAAO5W,MACb,KAAKm7C,EAAA9gD,YAAYmQ,OAAQ,IAAKjhB,KAAKyiE,yBAAiCp1C,EAAQqzC,GAAa,OAAO,KAChG,KAAK9O,EAAA9gD,YAAY+W,MACjB,KAAK+pC,EAAA9gD,YAAY8N,MAEf,GAAIyO,EAD6BA,EAAQpO,KACvB0P,eAGhB,OAFA3uB,KAAKsgE,sBAAwBuC,EAC7B7iE,KAAKugE,yBAA2B6C,EAAcjd,kBACvC94B,EAET,MAEF,KAAKukC,EAAA9gD,YAAY+N,MAGb,IAAImkD,EAAqB31C,EAAQF,eAAeykC,EAAArkD,aAAasB,aAC7D,IAAKm0D,EAOH,OANItC,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAew3D,qCACfmB,EAAcr4D,MAAesiB,EAAQjb,cAGlC,KAET,IAAI6wD,EAAYD,EAAW/uD,UAAUm3B,WAEvC,OAAIy3B,EAAiBpsD,MAAQ9I,EAAA+I,SAASosC,eAChCz1B,EAAS41C,EAAUt0C,iBACrB3uB,KAAKsgE,sBAAwBuC,EAC7B7iE,KAAKugE,yBAA2B6C,EAAcjd,kBACvC94B,GAEF,MAETrtB,KAAKsgE,sBAAwBuC,EAC7B7iE,KAAKugE,yBAA2B6C,EAAcjd,kBACvC94B,GASX,OANIqzC,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACfwhD,EAAiB93D,OAGd,MAITuH,EAAArQ,UAAAohE,4BAAA,SAEEC,EAEAV,GAEA,IAAKA,EAAetjD,GAAE,KAEpB,OAAQsjD,EAAensD,MACrB,OACE,GAAI8sD,UAAUD,GAAW,OAAO51D,EAAAkH,KAAK1R,GACrC,MAEF,OACE,GAAIsgE,UAAUF,GAAW,OAAO51D,EAAAkH,KAAKrR,GACrC,MAEF,OACE,GAAIkgE,WAAWH,GAAW,OAAO51D,EAAAkH,KAAKzR,IACtC,MAEF,OACE,GAAIugE,WAAWJ,GAAW,OAAO51D,EAAAkH,KAAKpR,IACtC,MAEF,OACE,GAAImgE,WAAWL,GAAW,OAAO51D,EAAAkH,KAAKxR,IACtC,MAEF,OACE,GAAIwgE,WAAWN,GAAW,OAAO51D,EAAAkH,KAAKnR,IACtC,MAEF,QACE,GAAIogE,YAAYP,GAAW,OAAO51D,EAAAkH,KAAKhR,KACvC,MAEF,OACE,IAAK5D,KAAKwlB,QAAQ9Q,QAAQc,SAAU,CAClC,GAAImuD,WAAWL,GAAW,OAAO51D,EAAAkH,KAAK29C,QACtC,MAEF,OAAO7kD,EAAAkH,KAAK09C,QAEd,OACE,IAAKtyD,KAAKwlB,QAAQ9Q,QAAQc,SAAU,CAClC,GAAIouD,WAAWN,GAAW,OAAO51D,EAAAkH,KAAK69C,QACtC,MAEF,OAAO/kD,EAAAkH,KAAK49C,QAEd,OAAmB,OAAO9kD,EAAAkH,KAAKvR,IAC/B,OAAmB,OAAOqK,EAAAkH,KAAKlR,IAC/B,QAAmB,OAAOgK,EAAAkH,KAAK/Q,IAC/B,QAAmB,OAAO6J,EAAAkH,KAAK9Q,IAC/B,QAAoB,MACpB,QAASsG,QAAO,GAIpB,OAAIu5D,WAAWL,GAAkB51D,EAAAkH,KAAKxR,IAClCwgE,WAAWN,GAAkB51D,EAAAkH,KAAKnR,IAC/BiK,EAAAkH,KAAKvR,KAIdiP,EAAArQ,UAAA6gE,kBAAA,SAEE94B,EAEA5f,EAEAw4C,EAEAlC,GAEA,SAJA,IAAAkC,MAAuBl1D,EAAAkH,KAAKG,WAE5B,IAAA2rD,MAAyBN,EAAWO,QAE7B32B,EAAWvzB,MAAQ9I,EAAA+I,SAASqsC,eACjC/Y,EAAuCA,EAAYA,WAErD,OAAQA,EAAWvzB,MACjB,KAAK9I,EAAA+I,SAASksC,UACZ,OAAO5iD,KAAK8jE,2BACW95B,EACrB5f,EAAMw4C,EAAgBlC,GAG1B,KAAK/yD,EAAA+I,SAAS+4C,YACZ,OAAOzvD,KAAK+jE,6BACa/5B,EACvB5f,EAAMw4C,EAAgBlC,GAG1B,KAAK/yD,EAAA+I,SAAS84C,aACZ,OAAOxvD,KAAKgkE,8BACch6B,EACxB5f,EAAMw4C,EAAgBlC,GAG1B,KAAK/yD,EAAA+I,SAASk4C,OACZ,OAAO5uD,KAAKikE,wBACQj6B,EAClB5f,EAAMw4C,EAAgBlC,GAG1B,KAAK/yD,EAAA+I,SAAS44C,KACZ,OAAOtvD,KAAKkkE,sBACMl6B,EAChB5f,EAAMw4C,EAAgBlC,GAG1B,KAAK/yD,EAAA+I,SAASusC,MACZ,OAAOjjD,KAAKmkE,uBACOn6B,EACjB5f,EAAMw4C,EAAgBlC,GAG1B,KAAK/yD,EAAA+I,SAASisC,WACZ,OAAO3iD,KAAKwiE,kBACYx4B,EACtB5f,EAAMA,EAAKg6C,eAAgB1D,GAG/B,KAAK/yD,EAAA+I,SAASwM,QACZ,OAAOljB,KAAKqkE,yBACSr6B,EACnB5f,EAAMw4C,EAAgBlC,GAG1B,KAAK/yD,EAAA+I,SAASssC,eACZ,OAAOhjD,KAAK0iE,gCACgB14B,EAC1B5f,EAAMw4C,EAAgBlC,GAG1B,KAAK/yD,EAAA+I,SAASosC,cACZ,OAAO9iD,KAAKmjE,+BACen5B,EACzB5f,EAAMw4C,EAAgBlC,GAG1B,KAAK/yD,EAAA+I,SAASmsC,KACZ,OAAO7iD,KAAKskE,sBACMt6B,EAChB5f,EAAMw4C,EAAgBlC,GAW5B,OANIA,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAGR,MAITuH,EAAArQ,UAAA6hE,2BAAA,SAEE95B,EAEA5f,EAEAw4C,EAEAlC,GAEA,QAJA,IAAAkC,MAAuBl1D,EAAAkH,KAAKG,WAE5B,IAAA2rD,MAAyBN,EAAWO,QAEhC32B,EAAWib,eAAiBt3C,EAAAghD,cAAc4V,QAC5C,OAAOvkE,KAAK8iE,kBACV94B,EAAWA,WACX5f,EACAw4C,EACAlC,GAGJ,IAAIzhD,EAAOjf,KAAKwgE,YACdp2D,OAAO4/B,EAAWkb,QAClB96B,EAAKg6C,eACLh6C,EAAK3B,wBACLi4C,GAEF,IAAKzhD,EAAM,OAAO,KAClB,IAAIrG,EAA0BqG,EAAK0P,eACnC,IAAK/V,EAAS,CACZ,IAAI3E,EAAYgL,EAAKmzC,mBACrB,IAAKn+C,EAAW,OAAO,KACvB2E,EAAU3E,EAAUogD,iBAAiBr0D,KAAKwlB,SAI5C,OAFAxlB,KAAKsgE,sBAAwB,KAC7BtgE,KAAKugE,yBAA2B,KACzB3nD,GAITtG,EAAArQ,UAAA8hE,6BAAA,SAEE/5B,EAEA5f,EAEAw4C,EAEAlC,QAFA,IAAAkC,MAAuBl1D,EAAAkH,KAAKG,WAE5B,IAAA2rD,MAAyBN,EAAWO,QAEpC,IAAIjY,EAAU1e,EAAW0e,QAEzB,OAAQ1e,EAAWqb,UACjB,KAAKjD,EAAAC,MAAM/xC,MAET,GAAIo4C,EAAQjyC,MAAQ9I,EAAA+I,SAASwM,SAA+BwlC,EAASvlC,aAAexV,EAAAyV,YAAY6rC,QAAS,CACvG,IAAIhwC,EAAOjf,KAAKqjE,4BACdmB,QAAQC,SAAqC/b,EAASpnD,OACtDshE,GAGF,OADInxD,EAAczR,KAAKwlB,QAAQ/T,aACZ+C,IAAIyK,EAAKxI,MAAQhF,EAAYvQ,IAAI+d,EAAKxI,MAAS,KAEpE,OAAOzW,KAAK8iE,kBACVpa,EACAt+B,EACAw4C,EACAlC,GAGJ,KAAKte,EAAAC,MAAMjyC,KACX,KAAKgyC,EAAAC,MAAM8V,UACX,KAAK/V,EAAAC,MAAM+V,YACT,OAAOp4D,KAAK8iE,kBACV94B,EAAW0e,QACXt+B,EACAw4C,EACAlC,GAGJ,KAAKte,EAAAC,MAAMsW,YACT,IAAIlnD,EACJ,OADIA,EAAczR,KAAKwlB,QAAQ/T,aACZ+C,IAAG,IAAkB/C,EAAYvQ,IAAG,IAAmB,KAE5E,KAAKkhD,EAAAC,MAAMuW,MAOT,IANsB54D,KAAK8iE,kBACzB94B,EAAW0e,QACXt+B,EACAw4C,EACAlC,GAEoB,OAAO,KAE7B,MAEF,QAASt2D,QAAO,GAQlB,OANIs2D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAGR,MAITuH,EAAArQ,UAAA+hE,8BAAA,SAEEh6B,EAEA5f,EAEAw4C,EAEAlC,GAGA,YALA,IAAAkC,MAAuBl1D,EAAAkH,KAAKG,WAE5B,IAAA2rD,MAAyBN,EAAWO,QAG5B32B,EAAWqb,UACjB,KAAKjD,EAAAC,MAAM8V,UACX,KAAK/V,EAAAC,MAAM+V,YACT,OAAOp4D,KAAK8iE,kBACV94B,EAAW0e,QACXt+B,EACAw4C,EACAlC,GAGJ,QAASt2D,QAAO,GAQlB,OANIs2D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAGR,MAITuH,EAAArQ,UAAAgiE,wBAAA,SAEEj6B,EAEA5f,EAEAw4C,EAEAlC,GASA,YAXA,IAAAkC,MAAuBl1D,EAAAkH,KAAKG,WAE5B,IAAA2rD,MAAyBN,EAAWO,QAGhCD,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAGR,MAITuH,EAAArQ,UAAAiiE,sBAAA,SAEEl6B,EAEA5f,EAEAw4C,EAEAlC,GAEA,QAJA,IAAAkC,MAAuBl1D,EAAAkH,KAAKG,WAE5B,IAAA2rD,MAAyBN,EAAWO,QAEhCv2C,EAAK9K,GAAE,OAA4B,CACrC,IAAIolD,EAAYt6C,EAAKu6C,YAAYn3D,EAAAxK,cAAcoC,OAC/C,GAAIs/D,EAGF,OAFA1kE,KAAKsgE,sBAAwB,KAC7BtgE,KAAKugE,yBAA2B,KACzBmE,EAGX,IAAIxwD,EAASkW,EAAKg6C,eAAelwD,OACjC,OAAIA,GACFlU,KAAKsgE,sBAAwB,KAC7BtgE,KAAKugE,yBAA2B,KACzBrsD,IAELwsD,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAem6D,+CACf56B,EAAWj/B,OAGR,OAITuH,EAAArQ,UAAAkiE,uBAAA,SAEEn6B,EAEA5f,EAEAw4C,EAEAlC,GAEA,QAJA,IAAAkC,MAAuBl1D,EAAAkH,KAAKG,WAE5B,IAAA2rD,MAAyBN,EAAWO,QAEhCv2C,EAAK9K,GAAE,OAA4B,CACrC,IAAIulD,EAAaz6C,EAAKu6C,YAAYn3D,EAAAxK,cAAcqC,QAChD,GAAIw/D,EAGF,OAFA7kE,KAAKsgE,sBAAwB,KAC7BtgE,KAAKugE,yBAA2B,KACzBsE,EAGX,IAAI3wD,EAAyBkW,EAAKg6C,eAAelwD,OACjD,OAAIA,GAAUA,EAAOuC,MAAQm7C,EAAA9gD,YAAY+N,QAAU3K,EAAiBA,EAAQgY,OAC1ElsB,KAAKsgE,sBAAwB,KAC7BtgE,KAAKugE,yBAA2B,KACzBrsD,IAELwsD,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAeq6D,iDACf96B,EAAWj/B,OAGR,OAITuH,EAAArQ,UAAAoiE,yBAAA,SAEEr6B,EAEA5f,EAEAw4C,EAEAlC,GAEA,YAJA,IAAAkC,MAAuBl1D,EAAAkH,KAAKG,WAE5B,IAAA2rD,MAAyBN,EAAWO,QAE5B32B,EAAW7mB,aACjB,KAAKxV,EAAAyV,YAAY6rC,QACfjvD,KAAKsgE,sBAAwBt2B,EAC7BhqC,KAAKugE,yBAA2B,KAChC,IAAIwE,EAAc/kE,KAAKqjE,4BACMr5B,EAAY1oC,MACvCshE,GAGF,OADInxD,EAAczR,KAAKwlB,QAAQ/T,aACZ+C,IAAIuwD,EAAYtuD,MAAQhF,EAAYvQ,IAAI6jE,EAAYtuD,MAAS,KAElF,KAAK9I,EAAAyV,YAAY2rC,MACf/uD,KAAKsgE,sBAAwBt2B,EAC7BhqC,KAAKugE,yBAA2B,KAChC,IACI9uD,EADAszD,EAAcnC,GAAkBl1D,EAAAkH,KAAK/Q,IAAM6J,EAAAkH,KAAK/Q,IAAM6J,EAAAkH,KAAK9Q,IAE/D,OADI2N,EAAczR,KAAKwlB,QAAQ/T,aACZ+C,IAAIuwD,EAAYtuD,MAAQhF,EAAYvQ,IAAI6jE,EAAYtuD,MAAS,KAElF,KAAK9I,EAAAyV,YAAYC,OAGf,OAFArjB,KAAKsgE,sBAAwBt2B,EAC7BhqC,KAAKugE,yBAA2B,KACzBvgE,KAAKwlB,QAAQvL,eAWxB,OANIymD,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAGR,MAITuH,EAAArQ,UAAAqiE,sBAAA,SAEEt6B,EAEA5f,EAEAw4C,EAEAlC,QAFA,IAAAkC,MAAuBl1D,EAAAkH,KAAKG,WAE5B,IAAA2rD,MAAyBN,EAAWO,QAEpC,IAAIkC,EAAmB74B,EAAWA,WAC9B3c,EAASrtB,KAAK8iE,kBAChBD,EACAz4C,EACAw4C,EACAlC,GAGF,IAAKrzC,EAAQ,OAAO,KACpB,GAAIA,EAAO5W,MAAQm7C,EAAA9gD,YAAYkN,mBAAoB,CAEjD,GACsBqP,EAAQjb,cAAgBiuD,EAAA2E,eAAe13C,WAC3D0c,EAAWhnB,UAAU7W,OAAS,EAE9B,OAAOnM,KAAK8iE,kBAAkB94B,EAAWhnB,UAAU,GAAIoH,EAAMw4C,EAAgBlC,GAG/E,IAAIn4C,EAAWvoB,KAAKilE,iCACC53C,EACnB2c,EAAW/d,cACX7B,EAAKg6C,eACLv6D,EAAA23D,QAAQp3C,EAAK3B,yBACbuhB,EACA02B,GAEF,IAAKn4C,EAAU,OAAO,KACtB,IAAI6iB,EAAa7iB,EAAStU,UAAUm3B,WAChC2nB,EAAY3nB,EAAWzc,eAC3B,GAAIokC,EAGF,OAAOA,EAEP,IAAI9+C,EAAYm3B,EAAWgnB,mBAC3B,GAAIn+C,EAIF,OAHqBA,EAAUogD,iBAAiBr0D,KAAKwlB,SAKrD,IAAI/T,EAAczR,KAAKwlB,QAAQ/T,YAC/B,OAAK25B,EAAW9rB,GAAE,MAAyB7N,EAAY+C,IAAI42B,EAAW30B,MAC7DhF,EAAYvQ,IAAIkqC,EAAW30B,OAIpCiqD,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAey6D,uGACfrC,EAAiB93D,MAAOsiB,EAAOjb,cAG5B,MAQT,OANIsuD,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAGR,MAITuH,EAAArQ,UAAAgc,gBAAA,SAEEhc,EAEAgqB,EAEAxD,EAEAi4C,QAFA,IAAAj4C,MAA4C5e,EAAA23D,gBAE5C,IAAAd,MAAyBN,EAAWO,QAEpC,IAAIwE,EAAeljE,EAAUiS,OAAOuC,MAAQm7C,EAAA9gD,YAAYyN,mBACpDtc,EAAUiS,OAAOA,OACjBjS,EAAUiS,OACVvB,EAA8B,KAC9B0V,EAAc4D,EAAgBve,EAAAsmD,cAAc/nC,GAAiB,GAGjE,GAAIhqB,EAAUqd,GAAG9R,EAAAnL,YAAY4iB,UAAW,CAMtC,GALA7a,OAAO+6D,EAAa1uD,MAAQm7C,EAAA9gD,YAAY+N,OACxClM,EAAuBwyD,EAGnBC,EAAmBnjE,EAAUmmB,oBAAoBC,GAC/B,OAAO+8C,EAG7B,IAAIC,EAAqB1yD,EAAcsZ,cACvC,GAAIo5C,EAAoB,CACtB,IAAIC,EAAsBl7D,OAAOuI,EAAc1Q,UAAU8qB,oBACrDw4C,EAAwBD,EAAoBn5D,OAChD/B,OAAOm7D,GAAyBD,EAAoBn5D,QACpD,IAAK,IAAI9L,EAAI,EAAGA,EAAIklE,IAAyBllE,EAAG,CAC9C,IAAImlE,EAAyBF,EAAoBjlE,GAAGO,KAAKqL,KACpDwc,EAAwBjU,IAAIgxD,IAC/B/8C,EAAwBtW,IACtBqzD,EACAH,EAAmBhlE,UAKtB,CAEL,IAAI+kE,EACJ,GAFAh7D,OAAO+6D,EAAa1uD,MAAQm7C,EAAA9gD,YAAY+N,OACpCumD,EAAmBnjE,EAAUmmB,oBAAoBC,GAC/B,OAAO+8C,EAI/B,IAEIK,EAFAC,EAAgBzjE,EAAU0jE,iBAC1B54C,EAAqB9qB,EAAU8qB,mBAEnC,GAAId,IAAkBw5C,EAA2Bx5C,EAAc9f,QAAS,CACtE/B,OAAO2iB,GAAsB04C,GAA4B14C,EAAmB5gB,QAC5E,IAAS9L,EAAI,EAAGA,EAAIolE,IAA4BplE,EAC9CooB,EAAwBtW,IACA4a,EAAoB1sB,GAAGO,KAAKqL,KAClDggB,EAAc5rB,SAIlB+J,QAAQ2iB,GAAmD,GAA7BA,EAAmB5gB,QAInD,IAAI4d,EAAwB,KACxBy5B,EAAmBkiB,EAAcliB,iBACrC,GAAIA,EAAkB,CAOpB,KANAz5B,EAAW/pB,KAAKwgE,YACdhd,EACAvhD,EAAUiS,OACVuU,EACAi4C,IAEa,OAAO,KACtBj4C,EAAwBtW,IAAI3E,EAAAxK,cAAcoC,MAAO2kB,QACxCpX,IACToX,EAAWpX,EAAcsM,KACzBwJ,EAAwBtW,IAAI3E,EAAAxK,cAAcoC,MAAO2kB,IAInD,IA8BIqhB,EA9BAw6B,EAAsBF,EAAcniB,WACpCsiB,EAAyBD,EAAoBz5D,OAC7C6d,EAAiB,IAAI/iB,MAAY4+D,GACjC3R,EAAiB,IAAIjtD,MAAc4+D,GACnC1R,EAAqB,EACzB,IAAS9zD,EAAI,EAAGA,EAAIwlE,IAA0BxlE,EAAG,CAC/C,IAAIylE,EAAuBF,EAAoBvlE,GAC3CylE,EAAqB9hB,eAAiBr2C,EAAAogD,cAAc6H,UACtDzB,EAAqB9zD,EAAI,GAE3B,IAAI6gE,EAAW4E,EAAqB7mD,KACpC,GAAItR,EAAAgkD,cAAcuP,GAKhB,OAJAlhE,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACfE,EAASn2D,OAEJ,KAET,IAAIkf,EAAgBjqB,KAAKwgE,YACvBU,EACAj/D,EAAUiS,OACVuU,EACAi4C,GAEF,IAAKz2C,EAAe,OAAO,KAC3BD,EAAe3pB,GAAK4pB,EACpBiqC,EAAe7zD,GAAKylE,EAAqBllE,KAAKqL,KAKhD,GAAIhK,EAAUqd,GAAG9R,EAAAnL,YAAYyf,KAC3BspB,EAAa19B,EAAAkH,KAAKG,UACb,GAAI9S,EAAUqd,GAAG9R,EAAAnL,YAAYugB,aAClCwoB,EAAahhC,OAAOuI,GAAesM,SAC9B,CACDiiD,EAAWwE,EAAct6B,WAC7B,GAAIz9B,EAAAgkD,cAAcuP,GAKhB,OAJAlhE,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACfE,EAASn2D,OAEJ,KAET,IAAIkU,EAAOjf,KAAKwgE,YACdU,EACAj/D,EAAUiS,OACVuU,EACAi4C,GAEF,IAAKzhD,EAAM,OAAO,KAClBmsB,EAAansB,EAGf,IAAIhL,EAAY,IAAIvG,EAAA0Y,UAAU4D,EAAgBohB,EAAYrhB,GAC1D9V,EAAUigD,eAAiBA,EAC3BjgD,EAAUkgD,mBAAqBA,EAE/B,IAAI3rC,EAAyBvmB,EAAUrB,KACnCynB,EAAYlc,SAAQqc,GAA0B,IAAMH,EAAc,KACtE,IAAIE,EAAW,IAAIqpC,EAAAx9C,SACjBoU,EACAvmB,EACAgS,EACAwU,GAGF,OADAxmB,EAAUqmB,oBAAoBD,EAAaE,GACpCA,GAITjW,EAAArQ,UAAAgjE,iCAAA,SAEEhjE,EAEAk/D,EAEAV,EAEAh4C,EAEAs9C,EAEArF,QAAA,IAAAA,MAAyBN,EAAWO,QAEpC,IAAIwE,EAAeljE,EAAUiS,OAAOuC,MAAQm7C,EAAA9gD,YAAYyN,mBACpDtc,EAAUiS,OAAOA,OACjBjS,EAAUiS,OACV8xD,EAAuC,KAG3C,GAAI/jE,EAAUqd,GAAG9R,EAAAnL,YAAY8S,SAAU,CAGrC,GAAIlT,EAAUqd,GAAG9R,EAAAnL,YAAY4iB,UAAW,CACtC7a,OAAO+6D,EAAa1uD,MAAQm7C,EAAA9gD,YAAY+N,OACxC,IAAIwmD,EAA6BF,EAAcl5C,cAC/C,GAAIo5C,EAAoB,CACtB,IAAIt4C,EAAqB3iB,OAAe+6D,EAAcljE,UAAU8qB,oBAC5Dw4C,EAAwBF,EAAmBl5D,OAC/C/B,OAAOm7D,GAAyBx4C,EAAmB5gB,QACnD,IAAK,IAAI9L,EAAI,EAAGA,EAAIklE,IAAyBllE,EAC3CooB,EAAwBtW,IACtB4a,EAAmB1sB,GAAGO,KAAKqL,KAC3Bo5D,EAAmBhlE,KAc3B,KARA2lE,EAAwBhmE,KAAK6hE,qBAC3Bz3D,OAAOnI,EAAU8qB,oBACjBo0C,EACAV,EACAh4C,EACAs9C,EACArF,IAE0B,OAAO,UAInC,GAA0B,OAAtBS,GAA8BA,EAAkBh1D,OAOlD,OANIu0D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe42D,sBACf0E,EAAWh7D,MAAO9I,EAAUmQ,cAGzB,KAKX,OAAOpS,KAAKie,gBACVhc,EACA+jE,EACAv9C,EACAi4C,IAKJpuD,EAAArQ,UAAA8b,aAAA,SAEE9b,EAEAgqB,EAEAxD,EAEAi4C,wBAFA,IAAAj4C,MAA4C5e,EAAA23D,gBAE5C,IAAAd,MAAyBN,EAAWO,QAEpC,IAAIt4C,EAAc4D,EAAgBve,EAAAsmD,cAAc/nC,GAAiB,GAG7D1D,EAAWtmB,EAAUmmB,oBAAoBC,GAC7C,GAAIE,EAAU,OAAOA,EAIrB,GAAI0D,EAAe,CACjB,IACIg6C,GADAl5C,EAAqB3iB,OAAOnI,EAAU8qB,qBACC5gB,OACvC6gB,EAAmBf,EAAc9f,OACrC/B,OAAO4iB,GAAoBi5C,GAC3B,IAAK,IAAI5lE,EAAI,EAAGA,EAAI2sB,IAAoB3sB,EACtCooB,EAAwBtW,IAAI4a,EAAmB1sB,GAAGO,KAAKqL,KAAMggB,EAAc5rB,QAExE,CACL,IAAI0sB,EAAqB9qB,EAAU8qB,mBACnC3iB,SAAS2iB,GAAsBA,EAAmB5gB,SAIpD,IAAIiP,EAAgBnZ,EAAUmZ,cAC1B8qD,EAA0B,KAC9B,GAAI9qD,EAAe,CACjB,IAAIH,EAAc7Q,OAAOnI,EAAUgZ,aASnC,KARAirD,EAAYlmE,KAAKuhE,8BACfnmD,EACAH,EAAYgR,cACZhqB,EAAUiS,OACVrK,EAAA23D,QAAQ/4C,GACRxN,EACAylD,IAEc,OAAO,KAIzB,IAAIyF,EAAwBlkE,EAAUrB,KAClCynB,EAAYlc,SAAQg6D,GAAyB,IAAM99C,EAAc,MACrEE,EAAW,IAAIqpC,EAAA5lC,MAAMm6C,EAAuBlkE,EAAWgqB,EAAei6C,IAC7Dz9C,wBAA0BA,EACnCxmB,EAAUqmB,oBAAoBD,EAAaE,GAG3C,IAAI+C,EAAoB,EACxB,GAAI46C,EAAW,CAEb,GADIE,EAAcF,EAAUpnD,QACX,EACXX,EAAkBoK,EAASzJ,WACTyJ,EAASzJ,QAAUX,EAAkB,IAAI/W,SAC/D,IAAyC,IAAAi/D,EAAAtuD,EAAAquD,GAAWE,EAAAD,EAAApuD,QAAAquD,EAAApuD,KAAAouD,EAAAD,EAAApuD,OAAE,CAA7C,IAAAoG,EAAAjG,EAAAkuD,EAAAhlE,MAAA,GAACilE,EAAAloD,EAAA,GAAgBmoD,EAAAnoD,EAAA,GACxBF,EAAgBhM,IAAIo0D,EAAgBC,sGAGxCl7C,EAAe46C,EAAU95C,oBAI3B,IAAIq6C,EAA2BxkE,EAAUkc,gBACzC,GAAIsoD,MACF,IAAmB,IAAA1nD,EAAAhH,EAAA0uD,EAAyBlpD,UAAQyB,EAAAD,EAAA9G,QAAA+G,EAAA9G,KAAA8G,EAAAD,EAAA9G,OAAE,CAAjD,IAAIqG,EAAMU,EAAA1d,MACb,OAAQgd,EAAO7H,MAGb,KAAKm7C,EAAA9gD,YAAYqa,gBACf,IAAIhN,EACJ,GADIA,EAAkBoK,EAASzJ,SAE1B,GAAIX,EAAgB3J,IAAI8J,EAAO1d,MAAO,CACzCZ,KAAKqN,MACHI,EAAAhD,eAAeuV,uBACE1B,EAAQ9C,eAAezQ,MACxCuT,EAAO1d,MAET,YAPoB2nB,EAASzJ,QAAUX,EAAkB,IAAI/W,IAS/D,IAAIs/D,EAAiCpoD,EAAQ4iD,SACzCyF,EAAyB,KAE7B,GAAKD,EAoBHC,EAAY3mE,KAAKwgE,YACfkG,EACAzkE,EAAUiS,OACVqU,EAASE,wBACTi4C,OAxBgB,CAEhB,IAAI0F,EADN,GAAIF,EAEF,IADIE,EAAcF,EAAUpnD,UACTsnD,EAAY5xD,IAAqB8J,EAAQ1d,MAAO,CACjE,IAAIgmE,EAAYR,EAAYllE,IAAqBod,EAAQ1d,MACpDgmE,EAAUtnD,GAAG9R,EAAAnL,YAAYq0D,WAC5BtsD,OAAOw8D,EAAUnwD,MAAQm7C,EAAA9gD,YAAY8N,OACrC+nD,EAAoBC,EAAW3nD,MAIhC0nD,GACCjG,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACE1iD,EAAQ9C,eAAezQ,MAAM87D,OAYtD,IAAKF,EAAW,MAChB,IAAIG,EAAgB,IAAIlV,EAAAvmC,MAAsB/M,EAAQiK,EAAUo+C,GAChEv8D,OAAOP,EAAAJ,WAAWk9D,EAAUzU,WAC5B,IAAIzlB,EAAOk6B,EAAUzU,SAAW,EAC5B5mC,EAAemhB,IAAMnhB,EAAuC,GAAvBA,EAAemhB,IACxDq6B,EAAcx7C,aAAeA,EAC7BA,GAAgBq7C,EAAUzU,SAC1B3pC,EAASvT,IAAIsJ,EAAO1d,KAAMkmE,GAC1B,MAEF,KAAKlV,EAAA9gD,YAAYkN,mBACf,IAAI+oD,EAAqCzoD,EAAQ4J,QAAQK,GACzDA,EAASvT,IAAI+xD,EAAenmE,KAAMmmE,GAClC,MAEF,KAAKnV,EAAA9gD,YAAYyN,mBACf,IAAIyoD,EAAmB,IAAIpV,EAAApmC,SAA4BlN,EAAQiK,GAC3D/J,EAAsCF,EAAQE,gBAClD,GAAIA,EAAiB,CACnB,IAAIiN,EAAiBzrB,KAAKie,gBACxBO,EAAgB0J,QAAQK,GACxB,KACA1e,EAAA23D,QAAQj5C,EAASE,yBACjBi4C,GAEEj1C,IACFu7C,EAAiBv7C,eAAiBA,EAClCu7C,EAAiB9nD,QAAQuM,EAAexX,UAAUm3B,aAGtD,IAAI3sB,EAAsCH,EAAQG,gBAClD,GAAIA,EAAiB,CACnB,IAAIiN,EAAiB1rB,KAAKie,gBACxBQ,EAAgByJ,QAAQK,GACxB,KACA1e,EAAA23D,QAAQj5C,EAASE,yBACjBi4C,GAEEh1C,IACFs7C,EAAiBt7C,eAAiBA,EAC7Bs7C,EAAiB1nD,GAAG9R,EAAAnL,YAAY6jB,YACnC9b,OAAyD,GAAlDshB,EAAezX,UAAU+V,eAAe7d,QAC/C66D,EAAiB9nD,QAAQwM,EAAezX,UAAU+V,eAAe,MAIvEzB,EAASvT,IAAIgyD,EAAiBpmE,KAAMomE,GACpC,MAEF,QAAS58D,QAAO,sGAMtBme,EAAS6D,oBAAsBd,EAI7B,IAAI27C,EAAgB1+C,EAAS5O,aAAanM,EAAAxK,cAAcsC,aACxD,GAAI2hE,GAAiBA,EAAc/yD,SAAWqU,EAAU,CACtDne,OAAO68D,EAAcxwD,MAAQm7C,EAAA9gD,YAAYkN,oBACzC,IAAIkpD,EAAelnE,KAAKie,gBACHgpD,EACnB,KACA1+C,EAASE,wBACTi4C,GAEEwG,IAAc3+C,EAAS8D,oBAAgC66C,OAK/D,IAAsC,IAAA/uD,EAAAJ,EAAA9V,EAAUshB,oBAAkBpK,GAAAhB,EAAAF,QAAAkB,GAAAjB,KAAAiB,GAAAhB,EAAAF,OAAE,CAA3D,IAAAsB,GAAAnB,EAAAe,GAAA7X,MAAA,GAACmV,GAAA8C,GAAA,GAAM4tD,GAAA5tD,GAAA,GACdnP,OAAOqM,IAAQm7C,EAAArkD,aAAasD,SAC5B,IAAIu2D,QAAgB,EACpB,GAAID,GAAkB7nD,GAAG9R,EAAAnL,YAAY4iB,UAAW,CAC1C8hD,EAAiBI,GAAkBj/C,QAAQK,GAC/C6+C,GAAmBpnE,KAAKie,gBACtB8oD,EACA,KACAl9D,EAAA23D,UACAd,QAGF0G,GAAmBpnE,KAAKie,gBACtBkpD,GACA,KACAt9D,EAAA23D,UACAd,GAGJ,GAAK0G,GAAL,CACA,IAAI9jD,GAAYiF,EAASjF,UACpBA,KAAWiF,EAASjF,UAAYA,GAAY,IAAIlc,KACrDkc,GAAUnR,IAAIsE,GAAM2wD,yGAEtB,OAAO7+C,GAITjW,EAAArQ,UAAAs/D,8BAAA,SAEEt/D,EAEAk/D,EAEAV,EAEAh4C,EAEAs9C,EAEArF,QAAA,IAAAA,MAAyBN,EAAWO,QAEpC,IAAIqF,EAAuC,KAG3C,GAAI/jE,EAAUqd,GAAG9R,EAAAnL,YAAY8S,UAS3B,KARA6wD,EAAwBhmE,KAAK6hE,qBAC3Bz3D,OAAOnI,EAAU8qB,oBACjBo0C,EACAV,EACAh4C,EACAs9C,EACArF,IAE0B,OAAO,UAInC,GAA0B,OAAtBS,GAA8BA,EAAkBh1D,OAOlD,OANIu0D,GAAcN,EAAWO,QAC3B3gE,KAAKqN,MACHI,EAAAhD,eAAe42D,sBACf0E,EAAWh7D,MAAO9I,EAAUmQ,cAGzB,KAKX,OAAOpS,KAAK+d,aACV9b,EACA+jE,EACAv9C,EACAi4C,IAGNpuD,EAlwDA,CAA8B7E,EAAAX,mBAAjBpN,EAAA4S,4RC5Fb,IAuIY+0D,EAvIZ35D,EAAAvN,EAAA,GAMAyxD,EAAAzxD,EAAA,GAQA0xD,EAAA1xD,EAAA,GAuCAqN,EAAArN,EAAA,GAIAsN,EAAAtN,EAAA,IASA,SAAkBmnE,GAEhBA,IAAA,eAKAA,IAAA,qBAEAA,IAAA,qCAEAA,IAAA,qCAEAA,IAAA,mBAEAA,IAAA,oBAEAA,IAAA,0BAEAA,IAAA,0BAEAA,IAAA,+BAEAA,IAAA,6BAKAA,IAAA,mDAEAA,IAAA,kDAEAA,IAAA,0DAEAA,IAAA,kDAEAA,IAAA,wDAEAA,IAAA,yDAKAA,IAAA,uCAEAA,IAAA,6CAKAA,IAAA,uCAWAA,IAAA,yCA7DF,CAAkB5nE,EAAA4nE,YAAA5nE,EAAA4nE,UAAS,KAqE3B,SAAYD,GAEVA,IAAA,eAGAA,IAAA,uBAEAA,IAAA,qBAEAA,IAAA,qBAEAA,IAAA,uBAEAA,IAAA,0BAEAA,IAAA,wBAGAA,IAAA,oDAEAA,IAAA,uDAEAA,IAAA,qDAGAA,IAAA,sCAQAA,IAAA,uCAMAA,IAAA,iCAvCF,CAAYA,EAAA3nE,EAAA2nE,aAAA3nE,EAAA2nE,WAAU,KA0CtB,SAAiBA,GACCA,EAAA16D,KAAhB,SAAqBo6B,EAAkBC,GACrC,OAASD,EAAOsgC,EAAWE,gBAAoBvgC,EAAQqgC,EAAWE,gBACzDxgC,EAAOsgC,EAAWG,gBAAoBxgC,EAAQqgC,EAAWG,iBAHtE,CAAiBH,EAAA3nE,EAAA2nE,aAAA3nE,EAAA2nE,WAAU,KAQ3B,SAAYI,GAEVA,IAAA,eAGAA,IAAA,6BAEAA,IAAA,yDAGAA,IAAA,qCAGAA,IAAA,qCAbF,CAAY/nE,EAAA+nE,aAAA/nE,EAAA+nE,WAAU,KAetB,SAAiBA,GACCA,EAAA96D,KAAhB,SAAqBo6B,EAAkBC,GACrC,OAASD,EAAO0gC,EAAWF,gBAAoBvgC,EAAQygC,EAAWF,gBACzDxgC,EAAO0gC,EAAWD,gBAAoBxgC,EAAQygC,EAAWD,iBAHtE,CAAiB9nE,EAAA+nE,aAAA/nE,EAAA+nE,WAAU,KAQ3B,IAAAp9C,EAAA,WAsDE,SAAAA,IArCArqB,KAAA0nE,aAAyC,KAIzC1nE,KAAA2nE,WAA4C,KA6yB9C,OAtyBSt9C,EAAA1oB,OAAP,SAAcimE,GACZ,IAAIx9C,EAAO,IAAIC,EAWf,OAVAD,EAAKlW,OAAS,KACdkW,EAAKpX,MAAK,EACVoX,EAAKw9C,eAAiBA,EACtBx9C,EAAKy9C,cAAgB,KACrBz9C,EAAKT,WAAa,KAClBS,EAAKghB,WAAaw8B,EAAe3zD,UAAUm3B,WAC3ChhB,EAAK3B,wBAA0Bm/C,EAAen/C,wBAC9C2B,EAAK09C,WAAa,GAClB19C,EAAK29C,eAAiB,KACtB39C,EAAK49C,kBAAoB,KAClB59C,GAIFC,EAAA49C,aAAP,SAAoBL,EAA0BG,GAC5C,IAAI39C,EAAOC,EAAK1oB,OAAOimE,GAMvB,OALAx9C,EAAKjY,IAAG,OACRiY,EAAK29C,eAAiBA,EACtB39C,EAAK49C,kBAAoBD,EAAe31D,aAAe,aAAe21D,EAAe9+C,gBAAgBvd,SAAS,IAC9G0e,EAAKghB,WAAa28B,EAAe9zD,UAAUm3B,WAC3ChhB,EAAK3B,wBAA0Bs/C,EAAet/C,wBACvC2B,GAMTrpB,OAAAC,eAAIqpB,EAAApoB,UAAA,iBAAc,KAAlB,WACE,OAAOjC,KAAK+nE,gBAAkB/nE,KAAK4nE,gDAIrCv9C,EAAApoB,UAAAqd,GAAA,SAAGoB,GAAyB,OAAQ1gB,KAAKgT,MAAQ0N,IAASA,GAE1D2J,EAAApoB,UAAA2f,MAAA,SAAMlB,GAAyB,OAA8B,IAAtB1gB,KAAKgT,MAAQ0N,IAEpD2J,EAAApoB,UAAAkQ,IAAA,SAAIuO,GAAyB1gB,KAAKgT,OAAS0N,GAE3C2J,EAAApoB,UAAA2jB,MAAA,SAAMlF,GAAyB1gB,KAAKgT,QAAU0N,GAG9C2J,EAAApoB,UAAAimE,KAAA,WACE,IAAIC,EAAS,IAAI99C,EAWjB,OAVA89C,EAAOj0D,OAASlU,KAChBmoE,EAAOn1D,MAAQhT,KAAKgT,MACpBm1D,EAAOP,eAAiB5nE,KAAK4nE,eAC7BO,EAAON,cAAgB7nE,KAAK6nE,cAC5BM,EAAOx+C,WAAa3pB,KAAK2pB,WACzBw+C,EAAO/8B,WAAaprC,KAAKorC,WACzB+8B,EAAO1/C,wBAA0BzoB,KAAKyoB,wBACtC0/C,EAAOL,WAAa9nE,KAAK8nE,WAAWM,QACpCD,EAAOJ,eAAiB/nE,KAAK+nE,eAC7BI,EAAOH,kBAAoBhoE,KAAKgoE,kBACzBG,GAIT99C,EAAApoB,UAAAomE,aAAA,SAAappD,EAAYyP,QAAA,IAAAA,MAAA,MACvB,IACI45C,EASAx+C,EAVA89C,EAAiB5nE,KAAK4nE,eAE1B,OAAQ3oD,EAAKw0C,gBACX,KAAK5B,EAAAriC,WAAWppB,IAAOkiE,EAAQV,EAAex+C,SAAU,MACxD,KAAKyoC,EAAAriC,WAAWnpB,IAAOiiE,EAAQV,EAAev+C,SAAU,MACxD,KAAKwoC,EAAAriC,WAAW3oB,IAAOyhE,EAAQV,EAAet+C,SAAU,MACxD,KAAKuoC,EAAAriC,WAAW1oB,IAAOwhE,EAAQV,EAAer+C,SAAU,MACxD,KAAKsoC,EAAAriC,WAAWzoB,KAAQuhE,EAAQV,EAAep+C,UAAW,MAC1D,QAAS,MAAM,IAAIpN,MAAM,0BAG3B,GAAIsS,EAAQ,CACV,GAAI45C,GAASA,EAAMn8D,OACjB,IAAK,IAAI9L,EAAI,EAAG+V,EAAIkyD,EAAMn8D,OAAQ9L,EAAI+V,IAAK/V,EACzC,IAAKquB,EAAOla,IAAI8zD,EAAMjoE,GAAGunB,OAAQ,CAC/BkC,EAAQw+C,EAAMjoE,GAEd,IADA,IAAIkoE,EAAID,EAAMn8D,OAAS,EAChB9L,EAAIkoE,GAAGj7C,UAAUg7C,EAAMjoE,GAAKioE,EAAY,EAANjoE,MAKzC,OAJAioE,EAAMn8D,OAASo8D,EACfz+C,EAAM7K,KAAOA,EACb6K,EAAM9W,MAAQxF,EAAAnL,YAAY4Q,KAC1BjT,KAAKwoE,eAAe1+C,EAAMlC,OAAO,GAC1BkC,EAIbA,EAAQ89C,EAAer9C,SAAStL,QAE5BqpD,GAASA,EAAMn8D,SACjB2d,EAAQw+C,EAAMG,OACRxpD,KAAOA,EACb6K,EAAM9W,MAAQxF,EAAAnL,YAAY4Q,MAE1B6W,EAAQ89C,EAAer9C,SAAStL,GAIpC,OADAjf,KAAKwoE,eAAe1+C,EAAMlC,OAAO,GAC1BkC,GAITO,EAAApoB,UAAAymE,oBAAA,SAAoBzpD,EAAYyP,QAAA,IAAAA,MAAA,MAC9B,IAAI5E,EAAQ9pB,KAAKqoE,aAAappD,EAAMyP,GACpC5E,EAAM3X,IAAI3E,EAAAnL,YAAYsmE,QACtB,IAAIjB,EAAe1nE,KAAK0nE,aAIxB,OAHKA,IAAc1nE,KAAK0nE,aAAeA,EAAe,IAAItgE,KAC1DsgE,EAAav1D,IAAI,QAAWnS,KAAK4nE,eAAez+C,oBAAsBW,GACtE9pB,KAAK4oE,aAAa9+C,EAAMlC,MAAOy/C,EAAWwB,UACnC/+C,GAITO,EAAApoB,UAAA6mE,cAAA,SAAch/C,GACZ,IAAIA,EAAMxK,GAAG9R,EAAAnL,YAAYilB,SAAzB,CACAld,OAAO0f,EAAMlC,OAAS,GACtB,IACI0gD,EADAV,EAAiB5nE,KAAK4nE,eAG1B,OADAx9D,OAAqB,MAAd0f,EAAM7K,MACE6K,EAAM7K,KAAMw0C,gBACzB,KAAK5B,EAAAriC,WAAWppB,IACdkiE,EAAQV,EAAex+C,WAAaw+C,EAAex+C,SAAW,IAC9D,MAEF,KAAKyoC,EAAAriC,WAAWnpB,IACdiiE,EAAQV,EAAev+C,WAAau+C,EAAev+C,SAAW,IAC9D,MAEF,KAAKwoC,EAAAriC,WAAW3oB,IACdyhE,EAAQV,EAAet+C,WAAas+C,EAAet+C,SAAW,IAC9D,MAEF,KAAKuoC,EAAAriC,WAAW1oB,IACdwhE,EAAQV,EAAer+C,WAAaq+C,EAAer+C,SAAW,IAC9D,MAEF,KAAKsoC,EAAAriC,WAAWzoB,KACduhE,EAAQV,EAAep+C,YAAco+C,EAAep+C,UAAY,IAChE,MAEF,QAAS,MAAM,IAAIpN,MAAM,0BAE3BhS,OAAO0f,EAAMlC,OAAS,GACtB0gD,EAAM57D,KAAKod,KAIbO,EAAApoB,UAAA8mE,oBAAA,SAAoB9pD,EAAYyP,QAAA,IAAAA,MAAA,MAC9B,IAAI5E,EAAQ9pB,KAAKqoE,aAAappD,EAAMyP,GAEpC,OADA1uB,KAAK8oE,cAAch/C,GACZA,GAITO,EAAApoB,UAAA+mE,eAAA,SAAepoE,GACb,IAAI8mE,EAAe1nE,KAAK0nE,aACxB,OAAIA,GAAgBA,EAAalzD,IAAI5T,GAAc8mE,EAAaxmE,IAAIN,GAC7D,MAITypB,EAAApoB,UAAAgnE,eAAA,SAAeroE,EAAcqe,EAAYyP,QAAA,IAAAA,MAAA,MACvC,IAAIw6C,EAAclpE,KAAKqoE,aAAappD,EAAMyP,GACtCg5C,EAAe1nE,KAAK0nE,aAKxB,OAJKA,EACAt9D,QAAQs9D,EAAalzD,IAAI5T,IADXZ,KAAK0nE,aAAeA,EAAe,IAAItgE,IAE1D8hE,EAAY/2D,IAAI3E,EAAAnL,YAAYsmE,QAC5BjB,EAAav1D,IAAIvR,EAAMsoE,GAChBA,GAIT7+C,EAAApoB,UAAAknE,eAAA,SAAevoE,EAAcqe,EAAY2I,EAAYm+C,GACnD,QADmD,IAAAA,MAAA,MAC9C/lE,KAAK0nE,aACL,CACH,IAAI0B,EAAgBppE,KAAK0nE,aAAaxmE,IAAIN,GAC1C,GAAIwoE,EAOF,OANIrD,GACF/lE,KAAK4nE,eAAepiD,QAAQnY,MAC1BI,EAAAhD,eAAeuV,uBACf+lD,EAAWh7D,OAGRq+D,OAVappE,KAAK0nE,aAAe,IAAItgE,IAahDgD,OAAOwd,EAAQ5nB,KAAK4nE,eAAej/C,cAAcxc,QACjD,IAAIk9D,EAAc,IAAIzX,EAAAjqC,MAAM/mB,EAAMgnB,EAAO3I,EAAMjf,KAAK4nE,gBAGpD,OADA5nE,KAAK0nE,aAAav1D,IAAIvR,EAAMyoE,GACrBA,GAITh/C,EAAApoB,UAAAqnE,iBAAA,mBACE,GAAItpE,KAAK0nE,aAAc,KACrB,IAAwB,IAAAhhD,EAAA3O,EAAA/X,KAAK0nE,aAAanqD,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAE,CAA/C,IAAIixD,EAAW9qD,EAAA9c,MACd4nE,EAAY5pD,GAAG9R,EAAAnL,YAAYsmE,SAC7B3oE,KAAK8oE,cAAcI,qGAGvBlpE,KAAK0nE,aAAe,OAKxBr9C,EAAApoB,UAAA0iE,YAAA,SAAY/jE,GACV,IACI2oE,EADA5jD,EAAuB3lB,KAE3B,GAAG,IAAKupE,EAAQ5jD,EAAQ+hD,eAAkB6B,EAAM/0D,IAAI5T,GAAQ,OAAO2oE,EAAMroE,IAAIN,SACtE+kB,EAAUA,EAAQzR,QACzB,OAAOlU,KAAK4nE,eAAel/C,aAAaxnB,IAAIN,IAI9CypB,EAAApoB,UAAAqkB,OAAA,SAAO1lB,GACL,IAAIgY,EAAU5Y,KAAK2kE,YAAY/jE,GAC/B,OAAIgY,GACG5Y,KAAKokE,eAAe99C,OAAO1lB,IAIpCypB,EAAApoB,UAAAunE,YAAA,SAAY5hD,EAAYlH,EAAkB+oD,GACxC,YADwC,IAAAA,OAAA,GACpC7hD,EAAQ,EAAU6hD,EAEf7hD,EADU5nB,KAAK8nE,WACI37D,SAAWmhB,UAAUttB,KAAK8nE,WAAWlgD,IAAUlH,IAASA,GAIpF2J,EAAApoB,UAAAynE,eAAA,SAAe9hD,EAAYlH,EAAkB+oD,GAC3C,YAD2C,IAAAA,OAAA,GACvC7hD,EAAQ,EAAU6hD,EAEf7hD,EADU5nB,KAAK8nE,WACI37D,QAAwD,IAA7CmhB,UAAUttB,KAAK8nE,WAAWlgD,IAAUlH,IAI3E2J,EAAApoB,UAAA2mE,aAAA,SAAahhD,EAAYlH,GACvB,KAAIkH,EAAQ,GAAZ,CACA,IAAIkgD,EAAa9nE,KAAK8nE,WAClB90D,EAAQ4U,EAAQkgD,EAAW37D,OAASmhB,UAAUw6C,EAAWlgD,IAAU,EACvE5nB,KAAK8nE,WAAWlgD,GAAS5U,EAAQ0N,IAInC2J,EAAApoB,UAAAumE,eAAA,SAAe5gD,EAAYlH,GACzB,KAAIkH,EAAQ,GAAZ,CACA,IAAIkgD,EAAa9nE,KAAK8nE,WAClB90D,EAAQ4U,EAAQkgD,EAAW37D,OAASmhB,UAAUw6C,EAAWlgD,IAAU,EACvE5nB,KAAK8nE,WAAWlgD,GAAS5U,GAAS0N,IAIpC2J,EAAApoB,UAAA0nE,eAAA,WACE,IAAI/B,EAAiB5nE,KAAK4nE,eACtB90D,EAAK80D,EAAen+C,cACpBmgD,EAAQhC,EAAel+C,WAG3B,OAFKkgD,EACAA,EAAMl9D,KAAKoG,GADJ80D,EAAel+C,WAAa,CAAE5W,GAEnC80D,EAAej+C,WAAa7W,EAAGpH,SAAS,KAIjD2e,EAAApoB,UAAA4nE,cAAA,WACE,IAAIjC,EAAiB5nE,KAAK4nE,eACtBgC,EAAQx/D,OAAOw9D,EAAel+C,YAC9Bvd,EAAS/B,OAAOw/D,EAAMz9D,QAC1By9D,EAAMnB,MACFt8D,EAAS,EACXy7D,EAAej+C,WAAaigD,EAAMz9D,EAAS,GAAGT,SAAS,KAEvDk8D,EAAej+C,WAAa,KAC5Bi+C,EAAel+C,WAAa,OAKhCW,EAAApoB,UAAA6nE,QAAA,SAAQr7C,GACNzuB,KAAKgT,OAAuB,MAAdyb,EAAMzb,MACpBhT,KAAK8nE,WAAar5C,EAAMq5C,YAI1Bz9C,EAAApoB,UAAA8nE,mBAAA,SAAmBt7C,GACbA,EAAMnP,GAAE,IACVtf,KAAKmS,IAAG,KAENsc,EAAMnP,GAAE,IACVtf,KAAKmS,IAAG,MAENsc,EAAMnP,GAAE,KAAsBmP,EAAM9E,YAAc3pB,KAAK2pB,YACzD3pB,KAAKmS,IAAG,MAENsc,EAAMnP,GAAE,KAAyBmP,EAAMo5C,eAAiB7nE,KAAK6nE,eAC/D7nE,KAAKmS,IAAG,MAENsc,EAAMnP,GAAE,KACVtf,KAAKmS,IAAG,OAGV,IADA,IAAI21D,EAAar5C,EAAMq5C,WACdznE,EAAI,EAAG+V,EAAI0xD,EAAW37D,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACjD,IAAI2S,EAAQ80D,EAAWznE,GACnB2S,EAAQq0D,EAAWwB,UAAU7oE,KAAK4oE,aAAavoE,EAAGgnE,EAAW2C,wBAC7Dh3D,EAAQq0D,EAAW4C,UAAUjqE,KAAK4oE,aAAavoE,EAAGgnE,EAAW6C,wBAC7Dl3D,EAAQq0D,EAAW8C,WAAWnqE,KAAK4oE,aAAavoE,EAAGgnE,EAAW+C,2BAKtE//C,EAAApoB,UAAAooE,cAAA,SAActjC,EAAYC,GAExBhnC,KAAKmS,IAAI40B,EAAK/zB,MAAQg0B,EAAMh0B,MAAK,KAGjChT,KAAKmS,IAAc,MAAV40B,EAAK/zB,OACdhT,KAAKmS,IAAe,MAAX60B,EAAMh0B,OAGfhT,KAAK+pE,mBAAmBhjC,GACxB/mC,KAAK+pE,mBAAmB/iC,GAQxB,IALA,IAAIsjC,EAAiBvjC,EAAK+gC,WACtByC,EAAoBD,EAAen+D,OACnCq+D,EAAkBxjC,EAAM8gC,WACxB2C,EAAqBD,EAAgBr+D,OACrCu+D,EAAgB,IAAIzjE,MAAkB0jE,IAASJ,EAAmBE,IAC7DpqE,EAAI,EAAGA,EAAIkqE,IAAqBlqE,EACvCqqE,EAAcrqE,GAAKgnE,EAAW16D,KAC5B2gB,UAAUg9C,EAAejqE,IACzBA,EAAIoqE,EACAn9C,UAAUk9C,EAAgBnqE,IAC1B,GAGR,IAASA,EAAIkqE,EAAmBlqE,EAAIoqE,IAAsBpqE,EACxDqqE,EAAcrqE,GAAKgnE,EAAW16D,KAC5B,EACA2gB,UAAUk9C,EAAgBnqE,KAG9BL,KAAK8nE,WAAa4C,GAIpBrgD,EAAApoB,UAAA2oE,UAAA,SAAUhkC,EAAqB3nB,GAC7B,IAAKA,EAAKK,GAAE,KAAsB,OAAO,EAIzC,OAAQuyC,EAAA9a,gBAAgBnQ,IACtB,KAAKirB,EAAApiC,aAAa0vB,SAChB,IAAK0S,EAAAla,WAAW/Q,GAAO,MAEvB,QADI9c,EAAQ9pB,KAAK4nE,eAAej/C,cAAckpC,EAAAta,iBAAiB3Q,KACjD3nB,KAAKK,GAAE,MAAwBtf,KAAKwpE,YAAY1/C,EAAMlC,MAAOy/C,EAAW9C,SAAS,GAEjG,KAAK1S,EAAApiC,aAAa0lB,SAChB,IAAIrrB,EACJ,QADIA,EAAQ9pB,KAAK4nE,eAAej/C,cAAckpC,EAAAva,iBAAiB1Q,KACjD3nB,KAAKK,GAAE,MAAwBtf,KAAKwpE,YAAY1/C,EAAMlC,MAAOy/C,EAAW9C,SAAS,GAGnG,OAAO,GAITl6C,EAAApoB,UAAA4oE,qBAAA,SAAqBjkC,GAEnB,OAAQirB,EAAA9a,gBAAgBnQ,IACtB,KAAKirB,EAAApiC,aAAa0vB,SAChB,IAAK0S,EAAAla,WAAW/Q,GAAO,MACvB,IAAI9c,EAAQ9pB,KAAK4nE,eAAej/C,cAAckpC,EAAAta,iBAAiB3Q,IAC/D5mC,KAAK4oE,aAAa9+C,EAAMlC,MAAOy/C,EAAW9C,SAC1CvkE,KAAK6qE,qBAAqBhZ,EAAApa,iBAAiB7Q,IAC3C,MAEF,KAAKirB,EAAApiC,aAAa0lB,SACZrrB,EAAQ9pB,KAAK4nE,eAAej/C,cAAckpC,EAAAva,iBAAiB1Q,IAC/D5mC,KAAK4oE,aAAa9+C,EAAMlC,MAAOy/C,EAAW9C,SAC1C,MAEF,KAAK1S,EAAApiC,aAAakvB,GAChB,IAAIrU,EAAUunB,EAAApY,WAAW7S,GACzB,IAAK0D,EAAS,MACVunB,EAAA9a,gBAAgBzM,IAAYunB,EAAApiC,aAAaolB,QAIxCgd,EAAA7a,kBAAkB1M,IAAYunB,EAAAriC,WAAWppB,KAAoC,GAA7ByrD,EAAA5a,iBAAiB3M,IACjEunB,EAAA7a,kBAAkB1M,IAAYunB,EAAAriC,WAAWnpB,KAAuC,GAAhCwrD,EAAA3a,oBAAoB5M,IAAkD,GAAjCunB,EAAA1a,qBAAqB7M,MAE3GtqC,KAAK6qE,qBAAqBhZ,EAAAxY,eAAezS,IACzC5mC,KAAK6qE,qBAAqBhZ,EAAAtY,UAAU3S,KAGxC,MAEF,KAAKirB,EAAApiC,aAAasmB,MAChB,OAAQ8b,EAAA5Z,WAAWrR,IACjB,KAAKirB,EAAA/+B,QAAQg4C,OACb,KAAKjZ,EAAA/+B,QAAQi4C,OACX/qE,KAAKgrE,sBAAsBnZ,EAAA3Z,cAActR,IAI7C,MAEF,KAAKirB,EAAApiC,aAAaymB,OAChB,OAAQ2b,EAAA/Z,YAAYlR,IAClB,KAAKirB,EAAAz5B,SAAS6yC,MACZ,IAAIlkC,EAAO8qB,EAAA9Z,cAAcnR,GACrBI,EAAQ6qB,EAAA7Z,eAAepR,GACvBirB,EAAA9a,gBAAgBhQ,IAAS8qB,EAAApiC,aAAaolB,OAAmC,GAA1Bgd,EAAA5a,iBAAiBlQ,GAClE/mC,KAAK6qE,qBAAqB7jC,GACjB6qB,EAAA9a,gBAAgB/P,IAAU6qB,EAAApiC,aAAaolB,OAAoC,GAA3Bgd,EAAA5a,iBAAiBjQ,IAC1EhnC,KAAK6qE,qBAAqB9jC,GAE5B,MAEF,KAAK8qB,EAAAz5B,SAAS8yC,MACRnkC,EAAO8qB,EAAA9Z,cAAcnR,GACrBI,EAAQ6qB,EAAA7Z,eAAepR,GACvBirB,EAAA9a,gBAAgBhQ,IAAS8qB,EAAApiC,aAAaolB,OAAuC,GAA7Bgd,EAAA3a,oBAAoBnQ,IAA4C,GAA9B8qB,EAAA1a,qBAAqBpQ,GAEhG8qB,EAAA9a,gBAAgB/P,IAAU6qB,EAAApiC,aAAaolB,OAAwC,GAA9Bgd,EAAA3a,oBAAoBlQ,IAA8C,GAA/B6qB,EAAA1a,qBAAqBnQ,IAClHhnC,KAAK6qE,qBAAqB9jC,GAF1B/mC,KAAK6qE,qBAAqB7jC,GAI5B,MAEF,KAAK6qB,EAAAz5B,SAAS+yC,MACRpkC,EAAO8qB,EAAA9Z,cAAcnR,GACrBI,EAAQ6qB,EAAA7Z,eAAepR,GACvBirB,EAAA9a,gBAAgBhQ,IAAS8qB,EAAApiC,aAAaolB,OAAmC,GAA1Bgd,EAAA5a,iBAAiBlQ,GAClE/mC,KAAK6qE,qBAAqB7jC,GACjB6qB,EAAA9a,gBAAgB/P,IAAU6qB,EAAApiC,aAAaolB,OAAoC,GAA3Bgd,EAAA5a,iBAAiBjQ,IAC1EhnC,KAAK6qE,qBAAqB9jC,GAE5B,MAEF,KAAK8qB,EAAAz5B,SAASgzC,MACRrkC,EAAO8qB,EAAA9Z,cAAcnR,GACrBI,EAAQ6qB,EAAA7Z,eAAepR,GACvBirB,EAAA9a,gBAAgBhQ,IAAS8qB,EAAApiC,aAAaolB,OAAsC,GAA7Bgd,EAAA3a,oBAAoBnQ,IAA4C,GAA9B8qB,EAAA1a,qBAAqBpQ,GACxG/mC,KAAK6qE,qBAAqB7jC,GACjB6qB,EAAA9a,gBAAgB/P,IAAU6qB,EAAApiC,aAAaolB,OAAuC,GAA9Bgd,EAAA3a,oBAAoBlQ,IAA8C,GAA/B6qB,EAAA1a,qBAAqBnQ,IACjHhnC,KAAK6qE,qBAAqB9jC,GAKhC,MAEF,KAAK8qB,EAAApiC,aAAasvB,KAGhB,OAFW8S,EAAAhX,cAAcjU,IAGvB,KAFY5mC,KAAK4nE,eAAepiD,QAEnBzI,eAAe3K,aAC1BpS,KAAK6qE,qBAAqBhZ,EAAA5W,eAAerU,EAAM,OAUzDvc,EAAApoB,UAAA+oE,sBAAA,SAAsBpkC,GAEpB,OAAQirB,EAAA9a,gBAAgBnQ,IACtB,KAAKirB,EAAApiC,aAAasmB,MAChB,OAAQ8b,EAAA5Z,WAAWrR,IACjB,KAAKirB,EAAA/+B,QAAQg4C,OACb,KAAKjZ,EAAA/+B,QAAQi4C,OACX/qE,KAAK6qE,qBAAqBhZ,EAAA3Z,cAActR,IAI5C,MAEF,KAAKirB,EAAApiC,aAAakvB,GAChB,IAAItU,EAASwnB,EAAAtY,UAAU3S,GACvB,GAAIirB,EAAA9a,gBAAgB1M,IAAWwnB,EAAApiC,aAAaolB,MAAO,CAEjD,IADcgd,EAAApY,WAAW7S,GACX,OAIXirB,EAAA7a,kBAAkB3M,IAAWwnB,EAAAriC,WAAWppB,KAAmC,GAA5ByrD,EAAA5a,iBAAiB5M,IAChEwnB,EAAA7a,kBAAkB3M,IAAWwnB,EAAAriC,WAAWnpB,MAAuC,GAA/BwrD,EAAA3a,oBAAoB7M,IAAgD,GAAhCwnB,EAAA1a,qBAAqB9M,OAE1GrqC,KAAKgrE,sBAAsBnZ,EAAAxY,eAAezS,IAC1C5mC,KAAKgrE,sBAAsBnZ,EAAApY,WAAW7S,KAI1C,MAEF,KAAKirB,EAAApiC,aAAaymB,OAChB,OAAQ2b,EAAA/Z,YAAYlR,IAElB,KAAKirB,EAAAz5B,SAAS6yC,MACZ,IAAIlkC,EAAO8qB,EAAA9Z,cAAcnR,GACrBI,EAAQ6qB,EAAA7Z,eAAepR,GACvBirB,EAAA9a,gBAAgBhQ,IAAS8qB,EAAApiC,aAAaolB,OAAmC,GAA1Bgd,EAAA5a,iBAAiBlQ,GAClE/mC,KAAK6qE,qBAAqB7jC,GACjB6qB,EAAA9a,gBAAgB/P,IAAU6qB,EAAApiC,aAAaolB,OAAoC,GAA3Bgd,EAAA5a,iBAAiBjQ,IAC1EhnC,KAAK6qE,qBAAqB9jC,GAE5B,MAEF,KAAK8qB,EAAAz5B,SAAS8yC,MACRnkC,EAAO8qB,EAAA9Z,cAAcnR,GACrBI,EAAQ6qB,EAAA7Z,eAAepR,GACvBirB,EAAA9a,gBAAgBhQ,IAAS8qB,EAAApiC,aAAaolB,OAAsC,GAA7Bgd,EAAA3a,oBAAoBnQ,IAA4C,GAA9B8qB,EAAA1a,qBAAqBpQ,GACxG/mC,KAAK6qE,qBAAqB7jC,GACjB6qB,EAAA9a,gBAAgB/P,IAAU6qB,EAAApiC,aAAaolB,OAAuC,GAA9Bgd,EAAA3a,oBAAoBlQ,IAA8C,GAA/B6qB,EAAA1a,qBAAqBnQ,IACjHhnC,KAAK6qE,qBAAqB9jC,GAE5B,MAEF,KAAK8qB,EAAAz5B,SAAS+yC,MACRpkC,EAAO8qB,EAAA9Z,cAAcnR,GACrBI,EAAQ6qB,EAAA7Z,eAAepR,GACvBirB,EAAA9a,gBAAgBhQ,IAAS8qB,EAAApiC,aAAaolB,OAAmC,GAA1Bgd,EAAA5a,iBAAiBlQ,GAClE/mC,KAAK6qE,qBAAqB7jC,GACjB6qB,EAAA9a,gBAAgB/P,IAAU6qB,EAAApiC,aAAaolB,OAAoC,GAA3Bgd,EAAA5a,iBAAiBjQ,IAC1EhnC,KAAK6qE,qBAAqB9jC,GAE5B,MAEF,KAAK8qB,EAAAz5B,SAASgzC,MACRrkC,EAAO8qB,EAAA9Z,cAAcnR,GACrBI,EAAQ6qB,EAAA7Z,eAAepR,GACvBirB,EAAA9a,gBAAgBhQ,IAAS8qB,EAAApiC,aAAaolB,OAAuC,GAA7Bgd,EAAA3a,oBAAoBnQ,IAA4C,GAA9B8qB,EAAA1a,qBAAqBpQ,GAEhG8qB,EAAA9a,gBAAgB/P,IAAU6qB,EAAApiC,aAAaolB,OAAwC,GAA9Bgd,EAAA3a,oBAAoBlQ,IAA8C,GAA/B6qB,EAAA1a,qBAAqBnQ,IAClHhnC,KAAK6qE,qBAAqB9jC,GAF1B/mC,KAAK6qE,qBAAqB7jC,MAiBtC3c,EAAApoB,UAAAopE,YAAA,SAAYzkC,EAAqB3nB,GAM/B,GAHA7U,OAAO6U,GAAQvR,EAAAkH,KAAKG,OAGfkK,EAAKK,GAAG,IAAsC,OAAO,EAE1D,IAAIopC,EACJ,OAAQmJ,EAAA9a,gBAAgBnQ,IAGtB,KAAKirB,EAAApiC,aAAa0lB,SAChB,IAAIrrB,EAAQ9pB,KAAK4nE,eAAej/C,cAAckpC,EAAAva,iBAAiB1Q,IAC/D,OAAQ5mC,KAAKwpE,YAAY1/C,EAAMlC,MAAOy/C,EAAWiE,SAAS,IACnDC,EAAsBzhD,EAAM7K,KAAMA,GAI3C,KAAK4yC,EAAApiC,aAAa0vB,SAEhB,OADA/0C,OAAOynD,EAAAla,WAAW/Q,IACX5mC,KAAKqrE,YAAYxZ,EAAApa,iBAAiB7Q,GAAO3nB,GAIlD,KAAK4yC,EAAApiC,aAAa4lB,UAEhB,IAAIm2B,EAASphE,OAAOpK,KAAK4nE,eAAepiD,QAAQlU,eAAepQ,IAAIkJ,OAAOynD,EAAAha,iBAAiBjR,MAE3F,OADAx8B,OAAOohE,EAAO/0D,MAAQm7C,EAAA9gD,YAAYmQ,QAC3BsqD,EAAsBnhE,OAAgBohE,EAAQvsD,MAAOA,GAG9D,KAAK4yC,EAAApiC,aAAaymB,OAChB,OAAQ2b,EAAA/Z,YAAYlR,IAGlB,KAAKirB,EAAAz5B,SAAS6yC,MACd,KAAKpZ,EAAAz5B,SAAS8yC,MACd,KAAKrZ,EAAAz5B,SAASqzC,MACd,KAAK5Z,EAAAz5B,SAASszC,MACd,KAAK7Z,EAAAz5B,SAAS+yC,MACd,KAAKtZ,EAAAz5B,SAASgzC,MACd,KAAKvZ,EAAAz5B,SAASuzC,MACd,KAAK9Z,EAAAz5B,SAASwzC,MACd,KAAK/Z,EAAAz5B,SAASyzC,MACd,KAAKha,EAAAz5B,SAAS0zC,MACd,KAAKja,EAAAz5B,SAAS2zC,MACd,KAAKla,EAAAz5B,SAAS4zC,MACd,KAAKna,EAAAz5B,SAAS6zC,MACd,KAAKpa,EAAAz5B,SAAS8zC,MACd,KAAKra,EAAAz5B,SAAS+zC,MACd,KAAKta,EAAAz5B,SAASg0C,MACd,KAAKva,EAAAz5B,SAASi0C,MACd,KAAKxa,EAAAz5B,SAASk0C,MACd,KAAKza,EAAAz5B,SAASm0C,MACd,KAAK1a,EAAAz5B,SAASo0C,MACd,KAAK3a,EAAAz5B,SAASq0C,MACd,KAAK5a,EAAAz5B,SAASs0C,MACd,KAAK7a,EAAAz5B,SAASu0C,MACd,KAAK9a,EAAAz5B,SAASw0C,MACd,KAAK/a,EAAAz5B,SAASy0C,MACd,KAAKhb,EAAAz5B,SAAS00C,MACd,KAAKjb,EAAAz5B,SAAS20C,MACd,KAAKlb,EAAAz5B,SAAS40C,MACd,KAAKnb,EAAAz5B,SAAS60C,MACd,KAAKpb,EAAAz5B,SAAS80C,MACd,KAAKrb,EAAAz5B,SAAS+0C,MACd,KAAKtb,EAAAz5B,SAASg1C,MAAO,OAAO,EAG5B,KAAKvb,EAAAz5B,SAASi1C,OACZ,QAEIxb,EAAA9a,gBAAgB2R,EAAUmJ,EAAA9Z,cAAcnR,KAAUirB,EAAApiC,aAAaolB,QAEhC,GAA7Bgd,EAAA5a,iBAAiByR,IAEc,GAA7BmJ,EAAA5a,iBAAiByR,KAChB1oD,KAAKqrE,YAAYxZ,EAAA7Z,eAAepR,GAAO3nB,KAI5C4yC,EAAA9a,gBAAgB2R,EAAUmJ,EAAA7Z,eAAepR,KAAUirB,EAAApiC,aAAaolB,QAEjC,GAA7Bgd,EAAA5a,iBAAiByR,IAEc,GAA7BmJ,EAAA5a,iBAAiByR,KAChB1oD,KAAKqrE,YAAYxZ,EAAA9Z,cAAcnR,GAAO3nB,KASjD,KAAK4yC,EAAAz5B,SAASk1C,OAGZ,QAGMzb,EAAA9a,gBAAgB2R,EAAUmJ,EAAA9Z,cAAcnR,KAAUirB,EAAApiC,aAAaolB,OAC/Dgd,EAAA5a,iBAAiByR,IAAYzpC,EAAK6zC,wBAAwBplD,EAAAkH,KAAKxR,OAC3DpD,KAAKqrE,YAAY3iB,EAASzpC,IAG9B4yC,EAAA9a,gBAAgB2R,EAAUmJ,EAAA7Z,eAAepR,KAAUirB,EAAApiC,aAAaolB,OAChEgd,EAAA5a,iBAAiByR,IAAYzpC,EAAK6zC,wBAAwBplD,EAAAkH,KAAKxR,OAC3DpD,KAAKqrE,YAAY3iB,EAASzpC,IAMtC,KAAK4yC,EAAAz5B,SAASm1C,OACZ,IAAIxgC,EAAQ,GAAK9tB,EAAK2sB,KACtB,OAAOimB,EAAA9a,gBAAgB2R,EAAUmJ,EAAA7Z,eAAepR,KAAUirB,EAAApiC,aAAaolB,OAChEgd,EAAA5a,iBAAiByR,GAAW3b,EAIrC,KAAK8kB,EAAAz5B,SAASo1C,OACRzgC,EAAQ,GAAK9tB,EAAK2sB,KACtB,OAAO5rC,KAAKqrE,YAAYxZ,EAAA9Z,cAAcnR,GAAO3nB,KAC3C4yC,EAAA9a,gBAAgB2R,EAAUmJ,EAAA7Z,eAAepR,KAAUirB,EAAApiC,aAAaolB,OAChEgd,EAAA5a,iBAAiByR,GAAW3b,GAMhC,KAAK8kB,EAAAz5B,SAASq1C,OACR1gC,EAAQ,GAAK9tB,EAAK2sB,KACtB,OAAO3sB,EAAKK,GAAE,KAERuyC,EAAA9a,gBAAgB2R,EAAUmJ,EAAA7Z,eAAepR,KAAUirB,EAAApiC,aAAaolB,OAChEgd,EAAA5a,iBAAiByR,GAAW3b,GAE9B/sC,KAAKqrE,YAAYxZ,EAAA9Z,cAAcnR,GAAO3nB,MACpC4yC,EAAA9a,gBAAgB2R,EAAUmJ,EAAA7Z,eAAepR,KAAUirB,EAAApiC,aAAaolB,OAChEgd,EAAA5a,iBAAiByR,IAAY3b,GAKrC,KAAK8kB,EAAAz5B,SAASs1C,OACd,KAAK7b,EAAAz5B,SAASu1C,OACd,KAAK9b,EAAAz5B,SAASw1C,OACZ,OAAO5tE,KAAKqrE,YAAYxZ,EAAA9Z,cAAcnR,GAAO3nB,IACtCjf,KAAKqrE,YAAYxZ,EAAA7Z,eAAepR,GAAO3nB,GAGlD,MAGF,KAAK4yC,EAAApiC,aAAasmB,MAChB,OAAQ8b,EAAA5Z,WAAWrR,IAGjB,KAAKirB,EAAA/+B,QAAQg4C,OACb,KAAKjZ,EAAA/+B,QAAQi4C,OAAQ,OAAO,EAG5B,KAAKlZ,EAAA/+B,QAAQ+6C,OACb,KAAKhc,EAAA/+B,QAAQg7C,OACb,KAAKjc,EAAA/+B,QAAQi7C,UAAW,OAAO9uD,EAAK2sB,KAAO,EAE7C,MAIF,KAAKimB,EAAApiC,aAAaolB,MAChB,IAAIvzC,EAAa,EACjB,OAAQuwD,EAAA7a,kBAAkBpQ,IACxB,KAAKirB,EAAAriC,WAAWppB,IAAO9E,EAAQuwD,EAAA5a,iBAAiBrQ,GAAO,MACvD,KAAKirB,EAAAriC,WAAWnpB,IAAO/E,EAAQuwD,EAAA3a,oBAAoBtQ,GAAO,MAC1D,KAAKirB,EAAAriC,WAAW3oB,IAAOvF,EAAQ8B,IAAIyuD,EAAAza,iBAAiBxQ,IAAQ,MAC5D,KAAKirB,EAAAriC,WAAW1oB,IAAOxF,EAAQ8B,IAAIyuD,EAAAxa,iBAAiBzQ,IAAQ,MAC5D,QAASx8B,QAAO,GAElB,OAAQ6U,EAAKxI,MACX,OAAkB,OAAOnV,EAAQ4B,GAAG8qE,WAAa1sE,EAAQ4B,GAAGuxC,UAC5D,OAAmB,OAAOnzC,EAAQ6B,IAAI6qE,WAAa1sE,EAAQ6B,IAAIsxC,UAC/D,OAAkB,OAAOnzC,EAAQ,GAAKA,EAAQiC,GAAGkxC,UACjD,OAAmB,OAAOnzC,EAAQ,GAAKA,EAAQkC,IAAIixC,UACnD,QAAoB,OAAuB,KAAP,EAARnzC,GAE9B,MAIF,KAAKuwD,EAAApiC,aAAa+lB,KAChB,IAAIy4B,OAAQ,EACRpmC,EAASgqB,EAAAvZ,aAAa1R,GAC1B,OAAQirB,EAAA1Z,aAAavR,IACnB,KAAK,EAAMqnC,EAAWpmC,EAASn6B,EAAAkH,KAAK1R,GAAMwK,EAAAkH,KAAKrR,GAAK,MACpD,KAAK,EAAM0qE,EAAWpmC,EAASn6B,EAAAkH,KAAKzR,IAAMuK,EAAAkH,KAAKpR,IAAK,MACpD,QAAWyqE,EAAWpmC,EAASn6B,EAAAkH,KAAKxR,IAAMsK,EAAAkH,KAAKnR,IAEjD,OAAO8nE,EAAsB0C,EAAUhvD,GAMzC,KAAK4yC,EAAApiC,aAAa8uB,MAChB,IAAKsT,EAAA9Y,aAAanS,GAAO,CACvB,IAAIgF,EAAOxhC,OAAOynD,EAAA5Y,mBAAmBrS,IACjCsnC,EAAOrc,EAAA1Y,cAAcvS,EAAMgF,EAAO,GACtC,OAAO5rC,KAAKqrE,YAAY6C,EAAMjvD,GAEhC,MAIF,KAAK4yC,EAAApiC,aAAakvB,GAChB,OAAO3+C,KAAKqrE,YAAYxZ,EAAAtY,UAAU3S,GAAO3nB,IAClCjf,KAAKqrE,YAAYjhE,OAAOynD,EAAApY,WAAW7S,IAAQ3nB,GAIpD,KAAK4yC,EAAApiC,aAAauyB,OAChB,OAAOhiD,KAAKqrE,YAAYxZ,EAAA1X,cAAcvT,GAAO3nB,IACtCjf,KAAKqrE,YAAYxZ,EAAAxX,cAAczT,GAAO3nB,GAI/C,KAAK4yC,EAAApiC,aAAasvB,KAChB,IACIvtC,EADUxR,KAAK4nE,eAAepiD,QACJhU,gBAC1B28D,EAAe/jE,OAAOynD,EAAAhX,cAAcjU,IACxC,GAAIp1B,EAAgBgD,IAAI25D,GAAe,CACrC,IAAI5lD,EAAW/W,EAAgBtQ,IAAIitE,GACnC/jE,OAAOme,EAAS9R,MAAQm7C,EAAA9gD,YAAY6N,UACpC,IAAIysB,EAAwB7iB,EAAUtU,UAAUm3B,WAChD,OAAmB7iB,EAAU6B,KAAK9K,GAAE,IAC7BisD,EAAsBngC,EAAYnsB,GAE3C,OAAO,EAIT,KAAK4yC,EAAApiC,aAAa2uB,YAAa,OAAO,EAExC,OAAO,GAGT/zB,EAAApoB,UAAAyJ,SAAA,WAGE,IAFA,IAAI0iE,EAAS,EACTl6D,EAASlU,KAAKkU,OACXA,GACLA,EAASA,EAAOA,SACdk6D,EAEJ,MAAO,QAAUpuE,KAAKokE,eAAiB,KAAOgK,EAAO1iE,WAAa,KAEtE2e,EAl0BA,GAq0BA,SAASkhD,EAAsB0C,EAAgB/oB,GAC7C,OAAQ+oB,EAAS3uD,GAAE,IACZ2uD,EAASriC,KAAOsZ,EAAOtZ,MACvBqiC,EAAS3uD,GAAE,IAAsB4lC,EAAO5lC,GAAE,GAUnD,SAAS+uD,EAAoBznC,EAAqB0nC,GAChD,OAAQzc,EAAA9a,gBAAgBnQ,IACtB,KAAKirB,EAAApiC,aAAa0lB,SAChBm5B,EAAKt5D,IAAI68C,EAAAva,iBAAiB1Q,IAC1B,MAEF,KAAKirB,EAAApiC,aAAa0vB,SAChBmvB,EAAKt5D,IAAI68C,EAAAta,iBAAiB3Q,IAG5B,QAASirB,EAAApT,SAAS7X,EAAM0nC,EAAMD,IA51BrB3uE,EAAA2qB,OA40Bb3qB,EAAA6uE,eAAA,SAA+B3nC,EAAqB0nC,GAElD,YAFkD,IAAAA,MAAA,IAAqBnnE,KACvE0qD,EAAApT,SAAS7X,EAAM0nC,EAAMD,GACdC,64BC9hCT,IAAAjO,EAAAlgE,EAAA,IASAsN,EAAAtN,EAAA,GAKA0xD,EAAA1xD,EAAA,GA4BAqN,EAAArN,EAAA,GAYAyxD,EAAAzxD,EAAA,GAwBA0N,EAAA1N,EAAA,IAOAyN,EAAAzN,EAAA,GAIAiiD,EAAAjiD,EAAA,GAKAwN,EAAAxN,EAAA,GA+DAuN,EAAAvN,EAAA,GAQA0J,EAAA1J,EAAA,GAWAquE,EAAA,oBAAAA,IAGExuE,KAAAqtB,OAAiB7f,EAAApE,OAAOsM,OAExB1V,KAAA2V,UAAiB,EAEjB3V,KAAAyuE,cAAqB,EAErBzuE,KAAA0uE,aAAoB,EAEpB1uE,KAAA2uE,aAAoB,EAEpB3uE,KAAA0qB,WAAkB,EAElB1qB,KAAA4uE,eAAsB,EAEtB5uE,KAAA4V,WAAkB,EAElB5V,KAAA6b,cAA2C,KAE3C7b,KAAA6uE,SAAQ,EAGR7uE,KAAA6V,kBAAyB,EAEzB7V,KAAA8V,gBAAuB,EA0BzB,OAvBE/U,OAAAC,eAAIwtE,EAAAvsE,UAAA,WAAQ,KAAZ,WACE,OAAOjC,KAAKqtB,QAAU7f,EAAApE,OAAOqM,wCAI/B1U,OAAAC,eAAIwtE,EAAAvsE,UAAA,YAAS,KAAb,WACE,OAAOjC,KAAKqtB,QAAU7f,EAAApE,OAAOqM,OAAS/H,EAAAkH,KAAK49C,QAAU9kD,EAAAkH,KAAK69C,yCAI5D1xD,OAAAC,eAAIwtE,EAAAvsE,UAAA,YAAS,KAAb,WACE,OAAOjC,KAAKqtB,QAAU7f,EAAApE,OAAOqM,OAAS/H,EAAAkH,KAAK09C,QAAU5kD,EAAAkH,KAAK29C,yCAI5DxxD,OAAAC,eAAIwtE,EAAAvsE,UAAA,iBAAc,KAAlB,WACE,OAAOjC,KAAKqtB,QAAU7f,EAAApE,OAAOqM,OAASo8C,EAAAriC,WAAWnpB,IAAMwrD,EAAAriC,WAAWppB,qCAIpEooE,EAAAvsE,UAAAoT,WAAA,SAAWy5D,GACT,OAAoC,IAA5B9uE,KAAK6uE,SAAWC,IAE5BN,EApDA,GAAa9uE,EAAA8uE,UAuDb,SAAkBO,GAChBA,IAAA,eAGAA,IAAA,iCAEAA,IAAA,iCAEAA,IAAA,yBAGAA,IAAA,yBAEAA,IAAA,8BAEAA,IAAA,kCAfF,CAAkBrvE,EAAAqvE,cAAArvE,EAAAqvE,YAAW,KAmB7B,SAAkBC,GAChBA,IAAA,eAEAA,IAAA,eAEAA,IAAA,eAEAA,IAAA,+BAEAA,IAAA,+BATF,CAAkBtvE,EAAAsvE,kBAAAtvE,EAAAsvE,gBAAe,KAajC,IA+hRIC,EACAC,EAhiRJC,EAAA,SAAAl+D,GA2CE,SAAAk+D,EAAY3pD,EAAkB9Q,QAAA,IAAAA,MAAA,MAA9B,IAAAxD,EACED,EAAAzQ,KAAAR,KAAMwlB,EAAQzY,cAAY/M,KA/B5BkR,EAAAk+D,uBAAqC,GAErCl+D,EAAAm+D,YAA2B,KAE3Bn+D,EAAAo+D,YAAoB5hE,EAAAkH,KAAKG,KAMzB7D,EAAAq+D,eAAkC,GAElCr+D,EAAAs+D,eAA4C,IAAIpoE,IAEhD8J,EAAAu+D,cAA0B,CAAE,QAE5Bv+D,EAAAw+D,QAAqB,EAErBx+D,EAAAy+D,QAAuB,EAEvBz+D,EAAA0+D,gBAAe,EAEf1+D,EAAA2+D,oBAA0C,IAAI1oE,IAywFtC+J,EAAA4+D,eAAkC,KAClC5+D,EAAA6+D,eAAkC,KAClC7+D,EAAA8+D,eAAkC,KAClC9+D,EAAA++D,eAAkC,KAlwFxC/+D,EAAKsU,QAAUA,EACftU,EAAKmB,SAAWmT,EAAQnT,SACnBqC,IAASA,EAAU,IAAI85D,GAC5Bt9D,EAAKwD,QAAUA,EACfxD,EAAKoa,aAAe/V,QAGlBo1D,IAAIj2D,EAAQkB,WAAY,IAE1B1E,EAAKvR,OAASkyD,EAAAvtB,OAAO3iC,SACrB,IAAImwC,EAAqC,SACrC5gC,EAAKwD,QAAQW,WAAU,MAAmBy8B,GAAgB+f,EAAA3hC,aAAaggD,SACvEh/D,EAAKwD,QAAQW,WAAU,KAA0By8B,GAAgB+f,EAAA3hC,aAAaigD,gBAE9Ej/D,EAAKwD,QAAQW,WAAU,KAAgBy8B,GAAgB+f,EAAA3hC,aAAakgD,SACpEl/D,EAAKwD,QAAQW,WAAU,KAAuBy8B,GAAgB+f,EAAA3hC,aAAamgD,YAC3En/D,EAAKwD,QAAQW,WAAU,KAA0By8B,GAAgB+f,EAAA3hC,aAAaogD,SAElFp/D,EAAKvR,OAAOkyC,YAAYC,KAu6Q5B,OAt+Q8Bv/B,EAAA48D,EAAAl+D,GAsCrBk+D,EAAAoB,QAAP,SAAe/qD,EAAkB9Q,GAC/B,YAD+B,IAAAA,MAAA,MACxB,IAAIy6D,EAAS3pD,EAAS9Q,GAAS67D,WA4BxCpB,EAAAltE,UAAAsuE,QAAA,uBACM77D,EAAU1U,KAAK0U,QACf/U,EAASK,KAAKL,OACd6lB,EAAUxlB,KAAKwlB,QAGnBA,EAAQ/Q,WAAWC,GAGnB,IAAI87D,EAAwBhrD,EAAQxR,mBAAmB,QAAS,IAAItG,EAAA0Y,UAAU,GAAI1Y,EAAAkH,KAAKG,OACvFy7D,EAAsBp+D,aAAe,QACrC,IAAIq+D,EAAoB,IAAIxpE,MAC5BjH,KAAK0wE,YAAcF,EAAsBpmD,KACzCpqB,KAAK2wE,YAAcF,EAGf/7D,EAAQc,UACV7V,EAAOstC,UAAUozB,EAAA2E,eAAe4L,UAAW/e,EAAAriC,WAAWnpB,KAAK,EAAM1G,EAAO0D,IAAI,IAC5E1D,EAAOstC,UAAUozB,EAAA2E,eAAe6L,UAAWhf,EAAAriC,WAAWnpB,KAAK,EAAM1G,EAAO0D,IAAI,MAE5E1D,EAAOstC,UAAUozB,EAAA2E,eAAe4L,UAAW/e,EAAAriC,WAAWppB,KAAK,EAAMzG,EAAOyD,IAAI,IAC5EzD,EAAOstC,UAAUozB,EAAA2E,eAAe6L,UAAWhf,EAAAriC,WAAWppB,KAAK,EAAMzG,EAAOyD,IAAI,KAI9E,IAAI0tE,EAAQtrD,EAAQnU,gBACpB,IAAiB,IAAA+M,EAAArG,EAAA+4D,EAAMvzD,UAAQc,EAAAD,EAAAnG,QAAAoG,EAAAnG,KAAAmG,EAAAD,EAAAnG,OAAE,EAAxB5B,EAAIgI,EAAA/c,OACFqK,OAAO8R,UACdzd,KAAK+wE,YAAY16D,GACjBrW,KAAKgxE,eAAe36D,sGAKxB,IAAI46D,GAAgBR,EAAkBtkE,OAClCyiE,EAAgBl6D,EAAQk6D,cAC5B,IAAKqC,GAAgBrC,EAAe,CAClC,IAAI36D,EAAYu8D,EAAsBv8D,WACjCg9D,GAAgBrC,IACnBjvE,EAAOstC,UAAUozB,EAAA2E,eAAekM,QAASrf,EAAAriC,WAAWppB,KAAK,EAAMzG,EAAOyD,IAAI,IAC1EqtE,EAAkBU,QAChBxxE,EAAOyqC,GACLzqC,EAAO+nC,WAAW24B,EAAA2E,eAAekM,QAASrf,EAAAriC,WAAWppB,KACrDzG,EAAO+qC,SACP/qC,EAAO2pC,WAAW+2B,EAAA2E,eAAekM,QAASvxE,EAAOyD,IAAI,OAI3D,IAAIguE,EAAUzxE,EAAO2tC,YACnBkjC,EAAsBp+D,aACtBpS,KAAKqxE,mBACHp9D,EAAU+V,eACV/V,EAAUm3B,WACVn3B,EAAU8V,UAEZrc,EAAAmmD,mBAAmB2c,EAAsB5nD,kBACzCjpB,EAAO6pC,MAAM,KAAMinC,IAErBD,EAAsB/lD,SAAS9qB,EAAQyxE,GAClCxC,EACAjvE,EAAOouC,kBAAkByiC,EAAsBp+D,aAAc,WAD9CzS,EAAOixC,SAASwgC,GAKd,EAApBpxE,KAAK4vE,iBAAgDvP,EAAAiR,oBAAoBtxE,MACrD,EAApBA,KAAK4vE,iBAAgDvP,EAAAkR,oBAAoBvxE,MAC7EL,EAAOytC,aAAaizB,EAAA2E,eAAe6L,WACX,EAApB7wE,KAAK4vE,iBAAwCvP,EAAAmR,YAAYxxE,MAG7D,IAAIsrB,EAAetrB,KAAKsrB,aACxBA,EAAemmD,UAAUnmD,EAAc5W,EAAQI,UAAUo9C,UACzDlyD,KAAKsrB,aAAeA,EACpB3rB,EAAOytC,aAAaizB,EAAA2E,eAAe4L,WACX,EAApB5wE,KAAK4vE,kBACHl7D,EAAQc,SACV7V,EAAOstC,UACLozB,EAAA2E,eAAe4L,UACf/e,EAAAriC,WAAWnpB,KACX,EACA1G,EAAO0D,IAAI6sC,QAAQ5kB,GAAe6kB,SAAS7kB,KAG7C3rB,EAAOstC,UACLozB,EAAA2E,eAAe4L,UACf/e,EAAAriC,WAAWppB,KACX,EACAzG,EAAOyD,IAAI8sC,QAAQ5kB,MAMzB,IAAIomD,EAAiBh9D,EAAQW,WAAU,KAAqBX,EAAQg6D,aAAe,EACnF/uE,EAAO+vC,UACL1vC,KAAK0U,QAAQkB,YAAiC5V,KAAKuvE,eAAepjE,OAC9D+jC,QAAQyhC,UAAUF,UAAUnmD,EAAc,OAAU/V,QAAQ,GAAI,KAChE,EACJm8D,EAAiBh9D,EAAQg6D,aAAe7c,EAAAvtB,OAAOwS,iBAC/C92C,KAAKuvE,eACL76D,EAAQ2Y,OACR,SACAqkD,GAIEh9D,EAAQ+5D,cAAc9uE,EAAOyvC,gBAAgB,IAAK,MAAO,SAAUsiC,GAGvE,IAAIjC,EAAgBzvE,KAAKyvE,cACzB9vE,EAAO8wC,iBAAiBg/B,EAActjE,OAAQ,WAAYsjE,GAC1D9vE,EAAO2tC,YAAY,OAAQttC,KAAKqxE,mBAAmB,KAAM3jE,EAAAkH,KAAKG,MAAO,KAAMpV,EAAO6pC,MAAM,KAAM,KAG1F90B,EAAQi6D,aAAahvE,EAAOuvC,eAAe,IAAK,MAAO,aAG3D,IAAiB,IAAAnwB,EAAAhH,EAAA/X,KAAKwlB,QAAQnU,YAAYkM,UAAQyB,EAAAD,EAAA9G,QAAA+G,EAAA9G,KAAA8G,EAAAD,EAAA9G,OAAE,CAA/C,IAAI5B,KAAI2I,EAAA1d,OACFqK,OAAO8R,SAASzd,KAAK4xE,oBAAoBv7D,qGAEpD,OAAO1W,GAIDwvE,EAAAltE,UAAA2vE,oBAAR,SAA4Bv7D,WACtByI,EAAUzI,EAAK3W,QACnB,GAAIof,MAAS,IAA2B,IAAA+yD,EAAA95D,EAAA+G,GAAOgzD,EAAAD,EAAA55D,QAAA65D,EAAA55D,KAAA45D,EAAAD,EAAA55D,OAAA,CAAzB,IAAAyO,EAAAtO,EAAA05D,EAAAxwE,MAAA,GAACV,EAAA8lB,EAAA,GAAMpI,EAAAoI,EAAA,GAAoB1mB,KAAK+xE,mBAAmBnxE,EAAM0d,qGAC/E,IAAIjG,EAAchC,EAAKgC,YACvB,GAAIA,EACF,IAAK,IAAIhY,EAAI,EAAG+V,EAAIiC,EAAYlM,OAAQ9L,EAAI+V,IAAK/V,EAAGL,KAAK4xE,oBAAoBv5D,EAAYhY,KAKrF8uE,EAAAltE,UAAA8vE,mBAAR,SAA2BnxE,EAAcgY,EAAkBo5D,uBACzD,YADyD,IAAAA,MAAA,IACjDp5D,EAAQnC,MAGd,KAAKm7C,EAAA9gD,YAAYkN,mBAEf,GADI8J,EAAgClP,EAASkP,cAE3C,IAAqB,IAAA/I,EAAAhH,EAAA+P,EAAUvK,UAAQyB,EAAAD,EAAA9G,QAAA+G,EAAA9G,KAAA8G,EAAAD,EAAA9G,OAAE,CAApC,IAAIsQ,EAAQvJ,EAAA1d,MACX6sE,EAAevtE,EACnB,GAAI2nB,EAASjJ,GAAG9R,EAAAnL,YAAY8S,SAE1Bg5D,IADI8D,EAAW1pD,EAASnW,cACC3F,UAAUwlE,EAASjiB,YAAY,MAE1DhwD,KAAK+xE,mBAAmB5D,EAAc5lD,EAAUypD,qGAGpD,MAEF,KAAKpgB,EAAA9gD,YAAYuJ,gBACf,IAAIyN,EACJ,GADIA,EAA6BlP,EAASkP,cAExC,IAAqB,IAAA3P,EAAAJ,EAAA+P,EAAUvK,UAAQpE,EAAAhB,EAAAF,QAAAkB,EAAAjB,KAAAiB,EAAAhB,EAAAF,OAAE,CAApC,IAGGg6D,EAHC1pD,EAAQpP,EAAA7X,MACX6sE,EAAevtE,EACnB,GAAI2nB,EAASjJ,GAAG9R,EAAAnL,YAAY8S,SAE1Bg5D,IADI8D,EAAW1pD,EAASnW,cACC3F,UAAUwlE,EAASjiB,YAAY,MAE1DhwD,KAAK+xE,mBAAmB5D,EAAc5lD,EAAUypD,qGAGpD,MAEF,KAAKpgB,EAAA9gD,YAAYyN,mBACf,IAAI1d,EAA6B+X,EAAS4F,gBACtC0zD,EAA6Bt5D,EAAS6F,gBACtC5d,GAAQb,KAAK+xE,mBAAmBvkE,EAAAhL,cAAgB5B,EAAMC,EAAQmxE,GAC9DE,GAAQlyE,KAAK+xE,mBAAmBvkE,EAAA/K,cAAgB7B,EAAMsxE,EAAQF,GAClE,MAIF,KAAKpgB,EAAA9gD,YAAYmQ,OACDrI,EAAQ0G,GAAG9R,EAAAnL,YAAYod,QAAU7G,EAAQ0G,GAAG9R,EAAAnL,YAAY6f,OAAS1U,EAAAnL,YAAY+f,WAC1EpiB,KAAK0U,QAAQW,WAAU,GAMtCrV,KAAKL,OAAO6uC,gBAAgB51B,EAAQxG,aAAc4/D,EAASpxE,GAL3DZ,KAAKqN,MACHI,EAAAhD,eAAe0nE,+BACNv5D,EAAS4C,eAAezQ,OAKrC,MAEF,KAAK6mD,EAAA9gD,YAAY0W,UACE5O,EAAS6O,aAAgBznB,KAAK0U,QAAQW,WAAU,GAM/DrV,KAAKL,OAAO6uC,gBAAgB51B,EAAQxG,aAAc4/D,EAASpxE,GAL3DZ,KAAKqN,MACHI,EAAAhD,eAAe0nE,+BACHv5D,EAAS4C,eAAezQ,OAKxC,MAEF,KAAK6mD,EAAA9gD,YAAY6N,SACf,IACI1K,GADAsU,EAAqB3P,GACA3E,UACrBA,EAAUkgD,mBAAqBlgD,EAAU+V,eAAe7d,SAE1Doc,EAAWvoB,KAAKoyE,iBAAiB7pD,GACjCvoB,KAAKqyE,iBAEH9pD,EAASjJ,GAAG9R,EAAAnL,YAAYiwE,WAAWtyE,KAAKL,OAAOouC,kBAAkBxlB,EAASnW,aAAc4/D,EAASpxE,GACrG,MAEF,KAAKgxD,EAAA9gD,YAAY4N,UACX7d,EAAoB+X,EAAS6S,iBACrBzrB,KAAK+xE,mBAAmBvkE,EAAAhL,cAAgB5B,EAAMC,EAAQmxE,IAC9DE,EAAoBt5D,EAAS8S,iBACrB1rB,KAAK+xE,mBAAmBvkE,EAAA/K,cAAgB7B,EAAMsxE,EAAQF,GAClE,MAEF,KAAKpgB,EAAA9gD,YAAY8N,MACf5e,KAAKuyE,wBAAwBP,EAASxkE,EAAAhL,cAAgB5B,EAAagY,GAC9DA,EAAQ0G,GAAG9R,EAAAnL,YAAY+f,WAC1BpiB,KAAKwyE,wBAAwBR,EAASxkE,EAAA/K,cAAgB7B,EAAagY,GAErE,MAEF,KAAKg5C,EAAA9gD,YAAY+N,MAEf,IAAajG,EAASqG,KAAKwzD,YAAa,CACtC,IAAI9yE,EAASK,KAAKL,OACdyS,EAAuBwG,EAASxG,aACpCzS,EAAOstC,UAAU76B,EAAcy/C,EAAAriC,WAAWppB,KAAK,EAAOzG,EAAOyD,IAAYwV,EAAS9F,KAClFnT,EAAO6uC,gBAAgBp8B,EAAc4/D,EAASpxE,GAEhD,MAIF,KAAKgxD,EAAA9gD,YAAYkW,KACjB,KAAK4qC,EAAA9gD,YAAYiW,UACjB,KAAK6qC,EAAA9gD,YAAY4U,KACjB,KAAKksC,EAAA9gD,YAAY8V,eAAgB,MAEjC,QAASxc,QAAO,GAIlB,IAAI0U,EAAUlG,EAAQkG,QACtB,GAAIA,EAAS,CACX,IAAI4zD,EAAYV,EAASpxE,GAAQgY,EAAQnC,MAAQm7C,EAAA9gD,YAAY+N,MACzDrR,EAAA9K,mBACA8K,EAAA7K,kBAEJ,GACEiW,EAAQnC,MAAQm7C,EAAA9gD,YAAYiW,WAC5BnO,EAAQnC,MAAQm7C,EAAA9gD,YAAY4U,SAE5B,IAAmB,IAAAnM,EAAAxB,EAAA+G,EAAQvB,UAAQvB,EAAAzC,EAAAtB,QAAA+D,EAAA9D,KAAA8D,EAAAzC,EAAAtB,OAAE,EAA5BqG,EAAMtC,EAAA1a,OACDge,GAAG9R,EAAAnL,YAAY6S,SAC3BlV,KAAK+xE,mBAAmBzzD,EAAO1d,KAAM0d,EAAQo0D,8GAG/C,IAAmB,IAAAp1D,EAAAvF,EAAA+G,EAAQvB,UAAQC,EAAAF,EAAArF,QAAAuF,EAAAtF,KAAAsF,EAAAF,EAAArF,OAAE,CAAhC,IAAIqG,KAAMd,EAAAlc,OACFge,GAAG9R,EAAAnL,YAAYq0D,UAC1B12D,KAAK+xE,mBAAmBzzD,EAAO1d,KAAM0d,EAAQo0D,wGAO7CvD,EAAAltE,UAAAswE,wBAAR,SAAgC3xE,EAAc+sB,GAC5C,IAAIhuB,EAASK,KAAKL,OACdsf,EAAO0O,EAAM1O,KACbnK,EAAY9U,KAAK0U,QAAQI,UACzB69D,EAAWhzE,EAAOioC,KAAK3oB,EAAKizC,SAAUjzC,EAAKK,GAAE,GAC/C3f,EAAO2nC,UAAU,EAAGxyB,EAAU2+C,gBAC9Bx0C,EAAKw0C,eAAgB9lC,EAAMrC,cAGzBrM,EAAK2zD,YAAWD,EAAW3yE,KAAK6yE,WAAWF,IAC/ChzE,EAAO2tC,YACL1sC,EACAZ,KAAKqxE,mBAAmB,KAAMpyD,EAAMnK,GACpC,KACA69D,GAEFhzE,EAAOouC,kBAAkBntC,EAAMA,IAIzBuuE,EAAAltE,UAAAuwE,wBAAR,SAAgC5xE,EAAc+sB,GAC5C,IAAIhuB,EAASK,KAAKL,OACdsf,EAAO0O,EAAM1O,KACb6zD,EAAa7zD,EAAKw0C,eAClB3+C,EAAY9U,KAAK0U,QAAQI,UACzBi+D,EAAiBj+D,EAAU2+C,eAC3Buf,EAAYrzE,EAAO2nC,UAAU,EAAGwrC,GAChC7zD,EAAK2zD,YACPI,EAAYhzE,KAAKizE,kBACftzE,EAAOioC,KAAK3oB,EAAKizC,UAAU,EACzBvyD,EAAO2nC,UAAU,EAAGyrC,GACpBD,EAAYnlD,EAAMrC,cAEpB0nD,IAGJrzE,EAAO2tC,YACL1sC,EACAZ,KAAKqxE,mBAAmB,CAAEpyD,GAAQvR,EAAAkH,KAAKG,KAAMD,GAC7C,KACAnV,EAAO6mC,MACLvnB,EAAKizC,SACLvyD,EAAO2nC,UAAU,EAAGyrC,GACpBC,EACAF,EACAnlD,EAAMrC,eAGV3rB,EAAOouC,kBAAkBntC,EAAMA,IAMjCuuE,EAAAltE,UAAAixE,eAAA,SAAet6D,EAAkBu6D,GAC/B,YAD+B,IAAAA,OAAA,GACvBv6D,EAAQnC,MACd,KAAKm7C,EAAA9gD,YAAYmQ,OACfjhB,KAAKozE,cAAsBx6D,GAC3B,MAEF,KAAKg5C,EAAA9gD,YAAYkW,KACfhnB,KAAKqzE,YAAkBz6D,GACvB,MAEF,KAAKg5C,EAAA9gD,YAAYkN,mBACVpF,EAAQ0G,GAAG9R,EAAAnL,YAAY8S,UAC1BnV,KAAKszE,kCAAqD16D,EAAS,IAErE,MAEF,KAAKg5C,EAAA9gD,YAAYuJ,gBACVzB,EAAQ0G,GAAG9R,EAAAnL,YAAY8S,UAC1BnV,KAAKuzE,+BAA+C36D,EAAS,IAE/D,MAEF,KAAKg5C,EAAA9gD,YAAYyN,mBACf,IAAIC,EAAsC5F,EAAS4F,gBAC/CA,GACFxe,KAAKszE,kCAAkC90D,EAAiB,IAE1D,IAAIC,EAAsC7F,EAAS6F,gBAC/CA,GACFze,KAAKszE,kCAAkC70D,EAAiB,IAE1D,MAEF,KAAKmzC,EAAA9gD,YAAYiW,UACjB,KAAK6qC,EAAA9gD,YAAY8V,eACjB,KAAKgrC,EAAA9gD,YAAY0W,UAAW,MAC5B,QAASpd,QAAO,EAAOwnD,EAAA9gD,YAAY8H,EAAQnC,OAEzC08D,GAAgBnzE,KAAKmzE,eAAev6D,IAI1Cu2D,EAAAltE,UAAAkxE,eAAA,SAAev6D,WACTkG,EAAUlG,EAAQkG,QACtB,GAAIA,MAAS,IAAoB,IAAA4H,EAAA3O,EAAA+G,EAAQvB,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAA,CAA/B,IAAIu7D,EAAOp1D,EAAA9c,MAAsBtB,KAAKkzE,eAAeM,uGAIzErE,EAAAltE,UAAA+uE,eAAA,SAAe36D,eACT3W,EAAU2W,EAAK3W,QACnB,GAAIA,MAAS,IAAoB,IAAA0e,EAAArG,EAAArY,EAAQ6d,UAAQc,EAAAD,EAAAnG,QAAAoG,EAAAnG,KAAAmG,EAAAD,EAAAnG,OAAA,CAA/B,IAAIW,EAAOyF,EAAA/c,MAAsBtB,KAAKkzE,eAAet6D,qGACvE,IAAIP,EAAchC,EAAKgC,YACvB,GAAIA,MACF,IAAuB,IAAAo7D,EAAA17D,EAAAM,GAAWq7D,EAAAD,EAAAx7D,QAAAy7D,EAAAx7D,KAAAw7D,EAAAD,EAAAx7D,OAAE,CAA/B,IAAIK,EAAUo7D,EAAApyE,MACjBtB,KAAK+wE,YAAYz4D,GACjBtY,KAAKgxE,eAAe14D,uGAQ1B62D,EAAAltE,UAAA0xE,kBAAA,SAAkBC,EAAwC7N,GACxD,IAAI1vD,EAEAw9D,EADAxiE,EAAcrR,KAAKwlB,QAAQnU,YAE/B,GAAIA,EAAYmD,IAAIo/D,GAClBv9D,EAAOhF,EAAYnQ,IAAI0yE,OAClB,KAAIviE,EAAYmD,IAAIq/D,EAAgBD,EAAiCpmE,EAAAzK,cAO1E,YAJA/C,KAAKqN,MACHI,EAAAhD,eAAeiO,iBACfqtD,EAAWh7D,MAAO6oE,GAJpBv9D,EAAOhF,EAAYnQ,IAAI2yE,GAQzB7zE,KAAK+wE,YAAY16D,IAInB84D,EAAAltE,UAAA8uE,YAAA,SAAY16D,GACV,IAAIA,EAAKiJ,GAAG9R,EAAAnL,YAAYiwE,UAAxB,CACAj8D,EAAKlE,IAAI3E,EAAAnL,YAAYiwE,UAGrB,IAAInsD,EAAgB9P,EAAK8P,cACrB2tD,EAAe9zE,KAAK2wE,YACpBF,EAAoB,IAAIxpE,MAC5BjH,KAAK2wE,YAAcF,EAGnB,IAAIsD,EAAe/zE,KAAK0wE,YACpBtmD,EAAOjE,EAAciE,KACzBpqB,KAAK0wE,YAActmD,EACnB,IAAK,IAAI9T,EAAaD,EAAK1K,OAAO2K,WAAYjW,EAAI,EAAG+V,EAAIE,EAAWnK,OAAQ9L,EAAI+V,IAAK/V,EACnFL,KAAKg0E,yBAAyB19D,EAAWjW,GAAIowE,GAO/C,GALAzwE,KAAKi0E,mBAAmB7pD,EAAMqmD,GAC9BzwE,KAAK0wE,YAAcqD,EACnB/zE,KAAK2wE,YAAcmD,EAGfrD,EAAkBtkE,OAAQ,CAC5B,IAAIxM,EAASK,KAAKL,OACd6qB,EAASrE,EAAcwC,cACvBurD,EAAY1pD,EAAOre,OACnBohC,EAAW,IAAItmC,MAAkBitE,GACrC,IAAS7zE,EAAI,EAAGA,EAAI6zE,IAAa7zE,EAAGktC,EAASltC,GAAKmqB,EAAOnqB,GAAG4e,KAAKw0C,eACjE9zD,EAAO2tC,YACLnnB,EAAc/T,aACdpS,KAAKqxE,mBAAmBlrD,EAAclS,UAAU+V,eAAgB7D,EAAclS,UAAUm3B,YACxFmC,EACAkjC,EAAkBtkE,OAAS,EACvBxM,EAAO6pC,MAAM,KAAMinC,GACnBA,EAAkB,IAExBqD,EAAapnE,KACX/M,EAAOa,KAAK2lB,EAAc/T,aAAc,KAAMy/C,EAAAriC,WAAWyY,UAO/DknC,EAAAltE,UAAAmxE,cAAA,SAAc7zD,GACZ,GAAIA,EAAOD,GAAG9R,EAAAnL,YAAYiwE,UAAW,OAAO,EAC5C/yD,EAAOpN,IAAI3E,EAAAnL,YAAYiwE,UAEvB,IAAI3yE,EAASK,KAAKL,OACdw0E,EAA0B,EAC1BC,GAA+B,EAC/BlT,EAAW3hD,EAAO2hD,SAClBmT,EAAkB90D,EAAO80D,gBAE7B,IAAK90D,EAAOD,GAAG9R,EAAAnL,YAAY6jB,UAGzB,GAAIg7C,EAAU,CACZ,IAAIgC,EAAeljE,KAAKqS,SAASmuD,YAAYU,EAAU3hD,EAAOrL,QAC9D,IAAKgvD,EAAc,OAAO,EAC1B,GAAIA,GAAgBx1D,EAAAkH,KAAKG,KAKvB,OAJA/U,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACfE,EAASn2D,QAEJ,EAETwU,EAAOL,QAAQgkD,OAGV,KAAImR,EAyBT,OAJAr0E,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACfzhD,EAAO/D,eAAezQ,MAAM87D,QAEvB,EAxBP,IAAIkN,EAAe/zE,KAAK0wE,YASxB,GARInxD,EAAOlE,aAAau2C,EAAA7gD,eAAeuR,QACrCtiB,KAAK0wE,YAAcnxD,EAAOlJ,KAAK8P,cAAciE,MAE/C+pD,EAAWn0E,KAAKs0E,kBAAkBD,EAAiB3mE,EAAAkH,KAAK89C,KACtD,IAEE1yD,KAAK6vE,oBAAoBr7D,IAAI2/D,KAAWC,GAAyB,GACrEp0E,KAAK0wE,YAAcqD,EACf/zE,KAAKsvE,aAAe5hE,EAAAkH,KAAKG,KAK3B,OAJA/U,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACfF,EAAgBtpE,MAAO/K,KAAKsvE,YAAY5jE,WAAY,WAE/C,EAET6T,EAAOL,QAAQlf,KAAKsvE,aAaxB,GAAI/vD,EAAOD,GAAG9R,EAAAnL,YAAY0iB,UAAYxF,EAAOlE,aAAau2C,EAAA7gD,eAAeqE,SAGvE,OAFImK,EAAOnN,cAAgBiuD,EAAA2E,eAAe4L,UAAW5wE,KAAK4vE,iBAAe,EAChErwD,EAAOnN,cAAgBiuD,EAAA2E,eAAe6L,YAAW7wE,KAAK4vE,iBAAe,IACvE,EAGT,IAAI3wD,EAAOM,EAAON,KACd6zD,EAAa7zD,EAAKw0C,eAClB+gB,EAAqBj1D,EAAOD,GAAG9R,EAAAnL,YAAYod,QAAUF,EAAOD,GAAG9R,EAAAnL,YAAY6f,OAAS1U,EAAAnL,YAAY+f,UAChGqyD,EAAmBl1D,EAAOlE,aAAau2C,EAAA7gD,eAAesR,QAG1D,GAAI9C,EAAOD,GAAG9R,EAAAnL,YAAY0iB,SAGxB,OAAIyvD,GAAsBx0E,KAAK0U,QAAQW,WAAU,IAC/CkK,EAAOpN,IAAI3E,EAAAnL,YAAYqyE,eACvBC,EAAiBp1D,EAAQA,EAAOhL,aAChC5U,EAAO4vC,gBACLhwB,EAAOnN,aACP68D,EACAC,EACA4D,GAEFvzD,EAAOpN,IAAI3E,EAAAnL,YAAYiwE,WAChB,IAIPtyE,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf9B,EAAOhL,YAAYxJ,QAGhB,GAKT,IAAI6pE,GAAoB,EAGxB,GAAIP,EAAiB,CACnB,IAAKF,EAAU,CACTJ,EAAe/zE,KAAK0wE,YACpBnxD,EAAOlE,aAAau2C,EAAA7gD,eAAeuR,QACrCtiB,KAAK0wE,YAAcnxD,EAAOlJ,KAAK8P,cAAciE,MAE/C+pD,EAAWn0E,KAAKs0E,kBAAkBD,EAAiBp1D,EACjD,IAEEjf,KAAK6vE,oBAAoBr7D,IAAI2/D,KAAWC,GAAyB,GACrEp0E,KAAK0wE,YAAcqD,EAarB,GAVIliB,EAAA9a,gBAAgBo9B,IAAatiB,EAAApiC,aAAaolB,QACxC2/B,GACFL,EAAWx0E,EAAO6yC,qBAAqB2hC,GACnCtiB,EAAA9a,gBAAgBo9B,IAAatiB,EAAApiC,aAAaolB,QAAO+/B,GAAoB,IAEzEA,GAAoB,GAKpBH,EACF,GAAIG,EACF50E,KAAKmN,QACHM,EAAAhD,eAAeoqE,gCACfR,EAAgBtpE,WAEb,CAGL,OAFAX,OAAOynD,EAAA9a,gBAAgBo9B,IAAatiB,EAAApiC,aAAaolB,OAClCgd,EAAA7a,kBAAkBm9B,IAE/B,KAAKtiB,EAAAriC,WAAWppB,IACdmZ,EAAO4H,kBAAiB,EACxB5H,EAAO8H,qBAAuB9R,QAAQs8C,EAAA5a,iBAAiBk9B,GAAW,GAClE,MAEF,KAAKtiB,EAAAriC,WAAWnpB,IACdkZ,EAAO4H,kBAAiB,EACxB5H,EAAO8H,qBAAuB9R,QAC5Bs8C,EAAA3a,oBAAoBi9B,GACpBtiB,EAAA1a,qBAAqBg9B,IAEvB,MAEF,KAAKtiB,EAAAriC,WAAW3oB,IACd0Y,EAAO4H,kBAAiB,EACxB5H,EAAOgI,mBAAqBsqC,EAAAza,iBAAiB+8B,GAC7C,MAEF,KAAKtiB,EAAAriC,WAAW1oB,IACdyY,EAAO4H,kBAAiB,EACxB5H,EAAOgI,mBAAqBsqC,EAAAxa,iBAAiB88B,GAC7C,MAEF,QAEE,OADA/pE,QAAO,IACA,EAGXmV,EAAOpN,IAAI3E,EAAAnL,YAAYilB,eAM3B6sD,EAAWl1D,EAAKy0C,aAAa/zD,GAG/B,IAAIyS,EAAemN,EAAOnN,aAiB1B,OAfIwiE,GACEH,GACFz0E,KAAKqN,MACHI,EAAAhD,eAAeqW,8BACf1W,OAAOuD,EAAA+jD,cAAc/jD,EAAAe,cAAc2T,OAAQ9C,EAAOu1D,iBAAiB/pE,MAAO,UAG9EpL,EAAOstC,UAAU76B,EAAc0gE,GAAY,EAAM7zD,EAAKy0C,aAAa/zD,IAC/Dsf,EAAK2zD,YAAcwB,IAAwBD,EAAWn0E,KAAK6yE,WAAWsB,IAC1En0E,KAAK2wE,YAAYjkE,KACf/M,EAAO2pC,WAAWl3B,EAAc+hE,KAExBM,GACV90E,EAAOstC,UAAU76B,EAAc0gE,GAAa0B,EAAoBL,IAE3D,GAKThF,EAAAltE,UAAAoxE,YAAA,SAAYz6D,WACV,GAAIA,EAAQ0G,GAAG9R,EAAAnL,YAAYiwE,UAAW,OAAO,EAC7C15D,EAAQzG,IAAI3E,EAAAnL,YAAYiwE,UAExB,IAAI3yE,EAASK,KAAKL,OAClBK,KAAKqvE,YAAcz2D,EACnB,IAAIm8D,EAAkC,KAClCC,GAAqB,EACrBC,EAAWr8D,EAAQ0G,GAAG9R,EAAAnL,YAAYod,QAAU7G,EAAQyC,aAAau2C,EAAA7gD,eAAesR,QAEpF,GAAIzJ,EAAQkG,YACV,IAAmB,IAAA4H,EAAA3O,EAAAa,EAAQkG,QAAQvB,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAE,CAAxC,IAAIqG,EAAMF,EAAA9c,MACb,GAAIgd,EAAO7H,MAAQm7C,EAAA9gD,YAAY0W,UAA/B,CACA,IAAI0tD,GAAc,EACd13B,EAAiBl/B,EACjB62D,EAAY33B,EAAI23B,UACpB33B,EAAIrrC,IAAI3E,EAAAnL,YAAYiwE,UACpB,IAAIyB,EAAe/zE,KAAK0wE,YACpB93D,EAAQyC,aAAau2C,EAAA7gD,eAAeuR,QACtCtiB,KAAK0wE,YAAc93D,EAAQvC,KAAK8P,cAAciE,MAEhD,IAAI+pD,OAAQ,EACRgB,GACFhB,EAAWn0E,KAAKs0E,kBAAkBa,EAAWznE,EAAAkH,KAAKxR,IAAG,GAGjDyuD,EAAA9a,gBAAgBo9B,IAAatiB,EAAApiC,aAAaolB,QAC5Cs/B,EAAWx0E,EAAO6yC,qBAAqB2hC,GACnCtiB,EAAA9a,gBAAgBo9B,IAAatiB,EAAApiC,aAAaolB,QACxCj8B,EAAQ0G,GAAG9R,EAAAnL,YAAYod,QACzBzf,KAAKqN,MACHI,EAAAhD,eAAe2qE,0EACfD,EAAUpqE,OAGdmqE,GAAc,KAGQ,MAAjBH,EACTZ,EAAWx0E,EAAOyD,IAAI,IAElB4xE,GACFh1E,KAAKqN,MACHI,EAAAhD,eAAe4qE,kCACH/2D,EAAQ9C,eAAezQ,MAAM87D,OAG7CsN,EAAWx0E,EAAOmnC,OAAO+qB,EAAAz5B,SAASk9C,OAChC31E,EAAO+nC,WAAWqtC,EAAc3iE,aAAcy/C,EAAAriC,WAAWppB,KACzDzG,EAAOyD,IAAI,IAEb+wE,EAAWx0E,EAAO6yC,qBAAqB2hC,GACnCtiB,EAAA9a,gBAAgBo9B,IAAatiB,EAAApiC,aAAaolB,QACxCj8B,EAAQ0G,GAAG9R,EAAAnL,YAAYod,QACzBzf,KAAKqN,MACHI,EAAAhD,eAAe2qE,0EACf92D,EAAO/J,YAAYxJ,OAGvBmqE,GAAc,IAGlBl1E,KAAK0wE,YAAcqD,EACfmB,GACFv1E,EAAOstC,UAAUuQ,EAAIprC,aAAcy/C,EAAAriC,WAAWppB,KAAK,EAAMzG,EAAOyD,IAAI,IACpEpD,KAAK2wE,YAAYjkE,KACf1M,KAAKu1E,qBAAqB/3B,EAAK22B,GAAU,IAE3Ca,GAAqB,IAEjBC,GACFz3B,EAAI99B,wBAAwBnK,QAAQs8C,EAAA5a,iBAAiBk9B,IAAYzmE,EAAAkH,KAAKxR,KAClEo6C,EAAIl+B,GAAG9R,EAAAnL,YAAY6b,gBACrBve,EAAOstC,UAAUuQ,EAAIprC,aAAcy/C,EAAAriC,WAAWppB,KAAK,EAAO+tE,IAG5Dx0E,EAAOstC,UAAUuQ,EAAIprC,aAAcy/C,EAAAriC,WAAWppB,KAAK,EAAO+tE,GAE5D32B,EAAI/1B,aAAc,EAClButD,GAAqB,GAEvBD,EAA2Bv3B,qGAI/B,OADAx9C,KAAKqvE,YAAc,MACZ,GAMTF,EAAAltE,UAAAqxE,kCAAA,SACErxE,EACAgqB,EACAxD,EACA25C,GAEA,QAHA,IAAA35C,MAA4C5e,EAAA23D,gBAC5C,IAAAY,MAAA,MAEIngE,EAAUoZ,aAAau2C,EAAA7gD,eAAeqE,SAAU,OAAO,KAC3D,IAAImT,EAAWvoB,KAAKqS,SAAS4yD,iCAC3BhjE,EACAgqB,EACAhqB,EAAUiS,OACVuU,EACA25C,GAAyBngE,EAAUsS,aAErC,OAAKgU,GACAvoB,KAAKw1E,gBAAgBjtD,GACnBA,EAFe,MAMxB4mD,EAAAltE,UAAAovE,mBAAA,SACErnD,EACAohB,EACArhB,QAAA,IAAAA,MAAA,MAEA,IACIub,EADAqvB,EAAgB3qC,EAAiBA,EAAe7d,OAAS,EAEzDyb,EAAQ,EAQZ,GAPImC,IACFub,EAAa,IAAIr+B,MAAM,EAAI0tD,IAChB,GAAK5qC,EAAS0pC,eACzB7rC,EAAQ,GAER0d,EAAa,IAAIr+B,MAAM0tD,GAErB3qC,EACF,IAAK,IAAI3pB,EAAI,EAAGA,EAAIs0D,IAAiBt0D,IAAKunB,EACxC0d,EAAW1d,GAASoC,EAAe3pB,GAAGozD,eAG1C,IAAIgiB,EAAarqC,EAAWqoB,eACxB9zD,EAASK,KAAKL,OACdkuC,EAAUluC,EAAOgmC,2BAA2B8vC,EAAYnwC,GAC5D,IAAKuI,EAAS,CACZ,IAAIjtC,EAAO8M,EAAA0Y,UAAU4uC,oBAAoBhrC,EAAgBohB,EAAYrhB,GACrE8jB,EAAUluC,EAAOylC,gBAAgBxkC,EAAM60E,EAAYnwC,GAErD,OAAOuI,GAITshC,EAAAltE,UAAAyzE,oBAAA,SAEEntD,EAEAotD,QAAA,IAAAA,MAAA,MAEA,IAAIh2E,EAASK,KAAKL,OACdi2E,EAAWxrE,OAAOme,EAAStmB,UAAU2zE,UACrCxqC,EAAa7iB,EAAStU,UAAUm3B,WAChChhB,EAAOpqB,KAAK0wE,YAGhB,GAAIkF,EAASn/D,MAAQ9I,EAAA+I,SAAS25C,MAC5BslB,EAAQ31E,KAAK61E,kBAAmCD,EAAUt/D,YAAY,EAAMq/D,OACvE,CAELvrE,OAAOwrE,EAASn/D,MAAQ9I,EAAA+I,SAASk6C,YAGjCxmD,OAAOme,EAAStmB,UAAUgmB,WAG1B7d,QAAQme,EAAS3G,MAAMpU,EAAAnL,YAAYugB,YAAcpV,EAAAnL,YAAYwf,IAAMrU,EAAAnL,YAAYyf,IAAMtU,EAAAnL,YAAYyzE,OAEjG,IAAIlvC,EAAO5mC,KAAKs0E,kBAAwCsB,EAAU5rC,WAAYoB,EAAU,GAKxF,GAFKuqC,EACAA,EAAMjpE,KAAKk6B,GADJ+uC,EAAQ,CAAE/uC,IAEjBxc,EAAK9K,GAAE,KAAwB,CAClC,IAAIy2D,EAAcJ,EAAMxpE,OACxBnM,KAAKg2E,oBAAoB5rD,EAAMurD,GAC/B31E,KAAKi0E,mBAAmB7pD,EAAMurD,GAC9B,IAAItK,EAAcjhD,EAAKihD,YAAYzkC,EAAMwE,GACrC6qC,EAAU7rD,EAAKwgD,UAAUhkC,EAAMwE,GACnC,GAAIuqC,EAAMxpE,OAAS4pE,EAAa,CAC9B,IAAIG,EAAO9rD,EAAK2+C,oBAAoB39B,GAC/BigC,GAAajhD,EAAKw+C,aAAasN,EAAKtuD,MAAO/Z,EAAAw5D,WAAWiE,SACvD2K,GAAS7rD,EAAKw+C,aAAasN,EAAKtuD,MAAO/Z,EAAAw5D,WAAW9C,SACtDoR,EAAMI,EAAc,GAAKp2E,EAAOypC,UAAU8sC,EAAKtuD,MAAOgf,GACtD+uC,EAAMjpE,KAAK/M,EAAO2nC,UAAU4uC,EAAKtuD,MAAOwjB,EAAWqoB,iBAEhD4X,GAAajhD,EAAKjY,IAAG,GACtB8jE,GAAS7rD,EAAKjY,IAAG,GACrBiY,EAAKjY,IAAI,MAKb,GAAIoW,EAASjJ,GAAG9R,EAAAnL,YAAYugB,aAAc,CACxC,IAAImwD,EAAiB/yE,KAAK0U,QAAQq+D,eAClC3oE,OAAOme,EAASjJ,GAAG9R,EAAAnL,YAAY4iB,WAC/B,IAAItS,EAAgBvI,OAAOme,EAASrU,QAEpC,GAF6C9J,OAAOuI,EAAc8D,MAAQm7C,EAAA9gD,YAAY+N,QAEjFuL,EAAK9K,GAAE,KAAwB,CAClC,IAAIolD,EAAYt6D,OAAOggB,EAAKu6C,YAAYn3D,EAAAxK,cAAcoC,QAGjDglB,EAAK9K,GAAE,MAMVq2D,EAAMjpE,KACJ/M,EAAOyqC,GACLzqC,EAAO+mC,MAAMqsC,GAAkBlhB,EAAAriC,WAAWnpB,IAAMwrD,EAAA/+B,QAAQi4C,OAASlZ,EAAA/+B,QAAQg4C,OACvEnrE,EAAO2nC,UAAUo9B,EAAU98C,MAAOmrD,IAEpCpzE,EAAOypC,UAAUs7B,EAAU98C,MACzB5nB,KAAK6yE,WACH7yE,KAAKm2E,eAAsBxjE,OAKnC3S,KAAKo2E,wBAA+BzjE,EAAegjE,IAErD31E,KAAKg2E,oBAAoB5rD,EAAMurD,GAC/B31E,KAAKi0E,mBAAmB7pD,EAAMurD,GAC9BA,EAAMjpE,KAAK/M,EAAO2nC,UAAUo9B,EAAU98C,MAAO5nB,KAAK0U,QAAQq+D,iBAC1D3oD,EAAKjY,IAAI,KAICQ,EAAeuZ,OAAS9B,EAAK9K,GAAE,MACzCtf,KAAKqN,MACHI,EAAAhD,eAAe4rE,2DACf9tD,EAAStmB,UAAUsS,YAAYxJ,YAK1BqgC,GAAc19B,EAAAkH,KAAKG,MAASqV,EAAK9K,GAAE,MAC5Ctf,KAAKqN,MACHI,EAAAhD,eAAe6rE,+DACf/tD,EAAStmB,UAAU0jE,iBAAiBv6B,WAAWrgC,OAInD,OAAO4qE,GAITxG,EAAAltE,UAAAuzE,gBAAA,SAAgBjtD,GACd,GAAIA,EAASjJ,GAAG9R,EAAAnL,YAAYiwE,UAAW,OAAO,EAC9CloE,SAASme,EAASjJ,GAAG9R,EAAAnL,YAAY0iB,UAAYwD,EAASlN,aAAau2C,EAAA7gD,eAAeqE,WAElF,IAAImhE,EAAev2E,KAAKsvE,YACxB/mD,EAASpW,IAAI3E,EAAAnL,YAAYiwE,UAEzB,IAKIlB,EALAzxE,EAASK,KAAKL,OACdsU,EAAYsU,EAAStU,UACrB2hE,EAAWrtD,EAAStmB,UAAU2zE,SAE9B/nC,EAAU7tC,KAAKqxE,mBAAmBp9D,EAAU+V,eAAgB/V,EAAUm3B,WAAYn3B,EAAU8V,UAIhG,GAAI6rD,EAAU,CAWZ,GARIrtD,EAASjJ,GAAG9R,EAAAnL,YAAY0iB,UAC1B/kB,KAAKqN,MACHI,EAAAhD,eAAe+rE,yDACfjuD,EAAS/M,eAAezQ,OAKxBwd,EAASlN,aAAau2C,EAAA7gD,eAAeiU,UAAW,CAClD,IAAI8vD,EAAiBvsD,EAASusD,eAC1Br0D,EAAYrW,OAAOuD,EAAA+jD,cAAc/jD,EAAAe,cAAcsW,SAAU8vD,IAC7D90E,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACfZ,EAAU1V,OAKd,IAAIgpE,EAAe/zE,KAAK0wE,YACpBtmD,EAAO7B,EAAS6B,KACpBpqB,KAAK0wE,YAActmD,EACnB,IAAIurD,EAAQ,IAAI1uE,MAGZ2gB,EAAQ,EACG3T,EAAU8V,YAGrBnC,EAGJ,IADA,IAAIoC,EAAiB/V,EAAU+V,eACtB3pB,EAAI,EAAG+V,EAAI4T,EAAe7d,OAAQ9L,EAAI+V,IAAK/V,IAAKunB,EAAO,CAC9D,IAAI3I,EAAO+K,EAAe3pB,GACtB4e,EAAK2zD,YACP+C,EAAMjpE,KACJ/M,EAAOoqC,KACL/pC,KAAK6yE,WACHlzE,EAAO2nC,UAAU1f,EAAO3I,EAAKw0C,mBAInCrpC,EAAKw+C,aAAahhD,EAAO/Z,EAAAw5D,WAAWwB,WAIxC7oE,KAAK01E,oBAAoBntD,EAAUotD,GAC9BvrD,EAAK9K,GAAE,OACVtf,KAAKg2E,oBAAoB5rD,EAAMurD,GAC/B31E,KAAKi0E,mBAAmB7pD,EAAMurD,IAEhC31E,KAAK0wE,YAAcqD,EAGnB3C,EAAUzxE,EAAO2tC,YACf/kB,EAASnW,aACTy7B,EACAngC,EAAAmmD,mBAAmBtrC,EAASK,kBAC5B6tD,EAAQ92E,EAAQg2E,EAAOptD,EAAStU,UAAUm3B,WAAWqoB,sBAKlDlrC,EAASjJ,GAAG9R,EAAAnL,YAAY0iB,UAC3B/kB,KAAKqN,MACHI,EAAAhD,eAAeisE,gFACfnuD,EAAS/M,eAAezQ,OAI5Bwd,EAASpW,IAAI3E,EAAAnL,YAAYqyE,eACzBC,EAAiBpsD,EAAUA,EAAShU,aAGpC68D,EAAUzxE,EAAOivC,kBACfrmB,EAASnW,aACT68D,EACAC,EACArhC,GAMJ,OAFAtlB,EAASkC,SAAS9qB,EAAQyxE,GAC1BpxE,KAAKsvE,YAAciH,GACZ,GAKTpH,EAAAltE,UAAAsxE,+BAAA,SACEtxE,EACAgqB,EACAxD,EACA25C,QADA,IAAA35C,MAA4C5e,EAAA23D,gBAC5C,IAAAY,MAAA,MAEA,IAAI75C,EAAWvoB,KAAKqS,SAASkvD,8BAC3Bt/D,EACAgqB,EACAhqB,EAAUiS,OACVuU,EACA25C,GAAyBngE,EAAUsS,aAEhCgU,GACLvoB,KAAK22E,aAAapuD,IAGpB4mD,EAAAltE,UAAA00E,aAAA,SAAapuD,eACX,GAAIA,EAASjJ,GAAG9R,EAAAnL,YAAYiwE,UAAW,OAAO,EAC9C/pD,EAASpW,IAAI3E,EAAAnL,YAAYiwE,UACzB,IACIsE,EADYruD,EAAStmB,UACuB6c,QAChD,GAAI83D,MACF,IAAoB,IAAAx4D,EAAArG,EAAA6+D,EAAcr5D,UAAQc,EAAAD,EAAAnG,QAAAoG,EAAAnG,KAAAmG,EAAAD,EAAAnG,OAAE,CAC1C,QADOW,EAAOyF,EAAA/c,OACEmV,MACd,KAAKm7C,EAAA9gD,YAAYmQ,OACfjhB,KAAKozE,cAAsBx6D,GAC3B,MAEF,KAAKg5C,EAAA9gD,YAAYkN,mBAEQpF,EAAS0G,GAAG9R,EAAAnL,YAAY8S,UAE7CnV,KAAKszE,kCACgB16D,EACnB,GACA/O,EAAA23D,UACoB5oD,EAAS4C,gBAGjC,MAEF,KAAKo2C,EAAA9gD,YAAYyN,oBACX1d,EAA6B+X,EAAS4F,kBAExCxe,KAAKszE,kCACHzyE,EACA,GACAgJ,EAAA23D,UACA3gE,EAAO2a,iBAGP02D,EAA6Bt5D,EAAS6F,kBAExCze,KAAKszE,kCACHpB,EACA,GACAroE,EAAA23D,UACA0Q,EAAO12D,gBAGX,MAEF,KAAKo2C,EAAA9gD,YAAY4N,6GAKvB,IAAIwoD,EAAe3+C,EAAS8D,oBACxB66C,GAAclnE,KAAKw1E,gBAAgBtO,GACvC,IAAI/oD,EAAkBoK,EAASzJ,QAC/B,GAAIX,MACF,IAAoB,IAAAY,EAAAhH,EAAAoG,EAAgBZ,UAAQyB,EAAAD,EAAA9G,QAAA+G,EAAA9G,KAAA8G,EAAAD,EAAA9G,OAAE,CAAzC,IAAIW,EACP,QADOA,EAAOoG,EAAA1d,OACEmV,MACd,KAAKm7C,EAAA9gD,YAAYkN,mBAEQpF,EAAS0G,GAAG9R,EAAAnL,YAAY8S,UAE7CnV,KAAKszE,kCACgB16D,EACnB,GACA/O,EAAA23D,QAAqBj5C,EAASE,yBACV7P,EAASrE,YAAY3T,MAG7C,MAEF,KAAKgxD,EAAA9gD,YAAYqa,gBACfvS,EAAQzG,IAAI3E,EAAAnL,YAAYiwE,UACxB,MAEF,KAAK1gB,EAAA9gD,YAAY4N,SACf,IAAI7d,EAEAqxE,GAFArxE,EAAoB+X,EAAS6S,iBACrBzrB,KAAKw1E,gBAAgB30E,IAC7BqxE,EAAoBt5D,EAAS8S,iBACrB1rB,KAAKw1E,gBAAgBtD,sGAMzC,OAAO,GAGT/C,EAAAltE,UAAA40E,4BAAA,SACEtiE,EACA0X,EACAxD,EACA25C,QADA,IAAA35C,MAAA,WACA,IAAA25C,MAAA,MAGApiE,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf9M,EAAYxJ,QAOhBokE,EAAAltE,UAAA60E,iBAAA,SAAiBrkE,EAAoBskE,QAAA,IAAAA,MAAA,GACnC,IAAIzrD,EAAemmD,UAAUzxE,KAAKsrB,aAAcyrD,GAC5C1yC,EAAUwtB,EAAAztB,cAAcziC,OAAO8Q,EAAQ6Y,GAG3C,OAFAtrB,KAAKuvE,eAAe7iE,KAAK23B,GACzBrkC,KAAKsrB,aAAeqzC,QAAQrzC,EAAc/V,QAAQ9C,EAAOtG,OAAQ,IAC1Dk4B,GAIT8qC,EAAAltE,UAAA+0E,mBAAA,SAAmBC,GACjB,IAGIC,EAHA1xD,EAAUxlB,KAAKwlB,QACf2xD,EAAe3xD,EAAQ4xD,kBACvBn9D,EAAiB7P,OAAOob,EAAQvL,gBAEhC41B,EAAW7vC,KAAKwvE,eACpB,GAAI3/B,EAASr7B,IAAIyiE,GACfC,EAAgBrnC,EAAS3uC,IAAI+1E,OACxB,CACL,IAAI9qE,EAAS8qE,EAAY9qE,OACrBsG,EAAS,IAAI5K,WAAWsvE,GAAgBhrE,GAAU,IACtDqZ,EAAQhT,mBAAmBC,EAAQ,EAAGwH,EAAgB9N,GAAU,GAChE,IAAK,IAAI9L,EAAI,EAAGA,EAAI8L,IAAU9L,EAC5BwJ,EAAAkkB,SAASkpD,EAAY1qE,WAAWlM,GAAIoS,EAAQ0kE,GAAgB92E,GAAK,IAEnE62E,EAAgBl3E,KAAK82E,iBAAiBrkE,GACtCo9B,EAAS19B,IAAI8kE,EAAaC,GAE5B,IAAIpuD,EAAM61C,QAAQuY,EAAcxkE,OAAQ6C,QAAQ4hE,IAEhD,OADAn3E,KAAKsvE,YAAcr1D,EAAegF,KAC9Bjf,KAAK0U,QAAQc,SACRxV,KAAKL,OAAO0D,IAAI6sC,QAAQpnB,GAAMqnB,SAASrnB,KAE9C1e,OAAOw5D,WAAW96C,IACX9oB,KAAKL,OAAOyD,IAAI8sC,QAAQpnB,MAInCqmD,EAAAltE,UAAAo1E,wBAAA,SAAwBC,EAAmB/5D,GACzC,IAAIiI,EAAUxlB,KAAKwlB,QACfrZ,EAASoR,EAAOpR,OAChB+lD,EAAWolB,EAAYplB,SACvBqlB,EAAaprE,EAAS+lD,EACtBslB,EAAiBptE,OAAOob,EAAQzL,qBAChCq9D,EAAoB5xD,EAAQ4xD,kBAE5BK,EAAM,IAAI5vE,WAAWuvE,EAAoBG,GAC7C/xD,EAAQhT,mBAAmBilE,EAAK,EAAGD,EAAgBD,GACnD,IAAIxnB,EAAMqnB,EACNtE,EAAawE,EAAY7jB,eAC7B,OAAQqf,GACN,KAAKjhB,EAAAriC,WAAWppB,IACd,OAAQ8rD,GACN,KAAK,EACH,IAAK,IAAI7xD,EAAI,EAAGA,EAAI8L,IAAU9L,EAAG,CAC/B,IAAIiB,EAAQic,EAAOld,GACnB+J,OAAOynD,EAAA7a,kBAAkB11C,IAAUwxE,GACnC1oE,OAAOynD,EAAA9a,gBAAgBz1C,IAAUuwD,EAAApiC,aAAaolB,OAC9ChrC,EAAAikB,QAAQ+jC,EAAA5a,iBAAiB31C,GAAQm2E,EAAK1nB,GACtCA,GAAO,EAET,MAEF,KAAK,EACH,IAAS1vD,EAAI,EAAGA,EAAI8L,IAAU9L,EAAG,CAC3BiB,EAAQic,EAAOld,GACnB+J,OAAOynD,EAAA7a,kBAAkB11C,IAAUwxE,GACnC1oE,OAAOynD,EAAA9a,gBAAgBz1C,IAAUuwD,EAAApiC,aAAaolB,OAC9ChrC,EAAAkkB,SAAS8jC,EAAA5a,iBAAiB31C,GAAQm2E,EAAK1nB,GACvCA,GAAO,EAET,MAEF,KAAK,EACH,IAAS1vD,EAAI,EAAGA,EAAI8L,IAAU9L,EAAG,CAC3BiB,EAAQic,EAAOld,GACnB+J,OAAOynD,EAAA7a,kBAAkB11C,IAAUwxE,GACnC1oE,OAAOynD,EAAA9a,gBAAgBz1C,IAAUuwD,EAAApiC,aAAaolB,OAC9ChrC,EAAAgJ,SAASg/C,EAAA5a,iBAAiB31C,GAAQm2E,EAAK1nB,GACvCA,GAAO,EAET,MAEF,QAAS3lD,QAAO,GAElB,MAEF,KAAKynD,EAAAriC,WAAWnpB,IACd,IAAShG,EAAI,EAAGA,EAAI8L,IAAU9L,EAAG,CAC3BiB,EAAQic,EAAOld,GACnB+J,OAAOynD,EAAA7a,kBAAkB11C,IAAUwxE,GACnC1oE,OAAOynD,EAAA9a,gBAAgBz1C,IAAUuwD,EAAApiC,aAAaolB,OAC9ChrC,EAAA6tE,SAASniE,QAAQs8C,EAAA3a,oBAAoB51C,GAAQuwD,EAAA1a,qBAAqB71C,IAASm2E,EAAK1nB,GAChFA,GAAO,EAET,MAEF,KAAK8B,EAAAriC,WAAW3oB,IACd,IAASxG,EAAI,EAAGA,EAAI8L,IAAU9L,EAAG,CAC3BiB,EAAQic,EAAOld,GACnB+J,OAAOynD,EAAA7a,kBAAkB11C,IAAUwxE,GACnC1oE,OAAOynD,EAAA9a,gBAAgBz1C,IAAUuwD,EAAApiC,aAAaolB,OAC9ChrC,EAAAmkB,SAAS6jC,EAAAza,iBAAiB91C,GAAQm2E,EAAK1nB,GACvCA,GAAO,EAET,MAEF,KAAK8B,EAAAriC,WAAW1oB,IACd,IAASzG,EAAI,EAAGA,EAAI8L,IAAU9L,EAAG,CAC3BiB,EAAQic,EAAOld,GACnB+J,OAAOynD,EAAA7a,kBAAkB11C,IAAUwxE,GACnC1oE,OAAOynD,EAAA9a,gBAAgBz1C,IAAUuwD,EAAApiC,aAAaolB,OAC9ChrC,EAAAokB,SAAS4jC,EAAAxa,iBAAiB/1C,GAAQm2E,EAAK1nB,GACvCA,GAAO,EAET,MAEF,QAAS3lD,QAAO,GAIlB,OAFAA,OAAO2lD,GAAO0nB,EAAItrE,QAEXnM,KAAK82E,iBAAiBW,IAG/BtI,EAAAltE,UAAA01E,wBAAA,SAAwBL,EAAmBM,GACzC,IAAIpyD,EAAUxlB,KAAKwlB,QACf4xD,EAAoB5xD,EAAQ4xD,kBAC5B/6D,EAAiBjS,OAAOob,EAAQnJ,gBAChCw7D,EAAgBztE,OAAOpK,KAAKqS,SAAS0L,aAAa1B,EAAgB,CAAEi7D,KACpEQ,EAAoBD,EAAczrD,oBAClC2rD,EAAeH,EAAcnlE,OAAOtG,OAASirE,EAC7CY,EAAc50E,IAAI20E,EAAeT,EAAYplB,UAE7CulB,EAAM,IAAI5vE,WAAWuvE,EAAoBU,GAC7CtyD,EAAQhT,mBAAmBilE,EAAK,EAAGI,EAAeC,GAElD,IAAIG,EAAkB/nC,QAAQ0nC,EAAcllE,QAAU0kE,EAOtD,OANAhtE,QAAQob,EAAQ9Q,QAAQc,UACxBpL,OAAOytE,EAAcjqD,WAAW,OAAQqqD,EAAiBR,EAAKL,IAC9DhtE,OAAOytE,EAAcjqD,WAAW,YAAaqqD,EAAiBR,EAAKL,IACnEhtE,OAAOytE,EAAcjqD,WAAW,aAAcmqD,EAAcN,EAAKL,IACjEhtE,OAAOytE,EAAcjqD,WAAW,UAAWoqD,EAAaP,EAAKL,IAEtDp3E,KAAK82E,iBAAiBW,IAM/BtI,EAAAltE,UAAAi2E,yBAAA,SAAyBrnC,GAEvB,GADAzmC,OAAOymC,EAAKvxB,GAAG9R,EAAAnL,YAAYiwE,WACvBzhC,EAAK9nB,oBAAsB,EAC7B,OAAO8nB,EAAK9nB,mBAEd,IAAI0mD,EAAgBzvE,KAAKyvE,cACrB7nD,EAAQ6nD,EAActjE,OAO1B,OANK0kC,EAAKvxB,GAAG9R,EAAAnL,YAAY81E,aAAetnC,EAAK58B,UAAUkgD,mBAAqBtjB,EAAK58B,UAAU+V,eAAe7d,SAExG0kC,EAAO7wC,KAAKoyE,iBAAiBvhC,IAE/B4+B,EAAc/iE,KAAKmkC,EAAKz+B,cACxBy+B,EAAK9nB,mBAAqBnB,EACnBA,GAKTunD,EAAAltE,UAAA+xE,yBAAA,SAAyBx9D,EAAsBwR,GAI7C,OAHIxR,EAAUC,MAAQ9I,EAAA+I,SAASE,gBAC7BJ,EAAqCA,EAAWjC,aAE1CiC,EAAUC,MAChB,KAAK9I,EAAA+I,SAASQ,iBAEZ,IADA,IACS7W,EAAI,EAAG+V,GADZgiE,EAAsC5hE,EAAWsI,SAChB3S,OAAQ9L,EAAI+V,IAAK/V,EACpDL,KAAKg0E,yBAAyBoE,EAAiB/3E,GAAI2nB,GAErD,MAEF,KAAKra,EAAA+I,SAASU,gBACZ,IAAIwB,EAAU5Y,KAAKwlB,QAAQlR,wBAAyCkC,GACpEpM,OAAOwO,EAAQnC,MAAQm7C,EAAA9gD,YAAYkW,MAC9BpO,EAAQyC,aAAau2C,EAAA7gD,eAAeuR,OAAOtiB,KAAKqzE,YAAkBz6D,GACvE,MAEF,KAAKjL,EAAA+I,SAASgB,qBACZ,IAAI0gE,EACJ,IAAS/3E,EAAI,EAAG+V,GADZgiE,EAA0C5hE,EAAWsI,SACpB3S,OAAQ9L,EAAI+V,IAAK/V,EACpDL,KAAKg0E,yBAAyBoE,EAAiB/3E,GAAI2nB,GAErD,MAEF,KAAKra,EAAA+I,SAASM,SACZ,IAAI2N,EAAmCnO,EAAWmO,aAClD,IAAStkB,EAAI,EAAG+V,EAAIuO,EAAaxY,OAAQ9L,EAAI+V,IAAK/V,EAAG,CAC/CuY,EAAU5Y,KAAKwlB,QAAQlR,wBAAwBqQ,EAAatkB,IAChE+J,OAAOwO,EAAQnC,MAAQm7C,EAAA9gD,YAAYmQ,QAEhCrI,EAAQ0G,GAAG9R,EAAAnL,YAAY0iB,UACvBnM,EAAQyC,aAAau2C,EAAA7gD,eAAeuR,OACrCtiB,KAAKozE,cAAsBx6D,GAE/B,MAEF,KAAKjL,EAAA+I,SAAS+K,kBACR7I,EAAU5Y,KAAKwlB,QAAQlR,wBAA0CkC,IACzDC,MAAQm7C,EAAA9gD,YAAYmQ,SACzBrI,EAAQyC,aAAau2C,EAAA7gD,eAAeuR,OAAOtiB,KAAKozE,cAAsBx6D,IAE7E,MAEF,KAAKjL,EAAA+I,SAASxB,OACuC,MAA7BsB,EAAW5K,gBAC/B5L,KAAK2zE,kBACuBn9D,EAAW5K,eACM4K,EAAWgO,MAG1D,MAEF,KAAK7W,EAAA+I,SAASI,OACZ9W,KAAK2zE,kBACen9D,EAAW5K,eACX4K,EAAWgO,MAE/B,MAEF,KAAK7W,EAAA+I,SAASY,oBACd,KAAK3J,EAAA+I,SAASiL,kBACd,KAAKhU,EAAA+I,SAASc,qBACd,KAAK7J,EAAA+I,SAASuL,0BACd,KAAKtU,EAAA+I,SAASkB,gBAAiB,MAC/B,QACE,IAAIusC,EAAOnkD,KAAKq4E,iBAAiB7hE,GAC7Bq7C,EAAA9a,gBAAgBoN,IAAS0N,EAAApiC,aAAa0yB,KAAKn6B,EAAKtb,KAAKy3C,KAM/DgrB,EAAAltE,UAAAo2E,iBAAA,SACE7hE,EACA8hE,QAAA,IAAAA,OAAA,GAEA,IACIn0B,EADAxkD,EAASK,KAAKL,OAElB,OAAQ6W,EAAUC,MAChB,KAAK9I,EAAA+I,SAAS25C,MACZlM,EAAOnkD,KAAKu4E,sBAAsC/hE,GAClD,MAEF,KAAK7I,EAAA+I,SAAS45C,MACZnM,EAAOnkD,KAAKw4E,sBAAsChiE,GAClD,MAEF,KAAK7I,EAAA+I,SAAS65C,SACZpM,EAAOnkD,KAAKy4E,yBAA4CjiE,GACxD,MAEF,KAAK7I,EAAA+I,SAAS85C,GACZrM,EAAOnkD,KAAK04E,mBAAgCliE,GAC5C,MAEF,KAAK7I,EAAA+I,SAASzT,MACZkhD,EAAOnkD,KAAK24E,sBAAsCniE,GAClD,MAEF,KAAK7I,EAAA+I,SAASk6C,WACZzM,EAAOnkD,KAAK44E,2BAAgDpiE,GAC5D,MAEF,KAAK7I,EAAA+I,SAASm6C,IACZ1M,EAAOnkD,KAAK64E,oBAAkCriE,GAC9C,MAEF,KAAK7I,EAAA+I,SAASs6C,GACZ7M,EAAOnkD,KAAK84E,mBAAgCtiE,GAC5C,MAEF,KAAK7I,EAAA+I,SAASw6C,OACZ/M,EAAOnkD,KAAK+4E,uBAAwCviE,EAAW8hE,GAC/D,MAEF,KAAK3qE,EAAA+I,SAAS06C,OACZjN,EAAOnkD,KAAKg5E,uBAAwCxiE,GACpD,MAEF,KAAK7I,EAAA+I,SAAS26C,MACZlN,EAAOnkD,KAAKi5E,sBAAsCziE,GAClD,MAEF,KAAK7I,EAAA+I,SAAS46C,IACZnN,EAAOnkD,KAAKk5E,oBAAkC1iE,GAC9C,MAEF,KAAK7I,EAAA+I,SAASM,UACZmtC,EAAOnkD,KAAKm5E,yBAA4C3iE,MAC7C2tC,EAAOxkD,EAAO6qC,OACzB,MAEF,KAAK78B,EAAA+I,SAAS86C,KACZrN,EAAOnkD,KAAKo5E,qBAAoC5iE,GAChD,MAEF,KAAK7I,EAAA+I,SAAS+6C,MACZtN,EAAOnkD,KAAKq5E,sBAAsC7iE,GAClD,MAEF,KAAK7I,EAAA+I,SAASkB,gBAEZ5X,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf7K,EAAUzL,OAEZo5C,EAAOxkD,EAAO8rC,cACd,MAEF,QACErhC,QAAO,GACP+5C,EAAOxkD,EAAO8rC,cAIlB,OADIzrC,KAAK0U,QAAQgW,WAAW1qB,KAAKs5E,iBAAiBn1B,EAAM3tC,EAAUzL,OAC3Do5C,GAGTgrB,EAAAltE,UAAA4zE,kBAAA,SACEv/D,EACAijE,EACA5D,QADA,IAAA4D,OAAA,QACA,IAAA5D,MAAA,MAEA,IAAI6D,EAAgBljE,EAAWnK,OAC1BwpE,KACHA,EAAQ,IAAI1uE,MAAqBuyE,IAC3BrtE,OAAS,GAIjB,IAFA,IAAIxM,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YACPrwE,EAAI,EAAGA,EAAIm5E,IAAiBn5E,EAAG,CACtC,IAAI8jD,EAAOnkD,KAAKq4E,iBAAiB/hE,EAAWjW,GAAIk5E,GAAUl5E,GAAKm5E,EAAgB,GAC/E,OAAQ3nB,EAAA9a,gBAAgBoN,IACtB,KAAK0N,EAAApiC,aAAa8uB,MAChB,IAAKsT,EAAA9Y,aAAaoL,GAAO,CACvB,IAAK,IAAI5tC,EAAI,EAAGH,EAAIy7C,EAAA5Y,mBAAmBkL,GAAO5tC,EAAIH,IAAKG,EAAGo/D,EAAMjpE,KAAKmlD,EAAA1Y,cAAcgL,EAAM5tC,IACzF,MAIJ,QAASo/D,EAAMjpE,KAAKy3C,GACpB,KAAK0N,EAAApiC,aAAa0yB,KAEpB,GAAI/3B,EAAKxI,MAAM,KAA0C,CACnDiwC,EAAA1T,yBAAyBgG,IAAOwxB,EAAMjpE,KAAK/M,EAAO8rC,eACtD,OAGJ,OAAOkqC,GAGTxG,EAAAltE,UAAAs2E,sBAAA,SACE/hE,GAEA,IAAIF,EAAaE,EAAUF,WACvBmjE,EAAYz5E,KAAK0wE,YACjBgJ,EAAYD,EAAUvR,OAC1BloE,KAAK0wE,YAAcgJ,EAEnB,IAAI/D,EAAQ31E,KAAK61E,kBAAkBv/D,GAKnC,OAJKojE,EAAU93D,MAAM,MAA0C5hB,KAAKg2E,oBAAoB0D,EAAW/D,GACnG+D,EAAUpQ,mBACVmQ,EAAU3P,QAAQ4P,GAClB15E,KAAK0wE,YAAc+I,EACZhD,EAAQz2E,KAAKL,OAAQg2E,EAAO9jB,EAAAriC,WAAWyY,OAGhDknC,EAAAltE,UAAAu2E,sBAAA,SACEhiE,GAEA,IAAI7W,EAASK,KAAKL,OAClB,GAAI6W,EAAUizB,MAKZ,OAJAzpC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf7K,EAAUizB,MAAM1+B,OAEXpL,EAAO8rC,cAEhB,IAAIrhB,EAAOpqB,KAAK0wE,YACZ/mD,EAAaS,EAAKT,WACtB,GAAkB,MAAdA,EAKF,OAJA3pB,KAAKqN,MACHI,EAAAhD,eAAekvE,qFACfnjE,EAAUzL,OAELpL,EAAO8rC,cAEhB,IAAIkqC,EAAQ,IAAI1uE,MAChBjH,KAAKg2E,oBAAoB5rD,EAAMurD,GAE/B,IADA,IAAIzhE,EAASkW,EAAKlW,OACA,OAAXA,GAAmBA,EAAOyV,YAAcA,GAC7C3pB,KAAKg2E,oBAAoB9hE,EAAQyhE,GAAwB,GACzDzhE,EAASA,EAAOA,OAKlB,OAHAkW,EAAKk/C,mBACLqM,EAAMjpE,KAAK/M,EAAOiqC,GAAGjgB,IACrBS,EAAKjY,IAAG,IACDskE,EAAQ92E,EAAQg2E,EAAO9jB,EAAAriC,WAAWyY,OAG3CknC,EAAAltE,UAAAw2E,yBAAA,SACEjiE,GAEA,IAAI7W,EAASK,KAAKL,OACd8pC,EAAQjzB,EAAUizB,MACtB,GAAIA,EAKF,OAJAzpC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACfooB,EAAM1+B,OAEDpL,EAAO8rC,cAGhB,IAAIrhB,EAAOpqB,KAAK0wE,YACZ7I,EAAgBz9C,EAAKy9C,cACzB,GAAqB,MAAjBA,EAKF,OAJA7nE,KAAKqN,MACHI,EAAAhD,eAAemvE,8EACfpjE,EAAUzL,OAELpL,EAAO8rC,cAEhBrhB,EAAKjY,IAAI,KACT,IAAIwjE,EAAQ,IAAI1uE,MAChBjH,KAAKg2E,oBAAoB5rD,EAAMurD,GAE/B,IADA,IAAIhwD,EAAuByE,EAAKlW,OACzByR,GAAWA,EAAQkiD,gBAAkBA,GAC1C7nE,KAAKg2E,oBAAoBrwD,EAASgwD,GAAwB,GAC1DhwD,EAAUA,EAAQzR,OAIpB,OAFAkW,EAAKk/C,mBACLqM,EAAMjpE,KAAK/M,EAAOiqC,GAAGi+B,IACd4O,EAAQ92E,EAAQg2E,EAAO9jB,EAAAriC,WAAWyY,OAG3CknC,EAAAltE,UAAAy2E,mBAAA,SACEliE,GAEA,IAAI7W,EAASK,KAAKL,OAEd85E,EAAYz5E,KAAK0wE,YACjBjnC,EAAQgwC,EAAU9P,iBAClB+P,EAAYD,EAAUvR,OAC1BloE,KAAK0wE,YAAcgJ,EACnB,IAAI/vD,EAAa,SAAW8f,EAC5BiwC,EAAU/vD,WAAaA,EACvB,IAAIk+C,EAAgB,YAAcp+B,EAClCiwC,EAAU7R,cAAgBA,EAE1B,IAAI8N,EAAQ,IAAI1uE,MACZuP,EAAUA,UAAUC,MAAQ9I,EAAA+I,SAAS25C,MACvCrwD,KAAK61E,kBAAmCr/D,EAAUA,UAAWF,YAAY,EAAOq/D,GAEhFA,EAAMjpE,KACJ1M,KAAKq4E,iBAAiB7hE,EAAUA,YAGpC,IAAIqjE,EAAWl6E,EAAO6yC,qBACpBxyC,KAAK85E,cACH95E,KAAKs0E,kBAAkB99D,EAAUqzB,UAAWn8B,EAAAkH,KAAKxR,KACjDpD,KAAKsvE,cAGLyK,GAAc,EACdloB,EAAA9a,gBAAgB8iC,IAAahoB,EAAApiC,aAAaolB,QAC5CzqC,OAAOynD,EAAA7a,kBAAkB6iC,IAAahoB,EAAAriC,WAAWppB,KAC5CyrD,EAAA5a,iBAAiB4iC,KAAWE,GAAc,IAEjD,IAAIC,EAAaN,EAAUp6D,GAAE,KACzB26D,EAAYP,EAAU93D,MAAM,MAC5Bs4D,EAASR,EAAU93D,MAAM,MAQzBu4D,GAAgBH,IAAeN,EAAUp6D,GAAE,IAE3C66D,IAAiBJ,GACnBpE,EAAMjpE,KAAK/M,EAAOiqC,GAAGi+B,EAAegS,IAEtC,IAAIjzC,EAAO6vC,EAAQ92E,EAAQg2E,EAAO9jB,EAAAriC,WAAWyY,MAoB7C,OAnBIkyC,IAAiBJ,GAAeE,KAClCrzC,EAAOjnC,EAAOuqC,KAAK29B,EAAejhC,IAEhCszC,IACFtzC,EAAOjnC,EAAO6pC,MAAM7f,EAAY,CAAEid,KAI/BozC,GAAYh6E,KAAKg2E,oBAAoB0D,EAAW/D,GACrD+D,EAAUpQ,mBACVmQ,EAAU5P,gBACV6P,EAAU9zD,MACR,OAKF6zD,EAAU3P,QAAQ4P,GAClB15E,KAAK0wE,YAAc+I,EACZ7yC,GAGTuoC,EAAAltE,UAAA02E,sBAAA,SACEniE,GAEA,OAAOxW,KAAKL,OAAO6qC,OAGrB2kC,EAAAltE,UAAA22E,2BAAA,SACEpiE,GAEA,OAAOxW,KAAKs0E,kBAAkB99D,EAAUwzB,WAAYt8B,EAAAkH,KAAKG,KAAI,IAG/Do6D,EAAAltE,UAAA42E,oBAAA,SACEriE,GAEA,IAAI7W,EAASK,KAAKL,OAGd85E,EAAYz5E,KAAK0wE,YACjBjnC,EAAQgwC,EAAU9P,iBAClB+P,EAAYD,EAAUvR,OAC1BloE,KAAK0wE,YAAcgJ,EAGnB,IAAItyD,EAAc5Q,EAAU4Q,YACxB+sD,EAA0B,EAC1B/sD,IAAa+sD,EAAWn0E,KAAKq4E,iBAAiBjxD,IAGlD,IAAIyyD,EAA0B,EAC1BO,GAAa,EACjB,GAAI5jE,EAAUqzB,WAQZ,GAPAgwC,EAAWl6E,EAAO6yC,qBAChBxyC,KAAK85E,cACH95E,KAAKs0E,kBAA8B99D,EAAUqzB,UAAWn8B,EAAAkH,KAAKhR,MAC7D5D,KAAKsvE,cAILzd,EAAA9a,gBAAgB8iC,IAAahoB,EAAApiC,aAAaolB,MAAO,CAEnD,GADAzqC,OAAOynD,EAAA7a,kBAAkB6iC,IAAahoB,EAAAriC,WAAWppB,KACH,GAA1CyrD,EAAA5a,iBAAiB4iC,GAA4B,CAC/C,IAAIQ,EAAQ,IAAIpzE,MAMhB,OALIktE,GAAUkG,EAAM3tE,KAAKynE,GACzBn0E,KAAKg2E,oBAAoB0D,EAAWW,GACpCX,EAAUpQ,mBACVmQ,EAAU5P,gBACV7pE,KAAK0wE,YAAc+I,EACZhD,EAAQ92E,EAAQ06E,EAAOxoB,EAAAriC,WAAWyY,MAE3CmyC,GAAa,QAGfP,EAAWl6E,EAAOyD,IAAI,GACtBg3E,GAAa,EAEfV,EAAU7O,qBAAqBgP,GAG/B,IAAInuB,EAAcl1C,EAAUk1C,YACxB4uB,EAA0B,EAC1B5uB,IAAa4uB,EAAWt6E,KAAKs0E,kBAAkB5oB,EAAah+C,EAAAkH,KAAKG,KAAM,IAG3E,IAAI4U,EAAa+vD,EAAU/vD,WAAa,SAAW8f,EAAOiwC,EAAU/vD,WAAaA,EACjF+vD,EAAU/vD,WAAaA,EACvB,IAAIk+C,EAAgB,YAAcp+B,EAClCiwC,EAAU7R,cAAgBA,EAC1B,IAAI0S,EAAY,QAAU9wC,EACtB+wC,EAAgBhkE,EAAUA,UAC1Bm/D,EAAQ,IAAI1uE,MACZuzE,EAAc/jE,MAAQ9I,EAAA+I,SAAS25C,MACjCrwD,KAAK61E,kBAAmC2E,EAAelkE,YAAY,EAAOq/D,GAE1EA,EAAMjpE,KAAK1M,KAAKq4E,iBAAiBmC,IAEnC,IA6BI5zC,EA7BAozC,EAAaN,EAAUp6D,GAAE,KACzB26D,EAAYP,EAAU93D,MAAM,MAC5Bs4D,EAASR,EAAU93D,MAAM,MAazBu4D,GAAgBH,IAAeN,EAAUp6D,GAAE,IAC3Cm7D,GAAcL,GAAcF,EAE5BhwC,EAAO,IAAIjjC,MAIf,GAHKmzE,GACHlwC,EAAKx9B,KAAK/M,EAAOiqC,GAAGjgB,EAAYhqB,EAAO+mC,MAAMmrB,EAAA/+B,QAAQg4C,OAAQ+O,KAE3DI,GACEtE,EAAMxpE,OAAS,GAAK0lD,EAAA9a,gBAAgB4+B,EAAM,KAAO9jB,EAAApiC,aAAa6uB,QAChEpU,EAAKx9B,KAAK/M,EAAO6pC,MAAMq+B,EAAe8N,SAGxC,IAAK,IAAIt1E,EAAI,EAAG+V,EAAIu/D,EAAMxpE,OAAQ9L,EAAI+V,IAAK/V,EAAG6pC,EAAKx9B,KAAKipE,EAAMt1E,IAmChE,OAhCI85E,GAAgBF,GACdK,GAAUpwC,EAAKx9B,KAAK4tE,GACxBt6E,KAAKg2E,oBAAoB0D,EAAWxvC,GACpCA,EAAKx9B,KAAK/M,EAAOiqC,GAAG2wC,IAElB3zC,EADEutC,EACKx0E,EAAO6pC,MAAMixC,EAAa9wD,EAAa,KAAM,CAClDwqD,EACAx0E,EAAOuqC,KAAKqwC,EAAW56E,EAAO6pC,MAAM,KAAMU,MAGrCvqC,EAAO6pC,MAAMixC,EAAa9wD,EAAa,KAAM,CAClDhqB,EAAOuqC,KAAKqwC,EAAW9D,EAAQ92E,EAAQuqC,EAAM2nB,EAAAriC,WAAWyY,WAIxDksC,GAAUjqC,EAAKinC,QAAQgD,GAC3Bn0E,KAAKg2E,oBAAoB0D,EAAWxvC,GACpCtD,EAAOjnC,EAAO6pC,MAAMixC,EAAa9wD,EAAa,KAAMugB,IAItDwvC,EAAUpQ,mBACVmQ,EAAU5P,gBACV6P,EAAU9zD,MACR,OAKEw0D,EAAYX,EAAU3P,QAAQ4P,GAC7BD,EAAU1P,mBAAmB2P,GAClC15E,KAAK0wE,YAAc+I,EACZ7yC,GAGTuoC,EAAAltE,UAAA62E,mBAAA,SACEtiE,GAEA,IAAI7W,EAASK,KAAKL,OACd0qC,EAAS7zB,EAAU6zB,OACnBC,EAAU9zB,EAAU8zB,QACpBmvC,EAAYz5E,KAAK0wE,YAGjBmJ,EAAWl6E,EAAO6yC,qBACpBxyC,KAAK85E,cACH95E,KAAKs0E,kBAAkB99D,EAAUqzB,UAAWn8B,EAAAkH,KAAKhR,MACjD5D,KAAKsvE,cAKT,GACEzd,EAAA9a,gBAAgB8iC,IAAahoB,EAAApiC,aAAaolB,OAC1Cgd,EAAA7a,kBAAkB6iC,IAAahoB,EAAAriC,WAAWppB,IAE1C,OAAOyrD,EAAA5a,iBAAiB4iC,GACpB75E,KAAKq4E,iBAAiBhuC,GACtBC,EACEtqC,KAAKq4E,iBAAiB/tC,GACtB3qC,EAAO6qC,MAIf,IAAIkwC,EAAc,IAAIzzE,MAClB0zE,EAAalB,EAAUvR,OAY3B,GAXAloE,KAAK0wE,YAAciK,EACnBA,EAAW9P,qBAAqBgP,GAC5BxvC,EAAO5zB,MAAQ9I,EAAA+I,SAAS25C,MAC1BrwD,KAAK61E,kBAAmCxrC,EAAQ/zB,YAAY,EAAOokE,GAEnEA,EAAYhuE,KAAK1M,KAAKq4E,iBAAiBhuC,IAEpCswC,EAAW/4D,MAAM,MAA0C5hB,KAAKg2E,oBAAoB2E,EAAYD,GACrGC,EAAWrR,mBACXtpE,KAAK0wE,YAAc+I,EAEfnvC,EAAS,CACX,IAAIswC,EAAcnB,EAAUvR,OAC5BloE,KAAK0wE,YAAckK,EACnBA,EAAY5P,sBAAsB6O,GAClC,IAAIgB,EAAe,IAAI5zE,MAUvB,OATIqjC,EAAQ7zB,MAAQ9I,EAAA+I,SAAS25C,MAC3BrwD,KAAK61E,kBAAmCvrC,EAASh0B,YAAY,EAAOukE,GAEpEA,EAAanuE,KAAK1M,KAAKq4E,iBAAiB/tC,IAErCswC,EAAYh5D,MAAM,MAA0C5hB,KAAKg2E,oBAAoB4E,EAAaC,GACvGD,EAAYtR,mBACZtpE,KAAK0wE,YAAc+I,EACnBA,EAAUpP,cAAcsQ,EAAYC,GAC7Bj7E,EAAOyqC,GAAGyvC,EACfpD,EAAQ92E,EAAQ+6E,EAAa7oB,EAAAriC,WAAWyY,MACxCwuC,EAAQ92E,EAAQk7E,EAAchpB,EAAAriC,WAAWyY,OAK3C,OAFAwxC,EAAU1P,mBAAmB4Q,GACzBA,EAAWr7D,GAAE,MAAwBm6D,EAAUzO,sBAAsB6O,GAClEl6E,EAAOyqC,GAAGyvC,EACfpD,EAAQ92E,EAAQ+6E,EAAa7oB,EAAAriC,WAAWyY,QAU9CknC,EAAAltE,UAAA82E,uBAAA,SACEviE,EACA8hE,GAEA,IAAI34E,EAASK,KAAKL,OACdinC,EAAsB,EACtBxc,EAAOpqB,KAAK0wE,YACZtlC,EAAahhB,EAAKghB,WAGtBhhB,EAAKjY,IAAI,KAET,IAAI2oE,EAAkBtkE,EAAUlV,MAChC,GAAIw5E,EAAiB,CACnB,GAAI1vC,GAAc19B,EAAAkH,KAAKG,KAMrB,OALA/U,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACfuG,EAAgB/vE,MAAO/K,KAAKsvE,YAAY5jE,WAAY0/B,EAAW1/B,YAEjE1L,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAO8rC,cAEhB,IAAIsvC,EAAW,EACX3wD,EAAKg6C,eAAe9kD,GAAG9R,EAAAnL,YAAY6b,iBAAgB68D,GAAW,GAClEn0C,EAAO5mC,KAAKs0E,kBAAkBwG,EAAiB1vC,EAAuB,GAAX2vC,GAItD/6E,KAAK6vE,oBAAoBr7D,IAAIoyB,IAC5BwE,EAAWwnC,WACT/gB,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAa0lB,UACpC/qB,EAAKs/C,eAAe7X,EAAAva,iBAAiB1Q,GAAO/4B,EAAAw5D,WAAW2T,gBACzD5wD,EAAKo+C,eAAe3W,EAAAva,iBAAiB1Q,GAAO/4B,EAAAw5D,WAAW2T,cACvDh7E,KAAK6vE,oBAAoB76D,IAAI4xB,IAOhCxc,EAAKihD,YAAYzkC,EAAMwE,IAAahhB,EAAKjY,IAAG,GAC7CiY,EAAKwgD,UAAUhkC,EAAMwE,IAAahhB,EAAKjY,IAAG,QAErCi5B,GAAc19B,EAAAkH,KAAKG,OAC5B/U,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACf/9D,EAAUzL,MAAO,OAAQqgC,EAAW1/B,YAEtCk7B,EAAOjnC,EAAO8rC,eAGhB,IAAIkqC,EAAQ,IAAI1uE,MAOhB,GANAjH,KAAKg2E,oBAAoB5rD,EAAMurD,GAC/B31E,KAAKi0E,mBAAmB7pD,EAAMurD,GAG1BvqC,EAAWwnC,YAAc5yE,KAAK6vE,oBAAoBr7D,IAAIoyB,KAAOA,EAAO5mC,KAAK6yE,WAAWjsC,IAEpFwE,GAAc19B,EAAAkH,KAAKG,MAAQ4gE,EAAMxpE,OAAQ,CAC3C,IAAI+pE,EAAO9rD,EAAK2+C,oBAAoB39B,GAChChhB,EAAKwgD,UAAUhkC,EAAMwE,IAAahhB,EAAKw+C,aAAasN,EAAKtuD,MAAO/Z,EAAAw5D,WAAW9C,SAC/EoR,EAAMxE,QACJxxE,EAAOypC,UAAU8sC,EAAKtuD,MAAOgf,IAE/BA,EAAOjnC,EAAO2nC,UAAU4uC,EAAKtuD,MAAOwjB,EAAWqoB,gBAKjD,OAHArpC,EAAKk/C,mBAGDgP,GAAgB1xC,GAAQwE,GAAc19B,EAAAkH,KAAKG,KACxC4gE,EAAMxpE,QACXwpE,EAAMjpE,KAAKk6B,GACJjnC,EAAO6pC,MAAM,KAAMmsC,EAAOvqC,EAAWqoB,iBAFlB7sB,EAMxBxc,EAAK9K,GAAE,OACJq2D,EAAMxpE,QACXwpE,EAAMjpE,KAAK/M,EAAOiqC,GAAGx/B,OAAOggB,EAAK49C,mBAAoB,EAAGphC,IAEjDjnC,EAAO6pC,MAAM,KAAMmsC,IAHAh2E,EAAOiqC,GAAGx/B,OAAOggB,EAAK49C,mBAAoB,EAAGphC,GAOpE+uC,EAAMxpE,QACXwpE,EAAMjpE,KAAK/M,EAAO+qC,OAAO9D,IAClBjnC,EAAO6pC,MAAM,KAAMmsC,IAFAh2E,EAAO+qC,OAAO9D,IAK1CuoC,EAAAltE,UAAA+2E,uBAAA,SACExiE,GAEA,IAAI7W,EAASK,KAAKL,OAEd4sD,EAAQ/1C,EAAU+1C,MAClB0uB,EAAW1uB,EAAMpgD,OACrB,IAAK8uE,EACH,OAAOj7E,KAAKs0E,kBAAkB99D,EAAUqzB,UAAWn8B,EAAAkH,KAAKG,KAAI,GAM9D,IAAI0kE,EAAYz5E,KAAK0wE,YACjBjQ,EAAUgZ,EAAU9P,iBAGpBuR,EAAYzB,EAAUpR,aAAa36D,EAAAkH,KAAKnR,KACxC03E,EAAiBD,EAAUtzD,MAG3BsyD,EAAS,IAAIjzE,MAAqB,EAAIg0E,GAC1Cf,EAAO,GAAKv6E,EAAOypC,UACjB+xC,EACAn7E,KAAKs0E,kBAAkB99D,EAAUqzB,UAAWn8B,EAAAkH,KAAKnR,IAAG,IAQtD,IAFA,IAAI23E,EAAa,EACbC,GAAgB,EACXh7E,EAAI,EAAGA,EAAI46E,IAAY56E,EAAG,CACjC,IACIopC,EADQ8iB,EAAMlsD,GACAopC,MACdA,EACFywC,EAAOkB,KAAgBz7E,EAAOiqC,GAAG,OAASvpC,EAAEqL,SAAS,IAAM,IAAM+0D,EAC/D9gE,EAAOmnC,OAAO+qB,EAAAz5B,SAAS6yC,MACrBtrE,EAAO2nC,UAAU6zC,EAAgBtpB,EAAAriC,WAAWppB,KAC5CpG,KAAKs0E,kBAAkB7qC,EAAO/7B,EAAAkH,KAAKnR,IAAG,KAM1C43E,EAAeh7E,EAInBo5E,EAAU3Q,cAAcoS,GAGxBhB,EAAOkB,GAAcz7E,EAAOiqC,IAAIyxC,GAAgB,EAC1C,OAASA,EAAa3vE,SAAS,IAC/B,SACA,IAAM+0D,GAGZ,IAAI6a,EAAe37E,EAAO6pC,MAAM,SAAWi3B,EAASyZ,EAAQroB,EAAAriC,WAAWyY,MACnEszC,EAAiB,IACjBC,EAAoB,EACxB,IAASn7E,EAAI,EAAGA,EAAI46E,IAAY56E,EAAG,CACjC,IACIiW,EADQi2C,EAAMlsD,GACKiW,WACnBkjE,EAAgBljE,EAAWnK,OAG3ButE,EAAYD,EAAUvR,OAC1BloE,KAAK0wE,YAAcgJ,EACnB,IAAI/vD,EAAa,SAAW82C,EAC5BiZ,EAAU/vD,WAAaA,EAEvB,IAAI8xD,EAASp7E,GAAK46E,EAAW,EACzBS,EAAYD,EAAS9xD,EAAa,QAAUtpB,EAAI,GAAGqL,SAAS,IAAM,IAAM+0D,EACxEkV,EAAQ,IAAI1uE,MAAqB,EAAIuyE,GACzC7D,EAAM,GAAK2F,EAGX,IAFA,IAAIK,EAAQ,EACR3B,GAAa,EACRzjE,EAAI,EAAGA,EAAIijE,IAAiBjjE,EAAG,CACtC,IAAI4tC,EAAOnkD,KAAKq4E,iBAAiB/hE,EAAWC,IAI5C,GAHIs7C,EAAA9a,gBAAgBoN,IAAS0N,EAAApiC,aAAa0yB,MACxCwzB,EAAMgG,KAAWx3B,GAEfu1B,EAAU93D,MAAM,KAA0C,CACxD83D,EAAUp6D,GAAE,OAAwB06D,GAAa,GACrD,OAGJrE,EAAMxpE,OAASwvE,GACX3B,GAAcyB,GAAU/B,EAAU93D,MAAM,SAC1C25D,GAAqB7B,EAAU1mE,OAEjCwoE,GAAoC,MAAf9B,EAAU1mE,MAG1BgnE,GAAYh6E,KAAKg2E,oBAAoB0D,EAAW/D,GACrD+D,EAAU9zD,MACR,MAGF8zD,EAAUpQ,mBACVtpE,KAAK0wE,YAAc+I,EACnB6B,EAAe37E,EAAO6pC,MAAMkyC,EAAW/F,EAAO9jB,EAAAriC,WAAWyY,MAQ3D,OANAwxC,EAAU5P,gBAGNwR,GAAgB,IAAG5B,EAAUzmE,QAA6B,GAApBuoE,GAC1C9B,EAAUzmE,QAA6B,KAApBwoE,EAEZF,GAGTnM,EAAAltE,UAAAg3E,sBAAA,SACEziE,GAEA,IAAI4T,EAAOpqB,KAAK0wE,YAGhBtmD,EAAKjY,IAAI,KAET,IAAIwjE,EAAQ,IAAI1uE,MAChBjH,KAAKi0E,mBAAmB7pD,EAAMurD,GAG9B,IAAIr0E,EAAQkV,EAAUlV,MAClBwJ,EAA6B,KACjC,GAAIxJ,EAAMmV,MAAQ9I,EAAA+I,SAASw4C,IAAK,CAC9B,IAAI0sB,EAA0Bt6E,EAAO0hB,UACjC44D,EAAQzvE,SAAQrB,EAAU8wE,EAAQ,IAIxC,OAFAjG,EAAMjpE,KAAK2zD,EAAAwb,aAAa77E,KAAM8K,EAAS0L,IAEhCigE,EAAQz2E,KAAKL,OAAQg2E,EAAO9jB,EAAAriC,WAAWyY,OAGhDknC,EAAAltE,UAAAi3E,oBAAA,SACE1iE,GAQA,OAJAxW,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf7K,EAAUzL,OAEL/K,KAAKL,OAAO8rC,eAIrB0jC,EAAAltE,UAAAk3E,yBAAA,SACE3iE,GASA,IAPA,IAAI7W,EAASK,KAAKL,OACdglB,EAAenO,EAAUmO,aACzBm3D,EAAkBn3D,EAAaxY,OAC/Bie,EAAOpqB,KAAK0wE,YACZqL,EAAe,IAAI90E,MACnBoL,EAAWrS,KAAKqS,SAEXhS,EAAI,EAAGA,EAAIy7E,IAAmBz7E,EAAG,CACxC,IAAIkU,EAAcoQ,EAAatkB,GAC3BO,EAAO2T,EAAY3T,KAAKqL,KACxBgT,EAAoB,KACpBk1D,EAA0B,EAC1BC,GAAyB,EAG7B,GAAI7/D,EAAY0K,KAAM,CAMpB,KALAA,EAAO5M,EAASmuD,YACdjsD,EAAY0K,KACZmL,EAAKg6C,eACLh6C,EAAK3B,0BAEI,SACPlU,EAAY6S,cACd+sD,EAAWn0E,KAAKs0E,kBAAkB//D,EAAY6S,YAAanI,EACzD,IAEFm1D,EAAyBp0E,KAAK6vE,oBAAoBr7D,IAAI2/D,QAInD,KAAI5/D,EAAY6S,YAehB,CACLpnB,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACfzsD,EAAY3T,KAAKmK,MAAM87D,OAEzB,SAfA,GAJAsN,EAAWn0E,KAAKs0E,kBAAkB//D,EAAY6S,YAAa1Z,EAAAkH,KAAK89C,KAAI,IAGpE0hB,EAAyBp0E,KAAK6vE,oBAAoBr7D,IAAI2/D,GAClDn0E,KAAKsvE,aAAe5hE,EAAAkH,KAAKG,KAAM,CACjC/U,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACfhgE,EAAYxJ,MAAO/K,KAAKsvE,YAAY5jE,WAAY,UAElD,SAEFuT,EAAOjf,KAAKsvE,YAYd,IAAI0M,EAAUznE,EAAY+K,GAAG9R,EAAAnL,YAAYod,OACrCkD,GAAW,EACf,GAAIq5D,EACF,GAAI7H,GAEF,GADAA,EAAWx0E,EAAO6yC,qBAAqB2hC,GACnCtiB,EAAA9a,gBAAgBo9B,IAAatiB,EAAApiC,aAAaolB,MAAO,CACnD,IAAI/qB,EAAQ,IAAI8nC,EAAAjqC,MAAM/mB,GAAO,EAAGqe,EAAMmL,EAAKw9C,gBAC3C,OAAQ/V,EAAA7a,kBAAkBm9B,IACxB,KAAKtiB,EAAAriC,WAAWppB,IACd0jB,EAAMpK,wBACJnK,QACEs8C,EAAA5a,iBAAiBk9B,GACjB,GAEFl1D,GAEF,MAEF,KAAK4yC,EAAAriC,WAAWnpB,IACdyjB,EAAMpK,wBACJnK,QACEs8C,EAAA3a,oBAAoBi9B,GACpBtiB,EAAA1a,qBAAqBg9B,IAEvBl1D,GAEF,MAEF,KAAK4yC,EAAAriC,WAAW3oB,IACdijB,EAAMlK,sBAA2BiyC,EAAAza,iBAAiB+8B,GAAWl1D,GAC7D,MAEF,KAAK4yC,EAAAriC,WAAW1oB,IACdgjB,EAAMlK,sBAAsBiyC,EAAAxa,iBAAiB88B,GAAWl1D,GACxD,MAEF,QAEE,OADA7U,QAAO,GACAzK,EAAO8rC,cAIlB,IAAIi8B,EAAet9C,EAAKs9C,aACxB,GAAKA,GACA,GAAIA,EAAalzD,IAAI5T,GAKxB,OAJAZ,KAAKqN,MACHI,EAAAhD,eAAeuV,uBACfzL,EAAY3T,KAAKmK,MAAOnK,GAEnBZ,KAAKL,OAAO8rC,mBANFrhB,EAAKs9C,aAAeA,EAAe,IAAItgE,IAQ1DsgE,EAAav1D,IAAIvR,EAAMkpB,GACvBnH,GAAW,QAGb3iB,KAAKqN,MACHI,EAAAhD,eAAewxE,wCACf1nE,EAAYxJ,OAMlB,IAAK4X,EAAU,CACTmH,OAAK,EACT,GACEvV,EAAYqN,MAAMpU,EAAAnL,YAAYi0D,IAAM9oD,EAAAnL,YAAYod,QAChD2K,EAAK9K,GAAE,OACP,CACA,IAAI8pD,EAAgBh/C,EAAK4+C,eAAepoE,GACpCwoE,GACFppE,KAAKqN,MACHI,EAAAhD,eAAeuV,uBACfzL,EAAY3T,KAAKmK,MAAOwJ,EAAY3T,KAAKqL,MAE3C6d,EAAQs/C,GAERt/C,EAAQM,EAAK6+C,eAAeroE,EAAMqe,GAEhC+8D,GAAS5xD,EAAKw+C,aAAa9+C,EAAMlC,MAAO/Z,EAAAw5D,WAAW6U,cAClD,CACL,GAAI9xD,EAAKu6C,YAAY/jE,GAAO,CAC1BZ,KAAKqN,MACHI,EAAAhD,eAAeuV,uBACfzL,EAAY3T,KAAKmK,MAAOnK,GAE1B,SAEFkpB,EAAQM,EAAKw9C,eAAer9C,SAAStL,EAAMre,EAAM2T,GAC7CynE,GAAS5xD,EAAKw+C,aAAa9+C,EAAMlC,MAAO/Z,EAAAw5D,WAAW6U,UAEzD,IAAItJ,EAAY3zD,EAAK2zD,UACjBuB,GACE/pD,EAAKwgD,UAAUuJ,EAAUl1D,IAAOmL,EAAKw+C,aAAa9+C,EAAMlC,MAAO/Z,EAAAw5D,WAAW9C,SAC1EqO,GACFxoD,EAAKw+C,aAAa9+C,EAAMlC,MAAO/Z,EAAAw5D,WAAWwB,UAC1CkT,EAAarvE,KACX/M,EAAOypC,UAAUtf,EAAMlC,MACrBwsD,EACID,EACAn0E,KAAK6yE,WAAWsB,OAIxB4H,EAAarvE,KACX/M,EAAOypC,UAAUtf,EAAMlC,MAAOusD,IAE5BrqD,EAAM7K,KAAKK,GAAG,MACX8K,EAAKihD,YAAY8I,EAAUl1D,GAC3BmL,EAAKo+C,eAAe1+C,EAAMlC,MAAO/Z,EAAAw5D,WAAWiE,SADVlhD,EAAKw+C,aAAa9+C,EAAMlC,MAAO/Z,EAAAw5D,WAAWiE,YAKjFsH,GAMFmJ,EAAarvE,KACX/M,EAAOypC,UAAUtf,EAAMlC,MACrB3I,EAAKy0C,aAAa/zD,KAGtByqB,EAAKw+C,aAAa9+C,EAAMlC,MAAO/Z,EAAAw5D,WAAW2C,yBACjClgD,EAAM7K,KAAKK,GAAG,KACvB8K,EAAKw+C,aAAa9+C,EAAMlC,MAAO/Z,EAAAw5D,WAAWiE,UAKlD,OAA8B,GAAvByQ,EAAa5vE,OAChB,EACAsqE,EAAQ92E,EAAQo8E,EAAclqB,EAAAriC,WAAWyY,OAG/CknC,EAAAltE,UAAAm3E,qBAAA,SACE5iE,GAEA,OAAOxW,KAAKs0E,kBAAkB99D,EAAUwzB,WAAYt8B,EAAAkH,KAAKG,KACvD,KAIJo6D,EAAAltE,UAAAo3E,sBAAA,SACE7iE,GAEA,IAAI7W,EAASK,KAAKL,OACd85E,EAAYz5E,KAAK0wE,YAGjBmJ,EAAWl6E,EAAO6yC,qBACpBxyC,KAAK85E,cACH95E,KAAKs0E,kBAAkB99D,EAAUqzB,UAAWn8B,EAAAkH,KAAKhR,MACjD5D,KAAKsvE,cAKL8K,GAAa,EACjB,GAAIvoB,EAAA9a,gBAAgB8iC,IAAahoB,EAAApiC,aAAaolB,MAAO,CAEnD,GADAzqC,OAAOynD,EAAA7a,kBAAkB6iC,IAAahoB,EAAAriC,WAAWppB,MAC5CyrD,EAAA5a,iBAAiB4iC,GAAW,OAAOl6E,EAAO6qC,MAC/C4vC,GAAa,EAIf,IAAI3wC,EAAQgwC,EAAU9P,iBAClB+P,EAAYD,EAAUvR,OAC1BloE,KAAK0wE,YAAcgJ,EACnB,IAAI/vD,EAAa,SAAW8f,EAC5BiwC,EAAU/vD,WAAaA,EACvB,IAAIk+C,EAAgB,YAAcp+B,EAClCiwC,EAAU7R,cAAgBA,EAC1B6R,EAAU7O,qBAAqBgP,GAC/B,IAAIlE,EAAQ,IAAI1uE,MACZuP,EAAUA,UAAUC,MAAQ9I,EAAA+I,SAAS25C,MACvCrwD,KAAK61E,kBAAmCr/D,EAAUA,UAAWF,YAAY,EAAOq/D,GAEhFA,EAAMjpE,KAAK1M,KAAKq4E,iBAAiB7hE,EAAUA,YAE7C,IASI2jE,GATaT,EAAUp6D,GAAE,OASMo6D,EAAUp6D,GAAE,IAE3C66D,IACFn6E,KAAKg2E,oBAAoB0D,EAAW/D,GACpCA,EAAMjpE,KAAK/M,EAAOiqC,GAAGi+B,KAElBuS,GACHzE,EAAMxE,QAAQxxE,EAAOiqC,GAAGjgB,EAAYhqB,EAAO+mC,MAAMmrB,EAAA/+B,QAAQg4C,OAAQ+O,KAEnE,IAAIjzC,EAAO6vC,EAAQ92E,EAAQg2E,EAAO9jB,EAAAriC,WAAWyY,MAoB7C,OAnBIkyC,GAAgBT,EAAU93D,MAAM,SAClCglB,EAAOjnC,EAAOuqC,KAAK29B,EAAejhC,IAE/BwzC,IAAcV,EAAU93D,MAAM,QACjCglB,EAAOjnC,EAAO6pC,MAAM7f,EAAY,CAAEid,KAIpC8yC,EAAUpQ,mBACVmQ,EAAU5P,gBACV6P,EAAU9zD,MACR,OAKEw0D,EAAYX,EAAU3P,QAAQ4P,GAC7BD,EAAU1P,mBAAmB2P,GAClC15E,KAAK0wE,YAAc+I,EACZ7yC,GAMTuoC,EAAAltE,UAAAk6E,sBAAA,SACEvjE,EACAgqD,EACAmY,GAEA3wE,OAAOwO,EAAQ0G,GAAG9R,EAAAnL,YAAYilB,UAC9B,IAAIrI,EAAOrG,EAAQqG,KACnB,SACkB,EAAd87D,IACF97D,EAAKK,GAAE,IACPsjD,EAAetjD,GAAE,IACjBL,EAAK2sB,KAAOg3B,EAAeh3B,MACtB5rC,KAAKsvE,YAAc1M,GAAgBnsD,MACnCzW,KAAKsvE,YAAcrwD,GAAMxI,MAE9B,OACA,OACE,IAAIs2B,EAAQ9tB,EAAK2zC,yBAAyBllD,EAAAkH,KAAKxR,KAC/C,OAAOpD,KAAKL,OAAOyD,IACQ,GAAzBwV,EAAQuO,kBACJ+oB,QAAQt3B,EAAQyO,uBAAyB0lB,GAASA,EAClD,GAGR,OACA,OACA,QACE,IAAIN,EAAO7zB,EAAQqG,KAAK6zC,wBAAwBplD,EAAAkH,KAAKxR,KACrD,OAAOpD,KAAKL,OAAOyD,IACQ,GAAzBwV,EAAQuO,kBACJ+oB,QAAQt3B,EAAQyO,sBAAwBolB,EACxC,GAGR,OACA,OACE,OAAOzsC,KAAKL,OAAOyD,IACQ,GAAzBwV,EAAQuO,kBACJ+oB,QAAQt3B,EAAQyO,sBAChB,GAGR,OACA,OACE,IAAKzO,EAAQ4M,QAAQ9Q,QAAQc,SAC3B,OAAOxV,KAAKL,OAAOyD,IACQ,GAAzBwV,EAAQuO,kBACJ+oB,QAAQt3B,EAAQyO,sBAChB,GAKV,OACA,OACE,OAAgC,GAAzBzO,EAAQuO,kBACXnnB,KAAKL,OAAO0D,IACV6sC,QAAQt3B,EAAQyO,sBAChB8oB,SAASv3B,EAAQyO,uBAEnBrnB,KAAKL,OAAO0D,IAAI,GAEtB,QAEE,IAAMuV,EAAQyC,aAAau2C,EAAA7gD,eAAeqE,UAAYwtD,GAAkBl1D,EAAAkH,KAAK/Q,IAC3E,OAAO7D,KAAKL,OAAOmE,IAA0B8U,EAAS2O,oBAGxDvnB,KAAKsvE,YAAc5hE,EAAAkH,KAAK/Q,IAE1B,QACE,OAAO7D,KAAKL,OAAOkE,IAA0B+U,EAAS2O,oBAExD,QAEE,OADAnd,QAAO,GACApK,KAAKL,OAAO8rC,gBAKzB0jC,EAAAltE,UAAAqyE,kBAAA,SACEtqC,EACA44B,EACAmY,GAGA,IAAIn0C,EAEJ,YALA,IAAAm0C,MAAA,GAEA/6E,KAAKsvE,YAAc1M,EAEfA,GAAkBl1D,EAAAkH,KAAKG,OAAMgmE,GAAW,GACpC/wC,EAAWvzB,MACjB,KAAK9I,EAAA+I,SAASksC,UACZhc,EAAO5mC,KAAKo8E,2BAAgDpyC,EAAY44B,EAAgBmY,GACxF,MAEF,KAAKptE,EAAA+I,SAASk4C,OACZhoB,EAAO5mC,KAAKq8E,wBAA0CryC,EAAY44B,EAAgBmY,GAClF,MAEF,KAAKptE,EAAA+I,SAASmsC,KACZjc,EAAO5mC,KAAKs8E,sBAAsCtyC,EAAY44B,EAAgBmY,GAC9E,MAEF,KAAKptE,EAAA+I,SAASo4C,MACZloB,EAAO5mC,KAAKu8E,uBAAwCvyC,EAAY44B,EAAgBmY,GAChF,MAEF,KAAKptE,EAAA+I,SAASosC,cACZlc,EAAO5mC,KAAKw8E,+BAAwDxyC,EAAY44B,EAAgBmY,GAChG,MAEF,KAAKptE,EAAA+I,SAASiI,SACZioB,EAAO5mC,KAAKy8E,0BAA8CzyC,EAAY44B,EAAexQ,mBAAoB2oB,GACzG,MAEF,KAAKptE,EAAA+I,SAASisC,WACd,KAAKh1C,EAAA+I,SAAS+rC,MACd,KAAK90C,EAAA+I,SAAS6rC,KACd,KAAK50C,EAAA+I,SAAS44C,KACd,KAAK3hD,EAAA+I,SAASusC,MACd,KAAKt1C,EAAA+I,SAAS8rC,KACZ5b,EAAO5mC,KAAK08E,4BAAkD1yC,EAAY44B,EAAgBmY,GAC1F,MAEF,KAAKptE,EAAA+I,SAASs4C,WACZpoB,EAAO5mC,KAAK28E,4BAAkD3yC,EAAY44B,EAAgBmY,GAC1F,MAEF,KAAKptE,EAAA+I,SAASwM,QACZ0jB,EAAO5mC,KAAK48E,yBAA4C5yC,EAAY44B,EAAgBmY,GACpF,MAEF,KAAKptE,EAAA+I,SAASw4C,IACZtoB,EAAO5mC,KAAK68E,qBAAoC7yC,EAAY44B,EAAgBmY,GAC5E,MAEF,KAAKptE,EAAA+I,SAASqsC,cACZnc,EAAO5mC,KAAKs0E,kBAA4CtqC,EAAYA,WAAY44B,EAAgBmY,GAChG,MAEF,KAAKptE,EAAA+I,SAASssC,eACZpc,EAAO5mC,KAAK88E,gCAA0D9yC,EAAY44B,EAAgBmY,GAClG,MAEF,KAAKptE,EAAA+I,SAAS24C,QACZzoB,EAAO5mC,KAAK+8E,yBAA4C/yC,EAAY44B,EAAgBmY,GACpF,MAEF,KAAKptE,EAAA+I,SAAS84C,aACZ5oB,EAAO5mC,KAAKg9E,8BAAsDhzC,EAAY44B,EAAgBmY,GAC9F,MAEF,KAAKptE,EAAA+I,SAAS+4C,YACZ7oB,EAAO5mC,KAAKi9E,6BAAoDjzC,EAAY44B,EAAgBmY,GAC5F,MAEF,QACE/6E,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEb67B,EAAO5mC,KAAKL,OAAO8rC,cAIvB,IAAI6jC,EAActvE,KAAKsvE,YACnB4N,EAAgD,IAA7B,EAAXnC,GAgBZ,OAfIzL,GAAe1M,IACF,EAAXmY,GACFn0C,EAAO5mC,KAAKm9E,kBAAkBv2C,EAAM0oC,EAAa1M,GAAgB,EAAMsa,EAAMlzC,GAC7EkzC,GAAO,EACPl9E,KAAKsvE,YAAc1M,GACC,EAAXmY,IACTn0C,EAAO5mC,KAAKm9E,kBAAkBv2C,EAAM0oC,EAAa1M,GAAgB,EAAOsa,EAAMlzC,GAC9EkzC,GAAO,EACPl9E,KAAKsvE,YAAc1M,IAGnBsa,IAAMt2C,EAAO5mC,KAAKo9E,uBAAuBx2C,EAAM0oC,IAG/CtvE,KAAK0U,QAAQgW,WAAW1qB,KAAKs5E,iBAAiB1yC,EAAMoD,EAAWj/B,OAC5D67B,GAITuoC,EAAAltE,UAAAuwC,qBAAA,SACExI,EACA44B,EACAmY,GAEA,YAFA,IAAAA,MAAA,GAEO/6E,KAAKL,OAAO6yC,qBACjBxyC,KAAKs0E,kBAAkBtqC,EAAY44B,EAAgBmY,KAIvD5L,EAAAltE,UAAAk7E,kBAAA,SACEv2C,EAEAqnC,EAEA/oB,EAEAm4B,EAEAH,EACAnX,GAEA,IAAIpmE,EAASK,KAAKL,OAGlB,OAAiB,IAAbsuE,EAASx3D,MACXrM,OAAkB,IAAX86C,EAAOzuC,MACdzW,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACfxO,EAAWh7D,MAAOkjE,EAASviE,WAAYw5C,EAAOx5C,YAEzC/L,EAAO8rC,eAID,IAAXyZ,EAAOzuC,KAA8B9W,EAAOoqC,KAAKnD,IAEjD5mC,KAAK0wE,YAAY9F,UAAUhkC,EAAMqnC,KAAWA,EAAWA,EAAS5b,iBAE/D4b,EAAS7gD,eAAe83B,IACtBm4B,IACCpP,EAAS5b,iBAAmBnN,EAC9BllD,KAAKqN,MACHI,EAAAhD,eAAe6yE,wBACfvX,EAAWh7D,OAGb/K,KAAKqN,MACHI,EAAAhD,eAAe8yE,sDACfxX,EAAWh7D,MAAOkjE,EAASviE,WAAYw5C,EAAOx5C,aAMlDuiE,EAAS3uD,GAAE,GAGT4lC,EAAO5lC,GAAE,GACM,IAAb2uD,EAASx3D,KAGI,IAAXyuC,EAAOzuC,OACTmwB,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ0qD,WAAY52C,IAMtB,IAAXse,EAAOzuC,OAChBmwB,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ2qD,UAAW72C,IAMhCse,EAAO5lC,GAAE,GAGD,IAAb2uD,EAASx3D,KACPyuC,GAAUx3C,EAAAkH,KAAKhR,MACjBgjC,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASuzC,MAAO/kC,EAAMjnC,EAAOkE,IAAI,IACtDq5E,GAAO,GAGLt2C,EAFOse,EAAO5lC,GAAE,GACd4lC,EAAO5lC,GAAE,IACJ3f,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ4qD,cAAe92C,GAEpCjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ6qD,cAAe/2C,GAGzCse,EAAO5lC,GAAE,IACJ3f,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ8qD,cAAeh3C,GAEpCjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ+qD,cAAej3C,GAM3Cse,GAAUx3C,EAAAkH,KAAKhR,MACjBgjC,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASwzC,MAAOhlC,EAAMjnC,EAAOmE,IAAI,IACtDo5E,GAAO,GAGLt2C,EAFOse,EAAO5lC,GAAE,GACd4lC,EAAO5lC,GAAE,IACJ3f,EAAO+mC,MAAMmrB,EAAA/+B,QAAQgrD,cAAel3C,GAEpCjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQirD,cAAen3C,GAGzCse,EAAO5lC,GAAE,IACJ3f,EAAO+mC,MAAMmrB,EAAA/+B,QAAQkrD,cAAep3C,GAEpCjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQmrD,cAAer3C,IAOjDx8B,OAAmB,GAAZ86C,EAAOlyC,MAAyB,sBACvC4zB,EAAOjnC,EAAOoqC,KAAKnD,IAIZqnC,EAAS3uD,GAAE,IAAuB4lC,EAAO5lC,GAAE,GAKhDsnB,EAFW,IAAXse,EAAOzuC,KACLw3D,EAAS3uD,GAAE,IACN3f,EAAO+mC,MACZunC,EAAS3uD,GAAE,GACPuyC,EAAA/+B,QAAQorD,gBACRrsB,EAAA/+B,QAAQqrD,gBACZv3C,GAGKjnC,EAAO+mC,MACZunC,EAAS3uD,GAAE,GACPuyC,EAAA/+B,QAAQsrD,gBACRvsB,EAAA/+B,QAAQurD,gBACZz3C,GAMAqnC,EAAS3uD,GAAE,IACN3f,EAAO+mC,MACZunC,EAAS3uD,GAAE,GACPuyC,EAAA/+B,QAAQwrD,gBACRzsB,EAAA/+B,QAAQyrD,gBACZ33C,GAGKjnC,EAAO+mC,MACZunC,EAAS3uD,GAAE,GACPuyC,EAAA/+B,QAAQ0rD,gBACR3sB,EAAA/+B,QAAQ2rD,gBACZ73C,GAQFqnC,EAAS3uD,GAAE,IAGT4lC,GAAUx3C,EAAAkH,KAAKhR,MACjBgjC,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASgzC,MAAOxkC,EAAMjnC,EAAO0D,IAAI,IACtD65E,GAAO,GACGh4B,EAAO5lC,GAAE,MACnBsnB,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ4rD,QAAS93C,IAI9Bse,EAAO5lC,GAAE,KAClBsnB,EAAOjnC,EAAO+mC,MACZunC,EAAS3uD,GAAE,GAAqBuyC,EAAA/+B,QAAQ6rD,UAAY9sB,EAAA/+B,QAAQ8rD,UAC5D5+E,KAAKo9E,uBAAuBx2C,EAAMqnC,IAEpCiP,GAAO,GAKHjP,EAAS3uD,GAAE,KAET2uD,EAASriC,KAAOsZ,EAAOtZ,OACzBhF,EAAO5mC,KAAKo9E,uBAAuBx2C,EAAMqnC,GACzCiP,GAAO,GAMfl9E,KAAKsvE,YAAcpqB,EACZg4B,EACHl9E,KAAKo9E,uBAAuBx2C,EAAMse,GAClCte,IAGNuoC,EAAAltE,UAAAm6E,2BAAA,SACEpyC,EACA44B,EACAmY,GAEA,IAAI8D,GAAqC,EAAd9D,EAC3B,OAAQ/wC,EAAWib,eACjB,KAAKt3C,EAAAghD,cAAcmwB,OACnB,KAAKnxE,EAAAghD,cAAc2G,GACjB,IAAIlrC,EAAOpqB,KAAK0wE,YACZxrB,EAASllD,KAAKqS,SAASmuD,YACzBp2D,OAAO4/B,EAAWkb,QAClB96B,EAAKg6C,eACLh6C,EAAK3B,yBAEP,OAAKy8B,EACEllD,KAAKs0E,kBAAkBtqC,EAAWA,WAAYkb,EAA4B,EAApB25B,GADzC7+E,KAAKL,OAAO8rC,cAGlC,KAAK99B,EAAAghD,cAAc4V,QACjBn6D,QAAQ4/B,EAAWkb,QACnB,IAAIte,EAAO5mC,KAAKs0E,kBAAkBtqC,EAAWA,WAAY44B,EAAemc,WAAYF,GAChF5/D,EAAOjf,KAAKsvE,YAChB,GAAItvE,KAAK0wE,YAAY9F,UAAUhkC,EAAM3nB,GACnCjf,KAAKiN,KACHQ,EAAAhD,eAAeu0E,yBACfh1C,EAAWA,WAAWj/B,YAEnB,IAAK/K,KAAK0U,QAAQiB,SAAU,CACjC,IAAIhW,EAASK,KAAKL,OAEds/E,GADA70D,EAAOpqB,KAAK0wE,aACK3H,oBAAoB9pD,GAAM2I,MAC1CwC,EAAKihD,YAAYzkC,EAAM3nB,IAAOmL,EAAKw+C,aAAaqW,EAAWpxE,EAAAw5D,WAAWiE,SAC3ElhD,EAAKw+C,aAAaqW,EAAWpxE,EAAAw5D,WAAW9C,SACxC39B,EAAOjnC,EAAOyqC,GACZzqC,EAAO6nC,UAAUy3C,EAAWr4C,GAC5BjnC,EAAO2nC,UAAU23C,EAAWhgE,EAAKw0C,gBACjC9zD,EAAO8rC,eAIX,OADAzrC,KAAKsvE,YAActvE,KAAKsvE,YAAYjd,gBAC7BzrB,EAET,QAASx8B,QAAO,GAElB,OAAOpK,KAAKL,OAAO8rC,eAQrB0jC,EAAAltE,UAAAo6E,wBAAA,SACEryC,EACA44B,EACAmY,GAEA,IAIImE,EACAC,EACAC,EACAC,EACAC,EAEA14C,EAVAjnC,EAASK,KAAKL,OACdonC,EAAOiD,EAAWjD,KAClBC,EAAQgD,EAAWhD,MASnBu4C,GAAW,EAEXl6B,EAAWrb,EAAWqb,SAC1B,OAAQA,GACN,KAAKjD,EAAAC,MAAMkV,SAKT,GAJA2nB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAayC,IAC5C,CACZ42B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAKrB,GAFA2zC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,IAAKo0E,EAASzzE,WAAY2zE,EAAU3zE,YAExD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAEhB,OAlBEyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAUIs4C,EAAW7oE,MACjB,OACA,OACA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASyzC,MAAOqT,EAAUE,GAC/C,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS2zC,MAAOmT,EAAUE,GAC/C,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS2zC,MACTla,EAAAz5B,SAASyzC,MACbqT,EACAE,GAEF,MAEF,OACA,OACA,OACA,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS0zC,MAAOoT,EAAUE,GAC/C,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS4zC,MACTna,EAAAz5B,SAAS0zC,MACboT,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS4zC,MAAOkT,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS6zC,MAAOiT,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS8zC,MAAOgT,EAAUE,GAC/C,MAEF,QACEh1E,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlBzrC,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACxB,MAEF,KAAKw+C,EAAAC,MAAMmV,YAKT,GAJA0nB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAaqC,IAC5C,CACZg3B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAKrB,GAFA2zC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,IAAKo0E,EAASzzE,WAAY2zE,EAAU3zE,YAExD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAEhB,OAlBEyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAUIs4C,EAAW7oE,MACjB,OACA,OACA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASq0C,MAAOyS,EAAUE,GAC/C,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASu0C,MACT9a,EAAAz5B,SAASq0C,MACbyS,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASu0C,MAAOuS,EAAUE,GAC/C,MAEF,OACA,OACA,OACA,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASs0C,MAAOwS,EAAUE,GAC/C,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASw0C,MACT/a,EAAAz5B,SAASs0C,MACbwS,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASw0C,MAAOsS,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASy0C,MAAOqS,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS00C,MAAOoS,EAAUE,GAC/C,MAEF,QACEh1E,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlBzrC,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACxB,MAEF,KAAKw+C,EAAAC,MAAMoV,gBAKT,GAJAynB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa0C,IAC5C,CACZ22B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAKrB,GAFA2zC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,KAAMo0E,EAASzzE,WAAY2zE,EAAU3zE,YAEzD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAEhB,OAlBEyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAUIs4C,EAAW7oE,MACjB,OACA,OACA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS+zC,MAAO+S,EAAUE,GAC/C,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASi0C,MACTxa,EAAAz5B,SAAS+zC,MACb+S,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASi0C,MAAO6S,EAAUE,GAC/C,MAEF,OACA,OACA,OACA,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASg0C,MAAO8S,EAAUE,GAC/C,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASk0C,MACTza,EAAAz5B,SAASg0C,MACb8S,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASk0C,MAAO4S,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASm0C,MAAO2S,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASo0C,MAAO0S,EAAUE,GAC/C,MAEF,QACEh1E,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlBzrC,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACxB,MAEF,KAAKw+C,EAAAC,MAAMqV,mBAKT,GAJAwnB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAasC,IAC5C,CACZ+2B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAKrB,GAFA2zC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,KAAMo0E,EAASzzE,WAAY2zE,EAAU3zE,YAEzD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAEhB,OAlBEyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAUIs4C,EAAW7oE,MACjB,OACA,OACA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS20C,MAAOmS,EAAUE,GAC/C,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS60C,MACTpb,EAAAz5B,SAAS20C,MACbmS,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS60C,MAAOiS,EAAUE,GAC/C,MAEF,OACA,OACA,OACA,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS40C,MAAOkS,EAAUE,GAC/C,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS80C,MACTrb,EAAAz5B,SAAS40C,MACbkS,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS80C,MAAOgS,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS+0C,MAAO+R,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASg1C,MAAO8R,EAAUE,GAC/C,MAEF,QACEh1E,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlBzrC,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACxB,MAGF,KAAKw+C,EAAAC,MAAMwV,qBACX,KAAKzV,EAAAC,MAAMsV,cAUT,GAJAunB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZjqB,GAAYjD,EAAAC,MAAMsV,eAAiB33D,KAAKsvE,YAAYhwD,GAAE,KAExD,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAamC,IAC5C,CACZk3B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAQN,GAFAo1C,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAOq3C,EAAAiV,sBAAsBrtB,EAAWqb,UAAW85B,EAASzzE,WAAY2zE,EAAU3zE,YAE/F1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAEhB,OAlBEyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAUIs4C,EAAW7oE,MACjB,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS6yC,MAAOiU,EAAUE,GAC/C,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS8yC,MACTrZ,EAAAz5B,SAAS6yC,MACbiU,EACAE,GAEF,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS8yC,MAAOgU,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASqzC,MAAOyT,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASszC,MAAOwT,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ4sD,gBAC1B//E,EAAOmnC,OAAO+qB,EAAAz5B,SAASunD,WAAYT,EAAUE,IAE/C,MAEF,QACEh1E,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlBzrC,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACxB,MAEF,KAAKw+C,EAAAC,MAAMyV,0BACX,KAAK1V,EAAAC,MAAMuV,mBAKT,GAJAsnB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZjqB,GAAYjD,EAAAC,MAAMuV,oBAAsB53D,KAAKsvE,YAAYhwD,GAAE,KAE7D,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAaoC,IAC5C,CACZi3B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAQN,GAFAo1C,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAOq3C,EAAAiV,sBAAsBrtB,EAAWqb,UAAW85B,EAASzzE,WAAY2zE,EAAU3zE,YAE/F1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAEhB,OAlBEyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAUIs4C,EAAW7oE,MACjB,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS+yC,MAAO+T,EAAUE,GAC/C,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASgzC,MACTvZ,EAAAz5B,SAAS+yC,MACb+T,EACAE,GAEF,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASgzC,MAAO8T,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASuzC,MAAOuT,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASwzC,MAAOsT,EAAUE,GAC/C,MAEF,QACEx4C,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ8sD,gBAC1BjgF,EAAOmnC,OAAO+qB,EAAAz5B,SAASynD,WAAYX,EAAUE,IAE/C,MAEF,QACEh1E,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlBzrC,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACxB,MAEF,KAAKw+C,EAAAC,MAAM0W,OACT,OAAO/4D,KAAK8/E,kBAAkB/4C,EAAMC,EAAO47B,GAE7C,KAAKxgB,EAAAC,MAAM2W,YAAaumB,GAAW,EACnC,KAAKn9B,EAAAC,MAAMjyC,KAKT,GAJA8uE,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa0B,KAC5C,CACZ23B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAGrB,GAAI8zC,EACFH,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,OAC7C,CAGL,GAFAC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,IAAKo0E,EAASzzE,WAAY2zE,EAAU3zE,YAExD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAhBdyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAWN,OAAQhnC,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,QACA,OACA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASk9C,OAAQ4J,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS2nD,OACTluB,EAAAz5B,SAASk9C,OACb4J,EACAE,GAEF,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS2nD,OAAQb,EAAUE,GAChD,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS4nD,OAAQd,EAAUE,GAChD,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS6nD,OAAQf,EAAUE,GAChD,MAEF,QACEh1E,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAM4W,aAAcsmB,GAAW,EACpC,KAAKn9B,EAAAC,MAAM/xC,MAKT,GAJA4uE,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa2B,KAC5C,CACZ03B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAGrB,GAAI8zC,EACFH,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,GAClDE,EAAYr/E,KAAKsvE,gBACZ,CAGL,GAFA8P,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,IAAKo0E,EAASzzE,WAAY2zE,EAAU3zE,YAExD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAhBdyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAWN,OAAQhnC,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,QACA,OACA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS8nD,OAAQhB,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS+nD,OACTtuB,EAAAz5B,SAAS8nD,OACbhB,EACAE,GAEF,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS+nD,OAAQjB,EAAUE,GAChD,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASgoD,OAAQlB,EAAUE,GAChD,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASioD,OAAQnB,EAAUE,GAChD,MAEF,QACEh1E,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAM6W,gBAAiBqmB,GAAW,EACvC,KAAKn9B,EAAAC,MAAM2V,SAKT,GAJAknB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa4B,KAC5C,CACZy3B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAGrB,GAAI8zC,EACFL,EAAWl/E,KAAKo9E,uBAAuB8B,EAAUC,GACjDC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,OAC7C,CAGL,GAFAC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,IAAKo0E,EAASzzE,WAAY2zE,EAAU3zE,YAExD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAhBdyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAWN,OAAQhnC,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,QACA,OACA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASi1C,OAAQ6R,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASkoD,OACTzuB,EAAAz5B,SAASi1C,OACb6R,EACAE,GAEF,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASkoD,OAAQpB,EAAUE,GAChD,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASmoD,OAAQrB,EAAUE,GAChD,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASooD,OAAQtB,EAAUE,GAChD,MAEF,QACEh1E,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAM8W,yBAA0BomB,GAAW,EAChD,KAAKn9B,EAAAC,MAAM0V,kBAKT,GAJAmnB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa6B,KAC5C,CACZw3B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAGrB,IAAIljB,OAAQ,EAGZ,GAAyB,IAArBvoB,KAAKsvE,YAAY74D,MAGnB,GAFA2oE,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOt5B,EAAAkH,KAAK/Q,IAAG,GAClDw7E,EAAYr/E,KAAKsvE,cACX/mD,EAAWvoB,KAAKgwE,gBAAiB,CAErC,KADIyQ,EAAYzgF,KAAKwlB,QAAQ3L,aAAarM,EAAAxK,cAAcwE,QACxC,CACdxH,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACf93B,EAAWj/B,MAAO,SAEpB67B,EAAOjnC,EAAO8rC,cACd,MAGF,KADIxpC,EAAYw+E,EAAU3hE,QAAU2hE,EAAU3hE,QAAQ5d,IAAIsM,EAAAxK,cAAcqF,KAAO,MAC/D,CACdrI,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACf93B,EAAWj/B,MAAO,aAEpB67B,EAAOjnC,EAAO8rC,cACd,MAEFrhC,OAAOnI,EAAUwU,MAAQm7C,EAAA9gD,YAAYkN,oBACrChe,KAAKgwE,eAAiBznD,EAAWvoB,KAAKqS,SAAS4L,gBAAmChc,EAAW,YAc/F,GARAi9E,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCl/E,KAAKsvE,YAAa5hE,EAAAkH,KAAK9Q,KACvB,GAAO,EACPijC,GAEFo4C,EAAWn/E,KAAKsvE,YAChB8P,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOt5B,EAAAkH,KAAK9Q,IAAG,GAClDu7E,EAAYr/E,KAAKsvE,cACX/mD,EAAWvoB,KAAKiwE,gBAAiB,CAErC,KADIwQ,EAAYzgF,KAAKwlB,QAAQ3L,aAAarM,EAAAxK,cAAcuE,OACxC,CACdvH,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACf93B,EAAWj/B,MAAO,QAEpB67B,EAAOjnC,EAAO8rC,cACd,MAGF,KADIxpC,EAAYw+E,EAAU3hE,QAAU2hE,EAAU3hE,QAAQ5d,IAAIsM,EAAAxK,cAAcqF,KAAO,MAC/D,CACdrI,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACf93B,EAAWj/B,MAAO,YAEpB67B,EAAOjnC,EAAO8rC,cACd,MAEFrhC,OAAOnI,EAAUwU,MAAQm7C,EAAA9gD,YAAYkN,oBACrChe,KAAKiwE,eAAiB1nD,EAAWvoB,KAAKqS,SAAS4L,gBAAmChc,EAAW,MAM/F2kC,EAHIre,GAAYvoB,KAAKw1E,gBAAgBjtD,GAG9BvoB,KAAK0gF,eAAen4D,EAAU,CAAE22D,EAAUE,GAAap1C,GAFvDrqC,EAAO8rC,cAIhB,MAEF,KAAK2W,EAAAC,MAAM+W,aAAcmmB,GAAW,EACpC,KAAKn9B,EAAAC,MAAM4V,MAKT,GAJAinB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa8B,KAC5C,CACZu3B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAGrB,GAAI8zC,EACFL,EAAWl/E,KAAKo9E,uBAAuB8B,EAAUC,GACjDC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,GAClDE,EAAYr/E,KAAKsvE,gBACZ,CAGL,GAFA8P,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,IAAKo0E,EAASzzE,WAAY2zE,EAAU3zE,YAExD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAhBdyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAWN,OAAQhnC,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASuoD,OAAQzB,EAAUE,GAChD,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASwoD,OACT/uB,EAAAz5B,SAASuoD,OACbzB,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASwoD,OAAQ1B,EAAUE,GAChD,MAEF,OACA,OACA,QAIA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASs1C,OAAQwR,EAAUE,GAChD,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASyoD,OACThvB,EAAAz5B,SAASs1C,OACbwR,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASyoD,OAAQ3B,EAAUE,GAChD,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS0oD,OAAQ5B,EAAUE,GAChD,MAEF,QACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS2oD,OAAQ7B,EAAUE,GAChD,MAEF,QACEh1E,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAMgX,eAAgBkmB,GAAW,EACtC,KAAKn9B,EAAAC,MAAM6V,QAKT,GAJAgnB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,GACxCuc,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa+B,KAC5C,CACZs3B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAGrB,GAAI8zC,EACFL,EAAWl/E,KAAKo9E,uBAAuB8B,EAAUC,GACjDC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,GAClDE,EAAYr/E,KAAKsvE,gBACZ,CAGL,GAFA8P,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,IAAKo0E,EAASzzE,WAAY2zE,EAAU3zE,YAExD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAhBdyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAWN,OAAQhnC,KAAKsvE,YAAY74D,MACvB,OACA,OAIA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASu1C,OAAQuR,EAAUE,GAChD,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS4oD,OACTnvB,EAAAz5B,SAASu1C,OACbuR,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS4oD,OAAQ9B,EAAUE,GAChD,MAEF,OACA,OACA,QAIA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASw1C,OAAQsR,EAAUE,GAChD,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS6oD,OACTpvB,EAAAz5B,SAASw1C,OACbsR,EACAE,GAEF,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS6oD,OAAQ/B,EAAUE,GAChD,MAEF,QAEE,KADI72D,EAAWvoB,KAAK8vE,gBACL,CAEb,KADI2Q,EAAYzgF,KAAKwlB,QAAQ3L,aAAarM,EAAAxK,cAAcwE,QACxC,CACdxH,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACf93B,EAAWj/B,MAAO,SAEpB67B,EAAOjnC,EAAO8rC,cACd,MAGF,KADIxpC,EAAYw+E,EAAU3hE,QAAU2hE,EAAU3hE,QAAQ5d,IAAIsM,EAAAxK,cAAcsF,KAAO,MAC/D,CACdtI,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACf93B,EAAWj/B,MAAO,aAEpB67B,EAAOjnC,EAAO8rC,cACd,MAEFrhC,OAAOnI,EAAUwU,MAAQm7C,EAAA9gD,YAAYkN,oBACrChe,KAAK8vE,eAAiBvnD,EAAWvoB,KAAKqS,SAAS4L,gBAAmChc,EAAW,MAK7F2kC,EAHIre,GAAYvoB,KAAKw1E,gBAAgBjtD,GAG9BvoB,KAAK0gF,eAAen4D,EAAU,CAAE22D,EAAUE,GAAap1C,GAFvDrqC,EAAO8rC,cAIhB,MAEF,QAEE,KADIljB,EAAWvoB,KAAK+vE,gBACL,CACb,IAAI0Q,EASAx+E,EARJ,KADIw+E,EAAYzgF,KAAKwlB,QAAQ3L,aAAarM,EAAAxK,cAAcuE,OACxC,CACdvH,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACf93B,EAAWj/B,MAAO,QAEpB67B,EAAOjnC,EAAO8rC,cACd,MAGF,KADIxpC,EAAYw+E,EAAU3hE,QAAU2hE,EAAU3hE,QAAQ5d,IAAIsM,EAAAxK,cAAcsF,KAAO,MAC/D,CACdtI,KAAKqN,MACHI,EAAAhD,eAAeq3D,mBACf93B,EAAWj/B,MAAO,YAEpB67B,EAAOjnC,EAAO8rC,cACd,MAEFrhC,OAAOnI,EAAUwU,MAAQm7C,EAAA9gD,YAAYkN,oBACrChe,KAAK+vE,eAAiBxnD,EAAWvoB,KAAKqS,SAAS4L,gBAAmChc,EAAW,MAK7F2kC,EAHIre,GAAYvoB,KAAKw1E,gBAAgBjtD,GAG9BvoB,KAAK0gF,eAAen4D,EAAU,CAAE22D,EAAUE,GAAap1C,GAFvDrqC,EAAO8rC,cAIhB,MAEF,QACErhC,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAMiX,yBAA0BimB,GAAW,EAChD,KAAKn9B,EAAAC,MAAMgW,kBAKT,GAJA6mB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,EAAese,SACvD/B,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa2C,aAC5C,CACZ02B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAKrB,OAFA2zC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,GAClDE,EAAYr/E,KAAKsvE,YACTtvE,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,QACA,OACA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASm1C,OAAQ2R,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS+oD,OAAQjC,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS+oD,OACTtvB,EAAAz5B,SAASm1C,OACb2R,EACAE,GAEF,MAEF,QACA,QAKE,OAJAp/E,KAAKqN,MACHI,EAAAhD,eAAe22E,2CACfp3C,EAAWj/B,MAAOq3C,EAAAiV,sBAAsBrtB,EAAWqb,UAAWrlD,KAAKsvE,YAAY5jE,YAE1E/L,EAAO8rC,cAEhB,QACErhC,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAMkX,+BAAgCgmB,GAAW,EACtD,KAAKn9B,EAAAC,MAAMiW,wBAKT,GAJA4mB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,EAAese,SACvD/B,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAauC,aAC5C,CACZ82B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAMrB,OAHAyzC,EAAWl/E,KAAKo9E,uBAAuB8B,EAAUC,GACjDC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,GAClDE,EAAYr/E,KAAKsvE,YACTtvE,KAAKsvE,YAAY74D,MACvB,OACA,OAIA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASo1C,OAAQ0R,EAAUE,GAChD,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASipD,OAAQnC,EAAUE,GAChD,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASipD,OACTxvB,EAAAz5B,SAASo1C,OACb0R,EACAE,GAEF,MAEF,OACA,OACA,QAIA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASq1C,OAAQyR,EAAUE,GAChD,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASkpD,OAAQpC,EAAUE,GAChD,MAEF,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASkpD,OACTzvB,EAAAz5B,SAASq1C,OACbyR,EACAE,GAEF,MAEF,QACA,QAKE,OAJAp/E,KAAKqN,MACHI,EAAAhD,eAAe22E,2CACfp3C,EAAWj/B,MAAOq3C,EAAAiV,sBAAsBrtB,EAAWqb,UAAWrlD,KAAKsvE,YAAY5jE,YAE1E/L,EAAO8rC,cAEhB,QACErhC,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAMmX,2CAA4C+lB,GAAW,EAClE,KAAKn9B,EAAAC,MAAMkW,oCAKT,GAJA2mB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,EAAese,SACvD/B,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAawC,eAC5C,CACZ62B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAMrB,OAHAyzC,EAAWl/E,KAAKo9E,uBAAuB8B,EAAUC,GACjDC,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,GAClDE,EAAYr/E,KAAKsvE,YACTtvE,KAAKsvE,YAAY74D,MACvB,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASq1C,OAAQyR,EAAUE,GAElD,OACA,OACA,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASq1C,OAAQyR,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASkpD,OAAQpC,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASkpD,OACTzvB,EAAAz5B,SAASq1C,OACbyR,EACAE,GAEF,MAEF,QACA,QAKE,OAJAp/E,KAAKqN,MACHI,EAAAhD,eAAe22E,2CACfp3C,EAAWj/B,MAAOq3C,EAAAiV,sBAAsBrtB,EAAWqb,UAAWrlD,KAAKsvE,YAAY5jE,YAE1E/L,EAAO8rC,cAEhB,QACErhC,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAMoX,iBAAkB8lB,GAAW,EACxC,KAAKn9B,EAAAC,MAAMmW,UAKT,GAJA0mB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,EAAese,SACvD/B,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAagC,aAC5C,CACZq3B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAGrB,GAAI8zC,EACFH,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,GAClDE,EAAYr/E,KAAKsvE,gBACZ,CAGL,GAFA8P,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,IAAKo0E,EAASzzE,WAAY2zE,EAAU3zE,YAExD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAhBdyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAWN,OAAQhnC,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,OACA,QACA,OACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASk1C,OAAQ4R,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASmpD,OAAQrC,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASmpD,OACT1vB,EAAAz5B,SAASk1C,OACb4R,EACAE,GAEF,MAEF,QACA,QAKE,OAJAp/E,KAAKqN,MACHI,EAAAhD,eAAe22E,2CACfp3C,EAAWj/B,MAAOq3C,EAAAiV,sBAAsBrtB,EAAWqb,UAAWrlD,KAAKsvE,YAAY5jE,YAE1E/L,EAAO8rC,cAEhB,QACErhC,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAMqX,WAAY6lB,GAAW,EAClC,KAAKn9B,EAAAC,MAAMoW,IAKT,GAJAymB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,EAAese,SACvD/B,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAaiC,YAC5C,CACZo3B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAGrB,GAAI8zC,EACFH,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,GAClDE,EAAYr/E,KAAKsvE,gBACZ,CAGL,GAFA8P,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,IAAKo0E,EAASzzE,WAAY2zE,EAAU3zE,YAExD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAhBdyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAWN,OAAQhnC,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASopD,MAAOtC,EAAUE,GAC/C,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASopD,MAAOtC,EAAUE,GAC/C,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASqpD,MAAOvC,EAAUE,GAC/C,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASqpD,MACT5vB,EAAAz5B,SAASopD,MACbtC,EACAE,GAEF,MAEF,QACA,QAKE,OAJAp/E,KAAKqN,MACHI,EAAAhD,eAAe22E,2CACfp3C,EAAWj/B,MAAOq3C,EAAAiV,sBAAsBrtB,EAAWqb,UAAWrlD,KAAKsvE,YAAY5jE,YAE1E/L,EAAO8rC,cAEhB,QACErhC,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAMsX,aAAc4lB,GAAW,EACpC,KAAKn9B,EAAAC,MAAMqW,MAKT,GAJAwmB,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,EAAese,SACvD/B,EAAWn/E,KAAKsvE,YAGZtvE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAC5C,IAAIqP,EAEEnB,EADN,GADImB,EAAiBwwD,EAASxwD,eAG5B,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAakC,aAC5C,CACZm3B,EAAO5mC,KAAKw/E,sBAAsBhyD,EAAUuZ,EAAMm4C,EAAUl4C,EAAOgD,GACnE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAGrB,GAAI8zC,EACFH,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAAQ,GAClDE,EAAYr/E,KAAKsvE,gBACZ,CAGL,GAFA8P,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,GAC1CE,EAAYr/E,KAAKsvE,cACbgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkB4rB,EAAUE,GAAW,IAiB3D,OALAr/E,KAAKqN,MACHI,EAAAhD,eAAeg1E,8CACfz1C,EAAWj/B,MAAO,IAAKo0E,EAASzzE,WAAY2zE,EAAU3zE,YAExD1L,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,cAhBdyzC,EAAWl/E,KAAKm9E,kBAAkB+B,EAChCC,EAAUA,EAAWG,GACrB,GAAO,EACPv4C,GAEFq4C,EAAYp/E,KAAKm9E,kBAAkBiC,EACjCC,EAAWA,EAAYC,GACvB,GAAO,EACPt4C,GAWN,OAAQhnC,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASspD,OAAQxC,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASspD,OAAQxC,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASupD,OAAQzC,EAAUE,GAChD,MAEF,OACA,OACEx4C,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASupD,OACT9vB,EAAAz5B,SAASspD,OACbxC,EACAE,GAEF,MAEF,QACA,QAKE,OAJAp/E,KAAKqN,MACHI,EAAAhD,eAAe22E,2CACfp3C,EAAWj/B,MAAOq3C,EAAAiV,sBAAsBrtB,EAAWqb,UAAWrlD,KAAKsvE,YAAY5jE,YAE1E/L,EAAO8rC,cAEhB,QACErhC,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAKF,KAAK2W,EAAAC,MAAMwW,oBACT,IAAIzuC,EAAOpqB,KAAK0wE,YACZmO,EAAqC,GAAd9D,EAC3BmE,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,EAAemc,WAAYF,GACnEM,EAAWn/E,KAAKsvE,YAEhB,IAAIsS,EAAYx3D,EAAK89C,OAOrB,GANAloE,KAAK0wE,YAAckR,EACnBA,EAAU/W,qBAAqBqU,GAC/BE,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAA8B,EAApBN,GACpDQ,EAAYF,EAGRvc,GAAkBl1D,EAAAkH,KAAKhR,MAAQg/D,GAAkBl1D,EAAAkH,KAAKG,KACxDqqE,EAAYp/E,KAAK6hF,6BAA6BD,EAAWxC,EAAWC,GACpEuC,EAAUtY,mBACVtpE,KAAK0wE,YAActmD,EACnBpqB,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACxBgjC,EAAOjnC,EAAOyqC,GACZpqC,KAAK85E,cAAcoF,EAAUC,GAC7Bn/E,KAAK85E,cAAcsF,EAAWC,GAC9B1/E,EAAOyD,IAAI,SAIR,GAAI+7E,EAASvM,UAAW,CAC7B,IAAIkP,EAAyB9hF,KAAK6vE,oBAAoBr7D,IAAI0qE,GACtD6C,EAA0B/hF,KAAK6vE,oBAAoBr7D,IAAI4qE,GACvDlJ,EAAO9rD,EAAKi+C,aAAa8W,GAC7BD,EAAWv/E,EAAO6nC,UAAU0uC,EAAKtuD,MAAOs3D,GAIxC,IAAI8C,GAAmB,EACnBF,GAA0BC,EACvBD,GAGH1C,EAAYp/E,KAAK6yE,WAAWuM,GAC5B2C,GAA0B,GAH1BC,GAAmB,EAKC,GAAXjH,IACXqE,EAAYp/E,KAAKiiF,gBAAgB7C,EAAWwC,EAAWx3D,IAGzD,IAAI83D,EAAa,IAAIj7E,MACjB66E,GACFI,EAAW/Q,QACTnxE,KAAKmiF,YACHxiF,EAAO2nC,UAAU4uC,EAAKtuD,MAAOu3D,EAAS1rB,kBAI5C2rB,EAAYp/E,KAAK6hF,6BAA6BD,EAAWxC,EAAWC,EAAW6C,GAC/EN,EAAUtY,mBACVtpE,KAAK0wE,YAActmD,EAEnBwc,EAAOjnC,EAAOyqC,GACZpqC,KAAK85E,cAAcoF,EAAUC,GAC7BC,EACA4C,EACIhiF,KAAK6yE,WACHlzE,EAAO2nC,UAAU4uC,EAAKtuD,MAAOu3D,EAAS1rB,iBAExC9zD,EAAO2nC,UAAU4uC,EAAKtuD,MAAOu3D,EAAS1rB,kBAExCquB,GAA0BC,IAAyB/hF,KAAK6vE,oBAAoB76D,IAAI4xB,GAChFsvC,GAAM9rD,EAAK0+C,cAAcoN,QAS7B,GALAkJ,EAAYp/E,KAAK6hF,6BAA6BD,EAAWxC,EAAWC,GACpEuC,EAAUtY,mBACVtpE,KAAK0wE,YAActmD,EAGfwc,EAAOjnC,EAAO20C,gBAAgB4qC,GAAU,EAAM,GAChDt4C,EAAOjnC,EAAOyqC,GACZpqC,KAAK85E,cAAcoF,EAAUl/E,KAAKsvE,aAClC8P,EACAx4C,OAIG,CACL,IAAIs0C,EAAY9wD,EAAKi+C,aAAa8W,GAC7B/0D,EAAKihD,YAAY6T,EAAUC,IAAW/0D,EAAKw+C,aAAasS,EAAUtzD,MAAO/Z,EAAAw5D,WAAWiE,SACrFlhD,EAAKwgD,UAAUsU,EAAUC,IAAW/0D,EAAKw+C,aAAasS,EAAUtzD,MAAO/Z,EAAAw5D,WAAW9C,SACtF39B,EAAOjnC,EAAOyqC,GACZpqC,KAAK85E,cAAcn6E,EAAO6nC,UAAU0zC,EAAUtzD,MAAOs3D,GAAWC,GAChEC,EACAz/E,EAAO2nC,UAAU4zC,EAAUtzD,MAAOu3D,EAAS1rB,iBAIjDzzD,KAAKsvE,YAAc6P,EACnB,MAEF,KAAK/8B,EAAAC,MAAMyW,QACL1uC,EAAOpqB,KAAK0wE,YACZmO,EAAqC,GAAd9D,EAC3BmE,EAAWl/E,KAAKs0E,kBAAkBvtC,EAAM67B,EAAemc,WAAYF,GACnEM,EAAWn/E,KAAKsvE,YAEZsS,EAAYx3D,EAAK89C,OAOrB,GANAloE,KAAK0wE,YAAckR,EACnBA,EAAU5W,sBAAsBkU,GAChCE,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOm4C,EAA8B,EAApBN,GACpDQ,EAAYF,EAGRvc,GAAkBl1D,EAAAkH,KAAKhR,MAAQg/D,GAAkBl1D,EAAAkH,KAAKG,KACxDqqE,EAAYp/E,KAAK6hF,6BAA6BD,EAAWxC,EAAWD,GACpEyC,EAAUtY,mBACVtpE,KAAK0wE,YAActmD,EACnBpqB,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACxBgjC,EAAOjnC,EAAOyqC,GACZpqC,KAAK85E,cAAcoF,EAAUC,GAC7Bx/E,EAAOyD,IAAI,GACXpD,KAAK85E,cAAcsF,EAAWC,SAI3B,GAAIF,EAASvM,UAAW,CACzBkP,EAAyB9hF,KAAK6vE,oBAAoBr7D,IAAI0qE,GACtD6C,EAA0B/hF,KAAK6vE,oBAAoBr7D,IAAI4qE,GACvDlJ,EAAO9rD,EAAKi+C,aAAa8W,GAC7BD,EAAWv/E,EAAO6nC,UAAU0uC,EAAKtuD,MAAOs3D,GAIxC,IAAIkD,GAAmB,EACnBN,GAA0BC,EACvBD,GAGH1C,EAAYp/E,KAAK6yE,WAAWuM,GAC5B2C,GAA0B,GAH1BK,GAAmB,EAKC,GAAXrH,IACXqE,EAAYp/E,KAAKiiF,gBAAgB7C,EAAWwC,EAAWx3D,IAGrD83D,EAAa,IAAIj7E,MACjB66E,GAGFI,EAAW/Q,QACTnxE,KAAKmiF,YACHxiF,EAAO2nC,UAAU4uC,EAAKtuD,MAAOu3D,EAAS1rB,kBAI5C2rB,EAAYp/E,KAAK6hF,6BAA6BD,EAAWxC,EAAWC,EAAW6C,GAC/EN,EAAUtY,mBACVtpE,KAAK0wE,YAActmD,EAEnBwc,EAAOjnC,EAAOyqC,GACZpqC,KAAK85E,cAAcoF,EAAUC,GAC7BiD,EACIpiF,KAAK6yE,WACHlzE,EAAO2nC,UAAU4uC,EAAKtuD,MAAOu3D,EAAS1rB,iBAExC9zD,EAAO2nC,UAAU4uC,EAAKtuD,MAAOu3D,EAAS1rB,gBAC1C2rB,IAEE0C,GAA0BC,IAAyB/hF,KAAK6vE,oBAAoB76D,IAAI4xB,GAChFsvC,GAAM9rD,EAAK0+C,cAAcoN,QAS7B,GALAkJ,EAAYp/E,KAAK6hF,6BAA6BD,EAAWxC,EAAWC,GACpEuC,EAAUtY,mBACVtpE,KAAK0wE,YAActmD,EAGfwc,EAAOjnC,EAAO20C,gBAAgB4qC,GAAU,EAAM,GAChDt4C,EAAOjnC,EAAOyqC,GACZpqC,KAAK85E,cAAcoF,EAAUC,GAC7Bv4C,EACAw4C,OAIG,CACDlE,EAAY9wD,EAAK2+C,oBAAoBoW,GACpC/0D,EAAKihD,YAAY6T,EAAUC,IAAW/0D,EAAKw+C,aAAasS,EAAUtzD,MAAO/Z,EAAAw5D,WAAWiE,SACrFlhD,EAAKwgD,UAAUsU,EAAUC,IAAW/0D,EAAKw+C,aAAasS,EAAUtzD,MAAO/Z,EAAAw5D,WAAW9C,SACtF39B,EAAOjnC,EAAOyqC,GACZpqC,KAAK85E,cAAcn6E,EAAO6nC,UAAU0zC,EAAUtzD,MAAOs3D,GAAWC,GAChEx/E,EAAO2nC,UAAU4zC,EAAUtzD,MAAOu3D,EAAS1rB,gBAC3C2rB,GAINp/E,KAAKsvE,YAAc6P,EACnB,MAEF,QACE/0E,QAAO,GACPw8B,EAAO5mC,KAAKL,OAAO8rC,cAGvB,IAAK8zC,EAAU,OAAO34C,EACtB,IAAIv0B,EAAWrS,KAAKqS,SAChBgb,EAASrtB,KAAKqS,SAASywD,kBAAkB/7B,EAAM/mC,KAAK0wE,aACxD,OAAKrjD,EACErtB,KAAKqiF,eACVh1D,EACAuZ,EACAG,EACA10B,EAASiuD,sBACTjuD,EAASkuD,yBACTqC,GAAkBl1D,EAAAkH,KAAKG,MAPLpV,EAAO8rC,eAW7B0jC,EAAAltE,UAAAqgF,qBAAA,SACElb,EACA9lE,EACA0xE,EACAjN,GAIA,OAAO/lE,KAAK0gF,eAAetZ,EAAkB,CAAE4L,GAAajN,GAAY,IAG1EoJ,EAAAltE,UAAAu9E,sBAAA,SACEpY,EACArgC,EACAm4C,EACAl4C,EACA++B,GAEA,IAAIsZ,EACJ,GAAIjY,EAAiB9nD,GAAG9R,EAAAnL,YAAY4iB,UAAW,CAC7C,IAAItS,EAAgBvI,OAAOg9D,EAAiBlzD,QAAS9J,OAAOuI,EAAc8D,MAAQm7C,EAAA9gD,YAAY+N,OAC9FwgE,EAAYjY,EAAiBnzD,UAAU+V,eAAe,QAUtDq1D,EAAYjY,EAAiBnzD,UAAU+V,eAAe,GAExD,IAAIo1D,EAAYp/E,KAAKs0E,kBAAkBttC,EAAOq4C,EAAS,GACvD,OAAOr/E,KAAK0gF,eAAetZ,EAAkB,CAAE8X,EAAUE,GAAarZ,IAGxEoJ,EAAAltE,UAAA69E,kBAAA,SAAkB91C,EAAwB8wC,EAA6BlY,GACrE,IACIvwD,EADUrS,KAAKwlB,QACInT,SACnB+X,EAAOpqB,KAAK0wE,YACZrjD,EAAShb,EAASywD,kBAAkB94B,EAAY5f,GACpD,IAAKiD,EAAQ,OAAOrtB,KAAKL,OAAO8rC,cAChC,IAIIonB,EAJA0vB,EAAiBlwE,EAASiuD,sBAC1Bna,EAAoB9zC,EAASkuD,yBAIjC,OAAQlzC,EAAO5W,MACb,KAAKm7C,EAAA9gD,YAAYmQ,OAEf,IAAKjhB,KAAKozE,cAAsB/lD,GAAS,OAAOrtB,KAAKL,OAAO8rC,cAG9D,KAAKmmB,EAAA9gD,YAAY8N,MAIjB,KAAKgzC,EAAA9gD,YAAY+W,MACfgrC,EAAmCxlC,EAAQpO,KAC3C,MAEF,KAAK2yC,EAAA9gD,YAAYyN,mBACf,IAAIE,EAAsC4O,EAAQ5O,gBAClD,IAAKA,EAKH,OAJAze,KAAKqN,MACHI,EAAAhD,eAAe+3E,oEACfx4C,EAAWj/B,MAAkBsiB,EAAQjb,cAEhCpS,KAAKL,OAAO8rC,cAGrB,KADI/f,EAAiB1rB,KAAKqS,SAAS4L,gBAAgBQ,EAAiB,KAAM5U,EAAA23D,UAAW5zD,EAAAwyD,WAAWO,SAC3E,OAAO3gE,KAAKL,OAAO8rC,cACxCrhC,OAAyD,GAAlDshB,EAAezX,UAAU+V,eAAe7d,QAC/C0mD,EAAannC,EAAezX,UAAU+V,eAAe,GACrD,MAEF,KAAK4nC,EAAA9gD,YAAY4N,SACf,IAAIgN,EACJ,KADIA,EAA4B2B,EAAQ3B,gBAMtC,OAJA1rB,KAAKqN,MACHI,EAAAhD,eAAe+3E,oEACfx4C,EAAWj/B,MAAkBsiB,EAAQjb,cAEhCpS,KAAKL,OAAO8rC,cAErBrhC,OAAyD,GAAlDshB,EAAezX,UAAU+V,eAAe7d,QAC/C0mD,EAAannC,EAAezX,UAAU+V,eAAe,GACrD,MAEF,KAAK4nC,EAAA9gD,YAAY+N,MACf,GAAIsnC,EAAmB,CACrB,IAAIs8B,EAAcr4D,EAAK9K,GAAE,OAcrBojE,EAAqBr1D,EAAQF,eAAeykC,EAAArkD,aAAauB,YAAa2zE,GAC1E,IAAKC,EAaH,OAZyBr1D,EAAQF,eAAeykC,EAAArkD,aAAasB,YAAa4zE,GAOxEziF,KAAKqN,MACHI,EAAAhD,eAAek4E,+CACf34C,EAAWj/B,MAAesiB,EAAQjb,cAPpCpS,KAAKqN,MACHI,EAAAhD,eAAew3D,qCACfj4B,EAAWj/B,MAAesiB,EAAQjb,cAQ/BpS,KAAKL,OAAO8rC,cAErBrhC,OAAqD,GAA9Cs4E,EAAWzuE,UAAU+V,eAAe7d,QAC3C0mD,EAAa6vB,EAAWzuE,UAAU+V,eAAe,GACjD,MAIJ,QAKE,OAJAhqB,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,cAMvB,OADArhC,OAAOyoD,GAAcnlD,EAAAkH,KAAKG,MACnB/U,KAAKqiF,eACVh1D,EACArtB,KAAKs0E,kBAAkBwG,EAAiBjoB,EAAY,IACpD7oB,EACAu4C,EACAp8B,EACAyc,GAAkBl1D,EAAAkH,KAAKG,OAK3Bo6D,EAAAltE,UAAAogF,eAAA,SAEEh1D,EAEA2lD,EAEA8H,EAEAyH,EAEAK,EAEAC,GAEA,IAAIljF,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YAKhB,OAAQrjD,EAAO5W,MACb,KAAKm7C,EAAA9gD,YAAY+W,MACf,OAAIuC,EAAKo/C,YAAoBn8C,EAAQzF,MAAO/Z,EAAAw5D,WAAW6U,UAAU,IAC/Dl8E,KAAKqN,MACHI,EAAAhD,eAAe+3E,oEACf1H,EAAgB/vE,MAAOsiB,EAAOjb,cAEhCpS,KAAKsvE,YAAcuT,EAAcx1D,EAAQpO,KAAOvR,EAAAkH,KAAKG,KAC9CpV,EAAO8rC,eAETzrC,KAAK8iF,oBAA2Bz1D,EAAQ2lD,EAAW6P,GAE5D,KAAKjxB,EAAA9gD,YAAYmQ,OACf,OAAKjhB,KAAKozE,cAAsB/lD,GAC5BA,EAAOzL,MAAMpU,EAAAnL,YAAYod,MAAQjS,EAAAnL,YAAY+f,WAC/CpiB,KAAKqN,MACHI,EAAAhD,eAAe+3E,oEACf1H,EAAgB/vE,MAChBsiB,EAAOjb,cAETpS,KAAKsvE,YAAcuT,EAAex1D,EAAQpO,KAAOvR,EAAAkH,KAAKG,KAC/CpV,EAAO8rC,eAETzrC,KAAKu1E,qBAA6BloD,EAAQ2lD,EAAW6P,GAVZljF,EAAO8rC,cAYzD,KAAKmmB,EAAA9gD,YAAY8N,MACf,IAAIy1D,EAA0BhnD,EAAQgnD,gBACtC,OACUhnD,EAAQ/N,GAAG9R,EAAAnL,YAAY+f,WAE7BgI,EAAKg6C,eAAe9kD,GAAG9R,EAAAnL,YAAYugB,cACnCyxD,EASGr0E,KAAK+iF,oBAA2B11D,EACrC2lD,EAEAhzE,KAAKs0E,kBAAkBlqE,OAAOm4E,GAAiBviF,KAAK0U,QAAQI,WAC5D+tE,IAVA7iF,KAAKqN,MACHI,EAAAhD,eAAe+3E,oEACf1H,EAAgB/vE,MAAesiB,EAAQjb,cAElCzS,EAAO8rC,eASlB,KAAKmmB,EAAA9gD,YAAYyN,mBACXve,KAAK6vE,oBAAoBr7D,IAAIw+D,KAAYA,EAAYhzE,KAAKgjF,gBAAgBhQ,EAAW5oD,IACzF,IAAI3L,EAAsC4O,EAAQ5O,gBAClD,IAAKA,EAKH,OAJAze,KAAKqN,MACHI,EAAAhD,eAAe+3E,oEACf1H,EAAgB/vE,MAAOsiB,EAAOjb,cAEzBzS,EAAO8rC,cAGhB,KADI/f,EAAiB1rB,KAAKqS,SAAS4L,gBAAgBQ,EAAiB,KAAM5U,EAAA23D,UAAW5zD,EAAAwyD,WAAWO,SAC3E,OAAOhhE,EAAO8rC,cAEnC,IAAKo3C,EAAK,OAAO7iF,KAAK0gF,eAAeh1D,EAAgB,CAAEsnD,GAAa8H,GAEpE,IAAIt8D,EAAkBpU,OAA2BijB,EAAQ7O,iBAEzD,KADIiN,EAAiBzrB,KAAKqS,SAAS4L,gBAAgBO,EAAiB,KAAM3U,EAAA23D,UAAW5zD,EAAAwyD,WAAWO,SAC3E,OAAOhhE,EAAO8rC,cACnC,IACIw3C,GADA73C,EAAa3f,EAAexX,UAAUm3B,YACRqoB,eAClC,OAAO9zD,EAAO6pC,MAAM,KAAM,CACxBxpC,KAAK0gF,eAAeh1D,EAAgB,CAAEsnD,GAAa8H,GACnD96E,KAAK0gF,eAAej1D,EAAgB,KAAMqvD,IACzCmI,GAEL,KAAKrxB,EAAA9gD,YAAY4N,SAEf,IAAIgN,EACJ,GAFI1rB,KAAK6vE,oBAAoBr7D,IAAIw+D,KAAYA,EAAYhzE,KAAKgjF,gBAAgBhQ,EAAW5oD,MACrFsB,EAA4B2B,EAAQ3B,gBAMtC,OAJA1rB,KAAKqN,MACHI,EAAAhD,eAAe+3E,oEACf1H,EAAgB/vE,MAAOsiB,EAAOjb,cAEzBzS,EAAO8rC,cAGhB,IAAKo3C,EAAK,CACR,IAAIK,EAAWljF,KAAKs0E,kBAAkBlqE,OAAOm4E,GAAiBviF,KAAK0U,QAAQI,WAC3E,OAAO9U,KAAK0gF,eAAeh1D,EAAgB,CAAEw3D,EAAUlQ,GAAa8H,GAKlEmI,GADA73C,GADA3f,EAAiBrhB,OAAkBijB,EAAQ5B,iBACfxX,UAAUm3B,YACRqoB,eAFlC,IAAIhoC,EAGA03D,EAAWnjF,KAAKs0E,kBAAkBlqE,OAAOm4E,GAAiBviF,KAAK0U,QAAQI,WAEvEqmE,EADY/wD,EAAK2+C,oBAAoB39B,GACVxjB,MAC/B,OAAOjoB,EAAO6pC,MAAM,KAAM,CACxBxpC,KAAK0gF,eAAeh1D,EAAgB,CAClC/rB,EAAO6nC,UAAU2zC,EAAgBgI,GACjCnQ,GACC8H,GACH96E,KAAK0gF,eAAej1D,EAAgB,CAClC9rB,EAAO2nC,UAAU6zC,EAAgB8H,IAChCnI,IACFmI,GAEL,KAAKrxB,EAAA9gD,YAAY+N,MAEf,GADI7e,KAAK6vE,oBAAoBr7D,IAAIw+D,KAAYA,EAAYhzE,KAAKgjF,gBAAgBhQ,EAAW5oD,IACrFw4D,EAAiB,CACnB,IAAIH,EAAcr4D,EAAK9K,GAAE,OACrB0jD,EAAqB31C,EAAQF,eAAeykC,EAAArkD,aAAasB,YAAa4zE,GAC1E,IAAKzf,EAKH,OAJAhjE,KAAKqN,MACHI,EAAAhD,eAAew3D,qCACf6Y,EAAgB/vE,MAAOsiB,EAAOjb,cAEzBzS,EAAO8rC,cAEhB,IAAIi3C,EAAqBr1D,EAAQF,eAAeykC,EAAArkD,aAAauB,YAAa2zE,GAC1E,IAAKC,EAMH,OALA1iF,KAAKqN,MACHI,EAAAhD,eAAek4E,+CACf7H,EAAgB/vE,MAAOsiB,EAAOjb,cAEhCpS,KAAKsvE,YAAcuT,EAAM7f,EAAW/uD,UAAUm3B,WAAa19B,EAAAkH,KAAKG,KACzDpV,EAAO8rC,cAEhB,IAAIonB,EAAqBxlC,EAAQpO,KAE7BmkE,GADAD,EAAWnjF,KAAKs0E,kBAAkBlqE,OAAOm4E,GAAiBviF,KAAK0U,QAAQI,WACzD9U,KAAKs0E,kBAAkBsO,EAAiBl1E,EAAAkH,KAAKxR,IAAG,IAClE,GAAIy/E,EAAK,CACP,IAAIQ,EAAkBj5D,EAAKi+C,aAAaxV,GACpCywB,EAAmBl5D,EAAK2+C,oBAAoB/oE,KAAKsvE,aACjDlkC,EAAa43B,EAAW/uD,UAAUm3B,WAEtC,OADAhhB,EAAK0+C,cAAcua,GACZ1jF,EAAO6pC,MAAM,KAAM,CACxBxpC,KAAK0gF,eAAegC,EAAY,CAC9B/iF,EAAO6nC,UAAU67C,EAAgBz7D,MAAOu7D,GACxCxjF,EAAO6nC,UAAU87C,EAAiB17D,MAAOw7D,GACzCpQ,GACC8H,GACH96E,KAAK0gF,eAAe1d,EAAY,CAC9BrjE,EAAO2nC,UAAU+7C,EAAgBz7D,MAAOy7D,EAAgBpkE,KAAKw0C,gBAC7D9zD,EAAO2nC,UAAUg8C,EAAiB17D,MAAO07D,EAAiBrkE,KAAKw0C,iBAC9DqnB,IACF1vC,EAAWqoB,gBAEd,OAAOzzD,KAAK0gF,eAAegC,EAAY,CACrCS,EACAC,EACApQ,GACC8H,IAUX,OAJA96E,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACfy5D,EAAgB/vE,OAEXpL,EAAO8rC,eAIR0jC,EAAAltE,UAAA6gF,oBAAR,SAEEh5D,EAEAkpD,EAEA6P,GAEA,IAAI5jE,EAAO6K,EAAM7K,KACjB7U,OAAO6U,GAAQvR,EAAAkH,KAAKG,MACpB,IAAIqV,EAAOpqB,KAAK0wE,YACZ7mD,EAAaC,EAAMlC,MAQvB,GANI3I,EAAKK,GAAE,OACL8K,EAAKwgD,UAAUoI,EAAW/zD,GAAOmL,EAAKw+C,aAAa/+C,EAAYhc,EAAAw5D,WAAW9C,SACzEn6C,EAAKo+C,eAAe3+C,EAAYhc,EAAAw5D,WAAW9C,UAElDn6C,EAAKw+C,aAAa/+C,EAAYhc,EAAAw5D,WAAW8C,WAErClrD,EAAK2zD,UAAW,CAClB,IAAIjzE,EAASK,KAAKL,OACdmzE,EAAa7zD,EAAKw0C,eAEtB,OAAIrpC,EAAKs/C,eAAe7/C,EAAYhc,EAAAw5D,WAAW2T,cACzCh7E,KAAK6vE,oBAAoBr7D,IAAIw+D,IAC/BA,EAAYhzE,KAAKujF,mBACf5jF,EAAO2nC,UAAUzd,EAAYipD,GAC7BE,GAEE6P,GACF7iF,KAAKsvE,YAAcrwD,EACZtf,EAAO6nC,UAAU3d,EAAYmpD,KAEpChzE,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAOypC,UAAUvf,EAAYmpD,MAGtCA,EAAYhzE,KAAKizE,kBACftzE,EAAO2nC,UAAUzd,EAAYipD,GAC7BE,GAEE6P,GACF7iF,KAAKsvE,YAAcrwD,EACZtf,EAAO6nC,UAAU3d,EAAYmpD,KAEpChzE,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAOypC,UAAUvf,EAAYmpD,MAIxC5oD,EAAKo+C,eAAe3+C,EAAYhc,EAAAw5D,WAAW2C,wBAC3C5/C,EAAKw+C,aAAa/+C,EAAYhc,EAAAw5D,WAAWwB,UACpC7oE,KAAK6vE,oBAAoBr7D,IAAIw+D,KAAYA,EAAYhzE,KAAK6yE,WAAWG,IACtE6P,GACF7iF,KAAKsvE,YAAcrwD,EACZtf,EAAO6nC,UAAU3d,EAAYmpD,KAEpChzE,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAOypC,UAAUvf,EAAYmpD,KAQxC,OAJI/zD,EAAKK,GAAG,MACL8K,EAAKihD,YAAY2H,EAAW/zD,GAC5BmL,EAAKo+C,eAAe3+C,EAAYhc,EAAAw5D,WAAWiE,SADRlhD,EAAKw+C,aAAa/+C,EAAYhc,EAAAw5D,WAAWiE,UAG/EuX,GACF7iF,KAAKsvE,YAAcrwD,EACZjf,KAAKL,OAAO6nC,UAAU3d,EAAYmpD,KAEzChzE,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjB/U,KAAKL,OAAOypC,UAAUvf,EAAYmpD,KAMvC7D,EAAAltE,UAAAszE,qBAAR,SAEEh2D,EAEAyzD,EAEA6P,GAEA,IAAIljF,EAASK,KAAKL,OACdsf,EAAOM,EAAON,KAClB7U,OAAO6U,GAAQvR,EAAAkH,KAAKG,MACpB,IAAI+9D,EAAa7zD,EAAKw0C,eAEtB,OAAIx0C,EAAK2zD,UACH5yE,KAAK6vE,oBAAoBr7D,IAAIw+D,GAC3B6P,GACF7iF,KAAKsvE,YAAcrwD,EACZtf,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAO2pC,WAAW/pB,EAAOnN,aACvBpS,KAAKujF,mBACH5jF,EAAO+nC,WAAWnoB,EAAOnN,aAAc0gE,GACvCE,IAGJrzE,EAAO+nC,WAAWnoB,EAAOnN,aAAc0gE,IACtCA,KAEH9yE,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAO2pC,WAAW/pB,EAAOnN,aAC9BpS,KAAKujF,mBACH5jF,EAAO+nC,WAAWnoB,EAAOnN,aAAc0gE,GACvCE,KAKF6P,GACF7iF,KAAKsvE,YAAcrwD,EACZtf,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAO2pC,WAAW/pB,EAAOnN,aACvBpS,KAAKizE,kBACHtzE,EAAO+nC,WAAWnoB,EAAOnN,aAAc0gE,GACvCE,IAGJrzE,EAAO+nC,WAAWnoB,EAAOnN,aAAc0gE,IACtCA,KAEH9yE,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAO2pC,WAAW/pB,EAAOnN,aAC9BpS,KAAKizE,kBACHtzE,EAAO+nC,WAAWnoB,EAAOnN,aAAc0gE,GACvCE,MAMRA,EAAYhzE,KAAKo9E,uBAAuBpK,EAAW/zD,GAC/C4jE,GACF7iF,KAAKsvE,YAAcrwD,EACZtf,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAO2pC,WAAW/pB,EAAOnN,aAAc4gE,GACvCrzE,EAAO+nC,WAAWnoB,EAAOnN,aAAc0gE,IACtCA,KAEH9yE,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAO2pC,WAAW/pB,EAAOnN,aAC9B4gE,MAOR7D,EAAAltE,UAAA8gF,oBAAA,SAEEp1D,EAEAqlD,EAEAmQ,EAEAN,GAEA,IAAIljF,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YACZ/J,EAAYh5C,EAAM1O,KAClBukE,EAAkB7c,EAAUlT,eAChCrpD,OAAOujB,EAAMzZ,OAAOuC,MAAQm7C,EAAA9gD,YAAY+N,OACxC,IAAIkL,EAAmB4D,EAAMzZ,OAAQ+K,KACjCwkE,EAAiB15D,EAAS0pC,eAE9B,GAAIkT,EAAUiM,WAAa7oD,EAAS6oD,UAAW,CAC7C,IAAI8Q,EAAWt5D,EAAKi+C,aAAat+C,GACjC,GAAI/pB,KAAK6vE,oBAAoBr7D,IAAIw+D,GAAY,CAC3C,GAAI6P,EAAK,CACP,IAAIc,EAAYv5D,EAAK2+C,oBAAoBpC,GAKzC,OAJKv8C,EAAKihD,YAAY2H,EAAWrM,IAAYv8C,EAAKw+C,aAAa+a,EAAU/7D,MAAO/Z,EAAAw5D,WAAWiE,SACvFlhD,EAAKwgD,UAAUoI,EAAWrM,IAAYv8C,EAAKw+C,aAAa+a,EAAU/7D,MAAO/Z,EAAAw5D,WAAW9C,SACxFn6C,EAAK0+C,cAAc4a,GACnB1jF,KAAKsvE,YAAc3I,EACZhnE,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAO6mC,MAAMmgC,EAAUzU,SACrBvyD,EAAO6nC,UAAUk8C,EAAS97D,MAAOu7D,GACjCnjF,KAAKujF,mBACH5jF,EAAOioC,KAAK++B,EAAUzU,SAAUyU,EAAUrnD,GAAE,GAC1C3f,EAAO2nC,UAAUo8C,EAAS97D,MAAO67D,GACjCD,EAAiB71D,EAAMrC,cAEzB3rB,EAAO6nC,UAAUm8C,EAAU/7D,MAAOorD,IAEpCwQ,EAAiB71D,EAAMrC,cAEzB3rB,EAAO2nC,UAAUq8C,EAAU/7D,MAAO47D,IACjCA,GAIH,OAFAp5D,EAAK0+C,cAAc4a,GACnB1jF,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAO6mC,MAAMmgC,EAAUzU,SAC5BvyD,EAAO6nC,UAAUk8C,EAAS97D,MAAOu7D,GACjCnjF,KAAKujF,mBACH5jF,EAAOioC,KAAK++B,EAAUzU,SAAUyU,EAAUrnD,GAAE,GAC1C3f,EAAO2nC,UAAUo8C,EAAS97D,MAAO67D,GACjCD,EAAiB71D,EAAMrC,cAEzB0nD,GAEFwQ,EAAiB71D,EAAMrC,cAI3B,GAAIu3D,EAAK,CACHc,EAAYv5D,EAAK2+C,oBAAoBpC,GAKzC,OAJKv8C,EAAKihD,YAAY2H,EAAWrM,IAAYv8C,EAAKw+C,aAAa+a,EAAU/7D,MAAO/Z,EAAAw5D,WAAWiE,SACvFlhD,EAAKwgD,UAAUoI,EAAWrM,IAAYv8C,EAAKw+C,aAAa+a,EAAU/7D,MAAO/Z,EAAAw5D,WAAW9C,SACxFn6C,EAAK0+C,cAAc4a,GACnB1jF,KAAKsvE,YAAc3I,EACZhnE,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAO6mC,MAAMmgC,EAAUzU,SACrBvyD,EAAO6nC,UAAUk8C,EAAS97D,MAAOu7D,GACjCnjF,KAAKizE,kBACHtzE,EAAOioC,KAAK++B,EAAUzU,SAAUyU,EAAUrnD,GAAE,GAC1C3f,EAAO2nC,UAAUo8C,EAAS97D,MAAO67D,GACjCD,EAAiB71D,EAAMrC,cAEzB3rB,EAAO6nC,UAAUm8C,EAAU/7D,MAAOorD,IAEpCwQ,EAAiB71D,EAAMrC,cAEzB3rB,EAAO2nC,UAAUq8C,EAAU/7D,MAAO47D,IACjCA,GAIH,OAFAp5D,EAAK0+C,cAAc4a,GACnB1jF,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAO6mC,MAAMmgC,EAAUzU,SAC5BvyD,EAAO6nC,UAAUk8C,EAAS97D,MAAOu7D,GACjCnjF,KAAKizE,kBACHtzE,EAAOioC,KAAK++B,EAAUzU,SAAUyU,EAAUrnD,GAAE,GAC1C3f,EAAO2nC,UAAUo8C,EAAS97D,MAAO67D,GACjCD,EAAiB71D,EAAMrC,cAEzB0nD,GAEFwQ,EAAiB71D,EAAMrC,cAK7B,GAAIu3D,EAAK,CACHc,EAAYv5D,EAAK2+C,oBAAoBpC,GAIzC,OAHKv8C,EAAKihD,YAAY2H,EAAWrM,IAAYv8C,EAAKw+C,aAAa+a,EAAU/7D,MAAO/Z,EAAAw5D,WAAWiE,SACvFlhD,EAAKwgD,UAAUoI,EAAWrM,IAAYv8C,EAAKw+C,aAAa+a,EAAU/7D,MAAO/Z,EAAAw5D,WAAW9C,SACxFvkE,KAAKsvE,YAAc3I,EACZhnE,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAO6mC,MAAMmgC,EAAUzU,SACrBixB,EACAxjF,EAAO6nC,UAAUm8C,EAAU/7D,MAAOorD,GAClCwQ,EAAiB71D,EAAMrC,cAEzB3rB,EAAO2nC,UAAUq8C,EAAU/7D,MAAO47D,IACjCA,GAGH,OADAxjF,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAO6mC,MAAMmgC,EAAUzU,SAC5BixB,EACAnQ,EACAwQ,EAAiB71D,EAAMrC,eAO/B6jD,EAAAltE,UAAAq6E,sBAAA,SAEEtyC,EAEA44B,EAEAmY,GAGA,IAAIp7E,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YAGhB,GAAI1mC,EAAWA,WAAWvzB,MAAQ9I,EAAA+I,SAASusC,MAAO,CAChD,IAAI2gC,EAAO5jF,KAAK0wE,YACZtM,EAAiBwf,EAAKxf,eAC1B,IAAKA,EAAe9kD,GAAG9R,EAAAnL,YAAYugB,aAKjC,OAJA5iB,KAAKqN,MACHI,EAAAhD,eAAeo5E,8FACf75C,EAAWj/B,OAENpL,EAAO8rC,cAGhB,IAAI94B,EAAgBvI,OAAOg6D,EAAelwD,QAAS9J,OAAOuI,EAAc8D,MAAQm7C,EAAA9gD,YAAY+N,OAC5F,IAAIilE,EAAoB15E,OAAeuI,EAAeuZ,MAClDw4C,EAAYt6D,OAAOw5E,EAAKjf,YAAYn3D,EAAAxK,cAAcoC,QAClD2tE,EAAiB/yE,KAAK0U,QAAQq+D,eAO9BgR,EAAU/jF,KAAKgkF,kBACjBhkF,KAAKikF,kBAAkBH,EAAmB95C,GAC1CA,EAAWhnB,UACXgnB,EACArqC,EAAOyqC,GACLzqC,EAAO2nC,UAAUo9B,EAAU98C,MAAOmrD,GAClCpzE,EAAO2nC,UAAUo9B,EAAU98C,MAAOmrD,GAClC/yE,KAAK6yE,WACH7yE,KAAKm2E,eAAsBxjE,KAE9B,IAGHvI,OAAOpK,KAAK6vE,oBAAoBr7D,IAAIuvE,IACpC,IAAIpO,EAAyB,CAC3Bh2E,EAAOypC,UAAUs7B,EAAU98C,MAAOm8D,IAKpC,OAHA/jF,KAAKo2E,wBAA+BzjE,EAAegjE,GAG/CiO,EAAKhiE,MACP,QAGA5hB,KAAKqN,MACHI,EAAAhD,eAAey5E,kFACfl6C,EAAWj/B,OAENpL,EAAO8rC,gBAEhBm4C,EAAKzxE,IAAI,KACTnS,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACjBpV,EAAO6pC,MAAM,KAAMmsC,IAI5B,IAGI1hE,EACAkwE,EAJA92D,EAASrtB,KAAKqS,SAASywD,kBAAkB94B,EAAWA,WAAY5f,GACpE,IAAKiD,EAAQ,OAAO1tB,EAAO8rC,cAI3B,OAAQpe,EAAO5W,MAGb,KAAKm7C,EAAA9gD,YAAYkN,mBACf,IAAI/b,EAA+BorB,EAC/BpB,EAAgB+d,EAAW/d,cAG/B,GAAIhqB,EAAUoZ,aAAau2C,EAAA7gD,eAAeqE,SACxC,OAAOpV,KAAKokF,6BAA6BniF,EAAW+nC,EAAY44B,GAGlE,IAAIr6C,EAA4B,KAGhC,GAAI0D,EAAe,CACjB,IAAKhqB,EAAUqd,GAAG9R,EAAAnL,YAAY8S,SAK5B,OAJAnV,KAAKqN,MACHI,EAAAhD,eAAe42D,sBACfr3B,EAAWA,WAAWj/B,MAAO9I,EAAUmQ,cAElCzS,EAAO8rC,cAEhBljB,EAAWvoB,KAAKqS,SAAS4yD,iCACvBhjE,EACAgqB,EACA7B,EAAKg6C,eAAelwD,OACpBrK,EAAA23D,QAAqBp3C,EAAK3B,yBAC1BuhB,OAIG,IAAI/nC,EAAUqd,GAAG9R,EAAAnL,YAAY8S,SAAU,CAI5C,IAHA,IAAIkvE,EAAgB,IAAIj9E,IACpB2lB,EAAqB3iB,OAAOnI,EAAU8qB,oBACtCk5C,EAAoBl5C,EAAmB5gB,OAClC9L,EAAI,EAAGA,EAAI4lE,IAAqB5lE,EACvCgkF,EAAclyE,IAAI4a,EAAmB1sB,GAAGO,KAAKqL,KAAM,MAGrD,IAAI20D,EAAiB3+D,EAAU0jE,iBAAiBpiB,WAC5CoR,EAAgBiM,EAAez0D,OAC/Bm4E,EAAgBt6C,EAAWhnB,UAC3B6rC,EAAey1B,EAAcn4E,OAC7Bo4E,EAAgB,IAAIt9E,MAAqB4nD,GAC7C,IAASxuD,EAAI,EAAGA,EAAIs0D,IAAiBt0D,EAAG,CACtC,IAAI6gE,EAAWN,EAAevgE,GAAG4e,KAC7BulE,EAAetjB,EAASzqD,MAAQ9I,EAAA+I,SAASk3C,WAA8BsT,EAAUtgE,KAAKqX,KAEtF,KADgBipD,EAAUtgE,KAAK0S,WAAWrH,KAE1Cw4E,EAAqBpkF,EAAIwuD,EACzBy1B,EAAcjkF,GACdugE,EAAevgE,GAAG+mB,YACtB,IAAKq9D,EAKH,OAJAzkF,KAAKqN,MACHI,EAAAhD,eAAekZ,+BACfqmB,EAAWj/B,MAAO4pD,EAAcjpD,SAAS,IAAKmjD,EAAanjD,SAAS,KAE/D/L,EAAO8rC,cAEhB,GAAqB,OAAjB+4C,GAAyBH,EAAc7vE,IAAIgwE,GAAe,CAE5D,GADIE,EAAeL,EAAcnjF,IAAIsjF,GACnB,CAChBD,EAAclkF,GAAKL,KAAKs0E,kBAAkBmQ,EAAoBC,GAC9D,IAAIpF,OAAU,EACd,KAAMA,EAAa5xE,EAAAkH,KAAK2+C,kBAAkBmxB,EAAc1kF,KAAKsvE,aAAa,OAClEgQ,EAAa5xE,EAAAkH,KAAK2+C,kBAAkBmxB,EAAc1kF,KAAKsvE,aAAa,IAKxE,OAJAtvE,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACf3T,EAAevgE,GAAG4e,KAAKlU,MAAO/K,KAAKsvE,YAAY5jE,WAAYg5E,EAAah5E,YAEnE/L,EAAO8rC,cAGlBi5C,EAAepF,OAEfiF,EAAclkF,GAAKL,KAAKs0E,kBAAkBmQ,EAAoB/2E,EAAAkH,KAAK89C,MACnEgyB,EAAe1kF,KAAKsvE,YAGtB+U,EAAclyE,IAAIqyE,EAAcE,OAC3B,CACL,IAAIC,EAAe3kF,KAAKqS,SAASmuD,YAC/BI,EAAevgE,GAAG4e,KAClBmL,EAAKg6C,eACLh6C,EAAK3B,yBAEP,IAAKk8D,EAAc,OAAOhlF,EAAO8rC,cACjC84C,EAAclkF,GAAKL,KAAKs0E,kBAAkBmQ,EAAoBE,EAAY,IAG9E,IAAI3e,EAAwB,IAAI/+D,MAAYg/D,GAC5C,IAAS5lE,EAAI,EAAGA,EAAI4lE,IAAqB5lE,EAAG,CAC1C,IAAIqkF,EAAet6E,OAAOi6E,EAAcnjF,IAAI6rB,EAAmB1sB,GAAGO,KAAKqL,OACvE+5D,EAAsB3lE,GAAKqkF,EAO7B,OALAn8D,EAAWvoB,KAAKqS,SAAS4L,gBACvBhc,EACA+jE,EACAn8D,EAAA23D,QAAqBp3C,EAAK3B,2BAGrBzoB,KAAK0gF,eAAen4D,EAAUg8D,EAAev6C,EAAY44B,GAAkBl1D,EAAAkH,KAAKG,MADjE/U,KAAKL,OAAO8rC,cAQlCljB,EAAWvoB,KAAKqS,SAAS4L,gBAAgBhc,EAAW,MAEtD,IAAKsmB,EAAU,OAAOvoB,KAAKL,OAAO8rC,cAGlC,IAAI03C,EAA0B,EAK9B,OAJI56D,EAASjJ,GAAG9R,EAAAnL,YAAY4iB,YAC1Bk+D,EAAWnjF,KAAKs0E,kBAAkBlqE,OAAOpK,KAAKqS,SAASiuD,uBAAwBtgE,KAAK0U,QAAQI,YAGvF9U,KAAKgkF,kBACVz7D,EACAyhB,EAAWhnB,UACXgnB,EACAm5C,EACApI,GAKJ,KAAKnpB,EAAA9gD,YAAY+W,MACf,GAAI5T,EAAoBoZ,EAAQpO,KAAKmzC,mBAAoB,CAErD+xB,EADU92D,EAAQ/N,GAAG9R,EAAAnL,YAAYilB,SACtB3nB,EAAOyD,IAAI8sC,QAAgB7iB,EAAQhG,uBAEnC1nB,EAAO2nC,UAAkBja,EAAQzF,MAAOiqC,EAAAriC,WAAWppB,KAEhE,MAMA,OAJApG,KAAKqN,MACHI,EAAAhD,eAAey6D,uGACfl7B,EAAWj/B,MAAesiB,EAAQpO,KAAKvT,YAElC/L,EAAO8rC,cAGlB,KAAKmmB,EAAA9gD,YAAYmQ,OACf,GAAIhN,EAAqBoZ,EAAQpO,KAAKmzC,mBAAoB,CACxD+xB,EAAWxkF,EAAO+nC,WAAoBra,EAAQjb,aAAuBib,EAAQpO,KAAKw0C,gBAClF,MAMA,OAJAzzD,KAAKqN,MACHI,EAAAhD,eAAey6D,uGACfl7B,EAAWj/B,MAAgBsiB,EAAQpO,KAAKvT,YAEnC/L,EAAO8rC,cAGlB,KAAKmmB,EAAA9gD,YAAY8N,MACf,IAAIK,EAAeoO,EAAQpO,KAC3B,GAAIhL,EAAYgL,EAAKmzC,mBAAoB,CACvC,IAAImwB,EAAiBn4E,OAAOpK,KAAKqS,SAASiuD,uBACtC6iB,EAAWnjF,KAAKs0E,kBAAkBiO,EAAgBviF,KAAK0U,QAAQI,WACnEqvE,EAAWxkF,EAAOioC,KAChB,GACA,EACAu7C,EACAtxB,EAAAriC,WAAWppB,IACHinB,EAAQ/B,cAElB,MAMA,OAJAtrB,KAAKqN,MACHI,EAAAhD,eAAey6D,uGACfl7B,EAAWj/B,MAAOkU,EAAKvT,YAElB/L,EAAO8rC,cAGlB,KAAKmmB,EAAA9gD,YAAYma,gBACfhX,EAA6BoZ,EAAQpZ,UACrCkwE,EAAWnkF,KAAKs0E,kBAAkBtqC,EAAWA,WAA6B3c,EAAQpO,KAAI,GACtF,MAGF,KAAK2yC,EAAA9gD,YAAYyN,mBACf,IAAIC,EAAkBpU,OAA2BijB,EAAQ7O,iBAEzD,KADIiN,EAAiBzrB,KAAKqS,SAAS4L,gBAAgBO,EAAiB,OAC/C,OAAO7e,EAAO8rC,cAGnC,GAFA04C,EAAWnkF,KAAKgkF,kBAAkBv4D,EAAgB,GAAIue,EAAWA,cACjE/1B,EAAYjU,KAAKsvE,YAAYld,oBAM3B,OAJApyD,KAAKqN,MACHI,EAAAhD,eAAey6D,uGACfl7B,EAAWj/B,MAAO/K,KAAKsvE,YAAY5jE,YAE9B/L,EAAO8rC,cAEhB,MAEF,KAAKmmB,EAAA9gD,YAAY4N,SACf,IAAI+M,EAAiBrhB,OAAkBijB,EAAQ5B,gBAK/C,GAJA04D,EAAWnkF,KAAKgkF,kBAAkBv4D,EAAgB,GAAIue,EAAWA,WAC/DhqC,KAAKs0E,kBAAkBlqE,OAAOpK,KAAKqS,SAASiuD,uBAAwBtgE,KAAK0U,QAAQI,cAEnFb,EAAYjU,KAAKsvE,YAAYld,oBAM3B,OAJApyD,KAAKqN,MACHI,EAAAhD,eAAey6D,uGACfl7B,EAAWj/B,MAAO/K,KAAKsvE,YAAY5jE,YAE9B/L,EAAO8rC,cAEhB,MAIF,QAKE,OAJAzrC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAENpL,EAAO8rC,cAGlB,OAAOzrC,KAAK4kF,oBACV3wE,EACAkwE,EACAn6C,EAAWhnB,UACXgnB,EACA,EACA44B,GAAkBl1D,EAAAkH,KAAKG,OAInBo6D,EAAAltE,UAAAmiF,6BAAR,SACEniF,EACA+nC,EACA44B,GAEA,IAAI32C,EAA+B,KAI/Bc,EAAqB9qB,EAAU8qB,mBAC/Bo0C,EAAoBn3B,EAAW/d,cAC/B+d,EAAW/d,gBACRhqB,EAAUqd,GAAG9R,EAAAnL,YAAY8S,UAC5BnV,KAAKqN,MACHI,EAAAhD,eAAe42D,sBACfr3B,EAAWj/B,MAAO9I,EAAUmQ,cAGhC6Z,EAAgBjsB,KAAKqS,SAASwvD,qBAC5Bz3D,OAAO2iB,GACPo0C,EACAnhE,KAAK0wE,YAAYtM,eAAelwD,OAChCrK,EAAA23D,QAAqBxhE,KAAK0wE,YAAYjoD,yBACtCuhB,IAKJ,IAAIpD,EAAOy5B,EAAAwkB,YACT7kF,KACAiC,EACAgqB,EACA+d,EAAWhnB,UACX4/C,EACA54B,GAEF,OAAKpD,IACH5mC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,gBASvB0jC,EAAAltE,UAAA6iF,mBAAA,SACE7wE,EACA46C,EACAk2B,EACAhf,GAKA,GAAIgf,IAAwB,MADb9wE,EAAU8V,UAMvB,OAJA/pB,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf0kD,EAAWh7D,QAEN,EAIT,IAAIqpD,EAAUngD,EAAUmgD,QACxB,GAAIA,EAKF,OAJAp0D,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf0kD,EAAWh7D,QAEN,EAGT,IAAIi6E,EAAU/wE,EAAUkgD,mBACpBvkB,EAAU37B,EAAU+V,eAAe7d,OAGvC,OAAI0iD,EAAem2B,GACjBhlF,KAAKqN,MACH23E,EAAUp1C,EACNniC,EAAAhD,eAAew6E,wCACfx3E,EAAAhD,eAAekZ,+BACnBoiD,EAAWh7D,MAAOi6E,EAAQt5E,WAAYmjD,EAAanjD,aAE9C,KAILmjD,EAAejf,IAAYwkB,KAC7Bp0D,KAAKqN,MACHI,EAAAhD,eAAekZ,+BACfoiD,EAAWh7D,MAAO6kC,EAAQlkC,WAAYmjD,EAAanjD,aAE9C,IAOXyjE,EAAAltE,UAAA+hF,kBAAA,SACEz7D,EACA28D,EACAnf,EACAof,EACApK,QADA,IAAAoK,MAAA,QACA,IAAApK,MAAA,GAEA,IAAIlsB,EAAeq2B,EAAoB/4E,OACnC8H,EAAYsU,EAAStU,UACzB,IAAKjU,KAAK8kF,mBACR7wE,EACA46C,EACW,GAAXs2B,EACApf,GAGA,OADA/lE,KAAKsvE,YAAcr7D,EAAUm3B,WACtBprC,KAAKL,OAAO8rC,cAIrB,GAAIljB,EAASlN,aAAau2C,EAAA7gD,eAAesR,QAAS,CAEhD,GADAjY,QAAQme,EAASjJ,GAAG9R,EAAAnL,YAAY81E,cAC5Bn4E,KAAKovE,uBAAuB7oD,SAASgC,GAKlC,CACLvoB,KAAKovE,uBAAuB1iE,KAAK6b,GACjC,IAAI68D,EAAiBnxE,EAAU+V,eAC/B5f,OAAOykD,GAAgBu2B,EAAej5E,QAGtC,IADA,IAAI+3C,EAAO,IAAIj9C,MAAqB4nD,GAC3BxuD,EAAI,EAAGA,EAAIwuD,IAAgBxuD,EAClC6jD,EAAK7jD,GAAKL,KAAKs0E,kBAAkB4Q,EAAoB7kF,GAAI+kF,EAAe/kF,GACtE,IAIJ,IAAIumC,EAAO5mC,KAAKqlF,eAAe98D,EAAU27B,EAAMihC,EAAkD,IAA7B,EAAXpK,IASzD,OARI/6E,KAAKsvE,YAAYsD,YACF,GAAXmI,EAGJ/6E,KAAK6vE,oBAAoB76D,IAAI4xB,GAF7BA,EAAO5mC,KAAKgjF,gBAAgBp8C,EAAM5mC,KAAK0wE,cAK3C1wE,KAAKovE,uBAAuB3G,MACrB7hC,EAzBP5mC,KAAKmN,QACHM,EAAAhD,eAAe66E,yCACfvf,EAAWh7D,MAAOwd,EAASnW,cA4BjC,IAAImzE,EAAuBJ,EAAUt2B,EAAe,EAAIA,EACpD1nB,EAAW,IAAIlgC,MAAqBs+E,GACpC39D,EAAQ,EACRu9D,IACFh+C,EAAS,GAAKg+C,EACdv9D,EAAQ,GAEV,IAAIoC,EAAiB/V,EAAU+V,eAC/B,IAAS3pB,EAAI,EAAGA,EAAIwuD,IAAgBxuD,IAAKunB,EACvCuf,EAASvf,GAAS5nB,KAAKs0E,kBAAkB4Q,EAAoB7kF,GAAI2pB,EAAe3pB,GAAE,GAKpF,GADA+J,OAAOwd,GAAS29D,GACZtxE,EAAUm3B,WAAWwnC,UAAW,CAClC,GAAe,EAAXmI,EAEF,OAAO/6E,KAAK0gF,eAAen4D,EAAU4e,EAAU4+B,GAAY,GACtD,GAAe,GAAXgV,EAAuC,CAE5Cn0C,EAAO5mC,KAAK0gF,eAAen4D,EAAU4e,EAAU4+B,GAAY,GAAO,GAEtE,OADA/lE,KAAK6vE,oBAAoB76D,IAAI4xB,GACtBA,EAEP,OAAO5mC,KAAK0gF,eAAen4D,EAAU4e,EAAU4+B,GAAY,GAAO,GAGtE,OAAO/lE,KAAK0gF,eAAen4D,EAAU4e,EAAU4+B,EACJ,IAA7B,EAAXgV,KAIL5L,EAAAltE,UAAAojF,eAAA,SACE98D,EACA4e,EACAg+C,EACAK,QADA,IAAAL,MAAA,QACA,IAAAK,OAAA,GAeA,IAbA,IAAI7lF,EAASK,KAAKL,OACdkvD,EAAe1nB,EAAWA,EAASh7B,OAAS,EAC5C8H,EAAYsU,EAAStU,UACrB+V,EAAiB/V,EAAU+V,eAC3B2qC,EAAgB3qC,EAAe7d,OAG/B4nE,EAAe/zE,KAAK0wE,YACpBtmD,EAAOvc,EAAAwc,KAAK49C,aAAa8L,EAAanM,eAAgBr/C,GACtDP,EAAO,GACPy9D,EAAa,IAAIt+E,IAGZ9G,EAAIwuD,EAAe,EAAGxuD,GAAK,IAAKA,EAAG,CAM1C,IAAIqlF,EAAYv+C,EAAU9mC,GACtBslF,EAAY37D,EAAe3pB,GAC3BulF,EAAgBx7D,EAAK6+C,eAAeh1D,EAAUkW,iBAAiB9pB,GAAIslF,EAAWF,GAClF53E,EAAA0gE,eAAemX,EAAWD,GAErB1R,EAAa1I,YAAYqa,EAAWC,IAAYv7D,EAAKw+C,aAAagd,EAAch+D,MAAO/Z,EAAAw5D,WAAWiE,SACnGlhD,EAAKwgD,UAAU8a,EAAWC,IAAYv7D,EAAKw+C,aAAagd,EAAch+D,MAAO/Z,EAAAw5D,WAAW9C,SAExFohB,EAAU/S,YACP5yE,KAAK6vE,oBAAoBr7D,IAAIkxE,KAAYA,EAAY1lF,KAAK6yE,WAAW6S,IAC1Et7D,EAAKw+C,aAAagd,EAAch+D,MAAO/Z,EAAAw5D,WAAWwB,WAEpD7gD,EAAKmpD,QACHxxE,EAAOypC,UAAUw8C,EAAch+D,MAAO89D,IAG1C,GAAIP,EAAS,CACX,IAAIxyE,EAAgBvI,OAAOme,EAASrU,QAAS9J,OAAOuI,EAAc8D,MAAQm7C,EAAA9gD,YAAY+N,OACtF,IAAIkL,EAAW3f,OAAOme,EAAStU,UAAU8V,UACrC26C,EAAYt6C,EAAK6+C,eAAez7D,EAAAxK,cAAcoC,MAAO2kB,EAAU07D,GAEnEz9D,EAAKmpD,QACHxxE,EAAOypC,UAAUs7B,EAAU98C,MAAOu9D,IAEpC,IAAIU,EAAuBlzE,EAAeuZ,KACtC25D,GAAcz7D,EAAK++C,eAAe37D,EAAAxK,cAAcqC,OAAQwgF,EAAa5mE,KAAMylD,EAAU98C,YAEzFxd,QAAQme,EAAStU,UAAU8V,UAK7B/pB,KAAK0wE,YAActmD,EACnB,IAAS/pB,EAAIwuD,EAAcxuD,EAAIs0D,IAAiBt0D,EAAG,CACjD,IAAIylF,EAAW97D,EAAe3pB,GAC1B8zE,EAAWn0E,KAAKs0E,kBAClBlqE,OAAOme,EAAStmB,UAAU0jE,iBAAiBpiB,WAAWljD,GAAG+mB,aACzD0+D,EAAQ,GAGNF,EAAgBx7D,EAAK6+C,eAAeh1D,EAAUkW,iBAAiB9pB,GAAIylF,GAClE17D,EAAKihD,YAAY8I,EAAU2R,IAAW17D,EAAKw+C,aAAagd,EAAch+D,MAAO/Z,EAAAw5D,WAAWiE,SACzFlhD,EAAKwgD,UAAUuJ,EAAU2R,IAAW17D,EAAKw+C,aAAagd,EAAch+D,MAAO/Z,EAAAw5D,WAAW9C,SACtFuhB,EAASlT,WACXxoD,EAAKw+C,aAAagd,EAAch+D,MAAO/Z,EAAAw5D,WAAWwB,UAClD7gD,EAAKtb,KACH/M,EAAOypC,UAAUw8C,EAAch+D,MAC7B5nB,KAAK6yE,WAAWsB,MAIpBnsD,EAAKtb,KACH/M,EAAOypC,UAAUw8C,EAAch+D,MAAOusD,IAM5Cn0E,KAAK01E,oBAAoBntD,EAAUP,GAG9BoC,EAAK9K,GAAE,OACVtf,KAAKg2E,oBAAoB5rD,EAAMpC,GAC/BhoB,KAAKi0E,mBAAmB7pD,EAAMpC,IAEhCoC,EAAKk/C,mBACL,IAAIl+B,EAAahhB,EAAKghB,WACtBprC,KAAK0wE,YAAcqD,EAGnB,IAAIntC,EAAOjnC,EAAO6pC,MAAMpf,EAAK49C,kBAAmBhgD,EAAMojB,EAAWqoB,gBAQjE,OAPAzzD,KAAKsvE,YAAclkC,EACfA,EAAWwnC,WACT4S,IACF5+C,EAAO5mC,KAAKmiF,YAAYv7C,GACxB5mC,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,MAGrB6xB,GAITuoC,EAAAltE,UAAAmwE,iBAAA,SAAiBjtD,GAQf,IAAI6D,EAAa7D,EAAS6D,WAC1B,GAAIA,EAAY,OAAOA,EAEvB,IAAI+8D,EAAoB5gE,EAASlR,UAC7B+xE,EAAe7gE,EAAS/S,aACxB6zE,EAAyBF,EAAkB/7D,eAC3Ck8D,EAAgC/gE,EAASljB,UAAU0jE,iBAAiBpiB,WACpEnY,EAAa26C,EAAkB36C,WAC/BrhB,EAAWg8D,EAAkBh8D,SAC7BuF,EAAanK,EAAS7F,GAAG9R,EAAAnL,YAAY4iB,UAGrCkhE,EAAeJ,EAAkB5xB,mBACjCiyB,EAAcD,EACdE,EAAeJ,EAAuB95E,OACtCm6E,EAAcD,EACd/2D,MACA82D,IACAE,GAEJ,IAAIC,EAAcn8E,OAAOk8E,EAAcF,GAEnCI,EAAoB,IAAIv/E,MAAqBm/E,GAC7CK,EAAe,EAGf9mF,EAASK,KAAKL,OACd2vB,IACFk3D,EAAkB,GAAK7mF,EAAO2nC,UAAU,EAAGtnC,KAAK0U,QAAQq+D,gBACxD0T,EAAe,GAIjB,IAAK,IAAIpmF,EAAI,EAAGA,EAAI8lF,IAAgB9lF,IAAKomF,EACvCD,EAAkBC,GAAgB9mF,EAAO2nC,UAAUm/C,EAAcR,EAAuB5lF,GAAGozD,gBAE7FrpD,OAAOq8E,GAAgBL,GAGvB,IAAIM,EAAsB,IAAIh5E,EAAA0Y,UAAU6/D,EAAwB76C,EAAYrhB,GAC5E28D,EAAoBvyB,mBAAqBkyB,EACzCK,EAAoBxyB,eAAiB6xB,EAAkB7xB,gBACvDlrC,EAAa,IAAI4oC,EAAAx9C,SACf+Q,EAASvkB,KAAO,cAChBukB,EAASljB,UACTykF,EACAvhE,EAASsD,0BAEAtW,IAAIgT,EAASnS,MAAQxF,EAAAnL,YAAY81E,WAAa3qE,EAAAnL,YAAYiwE,UACrEntD,EAAS6D,WAAaA,EAItB,IAAI+qD,EAAe/zE,KAAK0wE,YACpBtmD,EAAOpB,EAAWoB,KACtBpqB,KAAK0wE,YAActmD,EAGnB,IAAI6gB,EAAWs7C,EAAc,EACzBx7C,EAAQ,IAAI9jC,MAAcgkC,GAC1B07C,EAAM,KAAOJ,EAAY76E,SAAS,IACtC,IAASrL,EAAI,EAAGA,EAAI4qC,IAAY5qC,EAAG,CACjC,IAAIopC,EAAQppC,EAAEqL,SAAS,IAAMi7E,EAC7B57C,EAAM1qC,GAAKopC,EAEb,IAAIzhB,EAAOroB,EAAO6pC,MAAMuB,EAAM,GAAI,CAChCprC,EAAO6pC,MAAM,aAAc,CACzB7pC,EAAOmrC,OAAOC,EAAO,aAEnBo7C,EACIxmF,EAAOmnC,OACL+qB,EAAAz5B,SAAS8nD,OACTvgF,EAAO+nC,WAAW24B,EAAA2E,eAAe4hB,KAAM/0B,EAAAriC,WAAWppB,KAClDzG,EAAOyD,IAAI+iF,IAEbxmF,EAAO+nC,WAAW24B,EAAA2E,eAAe4hB,KAAM/0B,EAAAriC,WAAWppB,QAG1DzG,EAAO8rC,gBAET,IAASprC,EAAI,EAAGA,EAAIkmF,IAAelmF,IAAKomF,EAAc,CACpD,IAAIxnE,EAAOgnE,EAAuBE,EAAe9lF,GAC7CkU,EAAc2xE,EAA8BC,EAAe9lF,GAC3D+mB,EAAc7S,EAAY6S,YAC1B+sD,OAAQ,EACR/sD,EACF+sD,EAAWx0E,EAAOypC,UAAUq9C,EAC1BzmF,KAAKs0E,kBACHltD,EACAnI,EAAI,KAKRjf,KAAKqN,MACHI,EAAAhD,eAAeo8E,4CACftyE,EAAYxJ,OAEdopE,EAAWx0E,EAAO8rC,eAEpBzjB,EAAOroB,EAAO6pC,MAAMuB,EAAM1qC,EAAI,GAAI,CAChC2nB,EACAmsD,IAEFqS,EAAkBC,GAAgB9mF,EAAO2nC,UAAUm/C,EAAcxnE,EAAKw0C,gBAExErpD,OAAOq8E,GAAgBH,GAEvB,IAAI3Q,EAAyB,CAAE3tD,GAC3B+7D,EAAUpkF,EAAOa,KAAKwlF,EAAcQ,EAAmBp7C,EAAWqoB,gBAClEroB,GAAc19B,EAAAkH,KAAKG,KACrB/U,KAAK6hF,6BAA6Bz3D,EAAM25D,EAAS34C,EAAYuqC,IAE7DA,EAAMjpE,KAAKq3E,GACX/jF,KAAKg2E,oBAAoB5rD,EAAMurD,IAEjCvrD,EAAKk/C,mBACLtpE,KAAK0wE,YAAcqD,EAEnB,IAAI3C,EAAUzxE,EAAO2tC,YACnBtkB,EAAW5W,aACXpS,KAAKqxE,mBACHqV,EAAoB18D,eACpBohB,EACArhB,GAEFrc,EAAAmmD,mBAAmB7qC,EAAWJ,kBAC9BjpB,EAAO6pC,MAAM,KAAMmsC,EAAOvqC,EAAWqoB,iBAGvC,OADAzqC,EAAWyB,SAAS9qB,EAAQyxE,GACrBpoD,GAIDmmD,EAAAltE,UAAA6kF,cAAR,WACE,IAAK9mF,KAAK0vE,QAAS,CACjB,IAAI/vE,EAASK,KAAKL,OAClBK,KAAK0vE,QAAU/vE,EAAOstC,UACpBozB,EAAA2E,eAAe4hB,KACf/0B,EAAAriC,WAAWppB,KACX,EACAzG,EAAOyD,IAAI,IAGf,OAAOi9D,EAAA2E,eAAe4hB,MAIhBzX,EAAAltE,UAAAowE,cAAR,WACE,IAAKryE,KAAK2vE,QAAS,CACjB,IAAIhwE,EAASK,KAAKL,OAClBK,KAAK2vE,QAAUhwE,EAAO2tC,YAAY+yB,EAAA2E,eAAe+hB,QAC/C/mF,KAAKqxE,mBAAmB,CAAE3jE,EAAAkH,KAAKnR,KAAOiK,EAAAkH,KAAKG,MAC3C,KACApV,EAAO2pC,WAAWtpC,KAAK8mF,gBACrBnnF,EAAO2nC,UAAU,EAAGuqB,EAAAriC,WAAWppB,OAGnCzG,EAAOouC,kBAAkBsyB,EAAA2E,eAAe+hB,QAAS,aAEnD,OAAO1mB,EAAA2E,eAAe+hB,SAMxB5X,EAAAltE,UAAA4wE,WAAA,SAAWjsC,GACT,IAAI7pB,EAAiB/c,KAAKwlB,QAAQzI,eAElC,OADA/c,KAAKw1E,gBAAgBz4D,GACd/c,KAAKL,OAAOa,KAAKuc,EAAe3K,aAAc,CAAEw0B,GAAQ5mC,KAAK0U,QAAQq+D,iBAI9E5D,EAAAltE,UAAAgxE,kBAAA,SAAkB+T,EAAwBC,GAKxC,IAAItnF,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YACZ57D,EAAY9U,KAAK0U,QAAQI,UACzBi+D,EAAiB/yE,KAAK0U,QAAQq+D,eAC9BmU,EAAQ98D,EAAKi+C,aAAavzD,EAAWjH,EAAA0gE,eAAeyY,IACpDG,EAAQ/8D,EAAK2+C,oBAAoBj0D,GAErC,OADAsV,EAAK0+C,cAAcoe,GACZvnF,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAOyqC,GACLzqC,EAAOmnC,OAAOisC,GAAkBlhB,EAAAriC,WAAWnpB,IAAMwrD,EAAAz5B,SAASgzC,MAAQvZ,EAAAz5B,SAAS+yC,MACzExrE,EAAO6nC,UAAU0/C,EAAMt/D,MAAOq/D,GAC9BtnF,EAAO6nC,UAAU2/C,EAAMv/D,MAAOo/D,IAEhCrnF,EAAO6pC,MAAM,KAAM,CACjB7pC,EAAOoqC,KACL/pC,KAAK6yE,WAAWlzE,EAAO2nC,UAAU4/C,EAAMt/D,MAAOmrD,KAEhD/yE,KAAKmiF,YAAYxiF,EAAO2nC,UAAU6/C,EAAMv/D,MAAOmrD,OAGnDpzE,EAAO2nC,UAAU4/C,EAAMt/D,MAAOmrD,IAC7BA,IAIL5D,EAAAltE,UAAAshF,mBAAA,SAAmByD,EAAwBC,GAGzC,IAAItnF,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YACZ57D,EAAY9U,KAAK0U,QAAQI,UACzBi+D,EAAiB/yE,KAAK0U,QAAQq+D,eAC9BmD,EAAO9rD,EAAK2+C,oBAAoBj0D,EAAWjH,EAAA0gE,eAAeyY,IAC9D,OAAOrnF,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAOypC,UAAU8sC,EAAKtuD,MAAOq/D,GAC7BjnF,KAAKmiF,YAAY6E,GACjBrnF,EAAO2nC,UAAU4uC,EAAKtuD,MAAOmrD,IAC5BA,IAIL5D,EAAAltE,UAAAkgF,YAAA,SAAYv7C,GACV,IAAI5pB,EAAkBhd,KAAKwlB,QAAQxI,gBAEnC,OADAhd,KAAKw1E,gBAAgBx4D,GACdhd,KAAKL,OAAOa,KAAKwc,EAAgB5K,aAAc,CAAEw0B,GAAQirB,EAAAriC,WAAWyY,OAI7EknC,EAAAltE,UAAA+gF,gBAAA,SAAgBp8C,EAAqBxc,GAEnC,YAFmC,IAAAA,MAAapqB,KAAK0wE,aAE9C1wE,KAAKL,OAAO6nC,UAAUpd,EAAKs+C,oBAAoB1oE,KAAK0U,QAAQI,WAAW8S,MAAOgf,IAIvFuoC,EAAAltE,UAAAmlF,gBAAA,SAAgBxgD,EAAqBxc,GAInC,OAAQynC,EAAA9a,gBAAgBnQ,IACtB,KAAKirB,EAAApiC,aAAa0vB,SAChB,GAAI0S,EAAAla,WAAW/Q,GAAO,CACpB,IAAIhf,EAAQiqC,EAAAta,iBAAiB3Q,GAC7B,GAAIxc,EAAKs/C,eAAe9hD,EAAO/Z,EAAAw5D,WAAW2T,cAKxC,OADA5wD,EAAKo+C,eAAe5gD,EAAO/Z,EAAAw5D,WAAW2T,cAC/BpzD,EAGX,MAEF,KAAKiqC,EAAApiC,aAAa8uB,MAChB,GAA2B,OAAvBsT,EAAA9Y,aAAanS,GAAgB,CAC/B,IAAI+0C,EAAQ9pB,EAAA5Y,mBAAmBrS,GAC/B,GAAI+0C,EACF,OAAO37E,KAAKonF,gBAAgBv1B,EAAA1Y,cAAcvS,EAAM+0C,EAAQ,GAAIvxD,IAMpE,OAAQ,GAQV+kD,EAAAltE,UAAAggF,gBAAA,SAAgBr7C,EAAqBygD,EAAqBC,GAKxD,OADYtnF,KAAKonF,gBAAgBxgD,EAAMygD,GAEnCrnF,KAAKgjF,gBAAgBp8C,EAAM0gD,GAC3BtnF,KAAKgjF,gBAAgBhjF,KAAK6yE,WAAWjsC,GAAO0gD,IAIlDnY,EAAAltE,UAAA+zE,oBAAA,SAAoB5rD,EAAYurD,EAAwB4R,gBAAA,IAAAA,OAAA,GACtD,IAAI7f,EAAet9C,EAAKs9C,aACxB,GAAIA,EAAc,CAChB,IAAI/nE,EAASK,KAAKL,WAClB,IAAkB,IAAA+mB,EAAA3O,EAAA2vD,EAAanqD,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAE,CAApC,IAAI6R,EAAK1L,EAAA9c,MACZ,GAAIwoB,EAAMxK,GAAG9R,EAAAnL,YAAYsmE,QAAS,CAChC,IAAI9+C,EAAaC,EAAMlC,MACnBwC,EAAKs/C,eAAe7/C,EAAYhc,EAAAw5D,WAAW2T,gBACzCuM,GAAYn9D,EAAKo+C,eAAe3+C,EAAYhc,EAAAw5D,WAAW2T,cAC3DrF,EAAMjpE,KACJ1M,KAAKmiF,YACHxiF,EAAO2nC,UAAUzd,EAAYC,EAAM7K,KAAKw0C,yHAUtD0b,EAAAltE,UAAA4/E,6BAAA,SACEz3D,EACA4oD,EACAjnB,EACA4pB,EACA4R,QADA,IAAA5R,MAAA,WACA,IAAA4R,OAAA,GAEK5R,IAAOA,EAAQ,IAAI1uE,OACxB0uE,EAAMjpE,KACJ1M,KAAKL,OAAO6qC,OAEd,IAAIg9C,EAAe7R,EAAMxpE,OAEzB,GADAnM,KAAKg2E,oBAAoB5rD,EAAMurD,EAAO4R,GAClC5R,EAAMxpE,OAASq7E,EAAc,CAC/B,IAAI1U,EAAa/mB,EAAU0H,eACvByiB,EAAO9rD,EAAK2+C,oBAAoBhd,GAC/B3hC,EAAKihD,YAAY2H,EAAWjnB,IAAY3hC,EAAKw+C,aAAasN,EAAKtuD,MAAO/Z,EAAAw5D,WAAWiE,SAClFlhD,EAAKwgD,UAAUoI,EAAWjnB,IAAY3hC,EAAKw+C,aAAasN,EAAKtuD,MAAO/Z,EAAAw5D,WAAW9C,SACnF,IAAI5kE,EAASK,KAAKL,OAKlB,OAJAg2E,EAAM6R,EAAe,GAAK7nF,EAAOypC,UAAU8sC,EAAKtuD,MAAOorD,GACvD2C,EAAMjpE,KACJ/M,EAAO2nC,UAAU4uC,EAAKtuD,MAAOkrD,IAExBnzE,EAAO6pC,MAAM,KAAMmsC,EAAO7C,GAC5B,OAAI6C,EAAMxpE,OAAS,GACxBwpE,EAAM6R,EAAe,GAAKxU,EACnBhzE,KAAKL,OAAO6pC,MAAM,KAAMmsC,EAAO5pB,EAAU0H,iBAE3Cuf,GAIT7D,EAAAltE,UAAAgyE,mBAAA,SAAmB7pD,EAAYurD,WACzBh2E,EAASK,KAAKL,OAClB,GAAIyqB,EAAK9K,GAAE,OAA4B,CAIrC,IADA,IAAIpL,OAAM,EACHA,EAASkW,EAAKlW,QAAQkW,EAAOlW,EACpClU,KAAKg2E,oBAAoB5rD,EAAMurD,GAAO,YAEtC,IAAkB,IAAAjvD,EAAA3O,EAAAqS,EAAKw9C,eAAej/C,eAAavK,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAE,CAAhD,IAAI6R,EAAK1L,EAAA9c,MACRuoB,EAAaC,EAAMlC,MACnBwC,EAAKs/C,eAAe7/C,EAAYhc,EAAAw5D,WAAW2T,gBAC7C5wD,EAAKo+C,eAAe3+C,EAAYhc,EAAAw5D,WAAW2T,cAC3CrF,EAAMjpE,KACJ1M,KAAKmiF,YACHxiF,EAAO2nC,UAAUzd,EAAYC,EAAM7K,KAAKw0C,uHAWpD0b,EAAAltE,UAAAy+E,eAAA,SACEn4D,EACA4e,EACA4+B,EACAyf,EAEAiC,QAFA,IAAAjC,OAAA,QAEA,IAAAiC,OAAA,GAEIl/D,EAASlN,aAAau2C,EAAA7gD,eAAesR,SACvCriB,KAAKmN,QACHM,EAAAhD,eAAei9E,6DACf3hB,EAAWh7D,MAAOwd,EAASnW,cAG/B,IAAIu1E,EAAcxgD,EAAWA,EAASh7B,OAAS,EAC3C0iD,EAAe84B,EAEfvB,EADe79D,EAAStU,UAAUkgD,mBAElCkyB,EAAe99D,EAAStU,UAAU+V,eAAe7d,OACjDm6E,EAAcD,EACd99D,EAASjJ,GAAG9R,EAAAnL,YAAY4iB,cACxBmhE,IACAE,IACAz3B,GAEJzkD,OAAOu9E,GAAevB,GAEtB,IAAIzmF,EAASK,KAAKL,OAClB,IAAKK,KAAKw1E,gBAAgBjtD,GAAW,OAAO5oB,EAAO8rC,cACnD,IAAIL,EAAa7iB,EAAStU,UAAUm3B,WAChCw8C,EAAer/D,EAASjJ,GAAG9R,EAAAnL,YAAYqyE,eAG3C,GAAIiT,EAAcrB,EAAa,CACxBn/C,KACHA,EAAW,IAAIlgC,MAAMq/E,IACZn6E,OAAS,GAEpB,IAAI6d,EAAiBzB,EAAStU,UAAU+V,eACpC42C,EAAiBr4C,EAAStmB,UAAU0jE,iBAAiBpiB,WACzDn5C,OAAOw2D,EAAez0D,QAAU6d,EAAe7d,QAE/C,IADA,IAAI07E,GAA0B,EACrBxnF,EAAIwuD,EAAcxuD,EAAIgmF,IAAgBhmF,EAAG,CAChD,IAAI+mB,EAAcw5C,EAAevgE,GAAG+mB,YACpC,GAAIA,EAAa,CACf,GAAIzZ,EAAA20C,oBAAoBl7B,EAAY3Q,MAAO,CACzC0wB,EAASz6B,KAAK1M,KAAKs0E,kBACL1T,EAAevgE,GAAG+mB,YAC9B4C,EAAe3pB,GAAE,IAGnB,SAEF,IAAIyd,EAAW9d,KAAKqS,SAASywD,kBAAkB17C,EAAamB,EAAS6B,KAAMJ,EAAe3pB,IAC1F,GAAIyd,GACEA,EAASrH,MAAQm7C,EAAA9gD,YAAYmQ,OAAQ,CACvC,IAAIuqD,EAAiB1tD,EACrB,GAAI9d,KAAKozE,cAAc5H,GAAS,CAC1BA,EAAOlsD,GAAG9R,EAAAnL,YAAYilB,SACxB6f,EAASz6B,KACP1M,KAAKm8E,sBAAsB3Q,EAAQxhD,EAAe3pB,GAAE,IAGtD8mC,EAASz6B,KACP1M,KAAKm9E,kBACHx9E,EAAO+nC,WAAW8jC,EAAOp5D,aAAco5D,EAAOvsD,KAAKw0C,gBACnD+X,EAAOvsD,KAAM+K,EAAe3pB,IAAI,GAAO,EAAO+mB,IAIpD,WAKR+f,EAASz6B,KAAKsd,EAAe3pB,GAAGqzD,aAAa/zD,IAC7CkoF,GAA0B,EAE5B,IAAKA,IACED,EAAc,CACjB,IAAIziE,EAAWoD,EAEf,GADAA,EAAWvoB,KAAKoyE,iBAAiB7pD,IAC5BvoB,KAAKw1E,gBAAgBjtD,GAAW,OAAO5oB,EAAO8rC,cACnDljB,EAAS6B,KAAKpX,MAAQmS,EAASiF,KAAKpX,MACpC,IAAIiwE,EAAmB73C,EAAWqoB,eAC9Bq0B,EAAOnoF,EAAOa,KAAK+nB,EAASnW,aAAc+0B,EAAU87C,GAYxD,OAXAjjF,KAAKsvE,YAAclkC,EACfA,EAAWwnC,YACT4S,GACFsC,EAAO9nF,KAAKmiF,YAAY2F,GACxB9nF,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,MACd0yE,EAGVznF,KAAK6vE,oBAAoB76D,IAAI8yE,GAF7BA,EAAO9nF,KAAKgjF,gBAAgB8E,IAKzBnoF,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAO2pC,WAAWtpC,KAAK8mF,gBAAiBnnF,EAAOyD,IAAIyrD,IACnDi5B,GACC9nF,KAAKsvE,YAAY7b,iBAQ1B,IAAI7sB,EAAOjnC,EAAOa,KAAK+nB,EAASnW,aAAc+0B,EAAUiE,EAAWqoB,gBAUnE,OATAzzD,KAAKsvE,YAAclkC,EACfA,EAAWwnC,YACT4S,GACF5+C,EAAO5mC,KAAKmiF,YAAYv7C,GACxB5mC,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,MACd0yE,IACV7gD,EAAO5mC,KAAKgjF,gBAAgBp8C,KAGzBA,GAITuoC,EAAAltE,UAAA2iF,oBAAA,SACE3wE,EACAkwE,EACAe,EACAnf,EACAof,EACAK,QADA,IAAAL,MAAA,QACA,IAAAK,OAAA,GAEA,IAAI32B,EAAeq2B,EAAoB/4E,OAEvC,IAAKnM,KAAK8kF,mBACR7wE,EACA46C,EACW,GAAXs2B,EACApf,GAEA,OAAO/lE,KAAKL,OAAO8rC,cAGrB,IAAI85C,EAAuBJ,EAAUt2B,EAAe,EAAIA,EACpD1nB,EAAW,IAAIlgC,MAAqBs+E,GACpC39D,EAAQ,EACRu9D,IACFh+C,EAAS,GAAKg+C,EACdv9D,EAAQ,GAGV,IADA,IAAIoC,EAAiB/V,EAAU+V,eACtB3pB,EAAI,EAAGA,EAAIwuD,IAAgBxuD,IAAKunB,EACvCuf,EAASvf,GAAS5nB,KAAKs0E,kBAAkB4Q,EAAoB7kF,GAAI2pB,EAAe3pB,GAAE,GAKpF,OADA+J,OAAOwd,GAAS29D,GACTvlF,KAAK+nF,iBAAiB9zE,EAAWkwE,EAAUh9C,EAAUq+C,IAI9DrW,EAAAltE,UAAA8lF,iBAAA,SACE9zE,EACAkwE,EACAh9C,EACAq+C,QADA,IAAAr+C,MAAA,WACA,IAAAq+C,OAAA,GAEA,IAAImC,EAAcxgD,EAAWA,EAASh7B,OAAS,EAC3C0iD,EAAe84B,EAEfvB,EADenyE,EAAUkgD,mBAEzBkyB,EAAepyE,EAAU+V,eAAe7d,OACxCm6E,EAAcD,EACdpyE,EAAU8V,aACVq8D,IACAE,IACAz3B,GAEJzkD,OAAOu9E,GAAevB,GAEtBpmF,KAAKqxE,mBAAmBp9D,EAAU+V,eAAgB/V,EAAUm3B,WAAYn3B,EAAU8V,UAClF,IAAIpqB,EAASK,KAAKL,OAGlB,GAAIgoF,EAAcrB,EAAa,CACxBn/C,KACHA,EAAW,IAAIlgC,MAAMq/E,IACZn6E,OAAS,GAGpB,IADA,IAAI6d,EAAiB/V,EAAU+V,eACtB3pB,EAAIwuD,EAAcxuD,EAAIgmF,IAAgBhmF,EAC7C8mC,EAASz6B,KAAKsd,EAAe3pB,GAAGqzD,aAAa/zD,IAIjD,IAAIyrC,EAAan3B,EAAUm3B,WACvBxE,EAAOjnC,EAAO2rC,cAAc64C,EAAUh9C,EAAUlzB,EAAUiX,qBAU9D,OATAlrB,KAAKsvE,YAAclkC,EACfA,EAAWwnC,YACT4S,GACF5+C,EAAO5mC,KAAKmiF,YAAYv7C,GACxB5mC,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,MAExB6xB,EAAO5mC,KAAKgjF,gBAAgBp8C,IAGzBjnC,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAO2pC,WAAWtpC,KAAK8mF,gBACrBnnF,EAAOyD,IAAIyrD,IAEbjoB,GACC5mC,KAAKsvE,YAAY7b,iBAGtB0b,EAAAltE,UAAAs6E,uBAAA,SACEvyC,EACA44B,EACAmY,GAKA,IAHA,IAAIl1B,EAAc7b,EAAW6b,YACzBmiC,EAAiBniC,EAAY15C,OAC7B87E,EAAQ,IAAIhhF,MAAqB+gF,KAC5B3nF,EAAI,EAAGA,EAAI2nF,IAAkB3nF,EACpC4nF,EAAM5nF,GAAKL,KAAKs0E,kBAAkBzuB,EAAYxlD,GAAIqN,EAAAkH,KAAKG,KACrD,GAIJ,OADAkzE,EAAMD,GAAkBhoF,KAAKs0E,kBAAkBzuB,EAAYmiC,GAAiBplB,EAAgBmY,GACrF/6E,KAAKL,OAAO6pC,MAAM,KAAMy+C,EAAOjoF,KAAKsvE,YAAY7b,iBAGzD0b,EAAAltE,UAAAu6E,+BAAA,SACExyC,EACA44B,EACAmY,GAEA,IAAI1tD,EAASrtB,KAAKqS,SAAS8wD,+BACzBn5B,EACAhqC,KAAK0wE,YACL9N,GAEF,IAAKv1C,EAAQ,OAAOrtB,KAAKL,OAAO8rC,cAChC,OAAQpe,EAAO5W,MACb,KAAKm7C,EAAA9gD,YAAY+N,MACf,IAAImkD,EAAqB31C,EAAQF,eAAeykC,EAAArkD,aAAasB,YAAa7O,KAAK0wE,YAAYpxD,GAAE,QAC7F,IAAK0jD,EAKH,OAJAhjE,KAAKqN,MACHI,EAAAhD,eAAew3D,qCACfj4B,EAAWA,WAAWj/B,MAAesiB,EAAQjb,cAExCpS,KAAKL,OAAO8rC,cAErB,IAAI05C,EAAUnlF,KAAKs0E,kBAAkBtqC,EAAWA,WAAoB3c,EAAQpO,KAAI,GAGhF,OAAOjf,KAAKgkF,kBAAkBhhB,EAAY,CACxCh5B,EAAWmc,mBACVnc,EAAYm7C,EAASpK,GAO5B,OAJA/6E,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,eAGrB0jC,EAAAltE,UAAAw6E,0BAAA,SACEzyC,EACAk+C,EACAnN,GAEA,IAAIxmE,EAAcy1B,EAAWz1B,YAAYw8C,QACzC3mD,QAAQmK,EAAYuS,gBACpB,IAUIyB,EAVA6B,EAAOpqB,KAAK0wE,YACZtM,EAAiBh6C,EAAKg6C,eACtBniE,EAAY,IAAI2vD,EAAAv9C,kBAClBE,EAAY3T,KAAKqL,KAAKE,OAClBoI,EAAY3T,KAAKqL,KACjB,cAAgBm4D,EAAel7C,mBAAmBxd,SAAS,IAC/D04D,EACA7vD,EACAq9C,EAAA7gD,eAAekC,MAGbwV,EAA0B5e,EAAA23D,QAAQp3C,EAAK3B,yBAI3C,GAAIy/D,EAAqB,CACvB,IAAIxiB,EAAgBzjE,EAAU0jE,iBAC1B/E,EAAiB8E,EAAcniB,WAC/B4kC,EAAuBvnB,EAAez0D,OAGtC6d,EAAiBk+D,EAAoBl+D,eACrC2qC,EAAgB3qC,EAAe7d,OACnC,GAAIg8E,EAAuBxzB,EAKzB,OAJA30D,KAAKqN,MACHI,EAAAhD,eAAekZ,+BACfqmB,EAAWj/B,MAAO4pD,EAAcjpD,WAAYy8E,EAAqBz8E,YAE5D1L,KAAKL,OAAO8rC,cAKrB,IADA,IAAIyoB,EAAiB,IAAIjtD,MAAckhF,GAC9B9nF,EAAI,EAAGA,EAAI8nF,IAAwB9nF,EAAG,CAC7C,IAAIwgE,EAAgBD,EAAevgE,GAEnC,GADA6zD,EAAe7zD,GAAKwgE,EAAcjgE,KAAKqL,MAClC0B,EAAAgkD,cAAckP,EAAc5hD,MAAO,CAMtC,KALIikD,EAAeljE,KAAKqS,SAASmuD,YAC/BK,EAAc5hD,KACdmlD,EAAelwD,OACfuU,IAEiB,OAAOzoB,KAAKL,OAAO8rC,cACtC,IAAKzhB,EAAe3pB,GAAGizD,uBAAuB4P,GAK5C,OAJAljE,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACf1T,EAAc91D,MAAOif,EAAe3pB,GAAGqL,WAAYw3D,EAAax3D,YAE3D1L,KAAKL,OAAO8rC,eAOzB,IAAIL,EAAa88C,EAAoB98C,WACrC,IAAKz9B,EAAAgkD,cAAc+T,EAAct6B,YAAa,CAM5C,KALI83B,EAAeljE,KAAKqS,SAASmuD,YAC/BkF,EAAct6B,WACdg5B,EAAelwD,OACfuU,IAEiB,OAAOzoB,KAAKL,OAAO8rC,cACtC,GACEL,GAAc19B,EAAAkH,KAAKG,KACfmuD,GAAgBx1D,EAAAkH,KAAKG,MACpBmuD,EAAa5P,uBAAuBloB,GAMzC,OAJAprC,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACf7O,EAAct6B,WAAWrgC,MAAOm4D,EAAax3D,WAAY0/B,EAAW1/B,YAE/D1L,KAAKL,OAAO8rC,cAKvB,IAAI1hB,EAAWm+D,EAAoBn+D,SAC/Bq+D,EAAe1iB,EAAcliB,iBACjC,GAAI4kC,EAAc,CAChB,IAAKr+D,EAKH,OAJA/pB,KAAKqN,MACHI,EAAAhD,eAAem6D,+CACfwjB,EAAar9E,OAER/K,KAAKL,OAAO8rC,cAErB,IAAIy3B,EAKJ,KALIA,EAAeljE,KAAKqS,SAASmuD,YAC/B4nB,EACAhkB,EAAelwD,OACfuU,IAEiB,OAAOzoB,KAAKL,OAAO8rC,cACtC,IAAK1hB,EAASupC,uBAAuB4P,GAKnC,OAJAljE,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACf6T,EAAar9E,MAAOgf,EAASre,WAAYw3D,EAAax3D,YAEjD1L,KAAKL,OAAO8rC,cAIvB,IAAIx3B,EAAY,IAAIvG,EAAA0Y,UAAU4D,EAAgBohB,EAAYrhB,GAS1D,GARA9V,EAAUkgD,mBAAqBQ,EAC/B1gD,EAAUigD,eAAiBA,EAC3B3rC,EAAW,IAAIqpC,EAAAx9C,SACbnS,EAAUrB,KACVqB,EACAgS,EACAwU,IAEGzoB,KAAKw1E,gBAAgBjtD,GAAW,OAAOvoB,KAAKL,OAAO8rC,cACxDzrC,KAAKsvE,YAAc4Y,EAAoBjpE,SAGlC,CAML,KALAsJ,EAAWvoB,KAAKszE,kCACdrxE,EACA,GACAwmB,IAEa,OAAOzoB,KAAKL,OAAO8rC,cAClCzrC,KAAKsvE,YAAc/mD,EAAStU,UAAUgL,KAGxC,IAAI2I,EAAQ5nB,KAAKk4E,yBAAyB3vD,GAC1C,OAAOX,EAAQ,EACX5nB,KAAKL,OAAO8rC,cACZzrC,KAAKL,OAAOyD,IAAIwkB,IAIdunD,EAAAltE,UAAAomF,4BAAR,SAAoCr+C,GAClC,IAAI3lB,EAAe2lB,EAAWj/B,MAAMY,OAAO0Y,aACvChT,EAAcrR,KAAKwlB,QAAQnU,YAC/BjH,OAAOiH,EAAYmD,IAAI6P,IACHhT,EAAYnQ,IAAImjB,GACjB/E,GAAG9R,EAAAnL,YAAYiwE,WAChCtyE,KAAK2zE,kBAAkBtvD,EAAc2lB,IASzCmlC,EAAAltE,UAAAy6E,4BAAA,SACE1yC,EACA44B,EACAmY,GAEA,IAAIp7E,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YACZtM,EAAiBh6C,EAAKg6C,eAG1B,OAAQp6B,EAAWvzB,MACjB,KAAK9I,EAAA+I,SAAS6rC,KACZ,IAAI7tC,EAAU1U,KAAK0U,QAInB,OAHKkuD,EAAej0C,iBAClB3uB,KAAKsvE,YAAc56D,EAAQI,WAEtBJ,EAAQc,SACX7V,EAAO0D,IAAI,GACX1D,EAAOyD,IAAI,GAEjB,KAAKuK,EAAA+I,SAAS8rC,KAEZ,OADAxiD,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACjBjE,EAAOyD,IAAI,GAEpB,KAAKuK,EAAA+I,SAAS+rC,MAEZ,OADAziD,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACjBjE,EAAOyD,IAAI,GAEpB,KAAKuK,EAAA+I,SAAS44C,KACZ,GAAI8U,EAAe9kD,GAAG9R,EAAAnL,YAAY4iB,UAAW,CAC3C,IAAIy/C,EAAYt6D,OAAOggB,EAAKu6C,YAAYn3D,EAAAxK,cAAcoC,QAClDuN,EAAgBvI,OAAOg6D,EAAelwD,QAAS9J,OAAOuI,EAAc8D,MAAQm7C,EAAA9gD,YAAY+N,OAC5F,IAAIk0D,EAAiB/yE,KAAK0U,QAAQq+D,eAClC,GAAI3O,EAAe9kD,GAAG9R,EAAAnL,YAAYugB,eAC3BwH,EAAK9K,GAAE,IAAuB,CACjC8K,EAAKjY,IAAG,IAOR,IAAIwjE,EAAyB,CAC3Bh2E,EAAOyqC,GACLzqC,EAAO+mC,MAAMqsC,GAAkBlhB,EAAAriC,WAAWnpB,IAAMwrD,EAAA/+B,QAAQi4C,OAASlZ,EAAA/+B,QAAQg4C,OACvEnrE,EAAO2nC,UAAUo9B,EAAU98C,MAAOmrD,IAEpCpzE,EAAOypC,UAAUs7B,EAAU98C,MACzB5nB,KAAK6yE,WACH7yE,KAAKm2E,eAAsBxjE,OAUnC,OALA3S,KAAKo2E,wBAA+BzjE,EAAegjE,GACnDA,EAAMjpE,KACJ/M,EAAO2nC,UAAUo9B,EAAU98C,MAAOmrD,IAEpC/yE,KAAKsvE,YAAc5K,EAAUzlD,KACtBtf,EAAO6pC,MAAM,KAAMmsC,EAAO5C,GAIrC,IAAIhpD,EAAW3f,OAAOg6D,EAAenwD,UAAU8V,UAE/C,OADA/pB,KAAKsvE,YAAcvlD,EACZpqB,EAAO2nC,UAAUo9B,EAAU98C,MAAOmC,EAAS0pC,gBAOpD,OALAzzD,KAAKqN,MACHI,EAAAhD,eAAem6D,+CACf56B,EAAWj/B,OAEb/K,KAAKsvE,YAActvE,KAAK0U,QAAQI,UACzBnV,EAAO8rC,cAEhB,KAAK99B,EAAA+I,SAASusC,MACZ,IAAIqlC,EAAOtoF,KAAK0wE,YACZ6X,EAAiBD,EAAKlkB,eAU1B,GATImkB,EAAejpE,GAAG9R,EAAAnL,YAAYugB,eAC3B0lE,EAAKhpE,GAAE,MAEVtf,KAAKqN,MACHI,EAAAhD,eAAe+9E,iGACfx+C,EAAWj/B,QAIbu9E,EAAKhpE,GAAE,OAA4B,CACrC,IAAImpE,EAAaH,EAAK3jB,YAAYn3D,EAAAxK,cAAcoC,OAChD,GAAIqjF,EAAY,CACd,IACIv8D,EADkB9hB,OAAOq+E,EAAWxpE,KAAK0P,gBAClBzC,KAC3B,GAAIA,EAEF,OADAlsB,KAAKsvE,YAAcpjD,EAAKjN,KACjBtf,EAAO2nC,UAAUmhD,EAAW7gE,MAAOsE,EAAKjN,KAAKw0C,iBAI1D,GAAI80B,EAAejpE,GAAG9R,EAAAnL,YAAY4iB,UAAW,CACvCtS,EAAgBvI,OAAOm+E,EAAer0E,QAAS9J,OAAOuI,EAAc8D,MAAQm7C,EAAA9gD,YAAY+N,OAC5F,IAAIilE,EAA4BnxE,EAAeuZ,KAC/C,GAAI43D,EAAmB,CACrB,IAAI4E,EAAY5E,EAAkB7kE,KAElC,OADAjf,KAAKsvE,YAAcoZ,EACZ/oF,EAAO2nC,UAAU,EAAGohD,EAAUj1B,iBAQzC,OALAzzD,KAAKqN,MACHI,EAAAhD,eAAeq6D,iDACf96B,EAAWj/B,OAEb/K,KAAKsvE,YAActvE,KAAK0U,QAAQI,UACzBnV,EAAO8rC,cAIlBzrC,KAAKqoF,4BAA4Br+C,GAGjC,IAAI3c,EAASrtB,KAAKqS,SAASmwD,kBACzBx4B,EACA5f,EACApqB,KAAKqvE,aAAejL,GAEtB,IAAK/2C,EAAQ,OAAO1tB,EAAO8rC,cAE3B,OAAQpe,EAAO5W,MACb,KAAKm7C,EAAA9gD,YAAY+W,MACf,IAAI5I,EAAeoO,EAAQpO,KAE3B,GADA7U,OAAO6U,GAAQvR,EAAAkH,KAAKG,MACRsY,EAAQ/N,GAAG9R,EAAAnL,YAAYilB,SACjC,OAAOtnB,KAAKm8E,sBAA6B9uD,EAAQu1C,EAAgBmY,GAEnE,IAAIlxD,EAAqBwD,EAAQzF,MAMjC,OALAxd,OAAOyf,GAAc,GACjB5K,EAAKK,GAAE,MAAwB8K,EAAKo/C,YAAY3/C,EAAYhc,EAAAw5D,WAAW9C,SAAS,KAClFtlD,EAAOA,EAAKozC,iBAEdryD,KAAKsvE,YAAcrwD,EACZjf,KAAKL,OAAO2nC,UAAUzd,EAAY5K,EAAKw0C,gBAEhD,KAAK7B,EAAA9gD,YAAYmQ,OACf,IAAKjhB,KAAKozE,cAAsB/lD,GAC9B,OAAOrtB,KAAKL,OAAO8rC,cAEjBxsB,EAAgBoO,EAAQpO,KAE5B,OADA7U,OAAO6U,GAAQvR,EAAAkH,KAAKG,MACPsY,EAAQ/N,GAAG9R,EAAAnL,YAAYilB,SAC3BtnB,KAAKm8E,sBAA8B9uD,EAAQu1C,EAAgBmY,IAEpE/6E,KAAKsvE,YAAcrwD,EACZjf,KAAKL,OAAO+nC,WAAoBra,EAAQjb,aAAc6M,EAAKw0C,iBAEpE,KAAK7B,EAAA9gD,YAAY0W,UACf,OAAK6F,EAAO/N,GAAG9R,EAAAnL,YAAYiwE,WAQ3BtyE,KAAKsvE,YAAc5hE,EAAAkH,KAAKxR,IACRiqB,EAAQ/N,GAAG9R,EAAAnL,YAAYilB,UACrCld,OAA4C,GAAzBijB,EAAQlG,mBACpBnnB,KAAKL,OAAOyD,IAAI8sC,QAAoB7iB,EAAQhG,wBAE9CrnB,KAAKL,OAAO+nC,WAAuBra,EAAQjb,aAAcy/C,EAAAriC,WAAWppB,OAZzEpG,KAAKqN,MACHI,EAAAhD,eAAek+E,+HACf3+C,EAAWj/B,OAEb/K,KAAKsvE,YAAc5hE,EAAAkH,KAAKxR,IACjBpD,KAAKL,OAAO8rC,eASvB,KAAKmmB,EAAA9gD,YAAYkN,mBACf,IAAIuK,EAAWvoB,KAAKqS,SAAS4L,gBACRoP,EACnB,KACAxjB,EAAA23D,QAAqBp3C,EAAK3B,0BAE5B,IAAMF,IAAYvoB,KAAKw1E,gBAAgBjtD,GAAY,OAAO5oB,EAAO8rC,cACjE,IAAI7jB,EAAQ5nB,KAAKk4E,yBAAyB3vD,GAE1C,OADAvoB,KAAKsvE,YAAc/mD,EAAStU,UAAUgL,KAC/Bjf,KAAKL,OAAOyD,IAAIwkB,GAO3B,OAJA5nB,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEN/K,KAAKL,OAAO8rC,eAGrB0jC,EAAAltE,UAAA06E,4BAAA,SACE3yC,EACA44B,EACAmY,GAEA,IAAIp7E,EAASK,KAAKL,OAKdinC,EAAO5mC,KAAKs0E,kBAAkBtqC,EAAWA,WAAYhqC,KAAK0U,QAAQI,WAClE8zE,EAAa5oF,KAAKsvE,YAClBvmC,EAAe/oC,KAAKqS,SAASmuD,YAAYx2B,EAAW2c,OAAQ3mD,KAAK0wE,YAAYtM,gBAEjF,GADApkE,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,MACnBmlC,EAAc,OAAOppC,EAAO8rC,cAGjC,IAAK1C,EAAazpB,GAAE,KAClB,OAAO3f,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAOoqC,KAAKnD,GACZjnC,EAAOyD,IAAIwlF,GAAc7/C,EAAe,EAAI,IAC3C8oB,EAAAriC,WAAWppB,KAIhB,IAAKwiF,EAAWtpE,GAAE,KAChB,OAAO3f,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAOoqC,KAAKnD,GACZjnC,EAAOyD,IAAI,IACVyuD,EAAAriC,WAAWppB,KAIhB,IAAI2sE,EAAiB6V,EAAWn1B,eAGhC,GAAIm1B,EAAWtpE,GAAE,OAAyBypB,EAAazpB,GAAE,KAAsB,CAG7E,GAAIspE,EAAWv2B,gBAAgBjlC,eAAe2b,GAC5C,OAAOppC,EAAOmnC,OACZisC,GAAkBlhB,EAAAriC,WAAWnpB,IACzBwrD,EAAAz5B,SAASgzC,MACTvZ,EAAAz5B,SAAS+yC,MACbvkC,EACAgiD,EAAWl1B,aAAa/zD,IAK5B,GAAIopC,EAAa3b,eAAew7D,GAAa,CAC3C,IAAIpjE,EAAUxlB,KAAKwlB,QACnB,IAAMojE,EAAWnW,cAAe1pC,EAAa0pC,YAAc,CACzD,IACIyI,EADOl7E,KAAK0wE,YACK3H,oBAAoB6f,GACrCzrE,EAAqB/S,OAAOob,EAAQrI,oBAExC,OADAnd,KAAKw1E,gBAAgBr4D,GACdxd,EAAOyqC,GACZzqC,EAAO+mC,MACLqsC,GAAkBlhB,EAAAriC,WAAWnpB,IACzBwrD,EAAA/+B,QAAQi4C,OACRlZ,EAAA/+B,QAAQg4C,OACZnrE,EAAO6nC,UAAU0zC,EAAUtzD,MAAOgf,IAEpCjnC,EAAOyD,IAAI,GACXpD,KAAK0gF,eAAevjE,EAAoB,CACtCxd,EAAO2nC,UAAU4zC,EAAUtzD,MAAOmrD,GAClCpzE,EAAOyD,IAAI2lC,EAAapa,eAAgB7b,KACvCk3B,IAGLhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,YAMZ,CAGL,GAAI69E,EAAWx7D,eAAe2b,GAC5B,OAAOppC,EAAO6pC,MAAM,KAAM,CACxBxpC,KAAKm9E,kBAAkBv2C,EAAMgiD,EAAYl7E,EAAAkH,KAAKG,MAAM,GAAO,EAAOi1B,EAAWA,YAC7ErqC,EAAOyD,IAAI,IACVyuD,EAAAriC,WAAWppB,KAGT,GAAI2iC,EAAa3b,eAAew7D,GAAa,CAC9CpjE,EAAUxlB,KAAKwlB,QACnB,IAAMojE,EAAWnW,cAAe1pC,EAAa0pC,YAAc,CAKrDyI,EADOl7E,KAAK0wE,YACK3H,oBAAoB6f,GACrCzrE,EAAqB/S,OAAOob,EAAQrI,oBAExC,OADAnd,KAAKw1E,gBAAgBr4D,GACdxd,EAAOyqC,GACZzqC,EAAO+mC,MACLqsC,GAAkBlhB,EAAAriC,WAAWnpB,IACzBwrD,EAAA/+B,QAAQi4C,OACRlZ,EAAA/+B,QAAQg4C,OACZnrE,EAAO6nC,UAAU0zC,EAAUtzD,MAAOgf,IAEpCjnC,EAAOyD,IAAI,GACXpD,KAAK0gF,eAAevjE,EAAoB,CACtCxd,EAAO2nC,UAAU4zC,EAAUtzD,MAAOmrD,GAClCpzE,EAAOyD,IAAI2lC,EAAapa,eAAgB7b,KACvCk3B,IAGLhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,QAOnB,OAAOpL,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAOoqC,KAAKnD,GACZjnC,EAAOyD,IAAI,IACVyuD,EAAAriC,WAAWppB,MAGhB+oE,EAAAltE,UAAA26E,yBAAA,SACE5yC,EACA44B,EACAmY,EACA8N,QAAA,IAAAA,OAAA,GAEA,IAAIlpF,EAASK,KAAKL,OAClB,OAAQqqC,EAAW7mB,aACjB,KAAKxV,EAAAyV,YAAYsrC,MACftkD,QAAQy+E,GACR,IAAI91B,EAAY6P,EAAej0C,eAC/B,OAAIokC,GACEA,EAAU9wD,WAAajC,KAAKwlB,QAAQnJ,eAC/Brc,KAAK8oF,oBACV1+E,OAAO2oD,EAAU9mC,eAAe,GACP+d,EAAY+a,mBACrCg2B,EACA/wC,IAINhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAENpL,EAAO8rC,eAEhB,KAAK99B,EAAAyV,YAAY2rC,MACf,IAAIg6B,EAAsC/+C,EAAY1oC,MAItD,OAHIunF,IACFE,GAAcA,GAEZnmB,GAAkBl1D,EAAAkH,KAAK/Q,IAClBlE,EAAOkE,IAASklF,IAEzB/oF,KAAKsvE,YAAc5hE,EAAAkH,KAAK9Q,IACjBnE,EAAOmE,IAAIilF,IAEpB,KAAKp7E,EAAAyV,YAAY6rC,QACf,IAAIqU,EAAsCt5B,EAAY1oC,MAClDunF,IACFvlB,EAAWkB,QACTjvD,QAAQ,GACR+tD,IAGJ,IAAIrkD,EAAOjf,KAAKqS,SAASgxD,4BAA4BC,EAAUV,GAE/D,OADA5iE,KAAKsvE,YAAcrwD,EACXA,EAAKxI,MACX,OAAqB,IAAKzW,KAAK0U,QAAQc,SAAU,OAAO7V,EAAOyD,IAAI8sC,QAAQozB,IAC3E,OAAmB,OAAO3jE,EAAO0D,IAAI6sC,QAAQozB,GAAWnzB,SAASmzB,IACjE,OAAqB,IAAKtjE,KAAK0U,QAAQc,SAAU,OAAO7V,EAAOyD,IAAI8sC,QAAQozB,IAC3E,OAAmB,OAAO3jE,EAAO0D,IAAI6sC,QAAQozB,GAAWnzB,SAASmzB,IACjE,QAAmB,OAAO3jE,EAAOkE,IAAImlF,WAAW1lB,IAChD,QAAmB,OAAO3jE,EAAOmE,IAAImlF,WAAW3lB,IAChD,QAAS,OAAO3jE,EAAOyD,IAAI8sC,QAAQozB,IAGvC,KAAK31D,EAAAyV,YAAYC,OAEf,OADAjZ,QAAQy+E,GACD7oF,KAAKkpF,qBAA8Cl/C,GAE5D,KAAKr8B,EAAAyV,YAAY+rC,OAEf,OADA/kD,QAAQy+E,GACD7oF,KAAKmpF,qBAA8Cn/C,EAAY44B,GAS1E,OALA5iE,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAEb/K,KAAKsvE,YAAc1M,EACZjjE,EAAO8rC,eAGhB0jC,EAAAltE,UAAAinF,qBAAA,SAAqBl/C,GACnB,OAAOhqC,KAAKg3E,mBAAmBhtC,EAAW1oC,QAG5C6tE,EAAAltE,UAAA6mF,oBAAA,SACExR,EACAzxB,EACAk1B,EACAhV,GAmBA,IAjBA,IAAIpmE,EAASK,KAAKL,OACd6lB,EAAUxlB,KAAKwlB,QACfnJ,EAAiBjS,OAAOob,EAAQnJ,gBAChCw7D,EAAgBztE,OAAOpK,KAAKqS,SAAS0L,aAAa1B,EAAgB,CAAEi7D,KACpEv9D,EAAsB3P,OAAOob,EAAQzL,qBACrCkpD,EAAY4U,EAAc54D,KAC1BmL,EAAOpqB,KAAK0wE,YAGZgT,EAAWt5D,EAAKi+C,aAAapF,GAC7BmmB,EAAgBh/D,EAAKi+C,aAAatuD,EAAoBkF,MAGtD9S,EAAS05C,EAAY15C,OACrBoR,EAAS,IAAItW,MAAqBkF,GAClCwW,GAAW,EACX0mE,EAAoB/R,EAAY7jB,eAC3BpzD,EAAI,EAAGA,EAAI8L,IAAU9L,EAAG,CAC/B,IAAI2pC,EAAa6b,EAAYxlD,GACzBumC,EAAOoD,EACPrqC,EAAO6yC,qBACLxyC,KAAKs0E,kBAA8BtqC,EAAYstC,EAAW,IAI5DA,EAAY5jB,aAAa/zD,GACzBkyD,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAaolB,MACxCzqC,OAAOynD,EAAA7a,kBAAkBpQ,IAASyiD,GAElC1mE,GAAW,EAEbpF,EAAOld,GAAKumC,EAId,GAAIjkB,EAAU,CACZyH,EAAK0+C,cAAc4a,GACnBt5D,EAAK0+C,cAAcsgB,GAEnB,IAAIhS,EAAoB5xD,EAAQ4xD,kBAC5BQ,EAAgB53E,KAAKq3E,wBAAwBC,EAAa/5D,GAC1D+rE,EAAgB3qB,QAAQiZ,EAAcllE,OAAQ6C,QAAQ6hE,IAI1D,GAAe,GAAX2D,EAAyC,CAC3C,IAAIwO,EAAevpF,KAAK23E,wBAAwBL,EAAaM,GACzD4R,EAAe7qB,QAAQ4qB,EAAa72E,OAAQ6C,QAAQ6hE,IAExD,OADAp3E,KAAKsvE,YAAcrM,EACZz9C,EAAQ9Q,QAAQc,SACnBxV,KAAKL,OAAO0D,IAAI6sC,QAAQs5C,GAAer5C,SAASq5C,IAChDxpF,KAAKL,OAAOyD,IAAI8sC,QAAQs5C,IAKxB5iD,EAAO5mC,KAAK0gF,eAAel7D,EAAQnI,mBAAoB,CACzD1d,EAAOyD,IAAI+I,GACXqZ,EAAQ9Q,QAAQc,SACZ7V,EAAO0D,IAAIi0E,EAAYmS,WACvB9pF,EAAOyD,IAAIk0E,EAAYmS,WAC3B9pF,EAAOyD,IAAIy0E,EAAc/kE,IACzB0S,EAAQ9Q,QAAQc,SACZ7V,EAAO0D,IAAI6sC,QAAQo5C,GAAgBn5C,SAASm5C,IAC5C3pF,EAAOyD,IAAI8sC,QAAQo5C,KACtBvjB,GAEH,OADA/lE,KAAKsvE,YAAcrM,EACZjjE,KAAKgjF,gBAAgBhjF,KAAK6yE,WAAWjsC,IAMhD,IADaixC,EAAc1qD,eAAeykC,EAAArkD,aAAauB,aAAa,GASlE,OAPAsb,EAAK0+C,cAAc4a,GACnBt5D,EAAK0+C,cAAcsgB,GACnBppF,KAAKqN,MACHI,EAAAhD,eAAek4E,+CACf5c,EAAWh7D,MAAO8sE,EAAczlE,cAElCpS,KAAKsvE,YAAcrM,EACZtjE,EAAO8rC,cAEhB,IAAIi+C,EAAkBzmB,EAAUxP,eAE5BkiB,EAAQ,IAAI1uE,MAEhB0uE,EAAMjpE,KACJ/M,EAAOypC,UAAUs6C,EAAS97D,MACxB5nB,KAAK0gF,eAAel7D,EAAQnI,mBAAoB,CAC9C1d,EAAOyD,IAAI+I,GACXqZ,EAAQ9Q,QAAQc,SACZ7V,EAAO0D,IAAIi0E,EAAYmS,WACvB9pF,EAAOyD,IAAIk0E,EAAYmS,WAC3B9pF,EAAOyD,IAAIy0E,EAAc/kE,IACzB0S,EAAQ9Q,QAAQc,SACZ7V,EAAO0D,IAAI,GACX1D,EAAOyD,IAAI,IACd2iE,KAIP,IAAI4jB,EAAYv/E,OAAOytE,EAAcl+D,aAAa,cAClDvP,OAAOu/E,EAAUlzE,MAAQm7C,EAAA9gD,YAAY8N,OACrC+2D,EAAMjpE,KACJ/M,EAAOypC,UAAUggD,EAAcxhE,MAC7BjoB,EAAOioC,KAAKq7B,EAAU/Q,UAAU,EAC9BvyD,EAAO2nC,UAAUo8C,EAAS97D,MAAO8hE,GACjCA,EACQC,EAAWr+D,gBAKzB,IADA,IAAIsnD,EAAY0E,EAAY1E,UACZ6W,GAAPppF,EAAI,EAAei3E,EAAYmS,WAAWppF,EAAI8L,IAAU9L,EAAG,CAClE,IAAI2yE,EAAYz1D,EAAOld,GACnBuyE,IAEFI,EAAYhzE,KAAK6yE,WAAWG,IAG9B2C,EAAMjpE,KACJ/M,EAAO6mC,MAAM8wC,EAAYplB,SACvBvyD,EAAO2nC,UAAU8hD,EAAcxhE,MAAO8hE,GACtC1W,EACAqW,EACAhpF,GAAKopF,IAWX,OANA9T,EAAMjpE,KACJ/M,EAAO2nC,UAAUo8C,EAAS97D,MAAO8hE,IAEnCt/D,EAAK0+C,cAAc4a,GACnBt5D,EAAK0+C,cAAcsgB,GACnBppF,KAAKsvE,YAAcrM,EACZtjE,EAAO6pC,MAAM,KAAMmsC,EAAO+T,IAGnCva,EAAAltE,UAAAknF,qBAAA,SAAqBn/C,EAAqC44B,GACxD,IAAIjjE,EAASK,KAAKL,OAGdgvB,EAAiBi0C,EAAej0C,eACpC,IAAKA,GAAkBA,EAAerP,GAAG9R,EAAAnL,YAAYmgB,UAKnD,OAJAxiB,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACfvqC,EAAWj/B,MAAO,WAAY63D,EAAel3D,YAExC/L,EAAO8rC,cAIhB,IAAIm+C,EAAOj7D,EAAetC,oBAC1B,GAAIu9D,EAAM,CAGR,GAAIA,EAAK31E,UAAUkgD,mBAKjB,OAJAn0D,KAAKqN,MACHI,EAAAhD,eAAeo/E,sDACf7/C,EAAWj/B,MAAO4jB,EAAejjB,YAE5B/L,EAAO8rC,cAEhB,GAAIm+C,EAAKtqE,GAAG9R,EAAAnL,YAAYq0D,SAKtB,OAJA12D,KAAKqN,MACHI,EAAAhD,eAAeq/E,mFACf9/C,EAAWj/B,MAAO4jB,EAAejjB,YAE5B/L,EAAO8rC,cAEhB,GAAIm+C,EAAKtqE,GAAG9R,EAAAnL,YAAYs0D,WAKtB,OAJA32D,KAAKqN,MACHI,EAAAhD,eAAes/E,qFACf//C,EAAWj/B,MAAO4jB,EAAejjB,YAE5B/L,EAAO8rC,cAKlB,IAAIV,EAAQf,EAAWe,MACnBE,EAAWF,EAAM5+B,OACjBoR,EAASysB,EAAWzsB,OACpBuB,EAAU6P,EAAe7P,QACzBkrE,GAAY,EACZ/B,EAAQ,IAAIhhF,MAAqBgkC,EAAW,GAE5CiwC,EADOl7E,KAAK0wE,YACKhI,oBAAoB1oE,KAAK0U,QAAQI,WACtD1K,OAAO6gC,GAAY1tB,EAAOpR,QAC1B,IAAK,IAAI9L,EAAI,EAAG+V,EAAI60B,EAAU5qC,EAAI+V,IAAK/V,EAAG,CACxC,IAAIie,EAASQ,EAAUA,EAAQ5d,IAAI6pC,EAAM1qC,GAAG4L,MAAQ,KACpD,GAAKqS,GAAUA,EAAO7H,MAAQm7C,EAAA9gD,YAAY8N,MAA1C,CAQA,IAAIK,EAAeX,EAAQW,KAC3BgpE,EAAM5nF,EAAI,GAAKL,KAAKL,OAAO6mC,MACzBvnB,EAAKizC,SACLlyD,KAAKL,OAAO2nC,UAAU4zC,EAAUtzD,MAAO5nB,KAAK0U,QAAQq+D,gBACpD/yE,KAAKs0E,kBAAkB/2D,EAAOld,GAAYie,EAAQW,KAAI,GACtDA,EAAKw0C,eACGn1C,EAAQgN,mBAbhBtrB,KAAKqN,MACHI,EAAAhD,eAAe03D,oCACfp3B,EAAM1qC,GAAG0K,MAAOggC,EAAM1qC,GAAG4L,KAAM0iB,EAAejjB,YAEhDs+E,GAAY,EAahB,OADAhqF,KAAKsvE,YAAc3gD,EAAe1P,KAAKozC,gBACnC23B,EAAkBrqF,EAAO8rC,eAG7Bw8C,EAAM,GAAKtoF,EAAOypC,UAChB8xC,EAAUtzD,MACV5nB,KAAK6yE,WACH7yE,KAAKm2E,eAAexnD,KAKxBs5D,EAAMA,EAAM97E,OAAS,GAAKxM,EAAO2nC,UAAU4zC,EAAUtzD,MAAO5nB,KAAK0U,QAAQq+D,gBAEzE/yE,KAAKsvE,YAAc3gD,EAAe1P,KAC3Btf,EAAO6pC,MAAM,KAAMy+C,EAAOjoF,KAAK0U,QAAQq+D,kBAGhD5D,EAAAltE,UAAA46E,qBAAA,SACE7yC,EACA44B,EACAmY,GAEA,IAAIp7E,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YAGZrjD,EAASrtB,KAAKqS,SAASywD,kBACzB94B,EAAWA,WACX5f,GAEF,IAAKiD,EAAQ,OAAO1tB,EAAO8rC,cAC3B,GAAIpe,EAAO5W,MAAQm7C,EAAA9gD,YAAYuJ,gBAK7B,OAJAra,KAAKqN,MACHI,EAAAhD,eAAew/E,yEACfjgD,EAAWA,WAAWj/B,OAEjB/K,KAAKL,OAAO8rC,cAErB,IAGI9c,EAHA7L,EAAiCuK,EACjC1a,EAA8B,KAC9BsZ,EAAgB+d,EAAW/d,cAqB/B,OAdEtZ,GAJCsZ,GACoD,QAApD0C,EAAiBi0C,EAAej0C,iBACjCA,EAAerP,GAAG9R,EAAAnL,YAAY8S,SAEdnV,KAAKqS,SAAS0L,aAC5B+E,EACA6L,EAAe1C,cACfpiB,EAAA23D,QAAqBp3C,EAAK3B,0BAGZzoB,KAAKqS,SAASkvD,8BAC5Bz+C,EACAmJ,EACA7B,EAAKg6C,eAAelwD,OACpBrK,EAAA23D,QAAqBp3C,EAAK3B,yBAC1BuhB,KAIA44B,GAAkBl1D,EAAAkH,KAAKG,OAAMgmE,GAAW,GACrC/6E,KAAKkqF,mBAAmBv3E,EAAeq3B,EAAWhnB,UAAW+3D,EAAa/wC,IAFtDrqC,EAAO8rC,eAMpC0jC,EAAAltE,UAAAgiF,kBAAA,SAAkBtxE,EAAsBozD,GACtC,IAAIx9C,EAAW5V,EAAc0Z,oBAC7B,GAAI9D,EAGF,OADKA,EAASlN,aAAau2C,EAAA7gD,eAAesR,SAASriB,KAAKw1E,gBAAgBjtD,GACjEA,EAIT,IAAI29C,EAAYvzD,EAAcuZ,KAC9B,GAAIg6C,EAAW,CACb,IAAIikB,EAAWnqF,KAAKikF,kBAAkB/d,EAAWH,GACjDx9C,EAAW,IAAIqpC,EAAAx9C,SACb5G,EAAAxK,cAAcsC,YACd,IAAIssD,EAAAv9C,kBACF7G,EAAAxK,cAAcsC,YACdqN,EAEsBw3E,EAAS51E,YAAaw8C,SAE9Co5B,EAASl2E,UACT,WAKFsU,EAAW,IAAIqpC,EAAAx9C,SACb5G,EAAAxK,cAAcsC,YACd,IAAIssD,EAAAv9C,kBACF7G,EAAAxK,cAAcsC,YACdqN,EACA3S,KAAKwlB,QAAQ/R,8BAA8BjG,EAAAxK,cAAcsC,YACvDkI,EAAAnL,YAAY4iB,SAAWzX,EAAAnL,YAAYugB,cAGvC,IAAIlV,EAAA0Y,UAAU,KAAMzT,EAAcsM,KAAMtM,EAAcsM,MACtD,MAIJsJ,EAASnW,aAAeO,EAAcP,aAAe5E,EAAA9K,mBAAqB,cAC1E6lB,EAASpW,IAAI3E,EAAAnL,YAAYiwE,UACzB/pD,EAAStmB,UAAUqmB,oBAAoB,GAAIC,GAC3C5V,EAAc0Z,oBAAsB9D,EACpC,IAAIwrD,EAAe/zE,KAAK0wE,YACpBtmD,EAAO7B,EAAS6B,KACpBpqB,KAAK0wE,YAActmD,EAGnB,IAAInW,EAAYsU,EAAStU,UACrBtU,EAASK,KAAKL,OACdozE,EAAiB/yE,KAAK0U,QAAQq+D,eAC9B4C,EAAQ,IAAI1uE,MAqBhB,GAZA0uE,EAAMjpE,KACJ/M,EAAOyqC,GACLzqC,EAAO+mC,MAAMqsC,GAAkBlhB,EAAAriC,WAAWnpB,IAAMwrD,EAAA/+B,QAAQi4C,OAASlZ,EAAA/+B,QAAQg4C,OACvEnrE,EAAO2nC,UAAU,EAAGyrC,IAEtBpzE,EAAOypC,UAAU,EACfppC,KAAK6yE,WACH7yE,KAAKm2E,eAAexjE,OAKxBuzD,EAAW,CACb,IAAIl8C,EAAiB/V,EAAU+V,eAC3B2qC,EAAgB3qC,EAAe7d,OAC/Bg7B,EAAW,IAAIlgC,MAAqB,EAAI0tD,GAC5CxtB,EAAS,GAAKxnC,EAAO2nC,UAAU,EAAGyrC,GAClC,IAAK,IAAI1yE,EAAI,EAAGA,EAAIs0D,IAAiBt0D,EACnC8mC,EAAS9mC,EAAI,GAAKV,EAAO2nC,UAAUjnC,EAAI,EAAG2pB,EAAe3pB,GAAGozD,gBAG9DkiB,EAAMjpE,KACJ/M,EAAOypC,UAAU,EACfppC,KAAK0gF,eAAet2E,OAAO87D,EAAU75C,qBAAsB8a,EAAU4+B,GAAY,GAAO,KAI9F/lE,KAAKo2E,wBAAwBzjE,EAAegjE,GAC5C,IAAI3tD,EAAOhoB,KAAK6hF,6BAA6Bz3D,EAAMzqB,EAAO2nC,UAAU,EAAGyrC,GAAiBpgE,EAAcsM,KAAM02D,GAC5GvrD,EAAKk/C,mBACLtpE,KAAK0wE,YAAcqD,EAGnB,IAAIlmC,EAAU7tC,KAAKqxE,mBAAmBp9D,EAAU+V,eAAgB/V,EAAUm3B,WAAYn3B,EAAU8V,UAC5FS,EAASjC,EAASI,cAClB4kB,EAAW,IAAItmC,MACf0gF,EAAc,EAAI1zE,EAAU+V,eAAe7d,OAC3C+nE,EAAY1pD,EAAOre,OACvB,GAAI+nE,EAAYyT,EACd,IAAStnF,EAAIsnF,EAAatnF,EAAI6zE,IAAa7zE,EAAGktC,EAAS7gC,KAAK8d,EAAOnqB,GAAG4e,KAAKw0C,gBAE7E,IAAI2d,EAAUzxE,EAAO2tC,YAAY/kB,EAASnW,aAAcy7B,EAASN,EAAUvlB,GAE3E,OADAO,EAASkC,SAAS9qB,EAAQyxE,GACnB7oD,GAGT4mD,EAAAltE,UAAAioF,mBAAA,SAEEv3E,EAEAuyE,EAEAnK,EAEAhV,GAEA,IAAI6jB,EAAO5pF,KAAKikF,kBAAkBtxE,EAAeozD,GAC7Cn/B,EAAO5mC,KAAKgkF,kBACd4F,EACA1E,EACAnf,EACA/lE,KAAK0U,QAAQI,UAAU4+C,aAAa1zD,KAAKL,QACzCo7E,GAKF,OAHIlpB,EAAA7a,kBAAkBpQ,IAASirB,EAAAriC,WAAWyY,OACxCjoC,KAAKsvE,YAAc38D,EAAcsM,MAE5B2nB,GAQTuoC,EAAAltE,UAAA66E,gCAAA,SACEna,EACAC,EACAmY,GAEA,IAAIp7E,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YAEhB1wE,KAAKqoF,4BAA4B1lB,GAEjC,IAAIt1C,EAASrtB,KAAKqS,SAASqwD,gCAAgCC,EAAgBv4C,EAAMw4C,GACjF,IAAKv1C,EAAQ,OAAO1tB,EAAO8rC,cAE3B,OAAQpe,EAAO5W,MACb,KAAKm7C,EAAA9gD,YAAYmQ,OACf,IAAKjhB,KAAKozE,cAAsB/lD,GAC9B,OAAO1tB,EAAO8rC,cAEhB,IAAI+D,EAAsBniB,EAAQpO,KAElC,OADA7U,OAAOolC,GAAc9hC,EAAAkH,KAAKG,MACbsY,EAAQ/N,GAAG9R,EAAAnL,YAAYilB,SAC3BtnB,KAAKm8E,sBAA8B9uD,EAAQu1C,EAAgBmY,IAEpE/6E,KAAKsvE,YAAc9/B,EACZ7vC,EAAO+nC,WAAoBra,EAAQjb,aAAco9B,EAAWikB,iBAErE,KAAK7B,EAAA9gD,YAAY0W,UACf,IAAI4iE,EAAUhgF,OAAmBijB,EAAQnZ,QACzC,OADkD9J,OAAOggF,EAAQ3zE,MAAQm7C,EAAA9gD,YAAYkW,MAChFhnB,KAAKqzE,YAAkB+W,IAI5BpqF,KAAKsvE,YAAc5hE,EAAAkH,KAAKxR,IACRiqB,EAAQ/N,GAAG9R,EAAAnL,YAAYilB,UACrCld,OAA4C,GAAzBijB,EAAQlG,mBACpBxnB,EAAOyD,IAAI8sC,QAAoB7iB,EAAQhG,wBAEzC1nB,EAAO+nC,WAAuBra,EAAQjb,aAAcy/C,EAAAriC,WAAWppB,OARpEpG,KAAKsvE,YAAc5hE,EAAAkH,KAAKxR,IACjBpD,KAAKL,OAAO8rC,eASvB,KAAKmmB,EAAA9gD,YAAY8N,MACfxU,OAAeijB,EAAQ/B,cAAgB,GACvC,IAAI63D,EAAWnjF,KAAKs0E,kBAAkBlqE,OAAOpK,KAAKqS,SAASiuD,uBAAwBtgE,KAAK0U,QAAQI,WAEhG,OADA9U,KAAKsvE,YAAsBjiD,EAAQpO,KAC5Btf,EAAOioC,KACJva,EAAQpO,KAAKizC,SACb7kC,EAAQpO,KAAKK,GAAG,GACxB6jE,EACQ91D,EAAQpO,KAAKw0C,eACbpmC,EAAQ/B,cAGpB,KAAKsmC,EAAA9gD,YAAYyN,mBACf,IAAIC,EAAsC6O,EAAQ7O,gBAClD,GAAIA,EAAiB,CACnB,IAAI3d,EAASb,KAAKqS,SAAS4L,gBAAgBO,EAAiB,MAC5D,GAAI3d,EAAQ,OAAOb,KAAKgkF,kBAAkBnjF,EAAQ,GAAI8hE,EAAgB,GAExE,OAAOhjE,EAAO8rC,cAEhB,KAAKmmB,EAAA9gD,YAAY4N,SACf,IAAI+M,EAAiBrhB,OAAkBijB,EAAQ5B,gBAC/C,OAAOzrB,KAAKgkF,kBAAkBv4D,EAAgB,GAAIk3C,EAChD3iE,KAAKs0E,kBAAkBlqE,OAAOpK,KAAKqS,SAASiuD,uBAAwBtgE,KAAK0U,QAAQI,YAGrF,KAAK88C,EAAA9gD,YAAYkN,mBAKf,OAJAhe,KAAKqN,MACHI,EAAAhD,eAAe4/E,wEACf1nB,EAAe53D,MAA2BsiB,EAAQzsB,MAE7CjB,EAAO8rC,cAOlB,OAJAzrC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACfshD,EAAe53D,OAEVpL,EAAO8rC,eAGhB0jC,EAAAltE,UAAA86E,yBAAA,SACE/yC,EACA44B,EACAmY,GAEA,IAAIjzB,EAAS9d,EAAW8d,OACpBC,EAAS/d,EAAW+d,OACpB0xB,EAAYz5E,KAAK0wE,YAEjBmJ,EAAW75E,KAAKL,OAAO6yC,qBACzBxyC,KAAK85E,cACH95E,KAAKs0E,kBAAkBtqC,EAAWH,UAAWn8B,EAAAkH,KAAKhR,MAClD5D,KAAKsvE,cAKT,GACEzd,EAAA9a,gBAAgB8iC,IAAahoB,EAAApiC,aAAaolB,OAC1Cgd,EAAA7a,kBAAkB6iC,IAAahoB,EAAAriC,WAAWppB,IAE1C,OAAOyrD,EAAA5a,iBAAiB4iC,GACpB75E,KAAKs0E,kBAAkBxsB,EAAQ8a,GAC/B5iE,KAAKs0E,kBAAkBvsB,EAAQ6a,GAGrC,IAAIic,EAAkC,GAAX9D,EAEvBuP,EAAa7Q,EAAUvR,OAC3BloE,KAAK0wE,YAAc4Z,EACnB,IAAIC,EAAavqF,KAAKs0E,kBAAkBxsB,EAAQ8a,EAAgBic,GAC5D2L,EAAaxqF,KAAKsvE,YAClBmb,EAA2BzqF,KAAK6vE,oBAAoBr7D,IAAI+1E,GAExDG,EAAajR,EAAUvR,OAC3BloE,KAAK0wE,YAAcga,EACnB,IAAIC,EAAa3qF,KAAKs0E,kBAAkBvsB,EAAQ6a,EAAgBic,GAC5D+L,EAAa5qF,KAAKsvE,YAClBub,EAA2B7qF,KAAK6vE,oBAAoBr7D,IAAIm2E,GAExDrL,EAAa5xE,EAAAkH,KAAK2+C,kBAAkBi3B,EAAYI,GAAY,GAChE,IAAKtL,EAMH,OALAt/E,KAAKqN,MACHI,EAAAhD,eAAe8pE,mCACfxsB,EAAOh9C,MAAO6/E,EAAWl/E,WAAY8+E,EAAW9+E,YAElD1L,KAAKsvE,YAAc1M,EACZ5iE,KAAKL,OAAO8rC,cAErB8+C,EAAavqF,KAAKm9E,kBAChBoN,EACAC,EAAYlL,GACZ,GAAO,EACPx3B,GAEF6iC,EAAa3qF,KAAKm9E,kBAChBwN,EACAC,EAAYtL,GACZ,GAAO,EACPv3B,GAEF/nD,KAAKsvE,YAAcgQ,EAEfmL,GAA4BI,EACzBJ,GAIHE,EAAa3qF,KAAK6yE,WAAW8X,GAC7BE,GAA2B,IAJ3BN,EAAavqF,KAAK6yE,WAAW0X,GAC7BE,GAA2B,IAKnBA,GAA4BnL,EAAW1M,YAE/C2X,EAAavqF,KAAKiiF,gBAAgBsI,EAAYD,EAAY7Q,GAC1DkR,EAAa3qF,KAAKiiF,gBAAgB0I,EAAYD,EAAYjR,IAI9D8Q,EAAavqF,KAAK6hF,6BAA6ByI,EAAYC,EAAYjL,GACvEgL,EAAWhhB,mBAEXqhB,EAAa3qF,KAAK6hF,6BAA6B6I,EAAYC,EAAYrL,GACvEoL,EAAWphB,mBAEXtpE,KAAK0wE,YAAc+I,EACnBA,EAAUpP,cAAcigB,EAAYI,GAEpC,IAAI9jD,EAAO5mC,KAAKL,OAAOyqC,GAAGyvC,EAAU0Q,EAAYI,GAGhD,OAFAvgF,OAAOqgF,GAA4BI,GAC/BJ,GAA0BzqF,KAAK6vE,oBAAoB76D,IAAI4xB,GACpDA,GAGTuoC,EAAAltE,UAAA+6E,8BAAA,SACEhzC,EACA44B,EACAmY,GAEA,IAAIp7E,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YAGZoa,EAAW9qF,KAAKs0E,kBAClBtqC,EAAW0e,QACXka,EAAemc,WAAU,GAK3B,GAAIltB,EAAA9a,gBAAgB+zC,IAAaj5B,EAAApiC,aAAa2uB,YAAa,OAAO0sC,EAGlE,IASIlkD,EATAs0C,EAA0B,KAW9B,OAVItY,GAAkBl1D,EAAAkH,KAAKG,OACzBmmE,EAAY9wD,EAAKi+C,aAAaroE,KAAKsvE,aACnCwb,EAAWnrF,EAAO6nC,UAChB0zC,EAAUtzD,MACVkjE,IAMI9gD,EAAWqb,UACjB,KAAKjD,EAAAC,MAAM8V,UACT,OAAQn4D,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OACZ+qB,EAAAz5B,SAASk9C,OACTwV,EACAnrF,EAAOyD,IAAI,IAEb,MAEF,OAEE,GAAIpD,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiB3uB,KAAKsvE,YAAY3gD,eAGpC,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAaoD,aAC5C,CACZi2B,EAAO5mC,KAAKsiF,qBAAqB90D,EAAUwc,EAAW0e,QAASoiC,EAAU9gD,GACzE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAENpL,EAAO8rC,cAGlB,OACE,IAAI/2B,EAAU1U,KAAK0U,QACnBkyB,EAAOjnC,EAAOmnC,OACZpyB,EAAQc,SACJq8C,EAAAz5B,SAAS2nD,OACTluB,EAAAz5B,SAASk9C,OACbwV,EACA9qF,KAAKsvE,YAAY3b,YAAYh0D,IAE/B,MAEF,OACA,OACEinC,EAAOjnC,EAAOmnC,OACZ+qB,EAAAz5B,SAAS2nD,OACT+K,EACAnrF,EAAO0D,IAAI,IAEb,MAEF,QACEujC,EAAOjnC,EAAOmnC,OACZ+qB,EAAAz5B,SAAS4nD,OACT8K,EACAnrF,EAAOkE,IAAI,IAEb,MAEF,QACE+iC,EAAOjnC,EAAOmnC,OACZ+qB,EAAAz5B,SAAS6nD,OACT6K,EACAnrF,EAAOmE,IAAI,IAEb,MAEF,QAEE,OADAsG,QAAO,GACAzK,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAM+V,YACT,OAAQp4D,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OACZ+qB,EAAAz5B,SAAS8nD,OACT4K,EACAnrF,EAAOyD,IAAI,IAEb,MAEF,OAEE,GAAIpD,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAC5C,IAAIqP,EAEEnB,EADN,GADImB,EAAiB3uB,KAAKsvE,YAAY3gD,eAGpC,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAaqD,aAC5C,CACZg2B,EAAO5mC,KAAKsiF,qBAAqB90D,EAAUwc,EAAW0e,QAASoiC,EAAU9gD,GACzE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAENpL,EAAO8rC,cAGlB,OACM/2B,EAAU1U,KAAK0U,QACnBkyB,EAAOjnC,EAAOmnC,OACZpyB,EAAQc,SACJq8C,EAAAz5B,SAAS+nD,OACTtuB,EAAAz5B,SAAS8nD,OACb4K,EACA9qF,KAAKsvE,YAAY3b,YAAYh0D,IAE/B,MAEF,OACA,OACEinC,EAAOjnC,EAAOmnC,OACZ+qB,EAAAz5B,SAAS+nD,OACT2K,EACAnrF,EAAO0D,IAAI,IAEb,MAEF,QACEujC,EAAOjnC,EAAOmnC,OACZ+qB,EAAAz5B,SAASgoD,OACT0K,EACAnrF,EAAOkE,IAAI,IAEb,MAEF,QACE+iC,EAAOjnC,EAAOmnC,OACZ+qB,EAAAz5B,SAASioD,OACTyK,EACAnrF,EAAOmE,IAAI,IAEb,MAEF,QAEE,OADAsG,QAAO,GACAzK,EAAO8rC,cAGlB,MAEF,QAEE,OADArhC,QAAO,GACAzK,EAAO8rC,cAIlB,IAAIp5B,EAAWrS,KAAKqS,SAChBgb,EAAShb,EAASywD,kBAAkB94B,EAAW0e,QAASt+B,GAG5D,IAAK8wD,EAEH,OADAl7E,KAAKsvE,YAAc5hE,EAAAkH,KAAKG,KACnBsY,EACErtB,KAAKqiF,eACVh1D,EACAuZ,EACAoD,EAAW0e,QACXr2C,EAASiuD,sBACTjuD,EAASkuD,0BACT,GAPkB5gE,EAAO8rC,cAStB,IAAKpe,EACV,OAAO1tB,EAAO8rC,cAIhB,IAAIs/C,EAAW/qF,KAAKqiF,eAClBh1D,EACAuZ,EACAoD,EAAW0e,QACXr2C,EAASiuD,sBACTjuD,EAASkuD,0BACT,GAGFvgE,KAAKsvE,YAAc4L,EAAUj8D,KAC7BmL,EAAK0+C,cAAcoS,GACnB,IAAIpI,EAAaoI,EAAUj8D,KAAKw0C,eAEhC,OAAO9zD,EAAO6pC,MAAM,KAAM,CACxBuhD,EACAprF,EAAO2nC,UAAU4zC,EAAUtzD,MAAOkrD,IACjCA,IAGL3D,EAAAltE,UAAAg7E,6BAAA,SACEjzC,EACA44B,EACAmY,GAEA,IAEIn0C,EAFAjnC,EAASK,KAAKL,OACd4/E,GAAW,EAGf,OAAQv1C,EAAWqb,UACjB,KAAKjD,EAAAC,MAAMjyC,KAQT,GAPAw2B,EAAO5mC,KAAKs0E,kBACVtqC,EAAW0e,QACXka,EAAemc,WAAU,GAKvB/+E,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiB3uB,KAAKsvE,YAAY3gD,eAGpC,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa6C,MAC5C,CACZw2B,EAAO5mC,KAAKsiF,qBAAqB90D,EAAUwc,EAAW0e,QAAS9hB,EAAMoD,GACrE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAENpL,EAAO8rC,cAIhB,MAEF,KAAK2W,EAAAC,MAAM/xC,MACT,GAAI05B,EAAW0e,QAAQjyC,MAAQ9I,EAAA+I,SAASwM,UAClB8mB,EAAW0e,QAASvlC,aAAexV,EAAAyV,YAAY6rC,SAC/CjlB,EAAW0e,QAASvlC,aAAexV,EAAAyV,YAAY2rC,OAClE,CAEDnoB,EAAO5mC,KAAK48E,yBAA4C5yC,EAAW0e,QAASka,EAAc,GAAoB,GAE1G5iE,KAAK0U,QAAQgW,WAAW1qB,KAAKs5E,iBAAiB1yC,EAAMoD,EAAWj/B,OACnE,MAUF,GAPA67B,EAAO5mC,KAAKs0E,kBACVtqC,EAAW0e,QACXka,EAAemc,WAAU,GAKvB/+E,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiB3uB,KAAKsvE,YAAY3gD,eAGpC,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa+C,OAC5C,CACZs2B,EAAO5mC,KAAKsiF,qBAAqB90D,EAAUwc,EAAW0e,QAAS9hB,EAAMoD,GACrE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAENpL,EAAO8rC,cAGhB,OAAQzrC,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS8nD,OAAQvgF,EAAOyD,IAAI,GAAIwjC,GACrD,MAEF,OACA,OACEA,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS+nD,OACTtuB,EAAAz5B,SAAS8nD,OACblgF,KAAKsvE,YAAY5b,aAAa/zD,GAC9BinC,GAEF,MAEF,OACA,OACEA,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS+nD,OAAQxgF,EAAO0D,IAAI,GAAIujC,GACrD,MAEF,QACEA,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQk4D,OAAQpkD,GACpC,MAEF,QACEA,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQm4D,OAAQrkD,GACpC,MAEF,QACEx8B,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAM8V,UAST,GARAonB,GAAW,EACX34C,EAAO5mC,KAAKs0E,kBACVtqC,EAAW0e,QACXka,EAAemc,WAAU,GAKvB/+E,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiB3uB,KAAKsvE,YAAY3gD,eAGpC,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAa8C,YAC5C,CACZu2B,EAAO5mC,KAAKsiF,qBAAqB90D,EAAUwc,EAAW0e,QAAS9hB,EAAMoD,GACrE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAENpL,EAAO8rC,cAGhB,OAAQzrC,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASk9C,OAAQ1uC,EAAM5mC,KAAKL,OAAOyD,IAAI,IAC5D,MAEF,OACA,OACEwjC,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS2nD,OACTluB,EAAAz5B,SAASk9C,OACb1uC,EACA5mC,KAAKsvE,YAAY3b,YAAYh0D,IAE/B,MAEF,OACA,OACEinC,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS2nD,OAAQn5C,EAAMjnC,EAAO0D,IAAI,IACvD,MAEF,QACEujC,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS4nD,OAAQp5C,EAAMjnC,EAAOkE,IAAI,IACvD,MAEF,QACE+iC,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS6nD,OAAQr5C,EAAMjnC,EAAOmE,IAAI,IACvD,MAEF,QACEsG,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAM+V,YAST,GARAmnB,GAAW,EACX34C,EAAO5mC,KAAKs0E,kBACVtqC,EAAW0e,QACXka,EAAemc,WAAU,GAKvB/+E,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAE5C,GADIqP,EAAiB3uB,KAAKsvE,YAAY3gD,eAGpC,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAagD,YAC5C,CACZq2B,EAAO5mC,KAAKsiF,qBAAqB90D,EAAUwc,EAAW0e,QAAS9hB,EAAMoD,GACrE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAENpL,EAAO8rC,cAGhB,OAAQzrC,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS8nD,OAAQt5C,EAAMjnC,EAAOyD,IAAI,IACvD,MAEF,OACA,OACEwjC,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAAS+nD,OACTtuB,EAAAz5B,SAAS8nD,OACbt5C,EACA5mC,KAAKsvE,YAAY3b,YAAYh0D,IAE/B,MAEF,OACA,OACEinC,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS+nD,OAAQv5C,EAAMjnC,EAAO0D,IAAI,IACvD,MAEF,QACEujC,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASgoD,OAAQx5C,EAAMjnC,EAAOkE,IAAI,IACvD,MAEF,QACE+iC,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASioD,OAAQz5C,EAAMjnC,EAAOmE,IAAI,IACvD,MAEF,QACEsG,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAMsW,YAQT,GAPA/xB,EAAO5mC,KAAKs0E,kBACVtqC,EAAW0e,QACXka,EAAemc,WAAU,GAKvB/+E,KAAKsvE,YAAYhwD,GAAE,KAErB,GADIqP,EAAiB3uB,KAAKsvE,YAAY3gD,eAGpC,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAaiD,KAC5C,CACZo2B,EAAO5mC,KAAKsiF,qBAAqB90D,EAAUwc,EAAW0e,QAAS9hB,EAAMoD,GACrE,MAMNpD,EAAO5mC,KAAKkrF,eAAetkD,EAAM5mC,KAAKsvE,aACtCtvE,KAAKsvE,YAAc5hE,EAAAkH,KAAKhR,KACxB,MAEF,KAAKw+C,EAAAC,MAAMuW,MAYT,GAXAhyB,EAAO5mC,KAAKs0E,kBACVtqC,EAAW0e,QACXka,GAAkBl1D,EAAAkH,KAAKG,KACnBrH,EAAAkH,KAAKxR,IACLw/D,EAAetjD,GAAE,GACf5R,EAAAkH,KAAKvR,IACLu/D,EAAc,GAKlB5iE,KAAKsvE,YAAYhwD,GAAE,KAAuB,CAC5C,IAAIqP,EAEEnB,EADN,GADImB,EAAiB3uB,KAAKsvE,YAAY3gD,eAGpC,GADInB,EAAWmB,EAAexB,eAAeykC,EAAArkD,aAAakD,aAC5C,CACZm2B,EAAO5mC,KAAKsiF,qBAAqB90D,EAAUwc,EAAW0e,QAAS9hB,EAAMoD,GACrE,MAOJ,OAJAhqC,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAENpL,EAAO8rC,cAShB,OAPE7E,EAAO5mC,KAAKm9E,kBAAkBv2C,EAC5B5mC,KAAKsvE,YAAatvE,KAAKsvE,YAAY4R,SACnC,GAAO,EACPl3C,EAAW0e,SAIP1oD,KAAKsvE,YAAY74D,MACvB,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASspD,OAAQ96C,EAAMjnC,EAAOyD,KAAK,IACxD,MAEF,OACA,OACEwjC,EAAOjnC,EAAOmnC,OACZ9mC,KAAK0U,QAAQc,SACTq8C,EAAAz5B,SAASupD,OACT9vB,EAAAz5B,SAASspD,OACb96C,EACA5mC,KAAKsvE,YAAY1b,eAAej0D,IAElC,MAEF,OACA,OACEinC,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASupD,OAAQ/6C,EAAMjnC,EAAO0D,KAAK,GAAI,IAC5D,MAEF,QACE+G,QAAO,GACPw8B,EAAOjnC,EAAO8rC,cAGlB,MAEF,KAAK2W,EAAAC,MAAMyU,OAKT,OAJA92D,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf2oB,EAAWj/B,OAENpL,EAAO8rC,cAEhB,QAEE,OADArhC,QAAO,GACAzK,EAAO8rC,cAGlB,IAAK8zC,EAAU,OAAO34C,EACtB,IAAIv0B,EAAWrS,KAAKqS,SAChBgb,EAAShb,EAASywD,kBAAkB94B,EAAW0e,QAAS1oD,KAAK0wE,aACjE,OAAKrjD,EACErtB,KAAKqiF,eACVh1D,EACAuZ,EACAoD,EAAW0e,QACXr2C,EAASiuD,sBACTjuD,EAASkuD,yBACTqC,GAAkBl1D,EAAAkH,KAAKG,MAPLpV,EAAO8rC,eAY7B0jC,EAAAltE,UAAAm7E,uBAAA,SAAuBx2C,EAAqB3nB,GAC1C,IAAItf,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YAChB,OAAQzxD,EAAKxI,MACX,OACM2T,EAAKihD,YAAYzkC,EAAM3nB,KACzB2nB,EAAO5mC,KAAK0U,QAAQW,WAAU,GAC1B1V,EAAO+mC,MAAMmrB,EAAA/+B,QAAQq4D,cAAevkD,GACpCjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASo1C,OACrB7tE,EAAOmnC,OAAO+qB,EAAAz5B,SAASm1C,OACrB3mC,EACAjnC,EAAOyD,IAAI,KAEbzD,EAAOyD,IAAI,MAGnB,MAEF,OACMgnB,EAAKihD,YAAYzkC,EAAM3nB,KACzB2nB,EAAO5mC,KAAK0U,QAAQW,WAAU,GAC1B1V,EAAO+mC,MAAMmrB,EAAA/+B,QAAQs4D,eAAgBxkD,GACrCjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASo1C,OACrB7tE,EAAOmnC,OAAO+qB,EAAAz5B,SAASm1C,OACrB3mC,EACAjnC,EAAOyD,IAAI,KAEbzD,EAAOyD,IAAI,MAGnB,MAEF,OACMgnB,EAAKihD,YAAYzkC,EAAM3nB,KACzB2nB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASk1C,OAC5B1mC,EACAjnC,EAAOyD,IAAI,OAGf,MAEF,OACMgnB,EAAKihD,YAAYzkC,EAAM3nB,KACzB2nB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASk1C,OAC5B1mC,EACAjnC,EAAOyD,IAAI,SAGf,MAEF,QACMgnB,EAAKihD,YAAYzkC,EAAM3nB,KAEzB2nB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS+yC,MAC5BvkC,EACAjnC,EAAOyD,IAAI,KAMnB,OAAOwjC,GAITuoC,EAAAltE,UAAAq3E,iBAAA,SAAiB1yC,EAAqB77B,GACpC,IAAI68D,EAAiB5nE,KAAK0wE,YAAY9I,eAClCj8D,EAASZ,EAAMY,OACfA,EAAOmf,eAAiB,IAAGnf,EAAOmf,eAAiB9qB,KAAKL,OAAO22C,iBAAiB3qC,EAAOC,iBAC3Fb,EAAM8f,aAAe+b,EACrBghC,EAAe/+C,eAAenc,KAAK3B,IAMrCokE,EAAAltE,UAAAipF,eAAA,SAAetkD,EAAqB3nB,GAClC,IAAItf,EAASK,KAAKL,OAClB,OAAQsf,EAAKxI,MACX,OACA,OACA,OACA,OACA,QACEmwB,EAAO5mC,KAAKo9E,uBAAuBx2C,EAAM3nB,GAG3C,OACA,OACE,OAAOtf,EAAO+mC,MAAMmrB,EAAA/+B,QAAQg4C,OAAQlkC,GAEtC,OACA,OACE,OAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQi4C,OAAQnkC,GAEtC,OAAyB5mC,KAAK6vE,oBAAoBr7D,IAAIoyB,KAAOA,EAAO5mC,KAAKgjF,gBAAgBp8C,IACzF,OACE,OAAOjnC,EAAO+mC,MAAmB,IAAbznB,EAAK2sB,KAAaimB,EAAA/+B,QAAQi4C,OAASlZ,EAAA/+B,QAAQg4C,OAAQlkC,GAEzE,QACE,OAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASqzC,MAAO7kC,EAAMjnC,EAAOkE,IAAI,IAExD,QACE,OAAOlE,EAAOmnC,OAAO+qB,EAAAz5B,SAASszC,MAAO9kC,EAAMjnC,EAAOmE,IAAI,IAExD,QAEE,OADAsG,QAAO,GACAzK,EAAOyD,IAAI,KAMxB+rE,EAAAltE,UAAA63E,cAAA,SAAclzC,EAAqB3nB,GACjC,IAAItf,EAASK,KAAKL,OAClB,OAAQsf,EAAKxI,MACX,OACA,OACA,OACA,OACEmwB,EAAO5mC,KAAKo9E,uBAAuBx2C,EAAM3nB,GAG3C,QACA,OACA,OACE,OAAO2nB,EAET,OACA,OACE,OAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASgzC,MAAOxkC,EAAMjnC,EAAO0D,IAAI,IAExD,OAAyBrD,KAAK6vE,oBAAoBr7D,IAAIoyB,KAAOA,EAAO5mC,KAAKgjF,gBAAgBp8C,IACzF,OACE,OAAoB,IAAb3nB,EAAK2sB,KACRjsC,EAAOmnC,OAAO+qB,EAAAz5B,SAASgzC,MAAOxkC,EAAMjnC,EAAO0D,IAAI,IAC/CujC,EAEN,QACE,OAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASuzC,MAAO/kC,EAAMjnC,EAAOkE,IAAI,IAExD,QACE,OAAOlE,EAAOmnC,OAAO+qB,EAAAz5B,SAASwzC,MAAOhlC,EAAMjnC,EAAOmE,IAAI,IAExD,QAEE,OADAsG,QAAO,GACAzK,EAAOyD,IAAI,KAMxB+rE,EAAAltE,UAAAk0E,eAAA,SACExjE,GAGA,IAAI6S,EAAUxlB,KAAKwlB,QACnBpb,OAAOuI,EAAc6S,SAAWA,GAChC,IAAI7lB,EAASK,KAAKL,OACd+U,EAAU1U,KAAK0U,QACnB1U,KAAKsvE,YAAc38D,EAAcsM,KACjC,IAAItC,EAAgB6I,EAAQ7I,cAE5B,OADA3c,KAAKw1E,gBAAgB74D,GACdhd,EAAOa,KAAKmc,EAAcvK,aAAc,CAC7CsC,EAAQc,SACJ7V,EAAO0D,IAAIsP,EAAcyZ,qBACzBzsB,EAAOyD,IAAIuP,EAAcyZ,qBAC7BzsB,EAAOyD,IACLuP,EAAc0I,aAAau2C,EAAA7gD,eAAe0K,WACtC,EACA9I,EAAcG,KAEnB4B,EAAQq+D,iBAIb5D,EAAAltE,UAAAm0E,wBAAA,SACEzjE,EACAgjE,gBAAA,IAAAA,MAAA,IAEA,IAAI72D,EAAUnM,EAAcmM,QAC5B,IAAKA,EAAS,MAAO,GAErB,IAAInf,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YACZuE,EAAW7qD,EAAK9K,GAAE,OAClB+rE,EAAiBpW,EACjB7qE,OAAOggB,EAAKu6C,YAAYn3D,EAAAxK,cAAcoC,QAAQwiB,MAC9C,EACAmrD,EAAiB/yE,KAAK0U,QAAQq+D,mBAElC,IAAmB,IAAArsD,EAAA3O,EAAA+G,EAAQvB,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAE,CAAhC,IAAIqG,EAAMF,EAAA9c,MACb,GACEgd,EAAO7H,MAAQm7C,EAAA9gD,YAAY8N,OAC3BN,EAAOpK,QAAUvB,EAFnB,CAKA,IAAIgb,EAAerP,EAAQlU,QAAQujB,EAAM/L,MAAMpU,EAAAnL,YAAYod,QAC3D,IAAIknD,EAAYh5C,EAAM1O,KAClBukE,EAAkB7c,EAAUlT,eAC5B4gB,EAAkB1mD,EAAM1rB,UAAUoyE,gBACtC,GAAIA,EAAiB,CACnB,IAAIF,EAAWn0E,KAAKs0E,kBAAkBD,EAAiB1N,EACrD,IAEEA,EAAUiM,YAAc5yE,KAAK6vE,oBAAoBr7D,IAAI2/D,KACvDA,EAAWn0E,KAAK6yE,WAAWsB,IAE7BwB,EAAMjpE,KACJ/M,EAAO6mC,MAAMmgC,EAAUzU,SACrBvyD,EAAO2nC,UAAU+jD,EAAgBtY,GACjCoB,EACAqP,EACA71D,EAAMrC,mBAGL,CACL,IAAIF,EAAiBuC,EAAM1rB,UAAUmpB,eACrCuqD,EAAMjpE,KACJ/M,EAAO6mC,MAAMmgC,EAAUzU,SACrBvyD,EAAO2nC,UAAU+jD,EAAgBtY,GACjC3nD,GAAkB,EACdzrB,EAAO2nC,UACL2tC,EACI7qE,OAAOggB,EAAKu6C,YAAYh3C,EAAM/sB,OAAOgnB,MACrC,EAAIwD,EACRo4D,GAEF7c,EAAUjT,aAAa/zD,GAC3B6jF,EACA71D,EAAMrC,mHAKd,OAAOqqD,GAGTxG,EAAAltE,UAAAqpF,oBAAA,SACE1kD,EACAj0B,GAEA,IAAIhT,EAASK,KAAKL,OACdyqB,EAAOpqB,KAAK0wE,YACZ6a,EAASnhE,EAAKi+C,aAAa36D,EAAAkH,KAAKxR,KAChCooF,EAAS7rF,EAAOioC,KAAK,GAAG,EAC1BjoC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS8nD,OACrBt5C,EACAjnC,EAAOyD,IAAIpD,KAAKwlB,QAAQ4xD,oBAE1BvlB,EAAAriC,WAAWppB,KAETqjC,EAAQ,cAAgB92B,EAAc/R,KAAO,IAAMwpB,EAAKu/C,iBACxD8hB,EAA8B,GAmBlC,OAlBAA,EAAW/+E,KACT/M,EAAOoqC,KACLpqC,EAAOiqC,GAAGH,EACR9pC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS6yC,MACrBtrE,EAAO6nC,UAAU+jD,EAAO3jE,MAAO4jE,GAC/B7rF,EAAOyD,IAAIuP,EAAcG,KAE3BnT,EAAOyD,IAAI,MAMjBqoF,EAAW/+E,KACT/M,EAAOyD,IAAI,IAEbgnB,EAAK0+C,cAAcyiB,GACnBnhE,EAAKy/C,gBACElqE,EAAO6pC,MAAMC,EAAOgiD,EAAY55B,EAAAriC,WAAWppB,MAEtD+oE,EAt+QA,CAA8B1hE,EAAAX,mBA0+Q9B,SAAS6nE,EACP/7D,EACArE,GAQA,GALA06D,EAA8B16D,EAAYxJ,MAAMY,OAAOskD,WAEvDif,EAA+Btd,EAAA/qC,mBAC7BjO,EAAQhY,KAAMgY,EAAQ1E,OAAQ0E,EAAQ0G,GAAG9R,EAAAnL,YAAY4iB,WAAW,GAE7DrM,EAAQyC,aAAau2C,EAAA7gD,eAAeiU,UAAzC,CAEA,IAAIQ,EAAU5M,EAAQ4M,QAClB/E,EAAYrW,OAAOuD,EAAA+jD,cAAc/jD,EAAAe,cAAcsW,SAAUzQ,EAAYgM,aACrE2jC,EAAOzjC,EAAUuC,UACrB,GAAIkhC,GAAQA,EAAK/3C,OAAQ,CACvB,IAAIsC,EAAMy1C,EAAK,GAGXz1C,EAAIgI,MAAQ9I,EAAA+I,SAASwM,SAA+BzU,EAAK0U,aAAexV,EAAAyV,YAAYC,QACtF6rD,EAAyDzgE,EAAKnN,MAC1D4iD,EAAK/3C,QAAU,KACjBsC,EAAMy1C,EAAK,IACHztC,MAAQ9I,EAAA+I,SAASwM,SAA+BzU,EAAK0U,aAAexV,EAAAyV,YAAYC,QACtF4rD,EAA8BC,EAC9BA,EAAyDzgE,EAAKnN,MAC1D4iD,EAAK/3C,OAAS,GAChBqZ,EAAQnY,MACNI,EAAAhD,eAAekZ,+BACflD,EAAU1V,MAAO,IAAKm5C,EAAK/3C,OAAOT,aAItC8Z,EAAQnY,MACNI,EAAAhD,eAAeiZ,wBACfjV,EAAI1D,SAKVya,EAAQnY,MACNI,EAAAhD,eAAeiZ,wBACfjV,EAAI1D,YAIRya,EAAQnY,MACNI,EAAAhD,eAAew6E,wCACfxkE,EAAU1V,MAAO,IAAK,MAS5B,SAAgB0rE,EAAQ92E,EAAgBg2E,EAAwB12D,GAC9D,IAAI9S,EAASwpE,EAAMxpE,OACnB,GAAc,GAAVA,EAAa,OAAOxM,EAAO6qC,MAC/B,GAAc,GAAVr+B,EAAa,CACf,IAAIu/E,EAAS/V,EAAM,GACnB,GAAI9jB,EAAA7a,kBAAkB00C,IAAWzsE,EAAM,OAAOysE,EAC9C,GAAI75B,EAAA9a,gBAAgB20C,IAAW75B,EAAApiC,aAAa8uB,MAAO,CAGjD,IAFA,IAAIo9B,EAAQ9pB,EAAA5Y,mBAAmByyC,GAC3BhiD,EAAW,IAAIziC,MAAqB00E,GAC/Bt7E,EAAI,EAAGA,EAAIs7E,IAASt7E,EAAGqpC,EAASrpC,GAAKwxD,EAAA1Y,cAAcuyC,EAAQrrF,GACpE,OAAOV,EAAO6pC,MAAMqoB,EAAA9Y,aAAa2yC,GAAShiD,EAAUzqB,IAGxD,OAAOtf,EAAO6pC,MAAM,KAAMmsC,EACxB12D,GAAQ4yC,EAAAriC,WAAWm8D,KACf95B,EAAA7a,kBAAkB2+B,EAAMxpE,EAAS,IACjC8S,GAnjRKvf,EAAAyvE,WAmiRbzvE,EAAA+2E,yFCvyRA,SAAYhsE,GACVA,IAAA,uDACAA,IAAA,+CACAA,IAAA,qCACAA,IAAA,mHACAA,IAAA,6LACAA,IAAA,6EACAA,IAAA,yFACAA,IAAA,uEACAA,IAAA,qEACAA,IAAA,uEACAA,IAAA,qIACAA,IAAA,mGACAA,IAAA,yEACAA,IAAA,+FACAA,IAAA,yFACAA,IAAA,mEACAA,IAAA,+CACAA,IAAA,mFACAA,IAAA,+FACAA,IAAA,mHACAA,IAAA,yFACAA,IAAA,uJACAA,IAAA,mFACAA,IAAA,6FACAA,IAAA,+FACAA,IAAA,iGACAA,IAAA,2DACAA,IAAA,iIACAA,IAAA,yDACAA,IAAA,gEACAA,IAAA,gDACAA,IAAA,gCACAA,IAAA,0FACAA,IAAA,8DACAA,IAAA,0CACAA,IAAA,4GACAA,IAAA,gHACAA,IAAA,0HACAA,IAAA,sGACAA,IAAA,0GACAA,IAAA,wEACAA,IAAA,gFACAA,IAAA,gGACAA,IAAA,sGACAA,IAAA,gHACAA,IAAA,oFACAA,IAAA,4EACAA,IAAA,8HACAA,IAAA,8HACAA,IAAA,wFACAA,IAAA,gHACAA,IAAA,gFACAA,IAAA,oKACAA,IAAA,kLACAA,IAAA,8HACAA,IAAA,gDACAA,IAAA,oCACAA,IAAA,gJACAA,IAAA,4CACAA,IAAA,8FACAA,IAAA,oGACAA,IAAA,sCACAA,IAAA,8DACAA,IAAA,sDACAA,IAAA,4CACAA,IAAA,4DACAA,IAAA,kIACAA,IAAA,wIACAA,IAAA,sDACAA,IAAA,wDACAA,IAAA,oEACAA,IAAA,kDACAA,IAAA,wFACAA,IAAA,wFACAA,IAAA,gHACAA,IAAA,oDACAA,IAAA,kDACAA,IAAA,0HACAA,IAAA,gKACAA,IAAA,kFACAA,IAAA,oEACAA,IAAA,kKACAA,IAAA,kJACAA,IAAA,0IACAA,IAAA,oFACAA,IAAA,sIACAA,IAAA,sDACAA,IAAA,8CACAA,IAAA,4EACAA,IAAA,4FACAA,IAAA,oDACAA,IAAA,8EACAA,IAAA,kFACAA,IAAA,sGACAA,IAAA,0GACAA,IAAA,oMACAA,IAAA,gFACAA,IAAA,sNACAA,IAAA,0JACAA,IAAA,sIACAA,IAAA,4LACAA,IAAA,sLACAA,IAAA,oGACAA,IAAA,gIACAA,IAAA,8HACAA,IAAA,oGACAA,IAAA,oFACAA,IAAA,wKACAA,IAAA,kHACAA,IAAA,4EACAA,IAAA,4KACAA,IAAA,sMACAA,IAAA,0DACAA,IAAA,8FACAA,IAAA,4JACAA,IAAA,gIACAA,IAAA,wDACAA,IAAA,gJACAA,IAAA,gJACAA,IAAA,sGACAA,IAAA,sEACAA,IAAA,wFACAA,IAAA,gFACAA,IAAA,sQACAA,IAAA,8KACAA,IAAA,kLACAA,IAAA,kFACAA,IAAA,0IACAA,IAAA,kDACAA,IAAA,0CACAA,IAAA,wFACAA,IAAA,4HACAA,IAAA,6KACAA,IAAA,2MAtIF,CAAY/K,EAAA+K,iBAAA/K,EAAA+K,eAAc,KA0I1B/K,EAAAgL,uBAAA,SAAuCG,GACrC,OAAQA,GACN,KAAK,IAAK,MAAO,2BACjB,KAAK,IAAK,MAAO,uBACjB,KAAK,IAAK,MAAO,oBACjB,KAAK,IAAK,MAAO,iEACjB,KAAK,IAAK,MAAO,sGACjB,KAAK,IAAK,MAAO,8CACjB,KAAK,IAAK,MAAO,oDACjB,KAAK,IAAK,MAAO,uCACjB,KAAK,IAAK,MAAO,kCACjB,KAAK,IAAK,MAAO,mCACjB,KAAK,IAAK,MAAO,kEACjB,KAAK,IAAK,MAAO,iDACjB,KAAK,IAAK,MAAO,oCACjB,KAAK,IAAK,MAAO,uDACjB,KAAK,IAAK,MAAO,gDACjB,KAAK,IAAK,MAAO,qCACjB,KAAK,IAAK,MAAO,uBACjB,KAAK,IAAK,MAAO,6CACjB,KAAK,IAAK,MAAO,+CACjB,KAAK,IAAK,MAAO,6DACjB,KAAK,IAAK,MAAO,gDACjB,KAAK,IAAK,MAAO,iFACjB,KAAK,IAAK,MAAO,yCACjB,KAAK,IAAK,MAAO,8CACjB,KAAK,IAAK,MAAO,+CACjB,KAAK,IAAK,MAAO,2DACjB,KAAK,IAAK,MAAO,gCACjB,KAAK,IAAK,MAAO,iEACjB,KAAK,IAAK,MAAO,8BACjB,KAAK,KAAM,MAAO,+BAClB,KAAK,KAAM,MAAO,uBAClB,KAAK,KAAM,MAAO,kBAClB,KAAK,KAAM,MAAO,4CAClB,KAAK,KAAM,MAAO,8BAClB,KAAK,KAAM,MAAO,oBAClB,KAAK,KAAM,MAAO,qDAClB,KAAK,KAAM,MAAO,uDAClB,KAAK,KAAM,MAAO,4DAClB,KAAK,KAAM,MAAO,kDAClB,KAAK,KAAM,MAAO,oDAClB,KAAK,KAAM,MAAO,sCAClB,KAAK,KAAM,MAAO,uCAClB,KAAK,KAAM,MAAO,+CAClB,KAAK,KAAM,MAAO,oDAClB,KAAK,KAAM,MAAO,yDAClB,KAAK,KAAM,MAAO,2CAClB,KAAK,KAAM,MAAO,qCAClB,KAAK,KAAM,MAAO,8DAClB,KAAK,KAAM,MAAO,8DAClB,KAAK,KAAM,MAAO,2CAClB,KAAK,KAAM,MAAO,yDAClB,KAAK,KAAM,MAAO,uCAClB,KAAK,KAAM,MAAO,mFAClB,KAAK,KAAM,MAAO,0FAClB,KAAK,KAAM,MAAO,gEAClB,KAAK,KAAM,MAAO,uBAClB,KAAK,KAAM,MAAO,iBAClB,KAAK,KAAM,MAAO,2EAClB,KAAK,KAAM,MAAO,yBAClB,KAAK,KAAM,MAAO,8CAClB,KAAK,KAAM,MAAO,iDAClB,KAAK,KAAM,MAAO,kBAClB,KAAK,KAAM,MAAO,8BAClB,KAAK,KAAM,MAAO,0BAClB,KAAK,KAAM,MAAO,qBAClB,KAAK,KAAM,MAAO,gCAClB,KAAK,KAAM,MAAO,iEAClB,KAAK,KAAM,MAAO,qEAClB,KAAK,KAAM,MAAO,0BAClB,KAAK,KAAM,MAAO,2BAClB,KAAK,KAAM,MAAO,iCAClB,KAAK,KAAM,MAAO,wBAClB,KAAK,KAAM,MAAO,4CAClB,KAAK,KAAM,MAAO,2CAClB,KAAK,KAAM,MAAO,yDAClB,KAAK,KAAM,MAAO,yBAClB,KAAK,KAAM,MAAO,wBAClB,KAAK,KAAM,MAAO,4DAClB,KAAK,KAAM,MAAO,+EAClB,KAAK,KAAM,MAAO,wCAClB,KAAK,KAAM,MAAO,iCAClB,KAAK,KAAM,MAAO,mFAClB,KAAK,KAAM,MAAO,4EAClB,KAAK,KAAM,MAAO,wEAClB,KAAK,KAAM,MAAO,yCAClB,KAAK,KAAM,MAAO,kEAClB,KAAK,KAAM,MAAO,8BAClB,KAAK,KAAM,MAAO,0BAClB,KAAK,KAAM,MAAO,6CAClB,KAAK,KAAM,MAAO,oDAClB,KAAK,KAAM,MAAO,6BAClB,KAAK,KAAM,MAAO,8CAClB,KAAK,KAAM,MAAO,4CAClB,KAAK,KAAM,MAAO,mDAClB,KAAK,KAAM,MAAO,qDAClB,KAAK,KAAM,MAAO,iGAClB,KAAK,KAAM,MAAO,+CAClB,KAAK,KAAM,MAAO,+GAClB,KAAK,KAAM,MAAO,8EAClB,KAAK,KAAM,MAAO,oEAClB,KAAK,KAAM,MAAO,6FAClB,KAAK,KAAM,MAAO,0FAClB,KAAK,KAAM,MAAO,6DAClB,KAAK,KAAM,MAAO,iEAClB,KAAK,KAAM,MAAO,gEAClB,KAAK,KAAM,MAAO,oDAClB,KAAK,KAAM,MAAO,yCAClB,KAAK,KAAM,MAAO,mFAClB,KAAK,KAAM,MAAO,wDAClB,KAAK,KAAM,MAAO,qCAClB,KAAK,KAAM,MAAO,yFAClB,KAAK,KAAM,MAAO,kGAClB,KAAK,KAAM,MAAO,oCAClB,KAAK,KAAM,MAAO,sDAClB,KAAK,KAAM,MAAO,+EAClB,KAAK,KAAM,MAAO,mEAClB,KAAK,KAAM,MAAO,6BAClB,KAAK,KAAM,MAAO,2EAClB,KAAK,KAAM,MAAO,uEAClB,KAAK,KAAM,MAAO,sDAClB,KAAK,KAAM,MAAO,uCAClB,KAAK,KAAM,MAAO,gDAClB,KAAK,KAAM,MAAO,4CAClB,KAAK,KAAM,MAAO,mIAClB,KAAK,KAAM,MAAO,0FAClB,KAAK,KAAM,MAAO,4FAClB,KAAK,KAAM,MAAO,gDAClB,KAAK,KAAM,MAAO,oEAClB,KAAK,KAAM,MAAO,4BAClB,KAAK,KAAM,MAAO,wBAClB,KAAK,KAAM,MAAO,2CAClB,KAAK,KAAM,MAAO,6DAClB,KAAK,MAAO,MAAO,wFACnB,KAAK,MAAO,MAAO,uGACnB,QAAS,MAAO,mkBCrRnB,IAoFgBm6D,EApFhB4mB,EAAAzrF,EAAA,IAODsN,EAAAtN,EAAA,GAIAwN,EAAAxN,EAAA,GAUAuN,EAAAvN,EAAA,GAOA0xD,EAAA1xD,EAAA,GAsBAyxD,EAAAzxD,EAAA,GASA0N,EAAA1N,EAAA,IAKAyN,EAAAzN,EAAA,GAIAqN,EAAArN,EAAA,GAMA0J,EAAA1J,EAAA,GAubA,SAAgB0kF,EAEdgH,EAEA5pF,EAEAgqB,EAEAkb,EAEAy7B,EAEAmD,EAEA+lB,QAAA,IAAAA,OAAA,GAEA,IAAInsF,EAASksF,EAASlsF,OAUlBosF,GAAY,EAEhB,OAAQ9pF,EAAUmQ,cAIhB,KAAK4yD,EAAegnB,UAClB,IAAI/sE,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,OADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACvBqb,EACEA,EAAKK,GAAE,KAAwBL,EAAKK,GAAE,KACzC3f,EAAOyD,IAAI,GACXzD,EAAOyD,IAAI,GAHGzD,EAAO8rC,cAK3B,KAAKu5B,EAAeknB,QACdjtE,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,OADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACvBqb,EACEA,EAAKK,GAAE,GACV3f,EAAOyD,IAAI,GACXzD,EAAOyD,IAAI,GAHGzD,EAAO8rC,cAK3B,KAAKu5B,EAAemnB,UACdltE,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,OADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACvBqb,EACEA,GAAQvR,EAAAkH,KAAKhR,KAChBjE,EAAOyD,IAAI,GACXzD,EAAOyD,IAAI,GAHGzD,EAAO8rC,cAK3B,KAAKu5B,EAAeonB,SACdntE,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,OADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACvBqb,EACEA,EAAKK,GAAE,GACV3f,EAAOyD,IAAI,GACXzD,EAAOyD,IAAI,GAHGzD,EAAO8rC,cAK3B,KAAKu5B,EAAeqnB,YACdptE,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,OADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACvBqb,EACEA,EAAKK,GAAE,KACV3f,EAAOyD,IAAI,GACXzD,EAAOyD,IAAI,GAHGzD,EAAO8rC,cAK3B,KAAKu5B,EAAesnB,SACdrtE,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,GADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,MACvBqb,EAAM,OAAOtf,EAAO8rC,cAEzB,GADIsnB,EAAY9zC,EAAK0P,eACN,CACb,IAAI1U,EAAiB4xE,EAASrmE,QAAQvL,eACtC,GAAIA,GAAkB84C,EAAU3lC,eAAenT,GAAiB,OAAOta,EAAOyD,IAAI,GAEpF,OAAOzD,EAAOyD,IAAI,GAEpB,KAAK4hE,EAAeunB,QACdttE,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,GADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,MACvBqb,EAAM,OAAOtf,EAAO8rC,cAEzB,KADI9c,GAAiB1P,EAAK0P,gBACL,OAAOhvB,EAAOyD,IAAI,GACvC,IAAI0f,EAAiB6L,GAAe1sB,UACpC,OAAOtC,EAAOyD,IAAI0f,EAAegJ,QAAQ+/D,EAASrmE,QAAQnJ,gBAAkB,EAAI,GAElF,KAAK2oD,EAAewnB,YACdvtE,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,OADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACvBqb,GACD0P,GAAiB1P,EAAK0P,gBAEnBhvB,EAAOyD,IAAIurB,GAAe69D,YAAc,EAAI,GADvB7sF,EAAOyD,IAAI,GAFrBzD,EAAO8rC,cAK3B,KAAKu5B,EAAeynB,WACdxtE,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,OADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACvBqb,EACEtf,EAAOyD,IAAI6b,EAAKmzC,mBAAqB,EAAI,GAD9BzyD,EAAO8rC,cAG3B,KAAKu5B,EAAe3hB,WACdpkC,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,OADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACvBqb,EACEtf,EAAOyD,IAAI6b,EAAKK,GAAE,KAAuB,EAAI,GADlC3f,EAAO8rC,cAG3B,KAAKu5B,EAAe0nB,UAElB,GADAb,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KAE1B+oF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAChB,IAAI7yB,EAAUizE,EAASx5E,SAASywD,kBAC9B37B,EAAS,GACT0kD,EAASnb,YACThjE,EAAAkH,KAAKG,KACLnH,EAAAwyD,WAAWysB,SAEb,OAAOltF,EAAOyD,IAAIwV,EAAU,EAAI,GAElC,KAAKosD,EAAe8nB,WAElB,GADAjB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KAE1B+oF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAChB,IAAI7E,EAAOilD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK89C,MAExD,OADAm5B,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACrBjE,EAAOyD,IAAIyuD,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAaolB,MAAQ,EAAI,GAEtE,KAAKmwB,EAAe4N,UACd3zD,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,OADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACvBqb,EACEtf,EAAOyD,IAAI6b,EAAK2zD,UAAY,EAAI,GADrBjzE,EAAO8rC,cAG3B,KAAKu5B,EAAe+nB,OAElB,GADAlB,EAASvc,YAAcuc,EAASn3E,QAAQI,UAEtCk4E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7Ce,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAChB,IAAIymB,EAAoBjmC,EAAe,GAAGimC,SACtCtrB,OAAI,EAkBR,OAjBIilD,EAASn3E,QAAQc,SAEfotD,EAAetjD,GAAE,IAAuBsjD,EAAeh3B,MAAQ,IACjEigD,EAASvc,YAAc5hE,EAAAkH,KAAKnR,IAC5BmjC,EAAOjnC,EAAOyD,IAAI8uD,IAElBtrB,EAAOjnC,EAAO0D,IAAI6uD,EAAU,GAI1B0Q,EAAetjD,GAAE,IAA8C,IAAvBsjD,EAAeh3B,MACzDigD,EAASvc,YAAc5hE,EAAAkH,KAAKlR,IAC5BkjC,EAAOjnC,EAAO0D,IAAI6uD,EAAU,IAE5BtrB,EAAOjnC,EAAOyD,IAAI8uD,GAGftrB,EAET,KAAKo+B,EAAeioB,QAElB,GADApB,EAASvc,YAAcuc,EAASn3E,QAAQI,UAEtCk4E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7Ce,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZymB,EAAoBjmC,EAAe,GAAGimC,SAC1C9nD,OAAOP,EAAAJ,WAAWyoD,IAClB,IAAIu3B,EAAYyD,IAASh7B,GACrBtrB,OAAI,EAkBR,OAjBIilD,EAASn3E,QAAQc,SAEfotD,EAAetjD,GAAE,IAAuBsjD,EAAeh3B,MAAQ,IACjEigD,EAASvc,YAAc5hE,EAAAkH,KAAKnR,IAC5BmjC,EAAOjnC,EAAOyD,IAAIqmF,IAElB7iD,EAAOjnC,EAAO0D,IAAIomF,EAAW,GAI3B7mB,EAAetjD,GAAE,IAA8C,IAAvBsjD,EAAeh3B,MACzDigD,EAASvc,YAAc5hE,EAAAkH,KAAKlR,IAC5BkjC,EAAOjnC,EAAO0D,IAAIomF,EAAW,IAE7B7iD,EAAOjnC,EAAOyD,IAAIqmF,GAGf7iD,EAET,KAAKo+B,EAAev3C,SAElB,GADAo+D,EAASvc,YAAcuc,EAASn3E,QAAQI,UAEtCk4E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7CsB,EAAkBhmD,EAAU,EAAG,EAAG4+B,EAAY8lB,GAC9C,OAAOlsF,EAAO8rC,cAChB,IAAIsnB,EACJ,KADIA,EAAY9mC,EAAe,GAAG0C,gBAMhC,OAJAk9D,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEhB,IAAI/4B,OAAM,EACV,GAAIy0B,EAASh7B,OAAQ,CACnB,GACEg7B,EAAS,GAAG1wB,MAAQ9I,EAAA+I,SAASwM,SACTikB,EAAS,GAAIhkB,aAAexV,EAAAyV,YAAYC,OAM5D,OAJAwoE,EAASx+E,MACPI,EAAAhD,eAAeiZ,wBACfyjB,EAAS,GAAGp8B,OAEPpL,EAAO8rC,cAEhB,IAAI/d,EAAsCyZ,EAAS,GAAI7lC,MACnDqsB,EAAQolC,EAAUj0C,QAAUi0C,EAAUj0C,QAAQ5d,IAAIwsB,GAAa,KACnE,IAAMC,GAASA,EAAMlX,MAAQm7C,EAAA9gD,YAAY8N,MAKvC,OAJAitE,EAASx+E,MACPI,EAAAhD,eAAe4iF,yBACflmD,EAAS,GAAGp8B,MAAOgoD,EAAU3gD,aAAcsb,GAEtC/tB,EAAO8rC,cAEhB/4B,EAAiBib,EAAOrC,kBAExB5Y,EAASqgD,EAAU3mC,oBAErB,OAAIy/D,EAASn3E,QAAQc,SAEfotD,EAAetjD,GAAE,IAAuBsjD,EAAeh3B,MAAQ,IACjEigD,EAASvc,YAAc5hE,EAAAkH,KAAKnR,IACrB9D,EAAOyD,IAAIsP,IAEX/S,EAAO0D,IAAIqP,GAIhBkwD,EAAetjD,GAAE,IAA8C,IAAvBsjD,EAAeh3B,MACzDigD,EAASvc,YAAc5hE,EAAAkH,KAAKlR,IACrB/D,EAAO0D,IAAIqP,IAEX/S,EAAOyD,IAAIsP,GAOxB,KAAKsyD,EAAerS,IACpB,KAAKqS,EAAekoB,IACpB,KAAKloB,EAAesoB,OAClB,GACEC,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAChB,IAAIxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAI,GAC1D4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKxR,IAAG,GAEpD,IADI6b,EAAO4sE,EAASvc,aACXhwD,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEhB,IAAI9E,GAAe,EACnB,OAAQ1kC,EAAUmQ,cAChB,KAAK4yD,EAAerS,IAClB,OAAQ1zC,EAAKxI,MACX,QACA,OACA,OACA,OACA,OACA,OACA,OAAqBkwB,EAAKkrB,EAAA/+B,QAAQ+6C,OAAQ,MAC1C,OACA,OACElnC,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAA/+B,QAAQ06D,OACR37B,EAAA/+B,QAAQ+6C,OACZ,MAEF,OACA,OAAqBlnC,EAAKkrB,EAAA/+B,QAAQ06D,OAEpC,MAEF,KAAKxoB,EAAekoB,IAClB,OAAQjuE,EAAKxI,MACX,QACA,OACA,OACA,OACA,OACA,OACA,OAAqBkwB,EAAKkrB,EAAA/+B,QAAQg7C,OAAQ,MAC1C,OACA,OACEnnC,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAA/+B,QAAQ26D,OACR57B,EAAA/+B,QAAQg7C,OACZ,MAEF,OACA,OAAqBnnC,EAAKkrB,EAAA/+B,QAAQ26D,OAEpC,MAEF,KAAKzoB,EAAesoB,OAClB,OAAQzB,EAASvc,YAAY74D,MAC3B,QACA,OACA,OACA,OACA,OACA,OACA,OAAqBkwB,EAAKkrB,EAAA/+B,QAAQi7C,UAAW,MAC7C,OACA,OACEpnC,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAA/+B,QAAQ46D,UACR77B,EAAA/+B,QAAQi7C,UACZ,MAEF,OACA,OAAqBpnC,EAAKkrB,EAAA/+B,QAAQ46D,WAKxC,OAAW,GAAP/mD,GACFklD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,eAET9rC,EAAO+mC,MAAMC,EAAI17B,GAE1B,KAAK+5D,EAAe2oB,KAClB,GACEJ,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAI,GAC1D4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKxR,IAAG,GAEpD,IADI6b,EAAO4sE,EAASvc,aACXhwD,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEhB,IAAIvgC,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIloB,EAAI,GACnD2nB,OAAI,EACR,OAAQ3nB,EAAKxI,MACX,OACA,OACA,OACA,OACA,QACEmwB,EAAOilD,EAASzO,uBACdz9E,EAAOmnC,OAAO+qB,EAAAz5B,SAASw1D,QAAS3iF,EAAMC,GACtC+T,GAIJ,OACA,OACE2nB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASw1D,QAAS3iF,EAAMC,GAC7C,MAEF,OACA,OACE07B,EAAOjnC,EAAOmnC,OACZ+kD,EAASn3E,QAAQc,SACbq8C,EAAAz5B,SAASy1D,QACTh8B,EAAAz5B,SAASw1D,QACb3iF,EAAMC,GAER,MAEF,OACA,OACE07B,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASy1D,QAAS5iF,EAAMC,GAC7C,MAEF,QACE2gF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbxmD,EAAOjnC,EAAO8rC,cAIlB,OAAO7E,EAET,KAAKo+B,EAAe8oB,KAClB,GACEP,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAI,GAC1D4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKxR,IAAG,GAEpD,IADI6b,EAAO4sE,EAASvc,aACXhwD,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZvgC,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIloB,EAAI,GACnD2nB,OAAI,EACR,OAAQ3nB,EAAKxI,MACX,OACA,OACA,OACA,OACA,QACEmwB,EAAOilD,EAASzO,uBACdz9E,EAAOmnC,OAAO+qB,EAAAz5B,SAAS21D,QAAS9iF,EAAMC,GACtC+T,GAEF,MAEF,OACA,OACE2nB,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS21D,QAAS9iF,EAAMC,GAC7C,MAEF,OACA,OACE07B,EAAOjnC,EAAOmnC,OACZ+kD,EAASn3E,QAAQc,SACbq8C,EAAAz5B,SAAS41D,QACTn8B,EAAAz5B,SAAS21D,QACb9iF,EAAMC,GAER,MAEF,OACA,OACE07B,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAAS41D,QAAS/iF,EAAMC,GAC7C,MAEF,QACE2gF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbxmD,EAAOjnC,EAAO8rC,cAIlB,OAAO7E,EAET,KAAKo+B,EAAeipB,IAClB,GACEV,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAI,GAC1D4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK9Q,IAAG,GAEpD,IADImb,EAAO4sE,EAASvc,aACXhwD,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZ7E,OAAI,EACR,OAAQ3nB,EAAKxI,MACX,OACA,OACA,OACE,IAGIy3E,GAHA9jE,EAAOyhE,EAASnb,aAGErI,aAAa36D,EAAAkH,KAAKxR,KACpC+qF,EAAkB/jE,EAAK2+C,oBAAoBr7D,EAAAkH,KAAKxR,KAAKwkB,MACrDwmE,EAAkBF,EAAWtmE,MAGjCgf,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASspD,OAC5B/hF,EAAOmnC,OAAO+qB,EAAAz5B,SAASk9C,OACrB31E,EAAO6nC,UACL2mD,EACAxuF,EAAOmnC,OAAO+qB,EAAAz5B,SAASo1C,OACrB7tE,EAAO6nC,UAAU4mD,EAAiBnjF,GAClCtL,EAAOyD,IAAI,MAGfzD,EAAO2nC,UAAU8mD,EAAiBv8B,EAAAriC,WAAWppB,MAE/CzG,EAAO2nC,UAAU6mD,EAAiBt8B,EAAAriC,WAAWppB,MAG/CgkB,EAAK0+C,cAAcolB,GACnB,MAEF,OACE,IAAIx5E,EAAUm3E,EAASn3E,QACnB0V,EAAOyhE,EAASnb,YAChB2d,EAAS35E,EAAQc,SAEjB04E,EAAa9jE,EAAKi+C,aAAa3zD,EAAQI,WACvCq5E,EAAkB/jE,EAAK2+C,oBAAoBr0D,EAAQI,WAAW8S,MAC9DwmE,EAAkBF,EAAWtmE,MAEjCgf,EAAOjnC,EAAOmnC,OAAOunD,EAASx8B,EAAAz5B,SAASupD,OAAS9vB,EAAAz5B,SAASspD,OACvD/hF,EAAOmnC,OAAOunD,EAASx8B,EAAAz5B,SAAS2nD,OAASluB,EAAAz5B,SAASk9C,OAChD31E,EAAO6nC,UACL2mD,EACAxuF,EAAOmnC,OAAOunD,EAASx8B,EAAAz5B,SAASipD,OAASxvB,EAAAz5B,SAASo1C,OAChD7tE,EAAO6nC,UAAU4mD,EAAiBnjF,GAClCojF,EAAS1uF,EAAO0D,IAAI,IAAM1D,EAAOyD,IAAI,MAGzCzD,EAAO2nC,UAAU8mD,EAAiB15E,EAAQq+D,iBAE5CpzE,EAAO2nC,UAAU6mD,EAAiBz5E,EAAQq+D,iBAG5C3oD,EAAK0+C,cAAcolB,GACnB,MAEF,OAGMA,GAFA9jE,EAAOyhE,EAASnb,aAEErI,aAAa36D,EAAAkH,KAAKvR,KACpC8qF,EAAkB/jE,EAAK2+C,oBAAoBr7D,EAAAkH,KAAKvR,KAAKukB,MACrDwmE,EAAkBF,EAAWtmE,MAGjCgf,EAAOjnC,EAAOmnC,OAAO+qB,EAAAz5B,SAASupD,OAC5BhiF,EAAOmnC,OAAO+qB,EAAAz5B,SAAS2nD,OACrBpgF,EAAO6nC,UACL2mD,EACAxuF,EAAOmnC,OAAO+qB,EAAAz5B,SAASipD,OACrB1hF,EAAO6nC,UAAU4mD,EAAiBnjF,GAClCtL,EAAO0D,IAAI,MAGf1D,EAAO2nC,UAAU8mD,EAAiBv8B,EAAAriC,WAAWnpB,MAE/C1G,EAAO2nC,UAAU6mD,EAAiBt8B,EAAAriC,WAAWnpB,MAG/C+jB,EAAK0+C,cAAcolB,GACnB,MAEF,OACA,OACA,OACA,OACA,OACA,QACEtnD,EAAO37B,EACP,MAEF,QACE27B,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQw7D,OAAQrjF,GACpC,MAEF,QACE27B,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQy7D,OAAQtjF,GACpC,MAEF,QACE4gF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbxmD,EAAOjnC,EAAO8rC,cAIlB,OAAO7E,EAET,KAAKo+B,EAAe2F,IAClB,GACE4iB,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAI,GAC1D4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK9Q,IAAG,GAEpD,IADImb,EAAO4sE,EAASvc,aACXhwD,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZvgC,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIloB,EAAM,GACrD0nB,OAAE,EACN,OAAQ1nB,EAAKxI,MACX,OACA,OACA,OAAqBkwB,EAAKkrB,EAAAz5B,SAASq0C,MAAO,MAC1C,OACA,OACA,OACA,QAAsB9lC,EAAKkrB,EAAAz5B,SAASs0C,MAAO,MAC3C,OAAqB/lC,EAAKkrB,EAAAz5B,SAASu0C,MAAO,MAC1C,OAAqBhmC,EAAKkrB,EAAAz5B,SAASw0C,MAAO,MAC1C,OACEjmC,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAAz5B,SAASu0C,MACT9a,EAAAz5B,SAASq0C,MACb,MAEF,OACE9lC,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAAz5B,SAASw0C,MACT/a,EAAAz5B,SAASs0C,MACb,MAEF,QACE,OAAO/sE,EAAOmnC,OAAO+qB,EAAAz5B,SAASo2D,OAAQvjF,EAAMC,GAE9C,QACE,OAAOvL,EAAOmnC,OAAO+qB,EAAAz5B,SAASq2D,OAAQxjF,EAAMC,GAE9C,QAKE,OAJA2gF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAGdrhB,EAAOyhE,EAASnb,YAApB,IACIoC,EAAa7zD,EAAKw0C,eAClBi7B,EAAatkE,EAAKi+C,aAAappD,GACnCmL,EAAKw+C,aAAa8lB,EAAW9mE,MAAO/Z,EAAAw5D,WAAWiE,SAC3C4iB,EAAa9jE,EAAK2+C,oBAAoB9pD,GAG1C,OAFAmL,EAAKw+C,aAAaslB,EAAWtmE,MAAO/Z,EAAAw5D,WAAWiE,SAC/ClhD,EAAK0+C,cAAc4lB,GACZ/uF,EAAOirC,OACZjrC,EAAO6nC,UAAUknD,EAAW9mE,MAAO3c,GACnCtL,EAAO6nC,UAAU0mD,EAAWtmE,MAAO1c,GACnCvL,EAAOmnC,OAAOH,EACZhnC,EAAO2nC,UAAUonD,EAAW9mE,MAAOkrD,GACnCnzE,EAAO2nC,UAAU4mD,EAAWtmE,MAAOkrD,KAIzC,KAAK9N,EAAe2pB,IAClB,GACEpB,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAI,GAC1D4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK9Q,IAAG,GAEpD,IADImb,EAAO4sE,EAASvc,aACXhwD,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZvgC,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIloB,EAAM,GACrD0nB,OAAE,EACN,OAAQ1nB,EAAKxI,MACX,OACA,OACA,OAAqBkwB,EAAKkrB,EAAAz5B,SAASyzC,MAAO,MAC1C,OACA,OACA,OACA,QAAsBllC,EAAKkrB,EAAAz5B,SAAS0zC,MAAO,MAC3C,OAAsBnlC,EAAKkrB,EAAAz5B,SAAS2zC,MAAO,MAC3C,OAAsBplC,EAAKkrB,EAAAz5B,SAAS4zC,MAAO,MAC3C,OACErlC,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAAz5B,SAAS2zC,MACTla,EAAAz5B,SAASyzC,MACb,MAEF,OACEllC,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAAz5B,SAAS4zC,MACTna,EAAAz5B,SAAS0zC,MACb,MAEF,QACE,OAAOnsE,EAAOmnC,OAAO+qB,EAAAz5B,SAASw2D,OAAQ3jF,EAAMC,GAE9C,QACE,OAAOvL,EAAOmnC,OAAO+qB,EAAAz5B,SAASy2D,OAAQ5jF,EAAMC,GAE9C,QAKE,OAJA2gF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAGdrhB,EAAOyhE,EAASnb,YAChBoC,EAAa7zD,EAAKw0C,eAClBi7B,EAAatkE,EAAKi+C,aAAappD,GACnCmL,EAAKw+C,aAAa8lB,EAAW9mE,MAAO/Z,EAAAw5D,WAAWiE,SAC3C4iB,EAAa9jE,EAAK2+C,oBAAoB9pD,GAG1C,OAFAmL,EAAKw+C,aAAaslB,EAAWtmE,MAAO/Z,EAAAw5D,WAAWiE,SAC/ClhD,EAAK0+C,cAAc4lB,GACZ/uF,EAAOirC,OACZjrC,EAAO6nC,UAAUknD,EAAW9mE,MAAO3c,GACnCtL,EAAO6nC,UAAU0mD,EAAWtmE,MAAO1c,GACnCvL,EAAOmnC,OAAOH,EACZhnC,EAAO2nC,UAAUonD,EAAW9mE,MAAOkrD,GACnCnzE,EAAO2nC,UAAU4mD,EAAWtmE,MAAOkrD,KAIzC,KAAK9N,EAAe7S,KACpB,KAAK6S,EAAe8pB,MAClB,GACEvB,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAE,GACxD4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK9Q,IAAG,GAEpD,IADImb,EAAO4sE,EAASvc,aACXhwD,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZ9E,OAAE,EACN,OAAQ1nB,EAAKxI,MACX,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,QAAoB,OAAOxL,EAC3B,QACE07B,EAAK1kC,EAAUmQ,cAAgB4yD,EAAe7S,KAC1CN,EAAA/+B,QAAQi8D,QACRl9B,EAAA/+B,QAAQk8D,SACZ,MAEF,QACEroD,EAAK1kC,EAAUmQ,cAAgB4yD,EAAe7S,KAC1CN,EAAA/+B,QAAQm8D,QACRp9B,EAAA/+B,QAAQo8D,SACZ,MAEF,QAKE,OAJArD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAGlB,OAAO9rC,EAAO+mC,MAAMC,EAAI17B,GAE1B,KAAK+5D,EAAemqB,SAClB,GACE5B,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAE,GACxD4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK9Q,IAAG,GAEpD,IADImb,EAAO4sE,EAASvc,aACXhwD,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZvgC,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIloB,EAAI,GACnD0nB,OAAE,EACN,OAAQ1nB,EAAKxI,MAEX,QAAqBkwB,EAAKkrB,EAAAz5B,SAASg3D,YAAa,MAChD,QAAqBzoD,EAAKkrB,EAAAz5B,SAASi3D,YAAa,MAChD,QAKE,OAJAxD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAGlB,OAAO9rC,EAAOmnC,OAAOH,EAAI17B,EAAMC,GAEjC,KAAK85D,EAAesqB,QAClB,GACE/B,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAE,GACxD4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK9Q,IAAG,GAEpD,IADImb,EAAO4sE,EAASvc,aACXhwD,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZ7E,OAAI,EACR,OAAQ3nB,EAAKxI,MACX,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAO37B,EACP,MAEF,QACE27B,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQy8D,WAAYtkF,GACxC,MAEF,QACE27B,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ08D,WAAYvkF,GACxC,MAEF,QACE4gF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbxmD,EAAOjnC,EAAO8rC,cAIlB,OAAO7E,EAET,KAAKo+B,EAAeyqB,YAClB,GACEzC,EAAkB/gE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAEhB,IADIxsB,EAAOgN,EAAe,IACjB3M,GAAE,KAMT,OALAusE,EAASvc,YAAcrwD,EACvB4sE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZ7E,OAAI,EACR,OAAQ3nB,EAAKxI,MACX,OACA,OACMxL,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK/Q,IAAG,GAC3D+iC,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ48D,eAAgBzkF,GAC5C,MAEF,OACA,OACMA,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK9Q,IAAG,GAC3D8iC,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ68D,eAAgB1kF,GAC5C,MAEF,OACA,OACMA,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAC7C0kD,EAASn3E,QAAQc,SACb9H,EAAAkH,KAAK9Q,IACL4J,EAAAkH,KAAK/Q,IAAG,GAGd+iC,EAAOjnC,EAAO+mC,MACZmlD,EAASn3E,QAAQc,SACbq8C,EAAA/+B,QAAQ68D,eACR99B,EAAA/+B,QAAQ48D,eACZzkF,GAEF,MAEF,QACMA,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKxR,IAAG,GAC3DwjC,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ88D,eAAgB3kF,GAC5C,MAEF,QACMA,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKvR,IAAG,GAC3DujC,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQ+8D,eAAgB5kF,GAC5C,MAEF,QACE4gF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbxmD,EAAOjnC,EAAO8rC,cAKlB,OADAogD,EAASvc,YAAcrwD,EAChB2nB,EAET,KAAKo+B,EAAe8qB,KAClB,GACEvC,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAE,GACxD4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK9Q,IAAG,GAEpD,IADImb,EAAO4sE,EAASvc,aACXhwD,GAAE,KAMT,OALAusE,EAASvc,YAAcrwD,EACvB4sE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZ7E,OAAI,EACR,OAAQ3nB,EAAKxI,MACX,QACEmwB,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQi9D,QAAS9kF,GACrC,MAEF,QACE27B,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQk9D,QAAS/kF,GACrC,MAEF,QACE4gF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbxmD,EAAOjnC,EAAO8rC,cAIlB,OAAO7E,EAET,KAAKo+B,EAAeirB,MAClB,GACE1C,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAE,GACxD4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK9Q,IAAG,GAEpD,IADImb,EAAO4sE,EAASvc,aACXhwD,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWh7D,OAENpL,EAAO8rC,cAEZ7E,OAAI,EACR,OAAQ3nB,EAAKxI,MACX,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAO37B,EACP,MAGF,QACE27B,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQo9D,SAAUjlF,GACtC,MAEF,QACE27B,EAAOjnC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQq9D,SAAUllF,GACtC,MAEF,QACE4gF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbxmD,EAAOjnC,EAAO8rC,cAIlB,OAAO7E,EAKT,KAAKo+B,EAAep9B,KAClB,GACEolD,EAAkB/gE,EAAe85C,EAAY8lB,GAAU,GACvDsB,EAAkBhmD,EAAU,EAAG,EAAG4+B,EAAY8lB,GAC9C,OAAOlsF,EAAO8rC,cACZxsB,EAAOgN,EAAe,GAA1B,IACImkE,EACFxtB,GAAkBl1D,EAAAkH,KAAK89C,MACvBzzC,EAAKK,GAAE,IACPsjD,EAAetjD,GAAE,IACjBsjD,EAAeh3B,KAAO3sB,EAAK2sB,KACzBg3B,EAAiB3jD,EACjBhU,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAC7C0kD,EAASn3E,QAAQI,UAAS,GAK5B,IADIu7E,GADA1I,GAAcxgD,EAASh7B,SACI,EAAImkF,EAAwBnpD,EAAS,GAAI0kD,GAAY,GACpE,EAEd,OADAA,EAASvc,YAAc8gB,EAChBzwF,EAAO8rC,cAEhB,IAAI8kD,OAAQ,EACRC,EAAevxE,EAAKizC,SACxB,GAAmB,GAAfy1B,GAAkB,CAEpB,IADA4I,EAAWD,EAAwBnpD,EAAS,GAAI0kD,IACjC,EAEb,OADAA,EAASvc,YAAc8gB,EAChBzwF,EAAO8rC,cAEhB,GAAI8kD,EAAWC,EAMb,OALA3E,EAASx+E,MACPI,EAAAhD,eAAegmF,6CACftpD,EAAS,GAAGp8B,MAAO,YAAa,IAAKylF,EAAa9kF,YAEpDmgF,EAASvc,YAAc8gB,EAChBzwF,EAAO8rC,cAEhB,IAAK5hC,EAAAJ,WAAW8mF,GAMd,OALA1E,EAASx+E,MACPI,EAAAhD,eAAeimF,0BACfvpD,EAAS,GAAGp8B,MAAO,aAErB8gF,EAASvc,YAAc8gB,EAChBzwF,EAAO8rC,mBAGhB8kD,EAAWC,EAGb,OADA3E,EAASvc,YAAc8gB,EAChBzwF,EAAOioC,KACZ3oB,EAAKizC,SACLjzC,EAAKK,GAAG,GACRrU,EACAmlF,EAAQ38B,eACR48B,EACAE,GAGJ,KAAKvrB,EAAex+B,MAElB,GADAqlD,EAASvc,YAAc5hE,EAAAkH,KAAKG,KAE1Bi4E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7CsB,EAAkBhmD,EAAU,EAAG,EAAG4+B,EAAY8lB,GAC9C,OAAOlsF,EAAO8rC,cACZxsB,EAAOgN,EAAe,GACtBhhB,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAC7C0kD,EAASn3E,QAAQI,UAAS,GAGxB5J,EAAO4gF,EACPD,EAASvX,kBAAkBntC,EAAS,GAClCy7B,EAAc,GAGhBipB,EAASvX,kBACPntC,EAAS,GACTloB,EACAA,EAAKK,GAAE,GACJ,EACA,GAfT,IAiBIqxE,EAAS9E,EAASvc,YAgBtB,GAdErwD,EAAKK,GAAE,MAEJqxE,EAAOrxE,GAAE,IACVqxE,EAAO/kD,KAAO3sB,EAAK2sB,QAGrB1gC,EAAO2gF,EAAS1O,kBAAkBjyE,EAChCylF,EAAQ1xE,GACR,GAAO,EACPkoB,EAAS,IAEXwpD,EAAS1xE,IAEPoxE,EAAYlpD,EAASh7B,QAAU,EAAImkF,EAAwBnpD,EAAS,GAAI0kD,GAAY,GACxE,EAEd,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO8rC,cAEZ8kD,OAAQ,EACRC,EAAevxE,EAAKizC,SACxB,GAAuB,GAAnB/qB,EAASh7B,OAAa,CAExB,IADAokF,EAAWD,EAAwBnpD,EAAS,GAAI0kD,IACjC,EAEb,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO8rC,cAEhB,GAAI8kD,EAAWC,EAMb,OALA3E,EAASx+E,MACPI,EAAAhD,eAAegmF,6CACftpD,EAAS,GAAGp8B,MAAO,YAAa,IAAKylF,EAAa9kF,YAEpDmgF,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO8rC,cAEhB,IAAK5hC,EAAAJ,WAAW8mF,GAMd,OALA1E,EAASx+E,MACPI,EAAAhD,eAAeimF,0BACfvpD,EAAS,GAAGp8B,MAAO,aAErB8gF,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO8rC,mBAGhB8kD,EAAWC,EAGb,OADA3E,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO6mC,MAAMvnB,EAAKizC,SAAUjnD,EAAMC,EAAMylF,EAAOl9B,eAAgB48B,EAAWE,GAKnF,KAAKvrB,EAAe78B,YAClB,IAAK0jD,EAASn3E,QAAQW,WAAU,IAAmB,MACnD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAAU,GACvDsB,EAAkBhmD,EAAU,EAAG,EAAG4+B,EAAY8lB,GAC9C,OAAOlsF,EAAO8rC,cAEZ2kD,GADAnxE,EAAOgN,EAAe,IAEnB3M,GAAE,IACPsjD,EAAetjD,GAAE,IACjBsjD,EAAeh3B,KAAO3sB,EAAK2sB,KACzBg3B,EAAiB3jD,EACrB,IAAKA,EAAKK,GAAE,GAMV,OALAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc8gB,EAChBzwF,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAC7C0kD,EAASn3E,QAAQI,UAAS,GAI5B,OADIu7E,EAA+B,GAAnBlpD,EAASh7B,OAAcmkF,EAAwBnpD,EAAS,GAAI0kD,GAAY,GACxE,GACdA,EAASvc,YAAc8gB,EAChBzwF,EAAO8rC,gBAEhBogD,EAASvc,YAAc8gB,EAChBzwF,EAAOwoC,YACZlpB,EAAKizC,SACLjnD,EACAmlF,EAAQ38B,eACR48B,IAGJ,KAAKrrB,EAAe38B,aAClB,IAAKwjD,EAASn3E,QAAQW,WAAU,IAAmB,MAEnD,GADAw2E,EAASvc,YAAc5hE,EAAAkH,KAAKG,KAE1Bi4E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7CsB,EAAkBhmD,EAAU,EAAG,EAAG4+B,EAAY8lB,GAC9C,OAAOlsF,EAAO8rC,cAEhB,KADIxsB,EAAOgN,EAAe,IAChB3M,GAAE,IAAuBL,EAAK2sB,KAAO,EAK7C,OAJAigD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAC7C0kD,EAASn3E,QAAQI,UAAS,GAGxB5J,EAAO4gF,EACPD,EAASvX,kBACPntC,EAAS,GACTy7B,EAAc,GAGhBipB,EAASvX,kBACPntC,EAAS,GACTloB,EACAA,EAAKK,GAAE,GACJ,EACA,GAELqxE,EAAS9E,EAASvc,YAgBtB,OAdErwD,EAAKK,GAAE,MAEJqxE,EAAOrxE,GAAE,IACVqxE,EAAO/kD,KAAO3sB,EAAK2sB,QAGrB1gC,EAAO2gF,EAAS1O,kBAAkBjyE,EAChCylF,EAAQ1xE,GACR,GAAO,EACPkoB,EAAS,IAEXwpD,EAAS1xE,IAEPoxE,EAA+B,GAAnBlpD,EAASh7B,OAAcmkF,EAAwBnpD,EAAS,GAAI0kD,GAAY,GACxE,GACdA,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO8rC,gBAEhBogD,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO0oC,aAAappB,EAAKizC,SAAUjnD,EAAMC,EAAMylF,EAAOl9B,eAAgB48B,IAE/E,KAAKrrB,EAAe4rB,WACpB,KAAK5rB,EAAe6rB,WACpB,KAAK7rB,EAAe8rB,WACpB,KAAK9rB,EAAe+rB,UACpB,KAAK/rB,EAAegsB,WACpB,KAAKhsB,EAAeisB,YAClB,IAAKpF,EAASn3E,QAAQW,WAAU,IAAmB,MACnD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAAU,GACvDsB,EAAkBhmD,EAAU,EAAG,EAAG4+B,EAAY8lB,GAC9C,OAAOlsF,EAAO8rC,cAEhB,KADIxsB,EAAOgN,EAAe,IAChB3M,GAAE,IAAuBL,EAAK2sB,KAAO,EAK7C,OAJAigD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAC7C0kD,EAASn3E,QAAQI,UAAS,GAGxB5J,EAAO4gF,EACPD,EAASvX,kBAAkBntC,EAAS,GAClCy7B,EAAc,GAGhBipB,EAASvX,kBACPntC,EAAS,GACTloB,EACAA,EAAKK,GAAE,GACJ,EACA,GAELqxE,EAAS9E,EAASvc,YAgBtB,GAdErwD,EAAKK,GAAE,MAEJqxE,EAAOrxE,GAAE,IACVqxE,EAAO/kD,KAAO3sB,EAAK2sB,QAGrB1gC,EAAO2gF,EAAS1O,kBAAkBjyE,EAChCylF,EAAQ1xE,GACR,GAAO,EACPkoB,EAAS,IAEXwpD,EAAS1xE,IAEPoxE,EAA+B,GAAnBlpD,EAASh7B,OAAcmkF,EAAwBnpD,EAAS,GAAI0kD,GAAY,GACxE,EAEd,OADAA,EAASvc,YAAcqhB,EAChBhxF,EAAO8rC,cAEZ9E,OAAE,EACN,OAAQ1kC,EAAUmQ,cAChB,QAAShI,QAAO,GAChB,KAAK46D,EAAe4rB,WAAejqD,EAAKkrB,EAAA7vB,YAAYkvD,IAAM,MAC1D,KAAKlsB,EAAe6rB,WAAelqD,EAAKkrB,EAAA7vB,YAAYmvD,IAAM,MAC1D,KAAKnsB,EAAe8rB,WAAenqD,EAAKkrB,EAAA7vB,YAAYovD,IAAM,MAC1D,KAAKpsB,EAAe+rB,UAAepqD,EAAKkrB,EAAA7vB,YAAYqvD,GAAM,MAC1D,KAAKrsB,EAAegsB,WAAerqD,EAAKkrB,EAAA7vB,YAAYsvD,IAAM,MAC1D,KAAKtsB,EAAeisB,YAAetqD,EAAKkrB,EAAA7vB,YAAYuvD,KAGtD,OADA1F,EAASvc,YAAcqhB,EAChBhxF,EAAO4oC,WACZ5B,EAAI1nB,EAAKizC,SAAUm+B,EAAWplF,EAAMC,EAAMylF,EAAOl9B,gBAGrD,KAAKuR,EAAev8B,eAClB,IAAKojD,EAASn3E,QAAQW,WAAU,IAAmB,MACnD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAAU,GACvDsB,EAAkBhmD,EAAU,EAAG,EAAG4+B,EAAY8lB,GAC9C,OAAOlsF,EAAO8rC,cAEhB,KADIxsB,EAAOgN,EAAe,IAChB3M,GAAE,IAAuBL,EAAK2sB,KAAO,EAK7C,OAJAigD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAC7C0kD,EAASn3E,QAAQI,UAAS,GAGxB5J,EAAO4gF,EACPD,EAASvX,kBAAkBntC,EAAS,GAClCy7B,EAAc,GAGhBipB,EAASvX,kBACPntC,EAAS,GACTloB,EACAA,EAAKK,GAAE,GACJ,EACA,GAELqxE,EAAS9E,EAASvc,YAhBtB,IAwCI+gB,EAvBAllF,GAAO0gF,EAASvX,kBAAkBntC,EAAS,GAC7CwpD,EAAM,GAuBR,OAnBE1xE,EAAKK,GAAE,MAEJqxE,EAAOrxE,GAAE,IACVqxE,EAAO/kD,KAAO3sB,EAAK2sB,QAGrB1gC,EAAO2gF,EAAS1O,kBAAkBjyE,EAChCylF,EAAQ1xE,GACR,GAAO,EACPkoB,EAAS,IAEXh8B,GAAO0gF,EAAS1O,kBAAkBhyE,GAChCwlF,EAAQ1xE,GACR,GAAO,EACPkoB,EAAS,IAEXwpD,EAAS1xE,IAEPoxE,EAA+B,GAAnBlpD,EAASh7B,OAAcmkF,EAAwBnpD,EAAS,GAAI0kD,GAAY,GACxE,GACdA,EAASvc,YAAcqhB,EAChBhxF,EAAO8rC,gBAEhBogD,EAASvc,YAAcqhB,EAChBhxF,EAAO8oC,eACZxpB,EAAKizC,SAAUm+B,EAAWplF,EAAMC,EAAMC,GAAMwlF,EAAOl9B,iBAGvD,KAAKuR,EAAen8B,YAClB,IAAKgjD,EAASn3E,QAAQW,WAAU,IAAmB,MAEnD,GADAw2E,EAASvc,YAAc5hE,EAAAkH,KAAKxR,IAE1B4pF,EAAkB/gE,EAAe85C,EAAY8lB,GAC7Ce,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAEhB,KADIxsB,EAAOgN,EAAe,IAChB3M,GAAE,IAAuBL,EAAK2sB,KAAO,GAK7C,OAJAigD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAC7C0kD,EAASn3E,QAAQI,UAAS,GAGxB5J,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIloB,EAAI,GAGnD9T,GAAO0gF,EAASvX,kBAAkBntC,EAAS,GAC7Cz5B,EAAAkH,KAAKvR,IAAG,GAIV,OADAwoF,EAASvc,YAAc5hE,EAAAkH,KAAKxR,IACrBzD,EAAOkpC,YAAY59B,EAAMC,EAAMC,GAAM8T,EAAKw0C,gBAEnD,KAAKuR,EAAe/7B,cAClB,IAAK4iD,EAASn3E,QAAQW,WAAU,IAAmB,MAEnD,GADAw2E,EAASvc,YAAc5hE,EAAAkH,KAAKxR,IAE1BupF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAC7C0kD,EAASn3E,QAAQI,UAAS,GAGxB5J,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAC7Cz5B,EAAAkH,KAAKxR,IAAG,GAIV,OADAyoF,EAASvc,YAAc5hE,EAAAkH,KAAKxR,IACrBzD,EAAOspC,cAAch+B,EAAMC,GAKpC,KAAK85D,EAAep6B,OAClB,GACE2iD,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cACZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAE,GACxD4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK89C,MAEjD,KADIzzC,EAAO4sE,EAASvc,aACV1tD,MAAM,KAKd,OAJAiqE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZvgC,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIloB,EAAI,GACnD9T,GAAO0gF,EAAS/R,cAClB+R,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKhR,MAC7CioF,EAASvc,aAGX,OADAuc,EAASvc,YAAcrwD,EAChBtf,EAAOirC,OAAO3/B,EAAMC,EAAMC,IAEnC,KAAK65D,EAAev5B,YAQlB,OAPIxf,GACF4/D,EAASx+E,MACPI,EAAAhD,eAAe42D,sBACf0E,EAAWqnB,mBAAoBnrF,EAAUmQ,cAG7Cw6E,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GACpClsF,EAAO8rC,cAKhB,KAAKu5B,EAAewsB,YAElB,OADA3F,EAASvc,YAAc5hE,EAAAkH,KAAKxR,IAE1BupF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GACpClsF,EAAO8rC,cACT9rC,EAAOunC,KAAK2qB,EAAAhwB,OAAO4vD,YAE5B,KAAKzsB,EAAe0sB,YAElB,OADA7F,EAASvc,YAAc5hE,EAAAkH,KAAKxR,IAE1BupF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GACpClsF,EAAO8rC,cACT9rC,EAAOunC,KAAK2qB,EAAAhwB,OAAO8vD,WAAY,KAAM,CAC1C9F,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKxR,IAAG,KAGpD,KAAK4hE,EAAer5B,YAElB,GADAkgD,EAASvc,YAAc5hE,EAAAkH,KAAKG,KAE1B43E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAChB,IAAKogD,EAASn3E,QAAQW,WAAU,GAAuB,CACrD,IAAIkT,GAAWsjE,EAASx5E,SAAS4L,gBAAgBhc,EAAW,MAE5D,OADA4pF,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACvBwT,GACEsjE,EAAS7H,kBAAkBz7D,GAAU4e,EAAU4+B,GADhCpmE,EAAO8rC,cAG/B,IAAI32B,GAAY+2E,EAASn3E,QAAQI,UAC7B7J,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIryB,GAAS,GACxD5J,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIryB,GAAS,GACxD3J,GAAO0gF,EAASvX,kBAAkBntC,EAAS,GAAIryB,GAAS,GAE5D,OADA+2E,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAOgsC,YAAY1gC,EAAMC,EAAMC,IAExC,KAAK65D,EAAel5B,YAElB,GADA+/C,EAASvc,YAAc5hE,EAAAkH,KAAKG,KAE1B43E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAChB,IAAKogD,EAASn3E,QAAQW,WAAU,GAAuB,CACjDkT,GAAWsjE,EAASx5E,SAAS4L,gBAAgBhc,EAAW,MAE5D,OADA4pF,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACvBwT,GACEsjE,EAAS7H,kBAAkBz7D,GAAU4e,EAAU4+B,GADhCpmE,EAAO8rC,cAG3B32B,GAAY+2E,EAASn3E,QAAQI,UAC7B7J,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIryB,GAAS,GACxD5J,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKrR,GAAE,GACtD4H,GAAO0gF,EAASvX,kBAAkBntC,EAAS,GAAIryB,GAAS,GAE5D,OADA+2E,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAOmsC,YAAY7gC,EAAMC,EAAMC,IAKxC,KAAK65D,EAAe7/B,WAClB,GACE6nD,EAAkB/gE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAChB,IAAIyZ,GAASj5B,EAAe,GAExBgiD,IADAhjE,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAI+d,IACpC2mC,EAASvc,aAExB,OADAuc,EAASvc,YAAcpqB,GACnB+oB,GAASriC,MAAQsZ,GAAOtZ,MAC1BigD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWh7D,OAENpL,EAAO8rC,eAETxgC,EAET,KAAK+5D,EAAe56D,OAClB,GACEmjF,EAAkBthE,EAAe85C,EAAY8lB,GAC7CsB,EAAkBhmD,EAAU,EAAG,EAAG4+B,EAAY8lB,GAM9C,OAJI5/D,IACF7hB,OAAO6hB,EAAc9f,QACrB0/E,EAASvc,YAAcrjD,EAAc,GAAGomC,iBAEnC1yD,EAAO8rC,cAEZxgC,EAAOghB,EACP4/D,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAI,GAC1D4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKhR,KAAI,GACjDqb,EAAO4sE,EAASvc,YAIpB,GAHAuc,EAASvc,YAAcrwD,EAAKozC,gBAGxBw5B,EAASn3E,QAAQiB,SACnB,OAAIitD,GAAkBl1D,EAAAkH,KAAKG,MACzB82E,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO6qC,OAETv/B,EAIT,IAAI7C,GAAQyzE,EAAagQ,EAA6B,GAAnB1kD,EAASh7B,OAAcg7B,EAAS,GAAK,KAAM4+B,GAC9E8lB,EAASvc,YAAcrwD,EAAKozC,gBACxBzrB,OAAI,EACR,GAAIg8B,GAAkBl1D,EAAAkH,KAAKG,KAEzB,OADA82E,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACpBkK,EAAKxI,MACX,OACA,OACA,OACA,OACA,OACA,OACA,QACEmwB,EAAOjnC,EAAOyqC,GACZzqC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQg4C,OAAQ7/D,GAC7B7C,IAEF,MAEF,OACA,OACEw+B,EAAOjnC,EAAOyqC,GACZzqC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQi4C,OAAQ9/D,GAC7B7C,IAEF,MAEF,OACA,OACEw+B,EAAOjnC,EAAOyqC,GACZzqC,EAAO+mC,MACLmlD,EAASn3E,QAAQc,SACbq8C,EAAA/+B,QAAQi4C,OACRlZ,EAAA/+B,QAAQg4C,OACZ7/D,GAEF7C,IAEF,MAGF,QACEw+B,EAAOjnC,EAAOyqC,GACZzqC,EAAOmnC,OAAO+qB,EAAAz5B,SAASqzC,MACrBxgE,EACAtL,EAAOkE,IAAI,IAEbuE,IAEF,MAEF,QACEw+B,EAAOjnC,EAAOyqC,GACZzqC,EAAOmnC,OAAO+qB,EAAAz5B,SAASszC,MACrBzgE,EACAtL,EAAOmE,IAAI,IAEbsE,IAEF,MAEF,QACEyjF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbxmD,EAAOx+B,QAMX,OADAyjF,EAASvc,YAAcrwD,EAAKozC,gBACpBw5B,EAASvc,YAAY74D,MAC3B,OACA,OACA,OACA,OACA,OACA,OACA,QACE,IACIykE,IADA9wD,EAAOyhE,EAASnb,aACC3H,oBAAoB9pD,GACzCmL,EAAKw+C,aAAasS,GAAUtzD,MAAO/Z,EAAAw5D,WAAWiE,SAC9C1kC,EAAOjnC,EAAOyqC,GACZzqC,EAAO6nC,UAAU0zC,GAAUtzD,MAAO3c,GAClCtL,EAAO2nC,UAAU4zC,GAAUtzD,MAAOiqC,EAAAriC,WAAWppB,KAC7CgC,IAEF,MAEF,OACA,OACM8yE,GAAY2Q,EAASnb,YAAY3H,oBAAoBr7D,EAAAkH,KAAKvR,KAC9DujC,EAAOjnC,EAAOyqC,GACZzqC,EAAO+mC,MAAMmrB,EAAA/+B,QAAQi4C,OACnBprE,EAAO6nC,UAAU0zC,GAAUtzD,MAAO3c,IAEpC7C,GACAzI,EAAO2nC,UAAU4zC,GAAUtzD,MAAOiqC,EAAAriC,WAAWnpB,MAE/C,MAEF,OACA,OACM60E,GAAY2Q,EAASnb,YAAY3H,oBAAoB8iB,EAASn3E,QAAQI,WAC1E8xB,EAAOjnC,EAAOyqC,GACZzqC,EAAO+mC,MACLmlD,EAASn3E,QAAQc,SACbq8C,EAAA/+B,QAAQi4C,OACRlZ,EAAA/+B,QAAQg4C,OACZnrE,EAAO6nC,UAAU0zC,GAAUtzD,MAAO3c,IAEpC7C,GACAzI,EAAO2nC,UAAU4zC,GAAUtzD,MAAOikE,EAASn3E,QAAQq+D,iBAErD,MAEF,QACMmI,GAAY2Q,EAASnb,YAAY3H,oBAAoBr7D,EAAAkH,KAAK/Q,KAC9D+iC,EAAOjnC,EAAOyqC,GACZzqC,EAAOmnC,OAAO+qB,EAAAz5B,SAASqzC,MACrB9rE,EAAO6nC,UAAU0zC,GAAUtzD,MAAO3c,GAClCtL,EAAOkE,IAAI,IAEbuE,GACAzI,EAAO2nC,UAAU4zC,GAAUtzD,MAAOiqC,EAAAriC,WAAW3oB,MAE/C,MAEF,QACMq0E,GAAY2Q,EAASnb,YAAY3H,oBAAoBr7D,EAAAkH,KAAK9Q,KAC9D8iC,EAAOjnC,EAAOyqC,GACZzqC,EAAOmnC,OAAO+qB,EAAAz5B,SAASszC,MACrB/rE,EAAO6nC,UAAU0zC,GAAUtzD,MAAO3c,GAClCtL,EAAOmE,IAAI,IAEbsE,GACAzI,EAAO2nC,UAAU4zC,GAAUtzD,MAAOiqC,EAAAriC,WAAW1oB,MAE/C,MAEF,QACE+kF,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbxmD,EAAOx+B,GAKb,OAAOw+B,EAET,KAAKo+B,EAAe13C,UAClB,GACEq/D,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAChB,IACImmD,IADAxnE,EAAOyhE,EAASnb,aACQpxD,GAAE,OAC9B8K,EAAKjY,IAAG,OAEJy0B,EAAOilD,EAASvX,kBAAkBntC,EAAS,GAAIy7B,GAEnD,OADKgvB,IAAkBxnE,EAAKxE,MAAK,OAC1BghB,EAET,KAAKo+B,EAAe6sB,YAAa9F,GAAY,EAC7C,KAAK/mB,EAAe15B,cAClB,GACEiiD,EAAkBthE,EAAe85C,EAAY8lB,GAAU,GACvDsB,EAAkBhmD,EAAU,EAAG/jC,IAAIqxC,UAAWsxB,EAAY8lB,GAC1D,OAAOlsF,EAAO8rC,cAChB,IAAIL,GAAanf,EAAgBA,EAAc,GAAK22C,EAEhDkvB,IADA7mF,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKnR,KACzCooF,EAASvc,aACxB,KACEwiB,IAAYpkF,EAAAkH,KAAKnR,KACJ,GAAbquF,GAASr7E,MAAwBq7E,GAAS1/B,oBAM1C,OAJAy5B,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf8lB,EAAS,GAAGp8B,OAEPpL,EAAO8rC,cAOhB,IALA,IAAIk8C,GAAcxgD,EAASh7B,OAAS,EAChC4lF,GAAe,IAAI9qF,MAAqB0gF,IACxC1E,GAAmB73C,GAAWqoB,eAC9BzpC,GAAiB,IAAI/iB,MAAY0gF,IACjCqK,GAAmB,IAAI/qF,MAAkB0gF,IACpCtnF,GAAI,EAAGA,GAAIsnF,KAAetnF,GAAG,CACpC0xF,GAAa1xF,IAAKwrF,EAASvX,kBAAkBntC,EAAS,EAAI9mC,IAAIqN,EAAAkH,KAAKxR,KACnE,IAAI6uF,GAAcpG,EAASvc,YAC3BtlD,GAAe3pB,IAAK4xF,GACpBD,GAAiB3xF,IAAK4xF,GAAYx+B,eAEpC,IAAIloB,GAAW79B,EAAA0Y,UAAU4uC,oBAAoBhrC,GAAgBohB,IACzDyC,GAAUluC,EAAOgmC,2BAA2Bs9C,GAAkB+O,IAGlE,GAFKnkD,KAASA,GAAUluC,EAAOylC,gBAAgBmG,GAAU03C,GAAkB+O,KAC3EnG,EAASvc,YAAclkC,GACnB2gD,EAAW,CAEb,GAAIl6B,EAAA9a,gBAAgB9rC,EAAOtL,EAAO6yC,qBAAqBvnC,KAAU4mD,EAAApiC,aAAaolB,MAAO,CACnFzqC,OAAOynD,EAAA7a,kBAAkB/rC,IAAS4mD,EAAAriC,WAAWppB,KAC7C,IAAIwhB,GAAQiqC,EAAA5a,iBAAiBhsC,GACzBwkE,GAAgBoc,EAASpc,cAC7B,GAAI7nD,IAAS,GAAKA,GAAQ6nD,GAActjE,OACtC,OAAOxM,EAAOa,KAAKivE,GAAc7nD,IAAQmqE,GAAc9O,IAO3D,OAJA4I,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf8lB,EAAS,GAAGp8B,OAEPpL,EAAO8rC,cAIhB,OAAO9rC,EAAO2rC,cAAcrgC,EAAM8mF,GAAcxmD,IAElD,KAAKy5B,EAAektB,YAClB,GACElF,EAAkB/gE,EAAe85C,EAAY8lB,GAAU,GACvD,OAAOlsF,EAAO8rC,cAChB,IAAI94B,GAAgBsZ,EAAe,GAAG0C,eACtC,OAAKhc,IAOLk5E,EAASvc,YAAc38D,GAAcsM,KAC9B4sE,EAAS3B,mBAAmBv3E,GAAew0B,EAAQ,EAAoB4+B,KAP5E8lB,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,eAQlB,KAAKu5B,EAAe76D,MAMlB,OALAwiF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C4pF,EAASx+E,MACPI,EAAAhD,eAAe0nF,eACfpsB,EAAWh7D,OAAQo8B,EAASh7B,OAASg7B,EAAS,GAAK4+B,GAAYh7D,MAAMW,YAEhE/L,EAAO8rC,cAEhB,KAAKu5B,EAAe96D,QAMlB,OALAyiF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C4pF,EAAS1+E,QACPM,EAAAhD,eAAe0nF,eACfpsB,EAAWh7D,OAAQo8B,EAASh7B,OAASg7B,EAAS,GAAK4+B,GAAYh7D,MAAMW,YAEhE/L,EAAO6qC,MAEhB,KAAKw6B,EAAe/6D,KAMlB,OALA0iF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C4pF,EAAS5+E,KACPQ,EAAAhD,eAAe0nF,eACfpsB,EAAWh7D,OAAQo8B,EAASh7B,OAASg7B,EAAS,GAAK4+B,GAAYh7D,MAAMW,YAEhE/L,EAAO6qC,MAKhB,KAAKw6B,EAAe9hE,GAClB,OACEypF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAK1R,GACrBvD,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK1R,GAAE,GAExD,KAAK8hE,EAAe7hE,IAClB,OACEwpF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAKzR,IACrBxD,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKzR,IAAG,GAEzD,KAAK6hE,EAAe5hE,IAClB,OACEupF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAKxR,IACrBzD,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKxR,IAAG,GAEzD,KAAK4hE,EAAe3hE,IAClB,OACEspF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAKvR,IACrB1D,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKvR,IAAG,GAEzD,KAAK2hE,EAAe1hE,MAClB,IAAIuR,GAAYg3E,EAASn3E,QAAQG,UACjC,OACE83E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAcz6D,GAChBlV,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAItyB,GAAS,GAE1D,KAAKmwD,EAAezhE,GAClB,OACEopF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAKrR,GACrB5D,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKrR,GAAE,GAExD,KAAKyhE,EAAexhE,IAClB,OACEmpF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAKpR,IACrB7D,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKpR,IAAG,GAEzD,KAAKwhE,EAAevhE,IAClB,OACEkpF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAKnR,IACrB9D,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKnR,IAAG,GAEzD,KAAKuhE,EAAethE,IAClB,OACEipF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAKlR,IACrB/D,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKlR,IAAG,GAEzD,KAAKshE,EAAerhE,MACdmR,GAAY+2E,EAASn3E,QAAQI,UACjC,OACE63E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAcx6D,GAChBnV,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIryB,GAAS,GAE1D,KAAKkwD,EAAephE,KAClB,OACE+oF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACrBjE,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKhR,KAAI,GAE1D,KAAKohE,EAAenhE,IAClB,OACE8oF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAK/Q,IACrBlE,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK/Q,IAAG,GAEzD,KAAKmhE,EAAelhE,IAClB,OACE6oF,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,IAE3CA,EAASvc,YAAc5hE,EAAAkH,KAAK9Q,IACrBnE,EAAO8rC,eAETogD,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK9Q,IAAG,GAKzD,KAAKkhE,EAAejhE,KACpB,KAAKihE,EAAehhE,MAClB,IAAK6nF,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACEs3E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,GAAI4+B,EAAY8lB,GAG5C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhB,IAAIlF,GAAQ,IAAI1+B,WAAW,IAC3B,IAASxH,GAAI,EAAGA,GAAI,KAAMA,GAAG,CAE3B,GADIiB,GAAQ6lC,EAAS9mC,IACV,CACLumC,EAAOilD,EAASr5C,qBAAqBlxC,GAAOoM,EAAAkH,KAAK1R,GAAE,GACvD,GAAI2uD,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAaolB,MAMxC,OALAg3C,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACf9wF,GAAMyJ,OAER8gF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhBrhC,OAAOynD,EAAA7a,kBAAkBpQ,IAASirB,EAAAriC,WAAWppB,KAC7CyD,EAAAikB,QAAQ+jC,EAAA5a,iBAAiBrQ,GAAOL,GAAOlmC,KAI3C,OADAwrF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAOoE,KAAKwiC,IAErB,KAAKy+B,EAAe9gE,MAClB,IAAK2nF,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACEs3E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIlF,GAAQ,IAAI1+B,WAAW,IAClBxH,GAAI,EAAGA,GAAI,IAAKA,GAAG,CAE1B,GADIiB,GAAQ6lC,EAAS9mC,IACV,CACLumC,EAAOilD,EAASr5C,qBAAqBlxC,GAAOoM,EAAAkH,KAAKzR,IAAG,GACxD,GAAI0uD,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAaolB,MAMxC,OALAg3C,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACf9wF,GAAMyJ,OAER8gF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhBrhC,OAAOynD,EAAA7a,kBAAkBpQ,IAASirB,EAAAriC,WAAWppB,KAC7CyD,EAAAkkB,SAAS8jC,EAAA5a,iBAAiBrQ,GAAOL,GAAOlmC,IAAK,IAIjD,OADAwrF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAOoE,KAAKwiC,IAErB,KAAKy+B,EAAe5gE,MAClB,IAAKynF,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACEs3E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIlF,GAAQ,IAAI1+B,WAAW,IAClBxH,GAAI,EAAGA,GAAI,IAAKA,GAAG,CAE1B,GADIiB,GAAQ6lC,EAAS9mC,IACV,CACLumC,EAAOilD,EAASr5C,qBAAqBlxC,GAAOoM,EAAAkH,KAAKxR,IAAG,GACxD,GAAIyuD,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAaolB,MAMxC,OALAg3C,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACf9wF,GAAMyJ,OAER8gF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhBrhC,OAAOynD,EAAA7a,kBAAkBpQ,IAASirB,EAAAriC,WAAWppB,KAC7CyD,EAAAgJ,SAASg/C,EAAA5a,iBAAiBrQ,GAAOL,GAAOlmC,IAAK,IAIjD,OADAwrF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAOoE,KAAKwiC,IAErB,KAAKy+B,EAAe1gE,MAClB,IAAKunF,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACEs3E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIlF,GAAQ,IAAI1+B,WAAW,IAClBxH,GAAI,EAAGA,GAAI,IAAKA,GAAG,CAE1B,GADIiB,GAAQ6lC,EAAS9mC,IACV,CACLumC,EAAOilD,EAASr5C,qBAAqBlxC,GAAOoM,EAAAkH,KAAKvR,IAAG,GACxD,GAAIwuD,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAaolB,MAMxC,OALAg3C,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACf9wF,GAAMyJ,OAER8gF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhBrhC,OAAOynD,EAAA7a,kBAAkBpQ,IAASirB,EAAAriC,WAAWnpB,KAC7C,IAAIgsF,GAAMhyF,IAAK,EACfwJ,EAAAgJ,SAASg/C,EAAA3a,oBAAoBtQ,GAAOL,GAAO8rD,IAC3CxoF,EAAAgJ,SAASg/C,EAAA1a,qBAAqBvQ,GAAOL,GAAO8rD,GAAM,IAItD,OADAxG,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAOoE,KAAKwiC,IAErB,KAAKy+B,EAAexgE,MAClB,IAAKqnF,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACEs3E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIlF,GAAQ,IAAI1+B,WAAW,IAClBxH,GAAI,EAAGA,GAAI,IAAKA,GAAG,CAE1B,GADIiB,GAAQ6lC,EAAS9mC,IACV,CACLumC,EAAOilD,EAASr5C,qBAAqBlxC,GAAOoM,EAAAkH,KAAK/Q,IAAG,GACxD,GAAIguD,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAaolB,MAMxC,OALAg3C,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACf9wF,GAAMyJ,OAER8gF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhBrhC,OAAOynD,EAAA7a,kBAAkBpQ,IAASirB,EAAAriC,WAAW3oB,KAC7CgD,EAAAmkB,SAAS6jC,EAAAza,iBAAiBxQ,GAAOL,GAAOlmC,IAAK,IAIjD,OADAwrF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAOoE,KAAKwiC,IAErB,KAAKy+B,EAAevgE,MAClB,IAAKonF,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACEs3E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIlF,GAAQ,IAAI1+B,WAAW,IAClBxH,GAAI,EAAGA,GAAI,IAAKA,GAAG,CAC1B,IAAIiB,GACJ,GADIA,GAAQ6lC,EAAS9mC,IACV,CACLumC,EAAOilD,EAASr5C,qBAAqBlxC,GAAOoM,EAAAkH,KAAK9Q,IAAG,GACxD,GAAI+tD,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAaolB,MAMxC,OALAg3C,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACf9wF,GAAMyJ,OAER8gF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhBrhC,OAAOynD,EAAA7a,kBAAkBpQ,IAASirB,EAAAriC,WAAW1oB,KAC7C+C,EAAAokB,SAAS4jC,EAAAxa,iBAAiBzQ,GAAOL,GAAOlmC,IAAK,IAIjD,OADAwrF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAOoE,KAAKwiC,IAErB,KAAKy+B,EAAestB,WAClB,IAAKzG,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7Ce,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIxsB,EAAOgN,EAAe,IACjB3M,GAAE,KAMT,OALAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZ9E,OAAE,EACN,OAAQ1nB,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAA/+B,QAAQy/D,cAAe,MACjD,OACA,OAAqB5rD,EAAKkrB,EAAA/+B,QAAQ0/D,cAAe,MACjD,OACA,OAAqB7rD,EAAKkrB,EAAA/+B,QAAQ2/D,cAAe,MACjD,OACA,OAAqB9rD,EAAKkrB,EAAA/+B,QAAQ4/D,cAAe,MACjD,OACA,OACE/rD,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAA/+B,QAAQ4/D,cACR7gC,EAAA/+B,QAAQ2/D,cACZ,MAEF,QAAqB9rD,EAAKkrB,EAAA/+B,QAAQ6/D,cAAe,MACjD,QAAqBhsD,EAAKkrB,EAAA/+B,QAAQ8/D,cAAe,MACjD,QAME,OALA/G,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGdxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIloB,EAAI,GAEvD,OADA4sE,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO+mC,MAAMC,EAAI17B,GAE1B,KAAK+5D,EAAe6tB,kBAClB,IAAKhH,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAAU,GACvDe,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAC3C,OAAOlsF,EAAO8rC,cAEhB,IADIxsB,EAAOgN,EAAe,IACjB3M,GAAE,KAMT,OALAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAcrwD,EAChBtf,EAAO8rC,cAEZ9E,OAAE,EACN,OAAQ1nB,EAAKxI,MACX,OAAqBkwB,EAAKkrB,EAAAtvB,cAAcuwD,qBAAsB,MAC9D,OAAqBnsD,EAAKkrB,EAAAtvB,cAAcwwD,qBAAsB,MAC9D,OAAqBpsD,EAAKkrB,EAAAtvB,cAAcywD,qBAAsB,MAC9D,OAAqBrsD,EAAKkrB,EAAAtvB,cAAc0wD,qBAAsB,MAC9D,OACA,OAAqBtsD,EAAKkrB,EAAAtvB,cAAc2wD,oBAAqB,MAC7D,OACA,OAAqBvsD,EAAKkrB,EAAAtvB,cAAc4wD,oBAAqB,MAC7D,OACA,OACExsD,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAAtvB,cAAc4wD,oBACdthC,EAAAtvB,cAAc2wD,oBAClB,MAEF,QAAqBvsD,EAAKkrB,EAAAtvB,cAAc6wD,oBAAqB,MAC7D,QAAqBzsD,EAAKkrB,EAAAtvB,cAAc8wD,oBAAqB,MAC7D,QAME,OALAxH,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAcrwD,EAChBtf,EAAO8rC,cAGdxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GACxDmH,EAAO2gF,EAASr5C,qBAAqBrL,EAAS,GAAIz5B,EAAAkH,KAAKrR,GAAE,GAE7D,GADAsoF,EAASvc,YAAcrwD,EACnB4yC,EAAA9a,gBAAgB7rC,IAAS2mD,EAAApiC,aAAaolB,MAKxC,OAJAg3C,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACfjrD,EAAS,GAAGp8B,OAEPpL,EAAO8rC,cAEhBrhC,OAAOynD,EAAA7a,kBAAkB9rC,IAAS2mD,EAAAriC,WAAWppB,KAC7C,IAAIktF,GAAU,GAAKr0E,EAAKizC,SAAY,EAEpC,OADIhmB,GAAM2lB,EAAA5a,iBAAiB/rC,IACjB,GAAKghC,GAAMonD,IACnBzH,EAASx+E,MACPI,EAAAhD,eAAegmF,6CACftpD,EAAS,GAAGp8B,MAAO,aAAc,IAAKuoF,GAAO5nF,YAExC/L,EAAO8rC,eAET9rC,EAAOqsC,aAAarF,EAAI17B,EAAMihC,IAEvC,KAAK84B,EAAeuuB,kBAClB,IAAK1H,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7Ce,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIxsB,EAAOgN,EAAe,IACjB3M,GAAE,KAMT,OALAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZ9E,OAAE,EACN,OAAQ1nB,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAA7uB,cAAcwwD,oBAAqB,MAC7D,OACA,OAAqB7sD,EAAKkrB,EAAA7uB,cAAcywD,oBAAqB,MAC7D,OACA,OAAqB9sD,EAAKkrB,EAAA7uB,cAAc0wD,oBAAqB,MAC7D,OACA,OAAqB/sD,EAAKkrB,EAAA7uB,cAAc2wD,oBAAqB,MAC7D,OACA,OACEhtD,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAA7uB,cAAc2wD,oBACd9hC,EAAA7uB,cAAc0wD,oBAClB,MAEF,QAAqB/sD,EAAKkrB,EAAA7uB,cAAc4wD,oBAAqB,MAC7D,QAAqBjtD,EAAKkrB,EAAA7uB,cAAc6wD,oBAAqB,MAC7D,QAME,OALAhI,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGdxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GACxDmH,EAAO2gF,EAASr5C,qBAAqBrL,EAAS,GAAIz5B,EAAAkH,KAAKrR,GAAE,GAC7D,GAAIsuD,EAAA9a,gBAAgB7rC,IAAS2mD,EAAApiC,aAAaolB,MAMxC,OALAg3C,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACfjrD,EAAS,GAAGp8B,OAEd8gF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhBrhC,OAAOynD,EAAA7a,kBAAkB9rC,IAAS2mD,EAAAriC,WAAWppB,KACzCktF,GAAU,GAAKr0E,EAAKizC,SAAY,EAEpC,IADIhmB,GAAM2lB,EAAA5a,iBAAiB/rC,IACjB,GAAKghC,GAAMonD,GAKnB,OAJAzH,EAASx+E,MACPI,EAAAhD,eAAegmF,6CACftpD,EAAS,GAAGp8B,MAAO,aAAc,IAAKuoF,GAAO5nF,YAExC/L,EAAO8rC,cAEZtgC,GAAO0gF,EAASvX,kBAAkBntC,EAAS,GAAIloB,EAAI,GAEvD,OADA4sE,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAOysC,aAAazF,EAAI17B,EAAMihC,GAAK/gC,IAE5C,KAAK65D,EAAe8uB,aAClB,IAAKjI,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAG7C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIxsB,EAAOgN,EAAe,IACjB3M,GAAE,KAMT,OALAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhB,IAAIsoD,GAAY90E,EAAKizC,SACjB8hC,GAAY,GAAKD,GAErB,GADA3pF,OAAO4hF,UAAUgI,KAAcnqF,EAAAJ,WAAWuqF,KAExCpH,EAAkBzlD,EAAU,EAAI6sD,GAAWjuB,EAAY8lB,GAGvD,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhB,OAAQxsB,EAAKxI,MACX,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,OACA,QACA,QAAmB,MACnB,QAME,OALAo1E,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGdxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GACxDmH,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GAD5D,IAEI0oC,GAAO,IAAI5kC,WAAW,IAE1B,IADIyrF,IAAUU,IAAa,GAAK,EACvB3zF,GAAI,EAAGA,GAAI2zF,KAAa3zF,GAAG,CAClC,IAWI6rC,GAXAwc,GAAUvhB,EAAS,EAAI9mC,IACvB4zF,GAAOpI,EAASr5C,qBAAqBkW,GAASh7C,EAAAkH,KAAKrR,GAAE,GACzD,GAAIsuD,EAAA9a,gBAAgBk9C,KAASpiC,EAAApiC,aAAaolB,MAMxC,OALAg3C,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACf1pC,GAAQ39C,OAEV8gF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAIhB,GAFArhC,OAAOynD,EAAA7a,kBAAkBi9C,KAASpiC,EAAAriC,WAAWppB,MACzC8lC,GAAM2lB,EAAA5a,iBAAiBg9C,KACjB,GAAK/nD,GAAMonD,GAMnB,OALAzH,EAASx+E,MACPI,EAAAhD,eAAegmF,6CACf/nC,GAAQ39C,MAAO,aAAc,IAAKuoF,GAAO5nF,YAE3CmgF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEhB,OAAQsoD,IACN,KAAK,EACHlqF,EAAAikB,QAAQoe,GAAKO,GAAMpsC,IACnB,MAEF,KAAK,EACH,IAAI6zF,GAAO7zF,IAAK,EACZ8zF,GAAOjoD,IAAO,EAClBriC,EAAAikB,QAAQqmE,GAAU1nD,GAAMynD,IACxBrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/B,MAEF,KAAK,EACCA,GAAO7zF,IAAK,EACZ8zF,GAAOjoD,IAAO,EAClBriC,EAAAikB,QAAQqmE,GAAU1nD,GAAMynD,IACxBrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/BrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/BrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/B,MAEF,KAAK,EACCA,GAAO7zF,IAAK,EACZ8zF,GAAOjoD,IAAO,EAClBriC,EAAAikB,QAAQqmE,GAAU1nD,GAAMynD,IACxBrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/BrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/BrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/BrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/BrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/BrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/BrqF,EAAAikB,QAAQqmE,GAAO,EAAG1nD,GAAMynD,GAAO,GAC/B,MAEF,QAAS9pF,QAAO,IAIpB,OADAyhF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO2sC,aAAarhC,EAAMC,EAAMuhC,IAEzC,KAAKu4B,EAAeovB,SACpB,KAAKpvB,EAAeqvB,SACpB,KAAKrvB,EAAesvB,SACpB,KAAKtvB,EAAeuvB,SACpB,KAAKvvB,EAAewvB,kBACpB,KAAKxvB,EAAeyvB,kBACpB,KAAKzvB,EAAe0vB,SACpB,KAAK1vB,EAAe2vB,SACpB,KAAK3vB,EAAe4vB,QACpB,KAAK5vB,EAAe6vB,QACpB,KAAK7vB,EAAe8vB,QACpB,KAAK9vB,EAAe+vB,QACpB,KAAK/vB,EAAegwB,QACpB,KAAKhwB,EAAeiwB,QAClB,IAAKpJ,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7Ce,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIxsB,EAAOgN,EAAe,IACjB3M,GAAE,KAMT,OALAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZ9E,GAAgB,EACpB,OAAQ1kC,EAAUmQ,cAChB,KAAK4yD,EAAeovB,SAClB,OAAQn1E,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAAz5B,SAAS88D,YAAa,MAChD,OACA,OAAqBvuD,EAAKkrB,EAAAz5B,SAAS+8D,YAAa,MAChD,OACA,OAAqBxuD,EAAKkrB,EAAAz5B,SAASg9D,YAAa,MAChD,OACA,OAAqBzuD,EAAKkrB,EAAAz5B,SAASi9D,YAAa,MAChD,OACA,OACE1uD,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAAz5B,SAASi9D,YACTxjC,EAAAz5B,SAASg9D,YACb,MAEF,QAAqBzuD,EAAKkrB,EAAAz5B,SAASk9D,YAAa,MAChD,QAAqB3uD,EAAKkrB,EAAAz5B,SAASm9D,YAErC,MAEF,KAAKvwB,EAAeqvB,SAClB,OAAQp1E,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAAz5B,SAASo9D,YAAa,MAChD,OACA,OAAqB7uD,EAAKkrB,EAAAz5B,SAASq9D,YAAa,MAChD,OACA,OAAqB9uD,EAAKkrB,EAAAz5B,SAASs9D,YAAa,MAChD,OACA,OAAqB/uD,EAAKkrB,EAAAz5B,SAASu9D,YAAa,MAChD,OACA,OACEhvD,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAAz5B,SAASu9D,YACT9jC,EAAAz5B,SAASs9D,YACb,MAEF,QAAqB/uD,EAAKkrB,EAAAz5B,SAASw9D,YAAa,MAChD,QAAqBjvD,EAAKkrB,EAAAz5B,SAASy9D,YAErC,MAEF,KAAK7wB,EAAesvB,SAClB,OAAQr1E,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAAz5B,SAAS09D,YAAa,MAChD,OACA,OAAqBnvD,EAAKkrB,EAAAz5B,SAAS29D,YAAa,MAChD,OACA,OAAqBpvD,EAAKkrB,EAAAz5B,SAAS49D,YAAa,MAChD,QAAqBrvD,EAAKkrB,EAAAz5B,SAAS69D,YAAa,MAChD,QAAqBtvD,EAAKkrB,EAAAz5B,SAAS89D,YAAa,MAChD,OACA,OACOrK,EAASn3E,QAAQc,WAAUmxB,EAAKkrB,EAAAz5B,SAAS49D,aAIlD,MAEF,KAAKhxB,EAAeuvB,SAClB,OAAQt1E,EAAKxI,MACX,QAAqBkwB,EAAKkrB,EAAAz5B,SAAS+9D,YAAa,MAChD,QAAqBxvD,EAAKkrB,EAAAz5B,SAASg+D,YAErC,MAEF,KAAKpxB,EAAewvB,kBAClB,OAAQv1E,EAAKxI,MACX,OAAqBkwB,EAAKkrB,EAAAz5B,SAASi+D,gBAAiB,MACpD,OAAqB1vD,EAAKkrB,EAAAz5B,SAASk+D,gBAAiB,MACpD,OAAqB3vD,EAAKkrB,EAAAz5B,SAASm+D,gBAAiB,MACpD,OAAqB5vD,EAAKkrB,EAAAz5B,SAASo+D,gBAErC,MAEF,KAAKxxB,EAAeyvB,kBAClB,OAAQx1E,EAAKxI,MACX,OAAqBkwB,EAAKkrB,EAAAz5B,SAASq+D,gBAAiB,MACpD,OAAqB9vD,EAAKkrB,EAAAz5B,SAASs+D,gBAAiB,MACpD,OAAqB/vD,EAAKkrB,EAAAz5B,SAASu+D,gBAAiB,MACpD,OAAqBhwD,EAAKkrB,EAAAz5B,SAASw+D,gBAErC,MAEF,KAAK5xB,EAAe0vB,SAClB,OAAQz1E,EAAKxI,MACX,QAAqBkwB,EAAKkrB,EAAAz5B,SAASy+D,YAAa,MAChD,QAAqBlwD,EAAKkrB,EAAAz5B,SAAS0+D,YAErC,MAEF,KAAK9xB,EAAe2vB,SAClB,OAAQ11E,EAAKxI,MACX,QAAqBkwB,EAAKkrB,EAAAz5B,SAAS2+D,YAAa,MAChD,QAAqBpwD,EAAKkrB,EAAAz5B,SAAS4+D,YAErC,MAEF,KAAKhyB,EAAe4vB,QAClB,OAAQ31E,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAAz5B,SAASunD,WAAY,MAC/C,OACA,OAAqBh5C,EAAKkrB,EAAAz5B,SAAS6+D,WAAY,MAC/C,OACA,OAAqBtwD,EAAKkrB,EAAAz5B,SAAS8+D,WAAY,MAC/C,QAAqBvwD,EAAKkrB,EAAAz5B,SAAS++D,WAAY,MAC/C,QAAqBxwD,EAAKkrB,EAAAz5B,SAASg/D,WAAY,MAC/C,OACA,OACOvL,EAASn3E,QAAQc,WAAUmxB,EAAKkrB,EAAAz5B,SAAS8+D,YAIlD,MAEF,KAAKlyB,EAAe6vB,QAClB,OAAQ51E,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAAz5B,SAASynD,WAAY,MAC/C,OACA,OAAqBl5C,EAAKkrB,EAAAz5B,SAASi/D,WAAY,MAC/C,OACA,OAAqB1wD,EAAKkrB,EAAAz5B,SAASk/D,WAAY,MAC/C,QAAqB3wD,EAAKkrB,EAAAz5B,SAASm/D,WAAY,MAC/C,QAAqB5wD,EAAKkrB,EAAAz5B,SAASo/D,WAAY,MAC/C,OACA,OACO3L,EAASn3E,QAAQc,WAAUmxB,EAAKkrB,EAAAz5B,SAASk/D,YAIlD,MAEF,KAAKtyB,EAAe8vB,QAClB,OAAQ71E,EAAKxI,MACX,OAAqBkwB,EAAKkrB,EAAAz5B,SAASq/D,YAAa,MAChD,OAAqB9wD,EAAKkrB,EAAAz5B,SAASs/D,YAAa,MAChD,OAAqB/wD,EAAKkrB,EAAAz5B,SAASu/D,YAAa,MAChD,OAAqBhxD,EAAKkrB,EAAAz5B,SAASw/D,YAAa,MAChD,OAAqBjxD,EAAKkrB,EAAAz5B,SAASy/D,YAAa,MAChD,OAAqBlxD,EAAKkrB,EAAAz5B,SAAS0/D,YAAa,MAChD,QAAqBnxD,EAAKkrB,EAAAz5B,SAAS2/D,WAAY,MAC/C,QAAqBpxD,EAAKkrB,EAAAz5B,SAAS4/D,WAAY,MAC/C,OACA,OACOnM,EAASn3E,QAAQc,WACpBmxB,EAAc,GAAT1nB,EAAKxI,KACNo7C,EAAAz5B,SAASy/D,YACThmC,EAAAz5B,SAAS0/D,aAKnB,MAEF,KAAK9yB,EAAe+vB,QAClB,OAAQ91E,EAAKxI,MACX,OAAqBkwB,EAAKkrB,EAAAz5B,SAAS6/D,YAAa,MAChD,OAAqBtxD,EAAKkrB,EAAAz5B,SAAS8/D,YAAa,MAChD,OAAqBvxD,EAAKkrB,EAAAz5B,SAAS+/D,YAAa,MAChD,OAAqBxxD,EAAKkrB,EAAAz5B,SAASggE,YAAa,MAChD,OAAqBzxD,EAAKkrB,EAAAz5B,SAASigE,YAAa,MAChD,OAAqB1xD,EAAKkrB,EAAAz5B,SAASkgE,YAAa,MAChD,QAAqB3xD,EAAKkrB,EAAAz5B,SAASmgE,WAAY,MAC/C,QAAqB5xD,EAAKkrB,EAAAz5B,SAASogE,WAAY,MAC/C,OACA,OACO3M,EAASn3E,QAAQc,WACpBmxB,EAAc,GAAT1nB,EAAKxI,KACNo7C,EAAAz5B,SAASigE,YACTxmC,EAAAz5B,SAASkgE,aAKnB,MAEF,KAAKtzB,EAAegwB,QAClB,OAAQ/1E,EAAKxI,MACX,OAAqBkwB,EAAKkrB,EAAAz5B,SAASqgE,YAAa,MAChD,OAAqB9xD,EAAKkrB,EAAAz5B,SAASsgE,YAAa,MAChD,OAAqB/xD,EAAKkrB,EAAAz5B,SAASugE,YAAa,MAChD,OAAqBhyD,EAAKkrB,EAAAz5B,SAASwgE,YAAa,MAChD,OAAqBjyD,EAAKkrB,EAAAz5B,SAASygE,YAAa,MAChD,OAAqBlyD,EAAKkrB,EAAAz5B,SAAS0gE,YAAa,MAChD,QAAqBnyD,EAAKkrB,EAAAz5B,SAAS2gE,WAAY,MAC/C,QAAqBpyD,EAAKkrB,EAAAz5B,SAAS4gE,WAAY,MAC/C,OACA,OACOnN,EAASn3E,QAAQc,WACpBmxB,EAAc,GAAT1nB,EAAKxI,KACNo7C,EAAAz5B,SAASygE,YACThnC,EAAAz5B,SAAS0gE,aAKnB,MAEF,KAAK9zB,EAAeiwB,QAClB,OAAQh2E,EAAKxI,MACX,OAAqBkwB,EAAKkrB,EAAAz5B,SAAS6gE,YAAa,MAChD,OAAqBtyD,EAAKkrB,EAAAz5B,SAAS8gE,YAAa,MAChD,OAAqBvyD,EAAKkrB,EAAAz5B,SAAS+gE,YAAa,MAChD,OAAqBxyD,EAAKkrB,EAAAz5B,SAASghE,YAAa,MAChD,OAAqBzyD,EAAKkrB,EAAAz5B,SAASihE,YAAa,MAChD,OAAqB1yD,EAAKkrB,EAAAz5B,SAASkhE,YAAa,MAChD,QAAqB3yD,EAAKkrB,EAAAz5B,SAASmhE,WAAY,MAC/C,QAAqB5yD,EAAKkrB,EAAAz5B,SAASohE,WAAY,MAC/C,OACA,OACO3N,EAASn3E,QAAQc,WACpBmxB,EAAc,GAAT1nB,EAAKxI,KACNo7C,EAAAz5B,SAASihE,YACTxnC,EAAAz5B,SAASkhE,cAQvB,IAAW,GAAP3yD,EAMF,OALAklD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GACxDmH,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GAE5D,OADA8nF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAOmnC,OAAOH,EAAI17B,EAAMC,GAEjC,KAAK85D,EAAey0B,SACpB,KAAKz0B,EAAe00B,SACpB,KAAK10B,EAAe20B,UACpB,KAAK30B,EAAe40B,aACpB,KAAK50B,EAAe60B,WAClB,IAAKhO,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7Ce,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIxsB,EAAOgN,EAAe,IACjB3M,GAAE,KAMT,OALAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWh7D,OAEb8gF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZ9E,GAAe,EACnB,OAAQ1kC,EAAUmQ,cAChB,KAAK4yD,EAAey0B,SAClB,OAAQx6E,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAA/+B,QAAQgnE,YAAa,MAC/C,OACA,OAAqBnzD,EAAKkrB,EAAA/+B,QAAQinE,YAAa,MAC/C,OACA,OAAqBpzD,EAAKkrB,EAAA/+B,QAAQknE,YAAa,MAC/C,OACA,OAAqBrzD,EAAKkrB,EAAA/+B,QAAQmnE,YAAa,MAC/C,OACA,OACEtzD,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAA/+B,QAAQmnE,YACRpoC,EAAA/+B,QAAQknE,YACZ,MAEF,QAAqBrzD,EAAKkrB,EAAA/+B,QAAQonE,YAAa,MAC/C,QAAqBvzD,EAAKkrB,EAAA/+B,QAAQqnE,YAEpC,MAEF,KAAKn1B,EAAe00B,SAClB,OAAQz6E,EAAKxI,MACX,QAAqBkwB,EAAKkrB,EAAA/+B,QAAQsnE,YAAa,MAC/C,QAAqBzzD,EAAKkrB,EAAA/+B,QAAQunE,YAEpC,MAEF,KAAKr1B,EAAe20B,UAClB,OAAQ16E,EAAKxI,MACX,QAAqBkwB,EAAKkrB,EAAA/+B,QAAQwnE,aAAc,MAChD,QAAqB3zD,EAAKkrB,EAAA/+B,QAAQynE,aAEpC,MAEF,KAAKv1B,EAAe40B,aAClB,OAAQ36E,EAAKxI,MACX,OAAqBkwB,EAAKkrB,EAAA/+B,QAAQ0nE,2BAA4B,MAC9D,OAAqB7zD,EAAKkrB,EAAA/+B,QAAQ2nE,2BAA4B,MAC9D,OAAqB9zD,EAAKkrB,EAAA/+B,QAAQ4nE,2BAA4B,MAC9D,OAAqB/zD,EAAKkrB,EAAA/+B,QAAQ6nE,2BAEpC,MAEF,KAAK31B,EAAe60B,WAClB,OAAQ56E,EAAKxI,MACX,OAAqBkwB,EAAKkrB,EAAA/+B,QAAQ8nE,4BAA6B,MAC/D,OAAqBj0D,EAAKkrB,EAAA/+B,QAAQ+nE,4BAA6B,MAC/D,OAAqBl0D,EAAKkrB,EAAA/+B,QAAQgoE,4BAA6B,MAC/D,OAAqBn0D,EAAKkrB,EAAA/+B,QAAQioE,6BAKxC,IAAW,GAAPp0D,EAMF,OALAklD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GAE5D,OADA8nF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO+mC,MAAMC,EAAI17B,GAE1B,KAAK+5D,EAAeg2B,SACpB,KAAKh2B,EAAei2B,SAClB,IAAKpP,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7Ce,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAGhB,IADIxsB,EAAOgN,EAAe,IACjB3M,GAAE,KAMT,OALAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZ9E,GAAmB,EACvB,OAAQ1kC,EAAUmQ,cAChB,KAAK4yD,EAAeg2B,SAClB,OAAQ/7E,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAAtuB,YAAY23D,YAAa,MACnD,OACA,OAAqBv0D,EAAKkrB,EAAAtuB,YAAY43D,YAAa,MACnD,OACA,OAAqBx0D,EAAKkrB,EAAAtuB,YAAY63D,YAAa,MACnD,OACA,OAAqBz0D,EAAKkrB,EAAAtuB,YAAY83D,YAAa,MACnD,OACA,OACE10D,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAAtuB,YAAY83D,YACZxpC,EAAAtuB,YAAY63D,YAIpB,MAEF,KAAKp2B,EAAei2B,SAClB,OAAQh8E,EAAKxI,MACX,OAAqBkwB,EAAKkrB,EAAAtuB,YAAY+3D,aAAc,MACpD,OAAqB30D,EAAKkrB,EAAAtuB,YAAYg4D,aAAc,MACpD,OAAqB50D,EAAKkrB,EAAAtuB,YAAYi4D,aAAc,MACpD,OAAqB70D,EAAKkrB,EAAAtuB,YAAYk4D,aAAc,MACpD,OAAqB90D,EAAKkrB,EAAAtuB,YAAYm4D,aAAc,MACpD,OAAqB/0D,EAAKkrB,EAAAtuB,YAAYo4D,aAAc,MACpD,OAAqBh1D,EAAKkrB,EAAAtuB,YAAYq4D,aAAc,MACpD,OAAqBj1D,EAAKkrB,EAAAtuB,YAAYs4D,aAAc,MACpD,OACEl1D,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAAtuB,YAAYq4D,aACZ/pC,EAAAtuB,YAAYm4D,aAChB,MAEF,OACE/0D,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAAtuB,YAAYs4D,aACZhqC,EAAAtuB,YAAYo4D,cAOxB,IAAW,GAAPh1D,EAMF,OALAklD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWh7D,OAEb8gF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GACxDmH,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKxR,IAAG,GAE3D,OADAyoF,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAOmtC,WAAWnG,EAAI17B,EAAMC,GAErC,KAAK85D,EAAe82B,SACpB,KAAK92B,EAAe+2B,QACpB,KAAK/2B,EAAeg3B,SAClB,IAAKnQ,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACEs3E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZ9E,GAAgB,EACpB,OAAQ1kC,EAAUmQ,cAChB,QAAShI,QAAO,GAChB,KAAK46D,EAAe82B,SAAYn1D,EAAKkrB,EAAAz5B,SAAS6jE,UAAW,MACzD,KAAKj3B,EAAe+2B,QAAYp1D,EAAKkrB,EAAAz5B,SAAS8jE,SAAU,MACxD,KAAKl3B,EAAeg3B,SAAYr1D,EAAKkrB,EAAAz5B,SAAS+jE,UAE5ClxF,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GACxDmH,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GAC5D,OAAOpE,EAAOmnC,OAAOH,EAAI17B,EAAMC,GAEjC,KAAK85D,EAAeo3B,SAClB,IAAKvQ,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACEs3E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GAC5D,OAAOpE,EAAO+mC,MAAMmrB,EAAA/+B,QAAQupE,UAAWpxF,GAEzC,KAAK+5D,EAAes3B,eAClB,IAAKzQ,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACEs3E,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAK7Q,KACrBpE,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GACxDmH,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GACxDoH,GAAO0gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GAC5D,OAAOpE,EAAOgtC,eAAe1hC,EAAMC,EAAMC,IAE3C,KAAK65D,EAAeu3B,cACpB,KAAKv3B,EAAew3B,cAClB,IAAK3Q,EAASn3E,QAAQW,WAAU,GAAgB,MAChD,GACE23E,EAAkB/gE,EAAe85C,EAAY8lB,GAC7Ce,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACrBjE,EAAO8rC,cAGhB,IADIxsB,EAAOgN,EAAe,IACjB3M,GAAE,KAKT,OAJAusE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAENztF,EAAO8rC,cAEZ9E,GAAe,EACnB,OAAQ1kC,EAAUmQ,cAChB,QAAShI,QAAO,GAChB,KAAK46D,EAAeu3B,cAClB,OAAQt9E,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAA/+B,QAAQ8sD,gBAAiB,MACnD,OACA,OAAqBj5C,EAAKkrB,EAAA/+B,QAAQ2pE,gBAAiB,MACnD,OACA,OAAqB91D,EAAKkrB,EAAA/+B,QAAQ4pE,gBAAiB,MACnD,OACA,OAAqB/1D,EAAKkrB,EAAA/+B,QAAQ6pE,gBAAiB,MACnD,OACA,OACEh2D,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAA/+B,QAAQ6pE,gBACR9qC,EAAA/+B,QAAQ4pE,gBAIhB,MAEF,KAAK13B,EAAew3B,cAClB,OAAQv9E,EAAKxI,MACX,OACA,OAAqBkwB,EAAKkrB,EAAA/+B,QAAQ4sD,gBAAiB,MACnD,OACA,OAAqB/4C,EAAKkrB,EAAA/+B,QAAQ8pE,gBAAiB,MACnD,OACA,OAAqBj2D,EAAKkrB,EAAA/+B,QAAQ+pE,gBAAiB,MACnD,OACA,OAAqBl2D,EAAKkrB,EAAA/+B,QAAQgqE,gBAAiB,MACnD,OACA,OACEn2D,EAAKklD,EAASn3E,QAAQc,SAClBq8C,EAAA/+B,QAAQgqE,gBACRjrC,EAAA/+B,QAAQ+pE,iBAOpB,IAAW,GAAPl2D,EAMF,OALAklD,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWqnB,oBAEbvB,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACrBjE,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK7Q,KAAI,GAE5D,OADA8nF,EAASvc,YAAc5hE,EAAAkH,KAAKhR,KACrBjE,EAAO+mC,MAAMC,EAAI17B,GAK1B,KAAK+5D,EAAe+3B,KAClB,IAGIpuE,GAHA1P,EAAOgtE,EAAqBJ,EAAU5/D,EAAekb,EAAU4+B,GAEnE,OADA8lB,EAASvc,YAAc5hE,EAAAkH,KAAKnR,IACvBwb,IACD0P,GAAiB1P,EAAK0P,iBACHA,GAAetT,aAAau2C,EAAA7gD,eAAe0K,YAChEowE,EAASx+E,MACPI,EAAAhD,eAAe4W,wBACf0kD,EAAWh7D,OAENpL,EAAO8rC,eAET9rC,EAAOyD,IAAIurB,GAAe7b,IATfnT,EAAO8rC,cAW3B,KAAKu5B,EAAeg4B,cAClB,GACErQ,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKnR,IAAG,GAG3D,OAFAooF,EAASjc,iBAAe,EACxBic,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAOa,KAAKwkE,EAAeg4B,cAAe,CAAE/xF,GAAQ4mD,EAAAriC,WAAWyY,MAExE,KAAK+8B,EAAei4B,cAClB,GACEtQ,EAAgB1gE,EAAe85C,EAAY9jE,GAC3C2qF,EAAkBzlD,EAAU,EAAG4+B,EAAY8lB,GAG3C,OADAA,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO8rC,cAEZxgC,EAAO4gF,EAASvX,kBAAkBntC,EAAS,GAAI0kD,EAASn3E,QAAQI,UAAS,GACzE5J,EAAO2gF,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAKnR,IAAG,GAG3D,OAFAooF,EAASjc,iBAAe,EACxBic,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAOa,KAAKwkE,EAAei4B,cAAe,CAAEhyF,EAAMC,GAAQ2mD,EAAAriC,WAAWyY,MAO9E,OADIrB,EAmBR,SACEilD,EACA5pF,EACAklC,EACA4+B,GAGA,OAAQ9jE,EAAUmQ,cAOhB,KAAK4yD,EAAek4B,QAAS,OAAOC,EAASn4B,EAAerS,IAAKk5B,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GACzG,KAAKf,EAAeo4B,QAAS,OAAOD,EAASn4B,EAAerS,IAAKk5B,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GACzG,KAAKf,EAAeq4B,QAAS,OAAOF,EAASn4B,EAAekoB,IAAKrB,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GACzG,KAAKf,EAAes4B,QAAS,OAAOH,EAASn4B,EAAekoB,IAAKrB,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GACzG,KAAKf,EAAeu4B,WAAY,OAAOJ,EAASn4B,EAAesoB,OAAQzB,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC/G,KAAKf,EAAew4B,WAAY,OAAOL,EAASn4B,EAAesoB,OAAQzB,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/G,KAAKf,EAAey4B,SAAU,OAAON,EAASn4B,EAAe2oB,KAAM9B,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3G,KAAKf,EAAe04B,SAAU,OAAOP,EAASn4B,EAAe2oB,KAAM9B,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC3G,KAAKf,EAAe24B,SAAU,OAAOR,EAASn4B,EAAe8oB,KAAMjC,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3G,KAAKf,EAAe44B,SAAU,OAAOT,EAASn4B,EAAe8oB,KAAMjC,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC3G,KAAKf,EAAe64B,QAAS,OAAOV,EAASn4B,EAAeipB,IAAKpC,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GACzG,KAAKf,EAAe84B,QAAS,OAAOX,EAASn4B,EAAeipB,IAAKpC,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GACzG,KAAKf,EAAe+4B,QAAS,OAAOZ,EAASn4B,EAAe2F,IAAKkhB,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GACzG,KAAKf,EAAeg5B,QAAS,OAAOb,EAASn4B,EAAe2F,IAAKkhB,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GACzG,KAAKf,EAAei5B,QAAS,OAAOd,EAASn4B,EAAe2pB,IAAK9C,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GACzG,KAAKf,EAAek5B,QAAS,OAAOf,EAASn4B,EAAe2pB,IAAK9C,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GACzG,KAAKf,EAAem5B,SAAU,OAAOhB,EAASn4B,EAAe7S,KAAM05B,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GAC3G,KAAKf,EAAeo5B,SAAU,OAAOjB,EAASn4B,EAAe7S,KAAM05B,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GAC3G,KAAKf,EAAeq5B,UAAW,OAAOlB,EAASn4B,EAAe8pB,MAAOjD,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GAC7G,KAAKf,EAAes5B,UAAW,OAAOnB,EAASn4B,EAAe8pB,MAAOjD,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GAC7G,KAAKf,EAAeu5B,aAAc,OAAOpB,EAASn4B,EAAemqB,SAAUtD,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GACnH,KAAKf,EAAew5B,aAAc,OAAOrB,EAASn4B,EAAemqB,SAAUtD,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GACnH,KAAKf,EAAey5B,YAAa,OAAOtB,EAASn4B,EAAesqB,QAASzD,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GACjH,KAAKf,EAAe05B,YAAa,OAAOvB,EAASn4B,EAAesqB,QAASzD,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GACjH,KAAKf,EAAe25B,oBAAqB,OAAOxB,EAASn4B,EAAeyqB,YAAa5D,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GAC7H,KAAKf,EAAe45B,oBAAqB,OAAOzB,EAASn4B,EAAeyqB,YAAa5D,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GAC7H,KAAKf,EAAe65B,oBAAqB,OAAO1B,EAASn4B,EAAeyqB,YAAa5D,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7H,KAAKf,EAAe85B,oBAAqB,OAAO3B,EAASn4B,EAAeyqB,YAAa5D,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAe+5B,SAAU,OAAO5B,EAASn4B,EAAe8qB,KAAMjE,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GAC3G,KAAKf,EAAeg6B,SAAU,OAAO7B,EAASn4B,EAAe8qB,KAAMjE,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GAC3G,KAAKf,EAAei6B,UAAW,OAAO9B,EAASn4B,EAAeirB,MAAOpE,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GAC7G,KAAKf,EAAek6B,UAAW,OAAO/B,EAASn4B,EAAeirB,MAAOpE,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GAC7G,KAAKf,EAAem6B,YAAa,OAAOhC,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7G,KAAKf,EAAeo6B,YAAa,OAAOjC,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7G,KAAKf,EAAeq6B,aAAc,OAAOlC,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC/G,KAAKf,EAAes6B,aAAc,OAAOnC,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC/G,KAAKf,EAAeu6B,SAAU,OAAOpC,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3G,KAAKf,EAAew6B,YAAa,OAAOrC,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7G,KAAKf,EAAey6B,YAAa,OAAOtC,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7G,KAAKf,EAAe06B,aAAc,OAAOvC,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/G,KAAKf,EAAe26B,aAAc,OAAOxC,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/G,KAAKf,EAAe46B,aAAc,OAAOzC,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/G,KAAKf,EAAe66B,aAAc,OAAO1C,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/G,KAAKf,EAAe86B,SAAU,OAAO3C,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC3G,KAAKf,EAAe+6B,SAAU,OAAO5C,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GAC3G,KAAKf,EAAeg7B,SAAU,OAAO7C,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GAC3G,KAAKf,EAAei7B,WAAY,OAAO9C,EAASn4B,EAAex+B,MAAOqlD,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7G,KAAKf,EAAek7B,YAAa,OAAO/C,EAASn4B,EAAex+B,MAAOqlD,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC/G,KAAKf,EAAem7B,UAAW,OAAOhD,EAASn4B,EAAex+B,MAAOqlD,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7G,KAAKf,EAAeo7B,WAAY,OAAOjD,EAASn4B,EAAex+B,MAAOqlD,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7G,KAAKf,EAAeq7B,YAAa,OAAOlD,EAASn4B,EAAex+B,MAAOqlD,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/G,KAAKf,EAAes7B,YAAa,OAAOnD,EAASn4B,EAAex+B,MAAOqlD,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/G,KAAKf,EAAeu7B,UAAW,OAAOpD,EAASn4B,EAAex+B,MAAOqlD,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7G,KAAKf,EAAew7B,UAAW,OAAOrD,EAASn4B,EAAex+B,MAAOqlD,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GAC7G,KAAKf,EAAey7B,UAAW,OAAOtD,EAASn4B,EAAex+B,MAAOqlD,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GAE/G,GAAI8lB,EAASn3E,QAAQW,WAAU,IAC7B,OAAQpT,EAAUmQ,cAEhB,KAAK4yD,EAAe07B,mBAAoB,OAAOvD,EAASn4B,EAAe78B,YAAa0jD,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3H,KAAKf,EAAe27B,oBAAqB,OAAOxD,EAASn4B,EAAe78B,YAAa0jD,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7H,KAAKf,EAAe47B,gBAAiB,OAAOzD,EAASn4B,EAAe78B,YAAa0jD,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GACzH,KAAKf,EAAe67B,mBAAoB,OAAO1D,EAASn4B,EAAe78B,YAAa0jD,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC3H,KAAKf,EAAe87B,oBAAqB,OAAO3D,EAASn4B,EAAe78B,YAAa0jD,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAe+7B,oBAAqB,OAAO5D,EAASn4B,EAAe78B,YAAa0jD,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAeg8B,gBAAiB,OAAO7D,EAASn4B,EAAe78B,YAAa0jD,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAEzH,KAAKf,EAAei8B,kBAAmB,OAAO9D,EAASn4B,EAAe38B,aAAcwjD,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3H,KAAKf,EAAek8B,mBAAoB,OAAO/D,EAASn4B,EAAe38B,aAAcwjD,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7H,KAAKf,EAAem8B,iBAAkB,OAAOhE,EAASn4B,EAAe38B,aAAcwjD,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3H,KAAKf,EAAeo8B,kBAAmB,OAAOjE,EAASn4B,EAAe38B,aAAcwjD,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC3H,KAAKf,EAAeq8B,mBAAoB,OAAOlE,EAASn4B,EAAe38B,aAAcwjD,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAes8B,mBAAoB,OAAOnE,EAASn4B,EAAe38B,aAAcwjD,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAeu8B,iBAAkB,OAAOpE,EAASn4B,EAAe38B,aAAcwjD,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAE3H,KAAKf,EAAew8B,sBAAuB,OAAOrE,EAASn4B,EAAe4rB,WAAY/E,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7H,KAAKf,EAAey8B,uBAAwB,OAAOtE,EAASn4B,EAAe4rB,WAAY/E,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC/H,KAAKf,EAAe08B,mBAAoB,OAAOvE,EAASn4B,EAAe4rB,WAAY/E,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3H,KAAKf,EAAe28B,sBAAuB,OAAOxE,EAASn4B,EAAe4rB,WAAY/E,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAe48B,uBAAwB,OAAOzE,EAASn4B,EAAe4rB,WAAY/E,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/H,KAAKf,EAAe68B,uBAAwB,OAAO1E,EAASn4B,EAAe4rB,WAAY/E,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/H,KAAKf,EAAe88B,mBAAoB,OAAO3E,EAASn4B,EAAe4rB,WAAY/E,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAE3H,KAAKf,EAAe+8B,sBAAuB,OAAO5E,EAASn4B,EAAe6rB,WAAYhF,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7H,KAAKf,EAAeg9B,uBAAwB,OAAO7E,EAASn4B,EAAe6rB,WAAYhF,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC/H,KAAKf,EAAei9B,mBAAoB,OAAO9E,EAASn4B,EAAe6rB,WAAYhF,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3H,KAAKf,EAAek9B,sBAAuB,OAAO/E,EAASn4B,EAAe6rB,WAAYhF,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAem9B,uBAAwB,OAAOhF,EAASn4B,EAAe6rB,WAAYhF,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/H,KAAKf,EAAeo9B,uBAAwB,OAAOjF,EAASn4B,EAAe6rB,WAAYhF,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/H,KAAKf,EAAeq9B,mBAAoB,OAAOlF,EAASn4B,EAAe6rB,WAAYhF,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAE3H,KAAKf,EAAes9B,sBAAuB,OAAOnF,EAASn4B,EAAe8rB,WAAYjF,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7H,KAAKf,EAAeu9B,uBAAwB,OAAOpF,EAASn4B,EAAe8rB,WAAYjF,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC/H,KAAKf,EAAew9B,mBAAoB,OAAOrF,EAASn4B,EAAe8rB,WAAYjF,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3H,KAAKf,EAAey9B,sBAAuB,OAAOtF,EAASn4B,EAAe8rB,WAAYjF,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAe09B,uBAAwB,OAAOvF,EAASn4B,EAAe8rB,WAAYjF,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/H,KAAKf,EAAe29B,uBAAwB,OAAOxF,EAASn4B,EAAe8rB,WAAYjF,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/H,KAAKf,EAAe49B,mBAAoB,OAAOzF,EAASn4B,EAAe8rB,WAAYjF,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAE3H,KAAKf,EAAe69B,qBAAsB,OAAO1F,EAASn4B,EAAe+rB,UAAWlF,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3H,KAAKf,EAAe89B,sBAAuB,OAAO3F,EAASn4B,EAAe+rB,UAAWlF,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7H,KAAKf,EAAe+9B,kBAAmB,OAAO5F,EAASn4B,EAAe+rB,UAAWlF,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GACzH,KAAKf,EAAeg+B,qBAAsB,OAAO7F,EAASn4B,EAAe+rB,UAAWlF,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC3H,KAAKf,EAAei+B,sBAAuB,OAAO9F,EAASn4B,EAAe+rB,UAAWlF,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAek+B,sBAAuB,OAAO/F,EAASn4B,EAAe+rB,UAAWlF,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAem+B,kBAAmB,OAAOhG,EAASn4B,EAAe+rB,UAAWlF,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAEzH,KAAKf,EAAeo+B,sBAAuB,OAAOjG,EAASn4B,EAAegsB,WAAYnF,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7H,KAAKf,EAAeq+B,uBAAwB,OAAOlG,EAASn4B,EAAegsB,WAAYnF,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC/H,KAAKf,EAAes+B,mBAAoB,OAAOnG,EAASn4B,EAAegsB,WAAYnF,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC3H,KAAKf,EAAeu+B,sBAAuB,OAAOpG,EAASn4B,EAAegsB,WAAYnF,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC7H,KAAKf,EAAew+B,uBAAwB,OAAOrG,EAASn4B,EAAegsB,WAAYnF,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/H,KAAKf,EAAey+B,uBAAwB,OAAOtG,EAASn4B,EAAegsB,WAAYnF,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/H,KAAKf,EAAe0+B,mBAAoB,OAAOvG,EAASn4B,EAAegsB,WAAYnF,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAE3H,KAAKf,EAAe2+B,uBAAwB,OAAOxG,EAASn4B,EAAeisB,YAAapF,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC/H,KAAKf,EAAe4+B,wBAAyB,OAAOzG,EAASn4B,EAAeisB,YAAapF,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GACjI,KAAKf,EAAe6+B,oBAAqB,OAAO1G,EAASn4B,EAAeisB,YAAapF,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC7H,KAAKf,EAAe8+B,uBAAwB,OAAO3G,EAASn4B,EAAeisB,YAAapF,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAC/H,KAAKf,EAAe++B,wBAAyB,OAAO5G,EAASn4B,EAAeisB,YAAapF,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GACjI,KAAKf,EAAeg/B,wBAAyB,OAAO7G,EAASn4B,EAAeisB,YAAapF,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GACjI,KAAKf,EAAei/B,oBAAqB,OAAO9G,EAASn4B,EAAeisB,YAAapF,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAE7H,KAAKf,EAAek/B,0BAA2B,OAAO/G,EAASn4B,EAAev8B,eAAgBojD,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GACrI,KAAKf,EAAem/B,2BAA4B,OAAOhH,EAASn4B,EAAev8B,eAAgBojD,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GACvI,KAAKf,EAAeo/B,uBAAwB,OAAOjH,EAASn4B,EAAev8B,eAAgBojD,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GACnI,KAAKf,EAAeq/B,0BAA2B,OAAOlH,EAASn4B,EAAev8B,eAAgBojD,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GACrI,KAAKf,EAAes/B,2BAA4B,OAAOnH,EAASn4B,EAAev8B,eAAgBojD,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GACvI,KAAKf,EAAeu/B,2BAA4B,OAAOpH,EAASn4B,EAAev8B,eAAgBojD,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GACvI,KAAKf,EAAew/B,uBAAwB,OAAOrH,EAASn4B,EAAev8B,eAAgBojD,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAEnI,KAAKf,EAAey/B,SAAU,OAAOtH,EAASn4B,EAAen8B,YAAagjD,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAClH,KAAKf,EAAe0/B,SAAU,OAAOvH,EAASn4B,EAAen8B,YAAagjD,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAGtH,GAAI8lB,EAASn3E,QAAQW,WAAU,GAC7B,OAAQpT,EAAUmQ,cAEhB,KAAK4yD,EAAe2/B,UAAW,OAAOxH,EAASn4B,EAAep9B,KAAMikD,EAAUn+E,EAAAkH,KAAK7Q,KAAMojC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC9G,KAAKf,EAAe4/B,WAAY,OAAOzH,EAASn4B,EAAex+B,MAAOqlD,EAAUn+E,EAAAkH,KAAK7Q,KAAMojC,EAAUz5B,EAAAkH,KAAKG,KAAMgxD,GAEhH,KAAKf,EAAe6/B,YAAa,OAAO1H,EAASn4B,EAAestB,WAAYzG,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACpH,KAAKf,EAAe8/B,qBAAsB,OAAO3H,EAASn4B,EAAe6tB,kBAAmBhH,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK1R,GAAI6iE,GAClI,KAAKf,EAAe+/B,qBAAsB,OAAO5H,EAASn4B,EAAe6tB,kBAAmBhH,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAKrR,GAAIwiE,GAClI,KAAKf,EAAeggC,mBAAoB,OAAO7H,EAASn4B,EAAeuuB,kBAAmB1H,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAClI,KAAKf,EAAeigC,UAAW,OAAO9H,EAASn4B,EAAeovB,SAAUvI,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAekgC,UAAW,OAAO/H,EAASn4B,EAAeqvB,SAAUxI,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAemgC,UAAW,OAAOhI,EAASn4B,EAAesvB,SAAUzI,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAeogC,UAAW,OAAOjI,EAASn4B,EAAey0B,SAAU5N,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAeqgC,qBAAsB,OAAOlI,EAASn4B,EAAewvB,kBAAmB3I,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACpI,KAAKf,EAAesgC,qBAAsB,OAAOnI,EAASn4B,EAAewvB,kBAAmB3I,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACpI,KAAKf,EAAeugC,qBAAsB,OAAOpI,EAASn4B,EAAeyvB,kBAAmB5I,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACpI,KAAKf,EAAewgC,qBAAsB,OAAOrI,EAASn4B,EAAeyvB,kBAAmB5I,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACpI,KAAKf,EAAeygC,UAAW,OAAOtI,EAASn4B,EAAeg2B,SAAUnP,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAe0gC,YAAa,OAAOvI,EAASn4B,EAAei2B,SAAUpP,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAClH,KAAKf,EAAe2gC,YAAa,OAAOxI,EAASn4B,EAAei2B,SAAUpP,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAClH,KAAKf,EAAe4gC,eAAgB,OAAOzI,EAASn4B,EAAeu3B,cAAe1Q,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GACzH,KAAKf,EAAe6gC,eAAgB,OAAO1I,EAASn4B,EAAew3B,cAAe3Q,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GACzH,KAAKf,EAAe8gC,SAAU,OAAO3I,EAASn4B,EAAe4vB,QAAS/I,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC9G,KAAKf,EAAe+gC,SAAU,OAAO5I,EAASn4B,EAAe6vB,QAAShJ,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC9G,KAAKf,EAAeghC,WAAY,OAAO7I,EAASn4B,EAAe8vB,QAASjJ,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAeihC,WAAY,OAAO9I,EAASn4B,EAAe8vB,QAASjJ,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAekhC,WAAY,OAAO/I,EAASn4B,EAAe+vB,QAASlJ,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAemhC,WAAY,OAAOhJ,EAASn4B,EAAe+vB,QAASlJ,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAeohC,WAAY,OAAOjJ,EAASn4B,EAAegwB,QAASnJ,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAeqhC,WAAY,OAAOlJ,EAASn4B,EAAegwB,QAASnJ,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAeshC,WAAY,OAAOnJ,EAASn4B,EAAeiwB,QAASpJ,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAChH,KAAKf,EAAeuhC,WAAY,OAAOpJ,EAASn4B,EAAeiwB,QAASpJ,EAAUn+E,EAAAkH,KAAKrR,GAAI4jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAEhH,KAAKf,EAAewhC,YAAa,OAAOrJ,EAASn4B,EAAestB,WAAYzG,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACrH,KAAKf,EAAeyhC,qBAAsB,OAAOtJ,EAASn4B,EAAe6tB,kBAAmBhH,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAKzR,IAAK4iE,GACpI,KAAKf,EAAe0hC,qBAAsB,OAAOvJ,EAASn4B,EAAe6tB,kBAAmBhH,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAKpR,IAAKuiE,GACpI,KAAKf,EAAe2hC,mBAAoB,OAAOxJ,EAASn4B,EAAeuuB,kBAAmB1H,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnI,KAAKf,EAAe4hC,UAAW,OAAOzJ,EAASn4B,EAAeovB,SAAUvI,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe6hC,UAAW,OAAO1J,EAASn4B,EAAeqvB,SAAUxI,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe8hC,UAAW,OAAO3J,EAASn4B,EAAesvB,SAAUzI,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe+hC,UAAW,OAAO5J,EAASn4B,EAAey0B,SAAU5N,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAegiC,qBAAsB,OAAO7J,EAASn4B,EAAewvB,kBAAmB3I,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACrI,KAAKf,EAAeiiC,qBAAsB,OAAO9J,EAASn4B,EAAewvB,kBAAmB3I,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACrI,KAAKf,EAAekiC,qBAAsB,OAAO/J,EAASn4B,EAAeyvB,kBAAmB5I,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACrI,KAAKf,EAAemiC,qBAAsB,OAAOhK,EAASn4B,EAAeyvB,kBAAmB5I,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACrI,KAAKf,EAAeoiC,UAAW,OAAOjK,EAASn4B,EAAeg2B,SAAUnP,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeqiC,YAAa,OAAOlK,EAASn4B,EAAei2B,SAAUpP,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnH,KAAKf,EAAesiC,YAAa,OAAOnK,EAASn4B,EAAei2B,SAAUpP,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnH,KAAKf,EAAeuiC,eAAgB,OAAOpK,EAASn4B,EAAeu3B,cAAe1Q,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC1H,KAAKf,EAAewiC,eAAgB,OAAOrK,EAASn4B,EAAew3B,cAAe3Q,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC1H,KAAKf,EAAeyiC,SAAU,OAAOtK,EAASn4B,EAAe4vB,QAAS/I,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAe0iC,SAAU,OAAOvK,EAASn4B,EAAe6vB,QAAShJ,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAe2iC,WAAY,OAAOxK,EAASn4B,EAAe8vB,QAASjJ,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe4iC,WAAY,OAAOzK,EAASn4B,EAAe8vB,QAASjJ,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe6iC,WAAY,OAAO1K,EAASn4B,EAAe+vB,QAASlJ,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe8iC,WAAY,OAAO3K,EAASn4B,EAAe+vB,QAASlJ,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe+iC,WAAY,OAAO5K,EAASn4B,EAAegwB,QAASnJ,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAegjC,WAAY,OAAO7K,EAASn4B,EAAegwB,QAASnJ,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeijC,WAAY,OAAO9K,EAASn4B,EAAeiwB,QAASpJ,EAAUn+E,EAAAkH,KAAKzR,IAAKgkC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAekjC,WAAY,OAAO/K,EAASn4B,EAAeiwB,QAASpJ,EAAUn+E,EAAAkH,KAAKpR,IAAK2jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAEjH,KAAKf,EAAemjC,YAAa,OAAOhL,EAASn4B,EAAestB,WAAYzG,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACrH,KAAKf,EAAeojC,mBAAoB,OAAOjL,EAASn4B,EAAe6tB,kBAAmBhH,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAClI,KAAKf,EAAeqjC,mBAAoB,OAAOlL,EAASn4B,EAAeuuB,kBAAmB1H,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnI,KAAKf,EAAesjC,UAAW,OAAOnL,EAASn4B,EAAeovB,SAAUvI,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeujC,UAAW,OAAOpL,EAASn4B,EAAeqvB,SAAUxI,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAewjC,UAAW,OAAOrL,EAASn4B,EAAesvB,SAAUzI,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeyjC,UAAW,OAAOtL,EAASn4B,EAAey0B,SAAU5N,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe0jC,UAAW,OAAOvL,EAASn4B,EAAeg2B,SAAUnP,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe2jC,YAAa,OAAOxL,EAASn4B,EAAei2B,SAAUpP,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnH,KAAKf,EAAe4jC,YAAa,OAAOzL,EAASn4B,EAAei2B,SAAUpP,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnH,KAAKf,EAAe6jC,eAAgB,OAAO1L,EAASn4B,EAAeu3B,cAAe1Q,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC1H,KAAKf,EAAe8jC,eAAgB,OAAO3L,EAASn4B,EAAew3B,cAAe3Q,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC1H,KAAKf,EAAe+jC,SAAU,OAAO5L,EAASn4B,EAAe4vB,QAAS/I,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAegkC,SAAU,OAAO7L,EAASn4B,EAAe6vB,QAAShJ,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAeikC,WAAY,OAAO9L,EAASn4B,EAAe8vB,QAASjJ,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAekkC,WAAY,OAAO/L,EAASn4B,EAAe8vB,QAASjJ,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAemkC,WAAY,OAAOhM,EAASn4B,EAAe+vB,QAASlJ,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeokC,WAAY,OAAOjM,EAASn4B,EAAe+vB,QAASlJ,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeqkC,WAAY,OAAOlM,EAASn4B,EAAegwB,QAASnJ,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeskC,WAAY,OAAOnM,EAASn4B,EAAegwB,QAASnJ,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeukC,WAAY,OAAOpM,EAASn4B,EAAeiwB,QAASpJ,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAewkC,WAAY,OAAOrM,EAASn4B,EAAeiwB,QAASpJ,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeykC,wBAAyB,OAAOtM,EAASn4B,EAAe60B,WAAYhO,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjI,KAAKf,EAAe0kC,wBAAyB,OAAOvM,EAASn4B,EAAe60B,WAAYhO,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAEjI,KAAKf,EAAe2kC,YAAa,OAAOxM,EAASn4B,EAAestB,WAAYzG,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACrH,KAAKf,EAAe4kC,mBAAoB,OAAOzM,EAASn4B,EAAe6tB,kBAAmBhH,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKvR,IAAK0iE,GAClI,KAAKf,EAAe6kC,mBAAoB,OAAO1M,EAASn4B,EAAeuuB,kBAAmB1H,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnI,KAAKf,EAAe8kC,UAAW,OAAO3M,EAASn4B,EAAeovB,SAAUvI,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe+kC,UAAW,OAAO5M,EAASn4B,EAAeqvB,SAAUxI,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeglC,UAAW,OAAO7M,EAASn4B,EAAey0B,SAAU5N,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeilC,UAAW,OAAO9M,EAASn4B,EAAeg2B,SAAUnP,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeklC,YAAa,OAAO/M,EAASn4B,EAAei2B,SAAUpP,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnH,KAAKf,EAAemlC,YAAa,OAAOhN,EAASn4B,EAAei2B,SAAUpP,EAAUn+E,EAAAkH,KAAKlR,IAAKyjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnH,KAAKf,EAAeolC,eAAgB,OAAOjN,EAASn4B,EAAeu3B,cAAe1Q,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC1H,KAAKf,EAAeqlC,eAAgB,OAAOlN,EAASn4B,EAAew3B,cAAe3Q,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAKxR,IAAK2iE,GAC1H,KAAKf,EAAeslC,wBAAyB,OAAOnN,EAASn4B,EAAe60B,WAAYhO,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjI,KAAKf,EAAeulC,wBAAyB,OAAOpN,EAASn4B,EAAe60B,WAAYhO,EAAUn+E,EAAAkH,KAAKlR,IAAKyjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAEjI,KAAKf,EAAewlC,YAAa,OAAOrN,EAASn4B,EAAestB,WAAYzG,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACrH,KAAKf,EAAeylC,mBAAoB,OAAOtN,EAASn4B,EAAe6tB,kBAAmBhH,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK/Q,IAAKkiE,GAClI,KAAKf,EAAe0lC,mBAAoB,OAAOvN,EAASn4B,EAAeuuB,kBAAmB1H,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnI,KAAKf,EAAe2lC,UAAW,OAAOxN,EAASn4B,EAAeovB,SAAUvI,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe4lC,UAAW,OAAOzN,EAASn4B,EAAeqvB,SAAUxI,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe6lC,UAAW,OAAO1N,EAASn4B,EAAesvB,SAAUzI,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe8lC,UAAW,OAAO3N,EAASn4B,EAAeuvB,SAAU1I,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAe+lC,UAAW,OAAO5N,EAASn4B,EAAey0B,SAAU5N,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAegmC,UAAW,OAAO7N,EAASn4B,EAAe0vB,SAAU7I,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeimC,UAAW,OAAO9N,EAASn4B,EAAe2vB,SAAU9I,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAekmC,UAAW,OAAO/N,EAASn4B,EAAe00B,SAAU7N,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAemmC,WAAY,OAAOhO,EAASn4B,EAAe20B,UAAW9N,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnH,KAAKf,EAAeomC,SAAU,OAAOjO,EAASn4B,EAAe4vB,QAAS/I,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAeqmC,SAAU,OAAOlO,EAASn4B,EAAe6vB,QAAShJ,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAesmC,SAAU,OAAOnO,EAASn4B,EAAe8vB,QAASjJ,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAeumC,SAAU,OAAOpO,EAASn4B,EAAe+vB,QAASlJ,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAewmC,SAAU,OAAOrO,EAASn4B,EAAegwB,QAASnJ,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAeymC,SAAU,OAAOtO,EAASn4B,EAAeiwB,QAASpJ,EAAUn+E,EAAAkH,KAAK/Q,IAAKsjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAe0mC,sBAAuB,OAAOvO,EAASn4B,EAAe40B,aAAc/N,EAAUn+E,EAAAkH,KAAKxR,IAAK+jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjI,KAAKf,EAAe2mC,sBAAuB,OAAOxO,EAASn4B,EAAe40B,aAAc/N,EAAUn+E,EAAAkH,KAAKnR,IAAK0jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAEjI,KAAKf,EAAe4mC,YAAa,OAAOzO,EAASn4B,EAAestB,WAAYzG,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACrH,KAAKf,EAAe6mC,mBAAoB,OAAO1O,EAASn4B,EAAe6tB,kBAAmBhH,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK9Q,IAAKiiE,GAClI,KAAKf,EAAe8mC,mBAAoB,OAAO3O,EAASn4B,EAAeuuB,kBAAmB1H,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnI,KAAKf,EAAe+mC,UAAW,OAAO5O,EAASn4B,EAAeovB,SAAUvI,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAegnC,UAAW,OAAO7O,EAASn4B,EAAeqvB,SAAUxI,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeinC,UAAW,OAAO9O,EAASn4B,EAAesvB,SAAUzI,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeknC,UAAW,OAAO/O,EAASn4B,EAAeuvB,SAAU1I,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAemnC,UAAW,OAAOhP,EAASn4B,EAAey0B,SAAU5N,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeonC,UAAW,OAAOjP,EAASn4B,EAAe0vB,SAAU7I,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeqnC,UAAW,OAAOlP,EAASn4B,EAAe2vB,SAAU9I,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAesnC,UAAW,OAAOnP,EAASn4B,EAAe00B,SAAU7N,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjH,KAAKf,EAAeunC,WAAY,OAAOpP,EAASn4B,EAAe20B,UAAW9N,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACnH,KAAKf,EAAewnC,SAAU,OAAOrP,EAASn4B,EAAe4vB,QAAS/I,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAeynC,SAAU,OAAOtP,EAASn4B,EAAe6vB,QAAShJ,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAe0nC,SAAU,OAAOvP,EAASn4B,EAAe8vB,QAASjJ,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAe2nC,SAAU,OAAOxP,EAASn4B,EAAe+vB,QAASlJ,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAe4nC,SAAU,OAAOzP,EAASn4B,EAAegwB,QAASnJ,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAe6nC,SAAU,OAAO1P,EAASn4B,EAAeiwB,QAASpJ,EAAUn+E,EAAAkH,KAAK9Q,IAAKqjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAC/G,KAAKf,EAAe8nC,sBAAuB,OAAO3P,EAASn4B,EAAe40B,aAAc/N,EAAUn+E,EAAAkH,KAAKvR,IAAK8jC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GACjI,KAAKf,EAAe+nC,sBAAuB,OAAO5P,EAASn4B,EAAe40B,aAAc/N,EAAUn+E,EAAAkH,KAAKlR,IAAKyjC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAEjI,KAAKf,EAAegoC,cAAe,OAAO7P,EAASn4B,EAAe8uB,aAAcjI,EAAUn+E,EAAAkH,KAAK1R,GAAIikC,EAAUz5B,EAAAkH,KAAK7Q,KAAMgiE,GAI5H,OAAO,EA3TMknC,CAAYphB,EAAU5pF,EAAWklC,EAAU4+B,KAEhD95C,GACF4/D,EAASx+E,MACPI,EAAAhD,eAAe42D,sBACf0E,EAAWqnB,mBAAoBnrF,EAAUmQ,cAGtCw0B,IAGXilD,EAASx+E,MACPI,EAAAhD,eAAeq3D,mBACfiE,EAAW/7B,WAAWj/B,MAAO9I,EAAUmQ,cAElCzS,EAAO8rC,eAgThB,SAAS0xD,EACPv8F,EACAirF,EACA7pB,EACA76B,EACAy7B,EACAmD,GAEA37D,OAAOyhF,EAASrmE,QAAQlU,eAAekD,IAAI5T,IAC3C,IAAIqB,EAAY4pF,EAASrmE,QAAQlU,eAAepQ,IAAIN,GAEpD,OADAwJ,OAAOnI,EAAUwU,MAAQm7C,EAAA9gD,YAAYkN,oBAC9B6mE,EACLgH,EACmB5pF,EACnB,CAAE+/D,GACF76B,EACAy7B,EACAmD,GACY,GAKhB,SAAgB8V,EACdgQ,EACA/gF,EACAi7D,GAEA,IAAIvgD,EAAUqmE,EAASrmE,QACnB7lB,EAASksF,EAASlsF,OAElBsa,EAAiB4xE,EAASrmE,QAAQvL,eACtC,IAAKA,EAAgB,OAAOta,EAAO8rC,cAEnC,IAGIyhE,EAHAzwF,EAAgB+I,EAAQ/I,cAC5B,IAAMA,IAAiBovE,EAASrW,gBAAgB/4D,GAAiB,OAAO9c,EAAO8rC,cAQ7EyhE,EALc,OAAZpiG,EAKW+gF,EAASvX,kBAAkBxpE,EAASmP,EAAegF,KAAM,IAEzDhF,EAAegF,KAAKy0C,aAAa/zD,GAGhD,IAAIwtG,EAActhB,EAAS7U,mBAAmBjR,EAAWh7D,MAAMY,OAAOC,gBAGtE,OADAigF,EAASvc,YAAc5hE,EAAAkH,KAAKG,KACrBpV,EAAO6pC,MAAM,KAAM,CACxB7pC,EAAOa,KACLic,EAAcrK,aAAc,CAC1B86F,EACAC,EACAxtG,EAAOyD,IAAI2iE,EAAWh7D,MAAMc,MAC5BlM,EAAOyD,IAAI2iE,EAAWh7D,MAAMe,SAE9B+lD,EAAAriC,WAAWyY,MAEbtoC,EAAO8rC,gBA6KX,SAAS2hE,EAAmBnuF,GAC1B,IAAIjM,EAAQ,IAA+B,GAAKiM,EAAKwqE,WAKrD,OAJIxqE,EAAKK,GAAE,KAAoBtM,GAAK,MAChCiM,EAAKK,GAAE,KAAmBtM,GAAK,MAC/BiM,EAAKK,GAAE,OAAsBtM,GAAK,MAClCiM,EAAK2zD,YAAW5/D,GAAK,MAClBA,EAAK,GA2Dd,SAASi5E,EACPJ,EACA5/D,EACAkb,EACA4+B,GAEA,GAAuB,GAAnB5+B,EAASh7B,OACX,OAAK8f,GAAyC,GAAxBA,EAAc9f,OAO7B8f,EAAc,IANnB4/D,EAASx+E,MACPI,EAAAhD,eAAes3D,oCACfgE,EAAWqnB,mBAAoB,IAAKnhE,EAAgBA,EAAc9f,OAAOT,SAAS,IAAM,KAEnF,MAIX,GAAuB,GAAnBy7B,EAASh7B,OAAa,CACxB,GAAsB,OAAlB8f,GAA0BA,EAAc9f,OAAQ,CAClD,GAAI8f,EAAc9f,OAAS,EAKzB,OAJA0/E,EAASx+E,MACPI,EAAAhD,eAAes3D,oCACfgE,EAAWqnB,mBAAoB,IAAKnhE,EAAc9f,OAAOT,SAAS,KAE7D,KAETmgF,EAASvX,kBAAkBntC,EAAS,GAAIlb,EAAc,GAAE,QAExD4/D,EAASvX,kBAAkBntC,EAAS,GAAIz5B,EAAAkH,KAAK89C,MAE/C,OAAOm5B,EAASvc,YAYlB,OAVIrjD,GAAiBA,EAAc9f,OAAS,GAC1C0/E,EAASx+E,MACPI,EAAAhD,eAAes3D,oCACfgE,EAAWqnB,mBAAoB,IAAKnhE,EAAc9f,OAAOT,SAAS,KAGtEmgF,EAASx+E,MACPI,EAAAhD,eAAekZ,+BACfoiD,EAAWsnC,eAAgB,IAAKlmE,EAASh7B,OAAOT,SAAS,KAEpD,KAIT,SAAS4kF,EAAwBtmD,EAAwB6hD,GACvD,IAAIjlD,EACAtlC,EA6BJ,OA5BIuqF,EAASn3E,QAAQc,UACnBoxB,EAAOilD,EAASr5C,qBAAqBxI,EAAYt8B,EAAAkH,KAAK49C,QAAO,IAE3DX,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAaolB,OACtCgd,EAAA7a,kBAAkBpQ,IAASirB,EAAAriC,WAAWnpB,KACR,GAA9BwrD,EAAA1a,qBAAqBvQ,KACpBtlC,EAAQuwD,EAAA3a,oBAAoBtQ,IAAS,KAEtCilD,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACfpoD,EAAWj/B,OAEbzJ,GAAS,KAGXslC,EAAOilD,EAASr5C,qBAAqBxI,EAAYt8B,EAAAkH,KAAK69C,QAAO,IAE3DZ,EAAA9a,gBAAgBnQ,IAASirB,EAAApiC,aAAaolB,OACtCgd,EAAA7a,kBAAkBpQ,IAASirB,EAAAriC,WAAWppB,MACrC9E,EAAQuwD,EAAA5a,iBAAiBrQ,IAAS,KAEnCilD,EAASx+E,MACPI,EAAAhD,eAAe2nF,2CACfpoD,EAAWj/B,OAEbzJ,GAAS,IAGNA,EAIT,SAAS0rF,EACP/gE,EACA85C,EACA8lB,EACAyhB,GAEA,QAFA,IAAAA,OAAA,GAEIrhF,EAAe,CACjB,IAAIe,EAAmBf,EAAc9f,OACrC,GAAwB,GAApB6gB,EAAuB,OAAO,EAClC5iB,OAAO4iB,GACHsgF,IAAuBzhB,EAASvc,YAAcrjD,EAAc,IAChE4/D,EAASx+E,MACPI,EAAAhD,eAAes3D,oCACfgE,EAAWqnB,mBAAoB,IAAKpgE,EAAiBthB,iBAGvDmgF,EAASx+E,MACPI,EAAAhD,eAAes3D,oCACfgE,EAAWh7D,MAAO,IAAK,KAG3B,OAAO,EAIT,SAASwiF,EACPthE,EACA85C,EACA8lB,EACAyhB,GAEA,QAFA,IAAAA,OAAA,GAEIrhF,EAAe,CACjB,IAAIe,EAAmBf,EAAc9f,OACrC,OAAwB,GAApB6gB,EAA8B,GAClC5iB,OAAO4iB,GACHsgF,IAAuBzhB,EAASvc,YAAcrjD,EAAc,IAChE4/D,EAASx+E,MACPI,EAAAhD,eAAes3D,oCACfgE,EAAWqnB,mBAAoB,IAAKpgE,EAAiBthB,YAEhD,GAET,OAAO,EAIT,SAASihF,EACP1gE,EACA85C,EACA9jE,GAEA,OAAIgqB,GACFhqB,EAAUujB,QAAQnY,MAChBI,EAAAhD,eAAe42D,sBACf0E,EAAWqnB,mBAAoBnrF,EAAUmQ,cAEpC,GAEF,EAIT,SAASw6E,EACPzlD,EACAuB,EACAq9B,EACA8lB,GAEA,OAAI1kD,EAASh7B,QAAUu8B,GACrBmjD,EAASx+E,MACPI,EAAAhD,eAAekZ,+BACfoiD,EAAWh7D,MAAO29B,EAASh9B,WAAYy7B,EAASh7B,OAAOT,YAElD,GAEF,EAIT,SAASyhF,EACPhmD,EACAomE,EACAC,EACAznC,EACA8lB,GAEA,IAAIlE,EAAcxgD,EAASh7B,OAC3B,OAAIw7E,EAAc4lB,GAChB1hB,EAASx+E,MACPI,EAAAhD,eAAew6E,wCACflf,EAAWh7D,MAAOwiG,EAAgB7hG,WAAYi8E,EAAYj8E,YAErD,GACEi8E,EAAc6lB,GACvB3hB,EAASx+E,MACPI,EAAAhD,eAAekZ,+BACfoiD,EAAWh7D,MAAOyiG,EAAgB9hG,WAAYi8E,EAAYj8E,YAErD,GAEF,GA3sIT,SAAiBs5D,GAEFA,EAAAgnB,UAAY,0BACZhnB,EAAAknB,QAAU,wBACVlnB,EAAAmnB,UAAY,0BACZnnB,EAAAonB,SAAW,yBACXpnB,EAAAqnB,YAAc,4BACdrnB,EAAAsnB,SAAW,yBACXtnB,EAAAunB,QAAU,wBACVvnB,EAAAwnB,YAAc,4BACdxnB,EAAAynB,WAAa,2BACbznB,EAAA3hB,WAAa,2BACb2hB,EAAA0nB,UAAY,0BACZ1nB,EAAA8nB,WAAa,2BACb9nB,EAAA4N,UAAY,0BAEZ5N,EAAArS,IAAM,oBACNqS,EAAAkoB,IAAM,oBACNloB,EAAAsoB,OAAS,uBACTtoB,EAAA2oB,KAAO,qBACP3oB,EAAA8oB,KAAO,qBACP9oB,EAAAipB,IAAM,oBACNjpB,EAAA2F,IAAM,oBACN3F,EAAA2pB,IAAM,oBACN3pB,EAAA7S,KAAO,qBACP6S,EAAA8pB,MAAQ,sBACR9pB,EAAAmqB,SAAW,yBACXnqB,EAAAsqB,QAAU,wBACVtqB,EAAAyqB,YAAc,4BACdzqB,EAAA8qB,KAAO,qBACP9qB,EAAAirB,MAAQ,sBACRjrB,EAAAp9B,KAAO,qBACPo9B,EAAAx+B,MAAQ,sBACRw+B,EAAA78B,YAAc,4BACd68B,EAAA38B,aAAe,6BACf28B,EAAA4rB,WAAa,2BACb5rB,EAAA6rB,WAAa,2BACb7rB,EAAA8rB,WAAa,2BACb9rB,EAAA+rB,UAAY,0BACZ/rB,EAAAgsB,WAAa,2BACbhsB,EAAAisB,YAAc,4BACdjsB,EAAAv8B,eAAiB,+BACjBu8B,EAAAn8B,YAAc,4BACdm8B,EAAA/7B,cAAgB,8BAEhB+7B,EAAA+nB,OAAS,uBACT/nB,EAAAioB,QAAU,wBACVjoB,EAAAv3C,SAAW,yBACXu3C,EAAAp6B,OAAS,uBACTo6B,EAAAv5B,YAAc,4BACdu5B,EAAA7/B,WAAa,2BACb6/B,EAAA56D,OAAS,uBACT46D,EAAA13C,UAAY,0BACZ03C,EAAA6sB,YAAc,4BACd7sB,EAAA15B,cAAgB,8BAChB05B,EAAAktB,YAAc,4BACdltB,EAAA+3B,KAAO,qBAEP/3B,EAAA9hE,GAAK,mBACL8hE,EAAA7hE,IAAM,oBACN6hE,EAAA5hE,IAAM,oBACN4hE,EAAA3hE,IAAM,oBACN2hE,EAAA1hE,MAAQ,sBACR0hE,EAAAzhE,GAAK,mBACLyhE,EAAAxhE,IAAM,oBACNwhE,EAAAvhE,IAAM,oBACNuhE,EAAAthE,IAAM,oBACNshE,EAAArhE,MAAQ,sBACRqhE,EAAAphE,KAAO,qBACPohE,EAAAnhE,IAAM,oBACNmhE,EAAAlhE,IAAM,oBACNkhE,EAAAjhE,KAAO,qBACPihE,EAAAtgE,MAAQ,qBAERsgE,EAAAk4B,QAAU,wBACVl4B,EAAAo4B,QAAU,wBACVp4B,EAAAq4B,QAAU,wBACVr4B,EAAAs4B,QAAU,wBACVt4B,EAAAu4B,WAAa,2BACbv4B,EAAAw4B,WAAa,2BACbx4B,EAAAy4B,SAAW,yBACXz4B,EAAA04B,SAAW,yBACX14B,EAAA24B,SAAW,yBACX34B,EAAA44B,SAAW,yBAEX54B,EAAA64B,QAAU,wBACV74B,EAAA84B,QAAU,wBACV94B,EAAA+4B,QAAU,wBACV/4B,EAAAg5B,QAAU,wBACVh5B,EAAAi5B,QAAU,wBACVj5B,EAAAk5B,QAAU,wBACVl5B,EAAAm5B,SAAW,yBACXn5B,EAAAo5B,SAAW,yBACXp5B,EAAAq5B,UAAY,0BACZr5B,EAAAs5B,UAAY,0BACZt5B,EAAAu5B,aAAe,6BACfv5B,EAAAw5B,aAAe,6BACfx5B,EAAAy5B,YAAc,4BACdz5B,EAAA05B,YAAc,4BACd15B,EAAA25B,oBAAsB,oCACtB35B,EAAA45B,oBAAsB,oCACtB55B,EAAA65B,oBAAsB,oCACtB75B,EAAA85B,oBAAsB,oCACtB95B,EAAA+5B,SAAW,yBACX/5B,EAAAg6B,SAAW,yBACXh6B,EAAAi6B,UAAY,0BACZj6B,EAAAk6B,UAAY,0BAEZl6B,EAAAm6B,YAAc,4BACdn6B,EAAAo6B,YAAc,4BACdp6B,EAAAq6B,aAAe,6BACfr6B,EAAAs6B,aAAe,6BACft6B,EAAAu6B,SAAW,yBACXv6B,EAAAw6B,YAAc,4BACdx6B,EAAAy6B,YAAc,4BACdz6B,EAAA06B,aAAe,6BACf16B,EAAA26B,aAAe,6BACf36B,EAAA46B,aAAe,6BACf56B,EAAA66B,aAAe,6BACf76B,EAAA86B,SAAW,yBACX96B,EAAA+6B,SAAW,yBACX/6B,EAAAg7B,SAAW,yBACXh7B,EAAAi7B,WAAa,2BACbj7B,EAAAk7B,YAAc,4BACdl7B,EAAAm7B,UAAY,0BACZn7B,EAAAo7B,WAAa,2BACbp7B,EAAAq7B,YAAc,4BACdr7B,EAAAs7B,YAAc,4BACdt7B,EAAAu7B,UAAY,0BACZv7B,EAAAw7B,UAAY,0BACZx7B,EAAAy7B,UAAY,0BAEZz7B,EAAA07B,mBAAqB,mCACrB17B,EAAA27B,oBAAsB,oCACtB37B,EAAA47B,gBAAkB,gCAClB57B,EAAA67B,mBAAqB,mCACrB77B,EAAA87B,oBAAsB,oCACtB97B,EAAA+7B,oBAAsB,oCACtB/7B,EAAAg8B,gBAAkB,gCAClBh8B,EAAAi8B,kBAAoB,kCACpBj8B,EAAAk8B,mBAAqB,mCACrBl8B,EAAAm8B,iBAAmB,iCACnBn8B,EAAAo8B,kBAAoB,kCACpBp8B,EAAAq8B,mBAAqB,mCACrBr8B,EAAAs8B,mBAAqB,mCACrBt8B,EAAAu8B,iBAAmB,iCACnBv8B,EAAAw8B,sBAAwB,sCACxBx8B,EAAAy8B,uBAAyB,uCACzBz8B,EAAA08B,mBAAqB,mCACrB18B,EAAA28B,sBAAwB,sCACxB38B,EAAA48B,uBAAyB,uCACzB58B,EAAA68B,uBAAyB,uCACzB78B,EAAA88B,mBAAqB,mCACrB98B,EAAA+8B,sBAAwB,sCACxB/8B,EAAAg9B,uBAAyB,uCACzBh9B,EAAAi9B,mBAAqB,mCACrBj9B,EAAAk9B,sBAAwB,sCACxBl9B,EAAAm9B,uBAAyB,uCACzBn9B,EAAAo9B,uBAAyB,uCACzBp9B,EAAAq9B,mBAAqB,mCACrBr9B,EAAAs9B,sBAAwB,sCACxBt9B,EAAAu9B,uBAAyB,uCACzBv9B,EAAAw9B,mBAAqB,mCACrBx9B,EAAAy9B,sBAAwB,sCACxBz9B,EAAA09B,uBAAyB,uCACzB19B,EAAA29B,uBAAyB,uCACzB39B,EAAA49B,mBAAqB,mCACrB59B,EAAA69B,qBAAuB,qCACvB79B,EAAA89B,sBAAwB,sCACxB99B,EAAA+9B,kBAAoB,kCACpB/9B,EAAAg+B,qBAAuB,qCACvBh+B,EAAAi+B,sBAAwB,sCACxBj+B,EAAAk+B,sBAAwB,sCACxBl+B,EAAAm+B,kBAAoB,kCACpBn+B,EAAAo+B,sBAAwB,sCACxBp+B,EAAAq+B,uBAAyB,uCACzBr+B,EAAAs+B,mBAAqB,mCACrBt+B,EAAAu+B,sBAAwB,sCACxBv+B,EAAAw+B,uBAAyB,uCACzBx+B,EAAAy+B,uBAAyB,uCACzBz+B,EAAA0+B,mBAAqB,mCACrB1+B,EAAA2+B,uBAAyB,uCACzB3+B,EAAA4+B,wBAA0B,wCAC1B5+B,EAAA6+B,oBAAsB,oCACtB7+B,EAAA8+B,uBAAyB,uCACzB9+B,EAAA++B,wBAA0B,wCAC1B/+B,EAAAg/B,wBAA0B,wCAC1Bh/B,EAAAi/B,oBAAsB,oCACtBj/B,EAAAk/B,0BAA4B,0CAC5Bl/B,EAAAm/B,2BAA6B,2CAC7Bn/B,EAAAo/B,uBAAyB,uCACzBp/B,EAAAq/B,0BAA4B,0CAC5Br/B,EAAAs/B,2BAA6B,2CAC7Bt/B,EAAAu/B,2BAA6B,2CAC7Bv/B,EAAAw/B,uBAAyB,uCACzBx/B,EAAAy/B,SAAW,yBACXz/B,EAAA0/B,SAAW,yBAEX1/B,EAAAstB,WAAa,2BACbttB,EAAA6tB,kBAAoB,kCACpB7tB,EAAAuuB,kBAAoB,kCACpBvuB,EAAA8uB,aAAe,6BACf9uB,EAAA2/B,UAAY,0BACZ3/B,EAAA4/B,WAAa,2BACb5/B,EAAAovB,SAAW,yBACXpvB,EAAAqvB,SAAW,yBACXrvB,EAAAsvB,SAAW,yBACXtvB,EAAAuvB,SAAW,yBACXvvB,EAAAy0B,SAAW,yBACXz0B,EAAAwvB,kBAAoB,kCACpBxvB,EAAAyvB,kBAAoB,kCACpBzvB,EAAAg2B,SAAW,yBACXh2B,EAAAi2B,SAAW,yBACXj2B,EAAA82B,SAAW,yBACX92B,EAAA+2B,QAAU,wBACV/2B,EAAAg3B,SAAW,yBACXh3B,EAAAo3B,SAAW,yBACXp3B,EAAAs3B,eAAiB,+BACjBt3B,EAAAu3B,cAAgB,8BAChBv3B,EAAAw3B,cAAgB,8BAChBx3B,EAAA0vB,SAAW,yBACX1vB,EAAA2vB,SAAW,yBACX3vB,EAAA00B,SAAW,yBACX10B,EAAA20B,UAAY,0BACZ30B,EAAA4vB,QAAU,wBACV5vB,EAAA6vB,QAAU,wBACV7vB,EAAA8vB,QAAU,wBACV9vB,EAAA+vB,QAAU,wBACV/vB,EAAAgwB,QAAU,wBACVhwB,EAAAiwB,QAAU,wBACVjwB,EAAA40B,aAAe,6BACf50B,EAAA60B,WAAa,2BAEb70B,EAAAhhE,MAAQ,sBACRghE,EAAA9gE,MAAQ,sBACR8gE,EAAA5gE,MAAQ,sBACR4gE,EAAA1gE,MAAQ,sBACR0gE,EAAAxgE,MAAQ,sBACRwgE,EAAAvgE,MAAQ,sBAERugE,EAAA6/B,YAAc,4BACd7/B,EAAA8/B,qBAAuB,qCACvB9/B,EAAA+/B,qBAAuB,qCACvB//B,EAAAggC,mBAAqB,mCACrBhgC,EAAAigC,UAAY,0BACZjgC,EAAAkgC,UAAY,0BACZlgC,EAAAmgC,UAAY,0BACZngC,EAAAogC,UAAY,0BACZpgC,EAAAqgC,qBAAuB,qCACvBrgC,EAAAsgC,qBAAuB,qCACvBtgC,EAAAugC,qBAAuB,qCACvBvgC,EAAAwgC,qBAAuB,qCACvBxgC,EAAAygC,UAAY,0BACZzgC,EAAA0gC,YAAc,4BACd1gC,EAAA2gC,YAAc,4BACd3gC,EAAA4gC,eAAiB,+BACjB5gC,EAAA6gC,eAAiB,+BACjB7gC,EAAA8gC,SAAW,yBACX9gC,EAAA+gC,SAAW,yBACX/gC,EAAAghC,WAAa,2BACbhhC,EAAAihC,WAAa,2BACbjhC,EAAAkhC,WAAa,2BACblhC,EAAAmhC,WAAa,2BACbnhC,EAAAohC,WAAa,2BACbphC,EAAAqhC,WAAa,2BACbrhC,EAAAshC,WAAa,2BACbthC,EAAAuhC,WAAa,2BAEbvhC,EAAAwhC,YAAc,4BACdxhC,EAAAyhC,qBAAuB,qCACvBzhC,EAAA0hC,qBAAuB,qCACvB1hC,EAAA2hC,mBAAqB,mCACrB3hC,EAAA4hC,UAAY,0BACZ5hC,EAAA6hC,UAAY,0BACZ7hC,EAAA8hC,UAAY,0BACZ9hC,EAAA+hC,UAAY,0BACZ/hC,EAAAgiC,qBAAuB,qCACvBhiC,EAAAiiC,qBAAuB,qCACvBjiC,EAAAkiC,qBAAuB,qCACvBliC,EAAAmiC,qBAAuB,qCACvBniC,EAAAoiC,UAAY,0BACZpiC,EAAAqiC,YAAc,4BACdriC,EAAAsiC,YAAc,4BACdtiC,EAAAuiC,eAAiB,+BACjBviC,EAAAwiC,eAAiB,+BACjBxiC,EAAAyiC,SAAW,yBACXziC,EAAA0iC,SAAW,yBACX1iC,EAAA2iC,WAAa,2BACb3iC,EAAA4iC,WAAa,2BACb5iC,EAAA6iC,WAAa,2BACb7iC,EAAA8iC,WAAa,2BACb9iC,EAAA+iC,WAAa,2BACb/iC,EAAAgjC,WAAa,2BACbhjC,EAAAijC,WAAa,2BACbjjC,EAAAkjC,WAAa,2BAEbljC,EAAAmjC,YAAc,4BACdnjC,EAAAojC,mBAAqB,mCACrBpjC,EAAAqjC,mBAAqB,mCACrBrjC,EAAAsjC,UAAY,0BACZtjC,EAAAujC,UAAY,0BACZvjC,EAAAwjC,UAAY,0BACZxjC,EAAAyjC,UAAY,0BACZzjC,EAAA0jC,UAAY,0BACZ1jC,EAAA2jC,YAAc,4BACd3jC,EAAA4jC,YAAc,4BACd5jC,EAAA6jC,eAAiB,+BACjB7jC,EAAA8jC,eAAiB,+BACjB9jC,EAAA+jC,SAAW,yBACX/jC,EAAAgkC,SAAW,yBACXhkC,EAAAikC,WAAa,2BACbjkC,EAAAkkC,WAAa,2BACblkC,EAAAmkC,WAAa,2BACbnkC,EAAAokC,WAAa,2BACbpkC,EAAAqkC,WAAa,2BACbrkC,EAAAskC,WAAa,2BACbtkC,EAAAukC,WAAa,2BACbvkC,EAAAwkC,WAAa,2BACbxkC,EAAAykC,wBAA0B,wCAC1BzkC,EAAA0kC,wBAA0B,wCAE1B1kC,EAAA2kC,YAAc,4BACd3kC,EAAA4kC,mBAAqB,mCACrB5kC,EAAA6kC,mBAAqB,mCACrB7kC,EAAA8kC,UAAY,0BACZ9kC,EAAA+kC,UAAY,0BACZ/kC,EAAAglC,UAAY,0BACZhlC,EAAAilC,UAAY,0BACZjlC,EAAAklC,YAAc,4BACdllC,EAAAmlC,YAAc,4BACdnlC,EAAAolC,eAAiB,+BACjBplC,EAAAqlC,eAAiB,+BACjBrlC,EAAAslC,wBAA0B,wCAC1BtlC,EAAAulC,wBAA0B,wCAE1BvlC,EAAAwlC,YAAc,4BACdxlC,EAAAylC,mBAAqB,mCACrBzlC,EAAA0lC,mBAAqB,mCACrB1lC,EAAA2lC,UAAY,0BACZ3lC,EAAA4lC,UAAY,0BACZ5lC,EAAA6lC,UAAY,0BACZ7lC,EAAA8lC,UAAY,0BACZ9lC,EAAA+lC,UAAY,0BACZ/lC,EAAAgmC,UAAY,0BACZhmC,EAAAimC,UAAY,0BACZjmC,EAAAkmC,UAAY,0BACZlmC,EAAAmmC,WAAa,2BACbnmC,EAAAomC,SAAW,yBACXpmC,EAAAqmC,SAAW,yBACXrmC,EAAAsmC,SAAW,yBACXtmC,EAAAumC,SAAW,yBACXvmC,EAAAwmC,SAAW,yBACXxmC,EAAAymC,SAAW,yBACXzmC,EAAA0mC,sBAAwB,sCACxB1mC,EAAA2mC,sBAAwB,sCAExB3mC,EAAA4mC,YAAc,4BACd5mC,EAAA6mC,mBAAqB,mCACrB7mC,EAAA8mC,mBAAqB,mCACrB9mC,EAAA+mC,UAAY,0BACZ/mC,EAAAgnC,UAAY,0BACZhnC,EAAAinC,UAAY,0BACZjnC,EAAAknC,UAAY,0BACZlnC,EAAAmnC,UAAY,0BACZnnC,EAAAonC,UAAY,0BACZpnC,EAAAqnC,UAAY,0BACZrnC,EAAAsnC,UAAY,0BACZtnC,EAAAunC,WAAa,2BACbvnC,EAAAwnC,SAAW,yBACXxnC,EAAAynC,SAAW,yBACXznC,EAAA0nC,SAAW,yBACX1nC,EAAA2nC,SAAW,yBACX3nC,EAAA4nC,SAAW,yBACX5nC,EAAA6nC,SAAW,yBACX7nC,EAAA8nC,sBAAwB,sCACxB9nC,EAAA+nC,sBAAwB,sCAExB/nC,EAAAgoC,cAAgB,8BAGhBhoC,EAAA4L,UAAY,wBACZ5L,EAAA6L,UAAY,sBACZ7L,EAAAg4B,cAAgB,0BAChBh4B,EAAAi4B,cAAgB,0BAGhBj4B,EAAA76D,MAAQ,yBACR66D,EAAA96D,QAAU,2BACV86D,EAAA/6D,KAAO,wBAGP+6D,EAAAwsB,YAAc,0BACdxsB,EAAA0sB,YAAc,0BACd1sB,EAAAr5B,YAAc,0BACdq5B,EAAAl5B,YAAc,0BACdk5B,EAAAyoC,gBAAkB,8BAClBzoC,EAAA0oC,YAAc,0BACd1oC,EAAA2oC,aAAe,2BAGf3oC,EAAA4oC,mBAAqB,kCACrB5oC,EAAA6oC,cAAgB,6BAChB7oC,EAAA8oC,iBAAmB,6BACnB9oC,EAAA+oC,mBAAqB,+BACrB/oC,EAAAgpC,iBAAmB,6BACnBhpC,EAAAipC,gBAAkB,4BAClBjpC,EAAAkpC,kBAAoB,8BAGpBlpC,EAAAv9D,UAAY,4BACZu9D,EAAAn9D,WAAa,6BACbm9D,EAAAt9D,WAAa,6BACbs9D,EAAAj9D,YAAc,8BACdi9D,EAAAr9D,WAAa,6BACbq9D,EAAAh9D,YAAc,8BACdg9D,EAAAp9D,WAAa,6BACbo9D,EAAA/8D,YAAc,8BACd+8D,EAAAl9D,kBAAoB,oCACpBk9D,EAAA98D,aAAe,+BACf88D,EAAA78D,aAAe,+BAGf68D,EAAAkM,QAAU,eACVlM,EAAA4hB,KAAO,YACP5hB,EAAA+hB,QAAU,eACV/hB,EAAAmpC,aAAe,oBAza9B,CAAiBnpC,EAAAtlE,EAAAslE,iBAAAtlE,EAAAslE,eAAc,KA6a/BtlE,EAAAmlF,cAs1GAnlF,EAAAm8E,eA2CAn8E,EAAA4xE,oBAAA,SAAoCua,WAC9BlsF,EAASksF,EAASlsF,OAClBsoF,EAAQ,IAAIhhF,MACZ4mC,EAAUg+C,EAASxa,mBAAmB,CAAE3jE,EAAAkH,KAAKnR,KAAOiK,EAAAkH,KAAKG,MACzDg+D,EAAiB8Y,EAASn3E,QAAQq+D,eAClC31D,EAAgBhT,OAAOyhF,EAASrmE,QAAQpI,eAE5CyuE,EAASrW,gBAAgBp4D,OAEzB,IAAoB,IAAAsJ,EAAA3O,EAAA8zE,EAASrmE,QAAQlU,eAAeiM,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAE,CAAzD,IAAIW,EAAOwF,EAAA9c,MACd,GAAIsX,EAAQnC,MAAQm7C,EAAA9gD,YAAYmQ,OAAhC,CACA,IAAIuqD,EAAiB5yD,EACjB+V,EAAiB68C,EAAOvsD,KAAK0P,eACjC,GACE68C,EAAOlsD,GAAG9R,EAAAnL,YAAYiwE,WACH,OAAnB3jD,IACCA,EAAetT,aAAau2C,EAAA7gD,eAAe0K,WAE5C,GAAI+vD,EAAOlsD,GAAG9R,EAAAnL,YAAYilB,SAAU,CAClC,IAAIhmB,EAAQkqE,EAAOnkD,sBACf6oB,QAAQ5uC,IAAU6uC,SAAS7uC,KAC7B2mF,EAAMv7E,KACJ/M,EAAOa,KAAK4c,EAAchL,aAAc,CACtCy5E,EAASn3E,QAAQc,SACb7V,EAAO0D,IAAI6sC,QAAQ5uC,GAAQ6uC,SAAS7uC,IACpC3B,EAAOyD,IAAI8sC,QAAQ5uC,KACtBuwD,EAAAriC,WAAWyY,YAIlBggD,EAAMv7E,KACJ/M,EAAOyqC,GACLzqC,EAAO6nC,UAAU,EACf7nC,EAAO+nC,WAAW8jC,EAAOp5D,aAAc2gE,IAEzCpzE,EAAOa,KAAK4c,EAAchL,aAAc,CACtCzS,EAAO2nC,UAAU,EAAGyrC,GACpBpzE,EAAO2nC,UAAU,EAAGuqB,EAAAriC,WAAWppB,MAC9ByrD,EAAAriC,WAAWyY,2GAMxBtoC,EAAO2tC,YAAY03B,EAAeg4B,cAAenvD,EAAS,CAAEklC,GAC1DkV,EAAM97E,OACFxM,EAAO6pC,MAAM,KAAMy+C,GACnBtoF,EAAO6qC,QAKf9qC,EAAA6xE,oBAAA,SAAoCsa,mBAC9BrmE,EAAUqmE,EAASrmE,QACnB7lB,EAASksF,EAASlsF,OAClBmV,EAAY0Q,EAAQ9Q,QAAQI,UAC5Bi+D,EAAiBj+D,EAAU2+C,eAC3B26C,EAAiBt5F,EAAUo9C,SAC3Bm8C,EAAQxiB,EAASxa,mBAAmB,CAAEv8D,EAAWpH,EAAAkH,KAAKxR,KAAOsK,EAAAkH,KAAKG,MAClErD,EAAiB8T,EAAQ9T,eACzB0L,EAAgBhT,OAAOob,EAAQpI,eAC/BkxF,EAAS,IAAIrnG,MACbm1C,EAAWyV,EAAAxd,SAAS1yC,OAAOhC,GAE3B4uG,EAAQnyD,EAASQ,mBACnBj9C,EAAO6qC,MACP7qC,EAAOioC,KAAKwmE,GAAgB,EAC1Br7B,GAAkBlhB,EAAAriC,WAAWnpB,IACzB1G,EAAOmnC,OAAO+qB,EAAAz5B,SAAS+nD,OACrBxgF,EAAO2nC,UAAU,EAAGyrC,GACpBpzE,EAAO0D,IAAI,IAEb1D,EAAOmnC,OAAO+qB,EAAAz5B,SAAS8nD,OACrBvgF,EAAO2nC,UAAU,EAAGyrC,GACpBpzE,EAAOyD,IAAI,IAEjByuD,EAAAriC,WAAWppB,IACX,IAIAooG,EAAS,MACb,IAA2B,IAAAC,EAAA12F,EAAArG,GAAcg9F,EAAAD,EAAAx2F,QAAAy2F,EAAAx2F,KAAAw2F,EAAAD,EAAAx2F,OAAE,CAAlC,IAAAoG,EAAAjG,EAAAs2F,EAAAptG,MAAA,GAACwR,EAAAuL,EAAA,GAAIkK,EAAAlK,EAAA,GACZjU,OAAOme,EAAStJ,KAAK2zD,WACrBxoE,OAAO0I,GAAM07F,KAEb,IAAIG,OAAS,EACT9jG,EAAO,IAAI5D,MAGf,GAAIshB,EAASqmF,sBAAwBD,EAAYpmF,EAAS5O,aAAa,iBAAkB,CACvFvP,OAAOukG,EAAUl4F,MAAQm7C,EAAA9gD,YAAYkN,oBACrC,IAAI6wF,EAAYrpF,EAAQnT,SAAS4L,gBAAmC0wF,EAAW,MAC/E,GAAKE,GAAchjB,EAASrW,gBAAgBq5B,GAIrC,CACL,IAAIC,EAAWD,EAAU56F,UACzB7J,OACoC,GAAlC0kG,EAAS9kF,eAAe7d,QACxB2iG,EAAS9kF,eAAe,IAAMtc,EAAAkH,KAAKnR,KACnCqrG,EAAS1jE,YAAc19B,EAAAkH,KAAKG,MAC5B+5F,EAAS/kF,UAAYxB,EAAStJ,MAEhCpU,EAAK6B,KACH/M,EAAOa,KAAKquG,EAAUz8F,aAAc,CAClCzS,EAAO2nC,UAAU,EAAGyrC,GACpBpzE,EAAO2nC,UAAU,EAAGuqB,EAAAriC,WAAWppB,MAC9ByrD,EAAAriC,WAAWyY,YAfhBp9B,EAAK6B,KACH/M,EAAO8rC,mBAmBN,CACL,IAAI3sB,EAAUyJ,EAASzJ,QACvB,GAAIA,MACF,IAAmB,IAAAC,GAAA1F,OAAA,EAAAtB,EAAA+G,EAAQvB,WAAQyB,EAAAD,EAAA9G,QAAA+G,EAAA9G,KAAA8G,EAAAD,EAAA9G,OAAE,CAAhC,IAAIqG,EAAMU,EAAA1d,MACb,GAAIgd,EAAO7H,MAAQm7C,EAAA9gD,YAAY8N,OACjBN,EAAQpK,SAAWqU,GACLjK,EAAQW,KAClB2zD,UAAW,CACvB,IAAIm8B,EAAsBzwF,EAAQgN,aAClClhB,OAAO2kG,GAAe,GACtBlkG,EAAK6B,KAEH/M,EAAOyqC,GACLzqC,EAAO6nC,UAAU,EACf7nC,EAAOioC,KAAKwmE,GAAgB,EAC1BzuG,EAAO2nC,UAAU,EAAGyrC,GACpBA,EAAgBg8B,IAGpBpvG,EAAOa,KAAK4c,EAAchL,aAAc,CACtCzS,EAAO2nC,UAAU,EAAGyrC,GACpBpzE,EAAO2nC,UAAU,EAAGuqB,EAAAriC,WAAWppB,MAC9ByrD,EAAAriC,WAAWyY,4GASzB1f,EAAS2D,MAAMrhB,EAAK6B,KAAK/M,EAAO+qC,UACrC,IAAIlB,EAAQ4S,EAASE,SACnBsvC,EAAAnV,QAAQ92E,EAAQkL,EAAMgnD,EAAAriC,WAAWyY,OAEnCmU,EAASU,mBAAmByxD,EAAO/kE,EAAO,CAAE12B,IAC5Cw7F,EAAO5hG,KAAK88B,yGAEd,IAA2B,IAAAwlE,EAAAj3F,EAAArG,GAAcu9F,EAAAD,EAAA/2F,QAAAg3F,EAAA/2F,KAAA+2F,EAAAD,EAAA/2F,OAAE,CAAlC,IAAAE,EAAAC,EAAA62F,EAAA3tG,MAAA,GACH4qB,GADIpZ,EAAAqF,EAAA,IAAIoQ,EAAApQ,EAAA,IACQ+T,MAChBA,GACFkwB,EAASI,UAAU8xD,EAAOx7F,GAAKw7F,EAAOpiF,EAAKpZ,uGAG/Cw7F,EAAO5hG,KACL0vC,EAASE,SACP38C,EAAO8rC,gBAGX2Q,EAASU,mBAAmByxD,EAAOD,EAAOA,EAAOniG,OAAS,GAAI,IAC9D0/E,EAASrW,gBAAgBp4D,GACzBzd,EAAO2tC,YAAY03B,EAAei4B,cAAeoR,EAAO,CAAEt7B,GAAkB32B,EAASa,iBAAiBsxD,EAAO,KAa/G7uG,EAAA8xE,YAAA,SAA4Bqa,WACtBrmE,EAAUqmE,EAASrmE,QACnB7lB,EAASksF,EAASlsF,OAClB+R,EAAiB8T,EAAQ9T,eACzBiqE,EAAQjqE,EAAek6B,KACvBA,EAAO,EAAI,EAAI+vC,EACfj9B,EAAO,IAAI72C,WAAW+jC,GAC1B/hC,EAAAgJ,SAAS8oE,EAAOj9B,EAAM,GACtB,IAAI2zC,EAAM,EACNhkE,EAAc7I,EAAQtL,wBACtBg1F,EAAe7gF,EAAYpsB,UAC3Boa,EAAiBmJ,EAAQnJ,eACzBE,EAAeiJ,EAAQjJ,aACvBC,EAAegJ,EAAQhJ,aACvBgyF,EAAS,MACb,IAA2B,IAAAW,EAAAp3F,EAAArG,GAAc09F,EAAAD,EAAAl3F,QAAAm3F,EAAAl3F,KAAAk3F,EAAAD,EAAAl3F,OAAE,CAAlC,IAAAyO,EAAAtO,EAAAg3F,EAAA9tG,MAAA,GAACwR,EAAA4T,EAAA,GAAI6B,EAAA7B,EAAA,GACZtc,OAAO0I,GAAM07F,KACb,IAAIx7F,EAAuB,EAE3B,GADIuV,EAAS8mF,YAAWr8F,GAAK,IACzBuV,IAAa8F,GAAe9F,EAASuD,QAAQojF,GAAe,CAC9D,IAAInjD,EAAYxjC,EAAS6F,oBACzBpb,GAAK,EACDuV,EAASuD,QAAQzP,KAAiBrJ,GAAK,GAC3CA,GAAS,GAA8Bo6F,EAAmBrhD,QACrD,GAAIxjC,EAASuD,QAAQvP,GAAe,CACzC,IAAI0P,EAAgB7hB,OAAOme,EAAS2F,mBAAmB3R,IACvDnS,OAA+B,GAAxB6hB,EAAc9f,QACrB6G,GAAK,EACLA,GAAS,GAA8Bo6F,EAAmBnhF,EAAc,SAC/D1D,EAASuD,QAAQtP,KACtByP,EAAgB7hB,OAAOme,EAAS2F,mBAAmB1R,IACvDpS,OAA+B,GAAxB6hB,EAAc9f,QACrB6G,GAAK,EACLA,GAAS,MAA4Bo6F,EAAmBnhF,EAAc,IACtEjZ,GAAS,GAA8Bo6F,EAAmBnhF,EAAc,KAE1EpiB,EAAAgJ,SAASG,EAAO0rC,EAAM2zC,GAAMA,GAAO,EACnC9pE,EAASiE,UAAYxZ,EACrB,IAAIkZ,EAAO3D,EAAS2D,KACpBriB,EAAAgJ,SAASqZ,EAAOA,EAAKpZ,GAAK,EAAG4rC,EAAM2zC,GAAMA,GAAO,oGAElDjoF,OAAOioF,GAAOzmD,GACd,IAAI92B,EAAY0Q,EAAQ9Q,QAAQI,UAC5BuvB,EAAUwnD,EAAS/U,iBAAiBp4B,GACxC,GAAsB,GAAlB5pC,EAAU82B,KAAW,CACvB,IAAIl5B,EAAS2xB,EAAQ3xB,OACrB/S,EAAOstC,UAAU+3B,EAAe6L,UAAWhf,EAAAriC,WAAWnpB,KAAK,EAAO1G,EAAO0D,IAAI6sC,QAAQx9B,GAASy9B,SAASz9B,UAEvG/S,EAAOstC,UAAU+3B,EAAe6L,UAAWhf,EAAAriC,WAAWppB,KAAK,EAAOzG,EAAOyD,IAAI8sC,QAAQ7L,EAAQ3xB,0FCpmIjG,IAAAm/C,EAAA1xD,EAAA,GAwDAmvG,EAAA,WAWE,SAAAA,IAHAtvG,KAAAiM,KAAiB,GACjBjM,KAAAuvG,WAAkB,EAmyBpB,OA1yBSD,EAAAE,UAAP,SAAiB7vG,GACf,IAAI8vG,EAAa,IAAIH,EAErB,OADAG,EAAWD,UAAU7vG,GACd8vG,EAAWzvC,UASpBsvC,EAAArtG,UAAAutG,UAAA,SAAU7vG,GACR,MAAM,IAAIyc,MAAM,oBAGlBkzF,EAAArtG,UAAAytG,kBAAA,SAAkB7+D,GAChB,IAAIjwC,EAAOixD,EAAAjW,gBAAgB/K,IAAS,IAAM7wC,KAAKuvG,WAAW7jG,SAAS,IAC/Dsc,EAAO6pC,EAAAlW,gBAAgB9K,GAC3B7wC,KAAK0M,KAAK,aACV1M,KAAK0M,KAAK9L,GACVZ,KAAK0M,KAAK,KACT,IAAK,IAAIrM,EAAW,EAAG+V,EAAWy7C,EAAA/V,sBAAsBjL,GAAOxwC,EAAI+V,IAAK/V,EACnEA,EAAI,GAAGL,KAAK0M,KAAK,MACrB1M,KAAK0M,KAAK,KACV1M,KAAK0M,KAAKrM,EAAEqL,SAAS,KACrB1L,KAAK0M,KAAK,MACV1M,KAAK0M,KAAKijG,EAAiB99C,EAAA7V,qBAAqBnL,EAAMxwC,KAExDL,KAAK0M,KAAK,OACV1M,KAAK0M,KAAKijG,EAAiB99C,EAAA3V,sBAAsBrL,KACjD7wC,KAAK0M,KAAK,KACNmlD,EAAA9a,gBAAgB/uB,IAAS6pC,EAAApiC,aAAa8uB,OACxCv+C,KAAK0M,KAAK,OAEZ1M,KAAK4vG,oBAAoB5nF,GACrB6pC,EAAA9a,gBAAgB/uB,IAAS6pC,EAAApiC,aAAa8uB,OACxCv+C,KAAK0M,KAAK,WAEV1M,KAAKuvG,YAGTD,EAAArtG,UAAA2tG,oBAAA,SAAoBhpE,GAClB,IAGIipE,EACAhrG,EACAxE,EAAU+V,EALVtD,EAAK++C,EAAA9a,gBAAgBnQ,GACrB3nB,EAAO4yC,EAAA7a,kBAAkBpQ,GAM7B,OAAQ9zB,GACN,KAAK++C,EAAApiC,aAAa8uB,MAOhB,IANqC,OAAhC15C,EAASgtD,EAAA9Y,aAAanS,MACzB5mC,KAAK0M,KAAK7H,GACV7E,KAAK0M,KAAK,OAEZ1M,KAAK0M,KAAK,OACV0J,EAAIy7C,EAAA5Y,mBAAmBrS,GAClBvmC,EAAI,EAAGA,EAAI+V,IAAK/V,EACnBL,KAAK4vG,oBAAoB/9C,EAAA1Y,cAAcvS,EAAMvmC,IAG/C,YADAL,KAAK0M,KAAK,OAGZ,KAAKmlD,EAAApiC,aAAakvB,GAiBhB,YAhBI1/B,GAAQ4yC,EAAAriC,WAAWyY,MACrBjoC,KAAK0M,KAAK,QACV1M,KAAK4vG,oBAAoB/9C,EAAAxY,eAAezS,IACxC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAAtY,UAAU3S,KAC/BipE,EAASh+C,EAAApY,WAAW7S,MACtB5mC,KAAK0M,KAAK,UACV1M,KAAK4vG,oBAAoBC,MAG3B7vG,KAAK4vG,oBAAoB/9C,EAAAxY,eAAezS,IACxC5mC,KAAK0M,KAAK,OACV1M,KAAK4vG,oBAAoB/9C,EAAAtY,UAAU3S,IACnC5mC,KAAK0M,KAAK,OACV1M,KAAK4vG,oBAAoB/9C,EAAApY,WAAW7S,MAIxC,KAAKirB,EAAApiC,aAAamvB,KACoB,OAA/B/5C,EAASgtD,EAAAlY,YAAY/S,MACxB5mC,KAAK0M,KAAK7H,GACV7E,KAAK0M,KAAK,OAEZ1M,KAAK0M,KAAK,OACV1M,KAAK4vG,oBAAoB/9C,EAAAhY,YAAYjT,IACrC5mC,KAAK0M,KAAK,gBAEZ,KAAKmlD,EAAApiC,aAAa6uB,MAahB,OAZIuxD,EAASh+C,EAAA5X,kBAAkBrT,MAC7B5mC,KAAK0M,KAAK,QACV1M,KAAK4vG,oBAAoBC,GACzB7vG,KAAK0M,KAAK,YAEyB,OAAhC7H,EAASgtD,EAAA9X,aAAanT,KACzB5mC,KAAK0M,KAAK,UACV1M,KAAK0M,KAAK7H,GACV7E,KAAK0M,KAAK,QAEV1M,KAAK0M,KAAK,aAId,KAAKmlD,EAAApiC,aAAaovB,OAClB,KAAKgT,EAAApiC,aAAasvB,KAClB,KAAK8S,EAAApiC,aAAauvB,aAChB,MAAM,IAAI5iC,MAAM,mBAElB,KAAKy1C,EAAApiC,aAAa0lB,SAGhB,OAFAn1C,KAAK0M,KAAK,UACV1M,KAAK0M,KAAKmlD,EAAAva,iBAAiB1Q,GAAMl7B,SAAS,KAG5C,KAAKmmD,EAAApiC,aAAa0vB,SAKhB,OAJAn/C,KAAK0M,KAAK,KACV1M,KAAK0M,KAAKmlD,EAAAta,iBAAiB3Q,GAAMl7B,SAAS,KAC1C1L,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAApa,iBAAiB7Q,IAG5C,KAAKirB,EAAApiC,aAAa4lB,UAClB,KAAKwc,EAAApiC,aAAa2vB,UAChB,MAAM,IAAIhjC,MAAM,mBAElB,KAAKy1C,EAAApiC,aAAa+lB,KAQhB,OAPAx1C,KAAK0M,KAAK,SACV1M,KAAK0M,KAAKijG,EAAiB1wF,IAC3Bjf,KAAK0M,KAAK,MACV1M,KAAK0M,KAAKmlD,EAAAzZ,cAAcxR,GAAMl7B,SAAS,KACvC1L,KAAK0M,KAAK,OACV1M,KAAK4vG,oBAAoB/9C,EAAAxZ,WAAWzR,SACpC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAApiC,aAAa6vB,MAUhB,OATAt/C,KAAK0M,KAAK,UACV1M,KAAK0M,KAAKijG,EAAiB1wF,IAC3Bjf,KAAK0M,KAAK,MACV1M,KAAK0M,KAAKmlD,EAAApZ,eAAe7R,GAAMl7B,SAAS,KACxC1L,KAAK0M,KAAK,OACV1M,KAAK4vG,oBAAoB/9C,EAAAlZ,YAAY/R,IACrC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAAhZ,cAAcjS,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAApiC,aAAaolB,MAChB,OAAQ51B,GACN,KAAK4yC,EAAAriC,WAAWppB,IAEd,YADApG,KAAK0M,KAAKmlD,EAAA5a,iBAAiBrQ,GAAMl7B,SAAS,KAG5C,KAAKmmD,EAAAriC,WAAWnpB,IASd,YARArG,KAAK0M,KACHojG,cACEv6F,QACEs8C,EAAA3a,oBAAoBtQ,GACpBirB,EAAA1a,qBAAqBvQ,MAM7B,KAAKirB,EAAAriC,WAAW3oB,IAEd,YADA7G,KAAK0M,KAAKmlD,EAAAza,iBAAiBxQ,GAAMl7B,SAAS,KAG5C,KAAKmmD,EAAAriC,WAAW1oB,IAEd,YADA9G,KAAK0M,KAAKmlD,EAAAxa,iBAAiBzQ,GAAMl7B,SAAS,KAI9C,MAEF,KAAKmmD,EAAApiC,aAAasmB,MAChB,OAAQ8b,EAAA5Z,WAAWrR,IACjB,KAAKirB,EAAA/+B,QAAQ+6C,OAIX,OAHA7tE,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQg7C,OAIX,OAHA9tE,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQi7C,UAIX,OAHA/tE,KAAK0M,KAAK,gBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQk4D,OACb,KAAKn5B,EAAA/+B,QAAQm4D,OAGX,OAFAjrF,KAAK0M,KAAK,UACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQw7D,OAIX,OAHAtuF,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQi8D,QAIX,OAHA/uF,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQk8D,SAIX,OAHAhvF,KAAK0M,KAAK,eACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQo9D,SAIX,OAHAlwF,KAAK0M,KAAK,eACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQy8D,WAIX,OAHAvvF,KAAK0M,KAAK,iBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQi9D,QAIX,OAHA/vF,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQg4C,OACb,KAAKjZ,EAAA/+B,QAAQi4C,OAGX,OAFA/qE,KAAK0M,KAAK,UACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ06D,OAIX,OAHAxtF,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQ26D,OAIX,OAHAztF,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQ46D,UAIX,OAHA1tF,KAAK0M,KAAK,gBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQy7D,OAIX,OAHAvuF,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQm8D,QAIX,OAHAjvF,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQo8D,SAIX,OAHAlvF,KAAK0M,KAAK,eACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQq9D,SAIX,OAHAnwF,KAAK0M,KAAK,eACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQ08D,WAIX,OAHAxvF,KAAK0M,KAAK,iBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQk9D,QAIX,OAHAhwF,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQ6rD,UAGX,OAFA3+E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ8rD,UAGX,OAFA5+E,KAAK0M,KAAK,mBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ4rD,QAKb,KAAK7sB,EAAA/+B,QAAQ6qD,cAGX,OAFA39E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ4qD,cAGX,OAFA19E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ+qD,cAGX,OAFA79E,KAAK0M,KAAK,mBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ8qD,cAGX,OAFA59E,KAAK0M,KAAK,mBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQirD,cAGX,OAFA/9E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQgrD,cAGX,OAFA99E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQmrD,cAGX,OAFAj+E,KAAK0M,KAAK,mBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQkrD,cAGX,OAFAh+E,KAAK0M,KAAK,mBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ48D,eAIX,OAHA1vF,KAAK0M,KAAK,yBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQ68D,eAIX,OAHA3vF,KAAK0M,KAAK,yBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQsrD,gBAGX,OAFAp+E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ0rD,gBAGX,OAFAx+E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQurD,gBAGX,OAFAr+E,KAAK0M,KAAK,mBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ2rD,gBAGX,OAFAz+E,KAAK0M,KAAK,mBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQorD,gBAGX,OAFAl+E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQwrD,gBAGX,OAFAt+E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQqrD,gBAGX,OAFAn+E,KAAK0M,KAAK,mBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQyrD,gBAGX,OAFAv+E,KAAK0M,KAAK,mBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ0qD,WAGX,OAFAx9E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ2qD,UAGX,OAFAz9E,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,IAGzC,KAAKirB,EAAA/+B,QAAQ88D,eAIX,OAHA5vF,KAAK0M,KAAK,yBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAA/+B,QAAQ+8D,eAIX,OAHA7vF,KAAK0M,KAAK,yBACV1M,KAAK4vG,oBAAoB/9C,EAAA3Z,cAActR,SACvC5mC,KAAK0M,KAAK,KAId,MAEF,KAAKmlD,EAAApiC,aAAaymB,OAChB,OAAQ2b,EAAA/Z,YAAYlR,IAClB,KAAKirB,EAAAz5B,SAASk9C,OACd,KAAKzjB,EAAAz5B,SAAS2nD,OACd,KAAKluB,EAAAz5B,SAAS4nD,OACd,KAAKnuB,EAAAz5B,SAAS6nD,OAIZ,OAHAjgF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAAS8nD,OACd,KAAKruB,EAAAz5B,SAAS+nD,OACd,KAAKtuB,EAAAz5B,SAASgoD,OACd,KAAKvuB,EAAAz5B,SAASioD,OAIZ,OAHArgF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASi1C,OACd,KAAKxb,EAAAz5B,SAASkoD,OACd,KAAKzuB,EAAAz5B,SAASmoD,OACd,KAAK1uB,EAAAz5B,SAASooD,OAIZ,OAHAxgF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASuoD,OACd,KAAK9uB,EAAAz5B,SAASwoD,OACd,KAAK/uB,EAAAz5B,SAAS0oD,OACd,KAAKjvB,EAAAz5B,SAAS2oD,OAIZ,OAHA/gF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASs1C,OAMZ,OALA1tE,KAAK0M,KAAK,eACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAASu1C,OACd,KAAK9b,EAAAz5B,SAAS4oD,OAIZ,OAHAhhF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASw1C,OAMZ,OALA5tE,KAAK0M,KAAK,eACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAASk1C,OACd,KAAKzb,EAAAz5B,SAASmpD,OAIZ,OAHAvhF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASopD,MACd,KAAK3vB,EAAAz5B,SAASqpD,MAIZ,OAHAzhF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASspD,OACd,KAAK7vB,EAAAz5B,SAASupD,OAIZ,OAHA3hF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASm1C,OACd,KAAK1b,EAAAz5B,SAAS+oD,OAIZ,OAHAnhF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASq1C,OACd,KAAK5b,EAAAz5B,SAASkpD,OAIZ,OAHAthF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASo1C,OACd,KAAK3b,EAAAz5B,SAASipD,OAIZ,OAHArhF,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASw1D,QAMZ,OALA5tF,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAAS21D,QAMZ,OALA/tF,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAAS6yC,MACd,KAAKpZ,EAAAz5B,SAAS8yC,MACd,KAAKrZ,EAAAz5B,SAASqzC,MACd,KAAK5Z,EAAAz5B,SAASszC,MAIZ,OAHA1rE,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAAS+yC,MACd,KAAKtZ,EAAAz5B,SAASgzC,MACd,KAAKvZ,EAAAz5B,SAASuzC,MACd,KAAK9Z,EAAAz5B,SAASwzC,MAIZ,OAHA5rE,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASyzC,MACd,KAAKha,EAAAz5B,SAAS2zC,MACd,KAAKla,EAAAz5B,SAAS6zC,MACd,KAAKpa,EAAAz5B,SAAS8zC,MAIZ,OAHAlsE,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAAS0zC,MAKZ,OAJA9rE,KAAK0M,KAAK,SACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,iBACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAAS+zC,MACd,KAAKta,EAAAz5B,SAASi0C,MACd,KAAKxa,EAAAz5B,SAASm0C,MACd,KAAK1a,EAAAz5B,SAASo0C,MAIZ,OAHAxsE,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASg0C,MAKZ,OAJApsE,KAAK0M,KAAK,SACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,kBACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASq0C,MACd,KAAK5a,EAAAz5B,SAASu0C,MACd,KAAK9a,EAAAz5B,SAASy0C,MACd,KAAKhb,EAAAz5B,SAAS00C,MAIZ,OAHA9sE,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,YACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASs0C,MAKZ,OAJA1sE,KAAK0M,KAAK,SACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,iBACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAAS20C,MACd,KAAKlb,EAAAz5B,SAAS60C,MACd,KAAKpb,EAAAz5B,SAAS+0C,MACd,KAAKtb,EAAAz5B,SAASg1C,MAIZ,OAHAptE,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAAS40C,MAKZ,OAJAhtE,KAAK0M,KAAK,SACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,kBACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASyoD,OAKZ,OAJA7gF,KAAK0M,KAAK,SACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,iBACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAAS6oD,OAKZ,OAJAjhF,KAAK0M,KAAK,SACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,iBACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASy1D,QAMZ,OALA7tF,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAAS41D,QAMZ,OALAhuF,KAAK0M,KAAK,cACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAAS4zC,MAKZ,OAJAhsE,KAAK0M,KAAK,SACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,iBACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASk0C,MAKZ,OAJAtsE,KAAK0M,KAAK,SACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,kBACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASw0C,MAKZ,OAJA5sE,KAAK0M,KAAK,SACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,iBACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAAS80C,MAKZ,OAJAltE,KAAK0M,KAAK,SACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,kBACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,IAG1C,KAAKirB,EAAAz5B,SAASg3D,YAMZ,OALApvF,KAAK0M,KAAK,kBACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAASw2D,OAMZ,OALA5uF,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAASo2D,OAMZ,OALAxuF,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAASi3D,YAMZ,OALArvF,KAAK0M,KAAK,kBACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAASy2D,OAMZ,OALA7uF,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAAz5B,SAASq2D,OAMZ,OALAzuF,KAAK0M,KAAK,aACV1M,KAAK4vG,oBAAoB/9C,EAAA9Z,cAAcnR,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA7Z,eAAepR,SACxC5mC,KAAK0M,KAAK,KAId,OAEF,KAAKmlD,EAAApiC,aAAauyB,OAUhB,OATAhiD,KAAK0M,KAAK,WACV1M,KAAK0M,KAAKijG,EAAiB1wF,IAC3Bjf,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAA1X,cAAcvT,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAAxX,cAAczT,IACvC5mC,KAAK0M,KAAK,MACV1M,KAAK4vG,oBAAoB/9C,EAAAtX,mBAAmB3T,SAC5C5mC,KAAK0M,KAAK,KAGZ,KAAKmlD,EAAApiC,aAAawyB,KAGhB,OAFAjiD,KAAK4vG,oBAAoB/9C,EAAApX,aAAa7T,SACtC5mC,KAAK0M,KAAK,OAGZ,KAAKmlD,EAAApiC,aAAa4uB,OAQhB,aAPIwxD,EAASh+C,EAAAlX,eAAe/T,KAC1B5mC,KAAK0M,KAAK,WACV1M,KAAK4vG,oBAAoBC,GACzB7vG,KAAK0M,KAAK,QAEV1M,KAAK0M,KAAK,cAId,KAAKmlD,EAAApiC,aAAayyB,KAChB,OAAQ2P,EAAA1W,UAAUvU,IAChB,KAAKirB,EAAAhwB,OAAO4vD,WAEV,YADAzxF,KAAK0M,KAAK,iBAGZ,KAAKmlD,EAAAhwB,OAAO8vD,WAIV,OAHA3xF,KAAK0M,KAAK,gBACV1M,KAAK4vG,oBAAoB/9C,EAAAtW,eAAe3U,EAAM,SAC9C5mC,KAAK0M,KAAK,KAId,MAEF,KAAKmlD,EAAApiC,aAAa0yB,IAEhB,YADAniD,KAAK0M,KAAK,OAGZ,KAAKmlD,EAAApiC,aAAa2uB,YAEhB,YADAp+C,KAAK0M,KAAK,iBAGZ,KAAKmlD,EAAApiC,aAAaiwB,cAClB,KAAKmS,EAAApiC,aAAa8vB,UAClB,KAAKsS,EAAApiC,aAAaqwB,WAClB,KAAK+R,EAAApiC,aAAaywB,cAEpB,MAAM,IAAI9jC,MAAM,oBAGVkzF,EAAArtG,UAAAyK,KAAR,SAAaT,GAEXjM,KAAKiM,KAAKS,KAAKT,IAGjBqjG,EAAArtG,UAAA+9D,OAAA,WACE,IAAItsB,EAAM1zC,KAAKiM,KAAKU,KAAK,IAEzB,OADA3M,KAAKiM,KAAO,GACLynC,GAEX47D,EA5yBA,GA8yBA,SAASK,EAAiB1wF,GACxB,OAAQA,GACN,KAAK4yC,EAAAriC,WAAWyY,KAAM,MAAO,OAC7B,KAAK4pB,EAAAriC,WAAWppB,IAAK,MAAO,MAC5B,KAAKyrD,EAAAriC,WAAWnpB,IAAK,MAAO,MAC5B,KAAKwrD,EAAAriC,WAAW3oB,IAAK,MAAO,MAC5B,KAAKgrD,EAAAriC,WAAW1oB,IAAK,MAAO,MAC5B,KAAK+qD,EAAAriC,WAAWzoB,KAAM,MAAO,OAC7B,KAAK8qD,EAAAriC,WAAW4uB,YAAa,MAAM,IAAIhiC,MAAM,oBAC7C,KAAKy1C,EAAAriC,WAAWm8D,KAAM,MAAM,IAAIvvE,MAAM,aACtC,QAAS,MAAM,IAAIA,MAAM,oBAxzBhB1c,EAAA4vG,u5BCxDZ,IAAA9hG,EAAArN,EAAA,GAIDyxD,EAAAzxD,EAAA,GAyBA0J,EAAA1J,EAAA,GAKA4vG,EAAA,WAUE,SAAAA,EAAYvqF,EAAkBwqF,QAAA,IAAAA,OAAA,GAH9BhwG,KAAAiwG,KAA4B,IAAI7oG,IAI9BpH,KAAKwlB,QAAUA,EACfxlB,KAAKgwG,eA6GT,OAzGED,EAAA9tG,UAAAiuG,KAAA,uBACE,IAAiB,IAAAxpF,EAAA3O,EAAA/X,KAAKwlB,QAAQnU,YAAYkM,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAE,CAA/C,IAAI5B,EAAI+H,EAAA9c,MACP+U,EAAK1K,OAAO8R,SAASzd,KAAKmwG,UAAU95F,uGAK5C05F,EAAA9tG,UAAAkuG,UAAA,SAAU95F,eACJyI,EAAUzI,EAAK3W,QACnB,GAAIof,MACF,IAA2B,IAAA+yD,EAAA95D,EAAA+G,GAAOgzD,EAAAD,EAAA55D,QAAA65D,EAAA55D,KAAA45D,EAAAD,EAAA55D,OAAA,CAAzB,IAAAmG,EAAAhG,EAAA05D,EAAAxwE,MAAA,GAACV,EAAAwd,EAAA,GAAME,EAAAF,EAAA,GAAoBpe,KAAKowG,aAAaxvG,EAAM0d,qGAE9D,IAAIjG,EAAchC,EAAKgC,YACvB,GAAIA,MACF,IAAuB,IAAAo7D,EAAA17D,EAAAM,GAAWq7D,EAAAD,EAAAx7D,QAAAy7D,EAAAx7D,KAAAw7D,EAAAD,EAAAx7D,OAAA,CAA7B,IAAIK,EAAUo7D,EAAApyE,MAAiBtB,KAAKmwG,UAAU73F,uGAKvDy3F,EAAA9tG,UAAAmuG,aAAA,SAAaxvG,EAAcgY,GACzB,IAAIA,EAAQ0G,GAAG9R,EAAAnL,YAAYq0D,UAAa12D,KAAKgwG,eAA7C,CACA,IAAIC,EAAOjwG,KAAKiwG,KAChB,GAAIA,EAAKz7F,IAAIoE,GACX5Y,KAAKqwG,WAAWzvG,EAAMgY,EAAiBq3F,EAAK/uG,IAAI0X,SAIlD,OADAq3F,EAAK99F,IAAIyG,EAAShY,GACVgY,EAAQnC,MACd,KAAKm7C,EAAA9gD,YAAYmQ,OACXrI,EAAQ0G,GAAG9R,EAAAnL,YAAYiwE,WAAWtyE,KAAKswG,YAAY1vG,EAAcgY,GACrE,MAEF,KAAKg5C,EAAA9gD,YAAYkW,KACXpO,EAAQ0G,GAAG9R,EAAAnL,YAAYiwE,WAAWtyE,KAAKuwG,UAAU3vG,EAAYgY,GACjE,MAEF,KAAKg5C,EAAA9gD,YAAYkN,mBACfhe,KAAKwwG,uBAAuB5vG,EAAyBgY,GACrD,MAEF,KAAKg5C,EAAA9gD,YAAYuJ,gBACfra,KAAKywG,oBAAoB7vG,EAAsBgY,GAC/C,MAEF,KAAKg5C,EAAA9gD,YAAY8N,MACHhG,EAAS0G,GAAG9R,EAAAnL,YAAYiwE,WAAWtyE,KAAK0wG,WAAW9vG,EAAagY,GAC5E,MAEF,KAAKg5C,EAAA9gD,YAAYyN,mBACfve,KAAK2wG,uBAAuB/vG,EAAyBgY,GACrD,MAEF,KAAKg5C,EAAA9gD,YAAY4N,SACf,IAAIkyF,EAAiBh4F,EACjB/X,EAAS+vG,EAAKnlF,eACd5qB,GAAQb,KAAK6wG,cAAcjwG,EAAMC,GACrC,IAAIqxE,EAAS0+B,EAAKllF,eACdwmD,GAAQlyE,KAAK6wG,cAAcjwG,EAAMsxE,GACrC,MAEF,KAAKtgB,EAAA9gD,YAAYiW,WA+bvB,SAAS+pF,EAAkBl4F,mBACzB,IAAIkG,EAAUlG,EAAQkG,QACtB,GAAIA,MACF,IAAmB,IAAAT,EAAAtG,EAAA+G,EAAQvB,UAAQwB,EAAAV,EAAApG,QAAA8G,EAAA7G,KAAA6G,EAAAV,EAAApG,OAAE,CAAhC,IAAIqG,EAAMS,EAAAzd,MACb,OAAQgd,EAAO7H,MACb,KAAKm7C,EAAA9gD,YAAYkN,mBACf,IAAI8J,EAAgCxJ,EAAQwJ,UAC5C,GAAIA,MACF,IAAqB,IAAA9I,GAAA+xF,OAAA,EAAAh5F,EAAA+P,EAAUvK,WAAQpF,EAAA6G,EAAA/G,QAAAE,EAAAD,KAAAC,EAAA6G,EAAA/G,OAAE,CAApC,IAAIsQ,EAAQpQ,EAAA7W,MACf,GAAIinB,EAASjJ,GAAG9R,EAAAnL,YAAYiwE,UAAW,OAAO,oGAGlD,MAEF,KAAK1gB,EAAA9gD,YAAYuJ,gBACf,IAAIyN,EAA6BxJ,EAAQwJ,UACzC,GAAIA,MACF,IAAqB,IAAA3O,GAAA63F,OAAA,EAAAj5F,EAAA+P,EAAUvK,WAAQhE,EAAAJ,EAAAlB,QAAAsB,EAAArB,KAAAqB,EAAAJ,EAAAlB,OAAE,CAApC,IAAIsQ,EAAQhP,EAAAjY,MACf,GAAIinB,EAASjJ,GAAG9R,EAAAnL,YAAYiwE,UAAW,OAAO,oGAGlD,MAEF,QACE,GAAIh0D,EAAOgB,GAAG9R,EAAAnL,YAAYiwE,WAAaw+B,EAAkBxyF,GAAS,OAAO,qGAMjF,OAAO,GA5dGwyF,CAAkBl4F,IAAU5Y,KAAKixG,eAAerwG,EAAMgY,GAC1D,MAEF,KAAKg5C,EAAA9gD,YAAY8V,eAAgB,MACjC,QAASxc,QAAO,MAIZ2lG,EAAA9tG,UAAAuuG,uBAAR,SAA+B5vG,EAAcgY,WACvCkP,EAAYlP,EAAQkP,UACxB,GAAIA,MACF,IAAqB,IAAApB,EAAA3O,EAAA+P,EAAUvK,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAE,CAApC,IAAIsQ,EAAQnK,EAAA9c,MACXinB,EAASjJ,GAAG9R,EAAAnL,YAAYiwE,WAAWtyE,KAAK6wG,cAAcjwG,EAAgB2nB,uGAKxEwnF,EAAA9tG,UAAAwuG,oBAAR,SAA4B7vG,EAAcgY,WACpCkP,EAAYlP,EAAQkP,UACxB,GAAIA,MACF,IAAqB,IAAApB,EAAA3O,EAAA+P,EAAUvK,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAE,CAApC,IAAIsQ,EAAQnK,EAAA9c,MACXinB,EAASjJ,GAAG9R,EAAAnL,YAAYiwE,WAAWtyE,KAAKkxG,WAAWtwG,EAAa2nB,uGAKlEwnF,EAAA9tG,UAAA0uG,uBAAR,SAA+B/vG,EAAcgY,GAO3CxO,QAAO,IAWX2lG,EAzHA,GA4HAoB,EAAA,SAAAlgG,GAWE,SAAAkgG,EAAY3rF,EAAkBwqF,QAAA,IAAAA,OAAA,GAA9B,IAAA9+F,EACED,EAAAzQ,KAAAR,KAAMwlB,EAASwqF,IAAehwG,YALxBkR,EAAA1E,GAAe,GACf0E,EAAAkgG,YAAmB,IAuK7B,OA/KgC7+F,EAAA4+F,EAAAlgG,GAGvBkgG,EAAAE,MAAP,SAAa7rF,GACX,OAAO,IAAI2rF,EAAW3rF,GAAS6rF,SAWjCF,EAAAlvG,UAAAquG,YAAA,SAAY1vG,EAAcgY,GACxB,IAAIpM,EAAKxM,KAAKwM,GACVwvE,EAAUpjE,EAAQ0G,GAAG9R,EAAAnL,YAAYilB,SAMrC,GALAzd,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,aACZp1B,GAASxvE,EAAGE,KAAK,UACrBF,EAAGE,KAAK1M,KAAKuxG,aAAa34F,EAAQqG,OAClCzS,EAAGE,KAAK,KACRF,EAAGE,KAAK9L,GACJo7E,EACF,OAAQpjE,EAAQuO,mBACd,OACE3a,EAAGE,KAAK,OACRF,EAAGE,KAAKojG,cAAcl3F,EAAQyO,uBAC9B,MAEF,OACE7a,EAAGE,KAAK,OACRF,EAAGE,KAAKkM,EAAQ2O,mBAAmB7b,YACnC,MAEF,QAAStB,QAAO,GAGpBoC,EAAGE,KAAK,QAGVykG,EAAAlvG,UAAAsuG,UAAA,SAAU3vG,EAAcgY,eAClBpM,EAAKxM,KAAKwM,GACd3C,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,eAChB5kG,EAAGE,KAAK,cACRF,EAAGE,KAAK9L,GACR4L,EAAGE,KAAK,QACR,IAAIoS,EAAUlG,EAAQkG,QACtB,GAAIA,EAAS,KACX,IAA2B,IAAA0yF,EAAAz5F,EAAA+G,GAAO2yF,EAAAD,EAAAv5F,QAAAw5F,EAAAv5F,KAAAu5F,EAAAD,EAAAv5F,OAAE,CAA3B,IAAAmG,EAAAhG,EAAAq5F,EAAAnwG,MAAA,GAACowG,EAAAtzF,EAAA,GACR,IADcE,EAAAF,EAAA,IACH3H,MAAQm7C,EAAA9gD,YAAY0W,UAAW,CACxC,IAAIw0D,EAAsB19D,EAAQgB,GAAG9R,EAAAnL,YAAYilB,SACjDzd,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,aACZp1B,EAASxvE,EAAGE,KAAK,UAChBF,EAAGE,KAAK,aACbF,EAAGE,KAAK,kBACRF,EAAGE,KAAKglG,GACJ11B,IACFxvE,EAAGE,KAAK,OACRtC,OAA4C,GAAzBkU,EAAQ6I,mBAC3B3a,EAAGE,KAAKwjC,QAAoB5xB,EAAQ+I,sBAAsB3b,SAAS,MAErEc,EAAGE,KAAK,8GAGZ,IAAmB,IAAA2R,EAAAtG,EAAA+G,EAAQvB,UAAQwB,EAAAV,EAAApG,QAAA8G,EAAA7G,KAAA6G,EAAAV,EAAApG,OAAE,CAAhC,IAAIqG,KAAMS,EAAAzd,OACFmV,MAAQm7C,EAAA9gD,YAAY0W,WAAWxnB,KAAKowG,aAAa9xF,EAAO1d,KAAM0d,sGAG7EzU,EAAAynG,OAAO9kG,IAAMxM,KAAKoxG,aAClB5kG,EAAGE,KAAK,QAGVykG,EAAAlvG,UAAA4uG,cAAA,SAAcjwG,EAAcgY,WACtBpM,EAAKxM,KAAKwM,GACVyH,EAAY2E,EAAQ3E,UACxBpK,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,aAChB5kG,EAAGE,KAAK1M,KAAKuxG,aAAat9F,EAAUm3B,aACpC5+B,EAAGE,KAAK,KACRF,EAAGE,KAAK9L,GACR4L,EAAGE,KAAK,KAIR,IAHA,IAAI62C,EAAatvC,EAAU+V,eACvB2qC,EAAgBpR,EAAWp3C,OAEtB9L,EAAI,EAAGA,EAAIs0D,IAAiBt0D,EAC/BA,GAAGmM,EAAGE,KAAK,MAEfF,EAAGE,KAAK1M,KAAKuxG,aAAahuD,EAAWljD,KACrCmM,EAAGE,KAAK,KACRF,EAAGE,KAAKuH,EAAUkW,iBAAiB9pB,IAErCmM,EAAGE,KAAK,QACR,IAAIoS,EAAUlG,EAAQkG,QACtB,GAAIA,GAAWA,EAAQ8sB,KAAM,CAC3B/hC,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,aAChB5kG,EAAGE,KAAK,cACRF,EAAGE,KAAKkM,EAAQhY,MAChB4L,EAAGE,KAAK,YACR,IAAmB,IAAAga,EAAA3O,EAAA+G,EAAQvB,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAA,CAA9B,IAAIqG,EAAMF,EAAA9c,MAAsBtB,KAAKowG,aAAa9xF,EAAO1d,KAAM0d,qGACpEzU,EAAAynG,OAAO9kG,IAAMxM,KAAKoxG,aAClB5kG,EAAGE,KAAK,SAIZykG,EAAAlvG,UAAAivG,WAAA,SAAWtwG,EAAcgY,GACvB,IAAIpM,EAAKxM,KAAKwM,GACd3C,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,eAChB5kG,EAAGE,KAAK,cACRF,EAAGE,KAAK9L,GACR4L,EAAGE,KAAK,QAER7C,EAAAynG,OAAO9kG,IAAMxM,KAAKoxG,aAClB5kG,EAAGE,KAAK,QAGVykG,EAAAlvG,UAAA0vG,eAAA,SAAe/wG,EAAcgY,GAC3B5Y,KAAKkxG,WAAWtwG,EAAMgY,IAGxBu4F,EAAAlvG,UAAAyuG,WAAA,SAAW9vG,EAAcgY,KAIzBu4F,EAAAlvG,UAAAgvG,eAAA,SAAerwG,EAAcgY,WACvBpM,EAAKxM,KAAKwM,GACd3C,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,eAChB5kG,EAAGE,KAAK,cACRF,EAAGE,KAAK9L,GACR4L,EAAGE,KAAK,QACR,IAAIoS,EAAUlG,EAAQkG,QACtB,GAAIA,MACF,IAAmB,IAAA4H,EAAA3O,EAAA+G,EAAQvB,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAA,CAA9B,IAAIqG,EAAMF,EAAA9c,MAAsBtB,KAAKowG,aAAa9xF,EAAO1d,KAAM0d,qGAEtEzU,EAAAynG,OAAO9kG,IAAMxM,KAAKoxG,aAClB5kG,EAAGE,KAAK,QAGVykG,EAAAlvG,UAAAouG,WAAA,SAAWzvG,EAAcgY,EAAkBotE,KAI3CmrB,EAAAlvG,UAAAsvG,aAAA,SAAatyF,GACX,OAAQA,EAAKxI,MACX,OAAkB,MAAO,OACzB,OAAmB,MAAO,QAC1B,OAAmB,MAAO,OAC1B,OAAmB,MAAO,YAC1B,OAAqB,OAAOzW,KAAKwlB,QAAQ9Q,QAAQc,SAAW,YAAc,OAC1E,OAAkB,MAAO,QACzB,OAAmB,MAAO,iBAC1B,OAAmB,MAAO,gBAE1B,OAAmB,MAAO,qBAC1B,OAAqB,OAAOxV,KAAKwlB,QAAQ9Q,QAAQc,SAAW,qBAAuB,gBAEnF,QAAoB,MAAO,UAC3B,QAAmB,MAAO,qBAC1B,QAAmB,MAAO,sBAC1B,QAAoB,MAAO,OAC3B,QAEE,OADApL,QAAO,GACA,KAKb+mG,EAAAlvG,UAAAovG,MAAA,WACE,IAAI7kG,EAAKxM,KAAKwM,GAMd,OALAA,EAAGE,KAAK,4BACN1M,KAAKoxG,YACPpxG,KAAKkwG,SACHlwG,KAAKoxG,YACP5kG,EAAGE,KAAK,OACDF,EAAGG,KAAK,KAEnBwkG,EA/KA,CAAgCpB,GAAnBrwG,EAAAyxG,aAkLb,IAAAS,EAAA,SAAA3gG,GAYE,SAAA2gG,EAAYpsF,EAAkBwqF,QAAA,IAAAA,OAAA,GAA9B,IAAA9+F,EACED,EAAAzQ,KAAAR,KAAMwlB,EAASwqF,IAAehwG,YANxBkR,EAAA1E,GAAe,GACf0E,EAAAkgG,YAAmB,EACnBlgG,EAAA2gG,QAAuB,IAAI1qG,MA+MrC,OAxNgCoL,EAAAq/F,EAAA3gG,GAGvB2gG,EAAAP,MAAP,SAAa7rF,GACX,OAAO,IAAIosF,EAAWpsF,GAAS6rF,SAYjCO,EAAA3vG,UAAAquG,YAAA,SAAY1vG,EAAcgY,GACxB,IAAIpM,EAAKxM,KAAKwM,GACVwvE,EAAUpjE,EAAQ0G,GAAG9R,EAAAnL,YAAYilB,SACrCzd,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,aACZx4F,EAAQ0G,GAAG9R,EAAAnL,YAAY6f,QACrB85D,EAASxvE,EAAGE,KAAK,oBAChBF,EAAGE,KAAK,WAETsvE,EAASxvE,EAAGE,KAAK,iBAChBF,EAAGE,KAAK,eAEfF,EAAGE,KAAK9L,GACR4L,EAAGE,KAAK,MACRF,EAAGE,KAAK1M,KAAKuxG,aAAa34F,EAAQqG,OAClCzS,EAAGE,KAAK,OACR1M,KAAKixG,eAAerwG,EAAMgY,IAG5Bg5F,EAAA3vG,UAAAsuG,UAAA,SAAU3vG,EAAcgY,WAClBpM,EAAKxM,KAAKwM,GACd3C,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,eAChB5kG,EAAGE,KAAK,gBACRF,EAAGE,KAAK9L,GACR4L,EAAGE,KAAK,QACR,IAAIoS,EAAUlG,EAAQkG,QACtB,GAAIA,EAAS,CACX,IAAIgzF,EAAahzF,EAAQ8sB,SACzB,IAA2B,IAAAmmE,EAAAh6F,EAAA+G,GAAOkzF,EAAAD,EAAA95F,QAAA+5F,EAAA95F,KAAA85F,EAAAD,EAAA95F,OAAE,CAA3B,IAAAyO,EAAAtO,EAAA45F,EAAA1wG,MAAA,GAAC2wG,EAAAvrF,EAAA,GAAMpI,EAAAoI,EAAA,GACVpI,EAAO7H,MAAQm7C,EAAA9gD,YAAY0W,YAC7B3d,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,aAChB5kG,EAAGE,KAAKulG,GACJ3zF,EAAOgB,GAAG9R,EAAAnL,YAAYilB,WACxB9a,EAAGE,KAAK,OACRtC,OAA4C,GAAzBkU,EAAQ6I,mBAC3B3a,EAAGE,KAAKwjC,QAAoB5xB,EAAQ+I,sBAAsB3b,SAAS,MAErEc,EAAGE,KAAK,SACNolG,qGAGFA,GAAY9xG,KAAKixG,eAAerwG,EAAMgY,GAE5C/O,EAAAynG,OAAO9kG,IAAMxM,KAAKoxG,aAClB5kG,EAAGE,KAAK,QAGVklG,EAAA3vG,UAAA4uG,cAAA,SAAcjwG,EAAcgY,GAC1B,IAAIA,EAAQgJ,MAAMpU,EAAAnL,YAAYq0D,QAAUlpD,EAAAnL,YAAYyf,KAApD,CACA,IAAItV,EAAKxM,KAAKwM,GACVyH,EAAY2E,EAAQ3E,UAIxB,GAHApK,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,aACZx4F,EAAQ0G,GAAG9R,EAAAnL,YAAYs0D,YAAYnqD,EAAGE,KAAK,cAC3CkM,EAAQ0G,GAAG9R,EAAAnL,YAAY6f,SAAS1V,EAAGE,KAAK,WACxCkM,EAAQ0G,GAAG9R,EAAAnL,YAAYwf,KAMzB,OALArV,EAAGE,KAAK,QACRF,EAAGE,KAAK9L,GACR4L,EAAGE,KAAK,QACRF,EAAGE,KAAK1M,KAAKuxG,aAAat9F,EAAUm3B,kBACpC5+B,EAAGE,KAAK,OAGHkM,EAAQgJ,MAAMpU,EAAAnL,YAAY6f,OAAS1U,EAAAnL,YAAY4iB,WAAWzY,EAAGE,KAAK,oBACvEF,EAAGE,KAAK9L,GAEV4L,EAAGE,KAAK,KAIR,IAHA,IAAI62C,EAAatvC,EAAU+V,eACvB2qC,EAAgBpR,EAAWp3C,OAEtB9L,EAAI,EAAGA,EAAIs0D,IAAiBt0D,EAC/BA,GAAGmM,EAAGE,KAAK,MAEfF,EAAGE,KAAKuH,EAAUkW,iBAAiB9pB,IACnCmM,EAAGE,KAAK,MACRF,EAAGE,KAAK1M,KAAKuxG,aAAahuD,EAAWljD,KAEnCuY,EAAQgJ,MAAMpU,EAAAnL,YAAYugB,YAAcpV,EAAAnL,YAAYyf,KACtDtV,EAAGE,KAAK,MAERF,EAAGE,KAAK,OACRF,EAAGE,KAAK1M,KAAKuxG,aAAat9F,EAAUm3B,cAEtC5+B,EAAGE,KAAK,OACR1M,KAAKixG,eAAerwG,EAAMgY,KAG5Bg5F,EAAA3vG,UAAAivG,WAAA,SAAWtwG,EAAcgY,eACnBpM,EAAKxM,KAAKwM,GACV0lG,EAAct5F,EAAQnC,MAAQm7C,EAAA9gD,YAAYqb,UAC9CtiB,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,eACZc,EACF1lG,EAAGE,KAAK,sBAEJkM,EAAQ0G,GAAG9R,EAAAnL,YAAYmgB,WAAWhW,EAAGE,KAAK,aAC9CF,EAAGE,KAAK,kBAEVF,EAAGE,KAAK9L,GAMR4L,EAAGE,KAAK,QACR,IAAIkqE,EAAgBh+D,EAAQ3W,UAAU6c,QACtC,GAAI83D,MACF,IAAmB,IAAAx4D,EAAArG,EAAA6+D,EAAcr5D,UAAQc,EAAAD,EAAAnG,QAAAoG,EAAAnG,KAAAmG,EAAAD,EAAAnG,OAAA,CAApC,IAAIqG,EAAMD,EAAA/c,MAA4BtB,KAAKowG,aAAa9xF,EAAO1d,KAAM0d,qGAE5E,IAAIH,EAAkBvF,EAAQkG,QAC9B,GAAIX,MACF,IAAmB,IAAAY,EAAAhH,EAAAoG,EAAgBZ,UAAQyB,EAAAD,EAAA9G,QAAA+G,EAAA9G,KAAA8G,EAAAD,EAAA9G,OAAA,CAAlCqG,EAAMU,EAAA1d,MAA8BtB,KAAKowG,aAAa9xF,EAAO1d,KAAM0d,qGAE9EzU,EAAAynG,OAAO9kG,IAAMxM,KAAKoxG,aAClB5kG,EAAGE,KAAK,QAGVklG,EAAA3vG,UAAA0vG,eAAA,SAAe/wG,EAAcgY,GAC3B5Y,KAAKkxG,WAAWtwG,EAAMgY,IAGxBg5F,EAAA3vG,UAAAyuG,WAAA,SAAW9vG,EAAcgY,GACvB,IAAIA,EAAQ0G,GAAG9R,EAAAnL,YAAYq0D,SAA3B,CACA,IAAIlqD,EAAKxM,KAAKwM,GACd3C,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,aACZx4F,EAAQ0G,GAAG9R,EAAAnL,YAAYs0D,YAAYnqD,EAAGE,KAAK,cAC3CkM,EAAQ0G,GAAG9R,EAAAnL,YAAY6f,SAAS1V,EAAGE,KAAK,WACxCkM,EAAQ0G,GAAG9R,EAAAnL,YAAY+f,WAAW5V,EAAGE,KAAK,aAC9CF,EAAGE,KAAK9L,GACR4L,EAAGE,KAAK,MACRF,EAAGE,KAAK1M,KAAKuxG,aAAa34F,EAAQqG,OAClCzS,EAAGE,KAAK,SAGVklG,EAAA3vG,UAAAgvG,eAAA,SAAerwG,EAAcgY,WACvBkG,EAAUlG,EAAQkG,QACtB,GAAIA,GAAWA,EAAQ8sB,KAAM,CAC3B,IAAIp/B,EAAKxM,KAAKwM,GACd3C,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,eAChB5kG,EAAGE,KAAK,qBACRF,EAAGE,KAAK9L,GACR4L,EAAGE,KAAK,YACR,IAAmB,IAAAga,EAAA3O,EAAA+G,EAAQvB,UAAQa,EAAAsI,EAAAzO,QAAAmG,EAAAlG,KAAAkG,EAAAsI,EAAAzO,OAAA,CAA9B,IAAIqG,EAAMF,EAAA9c,MAAsBtB,KAAKowG,aAAa9xF,EAAO1d,KAAM0d,qGACpEzU,EAAAynG,OAAO9kG,IAAMxM,KAAKoxG,aAClB5kG,EAAGE,KAAK,SAIZklG,EAAA3vG,UAAAouG,WAAA,SAAWzvG,EAAcgY,EAAkBotE,GACzC,IAAIx5E,EAAKxM,KAAKwM,GACd3C,EAAAynG,OAAO9kG,EAAIxM,KAAKoxG,aAChB5kG,EAAGE,KAAK,iBACRF,EAAGE,KAAK9L,GACR4L,EAAGE,KAAK,cACRF,EAAGE,KAAKs5E,GACRx5E,EAAGE,KAAK,QAGVklG,EAAA3vG,UAAAsvG,aAAA,SAAatyF,GACX,OAAQA,EAAKxI,MACX,OAAkB,MAAO,KACzB,OAAmB,MAAO,MAC1B,OAAmB,MAAO,MAC1B,OAAmB,MAAO,MAC1B,OAAqB,OAAOzW,KAAKwlB,QAAQ9Q,QAAQc,SAAW,MAAQ,MACpE,OAAkB,MAAO,KACzB,OAAmB,MAAO,MAC1B,OAAmB,MAAO,MAE1B,OAAmB,MAAO,MAC1B,OAAqB,OAAOxV,KAAKwlB,QAAQ9Q,QAAQc,SAAW,MAAQ,MAEpE,QAAoB,MAAO,OAC3B,QAAmB,MAAO,MAC1B,QAAmB,MAAO,MAC1B,QAAoB,MAAO,OAC3B,QAAoB,MAAO,OAC3B,QAEE,OADApL,QAAO,GACA,QAKbwnG,EAAA3vG,UAAAovG,MAAA,WACE,IAAI7kG,EAAKxM,KAAKwM,GAgBd,OAfAA,EAAGE,KAAK,+BACRF,EAAGE,KAAK,yBACRF,EAAGE,KAAK,0BACRF,EAAGE,KAAK,0BACRF,EAAGE,KAAK,yBACRF,EAAGE,KAAK,0BACRF,EAAGE,KAAK,0BACRF,EAAGE,KAAK,0BACRF,EAAGE,KAAK,0BACRF,EAAGE,KAAK,0BACN1M,KAAKoxG,YACPpxG,KAAKkwG,SACHlwG,KAAKoxG,YACP5kG,EAAGE,KAAK,OACRF,EAAGE,KAAK,8BACD1M,KAAKwM,GAAGG,KAAK,KAExBilG,EAxNA,CAAgC7B,GAAnBrwG,EAAAkyG,4aChVb,IAAApkG,EAAArN,EAAA,GAMAyxD,EAAAzxD,EAAA,GAIAiiD,EAAAjiD,EAAA,GASAsN,EAAAtN,EAAA,GAKA0J,EAAA1J,EAAA,GAIAwN,EAAAxN,EAAA,GA2DAgyG,EAAA,SAAAlhG,GAcE,SAAAkhG,IAAA,IAAAjhG,EACED,EAAAzQ,KAAAR,OAAOA,YAVTkR,EAAAkhG,QAAoB,IAAInrG,MAExBiK,EAAAmhG,QAAuB,IAAIlrG,IAE3B+J,EAAAohG,QAAuB,IAAInrG,IAE3B+J,EAAAipD,UAAmC,KAye3BjpD,EAAAqhG,8BAAqC,EA8drCrhG,EAAAshG,oBAA4C,KAl8BlDthG,EAAKsU,QAAU,IAAIosC,EAAA5gD,QAAQE,EAAKnE,eA2sHpC,OA3tH4BwF,EAAA4/F,EAAAlhG,GAoB1BkhG,EAAAlwG,UAAAwwG,UAAA,SACExmG,EACAuY,EACA/G,GAEA,IAAI7R,EAAiB/B,EAAAogD,cAAczlC,GAC/BH,EAAe1W,EAAAy8C,mBAAmBx+C,GAGtC,IAAI5L,KAAKsyG,QAAQ99F,IAAI6P,GAArB,CACArkB,KAAKsyG,QAAQt9F,IAAIqP,GACjBrkB,KAAKqyG,QAAQr9F,IAAIqP,GAGjB,IAAI1Y,EAAS,IAAIgC,EAAAmE,OACflG,EACAK,EACAwR,EACI9P,EAAAoE,WAAWm+C,MACX1rC,EAAK0lC,WAAW18C,EAAA1K,iBAAmB0hB,EAAKkuF,QAAQllG,EAAAlL,eAAgBkL,EAAA1K,eAAeqJ,QAAU,EACvFwB,EAAAoE,WAAWC,QACXrE,EAAAoE,WAAW6jD,SAEfpwC,EAAUxlB,KAAKwlB,QACnBA,EAAQrU,QAAQzE,KAAKf,GAGrB,IAAIgnG,EAAK,IAAIvwD,EAAA0X,UAAUnuD,EAAQ6Z,EAAQzY,aACvC4lG,EAAGx4C,UAAYn6D,KAAKm6D,UACpBxuD,EAAOikD,UAAY+iD,EAEnB,IADA,IAAIr8F,EAAa3K,EAAO2K,YAChBq8F,EAAG71C,KAAK1a,EAAAC,MAAMka,YAAY,CAChC,IAAI/lD,EAAYxW,KAAK4yG,uBAAuBD,EAAI,MAC5Cn8F,GAAWF,EAAW5J,KAAK8J,GAEjCm8F,EAAG3yC,WAILmyC,EAAAlwG,UAAA2wG,uBAAA,SACED,EACAlyB,QAAA,IAAAA,MAAA,MAOA,IALA,IAAIztE,EAAQxF,EAAAnL,YAAY4Q,KACpB4/F,GAAiB,EAGjBtyF,EAAqC,KAClCoyF,EAAG71C,KAAK1a,EAAAC,MAAMwZ,KAAK,CACpBg3C,EAAW,IAAGA,EAAWF,EAAG54C,UAChC,IAAIt5C,EAAYzgB,KAAK8yG,eAAeH,GAC/BlyF,EAIAF,EACAA,EAAW7T,KAAK+T,GADJF,EAAa,CAACE,GAH7BzgB,KAAK+yG,cAAcJ,GAQvB,IAAIK,EAAmB,EACnBC,EAAiB,EACjBC,EAAoB,EACpBC,EAAkB,EAClBR,EAAG71C,KAAK1a,EAAAC,MAAMntC,UACZ29F,EAAW,IAAGA,EAAWF,EAAG54C,UAChC/mD,GAASxF,EAAAnL,YAAY6S,OACrB89F,EAAcL,EAAG54C,SACjBk5C,EAAYN,EAAG5iD,IACX4iD,EAAG71C,KAAK1a,EAAAC,MAAMuT,WAChBs9C,EAAeP,EAAG54C,SAClBo5C,EAAaR,EAAG5iD,MAIpB,IAAIqjD,EAAoB,EACpBC,EAAkB,EAClBC,EAAgC,MAAb7yB,GAAqBA,EAAUnhE,GAAG9R,EAAAnL,YAAY0iB,SACjE4tF,EAAG71C,KAAK1a,EAAAC,MAAM/8B,SACZguF,EACFtzG,KAAKqN,MACHI,EAAAhD,eAAe8oG,gEACfZ,EAAG5nG,UAGD8nG,EAAW,IAAGA,EAAWF,EAAG54C,UAChCq5C,EAAeP,EACfQ,EAAaV,EAAG5iD,IAChB/8C,GAASxF,EAAAnL,YAAYijB,QAAU9X,EAAAnL,YAAY0iB,SAEpCuuF,IACTtgG,GAASxF,EAAAnL,YAAY0iB,SAIvB,IAAIvO,EAA8B,KAG9Bg9F,EAAQb,EAAGn2C,OAEf,OADIq2C,EAAW,IAAGA,EAAWF,EAAG14C,cACxBu5C,GACN,KAAKpxD,EAAAC,MAAM5iC,MACTkzF,EAAG16F,OACHjF,GAASxF,EAAAnL,YAAYod,MAEnBjJ,EADEm8F,EAAG71C,KAAK1a,EAAAC,MAAMr7B,MACJhnB,KAAKyzG,UAAUd,EAAI3/F,EAAOuN,EAAYsyF,GAEtC7yG,KAAK0zG,cAAcf,EAAI3/F,EAAOuN,EAAYsyF,GAExDtyF,EAAa,KACb,MAEF,KAAK6hC,EAAAC,MAAMiU,IAAKtjD,GAASxF,EAAAnL,YAAYi0D,IACrC,KAAKlU,EAAAC,MAAM0U,IACT47C,EAAG16F,OACHzB,EAAYxW,KAAK0zG,cAAcf,EAAI3/F,EAAOuN,EAAYsyF,GACtDtyF,EAAa,KACb,MAEF,KAAK6hC,EAAAC,MAAMr7B,KACT2rF,EAAG16F,OACHzB,EAAYxW,KAAKyzG,UAAUd,EAAI3/F,EAAOuN,EAAYsyF,GAClDtyF,EAAa,KACb,MAEF,KAAK6hC,EAAAC,MAAM1jC,SACTg0F,EAAG16F,OACHzB,EAAYxW,KAAK2zG,cAAchB,EAAI3/F,EAAOuN,EAAYsyF,GACtDtyF,EAAa,KACb,MAEF,KAAK6hC,EAAAC,MAAM7/B,SACT,IAAIw6C,EAAQ21C,EAAG51C,OAEf,GADA41C,EAAG16F,QACE06F,EAAG71C,KAAK1a,EAAAC,MAAMxjC,OAAQ,CACzB8zF,EAAGv1C,MAAMJ,GACTxmD,EAAYxW,KAAK4zG,eAAejB,GAAI,GACpC,MAEAA,EAAGx1C,QAAQH,GAEbhqD,GAASxF,EAAAnL,YAAYmgB,SAGvB,KAAK4/B,EAAAC,MAAMxjC,MACX,KAAKujC,EAAAC,MAAMl2B,UACTwmF,EAAG16F,OACHzB,EAAYxW,KAAK6zG,sBAAsBlB,EAAI3/F,EAAOuN,EAAYsyF,GAC9DtyF,EAAa,KACb,MAEF,KAAK6hC,EAAAC,MAAMt7B,UACLi2C,EAAQ21C,EAAG51C,OACf41C,EAAG16F,OACC06F,EAAGn2C,MAAK,EAAOpa,EAAAgT,mBAAmBgH,SAAWha,EAAAC,MAAMM,YACrDgwD,EAAGx1C,QAAQH,GACXxmD,EAAYxW,KAAK8zG,eAAenB,EAAI3/F,EAAOuN,EAAYsyF,GACvDtyF,EAAa,OAEboyF,EAAGv1C,MAAMJ,GACTxmD,EAAYxW,KAAK4zG,eAAejB,GAAI,IAEtC,MAEF,KAAKvwD,EAAAC,MAAMvrC,OACT67F,EAAG16F,OAGDzB,GAFFxD,GAASxF,EAAAnL,YAAYyU,QACTtJ,EAAAnL,YAAY6S,OACVlV,KAAK+zG,kBAAkBpB,EAAIE,GAE3B7yG,KAAKg0G,YAAYrB,GAE/B,MAEF,KAAKvwD,EAAAC,MAAMwU,KACLmG,EAAQ21C,EAAG51C,OACf41C,EAAG16F,OACC06F,EAAGn2C,MAAK,EAAOpa,EAAAgT,mBAAmBgH,SAAWha,EAAAC,MAAMM,YACrDgwD,EAAGx1C,QAAQH,GACXxmD,EAAYxW,KAAKi0G,qBAAqBtB,EAAI3/F,EAAOuN,EAAYsyF,GAC7DtyF,EAAa,OAEboyF,EAAGv1C,MAAMJ,GACTxmD,EAAYxW,KAAK4zG,eAAejB,GAAI,IAEtC,MAEF,QAGM3/F,EAAQxF,EAAAnL,YAAY6S,OAClBi+F,GAAcR,EAAG91C,eAAeza,EAAAgT,mBAAmBgH,SACjDi3C,GACFrzG,KAAKqN,MACHI,EAAAhD,eAAeypG,2CACfvB,EAAG5nG,MAAMqoG,EAAcC,IAG3B78F,EAAYxW,KAAKm0G,wBAAwBxB,EAAIE,EAAUK,EAAcC,GACrED,EAAeC,EAAa,GAE5B38F,EAAYxW,KAAKo0G,YAAYzB,EAAIE,EAA2C,IAAhC7/F,EAAQxF,EAAAnL,YAAYijB,WAK9D2tF,GACFjzG,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMioG,EAAaC,GAAY,UAGlCI,GACFrzG,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMqoG,EAAcC,GAAa,WAGnC5yB,IACHjqE,EAAYxW,KAAK4zG,eAAejB,GAAI,KAQ5C,GAAIpyF,EACF,IAAK,IAAIlgB,EAAI,EAAG+V,EAAImK,EAAWpU,OAAQ9L,EAAI+V,IAAK/V,EAC9CL,KAAKqN,MACHI,EAAAhD,eAAe6pG,8BACf/zF,EAAWlgB,GAAG0K,OAMpB,GAAIooG,GAA4B,OAAd38F,EAChB,OAAQA,EAAUC,MAChB,KAAK9I,EAAA+I,SAASU,gBACd,KAAKzJ,EAAA+I,SAASY,oBACd,KAAK3J,EAAA+I,SAASQ,iBACd,KAAKvJ,EAAA+I,SAASc,qBACd,KAAK7J,EAAA+I,SAASgB,qBACZ,OAAO/J,EAAAuF,KAAKm3C,6BAAmD7zC,EAAWm8F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAElG,QACE/vD,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMmoG,EAAcC,GAAa,WAK5C,OAAO38F,GAIT27F,EAAAlwG,UAAAsyG,SAAA,WACE,IAAInC,EAAUpyG,KAAKoyG,QACnB,OAAOA,EAAQjmG,OAASimG,EAAQrlE,QAAU,MAI5ColE,EAAAlwG,UAAA+9D,OAAA,WACE,GAAIhgE,KAAKoyG,QAAQjmG,OAAQ,MAAM,IAAIiQ,MAAM,wBAIzC,OAHApc,KAAKoyG,QAAU,GACfpyG,KAAKqyG,QAAQmC,QACbx0G,KAAKsyG,QAAQkC,QACNx0G,KAAKwlB,SAId2sF,EAAAlwG,UAAAwyG,UAAA,SACE9B,EACA+B,EACAC,QADA,IAAAD,OAAA,QACA,IAAAC,OAAA,GAIA,IAGI11F,EAHAk4C,EAAQw7C,EAAG16F,OACX46F,EAAWF,EAAG54C,SAKlB,GAAI5C,GAAS/U,EAAAC,MAAMoY,UAAW,CAG5B,IAAIm6C,EAAsBjC,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAEpCxmD,EAAYjU,KAAK60G,qBAAqBlC,GAC1C,GAAI1+F,EAAW,CACb,GAAI2gG,EAAqB,CACvB,IAAKjC,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAKjB,OAJA16D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAET,IAAK4nG,EAAG71C,KAAK1a,EAAAC,MAAMoW,KAKjB,OAJAz4D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAEJ4nG,EAAG71C,KAAK1a,EAAAC,MAAME,OACjBviD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,QAGhBkJ,EAAUovC,YAAa,EAEzB,OAAOpvC,EACF,GAAI2gG,GAAuB50G,KAAKuyG,6BAKrC,OAJAvyG,KAAKqN,MACHI,EAAAhD,eAAeqqG,iBACfnC,EAAG5nG,SAEE,KAIT,IAAI2pG,EAoBF,OAJA10G,KAAKqN,MACHI,EAAAhD,eAAeqqG,iBACfnC,EAAG5nG,SAEE,KAnBP,IAAIgqG,EAAY/0G,KAAKy0G,UAAU9B,GAAI,EAAOgC,GAC1C,IAAKI,EAAW,OAAO,KACvB,IAAKpC,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAOjB,OANKi6C,GACH30G,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,MAAM4nG,EAAG5iD,KAAM,KAGf,MAET9wC,EAAO81F,GACFhqG,MAAMqB,MAAQymG,EACnB5zF,EAAKlU,MAAMsB,IAAMsmG,EAAG5iD,SAUjB,GAAIoH,GAAS/U,EAAAC,MAAMmP,KACxBvyC,EAAOtR,EAAAuF,KAAKU,gBACVjG,EAAAuF,KAAKW,qBAAqB,OAAQ8+F,EAAG5nG,SAAU,IAAI,EAAO4nG,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,WAI7E,GAAIoH,GAAS/U,EAAAC,MAAMiN,KACxBrwC,EAAOtR,EAAAuF,KAAKU,gBACVjG,EAAAuF,KAAKW,qBAAqB,OAAQ8+F,EAAG5nG,SAAU,IAAI,EAAO4nG,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,WAI7E,GAAIoH,GAAS/U,EAAAC,MAAMG,MAAQ2U,GAAS/U,EAAAC,MAAMI,MAC/CxjC,EAAOtR,EAAAuF,KAAKU,gBACVjG,EAAAuF,KAAKW,qBAAqB,OAAQ8+F,EAAG5nG,SAAU,IAAI,EAAO4nG,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,WAI7E,GAAIoH,GAAS/U,EAAAC,MAAMkY,cACxBo4C,EAAG7+D,aACH70B,EAAOtR,EAAAuF,KAAKU,gBACVjG,EAAAuF,KAAKW,qBAAqB,SAAU8+F,EAAG5nG,SAAU,IAAI,EAAO4nG,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,UAI/E,IAAIoH,GAAS/U,EAAAC,MAAMM,WA6DxB,OANKgyD,GACH30G,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGA,KAtDP,IANA,IAAIyoG,EAAQ7lG,EAAAuF,KAAKW,qBAAqB8+F,EAAGt1C,iBAAkBs1C,EAAG5nG,SAC1D4a,EAAU6tF,EACVjwD,EAAqC,KACrC0xD,GAAW,EAGRtC,EAAG71C,KAAK1a,EAAAC,MAAMwY,MAAM,CACzB,IAAI83C,EAAG71C,KAAK1a,EAAAC,MAAMM,YAShB,OAJA3iD,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,MAAM4nG,EAAG5iD,MAEP,KARP,IAAI93C,EAAOtK,EAAAuF,KAAKW,qBAAqB8+F,EAAGt1C,iBAAkBs1C,EAAG5nG,SAC7D4a,EAAQ1N,KAAOA,EACf0N,EAAU1N,EAWd,GAAI06F,EAAG71C,KAAK1a,EAAAC,MAAMkV,UAAW,CAC3B,EAAG,CACD,IAAI29C,EAAYl1G,KAAKy0G,UAAU9B,GAAI,EAAMgC,GACzC,IAAKO,EAAW,OAAO,KAClB3xD,EACAA,EAAW72C,KAAoBwoG,GADnB3xD,EAAa,CAAgB2xD,SAEvCvC,EAAG71C,KAAK1a,EAAAC,MAAMyM,QACvB,IAAK6jD,EAAG71C,KAAK1a,EAAAC,MAAMmV,aAOjB,OANKm9C,GACH30G,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,MAAM4nG,EAAG5iD,KAAM,KAGf,KAIX,KAAO4iD,EAAG71C,KAAK1a,EAAAC,MAAMoW,MAAM,CACzB,IAAIk6C,EAAG71C,KAAK1a,EAAAC,MAAME,MAShB,OANKoyD,GACH30G,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,MAAM4nG,EAAG5iD,KAAM,QAGf,KARPklD,GAAW,EAWfh2F,EAAOtR,EAAAuF,KAAKU,gBAAgB4/F,EAAOjwD,GAAc,GAAI0xD,EAAUtC,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAWvF,KAAO4iD,EAAG71C,KAAK1a,EAAAC,MAAMoZ,cAAc,CACjC,IAAI05C,EAAexC,EAAG54C,SACtB,IAAK44C,EAAG71C,KAAK1a,EAAAC,MAAMqZ,cAOjB,OANKi5C,GACH30G,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAGT,KAET,IAAIqqG,EAAezC,EAAG5nG,MAAMoqG,EAAcxC,EAAG5iD,KAGzCklD,GAAW,EACf,GAAItC,EAAG71C,KAAK1a,EAAAC,MAAMoW,KAAM,CACtB,IAAIk6C,EAAG71C,KAAK1a,EAAAC,MAAME,MAShB,OANKoyD,GACH30G,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,QAGT,KARPkqG,GAAW,EAiBf,GANAh2F,EAAOtR,EAAAuF,KAAKU,gBACVjG,EAAAuF,KAAKW,qBAAqB,QAASuhG,GACnC,CAAEn2F,GACFg2F,EACAtC,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAEpBklD,EAAU,MAGhB,OAAOh2F,GAOTkzF,EAAAlwG,UAAA4yG,qBAAA,SACElC,GAKA,IAuGIvnE,EAvGA4xB,EAAQ21C,EAAG51C,OACX81C,EAAWF,EAAG54C,SACdxW,EAAqC,KACrCx5B,EAAiC,KACjCsrF,GAAoB,EAExB,GAAI1C,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAChB26C,GAAc,EACd1C,EAAGx1C,QAAQH,GACXzZ,EAAa,OAER,CACL8xD,GAAc,EACd,EAAG,CACD,IAAI5+F,EAAO9I,EAAAogD,cAAc6H,QAMzB,GALI+8C,EAAG71C,KAAK1a,EAAAC,MAAMiV,eAChB+9C,GAAc,EACd1C,EAAGx1C,QAAQH,GACXvmD,EAAO9I,EAAAogD,cAAc+S,MAEnB6xC,EAAG71C,KAAK1a,EAAAC,MAAMiN,MAAO,CACvB,IAAIqjD,EAAG71C,KAAK1a,EAAAC,MAAMgZ,OAiBhB,OAFAs3C,EAAGv1C,MAAMJ,GACTh9D,KAAKuyG,8BAA+B,EAC7B,KAhBP8C,GAAc,EACd1C,EAAGx1C,QAAQH,GACX,IAAIz7D,EAAIvB,KAAKy0G,UAAU9B,GAAI,GAC3B,IAAKpxG,EAAG,OAAO,KACf,GAAIA,EAAEkV,MAAQ9I,EAAA+I,SAASk3C,UAMrB,OALA5tD,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf9f,EAAEwJ,OAEJ/K,KAAKuyG,8BAA+B,EAC7B,KAETxoF,EAA0BxoB,MAMvB,KAAIoxG,EAAG91C,iBA8CZ,OATIw4C,EACFr1G,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGL4nG,EAAGv1C,MAAMJ,GAEXh9D,KAAKuyG,6BAA+B8C,EAC7B,KA7CP,IAAIz0G,EAAO+M,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,MAAM4nG,EAAG54C,SAAU44C,EAAG5iD,MAazF,GAZI4iD,EAAG71C,KAAK1a,EAAAC,MAAMmZ,YAChB65C,GAAc,EACd1C,EAAGx1C,QAAQH,GACPvmD,GAAQ9I,EAAAogD,cAAc+S,KACxB9gE,KAAKqN,MACHI,EAAAhD,eAAe6qG,oCACf3C,EAAG5nG,SAGL0L,EAAO9I,EAAAogD,cAAcwnD,UAGrB5C,EAAG71C,KAAK1a,EAAAC,MAAMgZ,OAAQ,CACxBg6C,GAAc,EACd1C,EAAGx1C,QAAQH,GACX,IAAI/9C,EAAOjf,KAAKy0G,UAAU9B,GAC1B,IAAK1zF,EAEH,OADAjf,KAAKuyG,6BAA+B8C,EAC7B,KAET,IAAIG,EAAQ,IAAI7nG,EAAAo2C,cAChByxD,EAAMxxD,cAAgBvtC,EACtB++F,EAAM50G,KAAOA,EACb40G,EAAMv2F,KAAOA,EACRskC,EACAA,EAAW72C,KAAK8oG,GADJjyD,EAAa,CAAEiyD,QAG5BH,GACFr1G,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACf2xC,EAAG5nG,gBAgBJ4nG,EAAG71C,KAAK1a,EAAAC,MAAMyM,QACvB,IAAK6jD,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAUjB,OATI26C,EACFr1G,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAGd4nG,EAAGv1C,MAAMJ,GAEXh9D,KAAKuyG,6BAA+B8C,EAC7B,KAKX,OAAI1C,EAAG71C,KAAK1a,EAAAC,MAAMkZ,qBAChB85C,GAAc,EACd1C,EAAGx1C,QAAQH,IACX5xB,EAAaprC,KAAKy0G,UAAU9B,KAiB9B3yG,KAAKuyG,8BAA+B,EAC7B5kG,EAAAuF,KAAKS,mBACV4vC,GAAc,GACdnY,EACArhB,GACA,EACA4oF,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,QArBpB/vD,KAAKuyG,6BAA+B8C,EAC7B,QAGLA,EACFr1G,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,MAGd4nG,EAAGv1C,MAAMJ,GAEXh9D,KAAKuyG,6BAA+B8C,EAC7B,OAcXlD,EAAAlwG,UAAA6wG,eAAA,SACEH,GAKA,IAAIE,EAAWF,EAAG54C,SAClB,GAAI44C,EAAG91C,iBAAkB,CAGvB,IAFA,IAAIj8D,EAAO+xG,EAAGt1C,iBACVrzB,EAAyBr8B,EAAAuF,KAAKE,2BAA2BxS,EAAM+xG,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAClF4iD,EAAG71C,KAAK1a,EAAAC,MAAMwY,MAAM,CACzB,IAAI83C,EAAG91C,iBAYL,OAJA78D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,KAXPnK,EAAO+xG,EAAGt1C,iBACVrzB,EAAar8B,EAAAuF,KAAKq0C,+BAChBvd,EACAr8B,EAAAuF,KAAKE,2BAA2BxS,EAAM+xG,EAAG5nG,SACzC4nG,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAU5B,IAAI7L,OAAI,EACR,IAAIyuD,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAMhB,OAAO9sD,EAAAuF,KAAK+wC,gBAAgBja,EAAY,KAAM2oE,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAJpE,GADA7L,EAAOlkD,KAAKy1G,eAAe9C,GAEzB,OAAOhlG,EAAAuF,KAAK+wC,gBAAgBja,EAAYka,EAAMyuD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,WAMxE/vD,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGP,OAAO,MAGTonG,EAAAlwG,UAAAyxG,cAAA,SACEf,EACA3/F,EACAuN,EACAsyF,GAKA,IAAI/zF,EAAU,IAAI7X,MAClB,EAAG,CACD,IAAIqX,EAASte,KAAK01G,yBAAyB/C,EAAI3/F,EAAOuN,GACtD,IAAKjC,EAAQ,OAAO,KACpBQ,EAAQpS,KAA0B4R,SAC3Bq0F,EAAG71C,KAAK1a,EAAAC,MAAMyM,QAEvB,IAAIpb,EAAM/lC,EAAAuF,KAAKi6C,wBAAwBruC,EAASyB,EAAYoyF,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAElF,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAAyzG,yBAAA,SACE/C,EACAgD,EACAC,GAKA,IAAKjD,EAAG91C,iBAKN,OAJA78D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,KAET,IAAIuI,EAAa3F,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SACrEq3C,EAAAgV,4BAA4B9jD,EAAWrH,OACzCjM,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACf1hG,EAAWvI,OAGf,IAAIiI,EAAQ2iG,EACRhD,EAAG71C,KAAK1a,EAAAC,MAAMsW,eAChB3lD,GAASxF,EAAAnL,YAAYwzG,qBAGvB,IAAI52F,EAAwB,KACxB0zF,EAAG71C,KAAK1a,EAAAC,MAAMgZ,SAChBp8C,EAAOjf,KAAKy0G,UAAU9B,IAGxB,IAAIvrF,EAAiC,KACrC,GAAIurF,EAAG71C,KAAK1a,EAAAC,MAAM0W,SAQhB,GAPI/lD,EAAQxF,EAAAnL,YAAY0iB,SACtB/kB,KAAKqN,MACHI,EAAAhD,eAAeqrG,iDACfnD,EAAG5nG,WAGPqc,EAAcpnB,KAAK+1G,gBAAgBpD,EAAI,IACrB,OAAO,UAErB3/F,EAAQxF,EAAAnL,YAAYod,MAChBzM,EAAQxF,EAAAnL,YAAY0iB,SACxB/kB,KAAKqN,MACHI,EAAAhD,eAAewxE,wCACf3oE,EAAWvI,OAGLkU,GACVjf,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACf2xC,EAAG5nG,MAAM4nG,EAAG5iD,MAIlB,IAAIhlD,EAAQq3C,EAAAzmC,MAAMhP,KAAK2G,EAAWvI,MAAO4nG,EAAG5nG,SAM5C,OALKiI,EAAQxF,EAAAnL,YAAYwzG,qBAAwBzuF,GAC/CpnB,KAAKqN,MACHI,EAAAhD,eAAeurG,iEACfjrG,GAEG4C,EAAAuF,KAAKC,0BACVG,EACA2L,EACAmI,EACAwuF,EACA5iG,EACAjI,IAIJonG,EAAAlwG,UAAAwxG,UAAA,SACEd,EACA3/F,EACAuN,EACAsyF,GAKA,GAAIF,EAAG16F,QAAUmqC,EAAAC,MAAMM,WAKrB,OAJA3iD,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,KAET,IAAIuI,EAAa3F,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SACzE,GAAI4nG,EAAG16F,QAAUmqC,EAAAC,MAAMsZ,UAKrB,OAJA37D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAGT,IADA,IAAI+T,EAAU,IAAI7X,OACV0rG,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAAa,CACjC,IAAIt9C,EAASte,KAAKi2G,eAAetD,EAAInlG,EAAAnL,YAAY4Q,MACjD,IAAKqL,EAAQ,OAAO,KAEpB,GADAQ,EAAQpS,KAA2B4R,IAC9Bq0F,EAAG71C,KAAK1a,EAAAC,MAAMyM,OAAQ,CACzB,GAAI6jD,EAAG71C,KAAK1a,EAAAC,MAAMuZ,YAChB,MAMA,OAJA57D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MAIb,IAAI2oC,EAAM/lC,EAAAuF,KAAKw2C,sBACbp2C,EACAwL,EACAyB,EACAvN,EACA2/F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAGxB,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAAg0G,eAAA,SACEtD,EACAgD,GAKA,IAAKhD,EAAG91C,iBAKN,OAJA78D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,KAET,IAAIuI,EAAa3F,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SACrEzJ,EAA2B,KAC/B,OAAIqxG,EAAG71C,KAAK1a,EAAAC,MAAM0W,WAChBz3D,EAAQtB,KAAK+1G,gBAAgBpD,EAAI,IACd,KAEdhlG,EAAAuF,KAAK02C,2BACVt2C,EACAhS,EACAq0G,EACAvzD,EAAAzmC,MAAMhP,KAAK2G,EAAWvI,MAAO4nG,EAAG5nG,WAIpConG,EAAAlwG,UAAAi0G,YAAA,SACEvD,GAKA,IAAI/rE,EAA0B,KAC9B,GACE+rE,EAAGn2C,MAAK,IAASpa,EAAAC,MAAMiZ,WACvBq3C,EAAG34C,WAAa5X,EAAAC,MAAMuZ,aACrB+2C,EAAGz4C,sBAEEtzB,EAAO5mC,KAAK+1G,gBAAgBpD,IAAM,OAAO,KAGjD,IAAIj/D,EAAM/lC,EAAAuF,KAAKk5C,sBAAsBxlB,EAAM+rE,EAAG5nG,SAE9C,OADA4nG,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAAk0G,oBAAA,SACExD,GAOA,IAFA,IAAI7rF,EAA6C,KAC7CsvF,GAAe,GACXzD,EAAG71C,KAAK1a,EAAAC,MAAMmV,cAAc,CAClC,IAAI6+C,EAAgBr2G,KAAKs2G,mBAAmB3D,GAC5C,IAAK0D,EAAe,OAAO,KAY3B,GAXkC,OAA9BA,EAAc1yD,YAChByyD,GAAe,EACNA,IACTp2G,KAAKqN,MACHI,EAAAhD,eAAe8rG,iEACfF,EAActrG,OAEhBsrG,EAAc1yD,YAAc,MAEzB78B,EACAA,EAAepa,KAAK2pG,GADJvvF,EAAiB,CAAEuvF,IAEnC1D,EAAG71C,KAAK1a,EAAAC,MAAMyM,OAAQ,CACzB,GAAI6jD,EAAG71C,KAAK1a,EAAAC,MAAMmV,aAChB,MAMA,OAJAx3D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MAUb,OANM+b,GAAkBA,EAAe3a,QACrCnM,KAAKqN,MACHI,EAAAhD,eAAe+rG,oCACf7D,EAAG5nG,SAGA+b,GAGTqrF,EAAAlwG,UAAAq0G,mBAAA,SACE3D,GAKA,GAAIA,EAAG16F,QAAUmqC,EAAAC,MAAMM,WAAY,CACjC,IAAIrvC,EAAa3F,EAAAuF,KAAKE,2BACpBu/F,EAAGt1C,iBACHs1C,EAAG5nG,SAEDuW,EAAoC,KACxC,GAAIqxF,EAAG71C,KAAK1a,EAAAC,MAAM0T,SAAU,CAE1B,KADIx0D,EAAIvB,KAAKy0G,UAAU9B,IACf,OAAO,KACf,GAAIpxG,EAAEkV,MAAQ9I,EAAA+I,SAASk3C,UAKrB,OAJA5tD,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf9f,EAAEwJ,OAEG,KAETuW,EAA6B/f,EAE/B,IAAIoiD,EAAoC,KACxC,GAAIgvD,EAAG71C,KAAK1a,EAAAC,MAAM0W,QAAS,CACzB,IAAIx3D,EACJ,KADIA,EAAIvB,KAAKy0G,UAAU9B,IACf,OAAO,KACf,GAAIpxG,EAAEkV,MAAQ9I,EAAA+I,SAASk3C,UAKrB,OAJA5tD,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf9f,EAAEwJ,OAEG,KAET44C,EAA6BpiD,EAE/B,OAAOoM,EAAAuF,KAAKwwC,oBACVpwC,EACAgO,EACAqiC,EACAvB,EAAAzmC,MAAMhP,KAAK2G,EAAWvI,MAAO4nG,EAAG5nG,UAQpC,OALE/K,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGA,MAKTonG,EAAAlwG,UAAAw0G,gBAAA,SACE9D,EACA+D,QAAA,IAAAA,OAAA,GAKA,IAAInzD,EAAa,IAAIt8C,MACjB0vG,EAAiC,KACjCP,GAAe,EACfQ,GAAe,EACf7sF,EAA4B,KAIhC,GADA/pB,KAAKwyG,oBAAsB,KACvBG,EAAG71C,KAAK1a,EAAAC,MAAMiN,MAAO,CACvB,IAAIqjD,EAAG71C,KAAK1a,EAAAC,MAAMgZ,OAgBhB,OAJAr7D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAdP,KADAgf,EAAW/pB,KAAKy0G,UAAU9B,IACX,OAAO,KAgBxB,GAfM5oF,EAAStT,MAAQ9I,EAAA+I,SAASk3C,UAC5B5tD,KAAKwyG,oBAAqCzoF,EAE1C/pB,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf0I,EAAShf,QAUV4nG,EAAG71C,KAAK1a,EAAAC,MAAMyM,OACjB,OAAI6jD,EAAG71C,KAAK1a,EAAAC,MAAMqY,YACTnX,GAEPvjD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MAKb,MAAQ4nG,EAAG71C,KAAK1a,EAAAC,MAAMqY,aAAa,CACjC,IAAI86C,EAAQx1G,KAAK62G,eAAelE,EAAI+D,GACpC,IAAKlB,EAAO,OAAO,KAQnB,OAPImB,IAAaC,IACf52G,KAAKqN,MACHI,EAAAhD,eAAeqsG,kDACfH,EAAS/1G,KAAKmK,OAEhB6rG,GAAe,GAETpB,EAAMxxD,eACZ,QACMoyD,GACFp2G,KAAKqN,MACHI,EAAAhD,eAAessG,yDACfvB,EAAM50G,KAAKmK,OAGf,MAEF,KAAK4C,EAAAogD,cAAcwnD,SACjBa,GAAe,EACf,MAEF,KAAKzoG,EAAAogD,cAAc+S,KACjB61C,EAAWnB,EAKf,GADAjyD,EAAW72C,KAAK8oG,IACX7C,EAAG71C,KAAK1a,EAAAC,MAAMyM,OAAQ,CACzB,GAAI6jD,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAChB,MAMA,OAJA16D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MAIb,OAAOw4C,GAGT4uD,EAAAlwG,UAAA40G,eAAA,SACElE,EACA+D,QAAA,IAAAA,OAAA,GAKA,IAAIM,GAAS,EACTC,GAAa,EACbC,EAA2B,KAC3BC,EAA2B3pG,EAAAnL,YAAY4Q,KAC3C,GAAIyjG,IACE/D,EAAG71C,KAAK1a,EAAAC,MAAMuU,SAChBsgD,EAAavE,EAAG5nG,QAChBosG,GAAe3pG,EAAAnL,YAAYu0D,QAClB+7C,EAAG71C,KAAK1a,EAAAC,MAAMsU,YACvBugD,EAAavE,EAAG5nG,QAChBosG,GAAe3pG,EAAAnL,YAAYs0D,WAClBg8C,EAAG71C,KAAK1a,EAAAC,MAAMqU,WACvBwgD,EAAavE,EAAG5nG,QAChBosG,GAAe3pG,EAAAnL,YAAYq0D,SAEzBi8C,EAAGn2C,QAAUpa,EAAAC,MAAMjgC,UAAU,CAC/B,IAAI46C,EAAQ21C,EAAG51C,OACf41C,EAAG16F,OACC06F,EAAGn2C,QAAUpa,EAAAC,MAAMgZ,OACrBs3C,EAAGx1C,QAAQH,GACNk6C,IAAYA,EAAavE,EAAG5nG,SACjCosG,GAAe3pG,EAAAnL,YAAY+f,UAE3BuwF,EAAGv1C,MAAMJ,GAef,GAXI21C,EAAG71C,KAAK1a,EAAAC,MAAMiV,eACZ6/C,EACFn3G,KAAKqN,MACHI,EAAAhD,eAAe2sG,+DACfzE,EAAG5nG,SAGLmsG,EAAavE,EAAG5nG,QAElBisG,GAAS,GAEPrE,EAAG91C,iBAAkB,CAClBm6C,IAAQE,EAAavE,EAAG5nG,SAC7B,IAAIuI,EAAa3F,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SACrEkU,EAAwB,KAS5B,IARIg4F,EAAatE,EAAG71C,KAAK1a,EAAAC,MAAMmZ,YACzBw7C,GACFh3G,KAAKqN,MACHI,EAAAhD,eAAe6qG,oCACfhiG,EAAWvI,OAIb4nG,EAAG71C,KAAK1a,EAAAC,MAAMgZ,QAEhB,KADAp8C,EAAOjf,KAAKy0G,UAAU9B,IACX,OAAO,UAElB1zF,EAAOtR,EAAAuF,KAAKM,kBAAkBm/F,EAAG5nG,MAAM4nG,EAAG5iD,MAE5C,IAAI3oC,EAAiC,KACrC,GAAIurF,EAAG71C,KAAK1a,EAAAC,MAAM0W,UACZi+C,GACFh3G,KAAKqN,MACHI,EAAAhD,eAAe4sG,4CACf/jG,EAAWvI,OAGXksG,EACFj3G,KAAKqN,MACHI,EAAAhD,eAAe6sG,oDACfhkG,EAAWvI,OAGbksG,GAAa,IAEf7vF,EAAcpnB,KAAK+1G,gBAAgBpD,EAAI,KACrB,OAAO,KAE3B,IAAI6C,EAAQ7nG,EAAAuF,KAAK4wC,gBACfxwC,EACA2L,EACAmI,EACA4vF,EACIrpG,EAAAogD,cAAc+S,KACdm2C,EACEtpG,EAAAogD,cAAcwnD,SACd5nG,EAAAogD,cAAc6H,QACpBxT,EAAAzmC,MAAMhP,KAAYuqG,EAAYvE,EAAG5nG,UAGnC,OADAyqG,EAAMxiG,OAASmkG,EACR3B,EAOT,OALEx1G,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGA,MAGTonG,EAAAlwG,UAAA0xG,cAAA,SACEhB,EACA3/F,EACAuN,EACAsyF,GAUA,IAAKF,EAAG91C,iBAKN,OAJA78D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,MAAM4nG,EAAG5iD,MAEP,KAGT,IAAInvD,EAAO+M,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SAC/DwsG,GAAuB,EAEvBzwF,EAA6C,KACjD,GAAI6rF,EAAG71C,KAAK1a,EAAAC,MAAMkV,UAAW,CAG3B,GAFAggD,EAAiB5E,EAAG54C,WACpBjzC,EAAiB9mB,KAAKm2G,oBAAoBxD,IACrB,OAAO,KAC5B3/F,GAASxF,EAAAnL,YAAY8S,QAGvB,IAAKw9F,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAKjB,OAJAz6D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,MAAM4nG,EAAG5iD,KAAM,KAEb,KAGLwnD,EAAiB,IACnBA,EAAiB5E,EAAG54C,UAGtB,IAAIxW,EAAavjD,KAAKy2G,gBAAgB9D,GACtC,IAAKpvD,EAAY,OAAO,KACxB,IAAIx5B,EAAW/pB,KAAKwyG,oBAEhBgF,EAAwC,IAA5BxkG,EAAQxF,EAAAnL,YAAYyf,KAChC01F,IACuB,GAArBj0D,EAAWp3C,QACbnM,KAAKqN,MACHI,EAAAhD,eAAegtG,+CACf72G,EAAKmK,OAGLw4C,EAAWp3C,QAAUo3C,EAAW,GAAGn8B,aACrCpnB,KAAKqN,MACHI,EAAAhD,eAAeitG,oDACf92G,EAAKmK,QAKPiI,EAAQxF,EAAAnL,YAAYwf,KAClB0hC,EAAWp3C,QACbnM,KAAKqN,MACHI,EAAAhD,eAAektG,sCACf/2G,EAAKmK,OAKX,IAAIqgC,EAA8B,KAClC,GAAIunE,EAAG71C,KAAK1a,EAAAC,MAAMgZ,UAChBjwB,EAAaprC,KAAKy0G,UAAU9B,GAAI,EAAM6E,IACrB,OAAO,KAGrBpsE,IACHA,EAAaz9B,EAAAuF,KAAKM,kBAChBm/F,EAAG5nG,MAAM4nG,EAAG5iD,MAETynD,GACHx3G,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACf51B,EAAWrgC,QAKjB,IAAIkJ,EAAYtG,EAAAuF,KAAKS,mBACnB4vC,EACAnY,EACArhB,GACA,EACA4oF,EAAG5nG,MAAMwsG,EAAgB5E,EAAG5iD,MAG1B/nC,EAAyB,KAC7B,GAAI2qF,EAAG71C,KAAK1a,EAAAC,MAAMsZ,YAShB,GARI3oD,EAAQxF,EAAAnL,YAAY0iB,SACtB/kB,KAAKqN,MACHI,EAAAhD,eAAe+rE,yDACfm8B,EAAG5nG,WAIPid,EAAOhoB,KAAK43G,oBAAoBjF,GAAI,IACzB,OAAO,UACP3/F,EAAQxF,EAAAnL,YAAY0iB,SAC/B/kB,KAAKqN,MACHI,EAAAhD,eAAeisE,gFACfi8B,EAAG5nG,MAAM4nG,EAAG5iD,MAIhB,IAAIrc,EAAM/lC,EAAAuF,KAAKQ,0BACb9S,EACAkmB,EACA7S,EACA+T,EACAzH,EACAvN,EAAK,EAEL2/F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAGxB,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAA41G,wBAAA,SAAwBlF,GACtB,IACI/xG,EADAiyG,EAAWF,EAAG54C,SAEd9xC,EAAS,EAOb,GAAI0qF,EAAGx7C,OAAS/U,EAAAC,MAAM1jC,UAMpB,GAJE/d,EADE+xG,EAAG91C,iBACElvD,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SAExD4C,EAAAuF,KAAK0xC,gCAAgC+tD,EAAG5nG,MAAM4nG,EAAG5iD,OAErD4iD,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAKjB,OAJAz6D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,MAAM4nG,EAAG5iD,KAAM,KAEb,UAQT9nC,EAAS,EACT7d,OAAOuoG,EAAGx7C,OAAS/U,EAAAC,MAAMoY,WACzB75D,EAAO+M,EAAAuF,KAAK0xC,gCAAgC+tD,EAAG5nG,MAAM4nG,EAAG54C,WAK1D,IAAIw9C,EAAiB5E,EAAG5iD,IACpBxM,EAAavjD,KAAKy2G,gBAAgB9D,GACtC,OAAKpvD,EAEEvjD,KAAK83G,8BAA8BnF,EAAI/xG,EAAM2iD,EAAYt7B,EAAW4qF,EAAU0E,GAF7D,MAKlBpF,EAAAlwG,UAAA61G,8BAAR,SACEnF,EACA/xG,EACA2iD,EACAt7B,EACA4qF,EACA0E,QADA,IAAA1E,OAAiB,QACjB,IAAA0E,OAAuB,GAEnB1E,EAAW,IAAGA,EAAWjyG,EAAKmK,MAAMqB,OACpCmrG,EAAiB,IAAGA,EAAiB1E,GAEzC,IAAIznE,EAA8B,KAClC,GAAa,GAATnjB,GAAuC0qF,EAAG71C,KAAK1a,EAAAC,MAAMgZ,QAEvD,KADAjwB,EAAaprC,KAAKy0G,UAAU9B,IACX,OAAO,UAExBvnE,EAAaz9B,EAAAuF,KAAKM,kBAAkBm/F,EAAG5nG,MAAM4nG,EAAG5iD,MAGlD,GAAI9nC,IACG0qF,EAAG71C,KAAK1a,EAAAC,MAAMkZ,oBAKjB,OAJAv7D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,MAAM4nG,EAAG5iD,KAAM,MAEb,KAIX,IAAI97C,EAAYtG,EAAAuF,KAAKS,mBACnB4vC,EACAnY,EACA,MACA,EACAunE,EAAG5nG,MAAMwsG,EAAgB5E,EAAG5iD,MAG1B/nC,EAAyB,KAC7B,GAAIC,EACF,GAAI0qF,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAChB3zC,EAAOhoB,KAAK43G,oBAAoBjF,GAAI,OAC/B,CACL,IAAIoF,EAAiB/3G,KAAK+1G,gBAAgBpD,EAAI,GAC1CoF,IAAgB/vF,EAAOra,EAAAuF,KAAKy3C,0BAA0BotD,QAEvD,CACL,IAAKpF,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAKjB,OAJA37D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,MAAM4nG,EAAG5iD,KAAM,KAEb,KAET/nC,EAAOhoB,KAAK43G,oBAAoBjF,GAAI,GAEtC,IAAK3qF,EAAM,OAAO,KAElB,IAAIzT,EAAc5G,EAAAuF,KAAKQ,0BACrB9S,EACA,KACAqT,EACA+T,EACA,KACAxa,EAAAnL,YAAY4Q,KACZgV,EACA0qF,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAExB,OAAOpiD,EAAAuF,KAAKszC,yBAAyBjyC,IAGvC49F,EAAAlwG,UAAA4xG,sBAAA,SACElB,EACA3/F,EACAuN,EACAsyF,GAUA,IAAIX,EAAcS,EAAGx7C,OAAS/U,EAAAC,MAAMl2B,UAEpC,IAAKwmF,EAAG91C,iBAKN,OAJA78D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,KAGT,IAAIuI,EAAa3F,EAAAuF,KAAKE,2BACpBu/F,EAAGt1C,iBACHs1C,EAAG5nG,SAGD+b,EAA6C,KACjD,GAAI6rF,EAAG71C,KAAK1a,EAAAC,MAAMkV,UAAW,CAE3B,KADAzwC,EAAiB9mB,KAAKm2G,oBAAoBxD,IACrB,OAAO,KAC5B3/F,GAASxF,EAAAnL,YAAY8S,QAGvB,IAAImM,EAAoC,KACxC,GAAIqxF,EAAG71C,KAAK1a,EAAAC,MAAM0T,SAAU,CAC1B,IAAIx0D,EAAIvB,KAAKy0G,UAAU9B,GACvB,IAAKpxG,EAAG,OAAO,KACf,GAAIA,EAAEkV,MAAQ9I,EAAA+I,SAASk3C,UAKrB,OAJA5tD,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACf9f,EAAEwJ,OAEG,KAETuW,EAA6B/f,EAG/B,IAAI2f,EAA0C,KAC9C,GAAIyxF,EAAG71C,KAAK1a,EAAAC,MAAM6T,YAAa,CACzBg8C,GACFlyG,KAAKqN,MACHI,EAAAhD,eAAeutG,oDACfrF,EAAG5nG,SAGP,EAAG,CACD,IAAIkU,EAAOjf,KAAKy0G,UAAU9B,GAC1B,IAAK1zF,EAAM,OAAO,KACbizF,IACEhxF,EACAA,EAAgBxU,KAAoBuS,GADnBiC,EAAkB,CAAgBjC,UAGnD0zF,EAAG71C,KAAK1a,EAAAC,MAAMyM,QAGzB,IAAK6jD,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAKjB,OAJA37D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAGT,IACIwJ,EADAuK,EAAU,IAAI7X,MAyBlB,GAvBIirG,GACF9nG,QAAQ8W,GACR3M,EAAc5G,EAAAuF,KAAKm4C,2BACjB/3C,EACAwT,EACAxF,EACAxC,EACAyB,EACAvN,EACA2/F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,OAGxBx7C,EAAc5G,EAAAuF,KAAKg2C,uBACjB51C,EACAwT,EACAxF,EACAJ,EACApC,EACAyB,EACAvN,EACA2/F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,OAGrB4iD,EAAG71C,KAAK1a,EAAAC,MAAMuZ,YACjB,EAAG,CACD,IAAIt9C,EAASte,KAAKi4G,iBAAiBtF,EAAIp+F,GACvC,GAAI+J,EAAQQ,EAAQpS,KAA2B4R,QAG7C,GADAte,KAAK+yG,cAAcJ,GACfA,EAAG71C,KAAK1a,EAAAC,MAAMka,WAKhB,OAJAv8D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,YAGH4nG,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAG1B,OADArnD,EAAYxJ,MAAMsB,IAAMsmG,EAAG5iD,IACpBx7C,GAGT49F,EAAAlwG,UAAAi2G,qBAAA,SAAqBvF,GAInB,IACI/xG,EADAiyG,EAAWF,EAAG54C,SASlB,GALEn5D,EADE+xG,EAAG91C,iBACElvD,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SAExD4C,EAAAuF,KAAK0xC,gCAAgC+tD,EAAG5nG,MAAM4nG,EAAG5iD,OAGrD4iD,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAKjB,OAJA37D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,MAAM4nG,EAAG5iD,KAAM,KAEb,KAGT,IAAIjxC,EAAU,IAAI7X,MACdsN,EAAc5G,EAAAuF,KAAKg2C,uBACrBtoD,EACA,GACA,KACA,KACAke,EACA,KACAtR,EAAAnL,YAAY4Q,KACZ0/F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAExB,IAAK4iD,EAAG71C,KAAK1a,EAAAC,MAAMuZ,YACjB,EAAG,CACD,IAAIt9C,EAASte,KAAKi4G,iBAAiBtF,EAAIp+F,GACvC,GAAI+J,EAAQQ,EAAQpS,KAA2B4R,QAG7C,GADAte,KAAK+yG,cAAcJ,GACfA,EAAG71C,KAAK1a,EAAAC,MAAMka,WAKhB,OAJAv8D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,YAGH4nG,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAG1B,OADArnD,EAAYxJ,MAAMsB,IAAMsmG,EAAG5iD,IACpBpiD,EAAAuF,KAAKwyC,sBAAsBnxC,IAGpC49F,EAAAlwG,UAAAg2G,iBAAA,SACEtF,EACAz+F,GAUA,IAAI2+F,EAAWF,EAAG5iD,IACdmiD,EAAch+F,EAAOuC,MAAQ9I,EAAA+I,SAASc,qBAEtC+I,EAAqC,KACzC,GAAIoyF,EAAG71C,KAAK1a,EAAAC,MAAMwZ,IAAK,CACrB,EAAG,CACD,IAAIp7C,EAAYzgB,KAAK8yG,eAAeH,GACpC,IAAKlyF,EAAW,MACXF,EACAA,EAAW7T,KAAoB+T,GADnBF,EAAa,CAAgBE,SAEvCkyF,EAAG71C,KAAK1a,EAAAC,MAAMwZ,KACnBt7C,GAAc2xF,GAChBlyG,KAAKqN,MACHI,EAAAhD,eAAe6pG,8BACflyD,EAAAzmC,MAAMhP,KAAK4T,EAAW,GAAGxV,MAAOwV,EAAWA,EAAWpU,OAAS,GAAGpB,QAMxE,IAAIiI,EAAQkB,EAAOlB,MAAQxF,EAAAnL,YAAY0iB,QAGnCmtF,IAAal/F,GAASxF,EAAAnL,YAAY81G,SAEtC,IAAIC,EAAc,EACdC,EAAY,EACZ1F,EAAG71C,KAAK1a,EAAAC,MAAMuU,SACZs7C,GACFlyG,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,QAAS,UAGhBiI,GAASxF,EAAAnL,YAAYu0D,OACrBwhD,EAAczF,EAAG54C,SACjBs+C,EAAY1F,EAAG5iD,KACN4iD,EAAG71C,KAAK1a,EAAAC,MAAMqU,UACnBw7C,GACFlyG,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,QAAS,WAGhBiI,GAASxF,EAAAnL,YAAYq0D,QACrB0hD,EAAczF,EAAG54C,SACjBs+C,EAAY1F,EAAG5iD,KACN4iD,EAAG71C,KAAK1a,EAAAC,MAAMsU,aACnBu7C,GACFlyG,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,QAAS,aAGhBiI,GAASxF,EAAAnL,YAAYs0D,UACrByhD,EAAczF,EAAG54C,SACjBs+C,EAAY1F,EAAG5iD,KAGjB,IAAIuoD,EAAc,EACdC,EAAY,EACZC,EAAgB,EAChBC,EAAc,EACd9F,EAAG71C,KAAK1a,EAAAC,MAAMngC,SACZgwF,GACFlyG,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,QAAS,UAGhBiI,GAASxF,EAAAnL,YAAY6f,OACrBo2F,EAAc3F,EAAG54C,SACjBw+C,EAAY5F,EAAG5iD,MAEf/8C,GAASxF,EAAAnL,YAAY4iB,SACjB0tF,EAAG71C,KAAK1a,EAAAC,MAAM7/B,YACZ0vF,GACFlyG,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,QAAS,YAGhBiI,GAASxF,EAAAnL,YAAYmgB,SACrBg2F,EAAgB7F,EAAG54C,SACnB0+C,EAAc9F,EAAG5iD,KAEf77C,EAAOlB,MAAQxF,EAAAnL,YAAY8S,UAASnC,GAASxF,EAAAnL,YAAYq2G,kBAG/D,IAAIC,EAAqB,EACrBC,EAAmB,EACvB,GAAIjG,EAAGn2C,QAAUpa,EAAAC,MAAMjgC,SAAU,CAC/B,IAAIy2F,EAAQlG,EAAG51C,OACf41C,EAAG16F,OACC06F,EAAGn2C,QAAUpa,EAAAC,MAAMgZ,OACrBs3C,EAAGx1C,QAAQ07C,GACX7lG,GAASxF,EAAAnL,YAAY+f,SACrBu2F,EAAgBhG,EAAG54C,SACnB6+C,EAAcjG,EAAG5iD,KAEjB4iD,EAAGv1C,MAAMy7C,GAKb,IA+DIj4G,EA/DAo8D,EAAQ21C,EAAG51C,OACX25C,GAAgB,EAChB1yF,GAAW,EAGXwzF,GAAW,EACX5mE,EAAgB,EAChBkoE,EAAc,EAyDlB,GAxDK5G,IACCS,EAAG71C,KAAK1a,EAAAC,MAAMxgC,KACZ8wF,EAAGn2C,MAAK,EAAMpa,EAAAgT,mBAAmBgH,SAAWha,EAAAC,MAAMM,YAAegwD,EAAGz4C,mBAYtEy4C,EAAGv1C,MAAMJ,IAXThqD,GAASxF,EAAAnL,YAAYwf,IACrBmC,GAAW,EACX4sB,EAAW+hE,EAAG54C,SACd++C,EAASnG,EAAG5iD,IACR/8C,EAAQxF,EAAAnL,YAAY+f,UACtBpiB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAM4tG,EAAeC,GAAc,aAMnCjG,EAAG71C,KAAK1a,EAAAC,MAAMvgC,KACnB6wF,EAAGn2C,MAAK,EAAMpa,EAAAgT,mBAAmBgH,SAAWha,EAAAC,MAAMM,YAAegwD,EAAGz4C,mBAYtEy4C,EAAGv1C,MAAMJ,IAXThqD,GAASxF,EAAAnL,YAAYyf,IACrB01F,GAAW,EACX5mE,EAAW+hE,EAAG54C,SACd++C,EAASnG,EAAG5iD,IACR/8C,EAAQxF,EAAAnL,YAAY+f,UACtBpiB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAM4tG,EAAeC,GAAc,aAMnCjG,EAAG71C,KAAK1a,EAAAC,MAAMz/B,eAEvB8zF,GAAgB,GADhB1jG,GAASxF,EAAAnL,YAAYugB,aAETpV,EAAAnL,YAAY6f,QACtBliB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMutG,EAAaC,GAAY,UAGlCvlG,EAAQxF,EAAAnL,YAAYmgB,UACtBxiB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMytG,EAAeC,GAAc,YAGtCzlG,EAAQxF,EAAAnL,YAAY+f,UACtBpiB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAM4tG,EAAeC,GAAc,cAO1ClC,EACF91G,EAAO+M,EAAAuF,KAAK6yC,4BAA4B4sD,EAAG5nG,aACtC,CACL,IAAMiZ,IAAYwzF,GAAa7E,EAAG71C,KAAK1a,EAAAC,MAAMoZ,aAAc,CAErDzoD,EAAQxF,EAAAnL,YAAYu0D,OACtB52D,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMqtG,EAAaC,GAAY,UAE3BrlG,EAAQxF,EAAAnL,YAAYs0D,UAC7B32D,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMqtG,EAAaC,GAAY,aAE3BrlG,EAAQxF,EAAAnL,YAAYq0D,SAC7B12D,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMqtG,EAAaC,GAAY,aAGlCrlG,EAAQxF,EAAAnL,YAAY6f,QACtBliB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMutG,EAAaC,GAAY,UAGlCvlG,EAAQxF,EAAAnL,YAAYmgB,UACtBxiB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMytG,EAAeC,GAAc,YAGtCzlG,EAAQxF,EAAAnL,YAAY+f,UACtBpiB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAM4tG,EAAeC,GAAc,YAG1C,IAAIG,EAAW/4G,KAAKg5G,+BAA+BrG,EAAIpyF,GACvD,OAAKw4F,GACLpG,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACPy9C,GAFe,KAIxB,IAAKpG,EAAG91C,iBAKN,OAJA78D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,KAETnK,EAAO+M,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SAEjE,IAAI+b,EAA6C,KACjD,GAAI6rF,EAAG71C,KAAK1a,EAAAC,MAAMkV,UAAW,CAC3B,IAAI0hD,EAAsBtG,EAAG54C,SAE7B,KADAjzC,EAAiB9mB,KAAKm2G,oBAAoBxD,IACrB,OAAO,KACxB+D,EACF12G,KAAKqN,MACHI,EAAAhD,eAAeyuG,2DACfvG,EAAG5nG,MAAMkuG,EAAqBtG,EAAG5iD,MAE1B/rC,GAAYwzF,EACrBx3G,KAAKqN,MACHI,EAAAhD,eAAe0uG,wCACfxG,EAAG5nG,MAAMkuG,EAAqBtG,EAAG5iD,MAGnC/8C,GAASxF,EAAAnL,YAAY8S,QAKzB,GAAIw9F,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAAY,CAC5B,IAAI88C,EAAiB5E,EAAG54C,SACpBxW,EAAavjD,KAAKy2G,gBAAgB9D,EAAI+D,GAC1C,IAAKnzD,EAAY,OAAO,KACxB,IAAIx5B,EAAW/pB,KAAKwyG,oBACpB,GAAIkE,EACF,IAAK,IAAIr2G,EAAI,EAAG+V,EAAImtC,EAAWp3C,OAAQ9L,EAAI+V,IAAK/V,EAAG,CACjD,IAAI60G,EAAY3xD,EAAWljD,GAC3B,GAAI60G,EAAUtzF,MACZpU,EAAAnL,YAAYu0D,OACZppD,EAAAnL,YAAYs0D,UACZnpD,EAAAnL,YAAYq0D,QACZlpD,EAAAnL,YAAY+f,UACX,CACD,IAAI6rC,EAA2BtgD,EAAAuF,KAAKq4C,uBAClC2pD,EAAUt0G,KACVs0G,EAAUj2F,KACV,KACA,KACAi2F,EAAUliG,MAAQxF,EAAAnL,YAAY4iB,SAC9BiwF,EAAUnqG,OAEZkjD,EAAyB7iC,eAAiB/qB,EAC1C60G,EAAUjnD,yBAA2BA,EACrC/5C,EAAO4K,QAAQpS,KAAKuhD,SAGfjqC,EACLu/B,EAAWp3C,QACbnM,KAAKqN,MACHI,EAAAhD,eAAektG,sCACf/2G,EAAKmK,OAGAysG,IACgB,GAArBj0D,EAAWp3C,QACbnM,KAAKqN,MACHI,EAAAhD,eAAegtG,+CACf72G,EAAKmK,OAGLw4C,EAAWp3C,QAAUo3C,EAAW,GAAGn8B,aACrCpnB,KAAKqN,MACHI,EAAAhD,eAAeitG,oDACf92G,EAAKmK,QAKX,IAAIqgC,EAA8B,KAClC,GAAIunE,EAAG71C,KAAK1a,EAAAC,MAAMgZ,QAahB,GAZIz6D,EAAK6V,MAAQ9I,EAAA+I,SAASkM,YACxB5iB,KAAKqN,MACHI,EAAAhD,eAAe2uG,2DACfzG,EAAG5nG,SAEIysG,GACTx3G,KAAKqN,MACHI,EAAAhD,eAAe4uG,oDACf1G,EAAG5nG,WAGPqgC,EAAaprC,KAAKy0G,UAAU9B,EAAI/xG,EAAK6V,MAAQ9I,EAAA+I,SAASkM,aAAe40F,IACpD,OAAO,UAExBpsE,EAAaz9B,EAAAuF,KAAKM,kBAAkBm/F,EAAG5nG,MAAM4nG,EAAG5iD,MAC3CynD,GAAY52G,EAAK6V,MAAQ9I,EAAA+I,SAASkM,aACrC5iB,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACf51B,EAAWrgC,OAKjB,IAAIkJ,EAAYtG,EAAAuF,KAAKS,mBACnB4vC,EACAnY,EACArhB,GACA,EACA4oF,EAAG5nG,MAAMwsG,EAAgB5E,EAAG5iD,MAG1B/nC,EAAyB,KAC7B,GAAI2qF,EAAG71C,KAAK1a,EAAAC,MAAMsZ,YAahB,GAZI3oD,EAAQxF,EAAAnL,YAAY0iB,QACtB/kB,KAAKqN,MACHI,EAAAhD,eAAe+rE,yDACfm8B,EAAG5nG,SAEIiI,EAAQxF,EAAAnL,YAAYmgB,UAC7BxiB,KAAKqN,MACHI,EAAAhD,eAAe6uG,qEACf3G,EAAG5nG,QAASnK,EAAKqL,QAGrB+b,EAAOhoB,KAAK43G,oBAAoBjF,GAAI,IACzB,OAAO,UACP3/F,EAAQxF,EAAAnL,YAAY0iB,SAAamtF,GAC5ClyG,KAAKqN,MACHI,EAAAhD,eAAeisE,gFACfi8B,EAAG5nG,SAIP,IAAIwuG,EAAY5rG,EAAAuF,KAAK+4C,wBACnBrrD,EACAkmB,EACA7S,EACA+T,EACAzH,EACAvN,EACA2/F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAGxB,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACPi+C,EAEF,GAAI7C,EACT12G,KAAKqN,MACHI,EAAAhD,eAAe+uG,sCACf54G,EAAKmK,WAGF,KAAIiZ,IAAYwzF,EAOhB,CACDxkG,EAAQxF,EAAAnL,YAAYmgB,UACtBxiB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAMytG,EAAeC,GAAc,YAItCzlG,EAAQxF,EAAAnL,YAAYwf,KACtB7hB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAnRW,EACF,GAkRgB,OAI5BiI,EAAQxF,EAAAnL,YAAYyf,KACtB9hB,KAAKqN,MACHI,EAAAhD,eAAe4pG,gCACf1B,EAAG5nG,MAAM6lC,EAAUkoE,GAAS,OAIhC,IAAI75F,EAAwB,KAU5B,GATI0zF,EAAG71C,KAAK1a,EAAAC,MAAMmZ,WAChBx7D,KAAKqN,MACHI,EAAAhD,eAAegvG,sCACf9G,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAGtB4iD,EAAG71C,KAAK1a,EAAAC,MAAMsW,eAChB3lD,GAASxF,EAAAnL,YAAYwzG,qBAEnBlD,EAAG71C,KAAK1a,EAAAC,MAAMgZ,QAEhB,KADAp8C,EAAOjf,KAAKy0G,UAAU9B,IACX,OAAO,UAElB3yG,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACf2xC,EAAG5nG,SAGP,IAAIqc,EAAiC,KACrC,GAAIurF,EAAG71C,KAAK1a,EAAAC,MAAM0W,WAChB3xC,EAAcpnB,KAAK+1G,gBAAgBpD,IACjB,OAAO,KAE3B,IAAI5nG,EAAQ4nG,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,KAC7B/8C,EAAQxF,EAAAnL,YAAYwzG,sBAA0B7iG,EAAQxF,EAAAnL,YAAY6f,QAAWgwF,GAAe9qF,IAC/FpnB,KAAKqN,MACHI,EAAAhD,eAAeurG,iEACfjrG,GAGJ,IAAI2uG,EAAW/rG,EAAAuF,KAAKq4C,uBAClB3qD,EACAqe,EACAmI,EACA7G,EACAvN,EACAjI,GAGF,OADA4nG,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACPo+C,EApEP15G,KAAKqN,MACHI,EAAAhD,eAAeisE,gFACf91E,EAAKmK,OAoET,OAAO,MAGTonG,EAAAlwG,UAAA+2G,+BAAA,SAA+BrG,EAAepyF,GAIxCA,GAAcA,EAAWpU,QAC3BnM,KAAKqN,MACHI,EAAAhD,eAAe6pG,8BACflyD,EAAAzmC,MAAMhP,KAAK4T,EAAW,GAAGxV,MAAOwV,EAAWA,EAAWpU,OAAS,GAAGpB,QAItE,IAAIqB,EAAQumG,EAAG54C,SACf,GAAI44C,EAAG91C,iBAEL,GAAU,OADD81C,EAAGt1C,iBAEV,GAAIs1C,EAAG71C,KAAK1a,EAAAC,MAAMgZ,OAAQ,CACxB,IAAIvP,EAAU9rD,KAAKy0G,UAAU9B,GAC7B,IAAK7mD,EAAS,OAAO,KACrB,GAAIA,EAAQr1C,MAAQ9I,EAAA+I,SAASk3C,UAK3B,OAJA5tD,KAAKqN,MACHI,EAAAhD,eAAeu2D,cACf2xC,EAAG5nG,SAEE,KAET,GAAI4nG,EAAG71C,KAAK1a,EAAAC,MAAMqZ,cAAe,CAC/B,GAAIi3C,EAAG71C,KAAK1a,EAAAC,MAAMgZ,OAAQ,CACxB,IAAItP,EAAY/rD,KAAKy0G,UAAU9B,GAC/B,OAAK5mD,EACEp+C,EAAAuF,KAAK24C,gCAA+CC,EAASC,EAAW4mD,EAAG5nG,MAAMqB,EAAOumG,EAAG5iD,MAD3E,KAGvB/vD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,YAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGP,OAAO,MAGTonG,EAAAlwG,UAAA6xG,eAAA,SACEnB,EACA3/F,EACAuN,EACAsyF,GAKA,GAAIF,EAAG91C,iBAAkB,CACvB,IAAIvpD,EAAa3F,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SACzE,GAAI4nG,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAAY,CAS5B,IARA,IAAI78C,EAAU,IAAI7X,MACdsN,EAAc5G,EAAAuF,KAAKa,2BACrBT,EACAwL,EACAyB,EACAvN,EACA2/F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,OAEhB4iD,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAAa,CACjC,IAAIt9C,EAASte,KAAK4yG,uBAAuBD,EAAIp+F,GAC7C,GAAI+J,EAAQQ,EAAQpS,KAAK4R,QAGvB,GADAte,KAAK+yG,cAAcJ,GACfA,EAAG71C,KAAK1a,EAAAC,MAAMka,WAKhB,OAJAv8D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAMb,OAFAwJ,EAAYxJ,MAAMsB,IAAMsmG,EAAG5iD,IAC3B4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP/mD,EAEPvU,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGP,OAAO,MAGTonG,EAAAlwG,UAAAmyG,YAAA,SACEzB,EACAE,EACA9oD,GAKA,IAAIvlC,EAAuC,KAC3C,GAAImuF,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAAY,CAE5B,IADA,IAAI78C,EAAU,IAAI7X,OACV0rG,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAAa,CACjC,IAAIt9C,EAASte,KAAK25G,kBAAkBhH,GACpC,IAAKr0F,EAAQ,OAAO,KAEpB,GADAQ,EAAQpS,KAAK4R,IACRq0F,EAAG71C,KAAK1a,EAAAC,MAAMyM,OAAQ,CACzB,GAAI6jD,EAAG71C,KAAK1a,EAAAC,MAAMuZ,YAChB,MAMA,OAJA57D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MAIb,GAAI4nG,EAAG71C,KAAK1a,EAAAC,MAAM4T,MAAO,CACvB,IAAI08C,EAAG71C,KAAK1a,EAAAC,MAAMkY,eAOhB,OAJAv6D,KAAKqN,MACHI,EAAAhD,eAAeiZ,wBACfivF,EAAG5nG,SAEE,KANPyZ,EAAO7W,EAAAuF,KAAK+0C,8BAA8B0qD,EAAG7+D,aAAc6+D,EAAG5nG,SAgBlE,OALqB,QADjBsZ,GADAqvB,EAAM/lC,EAAAuF,KAAK42C,sBAAsBhrC,EAAS0F,EAAMulC,EAAW4oD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,OAC9D1rC,eACOrkB,KAAKqyG,QAAQ79F,IAAI6P,KAC7CrkB,KAAKoyG,QAAQ1lG,KAAK2X,GAClBrkB,KAAKqyG,QAAQr9F,IAAIqP,IAEnBsuF,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,EACF,GAAIi/D,EAAG71C,KAAK1a,EAAAC,MAAM2V,UACvB,GAAI26C,EAAG71C,KAAK1a,EAAAC,MAAM4T,MAAO,CACvB,GAAI08C,EAAG71C,KAAK1a,EAAAC,MAAMkY,eAAgB,CAChC/1C,EAAO7W,EAAAuF,KAAK+0C,8BAA8B0qD,EAAG7+D,aAAc6+D,EAAG5nG,SAC9D,IAAI2oC,EAAM/lC,EAAAuF,KAAK42C,sBAAsB,KAAMtlC,EAAMulC,EAAW4oD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAC9E1rC,EAAeja,OAAOspC,EAAIrvB,cAC1B1Y,EAASgnG,EAAGhnG,OAQhB,OAPKA,EAAOkkD,cAAalkD,EAAOkkD,YAAc,IAAI1oD,KAClDwE,EAAOkkD,YAAY76C,IAAIqP,GAClBrkB,KAAKqyG,QAAQ79F,IAAI6P,KACpBrkB,KAAKoyG,QAAQ1lG,KAAK2X,GAClBrkB,KAAKqyG,QAAQr9F,IAAIqP,IAEnBsuF,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,EAEP1zC,KAAKqN,MACHI,EAAAhD,eAAeiZ,wBACfivF,EAAG5nG,cAIP/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,aAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAGhB,OAAO,MAGTonG,EAAAlwG,UAAA03G,kBAAA,SACEhH,GAKA,GAAIA,EAAG91C,iBAAkB,CACvB,IAAIvpD,EAAa3F,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SACrE6uG,EAA4C,KAChD,GAAIjH,EAAG71C,KAAK1a,EAAAC,MAAMiT,IAAK,CACrB,IAAIq9C,EAAG91C,eAAeza,EAAAgT,mBAAmB+G,QAOvC,OAJAn8D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,KANP6uG,EAAejsG,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SAS3E,OAAO4C,EAAAuF,KAAKu3C,mBACVn3C,EACAsmG,EACAA,EACIx3D,EAAAzmC,MAAMhP,KAAK2G,EAAWvI,MAAO6uG,EAAa7uG,OAC1CuI,EAAWvI,OAQnB,OALE/K,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGA,MAGTonG,EAAAlwG,UAAAkyG,wBAAA,SACExB,EACAE,EACAK,EACAC,GAKA,IAAIvyG,EAAO+xG,EAAGt1C,iBACVtyD,EAAQ4nG,EAAG5nG,QACX2oC,EAAM/lC,EAAAuF,KAAK42C,sBAAsB,CACnCn8C,EAAAuF,KAAKu3C,mBACH98C,EAAAuF,KAAKE,2BAA2BxS,EAAMmK,GACtC4C,EAAAuF,KAAKE,2BAA2B,UAAWu/F,EAAG5nG,MAAMmoG,EAAcC,IAClEpoG,IAED,MAAM,EAAO4nG,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAEtC,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAA+xG,YAAA,SACErB,GAOA,IAAIE,EAAWF,EAAG54C,SACdj7C,EAAsC,KACtC+F,EAA6C,KAC7Cg1F,GAAW,EACf,GAAIlH,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAEhB,IADA78C,EAAU,IAAI7X,OACN0rG,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAAa,CACjC,IAAIt9C,EAASte,KAAK85G,uBAAuBnH,GACzC,IAAKr0F,EAAQ,OAAO,KAEpB,GADAQ,EAAQpS,KAAK4R,IACRq0F,EAAG71C,KAAK1a,EAAAC,MAAMyM,OAAQ,CACzB,GAAI6jD,EAAG71C,KAAK1a,EAAAC,MAAMuZ,YAChB,MAMA,OAJA57D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,WAIR,GAAI4nG,EAAG71C,KAAK1a,EAAAC,MAAM2V,UAAW,CAClC,IAAI26C,EAAG71C,KAAK1a,EAAAC,MAAMiT,IAehB,OAJAt1D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,MAEP,KAdP,IAAI4nG,EAAG91C,iBAOL,OAJA78D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,KANP8Z,EAAgBlX,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,cAevE,GAAI4nG,EAAG71C,KAAK1a,EAAAC,MAAMM,WAAYP,EAAAgT,mBAAmBgH,QAAS,CAC/D,IAAIx7D,EAAO+xG,EAAGt1C,iBACVtyD,EAAQ4nG,EAAG5nG,QAQf,GAPA+T,EAAU,CACRnR,EAAAuF,KAAKi4C,wBACHx9C,EAAAuF,KAAKE,2BAA2B,UAAWrI,GAC3C4C,EAAAuF,KAAKE,2BAA2BxS,EAAMmK,GACtCA,IAGA4nG,EAAG71C,KAAK1a,EAAAC,MAAMyM,OAMhB,OAJA9uD,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACfsxF,EAAG5nG,SAEE,UAGT8uG,GAAW,EAGb,GAAIA,GAAYlH,EAAG71C,KAAK1a,EAAAC,MAAM4T,MAAO,CACnC,GAAI08C,EAAG71C,KAAK1a,EAAAC,MAAMkY,eAAgB,CAChC,IAAI/1C,EAAO7W,EAAAuF,KAAK+0C,8BAA8B0qD,EAAG7+D,aAAc6+D,EAAG5nG,SAC9D2oC,OAAG,EACH7uB,GACFza,QAAQ0U,GACR40B,EAAM/lC,EAAAuF,KAAKg4C,kCAAkCrmC,EAAeL,EAAMmuF,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,OAExFrc,EAAM/lC,EAAAuF,KAAK63C,sBAAsBjsC,EAAS0F,EAAMmuF,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAExE,IAAI1rC,EAAeqvB,EAAIrvB,aAMvB,OALKrkB,KAAKqyG,QAAQ79F,IAAI6P,KACpBrkB,KAAKoyG,QAAQ1lG,KAAK2X,GAClBrkB,KAAKqyG,QAAQr9F,IAAIqP,IAEnBsuF,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,EAEP1zC,KAAKqN,MACHI,EAAAhD,eAAeiZ,wBACfivF,EAAG5nG,cAIP/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,QAGhB,OAAO,MAGTonG,EAAAlwG,UAAA63G,uBAAA,SACEnH,GAKA,GAAIA,EAAG91C,eAAeza,EAAAgT,mBAAmB+G,QAAS,CAChD,IAAI7oD,EAAa3F,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SACrE6uG,EAA4C,KAChD,GAAIjH,EAAG71C,KAAK1a,EAAAC,MAAMiT,IAAK,CACrB,IAAIq9C,EAAG91C,iBAOL,OAJA78D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,KANP6uG,EAAejsG,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SAS3E,OAAO4C,EAAAuF,KAAKi4C,wBACV73C,EACAsmG,EACAA,EACIx3D,EAAAzmC,MAAMhP,KAAK2G,EAAWvI,MAAO6uG,EAAa7uG,OAC1CuI,EAAWvI,OAQnB,OALE/K,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGA,MAGTonG,EAAAlwG,UAAA8xG,kBAAA,SACEpB,EACAE,GAKA,GAAIF,EAAG91C,iBAAkB,CACvB,IAAI+8C,EAAejsG,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SAC3E,GAAI4nG,EAAG71C,KAAK1a,EAAAC,MAAM0W,QAAS,CACzB,GAAI45C,EAAG91C,iBAAkB,CACvB,IAAIvpD,EAAa3F,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SACrE2oC,EAAM/lC,EAAAuF,KAAKq3C,4BAA4Bj3C,EAAYsmG,EAAcjH,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAE3F,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,EAEP1zC,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,cAIP/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGP,OAAO,MAGTonG,EAAAlwG,UAAA2xG,eAAA,SACEjB,EACAoH,QAAA,IAAAA,OAAA,GAKA,IAAI/8C,EAAQ21C,EAAG51C,OAEXvmD,EAA8B,KAClC,OAFYm8F,EAAG16F,QAGb,KAAKmqC,EAAAC,MAAMiO,MACT95C,EAAYxW,KAAKg6G,WAAWrH,GAC5B,MAEF,KAAKvwD,EAAAC,MAAM5iC,MACTjJ,EAAYxW,KAAK0zG,cAAcf,EAAInlG,EAAAnL,YAAYod,MAAO,KAAMkzF,EAAG54C,UAC/D,MAEF,KAAK3X,EAAAC,MAAMkO,SACT/5C,EAAYxW,KAAKi6G,cAActH,GAC/B,MAEF,KAAKvwD,EAAAC,MAAMmO,GACTh6C,EAAYxW,KAAKk6G,iBAAiBvH,GAClC,MAEF,KAAKvwD,EAAAC,MAAMwO,IACTr6C,EAAYxW,KAAKm6G,kBAAkBxH,GACnC,MAEF,KAAKvwD,EAAAC,MAAM2O,GACTx6C,EAAYxW,KAAKo6G,iBAAiBzH,GAClC,MAEF,KAAKvwD,EAAAC,MAAMiU,IACT9/C,EAAYxW,KAAK0zG,cAAcf,EAAInlG,EAAAnL,YAAYi0D,IAAK,KAAMq8C,EAAG54C,UAC7D,MAEF,KAAK3X,EAAAC,MAAM0U,IACTvgD,EAAYxW,KAAK0zG,cAAcf,EAAInlG,EAAAnL,YAAY4Q,KAAM,KAAM0/F,EAAG54C,UAC9D,MAEF,KAAK3X,EAAAC,MAAMsZ,UACTnlD,EAAYxW,KAAK43G,oBAAoBjF,EAAIoH,GACzC,MAEF,KAAK33D,EAAAC,MAAM6O,OACL6oD,GACF/5G,KAAKqN,MACHI,EAAAhD,eAAe4vG,2DACf1H,EAAG5nG,SAGPyL,EAAYxW,KAAKk2G,YAAYvD,GAC7B,MAEF,KAAKvwD,EAAAC,MAAMiZ,UACT,OAAO3tD,EAAAuF,KAAKs2C,qBAAqBmpD,EAAG5nG,MAAM4nG,EAAG54C,WAE/C,KAAK3X,EAAAC,MAAM+O,OACT56C,EAAYxW,KAAKs6G,qBAAqB3H,GACtC,MAEF,KAAKvwD,EAAAC,MAAMgP,MACT76C,EAAYxW,KAAKu6G,oBAAoB5H,GACrC,MAEF,KAAKvwD,EAAAC,MAAMiP,IACT96C,EAAYxW,KAAKw6G,kBAAkB7H,GACnC,MAEF,KAAKvwD,EAAAC,MAAMmP,KACTh7C,EAAYxW,KAAKy6G,mBAAmB9H,GACpC,MAEF,KAAKvwD,EAAAC,MAAMoP,MACTj7C,EAAYxW,KAAK06G,oBAAoB/H,GACrC,MAEF,KAAKvwD,EAAAC,MAAMwU,KACT,GAAI87C,EAAGn2C,MAAK,EAAOpa,EAAAgT,mBAAmBgH,SAAWha,EAAAC,MAAMM,WAAY,CACjEnsC,EAAYxW,KAAKi0G,qBAAqBtB,EAAInlG,EAAAnL,YAAY4Q,KAAM,KAAM0/F,EAAG54C,UACrE,MAIJ,QACE44C,EAAGv1C,MAAMJ,GACTxmD,EAAYxW,KAAK26G,yBAAyBhI,GAU9C,OANKn8F,EAIHm8F,EAAGx1C,QAAQH,IAHX21C,EAAGv1C,MAAMJ,GACTh9D,KAAK+yG,cAAcJ,IAIdn8F,GAGT27F,EAAAlwG,UAAA21G,oBAAA,SACEjF,EACAoH,GAOA,IAFA,IAAIlH,EAAWF,EAAG54C,SACdzjD,EAAa,IAAIrP,OACb0rG,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAAa,CACjC,IAAIoB,EAAQ21C,EAAG51C,OACXvmD,EAAYxW,KAAK4zG,eAAejB,EAAIoH,GACxC,GAAKvjG,EAKHm8F,EAAGx1C,QAAQH,GACX1mD,EAAW5J,KAAK8J,OANF,CACd,GAAIm8F,EAAGx7C,OAAS/U,EAAAC,MAAMka,UAAW,OAAO,KACxCo2C,EAAGv1C,MAAMJ,GACTh9D,KAAK+yG,cAAcJ,IAMvB,IAAIj/D,EAAM/lC,EAAAuF,KAAK41C,qBAAqBxyC,EAAYq8F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAEtE,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAA+3G,WAAA,SACErH,GAKA,IAAIr/F,EAA0C,KAC1Cq/F,EAAGn2C,MAAK,IAASpa,EAAAC,MAAMM,YAAegwD,EAAGz4C,qBAC3Cy4C,EAAG16F,KAAKmqC,EAAAgT,mBAAmBgH,QAC3B9oD,EAAa3F,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,UAEvE,IAAI2oC,EAAM/lC,EAAAuF,KAAK81C,qBAAqB11C,EAAYq/F,EAAG5nG,SAEnD,OADA4nG,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAAg4G,cAAA,SACEtH,GAKA,IAAIr/F,EAA0C,KAC1Cq/F,EAAGn2C,MAAK,IAASpa,EAAAC,MAAMM,YAAegwD,EAAGz4C,qBAC3Cy4C,EAAG16F,KAAKmqC,EAAAgT,mBAAmBgH,QAC3B9oD,EAAa3F,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,UAEvE,IAAI2oC,EAAM/lC,EAAAuF,KAAKk2C,wBAAwB91C,EAAYq/F,EAAG5nG,SAEtD,OADA4nG,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAAi4G,iBAAA,SACEvH,GAKA,IAAIE,EAAWF,EAAG54C,SACdvjD,EAAYxW,KAAK4zG,eAAejB,GACpC,IAAKn8F,EAAW,OAAO,KAEvB,GAAIm8F,EAAG71C,KAAK1a,EAAAC,MAAMoP,OAEhB,GAAIkhD,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAAY,CAC5B,IAAI5wB,EAAY7pC,KAAK+1G,gBAAgBpD,GACrC,IAAK9oE,EAAW,OAAO,KAEvB,GAAI8oE,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAAa,CAC7B,IAAIhnB,EAAM/lC,EAAAuF,KAAKo2C,kBAA6B9yC,EAAuBqzB,EAAW8oE,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAEpG,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,EAEP1zC,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,SAGhB,OAAO,MAGTonG,EAAAlwG,UAAA04G,yBAAA,SACEhI,GAKA,IAAI/rE,EAAO5mC,KAAK+1G,gBAAgBpD,GAChC,IAAK/rE,EAAM,OAAO,KAElB,IAAI8M,EAAM/lC,EAAAuF,KAAKy3C,0BAA0B/jB,GAEzC,OADA+rE,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAAk4G,kBAAA,SACExH,GAKA,IAAIE,EAAWF,EAAG54C,SAElB,GAAI44C,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAAY,CAC5B,IAAIrzC,EAAgC,KAEpC,GAAIurF,EAAG71C,KAAK1a,EAAAC,MAAM5iC,OAChB2H,EAAcpnB,KAAK0zG,cAAcf,EAAInlG,EAAAnL,YAAYod,MAAO,KAAMkzF,EAAG54C,eAC5D,GAAI44C,EAAG71C,KAAK1a,EAAAC,MAAMiU,KACvBlvC,EAAcpnB,KAAK0zG,cAAcf,EAAInlG,EAAAnL,YAAYi0D,IAAK,KAAMq8C,EAAG54C,eAC1D,GAAI44C,EAAG71C,KAAK1a,EAAAC,MAAM0U,KACvB3vC,EAAcpnB,KAAK0zG,cAAcf,EAAInlG,EAAAnL,YAAY4Q,KAAM,KAAM0/F,EAAG54C,eAE3D,IAAK44C,EAAG71C,KAAK1a,EAAAC,MAAMiZ,cACxBl0C,EAAcpnB,KAAK26G,yBAAyBhI,IAC1B,OAAO,KAG3B,GAAIA,EAAGx7C,OAAS/U,EAAAC,MAAMiZ,UAAW,CAC/B,IAAIzxB,EAAwC,KAC5C,IAAK8oE,EAAG71C,KAAK1a,EAAAC,MAAMiZ,cACjBzxB,EAAY7pC,KAAK26G,yBAAyBhI,IAC1B,OAAO,KAGzB,GAAIA,EAAGx7C,OAAS/U,EAAAC,MAAMiZ,UAAW,CAC/B,IAAI5P,EAAiC,KACrC,IAAKinD,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAAa,CAE9B,KADAhP,EAAc1rD,KAAK+1G,gBAAgBpD,IACjB,OAAO,KAEzB,IAAKA,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAKjB,OAJA16D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAIX,IAAIyL,EAAYxW,KAAK4zG,eAAejB,GACpC,OAAKn8F,EAEE7I,EAAAuF,KAAKu4C,mBACVrkC,EACAyiB,EACIA,EAAUG,WACV,KACJ0hB,EACAl1C,EACAm8F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MATD,KAavB/vD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAGhB,OAAO,MAGTonG,EAAAlwG,UAAAm4G,iBAAA,SACEzH,GAKA,IAAIE,EAAWF,EAAG54C,SAClB,GAAI44C,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAAY,CAC5B,IAAI5wB,EAAY7pC,KAAK+1G,gBAAgBpD,GACrC,IAAK9oE,EAAW,OAAO,KACvB,GAAI8oE,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAAa,CAC7B,IAAIlkD,EAAYxW,KAAK4zG,eAAejB,GACpC,IAAKn8F,EAAW,OAAO,KACvB,IAAIokG,EAAkC,KACtC,OAAIjI,EAAG71C,KAAK1a,EAAAC,MAAMyT,SAChB8kD,EAAgB56G,KAAK4zG,eAAejB,IACT,KAEtBhlG,EAAAuF,KAAK23C,kBACVhhB,EACArzB,EACAokG,EACAjI,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAGxB/vD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAGhB,OAAO,MAGTonG,EAAAlwG,UAAAq4G,qBAAA,SACE3H,GAKA,IAAIE,EAAWF,EAAG54C,SAClB,GAAI44C,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAAY,CAC5B,IAAI5wB,EAAY7pC,KAAK+1G,gBAAgBpD,GACrC,IAAK9oE,EAAW,OAAO,KACvB,GAAI8oE,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAAa,CAC7B,GAAIi4C,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAAY,CAE5B,IADA,IAAIpP,EAAQ,IAAItlD,OACR0rG,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAAa,CACjC,IAAIi/C,EAAQ76G,KAAK86G,gBAAgBnI,GACjC,IAAKkI,EAAO,OAAO,KACnBtuD,EAAM7/C,KAAiBmuG,GAEzB,IAAInnE,EAAM/lC,EAAAuF,KAAKo5C,sBAAsBziB,EAAW0iB,EAAOomD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAE7E,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,EAEP1zC,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAGhB,OAAO,MAGTonG,EAAAlwG,UAAA64G,gBAAA,SACEnI,GAGA,IACIr8F,EACAE,EAFAq8F,EAAWF,EAAG54C,SAMlB,GAAI44C,EAAG71C,KAAK1a,EAAAC,MAAMoT,MAAO,CACvB,IAAIhsB,EAAQzpC,KAAK+1G,gBAAgBpD,GACjC,IAAKlpE,EAAO,OAAO,KACnB,GAAIkpE,EAAG71C,KAAK1a,EAAAC,MAAMgZ,OAAQ,CAExB,IADA/kD,EAAa,IAAIrP,MACV0rG,EAAGn2C,QAAUpa,EAAAC,MAAMoT,MAAQk9C,EAAG34C,WAAa5X,EAAAC,MAAMuT,SAAW+8C,EAAG34C,WAAa5X,EAAAC,MAAMuZ,YAAY,CAEnG,KADAplD,EAAYxW,KAAK4zG,eAAejB,IAChB,OAAO,KACvBr8F,EAAW5J,KAAK8J,GAElB,OAAO7I,EAAAuF,KAAKu5C,iBAAiBhjB,EAAOnzB,EAAYq8F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAEtE/vD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAMX,GAAI4nG,EAAG71C,KAAK1a,EAAAC,MAAMuT,SAAU,CACjC,GAAI+8C,EAAG71C,KAAK1a,EAAAC,MAAMgZ,OAAQ,CAExB,IADA/kD,EAAa,IAAIrP,MACV0rG,EAAGn2C,QAAUpa,EAAAC,MAAMoT,MAAQk9C,EAAG34C,WAAa5X,EAAAC,MAAMuT,SAAW+8C,EAAG34C,WAAa5X,EAAAC,MAAMuZ,YAAY,CAEnG,KADAplD,EAAYxW,KAAK4zG,eAAejB,IAChB,OAAO,KACvBr8F,EAAW5J,KAAK8J,GAElB,OAAO7I,EAAAuF,KAAKu5C,iBAAiB,KAAMn2C,EAAYq8F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAErE/vD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeswG,0BACfpI,EAAG5nG,SAGP,OAAO,MAGTonG,EAAAlwG,UAAAs4G,oBAAA,SACE5H,GAKA,IAAIE,EAAWF,EAAG54C,SACd/vB,EAAahqC,KAAK+1G,gBAAgBpD,GACtC,IAAK3oE,EAAY,OAAO,KACxB,IAAI0J,EAAM/lC,EAAAuF,KAAKy5C,qBAAiC3iB,EAAY2oE,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAElF,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAAu4G,kBAAA,SACE7H,GAQA,IACIxuD,EADA0uD,EAAWF,EAAG54C,SAElB,GAAI44C,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAAY,CAE5B,IADA,IAAIrlD,EAAa,IAAIrP,OACb0rG,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAAa,CAEjC,KADAzX,EAAOnkD,KAAK4zG,eAAejB,IAChB,OAAO,KAClBr8F,EAAW5J,KAAgBy3C,GAE7B,IAAI2I,EAA6C,KAC7CC,EAAsC,KACtCC,EAAwC,KAC5C,GAAI2lD,EAAG71C,KAAK1a,EAAAC,MAAMqT,OAAQ,CACxB,IAAKi9C,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAKjB,OAJAz6D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAET,IAAK4nG,EAAG91C,iBAKN,OAJA78D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,KAGT,GADA+hD,EAAgBn/C,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,UACnE4nG,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAKjB,OAJA16D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAET,IAAK4nG,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAKjB,OAJA37D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAGT,IADAgiD,EAAkB,IACV4lD,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAAa,CAEjC,KADAzX,EAAOnkD,KAAK4zG,eAAejB,IAChB,OAAO,KAClB5lD,EAAgBrgD,KAAgBy3C,IAGpC,GAAIwuD,EAAG71C,KAAK1a,EAAAC,MAAM2T,SAAU,CAC1B,IAAK28C,EAAG71C,KAAK1a,EAAAC,MAAMsZ,WAKjB,OAJA37D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAGT,IADAiiD,EAAoB,IACZ2lD,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAAa,CAEjC,KADAzX,EAAOnkD,KAAK4zG,eAAejB,IAChB,OAAO,KAClB3lD,EAAkBtgD,KAAgBy3C,IAGtC,IAAM4I,IAAmBC,EAKvB,OAJAhtD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,SAEP,KAET,IAAI2oC,EAAM/lC,EAAAuF,KAAK25C,mBACbv2C,EACAw2C,EACAC,EACAC,EACA2lD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAGxB,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,EAOT,OALE1zC,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAGT,MAGTonG,EAAAlwG,UAAAgyG,qBAAA,SACEtB,EACA3/F,EACAuN,EACAsyF,GAKA,GAAIF,EAAG91C,iBAAkB,CACvB,IAAIj8D,EAAO+M,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,SAC/D+b,EAA6C,KACjD,GAAI6rF,EAAG71C,KAAK1a,EAAAC,MAAMkV,UAAW,CAE3B,KADAzwC,EAAiB9mB,KAAKm2G,oBAAoBxD,IACrB,OAAO,KAC5B3/F,GAASxF,EAAAnL,YAAY8S,QAEvB,GAAIw9F,EAAG71C,KAAK1a,EAAAC,MAAM0W,QAAS,CACzB,IAAI95C,EAAOjf,KAAKy0G,UAAU9B,GAC1B,IAAK1zF,EAAM,OAAO,KAClB,IAAIy0B,EAAM/lC,EAAAuF,KAAKK,sBACb3S,EACAkmB,EACA7H,EACAsB,EACAvN,EACA2/F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAGxB,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,EAEP1zC,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAGP,OAAO,MAGTonG,EAAAlwG,UAAAw4G,mBAAA,SACE9H,GAKA,IAAIE,EAAWF,EAAG54C,SACd/vB,EAAahqC,KAAK+1G,gBAAgBpD,EAAE,IACxC,IAAK3oE,EAAY,OAAO,KACxB,IAAI0J,EAAM/lC,EAAAuF,KAAKo6C,oBAAoBtjB,EAAY2oE,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAErE,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,GAGTy+D,EAAAlwG,UAAAy4G,oBAAA,SACE/H,GAKA,IAAIE,EAAWF,EAAG54C,SAClB,GAAI44C,EAAG71C,KAAK1a,EAAAC,MAAMoY,WAAY,CAC5B,IAAIzwB,EAAahqC,KAAK+1G,gBAAgBpD,GACtC,IAAK3oE,EAAY,OAAO,KACxB,GAAI2oE,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAAa,CAC7B,IAAIlkD,EAAYxW,KAAK4zG,eAAejB,GACpC,IAAKn8F,EAAW,OAAO,KACvB,IAAIk9B,EAAM/lC,EAAAuF,KAAKs6C,qBAAqBxjB,EAAYxzB,EAAWm8F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAEjF,OADA4iD,EAAG71C,KAAK1a,EAAAC,MAAMiZ,WACP5nB,EAEP1zC,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,UAIhB/K,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAGhB,OAAO,MAMTonG,EAAAlwG,UAAA+4G,qBAAA,SACErI,GAGA,IAAIx7C,EAAQw7C,EAAG16F,KAAKmqC,EAAAgT,mBAAmBgH,QACnCy2C,EAAWF,EAAG54C,SACdkhD,EA8sBR,SAAkCxkG,GAChC,OAAQA,GACN,KAAK2rC,EAAAC,MAAMiV,YAAa,SACxB,KAAKlV,EAAAC,MAAM4U,MAAO,SAClB,KAAK7U,EAAAC,MAAMsW,YACX,KAAKvW,EAAAC,MAAMuW,MACX,KAAKxW,EAAAC,MAAMjyC,KACX,KAAKgyC,EAAAC,MAAM/xC,MACX,KAAK8xC,EAAAC,MAAM8V,UACX,KAAK/V,EAAAC,MAAM+V,YACX,KAAKhW,EAAAC,MAAMyU,OACX,KAAK1U,EAAAC,MAAMmP,KACX,KAAKpP,EAAAC,MAAMwT,OAAQ,UACnB,KAAKzT,EAAAC,MAAM6M,IAAK,UAElB,SA7tBmBgsD,CAAyB/jD,GAC1C,GAAc,GAAV8jD,EAA+B,CACjC,IAAIvyD,OAAO,EAKX,OAAIyO,GAAS/U,EAAAC,MAAM6M,KACjBxG,EAAU1oD,KAAK+1G,gBAAgBpD,EAAE,KAE7BjqD,EAAQjyC,MAAQ9I,EAAA+I,SAASmsC,KACpBl1C,EAAAuF,KAAK6zC,oBACO2B,EAAS1e,WACT0e,EAASz8B,cACTy8B,EAAS1lC,UAC1B2vF,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,OAGxB/vD,KAAKqN,MACHI,EAAAhD,eAAe4W,wBACfsxF,EAAG5nG,SAGA,MAdc,MAgBrB29C,EAAU1oD,KAAK+1G,gBAAgBpD,EAAIsI,KAKjC9jD,GAAS/U,EAAAC,MAAM8V,WAAahB,GAAS/U,EAAAC,MAAM+V,aAE3C1P,EAAQjyC,MAAQ9I,EAAA+I,SAASisC,YACzB+F,EAAQjyC,MAAQ9I,EAAA+I,SAASosC,eACzB4F,EAAQjyC,MAAQ9I,EAAA+I,SAASssC,gBAEzBhjD,KAAKqN,MACHI,EAAAhD,eAAe0wG,0FACfzyD,EAAQ39C,OAIP4C,EAAAuF,KAAK01C,4BAA4BuO,EAAOzO,EAASiqD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,OAhBvD,KAmBzB,IAAInpB,EAA0B,KAC9B,OAAQuwB,GAEN,KAAK/U,EAAAC,MAAME,KAAM,OAAO50C,EAAAuF,KAAK+zC,qBAAqB0rD,EAAG5nG,SACrD,KAAKq3C,EAAAC,MAAMG,KAAM,OAAO70C,EAAAuF,KAAKq1C,qBAAqBoqD,EAAG5nG,SACrD,KAAKq3C,EAAAC,MAAMI,MAAO,OAAO90C,EAAAuF,KAAKkzC,sBAAsBusD,EAAG5nG,SAIvD,KAAKq3C,EAAAC,MAAMoY,UAGT,GAAIk4C,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAChB,OAAO16D,KAAK83G,8BACVnF,EACAhlG,EAAAuF,KAAK0xC,gCAAgC+tD,EAAG5nG,MAAM8nG,IAC9C,GAAE,GAIN,IAAI71C,EAAQ21C,EAAG51C,OACXq+C,GAAQ,EACZ,GACE,OAAQzI,EAAG16F,KAAKmqC,EAAAgT,mBAAmBgH,SAGjC,KAAKha,EAAAC,MAAMiV,YAET,OADAq7C,EAAGv1C,MAAMJ,GACFh9D,KAAK63G,wBAAwBlF,GAGtC,KAAKvwD,EAAAC,MAAMM,WAET,OADAgwD,EAAGt1C,iBACKs1C,EAAG16F,QAGT,KAAKmqC,EAAAC,MAAMqY,WACT,IACGi4C,EAAG71C,KAAK1a,EAAAC,MAAMgZ,SACds3C,EAAG71C,KAAK1a,EAAAC,MAAMkZ,oBACf,CACA6/C,GAAQ,EACR,MAKJ,KAAKh5D,EAAAC,MAAMgZ,MAET,OADAs3C,EAAGv1C,MAAMJ,GACFh9D,KAAK63G,wBAAwBlF,GAGtC,KAAKvwD,EAAAC,MAAMmZ,SACT,GACEm3C,EAAG71C,KAAK1a,EAAAC,MAAMgZ,QACds3C,EAAG71C,KAAK1a,EAAAC,MAAMyM,QACd6jD,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAGd,OADAi4C,EAAGv1C,MAAMJ,GACFh9D,KAAK63G,wBAAwBlF,GAEtCyI,GAAQ,EACR,MAEF,KAAKh5D,EAAAC,MAAMyM,MACT,MAIF,QACEssD,GAAQ,EAIZ,MAGF,QACEA,GAAQ,SAILA,GAKT,OAJAzI,EAAGv1C,MAAMJ,IAGTp2B,EAAO5mC,KAAK+1G,gBAAgBpD,IAEvBA,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAOZ/sD,EAAAuF,KAAKm0C,8BAA8BzgB,EAAM+rE,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,OANpE/vD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MANS,KAWpB,KAAKq3C,EAAAC,MAAMoZ,YAET,IADA,IAAI1W,EAAqB,IAAI99C,OACrB0rG,EAAG71C,KAAK1a,EAAAC,MAAMqZ,eAAe,CACnC,GAAIi3C,EAAGn2C,QAAUpa,EAAAC,MAAMyM,MACrBloB,EAAO,UAGP,KADAA,EAAO5mC,KAAK+1G,gBAAgBpD,EAAI,IACrB,OAAO,KAGpB,GADA5tD,EAAmBr4C,KAAKk6B,IACnB+rE,EAAG71C,KAAK1a,EAAAC,MAAMyM,OAAQ,CACzB,GAAI6jD,EAAG71C,KAAK1a,EAAAC,MAAMqZ,cAChB,MAMA,OAJA17D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MAIb,OAAO4C,EAAAuF,KAAK2xC,6BAA6BE,EAAoB4tD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAGrF,KAAK3N,EAAAC,MAAMsZ,UAKT,IAJA,IAAI0/C,EAAW1I,EAAG54C,SACdhvB,EAAQ,IAAI9jC,MACZsW,EAAS,IAAItW,MACbrG,OAAI,GACA+xG,EAAG71C,KAAK1a,EAAAC,MAAMuZ,aAAa,CACjC,GAAK+2C,EAAG91C,iBAWNj8D,EAAO+M,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,aAXvC,CACxB,IAAK4nG,EAAG71C,KAAK1a,EAAAC,MAAMkY,eAKjB,OAJAv6D,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfrC,EAAG5nG,SAEE,MAETnK,EAAO+M,EAAAuF,KAAKE,2BAA2Bu/F,EAAG7+D,aAAc6+D,EAAG5nG,UACtD05C,UAAW,EAKlB,GADA1Z,EAAMr+B,KAAK9L,GACP+xG,EAAG71C,KAAK1a,EAAAC,MAAMgZ,OAAQ,CACxB,IAAI/5D,EAAQtB,KAAK+1G,gBAAgBpD,EAAI,GACrC,IAAKrxG,EAAO,OAAO,KACnBic,EAAO7Q,KAAKpL,OACP,IAAKV,EAAK6jD,SAOf,OAJAzkD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KANPwS,EAAO7Q,KAAK9L,GAQd,IAAK+xG,EAAG71C,KAAK1a,EAAAC,MAAMyM,OAAQ,CACzB,GAAI6jD,EAAG71C,KAAK1a,EAAAC,MAAMuZ,YAChB,MAMA,OAJA57D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MAIb,OAAO4C,EAAAuF,KAAKi0C,8BAA8Bpc,EAAOxtB,EAAQo1F,EAAG5nG,MAAMswG,EAAU1I,EAAG5iD,MAGjF,KAAK3N,EAAAC,MAAMkV,SACT,IAAIrS,EAASllD,KAAKy0G,UAAU9B,GAC5B,OAAKztD,EACAytD,EAAG71C,KAAK1a,EAAAC,MAAMmV,cAOnB5wB,EAAO5mC,KAAK+1G,gBAAgBpD,EAAE,KAEvBhlG,EAAAuF,KAAK8xC,0BACVr3C,EAAAghD,cAAcmwB,OACdl4C,EACAse,EACAytD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MALN,MAPhB/vD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MANW,KAiBtB,KAAKq3C,EAAAC,MAAMM,WACT,IAAI24D,EAAiB3I,EAAGt1C,iBACxB,GAAsB,QAAlBi+C,EAA0B,OAAO3tG,EAAAuF,KAAK+zC,qBAAqB0rD,EAAG5nG,SAClE,IAAIuI,EAAa3F,EAAAuF,KAAKE,2BAA2BkoG,EAAgB3I,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MACvF,OAAI4iD,EAAGn2C,MAAK,IAASpa,EAAAC,MAAMkZ,oBAAuBo3C,EAAGz4C,mBAiB9C5mD,EAhBEtT,KAAK83G,8BACVnF,EACAhlG,EAAAuF,KAAK0xC,gCAAgC+tD,EAAG5nG,MAAM8nG,IAC9C,CACEllG,EAAAuF,KAAK4wC,gBACHxwC,EACA3F,EAAAuF,KAAKM,kBAAkBF,EAAWvI,MAAM87D,OACxC,KACAl5D,EAAAogD,cAAc6H,QACdtiD,EAAWvI,QAEd,EAED8nG,GAKN,KAAKzwD,EAAAC,MAAMiN,KACT,OAAO3hD,EAAAuF,KAAKm1C,qBAAqBsqD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAEzD,KAAK3N,EAAAC,MAAMz/B,YACT,OAAOjV,EAAAuF,KAAK6yC,4BAA4B4sD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAEhE,KAAK3N,EAAAC,MAAMY,MAOT,OANI0vD,EAAGn2C,QAAUpa,EAAAC,MAAMwY,KAAO83C,EAAG34C,WAAa5X,EAAAC,MAAMoY,WAClDz6D,KAAKqN,MACHI,EAAAhD,eAAe8wG,6DACf5I,EAAG5nG,SAGA4C,EAAAuF,KAAKi1C,sBAAsBwqD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAE1D,KAAK3N,EAAAC,MAAMkY,cACT,OAAO5sD,EAAAuF,KAAK+0C,8BAA8B0qD,EAAG7+D,aAAc6+D,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAEnF,KAAK3N,EAAAC,MAAM+Y,eACT,OAAOztD,EAAAuF,KAAK2zC,+BAA+B8rD,EAAGz0C,cAAey0C,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAErF,KAAK3N,EAAAC,MAAMuY,aACT,OAAOjtD,EAAAuF,KAAKozC,6BAA6BqsD,EAAGpzC,YAAaozC,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAIjF,KAAK3N,EAAAC,MAAM4V,MACT,IAAIujD,EAAgB7I,EAAG90C,oBACvB,OAAK80C,EAAG71C,KAAK1a,EAAAC,MAAM4V,OAOZtqD,EAAAuF,KAAKu0C,8BACV+zD,EACA7I,EAAG30C,kBACH20C,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,OATtB/vD,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MAQX,KAAKq3C,EAAAC,MAAM1jC,SACT,OAAO3e,KAAK63G,wBAAwBlF,GAEtC,KAAKvwD,EAAAC,MAAMxjC,MACT,OAAO7e,KAAKk4G,qBAAqBvF,GAEnC,QAYE,OAXIx7C,GAAS/U,EAAAC,MAAMka,UACjBv8D,KAAKqN,MACHI,EAAAhD,eAAegzD,uBACfk1C,EAAG5nG,MAAM8nG,IAGX7yG,KAAKqN,MACHI,EAAAhD,eAAegxG,oBACf9I,EAAG5nG,SAGA,OAKbonG,EAAAlwG,UAAAy5G,qCAAA,SACE/I,GAKA,IAAI31C,EAAQ21C,EAAG51C,OACf,IAAK41C,EAAG71C,KAAK1a,EAAAC,MAAMkV,UAAW,OAAO,KACrC,IAAItrC,EAAmC,KACvC,EAAG,CACD,GAAI0mF,EAAGn2C,SAAWpa,EAAAC,MAAMmV,YACtB,MAEF,IAAIv4C,EAAOjf,KAAKy0G,UAAU9B,GAAI,GAAM,GACpC,IAAK1zF,EAEH,OADA0zF,EAAGv1C,MAAMJ,GACF,KAEJ/wC,EACAA,EAAcvf,KAAKuS,GADJgN,EAAgB,CAAEhN,SAE/B0zF,EAAG71C,KAAK1a,EAAAC,MAAMyM,QACvB,OAAI6jD,EAAG71C,KAAK1a,EAAAC,MAAMmV,cAAgBm7C,EAAG71C,KAAK1a,EAAAC,MAAMoY,WACvCxuC,GAET0mF,EAAGv1C,MAAMJ,GACF,OAGTm1C,EAAAlwG,UAAAwzG,eAAA,SACE9C,GAMA,IADA,IAAIzuD,EAAO,IAAIj9C,OACP0rG,EAAG71C,KAAK1a,EAAAC,MAAMqY,aAAa,CACjC,IAAI9zB,EAAO5mC,KAAK+1G,gBAAgBpD,EAAI,GACpC,IAAK/rE,EAAM,OAAO,KAElB,GADAsd,EAAKx3C,KAAKk6B,IACL+rE,EAAG71C,KAAK1a,EAAAC,MAAMyM,OAAQ,CACzB,GAAI6jD,EAAG71C,KAAK1a,EAAAC,MAAMqY,YAChB,MAMA,OAJA16D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,MAIb,OAAOm5C,GAGTiuD,EAAAlwG,UAAA8zG,gBAAA,SACEpD,EACAsI,QAAA,IAAAA,MAAA,GAEA7wG,OAAiB,GAAV6wG,GAEP,IAAIr0E,EAAO5mC,KAAKg7G,qBAAqBrI,GACrC,IAAK/rE,EAAM,OAAO,KAOlB,IAJA,IACIuwB,EAEAwkD,EAHA9I,GAFJjsE,EAAO5mC,KAAK47G,yBAAyBjJ,EAAI/rE,IAErB77B,MAAMqB,MAEtB6L,EAA0B,MAG3B0jG,EAAiBE,EAAoB1kD,EAAQw7C,EAAGn2C,UAAYy+C,GAC7D,CAEA,OADAtI,EAAG16F,OACKk/C,GAEN,KAAK/U,EAAAC,MAAMiT,GACT,IAAIpQ,EAASllD,KAAKy0G,UAAU9B,GAC5B,IAAKztD,EAAQ,OAAO,KACpBte,EAAOj5B,EAAAuF,KAAK8xC,0BACVr3C,EAAAghD,cAAc2G,GACd1uB,EACAse,EACAytD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAExB,MAEF,KAAK3N,EAAAC,MAAMsW,YACT/xB,EAAOj5B,EAAAuF,KAAK8xC,0BACVr3C,EAAAghD,cAAc4V,QACd39B,EACA,KACA+rE,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAExB,MAGF,KAAK3N,EAAAC,MAAM2M,WACT,IAAIrI,EAAS3mD,KAAKy0G,UAAU9B,GAC5B,IAAKhsD,EAAQ,OAAO,KACpB/f,EAAOj5B,EAAAuF,KAAKwzC,2BACV9f,EACA+f,EACAgsD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAExB,MAGF,KAAK3N,EAAAC,MAAMoZ,YAET,KADAxjD,EAAOjY,KAAK+1G,gBAAgBpD,IACjB,OAAO,KAClB,IAAKA,EAAG71C,KAAK1a,EAAAC,MAAMqZ,cAKjB,OAJA17D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAET67B,EAAOj5B,EAAAuF,KAAK+yC,8BACVrf,EACA3uB,EACA06F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAExB,MAGF,KAAK3N,EAAAC,MAAM8V,UACX,KAAK/V,EAAAC,MAAM+V,YAEPxxB,EAAKnwB,MAAQ9I,EAAA+I,SAASisC,YACtB/b,EAAKnwB,MAAQ9I,EAAA+I,SAASosC,eACtBlc,EAAKnwB,MAAQ9I,EAAA+I,SAASssC,gBAEtBhjD,KAAKqN,MACHI,EAAAhD,eAAe0wG,0FACfv0E,EAAK77B,OAGT67B,EAAOj5B,EAAAuF,KAAKu1C,6BACV0O,EACAvwB,EACA+rE,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAExB,MAGF,KAAK3N,EAAAC,MAAMmZ,SACT,IAAI1T,EAAS9nD,KAAK+1G,gBAAgBpD,GAClC,IAAK7qD,EAAQ,OAAO,KACpB,IAAK6qD,EAAG71C,KAAK1a,EAAAC,MAAMgZ,OAKjB,OAJAr7D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEP,KAET,IAAIg9C,EAAS/nD,KAAK+1G,gBAAgBpD,EAAIsI,EAAU,EAC5C,EACD,GAEH,IAAKlzD,EAAQ,OAAO,KACpBnhB,EAAOj5B,EAAAuF,KAAK20C,wBACVjhB,EACAkhB,EACAC,EACA4qD,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAExB,MAGF,KAAK3N,EAAAC,MAAMyM,MACT,IAAIgtD,EAA2B,CAAEl1E,GACjC,EAAG,CAED,KADAA,EAAO5mC,KAAK+1G,gBAAgBpD,EAAI,IACrB,OAAO,KAClBmJ,EAAWpvG,KAAKk6B,SACT+rE,EAAG71C,KAAK1a,EAAAC,MAAMyM,QACvBloB,EAAOj5B,EAAAuF,KAAK0yC,sBAAsBk2D,EAAYnJ,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MACpE,MAEF,QAGE,GAAIoH,GAAS/U,EAAAC,MAAMwY,IAAK,CACtB,GAAI83C,EAAG91C,iBACL5kD,EAAOtK,EAAAuF,KAAKE,2BAA2Bu/F,EAAGt1C,iBAAkBs1C,EAAG5nG,cAO/D,KALAkN,EAAOjY,KAAK+1G,gBAAgBpD,EAC1BoJ,EAAmB5kD,GACfwkD,EACAA,EAAiB,IAEZ,OAAO,KAEpB,GAAI1jG,EAAKxB,MAAQ9I,EAAA+I,SAASisC,WACxB/b,EAAOj5B,EAAAuF,KAAKq0C,+BACV3gB,EACsB3uB,EACtB06F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,UAEnB,IAAI93C,EAAKxB,MAAQ9I,EAAA+I,SAASmsC,KAQ/B,OAJA7iD,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACf/8F,EAAKlN,OAEA,KANP,KADA67B,EAAO5mC,KAAKg8G,iBAAiBrJ,EAAIE,EAAUjsE,EAAsB3uB,IACtD,OAAO,UAUf,CAML,KALAA,EAAOjY,KAAK+1G,gBAAgBpD,EAC1BoJ,EAAmB5kD,GACfwkD,EACAA,EAAiB,IAEZ,OAAO,KAClB/0E,EAAOj5B,EAAAuF,KAAKkyC,uBAAuB+R,EAAOvwB,EAAM3uB,EAAM06F,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,OAKlFnpB,EAAO5mC,KAAK47G,yBAAyBjJ,EAAI/rE,GAE3C,OAAOA,GAGDurE,EAAAlwG,UAAA+5G,iBAAR,SACErJ,EACAE,EACAjsE,EACApmC,GAEA,IAAIy7G,EAASz7G,EAAKwpC,WAClB,OAAQiyE,EAAOxlG,MACb,KAAK9I,EAAA+I,SAASisC,WACZniD,EAAKwpC,WAAar8B,EAAAuF,KAAKq0C,+BACrB3gB,EACsBq1E,EACtBtJ,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,MAExB,MAEF,KAAKpiD,EAAA+I,SAASmsC,KACZ,IAAIq5D,EAAQl8G,KAAKg8G,iBAAiBrJ,EAAIE,EAAUjsE,EAAsBq1E,GACtE,IAAKC,EAAO,OAAO,KACnB17G,EAAKwpC,WAAakyE,EAClB17G,EAAKuK,MAAQ4nG,EAAG5nG,MAAM8nG,EAAUF,EAAG5iD,KACnC,MAEF,QAKE,OAJA/vD,KAAKqN,MACHI,EAAAhD,eAAeuqG,oBACfx0G,EAAKuK,OAEA,KAGX,OAAOvK,GAGD2xG,EAAAlwG,UAAA25G,yBAAR,SACEjJ,EACA/rE,GAEA,GAAIj5B,EAAA+0C,eAAe9b,EAAKnwB,MAEtB,IADA,IAAIwV,EAAmC,KAErC0mF,EAAG71C,KAAK1a,EAAAC,MAAMoY,YAEd9sD,EAAAu1C,sBAAsBtc,EAAKnwB,OAA6E,QAAnEwV,EAAgBjsB,KAAK07G,qCAAqC/I,KAC/F,CACA,IAAIzuD,EAAOlkD,KAAKy1G,eAAe9C,GAC/B,IAAKzuD,EAAM,MACXtd,EAAOj5B,EAAAuF,KAAKqyC,qBACV3e,EACA3a,EACAi4B,EACAyuD,EAAG5nG,MAAM67B,EAAK77B,MAAMqB,MAAOumG,EAAG5iD,MAIpC,OAAOnpB,GAITurE,EAAAlwG,UAAA8wG,cAAA,SAAcJ,GAGZ,IAFAA,EAAGn2C,MAAK,GACJm2C,EAAGz4C,oBAAoBy4C,EAAG16F,SAC3B,CACD,IAAI+hD,EAAY24C,EAAGn2C,MAAK,GACxB,GACExC,GAAa5X,EAAAC,MAAMka,WACnBvC,GAAa5X,EAAAC,MAAMiZ,UACnB,CACAq3C,EAAG16F,OACH,MAEF,GAAI06F,EAAGz4C,mBAAoB,MAC3B,OAAQy4C,EAAG16F,QACT,KAAKmqC,EAAAC,MAAMM,WACTgwD,EAAGt1C,iBACH,MAEF,KAAKjb,EAAAC,MAAMkY,cACTo4C,EAAG7+D,aACH,MAEF,KAAKsO,EAAAC,MAAM+Y,eACTu3C,EAAGz0C,cACH,MAEF,KAAK9b,EAAAC,MAAMuY,aACT+3C,EAAGpzC,YACH,MAEF,KAAKnd,EAAAC,MAAMsZ,UACT37D,KAAKm8G,UAAUxJ,MAQvBR,EAAAlwG,UAAAk6G,UAAA,SAAUxJ,GAER,IAAIyJ,EAAQ,EACRhB,GAAQ,EACZ,GACE,OAAQzI,EAAG16F,QACT,KAAKmqC,EAAAC,MAAMka,UACTv8D,KAAKqN,MACHI,EAAAhD,eAAeywD,YACfy3C,EAAG5nG,QAAS,KAEdqwG,GAAQ,EACR,MAEF,KAAKh5D,EAAAC,MAAMsZ,YACPygD,EACF,MAEF,KAAKh6D,EAAAC,MAAMuZ,aACPwgD,IACUhB,GAAQ,GACpB,MAEF,KAAKh5D,EAAAC,MAAMM,WACTgwD,EAAGt1C,iBACH,MAEF,KAAKjb,EAAAC,MAAMkY,cACTo4C,EAAG7+D,aACH,MAEF,KAAKsO,EAAAC,MAAM+Y,eACTu3C,EAAGz0C,cACH,MAEF,KAAK9b,EAAAC,MAAMuY,aACT+3C,EAAGpzC,mBAIA67C,IAEbjJ,EA3tHA,CAA4B1kG,EAAAX,mBA2wH5B,SAAS+uG,EAAoBplG,GAC3B,OAAQA,GACN,KAAK2rC,EAAAC,MAAMyM,MAAO,SAClB,KAAK1M,EAAAC,MAAM0W,OACX,KAAK3W,EAAAC,MAAM2W,YACX,KAAK5W,EAAAC,MAAM4W,aACX,KAAK7W,EAAAC,MAAM8W,yBACX,KAAK/W,EAAAC,MAAM6W,gBACX,KAAK9W,EAAAC,MAAM+W,aACX,KAAKhX,EAAAC,MAAMgX,eACX,KAAKjX,EAAAC,MAAMiX,yBACX,KAAKlX,EAAAC,MAAMkX,+BACX,KAAKnX,EAAAC,MAAMmX,2CACX,KAAKpX,EAAAC,MAAMoX,iBACX,KAAKrX,EAAAC,MAAMsX,aACX,KAAKvX,EAAAC,MAAMqX,WAAY,SACvB,KAAKtX,EAAAC,MAAMmZ,SAAU,SACrB,KAAKpZ,EAAAC,MAAMyW,QAAS,SACpB,KAAK1W,EAAAC,MAAMwW,oBAAqB,SAChC,KAAKzW,EAAAC,MAAMoW,IAAK,SAChB,KAAKrW,EAAAC,MAAMqW,MAAO,SAClB,KAAKtW,EAAAC,MAAMmW,UAAW,UACtB,KAAKpW,EAAAC,MAAMsV,cACX,KAAKvV,EAAAC,MAAMuV,mBACX,KAAKxV,EAAAC,MAAMwV,qBACX,KAAKzV,EAAAC,MAAMyV,0BAA2B,UACtC,KAAK1V,EAAAC,MAAMiT,GACX,KAAKlT,EAAAC,MAAM8T,GACX,KAAK/T,EAAAC,MAAM2M,WACX,KAAK5M,EAAAC,MAAMkV,SACX,KAAKnV,EAAAC,MAAMmV,YACX,KAAKpV,EAAAC,MAAMoV,gBACX,KAAKrV,EAAAC,MAAMqV,mBAAoB,UAC/B,KAAKtV,EAAAC,MAAMgW,kBACX,KAAKjW,EAAAC,MAAMiW,wBACX,KAAKlW,EAAAC,MAAMkW,oCAAqC,UAChD,KAAKnW,EAAAC,MAAMjyC,KACX,KAAKgyC,EAAAC,MAAM/xC,MAAO,UAClB,KAAK8xC,EAAAC,MAAM2V,SACX,KAAK5V,EAAAC,MAAM4V,MACX,KAAK7V,EAAAC,MAAM6V,QAAS,UACpB,KAAK9V,EAAAC,MAAM0V,kBAAmB,UAC9B,KAAK3V,EAAAC,MAAM8V,UACX,KAAK/V,EAAAC,MAAM+V,YAAa,UACxB,KAAKhW,EAAAC,MAAMwY,IACX,KAAKzY,EAAAC,MAAM6M,IACX,KAAK9M,EAAAC,MAAMoZ,YACX,KAAKrZ,EAAAC,MAAMsW,YAAa,UAE1B,SAIF,SAASojD,EAAmBtlG,GAC1B,OAAQA,GACN,KAAK2rC,EAAAC,MAAM0W,OACX,KAAK3W,EAAAC,MAAM2W,YACX,KAAK5W,EAAAC,MAAM4W,aACX,KAAK7W,EAAAC,MAAM8W,yBACX,KAAK/W,EAAAC,MAAM6W,gBACX,KAAK9W,EAAAC,MAAM+W,aACX,KAAKhX,EAAAC,MAAMgX,eACX,KAAKjX,EAAAC,MAAMiX,yBACX,KAAKlX,EAAAC,MAAMkX,+BACX,KAAKnX,EAAAC,MAAMmX,2CACX,KAAKpX,EAAAC,MAAMoX,iBACX,KAAKrX,EAAAC,MAAMsX,aACX,KAAKvX,EAAAC,MAAMqX,WACX,KAAKtX,EAAAC,MAAMmZ,SACX,KAAKpZ,EAAAC,MAAM0V,kBAAmB,OAAO,EACrC,QAAS,OAAO,GAj1HPr4D,EAAAyyG,SA8tHb,SAAkBkK,GAChBA,IAAA,eACAA,IAAA,iBACAA,IAAA,mBACAA,IAAA,iBACAA,IAAA,2BACAA,IAAA,6BACAA,IAAA,2BACAA,IAAA,6BACAA,IAAA,2BACAA,IAAA,6BACAA,IAAA,8BACAA,IAAA,wBACAA,IAAA,4BACAA,IAAA,kBACAA,IAAA,wBACAA,IAAA,oCACAA,IAAA,kCACAA,IAAA,gCACAA,IAAA,kCACAA,IAAA,gBACAA,IAAA,gCACAA,IAAA,wBAtBF,CAAkB38G,EAAA28G,aAAA38G,EAAA28G,WAAU,2HClzH5Bl8G,EAAA,IACAA,EAAA,IACAA,EAAA,IACAA,EAAA,IAEA,IAAA0xD,EAAA1xD,EAAA,GAEA0xD,EAAAvtB,OAAOriC,UAAU8xC,OAAS,WAKxB,OAAOuoE,SAASC,WAAWv8G,KAAK8oB,KAAK0zF,aAAoC,IAG3E3qD,EAAAvtB,OAAOriC,UAAU+xC,QAAU,WACzB,OAAOsoE,SAASC,WAAWv8G,KAAK8oB,KAAK2zF,+BCxBvC,SAAAl9F,GAEA,MAAA+8F,EAAA/8F,EAAAm9F,UAAoCv8G,EAAQ,IAG5C,QAAAyB,KAFA2d,EAAA+8F,WAEAA,GACA16G,EAAAsoD,WAAA,cAAAtoD,EAAAsoD,WAAA,gBAAA3qC,EAAA3d,GAAA06G,EAAA16G,IAKA2d,EAAAo9F,kBAAAL,EAAAM,QACAr9F,EAAAs9F,cAAAP,EAAAQ,MACAv9F,EAAAw9F,cAAAT,EAAAU,SACAz9F,EAAA09F,QAAA,SAAAn1E,EAAA0V,GAAqC8+D,EAAAY,OAAAp1E,GAAA0V,GACrCj+B,EAAA49F,OAAA,SAAAr1E,GAA+B,OAAAw0E,EAAAY,OAAAp1E,qCCf/BnoC,EAAAD,QAAAO,oBCAA,SAAAsf,GAEA,IAAA69F,EAAA,oBAAAj9C,qBAAA,IAAA5gD,MAAAxf,KAEAq9G,EAAA73G,WAAA,EACA63G,EAAA33G,eAAA,EACA23G,EAAA13G,gBAAA,EACA03G,EAAAz3G,mBAAA,EACAy3G,EAAAx3G,iBAAA,EACAw3G,EAAAv3G,4BAAA,EACAu3G,EAAAt3G,4BAAA,EACAs3G,EAAAr3G,yBAAA,EACAq3G,EAAAp3G,kBAAA,EACAo3G,EAAAn3G,qBAAA,EAEA,IAAAa,EAAA,IAAAqB,aAAA,GACAzB,EAAA,IAAAsB,YAAAlB,EAAA2L,QA2IA,SAAA4qG,IACAjhG,MAAAkhG,kBACAlhG,MAAAkhG,kBAAAt9G,KAAAq9G,GAEAr9G,KAAA4pE,MAAA5pE,KAAAY,KAAA,KAAAZ,KAAA8K,QAAA,UAAAsR,OAAAwtD,MAWA,SAAA2zC,EAAAzyG,GACA9K,KAAA8K,WAAA,mBACAsR,MAAAkhG,kBACAlhG,MAAAkhG,kBAAAt9G,KAAAu9G,GAEAv9G,KAAA4pE,MAAA5pE,KAAAY,KAAA,KAAAZ,KAAA8K,QAAA,UAAAsR,OAAAwtD,MA7JA7oE,OAAAy8G,iBACAJ,EAAA,YAAA97G,GAA0C,OAAAA,GAAA,QAC1C,CACA0sE,UAAA,CAAgB1sE,OAAA,IAAAm8G,UAAA,GAChBhpE,UAAA,CAAgBnzC,MAAA,IAAAm8G,UAAA,KAGhB18G,OAAAy8G,iBACAJ,EAAA,aAAA97G,GAA4C,OAAAA,GAAA,QAC5C,CACA0sE,UAAA,CAAgB1sE,OAAA,MAAAm8G,UAAA,GAChBhpE,UAAA,CAAgBnzC,MAAA,MAAAm8G,UAAA,KAGhB18G,OAAAy8G,iBACAJ,EAAA,IAAAA,EAAA,eAAA97G,GAAmE,SAAAA,GACnE,CACA0sE,UAAA,CAAgB1sE,OAAA,WAAAm8G,UAAA,GAChBhpE,UAAA,CAAgBnzC,MAAA,WAAAm8G,UAAA,KAGhB18G,OAAAy8G,iBACAJ,EAAA,YAAA97G,GAA0C,WAAAA,GAC1C,CACA0sE,UAAA,CAAgB1sE,MAAA,EAAAm8G,UAAA,GAChBhpE,UAAA,CAAgBnzC,MAAA,IAAAm8G,UAAA,KAGhB18G,OAAAy8G,iBACAJ,EAAA,aAAA97G,GAA4C,aAAAA,GAC5C,CACA0sE,UAAA,CAAgB1sE,MAAA,EAAAm8G,UAAA,GAChBhpE,UAAA,CAAgBnzC,MAAA,MAAAm8G,UAAA,KAGhB18G,OAAAy8G,iBACAJ,EAAA,IAAAA,EAAA,eAAA97G,GAAmE,OAAAA,IAAA,GACnE,CACA0sE,UAAA,CAAgB1sE,MAAA,EAAAm8G,UAAA,GAChBhpE,UAAA,CAAgBnzC,MAAA,WAAAm8G,UAAA,KAGhB18G,OAAAy8G,iBACAJ,EAAA,cAAA97G,GAA8C,QAAAA,GAC9C,CACA0sE,UAAA,CAAgB1sE,OAAA,EAAAm8G,UAAA,GAChBhpE,UAAA,CAAgBnzC,OAAA,EAAAm8G,UAAA,KAGhB18G,OAAAy8G,iBACAJ,EAAA,aAAA97G,GAA4C,OAAAiG,KAAAm2G,OAAAp8G,IAC5C,CACAq8G,QAAA,CAAgBr8G,MAAAiG,KAAAm2G,OAAA,cAAAD,UAAA,GAChBzvC,UAAA,CAAgB1sE,MAAAiG,KAAAm2G,OAAA,eAAAD,UAAA,GAChBhpE,UAAA,CAAgBnzC,MAAAiG,KAAAm2G,OAAA,cAAAD,UAAA,GAChBG,iBAAA,CAAwBt8G,MAAAiG,KAAAm2G,OAAA,gBAAAD,UAAA,GACxBI,iBAAA,CAAwBv8G,OAAA,SAAAm8G,UAAA,GACxBK,iBAAA,CAAwBx8G,MAAA,SAAAm8G,UAAA,KAGxB18G,OAAAy8G,iBACAJ,EAAA,aAAA97G,GAA4C,OAAAA,GAC5C,CACAq8G,QAAA,CAAgBr8G,MAAA,sBAAAm8G,UAAA,GAChBzvC,UAAA,CAAgB1sE,MAAA,OAAAm8G,UAAA,GAChBhpE,UAAA,CAAgBnzC,MAAA,uBAAAm8G,UAAA,GAChBG,iBAAA,CAAwBt8G,MAAA,wBAAAm8G,UAAA,GACxBI,iBAAA,CAAwBv8G,OAAA,iBAAAm8G,UAAA,GACxBK,iBAAA,CAAwBx8G,MAAA,iBAAAm8G,UAAA,KAGxBL,EAAA,IAAA71G,KAAAw2G,MAEAX,EAAA,aAAA97G,GACA,IAAAZ,EAAA6G,KAAAw2G,MAAAz8G,MACA,OAAAA,EAAA,GAAAZ,KAGA08G,EAAA,gBAAA97G,GAGA,kBADAA,GAAA,WADAA,OAAA,gBACAA,IAAA,eACAA,IAAA,oBAGA87G,EAAA,cAAA97G,EAAAyrC,GAEA,OAAAzrC,IADAyrC,GAAA,IACAzrC,IAAA,GAAAyrC,GAGAqwE,EAAA,cAAA97G,EAAAyrC,GAEA,OAAAzrC,KADAyrC,GAAA,IACAzrC,GAAA,GAAAyrC,GAGAqwE,EAAA,IAAA71G,KAAA0mF,IAEAmvB,EAAA,IAAA71G,KAAAojE,IAEAyyC,EAAA,IAAA71G,KAAAonF,IAEAyuB,EAAA,KAAA71G,KAAA4qD,KAEAirD,EAAA,MAAA71G,KAAAunF,MAGAsuB,EAAA,iBAAA97G,GACA,WAAAiG,KAAA0mF,IAAA3sF,EAAAiG,KAAA0oF,MAAA3uF,IACA,EAAAiG,KAAAy2G,MAAA,GAAA18G,GAEAiG,KAAAy2G,MAAA18G,IAGA87G,EAAA,gBAAA/yE,EAAAC,EAAAT,GACA,OAAAA,EAAAQ,EAAAC,GAGA8yE,EAAA,KAAA71G,KAAAuoF,KAEAstB,EAAA,MAAA71G,KAAA0oF,MAEAmtB,EAAA,kBAAA1zG,EAAAu0G,GACA,OAAA12G,KAAA0mF,IAAAvkF,GAAAnC,KAAA22G,KAAAD,IAGAb,EAAA,eAAA97G,GACA,IAAAs4D,EAAAt4D,GAAA,WACAu4D,GAAA,SAAAv4D,IAAA,EAIA,OAFAs4D,GADAt4D,EAAAs4D,EAAAC,IACA,WACAA,GAAA,MAAAv4D,IAAA,KAIA87G,EAAA,iBAAA97G,GACA,OAAAA,GAAA,QAAAA,GAAA,iBAAAA,GAUA+7G,EAAAp7G,UAAAlB,OAAAY,OAAAya,MAAAna,WACAo7G,EAAAp7G,UAAArB,KAAA,mBACAy8G,EAAAp7G,UAAA6I,QAAA,cAEAsyG,EAAA,uBACA,UAAAC,GAWAE,EAAAt7G,UAAAlB,OAAAY,OAAAya,MAAAna,WACAs7G,EAAAt7G,UAAArB,KAAA,iBAEAw8G,EAAA,gBAAAe,EAAArzG,GACA,GAAAqzG,EAAA,OAAAA,EACA,UAAAZ,EAAAzyG,IAGAsyG,EAAA,oBAAA97G,GACA,OAAAA,GAGA0F,OAAA,uBAAAi3C,GACA,OAAAj3C,OAAA42D,aAAA33C,MAAAjf,OAAAi3C,IAGAj3C,OAAA,wBAAAi3C,GACA,OAAAj3C,OAAAo3G,cAAAn4F,MAAAjf,OAAAi3C,IAGAj3C,OAAA/E,UAAAo8G,YACAt9G,OAAAC,eAAAgG,OAAA/E,UAAA,cACAX,MAAA,SAAAg9G,EAAAC,GACA,IAAAC,EAAAx+G,KAAAy+G,MAAAH,GAAA3xG,KAAA4xG,GAEA,OADAD,EAAAnyG,SAAAqyG,EAAAD,EAAAC,EAAAD,GACAC,KAKApB,EAAA,UAAAsB,OAAA1yB,UAEAoxB,EAAA,iBAAA3uG,GACA,uBAAAA,GAGA2uG,EAAA,oBAAA3uG,GACA,UAGA2uG,EAAA,qBAAA3uG,GACA,uBAAAA,GAAA,iBAAAA,GAGA2uG,EAAA,oBAAA3uG,GACA,yBAAAA,GAGA2uG,EAAA,kBAAA3uG,GACA,uBAAAA,gBAAAzH,QAGAo2G,EAAA,QAAAn2G,MAAAslF,QACA6wB,EAAA,qBAAAx2E,GACA,OAAAA,GACA,iBAAAA,GACA,iBAAAA,EAAAz6B,QACAy6B,EAAAz6B,QAAA,GACA5E,KAAA0oF,MAAArpD,EAAAz6B,UAAAy6B,EAAAz6B,QAGAlF,MAAAtF,OAAA,SAAAg9G,GACA,IAAA1gE,EAAA,IAAAh3C,MAAA03G,GAEA,OADA1gE,EAAA9xC,OAAA,EACA8xC,GAGAm/D,EAAA,mBAAAx2E,GACA,gBAAAA,GAGAw2E,EAAA,oBAAAx2E,GACA,UAGAw2E,EAAA,mBAAAx2E,GACA,OAAAA,GAGAw2E,EAAA,cAAA1zG,EAAAu0G,GACA,OAAAv0G,EAAAu0G,GAGAb,EAAA,eAAA1zG,EAAAu0G,GACA,OAAA12G,KAAAm2G,OAAAh0G,EAAAu0G,IAGAb,EAAA,OAAA71G,KAEAxG,OAAAy8G,iBAAAJ,EAAA,QACAwB,WAAA,CAAet9G,MAAA,EAAAm8G,UAAA,GACfoB,WAAA,CAAev9G,MAAA,EAAAm8G,UAAA,GACfqB,QAAA,CACAx9G,MAAA,SAAAoI,GACiB,OAAjB5C,EAAA,GAAA4C,EAAiBq1G,QAAAr4G,EAAA,QAAAgD,QAGjBs1G,OAAA,CACA19G,MAAA,SAAAoI,GACA1J,KAAA4+G,WAAAr3G,KAAA03G,IAAAv1G,GACA1J,KAAA6+G,WAAAt3G,KAAA23G,IAAAx1G,OAKA0zG,EAAA,aACA,IAAA+B,EAAA,IAAAt3G,WAAA,GACAu3G,EAAA,EACA,OACAv6E,SAAAu4E,EAAA,4BAAAxxE,GACA,KAAAA,KAAA,YACA,GAAAwzE,EAAAxzE,EAAAuzE,EAAAhzG,OAAA,CACA,IAAAkzG,EAAAF,GACAA,EAAA,IAAAt3G,WAAAN,KAAAojE,IAAA,MAAAw0C,EAAAhzG,OAAAy/B,EAAA,EAAAuzE,EAAAhzG,UACAgG,IAAAktG,GAEA,IAAAv3E,EAAAs3E,EAEA,OADA,GAAAA,GAAAxzE,KAAAwzE,EAAA,KAAAA,IACAt3E,GAEAw3E,KAAAlC,EAAA,wBAAAnuF,EAAA3tB,EAAAsqC,GACAuzE,EAAAG,KAAAh+G,EAAA2tB,IAAA2c,IAEAnjC,KAAA20G,EAAA,wBAAAt1E,KACAy3E,KAAAnC,EAAA,wBAAAnuF,EAAAD,EAAA4c,GACAuzE,EAAAK,WAAAvwF,EAAAD,IAAA4c,IAEAwxB,MAAAggD,EAAA,2BACA+B,EAAA,IAAAt3G,WAAA,GACAu3G,EAAA,KAxBA,GA6BAhC,EAAA,MAAAA,EAAA,kBAAAt1E,EAAAxmC,EAAAoR,GACAysG,MAAA,EAAAr3E,IAAA,EAAAp1B,IAAApR,GAGA87G,EAAA,KAAAA,EAAA,iBAAAt1E,EAAAp1B,GACA,OAAAysG,MAAA,EAAAr3E,IAAA,EAAAp1B,KAGA0qG,EAAA,2DChUA,SAAA79F,GAAA,MAAAzY,EAAA,IAAAqB,aAAA,GACAtB,EAAA,IAAAqB,aAAApB,EAAA2L,QACArM,EAAA,IAAAuB,WAAAb,EAAA2L,QAEA8M,EAAAkgG,WAAA,SAAAn+G,GAEA,OADAuF,EAAA,GAAAvF,EACA8E,EAAA,IAGAmZ,EAAAmgG,WAAA,SAAAp+G,GAEA,OADA8E,EAAA,GAAA9E,EACAuF,EAAA,IAGA0Y,EAAAogG,WAAA,SAAAr+G,GAEA,OADAwF,EAAA,GAAAxF,EACAiU,QAAAnP,EAAA,GAAAA,EAAA,KAGAmZ,EAAAqgG,WAAA,SAAAt+G,GAGA,OAFA8E,EAAA,GAAA8pC,QAAA5uC,GACA8E,EAAA,GAAA+pC,SAAA7uC,GACAwF,EAAA,wCCtBA,SAAAyY,GAAA,MAAAsgG,EAAAtgG,EAAAsgG,MAA4B1/G,EAAQ,IAEpCof,EAAAklD,SAAAo7C,EAAAC,KAEAvgG,EAAAwgG,QAAAF,EAAAG,IAEAzgG,EAAAhK,QAAA,SAAA0qG,EAAAC,GACA,OAAAL,EAAAM,SAAAF,EAAAC,IAGA3gG,EAAA2wB,QAAA,SAAA5uC,GACA,OAAAA,EAAA8+G,KAGA7gG,EAAA4wB,SAAA,SAAA7uC,GACA,OAAAA,EAAA++G,MAGA9gG,EAAAo/C,QAAA,SAAA53B,EAAAC,GACA,OAAAD,EAAA/xB,IAAAgyB,IAGAznB,EAAAilD,QAAA,SAAAz9B,EAAAC,GACA,OAAAD,EAAAu5E,IAAAt5E,IAGAznB,EAAA0/C,QAAA,SAAAl4B,EAAAC,GACA,OAAAD,EAAAw5E,IAAAv5E,IAGAznB,EAAAihG,QAAA,SAAAz5E,EAAAC,GACA,OAAAD,EAAA05E,IAAAz5E,IAGAznB,EAAAmhG,UAAA,SAAA35E,EAAAC,GACA,OAAAD,EAAA45E,aAAAF,IAAAz5E,EAAA25E,cAAAC,YAGArhG,EAAAshG,QAAA,SAAA95E,EAAAC,GACA,OAAAD,EAAAz+B,IAAA0+B,IAGAznB,EAAAuhG,UAAA,SAAA/5E,EAAAC,GACA,OAAAD,EAAA45E,aAAAr4G,IAAA0+B,EAAA25E,cAAAC,YAGArhG,EAAAwhG,QAAA,SAAAh6E,EAAAC,GACA,OAAAD,EAAAi6E,IAAAh6E,IAGAznB,EAAA0hG,OAAA,SAAAl6E,EAAAC,GACA,OAAAD,EAAAm6E,GAAAl6E,IAGAznB,EAAA4hG,QAAA,SAAAp6E,EAAAC,GACA,OAAAD,EAAAq6E,IAAAp6E,IAGAznB,EAAAq/C,QAAA,SAAA73B,EAAAC,GACA,OAAAD,EAAAs6E,IAAAr6E,IAGAznB,EAAA+hG,QAAA,SAAAv6E,EAAAC,GACA,OAAAD,EAAAw6E,IAAAv6E,IAGAznB,EAAAoyD,UAAA,SAAA5qC,EAAAC,GACA,OAAAD,EAAAy6E,KAAAx6E,IAGAznB,EAAAkiG,QAAA,SAAAngH,GACA,OAAAA,EAAAogH,OAGAniG,EAAAoiG,OAAA,SAAA56E,EAAAC,GACA,OAAAD,EAAA66E,GAAA56E,IAGAznB,EAAAsiG,OAAA,SAAA96E,EAAAC,GACA,OAAAD,EAAA+6E,GAAA96E,IAGAznB,EAAAkyD,UAAA,SAAAnwE,EAAAy1E,GACA3sE,OAAA2sE,GAAA,IAAAA,IAAA,IACA,IAAAtqC,EAAAozE,EAAAkC,QAAAhrC,EAAA,GACA,OAAAz1E,EAAA0T,IAAAy3B,GAAAu0E,IAAAv0E,EAAAi1E,QAGAniG,EAAAgkD,UAAA,SAAAjiE,GACA,WAAAA,EAAA++G,MAAA/+G,EAAA8+G,KAAA,GAAA9+G,EAAA8+G,KAAAl9G,GAAAuxC,YACA,IAAAnzC,EAAA++G,MAAA/+G,EAAA8+G,KAAAl9G,GAAA8qE,WAAA1sE,EAAA8+G,IAAA,GAGA7gG,EAAAkkD,WAAA,SAAAniE,GACA,WAAAA,EAAA++G,MAAA/+G,EAAA8+G,KAAA,GAAA9+G,EAAA8+G,KAAAj9G,IAAAsxC,YACA,IAAAnzC,EAAA++G,MAAA/+G,EAAA8+G,KAAAj9G,IAAA6qE,WAAA1sE,EAAA8+G,IAAA,GAGA7gG,EAAAokD,WAAA,SAAAriE,GACA,WAAAA,EAAA++G,MAAA/+G,EAAA8+G,KAAA,IACA,IAAA9+G,EAAA++G,MAAA/+G,EAAA8+G,IAAA,GAGA7gG,EAAAikD,UAAA,SAAAliE,GACA,WAAAA,EAAA++G,MAAA/+G,EAAA8+G,KAAA,GAAA9+G,EAAA8+G,KAAA78G,GAAAkxC,WAGAl1B,EAAAmkD,WAAA,SAAApiE,GACA,WAAAA,EAAA++G,MAAA/+G,EAAA8+G,KAAA,GAAA9+G,EAAA8+G,KAAA58G,IAAAixC,WAGAl1B,EAAAqkD,WAAA,SAAAtiE,GACA,WAAAA,EAAA++G,MAGA9gG,EAAAskD,YAAA,SAAAviE,GACA,WAAAA,EAAA++G,OAAA,IAAA/+G,EAAA8+G,KAAA,IAAA9+G,EAAA8+G,MAGA,MAAA4B,EAAAnC,EAAAoC,WAAAp+G,IAAAg6G,kBACAqE,EAAArC,EAAAoC,WAAAp+G,IAAAi6G,kBAEAv+F,EAAA4iG,WAAA,SAAA7gH,GACA,OAAAA,EAAA8gH,IAAAJ,IAAA1gH,EAAA+gH,IAAAH,IAGA,MAAAI,EAAAzC,EAAAoC,WAAAn+G,IAAA+5G,kBACA0E,EAAA1C,EAAAoC,WAAAn+G,IAAAg6G,kBAEAv+F,EAAAijG,WAAA,SAAAlhH,GACA,OAAAA,EAAA8gH,IAAAE,IAAAhhH,EAAA+gH,IAAAE,IAGAhjG,EAAAypE,WAAA,SAAA1nF,GACA,OAAAie,EAAAhY,KAAAm2G,OAAAp8G,EAAAmhH,aAGAljG,EAAA0pE,WAAA,SAAA3nF,GACA,OAAAA,EAAAmhH,YAGAljG,EAAAuwF,cAAA,SAAAxuG,EAAAohH,GACA,OAAAA,EAAAphH,EAAAq/G,aAAAr/G,GAAAoK,SAAA,sCC9IA/L,EAAAD,QAAAmgH,EAKA,IAAA8C,EAAA,KAEA,IACAA,EAAA,IAAAC,YAAAC,SAAA,IAAAD,YAAAt+E,OAAA,IAAAz8B,WAAA,CACA,m2BACA,IAASnI,QACR,MAAAwgE,IAcD,SAAA2/C,EAAAO,EAAAC,EAAAqC,GAMA1iH,KAAAogH,IAAA,EAAAA,EAMApgH,KAAAqgH,KAAA,EAAAA,EAMArgH,KAAA0iH,aAoCA,SAAAI,EAAAC,GACA,YAAAA,KAAA,YAXAlD,EAAA59G,UAAA+gH,WAEAjiH,OAAAC,eAAA6+G,EAAA59G,UAAA,cAAqDX,OAAA,IAkBrDu+G,EAAAiD,SAOA,IAAAG,EAAA,GAOAC,EAAA,GAQA,SAAAnB,EAAAzgH,EAAAohH,GACA,IAAAK,EAAAI,EAAAC,EACA,OAAAV,GAEAU,EAAA,IADA9hH,KAAA,IACAA,EAAA,OACA6hH,EAAAD,EAAA5hH,IAEA6hH,GAEAJ,EAAA5C,EAAA7+G,GAAA,EAAAA,GAAA,WACA8hH,IACAF,EAAA5hH,GAAAyhH,GACAA,IAGAK,GAAA,MADA9hH,GAAA,IACAA,EAAA,OACA6hH,EAAAF,EAAA3hH,IAEA6hH,GAEAJ,EAAA5C,EAAA7+G,IAAA,WACA8hH,IACAH,EAAA3hH,GAAAyhH,GACAA,GAmBA,SAAAd,EAAA3gH,EAAAohH,GACA,GAAAW,MAAA/hH,GACA,OAAAohH,EAAAY,EAAAxD,EACA,GAAA4C,EAAA,CACA,GAAAphH,EAAA,EACA,OAAAgiH,EACA,GAAAhiH,GAAAiiH,EACA,OAAAC,MACK,CACL,GAAAliH,IAAAmiH,EACA,OAAAz1C,EACA,GAAA1sE,EAAA,GAAAmiH,EACA,OAAAhvE,EAEA,OAAAnzC,EAAA,EACA2gH,GAAA3gH,EAAAohH,GAAAgB,MACAvD,EAAA7+G,EAAAqiH,EAAA,EAAAriH,EAAAqiH,EAAA,EAAAjB,GAmBA,SAAAvC,EAAAyD,EAAAC,EAAAnB,GACA,WAAA7C,EAAA+D,EAAAC,EAAAnB,GA5CA7C,EAAAkC,UAkCAlC,EAAAoC,aAsBApC,EAAAM,WASA,IAAA2D,EAAAv8G,KAAAc,IASA,SAAA07G,EAAA9vE,EAAAyuE,EAAAsB,GACA,OAAA/vE,EAAA9nC,OACA,MAAAiQ,MAAA,gBACA,WAAA63B,GAAA,aAAAA,GAAA,cAAAA,GAAA,cAAAA,EACA,OAAA6rE,EASA,GARA,iBAAA4C,GAEAsB,EAAAtB,EACAA,GAAA,GAEAA,OAEAsB,KAAA,IACA,MAAAA,EACA,MAAAC,WAAA,SAEA,IAAA9hH,EACA,IAAAA,EAAA8xC,EAAAy+D,QAAA,QACA,MAAAt2F,MAAA,mBACA,OAAAja,EACA,OAAA4hH,EAAA9vE,EAAAxnC,UAAA,GAAAi2G,EAAAsB,GAAAN,MAQA,IAHA,IAAAQ,EAAAjC,EAAA6B,EAAAE,EAAA,IAEA3+E,EAAAy6E,EACAz/G,EAAA,EAAmBA,EAAA4zC,EAAA9nC,OAAgB9L,GAAA,GACnC,IAAAurC,EAAArkC,KAAAonF,IAAA,EAAA16C,EAAA9nC,OAAA9L,GACAiB,EAAA6a,SAAA83B,EAAAxnC,UAAApM,IAAAurC,GAAAo4E,GACA,GAAAp4E,EAAA,GACA,IAAAu4E,EAAAlC,EAAA6B,EAAAE,EAAAp4E,IACAvG,IAAAk7E,IAAA4D,GAAAnvG,IAAAitG,EAAA3gH,SAGA+jC,GADAA,IAAAk7E,IAAA2D,IACAlvG,IAAAitG,EAAA3gH,IAIA,OADA+jC,EAAAq9E,WACAr9E,EAoBA,SAAA++E,EAAA5mE,EAAAklE,GACA,uBAAAllE,EACAykE,EAAAzkE,EAAAklE,GACA,iBAAAllE,EACAumE,EAAAvmE,EAAAklE,GAEAvC,EAAA3iE,EAAA4iE,IAAA5iE,EAAA6iE,KAAA,kBAAAqC,IAAAllE,EAAAklE,UAfA7C,EAAAkE,aAyBAlE,EAAAuE,YAUA,IAcAT,EAAAU,WAOAd,EAAAI,IAOAF,EAAAF,EAAA,EAOAe,EAAAvC,EA5BA,OAkCAjC,EAAAiC,EAAA,GAMAlC,EAAAC,OAMA,IAAAwD,EAAAvB,EAAA,MAMAlC,EAAAyD,QAMA,IAAAtD,EAAA+B,EAAA,GAMAlC,EAAAG,MAMA,IAAAuE,EAAAxC,EAAA,MAMAlC,EAAA0E,OAMA,IAAAC,EAAAzC,GAAA,GAMAlC,EAAA2E,UAMA,IAAA/vE,EAAA0rE,GAAA,iBAMAN,EAAAprE,YAMA,IAAA+uE,EAAArD,GAAA,SAMAN,EAAA2D,qBAMA,IAAAx1C,EAAAmyC,EAAA,kBAMAN,EAAA7xC,YAMA,IAAAy2C,EAAA5E,EAAA59G,UAMAwiH,EAAAC,MAAA,WACA,OAAA1kH,KAAA0iH,SAAA1iH,KAAAogH,MAAA,EAAApgH,KAAAogH,KAOAqE,EAAAhC,SAAA,WACA,OAAAziH,KAAA0iH,UACA1iH,KAAAqgH,OAAA,GAAAsD,GAAA3jH,KAAAogH,MAAA,GACApgH,KAAAqgH,KAAAsD,GAAA3jH,KAAAogH,MAAA,IAUAqE,EAAA/4G,SAAA,SAAAs4G,GAEA,IADAA,KAAA,IACA,MAAAA,EACA,MAAAC,WAAA,SACA,GAAAjkH,KAAA2kH,SACA,UACA,GAAA3kH,KAAA4kH,aAAA,CACA,GAAA5kH,KAAA4hH,GAAA5zC,GAAA,CAGA,IAAA62C,EAAA5C,EAAA+B,GACAvD,EAAAzgH,KAAAygH,IAAAoE,GACAC,EAAArE,EAAAF,IAAAsE,GAAAvE,IAAAtgH,MACA,OAAAygH,EAAA/0G,SAAAs4G,GAAAc,EAAAJ,QAAAh5G,SAAAs4G,GAEA,UAAAhkH,KAAA0jH,MAAAh4G,SAAAs4G,GAQA,IAHA,IAAAE,EAAAjC,EAAA6B,EAAAE,EAAA,GAAAhkH,KAAA0iH,UACAqC,EAAA/kH,KACAqlC,EAAA,KACA,CACA,IAAA2/E,EAAAD,EAAAtE,IAAAyD,GAEAe,GADAF,EAAAzE,IAAA0E,EAAAzE,IAAA2D,IAAAQ,UAAA,GACAh5G,SAAAs4G,GAEA,IADAe,EAAAC,GACAL,SACA,OAAAM,EAAA5/E,EAEA,KAAA4/E,EAAA94G,OAAA,GACA84G,EAAA,IAAAA,EACA5/E,EAAA,GAAA4/E,EAAA5/E,IASAo/E,EAAAS,YAAA,WACA,OAAAllH,KAAAqgH,MAOAoE,EAAAU,oBAAA,WACA,OAAAnlH,KAAAqgH,OAAA,GAOAoE,EAAAW,WAAA,WACA,OAAAplH,KAAAogH,KAOAqE,EAAAY,mBAAA,WACA,OAAArlH,KAAAogH,MAAA,GAOAqE,EAAAa,cAAA,WACA,GAAAtlH,KAAA4kH,aACA,OAAA5kH,KAAA4hH,GAAA5zC,GAAA,GAAAhuE,KAAA0jH,MAAA4B,gBAEA,IADA,IAAA9nE,EAAA,GAAAx9C,KAAAqgH,KAAArgH,KAAAqgH,KAAArgH,KAAAogH,IACAmF,EAAA,GAAsBA,EAAA,GACtB,IAAA/nE,EAAA,GAAA+nE,GAD+BA,KAG/B,UAAAvlH,KAAAqgH,KAAAkF,EAAA,GAAAA,EAAA,GAOAd,EAAAE,OAAA,WACA,WAAA3kH,KAAAqgH,MAAA,IAAArgH,KAAAogH,KAOAqE,EAAAe,IAAAf,EAAAE,OAMAF,EAAAG,WAAA,WACA,OAAA5kH,KAAA0iH,UAAA1iH,KAAAqgH,KAAA,GAOAoE,EAAAgB,WAAA,WACA,OAAAzlH,KAAA0iH,UAAA1iH,KAAAqgH,MAAA,GAOAoE,EAAAiB,MAAA,WACA,aAAA1lH,KAAAogH,MAOAqE,EAAAkB,OAAA,WACA,aAAA3lH,KAAAogH,MAQAqE,EAAAmB,OAAA,SAAAn3F,GAGA,OAFAq0F,EAAAr0F,KACAA,EAAA21F,EAAA31F,KACAzuB,KAAA0iH,WAAAj0F,EAAAi0F,UAAA1iH,KAAAqgH,OAAA,OAAA5xF,EAAA4xF,OAAA,SAEArgH,KAAAqgH,OAAA5xF,EAAA4xF,MAAArgH,KAAAogH,MAAA3xF,EAAA2xF,MASAqE,EAAA7C,GAAA6C,EAAAmB,OAOAnB,EAAAoB,UAAA,SAAAp3F,GACA,OAAAzuB,KAAA4hH,GAAAnzF,IASAg2F,EAAAqB,IAAArB,EAAAoB,UAQApB,EAAA3C,GAAA2C,EAAAoB,UAOApB,EAAAsB,SAAA,SAAAt3F,GACA,OAAAzuB,KAAAgmH,KAAAv3F,GAAA,GASAg2F,EAAAwB,GAAAxB,EAAAsB,SAOAtB,EAAAyB,gBAAA,SAAAz3F,GACA,OAAAzuB,KAAAgmH,KAAAv3F,IAAA,GASAg2F,EAAApC,IAAAoC,EAAAyB,gBAQAzB,EAAA0B,GAAA1B,EAAAyB,gBAOAzB,EAAA2B,YAAA,SAAA33F,GACA,OAAAzuB,KAAAgmH,KAAAv3F,GAAA,GASAg2F,EAAA4B,GAAA5B,EAAA2B,YAOA3B,EAAA6B,mBAAA,SAAA73F,GACA,OAAAzuB,KAAAgmH,KAAAv3F,IAAA,GASAg2F,EAAArC,IAAAqC,EAAA6B,mBAQA7B,EAAA8B,GAAA9B,EAAA6B,mBAQA7B,EAAA+B,QAAA,SAAA/3F,GAGA,GAFAq0F,EAAAr0F,KACAA,EAAA21F,EAAA31F,IACAzuB,KAAA4hH,GAAAnzF,GACA,SACA,IAAAg4F,EAAAzmH,KAAA4kH,aACA8B,EAAAj4F,EAAAm2F,aACA,OAAA6B,IAAAC,GACA,GACAD,GAAAC,EACA,EAEA1mH,KAAA0iH,SAGAj0F,EAAA4xF,OAAA,EAAArgH,KAAAqgH,OAAA,GAAA5xF,EAAA4xF,OAAArgH,KAAAqgH,MAAA5xF,EAAA2xF,MAAA,EAAApgH,KAAAogH,MAAA,OAFApgH,KAAAsgH,IAAA7xF,GAAAm2F,cAAA,KAYAH,EAAAuB,KAAAvB,EAAA+B,QAMA/B,EAAAkC,OAAA,WACA,OAAA3mH,KAAA0iH,UAAA1iH,KAAA4hH,GAAA5zC,GACAA,EACAhuE,KAAA0hH,MAAA1sG,IAAAgrG,IAQAyE,EAAAf,IAAAe,EAAAkC,OAOAlC,EAAAzvG,IAAA,SAAA4xG,GACA9D,EAAA8D,KACAA,EAAAxC,EAAAwC,IAIA,IAAAC,EAAA7mH,KAAAqgH,OAAA,GACAyG,EAAA,MAAA9mH,KAAAqgH,KACA0G,EAAA/mH,KAAAogH,MAAA,GACA4G,EAAA,MAAAhnH,KAAAogH,IAEA6G,EAAAL,EAAAvG,OAAA,GACA6G,EAAA,MAAAN,EAAAvG,KACA8G,EAAAP,EAAAxG,MAAA,GAGAgH,EAAA,EAAAC,EAAA,EAAAC,EAAA,EAAAC,EAAA,EAYA,OAVAD,IADAC,GAAAP,GAHA,MAAAJ,EAAAxG,QAIA,GAGAiH,IADAC,GAAAP,EAAAI,KACA,GAGAC,IADAC,GAAAP,EAAAI,KACA,GAEAE,GAAAP,EAAAI,EAEA9G,GANAmH,GAAA,QAMA,IATAC,GAAA,QAQAH,GAAA,QACA,IAHAC,GAAA,OAGArnH,KAAA0iH,WAQA+B,EAAA+C,SAAA,SAAAC,GAGA,OAFA3E,EAAA2E,KACAA,EAAArD,EAAAqD,IACAznH,KAAAgV,IAAAyyG,EAAA/D,QASAe,EAAAnE,IAAAmE,EAAA+C,SAOA/C,EAAAiD,SAAA,SAAAC,GACA,GAAA3nH,KAAA2kH,SACA,OAAA7E,EAKA,GAJAgD,EAAA6E,KACAA,EAAAvD,EAAAuD,IAGAhF,EAKA,OAAAxC,EAJAwC,EAAApC,IAAAvgH,KAAAogH,IACApgH,KAAAqgH,KACAsH,EAAAvH,IACAuH,EAAAtH,MACAsC,EAAAiF,WAAA5nH,KAAA0iH,UAGA,GAAAiF,EAAAhD,SACA,OAAA7E,EACA,GAAA9/G,KAAA4hH,GAAA5zC,GACA,OAAA25C,EAAAjC,QAAA13C,EAAA8xC,EACA,GAAA6H,EAAA/F,GAAA5zC,GACA,OAAAhuE,KAAA0lH,QAAA13C,EAAA8xC,EAEA,GAAA9/G,KAAA4kH,aACA,OAAA+C,EAAA/C,aACA5kH,KAAA0jH,MAAAnD,IAAAoH,EAAAjE,OAEA1jH,KAAA0jH,MAAAnD,IAAAoH,GAAAjE,MACK,GAAAiE,EAAA/C,aACL,OAAA5kH,KAAAugH,IAAAoH,EAAAjE,aAGA,GAAA1jH,KAAAimH,GAAA3B,IAAAqD,EAAA1B,GAAA3B,GACA,OAAArC,EAAAjiH,KAAAyiH,WAAAkF,EAAAlF,WAAAziH,KAAA0iH,UAKA,IAAAmE,EAAA7mH,KAAAqgH,OAAA,GACAyG,EAAA,MAAA9mH,KAAAqgH,KACA0G,EAAA/mH,KAAAogH,MAAA,GACA4G,EAAA,MAAAhnH,KAAAogH,IAEA6G,EAAAU,EAAAtH,OAAA,GACA6G,EAAA,MAAAS,EAAAtH,KACA8G,EAAAQ,EAAAvH,MAAA,GACAyH,EAAA,MAAAF,EAAAvH,IAEAgH,EAAA,EAAAC,EAAA,EAAAC,EAAA,EAAAC,EAAA,EAqBA,OAnBAD,IADAC,GAAAP,EAAAa,KACA,GAGAR,IADAC,GAAAP,EAAAc,KACA,GACAP,GAAA,MAEAD,IADAC,GAAAN,EAAAG,KACA,GAGAC,IADAC,GAAAP,EAAAe,KACA,GACAR,GAAA,MAEAD,IADAC,GAAAN,EAAAI,KACA,GACAE,GAAA,MAEAD,IADAC,GAAAL,EAAAE,KACA,GAEAE,GAAAP,EAAAgB,EAAAf,EAAAK,EAAAJ,EAAAG,EAAAF,EAAAC,EAEA9G,GAZAmH,GAAA,QAYA,IAlBAC,GAAA,QAiBAH,GAAA,QACA,IAHAC,GAAA,OAGArnH,KAAA0iH,WASA+B,EAAAlE,IAAAkE,EAAAiD,SAQAjD,EAAAqD,OAAA,SAAAC,GAGA,GAFAjF,EAAAiF,KACAA,EAAA3D,EAAA2D,IACAA,EAAApD,SACA,MAAAvoG,MAAA,oBAaA,IAWA4rG,EAAAjD,EAAAvG,EArBA,GAAAmE,EAIA,OAAA3iH,KAAA0iH,WACA,aAAA1iH,KAAAqgH,OACA,IAAA0H,EAAA3H,MAAA,IAAA2H,EAAA1H,KAUAF,GANAngH,KAAA0iH,SAAAC,EAAAsF,MAAAtF,EAAAuF,OACAloH,KAAAogH,IACApgH,KAAAqgH,KACA0H,EAAA3H,IACA2H,EAAA1H,MAEAsC,EAAAiF,WAAA5nH,KAAA0iH,UARA1iH,KAWA,GAAAA,KAAA2kH,SACA,OAAA3kH,KAAA0iH,SAAAY,EAAAxD,EAEA,GAAA9/G,KAAA0iH,SA6BK,CAKL,GAFAqF,EAAArF,WACAqF,IAAApH,cACAoH,EAAA1B,GAAArmH,MACA,OAAAsjH,EACA,GAAAyE,EAAA1B,GAAArmH,KAAAwhH,KAAA,IACA,OAAA+C,EACA/F,EAAA8E,MAtCA,CAGA,GAAAtjH,KAAA4hH,GAAA5zC,GACA,OAAA+5C,EAAAnG,GAAA5B,IAAA+H,EAAAnG,GAAA4C,GACAx2C,EACA+5C,EAAAnG,GAAA5zC,GACAgyC,GAIAgI,EADAhoH,KAAAuhH,IAAA,GACAd,IAAAsH,GAAA1G,IAAA,IACAO,GAAA9B,GACAiI,EAAAnD,aAAA5E,EAAAwE,GAEAO,EAAA/kH,KAAAsgH,IAAAyH,EAAAxH,IAAAyH,IACAxJ,EAAAwJ,EAAAhzG,IAAA+vG,EAAAtE,IAAAsH,KAIS,GAAAA,EAAAnG,GAAA5zC,GACT,OAAAhuE,KAAA0iH,SAAAY,EAAAxD,EACA,GAAA9/G,KAAA4kH,aACA,OAAAmD,EAAAnD,aACA5kH,KAAA0jH,MAAAjD,IAAAsH,EAAArE,OACA1jH,KAAA0jH,MAAAjD,IAAAsH,GAAArE,MACS,GAAAqE,EAAAnD,aACT,OAAA5kH,KAAAygH,IAAAsH,EAAArE,aACAlF,EAAAsB,EAmBA,IADAiF,EAAA/kH,KACA+kH,EAAA3C,IAAA2F,IAAA,CAGAC,EAAAzgH,KAAAojE,IAAA,EAAApjE,KAAAunF,MAAAi2B,EAAAtC,WAAAsF,EAAAtF,aAWA,IAPA,IAAA0F,EAAA5gH,KAAA4qD,KAAA5qD,KAAA6gH,IAAAJ,GAAAzgH,KAAA8gH,KACAC,EAAAH,GAAA,KAAArE,EAAA,EAAAqE,EAAA,IAIAI,EAAAtG,EAAA+F,GACAQ,EAAAD,EAAAhI,IAAAwH,GACAS,EAAA5D,cAAA4D,EAAAnC,GAAAtB,IAGAyD,GADAD,EAAAtG,EADA+F,GAAAM,EACAtoH,KAAA0iH,WACAnC,IAAAwH,GAKAQ,EAAA5D,WACA4D,EAAAvI,GAEAxB,IAAAxpG,IAAAuzG,GACAxD,IAAAzE,IAAAkI,GAEA,OAAAhK,GASAiG,EAAAhE,IAAAgE,EAAAqD,OAOArD,EAAAgE,OAAA,SAAAV,GAKA,OAJAjF,EAAAiF,KACAA,EAAA3D,EAAA2D,IAGApF,EAOAxC,GANAngH,KAAA0iH,SAAAC,EAAA+F,MAAA/F,EAAAgG,OACA3oH,KAAAogH,IACApgH,KAAAqgH,KACA0H,EAAA3H,IACA2H,EAAA1H,MAEAsC,EAAAiF,WAAA5nH,KAAA0iH,UAGA1iH,KAAAsgH,IAAAtgH,KAAAygH,IAAAsH,GAAAxH,IAAAwH,KASAtD,EAAAn8G,IAAAm8G,EAAAgE,OAQAhE,EAAAM,IAAAN,EAAAgE,OAMAhE,EAAA/C,IAAA,WACA,OAAAvB,GAAAngH,KAAAogH,KAAApgH,KAAAqgH,KAAArgH,KAAA0iH,WAQA+B,EAAAzD,IAAA,SAAAvyF,GAGA,OAFAq0F,EAAAr0F,KACAA,EAAA21F,EAAA31F,IACA0xF,EAAAngH,KAAAogH,IAAA3xF,EAAA2xF,IAAApgH,KAAAqgH,KAAA5xF,EAAA4xF,KAAArgH,KAAA0iH,WAQA+B,EAAAvD,GAAA,SAAAzyF,GAGA,OAFAq0F,EAAAr0F,KACAA,EAAA21F,EAAA31F,IACA0xF,EAAAngH,KAAAogH,IAAA3xF,EAAA2xF,IAAApgH,KAAAqgH,KAAA5xF,EAAA4xF,KAAArgH,KAAA0iH,WAQA+B,EAAArD,IAAA,SAAA3yF,GAGA,OAFAq0F,EAAAr0F,KACAA,EAAA21F,EAAA31F,IACA0xF,EAAAngH,KAAAogH,IAAA3xF,EAAA2xF,IAAApgH,KAAAqgH,KAAA5xF,EAAA4xF,KAAArgH,KAAA0iH,WAQA+B,EAAAmE,UAAA,SAAAC,GAGA,OAFA/F,EAAA+F,KACAA,IAAAnE,SACA,IAAAmE,GAAA,IACA7oH,KACA6oH,EAAA,GACA1I,EAAAngH,KAAAogH,KAAAyI,EAAA7oH,KAAAqgH,MAAAwI,EAAA7oH,KAAAogH,MAAA,GAAAyI,EAAA7oH,KAAA0iH,UAEAvC,EAAA,EAAAngH,KAAAogH,KAAAyI,EAAA,GAAA7oH,KAAA0iH,WASA+B,EAAApD,IAAAoD,EAAAmE,UAOAnE,EAAAqE,WAAA,SAAAD,GAGA,OAFA/F,EAAA+F,KACAA,IAAAnE,SACA,IAAAmE,GAAA,IACA7oH,KACA6oH,EAAA,GACA1I,EAAAngH,KAAAogH,MAAAyI,EAAA7oH,KAAAqgH,MAAA,GAAAwI,EAAA7oH,KAAAqgH,MAAAwI,EAAA7oH,KAAA0iH,UAEAvC,EAAAngH,KAAAqgH,MAAAwI,EAAA,GAAA7oH,KAAAqgH,MAAA,OAAArgH,KAAA0iH,WASA+B,EAAAlD,IAAAkD,EAAAqE,WAOArE,EAAAsE,mBAAA,SAAAF,GAIA,GAHA/F,EAAA+F,KACAA,IAAAnE,SAEA,KADAmE,GAAA,IAEA,OAAA7oH,KAEA,IAAAqgH,EAAArgH,KAAAqgH,KACA,OAAAwI,EAAA,GAEA1I,EADAngH,KAAAogH,MACAyI,EAAAxI,GAAA,GAAAwI,EAAAxI,IAAAwI,EAAA7oH,KAAA0iH,UAEAvC,EADS,KAAA0I,EACTxI,EAEAA,IAAAwI,EAAA,GAFA,EAAA7oH,KAAA0iH,WAYA+B,EAAAjD,KAAAiD,EAAAsE,mBAQAtE,EAAAuE,MAAAvE,EAAAsE,mBAMAtE,EAAA7D,SAAA,WACA,OAAA5gH,KAAA0iH,SAEAvC,EAAAngH,KAAAogH,IAAApgH,KAAAqgH,MAAA,GADArgH,MAQAykH,EAAA9D,WAAA,WACA,OAAA3gH,KAAA0iH,SACA1iH,KACAmgH,EAAAngH,KAAAogH,IAAApgH,KAAAqgH,MAAA,IAQAoE,EAAAwE,QAAA,SAAA9C,GACA,OAAAA,EAAAnmH,KAAAkpH,YAAAlpH,KAAAmpH,aAOA1E,EAAAyE,UAAA,WACA,IAAAhJ,EAAAlgH,KAAAqgH,KACAJ,EAAAjgH,KAAAogH,IACA,OACA,IAAAH,EACAA,IAAA,MACAA,IAAA,OACAA,IAAA,GACA,IAAAC,EACAA,IAAA,MACAA,IAAA,OACAA,IAAA,KAQAuE,EAAA0E,UAAA,WACA,IAAAjJ,EAAAlgH,KAAAqgH,KACAJ,EAAAjgH,KAAAogH,IACA,OACAF,IAAA,GACAA,IAAA,OACAA,IAAA,MACA,IAAAA,EACAD,IAAA,GACAA,IAAA,OACAA,IAAA,MACA,IAAAA,IAWAJ,EAAAuJ,UAAA,SAAA7iF,EAAAm8E,EAAAyD,GACA,OAAAA,EAAAtG,EAAAwJ,YAAA9iF,EAAAm8E,GAAA7C,EAAAyJ,YAAA/iF,EAAAm8E,IASA7C,EAAAwJ,YAAA,SAAA9iF,EAAAm8E,GACA,WAAA7C,EACAt5E,EAAA,GACAA,EAAA,MACAA,EAAA,OACAA,EAAA,OACAA,EAAA,GACAA,EAAA,MACAA,EAAA,OACAA,EAAA,OACAm8E,IAUA7C,EAAAyJ,YAAA,SAAA/iF,EAAAm8E,GACA,WAAA7C,EACAt5E,EAAA,OACAA,EAAA,OACAA,EAAA,MACAA,EAAA,GACAA,EAAA,OACAA,EAAA,OACAA,EAAA,MACAA,EAAA,GACAm8E,mFCryCA,SAAkBx5G,GAEhBA,IAAA,eAEAA,IAAA,mCAEAA,IAAA,mCAEAA,IAAA,6BAEAA,IAAA,eAEAA,IAAA,sBAZF,CAAkBxJ,EAAAwJ,UAAAxJ,EAAAwJ,QAAO,oFCAzB,SAAYE,GAEVA,IAAA,mBAEAA,IAAA,mBAEAA,IAAA,WANF,CAAY1J,EAAA0J,SAAA1J,EAAA0J,OAAM,qbCalB,IAAAE,EAAA,oBAAAA,KAKA,OALaA,EAAQigH,EAAA,CADpBC,WACYlgH,GAAb,GAAa5J,EAAA4J,WAQb,SAAkBC,GAEhBA,IAAA,eAEAA,IAAA,qCAEAA,IAAA,iBAEAA,IAAA,aAEAA,IAAA,aAEAA,IAAA,sBAEAA,IAAA,kCAEAA,IAAA,kCAEAA,IAAA,mCAEAA,IAAA,mCAEAA,IAAA,mCAEAA,IAAA,kCAEAA,IAAA,gCAEAA,IAAA,sCAEAA,IAAA,oCAEAA,IAAA,iCAEAA,IAAA,iCAEAA,IAAA,iCAEAA,IAAA,kCAEAA,IAAA,kCAEAA,IAAA,gCAEAA,IAAA,+BAEAA,IAAA,qCAEAA,IAAA,mCAhDF,CAAkB7J,EAAA6J,gBAAA7J,EAAA6J,cAAa,oVClB/B,IAAAqiF,EAAAzrF,EAAA,IACAspH,EAAAtpH,EAAA,IACAupH,EAAAvpH,EAAA,IACAsN,EAAAtN,EAAA,GA4BoCT,EAAAiqH,iBA5BYl8G,EAAAb,wBAEhD,IAAAg9G,EAAAzpH,EAAA,IAIAT,EAAA+yG,UAAA,SAA0BxmG,EAAcuY,EAAc/G,EACpDosG,GAIA,YALoD,IAAApsG,OAAA,QACpD,IAAAosG,MAAA,MAEKA,IAAQA,EAAS,IAAID,EAAAzX,QAC1B0X,EAAOpX,UAAUxmG,EAAMuY,EAAM/G,GACtBosG,GAITnqH,EAAA60G,SAAA,SAAyBsV,GACvB,OAAOA,EAAOtV,YAIhB70G,EAAAoqH,eAAA,SAA+BD,GAC7B,IAAIrkG,EAAUqkG,EAAOrkG,QACrB,OAAOA,EAAQpU,kBAAoBoU,EAAQzY,YAAYZ,OACnDqZ,EAAQzY,YAAYyY,EAAQpU,qBAC5B,MAON1R,EAAAqqH,OAAA,SAAuBj/G,GACrB,OAAOA,EAAQd,UAAYyD,EAAA9D,mBAAmBM,MAIhDvK,EAAAsqH,UAAA,SAA0Bl/G,GACxB,OAAOA,EAAQd,UAAYyD,EAAA9D,mBAAmBO,SAIhDxK,EAAAuqH,QAAA,SAAwBn/G,GACtB,OAAOA,EAAQd,UAAYyD,EAAA9D,mBAAmBQ,OAIhDzK,EAAAwqH,cAAA,WACE,OAAO,IAAIt+B,EAAApd,SAIb9uE,EAAAyqH,UAAA,SAA0Bz1G,EAAkB2Y,GAC1C3Y,EAAQ2Y,OAASA,GAInB3tB,EAAA0qH,YAAA,SAA4B11G,EAAkBiB,GAC5CjB,EAAQiB,SAAWA,GAIrBjW,EAAA2qH,gBAAA,SAAgC31G,EAAkB+5D,GAChD/5D,EAAQ+5D,aAAeA,GAIzB/uE,EAAA4qH,gBAAA,SAAgC51G,EAAkBg6D,GAChDh6D,EAAQg6D,aAAeA,GAIzBhvE,EAAA6qH,eAAA,SAA+B71G,EAAkBi6D,GAC/Cj6D,EAAQi6D,YAAcA,GAIxBjvE,EAAA8qH,aAAA,SAA6B91G,EAAkBgW,GAC7ChW,EAAQgW,UAAYA,GAItBhrB,EAAA+qH,cAAA,SAA8B/1G,EAAkBkB,GAC9ClB,EAAQkB,WAAaA,GAIvBlW,EAAAgrH,eAAA,SAA+Bh2G,EAAkBuH,EAAerb,GAC9D,IAAIib,EAAgBnH,EAAQmH,cACvBA,IAAenH,EAAQmH,cAAgBA,EAAgB,IAAIzU,KAChEyU,EAAc1J,IAAI8J,EAAOrb,IAI3BlB,EAAAirH,iBAAA,SAAiCj2G,EAAkBk6D,GACjDl6D,EAAQk6D,cAAgBA,GAIblvE,EAAAkrH,uBAAsB,EAEtBlrH,EAAAmrH,uBAAsB,EAEtBnrH,EAAAorH,oBAAmB,EAEnBprH,EAAAqrH,aAAY,EAEZrrH,EAAAsrH,gBAAe,GAG5BtrH,EAAAurH,cAAA,SAA8Bv2G,EAAkBo6D,GAC9Cp6D,EAAQm6D,UAAYC,GAItBpvE,EAAAwrH,sBAAA,SAAsCx2G,EAAkBy2G,EAAoBC,GAC1E12G,EAAQmB,kBAAoBs1G,EAC5Bz2G,EAAQoB,gBAAkBs1G,GAI5B1rH,EAAA2rH,cAAA,SAA8BxB,GAC5B,OAAOA,EAAO7pD,UAIhBtgE,EAAA4rH,eAAA,SAA+B9lG,EAAkB9Q,GAC/C,YAD+C,IAAAA,MAAA,MACxC,IAAIk3E,EAAAzc,SAAS3pD,EAAS9Q,GAAS67D,WAIxC7wE,EAAA6rH,gBAAA,SAAgC5rH,GAC9B,IAAI8vG,EAAa,IAAIga,EAAAna,WAErB,OADAG,EAAWD,UAAU7vG,GACd8vG,EAAWzvC,UAIpBtgE,EAAA8rH,SAAA,SAAyBhmG,GACvB,OAAOkkG,EAAAvY,WAAWE,MAAM7rF,IAI1B9lB,EAAA+rH,SAAA,SAAyBjmG,GACvB,OAAOkkG,EAAA9X,WAAWP,MAAM7rF,IAI1B9lB,EAAAgsH,UAAA,SAA0BlmG,mBACpBhZ,EAAK,IAAIvF,MACbuF,EAAGE,KAAK,yBACR,IAAgB,IAAA2R,EAAAtG,EAAAyN,EAAQ9T,eAAe6L,UAAQwB,EAAAV,EAAApG,QAAA8G,EAAA7G,KAAA6G,EAAAV,EAAApG,OAAE,CAA5C,IAAI0zG,EAAG5sG,EAAAzd,MACVkL,EAAGE,KAAK,SACRF,EAAGE,KAAKi/G,EAAIv5G,cACZ5F,EAAGE,KAAK,0GAEVF,EAAGE,KAAK,2BACR,IAAgB,IAAAsS,EAAAjH,EAAAyN,EAAQ9T,eAAe6L,UAAQpF,EAAA6G,EAAA/G,QAAAE,EAAAD,KAAAC,EAAA6G,EAAA/G,OAAE,CAA5C,IACCiU,GADGy/F,EAAGxzG,EAAA7W,OACK4qB,KACf1f,EAAGE,KAAK,QACRF,EAAGE,KAAKwf,EAAOA,EAAKpZ,GAAGpH,WAAa,KACpCc,EAAGE,KAAK,yGAEVF,EAAGE,KAAK,4BACR,IAAgB,IAAAyM,EAAApB,EAAAyN,EAAQ9T,eAAe6L,UAAQhE,EAAAJ,EAAAlB,QAAAsB,EAAArB,KAAAqB,EAAAJ,EAAAlB,OAAtC0zG,EAAGpyG,EAAAjY,MACVkL,EAAGE,KAAK,QACRF,EAAGE,KAAKi/G,EAAIn/F,UAAU9gB,YACtBc,EAAGE,KAAK,wGAGV,OADAF,EAAGE,KAAK,YACDF,EAAGG,KAAK,KAIjB,IAAAa,EAAArN,EAAA,GAAST,EAAAoD,eAAA0K,EAAA1K,eAGT0G,EAAArJ,EAAA,IAEAqJ,EAAArJ,EAAA,IACAqJ,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,IACAqJ,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,IACAqJ,EAAArJ,EAAA,KACAqJ,EAAArJ,EAAA,IACAqJ,EAAArJ,EAAA,IACAqJ,EAAArJ,EAAA,IACAqJ,EAAArJ,EAAA,IACAqJ,EAAArJ,EAAA,mFCrMAT,EAAAksH,SAAA,SAAyBC,EAAUjkG,GAEjC,OADAxd,OAAOwd,GAAS,GAAKA,EAAQ,IACtBi6F,OACLd,QACE8K,EACAjtD,QACEmhD,QACAxqG,QAAQqS,KAGZ68C,WAKJ/kE,EAAAosH,UAAA,SAA0BD,EAAUjkG,EAAYmkG,GAE9C,OADA3hH,OAAOwd,GAAS,GAAKA,EAAQ,IACtBmkG,EACH9K,OACE4K,EACAjtD,QACEmhD,QACAxqG,QAAQqS,KAGZm5F,QACE8K,EACApK,QACE7iD,QACEmhD,QACAxqG,QAAQqS,sFC9BpB,SAAkBokG,GAEhBA,IAAA,eACAA,IAAA,wBACAA,IAAA,oCACAA,IAAA,oCACAA,IAAA,8CACAA,IAAA,yBAEAA,IAAA,kBACAA,IAAA,yCACAA,IAAA,sBACAA,IAAA,sBACAA,IAAA,wBACAA,IAAA,wBACAA,IAAA,wCACAA,IAAA,sCACAA,IAAA,oCACAA,IAAA,gCACAA,IAAA,0CACAA,IAAA,4BACAA,IAAA,4BACAA,IAAA,sCACAA,IAAA,8CACAA,IAAA,2CACAA,IAAA,4CACAA,IAAA,oBAEAA,IAAA,UAEAA,IAAA,YACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YACAA,IAAA,YAEAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WACAA,IAAA,WAEAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UACAA,IAAA,UAEAA,IAAA,0BACAA,IAAA,wBACAA,IAAA,YACAA,IAAA,0BACAA,IAAA,wBACAA,IAAA,eACAA,IAAA,kBACAA,IAAA,6BACAA,IAAA,gCACAA,IAAA,4BACAA,IAAA,kBACAA,IAAA,kBACAA,IAAA,oBACAA,IAAA,cACAA,IAAA,8BACAA,IAAA,oBACAA,IAAA,8BACAA,IAAA,8BACAA,IAAA,gBACAA,IAAA,wBACAA,IAAA,kBACAA,IAAA,2BACAA,IAAA,8BACAA,IAAA,0BACAA,IAAA,sBACAA,IAAA,gBACAA,IAAA,wBACAA,IAAA,0BACAA,IAAA,8BACAA,IAAA,kBACAA,IAAA,mBAEAA,IAAA,yBACAA,IAAA,wBACAA,IAAA,qCACAA,IAAA,aACAA,IAAA,8BAnIF,CAAkBtsH,EAAAssH,WAAAtsH,EAAAssH,SAAQ,KAuI1BtsH,EAAA4M,YAAA,SAA4B5L,GAC1B,OAAQA,GACN,QACA,QACA,UACA,UACE,OAAO,EAET,QACE,OAAO,IAMbhB,EAAA28D,aAAA,SAA6B37D,GAC3B,OAAQA,GACN,QACA,OACA,QACA,QACA,SACA,SACA,UACA,UACA,UACA,WACA,WACE,OAAO,EAET,QACE,OAAOA,GAAC,MAAuBA,GAAC,OAMtChB,EAAAi7D,eAAA,SAA+Bj6D,GAC7B,OAAOA,GAAC,IAAmBA,GAAC,IAI9BhB,EAAA4+D,aAAA,SAA6B59D,GAC3B,OAAOA,GAAC,IAAmBA,GAAC,IAI9BhB,EAAAo8D,kBAAA,SAAkCp7D,GAChC,OAAOA,GAAC,IAAkBA,GAAC,KACpBA,GAAC,IAAkBA,GAAC,IACnB,IAADA,GACC,IAADA,GACAA,EAAI,QAmLqBmK,EAnLYnK,GAoL9B,GAAKmK,EAAO,QACnBohH,EAAmBphH,EAAaqhH,GAFzC,IAAkCrhH,GA/KlCnL,EAAAq8D,mBAAA,SAAmCr7D,GACjC,OAAOA,GAAC,IAAkBA,GAAC,KAI7BhB,EAAAu8D,iBAAA,SAAiCv7D,GAC/B,OAAOA,GAAC,IAAkBA,GAAC,KACpBA,GAAC,IAAkBA,GAAC,IACpBA,GAAC,IAAmBA,GAAC,IACpB,IAADA,GACC,IAADA,GACAA,EAAI,QAyKoBmK,EAzKYnK,GA0K7B,GAAKmK,EAAO,QACnBohH,EAAmBphH,EAAashH,GAFzC,IAAiCthH,GArKjC,IAAMqhH,EAAgC,CACpC,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACtE,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACtE,IAAK,IAAK,IAAK,IAAK,IACpB,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAC1C,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,KAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACtE,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,OAEtCC,EAA+B,CACnC,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACtE,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACtE,IAAK,IAAK,IAAK,IAAK,IACpB,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACxE,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KA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","file":"assemblyscript.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"binaryen\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"binaryen\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"assemblyscript\"] = factory(require(\"binaryen\"));\n\telse\n\t\troot[\"assemblyscript\"] = factory(root[\"binaryen\"]);\n})(typeof self !== 'undefined' ? self : this, function(__WEBPACK_EXTERNAL_MODULE__20__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 17);\n","/**\n * Common constants.\n * @module common\n *//***/\n\n/** Indicates traits of a {@link Node} or {@link Element}. */\nexport enum CommonFlags {\n /** No flags set. */\n NONE = 0,\n\n // Basic modifiers\n\n /** Has an `import` modifier. */\n IMPORT = 1 << 0,\n /** Has an `export` modifier. */\n EXPORT = 1 << 1,\n /** Has a `declare` modifier. */\n DECLARE = 1 << 2,\n /** Has a `const` modifier. */\n CONST = 1 << 3,\n /** Has a `let` modifier. */\n LET = 1 << 4,\n /** Has a `static` modifier. */\n STATIC = 1 << 5,\n /** Has a `readonly` modifier. */\n READONLY = 1 << 6,\n /** Has an `abstract` modifier. */\n ABSTRACT = 1 << 7,\n /** Has a `public` modifier. */\n PUBLIC = 1 << 8,\n /** Has a `private` modifier. */\n PRIVATE = 1 << 9,\n /** Has a `protected` modifier. */\n PROTECTED = 1 << 10,\n /** Has a `get` modifier. */\n GET = 1 << 11,\n /** Has a `set` modifier. */\n SET = 1 << 12,\n /** Has a definite assignment assertion `!` as in `x!: i32;`. */\n DEFINITE_ASSIGNMENT = 1 << 13,\n\n // Extended modifiers usually derived from basic modifiers\n\n /** Is ambient, that is either declared or nested in a declared element. */\n AMBIENT = 1 << 14,\n /** Is generic. */\n GENERIC = 1 << 15,\n /** Is part of a generic context. */\n GENERIC_CONTEXT = 1 << 16,\n /** Is an instance member. */\n INSTANCE = 1 << 17,\n /** Is a constructor. */\n CONSTRUCTOR = 1 << 18,\n /** Is a module export. */\n MODULE_EXPORT = 1 << 19,\n /** Is a module import. */\n MODULE_IMPORT = 1 << 20,\n\n // Compilation states\n\n /** Is resolved. */\n RESOLVED = 1 << 21,\n /** Is compiled. */\n COMPILED = 1 << 22,\n /** Has a constant value and is therefore inlined. */\n INLINED = 1 << 23,\n /** Is scoped. */\n SCOPED = 1 << 24,\n /** Is a trampoline. */\n TRAMPOLINE = 1 << 25,\n /** Is a virtual method. */\n VIRTUAL = 1 << 26,\n /** Is the main function. */\n MAIN = 1 << 27,\n\n // Other\n\n /** Is quoted. */\n QUOTED = 1 << 28\n}\n\n/** Path delimiter inserted between file system levels. */\nexport const PATH_DELIMITER = \"/\";\n/** Substitution used to indicate the parent directory. */\nexport const PARENT_SUBST = \"..\";\n/** Function name prefix used for getters. */\nexport const GETTER_PREFIX = \"get:\";\n/** Function name prefix used for setters. */\nexport const SETTER_PREFIX = \"set:\";\n/** Delimiter used between class names and instance members. */\nexport const INSTANCE_DELIMITER = \"#\";\n/** Delimiter used between class and namespace names and static members. */\nexport const STATIC_DELIMITER = \".\";\n/** Delimiter used between a function and its inner elements. */\nexport const INNER_DELIMITER = \"~\";\n/** Substitution used to indicate a library directory. */\nexport const LIBRARY_SUBST = \"~lib\";\n/** Library directory prefix. */\nexport const LIBRARY_PREFIX = LIBRARY_SUBST + PATH_DELIMITER;\n/** Path index suffix. */\nexport const INDEX_SUFFIX = PATH_DELIMITER + \"index\";\n\n/** Common compiler symbols. */\nexport namespace CommonSymbols {\n // special\n export const EMPTY = \"\";\n // types\n export const i8 = \"i8\";\n export const i16 = \"i16\";\n export const i32 = \"i32\";\n export const i64 = \"i64\";\n export const isize = \"isize\";\n export const u8 = \"u8\";\n export const u16 = \"u16\";\n export const u32 = \"u32\";\n export const u64 = \"u64\";\n export const usize = \"usize\";\n export const bool = \"bool\";\n export const f32 = \"f32\";\n export const f64 = \"f64\";\n export const v128 = \"v128\";\n export const i8x16 = \"i8x16\";\n export const u8x16 = \"u8x16\";\n export const i16x8 = \"i16x8\";\n export const u16x8 = \"u16x8\";\n export const i32x4 = \"i32x4\";\n export const u32x4 = \"u32x4\";\n export const i64x2 = \"i64x2\";\n export const u64x2 = \"u64x2\";\n export const f32x4 = \"f32x4\";\n export const f64x2 = \"f64x2\";\n export const void_ = \"void\";\n export const number = \"number\";\n export const boolean = \"boolean\";\n export const string = \"string\";\n export const native = \"native\";\n export const indexof = \"indexof\";\n export const valueof = \"valueof\";\n // aliases\n export const null_ = \"null\";\n export const true_ = \"true\";\n export const false_ = \"false\";\n // objects\n export const this_ = \"this\";\n export const super_ = \"super\";\n export const constructor = \"constructor\";\n // constants\n export const ASC_TARGET = \"ASC_TARGET\";\n export const ASC_NO_TREESHAKING = \"ASC_NO_TREESHAKING\";\n export const ASC_NO_ASSERT = \"ASC_NO_ASSERT\";\n export const ASC_MEMORY_BASE = \"ASC_MEMORY_BASE\";\n export const ASC_OPTIMIZE_LEVEL = \"ASC_OPTIMIZE_LEVEL\";\n export const ASC_SHRINK_LEVEL = \"ASC_SHRINK_LEVEL\";\n export const ASC_FEATURE_MUTABLE_GLOBAL = \"ASC_FEATURE_MUTABLE_GLOBAL\";\n export const ASC_FEATURE_SIGN_EXTENSION = \"ASC_FEATURE_SIGN_EXTENSION\";\n export const ASC_FEATURE_BULK_MEMORY = \"ASC_FEATURE_BULK_MEMORY\";\n export const ASC_FEATURE_SIMD = \"ASC_FEATURE_SIMD\";\n export const ASC_FEATURE_THREADS = \"ASC_FEATURE_THREADS\";\n // classes\n export const I8 = \"I8\";\n export const I16 = \"I16\";\n export const I32 = \"I32\";\n export const I64 = \"I64\";\n export const Isize = \"Isize\";\n export const U8 = \"U8\";\n export const U16 = \"U16\";\n export const U32 = \"U32\";\n export const U64 = \"U64\";\n export const Usize = \"Usize\";\n export const Bool = \"Bool\";\n export const F32 = \"F32\";\n export const F64 = \"F64\";\n export const V128 = \"V128\";\n export const String = \"String\";\n export const Array = \"Array\";\n export const FixedArray = \"FixedArray\";\n export const Set = \"Set\";\n export const Map = \"Map\";\n export const ArrayBufferView = \"ArrayBufferView\";\n export const ArrayBuffer = \"ArrayBuffer\";\n export const Math = \"Math\";\n export const Mathf = \"Mathf\";\n export const Int8Array = \"Int8Array\";\n export const Int16Array = \"Int16Array\";\n export const Int32Array = \"Int32Array\";\n export const Int64Array = \"Int64Array\";\n export const Uint8Array = \"Uint8Array\";\n export const Uint8ClampedArray = \"Uint8ClampedArray\";\n export const Uint16Array = \"Uint16Array\";\n export const Uint32Array = \"Uint32Array\";\n export const Uint64Array = \"Uint64Array\";\n export const Float32Array = \"Float32Array\";\n export const Float64Array = \"Float64Array\";\n // runtime\n export const abort = \"abort\";\n export const pow = \"pow\";\n export const mod = \"mod\";\n export const alloc = \"__alloc\";\n export const realloc = \"__realloc\";\n export const free = \"__free\";\n export const retain = \"__retain\";\n export const release = \"__release\";\n export const collect = \"__collect\";\n export const typeinfo = \"__typeinfo\";\n export const instanceof_ = \"__instanceof\";\n export const visit = \"__visit\";\n export const allocArray = \"__allocArray\";\n}\n\n// shared\nexport { Feature } from \"../std/assembly/shared/feature\";\nexport { Target } from \"../std/assembly/shared/target\";\nexport { Typeinfo, TypeinfoFlags } from \"../std/assembly/shared/typeinfo\";\n","/**\n * Various compiler utilities.\n * @module util\n * @preferred\n *//***/\n\nexport * from \"./bitset\";\nexport * from \"./charcode\";\nexport * from \"./collections\";\nexport * from \"./path\";\nexport * from \"./text\";\nexport * from \"./binary\";\n\n/** Tests if `x` is a power of two. */\nexport function isPowerOf2(x: i32): bool {\n return x != 0 && (x & (x - 1)) == 0;\n}\n","/**\n * Shared diagnostic handling inherited by the parser and the compiler.\n * @module diagnostics\n * @preferred\n *//***/\n\nimport {\n Range\n} from \"./ast\";\n\nimport {\n DiagnosticCode,\n diagnosticCodeToString\n} from \"./diagnosticMessages.generated\";\n\nimport {\n isLineBreak, CharCode\n} from \"./util\";\n\nexport {\n DiagnosticCode,\n diagnosticCodeToString\n} from \"./diagnosticMessages.generated\";\n\n/** Indicates the category of a {@link DiagnosticMessage}. */\nexport enum DiagnosticCategory {\n /** Informatory message. */\n INFO,\n /** Warning message. */\n WARNING,\n /** Error message. */\n ERROR\n}\n\n/** Returns the string representation of the specified diagnostic category. */\nexport function diagnosticCategoryToString(category: DiagnosticCategory): string {\n switch (category) {\n case DiagnosticCategory.INFO: return \"INFO\";\n case DiagnosticCategory.WARNING: return \"WARNING\";\n case DiagnosticCategory.ERROR: return \"ERROR\";\n default: {\n assert(false);\n return \"\";\n }\n }\n}\n\n/** ANSI escape sequence for blue foreground. */\nexport const COLOR_BLUE: string = \"\\u001b[96m\";\n/** ANSI escape sequence for yellow foreground. */\nexport const COLOR_YELLOW: string = \"\\u001b[93m\";\n/** ANSI escape sequence for red foreground. */\nexport const COLOR_RED: string = \"\\u001b[91m\";\n/** ANSI escape sequence to reset the foreground color. */\nexport const COLOR_RESET: string = \"\\u001b[0m\";\n\n/** Returns the ANSI escape sequence for the specified category. */\nexport function diagnosticCategoryToColor(category: DiagnosticCategory): string {\n switch (category) {\n case DiagnosticCategory.INFO: return COLOR_BLUE;\n case DiagnosticCategory.WARNING: return COLOR_YELLOW;\n case DiagnosticCategory.ERROR: return COLOR_RED;\n default: {\n assert(false);\n return \"\";\n }\n }\n}\n\n/** Represents a diagnostic message. */\nexport class DiagnosticMessage {\n\n /** Message code. */\n code: i32;\n /** Message category. */\n category: DiagnosticCategory;\n /** Message text. */\n message: string;\n /** Respective source range, if any. */\n range: Range | null = null;\n /** Related range, if any. */\n relatedRange: Range | null = null;\n\n /** Constructs a new diagnostic message. */\n private constructor(code: i32, category: DiagnosticCategory, message: string) {\n this.code = code;\n this.category = category;\n this.message = message;\n }\n\n /** Creates a new diagnostic message of the specified category. */\n static create(\n code: DiagnosticCode,\n category: DiagnosticCategory,\n arg0: string | null = null,\n arg1: string | null = null,\n arg2: string | null = null\n ): DiagnosticMessage {\n var message = diagnosticCodeToString(code);\n if (arg0 != null) message = message.replace(\"{0}\", arg0);\n if (arg1 != null) message = message.replace(\"{1}\", arg1);\n if (arg2 != null) message = message.replace(\"{2}\", arg2);\n return new DiagnosticMessage(code, category, message);\n }\n\n /** Creates a new informatory diagnostic message. */\n static createInfo(\n code: DiagnosticCode,\n arg0: string | null = null,\n arg1: string | null = null\n ): DiagnosticMessage {\n return DiagnosticMessage.create(code, DiagnosticCategory.INFO, arg0, arg1);\n }\n\n /** Creates a new warning diagnostic message. */\n static createWarning(\n code: DiagnosticCode,\n arg0: string | null = null,\n arg1: string | null = null\n ): DiagnosticMessage {\n return DiagnosticMessage.create(code, DiagnosticCategory.WARNING, arg0, arg1);\n }\n\n /** Creates a new error diagnostic message. */\n static createError(\n code: DiagnosticCode,\n arg0: string | null = null,\n arg1: string | null = null\n ): DiagnosticMessage {\n return DiagnosticMessage.create(code, DiagnosticCategory.ERROR, arg0, arg1);\n }\n\n /** Adds a source range to this message. */\n withRange(range: Range): this {\n this.range = range;\n return this;\n }\n\n /** Adds a related source range to this message. */\n withRelatedRange(range: Range): this {\n this.relatedRange = range;\n return this;\n }\n\n /** Converts this message to a string. */\n toString(): string {\n if (this.range) {\n return (\n diagnosticCategoryToString(this.category) +\n \" \" +\n this.code.toString(10) +\n \": \\\"\" +\n this.message +\n \"\\\" in \" +\n this.range.source.normalizedPath +\n \":\" +\n this.range.line.toString(10) +\n \":\" +\n this.range.column.toString(10)\n );\n }\n return (\n diagnosticCategoryToString(this.category) +\n \" \" +\n this.code.toString(10) +\n \": \" +\n this.message\n );\n }\n}\n\n/** Formats a diagnostic message, optionally with terminal colors and source context. */\nexport function formatDiagnosticMessage(\n message: DiagnosticMessage,\n useColors: bool = false,\n showContext: bool = false\n): string {\n\n // general information\n var sb: string[] = [];\n if (useColors) sb.push(diagnosticCategoryToColor(message.category));\n sb.push(diagnosticCategoryToString(message.category));\n if (useColors) sb.push(COLOR_RESET);\n sb.push(message.code < 1000 ? \" AS\" : \" TS\");\n sb.push(message.code.toString(10));\n sb.push(\": \");\n sb.push(message.message);\n\n // include range information if available\n if (message.range) {\n\n // include context information if requested\n let range = message.range;\n if (showContext) {\n sb.push(\"\\n\");\n sb.push(formatDiagnosticContext(range, useColors));\n }\n sb.push(\"\\n\");\n sb.push(\" in \");\n sb.push(range.source.normalizedPath);\n sb.push(\"(\");\n sb.push(range.line.toString(10));\n sb.push(\",\");\n sb.push(range.column.toString(10));\n sb.push(\")\");\n\n let relatedRange = message.relatedRange;\n if (relatedRange) {\n if (showContext) {\n sb.push(\"\\n\");\n sb.push(formatDiagnosticContext(relatedRange, useColors));\n }\n sb.push(\"\\n\");\n sb.push(\" in \");\n sb.push(range.source.normalizedPath);\n sb.push(\"(\");\n sb.push(range.line.toString(10));\n sb.push(\",\");\n sb.push(range.column.toString(10));\n sb.push(\")\");\n }\n }\n return sb.join(\"\");\n}\n\n/** Formats the diagnostic context for the specified range, optionally with terminal colors. */\nexport function formatDiagnosticContext(range: Range, useColors: bool = false): string {\n var text = range.source.text;\n var len = text.length;\n var start = range.start;\n var end = range.end;\n while (start > 0 && !isLineBreak(text.charCodeAt(start - 1))) start--;\n while (end < len && !isLineBreak(text.charCodeAt(end))) end++;\n var sb: string[] = [\n \"\\n \",\n text.substring(start, end),\n \"\\n \"\n ];\n while (start < range.start) {\n sb.push(\" \");\n start++;\n }\n if (useColors) sb.push(COLOR_RED);\n if (range.start == range.end) {\n sb.push(\"^\");\n } else {\n while (start++ < range.end) {\n if (isLineBreak(text.charCodeAt(start))) {\n sb.push(start == range.start + 1 ? \"^\" : \"~\");\n break;\n }\n sb.push(\"~\");\n }\n }\n if (useColors) sb.push(COLOR_RESET);\n return sb.join(\"\");\n}\n\n/** Base class of all diagnostic emitters. */\nexport abstract class DiagnosticEmitter {\n\n /** Diagnostic messages emitted so far. */\n diagnostics: DiagnosticMessage[];\n\n /** Initializes this diagnostic emitter. */\n protected constructor(diagnostics: DiagnosticMessage[] | null = null) {\n this.diagnostics = diagnostics ? diagnostics : new Array();\n }\n\n /** Emits a diagnostic message of the specified category. */\n emitDiagnostic(\n code: DiagnosticCode,\n category: DiagnosticCategory,\n range: Range,\n relatedRange: Range | null,\n arg0: string | null = null,\n arg1: string | null = null,\n arg2: string | null = null\n ): void {\n var message = DiagnosticMessage.create(code, category, arg0, arg1, arg2).withRange(range);\n if (relatedRange) message.relatedRange = relatedRange;\n this.diagnostics.push(message);\n // console.log(formatDiagnosticMessage(message, true, true) + \"\\n\"); // temporary\n // console.log(new Error(\"stack\").stack);\n }\n\n /** Emits an informatory diagnostic message. */\n info(\n code: DiagnosticCode,\n range: Range,\n arg0: string | null = null,\n arg1: string | null = null,\n arg2: string | null = null\n ): void {\n this.emitDiagnostic(code, DiagnosticCategory.INFO, range, null, arg0, arg1, arg2);\n }\n\n /** Emits an informatory diagnostic message with a related range. */\n infoRelated(\n code: DiagnosticCode,\n range: Range,\n relatedRange: Range,\n arg0: string | null = null,\n arg1: string | null = null,\n arg2: string | null = null\n ): void {\n this.emitDiagnostic(code, DiagnosticCategory.INFO, range, relatedRange, arg0, arg1, arg2);\n }\n\n /** Emits a warning diagnostic message. */\n warning(\n code: DiagnosticCode,\n range: Range,\n arg0: string | null = null,\n arg1: string | null = null,\n arg2: string | null = null\n ): void {\n this.emitDiagnostic(code, DiagnosticCategory.WARNING, range, null, arg0, arg1, arg2);\n }\n\n /** Emits a warning diagnostic message with a related range. */\n warningRelated(\n code: DiagnosticCode,\n range: Range,\n relatedRange: Range,\n arg0: string | null = null,\n arg1: string | null = null,\n arg2: string | null = null\n ): void {\n this.emitDiagnostic(code, DiagnosticCategory.WARNING, range, relatedRange, arg0, arg1, arg2);\n }\n\n /** Emits an error diagnostic message. */\n error(\n code: DiagnosticCode,\n range: Range,\n arg0: string | null = null,\n arg1: string | null = null,\n arg2: string | null = null\n ): void {\n this.emitDiagnostic(code, DiagnosticCategory.ERROR, range, null, arg0, arg1, arg2);\n }\n\n /** Emits an error diagnostic message with a related range. */\n errorRelated(\n code: DiagnosticCode,\n range: Range,\n relatedRange: Range,\n arg0: string | null = null,\n arg1: string | null = null,\n arg2: string | null = null\n ): void {\n this.emitDiagnostic(code, DiagnosticCategory.ERROR, range, relatedRange, arg0, arg1, arg2);\n }\n}\n","/**\n * AssemblyScript's intermediate representation describing a program's elements.\n * @module program\n *//***/\n\nimport {\n CommonFlags,\n PATH_DELIMITER,\n STATIC_DELIMITER,\n INSTANCE_DELIMITER,\n GETTER_PREFIX,\n SETTER_PREFIX,\n INNER_DELIMITER,\n LIBRARY_SUBST,\n INDEX_SUFFIX,\n CommonSymbols,\n Feature,\n Target\n} from \"./common\";\n\nimport {\n Options\n} from \"./compiler\";\n\nimport {\n DiagnosticCode,\n DiagnosticMessage,\n DiagnosticEmitter\n} from \"./diagnostics\";\n\nimport {\n Type,\n TypeKind,\n TypeFlags,\n Signature\n} from \"./types\";\n\nimport {\n Node,\n NodeKind,\n Source,\n SourceKind,\n Range,\n DecoratorNode,\n DecoratorKind,\n TypeParameterNode,\n TypeNode,\n NamedTypeNode,\n FunctionTypeNode,\n ArrowKind,\n\n Expression,\n IdentifierExpression,\n LiteralExpression,\n LiteralKind,\n StringLiteralExpression,\n\n Statement,\n ClassDeclaration,\n DeclarationStatement,\n EnumDeclaration,\n EnumValueDeclaration,\n ExportMember,\n ExportStatement,\n FieldDeclaration,\n FunctionDeclaration,\n ImportDeclaration,\n ImportStatement,\n InterfaceDeclaration,\n MethodDeclaration,\n NamespaceDeclaration,\n TypeDeclaration,\n VariableDeclaration,\n VariableLikeDeclarationStatement,\n VariableStatement,\n\n decoratorNameToKind,\n findDecorator,\n ExportDefaultStatement\n} from \"./ast\";\n\nimport {\n Module,\n FunctionRef\n} from \"./module\";\n\nimport {\n CharCode,\n writeI8,\n writeI16,\n writeI32,\n writeF32,\n writeF64\n} from \"./util\";\n\nimport {\n Resolver\n} from \"./resolver\";\n\nimport {\n Flow\n} from \"./flow\";\n\n/** Represents a yet unresolved `import`. */\nclass QueuedImport {\n constructor(\n /** File being imported into. */\n public localFile: File,\n /** Identifier within the local file. */\n public localIdentifier: IdentifierExpression,\n /** Identifier within the other file. Is an `import *` if not set. */\n public foreignIdentifier: IdentifierExpression | null,\n /** Path to the other file. */\n public foreignPath: string,\n /** Alternative path to the other file. */\n public foreignPathAlt: string\n ) {}\n}\n\n/** Represents a yet unresolved `export`. */\nclass QueuedExport {\n constructor(\n /** Identifier within the local file. */\n public localIdentifier: IdentifierExpression,\n /** Identifier within the other file. */\n public foreignIdentifier: IdentifierExpression,\n /** Path to the other file if a re-export. */\n public foreignPath: string | null,\n /** Alternative path to the other file if a re-export. */\n public foreignPathAlt: string | null\n ) {}\n}\n\n/** Represents a yet unresolved `export *`. */\nclass QueuedExportStar {\n // stored in a map with localFile as the key\n constructor(\n /** Path to the other file. */\n public foreignPath: string,\n /** Alternative path to the other file. */\n public foreignPathAlt: string,\n /** Reference to the path literal for reporting. */\n public pathLiteral: StringLiteralExpression\n ) {}\n}\n\n/** Represents the kind of an operator overload. */\nexport enum OperatorKind {\n INVALID,\n\n // indexed access\n INDEXED_GET, // a[]\n INDEXED_SET, // a[]=b\n UNCHECKED_INDEXED_GET, // unchecked(a[])\n UNCHECKED_INDEXED_SET, // unchecked(a[]=b)\n\n // binary\n ADD, // a + b\n SUB, // a - b\n MUL, // a * b\n DIV, // a / b\n REM, // a % b\n POW, // a ** b\n BITWISE_AND, // a & b\n BITWISE_OR, // a | b\n BITWISE_XOR, // a ^ b\n BITWISE_SHL, // a << b\n BITWISE_SHR, // a >> b\n BITWISE_SHR_U, // a >>> b\n EQ, // a == b\n NE, // a != b\n GT, // a > b\n GE, // a >= b\n LT, // a < b\n LE, // a <= b\n\n // unary prefix\n PLUS, // +a\n MINUS, // -a\n NOT, // !a\n BITWISE_NOT, // ~a\n PREFIX_INC, // ++a\n PREFIX_DEC, // --a\n\n // unary postfix\n POSTFIX_INC, // a++\n POSTFIX_DEC // a--\n\n // not overridable:\n // IDENTITY // a === b\n // LOGICAL_AND // a && b\n // LOGICAL_OR // a || b\n}\n\n/** Returns the operator kind represented by the specified decorator and string argument. */\nfunction operatorKindFromDecorator(decoratorKind: DecoratorKind, arg: string): OperatorKind {\n assert(arg.length);\n switch (decoratorKind) {\n case DecoratorKind.OPERATOR:\n case DecoratorKind.OPERATOR_BINARY: {\n switch (arg.charCodeAt(0)) {\n case CharCode.OPENBRACKET: {\n if (arg == \"[]\") return OperatorKind.INDEXED_GET;\n if (arg == \"[]=\") return OperatorKind.INDEXED_SET;\n break;\n }\n case CharCode.OPENBRACE: {\n if (arg == \"{}\") return OperatorKind.UNCHECKED_INDEXED_GET;\n if (arg == \"{}=\") return OperatorKind.UNCHECKED_INDEXED_SET;\n break;\n }\n case CharCode.PLUS: {\n if (arg == \"+\") return OperatorKind.ADD;\n break;\n }\n case CharCode.MINUS: {\n if (arg == \"-\") return OperatorKind.SUB;\n break;\n }\n case CharCode.ASTERISK: {\n if (arg == \"*\") return OperatorKind.MUL;\n if (arg == \"**\") return OperatorKind.POW;\n break;\n }\n case CharCode.SLASH: {\n if (arg == \"/\") return OperatorKind.DIV;\n break;\n }\n case CharCode.PERCENT: {\n if (arg == \"%\") return OperatorKind.REM;\n break;\n }\n case CharCode.AMPERSAND: {\n if (arg == \"&\") return OperatorKind.BITWISE_AND;\n break;\n }\n case CharCode.BAR: {\n if (arg == \"|\") return OperatorKind.BITWISE_OR;\n break;\n }\n case CharCode.CARET: {\n if (arg == \"^\") return OperatorKind.BITWISE_XOR;\n break;\n }\n case CharCode.EQUALS: {\n if (arg == \"==\") return OperatorKind.EQ;\n break;\n }\n case CharCode.EXCLAMATION: {\n if (arg == \"!=\") return OperatorKind.NE;\n break;\n }\n case CharCode.GREATERTHAN: {\n if (arg == \">\") return OperatorKind.GT;\n if (arg == \">=\") return OperatorKind.GE;\n if (arg == \">>\") return OperatorKind.BITWISE_SHR;\n if (arg == \">>>\") return OperatorKind.BITWISE_SHR_U;\n break;\n }\n case CharCode.LESSTHAN: {\n if (arg == \"<\") return OperatorKind.LT;\n if (arg == \"<=\") return OperatorKind.LE;\n if (arg == \"<<\") return OperatorKind.BITWISE_SHL;\n break;\n }\n }\n break;\n }\n case DecoratorKind.OPERATOR_PREFIX: {\n switch (arg.charCodeAt(0)) {\n case CharCode.PLUS: {\n if (arg == \"+\") return OperatorKind.PLUS;\n if (arg == \"++\") return OperatorKind.PREFIX_INC;\n break;\n }\n case CharCode.MINUS: {\n if (arg == \"-\") return OperatorKind.MINUS;\n if (arg == \"--\") return OperatorKind.PREFIX_DEC;\n break;\n }\n case CharCode.EXCLAMATION: {\n if (arg == \"!\") return OperatorKind.NOT;\n break;\n }\n case CharCode.TILDE: {\n if (arg == \"~\") return OperatorKind.BITWISE_NOT;\n break;\n }\n }\n break;\n }\n case DecoratorKind.OPERATOR_POSTFIX: {\n switch (arg.charCodeAt(0)) {\n case CharCode.PLUS: {\n if (arg == \"++\") return OperatorKind.POSTFIX_INC;\n break;\n }\n case CharCode.MINUS: {\n if (arg == \"--\") return OperatorKind.POSTFIX_DEC;\n break;\n }\n }\n break;\n }\n }\n return OperatorKind.INVALID;\n}\n\n/** Represents an AssemblyScript program. */\nexport class Program extends DiagnosticEmitter {\n\n /** Resolver instance. */\n resolver: Resolver;\n /** Array of sources. */\n sources: Source[] = [];\n /** Diagnostic offset used where successively obtaining the next diagnostic. */\n diagnosticsOffset: i32 = 0;\n /** Compiler options. */\n options: Options;\n /** Special native code source. */\n nativeSource: Source;\n /** Special native code file. */\n nativeFile: File;\n\n // lookup maps\n\n /** Files by unique internal name. */\n filesByName: Map = new Map();\n /** Elements by unique internal name in element space. */\n elementsByName: Map = new Map();\n /** Elements by declaration. */\n elementsByDeclaration: Map = new Map();\n /** Element instances by unique internal name. */\n instancesByName: Map = new Map();\n /** Classes backing basic types like `i32`. */\n typeClasses: Map = new Map();\n /** Managed classes contained in the program, by id. */\n managedClasses: Map = new Map();\n\n // standard references\n\n /** ArrayBufferView reference. */\n arrayBufferViewInstance: Class;\n /** ArrayBuffer instance reference. */\n arrayBufferInstance: Class;\n /** Array prototype reference. */\n arrayPrototype: ClassPrototype;\n /** Set prototype reference. */\n setPrototype: ClassPrototype;\n /** Map prototype reference. */\n mapPrototype: ClassPrototype;\n /** Fixed array prototype reference. */\n fixedArrayPrototype: ClassPrototype;\n /** Int8Array prototype. */\n i8ArrayPrototype: ClassPrototype;\n /** Int16Array prototype. */\n i16ArrayPrototype: ClassPrototype;\n /** Int32Array prototype. */\n i32ArrayPrototype: ClassPrototype;\n /** Int64Array prototype. */\n i64ArrayPrototype: ClassPrototype;\n /** Uint8Array prototype. */\n u8ArrayPrototype: ClassPrototype;\n /** Uint8ClampedArray prototype. */\n u8ClampedArrayPrototype: ClassPrototype;\n /** Uint16Array prototype. */\n u16ArrayPrototype: ClassPrototype;\n /** Uint32Array prototype. */\n u32ArrayPrototype: ClassPrototype;\n /** Uint64Array prototype. */\n u64ArrayPrototype: ClassPrototype;\n /** Float32Array prototype. */\n f32ArrayPrototype: ClassPrototype;\n /** Float64Array prototype. */\n f64ArrayPrototype: ClassPrototype;\n /** String instance reference. */\n stringInstance: Class;\n /** Abort function reference, if not explicitly disabled. */\n abortInstance: Function | null;\n\n // runtime references\n\n /** RT `__alloc(size: usize, id: u32): usize` */\n allocInstance: Function;\n /** RT `__realloc(ref: usize, newSize: usize): usize` */\n reallocInstance: Function;\n /** RT `__free(ref: usize): void` */\n freeInstance: Function;\n /** RT `__retain(ref: usize): usize` */\n retainInstance: Function;\n /** RT `__release(ref: usize): void` */\n releaseInstance: Function;\n /** RT `__collect(): void` */\n collectInstance: Function;\n /** RT `__visit(ref: usize, cookie: u32): void` */\n visitInstance: Function;\n /** RT `__typeinfo(id: u32): RTTIFlags` */\n typeinfoInstance: Function;\n /** RT `__instanceof(ref: usize, superId: u32): bool` */\n instanceofInstance: Function;\n /** RT `__allocArray(length: i32, alignLog2: usize, id: u32, data: usize = 0): usize` */\n allocArrayInstance: Function;\n\n /** Next class id. */\n nextClassId: u32 = 0;\n\n /** Constructs a new program, optionally inheriting parser diagnostics. */\n constructor(\n /** Shared array of diagnostic messages (emitted so far). */\n diagnostics: DiagnosticMessage[] | null = null\n ) {\n super(diagnostics);\n var nativeSource = new Source(LIBRARY_SUBST, \"[native code]\", SourceKind.LIBRARY);\n this.nativeSource = nativeSource;\n var nativeFile = new File(this, nativeSource);\n this.nativeFile = nativeFile;\n this.filesByName.set(nativeFile.internalName, nativeFile);\n this.resolver = new Resolver(this);\n }\n\n /** Writes a common runtime header to the specified buffer. */\n writeRuntimeHeader(buffer: Uint8Array, offset: i32, classInstance: Class, payloadSize: u32): void {\n // BLOCK {\n // mmInfo: usize // WASM64 TODO\n // gcInfo: u32\n // rtId: u32\n // rtSize: u32\n // }\n assert(payloadSize < (1 << 28)); // 1 bit BUFFERED + 3 bits color\n writeI32(payloadSize, buffer, offset);\n writeI32(1, buffer, offset + 4); // RC=1\n writeI32(classInstance.id, buffer, offset + 8);\n writeI32(payloadSize, buffer, offset + 12);\n }\n\n /** Gets the size of a runtime header. */\n get runtimeHeaderSize(): i32 {\n return 16;\n }\n\n /** Creates a native variable declaration. */\n makeNativeVariableDeclaration(\n /** The simple name of the variable */\n name: string,\n /** Flags indicating specific traits, e.g. `CONST`. */\n flags: CommonFlags = CommonFlags.NONE\n ): VariableDeclaration {\n var range = this.nativeSource.range;\n return Node.createVariableDeclaration(\n Node.createIdentifierExpression(name, range),\n null, null, null, flags, range\n );\n }\n\n /** Creates a native type declaration. */\n makeNativeTypeDeclaration(\n /** The simple name of the type. */\n name: string,\n /** Flags indicating specific traits, e.g. `GENERIC`. */\n flags: CommonFlags = CommonFlags.NONE\n ): TypeDeclaration {\n var range = this.nativeSource.range;\n var identifier = Node.createIdentifierExpression(name, range);\n return Node.createTypeDeclaration(\n identifier,\n null,\n Node.createOmittedType(range),\n null, flags, range\n );\n }\n\n // a dummy signature for programmatically generated native functions\n private nativeDummySignature: FunctionTypeNode | null = null;\n\n /** Creates a native function declaration. */\n makeNativeFunctionDeclaration(\n /** The simple name of the function. */\n name: string,\n /** Flags indicating specific traits, e.g. `DECLARE`. */\n flags: CommonFlags = CommonFlags.NONE\n ): FunctionDeclaration {\n var range = this.nativeSource.range;\n return Node.createFunctionDeclaration(\n Node.createIdentifierExpression(name, range),\n null,\n this.nativeDummySignature || (this.nativeDummySignature = Node.createFunctionType([],\n Node.createNamedType( // ^ AST signature doesn't really matter, is overridden anyway\n Node.createSimpleTypeName(CommonSymbols.void_, range),\n null, false, range\n ),\n null, false, range)\n ),\n null, null, flags, ArrowKind.NONE, range\n );\n }\n\n /** Creates a native namespace declaration. */\n makeNativeNamespaceDeclaration(\n /** The simple name of the namespace. */\n name: string,\n /** Flags indicating specific traits, e.g. `EXPORT`. */\n flags: CommonFlags = CommonFlags.NONE\n ): NamespaceDeclaration {\n var range = this.nativeSource.range;\n return Node.createNamespaceDeclaration(\n Node.createIdentifierExpression(name, range),\n [], null, flags, range\n );\n }\n\n /** Creates a native function. */\n makeNativeFunction(\n /** The simple name of the function. */\n name: string,\n /** Concrete function signature. */\n signature: Signature,\n /** Parent element, usually a file, class or namespace. */\n parent: Element = this.nativeFile,\n /** Flags indicating specific traits, e.g. `GENERIC`. */\n flags: CommonFlags = CommonFlags.NONE,\n /** Decorator flags representing built-in decorators. */\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\n ): Function {\n return new Function(\n name,\n new FunctionPrototype(\n name,\n parent,\n this.makeNativeFunctionDeclaration(name, flags),\n decoratorFlags\n ),\n signature\n );\n }\n\n /** Gets the (possibly merged) program element linked to the specified declaration. */\n getElementByDeclaration(declaration: DeclarationStatement): DeclaredElement {\n var elementsByDeclaration = this.elementsByDeclaration;\n assert(elementsByDeclaration.has(declaration));\n return elementsByDeclaration.get(declaration)!;\n }\n\n /** Initializes the program and its elements prior to compilation. */\n initialize(options: Options): void {\n this.options = options;\n\n // register native types\n this.registerNativeType(CommonSymbols.i8, Type.i8);\n this.registerNativeType(CommonSymbols.i16, Type.i16);\n this.registerNativeType(CommonSymbols.i32, Type.i32);\n this.registerNativeType(CommonSymbols.i64, Type.i64);\n this.registerNativeType(CommonSymbols.isize, options.isizeType);\n this.registerNativeType(CommonSymbols.u8, Type.u8);\n this.registerNativeType(CommonSymbols.u16, Type.u16);\n this.registerNativeType(CommonSymbols.u32, Type.u32);\n this.registerNativeType(CommonSymbols.u64, Type.u64);\n this.registerNativeType(CommonSymbols.usize, options.usizeType);\n this.registerNativeType(CommonSymbols.bool, Type.bool);\n this.registerNativeType(CommonSymbols.f32, Type.f32);\n this.registerNativeType(CommonSymbols.f64, Type.f64);\n this.registerNativeType(CommonSymbols.void_, Type.void);\n this.registerNativeType(CommonSymbols.number, Type.f64); // alias\n this.registerNativeType(CommonSymbols.boolean, Type.bool); // alias\n this.nativeFile.add(CommonSymbols.native, new TypeDefinition(\n CommonSymbols.native,\n this.nativeFile,\n this.makeNativeTypeDeclaration(CommonSymbols.native, CommonFlags.EXPORT | CommonFlags.GENERIC),\n DecoratorFlags.BUILTIN\n ));\n this.nativeFile.add(CommonSymbols.indexof, new TypeDefinition(\n CommonSymbols.indexof,\n this.nativeFile,\n this.makeNativeTypeDeclaration(CommonSymbols.indexof, CommonFlags.EXPORT | CommonFlags.GENERIC),\n DecoratorFlags.BUILTIN\n ));\n this.nativeFile.add(CommonSymbols.valueof, new TypeDefinition(\n CommonSymbols.valueof,\n this.nativeFile,\n this.makeNativeTypeDeclaration(CommonSymbols.valueof, CommonFlags.EXPORT | CommonFlags.GENERIC),\n DecoratorFlags.BUILTIN\n ));\n if (options.hasFeature(Feature.SIMD)) this.registerNativeType(CommonSymbols.v128, Type.v128);\n\n // register compiler hints\n this.registerConstantInteger(CommonSymbols.ASC_TARGET, Type.i32,\n i64_new(options.isWasm64 ? Target.WASM64 : Target.WASM32));\n this.registerConstantInteger(CommonSymbols.ASC_NO_ASSERT, Type.bool,\n i64_new(options.noAssert ? 1 : 0, 0));\n this.registerConstantInteger(CommonSymbols.ASC_MEMORY_BASE, Type.i32,\n i64_new(options.memoryBase, 0));\n this.registerConstantInteger(CommonSymbols.ASC_OPTIMIZE_LEVEL, Type.i32,\n i64_new(options.optimizeLevelHint, 0));\n this.registerConstantInteger(CommonSymbols.ASC_SHRINK_LEVEL, Type.i32,\n i64_new(options.shrinkLevelHint, 0));\n this.registerConstantInteger(CommonSymbols.ASC_FEATURE_MUTABLE_GLOBAL, Type.bool,\n i64_new(options.hasFeature(Feature.MUTABLE_GLOBAL) ? 1 : 0, 0));\n this.registerConstantInteger(CommonSymbols.ASC_FEATURE_SIGN_EXTENSION, Type.bool,\n i64_new(options.hasFeature(Feature.SIGN_EXTENSION) ? 1 : 0, 0));\n this.registerConstantInteger(CommonSymbols.ASC_FEATURE_BULK_MEMORY, Type.bool,\n i64_new(options.hasFeature(Feature.BULK_MEMORY) ? 1 : 0, 0));\n this.registerConstantInteger(CommonSymbols.ASC_FEATURE_SIMD, Type.bool,\n i64_new(options.hasFeature(Feature.SIMD) ? 1 : 0, 0));\n this.registerConstantInteger(CommonSymbols.ASC_FEATURE_THREADS, Type.bool,\n i64_new(options.hasFeature(Feature.THREADS) ? 1 : 0, 0));\n\n // remember deferred elements\n var queuedImports = new Array();\n var queuedExports = new Map>();\n var queuedExportsStar = new Map();\n var queuedExtends = new Array();\n var queuedImplements = new Array();\n\n // initialize relevant declaration-like statements of the entire program\n for (let i = 0, k = this.sources.length; i < k; ++i) {\n let source = this.sources[i];\n let file = new File(this, source);\n this.filesByName.set(file.internalName, file);\n let statements = source.statements;\n for (let j = 0, l = statements.length; j < l; ++j) {\n let statement = statements[j];\n switch (statement.kind) {\n case NodeKind.EXPORT: {\n this.initializeExports(statement, file, queuedExports, queuedExportsStar);\n break;\n }\n case NodeKind.EXPORTDEFAULT: {\n this.initializeExportDefault(statement, file, queuedExtends, queuedImplements);\n break;\n }\n case NodeKind.IMPORT: {\n this.initializeImports(statement, file, queuedImports, queuedExports);\n break;\n }\n case NodeKind.VARIABLE: {\n this.initializeVariables(statement, file);\n break;\n }\n case NodeKind.CLASSDECLARATION: {\n this.initializeClass(statement, file, queuedExtends, queuedImplements);\n break;\n }\n case NodeKind.ENUMDECLARATION: {\n this.initializeEnum(statement, file);\n break;\n }\n case NodeKind.FUNCTIONDECLARATION: {\n this.initializeFunction(statement, file);\n break;\n }\n case NodeKind.INTERFACEDECLARATION: {\n this.initializeInterface(statement, file);\n break;\n }\n case NodeKind.NAMESPACEDECLARATION: {\n this.initializeNamespace(statement, file, queuedExtends, queuedImplements);\n break;\n }\n case NodeKind.TYPEDECLARATION: {\n this.initializeTypeDefinition(statement, file);\n break;\n }\n }\n }\n }\n\n // queued exports * should be linkable now that all files have been processed\n for (let [file, exportsStar] of queuedExportsStar) {\n for (let i = 0, k = exportsStar.length; i < k; ++i) {\n let exportStar = exportsStar[i];\n let foreignFile = this.lookupForeignFile(exportStar.foreignPath, exportStar.foreignPathAlt);\n if (!foreignFile) {\n this.error(\n DiagnosticCode.File_0_not_found,\n exportStar.pathLiteral.range, exportStar.pathLiteral.value\n );\n continue;\n }\n file.ensureExportStar(foreignFile);\n }\n }\n\n // queued imports should be resolvable now through traversing exports and queued exports\n for (let i = 0, k = queuedImports.length; i < k; ++i) {\n let queuedImport = queuedImports[i];\n let foreignIdentifier = queuedImport.foreignIdentifier;\n if (foreignIdentifier) { // i.e. import { foo [as bar] } from \"./baz\"\n let element = this.lookupForeign(\n foreignIdentifier.text,\n queuedImport.foreignPath,\n queuedImport.foreignPathAlt,\n queuedExports\n );\n if (element) {\n queuedImport.localFile.add(\n queuedImport.localIdentifier.text,\n element,\n true // isImport\n );\n } else {\n // FIXME: file not found is not reported if this happens?\n this.error(\n DiagnosticCode.Module_0_has_no_exported_member_1,\n foreignIdentifier.range, queuedImport.foreignPath, foreignIdentifier.text\n );\n }\n } else { // i.e. import * as bar from \"./bar\"\n let foreignFile = this.lookupForeignFile(queuedImport.foreignPath, queuedImport.foreignPathAlt);\n if (foreignFile) {\n let localFile = queuedImport.localFile;\n let localName = queuedImport.localIdentifier.text;\n localFile.add(\n localName,\n foreignFile.asImportedNamespace(\n localName,\n localFile\n ),\n true // isImport\n );\n } else {\n assert(false); // already reported by the parser not finding the file\n }\n }\n }\n\n // queued exports should be resolvable now that imports are finalized\n for (let [file, exports] of queuedExports) {\n for (let [exportName, queuedExport] of exports) {\n let localName = queuedExport.localIdentifier.text;\n let foreignPath = queuedExport.foreignPath;\n if (foreignPath) { // i.e. export { foo [as bar] } from \"./baz\"\n let element = this.lookupForeign(\n localName,\n foreignPath,\n assert(queuedExport.foreignPathAlt), // must be set if foreignPath is\n queuedExports\n );\n if (element) {\n file.ensureExport(exportName, element);\n } else {\n this.error(\n DiagnosticCode.Module_0_has_no_exported_member_1,\n queuedExport.localIdentifier.range,\n foreignPath, localName\n );\n }\n } else { // i.e. export { foo [as bar] }\n let element = file.lookupInSelf(localName);\n if (element) {\n file.ensureExport(exportName, element);\n } else {\n let globalElement = this.lookupGlobal(localName);\n if (globalElement && globalElement instanceof DeclaredElement) { // export { memory }\n file.ensureExport(exportName, globalElement);\n } else {\n this.error(\n DiagnosticCode.Module_0_has_no_exported_member_1,\n queuedExport.foreignIdentifier.range,\n file.internalName, queuedExport.foreignIdentifier.text\n );\n }\n }\n }\n }\n }\n\n // register ArrayBuffer (id=0), String (id=1), ArrayBufferView (id=2)\n assert(this.nextClassId == 0);\n this.arrayBufferInstance = this.requireClass(CommonSymbols.ArrayBuffer);\n assert(this.arrayBufferInstance.id == 0);\n this.stringInstance = this.requireClass(CommonSymbols.String);\n assert(this.stringInstance.id == 1);\n this.arrayBufferViewInstance = this.requireClass(CommonSymbols.ArrayBufferView);\n assert(this.arrayBufferViewInstance.id == 2);\n\n // register classes backing basic types\n this.registerNativeTypeClass(TypeKind.I8, CommonSymbols.I8);\n this.registerNativeTypeClass(TypeKind.I16, CommonSymbols.I16);\n this.registerNativeTypeClass(TypeKind.I32, CommonSymbols.I32);\n this.registerNativeTypeClass(TypeKind.I64, CommonSymbols.I64);\n this.registerNativeTypeClass(TypeKind.ISIZE, CommonSymbols.Isize);\n this.registerNativeTypeClass(TypeKind.U8, CommonSymbols.U8);\n this.registerNativeTypeClass(TypeKind.U16, CommonSymbols.U16);\n this.registerNativeTypeClass(TypeKind.U32, CommonSymbols.U32);\n this.registerNativeTypeClass(TypeKind.U64, CommonSymbols.U64);\n this.registerNativeTypeClass(TypeKind.USIZE, CommonSymbols.Usize);\n this.registerNativeTypeClass(TypeKind.BOOL, CommonSymbols.Bool);\n this.registerNativeTypeClass(TypeKind.F32, CommonSymbols.F32);\n this.registerNativeTypeClass(TypeKind.F64, CommonSymbols.F64);\n if (options.hasFeature(Feature.SIMD)) this.registerNativeTypeClass(TypeKind.V128, CommonSymbols.V128);\n\n // register views but don't instantiate them yet\n this.i8ArrayPrototype = this.require(CommonSymbols.Int8Array, ElementKind.CLASS_PROTOTYPE);\n this.i16ArrayPrototype = this.require(CommonSymbols.Int16Array, ElementKind.CLASS_PROTOTYPE);\n this.i32ArrayPrototype = this.require(CommonSymbols.Int32Array, ElementKind.CLASS_PROTOTYPE);\n this.i64ArrayPrototype = this.require(CommonSymbols.Int64Array, ElementKind.CLASS_PROTOTYPE);\n this.u8ArrayPrototype = this.require(CommonSymbols.Uint8Array, ElementKind.CLASS_PROTOTYPE);\n this.u8ClampedArrayPrototype = this.require(CommonSymbols.Uint8ClampedArray, ElementKind.CLASS_PROTOTYPE);\n this.u16ArrayPrototype = this.require(CommonSymbols.Uint16Array, ElementKind.CLASS_PROTOTYPE);\n this.u32ArrayPrototype = this.require(CommonSymbols.Uint32Array, ElementKind.CLASS_PROTOTYPE);\n this.u64ArrayPrototype = this.require(CommonSymbols.Uint64Array, ElementKind.CLASS_PROTOTYPE);\n this.f32ArrayPrototype = this.require(CommonSymbols.Float32Array, ElementKind.CLASS_PROTOTYPE);\n this.f64ArrayPrototype = this.require(CommonSymbols.Float64Array, ElementKind.CLASS_PROTOTYPE);\n\n // resolve base prototypes of derived classes\n var resolver = this.resolver;\n for (let i = 0, k = queuedExtends.length; i < k; ++i) {\n let thisPrototype = queuedExtends[i];\n let extendsNode = assert(thisPrototype.extendsNode); // must be present if in queuedExtends\n let baseElement = resolver.resolveTypeName(extendsNode.name, thisPrototype.parent); // reports\n if (!baseElement) continue;\n if (baseElement.kind == ElementKind.CLASS_PROTOTYPE) {\n let basePrototype = baseElement;\n if (basePrototype.hasDecorator(DecoratorFlags.SEALED)) {\n this.error(\n DiagnosticCode.Class_0_is_sealed_and_cannot_be_extended,\n extendsNode.range, (baseElement).identifierNode.text\n );\n }\n if (\n basePrototype.hasDecorator(DecoratorFlags.UNMANAGED) !=\n thisPrototype.hasDecorator(DecoratorFlags.UNMANAGED)\n ) {\n this.error(\n DiagnosticCode.Unmanaged_classes_cannot_extend_managed_classes_and_vice_versa,\n Range.join(thisPrototype.identifierNode.range, extendsNode.range)\n );\n }\n thisPrototype.basePrototype = basePrototype;\n } else {\n this.error(\n DiagnosticCode.A_class_may_only_extend_another_class,\n extendsNode.range\n );\n }\n }\n\n // set up global aliases\n {\n let globalAliases = options.globalAliases;\n if (globalAliases) {\n for (let [alias, name] of globalAliases) {\n if (!name.length) continue; // explicitly disabled\n let firstChar = name.charCodeAt(0);\n if (firstChar >= CharCode._0 && firstChar <= CharCode._9) {\n this.registerConstantInteger(alias, Type.i32, i64_new(parseInt(name, 10)));\n } else {\n let elementsByName = this.elementsByName;\n let element = elementsByName.get(name);\n if (element) {\n if (elementsByName.has(alias)) throw new Error(\"duplicate global element: \" + name);\n elementsByName.set(alias, element);\n }\n else throw new Error(\"no such global element: \" + name);\n }\n }\n }\n }\n\n // register stdlib components\n this.arrayPrototype = this.require(CommonSymbols.Array, ElementKind.CLASS_PROTOTYPE);\n this.fixedArrayPrototype = this.require(CommonSymbols.FixedArray, ElementKind.CLASS_PROTOTYPE);\n this.setPrototype = this.require(CommonSymbols.Set, ElementKind.CLASS_PROTOTYPE);\n this.mapPrototype = this.require(CommonSymbols.Map, ElementKind.CLASS_PROTOTYPE);\n this.abortInstance = this.lookupFunction(CommonSymbols.abort); // can be disabled\n this.allocInstance = this.requireFunction(CommonSymbols.alloc);\n this.reallocInstance = this.requireFunction(CommonSymbols.realloc);\n this.freeInstance = this.requireFunction(CommonSymbols.free);\n this.retainInstance = this.requireFunction(CommonSymbols.retain);\n this.releaseInstance = this.requireFunction(CommonSymbols.release);\n this.collectInstance = this.requireFunction(CommonSymbols.collect);\n this.typeinfoInstance = this.requireFunction(CommonSymbols.typeinfo);\n this.instanceofInstance = this.requireFunction(CommonSymbols.instanceof_);\n this.visitInstance = this.requireFunction(CommonSymbols.visit);\n this.allocArrayInstance = this.requireFunction(CommonSymbols.allocArray);\n\n // mark module exports, i.e. to apply proper wrapping behavior on the boundaries\n for (let file of this.filesByName.values()) {\n let exports = file.exports;\n if (!(file.source.isEntry && exports)) continue;\n for (let element of exports.values()) this.markModuleExport(element);\n }\n }\n\n /** Requires that a global library element of the specified kind is present and returns it. */\n private require(name: string, kind: ElementKind): Element {\n var element = this.lookupGlobal(name);\n if (!element) throw new Error(\"missing \" + name);\n if (element.kind != kind) throw new Error(\"unexpected \" + name);\n return element;\n }\n\n /** Requires that a non-generic global class is present and returns it. */\n private requireClass(name: string): Class {\n var prototype = this.require(name, ElementKind.CLASS_PROTOTYPE);\n var resolved = this.resolver.resolveClass(prototype, null);\n if (!resolved) throw new Error(\"invalid \" + name);\n return resolved;\n }\n\n /** Obtains a non-generic global function and returns it. Returns `null` if it does not exist. */\n private lookupFunction(name: string): Function | null {\n var prototype = this.lookupGlobal(name);\n if (!prototype || prototype.kind != ElementKind.FUNCTION_PROTOTYPE) return null;\n return this.resolver.resolveFunction(prototype, null);\n }\n\n /** Requires that a non-generic global function is present and returns it. */\n private requireFunction(name: string): Function {\n var prototype = this.require(name, ElementKind.FUNCTION_PROTOTYPE);\n var resolved = this.resolver.resolveFunction(prototype, null);\n if (!resolved) throw new Error(\"invalid \" + name);\n return resolved;\n }\n\n /** Marks an element and its children as a module export. */\n private markModuleExport(element: Element): void {\n element.set(CommonFlags.MODULE_EXPORT);\n switch (element.kind) {\n case ElementKind.CLASS_PROTOTYPE: {\n let instanceMembers = (element).instanceMembers;\n if (instanceMembers) for (let member of instanceMembers.values()) this.markModuleExport(member);\n break;\n }\n case ElementKind.PROPERTY_PROTOTYPE: {\n let getterPrototype = (element).getterPrototype;\n if (getterPrototype) this.markModuleExport(getterPrototype);\n let setterPrototype = (element).setterPrototype;\n if (setterPrototype) this.markModuleExport(setterPrototype);\n break;\n }\n case ElementKind.PROPERTY:\n case ElementKind.FUNCTION:\n case ElementKind.FIELD:\n case ElementKind.CLASS: assert(false); // assumes that there are no instances yet\n }\n {\n let members = element.members;\n if (members) for (let member of members.values()) this.markModuleExport(member);\n }\n }\n\n /** Registers a native type with the program. */\n private registerNativeType(name: string, type: Type): void {\n var element = new TypeDefinition(\n name,\n this.nativeFile,\n this.makeNativeTypeDeclaration(name, CommonFlags.EXPORT),\n DecoratorFlags.BUILTIN\n );\n element.setType(type);\n this.nativeFile.add(name, element);\n }\n\n /** Registers the backing class of a native type. */\n private registerNativeTypeClass(typeKind: TypeKind, className: string): void {\n assert(!this.typeClasses.has(typeKind));\n var element = this.lookupGlobal(className);\n if (element) {\n assert(element.kind == ElementKind.CLASS_PROTOTYPE);\n let classElement = this.resolver.resolveClass(element, null);\n if (classElement) this.typeClasses.set(typeKind, classElement);\n }\n }\n\n /** Registers a constant integer value within the global scope. */\n private registerConstantInteger(name: string, type: Type, value: I64): void {\n assert(type.is(TypeFlags.INTEGER)); // must be an integer type\n var global = new Global(\n name,\n this.nativeFile,\n DecoratorFlags.NONE,\n this.makeNativeVariableDeclaration(name, CommonFlags.CONST | CommonFlags.EXPORT)\n );\n global.setConstantIntegerValue(value, type);\n this.nativeFile.add(name, global);\n }\n\n /** Registers a constant float value within the global scope. */\n private registerConstantFloat(name: string, type: Type, value: f64): void {\n assert(type.is(TypeFlags.FLOAT)); // must be a float type\n var global = new Global(\n name,\n this.nativeFile,\n DecoratorFlags.NONE,\n this.makeNativeVariableDeclaration(name, CommonFlags.CONST | CommonFlags.EXPORT)\n );\n global.setConstantFloatValue(value, type);\n this.nativeFile.add(name, global);\n }\n\n /** Ensures that the given global element exists. Attempts to merge duplicates. */\n ensureGlobal(name: string, element: DeclaredElement): DeclaredElement {\n var elementsByName = this.elementsByName;\n if (elementsByName.has(name)) {\n let actual = elementsByName.get(name)!;\n // NOTE: this is effectively only performed when merging native types with\n // their respective namespaces in std/builtins, but can also trigger when a\n // user has multiple global elements of the same name in different files,\n // which might result in unexpected shared symbols accross files. considering\n // this a wonky feature for now that we might want to revisit later.\n if (actual !== element) {\n let merged = tryMerge(elementsByName.get(name)!, element);\n if (!merged) {\n this.error(\n DiagnosticCode.Duplicate_identifier_0,\n element.identifierNode.range, name\n );\n return element;\n }\n element = merged;\n }\n }\n elementsByName.set(name, element);\n return element;\n }\n\n /** Looks up the element of the specified name in the global scope. */\n lookupGlobal(name: string): Element | null {\n var elements = this.elementsByName;\n if (elements.has(name)) return elements.get(name);\n return null;\n }\n\n /** Looks up the element of the specified name in the global scope. Errors if not present. */\n requireGlobal(name: string): Element {\n var elements = this.elementsByName;\n if (elements.has(name)) return elements.get(name)!;\n throw new Error(\"missing global\");\n }\n\n /** Tries to locate a foreign file given its normalized path. */\n private lookupForeignFile(\n /** Normalized path to the other file. */\n foreignPath: string,\n /** Alternative normalized path to the other file. */\n foreignPathAlt: string\n ): File | null {\n var filesByName = this.filesByName;\n return filesByName.has(foreignPath)\n ? filesByName.get(foreignPath)!\n : filesByName.has(foreignPathAlt)\n ? filesByName.get(foreignPathAlt)!\n : null;\n }\n\n /** Tries to locate a foreign element by traversing exports and queued exports. */\n private lookupForeign(\n /** Identifier within the other file. */\n foreignName: string,\n /** Normalized path to the other file. */\n foreignPath: string,\n /** Alternative normalized path to the other file. */\n foreignPathAlt: string,\n /** So far queued exports. */\n queuedExports: Map>\n ): DeclaredElement | null {\n do {\n let foreignFile = this.lookupForeignFile(foreignPath, foreignPathAlt);\n if (!foreignFile) return null; // no such file\n\n // search already resolved exports\n let element = foreignFile.lookupExport(foreignName);\n if (element) return element;\n\n // otherwise traverse queued exports\n if (queuedExports.has(foreignFile)) {\n let fileQueuedExports = queuedExports.get(foreignFile)!;\n if (fileQueuedExports.has(foreignName)) {\n let queuedExport = fileQueuedExports.get(foreignName)!;\n if (queuedExport.foreignPath) { // imported from another file\n foreignName = queuedExport.localIdentifier.text;\n foreignPath = queuedExport.foreignPath;\n foreignPathAlt = assert(queuedExport.foreignPathAlt);\n continue;\n } else { // local element of this file\n element = foreignFile.lookupInSelf(queuedExport.localIdentifier.text);\n if (element) return element;\n }\n }\n }\n break;\n } while (true);\n return null;\n }\n\n /** Validates that only supported decorators are present. */\n private checkDecorators(\n /** Decorators present on an element. */\n decorators: DecoratorNode[] | null,\n /** Accepted decorator flags. Emits diagnostics if any other decorators are present. */\n acceptedFlags: DecoratorFlags\n ): DecoratorFlags {\n var flags = DecoratorFlags.NONE;\n if (decorators) {\n for (let i = 0, k = decorators.length; i < k; ++i) {\n let decorator = decorators[i];\n let kind = decoratorNameToKind(decorator.name);\n let flag = decoratorKindToFlag(kind);\n if (flag) {\n if (flag == DecoratorFlags.BUILTIN) {\n if (!(acceptedFlags & flag) && !decorator.range.source.isLibrary) {\n this.error(\n DiagnosticCode.Decorator_0_is_not_valid_here,\n decorator.range, decorator.name.range.toString()\n );\n } else {\n flags |= flag;\n }\n } else if (!(acceptedFlags & flag)) {\n this.error(\n DiagnosticCode.Decorator_0_is_not_valid_here,\n decorator.range, decorator.name.range.toString()\n );\n } else if (flags & flag) {\n this.error(\n DiagnosticCode.Duplicate_decorator,\n decorator.range, decorator.name.range.toString()\n );\n } else {\n flags |= flag;\n }\n }\n }\n }\n return flags;\n }\n\n /** Initializes a class declaration. */\n private initializeClass(\n /** The declaration to initialize. */\n declaration: ClassDeclaration,\n /** Parent element, usually a file or namespace. */\n parent: Element,\n /** So far queued `extends` clauses. */\n queuedExtends: ClassPrototype[],\n /** So far queued `implements` clauses. */\n queuedImplements: ClassPrototype[]\n ): ClassPrototype | null {\n var name = declaration.name.text;\n var element = new ClassPrototype(\n name,\n parent,\n declaration,\n this.checkDecorators(declaration.decorators,\n DecoratorFlags.GLOBAL |\n DecoratorFlags.SEALED |\n DecoratorFlags.UNMANAGED\n )\n );\n if (!parent.add(name, element)) return null;\n\n var implementsTypes = declaration.implementsTypes;\n if (implementsTypes) {\n let numImplementsTypes = implementsTypes.length;\n // cannot implement interfaces when unmanaged\n if (element.hasDecorator(DecoratorFlags.UNMANAGED)) {\n if (numImplementsTypes) {\n this.error(\n DiagnosticCode.Unmanaged_classes_cannot_implement_interfaces,\n Range.join(\n declaration.name.range,\n implementsTypes[numImplementsTypes - 1].range\n )\n );\n }\n } else if (numImplementsTypes) {\n // remember classes that implement interfaces\n for (let i = 0; i < numImplementsTypes; ++i) {\n this.warning( // TODO: not yet supported\n DiagnosticCode.Operation_not_supported,\n implementsTypes[i].range\n );\n }\n queuedImplements.push(element);\n }\n }\n // remember classes that extend another class\n if (declaration.extendsType) queuedExtends.push(element);\n\n // initialize members\n var memberDeclarations = declaration.members;\n for (let i = 0, k = memberDeclarations.length; i < k; ++i) {\n let memberDeclaration = memberDeclarations[i];\n switch (memberDeclaration.kind) {\n case NodeKind.FIELDDECLARATION: {\n this.initializeField(memberDeclaration, element);\n break;\n }\n case NodeKind.METHODDECLARATION: {\n if (memberDeclaration.isAny(CommonFlags.GET | CommonFlags.SET)) {\n this.initializeProperty(memberDeclaration, element);\n } else {\n this.initializeMethod(memberDeclaration, element);\n }\n break;\n }\n case NodeKind.INDEXSIGNATUREDECLARATION: break; // ignored for now\n default: assert(false); // class member expected\n }\n }\n return element;\n }\n\n /** Initializes a field of a class or interface. */\n private initializeField(\n /** The declaration to initialize. */\n declaration: FieldDeclaration,\n /** Parent class. */\n parent: ClassPrototype\n ): void {\n var name = declaration.name.text;\n var decorators = declaration.decorators;\n var element: DeclaredElement;\n if (declaration.is(CommonFlags.STATIC)) { // global variable\n assert(parent.kind != ElementKind.INTERFACE_PROTOTYPE);\n element = new Global(\n name,\n parent,\n this.checkDecorators(decorators,\n (declaration.is(CommonFlags.READONLY)\n ? DecoratorFlags.INLINE\n : DecoratorFlags.NONE\n ) | DecoratorFlags.LAZY | DecoratorFlags.UNSAFE\n ),\n declaration\n );\n if (!parent.add(name, element)) return;\n } else { // actual instance field\n assert(!declaration.isAny(CommonFlags.ABSTRACT | CommonFlags.GET | CommonFlags.SET));\n element = new FieldPrototype(\n name,\n parent,\n declaration,\n this.checkDecorators(decorators, DecoratorFlags.UNSAFE)\n );\n if (!parent.addInstance(name, element)) return;\n }\n }\n\n /** Initializes a method of a class or interface. */\n private initializeMethod(\n /** The declaration to initialize. */\n declaration: MethodDeclaration,\n /** Parent class. */\n parent: ClassPrototype\n ): void {\n var name = declaration.name.text;\n var isStatic = declaration.is(CommonFlags.STATIC);\n var acceptedFlags = DecoratorFlags.INLINE | DecoratorFlags.UNSAFE;\n if (!declaration.is(CommonFlags.GENERIC)) {\n acceptedFlags |= DecoratorFlags.OPERATOR_BINARY\n | DecoratorFlags.OPERATOR_PREFIX\n | DecoratorFlags.OPERATOR_POSTFIX;\n }\n var element = new FunctionPrototype(\n name,\n parent,\n declaration,\n this.checkDecorators(declaration.decorators, acceptedFlags)\n );\n if (isStatic) { // global function\n assert(declaration.name.kind != NodeKind.CONSTRUCTOR);\n if (!parent.add(name, element)) return;\n } else { // actual instance method\n if (!parent.addInstance(name, element)) return;\n }\n this.checkOperatorOverloads(declaration.decorators, element, parent);\n }\n\n /** Checks that operator overloads are generally valid, if present. */\n private checkOperatorOverloads(\n /** Decorators to check. */\n decorators: DecoratorNode[] | null,\n /** Decorated method. */\n prototype: FunctionPrototype,\n /** Parent class. */\n classPrototype: ClassPrototype\n ): void {\n if (decorators) {\n for (let i = 0, k = decorators.length; i < k; ++i) {\n let decorator = decorators[i];\n switch (decorator.decoratorKind) {\n case DecoratorKind.OPERATOR:\n case DecoratorKind.OPERATOR_BINARY:\n case DecoratorKind.OPERATOR_PREFIX:\n case DecoratorKind.OPERATOR_POSTFIX: {\n let numArgs = decorator.arguments && decorator.arguments.length || 0;\n if (numArgs == 1) {\n let firstArg = (decorator.arguments)[0];\n if (\n firstArg.kind == NodeKind.LITERAL &&\n (firstArg).literalKind == LiteralKind.STRING\n ) {\n let kind = operatorKindFromDecorator(\n decorator.decoratorKind,\n (firstArg).value\n );\n if (kind == OperatorKind.INVALID) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n firstArg.range\n );\n } else {\n let overloads = classPrototype.overloadPrototypes;\n if (overloads.has(kind)) {\n this.error(\n DiagnosticCode.Duplicate_function_implementation,\n firstArg.range\n );\n } else {\n prototype.operatorKind = kind;\n overloads.set(kind, prototype);\n }\n }\n } else {\n this.error(\n DiagnosticCode.String_literal_expected,\n firstArg.range\n );\n }\n } else {\n this.error(\n DiagnosticCode.Expected_0_arguments_but_got_1,\n decorator.range, \"1\", numArgs.toString(10)\n );\n }\n }\n }\n }\n }\n }\n\n /** Ensures that the property introduced by the specified getter or setter exists.*/\n private ensureProperty(\n /** The declaration of the getter or setter introducing the property. */\n declaration: MethodDeclaration,\n /** Parent class. */\n parent: ClassPrototype\n ): PropertyPrototype | null {\n var name = declaration.name.text;\n if (declaration.is(CommonFlags.STATIC)) {\n let parentMembers = parent.members;\n if (parentMembers && parentMembers.has(name)) {\n let element = parentMembers.get(name)!;\n if (element.kind == ElementKind.PROPERTY_PROTOTYPE) return element;\n } else {\n let element = new PropertyPrototype(name, parent, declaration);\n if (!parent.add(name, element)) return null;\n return element;\n }\n } else {\n let parentMembers = parent.instanceMembers;\n if (parentMembers && parentMembers.has(name)) {\n let element = parentMembers.get(name);\n if (element.kind == ElementKind.PROPERTY_PROTOTYPE) return element;\n } else {\n let element = new PropertyPrototype(name, parent, declaration);\n if (!parent.addInstance(name, element)) return null;\n return element;\n }\n }\n this.error(\n DiagnosticCode.Duplicate_property_0,\n declaration.name.range, name\n );\n return null;\n }\n\n /** Initializes a property of a class. */\n private initializeProperty(\n /** The declaration of the getter or setter. */\n declaration: MethodDeclaration,\n /** Parent class. */\n parent: ClassPrototype\n ): void {\n var property = this.ensureProperty(declaration, parent);\n if (!property) return;\n var name = declaration.name.text;\n var isGetter = declaration.is(CommonFlags.GET);\n if (isGetter) {\n if (property.getterPrototype) {\n this.error(\n DiagnosticCode.Duplicate_property_0,\n declaration.name.range, name\n );\n return;\n }\n } else {\n if (property.setterPrototype) {\n this.error(\n DiagnosticCode.Duplicate_property_0,\n declaration.name.range, name\n );\n return;\n }\n }\n var element = new FunctionPrototype(\n (isGetter ? GETTER_PREFIX : SETTER_PREFIX) + name,\n property,\n declaration,\n this.checkDecorators(declaration.decorators,\n DecoratorFlags.INLINE | DecoratorFlags.UNSAFE\n )\n );\n if (isGetter) {\n property.getterPrototype = element;\n } else {\n property.setterPrototype = element;\n }\n }\n\n /** Initializes an enum. */\n private initializeEnum(\n /** The declaration to initialize. */\n declaration: EnumDeclaration,\n /** Parent element, usually a file or namespace. */\n parent: Element\n ): Enum | null {\n var name = declaration.name.text;\n var element = new Enum(\n name,\n parent,\n declaration,\n this.checkDecorators(declaration.decorators,\n DecoratorFlags.GLOBAL |\n DecoratorFlags.INLINE |\n DecoratorFlags.LAZY\n )\n );\n if (!parent.add(name, element)) return null;\n var values = declaration.values;\n for (let i = 0, k = values.length; i < k; ++i) {\n this.initializeEnumValue(values[i], element);\n }\n return element;\n }\n\n /** Initializes an enum value. */\n private initializeEnumValue(\n /** The declaration to initialize. */\n declaration: EnumValueDeclaration,\n /** Parent enum. */\n parent: Enum\n ): void {\n var name = declaration.name.text;\n var element = new EnumValue(\n name,\n parent,\n declaration,\n this.checkDecorators(declaration.decorators,\n DecoratorFlags.NONE\n )\n );\n if (!parent.add(name, element)) return;\n }\n\n /** Initializes an `export` statement. */\n private initializeExports(\n /** The statement to initialize. */\n statement: ExportStatement,\n /** Parent file. */\n parent: File,\n /** So far queued `export`s. */\n queuedExports: Map>,\n /** So far queued `export *`s. */\n queuedExportsStar: Map\n ): void {\n var members = statement.members;\n if (members) { // export { foo, bar } [from \"./baz\"]\n for (let i = 0, k = members.length; i < k; ++i) {\n this.initializeExport(members[i], parent, statement.internalPath, queuedExports);\n }\n } else { // export * from \"./baz\"\n let queued: QueuedExportStar[];\n if (queuedExportsStar.has(parent)) queued = queuedExportsStar.get(parent)!;\n else queuedExportsStar.set(parent, queued = []);\n let foreignPath = assert(statement.internalPath); // must be set for export *\n queued.push(new QueuedExportStar(\n foreignPath,\n foreignPath.endsWith(INDEX_SUFFIX) // strip or add index depending on what's already present\n ? foreignPath.substring(0, foreignPath.length - INDEX_SUFFIX.length)\n : foreignPath + INDEX_SUFFIX,\n assert(statement.path)\n ));\n }\n }\n\n /** Initializes a single `export` member. Does not handle `export *`. */\n private initializeExport(\n /** The member to initialize. */\n member: ExportMember,\n /** Local file. */\n localFile: File,\n /** Path to the other file, if present. */\n foreignPath: string | null,\n /** So far queued `export`s. */\n queuedExports: Map>\n ): void {\n var localName = member.localName.text;\n var foreignName = member.exportedName.text;\n\n // check for duplicates\n var element = localFile.lookupExport(foreignName);\n if (element) {\n this.error(\n DiagnosticCode.Export_declaration_conflicts_with_exported_declaration_of_0,\n member.exportedName.range, foreignName\n );\n return;\n }\n // local element, i.e. export { foo [as bar] }\n if (foreignPath === null) {\n\n // resolve right away if the local element already exists\n if (element = localFile.lookupInSelf(localName)) {\n localFile.ensureExport(foreignName, element);\n\n // otherwise queue it\n } else {\n let queued: Map;\n if (queuedExports.has(localFile)) queued = queuedExports.get(localFile)!;\n else queuedExports.set(localFile, queued = new Map());\n queued.set(foreignName, new QueuedExport(\n member.localName,\n member.exportedName,\n null, null\n ));\n }\n\n // foreign element, i.e. export { foo } from \"./bar\"\n } else {\n let queued: Map;\n if (queuedExports.has(localFile)) queued = queuedExports.get(localFile)!;\n else queuedExports.set(localFile, queued = new Map());\n queued.set(foreignName, new QueuedExport(\n member.localName,\n member.exportedName,\n foreignPath,\n foreignPath.endsWith(INDEX_SUFFIX) // strip or add index depending on what's already present\n ? foreignPath.substring(0, foreignPath.length - INDEX_SUFFIX.length)\n : foreignPath + INDEX_SUFFIX\n ));\n }\n }\n\n private initializeExportDefault(\n /** The statement to initialize. */\n statement: ExportDefaultStatement,\n /** Parent file. */\n parent: File,\n /** So far queued `extends` clauses. */\n queuedExtends: Array,\n /** So far queued `implements` clauses. */\n queuedImplements: ClassPrototype[]\n ): void {\n var declaration = statement.declaration;\n var element: DeclaredElement | null = null;\n switch (declaration.kind) {\n case NodeKind.ENUMDECLARATION: {\n element = this.initializeEnum(declaration, parent);\n break;\n }\n case NodeKind.FUNCTIONDECLARATION: {\n element = this.initializeFunction(declaration, parent);\n break;\n }\n case NodeKind.CLASSDECLARATION: {\n element = this.initializeClass(declaration, parent, queuedExtends, queuedImplements);\n break;\n }\n case NodeKind.INTERFACEDECLARATION: {\n element = this.initializeInterface(declaration, parent);\n break;\n }\n case NodeKind.NAMESPACEDECLARATION: {\n element = this.initializeNamespace(declaration, parent, queuedExtends, queuedImplements);\n break;\n }\n default: assert(false);\n }\n if (element) {\n let exports = parent.exports;\n if (!exports) parent.exports = exports = new Map();\n else if (exports.has(\"default\")) {\n this.error(\n DiagnosticCode.Duplicate_identifier_0,\n declaration.name.range, \"default\"\n );\n return;\n }\n exports.set(\"default\", element);\n }\n }\n\n /** Initializes an `import` statement. */\n private initializeImports(\n /** The statement to initialize. */\n statement: ImportStatement,\n /** Parent file. */\n parent: File,\n /** So far queued `import`s. */\n queuedImports: QueuedImport[],\n /** So far queued `export`s. */\n queuedExports: Map>\n ): void {\n var declarations = statement.declarations;\n if (declarations) { // import { foo [as bar] } from \"./baz\"\n for (let i = 0, k = declarations.length; i < k; ++i) {\n this.initializeImport(\n declarations[i],\n parent,\n statement.internalPath,\n queuedImports,\n queuedExports\n );\n }\n } else if (statement.namespaceName) { // import * as foo from \"./bar\"\n queuedImports.push(new QueuedImport(\n parent,\n statement.namespaceName,\n null, // indicates import *\n statement.internalPath,\n statement.internalPath + INDEX_SUFFIX\n ));\n } else {\n // import \"./foo\"\n }\n }\n\n /** Initializes a single `import` declaration. Does not handle `import *`. */\n private initializeImport( // { foo [as bar] }\n /** The declaration to initialize. */\n declaration: ImportDeclaration,\n /** Parent file. */\n parent: File,\n /** Path to the other file. */\n foreignPath: string,\n /** So far queued `import`s. */\n queuedImports: QueuedImport[],\n /** So far queued `export`s. */\n queuedExports: Map>\n ): void {\n var foreignPathAlt = foreignPath.endsWith(INDEX_SUFFIX) // strip or add index depending on what's already present\n ? foreignPath.substring(0, foreignPath.length - INDEX_SUFFIX.length)\n : foreignPath + INDEX_SUFFIX;\n\n // resolve right away if the element exists\n var element = this.lookupForeign(declaration.foreignName.text, foreignPath, foreignPathAlt, queuedExports);\n if (element) {\n parent.add(declaration.name.text, element, true);\n return;\n }\n\n // otherwise queue it\n queuedImports.push(new QueuedImport(\n parent,\n declaration.name,\n declaration.foreignName,\n foreignPath,\n foreignPathAlt\n ));\n }\n\n /** Initializes a function. Does not handle methods. */\n private initializeFunction(\n /** The declaration to initialize. */\n declaration: FunctionDeclaration,\n /** Parent element, usually a file or namespace. */\n parent: Element\n ): FunctionPrototype | null {\n var name = declaration.name.text;\n var validDecorators = DecoratorFlags.UNSAFE | DecoratorFlags.BUILTIN;\n if (declaration.is(CommonFlags.AMBIENT)) {\n validDecorators |= DecoratorFlags.EXTERNAL;\n } else {\n validDecorators |= DecoratorFlags.INLINE;\n }\n if (!declaration.is(CommonFlags.INSTANCE)) {\n if (parent.kind != ElementKind.CLASS_PROTOTYPE) {\n validDecorators |= DecoratorFlags.GLOBAL;\n }\n }\n var element = new FunctionPrototype(\n name,\n parent,\n declaration,\n this.checkDecorators(declaration.decorators, validDecorators)\n );\n if (!parent.add(name, element)) return null;\n return element;\n }\n\n /** Initializes an interface. */\n private initializeInterface(\n /** The declaration to initialize. */\n declaration: InterfaceDeclaration,\n /** Parent element, usually a file or namespace. */\n parent: Element\n ): InterfacePrototype | null {\n var name = declaration.name.text;\n var element = new InterfacePrototype(\n name,\n parent,\n declaration,\n this.checkDecorators(declaration.decorators,\n DecoratorFlags.GLOBAL\n )\n );\n if (!parent.add(name, element)) return null;\n var memberDeclarations = declaration.members;\n for (let i = 0, k = memberDeclarations.length; i < k; ++i) {\n let memberDeclaration = memberDeclarations[i];\n switch (memberDeclaration.kind) {\n case NodeKind.FIELDDECLARATION: {\n this.initializeField(memberDeclaration, element);\n break;\n }\n case NodeKind.METHODDECLARATION: {\n if (memberDeclaration.isAny(CommonFlags.GET | CommonFlags.SET)) {\n this.initializeProperty(memberDeclaration, element);\n } else {\n this.initializeMethod(memberDeclaration, element);\n }\n break;\n }\n default: assert(false); // interface member expected\n }\n }\n return element;\n }\n\n /** Initializes a namespace. */\n private initializeNamespace(\n /** The declaration to initialize. */\n declaration: NamespaceDeclaration,\n /** Parent element, usually a file or another namespace. */\n parent: Element,\n /** So far queued `extends` clauses. */\n queuedExtends: ClassPrototype[],\n /** So far queued `implements` clauses. */\n queuedImplements: ClassPrototype[]\n ): Namespace | null {\n var name = declaration.name.text;\n var original = new Namespace(\n name,\n parent,\n declaration,\n this.checkDecorators(declaration.decorators, DecoratorFlags.GLOBAL)\n );\n if (!parent.add(name, original)) return null;\n var element = assert(parent.lookupInSelf(name)); // possibly merged\n var members = declaration.members;\n for (let i = 0, k = members.length; i < k; ++i) {\n let member = members[i];\n switch (member.kind) {\n case NodeKind.CLASSDECLARATION: {\n this.initializeClass(member, original, queuedExtends, queuedImplements);\n break;\n }\n case NodeKind.ENUMDECLARATION: {\n this.initializeEnum(member, original);\n break;\n }\n case NodeKind.FUNCTIONDECLARATION: {\n this.initializeFunction(member, original);\n break;\n }\n case NodeKind.INTERFACEDECLARATION: {\n this.initializeInterface(member, original);\n break;\n }\n case NodeKind.NAMESPACEDECLARATION: {\n this.initializeNamespace(member, original, queuedExtends, queuedImplements);\n break;\n }\n case NodeKind.TYPEDECLARATION: {\n this.initializeTypeDefinition(member, original);\n break;\n }\n case NodeKind.VARIABLE: {\n this.initializeVariables(member, original);\n break;\n }\n default: assert(false); // namespace member expected\n }\n }\n if (original != element) copyMembers(original, element); // retain original parent\n return element;\n }\n\n /** Initializes a `type` definition. */\n private initializeTypeDefinition(\n /** The declaration to initialize. */\n declaration: TypeDeclaration,\n /** Parent element, usually a file or namespace. */\n parent: Element\n ): void {\n var name = declaration.name.text;\n var element = new TypeDefinition(\n name,\n parent,\n declaration,\n this.checkDecorators(declaration.decorators, DecoratorFlags.NONE)\n );\n parent.add(name, element); // reports\n }\n\n /** Initializes a variable statement. */\n private initializeVariables(\n /** The statement to initialize. */\n statement: VariableStatement,\n /** Parent element, usually a file or namespace. */\n parent: Element\n ): void {\n var declarations = statement.declarations;\n for (let i = 0, k = declarations.length; i < k; ++i) {\n let declaration = declarations[i];\n let name = declaration.name.text;\n let acceptedFlags = DecoratorFlags.GLOBAL | DecoratorFlags.LAZY;\n if (declaration.is(CommonFlags.DECLARE)) {\n acceptedFlags |= DecoratorFlags.EXTERNAL;\n }\n if (declaration.is(CommonFlags.CONST)) {\n acceptedFlags |= DecoratorFlags.INLINE;\n }\n let element = new Global(\n name,\n parent,\n this.checkDecorators(declaration.decorators, acceptedFlags),\n declaration\n );\n if (!parent.add(name, element)) continue; // reports\n }\n }\n\n /** Determines the element type of a built-in array. */\n // determineBuiltinArrayType(target: Class): Type | null {\n // switch (target.internalName) {\n // case BuiltinSymbols.Int8Array: return Type.i8;\n // case BuiltinSymbols.Uint8ClampedArray:\n // case BuiltinSymbols.Uint8Array: return Type.u8;\n // case BuiltinSymbols.Int16Array: return Type.i16;\n // case BuiltinSymbols.Uint16Array: return Type.u16;\n // case BuiltinSymbols.Int32Array: return Type.i32;\n // case BuiltinSymbols.Uint32Array: return Type.u32;\n // case BuiltinSymbols.Int64Array: return Type.i64;\n // case BuiltinSymbols.Uint64Array: return Type.u64;\n // case BuiltinSymbols.Float32Array: return Type.f32;\n // case BuiltinSymbols.Float64Array: return Type.f64;\n // }\n // var current: Class | null = target;\n // var arrayPrototype = this.arrayPrototype;\n // do {\n // if (current.prototype == arrayPrototype) { // Array\n // let typeArguments = assert(current.typeArguments);\n // assert(typeArguments.length == 1);\n // return typeArguments[0];\n // }\n // } while (current = current.base);\n // return null;\n // }\n}\n\n/** Indicates the specific kind of an {@link Element}. */\nexport enum ElementKind {\n /** A {@link Global}. */\n GLOBAL,\n /** A {@link Local}. */\n LOCAL,\n /** An {@link Enum}. */\n ENUM,\n /** An {@link EnumValue}. */\n ENUMVALUE,\n /** A {@link FunctionPrototype}. */\n FUNCTION_PROTOTYPE,\n /** A {@link Function}. */\n FUNCTION,\n /** A {@link FunctionTarget}. */\n FUNCTION_TARGET,\n /** A {@link ClassPrototype}. */\n CLASS_PROTOTYPE,\n /** A {@link Class}. */\n CLASS,\n /** An {@link InterfacePrototype}. */\n INTERFACE_PROTOTYPE,\n /** An {@link Interface}. */\n INTERFACE,\n /** A {@link FieldPrototype}. */\n FIELD_PROTOTYPE,\n /** A {@link Field}. */\n FIELD,\n /** A {@link PropertyPrototype}. */\n PROPERTY_PROTOTYPE,\n /** A {@link Property}. */\n PROPERTY,\n /** A {@link Namespace}. */\n NAMESPACE,\n /** A {@link File}. */\n FILE,\n /** A {@link TypeDefinition}. */\n TYPEDEFINITION,\n}\n\n/** Indicates built-in decorators that are present. */\nexport enum DecoratorFlags {\n /** No flags set. */\n NONE = 0,\n /** Is a program global. */\n GLOBAL = 1 << 0,\n /** Is a binary operator overload. */\n OPERATOR_BINARY = 1 << 1,\n /** Is a unary prefix operator overload. */\n OPERATOR_PREFIX = 1 << 2,\n /** Is a unary postfix operator overload. */\n OPERATOR_POSTFIX = 1 << 3,\n /** Is an unmanaged class. */\n UNMANAGED = 1 << 4,\n /** Is a sealed class. */\n SEALED = 1 << 5,\n /** Is always inlined. */\n INLINE = 1 << 6,\n /** Is using a different external name. */\n EXTERNAL = 1 << 7,\n /** Is a builtin. */\n BUILTIN = 1 << 8,\n /** Is compiled lazily. */\n LAZY = 1 << 9,\n /** Is considered unsafe code. */\n UNSAFE = 1 << 10\n}\n\n/** Translates a decorator kind to the respective decorator flag. */\nexport function decoratorKindToFlag(kind: DecoratorKind): DecoratorFlags {\n switch (kind) {\n case DecoratorKind.GLOBAL: return DecoratorFlags.GLOBAL;\n case DecoratorKind.OPERATOR:\n case DecoratorKind.OPERATOR_BINARY: return DecoratorFlags.OPERATOR_BINARY;\n case DecoratorKind.OPERATOR_PREFIX: return DecoratorFlags.OPERATOR_PREFIX;\n case DecoratorKind.OPERATOR_POSTFIX: return DecoratorFlags.OPERATOR_POSTFIX;\n case DecoratorKind.UNMANAGED: return DecoratorFlags.UNMANAGED;\n case DecoratorKind.SEALED: return DecoratorFlags.SEALED;\n case DecoratorKind.INLINE: return DecoratorFlags.INLINE;\n case DecoratorKind.EXTERNAL: return DecoratorFlags.EXTERNAL;\n case DecoratorKind.BUILTIN: return DecoratorFlags.BUILTIN;\n case DecoratorKind.LAZY: return DecoratorFlags.LAZY;\n case DecoratorKind.UNSAFE: return DecoratorFlags.UNSAFE;\n default: return DecoratorFlags.NONE;\n }\n}\n\n/** Base class of all program elements. */\nexport abstract class Element {\n\n /** Parent element. */\n parent: Element;\n /** Common flags indicating specific traits. */\n flags: CommonFlags = CommonFlags.NONE;\n /** Decorator flags indicating annotated traits. */\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE;\n /** Member elements. */\n members: Map | null = null;\n /** Shadowing type in type space, if any. */\n shadowType: TypeDefinition | null = null;\n\n /** Constructs a new program element. */\n protected constructor(\n /** Specific element kind. */\n public kind: ElementKind,\n /** Simple name. */\n public name: string,\n /** Internal name referring to this element. */\n public internalName: string,\n /** Containing {@link Program}. */\n public program: Program,\n /** Parent element. */\n parent: Element | null\n ) {\n this.program = program;\n this.name = name;\n this.internalName = internalName;\n if (parent) {\n this.parent = parent;\n } else {\n assert(this.kind == ElementKind.FILE);\n this.parent = this; // special case to keep this.parent non-nullable\n }\n }\n\n /** Gets the enclosing file. */\n get file(): File {\n var current: Element = this;\n do if ((current = current.parent).kind == ElementKind.FILE) return current;\n while (true);\n }\n\n /** Tests if this element has a specific flag or flags. */\n is(flag: CommonFlags): bool { return (this.flags & flag) == flag; }\n /** Tests if this element has any of the specified flags. */\n isAny(flags: CommonFlags): bool { return (this.flags & flags) != 0; }\n /** Sets a specific flag or flags. */\n set(flag: CommonFlags): void { this.flags |= flag; }\n /** Unsets the specific flag or flags. */\n unset(flag: CommonFlags): void {this.flags &= ~flag; }\n /** Tests if this element has a specific decorator flag or flags. */\n hasDecorator(flag: DecoratorFlags): bool { return (this.decoratorFlags & flag) == flag; }\n\n /** Looks up the element with the specified name within this element. */\n lookupInSelf(name: string): DeclaredElement | null {\n var members = this.members;\n if (members && members.has(name)) return members.get(name)!;\n return null;\n }\n\n /** Looks up the element with the specified name relative to this element, like in JS. */\n abstract lookup(name: string): Element | null;\n\n /** Adds an element as a member of this one. Reports and returns `false` if a duplicate. */\n add(name: string, element: DeclaredElement): bool {\n var originalDeclaration = element.declaration;\n var members = this.members;\n if (!members) this.members = members = new Map();\n else if (members.has(name)) {\n let actual = members.get(name)!;\n if (actual.parent !== this) {\n // override non-own element\n } else {\n let merged = tryMerge(actual, element);\n if (merged) {\n element = merged; // use merged element\n } else {\n this.program.error(\n DiagnosticCode.Duplicate_identifier_0,\n element.identifierNode.range, element.identifierNode.text\n );\n return false;\n }\n }\n }\n members.set(name, element);\n var program = this.program;\n if (element.kind != ElementKind.FUNCTION_PROTOTYPE || !(element).isBound) {\n // prefer unbound prototypes in global lookup maps\n program.elementsByName.set(element.internalName, element);\n program.elementsByDeclaration.set(originalDeclaration, element);\n }\n return true;\n }\n\n /** Returns a string representation of this element. */\n toString(): string {\n return ElementKind[this.kind] + \":\" + this.internalName;\n }\n}\n\n/** Base class of elements with an associated declaration statement. */\nexport abstract class DeclaredElement extends Element {\n\n /** Constructs a new declared program element. */\n protected constructor(\n /** Specific element kind. */\n kind: ElementKind,\n /** Simple name. */\n name: string,\n /** Internal name referring to this element. */\n internalName: string,\n /** Containing {@link Program}. */\n program: Program,\n /** Parent element. */\n parent: Element | null,\n /** Declaration reference. */\n public declaration: DeclarationStatement\n ) {\n super(kind, name, internalName, program, parent);\n // It is necessary to have access to identifiers of all members and exports\n // for reporting purposes and this is the lowest common denominator. Comes\n // at the expense of not having more specific type information in derived\n // classes, though. Instead, derived classes implement getters for other\n // important AST nodes directly through manual casting, allowing the resolver\n // etc. to not worry about actual declarations.\n this.declaration = declaration;\n this.flags = declaration.flags; // inherit\n }\n\n /** Tests if this element is a library element. */\n get isDeclaredInLibrary(): bool {\n return this.declaration.range.source.isLibrary;\n }\n\n /** Gets the associated identifier node. */\n get identifierNode(): IdentifierExpression {\n return this.declaration.name;\n }\n\n /** Gets the assiciated decorator nodes. */\n get decoratorNodes(): DecoratorNode[] | null {\n return this.declaration.decorators;\n }\n}\n\n/** Base class of elements that can be resolved to a concrete type. */\nexport abstract class TypedElement extends DeclaredElement {\n\n /** Resolved type. Set once `is(RESOLVED)`, otherwise void. */\n type: Type = Type.void;\n\n /** Sets the resolved type of this element. */\n setType(type: Type): void {\n assert(!this.is(CommonFlags.RESOLVED));\n this.type = type;\n this.set(CommonFlags.RESOLVED);\n }\n}\n\n/** A file representing the implicit top-level namespace of a source. */\nexport class File extends Element {\n\n /** File exports. */\n exports: Map | null = null;\n /** File re-exports. */\n exportsStar: File[] | null = null;\n /** Top-level start function of this file. */\n startFunction: Function;\n\n /** Constructs a new file. */\n constructor(\n /** Program this file belongs to. */\n program: Program,\n /** Source of this file. */\n public source: Source\n ) {\n super(\n ElementKind.FILE,\n source.normalizedPath,\n source.internalPath,\n program,\n null // special case for files\n );\n this.source = source;\n assert(!program.filesByName.has(this.internalName));\n program.filesByName.set(this.internalName, this);\n var startFunction = this.program.makeNativeFunction(\n \"start:\" + this.internalName,\n new Signature(null, Type.void),\n this\n );\n startFunction.internalName = startFunction.name;\n this.startFunction = startFunction;\n }\n\n /* @override */\n add(name: string, element: DeclaredElement, isImport: bool = false): bool {\n if (element.hasDecorator(DecoratorFlags.GLOBAL)) {\n element = this.program.ensureGlobal(name, element); // possibly merged globally\n }\n if (!super.add(name, element)) return false;\n element = assert(this.lookupInSelf(name)); // possibly merged locally\n if (element.is(CommonFlags.EXPORT) && !isImport) {\n this.ensureExport(\n element.name,\n element\n );\n }\n return true;\n }\n\n /* @override */\n lookupInSelf(name: string): DeclaredElement | null {\n var element = super.lookupInSelf(name);\n if (element) return element;\n var exportsStar = this.exportsStar;\n if (exportsStar) {\n for (let i = 0, k = exportsStar.length; i < k; ++i) {\n if (element = exportsStar[i].lookupInSelf(name)) return element;\n }\n }\n return null;\n }\n\n /* @override */\n lookup(name: string): Element | null {\n var element = this.lookupInSelf(name);\n if (element) return element;\n return this.program.lookupGlobal(name);\n }\n\n /** Ensures that an element is an export of this file. */\n ensureExport(name: string, element: DeclaredElement): void {\n var exports = this.exports;\n if (!exports) this.exports = exports = new Map();\n exports.set(name, element);\n if (this.source.isLibrary) this.program.ensureGlobal(name, element);\n }\n\n /** Ensures that another file is a re-export of this file. */\n ensureExportStar(file: File): void {\n var exportsStar = this.exportsStar;\n if (!exportsStar) this.exportsStar = exportsStar = [];\n else if (exportsStar.includes(file)) return;\n exportsStar.push(file);\n }\n\n /** Looks up the export of the specified name. */\n lookupExport(name: string): DeclaredElement | null {\n var exports = this.exports;\n if (exports && exports.has(name)) return exports.get(name)!;\n var exportsStar = this.exportsStar;\n if (exportsStar) {\n for (let i = 0, k = exportsStar.length; i < k; ++i) {\n let element = exportsStar[i].lookupExport(name);\n if (element) return element;\n }\n }\n return null;\n }\n\n /** Creates an imported namespace from this file. */\n asImportedNamespace(name: string, parent: Element): Namespace {\n var ns = new Namespace(\n name,\n parent,\n this.program.makeNativeNamespaceDeclaration(name)\n );\n var exports = this.exports;\n if (exports) {\n for (let [memberName, member] of exports) {\n ns.add(memberName, member);\n }\n }\n return ns;\n }\n}\n\n/** A type definition. */\nexport class TypeDefinition extends TypedElement {\n\n /** Constructs a new type definition. */\n constructor(\n /** Simple name. */\n name: string,\n /** Parent element, usually a file or namespace. */\n parent: Element,\n /** Declaration reference. */\n declaration: TypeDeclaration,\n /** Pre-checked flags indicating built-in decorators. */\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\n ) {\n super(\n ElementKind.TYPEDEFINITION,\n name,\n mangleInternalName(name, parent, false),\n parent.program,\n parent,\n declaration\n );\n this.decoratorFlags = decoratorFlags;\n }\n\n /** Gets the associated type parameter nodes. */\n get typeParameterNodes(): TypeParameterNode[] | null {\n return (this.declaration).typeParameters;\n }\n\n /** Gets the associated type node. */\n get typeNode(): TypeNode {\n return (this.declaration).type;\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return this.parent.lookup(name);\n }\n}\n\n/** A namespace that differs from a file in being user-declared with a name. */\nexport class Namespace extends DeclaredElement {\n\n /** Constructs a new namespace. */\n constructor(\n /** Simple name. */\n name: string,\n /** Parent element, usually a file or another namespace. */\n parent: Element,\n /** Declaration reference. */\n declaration: NamespaceDeclaration,\n /** Pre-checked flags indicating built-in decorators. */\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\n ) {\n super(\n ElementKind.NAMESPACE,\n name,\n mangleInternalName(name, parent, false),\n parent.program,\n parent,\n declaration\n );\n this.decoratorFlags = decoratorFlags;\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return this.lookupInSelf(name)\n || this.parent.lookup(name);\n }\n}\n\n/** An enum. */\nexport class Enum extends TypedElement {\n\n /** Constructs a new enum. */\n constructor(\n /** Simple name. */\n name: string,\n /** Parent element, usually a file or namespace. */\n parent: Element,\n /** Declaration reference. */\n declaration: EnumDeclaration,\n /** Pre-checked flags indicating built-in decorators. */\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\n ) {\n super(\n ElementKind.ENUM,\n name,\n mangleInternalName(name, parent, false),\n parent.program,\n parent,\n declaration\n );\n this.decoratorFlags = decoratorFlags;\n this.setType(Type.i32);\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return this.lookupInSelf(name)\n || this.parent.lookup(name);\n }\n}\n\n/** Indicates the kind of an inlined constant value. */\nexport const enum ConstantValueKind {\n /** No constant value. */\n NONE,\n /** Constant integer value. */\n INTEGER,\n /** Constant float value. */\n FLOAT\n}\n\n/** Base class of all variable-like program elements. */\nexport abstract class VariableLikeElement extends TypedElement {\n\n /** Constant value kind. */\n constantValueKind: ConstantValueKind = ConstantValueKind.NONE;\n /** Constant integer value, if applicable. */\n constantIntegerValue: I64;\n /** Constant float value, if applicable. */\n constantFloatValue: f64;\n\n /** Constructs a new variable-like element. */\n protected constructor(\n /** Specific element kind. */\n kind: ElementKind,\n /** Simple name. */\n name: string,\n /** Parent element, usually a file, namespace or class. */\n parent: Element,\n /** Declaration reference. Creates a native declaration if omitted. */\n declaration: VariableLikeDeclarationStatement = parent.program.makeNativeVariableDeclaration(name)\n ) {\n super(\n kind,\n name,\n mangleInternalName(name, parent, false),\n parent.program,\n parent,\n declaration\n );\n this.flags = declaration.flags;\n }\n\n /** Gets the associated type node.s */\n get typeNode(): TypeNode | null {\n return (this.declaration).type;\n }\n\n /** Gets the associated initializer node. */\n get initializerNode(): Expression | null {\n return (this.declaration).initializer;\n }\n\n /** Applies a constant integer value to this element. */\n setConstantIntegerValue(value: I64, type: Type): void {\n assert(type.is(TypeFlags.INTEGER));\n this.type = type;\n this.constantValueKind = ConstantValueKind.INTEGER;\n this.constantIntegerValue = value;\n this.set(CommonFlags.CONST | CommonFlags.INLINED | CommonFlags.RESOLVED);\n }\n\n /** Applies a constant float value to this element. */\n setConstantFloatValue(value: f64, type: Type): void {\n assert(type.is(TypeFlags.FLOAT));\n this.type = type;\n this.constantValueKind = ConstantValueKind.FLOAT;\n this.constantFloatValue = value;\n this.set(CommonFlags.CONST | CommonFlags.INLINED | CommonFlags.RESOLVED);\n }\n\n /** @override */\n lookup(name: string): Element | null {\n return this.parent.lookup(name);\n }\n}\n\n/** An enum value. */\nexport class EnumValue extends VariableLikeElement {\n\n /** Constructs a new enum value. */\n constructor(\n /** Simple name. */\n name: string,\n /** Parent enum. */\n parent: Enum,\n /** Declaration reference. */\n declaration: EnumValueDeclaration,\n /** Pre-checked flags indicating built-in decorators. */\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\n ) {\n super(\n ElementKind.ENUMVALUE,\n name,\n parent,\n declaration\n );\n this.decoratorFlags = decoratorFlags;\n this.setType(Type.i32);\n }\n\n /** Whether this enum value is immutable. */\n isImmutable: bool = false;\n\n /** Gets the associated value node. */\n get valueNode(): Expression | null {\n return (this.declaration).value;\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return this.parent.lookup(name);\n }\n}\n\n/** A global variable. */\nexport class Global extends VariableLikeElement {\n\n /** Constructs a new global variable. */\n constructor(\n /** Simple name. */\n name: string,\n /** Parent element, usually a file, namespace or static class. */\n parent: Element,\n /** Pre-checked flags indicating built-in decorators. */\n decoratorFlags: DecoratorFlags,\n /** Declaration reference. Creates a native declaration if omitted. */\n declaration: VariableLikeDeclarationStatement = parent.program.makeNativeVariableDeclaration(name)\n ) {\n super(\n ElementKind.GLOBAL,\n name,\n parent,\n declaration\n );\n this.decoratorFlags = decoratorFlags;\n }\n}\n\n/** A function parameter. */\nexport class Parameter {\n /** Constructs a new function parameter. */\n constructor(\n /** Parameter name. */\n public name: string,\n /** Parameter type. */\n public type: Type,\n /** Parameter initializer, if present. */\n public initializer: Expression | null = null\n ) {}\n}\n\n/** A local variable. */\nexport class Local extends VariableLikeElement {\n\n /** Constructs a new local variable. */\n constructor(\n /** Simple name. */\n name: string,\n /** Zero-based index within the enclosing function. `-1` indicates a virtual local. */\n public index: i32,\n /** Resolved type. */\n type: Type,\n /** Parent function. */\n parent: Function,\n /** Declaration reference. */\n declaration: VariableLikeDeclarationStatement = parent.program.makeNativeVariableDeclaration(name)\n ) {\n super(\n ElementKind.LOCAL,\n name,\n parent,\n declaration\n );\n this.index = index;\n assert(type != Type.void);\n this.setType(type);\n }\n}\n\n/** A yet unresolved function prototype. */\nexport class FunctionPrototype extends DeclaredElement {\n\n /** Operator kind, if an overload. */\n operatorKind: OperatorKind = OperatorKind.INVALID;\n /** Already resolved instances. */\n instances: Map | null = null;\n\n /** Clones of this prototype that are bounds to specific classes. */\n private boundPrototypes: Map | null = null;\n\n /** Constructs a new function prototype. */\n constructor(\n /** Simple name */\n name: string,\n /** Parent element, usually a file, namespace or class (if a method). */\n parent: Element,\n /** Declaration reference. */\n declaration: FunctionDeclaration,\n /** Pre-checked flags indicating built-in decorators. */\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\n ) {\n super(\n ElementKind.FUNCTION_PROTOTYPE,\n name,\n mangleInternalName(name, parent, declaration.is(CommonFlags.INSTANCE)),\n parent.program,\n parent,\n declaration\n );\n this.decoratorFlags = decoratorFlags;\n }\n\n /** Gets the associated type parameter nodes. */\n get typeParameterNodes(): TypeParameterNode[] | null {\n return (this.declaration).typeParameters;\n }\n\n /** Gets the associated function type node. */\n get functionTypeNode(): FunctionTypeNode {\n return (this.declaration).signature;\n }\n\n /** Gets the associated body node. */\n get bodyNode(): Statement | null {\n return (this.declaration).body;\n }\n\n /** Gets the arrow function kind. */\n get arrowKind(): ArrowKind {\n return (this.declaration).arrowKind;\n }\n\n /** Tests if this prototype is bound to a class. */\n get isBound(): bool {\n var parent = this.parent;\n return parent.kind == ElementKind.CLASS\n || parent.kind == ElementKind.PROPERTY_PROTOTYPE && parent.parent.kind == ElementKind.CLASS;\n }\n\n /** Creates a clone of this prototype that is bound to a concrete class instead. */\n toBound(classInstance: Class): FunctionPrototype {\n assert(this.is(CommonFlags.INSTANCE));\n assert(!this.isBound);\n var boundPrototypes = this.boundPrototypes;\n if (!boundPrototypes) this.boundPrototypes = boundPrototypes = new Map();\n else if (boundPrototypes.has(classInstance)) return boundPrototypes.get(classInstance)!;\n var declaration = this.declaration; assert(declaration.kind == NodeKind.METHODDECLARATION);\n var bound = new FunctionPrototype(\n this.name,\n classInstance, // !\n declaration,\n this.decoratorFlags\n );\n bound.flags = this.flags;\n bound.operatorKind = this.operatorKind;\n // NOTE: this.instances holds instances per bound class / unbound\n boundPrototypes.set(classInstance, bound);\n return bound;\n }\n\n /** Gets the resolved instance for the specified instance key, if already resolved. */\n getResolvedInstance(instanceKey: string): Function | null {\n var instances = this.instances;\n if (instances && instances.has(instanceKey)) return instances.get(instanceKey);\n return null;\n }\n\n /** Sets the resolved instance for the specified instance key. */\n setResolvedInstance(instanceKey: string, instance: Function): void {\n var instances = this.instances;\n if (!instances) this.instances = instances = new Map();\n else assert(!instances.has(instanceKey));\n instances.set(instanceKey, instance);\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return this.parent.lookup(name);\n }\n}\n\n/** A resolved function. */\nexport class Function extends TypedElement {\n\n /** Function prototype. */\n prototype: FunctionPrototype;\n /** Function signature. */\n signature: Signature;\n /** Map of locals by name. */\n localsByName: Map = new Map();\n /** Array of locals by index. */\n localsByIndex: Local[] = [];\n /** List of additional non-parameter locals. */\n additionalLocals: Type[] = [];\n /** Contextual type arguments. */\n contextualTypeArguments: Map | null;\n /** Default control flow. */\n flow: Flow;\n /** Remembered debug locations. */\n debugLocations: Range[] = [];\n /** Function reference, if compiled. */\n ref: FunctionRef = 0;\n /** Function table index, if any. */\n functionTableIndex: i32 = -1;\n /** Trampoline function for calling with omitted arguments. */\n trampoline: Function | null = null;\n\n /** Counting id of inline operations involving this function. */\n nextInlineId: i32 = 0;\n /** Counting id of anonymous inner functions. */\n nextAnonymousId: i32 = 0;\n /** Counting id of autorelease variables. */\n nextAutoreleaseId: i32 = 0;\n\n /** Constructs a new concrete function. */\n constructor(\n /** Name incl. type parameters, i.e. `foo`. */\n nameInclTypeParameters: string,\n /** Respective function prototype. */\n prototype: FunctionPrototype,\n /** Concrete signature. */\n signature: Signature, // pre-resolved\n /** Contextual type arguments inherited from its parent class, if any. */\n contextualTypeArguments: Map | null = null\n ) {\n super(\n ElementKind.FUNCTION,\n nameInclTypeParameters,\n mangleInternalName(nameInclTypeParameters, prototype.parent, prototype.is(CommonFlags.INSTANCE)),\n prototype.program,\n prototype.parent,\n prototype.declaration\n );\n this.prototype = prototype;\n this.signature = signature;\n this.flags = prototype.flags | CommonFlags.RESOLVED;\n this.decoratorFlags = prototype.decoratorFlags;\n this.contextualTypeArguments = contextualTypeArguments;\n this.type = Type.u32.asFunction(signature);\n if (!prototype.is(CommonFlags.AMBIENT)) {\n let localIndex = 0;\n if (this.is(CommonFlags.INSTANCE)) {\n let local = new Local(\n CommonSymbols.this_,\n localIndex++,\n assert(signature.thisType),\n this\n );\n this.localsByName.set(CommonSymbols.this_, local);\n this.localsByIndex[local.index] = local;\n }\n let parameterTypes = signature.parameterTypes;\n for (let i = 0, k = parameterTypes.length; i < k; ++i) {\n let parameterType = parameterTypes[i];\n let parameterName = signature.getParameterName(i);\n let local = new Local(\n parameterName,\n localIndex++,\n parameterType,\n this\n );\n this.localsByName.set(parameterName, local);\n this.localsByIndex[local.index] = local;\n }\n }\n this.flow = Flow.create(this);\n registerConcreteElement(this.program, this);\n }\n\n /** Adds a local of the specified type, with an optional name. */\n addLocal(type: Type, name: string | null = null, declaration: VariableDeclaration | null = null): Local {\n // if it has a name, check previously as this method will throw otherwise\n var localIndex = this.signature.parameterTypes.length + this.additionalLocals.length;\n if (this.is(CommonFlags.INSTANCE)) ++localIndex;\n var localName = name !== null\n ? name\n : \"var$\" + localIndex.toString();\n var local = new Local(\n localName,\n localIndex,\n type,\n this,\n declaration || this.program.makeNativeVariableDeclaration(localName)\n );\n if (name) {\n if (this.localsByName.has(name)) throw new Error(\"duplicate local name\");\n this.localsByName.set(name, local);\n }\n this.localsByIndex[local.index] = local;\n this.additionalLocals.push(type);\n return local;\n }\n\n /* @override */\n lookup(name: string): Element | null {\n var locals = this.localsByName;\n if (locals.has(name)) return locals.get(name);\n return this.parent.lookup(name);\n }\n\n // used by flows to keep track of temporary locals\n tempI32s: Local[] | null = null;\n tempI64s: Local[] | null = null;\n tempF32s: Local[] | null = null;\n tempF64s: Local[] | null = null;\n tempV128s: Local[] | null = null;\n\n // used by flows to keep track of break labels\n nextBreakId: i32 = 0;\n breakStack: i32[] | null = null;\n breakLabel: string | null = null;\n\n /** Finalizes the function once compiled, releasing no longer needed resources. */\n finalize(module: Module, ref: FunctionRef): void {\n this.ref = ref;\n assert(!this.breakStack || !this.breakStack.length); // internal error\n this.breakStack = null;\n this.breakLabel = null;\n this.tempI32s = this.tempI64s = this.tempF32s = this.tempF64s = null;\n if (this.program.options.sourceMap) {\n let debugLocations = this.debugLocations;\n for (let i = 0, k = debugLocations.length; i < k; ++i) {\n let debugLocation = debugLocations[i];\n module.setDebugLocation(\n ref,\n debugLocation.debugInfoRef,\n debugLocation.source.debugInfoIndex,\n debugLocation.line,\n debugLocation.column\n );\n }\n }\n }\n}\n\n/** A resolved function target, that is a function called indirectly by an index and signature. */\nexport class FunctionTarget extends Element {\n\n /** Underlying signature. */\n signature: Signature;\n /** Function type. */\n type: Type;\n\n /** Constructs a new function target. */\n constructor(\n /** Concrete signature. */\n signature: Signature,\n /** Program reference. */\n program: Program,\n __s: string = \"\" // FIXME: current TS limitation workaround, but a fix seems underway\n ) {\n super(\n ElementKind.FUNCTION_TARGET,\n __s = \"sig:\" + signature.toSignatureString(),\n __s,\n program,\n program.nativeFile\n );\n this.signature = signature;\n this.flags = CommonFlags.RESOLVED;\n this.type = Type.u32.asFunction(signature);\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return null;\n }\n}\n\n/** A yet unresolved instance field prototype. */\nexport class FieldPrototype extends DeclaredElement {\n\n /** Constructs a new field prototype. */\n constructor(\n /** Simple name. */\n name: string,\n /** Parent class. */\n parent: ClassPrototype,\n /** Declaration reference. */\n declaration: FieldDeclaration,\n /** Pre-checked flags indicating built-in decorators. */\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE\n ) {\n super(\n ElementKind.FIELD_PROTOTYPE,\n name,\n mangleInternalName(name, parent, assert(declaration.is(CommonFlags.INSTANCE))),\n parent.program,\n parent,\n declaration\n );\n this.decoratorFlags = decoratorFlags;\n }\n\n /** Gets the associated type node. */\n get typeNode(): TypeNode | null {\n return (this.declaration).type;\n }\n\n /** Gets the associated initializer node. */\n get initializerNode(): Expression | null {\n return (this.declaration).initializer;\n }\n\n /** Gets the associated parameter index. Set if declared as a constructor parameter, otherwise `-1`. */\n get parameterIndex(): i32 {\n return (this.declaration).parameterIndex;\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return this.parent.lookup(name);\n }\n}\n\n/** A resolved instance field. */\nexport class Field extends VariableLikeElement {\n\n /** Field prototype reference. */\n prototype: FieldPrototype;\n /** Field memory offset, if an instance field. */\n memoryOffset: i32 = -1;\n\n /** Constructs a new field. */\n constructor(\n /** Respective field prototype. */\n prototype: FieldPrototype,\n /** Parent class. */\n parent: Class,\n /** Concrete type. */\n type: Type\n ) {\n super(\n ElementKind.FIELD,\n prototype.name,\n parent,\n prototype.declaration\n );\n this.prototype = prototype;\n this.flags = prototype.flags;\n assert(type != Type.void);\n this.setType(type);\n registerConcreteElement(this.program, this);\n }\n}\n\n/** A property comprised of a getter and a setter function. */\nexport class PropertyPrototype extends DeclaredElement {\n\n /** Getter prototype. */\n getterPrototype: FunctionPrototype | null = null;\n /** Setter prototype. */\n setterPrototype: FunctionPrototype | null = null;\n\n /** Constructs a new property prototype. */\n constructor(\n /** Simple name. */\n name: string,\n /** Parent class. */\n parent: ClassPrototype,\n /** Declaration of the getter or setter introducing the property. */\n firstDeclaration: FunctionDeclaration\n ) {\n super(\n ElementKind.PROPERTY_PROTOTYPE,\n name,\n mangleInternalName(name, parent, firstDeclaration.is(CommonFlags.INSTANCE)),\n parent.program,\n parent,\n firstDeclaration\n );\n this.flags &= ~(CommonFlags.GET | CommonFlags.SET);\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return this.parent.lookup(name);\n }\n}\n\n/** A resolved property. */\nexport class Property extends VariableLikeElement {\n\n /** Prototype reference. */\n prototype: PropertyPrototype;\n /** Getter instance. */\n getterInstance: Function | null = null;\n /** Setter instance. */\n setterInstance: Function | null = null;\n\n /** Constructs a new property prototype. */\n constructor(\n /** Respective property prototype. */\n prototype: PropertyPrototype,\n /** Parent element, usually a static class prototype or class instance. */\n parent: Element\n ) {\n super(\n ElementKind.PROPERTY,\n prototype.name,\n parent,\n prototype.program.makeNativeVariableDeclaration(\n prototype.name,\n prototype.is(CommonFlags.INSTANCE)\n ? CommonFlags.INSTANCE\n : CommonFlags.NONE\n )\n );\n this.prototype = prototype;\n registerConcreteElement(this.program, this);\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return this.parent.lookup(name);\n }\n}\n\n/** A yet unresolved class prototype. */\nexport class ClassPrototype extends DeclaredElement {\n\n /** Instance member prototypes. */\n instanceMembers: Map | null = null;\n /** Base class prototype, if applicable. */\n basePrototype: ClassPrototype | null = null; // set in Program#initialize\n /** Constructor prototype. */\n constructorPrototype: FunctionPrototype | null = null;\n /** Operator overload prototypes. */\n overloadPrototypes: Map = new Map();\n /** Already resolved instances. */\n instances: Map | null = null;\n\n constructor(\n /** Simple name. */\n name: string,\n /** Parent element, usually a file or namespace. */\n parent: Element,\n /** Declaration reference. */\n declaration: ClassDeclaration,\n /** Pre-checked flags indicating built-in decorators. */\n decoratorFlags: DecoratorFlags = DecoratorFlags.NONE,\n _isInterface: bool = false // FIXME\n ) {\n super(\n _isInterface ? ElementKind.INTERFACE_PROTOTYPE : ElementKind.CLASS_PROTOTYPE,\n name,\n mangleInternalName(name, parent, declaration.is(CommonFlags.INSTANCE)),\n parent.program,\n parent,\n declaration\n );\n this.decoratorFlags = decoratorFlags;\n }\n\n /** Gets the associated type parameter nodes. */\n get typeParameterNodes(): TypeParameterNode[] | null {\n return (this.declaration).typeParameters;\n }\n /** Gets the associated extends node. */\n get extendsNode(): NamedTypeNode | null {\n return (this.declaration).extendsType;\n }\n /** Gets the associated implements nodes. */\n get implementsNodes(): NamedTypeNode[] | null {\n return (this.declaration).implementsTypes;\n }\n\n /** Tests if this prototype is of a builtin array type (Array/TypedArray). */\n get isBuiltinArray(): bool {\n var arrayBufferViewInstance = this.program.arrayBufferViewInstance;\n return arrayBufferViewInstance !== null\n && this.extends(arrayBufferViewInstance.prototype);\n }\n\n /** Tests if this prototype extends the specified. */\n extends(basePtototype: ClassPrototype | null): bool {\n var current: ClassPrototype | null = this;\n do if (current === basePtototype) return true;\n while (current = current.basePrototype);\n return false;\n }\n\n /** Adds an element as an instance member of this one. Returns the previous element if a duplicate. */\n addInstance(name: string, element: DeclaredElement): bool {\n var originalDeclaration = element.declaration;\n var instanceMembers = this.instanceMembers;\n if (!instanceMembers) this.instanceMembers = instanceMembers = new Map();\n else if (instanceMembers.has(name)) {\n let merged = tryMerge(instanceMembers.get(name)!, element);\n if (!merged) {\n this.program.error(\n DiagnosticCode.Duplicate_identifier_0,\n element.identifierNode.range, element.identifierNode.text\n );\n return false;\n }\n element = merged;\n }\n instanceMembers.set(name, element);\n if (element.is(CommonFlags.EXPORT) && this.is(CommonFlags.MODULE_EXPORT)) {\n element.set(CommonFlags.MODULE_EXPORT); // propagate\n }\n this.program.elementsByDeclaration.set(originalDeclaration, element);\n return true;\n }\n\n /** Gets the resolved instance for the specified instance key, if already resolved. */\n getResolvedInstance(instanceKey: string): Class | null {\n var instances = this.instances;\n if (instances && instances.has(instanceKey)) return instances.get(instanceKey);\n return null;\n }\n\n /** Sets the resolved instance for the specified instance key. */\n setResolvedInstance(instanceKey: string, instance: Class): void {\n var instances = this.instances;\n if (!instances) this.instances = instances = new Map();\n else assert(!instances.has(instanceKey));\n instances.set(instanceKey, instance);\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return this.parent.lookup(name);\n }\n}\n\nconst enum AcyclicState {\n UNKNOWN,\n ACYCLIC,\n NOT_ACYCLIC\n}\n\n/** A resolved class. */\nexport class Class extends TypedElement {\n\n /** Class prototype. */\n prototype: ClassPrototype;\n /** Resolved type arguments. */\n typeArguments: Type[] | null;\n /** Base class, if applicable. */\n base: Class | null;\n /** Contextual type arguments for fields and methods. */\n contextualTypeArguments: Map | null = null;\n /** Current member memory offset. */\n currentMemoryOffset: u32 = 0;\n /** Constructor instance. */\n constructorInstance: Function | null = null;\n /** Operator overloads. */\n overloads: Map | null = null;\n /** Unique class id. */\n private _id: u32 = 0;\n /** Remembers acyclic state. */\n private _acyclic: AcyclicState = AcyclicState.UNKNOWN;\n /** Runtime type information flags. */\n rttiFlags: u32 = 0;\n\n /** Gets the unique runtime id of this class. */\n get id(): u32 {\n return this._id; // unmanaged remains 0 (=ArrayBuffer)\n }\n\n /** Tests if this class is of a builtin array type (Array/TypedArray). */\n get isBuiltinArray(): bool {\n return this.prototype.isBuiltinArray;\n }\n\n /** Tests if this class is array-like. */\n get isArrayLike(): bool {\n if (this.isBuiltinArray) return true;\n var lengthField = this.lookupInSelf(\"length\");\n return lengthField !== null && (\n lengthField.kind == ElementKind.FIELD ||\n (\n lengthField.kind == ElementKind.PROPERTY &&\n (lengthField).getterInstance !== null // TODO: resolve & check type?\n )\n ) && (\n this.lookupOverload(OperatorKind.INDEXED_GET) !== null ||\n this.lookupOverload(OperatorKind.UNCHECKED_INDEXED_GET) !== null\n );\n }\n\n /** Constructs a new class. */\n constructor(\n /** Name incl. type parameters, i.e. `Foo`. */\n nameInclTypeParameters: string,\n /** The respective class prototype. */\n prototype: ClassPrototype,\n /** Concrete type arguments, if any. */\n typeArguments: Type[] | null = null,\n /** Base class, if derived. */\n base: Class | null = null,\n _isInterface: bool = false // FIXME\n ) {\n super(\n _isInterface ? ElementKind.INTERFACE : ElementKind.CLASS,\n nameInclTypeParameters,\n mangleInternalName(nameInclTypeParameters, prototype.parent, prototype.is(CommonFlags.INSTANCE)),\n prototype.program,\n prototype.parent,\n prototype.declaration\n );\n var program = this.program;\n this.prototype = prototype;\n this.flags = prototype.flags;\n this.decoratorFlags = prototype.decoratorFlags;\n this.typeArguments = typeArguments;\n this.setType(program.options.usizeType.asClass(this));\n this.base = base;\n\n if (!this.hasDecorator(DecoratorFlags.UNMANAGED)) {\n let id = program.nextClassId++;\n this._id = id;\n program.managedClasses.set(id, this);\n }\n\n // inherit static members and contextual type arguments from base class\n if (base) {\n let inheritedTypeArguments = base.contextualTypeArguments;\n if (inheritedTypeArguments) {\n let contextualTypeArguments = this.contextualTypeArguments;\n for (let [baseName, baseType] of inheritedTypeArguments) {\n if (!contextualTypeArguments) this.contextualTypeArguments = contextualTypeArguments = new Map();\n contextualTypeArguments.set(baseName, baseType);\n }\n }\n }\n\n // apply pre-checked instance-specific contextual type arguments\n var typeParameters = prototype.typeParameterNodes;\n if (typeArguments) {\n let numTypeArguments = typeArguments.length;\n if (!typeParameters || numTypeArguments != typeParameters.length) {\n throw new Error(\"type argument count mismatch\");\n }\n if (numTypeArguments) {\n if (!this.contextualTypeArguments) this.contextualTypeArguments = new Map();\n for (let i = 0; i < numTypeArguments; ++i) {\n this.contextualTypeArguments.set(typeParameters[i].name.text, typeArguments[i]);\n }\n }\n } else if (typeParameters && typeParameters.length) {\n throw new Error(\"type argument count mismatch\");\n }\n registerConcreteElement(program, this);\n }\n\n /** Tests if a value of this class type is assignable to a target of the specified class type. */\n isAssignableTo(target: Class): bool {\n var current: Class | null = this;\n do if (current == target) return true;\n while (current = current.base);\n return false;\n }\n\n /** Looks up the operator overload of the specified kind. */\n lookupOverload(kind: OperatorKind, unchecked: bool = false): Function | null {\n if (unchecked) {\n switch (kind) {\n case OperatorKind.INDEXED_GET: {\n let uncheckedOverload = this.lookupOverload(OperatorKind.UNCHECKED_INDEXED_GET);\n if (uncheckedOverload) return uncheckedOverload;\n break;\n }\n case OperatorKind.INDEXED_SET: {\n let uncheckedOverload = this.lookupOverload(OperatorKind.UNCHECKED_INDEXED_SET);\n if (uncheckedOverload) return uncheckedOverload;\n break;\n }\n default: assert(false);\n }\n }\n var instance: Class | null = this;\n do {\n let overloads = instance.overloads;\n if (overloads) {\n let overload = overloads.get(kind);\n if (overload) return overload;\n }\n } while (instance = instance.base);\n return null;\n }\n\n /* @override */\n lookup(name: string): Element | null {\n return this.parent.lookup(name);\n }\n\n /** Calculates the memory offset of the specified field. */\n offsetof(fieldName: string): u32 {\n var members = assert(this.members);\n assert(members.has(fieldName));\n var field = members.get(fieldName);\n assert(field.kind == ElementKind.FIELD);\n return (field).memoryOffset;\n }\n\n /** Writes a field value to a buffer and returns the number of bytes written. */\n writeField(name: string, value: T, buffer: Uint8Array, baseOffset: i32): i32 {\n var field = this.lookupInSelf(name);\n if (field && field.kind == ElementKind.FIELD) {\n let offset = baseOffset + (field).memoryOffset;\n switch ((field).type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: {\n writeI8(i32(value), buffer, offset);\n return 1;\n }\n case TypeKind.I16:\n case TypeKind.U16: {\n writeI16(i32(value), buffer, offset);\n return 2;\n }\n case TypeKind.I32:\n case TypeKind.U32: {\n writeI32(i32(value), buffer, offset);\n return 4;\n }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n assert(!this.program.options.isWasm64); // TODO\n writeI32(i32(value), buffer, offset);\n return 4;\n }\n case TypeKind.F32: {\n writeF32(f32(value), buffer, offset);\n return 4;\n }\n case TypeKind.F64: {\n writeF64(f64(value), buffer, offset);\n return 8;\n }\n }\n }\n assert(false);\n return 0;\n }\n\n /** Tests if this class extends the specified prototype. */\n extends(prototype: ClassPrototype): bool {\n return this.prototype.extends(prototype);\n }\n\n /** Gets the concrete type arguments to the specified extendend prototype. */\n getTypeArgumentsTo(extendedPrototype: ClassPrototype): Type[] | null {\n var current: Class | null = this;\n do if (current.prototype === extendedPrototype) return current.typeArguments;\n while (current = current.base);\n return null;\n }\n\n /** Gets the value type of an array. Must be an array. */\n getArrayValueType(): Type {\n var current: Class = this;\n var program = this.program;\n var abvInstance = program.arrayBufferViewInstance;\n while (current.base !== abvInstance) {\n current = assert(current.base);\n }\n switch (current.prototype) {\n case program.i8ArrayPrototype: return Type.i8;\n case program.i16ArrayPrototype: return Type.i16;\n case program.i32ArrayPrototype: return Type.i32;\n case program.i64ArrayPrototype: return Type.i64;\n case program.u8ArrayPrototype:\n case program.u8ClampedArrayPrototype: return Type.u8;\n case program.u16ArrayPrototype: return Type.u16;\n case program.u32ArrayPrototype: return Type.u32;\n case program.u64ArrayPrototype: return Type.u64;\n case program.f32ArrayPrototype: return Type.f32;\n case program.f64ArrayPrototype: return Type.f64;\n case program.arrayPrototype: return assert(this.getTypeArgumentsTo(program.arrayPrototype))[0];\n default: assert(false);\n }\n return Type.void;\n }\n\n /** Tests if this class is inherently acyclic. */\n get isAcyclic(): bool {\n var acyclic = this._acyclic;\n if (acyclic == AcyclicState.UNKNOWN) {\n let hasCycle = this.cyclesTo(this);\n if (hasCycle) this._acyclic = acyclic = AcyclicState.NOT_ACYCLIC;\n else this._acyclic = acyclic = AcyclicState.ACYCLIC;\n }\n return acyclic == AcyclicState.ACYCLIC;\n }\n\n /** Tests if this class potentially forms a reference cycle to another one. */\n private cyclesTo(other: Class, except: Set = new Set()): bool {\n // TODO: The pure RC paper describes acyclic data structures as classes that may contain\n //\n // - scalars\n // - references to classes that are both acyclic and final (here: Java); and\n // - arrays (in our case: also sets, maps) of either of the above\n //\n // Our implementation, however, treats all objects that do not reference themselves directly\n // or indirectly as acylic, allowing them to contain inner cycles of other non-acyclic objects.\n // This contradicts the second assumption and must be revisited when actually implementing RC.\n\n if (except.has(this)) return false;\n except.add(this); // don't recurse indefinitely\n\n // Find out if any field references 'other' directly or indirectly\n var current: Class | null;\n var members = this.members;\n if (members) {\n for (let member of members.values()) {\n if (\n member.kind == ElementKind.FIELD &&\n (current = (member).type.classReference) !== null &&\n (\n current === other ||\n current.cyclesTo(other, except)\n )\n ) return true;\n }\n }\n\n // Do the same for non-field data\n var basePrototype: ClassPrototype | null;\n\n // Arrayother?>\n if ((basePrototype = this.program.arrayPrototype) && this.prototype.extends(basePrototype)) {\n let typeArguments = assert(this.getTypeArgumentsTo(basePrototype));\n assert(typeArguments.length == 1);\n if (\n (current = typeArguments[0].classReference) !== null &&\n (\n current === other ||\n current.cyclesTo(other, except)\n )\n ) return true;\n\n // Setother?>\n } else if ((basePrototype = this.program.setPrototype) && this.prototype.extends(basePrototype)) {\n let typeArguments = assert(this.getTypeArgumentsTo(basePrototype));\n assert(typeArguments.length == 1);\n if (\n (current = typeArguments[0].classReference) !== null &&\n (\n current === other ||\n current.cyclesTo(other, except)\n )\n ) return true;\n\n // Mapother?,V->other?>\n } else if ((basePrototype = this.program.mapPrototype) && this.prototype.extends(basePrototype)) {\n let typeArguments = assert(this.getTypeArgumentsTo(basePrototype));\n assert(typeArguments.length == 2);\n if (\n (current = typeArguments[0].classReference) !== null &&\n (\n current === other ||\n current.cyclesTo(other, except)\n )\n ) return true;\n if (\n (current = typeArguments[1].classReference) !== null &&\n (\n current === other ||\n current.cyclesTo(other, except)\n )\n ) return true;\n }\n return false;\n }\n}\n\n/** A yet unresolved interface. */\nexport class InterfacePrototype extends ClassPrototype { // FIXME\n\n /** Constructs a new interface prototype. */\n constructor(\n name: string,\n parent: Element,\n declaration: InterfaceDeclaration,\n decoratorFlags: DecoratorFlags\n ) {\n super(\n name,\n parent,\n declaration,\n decoratorFlags,\n true\n );\n }\n}\n\n/** A resolved interface. */\nexport class Interface extends Class { // FIXME\n\n /** Constructs a new interface. */\n constructor(\n nameInclTypeParameters: string,\n prototype: InterfacePrototype,\n typeArguments: Type[] = [],\n base: Interface | null = null\n ) {\n super(\n nameInclTypeParameters,\n prototype,\n typeArguments,\n base,\n true\n );\n }\n}\n\n/** Registers a concrete element with a program. */\nfunction registerConcreteElement(program: Program, element: Element): void {\n assert(!program.instancesByName.has(element.internalName));\n program.instancesByName.set(element.internalName, element);\n}\n\n/** Attempts to merge two elements. Returns the merged element on success. */\nfunction tryMerge(older: Element, newer: Element): DeclaredElement | null {\n // NOTE: some of the following cases are not supported by TS, not sure why exactly.\n // suggesting to just merge what seems to be possible for now and revisit later.\n assert(older.program === newer.program);\n assert(!newer.members);\n var merged: DeclaredElement | null = null;\n switch (older.kind) {\n case ElementKind.FUNCTION_PROTOTYPE: {\n switch (newer.kind) {\n case ElementKind.NAMESPACE: {\n copyMembers(newer, older);\n merged = older;\n break;\n }\n case ElementKind.TYPEDEFINITION: {\n if (!older.shadowType) {\n older.shadowType = newer;\n copyMembers(newer, older);\n merged = older;\n }\n break;\n }\n }\n break;\n }\n case ElementKind.CLASS_PROTOTYPE:\n case ElementKind.ENUM: {\n if (newer.kind == ElementKind.NAMESPACE) {\n copyMembers(newer, older);\n merged = older;\n break;\n }\n break;\n }\n case ElementKind.NAMESPACE: {\n switch (newer.kind) {\n case ElementKind.ENUM:\n case ElementKind.CLASS_PROTOTYPE: // TS2434\n case ElementKind.FUNCTION_PROTOTYPE: { // TS2434\n copyMembers(older, newer);\n merged = newer;\n break;\n }\n case ElementKind.NAMESPACE: {\n copyMembers(newer, older);\n merged = older;\n break;\n }\n case ElementKind.TYPEDEFINITION: {\n if (!older.shadowType) {\n older.shadowType = newer;\n copyMembers(newer, older);\n merged = older;\n }\n break;\n }\n }\n break;\n }\n case ElementKind.GLOBAL: {\n if (newer.kind == ElementKind.TYPEDEFINITION) {\n if (!older.shadowType) {\n older.shadowType = newer;\n copyMembers(newer, older);\n merged = older;\n }\n }\n break;\n }\n case ElementKind.TYPEDEFINITION: {\n switch (newer.kind) {\n case ElementKind.GLOBAL:\n case ElementKind.FUNCTION_PROTOTYPE:\n case ElementKind.NAMESPACE: {\n if (!newer.shadowType) {\n newer.shadowType = older;\n copyMembers(older, newer);\n merged = newer;\n }\n break;\n }\n }\n break;\n }\n }\n if (merged) {\n let olderIsExport = older.is(CommonFlags.EXPORT) || older.hasDecorator(DecoratorFlags.GLOBAL);\n let newerIsExport = newer.is(CommonFlags.EXPORT) || newer.hasDecorator(DecoratorFlags.GLOBAL);\n if (olderIsExport != newerIsExport) {\n older.program.error(\n DiagnosticCode.Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local,\n merged.identifierNode.range, merged.identifierNode.text\n );\n }\n }\n return merged;\n}\n\n/** Copies the members of `src` to `dest`. */\nfunction copyMembers(src: Element, dest: Element): void {\n var srcMembers = src.members;\n if (srcMembers) {\n let destMembers = dest.members;\n if (!destMembers) dest.members = destMembers = new Map();\n for (let [memberName, member] of srcMembers) {\n destMembers.set(memberName, member);\n }\n }\n}\n\n/** Mangles the internal name of an element with the specified name that is a child of the given parent. */\nexport function mangleInternalName(name: string, parent: Element, isInstance: bool, asGlobal: bool = false): string {\n switch (parent.kind) {\n case ElementKind.FILE: {\n if (asGlobal) return name;\n return parent.internalName + PATH_DELIMITER + name;\n }\n case ElementKind.FUNCTION: {\n if (asGlobal) return name;\n assert(!isInstance);\n return parent.internalName + INNER_DELIMITER + name;\n }\n default: {\n return mangleInternalName(parent.name, parent.parent, parent.is(CommonFlags.INSTANCE), asGlobal)\n + (isInstance ? INSTANCE_DELIMITER : STATIC_DELIMITER) + name;\n }\n }\n}\n","/**\n * A thin wrapper around Binaryen's C-API.\n * @module module\n *//***/\n\nimport { Target } from \"./common\";\n\nexport type ModuleRef = usize;\nexport type FunctionTypeRef = usize;\nexport type FunctionRef = usize;\nexport type ExpressionRef = usize;\nexport type GlobalRef = usize;\nexport type ImportRef = usize;\nexport type ExportRef = usize;\nexport type RelooperRef = usize;\nexport type RelooperBlockRef = usize;\nexport type Index = u32;\n\nexport enum NativeType {\n None = _BinaryenTypeNone(),\n I32 = _BinaryenTypeInt32(),\n I64 = _BinaryenTypeInt64(),\n F32 = _BinaryenTypeFloat32(),\n F64 = _BinaryenTypeFloat64(),\n V128 = _BinaryenTypeVec128(),\n Unreachable = _BinaryenTypeUnreachable(),\n Auto = _BinaryenTypeAuto()\n}\n\nexport enum FeatureFlags {\n Atomics = _BinaryenFeatureAtomics(),\n MutableGloabls = _BinaryenFeatureMutableGlobals(),\n NontrappingFPToInt = _BinaryenFeatureNontrappingFPToInt(),\n SIMD128 = _BinaryenFeatureSIMD128(),\n BulkMemory = _BinaryenFeatureBulkMemory(),\n SignExt = _BinaryenFeatureSignExt(),\n ExceptionHandling = _BinaryenFeatureExceptionHandling()\n}\n\nexport enum ExpressionId {\n Invalid = _BinaryenInvalidId(),\n Block = _BinaryenBlockId(),\n If = _BinaryenIfId(),\n Loop = _BinaryenLoopId(),\n Break = _BinaryenBreakId(),\n Switch = _BinaryenSwitchId(),\n Call = _BinaryenCallId(),\n CallIndirect = _BinaryenCallIndirectId(),\n LocalGet = _BinaryenLocalGetId(),\n LocalSet = _BinaryenLocalSetId(),\n GlobalGet = _BinaryenGlobalGetId(),\n GlobalSet = _BinaryenGlobalSetId(),\n Load = _BinaryenLoadId(),\n Store = _BinaryenStoreId(),\n Const = _BinaryenConstId(),\n Unary = _BinaryenUnaryId(),\n Binary = _BinaryenBinaryId(),\n Select = _BinaryenSelectId(),\n Drop = _BinaryenDropId(),\n Return = _BinaryenReturnId(),\n Host = _BinaryenHostId(),\n Nop = _BinaryenNopId(),\n Unreachable = _BinaryenUnreachableId(),\n AtomicCmpxchg = _BinaryenAtomicCmpxchgId(),\n AtomicRMW = _BinaryenAtomicRMWId(),\n AtomicWait = _BinaryenAtomicWaitId(),\n AtomicNotify = _BinaryenAtomicNotifyId(),\n SIMDExtract = _BinaryenSIMDExtractId(),\n SIMDReplace = _BinaryenSIMDReplaceId(),\n SIMDShuffle = _BinaryenSIMDShuffleId(),\n SIMDBitselect = _BinaryenSIMDBitselectId(),\n SIMDShift = _BinaryenSIMDShiftId(),\n MemoryInit = _BinaryenMemoryInitId(),\n DataDrop = _BinaryenDataDropId(),\n MemoryCopy = _BinaryenMemoryCopyId(),\n MemoryFill = _BinaryenMemoryFillId()\n}\n\nexport enum UnaryOp {\n ClzI32 = _BinaryenClzInt32(),\n CtzI32 = _BinaryenCtzInt32(),\n PopcntI32 = _BinaryenPopcntInt32(),\n NegF32 = _BinaryenNegFloat32(),\n AbsF32 = _BinaryenAbsFloat32(),\n CeilF32 = _BinaryenCeilFloat32(),\n FloorF32 = _BinaryenFloorFloat32(),\n TruncF32 = _BinaryenTruncFloat32(),\n NearestF32 = _BinaryenNearestFloat32(),\n SqrtF32 = _BinaryenSqrtFloat32(),\n EqzI32 = _BinaryenEqZInt32(),\n ClzI64 = _BinaryenClzInt64(),\n CtzI64 = _BinaryenCtzInt64(),\n PopcntI64 = _BinaryenPopcntInt64(),\n NegF64 = _BinaryenNegFloat64(),\n AbsF64 = _BinaryenAbsFloat64(),\n CeilF64 = _BinaryenCeilFloat64(),\n FloorF64 = _BinaryenFloorFloat64(),\n TruncF64 = _BinaryenTruncFloat64(),\n NearestF64 = _BinaryenNearestFloat64(),\n SqrtF64 = _BinaryenSqrtFloat64(),\n EqzI64 = _BinaryenEqZInt64(),\n ExtendI32 = _BinaryenExtendSInt32(),\n ExtendU32 = _BinaryenExtendUInt32(),\n WrapI64 = _BinaryenWrapInt64(),\n TruncF32ToI32 = _BinaryenTruncSFloat32ToInt32(),\n TruncF32ToI64 = _BinaryenTruncSFloat32ToInt64(),\n TruncF32ToU32 = _BinaryenTruncUFloat32ToInt32(),\n TruncF32ToU64 = _BinaryenTruncUFloat32ToInt64(),\n TruncF64ToI32 = _BinaryenTruncSFloat64ToInt32(),\n TruncF64ToI64 = _BinaryenTruncSFloat64ToInt64(),\n TruncF64ToU32 = _BinaryenTruncUFloat64ToInt32(),\n TruncF64ToU64 = _BinaryenTruncUFloat64ToInt64(),\n ReinterpretF32 = _BinaryenReinterpretFloat32(),\n ReinterpretF64 = _BinaryenReinterpretFloat64(),\n ConvertI32ToF32 = _BinaryenConvertSInt32ToFloat32(),\n ConvertI32ToF64 = _BinaryenConvertSInt32ToFloat64(),\n ConvertU32ToF32 = _BinaryenConvertUInt32ToFloat32(),\n ConvertU32ToF64 = _BinaryenConvertUInt32ToFloat64(),\n ConvertI64ToF32 = _BinaryenConvertSInt64ToFloat32(),\n ConvertI64ToF64 = _BinaryenConvertSInt64ToFloat64(),\n ConvertU64ToF32 = _BinaryenConvertUInt64ToFloat32(),\n ConvertU64ToF64 = _BinaryenConvertUInt64ToFloat64(),\n PromoteF32 = _BinaryenPromoteFloat32(),\n DemoteF64 = _BinaryenDemoteFloat64(),\n ReinterpretI32 = _BinaryenReinterpretInt32(),\n ReinterpretI64 = _BinaryenReinterpretInt64(),\n\n // see: https://github.com/WebAssembly/sign-extension-ops\n ExtendI8ToI32 = _BinaryenExtendS8Int32(),\n ExtendI16ToI32 = _BinaryenExtendS16Int32(),\n ExtendI8ToI64 = _BinaryenExtendS8Int64(),\n ExtendI16ToI64 = _BinaryenExtendS16Int64(),\n ExtendI32ToI64 = _BinaryenExtendS32Int64(),\n\n // see: https://github.com/WebAssembly/nontrapping-float-to-int-conversions\n // TruncF32ToI32Sat\n // TruncF32ToU32Sat\n // TruncF64ToI32Sat\n // TruncF64ToU32Sat\n // TruncF32ToI64Sat\n // TruncF32ToU64Sat\n // TruncF64ToI64Sat\n // TruncF64ToU64Sat\n\n // see: https://github.com/WebAssembly/simd\n SplatVecI8x16 = _BinaryenSplatVecI8x16(),\n SplatVecI16x8 = _BinaryenSplatVecI16x8(),\n SplatVecI32x4 = _BinaryenSplatVecI32x4(),\n SplatVecI64x2 = _BinaryenSplatVecI64x2(),\n SplatVecF32x4 = _BinaryenSplatVecF32x4(),\n SplatVecF64x2 = _BinaryenSplatVecF64x2(),\n NotVec128 = _BinaryenNotVec128(),\n NegVecI8x16 = _BinaryenNegVecI8x16(),\n AnyTrueVecI8x16 = _BinaryenAnyTrueVecI8x16(),\n AllTrueVecI8x16 = _BinaryenAllTrueVecI8x16(),\n NegVecI16x8 = _BinaryenNegVecI16x8(),\n AnyTrueVecI16x8 = _BinaryenAnyTrueVecI16x8(),\n AllTrueVecI16x8 = _BinaryenAllTrueVecI16x8(),\n NegVecI32x4 = _BinaryenNegVecI32x4(),\n AnyTrueVecI32x4 = _BinaryenAnyTrueVecI32x4(),\n AllTrueVecI32x4 = _BinaryenAllTrueVecI32x4(),\n NegVecI64x2 = _BinaryenNegVecI64x2(),\n AnyTrueVecI64x2 = _BinaryenAnyTrueVecI64x2(),\n AllTrueVecI64x2 = _BinaryenAllTrueVecI64x2(),\n AbsVecF32x4 = _BinaryenAbsVecF32x4(),\n NegVecF32x4 = _BinaryenNegVecF32x4(),\n SqrtVecF32x4 = _BinaryenSqrtVecF32x4(),\n AbsVecF64x2 = _BinaryenAbsVecF64x2(),\n NegVecF64x2 = _BinaryenNegVecF64x2(),\n SqrtVecF64x2 = _BinaryenSqrtVecF64x2(),\n TruncSatSVecF32x4ToVecI32x4 = _BinaryenTruncSatSVecF32x4ToVecI32x4(),\n TruncSatUVecF32x4ToVecI32x4 = _BinaryenTruncSatUVecF32x4ToVecI32x4(),\n TruncSatSVecF64x2ToVecI64x2 = _BinaryenTruncSatSVecF64x2ToVecI64x2(),\n TruncSatUVecF64x2ToVecI64x2 = _BinaryenTruncSatUVecF64x2ToVecI64x2(),\n ConvertSVecI32x4ToVecF32x4 = _BinaryenConvertSVecI32x4ToVecF32x4(),\n ConvertUVecI32x4ToVecF32x4 = _BinaryenConvertUVecI32x4ToVecF32x4(),\n ConvertSVecI64x2ToVecF64x2 = _BinaryenConvertSVecI64x2ToVecF64x2(),\n ConvertUVecI64x2ToVecF64x2 = _BinaryenConvertUVecI64x2ToVecF64x2()\n}\n\nexport enum BinaryOp {\n AddI32 = _BinaryenAddInt32(),\n SubI32 = _BinaryenSubInt32(),\n MulI32 = _BinaryenMulInt32(),\n DivI32 = _BinaryenDivSInt32(),\n DivU32 = _BinaryenDivUInt32(),\n RemI32 = _BinaryenRemSInt32(),\n RemU32 = _BinaryenRemUInt32(),\n AndI32 = _BinaryenAndInt32(),\n OrI32 = _BinaryenOrInt32(),\n XorI32 = _BinaryenXorInt32(),\n ShlI32 = _BinaryenShlInt32(),\n ShrU32 = _BinaryenShrUInt32(),\n ShrI32 = _BinaryenShrSInt32(),\n RotlI32 = _BinaryenRotLInt32(),\n RotrI32 = _BinaryenRotRInt32(),\n EqI32 = _BinaryenEqInt32(),\n NeI32 = _BinaryenNeInt32(),\n LtI32 = _BinaryenLtSInt32(),\n LtU32 = _BinaryenLtUInt32(),\n LeI32 = _BinaryenLeSInt32(),\n LeU32 = _BinaryenLeUInt32(),\n GtI32 = _BinaryenGtSInt32(),\n GtU32 = _BinaryenGtUInt32(),\n GeI32 = _BinaryenGeSInt32(),\n GeU32 = _BinaryenGeUInt32(),\n AddI64 = _BinaryenAddInt64(),\n SubI64 = _BinaryenSubInt64(),\n MulI64 = _BinaryenMulInt64(),\n DivI64 = _BinaryenDivSInt64(),\n DivU64 = _BinaryenDivUInt64(),\n RemI64 = _BinaryenRemSInt64(),\n RemU64 = _BinaryenRemUInt64(),\n AndI64 = _BinaryenAndInt64(),\n OrI64 = _BinaryenOrInt64(),\n XorI64 = _BinaryenXorInt64(),\n ShlI64 = _BinaryenShlInt64(),\n ShrU64 = _BinaryenShrUInt64(),\n ShrI64 = _BinaryenShrSInt64(),\n RotlI64 = _BinaryenRotLInt64(),\n RotrI64 = _BinaryenRotRInt64(),\n EqI64 = _BinaryenEqInt64(),\n NeI64 = _BinaryenNeInt64(),\n LtI64 = _BinaryenLtSInt64(),\n LtU64 = _BinaryenLtUInt64(),\n LeI64 = _BinaryenLeSInt64(),\n LeU64 = _BinaryenLeUInt64(),\n GtI64 = _BinaryenGtSInt64(),\n GtU64 = _BinaryenGtUInt64(),\n GeI64 = _BinaryenGeSInt64(),\n GeU64 = _BinaryenGeUInt64(),\n AddF32 = _BinaryenAddFloat32(),\n SubF32 = _BinaryenSubFloat32(),\n MulF32 = _BinaryenMulFloat32(),\n DivF32 = _BinaryenDivFloat32(),\n CopysignF32 = _BinaryenCopySignFloat32(),\n MinF32 = _BinaryenMinFloat32(),\n MaxF32 = _BinaryenMaxFloat32(),\n EqF32 = _BinaryenEqFloat32(),\n NeF32 = _BinaryenNeFloat32(),\n LtF32 = _BinaryenLtFloat32(),\n LeF32 = _BinaryenLeFloat32(),\n GtF32 = _BinaryenGtFloat32(),\n GeF32 = _BinaryenGeFloat32(),\n AddF64 = _BinaryenAddFloat64(),\n SubF64 = _BinaryenSubFloat64(),\n MulF64 = _BinaryenMulFloat64(),\n DivF64 = _BinaryenDivFloat64(),\n CopysignF64 = _BinaryenCopySignFloat64(),\n MinF64 = _BinaryenMinFloat64(),\n MaxF64 = _BinaryenMaxFloat64(),\n EqF64 = _BinaryenEqFloat64(),\n NeF64 = _BinaryenNeFloat64(),\n LtF64 = _BinaryenLtFloat64(),\n LeF64 = _BinaryenLeFloat64(),\n GtF64 = _BinaryenGtFloat64(),\n GeF64 = _BinaryenGeFloat64(),\n\n // see: https://github.com/WebAssembly/simd\n EqVecI8x16 = _BinaryenEqVecI8x16(),\n NeVecI8x16 = _BinaryenNeVecI8x16(),\n LtSVecI8x16 = _BinaryenLtSVecI8x16(),\n LtUVecI8x16 = _BinaryenLtUVecI8x16(),\n LeSVecI8x16 = _BinaryenLeSVecI8x16(),\n LeUVecI8x16 = _BinaryenLeUVecI8x16(),\n GtSVecI8x16 = _BinaryenGtSVecI8x16(),\n GtUVecI8x16 = _BinaryenGtUVecI8x16(),\n GeSVecI8x16 = _BinaryenGeSVecI8x16(),\n GeUVecI8x16 = _BinaryenGeUVecI8x16(),\n EqVecI16x8 = _BinaryenEqVecI16x8(),\n NeVecI16x8 = _BinaryenNeVecI16x8(),\n LtSVecI16x8 = _BinaryenLtSVecI16x8(),\n LtUVecI16x8 = _BinaryenLtUVecI16x8(),\n LeSVecI16x8 = _BinaryenLeSVecI16x8(),\n LeUVecI16x8 = _BinaryenLeUVecI16x8(),\n GtSVecI16x8 = _BinaryenGtSVecI16x8(),\n GtUVecI16x8 = _BinaryenGtUVecI16x8(),\n GeSVecI16x8 = _BinaryenGeSVecI16x8(),\n GeUVecI16x8 = _BinaryenGeUVecI16x8(),\n EqVecI32x4 = _BinaryenEqVecI32x4(),\n NeVecI32x4 = _BinaryenNeVecI32x4(),\n LtSVecI32x4 = _BinaryenLtSVecI32x4(),\n LtUVecI32x4 = _BinaryenLtUVecI32x4(),\n LeSVecI32x4 = _BinaryenLeSVecI32x4(),\n LeUVecI32x4 = _BinaryenLeUVecI32x4(),\n GtSVecI32x4 = _BinaryenGtSVecI32x4(),\n GtUVecI32x4 = _BinaryenGtUVecI32x4(),\n GeSVecI32x4 = _BinaryenGeSVecI32x4(),\n GeUVecI32x4 = _BinaryenGeUVecI32x4(),\n EqVecF32x4 = _BinaryenEqVecF32x4(),\n NeVecF32x4 = _BinaryenNeVecF32x4(),\n LtVecF32x4 = _BinaryenLtVecF32x4(),\n LeVecF32x4 = _BinaryenLeVecF32x4(),\n GtVecF32x4 = _BinaryenGtVecF32x4(),\n GeVecF32x4 = _BinaryenGeVecF32x4(),\n EqVecF64x2 = _BinaryenEqVecF64x2(),\n NeVecF64x2 = _BinaryenNeVecF64x2(),\n LtVecF64x2 = _BinaryenLtVecF64x2(),\n LeVecF64x2 = _BinaryenLeVecF64x2(),\n GtVecF64x2 = _BinaryenGtVecF64x2(),\n GeVecF64x2 = _BinaryenGeVecF64x2(),\n AndVec128 = _BinaryenAndVec128(),\n OrVec128 = _BinaryenOrVec128(),\n XorVec128 = _BinaryenXorVec128(),\n AddVecI8x16 = _BinaryenAddVecI8x16(),\n AddSatSVecI8x16 = _BinaryenAddSatSVecI8x16(),\n AddSatUVecI8x16 = _BinaryenAddSatUVecI8x16(),\n SubVecI8x16 = _BinaryenSubVecI8x16(),\n SubSatSVecI8x16 = _BinaryenSubSatSVecI8x16(),\n SubSatUVecI8x16 = _BinaryenSubSatUVecI8x16(),\n MulVecI8x16 = _BinaryenMulVecI8x16(),\n AddVecI16x8 = _BinaryenAddVecI16x8(),\n AddSatSVecI16x8 = _BinaryenAddSatSVecI16x8(),\n AddSatUVecI16x8 = _BinaryenAddSatUVecI16x8(),\n SubVecI16x8 = _BinaryenSubVecI16x8(),\n SubSatSVecI16x8 = _BinaryenSubSatSVecI16x8(),\n SubSatUVecI16x8 = _BinaryenSubSatUVecI16x8(),\n MulVecI16x8 = _BinaryenMulVecI16x8(),\n AddVecI32x4 = _BinaryenAddVecI32x4(),\n SubVecI32x4 = _BinaryenSubVecI32x4(),\n MulVecI32x4 = _BinaryenMulVecI32x4(),\n AddVecI64x2 = _BinaryenAddVecI64x2(),\n SubVecI64x2 = _BinaryenSubVecI64x2(),\n AddVecF32x4 = _BinaryenAddVecF32x4(),\n SubVecF32x4 = _BinaryenSubVecF32x4(),\n MulVecF32x4 = _BinaryenMulVecF32x4(),\n DivVecF32x4 = _BinaryenDivVecF32x4(),\n MinVecF32x4 = _BinaryenMinVecF32x4(),\n MaxVecF32x4 = _BinaryenMaxVecF32x4(),\n AddVecF64x2 = _BinaryenAddVecF64x2(),\n SubVecF64x2 = _BinaryenSubVecF64x2(),\n MulVecF64x2 = _BinaryenMulVecF64x2(),\n DivVecF64x2 = _BinaryenDivVecF64x2(),\n MinVecF64x2 = _BinaryenMinVecF64x2(),\n MaxVecF64x2 = _BinaryenMaxVecF64x2()\n}\n\nexport enum HostOp {\n MemorySize = _BinaryenMemorySize(),\n MemoryGrow = _BinaryenMemoryGrow(),\n}\n\nexport enum AtomicRMWOp {\n Add = _BinaryenAtomicRMWAdd(),\n Sub = _BinaryenAtomicRMWSub(),\n And = _BinaryenAtomicRMWAnd(),\n Or = _BinaryenAtomicRMWOr(),\n Xor = _BinaryenAtomicRMWXor(),\n Xchg = _BinaryenAtomicRMWXchg()\n}\n\nexport enum SIMDExtractOp {\n ExtractLaneSVecI8x16 = _BinaryenExtractLaneSVecI8x16(),\n ExtractLaneUVecI8x16 = _BinaryenExtractLaneUVecI8x16(),\n ExtractLaneSVecI16x8 = _BinaryenExtractLaneSVecI16x8(),\n ExtractLaneUVecI16x8 = _BinaryenExtractLaneUVecI16x8(),\n ExtractLaneVecI32x4 = _BinaryenExtractLaneVecI32x4(),\n ExtractLaneVecI64x2 = _BinaryenExtractLaneVecI64x2(),\n ExtractLaneVecF32x4 = _BinaryenExtractLaneVecF32x4(),\n ExtractLaneVecF64x2 = _BinaryenExtractLaneVecF64x2(),\n}\n\nexport enum SIMDReplaceOp {\n ReplaceLaneVecI8x16 = _BinaryenReplaceLaneVecI8x16(),\n ReplaceLaneVecI16x8 = _BinaryenReplaceLaneVecI16x8(),\n ReplaceLaneVecI32x4 = _BinaryenReplaceLaneVecI32x4(),\n ReplaceLaneVecI64x2 = _BinaryenReplaceLaneVecI64x2(),\n ReplaceLaneVecF32x4 = _BinaryenReplaceLaneVecF32x4(),\n ReplaceLaneVecF64x2 = _BinaryenReplaceLaneVecF64x2()\n}\n\nexport enum SIMDShiftOp {\n ShlVecI8x16 = _BinaryenShlVecI8x16(),\n ShrSVecI8x16 = _BinaryenShrSVecI8x16(),\n ShrUVecI8x16 = _BinaryenShrUVecI8x16(),\n ShlVecI16x8 = _BinaryenShlVecI16x8(),\n ShrSVecI16x8 = _BinaryenShrSVecI16x8(),\n ShrUVecI16x8 = _BinaryenShrUVecI16x8(),\n ShlVecI32x4 = _BinaryenShlVecI32x4(),\n ShrSVecI32x4 = _BinaryenShrSVecI32x4(),\n ShrUVecI32x4 = _BinaryenShrUVecI32x4(),\n ShlVecI64x2 = _BinaryenShlVecI64x2(),\n ShrSVecI64x2 = _BinaryenShrSVecI64x2(),\n ShrUVecI64x2 = _BinaryenShrUVecI64x2()\n}\n\nexport class MemorySegment {\n\n buffer: Uint8Array;\n offset: I64;\n\n static create(buffer: Uint8Array, offset: I64): MemorySegment {\n var segment = new MemorySegment();\n segment.buffer = buffer;\n segment.offset = offset;\n return segment;\n }\n}\n\nexport class Module {\n\n ref: ModuleRef;\n\n private lit: usize;\n\n static create(): Module {\n var module = new Module();\n module.ref = _BinaryenModuleCreate();\n module.lit = memory.allocate(_BinaryenSizeofLiteral());\n return module;\n }\n\n static createFrom(buffer: Uint8Array): Module {\n var cArr = allocU8Array(buffer);\n try {\n let module = new Module();\n module.ref = _BinaryenModuleRead(cArr, buffer.length);\n module.lit = memory.allocate(_BinaryenSizeofLiteral());\n return module;\n } finally {\n memory.free(changetype(cArr));\n }\n }\n\n private constructor() { }\n\n // types\n\n addFunctionType(\n name: string,\n result: NativeType,\n paramTypes: NativeType[] | null\n ): FunctionRef {\n var cStr = this.allocStringCached(name);\n var cArr = allocI32Array(paramTypes);\n try {\n return _BinaryenAddFunctionType(this.ref, cStr, result, cArr, paramTypes ? paramTypes.length : 0);\n } finally {\n memory.free(cArr);\n }\n }\n\n getFunctionTypeBySignature(\n result: NativeType,\n paramTypes: NativeType[] | null\n ): FunctionTypeRef {\n var cArr = allocI32Array(paramTypes);\n try {\n return _BinaryenGetFunctionTypeBySignature(this.ref, result, cArr, paramTypes ? paramTypes.length : 0);\n } finally {\n memory.free(cArr);\n }\n }\n\n removeFunctionType(name: string): void {\n var cStr = this.allocStringCached(name);\n _BinaryenRemoveFunctionType(this.ref, cStr);\n }\n\n // constants\n\n i32(value: i32): ExpressionRef {\n var out = this.lit;\n _BinaryenLiteralInt32(out, value);\n return _BinaryenConst(this.ref, out);\n }\n\n i64(valueLow: i32, valueHigh: i32 = 0): ExpressionRef {\n var out = this.lit;\n _BinaryenLiteralInt64(out, valueLow, valueHigh);\n return _BinaryenConst(this.ref, out);\n }\n\n f32(value: f32): ExpressionRef {\n var out = this.lit;\n _BinaryenLiteralFloat32(out, value);\n return _BinaryenConst(this.ref, out);\n }\n\n f64(value: f64): ExpressionRef {\n var out = this.lit;\n _BinaryenLiteralFloat64(out, value);\n return _BinaryenConst(this.ref, out);\n }\n\n v128(bytes: Uint8Array): ExpressionRef {\n assert(bytes.length == 16);\n var out = this.lit;\n for (let i = 0; i < 16; ++i) store(out + i, bytes[i]);\n _BinaryenLiteralVec128(out, out);\n return _BinaryenConst(this.ref, out);\n }\n\n // expressions\n\n unary(\n op: UnaryOp,\n expr: ExpressionRef\n ): ExpressionRef {\n return _BinaryenUnary(this.ref, op, expr);\n }\n\n binary(\n op: BinaryOp,\n left: ExpressionRef,\n right: ExpressionRef\n ): ExpressionRef {\n return _BinaryenBinary(this.ref, op, left, right);\n }\n\n host(\n op: HostOp,\n name: string | null = null,\n operands: ExpressionRef[] | null = null\n ): ExpressionRef {\n var cStr = this.allocStringCached(name);\n var cArr = allocPtrArray(operands);\n try {\n return _BinaryenHost(this.ref, op, cStr, cArr, operands ? (operands).length : 0);\n } finally {\n memory.free(cArr);\n }\n }\n\n local_get(\n index: i32,\n type: NativeType\n ): ExpressionRef {\n return _BinaryenLocalGet(this.ref, index, type);\n }\n\n local_tee(\n index: i32,\n value: ExpressionRef\n ): ExpressionRef {\n return _BinaryenLocalTee(this.ref, index, value);\n }\n\n global_get(\n name: string,\n type: NativeType\n ): ExpressionRef {\n var cStr = this.allocStringCached(name);\n return _BinaryenGlobalGet(this.ref, cStr, type);\n }\n\n load(\n bytes: Index,\n signed: bool,\n ptr: ExpressionRef,\n type: NativeType,\n offset: Index = 0,\n align: Index = bytes // naturally aligned by default\n ): ExpressionRef {\n return _BinaryenLoad(this.ref, bytes, signed ? 1 : 0, offset, align, type, ptr);\n }\n\n store(\n bytes: Index,\n ptr: ExpressionRef,\n value: ExpressionRef,\n type: NativeType,\n offset: Index = 0,\n align: Index = bytes // naturally aligned by default\n ): ExpressionRef {\n if (type < NativeType.None || type > NativeType.V128) throw new Error(\"here: \" + type);\n return _BinaryenStore(this.ref, bytes, offset, align, ptr, value, type);\n }\n\n atomic_load(\n bytes: Index,\n ptr: ExpressionRef,\n type: NativeType,\n offset: Index = 0\n ): ExpressionRef {\n return _BinaryenAtomicLoad(this.ref, bytes, offset, type, ptr);\n }\n\n atomic_store(\n bytes: Index,\n ptr: ExpressionRef,\n value: ExpressionRef,\n type: NativeType,\n offset: Index = 0\n ): ExpressionRef {\n return _BinaryenAtomicStore(this.ref, bytes, offset, ptr, value, type);\n }\n\n atomic_rmw(\n op: AtomicRMWOp,\n bytes: Index,\n offset: Index,\n ptr: ExpressionRef,\n value: ExpressionRef,\n type: NativeType\n ): ExpressionRef {\n return _BinaryenAtomicRMW(this.ref, op, bytes, offset, ptr, value, type);\n }\n\n atomic_cmpxchg(\n bytes: Index,\n offset: Index,\n ptr: ExpressionRef,\n expected: ExpressionRef,\n replacement: ExpressionRef,\n type: NativeType\n ): ExpressionRef {\n return _BinaryenAtomicCmpxchg(this.ref, bytes, offset, ptr, expected, replacement, type);\n }\n\n atomic_wait(\n ptr: ExpressionRef,\n expected: ExpressionRef,\n timeout: ExpressionRef,\n expectedType: NativeType\n ): ExpressionRef {\n return _BinaryenAtomicWait(this.ref, ptr, expected, timeout, expectedType);\n }\n\n atomic_notify(\n ptr: ExpressionRef,\n notifyCount: ExpressionRef\n ): ExpressionRef {\n return _BinaryenAtomicNotify(this.ref, ptr, notifyCount);\n }\n\n // statements\n\n local_set(\n index: Index,\n value: ExpressionRef\n ): ExpressionRef {\n return _BinaryenLocalSet(this.ref, index, value);\n }\n\n global_set(\n name: string,\n value: ExpressionRef\n ): ExpressionRef {\n var cStr = this.allocStringCached(name);\n return _BinaryenGlobalSet(this.ref, cStr, value);\n }\n\n block(\n label: string | null,\n children: ExpressionRef[],\n type: NativeType = NativeType.None\n ): ExpressionRef {\n var cStr = this.allocStringCached(label);\n var cArr = allocPtrArray(children);\n try {\n return _BinaryenBlock(this.ref, cStr, cArr, children.length, type);\n } finally {\n memory.free(cArr);\n }\n }\n\n br(\n label: string | null,\n condition: ExpressionRef = 0,\n value: ExpressionRef = 0\n ): ExpressionRef {\n var cStr = this.allocStringCached(label);\n return _BinaryenBreak(this.ref, cStr, condition, value);\n }\n\n drop(\n expression: ExpressionRef\n ): ExpressionRef {\n return _BinaryenDrop(this.ref, expression);\n }\n\n loop(\n label: string | null,\n body: ExpressionRef\n ): ExpressionRef {\n var cStr = this.allocStringCached(label);\n return _BinaryenLoop(this.ref, cStr, body);\n }\n\n if(\n condition: ExpressionRef,\n ifTrue: ExpressionRef,\n ifFalse: ExpressionRef = 0\n ): ExpressionRef {\n return _BinaryenIf(this.ref, condition, ifTrue, ifFalse);\n }\n\n nop(): ExpressionRef {\n return _BinaryenNop(this.ref);\n }\n\n return(\n expression: ExpressionRef = 0\n ): ExpressionRef {\n return _BinaryenReturn(this.ref, expression);\n }\n\n select(\n ifTrue: ExpressionRef,\n ifFalse: ExpressionRef,\n condition: ExpressionRef\n ): ExpressionRef {\n return _BinaryenSelect(this.ref, condition, ifTrue, ifFalse);\n }\n\n switch(\n names: string[],\n defaultName: string | null,\n condition: ExpressionRef,\n value: ExpressionRef = 0\n ): ExpressionRef {\n var numNames = names.length;\n var strs = new Array(numNames);\n for (let i = 0; i < numNames; ++i) {\n strs[i] = this.allocStringCached(names[i]);\n }\n var cArr = allocI32Array(strs);\n var cStr = this.allocStringCached(defaultName);\n try {\n return _BinaryenSwitch(this.ref, cArr, numNames, cStr, condition, value);\n } finally {\n memory.free(cArr);\n }\n }\n\n call(\n target: string,\n operands: ExpressionRef[] | null,\n returnType: NativeType\n ): ExpressionRef {\n var cStr = this.allocStringCached(target);\n var cArr = allocPtrArray(operands);\n try {\n return _BinaryenCall(this.ref, cStr, cArr, operands && operands.length || 0, returnType);\n } finally {\n memory.free(cArr);\n }\n }\n\n call_indirect(\n index: ExpressionRef,\n operands: ExpressionRef[] | null,\n typeName: string\n ): ExpressionRef {\n var cStr = this.allocStringCached(typeName);\n var cArr = allocPtrArray(operands);\n try {\n return _BinaryenCallIndirect(this.ref, index, cArr, operands && operands.length || 0, cStr);\n } finally {\n memory.free(cArr);\n }\n }\n\n unreachable(): ExpressionRef {\n return _BinaryenUnreachable(this.ref);\n }\n\n // bulk memory\n\n memory_copy(\n dest: ExpressionRef,\n source: ExpressionRef,\n size: ExpressionRef\n ): ExpressionRef {\n return _BinaryenMemoryCopy(this.ref, dest, source, size);\n }\n\n memory_fill(\n dest: ExpressionRef,\n value: ExpressionRef,\n size: ExpressionRef\n ): ExpressionRef {\n return _BinaryenMemoryFill(this.ref, dest, value, size);\n }\n\n // simd\n\n simd_extract(\n op: SIMDExtractOp,\n vec: ExpressionRef,\n idx: u8\n ): ExpressionRef {\n return _BinaryenSIMDExtract(this.ref, op, vec, idx);\n }\n\n simd_replace(\n op: SIMDReplaceOp,\n vec: ExpressionRef,\n idx: u8,\n value: ExpressionRef\n ): ExpressionRef {\n return _BinaryenSIMDReplace(this.ref, op, vec, idx, value);\n }\n\n simd_shuffle(\n vec1: ExpressionRef,\n vec2: ExpressionRef,\n mask: Uint8Array\n ): ExpressionRef {\n assert(mask.length == 16);\n var cArr = allocU8Array(mask);\n try {\n return _BinaryenSIMDShuffle(this.ref, vec1, vec2, cArr);\n } finally {\n memory.free(cArr);\n }\n }\n\n simd_bitselect(\n vec1: ExpressionRef,\n vec2: ExpressionRef,\n cond: ExpressionRef\n ): ExpressionRef {\n return _BinaryenSIMDBitselect(this.ref, vec1, vec2, cond);\n }\n\n simd_shift(\n op: SIMDShiftOp,\n vec: ExpressionRef,\n shift: ExpressionRef\n ): ExpressionRef {\n return _BinaryenSIMDShift(this.ref, op, vec, shift);\n }\n\n // meta\n\n addGlobal(\n name: string,\n type: NativeType,\n mutable: bool,\n initializer: ExpressionRef\n ): GlobalRef {\n var cStr = this.allocStringCached(name);\n return _BinaryenAddGlobal(this.ref, cStr, type, mutable ? 1 : 0, initializer);\n }\n\n removeGlobal(\n name: string\n ): void {\n var cStr = this.allocStringCached(name);\n _BinaryenRemoveGlobal(this.ref, cStr);\n }\n\n addFunction(\n name: string,\n type: FunctionTypeRef,\n varTypes: NativeType[] | null,\n body: ExpressionRef\n ): FunctionRef {\n var cStr = this.allocStringCached(name);\n var cArr = allocI32Array(varTypes);\n try {\n return _BinaryenAddFunction(this.ref, cStr, type, cArr, varTypes ? varTypes.length : 0, body);\n } finally {\n memory.free(cArr);\n }\n }\n\n removeFunction(name: string): void {\n var cStr = this.allocStringCached(name);\n _BinaryenRemoveFunction(this.ref, cStr);\n }\n\n private hasTemporaryFunction: bool = false;\n\n addTemporaryFunction(result: NativeType, paramTypes: NativeType[] | null, body: ExpressionRef): FunctionRef {\n this.hasTemporaryFunction = assert(!this.hasTemporaryFunction);\n var tempName = this.allocStringCached(\"\");\n var cArr = allocI32Array(paramTypes);\n try {\n let typeRef = _BinaryenAddFunctionType(this.ref, tempName, result, cArr, paramTypes ? paramTypes.length : 0);\n return _BinaryenAddFunction(this.ref, tempName, typeRef, 0, 0, body);\n } finally {\n memory.free(cArr);\n }\n }\n\n removeTemporaryFunction(): void {\n this.hasTemporaryFunction = !assert(this.hasTemporaryFunction);\n var tempName = this.allocStringCached(\"\");\n _BinaryenRemoveFunction(this.ref, tempName);\n _BinaryenRemoveFunctionType(this.ref, tempName);\n }\n\n addFunctionExport(\n internalName: string,\n externalName: string\n ): ExportRef {\n var cStr1 = this.allocStringCached(internalName);\n var cStr2 = this.allocStringCached(externalName);\n return _BinaryenAddFunctionExport(this.ref, cStr1, cStr2);\n }\n\n addTableExport(\n internalName: string,\n externalName: string\n ): ExportRef {\n var cStr1 = this.allocStringCached(internalName);\n var cStr2 = this.allocStringCached(externalName);\n return _BinaryenAddTableExport(this.ref, cStr1, cStr2);\n }\n\n addMemoryExport(\n internalName: string,\n externalName: string\n ): ExportRef {\n var cStr1 = this.allocStringCached(internalName);\n var cStr2 = this.allocStringCached(externalName);\n return _BinaryenAddMemoryExport(this.ref, cStr1, cStr2);\n }\n\n addGlobalExport(\n internalName: string,\n externalName: string\n ): ExportRef {\n var cStr1 = this.allocStringCached(internalName);\n var cStr2 = this.allocStringCached(externalName);\n return _BinaryenAddGlobalExport(this.ref, cStr1, cStr2);\n }\n\n removeExport(externalName: string): void {\n var cStr = this.allocStringCached(externalName);\n _BinaryenRemoveExport(this.ref, cStr);\n }\n\n addFunctionImport(\n internalName: string,\n externalModuleName: string,\n externalBaseName: string,\n functionType: FunctionTypeRef\n ): ImportRef {\n var cStr1 = this.allocStringCached(internalName);\n var cStr2 = this.allocStringCached(externalModuleName);\n var cStr3 = this.allocStringCached(externalBaseName);\n return _BinaryenAddFunctionImport(this.ref, cStr1, cStr2, cStr3, functionType);\n }\n\n addTableImport(\n internalName: string,\n externalModuleName: string,\n externalBaseName: string\n ): ImportRef {\n var cStr1 = this.allocStringCached(internalName);\n var cStr2 = this.allocStringCached(externalModuleName);\n var cStr3 = this.allocStringCached(externalBaseName);\n return _BinaryenAddTableImport(this.ref, cStr1, cStr2, cStr3);\n }\n\n addMemoryImport(\n internalName: string,\n externalModuleName: string,\n externalBaseName: string,\n shared: bool = false,\n ): ImportRef {\n var cStr1 = this.allocStringCached(internalName);\n var cStr2 = this.allocStringCached(externalModuleName);\n var cStr3 = this.allocStringCached(externalBaseName);\n return _BinaryenAddMemoryImport(this.ref, cStr1, cStr2, cStr3, shared);\n }\n\n addGlobalImport(\n internalName: string,\n externalModuleName: string,\n externalBaseName: string,\n globalType: NativeType\n ): ImportRef {\n var cStr1 = this.allocStringCached(internalName);\n var cStr2 = this.allocStringCached(externalModuleName);\n var cStr3 = this.allocStringCached(externalBaseName);\n return _BinaryenAddGlobalImport(this.ref, cStr1, cStr2, cStr3, globalType);\n }\n\n /** Unlimited memory constant. */\n static readonly UNLIMITED_MEMORY: Index = -1;\n\n setMemory(\n initial: Index,\n maximum: Index,\n segments: MemorySegment[],\n target: Target,\n exportName: string | null = null,\n shared: bool = false\n ): void {\n var cStr = this.allocStringCached(exportName);\n var k = segments.length;\n var segs = new Array(k);\n var psvs = new Array(k);\n var offs = new Array(k);\n var sizs = new Array(k);\n for (let i = 0; i < k; ++i) {\n let buffer = segments[i].buffer;\n let offset = segments[i].offset;\n segs[i] = allocU8Array(buffer);\n psvs[i] = 0; // no passive segments currently\n offs[i] = target == Target.WASM64\n ? this.i64(i64_low(offset), i64_high(offset))\n : this.i32(i64_low(offset));\n sizs[i] = buffer.length;\n }\n var cArr1 = allocI32Array(segs);\n var cArr2 = allocU8Array(psvs);\n var cArr3 = allocI32Array(offs);\n var cArr4 = allocI32Array(sizs);\n try {\n _BinaryenSetMemory(this.ref, initial, maximum, cStr, cArr1, cArr2, cArr3, cArr4, k, shared);\n } finally {\n memory.free(cArr4);\n memory.free(cArr3);\n memory.free(cArr2);\n memory.free(cArr1);\n for (let i = k - 1; i >= 0; --i) memory.free(segs[i]);\n }\n }\n\n setFunctionTable(\n initial: Index,\n maximum: Index,\n funcs: string[]\n ): void {\n var numNames = funcs.length;\n var names = new Array(numNames);\n for (let i = 0; i < numNames; ++i) {\n names[i] = this.allocStringCached(funcs[i]);\n }\n var cArr = allocI32Array(names);\n try {\n _BinaryenSetFunctionTable(this.ref, initial, maximum, cArr, numNames);\n } finally {\n memory.free(cArr);\n }\n }\n\n setStart(func: FunctionRef): void {\n _BinaryenSetStart(this.ref, func);\n }\n\n getOptimizeLevel(): i32 {\n return _BinaryenGetOptimizeLevel();\n }\n\n setOptimizeLevel(level: i32 = 2): void {\n _BinaryenSetOptimizeLevel(level);\n }\n\n getShrinkLevel(): i32 {\n return _BinaryenGetShrinkLevel();\n }\n\n setShrinkLevel(level: i32 = 1): void {\n _BinaryenSetShrinkLevel(level);\n }\n\n setDebugInfo(on: bool = false): void {\n _BinaryenSetDebugInfo(on);\n }\n\n getFeatures(): BinaryenFeatureFlags {\n return _BinaryenModuleGetFeatures(this.ref);\n }\n\n setFeatures(featureFlags: BinaryenFeatureFlags): void {\n _BinaryenModuleSetFeatures(this.ref, featureFlags);\n }\n\n optimize(func: FunctionRef = 0): void {\n if (func) {\n _BinaryenFunctionOptimize(func, this.ref);\n } else {\n _BinaryenModuleOptimize(this.ref);\n }\n }\n\n runPasses(passes: string[], func: FunctionRef = 0): void {\n var numNames = passes.length;\n var names = new Array(numNames);\n for (let i = 0; i < numNames; ++i) {\n names[i] = allocString(passes[i]);\n }\n var cArr = allocI32Array(names);\n try {\n if (func) {\n _BinaryenFunctionRunPasses(func, this.ref, cArr, numNames);\n } else {\n _BinaryenModuleRunPasses(this.ref, cArr, numNames);\n }\n } finally {\n memory.free(cArr);\n for (let i = numNames; i >= 0; --i) memory.free(names[i]);\n }\n }\n\n private cachedPrecomputeNames: usize = 0;\n\n precomputeExpression(expr: ExpressionRef): ExpressionRef {\n // remember the previous optimize levels and set to max instead, to be sure\n var previousOptimizeLevel = _BinaryenGetOptimizeLevel();\n var previousShrinkLevel = _BinaryenGetShrinkLevel();\n var previousDebugInfo = _BinaryenGetDebugInfo();\n _BinaryenSetOptimizeLevel(4);\n _BinaryenSetShrinkLevel(0);\n _BinaryenSetDebugInfo(false);\n\n // wrap the expression in a temp. function and run the precompute pass on it\n var type = _BinaryenExpressionGetType(expr);\n var func = this.addTemporaryFunction(type, null, expr);\n var names = this.cachedPrecomputeNames;\n if (!names) {\n this.cachedPrecomputeNames = names = allocI32Array([ this.allocStringCached(\"precompute\") ]);\n }\n _BinaryenFunctionRunPasses(func, this.ref, names, 1);\n expr = _BinaryenFunctionGetBody(func);\n this.removeTemporaryFunction();\n\n // reset optimize levels to previous\n _BinaryenSetOptimizeLevel(previousOptimizeLevel);\n _BinaryenSetShrinkLevel(previousShrinkLevel);\n _BinaryenSetDebugInfo(previousDebugInfo);\n return expr;\n }\n\n validate(): bool {\n return _BinaryenModuleValidate(this.ref) == 1;\n }\n\n interpret(): void {\n _BinaryenModuleInterpret(this.ref);\n }\n\n toBinary(sourceMapUrl: string | null): BinaryModule {\n var out = this.lit; // safe to reuse as long as..\n assert(_BinaryenSizeofLiteral() >= 12);\n var cStr = allocString(sourceMapUrl);\n var binaryPtr: usize = 0;\n var sourceMapPtr: usize = 0;\n try {\n _BinaryenModuleAllocateAndWrite(out, this.ref, cStr);\n binaryPtr = readInt(out);\n let binaryBytes = readInt(out + 4);\n sourceMapPtr = readInt(out + 4 * 2);\n let ret = new BinaryModule();\n ret.output = readBuffer(binaryPtr, binaryBytes);\n ret.sourceMap = readString(sourceMapPtr);\n return ret;\n } finally {\n if (cStr) memory.free(cStr);\n if (binaryPtr) memory.free(binaryPtr);\n if (sourceMapPtr) memory.free(sourceMapPtr);\n }\n }\n\n toText(): string {\n throw new Error(\"not implemented\"); // JS glue overrides this\n }\n\n toAsmjs(): string {\n throw new Error(\"not implemented\"); // JS glue overrides this\n }\n\n private cachedStrings: Map = new Map();\n\n private allocStringCached(str: string | null): usize {\n if (str == null) return 0;\n var cachedStrings = this.cachedStrings;\n if (cachedStrings.has(str)) return cachedStrings.get(str);\n var ptr = allocString(str);\n cachedStrings.set(str, ptr);\n return ptr;\n }\n\n dispose(): void {\n assert(this.ref);\n for (let ptr of this.cachedStrings.values()) memory.free(ptr);\n this.cachedStrings = new Map();\n memory.free(this.lit);\n memory.free(this.cachedPrecomputeNames);\n this.cachedPrecomputeNames = 0;\n _BinaryenModuleDispose(this.ref);\n this.ref = 0;\n }\n\n createRelooper(): Relooper {\n return Relooper.create(this);\n }\n\n cloneExpression(\n expr: ExpressionRef,\n noSideEffects: bool = false,\n maxDepth: i32 = i32.MAX_VALUE\n ): ExpressionRef { // currently supports side effect free expressions only\n if (maxDepth < 0) return 0;\n maxDepth -= 1;\n\n var nested1: ExpressionRef,\n nested2: ExpressionRef;\n\n switch (_BinaryenExpressionGetId(expr)) {\n case ExpressionId.Const: {\n switch (_BinaryenExpressionGetType(expr)) {\n case NativeType.I32: {\n return this.i32(_BinaryenConstGetValueI32(expr));\n }\n case NativeType.I64: {\n return this.i64(\n _BinaryenConstGetValueI64Low(expr),\n _BinaryenConstGetValueI64High(expr)\n );\n }\n case NativeType.F32: {\n return this.f32(_BinaryenConstGetValueF32(expr));\n }\n case NativeType.F64: {\n return this.f64(_BinaryenConstGetValueF64(expr));\n }\n case NativeType.V128: {\n // TODO\n return 0;\n }\n default: {\n throw new Error(\"concrete type expected\");\n }\n }\n }\n case ExpressionId.LocalGet: {\n return _BinaryenLocalGet(this.ref,\n _BinaryenLocalGetGetIndex(expr),\n _BinaryenExpressionGetType(expr)\n );\n }\n case ExpressionId.GlobalGet: {\n let globalName = _BinaryenGlobalGetGetName(expr);\n if (!globalName) break;\n return _BinaryenGlobalGet(this.ref, globalName, _BinaryenExpressionGetType(expr));\n }\n case ExpressionId.Load: {\n if (!(nested1 = this.cloneExpression(_BinaryenLoadGetPtr(expr), noSideEffects, maxDepth))) {\n break;\n }\n return (\n _BinaryenLoadIsAtomic(expr)\n ? _BinaryenAtomicLoad(this.ref,\n _BinaryenLoadGetBytes(expr),\n _BinaryenLoadGetOffset(expr),\n _BinaryenExpressionGetType(expr),\n nested1\n )\n : _BinaryenLoad(this.ref,\n _BinaryenLoadGetBytes(expr),\n _BinaryenLoadIsSigned(expr) ? 1 : 0,\n _BinaryenLoadGetOffset(expr),\n _BinaryenLoadGetAlign(expr),\n _BinaryenExpressionGetType(expr),\n nested1\n )\n );\n }\n case ExpressionId.Unary: {\n if (!(nested1 = this.cloneExpression(_BinaryenUnaryGetValue(expr), noSideEffects, maxDepth))) {\n break;\n }\n return _BinaryenUnary(this.ref, _BinaryenUnaryGetOp(expr), nested1);\n }\n case ExpressionId.Binary: {\n if (!(nested1 = this.cloneExpression(_BinaryenBinaryGetLeft(expr), noSideEffects, maxDepth))) {\n break;\n }\n if (!(nested2 = this.cloneExpression(_BinaryenBinaryGetRight(expr), noSideEffects, maxDepth))) {\n break;\n }\n return _BinaryenBinary(this.ref, _BinaryenBinaryGetOp(expr), nested1, nested2);\n }\n }\n return 0;\n }\n\n // source map generation\n\n addDebugInfoFile(name: string): Index {\n var cStr = allocString(name);\n try {\n return _BinaryenModuleAddDebugInfoFileName(this.ref, cStr);\n } finally {\n memory.free(cStr);\n }\n }\n\n getDebugInfoFile(index: Index): string | null {\n return readString(_BinaryenModuleGetDebugInfoFileName(this.ref, index));\n }\n\n setDebugLocation(\n func: FunctionRef,\n expr: ExpressionRef,\n fileIndex: Index,\n lineNumber: Index,\n columnNumber: Index\n ): void {\n _BinaryenFunctionSetDebugLocation(func, expr, fileIndex, lineNumber, columnNumber);\n }\n}\n\n// expressions\n\nexport function getExpressionId(expr: ExpressionRef): ExpressionId {\n return _BinaryenExpressionGetId(expr);\n}\n\nexport function getExpressionType(expr: ExpressionRef): NativeType {\n return _BinaryenExpressionGetType(expr);\n}\n\nexport function getConstValueI32(expr: ExpressionRef): i32 {\n return _BinaryenConstGetValueI32(expr);\n}\n\nexport function getConstValueI64Low(expr: ExpressionRef): i32 {\n return _BinaryenConstGetValueI64Low(expr);\n}\n\nexport function getConstValueI64High(expr: ExpressionRef): i32 {\n return _BinaryenConstGetValueI64High(expr);\n}\n\nexport function getConstValueF32(expr: ExpressionRef): f32 {\n return _BinaryenConstGetValueF32(expr);\n}\n\nexport function getConstValueF64(expr: ExpressionRef): f32 {\n return _BinaryenConstGetValueF64(expr);\n}\n\nexport function getLocalGetIndex(expr: ExpressionRef): Index {\n return _BinaryenLocalGetGetIndex(expr);\n}\n\nexport function getLocalSetIndex(expr: ExpressionRef): Index {\n return _BinaryenLocalSetGetIndex(expr);\n}\n\nexport function getLocalSetValue(expr: ExpressionRef): ExpressionRef {\n return _BinaryenLocalSetGetValue(expr);\n}\n\nexport function isLocalTee(expr: ExpressionRef): bool {\n return _BinaryenLocalSetIsTee(expr);\n}\n\nexport function getGlobalGetName(expr: ExpressionRef): string | null {\n return readString(_BinaryenGlobalGetGetName(expr));\n}\n\nexport function getBinaryOp(expr: ExpressionRef): BinaryOp {\n return _BinaryenBinaryGetOp(expr);\n}\n\nexport function getBinaryLeft(expr: ExpressionRef): ExpressionRef {\n return _BinaryenBinaryGetLeft(expr);\n}\n\nexport function getBinaryRight(expr: ExpressionRef): ExpressionRef {\n return _BinaryenBinaryGetRight(expr);\n}\n\nexport function getUnaryOp(expr: ExpressionRef): UnaryOp {\n return _BinaryenUnaryGetOp(expr);\n}\n\nexport function getUnaryValue(expr: ExpressionRef): ExpressionRef {\n return _BinaryenUnaryGetValue(expr);\n}\n\nexport function getLoadBytes(expr: ExpressionRef): u32 {\n return _BinaryenLoadGetBytes(expr);\n}\n\nexport function getLoadOffset(expr: ExpressionRef): u32 {\n return _BinaryenLoadGetOffset(expr);\n}\n\nexport function getLoadPtr(expr: ExpressionRef): ExpressionRef {\n return _BinaryenLoadGetPtr(expr);\n}\n\nexport function isLoadSigned(expr: ExpressionRef): bool {\n return _BinaryenLoadIsSigned(expr);\n}\n\nexport function getStoreBytes(expr: ExpressionRef): u32 {\n return _BinaryenStoreGetBytes(expr);\n}\n\nexport function getStoreOffset(expr: ExpressionRef): u32 {\n return _BinaryenStoreGetOffset(expr);\n}\n\nexport function getStorePtr(expr: ExpressionRef): ExpressionRef {\n return _BinaryenStoreGetPtr(expr);\n}\n\nexport function getStoreValue(expr: ExpressionRef): ExpressionRef {\n return _BinaryenStoreGetValue(expr);\n}\n\nexport function getBlockName(expr: ExpressionRef): string | null {\n return readString(_BinaryenBlockGetName(expr));\n}\n\nexport function getBlockChildCount(expr: ExpressionRef): Index {\n return _BinaryenBlockGetNumChildren(expr);\n}\n\nexport function getBlockChild(expr: ExpressionRef, index: Index): ExpressionRef {\n return _BinaryenBlockGetChild(expr, index);\n}\n\nexport function getIfCondition(expr: ExpressionRef): ExpressionRef {\n return _BinaryenIfGetCondition(expr);\n}\n\nexport function getIfTrue(expr: ExpressionRef): ExpressionRef {\n return _BinaryenIfGetIfTrue(expr);\n}\n\nexport function getIfFalse(expr: ExpressionRef): ExpressionRef {\n return _BinaryenIfGetIfFalse(expr);\n}\n\nexport function getLoopName(expr: ExpressionRef): string | null {\n return readString(_BinaryenLoopGetName(expr));\n}\n\nexport function getLoopBody(expr: ExpressionRef): ExpressionRef {\n return _BinaryenLoopGetBody(expr);\n}\n\nexport function getBreakName(expr: ExpressionRef): string | null {\n return readString(_BinaryenBreakGetName(expr));\n}\n\nexport function getBreakCondition(expr: ExpressionRef): ExpressionRef {\n return _BinaryenBreakGetCondition(expr);\n}\n\nexport function getSelectThen(expr: ExpressionRef): ExpressionRef {\n return _BinaryenSelectGetIfTrue(expr);\n}\n\nexport function getSelectElse(expr: ExpressionRef): ExpressionRef {\n return _BinaryenSelectGetIfFalse(expr);\n}\n\nexport function getSelectCondition(expr: ExpressionRef): ExpressionRef {\n return _BinaryenSelectGetCondition(expr);\n}\n\nexport function getDropValue(expr: ExpressionRef): ExpressionRef {\n return _BinaryenDropGetValue(expr);\n}\n\nexport function getReturnValue(expr: ExpressionRef): ExpressionRef {\n return _BinaryenReturnGetValue(expr);\n}\n\nexport function getCallTarget(expr: ExpressionRef): string | null {\n return readString(_BinaryenCallGetTarget(expr));\n}\n\nexport function getCallOperandCount(expr: ExpressionRef): i32 {\n return _BinaryenCallGetNumOperands(expr);\n}\n\nexport function getCallOperand(expr: ExpressionRef, index: Index): ExpressionRef {\n return _BinaryenCallGetOperand(expr, index);\n}\n\nexport function getHostOp(expr: ExpressionRef): ExpressionRef {\n return _BinaryenHostGetOp(expr);\n}\n\nexport function getHostOperandCount(expr: ExpressionRef): Index {\n return _BinaryenHostGetNumOperands(expr);\n}\n\nexport function getHostOperand(expr: ExpressionRef, index: Index): ExpressionRef {\n return _BinaryenHostGetOperand(expr, index);\n}\n\nexport function getHostName(expr: ExpressionRef): string | null {\n return readString(_BinaryenHostGetNameOperand(expr));\n}\n\n// functions\n\nexport function getFunctionBody(func: FunctionRef): ExpressionRef {\n return _BinaryenFunctionGetBody(func);\n}\n\nexport function getFunctionName(func: FunctionRef): string | null {\n return readString(_BinaryenFunctionGetName(func));\n}\n\nexport function getFunctionParamCount(func: FunctionRef): Index {\n return _BinaryenFunctionGetNumParams(func);\n}\n\nexport function getFunctionParamType(func: FunctionRef, index: Index): NativeType {\n return _BinaryenFunctionGetParam(func, index);\n}\n\nexport function getFunctionResultType(func: FunctionRef): NativeType {\n return _BinaryenFunctionGetResult(func);\n}\n\nexport class Relooper {\n\n module: Module;\n ref: RelooperRef;\n\n static create(module: Module): Relooper {\n var relooper = new Relooper();\n relooper.module = module;\n relooper.ref = _RelooperCreate(module.ref);\n return relooper;\n }\n\n private constructor() {}\n\n addBlock(code: ExpressionRef): RelooperBlockRef {\n return _RelooperAddBlock(this.ref, code);\n }\n\n addBranch(\n from: RelooperBlockRef,\n to: RelooperBlockRef,\n condition: ExpressionRef = 0,\n code: ExpressionRef = 0\n ): void {\n _RelooperAddBranch(from, to, condition, code);\n }\n\n addBlockWithSwitch(code: ExpressionRef, condition: ExpressionRef): RelooperBlockRef {\n return _RelooperAddBlockWithSwitch(this.ref, code, condition);\n }\n\n addBranchForSwitch(\n from: RelooperBlockRef,\n to: RelooperBlockRef,\n indexes: i32[],\n code: ExpressionRef = 0\n ): void {\n var cArr = allocI32Array(indexes);\n try {\n _RelooperAddBranchForSwitch(from, to, cArr, indexes.length, code);\n } finally {\n memory.free(cArr);\n }\n }\n\n renderAndDispose(entry: RelooperBlockRef, labelHelper: Index): ExpressionRef {\n return _RelooperRenderAndDispose(this.ref, entry, labelHelper);\n }\n}\n\n// export function hasSideEffects(expr: ExpressionRef): bool {\n// switch (_BinaryenExpressionGetId(expr = getPtr(expr))) {\n// case ExpressionId.GetLocal:\n// case ExpressionId.GetGlobal:\n// case ExpressionId.Const:\n// case ExpressionId.Nop:\n// case ExpressionId.Unreachable: {\n// return false;\n// }\n// case ExpressionId.Block: {\n// for (let i = 0, k = _BinaryenBlockGetNumChildren(expr); i < k; ++i) {\n// if (hasSideEffects(_BinaryenBlockGetChild(expr, i))) return true;\n// }\n// return false;\n// }\n// case ExpressionId.If: {\n// return hasSideEffects(_BinaryenIfGetCondition(expr))\n// || hasSideEffects(_BinaryenIfGetIfTrue(expr))\n// || hasSideEffects(_BinaryenIfGetIfFalse(expr));\n// }\n// case ExpressionId.Unary: {\n// return hasSideEffects(_BinaryenUnaryGetValue(expr));\n// }\n// case ExpressionId.Binary: {\n// return hasSideEffects(_BinaryenBinaryGetLeft(expr))\n// || hasSideEffects(_BinaryenBinaryGetRight(expr));\n// }\n// case ExpressionId.Drop: {\n// return hasSideEffects(_BinaryenDropGetValue(expr));\n// }\n// case ExpressionId.Select: {\n// return hasSideEffects(_BinaryenSelectGetIfTrue(expr))\n// || hasSideEffects(_BinaryenSelectGetIfFalse(expr))\n// || hasSideEffects(_BinaryenSelectGetCondition(expr));\n// }\n// }\n// return true;\n// }\n\n// helpers\n// can't do stack allocation here: STACKTOP is a global in WASM but a hidden variable in asm.js\n\nfunction allocU8Array(u8s: Uint8Array | null): usize {\n if (!u8s) return 0;\n var numValues = u8s.length;\n var ptr = memory.allocate(numValues);\n var idx = ptr;\n for (let i = 0; i < numValues; ++i) {\n store(idx++, u8s[i]);\n }\n return ptr;\n}\n\nfunction allocI32Array(i32s: i32[] | null): usize {\n if (!i32s) return 0;\n var ptr = memory.allocate(i32s.length << 2);\n var idx = ptr;\n for (let i = 0, k = i32s.length; i < k; ++i) {\n let val = i32s[i];\n // store(idx, val) is not portable\n store(idx , ( val & 0xff) as u8);\n store(idx + 1, ((val >> 8) & 0xff) as u8);\n store(idx + 2, ((val >> 16) & 0xff) as u8);\n store(idx + 3, ( val >>> 24 ) as u8);\n idx += 4;\n }\n return ptr;\n}\n\nfunction allocPtrArray(ptrs: usize[] | null): usize {\n return allocI32Array(ptrs); // TODO: WASM64 one day\n}\n\nfunction stringLengthUTF8(str: string): usize {\n var len = 0;\n for (let i = 0, k = str.length; i < k; ++i) {\n let u = str.charCodeAt(i);\n if (u >= 0xD800 && u <= 0xDFFF && i + 1 < k) {\n u = 0x10000 + ((u & 0x3FF) << 10) | (str.charCodeAt(++i) & 0x3FF);\n }\n if (u <= 0x7F) {\n ++len;\n } else if (u <= 0x7FF) {\n len += 2;\n } else if (u <= 0xFFFF) {\n len += 3;\n } else if (u <= 0x1FFFFF) {\n len += 4;\n } else if (u <= 0x3FFFFFF) {\n len += 5;\n } else {\n len += 6;\n }\n }\n return len;\n}\n\nfunction allocString(str: string | null): usize {\n if (str == null) return 0;\n var ptr = memory.allocate(stringLengthUTF8(str) + 1);\n // the following is based on Emscripten's stringToUTF8Array\n var idx = ptr;\n for (let i = 0, k = str.length; i < k; ++i) {\n let u = str.charCodeAt(i);\n if (u >= 0xD800 && u <= 0xDFFF && i + 1 < k) {\n u = 0x10000 + ((u & 0x3FF) << 10) | (str.charCodeAt(++i) & 0x3FF);\n }\n if (u <= 0x7F) {\n store(idx++, u as u8);\n } else if (u <= 0x7FF) {\n store(idx++, (0xC0 | (u >>> 6) ) as u8);\n store(idx++, (0x80 | ( u & 63)) as u8);\n } else if (u <= 0xFFFF) {\n store(idx++, (0xE0 | (u >>> 12) ) as u8);\n store(idx++, (0x80 | ((u >>> 6) & 63)) as u8);\n store(idx++, (0x80 | ( u & 63)) as u8);\n } else if (u <= 0x1FFFFF) {\n store(idx++, (0xF0 | (u >>> 18) ) as u8);\n store(idx++, (0x80 | ((u >>> 12) & 63)) as u8);\n store(idx++, (0x80 | ((u >>> 6) & 63)) as u8);\n store(idx++, (0x80 | ( u & 63)) as u8);\n } else if (u <= 0x3FFFFFF) {\n store(idx++, (0xF8 | (u >>> 24) ) as u8);\n store(idx++, (0x80 | ((u >>> 18) & 63)) as u8);\n store(idx++, (0x80 | ((u >>> 12) & 63)) as u8);\n store(idx++, (0x80 | ((u >>> 6) & 63)) as u8);\n store(idx++, (0x80 | ( u & 63)) as u8);\n } else {\n store(idx++, (0xFC | (u >>> 30) ) as u8);\n store(idx++, (0x80 | ((u >>> 24) & 63)) as u8);\n store(idx++, (0x80 | ((u >>> 18) & 63)) as u8);\n store(idx++, (0x80 | ((u >>> 12) & 63)) as u8);\n store(idx++, (0x80 | ((u >>> 6) & 63)) as u8);\n store(idx++, (0x80 | ( u & 63)) as u8);\n }\n }\n store(idx, 0);\n return ptr;\n}\n\nfunction readInt(ptr: usize): i32 {\n return (\n load(ptr ) |\n (load(ptr + 1) << 8) |\n (load(ptr + 2) << 16) |\n (load(ptr + 3) << 24)\n );\n}\n\nfunction readBuffer(ptr: usize, length: usize): Uint8Array {\n var ret = new Uint8Array(length);\n for (let i: usize = 0; i < length; ++i) {\n ret[i] = load(ptr + i);\n }\n return ret;\n}\n\nexport function readString(ptr: usize): string | null {\n if (!ptr) return null;\n var arr = new Array();\n // the following is based on Emscripten's UTF8ArrayToString\n var cp: u32;\n var u1: u32, u2: u32, u3: u32, u4: u32, u5: u32;\n while (cp = load(ptr++)) {\n if (!(cp & 0x80)) {\n arr.push(cp);\n continue;\n }\n u1 = load(ptr++) & 63;\n if ((cp & 0xE0) == 0xC0) {\n arr.push(((cp & 31) << 6) | u1);\n continue;\n }\n u2 = load(ptr++) & 63;\n if ((cp & 0xF0) == 0xE0) {\n cp = ((cp & 15) << 12) | (u1 << 6) | u2;\n } else {\n u3 = load(ptr++) & 63;\n if ((cp & 0xF8) == 0xF0) {\n cp = ((cp & 7) << 18) | (u1 << 12) | (u2 << 6) | u3;\n } else {\n u4 = load(ptr++) & 63;\n if ((cp & 0xFC) == 0xF8) {\n cp = ((cp & 3) << 24) | (u1 << 18) | (u2 << 12) | (u3 << 6) | u4;\n } else {\n u5 = load(ptr++) & 63;\n cp = ((cp & 1) << 30) | (u1 << 24) | (u2 << 18) | (u3 << 12) | (u4 << 6) | u5;\n }\n }\n }\n arr.push(cp);\n // if (cp < 0x10000) {\n // arr.push(cp);\n // } else {\n // var ch = cp - 0x10000;\n // arr.push(0xD800 | (ch >> 10));\n // arr.push(0xDC00 | (ch & 0x3FF));\n // }\n }\n // return String.fromCharCodes(arr);\n return String.fromCodePoints(arr);\n}\n\n/** Result structure of {@link Module#toBinary}. */\nexport class BinaryModule {\n /** WebAssembly binary. */\n output: Uint8Array;\n /** Source map, if generated. */\n sourceMap: string | null;\n}\n\n/** Tests if an expression needs an explicit 'unreachable' when it is the terminating statement. */\nexport function needsExplicitUnreachable(expr: ExpressionRef): bool {\n // not applicable if pushing a value to the stack\n if (_BinaryenExpressionGetType(expr) != NativeType.Unreachable) return false;\n\n switch (_BinaryenExpressionGetId(expr)) {\n case ExpressionId.Unreachable:\n case ExpressionId.Return: return false;\n case ExpressionId.Break: return _BinaryenBreakGetCondition(expr) != 0;\n case ExpressionId.Block: {\n if (!_BinaryenBlockGetName(expr)) { // can't break out of it\n let numChildren = _BinaryenBlockGetNumChildren(expr); // last child needs unreachable\n return numChildren > 0 && needsExplicitUnreachable(_BinaryenBlockGetChild(expr, numChildren - 1));\n }\n }\n }\n return true;\n}\n\n/** Traverses all expression members of an expression, calling the given visitor. */\nexport function traverse(expr: ExpressionRef, data: T, visit: (expr: ExpressionRef, data: T) => void): bool {\n switch (getExpressionId(expr)) {\n case ExpressionId.Block: {\n for (let i = 0, n = _BinaryenBlockGetNumChildren(expr); i < n; ++i) {\n visit(_BinaryenBlockGetChild(expr, i), data);\n }\n break;\n }\n case ExpressionId.If: {\n visit(_BinaryenIfGetCondition(expr), data);\n visit(_BinaryenIfGetIfTrue(expr), data);\n let ifFalse = _BinaryenIfGetIfFalse(expr);\n if (ifFalse) visit(ifFalse, data);\n break;\n }\n case ExpressionId.Loop: {\n visit(_BinaryenLoopGetBody(expr), data);\n break;\n }\n case ExpressionId.Break: {\n let condition = _BinaryenBreakGetCondition(expr);\n if (condition) visit(condition, data);\n break;\n }\n case ExpressionId.Switch: {\n visit(_BinaryenSwitchGetCondition(expr), data);\n break;\n }\n case ExpressionId.Call: {\n for (let i = 0, n = _BinaryenCallGetNumOperands(expr); i < n; ++i) {\n visit(_BinaryenCallGetOperand(expr, i), data);\n }\n break;\n }\n case ExpressionId.CallIndirect: {\n for (let i = 0, n = _BinaryenCallIndirectGetNumOperands(expr); i < n; ++i) {\n visit(_BinaryenCallIndirectGetOperand(expr, i), data);\n }\n break;\n }\n case ExpressionId.LocalGet: {\n break;\n }\n case ExpressionId.LocalSet: {\n visit(_BinaryenLocalSetGetValue(expr), data);\n break;\n }\n case ExpressionId.GlobalGet: {\n break;\n }\n case ExpressionId.GlobalSet: {\n visit(_BinaryenGlobalSetGetValue(expr), data);\n break;\n }\n case ExpressionId.Load: {\n visit(_BinaryenLoadGetPtr(expr), data);\n break;\n }\n case ExpressionId.Store: {\n visit(_BinaryenStoreGetPtr(expr), data);\n visit(_BinaryenStoreGetValue(expr), data);\n break;\n }\n case ExpressionId.AtomicRMW: {\n visit(_BinaryenAtomicRMWGetPtr(expr), data);\n visit(_BinaryenAtomicRMWGetValue(expr), data);\n break;\n }\n case ExpressionId.AtomicCmpxchg: {\n visit(_BinaryenAtomicCmpxchgGetPtr(expr), data);\n visit(_BinaryenAtomicCmpxchgGetExpected(expr), data);\n visit(_BinaryenAtomicCmpxchgGetReplacement(expr), data);\n break;\n }\n case ExpressionId.AtomicWait: {\n visit(_BinaryenAtomicWaitGetPtr(expr), data);\n visit(_BinaryenAtomicWaitGetExpected(expr), data);\n visit(_BinaryenAtomicWaitGetTimeout(expr), data);\n break;\n }\n case ExpressionId.AtomicNotify: {\n visit(_BinaryenAtomicNotifyGetPtr(expr), data);\n break;\n }\n case ExpressionId.SIMDExtract: {\n visit(_BinaryenSIMDExtractGetVec(expr), data);\n break;\n }\n case ExpressionId.SIMDReplace: {\n visit(_BinaryenSIMDReplaceGetVec(expr), data);\n visit(_BinaryenSIMDReplaceGetValue(expr), data);\n break;\n }\n case ExpressionId.SIMDShuffle: {\n visit(_BinaryenSIMDShuffleGetLeft(expr), data);\n visit(_BinaryenSIMDShuffleGetRight(expr), data);\n break;\n }\n case ExpressionId.SIMDBitselect: {\n visit(_BinaryenSIMDBitselectGetLeft(expr), data);\n visit(_BinaryenSIMDBitselectGetRight(expr), data);\n visit(_BinaryenSIMDBitselectGetCond(expr), data);\n break;\n }\n case ExpressionId.SIMDShift: {\n visit(_BinaryenSIMDShiftGetVec(expr), data);\n visit(_BinaryenSIMDShiftGetShift(expr), data);\n break;\n }\n case ExpressionId.MemoryInit: {\n visit(_BinaryenMemoryInitGetDest(expr), data);\n visit(_BinaryenMemoryInitGetOffset(expr), data);\n visit(_BinaryenMemoryInitGetSize(expr), data);\n break;\n }\n case ExpressionId.DataDrop: {\n break;\n }\n case ExpressionId.MemoryCopy: {\n visit(_BinaryenMemoryCopyGetDest(expr), data);\n visit(_BinaryenMemoryCopyGetSource(expr), data);\n visit(_BinaryenMemoryCopyGetSize(expr), data);\n break;\n }\n case ExpressionId.MemoryFill: {\n visit(_BinaryenMemoryFillGetDest(expr), data);\n visit(_BinaryenMemoryFillGetValue(expr), data);\n visit(_BinaryenMemoryFillGetSize(expr), data);\n break;\n }\n case ExpressionId.Const: {\n break;\n }\n case ExpressionId.Unary: {\n visit(_BinaryenUnaryGetValue(expr), data);\n break;\n }\n case ExpressionId.Binary: {\n visit(_BinaryenBinaryGetLeft(expr), data);\n visit(_BinaryenBinaryGetRight(expr), data);\n break;\n }\n case ExpressionId.Select: {\n visit(_BinaryenSelectGetIfTrue(expr), data);\n visit(_BinaryenSelectGetIfFalse(expr), data);\n visit(_BinaryenSelectGetCondition(expr), data);\n break;\n }\n case ExpressionId.Drop: {\n visit(_BinaryenDropGetValue(expr), data);\n break;\n }\n case ExpressionId.Return: {\n visit(_BinaryenReturnGetValue(expr), data);\n break;\n }\n case ExpressionId.Host: {\n for (let i = 0, n = _BinaryenHostGetNumOperands(expr); i < n; ++i) {\n visit(_BinaryenHostGetOperand(expr, i), data);\n }\n break;\n }\n case ExpressionId.Nop: {\n break;\n }\n case ExpressionId.Unreachable: {\n break;\n }\n default: assert(false);\n }\n return true;\n}\n","/**\n * Abstract syntax tree representing a source file once parsed.\n * @module ast\n *//***/\n\nimport {\n CommonFlags,\n CommonSymbols,\n PATH_DELIMITER,\n LIBRARY_PREFIX\n} from \"./common\";\n\nimport {\n Token,\n Tokenizer,\n Range\n} from \"./tokenizer\";\n\nimport {\n normalizePath,\n resolvePath,\n CharCode\n} from \"./util\";\n\nexport { Token, Range };\n\n/** Indicates the kind of a node. */\nexport enum NodeKind {\n\n SOURCE,\n\n // types\n NAMEDTYPE,\n FUNCTIONTYPE,\n TYPENAME,\n TYPEPARAMETER,\n PARAMETER,\n\n // expressions\n IDENTIFIER,\n ASSERTION,\n BINARY,\n CALL,\n CLASS,\n COMMA,\n ELEMENTACCESS,\n FALSE,\n FUNCTION,\n INSTANCEOF,\n LITERAL,\n NEW,\n NULL,\n PARENTHESIZED,\n PROPERTYACCESS,\n TERNARY,\n SUPER,\n THIS,\n TRUE,\n CONSTRUCTOR,\n UNARYPOSTFIX,\n UNARYPREFIX,\n\n // statements\n BLOCK,\n BREAK,\n CONTINUE,\n DO,\n EMPTY,\n EXPORT,\n EXPORTDEFAULT,\n EXPORTIMPORT,\n EXPRESSION,\n FOR,\n IF,\n IMPORT,\n RETURN,\n SWITCH,\n THROW,\n TRY,\n VARIABLE,\n VOID,\n WHILE,\n\n // declaration statements\n CLASSDECLARATION,\n ENUMDECLARATION,\n ENUMVALUEDECLARATION,\n FIELDDECLARATION,\n FUNCTIONDECLARATION,\n IMPORTDECLARATION,\n INDEXSIGNATUREDECLARATION,\n INTERFACEDECLARATION,\n METHODDECLARATION,\n NAMESPACEDECLARATION,\n TYPEDECLARATION,\n VARIABLEDECLARATION,\n\n // special\n DECORATOR,\n EXPORTMEMBER,\n SWITCHCASE,\n COMMENT\n}\n\n/** Checks if a node represents a constant value. */\nexport function nodeIsConstantValue(kind: NodeKind): bool {\n switch (kind) {\n case NodeKind.LITERAL:\n case NodeKind.NULL:\n case NodeKind.TRUE:\n case NodeKind.FALSE: return true;\n }\n return false;\n}\n\n/** Checks if a node might be callable. */\nexport function nodeIsCallable(kind: NodeKind): bool {\n switch (kind) {\n case NodeKind.IDENTIFIER:\n case NodeKind.ASSERTION: // if kind=NONNULL\n case NodeKind.CALL:\n case NodeKind.ELEMENTACCESS:\n case NodeKind.PARENTHESIZED:\n case NodeKind.PROPERTYACCESS:\n case NodeKind.SUPER: return true;\n }\n return false;\n}\n\n/** Checks if a node might be callable with generic arguments. */\nexport function nodeIsGenericCallable(kind: NodeKind): bool {\n switch (kind) {\n case NodeKind.IDENTIFIER:\n case NodeKind.PROPERTYACCESS: return true;\n }\n return false;\n}\n\n/** Base class of all nodes. */\nexport abstract class Node {\n\n /** Node kind indicator. */\n kind: NodeKind;\n /** Source range. */\n range: Range;\n\n // types\n\n static createTypeName(\n name: IdentifierExpression,\n range: Range\n ): TypeName {\n var typeName = new TypeName();\n typeName.range = range;\n typeName.identifier = name;\n typeName.next = null;\n return typeName;\n }\n\n static createSimpleTypeName(\n name: string,\n range: Range\n ): TypeName {\n return Node.createTypeName(Node.createIdentifierExpression(name, range), range);\n }\n\n static createNamedType(\n name: TypeName,\n typeArguments: TypeNode[] | null,\n isNullable: bool,\n range: Range\n ): NamedTypeNode {\n var type = new NamedTypeNode();\n type.range = range;\n type.name = name;\n type.typeArguments = typeArguments;\n type.isNullable = isNullable;\n return type;\n }\n\n static createFunctionType(\n parameters: ParameterNode[],\n returnType: TypeNode,\n explicitThisType: NamedTypeNode | null,\n isNullable: bool,\n range: Range\n ): FunctionTypeNode {\n var type = new FunctionTypeNode();\n type.range = range;\n type.parameters = parameters;\n type.returnType = returnType;\n type.explicitThisType = explicitThisType;\n type.isNullable = isNullable;\n return type;\n }\n\n static createOmittedType(\n range: Range\n ): NamedTypeNode {\n return Node.createNamedType(\n Node.createSimpleTypeName(\"\", range),\n null,\n false,\n range\n );\n }\n\n static createTypeParameter(\n name: IdentifierExpression,\n extendsType: NamedTypeNode | null,\n defaultType: NamedTypeNode | null,\n range: Range\n ): TypeParameterNode {\n var elem = new TypeParameterNode();\n elem.range = range;\n elem.name = name;\n elem.extendsType = extendsType;\n elem.defaultType = defaultType;\n return elem;\n }\n\n static createParameter(\n name: IdentifierExpression,\n type: TypeNode,\n initializer: Expression | null,\n kind: ParameterKind,\n range: Range\n ): ParameterNode {\n var elem = new ParameterNode();\n elem.range = range;\n elem.name = name;\n elem.type = type;\n elem.initializer = initializer;\n elem.parameterKind = kind;\n return elem;\n }\n\n // special\n\n static createDecorator(\n name: Expression,\n args: Expression[] | null,\n range: Range\n ): DecoratorNode {\n var stmt = new DecoratorNode();\n stmt.range = range;\n stmt.name = name;\n stmt.arguments = args;\n stmt.decoratorKind = decoratorNameToKind(name);\n return stmt;\n }\n\n static createComment(\n text: string,\n kind: CommentKind,\n range: Range\n ): CommentNode {\n var node = new CommentNode();\n node.range = range;\n node.commentKind = kind;\n node.text = text;\n return node;\n }\n\n // expressions\n\n static createIdentifierExpression(\n name: string,\n range: Range,\n isQuoted: bool = false\n ): IdentifierExpression {\n var expr = new IdentifierExpression();\n expr.range = range;\n expr.text = name; // TODO: extract from range\n expr.symbol = name; // TODO: Symbol.for(name)\n expr.isQuoted = isQuoted;\n return expr;\n }\n\n static createEmptyIdentifierExpression(\n range: Range\n ): IdentifierExpression {\n var expr = new IdentifierExpression();\n expr.range = range;\n expr.text = \"\";\n return expr;\n }\n\n static createArrayLiteralExpression(\n elements: (Expression | null)[],\n range: Range\n ): ArrayLiteralExpression {\n var expr = new ArrayLiteralExpression();\n expr.range = range;\n expr.elementExpressions = elements;\n return expr;\n }\n\n static createAssertionExpression(\n assertionKind: AssertionKind,\n expression: Expression,\n toType: TypeNode | null,\n range: Range\n ): AssertionExpression {\n var expr = new AssertionExpression();\n expr.range = range;\n expr.assertionKind = assertionKind;\n expr.expression = expression;\n expr.toType = toType;\n return expr;\n }\n\n static createBinaryExpression(\n operator: Token,\n left: Expression,\n right: Expression,\n range: Range\n ): BinaryExpression {\n var expr = new BinaryExpression();\n expr.range = range;\n expr.operator = operator;\n expr.left = left;\n expr.right = right;\n return expr;\n }\n\n static createCallExpression(\n expression: Expression,\n typeArgs: TypeNode[] | null,\n args: Expression[],\n range: Range\n ): CallExpression {\n var expr = new CallExpression();\n expr.range = range;\n expr.expression = expression;\n expr.typeArguments = typeArgs;\n expr.arguments = args;\n return expr;\n }\n\n static createClassExpression(\n declaration: ClassDeclaration\n ): ClassExpression {\n var expr = new ClassExpression();\n expr.range = declaration.range;\n expr.declaration = declaration;\n return expr;\n }\n\n static createCommaExpression(\n expressions: Expression[],\n range: Range\n ): CommaExpression {\n var expr = new CommaExpression();\n expr.range = range;\n expr.expressions = expressions;\n return expr;\n }\n\n static createConstructorExpression(\n range: Range\n ): ConstructorExpression {\n var expr = new ConstructorExpression();\n expr.range = range;\n return expr;\n }\n\n static createElementAccessExpression(\n expression: Expression,\n element: Expression,\n range: Range\n ): ElementAccessExpression {\n var expr = new ElementAccessExpression();\n expr.range = range;\n expr.expression = expression;\n expr.elementExpression = element;\n return expr;\n }\n\n static createFalseExpression(\n range: Range\n ): FalseExpression {\n var expr = new FalseExpression();\n expr.range = range;\n return expr;\n }\n\n static createFloatLiteralExpression(\n value: f64,\n range: Range\n ): FloatLiteralExpression {\n var expr = new FloatLiteralExpression();\n expr.range = range;\n expr.value = value;\n return expr;\n }\n\n static createFunctionExpression(\n declaration: FunctionDeclaration\n ): FunctionExpression {\n var expr = new FunctionExpression();\n expr.range = declaration.range;\n expr.declaration = declaration;\n return expr;\n }\n\n static createInstanceOfExpression(\n expression: Expression,\n isType: TypeNode,\n range: Range\n ): InstanceOfExpression {\n var expr = new InstanceOfExpression();\n expr.range = range;\n expr.expression = expression;\n expr.isType = isType;\n return expr;\n }\n\n static createIntegerLiteralExpression(\n value: I64,\n range: Range\n ): IntegerLiteralExpression {\n var expr = new IntegerLiteralExpression();\n expr.range = range;\n expr.value = value;\n return expr;\n }\n\n static createNewExpression(\n expression: Expression,\n typeArgs: TypeNode[] | null,\n args: Expression[],\n range: Range\n ): NewExpression {\n var expr = new NewExpression();\n expr.range = range;\n expr.expression = expression;\n expr.typeArguments = typeArgs;\n expr.arguments = args;\n return expr;\n }\n\n static createNullExpression(\n range: Range\n ): NullExpression {\n var expr = new NullExpression();\n expr.range = range;\n return expr;\n }\n\n static createObjectLiteralExpression(\n names: IdentifierExpression[],\n values: Expression[],\n range: Range\n ): ObjectLiteralExpression {\n var expr = new ObjectLiteralExpression();\n expr.range = range;\n expr.names = names;\n expr.values = values;\n return expr;\n }\n\n static createParenthesizedExpression(\n expression: Expression,\n range: Range\n ): ParenthesizedExpression {\n var expr = new ParenthesizedExpression();\n expr.range = range;\n expr.expression = expression;\n return expr;\n }\n\n static createPropertyAccessExpression(\n expression: Expression,\n property: IdentifierExpression,\n range: Range\n ): PropertyAccessExpression {\n var expr = new PropertyAccessExpression();\n expr.range = range;\n expr.expression = expression;\n expr.property = property;\n return expr;\n }\n\n static createRegexpLiteralExpression(\n pattern: string,\n flags: string,\n range: Range\n ): RegexpLiteralExpression {\n var expr = new RegexpLiteralExpression();\n expr.range = range;\n expr.pattern = pattern;\n expr.patternFlags = flags;\n return expr;\n }\n\n static createTernaryExpression(\n condition: Expression,\n ifThen: Expression,\n ifElse: Expression,\n range: Range\n ): TernaryExpression {\n var expr = new TernaryExpression();\n expr.range = range;\n expr.condition = condition;\n expr.ifThen = ifThen;\n expr.ifElse = ifElse;\n return expr;\n }\n\n static createStringLiteralExpression(\n value: string,\n range: Range\n ): StringLiteralExpression {\n var expr = new StringLiteralExpression();\n expr.range = range;\n expr.value = value;\n return expr;\n }\n\n static createSuperExpression(\n range: Range\n ): SuperExpression {\n var expr = new SuperExpression();\n expr.range = range;\n return expr;\n }\n\n static createThisExpression(\n range: Range\n ): ThisExpression {\n var expr = new ThisExpression();\n expr.range = range;\n return expr;\n }\n\n static createTrueExpression(\n range: Range\n ): TrueExpression {\n var expr = new TrueExpression();\n expr.range = range;\n return expr;\n }\n\n static createUnaryPostfixExpression(\n operator: Token,\n operand: Expression,\n range: Range\n ): UnaryPostfixExpression {\n var expr = new UnaryPostfixExpression();\n expr.range = range;\n expr.operator = operator;\n expr.operand = operand;\n return expr;\n }\n\n static createUnaryPrefixExpression(\n operator: Token,\n operand: Expression,\n range: Range\n ): UnaryPrefixExpression {\n var expr = new UnaryPrefixExpression();\n expr.range = range;\n expr.operator = operator;\n expr.operand = operand;\n return expr;\n }\n\n // statements\n\n static createBlockStatement(\n statements: Statement[],\n range: Range\n ): BlockStatement {\n var stmt = new BlockStatement();\n stmt.range = range;\n stmt.statements = statements;\n return stmt;\n }\n\n static createBreakStatement(\n label: IdentifierExpression | null,\n range: Range\n ): BreakStatement {\n var stmt = new BreakStatement();\n stmt.range = range;\n stmt.label = label;\n return stmt;\n }\n\n static createClassDeclaration(\n identifier: IdentifierExpression,\n typeParameters: TypeParameterNode[] | null,\n extendsType: NamedTypeNode | null, // can't be a function\n implementsTypes: NamedTypeNode[] | null, // can't be functions\n members: DeclarationStatement[],\n decorators: DecoratorNode[] | null,\n flags: CommonFlags,\n range: Range\n ): ClassDeclaration {\n var stmt = new ClassDeclaration();\n stmt.range = range;\n stmt.flags = flags;\n stmt.name = identifier;\n stmt.typeParameters = typeParameters;\n stmt.extendsType = extendsType;\n stmt.implementsTypes = implementsTypes;\n stmt.members = members;\n stmt.decorators = decorators;\n return stmt;\n }\n\n static createContinueStatement(\n label: IdentifierExpression | null,\n range: Range\n ): ContinueStatement {\n var stmt = new ContinueStatement();\n stmt.range = range;\n stmt.label = label;\n return stmt;\n }\n\n static createDoStatement(\n statement: Statement,\n condition: Expression,\n range: Range\n ): DoStatement {\n var stmt = new DoStatement();\n stmt.range = range;\n stmt.statement = statement;\n stmt.condition = condition;\n return stmt;\n }\n\n static createEmptyStatement(\n range: Range\n ): EmptyStatement {\n var stmt = new EmptyStatement();\n stmt.range = range;\n return stmt;\n }\n\n static createEnumDeclaration(\n name: IdentifierExpression,\n members: EnumValueDeclaration[],\n decorators: DecoratorNode[] | null,\n flags: CommonFlags,\n range: Range\n ): EnumDeclaration {\n var stmt = new EnumDeclaration();\n stmt.range = range;\n stmt.flags = flags;\n stmt.name = name;\n stmt.values = members;\n stmt.decorators = decorators;\n return stmt;\n }\n\n static createEnumValueDeclaration(\n name: IdentifierExpression,\n value: Expression | null,\n flags: CommonFlags,\n range: Range\n ): EnumValueDeclaration {\n var stmt = new EnumValueDeclaration();\n stmt.range = range;\n stmt.flags = flags;\n stmt.name = name;\n stmt.value = value;\n return stmt;\n }\n\n static createExportStatement(\n members: ExportMember[] | null,\n path: StringLiteralExpression | null,\n isDeclare: bool,\n range: Range\n ): ExportStatement {\n var stmt = new ExportStatement();\n stmt.range = range;\n stmt.members = members;\n stmt.path = path;\n if (path) {\n let normalizedPath = normalizePath(path.value);\n if (path.value.startsWith(\".\")) { // relative\n stmt.normalizedPath = resolvePath(\n normalizedPath,\n range.source.normalizedPath\n );\n } else { // absolute\n if (!normalizedPath.startsWith(LIBRARY_PREFIX)) {\n normalizedPath = LIBRARY_PREFIX + normalizedPath;\n }\n stmt.normalizedPath = normalizedPath;\n }\n stmt.internalPath = mangleInternalPath(stmt.normalizedPath);\n } else {\n stmt.normalizedPath = null;\n stmt.internalPath = null;\n }\n stmt.isDeclare = isDeclare;\n return stmt;\n }\n\n static createExportDefaultStatement(\n declaration: DeclarationStatement,\n range: Range\n ): ExportDefaultStatement {\n var stmt = new ExportDefaultStatement();\n stmt.declaration = declaration;\n stmt.range = range;\n return stmt;\n }\n\n static createExportImportStatement(\n name: IdentifierExpression,\n externalName: IdentifierExpression,\n range: Range\n ): ExportImportStatement {\n var stmt = new ExportImportStatement();\n stmt.range = range;\n stmt.name = name;\n stmt.externalName = externalName;\n return stmt;\n }\n\n static createExportMember(\n name: IdentifierExpression,\n externalName: IdentifierExpression | null,\n range: Range\n ): ExportMember {\n var elem = new ExportMember();\n elem.range = range;\n elem.localName = name;\n if (!externalName) externalName = name;\n elem.exportedName = externalName;\n return elem;\n }\n\n static createExpressionStatement(\n expression: Expression\n ): ExpressionStatement {\n var stmt = new ExpressionStatement();\n stmt.range = expression.range;\n stmt.expression = expression;\n return stmt;\n }\n\n static createIfStatement(\n condition: Expression,\n ifTrue: Statement,\n ifFalse: Statement | null,\n range: Range\n ): IfStatement {\n var stmt = new IfStatement();\n stmt.range = range;\n stmt.condition = condition;\n stmt.ifTrue = ifTrue;\n stmt.ifFalse = ifFalse;\n return stmt;\n }\n\n static createImportStatement(\n decls: ImportDeclaration[] | null,\n path: StringLiteralExpression,\n range: Range\n ): ImportStatement {\n var stmt = new ImportStatement();\n stmt.range = range;\n stmt.declarations = decls;\n stmt.namespaceName = null;\n stmt.path = path;\n var normalizedPath = normalizePath(path.value);\n if (path.value.startsWith(\".\")) { // relative in project\n stmt.normalizedPath = resolvePath(\n normalizedPath,\n range.source.normalizedPath\n );\n } else { // absolute in library\n if (!normalizedPath.startsWith(LIBRARY_PREFIX)) {\n normalizedPath = LIBRARY_PREFIX + normalizedPath;\n }\n stmt.normalizedPath = normalizedPath;\n }\n stmt.internalPath = mangleInternalPath(stmt.normalizedPath);\n return stmt;\n }\n\n static createImportStatementWithWildcard(\n identifier: IdentifierExpression,\n path: StringLiteralExpression,\n range: Range\n ): ImportStatement {\n var stmt = new ImportStatement();\n stmt.range = range;\n stmt.declarations = null;\n stmt.namespaceName = identifier;\n stmt.path = path;\n var normalizedPath = normalizePath(path.value);\n if (path.value.startsWith(\".\")) {\n stmt.normalizedPath = resolvePath(\n normalizedPath,\n range.source.normalizedPath\n );\n } else {\n if (!normalizedPath.startsWith(LIBRARY_PREFIX)) {\n normalizedPath = LIBRARY_PREFIX + normalizedPath;\n }\n stmt.normalizedPath = normalizedPath;\n }\n stmt.internalPath = mangleInternalPath(stmt.normalizedPath);\n return stmt;\n }\n\n static createImportDeclaration(\n foreignName: IdentifierExpression,\n name: IdentifierExpression | null,\n range: Range\n ): ImportDeclaration {\n var elem = new ImportDeclaration();\n elem.range = range;\n elem.foreignName = foreignName;\n if (!name) name = foreignName;\n elem.name = name;\n return elem;\n }\n\n static createInterfaceDeclaration(\n name: IdentifierExpression,\n typeParameters: TypeParameterNode[] | null,\n extendsType: NamedTypeNode | null, // can't be a function\n members: DeclarationStatement[],\n decorators: DecoratorNode[] | null,\n flags: CommonFlags,\n range: Range\n ): InterfaceDeclaration {\n var stmt = new InterfaceDeclaration();\n stmt.range = range;\n stmt.flags = flags;\n stmt.name = name;\n stmt.typeParameters = typeParameters;\n stmt.extendsType = extendsType;\n stmt.members = members;\n stmt.decorators = decorators;\n return stmt;\n }\n\n static createFieldDeclaration(\n name: IdentifierExpression,\n type: TypeNode | null,\n initializer: Expression | null,\n decorators: DecoratorNode[] | null,\n flags: CommonFlags,\n range: Range\n ): FieldDeclaration {\n var stmt = new FieldDeclaration();\n stmt.range = range;\n stmt.flags = flags;\n stmt.name = name;\n stmt.type = type;\n stmt.initializer = initializer;\n stmt.decorators = decorators;\n return stmt;\n }\n\n static createForStatement(\n initializer: Statement | null,\n condition: Expression | null,\n incrementor: Expression | null,\n statement: Statement,\n range: Range\n ): ForStatement {\n var stmt = new ForStatement();\n stmt.range = range;\n stmt.initializer = initializer;\n stmt.condition = condition;\n stmt.incrementor = incrementor;\n stmt.statement = statement;\n return stmt;\n }\n\n static createFunctionDeclaration(\n name: IdentifierExpression,\n typeParameters: TypeParameterNode[] | null,\n signature: FunctionTypeNode,\n body: Statement | null,\n decorators: DecoratorNode[] | null,\n flags: CommonFlags,\n arrowKind: ArrowKind,\n range: Range\n ): FunctionDeclaration {\n var stmt = new FunctionDeclaration();\n stmt.range = range;\n stmt.flags = flags;\n stmt.name = name;\n stmt.typeParameters = typeParameters;\n stmt.signature = signature;\n stmt.body = body;\n stmt.decorators = decorators;\n stmt.arrowKind = arrowKind;\n return stmt;\n }\n\n static createIndexSignatureDeclaration(\n keyType: NamedTypeNode,\n valueType: TypeNode,\n range: Range\n ): IndexSignatureDeclaration {\n var elem = new IndexSignatureDeclaration();\n elem.range = range;\n elem.keyType = keyType;\n elem.valueType = valueType;\n return elem;\n }\n\n static createMethodDeclaration(\n name: IdentifierExpression,\n typeParameters: TypeParameterNode[] | null,\n signature: FunctionTypeNode,\n body: Statement | null,\n decorators: DecoratorNode[] | null,\n flags: CommonFlags,\n range: Range\n ): MethodDeclaration {\n var stmt = new MethodDeclaration();\n stmt.range = range;\n stmt.flags = flags;\n stmt.name = name;\n stmt.typeParameters = typeParameters;\n stmt.signature = signature;\n stmt.body = body;\n stmt.decorators = decorators;\n return stmt;\n }\n\n static createNamespaceDeclaration(\n name: IdentifierExpression,\n members: Statement[],\n decorators: DecoratorNode[] | null,\n flags: CommonFlags,\n range: Range\n ): NamespaceDeclaration {\n var stmt = new NamespaceDeclaration();\n stmt.range = range;\n stmt.flags = flags;\n stmt.name = name;\n stmt.members = members;\n stmt.decorators = decorators;\n return stmt;\n }\n\n static createReturnStatement(\n value: Expression | null,\n range: Range\n ): ReturnStatement {\n var stmt = new ReturnStatement();\n stmt.range = range;\n stmt.value = value;\n return stmt;\n }\n\n static createSwitchStatement(\n condition: Expression,\n cases: SwitchCase[],\n range: Range\n ): SwitchStatement {\n var stmt = new SwitchStatement();\n stmt.range = range;\n stmt.condition = condition;\n stmt.cases = cases;\n return stmt;\n }\n\n static createSwitchCase(\n label: Expression | null,\n statements: Statement[],\n range: Range\n ): SwitchCase {\n var elem = new SwitchCase();\n elem.range = range;\n elem.label = label;\n elem.statements = statements;\n return elem;\n }\n\n static createThrowStatement(\n value: Expression,\n range: Range\n ): ThrowStatement {\n var stmt = new ThrowStatement();\n stmt.range = range;\n stmt.value = value;\n return stmt;\n }\n\n static createTryStatement(\n statements: Statement[],\n catchVariable: IdentifierExpression | null,\n catchStatements: Statement[] | null,\n finallyStatements: Statement[] | null,\n range: Range\n ): TryStatement {\n var stmt = new TryStatement();\n stmt.range = range;\n stmt.statements = statements;\n stmt.catchVariable = catchVariable;\n stmt.catchStatements = catchStatements;\n stmt.finallyStatements = finallyStatements;\n return stmt;\n }\n\n static createTypeDeclaration(\n name: IdentifierExpression,\n typeParameters: TypeParameterNode[] | null,\n alias: TypeNode,\n decorators: DecoratorNode[] | null,\n flags: CommonFlags,\n range: Range\n ): TypeDeclaration {\n var stmt = new TypeDeclaration();\n stmt.range = range;\n stmt.flags = flags;\n stmt.name = name;\n stmt.typeParameters = typeParameters;\n stmt.type = alias;\n stmt.decorators = decorators;\n return stmt;\n }\n\n static createVariableStatement(\n declarations: VariableDeclaration[],\n decorators: DecoratorNode[] | null,\n range: Range\n ): VariableStatement {\n var stmt = new VariableStatement();\n stmt.range = range;\n stmt.declarations = declarations;\n stmt.decorators = decorators;\n return stmt;\n }\n\n static createVariableDeclaration(\n name: IdentifierExpression,\n type: TypeNode | null,\n initializer: Expression | null,\n decorators: DecoratorNode[] | null,\n flags: CommonFlags,\n range: Range\n ): VariableDeclaration {\n var elem = new VariableDeclaration();\n elem.range = range;\n elem.flags = flags;\n elem.name = name;\n elem.type = type;\n elem.initializer = initializer;\n elem.decorators = decorators; // inherited\n return elem;\n }\n\n static createVoidStatement(\n expression: Expression,\n range: Range\n ): VoidStatement {\n var stmt = new VoidStatement();\n stmt.range = range;\n stmt.expression = expression;\n return stmt;\n }\n\n static createWhileStatement(\n condition: Expression,\n statement: Statement,\n range: Range\n ): WhileStatement {\n var stmt = new WhileStatement();\n stmt.range = range;\n stmt.condition = condition;\n stmt.statement = statement;\n return stmt;\n }\n}\n\n// types\n\nexport abstract class TypeNode extends Node {\n // kind varies\n\n /** Whether nullable or not. */\n isNullable: bool;\n}\n\n/** Represents a type name. */\nexport class TypeName extends Node {\n kind = NodeKind.TYPENAME;\n\n /** Identifier of this part. */\n identifier: IdentifierExpression;\n /** Next part of the type name or `null` if this is the last part. */\n next: TypeName | null;\n}\n\n/** Represents a named type. */\nexport class NamedTypeNode extends TypeNode {\n kind = NodeKind.NAMEDTYPE;\n\n /** Type name. */\n name: TypeName;\n /** Type argument references. */\n typeArguments: TypeNode[] | null;\n}\n\n/** Represents a function type. */\nexport class FunctionTypeNode extends TypeNode {\n kind = NodeKind.FUNCTIONTYPE;\n\n /** Accepted parameters. */\n parameters: ParameterNode[];\n /** Return type. */\n returnType: TypeNode;\n /** Explicitly provided this type, if any. */\n explicitThisType: NamedTypeNode | null; // can't be a function\n}\n\n/** Represents a type parameter. */\nexport class TypeParameterNode extends Node {\n kind = NodeKind.TYPEPARAMETER;\n\n /** Identifier reference. */\n name: IdentifierExpression;\n /** Extended type reference, if any. */\n extendsType: NamedTypeNode | null; // can't be a function\n /** Default type if omitted, if any. */\n defaultType: NamedTypeNode | null; // can't be a function\n}\n\n/** Represents the kind of a parameter. */\nexport enum ParameterKind {\n /** No specific flags. */\n DEFAULT,\n /** Is an optional parameter. */\n OPTIONAL,\n /** Is a rest parameter. */\n REST\n}\n\n/** Represents a function parameter. */\nexport class ParameterNode extends Node {\n kind = NodeKind.PARAMETER;\n\n /** Parameter kind. */\n parameterKind: ParameterKind;\n /** Parameter name. */\n name: IdentifierExpression;\n /** Parameter type. */\n type: TypeNode;\n /** Initializer expression, if present. */\n initializer: Expression | null;\n /** Implicit field declaration, if applicable. */\n implicitFieldDeclaration: FieldDeclaration | null = null;\n /** Common flags indicating specific traits. */\n flags: CommonFlags = CommonFlags.NONE;\n\n /** Tests if this node has the specified flag or flags. */\n is(flag: CommonFlags): bool { return (this.flags & flag) == flag; }\n /** Tests if this node has one of the specified flags. */\n isAny(flag: CommonFlags): bool { return (this.flags & flag) != 0; }\n /** Sets a specific flag or flags. */\n set(flag: CommonFlags): void { this.flags |= flag; }\n}\n\n// special\n\n/** Built-in decorator kinds. */\nexport enum DecoratorKind {\n CUSTOM,\n GLOBAL,\n OPERATOR,\n OPERATOR_BINARY,\n OPERATOR_PREFIX,\n OPERATOR_POSTFIX,\n UNMANAGED,\n SEALED,\n INLINE,\n EXTERNAL,\n BUILTIN,\n LAZY,\n UNSAFE\n}\n\n/** Returns the kind of the specified decorator. Defaults to {@link DecoratorKind.CUSTOM}. */\nexport function decoratorNameToKind(name: Expression): DecoratorKind {\n // @global, @inline, @operator, @sealed, @unmanaged\n if (name.kind == NodeKind.IDENTIFIER) {\n let nameStr = (name).text;\n assert(nameStr.length);\n switch (nameStr.charCodeAt(0)) {\n case CharCode.b: {\n if (nameStr == \"builtin\") return DecoratorKind.BUILTIN;\n break;\n }\n case CharCode.e: {\n if (nameStr == \"external\") return DecoratorKind.EXTERNAL;\n break;\n }\n case CharCode.g: {\n if (nameStr == \"global\") return DecoratorKind.GLOBAL;\n break;\n }\n case CharCode.i: {\n if (nameStr == \"inline\") return DecoratorKind.INLINE;\n break;\n }\n case CharCode.l: {\n if (nameStr == \"lazy\") return DecoratorKind.LAZY;\n break;\n }\n case CharCode.o: {\n if (nameStr == \"operator\") return DecoratorKind.OPERATOR;\n break;\n }\n case CharCode.s: {\n if (nameStr == \"sealed\") return DecoratorKind.SEALED;\n break;\n }\n case CharCode.u: {\n if (nameStr == \"unmanaged\") return DecoratorKind.UNMANAGED;\n if (nameStr == \"unsafe\") return DecoratorKind.UNSAFE;\n break;\n }\n }\n } else if (\n name.kind == NodeKind.PROPERTYACCESS &&\n (name).expression.kind == NodeKind.IDENTIFIER\n ) {\n let nameStr = ((name).expression).text;\n assert(nameStr.length);\n let propStr = (name).property.text;\n assert(propStr.length);\n // @operator.binary, @operator.prefix, @operator.postfix\n if (nameStr == \"operator\") {\n switch (propStr.charCodeAt(0)) {\n case CharCode.b: {\n if (propStr == \"binary\") return DecoratorKind.OPERATOR_BINARY;\n break;\n }\n case CharCode.p: {\n switch (propStr) {\n case \"prefix\": return DecoratorKind.OPERATOR_PREFIX;\n case \"postfix\": return DecoratorKind.OPERATOR_POSTFIX;\n }\n break;\n }\n }\n }\n }\n return DecoratorKind.CUSTOM;\n}\n\n/** Represents a decorator. */\nexport class DecoratorNode extends Node {\n kind = NodeKind.DECORATOR;\n\n /** Built-in kind, if applicable. */\n decoratorKind: DecoratorKind;\n /** Name expression. */\n name: Expression;\n /** Argument expressions. */\n arguments: Expression[] | null;\n}\n\n/** Comment kinds. */\nexport enum CommentKind {\n /** Line comment. */\n LINE,\n /** Triple-slash comment. */\n TRIPLE,\n /** Block comment. */\n BLOCK\n}\n\n/** Represents a comment. */\nexport class CommentNode extends Node {\n kind = NodeKind.COMMENT;\n\n /** Comment kind. */\n commentKind: CommentKind;\n /** Comment text. */\n text: string;\n}\n\n// expressions\n\n/** Base class of all expression nodes. */\nexport abstract class Expression extends Node { }\n\n/** Represents an identifier expression. */\nexport class IdentifierExpression extends Expression {\n kind = NodeKind.IDENTIFIER;\n\n /** Textual name. */\n text: string;\n /** Symbol. */\n symbol: string; // TODO: symbol\n /** Whether quoted or not. */\n isQuoted: bool;\n}\n\n/** Indicates the kind of a literal. */\nexport enum LiteralKind {\n FLOAT,\n INTEGER,\n STRING,\n REGEXP,\n ARRAY,\n OBJECT\n}\n\n/** Base class of all literal expressions. */\nexport abstract class LiteralExpression extends Expression {\n kind = NodeKind.LITERAL;\n\n /** Specific literal kind. */\n literalKind: LiteralKind;\n}\n\n/** Represents an `[]` literal expression. */\nexport class ArrayLiteralExpression extends LiteralExpression {\n literalKind = LiteralKind.ARRAY;\n\n /** Nested element expressions. */\n elementExpressions: (Expression | null)[];\n}\n\n/** Indicates the kind of an assertion. */\nexport enum AssertionKind {\n PREFIX,\n AS,\n NONNULL\n}\n\n/** Represents an assertion expression. */\nexport class AssertionExpression extends Expression {\n kind = NodeKind.ASSERTION;\n\n /** Specific kind of this assertion. */\n assertionKind: AssertionKind;\n /** Expression being asserted. */\n expression: Expression;\n /** Target type. */\n toType: TypeNode | null;\n}\n\n/** Represents a binary expression. */\nexport class BinaryExpression extends Expression {\n kind = NodeKind.BINARY;\n\n /** Operator token. */\n operator: Token;\n /** Left-hand side expression */\n left: Expression;\n /** Right-hand side expression. */\n right: Expression;\n}\n\n/** Represents a call expression. */\nexport class CallExpression extends Expression {\n kind = NodeKind.CALL;\n\n /** Called expression. Usually an identifier or property access expression. */\n expression: Expression;\n /** Provided type arguments. */\n typeArguments: TypeNode[] | null;\n /** Provided arguments. */\n arguments: Expression[];\n\n /** Gets the type arguments range for reporting. */\n get typeArgumentsRange(): Range {\n var typeArguments = this.typeArguments;\n var numTypeArguments: i32;\n if (typeArguments && (numTypeArguments = typeArguments.length)) {\n return Range.join(typeArguments[0].range, typeArguments[numTypeArguments - 1].range);\n }\n return this.expression.range;\n }\n\n /** Gets the arguments range for reporting. */\n get argumentsRange(): Range {\n var args = this.arguments;\n var numArguments = args.length;\n if (numArguments) {\n return Range.join(args[0].range, args[numArguments - 1].range);\n }\n return this.expression.range;\n }\n}\n\n/** Represents a class expression using the 'class' keyword. */\nexport class ClassExpression extends Expression {\n kind = NodeKind.CLASS;\n\n /** Inline class declaration. */\n declaration: ClassDeclaration;\n}\n\n/** Represents a comma expression composed of multiple expressions. */\nexport class CommaExpression extends Expression {\n kind = NodeKind.COMMA;\n\n /** Sequential expressions. */\n expressions: Expression[];\n}\n\n/** Represents a `constructor` expression. */\nexport class ConstructorExpression extends IdentifierExpression {\n kind = NodeKind.CONSTRUCTOR;\n text = \"constructor\";\n symbol = CommonSymbols.constructor;\n}\n\n/** Represents an element access expression, e.g., array access. */\nexport class ElementAccessExpression extends Expression {\n kind = NodeKind.ELEMENTACCESS;\n\n /** Expression being accessed. */\n expression: Expression;\n /** Element of the expression being accessed. */\n elementExpression: Expression;\n}\n\n/** Represents a float literal expression. */\nexport class FloatLiteralExpression extends LiteralExpression {\n literalKind = LiteralKind.FLOAT;\n\n /** Float value. */\n value: f64;\n}\n\n/** Represents a function expression using the 'function' keyword. */\nexport class FunctionExpression extends Expression {\n kind = NodeKind.FUNCTION;\n\n /** Inline function declaration. */\n declaration: FunctionDeclaration;\n}\n\n/** Represents an `instanceof` expression. */\nexport class InstanceOfExpression extends Expression {\n kind = NodeKind.INSTANCEOF;\n\n /** Expression being asserted. */\n expression: Expression;\n /** Type to test for. */\n isType: TypeNode;\n}\n\n/** Represents an integer literal expression. */\nexport class IntegerLiteralExpression extends LiteralExpression {\n literalKind = LiteralKind.INTEGER;\n\n /** Integer value. */\n value: I64;\n}\n\n/** Represents a `new` expression. Like a call but with its own kind. */\nexport class NewExpression extends CallExpression {\n kind = NodeKind.NEW;\n}\n\n/** Represents a `null` expression. */\nexport class NullExpression extends IdentifierExpression {\n kind = NodeKind.NULL;\n text = \"null\";\n symbol = CommonSymbols.null_;\n}\n\n/** Represents an object literal expression. */\nexport class ObjectLiteralExpression extends LiteralExpression {\n literalKind = LiteralKind.OBJECT;\n\n /** Field names. */\n names: IdentifierExpression[];\n /** Field values. */\n values: Expression[];\n}\n\n/** Represents a parenthesized expression. */\nexport class ParenthesizedExpression extends Expression {\n kind = NodeKind.PARENTHESIZED;\n\n /** Expression in parenthesis. */\n expression: Expression;\n}\n\n/** Represents a property access expression. */\nexport class PropertyAccessExpression extends Expression {\n kind = NodeKind.PROPERTYACCESS;\n\n /** Expression being accessed. */\n expression: Expression;\n /** Property of the expression being accessed. */\n property: IdentifierExpression;\n}\n\n/** Represents a regular expression literal expression. */\nexport class RegexpLiteralExpression extends LiteralExpression {\n literalKind = LiteralKind.REGEXP;\n\n /** Regular expression pattern. */\n pattern: string;\n /** Regular expression flags. */\n patternFlags: string;\n}\n\n/** Represents a ternary expression, i.e., short if notation. */\nexport class TernaryExpression extends Expression {\n kind = NodeKind.TERNARY;\n\n /** Condition expression. */\n condition: Expression;\n /** Expression executed when condition is `true`. */\n ifThen: Expression;\n /** Expression executed when condition is `false`. */\n ifElse: Expression;\n}\n\n/** Represents a string literal expression. */\nexport class StringLiteralExpression extends LiteralExpression {\n literalKind = LiteralKind.STRING;\n\n /** String value without quotes. */\n value: string;\n}\n\n/** Represents a `super` expression. */\nexport class SuperExpression extends IdentifierExpression {\n kind = NodeKind.SUPER;\n text = \"super\";\n symbol = CommonSymbols.super_;\n}\n\n/** Represents a `this` expression. */\nexport class ThisExpression extends IdentifierExpression {\n kind = NodeKind.THIS;\n text = \"this\";\n symbol = CommonSymbols.this_;\n}\n\n/** Represents a `true` expression. */\nexport class TrueExpression extends IdentifierExpression {\n kind = NodeKind.TRUE;\n text = \"true\";\n symbol = CommonSymbols.true_;\n}\n\n/** Represents a `false` expression. */\nexport class FalseExpression extends IdentifierExpression {\n kind = NodeKind.FALSE;\n text = \"false\";\n symbol = CommonSymbols.false_;\n}\n\n/** Base class of all unary expressions. */\nexport abstract class UnaryExpression extends Expression {\n\n /** Operator token. */\n operator: Token;\n /** Operand expression. */\n operand: Expression;\n}\n\n/** Represents a unary postfix expression, e.g. a postfix increment. */\nexport class UnaryPostfixExpression extends UnaryExpression {\n kind = NodeKind.UNARYPOSTFIX;\n}\n\n/** Represents a unary prefix expression, e.g. a negation. */\nexport class UnaryPrefixExpression extends UnaryExpression {\n kind = NodeKind.UNARYPREFIX;\n}\n\n// statements\n\n/** Base class of all statement nodes. */\nexport abstract class Statement extends Node { }\n\n/** Indicates the specific kind of a source. */\nexport enum SourceKind {\n /** Default source. Usually imported from an entry file. */\n DEFAULT,\n /** Entry file. */\n ENTRY,\n /** Library file. */\n LIBRARY\n}\n\n/** A top-level source node. */\nexport class Source extends Node {\n kind = NodeKind.SOURCE;\n parent = null;\n\n /** Source kind. */\n sourceKind: SourceKind;\n /** Normalized path. */\n normalizedPath: string;\n /** Path used internally. */\n internalPath: string;\n /** Simple path (last part without extension). */\n simplePath: string;\n /** Contained statements. */\n statements: Statement[];\n /** Full source text. */\n text: string;\n /** Tokenizer reference. */\n tokenizer: Tokenizer | null = null;\n /** Source map index. */\n debugInfoIndex: i32 = -1;\n /** Re-exported sources. */\n exportPaths: Set | null = null;\n\n /** Constructs a new source node. */\n constructor(normalizedPath: string, text: string, kind: SourceKind) {\n super();\n this.sourceKind = kind;\n this.normalizedPath = normalizedPath;\n var internalPath = mangleInternalPath(this.normalizedPath);\n this.internalPath = internalPath;\n var pos = internalPath.lastIndexOf(PATH_DELIMITER);\n this.simplePath = pos >= 0 ? internalPath.substring(pos + 1) : internalPath;\n this.statements = new Array();\n this.range = new Range(this, 0, text.length);\n this.text = text;\n }\n\n /** Tests if this source is an entry file. */\n get isEntry(): bool { return this.sourceKind == SourceKind.ENTRY; }\n /** Tests if this source is a stdlib file. */\n get isLibrary(): bool { return this.sourceKind == SourceKind.LIBRARY; }\n}\n\n/** Base class of all declaration statements. */\nexport abstract class DeclarationStatement extends Statement {\n /** Simple name being declared. */\n name: IdentifierExpression;\n /** Array of decorators. */\n decorators: DecoratorNode[] | null = null;\n /** Common flags indicating specific traits. */\n flags: CommonFlags = CommonFlags.NONE;\n\n /** Tests if this node has the specified flag or flags. */\n is(flag: CommonFlags): bool { return (this.flags & flag) == flag; }\n /** Tests if this node has one of the specified flags. */\n isAny(flag: CommonFlags): bool { return (this.flags & flag) != 0; }\n /** Sets a specific flag or flags. */\n set(flag: CommonFlags): void { this.flags |= flag; }\n}\n\n/** Represents an index signature declaration. */\nexport class IndexSignatureDeclaration extends DeclarationStatement {\n kind = NodeKind.INDEXSIGNATUREDECLARATION;\n\n /** Key type. */\n keyType: NamedTypeNode;\n /** Value type. */\n valueType: TypeNode;\n}\n\n/** Base class of all variable-like declaration statements. */\nexport abstract class VariableLikeDeclarationStatement extends DeclarationStatement {\n\n /** Variable type. */\n type: TypeNode | null;\n /** Variable initializer. */\n initializer: Expression | null;\n}\n\n/** Represents a block statement. */\nexport class BlockStatement extends Statement {\n kind = NodeKind.BLOCK;\n\n /** Contained statements. */\n statements: Statement[];\n}\n\n/** Represents a `break` statement. */\nexport class BreakStatement extends Statement {\n kind = NodeKind.BREAK;\n\n /** Target label, if applicable. */\n label: IdentifierExpression | null;\n}\n\n/** Represents a `class` declaration. */\nexport class ClassDeclaration extends DeclarationStatement {\n kind = NodeKind.CLASSDECLARATION;\n\n /** Accepted type parameters. */\n typeParameters: TypeParameterNode[] | null;\n /** Base class type being extended, if any. */\n extendsType: NamedTypeNode | null; // can't be a function\n /** Interface types being implemented, if any. */\n implementsTypes: NamedTypeNode[] | null; // can't be functions\n /** Class member declarations. */\n members: DeclarationStatement[];\n\n get isGeneric(): bool {\n var typeParameters = this.typeParameters;\n return typeParameters != null && typeParameters.length > 0;\n }\n}\n\n/** Represents a `continue` statement. */\nexport class ContinueStatement extends Statement {\n kind = NodeKind.CONTINUE;\n\n /** Target label, if applicable. */\n label: IdentifierExpression | null;\n}\n\n/** Represents a `do` statement. */\nexport class DoStatement extends Statement {\n kind = NodeKind.DO;\n\n /** Statement being looped over. */\n statement: Statement;\n /** Condition when to repeat. */\n condition: Expression;\n}\n\n/** Represents an empty statement, i.e., a semicolon terminating nothing. */\nexport class EmptyStatement extends Statement {\n kind = NodeKind.EMPTY;\n}\n\n/** Represents an `enum` declaration. */\nexport class EnumDeclaration extends DeclarationStatement {\n kind = NodeKind.ENUMDECLARATION;\n\n /** Enum value declarations. */\n values: EnumValueDeclaration[];\n}\n\n/** Represents a value of an `enum` declaration. */\nexport class EnumValueDeclaration extends VariableLikeDeclarationStatement {\n kind = NodeKind.ENUMVALUEDECLARATION;\n // name is inherited\n\n /** Value expression. */\n value: Expression | null;\n}\n\n/** Represents an `export import` statement of an interface. */\nexport class ExportImportStatement extends Node {\n kind = NodeKind.EXPORTIMPORT;\n\n /** Identifier being imported. */\n name: IdentifierExpression;\n /** Identifier being exported. */\n externalName: IdentifierExpression;\n}\n\n/** Represents a member of an `export` statement. */\nexport class ExportMember extends Node {\n kind = NodeKind.EXPORTMEMBER;\n\n /** Local identifier. */\n localName: IdentifierExpression;\n /** Exported identifier. */\n exportedName: IdentifierExpression;\n}\n\n/** Represents an `export` statement. */\nexport class ExportStatement extends Statement {\n kind = NodeKind.EXPORT;\n\n /** Array of members if a set of named exports, or `null` if a file export. */\n members: ExportMember[] | null;\n /** Path being exported from, if applicable. */\n path: StringLiteralExpression | null;\n /** Normalized path, if `path` is set. */\n normalizedPath: string | null;\n /** Mangled internal path being referenced, if `path` is set. */\n internalPath: string | null;\n /** Whether this is a declared export. */\n isDeclare: bool;\n}\n\n/** Represents an `export default` statement. */\nexport class ExportDefaultStatement extends Statement {\n kind = NodeKind.EXPORTDEFAULT;\n\n /** Declaration being exported as default. */\n declaration: DeclarationStatement;\n}\n\n/** Represents an expression that is used as a statement. */\nexport class ExpressionStatement extends Statement {\n kind = NodeKind.EXPRESSION;\n\n /** Expression being used as a statement.*/\n expression: Expression;\n}\n\n/** Represents a field declaration within a `class`. */\nexport class FieldDeclaration extends VariableLikeDeclarationStatement {\n kind = NodeKind.FIELDDECLARATION;\n\n /** Parameter index if declared as a constructor parameter, otherwise `-1`. */\n parameterIndex: i32 = -1;\n}\n\n/** Represents a `for` statement. */\nexport class ForStatement extends Statement {\n kind = NodeKind.FOR;\n\n /**\n * Initializer statement, if present.\n * Either a {@link VariableStatement} or {@link ExpressionStatement}.\n */\n initializer: Statement | null;\n /** Condition expression, if present. */\n condition: Expression | null;\n /** Incrementor expression, if present. */\n incrementor: Expression | null;\n /** Statement being looped over. */\n statement: Statement;\n}\n\n/** Indicates the kind of an array function. */\nexport const enum ArrowKind {\n /** Not an arrow function. */\n NONE,\n /** Parenthesized parameter list. */\n ARROW_PARENTHESIZED,\n /** Single parameter without parenthesis. */\n ARROW_SINGLE\n}\n\n/** Represents a `function` declaration. */\nexport class FunctionDeclaration extends DeclarationStatement {\n kind = NodeKind.FUNCTIONDECLARATION;\n\n /** Type parameters, if any. */\n typeParameters: TypeParameterNode[] | null;\n /** Function signature. */\n signature: FunctionTypeNode;\n /** Body statement. Usually a block. */\n body: Statement | null;\n /** Arrow function kind, if applicable. */\n arrowKind: ArrowKind;\n\n get isGeneric(): bool {\n var typeParameters = this.typeParameters;\n return typeParameters != null && typeParameters.length > 0;\n }\n\n /** Clones this function declaration. */\n clone(): FunctionDeclaration {\n return Node.createFunctionDeclaration(\n this.name,\n this.typeParameters,\n this.signature,\n this.body,\n this.decorators,\n this.flags,\n this.arrowKind,\n this.range\n );\n }\n}\n\n/** Represents an `if` statement. */\nexport class IfStatement extends Statement {\n kind = NodeKind.IF;\n\n /** Condition. */\n condition: Expression;\n /** Statement executed when condition is `true`. */\n ifTrue: Statement;\n /** Statement executed when condition is `false`. */\n ifFalse: Statement | null;\n}\n\n/** Represents an `import` declaration part of an {@link ImportStatement}. */\nexport class ImportDeclaration extends DeclarationStatement {\n kind = NodeKind.IMPORTDECLARATION;\n\n /** Identifier being imported. */\n foreignName: IdentifierExpression;\n}\n\n/** Represents an `import` statement. */\nexport class ImportStatement extends Statement {\n kind = NodeKind.IMPORT;\n\n /** Array of member declarations or `null` if an asterisk import. */\n declarations: ImportDeclaration[] | null;\n /** Name of the local namespace, if an asterisk import. */\n namespaceName: IdentifierExpression | null;\n /** Path being imported from. */\n path: StringLiteralExpression;\n /** Normalized path. */\n normalizedPath: string;\n /** Mangled internal path being referenced. */\n internalPath: string;\n}\n\n/** Represents an `interfarce` declaration. */\nexport class InterfaceDeclaration extends ClassDeclaration {\n kind = NodeKind.INTERFACEDECLARATION;\n}\n\n/** Represents a method declaration within a `class`. */\nexport class MethodDeclaration extends FunctionDeclaration {\n kind = NodeKind.METHODDECLARATION;\n}\n\n/** Represents a `namespace` declaration. */\nexport class NamespaceDeclaration extends DeclarationStatement {\n kind = NodeKind.NAMESPACEDECLARATION;\n\n /** Array of namespace members. */\n members: Statement[];\n}\n\n/** Represents a `return` statement. */\nexport class ReturnStatement extends Statement {\n kind = NodeKind.RETURN;\n\n /** Value expression being returned, if present. */\n value: Expression | null;\n}\n\n/** Represents a single `case` within a `switch` statement. */\nexport class SwitchCase extends Node {\n kind = NodeKind.SWITCHCASE;\n\n /** Label expression. `null` indicates the default case. */\n label: Expression | null;\n /** Contained statements. */\n statements: Statement[];\n}\n\n/** Represents a `switch` statement. */\nexport class SwitchStatement extends Statement {\n kind = NodeKind.SWITCH;\n\n /** Condition expression. */\n condition: Expression;\n /** Contained cases. */\n cases: SwitchCase[];\n}\n\n/** Represents a `throw` statement. */\nexport class ThrowStatement extends Statement {\n kind = NodeKind.THROW;\n\n /** Value expression being thrown. */\n value: Expression;\n}\n\n/** Represents a `try` statement. */\nexport class TryStatement extends Statement {\n kind = NodeKind.TRY;\n\n /** Contained statements. */\n statements: Statement[];\n /** Exception variable name, if a `catch` clause is present. */\n catchVariable: IdentifierExpression | null;\n /** Statements being executed on catch, if a `catch` clause is present. */\n catchStatements: Statement[] | null;\n /** Statements being executed afterwards, if a `finally` clause is present. */\n finallyStatements: Statement[] | null;\n}\n\n/** Represents a `type` declaration. */\nexport class TypeDeclaration extends DeclarationStatement {\n kind = NodeKind.TYPEDECLARATION;\n\n /** Type parameters, if any. */\n typeParameters: TypeParameterNode[] | null;\n /** Type being aliased. */\n type: TypeNode;\n}\n\n/** Represents a variable declaration part of a {@link VariableStatement}. */\nexport class VariableDeclaration extends VariableLikeDeclarationStatement {\n kind = NodeKind.VARIABLEDECLARATION;\n}\n\n/** Represents a variable statement wrapping {@link VariableDeclaration}s. */\nexport class VariableStatement extends Statement {\n kind = NodeKind.VARIABLE;\n\n /** Array of decorators. */\n decorators: DecoratorNode[] | null;\n /** Array of member declarations. */\n declarations: VariableDeclaration[];\n}\n\n/** Represents a void statement dropping an expression's value. */\nexport class VoidStatement extends Statement {\n kind = NodeKind.VOID;\n\n /** Expression being dropped. */\n expression: Expression;\n}\n\n/** Represents a `while` statement. */\nexport class WhileStatement extends Statement {\n kind = NodeKind.WHILE;\n\n /** Condition expression. */\n condition: Expression;\n /** Statement being looped over. */\n statement: Statement;\n}\n\n/** Finds the first decorator matching the specified kind. */\nexport function findDecorator(kind: DecoratorKind, decorators: DecoratorNode[] | null): DecoratorNode | null {\n if (decorators) {\n for (let i = 0, k = decorators.length; i < k; ++i) {\n let decorator = decorators[i];\n if (decorator.decoratorKind == kind) return decorator;\n }\n }\n return null;\n}\n\n/** Mangles an external to an internal path. */\nexport function mangleInternalPath(path: string): string {\n if (path.endsWith(\".ts\")) path = path.substring(0, path.length - 3);\n return path;\n}\n\n/** Tests if the specified type node represents an omitted type. */\nexport function isTypeOmitted(type: TypeNode): bool {\n if (type.kind == NodeKind.NAMEDTYPE) {\n let name = (type).name;\n return !(name.next || name.identifier.text.length);\n }\n return false;\n}\n","/**\n * Mappings from AssemblyScript types to WebAssembly types.\n * @module types\n *//***/\n\nimport {\n Class,\n FunctionTarget,\n Program,\n DecoratorFlags\n} from \"./program\";\n\nimport {\n NativeType,\n ExpressionRef,\n Module\n} from \"./module\";\n\n/** Indicates the kind of a type. */\nexport const enum TypeKind {\n\n // signed integers\n\n /** An 8-bit signed integer. */\n I8,\n /** A 16-bit signed integer. */\n I16,\n /** A 32-bit signed integer. */\n I32,\n /** A 64-bit signed integer. */\n I64,\n /** A 32-bit/64-bit signed integer, depending on the target. */\n ISIZE,\n\n // unsigned integers\n\n /** An 8-bit unsigned integer. */\n U8,\n /** A 16-bit unsigned integer. */\n U16,\n /** A 32-bit unsigned integer. Also the base of function types. */\n U32,\n /** A 64-bit unsigned integer. */\n U64,\n /** A 32-bit/64-bit unsigned integer, depending on the target. Also the base of class types. */\n USIZE,\n /** A 1-bit unsigned integer. */\n BOOL, // sic\n\n // floats\n\n /** A 32-bit float. */\n F32,\n /** A 64-bit double. */\n F64,\n\n // vectors\n\n /** A 128-bit vector. */\n V128,\n\n // other\n\n /** No return type. */\n VOID\n}\n\n/** Indicates capabilities of a type. */\nexport const enum TypeFlags {\n NONE = 0,\n /** Is a signed type that can represent negative values. */\n SIGNED = 1 << 0,\n /** Is an unsigned type that cannot represent negative values. */\n UNSIGNED = 1 << 1,\n /** Is an integer type. */\n INTEGER = 1 << 2,\n /** Is a floating point type. */\n FLOAT = 1 << 3,\n /** Is a pointer type. */\n POINTER = 1 << 4,\n /** Is smaller than 32-bits. */\n SHORT = 1 << 5,\n /** Is larger than 32-bits. */\n LONG = 1 << 6,\n /** Is a value type. */\n VALUE = 1 << 7,\n /** Is a reference type. */\n REFERENCE = 1 << 8,\n /** Is a nullable type. */\n NULLABLE = 1 << 9,\n /** Is a vector type. */\n VECTOR = 1 << 10\n}\n\nconst v128_zero = new Uint8Array(16);\n\n/** Represents a resolved type. */\nexport class Type {\n\n /** Type kind. */\n kind: TypeKind;\n /** Type flags. */\n flags: TypeFlags;\n /** Size in bits. */\n size: u32;\n /** Size in bytes. */\n byteSize: i32;\n /** Underlying class reference, if a class type. */\n classReference: Class | null;\n /** Underlying signature reference, if a function type. */\n signatureReference: Signature | null;\n /** Respective non-nullable type, if nullable. */\n nonNullableType: Type;\n /** Cached nullable type, if non-nullable. */\n private cachedNullableType: Type | null = null;\n\n /** Constructs a new resolved type. */\n constructor(kind: TypeKind, flags: TypeFlags, size: u32) {\n this.kind = kind;\n this.flags = flags;\n this.size = size;\n this.byteSize = ceil(size / 8);\n this.classReference = null;\n this.signatureReference = null;\n this.nonNullableType = this;\n }\n\n /** Returns the closest int type representing this type. */\n get intType(): Type {\n switch (this.kind) {\n case TypeKind.I8: return Type.i8;\n case TypeKind.I16: return Type.i16;\n case TypeKind.F32:\n case TypeKind.I32: return Type.i32;\n case TypeKind.F64:\n case TypeKind.I64: return Type.i64;\n case TypeKind.ISIZE: return this.size == 64 ? Type.isize64 : Type.isize32;\n case TypeKind.U8: return Type.u8;\n case TypeKind.U16: return Type.u16;\n case TypeKind.U32: return Type.u32;\n case TypeKind.U64: return Type.u64;\n case TypeKind.USIZE: return this.size == 64 ? Type.usize64 : Type.usize32;\n case TypeKind.BOOL:\n default: return Type.i32;\n }\n }\n\n /** Substitutes this type with the auto type if this type is void. */\n get exceptVoid(): Type {\n if (this.kind == TypeKind.VOID) return Type.auto;\n return this;\n }\n\n /** Gets this type's logarithmic alignment in memory. */\n get alignLog2(): i32 {\n return 31 - clz(this.byteSize);\n }\n\n /** Tests if this is a managed type that needs GC hooks. */\n get isManaged(): bool {\n var classReference = this.classReference;\n return classReference !== null && !classReference.hasDecorator(DecoratorFlags.UNMANAGED);\n }\n\n /** Tests if this is a class type explicitly annotated as unmanaged. */\n get isUnmanaged(): bool {\n var classReference = this.classReference;\n return classReference !== null && classReference.hasDecorator(DecoratorFlags.UNMANAGED);\n }\n\n /** Computes the sign-extending shift in the target type. */\n computeSmallIntegerShift(targetType: Type): u32 {\n return targetType.size - this.size;\n }\n\n /** Computes the truncating mask in the target type. */\n computeSmallIntegerMask(targetType: Type): u32 {\n var size = this.is(TypeFlags.UNSIGNED) ? this.size : this.size - 1;\n return ~0 >>> (targetType.size - size);\n }\n\n /** Tests if this type has (all of) the specified flags. */\n is(flags: TypeFlags): bool { return (this.flags & flags) == flags; }\n /** Tests if this type has any of the specified flags. */\n isAny(flags: TypeFlags): bool { return (this.flags & flags) != 0; }\n\n /** Composes a class type from this type and a class. */\n asClass(classType: Class): Type {\n assert(this.kind == TypeKind.USIZE && !this.classReference);\n var ret = new Type(this.kind, this.flags & ~TypeFlags.VALUE | TypeFlags.REFERENCE, this.size);\n ret.classReference = classType;\n return ret;\n }\n\n /** Composes a function type from this type and a function. */\n asFunction(signature: Signature): Type {\n assert(this.kind == TypeKind.U32 && !this.signatureReference);\n var ret = new Type(this.kind, this.flags & ~TypeFlags.VALUE | TypeFlags.REFERENCE, this.size);\n ret.signatureReference = signature;\n return ret;\n }\n\n /** Composes the respective nullable type of this type. */\n asNullable(): Type {\n assert(this.is(TypeFlags.REFERENCE));\n if (!this.cachedNullableType) {\n assert(!this.is(TypeFlags.NULLABLE));\n this.cachedNullableType = new Type(this.kind, this.flags | TypeFlags.NULLABLE, this.size);\n this.cachedNullableType.nonNullableType = this;\n this.cachedNullableType.classReference = this.classReference; // either a class reference\n this.cachedNullableType.signatureReference = this.signatureReference; // or a function reference\n }\n return this.cachedNullableType;\n }\n\n /** Tests if a value of this type is assignable to the target type incl. implicit conversion. */\n isAssignableTo(target: Type, signednessIsRelevant: bool = false): bool {\n var currentClass: Class | null;\n var targetClass: Class | null;\n var currentFunction: Signature | null;\n var targetFunction: Signature | null;\n if (this.is(TypeFlags.REFERENCE)) {\n if (target.is(TypeFlags.REFERENCE)) {\n if (!this.is(TypeFlags.NULLABLE) || target.is(TypeFlags.NULLABLE)) {\n if (currentClass = this.classReference) {\n if (targetClass = target.classReference) {\n return currentClass.isAssignableTo(targetClass);\n }\n } else if (currentFunction = this.signatureReference) {\n if (targetFunction = target.signatureReference) {\n return currentFunction.isAssignableTo(targetFunction);\n }\n }\n }\n }\n } else if (!target.is(TypeFlags.REFERENCE)) {\n if (this.is(TypeFlags.INTEGER)) {\n if (target.is(TypeFlags.INTEGER)) {\n if (\n !signednessIsRelevant ||\n this == Type.bool || // a bool (0 or 1) can be safely assigned to all sorts of integers\n this.is(TypeFlags.SIGNED) == target.is(TypeFlags.SIGNED)\n ) {\n return this.size <= target.size;\n }\n } else if (target.kind == TypeKind.F32) {\n return this.size <= 23; // mantissa bits\n } else if (target.kind == TypeKind.F64) {\n return this.size <= 52; // ^\n }\n } else if (this.is(TypeFlags.FLOAT)) {\n if (target.is(TypeFlags.FLOAT)) {\n return this.size <= target.size;\n }\n } else if (this.is(TypeFlags.VECTOR)) {\n if (target.is(TypeFlags.VECTOR)) {\n return this.size == target.size;\n }\n }\n }\n return false;\n }\n\n /** Tests if a value of this type is assignable to the target type excl. implicit conversion. */\n isStrictlyAssignableTo(target: Type, signednessIsRelevant: bool = false): bool {\n if (this.is(TypeFlags.REFERENCE)) return this.isAssignableTo(target);\n else if (target.is(TypeFlags.REFERENCE)) return false;\n if (this.is(TypeFlags.INTEGER)) {\n return target.is(TypeFlags.INTEGER) && target.size == this.size && (\n !signednessIsRelevant || this.is(TypeFlags.SIGNED) == target.is(TypeFlags.SIGNED)\n );\n }\n return this.kind == target.kind;\n }\n\n /** Determines the common denominator type of two types, if there is any. */\n static commonDenominator(left: Type, right: Type, signednessIsImportant: bool): Type | null {\n if (right.isAssignableTo(left, signednessIsImportant)) return left;\n else if (left.isAssignableTo(right, signednessIsImportant)) return right;\n return null;\n }\n\n /** Converts this type to a string. */\n toString(): string {\n if (this.is(TypeFlags.REFERENCE)) {\n let classReference = this.classReference;\n if (classReference) {\n return this.is(TypeFlags.NULLABLE)\n ? classReference.internalName + \" | null\"\n : classReference.internalName;\n }\n let signatureReference = this.signatureReference;\n if (signatureReference) {\n return this.is(TypeFlags.NULLABLE)\n ? \"(\" + signatureReference.toString() + \") | null\"\n : signatureReference.toString();\n }\n assert(false);\n }\n switch (this.kind) {\n case TypeKind.I8: return \"i8\";\n case TypeKind.I16: return \"i16\";\n case TypeKind.I32: return \"i32\";\n case TypeKind.I64: return \"i64\";\n case TypeKind.ISIZE: return \"isize\";\n case TypeKind.U8: return \"u8\";\n case TypeKind.U16: return \"u16\";\n case TypeKind.U32: return \"u32\";\n case TypeKind.U64: return \"u64\";\n case TypeKind.USIZE: return \"usize\";\n case TypeKind.BOOL: return \"bool\";\n case TypeKind.F32: return \"f32\";\n case TypeKind.F64: return \"f64\";\n case TypeKind.V128: return \"v128\";\n default: assert(false);\n case TypeKind.VOID: return \"void\";\n }\n }\n\n // Binaryen specific\n\n /** Converts this type to its respective native type. */\n toNativeType(): NativeType {\n switch (this.kind) {\n default: return NativeType.I32;\n case TypeKind.I64:\n case TypeKind.U64: return NativeType.I64;\n case TypeKind.ISIZE:\n case TypeKind.USIZE: return this.size == 64 ? NativeType.I64 : NativeType.I32;\n case TypeKind.F32: return NativeType.F32;\n case TypeKind.F64: return NativeType.F64;\n case TypeKind.V128: return NativeType.V128;\n case TypeKind.VOID: return NativeType.None;\n }\n }\n\n /** Converts this type to its native `0` value. */\n toNativeZero(module: Module): ExpressionRef {\n switch (this.kind) {\n case TypeKind.VOID: assert(false);\n default: return module.i32(0);\n case TypeKind.ISIZE:\n case TypeKind.USIZE: if (this.size != 64) return module.i32(0);\n case TypeKind.I64:\n case TypeKind.U64: return module.i64(0);\n case TypeKind.F32: return module.f32(0);\n case TypeKind.F64: return module.f64(0);\n case TypeKind.V128: return module.v128(v128_zero);\n }\n }\n\n /** Converts this type to its native `1` value. */\n toNativeOne(module: Module): ExpressionRef {\n switch (this.kind) {\n case TypeKind.V128:\n case TypeKind.VOID: assert(false);\n default: return module.i32(1);\n case TypeKind.ISIZE:\n case TypeKind.USIZE: if (this.size != 64) return module.i32(1);\n case TypeKind.I64:\n case TypeKind.U64: return module.i64(1);\n case TypeKind.F32: return module.f32(1);\n case TypeKind.F64: return module.f64(1);\n }\n }\n\n /** Converts this type to its native `-1` value. */\n toNativeNegOne(module: Module): ExpressionRef {\n switch (this.kind) {\n case TypeKind.V128:\n case TypeKind.VOID: assert(false);\n default: return module.i32(-1);\n case TypeKind.ISIZE:\n case TypeKind.USIZE: if (this.size != 64) return module.i32(-1);\n case TypeKind.I64:\n case TypeKind.U64: return module.i64(-1, -1);\n case TypeKind.F32: return module.f32(-1);\n case TypeKind.F64: return module.f64(-1);\n }\n }\n\n /** Converts this type to its signature string. */\n toSignatureString(): string {\n switch (this.kind) {\n // same naming scheme as Binaryen\n case TypeKind.I8:\n case TypeKind.U8:\n case TypeKind.I16:\n case TypeKind.U16:\n case TypeKind.I32:\n case TypeKind.U32:\n case TypeKind.BOOL: return \"i\";\n case TypeKind.I64:\n case TypeKind.U64: return \"j\";\n case TypeKind.ISIZE:\n case TypeKind.USIZE: return this.size == 64 ? \"j\" : \"i\";\n case TypeKind.F32: return \"f\";\n case TypeKind.F64: return \"d\";\n case TypeKind.V128: return \"V\";\n case TypeKind.VOID: return \"v\";\n default: assert(false);\n }\n return \"i\";\n }\n\n // Types\n\n /** An 8-bit signed integer. */\n static readonly i8: Type = new Type(TypeKind.I8,\n TypeFlags.SIGNED |\n TypeFlags.SHORT |\n TypeFlags.INTEGER |\n TypeFlags.VALUE, 8\n );\n\n /** A 16-bit signed integer. */\n static readonly i16: Type = new Type(TypeKind.I16,\n TypeFlags.SIGNED |\n TypeFlags.SHORT |\n TypeFlags.INTEGER |\n TypeFlags.VALUE, 16\n );\n\n /** A 32-bit signed integer. */\n static readonly i32: Type = new Type(TypeKind.I32,\n TypeFlags.SIGNED |\n TypeFlags.INTEGER |\n TypeFlags.VALUE, 32\n );\n\n /** A 64-bit signed integer. */\n static readonly i64: Type = new Type(TypeKind.I64,\n TypeFlags.SIGNED |\n TypeFlags.LONG |\n TypeFlags.INTEGER |\n TypeFlags.VALUE, 64\n );\n\n /** A 32-bit signed size. WASM32 only. */\n static readonly isize32: Type = new Type(TypeKind.ISIZE,\n TypeFlags.SIGNED |\n TypeFlags.INTEGER |\n TypeFlags.POINTER |\n TypeFlags.VALUE, 32\n );\n\n /** A 64-bit signed size. WASM64 only. */\n static readonly isize64: Type = new Type(TypeKind.ISIZE,\n TypeFlags.SIGNED |\n TypeFlags.LONG |\n TypeFlags.INTEGER |\n TypeFlags.POINTER |\n TypeFlags.VALUE, 64\n );\n\n /** An 8-bit unsigned integer. */\n static readonly u8: Type = new Type(TypeKind.U8,\n TypeFlags.UNSIGNED |\n TypeFlags.SHORT |\n TypeFlags.INTEGER |\n TypeFlags.VALUE, 8\n );\n\n /** A 16-bit unsigned integer. */\n static readonly u16: Type = new Type(TypeKind.U16,\n TypeFlags.UNSIGNED |\n TypeFlags.SHORT |\n TypeFlags.INTEGER |\n TypeFlags.VALUE, 16\n );\n\n /** A 32-bit unsigned integer. */\n static readonly u32: Type = new Type(TypeKind.U32,\n TypeFlags.UNSIGNED |\n TypeFlags.INTEGER |\n TypeFlags.VALUE, 32\n );\n\n /** A 64-bit unsigned integer. */\n static readonly u64: Type = new Type(TypeKind.U64,\n TypeFlags.UNSIGNED |\n TypeFlags.LONG |\n TypeFlags.INTEGER |\n TypeFlags.VALUE, 64\n );\n\n /** A 32-bit unsigned size. WASM32 only. */\n static readonly usize32: Type = new Type(TypeKind.USIZE,\n TypeFlags.UNSIGNED |\n TypeFlags.INTEGER |\n TypeFlags.POINTER |\n TypeFlags.VALUE, 32\n );\n\n /** A 64-bit unsigned size. WASM64 only. */\n static readonly usize64: Type = new Type(TypeKind.USIZE,\n TypeFlags.UNSIGNED |\n TypeFlags.LONG |\n TypeFlags.INTEGER |\n TypeFlags.POINTER |\n TypeFlags.VALUE, 64\n );\n\n /** A 1-bit unsigned integer. */\n static readonly bool: Type = new Type(TypeKind.BOOL,\n TypeFlags.UNSIGNED |\n TypeFlags.SHORT |\n TypeFlags.INTEGER |\n TypeFlags.VALUE, 1\n );\n\n /** A 32-bit float. */\n static readonly f32: Type = new Type(TypeKind.F32,\n TypeFlags.SIGNED |\n TypeFlags.FLOAT |\n TypeFlags.VALUE, 32\n );\n\n /** A 64-bit float. */\n static readonly f64: Type = new Type(TypeKind.F64,\n TypeFlags.SIGNED |\n TypeFlags.LONG |\n TypeFlags.FLOAT |\n TypeFlags.VALUE, 64\n );\n\n /** A 128-bit vector. */\n static readonly v128: Type = new Type(TypeKind.V128,\n TypeFlags.VECTOR |\n TypeFlags.VALUE, 128\n );\n\n /** No return type. */\n static readonly void: Type = new Type(TypeKind.VOID, TypeFlags.NONE, 0);\n\n /** Alias of i32 indicating type inference of locals and globals with just an initializer. */\n static readonly auto: Type = new Type(Type.i32.kind, Type.i32.flags, Type.i32.size);\n}\n\n/** Converts an array of types to an array of native types. */\nexport function typesToNativeTypes(types: Type[]): NativeType[] {\n var numTypes = types.length;\n var ret = new Array(numTypes);\n for (let i = 0; i < numTypes; ++i) ret[i] = types[i].toNativeType();\n return ret;\n}\n\n/** Converts an array of types to its combined string representation. */\nexport function typesToString(types: Type[]): string {\n var numTypes = types.length;\n if (!numTypes) return \"\";\n var sb = new Array(numTypes);\n for (let i = 0; i < numTypes; ++i) sb[i] = types[i].toString();\n return sb.join(\",\");\n}\n\n/** Represents a fully resolved function signature. */\nexport class Signature {\n\n /** Parameter types, if any, excluding `this`. */\n parameterTypes: Type[];\n /** Parameter names, if known, excluding `this`. */\n parameterNames: string[] | null;\n /** Number of required parameters excluding `this`. Other parameters are considered optional. */\n requiredParameters: i32;\n /** Return type. */\n returnType: Type;\n /** This type, if an instance signature. */\n thisType: Type | null;\n /** Whether the last parameter is a rest parameter. */\n hasRest: bool;\n /** Cached {@link FunctionTarget}. */\n cachedFunctionTarget: FunctionTarget | null = null;\n /** Respective function type. */\n type: Type;\n\n /** Constructs a new signature. */\n constructor(\n parameterTypes: Type[] | null = null,\n returnType: Type | null = null,\n thisType: Type | null = null\n ) {\n this.parameterTypes = parameterTypes ? parameterTypes : [];\n this.parameterNames = null;\n this.requiredParameters = 0;\n this.returnType = returnType ? returnType : Type.void;\n this.thisType = thisType;\n this.hasRest = false;\n this.type = Type.u32.asFunction(this);\n }\n\n asFunctionTarget(program: Program): FunctionTarget {\n var target = this.cachedFunctionTarget;\n if (!target) this.cachedFunctionTarget = target = new FunctionTarget(this, program);\n else assert(target.program == program);\n return target;\n }\n\n /** Gets the known or, alternatively, generic parameter name at the specified index. */\n getParameterName(index: i32): string {\n var parameterNames = this.parameterNames;\n return parameterNames && parameterNames.length > index\n ? parameterNames[index]\n : getDefaultParameterName(index);\n }\n\n /** Tests if a value of this function type is assignable to a target of the specified function type. */\n isAssignableTo(target: Signature): bool {\n // TODO: maybe cache results?\n\n // check `this` type\n var thisThisType = this.thisType;\n var targetThisType = target.thisType;\n if (thisThisType) {\n if (!(targetThisType && thisThisType.isAssignableTo(targetThisType))) return false;\n } else if (targetThisType) {\n return false;\n }\n\n // check rest parameter\n if (this.hasRest != target.hasRest) return false; // TODO\n\n // check parameter types\n var thisParameterTypes = this.parameterTypes;\n var targetParameterTypes = target.parameterTypes;\n var numParameters = thisParameterTypes.length;\n if (numParameters != targetParameterTypes.length) return false;\n for (let i = 0; i < numParameters; ++i) {\n let thisParameterType = thisParameterTypes[i];\n let targetParameterType = targetParameterTypes[i];\n if (!thisParameterType.isAssignableTo(targetParameterType)) return false;\n }\n\n // check return type\n var thisReturnType = this.returnType;\n var targetReturnType = target.returnType;\n return thisReturnType == targetReturnType || thisReturnType.isAssignableTo(targetReturnType);\n }\n\n /** Converts a signature to a function type string. */\n static makeSignatureString(parameterTypes: Type[] | null, returnType: Type, thisType: Type | null = null): string {\n var sb = [];\n sb.push(returnType.toSignatureString());\n if (thisType) sb.push(thisType.toSignatureString());\n if (parameterTypes) {\n for (let i = 0, k = parameterTypes.length; i < k; ++i) sb.push(parameterTypes[i].toSignatureString());\n }\n return \"FUNCSIG$\" + sb.join(\"\");\n }\n\n /** Converts this signature to a function type string. */\n toSignatureString(): string {\n return Signature.makeSignatureString(this.parameterTypes, this.returnType, this.thisType);\n }\n\n /** Converts this signature to a string. */\n toString(): string {\n var sb = new Array();\n sb.push(\"(\");\n var index = 0;\n var thisType = this.thisType;\n if (thisType) {\n sb.push(\"this: \");\n assert(!thisType.signatureReference);\n sb.push(thisType.toString());\n index = 1;\n }\n var parameters = this.parameterTypes;\n var numParameters = parameters.length;\n if (numParameters) {\n let names = this.parameterNames;\n let numNames = names ? names.length : 0;\n let optionalStart = this.requiredParameters;\n let restIndex = this.hasRest ? numParameters - 1 : -1;\n for (let i = 0; i < numParameters; ++i, ++index) {\n if (index) sb.push(\", \");\n if (i == restIndex) sb.push(\"...\");\n if (i < numNames) sb.push((names)[i]);\n else sb.push(getDefaultParameterName(i));\n if (i >= optionalStart && i != restIndex) sb.push(\"?: \");\n else sb.push(\": \");\n sb.push(parameters[i].toString());\n }\n }\n sb.push(\") => \");\n sb.push(this.returnType.toString());\n return sb.join(\"\");\n }\n}\n\n// helpers\n\n// Cached default parameter names used where names are unknown.\nvar cachedDefaultParameterNames: string[] | null = null;\n\n/** Gets the cached default parameter name for the specified index. */\nexport function getDefaultParameterName(index: i32): string {\n if (!cachedDefaultParameterNames) cachedDefaultParameterNames = [];\n for (let i = cachedDefaultParameterNames.length; i <= index; ++i) {\n cachedDefaultParameterNames.push(\"arg$\" + i.toString(10));\n }\n return cachedDefaultParameterNames[index - 1];\n}\n","/**\n * A TypeScript tokenizer modified for AssemblyScript.\n *\n * Skips over trivia and provides a general mark/reset mechanism for the parser to utilize on\n * ambiguous tokens.\n *\n * @module tokenizer\n *//***/\n\nimport {\n DiagnosticCode,\n DiagnosticMessage,\n DiagnosticEmitter\n} from \"./diagnostics\";\n\nimport {\n Source,\n CommentKind\n} from \"./ast\";\n\nimport {\n CharCode,\n isLineBreak,\n isWhiteSpace,\n isIdentifierStart,\n isIdentifierPart,\n isDecimalDigit,\n isOctalDigit,\n isKeywordCharacter\n} from \"./util\";\n\n/** Named token types. */\nexport enum Token {\n\n // keywords\n // discarded: ANY, BOOLEAN, NEVER, NUMBER, STRING, SYMBOL, UNDEFINED, LESSTHAN_SLASH\n\n ABSTRACT,\n AS,\n ASYNC,\n AWAIT, // ES2017\n BREAK, // ES2017\n CASE, // ES2017\n CATCH, // ES2017\n CLASS, // ES2017\n CONST, // ES2017\n CONTINUE, // ES2017\n CONSTRUCTOR,\n DEBUGGER, // ES2017\n DECLARE,\n DEFAULT, // ES2017\n DELETE, // ES2017\n DO, // ES2017\n ELSE, // ES2017\n ENUM, // ES2017 future\n EXPORT, // ES2017\n EXTENDS, // ES2017\n FALSE, // ES\n FINALLY, // ES2017\n FOR, // ES2017\n FROM, // AS possible identifier\n FUNCTION, // ES2017\n GET,\n IF, // ES2017\n IMPLEMENTS, // ES2017 non-lexical\n IMPORT, // ES2017\n IN, // ES2017\n INSTANCEOF, // ES2017\n INTERFACE, // ES2017 non-lexical\n IS,\n KEYOF,\n LET, // ES2017 non-lexical\n MODULE, // AS possible identifier\n NAMESPACE, // AS possible identifier\n NEW, // ES2017\n NULL, // ES\n OF,\n PACKAGE, // ES2017 non-lexical\n PRIVATE, // ES2017 non-lexical\n PROTECTED, // ES2017 non-lexical\n PUBLIC, // ES2017 non-lexical\n READONLY,\n RETURN, // ES2017\n SET,\n STATIC, // ES2017 non-lexical\n SUPER, // ES2017\n SWITCH, // ES2017\n THIS, // ES2017\n THROW, // ES2017\n TRUE, // ES\n TRY, // ES2017\n TYPE, // AS possible identifier\n TYPEOF, // ES2017\n VAR, // ES2017\n VOID, // ES2017\n WHILE, // ES2017\n WITH, // ES2017\n YIELD, // ES2017\n\n // punctuation\n\n OPENBRACE,\n CLOSEBRACE,\n OPENPAREN,\n CLOSEPAREN,\n OPENBRACKET,\n CLOSEBRACKET,\n DOT,\n DOT_DOT_DOT,\n SEMICOLON,\n COMMA,\n LESSTHAN,\n GREATERTHAN,\n LESSTHAN_EQUALS,\n GREATERTHAN_EQUALS,\n EQUALS_EQUALS,\n EXCLAMATION_EQUALS,\n EQUALS_EQUALS_EQUALS,\n EXCLAMATION_EQUALS_EQUALS,\n EQUALS_GREATERTHAN,\n PLUS,\n MINUS,\n ASTERISK_ASTERISK,\n ASTERISK,\n SLASH,\n PERCENT,\n PLUS_PLUS,\n MINUS_MINUS,\n LESSTHAN_LESSTHAN,\n GREATERTHAN_GREATERTHAN,\n GREATERTHAN_GREATERTHAN_GREATERTHAN,\n AMPERSAND,\n BAR,\n CARET,\n EXCLAMATION,\n TILDE,\n AMPERSAND_AMPERSAND,\n BAR_BAR,\n QUESTION,\n COLON,\n EQUALS,\n PLUS_EQUALS,\n MINUS_EQUALS,\n ASTERISK_EQUALS,\n ASTERISK_ASTERISK_EQUALS,\n SLASH_EQUALS,\n PERCENT_EQUALS,\n LESSTHAN_LESSTHAN_EQUALS,\n GREATERTHAN_GREATERTHAN_EQUALS,\n GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS,\n AMPERSAND_EQUALS,\n BAR_EQUALS,\n CARET_EQUALS,\n AT,\n\n // literals\n\n IDENTIFIER,\n STRINGLITERAL,\n INTEGERLITERAL,\n FLOATLITERAL,\n\n // meta\n\n INVALID,\n ENDOFFILE\n}\n\nexport enum IdentifierHandling {\n DEFAULT,\n PREFER,\n ALWAYS\n}\n\nexport function tokenFromKeyword(text: string): Token {\n assert(text.length);\n switch (text.charCodeAt(0)) {\n case CharCode.a: {\n switch (text) {\n case \"abstract\": return Token.ABSTRACT;\n case \"as\": return Token.AS;\n case \"async\": return Token.ASYNC;\n case \"await\": return Token.AWAIT;\n }\n break;\n }\n case CharCode.b: {\n switch (text) {\n case \"break\": return Token.BREAK;\n }\n break;\n }\n case CharCode.c: {\n switch (text) {\n case \"case\": return Token.CASE;\n case \"catch\": return Token.CATCH;\n case \"class\": return Token.CLASS;\n case \"continue\": return Token.CONTINUE;\n case \"const\": return Token.CONST;\n case \"constructor\": return Token.CONSTRUCTOR;\n }\n break;\n }\n case CharCode.d: {\n switch (text) {\n case \"debugger\": return Token.DEBUGGER;\n case \"declare\": return Token.DECLARE;\n case \"default\": return Token.DEFAULT;\n case \"delete\": return Token.DELETE;\n case \"do\": return Token.DO;\n }\n break;\n }\n case CharCode.e: {\n switch (text) {\n case \"else\": return Token.ELSE;\n case \"enum\": return Token.ENUM;\n case \"export\": return Token.EXPORT;\n case \"extends\": return Token.EXTENDS;\n }\n break;\n }\n case CharCode.f: {\n switch (text) {\n case \"false\": return Token.FALSE;\n case \"finally\": return Token.FINALLY;\n case \"for\": return Token.FOR;\n case \"from\": return Token.FROM;\n case \"function\": return Token.FUNCTION;\n }\n break;\n }\n case CharCode.g: {\n switch (text) {\n case \"get\": return Token.GET;\n }\n break;\n }\n case CharCode.i: {\n switch (text) {\n case \"if\": return Token.IF;\n case \"implements\": return Token.IMPLEMENTS;\n case \"import\": return Token.IMPORT;\n case \"in\": return Token.IN;\n case \"instanceof\": return Token.INSTANCEOF;\n case \"interface\": return Token.INTERFACE;\n case \"is\": return Token.IS;\n }\n break;\n }\n case CharCode.k: {\n switch (text) {\n case \"keyof\": return Token.KEYOF;\n }\n break;\n }\n case CharCode.l: {\n switch (text) {\n case \"let\": return Token.LET;\n }\n break;\n }\n case CharCode.m: {\n switch (text) {\n case \"module\": return Token.MODULE;\n }\n break;\n }\n case CharCode.n: {\n switch (text) {\n case \"namespace\": return Token.NAMESPACE;\n case \"new\": return Token.NEW;\n case \"null\": return Token.NULL;\n }\n break;\n }\n case CharCode.o: {\n switch (text) {\n case \"of\": return Token.OF;\n }\n break;\n }\n case CharCode.p: {\n switch (text) {\n case \"package\": return Token.PACKAGE;\n case \"private\": return Token.PRIVATE;\n case \"protected\": return Token.PROTECTED;\n case \"public\": return Token.PUBLIC;\n }\n break;\n }\n case CharCode.r: {\n switch (text) {\n case \"readonly\": return Token.READONLY;\n case \"return\": return Token.RETURN;\n }\n break;\n }\n case CharCode.s: {\n switch (text) {\n case \"set\": return Token.SET;\n case \"static\": return Token.STATIC;\n case \"super\": return Token.SUPER;\n case \"switch\": return Token.SWITCH;\n }\n break;\n }\n case CharCode.t: {\n switch (text) {\n case \"this\": return Token.THIS;\n case \"throw\": return Token.THROW;\n case \"true\": return Token.TRUE;\n case \"try\": return Token.TRY;\n case \"type\": return Token.TYPE;\n case \"typeof\": return Token.TYPEOF;\n }\n break;\n }\n case CharCode.v: {\n switch (text) {\n case \"var\": return Token.VAR;\n case \"void\": return Token.VOID;\n }\n break;\n }\n case CharCode.w: {\n switch (text) {\n case \"while\": return Token.WHILE;\n case \"with\": return Token.WITH;\n }\n break;\n }\n case CharCode.y: {\n switch (text) {\n case \"yield\": return Token.YIELD;\n }\n break;\n }\n }\n return Token.INVALID;\n}\n\nexport function tokenIsAlsoIdentifier(token: Token): bool {\n switch (token) {\n case Token.ABSTRACT:\n case Token.AS:\n case Token.CONSTRUCTOR:\n case Token.DECLARE:\n case Token.DELETE:\n case Token.FROM:\n case Token.FOR:\n case Token.GET:\n case Token.INSTANCEOF:\n case Token.IS:\n case Token.KEYOF:\n case Token.MODULE:\n case Token.NAMESPACE:\n case Token.NULL:\n case Token.READONLY:\n case Token.SET:\n case Token.TYPE:\n case Token.VOID: return true;\n default: return false;\n }\n}\n\nexport function isIllegalVariableIdentifier(name: string): bool {\n assert(name.length);\n switch (name.charCodeAt(0)) {\n case CharCode.d: return name == \"delete\";\n case CharCode.f: return name == \"for\";\n case CharCode.i: return name == \"instanceof\";\n case CharCode.n: return name == \"null\";\n case CharCode.v: return name == \"void\";\n }\n return false;\n}\n\nexport function operatorTokenToString(token: Token): string {\n switch (token) {\n case Token.DELETE: return \"delete\";\n case Token.IN: return \"in\";\n case Token.INSTANCEOF: return \"instanceof\";\n case Token.NEW: return \"new\";\n case Token.TYPEOF: return \"typeof\";\n case Token.VOID: return \"void\";\n case Token.YIELD: return \"yield\";\n case Token.DOT_DOT_DOT: return \"...\";\n case Token.COMMA: return \",\";\n case Token.LESSTHAN: return \"<\";\n case Token.GREATERTHAN: return \">\";\n case Token.LESSTHAN_EQUALS: return \"<=\";\n case Token.GREATERTHAN_EQUALS: return \">=\";\n case Token.EQUALS_EQUALS: return \"==\";\n case Token.EXCLAMATION_EQUALS: return \"!=\";\n case Token.EQUALS_EQUALS_EQUALS: return \"===\";\n case Token.EXCLAMATION_EQUALS_EQUALS: return \"!==\";\n case Token.PLUS: return \"+\";\n case Token.MINUS: return \"-\";\n case Token.ASTERISK_ASTERISK: return \"**\";\n case Token.ASTERISK: return \"*\";\n case Token.SLASH: return \"/\";\n case Token.PERCENT: return \"%\";\n case Token.PLUS_PLUS: return \"++\";\n case Token.MINUS_MINUS: return \"--\";\n case Token.LESSTHAN_LESSTHAN: return \"<<\";\n case Token.GREATERTHAN_GREATERTHAN: return \">>\";\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN: return \">>>\";\n case Token.AMPERSAND: return \"&\";\n case Token.BAR: return \"|\";\n case Token.CARET: return \"^\";\n case Token.EXCLAMATION: return \"!\";\n case Token.TILDE: return \"~\";\n case Token.AMPERSAND_AMPERSAND: return \"&&\";\n case Token.BAR_BAR: return \"||\";\n case Token.EQUALS: return \"=\";\n case Token.PLUS_EQUALS: return \"+=\";\n case Token.MINUS_EQUALS: return \"-=\";\n case Token.ASTERISK_EQUALS: return \"*=\";\n case Token.ASTERISK_ASTERISK_EQUALS: return \"**=\";\n case Token.SLASH_EQUALS: return \"/=\";\n case Token.PERCENT_EQUALS: return \"%=\";\n case Token.LESSTHAN_LESSTHAN_EQUALS: return \"<<=\";\n case Token.GREATERTHAN_GREATERTHAN_EQUALS: return \">>=\";\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS: return \">>>=\";\n case Token.AMPERSAND_EQUALS: return \"&=\";\n case Token.BAR_EQUALS: return \"|=\";\n case Token.CARET_EQUALS: return \"^=\";\n default: {\n assert(false);\n return \"\";\n }\n }\n}\n\nexport class Range {\n\n source: Source;\n start: i32;\n end: i32;\n\n // TODO: set these while tokenizing\n // line: i32;\n // column: i32;\n\n constructor(source: Source, start: i32, end: i32) {\n this.source = source;\n this.start = start;\n this.end = end;\n }\n\n static join(a: Range, b: Range): Range {\n if (a.source != b.source) throw new Error(\"source mismatch\");\n return new Range(a.source,\n a.start < b.start ? a.start : b.start,\n a.end > b.end ? a.end : b.end\n );\n }\n\n get atStart(): Range {\n return new Range(this.source, this.start, this.start);\n }\n\n get atEnd(): Range {\n return new Range(this.source, this.end, this.end);\n }\n\n get line(): i32 {\n var text = this.source.text;\n var line = 1;\n for (let pos = this.start; pos >= 0; --pos) {\n if (text.charCodeAt(pos) == CharCode.LINEFEED) line++;\n }\n return line;\n }\n\n get column(): i32 {\n var text = this.source.text;\n var column = 0;\n for (let pos = this.start - 1; pos >= 0; --pos) {\n if (text.charCodeAt(pos) == CharCode.LINEFEED) break;\n ++column;\n }\n return column;\n }\n\n toString(): string {\n return this.source.text.substring(this.start, this.end);\n }\n\n debugInfoRef: usize = 0;\n}\n\ndeclare function parseFloat(str: string): f64;\n\n/** Handler for intercepting comments while tokenizing. */\nexport type CommentHandler = (kind: CommentKind, text: string, range: Range) => void;\n\n/** Tokenizes a source to individual {@link Token}s. */\nexport class Tokenizer extends DiagnosticEmitter {\n\n source: Source;\n end: i32 = 0;\n\n pos: i32 = 0;\n token: Token = -1;\n tokenPos: i32 = 0;\n\n nextToken: Token = -1;\n nextTokenPos: i32 = 0;\n nextTokenOnNewLine: bool = false;\n\n onComment: CommentHandler | null = null;\n\n /** Constructs a new tokenizer. */\n constructor(source: Source, diagnostics: DiagnosticMessage[] | null = null) {\n super(diagnostics);\n\n this.source = source;\n this.pos = 0;\n this.end = source.text.length;\n this.diagnostics = diagnostics || new Array();\n\n var end = this.end;\n var text = source.text;\n\n // skip bom\n if (\n this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.BYTEORDERMARK\n ) {\n ++this.pos;\n }\n\n // skip shebang\n if (\n this.pos + 1 < end &&\n text.charCodeAt(this.pos) == CharCode.HASH &&\n text.charCodeAt(this.pos + 1) == CharCode.EXCLAMATION\n ) {\n this.pos += 2;\n while (\n this.pos < end &&\n text.charCodeAt(this.pos) != CharCode.LINEFEED\n ) {\n ++this.pos;\n }\n // 'next' now starts at lf or eof\n }\n }\n\n next(identifierHandling: IdentifierHandling = IdentifierHandling.DEFAULT): Token {\n this.nextToken = -1;\n return this.token = this.unsafeNext(identifierHandling);\n }\n\n private unsafeNext(\n identifierHandling: IdentifierHandling = IdentifierHandling.DEFAULT,\n maxTokenLength: i32 = i32.MAX_VALUE\n ): Token {\n var end = this.end;\n var text = this.source.text;\n while (this.pos < end) {\n this.tokenPos = this.pos;\n let c = text.charCodeAt(this.pos);\n switch (c) {\n case CharCode.CARRIAGERETURN: {\n if (!(\n ++this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.LINEFEED\n )) break;\n // otherwise fall-through\n }\n case CharCode.LINEFEED:\n case CharCode.TAB:\n case CharCode.VERTICALTAB:\n case CharCode.FORMFEED:\n case CharCode.SPACE: {\n ++this.pos;\n break;\n }\n case CharCode.EXCLAMATION: {\n ++this.pos;\n if (\n maxTokenLength > 1 && this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.EQUALS\n ) {\n ++this.pos;\n if (\n maxTokenLength > 2 && this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.EQUALS\n ) {\n ++this.pos;\n return Token.EXCLAMATION_EQUALS_EQUALS;\n }\n return Token.EXCLAMATION_EQUALS;\n }\n return Token.EXCLAMATION;\n }\n case CharCode.DOUBLEQUOTE:\n case CharCode.SINGLEQUOTE:\n case CharCode.BACKTICK: { // TODO\n return Token.STRINGLITERAL; // expects a call to readString\n }\n case CharCode.PERCENT: {\n ++this.pos;\n if (\n maxTokenLength > 1 && this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.EQUALS\n ) {\n ++this.pos;\n return Token.PERCENT_EQUALS;\n }\n return Token.PERCENT;\n }\n case CharCode.AMPERSAND: {\n ++this.pos;\n if (maxTokenLength > 1 && this.pos < end) {\n let chr = text.charCodeAt(this.pos);\n if (chr == CharCode.AMPERSAND) {\n ++this.pos;\n return Token.AMPERSAND_AMPERSAND;\n }\n if (chr == CharCode.EQUALS) {\n ++this.pos;\n return Token.AMPERSAND_EQUALS;\n }\n }\n return Token.AMPERSAND;\n }\n case CharCode.OPENPAREN: {\n ++this.pos;\n return Token.OPENPAREN;\n }\n case CharCode.CLOSEPAREN: {\n ++this.pos;\n return Token.CLOSEPAREN;\n }\n case CharCode.ASTERISK: {\n ++this.pos;\n if (maxTokenLength > 1 && this.pos < end) {\n let chr = text.charCodeAt(this.pos);\n if (chr == CharCode.EQUALS) {\n ++this.pos;\n return Token.ASTERISK_EQUALS;\n }\n if (chr == CharCode.ASTERISK) {\n ++this.pos;\n if (\n maxTokenLength > 2 && this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.EQUALS\n ) {\n ++this.pos;\n return Token.ASTERISK_ASTERISK_EQUALS;\n }\n return Token.ASTERISK_ASTERISK;\n }\n }\n return Token.ASTERISK;\n }\n case CharCode.PLUS: {\n ++this.pos;\n if (maxTokenLength > 1 && this.pos < end) {\n let chr = text.charCodeAt(this.pos);\n if (chr == CharCode.PLUS) {\n ++this.pos;\n return Token.PLUS_PLUS;\n }\n if (chr == CharCode.EQUALS) {\n ++this.pos;\n return Token.PLUS_EQUALS;\n }\n }\n return Token.PLUS;\n }\n case CharCode.COMMA: {\n ++this.pos;\n return Token.COMMA;\n }\n case CharCode.MINUS: {\n ++this.pos;\n if (maxTokenLength > 1 && this.pos < end) {\n let chr = text.charCodeAt(this.pos);\n if (chr == CharCode.MINUS) {\n ++this.pos;\n return Token.MINUS_MINUS;\n }\n if (chr == CharCode.EQUALS) {\n ++this.pos;\n return Token.MINUS_EQUALS;\n }\n }\n return Token.MINUS;\n }\n case CharCode.DOT: {\n ++this.pos;\n if (maxTokenLength > 1 && this.pos < end) {\n let chr = text.charCodeAt(this.pos);\n if (isDecimalDigit(chr)) {\n --this.pos;\n return Token.FLOATLITERAL; // expects a call to readFloat\n }\n if (\n maxTokenLength > 2 && this.pos + 1 < end &&\n chr == CharCode.DOT &&\n text.charCodeAt(this.pos + 1) == CharCode.DOT\n ) {\n this.pos += 2;\n return Token.DOT_DOT_DOT;\n }\n }\n return Token.DOT;\n }\n case CharCode.SLASH: {\n let commentStartPos = this.pos;\n ++this.pos;\n if (maxTokenLength > 1 && this.pos < end) {\n let chr = text.charCodeAt(this.pos);\n if (chr == CharCode.SLASH) { // single-line\n let commentKind = CommentKind.LINE;\n if (\n this.pos + 1 < end &&\n text.charCodeAt(this.pos + 1) == CharCode.SLASH\n ) {\n ++this.pos;\n commentKind = CommentKind.TRIPLE;\n }\n while (++this.pos < end) {\n if (text.charCodeAt(this.pos) == CharCode.LINEFEED) {\n ++this.pos;\n break;\n }\n }\n if (this.onComment) {\n this.onComment(\n commentKind,\n text.substring(commentStartPos, this.pos),\n this.range(commentStartPos, this.pos)\n );\n }\n break;\n }\n if (chr == CharCode.ASTERISK) { // multi-line\n let closed = false;\n while (++this.pos < end) {\n c = text.charCodeAt(this.pos);\n if (\n c == CharCode.ASTERISK &&\n this.pos + 1 < end &&\n text.charCodeAt(this.pos + 1) == CharCode.SLASH\n ) {\n this.pos += 2;\n closed = true;\n break;\n }\n }\n if (!closed) {\n this.error(\n DiagnosticCode._0_expected,\n this.range(this.pos), \"*/\"\n );\n } else if (this.onComment) {\n this.onComment(\n CommentKind.BLOCK,\n text.substring(commentStartPos, this.pos),\n this.range(commentStartPos, this.pos)\n );\n }\n break;\n }\n if (chr == CharCode.EQUALS) {\n ++this.pos;\n return Token.SLASH_EQUALS;\n }\n }\n return Token.SLASH;\n }\n case CharCode._0:\n case CharCode._1:\n case CharCode._2:\n case CharCode._3:\n case CharCode._4:\n case CharCode._5:\n case CharCode._6:\n case CharCode._7:\n case CharCode._8:\n case CharCode._9: {\n return this.testInteger()\n ? Token.INTEGERLITERAL // expects a call to readInteger\n : Token.FLOATLITERAL; // expects a call to readFloat\n }\n case CharCode.COLON: {\n ++this.pos;\n return Token.COLON;\n }\n case CharCode.SEMICOLON: {\n ++this.pos;\n return Token.SEMICOLON;\n }\n case CharCode.LESSTHAN: {\n ++this.pos;\n if (maxTokenLength > 1 && this.pos < end) {\n let chr = text.charCodeAt(this.pos);\n if (chr == CharCode.LESSTHAN) {\n ++this.pos;\n if (\n maxTokenLength > 2 &&\n this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.EQUALS\n ) {\n ++this.pos;\n return Token.LESSTHAN_LESSTHAN_EQUALS;\n }\n return Token.LESSTHAN_LESSTHAN;\n }\n if (chr == CharCode.EQUALS) {\n ++this.pos;\n return Token.LESSTHAN_EQUALS;\n }\n }\n return Token.LESSTHAN;\n }\n case CharCode.EQUALS: {\n ++this.pos;\n if (maxTokenLength > 1 && this.pos < end) {\n let chr = text.charCodeAt(this.pos);\n if (chr == CharCode.EQUALS) {\n ++this.pos;\n if (\n maxTokenLength > 2 &&\n this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.EQUALS\n ) {\n ++this.pos;\n return Token.EQUALS_EQUALS_EQUALS;\n }\n return Token.EQUALS_EQUALS;\n }\n if (chr == CharCode.GREATERTHAN) {\n ++this.pos;\n return Token.EQUALS_GREATERTHAN;\n }\n }\n return Token.EQUALS;\n }\n case CharCode.GREATERTHAN: {\n ++this.pos;\n if (maxTokenLength > 1 && this.pos < end) {\n let chr = text.charCodeAt(this.pos);\n if (chr == CharCode.GREATERTHAN) {\n ++this.pos;\n if (maxTokenLength > 2 && this.pos < end) {\n chr = text.charCodeAt(this.pos);\n if (chr == CharCode.GREATERTHAN) {\n ++this.pos;\n if (\n maxTokenLength > 3 && this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.EQUALS\n ) {\n ++this.pos;\n return Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS;\n }\n return Token.GREATERTHAN_GREATERTHAN_GREATERTHAN;\n }\n if (chr == CharCode.EQUALS) {\n ++this.pos;\n return Token.GREATERTHAN_GREATERTHAN_EQUALS;\n }\n }\n return Token.GREATERTHAN_GREATERTHAN;\n }\n if (chr == CharCode.EQUALS) {\n ++this.pos;\n return Token.GREATERTHAN_EQUALS;\n }\n }\n return Token.GREATERTHAN;\n }\n case CharCode.QUESTION: {\n ++this.pos;\n return Token.QUESTION;\n }\n case CharCode.OPENBRACKET: {\n ++this.pos;\n return Token.OPENBRACKET;\n }\n case CharCode.CLOSEBRACKET: {\n ++this.pos;\n return Token.CLOSEBRACKET;\n }\n case CharCode.CARET: {\n ++this.pos;\n if (\n maxTokenLength > 1 && this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.EQUALS\n ) {\n ++this.pos;\n return Token.CARET_EQUALS;\n }\n return Token.CARET;\n }\n case CharCode.OPENBRACE: {\n ++this.pos;\n return Token.OPENBRACE;\n }\n case CharCode.BAR: {\n ++this.pos;\n if (maxTokenLength > 1 && this.pos < end) {\n let chr = text.charCodeAt(this.pos);\n if (chr == CharCode.BAR) {\n ++this.pos;\n return Token.BAR_BAR;\n }\n if (chr == CharCode.EQUALS) {\n ++this.pos;\n return Token.BAR_EQUALS;\n }\n }\n return Token.BAR;\n }\n case CharCode.CLOSEBRACE: {\n ++this.pos;\n return Token.CLOSEBRACE;\n }\n case CharCode.TILDE: {\n ++this.pos;\n return Token.TILDE;\n }\n case CharCode.AT: {\n ++this.pos;\n return Token.AT;\n }\n default: {\n if (isIdentifierStart(c)) {\n if (isKeywordCharacter(c)) {\n let posBefore = this.pos;\n while (\n ++this.pos < end &&\n isIdentifierPart(c = text.charCodeAt(this.pos))\n ) {\n if (!isKeywordCharacter(c)) {\n this.pos = posBefore;\n return Token.IDENTIFIER;\n }\n }\n let keywordText = text.substring(posBefore, this.pos);\n let keywordToken = tokenFromKeyword(keywordText);\n if (\n keywordToken !== Token.INVALID &&\n identifierHandling !== IdentifierHandling.ALWAYS &&\n !(\n identifierHandling === IdentifierHandling.PREFER &&\n tokenIsAlsoIdentifier(keywordToken)\n )\n ) {\n return keywordToken;\n }\n this.pos = posBefore;\n }\n return Token.IDENTIFIER; // expects a call to readIdentifier\n } else if (isWhiteSpace(c)) {\n ++this.pos;\n break;\n }\n this.error(\n DiagnosticCode.Invalid_character,\n this.range(this.pos, this.pos + 1)\n );\n ++this.pos;\n return Token.INVALID;\n }\n }\n }\n return Token.ENDOFFILE;\n }\n\n peek(\n checkOnNewLine: bool = false,\n identifierHandling: IdentifierHandling = IdentifierHandling.DEFAULT,\n maxCompoundLength: i32 = i32.MAX_VALUE\n ): Token {\n var text = this.source.text;\n if (this.nextToken < 0) {\n let posBefore = this.pos;\n let tokenBefore = this.token;\n let tokenPosBefore = this.tokenPos;\n this.nextToken = this.unsafeNext(identifierHandling, maxCompoundLength);\n this.nextTokenPos = this.tokenPos;\n if (checkOnNewLine) {\n this.nextTokenOnNewLine = false;\n for (let pos = posBefore, end = this.nextTokenPos; pos < end; ++pos) {\n if (isLineBreak(text.charCodeAt(pos))) {\n this.nextTokenOnNewLine = true;\n break;\n }\n }\n }\n this.pos = posBefore;\n this.token = tokenBefore;\n this.tokenPos = tokenPosBefore;\n }\n return this.nextToken;\n }\n\n skipIdentifier(identifierHandling: IdentifierHandling = IdentifierHandling.PREFER): bool {\n return this.skip(Token.IDENTIFIER, identifierHandling);\n }\n\n skip(token: Token, identifierHandling: IdentifierHandling = IdentifierHandling.DEFAULT): bool {\n var posBefore = this.pos;\n var tokenBefore = this.token;\n var tokenPosBefore = this.tokenPos;\n var maxCompoundLength = i32.MAX_VALUE;\n switch (token) {\n case Token.GREATERTHAN: { // where parsing type arguments\n maxCompoundLength = 1;\n break;\n }\n }\n this.token = this.unsafeNext(identifierHandling, maxCompoundLength);\n if (this.token == token) {\n this.nextToken = -1;\n return true;\n } else {\n this.pos = posBefore;\n this.token = tokenBefore;\n this.tokenPos = tokenPosBefore;\n return false;\n }\n }\n\n mark(): State {\n var state: State;\n if (reusableState) {\n state = reusableState;\n reusableState = null;\n } else {\n state = new State();\n }\n state.pos = this.pos;\n state.token = this.token;\n state.tokenPos = this.tokenPos;\n return state;\n }\n\n discard(state: State): void {\n reusableState = state;\n }\n\n reset(state: State): void {\n this.pos = state.pos;\n this.token = state.token;\n this.tokenPos = state.tokenPos;\n this.nextToken = -1;\n }\n\n range(start: i32 = -1, end: i32 = -1): Range {\n if (start < 0) {\n start = this.tokenPos;\n end = this.pos;\n } else if (end < 0) {\n end = start;\n }\n return new Range(this.source, start, end);\n }\n\n readIdentifier(): string {\n var text = this.source.text;\n var start = this.pos;\n var end = this.end;\n while (\n ++this.pos < end &&\n isIdentifierPart(text.charCodeAt(this.pos))\n );\n return text.substring(start, this.pos);\n }\n\n readString(): string {\n var text = this.source.text;\n var quote = text.charCodeAt(this.pos++);\n var start = this.pos;\n var end = this.end;\n var result = \"\";\n while (true) {\n if (this.pos >= end) {\n result += text.substring(start, this.pos);\n this.error(\n DiagnosticCode.Unterminated_string_literal,\n this.range(start - 1, end)\n );\n break;\n }\n let c = text.charCodeAt(this.pos);\n if (c == quote) {\n result += text.substring(start, this.pos++);\n break;\n }\n if (c == CharCode.BACKSLASH) {\n result += text.substring(start, this.pos);\n result += this.readEscapeSequence();\n start = this.pos;\n continue;\n }\n if (isLineBreak(c)) {\n result += text.substring(start, this.pos);\n this.error(\n DiagnosticCode.Unterminated_string_literal,\n this.range(start - 1, this.pos)\n );\n break;\n }\n ++this.pos;\n }\n return result;\n }\n\n readEscapeSequence(): string {\n var end = this.end;\n if (++this.pos >= end) {\n this.error(\n DiagnosticCode.Unexpected_end_of_text,\n this.range(end)\n );\n return \"\";\n }\n\n var text = this.source.text;\n var c = text.charCodeAt(this.pos++);\n switch (c) {\n case CharCode._0: return \"\\0\";\n case CharCode.b: return \"\\b\";\n case CharCode.t: return \"\\t\";\n case CharCode.n: return \"\\n\";\n case CharCode.v: return \"\\v\";\n case CharCode.f: return \"\\f\";\n case CharCode.r: return \"\\r\";\n case CharCode.SINGLEQUOTE: return \"'\";\n case CharCode.DOUBLEQUOTE: return \"\\\"\";\n case CharCode.u: {\n if (\n this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.OPENBRACE\n ) {\n ++this.pos;\n return this.readExtendedUnicodeEscape(); // \\u{DDDDDDDD}\n }\n return this.readUnicodeEscape(); // \\uDDDD\n }\n case CharCode.CARRIAGERETURN: {\n if (\n this.pos < end &&\n text.charCodeAt(this.pos) == CharCode.LINEFEED\n ) {\n ++this.pos;\n }\n // fall through\n }\n case CharCode.LINEFEED:\n case CharCode.LINESEPARATOR:\n case CharCode.PARAGRAPHSEPARATOR: return \"\";\n default: return String.fromCharCode(c);\n }\n }\n\n readRegexpPattern(): string {\n var text = this.source.text;\n var start = this.pos;\n var end = this.end;\n var escaped = false;\n while (true) {\n if (this.pos >= end) {\n this.error(\n DiagnosticCode.Unterminated_regular_expression_literal,\n this.range(start, end)\n );\n break;\n }\n if (text.charCodeAt(this.pos) == CharCode.BACKSLASH) {\n ++this.pos;\n escaped = true;\n continue;\n }\n let c = text.charCodeAt(this.pos);\n if (!escaped && c == CharCode.SLASH) break;\n if (isLineBreak(c)) {\n this.error(\n DiagnosticCode.Unterminated_regular_expression_literal,\n this.range(start, this.pos)\n );\n break;\n }\n ++this.pos;\n escaped = false;\n }\n return text.substring(start, this.pos);\n }\n\n readRegexpFlags(): string {\n var text = this.source.text;\n var start = this.pos;\n var end = this.end;\n var flags = 0;\n while (this.pos < end) {\n let c: i32 = text.charCodeAt(this.pos);\n if (!isIdentifierPart(c)) break;\n ++this.pos;\n\n // make sure each supported flag is unique\n switch (c) {\n case CharCode.g: {\n flags |= flags & 1 ? -1 : 1;\n break;\n }\n case CharCode.i: {\n flags |= flags & 2 ? -1 : 2;\n break;\n }\n case CharCode.m: {\n flags |= flags & 4 ? -1 : 4;\n break;\n }\n default: {\n flags = -1;\n break;\n }\n }\n }\n if (flags == -1) {\n this.error(\n DiagnosticCode.Invalid_regular_expression_flags,\n this.range(start, this.pos)\n );\n }\n return text.substring(start, this.pos);\n }\n\n testInteger(): bool {\n var end = this.end;\n var text = this.source.text;\n if (this.pos + 1 < end && text.charCodeAt(this.pos) == CharCode._0) {\n switch (text.charCodeAt(this.pos + 2)) {\n case CharCode.x:\n case CharCode.X:\n case CharCode.b:\n case CharCode.B:\n case CharCode.o:\n case CharCode.O: return true;\n }\n }\n var pos = this.pos;\n while (pos < end) {\n let c = text.charCodeAt(pos);\n if (c == CharCode.DOT || c == CharCode.e || c == CharCode.E) return false;\n if ((c < CharCode._0 || c > CharCode._9) && c != CharCode._) break;\n // does not validate separator placement (this is done in readXYInteger)\n pos++;\n }\n return true;\n }\n\n readInteger(): I64 {\n var text = this.source.text;\n if (this.pos + 2 < this.end && text.charCodeAt(this.pos) == CharCode._0) {\n switch (text.charCodeAt(this.pos + 1)) {\n case CharCode.x:\n case CharCode.X: {\n this.pos += 2;\n return this.readHexInteger();\n }\n case CharCode.b:\n case CharCode.B: {\n this.pos += 2;\n return this.readBinaryInteger();\n }\n case CharCode.o:\n case CharCode.O: {\n this.pos += 2;\n return this.readOctalInteger();\n }\n }\n if (isOctalDigit(text.charCodeAt(this.pos + 1))) {\n let start = this.pos;\n ++this.pos;\n let value = this.readOctalInteger();\n this.error(\n DiagnosticCode.Octal_literals_are_not_allowed_in_strict_mode,\n this.range(start, this.pos)\n );\n return value;\n }\n }\n return this.readDecimalInteger();\n }\n\n readHexInteger(): I64 {\n var text = this.source.text;\n var start = this.pos;\n var value = i64_new(0);\n var i64_4 = i64_new(4);\n var sepEnd = start;\n var end = this.end;\n while (this.pos < end) {\n let pos = this.pos;\n let c = text.charCodeAt(pos);\n if (c >= CharCode._0 && c <= CharCode._9) {\n // value = (value << 4) + c - CharCode._0;\n value = i64_add(\n i64_shl(value, i64_4),\n i64_new(c - CharCode._0)\n );\n } else if (c >= CharCode.A && c <= CharCode.F) {\n // value = (value << 4) + 10 + c - CharCode.A;\n value = i64_add(\n i64_shl(value, i64_4),\n i64_new(10 + c - CharCode.A)\n );\n } else if (c >= CharCode.a && c <= CharCode.f) {\n // value = (value << 4) + 10 + c - CharCode.a;\n value = i64_add(\n i64_shl(value, i64_4),\n i64_new(10 + c - CharCode.a)\n );\n } else if (c == CharCode._) {\n if (sepEnd == pos) {\n this.error(\n sepEnd == start\n ? DiagnosticCode.Numeric_separators_are_not_allowed_here\n : DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,\n this.range(pos)\n );\n }\n sepEnd = pos + 1;\n } else {\n break;\n }\n this.pos = pos + 1;\n }\n if (this.pos == start) {\n this.error(\n DiagnosticCode.Hexadecimal_digit_expected,\n this.range(start)\n );\n } else if (sepEnd == this.pos) {\n this.error(\n DiagnosticCode.Numeric_separators_are_not_allowed_here,\n this.range(sepEnd - 1)\n );\n }\n return value;\n }\n\n readDecimalInteger(): I64 {\n var text = this.source.text;\n var start = this.pos;\n var end = this.end;\n var value = i64_new(0);\n var i64_10 = i64_new(10);\n var sepEnd = start;\n while (this.pos < end) {\n let pos = this.pos;\n let c = text.charCodeAt(pos);\n if (c >= CharCode._0 && c <= CharCode._9) {\n // value = value * 10 + c - CharCode._0;\n value = i64_add(\n i64_mul(value, i64_10),\n i64_new(c - CharCode._0)\n );\n } else if (c == CharCode._) {\n if (sepEnd == pos) {\n this.error(\n sepEnd == start\n ? DiagnosticCode.Numeric_separators_are_not_allowed_here\n : DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,\n this.range(pos)\n );\n }\n sepEnd = pos + 1;\n } else {\n break;\n }\n this.pos = pos + 1;\n }\n if (this.pos == start) {\n this.error(\n DiagnosticCode.Digit_expected,\n this.range(start)\n );\n } else if (sepEnd == this.pos) {\n this.error(\n DiagnosticCode.Numeric_separators_are_not_allowed_here,\n this.range(sepEnd - 1)\n );\n }\n return value;\n }\n\n readOctalInteger(): I64 {\n var text = this.source.text;\n var start = this.pos;\n var value = i64_new(0);\n var i64_3 = i64_new(3);\n var sepEnd = start;\n var end = this.end;\n while (this.pos < end) {\n let pos = this.pos;\n let c = text.charCodeAt(pos);\n if (c >= CharCode._0 && c <= CharCode._7) {\n // value = (value << 3) + c - CharCode._0;\n value = i64_add(\n i64_shl(value, i64_3),\n i64_new(c - CharCode._0)\n );\n } else if (c == CharCode._) {\n if (sepEnd == pos) {\n this.error(\n sepEnd == start\n ? DiagnosticCode.Numeric_separators_are_not_allowed_here\n : DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,\n this.range(pos)\n );\n }\n sepEnd = pos + 1;\n } else {\n break;\n }\n ++this.pos;\n }\n if (this.pos == start) {\n this.error(\n DiagnosticCode.Octal_digit_expected,\n this.range(start)\n );\n } else if (sepEnd == this.pos) {\n this.error(\n DiagnosticCode.Numeric_separators_are_not_allowed_here,\n this.range(sepEnd - 1)\n );\n }\n return value;\n }\n\n readBinaryInteger(): I64 {\n var text = this.source.text;\n var start = this.pos;\n var value = i64_new(0);\n var i64_1 = i64_new(1);\n var sepEnd = start;\n var end = this.end;\n while (this.pos < end) {\n let pos = this.pos;\n let c = text.charCodeAt(pos);\n if (c == CharCode._0) {\n // value = (value << 1);\n value = i64_shl(value, i64_1);\n } else if (c == CharCode._1) {\n // value = (value << 1) + 1;\n value = i64_add(\n i64_shl(value, i64_1),\n i64_1\n );\n } else if (c == CharCode._) {\n if (sepEnd == pos) {\n this.error(\n sepEnd == start\n ? DiagnosticCode.Numeric_separators_are_not_allowed_here\n : DiagnosticCode.Multiple_consecutive_numeric_separators_are_not_permitted,\n this.range(pos)\n );\n }\n sepEnd = pos + 1;\n } else {\n break;\n }\n this.pos = pos + 1;\n }\n if (this.pos == start) {\n this.error(\n DiagnosticCode.Binary_digit_expected,\n this.range(start)\n );\n } else if (sepEnd == this.pos) {\n this.error(\n DiagnosticCode.Numeric_separators_are_not_allowed_here,\n this.range(sepEnd - 1)\n );\n }\n return value;\n }\n\n readFloat(): f64 {\n // var text = this.source.text;\n // if (text.charCodeAt(this.pos) == CharCode._0 && this.pos + 2 < this.end) {\n // switch (text.charCodeAt(this.pos + 1)) {\n // case CharCode.X:\n // case CharCode.x: {\n // this.pos += 2;\n // return this.readHexFloat();\n // }\n // }\n // }\n return this.readDecimalFloat();\n }\n\n readDecimalFloat(): f64 {\n // TODO: numeric separators (parseFloat can't handle these)\n var start = this.pos;\n var end = this.end;\n var text = this.source.text;\n while (this.pos < end && isDecimalDigit(text.charCodeAt(this.pos))) {\n ++this.pos;\n }\n if (this.pos < end && text.charCodeAt(this.pos) == CharCode.DOT) {\n ++this.pos;\n while (this.pos < end && isDecimalDigit(text.charCodeAt(this.pos))) {\n ++this.pos;\n }\n }\n if (this.pos < end) {\n let c = text.charCodeAt(this.pos);\n if (c == CharCode.e || c == CharCode.E) {\n if (\n ++this.pos < end &&\n (c = text.charCodeAt(this.pos)) == CharCode.MINUS || c == CharCode.PLUS &&\n isDecimalDigit(text.charCodeAt(this.pos + 1))\n ) {\n ++this.pos;\n }\n while (this.pos < end && isDecimalDigit(text.charCodeAt(this.pos))) {\n ++this.pos;\n }\n }\n }\n return parseFloat(text.substring(start, this.pos));\n }\n\n readHexFloat(): f64 {\n throw new Error(\"not implemented\"); // TBD\n }\n\n readUnicodeEscape(): string {\n var remain = 4;\n var value = 0;\n var end = this.end;\n var text = this.source.text;\n while (this.pos < end) {\n let c = text.charCodeAt(this.pos++);\n if (c >= CharCode._0 && c <= CharCode._9) {\n value = (value << 4) + c - CharCode._0;\n } else if (c >= CharCode.A && c <= CharCode.F) {\n value = (value << 4) + c + (10 - CharCode.A);\n } else if (c >= CharCode.a && c <= CharCode.f) {\n value = (value << 4) + c + (10 - CharCode.a);\n } else {\n this.error(\n DiagnosticCode.Hexadecimal_digit_expected,\n this.range(this.pos - 1, this.pos)\n );\n return \"\";\n }\n if (--remain == 0) break;\n }\n if (remain) {\n this.error(\n DiagnosticCode.Unexpected_end_of_text,\n this.range(this.pos)\n );\n return \"\";\n }\n return String.fromCharCode(value);\n }\n\n private readExtendedUnicodeEscape(): string {\n var start = this.pos;\n var value = this.readHexInteger();\n var value32 = i64_low(value);\n var invalid = false;\n\n assert(!i64_high(value));\n if (value32 > 0x10FFFF) {\n this.error(\n DiagnosticCode.An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive,\n this.range(start, this.pos)\n );\n invalid = true;\n }\n\n var end = this.end;\n var text = this.source.text;\n if (this.pos >= end) {\n this.error(\n DiagnosticCode.Unexpected_end_of_text,\n this.range(start, end)\n );\n invalid = true;\n } else if (text.charCodeAt(this.pos) == CharCode.CLOSEBRACE) {\n ++this.pos;\n } else {\n this.error(\n DiagnosticCode.Unterminated_Unicode_escape_sequence,\n this.range(start, this.pos)\n );\n invalid = true;\n }\n\n if (invalid) return \"\";\n return value32 < 65536\n ? String.fromCharCode(value32)\n : String.fromCharCode(\n ((value32 - 65536) >>> 10) + 0xD800,\n ((value32 - 65536) & 1023) + 0xDC00\n );\n }\n\n finish(): void {\n }\n}\n\n/** Tokenizer state as returned by {@link Tokenizer#mark} and consumed by {@link Tokenizer#reset}. */\nexport class State {\n /** Current position. */\n pos: i32;\n /** Current token. */\n token: Token;\n /** Current token's position. */\n tokenPos: i32;\n}\n\n// Reusable state object to reduce allocations\nvar reusableState: State | null = null;\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","/**\n * Resolve infrastructure to obtain types and elements.\n * @module resolver\n *//***/\n\nimport {\n DiagnosticEmitter,\n DiagnosticCode\n} from \"./diagnostics\";\n\nimport {\n Program,\n ElementKind,\n OperatorKind,\n Element,\n Class,\n ClassPrototype,\n Function,\n FunctionPrototype,\n VariableLikeElement,\n Property,\n PropertyPrototype,\n Field,\n FieldPrototype,\n Global,\n TypeDefinition\n} from \"./program\";\n\nimport {\n FlowFlags,\n Flow\n} from \"./flow\";\n\nimport {\n FunctionTypeNode,\n ParameterKind,\n TypeNode,\n NodeKind,\n NamedTypeNode,\n TypeName,\n TypeParameterNode,\n Node,\n Range,\n IdentifierExpression,\n CallExpression,\n ElementAccessExpression,\n PropertyAccessExpression,\n LiteralExpression,\n LiteralKind,\n ParenthesizedExpression,\n AssertionExpression,\n Expression,\n IntegerLiteralExpression,\n UnaryPrefixExpression,\n UnaryPostfixExpression,\n AssertionKind,\n BinaryExpression,\n ThisExpression,\n SuperExpression,\n isTypeOmitted\n} from \"./ast\";\n\nimport {\n Type,\n Signature,\n typesToString,\n TypeKind,\n TypeFlags\n} from \"./types\";\n\nimport {\n CommonFlags,\n CommonSymbols\n} from \"./common\";\n\nimport {\n makeMap,\n isPowerOf2\n} from \"./util\";\n\nimport {\n Token\n} from \"./tokenizer\";\n\nimport {\n BuiltinSymbols\n} from \"./builtins\";\n\n/** Indicates whether errors are reported or not. */\nexport enum ReportMode {\n /** Report errors. */\n REPORT,\n /** Swallow errors. */\n SWALLOW\n}\n\n/** Provides tools to resolve types and expressions. */\nexport class Resolver extends DiagnosticEmitter {\n\n /** The program this resolver belongs to. */\n program: Program;\n\n /** Target expression of the previously resolved property or element access. */\n currentThisExpression: Expression | null = null;\n /** Element expression of the previously resolved element access. */\n currentElementExpression : Expression | null = null;\n\n /** Constructs the resolver for the specified program. */\n constructor(\n /** The program to construct a resolver for. */\n program: Program\n ) {\n super(program.diagnostics);\n this.program = program;\n }\n\n /** Resolves a {@link CommonTypeNode} to a concrete {@link Type}. */\n resolveType(\n /** The type to resolve. */\n node: TypeNode,\n /** Relative context. */\n context: Element,\n /** Type arguments inherited through context, i.e. `T`. */\n contextualTypeArguments: Map | null = null,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Type | null {\n\n // handle signature\n if (node.kind == NodeKind.FUNCTIONTYPE) {\n let explicitThisType = (node).explicitThisType;\n let thisType: Type | null = null;\n if (explicitThisType) {\n thisType = this.resolveType(\n explicitThisType,\n context,\n contextualTypeArguments,\n reportMode\n );\n if (!thisType) return null;\n }\n let parameterNodes = (node).parameters;\n let numParameters = parameterNodes.length;\n let parameterTypes = new Array(numParameters);\n let parameterNames = new Array(numParameters);\n let requiredParameters = 0;\n let hasRest = false;\n for (let i = 0; i < numParameters; ++i) {\n let parameterNode = parameterNodes[i];\n switch (parameterNode.parameterKind) {\n case ParameterKind.DEFAULT: {\n requiredParameters = i + 1;\n break;\n }\n case ParameterKind.REST: {\n assert(i == numParameters);\n hasRest = true;\n break;\n }\n }\n let parameterTypeNode = parameterNode.type;\n if (isTypeOmitted(parameterTypeNode)) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Type_expected,\n parameterTypeNode.range\n );\n }\n return null;\n }\n let parameterType = this.resolveType(\n parameterTypeNode,\n context,\n contextualTypeArguments,\n reportMode\n );\n if (!parameterType) return null;\n parameterTypes[i] = parameterType;\n parameterNames[i] = parameterNode.name.text;\n }\n let returnTypeNode = (node).returnType;\n if (isTypeOmitted(returnTypeNode)) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Type_expected,\n returnTypeNode.range\n );\n }\n return null;\n }\n let returnType: Type | null;\n if (returnTypeNode) {\n returnType = this.resolveType(\n returnTypeNode,\n context,\n contextualTypeArguments,\n reportMode\n );\n if (!returnType) return null;\n } else {\n returnType = Type.void;\n }\n let signature = new Signature(parameterTypes, returnType, thisType);\n signature.parameterNames = parameterNames;\n signature.requiredParameters = requiredParameters;\n signature.hasRest = hasRest;\n return node.isNullable ? signature.type.asNullable() : signature.type;\n }\n\n // now dealing with TypeNode\n assert(node.kind == NodeKind.NAMEDTYPE);\n var typeNode = node;\n var typeName = typeNode.name;\n var typeArgumentNodes = typeNode.typeArguments;\n var isSimpleType = !typeName.next;\n\n // look up in contextual type arguments if a simple type\n if (isSimpleType) {\n if (contextualTypeArguments && contextualTypeArguments.has(typeName.identifier.text)) {\n let type = contextualTypeArguments.get(typeName.identifier.text)!;\n if (typeArgumentNodes !== null && typeArgumentNodes.length) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Type_0_is_not_generic,\n node.range, type.toString()\n );\n }\n }\n if (node.isNullable) {\n if (!type.is(TypeFlags.REFERENCE)) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Basic_type_0_cannot_be_nullable,\n node.range, type.toString()\n );\n }\n }\n return type.asNullable();\n }\n return type;\n }\n }\n\n // look up in context\n var element = this.resolveTypeName(typeName, context, reportMode);\n if (!element) return null;\n\n // use shadow type if present (i.e. namespace sharing a type)\n if (element.shadowType) {\n element = element.shadowType;\n\n } else {\n // handle enums (become i32)\n if (element.kind == ElementKind.ENUM) {\n if (typeArgumentNodes !== null && typeArgumentNodes.length) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Type_0_is_not_generic,\n node.range, element.internalName\n );\n }\n }\n if (node.isNullable) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Basic_type_0_cannot_be_nullable,\n node.range, element.name\n );\n }\n }\n return Type.i32;\n }\n\n // handle classes\n if (element.kind == ElementKind.CLASS_PROTOTYPE) {\n let instance = this.resolveClassInclTypeArguments(\n element,\n typeArgumentNodes,\n context,\n makeMap(contextualTypeArguments), // don't inherit\n node\n ); // reports\n if (!instance) return null;\n return node.isNullable ? instance.type.asNullable() : instance.type;\n }\n }\n\n // handle type definitions\n if (element.kind == ElementKind.TYPEDEFINITION) {\n\n // shortcut already resolved (mostly builtins)\n if (element.is(CommonFlags.RESOLVED)) {\n if (typeArgumentNodes !== null && typeArgumentNodes.length) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Type_0_is_not_generic,\n node.range, element.internalName\n );\n }\n }\n let type = (element).type;\n if (node.isNullable) {\n if (!type.is(TypeFlags.REFERENCE)) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Basic_type_0_cannot_be_nullable,\n typeNode.name.range, typeName.identifier.text\n );\n }\n } else {\n return type.asNullable();\n }\n }\n return type;\n }\n\n // handle built-in types\n if (isSimpleType) {\n switch (typeName.identifier.symbol) {\n case CommonSymbols.native: return this.resolveBuiltinNativeType(typeNode, context, contextualTypeArguments, reportMode);\n case CommonSymbols.indexof: return this.resolveBuiltinIndexofType(typeNode, context, contextualTypeArguments, reportMode);\n case CommonSymbols.valueof: return this.resolveBuiltinValueofType(typeNode, context, contextualTypeArguments, reportMode);\n }\n }\n\n // resolve normally\n let typeParameterNodes = (element).typeParameterNodes;\n let typeArguments: Type[] | null = null;\n if (typeParameterNodes) {\n typeArguments = this.resolveTypeArguments(\n typeParameterNodes,\n typeArgumentNodes,\n context,\n contextualTypeArguments = makeMap(contextualTypeArguments), // inherit\n node,\n reportMode\n );\n if (!typeArguments) return null;\n } else if (typeArgumentNodes && typeArgumentNodes.length) {\n this.error(\n DiagnosticCode.Type_0_is_not_generic,\n typeNode.range, typeName.identifier.text\n );\n // recoverable\n }\n let type = this.resolveType(\n (element).typeNode,\n element,\n contextualTypeArguments,\n reportMode\n );\n if (!type) return null;\n if (node.isNullable) {\n if (!type.is(TypeFlags.REFERENCE)) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Basic_type_0_cannot_be_nullable,\n typeNode.name.range, typeName.identifier.text\n );\n }\n } else {\n return type.asNullable();\n }\n }\n return type;\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n typeNode.name.range, typeName.identifier.text\n );\n }\n return null;\n }\n\n private resolveBuiltinNativeType(\n /** The type to resolve. */\n typeNode: NamedTypeNode,\n /** Relative context. */\n context: Element,\n /** Type arguments inherited through context, i.e. `T`. */\n contextualTypeArguments: Map | null = null,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Type | null {\n var typeArgumentNodes = typeNode.typeArguments;\n if (!(typeArgumentNodes && typeArgumentNodes.length == 1)) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\n typeNode.range, \"1\", (typeArgumentNodes ? typeArgumentNodes.length : 1).toString(10)\n );\n }\n return null;\n }\n var typeArgument = this.resolveType(typeArgumentNodes[0], context, contextualTypeArguments, reportMode);\n if (!typeArgument) return null;\n switch (typeArgument.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32: return Type.i32;\n case TypeKind.ISIZE: if (!this.program.options.isWasm64) return Type.i32;\n case TypeKind.I64: return Type.i64;\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: return Type.u32;\n case TypeKind.USIZE: if (!this.program.options.isWasm64) return Type.u32;\n case TypeKind.U64: return Type.u64;\n case TypeKind.F32: return Type.f32;\n case TypeKind.F64: return Type.f64;\n case TypeKind.V128: return Type.v128;\n case TypeKind.VOID: return Type.void;\n default: assert(false);\n }\n return null;\n }\n\n private resolveBuiltinIndexofType(\n /** The type to resolve. */\n typeNode: NamedTypeNode,\n /** Relative context. */\n context: Element,\n /** Type arguments inherited through context, i.e. `T`. */\n contextualTypeArguments: Map | null = null,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Type | null {\n var typeArgumentNodes = typeNode.typeArguments;\n if (!(typeArgumentNodes && typeArgumentNodes.length == 1)) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\n typeNode.range, \"1\", (typeArgumentNodes ? typeArgumentNodes.length : 1).toString(10)\n );\n }\n return null;\n }\n var typeArgument = this.resolveType(typeArgumentNodes[0], context, contextualTypeArguments, reportMode);\n if (!typeArgument) return null;\n var classReference = typeArgument.classReference;\n if (!classReference) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Index_signature_is_missing_in_type_0,\n typeArgumentNodes[0].range, typeArgument.toString()\n );\n }\n return null;\n }\n var overload = classReference.lookupOverload(OperatorKind.INDEXED_GET);\n if (overload) {\n if (overload.is(CommonFlags.STATIC)) {\n assert(overload.signature.parameterTypes.length == 2);\n return overload.signature.parameterTypes[1];\n } else {\n assert(overload.signature.parameterTypes.length == 1);\n return overload.signature.parameterTypes[0];\n }\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Index_signature_is_missing_in_type_0,\n typeArgumentNodes[0].range, typeArgument.toString()\n );\n }\n return null;\n }\n\n private resolveBuiltinValueofType(\n /** The type to resolve. */\n typeNode: NamedTypeNode,\n /** Relative context. */\n context: Element,\n /** Type arguments inherited through context, i.e. `T`. */\n contextualTypeArguments: Map | null = null,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Type | null {\n var typeArgumentNodes = typeNode.typeArguments;\n if (!(typeArgumentNodes && typeArgumentNodes.length == 1)) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\n typeNode.range, \"1\", (typeArgumentNodes ? typeArgumentNodes.length : 1).toString(10)\n );\n }\n return null;\n }\n var typeArgument = this.resolveType(typeArgumentNodes[0], context, contextualTypeArguments, reportMode);\n if (!typeArgument) return null;\n var classReference = typeArgument.classReference;\n if (!classReference) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Index_signature_is_missing_in_type_0,\n typeArgumentNodes[0].range, typeArgument.toString()\n );\n }\n return null;\n }\n\n var overload = classReference.lookupOverload(OperatorKind.INDEXED_GET);\n if (overload) return overload.signature.returnType;\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Index_signature_is_missing_in_type_0,\n typeArgumentNodes[0].range, typeArgument.toString()\n );\n }\n return null;\n }\n\n /** Resolves a type name to the program element it refers to. */\n resolveTypeName(\n /** The type name to resolve. */\n typeName: TypeName,\n /** Relative context. */\n context: Element,\n /** How to proceed with eventualy diagnostics. */\n reportMode = ReportMode.REPORT\n ): Element | null {\n var element = context.lookup(typeName.identifier.text);\n if (!element) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n typeName.range, typeName.identifier.text\n );\n }\n return null;\n }\n var prev = typeName;\n var next = typeName.next;\n while (next) {\n if (!(element = element.lookupInSelf(next.identifier.text))) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\n next.range, next.identifier.text, prev.identifier.text\n );\n }\n return null;\n }\n prev = next;\n next = next.next;\n }\n return element;\n }\n\n /** Resolves an array of type arguments to concrete types. */\n resolveTypeArguments(\n /** Actual type parameter nodes. */\n typeParameters: TypeParameterNode[],\n /** Type arguments provided. */\n typeArgumentNodes: TypeNode[] | null,\n /** Relative context. */\n context: Element,\n /** Type arguments inherited through context, i.e. `T`. */\n contextualTypeArguments: Map = makeMap(),\n /** Alternative report node in case of empty type arguments. */\n alternativeReportNode: Node | null = null,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Type[] | null {\n var minParameterCount = 0;\n var maxParameterCount = 0;\n for (let i = 0, k = typeParameters.length; i < k; ++i) {\n if (!typeParameters[i].defaultType) ++minParameterCount;\n ++maxParameterCount;\n }\n var argumentCount = typeArgumentNodes ? typeArgumentNodes.length : 0;\n if (argumentCount < minParameterCount || argumentCount > maxParameterCount) {\n this.error(\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\n argumentCount\n ? Range.join(\n (typeArgumentNodes)[0].range,\n (typeArgumentNodes)[argumentCount - 1].range\n )\n : assert(alternativeReportNode).range,\n (argumentCount < minParameterCount ? minParameterCount : maxParameterCount).toString(10),\n argumentCount.toString(10)\n );\n return null;\n }\n var typeArguments = new Array(maxParameterCount);\n for (let i = 0; i < maxParameterCount; ++i) {\n let type = i < argumentCount\n ? this.resolveType( // reports\n (typeArgumentNodes)[i],\n context,\n contextualTypeArguments,\n reportMode\n )\n : this.resolveType( // reports\n assert(typeParameters[i].defaultType),\n context,\n contextualTypeArguments,\n reportMode\n );\n if (!type) return null;\n // TODO: check extendsType\n contextualTypeArguments.set(typeParameters[i].name.text, type);\n typeArguments[i] = type;\n }\n return typeArguments;\n }\n\n /** Resolves an identifier to the program element it refers to. */\n resolveIdentifier(\n /** The expression to resolve. */\n identifier: IdentifierExpression,\n /** Optional flow to search for scoped locals. */\n flow: Flow | null,\n /** Optional context to search. */\n context: Element | null,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n var name = identifier.text;\n var element: Element | null;\n if (flow) {\n if (element = flow.lookup(name)) {\n this.currentThisExpression = null;\n this.currentElementExpression = null;\n return element;\n }\n }\n if (context) {\n if (element = context.lookup(name)) {\n this.currentThisExpression = null;\n this.currentElementExpression = null;\n return element;\n }\n }\n if (element = this.program.lookupGlobal(name)) {\n this.currentThisExpression = null;\n this.currentElementExpression = null;\n return element;\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n identifier.range, name\n );\n }\n return null;\n }\n\n /** Resolves a lazily compiled global, i.e. a static class field. */\n ensureResolvedLazyGlobal(global: Global, reportMode: ReportMode = ReportMode.REPORT): bool {\n if (global.is(CommonFlags.RESOLVED)) return true;\n var typeNode = global.typeNode;\n if (!typeNode) return false;\n var type = this.resolveType( // reports\n typeNode,\n global.parent,\n null,\n reportMode\n );\n if (!type) return false;\n global.setType(type);\n return true;\n }\n\n /** Resolves a property access expression to the program element it refers to. */\n resolvePropertyAccessExpression(\n /** The expression to resolve. */\n propertyAccess: PropertyAccessExpression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n var targetExpression = propertyAccess.expression;\n var target = this.resolveExpression(targetExpression, flow, contextualType, reportMode); // reports\n if (!target) return null;\n var propertyName = propertyAccess.property.text;\n\n // Resolve variable-likes to their class type first\n switch (target.kind) {\n case ElementKind.GLOBAL: if (!this.ensureResolvedLazyGlobal(target, reportMode)) return null;\n case ElementKind.LOCAL:\n case ElementKind.FIELD: {\n let type = (target).type; assert(type != Type.void);\n let classReference = type.classReference;\n if (!classReference) {\n let typeClasses = this.program.typeClasses;\n if (!type.is(TypeFlags.REFERENCE) && typeClasses.has(type.kind)) {\n classReference = typeClasses.get(type.kind)!;\n } else {\n this.error(\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\n propertyAccess.property.range, propertyName, (target).type.toString()\n );\n return null;\n }\n }\n target = classReference;\n break;\n }\n case ElementKind.PROPERTY_PROTOTYPE: { // static\n let getterInstance = this.resolveFunction( // reports\n assert((target).getterPrototype), // must have a getter\n null,\n makeMap(),\n reportMode\n );\n if (!getterInstance) return null;\n let classReference = getterInstance.signature.returnType.classReference;\n if (!classReference) {\n this.error(\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\n propertyAccess.property.range, propertyName, getterInstance.signature.returnType.toString()\n );\n return null;\n }\n target = classReference;\n break;\n }\n case ElementKind.PROPERTY: { // instance\n let getterInstance = assert((target).getterInstance); // must have a getter\n let classReference = getterInstance.signature.returnType.classReference;\n if (!classReference) {\n this.error(\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\n propertyAccess.property.range, propertyName, getterInstance.signature.returnType.toString()\n );\n return null;\n }\n target = classReference;\n break;\n }\n case ElementKind.CLASS: { // property access on element access?\n let elementExpression = this.currentElementExpression;\n if (elementExpression) {\n // let arrayType = this.program.determineBuiltinArrayType(target);\n // if (!arrayType) {\n let indexedGet = (target).lookupOverload(OperatorKind.INDEXED_GET);\n if (!indexedGet) {\n this.error(\n DiagnosticCode.Index_signature_is_missing_in_type_0,\n elementExpression.range, (target).internalName\n );\n return null;\n }\n let arrayType = indexedGet.signature.returnType;\n\n // }\n let classReference = arrayType.classReference;\n if (!classReference) {\n let typeClasses = this.program.typeClasses;\n if (!arrayType.is(TypeFlags.REFERENCE) && typeClasses.has(arrayType.kind)) {\n classReference = typeClasses.get(arrayType.kind)!;\n } else {\n this.error(\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\n propertyAccess.property.range, propertyName, arrayType.toString()\n );\n return null;\n }\n }\n target = classReference;\n }\n break;\n }\n case ElementKind.FUNCTION_PROTOTYPE: { // function Symbol() + type Symbol = _Symbol\n let shadowType = target.shadowType;\n if (shadowType) {\n if (!shadowType.is(CommonFlags.RESOLVED)) {\n let resolvedType = this.resolveType(shadowType.typeNode, shadowType.parent, null, reportMode);\n if (resolvedType) shadowType.setType(resolvedType);\n }\n let classReference = shadowType.type.classReference;\n if (classReference) target = classReference.prototype;\n break;\n }\n }\n }\n\n // Look up the member within\n switch (target.kind) {\n case ElementKind.CLASS_PROTOTYPE:\n case ElementKind.CLASS: {\n do {\n let members = target.members;\n if (members && members.has(propertyName)) {\n this.currentThisExpression = targetExpression;\n this.currentElementExpression = null;\n return members.get(propertyName)!; // instance FIELD, static GLOBAL, FUNCTION_PROTOTYPE...\n }\n // traverse inherited static members on the base prototype if target is a class prototype\n if (target.kind == ElementKind.CLASS_PROTOTYPE) {\n if ((target).basePrototype) {\n target = (target).basePrototype;\n } else {\n break;\n }\n // traverse inherited instance members on the base class if target is a class instance\n } else if (target.kind == ElementKind.CLASS) {\n if ((target).base) {\n target = (target).base;\n } else {\n break;\n }\n } else {\n break;\n }\n } while (true);\n break;\n }\n default: { // enums or other namespace-like elements\n let members = target.members;\n if (members && members.has(propertyName)) {\n this.currentThisExpression = targetExpression;\n this.currentElementExpression = null;\n return members.get(propertyName)!; // static ENUMVALUE, static GLOBAL, static FUNCTION_PROTOTYPE...\n }\n break;\n }\n }\n\n this.error(\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\n propertyAccess.property.range, propertyName, target.internalName\n );\n return null;\n }\n\n /** Resolves an element access expression to the program element it refers to. */\n resolveElementAccessExpression(\n /** The expression to resolve. */\n elementAccess: ElementAccessExpression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n var targetExpression = elementAccess.expression;\n var target = this.resolveExpression(targetExpression, flow, contextualType, reportMode); // reports\n if (!target) return null;\n switch (target.kind) {\n case ElementKind.GLOBAL: if (!this.ensureResolvedLazyGlobal(target, reportMode)) return null;\n case ElementKind.LOCAL:\n case ElementKind.FIELD: {\n let type = (target).type;\n if (target = type.classReference) {\n this.currentThisExpression = targetExpression;\n this.currentElementExpression = elementAccess.elementExpression;\n return target;\n }\n break;\n }\n case ElementKind.CLASS: {\n // let arrayType = this.program.determineBuiltinArrayType(target);\n // if (!arrayType) {\n let indexedGet = (target).lookupOverload(OperatorKind.INDEXED_GET);\n if (!indexedGet) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Index_signature_is_missing_in_type_0,\n elementAccess.range, (target).internalName\n );\n }\n return null;\n }\n let arrayType = indexedGet.signature.returnType;\n // }\n if (targetExpression.kind == NodeKind.ELEMENTACCESS) { // nested element access\n if (target = arrayType.classReference) {\n this.currentThisExpression = targetExpression;\n this.currentElementExpression = elementAccess.elementExpression;\n return target;\n }\n return null;\n }\n this.currentThisExpression = targetExpression;\n this.currentElementExpression = elementAccess.elementExpression;\n return target;\n }\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n targetExpression.range\n );\n }\n return null;\n }\n\n /** Determines the final type of an integer literal given the specified contextual type. */\n determineIntegerLiteralType(\n /** Integer literal value. */\n intValue: I64,\n /** Current contextual type. */\n contextualType: Type\n ): Type {\n if (!contextualType.is(TypeFlags.REFERENCE)) {\n // compile to contextualType if matching\n switch (contextualType.kind) {\n case TypeKind.I8: {\n if (i64_is_i8(intValue)) return Type.i8;\n break;\n }\n case TypeKind.U8: {\n if (i64_is_u8(intValue)) return Type.u8;\n break;\n }\n case TypeKind.I16: {\n if (i64_is_i16(intValue)) return Type.i16;\n break;\n }\n case TypeKind.U16: {\n if (i64_is_u16(intValue)) return Type.u16;\n break;\n }\n case TypeKind.I32: {\n if (i64_is_i32(intValue)) return Type.i32;\n break;\n }\n case TypeKind.U32: {\n if (i64_is_u32(intValue)) return Type.u32;\n break;\n }\n case TypeKind.BOOL: {\n if (i64_is_bool(intValue)) return Type.bool;\n break;\n }\n case TypeKind.ISIZE: {\n if (!this.program.options.isWasm64) {\n if (i64_is_i32(intValue)) return Type.isize32;\n break;\n }\n return Type.isize64;\n }\n case TypeKind.USIZE: {\n if (!this.program.options.isWasm64) {\n if (i64_is_u32(intValue)) return Type.usize32;\n break;\n }\n return Type.usize64;\n }\n case TypeKind.I64: return Type.i64;\n case TypeKind.U64: return Type.u64;\n case TypeKind.F32: return Type.f32;\n case TypeKind.F64: return Type.f64;\n case TypeKind.VOID: break; // best fitting below\n default: assert(false);\n }\n }\n // otherwise compile to best fitting native type\n if (i64_is_i32(intValue)) return Type.i32;\n if (i64_is_u32(intValue)) return Type.u32;\n return Type.i64;\n }\n\n /** Resolves any expression to the program element it refers to. */\n resolveExpression(\n /** The expression to resolve. */\n expression: Expression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type = Type.void,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n while (expression.kind == NodeKind.PARENTHESIZED) { // simply skip\n expression = (expression).expression;\n }\n switch (expression.kind) {\n case NodeKind.ASSERTION: {\n return this.resolveAssertionExpression(\n expression,\n flow, contextualType, reportMode\n );\n }\n case NodeKind.UNARYPREFIX: {\n return this.resolveUnaryPrefixExpression(\n expression,\n flow, contextualType, reportMode\n );\n }\n case NodeKind.UNARYPOSTFIX: {\n return this.resolveUnaryPostfixExpression(\n expression,\n flow, contextualType, reportMode\n );\n }\n case NodeKind.BINARY: {\n return this.resolveBinaryExpression(\n expression,\n flow, contextualType, reportMode\n );\n }\n case NodeKind.THIS: {\n return this.resolveThisExpression(\n expression,\n flow, contextualType, reportMode\n );\n }\n case NodeKind.SUPER: {\n return this.resolveSuperExpression(\n expression,\n flow, contextualType, reportMode\n );\n }\n case NodeKind.IDENTIFIER: {\n return this.resolveIdentifier(\n expression,\n flow, flow.actualFunction, reportMode\n );\n }\n case NodeKind.LITERAL: {\n return this.resolveLiteralExpression(\n expression,\n flow, contextualType, reportMode\n );\n }\n case NodeKind.PROPERTYACCESS: {\n return this.resolvePropertyAccessExpression(\n expression,\n flow, contextualType, reportMode\n );\n }\n case NodeKind.ELEMENTACCESS: {\n return this.resolveElementAccessExpression(\n expression,\n flow, contextualType, reportMode\n );\n }\n case NodeKind.CALL: {\n return this.resolveCallExpression(\n expression,\n flow, contextualType, reportMode\n );\n }\n // TODO: everything else\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n }\n return null;\n }\n\n /** Resolves an assertion expression to the program element it refers to. */\n resolveAssertionExpression(\n /** The expression to resolve. */\n expression: AssertionExpression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type = Type.void,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n if (expression.assertionKind == AssertionKind.NONNULL) {\n return this.resolveExpression(\n expression.expression,\n flow,\n contextualType,\n reportMode\n );\n }\n var type = this.resolveType(\n assert(expression.toType), // must be set if not NONNULL\n flow.actualFunction,\n flow.contextualTypeArguments,\n reportMode\n );\n if (!type) return null;\n var element: Element | null = type.classReference;\n if (!element) {\n let signature = type.signatureReference;\n if (!signature) return null;\n element = signature.asFunctionTarget(this.program);\n }\n this.currentThisExpression = null;\n this.currentElementExpression = null;\n return element;\n }\n\n /** Resolves an unary prefix expression to the program element it refers to. */\n resolveUnaryPrefixExpression(\n /** The expression to resolve. */\n expression: UnaryPrefixExpression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type = Type.void,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n var operand = expression.operand;\n // TODO: operator overloads\n switch (expression.operator) {\n case Token.MINUS: {\n // implicitly negate if an integer literal to distinguish between i32/u32/i64\n if (operand.kind == NodeKind.LITERAL && (operand).literalKind == LiteralKind.INTEGER) {\n let type = this.determineIntegerLiteralType(\n i64_sub(i64_zero, (operand).value),\n contextualType\n );\n let typeClasses = this.program.typeClasses;\n return typeClasses.has(type.kind) ? typeClasses.get(type.kind)! : null;\n }\n return this.resolveExpression(\n operand,\n flow,\n contextualType,\n reportMode\n );\n }\n case Token.PLUS:\n case Token.PLUS_PLUS:\n case Token.MINUS_MINUS: {\n return this.resolveExpression(\n expression.operand,\n flow,\n contextualType,\n reportMode\n );\n }\n case Token.EXCLAMATION: {\n let typeClasses = this.program.typeClasses;\n return typeClasses.has(TypeKind.BOOL) ? typeClasses.get(TypeKind.BOOL)! : null;\n }\n case Token.TILDE: {\n let resolvedOperand = this.resolveExpression(\n expression.operand,\n flow,\n contextualType,\n reportMode\n );\n if (!resolvedOperand) return null;\n // TODO\n break;\n }\n default: assert(false);\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n }\n return null;\n }\n\n /** Resolves an unary postfix expression to the program element it refers to. */\n resolveUnaryPostfixExpression(\n /** The expression to resolve. */\n expression: UnaryPostfixExpression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type = Type.void,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n // TODO: operator overloads\n switch (expression.operator) {\n case Token.PLUS_PLUS:\n case Token.MINUS_MINUS: {\n return this.resolveExpression(\n expression.operand,\n flow,\n contextualType,\n reportMode\n );\n }\n default: assert(false);\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n }\n return null;\n }\n\n /** Resolves a binary expression to the program element it refers to. */\n resolveBinaryExpression(\n /** The expression to resolve. */\n expression: BinaryExpression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type = Type.void,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n // TODO\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n }\n return null;\n }\n\n /** Resolves a this expression to the program element it refers to. */\n resolveThisExpression(\n /** The expression to resolve. */\n expression: ThisExpression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type = Type.void,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n if (flow.is(FlowFlags.INLINE_CONTEXT)) {\n let thisLocal = flow.lookupLocal(CommonSymbols.this_);\n if (thisLocal) {\n this.currentThisExpression = null;\n this.currentElementExpression = null;\n return thisLocal;\n }\n }\n var parent = flow.actualFunction.parent;\n if (parent) {\n this.currentThisExpression = null;\n this.currentElementExpression = null;\n return parent;\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode._this_cannot_be_referenced_in_current_location,\n expression.range\n );\n }\n return null;\n }\n\n /** Resolves a super expression to the program element it refers to. */\n resolveSuperExpression(\n /** The expression to resolve. */\n expression: SuperExpression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type = Type.void,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n if (flow.is(FlowFlags.INLINE_CONTEXT)) {\n let superLocal = flow.lookupLocal(CommonSymbols.super_);\n if (superLocal) {\n this.currentThisExpression = null;\n this.currentElementExpression = null;\n return superLocal;\n }\n }\n var parent: Element | null = flow.actualFunction.parent;\n if (parent && parent.kind == ElementKind.CLASS && (parent = (parent).base)) {\n this.currentThisExpression = null;\n this.currentElementExpression = null;\n return parent;\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode._super_can_only_be_referenced_in_a_derived_class,\n expression.range\n );\n }\n return null;\n }\n\n /** Resolves a literal expression to the program element it refers to. */\n resolveLiteralExpression(\n /** The expression to resolve. */\n expression: LiteralExpression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type = Type.void,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n switch (expression.literalKind) {\n case LiteralKind.INTEGER: {\n this.currentThisExpression = expression;\n this.currentElementExpression = null;\n let literalType = this.determineIntegerLiteralType(\n (expression).value,\n contextualType\n );\n let typeClasses = this.program.typeClasses;\n return typeClasses.has(literalType.kind) ? typeClasses.get(literalType.kind)! : null;\n }\n case LiteralKind.FLOAT: {\n this.currentThisExpression = expression;\n this.currentElementExpression = null;\n let literalType = contextualType == Type.f32 ? Type.f32 : Type.f64;\n let typeClasses = this.program.typeClasses;\n return typeClasses.has(literalType.kind) ? typeClasses.get(literalType.kind)! : null;\n }\n case LiteralKind.STRING: {\n this.currentThisExpression = expression;\n this.currentElementExpression = null;\n return this.program.stringInstance;\n }\n // TODO\n // case LiteralKind.ARRAY:\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n }\n return null;\n }\n\n /** Resolves a call expression to the program element it refers to. */\n resolveCallExpression(\n /** The expression to resolve. */\n expression: CallExpression,\n /** Current flow. */\n flow: Flow,\n /** Current contextual type. */\n contextualType: Type = Type.void,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Element | null {\n var targetExpression = expression.expression;\n var target = this.resolveExpression( // reports\n targetExpression,\n flow,\n contextualType,\n reportMode\n );\n\n if (!target) return null;\n if (target.kind == ElementKind.FUNCTION_PROTOTYPE) {\n // `unchecked(expr: *): *` is special\n if (\n (target).internalName == BuiltinSymbols.unchecked &&\n expression.arguments.length > 0\n ) {\n return this.resolveExpression(expression.arguments[0], flow, contextualType, reportMode);\n }\n // otherwise resolve normally\n let instance = this.resolveFunctionInclTypeArguments(\n target,\n expression.typeArguments,\n flow.actualFunction,\n makeMap(flow.contextualTypeArguments), // don't inherit\n expression,\n reportMode\n );\n if (!instance) return null;\n let returnType = instance.signature.returnType;\n let classType = returnType.classReference;\n if (classType) {\n // reuse resolvedThisExpression (might be property access)\n // reuse resolvedElementExpression (might be element access)\n return classType;\n } else {\n let signature = returnType.signatureReference;\n if (signature) {\n let functionTarget = signature.asFunctionTarget(this.program);\n // reuse resolvedThisExpression (might be property access)\n // reuse resolvedElementExpression (might be element access)\n return functionTarget;\n } else {\n let typeClasses = this.program.typeClasses;\n if (!returnType.is(TypeFlags.REFERENCE) && typeClasses.has(returnType.kind)) {\n return typeClasses.get(returnType.kind);\n }\n }\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\n targetExpression.range, target.internalName\n );\n }\n return null;\n }\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n }\n return null;\n }\n\n /** Resolves a function prototype using the specified concrete type arguments. */\n resolveFunction(\n /** The prototype of the function. */\n prototype: FunctionPrototype,\n /** Concrete type arguments. */\n typeArguments: Type[] | null,\n /** Type arguments inherited through context, i.e. `T`. */\n contextualTypeArguments: Map = makeMap(),\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Function | null {\n var actualParent = prototype.parent.kind == ElementKind.PROPERTY_PROTOTYPE\n ? prototype.parent.parent\n : prototype.parent;\n var classInstance: Class | null = null; // if an instance method\n var instanceKey = typeArguments ? typesToString(typeArguments) : \"\";\n\n // Instance method prototypes are pre-bound to their concrete class as their parent\n if (prototype.is(CommonFlags.INSTANCE)) {\n assert(actualParent.kind == ElementKind.CLASS);\n classInstance = actualParent;\n\n // check if this exact concrete class and function combination is known already\n let resolvedInstance = prototype.getResolvedInstance(instanceKey);\n if (resolvedInstance) return resolvedInstance;\n\n // inherit class specific type arguments\n let classTypeArguments = classInstance.typeArguments;\n if (classTypeArguments) {\n let classTypeParameters = assert(classInstance.prototype.typeParameterNodes);\n let numClassTypeArguments = classTypeParameters.length;\n assert(numClassTypeArguments == classTypeParameters.length);\n for (let i = 0; i < numClassTypeArguments; ++i) {\n let classTypeParameterName = classTypeParameters[i].name.text;\n if (!contextualTypeArguments.has(classTypeParameterName)) {\n contextualTypeArguments.set(\n classTypeParameterName,\n classTypeArguments[i]\n );\n }\n }\n }\n } else {\n assert(actualParent.kind != ElementKind.CLASS); // must not be pre-bound\n let resolvedInstance = prototype.getResolvedInstance(instanceKey);\n if (resolvedInstance) return resolvedInstance;\n }\n\n // override whatever is contextual with actual function type arguments\n var signatureNode = prototype.functionTypeNode;\n var typeParameterNodes = prototype.typeParameterNodes;\n var numFunctionTypeArguments: i32;\n if (typeArguments && (numFunctionTypeArguments = typeArguments.length)) {\n assert(typeParameterNodes && numFunctionTypeArguments == typeParameterNodes.length);\n for (let i = 0; i < numFunctionTypeArguments; ++i) {\n contextualTypeArguments.set(\n (typeParameterNodes)[i].name.text,\n typeArguments[i]\n );\n }\n } else {\n assert(!typeParameterNodes || typeParameterNodes.length == 0);\n }\n\n // resolve `this` type if applicable\n var thisType: Type | null = null;\n var explicitThisType = signatureNode.explicitThisType;\n if (explicitThisType) {\n thisType = this.resolveType(\n explicitThisType,\n prototype.parent, // relative to function\n contextualTypeArguments,\n reportMode\n );\n if (!thisType) return null;\n contextualTypeArguments.set(CommonSymbols.this_, thisType);\n } else if (classInstance) {\n thisType = classInstance.type;\n contextualTypeArguments.set(CommonSymbols.this_, thisType);\n }\n\n // resolve parameter types\n var signatureParameters = signatureNode.parameters;\n var numSignatureParameters = signatureParameters.length;\n var parameterTypes = new Array(numSignatureParameters);\n var parameterNames = new Array(numSignatureParameters);\n var requiredParameters = 0;\n for (let i = 0; i < numSignatureParameters; ++i) {\n let parameterDeclaration = signatureParameters[i];\n if (parameterDeclaration.parameterKind == ParameterKind.DEFAULT) {\n requiredParameters = i + 1;\n }\n let typeNode = parameterDeclaration.type;\n if (isTypeOmitted(typeNode)) {\n this.error(\n DiagnosticCode.Type_expected,\n typeNode.range\n );\n return null;\n }\n let parameterType = this.resolveType(\n typeNode,\n prototype.parent, // relative to function\n contextualTypeArguments,\n reportMode\n );\n if (!parameterType) return null;\n parameterTypes[i] = parameterType;\n parameterNames[i] = parameterDeclaration.name.text;\n }\n\n // resolve return type\n var returnType: Type;\n if (prototype.is(CommonFlags.SET)) {\n returnType = Type.void; // not annotated\n } else if (prototype.is(CommonFlags.CONSTRUCTOR)) {\n returnType = assert(classInstance).type; // not annotated\n } else {\n let typeNode = signatureNode.returnType;\n if (isTypeOmitted(typeNode)) {\n this.error(\n DiagnosticCode.Type_expected,\n typeNode.range\n );\n return null;\n }\n let type = this.resolveType(\n typeNode,\n prototype.parent, // relative to function\n contextualTypeArguments,\n reportMode\n );\n if (!type) return null;\n returnType = type;\n }\n\n var signature = new Signature(parameterTypes, returnType, thisType);\n signature.parameterNames = parameterNames;\n signature.requiredParameters = requiredParameters;\n\n var nameInclTypeParameters = prototype.name;\n if (instanceKey.length) nameInclTypeParameters += \"<\" + instanceKey + \">\";\n var instance = new Function(\n nameInclTypeParameters,\n prototype,\n signature,\n contextualTypeArguments\n );\n prototype.setResolvedInstance(instanceKey, instance);\n return instance;\n }\n\n /** Resolves a function prototypeby first resolving the specified type arguments. */\n resolveFunctionInclTypeArguments(\n /** The prototype of the function. */\n prototype: FunctionPrototype,\n /** Type arguments provided. */\n typeArgumentNodes: TypeNode[] | null,\n /** Relative context. Type arguments are resolved from here. */\n context: Element,\n /** Type arguments inherited through context, i.e. `T`. */\n contextualTypeArguments: Map,\n /** The node to use when reporting intermediate errors. */\n reportNode: Node,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Function | null {\n var actualParent = prototype.parent.kind == ElementKind.PROPERTY_PROTOTYPE\n ? prototype.parent.parent\n : prototype.parent;\n var resolvedTypeArguments: Type[] | null = null;\n\n // Resolve type arguments if generic\n if (prototype.is(CommonFlags.GENERIC)) {\n\n // If this is an instance method, first apply the class's type arguments\n if (prototype.is(CommonFlags.INSTANCE)) {\n assert(actualParent.kind == ElementKind.CLASS);\n let classTypeArguments = (actualParent).typeArguments;\n if (classTypeArguments) {\n let typeParameterNodes = assert((actualParent).prototype.typeParameterNodes);\n let numClassTypeArguments = classTypeArguments.length;\n assert(numClassTypeArguments == typeParameterNodes.length);\n for (let i = 0; i < numClassTypeArguments; ++i) {\n contextualTypeArguments.set(\n typeParameterNodes[i].name.text,\n classTypeArguments[i]\n );\n }\n }\n }\n\n resolvedTypeArguments = this.resolveTypeArguments( // reports\n assert(prototype.typeParameterNodes),\n typeArgumentNodes,\n context,\n contextualTypeArguments,\n reportNode,\n reportMode\n );\n if (!resolvedTypeArguments) return null;\n\n // Otherwise make sure that no type arguments have been specified\n } else {\n if (typeArgumentNodes !== null && typeArgumentNodes.length) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Type_0_is_not_generic,\n reportNode.range, prototype.internalName\n );\n }\n return null;\n }\n }\n\n // Continue with concrete types\n return this.resolveFunction(\n prototype,\n resolvedTypeArguments,\n contextualTypeArguments,\n reportMode\n );\n }\n\n /** Resolves a class prototype using the specified concrete type arguments. */\n resolveClass(\n /** The prototype of the class. */\n prototype: ClassPrototype,\n /** Concrete type arguments. */\n typeArguments: Type[] | null,\n /** Type arguments inherited through context, i.e. `T`. */\n contextualTypeArguments: Map = makeMap(),\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Class | null {\n var instanceKey = typeArguments ? typesToString(typeArguments) : \"\";\n\n // Check if this exact instance has already been resolved\n var instance = prototype.getResolvedInstance(instanceKey);\n if (instance) return instance;\n\n // Insert contextual type arguments for this operation. Internally, this method is always\n // called with matching type parameter / argument counts.\n if (typeArguments) {\n let typeParameterNodes = assert(prototype.typeParameterNodes);\n let numTypeParameters = typeParameterNodes.length;\n let numTypeArguments = typeArguments.length;\n assert(numTypeArguments == numTypeParameters);\n for (let i = 0; i < numTypeArguments; ++i) {\n contextualTypeArguments.set(typeParameterNodes[i].name.text, typeArguments[i]);\n }\n } else {\n let typeParameterNodes = prototype.typeParameterNodes;\n assert(!(typeParameterNodes && typeParameterNodes.length));\n }\n\n // Resolve base class if applicable\n var basePrototype = prototype.basePrototype;\n var baseClass: Class | null = null;\n if (basePrototype) {\n let extendsNode = assert(prototype.extendsNode); // must be present if it has a base prototype\n baseClass = this.resolveClassInclTypeArguments(\n basePrototype,\n extendsNode.typeArguments,\n prototype.parent, // relative to derived class\n makeMap(contextualTypeArguments), // don't inherit\n extendsNode,\n reportMode\n );\n if (!baseClass) return null;\n }\n\n // Construct the instance and remember that it has been resolved already\n var nameInclTypeParamters = prototype.name;\n if (instanceKey.length) nameInclTypeParamters += \"<\" + instanceKey + \">\";\n instance = new Class(nameInclTypeParamters, prototype, typeArguments, baseClass);\n instance.contextualTypeArguments = contextualTypeArguments;\n prototype.setResolvedInstance(instanceKey, instance);\n\n // Inherit base class members and set up the initial memory offset for own fields\n var memoryOffset: u32 = 0;\n if (baseClass) {\n let baseMembers = baseClass.members;\n if (baseMembers) {\n let instanceMembers = instance.members;\n if (!instanceMembers) instance.members = instanceMembers = new Map();\n for (let [baseMemberName, baseMember] of baseMembers) {\n instanceMembers.set(baseMemberName, baseMember);\n }\n }\n memoryOffset = baseClass.currentMemoryOffset;\n }\n\n // Resolve instance members\n var instanceMemberPrototypes = prototype.instanceMembers;\n if (instanceMemberPrototypes) {\n for (let member of instanceMemberPrototypes.values()) {\n switch (member.kind) {\n\n // Lay out fields in advance\n case ElementKind.FIELD_PROTOTYPE: {\n let instanceMembers = instance.members;\n if (!instanceMembers) instance.members = instanceMembers = new Map();\n else if (instanceMembers.has(member.name)) {\n this.error(\n DiagnosticCode.Duplicate_identifier_0,\n (member).identifierNode.range,\n member.name\n );\n break;\n }\n let fieldTypeNode = (member).typeNode;\n let fieldType: Type | null = null;\n // TODO: handle duplicate non-private fields specifically?\n if (!fieldTypeNode) {\n if (baseClass) {\n let baseMembers = baseClass.members;\n if (baseMembers && baseMembers.has((member).name)) {\n let baseField = baseMembers.get((member).name)!;\n if (!baseField.is(CommonFlags.PRIVATE)) {\n assert(baseField.kind == ElementKind.FIELD);\n fieldType = (baseField).type;\n }\n }\n }\n if (!fieldType) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Type_expected,\n (member).identifierNode.range.atEnd\n );\n }\n }\n } else {\n fieldType = this.resolveType(\n fieldTypeNode,\n prototype.parent, // relative to class\n instance.contextualTypeArguments,\n reportMode\n );\n }\n if (!fieldType) break; // did report above\n let fieldInstance = new Field(member, instance, fieldType);\n assert(isPowerOf2(fieldType.byteSize));\n let mask = fieldType.byteSize - 1;\n if (memoryOffset & mask) memoryOffset = (memoryOffset | mask) + 1;\n fieldInstance.memoryOffset = memoryOffset;\n memoryOffset += fieldType.byteSize;\n instance.add(member.name, fieldInstance); // reports\n break;\n }\n case ElementKind.FUNCTION_PROTOTYPE: {\n let boundPrototype = (member).toBound(instance);\n instance.add(boundPrototype.name, boundPrototype); // reports\n break;\n }\n case ElementKind.PROPERTY_PROTOTYPE: {\n let propertyInstance = new Property(member, instance);\n let getterPrototype = (member).getterPrototype;\n if (getterPrototype) {\n let getterInstance = this.resolveFunction(\n getterPrototype.toBound(instance),\n null,\n makeMap(instance.contextualTypeArguments),\n reportMode\n );\n if (getterInstance) {\n propertyInstance.getterInstance = getterInstance;\n propertyInstance.setType(getterInstance.signature.returnType);\n }\n }\n let setterPrototype = (member).setterPrototype;\n if (setterPrototype) {\n let setterInstance = this.resolveFunction(\n setterPrototype.toBound(instance),\n null,\n makeMap(instance.contextualTypeArguments),\n reportMode\n );\n if (setterInstance) {\n propertyInstance.setterInstance = setterInstance;\n if (!propertyInstance.is(CommonFlags.RESOLVED)) {\n assert(setterInstance.signature.parameterTypes.length == 1);\n propertyInstance.setType(setterInstance.signature.parameterTypes[0]);\n }\n }\n }\n instance.add(propertyInstance.name, propertyInstance); // reports\n break;\n }\n default: assert(false);\n }\n }\n }\n\n // Finalize memory offset\n instance.currentMemoryOffset = memoryOffset;\n\n // Link _own_ constructor if present\n {\n let ctorPrototype = instance.lookupInSelf(CommonSymbols.constructor);\n if (ctorPrototype && ctorPrototype.parent === instance) {\n assert(ctorPrototype.kind == ElementKind.FUNCTION_PROTOTYPE);\n let ctorInstance = this.resolveFunction(\n ctorPrototype,\n null,\n instance.contextualTypeArguments,\n reportMode\n );\n if (ctorInstance) instance.constructorInstance = ctorInstance;\n }\n }\n\n // Fully resolve operator overloads (don't have type parameters on their own)\n for (let [kind, overloadPrototype] of prototype.overloadPrototypes) {\n assert(kind != OperatorKind.INVALID);\n let operatorInstance: Function | null;\n if (overloadPrototype.is(CommonFlags.INSTANCE)) {\n let boundPrototype = overloadPrototype.toBound(instance);\n operatorInstance = this.resolveFunction(\n boundPrototype,\n null,\n makeMap(),\n reportMode\n );\n } else {\n operatorInstance = this.resolveFunction(\n overloadPrototype,\n null,\n makeMap(),\n reportMode\n );\n }\n if (!operatorInstance) continue;\n let overloads = instance.overloads;\n if (!overloads) instance.overloads = overloads = new Map();\n overloads.set(kind, operatorInstance);\n }\n return instance;\n }\n\n /** Resolves a class prototype by first resolving the specified type arguments. */\n resolveClassInclTypeArguments(\n /** The prototype of the class. */\n prototype: ClassPrototype,\n /** Type argument nodes provided. */\n typeArgumentNodes: TypeNode[] | null,\n /** Relative context. Type arguments are resolved from here. */\n context: Element,\n /** Type arguments inherited through context, i.e. `T`. */\n contextualTypeArguments: Map,\n /** The node to use when reporting intermediate errors. */\n reportNode: Node,\n /** How to proceed with eventualy diagnostics. */\n reportMode: ReportMode = ReportMode.REPORT\n ): Class | null {\n var resolvedTypeArguments: Type[] | null = null;\n\n // Resolve type arguments if generic\n if (prototype.is(CommonFlags.GENERIC)) {\n resolvedTypeArguments = this.resolveTypeArguments( // reports\n assert(prototype.typeParameterNodes), // must be present if generic\n typeArgumentNodes,\n context,\n contextualTypeArguments,\n reportNode,\n reportMode\n );\n if (!resolvedTypeArguments) return null;\n\n // Otherwise make sure that no type arguments have been specified\n } else {\n if (typeArgumentNodes !== null && typeArgumentNodes.length) {\n if (reportMode == ReportMode.REPORT) {\n this.error(\n DiagnosticCode.Type_0_is_not_generic,\n reportNode.range, prototype.internalName\n );\n }\n return null;\n }\n }\n\n // Continue with concrete types\n return this.resolveClass(\n prototype,\n resolvedTypeArguments,\n contextualTypeArguments,\n reportMode\n );\n }\n}\n","/**\n * A control flow analyzer.\n * @module flow\n *//***/\n\nimport {\n Type,\n TypeFlags,\n TypeKind\n} from \"./types\";\n\nimport {\n Local,\n Function,\n Element,\n ElementKind,\n Global\n} from \"./program\";\n\nimport {\n NativeType,\n ExpressionId,\n ExpressionRef,\n\n getExpressionId,\n getLocalGetIndex,\n isLocalTee,\n getLocalSetValue,\n getGlobalGetName,\n getBinaryOp,\n BinaryOp,\n getBinaryLeft,\n getConstValueI32,\n getBinaryRight,\n getUnaryOp,\n UnaryOp,\n getExpressionType,\n getConstValueI64Low,\n getConstValueF32,\n getConstValueF64,\n getLoadBytes,\n isLoadSigned,\n getBlockName,\n getBlockChildCount,\n getBlockChild,\n getIfTrue,\n getIfFalse,\n getSelectThen,\n getSelectElse,\n getCallTarget,\n getLocalSetIndex,\n getIfCondition,\n getConstValueI64High,\n getUnaryValue,\n getCallOperand,\n traverse\n} from \"./module\";\n\nimport {\n CommonFlags\n} from \"./common\";\n\nimport {\n DiagnosticCode\n} from \"./diagnostics\";\n\nimport {\n Node\n} from \"./ast\";\n\n/** Control flow flags indicating specific conditions. */\nexport const enum FlowFlags {\n /** No specific conditions. */\n NONE = 0,\n\n // categorical\n\n /** This flow returns. */\n RETURNS = 1 << 0,\n /** This flow returns a wrapped value. */\n RETURNS_WRAPPED = 1 << 1,\n /** This flow returns a non-null value. */\n RETURNS_NONNULL = 1 << 2,\n /** This flow throws. */\n THROWS = 1 << 3,\n /** This flow breaks. */\n BREAKS = 1 << 4,\n /** This flow continues. */\n CONTINUES = 1 << 5,\n /** This flow allocates. Constructors only. */\n ALLOCATES = 1 << 6,\n /** This flow calls super. Constructors only. */\n CALLS_SUPER = 1 << 7,\n /** This flow terminates (returns, throws or continues). */\n TERMINATES = 1 << 8,\n\n // conditional\n\n /** This flow conditionally returns in a child flow. */\n CONDITIONALLY_RETURNS = 1 << 9,\n /** This flow conditionally throws in a child flow. */\n CONDITIONALLY_THROWS = 1 << 10,\n /** This flow conditionally terminates in a child flow. */\n CONDITIONALLY_TERMINATES = 1 << 11,\n /** This flow conditionally breaks in a child flow. */\n CONDITIONALLY_BREAKS = 1 << 12,\n /** This flow conditionally continues in a child flow. */\n CONDITIONALLY_CONTINUES = 1 << 13,\n /** This flow conditionally allocates in a child flow. Constructors only. */\n CONDITIONALLY_ALLOCATES = 1 << 14,\n\n // special\n\n /** This is an inlining flow. */\n INLINE_CONTEXT = 1 << 15,\n /** This is a flow with explicitly disabled bounds checking. */\n UNCHECKED_CONTEXT = 1 << 16,\n\n // masks\n\n /** Any categorical flag. */\n ANY_CATEGORICAL = FlowFlags.RETURNS\n | FlowFlags.RETURNS_WRAPPED\n | FlowFlags.RETURNS_NONNULL\n | FlowFlags.THROWS\n | FlowFlags.BREAKS\n | FlowFlags.CONTINUES\n | FlowFlags.ALLOCATES\n | FlowFlags.CALLS_SUPER\n | FlowFlags.TERMINATES,\n\n /** Any conditional flag. */\n ANY_CONDITIONAL = FlowFlags.CONDITIONALLY_RETURNS\n | FlowFlags.CONDITIONALLY_THROWS\n | FlowFlags.CONDITIONALLY_BREAKS\n | FlowFlags.CONDITIONALLY_CONTINUES\n | FlowFlags.CONDITIONALLY_ALLOCATES\n}\n\n/** Flags indicating the current state of a local. */\nexport enum LocalFlags {\n /** No specific conditions. */\n NONE = 0,\n\n /** Local is constant. */\n CONSTANT = 1 << 0,\n /** Local is properly wrapped. Relevant for small integers. */\n WRAPPED = 1 << 1,\n /** Local is non-null. */\n NONNULL = 1 << 2,\n /** Local is read from. */\n READFROM = 1 << 3,\n /** Local is written to. */\n WRITTENTO = 1 << 4,\n /** Local is retained. */\n RETAINED = 1 << 5,\n\n /** Local is conditionally read from. */\n CONDITIONALLY_READFROM = 1 << 6,\n /** Local is conditionally written to. */\n CONDITIONALLY_WRITTENTO = 1 << 7,\n /** Local must be conditionally retained. */\n CONDITIONALLY_RETAINED = 1 << 8,\n\n /** Any categorical flag. */\n ANY_CATEGORICAL = CONSTANT\n | WRAPPED\n | NONNULL\n | READFROM\n | WRITTENTO\n | RETAINED,\n\n /** Any conditional flag. */\n ANY_CONDITIONAL = RETAINED\n | CONDITIONALLY_READFROM\n | CONDITIONALLY_WRITTENTO\n | CONDITIONALLY_RETAINED,\n\n /** Any retained flag. */\n ANY_RETAINED = RETAINED\n | CONDITIONALLY_RETAINED\n}\nexport namespace LocalFlags {\n export function join(left: LocalFlags, right: LocalFlags): LocalFlags {\n return ((left & LocalFlags.ANY_CATEGORICAL) & (right & LocalFlags.ANY_CATEGORICAL))\n | (left & LocalFlags.ANY_CONDITIONAL) | (right & LocalFlags.ANY_CONDITIONAL);\n }\n}\n\n/** Flags indicating the current state of a field. */\nexport enum FieldFlags {\n /** No specific conditions. */\n NONE = 0,\n\n /** Field is initialized. Relevant in constructors. */\n INITIALIZED = 1 << 0,\n /** Field is conditionally initialized. Relevant in constructors. */\n CONDITIONALLY_INITIALIZED = 1 << 1,\n\n /** Any categorical flag. */\n ANY_CATEGORICAL = INITIALIZED,\n\n /** Any conditional flag. */\n ANY_CONDITIONAL = CONDITIONALLY_INITIALIZED\n}\nexport namespace FieldFlags {\n export function join(left: FieldFlags, right: FieldFlags): FieldFlags {\n return ((left & FieldFlags.ANY_CATEGORICAL) & (right & FieldFlags.ANY_CATEGORICAL))\n | (left & FieldFlags.ANY_CONDITIONAL) | (right & FieldFlags.ANY_CONDITIONAL);\n }\n}\n\n/** A control flow evaluator. */\nexport class Flow {\n\n /** Parent flow. */\n parent: Flow | null;\n /** Flow flags indicating specific conditions. */\n flags: FlowFlags;\n /** Function this flow belongs to. */\n parentFunction: Function;\n /** The label we break to when encountering a continue statement. */\n continueLabel: string | null;\n /** The label we break to when encountering a break statement. */\n breakLabel: string | null;\n /** The current return type. */\n returnType: Type;\n /** The current contextual type arguments. */\n contextualTypeArguments: Map | null;\n /** Scoped local variables. */\n scopedLocals: Map | null = null;\n /** Local flags. */\n localFlags: LocalFlags[];\n /** Field flags. Relevant in constructors. */\n fieldFlags: Map | null = null;\n /** Function being inlined, when inlining. */\n inlineFunction: Function | null;\n /** The label we break to when encountering a return statement, when inlining. */\n inlineReturnLabel: string | null;\n\n /** Creates the parent flow of the specified function. */\n static create(parentFunction: Function): Flow {\n var flow = new Flow();\n flow.parent = null;\n flow.flags = FlowFlags.NONE;\n flow.parentFunction = parentFunction;\n flow.continueLabel = null;\n flow.breakLabel = null;\n flow.returnType = parentFunction.signature.returnType;\n flow.contextualTypeArguments = parentFunction.contextualTypeArguments;\n flow.localFlags = [];\n flow.inlineFunction = null;\n flow.inlineReturnLabel = null;\n return flow;\n }\n\n /** Creates an inline flow within `parentFunction`. */\n static createInline(parentFunction: Function, inlineFunction: Function): Flow {\n var flow = Flow.create(parentFunction);\n flow.set(FlowFlags.INLINE_CONTEXT);\n flow.inlineFunction = inlineFunction;\n flow.inlineReturnLabel = inlineFunction.internalName + \"|inlined.\" + (inlineFunction.nextInlineId++).toString(10);\n flow.returnType = inlineFunction.signature.returnType;\n flow.contextualTypeArguments = inlineFunction.contextualTypeArguments;\n return flow;\n }\n\n private constructor() { }\n\n /** Gets the actual function being compiled, The inlined function when inlining, otherwise the parent function. */\n get actualFunction(): Function {\n return this.inlineFunction || this.parentFunction;\n }\n\n /** Tests if this flow has the specified flag or flags. */\n is(flag: FlowFlags): bool { return (this.flags & flag) == flag; }\n /** Tests if this flow has one of the specified flags. */\n isAny(flag: FlowFlags): bool { return (this.flags & flag) != 0; }\n /** Sets the specified flag or flags. */\n set(flag: FlowFlags): void { this.flags |= flag; }\n /** Unsets the specified flag or flags. */\n unset(flag: FlowFlags): void { this.flags &= ~flag; }\n\n /** Forks this flow to a child flow. */\n fork(): Flow {\n var branch = new Flow();\n branch.parent = this;\n branch.flags = this.flags;\n branch.parentFunction = this.parentFunction;\n branch.continueLabel = this.continueLabel;\n branch.breakLabel = this.breakLabel;\n branch.returnType = this.returnType;\n branch.contextualTypeArguments = this.contextualTypeArguments;\n branch.localFlags = this.localFlags.slice();\n branch.inlineFunction = this.inlineFunction;\n branch.inlineReturnLabel = this.inlineReturnLabel;\n return branch;\n }\n\n /** Gets a free temporary local of the specified type. */\n getTempLocal(type: Type, except: Set | null = null): Local {\n var parentFunction = this.parentFunction;\n var temps: Local[] | null;\n switch (type.toNativeType()) {\n case NativeType.I32: { temps = parentFunction.tempI32s; break; }\n case NativeType.I64: { temps = parentFunction.tempI64s; break; }\n case NativeType.F32: { temps = parentFunction.tempF32s; break; }\n case NativeType.F64: { temps = parentFunction.tempF64s; break; }\n case NativeType.V128: { temps = parentFunction.tempV128s; break; }\n default: throw new Error(\"concrete type expected\");\n }\n var local: Local;\n if (except) {\n if (temps && temps.length) {\n for (let i = 0, k = temps.length; i < k; ++i) {\n if (!except.has(temps[i].index)) {\n local = temps[i];\n let k = temps.length - 1;\n while (i < k) unchecked(temps[i] = temps[i++ + 1]);\n temps.length = k;\n local.type = type;\n local.flags = CommonFlags.NONE;\n this.unsetLocalFlag(local.index, ~0);\n return local;\n }\n }\n }\n local = parentFunction.addLocal(type);\n } else {\n if (temps && temps.length) {\n local = temps.pop();\n local.type = type;\n local.flags = CommonFlags.NONE;\n } else {\n local = parentFunction.addLocal(type);\n }\n }\n this.unsetLocalFlag(local.index, ~0);\n return local;\n }\n\n /** Gets a local that sticks around until this flow is exited, and then released. */\n getAutoreleaseLocal(type: Type, except: Set | null = null): Local {\n var local = this.getTempLocal(type, except);\n local.set(CommonFlags.SCOPED);\n var scopedLocals = this.scopedLocals;\n if (!scopedLocals) this.scopedLocals = scopedLocals = new Map();\n scopedLocals.set(\"~auto\" + (this.parentFunction.nextAutoreleaseId++), local);\n this.setLocalFlag(local.index, LocalFlags.RETAINED);\n return local;\n }\n\n /** Frees the temporary local for reuse. */\n freeTempLocal(local: Local): void {\n if (local.is(CommonFlags.INLINED)) return;\n assert(local.index >= 0);\n var parentFunction = this.parentFunction;\n var temps: Local[];\n assert(local.type != null); // internal error\n switch ((local.type).toNativeType()) {\n case NativeType.I32: {\n temps = parentFunction.tempI32s || (parentFunction.tempI32s = []);\n break;\n }\n case NativeType.I64: {\n temps = parentFunction.tempI64s || (parentFunction.tempI64s = []);\n break;\n }\n case NativeType.F32: {\n temps = parentFunction.tempF32s || (parentFunction.tempF32s = []);\n break;\n }\n case NativeType.F64: {\n temps = parentFunction.tempF64s || (parentFunction.tempF64s = []);\n break;\n }\n case NativeType.V128: {\n temps = parentFunction.tempV128s || (parentFunction.tempV128s = []);\n break;\n }\n default: throw new Error(\"concrete type expected\");\n }\n assert(local.index >= 0);\n temps.push(local);\n }\n\n /** Gets and immediately frees a temporary local of the specified type. */\n getAndFreeTempLocal(type: Type, except: Set | null = null): Local {\n var local = this.getTempLocal(type, except);\n this.freeTempLocal(local);\n return local;\n }\n\n /** Gets the scoped local of the specified name. */\n getScopedLocal(name: string): Local | null {\n var scopedLocals = this.scopedLocals;\n if (scopedLocals && scopedLocals.has(name)) return scopedLocals.get(name);\n return null;\n }\n\n /** Adds a new scoped local of the specified name. */\n addScopedLocal(name: string, type: Type, except: Set | null = null): Local {\n var scopedLocal = this.getTempLocal(type, except);\n var scopedLocals = this.scopedLocals;\n if (!scopedLocals) this.scopedLocals = scopedLocals = new Map();\n else assert(!scopedLocals.has(name));\n scopedLocal.set(CommonFlags.SCOPED);\n scopedLocals.set(name, scopedLocal);\n return scopedLocal;\n }\n\n /** Adds a new scoped alias for the specified local. For example `super` aliased to the `this` local. */\n addScopedAlias(name: string, type: Type, index: i32, reportNode: Node | null = null): Local {\n if (!this.scopedLocals) this.scopedLocals = new Map();\n else {\n let existingLocal = this.scopedLocals.get(name);\n if (existingLocal) {\n if (reportNode) {\n this.parentFunction.program.error(\n DiagnosticCode.Duplicate_identifier_0,\n reportNode.range\n );\n }\n return existingLocal;\n }\n }\n assert(index < this.parentFunction.localsByIndex.length);\n var scopedAlias = new Local(name, index, type, this.parentFunction);\n // not flagged as SCOPED as it must not be free'd when the flow is finalized\n this.scopedLocals.set(name, scopedAlias);\n return scopedAlias;\n }\n\n /** Frees this flow's scoped variables and returns its parent flow. */\n freeScopedLocals(): void {\n if (this.scopedLocals) {\n for (let scopedLocal of this.scopedLocals.values()) {\n if (scopedLocal.is(CommonFlags.SCOPED)) { // otherwise an alias\n this.freeTempLocal(scopedLocal);\n }\n }\n this.scopedLocals = null;\n }\n }\n\n /** Looks up the local of the specified name in the current scope. */\n lookupLocal(name: string): Local | null {\n var current: Flow | null = this;\n var scope: Map | null;\n do if ((scope = current.scopedLocals) && (scope.has(name))) return scope.get(name);\n while (current = current.parent);\n return this.parentFunction.localsByName.get(name);\n }\n\n /** Looks up the element with the specified name relative to the scope of this flow. */\n lookup(name: string): Element | null {\n var element = this.lookupLocal(name);\n if (element) return element;\n return this.actualFunction.lookup(name);\n }\n\n /** Tests if the local at the specified index has the specified flag or flags. */\n isLocalFlag(index: i32, flag: LocalFlags, defaultIfInlined: bool = true): bool {\n if (index < 0) return defaultIfInlined;\n var localFlags = this.localFlags;\n return index < localFlags.length && (unchecked(this.localFlags[index]) & flag) == flag;\n }\n\n /** Tests if the local at the specified index has any of the specified flags. */\n isAnyLocalFlag(index: i32, flag: LocalFlags, defaultIfInlined: bool = true): bool {\n if (index < 0) return defaultIfInlined;\n var localFlags = this.localFlags;\n return index < localFlags.length && (unchecked(this.localFlags[index]) & flag) != 0;\n }\n\n /** Sets the specified flag or flags on the local at the specified index. */\n setLocalFlag(index: i32, flag: LocalFlags): void {\n if (index < 0) return;\n var localFlags = this.localFlags;\n var flags = index < localFlags.length ? unchecked(localFlags[index]) : 0;\n this.localFlags[index] = flags | flag;\n }\n\n /** Unsets the specified flag or flags on the local at the specified index. */\n unsetLocalFlag(index: i32, flag: LocalFlags): void {\n if (index < 0) return;\n var localFlags = this.localFlags;\n var flags = index < localFlags.length ? unchecked(localFlags[index]) : 0;\n this.localFlags[index] = flags & ~flag;\n }\n\n /** Pushes a new break label to the stack, for example when entering a loop that one can `break` from. */\n pushBreakLabel(): string {\n var parentFunction = this.parentFunction;\n var id = parentFunction.nextBreakId++;\n var stack = parentFunction.breakStack;\n if (!stack) parentFunction.breakStack = [ id ];\n else stack.push(id);\n return parentFunction.breakLabel = id.toString(10);\n }\n\n /** Pops the most recent break label from the stack. */\n popBreakLabel(): void {\n var parentFunction = this.parentFunction;\n var stack = assert(parentFunction.breakStack);\n var length = assert(stack.length);\n stack.pop();\n if (length > 1) {\n parentFunction.breakLabel = stack[length - 2].toString(10);\n } else {\n parentFunction.breakLabel = null;\n parentFunction.breakStack = null;\n }\n }\n\n /** Inherits flags and local wrap states from the specified flow (e.g. blocks). */\n inherit(other: Flow): void {\n this.flags |= other.flags & (FlowFlags.ANY_CATEGORICAL | FlowFlags.ANY_CONDITIONAL);\n this.localFlags = other.localFlags; // no need to slice because other flow is finished\n }\n\n /** Inherits categorical flags as conditional flags from the specified flow (e.g. then without else). */\n inheritConditional(other: Flow): void {\n if (other.is(FlowFlags.RETURNS)) {\n this.set(FlowFlags.CONDITIONALLY_RETURNS);\n }\n if (other.is(FlowFlags.THROWS)) {\n this.set(FlowFlags.CONDITIONALLY_THROWS);\n }\n if (other.is(FlowFlags.BREAKS) && other.breakLabel == this.breakLabel) {\n this.set(FlowFlags.CONDITIONALLY_BREAKS);\n }\n if (other.is(FlowFlags.CONTINUES) && other.continueLabel == this.continueLabel) {\n this.set(FlowFlags.CONDITIONALLY_CONTINUES);\n }\n if (other.is(FlowFlags.ALLOCATES)) {\n this.set(FlowFlags.CONDITIONALLY_ALLOCATES);\n }\n var localFlags = other.localFlags;\n for (let i = 0, k = localFlags.length; i < k; ++i) {\n let flags = localFlags[i];\n if (flags & LocalFlags.RETAINED) this.setLocalFlag(i, LocalFlags.CONDITIONALLY_RETAINED);\n if (flags & LocalFlags.READFROM) this.setLocalFlag(i, LocalFlags.CONDITIONALLY_READFROM);\n if (flags & LocalFlags.WRITTENTO) this.setLocalFlag(i, LocalFlags.CONDITIONALLY_WRITTENTO);\n }\n }\n\n /** Inherits mutual flags and local wrap states from the specified flows (e.g. then with else). */\n inheritMutual(left: Flow, right: Flow): void {\n // categorical flags set in both arms\n this.set(left.flags & right.flags & FlowFlags.ANY_CATEGORICAL);\n\n // conditional flags set in any arm\n this.set(left.flags & FlowFlags.ANY_CONDITIONAL);\n this.set(right.flags & FlowFlags.ANY_CONDITIONAL);\n\n // categorical flags in either arm as conditional\n this.inheritConditional(left);\n this.inheritConditional(right);\n\n // categorical local flags set in both arms / conditional local flags set in at least one arm\n var leftLocalFlags = left.localFlags;\n var numLeftLocalFlags = leftLocalFlags.length;\n var rightLocalFlags = right.localFlags;\n var numRightLocalFlags = rightLocalFlags.length;\n var combinedFlags = new Array(max(numLeftLocalFlags, numRightLocalFlags));\n for (let i = 0; i < numLeftLocalFlags; ++i) {\n combinedFlags[i] = LocalFlags.join(\n unchecked(leftLocalFlags[i]),\n i < numRightLocalFlags\n ? unchecked(rightLocalFlags[i])\n : 0\n );\n }\n for (let i = numLeftLocalFlags; i < numRightLocalFlags; ++i) {\n combinedFlags[i] = LocalFlags.join(\n 0,\n unchecked(rightLocalFlags[i])\n );\n }\n this.localFlags = combinedFlags;\n }\n\n /** Checks if an expression of the specified type is known to be non-null, even if the type might be nullable. */\n isNonnull(expr: ExpressionRef, type: Type): bool {\n if (!type.is(TypeFlags.NULLABLE)) return true;\n // below, only teeLocal/getLocal are relevant because these are the only expressions that\n // depend on a dynamic nullable state (flag = LocalFlags.NONNULL), while everything else\n // has already been handled by the nullable type check above.\n switch (getExpressionId(expr)) {\n case ExpressionId.LocalSet: {\n if (!isLocalTee(expr)) break;\n let local = this.parentFunction.localsByIndex[getLocalSetIndex(expr)];\n return !local.type.is(TypeFlags.NULLABLE) || this.isLocalFlag(local.index, LocalFlags.NONNULL, false);\n }\n case ExpressionId.LocalGet: {\n let local = this.parentFunction.localsByIndex[getLocalGetIndex(expr)];\n return !local.type.is(TypeFlags.NULLABLE) || this.isLocalFlag(local.index, LocalFlags.NONNULL, false);\n }\n }\n return false;\n }\n\n /** Updates local states to reflect that this branch is only taken when `expr` is true-ish. */\n inheritNonnullIfTrue(expr: ExpressionRef): void {\n // A: `expr` is true-ish -> Q: how did that happen?\n switch (getExpressionId(expr)) {\n case ExpressionId.LocalSet: {\n if (!isLocalTee(expr)) break;\n let local = this.parentFunction.localsByIndex[getLocalSetIndex(expr)];\n this.setLocalFlag(local.index, LocalFlags.NONNULL);\n this.inheritNonnullIfTrue(getLocalSetValue(expr)); // must have been true-ish as well\n break;\n }\n case ExpressionId.LocalGet: {\n let local = this.parentFunction.localsByIndex[getLocalGetIndex(expr)];\n this.setLocalFlag(local.index, LocalFlags.NONNULL);\n break;\n }\n case ExpressionId.If: {\n let ifFalse = getIfFalse(expr);\n if (!ifFalse) break;\n if (getExpressionId(ifFalse) == ExpressionId.Const) {\n // Logical AND: (if (condition ifTrue 0))\n // the only way this had become true is if condition and ifTrue are true\n if (\n (getExpressionType(ifFalse) == NativeType.I32 && getConstValueI32(ifFalse) == 0) ||\n (getExpressionType(ifFalse) == NativeType.I64 && getConstValueI64Low(ifFalse) == 0 && getConstValueI64High(ifFalse) == 0)\n ) {\n this.inheritNonnullIfTrue(getIfCondition(expr));\n this.inheritNonnullIfTrue(getIfTrue(expr));\n }\n }\n break;\n }\n case ExpressionId.Unary: {\n switch (getUnaryOp(expr)) {\n case UnaryOp.EqzI32:\n case UnaryOp.EqzI64: {\n this.inheritNonnullIfFalse(getUnaryValue(expr)); // !value -> value must have been false\n break;\n }\n }\n break;\n }\n case ExpressionId.Binary: {\n switch (getBinaryOp(expr)) {\n case BinaryOp.EqI32: {\n let left = getBinaryLeft(expr);\n let right = getBinaryRight(expr);\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI32(left) != 0) {\n this.inheritNonnullIfTrue(right); // TRUE == right -> right must have been true\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI32(right) != 0) {\n this.inheritNonnullIfTrue(left); // left == TRUE -> left must have been true\n }\n break;\n }\n case BinaryOp.EqI64: {\n let left = getBinaryLeft(expr);\n let right = getBinaryRight(expr);\n if (getExpressionId(left) == ExpressionId.Const && (getConstValueI64Low(left) != 0 || getConstValueI64High(left) != 0)) {\n this.inheritNonnullIfTrue(right); // TRUE == right -> right must have been true\n } else if (getExpressionId(right) == ExpressionId.Const && (getConstValueI64Low(right) != 0 && getConstValueI64High(right) != 0)) {\n this.inheritNonnullIfTrue(left); // left == TRUE -> left must have been true\n }\n break;\n }\n case BinaryOp.NeI32: {\n let left = getBinaryLeft(expr);\n let right = getBinaryRight(expr);\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI32(left) == 0) {\n this.inheritNonnullIfTrue(right); // FALSE != right -> right must have been true\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI32(right) == 0) {\n this.inheritNonnullIfTrue(left); // left != FALSE -> left must have been true\n }\n break;\n }\n case BinaryOp.NeI64: {\n let left = getBinaryLeft(expr);\n let right = getBinaryRight(expr);\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI64Low(left) == 0 && getConstValueI64High(left) == 0) {\n this.inheritNonnullIfTrue(right); // FALSE != right -> right must have been true\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI64Low(right) == 0 && getConstValueI64High(right) == 0) {\n this.inheritNonnullIfTrue(left); // left != FALSE -> left must have been true\n }\n break;\n }\n }\n break;\n }\n case ExpressionId.Call: {\n let name = getCallTarget(expr);\n let program = this.parentFunction.program;\n switch (name) {\n case program.retainInstance.internalName: {\n this.inheritNonnullIfTrue(getCallOperand(expr, 0));\n break;\n }\n }\n break;\n }\n }\n }\n\n /** Updates local states to reflect that this branch is only taken when `expr` is false-ish. */\n inheritNonnullIfFalse(expr: ExpressionRef): void {\n // A: `expr` is false-ish -> Q: how did that happen?\n switch (getExpressionId(expr)) {\n case ExpressionId.Unary: {\n switch (getUnaryOp(expr)) {\n case UnaryOp.EqzI32:\n case UnaryOp.EqzI64: {\n this.inheritNonnullIfTrue(getUnaryValue(expr)); // !value -> value must have been true\n break;\n }\n }\n break;\n }\n case ExpressionId.If: {\n let ifTrue = getIfTrue(expr);\n if (getExpressionId(ifTrue) == ExpressionId.Const) {\n let ifFalse = getIfFalse(expr);\n if (!ifFalse) break;\n // Logical OR: (if (condition 1 ifFalse))\n // the only way this had become false is if condition and ifFalse are false\n if (\n (getExpressionType(ifTrue) == NativeType.I32 && getConstValueI32(ifTrue) != 0) ||\n (getExpressionType(ifTrue) == NativeType.I64 && (getConstValueI64Low(ifTrue) != 0 || getConstValueI64High(ifTrue) != 0))\n ) {\n this.inheritNonnullIfFalse(getIfCondition(expr));\n this.inheritNonnullIfFalse(getIfFalse(expr));\n }\n\n }\n break;\n }\n case ExpressionId.Binary: {\n switch (getBinaryOp(expr)) {\n // remember: we want to know how the _entire_ expression became FALSE (!)\n case BinaryOp.EqI32: {\n let left = getBinaryLeft(expr);\n let right = getBinaryRight(expr);\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI32(left) == 0) {\n this.inheritNonnullIfTrue(right); // FALSE == right -> right must have been true\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI32(right) == 0) {\n this.inheritNonnullIfTrue(left); // left == FALSE -> left must have been true\n }\n break;\n }\n case BinaryOp.EqI64: {\n let left = getBinaryLeft(expr);\n let right = getBinaryRight(expr);\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI64Low(left) == 0 && getConstValueI64High(left) == 0) {\n this.inheritNonnullIfTrue(right); // FALSE == right -> right must have been true\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI64Low(right) == 0 && getConstValueI64High(right) == 0) {\n this.inheritNonnullIfTrue(left); // left == FALSE -> left must have been true\n }\n break;\n }\n case BinaryOp.NeI32: {\n let left = getBinaryLeft(expr);\n let right = getBinaryRight(expr);\n if (getExpressionId(left) == ExpressionId.Const && getConstValueI32(left) != 0) {\n this.inheritNonnullIfTrue(right); // TRUE != right -> right must have been true\n } else if (getExpressionId(right) == ExpressionId.Const && getConstValueI32(right) != 0) {\n this.inheritNonnullIfTrue(left); // left != TRUE -> left must have been true\n }\n break;\n }\n case BinaryOp.NeI64: {\n let left = getBinaryLeft(expr);\n let right = getBinaryRight(expr);\n if (getExpressionId(left) == ExpressionId.Const && (getConstValueI64Low(left) != 0 || getConstValueI64High(left) != 0)) {\n this.inheritNonnullIfTrue(right); // TRUE != right -> right must have been true for this to become false\n } else if (getExpressionId(right) == ExpressionId.Const && (getConstValueI64Low(right) != 0 || getConstValueI64High(right) != 0)) {\n this.inheritNonnullIfTrue(left); // left != TRUE -> left must have been true for this to become false\n }\n break;\n }\n }\n break;\n }\n }\n }\n\n /**\n * Tests if an expression can possibly overflow in the context of this flow. Assumes that the\n * expression might already have overflown and returns `false` only if the operation neglects\n * any possible combination of garbage bits being present.\n */\n canOverflow(expr: ExpressionRef, type: Type): bool {\n // TODO: the following catches most common and a few uncommon cases, but there are additional\n // opportunities here, obviously.\n assert(type != Type.void);\n\n // types other than i8, u8, i16, u16 and bool do not overflow\n if (!type.is(TypeFlags.SHORT | TypeFlags.INTEGER)) return false;\n\n var operand: ExpressionRef;\n switch (getExpressionId(expr)) {\n\n // overflows if the local isn't wrapped or the conversion does\n case ExpressionId.LocalGet: {\n let local = this.parentFunction.localsByIndex[getLocalGetIndex(expr)];\n return !this.isLocalFlag(local.index, LocalFlags.WRAPPED, true)\n || canConversionOverflow(local.type, type);\n }\n\n // overflows if the value does\n case ExpressionId.LocalSet: { // tee\n assert(isLocalTee(expr));\n return this.canOverflow(getLocalSetValue(expr), type);\n }\n\n // overflows if the conversion does (globals are wrapped on set)\n case ExpressionId.GlobalGet: {\n // TODO: this is inefficient because it has to read a string\n let global = assert(this.parentFunction.program.elementsByName.get(assert(getGlobalGetName(expr))));\n assert(global.kind == ElementKind.GLOBAL);\n return canConversionOverflow(assert((global).type), type);\n }\n\n case ExpressionId.Binary: {\n switch (getBinaryOp(expr)) {\n\n // comparisons do not overflow (result is 0 or 1)\n case BinaryOp.EqI32:\n case BinaryOp.EqI64:\n case BinaryOp.EqF32:\n case BinaryOp.EqF64:\n case BinaryOp.NeI32:\n case BinaryOp.NeI64:\n case BinaryOp.NeF32:\n case BinaryOp.NeF64:\n case BinaryOp.LtI32:\n case BinaryOp.LtU32:\n case BinaryOp.LtI64:\n case BinaryOp.LtU64:\n case BinaryOp.LtF32:\n case BinaryOp.LtF64:\n case BinaryOp.LeI32:\n case BinaryOp.LeU32:\n case BinaryOp.LeI64:\n case BinaryOp.LeU64:\n case BinaryOp.LeF32:\n case BinaryOp.LeF64:\n case BinaryOp.GtI32:\n case BinaryOp.GtU32:\n case BinaryOp.GtI64:\n case BinaryOp.GtU64:\n case BinaryOp.GtF32:\n case BinaryOp.GtF64:\n case BinaryOp.GeI32:\n case BinaryOp.GeU32:\n case BinaryOp.GeI64:\n case BinaryOp.GeU64:\n case BinaryOp.GeF32:\n case BinaryOp.GeF64: return false;\n\n // result won't overflow if one side is 0 or if one side is 1 and the other wrapped\n case BinaryOp.MulI32: {\n return !(\n (\n getExpressionId(operand = getBinaryLeft(expr)) == ExpressionId.Const &&\n (\n getConstValueI32(operand) == 0 ||\n (\n getConstValueI32(operand) == 1 &&\n !this.canOverflow(getBinaryRight(expr), type)\n )\n )\n ) || (\n getExpressionId(operand = getBinaryRight(expr)) == ExpressionId.Const &&\n (\n getConstValueI32(operand) == 0 ||\n (\n getConstValueI32(operand) == 1 &&\n !this.canOverflow(getBinaryLeft(expr), type)\n )\n )\n )\n );\n }\n\n // result won't overflow if one side is a constant less than this type's mask or one side\n // is wrapped\n case BinaryOp.AndI32: {\n // note that computeSmallIntegerMask returns the mask minus the MSB for signed types\n // because signed value garbage bits must be guaranteed to be equal to the MSB.\n return !(\n (\n (\n getExpressionId(operand = getBinaryLeft(expr)) == ExpressionId.Const &&\n getConstValueI32(operand) <= type.computeSmallIntegerMask(Type.i32)\n ) || !this.canOverflow(operand, type)\n ) || (\n (\n getExpressionId(operand = getBinaryRight(expr)) == ExpressionId.Const &&\n getConstValueI32(operand) <= type.computeSmallIntegerMask(Type.i32)\n ) || !this.canOverflow(operand, type)\n )\n );\n }\n\n // overflows if the shift doesn't clear potential garbage bits\n case BinaryOp.ShlI32: {\n let shift = 32 - type.size;\n return getExpressionId(operand = getBinaryRight(expr)) != ExpressionId.Const\n || getConstValueI32(operand) < shift;\n }\n\n // overflows if the value does and the shift doesn't clear potential garbage bits\n case BinaryOp.ShrI32: {\n let shift = 32 - type.size;\n return this.canOverflow(getBinaryLeft(expr), type) && (\n getExpressionId(operand = getBinaryRight(expr)) != ExpressionId.Const ||\n getConstValueI32(operand) < shift\n );\n }\n\n // overflows if the shift does not clear potential garbage bits. if an unsigned value is\n // wrapped, it can't overflow.\n case BinaryOp.ShrU32: {\n let shift = 32 - type.size;\n return type.is(TypeFlags.SIGNED)\n ? !(\n getExpressionId(operand = getBinaryRight(expr)) == ExpressionId.Const &&\n getConstValueI32(operand) > shift // must clear MSB\n )\n : this.canOverflow(getBinaryLeft(expr), type) && !(\n getExpressionId(operand = getBinaryRight(expr)) == ExpressionId.Const &&\n getConstValueI32(operand) >= shift // can leave MSB\n );\n }\n\n // overflows if any side does\n case BinaryOp.DivU32:\n case BinaryOp.RemI32:\n case BinaryOp.RemU32: {\n return this.canOverflow(getBinaryLeft(expr), type)\n || this.canOverflow(getBinaryRight(expr), type);\n }\n }\n break;\n }\n\n case ExpressionId.Unary: {\n switch (getUnaryOp(expr)) {\n\n // comparisons do not overflow (result is 0 or 1)\n case UnaryOp.EqzI32:\n case UnaryOp.EqzI64: return false;\n\n // overflow if the maximum result (32) cannot be represented in the target type\n case UnaryOp.ClzI32:\n case UnaryOp.CtzI32:\n case UnaryOp.PopcntI32: return type.size < 7;\n }\n break;\n }\n\n // overflows if the value cannot be represented in the target type\n case ExpressionId.Const: {\n let value: i32 = 0;\n switch (getExpressionType(expr)) {\n case NativeType.I32: { value = getConstValueI32(expr); break; }\n case NativeType.I64: { value = getConstValueI64Low(expr); break; } // discards upper bits\n case NativeType.F32: { value = i32(getConstValueF32(expr)); break; }\n case NativeType.F64: { value = i32(getConstValueF64(expr)); break; }\n default: assert(false);\n }\n switch (type.kind) {\n case TypeKind.I8: return value < i8.MIN_VALUE || value > i8.MAX_VALUE;\n case TypeKind.I16: return value < i16.MIN_VALUE || value > i16.MAX_VALUE;\n case TypeKind.U8: return value < 0 || value > u8.MAX_VALUE;\n case TypeKind.U16: return value < 0 || value > u16.MAX_VALUE;\n case TypeKind.BOOL: return (value & ~1) != 0;\n }\n break;\n }\n\n // overflows if the conversion does\n case ExpressionId.Load: {\n let fromType: Type;\n let signed = isLoadSigned(expr);\n switch (getLoadBytes(expr)) {\n case 1: { fromType = signed ? Type.i8 : Type.u8; break; }\n case 2: { fromType = signed ? Type.i16 : Type.u16; break; }\n default: { fromType = signed ? Type.i32 : Type.u32; break; }\n }\n return canConversionOverflow(fromType, type);\n }\n\n // overflows if the result does, which is either\n // - the last expression of the block, by contract, if the block doesn't have a label\n // - the last expression or the value of an inner br if the block has a label (TODO)\n case ExpressionId.Block: {\n if (!getBlockName(expr)) {\n let size = assert(getBlockChildCount(expr));\n let last = getBlockChild(expr, size - 1);\n return this.canOverflow(last, type);\n }\n break;\n }\n\n // overflows if either side does\n case ExpressionId.If: {\n return this.canOverflow(getIfTrue(expr), type)\n || this.canOverflow(assert(getIfFalse(expr)), type);\n }\n\n // overflows if either side does\n case ExpressionId.Select: {\n return this.canOverflow(getSelectThen(expr), type)\n || this.canOverflow(getSelectElse(expr), type);\n }\n\n // overflows if the call does not return a wrapped value or the conversion does\n case ExpressionId.Call: {\n let program = this.parentFunction.program;\n let instancesByName = program.instancesByName;\n let instanceName = assert(getCallTarget(expr));\n if (instancesByName.has(instanceName)) {\n let instance = instancesByName.get(instanceName)!;\n assert(instance.kind == ElementKind.FUNCTION);\n let returnType = (instance).signature.returnType;\n return !(instance).flow.is(FlowFlags.RETURNS_WRAPPED)\n || canConversionOverflow(returnType, type);\n }\n return false; // assume no overflow for builtins\n }\n\n // doesn't technically overflow\n case ExpressionId.Unreachable: return false;\n }\n return true;\n }\n\n toString(): string {\n var levels = 0;\n var parent = this.parent;\n while (parent) {\n parent = parent.parent;\n ++levels;\n }\n return \"Flow(\" + this.actualFunction + \")[\" + levels.toString() + \"]\";\n }\n}\n\n/** Tests if a conversion from one type to another can technically overflow. */\nfunction canConversionOverflow(fromType: Type, toType: Type): bool {\n return !fromType.is(TypeFlags.INTEGER) // non-i32 locals or returns\n || fromType.size > toType.size\n || fromType.is(TypeFlags.SIGNED) != toType.is(TypeFlags.SIGNED);\n}\n\n/** Finds all indexes of locals used in the specified expression. */\nexport function findUsedLocals(expr: ExpressionRef, used: Set = new Set()): Set {\n traverse(expr, used, findUsedLocalsVisit);\n return used;\n}\n\n/** A visitor function for use with `traverse` that finds all indexes of used locals. */\nfunction findUsedLocalsVisit(expr: ExpressionRef, used: Set): void {\n switch (getExpressionId(expr)) {\n case ExpressionId.LocalGet: {\n used.add(getLocalGetIndex(expr));\n break;\n }\n case ExpressionId.LocalSet: {\n used.add(getLocalSetIndex(expr));\n // fall-through for value\n }\n default: traverse(expr, used, findUsedLocalsVisit);\n }\n}\n","/**\n * The AssemblyScript compiler.\n * @module compiler\n *//***/\n\nimport {\n BuiltinSymbols,\n compileCall as compileBuiltinCall,\n compileAbort,\n compileVisitGlobals,\n compileVisitMembers,\n compileRTTI,\n} from \"./builtins\";\n\nimport {\n DiagnosticCode,\n DiagnosticEmitter\n} from \"./diagnostics\";\n\nimport {\n Module,\n MemorySegment,\n ExpressionRef,\n UnaryOp,\n BinaryOp,\n NativeType,\n FunctionRef,\n ExpressionId,\n FunctionTypeRef,\n GlobalRef,\n getExpressionId,\n getExpressionType,\n getConstValueI32,\n getConstValueI64Low,\n getConstValueI64High,\n getConstValueF32,\n getConstValueF64,\n getBlockChildCount,\n getBlockChild,\n getBlockName,\n getLocalGetIndex,\n isLocalTee,\n getLocalSetIndex,\n FeatureFlags,\n needsExplicitUnreachable\n} from \"./module\";\n\nimport {\n CommonFlags,\n INSTANCE_DELIMITER,\n STATIC_DELIMITER,\n GETTER_PREFIX,\n SETTER_PREFIX,\n CommonSymbols,\n INDEX_SUFFIX,\n Feature,\n Target\n} from \"./common\";\n\nimport {\n Program,\n ClassPrototype,\n Class,\n Element,\n ElementKind,\n Enum,\n Field,\n FunctionPrototype,\n Function,\n FunctionTarget,\n Global,\n Local,\n EnumValue,\n Property,\n VariableLikeElement,\n ConstantValueKind,\n OperatorKind,\n DecoratorFlags,\n PropertyPrototype,\n File,\n mangleInternalName\n} from \"./program\";\n\nimport {\n FlowFlags,\n Flow,\n LocalFlags,\n findUsedLocals\n} from \"./flow\";\n\nimport {\n Resolver, ReportMode\n} from \"./resolver\";\n\nimport {\n Token,\n operatorTokenToString\n} from \"./tokenizer\";\n\nimport {\n Node,\n NodeKind,\n NamedTypeNode,\n Range,\n DecoratorKind,\n AssertionKind,\n\n Statement,\n BlockStatement,\n BreakStatement,\n ClassDeclaration,\n ContinueStatement,\n DeclarationStatement,\n DoStatement,\n EmptyStatement,\n EnumDeclaration,\n ExportStatement,\n ExpressionStatement,\n FieldDeclaration,\n ForStatement,\n FunctionDeclaration,\n IfStatement,\n ImportStatement,\n InstanceOfExpression,\n InterfaceDeclaration,\n NamespaceDeclaration,\n ReturnStatement,\n SwitchStatement,\n ThrowStatement,\n TryStatement,\n VariableStatement,\n VoidStatement,\n WhileStatement,\n\n Expression,\n AssertionExpression,\n BinaryExpression,\n CallExpression,\n CommaExpression,\n ElementAccessExpression,\n FloatLiteralExpression,\n FunctionExpression,\n IdentifierExpression,\n IntegerLiteralExpression,\n LiteralExpression,\n LiteralKind,\n NewExpression,\n ObjectLiteralExpression,\n ParenthesizedExpression,\n PropertyAccessExpression,\n TernaryExpression,\n ArrayLiteralExpression,\n StringLiteralExpression,\n UnaryPostfixExpression,\n UnaryPrefixExpression,\n\n nodeIsConstantValue,\n findDecorator,\n isTypeOmitted,\n ExportDefaultStatement\n} from \"./ast\";\n\nimport {\n Type,\n TypeKind,\n TypeFlags,\n Signature,\n typesToNativeTypes\n} from \"./types\";\n\nimport {\n writeI8,\n writeI16,\n writeI32,\n writeI64,\n writeF32,\n writeF64,\n makeMap\n} from \"./util\";\n\n/** Compiler options. */\nexport class Options {\n\n /** WebAssembly target. Defaults to {@link Target.WASM32}. */\n target: Target = Target.WASM32;\n /** If true, replaces assertions with nops. */\n noAssert: bool = false;\n /** If true, imports the memory provided by the embedder. */\n importMemory: bool = false;\n /** If greater than zero, declare memory as shared by setting max memory to sharedMemory. */\n sharedMemory: i32 = 0;\n /** If true, imports the function table provided by the embedder. */\n importTable: bool = false;\n /** If true, generates information necessary for source maps. */\n sourceMap: bool = false;\n /** If true, generates an explicit start function. */\n explicitStart: bool = false;\n /** Static memory start offset. */\n memoryBase: i32 = 0;\n /** Global aliases, mapping alias names as the key to internal names to be aliased as the value. */\n globalAliases: Map | null = null;\n /** Additional features to activate. */\n features: Feature = Feature.NONE;\n\n /** Hinted optimize level. Not applied by the compiler itself. */\n optimizeLevelHint: i32 = 0;\n /** Hinted shrink level. Not applied by the compiler itself. */\n shrinkLevelHint: i32 = 0;\n\n /** Tests if the target is WASM64 or, otherwise, WASM32. */\n get isWasm64(): bool {\n return this.target == Target.WASM64;\n }\n\n /** Gets the unsigned size type matching the target. */\n get usizeType(): Type {\n return this.target == Target.WASM64 ? Type.usize64 : Type.usize32;\n }\n\n /** Gets the signed size type matching the target. */\n get isizeType(): Type {\n return this.target == Target.WASM64 ? Type.isize64 : Type.isize32;\n }\n\n /** Gets the native size type matching the target. */\n get nativeSizeType(): NativeType {\n return this.target == Target.WASM64 ? NativeType.I64 : NativeType.I32;\n }\n\n /** Tests if a specific feature is activated. */\n hasFeature(feature: Feature): bool {\n return (this.features & feature) != 0;\n }\n}\n\n/** Various constraints in expression compilation. */\nexport const enum Constraints {\n NONE = 0,\n\n /** Must implicitly convert to the target type. */\n CONV_IMPLICIT = 1 << 0,\n /** Must explicitly convert to the target type. */\n CONV_EXPLICIT = 1 << 1,\n /** Must wrap small integer values to match the target type. */\n MUST_WRAP = 1 << 2,\n\n /** Indicates that the value will be dropped immediately. */\n WILL_DROP = 1 << 3,\n /** Indicates that the value will be retained immediately. */\n WILL_RETAIN = 1 << 4,\n /** Indicates that static data is preferred. */\n PREFER_STATIC = 1 << 5\n}\n\n/** Runtime features to be activated by the compiler. */\nexport const enum RuntimeFeatures {\n NONE = 0,\n /** Requires heap setup. */\n HEAP = 1 << 0,\n /** Requires runtime type information setup. */\n RTTI = 1 << 1,\n /** Requires the built-in globals visitor. */\n visitGlobals = 1 << 2,\n /** Requires the built-in members visitor. */\n visitMembers = 1 << 3\n}\n\n/** Compiler interface. */\nexport class Compiler extends DiagnosticEmitter {\n\n /** Program reference. */\n program: Program;\n /** Resolver reference. */\n resolver: Resolver;\n /** Provided options. */\n options: Options;\n /** Module instance being compiled. */\n module: Module;\n /** Current control flow. */\n currentFlow: Flow;\n /** Current inline functions stack. */\n currentInlineFunctions: Function[] = [];\n /** Current enum in compilation. */\n currentEnum: Enum | null = null;\n /** Current type in compilation. */\n currentType: Type = Type.void;\n /** Start function statements. */\n currentBody: ExpressionRef[];\n /** Counting memory offset. */\n memoryOffset: I64;\n /** Memory segments being compiled. */\n memorySegments: MemorySegment[] = [];\n /** Map of already compiled static string segments. */\n stringSegments: Map = new Map();\n /** Function table being compiled. */\n functionTable: string[] = [ \"null\" ];\n /** Argument count helper global. */\n argcVar: GlobalRef = 0;\n /** Argument count helper setter. */\n argcSet: FunctionRef = 0;\n /** Requires runtime features. */\n runtimeFeatures: RuntimeFeatures = RuntimeFeatures.NONE;\n /** Expressions known to have skipped an autorelease. Usually function returns. */\n skippedAutoreleases: Set = new Set();\n\n /** Compiles a {@link Program} to a {@link Module} using the specified options. */\n static compile(program: Program, options: Options | null = null): Module {\n return new Compiler(program, options).compile();\n }\n\n /** Constructs a new compiler for a {@link Program} using the specified options. */\n constructor(program: Program, options: Options | null = null) {\n super(program.diagnostics);\n this.program = program;\n this.resolver = program.resolver;\n if (!options) options = new Options();\n this.options = options;\n this.memoryOffset = i64_new(\n // leave space for `null`. also functions as a sentinel for erroneous stores at offset 0.\n // note that Binaryen's asm.js output utilizes the first 8 bytes for reinterpretations (#1547)\n max(options.memoryBase, 8)\n );\n this.module = Module.create();\n var featureFlags: BinaryenFeatureFlags = 0;\n if (this.options.hasFeature(Feature.THREADS)) featureFlags |= FeatureFlags.Atomics;\n if (this.options.hasFeature(Feature.MUTABLE_GLOBAL)) featureFlags |= FeatureFlags.MutableGloabls;\n // if (this.options.hasFeature(Feature.TRUNC_SAT)) featureFlags |= FeatureFlags.NontrappingFPToInt;\n if (this.options.hasFeature(Feature.SIMD)) featureFlags |= FeatureFlags.SIMD128;\n if (this.options.hasFeature(Feature.BULK_MEMORY)) featureFlags |= FeatureFlags.BulkMemory;\n if (this.options.hasFeature(Feature.SIGN_EXTENSION)) featureFlags |= FeatureFlags.SignExt;\n // if (this.options.hasFeature(Feature.EXCEPTION_HANDLING)) featureFlags |= FeatureFlags.ExceptionHandling;\n this.module.setFeatures(featureFlags);\n }\n\n /** Performs compilation of the underlying {@link Program} to a {@link Module}. */\n compile(): Module {\n var options = this.options;\n var module = this.module;\n var program = this.program;\n\n // initialize lookup maps, built-ins, imports, exports, etc.\n program.initialize(options);\n\n // set up the main start function\n var startFunctionInstance = program.makeNativeFunction(\"start\", new Signature([], Type.void));\n startFunctionInstance.internalName = \"start\";\n var startFunctionBody = new Array();\n this.currentFlow = startFunctionInstance.flow;\n this.currentBody = startFunctionBody;\n\n // add a mutable heap and rtti base dummies\n if (options.isWasm64) {\n module.addGlobal(BuiltinSymbols.heap_base, NativeType.I64, true, module.i64(0));\n module.addGlobal(BuiltinSymbols.rtti_base, NativeType.I64, true, module.i64(0));\n } else {\n module.addGlobal(BuiltinSymbols.heap_base, NativeType.I32, true, module.i32(0));\n module.addGlobal(BuiltinSymbols.rtti_base, NativeType.I32, true, module.i32(0));\n }\n\n // compile entry file(s) while traversing reachable elements\n var files = program.filesByName;\n for (let file of files.values()) {\n if (file.source.isEntry) {\n this.compileFile(file);\n this.compileExports(file);\n }\n }\n\n // compile the start function if not empty or explicitly requested\n var startIsEmpty = !startFunctionBody.length;\n var explicitStart = options.explicitStart;\n if (!startIsEmpty || explicitStart) {\n let signature = startFunctionInstance.signature;\n if (!startIsEmpty && explicitStart) {\n module.addGlobal(BuiltinSymbols.started, NativeType.I32, true, module.i32(0));\n startFunctionBody.unshift(\n module.if(\n module.global_get(BuiltinSymbols.started, NativeType.I32),\n module.return(),\n module.global_set(BuiltinSymbols.started, module.i32(1))\n )\n );\n }\n let funcRef = module.addFunction(\n startFunctionInstance.internalName,\n this.ensureFunctionType(\n signature.parameterTypes,\n signature.returnType,\n signature.thisType\n ),\n typesToNativeTypes(startFunctionInstance.additionalLocals),\n module.block(null, startFunctionBody)\n );\n startFunctionInstance.finalize(module, funcRef);\n if (!explicitStart) module.setStart(funcRef);\n else module.addFunctionExport(startFunctionInstance.internalName, \"__start\");\n }\n\n // compile runtime features\n if (this.runtimeFeatures & RuntimeFeatures.visitGlobals) compileVisitGlobals(this);\n if (this.runtimeFeatures & RuntimeFeatures.visitMembers) compileVisitMembers(this);\n module.removeGlobal(BuiltinSymbols.rtti_base);\n if (this.runtimeFeatures & RuntimeFeatures.RTTI) compileRTTI(this);\n\n // update the heap base pointer\n var memoryOffset = this.memoryOffset;\n memoryOffset = i64_align(memoryOffset, options.usizeType.byteSize);\n this.memoryOffset = memoryOffset;\n module.removeGlobal(BuiltinSymbols.heap_base);\n if (this.runtimeFeatures & RuntimeFeatures.HEAP) {\n if (options.isWasm64) {\n module.addGlobal(\n BuiltinSymbols.heap_base,\n NativeType.I64,\n false,\n module.i64(i64_low(memoryOffset), i64_high(memoryOffset))\n );\n } else {\n module.addGlobal(\n BuiltinSymbols.heap_base,\n NativeType.I32,\n false,\n module.i32(i64_low(memoryOffset))\n );\n }\n }\n\n // set up memory\n var isSharedMemory = options.hasFeature(Feature.THREADS) && options.sharedMemory > 0;\n module.setMemory(\n this.options.memoryBase /* is specified */ || this.memorySegments.length\n ? i64_low(i64_shr_u(i64_align(memoryOffset, 0x10000), i64_new(16, 0)))\n : 0,\n isSharedMemory ? options.sharedMemory : Module.UNLIMITED_MEMORY,\n this.memorySegments,\n options.target,\n \"memory\",\n isSharedMemory\n );\n\n // import memory if requested (default memory is named '0' by Binaryen)\n if (options.importMemory) module.addMemoryImport(\"0\", \"env\", \"memory\", isSharedMemory);\n\n // set up function table\n var functionTable = this.functionTable;\n module.setFunctionTable(functionTable.length, 0xffffffff, functionTable);\n module.addFunction(\"null\", this.ensureFunctionType(null, Type.void), null, module.block(null, []));\n\n // import table if requested (default table is named '0' by Binaryen)\n if (options.importTable) module.addTableImport(\"0\", \"env\", \"table\");\n\n // set up module exports\n for (let file of this.program.filesByName.values()) {\n if (file.source.isEntry) this.ensureModuleExports(file);\n }\n return module;\n }\n\n /** Applies the respective module exports for the specified file. */\n private ensureModuleExports(file: File): void {\n var members = file.exports;\n if (members) for (let [name, member] of members) this.ensureModuleExport(name, member);\n var exportsStar = file.exportsStar;\n if (exportsStar) {\n for (let i = 0, k = exportsStar.length; i < k; ++i) this.ensureModuleExports(exportsStar[i]);\n }\n }\n\n /** Applies the respective module export(s) for the specified element. */\n private ensureModuleExport(name: string, element: Element, prefix: string = \"\"): void {\n switch (element.kind) {\n\n // traverse instances\n case ElementKind.FUNCTION_PROTOTYPE: {\n let instances = (element).instances;\n if (instances) {\n for (let instance of instances.values()) {\n let instanceName = name;\n if (instance.is(CommonFlags.GENERIC)) {\n let fullName = instance.internalName;\n instanceName += fullName.substring(fullName.lastIndexOf(\"<\"));\n }\n this.ensureModuleExport(instanceName, instance, prefix);\n }\n }\n break;\n }\n case ElementKind.CLASS_PROTOTYPE: {\n let instances = (element).instances;\n if (instances) {\n for (let instance of instances.values()) {\n let instanceName = name;\n if (instance.is(CommonFlags.GENERIC)) {\n let fullName = instance.internalName;\n instanceName += fullName.substring(fullName.lastIndexOf(\"<\"));\n }\n this.ensureModuleExport(instanceName, instance, prefix);\n }\n }\n break;\n }\n case ElementKind.PROPERTY_PROTOTYPE: {\n let getter = (element).getterPrototype;\n let setter = (element).setterPrototype;\n if (getter) this.ensureModuleExport(GETTER_PREFIX + name, getter, prefix);\n if (setter) this.ensureModuleExport(SETTER_PREFIX + name, setter, prefix);\n break;\n }\n\n // export concrete elements\n case ElementKind.GLOBAL: {\n let isConst = element.is(CommonFlags.CONST) || element.is(CommonFlags.STATIC | CommonFlags.READONLY);\n if (!isConst && !this.options.hasFeature(Feature.MUTABLE_GLOBAL)) {\n this.error(\n DiagnosticCode.Cannot_export_a_mutable_global,\n (element).identifierNode.range\n );\n } else {\n this.module.addGlobalExport(element.internalName, prefix + name);\n }\n break;\n }\n case ElementKind.ENUMVALUE: {\n if (!(element).isImmutable && !this.options.hasFeature(Feature.MUTABLE_GLOBAL)) {\n this.error(\n DiagnosticCode.Cannot_export_a_mutable_global,\n (element).identifierNode.range\n );\n } else {\n this.module.addGlobalExport(element.internalName, prefix + name);\n }\n break;\n }\n case ElementKind.FUNCTION: {\n let instance = element;\n let signature = instance.signature;\n if (signature.requiredParameters < signature.parameterTypes.length) {\n // utilize trampoline to fill in omitted arguments\n instance = this.ensureTrampoline(instance);\n this.ensureArgcSet();\n }\n if (instance.is(CommonFlags.COMPILED)) this.module.addFunctionExport(instance.internalName, prefix + name);\n break;\n }\n case ElementKind.PROPERTY: {\n let getter = (element).getterInstance;\n if (getter) this.ensureModuleExport(GETTER_PREFIX + name, getter, prefix);\n let setter = (element).setterInstance;\n if (setter) this.ensureModuleExport(SETTER_PREFIX + name, setter, prefix);\n break;\n }\n case ElementKind.FIELD: {\n this.ensureModuleFieldGetter(prefix + GETTER_PREFIX + name, element);\n if (!element.is(CommonFlags.READONLY)) {\n this.ensureModuleFieldSetter(prefix + SETTER_PREFIX + name, element);\n }\n break;\n }\n case ElementKind.CLASS: {\n // make the class name itself represent its runtime id\n if (!(element).type.isUnmanaged) {\n let module = this.module;\n let internalName = (element).internalName;\n module.addGlobal(internalName, NativeType.I32, false, module.i32((element).id));\n module.addGlobalExport(internalName, prefix + name);\n }\n break;\n }\n\n // just traverse members below\n case ElementKind.ENUM:\n case ElementKind.NAMESPACE:\n case ElementKind.FILE:\n case ElementKind.TYPEDEFINITION: break;\n\n default: assert(false); // unexpected module export\n }\n\n // traverse members\n var members = element.members;\n if (members) {\n let subPrefix = prefix + name + (element.kind == ElementKind.CLASS\n ? INSTANCE_DELIMITER\n : STATIC_DELIMITER\n );\n if (\n element.kind == ElementKind.NAMESPACE ||\n element.kind == ElementKind.FILE\n ) {\n for (let member of members.values()) {\n if (!member.is(CommonFlags.EXPORT)) continue;\n this.ensureModuleExport(member.name, member, subPrefix);\n }\n } else {\n for (let member of members.values()) {\n if (member.is(CommonFlags.PRIVATE)) continue;\n this.ensureModuleExport(member.name, member, subPrefix);\n }\n }\n }\n }\n\n /** Makes a function to get the value of a field of an exported class. */\n private ensureModuleFieldGetter(name: string, field: Field): void {\n var module = this.module;\n var type = field.type;\n var usizeType = this.options.usizeType;\n var loadExpr = module.load(type.byteSize, type.is(TypeFlags.SIGNED),\n module.local_get(0, usizeType.toNativeType()),\n type.toNativeType(), field.memoryOffset\n );\n // a user-defined getter would return a retained value, so:\n if (type.isManaged) loadExpr = this.makeRetain(loadExpr);\n module.addFunction(\n name,\n this.ensureFunctionType(null, type, usizeType),\n null,\n loadExpr\n );\n module.addFunctionExport(name, name);\n }\n\n /** Makes a function to set the value of a field of an exported class. */\n private ensureModuleFieldSetter(name: string, field: Field): void {\n var module = this.module;\n var type = field.type;\n var nativeType = type.toNativeType();\n var usizeType = this.options.usizeType;\n var nativeSizeType = usizeType.toNativeType();\n var valueExpr = module.local_get(1, nativeType);\n if (type.isManaged) {\n valueExpr = this.makeRetainRelease(\n module.load(type.byteSize, false, // oldRef\n module.local_get(0, nativeSizeType),\n nativeType, field.memoryOffset\n ),\n valueExpr // newRef\n );\n }\n module.addFunction(\n name,\n this.ensureFunctionType([ type ], Type.void, usizeType),\n null,\n module.store(\n type.byteSize,\n module.local_get(0, nativeSizeType),\n valueExpr,\n nativeType,\n field.memoryOffset\n )\n );\n module.addFunctionExport(name, name);\n }\n\n // === Elements =================================================================================\n\n /** Compiles any element. */\n compileElement(element: Element, compileMembers: bool = true): void {\n switch (element.kind) {\n case ElementKind.GLOBAL: {\n this.compileGlobal(element);\n break;\n }\n case ElementKind.ENUM: {\n this.compileEnum(element);\n break;\n }\n case ElementKind.FUNCTION_PROTOTYPE: {\n if (!element.is(CommonFlags.GENERIC)) {\n this.compileFunctionUsingTypeArguments(element, []);\n }\n break;\n }\n case ElementKind.CLASS_PROTOTYPE: {\n if (!element.is(CommonFlags.GENERIC)) {\n this.compileClassUsingTypeArguments(element, []);\n }\n break;\n }\n case ElementKind.PROPERTY_PROTOTYPE: {\n let getterPrototype = (element).getterPrototype;\n if (getterPrototype) {\n this.compileFunctionUsingTypeArguments(getterPrototype, []);\n }\n let setterPrototype = (element).setterPrototype;\n if (setterPrototype) {\n this.compileFunctionUsingTypeArguments(setterPrototype, []);\n }\n break;\n }\n case ElementKind.NAMESPACE:\n case ElementKind.TYPEDEFINITION:\n case ElementKind.ENUMVALUE: break;\n default: assert(false, ElementKind[element.kind]);\n }\n if (compileMembers) this.compileMembers(element);\n }\n\n /** Compiles an element's members. */\n compileMembers(element: Element): void {\n var members = element.members;\n if (members) for (let element of members.values()) this.compileElement(element);\n }\n\n /** Compiles a file's exports. */\n compileExports(file: File): void {\n var exports = file.exports;\n if (exports) for (let element of exports.values()) this.compileElement(element);\n var exportsStar = file.exportsStar;\n if (exportsStar) {\n for (let exportStar of exportsStar) {\n this.compileFile(exportStar);\n this.compileExports(exportStar);\n }\n }\n }\n\n // files\n\n /** Compiles the file matching the specified path. */\n compileFileByPath(normalizedPathWithoutExtension: string, reportNode: Node): void {\n var file: File;\n var filesByName = this.program.filesByName;\n var pathWithIndex: string;\n if (filesByName.has(normalizedPathWithoutExtension)) {\n file = filesByName.get(normalizedPathWithoutExtension)!;\n } else if (filesByName.has(pathWithIndex = normalizedPathWithoutExtension + INDEX_SUFFIX)) {\n file = filesByName.get(pathWithIndex)!;\n } else {\n this.error(\n DiagnosticCode.File_0_not_found,\n reportNode.range, normalizedPathWithoutExtension\n );\n return;\n }\n this.compileFile(file);\n }\n\n /** Compiles the specified file. */\n compileFile(file: File): void {\n if (file.is(CommonFlags.COMPILED)) return;\n file.set(CommonFlags.COMPILED);\n\n // compile top-level statements within the file's start function\n var startFunction = file.startFunction;\n var previousBody = this.currentBody;\n var startFunctionBody = new Array();\n this.currentBody = startFunctionBody;\n\n // compile top-level statements\n var previousFlow = this.currentFlow;\n var flow = startFunction.flow;\n this.currentFlow = flow;\n for (let statements = file.source.statements, i = 0, k = statements.length; i < k; ++i) {\n this.compileTopLevelStatement(statements[i], startFunctionBody);\n }\n this.finishAutoreleases(flow, startFunctionBody);\n this.currentFlow = previousFlow;\n this.currentBody = previousBody;\n\n // if top-level statements are present, make the per-file start function and call it in start\n if (startFunctionBody.length) {\n let module = this.module;\n let locals = startFunction.localsByIndex;\n let numLocals = locals.length;\n let varTypes = new Array(numLocals);\n for (let i = 0; i < numLocals; ++i) varTypes[i] = locals[i].type.toNativeType();\n module.addFunction(\n startFunction.internalName,\n this.ensureFunctionType(startFunction.signature.parameterTypes, startFunction.signature.returnType),\n varTypes,\n startFunctionBody.length > 1\n ? module.block(null, startFunctionBody)\n : startFunctionBody[0]\n );\n previousBody.push(\n module.call(startFunction.internalName, null, NativeType.None)\n );\n }\n }\n\n // === Globals ==================================================================================\n\n compileGlobal(global: Global): bool {\n if (global.is(CommonFlags.COMPILED)) return true;\n global.set(CommonFlags.COMPILED);\n\n var module = this.module;\n var initExpr: ExpressionRef = 0;\n var initAutoreleaseSkipped: bool = false;\n var typeNode = global.typeNode;\n var initializerNode = global.initializerNode;\n\n if (!global.is(CommonFlags.RESOLVED)) {\n\n // Resolve type if annotated\n if (typeNode) {\n let resolvedType = this.resolver.resolveType(typeNode, global.parent); // reports\n if (!resolvedType) return false;\n if (resolvedType == Type.void) {\n this.error(\n DiagnosticCode.Type_expected,\n typeNode.range\n );\n return false;\n }\n global.setType(resolvedType);\n\n // Otherwise infer type from initializer\n } else if (initializerNode) {\n let previousFlow = this.currentFlow;\n if (global.hasDecorator(DecoratorFlags.LAZY)) {\n this.currentFlow = global.file.startFunction.flow;\n }\n initExpr = this.compileExpression(initializerNode, Type.auto, // reports\n Constraints.MUST_WRAP | Constraints.WILL_RETAIN\n );\n if (this.skippedAutoreleases.has(initExpr)) initAutoreleaseSkipped = true;\n this.currentFlow = previousFlow;\n if (this.currentType == Type.void) {\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n initializerNode.range, this.currentType.toString(), \"\"\n );\n return false;\n }\n global.setType(this.currentType);\n\n // Error if there's neither a type nor an initializer\n } else {\n this.error(\n DiagnosticCode.Type_expected,\n global.identifierNode.range.atEnd\n );\n return false;\n }\n }\n\n // Handle ambient builtins like '__heap_base' that need to be resolved but are added explicitly\n if (global.is(CommonFlags.AMBIENT) && global.hasDecorator(DecoratorFlags.BUILTIN)) {\n if (global.internalName == BuiltinSymbols.heap_base) this.runtimeFeatures |= RuntimeFeatures.HEAP;\n else if (global.internalName == BuiltinSymbols.rtti_base) this.runtimeFeatures |= RuntimeFeatures.RTTI;\n return true;\n }\n\n var type = global.type;\n var nativeType = type.toNativeType();\n var isDeclaredConstant = global.is(CommonFlags.CONST) || global.is(CommonFlags.STATIC | CommonFlags.READONLY);\n var isDeclaredInline = global.hasDecorator(DecoratorFlags.INLINE);\n\n // Handle imports\n if (global.is(CommonFlags.AMBIENT)) {\n\n // Constant global or mutable globals enabled\n if (isDeclaredConstant || this.options.hasFeature(Feature.MUTABLE_GLOBAL)) {\n global.set(CommonFlags.MODULE_IMPORT);\n mangleImportName(global, global.declaration);\n module.addGlobalImport(\n global.internalName,\n mangleImportName_moduleName,\n mangleImportName_elementName,\n nativeType\n );\n global.set(CommonFlags.COMPILED);\n return true;\n\n // Importing mutable globals is not supported in the MVP\n } else {\n this.error(\n DiagnosticCode.Operation_not_supported,\n global.declaration.range\n );\n }\n return false;\n }\n\n // The MVP does not yet support initializer expressions other than constant values (and constant\n // get_globals), hence such initializations must be performed in the start function for now.\n var initializeInStart = false;\n\n // Evaluate initializer if present\n if (initializerNode) {\n if (!initExpr) {\n let previousFlow = this.currentFlow;\n if (global.hasDecorator(DecoratorFlags.LAZY)) {\n this.currentFlow = global.file.startFunction.flow;\n }\n initExpr = this.compileExpression(initializerNode, type,\n Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP | Constraints.WILL_RETAIN | Constraints.PREFER_STATIC\n );\n if (this.skippedAutoreleases.has(initExpr)) initAutoreleaseSkipped = true;\n this.currentFlow = previousFlow;\n }\n\n if (getExpressionId(initExpr) != ExpressionId.Const) {\n if (isDeclaredConstant) {\n initExpr = module.precomputeExpression(initExpr);\n if (getExpressionId(initExpr) != ExpressionId.Const) initializeInStart = true;\n } else {\n initializeInStart = true;\n }\n }\n\n // Explicitly inline if annotated\n if (isDeclaredInline) {\n if (initializeInStart) {\n this.warning(\n DiagnosticCode.Mutable_value_cannot_be_inlined,\n initializerNode.range\n );\n } else {\n assert(getExpressionId(initExpr) == ExpressionId.Const);\n let exprType = getExpressionType(initExpr);\n switch (exprType) {\n case NativeType.I32: {\n global.constantValueKind = ConstantValueKind.INTEGER;\n global.constantIntegerValue = i64_new(getConstValueI32(initExpr), 0);\n break;\n }\n case NativeType.I64: {\n global.constantValueKind = ConstantValueKind.INTEGER;\n global.constantIntegerValue = i64_new(\n getConstValueI64Low(initExpr),\n getConstValueI64High(initExpr)\n );\n break;\n }\n case NativeType.F32: {\n global.constantValueKind = ConstantValueKind.FLOAT;\n global.constantFloatValue = getConstValueF32(initExpr);\n break;\n }\n case NativeType.F64: {\n global.constantValueKind = ConstantValueKind.FLOAT;\n global.constantFloatValue = getConstValueF64(initExpr);\n break;\n }\n default: {\n assert(false);\n return false;\n }\n }\n global.set(CommonFlags.INLINED); // inline the value from now on\n }\n }\n\n // Initialize to zero if there's no initializer\n } else {\n initExpr = type.toNativeZero(module);\n }\n\n var internalName = global.internalName;\n\n if (initializeInStart) { // initialize to mutable zero and set the actual value in start\n if (isDeclaredInline) {\n this.error(\n DiagnosticCode.Decorator_0_is_not_valid_here,\n assert(findDecorator(DecoratorKind.INLINE, global.decoratorNodes)).range, \"inline\"\n );\n }\n module.addGlobal(internalName, nativeType, true, type.toNativeZero(module));\n if (type.isManaged && !initAutoreleaseSkipped) initExpr = this.makeRetain(initExpr);\n this.currentBody.push(\n module.global_set(internalName, initExpr)\n );\n } else if (!isDeclaredInline) { // compile normally\n module.addGlobal(internalName, nativeType, !isDeclaredConstant, initExpr);\n }\n return true;\n }\n\n // === Enums ====================================================================================\n\n compileEnum(element: Enum): bool {\n if (element.is(CommonFlags.COMPILED)) return true;\n element.set(CommonFlags.COMPILED);\n\n var module = this.module;\n this.currentEnum = element;\n var previousValue: EnumValue | null = null;\n var previousValueIsMut = false;\n var isInline = element.is(CommonFlags.CONST) || element.hasDecorator(DecoratorFlags.INLINE);\n\n if (element.members) {\n for (let member of element.members.values()) {\n if (member.kind != ElementKind.ENUMVALUE) continue; // happens if an enum is also a namespace\n let initInStart = false;\n let val = member;\n let valueNode = val.valueNode;\n val.set(CommonFlags.COMPILED);\n let previousFlow = this.currentFlow;\n if (element.hasDecorator(DecoratorFlags.LAZY)) {\n this.currentFlow = element.file.startFunction.flow;\n }\n let initExpr: ExpressionRef;\n if (valueNode) {\n initExpr = this.compileExpression(valueNode, Type.i32,\n Constraints.CONV_IMPLICIT // autorelease is not applicable in i32 context\n );\n if (getExpressionId(initExpr) != ExpressionId.Const) {\n initExpr = module.precomputeExpression(initExpr);\n if (getExpressionId(initExpr) != ExpressionId.Const) {\n if (element.is(CommonFlags.CONST)) {\n this.error(\n DiagnosticCode.In_const_enum_declarations_member_initializer_must_be_constant_expression,\n valueNode.range\n );\n }\n initInStart = true;\n }\n }\n } else if (previousValue == null) {\n initExpr = module.i32(0);\n } else {\n if (previousValueIsMut) {\n this.error(\n DiagnosticCode.Enum_member_must_have_initializer,\n (member).identifierNode.range.atEnd\n );\n }\n initExpr = module.binary(BinaryOp.AddI32,\n module.global_get(previousValue.internalName, NativeType.I32),\n module.i32(1)\n );\n initExpr = module.precomputeExpression(initExpr);\n if (getExpressionId(initExpr) != ExpressionId.Const) {\n if (element.is(CommonFlags.CONST)) {\n this.error(\n DiagnosticCode.In_const_enum_declarations_member_initializer_must_be_constant_expression,\n member.declaration.range\n );\n }\n initInStart = true;\n }\n }\n this.currentFlow = previousFlow;\n if (initInStart) {\n module.addGlobal(val.internalName, NativeType.I32, true, module.i32(0));\n this.currentBody.push(\n this.makeGlobalAssignment(val, initExpr, false)\n );\n previousValueIsMut = true;\n } else {\n if (isInline) {\n val.setConstantIntegerValue(i64_new(getConstValueI32(initExpr)), Type.i32);\n if (val.is(CommonFlags.MODULE_EXPORT)) {\n module.addGlobal(val.internalName, NativeType.I32, false, initExpr);\n }\n } else {\n module.addGlobal(val.internalName, NativeType.I32, false, initExpr);\n }\n val.isImmutable = true;\n previousValueIsMut = false;\n }\n previousValue = val;\n }\n }\n this.currentEnum = null;\n return true;\n }\n\n // === Functions ================================================================================\n\n /** Resolves the specified type arguments prior to compiling the resulting function instance. */\n compileFunctionUsingTypeArguments(\n prototype: FunctionPrototype,\n typeArguments: NamedTypeNode[],\n contextualTypeArguments: Map = makeMap(),\n alternativeReportNode: Node | null = null\n ): Function | null {\n if (prototype.hasDecorator(DecoratorFlags.BUILTIN)) return null;\n var instance = this.resolver.resolveFunctionInclTypeArguments(\n prototype,\n typeArguments,\n prototype.parent, // relative to itself\n contextualTypeArguments,\n alternativeReportNode || prototype.declaration\n );\n if (!instance) return null;\n if (!this.compileFunction(instance)) return null; // reports\n return instance;\n }\n\n /** Either reuses or creates the function type matching the specified signature. */\n ensureFunctionType(\n parameterTypes: Type[] | null,\n returnType: Type,\n thisType: Type | null = null\n ): FunctionTypeRef {\n var numParameters = parameterTypes ? parameterTypes.length : 0;\n var paramTypes: NativeType[];\n var index = 0;\n if (thisType) {\n paramTypes = new Array(1 + numParameters);\n paramTypes[0] = thisType.toNativeType();\n index = 1;\n } else {\n paramTypes = new Array(numParameters);\n }\n if (parameterTypes) {\n for (let i = 0; i < numParameters; ++i, ++index) {\n paramTypes[index] = parameterTypes[i].toNativeType();\n }\n }\n var resultType = returnType.toNativeType();\n var module = this.module;\n var typeRef = module.getFunctionTypeBySignature(resultType, paramTypes);\n if (!typeRef) {\n let name = Signature.makeSignatureString(parameterTypes, returnType, thisType);\n typeRef = module.addFunctionType(name, resultType, paramTypes);\n }\n return typeRef;\n }\n\n /** Compiles the body of a function within the specified flow. */\n compileFunctionBody(\n /** Function to compile. */\n instance: Function,\n /** Target array of statements. */\n stmts: ExpressionRef[] | null = null\n ): ExpressionRef[] {\n var module = this.module;\n var bodyNode = assert(instance.prototype.bodyNode);\n var returnType = instance.signature.returnType;\n var flow = this.currentFlow;\n\n // compile statements\n if (bodyNode.kind == NodeKind.BLOCK) {\n stmts = this.compileStatements((bodyNode).statements, true, stmts);\n } else {\n // must be an expression statement if not a block\n assert(bodyNode.kind == NodeKind.EXPRESSION);\n\n // must be an arrow function\n assert(instance.prototype.arrowKind);\n\n // none of the following can be an arrow function\n assert(!instance.isAny(CommonFlags.CONSTRUCTOR | CommonFlags.GET | CommonFlags.SET | CommonFlags.MAIN));\n\n let expr = this.compileExpression((bodyNode).expression, returnType,\n Constraints.CONV_IMPLICIT\n );\n if (!stmts) stmts = [ expr ];\n else stmts.push(expr);\n if (!flow.is(FlowFlags.TERMINATES)) { // TODO: detect if returning an autorelease local?\n let indexBefore = stmts.length;\n this.performAutoreleases(flow, stmts);\n this.finishAutoreleases(flow, stmts);\n let canOverflow = flow.canOverflow(expr, returnType);\n let nonNull = flow.isNonnull(expr, returnType);\n if (stmts.length > indexBefore) {\n let temp = flow.getAndFreeTempLocal(returnType);\n if (!canOverflow) flow.setLocalFlag(temp.index, LocalFlags.WRAPPED);\n if (nonNull) flow.setLocalFlag(temp.index, LocalFlags.NONNULL);\n stmts[indexBefore - 1] = module.local_set(temp.index, expr);\n stmts.push(module.local_get(temp.index, returnType.toNativeType()));\n }\n if (!canOverflow) flow.set(FlowFlags.RETURNS_WRAPPED);\n if (nonNull) flow.set(FlowFlags.RETURNS_NONNULL);\n flow.set(FlowFlags.RETURNS | FlowFlags.TERMINATES);\n }\n }\n\n // make constructors return their instance pointer\n if (instance.is(CommonFlags.CONSTRUCTOR)) {\n let nativeSizeType = this.options.nativeSizeType;\n assert(instance.is(CommonFlags.INSTANCE));\n let classInstance = assert(instance.parent); assert(classInstance.kind == ElementKind.CLASS);\n\n if (!flow.is(FlowFlags.TERMINATES)) {\n let thisLocal = assert(flow.lookupLocal(CommonSymbols.this_));\n\n // if `this` wasn't accessed before, allocate if necessary and initialize `this`\n if (!flow.is(FlowFlags.ALLOCATES)) {\n // {\n // if (!this) this = \n // this.a = X\n // this.b = Y\n // }\n stmts.push(\n module.if(\n module.unary(nativeSizeType == NativeType.I64 ? UnaryOp.EqzI64 : UnaryOp.EqzI32,\n module.local_get(thisLocal.index, nativeSizeType)\n ),\n module.local_set(thisLocal.index,\n this.makeRetain(\n this.makeAllocation(classInstance)\n ),\n )\n )\n );\n this.makeFieldInitialization(classInstance, stmts);\n }\n this.performAutoreleases(flow, stmts); // `this` is excluded anyway\n this.finishAutoreleases(flow, stmts);\n stmts.push(module.local_get(thisLocal.index, this.options.nativeSizeType));\n flow.set(FlowFlags.RETURNS | FlowFlags.RETURNS_NONNULL | FlowFlags.TERMINATES);\n }\n\n // check that super has been called if this is a derived class\n if ((classInstance).base && !flow.is(FlowFlags.CALLS_SUPER)) {\n this.error(\n DiagnosticCode.Constructors_for_derived_classes_must_contain_a_super_call,\n instance.prototype.declaration.range\n );\n }\n\n // if this is a normal function, make sure that all branches terminate\n } else if (returnType != Type.void && !flow.is(FlowFlags.TERMINATES)) {\n this.error(\n DiagnosticCode.A_function_whose_declared_type_is_not_void_must_return_a_value,\n instance.prototype.functionTypeNode.returnType.range\n );\n }\n\n return stmts;\n }\n\n /** Compiles a readily resolved function instance. */\n compileFunction(instance: Function): bool {\n if (instance.is(CommonFlags.COMPILED)) return true;\n assert(!(instance.is(CommonFlags.AMBIENT) && instance.hasDecorator(DecoratorFlags.BUILTIN)));\n\n var previousType = this.currentType; // remember to retain it if compiling a function lazily\n instance.set(CommonFlags.COMPILED);\n\n var module = this.module;\n var signature = instance.signature;\n var bodyNode = instance.prototype.bodyNode;\n\n var typeRef = this.ensureFunctionType(signature.parameterTypes, signature.returnType, signature.thisType);\n var funcRef: FunctionRef;\n\n // concrete function\n if (bodyNode) {\n\n // must not be ambient\n if (instance.is(CommonFlags.AMBIENT)) {\n this.error(\n DiagnosticCode.An_implementation_cannot_be_declared_in_ambient_contexts,\n instance.identifierNode.range\n );\n }\n\n // cannot have an annotated external name\n if (instance.hasDecorator(DecoratorFlags.EXTERNAL)) {\n let decoratorNodes = instance.decoratorNodes;\n let decorator = assert(findDecorator(DecoratorKind.EXTERNAL, decoratorNodes));\n this.error(\n DiagnosticCode.Operation_not_supported,\n decorator.range\n );\n }\n\n // compile body in this function's context\n let previousFlow = this.currentFlow;\n let flow = instance.flow;\n this.currentFlow = flow;\n let stmts = new Array();\n\n // retain each argument for as long as the function lives\n let index = 0;\n let thisType = signature.thisType;\n if (thisType) {\n // No need to retain `this` as it can't be reassigned and thus can't become prematurely released\n ++index;\n }\n let parameterTypes = signature.parameterTypes;\n for (let i = 0, k = parameterTypes.length; i < k; ++i, ++index) {\n let type = parameterTypes[i];\n if (type.isManaged) {\n stmts.push(\n module.drop(\n this.makeRetain(\n module.local_get(index, type.toNativeType())\n )\n )\n );\n flow.setLocalFlag(index, LocalFlags.RETAINED);\n }\n }\n\n this.compileFunctionBody(instance, stmts);\n if (!flow.is(FlowFlags.TERMINATES)) {\n this.performAutoreleases(flow, stmts);\n this.finishAutoreleases(flow, stmts);\n }\n this.currentFlow = previousFlow;\n\n // create the function\n funcRef = module.addFunction(\n instance.internalName,\n typeRef,\n typesToNativeTypes(instance.additionalLocals),\n flatten(module, stmts, instance.signature.returnType.toNativeType())\n );\n\n // imported function\n } else {\n if (!instance.is(CommonFlags.AMBIENT)) {\n this.error(\n DiagnosticCode.Function_implementation_is_missing_or_not_immediately_following_the_declaration,\n instance.identifierNode.range\n );\n }\n\n instance.set(CommonFlags.MODULE_IMPORT);\n mangleImportName(instance, instance.declaration); // TODO: check for duplicates\n\n // create the import\n funcRef = module.addFunctionImport(\n instance.internalName,\n mangleImportName_moduleName,\n mangleImportName_elementName,\n typeRef\n );\n }\n\n instance.finalize(module, funcRef);\n this.currentType = previousType;\n return true;\n }\n\n // === Classes ==================================================================================\n\n compileClassUsingTypeArguments(\n prototype: ClassPrototype,\n typeArguments: NamedTypeNode[],\n contextualTypeArguments: Map = makeMap(),\n alternativeReportNode: Node | null = null\n ): void {\n var instance = this.resolver.resolveClassInclTypeArguments(\n prototype,\n typeArguments,\n prototype.parent, // relative to itself\n contextualTypeArguments,\n alternativeReportNode || prototype.declaration\n );\n if (!instance) return;\n this.compileClass(instance);\n }\n\n compileClass(instance: Class): bool {\n if (instance.is(CommonFlags.COMPILED)) return true;\n instance.set(CommonFlags.COMPILED);\n var prototype = instance.prototype;\n var staticMembers = (prototype).members;\n if (staticMembers) {\n for (let element of staticMembers.values()) {\n switch (element.kind) {\n case ElementKind.GLOBAL: {\n this.compileGlobal(element);\n break;\n }\n case ElementKind.FUNCTION_PROTOTYPE: {\n if (\n !(element).is(CommonFlags.GENERIC)\n ) {\n this.compileFunctionUsingTypeArguments(\n element,\n [],\n makeMap(),\n (element).identifierNode\n );\n }\n break;\n }\n case ElementKind.PROPERTY_PROTOTYPE: {\n let getter = (element).getterPrototype;\n if (getter) {\n this.compileFunctionUsingTypeArguments(\n getter,\n [],\n makeMap(),\n getter.identifierNode\n );\n }\n let setter = (element).setterPrototype;\n if (setter) {\n this.compileFunctionUsingTypeArguments(\n setter,\n [],\n makeMap(),\n setter.identifierNode\n );\n }\n break;\n }\n case ElementKind.PROPERTY: {\n }\n }\n }\n }\n var ctorInstance = instance.constructorInstance;\n if (ctorInstance) this.compileFunction(ctorInstance);\n var instanceMembers = instance.members;\n if (instanceMembers) {\n for (let element of instanceMembers.values()) {\n switch (element.kind) {\n case ElementKind.FUNCTION_PROTOTYPE: {\n if (\n !(element).is(CommonFlags.GENERIC)\n ) {\n this.compileFunctionUsingTypeArguments(\n element,\n [],\n makeMap(instance.contextualTypeArguments),\n (element).declaration.name\n );\n }\n break;\n }\n case ElementKind.FIELD_PROTOTYPE: {\n element.set(CommonFlags.COMPILED);\n break;\n }\n case ElementKind.PROPERTY: {\n let getter = (element).getterInstance;\n if (getter) this.compileFunction(getter);\n let setter = (element).setterInstance;\n if (setter) this.compileFunction(setter);\n break;\n }\n }\n }\n }\n return true;\n }\n\n compileInterfaceDeclaration(\n declaration: InterfaceDeclaration,\n typeArguments: NamedTypeNode[],\n contextualTypeArguments: Map | null = null,\n alternativeReportNode: Node | null = null\n ): void {\n // TODO\n this.error(\n DiagnosticCode.Operation_not_supported,\n declaration.range\n );\n }\n\n // === Memory ===================================================================================\n\n /** Adds a static memory segment with the specified data. */\n addMemorySegment(buffer: Uint8Array, alignment: i32 = 8): MemorySegment {\n var memoryOffset = i64_align(this.memoryOffset, alignment);\n var segment = MemorySegment.create(buffer, memoryOffset);\n this.memorySegments.push(segment);\n this.memoryOffset = i64_add(memoryOffset, i64_new(buffer.length, 0));\n return segment;\n }\n\n /** Ensures that the specified string exists in static memory and returns a pointer to it. */\n ensureStaticString(stringValue: string): ExpressionRef {\n var program = this.program;\n var rtHeaderSize = program.runtimeHeaderSize;\n var stringInstance = assert(program.stringInstance);\n var stringSegment: MemorySegment;\n var segments = this.stringSegments;\n if (segments.has(stringValue)) {\n stringSegment = segments.get(stringValue)!; // reuse\n } else {\n let length = stringValue.length;\n let buffer = new Uint8Array(rtHeaderSize + (length << 1));\n program.writeRuntimeHeader(buffer, 0, stringInstance, length << 1);\n for (let i = 0; i < length; ++i) {\n writeI16(stringValue.charCodeAt(i), buffer, rtHeaderSize + (i << 1));\n }\n stringSegment = this.addMemorySegment(buffer);\n segments.set(stringValue, stringSegment);\n }\n var ref = i64_add(stringSegment.offset, i64_new(rtHeaderSize));\n this.currentType = stringInstance.type;\n if (this.options.isWasm64) {\n return this.module.i64(i64_low(ref), i64_high(ref));\n } else {\n assert(i64_is_u32(ref));\n return this.module.i32(i64_low(ref));\n }\n }\n\n ensureStaticArrayBuffer(elementType: Type, values: ExpressionRef[]): MemorySegment {\n var program = this.program;\n var length = values.length;\n var byteSize = elementType.byteSize;\n var byteLength = length * byteSize;\n var bufferInstance = assert(program.arrayBufferInstance);\n var runtimeHeaderSize = program.runtimeHeaderSize;\n\n var buf = new Uint8Array(runtimeHeaderSize + byteLength);\n program.writeRuntimeHeader(buf, 0, bufferInstance, byteLength);\n var pos = runtimeHeaderSize;\n var nativeType = elementType.toNativeType();\n switch (nativeType) {\n case NativeType.I32: {\n switch (byteSize) {\n case 1: {\n for (let i = 0; i < length; ++i) {\n let value = values[i];\n assert(getExpressionType(value) == nativeType);\n assert(getExpressionId(value) == ExpressionId.Const);\n writeI8(getConstValueI32(value), buf, pos);\n pos += 1;\n }\n break;\n }\n case 2: {\n for (let i = 0; i < length; ++i) {\n let value = values[i];\n assert(getExpressionType(value) == nativeType);\n assert(getExpressionId(value) == ExpressionId.Const);\n writeI16(getConstValueI32(value), buf, pos);\n pos += 2;\n }\n break;\n }\n case 4: {\n for (let i = 0; i < length; ++i) {\n let value = values[i];\n assert(getExpressionType(value) == nativeType);\n assert(getExpressionId(value) == ExpressionId.Const);\n writeI32(getConstValueI32(value), buf, pos);\n pos += 4;\n }\n break;\n }\n default: assert(false);\n }\n break;\n }\n case NativeType.I64: {\n for (let i = 0; i < length; ++i) {\n let value = values[i];\n assert(getExpressionType(value) == nativeType);\n assert(getExpressionId(value) == ExpressionId.Const);\n writeI64(i64_new(getConstValueI64Low(value), getConstValueI64High(value)), buf, pos);\n pos += 8;\n }\n break;\n }\n case NativeType.F32: {\n for (let i = 0; i < length; ++i) {\n let value = values[i];\n assert(getExpressionType(value) == nativeType);\n assert(getExpressionId(value) == ExpressionId.Const);\n writeF32(getConstValueF32(value), buf, pos);\n pos += 4;\n }\n break;\n }\n case NativeType.F64: {\n for (let i = 0; i < length; ++i) {\n let value = values[i];\n assert(getExpressionType(value) == nativeType);\n assert(getExpressionId(value) == ExpressionId.Const);\n writeF64(getConstValueF64(value), buf, pos);\n pos += 8;\n }\n break;\n }\n default: assert(false);\n }\n assert(pos == buf.length);\n\n return this.addMemorySegment(buf);\n }\n\n ensureStaticArrayHeader(elementType: Type, bufferSegment: MemorySegment): MemorySegment {\n var program = this.program;\n var runtimeHeaderSize = program.runtimeHeaderSize;\n var arrayPrototype = assert(program.arrayPrototype);\n var arrayInstance = assert(this.resolver.resolveClass(arrayPrototype, [ elementType ]));\n var arrayInstanceSize = arrayInstance.currentMemoryOffset;\n var bufferLength = bufferSegment.buffer.length - runtimeHeaderSize;\n var arrayLength = i32(bufferLength / elementType.byteSize);\n\n var buf = new Uint8Array(runtimeHeaderSize + arrayInstanceSize);\n program.writeRuntimeHeader(buf, 0, arrayInstance, arrayInstanceSize);\n\n var bufferAddress32 = i64_low(bufferSegment.offset) + runtimeHeaderSize;\n assert(!program.options.isWasm64); // TODO\n assert(arrayInstance.writeField(\"data\", bufferAddress32, buf, runtimeHeaderSize));\n assert(arrayInstance.writeField(\"dataStart\", bufferAddress32, buf, runtimeHeaderSize));\n assert(arrayInstance.writeField(\"dataLength\", bufferLength, buf, runtimeHeaderSize));\n assert(arrayInstance.writeField(\"length_\", arrayLength, buf, runtimeHeaderSize));\n\n return this.addMemorySegment(buf);\n }\n\n // === Table ====================================================================================\n\n /** Ensures that a table entry exists for the specified function and returns its index. */\n ensureFunctionTableEntry(func: Function): i32 {\n assert(func.is(CommonFlags.COMPILED));\n if (func.functionTableIndex >= 0) {\n return func.functionTableIndex;\n }\n var functionTable = this.functionTable;\n var index = functionTable.length;\n if (!func.is(CommonFlags.TRAMPOLINE) && func.signature.requiredParameters < func.signature.parameterTypes.length) {\n // insert the trampoline if the function has optional parameters\n func = this.ensureTrampoline(func);\n }\n functionTable.push(func.internalName);\n func.functionTableIndex = index;\n return index;\n }\n\n // === Statements ===============================================================================\n\n compileTopLevelStatement(statement: Statement, body: ExpressionRef[]): void {\n if (statement.kind == NodeKind.EXPORTDEFAULT) {\n statement = (statement).declaration;\n }\n switch (statement.kind) {\n case NodeKind.CLASSDECLARATION: {\n let memberStatements = (statement).members;\n for (let i = 0, k = memberStatements.length; i < k; ++i) {\n this.compileTopLevelStatement(memberStatements[i], body);\n }\n break;\n }\n case NodeKind.ENUMDECLARATION: {\n let element = this.program.getElementByDeclaration(statement);\n assert(element.kind == ElementKind.ENUM);\n if (!element.hasDecorator(DecoratorFlags.LAZY)) this.compileEnum(element);\n break;\n }\n case NodeKind.NAMESPACEDECLARATION: {\n let memberStatements = (statement).members;\n for (let i = 0, k = memberStatements.length; i < k; ++i) {\n this.compileTopLevelStatement(memberStatements[i], body);\n }\n break;\n }\n case NodeKind.VARIABLE: {\n let declarations = (statement).declarations;\n for (let i = 0, k = declarations.length; i < k; ++i) {\n let element = this.program.getElementByDeclaration(declarations[i]);\n assert(element.kind == ElementKind.GLOBAL);\n if (\n !element.is(CommonFlags.AMBIENT) && // delay imports\n !element.hasDecorator(DecoratorFlags.LAZY)\n ) this.compileGlobal(element);\n }\n break;\n }\n case NodeKind.FIELDDECLARATION: {\n let element = this.program.getElementByDeclaration(statement);\n if (element.kind == ElementKind.GLOBAL) { // static\n if (!element.hasDecorator(DecoratorFlags.LAZY)) this.compileGlobal(element);\n }\n break;\n }\n case NodeKind.EXPORT: {\n if ((statement).normalizedPath != null) {\n this.compileFileByPath(\n (statement).normalizedPath,\n (statement).path\n );\n }\n break;\n }\n case NodeKind.IMPORT: {\n this.compileFileByPath(\n (statement).normalizedPath,\n (statement).path\n );\n break;\n }\n case NodeKind.FUNCTIONDECLARATION:\n case NodeKind.METHODDECLARATION:\n case NodeKind.INTERFACEDECLARATION:\n case NodeKind.INDEXSIGNATUREDECLARATION:\n case NodeKind.TYPEDECLARATION: break;\n default: { // otherwise a top-level statement that is part of the start function's body\n let stmt = this.compileStatement(statement);\n if (getExpressionId(stmt) != ExpressionId.Nop) body.push(stmt);\n break;\n }\n }\n }\n\n compileStatement(\n statement: Statement,\n isLastInBody: bool = false\n ): ExpressionRef {\n var module = this.module;\n var stmt: ExpressionRef;\n switch (statement.kind) {\n case NodeKind.BLOCK: {\n stmt = this.compileBlockStatement(statement);\n break;\n }\n case NodeKind.BREAK: {\n stmt = this.compileBreakStatement(statement);\n break;\n }\n case NodeKind.CONTINUE: {\n stmt = this.compileContinueStatement(statement);\n break;\n }\n case NodeKind.DO: {\n stmt = this.compileDoStatement(statement);\n break;\n }\n case NodeKind.EMPTY: {\n stmt = this.compileEmptyStatement(statement);\n break;\n }\n case NodeKind.EXPRESSION: {\n stmt = this.compileExpressionStatement(statement);\n break;\n }\n case NodeKind.FOR: {\n stmt = this.compileForStatement(statement);\n break;\n }\n case NodeKind.IF: {\n stmt = this.compileIfStatement(statement);\n break;\n }\n case NodeKind.RETURN: {\n stmt = this.compileReturnStatement(statement, isLastInBody);\n break;\n }\n case NodeKind.SWITCH: {\n stmt = this.compileSwitchStatement(statement);\n break;\n }\n case NodeKind.THROW: {\n stmt = this.compileThrowStatement(statement);\n break;\n }\n case NodeKind.TRY: {\n stmt = this.compileTryStatement(statement);\n break;\n }\n case NodeKind.VARIABLE: {\n stmt = this.compileVariableStatement(statement);\n if (!stmt) stmt = module.nop();\n break;\n }\n case NodeKind.VOID: {\n stmt = this.compileVoidStatement(statement);\n break;\n }\n case NodeKind.WHILE: {\n stmt = this.compileWhileStatement(statement);\n break;\n }\n case NodeKind.TYPEDECLARATION: {\n // TODO: integrate inner type declaration into flow\n this.error(\n DiagnosticCode.Operation_not_supported,\n statement.range\n );\n stmt = module.unreachable();\n break;\n }\n default: {\n assert(false);\n stmt = module.unreachable();\n }\n }\n if (this.options.sourceMap) this.addDebugLocation(stmt, statement.range);\n return stmt;\n }\n\n compileStatements(\n statements: Statement[],\n isBody: bool = false,\n stmts: ExpressionRef[] | null = null\n ): ExpressionRef[] {\n var numStatements = statements.length;\n if (!stmts) {\n stmts = new Array(numStatements);\n stmts.length = 0;\n }\n var module = this.module;\n var flow = this.currentFlow;\n for (let i = 0; i < numStatements; ++i) {\n let stmt = this.compileStatement(statements[i], isBody && i == numStatements - 1);\n switch (getExpressionId(stmt)) {\n case ExpressionId.Block: {\n if (!getBlockName(stmt)) {\n for (let j = 0, k = getBlockChildCount(stmt); j < k; ++j) stmts.push(getBlockChild(stmt, j));\n break;\n }\n // fall-through\n }\n default: stmts.push(stmt);\n case ExpressionId.Nop:\n }\n if (flow.isAny(FlowFlags.TERMINATES | FlowFlags.BREAKS)) {\n if (needsExplicitUnreachable(stmt)) stmts.push(module.unreachable());\n break;\n }\n }\n return stmts;\n }\n\n compileBlockStatement(\n statement: BlockStatement\n ): ExpressionRef {\n var statements = statement.statements;\n var outerFlow = this.currentFlow;\n var innerFlow = outerFlow.fork();\n this.currentFlow = innerFlow;\n\n var stmts = this.compileStatements(statements);\n if (!innerFlow.isAny(FlowFlags.TERMINATES | FlowFlags.BREAKS)) this.performAutoreleases(innerFlow, stmts);\n innerFlow.freeScopedLocals();\n outerFlow.inherit(innerFlow); // TODO: only if not terminated?\n this.currentFlow = outerFlow;\n return flatten(this.module, stmts, NativeType.None);\n }\n\n compileBreakStatement(\n statement: BreakStatement\n ): ExpressionRef {\n var module = this.module;\n if (statement.label) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n statement.label.range\n );\n return module.unreachable();\n }\n var flow = this.currentFlow;\n var breakLabel = flow.breakLabel;\n if (breakLabel == null) {\n this.error(\n DiagnosticCode.A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement,\n statement.range\n );\n return module.unreachable();\n }\n var stmts = new Array();\n this.performAutoreleases(flow, stmts);\n var parent = flow.parent;\n while (parent !== null && parent.breakLabel == breakLabel) {\n this.performAutoreleases(parent, stmts, /* clearFlags */ false);\n parent = parent.parent;\n }\n flow.freeScopedLocals();\n stmts.push(module.br(breakLabel));\n flow.set(FlowFlags.BREAKS);\n return flatten(module, stmts, NativeType.None);\n }\n\n compileContinueStatement(\n statement: ContinueStatement\n ): ExpressionRef {\n var module = this.module;\n var label = statement.label;\n if (label) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n label.range\n );\n return module.unreachable();\n }\n // Check if 'continue' is allowed here\n var flow = this.currentFlow;\n var continueLabel = flow.continueLabel;\n if (continueLabel == null) {\n this.error(\n DiagnosticCode.A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement,\n statement.range\n );\n return module.unreachable();\n }\n flow.set(FlowFlags.CONTINUES | FlowFlags.TERMINATES);\n var stmts = new Array();\n this.performAutoreleases(flow, stmts);\n var current: Flow | null = flow.parent;\n while (current && current.continueLabel === continueLabel) {\n this.performAutoreleases(current, stmts, /* clearFlags */ false);\n current = current.parent;\n }\n flow.freeScopedLocals();\n stmts.push(module.br(continueLabel));\n return flatten(module, stmts, NativeType.None);\n }\n\n compileDoStatement(\n statement: DoStatement\n ): ExpressionRef {\n var module = this.module;\n\n var outerFlow = this.currentFlow;\n var label = outerFlow.pushBreakLabel();\n var innerFlow = outerFlow.fork();\n this.currentFlow = innerFlow;\n var breakLabel = \"break|\" + label;\n innerFlow.breakLabel = breakLabel;\n var continueLabel = \"continue|\" + label;\n innerFlow.continueLabel = continueLabel;\n\n var stmts = new Array();\n if (statement.statement.kind == NodeKind.BLOCK) {\n this.compileStatements((statement.statement).statements, false, stmts);\n } else {\n stmts.push(\n this.compileStatement(statement.statement)\n );\n }\n var condExpr = module.precomputeExpression(\n this.makeIsTrueish(\n this.compileExpression(statement.condition, Type.i32),\n this.currentType\n )\n );\n var alwaysFalse = false;\n if (getExpressionId(condExpr) == ExpressionId.Const) {\n assert(getExpressionType(condExpr) == NativeType.I32);\n if (!getConstValueI32(condExpr)) alwaysFalse = true;\n }\n var terminates = innerFlow.is(FlowFlags.TERMINATES);\n var continues = innerFlow.isAny(FlowFlags.CONTINUES | FlowFlags.CONDITIONALLY_CONTINUES);\n var breaks = innerFlow.isAny(FlowFlags.BREAKS | FlowFlags.CONDITIONALLY_BREAKS);\n\n // (block $break ;; (1) skip if no breaks\n // (loop $continue ;; (2) skip if skipping (4) + no continues\n // (...) ;; (3)\n // (br_if cond $continue) ;; (4) skip if (3) does not fall through or always false\n // )\n // )\n var fallsThrough = !terminates && !innerFlow.is(FlowFlags.BREAKS);\n\n if (fallsThrough && !alwaysFalse) { // (4)\n stmts.push(module.br(continueLabel, condExpr));\n }\n var expr = flatten(module, stmts, NativeType.None);\n if (fallsThrough && !alwaysFalse || continues) { // (2)\n expr = module.loop(continueLabel, expr);\n }\n if (breaks) { // (1)\n expr = module.block(breakLabel, [ expr ]);\n }\n\n // Switch back to the parent flow\n if (!terminates) this.performAutoreleases(innerFlow, stmts);\n innerFlow.freeScopedLocals();\n outerFlow.popBreakLabel();\n innerFlow.unset(\n FlowFlags.BREAKS |\n FlowFlags.CONDITIONALLY_BREAKS |\n FlowFlags.CONTINUES |\n FlowFlags.CONDITIONALLY_CONTINUES\n );\n outerFlow.inherit(innerFlow);\n this.currentFlow = outerFlow;\n return expr;\n }\n\n compileEmptyStatement(\n statement: EmptyStatement\n ): ExpressionRef {\n return this.module.nop();\n }\n\n compileExpressionStatement(\n statement: ExpressionStatement\n ): ExpressionRef {\n return this.compileExpression(statement.expression, Type.void, Constraints.CONV_IMPLICIT);\n }\n\n compileForStatement(\n statement: ForStatement\n ): ExpressionRef {\n var module = this.module;\n\n // Set up and use the inner flow\n var outerFlow = this.currentFlow;\n var label = outerFlow.pushBreakLabel();\n var innerFlow = outerFlow.fork();\n this.currentFlow = innerFlow;\n\n // Compile the initializer\n var initializer = statement.initializer;\n var initExpr: ExpressionRef = 0;\n if (initializer) initExpr = this.compileStatement(initializer);\n\n // Compile the condition\n var condExpr: ExpressionRef = 0;\n var alwaysTrue = false;\n if (statement.condition) {\n condExpr = module.precomputeExpression(\n this.makeIsTrueish(\n this.compileExpression(statement.condition, Type.bool),\n this.currentType\n )\n );\n // Simplify if the condition is constant\n if (getExpressionId(condExpr) == ExpressionId.Const) {\n assert(getExpressionType(condExpr) == NativeType.I32);\n if (getConstValueI32(condExpr) == /* false */ 0) {\n let stmts = new Array();\n if (initExpr) stmts.push(initExpr);\n this.performAutoreleases(innerFlow, stmts);\n innerFlow.freeScopedLocals();\n outerFlow.popBreakLabel();\n this.currentFlow = outerFlow;\n return flatten(module, stmts, NativeType.None);\n }\n alwaysTrue = true;\n }\n } else { // Omitted condition is always true\n condExpr = module.i32(1);\n alwaysTrue = true;\n }\n innerFlow.inheritNonnullIfTrue(condExpr);\n\n // Compile incrementor\n var incrementor = statement.incrementor;\n var incrExpr: ExpressionRef = 0;\n if (incrementor) incrExpr = this.compileExpression(incrementor, Type.void, Constraints.CONV_IMPLICIT | Constraints.WILL_DROP);\n\n // Compile body (break: drop out, continue: fall through to incrementor, + loop)\n var breakLabel = innerFlow.breakLabel = \"break|\" + label; innerFlow.breakLabel = breakLabel;\n innerFlow.breakLabel = breakLabel;\n var continueLabel = \"continue|\" + label;\n innerFlow.continueLabel = continueLabel;\n var loopLabel = \"loop|\" + label;\n var bodyStatement = statement.statement;\n var stmts = new Array();\n if (bodyStatement.kind == NodeKind.BLOCK) {\n this.compileStatements((bodyStatement).statements, false, stmts);\n } else {\n stmts.push(this.compileStatement(bodyStatement));\n }\n var terminates = innerFlow.is(FlowFlags.TERMINATES);\n var continues = innerFlow.isAny(FlowFlags.CONTINUES | FlowFlags.CONDITIONALLY_CONTINUES);\n var breaks = innerFlow.isAny(FlowFlags.BREAKS | FlowFlags.CONDITIONALLY_BREAKS);\n\n // (block $break ;; (1) skip label (needed anyway) if skipping (4) + no breaks\n // (initializer) ;; (2) [may be empty]\n // (loop $loop ;; (3) skip if (6) does not fall through + no continues\n // (br_if !cond $break) ;; (4) skip if always true\n // (block $continue ;; (5) skip if no continues or nothing else than continue\n // (...) ;; (6)\n // )\n // (incrementor) ;; (7) skip if skipping (3) [may be empty]\n // (br $loop) ;; (8) skip if skipping (3)\n // )\n // )\n var fallsThrough = !terminates && !innerFlow.is(FlowFlags.BREAKS);\n var needsLabel = !alwaysTrue || breaks;\n\n var loop = new Array();\n if (!alwaysTrue) { // (4)\n loop.push(module.br(breakLabel, module.unary(UnaryOp.EqzI32, condExpr)));\n }\n if (continues) { // (5)\n if (stmts.length > 1 || getExpressionId(stmts[0]) != ExpressionId.Break) { // otherwise lonely continue\n loop.push(module.block(continueLabel, stmts));\n }\n } else {\n for (let i = 0, k = stmts.length; i < k; ++i) loop.push(stmts[i]);\n }\n var expr: ExpressionRef;\n if (fallsThrough || continues) { // (3)\n if (incrExpr) loop.push(incrExpr); // (7)\n this.performAutoreleases(innerFlow, loop);\n loop.push(module.br(loopLabel)); // (8)\n if (initExpr) { // (2)\n expr = module.block(needsLabel ? breakLabel : null, [\n initExpr,\n module.loop(loopLabel, module.block(null, loop))\n ]);\n } else {\n expr = module.block(needsLabel ? breakLabel : null, [\n module.loop(loopLabel, flatten(module, loop, NativeType.None))\n ]);\n }\n } else {\n if (initExpr) loop.unshift(initExpr); // (2)\n this.performAutoreleases(innerFlow, loop);\n expr = module.block(needsLabel ? breakLabel : null, loop);\n }\n\n // Switch back to the parent flow\n innerFlow.freeScopedLocals();\n outerFlow.popBreakLabel();\n innerFlow.unset(\n FlowFlags.BREAKS |\n FlowFlags.CONDITIONALLY_BREAKS |\n FlowFlags.CONTINUES |\n FlowFlags.CONDITIONALLY_CONTINUES\n );\n if (alwaysTrue) outerFlow.inherit(innerFlow);\n else outerFlow.inheritConditional(innerFlow);\n this.currentFlow = outerFlow;\n return expr;\n }\n\n compileIfStatement(\n statement: IfStatement\n ): ExpressionRef {\n var module = this.module;\n var ifTrue = statement.ifTrue;\n var ifFalse = statement.ifFalse;\n var outerFlow = this.currentFlow;\n\n // The condition doesn't initiate a branch yet\n var condExpr = module.precomputeExpression(\n this.makeIsTrueish(\n this.compileExpression(statement.condition, Type.bool),\n this.currentType\n )\n );\n\n // Try to eliminate unnecesssary branches if the condition is constant\n if (\n getExpressionId(condExpr) == ExpressionId.Const &&\n getExpressionType(condExpr) == NativeType.I32\n ) {\n return getConstValueI32(condExpr)\n ? this.compileStatement(ifTrue)\n : ifFalse\n ? this.compileStatement(ifFalse)\n : module.nop();\n }\n\n // Each arm initiates a branch\n var ifTrueStmts = new Array();\n var ifTrueFlow = outerFlow.fork();\n this.currentFlow = ifTrueFlow;\n ifTrueFlow.inheritNonnullIfTrue(condExpr);\n if (ifTrue.kind == NodeKind.BLOCK) {\n this.compileStatements((ifTrue).statements, false, ifTrueStmts);\n } else {\n ifTrueStmts.push(this.compileStatement(ifTrue));\n }\n if (!ifTrueFlow.isAny(FlowFlags.TERMINATES | FlowFlags.BREAKS)) this.performAutoreleases(ifTrueFlow, ifTrueStmts);\n ifTrueFlow.freeScopedLocals();\n this.currentFlow = outerFlow;\n\n if (ifFalse) {\n let ifFalseFlow = outerFlow.fork();\n this.currentFlow = ifFalseFlow;\n ifFalseFlow.inheritNonnullIfFalse(condExpr);\n let ifFalseStmts = new Array();\n if (ifFalse.kind == NodeKind.BLOCK) {\n this.compileStatements((ifFalse).statements, false, ifFalseStmts);\n } else {\n ifFalseStmts.push(this.compileStatement(ifFalse));\n }\n if (!ifFalseFlow.isAny(FlowFlags.TERMINATES | FlowFlags.BREAKS)) this.performAutoreleases(ifFalseFlow, ifFalseStmts);\n ifFalseFlow.freeScopedLocals();\n this.currentFlow = outerFlow;\n outerFlow.inheritMutual(ifTrueFlow, ifFalseFlow);\n return module.if(condExpr,\n flatten(module, ifTrueStmts, NativeType.None),\n flatten(module, ifFalseStmts, NativeType.None)\n );\n } else {\n outerFlow.inheritConditional(ifTrueFlow);\n if (ifTrueFlow.is(FlowFlags.TERMINATES)) outerFlow.inheritNonnullIfFalse(condExpr);\n return module.if(condExpr,\n flatten(module, ifTrueStmts, NativeType.None)\n );\n }\n // TODO: Detect neglected condition\n // if (!foo) {\n // foo = [notNull]\n // }\n // foo // is possibly null\n }\n\n compileReturnStatement(\n statement: ReturnStatement,\n isLastInBody: bool\n ): ExpressionRef {\n var module = this.module;\n var expr: ExpressionRef = 0;\n var flow = this.currentFlow;\n var returnType = flow.returnType;\n\n // Remember that this flow returns\n flow.set(FlowFlags.RETURNS | FlowFlags.TERMINATES);\n\n var valueExpression = statement.value;\n if (valueExpression) {\n if (returnType == Type.void) {\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n valueExpression.range, this.currentType.toString(), returnType.toString()\n );\n this.currentType = Type.void;\n return module.unreachable();\n }\n let constraints = Constraints.CONV_IMPLICIT;\n if (flow.actualFunction.is(CommonFlags.MODULE_EXPORT)) constraints |= Constraints.MUST_WRAP;\n expr = this.compileExpression(valueExpression, returnType, constraints | Constraints.WILL_RETAIN);\n\n // when returning a local, and it is already retained, skip the final set\n // of retaining it as the return value and releasing it as a variable\n if (!this.skippedAutoreleases.has(expr)) {\n if (returnType.isManaged) {\n if (getExpressionId(expr) == ExpressionId.LocalGet) {\n if (flow.isAnyLocalFlag(getLocalGetIndex(expr), LocalFlags.ANY_RETAINED)) {\n flow.unsetLocalFlag(getLocalGetIndex(expr), LocalFlags.ANY_RETAINED);\n this.skippedAutoreleases.add(expr);\n }\n }\n }\n }\n\n // remember return states\n if (!flow.canOverflow(expr, returnType)) flow.set(FlowFlags.RETURNS_WRAPPED);\n if (flow.isNonnull(expr, returnType)) flow.set(FlowFlags.RETURNS_NONNULL);\n\n } else if (returnType != Type.void) {\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n statement.range, \"void\", returnType.toString()\n );\n expr = module.unreachable();\n }\n\n var stmts = new Array();\n this.performAutoreleases(flow, stmts);\n this.finishAutoreleases(flow, stmts);\n\n // Make sure that the return value is retained for the caller\n if (returnType.isManaged && !this.skippedAutoreleases.has(expr)) expr = this.makeRetain(expr);\n\n if (returnType != Type.void && stmts.length) {\n let temp = flow.getAndFreeTempLocal(returnType);\n if (flow.isNonnull(expr, returnType)) flow.setLocalFlag(temp.index, LocalFlags.NONNULL);\n stmts.unshift(\n module.local_set(temp.index, expr)\n );\n expr = module.local_get(temp.index, returnType.toNativeType());\n }\n flow.freeScopedLocals();\n\n // If the last statement anyway, make it the block's return value\n if (isLastInBody && expr && returnType != Type.void) {\n if (!stmts.length) return expr;\n stmts.push(expr);\n return module.block(null, stmts, returnType.toNativeType());\n }\n\n // When inlining, break to the end of the inlined function's block (no need to wrap)\n if (flow.is(FlowFlags.INLINE_CONTEXT)) {\n if (!stmts.length) return module.br(assert(flow.inlineReturnLabel), 0, expr);\n stmts.push(module.br(assert(flow.inlineReturnLabel), 0, expr));\n // stmts.push(module.createUnreachable());\n return module.block(null, stmts);\n }\n\n // Otherwise emit a normal return\n if (!stmts.length) return module.return(expr);\n stmts.push(module.return(expr));\n return module.block(null, stmts);\n }\n\n compileSwitchStatement(\n statement: SwitchStatement\n ): ExpressionRef {\n var module = this.module;\n\n var cases = statement.cases;\n var numCases = cases.length;\n if (!numCases) {\n return this.compileExpression(statement.condition, Type.void,\n Constraints.CONV_IMPLICIT\n );\n }\n\n // Everything within a switch uses the same break context\n var outerFlow = this.currentFlow;\n var context = outerFlow.pushBreakLabel();\n\n // introduce a local for evaluating the condition (exactly once)\n var tempLocal = outerFlow.getTempLocal(Type.u32);\n var tempLocalIndex = tempLocal.index;\n\n // Prepend initializer to inner block. Does not initiate a new branch, yet.\n var breaks = new Array(1 + numCases);\n breaks[0] = module.local_set( // initializer\n tempLocalIndex,\n this.compileExpression(statement.condition, Type.u32,\n Constraints.CONV_IMPLICIT\n )\n );\n\n // make one br_if per (possibly dynamic) labeled case (binaryen optimizes to br_table where possible)\n var breakIndex = 1;\n var defaultIndex = -1;\n for (let i = 0; i < numCases; ++i) {\n let case_ = cases[i];\n let label = case_.label;\n if (label) {\n breaks[breakIndex++] = module.br(\"case\" + i.toString(10) + \"|\" + context,\n module.binary(BinaryOp.EqI32,\n module.local_get(tempLocalIndex, NativeType.I32),\n this.compileExpression(label, Type.u32,\n Constraints.CONV_IMPLICIT\n )\n )\n );\n } else {\n defaultIndex = i;\n }\n }\n\n outerFlow.freeTempLocal(tempLocal);\n\n // otherwise br to default respectively out of the switch if there is no default case\n breaks[breakIndex] = module.br((defaultIndex >= 0\n ? \"case\" + defaultIndex.toString(10)\n : \"break\"\n ) + \"|\" + context);\n\n // nest blocks in order\n var currentBlock = module.block(\"case0|\" + context, breaks, NativeType.None);\n var commonCategorical = FlowFlags.ANY_CATEGORICAL;\n var commonConditional = 0;\n for (let i = 0; i < numCases; ++i) {\n let case_ = cases[i];\n let statements = case_.statements;\n let numStatements = statements.length;\n\n // Each switch case initiates a new branch\n let innerFlow = outerFlow.fork();\n this.currentFlow = innerFlow;\n let breakLabel = \"break|\" + context;\n innerFlow.breakLabel = breakLabel;\n\n let isLast = i == numCases - 1;\n let nextLabel = isLast ? breakLabel : \"case\" + (i + 1).toString(10) + \"|\" + context;\n let stmts = new Array(1 + numStatements);\n stmts[0] = currentBlock;\n let count = 1;\n let terminates = false;\n for (let j = 0; j < numStatements; ++j) {\n let stmt = this.compileStatement(statements[j]);\n if (getExpressionId(stmt) != ExpressionId.Nop) {\n stmts[count++] = stmt;\n }\n if (innerFlow.isAny(FlowFlags.TERMINATES | FlowFlags.BREAKS)) {\n if (innerFlow.is(FlowFlags.TERMINATES)) terminates = true;\n break;\n }\n }\n stmts.length = count;\n if (terminates || isLast || innerFlow.isAny(FlowFlags.BREAKS | FlowFlags.CONDITIONALLY_BREAKS)) {\n commonCategorical &= innerFlow.flags;\n }\n commonConditional |= innerFlow.flags & FlowFlags.ANY_CONDITIONAL;\n\n // Switch back to the parent flow\n if (!terminates) this.performAutoreleases(innerFlow, stmts);\n innerFlow.unset(\n FlowFlags.BREAKS |\n FlowFlags.CONDITIONALLY_BREAKS\n );\n innerFlow.freeScopedLocals();\n this.currentFlow = outerFlow;\n currentBlock = module.block(nextLabel, stmts, NativeType.None); // must be a labeled block\n }\n outerFlow.popBreakLabel();\n\n // If the switch has a default (guaranteed to handle any value), propagate common flags\n if (defaultIndex >= 0) outerFlow.flags |= commonCategorical & ~FlowFlags.BREAKS;\n outerFlow.flags |= commonConditional & ~FlowFlags.CONDITIONALLY_BREAKS;\n // TODO: what about local states?\n return currentBlock;\n }\n\n compileThrowStatement(\n statement: ThrowStatement\n ): ExpressionRef {\n var flow = this.currentFlow;\n\n // Remember that this branch throws\n flow.set(FlowFlags.THROWS | FlowFlags.TERMINATES);\n\n var stmts = new Array();\n this.finishAutoreleases(flow, stmts);\n\n // TODO: requires exception-handling spec.\n var value = statement.value;\n var message: Expression | null = null;\n if (value.kind == NodeKind.NEW) {\n let newArgs = (value).arguments;\n if (newArgs.length) message = newArgs[0]; // FIXME: naively assumes type string\n }\n stmts.push(compileAbort(this, message, statement));\n\n return flatten(this.module, stmts, NativeType.None);\n }\n\n compileTryStatement(\n statement: TryStatement\n ): ExpressionRef {\n // TODO: can't yet support something like: try { return ... } finally { ... }\n // worthwhile to investigate lowering returns to block results (here)?\n this.error(\n DiagnosticCode.Operation_not_supported,\n statement.range\n );\n return this.module.unreachable();\n }\n\n /** Compiles a variable statement. Returns `0` if an initializer is not necessary. */\n compileVariableStatement(\n statement: VariableStatement\n ): ExpressionRef {\n var module = this.module;\n var declarations = statement.declarations;\n var numDeclarations = declarations.length;\n var flow = this.currentFlow;\n var initializers = new Array();\n var resolver = this.resolver;\n\n for (let i = 0; i < numDeclarations; ++i) {\n let declaration = declarations[i];\n let name = declaration.name.text;\n let type: Type | null = null;\n let initExpr: ExpressionRef = 0;\n let initAutoreleaseSkipped = false;\n\n // Resolve type if annotated\n if (declaration.type) {\n type = resolver.resolveType( // reports\n declaration.type,\n flow.actualFunction,\n flow.contextualTypeArguments\n );\n if (!type) continue;\n if (declaration.initializer) {\n initExpr = this.compileExpression(declaration.initializer, type, // reports\n Constraints.CONV_IMPLICIT | Constraints.WILL_RETAIN\n );\n initAutoreleaseSkipped = this.skippedAutoreleases.has(initExpr);\n }\n\n // Otherwise infer type from initializer\n } else if (declaration.initializer) {\n initExpr = this.compileExpression(declaration.initializer, Type.auto,\n Constraints.WILL_RETAIN\n ); // reports\n initAutoreleaseSkipped = this.skippedAutoreleases.has(initExpr);\n if (this.currentType == Type.void) {\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n declaration.range, this.currentType.toString(), \"\"\n );\n continue;\n }\n type = this.currentType;\n\n // Error if there's neither a type nor an initializer\n } else {\n this.error(\n DiagnosticCode.Type_expected,\n declaration.name.range.atEnd\n );\n continue;\n }\n\n // Handle constants, and try to inline if value is static\n let isConst = declaration.is(CommonFlags.CONST);\n let isStatic = false;\n if (isConst) {\n if (initExpr) {\n initExpr = module.precomputeExpression(initExpr);\n if (getExpressionId(initExpr) == ExpressionId.Const) {\n let local = new Local(name, -1, type, flow.parentFunction);\n switch (getExpressionType(initExpr)) {\n case NativeType.I32: {\n local.setConstantIntegerValue(\n i64_new(\n getConstValueI32(initExpr),\n 0\n ),\n type\n );\n break;\n }\n case NativeType.I64: {\n local.setConstantIntegerValue(\n i64_new(\n getConstValueI64Low(initExpr),\n getConstValueI64High(initExpr)\n ),\n type\n );\n break;\n }\n case NativeType.F32: {\n local.setConstantFloatValue(getConstValueF32(initExpr), type);\n break;\n }\n case NativeType.F64: {\n local.setConstantFloatValue(getConstValueF64(initExpr), type);\n break;\n }\n default: {\n assert(false);\n return module.unreachable();\n }\n }\n // Create a virtual local that doesn't actually exist in WebAssembly\n let scopedLocals = flow.scopedLocals;\n if (!scopedLocals) flow.scopedLocals = scopedLocals = new Map();\n else if (scopedLocals.has(name)) {\n this.error(\n DiagnosticCode.Duplicate_identifier_0,\n declaration.name.range, name\n );\n return this.module.unreachable();\n }\n scopedLocals.set(name, local);\n isStatic = true;\n }\n } else {\n this.error(\n DiagnosticCode._const_declarations_must_be_initialized,\n declaration.range\n );\n }\n }\n\n // Otherwise compile as mutable\n if (!isStatic) {\n let local: Local;\n if (\n declaration.isAny(CommonFlags.LET | CommonFlags.CONST) ||\n flow.is(FlowFlags.INLINE_CONTEXT)\n ) { // here: not top-level\n let existingLocal = flow.getScopedLocal(name);\n if (existingLocal) {\n this.error(\n DiagnosticCode.Duplicate_identifier_0,\n declaration.name.range, declaration.name.text\n );\n local = existingLocal;\n } else {\n local = flow.addScopedLocal(name, type);\n }\n if (isConst) flow.setLocalFlag(local.index, LocalFlags.CONSTANT);\n } else {\n if (flow.lookupLocal(name)) {\n this.error(\n DiagnosticCode.Duplicate_identifier_0,\n declaration.name.range, name\n );\n continue;\n }\n local = flow.parentFunction.addLocal(type, name, declaration);\n if (isConst) flow.setLocalFlag(local.index, LocalFlags.CONSTANT);\n }\n let isManaged = type.isManaged;\n if (initExpr) {\n if (flow.isNonnull(initExpr, type)) flow.setLocalFlag(local.index, LocalFlags.NONNULL);\n if (isManaged) {\n flow.setLocalFlag(local.index, LocalFlags.RETAINED);\n initializers.push(\n module.local_set(local.index,\n initAutoreleaseSkipped\n ? initExpr\n : this.makeRetain(initExpr)\n )\n );\n } else {\n initializers.push(\n module.local_set(local.index, initExpr)\n );\n if (local.type.is(TypeFlags.SHORT | TypeFlags.INTEGER)) {\n if (!flow.canOverflow(initExpr, type)) flow.setLocalFlag(local.index, LocalFlags.WRAPPED);\n else flow.unsetLocalFlag(local.index, LocalFlags.WRAPPED);\n }\n }\n } else {\n if (isManaged) {\n // This is necessary because the first use (and assign) of the local could be taking place\n // in a loop, subsequently marking it retained, but the second iteration of the loop\n // still wouldn't release whatever is assigned in the first. Likewise, if the variable wasn't\n // initialized but becomes released later on, whatever was stored before would be released.\n // TODO: Detect this condition inside of a loop instead?\n initializers.push(\n module.local_set(local.index,\n type.toNativeZero(module)\n )\n );\n flow.setLocalFlag(local.index, LocalFlags.CONDITIONALLY_RETAINED);\n } else if (local.type.is(TypeFlags.SHORT | TypeFlags.INTEGER)) {\n flow.setLocalFlag(local.index, LocalFlags.WRAPPED);\n }\n }\n }\n }\n return initializers.length == 0\n ? 0\n : flatten(module, initializers, NativeType.None);\n }\n\n compileVoidStatement(\n statement: VoidStatement\n ): ExpressionRef {\n return this.compileExpression(statement.expression, Type.void,\n Constraints.CONV_EXPLICIT | Constraints.WILL_DROP\n );\n }\n\n compileWhileStatement(\n statement: WhileStatement\n ): ExpressionRef {\n var module = this.module;\n var outerFlow = this.currentFlow;\n\n // Compile condition\n var condExpr = module.precomputeExpression(\n this.makeIsTrueish(\n this.compileExpression(statement.condition, Type.bool),\n this.currentType\n )\n );\n\n // Simplify if the condition is constant\n var alwaysTrue = false;\n if (getExpressionId(condExpr) == ExpressionId.Const) {\n assert(getExpressionType(condExpr) == NativeType.I32);\n if (!getConstValueI32(condExpr)) return module.nop(); // simplify\n alwaysTrue = true;\n }\n\n // Compile body\n var label = outerFlow.pushBreakLabel();\n var innerFlow = outerFlow.fork();\n this.currentFlow = innerFlow;\n var breakLabel = \"break|\" + label;\n innerFlow.breakLabel = breakLabel;\n var continueLabel = \"continue|\" + label;\n innerFlow.continueLabel = continueLabel;\n innerFlow.inheritNonnullIfTrue(condExpr);\n var stmts = new Array();\n if (statement.statement.kind == NodeKind.BLOCK) {\n this.compileStatements((statement.statement).statements, false, stmts);\n } else {\n stmts.push(this.compileStatement(statement.statement));\n }\n var terminates = innerFlow.is(FlowFlags.TERMINATES);\n\n // (block $break ;; (1) skip if skipping (3) + no breaks\n // (loop $continue ;; (2) skip if skipping (5) + no continues\n // (br_if !cond $break) ;; (3) skip if always true\n // (...) ;; (4)\n // (br $continue) ;; (5) skip if (4) does not fall through\n // )\n // )\n var fallsThrough = !terminates && !innerFlow.is(FlowFlags.BREAKS);\n\n if (fallsThrough) { // (5)\n this.performAutoreleases(innerFlow, stmts);\n stmts.push(module.br(continueLabel));\n }\n if (!alwaysTrue) { // (3)\n stmts.unshift(module.br(breakLabel, module.unary(UnaryOp.EqzI32, condExpr)));\n }\n var expr = flatten(module, stmts, NativeType.None);\n if (fallsThrough || innerFlow.isAny(FlowFlags.CONTINUES | FlowFlags.CONDITIONALLY_CONTINUES)) { // (2)\n expr = module.loop(continueLabel, expr);\n }\n if (!alwaysTrue || innerFlow.isAny(FlowFlags.BREAKS | FlowFlags.CONDITIONALLY_BREAKS)) { // (1)\n expr = module.block(breakLabel, [ expr ]);\n }\n\n // Switch back to the parent flow\n innerFlow.freeScopedLocals();\n outerFlow.popBreakLabel();\n innerFlow.unset(\n FlowFlags.BREAKS |\n FlowFlags.CONDITIONALLY_BREAKS |\n FlowFlags.CONTINUES |\n FlowFlags.CONDITIONALLY_CONTINUES\n );\n if (alwaysTrue) outerFlow.inherit(innerFlow);\n else outerFlow.inheritConditional(innerFlow);\n this.currentFlow = outerFlow;\n return expr;\n }\n\n // === Expressions ==============================================================================\n\n /** Compiles the value of an inlined constant element. */\n compileInlineConstant(\n element: VariableLikeElement,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n assert(element.is(CommonFlags.INLINED));\n var type = element.type;\n switch (\n !(constraints & (Constraints.CONV_IMPLICIT | Constraints.CONV_EXPLICIT)) &&\n type.is(TypeFlags.INTEGER) &&\n contextualType.is(TypeFlags.INTEGER) &&\n type.size < contextualType.size\n ? (this.currentType = contextualType).kind // essentially precomputes a (sign-)extension\n : (this.currentType = type).kind\n ) {\n case TypeKind.I8:\n case TypeKind.I16: {\n let shift = type.computeSmallIntegerShift(Type.i32);\n return this.module.i32(\n element.constantValueKind == ConstantValueKind.INTEGER\n ? i64_low(element.constantIntegerValue) << shift >> shift\n : 0\n ); // recognized by canOverflow\n }\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL: {\n let mask = element.type.computeSmallIntegerMask(Type.i32);\n return this.module.i32(\n element.constantValueKind == ConstantValueKind.INTEGER\n ? i64_low(element.constantIntegerValue) & mask\n : 0\n ); // recognized by canOverflow\n }\n case TypeKind.I32:\n case TypeKind.U32: {\n return this.module.i32(\n element.constantValueKind == ConstantValueKind.INTEGER\n ? i64_low(element.constantIntegerValue)\n : 0\n );\n }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n if (!element.program.options.isWasm64) {\n return this.module.i32(\n element.constantValueKind == ConstantValueKind.INTEGER\n ? i64_low(element.constantIntegerValue)\n : 0\n );\n }\n // fall-through\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n return element.constantValueKind == ConstantValueKind.INTEGER\n ? this.module.i64(\n i64_low(element.constantIntegerValue),\n i64_high(element.constantIntegerValue)\n )\n : this.module.i64(0);\n }\n case TypeKind.F64: {\n // monkey-patch for converting built-in floats to f32 implicitly\n if (!(element.hasDecorator(DecoratorFlags.BUILTIN) && contextualType == Type.f32)) {\n return this.module.f64((element).constantFloatValue);\n }\n // otherwise fall-through: basically precomputes f32.demote/f64 of NaN / Infinity\n this.currentType = Type.f32;\n }\n case TypeKind.F32: {\n return this.module.f32((element).constantFloatValue);\n }\n default: {\n assert(false);\n return this.module.unreachable();\n }\n }\n }\n\n compileExpression(\n expression: Expression,\n contextualType: Type,\n constraints: Constraints = Constraints.NONE\n ): ExpressionRef {\n this.currentType = contextualType;\n var expr: ExpressionRef;\n if (contextualType == Type.void) constraints |= Constraints.WILL_DROP;\n switch (expression.kind) {\n case NodeKind.ASSERTION: {\n expr = this.compileAssertionExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.BINARY: {\n expr = this.compileBinaryExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.CALL: {\n expr = this.compileCallExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.COMMA: {\n expr = this.compileCommaExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.ELEMENTACCESS: {\n expr = this.compileElementAccessExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.FUNCTION: {\n expr = this.compileFunctionExpression(expression, contextualType.signatureReference, constraints);\n break;\n }\n case NodeKind.IDENTIFIER:\n case NodeKind.FALSE:\n case NodeKind.NULL:\n case NodeKind.THIS:\n case NodeKind.SUPER:\n case NodeKind.TRUE: {\n expr = this.compileIdentifierExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.INSTANCEOF: {\n expr = this.compileInstanceOfExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.LITERAL: {\n expr = this.compileLiteralExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.NEW: {\n expr = this.compileNewExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.PARENTHESIZED: {\n expr = this.compileExpression((expression).expression, contextualType, constraints);\n break;\n }\n case NodeKind.PROPERTYACCESS: {\n expr = this.compilePropertyAccessExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.TERNARY: {\n expr = this.compileTernaryExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.UNARYPOSTFIX: {\n expr = this.compileUnaryPostfixExpression(expression, contextualType, constraints);\n break;\n }\n case NodeKind.UNARYPREFIX: {\n expr = this.compileUnaryPrefixExpression(expression, contextualType, constraints);\n break;\n }\n default: {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n expr = this.module.unreachable();\n }\n }\n // ensure conversion and wrapping in case the respective function doesn't on its own\n var currentType = this.currentType;\n var wrap = (constraints & Constraints.MUST_WRAP) != 0;\n if (currentType != contextualType) {\n if (constraints & Constraints.CONV_EXPLICIT) {\n expr = this.convertExpression(expr, currentType, contextualType, true, wrap, expression);\n wrap = false;\n this.currentType = contextualType;\n } else if (constraints & Constraints.CONV_IMPLICIT) {\n expr = this.convertExpression(expr, currentType, contextualType, false, wrap, expression);\n wrap = false;\n this.currentType = contextualType;\n }\n }\n if (wrap) expr = this.ensureSmallIntegerWrap(expr, currentType);\n // debug location is added here so the caller doesn't have to. means: compilation of an expression\n // must go through this function, with the respective per-kind functions not being used directly.\n if (this.options.sourceMap) this.addDebugLocation(expr, expression.range);\n return expr;\n }\n\n /** Compiles and precomputes an expression, possibly yielding a costant value. */\n precomputeExpression(\n expression: Expression,\n contextualType: Type,\n constraints: Constraints = Constraints.NONE\n ): ExpressionRef {\n return this.module.precomputeExpression(\n this.compileExpression(expression, contextualType, constraints)\n );\n }\n\n convertExpression(\n expr: ExpressionRef,\n /** Original type. */\n fromType: Type,\n /** New type. */\n toType: Type,\n /** Whether the conversion is explicit.*/\n explicit: bool,\n /** Whether the result should be wrapped, if a small integer. */\n wrap: bool,\n reportNode: Node\n ): ExpressionRef {\n var module = this.module;\n\n // void to any\n if (fromType.kind == TypeKind.VOID) {\n assert(toType.kind != TypeKind.VOID); // convertExpression should not be called with void -> void\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n reportNode.range, fromType.toString(), toType.toString()\n );\n return module.unreachable();\n }\n\n // any to void\n if (toType.kind == TypeKind.VOID) return module.drop(expr);\n\n if (this.currentFlow.isNonnull(expr, fromType)) fromType = fromType.nonNullableType;\n\n if (!fromType.isAssignableTo(toType)) {\n if (!explicit) {\n if (fromType.nonNullableType == toType) {\n this.error(\n DiagnosticCode.Object_is_possibly_null,\n reportNode.range\n ); // recoverable\n } else {\n this.error(\n DiagnosticCode.Conversion_from_type_0_to_1_requires_an_explicit_cast,\n reportNode.range, fromType.toString(), toType.toString()\n ); // recoverable\n }\n }\n }\n\n if (fromType.is(TypeFlags.FLOAT)) {\n\n // float to float\n if (toType.is(TypeFlags.FLOAT)) {\n if (fromType.kind == TypeKind.F32) {\n\n // f32 to f64\n if (toType.kind == TypeKind.F64) {\n expr = module.unary(UnaryOp.PromoteF32, expr);\n }\n\n // otherwise f32 to f32\n\n // f64 to f32\n } else if (toType.kind == TypeKind.F32) {\n expr = module.unary(UnaryOp.DemoteF64, expr);\n }\n\n // otherwise f64 to f64\n\n // float to int\n } else if (toType.is(TypeFlags.INTEGER)) {\n\n // f32 to int\n if (fromType.kind == TypeKind.F32) {\n if (toType == Type.bool) {\n expr = module.binary(BinaryOp.NeF32, expr, module.f32(0));\n wrap = false;\n } else if (toType.is(TypeFlags.SIGNED)) {\n if (toType.is(TypeFlags.LONG)) {\n expr = module.unary(UnaryOp.TruncF32ToI64, expr);\n } else {\n expr = module.unary(UnaryOp.TruncF32ToI32, expr);\n }\n } else {\n if (toType.is(TypeFlags.LONG)) {\n expr = module.unary(UnaryOp.TruncF32ToU64, expr);\n } else {\n expr = module.unary(UnaryOp.TruncF32ToU32, expr);\n }\n }\n\n // f64 to int\n } else {\n if (toType == Type.bool) {\n expr = module.binary(BinaryOp.NeF64, expr, module.f64(0));\n wrap = false;\n } else if (toType.is(TypeFlags.SIGNED)) {\n if (toType.is(TypeFlags.LONG)) {\n expr = module.unary(UnaryOp.TruncF64ToI64, expr);\n } else {\n expr = module.unary(UnaryOp.TruncF64ToI32, expr);\n }\n } else {\n if (toType.is(TypeFlags.LONG)) {\n expr = module.unary(UnaryOp.TruncF64ToU64, expr);\n } else {\n expr = module.unary(UnaryOp.TruncF64ToU32, expr);\n }\n }\n }\n\n // float to void\n } else {\n assert(toType.flags == TypeFlags.NONE, \"void type expected\");\n expr = module.drop(expr);\n }\n\n // int to float\n } else if (fromType.is(TypeFlags.INTEGER) && toType.is(TypeFlags.FLOAT)) {\n\n // int to f32\n if (toType.kind == TypeKind.F32) {\n if (fromType.is(TypeFlags.LONG)) {\n expr = module.unary(\n fromType.is(TypeFlags.SIGNED)\n ? UnaryOp.ConvertI64ToF32\n : UnaryOp.ConvertU64ToF32,\n expr\n );\n } else {\n expr = module.unary(\n fromType.is(TypeFlags.SIGNED)\n ? UnaryOp.ConvertI32ToF32\n : UnaryOp.ConvertU32ToF32,\n expr\n );\n }\n\n // int to f64\n } else {\n if (fromType.is(TypeFlags.LONG)) {\n expr = module.unary(\n fromType.is(TypeFlags.SIGNED)\n ? UnaryOp.ConvertI64ToF64\n : UnaryOp.ConvertU64ToF64,\n expr\n );\n } else {\n expr = module.unary(\n fromType.is(TypeFlags.SIGNED)\n ? UnaryOp.ConvertI32ToF64\n : UnaryOp.ConvertU32ToF64,\n expr\n );\n }\n }\n\n // int to int\n } else {\n // i64 to ...\n if (fromType.is(TypeFlags.LONG)) {\n\n // i64 to i32 or smaller\n if (toType == Type.bool) {\n expr = module.binary(BinaryOp.NeI64, expr, module.i64(0));\n wrap = false;\n } else if (!toType.is(TypeFlags.LONG)) {\n expr = module.unary(UnaryOp.WrapI64, expr); // discards upper bits\n }\n\n // i32 or smaller to i64\n } else if (toType.is(TypeFlags.LONG)) {\n expr = module.unary(\n fromType.is(TypeFlags.SIGNED) ? UnaryOp.ExtendI32 : UnaryOp.ExtendU32,\n this.ensureSmallIntegerWrap(expr, fromType) // must clear garbage bits\n );\n wrap = false;\n\n // i32 to i32\n } else {\n // small i32 to ...\n if (fromType.is(TypeFlags.SHORT)) {\n // small i32 to larger i32\n if (fromType.size < toType.size) {\n expr = this.ensureSmallIntegerWrap(expr, fromType); // must clear garbage bits\n wrap = false;\n }\n }\n }\n }\n\n this.currentType = toType;\n return wrap\n ? this.ensureSmallIntegerWrap(expr, toType)\n : expr;\n }\n\n compileAssertionExpression(\n expression: AssertionExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var inheritedConstraints = constraints & ~(Constraints.CONV_IMPLICIT | Constraints.CONV_EXPLICIT);\n switch (expression.assertionKind) {\n case AssertionKind.PREFIX:\n case AssertionKind.AS: {\n let flow = this.currentFlow;\n let toType = this.resolver.resolveType( // reports\n assert(expression.toType),\n flow.actualFunction,\n flow.contextualTypeArguments\n );\n if (!toType) return this.module.unreachable();\n return this.compileExpression(expression.expression, toType, inheritedConstraints | Constraints.CONV_EXPLICIT);\n }\n case AssertionKind.NONNULL: {\n assert(!expression.toType);\n let expr = this.compileExpression(expression.expression, contextualType.exceptVoid, inheritedConstraints);\n let type = this.currentType;\n if (this.currentFlow.isNonnull(expr, type)) {\n this.info(\n DiagnosticCode.Expression_is_never_null,\n expression.expression.range\n );\n } else if (!this.options.noAssert) {\n let module = this.module;\n let flow = this.currentFlow;\n let tempIndex = flow.getAndFreeTempLocal(type).index;\n if (!flow.canOverflow(expr, type)) flow.setLocalFlag(tempIndex, LocalFlags.WRAPPED);\n flow.setLocalFlag(tempIndex, LocalFlags.NONNULL);\n expr = module.if(\n module.local_tee(tempIndex, expr),\n module.local_get(tempIndex, type.toNativeType()),\n module.unreachable()\n );\n }\n this.currentType = this.currentType.nonNullableType;\n return expr;\n }\n default: assert(false);\n }\n return this.module.unreachable();\n }\n\n private f32ModInstance: Function | null = null;\n private f64ModInstance: Function | null = null;\n private f32PowInstance: Function | null = null;\n private f64PowInstance: Function | null = null;\n\n compileBinaryExpression(\n expression: BinaryExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var module = this.module;\n var left = expression.left;\n var right = expression.right;\n\n var leftExpr: ExpressionRef;\n var leftType: Type;\n var rightExpr: ExpressionRef;\n var rightType: Type;\n var commonType: Type | null;\n\n var expr: ExpressionRef;\n var compound = false;\n\n var operator = expression.operator;\n switch (operator) {\n case Token.LESSTHAN: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.LT);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, true)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, true, // !\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, true, // !\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \"<\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n switch (commonType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32: {\n expr = module.binary(BinaryOp.LtI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I64: {\n expr = module.binary(BinaryOp.LtI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.LtI64\n : BinaryOp.LtI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.LtU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.LtU64\n : BinaryOp.LtU32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.LtU64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.LtF32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.LtF64, leftExpr, rightExpr);\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n this.currentType = Type.bool;\n break;\n }\n case Token.GREATERTHAN: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.GT);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, true)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, true, // !\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, true, // !\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \">\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n switch (commonType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32: {\n expr = module.binary(BinaryOp.GtI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.GtI64\n : BinaryOp.GtI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.I64: {\n expr = module.binary(BinaryOp.GtI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.GtU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.GtU64\n : BinaryOp.GtU32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.GtU64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.GtF32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.GtF64, leftExpr, rightExpr);\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n this.currentType = Type.bool;\n break;\n }\n case Token.LESSTHAN_EQUALS: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.LE);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, true)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, true, // !\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, true, // !\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \"<=\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n switch (commonType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32: {\n expr = module.binary(BinaryOp.LeI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.LeI64\n : BinaryOp.LeI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.I64: {\n expr = module.binary(BinaryOp.LeI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.LeU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.LeU64\n : BinaryOp.LeU32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.LeU64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.LeF32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.LeF64, leftExpr, rightExpr);\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n this.currentType = Type.bool;\n break;\n }\n case Token.GREATERTHAN_EQUALS: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.GE);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, true)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, true, // !\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, true, // !\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \">=\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n switch (commonType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32: {\n expr = module.binary(BinaryOp.GeI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.GeI64\n : BinaryOp.GeI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.I64: {\n expr = module.binary(BinaryOp.GeI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.GeU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.GeU64\n : BinaryOp.GeU32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.GeU64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.GeF32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.GeF64, leftExpr, rightExpr);\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n this.currentType = Type.bool;\n break;\n }\n\n case Token.EQUALS_EQUALS_EQUALS:\n case Token.EQUALS_EQUALS: {\n\n // NOTE that this favors correctness, in terms of emitting a binary expression, over\n // checking for a possible use of unary EQZ. while the most classic of all optimizations,\n // that's not what the source told us to do. for reference, `!left` emits unary EQZ.\n\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (operator == Token.EQUALS_EQUALS && this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.EQ);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n // still allow '==' with references\n }\n\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, true, // !\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, true, // !\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, operatorTokenToString(expression.operator), leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n switch (commonType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.EqI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.EqI64\n : BinaryOp.EqI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.EqI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.EqF32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.EqF64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.V128: {\n expr = module.unary(UnaryOp.AllTrueVecI8x16,\n module.binary(BinaryOp.EqVecI8x16, leftExpr, rightExpr)\n );\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n this.currentType = Type.bool;\n break;\n }\n case Token.EXCLAMATION_EQUALS_EQUALS:\n case Token.EXCLAMATION_EQUALS: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (operator == Token.EXCLAMATION_EQUALS && this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.NE);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n // still allow '!=' with references\n }\n\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, true, // !\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, true, // !\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, operatorTokenToString(expression.operator), leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n switch (commonType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.NeI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.NeI64\n : BinaryOp.NeI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.NeI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.NeF32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.NeF64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.V128: {\n expr = module.unary(UnaryOp.AnyTrueVecI8x16,\n module.binary(BinaryOp.NeVecI8x16, leftExpr, rightExpr)\n );\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n this.currentType = Type.bool;\n break;\n }\n case Token.EQUALS: {\n return this.compileAssignment(left, right, contextualType);\n }\n case Token.PLUS_EQUALS: compound = true;\n case Token.PLUS: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.ADD);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n if (compound) {\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n } else {\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, false,\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, false,\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \"+\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n }\n switch (this.currentType.kind) {\n case TypeKind.I8: // addition might overflow\n case TypeKind.I16: // ^\n case TypeKind.U8: // ^\n case TypeKind.U16: // ^\n case TypeKind.BOOL: // ^\n case TypeKind.I32:\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.AddI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.AddI64\n : BinaryOp.AddI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.AddI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.AddF32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.AddF64, leftExpr, rightExpr);\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.MINUS_EQUALS: compound = true;\n case Token.MINUS: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.SUB);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n if (compound) {\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n } else {\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, false,\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, false,\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \"-\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n }\n switch (this.currentType.kind) {\n case TypeKind.I8: // subtraction might overflow\n case TypeKind.I16: // ^\n case TypeKind.U8: // ^\n case TypeKind.U16: // ^\n case TypeKind.BOOL: // ^\n case TypeKind.I32:\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.SubI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.SubI64\n : BinaryOp.SubI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.SubI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.SubF32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.SubF64, leftExpr, rightExpr);\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.ASTERISK_EQUALS: compound = true;\n case Token.ASTERISK: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.MUL);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n if (compound) {\n leftExpr = this.ensureSmallIntegerWrap(leftExpr, leftType);\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n } else {\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, false,\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, false,\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \"*\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n }\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL:\n case TypeKind.I32:\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.MulI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.MulI64\n : BinaryOp.MulI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.MulI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.MulF32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.MulF64, leftExpr, rightExpr);\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.ASTERISK_ASTERISK_EQUALS: compound = true;\n case Token.ASTERISK_ASTERISK: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.POW);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n let instance: Function | null;\n\n // Mathf.pow if lhs is f32 (result is f32)\n if (this.currentType.kind == TypeKind.F32) {\n rightExpr = this.compileExpression(right, Type.f32, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n if (!(instance = this.f32PowInstance)) {\n let namespace = this.program.lookupGlobal(CommonSymbols.Mathf);\n if (!namespace) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n expression.range, \"Mathf\"\n );\n expr = module.unreachable();\n break;\n }\n let prototype = namespace.members ? namespace.members.get(CommonSymbols.pow) : null;\n if (!prototype) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n expression.range, \"Mathf.pow\"\n );\n expr = module.unreachable();\n break;\n }\n assert(prototype.kind == ElementKind.FUNCTION_PROTOTYPE);\n this.f32PowInstance = instance = this.resolver.resolveFunction(prototype, null);\n }\n\n // Math.pow otherwise (result is f64)\n // TODO: should the result be converted back?\n } else {\n leftExpr = this.convertExpression(leftExpr,\n this.currentType, Type.f64,\n false, false,\n left\n );\n leftType = this.currentType;\n rightExpr = this.compileExpression(right, Type.f64, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n if (!(instance = this.f64PowInstance)) {\n let namespace = this.program.lookupGlobal(CommonSymbols.Math);\n if (!namespace) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n expression.range, \"Math\"\n );\n expr = module.unreachable();\n break;\n }\n let prototype = namespace.members ? namespace.members.get(CommonSymbols.pow) : null;\n if (!prototype) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n expression.range, \"Math.pow\"\n );\n expr = module.unreachable();\n break;\n }\n assert(prototype.kind == ElementKind.FUNCTION_PROTOTYPE);\n this.f64PowInstance = instance = this.resolver.resolveFunction(prototype, null);\n }\n }\n if (!(instance && this.compileFunction(instance))) {\n expr = module.unreachable();\n } else {\n expr = this.makeCallDirect(instance, [ leftExpr, rightExpr ], expression);\n }\n break;\n }\n case Token.SLASH_EQUALS: compound = true;\n case Token.SLASH: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.DIV);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n if (compound) {\n leftExpr = this.ensureSmallIntegerWrap(leftExpr, leftType);\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n } else {\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, true, // !\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, true, // !\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \"/\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n }\n switch (this.currentType.kind) {\n case TypeKind.I8: // signed div on signed small integers might overflow, e.g. -128/-1\n case TypeKind.I16: // ^\n case TypeKind.I32: {\n expr = module.binary(BinaryOp.DivI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.DivI64\n : BinaryOp.DivI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.I64: {\n expr = module.binary(BinaryOp.DivI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.DivU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.DivU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.DivU64\n : BinaryOp.DivU32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.DivU64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.DivF32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.DivF64, leftExpr, rightExpr);\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.PERCENT_EQUALS: compound = true;\n case Token.PERCENT: {\n leftExpr = this.compileExpression(left, contextualType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.REM);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n if (compound) {\n leftExpr = this.ensureSmallIntegerWrap(leftExpr, leftType);\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n } else {\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, true, // !\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, true, // !\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \"%\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n }\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16: {\n expr = module.binary(BinaryOp.RemI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I32: {\n expr = module.binary(BinaryOp.RemI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.RemI64\n : BinaryOp.RemI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.I64: {\n expr = module.binary(BinaryOp.RemI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.RemU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.RemU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.RemU64\n : BinaryOp.RemU32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.RemU64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.F32: {\n let instance = this.f32ModInstance;\n if (!instance) {\n let namespace = this.program.lookupGlobal(CommonSymbols.Mathf);\n if (!namespace) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n expression.range, \"Mathf\"\n );\n expr = module.unreachable();\n break;\n }\n let prototype = namespace.members ? namespace.members.get(CommonSymbols.mod) : null;\n if (!prototype) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n expression.range, \"Mathf.mod\"\n );\n expr = module.unreachable();\n break;\n }\n assert(prototype.kind == ElementKind.FUNCTION_PROTOTYPE);\n this.f32ModInstance = instance = this.resolver.resolveFunction(prototype, null);\n }\n if (!(instance && this.compileFunction(instance))) {\n expr = module.unreachable();\n } else {\n expr = this.makeCallDirect(instance, [ leftExpr, rightExpr ], expression);\n }\n break;\n }\n case TypeKind.F64: {\n let instance = this.f64ModInstance;\n if (!instance) {\n let namespace = this.program.lookupGlobal(CommonSymbols.Math);\n if (!namespace) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n expression.range, \"Math\"\n );\n expr = module.unreachable();\n break;\n }\n let prototype = namespace.members ? namespace.members.get(CommonSymbols.mod) : null;\n if (!prototype) {\n this.error(\n DiagnosticCode.Cannot_find_name_0,\n expression.range, \"Math.mod\"\n );\n expr = module.unreachable();\n break;\n }\n assert(prototype.kind == ElementKind.FUNCTION_PROTOTYPE);\n this.f64ModInstance = instance = this.resolver.resolveFunction(prototype, null);\n }\n if (!(instance && this.compileFunction(instance))) {\n expr = module.unreachable();\n } else {\n expr = this.makeCallDirect(instance, [ leftExpr, rightExpr ], expression);\n }\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.LESSTHAN_LESSTHAN_EQUALS: compound = true;\n case Token.LESSTHAN_LESSTHAN: {\n leftExpr = this.compileExpression(left, contextualType.intType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_SHL);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL:\n case TypeKind.I32:\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.ShlI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.ShlI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.ShlI64\n : BinaryOp.ShlI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.F32:\n case TypeKind.F64: {\n this.error(\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\n );\n return module.unreachable();\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.GREATERTHAN_GREATERTHAN_EQUALS: compound = true;\n case Token.GREATERTHAN_GREATERTHAN: {\n leftExpr = this.compileExpression(left, contextualType.intType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_SHR);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n leftExpr = this.ensureSmallIntegerWrap(leftExpr, leftType); // must clear garbage bits\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16: {\n expr = module.binary(BinaryOp.ShrI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I32: {\n expr = module.binary(BinaryOp.ShrI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I64: {\n expr = module.binary(BinaryOp.ShrI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.ShrI64\n : BinaryOp.ShrI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.ShrU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.ShrU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.ShrU64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.ShrU64\n : BinaryOp.ShrU32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.F32:\n case TypeKind.F64: {\n this.error(\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\n );\n return module.unreachable();\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS: compound = true;\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN: {\n leftExpr = this.compileExpression(left, contextualType.intType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_SHR_U);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n leftExpr = this.ensureSmallIntegerWrap(leftExpr, leftType); // must clear garbage bits\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n switch (this.currentType.kind) {\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL: { // assumes that unsigned shr on unsigned small integers does not overflow\n expr = module.binary(BinaryOp.ShrU32, leftExpr, rightExpr);\n }\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.ShrU32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.ShrU64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.ShrU64\n : BinaryOp.ShrU32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.F32:\n case TypeKind.F64: {\n this.error(\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\n );\n return module.unreachable();\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.AMPERSAND_EQUALS: compound = true;\n case Token.AMPERSAND: {\n leftExpr = this.compileExpression(left, contextualType.intType);\n leftType = this.currentType;\n\n // check operator overloadd\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_AND);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n if (compound) {\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n } else {\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, false,\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, false,\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \"&\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n }\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL:\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.AndI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.AndI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.AndI64\n : BinaryOp.AndI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.F32:\n case TypeKind.F64: {\n this.error(\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\n );\n return module.unreachable();\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.BAR_EQUALS: compound = true;\n case Token.BAR: {\n leftExpr = this.compileExpression(left, contextualType.intType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_OR);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n if (compound) {\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n } else {\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, false,\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, false,\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \"|\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n }\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.OrI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I32:\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.OrI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.OrI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.OrI64\n : BinaryOp.OrI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.F32:\n case TypeKind.F64: {\n this.error(\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\n );\n return module.unreachable();\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.CARET_EQUALS: compound = true;\n case Token.CARET: {\n leftExpr = this.compileExpression(left, contextualType.intType);\n leftType = this.currentType;\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = leftType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_XOR);\n if (overload) {\n expr = this.compileBinaryOverload(overload, left, leftExpr, right, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n if (compound) {\n rightExpr = this.compileExpression(right, leftType, Constraints.CONV_IMPLICIT);\n rightType = this.currentType;\n } else {\n rightExpr = this.compileExpression(right, leftType);\n rightType = this.currentType;\n if (commonType = Type.commonDenominator(leftType, rightType, false)) {\n leftExpr = this.convertExpression(leftExpr,\n leftType, leftType = commonType,\n false, false,\n left\n );\n rightExpr = this.convertExpression(rightExpr,\n rightType, rightType = commonType,\n false, false,\n right\n );\n } else {\n this.error(\n DiagnosticCode.Operator_0_cannot_be_applied_to_types_1_and_2,\n expression.range, \"^\", leftType.toString(), rightType.toString()\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n }\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.XorI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I32:\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.XorI32, leftExpr, rightExpr);\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.XorI64, leftExpr, rightExpr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.XorI64\n : BinaryOp.XorI32,\n leftExpr,\n rightExpr\n );\n break;\n }\n case TypeKind.F32:\n case TypeKind.F64: {\n this.error(\n DiagnosticCode.The_0_operator_cannot_be_applied_to_type_1,\n expression.range, operatorTokenToString(expression.operator), this.currentType.toString()\n );\n return module.unreachable();\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n\n // logical (no overloading)\n\n case Token.AMPERSAND_AMPERSAND: { // left && right -> (t = left) ? right : t\n let flow = this.currentFlow;\n let inheritedConstraints = constraints & (Constraints.WILL_RETAIN | Constraints.MUST_WRAP);\n leftExpr = this.compileExpression(left, contextualType.exceptVoid, inheritedConstraints);\n leftType = this.currentType;\n\n let rightFlow = flow.fork();\n this.currentFlow = rightFlow;\n rightFlow.inheritNonnullIfTrue(leftExpr);\n rightExpr = this.compileExpression(right, leftType, inheritedConstraints | Constraints.CONV_IMPLICIT);\n rightType = leftType;\n\n // simplify if only interested in true or false\n if (contextualType == Type.bool || contextualType == Type.void) {\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, rightType);\n rightFlow.freeScopedLocals();\n this.currentFlow = flow;\n this.currentType = Type.bool;\n expr = module.if(\n this.makeIsTrueish(leftExpr, leftType),\n this.makeIsTrueish(rightExpr, rightType),\n module.i32(0)\n );\n\n // references must properly retain and release, with the same outcome independent of the branch taken\n } else if (leftType.isManaged) {\n let leftAutoreleaseSkipped = this.skippedAutoreleases.has(leftExpr);\n let rightAutoreleaseSkipped = this.skippedAutoreleases.has(rightExpr);\n let temp = flow.getTempLocal(leftType);\n leftExpr = module.local_tee(temp.index, leftExpr);\n\n // instead of retaining left and releasing it again in right when right\n // is taken, we can also just retain left if right is not taken\n let retainLeftInElse = false;\n if (leftAutoreleaseSkipped != rightAutoreleaseSkipped) { // xor\n if (!leftAutoreleaseSkipped) {\n retainLeftInElse = true;\n } else {\n rightExpr = this.makeRetain(rightExpr);\n rightAutoreleaseSkipped = true;\n }\n } else if (!(constraints & Constraints.WILL_RETAIN)) { // otherwise keep right alive a little longer\n rightExpr = this.moveAutorelease(rightExpr, rightFlow, flow);\n }\n\n let rightStmts = new Array();\n if (leftAutoreleaseSkipped) { // left turned out to be true'ish and is dropped\n rightStmts.unshift(\n this.makeRelease(\n module.local_get(temp.index, leftType.toNativeType())\n )\n );\n }\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, rightType, rightStmts);\n rightFlow.freeScopedLocals();\n this.currentFlow = flow;\n\n expr = module.if(\n this.makeIsTrueish(leftExpr, leftType),\n rightExpr,\n retainLeftInElse\n ? this.makeRetain(\n module.local_get(temp.index, leftType.toNativeType())\n )\n : module.local_get(temp.index, leftType.toNativeType())\n );\n if (leftAutoreleaseSkipped || rightAutoreleaseSkipped) this.skippedAutoreleases.add(expr);\n if (temp) flow.freeTempLocal(temp);\n\n // basic values can use more aggressive optimizations\n } else {\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, rightType);\n rightFlow.freeScopedLocals();\n this.currentFlow = flow;\n\n // simplify if cloning left without side effects is possible\n if (expr = module.cloneExpression(leftExpr, true, 0)) {\n expr = module.if(\n this.makeIsTrueish(leftExpr, this.currentType),\n rightExpr,\n expr\n );\n\n // if not possible, tee left to a temp\n } else {\n let tempLocal = flow.getTempLocal(leftType);\n if (!flow.canOverflow(leftExpr, leftType)) flow.setLocalFlag(tempLocal.index, LocalFlags.WRAPPED);\n if (flow.isNonnull(leftExpr, leftType)) flow.setLocalFlag(tempLocal.index, LocalFlags.NONNULL);\n expr = module.if(\n this.makeIsTrueish(module.local_tee(tempLocal.index, leftExpr), leftType),\n rightExpr,\n module.local_get(tempLocal.index, leftType.toNativeType())\n );\n }\n }\n this.currentType = leftType;\n break;\n }\n case Token.BAR_BAR: { // left || right -> ((t = left) ? t : right)\n let flow = this.currentFlow;\n let inheritedConstraints = constraints & (Constraints.WILL_RETAIN | Constraints.MUST_WRAP);\n leftExpr = this.compileExpression(left, contextualType.exceptVoid, inheritedConstraints);\n leftType = this.currentType;\n\n let rightFlow = flow.fork();\n this.currentFlow = rightFlow;\n rightFlow.inheritNonnullIfFalse(leftExpr);\n rightExpr = this.compileExpression(right, leftType, inheritedConstraints | Constraints.CONV_IMPLICIT);\n rightType = leftType;\n\n // simplify if only interested in true or false\n if (contextualType == Type.bool || contextualType == Type.void) {\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, leftType);\n rightFlow.freeScopedLocals();\n this.currentFlow = flow;\n this.currentType = Type.bool;\n expr = module.if(\n this.makeIsTrueish(leftExpr, leftType),\n module.i32(1),\n this.makeIsTrueish(rightExpr, rightType)\n );\n\n // references must properly retain and release, with the same outcome independent of the branch taken\n } else if (leftType.isManaged) {\n let leftAutoreleaseSkipped = this.skippedAutoreleases.has(leftExpr);\n let rightAutoreleaseSkipped = this.skippedAutoreleases.has(rightExpr);\n let temp = flow.getTempLocal(leftType);\n leftExpr = module.local_tee(temp.index, leftExpr);\n\n // instead of retaining left and releasing it again in right when right\n // is taken, we can also just retain left if right is not taken\n let retainLeftInThen = false;\n if (leftAutoreleaseSkipped != rightAutoreleaseSkipped) { // xor\n if (!leftAutoreleaseSkipped) {\n retainLeftInThen = true;\n } else {\n rightExpr = this.makeRetain(rightExpr);\n rightAutoreleaseSkipped = true;\n }\n } else if (!(constraints & Constraints.WILL_RETAIN)) { // otherwise keep right alive a little longer\n rightExpr = this.moveAutorelease(rightExpr, rightFlow, flow);\n }\n\n let rightStmts = new Array();\n if (leftAutoreleaseSkipped) { // left turned out to be false'ish and is dropped\n // TODO: usually, false'ish means left is null, but this might not hold\n // once implicit conversion with strings is performed and left is \"\", so:\n rightStmts.unshift(\n this.makeRelease(\n module.local_get(temp.index, leftType.toNativeType())\n )\n );\n }\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, rightType, rightStmts);\n rightFlow.freeScopedLocals();\n this.currentFlow = flow;\n\n expr = module.if(\n this.makeIsTrueish(leftExpr, leftType),\n retainLeftInThen\n ? this.makeRetain(\n module.local_get(temp.index, leftType.toNativeType())\n )\n : module.local_get(temp.index, leftType.toNativeType()),\n rightExpr\n );\n if (leftAutoreleaseSkipped || rightAutoreleaseSkipped) this.skippedAutoreleases.add(expr);\n if (temp) flow.freeTempLocal(temp);\n\n // basic values can use more aggressive optimizations\n } else {\n rightExpr = this.performAutoreleasesWithValue(rightFlow, rightExpr, rightType);\n rightFlow.freeScopedLocals();\n this.currentFlow = flow;\n\n // simplify if cloning left without side effects is possible\n if (expr = module.cloneExpression(leftExpr, true, 0)) {\n expr = module.if(\n this.makeIsTrueish(leftExpr, leftType),\n expr,\n rightExpr\n );\n\n // if not possible, tee left to a temp. local\n } else {\n let tempLocal = flow.getAndFreeTempLocal(leftType);\n if (!flow.canOverflow(leftExpr, leftType)) flow.setLocalFlag(tempLocal.index, LocalFlags.WRAPPED);\n if (flow.isNonnull(leftExpr, leftType)) flow.setLocalFlag(tempLocal.index, LocalFlags.NONNULL);\n expr = module.if(\n this.makeIsTrueish(module.local_tee(tempLocal.index, leftExpr), leftType),\n module.local_get(tempLocal.index, leftType.toNativeType()),\n rightExpr\n );\n }\n }\n this.currentType = leftType;\n break;\n }\n default: {\n assert(false);\n expr = this.module.unreachable();\n }\n }\n if (!compound) return expr;\n var resolver = this.resolver;\n var target = this.resolver.resolveExpression(left, this.currentFlow);\n if (!target) return module.unreachable();\n return this.makeAssignment(\n target,\n expr, // TODO: delay release above if possible?\n left,\n resolver.currentThisExpression,\n resolver.currentElementExpression,\n contextualType != Type.void\n );\n }\n\n compileUnaryOverload(\n operatorInstance: Function,\n value: Expression,\n valueExpr: ExpressionRef,\n reportNode: Node\n ): ExpressionRef {\n // FIXME: see comment in compileBinaryOverload below why recompiling on type mismatch\n // is a bad idea currently. so this assumes that the type matches.\n return this.makeCallDirect(operatorInstance, [ valueExpr ], reportNode, false);\n }\n\n compileBinaryOverload(\n operatorInstance: Function,\n left: Expression,\n leftExpr: ExpressionRef,\n right: Expression,\n reportNode: Node\n ): ExpressionRef {\n var rightType: Type;\n if (operatorInstance.is(CommonFlags.INSTANCE)) {\n let classInstance = assert(operatorInstance.parent); assert(classInstance.kind == ElementKind.CLASS);\n rightType = operatorInstance.signature.parameterTypes[0];\n } else {\n // FIXME: if LHS type differs we can't recompile left because that'd completely confuse\n // local states, like having retained locals that actually do not even exist, possibly\n // releasing something random in that local before and evil things like that. Hence this\n // assumes that LHS type matches, which in turn means that static overloads must be\n // guaranteed to never mismatch LHS type, which in turn means that we can't have shiny\n // things like multiple static overloads for different combinations of LHS/RHS types.\n // We might want that at some point of course, but requires to complete the resolver so\n // it can actually resolve every kind of expression without ever having to recompile.\n rightType = operatorInstance.signature.parameterTypes[1];\n }\n var rightExpr = this.compileExpression(right, rightType, Constraints.CONV_IMPLICIT);\n return this.makeCallDirect(operatorInstance, [ leftExpr, rightExpr ], reportNode);\n }\n\n compileAssignment(expression: Expression, valueExpression: Expression, contextualType: Type): ExpressionRef {\n var program = this.program;\n var resolver = program.resolver;\n var flow = this.currentFlow;\n var target = resolver.resolveExpression(expression, flow); // reports\n if (!target) return this.module.unreachable();\n var thisExpression = resolver.currentThisExpression;\n var elementExpression = resolver.currentElementExpression;\n\n // to compile just the value, we need to know the target's type\n var targetType: Type;\n switch (target.kind) {\n case ElementKind.GLOBAL: {\n // not yet compiled if a static field compiled as a global\n if (!this.compileGlobal(target)) return this.module.unreachable(); // reports\n // fall-through\n }\n case ElementKind.FIELD: {\n targetType = (target).type;\n break;\n }\n case ElementKind.LOCAL: {\n targetType = (target).type;\n break;\n }\n case ElementKind.PROPERTY_PROTOTYPE: { // static property\n let setterPrototype = (target).setterPrototype;\n if (!setterPrototype) {\n this.error(\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\n expression.range, (target).internalName\n );\n return this.module.unreachable();\n }\n let setterInstance = this.resolver.resolveFunction(setterPrototype, null, makeMap(), ReportMode.REPORT);\n if (!setterInstance) return this.module.unreachable();\n assert(setterInstance.signature.parameterTypes.length == 1); // parser must guarantee this\n targetType = setterInstance.signature.parameterTypes[0];\n break;\n }\n case ElementKind.PROPERTY: { // instance property\n let setterInstance = (target).setterInstance;\n if (!setterInstance) {\n this.error(\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\n expression.range, (target).internalName\n );\n return this.module.unreachable();\n }\n assert(setterInstance.signature.parameterTypes.length == 1); // parser must guarantee this\n targetType = setterInstance.signature.parameterTypes[0];\n break;\n }\n case ElementKind.CLASS: {\n if (elementExpression) { // indexed access\n let isUnchecked = flow.is(FlowFlags.UNCHECKED_CONTEXT);\n // if (isUnchecked) {\n // let arrayType = this.program.determineBuiltinArrayType(target);\n // if (arrayType) {\n // return compileBuiltinArraySet(\n // this,\n // target,\n // assert(this.resolver.currentThisExpression),\n // elementExpression,\n // valueExpression,\n // contextualType\n // );\n // }\n // }\n let indexedSet = (target).lookupOverload(OperatorKind.INDEXED_SET, isUnchecked);\n if (!indexedSet) {\n let indexedGet = (target).lookupOverload(OperatorKind.INDEXED_GET, isUnchecked);\n if (!indexedGet) {\n this.error(\n DiagnosticCode.Index_signature_is_missing_in_type_0,\n expression.range, (target).internalName\n );\n } else {\n this.error(\n DiagnosticCode.Index_signature_in_type_0_only_permits_reading,\n expression.range, (target).internalName\n );\n }\n return this.module.unreachable();\n }\n assert(indexedSet.signature.parameterTypes.length == 2); // parser must guarantee this\n targetType = indexedSet.signature.parameterTypes[1]; // 2nd parameter is the element\n break;\n }\n // fall-through\n }\n default: {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n }\n\n // compile the value and do the assignment\n assert(targetType != Type.void);\n return this.makeAssignment(\n target,\n this.compileExpression(valueExpression, targetType, Constraints.CONV_IMPLICIT | Constraints.WILL_RETAIN),\n expression,\n thisExpression,\n elementExpression,\n contextualType != Type.void\n );\n }\n\n /** Makes an assignment expression or block, assigning a value to a target. */\n makeAssignment(\n /** Target element, e.g. a Local. */\n target: Element,\n /** Value expression that has been compiled in a previous step already. */\n valueExpr: ExpressionRef,\n /** Expression reference. Has already been compiled to `valueExpr`. */\n valueExpression: Expression,\n /** `this` expression reference if a field or property set. */\n thisExpression: Expression | null,\n /** Index expression reference if an indexed set. */\n indexExpression: Expression | null,\n /** Whether to tee the value. */\n tee: bool\n ): ExpressionRef {\n var module = this.module;\n var flow = this.currentFlow;\n\n // NOTE: Only locals, globals and fields can make use of skipped autoreleases while\n // everything else must insert the skipped autorelease now. See (*)\n\n switch (target.kind) {\n case ElementKind.LOCAL: {\n if (flow.isLocalFlag((target).index, LocalFlags.CONSTANT, true)) {\n this.error(\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\n valueExpression.range, target.internalName\n );\n this.currentType = tee ? (target).type : Type.void;\n return module.unreachable();\n }\n return this.makeLocalAssignment(target, valueExpr, tee);\n }\n case ElementKind.GLOBAL: {\n if (!this.compileGlobal(target)) return module.unreachable();\n if (target.isAny(CommonFlags.CONST | CommonFlags.READONLY)) {\n this.error(\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\n valueExpression.range,\n target.internalName\n );\n this.currentType = tee ? (target).type : Type.void;\n return module.unreachable();\n }\n return this.makeGlobalAssignment(target, valueExpr, tee);\n }\n case ElementKind.FIELD: {\n let initializerNode = (target).initializerNode;\n if (\n (target).is(CommonFlags.READONLY) &&\n !(\n flow.actualFunction.is(CommonFlags.CONSTRUCTOR) ||\n initializerNode\n )\n ) {\n this.error(\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\n valueExpression.range, (target).internalName\n );\n return module.unreachable();\n }\n return this.makeFieldAssignment(target,\n valueExpr,\n // FIXME: explicit type (currently fails due to missing null checking)\n this.compileExpression(assert(thisExpression), this.options.usizeType),\n tee\n );\n }\n case ElementKind.PROPERTY_PROTOTYPE: { // static property\n if (this.skippedAutoreleases.has(valueExpr)) valueExpr = this.makeAutorelease(valueExpr, flow); // (*)\n let setterPrototype = (target).setterPrototype;\n if (!setterPrototype) {\n this.error(\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\n valueExpression.range, target.internalName\n );\n return module.unreachable();\n }\n let setterInstance = this.resolver.resolveFunction(setterPrototype, null, makeMap(), ReportMode.REPORT);\n if (!setterInstance) return module.unreachable();\n // call just the setter if the return value isn't of interest\n if (!tee) return this.makeCallDirect(setterInstance, [ valueExpr ], valueExpression);\n // otherwise call the setter first, then the getter\n let getterPrototype = assert((target).getterPrototype); // must be present\n let getterInstance = this.resolver.resolveFunction(getterPrototype, null, makeMap(), ReportMode.REPORT);\n if (!getterInstance) return module.unreachable();\n let returnType = getterInstance.signature.returnType;\n let nativeReturnType = returnType.toNativeType();\n return module.block(null, [\n this.makeCallDirect(setterInstance, [ valueExpr ], valueExpression),\n this.makeCallDirect(getterInstance, null, valueExpression) // sets currentType\n ], nativeReturnType);\n }\n case ElementKind.PROPERTY: { // instance property\n if (this.skippedAutoreleases.has(valueExpr)) valueExpr = this.makeAutorelease(valueExpr, flow); // (*)\n let setterInstance = (target).setterInstance;\n if (!setterInstance) {\n this.error(\n DiagnosticCode.Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property,\n valueExpression.range, target.internalName\n );\n return module.unreachable();\n }\n // call just the setter if the return value isn't of interest\n if (!tee) {\n let thisExpr = this.compileExpression(assert(thisExpression), this.options.usizeType);\n return this.makeCallDirect(setterInstance, [ thisExpr, valueExpr ], valueExpression);\n }\n // otherwise call the setter first, then the getter\n let getterInstance = assert((target).getterInstance); // must be present\n let returnType = getterInstance.signature.returnType;\n let nativeReturnType = returnType.toNativeType();\n let thisExpr = this.compileExpression(assert(thisExpression), this.options.usizeType);\n let tempLocal = flow.getAndFreeTempLocal(returnType);\n let tempLocalIndex = tempLocal.index;\n return module.block(null, [\n this.makeCallDirect(setterInstance, [ // set and remember the target\n module.local_tee(tempLocalIndex, thisExpr),\n valueExpr\n ], valueExpression),\n this.makeCallDirect(getterInstance, [ // get from remembered target\n module.local_get(tempLocalIndex, nativeReturnType)\n ], valueExpression)\n ], nativeReturnType);\n }\n case ElementKind.CLASS: {\n if (this.skippedAutoreleases.has(valueExpr)) valueExpr = this.makeAutorelease(valueExpr, flow); // (*)\n if (indexExpression) {\n let isUnchecked = flow.is(FlowFlags.UNCHECKED_CONTEXT);\n let indexedGet = (target).lookupOverload(OperatorKind.INDEXED_GET, isUnchecked);\n if (!indexedGet) {\n this.error(\n DiagnosticCode.Index_signature_is_missing_in_type_0,\n valueExpression.range, target.internalName\n );\n return module.unreachable();\n }\n let indexedSet = (target).lookupOverload(OperatorKind.INDEXED_SET, isUnchecked);\n if (!indexedSet) {\n this.error(\n DiagnosticCode.Index_signature_in_type_0_only_permits_reading,\n valueExpression.range, target.internalName\n );\n this.currentType = tee ? indexedGet.signature.returnType : Type.void;\n return module.unreachable();\n }\n let targetType = (target).type;\n let thisExpr = this.compileExpression(assert(thisExpression), this.options.usizeType);\n let elementExpr = this.compileExpression(indexExpression, Type.i32, Constraints.CONV_IMPLICIT);\n if (tee) {\n let tempLocalTarget = flow.getTempLocal(targetType);\n let tempLocalElement = flow.getAndFreeTempLocal(this.currentType);\n let returnType = indexedGet.signature.returnType;\n flow.freeTempLocal(tempLocalTarget);\n return module.block(null, [\n this.makeCallDirect(indexedSet, [\n module.local_tee(tempLocalTarget.index, thisExpr),\n module.local_tee(tempLocalElement.index, elementExpr),\n valueExpr\n ], valueExpression),\n this.makeCallDirect(indexedGet, [\n module.local_get(tempLocalTarget.index, tempLocalTarget.type.toNativeType()),\n module.local_get(tempLocalElement.index, tempLocalElement.type.toNativeType())\n ], valueExpression)\n ], returnType.toNativeType());\n } else {\n return this.makeCallDirect(indexedSet, [\n thisExpr,\n elementExpr,\n valueExpr\n ], valueExpression);\n }\n }\n // fall-through\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n valueExpression.range\n );\n return module.unreachable();\n }\n\n /** Makes an assignment to a local, possibly retaining and releasing affected references and keeping track of wrap and null states. */\n private makeLocalAssignment(\n /** The local to assign to. */\n local: Local,\n /** The value to assign. */\n valueExpr: ExpressionRef,\n /** Whether to tee the value. */\n tee: bool\n ): ExpressionRef {\n var type = local.type;\n assert(type != Type.void);\n var flow = this.currentFlow;\n var localIndex = local.index;\n\n if (type.is(TypeFlags.NULLABLE)) {\n if (flow.isNonnull(valueExpr, type)) flow.setLocalFlag(localIndex, LocalFlags.NONNULL);\n else flow.unsetLocalFlag(localIndex, LocalFlags.NONNULL);\n }\n flow.setLocalFlag(localIndex, LocalFlags.WRITTENTO);\n\n if (type.isManaged) {\n let module = this.module;\n let nativeType = type.toNativeType();\n\n if (flow.isAnyLocalFlag(localIndex, LocalFlags.ANY_RETAINED)) {\n if (this.skippedAutoreleases.has(valueExpr)) {\n valueExpr = this.makeSkippedRelease(\n module.local_get(localIndex, nativeType), // oldRef\n valueExpr // newRef\n );\n if (tee) { // TEE(local = __skippedRelease(local, value))\n this.currentType = type;\n return module.local_tee(localIndex, valueExpr);\n } else { // local = __skippedRelease(local, value)\n this.currentType = Type.void;\n return module.local_set(localIndex, valueExpr);\n }\n } else {\n valueExpr = this.makeRetainRelease(\n module.local_get(localIndex, nativeType), // oldRef\n valueExpr // newRef\n );\n if (tee) { // TEE(local = __retainRelease(local, value))\n this.currentType = type;\n return module.local_tee(localIndex, valueExpr);\n } else { // local = __retainRelease(local, value)\n this.currentType = Type.void;\n return module.local_set(localIndex, valueExpr);\n }\n }\n } else {\n flow.unsetLocalFlag(localIndex, LocalFlags.CONDITIONALLY_RETAINED);\n flow.setLocalFlag(localIndex, LocalFlags.RETAINED);\n if (!this.skippedAutoreleases.has(valueExpr)) valueExpr = this.makeRetain(valueExpr);\n if (tee) { // TEE(local = __retain(value, local))\n this.currentType = type;\n return module.local_tee(localIndex, valueExpr);\n } else { // local = __retain(value, local)\n this.currentType = Type.void;\n return module.local_set(localIndex, valueExpr);\n }\n }\n } else {\n if (type.is(TypeFlags.SHORT | TypeFlags.INTEGER)) {\n if (!flow.canOverflow(valueExpr, type)) flow.setLocalFlag(localIndex, LocalFlags.WRAPPED);\n else flow.unsetLocalFlag(localIndex, LocalFlags.WRAPPED);\n }\n if (tee) { // TEE(local = value)\n this.currentType = type;\n return this.module.local_tee(localIndex, valueExpr);\n } else { // local = value\n this.currentType = Type.void;\n return this.module.local_set(localIndex, valueExpr);\n }\n }\n }\n\n /** Makes an assignment to a global, possibly retaining and releasing affected references. */\n private makeGlobalAssignment(\n /** The global to assign to. */\n global: Global,\n /** The value to assign. */\n valueExpr: ExpressionRef,\n /** Whether to tee the value. */\n tee: bool\n ): ExpressionRef {\n var module = this.module;\n var type = global.type;\n assert(type != Type.void);\n var nativeType = type.toNativeType();\n\n if (type.isManaged) {\n if (this.skippedAutoreleases.has(valueExpr)) {\n if (tee) { // (global = __skippedRelease(global, value)), global\n this.currentType = type;\n return module.block(null, [\n module.global_set(global.internalName,\n this.makeSkippedRelease(\n module.global_get(global.internalName, nativeType), // oldRef\n valueExpr // newRef\n )\n ),\n module.global_get(global.internalName, nativeType)\n ], nativeType);\n } else { // global = __skippedRelease(global, value)\n this.currentType = Type.void;\n return module.global_set(global.internalName,\n this.makeSkippedRelease(\n module.global_get(global.internalName, nativeType), // oldRef\n valueExpr // newRef\n )\n );\n }\n } else {\n if (tee) { // (global = __retainRelease(global, value)), global\n this.currentType = type;\n return module.block(null, [\n module.global_set(global.internalName,\n this.makeRetainRelease(\n module.global_get(global.internalName, nativeType), // oldRef\n valueExpr // newRef\n )\n ),\n module.global_get(global.internalName, nativeType)\n ], nativeType);\n } else { // global = __retainRelease(global, value)\n this.currentType = Type.void;\n return module.global_set(global.internalName,\n this.makeRetainRelease(\n module.global_get(global.internalName, nativeType), // oldRef\n valueExpr // newRef\n )\n );\n }\n }\n } else {\n valueExpr = this.ensureSmallIntegerWrap(valueExpr, type); // globals must be wrapped\n if (tee) { // (global = value), global\n this.currentType = type;\n return module.block(null, [\n module.global_set(global.internalName, valueExpr),\n module.global_get(global.internalName, nativeType)\n ], nativeType);\n } else { // global = value\n this.currentType = Type.void;\n return module.global_set(global.internalName,\n valueExpr\n );\n }\n }\n }\n\n /** Makes an assignment to a field, possibly retaining and releasing affected references. */\n makeFieldAssignment(\n /** The field to assign to. */\n field: Field,\n /** The value to assign. */\n valueExpr: ExpressionRef,\n /** The value of `this`. */\n thisExpr: ExpressionRef,\n /** Whether to tee the value. */\n tee: bool\n ): ExpressionRef {\n var module = this.module;\n var flow = this.currentFlow;\n var fieldType = field.type;\n var nativeFieldType = fieldType.toNativeType();\n assert(field.parent.kind == ElementKind.CLASS);\n var thisType = (field.parent).type;\n var nativeThisType = thisType.toNativeType();\n\n if (fieldType.isManaged && thisType.isManaged) {\n let tempThis = flow.getTempLocal(thisType);\n if (this.skippedAutoreleases.has(valueExpr)) {\n if (tee) { // ((t1 = this).field = __skippedRelease(t1.field, t2 = value)), t2\n let tempValue = flow.getAndFreeTempLocal(fieldType);\n if (!flow.canOverflow(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.WRAPPED);\n if (flow.isNonnull(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.NONNULL);\n flow.freeTempLocal(tempThis);\n this.currentType = fieldType;\n return module.block(null, [\n module.store(fieldType.byteSize,\n module.local_tee(tempThis.index, thisExpr),\n this.makeSkippedRelease(\n module.load(fieldType.byteSize, fieldType.is(TypeFlags.SIGNED), // oldRef\n module.local_get(tempThis.index, nativeThisType),\n nativeFieldType, field.memoryOffset\n ),\n module.local_tee(tempValue.index, valueExpr), // newRef\n ),\n nativeFieldType, field.memoryOffset\n ),\n module.local_get(tempValue.index, nativeFieldType)\n ], nativeFieldType);\n } else { // (t1 = this).field = __skippedRelease(t1.field, value)\n flow.freeTempLocal(tempThis);\n this.currentType = Type.void;\n return module.store(fieldType.byteSize,\n module.local_tee(tempThis.index, thisExpr),\n this.makeSkippedRelease(\n module.load(fieldType.byteSize, fieldType.is(TypeFlags.SIGNED), // oldRef\n module.local_get(tempThis.index, nativeThisType),\n nativeFieldType, field.memoryOffset\n ),\n valueExpr, // newRef\n ),\n nativeFieldType, field.memoryOffset\n );\n }\n } else {\n if (tee) { // ((t1 = this).field = __retainRelease(t1.field, t2 = value)), t2\n let tempValue = flow.getAndFreeTempLocal(fieldType);\n if (!flow.canOverflow(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.WRAPPED);\n if (flow.isNonnull(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.NONNULL);\n flow.freeTempLocal(tempThis);\n this.currentType = fieldType;\n return module.block(null, [\n module.store(fieldType.byteSize,\n module.local_tee(tempThis.index, thisExpr),\n this.makeRetainRelease(\n module.load(fieldType.byteSize, fieldType.is(TypeFlags.SIGNED), // oldRef\n module.local_get(tempThis.index, nativeThisType),\n nativeFieldType, field.memoryOffset\n ),\n module.local_tee(tempValue.index, valueExpr) // newRef\n ),\n nativeFieldType, field.memoryOffset\n ),\n module.local_get(tempValue.index, nativeFieldType)\n ], nativeFieldType);\n } else { // (t1 = this).field = __retainRelease(t1.field, value)\n flow.freeTempLocal(tempThis);\n this.currentType = Type.void;\n return module.store(fieldType.byteSize,\n module.local_tee(tempThis.index, thisExpr),\n this.makeRetainRelease(\n module.load(fieldType.byteSize, fieldType.is(TypeFlags.SIGNED), // oldRef\n module.local_get(tempThis.index, nativeThisType),\n nativeFieldType, field.memoryOffset\n ),\n valueExpr // newRef\n ),\n nativeFieldType, field.memoryOffset\n );\n }\n }\n } else {\n if (tee) { // (this.field = (t1 = value)), t1\n let tempValue = flow.getAndFreeTempLocal(fieldType);\n if (!flow.canOverflow(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.WRAPPED);\n if (flow.isNonnull(valueExpr, fieldType)) flow.setLocalFlag(tempValue.index, LocalFlags.NONNULL);\n this.currentType = fieldType;\n return module.block(null, [\n module.store(fieldType.byteSize,\n thisExpr,\n module.local_tee(tempValue.index, valueExpr),\n nativeFieldType, field.memoryOffset\n ),\n module.local_get(tempValue.index, nativeFieldType)\n ], nativeFieldType);\n } else { // this.field = value\n this.currentType = Type.void;\n return module.store(fieldType.byteSize,\n thisExpr,\n valueExpr,\n nativeFieldType, field.memoryOffset\n );\n }\n }\n }\n\n /** Compiles a call expression according to the specified context. */\n compileCallExpression(\n /** Call expression to compile. */\n expression: CallExpression,\n /** Contextual type indicating the return type the caller expects, if any. */\n contextualType: Type,\n /** Constraints indicating contextual conditions. */\n constraints: Constraints\n ): ExpressionRef {\n\n var module = this.module;\n var flow = this.currentFlow;\n\n // handle call to super\n if (expression.expression.kind == NodeKind.SUPER) {\n let flow = this.currentFlow;\n let actualFunction = flow.actualFunction;\n if (!actualFunction.is(CommonFlags.CONSTRUCTOR)) {\n this.error(\n DiagnosticCode.Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors,\n expression.range\n );\n return module.unreachable();\n }\n\n let classInstance = assert(actualFunction.parent); assert(classInstance.kind == ElementKind.CLASS);\n let baseClassInstance = assert((classInstance).base);\n let thisLocal = assert(flow.lookupLocal(CommonSymbols.this_));\n let nativeSizeType = this.options.nativeSizeType;\n\n // {\n // this = super(this || , ...args)\n // this.a = X\n // this.b = Y\n // }\n let theCall = this.compileCallDirect(\n this.ensureConstructor(baseClassInstance, expression),\n expression.arguments,\n expression,\n module.if(\n module.local_get(thisLocal.index, nativeSizeType),\n module.local_get(thisLocal.index, nativeSizeType),\n this.makeRetain(\n this.makeAllocation(classInstance)\n )\n ),\n Constraints.WILL_RETAIN\n );\n assert(this.skippedAutoreleases.has(theCall)); // guaranteed\n let stmts: ExpressionRef[] = [\n module.local_set(thisLocal.index, theCall)\n ];\n this.makeFieldInitialization(classInstance, stmts);\n\n // check that super had been called before accessing `this`\n if (flow.isAny(\n FlowFlags.ALLOCATES |\n FlowFlags.CONDITIONALLY_ALLOCATES\n )) {\n this.error(\n DiagnosticCode._super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class,\n expression.range\n );\n return module.unreachable();\n }\n flow.set(FlowFlags.ALLOCATES | FlowFlags.CALLS_SUPER);\n this.currentType = Type.void;\n return module.block(null, stmts);\n }\n\n // otherwise resolve normally\n var target = this.resolver.resolveExpression(expression.expression, flow); // reports\n if (!target) return module.unreachable();\n\n var signature: Signature | null;\n var indexArg: ExpressionRef;\n switch (target.kind) {\n\n // direct call: concrete function\n case ElementKind.FUNCTION_PROTOTYPE: {\n let prototype = target;\n let typeArguments = expression.typeArguments;\n\n // builtins handle present respectively omitted type arguments on their own\n if (prototype.hasDecorator(DecoratorFlags.BUILTIN)) {\n return this.compileCallExpressionBuiltin(prototype, expression, contextualType);\n }\n\n let instance: Function | null = null;\n\n // resolve generic call if type arguments have been provided\n if (typeArguments) {\n if (!prototype.is(CommonFlags.GENERIC)) {\n this.error(\n DiagnosticCode.Type_0_is_not_generic,\n expression.expression.range, prototype.internalName\n );\n return module.unreachable();\n }\n instance = this.resolver.resolveFunctionInclTypeArguments(\n prototype,\n typeArguments,\n flow.actualFunction.parent, // relative to caller\n makeMap(flow.contextualTypeArguments),\n expression\n );\n\n // infer generic call if type arguments have been omitted\n } else if (prototype.is(CommonFlags.GENERIC)) {\n let inferredTypes = new Map();\n let typeParameterNodes = assert(prototype.typeParameterNodes);\n let numTypeParameters = typeParameterNodes.length;\n for (let i = 0; i < numTypeParameters; ++i) {\n inferredTypes.set(typeParameterNodes[i].name.text, null);\n }\n // let numInferred = 0;\n let parameterNodes = prototype.functionTypeNode.parameters;\n let numParameters = parameterNodes.length;\n let argumentNodes = expression.arguments;\n let numArguments = argumentNodes.length;\n let argumentExprs = new Array(numArguments);\n for (let i = 0; i < numParameters; ++i) {\n let typeNode = parameterNodes[i].type;\n let templateName = typeNode.kind == NodeKind.NAMEDTYPE && !(typeNode).name.next\n ? (typeNode).name.identifier.text\n : null;\n let argumentExpression = i < numArguments\n ? argumentNodes[i]\n : parameterNodes[i].initializer;\n if (!argumentExpression) { // missing initializer -> too few arguments\n this.error(\n DiagnosticCode.Expected_0_arguments_but_got_1,\n expression.range, numParameters.toString(10), numArguments.toString(10)\n );\n return module.unreachable();\n }\n if (templateName !== null && inferredTypes.has(templateName)) {\n let inferredType = inferredTypes.get(templateName);\n if (inferredType) {\n argumentExprs[i] = this.compileExpression(argumentExpression, inferredType);\n let commonType: Type | null;\n if (!(commonType = Type.commonDenominator(inferredType, this.currentType, true))) {\n if (!(commonType = Type.commonDenominator(inferredType, this.currentType, false))) {\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n parameterNodes[i].type.range, this.currentType.toString(), inferredType.toString()\n );\n return module.unreachable();\n }\n }\n inferredType = commonType;\n } else {\n argumentExprs[i] = this.compileExpression(argumentExpression, Type.auto);\n inferredType = this.currentType;\n // ++numInferred;\n }\n inferredTypes.set(templateName, inferredType);\n } else {\n let concreteType = this.resolver.resolveType(\n parameterNodes[i].type,\n flow.actualFunction,\n flow.contextualTypeArguments\n );\n if (!concreteType) return module.unreachable();\n argumentExprs[i] = this.compileExpression(argumentExpression, concreteType, Constraints.CONV_IMPLICIT);\n }\n }\n let resolvedTypeArguments = new Array(numTypeParameters);\n for (let i = 0; i < numTypeParameters; ++i) {\n let inferredType = assert(inferredTypes.get(typeParameterNodes[i].name.text)); // TODO\n resolvedTypeArguments[i] = inferredType;\n }\n instance = this.resolver.resolveFunction(\n prototype,\n resolvedTypeArguments,\n makeMap(flow.contextualTypeArguments)\n );\n if (!instance) return this.module.unreachable();\n return this.makeCallDirect(instance, argumentExprs, expression, contextualType == Type.void);\n // TODO: this skips inlining because inlining requires compiling its temporary locals in\n // the scope of the inlined flow. might need another mechanism to lock temp. locals early,\n // so inlining can be performed in `makeCallDirect` instead?\n\n // otherwise resolve the non-generic call as usual\n } else {\n instance = this.resolver.resolveFunction(prototype, null);\n }\n if (!instance) return this.module.unreachable();\n\n // compile 'this' expression if an instance method\n let thisExpr: ExpressionRef = 0;\n if (instance.is(CommonFlags.INSTANCE)) {\n thisExpr = this.compileExpression(assert(this.resolver.currentThisExpression), this.options.usizeType);\n }\n\n return this.compileCallDirect(\n instance,\n expression.arguments,\n expression,\n thisExpr,\n constraints\n );\n }\n\n // indirect call: index argument with signature (non-generic, can't be inlined)\n case ElementKind.LOCAL: {\n if (signature = (target).type.signatureReference) {\n if ((target).is(CommonFlags.INLINED)) {\n indexArg = module.i32(i64_low((target).constantIntegerValue));\n } else {\n indexArg = module.local_get((target).index, NativeType.I32);\n }\n break;\n } else {\n this.error(\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\n expression.range, (target).type.toString()\n );\n return module.unreachable();\n }\n }\n case ElementKind.GLOBAL: {\n if (signature = (target).type.signatureReference) {\n indexArg = module.global_get((target).internalName, (target).type.toNativeType());\n break;\n } else {\n this.error(\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\n expression.range, (target).type.toString()\n );\n return module.unreachable();\n }\n }\n case ElementKind.FIELD: {\n let type = (target).type;\n if (signature = type.signatureReference) {\n let thisExpression = assert(this.resolver.currentThisExpression);\n let thisExpr = this.compileExpression(thisExpression, this.options.usizeType);\n indexArg = module.load(\n 4,\n false,\n thisExpr,\n NativeType.I32,\n (target).memoryOffset\n );\n break;\n } else {\n this.error(\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\n expression.range, type.toString()\n );\n return module.unreachable();\n }\n }\n case ElementKind.FUNCTION_TARGET: {\n signature = (target).signature;\n indexArg = this.compileExpression(expression.expression, (target).type, Constraints.CONV_IMPLICIT);\n break;\n }\n\n case ElementKind.PROPERTY_PROTOTYPE: { // static property\n let getterPrototype = assert((target).getterPrototype);\n let getterInstance = this.resolver.resolveFunction(getterPrototype, null);\n if (!getterInstance) return module.unreachable();\n indexArg = this.compileCallDirect(getterInstance, [], expression.expression);\n signature = this.currentType.signatureReference;\n if (!signature) {\n this.error(\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\n expression.range, this.currentType.toString()\n );\n return module.unreachable();\n }\n break;\n }\n case ElementKind.PROPERTY: { // instance property\n let getterInstance = assert((target).getterInstance);\n indexArg = this.compileCallDirect(getterInstance, [], expression.expression,\n this.compileExpression(assert(this.resolver.currentThisExpression), this.options.usizeType)\n );\n signature = this.currentType.signatureReference;\n if (!signature) {\n this.error(\n DiagnosticCode.Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures,\n expression.range, this.currentType.toString()\n );\n return module.unreachable();\n }\n break;\n }\n\n // not supported\n default: {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return module.unreachable();\n }\n }\n return this.compileCallIndirect(\n signature,\n indexArg,\n expression.arguments,\n expression,\n 0,\n contextualType == Type.void\n );\n }\n\n private compileCallExpressionBuiltin(\n prototype: FunctionPrototype,\n expression: CallExpression,\n contextualType: Type\n ): ExpressionRef {\n var typeArguments: Type[] | null = null;\n\n // builtins handle omitted type arguments on their own. if present, however, resolve them here\n // and pass them to the builtin, even if it's still up to the builtin how to handle them.\n var typeParameterNodes = prototype.typeParameterNodes;\n var typeArgumentNodes = expression.typeArguments;\n if (expression.typeArguments) {\n if (!prototype.is(CommonFlags.GENERIC)) {\n this.error(\n DiagnosticCode.Type_0_is_not_generic,\n expression.range, prototype.internalName\n );\n }\n typeArguments = this.resolver.resolveTypeArguments(\n assert(typeParameterNodes),\n typeArgumentNodes,\n this.currentFlow.actualFunction.parent,\n makeMap(this.currentFlow.contextualTypeArguments),\n expression\n );\n }\n\n // now compile the builtin, which usually returns a block of code that replaces the call.\n var expr = compileBuiltinCall(\n this,\n prototype,\n typeArguments,\n expression.arguments,\n contextualType,\n expression\n );\n if (!expr) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n return expr;\n }\n\n /**\n * Checks that a call with the given number as arguments can be performed according to the\n * specified signature.\n */\n checkCallSignature(\n signature: Signature,\n numArguments: i32,\n hasThis: bool,\n reportNode: Node\n ): bool {\n\n // cannot call an instance method without a `this` argument (TODO: `.call`?)\n var thisType = signature.thisType;\n if (hasThis != (thisType != null)) {\n this.error(\n DiagnosticCode.Operation_not_supported, // TODO: better message?\n reportNode.range\n );\n return false;\n }\n\n // not yet implemented (TODO: maybe some sort of an unmanaged/lightweight array?)\n var hasRest = signature.hasRest;\n if (hasRest) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.range\n );\n return false;\n }\n\n var minimum = signature.requiredParameters;\n var maximum = signature.parameterTypes.length;\n\n // must at least be called with required arguments\n if (numArguments < minimum) {\n this.error(\n minimum < maximum\n ? DiagnosticCode.Expected_at_least_0_arguments_but_got_1\n : DiagnosticCode.Expected_0_arguments_but_got_1,\n reportNode.range, minimum.toString(), numArguments.toString()\n );\n return false;\n }\n\n // must not be called with more than the maximum arguments\n if (numArguments > maximum && !hasRest) {\n this.error(\n DiagnosticCode.Expected_0_arguments_but_got_1,\n reportNode.range, maximum.toString(), numArguments.toString()\n );\n return false;\n }\n\n return true;\n }\n\n /** Compiles a direct call to a concrete function. */\n compileCallDirect(\n instance: Function,\n argumentExpressions: Expression[],\n reportNode: Node,\n thisArg: ExpressionRef = 0,\n constraints: Constraints = Constraints.NONE\n ): ExpressionRef {\n var numArguments = argumentExpressions.length;\n var signature = instance.signature;\n if (!this.checkCallSignature( // reports\n signature,\n numArguments,\n thisArg != 0,\n reportNode\n )) {\n this.currentType = signature.returnType;\n return this.module.unreachable();\n }\n\n // Inline if explicitly requested\n if (instance.hasDecorator(DecoratorFlags.INLINE)) {\n assert(!instance.is(CommonFlags.TRAMPOLINE)); // doesn't make sense\n if (this.currentInlineFunctions.includes(instance)) {\n this.warning(\n DiagnosticCode.Function_0_cannot_be_inlined_into_itself,\n reportNode.range, instance.internalName\n );\n } else {\n this.currentInlineFunctions.push(instance);\n let parameterTypes = signature.parameterTypes;\n assert(numArguments <= parameterTypes.length);\n // compile argument expressions\n let args = new Array(numArguments);\n for (let i = 0; i < numArguments; ++i) {\n args[i] = this.compileExpression(argumentExpressions[i], parameterTypes[i],\n Constraints.CONV_IMPLICIT | Constraints.WILL_RETAIN\n );\n }\n // make the inlined call (is aware of autoreleases)\n let expr = this.makeCallInline(instance, args, thisArg, (constraints & Constraints.WILL_DROP) != 0);\n if (this.currentType.isManaged) {\n if (!(constraints & Constraints.WILL_RETAIN)) {\n expr = this.makeAutorelease(expr, this.currentFlow);\n } else {\n this.skippedAutoreleases.add(expr);\n }\n }\n this.currentInlineFunctions.pop();\n return expr;\n }\n }\n\n // Otherwise compile to just a call\n var numArgumentsInclThis = thisArg ? numArguments + 1 : numArguments;\n var operands = new Array(numArgumentsInclThis);\n var index = 0;\n if (thisArg) {\n operands[0] = thisArg;\n index = 1;\n }\n var parameterTypes = signature.parameterTypes;\n for (let i = 0; i < numArguments; ++i, ++index) {\n operands[index] = this.compileExpression(argumentExpressions[i], parameterTypes[i],\n Constraints.CONV_IMPLICIT\n );\n }\n assert(index == numArgumentsInclThis);\n if (signature.returnType.isManaged) {\n if (constraints & Constraints.WILL_DROP) {\n // Skip autorelease and simply release\n return this.makeCallDirect(instance, operands, reportNode, true);\n } else if (constraints & Constraints.WILL_RETAIN) {\n // Skip autorelease and remember\n let expr = this.makeCallDirect(instance, operands, reportNode, false, true);\n this.skippedAutoreleases.add(expr);\n return expr;\n } else {\n return this.makeCallDirect(instance, operands, reportNode, false, false);\n }\n }\n return this.makeCallDirect(instance, operands, reportNode,\n (constraints & Constraints.WILL_DROP) != 0\n );\n }\n\n makeCallInline(\n instance: Function,\n operands: ExpressionRef[] | null,\n thisArg: ExpressionRef = 0,\n immediatelyDropped: bool = false\n ): ExpressionRef {\n var module = this.module;\n var numArguments = operands ? operands.length : 0;\n var signature = instance.signature;\n var parameterTypes = signature.parameterTypes;\n var numParameters = parameterTypes.length;\n\n // Create a new inline flow and use it to compile the function as a block\n var previousFlow = this.currentFlow;\n var flow = Flow.createInline(previousFlow.parentFunction, instance);\n var body = [];\n var usedLocals = new Set();\n\n // Prepare compiled arguments right to left, keeping track of used locals.\n for (let i = numArguments - 1; i >= 0; --i) {\n // This is necessary because a later expression must not set an earlier argument local, which\n // is also just a temporary, when being executed. Take for example `t1=1, t2=(t1 = 2)`, where\n // the right expression would reassign the foregoing argument local. So, we iterate from right\n // to left, remembering what's used later, and don't use these for earlier arguments, making\n // the example above essentially `t2=1, t1=(t1 = 2)`.\n let paramExpr = operands![i];\n let paramType = parameterTypes[i];\n let argumentLocal = flow.addScopedLocal(signature.getParameterName(i), paramType, usedLocals);\n findUsedLocals(paramExpr, usedLocals);\n // inlining is aware of wrap/nonnull states:\n if (!previousFlow.canOverflow(paramExpr, paramType)) flow.setLocalFlag(argumentLocal.index, LocalFlags.WRAPPED);\n if (flow.isNonnull(paramExpr, paramType)) flow.setLocalFlag(argumentLocal.index, LocalFlags.NONNULL);\n // inlining is aware of skipped autoreleases:\n if (paramType.isManaged) {\n if (!this.skippedAutoreleases.has(paramExpr)) paramExpr = this.makeRetain(paramExpr);\n flow.setLocalFlag(argumentLocal.index, LocalFlags.RETAINED);\n }\n body.unshift(\n module.local_set(argumentLocal.index, paramExpr)\n );\n }\n if (thisArg) {\n let classInstance = assert(instance.parent); assert(classInstance.kind == ElementKind.CLASS);\n let thisType = assert(instance.signature.thisType);\n let thisLocal = flow.addScopedLocal(CommonSymbols.this_, thisType, usedLocals);\n // No need to retain `this` as it can't be reassigned and thus can't become prematurely released\n body.unshift(\n module.local_set(thisLocal.index, thisArg)\n );\n let baseInstance = (classInstance).base;\n if (baseInstance) flow.addScopedAlias(CommonSymbols.super_, baseInstance.type, thisLocal.index);\n } else {\n assert(!instance.signature.thisType);\n }\n\n // Compile omitted arguments with final argument locals blocked. Doesn't need to take care of\n // side-effects within earlier expressions because these already happened on set.\n this.currentFlow = flow;\n for (let i = numArguments; i < numParameters; ++i) {\n let initType = parameterTypes[i];\n let initExpr = this.compileExpression(\n assert(instance.prototype.functionTypeNode.parameters[i].initializer),\n initType,\n Constraints.CONV_IMPLICIT\n );\n let argumentLocal = flow.addScopedLocal(signature.getParameterName(i), initType);\n if (!flow.canOverflow(initExpr, initType)) flow.setLocalFlag(argumentLocal.index, LocalFlags.WRAPPED);\n if (flow.isNonnull(initExpr, initType)) flow.setLocalFlag(argumentLocal.index, LocalFlags.NONNULL);\n if (initType.isManaged) {\n flow.setLocalFlag(argumentLocal.index, LocalFlags.RETAINED);\n body.push(\n module.local_set(argumentLocal.index,\n this.makeRetain(initExpr)\n )\n );\n } else {\n body.push(\n module.local_set(argumentLocal.index, initExpr)\n );\n }\n }\n\n // Compile the called function's body in the scope of the inlined flow\n this.compileFunctionBody(instance, body);\n\n // Free any new scoped locals and reset to the original flow\n if (!flow.is(FlowFlags.TERMINATES)) {\n this.performAutoreleases(flow, body);\n this.finishAutoreleases(flow, body);\n }\n flow.freeScopedLocals();\n var returnType = flow.returnType;\n this.currentFlow = previousFlow;\n\n // Create an outer block that we can break to when returning a value out of order\n var expr = module.block(flow.inlineReturnLabel, body, returnType.toNativeType());\n this.currentType = returnType;\n if (returnType.isManaged) {\n if (immediatelyDropped) {\n expr = this.makeRelease(expr);\n this.currentType = Type.void;\n }\n }\n return expr;\n }\n\n /** Gets the trampoline for the specified function. */\n ensureTrampoline(original: Function): Function {\n // A trampoline is a function that takes a fixed amount of operands with some of them possibly\n // being zeroed. It takes one additional argument denoting the number of actual operands\n // provided to the call, and takes appropriate steps to initialize zeroed operands to their\n // default values using the optional parameter initializers of the original function. Doing so\n // allows calls to functions with optional parameters to circumvent the trampoline when all\n // parameters are provided as a fast route, respectively setting up omitted operands in a proper\n // context otherwise.\n var trampoline = original.trampoline;\n if (trampoline) return trampoline;\n\n var originalSignature = original.signature;\n var originalName = original.internalName;\n var originalParameterTypes = originalSignature.parameterTypes;\n var originalParameterDeclarations = original.prototype.functionTypeNode.parameters;\n var returnType = originalSignature.returnType;\n var thisType = originalSignature.thisType;\n var isInstance = original.is(CommonFlags.INSTANCE);\n\n // arguments excl. `this`, operands incl. `this`\n var minArguments = originalSignature.requiredParameters;\n var minOperands = minArguments;\n var maxArguments = originalParameterTypes.length;\n var maxOperands = maxArguments;\n if (isInstance) {\n ++minOperands;\n ++maxOperands;\n }\n var numOptional = assert(maxOperands - minOperands);\n\n var forwardedOperands = new Array(minOperands);\n var operandIndex = 0;\n\n // forward `this` if applicable\n var module = this.module;\n if (isInstance) {\n forwardedOperands[0] = module.local_get(0, this.options.nativeSizeType);\n operandIndex = 1;\n }\n\n // forward required arguments\n for (let i = 0; i < minArguments; ++i, ++operandIndex) {\n forwardedOperands[operandIndex] = module.local_get(operandIndex, originalParameterTypes[i].toNativeType());\n }\n assert(operandIndex == minOperands);\n\n // create the trampoline element\n var trampolineSignature = new Signature(originalParameterTypes, returnType, thisType);\n trampolineSignature.requiredParameters = maxArguments;\n trampolineSignature.parameterNames = originalSignature.parameterNames;\n trampoline = new Function(\n original.name + \"|trampoline\",\n original.prototype,\n trampolineSignature,\n original.contextualTypeArguments\n );\n trampoline.set(original.flags | CommonFlags.TRAMPOLINE | CommonFlags.COMPILED);\n original.trampoline = trampoline;\n\n // compile initializers of omitted arguments in scope of the trampoline function\n // this is necessary because initializers might need additional locals and a proper this context\n var previousFlow = this.currentFlow;\n var flow = trampoline.flow;\n this.currentFlow = flow;\n\n // create a br_table switching over the number of optional parameters provided\n var numNames = numOptional + 1; // incl. outer block\n var names = new Array(numNames);\n var ofN = \"of\" + numOptional.toString(10);\n for (let i = 0; i < numNames; ++i) {\n let label = i.toString(10) + ofN;\n names[i] = label;\n }\n var body = module.block(names[0], [\n module.block(\"outOfRange\", [\n module.switch(names, \"outOfRange\",\n // condition is number of provided optional arguments, so subtract required arguments\n minArguments\n ? module.binary(\n BinaryOp.SubI32,\n module.global_get(BuiltinSymbols.argc, NativeType.I32),\n module.i32(minArguments)\n )\n : module.global_get(BuiltinSymbols.argc, NativeType.I32)\n )\n ]),\n module.unreachable()\n ]);\n for (let i = 0; i < numOptional; ++i, ++operandIndex) {\n let type = originalParameterTypes[minArguments + i];\n let declaration = originalParameterDeclarations[minArguments + i];\n let initializer = declaration.initializer;\n let initExpr: ExpressionRef;\n if (initializer) {\n initExpr = module.local_set(operandIndex,\n this.compileExpression(\n initializer,\n type,\n Constraints.CONV_IMPLICIT\n )\n );\n } else {\n this.error(\n DiagnosticCode.Optional_parameter_must_have_an_initializer,\n declaration.range\n );\n initExpr = module.unreachable();\n }\n body = module.block(names[i + 1], [\n body,\n initExpr,\n ]);\n forwardedOperands[operandIndex] = module.local_get(operandIndex, type.toNativeType());\n }\n assert(operandIndex == maxOperands);\n\n var stmts: ExpressionRef[] = [ body ];\n var theCall = module.call(originalName, forwardedOperands, returnType.toNativeType());\n if (returnType != Type.void) {\n this.performAutoreleasesWithValue(flow, theCall, returnType, stmts);\n } else {\n stmts.push(theCall);\n this.performAutoreleases(flow, stmts);\n }\n flow.freeScopedLocals();\n this.currentFlow = previousFlow;\n\n var funcRef = module.addFunction(\n trampoline.internalName,\n this.ensureFunctionType(\n trampolineSignature.parameterTypes,\n returnType,\n thisType\n ),\n typesToNativeTypes(trampoline.additionalLocals),\n module.block(null, stmts, returnType.toNativeType())\n );\n trampoline.finalize(module, funcRef);\n return trampoline;\n }\n\n /** Makes sure that the argument count helper global is present and returns its name. */\n private ensureArgcVar(): string {\n if (!this.argcVar) {\n let module = this.module;\n this.argcVar = module.addGlobal(\n BuiltinSymbols.argc,\n NativeType.I32,\n true,\n module.i32(0)\n );\n }\n return BuiltinSymbols.argc;\n }\n\n /** Makes sure that the argument count helper setter is present and returns its name. */\n private ensureArgcSet(): string {\n if (!this.argcSet) {\n let module = this.module;\n this.argcSet = module.addFunction(BuiltinSymbols.setargc,\n this.ensureFunctionType([ Type.u32 ], Type.void),\n null,\n module.global_set(this.ensureArgcVar(),\n module.local_get(0, NativeType.I32)\n )\n );\n module.addFunctionExport(BuiltinSymbols.setargc, \"__setargc\");\n }\n return BuiltinSymbols.setargc;\n }\n\n // \n\n /** Makes retain call, retaining the expression's value. */\n makeRetain(expr: ExpressionRef): ExpressionRef {\n var retainInstance = this.program.retainInstance;\n this.compileFunction(retainInstance);\n return this.module.call(retainInstance.internalName, [ expr ], this.options.nativeSizeType);\n }\n\n /** Makes a retainRelease call, retaining the new expression's value and releasing the old expression's value, in this order. */\n makeRetainRelease(oldExpr: ExpressionRef, newExpr: ExpressionRef): ExpressionRef {\n // if ((t1=newExpr) != (t2=oldExpr)) {\n // __retain(t1);\n // __release(t2);\n // }, t1\n var module = this.module;\n var flow = this.currentFlow;\n var usizeType = this.options.usizeType;\n var nativeSizeType = this.options.nativeSizeType;\n var temp1 = flow.getTempLocal(usizeType, findUsedLocals(oldExpr));\n var temp2 = flow.getAndFreeTempLocal(usizeType);\n flow.freeTempLocal(temp1);\n return module.block(null, [\n module.if(\n module.binary(nativeSizeType == NativeType.I64 ? BinaryOp.NeI64 : BinaryOp.NeI32,\n module.local_tee(temp1.index, newExpr),\n module.local_tee(temp2.index, oldExpr)\n ),\n module.block(null, [\n module.drop(\n this.makeRetain(module.local_get(temp1.index, nativeSizeType))\n ),\n this.makeRelease(module.local_get(temp2.index, nativeSizeType))\n ])\n ),\n module.local_get(temp1.index, nativeSizeType)\n ], nativeSizeType);\n }\n\n /** Makes a skippedRelease call, ignoring the new expression's value and releasing the old expression's value, in this order. */\n makeSkippedRelease(oldExpr: ExpressionRef, newExpr: ExpressionRef): ExpressionRef {\n // TODO: this helper can be eliminated altogether if the current logic holds\n // (t1=newExpr), __release(oldExpr), t1\n var module = this.module;\n var flow = this.currentFlow;\n var usizeType = this.options.usizeType;\n var nativeSizeType = this.options.nativeSizeType;\n var temp = flow.getAndFreeTempLocal(usizeType, findUsedLocals(oldExpr));\n return module.block(null, [\n module.local_set(temp.index, newExpr),\n this.makeRelease(oldExpr),\n module.local_get(temp.index, nativeSizeType)\n ], nativeSizeType);\n }\n\n /** Makes a release call, releasing the expression's value. Changes the current type to void.*/\n makeRelease(expr: ExpressionRef): ExpressionRef {\n var releaseInstance = this.program.releaseInstance;\n this.compileFunction(releaseInstance);\n return this.module.call(releaseInstance.internalName, [ expr ], NativeType.None);\n }\n\n /** Makes an automatic release call at the end of the current flow. */\n makeAutorelease(expr: ExpressionRef, flow: Flow = this.currentFlow): ExpressionRef {\n // FIXME: loses track of nonNull state?\n return this.module.local_tee(flow.getAutoreleaseLocal(this.options.usizeType).index, expr);\n }\n\n /** Attempts to undo a final autorelease, returning the index of the previously retaining variable or -1 if not possible. */\n undoAutorelease(expr: ExpressionRef, flow: Flow): i32 {\n // NOTE: Can't remove the local.tee completely because it's already compiled\n // and a child of something else. Preventing the final release however should\n // make it optimize away.\n switch (getExpressionId(expr)) {\n case ExpressionId.LocalSet: { // local.tee(__retain(expr))\n if (isLocalTee(expr)) {\n let index = getLocalSetIndex(expr);\n if (flow.isAnyLocalFlag(index, LocalFlags.ANY_RETAINED)) {\n // Assumes that the expression actually belongs to the flow and that\n // top-level autoreleases are never undone. While that's true, it's\n // not necessary to check presence in scopedLocals.\n flow.unsetLocalFlag(index, LocalFlags.ANY_RETAINED);\n return index;\n }\n }\n break;\n }\n case ExpressionId.Block: { // { ..., local.tee(__retain(expr)) }\n if (getBlockName(expr) === null) { // must not be a break target\n let count = getBlockChildCount(expr);\n if (count) {\n return this.undoAutorelease(getBlockChild(expr, count - 1), flow);\n }\n }\n break;\n }\n }\n return -1;\n }\n\n /**\n * Attemps to move a final autorelease from one flow to a parent.\n * It is crucial that from flow hasn't processed autoreleases yet because otherwise the final\n * retain would have been written already.\n */\n moveAutorelease(expr: ExpressionRef, fromInnerFlow: Flow, toOuterFlow: Flow): ExpressionRef {\n // NOTE: While this avoids an unnecessary set of retain and release, it cannot\n // eliminate the now unnecessary temporary local.tee because it is already part of\n // another expression in the tree. But optimizing should collapse locals again.\n var index = this.undoAutorelease(expr, fromInnerFlow);\n return ~index\n ? this.makeAutorelease(expr, toOuterFlow) // undone, can skip the retain\n : this.makeAutorelease(this.makeRetain(expr), toOuterFlow);\n }\n\n /** Performs any queued autoreleases in the specified flow. */\n performAutoreleases(flow: Flow, stmts: ExpressionRef[], clearFlags: bool = true): void {\n var scopedLocals = flow.scopedLocals;\n if (scopedLocals) {\n let module = this.module;\n for (let local of scopedLocals.values()) {\n if (local.is(CommonFlags.SCOPED)) { // otherwise an alias\n let localIndex = local.index;\n if (flow.isAnyLocalFlag(localIndex, LocalFlags.ANY_RETAINED)) {\n if (clearFlags) flow.unsetLocalFlag(localIndex, LocalFlags.ANY_RETAINED);\n stmts.push(\n this.makeRelease(\n module.local_get(localIndex, local.type.toNativeType())\n )\n );\n }\n }\n }\n }\n }\n\n /** Performs any queued autoreleases in the specified flow and returns the value. */\n performAutoreleasesWithValue(\n flow: Flow,\n valueExpr: ExpressionRef,\n valueType: Type,\n stmts: ExpressionRef[] | null = null,\n clearFlags: bool = true\n ): ExpressionRef {\n if (!stmts) stmts = new Array();\n stmts.push(\n this.module.nop()\n );\n var lengthBefore = stmts.length;\n this.performAutoreleases(flow, stmts, clearFlags);\n if (stmts.length > lengthBefore) {\n let nativeType = valueType.toNativeType();\n let temp = flow.getAndFreeTempLocal(valueType);\n if (!flow.canOverflow(valueExpr, valueType)) flow.setLocalFlag(temp.index, LocalFlags.WRAPPED);\n if (flow.isNonnull(valueExpr, valueType)) flow.setLocalFlag(temp.index, LocalFlags.NONNULL);\n let module = this.module;\n stmts[lengthBefore - 1] = module.local_set(temp.index, valueExpr); // nop -> set\n stmts.push(\n module.local_get(temp.index, nativeType) // append get\n );\n return module.block(null, stmts, nativeType);\n } else if (stmts.length > 1) {\n stmts[lengthBefore - 1] = valueExpr; // nop -> value\n return this.module.block(null, stmts, valueType.toNativeType());\n }\n return valueExpr;\n }\n\n /** Finishes any queued top-level autoreleases in the actual function of the specified flow. */\n finishAutoreleases(flow: Flow, stmts: ExpressionRef[]): void {\n var module = this.module;\n if (flow.is(FlowFlags.INLINE_CONTEXT)) {\n // traverse to the top-most flow containing the inlined function's\n // locals as scoped locals and release these instead.\n let parent: Flow | null;\n while (parent = flow.parent) flow = parent;\n this.performAutoreleases(flow, stmts, false);\n } else {\n for (let local of flow.parentFunction.localsByIndex) {\n let localIndex = local.index;\n if (flow.isAnyLocalFlag(localIndex, LocalFlags.ANY_RETAINED)) {\n flow.unsetLocalFlag(localIndex, LocalFlags.ANY_RETAINED);\n stmts.push(\n this.makeRelease(\n module.local_get(localIndex, local.type.toNativeType())\n )\n );\n }\n }\n }\n }\n\n // \n\n /** Creates a direct call to the specified function. */\n makeCallDirect(\n instance: Function,\n operands: ExpressionRef[] | null,\n reportNode: Node,\n immediatelyDropped: bool = false,\n /** Skip the usual autorelease and manage this at the callsite instead. */\n skipAutorelease: bool = false\n ): ExpressionRef {\n if (instance.hasDecorator(DecoratorFlags.INLINE)) {\n this.warning(\n DiagnosticCode.TODO_Cannot_inline_inferred_calls_and_specific_internals_yet,\n reportNode.range, instance.internalName\n );\n }\n var numOperands = operands ? operands.length : 0;\n var numArguments = numOperands;\n var minArguments = instance.signature.requiredParameters;\n var minOperands = minArguments;\n var maxArguments = instance.signature.parameterTypes.length;\n var maxOperands = maxArguments;\n if (instance.is(CommonFlags.INSTANCE)) {\n ++minOperands;\n ++maxOperands;\n --numArguments;\n }\n assert(numOperands >= minOperands);\n\n var module = this.module;\n if (!this.compileFunction(instance)) return module.unreachable();\n var returnType = instance.signature.returnType;\n var isCallImport = instance.is(CommonFlags.MODULE_IMPORT);\n\n // fill up omitted arguments with their initializers, if constant, otherwise with zeroes.\n if (numOperands < maxOperands) {\n if (!operands) {\n operands = new Array(maxOperands);\n operands.length = 0;\n }\n let parameterTypes = instance.signature.parameterTypes;\n let parameterNodes = instance.prototype.functionTypeNode.parameters;\n assert(parameterNodes.length == parameterTypes.length);\n let allOptionalsAreConstant = true;\n for (let i = numArguments; i < maxArguments; ++i) {\n let initializer = parameterNodes[i].initializer;\n if (initializer) {\n if (nodeIsConstantValue(initializer.kind)) {\n operands.push(this.compileExpression(\n parameterNodes[i].initializer,\n parameterTypes[i],\n Constraints.CONV_IMPLICIT\n ));\n continue;\n }\n let resolved = this.resolver.resolveExpression(initializer, instance.flow, parameterTypes[i]);\n if (resolved) {\n if (resolved.kind == ElementKind.GLOBAL) {\n let global = resolved;\n if (this.compileGlobal(global)) {\n if (global.is(CommonFlags.INLINED)) {\n operands.push(\n this.compileInlineConstant(global, parameterTypes[i], Constraints.CONV_IMPLICIT)\n );\n } else {\n operands.push(\n this.convertExpression(\n module.global_get(global.internalName, global.type.toNativeType()),\n global.type, parameterTypes[i], false, false, initializer\n )\n );\n }\n continue;\n }\n }\n }\n }\n operands.push(parameterTypes[i].toNativeZero(module));\n allOptionalsAreConstant = false;\n }\n if (!allOptionalsAreConstant) {\n if (!isCallImport) {\n let original = instance;\n instance = this.ensureTrampoline(instance);\n if (!this.compileFunction(instance)) return module.unreachable();\n instance.flow.flags = original.flow.flags;\n let nativeReturnType = returnType.toNativeType();\n let expr = module.call(instance.internalName, operands, nativeReturnType);\n this.currentType = returnType;\n if (returnType.isManaged) {\n if (immediatelyDropped) {\n expr = this.makeRelease(expr);\n this.currentType = Type.void;\n } else if (!skipAutorelease) {\n expr = this.makeAutorelease(expr);\n } else {\n this.skippedAutoreleases.add(expr);\n }\n }\n return module.block(null, [\n module.global_set(this.ensureArgcVar(), module.i32(numArguments)),\n expr\n ], this.currentType.toNativeType());\n }\n }\n }\n\n // If the return value is of a reference type it has not yet been released but is in flight\n // which is equivalent to a skipped autorelease. Hence, insert either a release if it is\n // dropped anyway, preserve the skipped autorelease if explicitly requested or autorelease now.\n var expr = module.call(instance.internalName, operands, returnType.toNativeType());\n this.currentType = returnType;\n if (returnType.isManaged) {\n if (immediatelyDropped) {\n expr = this.makeRelease(expr);\n this.currentType = Type.void;\n } else if (!skipAutorelease) {\n expr = this.makeAutorelease(expr);\n }\n }\n return expr;\n }\n\n /** Compiles an indirect call using an index argument and a signature. */\n compileCallIndirect(\n signature: Signature,\n indexArg: ExpressionRef,\n argumentExpressions: Expression[],\n reportNode: Node,\n thisArg: ExpressionRef = 0,\n immediatelyDropped: bool = false\n ): ExpressionRef {\n var numArguments = argumentExpressions.length;\n\n if (!this.checkCallSignature( // reports\n signature,\n numArguments,\n thisArg != 0,\n reportNode\n )) {\n return this.module.unreachable();\n }\n\n var numArgumentsInclThis = thisArg ? numArguments + 1 : numArguments;\n var operands = new Array(numArgumentsInclThis);\n var index = 0;\n if (thisArg) {\n operands[0] = thisArg;\n index = 1;\n }\n var parameterTypes = signature.parameterTypes;\n for (let i = 0; i < numArguments; ++i, ++index) {\n operands[index] = this.compileExpression(argumentExpressions[i], parameterTypes[i],\n Constraints.CONV_IMPLICIT\n );\n }\n assert(index == numArgumentsInclThis);\n return this.makeCallIndirect(signature, indexArg, operands, immediatelyDropped);\n }\n\n /** Creates an indirect call to the function at `indexArg` in the function table. */\n makeCallIndirect(\n signature: Signature,\n indexArg: ExpressionRef,\n operands: ExpressionRef[] | null = null,\n immediatelyDropped: bool = false\n ): ExpressionRef {\n var numOperands = operands ? operands.length : 0;\n var numArguments = numOperands;\n var minArguments = signature.requiredParameters;\n var minOperands = minArguments;\n var maxArguments = signature.parameterTypes.length;\n var maxOperands = maxArguments;\n if (signature.thisType) {\n ++minOperands;\n ++maxOperands;\n --numArguments;\n }\n assert(numOperands >= minOperands);\n\n this.ensureFunctionType(signature.parameterTypes, signature.returnType, signature.thisType);\n var module = this.module;\n\n // fill up omitted arguments with zeroes\n if (numOperands < maxOperands) {\n if (!operands) {\n operands = new Array(maxOperands);\n operands.length = 0;\n }\n let parameterTypes = signature.parameterTypes;\n for (let i = numArguments; i < maxArguments; ++i) {\n operands.push(parameterTypes[i].toNativeZero(module));\n }\n }\n\n var returnType = signature.returnType;\n var expr = module.call_indirect(indexArg, operands, signature.toSignatureString());\n this.currentType = returnType;\n if (returnType.isManaged) {\n if (immediatelyDropped) {\n expr = this.makeRelease(expr);\n this.currentType = Type.void;\n } else {\n expr = this.makeAutorelease(expr);\n }\n }\n return module.block(null, [\n module.global_set(this.ensureArgcVar(), // might be calling a trampoline\n module.i32(numArguments)\n ),\n expr\n ], this.currentType.toNativeType()); // not necessarily wrapped\n }\n\n compileCommaExpression(\n expression: CommaExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var expressions = expression.expressions;\n var numExpressions = expressions.length;\n var exprs = new Array(numExpressions--);\n for (let i = 0; i < numExpressions; ++i) {\n exprs[i] = this.compileExpression(expressions[i], Type.void, // drop all except last\n Constraints.CONV_IMPLICIT | Constraints.WILL_DROP\n );\n }\n exprs[numExpressions] = this.compileExpression(expressions[numExpressions], contextualType, constraints);\n return this.module.block(null, exprs, this.currentType.toNativeType());\n }\n\n compileElementAccessExpression(\n expression: ElementAccessExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var target = this.resolver.resolveElementAccessExpression(\n expression,\n this.currentFlow,\n contextualType\n ); // reports\n if (!target) return this.module.unreachable();\n switch (target.kind) {\n case ElementKind.CLASS: {\n let indexedGet = (target).lookupOverload(OperatorKind.INDEXED_GET, this.currentFlow.is(FlowFlags.UNCHECKED_CONTEXT));\n if (!indexedGet) {\n this.error(\n DiagnosticCode.Index_signature_is_missing_in_type_0,\n expression.expression.range, (target).internalName\n );\n return this.module.unreachable();\n }\n let thisArg = this.compileExpression(expression.expression, (target).type,\n Constraints.CONV_IMPLICIT\n );\n return this.compileCallDirect(indexedGet, [\n expression.elementExpression\n ], expression, thisArg, constraints);\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n compileFunctionExpression(\n expression: FunctionExpression,\n contextualSignature: Signature | null,\n constraints: Constraints\n ): ExpressionRef {\n var declaration = expression.declaration.clone(); // generic contexts can have multiple\n assert(!declaration.typeParameters); // function expression cannot be generic\n var flow = this.currentFlow;\n var actualFunction = flow.actualFunction;\n var prototype = new FunctionPrototype(\n declaration.name.text.length\n ? declaration.name.text\n : \"anonymous|\" + (actualFunction.nextAnonymousId++).toString(10),\n actualFunction,\n declaration,\n DecoratorFlags.NONE\n );\n var instance: Function | null;\n var contextualTypeArguments = makeMap(flow.contextualTypeArguments);\n\n // compile according to context. this differs from a normal function in that omitted parameter\n // and return types can be inferred and omitted arguments can be replaced with dummies.\n if (contextualSignature) {\n let signatureNode = prototype.functionTypeNode;\n let parameterNodes = signatureNode.parameters;\n let numPresentParameters = parameterNodes.length;\n\n // must not require more than the maximum number of parameters\n let parameterTypes = contextualSignature.parameterTypes;\n let numParameters = parameterTypes.length;\n if (numPresentParameters > numParameters) {\n this.error(\n DiagnosticCode.Expected_0_arguments_but_got_1,\n expression.range, numParameters.toString(), numPresentParameters.toString()\n );\n return this.module.unreachable();\n }\n\n // check non-omitted parameter types\n let parameterNames = new Array(numPresentParameters);\n for (let i = 0; i < numPresentParameters; ++i) {\n let parameterNode = parameterNodes[i];\n parameterNames[i] = parameterNode.name.text; // use actual name\n if (!isTypeOmitted(parameterNode.type)) {\n let resolvedType = this.resolver.resolveType(\n parameterNode.type,\n actualFunction.parent,\n contextualTypeArguments\n );\n if (!resolvedType) return this.module.unreachable();\n if (!parameterTypes[i].isStrictlyAssignableTo(resolvedType)) {\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n parameterNode.range, parameterTypes[i].toString(), resolvedType.toString()\n );\n return this.module.unreachable();\n }\n }\n // any unused parameters are inherited but ignored\n }\n\n // check non-omitted return type\n let returnType = contextualSignature.returnType;\n if (!isTypeOmitted(signatureNode.returnType)) {\n let resolvedType = this.resolver.resolveType(\n signatureNode.returnType,\n actualFunction.parent,\n contextualTypeArguments\n );\n if (!resolvedType) return this.module.unreachable();\n if (\n returnType == Type.void\n ? resolvedType != Type.void\n : !resolvedType.isStrictlyAssignableTo(returnType)\n ) {\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n signatureNode.returnType.range, resolvedType.toString(), returnType.toString()\n );\n return this.module.unreachable();\n }\n }\n\n // check explicit this type\n let thisType = contextualSignature.thisType;\n let thisTypeNode = signatureNode.explicitThisType;\n if (thisTypeNode) {\n if (!thisType) {\n this.error(\n DiagnosticCode._this_cannot_be_referenced_in_current_location,\n thisTypeNode.range\n );\n return this.module.unreachable();\n }\n let resolvedType = this.resolver.resolveType(\n thisTypeNode,\n actualFunction.parent,\n contextualTypeArguments\n );\n if (!resolvedType) return this.module.unreachable();\n if (!thisType.isStrictlyAssignableTo(resolvedType)) {\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n thisTypeNode.range, thisType.toString(), resolvedType.toString()\n );\n return this.module.unreachable();\n }\n }\n\n let signature = new Signature(parameterTypes, returnType, thisType);\n signature.requiredParameters = numParameters; // !\n signature.parameterNames = parameterNames;\n instance = new Function(\n prototype.name,\n prototype,\n signature,\n contextualTypeArguments\n );\n if (!this.compileFunction(instance)) return this.module.unreachable();\n this.currentType = contextualSignature.type;\n\n // otherwise compile like a normal function\n } else {\n instance = this.compileFunctionUsingTypeArguments(\n prototype,\n [],\n contextualTypeArguments\n );\n if (!instance) return this.module.unreachable();\n this.currentType = instance.signature.type;\n }\n\n var index = this.ensureFunctionTableEntry(instance); // reports\n return index < 0\n ? this.module.unreachable()\n : this.module.i32(index);\n }\n\n /** Makes sure the enclosing source file of the specified expression has been compiled. */\n private maybeCompileEnclosingSource(expression: Expression): void {\n var internalPath = expression.range.source.internalPath;\n var filesByName = this.program.filesByName;\n assert(filesByName.has(internalPath));\n var enclosingFile = filesByName.get(internalPath)!;\n if (!enclosingFile.is(CommonFlags.COMPILED)) {\n this.compileFileByPath(internalPath, expression);\n }\n }\n\n /**\n * Compiles an identifier in the specified context.\n * @param retainConstantType Retains the type of inlined constants if `true`, otherwise\n * precomputes them according to context.\n */\n compileIdentifierExpression(\n expression: IdentifierExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var module = this.module;\n var flow = this.currentFlow;\n var actualFunction = flow.actualFunction;\n\n // check special keywords first\n switch (expression.kind) {\n case NodeKind.NULL: {\n let options = this.options;\n if (!contextualType.classReference) {\n this.currentType = options.usizeType;\n }\n return options.isWasm64\n ? module.i64(0)\n : module.i32(0);\n }\n case NodeKind.TRUE: {\n this.currentType = Type.bool;\n return module.i32(1);\n }\n case NodeKind.FALSE: {\n this.currentType = Type.bool;\n return module.i32(0);\n }\n case NodeKind.THIS: {\n if (actualFunction.is(CommonFlags.INSTANCE)) {\n let thisLocal = assert(flow.lookupLocal(CommonSymbols.this_));\n let classInstance = assert(actualFunction.parent); assert(classInstance.kind == ElementKind.CLASS);\n let nativeSizeType = this.options.nativeSizeType;\n if (actualFunction.is(CommonFlags.CONSTRUCTOR)) {\n if (!flow.is(FlowFlags.ALLOCATES)) {\n flow.set(FlowFlags.ALLOCATES);\n // {\n // if (!this) this = \n // this.a = X\n // this.b = Y\n // return this\n // }\n let stmts: ExpressionRef[] = [\n module.if(\n module.unary(nativeSizeType == NativeType.I64 ? UnaryOp.EqzI64 : UnaryOp.EqzI32,\n module.local_get(thisLocal.index, nativeSizeType)\n ),\n module.local_set(thisLocal.index,\n this.makeRetain(\n this.makeAllocation(classInstance)\n )\n )\n )\n ];\n this.makeFieldInitialization(classInstance, stmts);\n stmts.push(\n module.local_get(thisLocal.index, nativeSizeType)\n );\n this.currentType = thisLocal.type;\n return module.block(null, stmts, nativeSizeType);\n }\n }\n // if not a constructor, `this` type can differ\n let thisType = assert(actualFunction.signature.thisType);\n this.currentType = thisType;\n return module.local_get(thisLocal.index, thisType.toNativeType());\n }\n this.error(\n DiagnosticCode._this_cannot_be_referenced_in_current_location,\n expression.range\n );\n this.currentType = this.options.usizeType;\n return module.unreachable();\n }\n case NodeKind.SUPER: {\n let flow = this.currentFlow;\n let actualFunction = flow.actualFunction;\n if (actualFunction.is(CommonFlags.CONSTRUCTOR)) {\n if (!flow.is(FlowFlags.CALLS_SUPER)) {\n // TS1034 in the parser effectively limits this to property accesses\n this.error(\n DiagnosticCode._super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class,\n expression.range\n );\n }\n }\n if (flow.is(FlowFlags.INLINE_CONTEXT)) {\n let scopedThis = flow.lookupLocal(CommonSymbols.this_);\n if (scopedThis) {\n let scopedThisClass = assert(scopedThis.type.classReference);\n let base = scopedThisClass.base;\n if (base) {\n this.currentType = base.type;\n return module.local_get(scopedThis.index, base.type.toNativeType());\n }\n }\n }\n if (actualFunction.is(CommonFlags.INSTANCE)) {\n let classInstance = assert(actualFunction.parent); assert(classInstance.kind == ElementKind.CLASS);\n let baseClassInstance = (classInstance).base;\n if (baseClassInstance) {\n let superType = baseClassInstance.type;\n this.currentType = superType;\n return module.local_get(0, superType.toNativeType());\n }\n }\n this.error(\n DiagnosticCode._super_can_only_be_referenced_in_a_derived_class,\n expression.range\n );\n this.currentType = this.options.usizeType;\n return module.unreachable();\n }\n }\n\n this.maybeCompileEnclosingSource(expression);\n\n // otherwise resolve\n var target = this.resolver.resolveIdentifier( // reports\n expression,\n flow,\n this.currentEnum || actualFunction\n );\n if (!target) return module.unreachable();\n\n switch (target.kind) {\n case ElementKind.LOCAL: {\n let type = (target).type;\n assert(type != Type.void);\n if ((target).is(CommonFlags.INLINED)) {\n return this.compileInlineConstant(target, contextualType, constraints);\n }\n let localIndex = (target).index;\n assert(localIndex >= 0);\n if (type.is(TypeFlags.NULLABLE) && flow.isLocalFlag(localIndex, LocalFlags.NONNULL, false)) {\n type = type.nonNullableType;\n }\n this.currentType = type;\n return this.module.local_get(localIndex, type.toNativeType());\n }\n case ElementKind.GLOBAL: {\n if (!this.compileGlobal(target)) { // reports; not yet compiled if a static field\n return this.module.unreachable();\n }\n let type = (target).type;\n assert(type != Type.void);\n if ((target).is(CommonFlags.INLINED)) {\n return this.compileInlineConstant(target, contextualType, constraints);\n }\n this.currentType = type;\n return this.module.global_get((target).internalName, type.toNativeType());\n }\n case ElementKind.ENUMVALUE: { // here: if referenced from within the same enum\n if (!target.is(CommonFlags.COMPILED)) {\n this.error(\n DiagnosticCode.A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums,\n expression.range\n );\n this.currentType = Type.i32;\n return this.module.unreachable();\n }\n this.currentType = Type.i32;\n if ((target).is(CommonFlags.INLINED)) {\n assert((target).constantValueKind == ConstantValueKind.INTEGER);\n return this.module.i32(i64_low((target).constantIntegerValue));\n }\n return this.module.global_get((target).internalName, NativeType.I32);\n }\n case ElementKind.FUNCTION_PROTOTYPE: {\n let instance = this.resolver.resolveFunction(\n target,\n null,\n makeMap(flow.contextualTypeArguments)\n );\n if (!(instance && this.compileFunction(instance))) return module.unreachable();\n let index = this.ensureFunctionTableEntry(instance);\n this.currentType = instance.signature.type;\n return this.module.i32(index);\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return this.module.unreachable();\n }\n\n compileInstanceOfExpression(\n expression: InstanceOfExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var module = this.module;\n // NOTE that this differs from TypeScript in that the rhs is a type, not an expression. at the\n // time of implementation, this seemed more useful because dynamic rhs expressions are not\n // possible in AS anyway. also note that the code generated below must preserve side-effects of\n // the LHS expression even when the result is a constant, i.e. return a block dropping `expr`.\n var expr = this.compileExpression(expression.expression, this.options.usizeType);\n var actualType = this.currentType;\n var expectedType = this.resolver.resolveType(expression.isType, this.currentFlow.actualFunction);\n this.currentType = Type.bool;\n if (!expectedType) return module.unreachable();\n\n // instanceof - must be exact\n if (!expectedType.is(TypeFlags.REFERENCE)) {\n return module.block(null, [\n module.drop(expr),\n module.i32(actualType == expectedType ? 1 : 0)\n ], NativeType.I32);\n }\n\n // instanceof - always false\n if (!actualType.is(TypeFlags.REFERENCE)) {\n return module.block(null, [\n module.drop(expr),\n module.i32(0)\n ], NativeType.I32);\n }\n\n // both LHS and RHS are references now\n var nativeSizeType = actualType.toNativeType();\n\n // instanceof - LHS must be != 0\n if (actualType.is(TypeFlags.NULLABLE) && !expectedType.is(TypeFlags.NULLABLE)) {\n\n // downcast - check statically\n if (actualType.nonNullableType.isAssignableTo(expectedType)) {\n return module.binary(\n nativeSizeType == NativeType.I64\n ? BinaryOp.NeI64\n : BinaryOp.NeI32,\n expr,\n actualType.toNativeZero(module)\n );\n }\n\n // upcast - check dynamically\n if (expectedType.isAssignableTo(actualType)) {\n let program = this.program;\n if (!(actualType.isUnmanaged || expectedType.isUnmanaged)) {\n let flow = this.currentFlow;\n let tempLocal = flow.getAndFreeTempLocal(actualType);\n let instanceofInstance = assert(program.instanceofInstance);\n this.compileFunction(instanceofInstance);\n return module.if(\n module.unary(\n nativeSizeType == NativeType.I64\n ? UnaryOp.EqzI64\n : UnaryOp.EqzI32,\n module.local_tee(tempLocal.index, expr),\n ),\n module.i32(0),\n this.makeCallDirect(instanceofInstance, [\n module.local_get(tempLocal.index, nativeSizeType),\n module.i32(expectedType.classReference!.id)\n ], expression)\n );\n } else {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n }\n }\n\n // either none or both nullable\n } else {\n\n // downcast - check statically\n if (actualType.isAssignableTo(expectedType)) {\n return module.block(null, [\n this.convertExpression(expr, actualType, Type.void, false, false, expression.expression),\n module.i32(1)\n ], NativeType.I32);\n\n // upcast - check dynamically\n } else if (expectedType.isAssignableTo(actualType)) {\n let program = this.program;\n if (!(actualType.isUnmanaged || expectedType.isUnmanaged)) {\n // FIXME: the temp local and the if can be removed here once flows\n // perform null checking, which would error earlier when checking\n // uninitialized (thus zero) `var a: A` to be an instance of something.\n let flow = this.currentFlow;\n let tempLocal = flow.getAndFreeTempLocal(actualType);\n let instanceofInstance = assert(program.instanceofInstance);\n this.compileFunction(instanceofInstance);\n return module.if(\n module.unary(\n nativeSizeType == NativeType.I64\n ? UnaryOp.EqzI64\n : UnaryOp.EqzI32,\n module.local_tee(tempLocal.index, expr),\n ),\n module.i32(0),\n this.makeCallDirect(instanceofInstance, [\n module.local_get(tempLocal.index, nativeSizeType),\n module.i32(expectedType.classReference!.id)\n ], expression)\n );\n } else {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n }\n }\n }\n\n // false\n return module.block(null, [\n module.drop(expr),\n module.i32(0)\n ], NativeType.I32);\n }\n\n compileLiteralExpression(\n expression: LiteralExpression,\n contextualType: Type,\n constraints: Constraints,\n implicitlyNegate: bool = false\n ): ExpressionRef {\n var module = this.module;\n switch (expression.literalKind) {\n case LiteralKind.ARRAY: {\n assert(!implicitlyNegate);\n let classType = contextualType.classReference;\n if (classType) {\n if (classType.prototype == this.program.arrayPrototype) {\n return this.compileArrayLiteral(\n assert(classType.typeArguments)[0],\n (expression).elementExpressions,\n constraints,\n expression\n );\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return module.unreachable();\n }\n case LiteralKind.FLOAT: {\n let floatValue = (expression).value;\n if (implicitlyNegate) {\n floatValue = -floatValue;\n }\n if (contextualType == Type.f32) {\n return module.f32(floatValue);\n }\n this.currentType = Type.f64;\n return module.f64(floatValue);\n }\n case LiteralKind.INTEGER: {\n let intValue = (expression).value;\n if (implicitlyNegate) {\n intValue = i64_sub(\n i64_new(0),\n intValue\n );\n }\n let type = this.resolver.determineIntegerLiteralType(intValue, contextualType);\n this.currentType = type;\n switch (type.kind) {\n case TypeKind.ISIZE: if (!this.options.isWasm64) return module.i32(i64_low(intValue));\n case TypeKind.I64: return module.i64(i64_low(intValue), i64_high(intValue));\n case TypeKind.USIZE: if (!this.options.isWasm64) return module.i32(i64_low(intValue));\n case TypeKind.U64: return module.i64(i64_low(intValue), i64_high(intValue));\n case TypeKind.F32: return module.f32(i64_to_f32(intValue));\n case TypeKind.F64: return module.f64(i64_to_f64(intValue));\n default: return module.i32(i64_low(intValue));\n }\n }\n case LiteralKind.STRING: {\n assert(!implicitlyNegate);\n return this.compileStringLiteral(expression);\n }\n case LiteralKind.OBJECT: {\n assert(!implicitlyNegate);\n return this.compileObjectLiteral(expression, contextualType);\n }\n // case LiteralKind.REGEXP:\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n this.currentType = contextualType;\n return module.unreachable();\n }\n\n compileStringLiteral(expression: StringLiteralExpression): ExpressionRef {\n return this.ensureStaticString(expression.value);\n }\n\n compileArrayLiteral(\n elementType: Type,\n expressions: (Expression | null)[],\n constraints: Constraints,\n reportNode: Node\n ): ExpressionRef {\n var module = this.module;\n var program = this.program;\n var arrayPrototype = assert(program.arrayPrototype);\n var arrayInstance = assert(this.resolver.resolveClass(arrayPrototype, [ elementType ]));\n var arrayBufferInstance = assert(program.arrayBufferInstance);\n var arrayType = arrayInstance.type;\n var flow = this.currentFlow;\n\n // block those here so compiling expressions doesn't conflict\n var tempThis = flow.getTempLocal(arrayType);\n var tempDataStart = flow.getTempLocal(arrayBufferInstance.type);\n\n // compile value expressions and find out whether all are constant\n var length = expressions.length;\n var values = new Array(length);\n var isStatic = true;\n var nativeElementType = elementType.toNativeType();\n for (let i = 0; i < length; ++i) {\n let expression = expressions[i];\n let expr = expression\n ? module.precomputeExpression(\n this.compileExpression(expression, elementType,\n Constraints.CONV_IMPLICIT\n )\n )\n : elementType.toNativeZero(module);\n if (getExpressionId(expr) == ExpressionId.Const) {\n assert(getExpressionType(expr) == nativeElementType);\n } else {\n isStatic = false;\n }\n values[i] = expr;\n }\n\n // if the array is static, make a static arraybuffer segment\n if (isStatic) {\n flow.freeTempLocal(tempThis);\n flow.freeTempLocal(tempDataStart);\n\n let runtimeHeaderSize = program.runtimeHeaderSize;\n let bufferSegment = this.ensureStaticArrayBuffer(elementType, values);\n let bufferAddress = i64_add(bufferSegment.offset, i64_new(runtimeHeaderSize));\n\n // make both the buffer and array header static if assigned to a global. this can't be done\n // if inside of a function because each invocation must create a new array reference then.\n if (constraints & Constraints.PREFER_STATIC) {\n let arraySegment = this.ensureStaticArrayHeader(elementType, bufferSegment);\n let arrayAddress = i64_add(arraySegment.offset, i64_new(runtimeHeaderSize));\n this.currentType = arrayType;\n return program.options.isWasm64\n ? this.module.i64(i64_low(arrayAddress), i64_high(arrayAddress))\n : this.module.i32(i64_low(arrayAddress));\n\n // otherwise allocate a new array header and make it wrap a copy of the static buffer\n } else {\n // makeArray(length, alignLog2, classId, staticBuffer)\n let expr = this.makeCallDirect(program.allocArrayInstance, [\n module.i32(length),\n program.options.isWasm64\n ? module.i64(elementType.alignLog2)\n : module.i32(elementType.alignLog2),\n module.i32(arrayInstance.id),\n program.options.isWasm64\n ? module.i64(i64_low(bufferAddress), i64_high(bufferAddress))\n : module.i32(i64_low(bufferAddress))\n ], reportNode);\n this.currentType = arrayType;\n return this.makeAutorelease(this.makeRetain(expr));\n }\n }\n\n // otherwise compile an explicit instantiation with indexed sets\n var setter = arrayInstance.lookupOverload(OperatorKind.INDEXED_SET, true);\n if (!setter) {\n flow.freeTempLocal(tempThis);\n flow.freeTempLocal(tempDataStart);\n this.error(\n DiagnosticCode.Index_signature_in_type_0_only_permits_reading,\n reportNode.range, arrayInstance.internalName\n );\n this.currentType = arrayType;\n return module.unreachable();\n }\n var nativeArrayType = arrayType.toNativeType();\n\n var stmts = new Array();\n // tempThis = makeArray(length, alignLog2, classId, source = 0)\n stmts.push(\n module.local_set(tempThis.index,\n this.makeCallDirect(program.allocArrayInstance, [\n module.i32(length),\n program.options.isWasm64\n ? module.i64(elementType.alignLog2)\n : module.i32(elementType.alignLog2),\n module.i32(arrayInstance.id),\n program.options.isWasm64\n ? module.i64(0)\n : module.i32(0)\n ], reportNode),\n )\n );\n // tempData = tempThis.dataStart\n var dataStart = assert(arrayInstance.lookupInSelf(\"dataStart\"));\n assert(dataStart.kind == ElementKind.FIELD);\n stmts.push(\n module.local_set(tempDataStart.index,\n module.load(arrayType.byteSize, false,\n module.local_get(tempThis.index, nativeArrayType),\n nativeArrayType,\n (dataStart).memoryOffset\n )\n )\n );\n var isManaged = elementType.isManaged;\n for (let i = 0, alignLog2 = elementType.alignLog2; i < length; ++i) {\n let valueExpr = values[i];\n if (isManaged) {\n // value = __retain(value)\n valueExpr = this.makeRetain(valueExpr);\n }\n // store(tempData, value, immOffset)\n stmts.push(\n module.store(elementType.byteSize,\n module.local_get(tempDataStart.index, nativeArrayType),\n valueExpr,\n nativeElementType,\n i << alignLog2\n )\n );\n }\n // -> tempThis\n stmts.push(\n module.local_get(tempThis.index, nativeArrayType)\n );\n flow.freeTempLocal(tempThis);\n flow.freeTempLocal(tempDataStart);\n this.currentType = arrayType;\n return module.block(null, stmts, nativeArrayType);\n }\n\n compileObjectLiteral(expression: ObjectLiteralExpression, contextualType: Type): ExpressionRef {\n var module = this.module;\n\n // contextual type must be a class\n var classReference = contextualType.classReference;\n if (!classReference || classReference.is(CommonFlags.ABSTRACT)) {\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n expression.range, \"\", contextualType.toString()\n );\n return module.unreachable();\n }\n\n // if present, check that the constructor is compatible with object literals\n var ctor = classReference.constructorInstance;\n if (ctor) {\n // TODO: if the constructor requires parameters, check whether these are given as part of the\n // object literal and use them to call the ctor while not generating a store.\n if (ctor.signature.requiredParameters) {\n this.error(\n DiagnosticCode.Constructor_of_class_0_must_not_require_any_arguments,\n expression.range, classReference.toString()\n );\n return module.unreachable();\n }\n if (ctor.is(CommonFlags.PRIVATE)) {\n this.error(\n DiagnosticCode.Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration,\n expression.range, classReference.toString()\n );\n return module.unreachable();\n }\n if (ctor.is(CommonFlags.PROTECTED)) {\n this.error(\n DiagnosticCode.Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration,\n expression.range, classReference.toString()\n );\n return module.unreachable();\n }\n }\n\n // check and compile field values\n var names = expression.names;\n var numNames = names.length;\n var values = expression.values;\n var members = classReference.members;\n var hasErrors = false;\n var exprs = new Array(numNames + 2);\n var flow = this.currentFlow;\n var tempLocal = flow.getAutoreleaseLocal(this.options.usizeType);\n assert(numNames == values.length);\n for (let i = 0, k = numNames; i < k; ++i) {\n let member = members ? members.get(names[i].text) : null;\n if (!member || member.kind != ElementKind.FIELD) {\n this.error(\n DiagnosticCode.Property_0_does_not_exist_on_type_1,\n names[i].range, names[i].text, classReference.toString()\n );\n hasErrors = true;\n continue;\n }\n let type = (member).type;\n exprs[i + 1] = this.module.store( // TODO: handle setters as well\n type.byteSize,\n this.module.local_get(tempLocal.index, this.options.nativeSizeType),\n this.compileExpression(values[i], (member).type, Constraints.CONV_IMPLICIT),\n type.toNativeType(),\n (member).memoryOffset\n );\n }\n this.currentType = classReference.type.nonNullableType;\n if (hasErrors) return module.unreachable();\n\n // allocate a new instance first and assign 'this' to the temp. local\n exprs[0] = module.local_set(\n tempLocal.index,\n this.makeRetain(\n this.makeAllocation(classReference)\n )\n );\n\n // once all field values have been set, return 'this'\n exprs[exprs.length - 1] = module.local_get(tempLocal.index, this.options.nativeSizeType);\n\n this.currentType = classReference.type;\n return module.block(null, exprs, this.options.nativeSizeType);\n }\n\n compileNewExpression(\n expression: NewExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var module = this.module;\n var flow = this.currentFlow;\n\n // obtain the class being instantiated\n var target = this.resolver.resolveExpression( // reports\n expression.expression,\n flow\n );\n if (!target) return module.unreachable();\n if (target.kind != ElementKind.CLASS_PROTOTYPE) {\n this.error(\n DiagnosticCode.Cannot_use_new_with_an_expression_whose_type_lacks_a_construct_signature,\n expression.expression.range\n );\n return this.module.unreachable();\n }\n var classPrototype = target;\n var classInstance: Class | null = null;\n var typeArguments = expression.typeArguments;\n var classReference: Class | null;\n if (\n !typeArguments &&\n (classReference = contextualType.classReference) !== null &&\n classReference.is(CommonFlags.GENERIC)\n ) {\n classInstance = this.resolver.resolveClass(\n classPrototype,\n classReference.typeArguments,\n makeMap(flow.contextualTypeArguments)\n );\n } else {\n classInstance = this.resolver.resolveClassInclTypeArguments(\n classPrototype,\n typeArguments,\n flow.actualFunction.parent, // relative to caller\n makeMap(flow.contextualTypeArguments),\n expression\n );\n }\n if (!classInstance) return module.unreachable();\n if (contextualType == Type.void) constraints |= Constraints.WILL_DROP;\n return this.compileInstantiate(classInstance, expression.arguments, constraints, expression);\n }\n\n /** Gets the compiled constructor of the specified class or generates one if none is present. */\n ensureConstructor(classInstance: Class, reportNode: Node): Function {\n var instance = classInstance.constructorInstance;\n if (instance) {\n // do not attempt to compile it if inlined anyway\n if (!instance.hasDecorator(DecoratorFlags.INLINE)) this.compileFunction(instance);\n return instance;\n }\n\n // clone base constructor if a derived class\n var baseClass = classInstance.base;\n if (baseClass) {\n let baseCtor = this.ensureConstructor(baseClass, reportNode);\n instance = new Function(\n CommonSymbols.constructor,\n new FunctionPrototype(\n CommonSymbols.constructor,\n classInstance,\n // declaration is important, i.e. to access optional parameter initializers\n (baseCtor.declaration).clone()\n ),\n baseCtor.signature,\n null\n );\n\n // otherwise make a default constructor\n } else {\n instance = new Function(\n CommonSymbols.constructor,\n new FunctionPrototype(\n CommonSymbols.constructor,\n classInstance,\n this.program.makeNativeFunctionDeclaration(CommonSymbols.constructor,\n CommonFlags.INSTANCE | CommonFlags.CONSTRUCTOR\n )\n ),\n new Signature(null, classInstance.type, classInstance.type),\n null\n );\n }\n\n instance.internalName = classInstance.internalName + INSTANCE_DELIMITER + \"constructor\";\n instance.set(CommonFlags.COMPILED);\n instance.prototype.setResolvedInstance(\"\", instance);\n classInstance.constructorInstance = instance;\n var previousFlow = this.currentFlow;\n var flow = instance.flow;\n this.currentFlow = flow;\n\n // generate body\n var signature = instance.signature;\n var module = this.module;\n var nativeSizeType = this.options.nativeSizeType;\n var stmts = new Array();\n\n // {\n // if (!this) this = \n // IF_DERIVED: this = super(this, ...args)\n // this.a = X\n // this.b = Y\n // return this\n // }\n stmts.push(\n module.if(\n module.unary(nativeSizeType == NativeType.I64 ? UnaryOp.EqzI64 : UnaryOp.EqzI32,\n module.local_get(0, nativeSizeType)\n ),\n module.local_set(0,\n this.makeRetain(\n this.makeAllocation(classInstance)\n )\n )\n )\n );\n if (baseClass) {\n let parameterTypes = signature.parameterTypes;\n let numParameters = parameterTypes.length;\n let operands = new Array(1 + numParameters);\n operands[0] = module.local_get(0, nativeSizeType);\n for (let i = 0; i < numParameters; ++i) {\n operands[i + 1] = module.local_get(i + 1, parameterTypes[i].toNativeType());\n }\n // TODO: base constructor might be inlined, but makeCallDirect can't do this\n stmts.push(\n module.local_set(0,\n this.makeCallDirect(assert(baseClass.constructorInstance), operands, reportNode, false, true)\n )\n );\n }\n this.makeFieldInitialization(classInstance, stmts);\n var body = this.performAutoreleasesWithValue(flow, module.local_get(0, nativeSizeType), classInstance.type, stmts);\n flow.freeScopedLocals();\n this.currentFlow = previousFlow;\n\n // make the function\n var typeRef = this.ensureFunctionType(signature.parameterTypes, signature.returnType, signature.thisType);\n var locals = instance.localsByIndex;\n var varTypes = new Array(); // of temp. vars added while compiling initializers\n var numOperands = 1 + signature.parameterTypes.length;\n var numLocals = locals.length;\n if (numLocals > numOperands) {\n for (let i = numOperands; i < numLocals; ++i) varTypes.push(locals[i].type.toNativeType());\n }\n var funcRef = module.addFunction(instance.internalName, typeRef, varTypes, body);\n instance.finalize(module, funcRef);\n return instance;\n }\n\n compileInstantiate(\n /** Class to instantiate. */\n classInstance: Class,\n /** Constructor arguments. */\n argumentExpressions: Expression[],\n /** Contextual flags. */\n constraints: Constraints,\n /** Node to report on. */\n reportNode: Node\n ): ExpressionRef {\n var ctor = this.ensureConstructor(classInstance, reportNode);\n var expr = this.compileCallDirect( // no need for another autoreleased local\n ctor,\n argumentExpressions,\n reportNode,\n this.options.usizeType.toNativeZero(this.module),\n constraints\n );\n if (getExpressionType(expr) != NativeType.None) { // possibly IMM_DROPPED\n this.currentType = classInstance.type; // important because a super ctor could be called\n }\n return expr;\n }\n\n /**\n * Compiles a property access in the specified context.\n * @param retainConstantType Retains the type of inlined constants if `true`, otherwise\n * precomputes them according to context.\n */\n compilePropertyAccessExpression(\n propertyAccess: PropertyAccessExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var module = this.module;\n var flow = this.currentFlow;\n\n this.maybeCompileEnclosingSource(propertyAccess);\n\n var target = this.resolver.resolvePropertyAccessExpression(propertyAccess, flow, contextualType); // reports\n if (!target) return module.unreachable();\n\n switch (target.kind) {\n case ElementKind.GLOBAL: { // static field\n if (!this.compileGlobal(target)) { // reports; not yet compiled if a static field\n return module.unreachable();\n }\n let globalType = (target).type;\n assert(globalType != Type.void);\n if ((target).is(CommonFlags.INLINED)) {\n return this.compileInlineConstant(target, contextualType, constraints);\n }\n this.currentType = globalType;\n return module.global_get((target).internalName, globalType.toNativeType());\n }\n case ElementKind.ENUMVALUE: { // enum value\n let theEnum = assert((target).parent); assert(theEnum.kind == ElementKind.ENUM);\n if (!this.compileEnum(theEnum)) {\n this.currentType = Type.i32;\n return this.module.unreachable();\n }\n this.currentType = Type.i32;\n if ((target).is(CommonFlags.INLINED)) {\n assert((target).constantValueKind == ConstantValueKind.INTEGER);\n return module.i32(i64_low((target).constantIntegerValue));\n }\n return module.global_get((target).internalName, NativeType.I32);\n }\n case ElementKind.FIELD: { // instance field\n assert((target).memoryOffset >= 0);\n let thisExpr = this.compileExpression(assert(this.resolver.currentThisExpression), this.options.usizeType);\n this.currentType = (target).type;\n return module.load(\n (target).type.byteSize,\n (target).type.is(TypeFlags.SIGNED | TypeFlags.INTEGER),\n thisExpr,\n (target).type.toNativeType(),\n (target).memoryOffset\n );\n }\n case ElementKind.PROPERTY_PROTOTYPE: {// static property\n let getterPrototype = (target).getterPrototype;\n if (getterPrototype) {\n let getter = this.resolver.resolveFunction(getterPrototype, null);\n if (getter) return this.compileCallDirect(getter, [], propertyAccess, 0);\n }\n return module.unreachable();\n }\n case ElementKind.PROPERTY: { // instance property\n let getterInstance = assert((target).getterInstance);\n return this.compileCallDirect(getterInstance, [], propertyAccess,\n this.compileExpression(assert(this.resolver.currentThisExpression), this.options.usizeType)\n );\n }\n case ElementKind.FUNCTION_PROTOTYPE: {\n this.error(\n DiagnosticCode.Cannot_access_method_0_without_calling_it_as_it_requires_this_to_be_set,\n propertyAccess.range, (target).name\n );\n return module.unreachable();\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n propertyAccess.range\n );\n return module.unreachable();\n }\n\n compileTernaryExpression(\n expression: TernaryExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var ifThen = expression.ifThen;\n var ifElse = expression.ifElse;\n var outerFlow = this.currentFlow;\n\n var condExpr = this.module.precomputeExpression(\n this.makeIsTrueish(\n this.compileExpression(expression.condition, Type.bool),\n this.currentType\n )\n );\n\n // Try to eliminate unnecesssary branches if the condition is constant\n if (\n getExpressionId(condExpr) == ExpressionId.Const &&\n getExpressionType(condExpr) == NativeType.I32\n ) {\n return getConstValueI32(condExpr)\n ? this.compileExpression(ifThen, contextualType)\n : this.compileExpression(ifElse, contextualType);\n }\n\n var inheritedConstraints = constraints & Constraints.WILL_RETAIN;\n\n var ifThenFlow = outerFlow.fork();\n this.currentFlow = ifThenFlow;\n var ifThenExpr = this.compileExpression(ifThen, contextualType, inheritedConstraints);\n var ifThenType = this.currentType;\n var IfThenAutoreleaseSkipped = this.skippedAutoreleases.has(ifThenExpr);\n\n var ifElseFlow = outerFlow.fork();\n this.currentFlow = ifElseFlow;\n var ifElseExpr = this.compileExpression(ifElse, contextualType, inheritedConstraints);\n var ifElseType = this.currentType;\n var ifElseAutoreleaseSkipped = this.skippedAutoreleases.has(ifElseExpr);\n\n var commonType = Type.commonDenominator(ifThenType, ifElseType, false);\n if (!commonType) {\n this.error(\n DiagnosticCode.Type_0_is_not_assignable_to_type_1,\n ifElse.range, ifElseType.toString(), ifThenType.toString()\n );\n this.currentType = contextualType;\n return this.module.unreachable();\n }\n ifThenExpr = this.convertExpression(\n ifThenExpr,\n ifThenType, commonType,\n false, false,\n ifThen\n );\n ifElseExpr = this.convertExpression(\n ifElseExpr,\n ifElseType, commonType,\n false, false,\n ifElse\n );\n this.currentType = commonType;\n\n if (IfThenAutoreleaseSkipped != ifElseAutoreleaseSkipped) { // unify to both skipped\n if (!IfThenAutoreleaseSkipped) {\n ifThenExpr = this.makeRetain(ifThenExpr);\n IfThenAutoreleaseSkipped = true;\n } else {\n ifElseExpr = this.makeRetain(ifElseExpr);\n ifElseAutoreleaseSkipped = true;\n }\n } else if (!IfThenAutoreleaseSkipped && commonType.isManaged) { // keep alive a little longer\n // if (!(constraints & Constraints.WILL_RETAIN)) {\n ifThenExpr = this.moveAutorelease(ifThenExpr, ifThenFlow, outerFlow);\n ifElseExpr = this.moveAutorelease(ifElseExpr, ifElseFlow, outerFlow);\n // }\n }\n\n ifThenExpr = this.performAutoreleasesWithValue(ifThenFlow, ifThenExpr, commonType);\n ifThenFlow.freeScopedLocals();\n\n ifElseExpr = this.performAutoreleasesWithValue(ifElseFlow, ifElseExpr, commonType);\n ifElseFlow.freeScopedLocals();\n\n this.currentFlow = outerFlow;\n outerFlow.inheritMutual(ifThenFlow, ifElseFlow);\n\n var expr = this.module.if(condExpr, ifThenExpr, ifElseExpr);\n assert(IfThenAutoreleaseSkipped == ifElseAutoreleaseSkipped);\n if (IfThenAutoreleaseSkipped) this.skippedAutoreleases.add(expr);\n return expr;\n }\n\n compileUnaryPostfixExpression(\n expression: UnaryPostfixExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var module = this.module;\n var flow = this.currentFlow;\n\n // make a getter for the expression (also obtains the type)\n var getValue = this.compileExpression( // reports\n expression.operand,\n contextualType.exceptVoid,\n Constraints.NONE\n );\n\n // shortcut if compiling the getter already failed\n if (getExpressionId(getValue) == ExpressionId.Unreachable) return getValue;\n\n // if the value isn't dropped, a temp. local is required to remember the original value\n var tempLocal: Local | null = null;\n if (contextualType != Type.void) {\n tempLocal = flow.getTempLocal(this.currentType);\n getValue = module.local_tee(\n tempLocal.index,\n getValue\n );\n }\n\n var expr: ExpressionRef;\n\n switch (expression.operator) {\n case Token.PLUS_PLUS: {\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(\n BinaryOp.AddI32,\n getValue,\n module.i32(1)\n );\n break;\n }\n case TypeKind.USIZE: {\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = this.currentType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.POSTFIX_INC);\n if (overload) {\n expr = this.compileUnaryOverload(overload, expression.operand, getValue, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return module.unreachable();\n }\n }\n case TypeKind.ISIZE: {\n let options = this.options;\n expr = module.binary(\n options.isWasm64\n ? BinaryOp.AddI64\n : BinaryOp.AddI32,\n getValue,\n this.currentType.toNativeOne(module)\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(\n BinaryOp.AddI64,\n getValue,\n module.i64(1)\n );\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(\n BinaryOp.AddF32,\n getValue,\n module.f32(1)\n );\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(\n BinaryOp.AddF64,\n getValue,\n module.f64(1)\n );\n break;\n }\n default: {\n assert(false);\n return module.unreachable();\n }\n }\n break;\n }\n case Token.MINUS_MINUS: {\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(\n BinaryOp.SubI32,\n getValue,\n module.i32(1)\n );\n break;\n }\n case TypeKind.USIZE: {\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = this.currentType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.POSTFIX_DEC);\n if (overload) {\n expr = this.compileUnaryOverload(overload, expression.operand, getValue, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return module.unreachable();\n }\n }\n case TypeKind.ISIZE: {\n let options = this.options;\n expr = module.binary(\n options.isWasm64\n ? BinaryOp.SubI64\n : BinaryOp.SubI32,\n getValue,\n this.currentType.toNativeOne(module)\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(\n BinaryOp.SubI64,\n getValue,\n module.i64(1)\n );\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(\n BinaryOp.SubF32,\n getValue,\n module.f32(1)\n );\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(\n BinaryOp.SubF64,\n getValue,\n module.f64(1)\n );\n break;\n }\n default: {\n assert(false);\n return module.unreachable();\n }\n }\n break;\n }\n default: {\n assert(false);\n return module.unreachable();\n }\n }\n\n var resolver = this.resolver;\n var target = resolver.resolveExpression(expression.operand, flow); // reports\n\n // simplify if dropped anyway\n if (!tempLocal) {\n this.currentType = Type.void;\n if (!target) return module.unreachable();\n return this.makeAssignment(\n target,\n expr,\n expression.operand,\n resolver.currentThisExpression,\n resolver.currentElementExpression,\n false\n );\n } else if (!target) {\n return module.unreachable();\n }\n\n // otherwise use the temp. local for the intermediate value (always possibly overflows)\n var setValue = this.makeAssignment(\n target,\n expr, // includes a tee of getValue to tempLocal\n expression.operand,\n resolver.currentThisExpression,\n resolver.currentElementExpression,\n false\n );\n\n this.currentType = tempLocal.type;\n flow.freeTempLocal(tempLocal);\n var nativeType = tempLocal.type.toNativeType();\n\n return module.block(null, [\n setValue,\n module.local_get(tempLocal.index, nativeType)\n ], nativeType); // result of 'x++' / 'x--' might overflow\n }\n\n compileUnaryPrefixExpression(\n expression: UnaryPrefixExpression,\n contextualType: Type,\n constraints: Constraints\n ): ExpressionRef {\n var module = this.module;\n var compound = false;\n var expr: ExpressionRef;\n\n switch (expression.operator) {\n case Token.PLUS: {\n expr = this.compileExpression(\n expression.operand,\n contextualType.exceptVoid,\n Constraints.NONE\n );\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = this.currentType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.PLUS);\n if (overload) {\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return module.unreachable();\n }\n\n // nop\n break;\n }\n case Token.MINUS: {\n if (expression.operand.kind == NodeKind.LITERAL && (\n (expression.operand).literalKind == LiteralKind.INTEGER ||\n (expression.operand).literalKind == LiteralKind.FLOAT\n )) {\n // implicitly negate integer and float literals. also enables proper checking of literal ranges.\n expr = this.compileLiteralExpression(expression.operand, contextualType, Constraints.NONE, true);\n // compileExpression normally does this:\n if (this.options.sourceMap) this.addDebugLocation(expr, expression.range);\n break;\n }\n\n expr = this.compileExpression(\n expression.operand,\n contextualType.exceptVoid,\n Constraints.NONE\n );\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = this.currentType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.MINUS);\n if (overload) {\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return module.unreachable();\n }\n\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.SubI32, module.i32(0), expr);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.SubI64\n : BinaryOp.SubI32,\n this.currentType.toNativeZero(module),\n expr\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.SubI64, module.i64(0), expr);\n break;\n }\n case TypeKind.F32: {\n expr = module.unary(UnaryOp.NegF32, expr);\n break;\n }\n case TypeKind.F64: {\n expr = module.unary(UnaryOp.NegF64, expr);\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.PLUS_PLUS: {\n compound = true;\n expr = this.compileExpression(\n expression.operand,\n contextualType.exceptVoid,\n Constraints.NONE\n );\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = this.currentType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.PREFIX_INC);\n if (overload) {\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return module.unreachable();\n }\n\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.AddI32, expr, this.module.i32(1));\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.AddI64\n : BinaryOp.AddI32,\n expr,\n this.currentType.toNativeOne(module)\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.AddI64, expr, module.i64(1));\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.AddF32, expr, module.f32(1));\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.AddF64, expr, module.f64(1));\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.MINUS_MINUS: {\n compound = true;\n expr = this.compileExpression(\n expression.operand,\n contextualType.exceptVoid,\n Constraints.NONE\n );\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = this.currentType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.PREFIX_DEC);\n if (overload) {\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return module.unreachable();\n }\n\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.SubI32, expr, module.i32(1));\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.SubI64\n : BinaryOp.SubI32,\n expr,\n this.currentType.toNativeOne(module)\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.SubI64, expr, module.i64(1));\n break;\n }\n case TypeKind.F32: {\n expr = module.binary(BinaryOp.SubF32, expr, module.f32(1));\n break;\n }\n case TypeKind.F64: {\n expr = module.binary(BinaryOp.SubF64, expr, module.f64(1));\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.EXCLAMATION: {\n expr = this.compileExpression(\n expression.operand,\n contextualType.exceptVoid,\n Constraints.NONE\n );\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = this.currentType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.NOT);\n if (overload) {\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\n break;\n }\n }\n // allow '!' for references even without an overload\n }\n\n expr = this.makeIsFalseish(expr, this.currentType);\n this.currentType = Type.bool;\n break;\n }\n case Token.TILDE: {\n expr = this.compileExpression(\n expression.operand,\n contextualType == Type.void\n ? Type.i32\n : contextualType.is(TypeFlags.FLOAT)\n ? Type.i64\n : contextualType,\n Constraints.NONE\n );\n\n // check operator overload\n if (this.currentType.is(TypeFlags.REFERENCE)) {\n let classReference = this.currentType.classReference;\n if (classReference) {\n let overload = classReference.lookupOverload(OperatorKind.BITWISE_NOT);\n if (overload) {\n expr = this.compileUnaryOverload(overload, expression.operand, expr, expression);\n break;\n }\n }\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return module.unreachable();\n } else {\n expr = this.convertExpression(expr,\n this.currentType, this.currentType.intType,\n false, false,\n expression.operand\n );\n }\n\n switch (this.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.binary(BinaryOp.XorI32, expr, module.i32(-1));\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n this.options.isWasm64\n ? BinaryOp.XorI64\n : BinaryOp.XorI32,\n expr,\n this.currentType.toNativeNegOne(module)\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.XorI64, expr, module.i64(-1, -1));\n break;\n }\n default: {\n assert(false);\n expr = module.unreachable();\n }\n }\n break;\n }\n case Token.TYPEOF: {\n this.error(\n DiagnosticCode.Operation_not_supported,\n expression.range\n );\n return module.unreachable();\n }\n default: {\n assert(false);\n return module.unreachable();\n }\n }\n if (!compound) return expr;\n var resolver = this.resolver;\n var target = resolver.resolveExpression(expression.operand, this.currentFlow);\n if (!target) return module.unreachable();\n return this.makeAssignment(\n target,\n expr,\n expression.operand,\n resolver.currentThisExpression,\n resolver.currentElementExpression,\n contextualType != Type.void\n );\n }\n\n /** Makes sure that a 32-bit integer value is wrapped to a valid value of the specified type. */\n ensureSmallIntegerWrap(expr: ExpressionRef, type: Type): ExpressionRef {\n var module = this.module;\n var flow = this.currentFlow;\n switch (type.kind) {\n case TypeKind.I8: {\n if (flow.canOverflow(expr, type)) {\n expr = this.options.hasFeature(Feature.SIGN_EXTENSION)\n ? module.unary(UnaryOp.ExtendI8ToI32, expr)\n : module.binary(BinaryOp.ShrI32,\n module.binary(BinaryOp.ShlI32,\n expr,\n module.i32(24)\n ),\n module.i32(24)\n );\n }\n break;\n }\n case TypeKind.I16: {\n if (flow.canOverflow(expr, type)) {\n expr = this.options.hasFeature(Feature.SIGN_EXTENSION)\n ? module.unary(UnaryOp.ExtendI16ToI32, expr)\n : module.binary(BinaryOp.ShrI32,\n module.binary(BinaryOp.ShlI32,\n expr,\n module.i32(16)\n ),\n module.i32(16)\n );\n }\n break;\n }\n case TypeKind.U8: {\n if (flow.canOverflow(expr, type)) {\n expr = module.binary(BinaryOp.AndI32,\n expr,\n module.i32(0xff)\n );\n }\n break;\n }\n case TypeKind.U16: {\n if (flow.canOverflow(expr, type)) {\n expr = module.binary(BinaryOp.AndI32,\n expr,\n module.i32(0xffff)\n );\n }\n break;\n }\n case TypeKind.BOOL: {\n if (flow.canOverflow(expr, type)) {\n // bool is special in that it compares to 0 instead of masking with 0x1\n expr = module.binary(BinaryOp.NeI32,\n expr,\n module.i32(0)\n );\n }\n break;\n }\n }\n return expr;\n }\n\n /** Adds the debug location of the specified expression at the specified range to the source map. */\n addDebugLocation(expr: ExpressionRef, range: Range): void {\n var parentFunction = this.currentFlow.parentFunction;\n var source = range.source;\n if (source.debugInfoIndex < 0) source.debugInfoIndex = this.module.addDebugInfoFile(source.normalizedPath);\n range.debugInfoRef = expr;\n parentFunction.debugLocations.push(range);\n }\n\n // === Specialized code generation ==============================================================\n\n /** Creates a comparison whether an expression is 'false' in a broader sense. */\n makeIsFalseish(expr: ExpressionRef, type: Type): ExpressionRef {\n var module = this.module;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL: {\n expr = this.ensureSmallIntegerWrap(expr, type);\n // fall-through\n }\n case TypeKind.I32:\n case TypeKind.U32: {\n return module.unary(UnaryOp.EqzI32, expr);\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n return module.unary(UnaryOp.EqzI64, expr);\n }\n case TypeKind.USIZE: if (this.skippedAutoreleases.has(expr)) expr = this.makeAutorelease(expr);\n case TypeKind.ISIZE: {\n return module.unary(type.size == 64 ? UnaryOp.EqzI64 : UnaryOp.EqzI32, expr);\n }\n case TypeKind.F32: {\n return module.binary(BinaryOp.EqF32, expr, module.f32(0));\n }\n case TypeKind.F64: {\n return module.binary(BinaryOp.EqF64, expr, module.f64(0));\n }\n default: {\n assert(false);\n return module.i32(1);\n }\n }\n }\n\n /** Creates a comparison whether an expression is 'true' in a broader sense. */\n makeIsTrueish(expr: ExpressionRef, type: Type): ExpressionRef {\n var module = this.module;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.U8:\n case TypeKind.U16: {\n expr = this.ensureSmallIntegerWrap(expr, type);\n // fall-through\n }\n case TypeKind.BOOL: // not a mask, just != 0\n case TypeKind.I32:\n case TypeKind.U32: {\n return expr;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n return module.binary(BinaryOp.NeI64, expr, module.i64(0));\n }\n case TypeKind.USIZE: if (this.skippedAutoreleases.has(expr)) expr = this.makeAutorelease(expr);\n case TypeKind.ISIZE: {\n return type.size == 64\n ? module.binary(BinaryOp.NeI64, expr, module.i64(0))\n : expr;\n }\n case TypeKind.F32: {\n return module.binary(BinaryOp.NeF32, expr, module.f32(0));\n }\n case TypeKind.F64: {\n return module.binary(BinaryOp.NeF64, expr, module.f64(0));\n }\n default: {\n assert(false);\n return module.i32(0);\n }\n }\n }\n\n /** Makes an allocation suitable to hold the data of an instance of the given class. */\n makeAllocation(\n classInstance: Class\n ): ExpressionRef {\n // TODO: investigate if it's possible to allocate with RC=1 immediately\n var program = this.program;\n assert(classInstance.program == program);\n var module = this.module;\n var options = this.options;\n this.currentType = classInstance.type;\n var allocInstance = program.allocInstance;\n this.compileFunction(allocInstance);\n return module.call(allocInstance.internalName, [\n options.isWasm64\n ? module.i64(classInstance.currentMemoryOffset)\n : module.i32(classInstance.currentMemoryOffset),\n module.i32(\n classInstance.hasDecorator(DecoratorFlags.UNMANAGED)\n ? 0\n : classInstance.id\n )\n ], options.nativeSizeType);\n }\n\n /** Makes the initializers for a class's fields. */\n makeFieldInitialization(\n classInstance: Class,\n stmts: ExpressionRef[] = []\n ): ExpressionRef[] {\n var members = classInstance.members;\n if (!members) return [];\n\n var module = this.module;\n var flow = this.currentFlow;\n var isInline = flow.is(FlowFlags.INLINE_CONTEXT);\n var thisLocalIndex = isInline\n ? assert(flow.lookupLocal(CommonSymbols.this_)).index\n : 0;\n var nativeSizeType = this.options.nativeSizeType;\n\n for (let member of members.values()) {\n if (\n member.kind != ElementKind.FIELD || // not a field\n member.parent != classInstance // inherited field\n ) continue;\n\n let field = member; assert(!field.isAny(CommonFlags.CONST));\n let fieldType = field.type;\n let nativeFieldType = fieldType.toNativeType();\n let initializerNode = field.prototype.initializerNode;\n if (initializerNode) { // use initializer\n let initExpr = this.compileExpression(initializerNode, fieldType, // reports\n Constraints.CONV_IMPLICIT | Constraints.WILL_RETAIN\n );\n if (fieldType.isManaged && !this.skippedAutoreleases.has(initExpr)) {\n initExpr = this.makeRetain(initExpr);\n }\n stmts.push(\n module.store(fieldType.byteSize,\n module.local_get(thisLocalIndex, nativeSizeType),\n initExpr,\n nativeFieldType,\n field.memoryOffset\n )\n );\n } else {\n let parameterIndex = field.prototype.parameterIndex;\n stmts.push(\n module.store(fieldType.byteSize,\n module.local_get(thisLocalIndex, nativeSizeType),\n parameterIndex >= 0 // initialized via parameter (here: a local)\n ? module.local_get(\n isInline\n ? assert(flow.lookupLocal(field.name)).index\n : 1 + parameterIndex, // this is local 0\n nativeFieldType\n )\n : fieldType.toNativeZero(module),\n nativeFieldType,\n field.memoryOffset\n )\n );\n }\n }\n return stmts;\n }\n\n makeInstanceOfClass(\n expr: ExpressionRef,\n classInstance: Class\n ): ExpressionRef {\n var module = this.module;\n var flow = this.currentFlow;\n var idTemp = flow.getTempLocal(Type.i32);\n var idExpr = module.load(4, false,\n module.binary(BinaryOp.SubI32,\n expr,\n module.i32(this.program.runtimeHeaderSize)\n ),\n NativeType.I32\n );\n var label = \"instanceof_\" + classInstance.name + \"|\" + flow.pushBreakLabel();\n var conditions: ExpressionRef[] = [];\n conditions.push(\n module.drop( // br_if returns the value too\n module.br(label,\n module.binary(BinaryOp.EqI32, // classId == class.id\n module.local_tee(idTemp.index, idExpr),\n module.i32(classInstance.id)\n ),\n module.i32(1) // ? true\n )\n )\n );\n // TODO: insert conditions for all possible subclasses (i.e. cat is also animal)\n // TODO: simplify if there are none\n conditions.push(\n module.i32(0) // : false\n );\n flow.freeTempLocal(idTemp);\n flow.popBreakLabel();\n return module.block(label, conditions, NativeType.I32);\n }\n}\n\n// helpers\n\nfunction mangleImportName(\n element: Element,\n declaration: DeclarationStatement\n): void {\n // by default, use the file name as the module name\n mangleImportName_moduleName = declaration.range.source.simplePath;\n // and the internal name of the element within that file as the element name\n mangleImportName_elementName = mangleInternalName(\n element.name, element.parent, element.is(CommonFlags.INSTANCE), true\n );\n if (!element.hasDecorator(DecoratorFlags.EXTERNAL)) return;\n\n var program = element.program;\n var decorator = assert(findDecorator(DecoratorKind.EXTERNAL, declaration.decorators));\n var args = decorator.arguments;\n if (args && args.length) {\n let arg = args[0];\n // if one argument is given, override just the element name\n // if two arguments are given, override both module and element name\n if (arg.kind == NodeKind.LITERAL && (arg).literalKind == LiteralKind.STRING) {\n mangleImportName_elementName = (arg).value;\n if (args.length >= 2) {\n arg = args[1];\n if (arg.kind == NodeKind.LITERAL && (arg).literalKind == LiteralKind.STRING) {\n mangleImportName_moduleName = mangleImportName_elementName;\n mangleImportName_elementName = (arg).value;\n if (args.length > 2) {\n program.error(\n DiagnosticCode.Expected_0_arguments_but_got_1,\n decorator.range, \"2\", args.length.toString()\n );\n }\n } else {\n program.error(\n DiagnosticCode.String_literal_expected,\n arg.range\n );\n }\n }\n } else {\n program.error(\n DiagnosticCode.String_literal_expected,\n arg.range\n );\n }\n } else {\n program.error(\n DiagnosticCode.Expected_at_least_0_arguments_but_got_1,\n decorator.range, \"1\", \"0\"\n );\n }\n}\n\nvar mangleImportName_moduleName: string;\nvar mangleImportName_elementName: string;\n\n/** Flattens a series of expressions to a nop, a single statement or a block depending on statement count. */\nexport function flatten(module: Module, stmts: ExpressionRef[], type: NativeType): ExpressionRef {\n var length = stmts.length;\n if (length == 0) return module.nop(); // usually filtered out again\n if (length == 1) {\n let single = stmts[0];\n if (getExpressionType(single) == type) return single;\n if (getExpressionId(single) == ExpressionId.Block) {\n let count = getBlockChildCount(single);\n let children = new Array(count);\n for (let i = 0; i < count; ++i) children[i] = getBlockChild(single, i);\n return module.block(getBlockName(single), children, type);\n }\n }\n return module.block(null, stmts,\n type == NativeType.Auto\n ? getExpressionType(stmts[length - 1])\n : type\n );\n}\n","/**\n * Generated from diagnosticsMessages.json. Do not edit.\n * @module diagnostics\n *//***/\n\n/* tslint:disable:max-line-length */\n\n/** Enum of available diagnostic codes. */\nexport enum DiagnosticCode {\n Operation_not_supported = 100,\n Operation_is_unsafe = 101,\n User_defined_0 = 102,\n Conversion_from_type_0_to_1_requires_an_explicit_cast = 200,\n Conversion_from_type_0_to_1_will_require_an_explicit_cast_when_switching_between_32_64_bit = 201,\n Type_0_cannot_be_changed_to_type_1 = 202,\n Type_0_cannot_be_reinterpreted_as_type_1 = 203,\n Basic_type_0_cannot_be_nullable = 204,\n Cannot_export_a_mutable_global = 205,\n Mutable_value_cannot_be_inlined = 206,\n Unmanaged_classes_cannot_extend_managed_classes_and_vice_versa = 207,\n Unmanaged_classes_cannot_implement_interfaces = 208,\n Invalid_regular_expression_flags = 209,\n Implementation_0_must_match_the_signature_1 = 210,\n Class_0_is_sealed_and_cannot_be_extended = 211,\n Decorator_0_is_not_valid_here = 212,\n Duplicate_decorator = 213,\n An_allocator_must_be_present_to_use_0 = 214,\n Optional_parameter_must_have_an_initializer = 215,\n Constructor_of_class_0_must_not_require_any_arguments = 216,\n Function_0_cannot_be_inlined_into_itself = 217,\n Cannot_access_method_0_without_calling_it_as_it_requires_this_to_be_set = 218,\n Optional_properties_are_not_supported = 219,\n Expression_must_be_a_compile_time_constant = 220,\n Module_cannot_have_multiple_start_functions = 221,\n _0_must_be_a_value_between_1_and_2_inclusive = 222,\n _0_must_be_a_power_of_two = 223,\n TODO_Cannot_inline_inferred_calls_and_specific_internals_yet = 224,\n Expression_is_never_null = 225,\n Unterminated_string_literal = 1002,\n Identifier_expected = 1003,\n _0_expected = 1005,\n A_file_cannot_have_a_reference_to_itself = 1006,\n Trailing_comma_not_allowed = 1009,\n Unexpected_token = 1012,\n A_rest_parameter_must_be_last_in_a_parameter_list = 1014,\n Parameter_cannot_have_question_mark_and_initializer = 1015,\n A_required_parameter_cannot_follow_an_optional_parameter = 1016,\n Statements_are_not_allowed_in_ambient_contexts = 1036,\n Initializers_are_not_allowed_in_ambient_contexts = 1039,\n _0_modifier_cannot_be_used_here = 1042,\n A_rest_parameter_cannot_be_optional = 1047,\n A_rest_parameter_cannot_have_an_initializer = 1048,\n A_set_accessor_must_have_exactly_one_parameter = 1049,\n A_set_accessor_parameter_cannot_have_an_initializer = 1052,\n A_get_accessor_cannot_have_parameters = 1054,\n Enum_member_must_have_initializer = 1061,\n Type_parameters_cannot_appear_on_a_constructor_declaration = 1092,\n Type_annotation_cannot_appear_on_a_constructor_declaration = 1093,\n An_accessor_cannot_have_type_parameters = 1094,\n A_set_accessor_cannot_have_a_return_type_annotation = 1095,\n Type_parameter_list_cannot_be_empty = 1098,\n A_continue_statement_can_only_be_used_within_an_enclosing_iteration_statement = 1104,\n A_break_statement_can_only_be_used_within_an_enclosing_iteration_or_switch_statement = 1105,\n A_return_statement_can_only_be_used_within_a_function_body = 1108,\n Expression_expected = 1109,\n Type_expected = 1110,\n A_default_clause_cannot_appear_more_than_once_in_a_switch_statement = 1113,\n Duplicate_label_0 = 1114,\n An_export_assignment_cannot_have_modifiers = 1120,\n Octal_literals_are_not_allowed_in_strict_mode = 1121,\n Digit_expected = 1124,\n Hexadecimal_digit_expected = 1125,\n Unexpected_end_of_text = 1126,\n Invalid_character = 1127,\n _case_or_default_expected = 1130,\n _super_must_be_followed_by_an_argument_list_or_member_access = 1034,\n A_declare_modifier_cannot_be_used_in_an_already_ambient_context = 1038,\n Type_argument_expected = 1140,\n String_literal_expected = 1141,\n Line_break_not_permitted_here = 1142,\n Declaration_expected = 1146,\n _const_declarations_must_be_initialized = 1155,\n Unterminated_regular_expression_literal = 1161,\n Interface_declaration_cannot_have_implements_clause = 1176,\n Binary_digit_expected = 1177,\n Octal_digit_expected = 1178,\n An_implementation_cannot_be_declared_in_ambient_contexts = 1183,\n An_extended_Unicode_escape_value_must_be_between_0x0_and_0x10FFFF_inclusive = 1198,\n Unterminated_Unicode_escape_sequence = 1199,\n Decorators_are_not_valid_here = 1206,\n _abstract_modifier_can_only_appear_on_a_class_method_or_property_declaration = 1242,\n Method_0_cannot_have_an_implementation_because_it_is_marked_abstract = 1245,\n A_definite_assignment_assertion_is_not_permitted_in_this_context = 1255,\n A_class_may_only_extend_another_class = 1311,\n A_parameter_property_cannot_be_declared_using_a_rest_parameter = 1317,\n Duplicate_identifier_0 = 2300,\n Cannot_find_name_0 = 2304,\n Module_0_has_no_exported_member_1 = 2305,\n Generic_type_0_requires_1_type_argument_s = 2314,\n Type_0_is_not_generic = 2315,\n Type_0_is_not_assignable_to_type_1 = 2322,\n Index_signature_is_missing_in_type_0 = 2329,\n _this_cannot_be_referenced_in_current_location = 2332,\n _super_can_only_be_referenced_in_a_derived_class = 2335,\n Super_calls_are_not_permitted_outside_constructors_or_in_nested_functions_inside_constructors = 2337,\n Property_0_does_not_exist_on_type_1 = 2339,\n Cannot_invoke_an_expression_whose_type_lacks_a_call_signature_Type_0_has_no_compatible_call_signatures = 2349,\n Cannot_use_new_with_an_expression_whose_type_lacks_a_construct_signature = 2351,\n A_function_whose_declared_type_is_not_void_must_return_a_value = 2355,\n The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access = 2357,\n The_left_hand_side_of_an_assignment_expression_must_be_a_variable_or_a_property_access = 2364,\n Operator_0_cannot_be_applied_to_types_1_and_2 = 2365,\n A_super_call_must_be_the_first_statement_in_the_constructor = 2376,\n Constructors_for_derived_classes_must_contain_a_super_call = 2377,\n _get_and_set_accessor_must_have_the_same_type = 2380,\n Constructor_implementation_is_missing = 2390,\n Function_implementation_is_missing_or_not_immediately_following_the_declaration = 2391,\n Multiple_constructor_implementations_are_not_allowed = 2392,\n Duplicate_function_implementation = 2393,\n Individual_declarations_in_merged_declaration_0_must_be_all_exported_or_all_local = 2395,\n A_namespace_declaration_cannot_be_located_prior_to_a_class_or_function_with_which_it_is_merged = 2434,\n Type_0_has_no_property_1 = 2460,\n The_0_operator_cannot_be_applied_to_type_1 = 2469,\n In_const_enum_declarations_member_initializer_must_be_constant_expression = 2474,\n Export_declaration_conflicts_with_exported_declaration_of_0 = 2484,\n Object_is_possibly_null = 2531,\n Cannot_assign_to_0_because_it_is_a_constant_or_a_read_only_property = 2540,\n The_target_of_an_assignment_must_be_a_variable_or_a_property_access = 2541,\n Index_signature_in_type_0_only_permits_reading = 2542,\n Expected_0_arguments_but_got_1 = 2554,\n Expected_at_least_0_arguments_but_got_1 = 2555,\n Expected_0_type_arguments_but_got_1 = 2558,\n A_member_initializer_in_a_enum_declaration_cannot_reference_members_declared_after_it_including_members_defined_in_other_enums = 2651,\n Constructor_of_class_0_is_private_and_only_accessible_within_the_class_declaration = 2673,\n Constructor_of_class_0_is_protected_and_only_accessible_within_the_class_declaration = 2674,\n Namespace_0_has_no_exported_member_1 = 2694,\n Required_type_parameters_may_not_follow_optional_type_parameters = 2706,\n Duplicate_property_0 = 2718,\n File_0_not_found = 6054,\n Numeric_separators_are_not_allowed_here = 6188,\n Multiple_consecutive_numeric_separators_are_not_permitted = 6189,\n _super_must_be_called_before_accessing_this_in_the_constructor_of_a_derived_class = 17009,\n _super_must_be_called_before_accessing_a_property_of_super_in_the_constructor_of_a_derived_class = 17011\n}\n\n/** Translates a diagnostic code to its respective string. */\nexport function diagnosticCodeToString(code: DiagnosticCode): string {\n switch (code) {\n case 100: return \"Operation not supported.\";\n case 101: return \"Operation is unsafe.\";\n case 102: return \"User-defined: {0}\";\n case 200: return \"Conversion from type '{0}' to '{1}' requires an explicit cast.\";\n case 201: return \"Conversion from type '{0}' to '{1}' will require an explicit cast when switching between 32/64-bit.\";\n case 202: return \"Type '{0}' cannot be changed to type '{1}'.\";\n case 203: return \"Type '{0}' cannot be reinterpreted as type '{1}'.\";\n case 204: return \"Basic type '{0}' cannot be nullable.\";\n case 205: return \"Cannot export a mutable global.\";\n case 206: return \"Mutable value cannot be inlined.\";\n case 207: return \"Unmanaged classes cannot extend managed classes and vice-versa.\";\n case 208: return \"Unmanaged classes cannot implement interfaces.\";\n case 209: return \"Invalid regular expression flags.\";\n case 210: return \"Implementation '{0}' must match the signature '{1}'.\";\n case 211: return \"Class '{0}' is sealed and cannot be extended.\";\n case 212: return \"Decorator '{0}' is not valid here.\";\n case 213: return \"Duplicate decorator.\";\n case 214: return \"An allocator must be present to use '{0}'.\";\n case 215: return \"Optional parameter must have an initializer.\";\n case 216: return \"Constructor of class '{0}' must not require any arguments.\";\n case 217: return \"Function '{0}' cannot be inlined into itself.\";\n case 218: return \"Cannot access method '{0}' without calling it as it requires 'this' to be set.\";\n case 219: return \"Optional properties are not supported.\";\n case 220: return \"Expression must be a compile-time constant.\";\n case 221: return \"Module cannot have multiple start functions.\";\n case 222: return \"'{0}' must be a value between '{1}' and '{2}' inclusive.\";\n case 223: return \"'{0}' must be a power of two.\";\n case 224: return \"TODO: Cannot inline inferred calls and specific internals yet.\";\n case 225: return \"Expression is never 'null'.\";\n case 1002: return \"Unterminated string literal.\";\n case 1003: return \"Identifier expected.\";\n case 1005: return \"'{0}' expected.\";\n case 1006: return \"A file cannot have a reference to itself.\";\n case 1009: return \"Trailing comma not allowed.\";\n case 1012: return \"Unexpected token.\";\n case 1014: return \"A rest parameter must be last in a parameter list.\";\n case 1015: return \"Parameter cannot have question mark and initializer.\";\n case 1016: return \"A required parameter cannot follow an optional parameter.\";\n case 1036: return \"Statements are not allowed in ambient contexts.\";\n case 1039: return \"Initializers are not allowed in ambient contexts.\";\n case 1042: return \"'{0}' modifier cannot be used here.\";\n case 1047: return \"A rest parameter cannot be optional.\";\n case 1048: return \"A rest parameter cannot have an initializer.\";\n case 1049: return \"A 'set' accessor must have exactly one parameter.\";\n case 1052: return \"A 'set' accessor parameter cannot have an initializer.\";\n case 1054: return \"A 'get' accessor cannot have parameters.\";\n case 1061: return \"Enum member must have initializer.\";\n case 1092: return \"Type parameters cannot appear on a constructor declaration.\";\n case 1093: return \"Type annotation cannot appear on a constructor declaration.\";\n case 1094: return \"An accessor cannot have type parameters.\";\n case 1095: return \"A 'set' accessor cannot have a return type annotation.\";\n case 1098: return \"Type parameter list cannot be empty.\";\n case 1104: return \"A 'continue' statement can only be used within an enclosing iteration statement.\";\n case 1105: return \"A 'break' statement can only be used within an enclosing iteration or switch statement.\";\n case 1108: return \"A 'return' statement can only be used within a function body.\";\n case 1109: return \"Expression expected.\";\n case 1110: return \"Type expected.\";\n case 1113: return \"A 'default' clause cannot appear more than once in a 'switch' statement.\";\n case 1114: return \"Duplicate label '{0}'.\";\n case 1120: return \"An export assignment cannot have modifiers.\";\n case 1121: return \"Octal literals are not allowed in strict mode.\";\n case 1124: return \"Digit expected.\";\n case 1125: return \"Hexadecimal digit expected.\";\n case 1126: return \"Unexpected end of text.\";\n case 1127: return \"Invalid character.\";\n case 1130: return \"'case' or 'default' expected.\";\n case 1034: return \"'super' must be followed by an argument list or member access.\";\n case 1038: return \"A 'declare' modifier cannot be used in an already ambient context.\";\n case 1140: return \"Type argument expected.\";\n case 1141: return \"String literal expected.\";\n case 1142: return \"Line break not permitted here.\";\n case 1146: return \"Declaration expected.\";\n case 1155: return \"'const' declarations must be initialized.\";\n case 1161: return \"Unterminated regular expression literal.\";\n case 1176: return \"Interface declaration cannot have 'implements' clause.\";\n case 1177: return \"Binary digit expected.\";\n case 1178: return \"Octal digit expected.\";\n case 1183: return \"An implementation cannot be declared in ambient contexts.\";\n case 1198: return \"An extended Unicode escape value must be between 0x0 and 0x10FFFF inclusive.\";\n case 1199: return \"Unterminated Unicode escape sequence.\";\n case 1206: return \"Decorators are not valid here.\";\n case 1242: return \"'abstract' modifier can only appear on a class, method, or property declaration.\";\n case 1245: return \"Method '{0}' cannot have an implementation because it is marked abstract.\";\n case 1255: return \"A definite assignment assertion '!' is not permitted in this context.\";\n case 1311: return \"A class may only extend another class.\";\n case 1317: return \"A parameter property cannot be declared using a rest parameter.\";\n case 2300: return \"Duplicate identifier '{0}'.\";\n case 2304: return \"Cannot find name '{0}'.\";\n case 2305: return \"Module '{0}' has no exported member '{1}'.\";\n case 2314: return \"Generic type '{0}' requires {1} type argument(s).\";\n case 2315: return \"Type '{0}' is not generic.\";\n case 2322: return \"Type '{0}' is not assignable to type '{1}'.\";\n case 2329: return \"Index signature is missing in type '{0}'.\";\n case 2332: return \"'this' cannot be referenced in current location.\";\n case 2335: return \"'super' can only be referenced in a derived class.\";\n case 2337: return \"Super calls are not permitted outside constructors or in nested functions inside constructors.\";\n case 2339: return \"Property '{0}' does not exist on type '{1}'.\";\n case 2349: return \"Cannot invoke an expression whose type lacks a call signature. Type '{0}' has no compatible call signatures.\";\n case 2351: return \"Cannot use 'new' with an expression whose type lacks a construct signature.\";\n case 2355: return \"A function whose declared type is not 'void' must return a value.\";\n case 2357: return \"The operand of an increment or decrement operator must be a variable or a property access.\";\n case 2364: return \"The left-hand side of an assignment expression must be a variable or a property access.\";\n case 2365: return \"Operator '{0}' cannot be applied to types '{1}' and '{2}'.\";\n case 2376: return \"A 'super' call must be the first statement in the constructor.\";\n case 2377: return \"Constructors for derived classes must contain a 'super' call.\";\n case 2380: return \"'get' and 'set' accessor must have the same type.\";\n case 2390: return \"Constructor implementation is missing.\";\n case 2391: return \"Function implementation is missing or not immediately following the declaration.\";\n case 2392: return \"Multiple constructor implementations are not allowed.\";\n case 2393: return \"Duplicate function implementation.\";\n case 2395: return \"Individual declarations in merged declaration '{0}' must be all exported or all local.\";\n case 2434: return \"A namespace declaration cannot be located prior to a class or function with which it is merged.\";\n case 2460: return \"Type '{0}' has no property '{1}'.\";\n case 2469: return \"The '{0}' operator cannot be applied to type '{1}'.\";\n case 2474: return \"In 'const' enum declarations member initializer must be constant expression.\";\n case 2484: return \"Export declaration conflicts with exported declaration of '{0}'.\";\n case 2531: return \"Object is possibly 'null'.\";\n case 2540: return \"Cannot assign to '{0}' because it is a constant or a read-only property.\";\n case 2541: return \"The target of an assignment must be a variable or a property access.\";\n case 2542: return \"Index signature in type '{0}' only permits reading.\";\n case 2554: return \"Expected {0} arguments, but got {1}.\";\n case 2555: return \"Expected at least {0} arguments, but got {1}.\";\n case 2558: return \"Expected {0} type arguments, but got {1}.\";\n case 2651: return \"A member initializer in a enum declaration cannot reference members declared after it, including members defined in other enums.\";\n case 2673: return \"Constructor of class '{0}' is private and only accessible within the class declaration.\";\n case 2674: return \"Constructor of class '{0}' is protected and only accessible within the class declaration.\";\n case 2694: return \"Namespace '{0}' has no exported member '{1}'.\";\n case 2706: return \"Required type parameters may not follow optional type parameters.\";\n case 2718: return \"Duplicate property '{0}'.\";\n case 6054: return \"File '{0}' not found.\";\n case 6188: return \"Numeric separators are not allowed here.\";\n case 6189: return \"Multiple consecutive numeric separators are not permitted.\";\n case 17009: return \"'super' must be called before accessing 'this' in the constructor of a derived class.\";\n case 17011: return \"'super' must be called before accessing a property of 'super' in the constructor of a derived class.\";\n default: return \"\";\n }\n}\n","/**\n * Built-in elements providing WebAssembly core functionality.\n * @module builtins\n *//***/\n\n import {\n Compiler,\n Constraints,\n RuntimeFeatures,\n flatten\n} from \"./compiler\";\n\nimport {\n DiagnosticCode\n} from \"./diagnostics\";\n\nimport {\n Node,\n NodeKind,\n Expression,\n LiteralKind,\n LiteralExpression,\n StringLiteralExpression,\n CallExpression\n} from \"./ast\";\n\nimport {\n Type,\n TypeKind,\n TypeFlags,\n Signature\n} from \"./types\";\n\nimport {\n BinaryOp,\n UnaryOp,\n HostOp,\n AtomicRMWOp,\n SIMDExtractOp,\n SIMDReplaceOp,\n SIMDShiftOp,\n NativeType,\n ExpressionRef,\n ExpressionId,\n getExpressionId,\n getExpressionType,\n getConstValueI64High,\n getConstValueI64Low,\n getConstValueI32,\n getConstValueF32,\n getConstValueF64,\n Relooper,\n RelooperBlockRef\n} from \"./module\";\n\nimport {\n ElementKind,\n FunctionPrototype,\n Field,\n Global,\n DecoratorFlags,\n Element\n} from \"./program\";\n\nimport {\n FlowFlags,\n LocalFlags\n} from \"./flow\";\n\nimport {\n ReportMode\n} from \"./resolver\";\n\nimport {\n CommonFlags,\n Feature,\n TypeinfoFlags\n} from \"./common\";\n\nimport {\n writeI8,\n writeI16,\n writeI32,\n writeF32,\n writeF64,\n isPowerOf2\n} from \"./util\";\n\n/** Symbols of various compiler built-ins. */\nexport namespace BuiltinSymbols {\n // std/builtins.ts\n export const isInteger = \"~lib/builtins/isInteger\";\n export const isFloat = \"~lib/builtins/isFloat\";\n export const isBoolean = \"~lib/builtins/isBoolean\";\n export const isSigned = \"~lib/builtins/isSigned\";\n export const isReference = \"~lib/builtins/isReference\";\n export const isString = \"~lib/builtins/isString\";\n export const isArray = \"~lib/builtins/isArray\";\n export const isArrayLike = \"~lib/builtins/isArrayLike\";\n export const isFunction = \"~lib/builtins/isFunction\";\n export const isNullable = \"~lib/builtins/isNullable\";\n export const isDefined = \"~lib/builtins/isDefined\";\n export const isConstant = \"~lib/builtins/isConstant\";\n export const isManaged = \"~lib/builtins/isManaged\";\n\n export const clz = \"~lib/builtins/clz\";\n export const ctz = \"~lib/builtins/ctz\";\n export const popcnt = \"~lib/builtins/popcnt\";\n export const rotl = \"~lib/builtins/rotl\";\n export const rotr = \"~lib/builtins/rotr\";\n export const abs = \"~lib/builtins/abs\";\n export const max = \"~lib/builtins/max\";\n export const min = \"~lib/builtins/min\";\n export const ceil = \"~lib/builtins/ceil\";\n export const floor = \"~lib/builtins/floor\";\n export const copysign = \"~lib/builtins/copysign\";\n export const nearest = \"~lib/builtins/nearest\";\n export const reinterpret = \"~lib/builtins/reinterpret\";\n export const sqrt = \"~lib/builtins/sqrt\";\n export const trunc = \"~lib/builtins/trunc\";\n export const load = \"~lib/builtins/load\";\n export const store = \"~lib/builtins/store\";\n export const atomic_load = \"~lib/builtins/atomic.load\";\n export const atomic_store = \"~lib/builtins/atomic.store\";\n export const atomic_add = \"~lib/builtins/atomic.add\";\n export const atomic_sub = \"~lib/builtins/atomic.sub\";\n export const atomic_and = \"~lib/builtins/atomic.and\";\n export const atomic_or = \"~lib/builtins/atomic.or\";\n export const atomic_xor = \"~lib/builtins/atomic.xor\";\n export const atomic_xchg = \"~lib/builtins/atomic.xchg\";\n export const atomic_cmpxchg = \"~lib/builtins/atomic.cmpxchg\";\n export const atomic_wait = \"~lib/builtins/atomic.wait\";\n export const atomic_notify = \"~lib/builtins/atomic.notify\";\n\n export const sizeof = \"~lib/builtins/sizeof\";\n export const alignof = \"~lib/builtins/alignof\";\n export const offsetof = \"~lib/builtins/offsetof\";\n export const select = \"~lib/builtins/select\";\n export const unreachable = \"~lib/builtins/unreachable\";\n export const changetype = \"~lib/builtins/changetype\";\n export const assert = \"~lib/builtins/assert\";\n export const unchecked = \"~lib/builtins/unchecked\";\n export const call_direct = \"~lib/builtins/call_direct\";\n export const call_indirect = \"~lib/builtins/call_indirect\";\n export const instantiate = \"~lib/builtins/instantiate\";\n export const idof = \"~lib/builtins/idof\";\n\n export const i8 = \"~lib/builtins/i8\";\n export const i16 = \"~lib/builtins/i16\";\n export const i32 = \"~lib/builtins/i32\";\n export const i64 = \"~lib/builtins/i64\";\n export const isize = \"~lib/builtins/isize\";\n export const u8 = \"~lib/builtins/u8\";\n export const u16 = \"~lib/builtins/u16\";\n export const u32 = \"~lib/builtins/u32\";\n export const u64 = \"~lib/builtins/u64\";\n export const usize = \"~lib/builtins/usize\";\n export const bool = \"~lib/builtins/bool\";\n export const f32 = \"~lib/builtins/f32\";\n export const f64 = \"~lib/builtins/f64\";\n export const v128 = \"~lib/builtins/v128\";\n export const void_ = \"~lib/builtins/void\";\n\n export const i32_clz = \"~lib/builtins/i32.clz\";\n export const i64_clz = \"~lib/builtins/i64.clz\";\n export const i32_ctz = \"~lib/builtins/i32.ctz\";\n export const i64_ctz = \"~lib/builtins/i64.ctz\";\n export const i32_popcnt = \"~lib/builtins/i32.popcnt\";\n export const i64_popcnt = \"~lib/builtins/i64.popcnt\";\n export const i32_rotl = \"~lib/builtins/i32.rotl\";\n export const i64_rotl = \"~lib/builtins/i64.rotl\";\n export const i32_rotr = \"~lib/builtins/i32.rotr\";\n export const i64_rotr = \"~lib/builtins/i64.rotr\";\n\n export const f32_abs = \"~lib/builtins/f32.abs\";\n export const f64_abs = \"~lib/builtins/f64.abs\";\n export const f32_max = \"~lib/builtins/f32.max\";\n export const f64_max = \"~lib/builtins/f64.max\";\n export const f32_min = \"~lib/builtins/f32.min\";\n export const f64_min = \"~lib/builtins/f64.min\";\n export const f32_ceil = \"~lib/builtins/f32.ceil\";\n export const f64_ceil = \"~lib/builtins/f64.ceil\";\n export const f32_floor = \"~lib/builtins/f32.floor\";\n export const f64_floor = \"~lib/builtins/f64.floor\";\n export const f32_copysign = \"~lib/builtins/f32.copysign\";\n export const f64_copysign = \"~lib/builtins/f64.copysign\";\n export const f32_nearest = \"~lib/builtins/f32.nearest\";\n export const f64_nearest = \"~lib/builtins/f64.nearest\";\n export const i32_reinterpret_f32 = \"~lib/builtins/i32.reinterpret_f32\";\n export const i64_reinterpret_f64 = \"~lib/builtins/i64.reinterpret_f64\";\n export const f32_reinterpret_i32 = \"~lib/builtins/f32.reinterpret_i32\";\n export const f64_reinterpret_i64 = \"~lib/builtins/f64.reinterpret_i64\";\n export const f32_sqrt = \"~lib/builtins/f32.sqrt\";\n export const f64_sqrt = \"~lib/builtins/f64.sqrt\";\n export const f32_trunc = \"~lib/builtins/f32.trunc\";\n export const f64_trunc = \"~lib/builtins/f64.trunc\";\n\n export const i32_load8_s = \"~lib/builtins/i32.load8_s\";\n export const i32_load8_u = \"~lib/builtins/i32.load8_u\";\n export const i32_load16_s = \"~lib/builtins/i32.load16_s\";\n export const i32_load16_u = \"~lib/builtins/i32.load16_u\";\n export const i32_load = \"~lib/builtins/i32.load\";\n export const i64_load8_s = \"~lib/builtins/i64.load8_s\";\n export const i64_load8_u = \"~lib/builtins/i64.load8_u\";\n export const i64_load16_s = \"~lib/builtins/i64.load16_s\";\n export const i64_load16_u = \"~lib/builtins/i64.load16_u\";\n export const i64_load32_s = \"~lib/builtins/i64.load32_s\";\n export const i64_load32_u = \"~lib/builtins/i64.load32_u\";\n export const i64_load = \"~lib/builtins/i64.load\";\n export const f32_load = \"~lib/builtins/f32.load\";\n export const f64_load = \"~lib/builtins/f64.load\";\n export const i32_store8 = \"~lib/builtins/i32.store8\";\n export const i32_store16 = \"~lib/builtins/i32.store16\";\n export const i32_store = \"~lib/builtins/i32.store\";\n export const i64_store8 = \"~lib/builtins/i64.store8\";\n export const i64_store16 = \"~lib/builtins/i64.store16\";\n export const i64_store32 = \"~lib/builtins/i64.store32\";\n export const i64_store = \"~lib/builtins/i64.store\";\n export const f32_store = \"~lib/builtins/f32.store\";\n export const f64_store = \"~lib/builtins/f64.store\";\n\n export const i32_atomic_load8_u = \"~lib/builtins/i32.atomic.load8_u\";\n export const i32_atomic_load16_u = \"~lib/builtins/i32.atomic.load16_u\";\n export const i32_atomic_load = \"~lib/builtins/i32.atomic.load\";\n export const i64_atomic_load8_u = \"~lib/builtins/i64.atomic.load8_u\";\n export const i64_atomic_load16_u = \"~lib/builtins/i64.atomic.load16_u\";\n export const i64_atomic_load32_u = \"~lib/builtins/i64.atomic.load32_u\";\n export const i64_atomic_load = \"~lib/builtins/i64.atomic.load\";\n export const i32_atomic_store8 = \"~lib/builtins/i32.atomic.store8\";\n export const i32_atomic_store16 = \"~lib/builtins/i32.atomic.store16\";\n export const i32_atomic_store = \"~lib/builtins/i32.atomic.store\";\n export const i64_atomic_store8 = \"~lib/builtins/i64.atomic.store8\";\n export const i64_atomic_store16 = \"~lib/builtins/i64.atomic.store16\";\n export const i64_atomic_store32 = \"~lib/builtins/i64.atomic.store32\";\n export const i64_atomic_store = \"~lib/builtins/i64.atomic.store\";\n export const i32_atomic_rmw8_add_u = \"~lib/builtins/i32.atomic.rmw8.add_u\";\n export const i32_atomic_rmw16_add_u = \"~lib/builtins/i32.atomic.rmw16.add_u\";\n export const i32_atomic_rmw_add = \"~lib/builtins/i32.atomic.rmw.add\";\n export const i64_atomic_rmw8_add_u = \"~lib/builtins/i64.atomic.rmw8.add_u\";\n export const i64_atomic_rmw16_add_u = \"~lib/builtins/i64.atomic.rmw16.add_u\";\n export const i64_atomic_rmw32_add_u = \"~lib/builtins/i64.atomic.rmw32.add_u\";\n export const i64_atomic_rmw_add = \"~lib/builtins/i64.atomic.rmw.add\";\n export const i32_atomic_rmw8_sub_u = \"~lib/builtins/i32.atomic.rmw8.sub_u\";\n export const i32_atomic_rmw16_sub_u = \"~lib/builtins/i32.atomic.rmw16.sub_u\";\n export const i32_atomic_rmw_sub = \"~lib/builtins/i32.atomic.rmw.sub\";\n export const i64_atomic_rmw8_sub_u = \"~lib/builtins/i64.atomic.rmw8.sub_u\";\n export const i64_atomic_rmw16_sub_u = \"~lib/builtins/i64.atomic.rmw16.sub_u\";\n export const i64_atomic_rmw32_sub_u = \"~lib/builtins/i64.atomic.rmw32.sub_u\";\n export const i64_atomic_rmw_sub = \"~lib/builtins/i64.atomic.rmw.sub\";\n export const i32_atomic_rmw8_and_u = \"~lib/builtins/i32.atomic.rmw8.and_u\";\n export const i32_atomic_rmw16_and_u = \"~lib/builtins/i32.atomic.rmw16.and_u\";\n export const i32_atomic_rmw_and = \"~lib/builtins/i32.atomic.rmw.and\";\n export const i64_atomic_rmw8_and_u = \"~lib/builtins/i64.atomic.rmw8.and_u\";\n export const i64_atomic_rmw16_and_u = \"~lib/builtins/i64.atomic.rmw16.and_u\";\n export const i64_atomic_rmw32_and_u = \"~lib/builtins/i64.atomic.rmw32.and_u\";\n export const i64_atomic_rmw_and = \"~lib/builtins/i64.atomic.rmw.and\";\n export const i32_atomic_rmw8_or_u = \"~lib/builtins/i32.atomic.rmw8.or_u\";\n export const i32_atomic_rmw16_or_u = \"~lib/builtins/i32.atomic.rmw16.or_u\";\n export const i32_atomic_rmw_or = \"~lib/builtins/i32.atomic.rmw.or\";\n export const i64_atomic_rmw8_or_u = \"~lib/builtins/i64.atomic.rmw8.or_u\";\n export const i64_atomic_rmw16_or_u = \"~lib/builtins/i64.atomic.rmw16.or_u\";\n export const i64_atomic_rmw32_or_u = \"~lib/builtins/i64.atomic.rmw32.or_u\";\n export const i64_atomic_rmw_or = \"~lib/builtins/i64.atomic.rmw.or\";\n export const i32_atomic_rmw8_u_xor = \"~lib/builtins/i32.atomic.rmw8.xor_u\";\n export const i32_atomic_rmw16_u_xor = \"~lib/builtins/i32.atomic.rmw16.xor_u\";\n export const i32_atomic_rmw_xor = \"~lib/builtins/i32.atomic.rmw.xor\";\n export const i64_atomic_rmw8_xor_u = \"~lib/builtins/i64.atomic.rmw8.xor_u\";\n export const i64_atomic_rmw16_xor_u = \"~lib/builtins/i64.atomic.rmw16.xor_u\";\n export const i64_atomic_rmw32_xor_u = \"~lib/builtins/i64.atomic.rmw32.xor_u\";\n export const i64_atomic_rmw_xor = \"~lib/builtins/i64.atomic.rmw.xor\";\n export const i32_atomic_rmw8_xchg_u = \"~lib/builtins/i32.atomic.rmw8.xchg_u\";\n export const i32_atomic_rmw16_xchg_u = \"~lib/builtins/i32.atomic.rmw16.xchg_u\";\n export const i32_atomic_rmw_xchg = \"~lib/builtins/i32.atomic.rmw.xchg\";\n export const i64_atomic_rmw8_xchg_u = \"~lib/builtins/i64.atomic.rmw8.xchg_u\";\n export const i64_atomic_rmw16_xchg_u = \"~lib/builtins/i64.atomic.rmw16.xchg_u\";\n export const i64_atomic_rmw32_xchg_u = \"~lib/builtins/i64.atomic.rmw32.xchg_u\";\n export const i64_atomic_rmw_xchg = \"~lib/builtins/i64.atomic.rmw.xchg\";\n export const i32_atomic_rmw8_cmpxchg_u = \"~lib/builtins/i32.atomic.rmw8.cmpxchg_u\";\n export const i32_atomic_rmw16_cmpxchg_u = \"~lib/builtins/i32.atomic.rmw16.cmpxchg_u\";\n export const i32_atomic_rmw_cmpxchg = \"~lib/builtins/i32.atomic.rmw.cmpxchg\";\n export const i64_atomic_rmw8_cmpxchg_u = \"~lib/builtins/i64.atomic.rmw8.cmpxchg_u\";\n export const i64_atomic_rmw16_cmpxchg_u = \"~lib/builtins/i64.atomic.rmw16.cmpxchg_u\";\n export const i64_atomic_rmw32_cmpxchg_u = \"~lib/builtins/i64.atomic.rmw32.cmpxchg_u\";\n export const i64_atomic_rmw_cmpxchg = \"~lib/builtins/i64.atomic.rmw.cmpxchg\";\n export const i32_wait = \"~lib/builtins/i32.wait\";\n export const i64_wait = \"~lib/builtins/i64.wait\";\n\n export const v128_splat = \"~lib/builtins/v128.splat\";\n export const v128_extract_lane = \"~lib/builtins/v128.extract_lane\";\n export const v128_replace_lane = \"~lib/builtins/v128.replace_lane\";\n export const v128_shuffle = \"~lib/builtins/v128.shuffle\";\n export const v128_load = \"~lib/builtins/v128.load\";\n export const v128_store = \"~lib/builtins/v128.store\";\n export const v128_add = \"~lib/builtins/v128.add\";\n export const v128_sub = \"~lib/builtins/v128.sub\";\n export const v128_mul = \"~lib/builtins/v128.mul\";\n export const v128_div = \"~lib/builtins/v128.div\";\n export const v128_neg = \"~lib/builtins/v128.neg\";\n export const v128_add_saturate = \"~lib/builtins/v128.add_saturate\";\n export const v128_sub_saturate = \"~lib/builtins/v128.sub_saturate\";\n export const v128_shl = \"~lib/builtins/v128.shl\";\n export const v128_shr = \"~lib/builtins/v128.shr\";\n export const v128_and = \"~lib/builtins/v128.and\";\n export const v128_or = \"~lib/builtins/v128.or\";\n export const v128_xor = \"~lib/builtins/v128.xor\";\n export const v128_not = \"~lib/builtins/v128.not\";\n export const v128_bitselect = \"~lib/builtins/v128.bitselect\";\n export const v128_any_true = \"~lib/builtins/v128.any_true\";\n export const v128_all_true = \"~lib/builtins/v128.all_true\";\n export const v128_min = \"~lib/builtins/v128.min\";\n export const v128_max = \"~lib/builtins/v128.max\";\n export const v128_abs = \"~lib/builtins/v128.abs\";\n export const v128_sqrt = \"~lib/builtins/v128.sqrt\";\n export const v128_eq = \"~lib/builtins/v128.eq\";\n export const v128_ne = \"~lib/builtins/v128.ne\";\n export const v128_lt = \"~lib/builtins/v128.lt\";\n export const v128_le = \"~lib/builtins/v128.le\";\n export const v128_gt = \"~lib/builtins/v128.gt\";\n export const v128_ge = \"~lib/builtins/v128.ge\";\n export const v128_convert = \"~lib/builtins/v128.convert\";\n export const v128_trunc = \"~lib/builtins/v128.trunc\";\n\n export const i8x16 = \"~lib/builtins/i8x16\";\n export const i16x8 = \"~lib/builtins/i16x8\";\n export const i32x4 = \"~lib/builtins/i32x4\";\n export const i64x2 = \"~lib/builtins/i64x2\";\n export const f32x4 = \"~lib/builtins/f32x4\";\n export const f64x2 = \"~lib/builtins/f64x2\";\n\n export const i8x16_splat = \"~lib/builtins/i8x16.splat\";\n export const i8x16_extract_lane_s = \"~lib/builtins/i8x16.extract_lane_s\";\n export const i8x16_extract_lane_u = \"~lib/builtins/i8x16.extract_lane_u\";\n export const i8x16_replace_lane = \"~lib/builtins/i8x16.replace_lane\";\n export const i8x16_add = \"~lib/builtins/i8x16.add\";\n export const i8x16_sub = \"~lib/builtins/i8x16.sub\";\n export const i8x16_mul = \"~lib/builtins/i8x16.mul\";\n export const i8x16_neg = \"~lib/builtins/i8x16.neg\";\n export const i8x16_add_saturate_s = \"~lib/builtins/i8x16.add_saturate_s\";\n export const i8x16_add_saturate_u = \"~lib/builtins/i8x16.add_saturate_u\";\n export const i8x16_sub_saturate_s = \"~lib/builtins/i8x16.sub_saturate_s\";\n export const i8x16_sub_saturate_u = \"~lib/builtins/i8x16.sub_saturate_u\";\n export const i8x16_shl = \"~lib/builtins/i8x16.shl\";\n export const i8x16_shr_s = \"~lib/builtins/i8x16.shr_s\";\n export const i8x16_shr_u = \"~lib/builtins/i8x16.shr_u\";\n export const i8x16_any_true = \"~lib/builtins/i8x16.any_true\";\n export const i8x16_all_true = \"~lib/builtins/i8x16.all_true\";\n export const i8x16_eq = \"~lib/builtins/i8x16.eq\";\n export const i8x16_ne = \"~lib/builtins/i8x16.ne\";\n export const i8x16_lt_s = \"~lib/builtins/i8x16.lt_s\";\n export const i8x16_lt_u = \"~lib/builtins/i8x16.lt_u\";\n export const i8x16_le_s = \"~lib/builtins/i8x16.le_s\";\n export const i8x16_le_u = \"~lib/builtins/i8x16.le_u\";\n export const i8x16_gt_s = \"~lib/builtins/i8x16.gt_s\";\n export const i8x16_gt_u = \"~lib/builtins/i8x16.gt_u\";\n export const i8x16_ge_s = \"~lib/builtins/i8x16.ge_s\";\n export const i8x16_ge_u = \"~lib/builtins/i8x16.ge_u\";\n\n export const i16x8_splat = \"~lib/builtins/i16x8.splat\";\n export const i16x8_extract_lane_s = \"~lib/builtins/i16x8.extract_lane_s\";\n export const i16x8_extract_lane_u = \"~lib/builtins/i16x8.extract_lane_u\";\n export const i16x8_replace_lane = \"~lib/builtins/i16x8.replace_lane\";\n export const i16x8_add = \"~lib/builtins/i16x8.add\";\n export const i16x8_sub = \"~lib/builtins/i16x8.sub\";\n export const i16x8_mul = \"~lib/builtins/i16x8.mul\";\n export const i16x8_neg = \"~lib/builtins/i16x8.neg\";\n export const i16x8_add_saturate_s = \"~lib/builtins/i16x8.add_saturate_s\";\n export const i16x8_add_saturate_u = \"~lib/builtins/i16x8.add_saturate_u\";\n export const i16x8_sub_saturate_s = \"~lib/builtins/i16x8.sub_saturate_s\";\n export const i16x8_sub_saturate_u = \"~lib/builtins/i16x8.sub_saturate_u\";\n export const i16x8_shl = \"~lib/builtins/i16x8.shl\";\n export const i16x8_shr_s = \"~lib/builtins/i16x8.shr_s\";\n export const i16x8_shr_u = \"~lib/builtins/i16x8.shr_u\";\n export const i16x8_any_true = \"~lib/builtins/i16x8.any_true\";\n export const i16x8_all_true = \"~lib/builtins/i16x8.all_true\";\n export const i16x8_eq = \"~lib/builtins/i16x8.eq\";\n export const i16x8_ne = \"~lib/builtins/i16x8.ne\";\n export const i16x8_lt_s = \"~lib/builtins/i16x8.lt_s\";\n export const i16x8_lt_u = \"~lib/builtins/i16x8.lt_u\";\n export const i16x8_le_s = \"~lib/builtins/i16x8.le_s\";\n export const i16x8_le_u = \"~lib/builtins/i16x8.le_u\";\n export const i16x8_gt_s = \"~lib/builtins/i16x8.gt_s\";\n export const i16x8_gt_u = \"~lib/builtins/i16x8.gt_u\";\n export const i16x8_ge_s = \"~lib/builtins/i16x8.ge_s\";\n export const i16x8_ge_u = \"~lib/builtins/i16x8.ge_u\";\n\n export const i32x4_splat = \"~lib/builtins/i32x4.splat\";\n export const i32x4_extract_lane = \"~lib/builtins/i32x4.extract_lane\";\n export const i32x4_replace_lane = \"~lib/builtins/i32x4.replace_lane\";\n export const i32x4_add = \"~lib/builtins/i32x4.add\";\n export const i32x4_sub = \"~lib/builtins/i32x4.sub\";\n export const i32x4_mul = \"~lib/builtins/i32x4.mul\";\n export const i32x4_neg = \"~lib/builtins/i32x4.neg\";\n export const i32x4_shl = \"~lib/builtins/i32x4.shl\";\n export const i32x4_shr_s = \"~lib/builtins/i32x4.shr_s\";\n export const i32x4_shr_u = \"~lib/builtins/i32x4.shr_u\";\n export const i32x4_any_true = \"~lib/builtins/i32x4.any_true\";\n export const i32x4_all_true = \"~lib/builtins/i32x4.all_true\";\n export const i32x4_eq = \"~lib/builtins/i32x4.eq\";\n export const i32x4_ne = \"~lib/builtins/i32x4.ne\";\n export const i32x4_lt_s = \"~lib/builtins/i32x4.lt_s\";\n export const i32x4_lt_u = \"~lib/builtins/i32x4.lt_u\";\n export const i32x4_le_s = \"~lib/builtins/i32x4.le_s\";\n export const i32x4_le_u = \"~lib/builtins/i32x4.le_u\";\n export const i32x4_gt_s = \"~lib/builtins/i32x4.gt_s\";\n export const i32x4_gt_u = \"~lib/builtins/i32x4.gt_u\";\n export const i32x4_ge_s = \"~lib/builtins/i32x4.ge_s\";\n export const i32x4_ge_u = \"~lib/builtins/i32x4.ge_u\";\n export const i32x4_trunc_s_f32x4_sat = \"~lib/builtins/i32x4.trunc_s_f32x4_sat\";\n export const i32x4_trunc_u_f32x4_sat = \"~lib/builtins/i32x4.trunc_u_f32x4_sat\";\n\n export const i64x2_splat = \"~lib/builtins/i64x2.splat\";\n export const i64x2_extract_lane = \"~lib/builtins/i64x2.extract_lane\";\n export const i64x2_replace_lane = \"~lib/builtins/i64x2.replace_lane\";\n export const i64x2_add = \"~lib/builtins/i64x2.add\";\n export const i64x2_sub = \"~lib/builtins/i64x2.sub\"; // i64x2 has no .mul\n export const i64x2_neg = \"~lib/builtins/i64x2.neg\";\n export const i64x2_shl = \"~lib/builtins/i64x2.shl\";\n export const i64x2_shr_s = \"~lib/builtins/i64x2.shr_s\";\n export const i64x2_shr_u = \"~lib/builtins/i64x2.shr_u\";\n export const i64x2_any_true = \"~lib/builtins/i64x2.any_true\";\n export const i64x2_all_true = \"~lib/builtins/i64x2.all_true\"; // i64x2 has no .eq etc.\n export const i64x2_trunc_s_f64x2_sat = \"~lib/builtins/i64x2.trunc_s_f64x2_sat\";\n export const i64x2_trunc_u_f64x2_sat = \"~lib/builtins/i64x2.trunc_u_f64x2_sat\";\n\n export const f32x4_splat = \"~lib/builtins/f32x4.splat\";\n export const f32x4_extract_lane = \"~lib/builtins/f32x4.extract_lane\";\n export const f32x4_replace_lane = \"~lib/builtins/f32x4.replace_lane\";\n export const f32x4_add = \"~lib/builtins/f32x4.add\";\n export const f32x4_sub = \"~lib/builtins/f32x4.sub\";\n export const f32x4_mul = \"~lib/builtins/f32x4.mul\";\n export const f32x4_div = \"~lib/builtins/f32x4.div\";\n export const f32x4_neg = \"~lib/builtins/f32x4.neg\";\n export const f32x4_min = \"~lib/builtins/f32x4.min\";\n export const f32x4_max = \"~lib/builtins/f32x4.max\";\n export const f32x4_abs = \"~lib/builtins/f32x4.abs\";\n export const f32x4_sqrt = \"~lib/builtins/f32x4.sqrt\";\n export const f32x4_eq = \"~lib/builtins/f32x4.eq\";\n export const f32x4_ne = \"~lib/builtins/f32x4.ne\";\n export const f32x4_lt = \"~lib/builtins/f32x4.lt\";\n export const f32x4_le = \"~lib/builtins/f32x4.le\";\n export const f32x4_gt = \"~lib/builtins/f32x4.gt\";\n export const f32x4_ge = \"~lib/builtins/f32x4.ge\";\n export const f32x4_convert_s_i32x4 = \"~lib/builtins/f32x4.convert_s_i32x4\";\n export const f32x4_convert_u_i32x4 = \"~lib/builtins/f32x4.convert_u_i32x4\";\n\n export const f64x2_splat = \"~lib/builtins/f64x2.splat\";\n export const f64x2_extract_lane = \"~lib/builtins/f64x2.extract_lane\";\n export const f64x2_replace_lane = \"~lib/builtins/f64x2.replace_lane\";\n export const f64x2_add = \"~lib/builtins/f64x2.add\";\n export const f64x2_sub = \"~lib/builtins/f64x2.sub\";\n export const f64x2_mul = \"~lib/builtins/f64x2.mul\";\n export const f64x2_div = \"~lib/builtins/f64x2.div\";\n export const f64x2_neg = \"~lib/builtins/f64x2.neg\";\n export const f64x2_min = \"~lib/builtins/f64x2.min\";\n export const f64x2_max = \"~lib/builtins/f64x2.max\";\n export const f64x2_abs = \"~lib/builtins/f64x2.abs\";\n export const f64x2_sqrt = \"~lib/builtins/f64x2.sqrt\";\n export const f64x2_eq = \"~lib/builtins/f64x2.eq\";\n export const f64x2_ne = \"~lib/builtins/f64x2.ne\";\n export const f64x2_lt = \"~lib/builtins/f64x2.lt\";\n export const f64x2_le = \"~lib/builtins/f64x2.le\";\n export const f64x2_gt = \"~lib/builtins/f64x2.gt\";\n export const f64x2_ge = \"~lib/builtins/f64x2.ge\";\n export const f64x2_convert_s_i64x2 = \"~lib/builtins/f64x2.convert_s_i64x2\";\n export const f64x2_convert_u_i64x2 = \"~lib/builtins/f64x2.convert_u_i64x2\";\n\n export const v8x16_shuffle = \"~lib/builtins/v8x16.shuffle\";\n\n // internals\n export const heap_base = \"~lib/heap/__heap_base\";\n export const rtti_base = \"~lib/rt/__rtti_base\";\n export const visit_globals = \"~lib/rt/__visit_globals\";\n export const visit_members = \"~lib/rt/__visit_members\";\n\n // std/diagnostics.ts\n export const ERROR = \"~lib/diagnostics/ERROR\";\n export const WARNING = \"~lib/diagnostics/WARNING\";\n export const INFO = \"~lib/diagnostics/INFO\";\n\n // std/memory.ts\n export const memory_size = \"~lib/memory/memory.size\";\n export const memory_grow = \"~lib/memory/memory.grow\";\n export const memory_copy = \"~lib/memory/memory.copy\";\n export const memory_fill = \"~lib/memory/memory.fill\";\n export const memory_allocate = \"~lib/memory/memory.allocate\";\n export const memory_free = \"~lib/memory/memory.free\";\n export const memory_reset = \"~lib/memory/memory.reset\";\n\n // std/runtime.ts\n export const runtime_instanceof = \"~lib/runtime/runtime.instanceof\";\n export const runtime_flags = \"~lib/runtime/runtime.flags\";\n export const runtime_allocate = \"~lib/util/runtime/allocate\";\n export const runtime_reallocate = \"~lib/util/runtime/reallocate\";\n export const runtime_register = \"~lib/util/runtime/register\";\n export const runtime_discard = \"~lib/util/runtime/discard\";\n export const runtime_makeArray = \"~lib/util/runtime/makeArray\";\n\n // std/typedarray.ts\n export const Int8Array = \"~lib/typedarray/Int8Array\";\n export const Uint8Array = \"~lib/typedarray/Uint8Array\";\n export const Int16Array = \"~lib/typedarray/Int16Array\";\n export const Uint16Array = \"~lib/typedarray/Uint16Array\";\n export const Int32Array = \"~lib/typedarray/Int32Array\";\n export const Uint32Array = \"~lib/typedarray/Uint32Array\";\n export const Int64Array = \"~lib/typedarray/Int64Array\";\n export const Uint64Array = \"~lib/typedarray/Uint64Array\";\n export const Uint8ClampedArray = \"~lib/typedarray/Uint8ClampedArray\";\n export const Float32Array = \"~lib/typedarray/Float32Array\";\n export const Float64Array = \"~lib/typedarray/Float64Array\";\n\n // compiler generated\n export const started = \"~lib/started\";\n export const argc = \"~lib/argc\";\n export const setargc = \"~lib/setargc\";\n export const capabilities = \"~lib/capabilities\";\n}\n\n/** Compiles a call to a built-in function. */\nexport function compileCall(\n /* Compiler reference. */\n compiler: Compiler,\n /** Respective function prototype. */\n prototype: FunctionPrototype,\n /** Pre-resolved type arguments. */\n typeArguments: Type[] | null,\n /** Operand expressions. */\n operands: Expression[],\n /** Contextual type. */\n contextualType: Type,\n /** Respective call expression. */\n reportNode: CallExpression,\n /** Indicates that contextual type is ASM type. */\n isAsm: bool = false\n): ExpressionRef {\n var module = compiler.module;\n\n // NOTE that some implementations below make use of the select expression where straight-forward.\n // whether worth or not should probably be tested once it's known if/how embedders handle it.\n // search: createSelect\n\n // NOTE that consolidation of individual instructions into a single case isn't exactly scientific\n // below, but rather done to make this file easier to work with. If there was a general rule it'd\n // most likely be \"three or more instructions that only differ in their actual opcode\".\n\n var directize = false;\n\n switch (prototype.internalName) {\n\n // === Static type evaluation =================================================================\n\n case BuiltinSymbols.isInteger: { // isInteger() / isInteger(value: T) -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n return type.is(TypeFlags.INTEGER) && !type.is(TypeFlags.REFERENCE)\n ? module.i32(1)\n : module.i32(0);\n }\n case BuiltinSymbols.isFloat: { // isFloat() / isFloat(value: T) -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n return type.is(TypeFlags.FLOAT)\n ? module.i32(1)\n : module.i32(0);\n }\n case BuiltinSymbols.isBoolean: { // isBoolean() / isBoolean(value: T) -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n return type == Type.bool\n ? module.i32(1)\n : module.i32(0);\n }\n case BuiltinSymbols.isSigned: { // isSigned() / isSigned(value: T) -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n return type.is(TypeFlags.SIGNED)\n ? module.i32(1)\n : module.i32(0);\n }\n case BuiltinSymbols.isReference: { // isReference() / isReference(value: T) -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n return type.is(TypeFlags.REFERENCE)\n ? module.i32(1)\n : module.i32(0);\n }\n case BuiltinSymbols.isString: { // isString() / isString(value: T) -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n let classType = type.classReference;\n if (classType) {\n let stringInstance = compiler.program.stringInstance;\n if (stringInstance && classType.isAssignableTo(stringInstance)) return module.i32(1);\n }\n return module.i32(0);\n }\n case BuiltinSymbols.isArray: { // isArray() / isArray(value: T) -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n let classReference = type.classReference;\n if (!classReference) return module.i32(0);\n let classPrototype = classReference.prototype;\n return module.i32(classPrototype.extends(compiler.program.arrayPrototype) ? 1 : 0);\n }\n case BuiltinSymbols.isArrayLike: { // isArrayLike() / isArrayLike(value: T) -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n let classReference = type.classReference;\n if (!classReference) return module.i32(0);\n return module.i32(classReference.isArrayLike ? 1 : 0);\n }\n case BuiltinSymbols.isFunction: { // isFunction / isFunction(value: T) -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n return module.i32(type.signatureReference ? 1 : 0);\n }\n case BuiltinSymbols.isNullable: { // isNullable / isNullable(value: T) -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n return module.i32(type.is(TypeFlags.NULLABLE) ? 1 : 0);\n }\n case BuiltinSymbols.isDefined: { // isDefined(expression) -> bool\n compiler.currentType = Type.bool;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let element = compiler.resolver.resolveExpression(\n operands[0],\n compiler.currentFlow,\n Type.void,\n ReportMode.SWALLOW\n );\n return module.i32(element ? 1 : 0);\n }\n case BuiltinSymbols.isConstant: { // isConstant(expression) -> bool\n compiler.currentType = Type.bool;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let expr = compiler.compileExpression(operands[0], Type.auto);\n compiler.currentType = Type.bool;\n return module.i32(getExpressionId(expr) == ExpressionId.Const ? 1 : 0);\n }\n case BuiltinSymbols.isManaged: { // isManaged() -> bool\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.bool;\n if (!type) return module.unreachable();\n return module.i32(type.isManaged ? 1 : 0);\n }\n case BuiltinSymbols.sizeof: { // sizeof() -> usize\n compiler.currentType = compiler.options.usizeType;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsRequired(operands, 0, reportNode, compiler)\n ) return module.unreachable();\n let byteSize = (typeArguments)[0].byteSize;\n let expr: ExpressionRef;\n if (compiler.options.isWasm64) {\n // implicitly wrap if contextual type is a 32-bit integer\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size <= 32) {\n compiler.currentType = Type.u32;\n expr = module.i32(byteSize);\n } else {\n expr = module.i64(byteSize, 0);\n }\n } else {\n // implicitly extend if contextual type is a 64-bit integer\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size == 64) {\n compiler.currentType = Type.u64;\n expr = module.i64(byteSize, 0);\n } else {\n expr = module.i32(byteSize);\n }\n }\n return expr;\n }\n case BuiltinSymbols.alignof: { // alignof() -> usize\n compiler.currentType = compiler.options.usizeType;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsRequired(operands, 0, reportNode, compiler)\n ) return module.unreachable();\n let byteSize = (typeArguments)[0].byteSize;\n assert(isPowerOf2(byteSize));\n let alignLog2 = ctz(byteSize);\n let expr: ExpressionRef;\n if (compiler.options.isWasm64) {\n // implicitly wrap if contextual type is a 32-bit integer\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size <= 32) {\n compiler.currentType = Type.u32;\n expr = module.i32(alignLog2);\n } else {\n expr = module.i64(alignLog2, 0);\n }\n } else {\n // implicitly extend if contextual type is a 64-bit integer\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size == 64) {\n compiler.currentType = Type.u64;\n expr = module.i64(alignLog2, 0);\n } else {\n expr = module.i32(alignLog2);\n }\n }\n return expr;\n }\n case BuiltinSymbols.offsetof: { // offsetof(fieldName?: string) -> usize\n compiler.currentType = compiler.options.usizeType;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsOptional(operands, 0, 1, reportNode, compiler)\n ) return module.unreachable();\n let classType = typeArguments![0].classReference;\n if (!classType) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let offset: i32;\n if (operands.length) {\n if (\n operands[0].kind != NodeKind.LITERAL ||\n (operands[0]).literalKind != LiteralKind.STRING\n ) {\n compiler.error(\n DiagnosticCode.String_literal_expected,\n operands[0].range\n );\n return module.unreachable();\n }\n let fieldName = (operands[0]).value;\n let field = classType.members ? classType.members.get(fieldName) : null;\n if (!(field && field.kind == ElementKind.FIELD)) {\n compiler.error(\n DiagnosticCode.Type_0_has_no_property_1,\n operands[0].range, classType.internalName, fieldName\n );\n return module.unreachable();\n }\n offset = (field).memoryOffset;\n } else {\n offset = classType.currentMemoryOffset;\n }\n if (compiler.options.isWasm64) {\n // implicitly wrap if contextual type is a 32-bit integer\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size <= 32) {\n compiler.currentType = Type.u32;\n return module.i32(offset);\n } else {\n return module.i64(offset);\n }\n } else {\n // implicitly extend if contextual type is a 64-bit integer\n if (contextualType.is(TypeFlags.INTEGER) && contextualType.size == 64) {\n compiler.currentType = Type.u64;\n return module.i64(offset);\n } else {\n return module.i32(offset);\n }\n }\n }\n\n // === Math ===================================================================================\n\n case BuiltinSymbols.clz: // any_bitcount(value: T) -> T\n case BuiltinSymbols.ctz:\n case BuiltinSymbols.popcnt: {\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\n : compiler.compileExpression(operands[0], Type.i32, Constraints.MUST_WRAP);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let op: UnaryOp = -1;\n switch (prototype.internalName) {\n case BuiltinSymbols.clz: {\n switch (type.kind) {\n case TypeKind.BOOL:\n case TypeKind.I8:\n case TypeKind.U8:\n case TypeKind.I16:\n case TypeKind.U16:\n case TypeKind.I32:\n case TypeKind.U32: { op = UnaryOp.ClzI32; break; }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n op = compiler.options.isWasm64\n ? UnaryOp.ClzI64\n : UnaryOp.ClzI32;\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: { op = UnaryOp.ClzI64; break; }\n }\n break;\n }\n case BuiltinSymbols.ctz: {\n switch (type.kind) {\n case TypeKind.BOOL:\n case TypeKind.I8:\n case TypeKind.U8:\n case TypeKind.I16:\n case TypeKind.U16:\n case TypeKind.I32:\n case TypeKind.U32: { op = UnaryOp.CtzI32; break; }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n op = compiler.options.isWasm64\n ? UnaryOp.CtzI64\n : UnaryOp.CtzI32;\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: { op = UnaryOp.CtzI64; break; }\n }\n break;\n }\n case BuiltinSymbols.popcnt: {\n switch (compiler.currentType.kind) {\n case TypeKind.BOOL:\n case TypeKind.I8:\n case TypeKind.U8:\n case TypeKind.I16:\n case TypeKind.U16:\n case TypeKind.I32:\n case TypeKind.U32: { op = UnaryOp.PopcntI32; break; }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n op = compiler.options.isWasm64\n ? UnaryOp.PopcntI64\n : UnaryOp.PopcntI32;\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: { op = UnaryOp.PopcntI64; break; }\n }\n break;\n }\n }\n if (op == -1) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n return module.unary(op, arg0);\n }\n case BuiltinSymbols.rotl: { // rotl(value: T, shift: T) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\n : compiler.compileExpression(operands[0], Type.i32, Constraints.MUST_WRAP);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT);\n let expr: ExpressionRef;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL: {\n expr = compiler.ensureSmallIntegerWrap(\n module.binary(BinaryOp.RotlI32, arg0, arg1),\n type\n );\n // fall-through\n }\n case TypeKind.I32:\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.RotlI32, arg0, arg1);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n compiler.options.isWasm64\n ? BinaryOp.RotlI64\n : BinaryOp.RotlI32,\n arg0, arg1\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.RotlI64, arg0, arg1);\n break;\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n expr = module.unreachable();\n break;\n }\n }\n return expr; // possibly overflows\n }\n case BuiltinSymbols.rotr: { // rotr(value: T, shift: T) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\n : compiler.compileExpression(operands[0], Type.i32, Constraints.MUST_WRAP);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT);\n let expr: ExpressionRef;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.BOOL: {\n expr = compiler.ensureSmallIntegerWrap(\n module.binary(BinaryOp.RotrI32, arg0, arg1),\n type\n );\n break;\n }\n case TypeKind.I32:\n case TypeKind.U32: {\n expr = module.binary(BinaryOp.RotrI32, arg0, arg1);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.ISIZE: {\n expr = module.binary(\n compiler.options.isWasm64\n ? BinaryOp.RotrI64\n : BinaryOp.RotrI32,\n arg0, arg1\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.binary(BinaryOp.RotrI64, arg0, arg1);\n break;\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n expr = module.unreachable();\n break;\n }\n }\n return expr; // possibly overflowws\n }\n case BuiltinSymbols.abs: { // abs(value: T) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\n : compiler.compileExpression(operands[0], Type.f64, Constraints.MUST_WRAP);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let expr: ExpressionRef;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32: {\n let flow = compiler.currentFlow;\n\n // possibly overflows, e.g. abs(-128) == 128\n let tempLocal1 = flow.getTempLocal(Type.i32);\n let tempLocalIndex2 = flow.getAndFreeTempLocal(Type.i32).index;\n let tempLocalIndex1 = tempLocal1.index;\n\n // (x + (x >> 31)) ^ (x >> 31)\n expr = module.binary(BinaryOp.XorI32,\n module.binary(BinaryOp.AddI32,\n module.local_tee(\n tempLocalIndex2,\n module.binary(BinaryOp.ShrI32,\n module.local_tee(tempLocalIndex1, arg0),\n module.i32(31)\n )\n ),\n module.local_get(tempLocalIndex1, NativeType.I32)\n ),\n module.local_get(tempLocalIndex2, NativeType.I32)\n );\n\n flow.freeTempLocal(tempLocal1);\n break;\n }\n case TypeKind.ISIZE: {\n let options = compiler.options;\n let flow = compiler.currentFlow;\n let wasm64 = options.isWasm64;\n\n let tempLocal1 = flow.getTempLocal(options.usizeType);\n let tempLocalIndex2 = flow.getAndFreeTempLocal(options.usizeType).index;\n let tempLocalIndex1 = tempLocal1.index;\n\n expr = module.binary(wasm64 ? BinaryOp.XorI64 : BinaryOp.XorI32,\n module.binary(wasm64 ? BinaryOp.AddI64 : BinaryOp.AddI32,\n module.local_tee(\n tempLocalIndex2,\n module.binary(wasm64 ? BinaryOp.ShrI64 : BinaryOp.ShrI32,\n module.local_tee(tempLocalIndex1, arg0),\n wasm64 ? module.i64(63) : module.i32(31)\n )\n ),\n module.local_get(tempLocalIndex1, options.nativeSizeType)\n ),\n module.local_get(tempLocalIndex2, options.nativeSizeType)\n );\n\n flow.freeTempLocal(tempLocal1);\n break;\n }\n case TypeKind.I64: {\n let flow = compiler.currentFlow;\n\n let tempLocal1 = flow.getTempLocal(Type.i64);\n let tempLocalIndex2 = flow.getAndFreeTempLocal(Type.i64).index;\n let tempLocalIndex1 = tempLocal1.index;\n\n // (x + (x >> 63)) ^ (x >> 63)\n expr = module.binary(BinaryOp.XorI64,\n module.binary(BinaryOp.AddI64,\n module.local_tee(\n tempLocalIndex2,\n module.binary(BinaryOp.ShrI64,\n module.local_tee(tempLocalIndex1, arg0),\n module.i64(63)\n )\n ),\n module.local_get(tempLocalIndex1, NativeType.I64)\n ),\n module.local_get(tempLocalIndex2, NativeType.I64)\n );\n\n flow.freeTempLocal(tempLocal1);\n break;\n }\n case TypeKind.USIZE:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.U64:\n case TypeKind.BOOL: {\n expr = arg0;\n break;\n }\n case TypeKind.F32: {\n expr = module.unary(UnaryOp.AbsF32, arg0);\n break;\n }\n case TypeKind.F64: {\n expr = module.unary(UnaryOp.AbsF64, arg0);\n break;\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n expr = module.unreachable();\n break;\n }\n }\n return expr;\n }\n case BuiltinSymbols.max: { // max(left: T, right: T) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\n : compiler.compileExpression(operands[0], Type.f64, Constraints.MUST_WRAP);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP);\n let op: BinaryOp;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32: { op = BinaryOp.GtI32; break; }\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: { op = BinaryOp.GtU32; break; }\n case TypeKind.I64: { op = BinaryOp.GtI64; break; }\n case TypeKind.U64: { op = BinaryOp.GtU64; break; }\n case TypeKind.ISIZE: {\n op = compiler.options.isWasm64\n ? BinaryOp.GtI64\n : BinaryOp.GtI32;\n break;\n }\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? BinaryOp.GtU64\n : BinaryOp.GtU32;\n break;\n }\n case TypeKind.F32: {\n return module.binary(BinaryOp.MaxF32, arg0, arg1);\n }\n case TypeKind.F64: {\n return module.binary(BinaryOp.MaxF64, arg0, arg1);\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n }\n let flow = compiler.currentFlow;\n let nativeType = type.toNativeType();\n let tempLocal0 = flow.getTempLocal(type);\n flow.setLocalFlag(tempLocal0.index, LocalFlags.WRAPPED);\n let tempLocal1 = flow.getAndFreeTempLocal(type);\n flow.setLocalFlag(tempLocal1.index, LocalFlags.WRAPPED);\n flow.freeTempLocal(tempLocal0);\n return module.select(\n module.local_tee(tempLocal0.index, arg0),\n module.local_tee(tempLocal1.index, arg1),\n module.binary(op,\n module.local_get(tempLocal0.index, nativeType),\n module.local_get(tempLocal1.index, nativeType)\n )\n );\n }\n case BuiltinSymbols.min: { // min(left: T, right: T) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\n : compiler.compileExpression(operands[0], Type.f64, Constraints.MUST_WRAP);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP);\n let op: BinaryOp;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32: { op = BinaryOp.LtI32; break; }\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: { op = BinaryOp.LtU32; break; }\n case TypeKind.I64: { op = BinaryOp.LtI64; break; }\n case TypeKind.U64: { op = BinaryOp.LtU64; break; }\n case TypeKind.ISIZE: {\n op = compiler.options.isWasm64\n ? BinaryOp.LtI64\n : BinaryOp.LtI32;\n break;\n }\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? BinaryOp.LtU64\n : BinaryOp.LtU32;\n break;\n }\n case TypeKind.F32: {\n return module.binary(BinaryOp.MinF32, arg0, arg1);\n }\n case TypeKind.F64: {\n return module.binary(BinaryOp.MinF64, arg0, arg1);\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n }\n let flow = compiler.currentFlow;\n let nativeType = type.toNativeType();\n let tempLocal0 = flow.getTempLocal(type);\n flow.setLocalFlag(tempLocal0.index, LocalFlags.WRAPPED);\n let tempLocal1 = flow.getAndFreeTempLocal(type);\n flow.setLocalFlag(tempLocal1.index, LocalFlags.WRAPPED);\n flow.freeTempLocal(tempLocal0);\n return module.select(\n module.local_tee(tempLocal0.index, arg0),\n module.local_tee(tempLocal1.index, arg1),\n module.binary(op,\n module.local_get(tempLocal0.index, nativeType),\n module.local_get(tempLocal1.index, nativeType)\n )\n );\n }\n case BuiltinSymbols.ceil: // any_rounding(value: T) -> T\n case BuiltinSymbols.floor: {\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\n : compiler.compileExpression(operands[0], Type.f64, Constraints.NONE);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let op: UnaryOp;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.I64:\n case TypeKind.ISIZE:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.U64:\n case TypeKind.USIZE:\n case TypeKind.BOOL: return arg0; // considered rounded\n case TypeKind.F32: {\n op = prototype.internalName == BuiltinSymbols.ceil\n ? UnaryOp.CeilF32\n : UnaryOp.FloorF32;\n break;\n }\n case TypeKind.F64: {\n op = prototype.internalName == BuiltinSymbols.ceil\n ? UnaryOp.CeilF64\n : UnaryOp.FloorF64;\n break;\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n }\n return module.unary(op, arg0);\n }\n case BuiltinSymbols.copysign: { // copysign(left: T, right: T) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\n : compiler.compileExpression(operands[0], Type.f64, Constraints.NONE);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT);\n let op: BinaryOp;\n switch (type.kind) {\n // TODO: does an integer version make sense?\n case TypeKind.F32: { op = BinaryOp.CopysignF32; break; }\n case TypeKind.F64: { op = BinaryOp.CopysignF64; break; }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n }\n return module.binary(op, arg0, arg1);\n }\n case BuiltinSymbols.nearest: { // nearest(value: T) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\n : compiler.compileExpression(operands[0], Type.f64, Constraints.NONE);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let expr: ExpressionRef;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.I64:\n case TypeKind.ISIZE:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.U64:\n case TypeKind.USIZE:\n case TypeKind.BOOL: {\n expr = arg0;\n break;\n }\n case TypeKind.F32: {\n expr = module.unary(UnaryOp.NearestF32, arg0);\n break;\n }\n case TypeKind.F64: {\n expr = module.unary(UnaryOp.NearestF64, arg0);\n break;\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n expr = module.unreachable();\n break;\n }\n }\n return expr;\n }\n case BuiltinSymbols.reinterpret: { // reinterpret(value: *) -> T\n if (\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let type = typeArguments![0];\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.currentType = type;\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let expr: ExpressionRef;\n switch (type.kind) {\n case TypeKind.I32:\n case TypeKind.U32: {\n let arg0 = compiler.compileExpression(operands[0], Type.f32, Constraints.CONV_IMPLICIT);\n expr = module.unary(UnaryOp.ReinterpretF32, arg0);\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n let arg0 = compiler.compileExpression(operands[0], Type.f64, Constraints.CONV_IMPLICIT);\n expr = module.unary(UnaryOp.ReinterpretF64, arg0);\n break;\n }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n let arg0 = compiler.compileExpression(operands[0],\n compiler.options.isWasm64\n ? Type.f64\n : Type.f32,\n Constraints.CONV_IMPLICIT\n );\n expr = module.unary(\n compiler.options.isWasm64\n ? UnaryOp.ReinterpretF64\n : UnaryOp.ReinterpretF32,\n arg0\n );\n break;\n }\n case TypeKind.F32: {\n let arg0 = compiler.compileExpression(operands[0], Type.i32, Constraints.CONV_IMPLICIT);\n expr = module.unary(UnaryOp.ReinterpretI32, arg0);\n break;\n }\n case TypeKind.F64: {\n let arg0 = compiler.compileExpression(operands[0], Type.i64, Constraints.CONV_IMPLICIT);\n expr = module.unary(UnaryOp.ReinterpretI64, arg0);\n break;\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n expr = module.unreachable();\n break;\n }\n }\n compiler.currentType = type;\n return expr;\n }\n case BuiltinSymbols.sqrt: { // sqrt(value: T) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\n : compiler.compileExpression(operands[0], Type.f64, Constraints.NONE);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.currentType = type;\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let expr: ExpressionRef;\n switch (type.kind) { // TODO: integer versions (that return f64 or convert)?\n case TypeKind.F32: {\n expr = module.unary(UnaryOp.SqrtF32, arg0);\n break;\n }\n case TypeKind.F64: {\n expr = module.unary(UnaryOp.SqrtF64, arg0);\n break;\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n expr = module.unreachable();\n break;\n }\n }\n return expr;\n }\n case BuiltinSymbols.trunc: { // trunc(value: T) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\n : compiler.compileExpression(operands[0], Type.f64, Constraints.NONE);\n let type = compiler.currentType;\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.range\n );\n return module.unreachable();\n }\n let expr: ExpressionRef;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.I64:\n case TypeKind.ISIZE:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.U64:\n case TypeKind.USIZE:\n case TypeKind.BOOL: {\n expr = arg0;\n break;\n }\n // TODO: truncate to contextual type directly (if not void etc.)?\n case TypeKind.F32: {\n expr = module.unary(UnaryOp.TruncF32, arg0);\n break;\n }\n case TypeKind.F64: {\n expr = module.unary(UnaryOp.TruncF64, arg0);\n break;\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n expr = module.unreachable();\n break;\n }\n }\n return expr;\n }\n\n // === Memory access ==========================================================================\n\n case BuiltinSymbols.load: { // load(offset: usize, immOffset?: usize, immAlign?: usize) -> T*\n if (\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\n checkArgsOptional(operands, 1, 3, reportNode, compiler)\n ) return module.unreachable();\n let type = typeArguments![0];\n let outType = (\n contextualType != Type.auto &&\n type.is(TypeFlags.INTEGER) &&\n contextualType.is(TypeFlags.INTEGER) &&\n contextualType.size > type.size\n ) ? contextualType : type;\n let arg0 = compiler.compileExpression(operands[0],\n compiler.options.usizeType,\n Constraints.CONV_IMPLICIT\n );\n let numOperands = operands.length;\n let immOffset = numOperands >= 2 ? evaluateImmediateOffset(operands[1], compiler) : 0; // reports\n if (immOffset < 0) {\n compiler.currentType = outType;\n return module.unreachable();\n }\n let immAlign: i32;\n let naturalAlign = type.byteSize;\n if (numOperands == 3) {\n immAlign = evaluateImmediateOffset(operands[2], compiler);\n if (immAlign < 0) {\n compiler.currentType = outType;\n return module.unreachable();\n }\n if (immAlign > naturalAlign) {\n compiler.error(\n DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,\n operands[2].range, \"Alignment\", \"0\", naturalAlign.toString()\n );\n compiler.currentType = outType;\n return module.unreachable();\n }\n if (!isPowerOf2(immAlign)) {\n compiler.error(\n DiagnosticCode._0_must_be_a_power_of_two,\n operands[2].range, \"Alignment\"\n );\n compiler.currentType = outType;\n return module.unreachable();\n }\n } else {\n immAlign = naturalAlign;\n }\n compiler.currentType = outType;\n return module.load(\n type.byteSize,\n type.is(TypeFlags.SIGNED | TypeFlags.INTEGER),\n arg0,\n outType.toNativeType(),\n immOffset,\n immAlign\n );\n }\n case BuiltinSymbols.store: { // store(offset: usize, value: T*, offset?: usize, align?: usize) -> void\n compiler.currentType = Type.void;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsOptional(operands, 2, 4, reportNode, compiler)\n ) return module.unreachable();\n let type = typeArguments![0];\n let arg0 = compiler.compileExpression(operands[0],\n compiler.options.usizeType,\n Constraints.CONV_IMPLICIT\n );\n let arg1 = isAsm\n ? compiler.compileExpression(operands[1],\n contextualType,\n Constraints.CONV_IMPLICIT\n )\n : compiler.compileExpression(\n operands[1],\n type,\n type.is(TypeFlags.INTEGER)\n ? Constraints.NONE // no need to convert to small int (but now might result in a float)\n : Constraints.CONV_IMPLICIT\n );\n let inType = compiler.currentType;\n if (\n type.is(TypeFlags.INTEGER) &&\n (\n !inType.is(TypeFlags.INTEGER) || // float to int\n inType.size < type.size // int to larger int (clear garbage bits)\n )\n ) {\n arg1 = compiler.convertExpression(arg1,\n inType, type,\n false, false, // still clears garbage bits when not wrapping\n operands[1]\n );\n inType = type;\n }\n let immOffset = operands.length >= 3 ? evaluateImmediateOffset(operands[2], compiler) : 0; // reports\n if (immOffset < 0) {\n compiler.currentType = Type.void;\n return module.unreachable();\n }\n let immAlign: i32;\n let naturalAlign = type.byteSize;\n if (operands.length == 4) {\n immAlign = evaluateImmediateOffset(operands[3], compiler);\n if (immAlign < 0) {\n compiler.currentType = Type.void;\n return module.unreachable();\n }\n if (immAlign > naturalAlign) {\n compiler.error(\n DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,\n operands[3].range, \"Alignment\", \"0\", naturalAlign.toString()\n );\n compiler.currentType = Type.void;\n return module.unreachable();\n }\n if (!isPowerOf2(immAlign)) {\n compiler.error(\n DiagnosticCode._0_must_be_a_power_of_two,\n operands[3].range, \"Alignment\"\n );\n compiler.currentType = Type.void;\n return module.unreachable();\n }\n } else {\n immAlign = naturalAlign;\n }\n compiler.currentType = Type.void;\n return module.store(type.byteSize, arg0, arg1, inType.toNativeType(), immOffset, immAlign);\n }\n\n // === Atomics ================================================================================\n\n case BuiltinSymbols.atomic_load: { // load(offset: usize, immOffset?: usize) -> T*\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\n checkArgsOptional(operands, 1, 2, reportNode, compiler)\n ) return module.unreachable();\n let type = typeArguments![0];\n let outType = (\n type.is(TypeFlags.INTEGER) &&\n contextualType.is(TypeFlags.INTEGER) &&\n contextualType.size > type.size\n ) ? contextualType : type;\n if (!type.is(TypeFlags.INTEGER)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = outType;\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0],\n compiler.options.usizeType,\n Constraints.CONV_IMPLICIT\n );\n let immOffset = operands.length == 2 ? evaluateImmediateOffset(operands[1], compiler) : 0; // reports\n if (immOffset < 0) {\n compiler.currentType = outType;\n return module.unreachable();\n }\n compiler.currentType = outType;\n return module.atomic_load(\n type.byteSize,\n arg0,\n outType.toNativeType(),\n immOffset\n );\n }\n case BuiltinSymbols.atomic_store: { // store(offset: usize, value: T*, immOffset?: usize) -> void\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\n compiler.currentType = Type.void;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsOptional(operands, 2, 3, reportNode, compiler)\n ) return module.unreachable();\n let type = typeArguments![0];\n if (!type.is(TypeFlags.INTEGER) || type.size < 8) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0],\n compiler.options.usizeType,\n Constraints.CONV_IMPLICIT\n );\n let arg1 = isAsm\n ? compiler.compileExpression(\n operands[1],\n contextualType,\n Constraints.CONV_IMPLICIT\n )\n : compiler.compileExpression(\n operands[1],\n type,\n type.is(TypeFlags.INTEGER)\n ? Constraints.NONE // no need to convert to small int (but now might result in a float)\n : Constraints.CONV_IMPLICIT\n );\n let inType = compiler.currentType;\n if (\n type.is(TypeFlags.INTEGER) &&\n (\n !inType.is(TypeFlags.INTEGER) || // float to int\n inType.size < type.size // int to larger int (clear garbage bits)\n )\n ) {\n arg1 = compiler.convertExpression(arg1,\n inType, type,\n false, false, // still clears garbage bits when not wrapping\n operands[1]\n );\n inType = type;\n }\n let immOffset = operands.length == 3 ? evaluateImmediateOffset(operands[2], compiler) : 0; // reports\n if (immOffset < 0) {\n compiler.currentType = Type.void;\n return module.unreachable();\n }\n compiler.currentType = Type.void;\n return module.atomic_store(type.byteSize, arg0, arg1, inType.toNativeType(), immOffset);\n }\n case BuiltinSymbols.atomic_add: // any_atomic_binary(ptr, value: T, immOffset?: usize) -> T\n case BuiltinSymbols.atomic_sub:\n case BuiltinSymbols.atomic_and:\n case BuiltinSymbols.atomic_or:\n case BuiltinSymbols.atomic_xor:\n case BuiltinSymbols.atomic_xchg: {\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\n checkArgsOptional(operands, 2, 3, reportNode, compiler)\n ) return module.unreachable();\n let type = typeArguments![0];\n if (!type.is(TypeFlags.INTEGER) || type.size < 8) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0],\n compiler.options.usizeType,\n Constraints.CONV_IMPLICIT\n );\n let arg1 = isAsm\n ? compiler.compileExpression(operands[1],\n contextualType,\n Constraints.CONV_IMPLICIT\n )\n : compiler.compileExpression(\n operands[1],\n type,\n type.is(TypeFlags.INTEGER)\n ? Constraints.NONE // no need to convert to small int (but now might result in a float)\n : Constraints.CONV_IMPLICIT\n );\n let inType = compiler.currentType;\n if (\n type.is(TypeFlags.INTEGER) &&\n (\n !inType.is(TypeFlags.INTEGER) || // float to int\n inType.size < type.size // int to larger int (clear garbage bits)\n )\n ) {\n arg1 = compiler.convertExpression(arg1,\n inType, type,\n false, false, // still clears garbage bits when not wrapping\n operands[1]\n );\n inType = type;\n }\n let immOffset = operands.length == 3 ? evaluateImmediateOffset(operands[2], compiler) : 0; // reports\n if (immOffset < 0) {\n compiler.currentType = inType;\n return module.unreachable();\n }\n let op: AtomicRMWOp;\n switch (prototype.internalName) {\n default: assert(false);\n case BuiltinSymbols.atomic_add: { op = AtomicRMWOp.Add; break; }\n case BuiltinSymbols.atomic_sub: { op = AtomicRMWOp.Sub; break; }\n case BuiltinSymbols.atomic_and: { op = AtomicRMWOp.And; break; }\n case BuiltinSymbols.atomic_or: { op = AtomicRMWOp.Or; break; }\n case BuiltinSymbols.atomic_xor: { op = AtomicRMWOp.Xor; break; }\n case BuiltinSymbols.atomic_xchg: { op = AtomicRMWOp.Xchg; break; }\n }\n compiler.currentType = inType;\n return module.atomic_rmw(\n op, type.byteSize, immOffset, arg0, arg1, inType.toNativeType()\n );\n }\n case BuiltinSymbols.atomic_cmpxchg: { // cmpxchg(ptr: usize, expected: T, replacement: T, off?: usize): T\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\n checkArgsOptional(operands, 3, 4, reportNode, compiler)\n ) return module.unreachable();\n let type = typeArguments![0];\n if (!type.is(TypeFlags.INTEGER) || type.size < 8) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0],\n compiler.options.usizeType,\n Constraints.CONV_IMPLICIT\n );\n let arg1 = isAsm\n ? compiler.compileExpression(operands[1],\n contextualType,\n Constraints.CONV_IMPLICIT\n )\n : compiler.compileExpression(\n operands[1],\n type,\n type.is(TypeFlags.INTEGER)\n ? Constraints.NONE // no need to convert to small int (but now might result in a float)\n : Constraints.CONV_IMPLICIT\n );\n let inType = compiler.currentType;\n let arg2 = compiler.compileExpression(operands[2],\n inType,\n Constraints.CONV_IMPLICIT\n );\n if (\n type.is(TypeFlags.INTEGER) &&\n (\n !inType.is(TypeFlags.INTEGER) || // float to int\n inType.size < type.size // int to larger int (clear garbage bits)\n )\n ) {\n arg1 = compiler.convertExpression(arg1,\n inType, type,\n false, false, // still clears garbage bits when not wrapping\n operands[1]\n );\n arg2 = compiler.convertExpression(arg2,\n inType, type,\n false, false, // still clears garbage bits when not wrapping\n operands[2]\n );\n inType = type;\n }\n let immOffset = operands.length == 4 ? evaluateImmediateOffset(operands[3], compiler) : 0; // reports\n if (immOffset < 0) {\n compiler.currentType = inType;\n return module.unreachable();\n }\n compiler.currentType = inType;\n return module.atomic_cmpxchg(\n type.byteSize, immOffset, arg0, arg1, arg2, inType.toNativeType()\n );\n }\n case BuiltinSymbols.atomic_wait: { // wait(ptr: usize, expected: T, timeout: i64): i32;\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\n compiler.currentType = Type.i32;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsRequired(operands, 3, reportNode, compiler)\n ) return module.unreachable();\n let type = typeArguments![0];\n if (!type.is(TypeFlags.INTEGER) || type.size < 32) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0],\n compiler.options.usizeType,\n Constraints.CONV_IMPLICIT\n );\n let arg1 = compiler.compileExpression(operands[1], type,\n Constraints.CONV_IMPLICIT\n );\n let arg2 = compiler.compileExpression(operands[2],\n Type.i64,\n Constraints.CONV_IMPLICIT\n );\n compiler.currentType = Type.i32;\n return module.atomic_wait(arg0, arg1, arg2, type.toNativeType());\n }\n case BuiltinSymbols.atomic_notify: { // notify(ptr: usize, count: i32): i32;\n if (!compiler.options.hasFeature(Feature.THREADS)) break;\n compiler.currentType = Type.i32;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = compiler.compileExpression(operands[0],\n compiler.options.usizeType,\n Constraints.CONV_IMPLICIT\n );\n let arg1 = compiler.compileExpression(operands[1],\n Type.i32,\n Constraints.CONV_IMPLICIT\n );\n compiler.currentType = Type.i32;\n return module.atomic_notify(arg0, arg1);\n }\n\n // === Control flow ===========================================================================\n\n case BuiltinSymbols.select: { // select(ifTrue: T, ifFalse: T, condition: bool) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 3, reportNode, compiler)\n ) return module.unreachable();\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT)\n : compiler.compileExpression(operands[0], Type.auto);\n let type = compiler.currentType;\n if (!type.isAny(TypeFlags.VALUE | TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let arg1 = compiler.compileExpression(operands[1], type, Constraints.CONV_IMPLICIT);\n let arg2 = compiler.makeIsTrueish(\n compiler.compileExpression(operands[2], Type.bool),\n compiler.currentType // ^\n );\n compiler.currentType = type;\n return module.select(arg0, arg1, arg2);\n }\n case BuiltinSymbols.unreachable: { // unreachable() -> *\n if (typeArguments) {\n compiler.error(\n DiagnosticCode.Type_0_is_not_generic,\n reportNode.typeArgumentsRange, prototype.internalName\n );\n }\n checkArgsRequired(operands, 0, reportNode, compiler);\n return module.unreachable();\n }\n\n // === Memory =================================================================================\n\n case BuiltinSymbols.memory_size: { // memory.size() -> i32\n compiler.currentType = Type.i32;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 0, reportNode, compiler)\n ) return module.unreachable();\n return module.host(HostOp.MemorySize);\n }\n case BuiltinSymbols.memory_grow: { // memory.grow(pages: i32) -> i32\n compiler.currentType = Type.i32;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n return module.host(HostOp.MemoryGrow, null, [\n compiler.compileExpression(operands[0], Type.i32, Constraints.CONV_IMPLICIT)\n ]);\n }\n case BuiltinSymbols.memory_copy: { // memory.copy(dest: usize, src: usize: n: usize) -> void\n compiler.currentType = Type.void;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 3, reportNode, compiler)\n ) return module.unreachable();\n if (!compiler.options.hasFeature(Feature.BULK_MEMORY)) {\n let instance = compiler.resolver.resolveFunction(prototype, null); // reports\n compiler.currentType = Type.void;\n if (!instance) return module.unreachable();\n return compiler.compileCallDirect(instance, operands, reportNode);\n }\n let usizeType = compiler.options.usizeType;\n let arg0 = compiler.compileExpression(operands[0], usizeType, Constraints.CONV_IMPLICIT);\n let arg1 = compiler.compileExpression(operands[1], usizeType, Constraints.CONV_IMPLICIT);\n let arg2 = compiler.compileExpression(operands[2], usizeType, Constraints.CONV_IMPLICIT);\n compiler.currentType = Type.void;\n return module.memory_copy(arg0, arg1, arg2);\n }\n case BuiltinSymbols.memory_fill: { // memory.fill(dest: usize, value: u8, n: usize) -> void\n compiler.currentType = Type.void;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 3, reportNode, compiler)\n ) return module.unreachable();\n if (!compiler.options.hasFeature(Feature.BULK_MEMORY)) {\n let instance = compiler.resolver.resolveFunction(prototype, null); // reports\n compiler.currentType = Type.void;\n if (!instance) return module.unreachable();\n return compiler.compileCallDirect(instance, operands, reportNode);\n }\n let usizeType = compiler.options.usizeType;\n let arg0 = compiler.compileExpression(operands[0], usizeType, Constraints.CONV_IMPLICIT);\n let arg1 = compiler.compileExpression(operands[1], Type.u8, Constraints.CONV_IMPLICIT);\n let arg2 = compiler.compileExpression(operands[2], usizeType, Constraints.CONV_IMPLICIT);\n compiler.currentType = Type.void;\n return module.memory_fill(arg0, arg1, arg2);\n }\n\n // === Helpers ================================================================================\n\n case BuiltinSymbols.changetype: { // changetype(value: *) -> T\n if (\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let toType = typeArguments![0];\n let arg0 = compiler.compileExpression(operands[0], toType);\n let fromType = compiler.currentType;\n compiler.currentType = toType;\n if (fromType.size != toType.size) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.range\n );\n return module.unreachable();\n }\n return arg0;\n }\n case BuiltinSymbols.assert: { // assert(isTrueish: T, message?: string) -> T{!= null}\n if (\n checkTypeOptional(typeArguments, reportNode, compiler) |\n checkArgsOptional(operands, 1, 2, reportNode, compiler)\n ) {\n if (typeArguments) {\n assert(typeArguments.length); // otherwise invalid, should not been set at all\n compiler.currentType = typeArguments[0].nonNullableType;\n }\n return module.unreachable();\n }\n let arg0 = typeArguments\n ? compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT | Constraints.MUST_WRAP)\n : compiler.compileExpression(operands[0], Type.bool, Constraints.MUST_WRAP);\n let type = compiler.currentType;\n compiler.currentType = type.nonNullableType;\n\n // return ifTrueish if assertions are disabled\n if (compiler.options.noAssert) {\n if (contextualType == Type.void) { // simplify if dropped anyway\n compiler.currentType = Type.void;\n return module.nop();\n }\n return arg0;\n }\n\n // otherwise call abort if the assertion is false-ish\n let abort = compileAbort(compiler, operands.length == 2 ? operands[1] : null, reportNode);\n compiler.currentType = type.nonNullableType;\n let expr: ExpressionRef;\n if (contextualType == Type.void) { // simplify if dropped anyway\n compiler.currentType = Type.void;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n expr = module.if(\n module.unary(UnaryOp.EqzI32, arg0),\n abort\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n expr = module.if(\n module.unary(UnaryOp.EqzI64, arg0),\n abort\n );\n break;\n }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n expr = module.if(\n module.unary(\n compiler.options.isWasm64\n ? UnaryOp.EqzI64\n : UnaryOp.EqzI32,\n arg0\n ),\n abort\n );\n break;\n }\n // TODO: also check for NaN in float assertions, as in `Boolean(NaN) -> false`?\n case TypeKind.F32: {\n expr = module.if(\n module.binary(BinaryOp.EqF32,\n arg0,\n module.f32(0)\n ),\n abort\n );\n break;\n }\n case TypeKind.F64: {\n expr = module.if(\n module.binary(BinaryOp.EqF64,\n arg0,\n module.f64(0)\n ),\n abort\n );\n break;\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n expr = abort;\n break;\n }\n }\n } else {\n compiler.currentType = type.nonNullableType;\n switch (compiler.currentType.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.BOOL: {\n let flow = compiler.currentFlow;\n let tempLocal = flow.getAndFreeTempLocal(type);\n flow.setLocalFlag(tempLocal.index, LocalFlags.WRAPPED); // arg0 is wrapped\n expr = module.if(\n module.local_tee(tempLocal.index, arg0),\n module.local_get(tempLocal.index, NativeType.I32),\n abort\n );\n break;\n }\n case TypeKind.I64:\n case TypeKind.U64: {\n let tempLocal = compiler.currentFlow.getAndFreeTempLocal(Type.i64);\n expr = module.if(\n module.unary(UnaryOp.EqzI64,\n module.local_tee(tempLocal.index, arg0)\n ),\n abort,\n module.local_get(tempLocal.index, NativeType.I64)\n );\n break;\n }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n let tempLocal = compiler.currentFlow.getAndFreeTempLocal(compiler.options.usizeType);\n expr = module.if(\n module.unary(\n compiler.options.isWasm64\n ? UnaryOp.EqzI64\n : UnaryOp.EqzI32,\n module.local_tee(tempLocal.index, arg0)\n ),\n abort,\n module.local_get(tempLocal.index, compiler.options.nativeSizeType)\n );\n break;\n }\n case TypeKind.F32: {\n let tempLocal = compiler.currentFlow.getAndFreeTempLocal(Type.f32);\n expr = module.if(\n module.binary(BinaryOp.EqF32,\n module.local_tee(tempLocal.index, arg0),\n module.f32(0)\n ),\n abort,\n module.local_get(tempLocal.index, NativeType.F32)\n );\n break;\n }\n case TypeKind.F64: {\n let tempLocal = compiler.currentFlow.getAndFreeTempLocal(Type.f64);\n expr = module.if(\n module.binary(BinaryOp.EqF64,\n module.local_tee(tempLocal.index, arg0),\n module.f64(0)\n ),\n abort,\n module.local_get(tempLocal.index, NativeType.F64)\n );\n break;\n }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n expr = abort;\n break;\n }\n }\n }\n return expr;\n }\n case BuiltinSymbols.unchecked: { // unchecked(expr: *) -> *\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) return module.unreachable();\n let flow = compiler.currentFlow;\n let alreadyUnchecked = flow.is(FlowFlags.UNCHECKED_CONTEXT);\n flow.set(FlowFlags.UNCHECKED_CONTEXT);\n // eliminate unnecessary tees by preferring contextualType(=void):\n let expr = compiler.compileExpression(operands[0], contextualType);\n if (!alreadyUnchecked) flow.unset(FlowFlags.UNCHECKED_CONTEXT);\n return expr;\n }\n case BuiltinSymbols.call_direct: directize = true;\n case BuiltinSymbols.call_indirect: { // call_indirect(target: Function | u32, ...args: *[]) -> T\n if (\n checkTypeOptional(typeArguments, reportNode, compiler, true) |\n checkArgsOptional(operands, 1, i32.MAX_VALUE, reportNode, compiler)\n ) return module.unreachable();\n let returnType = typeArguments ? typeArguments[0] : contextualType;\n let arg0 = compiler.compileExpression(operands[0], Type.u32);\n let arg0Type = compiler.currentType;\n if (!(\n arg0Type == Type.u32 || // either plain index\n arg0Type.kind == TypeKind.U32 && arg0Type.signatureReference // or function reference\n )) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n operands[0].range\n );\n return module.unreachable();\n }\n let numOperands = operands.length - 1;\n let operandExprs = new Array(numOperands);\n let nativeReturnType = returnType.toNativeType();\n let parameterTypes = new Array(numOperands);\n let nativeParamTypes = new Array(numOperands);\n for (let i = 0; i < numOperands; ++i) {\n operandExprs[i] = compiler.compileExpression(operands[1 + i], Type.i32);\n let operandType = compiler.currentType;\n parameterTypes[i] = operandType;\n nativeParamTypes[i] = operandType.toNativeType();\n }\n let typeName = Signature.makeSignatureString(parameterTypes, returnType);\n let typeRef = module.getFunctionTypeBySignature(nativeReturnType, nativeParamTypes);\n if (!typeRef) typeRef = module.addFunctionType(typeName, nativeReturnType, nativeParamTypes);\n compiler.currentType = returnType;\n if (directize) {\n // if the index expression is precomputable to a constant value, emit a direct call\n if (getExpressionId(arg0 = module.precomputeExpression(arg0)) == ExpressionId.Const) {\n assert(getExpressionType(arg0) == NativeType.I32);\n let index = getConstValueI32(arg0);\n let functionTable = compiler.functionTable;\n if (index >= 0 && index < functionTable.length) {\n return module.call(functionTable[index], operandExprs, nativeReturnType);\n }\n }\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n operands[0].range\n );\n return module.unreachable();\n }\n // of course this can easily result in a 'RuntimeError: function signature mismatch' trap and\n // thus must be used with care. it exists because it *might* be useful in specific scenarios.\n return module.call_indirect(arg0, operandExprs, typeName);\n }\n case BuiltinSymbols.instantiate: { // instantiate(...args: *[]) -> T\n if (\n checkTypeRequired(typeArguments, reportNode, compiler, true)\n ) return module.unreachable();\n let classInstance = typeArguments![0].classReference;\n if (!classInstance) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n compiler.currentType = classInstance.type;\n return compiler.compileInstantiate(classInstance, operands, Constraints.NONE, reportNode);\n }\n\n // === User-defined diagnostics ===============================================================\n\n case BuiltinSymbols.ERROR: {\n checkTypeAbsent(typeArguments, reportNode, prototype);\n compiler.error(\n DiagnosticCode.User_defined_0,\n reportNode.range, (operands.length ? operands[0] : reportNode).range.toString()\n );\n return module.unreachable();\n }\n case BuiltinSymbols.WARNING: {\n checkTypeAbsent(typeArguments, reportNode, prototype);\n compiler.warning(\n DiagnosticCode.User_defined_0,\n reportNode.range, (operands.length ? operands[0] : reportNode).range.toString()\n );\n return module.nop();\n }\n case BuiltinSymbols.INFO: {\n checkTypeAbsent(typeArguments, reportNode, prototype);\n compiler.info(\n DiagnosticCode.User_defined_0,\n reportNode.range, (operands.length ? operands[0] : reportNode).range.toString()\n );\n return module.nop();\n }\n\n // === Portable type conversions ==============================================================\n\n case BuiltinSymbols.i8: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.i8;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.i8, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.i16: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.i16;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.i16, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.i32: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.i32;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.i32, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.i64: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.i64;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.i64, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.isize: {\n let isizeType = compiler.options.isizeType;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = isizeType;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], isizeType, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.u8: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.u8;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.u8, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.u16: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.u16;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.u16, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.u32: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.u32;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.u32, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.u64: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.u64;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.u64, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.usize: {\n let usizeType = compiler.options.usizeType;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = usizeType;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], usizeType, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.bool: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.bool;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.bool, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.f32: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.f32;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.f32, Constraints.CONV_EXPLICIT);\n }\n case BuiltinSymbols.f64: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.f64;\n return module.unreachable();\n }\n return compiler.compileExpression(operands[0], Type.f64, Constraints.CONV_EXPLICIT);\n }\n\n // === SIMD ===================================================================================\n\n case BuiltinSymbols.v128: // alias for now\n case BuiltinSymbols.i8x16: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 16, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let bytes = new Uint8Array(16);\n for (let i = 0; i < 16; ++i) {\n let value = operands[i];\n if (value) {\n let expr = compiler.precomputeExpression(value, Type.i8, Constraints.CONV_IMPLICIT);\n if (getExpressionId(expr) != ExpressionId.Const) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n value.range\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n assert(getExpressionType(expr) == NativeType.I32);\n writeI8(getConstValueI32(expr), bytes, i);\n }\n }\n compiler.currentType = Type.v128;\n return module.v128(bytes);\n }\n case BuiltinSymbols.i16x8: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 8, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let bytes = new Uint8Array(16);\n for (let i = 0; i < 8; ++i) {\n let value = operands[i];\n if (value) {\n let expr = compiler.precomputeExpression(value, Type.i16, Constraints.CONV_IMPLICIT);\n if (getExpressionId(expr) != ExpressionId.Const) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n value.range\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n assert(getExpressionType(expr) == NativeType.I32);\n writeI16(getConstValueI32(expr), bytes, i << 1);\n }\n }\n compiler.currentType = Type.v128;\n return module.v128(bytes);\n }\n case BuiltinSymbols.i32x4: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 4, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let bytes = new Uint8Array(16);\n for (let i = 0; i < 4; ++i) {\n let value = operands[i];\n if (value) {\n let expr = compiler.precomputeExpression(value, Type.i32, Constraints.CONV_IMPLICIT);\n if (getExpressionId(expr) != ExpressionId.Const) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n value.range\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n assert(getExpressionType(expr) == NativeType.I32);\n writeI32(getConstValueI32(expr), bytes, i << 2);\n }\n }\n compiler.currentType = Type.v128;\n return module.v128(bytes);\n }\n case BuiltinSymbols.i64x2: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let bytes = new Uint8Array(16);\n for (let i = 0; i < 2; ++i) {\n let value = operands[i];\n if (value) {\n let expr = compiler.precomputeExpression(value, Type.i64, Constraints.CONV_IMPLICIT);\n if (getExpressionId(expr) != ExpressionId.Const) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n value.range\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n assert(getExpressionType(expr) == NativeType.I64);\n let off = i << 3;\n writeI32(getConstValueI64Low(expr), bytes, off);\n writeI32(getConstValueI64High(expr), bytes, off + 4);\n }\n }\n compiler.currentType = Type.v128;\n return module.v128(bytes);\n }\n case BuiltinSymbols.f32x4: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 4, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let bytes = new Uint8Array(16);\n for (let i = 0; i < 4; ++i) {\n let value = operands[i];\n if (value) {\n let expr = compiler.precomputeExpression(value, Type.f32, Constraints.CONV_IMPLICIT);\n if (getExpressionId(expr) != ExpressionId.Const) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n value.range\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n assert(getExpressionType(expr) == NativeType.F32);\n writeF32(getConstValueF32(expr), bytes, i << 2);\n }\n }\n compiler.currentType = Type.v128;\n return module.v128(bytes);\n }\n case BuiltinSymbols.f64x2: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let bytes = new Uint8Array(16);\n for (let i = 0; i < 2; ++i) {\n let value = operands[i];\n if (value) {\n let expr = compiler.precomputeExpression(value, Type.f64, Constraints.CONV_IMPLICIT);\n if (getExpressionId(expr) != ExpressionId.Const) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n value.range\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n assert(getExpressionType(expr) == NativeType.F64);\n writeF64(getConstValueF64(expr), bytes, i << 3);\n }\n }\n compiler.currentType = Type.v128;\n return module.v128(bytes);\n }\n case BuiltinSymbols.v128_splat: { // splat(x: T) -> v128\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let type = typeArguments![0];\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let op: UnaryOp;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = UnaryOp.SplatVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = UnaryOp.SplatVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = UnaryOp.SplatVecI32x4; break; }\n case TypeKind.I64:\n case TypeKind.U64: { op = UnaryOp.SplatVecI64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? UnaryOp.SplatVecI64x2\n : UnaryOp.SplatVecI32x4;\n break;\n }\n case TypeKind.F32: { op = UnaryOp.SplatVecF32x4; break; }\n case TypeKind.F64: { op = UnaryOp.SplatVecF64x2; break; }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n }\n let arg0 = compiler.compileExpression(operands[0], type, Constraints.CONV_IMPLICIT);\n compiler.currentType = Type.v128;\n return module.unary(op, arg0);\n }\n case BuiltinSymbols.v128_extract_lane: { // extract_lane(x: v128, idx: u8) -> T\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler, true) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) return module.unreachable();\n let type = typeArguments![0];\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = type;\n return module.unreachable();\n }\n let op: SIMDExtractOp;\n switch (type.kind) {\n case TypeKind.I8: { op = SIMDExtractOp.ExtractLaneSVecI8x16; break; }\n case TypeKind.U8: { op = SIMDExtractOp.ExtractLaneUVecI8x16; break; }\n case TypeKind.I16: { op = SIMDExtractOp.ExtractLaneSVecI16x8; break; }\n case TypeKind.U16: { op = SIMDExtractOp.ExtractLaneUVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = SIMDExtractOp.ExtractLaneVecI32x4; break; }\n case TypeKind.I64:\n case TypeKind.U64: { op = SIMDExtractOp.ExtractLaneVecI64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? SIMDExtractOp.ExtractLaneVecI64x2\n : SIMDExtractOp.ExtractLaneVecI32x4;\n break;\n }\n case TypeKind.F32: { op = SIMDExtractOp.ExtractLaneVecF32x4; break; }\n case TypeKind.F64: { op = SIMDExtractOp.ExtractLaneVecF64x2; break; }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = type;\n return module.unreachable();\n }\n }\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\n let arg1 = compiler.precomputeExpression(operands[1], Type.u8, Constraints.CONV_IMPLICIT);\n compiler.currentType = type;\n if (getExpressionId(arg1) != ExpressionId.Const) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n operands[1].range\n );\n return module.unreachable();\n }\n assert(getExpressionType(arg1) == NativeType.I32);\n let maxIdx = (16 / type.byteSize) - 1;\n let idx = getConstValueI32(arg1);\n if (idx < 0 || idx > maxIdx) {\n compiler.error(\n DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,\n operands[1].range, \"Lane index\", \"0\", maxIdx.toString()\n );\n return module.unreachable();\n }\n return module.simd_extract(op, arg0, idx);\n }\n case BuiltinSymbols.v128_replace_lane: { // replace_lane(x: v128, idx: u8, value: T) -> v128\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsRequired(operands, 3, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let type = typeArguments![0];\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let op: SIMDReplaceOp;\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = SIMDReplaceOp.ReplaceLaneVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = SIMDReplaceOp.ReplaceLaneVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = SIMDReplaceOp.ReplaceLaneVecI32x4; break; }\n case TypeKind.I64:\n case TypeKind.U64: { op = SIMDReplaceOp.ReplaceLaneVecI64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? SIMDReplaceOp.ReplaceLaneVecI64x2\n : SIMDReplaceOp.ReplaceLaneVecI32x4;\n break;\n }\n case TypeKind.F32: { op = SIMDReplaceOp.ReplaceLaneVecF32x4; break; }\n case TypeKind.F64: { op = SIMDReplaceOp.ReplaceLaneVecF64x2; break; }\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n }\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\n let arg1 = compiler.precomputeExpression(operands[1], Type.u8, Constraints.CONV_IMPLICIT);\n if (getExpressionId(arg1) != ExpressionId.Const) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n operands[1].range\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n assert(getExpressionType(arg1) == NativeType.I32);\n let maxIdx = (16 / type.byteSize) - 1;\n let idx = getConstValueI32(arg1);\n if (idx < 0 || idx > maxIdx) {\n compiler.error(\n DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,\n operands[1].range, \"Lane index\", \"0\", maxIdx.toString()\n );\n return module.unreachable();\n }\n let arg2 = compiler.compileExpression(operands[2], type, Constraints.CONV_IMPLICIT);\n compiler.currentType = Type.v128;\n return module.simd_replace(op, arg0, idx, arg2);\n }\n case BuiltinSymbols.v128_shuffle: { // shuffle(a: v128, b: v128, ...lanes: u8[]) -> v128\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let type = typeArguments![0];\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let laneWidth = type.byteSize;\n let laneCount = 16 / laneWidth;\n assert(isInteger(laneCount) && isPowerOf2(laneCount));\n if (\n checkArgsRequired(operands, 2 + laneCount, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.I16:\n case TypeKind.I32:\n case TypeKind.I64:\n case TypeKind.ISIZE:\n case TypeKind.U8:\n case TypeKind.U16:\n case TypeKind.U32:\n case TypeKind.U64:\n case TypeKind.USIZE:\n case TypeKind.F32:\n case TypeKind.F64: break;\n default: {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n }\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\n let arg1 = compiler.compileExpression(operands[1], Type.v128, Constraints.CONV_IMPLICIT);\n let mask = new Uint8Array(16);\n let maxIdx = (laneCount << 1) - 1;\n for (let i = 0; i < laneCount; ++i) {\n let operand = operands[2 + i];\n let argN = compiler.precomputeExpression(operand, Type.u8, Constraints.CONV_IMPLICIT);\n if (getExpressionId(argN) != ExpressionId.Const) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n operand.range\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n assert(getExpressionType(argN) == NativeType.I32);\n let idx = getConstValueI32(argN);\n if (idx < 0 || idx > maxIdx) {\n compiler.error(\n DiagnosticCode._0_must_be_a_value_between_1_and_2_inclusive,\n operand.range, \"Lane index\", \"0\", maxIdx.toString()\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n switch (laneWidth) {\n case 1: {\n writeI8(idx, mask, i);\n break;\n }\n case 2: {\n let off8 = i << 1;\n let idx8 = idx << 1;\n writeI8(idx8 , mask, off8);\n writeI8(idx8 + 1, mask, off8 + 1);\n break;\n }\n case 4: {\n let off8 = i << 2;\n let idx8 = idx << 2;\n writeI8(idx8 , mask, off8);\n writeI8(idx8 + 1, mask, off8 + 1);\n writeI8(idx8 + 2, mask, off8 + 2);\n writeI8(idx8 + 3, mask, off8 + 3);\n break;\n }\n case 8: {\n let off8 = i << 3;\n let idx8 = idx << 3;\n writeI8(idx8 , mask, off8);\n writeI8(idx8 + 1, mask, off8 + 1);\n writeI8(idx8 + 2, mask, off8 + 2);\n writeI8(idx8 + 3, mask, off8 + 3);\n writeI8(idx8 + 4, mask, off8 + 4);\n writeI8(idx8 + 5, mask, off8 + 5);\n writeI8(idx8 + 6, mask, off8 + 6);\n writeI8(idx8 + 7, mask, off8 + 7);\n break;\n }\n default: assert(false);\n }\n }\n compiler.currentType = Type.v128;\n return module.simd_shuffle(arg0, arg1, mask);\n }\n case BuiltinSymbols.v128_add: // any_binary(a: v128, b: v128) -> v128\n case BuiltinSymbols.v128_sub:\n case BuiltinSymbols.v128_mul:\n case BuiltinSymbols.v128_div:\n case BuiltinSymbols.v128_add_saturate:\n case BuiltinSymbols.v128_sub_saturate:\n case BuiltinSymbols.v128_min:\n case BuiltinSymbols.v128_max:\n case BuiltinSymbols.v128_eq:\n case BuiltinSymbols.v128_ne:\n case BuiltinSymbols.v128_lt:\n case BuiltinSymbols.v128_le:\n case BuiltinSymbols.v128_gt:\n case BuiltinSymbols.v128_ge: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let type = typeArguments![0];\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let op: BinaryOp = -1;\n switch (prototype.internalName) {\n case BuiltinSymbols.v128_add: {\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = BinaryOp.AddVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = BinaryOp.AddVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = BinaryOp.AddVecI32x4; break; }\n case TypeKind.I64:\n case TypeKind.U64: { op = BinaryOp.AddVecI64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? BinaryOp.AddVecI64x2\n : BinaryOp.AddVecI32x4;\n break;\n }\n case TypeKind.F32: { op = BinaryOp.AddVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.AddVecF64x2; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_sub: {\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = BinaryOp.SubVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = BinaryOp.SubVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = BinaryOp.SubVecI32x4; break; }\n case TypeKind.I64:\n case TypeKind.U64: { op = BinaryOp.SubVecI64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? BinaryOp.SubVecI64x2\n : BinaryOp.SubVecI32x4;\n break;\n }\n case TypeKind.F32: { op = BinaryOp.SubVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.SubVecF64x2; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_mul: {\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = BinaryOp.MulVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = BinaryOp.MulVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = BinaryOp.MulVecI32x4; break; }\n case TypeKind.F32: { op = BinaryOp.MulVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.MulVecF64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n if (!compiler.options.isWasm64) op = BinaryOp.MulVecI32x4;\n break;\n }\n }\n break;\n }\n case BuiltinSymbols.v128_div: {\n switch (type.kind) {\n case TypeKind.F32: { op = BinaryOp.DivVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.DivVecF64x2; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_add_saturate: {\n switch (type.kind) {\n case TypeKind.I8: { op = BinaryOp.AddSatSVecI8x16; break; }\n case TypeKind.U8: { op = BinaryOp.AddSatUVecI8x16; break; }\n case TypeKind.I16: { op = BinaryOp.AddSatSVecI16x8; break; }\n case TypeKind.U16: { op = BinaryOp.AddSatUVecI16x8; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_sub_saturate: {\n switch (type.kind) {\n case TypeKind.I8: { op = BinaryOp.SubSatSVecI8x16; break; }\n case TypeKind.U8: { op = BinaryOp.SubSatUVecI8x16; break; }\n case TypeKind.I16: { op = BinaryOp.SubSatSVecI16x8; break; }\n case TypeKind.U16: { op = BinaryOp.SubSatUVecI16x8; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_min: {\n switch (type.kind) {\n case TypeKind.F32: { op = BinaryOp.MinVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.MinVecF64x2; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_max: {\n switch (type.kind) {\n case TypeKind.F32: { op = BinaryOp.MaxVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.MaxVecF64x2; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_eq: {\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = BinaryOp.EqVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = BinaryOp.EqVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = BinaryOp.EqVecI32x4; break; }\n case TypeKind.F32: { op = BinaryOp.EqVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.EqVecF64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n if (!compiler.options.isWasm64) op = BinaryOp.EqVecI32x4;\n break;\n }\n }\n break;\n }\n case BuiltinSymbols.v128_ne: {\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = BinaryOp.NeVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = BinaryOp.NeVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = BinaryOp.NeVecI32x4; break; }\n case TypeKind.F32: { op = BinaryOp.NeVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.NeVecF64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n if (!compiler.options.isWasm64) op = BinaryOp.NeVecI32x4;\n break;\n }\n }\n break;\n }\n case BuiltinSymbols.v128_lt: {\n switch (type.kind) {\n case TypeKind.I8: { op = BinaryOp.LtSVecI8x16; break; }\n case TypeKind.U8: { op = BinaryOp.LtUVecI8x16; break; }\n case TypeKind.I16: { op = BinaryOp.LtSVecI16x8; break; }\n case TypeKind.U16: { op = BinaryOp.LtUVecI16x8; break; }\n case TypeKind.I32: { op = BinaryOp.LtSVecI32x4; break; }\n case TypeKind.U32: { op = BinaryOp.LtUVecI32x4; break; }\n case TypeKind.F32: { op = BinaryOp.LtVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.LtVecF64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n if (!compiler.options.isWasm64) {\n op = type.kind == TypeKind.ISIZE\n ? BinaryOp.LtSVecI32x4\n : BinaryOp.LtUVecI32x4;\n }\n break;\n }\n }\n break;\n }\n case BuiltinSymbols.v128_le: {\n switch (type.kind) {\n case TypeKind.I8: { op = BinaryOp.LeSVecI8x16; break; }\n case TypeKind.U8: { op = BinaryOp.LeUVecI8x16; break; }\n case TypeKind.I16: { op = BinaryOp.LeSVecI16x8; break; }\n case TypeKind.U16: { op = BinaryOp.LeUVecI16x8; break; }\n case TypeKind.I32: { op = BinaryOp.LeSVecI32x4; break; }\n case TypeKind.U32: { op = BinaryOp.LeUVecI32x4; break; }\n case TypeKind.F32: { op = BinaryOp.LeVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.LeVecF64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n if (!compiler.options.isWasm64) {\n op = type.kind == TypeKind.ISIZE\n ? BinaryOp.LeSVecI32x4\n : BinaryOp.LeUVecI32x4;\n }\n break;\n }\n }\n break;\n }\n case BuiltinSymbols.v128_gt: {\n switch (type.kind) {\n case TypeKind.I8: { op = BinaryOp.GtSVecI8x16; break; }\n case TypeKind.U8: { op = BinaryOp.GtUVecI8x16; break; }\n case TypeKind.I16: { op = BinaryOp.GtSVecI16x8; break; }\n case TypeKind.U16: { op = BinaryOp.GtUVecI16x8; break; }\n case TypeKind.I32: { op = BinaryOp.GtSVecI32x4; break; }\n case TypeKind.U32: { op = BinaryOp.GtUVecI32x4; break; }\n case TypeKind.F32: { op = BinaryOp.GtVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.GtVecF64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n if (!compiler.options.isWasm64) {\n op = type.kind == TypeKind.ISIZE\n ? BinaryOp.GtSVecI32x4\n : BinaryOp.GtUVecI32x4;\n }\n break;\n }\n }\n break;\n }\n case BuiltinSymbols.v128_ge: {\n switch (type.kind) {\n case TypeKind.I8: { op = BinaryOp.GeSVecI8x16; break; }\n case TypeKind.U8: { op = BinaryOp.GeUVecI8x16; break; }\n case TypeKind.I16: { op = BinaryOp.GeSVecI16x8; break; }\n case TypeKind.U16: { op = BinaryOp.GeUVecI16x8; break; }\n case TypeKind.I32: { op = BinaryOp.GeSVecI32x4; break; }\n case TypeKind.U32: { op = BinaryOp.GeUVecI32x4; break; }\n case TypeKind.F32: { op = BinaryOp.GeVecF32x4; break; }\n case TypeKind.F64: { op = BinaryOp.GeVecF64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n if (!compiler.options.isWasm64) {\n op = type.kind == TypeKind.ISIZE\n ? BinaryOp.GeSVecI32x4\n : BinaryOp.GeUVecI32x4;\n }\n break;\n }\n }\n break;\n }\n }\n if (op == -1) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\n let arg1 = compiler.compileExpression(operands[1], Type.v128, Constraints.CONV_IMPLICIT);\n compiler.currentType = Type.v128;\n return module.binary(op, arg0, arg1);\n }\n case BuiltinSymbols.v128_neg: // any_unary(a: v128) -> v128\n case BuiltinSymbols.v128_abs:\n case BuiltinSymbols.v128_sqrt:\n case BuiltinSymbols.v128_convert:\n case BuiltinSymbols.v128_trunc: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let type = typeArguments![0];\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.range\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let op: UnaryOp = -1;\n switch (prototype.internalName) {\n case BuiltinSymbols.v128_neg: {\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = UnaryOp.NegVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = UnaryOp.NegVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = UnaryOp.NegVecI32x4; break; }\n case TypeKind.I64:\n case TypeKind.U64: { op = UnaryOp.NegVecI64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? UnaryOp.NegVecI64x2\n : UnaryOp.NegVecI32x4;\n break;\n }\n case TypeKind.F32: { op = UnaryOp.NegVecF32x4; break; }\n case TypeKind.F64: { op = UnaryOp.NegVecF64x2; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_abs: {\n switch (type.kind) {\n case TypeKind.F32: { op = UnaryOp.AbsVecF32x4; break; }\n case TypeKind.F64: { op = UnaryOp.AbsVecF64x2; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_sqrt: {\n switch (type.kind) {\n case TypeKind.F32: { op = UnaryOp.SqrtVecF32x4; break; }\n case TypeKind.F64: { op = UnaryOp.SqrtVecF64x2; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_convert: {\n switch (type.kind) {\n case TypeKind.I32: { op = UnaryOp.ConvertSVecI32x4ToVecF32x4; break; }\n case TypeKind.U32: { op = UnaryOp.ConvertUVecI32x4ToVecF32x4; break; }\n case TypeKind.I64: { op = UnaryOp.ConvertSVecI64x2ToVecF64x2; break; }\n case TypeKind.U64: { op = UnaryOp.ConvertUVecI64x2ToVecF64x2; break; }\n }\n break;\n }\n case BuiltinSymbols.v128_trunc: {\n switch (type.kind) {\n case TypeKind.I32: { op = UnaryOp.TruncSatSVecF32x4ToVecI32x4; break; }\n case TypeKind.U32: { op = UnaryOp.TruncSatUVecF32x4ToVecI32x4; break; }\n case TypeKind.I64: { op = UnaryOp.TruncSatSVecF64x2ToVecI64x2; break; }\n case TypeKind.U64: { op = UnaryOp.TruncSatUVecF64x2ToVecI64x2; break; }\n }\n break;\n }\n }\n if (op == -1) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\n compiler.currentType = Type.v128;\n return module.unary(op, arg0);\n }\n case BuiltinSymbols.v128_shl: // any_shift(a: v128, b: i32) -> v128\n case BuiltinSymbols.v128_shr: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let type = typeArguments![0];\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let op: SIMDShiftOp = -1;\n switch (prototype.internalName) {\n case BuiltinSymbols.v128_shl: {\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = SIMDShiftOp.ShlVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = SIMDShiftOp.ShlVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = SIMDShiftOp.ShlVecI32x4; break; }\n case TypeKind.I64:\n case TypeKind.U64: { op = SIMDShiftOp.ShlVecI64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? SIMDShiftOp.ShlVecI64x2\n : SIMDShiftOp.ShlVecI32x4;\n break;\n }\n }\n break;\n }\n case BuiltinSymbols.v128_shr: {\n switch (type.kind) {\n case TypeKind.I8: { op = SIMDShiftOp.ShrSVecI8x16; break; }\n case TypeKind.U8: { op = SIMDShiftOp.ShrUVecI8x16; break; }\n case TypeKind.I16: { op = SIMDShiftOp.ShrSVecI16x8; break; }\n case TypeKind.U16: { op = SIMDShiftOp.ShrUVecI16x8; break; }\n case TypeKind.I32: { op = SIMDShiftOp.ShrSVecI32x4; break; }\n case TypeKind.U32: { op = SIMDShiftOp.ShrUVecI32x4; break; }\n case TypeKind.I64: { op = SIMDShiftOp.ShrSVecI64x2; break; }\n case TypeKind.U64: { op = SIMDShiftOp.ShrUVecI64x2; break; }\n case TypeKind.ISIZE: {\n op = compiler.options.isWasm64\n ? SIMDShiftOp.ShrSVecI64x2\n : SIMDShiftOp.ShrSVecI32x4;\n break;\n }\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? SIMDShiftOp.ShrUVecI64x2\n : SIMDShiftOp.ShrUVecI32x4;\n break;\n }\n }\n break;\n }\n }\n if (op == -1) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.range\n );\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\n let arg1 = compiler.compileExpression(operands[1], Type.i32, Constraints.CONV_IMPLICIT);\n compiler.currentType = Type.v128;\n return module.simd_shift(op, arg0, arg1);\n }\n case BuiltinSymbols.v128_and: // any_bitwise_binary(a: v128, b: v128) -> v128\n case BuiltinSymbols.v128_or:\n case BuiltinSymbols.v128_xor: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 2, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let op: BinaryOp = -1;\n switch (prototype.internalName) {\n default: assert(false);\n case BuiltinSymbols.v128_and: { op = BinaryOp.AndVec128; break; }\n case BuiltinSymbols.v128_or: { op = BinaryOp.OrVec128; break; }\n case BuiltinSymbols.v128_xor: { op = BinaryOp.XorVec128; break; }\n }\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\n let arg1 = compiler.compileExpression(operands[1], Type.v128, Constraints.CONV_IMPLICIT);\n return module.binary(op, arg0, arg1);\n }\n case BuiltinSymbols.v128_not: { // any_bitwise_unary(a: v128) -> v128\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\n return module.unary(UnaryOp.NotVec128, arg0);\n }\n case BuiltinSymbols.v128_bitselect: { // bitselect(v1: v128, v2: v128, c: v128) -> v128\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 3, reportNode, compiler)\n ) {\n compiler.currentType = Type.v128;\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\n let arg1 = compiler.compileExpression(operands[1], Type.v128, Constraints.CONV_IMPLICIT);\n let arg2 = compiler.compileExpression(operands[2], Type.v128, Constraints.CONV_IMPLICIT);\n return module.simd_bitselect(arg0, arg1, arg2);\n }\n case BuiltinSymbols.v128_any_true: // any_test(a: v128) -> bool\n case BuiltinSymbols.v128_all_true: {\n if (!compiler.options.hasFeature(Feature.SIMD)) break;\n if (\n checkTypeRequired(typeArguments, reportNode, compiler) |\n checkArgsRequired(operands, 1, reportNode, compiler)\n ) {\n compiler.currentType = Type.bool;\n return module.unreachable();\n }\n let type = typeArguments![0];\n if (type.is(TypeFlags.REFERENCE)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n return module.unreachable();\n }\n let op: UnaryOp = -1;\n switch (prototype.internalName) {\n default: assert(false);\n case BuiltinSymbols.v128_any_true: {\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = UnaryOp.AnyTrueVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = UnaryOp.AnyTrueVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = UnaryOp.AnyTrueVecI32x4; break; }\n case TypeKind.I64:\n case TypeKind.U64: { op = UnaryOp.AnyTrueVecI64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? UnaryOp.AnyTrueVecI64x2\n : UnaryOp.AnyTrueVecI32x4;\n break;\n }\n }\n break;\n }\n case BuiltinSymbols.v128_all_true: {\n switch (type.kind) {\n case TypeKind.I8:\n case TypeKind.U8: { op = UnaryOp.AllTrueVecI8x16; break; }\n case TypeKind.I16:\n case TypeKind.U16: { op = UnaryOp.AllTrueVecI16x8; break; }\n case TypeKind.I32:\n case TypeKind.U32: { op = UnaryOp.AllTrueVecI32x4; break; }\n case TypeKind.I64:\n case TypeKind.U64: { op = UnaryOp.AllTrueVecI64x2; break; }\n case TypeKind.ISIZE:\n case TypeKind.USIZE: {\n op = compiler.options.isWasm64\n ? UnaryOp.AllTrueVecI64x2\n : UnaryOp.AllTrueVecI32x4;\n break;\n }\n }\n break;\n }\n }\n if (op == -1) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.typeArgumentsRange\n );\n compiler.currentType = Type.bool;\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0], Type.v128, Constraints.CONV_IMPLICIT);\n compiler.currentType = Type.bool;\n return module.unary(op, arg0);\n }\n\n // === Internal runtime =======================================================================\n\n case BuiltinSymbols.idof: {\n let type = evaluateConstantType(compiler, typeArguments, operands, reportNode);\n compiler.currentType = Type.u32;\n if (!type) return module.unreachable();\n let classReference = type.classReference;\n if (!classReference || classReference.hasDecorator(DecoratorFlags.UNMANAGED)) {\n compiler.error(\n DiagnosticCode.Operation_not_supported,\n reportNode.range\n );\n return module.unreachable();\n }\n return module.i32(classReference.id);\n }\n case BuiltinSymbols.visit_globals: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 1, reportNode, compiler) // cookie\n ) {\n compiler.currentType = Type.void;\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0], Type.u32, Constraints.CONV_IMPLICIT);\n compiler.runtimeFeatures |= RuntimeFeatures.visitGlobals;\n compiler.currentType = Type.void;\n return module.call(BuiltinSymbols.visit_globals, [ arg0 ], NativeType.None);\n }\n case BuiltinSymbols.visit_members: {\n if (\n checkTypeAbsent(typeArguments, reportNode, prototype) |\n checkArgsRequired(operands, 2, reportNode, compiler) // ref, cookie\n ) {\n compiler.currentType = Type.void;\n return module.unreachable();\n }\n let arg0 = compiler.compileExpression(operands[0], compiler.options.usizeType, Constraints.CONV_IMPLICIT);\n let arg1 = compiler.compileExpression(operands[1], Type.u32, Constraints.CONV_IMPLICIT);\n compiler.runtimeFeatures |= RuntimeFeatures.visitMembers;\n compiler.currentType = Type.void;\n return module.call(BuiltinSymbols.visit_members, [ arg0, arg1 ], NativeType.None);\n }\n }\n\n // try to defer inline asm to a concrete built-in\n {\n let expr = tryDeferASM(compiler, prototype, operands, reportNode);\n if (expr) {\n if (typeArguments) {\n compiler.error(\n DiagnosticCode.Type_0_is_not_generic,\n reportNode.typeArgumentsRange, prototype.internalName\n );\n }\n return expr;\n }\n }\n compiler.error(\n DiagnosticCode.Cannot_find_name_0,\n reportNode.expression.range, prototype.internalName\n );\n return module.unreachable();\n}\n\n/** Tries to defer an inline-assembler-like call to a built-in function. */\nfunction tryDeferASM(\n compiler: Compiler,\n prototype: FunctionPrototype,\n operands: Expression[],\n reportNode: CallExpression\n): ExpressionRef {\n /* tslint:disable:max-line-length */\n switch (prototype.internalName) {\n\n // TODO: Operators can't be just deferred (don't have a corresponding generic built-in)\n // add, sub, mul, div_s, div_u, rem_s, rem_u\n // and, or, xor, shl, shr_u, shr_s\n // eq, eqz, ne, lt_s, lt_u, le_s, le_u, gt_s, gt_u, ge_s, ge_u\n\n case BuiltinSymbols.i32_clz: return deferASM(BuiltinSymbols.clz, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_clz: return deferASM(BuiltinSymbols.clz, compiler, Type.i64, operands, Type.i64, reportNode);\n case BuiltinSymbols.i32_ctz: return deferASM(BuiltinSymbols.ctz, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_ctz: return deferASM(BuiltinSymbols.ctz, compiler, Type.i64, operands, Type.i64, reportNode);\n case BuiltinSymbols.i32_popcnt: return deferASM(BuiltinSymbols.popcnt, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_popcnt: return deferASM(BuiltinSymbols.popcnt, compiler, Type.i64, operands, Type.i64, reportNode);\n case BuiltinSymbols.i32_rotl: return deferASM(BuiltinSymbols.rotl, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_rotl: return deferASM(BuiltinSymbols.rotl, compiler, Type.i64, operands, Type.i64, reportNode);\n case BuiltinSymbols.i32_rotr: return deferASM(BuiltinSymbols.rotr, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_rotr: return deferASM(BuiltinSymbols.rotr, compiler, Type.i64, operands, Type.i64, reportNode);\n case BuiltinSymbols.f32_abs: return deferASM(BuiltinSymbols.abs, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_abs: return deferASM(BuiltinSymbols.abs, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.f32_max: return deferASM(BuiltinSymbols.max, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_max: return deferASM(BuiltinSymbols.max, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.f32_min: return deferASM(BuiltinSymbols.min, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_min: return deferASM(BuiltinSymbols.min, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.f32_ceil: return deferASM(BuiltinSymbols.ceil, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_ceil: return deferASM(BuiltinSymbols.ceil, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.f32_floor: return deferASM(BuiltinSymbols.floor, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_floor: return deferASM(BuiltinSymbols.floor, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.f32_copysign: return deferASM(BuiltinSymbols.copysign, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_copysign: return deferASM(BuiltinSymbols.copysign, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.f32_nearest: return deferASM(BuiltinSymbols.nearest, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_nearest: return deferASM(BuiltinSymbols.nearest, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.i32_reinterpret_f32: return deferASM(BuiltinSymbols.reinterpret, compiler, Type.i32, operands, Type.f32, reportNode);\n case BuiltinSymbols.i64_reinterpret_f64: return deferASM(BuiltinSymbols.reinterpret, compiler, Type.i64, operands, Type.f64, reportNode);\n case BuiltinSymbols.f32_reinterpret_i32: return deferASM(BuiltinSymbols.reinterpret, compiler, Type.f32, operands, Type.i32, reportNode);\n case BuiltinSymbols.f64_reinterpret_i64: return deferASM(BuiltinSymbols.reinterpret, compiler, Type.f64, operands, Type.i64, reportNode);\n case BuiltinSymbols.f32_sqrt: return deferASM(BuiltinSymbols.sqrt, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_sqrt: return deferASM(BuiltinSymbols.sqrt, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.f32_trunc: return deferASM(BuiltinSymbols.trunc, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_trunc: return deferASM(BuiltinSymbols.trunc, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.i32_load8_s: return deferASM(BuiltinSymbols.load, compiler, Type.i8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_load8_u: return deferASM(BuiltinSymbols.load, compiler, Type.u8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_load16_s: return deferASM(BuiltinSymbols.load, compiler, Type.i16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_load16_u: return deferASM(BuiltinSymbols.load, compiler, Type.u16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_load: return deferASM(BuiltinSymbols.load, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_load8_s: return deferASM(BuiltinSymbols.load, compiler, Type.i8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_load8_u: return deferASM(BuiltinSymbols.load, compiler, Type.u8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_load16_s: return deferASM(BuiltinSymbols.load, compiler, Type.i16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_load16_u: return deferASM(BuiltinSymbols.load, compiler, Type.u16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_load32_s: return deferASM(BuiltinSymbols.load, compiler, Type.i32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_load32_u: return deferASM(BuiltinSymbols.load, compiler, Type.u32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_load: return deferASM(BuiltinSymbols.load, compiler, Type.i64, operands, Type.i64, reportNode);\n case BuiltinSymbols.f32_load: return deferASM(BuiltinSymbols.load, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_load: return deferASM(BuiltinSymbols.load, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.i32_store8: return deferASM(BuiltinSymbols.store, compiler, Type.i8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_store16: return deferASM(BuiltinSymbols.store, compiler, Type.i16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_store: return deferASM(BuiltinSymbols.store, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_store8: return deferASM(BuiltinSymbols.store, compiler, Type.i8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_store16: return deferASM(BuiltinSymbols.store, compiler, Type.i16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_store32: return deferASM(BuiltinSymbols.store, compiler, Type.i32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_store: return deferASM(BuiltinSymbols.store, compiler, Type.i64, operands, Type.i64, reportNode);\n case BuiltinSymbols.f32_store: return deferASM(BuiltinSymbols.store, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f64_store: return deferASM(BuiltinSymbols.store, compiler, Type.f64, operands, Type.f64, reportNode);\n }\n if (compiler.options.hasFeature(Feature.THREADS)) {\n switch (prototype.internalName) {\n\n case BuiltinSymbols.i32_atomic_load8_u: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.u8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_load16_u: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.u16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_load: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_atomic_load8_u: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.u8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_load16_u: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.u16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_load32_u: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.u32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_load: return deferASM(BuiltinSymbols.atomic_load, compiler, Type.i64, operands, Type.i64, reportNode);\n\n case BuiltinSymbols.i32_atomic_store8: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.u8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_store16: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.u16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_store: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_atomic_store8: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.u8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_store16: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.u16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_store32: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.u32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_store: return deferASM(BuiltinSymbols.atomic_store, compiler, Type.i64, operands, Type.i64, reportNode);\n\n case BuiltinSymbols.i32_atomic_rmw8_add_u: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.u8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw16_add_u: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.u16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw_add: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_atomic_rmw8_add_u: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.u8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw16_add_u: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.u16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw32_add_u: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.u32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw_add: return deferASM(BuiltinSymbols.atomic_add, compiler, Type.i64, operands, Type.i64, reportNode);\n\n case BuiltinSymbols.i32_atomic_rmw8_sub_u: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.u8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw16_sub_u: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.u16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw_sub: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_atomic_rmw8_sub_u: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.u8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw16_sub_u: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.u16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw32_sub_u: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.u32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw_sub: return deferASM(BuiltinSymbols.atomic_sub, compiler, Type.i64, operands, Type.i64, reportNode);\n\n case BuiltinSymbols.i32_atomic_rmw8_and_u: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.u8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw16_and_u: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.u16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw_and: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_atomic_rmw8_and_u: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.u8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw16_and_u: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.u16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw32_and_u: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.u32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw_and: return deferASM(BuiltinSymbols.atomic_and, compiler, Type.i64, operands, Type.i64, reportNode);\n\n case BuiltinSymbols.i32_atomic_rmw8_or_u: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.u8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw16_or_u: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.u16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw_or: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_atomic_rmw8_or_u: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.u8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw16_or_u: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.u16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw32_or_u: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.u32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw_or: return deferASM(BuiltinSymbols.atomic_or, compiler, Type.i64, operands, Type.i64, reportNode);\n\n case BuiltinSymbols.i32_atomic_rmw8_u_xor: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.u8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw16_u_xor: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.u16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw_xor: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_atomic_rmw8_xor_u: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.u8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw16_xor_u: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.u16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw32_xor_u: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.u32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw_xor: return deferASM(BuiltinSymbols.atomic_xor, compiler, Type.i64, operands, Type.i64, reportNode);\n\n case BuiltinSymbols.i32_atomic_rmw8_xchg_u: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.u8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw16_xchg_u: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.u16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw_xchg: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_atomic_rmw8_xchg_u: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.u8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw16_xchg_u: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.u16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw32_xchg_u: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.u32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw_xchg: return deferASM(BuiltinSymbols.atomic_xchg, compiler, Type.i64, operands, Type.i64, reportNode);\n\n case BuiltinSymbols.i32_atomic_rmw8_cmpxchg_u: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.u8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw16_cmpxchg_u: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.u16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32_atomic_rmw_cmpxchg: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_atomic_rmw8_cmpxchg_u: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.u8, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw16_cmpxchg_u: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.u16, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw32_cmpxchg_u: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.u32, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64_atomic_rmw_cmpxchg: return deferASM(BuiltinSymbols.atomic_cmpxchg, compiler, Type.i64, operands, Type.i64, reportNode);\n\n case BuiltinSymbols.i32_wait: return deferASM(BuiltinSymbols.atomic_wait, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64_wait: return deferASM(BuiltinSymbols.atomic_wait, compiler, Type.i64, operands, Type.i32, reportNode);\n }\n }\n if (compiler.options.hasFeature(Feature.SIMD)) {\n switch (prototype.internalName) {\n\n case BuiltinSymbols.v128_load: return deferASM(BuiltinSymbols.load, compiler, Type.v128, operands, Type.v128, reportNode);\n case BuiltinSymbols.v128_store: return deferASM(BuiltinSymbols.store, compiler, Type.v128, operands, Type.void, reportNode);\n\n case BuiltinSymbols.i8x16_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_extract_lane_s: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.i8, operands, Type.i8, reportNode);\n case BuiltinSymbols.i8x16_extract_lane_u: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.u8, operands, Type.u8, reportNode);\n case BuiltinSymbols.i8x16_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_mul: return deferASM(BuiltinSymbols.v128_mul, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_add_saturate_s: return deferASM(BuiltinSymbols.v128_add_saturate, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_add_saturate_u: return deferASM(BuiltinSymbols.v128_add_saturate, compiler, Type.u8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_sub_saturate_s: return deferASM(BuiltinSymbols.v128_sub_saturate, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_sub_saturate_u: return deferASM(BuiltinSymbols.v128_sub_saturate, compiler, Type.u8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_shl: return deferASM(BuiltinSymbols.v128_shl, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_shr_s: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_shr_u: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.u8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_any_true: return deferASM(BuiltinSymbols.v128_any_true, compiler, Type.i8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i8x16_all_true: return deferASM(BuiltinSymbols.v128_all_true, compiler, Type.i8, operands, Type.i32, reportNode);\n case BuiltinSymbols.i8x16_eq: return deferASM(BuiltinSymbols.v128_eq, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_ne: return deferASM(BuiltinSymbols.v128_ne, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_lt_s: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_lt_u: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.u8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_le_s: return deferASM(BuiltinSymbols.v128_le, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_le_u: return deferASM(BuiltinSymbols.v128_le, compiler, Type.u8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_gt_s: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_gt_u: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.u8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_ge_s: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.i8, operands, Type.v128, reportNode);\n case BuiltinSymbols.i8x16_ge_u: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.u8, operands, Type.v128, reportNode);\n\n case BuiltinSymbols.i16x8_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_extract_lane_s: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.i16, operands, Type.i16, reportNode);\n case BuiltinSymbols.i16x8_extract_lane_u: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.u16, operands, Type.u16, reportNode);\n case BuiltinSymbols.i16x8_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_mul: return deferASM(BuiltinSymbols.v128_mul, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_add_saturate_s: return deferASM(BuiltinSymbols.v128_add_saturate, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_add_saturate_u: return deferASM(BuiltinSymbols.v128_add_saturate, compiler, Type.u16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_sub_saturate_s: return deferASM(BuiltinSymbols.v128_sub_saturate, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_sub_saturate_u: return deferASM(BuiltinSymbols.v128_sub_saturate, compiler, Type.u16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_shl: return deferASM(BuiltinSymbols.v128_shl, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_shr_s: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_shr_u: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.u16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_any_true: return deferASM(BuiltinSymbols.v128_any_true, compiler, Type.i16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i16x8_all_true: return deferASM(BuiltinSymbols.v128_all_true, compiler, Type.i16, operands, Type.i32, reportNode);\n case BuiltinSymbols.i16x8_eq: return deferASM(BuiltinSymbols.v128_eq, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_ne: return deferASM(BuiltinSymbols.v128_ne, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_lt_s: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_lt_u: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.u16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_le_s: return deferASM(BuiltinSymbols.v128_le, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_le_u: return deferASM(BuiltinSymbols.v128_le, compiler, Type.u16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_gt_s: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_gt_u: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.u16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_ge_s: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.i16, operands, Type.v128, reportNode);\n case BuiltinSymbols.i16x8_ge_u: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.u16, operands, Type.v128, reportNode);\n\n case BuiltinSymbols.i32x4_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_extract_lane: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32x4_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_mul: return deferASM(BuiltinSymbols.v128_mul, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_shl: return deferASM(BuiltinSymbols.v128_shl, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_shr_s: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_shr_u: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.u32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_any_true: return deferASM(BuiltinSymbols.v128_any_true, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32x4_all_true: return deferASM(BuiltinSymbols.v128_all_true, compiler, Type.i32, operands, Type.i32, reportNode);\n case BuiltinSymbols.i32x4_eq: return deferASM(BuiltinSymbols.v128_eq, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_ne: return deferASM(BuiltinSymbols.v128_ne, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_lt_s: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_lt_u: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.u32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_le_s: return deferASM(BuiltinSymbols.v128_le, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_le_u: return deferASM(BuiltinSymbols.v128_le, compiler, Type.u32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_gt_s: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_gt_u: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.u32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_ge_s: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_ge_u: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.u32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_trunc_s_f32x4_sat: return deferASM(BuiltinSymbols.v128_trunc, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.i32x4_trunc_u_f32x4_sat: return deferASM(BuiltinSymbols.v128_trunc, compiler, Type.u32, operands, Type.v128, reportNode);\n\n case BuiltinSymbols.i64x2_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.i64, operands, Type.v128, reportNode);\n case BuiltinSymbols.i64x2_extract_lane: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.i64, operands, Type.i64, reportNode);\n case BuiltinSymbols.i64x2_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.i64, operands, Type.v128, reportNode);\n case BuiltinSymbols.i64x2_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.i64, operands, Type.v128, reportNode);\n case BuiltinSymbols.i64x2_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.i64, operands, Type.v128, reportNode);\n case BuiltinSymbols.i64x2_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.i64, operands, Type.v128, reportNode);\n case BuiltinSymbols.i64x2_shl: return deferASM(BuiltinSymbols.v128_shl, compiler, Type.i64, operands, Type.v128, reportNode);\n case BuiltinSymbols.i64x2_shr_s: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.i64, operands, Type.v128, reportNode);\n case BuiltinSymbols.i64x2_shr_u: return deferASM(BuiltinSymbols.v128_shr, compiler, Type.u64, operands, Type.v128, reportNode);\n case BuiltinSymbols.i64x2_any_true: return deferASM(BuiltinSymbols.v128_any_true, compiler, Type.i64, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64x2_all_true: return deferASM(BuiltinSymbols.v128_all_true, compiler, Type.i64, operands, Type.i32, reportNode);\n case BuiltinSymbols.i64x2_trunc_s_f64x2_sat: return deferASM(BuiltinSymbols.v128_trunc, compiler, Type.i64, operands, Type.v128, reportNode);\n case BuiltinSymbols.i64x2_trunc_u_f64x2_sat: return deferASM(BuiltinSymbols.v128_trunc, compiler, Type.u64, operands, Type.v128, reportNode);\n\n case BuiltinSymbols.f32x4_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_extract_lane: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.f32, operands, Type.f32, reportNode);\n case BuiltinSymbols.f32x4_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_mul: return deferASM(BuiltinSymbols.v128_mul, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_div: return deferASM(BuiltinSymbols.v128_div, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_min: return deferASM(BuiltinSymbols.v128_min, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_max: return deferASM(BuiltinSymbols.v128_max, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_abs: return deferASM(BuiltinSymbols.v128_abs, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_sqrt: return deferASM(BuiltinSymbols.v128_sqrt, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_eq: return deferASM(BuiltinSymbols.v128_eq, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_ne: return deferASM(BuiltinSymbols.v128_ne, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_lt: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_le: return deferASM(BuiltinSymbols.v128_le, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_gt: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_ge: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.f32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_convert_s_i32x4: return deferASM(BuiltinSymbols.v128_convert, compiler, Type.i32, operands, Type.v128, reportNode);\n case BuiltinSymbols.f32x4_convert_u_i32x4: return deferASM(BuiltinSymbols.v128_convert, compiler, Type.u32, operands, Type.v128, reportNode);\n\n case BuiltinSymbols.f64x2_splat: return deferASM(BuiltinSymbols.v128_splat, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_extract_lane: return deferASM(BuiltinSymbols.v128_extract_lane, compiler, Type.f64, operands, Type.f64, reportNode);\n case BuiltinSymbols.f64x2_replace_lane: return deferASM(BuiltinSymbols.v128_replace_lane, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_add: return deferASM(BuiltinSymbols.v128_add, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_sub: return deferASM(BuiltinSymbols.v128_sub, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_mul: return deferASM(BuiltinSymbols.v128_mul, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_div: return deferASM(BuiltinSymbols.v128_div, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_neg: return deferASM(BuiltinSymbols.v128_neg, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_min: return deferASM(BuiltinSymbols.v128_min, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_max: return deferASM(BuiltinSymbols.v128_max, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_abs: return deferASM(BuiltinSymbols.v128_abs, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_sqrt: return deferASM(BuiltinSymbols.v128_sqrt, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_eq: return deferASM(BuiltinSymbols.v128_eq, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_ne: return deferASM(BuiltinSymbols.v128_ne, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_lt: return deferASM(BuiltinSymbols.v128_lt, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_le: return deferASM(BuiltinSymbols.v128_le, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_gt: return deferASM(BuiltinSymbols.v128_gt, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_ge: return deferASM(BuiltinSymbols.v128_ge, compiler, Type.f64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_convert_s_i64x2: return deferASM(BuiltinSymbols.v128_convert, compiler, Type.i64, operands, Type.v128, reportNode);\n case BuiltinSymbols.f64x2_convert_u_i64x2: return deferASM(BuiltinSymbols.v128_convert, compiler, Type.u64, operands, Type.v128, reportNode);\n\n case BuiltinSymbols.v8x16_shuffle: return deferASM(BuiltinSymbols.v128_shuffle, compiler, Type.i8, operands, Type.v128, reportNode);\n }\n }\n /* tslint:enable:max-line-length */\n return 0;\n}\n\n/** A helper for deferring inline-assembler-like calls to built-in functions. */\nfunction deferASM(\n name: string,\n compiler: Compiler,\n typeArgument: Type,\n operands: Expression[],\n contextualType: Type,\n reportNode: CallExpression\n): ExpressionRef {\n assert(compiler.program.elementsByName.has(name));\n var prototype = compiler.program.elementsByName.get(name)!;\n assert(prototype.kind == ElementKind.FUNCTION_PROTOTYPE);\n return compileCall(\n compiler,\n prototype,\n [ typeArgument ],\n operands,\n contextualType,\n reportNode,\n /* isAsm */ true\n );\n}\n\n/** Compiles an abort wired to the conditionally imported 'abort' function. */\nexport function compileAbort(\n compiler: Compiler,\n message: Expression | null,\n reportNode: Node\n): ExpressionRef {\n var program = compiler.program;\n var module = compiler.module;\n\n var stringInstance = compiler.program.stringInstance;\n if (!stringInstance) return module.unreachable();\n\n var abortInstance = program.abortInstance;\n if (!(abortInstance && compiler.compileFunction(abortInstance))) return module.unreachable();\n\n var messageArg: ExpressionRef;\n if (message !== null) {\n // The message argument works much like an arm of an IF that does not become executed if the\n // assertion succeeds respectively is only being computed if the program actually crashes.\n // Hence, let's make it so that the autorelease is skipped at the end of the current block,\n // essentially ignoring the message GC-wise. Doesn't matter anyway on a crash.\n messageArg = compiler.compileExpression(message, stringInstance.type, Constraints.CONV_IMPLICIT | Constraints.WILL_RETAIN);\n } else {\n messageArg = stringInstance.type.toNativeZero(module);\n }\n\n var filenameArg = compiler.ensureStaticString(reportNode.range.source.normalizedPath);\n\n compiler.currentType = Type.void;\n return module.block(null, [\n module.call(\n abortInstance.internalName, [\n messageArg,\n filenameArg,\n module.i32(reportNode.range.line),\n module.i32(reportNode.range.column)\n ],\n NativeType.None\n ),\n module.unreachable()\n ]);\n}\n\n/** Compiles the `visit_globals` function. */\nexport function compileVisitGlobals(compiler: Compiler): void {\n var module = compiler.module;\n var exprs = new Array();\n var typeRef = compiler.ensureFunctionType([ Type.u32 ], Type.void); // cookie\n var nativeSizeType = compiler.options.nativeSizeType;\n var visitInstance = assert(compiler.program.visitInstance);\n\n compiler.compileFunction(visitInstance);\n\n for (let element of compiler.program.elementsByName.values()) {\n if (element.kind != ElementKind.GLOBAL) continue;\n let global = element;\n let classReference = global.type.classReference;\n if (\n global.is(CommonFlags.COMPILED) &&\n classReference !== null &&\n !classReference.hasDecorator(DecoratorFlags.UNMANAGED)\n ) {\n if (global.is(CommonFlags.INLINED)) {\n let value = global.constantIntegerValue;\n if (i64_low(value) || i64_high(value)) {\n exprs.push(\n module.call(visitInstance.internalName, [\n compiler.options.isWasm64\n ? module.i64(i64_low(value), i64_high(value))\n : module.i32(i64_low(value))\n ], NativeType.None)\n );\n }\n } else {\n exprs.push(\n module.if(\n module.local_tee(1,\n module.global_get(global.internalName, nativeSizeType)\n ),\n module.call(visitInstance.internalName, [\n module.local_get(1, nativeSizeType), // tempRef != null\n module.local_get(0, NativeType.I32) // cookie\n ], NativeType.None)\n )\n );\n }\n }\n }\n module.addFunction(BuiltinSymbols.visit_globals, typeRef, [ nativeSizeType ],\n exprs.length\n ? module.block(null, exprs)\n : module.nop()\n );\n}\n\n/** Compiles the `visit_members` function. */\nexport function compileVisitMembers(compiler: Compiler): void {\n var program = compiler.program;\n var module = compiler.module;\n var usizeType = program.options.usizeType;\n var nativeSizeType = usizeType.toNativeType();\n var nativeSizeSize = usizeType.byteSize;\n var ftype = compiler.ensureFunctionType([ usizeType, Type.i32 ], Type.void); // ref, cookie\n var managedClasses = program.managedClasses;\n var visitInstance = assert(program.visitInstance);\n var blocks = new Array();\n var relooper = Relooper.create(module);\n\n var outer = relooper.addBlockWithSwitch(\n module.nop(),\n module.load(nativeSizeSize, false,\n nativeSizeType == NativeType.I64\n ? module.binary(BinaryOp.SubI64,\n module.local_get(0, nativeSizeType),\n module.i64(8)\n )\n : module.binary(BinaryOp.SubI32,\n module.local_get(0, nativeSizeType),\n module.i32(8) // rtId is at -8\n ),\n NativeType.I32,\n 0\n )\n );\n\n var lastId = 0;\n for (let [id, instance] of managedClasses) {\n assert(instance.type.isManaged);\n assert(id == lastId++);\n\n let visitImpl: Element | null;\n let code = new Array();\n\n // if a library element, check if it implements a custom traversal function\n if (instance.isDeclaredInLibrary && (visitImpl = instance.lookupInSelf(\"__visit_impl\"))) {\n assert(visitImpl.kind == ElementKind.FUNCTION_PROTOTYPE);\n let visitFunc = program.resolver.resolveFunction(visitImpl, null);\n if (!visitFunc || !compiler.compileFunction(visitFunc)) {\n code.push(\n module.unreachable()\n );\n } else {\n let visitSig = visitFunc.signature;\n assert(\n visitSig.parameterTypes.length == 1 &&\n visitSig.parameterTypes[0] == Type.u32 &&\n visitSig.returnType == Type.void &&\n visitSig.thisType == instance.type\n );\n code.push(\n module.call(visitFunc.internalName, [\n module.local_get(0, nativeSizeType), // ref\n module.local_get(1, NativeType.I32) // cookie\n ], NativeType.None)\n );\n }\n\n // otherwise generate traversal logic for own fields\n } else {\n let members = instance.members;\n if (members) {\n for (let member of members.values()) {\n if (member.kind == ElementKind.FIELD) {\n if ((member).parent === instance) {\n let fieldType = (member).type;\n if (fieldType.isManaged) {\n let fieldOffset = (member).memoryOffset;\n assert(fieldOffset >= 0);\n code.push(\n // if ($2 = value) FIELDCLASS~traverse($2)\n module.if(\n module.local_tee(2,\n module.load(nativeSizeSize, false,\n module.local_get(0, nativeSizeType),\n nativeSizeType, fieldOffset\n )\n ),\n module.call(visitInstance.internalName, [\n module.local_get(2, nativeSizeType), // ref\n module.local_get(1, NativeType.I32) // cookie\n ], NativeType.None)\n )\n );\n }\n }\n }\n }\n }\n }\n if (!instance.base) code.push(module.return());\n let block = relooper.addBlock(\n flatten(module, code, NativeType.None)\n );\n relooper.addBranchForSwitch(outer, block, [ id ]);\n blocks.push(block);\n }\n for (let [id, instance] of managedClasses) {\n let base = instance.base;\n if (base) {\n relooper.addBranch(blocks[id], blocks[base.id]);\n }\n }\n blocks.push(\n relooper.addBlock(\n module.unreachable()\n )\n );\n relooper.addBranchForSwitch(outer, blocks[blocks.length - 1], []); // default\n compiler.compileFunction(visitInstance);\n module.addFunction(BuiltinSymbols.visit_members, ftype, [ nativeSizeType ], relooper.renderAndDispose(outer, 2));\n}\n\nfunction typeToRuntimeFlags(type: Type): TypeinfoFlags {\n var flags = TypeinfoFlags.VALUE_ALIGN_0 * (1 << type.alignLog2);\n if (type.is(TypeFlags.SIGNED)) flags |= TypeinfoFlags.VALUE_SIGNED;\n if (type.is(TypeFlags.FLOAT)) flags |= TypeinfoFlags.VALUE_FLOAT;\n if (type.is(TypeFlags.NULLABLE)) flags |= TypeinfoFlags.VALUE_NULLABLE;\n if (type.isManaged) flags |= TypeinfoFlags.VALUE_MANAGED;\n return flags / TypeinfoFlags.VALUE_ALIGN_0;\n}\n\n/** Compiles runtime type information for use by stdlib. */\nexport function compileRTTI(compiler: Compiler): void {\n var program = compiler.program;\n var module = compiler.module;\n var managedClasses = program.managedClasses;\n var count = managedClasses.size;\n var size = 4 + 8 * count;\n var data = new Uint8Array(size);\n writeI32(count, data, 0);\n var off = 4;\n var abvInstance = program.arrayBufferViewInstance;\n var abvPrototype = abvInstance.prototype;\n var arrayPrototype = program.arrayPrototype;\n var setPrototype = program.setPrototype;\n var mapPrototype = program.mapPrototype;\n var lastId = 0;\n for (let [id, instance] of managedClasses) {\n assert(id == lastId++);\n let flags: TypeinfoFlags = 0;\n if (instance.isAcyclic) flags |= TypeinfoFlags.ACYCLIC;\n if (instance !== abvInstance && instance.extends(abvPrototype)) {\n let valueType = instance.getArrayValueType();\n flags |= TypeinfoFlags.ARRAYBUFFERVIEW;\n if (instance.extends(arrayPrototype)) flags |= TypeinfoFlags.ARRAY;\n flags |= TypeinfoFlags.VALUE_ALIGN_0 * typeToRuntimeFlags(valueType);\n } else if (instance.extends(setPrototype)) {\n let typeArguments = assert(instance.getTypeArgumentsTo(setPrototype));\n assert(typeArguments.length == 1);\n flags |= TypeinfoFlags.SET;\n flags |= TypeinfoFlags.VALUE_ALIGN_0 * typeToRuntimeFlags(typeArguments[0]);\n } else if (instance.extends(mapPrototype)) {\n let typeArguments = assert(instance.getTypeArgumentsTo(mapPrototype));\n assert(typeArguments.length == 2);\n flags |= TypeinfoFlags.MAP;\n flags |= TypeinfoFlags.KEY_ALIGN_0 * typeToRuntimeFlags(typeArguments[0]);\n flags |= TypeinfoFlags.VALUE_ALIGN_0 * typeToRuntimeFlags(typeArguments[1]);\n }\n writeI32(flags, data, off); off += 4;\n instance.rttiFlags = flags;\n let base = instance.base;\n writeI32(base ? base.id : 0, data, off); off += 4;\n }\n assert(off == size);\n var usizeType = program.options.usizeType;\n var segment = compiler.addMemorySegment(data);\n if (usizeType.size == 8) {\n let offset = segment.offset;\n module.addGlobal(BuiltinSymbols.rtti_base, NativeType.I64, false, module.i64(i64_low(offset), i64_high(offset)));\n } else {\n module.addGlobal(BuiltinSymbols.rtti_base, NativeType.I32, false, module.i32(i64_low(segment.offset)));\n }\n}\n\n// Helpers\n\n/** Evaluates the constant type of a type argument *or* expression. */\nfunction evaluateConstantType(\n compiler: Compiler,\n typeArguments: Type[] | null,\n operands: Expression[],\n reportNode: CallExpression\n): Type | null {\n if (operands.length == 0) { // requires type argument\n if (!typeArguments || typeArguments.length != 1) {\n compiler.error(\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\n reportNode.typeArgumentsRange, \"1\", typeArguments ? typeArguments.length.toString(10) : \"0\"\n );\n return null;\n }\n return typeArguments[0];\n }\n if (operands.length == 1) { // optional type argument\n if (typeArguments !== null && typeArguments.length) {\n if (typeArguments.length > 1) {\n compiler.error(\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\n reportNode.typeArgumentsRange, \"1\", typeArguments.length.toString(10)\n );\n return null;\n }\n compiler.compileExpression(operands[0], typeArguments[0], Constraints.CONV_IMPLICIT);\n } else {\n compiler.compileExpression(operands[0], Type.auto);\n }\n return compiler.currentType;\n }\n if (typeArguments && typeArguments.length > 1) {\n compiler.error(\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\n reportNode.typeArgumentsRange, \"1\", typeArguments.length.toString(10)\n );\n }\n compiler.error(\n DiagnosticCode.Expected_0_arguments_but_got_1,\n reportNode.argumentsRange, \"1\", operands.length.toString(10)\n );\n return null;\n}\n\n/** Evaluates a compile-time constant immediate offset argument.*/\nfunction evaluateImmediateOffset(expression: Expression, compiler: Compiler): i32 {\n var expr: ExpressionRef;\n var value: i32;\n if (compiler.options.isWasm64) {\n expr = compiler.precomputeExpression(expression, Type.usize64, Constraints.CONV_IMPLICIT);\n if (\n getExpressionId(expr) != ExpressionId.Const ||\n getExpressionType(expr) != NativeType.I64 ||\n getConstValueI64High(expr) != 0 ||\n (value = getConstValueI64Low(expr)) < 0\n ) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n expression.range\n );\n value = -1;\n }\n } else {\n expr = compiler.precomputeExpression(expression, Type.usize32, Constraints.CONV_IMPLICIT);\n if (\n getExpressionId(expr) != ExpressionId.Const ||\n getExpressionType(expr) != NativeType.I32 ||\n (value = getConstValueI32(expr)) < 0\n ) {\n compiler.error(\n DiagnosticCode.Expression_must_be_a_compile_time_constant,\n expression.range\n );\n value = -1;\n }\n }\n return value;\n}\n\n/** Checks a call with a single required type argument. Returns `1` on error. */\nfunction checkTypeRequired(\n typeArguments: Type[] | null,\n reportNode: CallExpression,\n compiler: Compiler,\n setCurrentTypeOnError: bool = false\n): i32 {\n if (typeArguments) {\n let numTypeArguments = typeArguments.length;\n if (numTypeArguments == 1) return 0;\n assert(numTypeArguments); // invalid if 0, must not be set at all instead\n if (setCurrentTypeOnError) compiler.currentType = typeArguments[0];\n compiler.error(\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\n reportNode.typeArgumentsRange, \"1\", numTypeArguments.toString()\n );\n } else {\n compiler.error(\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\n reportNode.range, \"1\", \"0\"\n );\n }\n return 1;\n}\n\n/** Checks a call with a single optional type argument. Returns `1` on error. */\nfunction checkTypeOptional(\n typeArguments: Type[] | null,\n reportNode: CallExpression,\n compiler: Compiler,\n setCurrentTypeOnError: bool = false\n): i32 {\n if (typeArguments) {\n let numTypeArguments = typeArguments.length;\n if (numTypeArguments == 1) return 0;\n assert(numTypeArguments); // invalid if 0, must not be set at all instead\n if (setCurrentTypeOnError) compiler.currentType = typeArguments[0];\n compiler.error(\n DiagnosticCode.Expected_0_type_arguments_but_got_1,\n reportNode.typeArgumentsRange, \"1\", numTypeArguments.toString()\n );\n return 1;\n }\n return 0;\n}\n\n/** Checks a call that is not generic. Returns `1` on error. */\nfunction checkTypeAbsent(\n typeArguments: Type[] | null,\n reportNode: CallExpression,\n prototype: FunctionPrototype\n): i32 {\n if (typeArguments) {\n prototype.program.error(\n DiagnosticCode.Type_0_is_not_generic,\n reportNode.typeArgumentsRange, prototype.internalName\n );\n return 1;\n }\n return 0;\n}\n\n/** Checks a call that requires a fixed number of arguments. Returns `1` on error. */\nfunction checkArgsRequired(\n operands: Expression[],\n expected: i32,\n reportNode: CallExpression,\n compiler: Compiler\n): i32 {\n if (operands.length != expected) {\n compiler.error(\n DiagnosticCode.Expected_0_arguments_but_got_1,\n reportNode.range, expected.toString(), operands.length.toString()\n );\n return 1;\n }\n return 0;\n}\n\n/** Checks a call that requires a variable number of arguments. Returns `1` on error. */\nfunction checkArgsOptional(\n operands: Expression[],\n expectedMinimum: i32,\n expectedMaximum: i32,\n reportNode: CallExpression,\n compiler: Compiler\n): i32 {\n var numOperands = operands.length;\n if (numOperands < expectedMinimum) {\n compiler.error(\n DiagnosticCode.Expected_at_least_0_arguments_but_got_1,\n reportNode.range, expectedMinimum.toString(), numOperands.toString()\n );\n return 1;\n } else if (numOperands > expectedMaximum) {\n compiler.error(\n DiagnosticCode.Expected_0_arguments_but_got_1,\n reportNode.range, expectedMaximum.toString(), numOperands.toString()\n );\n return 1;\n }\n return 0;\n}\n","/**\n * A decompiler that generates low-level AssemblyScript from WebAssembly binaries.\n * @module decompiler\n *//***/\n\nimport {\n Module,\n NativeType,\n ExpressionId,\n UnaryOp,\n BinaryOp,\n HostOp,\n FunctionRef,\n ExpressionRef,\n Index,\n getFunctionName,\n getFunctionBody,\n getFunctionParamCount,\n getFunctionParamType,\n getFunctionResultType,\n getExpressionId,\n getExpressionType,\n getBlockName,\n getBlockChildCount,\n getBlockChild,\n getIfCondition,\n getIfTrue,\n getIfFalse,\n getLoopName,\n getLoopBody,\n getBreakName,\n getBreakCondition,\n getLocalGetIndex,\n getLocalSetIndex,\n getLocalSetValue,\n getLoadOffset,\n getLoadPtr,\n getStoreOffset,\n getStorePtr,\n getStoreValue,\n getConstValueI32,\n getConstValueI64Low,\n getConstValueI64High,\n getConstValueF32,\n getConstValueF64,\n getUnaryOp,\n getUnaryValue,\n getBinaryOp,\n getBinaryLeft,\n getBinaryRight,\n getSelectThen,\n getSelectElse,\n getSelectCondition,\n getDropValue,\n getReturnValue,\n getHostOp,\n getHostOperand\n} from \"./module\";\n\n// TODO :-)\n\nexport class Decompiler {\n\n static decompile(module: Module): string {\n var decompiler = new Decompiler();\n decompiler.decompile(module);\n return decompiler.finish();\n }\n\n text: string[] = [];\n functionId: i32 = 0;\n\n constructor() { }\n\n /** Decompiles a module to an AST that can then be serialized. */\n decompile(module: Module): void {\n throw new Error(\"not implemented\");\n }\n\n decompileFunction(func: FunctionRef): void {\n var name = getFunctionName(func) || \"$\" + this.functionId.toString(10);\n var body = getFunctionBody(func);\n this.push(\"function \");\n this.push(name);\n this.push(\"(\");\n for (let i: Index = 0, k: Index = getFunctionParamCount(func); i < k; ++i) {\n if (i > 0) this.push(\", \");\n this.push(\"$\");\n this.push(i.toString(10));\n this.push(\": \");\n this.push(nativeTypeToType(getFunctionParamType(func, i)));\n }\n this.push(\"): \");\n this.push(nativeTypeToType(getFunctionResultType(func)));\n this.push(\" \");\n if (getExpressionId(body) != ExpressionId.Block) {\n this.push(\"{\\n\");\n }\n this.decompileExpression(body);\n if (getExpressionId(body) != ExpressionId.Block) {\n this.push(\"\\n}\\n\");\n }\n ++this.functionId;\n }\n\n decompileExpression(expr: ExpressionRef): void {\n var id = getExpressionId(expr);\n var type = getExpressionType(expr);\n\n var nested: ExpressionRef;\n var string: string | null;\n var i: Index, k: Index;\n\n switch (id) {\n case ExpressionId.Block: { // TODO: magic\n if ((string = getBlockName(expr)) != null) {\n this.push(string);\n this.push(\": \");\n }\n this.push(\"{\\n\");\n k = getBlockChildCount(expr);\n for (i = 0; i < k; ++i) {\n this.decompileExpression(getBlockChild(expr, i));\n }\n this.push(\"}\\n\");\n return;\n }\n case ExpressionId.If: {\n if (type == NativeType.None) {\n this.push(\"if (\");\n this.decompileExpression(getIfCondition(expr));\n this.push(\") \");\n this.decompileExpression(getIfTrue(expr));\n if (nested = getIfFalse(expr)) {\n this.push(\" else \");\n this.decompileExpression(nested);\n }\n } else {\n this.decompileExpression(getIfCondition(expr));\n this.push(\" ? \");\n this.decompileExpression(getIfTrue(expr));\n this.push(\" : \");\n this.decompileExpression(getIfFalse(expr));\n }\n return;\n }\n case ExpressionId.Loop: {\n if ((string = getLoopName(expr)) != null) {\n this.push(string);\n this.push(\": \");\n }\n this.push(\"do \");\n this.decompileExpression(getLoopBody(expr));\n this.push(\"while (0);\\n\");\n }\n case ExpressionId.Break: {\n if (nested = getBreakCondition(expr)) {\n this.push(\"if (\");\n this.decompileExpression(nested);\n this.push(\") \");\n }\n if ((string = getBreakName(expr)) != null) {\n this.push(\"break \");\n this.push(string);\n this.push(\";\\n\");\n } else {\n this.push(\"break;\\n\");\n }\n return;\n }\n case ExpressionId.Switch:\n case ExpressionId.Call:\n case ExpressionId.CallIndirect: {\n throw new Error(\"not implemented\");\n }\n case ExpressionId.LocalGet: {\n this.push(\"$\");\n this.push(getLocalGetIndex(expr).toString(10));\n return;\n }\n case ExpressionId.LocalSet: {\n this.push(\"$\");\n this.push(getLocalSetIndex(expr).toString(10));\n this.push(\" = \");\n this.decompileExpression(getLocalSetValue(expr));\n return;\n }\n case ExpressionId.GlobalGet:\n case ExpressionId.GlobalSet: {\n throw new Error(\"not implemented\");\n }\n case ExpressionId.Load: {\n this.push(\"load<\");\n this.push(nativeTypeToType(type));\n this.push(\">(\");\n this.push(getLoadOffset(expr).toString(10));\n this.push(\" + \");\n this.decompileExpression(getLoadPtr(expr));\n this.push(\")\");\n return;\n }\n case ExpressionId.Store: {\n this.push(\"store<\");\n this.push(nativeTypeToType(type));\n this.push(\">(\");\n this.push(getStoreOffset(expr).toString(10));\n this.push(\" + \");\n this.decompileExpression(getStorePtr(expr));\n this.push(\", \");\n this.decompileExpression(getStoreValue(expr));\n this.push(\")\");\n return;\n }\n case ExpressionId.Const: {\n switch (type) {\n case NativeType.I32: {\n this.push(getConstValueI32(expr).toString(10));\n return;\n }\n case NativeType.I64: {\n this.push(\n i64_to_string(\n i64_new(\n getConstValueI64Low(expr),\n getConstValueI64High(expr)\n )\n )\n );\n return;\n }\n case NativeType.F32: {\n this.push(getConstValueF32(expr).toString(10));\n return;\n }\n case NativeType.F64: {\n this.push(getConstValueF64(expr).toString(10));\n return;\n }\n }\n break;\n }\n case ExpressionId.Unary: {\n switch (getUnaryOp(expr)) {\n case UnaryOp.ClzI32: {\n this.push(\"clz(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.CtzI32: {\n this.push(\"ctz(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.PopcntI32: {\n this.push(\"popcnt(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.NegF32:\n case UnaryOp.NegF64: {\n this.push(\"-\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.AbsF32: {\n this.push(\"abs(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.CeilF32: {\n this.push(\"ceil(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.FloorF32: {\n this.push(\"floor(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.TruncF32: {\n this.push(\"trunc(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.NearestF32: {\n this.push(\"nearest(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.SqrtF32: {\n this.push(\"sqrt(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.EqzI32:\n case UnaryOp.EqzI64: {\n this.push(\"!\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ClzI64: {\n this.push(\"clz(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.CtzI64: {\n this.push(\"ctz(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.PopcntI64: {\n this.push(\"popcnt(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.AbsF64: {\n this.push(\"abs(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.CeilF64: {\n this.push(\"ceil(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.FloorF64: {\n this.push(\"floor(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.TruncF64: {\n this.push(\"trunc(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.NearestF64: {\n this.push(\"nearest(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.SqrtF64: {\n this.push(\"sqrt(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.ExtendI32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ExtendU32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.WrapI64: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.TruncF32ToI32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.TruncF32ToI64: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.TruncF32ToU32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.TruncF32ToU64: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.TruncF64ToI32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.TruncF64ToI64: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.TruncF64ToU32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.TruncF64ToU64: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ReinterpretF32: {\n this.push(\"reinterpret(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.ReinterpretF64: {\n this.push(\"reinterpret(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.ConvertI32ToF32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ConvertI32ToF64: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ConvertU32ToF32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ConvertU32ToF64: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ConvertI64ToF32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ConvertI64ToF64: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ConvertU64ToF32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ConvertU64ToF64: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.PromoteF32: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.DemoteF64: {\n this.push(\"\");\n this.decompileExpression(getUnaryValue(expr));\n return;\n }\n case UnaryOp.ReinterpretI32: {\n this.push(\"reinterpret(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n case UnaryOp.ReinterpretI64: {\n this.push(\"reinterpret(\");\n this.decompileExpression(getUnaryValue(expr));\n this.push(\")\");\n return;\n }\n }\n break;\n }\n case ExpressionId.Binary: { // TODO: precedence\n switch (getBinaryOp(expr)) {\n case BinaryOp.AddI32:\n case BinaryOp.AddI64:\n case BinaryOp.AddF32:\n case BinaryOp.AddF64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" + \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.SubI32:\n case BinaryOp.SubI64:\n case BinaryOp.SubF32:\n case BinaryOp.SubF64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" - \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.MulI32:\n case BinaryOp.MulI64:\n case BinaryOp.MulF32:\n case BinaryOp.MulF64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" * \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.DivI32:\n case BinaryOp.DivI64:\n case BinaryOp.DivF32:\n case BinaryOp.DivF64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" / \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.DivU32: {\n this.push(\"(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" / \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.RemI32:\n case BinaryOp.RemI64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" % \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.RemU32: {\n this.push(\"(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" / \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.AndI32:\n case BinaryOp.AndI64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" & \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.OrI32:\n case BinaryOp.OrI64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" | \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.XorI32:\n case BinaryOp.XorI64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" ^ \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.ShlI32:\n case BinaryOp.ShlI64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" << \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.ShrU32:\n case BinaryOp.ShrU64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" >>> \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.ShrI32:\n case BinaryOp.ShrI64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" >> \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.RotlI32: {\n this.push(\"rotl(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\", \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.RotrI32: {\n this.push(\"rotr(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\", \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.EqI32:\n case BinaryOp.EqI64:\n case BinaryOp.EqF32:\n case BinaryOp.EqF64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" == \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.NeI32:\n case BinaryOp.NeI64:\n case BinaryOp.NeF32:\n case BinaryOp.NeF64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" != \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.LtI32:\n case BinaryOp.LtI64:\n case BinaryOp.LtF32:\n case BinaryOp.LtF64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" < \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.LtU32: {\n this.push(\"\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" < \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.LeI32:\n case BinaryOp.LeI64:\n case BinaryOp.LeF32:\n case BinaryOp.LeF64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" <= \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.LeU32: {\n this.push(\"\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" <= \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.GtI32:\n case BinaryOp.GtI64:\n case BinaryOp.GtF32:\n case BinaryOp.GtF64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" > \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.GtU32: {\n this.push(\"\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" > \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.GeI32:\n case BinaryOp.GeI64:\n case BinaryOp.GeF32:\n case BinaryOp.GeF64: {\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" >= \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.GeU32: {\n this.push(\"\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" >= \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.DivU64: {\n this.push(\"\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" / \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.RemU64: {\n this.push(\"\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" % \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.RotlI64: {\n this.push(\"rotl(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\", \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.RotrI64: {\n this.push(\"rotr(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\", \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.LtU64: {\n this.push(\"\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" < \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.LeU64: {\n this.push(\"\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" <= \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.GtU64: {\n this.push(\"\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" > \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.GeU64: {\n this.push(\"\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\" >= \");\n this.decompileExpression(getBinaryRight(expr));\n return;\n }\n case BinaryOp.CopysignF32: {\n this.push(\"copysign(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\", \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.MinF32: {\n this.push(\"min(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\", \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.MaxF32: {\n this.push(\"max(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\", \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.CopysignF64: {\n this.push(\"copysign(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\", \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.MinF64: {\n this.push(\"min(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\", \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n case BinaryOp.MaxF64: {\n this.push(\"max(\");\n this.decompileExpression(getBinaryLeft(expr));\n this.push(\", \");\n this.decompileExpression(getBinaryRight(expr));\n this.push(\")\");\n return;\n }\n }\n return;\n }\n case ExpressionId.Select: {\n this.push(\"select<\");\n this.push(nativeTypeToType(type));\n this.push(\">(\");\n this.decompileExpression(getSelectThen(expr));\n this.push(\", \");\n this.decompileExpression(getSelectElse(expr));\n this.push(\", \");\n this.decompileExpression(getSelectCondition(expr));\n this.push(\")\");\n return;\n }\n case ExpressionId.Drop: {\n this.decompileExpression(getDropValue(expr));\n this.push(\";\\n\");\n return;\n }\n case ExpressionId.Return: {\n if (nested = getReturnValue(expr)) {\n this.push(\"return \");\n this.decompileExpression(nested);\n this.push(\";\\n\");\n } else {\n this.push(\"return;\\n\");\n }\n return;\n }\n case ExpressionId.Host: {\n switch (getHostOp(expr)) {\n case HostOp.MemorySize: {\n this.push(\"memory.size()\");\n return;\n }\n case HostOp.MemoryGrow: {\n this.push(\"memory.grow(\");\n this.decompileExpression(getHostOperand(expr, 0));\n this.push(\")\");\n return;\n }\n }\n break;\n }\n case ExpressionId.Nop: {\n this.push(\";\\n\");\n return;\n }\n case ExpressionId.Unreachable: {\n this.push(\"unreachable()\");\n return;\n }\n case ExpressionId.AtomicCmpxchg:\n case ExpressionId.AtomicRMW:\n case ExpressionId.AtomicWait:\n case ExpressionId.AtomicNotify:\n }\n throw new Error(\"not implemented\");\n }\n\n private push(text: string): void {\n // mostly here so we can add debugging if necessary\n this.text.push(text);\n }\n\n finish(): string {\n var ret = this.text.join(\"\");\n this.text = [];\n return ret;\n }\n}\n\nfunction nativeTypeToType(type: NativeType): string {\n switch (type) {\n case NativeType.None: return \"void\";\n case NativeType.I32: return \"i32\";\n case NativeType.I64: return \"i64\";\n case NativeType.F32: return \"f32\";\n case NativeType.F64: return \"f64\";\n case NativeType.V128: return \"v128\";\n case NativeType.Unreachable: throw new Error(\"unreachable type\");\n case NativeType.Auto: throw new Error(\"auto type\");\n default: throw new Error(\"unexpected type\");\n }\n}\n","/**\n * Definition builders for WebIDL and TypeScript.\n * @module definitions\n *//***/\n\n import {\n CommonFlags\n} from \"./common\";\n\nimport {\n Program,\n Element,\n ElementKind,\n Global,\n Enum,\n EnumValue,\n Field,\n Function,\n FunctionPrototype,\n Class,\n ClassPrototype,\n Namespace,\n ConstantValueKind,\n Interface,\n Property,\n PropertyPrototype,\n File\n} from \"./program\";\n\nimport {\n Type,\n TypeKind\n} from \"./types\";\n\nimport {\n indent\n} from \"./util\";\n\n/** Walker base class. */\nabstract class ExportsWalker {\n\n /** Program reference. */\n program: Program;\n /** Whether to include private members */\n includePrivate: bool;\n /** Already seen elements. */\n seen: Map = new Map();\n\n /** Constructs a new Element walker. */\n constructor(program: Program, includePrivate: bool = false) {\n this.program = program;\n this.includePrivate;\n }\n\n /** Walks all elements and calls the respective handlers. */\n walk(): void {\n for (let file of this.program.filesByName.values()) {\n if (file.source.isEntry) this.visitFile(file);\n }\n }\n\n /** Visits all exported elements of a file. */\n visitFile(file: File): void {\n var members = file.exports;\n if (members) {\n for (let [name, member] of members) this.visitElement(name, member);\n }\n var exportsStar = file.exportsStar;\n if (exportsStar) {\n for (let exportStar of exportsStar) this.visitFile(exportStar);\n }\n }\n\n /** Visits an element.*/\n visitElement(name: string, element: Element): void {\n if (element.is(CommonFlags.PRIVATE) && !this.includePrivate) return;\n var seen = this.seen;\n if (seen.has(element)) {\n this.visitAlias(name, element, seen.get(element));\n return;\n }\n seen.set(element, name);\n switch (element.kind) {\n case ElementKind.GLOBAL: {\n if (element.is(CommonFlags.COMPILED)) this.visitGlobal(name, element);\n break;\n }\n case ElementKind.ENUM: {\n if (element.is(CommonFlags.COMPILED)) this.visitEnum(name, element);\n break;\n }\n case ElementKind.FUNCTION_PROTOTYPE: {\n this.visitFunctionInstances(name, element);\n break;\n }\n case ElementKind.CLASS_PROTOTYPE: {\n this.visitClassInstances(name, element);\n break;\n }\n case ElementKind.FIELD: {\n if ((element).is(CommonFlags.COMPILED)) this.visitField(name, element);\n break;\n }\n case ElementKind.PROPERTY_PROTOTYPE: {\n this.visitPropertyInstances(name, element);\n break;\n }\n case ElementKind.PROPERTY: {\n let prop = element;\n let getter = prop.getterInstance;\n if (getter) this.visitFunction(name, getter);\n let setter = prop.setterInstance;\n if (setter) this.visitFunction(name, setter);\n break;\n }\n case ElementKind.NAMESPACE: {\n if (hasCompiledMember(element)) this.visitNamespace(name, element);\n break;\n }\n case ElementKind.TYPEDEFINITION: break;\n default: assert(false);\n }\n }\n\n private visitFunctionInstances(name: string, element: FunctionPrototype): void {\n var instances = element.instances;\n if (instances) {\n for (let instance of instances.values()) {\n if (instance.is(CommonFlags.COMPILED)) this.visitFunction(name, instance);\n }\n }\n }\n\n private visitClassInstances(name: string, element: ClassPrototype): void {\n var instances = element.instances;\n if (instances) {\n for (let instance of instances.values()) {\n if (instance.is(CommonFlags.COMPILED)) this.visitClass(name, instance);\n }\n }\n }\n\n private visitPropertyInstances(name: string, element: PropertyPrototype): void {\n // var instances = element.instances;\n // if (instances) {\n // for (let instance of instances.values()) {\n // if (instance.is(CommonFlags.COMPILED)) this.visitProperty(instance);\n // }\n // }\n assert(false);\n }\n\n abstract visitGlobal(name: string, element: Global): void;\n abstract visitEnum(name: string, element: Enum): void;\n abstract visitFunction(name: string, element: Function): void;\n abstract visitClass(name: string, element: Class): void;\n abstract visitInterface(name: string, element: Interface): void;\n abstract visitField(name: string, element: Field): void;\n abstract visitNamespace(name: string, element: Element): void;\n abstract visitAlias(name: string, element: Element, originalName: string): void;\n}\n\n/** A WebIDL definitions builder. */\nexport class IDLBuilder extends ExportsWalker {\n\n /** Builds WebIDL definitions for the specified program. */\n static build(program: Program): string {\n return new IDLBuilder(program).build();\n }\n\n private sb: string[] = [];\n private indentLevel: i32 = 0;\n\n /** Constructs a new WebIDL builder. */\n constructor(program: Program, includePrivate: bool = false) {\n super(program, includePrivate);\n }\n\n visitGlobal(name: string, element: Global): void {\n var sb = this.sb;\n var isConst = element.is(CommonFlags.INLINED);\n indent(sb, this.indentLevel);\n if (isConst) sb.push(\"const \");\n sb.push(this.typeToString(element.type));\n sb.push(\" \");\n sb.push(name);\n if (isConst) {\n switch (element.constantValueKind) {\n case ConstantValueKind.INTEGER: {\n sb.push(\" = \");\n sb.push(i64_to_string(element.constantIntegerValue));\n break;\n }\n case ConstantValueKind.FLOAT: {\n sb.push(\" = \");\n sb.push(element.constantFloatValue.toString());\n break;\n }\n default: assert(false);\n }\n }\n sb.push(\";\\n\");\n }\n\n visitEnum(name: string, element: Enum): void {\n var sb = this.sb;\n indent(sb, this.indentLevel++);\n sb.push(\"interface \");\n sb.push(name);\n sb.push(\" {\\n\");\n var members = element.members;\n if (members) {\n for (let [name, member] of members) {\n if (member.kind == ElementKind.ENUMVALUE) {\n let isConst = (member).is(CommonFlags.INLINED);\n indent(sb, this.indentLevel);\n if (isConst) sb.push(\"const \");\n else sb.push(\"readonly \");\n sb.push(\"unsigned long \");\n sb.push(name);\n if (isConst) {\n sb.push(\" = \");\n assert((member).constantValueKind == ConstantValueKind.INTEGER);\n sb.push(i64_low((member).constantIntegerValue).toString(10));\n }\n sb.push(\";\\n\");\n }\n }\n for (let member of members.values()) {\n if (member.kind != ElementKind.ENUMVALUE) this.visitElement(member.name, member);\n }\n }\n indent(sb, --this.indentLevel);\n sb.push(\"}\\n\");\n }\n\n visitFunction(name: string, element: Function): void {\n var sb = this.sb;\n var signature = element.signature;\n indent(sb, this.indentLevel);\n sb.push(this.typeToString(signature.returnType));\n sb.push(\" \");\n sb.push(name);\n sb.push(\"(\");\n var parameters = signature.parameterTypes;\n var numParameters = parameters.length;\n // var requiredParameters = signature.requiredParameters;\n for (let i = 0; i < numParameters; ++i) {\n if (i) sb.push(\", \");\n // if (i >= requiredParameters) sb.push(\"optional \");\n sb.push(this.typeToString(parameters[i]));\n sb.push(\" \");\n sb.push(signature.getParameterName(i));\n }\n sb.push(\");\\n\");\n var members = element.members;\n if (members && members.size) {\n indent(sb, this.indentLevel);\n sb.push(\"interface \");\n sb.push(element.name);\n sb.push(\" {\\n\");\n for (let member of members.values()) this.visitElement(member.name, member);\n indent(sb, --this.indentLevel);\n sb.push(\"}\\n\");\n }\n }\n\n visitClass(name: string, element: Class): void {\n var sb = this.sb;\n indent(sb, this.indentLevel++);\n sb.push(\"interface \");\n sb.push(name);\n sb.push(\" {\\n\");\n // TODO\n indent(sb, --this.indentLevel);\n sb.push(\"}\\n\");\n }\n\n visitInterface(name: string, element: Interface): void {\n this.visitClass(name, element);\n }\n\n visitField(name: string, element: Field): void {\n // TODO\n }\n\n visitNamespace(name: string, element: Namespace): void {\n var sb = this.sb;\n indent(sb, this.indentLevel++);\n sb.push(\"interface \");\n sb.push(name);\n sb.push(\" {\\n\");\n var members = element.members;\n if (members) {\n for (let member of members.values()) this.visitElement(member.name, member);\n }\n indent(sb, --this.indentLevel);\n sb.push(\"}\\n\");\n }\n\n visitAlias(name: string, element: Element, originalName: string): void {\n // TODO\n }\n\n typeToString(type: Type): string {\n switch (type.kind) {\n case TypeKind.I8: return \"byte\";\n case TypeKind.I16: return \"short\";\n case TypeKind.I32: return \"long\";\n case TypeKind.I64: return \"long long\";\n case TypeKind.ISIZE: return this.program.options.isWasm64 ? \"long long\" : \"long\";\n case TypeKind.U8: return \"octet\";\n case TypeKind.U16: return \"unsigned short\";\n case TypeKind.U32: return \"unsigned long\";\n // ^ TODO: function types\n case TypeKind.U64: return \"unsigned long long\";\n case TypeKind.USIZE: return this.program.options.isWasm64 ? \"unsigned long long\" : \"unsigned long\";\n // ^ TODO: class types\n case TypeKind.BOOL: return \"boolean\";\n case TypeKind.F32: return \"unrestricted float\";\n case TypeKind.F64: return \"unrestricted double\";\n case TypeKind.VOID: return \"void\";\n default: {\n assert(false);\n return \"\";\n }\n }\n }\n\n build(): string {\n var sb = this.sb;\n sb.push(\"interface ASModule {\\n\");\n ++this.indentLevel;\n this.walk();\n --this.indentLevel;\n sb.push(\"}\\n\");\n return sb.join(\"\");\n }\n}\n\n/** A TypeScript definitions builder. */\nexport class TSDBuilder extends ExportsWalker {\n\n /** Builds TypeScript definitions for the specified program. */\n static build(program: Program): string {\n return new TSDBuilder(program).build();\n }\n\n private sb: string[] = [];\n private indentLevel: i32 = 0;\n private unknown: Set = new Set();\n\n /** Constructs a new WebIDL builder. */\n constructor(program: Program, includePrivate: bool = false) {\n super(program, includePrivate);\n }\n\n visitGlobal(name: string, element: Global): void {\n var sb = this.sb;\n var isConst = element.is(CommonFlags.INLINED);\n indent(sb, this.indentLevel);\n if (element.is(CommonFlags.STATIC)) {\n if (isConst) sb.push(\"static readonly \");\n else sb.push(\"static \");\n } else {\n if (isConst) sb.push(\"export const \");\n else sb.push(\"export var \");\n }\n sb.push(name);\n sb.push(\": \");\n sb.push(this.typeToString(element.type));\n sb.push(\";\\n\");\n this.visitNamespace(name, element);\n }\n\n visitEnum(name: string, element: Enum): void {\n var sb = this.sb;\n indent(sb, this.indentLevel++);\n sb.push(\"export enum \");\n sb.push(name);\n sb.push(\" {\\n\");\n var members = element.members;\n if (members) {\n let numMembers = members.size;\n for (let [name, member] of members) {\n if (member.kind == ElementKind.ENUMVALUE) {\n indent(sb, this.indentLevel);\n sb.push(name);\n if (member.is(CommonFlags.INLINED)) {\n sb.push(\" = \");\n assert((member).constantValueKind == ConstantValueKind.INTEGER);\n sb.push(i64_low((member).constantIntegerValue).toString(10));\n }\n sb.push(\",\\n\");\n --numMembers;\n }\n }\n if (numMembers) this.visitNamespace(name, element);\n }\n indent(sb, --this.indentLevel);\n sb.push(\"}\\n\");\n }\n\n visitFunction(name: string, element: Function): void {\n if (element.isAny(CommonFlags.PRIVATE | CommonFlags.SET)) return;\n var sb = this.sb;\n var signature = element.signature;\n indent(sb, this.indentLevel);\n if (element.is(CommonFlags.PROTECTED)) sb.push(\"protected \");\n if (element.is(CommonFlags.STATIC)) sb.push(\"static \");\n if (element.is(CommonFlags.GET)) {\n sb.push(\"get \");\n sb.push(name); // 'get:funcName' internally\n sb.push(\"(): \");\n sb.push(this.typeToString(signature.returnType));\n sb.push(\";\\n\");\n return;\n } else {\n if (!element.isAny(CommonFlags.STATIC | CommonFlags.INSTANCE)) sb.push(\"export function \");\n sb.push(name);\n }\n sb.push(\"(\");\n var parameters = signature.parameterTypes;\n var numParameters = parameters.length;\n // var requiredParameters = signature.requiredParameters;\n for (let i = 0; i < numParameters; ++i) {\n if (i) sb.push(\", \");\n // if (i >= requiredParameters) sb.push(\"optional \");\n sb.push(signature.getParameterName(i));\n sb.push(\": \");\n sb.push(this.typeToString(parameters[i]));\n }\n if (element.isAny(CommonFlags.CONSTRUCTOR | CommonFlags.SET)) {\n sb.push(\")\");\n } else {\n sb.push(\"): \");\n sb.push(this.typeToString(signature.returnType));\n }\n sb.push(\";\\n\");\n this.visitNamespace(name, element);\n }\n\n visitClass(name: string, element: Class): void {\n var sb = this.sb;\n var isInterface = element.kind == ElementKind.INTERFACE;\n indent(sb, this.indentLevel++);\n if (isInterface) {\n sb.push(\"export interface \");\n } else {\n if (element.is(CommonFlags.ABSTRACT)) sb.push(\"abstract \");\n sb.push(\"export class \");\n }\n sb.push(name);\n // var base = element.base;\n // if (base && base.is(CommonFlags.COMPILED | CommonFlags.MODULE_EXPORT)) {\n // sb.push(\" extends \");\n // sb.push(base.name); // TODO: fqn\n // }\n sb.push(\" {\\n\");\n var staticMembers = element.prototype.members;\n if (staticMembers) {\n for (let member of staticMembers.values()) this.visitElement(member.name, member);\n }\n var instanceMembers = element.members;\n if (instanceMembers) {\n for (let member of instanceMembers.values()) this.visitElement(member.name, member);\n }\n indent(sb, --this.indentLevel);\n sb.push(\"}\\n\");\n }\n\n visitInterface(name: string, element: Interface): void {\n this.visitClass(name, element);\n }\n\n visitField(name: string, element: Field): void {\n if (element.is(CommonFlags.PRIVATE)) return;\n var sb = this.sb;\n indent(sb, this.indentLevel);\n if (element.is(CommonFlags.PROTECTED)) sb.push(\"protected \");\n if (element.is(CommonFlags.STATIC)) sb.push(\"static \");\n if (element.is(CommonFlags.READONLY)) sb.push(\"readonly \");\n sb.push(name);\n sb.push(\": \");\n sb.push(this.typeToString(element.type));\n sb.push(\";\\n\");\n }\n\n visitNamespace(name: string, element: Element): void {\n var members = element.members;\n if (members && members.size) {\n let sb = this.sb;\n indent(sb, this.indentLevel++);\n sb.push(\"export namespace \");\n sb.push(name);\n sb.push(\" {\\n\");\n for (let member of members.values()) this.visitElement(member.name, member);\n indent(sb, --this.indentLevel);\n sb.push(\"}\\n\");\n }\n }\n\n visitAlias(name: string, element: Element, originalName: string): void {\n var sb = this.sb;\n indent(sb, this.indentLevel);\n sb.push(\"export const \");\n sb.push(name);\n sb.push(\" = typeof \");\n sb.push(originalName);\n sb.push(\";\\n\");\n }\n\n typeToString(type: Type): string {\n switch (type.kind) {\n case TypeKind.I8: return \"i8\";\n case TypeKind.I16: return \"i16\";\n case TypeKind.I32: return \"i32\";\n case TypeKind.I64: return \"I64\";\n case TypeKind.ISIZE: return this.program.options.isWasm64 ? \"I64\" : \"i32\";\n case TypeKind.U8: return \"u8\";\n case TypeKind.U16: return \"u16\";\n case TypeKind.U32: return \"u32\";\n // ^ TODO: function types\n case TypeKind.U64: return \"U64\";\n case TypeKind.USIZE: return this.program.options.isWasm64 ? \"U64\" : \"u32\";\n // ^ TODO: class types\n case TypeKind.BOOL: return \"bool\";\n case TypeKind.F32: return \"f32\";\n case TypeKind.F64: return \"f64\";\n case TypeKind.V128: return \"v128\";\n case TypeKind.VOID: return \"void\";\n default: {\n assert(false);\n return \"any\";\n }\n }\n }\n\n build(): string {\n var sb = this.sb;\n sb.push(\"declare module ASModule {\\n\");\n sb.push(\" type i8 = number;\\n\");\n sb.push(\" type i16 = number;\\n\");\n sb.push(\" type i32 = number;\\n\");\n sb.push(\" type u8 = number;\\n\");\n sb.push(\" type u16 = number;\\n\");\n sb.push(\" type u32 = number;\\n\");\n sb.push(\" type f32 = number;\\n\");\n sb.push(\" type f64 = number;\\n\");\n sb.push(\" type bool = any;\\n\");\n ++this.indentLevel;\n this.walk();\n --this.indentLevel;\n sb.push(\"}\\n\");\n sb.push(\"export default ASModule;\\n\");\n return this.sb.join(\"\");\n }\n}\n\n// helpers\n\n/** Tests if a namespace-like element has at least one compiled member. */\nfunction hasCompiledMember(element: Element): bool {\n var members = element.members;\n if (members) {\n for (let member of members.values()) {\n switch (member.kind) {\n case ElementKind.FUNCTION_PROTOTYPE: {\n let instances = (member).instances;\n if (instances) {\n for (let instance of instances.values()) {\n if (instance.is(CommonFlags.COMPILED)) return true;\n }\n }\n break;\n }\n case ElementKind.CLASS_PROTOTYPE: {\n let instances = (member).instances;\n if (instances) {\n for (let instance of instances.values()) {\n if (instance.is(CommonFlags.COMPILED)) return true;\n }\n }\n break;\n }\n default: {\n if (member.is(CommonFlags.COMPILED) || hasCompiledMember(member)) return true;\n break;\n }\n }\n }\n }\n return false;\n}\n","/**\n * A TypeScript parser for the AssemblyScript subset.\n * @module parser\n *//***/\n\nimport {\n CommonFlags,\n LIBRARY_PREFIX,\n PATH_DELIMITER\n} from \"./common\";\n\nimport {\n Program\n} from \"./program\";\n\nimport {\n Tokenizer,\n Token,\n Range,\n CommentHandler,\n IdentifierHandling,\n isIllegalVariableIdentifier\n} from \"./tokenizer\";\n\nimport {\n DiagnosticCode,\n DiagnosticEmitter\n} from \"./diagnostics\";\n\nimport {\n normalizePath\n} from \"./util\";\n\nimport {\n Node,\n NodeKind,\n Source,\n SourceKind,\n TypeNode,\n NamedTypeNode,\n FunctionTypeNode,\n ArrowKind,\n\n Expression,\n AssertionKind,\n CallExpression,\n ClassExpression,\n FunctionExpression,\n IdentifierExpression,\n StringLiteralExpression,\n\n Statement,\n BlockStatement,\n BreakStatement,\n ClassDeclaration,\n ContinueStatement,\n DeclarationStatement,\n DecoratorNode,\n DoStatement,\n EnumDeclaration,\n EnumValueDeclaration,\n ExportImportStatement,\n ExportMember,\n ExportStatement,\n ExpressionStatement,\n ForStatement,\n FunctionDeclaration,\n IfStatement,\n ImportDeclaration,\n ImportStatement,\n IndexSignatureDeclaration,\n NamespaceDeclaration,\n ParameterNode,\n ParameterKind,\n ReturnStatement,\n SwitchCase,\n SwitchStatement,\n ThrowStatement,\n TryStatement,\n TypeDeclaration,\n TypeParameterNode,\n VariableStatement,\n VariableDeclaration,\n VoidStatement,\n WhileStatement,\n\n mangleInternalPath,\n nodeIsCallable,\n nodeIsGenericCallable\n} from \"./ast\";\n\n/** Parser interface. */\nexport class Parser extends DiagnosticEmitter {\n\n /** Program being created. */\n program: Program;\n /** Source file names to be requested next. */\n backlog: string[] = new Array();\n /** Source file names already seen, that is processed or backlogged. */\n seenlog: Set = new Set();\n /** Source file names already completely processed. */\n donelog: Set = new Set();\n /** Optional handler to intercept comments while tokenizing. */\n onComment: CommentHandler | null = null;\n\n /** Constructs a new parser. */\n constructor() {\n super();\n this.program = new Program(this.diagnostics);\n }\n\n /** Parses a file and adds its definitions to the program. */\n parseFile(\n text: string,\n path: string,\n isEntry: bool\n ): void {\n var normalizedPath = normalizePath(path);\n var internalPath = mangleInternalPath(normalizedPath);\n\n // check if already processed\n if (this.donelog.has(internalPath)) return;\n this.donelog.add(internalPath); // do not parse again\n this.seenlog.add(internalPath); // do not request again\n\n // create the source element\n var source = new Source(\n normalizedPath,\n text,\n isEntry\n ? SourceKind.ENTRY\n : path.startsWith(LIBRARY_PREFIX) && path.indexOf(PATH_DELIMITER, LIBRARY_PREFIX.length) < 0\n ? SourceKind.LIBRARY\n : SourceKind.DEFAULT\n );\n var program = this.program;\n program.sources.push(source);\n\n // tokenize and parse\n var tn = new Tokenizer(source, program.diagnostics);\n tn.onComment = this.onComment;\n source.tokenizer = tn;\n var statements = source.statements;\n while (!tn.skip(Token.ENDOFFILE)) {\n let statement = this.parseTopLevelStatement(tn, null);\n if (statement) statements.push(statement);\n }\n tn.finish();\n }\n\n /** Parses a top-level statement. */\n parseTopLevelStatement(\n tn: Tokenizer,\n namespace: NamespaceDeclaration | null = null\n ): Statement | null {\n var flags = CommonFlags.NONE;\n var startPos: i32 = -1;\n\n // check decorators\n var decorators: DecoratorNode[] | null = null;\n while (tn.skip(Token.AT)) {\n if (startPos < 0) startPos = tn.tokenPos;\n let decorator = this.parseDecorator(tn);\n if (!decorator) {\n this.skipStatement(tn);\n continue;\n }\n if (!decorators) decorators = [decorator];\n else decorators.push(decorator);\n }\n\n // check modifiers\n var exportStart: i32 = 0;\n var exportEnd: i32 = 0;\n var defaultStart: i32 = 0;\n var defaultEnd: i32 = 0;\n if (tn.skip(Token.EXPORT)) {\n if (startPos < 0) startPos = tn.tokenPos;\n flags |= CommonFlags.EXPORT;\n exportStart = tn.tokenPos;\n exportEnd = tn.pos;\n if (tn.skip(Token.DEFAULT)) {\n defaultStart = tn.tokenPos;\n defaultEnd = tn.pos;\n }\n }\n\n var declareStart: i32 = 0;\n var declareEnd: i32 = 0;\n var contextIsAmbient = namespace != null && namespace.is(CommonFlags.AMBIENT);\n if (tn.skip(Token.DECLARE)) {\n if (contextIsAmbient) {\n this.error(\n DiagnosticCode.A_declare_modifier_cannot_be_used_in_an_already_ambient_context,\n tn.range()\n ); // recoverable\n } else {\n if (startPos < 0) startPos = tn.tokenPos;\n declareStart = startPos;\n declareEnd = tn.pos;\n flags |= CommonFlags.DECLARE | CommonFlags.AMBIENT;\n }\n } else if (contextIsAmbient) {\n flags |= CommonFlags.AMBIENT;\n }\n\n // parse the statement\n var statement: Statement | null = null;\n\n // handle declarations\n var first = tn.peek();\n if (startPos < 0) startPos = tn.nextTokenPos;\n switch (first) {\n case Token.CONST: {\n tn.next();\n flags |= CommonFlags.CONST;\n if (tn.skip(Token.ENUM)) {\n statement = this.parseEnum(tn, flags, decorators, startPos);\n } else {\n statement = this.parseVariable(tn, flags, decorators, startPos);\n }\n decorators = null;\n break;\n }\n case Token.LET: flags |= CommonFlags.LET;\n case Token.VAR: {\n tn.next();\n statement = this.parseVariable(tn, flags, decorators, startPos);\n decorators = null;\n break;\n }\n case Token.ENUM: {\n tn.next();\n statement = this.parseEnum(tn, flags, decorators, startPos);\n decorators = null;\n break;\n }\n case Token.FUNCTION: {\n tn.next();\n statement = this.parseFunction(tn, flags, decorators, startPos);\n decorators = null;\n break;\n }\n case Token.ABSTRACT: {\n let state = tn.mark();\n tn.next();\n if (!tn.skip(Token.CLASS)) {\n tn.reset(state);\n statement = this.parseStatement(tn, true);\n break;\n } else {\n tn.discard(state);\n }\n flags |= CommonFlags.ABSTRACT;\n // fall through\n }\n case Token.CLASS:\n case Token.INTERFACE: {\n tn.next();\n statement = this.parseClassOrInterface(tn, flags, decorators, startPos);\n decorators = null;\n break;\n }\n case Token.NAMESPACE: {\n let state = tn.mark();\n tn.next();\n if (tn.peek(false, IdentifierHandling.PREFER) == Token.IDENTIFIER) {\n tn.discard(state);\n statement = this.parseNamespace(tn, flags, decorators, startPos);\n decorators = null;\n } else {\n tn.reset(state);\n statement = this.parseStatement(tn, true);\n }\n break;\n }\n case Token.IMPORT: {\n tn.next();\n flags |= CommonFlags.IMPORT;\n if (flags & CommonFlags.EXPORT) {\n statement = this.parseExportImport(tn, startPos);\n } else {\n statement = this.parseImport(tn);\n }\n break;\n }\n case Token.TYPE: { // also identifier\n let state = tn.mark();\n tn.next();\n if (tn.peek(false, IdentifierHandling.PREFER) == Token.IDENTIFIER) {\n tn.discard(state);\n statement = this.parseTypeDeclaration(tn, flags, decorators, startPos);\n decorators = null;\n } else {\n tn.reset(state);\n statement = this.parseStatement(tn, true);\n }\n break;\n }\n default: {\n\n // handle plain exports\n if (flags & CommonFlags.EXPORT) {\n if (defaultEnd && tn.skipIdentifier(IdentifierHandling.PREFER)) {\n if (declareEnd) {\n this.error(\n DiagnosticCode.An_export_assignment_cannot_have_modifiers,\n tn.range(declareStart, declareEnd)\n );\n }\n statement = this.parseExportDefaultAlias(tn, startPos, defaultStart, defaultEnd);\n defaultStart = defaultEnd = 0; // consume\n } else {\n statement = this.parseExport(tn, startPos, (flags & CommonFlags.DECLARE) != 0);\n }\n\n // handle non-declaration statements\n } else {\n if (exportEnd) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(exportStart, exportEnd), \"export\"\n ); // recoverable\n }\n if (declareEnd) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(declareStart, declareEnd), \"declare\"\n ); // recoverable\n }\n if (!namespace) {\n statement = this.parseStatement(tn, true);\n } // TODO: else?\n }\n break;\n }\n }\n\n // check for decorators that weren't consumed\n if (decorators) {\n for (let i = 0, k = decorators.length; i < k; ++i) {\n this.error(\n DiagnosticCode.Decorators_are_not_valid_here,\n decorators[i].range\n );\n }\n }\n\n // check if this an `export default` declaration\n if (defaultEnd && statement !== null) {\n switch (statement.kind) {\n case NodeKind.ENUMDECLARATION:\n case NodeKind.FUNCTIONDECLARATION:\n case NodeKind.CLASSDECLARATION:\n case NodeKind.INTERFACEDECLARATION:\n case NodeKind.NAMESPACEDECLARATION: {\n return Node.createExportDefaultStatement(statement, tn.range(startPos, tn.pos));\n }\n default: {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(defaultStart, defaultEnd), \"default\"\n );\n }\n }\n }\n return statement;\n }\n\n /** Obtains the next file to parse. */\n nextFile(): string | null {\n var backlog = this.backlog;\n return backlog.length ? backlog.shift() : null;\n }\n\n /** Finishes parsing and returns the program. */\n finish(): Program {\n if (this.backlog.length) throw new Error(\"backlog is not empty\");\n this.backlog = [];\n this.seenlog.clear();\n this.donelog.clear();\n return this.program;\n }\n\n /** Parses a type. */\n parseType(\n tn: Tokenizer,\n acceptParenthesized: bool = true,\n suppressErrors: bool = false\n ): TypeNode | null {\n\n // NOTE: this parses our limited subset\n var token = tn.next();\n var startPos = tn.tokenPos;\n\n var type: TypeNode;\n\n // '(' ...\n if (token == Token.OPENPAREN) {\n\n // '(' FunctionSignature ')' '|' 'null'?\n let isNullableSignature = tn.skip(Token.OPENPAREN);\n // FunctionSignature?\n let signature = this.tryParseFunctionType(tn);\n if (signature) {\n if (isNullableSignature) {\n if (!tn.skip(Token.CLOSEPAREN)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n return null;\n }\n if (!tn.skip(Token.BAR)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"|\"\n );\n return null;\n }\n if (!tn.skip(Token.NULL)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"null\"\n );\n }\n signature.isNullable = true;\n }\n return signature;\n } else if (isNullableSignature || this.tryParseSignatureIsSignature) {\n this.error(\n DiagnosticCode.Unexpected_token,\n tn.range()\n );\n return null;\n }\n\n // Type (',' Type)* ')'\n if (acceptParenthesized) {\n let innerType = this.parseType(tn, false, suppressErrors);\n if (!innerType) return null;\n if (!tn.skip(Token.CLOSEPAREN)) {\n if (!suppressErrors) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(tn.pos), \"}\"\n );\n }\n return null;\n }\n type = innerType;\n type.range.start = startPos;\n type.range.end = tn.pos;\n } else {\n this.error(\n DiagnosticCode.Unexpected_token,\n tn.range()\n );\n return null;\n }\n\n // 'void'\n } else if (token == Token.VOID) {\n type = Node.createNamedType(\n Node.createSimpleTypeName(\"void\", tn.range()), [], false, tn.range(startPos, tn.pos)\n );\n\n // 'this'\n } else if (token == Token.THIS) {\n type = Node.createNamedType(\n Node.createSimpleTypeName(\"this\", tn.range()), [], false, tn.range(startPos, tn.pos)\n );\n\n // 'true'\n } else if (token == Token.TRUE || token == Token.FALSE) {\n type = Node.createNamedType(\n Node.createSimpleTypeName(\"bool\", tn.range()), [], false, tn.range(startPos, tn.pos)\n );\n\n // StringLiteral\n } else if (token == Token.STRINGLITERAL) {\n tn.readString();\n type = Node.createNamedType(\n Node.createSimpleTypeName(\"string\", tn.range()), [], false, tn.range(startPos, tn.pos)\n );\n\n // Identifier\n } else if (token == Token.IDENTIFIER) {\n let first = Node.createSimpleTypeName(tn.readIdentifier(), tn.range());\n let current = first;\n let parameters: NamedTypeNode[] | null = null;\n let nullable = false;\n\n // Identifier ('.' Identifier)+\n while (tn.skip(Token.DOT)) {\n if (tn.skip(Token.IDENTIFIER)) {\n let next = Node.createSimpleTypeName(tn.readIdentifier(), tn.range());\n current.next = next;\n current = next;\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range(tn.pos)\n );\n return null;\n }\n }\n\n // Name\n if (tn.skip(Token.LESSTHAN)) {\n do {\n let parameter = this.parseType(tn, true, suppressErrors);\n if (!parameter) return null;\n if (!parameters) parameters = [parameter];\n else parameters.push(parameter);\n } while (tn.skip(Token.COMMA));\n if (!tn.skip(Token.GREATERTHAN)) {\n if (!suppressErrors) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(tn.pos), \">\"\n );\n }\n return null;\n }\n }\n // ... | null\n while (tn.skip(Token.BAR)) {\n if (tn.skip(Token.NULL)) {\n nullable = true;\n } else {\n if (!suppressErrors) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(tn.pos), \"null\"\n );\n }\n return null;\n }\n }\n type = Node.createNamedType(first, parameters || [], nullable, tn.range(startPos, tn.pos));\n } else {\n if (!suppressErrors) {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n return null;\n }\n // ... [][]\n while (tn.skip(Token.OPENBRACKET)) {\n let bracketStart = tn.tokenPos;\n if (!tn.skip(Token.CLOSEBRACKET)) {\n if (!suppressErrors) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"]\"\n );\n }\n return null;\n }\n let bracketRange = tn.range(bracketStart, tn.pos);\n\n // ...[] | null\n let nullable = false;\n if (tn.skip(Token.BAR)) {\n if (tn.skip(Token.NULL)) {\n nullable = true;\n } else {\n if (!suppressErrors) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"null\"\n );\n }\n return null;\n }\n }\n type = Node.createNamedType(\n Node.createSimpleTypeName(\"Array\", bracketRange),\n [ type ],\n nullable,\n tn.range(startPos, tn.pos)\n );\n if (nullable) break;\n }\n\n return type;\n }\n\n // Indicates whether tryParseSignature determined that it is handling a Signature\n private tryParseSignatureIsSignature: bool = false;\n\n /** Parses a function type, as used in type declarations. */\n tryParseFunctionType(\n tn: Tokenizer\n ): FunctionTypeNode | null {\n\n // at '(': ('...'? Identifier '?'? ':' Type (',' '...'? Identifier '?'? ':' Type)* )? ')' '=>' Type\n\n var state = tn.mark();\n var startPos = tn.tokenPos;\n var parameters: ParameterNode[] | null = null;\n var thisType: NamedTypeNode | null = null;\n var isSignature: bool = false;\n\n if (tn.skip(Token.CLOSEPAREN)) {\n isSignature = true;\n tn.discard(state);\n parameters = [];\n\n } else {\n isSignature = false; // not yet known\n do {\n let kind = ParameterKind.DEFAULT;\n if (tn.skip(Token.DOT_DOT_DOT)) {\n isSignature = true;\n tn.discard(state);\n kind = ParameterKind.REST;\n }\n if (tn.skip(Token.THIS)) {\n if (tn.skip(Token.COLON)) {\n isSignature = true;\n tn.discard(state);\n let t = this.parseType(tn, false);\n if (!t) return null;\n if (t.kind != NodeKind.NAMEDTYPE) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n t.range\n );\n this.tryParseSignatureIsSignature = true;\n return null;\n }\n thisType = t;\n } else {\n tn.reset(state);\n this.tryParseSignatureIsSignature = false;\n return null;\n }\n } else if (tn.skipIdentifier()) {\n let name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range(tn.tokenPos, tn.pos));\n if (tn.skip(Token.QUESTION)) {\n isSignature = true;\n tn.discard(state);\n if (kind == ParameterKind.REST) {\n this.error(\n DiagnosticCode.A_rest_parameter_cannot_be_optional,\n tn.range()\n ); // recoverable\n } else {\n kind = ParameterKind.OPTIONAL;\n }\n }\n if (tn.skip(Token.COLON)) {\n isSignature = true;\n tn.discard(state);\n let type = this.parseType(tn); // not suppressing errors because known\n if (!type) {\n this.tryParseSignatureIsSignature = isSignature;\n return null;\n }\n let param = new ParameterNode();\n param.parameterKind = kind;\n param.name = name;\n param.type = type;\n if (!parameters) parameters = [ param ];\n else parameters.push(param);\n } else {\n if (isSignature) {\n this.error(\n DiagnosticCode.Type_expected,\n tn.range()\n ); // recoverable\n }\n }\n } else {\n if (isSignature) {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n } else {\n tn.reset(state);\n }\n this.tryParseSignatureIsSignature = isSignature;\n return null;\n }\n } while (tn.skip(Token.COMMA));\n if (!tn.skip(Token.CLOSEPAREN)) {\n if (isSignature) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n } else {\n tn.reset(state);\n }\n this.tryParseSignatureIsSignature = isSignature;\n return null;\n }\n }\n\n var returnType: TypeNode | null;\n if (tn.skip(Token.EQUALS_GREATERTHAN)) {\n isSignature = true;\n tn.discard(state);\n returnType = this.parseType(tn);\n if (!returnType) {\n this.tryParseSignatureIsSignature = isSignature;\n return null;\n }\n } else {\n if (isSignature) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"=>\"\n );\n } else {\n tn.reset(state);\n }\n this.tryParseSignatureIsSignature = isSignature;\n return null;\n }\n this.tryParseSignatureIsSignature = true;\n return Node.createFunctionType(\n parameters || [],\n returnType,\n thisType,\n false,\n tn.range(startPos, tn.pos)\n );\n }\n\n // statements\n\n parseDecorator(\n tn: Tokenizer\n ): DecoratorNode | null {\n\n // at '@': Identifier ('.' Identifier)* '(' Arguments\n\n var startPos = tn.tokenPos;\n if (tn.skipIdentifier()) {\n let name = tn.readIdentifier();\n let expression: Expression = Node.createIdentifierExpression(name, tn.range(startPos, tn.pos));\n while (tn.skip(Token.DOT)) {\n if (tn.skipIdentifier()) {\n name = tn.readIdentifier();\n expression = Node.createPropertyAccessExpression(\n expression,\n Node.createIdentifierExpression(name, tn.range()),\n tn.range(startPos, tn.pos)\n );\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n return null;\n }\n }\n let args: Expression[] | null;\n if (tn.skip(Token.OPENPAREN)) {\n args = this.parseArguments(tn);\n if (args) {\n return Node.createDecorator(expression, args, tn.range(startPos, tn.pos));\n }\n } else {\n return Node.createDecorator(expression, null, tn.range(startPos, tn.pos));\n }\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n return null;\n }\n\n parseVariable(\n tn: Tokenizer,\n flags: CommonFlags,\n decorators: DecoratorNode[] | null,\n startPos: i32\n ): VariableStatement | null {\n\n // at ('const' | 'let' | 'var'): VariableDeclaration (',' VariableDeclaration)* ';'?\n\n var members = new Array();\n do {\n let member = this.parseVariableDeclaration(tn, flags, decorators);\n if (!member) return null;\n members.push(member);\n } while (tn.skip(Token.COMMA));\n\n var ret = Node.createVariableStatement(members, decorators, tn.range(startPos, tn.pos));\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseVariableDeclaration(\n tn: Tokenizer,\n parentFlags: CommonFlags,\n parentDecorators: DecoratorNode[] | null\n ): VariableDeclaration | null {\n\n // before: Identifier (':' Type)? ('=' Expression)?\n\n if (!tn.skipIdentifier()) {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n return null;\n }\n var identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n if (isIllegalVariableIdentifier(identifier.text)) {\n this.error(\n DiagnosticCode.Identifier_expected,\n identifier.range\n );\n }\n var flags = parentFlags;\n if (tn.skip(Token.EXCLAMATION)) {\n flags |= CommonFlags.DEFINITE_ASSIGNMENT;\n }\n\n var type: TypeNode | null = null;\n if (tn.skip(Token.COLON)) {\n type = this.parseType(tn);\n }\n\n var initializer: Expression | null = null;\n if (tn.skip(Token.EQUALS)) {\n if (flags & CommonFlags.AMBIENT) {\n this.error(\n DiagnosticCode.Initializers_are_not_allowed_in_ambient_contexts,\n tn.range()\n ); // recoverable\n }\n initializer = this.parseExpression(tn, Precedence.COMMA + 1);\n if (!initializer) return null;\n } else {\n if (flags & CommonFlags.CONST) {\n if (!(flags & CommonFlags.AMBIENT)) {\n this.error(\n DiagnosticCode._const_declarations_must_be_initialized,\n identifier.range\n ); // recoverable\n }\n } else if (!type) { // neither type nor initializer\n this.error(\n DiagnosticCode.Type_expected,\n tn.range(tn.pos)\n ); // recoverable\n }\n }\n var range = Range.join(identifier.range, tn.range());\n if ((flags & CommonFlags.DEFINITE_ASSIGNMENT) && initializer) {\n this.error(\n DiagnosticCode.A_definite_assignment_assertion_is_not_permitted_in_this_context,\n range);\n }\n return Node.createVariableDeclaration(\n identifier,\n type,\n initializer,\n parentDecorators,\n flags,\n range\n );\n }\n\n parseEnum(\n tn: Tokenizer,\n flags: CommonFlags,\n decorators: DecoratorNode[] | null,\n startPos: i32\n ): EnumDeclaration | null {\n\n // at 'enum': Identifier '{' (EnumValueDeclaration (',' EnumValueDeclaration )*)? '}' ';'?\n\n if (tn.next() != Token.IDENTIFIER) {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n return null;\n }\n var identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n if (tn.next() != Token.OPENBRACE) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"{\"\n );\n return null;\n }\n var members = new Array();\n while (!tn.skip(Token.CLOSEBRACE)) {\n let member = this.parseEnumValue(tn, CommonFlags.NONE);\n if (!member) return null;\n members.push(member);\n if (!tn.skip(Token.COMMA)) {\n if (tn.skip(Token.CLOSEBRACE)) {\n break;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"}\"\n );\n return null;\n }\n }\n }\n var ret = Node.createEnumDeclaration(\n identifier,\n members,\n decorators,\n flags,\n tn.range(startPos, tn.pos)\n );\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseEnumValue(\n tn: Tokenizer,\n parentFlags: CommonFlags\n ): EnumValueDeclaration | null {\n\n // before: Identifier ('=' Expression)?\n\n if (!tn.skipIdentifier()) {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n return null;\n }\n var identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n var value: Expression | null = null;\n if (tn.skip(Token.EQUALS)) {\n value = this.parseExpression(tn, Precedence.COMMA + 1);\n if (!value) return null;\n }\n return Node.createEnumValueDeclaration(\n identifier,\n value,\n parentFlags,\n Range.join(identifier.range, tn.range())\n );\n }\n\n parseReturn(\n tn: Tokenizer\n ): ReturnStatement | null {\n\n // at 'return': Expression | (';' | '}' | ...'\\n')\n\n var expr: Expression | null = null;\n if (\n tn.peek(true) != Token.SEMICOLON &&\n tn.nextToken != Token.CLOSEBRACE &&\n !tn.nextTokenOnNewLine\n ) {\n if (!(expr = this.parseExpression(tn))) return null;\n }\n\n var ret = Node.createReturnStatement(expr, tn.range());\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseTypeParameters(\n tn: Tokenizer\n ): TypeParameterNode[] | null {\n\n // at '<': TypeParameter (',' TypeParameter)* '>'\n\n var typeParameters: TypeParameterNode[] | null = null;\n var seenOptional = false;\n while (!tn.skip(Token.GREATERTHAN)) {\n let typeParameter = this.parseTypeParameter(tn);\n if (!typeParameter) return null;\n if (typeParameter.defaultType !== null) {\n seenOptional = true;\n } else if (seenOptional) {\n this.error(\n DiagnosticCode.Required_type_parameters_may_not_follow_optional_type_parameters,\n typeParameter.range\n );\n typeParameter.defaultType = null;\n }\n if (!typeParameters) typeParameters = [ typeParameter ];\n else typeParameters.push(typeParameter);\n if (!tn.skip(Token.COMMA)) {\n if (tn.skip(Token.GREATERTHAN)) {\n break;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \">\"\n );\n return null;\n }\n }\n }\n if (!(typeParameters && typeParameters.length)) {\n this.error(\n DiagnosticCode.Type_parameter_list_cannot_be_empty,\n tn.range()\n ); // recoverable\n }\n return typeParameters;\n }\n\n parseTypeParameter(\n tn: Tokenizer\n ): TypeParameterNode | null {\n\n // before: Identifier ('extends' Type)? ('=' Type)?\n\n if (tn.next() == Token.IDENTIFIER) {\n let identifier = Node.createIdentifierExpression(\n tn.readIdentifier(),\n tn.range()\n );\n let extendsType: NamedTypeNode | null = null;\n if (tn.skip(Token.EXTENDS)) {\n let t = this.parseType(tn);\n if (!t) return null;\n if (t.kind != NodeKind.NAMEDTYPE) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n t.range\n );\n return null;\n }\n extendsType = t;\n }\n let defaultType: NamedTypeNode | null = null;\n if (tn.skip(Token.EQUALS)) {\n let t = this.parseType(tn);\n if (!t) return null;\n if (t.kind != NodeKind.NAMEDTYPE) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n t.range\n );\n return null;\n }\n defaultType = t;\n }\n return Node.createTypeParameter(\n identifier,\n extendsType,\n defaultType,\n Range.join(identifier.range, tn.range())\n );\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n return null;\n }\n\n private parseParametersThis: NamedTypeNode | null = null;\n\n parseParameters(\n tn: Tokenizer,\n isConstructor: bool = false\n ): ParameterNode[] | null {\n\n // at '(': (Parameter (',' Parameter)*)? ')'\n\n var parameters = new Array();\n var seenRest: ParameterNode | null = null;\n var seenOptional = false;\n var reportedRest = false;\n var thisType: TypeNode | null = null;\n\n // check if there is a leading `this` parameter\n this.parseParametersThis = null;\n if (tn.skip(Token.THIS)) {\n if (tn.skip(Token.COLON)) {\n thisType = this.parseType(tn); // reports\n if (!thisType) return null;\n if (thisType.kind == NodeKind.NAMEDTYPE) {\n this.parseParametersThis = thisType;\n } else {\n this.error(\n DiagnosticCode.Operation_not_supported,\n thisType.range\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \":\"\n );\n return null;\n }\n if (!tn.skip(Token.COMMA)) {\n if (tn.skip(Token.CLOSEPAREN)) {\n return parameters;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n return null;\n }\n }\n }\n\n while (!tn.skip(Token.CLOSEPAREN)) {\n let param = this.parseParameter(tn, isConstructor); // reports\n if (!param) return null;\n if (seenRest && !reportedRest) {\n this.error(\n DiagnosticCode.A_rest_parameter_must_be_last_in_a_parameter_list,\n seenRest.name.range\n );\n reportedRest = true;\n }\n switch (param.parameterKind) {\n default: {\n if (seenOptional) {\n this.error(\n DiagnosticCode.A_required_parameter_cannot_follow_an_optional_parameter,\n param.name.range\n );\n }\n break;\n }\n case ParameterKind.OPTIONAL: {\n seenOptional = true;\n break;\n }\n case ParameterKind.REST: {\n seenRest = param;\n break;\n }\n }\n parameters.push(param);\n if (!tn.skip(Token.COMMA)) {\n if (tn.skip(Token.CLOSEPAREN)) {\n break;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n return null;\n }\n }\n }\n return parameters;\n }\n\n parseParameter(\n tn: Tokenizer,\n isConstructor: bool = false\n ): ParameterNode | null {\n\n // before: ('public' | 'private' | 'protected' | '...')? Identifier '?'? (':' Type)? ('=' Expression)?\n\n var isRest = false;\n var isOptional = false;\n var startRange: Range | null = null;\n var accessFlags: CommonFlags = CommonFlags.NONE;\n if (isConstructor) {\n if (tn.skip(Token.PUBLIC)) {\n startRange = tn.range();\n accessFlags |= CommonFlags.PUBLIC;\n } else if (tn.skip(Token.PROTECTED)) {\n startRange = tn.range();\n accessFlags |= CommonFlags.PROTECTED;\n } else if (tn.skip(Token.PRIVATE)) {\n startRange = tn.range();\n accessFlags |= CommonFlags.PRIVATE;\n }\n if (tn.peek() == Token.READONLY) {\n let state = tn.mark();\n tn.next();\n if (tn.peek() != Token.COLON) { // modifier\n tn.discard(state);\n if (!startRange) startRange = tn.range();\n accessFlags |= CommonFlags.READONLY;\n } else { // identifier\n tn.reset(state);\n }\n }\n }\n if (tn.skip(Token.DOT_DOT_DOT)) {\n if (accessFlags) {\n this.error(\n DiagnosticCode.A_parameter_property_cannot_be_declared_using_a_rest_parameter,\n tn.range()\n );\n } else {\n startRange = tn.range();\n }\n isRest = true;\n }\n if (tn.skipIdentifier()) {\n if (!isRest) startRange = tn.range();\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n let type: TypeNode | null = null;\n if (isOptional = tn.skip(Token.QUESTION)) {\n if (isRest) {\n this.error(\n DiagnosticCode.A_rest_parameter_cannot_be_optional,\n identifier.range\n );\n }\n }\n if (tn.skip(Token.COLON)) {\n type = this.parseType(tn);\n if (!type) return null;\n } else {\n type = Node.createOmittedType(tn.range(tn.pos));\n }\n let initializer: Expression | null = null;\n if (tn.skip(Token.EQUALS)) {\n if (isRest) {\n this.error(\n DiagnosticCode.A_rest_parameter_cannot_have_an_initializer,\n identifier.range\n );\n }\n if (isOptional) {\n this.error(\n DiagnosticCode.Parameter_cannot_have_question_mark_and_initializer,\n identifier.range\n );\n } else {\n isOptional = true;\n }\n initializer = this.parseExpression(tn, Precedence.COMMA + 1);\n if (!initializer) return null;\n }\n let param = Node.createParameter(\n identifier,\n type,\n initializer,\n isRest\n ? ParameterKind.REST\n : isOptional\n ? ParameterKind.OPTIONAL\n : ParameterKind.DEFAULT,\n Range.join(startRange, tn.range())\n );\n param.flags |= accessFlags;\n return param;\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n return null;\n }\n\n parseFunction(\n tn: Tokenizer,\n flags: CommonFlags,\n decorators: DecoratorNode[] | null,\n startPos: i32\n ): FunctionDeclaration | null {\n\n // at 'function':\n // Identifier\n // ('<' TypeParameters)?\n // '(' Parameters (':' Type)?\n // '{' Statement* '}'\n // ';'?\n\n if (!tn.skipIdentifier()) {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range(tn.pos)\n );\n return null;\n }\n\n var name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n var signatureStart: i32 = -1;\n\n var typeParameters: TypeParameterNode[] | null = null;\n if (tn.skip(Token.LESSTHAN)) {\n signatureStart = tn.tokenPos;\n typeParameters = this.parseTypeParameters(tn);\n if (!typeParameters) return null;\n flags |= CommonFlags.GENERIC;\n }\n\n if (!tn.skip(Token.OPENPAREN)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(tn.pos), \"(\"\n );\n return null;\n }\n\n if (signatureStart < 0) {\n signatureStart = tn.tokenPos;\n }\n\n var parameters = this.parseParameters(tn);\n if (!parameters) return null;\n var thisType = this.parseParametersThis;\n\n var isSetter = (flags & CommonFlags.SET) != 0;\n if (isSetter) {\n if (parameters.length != 1) {\n this.error(\n DiagnosticCode.A_set_accessor_must_have_exactly_one_parameter,\n name.range\n ); // recoverable\n }\n if (parameters.length && parameters[0].initializer) {\n this.error(\n DiagnosticCode.A_set_accessor_parameter_cannot_have_an_initializer,\n name.range\n ); // recoverable\n }\n }\n\n if (flags & CommonFlags.GET) {\n if (parameters.length) {\n this.error(\n DiagnosticCode.A_get_accessor_cannot_have_parameters,\n name.range\n ); // recoverable\n }\n }\n\n var returnType: TypeNode | null = null;\n if (tn.skip(Token.COLON)) {\n returnType = this.parseType(tn, true, isSetter);\n if (!returnType) return null;\n }\n\n if (!returnType) {\n returnType = Node.createOmittedType(\n tn.range(tn.pos)\n );\n if (!isSetter) {\n this.error(\n DiagnosticCode.Type_expected,\n returnType.range\n ); // recoverable\n }\n }\n\n var signature = Node.createFunctionType(\n parameters,\n returnType,\n thisType,\n false,\n tn.range(signatureStart, tn.pos)\n );\n\n var body: Statement | null = null;\n if (tn.skip(Token.OPENBRACE)) {\n if (flags & CommonFlags.AMBIENT) {\n this.error(\n DiagnosticCode.An_implementation_cannot_be_declared_in_ambient_contexts,\n tn.range()\n ); // recoverable\n }\n\n body = this.parseBlockStatement(tn, false);\n if (!body) return null;\n } else if (!(flags & CommonFlags.AMBIENT)) {\n this.error(\n DiagnosticCode.Function_implementation_is_missing_or_not_immediately_following_the_declaration,\n tn.range(tn.pos)\n );\n }\n\n var ret = Node.createFunctionDeclaration(\n name,\n typeParameters,\n signature,\n body,\n decorators,\n flags,\n ArrowKind.NONE,\n tn.range(startPos, tn.pos)\n );\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseFunctionExpression(tn: Tokenizer): FunctionExpression | null {\n var startPos = tn.tokenPos;\n var name: IdentifierExpression;\n var arrowKind = ArrowKind.NONE;\n\n // either at 'function':\n // Identifier?\n // '(' Parameters (':' Type)?\n // Statement\n\n if (tn.token == Token.FUNCTION) {\n if (tn.skipIdentifier()) {\n name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n } else { // empty name\n name = Node.createEmptyIdentifierExpression(tn.range(tn.pos));\n }\n if (!tn.skip(Token.OPENPAREN)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(tn.pos), \"(\"\n );\n return null;\n }\n\n // or at '(' of arrow function:\n // Parameters (':' Type)?\n // Statement\n\n } else {\n arrowKind = ArrowKind.ARROW_PARENTHESIZED;\n assert(tn.token == Token.OPENPAREN);\n name = Node.createEmptyIdentifierExpression(tn.range(tn.tokenPos));\n }\n\n // TODO: type parameters? doesn't seem worth it.\n\n var signatureStart = tn.pos;\n var parameters = this.parseParameters(tn);\n if (!parameters) return null;\n\n return this.parseFunctionExpressionCommon(tn, name, parameters, arrowKind, startPos, signatureStart);\n }\n\n private parseFunctionExpressionCommon(\n tn: Tokenizer,\n name: IdentifierExpression,\n parameters: ParameterNode[],\n arrowKind: ArrowKind,\n startPos: i32 = -1,\n signatureStart: i32 = -1\n ): FunctionExpression | null {\n if (startPos < 0) startPos = name.range.start;\n if (signatureStart < 0) signatureStart = startPos;\n\n var returnType: TypeNode | null = null;\n if (arrowKind != ArrowKind.ARROW_SINGLE && tn.skip(Token.COLON)) {\n returnType = this.parseType(tn);\n if (!returnType) return null;\n } else {\n returnType = Node.createOmittedType(tn.range(tn.pos));\n }\n\n if (arrowKind) {\n if (!tn.skip(Token.EQUALS_GREATERTHAN)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(tn.pos), \"=>\"\n );\n return null;\n }\n }\n\n var signature = Node.createFunctionType(\n parameters,\n returnType,\n null, // TODO?\n false,\n tn.range(signatureStart, tn.pos)\n );\n\n var body: Statement | null = null;\n if (arrowKind) {\n if (tn.skip(Token.OPENBRACE)) {\n body = this.parseBlockStatement(tn, false);\n } else {\n let bodyExpression = this.parseExpression(tn, Precedence.COMMA + 1);\n if (bodyExpression) body = Node.createExpressionStatement(bodyExpression);\n }\n } else {\n if (!tn.skip(Token.OPENBRACE)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(tn.pos), \"{\"\n );\n return null;\n }\n body = this.parseBlockStatement(tn, false);\n }\n if (!body) return null;\n\n var declaration = Node.createFunctionDeclaration(\n name,\n null,\n signature,\n body,\n null,\n CommonFlags.NONE,\n arrowKind,\n tn.range(startPos, tn.pos)\n );\n return Node.createFunctionExpression(declaration);\n }\n\n parseClassOrInterface(\n tn: Tokenizer,\n flags: CommonFlags,\n decorators: DecoratorNode[] | null,\n startPos: i32\n ): ClassDeclaration | null {\n\n // at ('class' | 'interface'):\n // Identifier\n // ('<' TypeParameters)?\n // ('extends' Type)?\n // ('implements' Type (',' Type)*)?\n // '{' ClassMember* '}'\n\n var isInterface = tn.token == Token.INTERFACE;\n\n if (!tn.skipIdentifier()) {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n return null;\n }\n\n var identifier = Node.createIdentifierExpression(\n tn.readIdentifier(),\n tn.range()\n );\n\n var typeParameters: TypeParameterNode[] | null = null;\n if (tn.skip(Token.LESSTHAN)) {\n typeParameters = this.parseTypeParameters(tn);\n if (!typeParameters) return null;\n flags |= CommonFlags.GENERIC;\n }\n\n var extendsType: NamedTypeNode | null = null;\n if (tn.skip(Token.EXTENDS)) {\n let t = this.parseType(tn);\n if (!t) return null;\n if (t.kind != NodeKind.NAMEDTYPE) {\n this.error(\n DiagnosticCode.Operation_not_supported,\n t.range\n );\n return null;\n }\n extendsType = t;\n }\n\n var implementsTypes: NamedTypeNode[] | null = null;\n if (tn.skip(Token.IMPLEMENTS)) {\n if (isInterface) {\n this.error(\n DiagnosticCode.Interface_declaration_cannot_have_implements_clause,\n tn.range()\n ); // recoverable\n }\n do {\n let type = this.parseType(tn);\n if (!type) return null;\n if (!isInterface) {\n if (!implementsTypes) implementsTypes = [type];\n else implementsTypes.push(type);\n }\n } while (tn.skip(Token.COMMA));\n }\n\n if (!tn.skip(Token.OPENBRACE)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"{\"\n );\n return null;\n }\n\n var members = new Array();\n var declaration: ClassDeclaration;\n if (isInterface) {\n assert(!implementsTypes);\n declaration = Node.createInterfaceDeclaration(\n identifier,\n typeParameters,\n extendsType,\n members,\n decorators,\n flags,\n tn.range(startPos, tn.pos)\n );\n } else {\n declaration = Node.createClassDeclaration(\n identifier,\n typeParameters,\n extendsType,\n implementsTypes,\n members,\n decorators,\n flags,\n tn.range(startPos, tn.pos)\n );\n }\n if (!tn.skip(Token.CLOSEBRACE)) {\n do {\n let member = this.parseClassMember(tn, declaration);\n if (member) members.push(member);\n else {\n this.skipStatement(tn);\n if (tn.skip(Token.ENDOFFILE)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"}\"\n );\n return null;\n }\n }\n } while (!tn.skip(Token.CLOSEBRACE));\n }\n declaration.range.end = tn.pos;\n return declaration;\n }\n\n parseClassExpression(tn: Tokenizer): ClassExpression | null {\n\n // at 'class': Identifier? '{' ... '}'\n\n var startPos = tn.tokenPos;\n var name: IdentifierExpression;\n\n if (tn.skipIdentifier()) {\n name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n } else {\n name = Node.createEmptyIdentifierExpression(tn.range(tn.pos));\n }\n\n if (!tn.skip(Token.OPENBRACE)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(tn.pos), \"{\"\n );\n return null;\n }\n\n var members = new Array();\n var declaration = Node.createClassDeclaration(\n name,\n [],\n null,\n null,\n members,\n null,\n CommonFlags.NONE,\n tn.range(startPos, tn.pos)\n );\n if (!tn.skip(Token.CLOSEBRACE)) {\n do {\n let member = this.parseClassMember(tn, declaration);\n if (member) members.push(member);\n else {\n this.skipStatement(tn);\n if (tn.skip(Token.ENDOFFILE)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"}\"\n );\n return null;\n }\n }\n } while (!tn.skip(Token.CLOSEBRACE));\n }\n declaration.range.end = tn.pos;\n return Node.createClassExpression(declaration);\n }\n\n parseClassMember(\n tn: Tokenizer,\n parent: ClassDeclaration\n ): DeclarationStatement | null {\n\n // before:\n // ('public' | 'private' | 'protected')?\n // ('static' | 'abstract')?\n // 'readonly'?\n // ('get' | 'set')?\n // Identifier ...\n\n var startPos = tn.pos;\n var isInterface = parent.kind == NodeKind.INTERFACEDECLARATION;\n\n var decorators: DecoratorNode[] | null = null;\n if (tn.skip(Token.AT)) {\n do {\n let decorator = this.parseDecorator(tn);\n if (!decorator) break;\n if (!decorators) decorators = [decorator];\n else decorators.push(decorator);\n } while (tn.skip(Token.AT));\n if (decorators && isInterface) {\n this.error(\n DiagnosticCode.Decorators_are_not_valid_here,\n Range.join(decorators[0].range, decorators[decorators.length - 1].range)\n );\n }\n }\n\n // inherit ambient status\n var flags = parent.flags & CommonFlags.AMBIENT;\n\n // implemented methods are virtual\n if (isInterface) flags |= CommonFlags.VIRTUAL;\n\n var accessStart = 0;\n var accessEnd = 0;\n if (tn.skip(Token.PUBLIC)) {\n if (isInterface) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(), \"public\"\n );\n }\n flags |= CommonFlags.PUBLIC;\n accessStart = tn.tokenPos;\n accessEnd = tn.pos;\n } else if (tn.skip(Token.PRIVATE)) {\n if (isInterface) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(), \"private\"\n );\n }\n flags |= CommonFlags.PRIVATE;\n accessStart = tn.tokenPos;\n accessEnd = tn.pos;\n } else if (tn.skip(Token.PROTECTED)) {\n if (isInterface) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(), \"protected\"\n );\n }\n flags |= CommonFlags.PROTECTED;\n accessStart = tn.tokenPos;\n accessEnd = tn.pos;\n }\n\n var staticStart = 0;\n var staticEnd = 0;\n var abstractStart = 0;\n var abstractEnd = 0;\n if (tn.skip(Token.STATIC)) {\n if (isInterface) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(), \"static\"\n );\n }\n flags |= CommonFlags.STATIC;\n staticStart = tn.tokenPos;\n staticEnd = tn.pos;\n } else {\n flags |= CommonFlags.INSTANCE;\n if (tn.skip(Token.ABSTRACT)) {\n if (isInterface) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(), \"abstract\"\n );\n }\n flags |= CommonFlags.ABSTRACT;\n abstractStart = tn.tokenPos;\n abstractEnd = tn.pos;\n }\n if (parent.flags & CommonFlags.GENERIC) flags |= CommonFlags.GENERIC_CONTEXT;\n }\n\n var readonlyStart: i32 = 0;\n var readonlyEnd: i32 = 0;\n if (tn.peek() == Token.READONLY) {\n let state = tn.mark();\n tn.next();\n if (tn.peek() != Token.COLON) { // modifier\n tn.discard(state);\n flags |= CommonFlags.READONLY;\n readonlyStart = tn.tokenPos;\n readonlyEnd = tn.pos;\n } else { // identifier\n tn.reset(state);\n }\n }\n\n // check if accessor: ('get' | 'set') ^\\n Identifier\n var state = tn.mark();\n var isConstructor = false;\n var isGetter = false;\n var getStart: i32 = 0;\n var getEnd: i32 = 0;\n var isSetter = false;\n var setStart: i32 = 0;\n var setEnd: i32 = 0;\n if (!isInterface) {\n if (tn.skip(Token.GET)) {\n if (tn.peek(true, IdentifierHandling.PREFER) == Token.IDENTIFIER && !tn.nextTokenOnNewLine) {\n flags |= CommonFlags.GET;\n isGetter = true;\n setStart = tn.tokenPos;\n setEnd = tn.pos;\n if (flags & CommonFlags.READONLY) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(readonlyStart, readonlyEnd), \"readonly\"\n ); // recoverable\n }\n } else {\n tn.reset(state);\n }\n } else if (tn.skip(Token.SET)) {\n if (tn.peek(true, IdentifierHandling.PREFER) == Token.IDENTIFIER && !tn.nextTokenOnNewLine) {\n flags |= CommonFlags.SET;\n isSetter = true;\n setStart = tn.tokenPos;\n setEnd = tn.pos;\n if (flags & CommonFlags.READONLY) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(readonlyStart, readonlyEnd), \"readonly\"\n ); // recoverable\n }\n } else {\n tn.reset(state);\n }\n } else if (tn.skip(Token.CONSTRUCTOR)) {\n flags |= CommonFlags.CONSTRUCTOR;\n isConstructor = true;\n if (flags & CommonFlags.STATIC) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(staticStart, staticEnd), \"static\"\n ); // recoverable\n }\n if (flags & CommonFlags.ABSTRACT) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(abstractStart, abstractEnd), \"abstract\"\n ); // recoverable\n }\n if (flags & CommonFlags.READONLY) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(readonlyStart, readonlyEnd), \"readonly\"\n ); // recoverable\n }\n }\n }\n\n var name: IdentifierExpression;\n if (isConstructor) {\n name = Node.createConstructorExpression(tn.range());\n } else {\n if (!(isGetter || isSetter) && tn.skip(Token.OPENBRACKET)) {\n // TODO: also handle symbols, which might have some of these modifiers\n if (flags & CommonFlags.PUBLIC) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(accessStart, accessEnd), \"public\"\n ); // recoverable\n } else if (flags & CommonFlags.PROTECTED) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(accessStart, accessEnd), \"protected\"\n ); // recoverable\n } else if (flags & CommonFlags.PRIVATE) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(accessStart, accessEnd), \"protected\"\n ); // recoverable\n }\n if (flags & CommonFlags.STATIC) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(staticStart, staticEnd), \"static\"\n ); // recoverable\n }\n if (flags & CommonFlags.ABSTRACT) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(abstractStart, abstractEnd), \"abstract\"\n ); // recoverable\n }\n if (flags & CommonFlags.READONLY) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(readonlyStart, readonlyEnd), \"readonly\"\n ); // recoverable\n }\n let retIndex = this.parseIndexSignatureDeclaration(tn, decorators);\n if (!retIndex) return null;\n tn.skip(Token.SEMICOLON);\n return retIndex;\n }\n if (!tn.skipIdentifier()) {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n return null;\n }\n name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n }\n var typeParameters: TypeParameterNode[] | null = null;\n if (tn.skip(Token.LESSTHAN)) {\n let typeParametersStart = tn.tokenPos;\n typeParameters = this.parseTypeParameters(tn);\n if (!typeParameters) return null;\n if (isConstructor) {\n this.error(\n DiagnosticCode.Type_parameters_cannot_appear_on_a_constructor_declaration,\n tn.range(typeParametersStart, tn.pos)\n ); // recoverable\n } else if (isGetter || isSetter) {\n this.error(\n DiagnosticCode.An_accessor_cannot_have_type_parameters,\n tn.range(typeParametersStart, tn.pos)\n ); // recoverable\n } else {\n flags |= CommonFlags.GENERIC;\n }\n }\n\n // method: '(' Parameters (':' Type)? '{' Statement* '}' ';'?\n if (tn.skip(Token.OPENPAREN)) {\n let signatureStart = tn.tokenPos;\n let parameters = this.parseParameters(tn, isConstructor);\n if (!parameters) return null;\n let thisType = this.parseParametersThis;\n if (isConstructor) {\n for (let i = 0, k = parameters.length; i < k; ++i) {\n let parameter = parameters[i];\n if (parameter.isAny(\n CommonFlags.PUBLIC |\n CommonFlags.PROTECTED |\n CommonFlags.PRIVATE |\n CommonFlags.READONLY\n )) {\n let implicitFieldDeclaration = Node.createFieldDeclaration(\n parameter.name,\n parameter.type,\n null, // initialized via parameter\n null,\n parameter.flags | CommonFlags.INSTANCE,\n parameter.range\n );\n implicitFieldDeclaration.parameterIndex = i;\n parameter.implicitFieldDeclaration = implicitFieldDeclaration;\n parent.members.push(implicitFieldDeclaration);\n }\n }\n } else if (isGetter) {\n if (parameters.length) {\n this.error(\n DiagnosticCode.A_get_accessor_cannot_have_parameters,\n name.range\n );\n }\n } else if (isSetter) {\n if (parameters.length != 1) {\n this.error(\n DiagnosticCode.A_set_accessor_must_have_exactly_one_parameter,\n name.range\n );\n }\n if (parameters.length && parameters[0].initializer) {\n this.error(\n DiagnosticCode.A_set_accessor_parameter_cannot_have_an_initializer,\n name.range\n );\n }\n }\n\n let returnType: TypeNode | null = null;\n if (tn.skip(Token.COLON)) {\n if (name.kind == NodeKind.CONSTRUCTOR) {\n this.error(\n DiagnosticCode.Type_annotation_cannot_appear_on_a_constructor_declaration,\n tn.range()\n );\n } else if (isSetter) {\n this.error(\n DiagnosticCode.A_set_accessor_cannot_have_a_return_type_annotation,\n tn.range()\n );\n }\n returnType = this.parseType(tn, name.kind == NodeKind.CONSTRUCTOR || isSetter);\n if (!returnType) return null;\n } else {\n returnType = Node.createOmittedType(tn.range(tn.pos));\n if (!isSetter && name.kind != NodeKind.CONSTRUCTOR) {\n this.error(\n DiagnosticCode.Type_expected,\n returnType.range\n ); // recoverable\n }\n }\n\n let signature = Node.createFunctionType(\n parameters,\n returnType,\n thisType,\n false,\n tn.range(signatureStart, tn.pos)\n );\n\n let body: Statement | null = null;\n if (tn.skip(Token.OPENBRACE)) {\n if (flags & CommonFlags.AMBIENT) {\n this.error(\n DiagnosticCode.An_implementation_cannot_be_declared_in_ambient_contexts,\n tn.range()\n ); // recoverable\n } else if (flags & CommonFlags.ABSTRACT) {\n this.error(\n DiagnosticCode.Method_0_cannot_have_an_implementation_because_it_is_marked_abstract,\n tn.range(), name.text\n ); // recoverable\n }\n body = this.parseBlockStatement(tn, false);\n if (!body) return null;\n } else if (!(flags & CommonFlags.AMBIENT) && !isInterface) {\n this.error(\n DiagnosticCode.Function_implementation_is_missing_or_not_immediately_following_the_declaration,\n tn.range()\n ); // recoverable\n }\n\n let retMethod = Node.createMethodDeclaration(\n name,\n typeParameters,\n signature,\n body,\n decorators,\n flags,\n tn.range(startPos, tn.pos)\n );\n tn.skip(Token.SEMICOLON);\n return retMethod;\n\n } else if (isConstructor) {\n this.error(\n DiagnosticCode.Constructor_implementation_is_missing,\n name.range\n );\n\n } else if (isGetter || isSetter) {\n this.error(\n DiagnosticCode.Function_implementation_is_missing_or_not_immediately_following_the_declaration,\n name.range\n );\n\n // field: (':' Type)? ('=' Expression)? ';'?\n } else {\n if (flags & CommonFlags.ABSTRACT) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(abstractStart, abstractEnd), \"abstract\"\n ); // recoverable\n }\n\n if (flags & CommonFlags.GET) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(getStart, getEnd), \"get\"\n ); // recoverable\n }\n\n if (flags & CommonFlags.SET) {\n this.error(\n DiagnosticCode._0_modifier_cannot_be_used_here,\n tn.range(setStart, setEnd), \"set\"\n ); // recoverable\n }\n\n let type: TypeNode | null = null;\n if (tn.skip(Token.QUESTION)) {\n this.error(\n DiagnosticCode.Optional_properties_are_not_supported,\n tn.range(startPos, tn.pos)\n );\n }\n if (tn.skip(Token.EXCLAMATION)) {\n flags |= CommonFlags.DEFINITE_ASSIGNMENT;\n }\n if (tn.skip(Token.COLON)) {\n type = this.parseType(tn);\n if (!type) return null;\n } else {\n this.error(\n DiagnosticCode.Type_expected,\n tn.range()\n ); // recoverable\n }\n let initializer: Expression | null = null;\n if (tn.skip(Token.EQUALS)) {\n initializer = this.parseExpression(tn);\n if (!initializer) return null;\n }\n let range = tn.range(startPos, tn.pos);\n if ((flags & CommonFlags.DEFINITE_ASSIGNMENT) && ((flags & CommonFlags.STATIC) || isInterface || initializer)) {\n this.error(\n DiagnosticCode.A_definite_assignment_assertion_is_not_permitted_in_this_context,\n range\n );\n }\n let retField = Node.createFieldDeclaration(\n name,\n type,\n initializer,\n decorators,\n flags,\n range\n );\n tn.skip(Token.SEMICOLON);\n return retField;\n }\n return null;\n }\n\n parseIndexSignatureDeclaration(tn: Tokenizer, decorators: DecoratorNode[] | null): IndexSignatureDeclaration | null {\n\n // at: '[': 'key' ':' Type ']' ':' Type\n\n if (decorators && decorators.length) {\n this.error(\n DiagnosticCode.Decorators_are_not_valid_here,\n Range.join(decorators[0].range, decorators[decorators.length - 1].range)\n ); // recoverable\n }\n\n var start = tn.tokenPos;\n if (tn.skipIdentifier()) {\n let id = tn.readIdentifier();\n if (id == \"key\") {\n if (tn.skip(Token.COLON)) {\n let keyType = this.parseType(tn);\n if (!keyType) return null;\n if (keyType.kind != NodeKind.NAMEDTYPE) {\n this.error(\n DiagnosticCode.Type_expected,\n tn.range()\n );\n return null;\n }\n if (tn.skip(Token.CLOSEBRACKET)) {\n if (tn.skip(Token.COLON)) {\n let valueType = this.parseType(tn);\n if (!valueType) return null;\n return Node.createIndexSignatureDeclaration(keyType, valueType, tn.range(start, tn.pos));\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \":\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"]\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \":\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"key\"\n );\n }\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n return null;\n }\n\n parseNamespace(\n tn: Tokenizer,\n flags: CommonFlags,\n decorators: DecoratorNode[] | null,\n startPos: i32\n ): NamespaceDeclaration | null {\n\n // at 'namespace': Identifier '{' (Variable | Function)* '}'\n\n if (tn.skipIdentifier()) {\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n if (tn.skip(Token.OPENBRACE)) {\n let members = new Array();\n let declaration = Node.createNamespaceDeclaration(\n identifier,\n members,\n decorators,\n flags,\n tn.range(startPos, tn.pos)\n );\n while (!tn.skip(Token.CLOSEBRACE)) {\n let member = this.parseTopLevelStatement(tn, declaration);\n if (member) members.push(member);\n else {\n this.skipStatement(tn);\n if (tn.skip(Token.ENDOFFILE)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"}\"\n );\n return null;\n }\n }\n }\n declaration.range.end = tn.pos;\n tn.skip(Token.SEMICOLON);\n return declaration;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"{\"\n );\n }\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n return null;\n }\n\n parseExport(\n tn: Tokenizer,\n startPos: i32,\n isDeclare: bool\n ): ExportStatement | null {\n\n // at 'export': '{' ExportMember (',' ExportMember)* }' ('from' StringLiteral)? ';'?\n\n var path: StringLiteralExpression | null = null;\n if (tn.skip(Token.OPENBRACE)) {\n let members = new Array();\n while (!tn.skip(Token.CLOSEBRACE)) {\n let member = this.parseExportMember(tn);\n if (!member) return null;\n members.push(member);\n if (!tn.skip(Token.COMMA)) {\n if (tn.skip(Token.CLOSEBRACE)) {\n break;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"}\"\n );\n return null;\n }\n }\n }\n if (tn.skip(Token.FROM)) {\n if (tn.skip(Token.STRINGLITERAL)) {\n path = Node.createStringLiteralExpression(tn.readString(), tn.range());\n } else {\n this.error(\n DiagnosticCode.String_literal_expected,\n tn.range()\n );\n return null;\n }\n }\n let ret = Node.createExportStatement(members, path, isDeclare, tn.range(startPos, tn.pos));\n let internalPath = ret.internalPath;\n if (internalPath !== null && !this.seenlog.has(internalPath)) {\n this.backlog.push(internalPath);\n this.seenlog.add(internalPath);\n }\n tn.skip(Token.SEMICOLON);\n return ret;\n } else if (tn.skip(Token.ASTERISK)) {\n if (tn.skip(Token.FROM)) {\n if (tn.skip(Token.STRINGLITERAL)) {\n path = Node.createStringLiteralExpression(tn.readString(), tn.range());\n let ret = Node.createExportStatement(null, path, isDeclare, tn.range(startPos, tn.pos));\n let internalPath = assert(ret.internalPath);\n let source = tn.source;\n if (!source.exportPaths) source.exportPaths = new Set();\n source.exportPaths.add(internalPath);\n if (!this.seenlog.has(internalPath)) {\n this.backlog.push(internalPath);\n this.seenlog.add(internalPath);\n }\n tn.skip(Token.SEMICOLON);\n return ret;\n } else {\n this.error(\n DiagnosticCode.String_literal_expected,\n tn.range()\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"from\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"{\"\n );\n }\n return null;\n }\n\n parseExportMember(\n tn: Tokenizer\n ): ExportMember | null {\n\n // before: Identifier ('as' Identifier)?\n\n if (tn.skipIdentifier()) {\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n let asIdentifier: IdentifierExpression | null = null;\n if (tn.skip(Token.AS)) {\n if (tn.skipIdentifier(IdentifierHandling.ALWAYS)) {\n asIdentifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n return null;\n }\n }\n return Node.createExportMember(\n identifier,\n asIdentifier,\n asIdentifier\n ? Range.join(identifier.range, asIdentifier.range)\n : identifier.range\n );\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n return null;\n }\n\n parseExportDefaultAlias(\n tn: Tokenizer,\n startPos: i32,\n defaultStart: i32,\n defaultEnd: i32\n ): ExportStatement {\n\n // at 'export' 'default': [Known-To-Be-]Identifier\n\n var name = tn.readIdentifier();\n var range = tn.range();\n var ret = Node.createExportStatement([\n Node.createExportMember(\n Node.createIdentifierExpression(name, range),\n Node.createIdentifierExpression(\"default\", tn.range(defaultStart, defaultEnd)),\n range\n )\n ], null, false, tn.range(startPos, tn.pos));\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseImport(\n tn: Tokenizer\n ): ImportStatement | null {\n\n // at 'import':\n // ('{' (ImportMember (',' ImportMember)* '}') | ('*' 'as' Identifier)?\n // 'from' StringLiteral ';'?\n\n var startPos = tn.tokenPos;\n var members: ImportDeclaration[] | null = null;\n var namespaceName: IdentifierExpression | null = null;\n var skipFrom = false;\n if (tn.skip(Token.OPENBRACE)) { // import { ... } from \"file\"\n members = new Array();\n while (!tn.skip(Token.CLOSEBRACE)) {\n let member = this.parseImportDeclaration(tn);\n if (!member) return null;\n members.push(member);\n if (!tn.skip(Token.COMMA)) {\n if (tn.skip(Token.CLOSEBRACE)) {\n break;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"}\"\n );\n return null;\n }\n }\n }\n } else if (tn.skip(Token.ASTERISK)) { // import * from \"file\"\n if (tn.skip(Token.AS)) {\n if (tn.skipIdentifier()) {\n namespaceName = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n return null;\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"as\"\n );\n return null;\n }\n } else if (tn.skip(Token.IDENTIFIER, IdentifierHandling.PREFER)) { // import Name from \"file\"\n let name = tn.readIdentifier();\n let range = tn.range();\n members = [\n Node.createImportDeclaration(\n Node.createIdentifierExpression(\"default\", range),\n Node.createIdentifierExpression(name, range),\n range\n )\n ];\n if (tn.skip(Token.COMMA)) {\n // TODO: default + star, default + members\n this.error(\n DiagnosticCode.Operation_not_supported,\n tn.range()\n );\n return null;\n }\n } else { // import \"file\"\n skipFrom = true;\n }\n\n if (skipFrom || tn.skip(Token.FROM)) {\n if (tn.skip(Token.STRINGLITERAL)) {\n let path = Node.createStringLiteralExpression(tn.readString(), tn.range());\n let ret: ImportStatement;\n if (namespaceName) {\n assert(!members);\n ret = Node.createImportStatementWithWildcard(namespaceName, path, tn.range(startPos, tn.pos));\n } else {\n ret = Node.createImportStatement(members, path, tn.range(startPos, tn.pos));\n }\n let internalPath = ret.internalPath;\n if (!this.seenlog.has(internalPath)) {\n this.backlog.push(internalPath);\n this.seenlog.add(internalPath);\n }\n tn.skip(Token.SEMICOLON);\n return ret;\n } else {\n this.error(\n DiagnosticCode.String_literal_expected,\n tn.range()\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"from\"\n );\n }\n return null;\n }\n\n parseImportDeclaration(\n tn: Tokenizer\n ): ImportDeclaration | null {\n\n // before: Identifier ('as' Identifier)?\n\n if (tn.skipIdentifier(IdentifierHandling.ALWAYS)) {\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n let asIdentifier: IdentifierExpression | null = null;\n if (tn.skip(Token.AS)) {\n if (tn.skipIdentifier()) {\n asIdentifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n return null;\n }\n }\n return Node.createImportDeclaration(\n identifier,\n asIdentifier,\n asIdentifier\n ? Range.join(identifier.range, asIdentifier.range)\n : identifier.range\n );\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n return null;\n }\n\n parseExportImport(\n tn: Tokenizer,\n startPos: i32\n ): ExportImportStatement | null {\n\n // at 'export' 'import': Identifier ('=' Identifier)? ';'?\n\n if (tn.skipIdentifier()) {\n let asIdentifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n if (tn.skip(Token.EQUALS)) {\n if (tn.skipIdentifier()) {\n let identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n let ret = Node.createExportImportStatement(identifier, asIdentifier, tn.range(startPos, tn.pos));\n tn.skip(Token.SEMICOLON);\n return ret;\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"=\"\n );\n }\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n return null;\n }\n\n parseStatement(\n tn: Tokenizer,\n topLevel: bool = false\n ): Statement | null {\n\n // at previous token\n\n var state = tn.mark();\n var token = tn.next();\n var statement: Statement | null = null;\n switch (token) {\n case Token.BREAK: {\n statement = this.parseBreak(tn);\n break;\n }\n case Token.CONST: {\n statement = this.parseVariable(tn, CommonFlags.CONST, null, tn.tokenPos);\n break;\n }\n case Token.CONTINUE: {\n statement = this.parseContinue(tn);\n break;\n }\n case Token.DO: {\n statement = this.parseDoStatement(tn);\n break;\n }\n case Token.FOR: {\n statement = this.parseForStatement(tn);\n break;\n }\n case Token.IF: {\n statement = this.parseIfStatement(tn);\n break;\n }\n case Token.LET: {\n statement = this.parseVariable(tn, CommonFlags.LET, null, tn.tokenPos);\n break;\n }\n case Token.VAR: {\n statement = this.parseVariable(tn, CommonFlags.NONE, null, tn.tokenPos);\n break;\n }\n case Token.OPENBRACE: {\n statement = this.parseBlockStatement(tn, topLevel);\n break;\n }\n case Token.RETURN: {\n if (topLevel) {\n this.error(\n DiagnosticCode.A_return_statement_can_only_be_used_within_a_function_body,\n tn.range()\n ); // recoverable\n }\n statement = this.parseReturn(tn);\n break;\n }\n case Token.SEMICOLON: {\n return Node.createEmptyStatement(tn.range(tn.tokenPos));\n }\n case Token.SWITCH: {\n statement = this.parseSwitchStatement(tn);\n break;\n }\n case Token.THROW: {\n statement = this.parseThrowStatement(tn);\n break;\n }\n case Token.TRY: {\n statement = this.parseTryStatement(tn);\n break;\n }\n case Token.VOID: {\n statement = this.parseVoidStatement(tn);\n break;\n }\n case Token.WHILE: {\n statement = this.parseWhileStatement(tn);\n break;\n }\n case Token.TYPE: { // also identifier\n if (tn.peek(false, IdentifierHandling.PREFER) == Token.IDENTIFIER) {\n statement = this.parseTypeDeclaration(tn, CommonFlags.NONE, null, tn.tokenPos);\n break;\n }\n // fall-through\n }\n default: {\n tn.reset(state);\n statement = this.parseExpressionStatement(tn);\n break;\n }\n }\n if (!statement) { // has been reported\n tn.reset(state);\n this.skipStatement(tn);\n } else {\n tn.discard(state);\n }\n return statement;\n }\n\n parseBlockStatement(\n tn: Tokenizer,\n topLevel: bool\n ): BlockStatement | null {\n\n // at '{': Statement* '}' ';'?\n\n var startPos = tn.tokenPos;\n var statements = new Array();\n while (!tn.skip(Token.CLOSEBRACE)) {\n let state = tn.mark();\n let statement = this.parseStatement(tn, topLevel);\n if (!statement) {\n if (tn.token == Token.ENDOFFILE) return null;\n tn.reset(state);\n this.skipStatement(tn);\n } else {\n tn.discard(state);\n statements.push(statement);\n }\n }\n var ret = Node.createBlockStatement(statements, tn.range(startPos, tn.pos));\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseBreak(\n tn: Tokenizer\n ): BreakStatement | null {\n\n // at 'break': Identifier? ';'?\n\n var identifier: IdentifierExpression | null = null;\n if (tn.peek(true) == Token.IDENTIFIER && !tn.nextTokenOnNewLine) {\n tn.next(IdentifierHandling.PREFER);\n identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n }\n var ret = Node.createBreakStatement(identifier, tn.range());\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseContinue(\n tn: Tokenizer\n ): ContinueStatement | null {\n\n // at 'continue': Identifier? ';'?\n\n var identifier: IdentifierExpression | null = null;\n if (tn.peek(true) == Token.IDENTIFIER && !tn.nextTokenOnNewLine) {\n tn.next(IdentifierHandling.PREFER);\n identifier = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n }\n var ret = Node.createContinueStatement(identifier, tn.range());\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseDoStatement(\n tn: Tokenizer\n ): DoStatement | null {\n\n // at 'do': Statement 'while' '(' Expression ')' ';'?\n\n var startPos = tn.tokenPos;\n var statement = this.parseStatement(tn);\n if (!statement) return null;\n\n if (tn.skip(Token.WHILE)) {\n\n if (tn.skip(Token.OPENPAREN)) {\n let condition = this.parseExpression(tn);\n if (!condition) return null;\n\n if (tn.skip(Token.CLOSEPAREN)) {\n let ret = Node.createDoStatement(statement, condition, tn.range(startPos, tn.pos));\n tn.skip(Token.SEMICOLON);\n return ret;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"(\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"while\"\n );\n }\n return null;\n }\n\n parseExpressionStatement(\n tn: Tokenizer\n ): ExpressionStatement | null {\n\n // at previous token\n\n var expr = this.parseExpression(tn);\n if (!expr) return null;\n\n var ret = Node.createExpressionStatement(expr);\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseForStatement(\n tn: Tokenizer\n ): ForStatement | null {\n\n // at 'for': '(' Statement? Expression? ';' Expression? ')' Statement\n\n var startPos = tn.tokenPos;\n\n if (tn.skip(Token.OPENPAREN)) {\n let initializer: Statement | null = null;\n\n if (tn.skip(Token.CONST)) {\n initializer = this.parseVariable(tn, CommonFlags.CONST, null, tn.tokenPos);\n } else if (tn.skip(Token.LET)) {\n initializer = this.parseVariable(tn, CommonFlags.LET, null, tn.tokenPos);\n } else if (tn.skip(Token.VAR)) {\n initializer = this.parseVariable(tn, CommonFlags.NONE, null, tn.tokenPos);\n\n } else if (!tn.skip(Token.SEMICOLON)) {\n initializer = this.parseExpressionStatement(tn);\n if (!initializer) return null;\n }\n\n if (tn.token == Token.SEMICOLON) {\n let condition: ExpressionStatement | null = null;\n if (!tn.skip(Token.SEMICOLON)) {\n condition = this.parseExpressionStatement(tn);\n if (!condition) return null;\n }\n\n if (tn.token == Token.SEMICOLON) {\n let incrementor: Expression | null = null;\n if (!tn.skip(Token.CLOSEPAREN)) {\n incrementor = this.parseExpression(tn);\n if (!incrementor) return null;\n\n if (!tn.skip(Token.CLOSEPAREN)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n return null;\n }\n }\n\n let statement = this.parseStatement(tn);\n if (!statement) return null;\n\n return Node.createForStatement(\n initializer,\n condition\n ? condition.expression\n : null,\n incrementor,\n statement,\n tn.range(startPos, tn.pos)\n );\n\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \";\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \";\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"(\"\n );\n }\n return null;\n }\n\n parseIfStatement(\n tn: Tokenizer\n ): IfStatement | null {\n\n // at 'if': '(' Expression ')' Statement ('else' Statement)?\n\n var startPos = tn.tokenPos;\n if (tn.skip(Token.OPENPAREN)) {\n let condition = this.parseExpression(tn);\n if (!condition) return null;\n if (tn.skip(Token.CLOSEPAREN)) {\n let statement = this.parseStatement(tn);\n if (!statement) return null;\n let elseStatement: Statement | null = null;\n if (tn.skip(Token.ELSE)) {\n elseStatement = this.parseStatement(tn);\n if (!elseStatement) return null;\n }\n return Node.createIfStatement(\n condition,\n statement,\n elseStatement,\n tn.range(startPos, tn.pos)\n );\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"(\"\n );\n }\n return null;\n }\n\n parseSwitchStatement(\n tn: Tokenizer\n ): SwitchStatement | null {\n\n // at 'switch': '(' Expression ')' '{' SwitchCase* '}' ';'?\n\n var startPos = tn.tokenPos;\n if (tn.skip(Token.OPENPAREN)) {\n let condition = this.parseExpression(tn);\n if (!condition) return null;\n if (tn.skip(Token.CLOSEPAREN)) {\n if (tn.skip(Token.OPENBRACE)) {\n let cases = new Array();\n while (!tn.skip(Token.CLOSEBRACE)) {\n let case_ = this.parseSwitchCase(tn);\n if (!case_) return null;\n cases.push(case_);\n }\n let ret = Node.createSwitchStatement(condition, cases, tn.range(startPos, tn.pos));\n tn.skip(Token.SEMICOLON);\n return ret;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"{\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"(\"\n );\n }\n return null;\n }\n\n parseSwitchCase(\n tn: Tokenizer\n ): SwitchCase | null {\n\n var startPos = tn.tokenPos;\n var statements: Statement[],\n statement: Statement | null;\n\n // 'case' Expression ':' Statement*\n\n if (tn.skip(Token.CASE)) {\n let label = this.parseExpression(tn);\n if (!label) return null;\n if (tn.skip(Token.COLON)) {\n statements = new Array();\n while (tn.peek() != Token.CASE && tn.nextToken != Token.DEFAULT && tn.nextToken != Token.CLOSEBRACE) {\n statement = this.parseStatement(tn);\n if (!statement) return null;\n statements.push(statement);\n }\n return Node.createSwitchCase(label, statements, tn.range(startPos, tn.pos));\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \":\"\n );\n }\n\n // 'default' ':' Statement*\n\n } else if (tn.skip(Token.DEFAULT)) {\n if (tn.skip(Token.COLON)) {\n statements = new Array();\n while (tn.peek() != Token.CASE && tn.nextToken != Token.DEFAULT && tn.nextToken != Token.CLOSEBRACE) {\n statement = this.parseStatement(tn);\n if (!statement) return null;\n statements.push(statement);\n }\n return Node.createSwitchCase(null, statements, tn.range(startPos, tn.pos));\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \":\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._case_or_default_expected,\n tn.range()\n );\n }\n return null;\n }\n\n parseThrowStatement(\n tn: Tokenizer\n ): ThrowStatement | null {\n\n // at 'throw': Expression ';'?\n\n var startPos = tn.tokenPos;\n var expression = this.parseExpression(tn);\n if (!expression) return null;\n var ret = Node.createThrowStatement(expression, tn.range(startPos, tn.pos));\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseTryStatement(\n tn: Tokenizer\n ): TryStatement | null {\n\n // at 'try':\n // '{' Statement* '}'\n // ('catch' '(' VariableMember ')' '{' Statement* '}')?\n // ('finally' '{' Statement* '}'? ';'?\n\n var startPos = tn.tokenPos;\n var stmt: Statement | null;\n if (tn.skip(Token.OPENBRACE)) {\n let statements = new Array();\n while (!tn.skip(Token.CLOSEBRACE)) {\n stmt = this.parseStatement(tn);\n if (!stmt) return null;\n statements.push(stmt);\n }\n let catchVariable: IdentifierExpression | null = null;\n let catchStatements: Statement[] | null = null;\n let finallyStatements: Statement[] | null = null;\n if (tn.skip(Token.CATCH)) {\n if (!tn.skip(Token.OPENPAREN)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"(\"\n );\n return null;\n }\n if (!tn.skipIdentifier()) {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n return null;\n }\n catchVariable = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n if (!tn.skip(Token.CLOSEPAREN)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n return null;\n }\n if (!tn.skip(Token.OPENBRACE)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"{\"\n );\n return null;\n }\n catchStatements = [];\n while (!tn.skip(Token.CLOSEBRACE)) {\n stmt = this.parseStatement(tn);\n if (!stmt) return null;\n catchStatements.push(stmt);\n }\n }\n if (tn.skip(Token.FINALLY)) {\n if (!tn.skip(Token.OPENBRACE)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"{\"\n );\n return null;\n }\n finallyStatements = [];\n while (!tn.skip(Token.CLOSEBRACE)) {\n stmt = this.parseStatement(tn);\n if (!stmt) return null;\n finallyStatements.push(stmt);\n }\n }\n if (!(catchStatements || finallyStatements)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"catch\"\n );\n return null;\n }\n let ret = Node.createTryStatement(\n statements,\n catchVariable,\n catchStatements,\n finallyStatements,\n tn.range(startPos, tn.pos)\n );\n tn.skip(Token.SEMICOLON);\n return ret;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"{\"\n );\n }\n return null;\n }\n\n parseTypeDeclaration(\n tn: Tokenizer,\n flags: CommonFlags,\n decorators: DecoratorNode[] | null,\n startPos: i32\n ): TypeDeclaration | null {\n\n // at 'type': Identifier ('<' TypeParameters '>')? '=' Type ';'?\n\n if (tn.skipIdentifier()) {\n let name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n let typeParameters: TypeParameterNode[] | null = null;\n if (tn.skip(Token.LESSTHAN)) {\n typeParameters = this.parseTypeParameters(tn);\n if (!typeParameters) return null;\n flags |= CommonFlags.GENERIC;\n }\n if (tn.skip(Token.EQUALS)) {\n let type = this.parseType(tn);\n if (!type) return null;\n let ret = Node.createTypeDeclaration(\n name,\n typeParameters,\n type,\n decorators,\n flags,\n tn.range(startPos, tn.pos)\n );\n tn.skip(Token.SEMICOLON);\n return ret;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"=\"\n );\n }\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range()\n );\n }\n return null;\n }\n\n parseVoidStatement(\n tn: Tokenizer\n ): VoidStatement | null {\n\n // at 'void': Expression ';'?\n\n var startPos = tn.tokenPos;\n var expression = this.parseExpression(tn, Precedence.GROUPING);\n if (!expression) return null;\n var ret = Node.createVoidStatement(expression, tn.range(startPos, tn.pos));\n tn.skip(Token.SEMICOLON);\n return ret;\n }\n\n parseWhileStatement(\n tn: Tokenizer\n ): WhileStatement | null {\n\n // at 'while': '(' Expression ')' Statement ';'?\n\n var startPos = tn.tokenPos;\n if (tn.skip(Token.OPENPAREN)) {\n let expression = this.parseExpression(tn);\n if (!expression) return null;\n if (tn.skip(Token.CLOSEPAREN)) {\n let statement = this.parseStatement(tn);\n if (!statement) return null;\n let ret = Node.createWhileStatement(expression, statement, tn.range(startPos, tn.pos));\n tn.skip(Token.SEMICOLON);\n return ret;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n }\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"(\"\n );\n }\n return null;\n }\n\n // expressions\n // see: http://www.engr.mun.ca/~theo/Misc/exp_parsing.htm#climbing\n\n parseExpressionStart(\n tn: Tokenizer\n ): Expression | null {\n\n var token = tn.next(IdentifierHandling.PREFER);\n var startPos = tn.tokenPos;\n var precedence = determinePrecedenceStart(token);\n if (precedence != Precedence.NONE) {\n let operand: Expression | null;\n\n // TODO: SpreadExpression, YieldExpression (currently become unsupported UnaryPrefixExpressions)\n\n // NewExpression\n if (token == Token.NEW) {\n operand = this.parseExpression(tn, Precedence.CALL);\n if (!operand) return null;\n if (operand.kind == NodeKind.CALL) {\n return Node.createNewExpression(\n (operand).expression,\n (operand).typeArguments,\n (operand).arguments,\n tn.range(startPos, tn.pos)\n );\n } else {\n this.error(\n DiagnosticCode.Operation_not_supported,\n tn.range()\n );\n }\n return null;\n } else {\n operand = this.parseExpression(tn, precedence);\n if (!operand) return null;\n }\n\n // UnaryPrefixExpression\n if (token == Token.PLUS_PLUS || token == Token.MINUS_MINUS) {\n if (\n operand.kind != NodeKind.IDENTIFIER &&\n operand.kind != NodeKind.ELEMENTACCESS &&\n operand.kind != NodeKind.PROPERTYACCESS\n ) {\n this.error(\n DiagnosticCode.The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access,\n operand.range\n );\n }\n }\n return Node.createUnaryPrefixExpression(token, operand, tn.range(startPos, tn.pos));\n }\n\n var expr: Expression | null = null;\n switch (token) {\n\n case Token.NULL: return Node.createNullExpression(tn.range());\n case Token.TRUE: return Node.createTrueExpression(tn.range());\n case Token.FALSE: return Node.createFalseExpression(tn.range());\n\n // ParenthesizedExpression\n // FunctionExpression\n case Token.OPENPAREN: {\n\n // determine whether this is a function expression\n if (tn.skip(Token.CLOSEPAREN)) { // must be a function expression (fast route)\n return this.parseFunctionExpressionCommon(\n tn,\n Node.createEmptyIdentifierExpression(tn.range(startPos)),\n [],\n ArrowKind.ARROW_PARENTHESIZED\n );\n }\n let state = tn.mark();\n let again = true;\n do {\n switch (tn.next(IdentifierHandling.PREFER)) {\n\n // function expression\n case Token.DOT_DOT_DOT: {\n tn.reset(state);\n return this.parseFunctionExpression(tn);\n }\n // can be both\n case Token.IDENTIFIER: {\n tn.readIdentifier();\n switch (tn.next()) {\n\n // if we got here, check for arrow\n case Token.CLOSEPAREN: {\n if (\n !tn.skip(Token.COLON) &&\n !tn.skip(Token.EQUALS_GREATERTHAN)\n ) {\n again = false;\n break;\n }\n // fall-through\n }\n // function expression\n case Token.COLON: { // type annotation\n tn.reset(state);\n return this.parseFunctionExpression(tn);\n }\n // optional parameter or parenthesized\n case Token.QUESTION: {\n if (\n tn.skip(Token.COLON) || // optional parameter with type\n tn.skip(Token.COMMA) || // optional parameter without type\n tn.skip(Token.CLOSEPAREN) // last optional parameter without type\n ) {\n tn.reset(state);\n return this.parseFunctionExpression(tn);\n }\n again = false; // parenthesized\n break;\n }\n case Token.COMMA: {\n break; // continue\n }\n // parenthesized expression\n // case Token.EQUALS: // missing type annotation for simplicity\n default: {\n again = false;\n break;\n }\n }\n break;\n }\n // parenthesized expression\n default: {\n again = false;\n break;\n }\n }\n } while (again);\n tn.reset(state);\n\n // parse parenthesized\n expr = this.parseExpression(tn);\n if (!expr) return null;\n if (!tn.skip(Token.CLOSEPAREN)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n return null;\n }\n return Node.createParenthesizedExpression(expr, tn.range(startPos, tn.pos));\n }\n // ArrayLiteralExpression\n case Token.OPENBRACKET: {\n let elementExpressions = new Array();\n while (!tn.skip(Token.CLOSEBRACKET)) {\n if (tn.peek() == Token.COMMA) {\n expr = null; // omitted\n } else {\n expr = this.parseExpression(tn, Precedence.COMMA + 1);\n if (!expr) return null;\n }\n elementExpressions.push(expr);\n if (!tn.skip(Token.COMMA)) {\n if (tn.skip(Token.CLOSEBRACKET)) {\n break;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"]\"\n );\n return null;\n }\n }\n }\n return Node.createArrayLiteralExpression(elementExpressions, tn.range(startPos, tn.pos));\n }\n // ObjectLiteralExpression\n case Token.OPENBRACE: {\n let startPos = tn.tokenPos;\n let names = new Array();\n let values = new Array();\n let name: IdentifierExpression;\n while (!tn.skip(Token.CLOSEBRACE)) {\n if (!tn.skipIdentifier()) {\n if (!tn.skip(Token.STRINGLITERAL)) {\n this.error(\n DiagnosticCode.Identifier_expected,\n tn.range(),\n );\n return null;\n }\n name = Node.createIdentifierExpression(tn.readString(), tn.range());\n name.isQuoted = true;\n } else {\n name = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n }\n names.push(name);\n if (tn.skip(Token.COLON)) {\n let value = this.parseExpression(tn, Precedence.COMMA + 1);\n if (!value) return null;\n values.push(value);\n } else if (!name.isQuoted) {\n values.push(name);\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \":\"\n );\n return null;\n }\n if (!tn.skip(Token.COMMA)) {\n if (tn.skip(Token.CLOSEBRACE)) {\n break;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"}\"\n );\n return null;\n }\n }\n }\n return Node.createObjectLiteralExpression(names, values, tn.range(startPos, tn.pos));\n }\n // AssertionExpression (unary prefix)\n case Token.LESSTHAN: {\n let toType = this.parseType(tn);\n if (!toType) return null;\n if (!tn.skip(Token.GREATERTHAN)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \">\"\n );\n return null;\n }\n expr = this.parseExpression(tn, Precedence.CALL);\n if (!expr) return null;\n return Node.createAssertionExpression(\n AssertionKind.PREFIX,\n expr,\n toType,\n tn.range(startPos, tn.pos)\n );\n }\n case Token.IDENTIFIER: {\n let identifierText = tn.readIdentifier();\n if (identifierText == \"null\") return Node.createNullExpression(tn.range()); // special\n let identifier = Node.createIdentifierExpression(identifierText, tn.range(startPos, tn.pos));\n if (tn.peek(true) == Token.EQUALS_GREATERTHAN && !tn.nextTokenOnNewLine) {\n return this.parseFunctionExpressionCommon(\n tn,\n Node.createEmptyIdentifierExpression(tn.range(startPos)),\n [\n Node.createParameter(\n identifier,\n Node.createOmittedType(identifier.range.atEnd),\n null,\n ParameterKind.DEFAULT,\n identifier.range\n )\n ],\n ArrowKind.ARROW_SINGLE,\n startPos\n );\n }\n return identifier;\n }\n case Token.THIS: {\n return Node.createThisExpression(tn.range(startPos, tn.pos));\n }\n case Token.CONSTRUCTOR: {\n return Node.createConstructorExpression(tn.range(startPos, tn.pos));\n }\n case Token.SUPER: {\n if (tn.peek() != Token.DOT && tn.nextToken != Token.OPENPAREN) {\n this.error(\n DiagnosticCode._super_must_be_followed_by_an_argument_list_or_member_access,\n tn.range()\n );\n }\n return Node.createSuperExpression(tn.range(startPos, tn.pos));\n }\n case Token.STRINGLITERAL: {\n return Node.createStringLiteralExpression(tn.readString(), tn.range(startPos, tn.pos));\n }\n case Token.INTEGERLITERAL: {\n return Node.createIntegerLiteralExpression(tn.readInteger(), tn.range(startPos, tn.pos));\n }\n case Token.FLOATLITERAL: {\n return Node.createFloatLiteralExpression(tn.readFloat(), tn.range(startPos, tn.pos));\n }\n // RegexpLiteralExpression\n // note that this also continues on invalid ones so the surrounding AST remains intact\n case Token.SLASH: {\n let regexpPattern = tn.readRegexpPattern(); // also reports\n if (!tn.skip(Token.SLASH)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"/\"\n );\n return null;\n }\n return Node.createRegexpLiteralExpression(\n regexpPattern,\n tn.readRegexpFlags(), // also reports\n tn.range(startPos, tn.pos)\n );\n }\n case Token.FUNCTION: {\n return this.parseFunctionExpression(tn);\n }\n case Token.CLASS: {\n return this.parseClassExpression(tn);\n }\n default: {\n if (token == Token.ENDOFFILE) {\n this.error(\n DiagnosticCode.Unexpected_end_of_text,\n tn.range(startPos)\n );\n } else {\n this.error(\n DiagnosticCode.Expression_expected,\n tn.range()\n );\n }\n return null;\n }\n }\n }\n\n tryParseTypeArgumentsBeforeArguments(\n tn: Tokenizer\n ): TypeNode[] | null {\n\n // at '<': Type (',' Type)* '>' '('\n\n var state = tn.mark();\n if (!tn.skip(Token.LESSTHAN)) return null;\n var typeArguments: TypeNode[] | null = null;\n do {\n if (tn.peek() === Token.GREATERTHAN) {\n break;\n }\n let type = this.parseType(tn, true, true);\n if (!type) {\n tn.reset(state);\n return null;\n }\n if (!typeArguments) typeArguments = [ type ];\n else typeArguments.push(type);\n } while (tn.skip(Token.COMMA));\n if (tn.skip(Token.GREATERTHAN) && tn.skip(Token.OPENPAREN)) {\n return typeArguments;\n }\n tn.reset(state);\n return null;\n }\n\n parseArguments(\n tn: Tokenizer\n ): Expression[] | null {\n\n // at '(': (Expression (',' Expression)*)? ')'\n\n var args = new Array();\n while (!tn.skip(Token.CLOSEPAREN)) {\n let expr = this.parseExpression(tn, Precedence.COMMA + 1);\n if (!expr) return null;\n args.push(expr);\n if (!tn.skip(Token.COMMA)) {\n if (tn.skip(Token.CLOSEPAREN)) {\n break;\n } else {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \")\"\n );\n return null;\n }\n }\n }\n return args;\n }\n\n parseExpression(\n tn: Tokenizer,\n precedence: Precedence = Precedence.COMMA\n ): Expression | null {\n assert(precedence != Precedence.NONE);\n\n var expr = this.parseExpressionStart(tn);\n if (!expr) return null;\n expr = this.maybeParseCallExpression(tn, expr); // simple call like on an Identifier\n\n var startPos = expr.range.start;\n var token: Token;\n var next: Expression | null = null;\n var nextPrecedence: Precedence;\n while (\n (nextPrecedence = determinePrecedence(token = tn.peek())) >= precedence\n ) { // precedence climbing\n tn.next();\n switch (token) {\n // AssertionExpression\n case Token.AS: {\n let toType = this.parseType(tn); // reports\n if (!toType) return null;\n expr = Node.createAssertionExpression(\n AssertionKind.AS,\n expr,\n toType,\n tn.range(startPos, tn.pos)\n );\n break;\n }\n case Token.EXCLAMATION: {\n expr = Node.createAssertionExpression(\n AssertionKind.NONNULL,\n expr,\n null,\n tn.range(startPos, tn.pos)\n );\n break;\n }\n // InstanceOfExpression\n case Token.INSTANCEOF: {\n let isType = this.parseType(tn); // reports\n if (!isType) return null;\n expr = Node.createInstanceOfExpression(\n expr,\n isType,\n tn.range(startPos, tn.pos)\n );\n break;\n }\n // ElementAccessExpression\n case Token.OPENBRACKET: {\n next = this.parseExpression(tn); // reports\n if (!next) return null;\n if (!tn.skip(Token.CLOSEBRACKET)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"]\"\n );\n return null;\n }\n expr = Node.createElementAccessExpression(\n expr,\n next,\n tn.range(startPos, tn.pos)\n );\n break;\n }\n // UnaryPostfixExpression\n case Token.PLUS_PLUS:\n case Token.MINUS_MINUS: {\n if (\n expr.kind != NodeKind.IDENTIFIER &&\n expr.kind != NodeKind.ELEMENTACCESS &&\n expr.kind != NodeKind.PROPERTYACCESS\n ) {\n this.error(\n DiagnosticCode.The_operand_of_an_increment_or_decrement_operator_must_be_a_variable_or_a_property_access,\n expr.range\n );\n }\n expr = Node.createUnaryPostfixExpression(\n token,\n expr,\n tn.range(startPos, tn.pos)\n );\n break;\n }\n // TernaryExpression\n case Token.QUESTION: {\n let ifThen = this.parseExpression(tn);\n if (!ifThen) return null;\n if (!tn.skip(Token.COLON)) {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \":\"\n );\n return null;\n }\n let ifElse = this.parseExpression(tn, precedence > Precedence.COMMA\n ? Precedence.COMMA + 1\n : Precedence.COMMA\n );\n if (!ifElse) return null;\n expr = Node.createTernaryExpression(\n expr,\n ifThen,\n ifElse,\n tn.range(startPos, tn.pos)\n );\n break;\n }\n // CommaExpression\n case Token.COMMA: {\n let commaExprs: Expression[] = [ expr ];\n do {\n expr = this.parseExpression(tn, Precedence.COMMA + 1);\n if (!expr) return null;\n commaExprs.push(expr);\n } while (tn.skip(Token.COMMA));\n expr = Node.createCommaExpression(commaExprs, tn.range(startPos, tn.pos));\n break;\n }\n default: {\n\n // PropertyAccessExpression\n if (token == Token.DOT) {\n if (tn.skipIdentifier()) {\n next = Node.createIdentifierExpression(tn.readIdentifier(), tn.range());\n } else {\n next = this.parseExpression(tn,\n isRightAssociative(token)\n ? nextPrecedence\n : nextPrecedence + 1\n );\n if (!next) return null;\n }\n if (next.kind == NodeKind.IDENTIFIER) { // expr '.' Identifier\n expr = Node.createPropertyAccessExpression(\n expr,\n next,\n tn.range(startPos, tn.pos)\n );\n } else if (next.kind == NodeKind.CALL) { // expr '.' CallExpression\n expr = this.joinPropertyCall(tn, startPos, expr, next);\n if (!expr) return null;\n } else {\n this.error(\n DiagnosticCode.Identifier_expected,\n next.range\n );\n return null;\n }\n\n // BinaryExpression\n } else {\n next = this.parseExpression(tn,\n isRightAssociative(token)\n ? nextPrecedence\n : nextPrecedence + 1\n );\n if (!next) return null;\n expr = Node.createBinaryExpression(token, expr, next, tn.range(startPos, tn.pos));\n }\n break;\n }\n }\n expr = this.maybeParseCallExpression(tn, expr); // compound call like on an ElementAccess\n }\n return expr;\n }\n\n private joinPropertyCall(\n tn: Tokenizer,\n startPos: i32,\n expr: Expression,\n call: CallExpression\n ): Expression | null {\n var callee = call.expression;\n switch (callee.kind) {\n case NodeKind.IDENTIFIER: { // join property access and use as call target\n call.expression = Node.createPropertyAccessExpression(\n expr,\n callee,\n tn.range(startPos, tn.pos)\n );\n break;\n }\n case NodeKind.CALL: { // join call target und wrap the original call around it\n let inner = this.joinPropertyCall(tn, startPos, expr, callee);\n if (!inner) return null;\n call.expression = inner;\n call.range = tn.range(startPos, tn.pos);\n break;\n }\n default: {\n this.error(\n DiagnosticCode.Identifier_expected,\n call.range\n );\n return null;\n }\n }\n return call;\n }\n\n private maybeParseCallExpression(\n tn: Tokenizer,\n expr: Expression\n ): Expression {\n if (nodeIsCallable(expr.kind)) {\n let typeArguments: TypeNode[] | null = null;\n while (\n tn.skip(Token.OPENPAREN)\n ||\n nodeIsGenericCallable(expr.kind) && (typeArguments = this.tryParseTypeArgumentsBeforeArguments(tn)) !== null\n ) {\n let args = this.parseArguments(tn);\n if (!args) break;\n expr = Node.createCallExpression( // is again callable\n expr,\n typeArguments,\n args,\n tn.range(expr.range.start, tn.pos)\n );\n }\n }\n return expr;\n }\n\n /** Skips over a statement on errors in an attempt to reduce unnecessary diagnostic noise. */\n skipStatement(tn: Tokenizer): void {\n tn.peek(true);\n if (tn.nextTokenOnNewLine) tn.next(); // if reset() to the previous line\n do {\n let nextToken = tn.peek(true);\n if (\n nextToken == Token.ENDOFFILE || // next step should handle this\n nextToken == Token.SEMICOLON // end of the statement for sure\n ) {\n tn.next();\n break;\n }\n if (tn.nextTokenOnNewLine) break; // end of the statement maybe\n switch (tn.next()) {\n case Token.IDENTIFIER: {\n tn.readIdentifier();\n break;\n }\n case Token.STRINGLITERAL: {\n tn.readString();\n break;\n }\n case Token.INTEGERLITERAL: {\n tn.readInteger();\n break;\n }\n case Token.FLOATLITERAL: {\n tn.readFloat();\n break;\n }\n case Token.OPENBRACE: {\n this.skipBlock(tn);\n break;\n }\n }\n } while (true);\n }\n\n /** Skips over a block on errors in an attempt to reduce unnecessary diagnostic noise. */\n skipBlock(tn: Tokenizer): void {\n // at '{': ... '}'\n var depth = 1;\n var again = true;\n do {\n switch (tn.next()) {\n case Token.ENDOFFILE: {\n this.error(\n DiagnosticCode._0_expected,\n tn.range(), \"}\"\n );\n again = false;\n break;\n }\n case Token.OPENBRACE: {\n ++depth;\n break;\n }\n case Token.CLOSEBRACE: {\n --depth;\n if (!depth) again = false;\n break;\n }\n case Token.IDENTIFIER: {\n tn.readIdentifier();\n break;\n }\n case Token.STRINGLITERAL: {\n tn.readString();\n break;\n }\n case Token.INTEGERLITERAL: {\n tn.readInteger();\n break;\n }\n case Token.FLOATLITERAL: {\n tn.readFloat();\n break;\n }\n }\n } while (again);\n }\n}\n\n/** Operator precedence from least to largest. */\nexport const enum Precedence {\n NONE,\n COMMA,\n SPREAD,\n YIELD,\n ASSIGNMENT,\n CONDITIONAL,\n LOGICAL_OR,\n LOGICAL_AND,\n BITWISE_OR,\n BITWISE_XOR,\n BITWISE_AND,\n EQUALITY,\n RELATIONAL,\n SHIFT,\n ADDITIVE,\n MULTIPLICATIVE,\n EXPONENTIATED,\n UNARY_PREFIX,\n UNARY_POSTFIX,\n CALL,\n MEMBERACCESS,\n GROUPING\n}\n\n/** Determines the precedence of a starting token. */\nfunction determinePrecedenceStart(kind: Token): Precedence {\n switch (kind) {\n case Token.DOT_DOT_DOT: return Precedence.SPREAD;\n case Token.YIELD: return Precedence.YIELD;\n case Token.EXCLAMATION:\n case Token.TILDE:\n case Token.PLUS:\n case Token.MINUS:\n case Token.PLUS_PLUS:\n case Token.MINUS_MINUS:\n case Token.TYPEOF:\n case Token.VOID:\n case Token.DELETE: return Precedence.UNARY_PREFIX;\n case Token.NEW: return Precedence.MEMBERACCESS;\n }\n return Precedence.NONE;\n}\n\n/** Determines the precende of a non-starting token. */\nfunction determinePrecedence(kind: Token): Precedence {\n switch (kind) {\n case Token.COMMA: return Precedence.COMMA;\n case Token.EQUALS:\n case Token.PLUS_EQUALS:\n case Token.MINUS_EQUALS:\n case Token.ASTERISK_ASTERISK_EQUALS:\n case Token.ASTERISK_EQUALS:\n case Token.SLASH_EQUALS:\n case Token.PERCENT_EQUALS:\n case Token.LESSTHAN_LESSTHAN_EQUALS:\n case Token.GREATERTHAN_GREATERTHAN_EQUALS:\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:\n case Token.AMPERSAND_EQUALS:\n case Token.CARET_EQUALS:\n case Token.BAR_EQUALS: return Precedence.ASSIGNMENT;\n case Token.QUESTION: return Precedence.CONDITIONAL;\n case Token.BAR_BAR: return Precedence.LOGICAL_OR;\n case Token.AMPERSAND_AMPERSAND: return Precedence.LOGICAL_AND;\n case Token.BAR: return Precedence.BITWISE_OR;\n case Token.CARET: return Precedence.BITWISE_XOR;\n case Token.AMPERSAND: return Precedence.BITWISE_AND;\n case Token.EQUALS_EQUALS:\n case Token.EXCLAMATION_EQUALS:\n case Token.EQUALS_EQUALS_EQUALS:\n case Token.EXCLAMATION_EQUALS_EQUALS: return Precedence.EQUALITY;\n case Token.AS:\n case Token.IN:\n case Token.INSTANCEOF:\n case Token.LESSTHAN:\n case Token.GREATERTHAN:\n case Token.LESSTHAN_EQUALS:\n case Token.GREATERTHAN_EQUALS: return Precedence.RELATIONAL;\n case Token.LESSTHAN_LESSTHAN:\n case Token.GREATERTHAN_GREATERTHAN:\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN: return Precedence.SHIFT;\n case Token.PLUS:\n case Token.MINUS: return Precedence.ADDITIVE;\n case Token.ASTERISK:\n case Token.SLASH:\n case Token.PERCENT: return Precedence.MULTIPLICATIVE;\n case Token.ASTERISK_ASTERISK: return Precedence.EXPONENTIATED;\n case Token.PLUS_PLUS:\n case Token.MINUS_MINUS: return Precedence.UNARY_POSTFIX;\n case Token.DOT:\n case Token.NEW:\n case Token.OPENBRACKET:\n case Token.EXCLAMATION: return Precedence.MEMBERACCESS;\n }\n return Precedence.NONE;\n}\n\n/** Determines whether a non-starting token is right associative. */\nfunction isRightAssociative(kind: Token): bool {\n switch (kind) {\n case Token.EQUALS:\n case Token.PLUS_EQUALS:\n case Token.MINUS_EQUALS:\n case Token.ASTERISK_ASTERISK_EQUALS:\n case Token.ASTERISK_EQUALS:\n case Token.SLASH_EQUALS:\n case Token.PERCENT_EQUALS:\n case Token.LESSTHAN_LESSTHAN_EQUALS:\n case Token.GREATERTHAN_GREATERTHAN_EQUALS:\n case Token.GREATERTHAN_GREATERTHAN_GREATERTHAN_EQUALS:\n case Token.AMPERSAND_EQUALS:\n case Token.CARET_EQUALS:\n case Token.BAR_EQUALS:\n case Token.QUESTION:\n case Token.ASTERISK_ASTERISK: return true;\n default: return false;\n }\n}\n","/**\n * JavaScript glue code.\n * @module glue/js\n * @preferred\n *//***/\n\n/// \n\nimport \"./binaryen\"; // must be first so portable can pick up the memory implementation\nimport \"../../../std/portable/index\";\nimport \"./float\";\nimport \"./i64\";\n\nimport { Module } from \"../../module\";\n\nModule.prototype.toText = function(this: Module) {\n // NOTE: Conversion to StackIR can yield conversion artifacts like sequences\n // of unreachable statements not actually emitted by the compiler. Optimizing\n // StackIR removes these again, but may also suppress useless code emitted by\n // the compiler that's then no longer visible in tests. Both not ideal.\n return binaryen.wrapModule(this.ref).emitStackIR(/* optimize-stack-ir */ true);\n};\n\nModule.prototype.toAsmjs = function(this: Module) {\n return binaryen.wrapModule(this.ref).emitAsmjs();\n};\n","// Copy Binaryen exports to global scope\n\nconst binaryen = global.Binaryen || require(\"binaryen\");\nglobal.binaryen = binaryen;\n\nfor (var key in binaryen) {\n if (key.startsWith(\"_Binaryen\") || key.startsWith(\"_Relooper\")) global[key] = binaryen[key];\n}\n\n// Utilize Binaryen's heap\n\nglobal.__memory_allocate = binaryen._malloc;\nglobal.__memory_free = binaryen._free;\nglobal.__memory_copy = binaryen._memmove;\nglobal.__store = function(ptr, val) { binaryen.HEAPU8[ptr] = val; };\nglobal.__load = function(ptr) { return binaryen.HEAPU8[ptr]; };\n","module.exports = __WEBPACK_EXTERNAL_MODULE__20__;","/** @module std/portable *//***/\n\nvar globalScope = typeof window !== \"undefined\" && window || typeof global !== \"undefined\" && global || self;\n\nglobalScope.ASC_TARGET = 2; // Target.JS\nglobalScope.ASC_NO_ASSERT = false;\nglobalScope.ASC_MEMORY_BASE = 0;\nglobalScope.ASC_OPTIMIZE_LEVEL = 3;\nglobalScope.ASC_SHRINK_LEVEL = 0;\nglobalScope.ASC_FEATURE_MUTABLE_GLOBAL = false;\nglobalScope.ASC_FEATURE_SIGN_EXTENSION = false;\nglobalScope.ASC_FEATURE_BULK_MEMORY = false;\nglobalScope.ASC_FEATURE_SIMD = false;\nglobalScope.ASC_FEATURE_THREADS = false;\n\nvar F64 = new Float64Array(1);\nvar U64 = new Uint32Array(F64.buffer);\n\nObject.defineProperties(\n globalScope[\"i8\"] = function i8(value) { return value << 24 >> 24; }\n, {\n \"MIN_VALUE\": { value: -128, writable: false },\n \"MAX_VALUE\": { value: 127, writable: false }\n});\n\nObject.defineProperties(\n globalScope[\"i16\"] = function i16(value) { return value << 16 >> 16; }\n, {\n \"MIN_VALUE\": { value: -32768, writable: false },\n \"MAX_VALUE\": { value: 32767, writable: false }\n});\n\nObject.defineProperties(\n globalScope[\"i32\"] = globalScope[\"isize\"] = function i32(value) { return value | 0; }\n, {\n \"MIN_VALUE\": { value: -2147483648, writable: false },\n \"MAX_VALUE\": { value: 2147483647, writable: false }\n});\n\nObject.defineProperties(\n globalScope[\"u8\"] = function u8(value) { return value & 0xff; }\n, {\n \"MIN_VALUE\": { value: 0, writable: false },\n \"MAX_VALUE\": { value: 255, writable: false }\n});\n\nObject.defineProperties(\n globalScope[\"u16\"] = function u16(value) { return value & 0xffff; }\n, {\n \"MIN_VALUE\": { value: 0, writable: false },\n \"MAX_VALUE\": { value: 65535, writable: false }\n});\n\nObject.defineProperties(\n globalScope[\"u32\"] = globalScope[\"usize\"] = function u32(value) { return value >>> 0; }\n, {\n \"MIN_VALUE\": { value: 0, writable: false },\n \"MAX_VALUE\": { value: 4294967295, writable: false }\n});\n\nObject.defineProperties(\n globalScope[\"bool\"] = function bool(value) { return !!value; }\n, {\n \"MIN_VALUE\": { value: false, writable: false },\n \"MAX_VALUE\": { value: true, writable: false }\n});\n\nObject.defineProperties(\n globalScope[\"f32\"] = function f32(value) { return Math.fround(value); }\n, {\n \"EPSILON\": { value: Math.fround(1.1920929e-07), writable: false },\n \"MIN_VALUE\": { value: Math.fround(1.4012985e-45), writable: false },\n \"MAX_VALUE\": { value: Math.fround(3.4028235e+38), writable: false },\n \"MIN_NORMAL_VALUE\": { value: Math.fround(1.17549435e-38), writable: false },\n \"MIN_SAFE_INTEGER\": { value: -16777215, writable: false },\n \"MAX_SAFE_INTEGER\": { value: 16777215, writable: false }\n});\n\nObject.defineProperties(\n globalScope[\"f64\"] = function f64(value) { return +value; }\n, {\n \"EPSILON\": { value: 2.2204460492503131e-16, writable: false },\n \"MIN_VALUE\": { value: 5e-324, writable: false },\n \"MAX_VALUE\": { value: 1.7976931348623157e+308, writable: false },\n \"MIN_NORMAL_VALUE\": { value: 2.2250738585072014e-308 , writable: false },\n \"MIN_SAFE_INTEGER\": { value: -9007199254740991, writable: false },\n \"MAX_SAFE_INTEGER\": { value: 9007199254740991, writable: false }\n});\n\nglobalScope[\"clz\"] = Math.clz32;\n\nglobalScope[\"ctz\"] = function ctz(value) {\n var c = Math.clz32(value & -value);\n return value ? 31 - c : c;\n};\n\nglobalScope[\"popcnt\"] = function popcnt(value) {\n value -= value >>> 1 & 0x55555555;\n value = (value & 0x33333333) + (value >>> 2 & 0x33333333);\n return (((value + (value >>> 4)) & 0x0F0F0F0F) * 0x01010101) >>> 24;\n};\n\nglobalScope[\"rotl\"] = function rotl(value, shift) {\n shift &= 31;\n return (value << shift) | (value >>> (32 - shift));\n};\n\nglobalScope[\"rotr\"] = function rotr(value, shift) {\n shift &= 31;\n return (value >>> shift) | (value << (32 - shift));\n};\n\nglobalScope[\"abs\"] = Math.abs;\n\nglobalScope[\"max\"] = Math.max;\n\nglobalScope[\"min\"] = Math.min;\n\nglobalScope[\"ceil\"] = Math.ceil;\n\nglobalScope[\"floor\"] = Math.floor;\n\n// Adopt code from https://github.com/rfk/wasm-polyfill\nglobalScope[\"nearest\"] = function nearest(value) {\n if (Math.abs(value - Math.trunc(value)) === 0.5) {\n return 2.0 * Math.round(value * 0.5);\n }\n return Math.round(value);\n};\n\nglobalScope[\"select\"] = function select(ifTrue, ifFalse, condition) {\n return condition ? ifTrue : ifFalse;\n};\n\nglobalScope[\"sqrt\"] = Math.sqrt;\n\nglobalScope[\"trunc\"] = Math.trunc;\n\nglobalScope[\"copysign\"] = function copysign(x, y) {\n return Math.abs(x) * Math.sign(y);\n};\n\nglobalScope[\"bswap\"] = function bswap(value) {\n var a = value >> 8 & 0x00FF00FF;\n var b = (value & 0x00FF00FF) << 8;\n value = a | b;\n a = value >> 16 & 0x0000FFFF;\n b = (value & 0x0000FFFF) << 16;\n return a | b;\n};\n\nglobalScope[\"bswap16\"] = function bswap16(value) {\n return ((value << 8) & 0xFF00) | ((value >> 8) & 0x00FF) | (value & 0xFFFF0000);\n};\n\nfunction UnreachableError() {\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, UnreachableError);\n } else {\n this.stack = this.name + \": \" + this.message + \"\\n\" + new Error().stack;\n }\n}\nUnreachableError.prototype = Object.create(Error.prototype);\nUnreachableError.prototype.name = \"UnreachableError\";\nUnreachableError.prototype.message = \"unreachable\";\n\nglobalScope[\"unreachable\"] = function unreachable() {\n throw new UnreachableError();\n};\n\nfunction AssertionError(message) {\n this.message = message || \"assertion failed\";\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, AssertionError);\n } else {\n this.stack = this.name + \": \" + this.message + \"\\n\" + new Error().stack;\n }\n}\nAssertionError.prototype = Object.create(Error.prototype);\nAssertionError.prototype.name = \"AssertionError\";\n\nglobalScope[\"assert\"] = function assert(isTrueish, message) {\n if (isTrueish) return isTrueish;\n throw new AssertionError(message);\n};\n\nglobalScope[\"changetype\"] = function changetype(value) {\n return value;\n};\n\nString[\"fromCharCodes\"] = function fromCharCodes(arr) {\n return String.fromCharCode.apply(String, arr);\n};\n\nString[\"fromCodePoints\"] = function fromCodePoints(arr) {\n return String.fromCodePoint.apply(String, arr);\n};\n\nif (!String.prototype.replaceAll) {\n Object.defineProperty(String.prototype, \"replaceAll\", {\n value: function replaceAll(search, replacment) {\n var res = this.split(search).join(replacment);\n if (!search.length) res = replacment + res + replacment;\n return res;\n }\n });\n}\n\nglobalScope[\"isInteger\"] = Number.isInteger;\n\nglobalScope[\"isFloat\"] = function isFloat(arg) {\n return typeof arg === \"number\";\n};\n\nglobalScope[\"isNullable\"] = function isNullable(arg) {\n return true;\n}\n\nglobalScope[\"isReference\"] = function isReference(arg) {\n return typeof arg === \"object\" || typeof arg === \"string\";\n};\n\nglobalScope[\"isFunction\"] = function isFunction(arg) {\n return typeof arg === \"function\";\n}\n\nglobalScope[\"isString\"] = function isString(arg) {\n return typeof arg === \"string\" || arg instanceof String;\n};\n\nglobalScope[\"isArray\"] = Array.isArray;\nglobalScope[\"isArrayLike\"] = function isArrayLike(expr) {\n return expr\n && typeof expr === 'object'\n && typeof expr.length === 'number'\n && expr.length >= 0\n && Math.trunc(expr.length) === expr.length;\n};\n\nArray.create = function(capacity) {\n var arr = new Array(capacity);\n arr.length = 0;\n return arr;\n};\n\nglobalScope[\"isDefined\"] = function isDefined(expr) {\n return typeof expr !== \"undefined\";\n}\n\nglobalScope[\"isConstant\"] = function isConstant(expr) {\n return false;\n};\n\nglobalScope[\"unchecked\"] = function unchecked(expr) {\n return expr;\n};\n\nglobalScope[\"fmod\"] = function fmod(x, y) {\n return x % y;\n};\n\nglobalScope[\"fmodf\"] = function fmodf(x, y) {\n return Math.fround(x % y);\n};\n\nglobalScope[\"JSMath\"] = Math;\n\nObject.defineProperties(globalScope[\"JSMath\"], {\n sincos_sin: { value: 0.0, writable: true },\n sincos_cos: { value: 0.0, writable: true },\n signbit: {\n value: function signbit(x) {\n F64[0] = x; return Boolean((U64[1] >>> 31) & (x == x));\n }\n },\n sincos: {\n value: function sincos(x) {\n this.sincos_sin = Math.sin(x);\n this.sincos_cos = Math.cos(x);\n }\n }\n});\n\nglobalScope[\"memory\"] = (() => {\n var HEAP = new Uint8Array(0);\n var HEAP_OFFSET = 0;\n return {\n allocate: globalScope[\"__memory_allocate\"] || function allocate(size) {\n if (!(size >>>= 0)) return 0;\n if (HEAP_OFFSET + size > HEAP.length) {\n var oldHeap = HEAP;\n HEAP = new Uint8Array(Math.max(65536, HEAP.length + size, HEAP.length * 2));\n HEAP.set(oldHeap);\n }\n var ptr = HEAP_OFFSET;\n if ((HEAP_OFFSET += size) & 7) HEAP_OFFSET = (HEAP_OFFSET | 7) + 1;\n return ptr;\n },\n fill: globalScope[\"__memory_fill\"] || function fill(dest, value, size) {\n HEAP.fill(value, dest, dest + size);\n },\n free: globalScope[\"__memory_free\"] || function free(ptr) { },\n copy: globalScope[\"__memory_copy\"] || function copy(dest, src, size) {\n HEAP.copyWithin(dest, src, src + size);\n },\n reset: globalScope[\"__memory_reset\"] || function reset() {\n HEAP = new Uint8Array(0);\n HEAP_OFFSET = 0;\n }\n };\n})();\n\nglobalScope[\"store\"] = globalScope[\"__store\"] || function store(ptr, value, offset) {\n HEAP[(ptr | 0) + (offset | 0)] = value;\n};\n\nglobalScope[\"load\"] = globalScope[\"__load\"] || function load(ptr, offset) {\n return HEAP[(ptr | 0) + (offset | 0)];\n};\n\nglobalScope[\"unmanaged\"] = function() {};\n","const F64 = new Float64Array(1);\nconst F32 = new Float32Array(F64.buffer);\nconst I32 = new Int32Array(F64.buffer);\n\nglobal.f32_as_i32 = function(value) {\n F32[0] = value;\n return I32[0];\n};\n\nglobal.i32_as_f32 = function(value) {\n I32[0] = value;\n return F32[0];\n};\n\nglobal.f64_as_i64 = function(value) {\n F64[0] = value;\n return i64_new(I32[0], I32[1]);\n};\n\nglobal.i64_as_f64 = function(value) {\n I32[0] = i64_low(value);\n I32[1] = i64_high(value);\n return F64[0];\n};\n","const Long = global.Long || require(\"long\");\n\nglobal.i64_zero = Long.ZERO;\n\nglobal.i64_one = Long.ONE;\n\nglobal.i64_new = function(lo, hi) {\n return Long.fromBits(lo, hi);\n};\n\nglobal.i64_low = function(value) {\n return value.low;\n};\n\nglobal.i64_high = function(value) {\n return value.high;\n};\n\nglobal.i64_add = function(left, right) {\n return left.add(right);\n};\n\nglobal.i64_sub = function(left, right) {\n return left.sub(right);\n};\n\nglobal.i64_mul = function(left, right) {\n return left.mul(right);\n};\n\nglobal.i64_div = function(left, right) {\n return left.div(right);\n};\n\nglobal.i64_div_u = function(left, right) {\n return left.toUnsigned().div(right.toUnsigned()).toSigned();\n};\n\nglobal.i64_rem = function(left, right) {\n return left.mod(right);\n};\n\nglobal.i64_rem_u = function(left, right) {\n return left.toUnsigned().mod(right.toUnsigned()).toSigned();\n};\n\nglobal.i64_and = function(left, right) {\n return left.and(right);\n};\n\nglobal.i64_or = function(left, right) {\n return left.or(right);\n};\n\nglobal.i64_xor = function(left, right) {\n return left.xor(right);\n};\n\nglobal.i64_shl = function(left, right) {\n return left.shl(right);\n};\n\nglobal.i64_shr = function(left, right) {\n return left.shr(right);\n};\n\nglobal.i64_shr_u = function(left, right) {\n return left.shru(right);\n};\n\nglobal.i64_not = function(value) {\n return value.not();\n};\n\nglobal.i64_eq = function(left, right) {\n return left.eq(right);\n};\n\nglobal.i64_ne = function(left, right) {\n return left.ne(right);\n};\n\nglobal.i64_align = function(value, alignment) {\n assert(alignment && (alignment & (alignment - 1)) == 0);\n var mask = Long.fromInt(alignment - 1);\n return value.add(mask).and(mask.not());\n};\n\nglobal.i64_is_i8 = function(value) {\n return value.high === 0 && (value.low >= 0 && value.low <= i8.MAX_VALUE)\n || value.high === -1 && (value.low >= i8.MIN_VALUE && value.low < 0);\n};\n\nglobal.i64_is_i16 = function(value) {\n return value.high === 0 && (value.low >= 0 && value.low <= i16.MAX_VALUE)\n || value.high === -1 && (value.low >= i16.MIN_VALUE && value.low < 0);\n};\n\nglobal.i64_is_i32 = function(value) {\n return (value.high === 0 && value.low >= 0)\n || (value.high === -1 && value.low < 0);\n};\n\nglobal.i64_is_u8 = function(value) {\n return value.high === 0 && value.low >= 0 && value.low <= u8.MAX_VALUE;\n};\n\nglobal.i64_is_u16 = function(value) {\n return value.high === 0 && value.low >= 0 && value.low <= u16.MAX_VALUE;\n};\n\nglobal.i64_is_u32 = function(value) {\n return value.high === 0;\n};\n\nglobal.i64_is_bool = function(value) {\n return value.high === 0 && (value.low === 0 || value.low === 1);\n};\n\nconst minSafeF32 = Long.fromNumber(f32.MIN_SAFE_INTEGER);\nconst maxSafeF32 = Long.fromNumber(f32.MAX_SAFE_INTEGER);\n\nglobal.i64_is_f32 = function(value) {\n return value.gte(minSafeF32) && value.lte(maxSafeF32);\n};\n\nconst minSafeF64 = Long.fromNumber(f64.MIN_SAFE_INTEGER);\nconst maxSafeF64 = Long.fromNumber(f64.MAX_SAFE_INTEGER);\n\nglobal.i64_is_f64 = function(value) {\n return value.gte(minSafeF64) && value.lte(maxSafeF64);\n};\n\nglobal.i64_to_f32 = function(value) {\n return global.Math.fround(value.toNumber());\n};\n\nglobal.i64_to_f64 = function(value) {\n return value.toNumber();\n};\n\nglobal.i64_to_string = function(value, unsigned) {\n return (unsigned ? value.toUnsigned() : value).toString(10);\n};\n","module.exports = Long;\r\n\r\n/**\r\n * wasm optimizations, to do native i64 multiplication and divide\r\n */\r\nvar wasm = null;\r\n\r\ntry {\r\n wasm = new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([\r\n 0, 97, 115, 109, 1, 0, 0, 0, 1, 13, 2, 96, 0, 1, 127, 96, 4, 127, 127, 127, 127, 1, 127, 3, 7, 6, 0, 1, 1, 1, 1, 1, 6, 6, 1, 127, 1, 65, 0, 11, 7, 50, 6, 3, 109, 117, 108, 0, 1, 5, 100, 105, 118, 95, 115, 0, 2, 5, 100, 105, 118, 95, 117, 0, 3, 5, 114, 101, 109, 95, 115, 0, 4, 5, 114, 101, 109, 95, 117, 0, 5, 8, 103, 101, 116, 95, 104, 105, 103, 104, 0, 0, 10, 191, 1, 6, 4, 0, 35, 0, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 126, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 127, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 128, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 129, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 130, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11\r\n ])), {}).exports;\r\n} catch (e) {\r\n // no wasm support :(\r\n}\r\n\r\n/**\r\n * Constructs a 64 bit two's-complement integer, given its low and high 32 bit values as *signed* integers.\r\n * See the from* functions below for more convenient ways of constructing Longs.\r\n * @exports Long\r\n * @class A Long class for representing a 64 bit two's-complement integer value.\r\n * @param {number} low The low (signed) 32 bits of the long\r\n * @param {number} high The high (signed) 32 bits of the long\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @constructor\r\n */\r\nfunction Long(low, high, unsigned) {\r\n\r\n /**\r\n * The low 32 bits as a signed value.\r\n * @type {number}\r\n */\r\n this.low = low | 0;\r\n\r\n /**\r\n * The high 32 bits as a signed value.\r\n * @type {number}\r\n */\r\n this.high = high | 0;\r\n\r\n /**\r\n * Whether unsigned or not.\r\n * @type {boolean}\r\n */\r\n this.unsigned = !!unsigned;\r\n}\r\n\r\n// The internal representation of a long is the two given signed, 32-bit values.\r\n// We use 32-bit pieces because these are the size of integers on which\r\n// Javascript performs bit-operations. For operations like addition and\r\n// multiplication, we split each number into 16 bit pieces, which can easily be\r\n// multiplied within Javascript's floating-point representation without overflow\r\n// or change in sign.\r\n//\r\n// In the algorithms below, we frequently reduce the negative case to the\r\n// positive case by negating the input(s) and then post-processing the result.\r\n// Note that we must ALWAYS check specially whether those values are MIN_VALUE\r\n// (-2^63) because -MIN_VALUE == MIN_VALUE (since 2^63 cannot be represented as\r\n// a positive number, it overflows back into a negative). Not handling this\r\n// case would often result in infinite recursion.\r\n//\r\n// Common constant values ZERO, ONE, NEG_ONE, etc. are defined below the from*\r\n// methods on which they depend.\r\n\r\n/**\r\n * An indicator used to reliably determine if an object is a Long or not.\r\n * @type {boolean}\r\n * @const\r\n * @private\r\n */\r\nLong.prototype.__isLong__;\r\n\r\nObject.defineProperty(Long.prototype, \"__isLong__\", { value: true });\r\n\r\n/**\r\n * @function\r\n * @param {*} obj Object\r\n * @returns {boolean}\r\n * @inner\r\n */\r\nfunction isLong(obj) {\r\n return (obj && obj[\"__isLong__\"]) === true;\r\n}\r\n\r\n/**\r\n * Tests if the specified object is a Long.\r\n * @function\r\n * @param {*} obj Object\r\n * @returns {boolean}\r\n */\r\nLong.isLong = isLong;\r\n\r\n/**\r\n * A cache of the Long representations of small integer values.\r\n * @type {!Object}\r\n * @inner\r\n */\r\nvar INT_CACHE = {};\r\n\r\n/**\r\n * A cache of the Long representations of small unsigned integer values.\r\n * @type {!Object}\r\n * @inner\r\n */\r\nvar UINT_CACHE = {};\r\n\r\n/**\r\n * @param {number} value\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromInt(value, unsigned) {\r\n var obj, cachedObj, cache;\r\n if (unsigned) {\r\n value >>>= 0;\r\n if (cache = (0 <= value && value < 256)) {\r\n cachedObj = UINT_CACHE[value];\r\n if (cachedObj)\r\n return cachedObj;\r\n }\r\n obj = fromBits(value, (value | 0) < 0 ? -1 : 0, true);\r\n if (cache)\r\n UINT_CACHE[value] = obj;\r\n return obj;\r\n } else {\r\n value |= 0;\r\n if (cache = (-128 <= value && value < 128)) {\r\n cachedObj = INT_CACHE[value];\r\n if (cachedObj)\r\n return cachedObj;\r\n }\r\n obj = fromBits(value, value < 0 ? -1 : 0, false);\r\n if (cache)\r\n INT_CACHE[value] = obj;\r\n return obj;\r\n }\r\n}\r\n\r\n/**\r\n * Returns a Long representing the given 32 bit integer value.\r\n * @function\r\n * @param {number} value The 32 bit integer in question\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromInt = fromInt;\r\n\r\n/**\r\n * @param {number} value\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromNumber(value, unsigned) {\r\n if (isNaN(value))\r\n return unsigned ? UZERO : ZERO;\r\n if (unsigned) {\r\n if (value < 0)\r\n return UZERO;\r\n if (value >= TWO_PWR_64_DBL)\r\n return MAX_UNSIGNED_VALUE;\r\n } else {\r\n if (value <= -TWO_PWR_63_DBL)\r\n return MIN_VALUE;\r\n if (value + 1 >= TWO_PWR_63_DBL)\r\n return MAX_VALUE;\r\n }\r\n if (value < 0)\r\n return fromNumber(-value, unsigned).neg();\r\n return fromBits((value % TWO_PWR_32_DBL) | 0, (value / TWO_PWR_32_DBL) | 0, unsigned);\r\n}\r\n\r\n/**\r\n * Returns a Long representing the given value, provided that it is a finite number. Otherwise, zero is returned.\r\n * @function\r\n * @param {number} value The number in question\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromNumber = fromNumber;\r\n\r\n/**\r\n * @param {number} lowBits\r\n * @param {number} highBits\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromBits(lowBits, highBits, unsigned) {\r\n return new Long(lowBits, highBits, unsigned);\r\n}\r\n\r\n/**\r\n * Returns a Long representing the 64 bit integer that comes by concatenating the given low and high bits. Each is\r\n * assumed to use 32 bits.\r\n * @function\r\n * @param {number} lowBits The low 32 bits\r\n * @param {number} highBits The high 32 bits\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromBits = fromBits;\r\n\r\n/**\r\n * @function\r\n * @param {number} base\r\n * @param {number} exponent\r\n * @returns {number}\r\n * @inner\r\n */\r\nvar pow_dbl = Math.pow; // Used 4 times (4*8 to 15+4)\r\n\r\n/**\r\n * @param {string} str\r\n * @param {(boolean|number)=} unsigned\r\n * @param {number=} radix\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromString(str, unsigned, radix) {\r\n if (str.length === 0)\r\n throw Error('empty string');\r\n if (str === \"NaN\" || str === \"Infinity\" || str === \"+Infinity\" || str === \"-Infinity\")\r\n return ZERO;\r\n if (typeof unsigned === 'number') {\r\n // For goog.math.long compatibility\r\n radix = unsigned,\r\n unsigned = false;\r\n } else {\r\n unsigned = !! unsigned;\r\n }\r\n radix = radix || 10;\r\n if (radix < 2 || 36 < radix)\r\n throw RangeError('radix');\r\n\r\n var p;\r\n if ((p = str.indexOf('-')) > 0)\r\n throw Error('interior hyphen');\r\n else if (p === 0) {\r\n return fromString(str.substring(1), unsigned, radix).neg();\r\n }\r\n\r\n // Do several (8) digits each time through the loop, so as to\r\n // minimize the calls to the very expensive emulated div.\r\n var radixToPower = fromNumber(pow_dbl(radix, 8));\r\n\r\n var result = ZERO;\r\n for (var i = 0; i < str.length; i += 8) {\r\n var size = Math.min(8, str.length - i),\r\n value = parseInt(str.substring(i, i + size), radix);\r\n if (size < 8) {\r\n var power = fromNumber(pow_dbl(radix, size));\r\n result = result.mul(power).add(fromNumber(value));\r\n } else {\r\n result = result.mul(radixToPower);\r\n result = result.add(fromNumber(value));\r\n }\r\n }\r\n result.unsigned = unsigned;\r\n return result;\r\n}\r\n\r\n/**\r\n * Returns a Long representation of the given string, written using the specified radix.\r\n * @function\r\n * @param {string} str The textual representation of the Long\r\n * @param {(boolean|number)=} unsigned Whether unsigned or not, defaults to signed\r\n * @param {number=} radix The radix in which the text is written (2-36), defaults to 10\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromString = fromString;\r\n\r\n/**\r\n * @function\r\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromValue(val, unsigned) {\r\n if (typeof val === 'number')\r\n return fromNumber(val, unsigned);\r\n if (typeof val === 'string')\r\n return fromString(val, unsigned);\r\n // Throws for non-objects, converts non-instanceof Long:\r\n return fromBits(val.low, val.high, typeof unsigned === 'boolean' ? unsigned : val.unsigned);\r\n}\r\n\r\n/**\r\n * Converts the specified value to a Long using the appropriate from* function for its type.\r\n * @function\r\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val Value\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long}\r\n */\r\nLong.fromValue = fromValue;\r\n\r\n// NOTE: the compiler should inline these constant values below and then remove these variables, so there should be\r\n// no runtime penalty for these.\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_16_DBL = 1 << 16;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_24_DBL = 1 << 24;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_32_DBL = TWO_PWR_16_DBL * TWO_PWR_16_DBL;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_64_DBL = TWO_PWR_32_DBL * TWO_PWR_32_DBL;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_63_DBL = TWO_PWR_64_DBL / 2;\r\n\r\n/**\r\n * @type {!Long}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_24 = fromInt(TWO_PWR_24_DBL);\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar ZERO = fromInt(0);\r\n\r\n/**\r\n * Signed zero.\r\n * @type {!Long}\r\n */\r\nLong.ZERO = ZERO;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar UZERO = fromInt(0, true);\r\n\r\n/**\r\n * Unsigned zero.\r\n * @type {!Long}\r\n */\r\nLong.UZERO = UZERO;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar ONE = fromInt(1);\r\n\r\n/**\r\n * Signed one.\r\n * @type {!Long}\r\n */\r\nLong.ONE = ONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar UONE = fromInt(1, true);\r\n\r\n/**\r\n * Unsigned one.\r\n * @type {!Long}\r\n */\r\nLong.UONE = UONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar NEG_ONE = fromInt(-1);\r\n\r\n/**\r\n * Signed negative one.\r\n * @type {!Long}\r\n */\r\nLong.NEG_ONE = NEG_ONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MAX_VALUE = fromBits(0xFFFFFFFF|0, 0x7FFFFFFF|0, false);\r\n\r\n/**\r\n * Maximum signed value.\r\n * @type {!Long}\r\n */\r\nLong.MAX_VALUE = MAX_VALUE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MAX_UNSIGNED_VALUE = fromBits(0xFFFFFFFF|0, 0xFFFFFFFF|0, true);\r\n\r\n/**\r\n * Maximum unsigned value.\r\n * @type {!Long}\r\n */\r\nLong.MAX_UNSIGNED_VALUE = MAX_UNSIGNED_VALUE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MIN_VALUE = fromBits(0, 0x80000000|0, false);\r\n\r\n/**\r\n * Minimum signed value.\r\n * @type {!Long}\r\n */\r\nLong.MIN_VALUE = MIN_VALUE;\r\n\r\n/**\r\n * @alias Long.prototype\r\n * @inner\r\n */\r\nvar LongPrototype = Long.prototype;\r\n\r\n/**\r\n * Converts the Long to a 32 bit integer, assuming it is a 32 bit integer.\r\n * @returns {number}\r\n */\r\nLongPrototype.toInt = function toInt() {\r\n return this.unsigned ? this.low >>> 0 : this.low;\r\n};\r\n\r\n/**\r\n * Converts the Long to a the nearest floating-point representation of this value (double, 53 bit mantissa).\r\n * @returns {number}\r\n */\r\nLongPrototype.toNumber = function toNumber() {\r\n if (this.unsigned)\r\n return ((this.high >>> 0) * TWO_PWR_32_DBL) + (this.low >>> 0);\r\n return this.high * TWO_PWR_32_DBL + (this.low >>> 0);\r\n};\r\n\r\n/**\r\n * Converts the Long to a string written in the specified radix.\r\n * @param {number=} radix Radix (2-36), defaults to 10\r\n * @returns {string}\r\n * @override\r\n * @throws {RangeError} If `radix` is out of range\r\n */\r\nLongPrototype.toString = function toString(radix) {\r\n radix = radix || 10;\r\n if (radix < 2 || 36 < radix)\r\n throw RangeError('radix');\r\n if (this.isZero())\r\n return '0';\r\n if (this.isNegative()) { // Unsigned Longs are never negative\r\n if (this.eq(MIN_VALUE)) {\r\n // We need to change the Long value before it can be negated, so we remove\r\n // the bottom-most digit in this base and then recurse to do the rest.\r\n var radixLong = fromNumber(radix),\r\n div = this.div(radixLong),\r\n rem1 = div.mul(radixLong).sub(this);\r\n return div.toString(radix) + rem1.toInt().toString(radix);\r\n } else\r\n return '-' + this.neg().toString(radix);\r\n }\r\n\r\n // Do several (6) digits each time through the loop, so as to\r\n // minimize the calls to the very expensive emulated div.\r\n var radixToPower = fromNumber(pow_dbl(radix, 6), this.unsigned),\r\n rem = this;\r\n var result = '';\r\n while (true) {\r\n var remDiv = rem.div(radixToPower),\r\n intval = rem.sub(remDiv.mul(radixToPower)).toInt() >>> 0,\r\n digits = intval.toString(radix);\r\n rem = remDiv;\r\n if (rem.isZero())\r\n return digits + result;\r\n else {\r\n while (digits.length < 6)\r\n digits = '0' + digits;\r\n result = '' + digits + result;\r\n }\r\n }\r\n};\r\n\r\n/**\r\n * Gets the high 32 bits as a signed integer.\r\n * @returns {number} Signed high bits\r\n */\r\nLongPrototype.getHighBits = function getHighBits() {\r\n return this.high;\r\n};\r\n\r\n/**\r\n * Gets the high 32 bits as an unsigned integer.\r\n * @returns {number} Unsigned high bits\r\n */\r\nLongPrototype.getHighBitsUnsigned = function getHighBitsUnsigned() {\r\n return this.high >>> 0;\r\n};\r\n\r\n/**\r\n * Gets the low 32 bits as a signed integer.\r\n * @returns {number} Signed low bits\r\n */\r\nLongPrototype.getLowBits = function getLowBits() {\r\n return this.low;\r\n};\r\n\r\n/**\r\n * Gets the low 32 bits as an unsigned integer.\r\n * @returns {number} Unsigned low bits\r\n */\r\nLongPrototype.getLowBitsUnsigned = function getLowBitsUnsigned() {\r\n return this.low >>> 0;\r\n};\r\n\r\n/**\r\n * Gets the number of bits needed to represent the absolute value of this Long.\r\n * @returns {number}\r\n */\r\nLongPrototype.getNumBitsAbs = function getNumBitsAbs() {\r\n if (this.isNegative()) // Unsigned Longs are never negative\r\n return this.eq(MIN_VALUE) ? 64 : this.neg().getNumBitsAbs();\r\n var val = this.high != 0 ? this.high : this.low;\r\n for (var bit = 31; bit > 0; bit--)\r\n if ((val & (1 << bit)) != 0)\r\n break;\r\n return this.high != 0 ? bit + 33 : bit + 1;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals zero.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isZero = function isZero() {\r\n return this.high === 0 && this.low === 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals zero. This is an alias of {@link Long#isZero}.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.eqz = LongPrototype.isZero;\r\n\r\n/**\r\n * Tests if this Long's value is negative.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isNegative = function isNegative() {\r\n return !this.unsigned && this.high < 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is positive.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isPositive = function isPositive() {\r\n return this.unsigned || this.high >= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is odd.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isOdd = function isOdd() {\r\n return (this.low & 1) === 1;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is even.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isEven = function isEven() {\r\n return (this.low & 1) === 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.equals = function equals(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n if (this.unsigned !== other.unsigned && (this.high >>> 31) === 1 && (other.high >>> 31) === 1)\r\n return false;\r\n return this.high === other.high && this.low === other.low;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals the specified's. This is an alias of {@link Long#equals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.eq = LongPrototype.equals;\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.notEquals = function notEquals(other) {\r\n return !this.eq(/* validates */ other);\r\n};\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.neq = LongPrototype.notEquals;\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.ne = LongPrototype.notEquals;\r\n\r\n/**\r\n * Tests if this Long's value is less than the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lessThan = function lessThan(other) {\r\n return this.comp(/* validates */ other) < 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is less than the specified's. This is an alias of {@link Long#lessThan}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lt = LongPrototype.lessThan;\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lessThanOrEqual = function lessThanOrEqual(other) {\r\n return this.comp(/* validates */ other) <= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lte = LongPrototype.lessThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.le = LongPrototype.lessThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is greater than the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.greaterThan = function greaterThan(other) {\r\n return this.comp(/* validates */ other) > 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is greater than the specified's. This is an alias of {@link Long#greaterThan}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.gt = LongPrototype.greaterThan;\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.greaterThanOrEqual = function greaterThanOrEqual(other) {\r\n return this.comp(/* validates */ other) >= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.gte = LongPrototype.greaterThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.ge = LongPrototype.greaterThanOrEqual;\r\n\r\n/**\r\n * Compares this Long's value with the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\r\n * if the given one is greater\r\n */\r\nLongPrototype.compare = function compare(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n if (this.eq(other))\r\n return 0;\r\n var thisNeg = this.isNegative(),\r\n otherNeg = other.isNegative();\r\n if (thisNeg && !otherNeg)\r\n return -1;\r\n if (!thisNeg && otherNeg)\r\n return 1;\r\n // At this point the sign bits are the same\r\n if (!this.unsigned)\r\n return this.sub(other).isNegative() ? -1 : 1;\r\n // Both are positive if at least one is unsigned\r\n return (other.high >>> 0) > (this.high >>> 0) || (other.high === this.high && (other.low >>> 0) > (this.low >>> 0)) ? -1 : 1;\r\n};\r\n\r\n/**\r\n * Compares this Long's value with the specified's. This is an alias of {@link Long#compare}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\r\n * if the given one is greater\r\n */\r\nLongPrototype.comp = LongPrototype.compare;\r\n\r\n/**\r\n * Negates this Long's value.\r\n * @returns {!Long} Negated Long\r\n */\r\nLongPrototype.negate = function negate() {\r\n if (!this.unsigned && this.eq(MIN_VALUE))\r\n return MIN_VALUE;\r\n return this.not().add(ONE);\r\n};\r\n\r\n/**\r\n * Negates this Long's value. This is an alias of {@link Long#negate}.\r\n * @function\r\n * @returns {!Long} Negated Long\r\n */\r\nLongPrototype.neg = LongPrototype.negate;\r\n\r\n/**\r\n * Returns the sum of this and the specified Long.\r\n * @param {!Long|number|string} addend Addend\r\n * @returns {!Long} Sum\r\n */\r\nLongPrototype.add = function add(addend) {\r\n if (!isLong(addend))\r\n addend = fromValue(addend);\r\n\r\n // Divide each number into 4 chunks of 16 bits, and then sum the chunks.\r\n\r\n var a48 = this.high >>> 16;\r\n var a32 = this.high & 0xFFFF;\r\n var a16 = this.low >>> 16;\r\n var a00 = this.low & 0xFFFF;\r\n\r\n var b48 = addend.high >>> 16;\r\n var b32 = addend.high & 0xFFFF;\r\n var b16 = addend.low >>> 16;\r\n var b00 = addend.low & 0xFFFF;\r\n\r\n var c48 = 0, c32 = 0, c16 = 0, c00 = 0;\r\n c00 += a00 + b00;\r\n c16 += c00 >>> 16;\r\n c00 &= 0xFFFF;\r\n c16 += a16 + b16;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c32 += a32 + b32;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c48 += a48 + b48;\r\n c48 &= 0xFFFF;\r\n return fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the difference of this and the specified Long.\r\n * @param {!Long|number|string} subtrahend Subtrahend\r\n * @returns {!Long} Difference\r\n */\r\nLongPrototype.subtract = function subtract(subtrahend) {\r\n if (!isLong(subtrahend))\r\n subtrahend = fromValue(subtrahend);\r\n return this.add(subtrahend.neg());\r\n};\r\n\r\n/**\r\n * Returns the difference of this and the specified Long. This is an alias of {@link Long#subtract}.\r\n * @function\r\n * @param {!Long|number|string} subtrahend Subtrahend\r\n * @returns {!Long} Difference\r\n */\r\nLongPrototype.sub = LongPrototype.subtract;\r\n\r\n/**\r\n * Returns the product of this and the specified Long.\r\n * @param {!Long|number|string} multiplier Multiplier\r\n * @returns {!Long} Product\r\n */\r\nLongPrototype.multiply = function multiply(multiplier) {\r\n if (this.isZero())\r\n return ZERO;\r\n if (!isLong(multiplier))\r\n multiplier = fromValue(multiplier);\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n var low = wasm.mul(this.low,\r\n this.high,\r\n multiplier.low,\r\n multiplier.high);\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n if (multiplier.isZero())\r\n return ZERO;\r\n if (this.eq(MIN_VALUE))\r\n return multiplier.isOdd() ? MIN_VALUE : ZERO;\r\n if (multiplier.eq(MIN_VALUE))\r\n return this.isOdd() ? MIN_VALUE : ZERO;\r\n\r\n if (this.isNegative()) {\r\n if (multiplier.isNegative())\r\n return this.neg().mul(multiplier.neg());\r\n else\r\n return this.neg().mul(multiplier).neg();\r\n } else if (multiplier.isNegative())\r\n return this.mul(multiplier.neg()).neg();\r\n\r\n // If both longs are small, use float multiplication\r\n if (this.lt(TWO_PWR_24) && multiplier.lt(TWO_PWR_24))\r\n return fromNumber(this.toNumber() * multiplier.toNumber(), this.unsigned);\r\n\r\n // Divide each long into 4 chunks of 16 bits, and then add up 4x4 products.\r\n // We can skip products that would overflow.\r\n\r\n var a48 = this.high >>> 16;\r\n var a32 = this.high & 0xFFFF;\r\n var a16 = this.low >>> 16;\r\n var a00 = this.low & 0xFFFF;\r\n\r\n var b48 = multiplier.high >>> 16;\r\n var b32 = multiplier.high & 0xFFFF;\r\n var b16 = multiplier.low >>> 16;\r\n var b00 = multiplier.low & 0xFFFF;\r\n\r\n var c48 = 0, c32 = 0, c16 = 0, c00 = 0;\r\n c00 += a00 * b00;\r\n c16 += c00 >>> 16;\r\n c00 &= 0xFFFF;\r\n c16 += a16 * b00;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c16 += a00 * b16;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c32 += a32 * b00;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c32 += a16 * b16;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c32 += a00 * b32;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c48 += a48 * b00 + a32 * b16 + a16 * b32 + a00 * b48;\r\n c48 &= 0xFFFF;\r\n return fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the product of this and the specified Long. This is an alias of {@link Long#multiply}.\r\n * @function\r\n * @param {!Long|number|string} multiplier Multiplier\r\n * @returns {!Long} Product\r\n */\r\nLongPrototype.mul = LongPrototype.multiply;\r\n\r\n/**\r\n * Returns this Long divided by the specified. The result is signed if this Long is signed or\r\n * unsigned if this Long is unsigned.\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Quotient\r\n */\r\nLongPrototype.divide = function divide(divisor) {\r\n if (!isLong(divisor))\r\n divisor = fromValue(divisor);\r\n if (divisor.isZero())\r\n throw Error('division by zero');\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n // guard against signed division overflow: the largest\r\n // negative number / -1 would be 1 larger than the largest\r\n // positive number, due to two's complement.\r\n if (!this.unsigned &&\r\n this.high === -0x80000000 &&\r\n divisor.low === -1 && divisor.high === -1) {\r\n // be consistent with non-wasm code path\r\n return this;\r\n }\r\n var low = (this.unsigned ? wasm.div_u : wasm.div_s)(\r\n this.low,\r\n this.high,\r\n divisor.low,\r\n divisor.high\r\n );\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n if (this.isZero())\r\n return this.unsigned ? UZERO : ZERO;\r\n var approx, rem, res;\r\n if (!this.unsigned) {\r\n // This section is only relevant for signed longs and is derived from the\r\n // closure library as a whole.\r\n if (this.eq(MIN_VALUE)) {\r\n if (divisor.eq(ONE) || divisor.eq(NEG_ONE))\r\n return MIN_VALUE; // recall that -MIN_VALUE == MIN_VALUE\r\n else if (divisor.eq(MIN_VALUE))\r\n return ONE;\r\n else {\r\n // At this point, we have |other| >= 2, so |this/other| < |MIN_VALUE|.\r\n var halfThis = this.shr(1);\r\n approx = halfThis.div(divisor).shl(1);\r\n if (approx.eq(ZERO)) {\r\n return divisor.isNegative() ? ONE : NEG_ONE;\r\n } else {\r\n rem = this.sub(divisor.mul(approx));\r\n res = approx.add(rem.div(divisor));\r\n return res;\r\n }\r\n }\r\n } else if (divisor.eq(MIN_VALUE))\r\n return this.unsigned ? UZERO : ZERO;\r\n if (this.isNegative()) {\r\n if (divisor.isNegative())\r\n return this.neg().div(divisor.neg());\r\n return this.neg().div(divisor).neg();\r\n } else if (divisor.isNegative())\r\n return this.div(divisor.neg()).neg();\r\n res = ZERO;\r\n } else {\r\n // The algorithm below has not been made for unsigned longs. It's therefore\r\n // required to take special care of the MSB prior to running it.\r\n if (!divisor.unsigned)\r\n divisor = divisor.toUnsigned();\r\n if (divisor.gt(this))\r\n return UZERO;\r\n if (divisor.gt(this.shru(1))) // 15 >>> 1 = 7 ; with divisor = 8 ; true\r\n return UONE;\r\n res = UZERO;\r\n }\r\n\r\n // Repeat the following until the remainder is less than other: find a\r\n // floating-point that approximates remainder / other *from below*, add this\r\n // into the result, and subtract it from the remainder. It is critical that\r\n // the approximate value is less than or equal to the real value so that the\r\n // remainder never becomes negative.\r\n rem = this;\r\n while (rem.gte(divisor)) {\r\n // Approximate the result of division. This may be a little greater or\r\n // smaller than the actual value.\r\n approx = Math.max(1, Math.floor(rem.toNumber() / divisor.toNumber()));\r\n\r\n // We will tweak the approximate result by changing it in the 48-th digit or\r\n // the smallest non-fractional digit, whichever is larger.\r\n var log2 = Math.ceil(Math.log(approx) / Math.LN2),\r\n delta = (log2 <= 48) ? 1 : pow_dbl(2, log2 - 48),\r\n\r\n // Decrease the approximation until it is smaller than the remainder. Note\r\n // that if it is too large, the product overflows and is negative.\r\n approxRes = fromNumber(approx),\r\n approxRem = approxRes.mul(divisor);\r\n while (approxRem.isNegative() || approxRem.gt(rem)) {\r\n approx -= delta;\r\n approxRes = fromNumber(approx, this.unsigned);\r\n approxRem = approxRes.mul(divisor);\r\n }\r\n\r\n // We know the answer can't be zero... and actually, zero would cause\r\n // infinite recursion since we would make no progress.\r\n if (approxRes.isZero())\r\n approxRes = ONE;\r\n\r\n res = res.add(approxRes);\r\n rem = rem.sub(approxRem);\r\n }\r\n return res;\r\n};\r\n\r\n/**\r\n * Returns this Long divided by the specified. This is an alias of {@link Long#divide}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Quotient\r\n */\r\nLongPrototype.div = LongPrototype.divide;\r\n\r\n/**\r\n * Returns this Long modulo the specified.\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.modulo = function modulo(divisor) {\r\n if (!isLong(divisor))\r\n divisor = fromValue(divisor);\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n var low = (this.unsigned ? wasm.rem_u : wasm.rem_s)(\r\n this.low,\r\n this.high,\r\n divisor.low,\r\n divisor.high\r\n );\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n return this.sub(this.div(divisor).mul(divisor));\r\n};\r\n\r\n/**\r\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.mod = LongPrototype.modulo;\r\n\r\n/**\r\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.rem = LongPrototype.modulo;\r\n\r\n/**\r\n * Returns the bitwise NOT of this Long.\r\n * @returns {!Long}\r\n */\r\nLongPrototype.not = function not() {\r\n return fromBits(~this.low, ~this.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise AND of this Long and the specified.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.and = function and(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low & other.low, this.high & other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise OR of this Long and the specified.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.or = function or(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low | other.low, this.high | other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise XOR of this Long and the given one.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.xor = function xor(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low ^ other.low, this.high ^ other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits shifted to the left by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftLeft = function shiftLeft(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n if ((numBits &= 63) === 0)\r\n return this;\r\n else if (numBits < 32)\r\n return fromBits(this.low << numBits, (this.high << numBits) | (this.low >>> (32 - numBits)), this.unsigned);\r\n else\r\n return fromBits(0, this.low << (numBits - 32), this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits shifted to the left by the given amount. This is an alias of {@link Long#shiftLeft}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shl = LongPrototype.shiftLeft;\r\n\r\n/**\r\n * Returns this Long with bits arithmetically shifted to the right by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftRight = function shiftRight(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n if ((numBits &= 63) === 0)\r\n return this;\r\n else if (numBits < 32)\r\n return fromBits((this.low >>> numBits) | (this.high << (32 - numBits)), this.high >> numBits, this.unsigned);\r\n else\r\n return fromBits(this.high >> (numBits - 32), this.high >= 0 ? 0 : -1, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits arithmetically shifted to the right by the given amount. This is an alias of {@link Long#shiftRight}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shr = LongPrototype.shiftRight;\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftRightUnsigned = function shiftRightUnsigned(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n numBits &= 63;\r\n if (numBits === 0)\r\n return this;\r\n else {\r\n var high = this.high;\r\n if (numBits < 32) {\r\n var low = this.low;\r\n return fromBits((low >>> numBits) | (high << (32 - numBits)), high >>> numBits, this.unsigned);\r\n } else if (numBits === 32)\r\n return fromBits(high, 0, this.unsigned);\r\n else\r\n return fromBits(high >>> (numBits - 32), 0, this.unsigned);\r\n }\r\n};\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shru = LongPrototype.shiftRightUnsigned;\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shr_u = LongPrototype.shiftRightUnsigned;\r\n\r\n/**\r\n * Converts this Long to signed.\r\n * @returns {!Long} Signed long\r\n */\r\nLongPrototype.toSigned = function toSigned() {\r\n if (!this.unsigned)\r\n return this;\r\n return fromBits(this.low, this.high, false);\r\n};\r\n\r\n/**\r\n * Converts this Long to unsigned.\r\n * @returns {!Long} Unsigned long\r\n */\r\nLongPrototype.toUnsigned = function toUnsigned() {\r\n if (this.unsigned)\r\n return this;\r\n return fromBits(this.low, this.high, true);\r\n};\r\n\r\n/**\r\n * Converts this Long to its byte representation.\r\n * @param {boolean=} le Whether little or big endian, defaults to big endian\r\n * @returns {!Array.} Byte representation\r\n */\r\nLongPrototype.toBytes = function toBytes(le) {\r\n return le ? this.toBytesLE() : this.toBytesBE();\r\n};\r\n\r\n/**\r\n * Converts this Long to its little endian byte representation.\r\n * @returns {!Array.} Little endian byte representation\r\n */\r\nLongPrototype.toBytesLE = function toBytesLE() {\r\n var hi = this.high,\r\n lo = this.low;\r\n return [\r\n lo & 0xff,\r\n lo >>> 8 & 0xff,\r\n lo >>> 16 & 0xff,\r\n lo >>> 24 ,\r\n hi & 0xff,\r\n hi >>> 8 & 0xff,\r\n hi >>> 16 & 0xff,\r\n hi >>> 24\r\n ];\r\n};\r\n\r\n/**\r\n * Converts this Long to its big endian byte representation.\r\n * @returns {!Array.} Big endian byte representation\r\n */\r\nLongPrototype.toBytesBE = function toBytesBE() {\r\n var hi = this.high,\r\n lo = this.low;\r\n return [\r\n hi >>> 24 ,\r\n hi >>> 16 & 0xff,\r\n hi >>> 8 & 0xff,\r\n hi & 0xff,\r\n lo >>> 24 ,\r\n lo >>> 16 & 0xff,\r\n lo >>> 8 & 0xff,\r\n lo & 0xff\r\n ];\r\n};\r\n\r\n/**\r\n * Creates a Long from its byte representation.\r\n * @param {!Array.} bytes Byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @param {boolean=} le Whether little or big endian, defaults to big endian\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytes = function fromBytes(bytes, unsigned, le) {\r\n return le ? Long.fromBytesLE(bytes, unsigned) : Long.fromBytesBE(bytes, unsigned);\r\n};\r\n\r\n/**\r\n * Creates a Long from its little endian byte representation.\r\n * @param {!Array.} bytes Little endian byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytesLE = function fromBytesLE(bytes, unsigned) {\r\n return new Long(\r\n bytes[0] |\r\n bytes[1] << 8 |\r\n bytes[2] << 16 |\r\n bytes[3] << 24,\r\n bytes[4] |\r\n bytes[5] << 8 |\r\n bytes[6] << 16 |\r\n bytes[7] << 24,\r\n unsigned\r\n );\r\n};\r\n\r\n/**\r\n * Creates a Long from its big endian byte representation.\r\n * @param {!Array.} bytes Big endian byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytesBE = function fromBytesBE(bytes, unsigned) {\r\n return new Long(\r\n bytes[4] << 24 |\r\n bytes[5] << 16 |\r\n bytes[6] << 8 |\r\n bytes[7],\r\n bytes[0] << 24 |\r\n bytes[1] << 16 |\r\n bytes[2] << 8 |\r\n bytes[3],\r\n unsigned\r\n );\r\n};\r\n","// This file is shared with the compiler and must remain portable\n\n/** Indicates specific features to activate. */\nexport const enum Feature {\n /** No additional features. */\n NONE = 0,\n /** Sign extension operations. */\n SIGN_EXTENSION = 1 << 0, // see: https://github.com/WebAssembly/sign-extension-ops\n /** Mutable global imports and exports. */\n MUTABLE_GLOBAL = 1 << 1, // see: https://github.com/WebAssembly/mutable-global\n /** Bulk memory operations. */\n BULK_MEMORY = 1 << 2, // see: https://github.com/WebAssembly/bulk-memory-operations\n /** SIMD types and operations. */\n SIMD = 1 << 3, // see: https://github.com/WebAssembly/simd\n /** Threading and atomic operations. */\n THREADS = 1 << 4 // see: https://github.com/WebAssembly/threads\n}\n","// This file is shared with the compiler and must remain portable\n\n/** Compilation target. */\nexport enum Target {\n /** WebAssembly with 32-bit pointers. */\n WASM32,\n /** WebAssembly with 64-bit pointers. Experimental and not supported by any runtime yet. */\n WASM64,\n /** Portable. */\n JS\n}\n","// This file is shared with the compiler and must remain portable\n\n// ╒═══════════════════ Typeinfo interpretation ═══════════════════╕\n// 3 2 1\n// 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 bits\n// ├─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┤ ◄─ __rtti_base\n// │ count │\n// ╞═══════════════════════════════════════════════════════════════╡ ┐\n// │ Typeinfo#flags [id=0] │ id < count\n// ├ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ┤\n// │ Typeinfo#base [id=0] │\n// ├───────────────────────────────────────────────────────────────┤\n// │ ... │\n\n/** Runtime type information data structure. */\n@unmanaged\nexport class Typeinfo {\n /** Flags describing the shape of this class type. */\n flags: TypeinfoFlags;\n /** Base class id or `0` if none. */\n base: u32;\n}\n\n/** Runtime type information flags. */\nexport const enum TypeinfoFlags {\n /** No specific flags. */\n NONE = 0,\n /** Type is an `ArrayBufferView`. */\n ARRAYBUFFERVIEW = 1 << 0,\n /** Type is an `Array`. */\n ARRAY = 1 << 1,\n /** Type is a `Set`. */\n SET = 1 << 2,\n /** Type is a `Map`. */\n MAP = 1 << 3,\n /** Type is inherently acyclic. */\n ACYCLIC = 1 << 4,\n /** Value alignment of 1 byte. */\n VALUE_ALIGN_0 = 1 << 5,\n /** Value alignment of 2 bytes. */\n VALUE_ALIGN_1 = 1 << 6,\n /** Value alignment of 4 bytes. */\n VALUE_ALIGN_2 = 1 << 7,\n /** Value alignment of 8 bytes. */\n VALUE_ALIGN_3 = 1 << 8,\n /** Value alignment of 16 bytes. */\n VALUE_ALIGN_4 = 1 << 9,\n /** Value is a signed type. */\n VALUE_SIGNED = 1 << 10,\n /** Value is a float type. */\n VALUE_FLOAT = 1 << 11,\n /** Value type is nullable. */\n VALUE_NULLABLE = 1 << 12,\n /** Value type is managed. */\n VALUE_MANAGED = 1 << 13,\n /** Key alignment of 1 byte. */\n KEY_ALIGN_0 = 1 << 14,\n /** Key alignment of 2 bytes. */\n KEY_ALIGN_1 = 1 << 15,\n /** Key alignment of 4 bytes. */\n KEY_ALIGN_2 = 1 << 16,\n /** Key alignment of 8 bytes. */\n KEY_ALIGN_3 = 1 << 17,\n /** Key alignment of 16 bytes. */\n KEY_ALIGN_4 = 1 << 18,\n /** Value is a signed type. */\n KEY_SIGNED = 1 << 19,\n /** Value is a float type. */\n KEY_FLOAT = 1 << 20,\n /** Key type is nullable. */\n KEY_NULLABLE = 1 << 21,\n /** Key type is managed. */\n KEY_MANAGED = 1 << 22\n}\n","/**\n * Low-level C-like compiler API.\n * @module index\n *//***/\n\nimport { Target, Feature } from \"./common\";\nimport { Compiler, Options } from \"./compiler\";\nimport { Decompiler } from \"./decompiler\";\nimport { IDLBuilder, TSDBuilder } from \"./definitions\";\nimport { DiagnosticMessage, DiagnosticCategory, formatDiagnosticMessage } from \"./diagnostics\";\nimport { Module } from \"./module\";\nimport { Parser } from \"./parser\";\nimport { Program } from \"./program\";\n\n/** Parses a source file. If `parser` has been omitted a new one is created. */\nexport function parseFile(text: string, path: string, isEntry: bool = false,\n parser: Parser | null = null\n): Parser {\n if (!parser) parser = new Parser();\n parser.parseFile(text, path, isEntry);\n return parser;\n}\n\n/** Obtains the next required file's path. Returns `null` once complete. */\nexport function nextFile(parser: Parser): string | null {\n return parser.nextFile();\n}\n\n/** Obtains the next diagnostic message. Returns `null` once complete. */\nexport function nextDiagnostic(parser: Parser): DiagnosticMessage | null {\n var program = parser.program;\n return program.diagnosticsOffset < program.diagnostics.length\n ? program.diagnostics[program.diagnosticsOffset++]\n : null;\n}\n\n/** Formats a diagnostic message to a string. */\nexport { formatDiagnosticMessage as formatDiagnostic };\n\n/** Tests whether a diagnostic is informatory. */\nexport function isInfo(message: DiagnosticMessage): bool {\n return message.category == DiagnosticCategory.INFO;\n}\n\n/** Tests whether a diagnostic is a warning. */\nexport function isWarning(message: DiagnosticMessage): bool {\n return message.category == DiagnosticCategory.WARNING;\n}\n\n/** Tests whether a diagnostic is an error. */\nexport function isError(message: DiagnosticMessage): bool {\n return message.category == DiagnosticCategory.ERROR;\n}\n\n/** Creates a new set of compiler options. */\nexport function createOptions(): Options {\n return new Options();\n}\n\n/** Sets the `target` option. */\nexport function setTarget(options: Options, target: Target): void {\n options.target = target;\n}\n\n/** Sets the `noAssert` option. */\nexport function setNoAssert(options: Options, noAssert: bool): void {\n options.noAssert = noAssert;\n}\n\n/** Sets the `importMemory` option. */\nexport function setImportMemory(options: Options, importMemory: bool): void {\n options.importMemory = importMemory;\n}\n\n/** Sets the `sharedMemory` option. */\nexport function setSharedMemory(options: Options, sharedMemory: i32): void {\n options.sharedMemory = sharedMemory;\n}\n\n/** Sets the `importTable` option. */\nexport function setImportTable(options: Options, importTable: bool): void {\n options.importTable = importTable;\n}\n\n/** Sets the `sourceMap` option. */\nexport function setSourceMap(options: Options, sourceMap: bool): void {\n options.sourceMap = sourceMap;\n}\n\n/** Sets the `memoryBase` option. */\nexport function setMemoryBase(options: Options, memoryBase: u32): void {\n options.memoryBase = memoryBase;\n}\n\n/** Sets a 'globalAliases' value. */\nexport function setGlobalAlias(options: Options, alias: string, name: string): void {\n var globalAliases = options.globalAliases;\n if (!globalAliases) options.globalAliases = globalAliases = new Map();\n globalAliases.set(alias, name);\n}\n\n/** Sets the `explicitStart` option. */\nexport function setExplicitStart(options: Options, explicitStart: bool): void {\n options.explicitStart = explicitStart;\n}\n\n/** Sign extension operations. */\nexport const FEATURE_SIGN_EXTENSION = Feature.SIGN_EXTENSION;\n/** Mutable global imports and exports. */\nexport const FEATURE_MUTABLE_GLOBAL = Feature.MUTABLE_GLOBAL;\n/** Bulk memory operations. */\nexport const FEATURE_BULK_MEMORY = Feature.BULK_MEMORY;\n/** SIMD types and operations. */\nexport const FEATURE_SIMD = Feature.SIMD;\n/** Threading and atomic operations. */\nexport const FEATURE_THREADS = Feature.THREADS;\n\n/** Enables a specific feature. */\nexport function enableFeature(options: Options, feature: Feature): void {\n options.features |= feature;\n}\n\n/** Gives the compiler a hint at the optimize levels that will be used later on. */\nexport function setOptimizeLevelHints(options: Options, optimizeLevel: i32, shrinkLevel: i32): void {\n options.optimizeLevelHint = optimizeLevel;\n options.shrinkLevelHint = shrinkLevel;\n}\n\n/** Finishes parsing. */\nexport function finishParsing(parser: Parser): Program {\n return parser.finish();\n}\n\n/** Compiles the sources computed by the parser to a module. */\nexport function compileProgram(program: Program, options: Options | null = null): Module {\n return new Compiler(program, options).compile();\n}\n\n/** Decompiles a module to its (low level) source. */\nexport function decompileModule(module: Module): string {\n var decompiler = new Decompiler();\n decompiler.decompile(module);\n return decompiler.finish();\n}\n\n/** Builds WebIDL definitions for the specified program. */\nexport function buildIDL(program: Program): string {\n return IDLBuilder.build(program);\n}\n\n/** Builds TypeScript definitions for the specified program. */\nexport function buildTSD(program: Program): string {\n return TSDBuilder.build(program);\n}\n\n/** Builds a JSON file of a program's runtime type information. */\nexport function buildRTTI(program: Program): string {\n var sb = new Array();\n sb.push(\"{\\n \\\"names\\\": [\\n\");\n for (let cls of program.managedClasses.values()) {\n sb.push(\" \\\"\");\n sb.push(cls.internalName);\n sb.push(\"\\\",\\n\");\n }\n sb.push(\" ],\\n \\\"base\\\": [\\n\");\n for (let cls of program.managedClasses.values()) {\n let base = cls.base;\n sb.push(\" \");\n sb.push(base ? base.id.toString() : \"0\");\n sb.push(\",\\n\");\n }\n sb.push(\" ],\\n \\\"flags\\\": [\\n\");\n for (let cls of program.managedClasses.values()) {\n sb.push(\" \");\n sb.push(cls.rttiFlags.toString());\n sb.push(\",\\n\");\n }\n sb.push(\" ]\\n}\\n\");\n return sb.join(\"\");\n}\n\n/** Prefix indicating a library file. */\nexport { LIBRARY_PREFIX } from \"./common\";\n\n// Full API\nexport * from \"./ast\";\n// export * from \"./binary\";\nexport * from \"./common\";\nexport * from \"./compiler\";\nexport * from \"./decompiler\";\nexport * from \"./definitions\";\nexport * from \"./diagnosticMessages.generated\";\nexport * from \"./diagnostics\";\nexport * from \"./flow\";\nexport * from \"./module\";\nexport * from \"./parser\";\nexport * from \"./program\";\nexport * from \"./resolver\";\nexport * from \"./tokenizer\";\nexport * from \"./types\";\nexport * from \"./util\";\n","/** @module util *//***/\n\n/** Tests if the bit at the specified index is set within a 64-bit map. */\nexport function bitsetIs(map: I64, index: i32): bool {\n assert(index >= 0 && index < 64);\n return i64_ne(\n i64_and(\n map,\n i64_shl(\n i64_one,\n i64_new(index)\n )\n ),\n i64_zero\n );\n}\n\n/** Sets or unsets the bit at the specified index within a 64-bit map and returns the new map. */\nexport function bitsetSet(map: I64, index: i32, isSet: bool): I64 {\n assert(index >= 0 && index < 64);\n return isSet\n ? i64_or(\n map,\n i64_shl(\n i64_one,\n i64_new(index)\n )\n )\n : i64_and(\n map,\n i64_not(\n i64_shl(\n i64_one,\n i64_new(index)\n )\n )\n );\n}\n","/** @module util *//***/\n\n/** An enum of named character codes. */\nexport const enum CharCode {\n\n NULL = 0,\n LINEFEED = 0x0A,\n CARRIAGERETURN = 0x0D,\n LINESEPARATOR = 0x2028,\n PARAGRAPHSEPARATOR = 0x2029,\n NEXTLINE = 0x0085,\n\n SPACE = 0x20,\n NONBREAKINGSPACE = 0xA0,\n ENQUAD = 0x2000,\n EMQUAD = 0x2001,\n ENSPACE = 0x2002,\n EMSPACE = 0x2003,\n THREEPEREMSPACE = 0x2004,\n FOURPEREMSPACE = 0x2005,\n SIXPEREMSPACE = 0x2006,\n FIGURESPACE = 0x2007,\n PUNCTUATIONSPACE = 0x2008,\n THINSPACE = 0x2009,\n HAIRSPACE = 0x200A,\n ZEROWIDTHSPACE = 0x200B,\n NARROWNOBREAKSPACE = 0x202F,\n IDEOGRAPHICSPACE = 0x3000,\n MATHEMATICALSPACE = 0x205F,\n OGHAM = 0x1680,\n\n _ = 0x5F,\n\n _0 = 0x30,\n _1 = 0x31,\n _2 = 0x32,\n _3 = 0x33,\n _4 = 0x34,\n _5 = 0x35,\n _6 = 0x36,\n _7 = 0x37,\n _8 = 0x38,\n _9 = 0x39,\n\n a = 0x61,\n b = 0x62,\n c = 0x63,\n d = 0x64,\n e = 0x65,\n f = 0x66,\n g = 0x67,\n h = 0x68,\n i = 0x69,\n j = 0x6A,\n k = 0x6B,\n l = 0x6C,\n m = 0x6D,\n n = 0x6E,\n o = 0x6F,\n p = 0x70,\n q = 0x71,\n r = 0x72,\n s = 0x73,\n t = 0x74,\n u = 0x75,\n v = 0x76,\n w = 0x77,\n x = 0x78,\n y = 0x79,\n z = 0x7A,\n\n A = 0x41,\n B = 0x42,\n C = 0x43,\n D = 0x44,\n E = 0x45,\n F = 0x46,\n G = 0x47,\n H = 0x48,\n I = 0x49,\n J = 0x4A,\n K = 0x4B,\n L = 0x4C,\n M = 0x4D,\n N = 0x4E,\n O = 0x4F,\n P = 0x50,\n Q = 0x51,\n R = 0x52,\n S = 0x53,\n T = 0x54,\n U = 0x55,\n V = 0x56,\n W = 0x57,\n X = 0x58,\n Y = 0x59,\n Z = 0x5a,\n\n AMPERSAND = 0x26,\n ASTERISK = 0x2A,\n AT = 0x40,\n BACKSLASH = 0x5C,\n BACKTICK = 0x60,\n BAR = 0x7C,\n CARET = 0x5E,\n CLOSEBRACE = 0x7D,\n CLOSEBRACKET = 0x5D,\n CLOSEPAREN = 0x29,\n COLON = 0x3A,\n COMMA = 0x2C,\n DOLLAR = 0x24,\n DOT = 0x2E,\n DOUBLEQUOTE = 0x22,\n EQUALS = 0x3D,\n EXCLAMATION = 0x21,\n GREATERTHAN = 0x3E,\n HASH = 0x23,\n LESSTHAN = 0x3C,\n MINUS = 0x2D,\n OPENBRACE = 0x7B,\n OPENBRACKET = 0x5B,\n OPENPAREN = 0x28,\n PERCENT = 0x25,\n PLUS = 0x2B,\n QUESTION = 0x3F,\n SEMICOLON = 0x3B,\n SINGLEQUOTE = 0x27,\n SLASH = 0x2F,\n TILDE = 0x7E,\n\n BACKSPACE = 0x08,\n FORMFEED = 0x0C,\n BYTEORDERMARK = 0xFEFF,\n TAB = 0x09,\n VERTICALTAB = 0x0B\n}\n\n/** Tests if the specified character code is some sort of line break. */\nexport function isLineBreak(c: CharCode): bool {\n switch (c) {\n case CharCode.LINEFEED:\n case CharCode.CARRIAGERETURN:\n case CharCode.LINESEPARATOR:\n case CharCode.PARAGRAPHSEPARATOR: {\n return true;\n }\n default: {\n return false;\n }\n }\n}\n\n/** Tests if the specified character code is some sort of white space. */\nexport function isWhiteSpace(c: i32): bool {\n switch (c) {\n case CharCode.SPACE:\n case CharCode.TAB:\n case CharCode.VERTICALTAB:\n case CharCode.FORMFEED:\n case CharCode.NONBREAKINGSPACE:\n case CharCode.NEXTLINE:\n case CharCode.OGHAM:\n case CharCode.NARROWNOBREAKSPACE:\n case CharCode.MATHEMATICALSPACE:\n case CharCode.IDEOGRAPHICSPACE:\n case CharCode.BYTEORDERMARK: {\n return true;\n }\n default: {\n return c >= CharCode.ENQUAD && c <= CharCode.ZEROWIDTHSPACE;\n }\n }\n}\n\n/** Tests if the specified character code is a valid decimal digit. */\nexport function isDecimalDigit(c: i32): bool {\n return c >= CharCode._0 && c <= CharCode._9;\n}\n\n/** Tests if the specified character code is a valid octal digit. */\nexport function isOctalDigit(c: i32): bool {\n return c >= CharCode._0 && c <= CharCode._7;\n}\n\n/** Tests if the specified character code is a valid start of an identifier. */\nexport function isIdentifierStart(c: i32): bool {\n return c >= CharCode.a && c <= CharCode.z\n || c >= CharCode.A && c <= CharCode.Z\n || c == CharCode._\n || c == CharCode.DOLLAR\n || c > 0x7f && isUnicodeIdentifierStart(c);\n}\n\n/** Tests if the specified character code is a valid keyword character. */\nexport function isKeywordCharacter(c: i32): bool {\n return c >= CharCode.a && c <= CharCode.z;\n}\n\n/** Tests if the specified character code is a valid part of an identifier. */\nexport function isIdentifierPart(c: i32): bool {\n return c >= CharCode.a && c <= CharCode.z\n || c >= CharCode.A && c <= CharCode.Z\n || c >= CharCode._0 && c <= CharCode._9\n || c == CharCode._\n || c == CharCode.DOLLAR\n || c > 0x7f && isUnicodeIdentifierPart(c);\n}\n\n// storing as u16 to save memory\nconst unicodeIdentifierStart: u16[] = [\n 170, 170, 181, 181, 186, 186, 192, 214, 216, 246, 248, 705, 710, 721, 736,\n 740, 748, 748, 750, 750, 880, 884, 886, 887, 890, 893, 902, 902, 904, 906,\n 908, 908, 910, 929, 931,\n 1013, 1015, 1153, 1162, 1319, 1329, 1366, 1369, 1369, 1377, 1415, 1488, 1514,\n 1520, 1522, 1568, 1610, 1646, 1647, 1649, 1747, 1749, 1749, 1765, 1766, 1774,\n 1775, 1786, 1788, 1791, 1791, 1808, 1808, 1810, 1839, 1869, 1957, 1969, 1969,\n 1994, 2026, 2036, 2037, 2042, 2042, 2048, 2069, 2074, 2074, 2084, 2084, 2088,\n 2088, 2112, 2136, 2208, 2208, 2210, 2220, 2308, 2361, 2365, 2365, 2384, 2384,\n 2392, 2401, 2417, 2423, 2425, 2431, 2437, 2444, 2447, 2448, 2451, 2472, 2474,\n 2480, 2482, 2482, 2486, 2489, 2493, 2493, 2510, 2510, 2524, 2525, 2527, 2529,\n 2544, 2545, 2565, 2570, 2575, 2576, 2579, 2600, 2602, 2608, 2610, 2611, 2613,\n 2614, 2616, 2617, 2649, 2652, 2654, 2654, 2674, 2676, 2693, 2701, 2703, 2705,\n 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2749, 2749, 2768, 2768, 2784,\n 2785, 2821, 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2869, 2873,\n 2877, 2877, 2908, 2909, 2911, 2913, 2929, 2929, 2947, 2947, 2949, 2954, 2958,\n 2960, 2962, 2965, 2969, 2970, 2972, 2972, 2974, 2975, 2979, 2980, 2984, 2986,\n 2990, 3001, 3024, 3024, 3077, 3084, 3086, 3088, 3090, 3112, 3114, 3123, 3125,\n 3129, 3133, 3133, 3160, 3161, 3168, 3169, 3205, 3212, 3214, 3216, 3218, 3240,\n 3242, 3251, 3253, 3257, 3261, 3261, 3294, 3294, 3296, 3297, 3313, 3314, 3333,\n 3340, 3342, 3344, 3346, 3386, 3389, 3389, 3406, 3406, 3424, 3425, 3450, 3455,\n 3461, 3478, 3482, 3505, 3507, 3515, 3517, 3517, 3520, 3526, 3585, 3632, 3634,\n 3635, 3648, 3654, 3713, 3714, 3716, 3716, 3719, 3720, 3722, 3722, 3725, 3725,\n 3732, 3735, 3737, 3743, 3745, 3747, 3749, 3749, 3751, 3751, 3754, 3755, 3757,\n 3760, 3762, 3763, 3773, 3773, 3776, 3780, 3782, 3782, 3804, 3807, 3840, 3840,\n 3904, 3911, 3913, 3948, 3976, 3980, 4096, 4138, 4159, 4159, 4176, 4181, 4186,\n 4189, 4193, 4193, 4197, 4198, 4206, 4208, 4213, 4225, 4238, 4238, 4256, 4293,\n 4295, 4295, 4301, 4301, 4304, 4346, 4348, 4680, 4682, 4685, 4688, 4694, 4696,\n 4696, 4698, 4701, 4704, 4744, 4746, 4749, 4752, 4784, 4786, 4789, 4792, 4798,\n 4800, 4800, 4802, 4805, 4808, 4822, 4824, 4880, 4882, 4885, 4888, 4954, 4992,\n 5007, 5024, 5108, 5121, 5740, 5743, 5759, 5761, 5786, 5792, 5866, 5870, 5872,\n 5888, 5900, 5902, 5905, 5920, 5937, 5952, 5969, 5984, 5996, 5998, 6000, 6016,\n 6067, 6103, 6103, 6108, 6108, 6176, 6263, 6272, 6312, 6314, 6314, 6320, 6389,\n 6400, 6428, 6480, 6509, 6512, 6516, 6528, 6571, 6593, 6599, 6656, 6678, 6688,\n 6740, 6823, 6823, 6917, 6963, 6981, 6987, 7043, 7072, 7086, 7087, 7098, 7141,\n 7168, 7203, 7245, 7247, 7258, 7293, 7401, 7404, 7406, 7409, 7413, 7414, 7424,\n 7615, 7680, 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025,\n 8027, 8027, 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130,\n 8132, 8134, 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188,\n 8305, 8305, 8319, 8319, 8336, 8348, 8450, 8450, 8455, 8455, 8458, 8467, 8469,\n 8469, 8473, 8477, 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8493, 8495, 8505,\n 8508, 8511, 8517, 8521, 8526, 8526, 8544, 8584,\n 11264, 11310, 11312, 11358, 11360, 11492, 11499, 11502, 11506, 11507, 11520,\n 11557, 11559, 11559, 11565, 11565, 11568, 11623, 11631, 11631, 11648, 11670,\n 11680, 11686, 11688, 11694, 11696, 11702, 11704, 11710, 11712, 11718, 11720,\n 11726, 11728, 11734, 11736, 11742, 11823, 11823, 12293, 12295, 12321, 12329,\n 12337, 12341, 12344, 12348, 12353, 12438, 12445, 12447, 12449, 12538, 12540,\n 12543, 12549, 12589, 12593, 12686, 12704, 12730, 12784, 12799, 13312, 19893,\n 19968, 40908, 40960, 42124, 42192, 42237, 42240, 42508, 42512, 42527, 42538,\n 42539, 42560, 42606, 42623, 42647, 42656, 42735, 42775, 42783, 42786, 42888,\n 42891, 42894, 42896, 42899, 42912, 42922, 43000, 43009, 43011, 43013, 43015,\n 43018, 43020, 43042, 43072, 43123, 43138, 43187, 43250, 43255, 43259, 43259,\n 43274, 43301, 43312, 43334, 43360, 43388, 43396, 43442, 43471, 43471, 43520,\n 43560, 43584, 43586, 43588, 43595, 43616, 43638, 43642, 43642, 43648, 43695,\n 43697, 43697, 43701, 43702, 43705, 43709, 43712, 43712, 43714, 43714, 43739,\n 43741, 43744, 43754, 43762, 43764, 43777, 43782, 43785, 43790, 43793, 43798,\n 43808, 43814, 43816, 43822, 43968, 44002, 44032, 55203, 55216, 55238, 55243,\n 55291, 63744, 64109, 64112, 64217, 64256, 64262, 64275, 64279, 64285, 64285,\n 64287, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321, 64323,\n 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008, 65019,\n 65136, 65140, 65142, 65276, 65313, 65338, 65345, 65370, 65382, 65470, 65474,\n 65479, 65482, 65487, 65490, 65495, 65498, 65500,\n];\nconst unicodeIdentifierPart: u16[] = [\n 170, 170, 181, 181, 186, 186, 192, 214, 216, 246, 248, 705, 710, 721, 736,\n 740, 748, 748, 750, 750, 768, 884, 886, 887, 890, 893, 902, 902, 904, 906,\n 908, 908, 910, 929, 931,\n 1013, 1015, 1153, 1155, 1159, 1162, 1319, 1329, 1366, 1369, 1369, 1377, 1415,\n 1425, 1469, 1471, 1471, 1473, 1474, 1476, 1477, 1479, 1479, 1488, 1514, 1520,\n 1522, 1552, 1562, 1568, 1641, 1646, 1747, 1749, 1756, 1759, 1768, 1770, 1788,\n 1791, 1791, 1808, 1866, 1869, 1969, 1984, 2037, 2042, 2042, 2048, 2093, 2112,\n 2139, 2208, 2208, 2210, 2220, 2276, 2302, 2304, 2403, 2406, 2415, 2417, 2423,\n 2425, 2431, 2433, 2435, 2437, 2444, 2447, 2448, 2451, 2472, 2474, 2480, 2482,\n 2482, 2486, 2489, 2492, 2500, 2503, 2504, 2507, 2510, 2519, 2519, 2524, 2525,\n 2527, 2531, 2534, 2545, 2561, 2563, 2565, 2570, 2575, 2576, 2579, 2600, 2602,\n 2608, 2610, 2611, 2613, 2614, 2616, 2617, 2620, 2620, 2622, 2626, 2631, 2632,\n 2635, 2637, 2641, 2641, 2649, 2652, 2654, 2654, 2662, 2677, 2689, 2691, 2693,\n 2701, 2703, 2705, 2707, 2728, 2730, 2736, 2738, 2739, 2741, 2745, 2748, 2757,\n 2759, 2761, 2763, 2765, 2768, 2768, 2784, 2787, 2790, 2799, 2817, 2819, 2821,\n 2828, 2831, 2832, 2835, 2856, 2858, 2864, 2866, 2867, 2869, 2873, 2876, 2884,\n 2887, 2888, 2891, 2893, 2902, 2903, 2908, 2909, 2911, 2915, 2918, 2927, 2929,\n 2929, 2946, 2947, 2949, 2954, 2958, 2960, 2962, 2965, 2969, 2970, 2972, 2972,\n 2974, 2975, 2979, 2980, 2984, 2986, 2990, 3001, 3006, 3010, 3014, 3016, 3018,\n 3021, 3024, 3024, 3031, 3031, 3046, 3055, 3073, 3075, 3077, 3084, 3086, 3088,\n 3090, 3112, 3114, 3123, 3125, 3129, 3133, 3140, 3142, 3144, 3146, 3149, 3157,\n 3158, 3160, 3161, 3168, 3171, 3174, 3183, 3202, 3203, 3205, 3212, 3214, 3216,\n 3218, 3240, 3242, 3251, 3253, 3257, 3260, 3268, 3270, 3272, 3274, 3277, 3285,\n 3286, 3294, 3294, 3296, 3299, 3302, 3311, 3313, 3314, 3330, 3331, 3333, 3340,\n 3342, 3344, 3346, 3386, 3389, 3396, 3398, 3400, 3402, 3406, 3415, 3415, 3424,\n 3427, 3430, 3439, 3450, 3455, 3458, 3459, 3461, 3478, 3482, 3505, 3507, 3515,\n 3517, 3517, 3520, 3526, 3530, 3530, 3535, 3540, 3542, 3542, 3544, 3551, 3570,\n 3571, 3585, 3642, 3648, 3662, 3664, 3673, 3713, 3714, 3716, 3716, 3719, 3720,\n 3722, 3722, 3725, 3725, 3732, 3735, 3737, 3743, 3745, 3747, 3749, 3749, 3751,\n 3751, 3754, 3755, 3757, 3769, 3771, 3773, 3776, 3780, 3782, 3782, 3784, 3789,\n 3792, 3801, 3804, 3807, 3840, 3840, 3864, 3865, 3872, 3881, 3893, 3893, 3895,\n 3895, 3897, 3897, 3902, 3911, 3913, 3948, 3953, 3972, 3974, 3991, 3993, 4028,\n 4038, 4038, 4096, 4169, 4176, 4253, 4256, 4293, 4295, 4295, 4301, 4301, 4304,\n 4346, 4348, 4680, 4682, 4685, 4688, 4694, 4696, 4696, 4698, 4701, 4704, 4744,\n 4746, 4749, 4752, 4784, 4786, 4789, 4792, 4798, 4800, 4800, 4802, 4805, 4808,\n 4822, 4824, 4880, 4882, 4885, 4888, 4954, 4957, 4959, 4992, 5007, 5024, 5108,\n 5121, 5740, 5743, 5759, 5761, 5786, 5792, 5866, 5870, 5872, 5888, 5900, 5902,\n 5908, 5920, 5940, 5952, 5971, 5984, 5996, 5998, 6000, 6002, 6003, 6016, 6099,\n 6103, 6103, 6108, 6109, 6112, 6121, 6155, 6157, 6160, 6169, 6176, 6263, 6272,\n 6314, 6320, 6389, 6400, 6428, 6432, 6443, 6448, 6459, 6470, 6509, 6512, 6516,\n 6528, 6571, 6576, 6601, 6608, 6617, 6656, 6683, 6688, 6750, 6752, 6780, 6783,\n 6793, 6800, 6809, 6823, 6823, 6912, 6987, 6992, 7001, 7019, 7027, 7040, 7155,\n 7168, 7223, 7232, 7241, 7245, 7293, 7376, 7378, 7380, 7414, 7424, 7654, 7676,\n 7957, 7960, 7965, 7968, 8005, 8008, 8013, 8016, 8023, 8025, 8025, 8027, 8027,\n 8029, 8029, 8031, 8061, 8064, 8116, 8118, 8124, 8126, 8126, 8130, 8132, 8134,\n 8140, 8144, 8147, 8150, 8155, 8160, 8172, 8178, 8180, 8182, 8188, 8204, 8205,\n 8255, 8256, 8276, 8276, 8305, 8305, 8319, 8319, 8336, 8348, 8400, 8412, 8417,\n 8417, 8421, 8432, 8450, 8450, 8455, 8455, 8458, 8467, 8469, 8469, 8473, 8477,\n 8484, 8484, 8486, 8486, 8488, 8488, 8490, 8493, 8495, 8505, 8508, 8511, 8517,\n 8521, 8526, 8526, 8544, 8584,\n 11264, 11310, 11312, 11358, 11360, 11492, 11499, 11507, 11520, 11557, 11559,\n 11559, 11565, 11565, 11568, 11623, 11631, 11631, 11647, 11670, 11680, 11686,\n 11688, 11694, 11696, 11702, 11704, 11710, 11712, 11718, 11720, 11726, 11728,\n 11734, 11736, 11742, 11744, 11775, 11823, 11823, 12293, 12295, 12321, 12335,\n 12337, 12341, 12344, 12348, 12353, 12438, 12441, 12442, 12445, 12447, 12449,\n 12538, 12540, 12543, 12549, 12589, 12593, 12686, 12704, 12730, 12784, 12799,\n 13312, 19893, 19968, 40908, 40960, 42124, 42192, 42237, 42240, 42508, 42512,\n 42539, 42560, 42607, 42612, 42621, 42623, 42647, 42655, 42737, 42775, 42783,\n 42786, 42888, 42891, 42894, 42896, 42899, 42912, 42922, 43000, 43047, 43072,\n 43123, 43136, 43204, 43216, 43225, 43232, 43255, 43259, 43259, 43264, 43309,\n 43312, 43347, 43360, 43388, 43392, 43456, 43471, 43481, 43520, 43574, 43584,\n 43597, 43600, 43609, 43616, 43638, 43642, 43643, 43648, 43714, 43739, 43741,\n 43744, 43759, 43762, 43766, 43777, 43782, 43785, 43790, 43793, 43798, 43808,\n 43814, 43816, 43822, 43968, 44010, 44012, 44013, 44016, 44025, 44032, 55203,\n 55216, 55238, 55243, 55291, 63744, 64109, 64112, 64217, 64256, 64262, 64275,\n 64279, 64285, 64296, 64298, 64310, 64312, 64316, 64318, 64318, 64320, 64321,\n 64323, 64324, 64326, 64433, 64467, 64829, 64848, 64911, 64914, 64967, 65008,\n 65019, 65024, 65039, 65056, 65062, 65075, 65076, 65101, 65103, 65136, 65140,\n 65142, 65276, 65296, 65305, 65313, 65338, 65343, 65343, 65345, 65370, 65382,\n 65470, 65474, 65479, 65482, 65487, 65490, 65495, 65498, 65500,\n];\n\nfunction lookupInUnicodeMap(code: u16, map: u16[]): bool {\n if (code < map[0]) return false;\n\n var lo = 0;\n var hi = map.length;\n var mid: i32;\n var midVal: u16;\n\n while (lo + 1 < hi) {\n mid = lo + ((hi - lo) >> 1);\n mid -= (mid & 1);\n midVal = map[mid];\n if (midVal <= code && code <= map[mid + 1]) {\n return true;\n }\n if (code < midVal) {\n hi = mid;\n } else {\n lo = mid + 2;\n }\n }\n return false;\n}\n\nfunction isUnicodeIdentifierStart(code: i32): bool {\n return code < 0 || code > 0xffff ? false\n : lookupInUnicodeMap(code as u16, unicodeIdentifierStart);\n}\n\nfunction isUnicodeIdentifierPart(code: i32): bool {\n return code < 0 || code > 0xffff ? false\n : lookupInUnicodeMap(code as u16, unicodeIdentifierPart);\n}\n","export function makeArray(original: Array | null = null): Array {\n if (original) {\n let cloned = new Array(original.length);\n for (let i = 0, k = original.length; i < k; ++i) unchecked(cloned[i] = original[i]);\n return cloned;\n }\n return new Array();\n}\n\nexport function makeSet(original: Set | null = null): Set {\n if (original) {\n let cloned = new Set();\n for (let v of original) cloned.add(v);\n return cloned;\n }\n return new Set();\n}\n\nexport function makeMap(original: Map | null = null, overrides: Map | null = null): Map {\n var cloned = new Map();\n if (original) {\n for (let [k, v] of original) cloned.set(k, v);\n if (overrides) for (let [k, v] of overrides) cloned.set(k, v);\n } else if (overrides) {\n for (let [k, v] of overrides) cloned.set(k, v);\n }\n return cloned;\n}\n","/** @module util *//***/\n\nimport {\n CharCode\n} from \"./charcode\";\n\nimport {\n PATH_DELIMITER\n} from \"../common\";\n\nconst separator = CharCode.SLASH;\n\n/**\n * Normalizes the specified path, removing interior placeholders.\n * Expects a posix-compatible relative path (not Windows compatible).\n */\nexport function normalizePath(path: string): string {\n var pos = 0;\n var len = path.length;\n\n // trim leading './'\n while (pos + 1 < len &&\n path.charCodeAt(pos) == CharCode.DOT &&\n path.charCodeAt(pos + 1) == separator\n ) {\n pos += 2;\n }\n\n if (pos > 0 || len < path.length) {\n path = path.substring(pos, len);\n len -= pos;\n pos = 0;\n }\n\n var atEnd: bool;\n while (pos + 1 < len) {\n atEnd = false;\n\n // we are only interested in '/.' sequences ...\n if (\n path.charCodeAt(pos) == separator &&\n path.charCodeAt(pos + 1) == CharCode.DOT\n ) {\n // '/.' ( '/' | $ )\n atEnd = pos + 2 == len;\n if (atEnd ||\n pos + 2 < len &&\n path.charCodeAt(pos + 2) == separator\n ) {\n path = atEnd\n ? path.substring(0, pos)\n : path.substring(0, pos) + path.substring(pos + 2);\n len -= 2;\n continue;\n }\n\n // '/.' ( './' | '.' $ )\n atEnd = pos + 3 == len;\n if (atEnd && path.charCodeAt(pos + 2) == CharCode.DOT ||\n pos + 3 < len &&\n path.charCodeAt(pos + 2) == CharCode.DOT &&\n path.charCodeAt(pos + 3) == separator\n ) {\n // find preceeding '/'\n let ipos = pos;\n while (--ipos >= 0) {\n if (path.charCodeAt(ipos) == separator) {\n if (pos - ipos != 3 ||\n path.charCodeAt(ipos + 1) != CharCode.DOT ||\n path.charCodeAt(ipos + 2) != CharCode.DOT\n ) { // exclude '..' itself\n path = atEnd\n ? path.substring(0, ipos)\n : path.substring(0, ipos) + path.substring(pos + 3);\n len -= pos + 3 - ipos;\n pos = ipos - 1; // incremented again at end of loop\n }\n break;\n }\n }\n\n // if there's no preceeding '/', trim start if non-empty\n if (ipos < 0 && pos > 0) {\n if (pos != 2 ||\n path.charCodeAt(0) != CharCode.DOT ||\n path.charCodeAt(1) != CharCode.DOT\n ) { // exclude '..' itself\n path = path.substring(pos + 4);\n len = path.length;\n continue;\n }\n }\n }\n }\n pos++;\n }\n return len > 0 ? path : \".\";\n}\n\n/** Resolves the specified path relative to the specified origin. */\nexport function resolvePath(normalizedPath: string, origin: string): string {\n if (normalizedPath.startsWith(\"std/\")) {\n return normalizedPath;\n }\n return normalizePath(\n dirname(origin) + PATH_DELIMITER + normalizedPath\n );\n}\n\n/** Obtains the directory portion of a normalized path. */\nexport function dirname(normalizedPath: string): string {\n var pos = normalizedPath.length;\n if (pos <= 1) {\n if (pos == 0) return \".\";\n if (normalizedPath.charCodeAt(0) == separator) {\n return normalizedPath;\n }\n }\n while (--pos > 0) {\n if (normalizedPath.charCodeAt(pos) == separator) {\n return normalizedPath.substring(0, pos);\n }\n }\n return \".\";\n}\n","/** @module util *//***/\n\nconst indentX1 = \" \";\nconst indentX2 = \" \";\nconst indentX4 = \" \";\n\n/** Creates an indentation matching the number of specified levels. */\nexport function indent(sb: string[], level: i32): void {\n while (level >= 4) {\n sb.push(indentX4);\n level -= 4;\n }\n if (level >= 2) {\n sb.push(indentX2);\n level -= 2;\n }\n if (level) {\n sb.push(indentX1);\n }\n}\n","/** @module util *//***/\n\n/** Reads an 8-bit integer from the specified buffer. */\nexport function readI8(buffer: Uint8Array, offset: i32): i32 {\n return buffer[offset];\n}\n\n/** Writes an 8-bit integer to the specified buffer. */\nexport function writeI8(value: i32, buffer: Uint8Array, offset: i32): void {\n buffer[offset] = value;\n}\n\n/** Reads a 16-bit integer from the specified buffer. */\nexport function readI16(buffer: Uint8Array, offset: i32): i32 {\n return buffer[offset ]\n | buffer[offset + 1] << 8;\n}\n\n/** Writes a 16-bit integer to the specified buffer. */\nexport function writeI16(value: i32, buffer: Uint8Array, offset: i32): void {\n buffer[offset ] = value;\n buffer[offset + 1] = value >>> 8;\n}\n\n/** Reads a 32-bit integer from the specified buffer. */\nexport function readI32(buffer: Uint8Array, offset: i32): i32 {\n return buffer[offset ]\n | buffer[offset + 1] << 8\n | buffer[offset + 2] << 16\n | buffer[offset + 3] << 24;\n}\n\n/** Writes a 32-bit integer to the specified buffer. */\nexport function writeI32(value: i32, buffer: Uint8Array, offset: i32): void {\n buffer[offset ] = value;\n buffer[offset + 1] = value >>> 8;\n buffer[offset + 2] = value >>> 16;\n buffer[offset + 3] = value >>> 24;\n}\n\n/** Reads a 64-bit integer from the specified buffer. */\nexport function readI64(buffer: Uint8Array, offset: i32): I64 {\n var lo = readI32(buffer, offset);\n var hi = readI32(buffer, offset + 4);\n return i64_new(lo, hi);\n}\n\n/** Writes a 64-bit integer to the specified buffer. */\nexport function writeI64(value: I64, buffer: Uint8Array, offset: i32): void {\n writeI32(i64_low(value), buffer, offset);\n writeI32(i64_high(value), buffer, offset + 4);\n}\n\n/** Reads a 32-bit float from the specified buffer. */\nexport function readF32(buffer: Uint8Array, offset: i32): f32 {\n return i32_as_f32(readI32(buffer, offset));\n}\n\n/** Writes a 32-bit float to the specified buffer. */\nexport function writeF32(value: f32, buffer: Uint8Array, offset: i32): void {\n writeI32(f32_as_i32(value), buffer, offset);\n}\n\n/** Reads a 64-bit float from the specified buffer. */\nexport function readF64(buffer: Uint8Array, offset: i32): f64 {\n return i64_as_f64(readI64(buffer, offset));\n}\n\n/** Writes a 64-bit float to the specified buffer. */\nexport function writeF64(value: f64, buffer: Uint8Array, offset: i32): void {\n var valueI64 = f64_as_i64(value);\n writeI32(i64_low(valueI64), buffer, offset);\n writeI32(i64_high(valueI64), buffer, offset + 4);\n}\n"],"sourceRoot":""} \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index 9ee87ce393..7a820d4ef7 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1492,8 +1492,7 @@ "ansi-regex": { "version": "2.1.1", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "aproba": { "version": "1.2.0", @@ -1514,14 +1513,12 @@ "balanced-match": { "version": "1.0.0", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "brace-expansion": { "version": "1.1.11", "bundled": true, "dev": true, - "optional": true, "requires": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" @@ -1536,20 +1533,17 @@ "code-point-at": { "version": "1.1.0", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "concat-map": { "version": "0.0.1", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "console-control-strings": { "version": "1.1.0", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "core-util-is": { "version": "1.0.2", @@ -1666,8 +1660,7 @@ "inherits": { "version": "2.0.3", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "ini": { "version": "1.3.5", @@ -1679,7 +1672,6 @@ "version": "1.0.0", "bundled": true, "dev": true, - "optional": true, "requires": { "number-is-nan": "^1.0.0" } @@ -1694,7 +1686,6 @@ "version": "3.0.4", "bundled": true, "dev": true, - "optional": true, "requires": { "brace-expansion": "^1.1.7" } @@ -1702,14 +1693,12 @@ "minimist": { "version": "0.0.8", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "minipass": { "version": "2.3.5", "bundled": true, "dev": true, - "optional": true, "requires": { "safe-buffer": "^5.1.2", "yallist": "^3.0.0" @@ -1728,7 +1717,6 @@ "version": "0.5.1", "bundled": true, "dev": true, - "optional": true, "requires": { "minimist": "0.0.8" } @@ -1809,8 +1797,7 @@ "number-is-nan": { "version": "1.0.1", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "object-assign": { "version": "4.1.1", @@ -1822,7 +1809,6 @@ "version": "1.4.0", "bundled": true, "dev": true, - "optional": true, "requires": { "wrappy": "1" } @@ -1908,8 +1894,7 @@ "safe-buffer": { "version": "5.1.2", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "safer-buffer": { "version": "2.1.2", @@ -1945,7 +1930,6 @@ "version": "1.0.2", "bundled": true, "dev": true, - "optional": true, "requires": { "code-point-at": "^1.0.0", "is-fullwidth-code-point": "^1.0.0", @@ -1965,7 +1949,6 @@ "version": "3.0.1", "bundled": true, "dev": true, - "optional": true, "requires": { "ansi-regex": "^2.0.0" } @@ -2009,14 +1992,12 @@ "wrappy": { "version": "1.0.2", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "yallist": { "version": "3.0.3", "bundled": true, - "dev": true, - "optional": true + "dev": true } } }, diff --git a/src/resolver.ts b/src/resolver.ts index 7a7c97ea12..a7caa94ff8 100644 --- a/src/resolver.ts +++ b/src/resolver.ts @@ -748,14 +748,22 @@ export class Resolver extends DiagnosticEmitter { return null; } let arrayType = indexedGet.signature.returnType; + // } - if (!(target = arrayType.classReference)) { - this.error( - DiagnosticCode.Property_0_does_not_exist_on_type_1, - propertyAccess.property.range, propertyName, arrayType.toString() - ); - return null; + let classReference = arrayType.classReference; + if (!classReference) { + let typeClasses = this.program.typeClasses; + if (!arrayType.is(TypeFlags.REFERENCE) && typeClasses.has(arrayType.kind)) { + classReference = typeClasses.get(arrayType.kind)!; + } else { + this.error( + DiagnosticCode.Property_0_does_not_exist_on_type_1, + propertyAccess.property.range, propertyName, arrayType.toString() + ); + return null; + } } + target = classReference; } break; } @@ -1333,6 +1341,7 @@ export class Resolver extends DiagnosticEmitter { contextualType, reportMode ); + if (!target) return null; if (target.kind == ElementKind.FUNCTION_PROTOTYPE) { // `unchecked(expr: *): *` is special @@ -1365,6 +1374,11 @@ export class Resolver extends DiagnosticEmitter { // reuse resolvedThisExpression (might be property access) // reuse resolvedElementExpression (might be element access) return functionTarget; + } else { + let typeClasses = this.program.typeClasses; + if (!returnType.is(TypeFlags.REFERENCE) && typeClasses.has(returnType.kind)) { + return typeClasses.get(returnType.kind); + } } } if (reportMode == ReportMode.REPORT) { diff --git a/tests/compiler/resolve-access.json b/tests/compiler/resolve-access.json new file mode 100644 index 0000000000..453cb07770 --- /dev/null +++ b/tests/compiler/resolve-access.json @@ -0,0 +1,5 @@ +{ + "asc_flags": [ + "--runtime none" + ] +} diff --git a/tests/compiler/resolve-access.optimized.wat b/tests/compiler/resolve-access.optimized.wat new file mode 100644 index 0000000000..fd20d90cc9 --- /dev/null +++ b/tests/compiler/resolve-access.optimized.wat @@ -0,0 +1,576 @@ +(module + (type $FUNCSIG$i (func (result i32))) + (type $FUNCSIG$iii (func (param i32 i32) (result i32))) + (type $FUNCSIG$ii (func (param i32) (result i32))) + (type $FUNCSIG$viii (func (param i32 i32 i32))) + (type $FUNCSIG$viiii (func (param i32 i32 i32 i32))) + (type $FUNCSIG$ij (func (param i64) (result i32))) + (type $FUNCSIG$viji (func (param i32 i64 i32))) + (type $FUNCSIG$v (func)) + (type $FUNCSIG$vi (func (param i32))) + (type $FUNCSIG$ji (func (param i32) (result i64))) + (import "env" "abort" (func $~lib/builtins/abort (param i32 i32 i32 i32))) + (memory $0 1) + (data (i32.const 8) "\08\00\00\00\01\00\00\00\00\00\00\00\08\00\00\00\01") + (data (i32.const 32) "$\00\00\00\01\00\00\00\01\00\00\00$\00\00\00I\00n\00d\00e\00x\00 \00o\00u\00t\00 \00o\00f\00 \00r\00a\00n\00g\00e") + (data (i32.const 88) "\1a\00\00\00\01\00\00\00\01\00\00\00\1a\00\00\00~\00l\00i\00b\00/\00a\00r\00r\00a\00y\00.\00t\00s") + (data (i32.const 136) "\02\00\00\00\01\00\00\00\01\00\00\00\02\00\00\000") + (global $~lib/rt/stub/startOffset (mut i32) (i32.const 0)) + (global $~lib/rt/stub/offset (mut i32) (i32.const 0)) + (export "memory" (memory $0)) + (export "arrayAccess" (func $resolve-access/arrayAccess)) + (export "fieldAccess" (func $resolve-access/fieldAccess)) + (export "propertyAccess" (func $resolve-access/propertyAccess)) + (start $start) + (func $~lib/rt/stub/__alloc (; 1 ;) (type $FUNCSIG$iii) (param $0 i32) (param $1 i32) (result i32) + (local $2 i32) + (local $3 i32) + (local $4 i32) + (local $5 i32) + local.get $0 + i32.const 1073741808 + i32.gt_u + if + unreachable + end + global.get $~lib/rt/stub/offset + i32.const 16 + i32.add + local.tee $3 + local.get $0 + i32.const 1 + local.get $0 + i32.const 1 + i32.gt_u + select + i32.add + i32.const 15 + i32.add + i32.const -16 + i32.and + local.tee $2 + memory.size + local.tee $4 + i32.const 16 + i32.shl + i32.gt_u + if + local.get $4 + local.get $2 + local.get $3 + i32.sub + i32.const 65535 + i32.add + i32.const -65536 + i32.and + i32.const 16 + i32.shr_u + local.tee $5 + local.get $4 + local.get $5 + i32.gt_s + select + memory.grow + i32.const 0 + i32.lt_s + if + local.get $5 + memory.grow + i32.const 0 + i32.lt_s + if + unreachable + end + end + end + local.get $2 + global.set $~lib/rt/stub/offset + local.get $3 + i32.const 16 + i32.sub + local.tee $2 + local.get $1 + i32.store offset=8 + local.get $2 + local.get $0 + i32.store offset=12 + local.get $3 + ) + (func $~lib/memory/memory.copy (; 2 ;) (type $FUNCSIG$vi) (param $0 i32) + (local $1 i32) + (local $2 i32) + (local $3 i32) + (local $4 i32) + i32.const 24 + local.set $2 + i32.const 8 + local.set $1 + block $~lib/util/memory/memmove|inlined.0 + local.get $0 + i32.const 24 + i32.eq + br_if $~lib/util/memory/memmove|inlined.0 + local.get $0 + i32.const 24 + i32.lt_u + if + local.get $0 + i32.const 7 + i32.and + i32.eqz + if + loop $continue|0 + local.get $0 + i32.const 7 + i32.and + if + local.get $1 + i32.eqz + br_if $~lib/util/memory/memmove|inlined.0 + local.get $1 + i32.const 1 + i32.sub + local.set $1 + local.get $0 + local.tee $3 + i32.const 1 + i32.add + local.set $0 + local.get $2 + local.tee $4 + i32.const 1 + i32.add + local.set $2 + local.get $3 + local.get $4 + i32.load8_u + i32.store8 + br $continue|0 + end + end + loop $continue|1 + local.get $1 + i32.const 8 + i32.ge_u + if + local.get $0 + local.get $2 + i64.load + i64.store + local.get $1 + i32.const 8 + i32.sub + local.set $1 + local.get $0 + i32.const 8 + i32.add + local.set $0 + local.get $2 + i32.const 8 + i32.add + local.set $2 + br $continue|1 + end + end + end + loop $continue|2 + local.get $1 + if + local.get $0 + local.tee $3 + i32.const 1 + i32.add + local.set $0 + local.get $2 + local.tee $4 + i32.const 1 + i32.add + local.set $2 + local.get $3 + local.get $4 + i32.load8_u + i32.store8 + local.get $1 + i32.const 1 + i32.sub + local.set $1 + br $continue|2 + end + end + else + local.get $0 + i32.const 7 + i32.and + i32.eqz + if + loop $continue|3 + local.get $0 + local.get $1 + i32.add + i32.const 7 + i32.and + if + local.get $1 + i32.eqz + br_if $~lib/util/memory/memmove|inlined.0 + local.get $1 + i32.const 1 + i32.sub + local.tee $1 + local.get $0 + i32.add + local.get $1 + i32.const 24 + i32.add + i32.load8_u + i32.store8 + br $continue|3 + end + end + loop $continue|4 + local.get $1 + i32.const 8 + i32.ge_u + if + local.get $1 + i32.const 8 + i32.sub + local.tee $1 + local.get $0 + i32.add + local.get $1 + i32.const 24 + i32.add + i64.load + i64.store + br $continue|4 + end + end + end + loop $continue|5 + local.get $1 + if + local.get $1 + i32.const 1 + i32.sub + local.tee $1 + local.get $0 + i32.add + local.get $1 + i32.const 24 + i32.add + i32.load8_u + i32.store8 + br $continue|5 + end + end + end + end + ) + (func $~lib/rt/__allocArray (; 3 ;) (type $FUNCSIG$i) (result i32) + (local $0 i32) + (local $1 i32) + i32.const 16 + i32.const 3 + call $~lib/rt/stub/__alloc + local.tee $0 + i32.const 8 + i32.const 0 + call $~lib/rt/stub/__alloc + local.tee $1 + i32.store + local.get $0 + local.get $1 + i32.store offset=4 + local.get $0 + i32.const 8 + i32.store offset=8 + local.get $0 + i32.const 1 + i32.store offset=12 + local.get $1 + call $~lib/memory/memory.copy + local.get $0 + ) + (func $~lib/array/Array#__get (; 4 ;) (type $FUNCSIG$ji) (param $0 i32) (result i64) + i32.const 0 + local.get $0 + i32.load offset=8 + i32.const 3 + i32.shr_u + i32.ge_u + if + i32.const 48 + i32.const 104 + i32.const 109 + i32.const 61 + call $~lib/builtins/abort + unreachable + end + local.get $0 + i32.load offset=4 + i64.load + ) + (func $~lib/util/number/decimalCount32 (; 5 ;) (type $FUNCSIG$ii) (param $0 i32) (result i32) + i32.const 1 + i32.const 2 + local.get $0 + i32.const 10 + i32.lt_u + select + i32.const 3 + i32.const 4 + i32.const 5 + local.get $0 + i32.const 10000 + i32.lt_u + select + local.get $0 + i32.const 1000 + i32.lt_u + select + local.get $0 + i32.const 100 + i32.lt_u + select + i32.const 6 + i32.const 7 + local.get $0 + i32.const 1000000 + i32.lt_u + select + i32.const 8 + i32.const 9 + i32.const 10 + local.get $0 + i32.const 1000000000 + i32.lt_u + select + local.get $0 + i32.const 100000000 + i32.lt_u + select + local.get $0 + i32.const 10000000 + i32.lt_u + select + local.get $0 + i32.const 100000 + i32.lt_u + select + ) + (func $~lib/util/number/utoa_simple (; 6 ;) (type $FUNCSIG$viii) (param $0 i32) (param $1 i32) (param $2 i32) + (local $3 i32) + loop $continue|0 + local.get $1 + i32.const 10 + i32.rem_u + local.set $3 + local.get $1 + i32.const 10 + i32.div_u + local.set $1 + local.get $2 + i32.const 1 + i32.sub + local.tee $2 + i32.const 1 + i32.shl + local.get $0 + i32.add + local.get $3 + i32.const 48 + i32.add + i32.store16 + local.get $1 + br_if $continue|0 + end + ) + (func $~lib/util/number/decimalCount64 (; 7 ;) (type $FUNCSIG$ij) (param $0 i64) (result i32) + i32.const 11 + i32.const 12 + local.get $0 + i64.const 100000000000 + i64.lt_u + select + i32.const 13 + i32.const 14 + i32.const 15 + local.get $0 + i64.const 100000000000000 + i64.lt_u + select + local.get $0 + i64.const 10000000000000 + i64.lt_u + select + local.get $0 + i64.const 1000000000000 + i64.lt_u + select + i32.const 16 + i32.const 17 + local.get $0 + i64.const 10000000000000000 + i64.lt_u + select + i32.const 18 + i32.const 19 + i32.const 20 + local.get $0 + i64.const -8446744073709551616 + i64.lt_u + select + local.get $0 + i64.const 1000000000000000000 + i64.lt_u + select + local.get $0 + i64.const 100000000000000000 + i64.lt_u + select + local.get $0 + i64.const 1000000000000000 + i64.lt_u + select + ) + (func $~lib/util/number/utoa_simple (; 8 ;) (type $FUNCSIG$viji) (param $0 i32) (param $1 i64) (param $2 i32) + (local $3 i32) + loop $continue|0 + local.get $1 + i64.const 10 + i64.rem_u + i32.wrap_i64 + local.set $3 + local.get $1 + i64.const 10 + i64.div_u + local.set $1 + local.get $2 + i32.const 1 + i32.sub + local.tee $2 + i32.const 1 + i32.shl + local.get $0 + i32.add + local.get $3 + i32.const 48 + i32.add + i32.store16 + local.get $1 + i64.const 0 + i64.ne + br_if $continue|0 + end + ) + (func $~lib/util/number/utoa64 (; 9 ;) (type $FUNCSIG$ij) (param $0 i64) (result i32) + (local $1 i32) + (local $2 i32) + (local $3 i32) + local.get $0 + i64.eqz + if + i32.const 152 + return + end + local.get $0 + i64.const 4294967295 + i64.le_u + if + local.get $0 + i32.wrap_i64 + local.tee $1 + call $~lib/util/number/decimalCount32 + local.tee $3 + i32.const 1 + i32.shl + i32.const 1 + call $~lib/rt/stub/__alloc + local.tee $2 + local.get $1 + local.get $3 + call $~lib/util/number/utoa_simple + else + local.get $0 + call $~lib/util/number/decimalCount64 + local.tee $1 + i32.const 1 + i32.shl + i32.const 1 + call $~lib/rt/stub/__alloc + local.tee $2 + local.get $0 + local.get $1 + call $~lib/util/number/utoa_simple + end + local.get $2 + ) + (func $resolve-access/arrayAccess (; 10 ;) (type $FUNCSIG$i) (result i32) + call $~lib/rt/__allocArray + call $~lib/array/Array#__get + call $~lib/util/number/utoa64 + ) + (func $resolve-access/Container#constructor (; 11 ;) (type $FUNCSIG$i) (result i32) + (local $0 i32) + i32.const 8 + i32.const 5 + call $~lib/rt/stub/__alloc + local.tee $0 + i64.const 0 + i64.store + local.get $0 + ) + (func $resolve-access/fieldAccess (; 12 ;) (type $FUNCSIG$i) (result i32) + (local $0 i32) + call $resolve-access/Container#constructor + local.tee $0 + i64.const 1 + i64.store + local.get $0 + i64.load + call $~lib/util/number/utoa64 + ) + (func $~lib/util/number/utoa32 (; 13 ;) (type $FUNCSIG$ii) (param $0 i32) (result i32) + (local $1 i32) + (local $2 i32) + local.get $0 + i32.eqz + if + i32.const 152 + return + end + local.get $0 + call $~lib/util/number/decimalCount32 + local.tee $1 + i32.const 1 + i32.shl + i32.const 1 + call $~lib/rt/stub/__alloc + local.tee $2 + local.get $0 + local.get $1 + call $~lib/util/number/utoa_simple + local.get $2 + ) + (func $resolve-access/propertyAccess (; 14 ;) (type $FUNCSIG$i) (result i32) + (local $0 i32) + call $resolve-access/Container#constructor + local.tee $0 + i64.const 1 + i64.store + local.get $0 + i64.load + i32.wrap_i64 + call $~lib/util/number/utoa32 + ) + (func $start (; 15 ;) (type $FUNCSIG$v) + i32.const 160 + global.set $~lib/rt/stub/startOffset + global.get $~lib/rt/stub/startOffset + global.set $~lib/rt/stub/offset + ) + (func $null (; 16 ;) (type $FUNCSIG$v) + nop + ) +) diff --git a/tests/compiler/resolve-access.ts b/tests/compiler/resolve-access.ts new file mode 100644 index 0000000000..d029ad3a08 --- /dev/null +++ b/tests/compiler/resolve-access.ts @@ -0,0 +1,25 @@ +export function arrayAccess(): string { + let arr: u64[] = [1]; + return arr[0].toString(); +} + +class Container { + foo: u64; + + toU32(): u32 { + return this.foo as u32; + } +} + +export function fieldAccess(): string { + let container = new Container(); + container.foo = 1; + return container.foo.toString(); +} + +export function propertyAccess(): string { + let container = new Container(); + container.foo = 1; + return container.toU32().toString(); +} + diff --git a/tests/compiler/resolve-access.untouched.wat b/tests/compiler/resolve-access.untouched.wat new file mode 100644 index 0000000000..0fac801874 --- /dev/null +++ b/tests/compiler/resolve-access.untouched.wat @@ -0,0 +1,2077 @@ +(module + (type $FUNCSIG$i (func (result i32))) + (type $FUNCSIG$iiiii (func (param i32 i32 i32 i32) (result i32))) + (type $FUNCSIG$iii (func (param i32 i32) (result i32))) + (type $FUNCSIG$ii (func (param i32) (result i32))) + (type $FUNCSIG$viii (func (param i32 i32 i32))) + (type $FUNCSIG$jii (func (param i32 i32) (result i64))) + (type $FUNCSIG$viiii (func (param i32 i32 i32 i32))) + (type $FUNCSIG$ij (func (param i64) (result i32))) + (type $FUNCSIG$viji (func (param i32 i64 i32))) + (type $FUNCSIG$vi (func (param i32))) + (type $FUNCSIG$v (func)) + (import "env" "abort" (func $~lib/builtins/abort (param i32 i32 i32 i32))) + (memory $0 1) + (data (i32.const 8) "\08\00\00\00\01\00\00\00\00\00\00\00\08\00\00\00\01\00\00\00\00\00\00\00") + (data (i32.const 32) "$\00\00\00\01\00\00\00\01\00\00\00$\00\00\00I\00n\00d\00e\00x\00 \00o\00u\00t\00 \00o\00f\00 \00r\00a\00n\00g\00e\00") + (data (i32.const 88) "\1a\00\00\00\01\00\00\00\01\00\00\00\1a\00\00\00~\00l\00i\00b\00/\00a\00r\00r\00a\00y\00.\00t\00s\00") + (data (i32.const 136) "\02\00\00\00\01\00\00\00\01\00\00\00\02\00\00\000\00") + (data (i32.const 160) "\90\01\00\00\01\00\00\00\00\00\00\00\90\01\00\000\000\000\001\000\002\000\003\000\004\000\005\000\006\000\007\000\008\000\009\001\000\001\001\001\002\001\003\001\004\001\005\001\006\001\007\001\008\001\009\002\000\002\001\002\002\002\003\002\004\002\005\002\006\002\007\002\008\002\009\003\000\003\001\003\002\003\003\003\004\003\005\003\006\003\007\003\008\003\009\004\000\004\001\004\002\004\003\004\004\004\005\004\006\004\007\004\008\004\009\005\000\005\001\005\002\005\003\005\004\005\005\005\006\005\007\005\008\005\009\006\000\006\001\006\002\006\003\006\004\006\005\006\006\006\007\006\008\006\009\007\000\007\001\007\002\007\003\007\004\007\005\007\006\007\007\007\008\007\009\008\000\008\001\008\002\008\003\008\004\008\005\008\006\008\007\008\008\008\009\009\000\009\001\009\002\009\003\009\004\009\005\009\006\009\007\009\008\009\009\00") + (data (i32.const 576) "\10\00\00\00\01\00\00\00\05\00\00\00\10\00\00\00\b0\00\00\00\b0\00\00\00\90\01\00\00d\00\00\00") + (table $0 1 funcref) + (elem (i32.const 0) $null) + (global $~lib/rt/stub/startOffset (mut i32) (i32.const 0)) + (global $~lib/rt/stub/offset (mut i32) (i32.const 0)) + (global $~lib/ASC_SHRINK_LEVEL i32 (i32.const 0)) + (global $~lib/builtins/u32.MAX_VALUE i32 (i32.const -1)) + (global $~lib/heap/__heap_base i32 (i32.const 608)) + (export "memory" (memory $0)) + (export "arrayAccess" (func $resolve-access/arrayAccess)) + (export "fieldAccess" (func $resolve-access/fieldAccess)) + (export "propertyAccess" (func $resolve-access/propertyAccess)) + (start $start) + (func $~lib/rt/stub/__alloc (; 1 ;) (type $FUNCSIG$iii) (param $0 i32) (param $1 i32) (result i32) + (local $2 i32) + (local $3 i32) + (local $4 i32) + (local $5 i32) + (local $6 i32) + (local $7 i32) + (local $8 i32) + local.get $0 + i32.const 1073741808 + i32.gt_u + if + unreachable + end + global.get $~lib/rt/stub/offset + i32.const 16 + i32.add + local.set $2 + local.get $2 + local.get $0 + local.tee $3 + i32.const 1 + local.tee $4 + local.get $3 + local.get $4 + i32.gt_u + select + i32.add + i32.const 15 + i32.add + i32.const 15 + i32.const -1 + i32.xor + i32.and + local.set $5 + memory.size + local.set $6 + local.get $5 + local.get $6 + i32.const 16 + i32.shl + i32.gt_u + if + local.get $5 + local.get $2 + i32.sub + i32.const 65535 + i32.add + i32.const 65535 + i32.const -1 + i32.xor + i32.and + i32.const 16 + i32.shr_u + local.set $3 + local.get $6 + local.tee $4 + local.get $3 + local.tee $7 + local.get $4 + local.get $7 + i32.gt_s + select + local.set $4 + local.get $4 + memory.grow + i32.const 0 + i32.lt_s + if + local.get $3 + memory.grow + i32.const 0 + i32.lt_s + if + unreachable + end + end + end + local.get $5 + global.set $~lib/rt/stub/offset + local.get $2 + i32.const 16 + i32.sub + local.set $8 + local.get $8 + local.get $1 + i32.store offset=8 + local.get $8 + local.get $0 + i32.store offset=12 + local.get $2 + ) + (func $~lib/rt/stub/__retain (; 2 ;) (type $FUNCSIG$ii) (param $0 i32) (result i32) + local.get $0 + ) + (func $~lib/util/memory/memcpy (; 3 ;) (type $FUNCSIG$viii) (param $0 i32) (param $1 i32) (param $2 i32) + (local $3 i32) + (local $4 i32) + (local $5 i32) + block $break|0 + loop $continue|0 + local.get $2 + if (result i32) + local.get $1 + i32.const 3 + i32.and + else + i32.const 0 + end + i32.eqz + br_if $break|0 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $2 + i32.const 1 + i32.sub + local.set $2 + br $continue|0 + end + unreachable + end + local.get $0 + i32.const 3 + i32.and + i32.const 0 + i32.eq + if + block $break|1 + loop $continue|1 + local.get $2 + i32.const 16 + i32.ge_u + i32.eqz + br_if $break|1 + local.get $0 + local.get $1 + i32.load + i32.store + local.get $0 + i32.const 4 + i32.add + local.get $1 + i32.const 4 + i32.add + i32.load + i32.store + local.get $0 + i32.const 8 + i32.add + local.get $1 + i32.const 8 + i32.add + i32.load + i32.store + local.get $0 + i32.const 12 + i32.add + local.get $1 + i32.const 12 + i32.add + i32.load + i32.store + local.get $1 + i32.const 16 + i32.add + local.set $1 + local.get $0 + i32.const 16 + i32.add + local.set $0 + local.get $2 + i32.const 16 + i32.sub + local.set $2 + br $continue|1 + end + unreachable + end + local.get $2 + i32.const 8 + i32.and + if + local.get $0 + local.get $1 + i32.load + i32.store + local.get $0 + i32.const 4 + i32.add + local.get $1 + i32.const 4 + i32.add + i32.load + i32.store + local.get $0 + i32.const 8 + i32.add + local.set $0 + local.get $1 + i32.const 8 + i32.add + local.set $1 + end + local.get $2 + i32.const 4 + i32.and + if + local.get $0 + local.get $1 + i32.load + i32.store + local.get $0 + i32.const 4 + i32.add + local.set $0 + local.get $1 + i32.const 4 + i32.add + local.set $1 + end + local.get $2 + i32.const 2 + i32.and + if + local.get $0 + local.get $1 + i32.load16_u + i32.store16 + local.get $0 + i32.const 2 + i32.add + local.set $0 + local.get $1 + i32.const 2 + i32.add + local.set $1 + end + local.get $2 + i32.const 1 + i32.and + if + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + end + return + end + local.get $2 + i32.const 32 + i32.ge_u + if + block $break|2 + block $case2|2 + block $case1|2 + block $case0|2 + local.get $0 + i32.const 3 + i32.and + local.set $5 + local.get $5 + i32.const 1 + i32.eq + br_if $case0|2 + local.get $5 + i32.const 2 + i32.eq + br_if $case1|2 + local.get $5 + i32.const 3 + i32.eq + br_if $case2|2 + br $break|2 + end + local.get $1 + i32.load + local.set $3 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $2 + i32.const 3 + i32.sub + local.set $2 + block $break|3 + loop $continue|3 + local.get $2 + i32.const 17 + i32.ge_u + i32.eqz + br_if $break|3 + local.get $1 + i32.const 1 + i32.add + i32.load + local.set $4 + local.get $0 + local.get $3 + i32.const 24 + i32.shr_u + local.get $4 + i32.const 8 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 5 + i32.add + i32.load + local.set $3 + local.get $0 + i32.const 4 + i32.add + local.get $4 + i32.const 24 + i32.shr_u + local.get $3 + i32.const 8 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 9 + i32.add + i32.load + local.set $4 + local.get $0 + i32.const 8 + i32.add + local.get $3 + i32.const 24 + i32.shr_u + local.get $4 + i32.const 8 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 13 + i32.add + i32.load + local.set $3 + local.get $0 + i32.const 12 + i32.add + local.get $4 + i32.const 24 + i32.shr_u + local.get $3 + i32.const 8 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 16 + i32.add + local.set $1 + local.get $0 + i32.const 16 + i32.add + local.set $0 + local.get $2 + i32.const 16 + i32.sub + local.set $2 + br $continue|3 + end + unreachable + end + br $break|2 + end + local.get $1 + i32.load + local.set $3 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $2 + i32.const 2 + i32.sub + local.set $2 + block $break|4 + loop $continue|4 + local.get $2 + i32.const 18 + i32.ge_u + i32.eqz + br_if $break|4 + local.get $1 + i32.const 2 + i32.add + i32.load + local.set $4 + local.get $0 + local.get $3 + i32.const 16 + i32.shr_u + local.get $4 + i32.const 16 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 6 + i32.add + i32.load + local.set $3 + local.get $0 + i32.const 4 + i32.add + local.get $4 + i32.const 16 + i32.shr_u + local.get $3 + i32.const 16 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 10 + i32.add + i32.load + local.set $4 + local.get $0 + i32.const 8 + i32.add + local.get $3 + i32.const 16 + i32.shr_u + local.get $4 + i32.const 16 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 14 + i32.add + i32.load + local.set $3 + local.get $0 + i32.const 12 + i32.add + local.get $4 + i32.const 16 + i32.shr_u + local.get $3 + i32.const 16 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 16 + i32.add + local.set $1 + local.get $0 + i32.const 16 + i32.add + local.set $0 + local.get $2 + i32.const 16 + i32.sub + local.set $2 + br $continue|4 + end + unreachable + end + br $break|2 + end + local.get $1 + i32.load + local.set $3 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $2 + i32.const 1 + i32.sub + local.set $2 + block $break|5 + loop $continue|5 + local.get $2 + i32.const 19 + i32.ge_u + i32.eqz + br_if $break|5 + local.get $1 + i32.const 3 + i32.add + i32.load + local.set $4 + local.get $0 + local.get $3 + i32.const 8 + i32.shr_u + local.get $4 + i32.const 24 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 7 + i32.add + i32.load + local.set $3 + local.get $0 + i32.const 4 + i32.add + local.get $4 + i32.const 8 + i32.shr_u + local.get $3 + i32.const 24 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 11 + i32.add + i32.load + local.set $4 + local.get $0 + i32.const 8 + i32.add + local.get $3 + i32.const 8 + i32.shr_u + local.get $4 + i32.const 24 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 15 + i32.add + i32.load + local.set $3 + local.get $0 + i32.const 12 + i32.add + local.get $4 + i32.const 8 + i32.shr_u + local.get $3 + i32.const 24 + i32.shl + i32.or + i32.store + local.get $1 + i32.const 16 + i32.add + local.set $1 + local.get $0 + i32.const 16 + i32.add + local.set $0 + local.get $2 + i32.const 16 + i32.sub + local.set $2 + br $continue|5 + end + unreachable + end + br $break|2 + end + end + local.get $2 + i32.const 16 + i32.and + if + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + end + local.get $2 + i32.const 8 + i32.and + if + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + end + local.get $2 + i32.const 4 + i32.and + if + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + end + local.get $2 + i32.const 2 + i32.and + if + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + end + local.get $2 + i32.const 1 + i32.and + if + local.get $0 + local.tee $5 + i32.const 1 + i32.add + local.set $0 + local.get $5 + local.get $1 + local.tee $5 + i32.const 1 + i32.add + local.set $1 + local.get $5 + i32.load8_u + i32.store8 + end + ) + (func $~lib/memory/memory.copy (; 4 ;) (type $FUNCSIG$viii) (param $0 i32) (param $1 i32) (param $2 i32) + (local $3 i32) + (local $4 i32) + (local $5 i32) + (local $6 i32) + block $~lib/util/memory/memmove|inlined.0 + local.get $0 + local.set $5 + local.get $1 + local.set $4 + local.get $2 + local.set $3 + local.get $5 + local.get $4 + i32.eq + if + br $~lib/util/memory/memmove|inlined.0 + end + local.get $4 + local.get $3 + i32.add + local.get $5 + i32.le_u + if (result i32) + i32.const 1 + else + local.get $5 + local.get $3 + i32.add + local.get $4 + i32.le_u + end + if + local.get $5 + local.get $4 + local.get $3 + call $~lib/util/memory/memcpy + br $~lib/util/memory/memmove|inlined.0 + end + local.get $5 + local.get $4 + i32.lt_u + if + local.get $4 + i32.const 7 + i32.and + local.get $5 + i32.const 7 + i32.and + i32.eq + if + block $break|0 + loop $continue|0 + local.get $5 + i32.const 7 + i32.and + i32.eqz + br_if $break|0 + local.get $3 + i32.eqz + if + br $~lib/util/memory/memmove|inlined.0 + end + local.get $3 + i32.const 1 + i32.sub + local.set $3 + local.get $5 + local.tee $6 + i32.const 1 + i32.add + local.set $5 + local.get $6 + local.get $4 + local.tee $6 + i32.const 1 + i32.add + local.set $4 + local.get $6 + i32.load8_u + i32.store8 + br $continue|0 + end + unreachable + end + block $break|1 + loop $continue|1 + local.get $3 + i32.const 8 + i32.ge_u + i32.eqz + br_if $break|1 + local.get $5 + local.get $4 + i64.load + i64.store + local.get $3 + i32.const 8 + i32.sub + local.set $3 + local.get $5 + i32.const 8 + i32.add + local.set $5 + local.get $4 + i32.const 8 + i32.add + local.set $4 + br $continue|1 + end + unreachable + end + end + block $break|2 + loop $continue|2 + local.get $3 + i32.eqz + br_if $break|2 + local.get $5 + local.tee $6 + i32.const 1 + i32.add + local.set $5 + local.get $6 + local.get $4 + local.tee $6 + i32.const 1 + i32.add + local.set $4 + local.get $6 + i32.load8_u + i32.store8 + local.get $3 + i32.const 1 + i32.sub + local.set $3 + br $continue|2 + end + unreachable + end + else + local.get $4 + i32.const 7 + i32.and + local.get $5 + i32.const 7 + i32.and + i32.eq + if + block $break|3 + loop $continue|3 + local.get $5 + local.get $3 + i32.add + i32.const 7 + i32.and + i32.eqz + br_if $break|3 + local.get $3 + i32.eqz + if + br $~lib/util/memory/memmove|inlined.0 + end + local.get $5 + local.get $3 + i32.const 1 + i32.sub + local.tee $3 + i32.add + local.get $4 + local.get $3 + i32.add + i32.load8_u + i32.store8 + br $continue|3 + end + unreachable + end + block $break|4 + loop $continue|4 + local.get $3 + i32.const 8 + i32.ge_u + i32.eqz + br_if $break|4 + local.get $3 + i32.const 8 + i32.sub + local.set $3 + local.get $5 + local.get $3 + i32.add + local.get $4 + local.get $3 + i32.add + i64.load + i64.store + br $continue|4 + end + unreachable + end + end + block $break|5 + loop $continue|5 + local.get $3 + i32.eqz + br_if $break|5 + local.get $5 + local.get $3 + i32.const 1 + i32.sub + local.tee $3 + i32.add + local.get $4 + local.get $3 + i32.add + i32.load8_u + i32.store8 + br $continue|5 + end + unreachable + end + end + end + ) + (func $~lib/rt/__allocArray (; 5 ;) (type $FUNCSIG$iiiii) (param $0 i32) (param $1 i32) (param $2 i32) (param $3 i32) (result i32) + (local $4 i32) + (local $5 i32) + (local $6 i32) + i32.const 16 + local.get $2 + call $~lib/rt/stub/__alloc + local.set $4 + local.get $0 + local.get $1 + i32.shl + local.set $5 + local.get $5 + i32.const 0 + call $~lib/rt/stub/__alloc + local.set $6 + local.get $4 + local.get $6 + call $~lib/rt/stub/__retain + i32.store + local.get $4 + local.get $6 + i32.store offset=4 + local.get $4 + local.get $5 + i32.store offset=8 + local.get $4 + local.get $0 + i32.store offset=12 + local.get $3 + if + local.get $6 + local.get $3 + local.get $5 + call $~lib/memory/memory.copy + end + local.get $4 + ) + (func $~lib/array/Array#__unchecked_get (; 6 ;) (type $FUNCSIG$jii) (param $0 i32) (param $1 i32) (result i64) + local.get $0 + i32.load offset=4 + local.get $1 + i32.const 3 + i32.shl + i32.add + i64.load + ) + (func $~lib/array/Array#__get (; 7 ;) (type $FUNCSIG$jii) (param $0 i32) (param $1 i32) (result i64) + local.get $1 + local.get $0 + i32.load offset=8 + i32.const 3 + i32.shr_u + i32.ge_u + if + i32.const 48 + i32.const 104 + i32.const 109 + i32.const 61 + call $~lib/builtins/abort + unreachable + end + local.get $0 + local.get $1 + call $~lib/array/Array#__unchecked_get + ) + (func $~lib/util/number/decimalCount32 (; 8 ;) (type $FUNCSIG$ii) (param $0 i32) (result i32) + (local $1 i32) + local.get $0 + i32.const 100000 + i32.lt_u + if + local.get $0 + i32.const 100 + i32.lt_u + if + i32.const 1 + i32.const 2 + local.get $0 + i32.const 10 + i32.lt_u + select + return + else + i32.const 4 + i32.const 5 + local.get $0 + i32.const 10000 + i32.lt_u + select + local.set $1 + i32.const 3 + local.get $1 + local.get $0 + i32.const 1000 + i32.lt_u + select + return + end + unreachable + else + local.get $0 + i32.const 10000000 + i32.lt_u + if + i32.const 6 + i32.const 7 + local.get $0 + i32.const 1000000 + i32.lt_u + select + return + else + i32.const 9 + i32.const 10 + local.get $0 + i32.const 1000000000 + i32.lt_u + select + local.set $1 + i32.const 8 + local.get $1 + local.get $0 + i32.const 100000000 + i32.lt_u + select + return + end + unreachable + end + unreachable + ) + (func $~lib/util/number/utoa32_lut (; 9 ;) (type $FUNCSIG$viii) (param $0 i32) (param $1 i32) (param $2 i32) + (local $3 i32) + (local $4 i32) + (local $5 i32) + (local $6 i32) + (local $7 i32) + (local $8 i64) + (local $9 i64) + i32.const 592 + i32.load offset=4 + local.set $3 + block $break|0 + loop $continue|0 + local.get $1 + i32.const 10000 + i32.ge_u + i32.eqz + br_if $break|0 + local.get $1 + i32.const 10000 + i32.div_u + local.set $4 + local.get $1 + i32.const 10000 + i32.rem_u + local.set $5 + local.get $4 + local.set $1 + local.get $5 + i32.const 100 + i32.div_u + local.set $6 + local.get $5 + i32.const 100 + i32.rem_u + local.set $7 + local.get $3 + local.get $6 + i32.const 2 + i32.shl + i32.add + i64.load32_u + local.set $8 + local.get $3 + local.get $7 + i32.const 2 + i32.shl + i32.add + i64.load32_u + local.set $9 + local.get $2 + i32.const 4 + i32.sub + local.set $2 + local.get $0 + local.get $2 + i32.const 1 + i32.shl + i32.add + local.get $8 + local.get $9 + i64.const 32 + i64.shl + i64.or + i64.store + br $continue|0 + end + unreachable + end + local.get $1 + i32.const 100 + i32.ge_u + if + local.get $1 + i32.const 100 + i32.div_u + local.set $7 + local.get $1 + i32.const 100 + i32.rem_u + local.set $6 + local.get $7 + local.set $1 + local.get $2 + i32.const 2 + i32.sub + local.set $2 + local.get $3 + local.get $6 + i32.const 2 + i32.shl + i32.add + i32.load + local.set $5 + local.get $0 + local.get $2 + i32.const 1 + i32.shl + i32.add + local.get $5 + i32.store + end + local.get $1 + i32.const 10 + i32.ge_u + if + local.get $2 + i32.const 2 + i32.sub + local.set $2 + local.get $3 + local.get $1 + i32.const 2 + i32.shl + i32.add + i32.load + local.set $5 + local.get $0 + local.get $2 + i32.const 1 + i32.shl + i32.add + local.get $5 + i32.store + else + local.get $2 + i32.const 1 + i32.sub + local.set $2 + i32.const 48 + local.get $1 + i32.add + local.set $5 + local.get $0 + local.get $2 + i32.const 1 + i32.shl + i32.add + local.get $5 + i32.store16 + end + ) + (func $~lib/util/number/decimalCount64 (; 10 ;) (type $FUNCSIG$ij) (param $0 i64) (result i32) + (local $1 i32) + local.get $0 + i64.const 1000000000000000 + i64.lt_u + if + local.get $0 + i64.const 1000000000000 + i64.lt_u + if + i32.const 11 + i32.const 12 + local.get $0 + i64.const 100000000000 + i64.lt_u + select + return + else + i32.const 14 + i32.const 15 + local.get $0 + i64.const 100000000000000 + i64.lt_u + select + local.set $1 + i32.const 13 + local.get $1 + local.get $0 + i64.const 10000000000000 + i64.lt_u + select + return + end + unreachable + else + local.get $0 + i64.const 100000000000000000 + i64.lt_u + if + i32.const 16 + i32.const 17 + local.get $0 + i64.const 10000000000000000 + i64.lt_u + select + return + else + i32.const 19 + i32.const 20 + local.get $0 + i64.const -8446744073709551616 + i64.lt_u + select + local.set $1 + i32.const 18 + local.get $1 + local.get $0 + i64.const 1000000000000000000 + i64.lt_u + select + return + end + unreachable + end + unreachable + ) + (func $~lib/util/number/utoa64_lut (; 11 ;) (type $FUNCSIG$viji) (param $0 i32) (param $1 i64) (param $2 i32) + (local $3 i32) + (local $4 i64) + (local $5 i32) + (local $6 i32) + (local $7 i32) + (local $8 i32) + (local $9 i32) + (local $10 i32) + (local $11 i32) + (local $12 i64) + (local $13 i64) + i32.const 592 + i32.load offset=4 + local.set $3 + block $break|0 + loop $continue|0 + local.get $1 + i64.const 100000000 + i64.ge_u + i32.eqz + br_if $break|0 + local.get $1 + i64.const 100000000 + i64.div_u + local.set $4 + local.get $1 + local.get $4 + i64.const 100000000 + i64.mul + i64.sub + i32.wrap_i64 + local.set $5 + local.get $4 + local.set $1 + local.get $5 + i32.const 10000 + i32.div_u + local.set $6 + local.get $5 + i32.const 10000 + i32.rem_u + local.set $7 + local.get $6 + i32.const 100 + i32.div_u + local.set $8 + local.get $6 + i32.const 100 + i32.rem_u + local.set $9 + local.get $7 + i32.const 100 + i32.div_u + local.set $10 + local.get $7 + i32.const 100 + i32.rem_u + local.set $11 + local.get $3 + local.get $10 + i32.const 2 + i32.shl + i32.add + i64.load32_u + local.set $12 + local.get $3 + local.get $11 + i32.const 2 + i32.shl + i32.add + i64.load32_u + local.set $13 + local.get $2 + i32.const 4 + i32.sub + local.set $2 + local.get $0 + local.get $2 + i32.const 1 + i32.shl + i32.add + local.get $12 + local.get $13 + i64.const 32 + i64.shl + i64.or + i64.store + local.get $3 + local.get $8 + i32.const 2 + i32.shl + i32.add + i64.load32_u + local.set $12 + local.get $3 + local.get $9 + i32.const 2 + i32.shl + i32.add + i64.load32_u + local.set $13 + local.get $2 + i32.const 4 + i32.sub + local.set $2 + local.get $0 + local.get $2 + i32.const 1 + i32.shl + i32.add + local.get $12 + local.get $13 + i64.const 32 + i64.shl + i64.or + i64.store + br $continue|0 + end + unreachable + end + local.get $0 + local.get $1 + i32.wrap_i64 + local.get $2 + call $~lib/util/number/utoa32_lut + ) + (func $~lib/util/number/utoa64 (; 12 ;) (type $FUNCSIG$ij) (param $0 i64) (result i32) + (local $1 i32) + (local $2 i32) + (local $3 i32) + (local $4 i32) + (local $5 i32) + (local $6 i32) + (local $7 i64) + local.get $0 + i64.eqz + if + i32.const 152 + call $~lib/rt/stub/__retain + return + end + local.get $0 + i64.const 4294967295 + i64.le_u + if + local.get $0 + i32.wrap_i64 + local.set $2 + local.get $2 + call $~lib/util/number/decimalCount32 + local.set $3 + local.get $3 + i32.const 1 + i32.shl + i32.const 1 + call $~lib/rt/stub/__alloc + local.set $1 + local.get $1 + local.set $6 + local.get $2 + local.set $5 + local.get $3 + local.set $4 + local.get $6 + local.get $5 + local.get $4 + call $~lib/util/number/utoa32_lut + else + local.get $0 + call $~lib/util/number/decimalCount64 + local.set $3 + local.get $3 + i32.const 1 + i32.shl + i32.const 1 + call $~lib/rt/stub/__alloc + local.set $1 + local.get $1 + local.set $5 + local.get $0 + local.set $7 + local.get $3 + local.set $4 + local.get $5 + local.get $7 + local.get $4 + call $~lib/util/number/utoa64_lut + end + local.get $1 + call $~lib/rt/stub/__retain + ) + (func $~lib/util/number/itoa (; 13 ;) (type $FUNCSIG$ij) (param $0 i64) (result i32) + local.get $0 + call $~lib/util/number/utoa64 + return + ) + (func $~lib/rt/stub/__release (; 14 ;) (type $FUNCSIG$vi) (param $0 i32) + nop + ) + (func $~lib/number/U64#toString (; 15 ;) (type $FUNCSIG$ij) (param $0 i64) (result i32) + (local $1 i32) + (local $2 i32) + local.get $0 + call $~lib/util/number/itoa + local.tee $1 + call $~lib/rt/stub/__retain + local.set $2 + local.get $1 + call $~lib/rt/stub/__release + local.get $2 + ) + (func $resolve-access/arrayAccess (; 16 ;) (type $FUNCSIG$i) (result i32) + (local $0 i32) + (local $1 i32) + (local $2 i32) + i32.const 1 + i32.const 3 + i32.const 3 + i32.const 24 + call $~lib/rt/__allocArray + call $~lib/rt/stub/__retain + local.tee $1 + call $~lib/rt/stub/__retain + local.set $0 + local.get $0 + i32.const 0 + call $~lib/array/Array#__get + call $~lib/number/U64#toString + local.set $2 + local.get $1 + call $~lib/rt/stub/__release + local.get $0 + call $~lib/rt/stub/__release + local.get $2 + ) + (func $resolve-access/Container#constructor (; 17 ;) (type $FUNCSIG$ii) (param $0 i32) (result i32) + local.get $0 + i32.eqz + if + i32.const 8 + i32.const 6 + call $~lib/rt/stub/__alloc + call $~lib/rt/stub/__retain + local.set $0 + end + local.get $0 + i64.const 0 + i64.store + local.get $0 + ) + (func $resolve-access/fieldAccess (; 18 ;) (type $FUNCSIG$i) (result i32) + (local $0 i32) + (local $1 i32) + i32.const 0 + call $resolve-access/Container#constructor + local.set $0 + local.get $0 + i64.const 1 + i64.store + local.get $0 + i64.load + call $~lib/number/U64#toString + local.set $1 + local.get $0 + call $~lib/rt/stub/__release + local.get $1 + ) + (func $resolve-access/Container#toU32 (; 19 ;) (type $FUNCSIG$ii) (param $0 i32) (result i32) + local.get $0 + i64.load + i32.wrap_i64 + ) + (func $~lib/util/number/utoa32 (; 20 ;) (type $FUNCSIG$ii) (param $0 i32) (result i32) + (local $1 i32) + (local $2 i32) + (local $3 i32) + (local $4 i32) + (local $5 i32) + local.get $0 + i32.eqz + if + i32.const 152 + call $~lib/rt/stub/__retain + return + end + local.get $0 + call $~lib/util/number/decimalCount32 + local.set $1 + local.get $1 + i32.const 1 + i32.shl + i32.const 1 + call $~lib/rt/stub/__alloc + local.set $2 + local.get $2 + local.set $5 + local.get $0 + local.set $4 + local.get $1 + local.set $3 + local.get $5 + local.get $4 + local.get $3 + call $~lib/util/number/utoa32_lut + local.get $2 + call $~lib/rt/stub/__retain + ) + (func $~lib/util/number/itoa (; 21 ;) (type $FUNCSIG$ii) (param $0 i32) (result i32) + local.get $0 + call $~lib/util/number/utoa32 + return + ) + (func $~lib/number/U32#toString (; 22 ;) (type $FUNCSIG$ii) (param $0 i32) (result i32) + (local $1 i32) + (local $2 i32) + local.get $0 + call $~lib/util/number/itoa + local.tee $1 + call $~lib/rt/stub/__retain + local.set $2 + local.get $1 + call $~lib/rt/stub/__release + local.get $2 + ) + (func $resolve-access/propertyAccess (; 23 ;) (type $FUNCSIG$i) (result i32) + (local $0 i32) + (local $1 i32) + i32.const 0 + call $resolve-access/Container#constructor + local.set $0 + local.get $0 + i64.const 1 + i64.store + local.get $0 + call $resolve-access/Container#toU32 + call $~lib/number/U32#toString + local.set $1 + local.get $0 + call $~lib/rt/stub/__release + local.get $1 + ) + (func $start (; 24 ;) (type $FUNCSIG$v) + global.get $~lib/heap/__heap_base + i32.const 15 + i32.add + i32.const 15 + i32.const -1 + i32.xor + i32.and + global.set $~lib/rt/stub/startOffset + global.get $~lib/rt/stub/startOffset + global.set $~lib/rt/stub/offset + ) + (func $null (; 25 ;) (type $FUNCSIG$v) + ) +) From 17f7380ae956f75ea2a1cf7773a91b91224d239e Mon Sep 17 00:00:00 2001 From: Bowen Wang Date: Fri, 21 Jun 2019 11:52:00 -0700 Subject: [PATCH 2/3] add info to NOTICE --- NOTICE | 1 + 1 file changed, 1 insertion(+) diff --git a/NOTICE b/NOTICE index c99b6077b7..f9e5e9e9a2 100644 --- a/NOTICE +++ b/NOTICE @@ -14,6 +14,7 @@ under the licensing terms detailed in LICENSE: * Nidin Vinayakan <01@01alchemist.com> * Aaron Turner * Willem Wyndham +* Bowen Wang Portions of this software are derived from third-party works licensed under the following terms: From b9e42e6b3ed9bd726f22d8f0430ef4361a2bf8ba Mon Sep 17 00:00:00 2001 From: Bowen Wang Date: Fri, 21 Jun 2019 17:30:03 -0700 Subject: [PATCH 3/3] address comments --- package-lock.json | 41 +++++++++++++++++++++++--------- src/resolver.ts | 4 ++-- tests/compiler/resolve-access.ts | 24 +++++++++---------- 3 files changed, 44 insertions(+), 25 deletions(-) diff --git a/package-lock.json b/package-lock.json index 7a820d4ef7..9ee87ce393 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1492,7 +1492,8 @@ "ansi-regex": { "version": "2.1.1", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "aproba": { "version": "1.2.0", @@ -1513,12 +1514,14 @@ "balanced-match": { "version": "1.0.0", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "brace-expansion": { "version": "1.1.11", "bundled": true, "dev": true, + "optional": true, "requires": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" @@ -1533,17 +1536,20 @@ "code-point-at": { "version": "1.1.0", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "concat-map": { "version": "0.0.1", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "console-control-strings": { "version": "1.1.0", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "core-util-is": { "version": "1.0.2", @@ -1660,7 +1666,8 @@ "inherits": { "version": "2.0.3", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "ini": { "version": "1.3.5", @@ -1672,6 +1679,7 @@ "version": "1.0.0", "bundled": true, "dev": true, + "optional": true, "requires": { "number-is-nan": "^1.0.0" } @@ -1686,6 +1694,7 @@ "version": "3.0.4", "bundled": true, "dev": true, + "optional": true, "requires": { "brace-expansion": "^1.1.7" } @@ -1693,12 +1702,14 @@ "minimist": { "version": "0.0.8", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "minipass": { "version": "2.3.5", "bundled": true, "dev": true, + "optional": true, "requires": { "safe-buffer": "^5.1.2", "yallist": "^3.0.0" @@ -1717,6 +1728,7 @@ "version": "0.5.1", "bundled": true, "dev": true, + "optional": true, "requires": { "minimist": "0.0.8" } @@ -1797,7 +1809,8 @@ "number-is-nan": { "version": "1.0.1", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "object-assign": { "version": "4.1.1", @@ -1809,6 +1822,7 @@ "version": "1.4.0", "bundled": true, "dev": true, + "optional": true, "requires": { "wrappy": "1" } @@ -1894,7 +1908,8 @@ "safe-buffer": { "version": "5.1.2", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "safer-buffer": { "version": "2.1.2", @@ -1930,6 +1945,7 @@ "version": "1.0.2", "bundled": true, "dev": true, + "optional": true, "requires": { "code-point-at": "^1.0.0", "is-fullwidth-code-point": "^1.0.0", @@ -1949,6 +1965,7 @@ "version": "3.0.1", "bundled": true, "dev": true, + "optional": true, "requires": { "ansi-regex": "^2.0.0" } @@ -1992,12 +2009,14 @@ "wrappy": { "version": "1.0.2", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "yallist": { "version": "3.0.3", "bundled": true, - "dev": true + "dev": true, + "optional": true } } }, diff --git a/src/resolver.ts b/src/resolver.ts index a7caa94ff8..2f52dc88d2 100644 --- a/src/resolver.ts +++ b/src/resolver.ts @@ -757,8 +757,8 @@ export class Resolver extends DiagnosticEmitter { classReference = typeClasses.get(arrayType.kind)!; } else { this.error( - DiagnosticCode.Property_0_does_not_exist_on_type_1, - propertyAccess.property.range, propertyName, arrayType.toString() + DiagnosticCode.Property_0_does_not_exist_on_type_1, + propertyAccess.property.range, propertyName, arrayType.toString() ); return null; } diff --git a/tests/compiler/resolve-access.ts b/tests/compiler/resolve-access.ts index d029ad3a08..9519101fb2 100644 --- a/tests/compiler/resolve-access.ts +++ b/tests/compiler/resolve-access.ts @@ -1,25 +1,25 @@ export function arrayAccess(): string { - let arr: u64[] = [1]; - return arr[0].toString(); + let arr: u64[] = [1]; + return arr[0].toString(); } class Container { - foo: u64; + foo: u64; - toU32(): u32 { - return this.foo as u32; - } + toU32(): u32 { + return this.foo as u32; + } } export function fieldAccess(): string { - let container = new Container(); - container.foo = 1; - return container.foo.toString(); + let container = new Container(); + container.foo = 1; + return container.foo.toString(); } export function propertyAccess(): string { - let container = new Container(); - container.foo = 1; - return container.toU32().toString(); + let container = new Container(); + container.foo = 1; + return container.toU32().toString(); }