You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1 line
131 KiB

{"version":3,"file":"index-no-eval.min.js","sources":["../unpack.js","../pack.js","../iterators.js","../index.js"],"sourcesContent":["var decoder\ntry {\n\tdecoder = new TextDecoder()\n} catch(error) {}\nvar src\nvar srcEnd\nvar position = 0\nvar alreadySet\nconst EMPTY_ARRAY = []\nvar strings = EMPTY_ARRAY\nvar stringPosition = 0\nvar currentUnpackr = {}\nvar currentStructures\nvar srcString\nvar srcStringStart = 0\nvar srcStringEnd = 0\nvar bundledStrings\nvar referenceMap\nvar currentExtensions = []\nvar dataView\nvar defaultOptions = {\n\tuseRecords: false,\n\tmapsAsObjects: true\n}\nexport class C1Type {}\nexport const C1 = new C1Type()\nC1.name = 'MessagePack 0xC1'\nvar sequentialMode = false\nvar inlineObjectReadThreshold = 2\nvar readStruct, onLoadedStructures, onSaveState\nvar BlockedFunction // we use search and replace to change the next call to BlockedFunction to avoid CSP issues for\n// no-eval build\ntry {\n\tnew Function('')\n} catch(error) {\n\t// if eval variants are not supported, do not create inline object readers ever\n\tinlineObjectReadThreshold = Infinity\n}\n\nexport class Unpackr {\n\tconstructor(options) {\n\t\tif (options) {\n\t\t\tif (options.useRecords === false && options.mapsAsObjects === undefined)\n\t\t\t\toptions.mapsAsObjects = true\n\t\t\tif (options.sequential && options.trusted !== false) {\n\t\t\t\toptions.trusted = true;\n\t\t\t\tif (!options.structures && options.useRecords != false) {\n\t\t\t\t\toptions.structures = []\n\t\t\t\t\tif (!options.maxSharedStructures)\n\t\t\t\t\t\toptions.maxSharedStructures = 0\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (options.structures)\n\t\t\t\toptions.structures.sharedLength = options.structures.length\n\t\t\telse if (options.getStructures) {\n\t\t\t\t(options.structures = []).uninitialized = true // this is what we use to denote an uninitialized structures\n\t\t\t\toptions.structures.sharedLength = 0\n\t\t\t}\n\t\t\tif (options.int64AsNumber) {\n\t\t\t\toptions.int64AsType = 'number'\n\t\t\t}\n\t\t}\n\t\tObject.assign(this, options)\n\t}\n\tunpack(source, options) {\n\t\tif (src) {\n\t\t\t// re-entrant execution, save the state and restore it after we do this unpack\n\t\t\treturn saveState(() => {\n\t\t\t\tclearSource()\n\t\t\t\treturn this ? this.unpack(source, options) : Unpackr.prototype.unpack.call(defaultOptions, source, options)\n\t\t\t})\n\t\t}\n\t\tif (!source.buffer && source.constructor === ArrayBuffer)\n\t\t\tsource = typeof Buffer !== 'undefined' ? Buffer.from(source) : new Uint8Array(source);\n\t\tif (typeof options === 'object') {\n\t\t\tsrcEnd = options.end || source.length\n\t\t\tposition = options.start || 0\n\t\t} else {\n\t\t\tposition = 0\n\t\t\tsrcEnd = options > -1 ? options : source.length\n\t\t}\n\t\tstringPosition = 0\n\t\tsrcStringEnd = 0\n\t\tsrcString = null\n\t\tstrings = EMPTY_ARRAY\n\t\tbundledStrings = null\n\t\tsrc = source\n\t\t// this provides cached access to the data view for a buffer if it is getting reused, which is a recommend\n\t\t// technique for getting data from a database where it can be copied into an existing buffer instead of creating\n\t\t// new ones\n\t\ttry {\n\t\t\tdataView = source.dataView || (source.dataView = new DataView(source.buffer, source.byteOffset, source.byteLength))\n\t\t} catch(error) {\n\t\t\t// if it doesn't have a buffer, maybe it is the wrong type of object\n\t\t\tsrc = null\n\t\t\tif (source instanceof Uint8Array)\n\t\t\t\tthrow error\n\t\t\tthrow new Error('Source must be a Uint8Array or Buffer but was a ' + ((source && typeof source == 'object') ? source.constructor.name : typeof source))\n\t\t}\n\t\tif (this instanceof Unpackr) {\n\t\t\tcurrentUnpackr = this\n\t\t\tif (this.structures) {\n\t\t\t\tcurrentStructures = this.structures\n\t\t\t\treturn checkedRead(options)\n\t\t\t} else if (!currentStructures || currentStructures.length > 0) {\n\t\t\t\tcurrentStructures = []\n\t\t\t}\n\t\t} else {\n\t\t\tcurrentUnpackr = defaultOptions\n\t\t\tif (!currentStructures || currentStructures.length > 0)\n\t\t\t\tcurrentStructures = []\n\t\t}\n\t\treturn checkedRead(options)\n\t}\n\tunpackMultiple(source, forEach) {\n\t\tlet values, lastPosition = 0\n\t\ttry {\n\t\t\tsequentialMode = true\n\t\t\tlet size = source.length\n\t\t\tlet value = this ? this.unpack(source, size) : defaultUnpackr.unpack(source, size)\n\t\t\tif (forEach) {\n\t\t\t\tif (forEach(value, lastPosition, position) === false) return;\n\t\t\t\twhile(position < size) {\n\t\t\t\t\tlastPosition = position\n\t\t\t\t\tif (forEach(checkedRead(), lastPosition, position) === false) {\n\t\t\t\t\t\treturn\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tvalues = [ value ]\n\t\t\t\twhile(position < size) {\n\t\t\t\t\tlastPosition = position\n\t\t\t\t\tvalues.push(checkedRead())\n\t\t\t\t}\n\t\t\t\treturn values\n\t\t\t}\n\t\t} catch(error) {\n\t\t\terror.lastPosition = lastPosition\n\t\t\terror.values = values\n\t\t\tthrow error\n\t\t} finally {\n\t\t\tsequentialMode = false\n\t\t\tclearSource()\n\t\t}\n\t}\n\t_mergeStructures(loadedStructures, existingStructures) {\n\t\tif (onLoadedStructures)\n\t\t\tloadedStructures = onLoadedStructures.call(this, loadedStructures);\n\t\tloadedStructures = loadedStructures || []\n\t\tif (Object.isFrozen(loadedStructures))\n\t\t\tloadedStructures = loadedStructures.map(structure => structure.slice(0))\n\t\tfor (let i = 0, l = loadedStructures.length; i < l; i++) {\n\t\t\tlet structure = loadedStructures[i]\n\t\t\tif (structure) {\n\t\t\t\tstructure.isShared = true\n\t\t\t\tif (i >= 32)\n\t\t\t\t\tstructure.highByte = (i - 32) >> 5\n\t\t\t}\n\t\t}\n\t\tloadedStructures.sharedLength = loadedStructures.length\n\t\tfor (let id in existingStructures || []) {\n\t\t\tif (id >= 0) {\n\t\t\t\tlet structure = loadedStructures[id]\n\t\t\t\tlet existing = existingStructures[id]\n\t\t\t\tif (existing) {\n\t\t\t\t\tif (structure)\n\t\t\t\t\t\t(loadedStructures.restoreStructures || (loadedStructures.restoreStructures = []))[id] = structure\n\t\t\t\t\tloadedStructures[id] = existing\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn this.structures = loadedStructures\n\t}\n\tdecode(source, options) {\n\t\treturn this.unpack(source, options)\n\t}\n}\nexport function getPosition() {\n\treturn position\n}\nexport function checkedRead(options) {\n\ttry {\n\t\tif (!currentUnpackr.trusted && !sequentialMode) {\n\t\t\tlet sharedLength = currentStructures.sharedLength || 0\n\t\t\tif (sharedLength < currentStructures.length)\n\t\t\t\tcurrentStructures.length = sharedLength\n\t\t}\n\t\tlet result\n\t\tif (currentUnpackr.randomAccessStructure && src[position] < 0x40 && src[position] >= 0x20 && readStruct) {\n\t\t\tresult = readStruct(src, position, srcEnd, currentUnpackr)\n\t\t\tsrc = null // dispose of this so that recursive unpack calls don't save state\n\t\t\tif (!(options && options.lazy) && result)\n\t\t\t\tresult = result.toJSON()\n\t\t\tposition = srcEnd\n\t\t} else\n\t\t\tresult = read()\n\t\tif (bundledStrings) { // bundled strings to skip past\n\t\t\tposition = bundledStrings.postBundlePosition\n\t\t\tbundledStrings = null\n\t\t}\n\t\tif (sequentialMode)\n\t\t\t// we only need to restore the structures if there was an error, but if we completed a read,\n\t\t\t// we can clear this out and keep the structures we read\n\t\t\tcurrentStructures.restoreStructures = null\n\n\t\tif (position == srcEnd) {\n\t\t\t// finished reading this source, cleanup references\n\t\t\tif (currentStructures && currentStructures.restoreStructures)\n\t\t\t\trestoreStructures()\n\t\t\tcurrentStructures = null\n\t\t\tsrc = null\n\t\t\tif (referenceMap)\n\t\t\t\treferenceMap = null\n\t\t} else if (position > srcEnd) {\n\t\t\t// over read\n\t\t\tthrow new Error('Unexpected end of MessagePack data')\n\t\t} else if (!sequentialMode) {\n\t\t\tlet jsonView;\n\t\t\ttry {\n\t\t\t\tjsonView = JSON.stringify(result, (_, value) => typeof value === \"bigint\" ? `${value}n` : value).slice(0, 100)\n\t\t\t} catch(error) {\n\t\t\t\tjsonView = '(JSON view not available ' + error + ')'\n\t\t\t}\n\t\t\tthrow new Error('Data read, but end of buffer not reached ' + jsonView)\n\t\t}\n\t\t// else more to read, but we are reading sequentially, so don't clear source yet\n\t\treturn result\n\t} catch(error) {\n\t\tif (currentStructures && currentStructures.restoreStructures)\n\t\t\trestoreStructures()\n\t\tclearSource()\n\t\tif (error instanceof RangeError || error.message.startsWith('Unexpected end of buffer') || position > srcEnd) {\n\t\t\terror.incomplete = true\n\t\t}\n\t\tthrow error\n\t}\n}\n\nfunction restoreStructures() {\n\tfor (let id in currentStructures.restoreStructures) {\n\t\tcurrentStructures[id] = currentStructures.restoreStructures[id]\n\t}\n\tcurrentStructures.restoreStructures = null\n}\n\nexport function read() {\n\tlet token = src[position++]\n\tif (token < 0xa0) {\n\t\tif (token < 0x80) {\n\t\t\tif (token < 0x40)\n\t\t\t\treturn token\n\t\t\telse {\n\t\t\t\tlet structure = currentStructures[token & 0x3f] ||\n\t\t\t\t\tcurrentUnpackr.getStructures && loadStructures()[token & 0x3f]\n\t\t\t\tif (structure) {\n\t\t\t\t\tif (!structure.read) {\n\t\t\t\t\t\tstructure.read = createStructureReader(structure, token & 0x3f)\n\t\t\t\t\t}\n\t\t\t\t\treturn structure.read()\n\t\t\t\t} else\n\t\t\t\t\treturn token\n\t\t\t}\n\t\t} else if (token < 0x90) {\n\t\t\t// map\n\t\t\ttoken -= 0x80\n\t\t\tif (currentUnpackr.mapsAsObjects) {\n\t\t\t\tlet object = {}\n\t\t\t\tfor (let i = 0; i < token; i++) {\n\t\t\t\t\tlet key = readKey()\n\t\t\t\t\tif (key === '__proto__')\n\t\t\t\t\t\tkey = '__proto_'\n\t\t\t\t\tobject[key] = read()\n\t\t\t\t}\n\t\t\t\treturn object\n\t\t\t} else {\n\t\t\t\tlet map = new Map()\n\t\t\t\tfor (let i = 0; i < token; i++) {\n\t\t\t\t\tmap.set(read(), read())\n\t\t\t\t}\n\t\t\t\treturn map\n\t\t\t}\n\t\t} else {\n\t\t\ttoken -= 0x90\n\t\t\tlet array = new Array(token)\n\t\t\tfor (let i = 0; i < token; i++) {\n\t\t\t\tarray[i] = read()\n\t\t\t}\n\t\t\tif (currentUnpackr.freezeData)\n\t\t\t\treturn Object.freeze(array)\n\t\t\treturn array\n\t\t}\n\t} else if (token < 0xc0) {\n\t\t// fixstr\n\t\tlet length = token - 0xa0\n\t\tif (srcStringEnd >= position) {\n\t\t\treturn srcString.slice(position - srcStringStart, (position += length) - srcStringStart)\n\t\t}\n\t\tif (srcStringEnd == 0 && srcEnd < 140) {\n\t\t\t// for small blocks, avoiding the overhead of the extract call is helpful\n\t\t\tlet string = length < 16 ? shortStringInJS(length) : longStringInJS(length)\n\t\t\tif (string != null)\n\t\t\t\treturn string\n\t\t}\n\t\treturn readFixedString(length)\n\t} else {\n\t\tlet value\n\t\tswitch (token) {\n\t\t\tcase 0xc0: return null\n\t\t\tcase 0xc1:\n\t\t\t\tif (bundledStrings) {\n\t\t\t\t\tvalue = read() // followed by the length of the string in characters (not bytes!)\n\t\t\t\t\tif (value > 0)\n\t\t\t\t\t\treturn bundledStrings[1].slice(bundledStrings.position1, bundledStrings.position1 += value)\n\t\t\t\t\telse\n\t\t\t\t\t\treturn bundledStrings[0].slice(bundledStrings.position0, bundledStrings.position0 -= value)\n\t\t\t\t}\n\t\t\t\treturn C1; // \"never-used\", return special object to denote that\n\t\t\tcase 0xc2: return false\n\t\t\tcase 0xc3: return true\n\t\t\tcase 0xc4:\n\t\t\t\t// bin 8\n\t\t\t\tvalue = src[position++]\n\t\t\t\tif (value === undefined)\n\t\t\t\t\tthrow new Error('Unexpected end of buffer')\n\t\t\t\treturn readBin(value)\n\t\t\tcase 0xc5:\n\t\t\t\t// bin 16\n\t\t\t\tvalue = dataView.getUint16(position)\n\t\t\t\tposition += 2\n\t\t\t\treturn readBin(value)\n\t\t\tcase 0xc6:\n\t\t\t\t// bin 32\n\t\t\t\tvalue = dataView.getUint32(position)\n\t\t\t\tposition += 4\n\t\t\t\treturn readBin(value)\n\t\t\tcase 0xc7:\n\t\t\t\t// ext 8\n\t\t\t\treturn readExt(src[position++])\n\t\t\tcase 0xc8:\n\t\t\t\t// ext 16\n\t\t\t\tvalue = dataView.getUint16(position)\n\t\t\t\tposition += 2\n\t\t\t\treturn readExt(value)\n\t\t\tcase 0xc9:\n\t\t\t\t// ext 32\n\t\t\t\tvalue = dataView.getUint32(position)\n\t\t\t\tposition += 4\n\t\t\t\treturn readExt(value)\n\t\t\tcase 0xca:\n\t\t\t\tvalue = dataView.getFloat32(position)\n\t\t\t\tif (currentUnpackr.useFloat32 > 2) {\n\t\t\t\t\t// this does rounding of numbers that were encoded in 32-bit float to nearest significant decimal digit that could be preserved\n\t\t\t\t\tlet multiplier = mult10[((src[position] & 0x7f) << 1) | (src[position + 1] >> 7)]\n\t\t\t\t\tposition += 4\n\t\t\t\t\treturn ((multiplier * value + (value > 0 ? 0.5 : -0.5)) >> 0) / multiplier\n\t\t\t\t}\n\t\t\t\tposition += 4\n\t\t\t\treturn value\n\t\t\tcase 0xcb:\n\t\t\t\tvalue = dataView.getFloat64(position)\n\t\t\t\tposition += 8\n\t\t\t\treturn value\n\t\t\t// uint handlers\n\t\t\tcase 0xcc:\n\t\t\t\treturn src[position++]\n\t\t\tcase 0xcd:\n\t\t\t\tvalue = dataView.getUint16(position)\n\t\t\t\tposition += 2\n\t\t\t\treturn value\n\t\t\tcase 0xce:\n\t\t\t\tvalue = dataView.getUint32(position)\n\t\t\t\tposition += 4\n\t\t\t\treturn value\n\t\t\tcase 0xcf:\n\t\t\t\tif (currentUnpackr.int64AsType === 'number') {\n\t\t\t\t\tvalue = dataView.getUint32(position) * 0x100000000\n\t\t\t\t\tvalue += dataView.getUint32(position + 4)\n\t\t\t\t} else if (currentUnpackr.int64AsType === 'string') {\n\t\t\t\t\tvalue = dataView.getBigUint64(position).toString()\n\t\t\t\t} else if (currentUnpackr.int64AsType === 'auto') {\n\t\t\t\t\tvalue = dataView.getBigUint64(position)\n\t\t\t\t\tif (value<=BigInt(2)<<BigInt(52)) value=Number(value)\n\t\t\t\t} else\n\t\t\t\t\tvalue = dataView.getBigUint64(position)\n\t\t\t\tposition += 8\n\t\t\t\treturn value\n\n\t\t\t// int handlers\n\t\t\tcase 0xd0:\n\t\t\t\treturn dataView.getInt8(position++)\n\t\t\tcase 0xd1:\n\t\t\t\tvalue = dataView.getInt16(position)\n\t\t\t\tposition += 2\n\t\t\t\treturn value\n\t\t\tcase 0xd2:\n\t\t\t\tvalue = dataView.getInt32(position)\n\t\t\t\tposition += 4\n\t\t\t\treturn value\n\t\t\tcase 0xd3:\n\t\t\t\tif (currentUnpackr.int64AsType === 'number') {\n\t\t\t\t\tvalue = dataView.getInt32(position) * 0x100000000\n\t\t\t\t\tvalue += dataView.getUint32(position + 4)\n\t\t\t\t} else if (currentUnpackr.int64AsType === 'string') {\n\t\t\t\t\tvalue = dataView.getBigInt64(position).toString()\n\t\t\t\t} else if (currentUnpackr.int64AsType === 'auto') {\n\t\t\t\t\tvalue = dataView.getBigInt64(position)\n\t\t\t\t\tif (value>=BigInt(-2)<<BigInt(52)&&value<=BigInt(2)<<BigInt(52)) value=Number(value)\n\t\t\t\t} else\n\t\t\t\t\tvalue = dataView.getBigInt64(position)\n\t\t\t\tposition += 8\n\t\t\t\treturn value\n\n\t\t\tcase 0xd4:\n\t\t\t\t// fixext 1\n\t\t\t\tvalue = src[position++]\n\t\t\t\tif (value == 0x72) {\n\t\t\t\t\treturn recordDefinition(src[position++] & 0x3f)\n\t\t\t\t} else {\n\t\t\t\t\tlet extension = currentExtensions[value]\n\t\t\t\t\tif (extension) {\n\t\t\t\t\t\tif (extension.read) {\n\t\t\t\t\t\t\tposition++ // skip filler byte\n\t\t\t\t\t\t\treturn extension.read(read())\n\t\t\t\t\t\t} else if (extension.noBuffer) {\n\t\t\t\t\t\t\tposition++ // skip filler byte\n\t\t\t\t\t\t\treturn extension()\n\t\t\t\t\t\t} else\n\t\t\t\t\t\t\treturn extension(src.subarray(position, ++position))\n\t\t\t\t\t} else\n\t\t\t\t\t\tthrow new Error('Unknown extension ' + value)\n\t\t\t\t}\n\t\t\tcase 0xd5:\n\t\t\t\t// fixext 2\n\t\t\t\tvalue = src[position]\n\t\t\t\tif (value == 0x72) {\n\t\t\t\t\tposition++\n\t\t\t\t\treturn recordDefinition(src[position++] & 0x3f, src[position++])\n\t\t\t\t} else\n\t\t\t\t\treturn readExt(2)\n\t\t\tcase 0xd6:\n\t\t\t\t// fixext 4\n\t\t\t\treturn readExt(4)\n\t\t\tcase 0xd7:\n\t\t\t\t// fixext 8\n\t\t\t\treturn readExt(8)\n\t\t\tcase 0xd8:\n\t\t\t\t// fixext 16\n\t\t\t\treturn readExt(16)\n\t\t\tcase 0xd9:\n\t\t\t// str 8\n\t\t\t\tvalue = src[position++]\n\t\t\t\tif (srcStringEnd >= position) {\n\t\t\t\t\treturn srcString.slice(position - srcStringStart, (position += value) - srcStringStart)\n\t\t\t\t}\n\t\t\t\treturn readString8(value)\n\t\t\tcase 0xda:\n\t\t\t// str 16\n\t\t\t\tvalue = dataView.getUint16(position)\n\t\t\t\tposition += 2\n\t\t\t\tif (srcStringEnd >= position) {\n\t\t\t\t\treturn srcString.slice(position - srcStringStart, (position += value) - srcStringStart)\n\t\t\t\t}\n\t\t\t\treturn readString16(value)\n\t\t\tcase 0xdb:\n\t\t\t// str 32\n\t\t\t\tvalue = dataView.getUint32(position)\n\t\t\t\tposition += 4\n\t\t\t\tif (srcStringEnd >= position) {\n\t\t\t\t\treturn srcString.slice(position - srcStringStart, (position += value) - srcStringStart)\n\t\t\t\t}\n\t\t\t\treturn readString32(value)\n\t\t\tcase 0xdc:\n\t\t\t// array 16\n\t\t\t\tvalue = dataView.getUint16(position)\n\t\t\t\tposition += 2\n\t\t\t\treturn readArray(value)\n\t\t\tcase 0xdd:\n\t\t\t// array 32\n\t\t\t\tvalue = dataView.getUint32(position)\n\t\t\t\tposition += 4\n\t\t\t\treturn readArray(value)\n\t\t\tcase 0xde:\n\t\t\t// map 16\n\t\t\t\tvalue = dataView.getUint16(position)\n\t\t\t\tposition += 2\n\t\t\t\treturn readMap(value)\n\t\t\tcase 0xdf:\n\t\t\t// map 32\n\t\t\t\tvalue = dataView.getUint32(position)\n\t\t\t\tposition += 4\n\t\t\t\treturn readMap(value)\n\t\t\tdefault: // negative int\n\t\t\t\tif (token >= 0xe0)\n\t\t\t\t\treturn token - 0x100\n\t\t\t\tif (token === undefined) {\n\t\t\t\t\tlet error = new Error('Unexpected end of MessagePack data')\n\t\t\t\t\terror.incomplete = true\n\t\t\t\t\tthrow error\n\t\t\t\t}\n\t\t\t\tthrow new Error('Unknown MessagePack token ' + token)\n\n\t\t}\n\t}\n}\nconst validName = /^[a-zA-Z_$][a-zA-Z\\d_$]*$/\nfunction createStructureReader(structure, firstId) {\n\tfunction readObject() {\n\t\t// This initial function is quick to instantiate, but runs slower. After several iterations pay the cost to build the faster function\n\t\tif (readObject.count++ > inlineObjectReadThreshold) {\n\t\t\tlet readObject = structure.read = (new Function('r', 'return function(){return ' + (currentUnpackr.freezeData ? 'Object.freeze' : '') +\n\t\t\t\t'({' + structure.map(key => key === '__proto__' ? '__proto_:r()' : validName.test(key) ? key + ':r()' : ('[' + JSON.stringify(key) + ']:r()')).join(',') + '})}'))(read)\n\t\t\tif (structure.highByte === 0)\n\t\t\t\tstructure.read = createSecondByteReader(firstId, structure.read)\n\t\t\treturn readObject() // second byte is already read, if there is one so immediately read object\n\t\t}\n\t\tlet object = {}\n\t\tfor (let i = 0, l = structure.length; i < l; i++) {\n\t\t\tlet key = structure[i]\n\t\t\tif (key === '__proto__')\n\t\t\t\tkey = '__proto_'\n\t\t\tobject[key] = read()\n\t\t}\n\t\tif (currentUnpackr.freezeData)\n\t\t\treturn Object.freeze(object);\n\t\treturn object\n\t}\n\treadObject.count = 0\n\tif (structure.highByte === 0) {\n\t\treturn createSecondByteReader(firstId, readObject)\n\t}\n\treturn readObject\n}\n\nconst createSecondByteReader = (firstId, read0) => {\n\treturn function() {\n\t\tlet highByte = src[position++]\n\t\tif (highByte === 0)\n\t\t\treturn read0()\n\t\tlet id = firstId < 32 ? -(firstId + (highByte << 5)) : firstId + (highByte << 5)\n\t\tlet structure = currentStructures[id] || loadStructures()[id]\n\t\tif (!structure) {\n\t\t\tthrow new Error('Record id is not defined for ' + id)\n\t\t}\n\t\tif (!structure.read)\n\t\t\tstructure.read = createStructureReader(structure, firstId)\n\t\treturn structure.read()\n\t}\n}\n\nexport function loadStructures() {\n\tlet loadedStructures = saveState(() => {\n\t\t// save the state in case getStructures modifies our buffer\n\t\tsrc = null\n\t\treturn currentUnpackr.getStructures()\n\t})\n\treturn currentStructures = currentUnpackr._mergeStructures(loadedStructures, currentStructures)\n}\n\nvar readFixedString = readStringJS\nvar readString8 = readStringJS\nvar readString16 = readStringJS\nvar readString32 = readStringJS\nexport let isNativeAccelerationEnabled = false\n\nexport function setExtractor(extractStrings) {\n\tisNativeAccelerationEnabled = true\n\treadFixedString = readString(1)\n\treadString8 = readString(2)\n\treadString16 = readString(3)\n\treadString32 = readString(5)\n\tfunction readString(headerLength) {\n\t\treturn function readString(length) {\n\t\t\tlet string = strings[stringPosition++]\n\t\t\tif (string == null) {\n\t\t\t\tif (bundledStrings)\n\t\t\t\t\treturn readStringJS(length)\n\t\t\t\tlet byteOffset = src.byteOffset\n\t\t\t\tlet extraction = extractStrings(position - headerLength + byteOffset, srcEnd + byteOffset, src.buffer)\n\t\t\t\tif (typeof extraction == 'string') {\n\t\t\t\t\tstring = extraction\n\t\t\t\t\tstrings = EMPTY_ARRAY\n\t\t\t\t} else {\n\t\t\t\t\tstrings = extraction\n\t\t\t\t\tstringPosition = 1\n\t\t\t\t\tsrcStringEnd = 1 // even if a utf-8 string was decoded, must indicate we are in the midst of extracted strings and can't skip strings\n\t\t\t\t\tstring = strings[0]\n\t\t\t\t\tif (string === undefined)\n\t\t\t\t\t\tthrow new Error('Unexpected end of buffer')\n\t\t\t\t}\n\t\t\t}\n\t\t\tlet srcStringLength = string.length\n\t\t\tif (srcStringLength <= length) {\n\t\t\t\tposition += length\n\t\t\t\treturn string\n\t\t\t}\n\t\t\tsrcString = string\n\t\t\tsrcStringStart = position\n\t\t\tsrcStringEnd = position + srcStringLength\n\t\t\tposition += length\n\t\t\treturn string.slice(0, length) // we know we just want the beginning\n\t\t}\n\t}\n}\nfunction readStringJS(length) {\n\tlet result\n\tif (length < 16) {\n\t\tif (result = shortStringInJS(length))\n\t\t\treturn result\n\t}\n\tif (length > 64 && decoder)\n\t\treturn decoder.decode(src.subarray(position, position += length))\n\tconst end = position + length\n\tconst units = []\n\tresult = ''\n\twhile (position < end) {\n\t\tconst byte1 = src[position++]\n\t\tif ((byte1 & 0x80) === 0) {\n\t\t\t// 1 byte\n\t\t\tunits.push(byte1)\n\t\t} else if ((byte1 & 0xe0) === 0xc0) {\n\t\t\t// 2 bytes\n\t\t\tconst byte2 = src[position++] & 0x3f\n\t\t\tunits.push(((byte1 & 0x1f) << 6) | byte2)\n\t\t} else if ((byte1 & 0xf0) === 0xe0) {\n\t\t\t// 3 bytes\n\t\t\tconst byte2 = src[position++] & 0x3f\n\t\t\tconst byte3 = src[position++] & 0x3f\n\t\t\tunits.push(((byte1 & 0x1f) << 12) | (byte2 << 6) | byte3)\n\t\t} else if ((byte1 & 0xf8) === 0xf0) {\n\t\t\t// 4 bytes\n\t\t\tconst byte2 = src[position++] & 0x3f\n\t\t\tconst byte3 = src[position++] & 0x3f\n\t\t\tconst byte4 = src[position++] & 0x3f\n\t\t\tlet unit = ((byte1 & 0x07) << 0x12) | (byte2 << 0x0c) | (byte3 << 0x06) | byte4\n\t\t\tif (unit > 0xffff) {\n\t\t\t\tunit -= 0x10000\n\t\t\t\tunits.push(((unit >>> 10) & 0x3ff) | 0xd800)\n\t\t\t\tunit = 0xdc00 | (unit & 0x3ff)\n\t\t\t}\n\t\t\tunits.push(unit)\n\t\t} else {\n\t\t\tunits.push(byte1)\n\t\t}\n\n\t\tif (units.length >= 0x1000) {\n\t\t\tresult += fromCharCode.apply(String, units)\n\t\t\tunits.length = 0\n\t\t}\n\t}\n\n\tif (units.length > 0) {\n\t\tresult += fromCharCode.apply(String, units)\n\t}\n\n\treturn result\n}\nexport function readString(source, start, length) {\n\tlet existingSrc = src;\n\tsrc = source;\n\tposition = start;\n\ttry {\n\t\treturn readStringJS(length);\n\t} finally {\n\t\tsrc = existingSrc;\n\t}\n}\n\nfunction readArray(length) {\n\tlet array = new Array(length)\n\tfor (let i = 0; i < length; i++) {\n\t\tarray[i] = read()\n\t}\n\tif (currentUnpackr.freezeData)\n\t\treturn Object.freeze(array)\n\treturn array\n}\n\nfunction readMap(length) {\n\tif (currentUnpackr.mapsAsObjects) {\n\t\tlet object = {}\n\t\tfor (let i = 0; i < length; i++) {\n\t\t\tlet key = readKey()\n\t\t\tif (key === '__proto__')\n\t\t\t\tkey = '__proto_';\n\t\t\tobject[key] = read()\n\t\t}\n\t\treturn object\n\t} else {\n\t\tlet map = new Map()\n\t\tfor (let i = 0; i < length; i++) {\n\t\t\tmap.set(read(), read())\n\t\t}\n\t\treturn map\n\t}\n}\n\nvar fromCharCode = String.fromCharCode\nfunction longStringInJS(length) {\n\tlet start = position\n\tlet bytes = new Array(length)\n\tfor (let i = 0; i < length; i++) {\n\t\tconst byte = src[position++];\n\t\tif ((byte & 0x80) > 0) {\n\t\t\t\tposition = start\n\t\t\t\treturn\n\t\t\t}\n\t\t\tbytes[i] = byte\n\t\t}\n\t\treturn fromCharCode.apply(String, bytes)\n}\nfunction shortStringInJS(length) {\n\tif (length < 4) {\n\t\tif (length < 2) {\n\t\t\tif (length === 0)\n\t\t\t\treturn ''\n\t\t\telse {\n\t\t\t\tlet a = src[position++]\n\t\t\t\tif ((a & 0x80) > 1) {\n\t\t\t\t\tposition -= 1\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\treturn fromCharCode(a)\n\t\t\t}\n\t\t} else {\n\t\t\tlet a = src[position++]\n\t\t\tlet b = src[position++]\n\t\t\tif ((a & 0x80) > 0 || (b & 0x80) > 0) {\n\t\t\t\tposition -= 2\n\t\t\t\treturn\n\t\t\t}\n\t\t\tif (length < 3)\n\t\t\t\treturn fromCharCode(a, b)\n\t\t\tlet c = src[position++]\n\t\t\tif ((c & 0x80) > 0) {\n\t\t\t\tposition -= 3\n\t\t\t\treturn\n\t\t\t}\n\t\t\treturn fromCharCode(a, b, c)\n\t\t}\n\t} else {\n\t\tlet a = src[position++]\n\t\tlet b = src[position++]\n\t\tlet c = src[position++]\n\t\tlet d = src[position++]\n\t\tif ((a & 0x80) > 0 || (b & 0x80) > 0 || (c & 0x80) > 0 || (d & 0x80) > 0) {\n\t\t\tposition -= 4\n\t\t\treturn\n\t\t}\n\t\tif (length < 6) {\n\t\t\tif (length === 4)\n\t\t\t\treturn fromCharCode(a, b, c, d)\n\t\t\telse {\n\t\t\t\tlet e = src[position++]\n\t\t\t\tif ((e & 0x80) > 0) {\n\t\t\t\t\tposition -= 5\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\treturn fromCharCode(a, b, c, d, e)\n\t\t\t}\n\t\t} else if (length < 8) {\n\t\t\tlet e = src[position++]\n\t\t\tlet f = src[position++]\n\t\t\tif ((e & 0x80) > 0 || (f & 0x80) > 0) {\n\t\t\t\tposition -= 6\n\t\t\t\treturn\n\t\t\t}\n\t\t\tif (length < 7)\n\t\t\t\treturn fromCharCode(a, b, c, d, e, f)\n\t\t\tlet g = src[position++]\n\t\t\tif ((g & 0x80) > 0) {\n\t\t\t\tposition -= 7\n\t\t\t\treturn\n\t\t\t}\n\t\t\treturn fromCharCode(a, b, c, d, e, f, g)\n\t\t} else {\n\t\t\tlet e = src[position++]\n\t\t\tlet f = src[position++]\n\t\t\tlet g = src[position++]\n\t\t\tlet h = src[position++]\n\t\t\tif ((e & 0x80) > 0 || (f & 0x80) > 0 || (g & 0x80) > 0 || (h & 0x80) > 0) {\n\t\t\t\tposition -= 8\n\t\t\t\treturn\n\t\t\t}\n\t\t\tif (length < 10) {\n\t\t\t\tif (length === 8)\n\t\t\t\t\treturn fromCharCode(a, b, c, d, e, f, g, h)\n\t\t\t\telse {\n\t\t\t\t\tlet i = src[position++]\n\t\t\t\t\tif ((i & 0x80) > 0) {\n\t\t\t\t\t\tposition -= 9\n\t\t\t\t\t\treturn\n\t\t\t\t\t}\n\t\t\t\t\treturn fromCharCode(a, b, c, d, e, f, g, h, i)\n\t\t\t\t}\n\t\t\t} else if (length < 12) {\n\t\t\t\tlet i = src[position++]\n\t\t\t\tlet j = src[position++]\n\t\t\t\tif ((i & 0x80) > 0 || (j & 0x80) > 0) {\n\t\t\t\t\tposition -= 10\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\tif (length < 11)\n\t\t\t\t\treturn fromCharCode(a, b, c, d, e, f, g, h, i, j)\n\t\t\t\tlet k = src[position++]\n\t\t\t\tif ((k & 0x80) > 0) {\n\t\t\t\t\tposition -= 11\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\treturn fromCharCode(a, b, c, d, e, f, g, h, i, j, k)\n\t\t\t} else {\n\t\t\t\tlet i = src[position++]\n\t\t\t\tlet j = src[position++]\n\t\t\t\tlet k = src[position++]\n\t\t\t\tlet l = src[position++]\n\t\t\t\tif ((i & 0x80) > 0 || (j & 0x80) > 0 || (k & 0x80) > 0 || (l & 0x80) > 0) {\n\t\t\t\t\tposition -= 12\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\tif (length < 14) {\n\t\t\t\t\tif (length === 12)\n\t\t\t\t\t\treturn fromCharCode(a, b, c, d, e, f, g, h, i, j, k, l)\n\t\t\t\t\telse {\n\t\t\t\t\t\tlet m = src[position++]\n\t\t\t\t\t\tif ((m & 0x80) > 0) {\n\t\t\t\t\t\t\tposition -= 13\n\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn fromCharCode(a, b, c, d, e, f, g, h, i, j, k, l, m)\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tlet m = src[position++]\n\t\t\t\t\tlet n = src[position++]\n\t\t\t\t\tif ((m & 0x80) > 0 || (n & 0x80) > 0) {\n\t\t\t\t\t\tposition -= 14\n\t\t\t\t\t\treturn\n\t\t\t\t\t}\n\t\t\t\t\tif (length < 15)\n\t\t\t\t\t\treturn fromCharCode(a, b, c, d, e, f, g, h, i, j, k, l, m, n)\n\t\t\t\t\tlet o = src[position++]\n\t\t\t\t\tif ((o & 0x80) > 0) {\n\t\t\t\t\t\tposition -= 15\n\t\t\t\t\t\treturn\n\t\t\t\t\t}\n\t\t\t\t\treturn fromCharCode(a, b, c, d, e, f, g, h, i, j, k, l, m, n, o)\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction readOnlyJSString() {\n\tlet token = src[position++]\n\tlet length\n\tif (token < 0xc0) {\n\t\t// fixstr\n\t\tlength = token - 0xa0\n\t} else {\n\t\tswitch(token) {\n\t\t\tcase 0xd9:\n\t\t\t// str 8\n\t\t\t\tlength = src[position++]\n\t\t\t\tbreak\n\t\t\tcase 0xda:\n\t\t\t// str 16\n\t\t\t\tlength = dataView.getUint16(position)\n\t\t\t\tposition += 2\n\t\t\t\tbreak\n\t\t\tcase 0xdb:\n\t\t\t// str 32\n\t\t\t\tlength = dataView.getUint32(position)\n\t\t\t\tposition += 4\n\t\t\t\tbreak\n\t\t\tdefault:\n\t\t\t\tthrow new Error('Expected string')\n\t\t}\n\t}\n\treturn readStringJS(length)\n}\n\n\nfunction readBin(length) {\n\treturn currentUnpackr.copyBuffers ?\n\t\t// specifically use the copying slice (not the node one)\n\t\tUint8Array.prototype.slice.call(src, position, position += length) :\n\t\tsrc.subarray(position, position += length)\n}\nfunction readExt(length) {\n\tlet type = src[position++]\n\tif (currentExtensions[type]) {\n\t\tlet end\n\t\treturn currentExtensions[type](src.subarray(position, end = (position += length)), (readPosition) => {\n\t\t\tposition = readPosition;\n\t\t\ttry {\n\t\t\t\treturn read();\n\t\t\t} finally {\n\t\t\t\tposition = end;\n\t\t\t}\n\t\t})\n\t}\n\telse\n\t\tthrow new Error('Unknown extension type ' + type)\n}\n\nvar keyCache = new Array(4096)\nfunction readKey() {\n\tlet length = src[position++]\n\tif (length >= 0xa0 && length < 0xc0) {\n\t\t// fixstr, potentially use key cache\n\t\tlength = length - 0xa0\n\t\tif (srcStringEnd >= position) // if it has been extracted, must use it (and faster anyway)\n\t\t\treturn srcString.slice(position - srcStringStart, (position += length) - srcStringStart)\n\t\telse if (!(srcStringEnd == 0 && srcEnd < 180))\n\t\t\treturn readFixedString(length)\n\t} else { // not cacheable, go back and do a standard read\n\t\tposition--\n\t\treturn asSafeString(read())\n\t}\n\tlet key = ((length << 5) ^ (length > 1 ? dataView.getUint16(position) : length > 0 ? src[position] : 0)) & 0xfff\n\tlet entry = keyCache[key]\n\tlet checkPosition = position\n\tlet end = position + length - 3\n\tlet chunk\n\tlet i = 0\n\tif (entry && entry.bytes == length) {\n\t\twhile (checkPosition < end) {\n\t\t\tchunk = dataView.getUint32(checkPosition)\n\t\t\tif (chunk != entry[i++]) {\n\t\t\t\tcheckPosition = 0x70000000\n\t\t\t\tbreak\n\t\t\t}\n\t\t\tcheckPosition += 4\n\t\t}\n\t\tend += 3\n\t\twhile (checkPosition < end) {\n\t\t\tchunk = src[checkPosition++]\n\t\t\tif (chunk != entry[i++]) {\n\t\t\t\tcheckPosition = 0x70000000\n\t\t\t\tbreak\n\t\t\t}\n\t\t}\n\t\tif (checkPosition === end) {\n\t\t\tposition = checkPosition\n\t\t\treturn entry.string\n\t\t}\n\t\tend -= 3\n\t\tcheckPosition = position\n\t}\n\tentry = []\n\tkeyCache[key] = entry\n\tentry.bytes = length\n\twhile (checkPosition < end) {\n\t\tchunk = dataView.getUint32(checkPosition)\n\t\tentry.push(chunk)\n\t\tcheckPosition += 4\n\t}\n\tend += 3\n\twhile (checkPosition < end) {\n\t\tchunk = src[checkPosition++]\n\t\tentry.push(chunk)\n\t}\n\t// for small blocks, avoiding the overhead of the extract call is helpful\n\tlet string = length < 16 ? shortStringInJS(length) : longStringInJS(length)\n\tif (string != null)\n\t\treturn entry.string = string\n\treturn entry.string = readFixedString(length)\n}\n\nfunction asSafeString(property) {\n\t// protect against expensive (DoS) string conversions\n\tif (typeof property === 'string') return property;\n\tif (typeof property === 'number' || typeof property === 'boolean' || typeof property === 'bigint') return property.toString();\n\tif (property == null) return property + '';\n\tthrow new Error('Invalid property type for record', typeof property);\n}\n// the registration of the record definition extension (as \"r\")\nconst recordDefinition = (id, highByte) => {\n\tlet structure = read().map(asSafeString) // ensure that all keys are strings and\n\t// that the array is mutable\n\tlet firstByte = id\n\tif (highByte !== undefined) {\n\t\tid = id < 32 ? -((highByte << 5) + id) : ((highByte << 5) + id)\n\t\tstructure.highByte = highByte\n\t}\n\tlet existingStructure = currentStructures[id]\n\t// If it is a shared structure, we need to restore any changes after reading.\n\t// Also in sequential mode, we may get incomplete reads and thus errors, and we need to restore\n\t// to the state prior to an incomplete read in order to properly resume.\n\tif (existingStructure && (existingStructure.isShared || sequentialMode)) {\n\t\t(currentStructures.restoreStructures || (currentStructures.restoreStructures = []))[id] = existingStructure\n\t}\n\tcurrentStructures[id] = structure\n\tstructure.read = createStructureReader(structure, firstByte)\n\treturn structure.read()\n}\ncurrentExtensions[0] = () => {} // notepack defines extension 0 to mean undefined, so use that as the default here\ncurrentExtensions[0].noBuffer = true\n\ncurrentExtensions[0x42] = (data) => {\n\t// decode bigint\n\tlet length = data.length;\n\tlet value = BigInt(data[0] & 0x80 ? data[0] - 0x100 : data[0]);\n\tfor (let i = 1; i < length; i++) {\n\t\tvalue <<= 8n;\n\t\tvalue += BigInt(data[i]);\n\t}\n\treturn value;\n}\n\nlet errors = { Error, TypeError, ReferenceError };\ncurrentExtensions[0x65] = () => {\n\tlet data = read()\n\treturn (errors[data[0]] || Error)(data[1], { cause: data[2] })\n}\n\ncurrentExtensions[0x69] = (data) => {\n\t// id extension (for structured clones)\n\tif (currentUnpackr.structuredClone === false) throw new Error('Structured clone extension is disabled')\n\tlet id = dataView.getUint32(position - 4)\n\tif (!referenceMap)\n\t\treferenceMap = new Map()\n\tlet token = src[position]\n\tlet target\n\t// TODO: handle Maps, Sets, and other types that can cycle; this is complicated, because you potentially need to read\n\t// ahead past references to record structure definitions\n\tif (token >= 0x90 && token < 0xa0 || token == 0xdc || token == 0xdd)\n\t\ttarget = []\n\telse\n\t\ttarget = {}\n\n\tlet refEntry = { target } // a placeholder object\n\treferenceMap.set(id, refEntry)\n\tlet targetProperties = read() // read the next value as the target object to id\n\tif (refEntry.used) // there is a cycle, so we have to assign properties to original target\n\t\treturn Object.assign(target, targetProperties)\n\trefEntry.target = targetProperties // the placeholder wasn't used, replace with the deserialized one\n\treturn targetProperties // no cycle, can just use the returned read object\n}\n\ncurrentExtensions[0x70] = (data) => {\n\t// pointer extension (for structured clones)\n\tif (currentUnpackr.structuredClone === false) throw new Error('Structured clone extension is disabled')\n\tlet id = dataView.getUint32(position - 4)\n\tlet refEntry = referenceMap.get(id)\n\trefEntry.used = true\n\treturn refEntry.target\n}\n\ncurrentExtensions[0x73] = () => new Set(read())\n\nexport const typedArrays = ['Int8','Uint8','Uint8Clamped','Int16','Uint16','Int32','Uint32','Float32','Float64','BigInt64','BigUint64'].map(type => type + 'Array')\n\nlet glbl = typeof globalThis === 'object' ? globalThis : window;\ncurrentExtensions[0x74] = (data) => {\n\tlet typeCode = data[0]\n\tlet typedArrayName = typedArrays[typeCode]\n\tif (!typedArrayName) {\n\t\tif (typeCode === 16) {\n\t\t\tlet ab = new ArrayBuffer(data.length - 1)\n\t\t\tlet u8 = new Uint8Array(ab)\n\t\t\tu8.set(data.subarray(1))\n\t\t\treturn ab;\n\t\t}\n\t\tthrow new Error('Could not find typed array for code ' + typeCode)\n\t}\n\t// we have to always slice/copy here to get a new ArrayBuffer that is word/byte aligned\n\treturn new glbl[typedArrayName](Uint8Array.prototype.slice.call(data, 1).buffer)\n}\ncurrentExtensions[0x78] = () => {\n\tlet data = read()\n\treturn new RegExp(data[0], data[1])\n}\nconst TEMP_BUNDLE = []\ncurrentExtensions[0x62] = (data) => {\n\tlet dataSize = (data[0] << 24) + (data[1] << 16) + (data[2] << 8) + data[3]\n\tlet dataPosition = position\n\tposition += dataSize - data.length\n\tbundledStrings = TEMP_BUNDLE\n\tbundledStrings = [readOnlyJSString(), readOnlyJSString()]\n\tbundledStrings.position0 = 0\n\tbundledStrings.position1 = 0\n\tbundledStrings.postBundlePosition = position\n\tposition = dataPosition\n\treturn read()\n}\n\ncurrentExtensions[0xff] = (data) => {\n\t// 32-bit date extension\n\tif (data.length == 4)\n\t\treturn new Date((data[0] * 0x1000000 + (data[1] << 16) + (data[2] << 8) + data[3]) * 1000)\n\telse if (data.length == 8)\n\t\treturn new Date(\n\t\t\t((data[0] << 22) + (data[1] << 14) + (data[2] << 6) + (data[3] >> 2)) / 1000000 +\n\t\t\t((data[3] & 0x3) * 0x100000000 + data[4] * 0x1000000 + (data[5] << 16) + (data[6] << 8) + data[7]) * 1000)\n\telse if (data.length == 12)// TODO: Implement support for negative\n\t\treturn new Date(\n\t\t\t((data[0] << 24) + (data[1] << 16) + (data[2] << 8) + data[3]) / 1000000 +\n\t\t\t(((data[4] & 0x80) ? -0x1000000000000 : 0) + data[6] * 0x10000000000 + data[7] * 0x100000000 + data[8] * 0x1000000 + (data[9] << 16) + (data[10] << 8) + data[11]) * 1000)\n\telse\n\t\treturn new Date('invalid')\n} // notepack defines extension 0 to mean undefined, so use that as the default here\n// registration of bulk record definition?\n// currentExtensions[0x52] = () =>\n\nfunction saveState(callback) {\n\tif (onSaveState)\n\t\tonSaveState();\n\tlet savedSrcEnd = srcEnd\n\tlet savedPosition = position\n\tlet savedStringPosition = stringPosition\n\tlet savedSrcStringStart = srcStringStart\n\tlet savedSrcStringEnd = srcStringEnd\n\tlet savedSrcString = srcString\n\tlet savedStrings = strings\n\tlet savedReferenceMap = referenceMap\n\tlet savedBundledStrings = bundledStrings\n\n\t// TODO: We may need to revisit this if we do more external calls to user code (since it could be slow)\n\tlet savedSrc = new Uint8Array(src.slice(0, srcEnd)) // we copy the data in case it changes while external data is processed\n\tlet savedStructures = currentStructures\n\tlet savedStructuresContents = currentStructures.slice(0, currentStructures.length)\n\tlet savedPackr = currentUnpackr\n\tlet savedSequentialMode = sequentialMode\n\tlet value = callback()\n\tsrcEnd = savedSrcEnd\n\tposition = savedPosition\n\tstringPosition = savedStringPosition\n\tsrcStringStart = savedSrcStringStart\n\tsrcStringEnd = savedSrcStringEnd\n\tsrcString = savedSrcString\n\tstrings = savedStrings\n\treferenceMap = savedReferenceMap\n\tbundledStrings = savedBundledStrings\n\tsrc = savedSrc\n\tsequentialMode = savedSequentialMode\n\tcurrentStructures = savedStructures\n\tcurrentStructures.splice(0, currentStructures.length, ...savedStructuresContents)\n\tcurrentUnpackr = savedPackr\n\tdataView = new DataView(src.buffer, src.byteOffset, src.byteLength)\n\treturn value\n}\nexport function clearSource() {\n\tsrc = null\n\treferenceMap = null\n\tcurrentStructures = null\n}\n\nexport function addExtension(extension) {\n\tif (extension.unpack)\n\t\tcurrentExtensions[extension.type] = extension.unpack\n\telse\n\t\tcurrentExtensions[extension.type] = extension\n}\n\nexport const mult10 = new Array(147) // this is a table matching binary exponents to the multiplier to determine significant digit rounding\nfor (let i = 0; i < 256; i++) {\n\tmult10[i] = +('1e' + Math.floor(45.15 - i * 0.30103))\n}\nexport const Decoder = Unpackr\nvar defaultUnpackr = new Unpackr({ useRecords: false })\nexport const unpack = defaultUnpackr.unpack\nexport const unpackMultiple = defaultUnpackr.unpackMultiple\nexport const decode = defaultUnpackr.unpack\nexport const FLOAT32_OPTIONS = {\n\tNEVER: 0,\n\tALWAYS: 1,\n\tDECIMAL_ROUND: 3,\n\tDECIMAL_FIT: 4\n}\nlet f32Array = new Float32Array(1)\nlet u8Array = new Uint8Array(f32Array.buffer, 0, 4)\nexport function roundFloat32(float32Number) {\n\tf32Array[0] = float32Number\n\tlet multiplier = mult10[((u8Array[3] & 0x7f) << 1) | (u8Array[2] >> 7)]\n\treturn ((multiplier * float32Number + (float32Number > 0 ? 0.5 : -0.5)) >> 0) / multiplier\n}\nexport function setReadStruct(updatedReadStruct, loadedStructs, saveState) {\n\treadStruct = updatedReadStruct;\n\tonLoadedStructures = loadedStructs;\n\tonSaveState = saveState;\n}\n","import { Unpackr, mult10, C1Type, typedArrays, addExtension as unpackAddExtension } from './unpack.js'\nlet textEncoder\ntry {\n\ttextEncoder = new TextEncoder()\n} catch (error) {}\nlet extensions, extensionClasses\nconst hasNodeBuffer = typeof Buffer !== 'undefined'\nconst ByteArrayAllocate = hasNodeBuffer ?\n\tfunction(length) { return Buffer.allocUnsafeSlow(length) } : Uint8Array\nconst ByteArray = hasNodeBuffer ? Buffer : Uint8Array\nconst MAX_BUFFER_SIZE = hasNodeBuffer ? 0x100000000 : 0x7fd00000\nlet target, keysTarget\nlet targetView\nlet position = 0\nlet safeEnd\nlet bundledStrings = null\nlet writeStructSlots\nconst MAX_BUNDLE_SIZE = 0x5500 // maximum characters such that the encoded bytes fits in 16 bits.\nconst hasNonLatin = /[\\u0080-\\uFFFF]/\nexport const RECORD_SYMBOL = Symbol('record-id')\nexport class Packr extends Unpackr {\n\tconstructor(options) {\n\t\tsuper(options)\n\t\tthis.offset = 0\n\t\tlet typeBuffer\n\t\tlet start\n\t\tlet hasSharedUpdate\n\t\tlet structures\n\t\tlet referenceMap\n\t\tlet encodeUtf8 = ByteArray.prototype.utf8Write ? function(string, position) {\n\t\t\treturn target.utf8Write(string, position, 0xffffffff)\n\t\t} : (textEncoder && textEncoder.encodeInto) ?\n\t\t\tfunction(string, position) {\n\t\t\t\treturn textEncoder.encodeInto(string, target.subarray(position)).written\n\t\t\t} : false\n\n\t\tlet packr = this\n\t\tif (!options)\n\t\t\toptions = {}\n\t\tlet isSequential = options && options.sequential\n\t\tlet hasSharedStructures = options.structures || options.saveStructures\n\t\tlet maxSharedStructures = options.maxSharedStructures\n\t\tif (maxSharedStructures == null)\n\t\t\tmaxSharedStructures = hasSharedStructures ? 32 : 0\n\t\tif (maxSharedStructures > 8160)\n\t\t\tthrow new Error('Maximum maxSharedStructure is 8160')\n\t\tif (options.structuredClone && options.moreTypes == undefined) {\n\t\t\tthis.moreTypes = true\n\t\t}\n\t\tlet maxOwnStructures = options.maxOwnStructures\n\t\tif (maxOwnStructures == null)\n\t\t\tmaxOwnStructures = hasSharedStructures ? 32 : 64\n\t\tif (!this.structures && options.useRecords != false)\n\t\t\tthis.structures = []\n\t\t// two byte record ids for shared structures\n\t\tlet useTwoByteRecords = maxSharedStructures > 32 || (maxOwnStructures + maxSharedStructures > 64)\n\t\tlet sharedLimitId = maxSharedStructures + 0x40\n\t\tlet maxStructureId = maxSharedStructures + maxOwnStructures + 0x40\n\t\tif (maxStructureId > 8256) {\n\t\t\tthrow new Error('Maximum maxSharedStructure + maxOwnStructure is 8192')\n\t\t}\n\t\tlet recordIdsToRemove = []\n\t\tlet transitionsCount = 0\n\t\tlet serializationsSinceTransitionRebuild = 0\n\n\t\tthis.pack = this.encode = function(value, encodeOptions) {\n\t\t\tif (!target) {\n\t\t\t\ttarget = new ByteArrayAllocate(8192)\n\t\t\t\ttargetView = target.dataView || (target.dataView = new DataView(target.buffer, 0, 8192))\n\t\t\t\tposition = 0\n\t\t\t}\n\t\t\tsafeEnd = target.length - 10\n\t\t\tif (safeEnd - position < 0x800) {\n\t\t\t\t// don't start too close to the end,\n\t\t\t\ttarget = new ByteArrayAllocate(target.length)\n\t\t\t\ttargetView = target.dataView || (target.dataView = new DataView(target.buffer, 0, target.length))\n\t\t\t\tsafeEnd = target.length - 10\n\t\t\t\tposition = 0\n\t\t\t} else\n\t\t\t\tposition = (position + 7) & 0x7ffffff8 // Word align to make any future copying of this buffer faster\n\t\t\tstart = position\n\t\t\tif (encodeOptions & RESERVE_START_SPACE) position += (encodeOptions & 0xff)\n\t\t\treferenceMap = packr.structuredClone ? new Map() : null\n\t\t\tif (packr.bundleStrings && typeof value !== 'string') {\n\t\t\t\tbundledStrings = []\n\t\t\t\tbundledStrings.size = Infinity // force a new bundle start on first string\n\t\t\t} else\n\t\t\t\tbundledStrings = null\n\t\t\tstructures = packr.structures\n\t\t\tif (structures) {\n\t\t\t\tif (structures.uninitialized)\n\t\t\t\t\tstructures = packr._mergeStructures(packr.getStructures())\n\t\t\t\tlet sharedLength = structures.sharedLength || 0\n\t\t\t\tif (sharedLength > maxSharedStructures) {\n\t\t\t\t\t//if (maxSharedStructures <= 32 && structures.sharedLength > 32) // TODO: could support this, but would need to update the limit ids\n\t\t\t\t\tthrow new Error('Shared structures is larger than maximum shared structures, try increasing maxSharedStructures to ' + structures.sharedLength)\n\t\t\t\t}\n\t\t\t\tif (!structures.transitions) {\n\t\t\t\t\t// rebuild our structure transitions\n\t\t\t\t\tstructures.transitions = Object.create(null)\n\t\t\t\t\tfor (let i = 0; i < sharedLength; i++) {\n\t\t\t\t\t\tlet keys = structures[i]\n\t\t\t\t\t\tif (!keys)\n\t\t\t\t\t\t\tcontinue\n\t\t\t\t\t\tlet nextTransition, transition = structures.transitions\n\t\t\t\t\t\tfor (let j = 0, l = keys.length; j < l; j++) {\n\t\t\t\t\t\t\tlet key = keys[j]\n\t\t\t\t\t\t\tnextTransition = transition[key]\n\t\t\t\t\t\t\tif (!nextTransition) {\n\t\t\t\t\t\t\t\tnextTransition = transition[key] = Object.create(null)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\ttransition = nextTransition\n\t\t\t\t\t\t}\n\t\t\t\t\t\ttransition[RECORD_SYMBOL] = i + 0x40\n\t\t\t\t\t}\n\t\t\t\t\tthis.lastNamedStructuresLength = sharedLength\n\t\t\t\t}\n\t\t\t\tif (!isSequential) {\n\t\t\t\t\tstructures.nextId = sharedLength + 0x40\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (hasSharedUpdate)\n\t\t\t\thasSharedUpdate = false\n\t\t\tlet encodingError;\n\t\t\ttry {\n\t\t\t\tif (packr.randomAccessStructure && value && value.constructor && value.constructor === Object)\n\t\t\t\t\twriteStruct(value);\n\t\t\t\telse\n\t\t\t\t\tpack(value)\n\t\t\t\tlet lastBundle = bundledStrings;\n\t\t\t\tif (bundledStrings)\n\t\t\t\t\twriteBundles(start, pack, 0)\n\t\t\t\tif (referenceMap && referenceMap.idsToInsert) {\n\t\t\t\t\tlet idsToInsert = referenceMap.idsToInsert.sort((a, b) => a.offset > b.offset ? 1 : -1);\n\t\t\t\t\tlet i = idsToInsert.length;\n\t\t\t\t\tlet incrementPosition = -1;\n\t\t\t\t\twhile (lastBundle && i > 0) {\n\t\t\t\t\t\tlet insertionPoint = idsToInsert[--i].offset + start;\n\t\t\t\t\t\tif (insertionPoint < (lastBundle.stringsPosition + start) && incrementPosition === -1)\n\t\t\t\t\t\t\tincrementPosition = 0;\n\t\t\t\t\t\tif (insertionPoint > (lastBundle.position + start)) {\n\t\t\t\t\t\t\tif (incrementPosition >= 0)\n\t\t\t\t\t\t\t\tincrementPosition += 6;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tif (incrementPosition >= 0) {\n\t\t\t\t\t\t\t\t// update the bundle reference now\n\t\t\t\t\t\t\t\ttargetView.setUint32(lastBundle.position + start,\n\t\t\t\t\t\t\t\t\ttargetView.getUint32(lastBundle.position + start) + incrementPosition)\n\t\t\t\t\t\t\t\tincrementPosition = -1; // reset\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tlastBundle = lastBundle.previous;\n\t\t\t\t\t\t\ti++;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif (incrementPosition >= 0 && lastBundle) {\n\t\t\t\t\t\t// update the bundle reference now\n\t\t\t\t\t\ttargetView.setUint32(lastBundle.position + start,\n\t\t\t\t\t\t\ttargetView.getUint32(lastBundle.position + start) + incrementPosition)\n\t\t\t\t\t}\n\t\t\t\t\tposition += idsToInsert.length * 6;\n\t\t\t\t\tif (position > safeEnd)\n\t\t\t\t\t\tmakeRoom(position)\n\t\t\t\t\tpackr.offset = position\n\t\t\t\t\tlet serialized = insertIds(target.subarray(start, position), idsToInsert)\n\t\t\t\t\treferenceMap = null\n\t\t\t\t\treturn serialized\n\t\t\t\t}\n\t\t\t\tpackr.offset = position // update the offset so next serialization doesn't write over our buffer, but can continue writing to same buffer sequentially\n\t\t\t\tif (encodeOptions & REUSE_BUFFER_MODE) {\n\t\t\t\t\ttarget.start = start\n\t\t\t\t\ttarget.end = position\n\t\t\t\t\treturn target\n\t\t\t\t}\n\t\t\t\treturn target.subarray(start, position) // position can change if we call pack again in saveStructures, so we get the buffer now\n\t\t\t} catch(error) {\n\t\t\t\tencodingError = error;\n\t\t\t\tthrow error;\n\t\t\t} finally {\n\t\t\t\tif (structures) {\n\t\t\t\t\tresetStructures();\n\t\t\t\t\tif (hasSharedUpdate && packr.saveStructures) {\n\t\t\t\t\t\tlet sharedLength = structures.sharedLength || 0\n\t\t\t\t\t\t// we can't rely on start/end with REUSE_BUFFER_MODE since they will (probably) change when we save\n\t\t\t\t\t\tlet returnBuffer = target.subarray(start, position)\n\t\t\t\t\t\tlet newSharedData = prepareStructures(structures, packr);\n\t\t\t\t\t\tif (!encodingError) { // TODO: If there is an encoding error, should make the structures as uninitialized so they get rebuilt next time\n\t\t\t\t\t\t\tif (packr.saveStructures(newSharedData, newSharedData.isCompatible) === false) {\n\t\t\t\t\t\t\t\t// get updated structures and try again if the update failed\n\t\t\t\t\t\t\t\treturn packr.pack(value, encodeOptions)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tpackr.lastNamedStructuresLength = sharedLength\n\t\t\t\t\t\t\t// don't keep large buffers around\n\t\t\t\t\t\t\tif (target.length > 0x40000000) target = null\n\t\t\t\t\t\t\treturn returnBuffer\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t// don't keep large buffers around, they take too much memory and cause problems (limit at 1GB)\n\t\t\t\tif (target.length > 0x40000000) target = null\n\t\t\t\tif (encodeOptions & RESET_BUFFER_MODE)\n\t\t\t\t\tposition = start\n\t\t\t}\n\t\t}\n\t\tconst resetStructures = () => {\n\t\t\tif (serializationsSinceTransitionRebuild < 10)\n\t\t\t\tserializationsSinceTransitionRebuild++\n\t\t\tlet sharedLength = structures.sharedLength || 0\n\t\t\tif (structures.length > sharedLength && !isSequential)\n\t\t\t\tstructures.length = sharedLength\n\t\t\tif (transitionsCount > 10000) {\n\t\t\t\t// force a rebuild occasionally after a lot of transitions so it can get cleaned up\n\t\t\t\tstructures.transitions = null\n\t\t\t\tserializationsSinceTransitionRebuild = 0\n\t\t\t\ttransitionsCount = 0\n\t\t\t\tif (recordIdsToRemove.length > 0)\n\t\t\t\t\trecordIdsToRemove = []\n\t\t\t} else if (recordIdsToRemove.length > 0 && !isSequential) {\n\t\t\t\tfor (let i = 0, l = recordIdsToRemove.length; i < l; i++) {\n\t\t\t\t\trecordIdsToRemove[i][RECORD_SYMBOL] = 0\n\t\t\t\t}\n\t\t\t\trecordIdsToRemove = []\n\t\t\t}\n\t\t}\n\t\tconst packArray = (value) => {\n\t\t\tvar length = value.length\n\t\t\tif (length < 0x10) {\n\t\t\t\ttarget[position++] = 0x90 | length\n\t\t\t} else if (length < 0x10000) {\n\t\t\t\ttarget[position++] = 0xdc\n\t\t\t\ttarget[position++] = length >> 8\n\t\t\t\ttarget[position++] = length & 0xff\n\t\t\t} else {\n\t\t\t\ttarget[position++] = 0xdd\n\t\t\t\ttargetView.setUint32(position, length)\n\t\t\t\tposition += 4\n\t\t\t}\n\t\t\tfor (let i = 0; i < length; i++) {\n\t\t\t\tpack(value[i])\n\t\t\t}\n\t\t}\n\t\tconst pack = (value) => {\n\t\t\tif (position > safeEnd)\n\t\t\t\ttarget = makeRoom(position)\n\n\t\t\tvar type = typeof value\n\t\t\tvar length\n\t\t\tif (type === 'string') {\n\t\t\t\tlet strLength = value.length\n\t\t\t\tif (bundledStrings && strLength >= 4 && strLength < 0x1000) {\n\t\t\t\t\tif ((bundledStrings.size += strLength) > MAX_BUNDLE_SIZE) {\n\t\t\t\t\t\tlet extStart\n\t\t\t\t\t\tlet maxBytes = (bundledStrings[0] ? bundledStrings[0].length * 3 + bundledStrings[1].length : 0) + 10\n\t\t\t\t\t\tif (position + maxBytes > safeEnd)\n\t\t\t\t\t\t\ttarget = makeRoom(position + maxBytes)\n\t\t\t\t\t\tlet lastBundle\n\t\t\t\t\t\tif (bundledStrings.position) { // here we use the 0x62 extension to write the last bundle and reserve space for the reference pointer to the next/current bundle\n\t\t\t\t\t\t\tlastBundle = bundledStrings\n\t\t\t\t\t\t\ttarget[position] = 0xc8 // ext 16\n\t\t\t\t\t\t\tposition += 3 // reserve for the writing bundle size\n\t\t\t\t\t\t\ttarget[position++] = 0x62 // 'b'\n\t\t\t\t\t\t\textStart = position - start\n\t\t\t\t\t\t\tposition += 4 // reserve for writing bundle reference\n\t\t\t\t\t\t\twriteBundles(start, pack, 0) // write the last bundles\n\t\t\t\t\t\t\ttargetView.setUint16(extStart + start - 3, position - start - extStart)\n\t\t\t\t\t\t} else { // here we use the 0x62 extension just to reserve the space for the reference pointer to the bundle (will be updated once the bundle is written)\n\t\t\t\t\t\t\ttarget[position++] = 0xd6 // fixext 4\n\t\t\t\t\t\t\ttarget[position++] = 0x62 // 'b'\n\t\t\t\t\t\t\textStart = position - start\n\t\t\t\t\t\t\tposition += 4 // reserve for writing bundle reference\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbundledStrings = ['', ''] // create new ones\n\t\t\t\t\t\tbundledStrings.previous = lastBundle;\n\t\t\t\t\t\tbundledStrings.size = 0\n\t\t\t\t\t\tbundledStrings.position = extStart\n\t\t\t\t\t}\n\t\t\t\t\tlet twoByte = hasNonLatin.test(value)\n\t\t\t\t\tbundledStrings[twoByte ? 0 : 1] += value\n\t\t\t\t\ttarget[position++] = 0xc1\n\t\t\t\t\tpack(twoByte ? -strLength : strLength);\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\tlet headerSize\n\t\t\t\t// first we estimate the header size, so we can write to the correct location\n\t\t\t\tif (strLength < 0x20) {\n\t\t\t\t\theaderSize = 1\n\t\t\t\t} else if (strLength < 0x100) {\n\t\t\t\t\theaderSize = 2\n\t\t\t\t} else if (strLength < 0x10000) {\n\t\t\t\t\theaderSize = 3\n\t\t\t\t} else {\n\t\t\t\t\theaderSize = 5\n\t\t\t\t}\n\t\t\t\tlet maxBytes = strLength * 3\n\t\t\t\tif (position + maxBytes > safeEnd)\n\t\t\t\t\ttarget = makeRoom(position + maxBytes)\n\n\t\t\t\tif (strLength < 0x40 || !encodeUtf8) {\n\t\t\t\t\tlet i, c1, c2, strPosition = position + headerSize\n\t\t\t\t\tfor (i = 0; i < strLength; i++) {\n\t\t\t\t\t\tc1 = value.charCodeAt(i)\n\t\t\t\t\t\tif (c1 < 0x80) {\n\t\t\t\t\t\t\ttarget[strPosition++] = c1\n\t\t\t\t\t\t} else if (c1 < 0x800) {\n\t\t\t\t\t\t\ttarget[strPosition++] = c1 >> 6 | 0xc0\n\t\t\t\t\t\t\ttarget[strPosition++] = c1 & 0x3f | 0x80\n\t\t\t\t\t\t} else if (\n\t\t\t\t\t\t\t(c1 & 0xfc00) === 0xd800 &&\n\t\t\t\t\t\t\t((c2 = value.charCodeAt(i + 1)) & 0xfc00) === 0xdc00\n\t\t\t\t\t\t) {\n\t\t\t\t\t\t\tc1 = 0x10000 + ((c1 & 0x03ff) << 10) + (c2 & 0x03ff)\n\t\t\t\t\t\t\ti++\n\t\t\t\t\t\t\ttarget[strPosition++] = c1 >> 18 | 0xf0\n\t\t\t\t\t\t\ttarget[strPosition++] = c1 >> 12 & 0x3f | 0x80\n\t\t\t\t\t\t\ttarget[strPosition++] = c1 >> 6 & 0x3f | 0x80\n\t\t\t\t\t\t\ttarget[strPosition++] = c1 & 0x3f | 0x80\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\ttarget[strPosition++] = c1 >> 12 | 0xe0\n\t\t\t\t\t\t\ttarget[strPosition++] = c1 >> 6 & 0x3f | 0x80\n\t\t\t\t\t\t\ttarget[strPosition++] = c1 & 0x3f | 0x80\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tlength = strPosition - position - headerSize\n\t\t\t\t} else {\n\t\t\t\t\tlength = encodeUtf8(value, position + headerSize)\n\t\t\t\t}\n\n\t\t\t\tif (length < 0x20) {\n\t\t\t\t\ttarget[position++] = 0xa0 | length\n\t\t\t\t} else if (length < 0x100) {\n\t\t\t\t\tif (headerSize < 2) {\n\t\t\t\t\t\ttarget.copyWithin(position + 2, position + 1, position + 1 + length)\n\t\t\t\t\t}\n\t\t\t\t\ttarget[position++] = 0xd9\n\t\t\t\t\ttarget[position++] = length\n\t\t\t\t} else if (length < 0x10000) {\n\t\t\t\t\tif (headerSize < 3) {\n\t\t\t\t\t\ttarget.copyWithin(position + 3, position + 2, position + 2 + length)\n\t\t\t\t\t}\n\t\t\t\t\ttarget[position++] = 0xda\n\t\t\t\t\ttarget[position++] = length >> 8\n\t\t\t\t\ttarget[position++] = length & 0xff\n\t\t\t\t} else {\n\t\t\t\t\tif (headerSize < 5) {\n\t\t\t\t\t\ttarget.copyWithin(position + 5, position + 3, position + 3 + length)\n\t\t\t\t\t}\n\t\t\t\t\ttarget[position++] = 0xdb\n\t\t\t\t\ttargetView.setUint32(position, length)\n\t\t\t\t\tposition += 4\n\t\t\t\t}\n\t\t\t\tposition += length\n\t\t\t} else if (type === 'number') {\n\t\t\t\tif (value >>> 0 === value) {// positive integer, 32-bit or less\n\t\t\t\t\t// positive uint\n\t\t\t\t\tif (value < 0x20 || (value < 0x80 && this.useRecords === false) || (value < 0x40 && !this.randomAccessStructure)) {\n\t\t\t\t\t\ttarget[position++] = value\n\t\t\t\t\t} else if (value < 0x100) {\n\t\t\t\t\t\ttarget[position++] = 0xcc\n\t\t\t\t\t\ttarget[position++] = value\n\t\t\t\t\t} else if (value < 0x10000) {\n\t\t\t\t\t\ttarget[position++] = 0xcd\n\t\t\t\t\t\ttarget[position++] = value >> 8\n\t\t\t\t\t\ttarget[position++] = value & 0xff\n\t\t\t\t\t} else {\n\t\t\t\t\t\ttarget[position++] = 0xce\n\t\t\t\t\t\ttargetView.setUint32(position, value)\n\t\t\t\t\t\tposition += 4\n\t\t\t\t\t}\n\t\t\t\t} else if (value >> 0 === value) { // negative integer\n\t\t\t\t\tif (value >= -0x20) {\n\t\t\t\t\t\ttarget[position++] = 0x100 + value\n\t\t\t\t\t} else if (value >= -0x80) {\n\t\t\t\t\t\ttarget[position++] = 0xd0\n\t\t\t\t\t\ttarget[position++] = value + 0x100\n\t\t\t\t\t} else if (value >= -0x8000) {\n\t\t\t\t\t\ttarget[position++] = 0xd1\n\t\t\t\t\t\ttargetView.setInt16(position, value)\n\t\t\t\t\t\tposition += 2\n\t\t\t\t\t} else {\n\t\t\t\t\t\ttarget[position++] = 0xd2\n\t\t\t\t\t\ttargetView.setInt32(position, value)\n\t\t\t\t\t\tposition += 4\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tlet useFloat32\n\t\t\t\t\tif ((useFloat32 = this.useFloat32) > 0 && value < 0x100000000 && value >= -0x80000000) {\n\t\t\t\t\t\ttarget[position++] = 0xca\n\t\t\t\t\t\ttargetView.setFloat32(position, value)\n\t\t\t\t\t\tlet xShifted\n\t\t\t\t\t\tif (useFloat32 < 4 ||\n\t\t\t\t\t\t\t\t// this checks for rounding of numbers that were encoded in 32-bit float to nearest significant decimal digit that could be preserved\n\t\t\t\t\t\t\t\t((xShifted = value * mult10[((target[position] & 0x7f) << 1) | (target[position + 1] >> 7)]) >> 0) === xShifted) {\n\t\t\t\t\t\t\tposition += 4\n\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t} else\n\t\t\t\t\t\t\tposition-- // move back into position for writing a double\n\t\t\t\t\t}\n\t\t\t\t\ttarget[position++] = 0xcb\n\t\t\t\t\ttargetView.setFloat64(position, value)\n\t\t\t\t\tposition += 8\n\t\t\t\t}\n\t\t\t} else if (type === 'object' || type === 'function') {\n\t\t\t\tif (!value)\n\t\t\t\t\ttarget[position++] = 0xc0\n\t\t\t\telse {\n\t\t\t\t\tif (referenceMap) {\n\t\t\t\t\t\tlet referee = referenceMap.get(value)\n\t\t\t\t\t\tif (referee) {\n\t\t\t\t\t\t\tif (!referee.id) {\n\t\t\t\t\t\t\t\tlet idsToInsert = referenceMap.idsToInsert || (referenceMap.idsToInsert = [])\n\t\t\t\t\t\t\t\treferee.id = idsToInsert.push(referee)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\ttarget[position++] = 0xd6 // fixext 4\n\t\t\t\t\t\t\ttarget[position++] = 0x70 // \"p\" for pointer\n\t\t\t\t\t\t\ttargetView.setUint32(position, referee.id)\n\t\t\t\t\t\t\tposition += 4\n\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t} else\n\t\t\t\t\t\t\treferenceMap.set(value, { offset: position - start })\n\t\t\t\t\t}\n\t\t\t\t\tlet constructor = value.constructor\n\t\t\t\t\tif (constructor === Object) {\n\t\t\t\t\t\twriteObject(value)\n\t\t\t\t\t} else if (constructor === Array) {\n\t\t\t\t\t\tpackArray(value)\n\t\t\t\t\t} else if (constructor === Map) {\n\t\t\t\t\t\tif (this.mapAsEmptyObject) target[position++] = 0x80\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tlength = value.size\n\t\t\t\t\t\t\tif (length < 0x10) {\n\t\t\t\t\t\t\t\ttarget[position++] = 0x80 | length\n\t\t\t\t\t\t\t} else if (length < 0x10000) {\n\t\t\t\t\t\t\t\ttarget[position++] = 0xde\n\t\t\t\t\t\t\t\ttarget[position++] = length >> 8\n\t\t\t\t\t\t\t\ttarget[position++] = length & 0xff\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\ttarget[position++] = 0xdf\n\t\t\t\t\t\t\t\ttargetView.setUint32(position, length)\n\t\t\t\t\t\t\t\tposition += 4\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tfor (let [key, entryValue] of value) {\n\t\t\t\t\t\t\t\tpack(key)\n\t\t\t\t\t\t\t\tpack(entryValue)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tfor (let i = 0, l = extensions.length; i < l; i++) {\n\t\t\t\t\t\t\tlet extensionClass = extensionClasses[i]\n\t\t\t\t\t\t\tif (value instanceof extensionClass) {\n\t\t\t\t\t\t\t\tlet extension = extensions[i]\n\t\t\t\t\t\t\t\tif (extension.write) {\n\t\t\t\t\t\t\t\t\tif (extension.type) {\n\t\t\t\t\t\t\t\t\t\ttarget[position++] = 0xd4 // one byte \"tag\" extension\n\t\t\t\t\t\t\t\t\t\ttarget[position++] = extension.type\n\t\t\t\t\t\t\t\t\t\ttarget[position++] = 0\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tlet writeResult = extension.write.call(this, value)\n\t\t\t\t\t\t\t\t\tif (writeResult === value) { // avoid infinite recursion\n\t\t\t\t\t\t\t\t\t\tif (Array.isArray(value)) {\n\t\t\t\t\t\t\t\t\t\t\tpackArray(value)\n\t\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t\twriteObject(value)\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\tpack(writeResult)\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tlet currentTarget = target\n\t\t\t\t\t\t\t\tlet currentTargetView = targetView\n\t\t\t\t\t\t\t\tlet currentPosition = position\n\t\t\t\t\t\t\t\ttarget = null\n\t\t\t\t\t\t\t\tlet result\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tresult = extension.pack.call(this, value, (size) => {\n\t\t\t\t\t\t\t\t\t\t// restore target and use it\n\t\t\t\t\t\t\t\t\t\ttarget = currentTarget\n\t\t\t\t\t\t\t\t\t\tcurrentTarget = null\n\t\t\t\t\t\t\t\t\t\tposition += size\n\t\t\t\t\t\t\t\t\t\tif (position > safeEnd)\n\t\t\t\t\t\t\t\t\t\t\tmakeRoom(position)\n\t\t\t\t\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\t\t\t\t\ttarget, targetView, position: position - size\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}, pack)\n\t\t\t\t\t\t\t\t} finally {\n\t\t\t\t\t\t\t\t\t// restore current target information (unless already restored)\n\t\t\t\t\t\t\t\t\tif (currentTarget) {\n\t\t\t\t\t\t\t\t\t\ttarget = currentTarget\n\t\t\t\t\t\t\t\t\t\ttargetView = currentTargetView\n\t\t\t\t\t\t\t\t\t\tposition = currentPosition\n\t\t\t\t\t\t\t\t\t\tsafeEnd = target.length - 10\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tif (result) {\n\t\t\t\t\t\t\t\t\tif (result.length + position > safeEnd)\n\t\t\t\t\t\t\t\t\t\tmakeRoom(result.length + position)\n\t\t\t\t\t\t\t\t\tposition = writeExtensionData(result, target, position, extension.type)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// check isArray after extensions, because extensions can extend Array\n\t\t\t\t\t\tif (Array.isArray(value)) {\n\t\t\t\t\t\t\tpackArray(value)\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// use this as an alternate mechanism for expressing how to serialize\n\t\t\t\t\t\t\tif (value.toJSON) {\n\t\t\t\t\t\t\t\tconst json = value.toJSON()\n\t\t\t\t\t\t\t\t// if for some reason value.toJSON returns itself it'll loop forever\n\t\t\t\t\t\t\t\tif (json !== value)\n\t\t\t\t\t\t\t\t\treturn pack(json)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// if there is a writeFunction, use it, otherwise just encode as undefined\n\t\t\t\t\t\t\tif (type === 'function')\n\t\t\t\t\t\t\t\treturn pack(this.writeFunction && this.writeFunction(value));\n\n\t\t\t\t\t\t\t// no extension found, write as plain object\n\t\t\t\t\t\t\twriteObject(value)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (type === 'boolean') {\n\t\t\t\ttarget[position++] = value ? 0xc3 : 0xc2\n\t\t\t} else if (type === 'bigint') {\n\t\t\t\tif (value < (BigInt(1)<<BigInt(63)) && value >= -(BigInt(1)<<BigInt(63))) {\n\t\t\t\t\t// use a signed int as long as it fits\n\t\t\t\t\ttarget[position++] = 0xd3\n\t\t\t\t\ttargetView.setBigInt64(position, value)\n\t\t\t\t} else if (value < (BigInt(1)<<BigInt(64)) && value > 0) {\n\t\t\t\t\t// if we can fit an unsigned int, use that\n\t\t\t\t\ttarget[position++] = 0xcf\n\t\t\t\t\ttargetView.setBigUint64(position, value)\n\t\t\t\t} else {\n\t\t\t\t\t// overflow\n\t\t\t\t\tif (this.largeBigIntToFloat) {\n\t\t\t\t\t\ttarget[position++] = 0xcb\n\t\t\t\t\t\ttargetView.setFloat64(position, Number(value))\n\t\t\t\t\t} else if (this.useBigIntExtension && value < 2n**(1023n) && value > -(2n**(1023n))) {\n\t\t\t\t\t\ttarget[position++] = 0xc7\n\t\t\t\t\t\tposition++;\n\t\t\t\t\t\ttarget[position++] = 0x42 // \"B\" for BigInt\n\t\t\t\t\t\tlet bytes = [];\n\t\t\t\t\t\tlet alignedSign;\n\t\t\t\t\t\tdo {\n\t\t\t\t\t\t\tlet byte = value & 0xffn;\n\t\t\t\t\t\t\talignedSign = (byte & 0x80n) === (value < 0n ? 0x80n : 0n);\n\t\t\t\t\t\t\tbytes.push(byte);\n\t\t\t\t\t\t\tvalue >>= 8n;\n\t\t\t\t\t\t} while (!((value === 0n || value === -1n) && alignedSign));\n\t\t\t\t\t\ttarget[position-2] = bytes.length;\n\t\t\t\t\t\tfor (let i = bytes.length; i > 0;) {\n\t\t\t\t\t\t\ttarget[position++] = Number(bytes[--i]);\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthrow new RangeError(value + ' was too large to fit in MessagePack 64-bit integer format, use' +\n\t\t\t\t\t\t\t' useBigIntExtension or set largeBigIntToFloat to convert to float-64')\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tposition += 8\n\t\t\t} else if (type === 'undefined') {\n\t\t\t\tif (this.encodeUndefinedAsNil)\n\t\t\t\t\ttarget[position++] = 0xc0\n\t\t\t\telse {\n\t\t\t\t\ttarget[position++] = 0xd4 // a number of implementations use fixext1 with type 0, data 0 to denote undefined, so we follow suite\n\t\t\t\t\ttarget[position++] = 0\n\t\t\t\t\ttarget[position++] = 0\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthrow new Error('Unknown type: ' + type)\n\t\t\t}\n\t\t}\n\n\t\tconst writePlainObject = (this.variableMapSize || this.coercibleKeyAsNumber || this.skipValues) ? (object) => {\n\t\t\t// this method is slightly slower, but generates \"preferred serialization\" (optimally small for smaller objects)\n\t\t\tlet keys;\n\t\t\tif (this.skipValues) {\n\t\t\t\tkeys = [];\n\t\t\t\tfor (let key in object) {\n\t\t\t\t\tif ((typeof object.hasOwnProperty !== 'function' || object.hasOwnProperty(key)) &&\n\t\t\t\t\t\t!this.skipValues.includes(object[key]))\n\t\t\t\t\t\tkeys.push(key);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tkeys = Object.keys(object)\n\t\t\t}\n\t\t\tlet length = keys.length\n\t\t\tif (length < 0x10) {\n\t\t\t\ttarget[position++] = 0x80 | length\n\t\t\t} else if (length < 0x10000) {\n\t\t\t\ttarget[position++] = 0xde\n\t\t\t\ttarget[position++] = length >> 8\n\t\t\t\ttarget[position++] = length & 0xff\n\t\t\t} else {\n\t\t\t\ttarget[position++] = 0xdf\n\t\t\t\ttargetView.setUint32(position, length)\n\t\t\t\tposition += 4\n\t\t\t}\n\t\t\tlet key\n\t\t\tif (this.coercibleKeyAsNumber) {\n\t\t\t\tfor (let i = 0; i < length; i++) {\n\t\t\t\t\tkey = keys[i]\n\t\t\t\t\tlet num = Number(key)\n\t\t\t\t\tpack(isNaN(num) ? key : num)\n\t\t\t\t\tpack(object[key])\n\t\t\t\t}\n\n\t\t\t} else {\n\t\t\t\tfor (let i = 0; i < length; i++) {\n\t\t\t\t\tpack(key = keys[i])\n\t\t\t\t\tpack(object[key])\n\t\t\t\t}\n\t\t\t}\n\t\t} :\n\t\t(object) => {\n\t\t\ttarget[position++] = 0xde // always using map 16, so we can preallocate and set the length afterwards\n\t\t\tlet objectOffset = position - start\n\t\t\tposition += 2\n\t\t\tlet size = 0\n\t\t\tfor (let key in object) {\n\t\t\t\tif (typeof object.hasOwnProperty !== 'function' || object.hasOwnProperty(key)) {\n\t\t\t\t\tpack(key)\n\t\t\t\t\tpack(object[key])\n\t\t\t\t\tsize++\n\t\t\t\t}\n\t\t\t}\n\t\t\ttarget[objectOffset++ + start] = size >> 8\n\t\t\ttarget[objectOffset + start] = size & 0xff\n\t\t}\n\n\t\tconst writeRecord = this.useRecords === false ? writePlainObject :\n\t\t(options.progressiveRecords && !useTwoByteRecords) ? // this is about 2% faster for highly stable structures, since it only requires one for-in loop (but much more expensive when new structure needs to be written)\n\t\t(object) => {\n\t\t\tlet nextTransition, transition = structures.transitions || (structures.transitions = Object.create(null))\n\t\t\tlet objectOffset = position++ - start\n\t\t\tlet wroteKeys\n\t\t\tfor (let key in object) {\n\t\t\t\tif (typeof object.hasOwnProperty !== 'function' || object.hasOwnProperty(key)) {\n\t\t\t\t\tnextTransition = transition[key]\n\t\t\t\t\tif (nextTransition)\n\t\t\t\t\t\ttransition = nextTransition\n\t\t\t\t\telse {\n\t\t\t\t\t\t// record doesn't exist, create full new record and insert it\n\t\t\t\t\t\tlet keys = Object.keys(object)\n\t\t\t\t\t\tlet lastTransition = transition\n\t\t\t\t\t\ttransition = structures.transitions\n\t\t\t\t\t\tlet newTransitions = 0\n\t\t\t\t\t\tfor (let i = 0, l = keys.length; i < l; i++) {\n\t\t\t\t\t\t\tlet key = keys[i]\n\t\t\t\t\t\t\tnextTransition = transition[key]\n\t\t\t\t\t\t\tif (!nextTransition) {\n\t\t\t\t\t\t\t\tnextTransition = transition[key] = Object.create(null)\n\t\t\t\t\t\t\t\tnewTransitions++\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\ttransition = nextTransition\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (objectOffset + start + 1 == position) {\n\t\t\t\t\t\t\t// first key, so we don't need to insert, we can just write record directly\n\t\t\t\t\t\t\tposition--\n\t\t\t\t\t\t\tnewRecord(transition, keys, newTransitions)\n\t\t\t\t\t\t} else // otherwise we need to insert the record, moving existing data after the record\n\t\t\t\t\t\t\tinsertNewRecord(transition, keys, objectOffset, newTransitions)\n\t\t\t\t\t\twroteKeys = true\n\t\t\t\t\t\ttransition = lastTransition[key]\n\t\t\t\t\t}\n\t\t\t\t\tpack(object[key])\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!wroteKeys) {\n\t\t\t\tlet recordId = transition[RECORD_SYMBOL]\n\t\t\t\tif (recordId)\n\t\t\t\t\ttarget[objectOffset + start] = recordId\n\t\t\t\telse\n\t\t\t\t\tinsertNewRecord(transition, Object.keys(object), objectOffset, 0)\n\t\t\t}\n\t\t} :\n\t\t(object) => {\n\t\t\tlet nextTransition, transition = structures.transitions || (structures.transitions = Object.create(null))\n\t\t\tlet newTransitions = 0\n\t\t\tfor (let key in object) if (typeof object.hasOwnProperty !== 'function' || object.hasOwnProperty(key)) {\n\t\t\t\tnextTransition = transition[key]\n\t\t\t\tif (!nextTransition) {\n\t\t\t\t\tnextTransition = transition[key] = Object.create(null)\n\t\t\t\t\tnewTransitions++\n\t\t\t\t}\n\t\t\t\ttransition = nextTransition\n\t\t\t}\n\t\t\tlet recordId = transition[RECORD_SYMBOL]\n\t\t\tif (recordId) {\n\t\t\t\tif (recordId >= 0x60 && useTwoByteRecords) {\n\t\t\t\t\ttarget[position++] = ((recordId -= 0x60) & 0x1f) + 0x60\n\t\t\t\t\ttarget[position++] = recordId >> 5\n\t\t\t\t} else\n\t\t\t\t\ttarget[position++] = recordId\n\t\t\t} else {\n\t\t\t\tnewRecord(transition, transition.__keys__ || Object.keys(object), newTransitions)\n\t\t\t}\n\t\t\t// now write the values\n\t\t\tfor (let key in object)\n\t\t\t\tif (typeof object.hasOwnProperty !== 'function' || object.hasOwnProperty(key)) {\n\t\t\t\t\tpack(object[key])\n\t\t\t\t}\n\t\t}\n\n\t\t// create reference to useRecords if useRecords is a function\n\t\tconst checkUseRecords = typeof this.useRecords == 'function' && this.useRecords;\n\n\t\tconst writeObject = checkUseRecords ? (object) => {\n\t\t\tcheckUseRecords(object) ? writeRecord(object) : writePlainObject(object)\n\t\t} : writeRecord\n\n\t\tconst makeRoom = (end) => {\n\t\t\tlet newSize\n\t\t\tif (end > 0x1000000) {\n\t\t\t\t// special handling for really large buffers\n\t\t\t\tif ((end - start) > MAX_BUFFER_SIZE)\n\t\t\t\t\tthrow new Error('Packed buffer would be larger than maximum buffer size')\n\t\t\t\tnewSize = Math.min(MAX_BUFFER_SIZE,\n\t\t\t\t\tMath.round(Math.max((end - start) * (end > 0x4000000 ? 1.25 : 2), 0x400000) / 0x1000) * 0x1000)\n\t\t\t} else // faster handling for smaller buffers\n\t\t\t\tnewSize = ((Math.max((end - start) << 2, target.length - 1) >> 12) + 1) << 12\n\t\t\tlet newBuffer = new ByteArrayAllocate(newSize)\n\t\t\ttargetView = newBuffer.dataView || (newBuffer.dataView = new DataView(newBuffer.buffer, 0, newSize))\n\t\t\tend = Math.min(end, target.length)\n\t\t\tif (target.copy)\n\t\t\t\ttarget.copy(newBuffer, 0, start, end)\n\t\t\telse\n\t\t\t\tnewBuffer.set(target.slice(start, end))\n\t\t\tposition -= start\n\t\t\tstart = 0\n\t\t\tsafeEnd = newBuffer.length - 10\n\t\t\treturn target = newBuffer\n\t\t}\n\t\tconst newRecord = (transition, keys, newTransitions) => {\n\t\t\tlet recordId = structures.nextId\n\t\t\tif (!recordId)\n\t\t\t\trecordId = 0x40\n\t\t\tif (recordId < sharedLimitId && this.shouldShareStructure && !this.shouldShareStructure(keys)) {\n\t\t\t\trecordId = structures.nextOwnId\n\t\t\t\tif (!(recordId < maxStructureId))\n\t\t\t\t\trecordId = sharedLimitId\n\t\t\t\tstructures.nextOwnId = recordId + 1\n\t\t\t} else {\n\t\t\t\tif (recordId >= maxStructureId)// cycle back around\n\t\t\t\t\trecordId = sharedLimitId\n\t\t\t\tstructures.nextId = recordId + 1\n\t\t\t}\n\t\t\tlet highByte = keys.highByte = recordId >= 0x60 && useTwoByteRecords ? (recordId - 0x60) >> 5 : -1\n\t\t\ttransition[RECORD_SYMBOL] = recordId\n\t\t\ttransition.__keys__ = keys\n\t\t\tstructures[recordId - 0x40] = keys\n\n\t\t\tif (recordId < sharedLimitId) {\n\t\t\t\tkeys.isShared = true\n\t\t\t\tstructures.sharedLength = recordId - 0x3f\n\t\t\t\thasSharedUpdate = true\n\t\t\t\tif (highByte >= 0) {\n\t\t\t\t\ttarget[position++] = (recordId & 0x1f) + 0x60\n\t\t\t\t\ttarget[position++] = highByte\n\t\t\t\t} else {\n\t\t\t\t\ttarget[position++] = recordId\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (highByte >= 0) {\n\t\t\t\t\ttarget[position++] = 0xd5 // fixext 2\n\t\t\t\t\ttarget[position++] = 0x72 // \"r\" record defintion extension type\n\t\t\t\t\ttarget[position++] = (recordId & 0x1f) + 0x60\n\t\t\t\t\ttarget[position++] = highByte\n\t\t\t\t} else {\n\t\t\t\t\ttarget[position++] = 0xd4 // fixext 1\n\t\t\t\t\ttarget[position++] = 0x72 // \"r\" record defintion extension type\n\t\t\t\t\ttarget[position++] = recordId\n\t\t\t\t}\n\n\t\t\t\tif (newTransitions)\n\t\t\t\t\ttransitionsCount += serializationsSinceTransitionRebuild * newTransitions\n\t\t\t\t// record the removal of the id, we can maintain our shared structure\n\t\t\t\tif (recordIdsToRemove.length >= maxOwnStructures)\n\t\t\t\t\trecordIdsToRemove.shift()[RECORD_SYMBOL] = 0 // we are cycling back through, and have to remove old ones\n\t\t\t\trecordIdsToRemove.push(transition)\n\t\t\t\tpack(keys)\n\t\t\t}\n\t\t}\n\t\tconst insertNewRecord = (transition, keys, insertionOffset, newTransitions) => {\n\t\t\tlet mainTarget = target\n\t\t\tlet mainPosition = position\n\t\t\tlet mainSafeEnd = safeEnd\n\t\t\tlet mainStart = start\n\t\t\ttarget = keysTarget\n\t\t\tposition = 0\n\t\t\tstart = 0\n\t\t\tif (!target)\n\t\t\t\tkeysTarget = target = new ByteArrayAllocate(8192)\n\t\t\tsafeEnd = target.length - 10\n\t\t\tnewRecord(transition, keys, newTransitions)\n\t\t\tkeysTarget = target\n\t\t\tlet keysPosition = position\n\t\t\ttarget = mainTarget\n\t\t\tposition = mainPosition\n\t\t\tsafeEnd = mainSafeEnd\n\t\t\tstart = mainStart\n\t\t\tif (keysPosition > 1) {\n\t\t\t\tlet newEnd = position + keysPosition - 1\n\t\t\t\tif (newEnd > safeEnd)\n\t\t\t\t\tmakeRoom(newEnd)\n\t\t\t\tlet insertionPosition = insertionOffset + start\n\t\t\t\ttarget.copyWithin(insertionPosition + keysPosition, insertionPosition + 1, position)\n\t\t\t\ttarget.set(keysTarget.slice(0, keysPosition), insertionPosition)\n\t\t\t\tposition = newEnd\n\t\t\t} else {\n\t\t\t\ttarget[insertionOffset + start] = keysTarget[0]\n\t\t\t}\n\t\t}\n\t\tconst writeStruct = (object) => {\n\t\t\tlet newPosition = writeStructSlots(object, target, start, position, structures, makeRoom, (value, newPosition, notifySharedUpdate) => {\n\t\t\t\tif (notifySharedUpdate)\n\t\t\t\t\treturn hasSharedUpdate = true;\n\t\t\t\tposition = newPosition;\n\t\t\t\tlet startTarget = target;\n\t\t\t\tpack(value);\n\t\t\t\tresetStructures();\n\t\t\t\tif (startTarget !== target) {\n\t\t\t\t\treturn { position, targetView, target }; // indicate the buffer was re-allocated\n\t\t\t\t}\n\t\t\t\treturn position;\n\t\t\t}, this);\n\t\t\tif (newPosition === 0) // bail and go to a msgpack object\n\t\t\t\treturn writeObject(object);\n\t\t\tposition = newPosition;\n\t\t}\n\t}\n\tuseBuffer(buffer) {\n\t\t// this means we are finished using our own buffer and we can write over it safely\n\t\ttarget = buffer\n\t\ttarget.dataView || (target.dataView = new DataView(target.buffer, target.byteOffset, target.byteLength))\n\t\tposition = 0\n\t}\n\tset position (value) {\n\t\tposition = value;\n\t}\n\tget position() {\n\t\treturn position;\n\t}\n\tclearSharedData() {\n\t\tif (this.structures)\n\t\t\tthis.structures = []\n\t\tif (this.typedStructs)\n\t\t\tthis.typedStructs = []\n\t}\n}\n\nextensionClasses = [ Date, Set, Error, RegExp, ArrayBuffer, Object.getPrototypeOf(Uint8Array.prototype).constructor /*TypedArray*/, C1Type ]\nextensions = [{\n\tpack(date, allocateForWrite, pack) {\n\t\tlet seconds = date.getTime() / 1000\n\t\tif ((this.useTimestamp32 || date.getMilliseconds() === 0) && seconds >= 0 && seconds < 0x100000000) {\n\t\t\t// Timestamp 32\n\t\t\tlet { target, targetView, position} = allocateForWrite(6)\n\t\t\ttarget[position++] = 0xd6\n\t\t\ttarget[position++] = 0xff\n\t\t\ttargetView.setUint32(position, seconds)\n\t\t} else if (seconds > 0 && seconds < 0x100000000) {\n\t\t\t// Timestamp 64\n\t\t\tlet { target, targetView, position} = allocateForWrite(10)\n\t\t\ttarget[position++] = 0xd7\n\t\t\ttarget[position++] = 0xff\n\t\t\ttargetView.setUint32(position, date.getMilliseconds() * 4000000 + ((seconds / 1000 / 0x100000000) >> 0))\n\t\t\ttargetView.setUint32(position + 4, seconds)\n\t\t} else if (isNaN(seconds)) {\n\t\t\tif (this.onInvalidDate) {\n\t\t\t\tallocateForWrite(0)\n\t\t\t\treturn pack(this.onInvalidDate())\n\t\t\t}\n\t\t\t// Intentionally invalid timestamp\n\t\t\tlet { target, targetView, position} = allocateForWrite(3)\n\t\t\ttarget[position++] = 0xd4\n\t\t\ttarget[position++] = 0xff\n\t\t\ttarget[position++] = 0xff\n\t\t} else {\n\t\t\t// Timestamp 96\n\t\t\tlet { target, targetView, position} = allocateForWrite(15)\n\t\t\ttarget[position++] = 0xc7\n\t\t\ttarget[position++] = 12\n\t\t\ttarget[position++] = 0xff\n\t\t\ttargetView.setUint32(position, date.getMilliseconds() * 1000000)\n\t\t\ttargetView.setBigInt64(position + 4, BigInt(Math.floor(seconds)))\n\t\t}\n\t}\n}, {\n\tpack(set, allocateForWrite, pack) {\n\t\tif (this.setAsEmptyObject) {\n\t\t\tallocateForWrite(0);\n\t\t\treturn pack({})\n\t\t}\n\t\tlet array = Array.from(set)\n\t\tlet { target, position} = allocateForWrite(this.moreTypes ? 3 : 0)\n\t\tif (this.moreTypes) {\n\t\t\ttarget[position++] = 0xd4\n\t\t\ttarget[position++] = 0x73 // 's' for Set\n\t\t\ttarget[position++] = 0\n\t\t}\n\t\tpack(array)\n\t}\n}, {\n\tpack(error, allocateForWrite, pack) {\n\t\tlet { target, position} = allocateForWrite(this.moreTypes ? 3 : 0)\n\t\tif (this.moreTypes) {\n\t\t\ttarget[position++] = 0xd4\n\t\t\ttarget[position++] = 0x65 // 'e' for error\n\t\t\ttarget[position++] = 0\n\t\t}\n\t\tpack([ error.name, error.message, error.cause ])\n\t}\n}, {\n\tpack(regex, allocateForWrite, pack) {\n\t\tlet { target, position} = allocateForWrite(this.moreTypes ? 3 : 0)\n\t\tif (this.moreTypes) {\n\t\t\ttarget[position++] = 0xd4\n\t\t\ttarget[position++] = 0x78 // 'x' for regeXp\n\t\t\ttarget[position++] = 0\n\t\t}\n\t\tpack([ regex.source, regex.flags ])\n\t}\n}, {\n\tpack(arrayBuffer, allocateForWrite) {\n\t\tif (this.moreTypes)\n\t\t\twriteExtBuffer(arrayBuffer, 0x10, allocateForWrite)\n\t\telse\n\t\t\twriteBuffer(hasNodeBuffer ? Buffer.from(arrayBuffer) : new Uint8Array(arrayBuffer), allocateForWrite)\n\t}\n}, {\n\tpack(typedArray, allocateForWrite) {\n\t\tlet constructor = typedArray.constructor\n\t\tif (constructor !== ByteArray && this.moreTypes)\n\t\t\twriteExtBuffer(typedArray, typedArrays.indexOf(constructor.name), allocateForWrite)\n\t\telse\n\t\t\twriteBuffer(typedArray, allocateForWrite)\n\t}\n}, {\n\tpack(c1, allocateForWrite) { // specific 0xC1 object\n\t\tlet { target, position} = allocateForWrite(1)\n\t\ttarget[position] = 0xc1\n\t}\n}]\n\nfunction writeExtBuffer(typedArray, type, allocateForWrite, encode) {\n\tlet length = typedArray.byteLength\n\tif (length + 1 < 0x100) {\n\t\tvar { target, position } = allocateForWrite(4 + length)\n\t\ttarget[position++] = 0xc7\n\t\ttarget[position++] = length + 1\n\t} else if (length + 1 < 0x10000) {\n\t\tvar { target, position } = allocateForWrite(5 + length)\n\t\ttarget[position++] = 0xc8\n\t\ttarget[position++] = (length + 1) >> 8\n\t\ttarget[position++] = (length + 1) & 0xff\n\t} else {\n\t\tvar { target, position, targetView } = allocateForWrite(7 + length)\n\t\ttarget[position++] = 0xc9\n\t\ttargetView.setUint32(position, length + 1) // plus one for the type byte\n\t\tposition += 4\n\t}\n\ttarget[position++] = 0x74 // \"t\" for typed array\n\ttarget[position++] = type\n\tif (!typedArray.buffer) typedArray = new Uint8Array(typedArray)\n\ttarget.set(new Uint8Array(typedArray.buffer, typedArray.byteOffset, typedArray.byteLength), position)\n}\nfunction writeBuffer(buffer, allocateForWrite) {\n\tlet length = buffer.byteLength\n\tvar target, position\n\tif (length < 0x100) {\n\t\tvar { target, position } = allocateForWrite(length + 2)\n\t\ttarget[position++] = 0xc4\n\t\ttarget[position++] = length\n\t} else if (length < 0x10000) {\n\t\tvar { target, position } = allocateForWrite(length + 3)\n\t\ttarget[position++] = 0xc5\n\t\ttarget[position++] = length >> 8\n\t\ttarget[position++] = length & 0xff\n\t} else {\n\t\tvar { target, position, targetView } = allocateForWrite(length + 5)\n\t\ttarget[position++] = 0xc6\n\t\ttargetView.setUint32(position, length)\n\t\tposition += 4\n\t}\n\ttarget.set(buffer, position)\n}\n\nfunction writeExtensionData(result, target, position, type) {\n\tlet length = result.length\n\tswitch (length) {\n\t\tcase 1:\n\t\t\ttarget[position++] = 0xd4\n\t\t\tbreak\n\t\tcase 2:\n\t\t\ttarget[position++] = 0xd5\n\t\t\tbreak\n\t\tcase 4:\n\t\t\ttarget[position++] = 0xd6\n\t\t\tbreak\n\t\tcase 8:\n\t\t\ttarget[position++] = 0xd7\n\t\t\tbreak\n\t\tcase 16:\n\t\t\ttarget[position++] = 0xd8\n\t\t\tbreak\n\t\tdefault:\n\t\t\tif (length < 0x100) {\n\t\t\t\ttarget[position++] = 0xc7\n\t\t\t\ttarget[position++] = length\n\t\t\t} else if (length < 0x10000) {\n\t\t\t\ttarget[position++] = 0xc8\n\t\t\t\ttarget[position++] = length >> 8\n\t\t\t\ttarget[position++] = length & 0xff\n\t\t\t} else {\n\t\t\t\ttarget[position++] = 0xc9\n\t\t\t\ttarget[position++] = length >> 24\n\t\t\t\ttarget[position++] = (length >> 16) & 0xff\n\t\t\t\ttarget[position++] = (length >> 8) & 0xff\n\t\t\t\ttarget[position++] = length & 0xff\n\t\t\t}\n\t}\n\ttarget[position++] = type\n\ttarget.set(result, position)\n\tposition += length\n\treturn position\n}\n\nfunction insertIds(serialized, idsToInsert) {\n\t// insert the ids that need to be referenced for structured clones\n\tlet nextId\n\tlet distanceToMove = idsToInsert.length * 6\n\tlet lastEnd = serialized.length - distanceToMove\n\twhile (nextId = idsToInsert.pop()) {\n\t\tlet offset = nextId.offset\n\t\tlet id = nextId.id\n\t\tserialized.copyWithin(offset + distanceToMove, offset, lastEnd)\n\t\tdistanceToMove -= 6\n\t\tlet position = offset + distanceToMove\n\t\tserialized[position++] = 0xd6\n\t\tserialized[position++] = 0x69 // 'i'\n\t\tserialized[position++] = id >> 24\n\t\tserialized[position++] = (id >> 16) & 0xff\n\t\tserialized[position++] = (id >> 8) & 0xff\n\t\tserialized[position++] = id & 0xff\n\t\tlastEnd = offset\n\t}\n\treturn serialized\n}\n\nfunction writeBundles(start, pack, incrementPosition) {\n\tif (bundledStrings.length > 0) {\n\t\ttargetView.setUint32(bundledStrings.position + start, position + incrementPosition - bundledStrings.position - start)\n\t\tbundledStrings.stringsPosition = position - start;\n\t\tlet writeStrings = bundledStrings\n\t\tbundledStrings = null\n\t\tpack(writeStrings[0])\n\t\tpack(writeStrings[1])\n\t}\n}\n\nexport function addExtension(extension) {\n\tif (extension.Class) {\n\t\tif (!extension.pack && !extension.write)\n\t\t\tthrow new Error('Extension has no pack or write function')\n\t\tif (extension.pack && !extension.type)\n\t\t\tthrow new Error('Extension has no type (numeric code to identify the extension)')\n\t\textensionClasses.unshift(extension.Class)\n\t\textensions.unshift(extension)\n\t}\n\tunpackAddExtension(extension)\n}\nfunction prepareStructures(structures, packr) {\n\tstructures.isCompatible = (existingStructures) => {\n\t\tlet compatible = !existingStructures || ((packr.lastNamedStructuresLength || 0) === existingStructures.length)\n\t\tif (!compatible) // we want to merge these existing structures immediately since we already have it and we are in the right transaction\n\t\t\tpackr._mergeStructures(existingStructures);\n\t\treturn compatible;\n\t}\n\treturn structures\n}\nexport function setWriteStructSlots(writeSlots, makeStructures) {\n\twriteStructSlots = writeSlots;\n\tprepareStructures = makeStructures;\n}\n\nlet defaultPackr = new Packr({ useRecords: false })\nexport const pack = defaultPackr.pack\nexport const encode = defaultPackr.pack\nexport const Encoder = Packr\nexport { FLOAT32_OPTIONS } from './unpack.js'\nimport { FLOAT32_OPTIONS } from './unpack.js'\nexport const { NEVER, ALWAYS, DECIMAL_ROUND, DECIMAL_FIT } = FLOAT32_OPTIONS\nexport const REUSE_BUFFER_MODE = 512\nexport const RESET_BUFFER_MODE = 1024\nexport const RESERVE_START_SPACE = 2048","import { Packr } from './pack.js'\nimport { Unpackr } from './unpack.js'\n\n/**\n * Given an Iterable first argument, returns an Iterable where each value is packed as a Buffer\n * If the argument is only Async Iterable, the return value will be an Async Iterable.\n * @param {Iterable|Iterator|AsyncIterable|AsyncIterator} objectIterator - iterable source, like a Readable object stream, an array, Set, or custom object\n * @param {options} [options] - msgpackr pack options\n * @returns {IterableIterator|Promise.<AsyncIterableIterator>}\n */\nexport function packIter (objectIterator, options = {}) {\n if (!objectIterator || typeof objectIterator !== 'object') {\n throw new Error('first argument must be an Iterable, Async Iterable, or a Promise for an Async Iterable')\n } else if (typeof objectIterator[Symbol.iterator] === 'function') {\n return packIterSync(objectIterator, options)\n } else if (typeof objectIterator.then === 'function' || typeof objectIterator[Symbol.asyncIterator] === 'function') {\n return packIterAsync(objectIterator, options)\n } else {\n throw new Error('first argument must be an Iterable, Async Iterable, Iterator, Async Iterator, or a Promise')\n }\n}\n\nfunction * packIterSync (objectIterator, options) {\n const packr = new Packr(options)\n for (const value of objectIterator) {\n yield packr.pack(value)\n }\n}\n\nasync function * packIterAsync (objectIterator, options) {\n const packr = new Packr(options)\n for await (const value of objectIterator) {\n yield packr.pack(value)\n }\n}\n\n/**\n * Given an Iterable/Iterator input which yields buffers, returns an IterableIterator which yields sync decoded objects\n * Or, given an Async Iterable/Iterator which yields promises resolving in buffers, returns an AsyncIterableIterator.\n * @param {Iterable|Iterator|AsyncIterable|AsyncIterableIterator} bufferIterator\n * @param {object} [options] - unpackr options\n * @returns {IterableIterator|Promise.<AsyncIterableIterator}\n */\nexport function unpackIter (bufferIterator, options = {}) {\n if (!bufferIterator || typeof bufferIterator !== 'object') {\n throw new Error('first argument must be an Iterable, Async Iterable, Iterator, Async Iterator, or a promise')\n }\n\n const unpackr = new Unpackr(options)\n let incomplete\n const parser = (chunk) => {\n let yields\n // if there's incomplete data from previous chunk, concatinate and try again\n if (incomplete) {\n chunk = Buffer.concat([incomplete, chunk])\n incomplete = undefined\n }\n\n try {\n yields = unpackr.unpackMultiple(chunk)\n } catch (err) {\n if (err.incomplete) {\n incomplete = chunk.slice(err.lastPosition)\n yields = err.values\n } else {\n throw err\n }\n }\n return yields\n }\n\n if (typeof bufferIterator[Symbol.iterator] === 'function') {\n return (function * iter () {\n for (const value of bufferIterator) {\n yield * parser(value)\n }\n })()\n } else if (typeof bufferIterator[Symbol.asyncIterator] === 'function') {\n return (async function * iter () {\n for await (const value of bufferIterator) {\n yield * parser(value)\n }\n })()\n }\n}\nexport const decodeIter = unpackIter\nexport const encodeIter = packIter","export { Packr, Encoder, addExtension, pack, encode, NEVER, ALWAYS, DECIMAL_ROUND, DECIMAL_FIT, REUSE_BUFFER_MODE, RESET_BUFFER_MODE, RESERVE_START_SPACE } from './pack.js'\nexport { Unpackr, Decoder, C1, unpack, unpackMultiple, decode, FLOAT32_OPTIONS, clearSource, roundFloat32, isNativeAccelerationEnabled } from './unpack.js'\nexport { decodeIter, encodeIter } from './iterators.js'\nexport const useRecords = false\nexport const mapsAsObjects = true\n"],"names":["decoder","src","srcEnd","TextDecoder","error","currentStructures","srcString","bundledStrings","referenceMap","dataView","position","currentUnpackr","srcStringStart","srcStringEnd","currentExtensions","defaultOptions","useRecords","mapsAsObjects","C1Type","C1","name","BlockedFunction","sequentialMode","inlineObjectReadThreshold","Infinity","Unpackr","constructor","options","undefined","sequential","trusted","structures","maxSharedStructures","sharedLength","length","getStructures","uninitialized","int64AsNumber","int64AsType","Object","assign","this","unpack","source","saveState","clearSource","prototype","call","buffer","ArrayBuffer","Buffer","from","Uint8Array","end","start","DataView","byteOffset","byteLength","Error","checkedRead","unpackMultiple","forEach","values","lastPosition","size","value","defaultUnpackr","push","_mergeStructures","loadedStructures","existingStructures","isFrozen","map","structure","slice","i","l","isShared","highByte","id","existing","restoreStructures","decode","result","randomAccessStructure","read","postBundlePosition","jsonView","JSON","stringify","_","RangeError","message","startsWith","incomplete","token","loadStructures","createStructureReader","object","key","readKey","Map","set","array","Array","freezeData","freeze","string","shortStringInJS","longStringInJS","readFixedString","position1","position0","readBin","getUint16","getUint32","readExt","getFloat32","useFloat32","multiplier","mult10","getFloat64","getBigUint64","toString","BigInt","Number","getInt8","getInt16","getInt32","getBigInt64","recordDefinition","extension","noBuffer","subarray","readString8","readString16","readString32","readArray","readMap","validName","firstId","readObject","count","test","join","createSecondByteReader","read0","readStringJS","units","byte1","byte2","byte3","unit","fromCharCode","apply","String","bytes","byte","a","b","c","d","e","f","g","h","j","k","m","n","o","readOnlyJSString","copyBuffers","type","readPosition","keyCache","asSafeString","chunk","entry","checkPosition","property","firstByte","existingStructure","data","errors","TypeError","ReferenceError","cause","structuredClone","target","refEntry","targetProperties","used","get","Set","typedArrays","glbl","globalThis","window","typeCode","typedArrayName","ab","RegExp","TEMP_BUNDLE","callback","savedSrcEnd","savedPosition","savedSrcStringStart","savedSrcStringEnd","savedSrcString","savedReferenceMap","savedBundledStrings","savedSrc","savedStructures","savedStructuresContents","savedPackr","savedSequentialMode","splice","dataSize","dataPosition","Date","Math","floor","Decoder","FLOAT32_OPTIONS","NEVER","ALWAYS","DECIMAL_ROUND","DECIMAL_FIT","textEncoder","extensions","extensionClasses","f32Array","Float32Array","u8Array","TextEncoder","hasNodeBuffer","ByteArrayAllocate","allocUnsafeSlow","ByteArray","MAX_BUFFER_SIZE","keysTarget","targetView","safeEnd","hasNonLatin","RECORD_SYMBOL","Symbol","Packr","hasSharedUpdate","super","offset","encodeUtf8","utf8Write","encodeInto","written","packr","isSequential","hasSharedStructures","saveStructures","moreTypes","maxOwnStructures","useTwoByteRecords","sharedLimitId","maxStructureId","recordIdsToRemove","transitionsCount","serializationsSinceTransitionRebuild","pack","encode","encodeOptions","RESERVE_START_SPACE","bundleStrings","transitions","create","keys","nextTransition","transition","lastNamedStructuresLength","nextId","encodingError","writeStruct","lastBundle","writeBundles","idsToInsert","sort","incrementPosition","insertionPoint","stringsPosition","setUint32","previous","makeRoom","serialized","distanceToMove","lastEnd","pop","copyWithin","insertIds","REUSE_BUFFER_MODE","resetStructures","returnBuffer","newSharedData","isCompatible","compatible","prepareStructures","RESET_BUFFER_MODE","packArray","headerSize","strLength","extStart","maxBytes","setUint16","twoByte","c1","c2","strPosition","charCodeAt","setInt16","setInt32","xShifted","setFloat32","setFloat64","referee","writeObject","mapAsEmptyObject","entryValue","write","writeResult","isArray","currentTarget","currentTargetView","currentPosition","writeExtensionData","toJSON","json","writeFunction","setBigInt64","setBigUint64","largeBigIntToFloat","useBigIntExtension","alignedSign","encodeUndefinedAsNil","writePlainObject","variableMapSize","coercibleKeyAsNumber","skipValues","hasOwnProperty","includes","num","isNaN","objectOffset","writeRecord","progressiveRecords","wroteKeys","lastTransition","newTransitions","newRecord","insertNewRecord","recordId","__keys__","checkUseRecords","newSize","min","round","max","newBuffer","copy","shouldShareStructure","nextOwnId","shift","insertionOffset","mainTarget","mainPosition","mainSafeEnd","mainStart","keysPosition","newEnd","insertionPosition","newPosition","writeStructSlots","notifySharedUpdate","startTarget","useBuffer","clearSharedData","typedStructs","writeExtBuffer","typedArray","allocateForWrite","writeBuffer","writeStrings","getPrototypeOf","date","seconds","getTime","useTimestamp32","getMilliseconds","onInvalidDate","setAsEmptyObject","regex","flags","arrayBuffer","indexOf","defaultPackr","Encoder","decodeIter","bufferIterator","unpackr","parser","yields","concat","err","iterator","asyncIterator","encodeIter","objectIterator","packIterSync","then","async","packIterAsync","Class","unshift","unpackAddExtension","float32Number"],"mappings":"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"}