@gibme/base58 20.0.0 → 20.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"base58.min.js","mappings":"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","sources":["webpack://@gibme/base58/webpack/universalModuleDefinition","webpack://@gibme/base58/./node_modules/events/events.js","webpack://@gibme/base58/./node_modules/@gibme/bytepack/dist/index.js","webpack://@gibme/base58/./node_modules/readable-stream/errors-browser.js","webpack://@gibme/base58/./node_modules/big-integer/BigInteger.js","webpack://@gibme/base58/./node_modules/string_decoder/lib/string_decoder.js","webpack://@gibme/base58/./node_modules/@gibme/bytepack/dist/varint.js","webpack://@gibme/base58/./src/index.ts","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/from-browser.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/end-of-stream.js","webpack://@gibme/base58/./node_modules/ieee754/index.js","webpack://@gibme/base58/./node_modules/buffer/index.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/state.js","webpack://@gibme/base58/./node_modules/@gibme/bytepack/dist/writer.js","webpack://@gibme/base58/./node_modules/stream-browserify/index.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/stream-browser.js","webpack://@gibme/base58/./src/base58-js.ts","webpack://@gibme/base58/./node_modules/readable-stream/lib/_stream_duplex.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/_stream_readable.js","webpack://@gibme/base58/./node_modules/base64-js/index.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/_stream_passthrough.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/_stream_transform.js","webpack://@gibme/base58/./node_modules/util-deprecate/browser.js","webpack://@gibme/base58/./node_modules/inherits/inherits_browser.js","webpack://@gibme/base58/./src/cryptonote_base58.ts","webpack://@gibme/base58/./node_modules/readable-stream/lib/_stream_writable.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/buffer_list.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/pipeline.js","webpack://@gibme/base58/./node_modules/@gibme/bytepack/dist/reader.js","webpack://@gibme/base58/./node_modules/safe-buffer/index.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/destroy.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/async_iterator.js","webpack://@gibme/base58/webpack/bootstrap","webpack://@gibme/base58/webpack/runtime/global","webpack://@gibme/base58/webpack/runtime/node module decorator","webpack://@gibme/base58/webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse {\n\t\tvar a = factory();\n\t\tfor(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];\n\t}\n})(self, () => {\nreturn ","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n\nfunction once(emitter, name) {\n return new Promise(function (resolve, reject) {\n function errorListener(err) {\n emitter.removeListener(name, resolver);\n reject(err);\n }\n\n function resolver() {\n if (typeof emitter.removeListener === 'function') {\n emitter.removeListener('error', errorListener);\n }\n resolve([].slice.call(arguments));\n };\n\n eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n if (name !== 'error') {\n addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n }\n });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n if (typeof emitter.on === 'function') {\n eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n if (typeof emitter.on === 'function') {\n if (flags.once) {\n emitter.once(name, listener);\n } else {\n emitter.on(name, listener);\n }\n } else if (typeof emitter.addEventListener === 'function') {\n // EventTarget does not have `error` event semantics like Node\n // EventEmitters, we do not listen for `error` events here.\n emitter.addEventListener(name, function wrapListener(arg) {\n // IE does not have builtin `{ once: true }` support so we\n // have to do it manually.\n if (flags.once) {\n emitter.removeEventListener(name, wrapListener);\n }\n listener(arg);\n });\n } else {\n throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n }\n}\n","\"use strict\";\n// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Buffer = exports.BigInteger = exports.Varint = exports.Writer = exports.Reader = void 0;\nvar reader_1 = require(\"./reader\");\nObject.defineProperty(exports, \"Reader\", { enumerable: true, get: function () { return reader_1.Reader; } });\nvar writer_1 = require(\"./writer\");\nObject.defineProperty(exports, \"Writer\", { enumerable: true, get: function () { return writer_1.Writer; } });\nvar varint_1 = require(\"./varint\");\nObject.defineProperty(exports, \"Varint\", { enumerable: true, get: function () { return varint_1.Varint; } });\nvar big_integer_1 = require(\"big-integer\");\nObject.defineProperty(exports, \"BigInteger\", { enumerable: true, get: function () { return __importDefault(big_integer_1).default; } });\nvar buffer_1 = require(\"buffer\");\nObject.defineProperty(exports, \"Buffer\", { enumerable: true, get: function () { return buffer_1.Buffer; } });\n//# sourceMappingURL=index.js.map","'use strict';\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar codes = {};\n\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error;\n }\n\n function getMessage(arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message;\n } else {\n return message(arg1, arg2, arg3);\n }\n }\n\n var NodeError =\n /*#__PURE__*/\n function (_Base) {\n _inheritsLoose(NodeError, _Base);\n\n function NodeError(arg1, arg2, arg3) {\n return _Base.call(this, getMessage(arg1, arg2, arg3)) || this;\n }\n\n return NodeError;\n }(Base);\n\n NodeError.prototype.name = Base.name;\n NodeError.prototype.code = code;\n codes[code] = NodeError;\n} // https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\n\n\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n var len = expected.length;\n expected = expected.map(function (i) {\n return String(i);\n });\n\n if (len > 2) {\n return \"one of \".concat(thing, \" \").concat(expected.slice(0, len - 1).join(', '), \", or \") + expected[len - 1];\n } else if (len === 2) {\n return \"one of \".concat(thing, \" \").concat(expected[0], \" or \").concat(expected[1]);\n } else {\n return \"of \".concat(thing, \" \").concat(expected[0]);\n }\n } else {\n return \"of \".concat(thing, \" \").concat(String(expected));\n }\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\n\n\nfunction startsWith(str, search, pos) {\n return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\n\n\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n\n return str.substring(this_len - search.length, this_len) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\n\n\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\n\ncreateErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {\n return 'The value \"' + value + '\" is invalid for option \"' + name + '\"';\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n // determiner: 'must be' or 'must not be'\n var determiner;\n\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n\n var msg;\n\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = \"The \".concat(name, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n } else {\n var type = includes(name, '.') ? 'property' : 'argument';\n msg = \"The \\\"\".concat(name, \"\\\" \").concat(type, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n }\n\n msg += \". Received type \".concat(typeof actual);\n return msg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');\ncreateErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {\n return 'The ' + name + ' method is not implemented';\n});\ncreateErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');\ncreateErrorType('ERR_STREAM_DESTROYED', function (name) {\n return 'Cannot call ' + name + ' after a stream was destroyed';\n});\ncreateErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');\ncreateErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');\ncreateErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');\ncreateErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);\ncreateErrorType('ERR_UNKNOWN_ENCODING', function (arg) {\n return 'Unknown encoding: ' + arg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');\nmodule.exports.codes = codes;\n","var bigInt = (function (undefined) {\r\n \"use strict\";\r\n\r\n var BASE = 1e7,\r\n LOG_BASE = 7,\r\n MAX_INT = 9007199254740992,\r\n MAX_INT_ARR = smallToArray(MAX_INT),\r\n DEFAULT_ALPHABET = \"0123456789abcdefghijklmnopqrstuvwxyz\";\r\n\r\n var supportsNativeBigInt = typeof BigInt === \"function\";\r\n\r\n function Integer(v, radix, alphabet, caseSensitive) {\r\n if (typeof v === \"undefined\") return Integer[0];\r\n if (typeof radix !== \"undefined\") return +radix === 10 && !alphabet ? parseValue(v) : parseBase(v, radix, alphabet, caseSensitive);\r\n return parseValue(v);\r\n }\r\n\r\n function BigInteger(value, sign) {\r\n this.value = value;\r\n this.sign = sign;\r\n this.isSmall = false;\r\n }\r\n BigInteger.prototype = Object.create(Integer.prototype);\r\n\r\n function SmallInteger(value) {\r\n this.value = value;\r\n this.sign = value < 0;\r\n this.isSmall = true;\r\n }\r\n SmallInteger.prototype = Object.create(Integer.prototype);\r\n\r\n function NativeBigInt(value) {\r\n this.value = value;\r\n }\r\n NativeBigInt.prototype = Object.create(Integer.prototype);\r\n\r\n function isPrecise(n) {\r\n return -MAX_INT < n && n < MAX_INT;\r\n }\r\n\r\n function smallToArray(n) { // For performance reasons doesn't reference BASE, need to change this function if BASE changes\r\n if (n < 1e7)\r\n return [n];\r\n if (n < 1e14)\r\n return [n % 1e7, Math.floor(n / 1e7)];\r\n return [n % 1e7, Math.floor(n / 1e7) % 1e7, Math.floor(n / 1e14)];\r\n }\r\n\r\n function arrayToSmall(arr) { // If BASE changes this function may need to change\r\n trim(arr);\r\n var length = arr.length;\r\n if (length < 4 && compareAbs(arr, MAX_INT_ARR) < 0) {\r\n switch (length) {\r\n case 0: return 0;\r\n case 1: return arr[0];\r\n case 2: return arr[0] + arr[1] * BASE;\r\n default: return arr[0] + (arr[1] + arr[2] * BASE) * BASE;\r\n }\r\n }\r\n return arr;\r\n }\r\n\r\n function trim(v) {\r\n var i = v.length;\r\n while (v[--i] === 0);\r\n v.length = i + 1;\r\n }\r\n\r\n function createArray(length) { // function shamelessly stolen from Yaffle's library https://github.com/Yaffle/BigInteger\r\n var x = new Array(length);\r\n var i = -1;\r\n while (++i < length) {\r\n x[i] = 0;\r\n }\r\n return x;\r\n }\r\n\r\n function truncate(n) {\r\n if (n > 0) return Math.floor(n);\r\n return Math.ceil(n);\r\n }\r\n\r\n function add(a, b) { // assumes a and b are arrays with a.length >= b.length\r\n var l_a = a.length,\r\n l_b = b.length,\r\n r = new Array(l_a),\r\n carry = 0,\r\n base = BASE,\r\n sum, i;\r\n for (i = 0; i < l_b; i++) {\r\n sum = a[i] + b[i] + carry;\r\n carry = sum >= base ? 1 : 0;\r\n r[i] = sum - carry * base;\r\n }\r\n while (i < l_a) {\r\n sum = a[i] + carry;\r\n carry = sum === base ? 1 : 0;\r\n r[i++] = sum - carry * base;\r\n }\r\n if (carry > 0) r.push(carry);\r\n return r;\r\n }\r\n\r\n function addAny(a, b) {\r\n if (a.length >= b.length) return add(a, b);\r\n return add(b, a);\r\n }\r\n\r\n function addSmall(a, carry) { // assumes a is array, carry is number with 0 <= carry < MAX_INT\r\n var l = a.length,\r\n r = new Array(l),\r\n base = BASE,\r\n sum, i;\r\n for (i = 0; i < l; i++) {\r\n sum = a[i] - base + carry;\r\n carry = Math.floor(sum / base);\r\n r[i] = sum - carry * base;\r\n carry += 1;\r\n }\r\n while (carry > 0) {\r\n r[i++] = carry % base;\r\n carry = Math.floor(carry / base);\r\n }\r\n return r;\r\n }\r\n\r\n BigInteger.prototype.add = function (v) {\r\n var n = parseValue(v);\r\n if (this.sign !== n.sign) {\r\n return this.subtract(n.negate());\r\n }\r\n var a = this.value, b = n.value;\r\n if (n.isSmall) {\r\n return new BigInteger(addSmall(a, Math.abs(b)), this.sign);\r\n }\r\n return new BigInteger(addAny(a, b), this.sign);\r\n };\r\n BigInteger.prototype.plus = BigInteger.prototype.add;\r\n\r\n SmallInteger.prototype.add = function (v) {\r\n var n = parseValue(v);\r\n var a = this.value;\r\n if (a < 0 !== n.sign) {\r\n return this.subtract(n.negate());\r\n }\r\n var b = n.value;\r\n if (n.isSmall) {\r\n if (isPrecise(a + b)) return new SmallInteger(a + b);\r\n b = smallToArray(Math.abs(b));\r\n }\r\n return new BigInteger(addSmall(b, Math.abs(a)), a < 0);\r\n };\r\n SmallInteger.prototype.plus = SmallInteger.prototype.add;\r\n\r\n NativeBigInt.prototype.add = function (v) {\r\n return new NativeBigInt(this.value + parseValue(v).value);\r\n }\r\n NativeBigInt.prototype.plus = NativeBigInt.prototype.add;\r\n\r\n function subtract(a, b) { // assumes a and b are arrays with a >= b\r\n var a_l = a.length,\r\n b_l = b.length,\r\n r = new Array(a_l),\r\n borrow = 0,\r\n base = BASE,\r\n i, difference;\r\n for (i = 0; i < b_l; i++) {\r\n difference = a[i] - borrow - b[i];\r\n if (difference < 0) {\r\n difference += base;\r\n borrow = 1;\r\n } else borrow = 0;\r\n r[i] = difference;\r\n }\r\n for (i = b_l; i < a_l; i++) {\r\n difference = a[i] - borrow;\r\n if (difference < 0) difference += base;\r\n else {\r\n r[i++] = difference;\r\n break;\r\n }\r\n r[i] = difference;\r\n }\r\n for (; i < a_l; i++) {\r\n r[i] = a[i];\r\n }\r\n trim(r);\r\n return r;\r\n }\r\n\r\n function subtractAny(a, b, sign) {\r\n var value;\r\n if (compareAbs(a, b) >= 0) {\r\n value = subtract(a, b);\r\n } else {\r\n value = subtract(b, a);\r\n sign = !sign;\r\n }\r\n value = arrayToSmall(value);\r\n if (typeof value === \"number\") {\r\n if (sign) value = -value;\r\n return new SmallInteger(value);\r\n }\r\n return new BigInteger(value, sign);\r\n }\r\n\r\n function subtractSmall(a, b, sign) { // assumes a is array, b is number with 0 <= b < MAX_INT\r\n var l = a.length,\r\n r = new Array(l),\r\n carry = -b,\r\n base = BASE,\r\n i, difference;\r\n for (i = 0; i < l; i++) {\r\n difference = a[i] + carry;\r\n carry = Math.floor(difference / base);\r\n difference %= base;\r\n r[i] = difference < 0 ? difference + base : difference;\r\n }\r\n r = arrayToSmall(r);\r\n if (typeof r === \"number\") {\r\n if (sign) r = -r;\r\n return new SmallInteger(r);\r\n } return new BigInteger(r, sign);\r\n }\r\n\r\n BigInteger.prototype.subtract = function (v) {\r\n var n = parseValue(v);\r\n if (this.sign !== n.sign) {\r\n return this.add(n.negate());\r\n }\r\n var a = this.value, b = n.value;\r\n if (n.isSmall)\r\n return subtractSmall(a, Math.abs(b), this.sign);\r\n return subtractAny(a, b, this.sign);\r\n };\r\n BigInteger.prototype.minus = BigInteger.prototype.subtract;\r\n\r\n SmallInteger.prototype.subtract = function (v) {\r\n var n = parseValue(v);\r\n var a = this.value;\r\n if (a < 0 !== n.sign) {\r\n return this.add(n.negate());\r\n }\r\n var b = n.value;\r\n if (n.isSmall) {\r\n return new SmallInteger(a - b);\r\n }\r\n return subtractSmall(b, Math.abs(a), a >= 0);\r\n };\r\n SmallInteger.prototype.minus = SmallInteger.prototype.subtract;\r\n\r\n NativeBigInt.prototype.subtract = function (v) {\r\n return new NativeBigInt(this.value - parseValue(v).value);\r\n }\r\n NativeBigInt.prototype.minus = NativeBigInt.prototype.subtract;\r\n\r\n BigInteger.prototype.negate = function () {\r\n return new BigInteger(this.value, !this.sign);\r\n };\r\n SmallInteger.prototype.negate = function () {\r\n var sign = this.sign;\r\n var small = new SmallInteger(-this.value);\r\n small.sign = !sign;\r\n return small;\r\n };\r\n NativeBigInt.prototype.negate = function () {\r\n return new NativeBigInt(-this.value);\r\n }\r\n\r\n BigInteger.prototype.abs = function () {\r\n return new BigInteger(this.value, false);\r\n };\r\n SmallInteger.prototype.abs = function () {\r\n return new SmallInteger(Math.abs(this.value));\r\n };\r\n NativeBigInt.prototype.abs = function () {\r\n return new NativeBigInt(this.value >= 0 ? this.value : -this.value);\r\n }\r\n\r\n\r\n function multiplyLong(a, b) {\r\n var a_l = a.length,\r\n b_l = b.length,\r\n l = a_l + b_l,\r\n r = createArray(l),\r\n base = BASE,\r\n product, carry, i, a_i, b_j;\r\n for (i = 0; i < a_l; ++i) {\r\n a_i = a[i];\r\n for (var j = 0; j < b_l; ++j) {\r\n b_j = b[j];\r\n product = a_i * b_j + r[i + j];\r\n carry = Math.floor(product / base);\r\n r[i + j] = product - carry * base;\r\n r[i + j + 1] += carry;\r\n }\r\n }\r\n trim(r);\r\n return r;\r\n }\r\n\r\n function multiplySmall(a, b) { // assumes a is array, b is number with |b| < BASE\r\n var l = a.length,\r\n r = new Array(l),\r\n base = BASE,\r\n carry = 0,\r\n product, i;\r\n for (i = 0; i < l; i++) {\r\n product = a[i] * b + carry;\r\n carry = Math.floor(product / base);\r\n r[i] = product - carry * base;\r\n }\r\n while (carry > 0) {\r\n r[i++] = carry % base;\r\n carry = Math.floor(carry / base);\r\n }\r\n return r;\r\n }\r\n\r\n function shiftLeft(x, n) {\r\n var r = [];\r\n while (n-- > 0) r.push(0);\r\n return r.concat(x);\r\n }\r\n\r\n function multiplyKaratsuba(x, y) {\r\n var n = Math.max(x.length, y.length);\r\n\r\n if (n <= 30) return multiplyLong(x, y);\r\n n = Math.ceil(n / 2);\r\n\r\n var b = x.slice(n),\r\n a = x.slice(0, n),\r\n d = y.slice(n),\r\n c = y.slice(0, n);\r\n\r\n var ac = multiplyKaratsuba(a, c),\r\n bd = multiplyKaratsuba(b, d),\r\n abcd = multiplyKaratsuba(addAny(a, b), addAny(c, d));\r\n\r\n var product = addAny(addAny(ac, shiftLeft(subtract(subtract(abcd, ac), bd), n)), shiftLeft(bd, 2 * n));\r\n trim(product);\r\n return product;\r\n }\r\n\r\n // The following function is derived from a surface fit of a graph plotting the performance difference\r\n // between long multiplication and karatsuba multiplication versus the lengths of the two arrays.\r\n function useKaratsuba(l1, l2) {\r\n return -0.012 * l1 - 0.012 * l2 + 0.000015 * l1 * l2 > 0;\r\n }\r\n\r\n BigInteger.prototype.multiply = function (v) {\r\n var n = parseValue(v),\r\n a = this.value, b = n.value,\r\n sign = this.sign !== n.sign,\r\n abs;\r\n if (n.isSmall) {\r\n if (b === 0) return Integer[0];\r\n if (b === 1) return this;\r\n if (b === -1) return this.negate();\r\n abs = Math.abs(b);\r\n if (abs < BASE) {\r\n return new BigInteger(multiplySmall(a, abs), sign);\r\n }\r\n b = smallToArray(abs);\r\n }\r\n if (useKaratsuba(a.length, b.length)) // Karatsuba is only faster for certain array sizes\r\n return new BigInteger(multiplyKaratsuba(a, b), sign);\r\n return new BigInteger(multiplyLong(a, b), sign);\r\n };\r\n\r\n BigInteger.prototype.times = BigInteger.prototype.multiply;\r\n\r\n function multiplySmallAndArray(a, b, sign) { // a >= 0\r\n if (a < BASE) {\r\n return new BigInteger(multiplySmall(b, a), sign);\r\n }\r\n return new BigInteger(multiplyLong(b, smallToArray(a)), sign);\r\n }\r\n SmallInteger.prototype._multiplyBySmall = function (a) {\r\n if (isPrecise(a.value * this.value)) {\r\n return new SmallInteger(a.value * this.value);\r\n }\r\n return multiplySmallAndArray(Math.abs(a.value), smallToArray(Math.abs(this.value)), this.sign !== a.sign);\r\n };\r\n BigInteger.prototype._multiplyBySmall = function (a) {\r\n if (a.value === 0) return Integer[0];\r\n if (a.value === 1) return this;\r\n if (a.value === -1) return this.negate();\r\n return multiplySmallAndArray(Math.abs(a.value), this.value, this.sign !== a.sign);\r\n };\r\n SmallInteger.prototype.multiply = function (v) {\r\n return parseValue(v)._multiplyBySmall(this);\r\n };\r\n SmallInteger.prototype.times = SmallInteger.prototype.multiply;\r\n\r\n NativeBigInt.prototype.multiply = function (v) {\r\n return new NativeBigInt(this.value * parseValue(v).value);\r\n }\r\n NativeBigInt.prototype.times = NativeBigInt.prototype.multiply;\r\n\r\n function square(a) {\r\n //console.assert(2 * BASE * BASE < MAX_INT);\r\n var l = a.length,\r\n r = createArray(l + l),\r\n base = BASE,\r\n product, carry, i, a_i, a_j;\r\n for (i = 0; i < l; i++) {\r\n a_i = a[i];\r\n carry = 0 - a_i * a_i;\r\n for (var j = i; j < l; j++) {\r\n a_j = a[j];\r\n product = 2 * (a_i * a_j) + r[i + j] + carry;\r\n carry = Math.floor(product / base);\r\n r[i + j] = product - carry * base;\r\n }\r\n r[i + l] = carry;\r\n }\r\n trim(r);\r\n return r;\r\n }\r\n\r\n BigInteger.prototype.square = function () {\r\n return new BigInteger(square(this.value), false);\r\n };\r\n\r\n SmallInteger.prototype.square = function () {\r\n var value = this.value * this.value;\r\n if (isPrecise(value)) return new SmallInteger(value);\r\n return new BigInteger(square(smallToArray(Math.abs(this.value))), false);\r\n };\r\n\r\n NativeBigInt.prototype.square = function (v) {\r\n return new NativeBigInt(this.value * this.value);\r\n }\r\n\r\n function divMod1(a, b) { // Left over from previous version. Performs faster than divMod2 on smaller input sizes.\r\n var a_l = a.length,\r\n b_l = b.length,\r\n base = BASE,\r\n result = createArray(b.length),\r\n divisorMostSignificantDigit = b[b_l - 1],\r\n // normalization\r\n lambda = Math.ceil(base / (2 * divisorMostSignificantDigit)),\r\n remainder = multiplySmall(a, lambda),\r\n divisor = multiplySmall(b, lambda),\r\n quotientDigit, shift, carry, borrow, i, l, q;\r\n if (remainder.length <= a_l) remainder.push(0);\r\n divisor.push(0);\r\n divisorMostSignificantDigit = divisor[b_l - 1];\r\n for (shift = a_l - b_l; shift >= 0; shift--) {\r\n quotientDigit = base - 1;\r\n if (remainder[shift + b_l] !== divisorMostSignificantDigit) {\r\n quotientDigit = Math.floor((remainder[shift + b_l] * base + remainder[shift + b_l - 1]) / divisorMostSignificantDigit);\r\n }\r\n // quotientDigit <= base - 1\r\n carry = 0;\r\n borrow = 0;\r\n l = divisor.length;\r\n for (i = 0; i < l; i++) {\r\n carry += quotientDigit * divisor[i];\r\n q = Math.floor(carry / base);\r\n borrow += remainder[shift + i] - (carry - q * base);\r\n carry = q;\r\n if (borrow < 0) {\r\n remainder[shift + i] = borrow + base;\r\n borrow = -1;\r\n } else {\r\n remainder[shift + i] = borrow;\r\n borrow = 0;\r\n }\r\n }\r\n while (borrow !== 0) {\r\n quotientDigit -= 1;\r\n carry = 0;\r\n for (i = 0; i < l; i++) {\r\n carry += remainder[shift + i] - base + divisor[i];\r\n if (carry < 0) {\r\n remainder[shift + i] = carry + base;\r\n carry = 0;\r\n } else {\r\n remainder[shift + i] = carry;\r\n carry = 1;\r\n }\r\n }\r\n borrow += carry;\r\n }\r\n result[shift] = quotientDigit;\r\n }\r\n // denormalization\r\n remainder = divModSmall(remainder, lambda)[0];\r\n return [arrayToSmall(result), arrayToSmall(remainder)];\r\n }\r\n\r\n function divMod2(a, b) { // Implementation idea shamelessly stolen from Silent Matt's library http://silentmatt.com/biginteger/\r\n // Performs faster than divMod1 on larger input sizes.\r\n var a_l = a.length,\r\n b_l = b.length,\r\n result = [],\r\n part = [],\r\n base = BASE,\r\n guess, xlen, highx, highy, check;\r\n while (a_l) {\r\n part.unshift(a[--a_l]);\r\n trim(part);\r\n if (compareAbs(part, b) < 0) {\r\n result.push(0);\r\n continue;\r\n }\r\n xlen = part.length;\r\n highx = part[xlen - 1] * base + part[xlen - 2];\r\n highy = b[b_l - 1] * base + b[b_l - 2];\r\n if (xlen > b_l) {\r\n highx = (highx + 1) * base;\r\n }\r\n guess = Math.ceil(highx / highy);\r\n do {\r\n check = multiplySmall(b, guess);\r\n if (compareAbs(check, part) <= 0) break;\r\n guess--;\r\n } while (guess);\r\n result.push(guess);\r\n part = subtract(part, check);\r\n }\r\n result.reverse();\r\n return [arrayToSmall(result), arrayToSmall(part)];\r\n }\r\n\r\n function divModSmall(value, lambda) {\r\n var length = value.length,\r\n quotient = createArray(length),\r\n base = BASE,\r\n i, q, remainder, divisor;\r\n remainder = 0;\r\n for (i = length - 1; i >= 0; --i) {\r\n divisor = remainder * base + value[i];\r\n q = truncate(divisor / lambda);\r\n remainder = divisor - q * lambda;\r\n quotient[i] = q | 0;\r\n }\r\n return [quotient, remainder | 0];\r\n }\r\n\r\n function divModAny(self, v) {\r\n var value, n = parseValue(v);\r\n if (supportsNativeBigInt) {\r\n return [new NativeBigInt(self.value / n.value), new NativeBigInt(self.value % n.value)];\r\n }\r\n var a = self.value, b = n.value;\r\n var quotient;\r\n if (b === 0) throw new Error(\"Cannot divide by zero\");\r\n if (self.isSmall) {\r\n if (n.isSmall) {\r\n return [new SmallInteger(truncate(a / b)), new SmallInteger(a % b)];\r\n }\r\n return [Integer[0], self];\r\n }\r\n if (n.isSmall) {\r\n if (b === 1) return [self, Integer[0]];\r\n if (b == -1) return [self.negate(), Integer[0]];\r\n var abs = Math.abs(b);\r\n if (abs < BASE) {\r\n value = divModSmall(a, abs);\r\n quotient = arrayToSmall(value[0]);\r\n var remainder = value[1];\r\n if (self.sign) remainder = -remainder;\r\n if (typeof quotient === \"number\") {\r\n if (self.sign !== n.sign) quotient = -quotient;\r\n return [new SmallInteger(quotient), new SmallInteger(remainder)];\r\n }\r\n return [new BigInteger(quotient, self.sign !== n.sign), new SmallInteger(remainder)];\r\n }\r\n b = smallToArray(abs);\r\n }\r\n var comparison = compareAbs(a, b);\r\n if (comparison === -1) return [Integer[0], self];\r\n if (comparison === 0) return [Integer[self.sign === n.sign ? 1 : -1], Integer[0]];\r\n\r\n // divMod1 is faster on smaller input sizes\r\n if (a.length + b.length <= 200)\r\n value = divMod1(a, b);\r\n else value = divMod2(a, b);\r\n\r\n quotient = value[0];\r\n var qSign = self.sign !== n.sign,\r\n mod = value[1],\r\n mSign = self.sign;\r\n if (typeof quotient === \"number\") {\r\n if (qSign) quotient = -quotient;\r\n quotient = new SmallInteger(quotient);\r\n } else quotient = new BigInteger(quotient, qSign);\r\n if (typeof mod === \"number\") {\r\n if (mSign) mod = -mod;\r\n mod = new SmallInteger(mod);\r\n } else mod = new BigInteger(mod, mSign);\r\n return [quotient, mod];\r\n }\r\n\r\n BigInteger.prototype.divmod = function (v) {\r\n var result = divModAny(this, v);\r\n return {\r\n quotient: result[0],\r\n remainder: result[1]\r\n };\r\n };\r\n NativeBigInt.prototype.divmod = SmallInteger.prototype.divmod = BigInteger.prototype.divmod;\r\n\r\n\r\n BigInteger.prototype.divide = function (v) {\r\n return divModAny(this, v)[0];\r\n };\r\n NativeBigInt.prototype.over = NativeBigInt.prototype.divide = function (v) {\r\n return new NativeBigInt(this.value / parseValue(v).value);\r\n };\r\n SmallInteger.prototype.over = SmallInteger.prototype.divide = BigInteger.prototype.over = BigInteger.prototype.divide;\r\n\r\n BigInteger.prototype.mod = function (v) {\r\n return divModAny(this, v)[1];\r\n };\r\n NativeBigInt.prototype.mod = NativeBigInt.prototype.remainder = function (v) {\r\n return new NativeBigInt(this.value % parseValue(v).value);\r\n };\r\n SmallInteger.prototype.remainder = SmallInteger.prototype.mod = BigInteger.prototype.remainder = BigInteger.prototype.mod;\r\n\r\n BigInteger.prototype.pow = function (v) {\r\n var n = parseValue(v),\r\n a = this.value,\r\n b = n.value,\r\n value, x, y;\r\n if (b === 0) return Integer[1];\r\n if (a === 0) return Integer[0];\r\n if (a === 1) return Integer[1];\r\n if (a === -1) return n.isEven() ? Integer[1] : Integer[-1];\r\n if (n.sign) {\r\n return Integer[0];\r\n }\r\n if (!n.isSmall) throw new Error(\"The exponent \" + n.toString() + \" is too large.\");\r\n if (this.isSmall) {\r\n if (isPrecise(value = Math.pow(a, b)))\r\n return new SmallInteger(truncate(value));\r\n }\r\n x = this;\r\n y = Integer[1];\r\n while (true) {\r\n if (b & 1 === 1) {\r\n y = y.times(x);\r\n --b;\r\n }\r\n if (b === 0) break;\r\n b /= 2;\r\n x = x.square();\r\n }\r\n return y;\r\n };\r\n SmallInteger.prototype.pow = BigInteger.prototype.pow;\r\n\r\n NativeBigInt.prototype.pow = function (v) {\r\n var n = parseValue(v);\r\n var a = this.value, b = n.value;\r\n var _0 = BigInt(0), _1 = BigInt(1), _2 = BigInt(2);\r\n if (b === _0) return Integer[1];\r\n if (a === _0) return Integer[0];\r\n if (a === _1) return Integer[1];\r\n if (a === BigInt(-1)) return n.isEven() ? Integer[1] : Integer[-1];\r\n if (n.isNegative()) return new NativeBigInt(_0);\r\n var x = this;\r\n var y = Integer[1];\r\n while (true) {\r\n if ((b & _1) === _1) {\r\n y = y.times(x);\r\n --b;\r\n }\r\n if (b === _0) break;\r\n b /= _2;\r\n x = x.square();\r\n }\r\n return y;\r\n }\r\n\r\n BigInteger.prototype.modPow = function (exp, mod) {\r\n exp = parseValue(exp);\r\n mod = parseValue(mod);\r\n if (mod.isZero()) throw new Error(\"Cannot take modPow with modulus 0\");\r\n var r = Integer[1],\r\n base = this.mod(mod);\r\n if (exp.isNegative()) {\r\n exp = exp.multiply(Integer[-1]);\r\n base = base.modInv(mod);\r\n }\r\n while (exp.isPositive()) {\r\n if (base.isZero()) return Integer[0];\r\n if (exp.isOdd()) r = r.multiply(base).mod(mod);\r\n exp = exp.divide(2);\r\n base = base.square().mod(mod);\r\n }\r\n return r;\r\n };\r\n NativeBigInt.prototype.modPow = SmallInteger.prototype.modPow = BigInteger.prototype.modPow;\r\n\r\n function compareAbs(a, b) {\r\n if (a.length !== b.length) {\r\n return a.length > b.length ? 1 : -1;\r\n }\r\n for (var i = a.length - 1; i >= 0; i--) {\r\n if (a[i] !== b[i]) return a[i] > b[i] ? 1 : -1;\r\n }\r\n return 0;\r\n }\r\n\r\n BigInteger.prototype.compareAbs = function (v) {\r\n var n = parseValue(v),\r\n a = this.value,\r\n b = n.value;\r\n if (n.isSmall) return 1;\r\n return compareAbs(a, b);\r\n };\r\n SmallInteger.prototype.compareAbs = function (v) {\r\n var n = parseValue(v),\r\n a = Math.abs(this.value),\r\n b = n.value;\r\n if (n.isSmall) {\r\n b = Math.abs(b);\r\n return a === b ? 0 : a > b ? 1 : -1;\r\n }\r\n return -1;\r\n };\r\n NativeBigInt.prototype.compareAbs = function (v) {\r\n var a = this.value;\r\n var b = parseValue(v).value;\r\n a = a >= 0 ? a : -a;\r\n b = b >= 0 ? b : -b;\r\n return a === b ? 0 : a > b ? 1 : -1;\r\n }\r\n\r\n BigInteger.prototype.compare = function (v) {\r\n // See discussion about comparison with Infinity:\r\n // https://github.com/peterolson/BigInteger.js/issues/61\r\n if (v === Infinity) {\r\n return -1;\r\n }\r\n if (v === -Infinity) {\r\n return 1;\r\n }\r\n\r\n var n = parseValue(v),\r\n a = this.value,\r\n b = n.value;\r\n if (this.sign !== n.sign) {\r\n return n.sign ? 1 : -1;\r\n }\r\n if (n.isSmall) {\r\n return this.sign ? -1 : 1;\r\n }\r\n return compareAbs(a, b) * (this.sign ? -1 : 1);\r\n };\r\n BigInteger.prototype.compareTo = BigInteger.prototype.compare;\r\n\r\n SmallInteger.prototype.compare = function (v) {\r\n if (v === Infinity) {\r\n return -1;\r\n }\r\n if (v === -Infinity) {\r\n return 1;\r\n }\r\n\r\n var n = parseValue(v),\r\n a = this.value,\r\n b = n.value;\r\n if (n.isSmall) {\r\n return a == b ? 0 : a > b ? 1 : -1;\r\n }\r\n if (a < 0 !== n.sign) {\r\n return a < 0 ? -1 : 1;\r\n }\r\n return a < 0 ? 1 : -1;\r\n };\r\n SmallInteger.prototype.compareTo = SmallInteger.prototype.compare;\r\n\r\n NativeBigInt.prototype.compare = function (v) {\r\n if (v === Infinity) {\r\n return -1;\r\n }\r\n if (v === -Infinity) {\r\n return 1;\r\n }\r\n var a = this.value;\r\n var b = parseValue(v).value;\r\n return a === b ? 0 : a > b ? 1 : -1;\r\n }\r\n NativeBigInt.prototype.compareTo = NativeBigInt.prototype.compare;\r\n\r\n BigInteger.prototype.equals = function (v) {\r\n return this.compare(v) === 0;\r\n };\r\n NativeBigInt.prototype.eq = NativeBigInt.prototype.equals = SmallInteger.prototype.eq = SmallInteger.prototype.equals = BigInteger.prototype.eq = BigInteger.prototype.equals;\r\n\r\n BigInteger.prototype.notEquals = function (v) {\r\n return this.compare(v) !== 0;\r\n };\r\n NativeBigInt.prototype.neq = NativeBigInt.prototype.notEquals = SmallInteger.prototype.neq = SmallInteger.prototype.notEquals = BigInteger.prototype.neq = BigInteger.prototype.notEquals;\r\n\r\n BigInteger.prototype.greater = function (v) {\r\n return this.compare(v) > 0;\r\n };\r\n NativeBigInt.prototype.gt = NativeBigInt.prototype.greater = SmallInteger.prototype.gt = SmallInteger.prototype.greater = BigInteger.prototype.gt = BigInteger.prototype.greater;\r\n\r\n BigInteger.prototype.lesser = function (v) {\r\n return this.compare(v) < 0;\r\n };\r\n NativeBigInt.prototype.lt = NativeBigInt.prototype.lesser = SmallInteger.prototype.lt = SmallInteger.prototype.lesser = BigInteger.prototype.lt = BigInteger.prototype.lesser;\r\n\r\n BigInteger.prototype.greaterOrEquals = function (v) {\r\n return this.compare(v) >= 0;\r\n };\r\n NativeBigInt.prototype.geq = NativeBigInt.prototype.greaterOrEquals = SmallInteger.prototype.geq = SmallInteger.prototype.greaterOrEquals = BigInteger.prototype.geq = BigInteger.prototype.greaterOrEquals;\r\n\r\n BigInteger.prototype.lesserOrEquals = function (v) {\r\n return this.compare(v) <= 0;\r\n };\r\n NativeBigInt.prototype.leq = NativeBigInt.prototype.lesserOrEquals = SmallInteger.prototype.leq = SmallInteger.prototype.lesserOrEquals = BigInteger.prototype.leq = BigInteger.prototype.lesserOrEquals;\r\n\r\n BigInteger.prototype.isEven = function () {\r\n return (this.value[0] & 1) === 0;\r\n };\r\n SmallInteger.prototype.isEven = function () {\r\n return (this.value & 1) === 0;\r\n };\r\n NativeBigInt.prototype.isEven = function () {\r\n return (this.value & BigInt(1)) === BigInt(0);\r\n }\r\n\r\n BigInteger.prototype.isOdd = function () {\r\n return (this.value[0] & 1) === 1;\r\n };\r\n SmallInteger.prototype.isOdd = function () {\r\n return (this.value & 1) === 1;\r\n };\r\n NativeBigInt.prototype.isOdd = function () {\r\n return (this.value & BigInt(1)) === BigInt(1);\r\n }\r\n\r\n BigInteger.prototype.isPositive = function () {\r\n return !this.sign;\r\n };\r\n SmallInteger.prototype.isPositive = function () {\r\n return this.value > 0;\r\n };\r\n NativeBigInt.prototype.isPositive = SmallInteger.prototype.isPositive;\r\n\r\n BigInteger.prototype.isNegative = function () {\r\n return this.sign;\r\n };\r\n SmallInteger.prototype.isNegative = function () {\r\n return this.value < 0;\r\n };\r\n NativeBigInt.prototype.isNegative = SmallInteger.prototype.isNegative;\r\n\r\n BigInteger.prototype.isUnit = function () {\r\n return false;\r\n };\r\n SmallInteger.prototype.isUnit = function () {\r\n return Math.abs(this.value) === 1;\r\n };\r\n NativeBigInt.prototype.isUnit = function () {\r\n return this.abs().value === BigInt(1);\r\n }\r\n\r\n BigInteger.prototype.isZero = function () {\r\n return false;\r\n };\r\n SmallInteger.prototype.isZero = function () {\r\n return this.value === 0;\r\n };\r\n NativeBigInt.prototype.isZero = function () {\r\n return this.value === BigInt(0);\r\n }\r\n\r\n BigInteger.prototype.isDivisibleBy = function (v) {\r\n var n = parseValue(v);\r\n if (n.isZero()) return false;\r\n if (n.isUnit()) return true;\r\n if (n.compareAbs(2) === 0) return this.isEven();\r\n return this.mod(n).isZero();\r\n };\r\n NativeBigInt.prototype.isDivisibleBy = SmallInteger.prototype.isDivisibleBy = BigInteger.prototype.isDivisibleBy;\r\n\r\n function isBasicPrime(v) {\r\n var n = v.abs();\r\n if (n.isUnit()) return false;\r\n if (n.equals(2) || n.equals(3) || n.equals(5)) return true;\r\n if (n.isEven() || n.isDivisibleBy(3) || n.isDivisibleBy(5)) return false;\r\n if (n.lesser(49)) return true;\r\n // we don't know if it's prime: let the other functions figure it out\r\n }\r\n\r\n function millerRabinTest(n, a) {\r\n var nPrev = n.prev(),\r\n b = nPrev,\r\n r = 0,\r\n d, t, i, x;\r\n while (b.isEven()) b = b.divide(2), r++;\r\n next: for (i = 0; i < a.length; i++) {\r\n if (n.lesser(a[i])) continue;\r\n x = bigInt(a[i]).modPow(b, n);\r\n if (x.isUnit() || x.equals(nPrev)) continue;\r\n for (d = r - 1; d != 0; d--) {\r\n x = x.square().mod(n);\r\n if (x.isUnit()) return false;\r\n if (x.equals(nPrev)) continue next;\r\n }\r\n return false;\r\n }\r\n return true;\r\n }\r\n\r\n // Set \"strict\" to true to force GRH-supported lower bound of 2*log(N)^2\r\n BigInteger.prototype.isPrime = function (strict) {\r\n var isPrime = isBasicPrime(this);\r\n if (isPrime !== undefined) return isPrime;\r\n var n = this.abs();\r\n var bits = n.bitLength();\r\n if (bits <= 64)\r\n return millerRabinTest(n, [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37]);\r\n var logN = Math.log(2) * bits.toJSNumber();\r\n var t = Math.ceil((strict === true) ? (2 * Math.pow(logN, 2)) : logN);\r\n for (var a = [], i = 0; i < t; i++) {\r\n a.push(bigInt(i + 2));\r\n }\r\n return millerRabinTest(n, a);\r\n };\r\n NativeBigInt.prototype.isPrime = SmallInteger.prototype.isPrime = BigInteger.prototype.isPrime;\r\n\r\n BigInteger.prototype.isProbablePrime = function (iterations, rng) {\r\n var isPrime = isBasicPrime(this);\r\n if (isPrime !== undefined) return isPrime;\r\n var n = this.abs();\r\n var t = iterations === undefined ? 5 : iterations;\r\n for (var a = [], i = 0; i < t; i++) {\r\n a.push(bigInt.randBetween(2, n.minus(2), rng));\r\n }\r\n return millerRabinTest(n, a);\r\n };\r\n NativeBigInt.prototype.isProbablePrime = SmallInteger.prototype.isProbablePrime = BigInteger.prototype.isProbablePrime;\r\n\r\n BigInteger.prototype.modInv = function (n) {\r\n var t = bigInt.zero, newT = bigInt.one, r = parseValue(n), newR = this.abs(), q, lastT, lastR;\r\n while (!newR.isZero()) {\r\n q = r.divide(newR);\r\n lastT = t;\r\n lastR = r;\r\n t = newT;\r\n r = newR;\r\n newT = lastT.subtract(q.multiply(newT));\r\n newR = lastR.subtract(q.multiply(newR));\r\n }\r\n if (!r.isUnit()) throw new Error(this.toString() + \" and \" + n.toString() + \" are not co-prime\");\r\n if (t.compare(0) === -1) {\r\n t = t.add(n);\r\n }\r\n if (this.isNegative()) {\r\n return t.negate();\r\n }\r\n return t;\r\n };\r\n\r\n NativeBigInt.prototype.modInv = SmallInteger.prototype.modInv = BigInteger.prototype.modInv;\r\n\r\n BigInteger.prototype.next = function () {\r\n var value = this.value;\r\n if (this.sign) {\r\n return subtractSmall(value, 1, this.sign);\r\n }\r\n return new BigInteger(addSmall(value, 1), this.sign);\r\n };\r\n SmallInteger.prototype.next = function () {\r\n var value = this.value;\r\n if (value + 1 < MAX_INT) return new SmallInteger(value + 1);\r\n return new BigInteger(MAX_INT_ARR, false);\r\n };\r\n NativeBigInt.prototype.next = function () {\r\n return new NativeBigInt(this.value + BigInt(1));\r\n }\r\n\r\n BigInteger.prototype.prev = function () {\r\n var value = this.value;\r\n if (this.sign) {\r\n return new BigInteger(addSmall(value, 1), true);\r\n }\r\n return subtractSmall(value, 1, this.sign);\r\n };\r\n SmallInteger.prototype.prev = function () {\r\n var value = this.value;\r\n if (value - 1 > -MAX_INT) return new SmallInteger(value - 1);\r\n return new BigInteger(MAX_INT_ARR, true);\r\n };\r\n NativeBigInt.prototype.prev = function () {\r\n return new NativeBigInt(this.value - BigInt(1));\r\n }\r\n\r\n var powersOfTwo = [1];\r\n while (2 * powersOfTwo[powersOfTwo.length - 1] <= BASE) powersOfTwo.push(2 * powersOfTwo[powersOfTwo.length - 1]);\r\n var powers2Length = powersOfTwo.length, highestPower2 = powersOfTwo[powers2Length - 1];\r\n\r\n function shift_isSmall(n) {\r\n return Math.abs(n) <= BASE;\r\n }\r\n\r\n BigInteger.prototype.shiftLeft = function (v) {\r\n var n = parseValue(v).toJSNumber();\r\n if (!shift_isSmall(n)) {\r\n throw new Error(String(n) + \" is too large for shifting.\");\r\n }\r\n if (n < 0) return this.shiftRight(-n);\r\n var result = this;\r\n if (result.isZero()) return result;\r\n while (n >= powers2Length) {\r\n result = result.multiply(highestPower2);\r\n n -= powers2Length - 1;\r\n }\r\n return result.multiply(powersOfTwo[n]);\r\n };\r\n NativeBigInt.prototype.shiftLeft = SmallInteger.prototype.shiftLeft = BigInteger.prototype.shiftLeft;\r\n\r\n BigInteger.prototype.shiftRight = function (v) {\r\n var remQuo;\r\n var n = parseValue(v).toJSNumber();\r\n if (!shift_isSmall(n)) {\r\n throw new Error(String(n) + \" is too large for shifting.\");\r\n }\r\n if (n < 0) return this.shiftLeft(-n);\r\n var result = this;\r\n while (n >= powers2Length) {\r\n if (result.isZero() || (result.isNegative() && result.isUnit())) return result;\r\n remQuo = divModAny(result, highestPower2);\r\n result = remQuo[1].isNegative() ? remQuo[0].prev() : remQuo[0];\r\n n -= powers2Length - 1;\r\n }\r\n remQuo = divModAny(result, powersOfTwo[n]);\r\n return remQuo[1].isNegative() ? remQuo[0].prev() : remQuo[0];\r\n };\r\n NativeBigInt.prototype.shiftRight = SmallInteger.prototype.shiftRight = BigInteger.prototype.shiftRight;\r\n\r\n function bitwise(x, y, fn) {\r\n y = parseValue(y);\r\n var xSign = x.isNegative(), ySign = y.isNegative();\r\n var xRem = xSign ? x.not() : x,\r\n yRem = ySign ? y.not() : y;\r\n var xDigit = 0, yDigit = 0;\r\n var xDivMod = null, yDivMod = null;\r\n var result = [];\r\n while (!xRem.isZero() || !yRem.isZero()) {\r\n xDivMod = divModAny(xRem, highestPower2);\r\n xDigit = xDivMod[1].toJSNumber();\r\n if (xSign) {\r\n xDigit = highestPower2 - 1 - xDigit; // two's complement for negative numbers\r\n }\r\n\r\n yDivMod = divModAny(yRem, highestPower2);\r\n yDigit = yDivMod[1].toJSNumber();\r\n if (ySign) {\r\n yDigit = highestPower2 - 1 - yDigit; // two's complement for negative numbers\r\n }\r\n\r\n xRem = xDivMod[0];\r\n yRem = yDivMod[0];\r\n result.push(fn(xDigit, yDigit));\r\n }\r\n var sum = fn(xSign ? 1 : 0, ySign ? 1 : 0) !== 0 ? bigInt(-1) : bigInt(0);\r\n for (var i = result.length - 1; i >= 0; i -= 1) {\r\n sum = sum.multiply(highestPower2).add(bigInt(result[i]));\r\n }\r\n return sum;\r\n }\r\n\r\n BigInteger.prototype.not = function () {\r\n return this.negate().prev();\r\n };\r\n NativeBigInt.prototype.not = SmallInteger.prototype.not = BigInteger.prototype.not;\r\n\r\n BigInteger.prototype.and = function (n) {\r\n return bitwise(this, n, function (a, b) { return a & b; });\r\n };\r\n NativeBigInt.prototype.and = SmallInteger.prototype.and = BigInteger.prototype.and;\r\n\r\n BigInteger.prototype.or = function (n) {\r\n return bitwise(this, n, function (a, b) { return a | b; });\r\n };\r\n NativeBigInt.prototype.or = SmallInteger.prototype.or = BigInteger.prototype.or;\r\n\r\n BigInteger.prototype.xor = function (n) {\r\n return bitwise(this, n, function (a, b) { return a ^ b; });\r\n };\r\n NativeBigInt.prototype.xor = SmallInteger.prototype.xor = BigInteger.prototype.xor;\r\n\r\n var LOBMASK_I = 1 << 30, LOBMASK_BI = (BASE & -BASE) * (BASE & -BASE) | LOBMASK_I;\r\n function roughLOB(n) { // get lowestOneBit (rough)\r\n // SmallInteger: return Min(lowestOneBit(n), 1 << 30)\r\n // BigInteger: return Min(lowestOneBit(n), 1 << 14) [BASE=1e7]\r\n var v = n.value,\r\n x = typeof v === \"number\" ? v | LOBMASK_I :\r\n typeof v === \"bigint\" ? v | BigInt(LOBMASK_I) :\r\n v[0] + v[1] * BASE | LOBMASK_BI;\r\n return x & -x;\r\n }\r\n\r\n function integerLogarithm(value, base) {\r\n if (base.compareTo(value) <= 0) {\r\n var tmp = integerLogarithm(value, base.square(base));\r\n var p = tmp.p;\r\n var e = tmp.e;\r\n var t = p.multiply(base);\r\n return t.compareTo(value) <= 0 ? { p: t, e: e * 2 + 1 } : { p: p, e: e * 2 };\r\n }\r\n return { p: bigInt(1), e: 0 };\r\n }\r\n\r\n BigInteger.prototype.bitLength = function () {\r\n var n = this;\r\n if (n.compareTo(bigInt(0)) < 0) {\r\n n = n.negate().subtract(bigInt(1));\r\n }\r\n if (n.compareTo(bigInt(0)) === 0) {\r\n return bigInt(0);\r\n }\r\n return bigInt(integerLogarithm(n, bigInt(2)).e).add(bigInt(1));\r\n }\r\n NativeBigInt.prototype.bitLength = SmallInteger.prototype.bitLength = BigInteger.prototype.bitLength;\r\n\r\n function max(a, b) {\r\n a = parseValue(a);\r\n b = parseValue(b);\r\n return a.greater(b) ? a : b;\r\n }\r\n function min(a, b) {\r\n a = parseValue(a);\r\n b = parseValue(b);\r\n return a.lesser(b) ? a : b;\r\n }\r\n function gcd(a, b) {\r\n a = parseValue(a).abs();\r\n b = parseValue(b).abs();\r\n if (a.equals(b)) return a;\r\n if (a.isZero()) return b;\r\n if (b.isZero()) return a;\r\n var c = Integer[1], d, t;\r\n while (a.isEven() && b.isEven()) {\r\n d = min(roughLOB(a), roughLOB(b));\r\n a = a.divide(d);\r\n b = b.divide(d);\r\n c = c.multiply(d);\r\n }\r\n while (a.isEven()) {\r\n a = a.divide(roughLOB(a));\r\n }\r\n do {\r\n while (b.isEven()) {\r\n b = b.divide(roughLOB(b));\r\n }\r\n if (a.greater(b)) {\r\n t = b; b = a; a = t;\r\n }\r\n b = b.subtract(a);\r\n } while (!b.isZero());\r\n return c.isUnit() ? a : a.multiply(c);\r\n }\r\n function lcm(a, b) {\r\n a = parseValue(a).abs();\r\n b = parseValue(b).abs();\r\n return a.divide(gcd(a, b)).multiply(b);\r\n }\r\n function randBetween(a, b, rng) {\r\n a = parseValue(a);\r\n b = parseValue(b);\r\n var usedRNG = rng || Math.random;\r\n var low = min(a, b), high = max(a, b);\r\n var range = high.subtract(low).add(1);\r\n if (range.isSmall) return low.add(Math.floor(usedRNG() * range));\r\n var digits = toBase(range, BASE).value;\r\n var result = [], restricted = true;\r\n for (var i = 0; i < digits.length; i++) {\r\n var top = restricted ? digits[i] + (i + 1 < digits.length ? digits[i + 1] / BASE : 0) : BASE;\r\n var digit = truncate(usedRNG() * top);\r\n result.push(digit);\r\n if (digit < digits[i]) restricted = false;\r\n }\r\n return low.add(Integer.fromArray(result, BASE, false));\r\n }\r\n\r\n var parseBase = function (text, base, alphabet, caseSensitive) {\r\n alphabet = alphabet || DEFAULT_ALPHABET;\r\n text = String(text);\r\n if (!caseSensitive) {\r\n text = text.toLowerCase();\r\n alphabet = alphabet.toLowerCase();\r\n }\r\n var length = text.length;\r\n var i;\r\n var absBase = Math.abs(base);\r\n var alphabetValues = {};\r\n for (i = 0; i < alphabet.length; i++) {\r\n alphabetValues[alphabet[i]] = i;\r\n }\r\n for (i = 0; i < length; i++) {\r\n var c = text[i];\r\n if (c === \"-\") continue;\r\n if (c in alphabetValues) {\r\n if (alphabetValues[c] >= absBase) {\r\n if (c === \"1\" && absBase === 1) continue;\r\n throw new Error(c + \" is not a valid digit in base \" + base + \".\");\r\n }\r\n }\r\n }\r\n base = parseValue(base);\r\n var digits = [];\r\n var isNegative = text[0] === \"-\";\r\n for (i = isNegative ? 1 : 0; i < text.length; i++) {\r\n var c = text[i];\r\n if (c in alphabetValues) digits.push(parseValue(alphabetValues[c]));\r\n else if (c === \"<\") {\r\n var start = i;\r\n do { i++; } while (text[i] !== \">\" && i < text.length);\r\n digits.push(parseValue(text.slice(start + 1, i)));\r\n }\r\n else throw new Error(c + \" is not a valid character\");\r\n }\r\n return parseBaseFromArray(digits, base, isNegative);\r\n };\r\n\r\n function parseBaseFromArray(digits, base, isNegative) {\r\n var val = Integer[0], pow = Integer[1], i;\r\n for (i = digits.length - 1; i >= 0; i--) {\r\n val = val.add(digits[i].times(pow));\r\n pow = pow.times(base);\r\n }\r\n return isNegative ? val.negate() : val;\r\n }\r\n\r\n function stringify(digit, alphabet) {\r\n alphabet = alphabet || DEFAULT_ALPHABET;\r\n if (digit < alphabet.length) {\r\n return alphabet[digit];\r\n }\r\n return \"<\" + digit + \">\";\r\n }\r\n\r\n function toBase(n, base) {\r\n base = bigInt(base);\r\n if (base.isZero()) {\r\n if (n.isZero()) return { value: [0], isNegative: false };\r\n throw new Error(\"Cannot convert nonzero numbers to base 0.\");\r\n }\r\n if (base.equals(-1)) {\r\n if (n.isZero()) return { value: [0], isNegative: false };\r\n if (n.isNegative())\r\n return {\r\n value: [].concat.apply([], Array.apply(null, Array(-n.toJSNumber()))\r\n .map(Array.prototype.valueOf, [1, 0])\r\n ),\r\n isNegative: false\r\n };\r\n\r\n var arr = Array.apply(null, Array(n.toJSNumber() - 1))\r\n .map(Array.prototype.valueOf, [0, 1]);\r\n arr.unshift([1]);\r\n return {\r\n value: [].concat.apply([], arr),\r\n isNegative: false\r\n };\r\n }\r\n\r\n var neg = false;\r\n if (n.isNegative() && base.isPositive()) {\r\n neg = true;\r\n n = n.abs();\r\n }\r\n if (base.isUnit()) {\r\n if (n.isZero()) return { value: [0], isNegative: false };\r\n\r\n return {\r\n value: Array.apply(null, Array(n.toJSNumber()))\r\n .map(Number.prototype.valueOf, 1),\r\n isNegative: neg\r\n };\r\n }\r\n var out = [];\r\n var left = n, divmod;\r\n while (left.isNegative() || left.compareAbs(base) >= 0) {\r\n divmod = left.divmod(base);\r\n left = divmod.quotient;\r\n var digit = divmod.remainder;\r\n if (digit.isNegative()) {\r\n digit = base.minus(digit).abs();\r\n left = left.next();\r\n }\r\n out.push(digit.toJSNumber());\r\n }\r\n out.push(left.toJSNumber());\r\n return { value: out.reverse(), isNegative: neg };\r\n }\r\n\r\n function toBaseString(n, base, alphabet) {\r\n var arr = toBase(n, base);\r\n return (arr.isNegative ? \"-\" : \"\") + arr.value.map(function (x) {\r\n return stringify(x, alphabet);\r\n }).join('');\r\n }\r\n\r\n BigInteger.prototype.toArray = function (radix) {\r\n return toBase(this, radix);\r\n };\r\n\r\n SmallInteger.prototype.toArray = function (radix) {\r\n return toBase(this, radix);\r\n };\r\n\r\n NativeBigInt.prototype.toArray = function (radix) {\r\n return toBase(this, radix);\r\n };\r\n\r\n BigInteger.prototype.toString = function (radix, alphabet) {\r\n if (radix === undefined) radix = 10;\r\n if (radix !== 10 || alphabet) return toBaseString(this, radix, alphabet);\r\n var v = this.value, l = v.length, str = String(v[--l]), zeros = \"0000000\", digit;\r\n while (--l >= 0) {\r\n digit = String(v[l]);\r\n str += zeros.slice(digit.length) + digit;\r\n }\r\n var sign = this.sign ? \"-\" : \"\";\r\n return sign + str;\r\n };\r\n\r\n SmallInteger.prototype.toString = function (radix, alphabet) {\r\n if (radix === undefined) radix = 10;\r\n if (radix != 10 || alphabet) return toBaseString(this, radix, alphabet);\r\n return String(this.value);\r\n };\r\n\r\n NativeBigInt.prototype.toString = SmallInteger.prototype.toString;\r\n\r\n NativeBigInt.prototype.toJSON = BigInteger.prototype.toJSON = SmallInteger.prototype.toJSON = function () { return this.toString(); }\r\n\r\n BigInteger.prototype.valueOf = function () {\r\n return parseInt(this.toString(), 10);\r\n };\r\n BigInteger.prototype.toJSNumber = BigInteger.prototype.valueOf;\r\n\r\n SmallInteger.prototype.valueOf = function () {\r\n return this.value;\r\n };\r\n SmallInteger.prototype.toJSNumber = SmallInteger.prototype.valueOf;\r\n NativeBigInt.prototype.valueOf = NativeBigInt.prototype.toJSNumber = function () {\r\n return parseInt(this.toString(), 10);\r\n }\r\n\r\n function parseStringValue(v) {\r\n if (isPrecise(+v)) {\r\n var x = +v;\r\n if (x === truncate(x))\r\n return supportsNativeBigInt ? new NativeBigInt(BigInt(x)) : new SmallInteger(x);\r\n throw new Error(\"Invalid integer: \" + v);\r\n }\r\n var sign = v[0] === \"-\";\r\n if (sign) v = v.slice(1);\r\n var split = v.split(/e/i);\r\n if (split.length > 2) throw new Error(\"Invalid integer: \" + split.join(\"e\"));\r\n if (split.length === 2) {\r\n var exp = split[1];\r\n if (exp[0] === \"+\") exp = exp.slice(1);\r\n exp = +exp;\r\n if (exp !== truncate(exp) || !isPrecise(exp)) throw new Error(\"Invalid integer: \" + exp + \" is not a valid exponent.\");\r\n var text = split[0];\r\n var decimalPlace = text.indexOf(\".\");\r\n if (decimalPlace >= 0) {\r\n exp -= text.length - decimalPlace - 1;\r\n text = text.slice(0, decimalPlace) + text.slice(decimalPlace + 1);\r\n }\r\n if (exp < 0) throw new Error(\"Cannot include negative exponent part for integers\");\r\n text += (new Array(exp + 1)).join(\"0\");\r\n v = text;\r\n }\r\n var isValid = /^([0-9][0-9]*)$/.test(v);\r\n if (!isValid) throw new Error(\"Invalid integer: \" + v);\r\n if (supportsNativeBigInt) {\r\n return new NativeBigInt(BigInt(sign ? \"-\" + v : v));\r\n }\r\n var r = [], max = v.length, l = LOG_BASE, min = max - l;\r\n while (max > 0) {\r\n r.push(+v.slice(min, max));\r\n min -= l;\r\n if (min < 0) min = 0;\r\n max -= l;\r\n }\r\n trim(r);\r\n return new BigInteger(r, sign);\r\n }\r\n\r\n function parseNumberValue(v) {\r\n if (supportsNativeBigInt) {\r\n return new NativeBigInt(BigInt(v));\r\n }\r\n if (isPrecise(v)) {\r\n if (v !== truncate(v)) throw new Error(v + \" is not an integer.\");\r\n return new SmallInteger(v);\r\n }\r\n return parseStringValue(v.toString());\r\n }\r\n\r\n function parseValue(v) {\r\n if (typeof v === \"number\") {\r\n return parseNumberValue(v);\r\n }\r\n if (typeof v === \"string\") {\r\n return parseStringValue(v);\r\n }\r\n if (typeof v === \"bigint\") {\r\n return new NativeBigInt(v);\r\n }\r\n return v;\r\n }\r\n // Pre-define numbers in range [-999,999]\r\n for (var i = 0; i < 1000; i++) {\r\n Integer[i] = parseValue(i);\r\n if (i > 0) Integer[-i] = parseValue(-i);\r\n }\r\n // Backwards compatibility\r\n Integer.one = Integer[1];\r\n Integer.zero = Integer[0];\r\n Integer.minusOne = Integer[-1];\r\n Integer.max = max;\r\n Integer.min = min;\r\n Integer.gcd = gcd;\r\n Integer.lcm = lcm;\r\n Integer.isInstance = function (x) { return x instanceof BigInteger || x instanceof SmallInteger || x instanceof NativeBigInt; };\r\n Integer.randBetween = randBetween;\r\n\r\n Integer.fromArray = function (digits, base, isNegative) {\r\n return parseBaseFromArray(digits.map(parseValue), parseValue(base || 10), isNegative);\r\n };\r\n\r\n return Integer;\r\n})();\r\n\r\n// Node.js check\r\nif (typeof module !== \"undefined\" && module.hasOwnProperty(\"exports\")) {\r\n module.exports = bigInt;\r\n}\r\n\r\n//amd check\r\nif (typeof define === \"function\" && define.amd) {\r\n define( function () {\r\n return bigInt;\r\n });\r\n}\r\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/*<replacement>*/\n\nvar Buffer = require('safe-buffer').Buffer;\n/*</replacement>*/\n\nvar isEncoding = Buffer.isEncoding || function (encoding) {\n encoding = '' + encoding;\n switch (encoding && encoding.toLowerCase()) {\n case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':\n return true;\n default:\n return false;\n }\n};\n\nfunction _normalizeEncoding(enc) {\n if (!enc) return 'utf8';\n var retried;\n while (true) {\n switch (enc) {\n case 'utf8':\n case 'utf-8':\n return 'utf8';\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return 'utf16le';\n case 'latin1':\n case 'binary':\n return 'latin1';\n case 'base64':\n case 'ascii':\n case 'hex':\n return enc;\n default:\n if (retried) return; // undefined\n enc = ('' + enc).toLowerCase();\n retried = true;\n }\n }\n};\n\n// Do not cache `Buffer.isEncoding` when checking encoding names as some\n// modules monkey-patch it to support additional encodings\nfunction normalizeEncoding(enc) {\n var nenc = _normalizeEncoding(enc);\n if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);\n return nenc || enc;\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters.\nexports.StringDecoder = StringDecoder;\nfunction StringDecoder(encoding) {\n this.encoding = normalizeEncoding(encoding);\n var nb;\n switch (this.encoding) {\n case 'utf16le':\n this.text = utf16Text;\n this.end = utf16End;\n nb = 4;\n break;\n case 'utf8':\n this.fillLast = utf8FillLast;\n nb = 4;\n break;\n case 'base64':\n this.text = base64Text;\n this.end = base64End;\n nb = 3;\n break;\n default:\n this.write = simpleWrite;\n this.end = simpleEnd;\n return;\n }\n this.lastNeed = 0;\n this.lastTotal = 0;\n this.lastChar = Buffer.allocUnsafe(nb);\n}\n\nStringDecoder.prototype.write = function (buf) {\n if (buf.length === 0) return '';\n var r;\n var i;\n if (this.lastNeed) {\n r = this.fillLast(buf);\n if (r === undefined) return '';\n i = this.lastNeed;\n this.lastNeed = 0;\n } else {\n i = 0;\n }\n if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);\n return r || '';\n};\n\nStringDecoder.prototype.end = utf8End;\n\n// Returns only complete characters in a Buffer\nStringDecoder.prototype.text = utf8Text;\n\n// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer\nStringDecoder.prototype.fillLast = function (buf) {\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);\n this.lastNeed -= buf.length;\n};\n\n// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a\n// continuation byte. If an invalid byte is detected, -2 is returned.\nfunction utf8CheckByte(byte) {\n if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;\n return byte >> 6 === 0x02 ? -1 : -2;\n}\n\n// Checks at most 3 bytes at the end of a Buffer in order to detect an\n// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)\n// needed to complete the UTF-8 character (if applicable) are returned.\nfunction utf8CheckIncomplete(self, buf, i) {\n var j = buf.length - 1;\n if (j < i) return 0;\n var nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 1;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 2;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) {\n if (nb === 2) nb = 0;else self.lastNeed = nb - 3;\n }\n return nb;\n }\n return 0;\n}\n\n// Validates as many continuation bytes for a multi-byte UTF-8 character as\n// needed or are available. If we see a non-continuation byte where we expect\n// one, we \"replace\" the validated continuation bytes we've seen so far with\n// a single UTF-8 replacement character ('\\ufffd'), to match v8's UTF-8 decoding\n// behavior. The continuation byte check is included three times in the case\n// where all of the continuation bytes for a character exist in the same buffer.\n// It is also done this way as a slight performance increase instead of using a\n// loop.\nfunction utf8CheckExtraBytes(self, buf, p) {\n if ((buf[0] & 0xC0) !== 0x80) {\n self.lastNeed = 0;\n return '\\ufffd';\n }\n if (self.lastNeed > 1 && buf.length > 1) {\n if ((buf[1] & 0xC0) !== 0x80) {\n self.lastNeed = 1;\n return '\\ufffd';\n }\n if (self.lastNeed > 2 && buf.length > 2) {\n if ((buf[2] & 0xC0) !== 0x80) {\n self.lastNeed = 2;\n return '\\ufffd';\n }\n }\n }\n}\n\n// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.\nfunction utf8FillLast(buf) {\n var p = this.lastTotal - this.lastNeed;\n var r = utf8CheckExtraBytes(this, buf, p);\n if (r !== undefined) return r;\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, p, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, p, 0, buf.length);\n this.lastNeed -= buf.length;\n}\n\n// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a\n// partial character, the character's bytes are buffered until the required\n// number of bytes are available.\nfunction utf8Text(buf, i) {\n var total = utf8CheckIncomplete(this, buf, i);\n if (!this.lastNeed) return buf.toString('utf8', i);\n this.lastTotal = total;\n var end = buf.length - (total - this.lastNeed);\n buf.copy(this.lastChar, 0, end);\n return buf.toString('utf8', i, end);\n}\n\n// For UTF-8, a replacement character is added when ending on a partial\n// character.\nfunction utf8End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + '\\ufffd';\n return r;\n}\n\n// UTF-16LE typically needs two bytes per character, but even if we have an even\n// number of bytes available, we need to check if we end on a leading/high\n// surrogate. In that case, we need to wait for the next two bytes in order to\n// decode the last character properly.\nfunction utf16Text(buf, i) {\n if ((buf.length - i) % 2 === 0) {\n var r = buf.toString('utf16le', i);\n if (r) {\n var c = r.charCodeAt(r.length - 1);\n if (c >= 0xD800 && c <= 0xDBFF) {\n this.lastNeed = 2;\n this.lastTotal = 4;\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n return r.slice(0, -1);\n }\n }\n return r;\n }\n this.lastNeed = 1;\n this.lastTotal = 2;\n this.lastChar[0] = buf[buf.length - 1];\n return buf.toString('utf16le', i, buf.length - 1);\n}\n\n// For UTF-16LE we do not explicitly append special replacement characters if we\n// end on a partial character, we simply let v8 handle that.\nfunction utf16End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) {\n var end = this.lastTotal - this.lastNeed;\n return r + this.lastChar.toString('utf16le', 0, end);\n }\n return r;\n}\n\nfunction base64Text(buf, i) {\n var n = (buf.length - i) % 3;\n if (n === 0) return buf.toString('base64', i);\n this.lastNeed = 3 - n;\n this.lastTotal = 3;\n if (n === 1) {\n this.lastChar[0] = buf[buf.length - 1];\n } else {\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n }\n return buf.toString('base64', i, buf.length - n);\n}\n\nfunction base64End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);\n return r;\n}\n\n// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)\nfunction simpleWrite(buf) {\n return buf.toString(this.encoding);\n}\n\nfunction simpleEnd(buf) {\n return buf && buf.length ? this.write(buf) : '';\n}","\"use strict\";\n// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Varint = void 0;\nconst big_integer_1 = __importDefault(require(\"big-integer\"));\nconst buffer_1 = require(\"buffer\");\nclass Varint {\n /**\n * Decodes a varint from a buffer\n *\n * @param buffer\n */\n static decode(buffer) {\n let counter = 0;\n let shift = 0;\n let b;\n let result = big_integer_1.default.zero;\n do {\n if (counter >= buffer.length) {\n throw new RangeError('Could not decode varint');\n }\n b = buffer[counter++];\n const value = (shift < 28) ? (b & 0x7f) << shift : (b & 0x7f) * Math.pow(2, shift);\n result = result.add(value);\n shift += 7;\n } while (b >= 0x80);\n return result;\n }\n /**\n * Encodes a value into a varint encoded buffer\n *\n * @param value\n */\n static encode(value) {\n if (typeof value === 'number') {\n value = big_integer_1.default.zero.add(value);\n }\n const out = [];\n let offset = 0;\n while (value.greaterOrEquals(Math.pow(2, 31))) {\n out[offset++] = value.and(0xFF).or(0x80).toJSNumber();\n value = value.divide(128);\n }\n while (value.and(~0x7F).greater(0)) {\n out[offset++] = value.and(0xFF).or(0x80).toJSNumber();\n value = value.shiftRight(7);\n }\n out[offset] = value.or(0).toJSNumber();\n return buffer_1.Buffer.from(out);\n }\n}\nexports.default = Varint;\nexports.Varint = Varint;\n//# sourceMappingURL=varint.js.map","// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\n\nimport CryptoNoteBase58 from './cryptonote_base58';\nimport { base58_to_binary, binary_to_base58 } from './base58-js';\nimport { Buffer } from 'buffer';\n\nexport default abstract class Base58 extends CryptoNoteBase58 {\n /**\n * Decodes the Base58 encoded string into a Buffer\n *\n * @param encoded\n */\n public static decode (\n encoded: string\n ): Buffer {\n return Buffer.from(base58_to_binary(encoded));\n }\n\n /**\n * Encodes the data into Base58\n *\n * @param data\n */\n public static encode (data: string | Uint8Array | Buffer): string {\n if (data instanceof Buffer) {\n data = data.valueOf();\n } else if (typeof data === 'string') {\n data = Buffer.from(data, 'hex').valueOf();\n }\n\n return binary_to_base58(data);\n }\n}\n\nexport { Base58, Buffer };\n","module.exports = function () {\n throw new Error('Readable.from is not available in the browser')\n};\n","// Ported from https://github.com/mafintosh/end-of-stream with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar ERR_STREAM_PREMATURE_CLOSE = require('../../../errors').codes.ERR_STREAM_PREMATURE_CLOSE;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n callback.apply(this, args);\n };\n}\nfunction noop() {}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction eos(stream, opts, callback) {\n if (typeof opts === 'function') return eos(stream, null, opts);\n if (!opts) opts = {};\n callback = once(callback || noop);\n var readable = opts.readable || opts.readable !== false && stream.readable;\n var writable = opts.writable || opts.writable !== false && stream.writable;\n var onlegacyfinish = function onlegacyfinish() {\n if (!stream.writable) onfinish();\n };\n var writableEnded = stream._writableState && stream._writableState.finished;\n var onfinish = function onfinish() {\n writable = false;\n writableEnded = true;\n if (!readable) callback.call(stream);\n };\n var readableEnded = stream._readableState && stream._readableState.endEmitted;\n var onend = function onend() {\n readable = false;\n readableEnded = true;\n if (!writable) callback.call(stream);\n };\n var onerror = function onerror(err) {\n callback.call(stream, err);\n };\n var onclose = function onclose() {\n var err;\n if (readable && !readableEnded) {\n if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n if (writable && !writableEnded) {\n if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n };\n var onrequest = function onrequest() {\n stream.req.on('finish', onfinish);\n };\n if (isRequest(stream)) {\n stream.on('complete', onfinish);\n stream.on('abort', onclose);\n if (stream.req) onrequest();else stream.on('request', onrequest);\n } else if (writable && !stream._writableState) {\n // legacy streams\n stream.on('end', onlegacyfinish);\n stream.on('close', onlegacyfinish);\n }\n stream.on('end', onend);\n stream.on('finish', onfinish);\n if (opts.error !== false) stream.on('error', onerror);\n stream.on('close', onclose);\n return function () {\n stream.removeListener('complete', onfinish);\n stream.removeListener('abort', onclose);\n stream.removeListener('request', onrequest);\n if (stream.req) stream.req.removeListener('finish', onfinish);\n stream.removeListener('end', onlegacyfinish);\n stream.removeListener('close', onlegacyfinish);\n stream.removeListener('finish', onfinish);\n stream.removeListener('end', onend);\n stream.removeListener('error', onerror);\n stream.removeListener('close', onclose);\n };\n}\nmodule.exports = eos;","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh <https://feross.org>\n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nconst base64 = require('base64-js')\nconst ieee754 = require('ieee754')\nconst customInspectSymbol =\n (typeof Symbol === 'function' && typeof Symbol['for'] === 'function') // eslint-disable-line dot-notation\n ? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n : null\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nconst K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n typeof console.error === 'function') {\n console.error(\n 'This browser lacks typed array (Uint8Array) support which is required by ' +\n '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n )\n}\n\nfunction typedArraySupport () {\n // Can typed array instances can be augmented?\n try {\n const arr = new Uint8Array(1)\n const proto = { foo: function () { return 42 } }\n Object.setPrototypeOf(proto, Uint8Array.prototype)\n Object.setPrototypeOf(arr, proto)\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nObject.defineProperty(Buffer.prototype, 'parent', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.buffer\n }\n})\n\nObject.defineProperty(Buffer.prototype, 'offset', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.byteOffset\n }\n})\n\nfunction createBuffer (length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"')\n }\n // Return an augmented `Uint8Array` instance\n const buf = new Uint8Array(length)\n Object.setPrototypeOf(buf, Buffer.prototype)\n return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new TypeError(\n 'The \"string\" argument must be of type string. Received type number'\n )\n }\n return allocUnsafe(arg)\n }\n return from(arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset)\n }\n\n if (ArrayBuffer.isView(value)) {\n return fromArrayView(value)\n }\n\n if (value == null) {\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n }\n\n if (isInstance(value, ArrayBuffer) ||\n (value && isInstance(value.buffer, ArrayBuffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof SharedArrayBuffer !== 'undefined' &&\n (isInstance(value, SharedArrayBuffer) ||\n (value && isInstance(value.buffer, SharedArrayBuffer)))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof value === 'number') {\n throw new TypeError(\n 'The \"value\" argument must not be of type number. Received type number'\n )\n }\n\n const valueOf = value.valueOf && value.valueOf()\n if (valueOf != null && valueOf !== value) {\n return Buffer.from(valueOf, encodingOrOffset, length)\n }\n\n const b = fromObject(value)\n if (b) return b\n\n if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null &&\n typeof value[Symbol.toPrimitive] === 'function') {\n return Buffer.from(value[Symbol.toPrimitive]('string'), encodingOrOffset, length)\n }\n\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nObject.setPrototypeOf(Buffer.prototype, Uint8Array.prototype)\nObject.setPrototypeOf(Buffer, Uint8Array)\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number')\n } else if (size < 0) {\n throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n }\n}\n\nfunction alloc (size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpreted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(size).fill(fill, encoding)\n : createBuffer(size).fill(fill)\n }\n return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n assertSize(size)\n return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n\n const length = byteLength(string, encoding) | 0\n let buf = createBuffer(length)\n\n const actual = buf.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (array) {\n const length = array.length < 0 ? 0 : checked(array.length) | 0\n const buf = createBuffer(length)\n for (let i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayView (arrayView) {\n if (isInstance(arrayView, Uint8Array)) {\n const copy = new Uint8Array(arrayView)\n return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength)\n }\n return fromArrayLike(arrayView)\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds')\n }\n\n let buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(buf, Buffer.prototype)\n\n return buf\n}\n\nfunction fromObject (obj) {\n if (Buffer.isBuffer(obj)) {\n const len = checked(obj.length) | 0\n const buf = createBuffer(len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj.length !== undefined) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0)\n }\n return fromArrayLike(obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data)\n }\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return b != null && b._isBuffer === true &&\n b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false\n}\n\nBuffer.compare = function compare (a, b) {\n if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength)\n if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength)\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError(\n 'The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array'\n )\n }\n\n if (a === b) return 0\n\n let x = a.length\n let y = b.length\n\n for (let i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n let i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n const buffer = Buffer.allocUnsafe(length)\n let pos = 0\n for (i = 0; i < list.length; ++i) {\n let buf = list[i]\n if (isInstance(buf, Uint8Array)) {\n if (pos + buf.length > buffer.length) {\n if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf)\n buf.copy(buffer, pos)\n } else {\n Uint8Array.prototype.set.call(\n buffer,\n buf,\n pos\n )\n }\n } else if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n } else {\n buf.copy(buffer, pos)\n }\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n throw new TypeError(\n 'The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' +\n 'Received type ' + typeof string\n )\n }\n\n const len = string.length\n const mustMatch = (arguments.length > 2 && arguments[2] === true)\n if (!mustMatch && len === 0) return 0\n\n // Use a for loop to avoid recursion\n let loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) {\n return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8\n }\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n let loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n const i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n const len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (let i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n const len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (let i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n const len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (let i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n const length = this.length\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.toLocaleString = Buffer.prototype.toString\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n let str = ''\n const max = exports.INSPECT_MAX_BYTES\n str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim()\n if (this.length > max) str += ' ... '\n return '<Buffer ' + str + '>'\n}\nif (customInspectSymbol) {\n Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (isInstance(target, Uint8Array)) {\n target = Buffer.from(target, target.offset, target.byteLength)\n }\n if (!Buffer.isBuffer(target)) {\n throw new TypeError(\n 'The \"target\" argument must be one of type Buffer or Uint8Array. ' +\n 'Received type ' + (typeof target)\n )\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n let x = thisEnd - thisStart\n let y = end - start\n const len = Math.min(x, y)\n\n const thisCopy = this.slice(thisStart, thisEnd)\n const targetCopy = target.slice(start, end)\n\n for (let i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (numberIsNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [val], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n let indexSize = 1\n let arrLength = arr.length\n let valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n let i\n if (dir) {\n let foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n let found = true\n for (let j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n const remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n const strLen = string.length\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n let i\n for (i = 0; i < length; ++i) {\n const parsed = parseInt(string.substr(i * 2, 2), 16)\n if (numberIsNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0\n if (isFinite(length)) {\n length = length >>> 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n const remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n let loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n case 'latin1':\n case 'binary':\n return asciiWrite(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n const res = []\n\n let i = start\n while (i < end) {\n const firstByte = buf[i]\n let codePoint = null\n let bytesPerSequence = (firstByte > 0xEF)\n ? 4\n : (firstByte > 0xDF)\n ? 3\n : (firstByte > 0xBF)\n ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n let secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nconst MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n const len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n let res = ''\n let i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n let ret = ''\n end = Math.min(buf.length, end)\n\n for (let i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n let ret = ''\n end = Math.min(buf.length, end)\n\n for (let i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n const len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n let out = ''\n for (let i = start; i < end; ++i) {\n out += hexSliceLookupTable[buf[i]]\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n const bytes = buf.slice(start, end)\n let res = ''\n // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n for (let i = 0; i < bytes.length - 1; i += 2) {\n res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256))\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n const len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n const newBuf = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(newBuf, Buffer.prototype)\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUintLE =\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let val = this[offset]\n let mul = 1\n let i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUintBE =\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n let val = this[offset + --byteLength]\n let mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUint8 =\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUint16LE =\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUint16BE =\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUint32LE =\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUint32BE =\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readBigUInt64LE = defineBigIntMethod(function readBigUInt64LE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const lo = first +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 24\n\n const hi = this[++offset] +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n last * 2 ** 24\n\n return BigInt(lo) + (BigInt(hi) << BigInt(32))\n})\n\nBuffer.prototype.readBigUInt64BE = defineBigIntMethod(function readBigUInt64BE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const hi = first * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n this[++offset]\n\n const lo = this[++offset] * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n last\n\n return (BigInt(hi) << BigInt(32)) + BigInt(lo)\n})\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let val = this[offset]\n let mul = 1\n let i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let i = byteLength\n let mul = 1\n let val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n const val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n const val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readBigInt64LE = defineBigIntMethod(function readBigInt64LE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const val = this[offset + 4] +\n this[offset + 5] * 2 ** 8 +\n this[offset + 6] * 2 ** 16 +\n (last << 24) // Overflow\n\n return (BigInt(val) << BigInt(32)) +\n BigInt(first +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 24)\n})\n\nBuffer.prototype.readBigInt64BE = defineBigIntMethod(function readBigInt64BE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const val = (first << 24) + // Overflow\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n this[++offset]\n\n return (BigInt(val) << BigInt(32)) +\n BigInt(this[++offset] * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n last)\n})\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUintLE =\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n const maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n let mul = 1\n let i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUintBE =\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n const maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n let i = byteLength - 1\n let mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUint8 =\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeUint16LE =\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeUint16BE =\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeUint32LE =\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeUint32BE =\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nfunction wrtBigUInt64LE (buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7)\n\n let lo = Number(value & BigInt(0xffffffff))\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n let hi = Number(value >> BigInt(32) & BigInt(0xffffffff))\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n return offset\n}\n\nfunction wrtBigUInt64BE (buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7)\n\n let lo = Number(value & BigInt(0xffffffff))\n buf[offset + 7] = lo\n lo = lo >> 8\n buf[offset + 6] = lo\n lo = lo >> 8\n buf[offset + 5] = lo\n lo = lo >> 8\n buf[offset + 4] = lo\n let hi = Number(value >> BigInt(32) & BigInt(0xffffffff))\n buf[offset + 3] = hi\n hi = hi >> 8\n buf[offset + 2] = hi\n hi = hi >> 8\n buf[offset + 1] = hi\n hi = hi >> 8\n buf[offset] = hi\n return offset + 8\n}\n\nBuffer.prototype.writeBigUInt64LE = defineBigIntMethod(function writeBigUInt64LE (value, offset = 0) {\n return wrtBigUInt64LE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n})\n\nBuffer.prototype.writeBigUInt64BE = defineBigIntMethod(function writeBigUInt64BE (value, offset = 0) {\n return wrtBigUInt64BE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n})\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n const limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n let i = 0\n let mul = 1\n let sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n const limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n let i = byteLength - 1\n let mul = 1\n let sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeBigInt64LE = defineBigIntMethod(function writeBigInt64LE (value, offset = 0) {\n return wrtBigUInt64LE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n})\n\nBuffer.prototype.writeBigInt64BE = defineBigIntMethod(function writeBigInt64BE (value, offset = 0) {\n return wrtBigUInt64BE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n})\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('Index out of range')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n const len = end - start\n\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end)\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, end),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n if (val.length === 1) {\n const code = val.charCodeAt(0)\n if ((encoding === 'utf8' && code < 128) ||\n encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255\n } else if (typeof val === 'boolean') {\n val = Number(val)\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n let i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n const bytes = Buffer.isBuffer(val)\n ? val\n : Buffer.from(val, encoding)\n const len = bytes.length\n if (len === 0) {\n throw new TypeError('The value \"' + val +\n '\" is invalid for argument \"value\"')\n }\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// CUSTOM ERRORS\n// =============\n\n// Simplified versions from Node, changed for Buffer-only usage\nconst errors = {}\nfunction E (sym, getMessage, Base) {\n errors[sym] = class NodeError extends Base {\n constructor () {\n super()\n\n Object.defineProperty(this, 'message', {\n value: getMessage.apply(this, arguments),\n writable: true,\n configurable: true\n })\n\n // Add the error code to the name to include it in the stack trace.\n this.name = `${this.name} [${sym}]`\n // Access the stack to generate the error message including the error code\n // from the name.\n this.stack // eslint-disable-line no-unused-expressions\n // Reset the name to the actual name.\n delete this.name\n }\n\n get code () {\n return sym\n }\n\n set code (value) {\n Object.defineProperty(this, 'code', {\n configurable: true,\n enumerable: true,\n value,\n writable: true\n })\n }\n\n toString () {\n return `${this.name} [${sym}]: ${this.message}`\n }\n }\n}\n\nE('ERR_BUFFER_OUT_OF_BOUNDS',\n function (name) {\n if (name) {\n return `${name} is outside of buffer bounds`\n }\n\n return 'Attempt to access memory outside buffer bounds'\n }, RangeError)\nE('ERR_INVALID_ARG_TYPE',\n function (name, actual) {\n return `The \"${name}\" argument must be of type number. Received type ${typeof actual}`\n }, TypeError)\nE('ERR_OUT_OF_RANGE',\n function (str, range, input) {\n let msg = `The value of \"${str}\" is out of range.`\n let received = input\n if (Number.isInteger(input) && Math.abs(input) > 2 ** 32) {\n received = addNumericalSeparator(String(input))\n } else if (typeof input === 'bigint') {\n received = String(input)\n if (input > BigInt(2) ** BigInt(32) || input < -(BigInt(2) ** BigInt(32))) {\n received = addNumericalSeparator(received)\n }\n received += 'n'\n }\n msg += ` It must be ${range}. Received ${received}`\n return msg\n }, RangeError)\n\nfunction addNumericalSeparator (val) {\n let res = ''\n let i = val.length\n const start = val[0] === '-' ? 1 : 0\n for (; i >= start + 4; i -= 3) {\n res = `_${val.slice(i - 3, i)}${res}`\n }\n return `${val.slice(0, i)}${res}`\n}\n\n// CHECK FUNCTIONS\n// ===============\n\nfunction checkBounds (buf, offset, byteLength) {\n validateNumber(offset, 'offset')\n if (buf[offset] === undefined || buf[offset + byteLength] === undefined) {\n boundsError(offset, buf.length - (byteLength + 1))\n }\n}\n\nfunction checkIntBI (value, min, max, buf, offset, byteLength) {\n if (value > max || value < min) {\n const n = typeof min === 'bigint' ? 'n' : ''\n let range\n if (byteLength > 3) {\n if (min === 0 || min === BigInt(0)) {\n range = `>= 0${n} and < 2${n} ** ${(byteLength + 1) * 8}${n}`\n } else {\n range = `>= -(2${n} ** ${(byteLength + 1) * 8 - 1}${n}) and < 2 ** ` +\n `${(byteLength + 1) * 8 - 1}${n}`\n }\n } else {\n range = `>= ${min}${n} and <= ${max}${n}`\n }\n throw new errors.ERR_OUT_OF_RANGE('value', range, value)\n }\n checkBounds(buf, offset, byteLength)\n}\n\nfunction validateNumber (value, name) {\n if (typeof value !== 'number') {\n throw new errors.ERR_INVALID_ARG_TYPE(name, 'number', value)\n }\n}\n\nfunction boundsError (value, length, type) {\n if (Math.floor(value) !== value) {\n validateNumber(value, type)\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset', 'an integer', value)\n }\n\n if (length < 0) {\n throw new errors.ERR_BUFFER_OUT_OF_BOUNDS()\n }\n\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset',\n `>= ${type ? 1 : 0} and <= ${length}`,\n value)\n}\n\n// HELPER FUNCTIONS\n// ================\n\nconst INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node takes equal signs as end of the Base64 encoding\n str = str.split('=')[0]\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n let codePoint\n const length = string.length\n let leadSurrogate = null\n const bytes = []\n\n for (let i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n const byteArray = []\n for (let i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n let c, hi, lo\n const byteArray = []\n for (let i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n let i\n for (i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\n// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n// the `instanceof` check but they should be treated as of that type.\n// See: https://github.com/feross/buffer/issues/166\nfunction isInstance (obj, type) {\n return obj instanceof type ||\n (obj != null && obj.constructor != null && obj.constructor.name != null &&\n obj.constructor.name === type.name)\n}\nfunction numberIsNaN (obj) {\n // For IE11 support\n return obj !== obj // eslint-disable-line no-self-compare\n}\n\n// Create lookup table for `toString('hex')`\n// See: https://github.com/feross/buffer/issues/219\nconst hexSliceLookupTable = (function () {\n const alphabet = '0123456789abcdef'\n const table = new Array(256)\n for (let i = 0; i < 16; ++i) {\n const i16 = i * 16\n for (let j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j]\n }\n }\n return table\n})()\n\n// Return not function with Error if BigInt not supported\nfunction defineBigIntMethod (fn) {\n return typeof BigInt === 'undefined' ? BufferBigIntNotDefined : fn\n}\n\nfunction BufferBigIntNotDefined () {\n throw new Error('BigInt not supported')\n}\n","'use strict';\n\nvar ERR_INVALID_OPT_VALUE = require('../../../errors').codes.ERR_INVALID_OPT_VALUE;\nfunction highWaterMarkFrom(options, isDuplex, duplexKey) {\n return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;\n}\nfunction getHighWaterMark(state, options, duplexKey, isDuplex) {\n var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);\n if (hwm != null) {\n if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {\n var name = isDuplex ? duplexKey : 'highWaterMark';\n throw new ERR_INVALID_OPT_VALUE(name, hwm);\n }\n return Math.floor(hwm);\n }\n\n // Default value\n return state.objectMode ? 16 : 16 * 1024;\n}\nmodule.exports = {\n getHighWaterMark: getHighWaterMark\n};","\"use strict\";\n// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Writer = void 0;\nconst varint_1 = __importDefault(require(\"./varint\"));\nconst big_integer_1 = __importDefault(require(\"big-integer\"));\nconst stream_1 = require(\"stream\");\nconst reader_1 = __importDefault(require(\"./reader\"));\nconst buffer_1 = require(\"buffer\");\nclass Writer extends stream_1.Readable {\n /**\n * Creates a new instance of the writer with the buffer preloaded with data if specified\n *\n * @param payload\n * @param encoding\n */\n constructor(payload = buffer_1.Buffer.alloc(0), encoding = 'hex') {\n super();\n this._buffer = buffer_1.Buffer.alloc(0);\n this._readIndex = 0;\n this.append(payload, encoding);\n }\n /**\n * Returns the current contents of the buffer\n */\n get buffer() {\n return this._buffer;\n }\n /**\n * Returns the byte size of the current buffer\n */\n get length() {\n return this._buffer.length;\n }\n /** @ignore */\n get readIndex() {\n return this._readIndex;\n }\n /** @ignore */\n static determineBits(value) {\n if (typeof value === 'number') {\n value = (0, big_integer_1.default)(value);\n }\n const bytes = [1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024];\n for (const byte of bytes) {\n let check = big_integer_1.default.zero;\n if (value.greater(-1)) {\n check = (0, big_integer_1.default)(2).pow(byte * 8)\n .subtract(1);\n }\n else {\n check = (0, big_integer_1.default)(2).pow((byte * 8) - 1)\n .subtract(1)\n .abs();\n }\n if (value.compare(check) <= 0) {\n return byte * 8;\n }\n }\n throw new RangeError('value is out of range');\n }\n /** @ignore */\n static writeUIntBE(value, bytes) {\n const hex = value.toString(16).padStart(bytes * 2, '0');\n return buffer_1.Buffer.from(hex, 'hex');\n }\n /** @ignore */\n static writeUIntLE(value, bytes) {\n const hex = value.toString(16).padStart(bytes * 2, '0');\n const buffer = buffer_1.Buffer.from(hex, 'hex');\n const tempBuffer = buffer_1.Buffer.alloc(bytes);\n let position = bytes - 1;\n for (const slice of buffer) {\n tempBuffer[position] = slice;\n position -= 1;\n }\n return tempBuffer;\n }\n /** @ignore */\n _read(size) {\n let okToSend = true;\n while (okToSend) {\n let slice = buffer_1.Buffer.alloc(0);\n if (this.readIndex + size > this.length) {\n slice = this._buffer.slice(this.readIndex);\n }\n else {\n slice = this._buffer.slice(this.readIndex, this.readIndex + size);\n }\n if (slice.length > 0) {\n this.push(slice);\n }\n else {\n this.push(null);\n okToSend = false;\n }\n this._readIndex += slice.length;\n }\n }\n /**\n * Clears the current write buffer\n */\n clear() {\n this._buffer = buffer_1.Buffer.alloc(0);\n }\n /**\n * Writes a hash to the buffer\n *\n * @param hash\n * @param encoding\n */\n hash(hash, encoding = 'hex') {\n if ((hash instanceof buffer_1.Buffer || hash instanceof Uint8Array) && (hash.length === 32 || hash.length === 64)) {\n return this.append(hash);\n }\n else if (typeof hash === 'string' && (hash.length === 64 || hash.length === 128)) {\n return this.append(hash, encoding);\n }\n throw new TypeError('hash is of wrong size and/or type');\n }\n /**\n * Writes the hex encoded value to the buffer\n *\n * @param hex\n */\n hex(hex) {\n if (hex instanceof buffer_1.Buffer || hex instanceof Uint8Array) {\n return this.append(hex);\n }\n else if (hex.length % 2 === 0) {\n return this.append(hex, 'hex');\n }\n throw new TypeError('hex is of the wrong size and/or type');\n }\n /**\n * Writes a signed integer to the buffer\n *\n * @param value\n * @param bits\n * @param bigEndian\n */\n signed_integer(value, bits = Writer.determineBits(value), bigEndian = false) {\n if (bits % 8 !== 0) {\n throw new RangeError('bits must be a multiple of 8');\n }\n if (typeof value === 'number') {\n value = (0, big_integer_1.default)(value);\n }\n const bytes = bits / 8;\n const buffer = buffer_1.Buffer.alloc(bytes);\n switch (bytes) {\n case 1:\n buffer.writeInt8(value.toJSNumber(), 0);\n break;\n case 2:\n (bigEndian ? buffer.writeInt16BE : buffer.writeInt16LE)(value.toJSNumber(), 0);\n break;\n case 4:\n (bigEndian ? buffer.writeInt32BE : buffer.writeInt32LE)(value.toJSNumber(), 0);\n break;\n case 8:\n (bigEndian ? buffer.writeBigInt64BE : buffer.writeBigInt64LE)(BigInt(value.toString()), 0);\n break;\n default:\n throw new TypeError('value bit size is not supported');\n }\n return this.append(buffer);\n }\n /**\n * Writes an int8_t to the buffer\n *\n * @param value\n */\n int8_t(value) {\n return this.signed_integer(value, 8);\n }\n /**\n * Writes an int16_t to the buffer\n *\n * @param value\n */\n int16_t(value) {\n return this.signed_integer(value, 16);\n }\n /**\n * Writes an int32_t to the buffer\n *\n * @param value\n */\n int32_t(value) {\n return this.signed_integer(value, 32);\n }\n /**\n * Writes an int64_t to the buffer\n *\n * @param value\n */\n int64_t(value) {\n return this.signed_integer(value, 64);\n }\n /**\n * Writes a string to the buffer\n *\n * @param value\n * @param encoding\n */\n string(value, encoding = 'utf-8') {\n const success = this.varint(value.length);\n if (!success) {\n throw new Error('could not encode string length as varint');\n }\n const buffer = buffer_1.Buffer.from(value, encoding);\n return this.append(buffer);\n }\n /**\n * Writes a time_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n time_t(value, bigEndian = false) {\n const num = (0, big_integer_1.default)(Math.floor(value.getTime() / 1000));\n return this.uint64_t(num, !bigEndian);\n }\n /**\n * Dumps the buffer to a string\n *\n * @param encoding\n */\n toString(encoding = 'hex') {\n return this.buffer.toString(encoding);\n }\n /**\n * Writes an unsigned integer to the buffer\n *\n * @param value\n * @param bits\n * @param bigEndian\n */\n unsigned_integer(value, bits = Writer.determineBits(value), bigEndian = false) {\n if (typeof value === 'number') {\n value = (0, big_integer_1.default)(value);\n }\n if (bits % 8 !== 0) {\n throw new RangeError('bits must be a multiple of 8');\n }\n if (value.lesser(0)) {\n throw new RangeError('cannot store signed value in unsigned type');\n }\n const bytes = bits / 8;\n const buffer = bigEndian ? Writer.writeUIntBE(value, bytes) : Writer.writeUIntLE(value, bytes);\n return this.append(buffer);\n }\n /**\n * Writes an uint8_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint8_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 8, bigEndian);\n }\n /**\n * Writes an uint16_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint16_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 16, bigEndian);\n }\n /**\n * Writes an uint32_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint32_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 32, bigEndian);\n }\n /**\n * Writes an uint64_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint64_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 64, bigEndian);\n }\n /**\n * Writes an uint128_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint128_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 128, bigEndian);\n }\n /**\n * Writes an uint256_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint256_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 256, bigEndian);\n }\n /**\n * Writes an uint512_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint512_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 512, bigEndian);\n }\n /**\n * Writes a Varint to the buffer\n *\n * @param value\n * @param levin\n */\n varint(value, levin = false) {\n if (typeof value === 'number') {\n value = (0, big_integer_1.default)(value);\n }\n if (!levin) {\n return this.append(buffer_1.Buffer.from(varint_1.default.encode(value)));\n }\n else {\n if (value.greater((0, big_integer_1.default)('1073741823'))) {\n throw new RangeError('value out of range');\n }\n value = value.toJSNumber();\n let tempValue = value << 2;\n let byteCount = 0;\n if (value <= 63) {\n tempValue |= 0;\n byteCount = 1;\n }\n else if (value <= 16383) {\n tempValue |= 1;\n byteCount = 2;\n }\n else {\n tempValue |= 2;\n byteCount = 4;\n }\n for (let i = 0; i < byteCount; i++) {\n this.uint8_t((tempValue >> i * 8) & 0xFF);\n }\n return this;\n }\n }\n /**\n * Writes the supplied value to the buffer\n *\n * @param payload\n * @param encoding\n */\n append(payload, encoding = 'hex') {\n let buffer;\n if (payload instanceof reader_1.default || payload instanceof Writer) {\n buffer = payload.buffer;\n }\n else if (payload instanceof buffer_1.Buffer) {\n buffer = payload;\n }\n else if (payload instanceof Uint8Array) {\n buffer = buffer_1.Buffer.from(payload);\n }\n else {\n buffer = buffer_1.Buffer.from(payload, encoding);\n }\n this._buffer = buffer_1.Buffer.concat([this._buffer, buffer]);\n return this;\n }\n /**\n * Writes the specified bytes to the buffer\n *\n * @param value\n */\n bytes(value) {\n return this.append(value);\n }\n}\nexports.default = Writer;\nexports.Writer = Writer;\n//# sourceMappingURL=writer.js.map","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = Stream;\n\nvar EE = require('events').EventEmitter;\nvar inherits = require('inherits');\n\ninherits(Stream, EE);\nStream.Readable = require('readable-stream/lib/_stream_readable.js');\nStream.Writable = require('readable-stream/lib/_stream_writable.js');\nStream.Duplex = require('readable-stream/lib/_stream_duplex.js');\nStream.Transform = require('readable-stream/lib/_stream_transform.js');\nStream.PassThrough = require('readable-stream/lib/_stream_passthrough.js');\nStream.finished = require('readable-stream/lib/internal/streams/end-of-stream.js')\nStream.pipeline = require('readable-stream/lib/internal/streams/pipeline.js')\n\n// Backwards-compat with node 0.4.x\nStream.Stream = Stream;\n\n\n\n// old-style streams. Note that the pipe method (the only relevant\n// part of this class) is overridden in the Readable class.\n\nfunction Stream() {\n EE.call(this);\n}\n\nStream.prototype.pipe = function(dest, options) {\n var source = this;\n\n function ondata(chunk) {\n if (dest.writable) {\n if (false === dest.write(chunk) && source.pause) {\n source.pause();\n }\n }\n }\n\n source.on('data', ondata);\n\n function ondrain() {\n if (source.readable && source.resume) {\n source.resume();\n }\n }\n\n dest.on('drain', ondrain);\n\n // If the 'end' option is not supplied, dest.end() will be called when\n // source gets the 'end' or 'close' events. Only dest.end() once.\n if (!dest._isStdio && (!options || options.end !== false)) {\n source.on('end', onend);\n source.on('close', onclose);\n }\n\n var didOnEnd = false;\n function onend() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n dest.end();\n }\n\n\n function onclose() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n if (typeof dest.destroy === 'function') dest.destroy();\n }\n\n // don't leave dangling pipes when there are errors.\n function onerror(er) {\n cleanup();\n if (EE.listenerCount(this, 'error') === 0) {\n throw er; // Unhandled stream error in pipe.\n }\n }\n\n source.on('error', onerror);\n dest.on('error', onerror);\n\n // remove all the event listeners that were added.\n function cleanup() {\n source.removeListener('data', ondata);\n dest.removeListener('drain', ondrain);\n\n source.removeListener('end', onend);\n source.removeListener('close', onclose);\n\n source.removeListener('error', onerror);\n dest.removeListener('error', onerror);\n\n source.removeListener('end', cleanup);\n source.removeListener('close', cleanup);\n\n dest.removeListener('close', cleanup);\n }\n\n source.on('end', cleanup);\n source.on('close', cleanup);\n\n dest.on('close', cleanup);\n\n dest.emit('pipe', source);\n\n // Allow for unix-like usage: A.pipe(B).pipe(C)\n return dest;\n};\n","module.exports = require('events').EventEmitter;\n","// Copyright (c) 2021, pur3missh\n// Copyright (c) 2023-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\n\n/**\n * This code has been copied over from the base58-js package and translated to typescript\n * as the author of base58-js has no included typings at this time and it is not available\n * via @types/base58-js\n */\n\n/** @ignore */\nconst base58_chars =\n '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';\n\n/** @ignore */\nconst create_base58_map = () => {\n const base58M = Array(256).fill(-1);\n\n for (let i = 0; i < base58_chars.length; ++i) {\n base58M[base58_chars.charCodeAt(i)] = i;\n }\n\n return base58M;\n};\n\n/** @ignore */\nconst base58Map = create_base58_map();\n\n/**\n * Converts a base58 string to the corresponding binary representation\n *\n * @param base58String\n */\nexport const base58_to_binary = (base58String: string): Uint8Array<ArrayBuffer> => {\n if (base58String.match(/[IOl0]/gmu)) {\n throw new Error(\n `Invalid base58 character “${base58String.match(/[IOl0]/gmu)}”`\n );\n }\n\n const lz = base58String.match(/^1+/gmu);\n\n const psz = lz ? lz[0].length : 0;\n\n const size = ((base58String.length - psz) * (Math.log(58) / Math.log(256)) + 1) >>> 0;\n\n const base58_match = base58String.match(/./gmu);\n\n const psz_Uint = new Uint8Array(psz);\n\n let base58_temp: Uint8Array = new Uint8Array();\n\n if (base58_match) {\n base58_temp = base58_match.map(i => base58_chars.indexOf(i))\n .reduce((acc, i) => {\n acc = acc.map((j) => {\n const x = j * 58 + i;\n i = x >> 8;\n return x;\n });\n return acc;\n }, new Uint8Array(size))\n .reverse()\n .filter((lastValue =>\n value =>\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n (lastValue = lastValue || value)\n )(false));\n }\n\n return new Uint8Array([\n ...psz_Uint,\n ...base58_temp\n ]);\n};\n\n/**\n * Converts a Uint8Array into a base58 string\n *\n * @param uint8array\n */\nexport const binary_to_base58 = (uint8array: Uint8Array): string => {\n const result = [];\n\n for (const byte of uint8array) {\n let carry = byte;\n\n for (let j = 0; j < result.length; ++j) {\n const x: number = (base58Map[result[j]] << 8) + carry;\n\n result[j] = base58_chars.charCodeAt(x % 58);\n\n carry = (x / 58) | 0;\n }\n\n while (carry) {\n result.push(base58_chars.charCodeAt(carry % 58));\n\n carry = (carry / 58) | 0;\n }\n }\n\n for (const byte of uint8array) {\n if (byte) break;\n else result.push('1'.charCodeAt(0));\n }\n\n result.reverse();\n\n return String.fromCharCode(...result);\n};\n\nexport default {\n binary_to_base58,\n base58_to_binary\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/*<replacement>*/\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) keys.push(key);\n return keys;\n};\n/*</replacement>*/\n\nmodule.exports = Duplex;\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\nrequire('inherits')(Duplex, Readable);\n{\n // Allow the keys array to be GC'ed.\n var keys = objectKeys(Writable.prototype);\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n Readable.call(this, options);\n Writable.call(this, options);\n this.allowHalfOpen = true;\n if (options) {\n if (options.readable === false) this.readable = false;\n if (options.writable === false) this.writable = false;\n if (options.allowHalfOpen === false) {\n this.allowHalfOpen = false;\n this.once('end', onend);\n }\n }\n}\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\n\n// the no-half-open enforcer\nfunction onend() {\n // If the writable side ended, then we're ok.\n if (this._writableState.ended) return;\n\n // no more data can be written.\n // But allow more writes to happen in this tick.\n process.nextTick(onEndNT, this);\n}\nfunction onEndNT(self) {\n self.end();\n}\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nmodule.exports = Readable;\n\n/*<replacement>*/\nvar Duplex;\n/*</replacement>*/\n\nReadable.ReadableState = ReadableState;\n\n/*<replacement>*/\nvar EE = require('events').EventEmitter;\nvar EElistenerCount = function EElistenerCount(emitter, type) {\n return emitter.listeners(type).length;\n};\n/*</replacement>*/\n\n/*<replacement>*/\nvar Stream = require('./internal/streams/stream');\n/*</replacement>*/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/*<replacement>*/\nvar debugUtil = require('util');\nvar debug;\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function debug() {};\n}\n/*</replacement>*/\n\nvar BufferList = require('./internal/streams/buffer_list');\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT;\n\n// Lazy loaded to improve the startup performance.\nvar StringDecoder;\nvar createReadableStreamAsyncIterator;\nvar from;\nrequire('inherits')(Readable, Stream);\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn);\n\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\nfunction ReadableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex);\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false;\n\n // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n this.sync = true;\n\n // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n this.paused = true;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'end' (and potentially 'finish')\n this.autoDestroy = !!options.autoDestroy;\n\n // has it been destroyed\n this.destroyed = false;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // the number of writers that are awaiting a drain event in .pipe()s\n this.awaitDrain = 0;\n\n // if true, a maybeReadMore has been scheduled\n this.readingMore = false;\n this.decoder = null;\n this.encoding = null;\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n if (!(this instanceof Readable)) return new Readable(options);\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the ReadableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n this._readableState = new ReadableState(options, this, isDuplex);\n\n // legacy\n this.readable = true;\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n Stream.call(this);\n}\nObject.defineProperty(Readable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined) {\n return false;\n }\n return this._readableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n }\n});\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\nReadable.prototype._destroy = function (err, cb) {\n cb(err);\n};\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n debug('readableAddChunk', chunk);\n var state = stream._readableState;\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n if (er) {\n errorOrDestroy(stream, er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (addToFront) {\n if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());\n } else if (state.destroyed) {\n return false;\n } else {\n state.reading = false;\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n maybeReadMore(stream, state);\n }\n }\n\n // We can push more data if we are below the highWaterMark.\n // Also, if we have no data yet, we can stand some more bytes.\n // This is to work around cases where hwm=0, such as the repl.\n return !state.ended && (state.length < state.highWaterMark || state.length === 0);\n}\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n state.awaitDrain = 0;\n stream.emit('data', chunk);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n if (state.needReadable) emitReadable(stream);\n }\n maybeReadMore(stream, state);\n}\nfunction chunkInvalid(state, chunk) {\n var er;\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);\n }\n return er;\n}\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n};\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n var decoder = new StringDecoder(enc);\n this._readableState.decoder = decoder;\n // If setEncoding(null), decoder.encoding equals utf8\n this._readableState.encoding = this._readableState.decoder.encoding;\n\n // Iterate over current buffer to convert already stored Buffers:\n var p = this._readableState.buffer.head;\n var content = '';\n while (p !== null) {\n content += decoder.write(p.data);\n p = p.next;\n }\n this._readableState.buffer.clear();\n if (content !== '') this._readableState.buffer.push(content);\n this._readableState.length = content.length;\n return this;\n};\n\n// Don't raise the hwm > 1GB\nvar MAX_HWM = 0x40000000;\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n return n;\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n }\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n;\n // Don't have enough\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n return state.length;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n if (n !== 0) state.emittedReadable = false;\n\n // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n n = howMuchToRead(n, state);\n\n // if we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n var doRead = state.needReadable;\n debug('need readable', doRead);\n\n // if we currently have less than the highWaterMark, then also read some\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n }\n\n // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true;\n // if the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.needReadable = true;\n // call internal read method\n this._read(state.highWaterMark);\n state.sync = false;\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n if (ret === null) {\n state.needReadable = state.length <= state.highWaterMark;\n n = 0;\n } else {\n state.length -= n;\n state.awaitDrain = 0;\n }\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true;\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this);\n }\n if (ret !== null) this.emit('data', ret);\n return ret;\n};\nfunction onEofChunk(stream, state) {\n debug('onEofChunk');\n if (state.ended) return;\n if (state.decoder) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n state.ended = true;\n if (state.sync) {\n // if we are sync, wait until next tick to emit the data.\n // Otherwise we risk emitting data in the flow()\n // the readable code triggers during a read() call\n emitReadable(stream);\n } else {\n // emit 'readable' now to make sure it gets picked up.\n state.needReadable = false;\n if (!state.emittedReadable) {\n state.emittedReadable = true;\n emitReadable_(stream);\n }\n }\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n var state = stream._readableState;\n debug('emitReadable', state.needReadable, state.emittedReadable);\n state.needReadable = false;\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n process.nextTick(emitReadable_, stream);\n }\n}\nfunction emitReadable_(stream) {\n var state = stream._readableState;\n debug('emitReadable_', state.destroyed, state.length, state.ended);\n if (!state.destroyed && (state.length || state.ended)) {\n stream.emit('readable');\n state.emittedReadable = false;\n }\n\n // The stream needs another readable event if\n // 1. It is not flowing, as the flow mechanism will take\n // care of it.\n // 2. It is not ended.\n // 3. It is below the highWaterMark, so we can schedule\n // another readable later.\n state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;\n flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n process.nextTick(maybeReadMore_, stream, state);\n }\n}\nfunction maybeReadMore_(stream, state) {\n // Attempt to read more data if we should.\n //\n // The conditions for reading more data are (one of):\n // - Not enough data buffered (state.length < state.highWaterMark). The loop\n // is responsible for filling the buffer with enough data if such data\n // is available. If highWaterMark is 0 and we are not in the flowing mode\n // we should _not_ attempt to buffer any extra data. We'll get more data\n // when the stream consumer calls read() instead.\n // - No data in the buffer, and the stream is in flowing mode. In this mode\n // the loop below is responsible for ensuring read() is called. Failing to\n // call read here would abort the flow and there's no other mechanism for\n // continuing the flow if the stream consumer has just subscribed to the\n // 'data' event.\n //\n // In addition to the above conditions to keep reading data, the following\n // conditions prevent the data from being read:\n // - The stream has ended (state.ended).\n // - There is already a pending 'read' operation (state.reading). This is a\n // case where the the stream has called the implementation defined _read()\n // method, but they are processing the call asynchronously and have _not_\n // called push() with new data. In this case we skip performing more\n // read()s. The execution ends in this method again after the _read() ends\n // up calling push() with more data.\n while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {\n var len = state.length;\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length)\n // didn't get any data, stop spinning.\n break;\n }\n state.readingMore = false;\n}\n\n// abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));\n};\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n default:\n state.pipes.push(dest);\n break;\n }\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);\n dest.on('unpipe', onunpipe);\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n function onend() {\n debug('onend');\n dest.end();\n }\n\n // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n var cleanedUp = false;\n function cleanup() {\n debug('cleanup');\n // cleanup event handlers once the pipe is broken\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n cleanedUp = true;\n\n // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n src.on('data', ondata);\n function ondata(chunk) {\n debug('ondata');\n var ret = dest.write(chunk);\n debug('dest.write', ret);\n if (ret === false) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n }\n src.pause();\n }\n }\n\n // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror);\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n dest.once('close', onclose);\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n dest.once('finish', onfinish);\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n }\n\n // tell the dest that it's being piped to\n dest.emit('pipe', src);\n\n // start the flow if it hasn't been started already.\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n return dest;\n};\nfunction pipeOnDrain(src) {\n return function pipeOnDrainFunctionResult() {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = {\n hasUnpiped: false\n };\n\n // if we're not piping anywhere, then do nothing.\n if (state.pipesCount === 0) return this;\n\n // just one destination. most common case.\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n if (!dest) dest = state.pipes;\n\n // got a match.\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n }\n\n // slow case. multiple pipe destinations.\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n for (var i = 0; i < len; i++) dests[i].emit('unpipe', this, {\n hasUnpiped: false\n });\n return this;\n }\n\n // try to find the right one.\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n dest.emit('unpipe', this, unpipeInfo);\n return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n var state = this._readableState;\n if (ev === 'data') {\n // update readableListening so that resume() may be a no-op\n // a few lines down. This is needed to support once('readable').\n state.readableListening = this.listenerCount('readable') > 0;\n\n // Try start flowing on next tick if stream isn't explicitly paused\n if (state.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.flowing = false;\n state.emittedReadable = false;\n debug('on readable', state.length, state.reading);\n if (state.length) {\n emitReadable(this);\n } else if (!state.reading) {\n process.nextTick(nReadingNextTick, this);\n }\n }\n }\n return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\nReadable.prototype.removeListener = function (ev, fn) {\n var res = Stream.prototype.removeListener.call(this, ev, fn);\n if (ev === 'readable') {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nReadable.prototype.removeAllListeners = function (ev) {\n var res = Stream.prototype.removeAllListeners.apply(this, arguments);\n if (ev === 'readable' || ev === undefined) {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nfunction updateReadableListening(self) {\n var state = self._readableState;\n state.readableListening = self.listenerCount('readable') > 0;\n if (state.resumeScheduled && !state.paused) {\n // flowing needs to be set to true now, otherwise\n // the upcoming resume will not flow.\n state.flowing = true;\n\n // crude way to check if we should resume\n } else if (self.listenerCount('data') > 0) {\n self.resume();\n }\n}\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n var state = this._readableState;\n if (!state.flowing) {\n debug('resume');\n // we flow only if there is no one listening\n // for readable, but we still have to call\n // resume()\n state.flowing = !state.readableListening;\n resume(this, state);\n }\n state.paused = false;\n return this;\n};\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n process.nextTick(resume_, stream, state);\n }\n}\nfunction resume_(stream, state) {\n debug('resume', state.reading);\n if (!state.reading) {\n stream.read(0);\n }\n state.resumeScheduled = false;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n if (this._readableState.flowing !== false) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n this._readableState.paused = true;\n return this;\n};\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n while (state.flowing && stream.read() !== null);\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n var state = this._readableState;\n var paused = false;\n stream.on('end', function () {\n debug('wrapped end');\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n _this.push(null);\n });\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk);\n\n // don't skip over falsy values in objectMode\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n var ret = _this.push(chunk);\n if (!ret) {\n paused = true;\n stream.pause();\n }\n });\n\n // proxy all the other methods.\n // important when wrapping filters and duplexes.\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function methodWrap(method) {\n return function methodWrapReturnFunction() {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n }\n\n // proxy certain important events.\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n }\n\n // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n this._read = function (n) {\n debug('wrapped _read', n);\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n return this;\n};\nif (typeof Symbol === 'function') {\n Readable.prototype[Symbol.asyncIterator] = function () {\n if (createReadableStreamAsyncIterator === undefined) {\n createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');\n }\n return createReadableStreamAsyncIterator(this);\n };\n}\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.highWaterMark;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState && this._readableState.buffer;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableFlowing', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.flowing;\n },\n set: function set(state) {\n if (this._readableState) {\n this._readableState.flowing = state;\n }\n }\n});\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\nObject.defineProperty(Readable.prototype, 'readableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.length;\n }\n});\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = state.buffer.consume(n, state.decoder);\n }\n return ret;\n}\nfunction endReadable(stream) {\n var state = stream._readableState;\n debug('endReadable', state.endEmitted);\n if (!state.endEmitted) {\n state.ended = true;\n process.nextTick(endReadableNT, state, stream);\n }\n}\nfunction endReadableNT(state, stream) {\n debug('endReadableNT', state.endEmitted, state.length);\n\n // Check that we didn't get one last unshift.\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the writable side is ready for autoDestroy as well\n var wState = stream._writableState;\n if (!wState || wState.autoDestroy && wState.finished) {\n stream.destroy();\n }\n }\n }\n}\nif (typeof Symbol === 'function') {\n Readable.from = function (iterable, opts) {\n if (from === undefined) {\n from = require('./internal/streams/from');\n }\n return from(Readable, iterable, opts);\n };\n}\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n return -1;\n}","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\nvar Transform = require('./_stream_transform');\nrequire('inherits')(PassThrough, Transform);\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n Transform.call(this, options);\n}\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\nvar _require$codes = require('../errors').codes,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,\n ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;\nvar Duplex = require('./_stream_duplex');\nrequire('inherits')(Transform, Duplex);\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n var cb = ts.writecb;\n if (cb === null) {\n return this.emit('error', new ERR_MULTIPLE_CALLBACK());\n }\n ts.writechunk = null;\n ts.writecb = null;\n if (data != null)\n // single equals check for both `null` and `undefined`\n this.push(data);\n cb(er);\n var rs = this._readableState;\n rs.reading = false;\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n Duplex.call(this, options);\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n };\n\n // start out asking for a readable event once data is transformed.\n this._readableState.needReadable = true;\n\n // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false;\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n if (typeof options.flush === 'function') this._flush = options.flush;\n }\n\n // When the writable side finishes, then flush out anything remaining.\n this.on('prefinish', prefinish);\n}\nfunction prefinish() {\n var _this = this;\n if (typeof this._flush === 'function' && !this._readableState.destroyed) {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));\n};\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n if (ts.writechunk !== null && !ts.transforming) {\n ts.transforming = true;\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\nTransform.prototype._destroy = function (err, cb) {\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n });\n};\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n if (data != null)\n // single equals check for both `null` and `undefined`\n stream.push(data);\n\n // TODO(BridgeAR): Write a test for these two error cases\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();\n if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();\n return stream.push(null);\n}","\n/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate (fn, msg) {\n if (config('noDeprecation')) {\n return fn;\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (config('throwDeprecation')) {\n throw new Error(msg);\n } else if (config('traceDeprecation')) {\n console.trace(msg);\n } else {\n console.warn(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config (name) {\n // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n try {\n if (!global.localStorage) return false;\n } catch (_) {\n return false;\n }\n var val = global.localStorage[name];\n if (null == val) return false;\n return String(val).toLowerCase() === 'true';\n}\n","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\n\nimport { BigInteger, Reader, Writer } from '@gibme/bytepack';\nimport { Buffer } from 'buffer';\n\n/** @ignore */\nconst ALPHABET: number[] = (() => {\n const str = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';\n\n return str.split('')\n .map(char => char.charCodeAt(0));\n})();\n\n/** @ignore */\nconst ENCODED_BLOCK_SIZES = [0, 2, 3, 5, 6, 7, 9, 10, 11];\n\n/** @ignore */\nconst FULL_BLOCK_SIZE = 8;\n\n/** @ignore */\nconst FULL_ENCODED_BLOCK_SIZE = 11;\n\n/** @ignore */\nconst UINT64_MAX = BigInteger(2).pow(64);\n\nexport default abstract class CryptoNoteBase58 {\n /**\n * Decodes the CryptoNote Base58 encoded string into a Buffer\n *\n * @param encoded\n */\n public static cn_decode (\n encoded: string\n ): Buffer {\n const enc = Buffer.from(encoded).valueOf();\n\n if (enc.length === 0) {\n return Buffer.alloc(0);\n }\n\n const fullBlockCount = Math.floor(enc.length / FULL_ENCODED_BLOCK_SIZE);\n\n const lastBlockSize = enc.length % FULL_ENCODED_BLOCK_SIZE;\n\n const lastBlockDecodedSize = ENCODED_BLOCK_SIZES.indexOf(lastBlockSize);\n\n if (lastBlockDecodedSize < 0) {\n throw new Error('Invalid encoded length');\n }\n\n const dataSize = fullBlockCount * FULL_BLOCK_SIZE + lastBlockDecodedSize;\n\n let result = new Uint8Array(dataSize);\n\n for (let i = 0; i < fullBlockCount; i++) {\n result = CryptoNoteBase58.decodeBlock(\n enc.subarray(\n i * FULL_ENCODED_BLOCK_SIZE,\n i * FULL_ENCODED_BLOCK_SIZE + FULL_ENCODED_BLOCK_SIZE),\n result,\n i * FULL_BLOCK_SIZE\n );\n }\n\n if (lastBlockSize > 0) {\n result = CryptoNoteBase58.decodeBlock(\n enc.subarray(\n fullBlockCount * FULL_ENCODED_BLOCK_SIZE,\n fullBlockCount * FULL_ENCODED_BLOCK_SIZE + lastBlockSize),\n result,\n fullBlockCount * FULL_BLOCK_SIZE\n );\n }\n\n return Buffer.from(result);\n }\n\n /**\n * Encodes the data into CryptoNote Base58 string\n *\n * @param data\n */\n public static cn_encode (\n data: string | Uint8Array | Buffer\n ): string {\n if (data instanceof Buffer) {\n data = data.toString('hex');\n } else if (data instanceof Uint8Array) {\n data = Buffer.from(data).toString('hex');\n }\n\n const _data = Buffer.from(data, 'hex').valueOf();\n\n if (_data.length === 0) {\n return '';\n }\n\n const fullBlockCount = Math.floor(_data.length / FULL_BLOCK_SIZE);\n\n const lastBlockSize = _data.length % FULL_BLOCK_SIZE;\n\n const resSize = fullBlockCount * FULL_ENCODED_BLOCK_SIZE + ENCODED_BLOCK_SIZES[lastBlockSize];\n\n let result = new Uint8Array(resSize);\n\n for (let i = 0; i < resSize; ++i) {\n result[i] = ALPHABET[0];\n }\n\n for (let i = 0; i < fullBlockCount; i++) {\n result = CryptoNoteBase58.encodeBlock(\n _data.subarray(\n i * FULL_BLOCK_SIZE,\n i * FULL_BLOCK_SIZE + FULL_BLOCK_SIZE),\n result, i *\n FULL_ENCODED_BLOCK_SIZE);\n }\n\n if (lastBlockSize > 0) {\n result = CryptoNoteBase58.encodeBlock(\n _data.subarray(\n fullBlockCount * FULL_BLOCK_SIZE,\n fullBlockCount * FULL_BLOCK_SIZE + lastBlockSize),\n result,\n fullBlockCount * FULL_ENCODED_BLOCK_SIZE);\n }\n\n return Buffer.from(result).toString();\n }\n\n /**\n * Decodes a Base58 block\n *\n * @param data\n * @param buffer\n * @param index\n * @private\n */\n private static decodeBlock (\n data: Uint8Array,\n buffer: Uint8Array<ArrayBuffer>,\n index: number\n ): Uint8Array<ArrayBuffer> {\n if (data.length < 1 || data.length > FULL_ENCODED_BLOCK_SIZE) {\n throw new Error('Invalid block length: ' + data.length);\n }\n\n const resSize = ENCODED_BLOCK_SIZES.indexOf(data.length);\n\n if (resSize <= 0) {\n throw new Error('Invalid block size');\n }\n\n let resNum = BigInteger.zero;\n\n let order = BigInteger.one;\n\n for (let i = data.length - 1; i >= 0; i--) {\n const digit = ALPHABET.indexOf(data[i]);\n\n if (digit < 0) {\n throw new Error('Invalid symbol');\n }\n\n const product = order.multiply(digit).add(resNum);\n\n if (product.compare(UINT64_MAX) === 1) {\n throw new Error('Overflow');\n }\n\n resNum = product;\n\n order = order.multiply(ALPHABET.length);\n }\n\n if (resSize < FULL_BLOCK_SIZE && (BigInteger(2).pow(8 * resSize).compare(resNum) <= 0)) {\n throw new Error('Overflow 2');\n }\n\n const value = new Writer()\n .uint64_t(resNum, true)\n .buffer\n .valueOf();\n\n buffer.set(value, index);\n\n return buffer;\n }\n\n /**\n * Encodes the data into a block for Base58\n *\n * @param data\n * @param buffer\n * @param index\n * @private\n */\n private static encodeBlock (\n data: Uint8Array,\n buffer: Uint8Array<ArrayBuffer>,\n index: number\n ): Uint8Array<ArrayBuffer> {\n if (data.length < 1 || data.length > FULL_ENCODED_BLOCK_SIZE) {\n throw new Error('Invalid block length: ' + data.length);\n }\n\n let num = new Reader(data).uint64_t(true);\n\n let i = ENCODED_BLOCK_SIZES[data.length] - 1;\n\n while (num.compare(0) === 1) {\n const div = num.divmod(ALPHABET.length);\n\n const remainder = div.remainder;\n\n num = div.quotient;\n\n buffer[index + i] = ALPHABET[remainder.toJSNumber()];\n\n i--;\n }\n\n return buffer;\n }\n}\n\nexport { CryptoNoteBase58 };\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\nmodule.exports = Writable;\n\n/* <replacement> */\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n var _this = this;\n this.next = null;\n this.entry = null;\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* </replacement> */\n\n/*<replacement>*/\nvar Duplex;\n/*</replacement>*/\n\nWritable.WritableState = WritableState;\n\n/*<replacement>*/\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/*</replacement>*/\n\n/*<replacement>*/\nvar Stream = require('./internal/streams/stream');\n/*</replacement>*/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,\n ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,\n ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,\n ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nrequire('inherits')(Writable, Stream);\nfunction nop() {}\nfunction WritableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream,\n // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex);\n\n // if _final has been called\n this.finalCalled = false;\n\n // drain event flag.\n this.needDrain = false;\n // at the start of calling end()\n this.ending = false;\n // when end() has been called, and returned\n this.ended = false;\n // when 'finish' is emitted\n this.finished = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0;\n\n // a flag to see when we're in the middle of a write.\n this.writing = false;\n\n // when true all writes will be buffered until .uncork() call\n this.corked = 0;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false;\n\n // the callback that's passed to _write(chunk,cb)\n this.onwrite = function (er) {\n onwrite(stream, er);\n };\n\n // the callback that the user supplies to write(chunk,encoding,cb)\n this.writecb = null;\n\n // the amount that is being written when _write is called.\n this.writelen = 0;\n this.bufferedRequest = null;\n this.lastBufferedRequest = null;\n\n // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n this.pendingcb = 0;\n\n // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n this.prefinished = false;\n\n // True if the error was already emitted and should not be thrown again\n this.errorEmitted = false;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'finish' (and potentially 'end')\n this.autoDestroy = !!options.autoDestroy;\n\n // count buffered requests\n this.bufferedRequestCount = 0;\n\n // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n this.corkedRequestsFree = new CorkedRequest(this);\n}\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n while (current) {\n out.push(current);\n current = current.next;\n }\n return out;\n};\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function writableStateBufferGetter() {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})();\n\n// Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\nvar realHasInstance;\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function value(object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function realHasInstance(object) {\n return object instanceof this;\n };\n}\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the WritableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);\n this._writableState = new WritableState(options, this, isDuplex);\n\n // legacy.\n this.writable = true;\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n if (typeof options.writev === 'function') this._writev = options.writev;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n if (typeof options.final === 'function') this._final = options.final;\n }\n Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());\n};\nfunction writeAfterEnd(stream, cb) {\n var er = new ERR_STREAM_WRITE_AFTER_END();\n // TODO: defer error events consistently everywhere, not just the cb\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n}\n\n// Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\nfunction validChunk(stream, state, chunk, cb) {\n var er;\n if (chunk === null) {\n er = new ERR_STREAM_NULL_VALUES();\n } else if (typeof chunk !== 'string' && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);\n }\n if (er) {\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n return false;\n }\n return true;\n}\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n if (typeof cb !== 'function') cb = nop;\n if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n return ret;\n};\nWritable.prototype.cork = function () {\n this._writableState.corked++;\n};\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n if (state.corked) {\n state.corked--;\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n return chunk;\n}\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n var len = state.objectMode ? 1 : chunk.length;\n state.length += len;\n var ret = state.length < state.highWaterMark;\n // we must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true;\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n return ret;\n}\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n process.nextTick(cb, er);\n // this can emit finish, and it will always happen\n // after error\n process.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n // this can emit finish, but finish must\n // always follow error\n finishMaybe(stream, state);\n }\n}\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();\n onwriteStateUpdate(state);\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state) || stream.destroyed;\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n if (sync) {\n process.nextTick(afterWrite, stream, state, finished, cb);\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n var count = 0;\n var allBuffers = true;\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n buffer.allBuffers = allBuffers;\n doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n state.pendingcb++;\n state.lastBufferedRequest = null;\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--;\n // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n if (state.writing) {\n break;\n }\n }\n if (entry === null) state.lastBufferedRequest = null;\n }\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));\n};\nWritable.prototype._writev = null;\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n // .end() fully uncorks\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n }\n\n // ignore unnecessary end() calls.\n if (!state.ending) endWritable(this, state, cb);\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n if (err) {\n errorOrDestroy(stream, err);\n }\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function' && !state.destroyed) {\n state.pendingcb++;\n state.finalCalled = true;\n process.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n if (need) {\n prefinish(stream, state);\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the readable side is ready for autoDestroy as well\n var rState = stream._readableState;\n if (!rState || rState.autoDestroy && rState.endEmitted) {\n stream.destroy();\n }\n }\n }\n }\n return need;\n}\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n if (cb) {\n if (state.finished) process.nextTick(cb);else stream.once('finish', cb);\n }\n state.ended = true;\n stream.writable = false;\n}\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n }\n\n // reuse the free corkReq.\n state.corkedRequestsFree.next = corkReq;\n}\nObject.defineProperty(Writable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._writableState === undefined) {\n return false;\n }\n return this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._writableState.destroyed = value;\n }\n});\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\nWritable.prototype._destroy = function (err, cb) {\n cb(err);\n};","'use strict';\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nvar _require = require('buffer'),\n Buffer = _require.Buffer;\nvar _require2 = require('util'),\n inspect = _require2.inspect;\nvar custom = inspect && inspect.custom || 'inspect';\nfunction copyBuffer(src, target, offset) {\n Buffer.prototype.copy.call(src, target, offset);\n}\nmodule.exports = /*#__PURE__*/function () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n _createClass(BufferList, [{\n key: \"push\",\n value: function push(v) {\n var entry = {\n data: v,\n next: null\n };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n }\n }, {\n key: \"unshift\",\n value: function unshift(v) {\n var entry = {\n data: v,\n next: this.head\n };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n }\n }, {\n key: \"shift\",\n value: function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n }\n }, {\n key: \"clear\",\n value: function clear() {\n this.head = this.tail = null;\n this.length = 0;\n }\n }, {\n key: \"join\",\n value: function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n while (p = p.next) ret += s + p.data;\n return ret;\n }\n }, {\n key: \"concat\",\n value: function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n return ret;\n }\n\n // Consumes a specified amount of bytes or characters from the buffered data.\n }, {\n key: \"consume\",\n value: function consume(n, hasStrings) {\n var ret;\n if (n < this.head.data.length) {\n // `slice` is the same for buffers and strings.\n ret = this.head.data.slice(0, n);\n this.head.data = this.head.data.slice(n);\n } else if (n === this.head.data.length) {\n // First chunk is a perfect match.\n ret = this.shift();\n } else {\n // Result spans more than one buffer.\n ret = hasStrings ? this._getString(n) : this._getBuffer(n);\n }\n return ret;\n }\n }, {\n key: \"first\",\n value: function first() {\n return this.head.data;\n }\n\n // Consumes a specified amount of characters from the buffered data.\n }, {\n key: \"_getString\",\n value: function _getString(n) {\n var p = this.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = str.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Consumes a specified amount of bytes from the buffered data.\n }, {\n key: \"_getBuffer\",\n value: function _getBuffer(n) {\n var ret = Buffer.allocUnsafe(n);\n var p = this.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = buf.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Make sure the linked list only shows the minimal necessary information.\n }, {\n key: custom,\n value: function value(_, options) {\n return inspect(this, _objectSpread(_objectSpread({}, options), {}, {\n // Only inspect one level.\n depth: 0,\n // It should not recurse.\n customInspect: false\n }));\n }\n }]);\n return BufferList;\n}();","// Ported from https://github.com/mafintosh/pump with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar eos;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n callback.apply(void 0, arguments);\n };\n}\nvar _require$codes = require('../../../errors').codes,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;\nfunction noop(err) {\n // Rethrow the error if it exists to avoid swallowing it\n if (err) throw err;\n}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction destroyer(stream, reading, writing, callback) {\n callback = once(callback);\n var closed = false;\n stream.on('close', function () {\n closed = true;\n });\n if (eos === undefined) eos = require('./end-of-stream');\n eos(stream, {\n readable: reading,\n writable: writing\n }, function (err) {\n if (err) return callback(err);\n closed = true;\n callback();\n });\n var destroyed = false;\n return function (err) {\n if (closed) return;\n if (destroyed) return;\n destroyed = true;\n\n // request.destroy just do .end - .abort is what we want\n if (isRequest(stream)) return stream.abort();\n if (typeof stream.destroy === 'function') return stream.destroy();\n callback(err || new ERR_STREAM_DESTROYED('pipe'));\n };\n}\nfunction call(fn) {\n fn();\n}\nfunction pipe(from, to) {\n return from.pipe(to);\n}\nfunction popCallback(streams) {\n if (!streams.length) return noop;\n if (typeof streams[streams.length - 1] !== 'function') return noop;\n return streams.pop();\n}\nfunction pipeline() {\n for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {\n streams[_key] = arguments[_key];\n }\n var callback = popCallback(streams);\n if (Array.isArray(streams[0])) streams = streams[0];\n if (streams.length < 2) {\n throw new ERR_MISSING_ARGS('streams');\n }\n var error;\n var destroys = streams.map(function (stream, i) {\n var reading = i < streams.length - 1;\n var writing = i > 0;\n return destroyer(stream, reading, writing, function (err) {\n if (!error) error = err;\n if (err) destroys.forEach(call);\n if (reading) return;\n destroys.forEach(call);\n callback(error);\n });\n });\n return streams.reduce(pipe);\n}\nmodule.exports = pipeline;","\"use strict\";\n// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Reader = void 0;\nconst varint_1 = __importDefault(require(\"./varint\"));\nconst big_integer_1 = __importDefault(require(\"big-integer\"));\nconst writer_1 = __importDefault(require(\"./writer\"));\nconst stream_1 = require(\"stream\");\nconst buffer_1 = require(\"buffer\");\nclass Reader extends stream_1.Writable {\n /**\n * Creates a new instance of the reader\n *\n * @param blob\n * @param encoding\n */\n constructor(blob = buffer_1.Buffer.alloc(0), encoding = 'hex') {\n super();\n this._current_offset = 0;\n this._buffer = buffer_1.Buffer.alloc(0);\n this.append(blob, encoding);\n }\n /**\n * Returns the current contents of the buffer\n */\n get buffer() {\n return this._buffer;\n }\n /**\n * Returns the byte size of the current buffer\n */\n get length() {\n return this._buffer.length;\n }\n /**\n * Returns the current read offset of the buffer\n */\n get offset() {\n return this._current_offset;\n }\n /**\n * Returns the number of unread bytes left in the buffer\n */\n get unreadBytes() {\n const unread = this.length - this.offset;\n return unread >= 0 ? unread : 0;\n }\n /**\n * Returns the unread portion of the buffer\n */\n get unreadBuffer() {\n return this.buffer.slice(this.offset);\n }\n /** @ignore */\n static readUIntBE(buffer, bytes, offset = 0, noAssert = false) {\n if (buffer.length < offset + bytes) {\n if (noAssert) {\n return big_integer_1.default.zero;\n }\n throw new RangeError('Out of bounds');\n }\n const slice = buffer.slice(offset, offset + bytes);\n return (0, big_integer_1.default)(slice.toString('hex'), 16);\n }\n /** @ignore */\n static readUIntLE(buffer, bytes, offset = 0, noAssert = false) {\n if (buffer.length < offset + bytes) {\n if (noAssert) {\n return big_integer_1.default.zero;\n }\n throw new RangeError('Out of bounds');\n }\n const buf = buffer.slice(offset, offset + bytes);\n const tempBuffer = buffer_1.Buffer.alloc(bytes);\n let position = bytes - 1;\n for (const slice of buf) {\n tempBuffer[position] = slice;\n position -= 1;\n }\n return (0, big_integer_1.default)(tempBuffer.toString('hex'), 16);\n }\n /** @ignore */\n _write(chunk, encoding, callback) {\n this.append(chunk);\n callback();\n }\n /**\n * Appends the supplied value to the end of the buffer\n *\n * @param blob\n * @param encoding\n */\n append(blob, encoding = 'hex') {\n let buffer;\n if (blob instanceof Reader || blob instanceof writer_1.default) {\n buffer = blob.buffer;\n }\n else if (blob instanceof buffer_1.Buffer) {\n buffer = blob;\n }\n else if (blob instanceof Uint8Array) {\n buffer = buffer_1.Buffer.from(blob);\n }\n else if (blob.length % 2 === 0) {\n buffer = buffer_1.Buffer.from(blob, encoding);\n }\n else {\n throw new Error('Unknown data type');\n }\n this._buffer = buffer_1.Buffer.concat([this._buffer, buffer]);\n }\n /**\n * Read the specified number of bytes from the buffer\n *\n * @param count\n */\n bytes(count = 1) {\n if (this.unreadBytes < count) {\n throw new RangeError(`Requested ${count} bytes but only ${this.unreadBytes} bytes remain`);\n }\n const start = this.offset;\n this._current_offset += count;\n return this._buffer.slice(start, this.offset);\n }\n /**\n * Compacts the current buffer by truncating up to the unread position of the buffer\n *\n * @param offset\n */\n compact(offset = this.offset) {\n this._buffer = this._buffer.slice(offset);\n this._current_offset = 0;\n }\n /**\n * Reads a hash from the buffer\n *\n * @param size\n * @param encoding\n */\n hash(size = 32, encoding = 'hex') {\n return this.bytes(size).toString(encoding);\n }\n /**\n * Reads the specified number of hex encoded bytes from the buffer\n *\n * @param count\n * @param encoding\n */\n hex(count = 1, encoding = 'hex') {\n return this.bytes(count).toString(encoding);\n }\n /**\n * Reads a signed integer from the buffer\n *\n * @param bits\n * @param bigEndian\n */\n signed_integer(bits, bigEndian = false) {\n if (bits % 8 !== 0) {\n throw new RangeError('bits must be a multiple of 8');\n }\n const bytes = bits / 8;\n const result = this.bytes(bytes);\n switch (bytes) {\n case 1:\n return (0, big_integer_1.default)(result.readInt8());\n case 2:\n return (0, big_integer_1.default)(bigEndian ? result.readInt16BE() : result.readInt16LE());\n case 4:\n return (0, big_integer_1.default)(bigEndian ? result.readInt32BE() : result.readInt32LE());\n case 8:\n return (0, big_integer_1.default)(bigEndian ? result.readBigInt64BE() : result.readBigInt64LE());\n default:\n throw new RangeError('Data type');\n }\n }\n /**\n * Reads an int8_t from the buffer\n */\n int8_t() {\n return this.signed_integer(8);\n }\n /**\n * Reads an int16_t from the buffer\n *\n * @param bigEndian\n */\n int16_t(bigEndian = false) {\n return this.signed_integer(16, bigEndian);\n }\n /**\n * Reads an int32_t from the buffer\n *\n * @param bigEndian\n */\n int32_t(bigEndian = false) {\n return this.signed_integer(32, bigEndian);\n }\n /**\n * Reads an int64_t from the buffer\n *\n * @param bigEndian\n */\n int64_t(bigEndian = false) {\n return this.signed_integer(64, bigEndian);\n }\n /**\n * Resets the current position of the buffer back to the beginning\n *\n * @param offset\n */\n reset(offset = 0) {\n this._current_offset = offset;\n }\n /**\n * Skips reading the specified number of bytes from the buffer\n *\n * @param count\n */\n skip(count = 1) {\n this._current_offset += count;\n }\n /**\n * Reads a string from the buffer\n *\n * @param encoding\n */\n string(encoding = 'utf-8') {\n const length = this.varint().toJSNumber();\n return this.bytes(length).toString(encoding);\n }\n /**\n * Reads a time_t from the buffer\n *\n * @param bigEndian\n */\n time_t(bigEndian = false) {\n const epoch = this.uint64_t(!bigEndian).toJSNumber();\n return new Date(epoch * 1000);\n }\n /**\n * Returns the current contents of the buffer as a string\n *\n * @param encoding\n */\n toString(encoding = 'hex') {\n return this._buffer.toString(encoding);\n }\n /**\n * Reads an unsigned integer from the buffer\n *\n * @param bits\n * @param bigEndian\n */\n unsigned_integer(bits, bigEndian = false) {\n if (bits % 8 !== 0) {\n throw new RangeError('bits must be a multiple of 8');\n }\n const bytes = bits / 8;\n return bigEndian\n ? Reader.readUIntBE(this.bytes(bytes), bytes)\n : Reader.readUIntLE(this.bytes(bytes), bytes);\n }\n /**\n * Reads an uint8_t from the buffer\n */\n uint8_t() {\n return this.unsigned_integer(8);\n }\n /**\n * Reads an uint16_t from the buffer\n *\n * @param bigEndian\n */\n uint16_t(bigEndian = false) {\n return this.unsigned_integer(16, bigEndian);\n }\n /**\n * Reads an uint32_t from the buffer\n *\n * @param bigEndian\n */\n uint32_t(bigEndian = false) {\n return this.unsigned_integer(32, bigEndian);\n }\n /**\n * Reads an uint64_t from the buffer\n *\n * @param bigEndian\n */\n uint64_t(bigEndian = false) {\n return this.unsigned_integer(64, bigEndian);\n }\n /**\n * Reads an uint128_t from the buffer\n *\n * @param bigEndian\n */\n uint128_t(bigEndian = false) {\n return this.unsigned_integer(128, bigEndian);\n }\n /**\n * Reads an uint256_t from the buffer\n *\n * @param bigEndian\n */\n uint256_t(bigEndian = false) {\n return this.unsigned_integer(256, bigEndian);\n }\n /**\n * Reads an uint512_t from the buffer\n *\n * @param bigEndian\n */\n uint512_t(bigEndian = false) {\n return this.unsigned_integer(512, bigEndian);\n }\n /**\n * Reads a Varint from the buffer\n *\n * @param peek\n * @param levin\n */\n varint(peek = false, levin = false) {\n const start = this._current_offset;\n if (!levin) {\n do {\n if (this.buffer.readUInt8(this._current_offset) < 128) {\n this._current_offset++;\n const tmp = this.buffer.slice(start, this.offset);\n if (peek) {\n this._current_offset = start;\n }\n return varint_1.default.decode(tmp);\n }\n this._current_offset++;\n } while (true);\n }\n else {\n let value = this.uint8_t().toJSNumber();\n const sizeMask = value & 0x03;\n value = (0, big_integer_1.default)(value);\n let bytesLeft = 0;\n switch (sizeMask) {\n case 0:\n bytesLeft = 0;\n break;\n case 1:\n bytesLeft = 1;\n break;\n case 2:\n bytesLeft = 3;\n break;\n case 3:\n bytesLeft = 7;\n break;\n }\n for (let i = 1; i <= bytesLeft; ++i) {\n const nv = this.uint8_t().shiftLeft(i * 8);\n value = value.or(nv);\n }\n return value.shiftRight(2);\n }\n }\n}\nexports.default = Reader;\nexports.Reader = Reader;\n//# sourceMappingURL=reader.js.map","/*! safe-buffer. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","'use strict';\n\n// undocumented cb() API, needed for core, not for public API\nfunction destroy(err, cb) {\n var _this = this;\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n process.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n process.nextTick(emitErrorNT, this, err);\n }\n }\n return this;\n }\n\n // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n }\n\n // if this is a duplex stream mark the writable part as destroyed as well\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n } else if (cb) {\n process.nextTick(emitCloseNT, _this);\n cb(err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n });\n return this;\n}\nfunction emitErrorAndCloseNT(self, err) {\n emitErrorNT(self, err);\n emitCloseNT(self);\n}\nfunction emitCloseNT(self) {\n if (self._writableState && !self._writableState.emitClose) return;\n if (self._readableState && !self._readableState.emitClose) return;\n self.emit('close');\n}\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\nfunction errorOrDestroy(stream, err) {\n // We have tests that rely on errors being emitted\n // in the same tick, so changing this is semver major.\n // For now when you opt-in to autoDestroy we allow\n // the error to be emitted nextTick. In a future\n // semver major update we should change the default to this.\n\n var rState = stream._readableState;\n var wState = stream._writableState;\n if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);\n}\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy,\n errorOrDestroy: errorOrDestroy\n};","'use strict';\n\nvar _Object$setPrototypeO;\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nvar finished = require('./end-of-stream');\nvar kLastResolve = Symbol('lastResolve');\nvar kLastReject = Symbol('lastReject');\nvar kError = Symbol('error');\nvar kEnded = Symbol('ended');\nvar kLastPromise = Symbol('lastPromise');\nvar kHandlePromise = Symbol('handlePromise');\nvar kStream = Symbol('stream');\nfunction createIterResult(value, done) {\n return {\n value: value,\n done: done\n };\n}\nfunction readAndResolve(iter) {\n var resolve = iter[kLastResolve];\n if (resolve !== null) {\n var data = iter[kStream].read();\n // we defer if data is null\n // we can be expecting either 'end' or\n // 'error'\n if (data !== null) {\n iter[kLastPromise] = null;\n iter[kLastResolve] = null;\n iter[kLastReject] = null;\n resolve(createIterResult(data, false));\n }\n }\n}\nfunction onReadable(iter) {\n // we wait for the next tick, because it might\n // emit an error with process.nextTick\n process.nextTick(readAndResolve, iter);\n}\nfunction wrapForNext(lastPromise, iter) {\n return function (resolve, reject) {\n lastPromise.then(function () {\n if (iter[kEnded]) {\n resolve(createIterResult(undefined, true));\n return;\n }\n iter[kHandlePromise](resolve, reject);\n }, reject);\n };\n}\nvar AsyncIteratorPrototype = Object.getPrototypeOf(function () {});\nvar ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {\n get stream() {\n return this[kStream];\n },\n next: function next() {\n var _this = this;\n // if we have detected an error in the meanwhile\n // reject straight away\n var error = this[kError];\n if (error !== null) {\n return Promise.reject(error);\n }\n if (this[kEnded]) {\n return Promise.resolve(createIterResult(undefined, true));\n }\n if (this[kStream].destroyed) {\n // We need to defer via nextTick because if .destroy(err) is\n // called, the error will be emitted via nextTick, and\n // we cannot guarantee that there is no error lingering around\n // waiting to be emitted.\n return new Promise(function (resolve, reject) {\n process.nextTick(function () {\n if (_this[kError]) {\n reject(_this[kError]);\n } else {\n resolve(createIterResult(undefined, true));\n }\n });\n });\n }\n\n // if we have multiple next() calls\n // we will wait for the previous Promise to finish\n // this logic is optimized to support for await loops,\n // where next() is only called once at a time\n var lastPromise = this[kLastPromise];\n var promise;\n if (lastPromise) {\n promise = new Promise(wrapForNext(lastPromise, this));\n } else {\n // fast path needed to support multiple this.push()\n // without triggering the next() queue\n var data = this[kStream].read();\n if (data !== null) {\n return Promise.resolve(createIterResult(data, false));\n }\n promise = new Promise(this[kHandlePromise]);\n }\n this[kLastPromise] = promise;\n return promise;\n }\n}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {\n return this;\n}), _defineProperty(_Object$setPrototypeO, \"return\", function _return() {\n var _this2 = this;\n // destroy(err, cb) is a private API\n // we can guarantee we have that here, because we control the\n // Readable class this is attached to\n return new Promise(function (resolve, reject) {\n _this2[kStream].destroy(null, function (err) {\n if (err) {\n reject(err);\n return;\n }\n resolve(createIterResult(undefined, true));\n });\n });\n}), _Object$setPrototypeO), AsyncIteratorPrototype);\nvar createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {\n var _Object$create;\n var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {\n value: stream,\n writable: true\n }), _defineProperty(_Object$create, kLastResolve, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kLastReject, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kError, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kEnded, {\n value: stream._readableState.endEmitted,\n writable: true\n }), _defineProperty(_Object$create, kHandlePromise, {\n value: function value(resolve, reject) {\n var data = iterator[kStream].read();\n if (data) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(data, false));\n } else {\n iterator[kLastResolve] = resolve;\n iterator[kLastReject] = reject;\n }\n },\n writable: true\n }), _Object$create));\n iterator[kLastPromise] = null;\n finished(stream, function (err) {\n if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {\n var reject = iterator[kLastReject];\n // reject if we are waiting for data in the Promise\n // returned by next() and store the error\n if (reject !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n reject(err);\n }\n iterator[kError] = err;\n return;\n }\n var resolve = iterator[kLastResolve];\n if (resolve !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(undefined, true));\n }\n iterator[kEnded] = true;\n });\n stream.on('readable', onReadable.bind(null, iterator));\n return iterator;\n};\nmodule.exports = createReadableStreamAsyncIterator;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.nmd = (module) => {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(156);\n"],"names":["root","factory","exports","module","define","amd","a","i","self","ReflectOwnKeys","R","Reflect","ReflectApply","apply","target","receiver","args","Function","prototype","call","ownKeys","Object","getOwnPropertySymbols","getOwnPropertyNames","concat","NumberIsNaN","Number","isNaN","value","EventEmitter","init","this","once","emitter","name","Promise","resolve","reject","errorListener","err","removeListener","resolver","slice","arguments","eventTargetAgnosticAddListener","handler","on","addErrorHandlerIfEventEmitter","_events","undefined","_eventsCount","_maxListeners","defaultMaxListeners","checkListener","listener","TypeError","_getMaxListeners","that","_addListener","type","prepend","m","events","existing","warning","create","newListener","emit","unshift","push","length","warned","w","Error","String","count","console","warn","onceWrapper","fired","wrapFn","_onceWrap","state","wrapped","bind","_listeners","unwrap","evlistener","arr","ret","Array","unwrapListeners","arrayClone","listenerCount","n","copy","flags","addEventListener","wrapListener","arg","removeEventListener","defineProperty","enumerable","get","set","RangeError","getPrototypeOf","setMaxListeners","getMaxListeners","doError","error","er","message","context","len","listeners","addListener","prependListener","prependOnceListener","list","position","originalListener","shift","index","pop","spliceOne","off","removeAllListeners","key","keys","rawListeners","eventNames","__importDefault","mod","__esModule","Buffer","BigInteger","Varint","Writer","Reader","reader_1","writer_1","varint_1","big_integer_1","default","buffer_1","codes","createErrorType","code","Base","NodeError","_Base","subClass","superClass","arg1","arg2","arg3","getMessage","constructor","__proto__","oneOf","expected","thing","isArray","map","join","actual","determiner","search","msg","str","start","substr","replace","this_len","substring","endsWith","indexOf","BASE","MAX_INT","MAX_INT_ARR","smallToArray","DEFAULT_ALPHABET","supportsNativeBigInt","BigInt","Integer","v","radix","alphabet","caseSensitive","parseValue","parseBase","sign","isSmall","SmallInteger","NativeBigInt","isPrecise","Math","floor","arrayToSmall","trim","compareAbs","createArray","x","truncate","ceil","add","b","sum","l_a","l_b","r","carry","base","addAny","addSmall","l","subtract","difference","a_l","b_l","borrow","subtractSmall","multiplyLong","product","a_i","j","multiplySmall","shiftLeft","multiplyKaratsuba","y","max","d","c","ac","bd","abcd","multiplySmallAndArray","square","divModSmall","lambda","q","remainder","divisor","quotient","divModAny","negate","abs","comparison","quotientDigit","result","divisorMostSignificantDigit","divMod1","guess","xlen","highx","highy","check","part","reverse","divMod2","qSign","mSign","isBasicPrime","isUnit","equals","isEven","isDivisibleBy","lesser","millerRabinTest","nPrev","prev","divide","next","bigInt","modPow","plus","subtractAny","minus","small","multiply","l1","l2","times","_multiplyBySmall","divmod","over","pow","toString","_0","_1","_2","isNegative","exp","isZero","modInv","isPositive","isOdd","compare","Infinity","compareTo","eq","notEquals","neq","greater","gt","lt","greaterOrEquals","geq","lesserOrEquals","leq","isPrime","strict","bits","bitLength","logN","log","toJSNumber","t","isProbablePrime","iterations","rng","randBetween","lastT","lastR","zero","newT","one","newR","powersOfTwo","powers2Length","highestPower2","shift_isSmall","bitwise","fn","xSign","ySign","xRem","not","yRem","xDigit","yDigit","xDivMod","yDivMod","shiftRight","remQuo","and","or","xor","LOBMASK_I","roughLOB","integerLogarithm","tmp","p","e","min","gcd","text","toLowerCase","absBase","alphabetValues","digits","parseBaseFromArray","val","toBase","valueOf","neg","out","left","digit","toBaseString","stringify","parseStringValue","split","decimalPlace","test","parseNumberValue","toArray","toJSON","parseInt","minusOne","lcm","isInstance","usedRNG","random","low","range","restricted","top","fromArray","hasOwnProperty","isEncoding","encoding","StringDecoder","nb","enc","nenc","retried","_normalizeEncoding","normalizeEncoding","utf16Text","end","utf16End","fillLast","utf8FillLast","base64Text","base64End","write","simpleWrite","simpleEnd","lastNeed","lastTotal","lastChar","allocUnsafe","utf8CheckByte","byte","buf","utf8CheckExtraBytes","charCodeAt","total","utf8CheckIncomplete","decode","buffer","counter","encode","offset","from","Base58","encoded","base58_to_binary","data","binary_to_base58","ERR_STREAM_PREMATURE_CLOSE","noop","eos","stream","opts","callback","called","_len","_key","readable","writable","onlegacyfinish","onfinish","writableEnded","_writableState","finished","readableEnded","_readableState","endEmitted","onend","onerror","onclose","ended","onrequest","req","setHeader","abort","isRequest","read","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","s","NaN","rt","LN2","base64","ieee754","customInspectSymbol","Symbol","SlowBuffer","alloc","INSPECT_MAX_BYTES","K_MAX_LENGTH","createBuffer","Uint8Array","setPrototypeOf","encodingOrOffset","string","byteLength","fromString","ArrayBuffer","isView","arrayView","fromArrayBuffer","byteOffset","fromArrayLike","fromArrayView","SharedArrayBuffer","obj","isBuffer","checked","numberIsNaN","fromObject","toPrimitive","assertSize","size","array","mustMatch","loweredCase","utf8ToBytes","base64ToBytes","slowToString","hexSlice","utf8Slice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","bidirectionalIndexOf","dir","arrayIndexOf","lastIndexOf","indexSize","arrLength","valLength","readUInt16BE","foundIndex","found","hexWrite","remaining","strLen","parsed","utf8Write","blitBuffer","asciiWrite","byteArray","asciiToBytes","base64Write","ucs2Write","units","hi","lo","utf16leToBytes","fromByteArray","res","firstByte","codePoint","bytesPerSequence","secondByte","thirdByte","fourthByte","tempCodePoint","codePoints","MAX_ARGUMENTS_LENGTH","fromCharCode","decodeCodePointsArray","kMaxLength","TYPED_ARRAY_SUPPORT","proto","foo","typedArraySupport","poolSize","fill","allocUnsafeSlow","_isBuffer","pos","swap16","swap32","swap64","toLocaleString","inspect","thisStart","thisEnd","thisCopy","targetCopy","includes","isFinite","_arr","hexSliceLookupTable","bytes","checkOffset","ext","checkInt","wrtBigUInt64LE","checkIntBI","wrtBigUInt64BE","checkIEEE754","writeFloat","littleEndian","noAssert","writeDouble","newBuf","subarray","readUintLE","readUIntLE","mul","readUintBE","readUIntBE","readUint8","readUInt8","readUint16LE","readUInt16LE","readUint16BE","readUint32LE","readUInt32LE","readUint32BE","readUInt32BE","readBigUInt64LE","defineBigIntMethod","validateNumber","first","last","boundsError","readBigUInt64BE","readIntLE","readIntBE","readInt8","readInt16LE","readInt16BE","readInt32LE","readInt32BE","readBigInt64LE","readBigInt64BE","readFloatLE","readFloatBE","readDoubleLE","readDoubleBE","writeUintLE","writeUIntLE","writeUintBE","writeUIntBE","writeUint8","writeUInt8","writeUint16LE","writeUInt16LE","writeUint16BE","writeUInt16BE","writeUint32LE","writeUInt32LE","writeUint32BE","writeUInt32BE","writeBigUInt64LE","writeBigUInt64BE","writeIntLE","limit","sub","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","writeBigInt64LE","writeBigInt64BE","writeFloatLE","writeFloatBE","writeDoubleLE","writeDoubleBE","targetStart","copyWithin","errors","E","sym","super","configurable","stack","addNumericalSeparator","ERR_OUT_OF_RANGE","checkBounds","ERR_INVALID_ARG_TYPE","ERR_BUFFER_OUT_OF_BOUNDS","input","received","isInteger","INVALID_BASE64_RE","leadSurrogate","toByteArray","base64clean","src","dst","table","i16","BufferBigIntNotDefined","ERR_INVALID_OPT_VALUE","getHighWaterMark","options","duplexKey","isDuplex","hwm","highWaterMark","highWaterMarkFrom","objectMode","stream_1","Readable","payload","_buffer","_readIndex","append","readIndex","determineBits","hex","padStart","tempBuffer","_read","okToSend","clear","hash","signed_integer","bigEndian","int8_t","int16_t","int32_t","int64_t","varint","time_t","num","getTime","uint64_t","unsigned_integer","uint8_t","uint16_t","uint32_t","uint128_t","uint256_t","uint512_t","levin","tempValue","byteCount","Stream","EE","inherits","Writable","Duplex","Transform","PassThrough","pipeline","pipe","dest","source","ondata","chunk","pause","ondrain","resume","_isStdio","didOnEnd","destroy","cleanup","base58_chars","base58Map","base58M","create_base58_map","base58String","match","lz","psz","base58_match","psz_Uint","base58_temp","lastValue","reduce","acc","filter","uint8array","objectKeys","method","allowHalfOpen","process","nextTick","onEndNT","getBuffer","destroyed","ReadableState","debug","EElistenerCount","OurUint8Array","g","window","debugUtil","debuglog","createReadableStreamAsyncIterator","BufferList","destroyImpl","_require$codes","ERR_STREAM_PUSH_AFTER_EOF","ERR_METHOD_NOT_IMPLEMENTED","ERR_STREAM_UNSHIFT_AFTER_END_EVENT","errorOrDestroy","kProxyEvents","readableObjectMode","pipes","pipesCount","flowing","reading","sync","needReadable","emittedReadable","readableListening","resumeScheduled","paused","emitClose","autoDestroy","defaultEncoding","awaitDrain","readingMore","decoder","_destroy","readableAddChunk","addToFront","skipChunkCheck","emitReadable","emitReadable_","onEofChunk","chunkInvalid","_uint8ArrayToBuffer","addChunk","maybeReadMore","_undestroy","undestroy","cb","isPaused","setEncoding","head","content","MAX_HWM","howMuchToRead","computeNewHighWaterMark","flow","maybeReadMore_","updateReadableListening","nReadingNextTick","resume_","fromList","consume","endReadable","endReadableNT","wState","xs","nOrig","doRead","pipeOpts","endFn","stdout","stderr","unpipe","onunpipe","unpipeInfo","hasUnpiped","cleanedUp","needDrain","pipeOnDrain","event","dests","splice","ev","wrap","_this","asyncIterator","_fromList","iterable","b64","lens","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","parts","maxChunkLength","len2","encodeChunk","lookup","output","_transform","ERR_MULTIPLE_CALLBACK","ERR_TRANSFORM_ALREADY_TRANSFORMING","ERR_TRANSFORM_WITH_LENGTH_0","afterTransform","ts","_transformState","transforming","writecb","writechunk","rs","needTransform","writeencoding","transform","flush","_flush","prefinish","done","_write","err2","config","localStorage","_","trace","ctor","superCtor","super_","TempCtor","ALPHABET","char","ENCODED_BLOCK_SIZES","FULL_ENCODED_BLOCK_SIZE","UINT64_MAX","CryptoNoteBase58","cn_decode","fullBlockCount","lastBlockSize","lastBlockDecodedSize","decodeBlock","cn_encode","_data","resSize","encodeBlock","resNum","order","div","CorkedRequest","entry","finish","corkReq","pendingcb","onCorkedFinish","corkedRequestsFree","WritableState","realHasInstance","internalUtil","deprecate","ERR_STREAM_CANNOT_PIPE","ERR_STREAM_DESTROYED","ERR_STREAM_NULL_VALUES","ERR_STREAM_WRITE_AFTER_END","ERR_UNKNOWN_ENCODING","nop","writableObjectMode","finalCalled","ending","noDecode","decodeStrings","writing","corked","bufferProcessing","onwrite","writelen","onwriteStateUpdate","finishMaybe","errorEmitted","onwriteError","needFinish","bufferedRequest","clearBuffer","afterWrite","lastBufferedRequest","prefinished","bufferedRequestCount","writev","_writev","final","_final","doWrite","onwriteDrain","holder","allBuffers","isBuf","callFinal","need","rState","current","hasInstance","object","writeAfterEnd","validChunk","newChunk","decodeChunk","writeOrBuffer","cork","uncork","setDefaultEncoding","endWritable","enumerableOnly","symbols","getOwnPropertyDescriptor","_objectSpread","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","_toPropertyKey","_defineProperties","props","descriptor","prim","hint","_toPrimitive","custom","instance","Constructor","_classCallCheck","tail","protoProps","hasStrings","_getString","_getBuffer","depth","customInspect","ERR_MISSING_ARGS","to","streams","popCallback","destroys","closed","destroyer","blob","_current_offset","unreadBytes","unread","unreadBuffer","compact","reset","skip","epoch","Date","peek","sizeMask","bytesLeft","nv","copyProps","SafeBuffer","emitErrorAndCloseNT","emitErrorNT","emitCloseNT","readableDestroyed","writableDestroyed","_Object$setPrototypeO","kLastResolve","kLastReject","kError","kEnded","kLastPromise","kHandlePromise","kStream","createIterResult","readAndResolve","iter","onReadable","AsyncIteratorPrototype","ReadableStreamAsyncIteratorPrototype","promise","lastPromise","then","wrapForNext","_this2","_Object$create","iterator","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","id","loaded","__webpack_modules__","globalThis","nmd","paths","children"],"sourceRoot":""}
1
+ {"version":3,"file":"base58.min.js","mappings":"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","sources":["webpack://@gibme/base58/webpack/universalModuleDefinition","webpack://@gibme/base58/./node_modules/events/events.js","webpack://@gibme/base58/./node_modules/@gibme/bytepack/dist/index.js","webpack://@gibme/base58/./node_modules/readable-stream/errors-browser.js","webpack://@gibme/base58/./node_modules/big-integer/BigInteger.js","webpack://@gibme/base58/./node_modules/string_decoder/lib/string_decoder.js","webpack://@gibme/base58/./node_modules/@gibme/bytepack/dist/varint.js","webpack://@gibme/base58/./src/index.ts","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/from-browser.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/end-of-stream.js","webpack://@gibme/base58/./node_modules/ieee754/index.js","webpack://@gibme/base58/./node_modules/buffer/index.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/state.js","webpack://@gibme/base58/./node_modules/@gibme/bytepack/dist/writer.js","webpack://@gibme/base58/./node_modules/stream-browserify/index.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/stream-browser.js","webpack://@gibme/base58/./src/base58-js.ts","webpack://@gibme/base58/./node_modules/readable-stream/lib/_stream_duplex.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/_stream_readable.js","webpack://@gibme/base58/./node_modules/base64-js/index.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/_stream_passthrough.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/_stream_transform.js","webpack://@gibme/base58/./node_modules/util-deprecate/browser.js","webpack://@gibme/base58/./node_modules/inherits/inherits_browser.js","webpack://@gibme/base58/./src/cryptonote_base58.ts","webpack://@gibme/base58/./node_modules/readable-stream/lib/_stream_writable.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/buffer_list.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/pipeline.js","webpack://@gibme/base58/./node_modules/@gibme/bytepack/dist/reader.js","webpack://@gibme/base58/./node_modules/safe-buffer/index.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/destroy.js","webpack://@gibme/base58/./node_modules/readable-stream/lib/internal/streams/async_iterator.js","webpack://@gibme/base58/webpack/bootstrap","webpack://@gibme/base58/webpack/runtime/global","webpack://@gibme/base58/webpack/runtime/node module decorator","webpack://@gibme/base58/webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse {\n\t\tvar a = factory();\n\t\tfor(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];\n\t}\n})(self, () => {\nreturn ","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n\nfunction once(emitter, name) {\n return new Promise(function (resolve, reject) {\n function errorListener(err) {\n emitter.removeListener(name, resolver);\n reject(err);\n }\n\n function resolver() {\n if (typeof emitter.removeListener === 'function') {\n emitter.removeListener('error', errorListener);\n }\n resolve([].slice.call(arguments));\n };\n\n eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n if (name !== 'error') {\n addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n }\n });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n if (typeof emitter.on === 'function') {\n eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n if (typeof emitter.on === 'function') {\n if (flags.once) {\n emitter.once(name, listener);\n } else {\n emitter.on(name, listener);\n }\n } else if (typeof emitter.addEventListener === 'function') {\n // EventTarget does not have `error` event semantics like Node\n // EventEmitters, we do not listen for `error` events here.\n emitter.addEventListener(name, function wrapListener(arg) {\n // IE does not have builtin `{ once: true }` support so we\n // have to do it manually.\n if (flags.once) {\n emitter.removeEventListener(name, wrapListener);\n }\n listener(arg);\n });\n } else {\n throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n }\n}\n","\"use strict\";\n// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Buffer = exports.BigInteger = exports.Varint = exports.Writer = exports.Reader = void 0;\nvar reader_1 = require(\"./reader\");\nObject.defineProperty(exports, \"Reader\", { enumerable: true, get: function () { return reader_1.Reader; } });\nvar writer_1 = require(\"./writer\");\nObject.defineProperty(exports, \"Writer\", { enumerable: true, get: function () { return writer_1.Writer; } });\nvar varint_1 = require(\"./varint\");\nObject.defineProperty(exports, \"Varint\", { enumerable: true, get: function () { return varint_1.Varint; } });\nvar big_integer_1 = require(\"big-integer\");\nObject.defineProperty(exports, \"BigInteger\", { enumerable: true, get: function () { return __importDefault(big_integer_1).default; } });\nvar buffer_1 = require(\"buffer\");\nObject.defineProperty(exports, \"Buffer\", { enumerable: true, get: function () { return buffer_1.Buffer; } });\n//# sourceMappingURL=index.js.map","'use strict';\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar codes = {};\n\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error;\n }\n\n function getMessage(arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message;\n } else {\n return message(arg1, arg2, arg3);\n }\n }\n\n var NodeError =\n /*#__PURE__*/\n function (_Base) {\n _inheritsLoose(NodeError, _Base);\n\n function NodeError(arg1, arg2, arg3) {\n return _Base.call(this, getMessage(arg1, arg2, arg3)) || this;\n }\n\n return NodeError;\n }(Base);\n\n NodeError.prototype.name = Base.name;\n NodeError.prototype.code = code;\n codes[code] = NodeError;\n} // https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\n\n\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n var len = expected.length;\n expected = expected.map(function (i) {\n return String(i);\n });\n\n if (len > 2) {\n return \"one of \".concat(thing, \" \").concat(expected.slice(0, len - 1).join(', '), \", or \") + expected[len - 1];\n } else if (len === 2) {\n return \"one of \".concat(thing, \" \").concat(expected[0], \" or \").concat(expected[1]);\n } else {\n return \"of \".concat(thing, \" \").concat(expected[0]);\n }\n } else {\n return \"of \".concat(thing, \" \").concat(String(expected));\n }\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\n\n\nfunction startsWith(str, search, pos) {\n return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\n\n\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n\n return str.substring(this_len - search.length, this_len) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\n\n\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\n\ncreateErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {\n return 'The value \"' + value + '\" is invalid for option \"' + name + '\"';\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n // determiner: 'must be' or 'must not be'\n var determiner;\n\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n\n var msg;\n\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = \"The \".concat(name, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n } else {\n var type = includes(name, '.') ? 'property' : 'argument';\n msg = \"The \\\"\".concat(name, \"\\\" \").concat(type, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n }\n\n msg += \". Received type \".concat(typeof actual);\n return msg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');\ncreateErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {\n return 'The ' + name + ' method is not implemented';\n});\ncreateErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');\ncreateErrorType('ERR_STREAM_DESTROYED', function (name) {\n return 'Cannot call ' + name + ' after a stream was destroyed';\n});\ncreateErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');\ncreateErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');\ncreateErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');\ncreateErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);\ncreateErrorType('ERR_UNKNOWN_ENCODING', function (arg) {\n return 'Unknown encoding: ' + arg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');\nmodule.exports.codes = codes;\n","var bigInt = (function (undefined) {\r\n \"use strict\";\r\n\r\n var BASE = 1e7,\r\n LOG_BASE = 7,\r\n MAX_INT = 9007199254740992,\r\n MAX_INT_ARR = smallToArray(MAX_INT),\r\n DEFAULT_ALPHABET = \"0123456789abcdefghijklmnopqrstuvwxyz\";\r\n\r\n var supportsNativeBigInt = typeof BigInt === \"function\";\r\n\r\n function Integer(v, radix, alphabet, caseSensitive) {\r\n if (typeof v === \"undefined\") return Integer[0];\r\n if (typeof radix !== \"undefined\") return +radix === 10 && !alphabet ? parseValue(v) : parseBase(v, radix, alphabet, caseSensitive);\r\n return parseValue(v);\r\n }\r\n\r\n function BigInteger(value, sign) {\r\n this.value = value;\r\n this.sign = sign;\r\n this.isSmall = false;\r\n }\r\n BigInteger.prototype = Object.create(Integer.prototype);\r\n\r\n function SmallInteger(value) {\r\n this.value = value;\r\n this.sign = value < 0;\r\n this.isSmall = true;\r\n }\r\n SmallInteger.prototype = Object.create(Integer.prototype);\r\n\r\n function NativeBigInt(value) {\r\n this.value = value;\r\n }\r\n NativeBigInt.prototype = Object.create(Integer.prototype);\r\n\r\n function isPrecise(n) {\r\n return -MAX_INT < n && n < MAX_INT;\r\n }\r\n\r\n function smallToArray(n) { // For performance reasons doesn't reference BASE, need to change this function if BASE changes\r\n if (n < 1e7)\r\n return [n];\r\n if (n < 1e14)\r\n return [n % 1e7, Math.floor(n / 1e7)];\r\n return [n % 1e7, Math.floor(n / 1e7) % 1e7, Math.floor(n / 1e14)];\r\n }\r\n\r\n function arrayToSmall(arr) { // If BASE changes this function may need to change\r\n trim(arr);\r\n var length = arr.length;\r\n if (length < 4 && compareAbs(arr, MAX_INT_ARR) < 0) {\r\n switch (length) {\r\n case 0: return 0;\r\n case 1: return arr[0];\r\n case 2: return arr[0] + arr[1] * BASE;\r\n default: return arr[0] + (arr[1] + arr[2] * BASE) * BASE;\r\n }\r\n }\r\n return arr;\r\n }\r\n\r\n function trim(v) {\r\n var i = v.length;\r\n while (v[--i] === 0);\r\n v.length = i + 1;\r\n }\r\n\r\n function createArray(length) { // function shamelessly stolen from Yaffle's library https://github.com/Yaffle/BigInteger\r\n var x = new Array(length);\r\n var i = -1;\r\n while (++i < length) {\r\n x[i] = 0;\r\n }\r\n return x;\r\n }\r\n\r\n function truncate(n) {\r\n if (n > 0) return Math.floor(n);\r\n return Math.ceil(n);\r\n }\r\n\r\n function add(a, b) { // assumes a and b are arrays with a.length >= b.length\r\n var l_a = a.length,\r\n l_b = b.length,\r\n r = new Array(l_a),\r\n carry = 0,\r\n base = BASE,\r\n sum, i;\r\n for (i = 0; i < l_b; i++) {\r\n sum = a[i] + b[i] + carry;\r\n carry = sum >= base ? 1 : 0;\r\n r[i] = sum - carry * base;\r\n }\r\n while (i < l_a) {\r\n sum = a[i] + carry;\r\n carry = sum === base ? 1 : 0;\r\n r[i++] = sum - carry * base;\r\n }\r\n if (carry > 0) r.push(carry);\r\n return r;\r\n }\r\n\r\n function addAny(a, b) {\r\n if (a.length >= b.length) return add(a, b);\r\n return add(b, a);\r\n }\r\n\r\n function addSmall(a, carry) { // assumes a is array, carry is number with 0 <= carry < MAX_INT\r\n var l = a.length,\r\n r = new Array(l),\r\n base = BASE,\r\n sum, i;\r\n for (i = 0; i < l; i++) {\r\n sum = a[i] - base + carry;\r\n carry = Math.floor(sum / base);\r\n r[i] = sum - carry * base;\r\n carry += 1;\r\n }\r\n while (carry > 0) {\r\n r[i++] = carry % base;\r\n carry = Math.floor(carry / base);\r\n }\r\n return r;\r\n }\r\n\r\n BigInteger.prototype.add = function (v) {\r\n var n = parseValue(v);\r\n if (this.sign !== n.sign) {\r\n return this.subtract(n.negate());\r\n }\r\n var a = this.value, b = n.value;\r\n if (n.isSmall) {\r\n return new BigInteger(addSmall(a, Math.abs(b)), this.sign);\r\n }\r\n return new BigInteger(addAny(a, b), this.sign);\r\n };\r\n BigInteger.prototype.plus = BigInteger.prototype.add;\r\n\r\n SmallInteger.prototype.add = function (v) {\r\n var n = parseValue(v);\r\n var a = this.value;\r\n if (a < 0 !== n.sign) {\r\n return this.subtract(n.negate());\r\n }\r\n var b = n.value;\r\n if (n.isSmall) {\r\n if (isPrecise(a + b)) return new SmallInteger(a + b);\r\n b = smallToArray(Math.abs(b));\r\n }\r\n return new BigInteger(addSmall(b, Math.abs(a)), a < 0);\r\n };\r\n SmallInteger.prototype.plus = SmallInteger.prototype.add;\r\n\r\n NativeBigInt.prototype.add = function (v) {\r\n return new NativeBigInt(this.value + parseValue(v).value);\r\n }\r\n NativeBigInt.prototype.plus = NativeBigInt.prototype.add;\r\n\r\n function subtract(a, b) { // assumes a and b are arrays with a >= b\r\n var a_l = a.length,\r\n b_l = b.length,\r\n r = new Array(a_l),\r\n borrow = 0,\r\n base = BASE,\r\n i, difference;\r\n for (i = 0; i < b_l; i++) {\r\n difference = a[i] - borrow - b[i];\r\n if (difference < 0) {\r\n difference += base;\r\n borrow = 1;\r\n } else borrow = 0;\r\n r[i] = difference;\r\n }\r\n for (i = b_l; i < a_l; i++) {\r\n difference = a[i] - borrow;\r\n if (difference < 0) difference += base;\r\n else {\r\n r[i++] = difference;\r\n break;\r\n }\r\n r[i] = difference;\r\n }\r\n for (; i < a_l; i++) {\r\n r[i] = a[i];\r\n }\r\n trim(r);\r\n return r;\r\n }\r\n\r\n function subtractAny(a, b, sign) {\r\n var value;\r\n if (compareAbs(a, b) >= 0) {\r\n value = subtract(a, b);\r\n } else {\r\n value = subtract(b, a);\r\n sign = !sign;\r\n }\r\n value = arrayToSmall(value);\r\n if (typeof value === \"number\") {\r\n if (sign) value = -value;\r\n return new SmallInteger(value);\r\n }\r\n return new BigInteger(value, sign);\r\n }\r\n\r\n function subtractSmall(a, b, sign) { // assumes a is array, b is number with 0 <= b < MAX_INT\r\n var l = a.length,\r\n r = new Array(l),\r\n carry = -b,\r\n base = BASE,\r\n i, difference;\r\n for (i = 0; i < l; i++) {\r\n difference = a[i] + carry;\r\n carry = Math.floor(difference / base);\r\n difference %= base;\r\n r[i] = difference < 0 ? difference + base : difference;\r\n }\r\n r = arrayToSmall(r);\r\n if (typeof r === \"number\") {\r\n if (sign) r = -r;\r\n return new SmallInteger(r);\r\n } return new BigInteger(r, sign);\r\n }\r\n\r\n BigInteger.prototype.subtract = function (v) {\r\n var n = parseValue(v);\r\n if (this.sign !== n.sign) {\r\n return this.add(n.negate());\r\n }\r\n var a = this.value, b = n.value;\r\n if (n.isSmall)\r\n return subtractSmall(a, Math.abs(b), this.sign);\r\n return subtractAny(a, b, this.sign);\r\n };\r\n BigInteger.prototype.minus = BigInteger.prototype.subtract;\r\n\r\n SmallInteger.prototype.subtract = function (v) {\r\n var n = parseValue(v);\r\n var a = this.value;\r\n if (a < 0 !== n.sign) {\r\n return this.add(n.negate());\r\n }\r\n var b = n.value;\r\n if (n.isSmall) {\r\n return new SmallInteger(a - b);\r\n }\r\n return subtractSmall(b, Math.abs(a), a >= 0);\r\n };\r\n SmallInteger.prototype.minus = SmallInteger.prototype.subtract;\r\n\r\n NativeBigInt.prototype.subtract = function (v) {\r\n return new NativeBigInt(this.value - parseValue(v).value);\r\n }\r\n NativeBigInt.prototype.minus = NativeBigInt.prototype.subtract;\r\n\r\n BigInteger.prototype.negate = function () {\r\n return new BigInteger(this.value, !this.sign);\r\n };\r\n SmallInteger.prototype.negate = function () {\r\n var sign = this.sign;\r\n var small = new SmallInteger(-this.value);\r\n small.sign = !sign;\r\n return small;\r\n };\r\n NativeBigInt.prototype.negate = function () {\r\n return new NativeBigInt(-this.value);\r\n }\r\n\r\n BigInteger.prototype.abs = function () {\r\n return new BigInteger(this.value, false);\r\n };\r\n SmallInteger.prototype.abs = function () {\r\n return new SmallInteger(Math.abs(this.value));\r\n };\r\n NativeBigInt.prototype.abs = function () {\r\n return new NativeBigInt(this.value >= 0 ? this.value : -this.value);\r\n }\r\n\r\n\r\n function multiplyLong(a, b) {\r\n var a_l = a.length,\r\n b_l = b.length,\r\n l = a_l + b_l,\r\n r = createArray(l),\r\n base = BASE,\r\n product, carry, i, a_i, b_j;\r\n for (i = 0; i < a_l; ++i) {\r\n a_i = a[i];\r\n for (var j = 0; j < b_l; ++j) {\r\n b_j = b[j];\r\n product = a_i * b_j + r[i + j];\r\n carry = Math.floor(product / base);\r\n r[i + j] = product - carry * base;\r\n r[i + j + 1] += carry;\r\n }\r\n }\r\n trim(r);\r\n return r;\r\n }\r\n\r\n function multiplySmall(a, b) { // assumes a is array, b is number with |b| < BASE\r\n var l = a.length,\r\n r = new Array(l),\r\n base = BASE,\r\n carry = 0,\r\n product, i;\r\n for (i = 0; i < l; i++) {\r\n product = a[i] * b + carry;\r\n carry = Math.floor(product / base);\r\n r[i] = product - carry * base;\r\n }\r\n while (carry > 0) {\r\n r[i++] = carry % base;\r\n carry = Math.floor(carry / base);\r\n }\r\n return r;\r\n }\r\n\r\n function shiftLeft(x, n) {\r\n var r = [];\r\n while (n-- > 0) r.push(0);\r\n return r.concat(x);\r\n }\r\n\r\n function multiplyKaratsuba(x, y) {\r\n var n = Math.max(x.length, y.length);\r\n\r\n if (n <= 30) return multiplyLong(x, y);\r\n n = Math.ceil(n / 2);\r\n\r\n var b = x.slice(n),\r\n a = x.slice(0, n),\r\n d = y.slice(n),\r\n c = y.slice(0, n);\r\n\r\n var ac = multiplyKaratsuba(a, c),\r\n bd = multiplyKaratsuba(b, d),\r\n abcd = multiplyKaratsuba(addAny(a, b), addAny(c, d));\r\n\r\n var product = addAny(addAny(ac, shiftLeft(subtract(subtract(abcd, ac), bd), n)), shiftLeft(bd, 2 * n));\r\n trim(product);\r\n return product;\r\n }\r\n\r\n // The following function is derived from a surface fit of a graph plotting the performance difference\r\n // between long multiplication and karatsuba multiplication versus the lengths of the two arrays.\r\n function useKaratsuba(l1, l2) {\r\n return -0.012 * l1 - 0.012 * l2 + 0.000015 * l1 * l2 > 0;\r\n }\r\n\r\n BigInteger.prototype.multiply = function (v) {\r\n var n = parseValue(v),\r\n a = this.value, b = n.value,\r\n sign = this.sign !== n.sign,\r\n abs;\r\n if (n.isSmall) {\r\n if (b === 0) return Integer[0];\r\n if (b === 1) return this;\r\n if (b === -1) return this.negate();\r\n abs = Math.abs(b);\r\n if (abs < BASE) {\r\n return new BigInteger(multiplySmall(a, abs), sign);\r\n }\r\n b = smallToArray(abs);\r\n }\r\n if (useKaratsuba(a.length, b.length)) // Karatsuba is only faster for certain array sizes\r\n return new BigInteger(multiplyKaratsuba(a, b), sign);\r\n return new BigInteger(multiplyLong(a, b), sign);\r\n };\r\n\r\n BigInteger.prototype.times = BigInteger.prototype.multiply;\r\n\r\n function multiplySmallAndArray(a, b, sign) { // a >= 0\r\n if (a < BASE) {\r\n return new BigInteger(multiplySmall(b, a), sign);\r\n }\r\n return new BigInteger(multiplyLong(b, smallToArray(a)), sign);\r\n }\r\n SmallInteger.prototype._multiplyBySmall = function (a) {\r\n if (isPrecise(a.value * this.value)) {\r\n return new SmallInteger(a.value * this.value);\r\n }\r\n return multiplySmallAndArray(Math.abs(a.value), smallToArray(Math.abs(this.value)), this.sign !== a.sign);\r\n };\r\n BigInteger.prototype._multiplyBySmall = function (a) {\r\n if (a.value === 0) return Integer[0];\r\n if (a.value === 1) return this;\r\n if (a.value === -1) return this.negate();\r\n return multiplySmallAndArray(Math.abs(a.value), this.value, this.sign !== a.sign);\r\n };\r\n SmallInteger.prototype.multiply = function (v) {\r\n return parseValue(v)._multiplyBySmall(this);\r\n };\r\n SmallInteger.prototype.times = SmallInteger.prototype.multiply;\r\n\r\n NativeBigInt.prototype.multiply = function (v) {\r\n return new NativeBigInt(this.value * parseValue(v).value);\r\n }\r\n NativeBigInt.prototype.times = NativeBigInt.prototype.multiply;\r\n\r\n function square(a) {\r\n //console.assert(2 * BASE * BASE < MAX_INT);\r\n var l = a.length,\r\n r = createArray(l + l),\r\n base = BASE,\r\n product, carry, i, a_i, a_j;\r\n for (i = 0; i < l; i++) {\r\n a_i = a[i];\r\n carry = 0 - a_i * a_i;\r\n for (var j = i; j < l; j++) {\r\n a_j = a[j];\r\n product = 2 * (a_i * a_j) + r[i + j] + carry;\r\n carry = Math.floor(product / base);\r\n r[i + j] = product - carry * base;\r\n }\r\n r[i + l] = carry;\r\n }\r\n trim(r);\r\n return r;\r\n }\r\n\r\n BigInteger.prototype.square = function () {\r\n return new BigInteger(square(this.value), false);\r\n };\r\n\r\n SmallInteger.prototype.square = function () {\r\n var value = this.value * this.value;\r\n if (isPrecise(value)) return new SmallInteger(value);\r\n return new BigInteger(square(smallToArray(Math.abs(this.value))), false);\r\n };\r\n\r\n NativeBigInt.prototype.square = function (v) {\r\n return new NativeBigInt(this.value * this.value);\r\n }\r\n\r\n function divMod1(a, b) { // Left over from previous version. Performs faster than divMod2 on smaller input sizes.\r\n var a_l = a.length,\r\n b_l = b.length,\r\n base = BASE,\r\n result = createArray(b.length),\r\n divisorMostSignificantDigit = b[b_l - 1],\r\n // normalization\r\n lambda = Math.ceil(base / (2 * divisorMostSignificantDigit)),\r\n remainder = multiplySmall(a, lambda),\r\n divisor = multiplySmall(b, lambda),\r\n quotientDigit, shift, carry, borrow, i, l, q;\r\n if (remainder.length <= a_l) remainder.push(0);\r\n divisor.push(0);\r\n divisorMostSignificantDigit = divisor[b_l - 1];\r\n for (shift = a_l - b_l; shift >= 0; shift--) {\r\n quotientDigit = base - 1;\r\n if (remainder[shift + b_l] !== divisorMostSignificantDigit) {\r\n quotientDigit = Math.floor((remainder[shift + b_l] * base + remainder[shift + b_l - 1]) / divisorMostSignificantDigit);\r\n }\r\n // quotientDigit <= base - 1\r\n carry = 0;\r\n borrow = 0;\r\n l = divisor.length;\r\n for (i = 0; i < l; i++) {\r\n carry += quotientDigit * divisor[i];\r\n q = Math.floor(carry / base);\r\n borrow += remainder[shift + i] - (carry - q * base);\r\n carry = q;\r\n if (borrow < 0) {\r\n remainder[shift + i] = borrow + base;\r\n borrow = -1;\r\n } else {\r\n remainder[shift + i] = borrow;\r\n borrow = 0;\r\n }\r\n }\r\n while (borrow !== 0) {\r\n quotientDigit -= 1;\r\n carry = 0;\r\n for (i = 0; i < l; i++) {\r\n carry += remainder[shift + i] - base + divisor[i];\r\n if (carry < 0) {\r\n remainder[shift + i] = carry + base;\r\n carry = 0;\r\n } else {\r\n remainder[shift + i] = carry;\r\n carry = 1;\r\n }\r\n }\r\n borrow += carry;\r\n }\r\n result[shift] = quotientDigit;\r\n }\r\n // denormalization\r\n remainder = divModSmall(remainder, lambda)[0];\r\n return [arrayToSmall(result), arrayToSmall(remainder)];\r\n }\r\n\r\n function divMod2(a, b) { // Implementation idea shamelessly stolen from Silent Matt's library http://silentmatt.com/biginteger/\r\n // Performs faster than divMod1 on larger input sizes.\r\n var a_l = a.length,\r\n b_l = b.length,\r\n result = [],\r\n part = [],\r\n base = BASE,\r\n guess, xlen, highx, highy, check;\r\n while (a_l) {\r\n part.unshift(a[--a_l]);\r\n trim(part);\r\n if (compareAbs(part, b) < 0) {\r\n result.push(0);\r\n continue;\r\n }\r\n xlen = part.length;\r\n highx = part[xlen - 1] * base + part[xlen - 2];\r\n highy = b[b_l - 1] * base + b[b_l - 2];\r\n if (xlen > b_l) {\r\n highx = (highx + 1) * base;\r\n }\r\n guess = Math.ceil(highx / highy);\r\n do {\r\n check = multiplySmall(b, guess);\r\n if (compareAbs(check, part) <= 0) break;\r\n guess--;\r\n } while (guess);\r\n result.push(guess);\r\n part = subtract(part, check);\r\n }\r\n result.reverse();\r\n return [arrayToSmall(result), arrayToSmall(part)];\r\n }\r\n\r\n function divModSmall(value, lambda) {\r\n var length = value.length,\r\n quotient = createArray(length),\r\n base = BASE,\r\n i, q, remainder, divisor;\r\n remainder = 0;\r\n for (i = length - 1; i >= 0; --i) {\r\n divisor = remainder * base + value[i];\r\n q = truncate(divisor / lambda);\r\n remainder = divisor - q * lambda;\r\n quotient[i] = q | 0;\r\n }\r\n return [quotient, remainder | 0];\r\n }\r\n\r\n function divModAny(self, v) {\r\n var value, n = parseValue(v);\r\n if (supportsNativeBigInt) {\r\n return [new NativeBigInt(self.value / n.value), new NativeBigInt(self.value % n.value)];\r\n }\r\n var a = self.value, b = n.value;\r\n var quotient;\r\n if (b === 0) throw new Error(\"Cannot divide by zero\");\r\n if (self.isSmall) {\r\n if (n.isSmall) {\r\n return [new SmallInteger(truncate(a / b)), new SmallInteger(a % b)];\r\n }\r\n return [Integer[0], self];\r\n }\r\n if (n.isSmall) {\r\n if (b === 1) return [self, Integer[0]];\r\n if (b == -1) return [self.negate(), Integer[0]];\r\n var abs = Math.abs(b);\r\n if (abs < BASE) {\r\n value = divModSmall(a, abs);\r\n quotient = arrayToSmall(value[0]);\r\n var remainder = value[1];\r\n if (self.sign) remainder = -remainder;\r\n if (typeof quotient === \"number\") {\r\n if (self.sign !== n.sign) quotient = -quotient;\r\n return [new SmallInteger(quotient), new SmallInteger(remainder)];\r\n }\r\n return [new BigInteger(quotient, self.sign !== n.sign), new SmallInteger(remainder)];\r\n }\r\n b = smallToArray(abs);\r\n }\r\n var comparison = compareAbs(a, b);\r\n if (comparison === -1) return [Integer[0], self];\r\n if (comparison === 0) return [Integer[self.sign === n.sign ? 1 : -1], Integer[0]];\r\n\r\n // divMod1 is faster on smaller input sizes\r\n if (a.length + b.length <= 200)\r\n value = divMod1(a, b);\r\n else value = divMod2(a, b);\r\n\r\n quotient = value[0];\r\n var qSign = self.sign !== n.sign,\r\n mod = value[1],\r\n mSign = self.sign;\r\n if (typeof quotient === \"number\") {\r\n if (qSign) quotient = -quotient;\r\n quotient = new SmallInteger(quotient);\r\n } else quotient = new BigInteger(quotient, qSign);\r\n if (typeof mod === \"number\") {\r\n if (mSign) mod = -mod;\r\n mod = new SmallInteger(mod);\r\n } else mod = new BigInteger(mod, mSign);\r\n return [quotient, mod];\r\n }\r\n\r\n BigInteger.prototype.divmod = function (v) {\r\n var result = divModAny(this, v);\r\n return {\r\n quotient: result[0],\r\n remainder: result[1]\r\n };\r\n };\r\n NativeBigInt.prototype.divmod = SmallInteger.prototype.divmod = BigInteger.prototype.divmod;\r\n\r\n\r\n BigInteger.prototype.divide = function (v) {\r\n return divModAny(this, v)[0];\r\n };\r\n NativeBigInt.prototype.over = NativeBigInt.prototype.divide = function (v) {\r\n return new NativeBigInt(this.value / parseValue(v).value);\r\n };\r\n SmallInteger.prototype.over = SmallInteger.prototype.divide = BigInteger.prototype.over = BigInteger.prototype.divide;\r\n\r\n BigInteger.prototype.mod = function (v) {\r\n return divModAny(this, v)[1];\r\n };\r\n NativeBigInt.prototype.mod = NativeBigInt.prototype.remainder = function (v) {\r\n return new NativeBigInt(this.value % parseValue(v).value);\r\n };\r\n SmallInteger.prototype.remainder = SmallInteger.prototype.mod = BigInteger.prototype.remainder = BigInteger.prototype.mod;\r\n\r\n BigInteger.prototype.pow = function (v) {\r\n var n = parseValue(v),\r\n a = this.value,\r\n b = n.value,\r\n value, x, y;\r\n if (b === 0) return Integer[1];\r\n if (a === 0) return Integer[0];\r\n if (a === 1) return Integer[1];\r\n if (a === -1) return n.isEven() ? Integer[1] : Integer[-1];\r\n if (n.sign) {\r\n return Integer[0];\r\n }\r\n if (!n.isSmall) throw new Error(\"The exponent \" + n.toString() + \" is too large.\");\r\n if (this.isSmall) {\r\n if (isPrecise(value = Math.pow(a, b)))\r\n return new SmallInteger(truncate(value));\r\n }\r\n x = this;\r\n y = Integer[1];\r\n while (true) {\r\n if (b & 1 === 1) {\r\n y = y.times(x);\r\n --b;\r\n }\r\n if (b === 0) break;\r\n b /= 2;\r\n x = x.square();\r\n }\r\n return y;\r\n };\r\n SmallInteger.prototype.pow = BigInteger.prototype.pow;\r\n\r\n NativeBigInt.prototype.pow = function (v) {\r\n var n = parseValue(v);\r\n var a = this.value, b = n.value;\r\n var _0 = BigInt(0), _1 = BigInt(1), _2 = BigInt(2);\r\n if (b === _0) return Integer[1];\r\n if (a === _0) return Integer[0];\r\n if (a === _1) return Integer[1];\r\n if (a === BigInt(-1)) return n.isEven() ? Integer[1] : Integer[-1];\r\n if (n.isNegative()) return new NativeBigInt(_0);\r\n var x = this;\r\n var y = Integer[1];\r\n while (true) {\r\n if ((b & _1) === _1) {\r\n y = y.times(x);\r\n --b;\r\n }\r\n if (b === _0) break;\r\n b /= _2;\r\n x = x.square();\r\n }\r\n return y;\r\n }\r\n\r\n BigInteger.prototype.modPow = function (exp, mod) {\r\n exp = parseValue(exp);\r\n mod = parseValue(mod);\r\n if (mod.isZero()) throw new Error(\"Cannot take modPow with modulus 0\");\r\n var r = Integer[1],\r\n base = this.mod(mod);\r\n if (exp.isNegative()) {\r\n exp = exp.multiply(Integer[-1]);\r\n base = base.modInv(mod);\r\n }\r\n while (exp.isPositive()) {\r\n if (base.isZero()) return Integer[0];\r\n if (exp.isOdd()) r = r.multiply(base).mod(mod);\r\n exp = exp.divide(2);\r\n base = base.square().mod(mod);\r\n }\r\n return r;\r\n };\r\n NativeBigInt.prototype.modPow = SmallInteger.prototype.modPow = BigInteger.prototype.modPow;\r\n\r\n function compareAbs(a, b) {\r\n if (a.length !== b.length) {\r\n return a.length > b.length ? 1 : -1;\r\n }\r\n for (var i = a.length - 1; i >= 0; i--) {\r\n if (a[i] !== b[i]) return a[i] > b[i] ? 1 : -1;\r\n }\r\n return 0;\r\n }\r\n\r\n BigInteger.prototype.compareAbs = function (v) {\r\n var n = parseValue(v),\r\n a = this.value,\r\n b = n.value;\r\n if (n.isSmall) return 1;\r\n return compareAbs(a, b);\r\n };\r\n SmallInteger.prototype.compareAbs = function (v) {\r\n var n = parseValue(v),\r\n a = Math.abs(this.value),\r\n b = n.value;\r\n if (n.isSmall) {\r\n b = Math.abs(b);\r\n return a === b ? 0 : a > b ? 1 : -1;\r\n }\r\n return -1;\r\n };\r\n NativeBigInt.prototype.compareAbs = function (v) {\r\n var a = this.value;\r\n var b = parseValue(v).value;\r\n a = a >= 0 ? a : -a;\r\n b = b >= 0 ? b : -b;\r\n return a === b ? 0 : a > b ? 1 : -1;\r\n }\r\n\r\n BigInteger.prototype.compare = function (v) {\r\n // See discussion about comparison with Infinity:\r\n // https://github.com/peterolson/BigInteger.js/issues/61\r\n if (v === Infinity) {\r\n return -1;\r\n }\r\n if (v === -Infinity) {\r\n return 1;\r\n }\r\n\r\n var n = parseValue(v),\r\n a = this.value,\r\n b = n.value;\r\n if (this.sign !== n.sign) {\r\n return n.sign ? 1 : -1;\r\n }\r\n if (n.isSmall) {\r\n return this.sign ? -1 : 1;\r\n }\r\n return compareAbs(a, b) * (this.sign ? -1 : 1);\r\n };\r\n BigInteger.prototype.compareTo = BigInteger.prototype.compare;\r\n\r\n SmallInteger.prototype.compare = function (v) {\r\n if (v === Infinity) {\r\n return -1;\r\n }\r\n if (v === -Infinity) {\r\n return 1;\r\n }\r\n\r\n var n = parseValue(v),\r\n a = this.value,\r\n b = n.value;\r\n if (n.isSmall) {\r\n return a == b ? 0 : a > b ? 1 : -1;\r\n }\r\n if (a < 0 !== n.sign) {\r\n return a < 0 ? -1 : 1;\r\n }\r\n return a < 0 ? 1 : -1;\r\n };\r\n SmallInteger.prototype.compareTo = SmallInteger.prototype.compare;\r\n\r\n NativeBigInt.prototype.compare = function (v) {\r\n if (v === Infinity) {\r\n return -1;\r\n }\r\n if (v === -Infinity) {\r\n return 1;\r\n }\r\n var a = this.value;\r\n var b = parseValue(v).value;\r\n return a === b ? 0 : a > b ? 1 : -1;\r\n }\r\n NativeBigInt.prototype.compareTo = NativeBigInt.prototype.compare;\r\n\r\n BigInteger.prototype.equals = function (v) {\r\n return this.compare(v) === 0;\r\n };\r\n NativeBigInt.prototype.eq = NativeBigInt.prototype.equals = SmallInteger.prototype.eq = SmallInteger.prototype.equals = BigInteger.prototype.eq = BigInteger.prototype.equals;\r\n\r\n BigInteger.prototype.notEquals = function (v) {\r\n return this.compare(v) !== 0;\r\n };\r\n NativeBigInt.prototype.neq = NativeBigInt.prototype.notEquals = SmallInteger.prototype.neq = SmallInteger.prototype.notEquals = BigInteger.prototype.neq = BigInteger.prototype.notEquals;\r\n\r\n BigInteger.prototype.greater = function (v) {\r\n return this.compare(v) > 0;\r\n };\r\n NativeBigInt.prototype.gt = NativeBigInt.prototype.greater = SmallInteger.prototype.gt = SmallInteger.prototype.greater = BigInteger.prototype.gt = BigInteger.prototype.greater;\r\n\r\n BigInteger.prototype.lesser = function (v) {\r\n return this.compare(v) < 0;\r\n };\r\n NativeBigInt.prototype.lt = NativeBigInt.prototype.lesser = SmallInteger.prototype.lt = SmallInteger.prototype.lesser = BigInteger.prototype.lt = BigInteger.prototype.lesser;\r\n\r\n BigInteger.prototype.greaterOrEquals = function (v) {\r\n return this.compare(v) >= 0;\r\n };\r\n NativeBigInt.prototype.geq = NativeBigInt.prototype.greaterOrEquals = SmallInteger.prototype.geq = SmallInteger.prototype.greaterOrEquals = BigInteger.prototype.geq = BigInteger.prototype.greaterOrEquals;\r\n\r\n BigInteger.prototype.lesserOrEquals = function (v) {\r\n return this.compare(v) <= 0;\r\n };\r\n NativeBigInt.prototype.leq = NativeBigInt.prototype.lesserOrEquals = SmallInteger.prototype.leq = SmallInteger.prototype.lesserOrEquals = BigInteger.prototype.leq = BigInteger.prototype.lesserOrEquals;\r\n\r\n BigInteger.prototype.isEven = function () {\r\n return (this.value[0] & 1) === 0;\r\n };\r\n SmallInteger.prototype.isEven = function () {\r\n return (this.value & 1) === 0;\r\n };\r\n NativeBigInt.prototype.isEven = function () {\r\n return (this.value & BigInt(1)) === BigInt(0);\r\n }\r\n\r\n BigInteger.prototype.isOdd = function () {\r\n return (this.value[0] & 1) === 1;\r\n };\r\n SmallInteger.prototype.isOdd = function () {\r\n return (this.value & 1) === 1;\r\n };\r\n NativeBigInt.prototype.isOdd = function () {\r\n return (this.value & BigInt(1)) === BigInt(1);\r\n }\r\n\r\n BigInteger.prototype.isPositive = function () {\r\n return !this.sign;\r\n };\r\n SmallInteger.prototype.isPositive = function () {\r\n return this.value > 0;\r\n };\r\n NativeBigInt.prototype.isPositive = SmallInteger.prototype.isPositive;\r\n\r\n BigInteger.prototype.isNegative = function () {\r\n return this.sign;\r\n };\r\n SmallInteger.prototype.isNegative = function () {\r\n return this.value < 0;\r\n };\r\n NativeBigInt.prototype.isNegative = SmallInteger.prototype.isNegative;\r\n\r\n BigInteger.prototype.isUnit = function () {\r\n return false;\r\n };\r\n SmallInteger.prototype.isUnit = function () {\r\n return Math.abs(this.value) === 1;\r\n };\r\n NativeBigInt.prototype.isUnit = function () {\r\n return this.abs().value === BigInt(1);\r\n }\r\n\r\n BigInteger.prototype.isZero = function () {\r\n return false;\r\n };\r\n SmallInteger.prototype.isZero = function () {\r\n return this.value === 0;\r\n };\r\n NativeBigInt.prototype.isZero = function () {\r\n return this.value === BigInt(0);\r\n }\r\n\r\n BigInteger.prototype.isDivisibleBy = function (v) {\r\n var n = parseValue(v);\r\n if (n.isZero()) return false;\r\n if (n.isUnit()) return true;\r\n if (n.compareAbs(2) === 0) return this.isEven();\r\n return this.mod(n).isZero();\r\n };\r\n NativeBigInt.prototype.isDivisibleBy = SmallInteger.prototype.isDivisibleBy = BigInteger.prototype.isDivisibleBy;\r\n\r\n function isBasicPrime(v) {\r\n var n = v.abs();\r\n if (n.isUnit()) return false;\r\n if (n.equals(2) || n.equals(3) || n.equals(5)) return true;\r\n if (n.isEven() || n.isDivisibleBy(3) || n.isDivisibleBy(5)) return false;\r\n if (n.lesser(49)) return true;\r\n // we don't know if it's prime: let the other functions figure it out\r\n }\r\n\r\n function millerRabinTest(n, a) {\r\n var nPrev = n.prev(),\r\n b = nPrev,\r\n r = 0,\r\n d, t, i, x;\r\n while (b.isEven()) b = b.divide(2), r++;\r\n next: for (i = 0; i < a.length; i++) {\r\n if (n.lesser(a[i])) continue;\r\n x = bigInt(a[i]).modPow(b, n);\r\n if (x.isUnit() || x.equals(nPrev)) continue;\r\n for (d = r - 1; d != 0; d--) {\r\n x = x.square().mod(n);\r\n if (x.isUnit()) return false;\r\n if (x.equals(nPrev)) continue next;\r\n }\r\n return false;\r\n }\r\n return true;\r\n }\r\n\r\n // Set \"strict\" to true to force GRH-supported lower bound of 2*log(N)^2\r\n BigInteger.prototype.isPrime = function (strict) {\r\n var isPrime = isBasicPrime(this);\r\n if (isPrime !== undefined) return isPrime;\r\n var n = this.abs();\r\n var bits = n.bitLength();\r\n if (bits <= 64)\r\n return millerRabinTest(n, [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37]);\r\n var logN = Math.log(2) * bits.toJSNumber();\r\n var t = Math.ceil((strict === true) ? (2 * Math.pow(logN, 2)) : logN);\r\n for (var a = [], i = 0; i < t; i++) {\r\n a.push(bigInt(i + 2));\r\n }\r\n return millerRabinTest(n, a);\r\n };\r\n NativeBigInt.prototype.isPrime = SmallInteger.prototype.isPrime = BigInteger.prototype.isPrime;\r\n\r\n BigInteger.prototype.isProbablePrime = function (iterations, rng) {\r\n var isPrime = isBasicPrime(this);\r\n if (isPrime !== undefined) return isPrime;\r\n var n = this.abs();\r\n var t = iterations === undefined ? 5 : iterations;\r\n for (var a = [], i = 0; i < t; i++) {\r\n a.push(bigInt.randBetween(2, n.minus(2), rng));\r\n }\r\n return millerRabinTest(n, a);\r\n };\r\n NativeBigInt.prototype.isProbablePrime = SmallInteger.prototype.isProbablePrime = BigInteger.prototype.isProbablePrime;\r\n\r\n BigInteger.prototype.modInv = function (n) {\r\n var t = bigInt.zero, newT = bigInt.one, r = parseValue(n), newR = this.abs(), q, lastT, lastR;\r\n while (!newR.isZero()) {\r\n q = r.divide(newR);\r\n lastT = t;\r\n lastR = r;\r\n t = newT;\r\n r = newR;\r\n newT = lastT.subtract(q.multiply(newT));\r\n newR = lastR.subtract(q.multiply(newR));\r\n }\r\n if (!r.isUnit()) throw new Error(this.toString() + \" and \" + n.toString() + \" are not co-prime\");\r\n if (t.compare(0) === -1) {\r\n t = t.add(n);\r\n }\r\n if (this.isNegative()) {\r\n return t.negate();\r\n }\r\n return t;\r\n };\r\n\r\n NativeBigInt.prototype.modInv = SmallInteger.prototype.modInv = BigInteger.prototype.modInv;\r\n\r\n BigInteger.prototype.next = function () {\r\n var value = this.value;\r\n if (this.sign) {\r\n return subtractSmall(value, 1, this.sign);\r\n }\r\n return new BigInteger(addSmall(value, 1), this.sign);\r\n };\r\n SmallInteger.prototype.next = function () {\r\n var value = this.value;\r\n if (value + 1 < MAX_INT) return new SmallInteger(value + 1);\r\n return new BigInteger(MAX_INT_ARR, false);\r\n };\r\n NativeBigInt.prototype.next = function () {\r\n return new NativeBigInt(this.value + BigInt(1));\r\n }\r\n\r\n BigInteger.prototype.prev = function () {\r\n var value = this.value;\r\n if (this.sign) {\r\n return new BigInteger(addSmall(value, 1), true);\r\n }\r\n return subtractSmall(value, 1, this.sign);\r\n };\r\n SmallInteger.prototype.prev = function () {\r\n var value = this.value;\r\n if (value - 1 > -MAX_INT) return new SmallInteger(value - 1);\r\n return new BigInteger(MAX_INT_ARR, true);\r\n };\r\n NativeBigInt.prototype.prev = function () {\r\n return new NativeBigInt(this.value - BigInt(1));\r\n }\r\n\r\n var powersOfTwo = [1];\r\n while (2 * powersOfTwo[powersOfTwo.length - 1] <= BASE) powersOfTwo.push(2 * powersOfTwo[powersOfTwo.length - 1]);\r\n var powers2Length = powersOfTwo.length, highestPower2 = powersOfTwo[powers2Length - 1];\r\n\r\n function shift_isSmall(n) {\r\n return Math.abs(n) <= BASE;\r\n }\r\n\r\n BigInteger.prototype.shiftLeft = function (v) {\r\n var n = parseValue(v).toJSNumber();\r\n if (!shift_isSmall(n)) {\r\n throw new Error(String(n) + \" is too large for shifting.\");\r\n }\r\n if (n < 0) return this.shiftRight(-n);\r\n var result = this;\r\n if (result.isZero()) return result;\r\n while (n >= powers2Length) {\r\n result = result.multiply(highestPower2);\r\n n -= powers2Length - 1;\r\n }\r\n return result.multiply(powersOfTwo[n]);\r\n };\r\n NativeBigInt.prototype.shiftLeft = SmallInteger.prototype.shiftLeft = BigInteger.prototype.shiftLeft;\r\n\r\n BigInteger.prototype.shiftRight = function (v) {\r\n var remQuo;\r\n var n = parseValue(v).toJSNumber();\r\n if (!shift_isSmall(n)) {\r\n throw new Error(String(n) + \" is too large for shifting.\");\r\n }\r\n if (n < 0) return this.shiftLeft(-n);\r\n var result = this;\r\n while (n >= powers2Length) {\r\n if (result.isZero() || (result.isNegative() && result.isUnit())) return result;\r\n remQuo = divModAny(result, highestPower2);\r\n result = remQuo[1].isNegative() ? remQuo[0].prev() : remQuo[0];\r\n n -= powers2Length - 1;\r\n }\r\n remQuo = divModAny(result, powersOfTwo[n]);\r\n return remQuo[1].isNegative() ? remQuo[0].prev() : remQuo[0];\r\n };\r\n NativeBigInt.prototype.shiftRight = SmallInteger.prototype.shiftRight = BigInteger.prototype.shiftRight;\r\n\r\n function bitwise(x, y, fn) {\r\n y = parseValue(y);\r\n var xSign = x.isNegative(), ySign = y.isNegative();\r\n var xRem = xSign ? x.not() : x,\r\n yRem = ySign ? y.not() : y;\r\n var xDigit = 0, yDigit = 0;\r\n var xDivMod = null, yDivMod = null;\r\n var result = [];\r\n while (!xRem.isZero() || !yRem.isZero()) {\r\n xDivMod = divModAny(xRem, highestPower2);\r\n xDigit = xDivMod[1].toJSNumber();\r\n if (xSign) {\r\n xDigit = highestPower2 - 1 - xDigit; // two's complement for negative numbers\r\n }\r\n\r\n yDivMod = divModAny(yRem, highestPower2);\r\n yDigit = yDivMod[1].toJSNumber();\r\n if (ySign) {\r\n yDigit = highestPower2 - 1 - yDigit; // two's complement for negative numbers\r\n }\r\n\r\n xRem = xDivMod[0];\r\n yRem = yDivMod[0];\r\n result.push(fn(xDigit, yDigit));\r\n }\r\n var sum = fn(xSign ? 1 : 0, ySign ? 1 : 0) !== 0 ? bigInt(-1) : bigInt(0);\r\n for (var i = result.length - 1; i >= 0; i -= 1) {\r\n sum = sum.multiply(highestPower2).add(bigInt(result[i]));\r\n }\r\n return sum;\r\n }\r\n\r\n BigInteger.prototype.not = function () {\r\n return this.negate().prev();\r\n };\r\n NativeBigInt.prototype.not = SmallInteger.prototype.not = BigInteger.prototype.not;\r\n\r\n BigInteger.prototype.and = function (n) {\r\n return bitwise(this, n, function (a, b) { return a & b; });\r\n };\r\n NativeBigInt.prototype.and = SmallInteger.prototype.and = BigInteger.prototype.and;\r\n\r\n BigInteger.prototype.or = function (n) {\r\n return bitwise(this, n, function (a, b) { return a | b; });\r\n };\r\n NativeBigInt.prototype.or = SmallInteger.prototype.or = BigInteger.prototype.or;\r\n\r\n BigInteger.prototype.xor = function (n) {\r\n return bitwise(this, n, function (a, b) { return a ^ b; });\r\n };\r\n NativeBigInt.prototype.xor = SmallInteger.prototype.xor = BigInteger.prototype.xor;\r\n\r\n var LOBMASK_I = 1 << 30, LOBMASK_BI = (BASE & -BASE) * (BASE & -BASE) | LOBMASK_I;\r\n function roughLOB(n) { // get lowestOneBit (rough)\r\n // SmallInteger: return Min(lowestOneBit(n), 1 << 30)\r\n // BigInteger: return Min(lowestOneBit(n), 1 << 14) [BASE=1e7]\r\n var v = n.value,\r\n x = typeof v === \"number\" ? v | LOBMASK_I :\r\n typeof v === \"bigint\" ? v | BigInt(LOBMASK_I) :\r\n v[0] + v[1] * BASE | LOBMASK_BI;\r\n return x & -x;\r\n }\r\n\r\n function integerLogarithm(value, base) {\r\n if (base.compareTo(value) <= 0) {\r\n var tmp = integerLogarithm(value, base.square(base));\r\n var p = tmp.p;\r\n var e = tmp.e;\r\n var t = p.multiply(base);\r\n return t.compareTo(value) <= 0 ? { p: t, e: e * 2 + 1 } : { p: p, e: e * 2 };\r\n }\r\n return { p: bigInt(1), e: 0 };\r\n }\r\n\r\n BigInteger.prototype.bitLength = function () {\r\n var n = this;\r\n if (n.compareTo(bigInt(0)) < 0) {\r\n n = n.negate().subtract(bigInt(1));\r\n }\r\n if (n.compareTo(bigInt(0)) === 0) {\r\n return bigInt(0);\r\n }\r\n return bigInt(integerLogarithm(n, bigInt(2)).e).add(bigInt(1));\r\n }\r\n NativeBigInt.prototype.bitLength = SmallInteger.prototype.bitLength = BigInteger.prototype.bitLength;\r\n\r\n function max(a, b) {\r\n a = parseValue(a);\r\n b = parseValue(b);\r\n return a.greater(b) ? a : b;\r\n }\r\n function min(a, b) {\r\n a = parseValue(a);\r\n b = parseValue(b);\r\n return a.lesser(b) ? a : b;\r\n }\r\n function gcd(a, b) {\r\n a = parseValue(a).abs();\r\n b = parseValue(b).abs();\r\n if (a.equals(b)) return a;\r\n if (a.isZero()) return b;\r\n if (b.isZero()) return a;\r\n var c = Integer[1], d, t;\r\n while (a.isEven() && b.isEven()) {\r\n d = min(roughLOB(a), roughLOB(b));\r\n a = a.divide(d);\r\n b = b.divide(d);\r\n c = c.multiply(d);\r\n }\r\n while (a.isEven()) {\r\n a = a.divide(roughLOB(a));\r\n }\r\n do {\r\n while (b.isEven()) {\r\n b = b.divide(roughLOB(b));\r\n }\r\n if (a.greater(b)) {\r\n t = b; b = a; a = t;\r\n }\r\n b = b.subtract(a);\r\n } while (!b.isZero());\r\n return c.isUnit() ? a : a.multiply(c);\r\n }\r\n function lcm(a, b) {\r\n a = parseValue(a).abs();\r\n b = parseValue(b).abs();\r\n return a.divide(gcd(a, b)).multiply(b);\r\n }\r\n function randBetween(a, b, rng) {\r\n a = parseValue(a);\r\n b = parseValue(b);\r\n var usedRNG = rng || Math.random;\r\n var low = min(a, b), high = max(a, b);\r\n var range = high.subtract(low).add(1);\r\n if (range.isSmall) return low.add(Math.floor(usedRNG() * range));\r\n var digits = toBase(range, BASE).value;\r\n var result = [], restricted = true;\r\n for (var i = 0; i < digits.length; i++) {\r\n var top = restricted ? digits[i] + (i + 1 < digits.length ? digits[i + 1] / BASE : 0) : BASE;\r\n var digit = truncate(usedRNG() * top);\r\n result.push(digit);\r\n if (digit < digits[i]) restricted = false;\r\n }\r\n return low.add(Integer.fromArray(result, BASE, false));\r\n }\r\n\r\n var parseBase = function (text, base, alphabet, caseSensitive) {\r\n alphabet = alphabet || DEFAULT_ALPHABET;\r\n text = String(text);\r\n if (!caseSensitive) {\r\n text = text.toLowerCase();\r\n alphabet = alphabet.toLowerCase();\r\n }\r\n var length = text.length;\r\n var i;\r\n var absBase = Math.abs(base);\r\n var alphabetValues = {};\r\n for (i = 0; i < alphabet.length; i++) {\r\n alphabetValues[alphabet[i]] = i;\r\n }\r\n for (i = 0; i < length; i++) {\r\n var c = text[i];\r\n if (c === \"-\") continue;\r\n if (c in alphabetValues) {\r\n if (alphabetValues[c] >= absBase) {\r\n if (c === \"1\" && absBase === 1) continue;\r\n throw new Error(c + \" is not a valid digit in base \" + base + \".\");\r\n }\r\n }\r\n }\r\n base = parseValue(base);\r\n var digits = [];\r\n var isNegative = text[0] === \"-\";\r\n for (i = isNegative ? 1 : 0; i < text.length; i++) {\r\n var c = text[i];\r\n if (c in alphabetValues) digits.push(parseValue(alphabetValues[c]));\r\n else if (c === \"<\") {\r\n var start = i;\r\n do { i++; } while (text[i] !== \">\" && i < text.length);\r\n digits.push(parseValue(text.slice(start + 1, i)));\r\n }\r\n else throw new Error(c + \" is not a valid character\");\r\n }\r\n return parseBaseFromArray(digits, base, isNegative);\r\n };\r\n\r\n function parseBaseFromArray(digits, base, isNegative) {\r\n var val = Integer[0], pow = Integer[1], i;\r\n for (i = digits.length - 1; i >= 0; i--) {\r\n val = val.add(digits[i].times(pow));\r\n pow = pow.times(base);\r\n }\r\n return isNegative ? val.negate() : val;\r\n }\r\n\r\n function stringify(digit, alphabet) {\r\n alphabet = alphabet || DEFAULT_ALPHABET;\r\n if (digit < alphabet.length) {\r\n return alphabet[digit];\r\n }\r\n return \"<\" + digit + \">\";\r\n }\r\n\r\n function toBase(n, base) {\r\n base = bigInt(base);\r\n if (base.isZero()) {\r\n if (n.isZero()) return { value: [0], isNegative: false };\r\n throw new Error(\"Cannot convert nonzero numbers to base 0.\");\r\n }\r\n if (base.equals(-1)) {\r\n if (n.isZero()) return { value: [0], isNegative: false };\r\n if (n.isNegative())\r\n return {\r\n value: [].concat.apply([], Array.apply(null, Array(-n.toJSNumber()))\r\n .map(Array.prototype.valueOf, [1, 0])\r\n ),\r\n isNegative: false\r\n };\r\n\r\n var arr = Array.apply(null, Array(n.toJSNumber() - 1))\r\n .map(Array.prototype.valueOf, [0, 1]);\r\n arr.unshift([1]);\r\n return {\r\n value: [].concat.apply([], arr),\r\n isNegative: false\r\n };\r\n }\r\n\r\n var neg = false;\r\n if (n.isNegative() && base.isPositive()) {\r\n neg = true;\r\n n = n.abs();\r\n }\r\n if (base.isUnit()) {\r\n if (n.isZero()) return { value: [0], isNegative: false };\r\n\r\n return {\r\n value: Array.apply(null, Array(n.toJSNumber()))\r\n .map(Number.prototype.valueOf, 1),\r\n isNegative: neg\r\n };\r\n }\r\n var out = [];\r\n var left = n, divmod;\r\n while (left.isNegative() || left.compareAbs(base) >= 0) {\r\n divmod = left.divmod(base);\r\n left = divmod.quotient;\r\n var digit = divmod.remainder;\r\n if (digit.isNegative()) {\r\n digit = base.minus(digit).abs();\r\n left = left.next();\r\n }\r\n out.push(digit.toJSNumber());\r\n }\r\n out.push(left.toJSNumber());\r\n return { value: out.reverse(), isNegative: neg };\r\n }\r\n\r\n function toBaseString(n, base, alphabet) {\r\n var arr = toBase(n, base);\r\n return (arr.isNegative ? \"-\" : \"\") + arr.value.map(function (x) {\r\n return stringify(x, alphabet);\r\n }).join('');\r\n }\r\n\r\n BigInteger.prototype.toArray = function (radix) {\r\n return toBase(this, radix);\r\n };\r\n\r\n SmallInteger.prototype.toArray = function (radix) {\r\n return toBase(this, radix);\r\n };\r\n\r\n NativeBigInt.prototype.toArray = function (radix) {\r\n return toBase(this, radix);\r\n };\r\n\r\n BigInteger.prototype.toString = function (radix, alphabet) {\r\n if (radix === undefined) radix = 10;\r\n if (radix !== 10 || alphabet) return toBaseString(this, radix, alphabet);\r\n var v = this.value, l = v.length, str = String(v[--l]), zeros = \"0000000\", digit;\r\n while (--l >= 0) {\r\n digit = String(v[l]);\r\n str += zeros.slice(digit.length) + digit;\r\n }\r\n var sign = this.sign ? \"-\" : \"\";\r\n return sign + str;\r\n };\r\n\r\n SmallInteger.prototype.toString = function (radix, alphabet) {\r\n if (radix === undefined) radix = 10;\r\n if (radix != 10 || alphabet) return toBaseString(this, radix, alphabet);\r\n return String(this.value);\r\n };\r\n\r\n NativeBigInt.prototype.toString = SmallInteger.prototype.toString;\r\n\r\n NativeBigInt.prototype.toJSON = BigInteger.prototype.toJSON = SmallInteger.prototype.toJSON = function () { return this.toString(); }\r\n\r\n BigInteger.prototype.valueOf = function () {\r\n return parseInt(this.toString(), 10);\r\n };\r\n BigInteger.prototype.toJSNumber = BigInteger.prototype.valueOf;\r\n\r\n SmallInteger.prototype.valueOf = function () {\r\n return this.value;\r\n };\r\n SmallInteger.prototype.toJSNumber = SmallInteger.prototype.valueOf;\r\n NativeBigInt.prototype.valueOf = NativeBigInt.prototype.toJSNumber = function () {\r\n return parseInt(this.toString(), 10);\r\n }\r\n\r\n function parseStringValue(v) {\r\n if (isPrecise(+v)) {\r\n var x = +v;\r\n if (x === truncate(x))\r\n return supportsNativeBigInt ? new NativeBigInt(BigInt(x)) : new SmallInteger(x);\r\n throw new Error(\"Invalid integer: \" + v);\r\n }\r\n var sign = v[0] === \"-\";\r\n if (sign) v = v.slice(1);\r\n var split = v.split(/e/i);\r\n if (split.length > 2) throw new Error(\"Invalid integer: \" + split.join(\"e\"));\r\n if (split.length === 2) {\r\n var exp = split[1];\r\n if (exp[0] === \"+\") exp = exp.slice(1);\r\n exp = +exp;\r\n if (exp !== truncate(exp) || !isPrecise(exp)) throw new Error(\"Invalid integer: \" + exp + \" is not a valid exponent.\");\r\n var text = split[0];\r\n var decimalPlace = text.indexOf(\".\");\r\n if (decimalPlace >= 0) {\r\n exp -= text.length - decimalPlace - 1;\r\n text = text.slice(0, decimalPlace) + text.slice(decimalPlace + 1);\r\n }\r\n if (exp < 0) throw new Error(\"Cannot include negative exponent part for integers\");\r\n text += (new Array(exp + 1)).join(\"0\");\r\n v = text;\r\n }\r\n var isValid = /^([0-9][0-9]*)$/.test(v);\r\n if (!isValid) throw new Error(\"Invalid integer: \" + v);\r\n if (supportsNativeBigInt) {\r\n return new NativeBigInt(BigInt(sign ? \"-\" + v : v));\r\n }\r\n var r = [], max = v.length, l = LOG_BASE, min = max - l;\r\n while (max > 0) {\r\n r.push(+v.slice(min, max));\r\n min -= l;\r\n if (min < 0) min = 0;\r\n max -= l;\r\n }\r\n trim(r);\r\n return new BigInteger(r, sign);\r\n }\r\n\r\n function parseNumberValue(v) {\r\n if (supportsNativeBigInt) {\r\n return new NativeBigInt(BigInt(v));\r\n }\r\n if (isPrecise(v)) {\r\n if (v !== truncate(v)) throw new Error(v + \" is not an integer.\");\r\n return new SmallInteger(v);\r\n }\r\n return parseStringValue(v.toString());\r\n }\r\n\r\n function parseValue(v) {\r\n if (typeof v === \"number\") {\r\n return parseNumberValue(v);\r\n }\r\n if (typeof v === \"string\") {\r\n return parseStringValue(v);\r\n }\r\n if (typeof v === \"bigint\") {\r\n return new NativeBigInt(v);\r\n }\r\n return v;\r\n }\r\n // Pre-define numbers in range [-999,999]\r\n for (var i = 0; i < 1000; i++) {\r\n Integer[i] = parseValue(i);\r\n if (i > 0) Integer[-i] = parseValue(-i);\r\n }\r\n // Backwards compatibility\r\n Integer.one = Integer[1];\r\n Integer.zero = Integer[0];\r\n Integer.minusOne = Integer[-1];\r\n Integer.max = max;\r\n Integer.min = min;\r\n Integer.gcd = gcd;\r\n Integer.lcm = lcm;\r\n Integer.isInstance = function (x) { return x instanceof BigInteger || x instanceof SmallInteger || x instanceof NativeBigInt; };\r\n Integer.randBetween = randBetween;\r\n\r\n Integer.fromArray = function (digits, base, isNegative) {\r\n return parseBaseFromArray(digits.map(parseValue), parseValue(base || 10), isNegative);\r\n };\r\n\r\n return Integer;\r\n})();\r\n\r\n// Node.js check\r\nif (typeof module !== \"undefined\" && module.hasOwnProperty(\"exports\")) {\r\n module.exports = bigInt;\r\n}\r\n\r\n//amd check\r\nif (typeof define === \"function\" && define.amd) {\r\n define( function () {\r\n return bigInt;\r\n });\r\n}\r\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/*<replacement>*/\n\nvar Buffer = require('safe-buffer').Buffer;\n/*</replacement>*/\n\nvar isEncoding = Buffer.isEncoding || function (encoding) {\n encoding = '' + encoding;\n switch (encoding && encoding.toLowerCase()) {\n case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':\n return true;\n default:\n return false;\n }\n};\n\nfunction _normalizeEncoding(enc) {\n if (!enc) return 'utf8';\n var retried;\n while (true) {\n switch (enc) {\n case 'utf8':\n case 'utf-8':\n return 'utf8';\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return 'utf16le';\n case 'latin1':\n case 'binary':\n return 'latin1';\n case 'base64':\n case 'ascii':\n case 'hex':\n return enc;\n default:\n if (retried) return; // undefined\n enc = ('' + enc).toLowerCase();\n retried = true;\n }\n }\n};\n\n// Do not cache `Buffer.isEncoding` when checking encoding names as some\n// modules monkey-patch it to support additional encodings\nfunction normalizeEncoding(enc) {\n var nenc = _normalizeEncoding(enc);\n if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);\n return nenc || enc;\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters.\nexports.StringDecoder = StringDecoder;\nfunction StringDecoder(encoding) {\n this.encoding = normalizeEncoding(encoding);\n var nb;\n switch (this.encoding) {\n case 'utf16le':\n this.text = utf16Text;\n this.end = utf16End;\n nb = 4;\n break;\n case 'utf8':\n this.fillLast = utf8FillLast;\n nb = 4;\n break;\n case 'base64':\n this.text = base64Text;\n this.end = base64End;\n nb = 3;\n break;\n default:\n this.write = simpleWrite;\n this.end = simpleEnd;\n return;\n }\n this.lastNeed = 0;\n this.lastTotal = 0;\n this.lastChar = Buffer.allocUnsafe(nb);\n}\n\nStringDecoder.prototype.write = function (buf) {\n if (buf.length === 0) return '';\n var r;\n var i;\n if (this.lastNeed) {\n r = this.fillLast(buf);\n if (r === undefined) return '';\n i = this.lastNeed;\n this.lastNeed = 0;\n } else {\n i = 0;\n }\n if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);\n return r || '';\n};\n\nStringDecoder.prototype.end = utf8End;\n\n// Returns only complete characters in a Buffer\nStringDecoder.prototype.text = utf8Text;\n\n// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer\nStringDecoder.prototype.fillLast = function (buf) {\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);\n this.lastNeed -= buf.length;\n};\n\n// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a\n// continuation byte. If an invalid byte is detected, -2 is returned.\nfunction utf8CheckByte(byte) {\n if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;\n return byte >> 6 === 0x02 ? -1 : -2;\n}\n\n// Checks at most 3 bytes at the end of a Buffer in order to detect an\n// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)\n// needed to complete the UTF-8 character (if applicable) are returned.\nfunction utf8CheckIncomplete(self, buf, i) {\n var j = buf.length - 1;\n if (j < i) return 0;\n var nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 1;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 2;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) {\n if (nb === 2) nb = 0;else self.lastNeed = nb - 3;\n }\n return nb;\n }\n return 0;\n}\n\n// Validates as many continuation bytes for a multi-byte UTF-8 character as\n// needed or are available. If we see a non-continuation byte where we expect\n// one, we \"replace\" the validated continuation bytes we've seen so far with\n// a single UTF-8 replacement character ('\\ufffd'), to match v8's UTF-8 decoding\n// behavior. The continuation byte check is included three times in the case\n// where all of the continuation bytes for a character exist in the same buffer.\n// It is also done this way as a slight performance increase instead of using a\n// loop.\nfunction utf8CheckExtraBytes(self, buf, p) {\n if ((buf[0] & 0xC0) !== 0x80) {\n self.lastNeed = 0;\n return '\\ufffd';\n }\n if (self.lastNeed > 1 && buf.length > 1) {\n if ((buf[1] & 0xC0) !== 0x80) {\n self.lastNeed = 1;\n return '\\ufffd';\n }\n if (self.lastNeed > 2 && buf.length > 2) {\n if ((buf[2] & 0xC0) !== 0x80) {\n self.lastNeed = 2;\n return '\\ufffd';\n }\n }\n }\n}\n\n// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.\nfunction utf8FillLast(buf) {\n var p = this.lastTotal - this.lastNeed;\n var r = utf8CheckExtraBytes(this, buf, p);\n if (r !== undefined) return r;\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, p, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, p, 0, buf.length);\n this.lastNeed -= buf.length;\n}\n\n// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a\n// partial character, the character's bytes are buffered until the required\n// number of bytes are available.\nfunction utf8Text(buf, i) {\n var total = utf8CheckIncomplete(this, buf, i);\n if (!this.lastNeed) return buf.toString('utf8', i);\n this.lastTotal = total;\n var end = buf.length - (total - this.lastNeed);\n buf.copy(this.lastChar, 0, end);\n return buf.toString('utf8', i, end);\n}\n\n// For UTF-8, a replacement character is added when ending on a partial\n// character.\nfunction utf8End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + '\\ufffd';\n return r;\n}\n\n// UTF-16LE typically needs two bytes per character, but even if we have an even\n// number of bytes available, we need to check if we end on a leading/high\n// surrogate. In that case, we need to wait for the next two bytes in order to\n// decode the last character properly.\nfunction utf16Text(buf, i) {\n if ((buf.length - i) % 2 === 0) {\n var r = buf.toString('utf16le', i);\n if (r) {\n var c = r.charCodeAt(r.length - 1);\n if (c >= 0xD800 && c <= 0xDBFF) {\n this.lastNeed = 2;\n this.lastTotal = 4;\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n return r.slice(0, -1);\n }\n }\n return r;\n }\n this.lastNeed = 1;\n this.lastTotal = 2;\n this.lastChar[0] = buf[buf.length - 1];\n return buf.toString('utf16le', i, buf.length - 1);\n}\n\n// For UTF-16LE we do not explicitly append special replacement characters if we\n// end on a partial character, we simply let v8 handle that.\nfunction utf16End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) {\n var end = this.lastTotal - this.lastNeed;\n return r + this.lastChar.toString('utf16le', 0, end);\n }\n return r;\n}\n\nfunction base64Text(buf, i) {\n var n = (buf.length - i) % 3;\n if (n === 0) return buf.toString('base64', i);\n this.lastNeed = 3 - n;\n this.lastTotal = 3;\n if (n === 1) {\n this.lastChar[0] = buf[buf.length - 1];\n } else {\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n }\n return buf.toString('base64', i, buf.length - n);\n}\n\nfunction base64End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);\n return r;\n}\n\n// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)\nfunction simpleWrite(buf) {\n return buf.toString(this.encoding);\n}\n\nfunction simpleEnd(buf) {\n return buf && buf.length ? this.write(buf) : '';\n}","\"use strict\";\n// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Varint = void 0;\nconst big_integer_1 = __importDefault(require(\"big-integer\"));\nconst buffer_1 = require(\"buffer\");\nclass Varint {\n /**\n * Decodes a varint from a buffer\n *\n * @param buffer\n */\n static decode(buffer) {\n let counter = 0;\n let shift = 0;\n let b;\n let result = big_integer_1.default.zero;\n do {\n if (counter >= buffer.length) {\n throw new RangeError('Could not decode varint');\n }\n b = buffer[counter++];\n const value = (shift < 28) ? (b & 0x7f) << shift : (b & 0x7f) * Math.pow(2, shift);\n result = result.add(value);\n shift += 7;\n } while (b >= 0x80);\n return result;\n }\n /**\n * Encodes a value into a varint encoded buffer\n *\n * @param value\n */\n static encode(value) {\n if (typeof value === 'number') {\n value = big_integer_1.default.zero.add(value);\n }\n const out = [];\n let offset = 0;\n while (value.greaterOrEquals(Math.pow(2, 31))) {\n out[offset++] = value.and(0xFF).or(0x80).toJSNumber();\n value = value.divide(128);\n }\n while (value.and(~0x7F).greater(0)) {\n out[offset++] = value.and(0xFF).or(0x80).toJSNumber();\n value = value.shiftRight(7);\n }\n out[offset] = value.or(0).toJSNumber();\n return buffer_1.Buffer.from(out);\n }\n}\nexports.default = Varint;\nexports.Varint = Varint;\n//# sourceMappingURL=varint.js.map","// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\n\nimport CryptoNoteBase58 from './cryptonote_base58';\nimport { base58_to_binary, binary_to_base58 } from './base58-js';\nimport { Buffer } from 'buffer';\n\nexport default abstract class Base58 extends CryptoNoteBase58 {\n /**\n * Decodes the Base58 encoded string into a Buffer\n *\n * @param encoded\n */\n public static decode (\n encoded: string\n ): Buffer {\n return Buffer.from(base58_to_binary(encoded));\n }\n\n /**\n * Encodes the data into Base58\n *\n * @param data\n */\n public static encode (data: string | Uint8Array | Buffer): string {\n if (data instanceof Buffer) {\n data = data.valueOf();\n } else if (typeof data === 'string') {\n data = Buffer.from(data, 'hex').valueOf();\n }\n\n return binary_to_base58(data);\n }\n}\n\nexport { Base58, Buffer };\n","module.exports = function () {\n throw new Error('Readable.from is not available in the browser')\n};\n","// Ported from https://github.com/mafintosh/end-of-stream with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar ERR_STREAM_PREMATURE_CLOSE = require('../../../errors').codes.ERR_STREAM_PREMATURE_CLOSE;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n callback.apply(this, args);\n };\n}\nfunction noop() {}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction eos(stream, opts, callback) {\n if (typeof opts === 'function') return eos(stream, null, opts);\n if (!opts) opts = {};\n callback = once(callback || noop);\n var readable = opts.readable || opts.readable !== false && stream.readable;\n var writable = opts.writable || opts.writable !== false && stream.writable;\n var onlegacyfinish = function onlegacyfinish() {\n if (!stream.writable) onfinish();\n };\n var writableEnded = stream._writableState && stream._writableState.finished;\n var onfinish = function onfinish() {\n writable = false;\n writableEnded = true;\n if (!readable) callback.call(stream);\n };\n var readableEnded = stream._readableState && stream._readableState.endEmitted;\n var onend = function onend() {\n readable = false;\n readableEnded = true;\n if (!writable) callback.call(stream);\n };\n var onerror = function onerror(err) {\n callback.call(stream, err);\n };\n var onclose = function onclose() {\n var err;\n if (readable && !readableEnded) {\n if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n if (writable && !writableEnded) {\n if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n };\n var onrequest = function onrequest() {\n stream.req.on('finish', onfinish);\n };\n if (isRequest(stream)) {\n stream.on('complete', onfinish);\n stream.on('abort', onclose);\n if (stream.req) onrequest();else stream.on('request', onrequest);\n } else if (writable && !stream._writableState) {\n // legacy streams\n stream.on('end', onlegacyfinish);\n stream.on('close', onlegacyfinish);\n }\n stream.on('end', onend);\n stream.on('finish', onfinish);\n if (opts.error !== false) stream.on('error', onerror);\n stream.on('close', onclose);\n return function () {\n stream.removeListener('complete', onfinish);\n stream.removeListener('abort', onclose);\n stream.removeListener('request', onrequest);\n if (stream.req) stream.req.removeListener('finish', onfinish);\n stream.removeListener('end', onlegacyfinish);\n stream.removeListener('close', onlegacyfinish);\n stream.removeListener('finish', onfinish);\n stream.removeListener('end', onend);\n stream.removeListener('error', onerror);\n stream.removeListener('close', onclose);\n };\n}\nmodule.exports = eos;","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh <https://feross.org>\n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nconst base64 = require('base64-js')\nconst ieee754 = require('ieee754')\nconst customInspectSymbol =\n (typeof Symbol === 'function' && typeof Symbol['for'] === 'function') // eslint-disable-line dot-notation\n ? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n : null\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nconst K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n typeof console.error === 'function') {\n console.error(\n 'This browser lacks typed array (Uint8Array) support which is required by ' +\n '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n )\n}\n\nfunction typedArraySupport () {\n // Can typed array instances can be augmented?\n try {\n const arr = new Uint8Array(1)\n const proto = { foo: function () { return 42 } }\n Object.setPrototypeOf(proto, Uint8Array.prototype)\n Object.setPrototypeOf(arr, proto)\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nObject.defineProperty(Buffer.prototype, 'parent', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.buffer\n }\n})\n\nObject.defineProperty(Buffer.prototype, 'offset', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.byteOffset\n }\n})\n\nfunction createBuffer (length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"')\n }\n // Return an augmented `Uint8Array` instance\n const buf = new Uint8Array(length)\n Object.setPrototypeOf(buf, Buffer.prototype)\n return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new TypeError(\n 'The \"string\" argument must be of type string. Received type number'\n )\n }\n return allocUnsafe(arg)\n }\n return from(arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset)\n }\n\n if (ArrayBuffer.isView(value)) {\n return fromArrayView(value)\n }\n\n if (value == null) {\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n }\n\n if (isInstance(value, ArrayBuffer) ||\n (value && isInstance(value.buffer, ArrayBuffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof SharedArrayBuffer !== 'undefined' &&\n (isInstance(value, SharedArrayBuffer) ||\n (value && isInstance(value.buffer, SharedArrayBuffer)))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof value === 'number') {\n throw new TypeError(\n 'The \"value\" argument must not be of type number. Received type number'\n )\n }\n\n const valueOf = value.valueOf && value.valueOf()\n if (valueOf != null && valueOf !== value) {\n return Buffer.from(valueOf, encodingOrOffset, length)\n }\n\n const b = fromObject(value)\n if (b) return b\n\n if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null &&\n typeof value[Symbol.toPrimitive] === 'function') {\n return Buffer.from(value[Symbol.toPrimitive]('string'), encodingOrOffset, length)\n }\n\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nObject.setPrototypeOf(Buffer.prototype, Uint8Array.prototype)\nObject.setPrototypeOf(Buffer, Uint8Array)\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number')\n } else if (size < 0) {\n throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n }\n}\n\nfunction alloc (size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpreted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(size).fill(fill, encoding)\n : createBuffer(size).fill(fill)\n }\n return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n assertSize(size)\n return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n\n const length = byteLength(string, encoding) | 0\n let buf = createBuffer(length)\n\n const actual = buf.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (array) {\n const length = array.length < 0 ? 0 : checked(array.length) | 0\n const buf = createBuffer(length)\n for (let i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayView (arrayView) {\n if (isInstance(arrayView, Uint8Array)) {\n const copy = new Uint8Array(arrayView)\n return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength)\n }\n return fromArrayLike(arrayView)\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds')\n }\n\n let buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(buf, Buffer.prototype)\n\n return buf\n}\n\nfunction fromObject (obj) {\n if (Buffer.isBuffer(obj)) {\n const len = checked(obj.length) | 0\n const buf = createBuffer(len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj.length !== undefined) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0)\n }\n return fromArrayLike(obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data)\n }\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return b != null && b._isBuffer === true &&\n b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false\n}\n\nBuffer.compare = function compare (a, b) {\n if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength)\n if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength)\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError(\n 'The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array'\n )\n }\n\n if (a === b) return 0\n\n let x = a.length\n let y = b.length\n\n for (let i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n let i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n const buffer = Buffer.allocUnsafe(length)\n let pos = 0\n for (i = 0; i < list.length; ++i) {\n let buf = list[i]\n if (isInstance(buf, Uint8Array)) {\n if (pos + buf.length > buffer.length) {\n if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf)\n buf.copy(buffer, pos)\n } else {\n Uint8Array.prototype.set.call(\n buffer,\n buf,\n pos\n )\n }\n } else if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n } else {\n buf.copy(buffer, pos)\n }\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n throw new TypeError(\n 'The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' +\n 'Received type ' + typeof string\n )\n }\n\n const len = string.length\n const mustMatch = (arguments.length > 2 && arguments[2] === true)\n if (!mustMatch && len === 0) return 0\n\n // Use a for loop to avoid recursion\n let loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) {\n return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8\n }\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n let loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n const i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n const len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (let i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n const len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (let i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n const len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (let i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n const length = this.length\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.toLocaleString = Buffer.prototype.toString\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n let str = ''\n const max = exports.INSPECT_MAX_BYTES\n str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim()\n if (this.length > max) str += ' ... '\n return '<Buffer ' + str + '>'\n}\nif (customInspectSymbol) {\n Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (isInstance(target, Uint8Array)) {\n target = Buffer.from(target, target.offset, target.byteLength)\n }\n if (!Buffer.isBuffer(target)) {\n throw new TypeError(\n 'The \"target\" argument must be one of type Buffer or Uint8Array. ' +\n 'Received type ' + (typeof target)\n )\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n let x = thisEnd - thisStart\n let y = end - start\n const len = Math.min(x, y)\n\n const thisCopy = this.slice(thisStart, thisEnd)\n const targetCopy = target.slice(start, end)\n\n for (let i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (numberIsNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [val], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n let indexSize = 1\n let arrLength = arr.length\n let valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n let i\n if (dir) {\n let foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n let found = true\n for (let j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n const remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n const strLen = string.length\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n let i\n for (i = 0; i < length; ++i) {\n const parsed = parseInt(string.substr(i * 2, 2), 16)\n if (numberIsNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0\n if (isFinite(length)) {\n length = length >>> 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n const remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n let loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n case 'latin1':\n case 'binary':\n return asciiWrite(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n const res = []\n\n let i = start\n while (i < end) {\n const firstByte = buf[i]\n let codePoint = null\n let bytesPerSequence = (firstByte > 0xEF)\n ? 4\n : (firstByte > 0xDF)\n ? 3\n : (firstByte > 0xBF)\n ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n let secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nconst MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n const len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n let res = ''\n let i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n let ret = ''\n end = Math.min(buf.length, end)\n\n for (let i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n let ret = ''\n end = Math.min(buf.length, end)\n\n for (let i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n const len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n let out = ''\n for (let i = start; i < end; ++i) {\n out += hexSliceLookupTable[buf[i]]\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n const bytes = buf.slice(start, end)\n let res = ''\n // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n for (let i = 0; i < bytes.length - 1; i += 2) {\n res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256))\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n const len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n const newBuf = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(newBuf, Buffer.prototype)\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUintLE =\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let val = this[offset]\n let mul = 1\n let i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUintBE =\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n let val = this[offset + --byteLength]\n let mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUint8 =\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUint16LE =\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUint16BE =\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUint32LE =\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUint32BE =\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readBigUInt64LE = defineBigIntMethod(function readBigUInt64LE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const lo = first +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 24\n\n const hi = this[++offset] +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n last * 2 ** 24\n\n return BigInt(lo) + (BigInt(hi) << BigInt(32))\n})\n\nBuffer.prototype.readBigUInt64BE = defineBigIntMethod(function readBigUInt64BE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const hi = first * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n this[++offset]\n\n const lo = this[++offset] * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n last\n\n return (BigInt(hi) << BigInt(32)) + BigInt(lo)\n})\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let val = this[offset]\n let mul = 1\n let i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let i = byteLength\n let mul = 1\n let val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n const val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n const val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readBigInt64LE = defineBigIntMethod(function readBigInt64LE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const val = this[offset + 4] +\n this[offset + 5] * 2 ** 8 +\n this[offset + 6] * 2 ** 16 +\n (last << 24) // Overflow\n\n return (BigInt(val) << BigInt(32)) +\n BigInt(first +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 24)\n})\n\nBuffer.prototype.readBigInt64BE = defineBigIntMethod(function readBigInt64BE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const val = (first << 24) + // Overflow\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n this[++offset]\n\n return (BigInt(val) << BigInt(32)) +\n BigInt(this[++offset] * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n last)\n})\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUintLE =\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n const maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n let mul = 1\n let i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUintBE =\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n const maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n let i = byteLength - 1\n let mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUint8 =\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeUint16LE =\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeUint16BE =\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeUint32LE =\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeUint32BE =\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nfunction wrtBigUInt64LE (buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7)\n\n let lo = Number(value & BigInt(0xffffffff))\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n let hi = Number(value >> BigInt(32) & BigInt(0xffffffff))\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n return offset\n}\n\nfunction wrtBigUInt64BE (buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7)\n\n let lo = Number(value & BigInt(0xffffffff))\n buf[offset + 7] = lo\n lo = lo >> 8\n buf[offset + 6] = lo\n lo = lo >> 8\n buf[offset + 5] = lo\n lo = lo >> 8\n buf[offset + 4] = lo\n let hi = Number(value >> BigInt(32) & BigInt(0xffffffff))\n buf[offset + 3] = hi\n hi = hi >> 8\n buf[offset + 2] = hi\n hi = hi >> 8\n buf[offset + 1] = hi\n hi = hi >> 8\n buf[offset] = hi\n return offset + 8\n}\n\nBuffer.prototype.writeBigUInt64LE = defineBigIntMethod(function writeBigUInt64LE (value, offset = 0) {\n return wrtBigUInt64LE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n})\n\nBuffer.prototype.writeBigUInt64BE = defineBigIntMethod(function writeBigUInt64BE (value, offset = 0) {\n return wrtBigUInt64BE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n})\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n const limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n let i = 0\n let mul = 1\n let sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n const limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n let i = byteLength - 1\n let mul = 1\n let sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeBigInt64LE = defineBigIntMethod(function writeBigInt64LE (value, offset = 0) {\n return wrtBigUInt64LE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n})\n\nBuffer.prototype.writeBigInt64BE = defineBigIntMethod(function writeBigInt64BE (value, offset = 0) {\n return wrtBigUInt64BE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n})\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('Index out of range')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n const len = end - start\n\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end)\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, end),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n if (val.length === 1) {\n const code = val.charCodeAt(0)\n if ((encoding === 'utf8' && code < 128) ||\n encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255\n } else if (typeof val === 'boolean') {\n val = Number(val)\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n let i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n const bytes = Buffer.isBuffer(val)\n ? val\n : Buffer.from(val, encoding)\n const len = bytes.length\n if (len === 0) {\n throw new TypeError('The value \"' + val +\n '\" is invalid for argument \"value\"')\n }\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// CUSTOM ERRORS\n// =============\n\n// Simplified versions from Node, changed for Buffer-only usage\nconst errors = {}\nfunction E (sym, getMessage, Base) {\n errors[sym] = class NodeError extends Base {\n constructor () {\n super()\n\n Object.defineProperty(this, 'message', {\n value: getMessage.apply(this, arguments),\n writable: true,\n configurable: true\n })\n\n // Add the error code to the name to include it in the stack trace.\n this.name = `${this.name} [${sym}]`\n // Access the stack to generate the error message including the error code\n // from the name.\n this.stack // eslint-disable-line no-unused-expressions\n // Reset the name to the actual name.\n delete this.name\n }\n\n get code () {\n return sym\n }\n\n set code (value) {\n Object.defineProperty(this, 'code', {\n configurable: true,\n enumerable: true,\n value,\n writable: true\n })\n }\n\n toString () {\n return `${this.name} [${sym}]: ${this.message}`\n }\n }\n}\n\nE('ERR_BUFFER_OUT_OF_BOUNDS',\n function (name) {\n if (name) {\n return `${name} is outside of buffer bounds`\n }\n\n return 'Attempt to access memory outside buffer bounds'\n }, RangeError)\nE('ERR_INVALID_ARG_TYPE',\n function (name, actual) {\n return `The \"${name}\" argument must be of type number. Received type ${typeof actual}`\n }, TypeError)\nE('ERR_OUT_OF_RANGE',\n function (str, range, input) {\n let msg = `The value of \"${str}\" is out of range.`\n let received = input\n if (Number.isInteger(input) && Math.abs(input) > 2 ** 32) {\n received = addNumericalSeparator(String(input))\n } else if (typeof input === 'bigint') {\n received = String(input)\n if (input > BigInt(2) ** BigInt(32) || input < -(BigInt(2) ** BigInt(32))) {\n received = addNumericalSeparator(received)\n }\n received += 'n'\n }\n msg += ` It must be ${range}. Received ${received}`\n return msg\n }, RangeError)\n\nfunction addNumericalSeparator (val) {\n let res = ''\n let i = val.length\n const start = val[0] === '-' ? 1 : 0\n for (; i >= start + 4; i -= 3) {\n res = `_${val.slice(i - 3, i)}${res}`\n }\n return `${val.slice(0, i)}${res}`\n}\n\n// CHECK FUNCTIONS\n// ===============\n\nfunction checkBounds (buf, offset, byteLength) {\n validateNumber(offset, 'offset')\n if (buf[offset] === undefined || buf[offset + byteLength] === undefined) {\n boundsError(offset, buf.length - (byteLength + 1))\n }\n}\n\nfunction checkIntBI (value, min, max, buf, offset, byteLength) {\n if (value > max || value < min) {\n const n = typeof min === 'bigint' ? 'n' : ''\n let range\n if (byteLength > 3) {\n if (min === 0 || min === BigInt(0)) {\n range = `>= 0${n} and < 2${n} ** ${(byteLength + 1) * 8}${n}`\n } else {\n range = `>= -(2${n} ** ${(byteLength + 1) * 8 - 1}${n}) and < 2 ** ` +\n `${(byteLength + 1) * 8 - 1}${n}`\n }\n } else {\n range = `>= ${min}${n} and <= ${max}${n}`\n }\n throw new errors.ERR_OUT_OF_RANGE('value', range, value)\n }\n checkBounds(buf, offset, byteLength)\n}\n\nfunction validateNumber (value, name) {\n if (typeof value !== 'number') {\n throw new errors.ERR_INVALID_ARG_TYPE(name, 'number', value)\n }\n}\n\nfunction boundsError (value, length, type) {\n if (Math.floor(value) !== value) {\n validateNumber(value, type)\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset', 'an integer', value)\n }\n\n if (length < 0) {\n throw new errors.ERR_BUFFER_OUT_OF_BOUNDS()\n }\n\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset',\n `>= ${type ? 1 : 0} and <= ${length}`,\n value)\n}\n\n// HELPER FUNCTIONS\n// ================\n\nconst INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node takes equal signs as end of the Base64 encoding\n str = str.split('=')[0]\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n let codePoint\n const length = string.length\n let leadSurrogate = null\n const bytes = []\n\n for (let i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n const byteArray = []\n for (let i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n let c, hi, lo\n const byteArray = []\n for (let i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n let i\n for (i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\n// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n// the `instanceof` check but they should be treated as of that type.\n// See: https://github.com/feross/buffer/issues/166\nfunction isInstance (obj, type) {\n return obj instanceof type ||\n (obj != null && obj.constructor != null && obj.constructor.name != null &&\n obj.constructor.name === type.name)\n}\nfunction numberIsNaN (obj) {\n // For IE11 support\n return obj !== obj // eslint-disable-line no-self-compare\n}\n\n// Create lookup table for `toString('hex')`\n// See: https://github.com/feross/buffer/issues/219\nconst hexSliceLookupTable = (function () {\n const alphabet = '0123456789abcdef'\n const table = new Array(256)\n for (let i = 0; i < 16; ++i) {\n const i16 = i * 16\n for (let j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j]\n }\n }\n return table\n})()\n\n// Return not function with Error if BigInt not supported\nfunction defineBigIntMethod (fn) {\n return typeof BigInt === 'undefined' ? BufferBigIntNotDefined : fn\n}\n\nfunction BufferBigIntNotDefined () {\n throw new Error('BigInt not supported')\n}\n","'use strict';\n\nvar ERR_INVALID_OPT_VALUE = require('../../../errors').codes.ERR_INVALID_OPT_VALUE;\nfunction highWaterMarkFrom(options, isDuplex, duplexKey) {\n return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;\n}\nfunction getHighWaterMark(state, options, duplexKey, isDuplex) {\n var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);\n if (hwm != null) {\n if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {\n var name = isDuplex ? duplexKey : 'highWaterMark';\n throw new ERR_INVALID_OPT_VALUE(name, hwm);\n }\n return Math.floor(hwm);\n }\n\n // Default value\n return state.objectMode ? 16 : 16 * 1024;\n}\nmodule.exports = {\n getHighWaterMark: getHighWaterMark\n};","\"use strict\";\n// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Writer = void 0;\nconst varint_1 = __importDefault(require(\"./varint\"));\nconst big_integer_1 = __importDefault(require(\"big-integer\"));\nconst stream_1 = require(\"stream\");\nconst reader_1 = __importDefault(require(\"./reader\"));\nconst buffer_1 = require(\"buffer\");\nclass Writer extends stream_1.Readable {\n /**\n * Creates a new instance of the writer with the buffer preloaded with data if specified\n *\n * @param payload\n * @param encoding\n */\n constructor(payload = buffer_1.Buffer.alloc(0), encoding = 'hex') {\n super();\n this._buffer = buffer_1.Buffer.alloc(0);\n this._readIndex = 0;\n this.append(payload, encoding);\n }\n /**\n * Returns the current contents of the buffer\n */\n get buffer() {\n return this._buffer;\n }\n /**\n * Returns the byte size of the current buffer\n */\n get length() {\n return this._buffer.length;\n }\n /** @ignore */\n get readIndex() {\n return this._readIndex;\n }\n /** @ignore */\n static determineBits(value) {\n if (typeof value === 'number') {\n value = (0, big_integer_1.default)(value);\n }\n const bytes = [1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024];\n for (const byte of bytes) {\n let check = big_integer_1.default.zero;\n if (value.greater(-1)) {\n check = (0, big_integer_1.default)(2).pow(byte * 8)\n .subtract(1);\n }\n else {\n check = (0, big_integer_1.default)(2).pow((byte * 8) - 1)\n .subtract(1)\n .abs();\n }\n if (value.compare(check) <= 0) {\n return byte * 8;\n }\n }\n throw new RangeError('value is out of range');\n }\n /** @ignore */\n static writeUIntBE(value, bytes) {\n const hex = value.toString(16).padStart(bytes * 2, '0');\n return buffer_1.Buffer.from(hex, 'hex');\n }\n /** @ignore */\n static writeUIntLE(value, bytes) {\n const hex = value.toString(16).padStart(bytes * 2, '0');\n const buffer = buffer_1.Buffer.from(hex, 'hex');\n const tempBuffer = buffer_1.Buffer.alloc(bytes);\n let position = bytes - 1;\n for (const slice of buffer) {\n tempBuffer[position] = slice;\n position -= 1;\n }\n return tempBuffer;\n }\n /** @ignore */\n _read(size) {\n let okToSend = true;\n while (okToSend) {\n let slice = buffer_1.Buffer.alloc(0);\n if (this.readIndex + size > this.length) {\n slice = this._buffer.slice(this.readIndex);\n }\n else {\n slice = this._buffer.slice(this.readIndex, this.readIndex + size);\n }\n if (slice.length > 0) {\n this.push(slice);\n }\n else {\n this.push(null);\n okToSend = false;\n }\n this._readIndex += slice.length;\n }\n }\n /**\n * Clears the current write buffer\n */\n clear() {\n this._buffer = buffer_1.Buffer.alloc(0);\n }\n /**\n * Writes a hash to the buffer\n *\n * @param hash\n * @param encoding\n */\n hash(hash, encoding = 'hex') {\n if ((hash instanceof buffer_1.Buffer || hash instanceof Uint8Array) && (hash.length === 32 || hash.length === 64)) {\n return this.append(hash);\n }\n else if (typeof hash === 'string' && (hash.length === 64 || hash.length === 128)) {\n return this.append(hash, encoding);\n }\n throw new TypeError('hash is of wrong size and/or type');\n }\n /**\n * Writes the hex encoded value to the buffer\n *\n * @param hex\n */\n hex(hex) {\n if (hex instanceof buffer_1.Buffer || hex instanceof Uint8Array) {\n return this.append(hex);\n }\n else if (hex.length % 2 === 0) {\n return this.append(hex, 'hex');\n }\n throw new TypeError('hex is of the wrong size and/or type');\n }\n /**\n * Writes a signed integer to the buffer\n *\n * @param value\n * @param bits\n * @param bigEndian\n */\n signed_integer(value, bits = Writer.determineBits(value), bigEndian = false) {\n if (bits % 8 !== 0) {\n throw new RangeError('bits must be a multiple of 8');\n }\n if (typeof value === 'number') {\n value = (0, big_integer_1.default)(value);\n }\n const bytes = bits / 8;\n const buffer = buffer_1.Buffer.alloc(bytes);\n switch (bytes) {\n case 1:\n buffer.writeInt8(value.toJSNumber(), 0);\n break;\n case 2:\n (bigEndian ? buffer.writeInt16BE : buffer.writeInt16LE)(value.toJSNumber(), 0);\n break;\n case 4:\n (bigEndian ? buffer.writeInt32BE : buffer.writeInt32LE)(value.toJSNumber(), 0);\n break;\n case 8:\n (bigEndian ? buffer.writeBigInt64BE : buffer.writeBigInt64LE)(BigInt(value.toString()), 0);\n break;\n default:\n throw new TypeError('value bit size is not supported');\n }\n return this.append(buffer);\n }\n /**\n * Writes an int8_t to the buffer\n *\n * @param value\n */\n int8_t(value) {\n return this.signed_integer(value, 8);\n }\n /**\n * Writes an int16_t to the buffer\n *\n * @param value\n */\n int16_t(value) {\n return this.signed_integer(value, 16);\n }\n /**\n * Writes an int32_t to the buffer\n *\n * @param value\n */\n int32_t(value) {\n return this.signed_integer(value, 32);\n }\n /**\n * Writes an int64_t to the buffer\n *\n * @param value\n */\n int64_t(value) {\n return this.signed_integer(value, 64);\n }\n /**\n * Writes a string to the buffer\n *\n * @param value\n * @param encoding\n */\n string(value, encoding = 'utf-8') {\n const success = this.varint(value.length);\n if (!success) {\n throw new Error('could not encode string length as varint');\n }\n const buffer = buffer_1.Buffer.from(value, encoding);\n return this.append(buffer);\n }\n /**\n * Writes a time_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n time_t(value, bigEndian = false) {\n const num = (0, big_integer_1.default)(Math.floor(value.getTime() / 1000));\n return this.uint64_t(num, !bigEndian);\n }\n /**\n * Dumps the buffer to a string\n *\n * @param encoding\n */\n toString(encoding = 'hex') {\n return this.buffer.toString(encoding);\n }\n /**\n * Writes an unsigned integer to the buffer\n *\n * @param value\n * @param bits\n * @param bigEndian\n */\n unsigned_integer(value, bits = Writer.determineBits(value), bigEndian = false) {\n if (typeof value === 'number') {\n value = (0, big_integer_1.default)(value);\n }\n if (bits % 8 !== 0) {\n throw new RangeError('bits must be a multiple of 8');\n }\n if (value.lesser(0)) {\n throw new RangeError('cannot store signed value in unsigned type');\n }\n const bytes = bits / 8;\n const buffer = bigEndian ? Writer.writeUIntBE(value, bytes) : Writer.writeUIntLE(value, bytes);\n return this.append(buffer);\n }\n /**\n * Writes an uint8_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint8_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 8, bigEndian);\n }\n /**\n * Writes an uint16_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint16_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 16, bigEndian);\n }\n /**\n * Writes an uint32_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint32_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 32, bigEndian);\n }\n /**\n * Writes an uint64_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint64_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 64, bigEndian);\n }\n /**\n * Writes an uint128_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint128_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 128, bigEndian);\n }\n /**\n * Writes an uint256_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint256_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 256, bigEndian);\n }\n /**\n * Writes an uint512_t to the buffer\n *\n * @param value\n * @param bigEndian\n */\n uint512_t(value, bigEndian = false) {\n return this.unsigned_integer(value, 512, bigEndian);\n }\n /**\n * Writes a Varint to the buffer\n *\n * @param value\n * @param levin\n */\n varint(value, levin = false) {\n if (typeof value === 'number') {\n value = (0, big_integer_1.default)(value);\n }\n if (!levin) {\n return this.append(buffer_1.Buffer.from(varint_1.default.encode(value)));\n }\n else {\n if (value.greater((0, big_integer_1.default)('1073741823'))) {\n throw new RangeError('value out of range');\n }\n value = value.toJSNumber();\n let tempValue = value << 2;\n let byteCount = 0;\n if (value <= 63) {\n tempValue |= 0;\n byteCount = 1;\n }\n else if (value <= 16383) {\n tempValue |= 1;\n byteCount = 2;\n }\n else {\n tempValue |= 2;\n byteCount = 4;\n }\n for (let i = 0; i < byteCount; i++) {\n this.uint8_t((tempValue >> i * 8) & 0xFF);\n }\n return this;\n }\n }\n /**\n * Writes the supplied value to the buffer\n *\n * @param payload\n * @param encoding\n */\n append(payload, encoding = 'hex') {\n let buffer;\n if (payload instanceof reader_1.default || payload instanceof Writer) {\n buffer = payload.buffer;\n }\n else if (payload instanceof buffer_1.Buffer) {\n buffer = payload;\n }\n else if (payload instanceof Uint8Array) {\n buffer = buffer_1.Buffer.from(payload);\n }\n else {\n buffer = buffer_1.Buffer.from(payload, encoding);\n }\n this._buffer = buffer_1.Buffer.concat([this._buffer, buffer]);\n return this;\n }\n /**\n * Writes the specified bytes to the buffer\n *\n * @param value\n */\n bytes(value) {\n return this.append(value);\n }\n}\nexports.default = Writer;\nexports.Writer = Writer;\n//# sourceMappingURL=writer.js.map","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = Stream;\n\nvar EE = require('events').EventEmitter;\nvar inherits = require('inherits');\n\ninherits(Stream, EE);\nStream.Readable = require('readable-stream/lib/_stream_readable.js');\nStream.Writable = require('readable-stream/lib/_stream_writable.js');\nStream.Duplex = require('readable-stream/lib/_stream_duplex.js');\nStream.Transform = require('readable-stream/lib/_stream_transform.js');\nStream.PassThrough = require('readable-stream/lib/_stream_passthrough.js');\nStream.finished = require('readable-stream/lib/internal/streams/end-of-stream.js')\nStream.pipeline = require('readable-stream/lib/internal/streams/pipeline.js')\n\n// Backwards-compat with node 0.4.x\nStream.Stream = Stream;\n\n\n\n// old-style streams. Note that the pipe method (the only relevant\n// part of this class) is overridden in the Readable class.\n\nfunction Stream() {\n EE.call(this);\n}\n\nStream.prototype.pipe = function(dest, options) {\n var source = this;\n\n function ondata(chunk) {\n if (dest.writable) {\n if (false === dest.write(chunk) && source.pause) {\n source.pause();\n }\n }\n }\n\n source.on('data', ondata);\n\n function ondrain() {\n if (source.readable && source.resume) {\n source.resume();\n }\n }\n\n dest.on('drain', ondrain);\n\n // If the 'end' option is not supplied, dest.end() will be called when\n // source gets the 'end' or 'close' events. Only dest.end() once.\n if (!dest._isStdio && (!options || options.end !== false)) {\n source.on('end', onend);\n source.on('close', onclose);\n }\n\n var didOnEnd = false;\n function onend() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n dest.end();\n }\n\n\n function onclose() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n if (typeof dest.destroy === 'function') dest.destroy();\n }\n\n // don't leave dangling pipes when there are errors.\n function onerror(er) {\n cleanup();\n if (EE.listenerCount(this, 'error') === 0) {\n throw er; // Unhandled stream error in pipe.\n }\n }\n\n source.on('error', onerror);\n dest.on('error', onerror);\n\n // remove all the event listeners that were added.\n function cleanup() {\n source.removeListener('data', ondata);\n dest.removeListener('drain', ondrain);\n\n source.removeListener('end', onend);\n source.removeListener('close', onclose);\n\n source.removeListener('error', onerror);\n dest.removeListener('error', onerror);\n\n source.removeListener('end', cleanup);\n source.removeListener('close', cleanup);\n\n dest.removeListener('close', cleanup);\n }\n\n source.on('end', cleanup);\n source.on('close', cleanup);\n\n dest.on('close', cleanup);\n\n dest.emit('pipe', source);\n\n // Allow for unix-like usage: A.pipe(B).pipe(C)\n return dest;\n};\n","module.exports = require('events').EventEmitter;\n","// Copyright (c) 2021, pur3missh\n// Copyright (c) 2023-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\n\n/**\n * This code has been copied over from the base58-js package and translated to typescript\n * as the author of base58-js has no included typings at this time and it is not available\n * via @types/base58-js\n */\n\n/** @ignore */\nconst base58_chars =\n '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';\n\n/** @ignore */\nconst create_base58_map = () => {\n const base58M = Array(256).fill(-1);\n\n for (let i = 0; i < base58_chars.length; ++i) {\n base58M[base58_chars.charCodeAt(i)] = i;\n }\n\n return base58M;\n};\n\n/** @ignore */\nconst base58Map = create_base58_map();\n\n/**\n * Converts a base58 string to the corresponding binary representation\n *\n * @param base58String\n */\nexport const base58_to_binary = (base58String: string): Uint8Array<ArrayBuffer> => {\n if (base58String.match(/[IOl0]/gmu)) {\n throw new Error(\n `Invalid base58 character “${base58String.match(/[IOl0]/gmu)}”`\n );\n }\n\n const lz = base58String.match(/^1+/gmu);\n\n const psz = lz ? lz[0].length : 0;\n\n const size = ((base58String.length - psz) * (Math.log(58) / Math.log(256)) + 1) >>> 0;\n\n const base58_match = base58String.match(/./gmu);\n\n const psz_Uint = new Uint8Array(psz);\n\n let base58_temp: Uint8Array = new Uint8Array();\n\n if (base58_match) {\n base58_temp = base58_match.map(i => base58_chars.indexOf(i))\n .reduce((acc, i) => {\n acc = acc.map((j) => {\n const x = j * 58 + i;\n i = x >> 8;\n return x;\n });\n return acc;\n }, new Uint8Array(size))\n .reverse()\n .filter((lastValue =>\n value =>\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n (lastValue = lastValue || value)\n )(false));\n }\n\n return new Uint8Array([\n ...psz_Uint,\n ...base58_temp\n ]);\n};\n\n/**\n * Converts a Uint8Array into a base58 string\n *\n * @param uint8array\n */\nexport const binary_to_base58 = (uint8array: Uint8Array): string => {\n const result = [];\n\n for (const byte of uint8array) {\n let carry = byte;\n\n for (let j = 0; j < result.length; ++j) {\n const x: number = (base58Map[result[j]] << 8) + carry;\n\n result[j] = base58_chars.charCodeAt(x % 58);\n\n carry = (x / 58) | 0;\n }\n\n while (carry) {\n result.push(base58_chars.charCodeAt(carry % 58));\n\n carry = (carry / 58) | 0;\n }\n }\n\n for (const byte of uint8array) {\n if (byte) break;\n else result.push('1'.charCodeAt(0));\n }\n\n result.reverse();\n\n return String.fromCharCode(...result);\n};\n\nexport default {\n binary_to_base58,\n base58_to_binary\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/*<replacement>*/\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) keys.push(key);\n return keys;\n};\n/*</replacement>*/\n\nmodule.exports = Duplex;\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\nrequire('inherits')(Duplex, Readable);\n{\n // Allow the keys array to be GC'ed.\n var keys = objectKeys(Writable.prototype);\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n Readable.call(this, options);\n Writable.call(this, options);\n this.allowHalfOpen = true;\n if (options) {\n if (options.readable === false) this.readable = false;\n if (options.writable === false) this.writable = false;\n if (options.allowHalfOpen === false) {\n this.allowHalfOpen = false;\n this.once('end', onend);\n }\n }\n}\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\n\n// the no-half-open enforcer\nfunction onend() {\n // If the writable side ended, then we're ok.\n if (this._writableState.ended) return;\n\n // no more data can be written.\n // But allow more writes to happen in this tick.\n process.nextTick(onEndNT, this);\n}\nfunction onEndNT(self) {\n self.end();\n}\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nmodule.exports = Readable;\n\n/*<replacement>*/\nvar Duplex;\n/*</replacement>*/\n\nReadable.ReadableState = ReadableState;\n\n/*<replacement>*/\nvar EE = require('events').EventEmitter;\nvar EElistenerCount = function EElistenerCount(emitter, type) {\n return emitter.listeners(type).length;\n};\n/*</replacement>*/\n\n/*<replacement>*/\nvar Stream = require('./internal/streams/stream');\n/*</replacement>*/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/*<replacement>*/\nvar debugUtil = require('util');\nvar debug;\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function debug() {};\n}\n/*</replacement>*/\n\nvar BufferList = require('./internal/streams/buffer_list');\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT;\n\n// Lazy loaded to improve the startup performance.\nvar StringDecoder;\nvar createReadableStreamAsyncIterator;\nvar from;\nrequire('inherits')(Readable, Stream);\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn);\n\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\nfunction ReadableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex);\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false;\n\n // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n this.sync = true;\n\n // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n this.paused = true;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'end' (and potentially 'finish')\n this.autoDestroy = !!options.autoDestroy;\n\n // has it been destroyed\n this.destroyed = false;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // the number of writers that are awaiting a drain event in .pipe()s\n this.awaitDrain = 0;\n\n // if true, a maybeReadMore has been scheduled\n this.readingMore = false;\n this.decoder = null;\n this.encoding = null;\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n if (!(this instanceof Readable)) return new Readable(options);\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the ReadableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n this._readableState = new ReadableState(options, this, isDuplex);\n\n // legacy\n this.readable = true;\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n Stream.call(this);\n}\nObject.defineProperty(Readable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined) {\n return false;\n }\n return this._readableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n }\n});\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\nReadable.prototype._destroy = function (err, cb) {\n cb(err);\n};\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n debug('readableAddChunk', chunk);\n var state = stream._readableState;\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n if (er) {\n errorOrDestroy(stream, er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (addToFront) {\n if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());\n } else if (state.destroyed) {\n return false;\n } else {\n state.reading = false;\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n maybeReadMore(stream, state);\n }\n }\n\n // We can push more data if we are below the highWaterMark.\n // Also, if we have no data yet, we can stand some more bytes.\n // This is to work around cases where hwm=0, such as the repl.\n return !state.ended && (state.length < state.highWaterMark || state.length === 0);\n}\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n state.awaitDrain = 0;\n stream.emit('data', chunk);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n if (state.needReadable) emitReadable(stream);\n }\n maybeReadMore(stream, state);\n}\nfunction chunkInvalid(state, chunk) {\n var er;\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);\n }\n return er;\n}\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n};\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n var decoder = new StringDecoder(enc);\n this._readableState.decoder = decoder;\n // If setEncoding(null), decoder.encoding equals utf8\n this._readableState.encoding = this._readableState.decoder.encoding;\n\n // Iterate over current buffer to convert already stored Buffers:\n var p = this._readableState.buffer.head;\n var content = '';\n while (p !== null) {\n content += decoder.write(p.data);\n p = p.next;\n }\n this._readableState.buffer.clear();\n if (content !== '') this._readableState.buffer.push(content);\n this._readableState.length = content.length;\n return this;\n};\n\n// Don't raise the hwm > 1GB\nvar MAX_HWM = 0x40000000;\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n return n;\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n }\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n;\n // Don't have enough\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n return state.length;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n if (n !== 0) state.emittedReadable = false;\n\n // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n n = howMuchToRead(n, state);\n\n // if we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n var doRead = state.needReadable;\n debug('need readable', doRead);\n\n // if we currently have less than the highWaterMark, then also read some\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n }\n\n // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true;\n // if the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.needReadable = true;\n // call internal read method\n this._read(state.highWaterMark);\n state.sync = false;\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n if (ret === null) {\n state.needReadable = state.length <= state.highWaterMark;\n n = 0;\n } else {\n state.length -= n;\n state.awaitDrain = 0;\n }\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true;\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this);\n }\n if (ret !== null) this.emit('data', ret);\n return ret;\n};\nfunction onEofChunk(stream, state) {\n debug('onEofChunk');\n if (state.ended) return;\n if (state.decoder) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n state.ended = true;\n if (state.sync) {\n // if we are sync, wait until next tick to emit the data.\n // Otherwise we risk emitting data in the flow()\n // the readable code triggers during a read() call\n emitReadable(stream);\n } else {\n // emit 'readable' now to make sure it gets picked up.\n state.needReadable = false;\n if (!state.emittedReadable) {\n state.emittedReadable = true;\n emitReadable_(stream);\n }\n }\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n var state = stream._readableState;\n debug('emitReadable', state.needReadable, state.emittedReadable);\n state.needReadable = false;\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n process.nextTick(emitReadable_, stream);\n }\n}\nfunction emitReadable_(stream) {\n var state = stream._readableState;\n debug('emitReadable_', state.destroyed, state.length, state.ended);\n if (!state.destroyed && (state.length || state.ended)) {\n stream.emit('readable');\n state.emittedReadable = false;\n }\n\n // The stream needs another readable event if\n // 1. It is not flowing, as the flow mechanism will take\n // care of it.\n // 2. It is not ended.\n // 3. It is below the highWaterMark, so we can schedule\n // another readable later.\n state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;\n flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n process.nextTick(maybeReadMore_, stream, state);\n }\n}\nfunction maybeReadMore_(stream, state) {\n // Attempt to read more data if we should.\n //\n // The conditions for reading more data are (one of):\n // - Not enough data buffered (state.length < state.highWaterMark). The loop\n // is responsible for filling the buffer with enough data if such data\n // is available. If highWaterMark is 0 and we are not in the flowing mode\n // we should _not_ attempt to buffer any extra data. We'll get more data\n // when the stream consumer calls read() instead.\n // - No data in the buffer, and the stream is in flowing mode. In this mode\n // the loop below is responsible for ensuring read() is called. Failing to\n // call read here would abort the flow and there's no other mechanism for\n // continuing the flow if the stream consumer has just subscribed to the\n // 'data' event.\n //\n // In addition to the above conditions to keep reading data, the following\n // conditions prevent the data from being read:\n // - The stream has ended (state.ended).\n // - There is already a pending 'read' operation (state.reading). This is a\n // case where the the stream has called the implementation defined _read()\n // method, but they are processing the call asynchronously and have _not_\n // called push() with new data. In this case we skip performing more\n // read()s. The execution ends in this method again after the _read() ends\n // up calling push() with more data.\n while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {\n var len = state.length;\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length)\n // didn't get any data, stop spinning.\n break;\n }\n state.readingMore = false;\n}\n\n// abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));\n};\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n default:\n state.pipes.push(dest);\n break;\n }\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);\n dest.on('unpipe', onunpipe);\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n function onend() {\n debug('onend');\n dest.end();\n }\n\n // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n var cleanedUp = false;\n function cleanup() {\n debug('cleanup');\n // cleanup event handlers once the pipe is broken\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n cleanedUp = true;\n\n // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n src.on('data', ondata);\n function ondata(chunk) {\n debug('ondata');\n var ret = dest.write(chunk);\n debug('dest.write', ret);\n if (ret === false) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n }\n src.pause();\n }\n }\n\n // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror);\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n dest.once('close', onclose);\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n dest.once('finish', onfinish);\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n }\n\n // tell the dest that it's being piped to\n dest.emit('pipe', src);\n\n // start the flow if it hasn't been started already.\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n return dest;\n};\nfunction pipeOnDrain(src) {\n return function pipeOnDrainFunctionResult() {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = {\n hasUnpiped: false\n };\n\n // if we're not piping anywhere, then do nothing.\n if (state.pipesCount === 0) return this;\n\n // just one destination. most common case.\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n if (!dest) dest = state.pipes;\n\n // got a match.\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n }\n\n // slow case. multiple pipe destinations.\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n for (var i = 0; i < len; i++) dests[i].emit('unpipe', this, {\n hasUnpiped: false\n });\n return this;\n }\n\n // try to find the right one.\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n dest.emit('unpipe', this, unpipeInfo);\n return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n var state = this._readableState;\n if (ev === 'data') {\n // update readableListening so that resume() may be a no-op\n // a few lines down. This is needed to support once('readable').\n state.readableListening = this.listenerCount('readable') > 0;\n\n // Try start flowing on next tick if stream isn't explicitly paused\n if (state.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.flowing = false;\n state.emittedReadable = false;\n debug('on readable', state.length, state.reading);\n if (state.length) {\n emitReadable(this);\n } else if (!state.reading) {\n process.nextTick(nReadingNextTick, this);\n }\n }\n }\n return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\nReadable.prototype.removeListener = function (ev, fn) {\n var res = Stream.prototype.removeListener.call(this, ev, fn);\n if (ev === 'readable') {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nReadable.prototype.removeAllListeners = function (ev) {\n var res = Stream.prototype.removeAllListeners.apply(this, arguments);\n if (ev === 'readable' || ev === undefined) {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nfunction updateReadableListening(self) {\n var state = self._readableState;\n state.readableListening = self.listenerCount('readable') > 0;\n if (state.resumeScheduled && !state.paused) {\n // flowing needs to be set to true now, otherwise\n // the upcoming resume will not flow.\n state.flowing = true;\n\n // crude way to check if we should resume\n } else if (self.listenerCount('data') > 0) {\n self.resume();\n }\n}\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n var state = this._readableState;\n if (!state.flowing) {\n debug('resume');\n // we flow only if there is no one listening\n // for readable, but we still have to call\n // resume()\n state.flowing = !state.readableListening;\n resume(this, state);\n }\n state.paused = false;\n return this;\n};\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n process.nextTick(resume_, stream, state);\n }\n}\nfunction resume_(stream, state) {\n debug('resume', state.reading);\n if (!state.reading) {\n stream.read(0);\n }\n state.resumeScheduled = false;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n if (this._readableState.flowing !== false) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n this._readableState.paused = true;\n return this;\n};\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n while (state.flowing && stream.read() !== null);\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n var state = this._readableState;\n var paused = false;\n stream.on('end', function () {\n debug('wrapped end');\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n _this.push(null);\n });\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk);\n\n // don't skip over falsy values in objectMode\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n var ret = _this.push(chunk);\n if (!ret) {\n paused = true;\n stream.pause();\n }\n });\n\n // proxy all the other methods.\n // important when wrapping filters and duplexes.\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function methodWrap(method) {\n return function methodWrapReturnFunction() {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n }\n\n // proxy certain important events.\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n }\n\n // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n this._read = function (n) {\n debug('wrapped _read', n);\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n return this;\n};\nif (typeof Symbol === 'function') {\n Readable.prototype[Symbol.asyncIterator] = function () {\n if (createReadableStreamAsyncIterator === undefined) {\n createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');\n }\n return createReadableStreamAsyncIterator(this);\n };\n}\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.highWaterMark;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState && this._readableState.buffer;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableFlowing', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.flowing;\n },\n set: function set(state) {\n if (this._readableState) {\n this._readableState.flowing = state;\n }\n }\n});\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\nObject.defineProperty(Readable.prototype, 'readableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.length;\n }\n});\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = state.buffer.consume(n, state.decoder);\n }\n return ret;\n}\nfunction endReadable(stream) {\n var state = stream._readableState;\n debug('endReadable', state.endEmitted);\n if (!state.endEmitted) {\n state.ended = true;\n process.nextTick(endReadableNT, state, stream);\n }\n}\nfunction endReadableNT(state, stream) {\n debug('endReadableNT', state.endEmitted, state.length);\n\n // Check that we didn't get one last unshift.\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the writable side is ready for autoDestroy as well\n var wState = stream._writableState;\n if (!wState || wState.autoDestroy && wState.finished) {\n stream.destroy();\n }\n }\n }\n}\nif (typeof Symbol === 'function') {\n Readable.from = function (iterable, opts) {\n if (from === undefined) {\n from = require('./internal/streams/from');\n }\n return from(Readable, iterable, opts);\n };\n}\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n return -1;\n}","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\nvar Transform = require('./_stream_transform');\nrequire('inherits')(PassThrough, Transform);\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n Transform.call(this, options);\n}\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\nvar _require$codes = require('../errors').codes,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,\n ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;\nvar Duplex = require('./_stream_duplex');\nrequire('inherits')(Transform, Duplex);\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n var cb = ts.writecb;\n if (cb === null) {\n return this.emit('error', new ERR_MULTIPLE_CALLBACK());\n }\n ts.writechunk = null;\n ts.writecb = null;\n if (data != null)\n // single equals check for both `null` and `undefined`\n this.push(data);\n cb(er);\n var rs = this._readableState;\n rs.reading = false;\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n Duplex.call(this, options);\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n };\n\n // start out asking for a readable event once data is transformed.\n this._readableState.needReadable = true;\n\n // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false;\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n if (typeof options.flush === 'function') this._flush = options.flush;\n }\n\n // When the writable side finishes, then flush out anything remaining.\n this.on('prefinish', prefinish);\n}\nfunction prefinish() {\n var _this = this;\n if (typeof this._flush === 'function' && !this._readableState.destroyed) {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));\n};\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n if (ts.writechunk !== null && !ts.transforming) {\n ts.transforming = true;\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\nTransform.prototype._destroy = function (err, cb) {\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n });\n};\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n if (data != null)\n // single equals check for both `null` and `undefined`\n stream.push(data);\n\n // TODO(BridgeAR): Write a test for these two error cases\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();\n if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();\n return stream.push(null);\n}","\n/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate (fn, msg) {\n if (config('noDeprecation')) {\n return fn;\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (config('throwDeprecation')) {\n throw new Error(msg);\n } else if (config('traceDeprecation')) {\n console.trace(msg);\n } else {\n console.warn(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config (name) {\n // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n try {\n if (!global.localStorage) return false;\n } catch (_) {\n return false;\n }\n var val = global.localStorage[name];\n if (null == val) return false;\n return String(val).toLowerCase() === 'true';\n}\n","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\n\nimport { BigInteger, Reader, Writer } from '@gibme/bytepack';\nimport { Buffer } from 'buffer';\n\n/** @ignore */\nconst ALPHABET: number[] = (() => {\n const str = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';\n\n return str.split('')\n .map(char => char.charCodeAt(0));\n})();\n\n/** @ignore */\nconst ENCODED_BLOCK_SIZES = [0, 2, 3, 5, 6, 7, 9, 10, 11];\n\n/** @ignore */\nconst FULL_BLOCK_SIZE = 8;\n\n/** @ignore */\nconst FULL_ENCODED_BLOCK_SIZE = 11;\n\n/** @ignore */\nconst UINT64_MAX = BigInteger(2).pow(64);\n\nexport default abstract class CryptoNoteBase58 {\n /**\n * Decodes the CryptoNote Base58 encoded string into a Buffer\n *\n * @param encoded\n */\n public static cn_decode (\n encoded: string\n ): Buffer {\n const enc = Buffer.from(encoded).valueOf();\n\n if (enc.length === 0) {\n return Buffer.alloc(0);\n }\n\n const fullBlockCount = Math.floor(enc.length / FULL_ENCODED_BLOCK_SIZE);\n\n const lastBlockSize = enc.length % FULL_ENCODED_BLOCK_SIZE;\n\n const lastBlockDecodedSize = ENCODED_BLOCK_SIZES.indexOf(lastBlockSize);\n\n if (lastBlockDecodedSize < 0) {\n throw new Error('Invalid encoded length');\n }\n\n const dataSize = fullBlockCount * FULL_BLOCK_SIZE + lastBlockDecodedSize;\n\n let result = new Uint8Array(dataSize);\n\n for (let i = 0; i < fullBlockCount; i++) {\n result = CryptoNoteBase58.decodeBlock(\n enc.subarray(\n i * FULL_ENCODED_BLOCK_SIZE,\n i * FULL_ENCODED_BLOCK_SIZE + FULL_ENCODED_BLOCK_SIZE),\n result,\n i * FULL_BLOCK_SIZE\n );\n }\n\n if (lastBlockSize > 0) {\n result = CryptoNoteBase58.decodeBlock(\n enc.subarray(\n fullBlockCount * FULL_ENCODED_BLOCK_SIZE,\n fullBlockCount * FULL_ENCODED_BLOCK_SIZE + lastBlockSize),\n result,\n fullBlockCount * FULL_BLOCK_SIZE\n );\n }\n\n return Buffer.from(result);\n }\n\n /**\n * Encodes the data into CryptoNote Base58 string\n *\n * @param data\n */\n public static cn_encode (\n data: string | Uint8Array | Buffer\n ): string {\n if (data instanceof Buffer) {\n data = data.toString('hex');\n } else if (data instanceof Uint8Array) {\n data = Buffer.from(data).toString('hex');\n }\n\n const _data = Buffer.from(data, 'hex').valueOf();\n\n if (_data.length === 0) {\n return '';\n }\n\n const fullBlockCount = Math.floor(_data.length / FULL_BLOCK_SIZE);\n\n const lastBlockSize = _data.length % FULL_BLOCK_SIZE;\n\n const resSize = fullBlockCount * FULL_ENCODED_BLOCK_SIZE + ENCODED_BLOCK_SIZES[lastBlockSize];\n\n let result = new Uint8Array(resSize);\n\n for (let i = 0; i < resSize; ++i) {\n result[i] = ALPHABET[0];\n }\n\n for (let i = 0; i < fullBlockCount; i++) {\n result = CryptoNoteBase58.encodeBlock(\n _data.subarray(\n i * FULL_BLOCK_SIZE,\n i * FULL_BLOCK_SIZE + FULL_BLOCK_SIZE),\n result, i *\n FULL_ENCODED_BLOCK_SIZE);\n }\n\n if (lastBlockSize > 0) {\n result = CryptoNoteBase58.encodeBlock(\n _data.subarray(\n fullBlockCount * FULL_BLOCK_SIZE,\n fullBlockCount * FULL_BLOCK_SIZE + lastBlockSize),\n result,\n fullBlockCount * FULL_ENCODED_BLOCK_SIZE);\n }\n\n return Buffer.from(result).toString();\n }\n\n /**\n * Decodes a Base58 block\n *\n * @param data\n * @param buffer\n * @param index\n * @private\n */\n private static decodeBlock (\n data: Uint8Array,\n buffer: Uint8Array<ArrayBuffer>,\n index: number\n ): Uint8Array<ArrayBuffer> {\n if (data.length < 1 || data.length > FULL_ENCODED_BLOCK_SIZE) {\n throw new Error('Invalid block length: ' + data.length);\n }\n\n const resSize = ENCODED_BLOCK_SIZES.indexOf(data.length);\n\n if (resSize <= 0) {\n throw new Error('Invalid block size');\n }\n\n let resNum = BigInteger.zero;\n\n let order = BigInteger.one;\n\n for (let i = data.length - 1; i >= 0; i--) {\n const digit = ALPHABET.indexOf(data[i]);\n\n if (digit < 0) {\n throw new Error('Invalid symbol');\n }\n\n const product = order.multiply(digit).add(resNum);\n\n if (product.compare(UINT64_MAX) === 1) {\n throw new Error('Overflow');\n }\n\n resNum = product;\n\n order = order.multiply(ALPHABET.length);\n }\n\n if (resSize < FULL_BLOCK_SIZE && (BigInteger(2).pow(8 * resSize).compare(resNum) <= 0)) {\n throw new Error('Overflow 2');\n }\n\n const value = new Writer()\n .uint64_t(resNum, true)\n .buffer\n .valueOf();\n\n buffer.set(value, index);\n\n return buffer;\n }\n\n /**\n * Encodes the data into a block for Base58\n *\n * @param data\n * @param buffer\n * @param index\n * @private\n */\n private static encodeBlock (\n data: Uint8Array,\n buffer: Uint8Array<ArrayBuffer>,\n index: number\n ): Uint8Array<ArrayBuffer> {\n if (data.length < 1 || data.length > FULL_ENCODED_BLOCK_SIZE) {\n throw new Error('Invalid block length: ' + data.length);\n }\n\n let num = new Reader(data).uint64_t(true);\n\n let i = ENCODED_BLOCK_SIZES[data.length] - 1;\n\n while (num.compare(0) === 1) {\n const div = num.divmod(ALPHABET.length);\n\n const remainder = div.remainder;\n\n num = div.quotient;\n\n buffer[index + i] = ALPHABET[remainder.toJSNumber()];\n\n i--;\n }\n\n return buffer;\n }\n}\n\nexport { CryptoNoteBase58 };\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\nmodule.exports = Writable;\n\n/* <replacement> */\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n var _this = this;\n this.next = null;\n this.entry = null;\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* </replacement> */\n\n/*<replacement>*/\nvar Duplex;\n/*</replacement>*/\n\nWritable.WritableState = WritableState;\n\n/*<replacement>*/\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/*</replacement>*/\n\n/*<replacement>*/\nvar Stream = require('./internal/streams/stream');\n/*</replacement>*/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,\n ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,\n ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,\n ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nrequire('inherits')(Writable, Stream);\nfunction nop() {}\nfunction WritableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream,\n // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex);\n\n // if _final has been called\n this.finalCalled = false;\n\n // drain event flag.\n this.needDrain = false;\n // at the start of calling end()\n this.ending = false;\n // when end() has been called, and returned\n this.ended = false;\n // when 'finish' is emitted\n this.finished = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0;\n\n // a flag to see when we're in the middle of a write.\n this.writing = false;\n\n // when true all writes will be buffered until .uncork() call\n this.corked = 0;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false;\n\n // the callback that's passed to _write(chunk,cb)\n this.onwrite = function (er) {\n onwrite(stream, er);\n };\n\n // the callback that the user supplies to write(chunk,encoding,cb)\n this.writecb = null;\n\n // the amount that is being written when _write is called.\n this.writelen = 0;\n this.bufferedRequest = null;\n this.lastBufferedRequest = null;\n\n // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n this.pendingcb = 0;\n\n // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n this.prefinished = false;\n\n // True if the error was already emitted and should not be thrown again\n this.errorEmitted = false;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'finish' (and potentially 'end')\n this.autoDestroy = !!options.autoDestroy;\n\n // count buffered requests\n this.bufferedRequestCount = 0;\n\n // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n this.corkedRequestsFree = new CorkedRequest(this);\n}\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n while (current) {\n out.push(current);\n current = current.next;\n }\n return out;\n};\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function writableStateBufferGetter() {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})();\n\n// Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\nvar realHasInstance;\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function value(object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function realHasInstance(object) {\n return object instanceof this;\n };\n}\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the WritableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);\n this._writableState = new WritableState(options, this, isDuplex);\n\n // legacy.\n this.writable = true;\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n if (typeof options.writev === 'function') this._writev = options.writev;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n if (typeof options.final === 'function') this._final = options.final;\n }\n Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());\n};\nfunction writeAfterEnd(stream, cb) {\n var er = new ERR_STREAM_WRITE_AFTER_END();\n // TODO: defer error events consistently everywhere, not just the cb\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n}\n\n// Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\nfunction validChunk(stream, state, chunk, cb) {\n var er;\n if (chunk === null) {\n er = new ERR_STREAM_NULL_VALUES();\n } else if (typeof chunk !== 'string' && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);\n }\n if (er) {\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n return false;\n }\n return true;\n}\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n if (typeof cb !== 'function') cb = nop;\n if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n return ret;\n};\nWritable.prototype.cork = function () {\n this._writableState.corked++;\n};\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n if (state.corked) {\n state.corked--;\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n return chunk;\n}\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n var len = state.objectMode ? 1 : chunk.length;\n state.length += len;\n var ret = state.length < state.highWaterMark;\n // we must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true;\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n return ret;\n}\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n process.nextTick(cb, er);\n // this can emit finish, and it will always happen\n // after error\n process.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n // this can emit finish, but finish must\n // always follow error\n finishMaybe(stream, state);\n }\n}\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();\n onwriteStateUpdate(state);\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state) || stream.destroyed;\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n if (sync) {\n process.nextTick(afterWrite, stream, state, finished, cb);\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n var count = 0;\n var allBuffers = true;\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n buffer.allBuffers = allBuffers;\n doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n state.pendingcb++;\n state.lastBufferedRequest = null;\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--;\n // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n if (state.writing) {\n break;\n }\n }\n if (entry === null) state.lastBufferedRequest = null;\n }\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));\n};\nWritable.prototype._writev = null;\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n // .end() fully uncorks\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n }\n\n // ignore unnecessary end() calls.\n if (!state.ending) endWritable(this, state, cb);\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n if (err) {\n errorOrDestroy(stream, err);\n }\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function' && !state.destroyed) {\n state.pendingcb++;\n state.finalCalled = true;\n process.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n if (need) {\n prefinish(stream, state);\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the readable side is ready for autoDestroy as well\n var rState = stream._readableState;\n if (!rState || rState.autoDestroy && rState.endEmitted) {\n stream.destroy();\n }\n }\n }\n }\n return need;\n}\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n if (cb) {\n if (state.finished) process.nextTick(cb);else stream.once('finish', cb);\n }\n state.ended = true;\n stream.writable = false;\n}\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n }\n\n // reuse the free corkReq.\n state.corkedRequestsFree.next = corkReq;\n}\nObject.defineProperty(Writable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._writableState === undefined) {\n return false;\n }\n return this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._writableState.destroyed = value;\n }\n});\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\nWritable.prototype._destroy = function (err, cb) {\n cb(err);\n};","'use strict';\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nvar _require = require('buffer'),\n Buffer = _require.Buffer;\nvar _require2 = require('util'),\n inspect = _require2.inspect;\nvar custom = inspect && inspect.custom || 'inspect';\nfunction copyBuffer(src, target, offset) {\n Buffer.prototype.copy.call(src, target, offset);\n}\nmodule.exports = /*#__PURE__*/function () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n _createClass(BufferList, [{\n key: \"push\",\n value: function push(v) {\n var entry = {\n data: v,\n next: null\n };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n }\n }, {\n key: \"unshift\",\n value: function unshift(v) {\n var entry = {\n data: v,\n next: this.head\n };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n }\n }, {\n key: \"shift\",\n value: function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n }\n }, {\n key: \"clear\",\n value: function clear() {\n this.head = this.tail = null;\n this.length = 0;\n }\n }, {\n key: \"join\",\n value: function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n while (p = p.next) ret += s + p.data;\n return ret;\n }\n }, {\n key: \"concat\",\n value: function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n return ret;\n }\n\n // Consumes a specified amount of bytes or characters from the buffered data.\n }, {\n key: \"consume\",\n value: function consume(n, hasStrings) {\n var ret;\n if (n < this.head.data.length) {\n // `slice` is the same for buffers and strings.\n ret = this.head.data.slice(0, n);\n this.head.data = this.head.data.slice(n);\n } else if (n === this.head.data.length) {\n // First chunk is a perfect match.\n ret = this.shift();\n } else {\n // Result spans more than one buffer.\n ret = hasStrings ? this._getString(n) : this._getBuffer(n);\n }\n return ret;\n }\n }, {\n key: \"first\",\n value: function first() {\n return this.head.data;\n }\n\n // Consumes a specified amount of characters from the buffered data.\n }, {\n key: \"_getString\",\n value: function _getString(n) {\n var p = this.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = str.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Consumes a specified amount of bytes from the buffered data.\n }, {\n key: \"_getBuffer\",\n value: function _getBuffer(n) {\n var ret = Buffer.allocUnsafe(n);\n var p = this.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = buf.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Make sure the linked list only shows the minimal necessary information.\n }, {\n key: custom,\n value: function value(_, options) {\n return inspect(this, _objectSpread(_objectSpread({}, options), {}, {\n // Only inspect one level.\n depth: 0,\n // It should not recurse.\n customInspect: false\n }));\n }\n }]);\n return BufferList;\n}();","// Ported from https://github.com/mafintosh/pump with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar eos;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n callback.apply(void 0, arguments);\n };\n}\nvar _require$codes = require('../../../errors').codes,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;\nfunction noop(err) {\n // Rethrow the error if it exists to avoid swallowing it\n if (err) throw err;\n}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction destroyer(stream, reading, writing, callback) {\n callback = once(callback);\n var closed = false;\n stream.on('close', function () {\n closed = true;\n });\n if (eos === undefined) eos = require('./end-of-stream');\n eos(stream, {\n readable: reading,\n writable: writing\n }, function (err) {\n if (err) return callback(err);\n closed = true;\n callback();\n });\n var destroyed = false;\n return function (err) {\n if (closed) return;\n if (destroyed) return;\n destroyed = true;\n\n // request.destroy just do .end - .abort is what we want\n if (isRequest(stream)) return stream.abort();\n if (typeof stream.destroy === 'function') return stream.destroy();\n callback(err || new ERR_STREAM_DESTROYED('pipe'));\n };\n}\nfunction call(fn) {\n fn();\n}\nfunction pipe(from, to) {\n return from.pipe(to);\n}\nfunction popCallback(streams) {\n if (!streams.length) return noop;\n if (typeof streams[streams.length - 1] !== 'function') return noop;\n return streams.pop();\n}\nfunction pipeline() {\n for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {\n streams[_key] = arguments[_key];\n }\n var callback = popCallback(streams);\n if (Array.isArray(streams[0])) streams = streams[0];\n if (streams.length < 2) {\n throw new ERR_MISSING_ARGS('streams');\n }\n var error;\n var destroys = streams.map(function (stream, i) {\n var reading = i < streams.length - 1;\n var writing = i > 0;\n return destroyer(stream, reading, writing, function (err) {\n if (!error) error = err;\n if (err) destroys.forEach(call);\n if (reading) return;\n destroys.forEach(call);\n callback(error);\n });\n });\n return streams.reduce(pipe);\n}\nmodule.exports = pipeline;","\"use strict\";\n// Copyright (c) 2018-2025, Brandon Lehmann <brandonlehmann@gmail.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Reader = void 0;\nconst varint_1 = __importDefault(require(\"./varint\"));\nconst big_integer_1 = __importDefault(require(\"big-integer\"));\nconst writer_1 = __importDefault(require(\"./writer\"));\nconst stream_1 = require(\"stream\");\nconst buffer_1 = require(\"buffer\");\nclass Reader extends stream_1.Writable {\n /**\n * Creates a new instance of the reader\n *\n * @param blob\n * @param encoding\n */\n constructor(blob = buffer_1.Buffer.alloc(0), encoding = 'hex') {\n super();\n this._current_offset = 0;\n this._buffer = buffer_1.Buffer.alloc(0);\n this.append(blob, encoding);\n }\n /**\n * Returns the current contents of the buffer\n */\n get buffer() {\n return this._buffer;\n }\n /**\n * Returns the byte size of the current buffer\n */\n get length() {\n return this._buffer.length;\n }\n /**\n * Returns the current read offset of the buffer\n */\n get offset() {\n return this._current_offset;\n }\n /**\n * Returns the number of unread bytes left in the buffer\n */\n get unreadBytes() {\n const unread = this.length - this.offset;\n return unread >= 0 ? unread : 0;\n }\n /**\n * Returns the unread portion of the buffer\n */\n get unreadBuffer() {\n return this.buffer.slice(this.offset);\n }\n /** @ignore */\n static readUIntBE(buffer, bytes, offset = 0, noAssert = false) {\n if (buffer.length < offset + bytes) {\n if (noAssert) {\n return big_integer_1.default.zero;\n }\n throw new RangeError('Out of bounds');\n }\n const slice = buffer.slice(offset, offset + bytes);\n return (0, big_integer_1.default)(slice.toString('hex'), 16);\n }\n /** @ignore */\n static readUIntLE(buffer, bytes, offset = 0, noAssert = false) {\n if (buffer.length < offset + bytes) {\n if (noAssert) {\n return big_integer_1.default.zero;\n }\n throw new RangeError('Out of bounds');\n }\n const buf = buffer.slice(offset, offset + bytes);\n const tempBuffer = buffer_1.Buffer.alloc(bytes);\n let position = bytes - 1;\n for (const slice of buf) {\n tempBuffer[position] = slice;\n position -= 1;\n }\n return (0, big_integer_1.default)(tempBuffer.toString('hex'), 16);\n }\n /** @ignore */\n _write(chunk, encoding, callback) {\n this.append(chunk);\n callback();\n }\n /**\n * Appends the supplied value to the end of the buffer\n *\n * @param blob\n * @param encoding\n */\n append(blob, encoding = 'hex') {\n let buffer;\n if (blob instanceof Reader || blob instanceof writer_1.default) {\n buffer = blob.buffer;\n }\n else if (blob instanceof buffer_1.Buffer) {\n buffer = blob;\n }\n else if (blob instanceof Uint8Array) {\n buffer = buffer_1.Buffer.from(blob);\n }\n else if (blob.length % 2 === 0) {\n buffer = buffer_1.Buffer.from(blob, encoding);\n }\n else {\n throw new Error('Unknown data type');\n }\n this._buffer = buffer_1.Buffer.concat([this._buffer, buffer]);\n }\n /**\n * Read the specified number of bytes from the buffer\n *\n * @param count\n */\n bytes(count = 1) {\n if (this.unreadBytes < count) {\n throw new RangeError(`Requested ${count} bytes but only ${this.unreadBytes} bytes remain`);\n }\n const start = this.offset;\n this._current_offset += count;\n return this._buffer.slice(start, this.offset);\n }\n /**\n * Compacts the current buffer by truncating up to the unread position of the buffer\n *\n * @param offset\n */\n compact(offset = this.offset) {\n this._buffer = this._buffer.slice(offset);\n this._current_offset = 0;\n }\n /**\n * Reads a hash from the buffer\n *\n * @param size\n * @param encoding\n */\n hash(size = 32, encoding = 'hex') {\n return this.bytes(size).toString(encoding);\n }\n /**\n * Reads the specified number of hex encoded bytes from the buffer\n *\n * @param count\n * @param encoding\n */\n hex(count = 1, encoding = 'hex') {\n return this.bytes(count).toString(encoding);\n }\n /**\n * Reads a signed integer from the buffer\n *\n * @param bits\n * @param bigEndian\n */\n signed_integer(bits, bigEndian = false) {\n if (bits % 8 !== 0) {\n throw new RangeError('bits must be a multiple of 8');\n }\n const bytes = bits / 8;\n const result = this.bytes(bytes);\n switch (bytes) {\n case 1:\n return (0, big_integer_1.default)(result.readInt8());\n case 2:\n return (0, big_integer_1.default)(bigEndian ? result.readInt16BE() : result.readInt16LE());\n case 4:\n return (0, big_integer_1.default)(bigEndian ? result.readInt32BE() : result.readInt32LE());\n case 8:\n return (0, big_integer_1.default)(bigEndian ? result.readBigInt64BE() : result.readBigInt64LE());\n default:\n throw new RangeError('Data type');\n }\n }\n /**\n * Reads an int8_t from the buffer\n */\n int8_t() {\n return this.signed_integer(8);\n }\n /**\n * Reads an int16_t from the buffer\n *\n * @param bigEndian\n */\n int16_t(bigEndian = false) {\n return this.signed_integer(16, bigEndian);\n }\n /**\n * Reads an int32_t from the buffer\n *\n * @param bigEndian\n */\n int32_t(bigEndian = false) {\n return this.signed_integer(32, bigEndian);\n }\n /**\n * Reads an int64_t from the buffer\n *\n * @param bigEndian\n */\n int64_t(bigEndian = false) {\n return this.signed_integer(64, bigEndian);\n }\n /**\n * Resets the current position of the buffer back to the beginning\n *\n * @param offset\n */\n reset(offset = 0) {\n this._current_offset = offset;\n }\n /**\n * Skips reading the specified number of bytes from the buffer\n *\n * @param count\n */\n skip(count = 1) {\n this._current_offset += count;\n }\n /**\n * Reads a string from the buffer\n *\n * @param encoding\n */\n string(encoding = 'utf-8') {\n const length = this.varint().toJSNumber();\n return this.bytes(length).toString(encoding);\n }\n /**\n * Reads a time_t from the buffer\n *\n * @param bigEndian\n */\n time_t(bigEndian = false) {\n const epoch = this.uint64_t(!bigEndian).toJSNumber();\n return new Date(epoch * 1000);\n }\n /**\n * Returns the current contents of the buffer as a string\n *\n * @param encoding\n */\n toString(encoding = 'hex') {\n return this._buffer.toString(encoding);\n }\n /**\n * Reads an unsigned integer from the buffer\n *\n * @param bits\n * @param bigEndian\n */\n unsigned_integer(bits, bigEndian = false) {\n if (bits % 8 !== 0) {\n throw new RangeError('bits must be a multiple of 8');\n }\n const bytes = bits / 8;\n return bigEndian\n ? Reader.readUIntBE(this.bytes(bytes), bytes)\n : Reader.readUIntLE(this.bytes(bytes), bytes);\n }\n /**\n * Reads an uint8_t from the buffer\n */\n uint8_t() {\n return this.unsigned_integer(8);\n }\n /**\n * Reads an uint16_t from the buffer\n *\n * @param bigEndian\n */\n uint16_t(bigEndian = false) {\n return this.unsigned_integer(16, bigEndian);\n }\n /**\n * Reads an uint32_t from the buffer\n *\n * @param bigEndian\n */\n uint32_t(bigEndian = false) {\n return this.unsigned_integer(32, bigEndian);\n }\n /**\n * Reads an uint64_t from the buffer\n *\n * @param bigEndian\n */\n uint64_t(bigEndian = false) {\n return this.unsigned_integer(64, bigEndian);\n }\n /**\n * Reads an uint128_t from the buffer\n *\n * @param bigEndian\n */\n uint128_t(bigEndian = false) {\n return this.unsigned_integer(128, bigEndian);\n }\n /**\n * Reads an uint256_t from the buffer\n *\n * @param bigEndian\n */\n uint256_t(bigEndian = false) {\n return this.unsigned_integer(256, bigEndian);\n }\n /**\n * Reads an uint512_t from the buffer\n *\n * @param bigEndian\n */\n uint512_t(bigEndian = false) {\n return this.unsigned_integer(512, bigEndian);\n }\n /**\n * Reads a Varint from the buffer\n *\n * @param peek\n * @param levin\n */\n varint(peek = false, levin = false) {\n const start = this._current_offset;\n if (!levin) {\n do {\n if (this.buffer.readUInt8(this._current_offset) < 128) {\n this._current_offset++;\n const tmp = this.buffer.slice(start, this.offset);\n if (peek) {\n this._current_offset = start;\n }\n return varint_1.default.decode(tmp);\n }\n this._current_offset++;\n } while (true);\n }\n else {\n let value = this.uint8_t().toJSNumber();\n const sizeMask = value & 0x03;\n value = (0, big_integer_1.default)(value);\n let bytesLeft = 0;\n switch (sizeMask) {\n case 0:\n bytesLeft = 0;\n break;\n case 1:\n bytesLeft = 1;\n break;\n case 2:\n bytesLeft = 3;\n break;\n case 3:\n bytesLeft = 7;\n break;\n }\n for (let i = 1; i <= bytesLeft; ++i) {\n const nv = this.uint8_t().shiftLeft(i * 8);\n value = value.or(nv);\n }\n return value.shiftRight(2);\n }\n }\n}\nexports.default = Reader;\nexports.Reader = Reader;\n//# sourceMappingURL=reader.js.map","/*! safe-buffer. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","'use strict';\n\n// undocumented cb() API, needed for core, not for public API\nfunction destroy(err, cb) {\n var _this = this;\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n process.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n process.nextTick(emitErrorNT, this, err);\n }\n }\n return this;\n }\n\n // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n }\n\n // if this is a duplex stream mark the writable part as destroyed as well\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n } else if (cb) {\n process.nextTick(emitCloseNT, _this);\n cb(err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n });\n return this;\n}\nfunction emitErrorAndCloseNT(self, err) {\n emitErrorNT(self, err);\n emitCloseNT(self);\n}\nfunction emitCloseNT(self) {\n if (self._writableState && !self._writableState.emitClose) return;\n if (self._readableState && !self._readableState.emitClose) return;\n self.emit('close');\n}\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\nfunction errorOrDestroy(stream, err) {\n // We have tests that rely on errors being emitted\n // in the same tick, so changing this is semver major.\n // For now when you opt-in to autoDestroy we allow\n // the error to be emitted nextTick. In a future\n // semver major update we should change the default to this.\n\n var rState = stream._readableState;\n var wState = stream._writableState;\n if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);\n}\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy,\n errorOrDestroy: errorOrDestroy\n};","'use strict';\n\nvar _Object$setPrototypeO;\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nvar finished = require('./end-of-stream');\nvar kLastResolve = Symbol('lastResolve');\nvar kLastReject = Symbol('lastReject');\nvar kError = Symbol('error');\nvar kEnded = Symbol('ended');\nvar kLastPromise = Symbol('lastPromise');\nvar kHandlePromise = Symbol('handlePromise');\nvar kStream = Symbol('stream');\nfunction createIterResult(value, done) {\n return {\n value: value,\n done: done\n };\n}\nfunction readAndResolve(iter) {\n var resolve = iter[kLastResolve];\n if (resolve !== null) {\n var data = iter[kStream].read();\n // we defer if data is null\n // we can be expecting either 'end' or\n // 'error'\n if (data !== null) {\n iter[kLastPromise] = null;\n iter[kLastResolve] = null;\n iter[kLastReject] = null;\n resolve(createIterResult(data, false));\n }\n }\n}\nfunction onReadable(iter) {\n // we wait for the next tick, because it might\n // emit an error with process.nextTick\n process.nextTick(readAndResolve, iter);\n}\nfunction wrapForNext(lastPromise, iter) {\n return function (resolve, reject) {\n lastPromise.then(function () {\n if (iter[kEnded]) {\n resolve(createIterResult(undefined, true));\n return;\n }\n iter[kHandlePromise](resolve, reject);\n }, reject);\n };\n}\nvar AsyncIteratorPrototype = Object.getPrototypeOf(function () {});\nvar ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {\n get stream() {\n return this[kStream];\n },\n next: function next() {\n var _this = this;\n // if we have detected an error in the meanwhile\n // reject straight away\n var error = this[kError];\n if (error !== null) {\n return Promise.reject(error);\n }\n if (this[kEnded]) {\n return Promise.resolve(createIterResult(undefined, true));\n }\n if (this[kStream].destroyed) {\n // We need to defer via nextTick because if .destroy(err) is\n // called, the error will be emitted via nextTick, and\n // we cannot guarantee that there is no error lingering around\n // waiting to be emitted.\n return new Promise(function (resolve, reject) {\n process.nextTick(function () {\n if (_this[kError]) {\n reject(_this[kError]);\n } else {\n resolve(createIterResult(undefined, true));\n }\n });\n });\n }\n\n // if we have multiple next() calls\n // we will wait for the previous Promise to finish\n // this logic is optimized to support for await loops,\n // where next() is only called once at a time\n var lastPromise = this[kLastPromise];\n var promise;\n if (lastPromise) {\n promise = new Promise(wrapForNext(lastPromise, this));\n } else {\n // fast path needed to support multiple this.push()\n // without triggering the next() queue\n var data = this[kStream].read();\n if (data !== null) {\n return Promise.resolve(createIterResult(data, false));\n }\n promise = new Promise(this[kHandlePromise]);\n }\n this[kLastPromise] = promise;\n return promise;\n }\n}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {\n return this;\n}), _defineProperty(_Object$setPrototypeO, \"return\", function _return() {\n var _this2 = this;\n // destroy(err, cb) is a private API\n // we can guarantee we have that here, because we control the\n // Readable class this is attached to\n return new Promise(function (resolve, reject) {\n _this2[kStream].destroy(null, function (err) {\n if (err) {\n reject(err);\n return;\n }\n resolve(createIterResult(undefined, true));\n });\n });\n}), _Object$setPrototypeO), AsyncIteratorPrototype);\nvar createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {\n var _Object$create;\n var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {\n value: stream,\n writable: true\n }), _defineProperty(_Object$create, kLastResolve, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kLastReject, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kError, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kEnded, {\n value: stream._readableState.endEmitted,\n writable: true\n }), _defineProperty(_Object$create, kHandlePromise, {\n value: function value(resolve, reject) {\n var data = iterator[kStream].read();\n if (data) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(data, false));\n } else {\n iterator[kLastResolve] = resolve;\n iterator[kLastReject] = reject;\n }\n },\n writable: true\n }), _Object$create));\n iterator[kLastPromise] = null;\n finished(stream, function (err) {\n if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {\n var reject = iterator[kLastReject];\n // reject if we are waiting for data in the Promise\n // returned by next() and store the error\n if (reject !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n reject(err);\n }\n iterator[kError] = err;\n return;\n }\n var resolve = iterator[kLastResolve];\n if (resolve !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(undefined, true));\n }\n iterator[kEnded] = true;\n });\n stream.on('readable', onReadable.bind(null, iterator));\n return iterator;\n};\nmodule.exports = createReadableStreamAsyncIterator;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.nmd = (module) => {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(156);\n"],"names":["root","factory","exports","module","define","amd","a","i","self","ReflectOwnKeys","R","Reflect","ReflectApply","apply","target","receiver","args","Function","prototype","call","ownKeys","Object","getOwnPropertySymbols","getOwnPropertyNames","concat","NumberIsNaN","Number","isNaN","value","EventEmitter","init","this","once","emitter","name","Promise","resolve","reject","errorListener","err","removeListener","resolver","slice","arguments","eventTargetAgnosticAddListener","handler","on","addErrorHandlerIfEventEmitter","_events","undefined","_eventsCount","_maxListeners","defaultMaxListeners","checkListener","listener","TypeError","_getMaxListeners","that","_addListener","type","prepend","m","events","existing","warning","create","newListener","emit","unshift","push","length","warned","w","Error","String","count","console","warn","onceWrapper","fired","wrapFn","_onceWrap","state","wrapped","bind","_listeners","unwrap","evlistener","arr","ret","Array","unwrapListeners","arrayClone","listenerCount","n","copy","flags","addEventListener","wrapListener","arg","removeEventListener","defineProperty","enumerable","get","set","RangeError","getPrototypeOf","setMaxListeners","getMaxListeners","doError","error","er","message","context","len","listeners","addListener","prependListener","prependOnceListener","list","position","originalListener","shift","index","pop","spliceOne","off","removeAllListeners","key","keys","rawListeners","eventNames","__importDefault","mod","__esModule","Buffer","BigInteger","Varint","Writer","Reader","reader_1","writer_1","varint_1","big_integer_1","default","buffer_1","codes","createErrorType","code","Base","NodeError","_Base","subClass","superClass","arg1","arg2","arg3","getMessage","constructor","__proto__","oneOf","expected","thing","isArray","map","join","actual","determiner","search","msg","str","start","substr","replace","this_len","substring","endsWith","indexOf","BASE","MAX_INT","MAX_INT_ARR","smallToArray","DEFAULT_ALPHABET","supportsNativeBigInt","BigInt","Integer","v","radix","alphabet","caseSensitive","parseValue","parseBase","sign","isSmall","SmallInteger","NativeBigInt","isPrecise","Math","floor","arrayToSmall","trim","compareAbs","createArray","x","truncate","ceil","add","b","sum","l_a","l_b","r","carry","base","addAny","addSmall","l","subtract","difference","a_l","b_l","borrow","subtractSmall","multiplyLong","product","a_i","j","multiplySmall","shiftLeft","multiplyKaratsuba","y","max","d","c","ac","bd","abcd","multiplySmallAndArray","square","divModSmall","lambda","q","remainder","divisor","quotient","divModAny","negate","abs","comparison","quotientDigit","result","divisorMostSignificantDigit","divMod1","guess","xlen","highx","highy","check","part","reverse","divMod2","qSign","mSign","isBasicPrime","isUnit","equals","isEven","isDivisibleBy","lesser","millerRabinTest","nPrev","prev","divide","next","bigInt","modPow","plus","subtractAny","minus","small","multiply","l1","l2","times","_multiplyBySmall","divmod","over","pow","toString","_0","_1","_2","isNegative","exp","isZero","modInv","isPositive","isOdd","compare","Infinity","compareTo","eq","notEquals","neq","greater","gt","lt","greaterOrEquals","geq","lesserOrEquals","leq","isPrime","strict","bits","bitLength","logN","log","toJSNumber","t","isProbablePrime","iterations","rng","randBetween","lastT","lastR","zero","newT","one","newR","powersOfTwo","powers2Length","highestPower2","shift_isSmall","bitwise","fn","xSign","ySign","xRem","not","yRem","xDigit","yDigit","xDivMod","yDivMod","shiftRight","remQuo","and","or","xor","LOBMASK_I","roughLOB","integerLogarithm","tmp","p","e","min","gcd","text","toLowerCase","absBase","alphabetValues","digits","parseBaseFromArray","val","toBase","valueOf","neg","out","left","digit","toBaseString","stringify","parseStringValue","split","decimalPlace","test","parseNumberValue","toArray","toJSON","parseInt","minusOne","lcm","isInstance","usedRNG","random","low","range","restricted","top","fromArray","hasOwnProperty","isEncoding","encoding","StringDecoder","nb","enc","nenc","retried","_normalizeEncoding","normalizeEncoding","utf16Text","end","utf16End","fillLast","utf8FillLast","base64Text","base64End","write","simpleWrite","simpleEnd","lastNeed","lastTotal","lastChar","allocUnsafe","utf8CheckByte","byte","buf","utf8CheckExtraBytes","charCodeAt","total","utf8CheckIncomplete","decode","buffer","counter","encode","offset","from","Base58","encoded","base58_to_binary","data","binary_to_base58","ERR_STREAM_PREMATURE_CLOSE","noop","eos","stream","opts","callback","called","_len","_key","readable","writable","onlegacyfinish","onfinish","writableEnded","_writableState","finished","readableEnded","_readableState","endEmitted","onend","onerror","onclose","ended","onrequest","req","setHeader","abort","isRequest","read","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","s","NaN","rt","LN2","base64","ieee754","customInspectSymbol","Symbol","SlowBuffer","alloc","INSPECT_MAX_BYTES","K_MAX_LENGTH","createBuffer","Uint8Array","setPrototypeOf","encodingOrOffset","string","byteLength","fromString","ArrayBuffer","isView","arrayView","fromArrayBuffer","byteOffset","fromArrayLike","fromArrayView","SharedArrayBuffer","obj","isBuffer","checked","numberIsNaN","fromObject","toPrimitive","assertSize","size","array","mustMatch","loweredCase","utf8ToBytes","base64ToBytes","slowToString","hexSlice","utf8Slice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","bidirectionalIndexOf","dir","arrayIndexOf","lastIndexOf","indexSize","arrLength","valLength","readUInt16BE","foundIndex","found","hexWrite","remaining","strLen","parsed","utf8Write","blitBuffer","asciiWrite","byteArray","asciiToBytes","base64Write","ucs2Write","units","hi","lo","utf16leToBytes","fromByteArray","res","firstByte","codePoint","bytesPerSequence","secondByte","thirdByte","fourthByte","tempCodePoint","codePoints","MAX_ARGUMENTS_LENGTH","fromCharCode","decodeCodePointsArray","kMaxLength","TYPED_ARRAY_SUPPORT","proto","foo","typedArraySupport","poolSize","fill","allocUnsafeSlow","_isBuffer","pos","swap16","swap32","swap64","toLocaleString","inspect","thisStart","thisEnd","thisCopy","targetCopy","includes","isFinite","_arr","hexSliceLookupTable","bytes","checkOffset","ext","checkInt","wrtBigUInt64LE","checkIntBI","wrtBigUInt64BE","checkIEEE754","writeFloat","littleEndian","noAssert","writeDouble","newBuf","subarray","readUintLE","readUIntLE","mul","readUintBE","readUIntBE","readUint8","readUInt8","readUint16LE","readUInt16LE","readUint16BE","readUint32LE","readUInt32LE","readUint32BE","readUInt32BE","readBigUInt64LE","defineBigIntMethod","validateNumber","first","last","boundsError","readBigUInt64BE","readIntLE","readIntBE","readInt8","readInt16LE","readInt16BE","readInt32LE","readInt32BE","readBigInt64LE","readBigInt64BE","readFloatLE","readFloatBE","readDoubleLE","readDoubleBE","writeUintLE","writeUIntLE","writeUintBE","writeUIntBE","writeUint8","writeUInt8","writeUint16LE","writeUInt16LE","writeUint16BE","writeUInt16BE","writeUint32LE","writeUInt32LE","writeUint32BE","writeUInt32BE","writeBigUInt64LE","writeBigUInt64BE","writeIntLE","limit","sub","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","writeBigInt64LE","writeBigInt64BE","writeFloatLE","writeFloatBE","writeDoubleLE","writeDoubleBE","targetStart","copyWithin","errors","E","sym","super","configurable","stack","addNumericalSeparator","ERR_OUT_OF_RANGE","checkBounds","ERR_INVALID_ARG_TYPE","ERR_BUFFER_OUT_OF_BOUNDS","input","received","isInteger","INVALID_BASE64_RE","leadSurrogate","toByteArray","base64clean","src","dst","table","i16","BufferBigIntNotDefined","ERR_INVALID_OPT_VALUE","getHighWaterMark","options","duplexKey","isDuplex","hwm","highWaterMark","highWaterMarkFrom","objectMode","stream_1","Readable","payload","_buffer","_readIndex","append","readIndex","determineBits","hex","padStart","tempBuffer","_read","okToSend","clear","hash","signed_integer","bigEndian","int8_t","int16_t","int32_t","int64_t","varint","time_t","num","getTime","uint64_t","unsigned_integer","uint8_t","uint16_t","uint32_t","uint128_t","uint256_t","uint512_t","levin","tempValue","byteCount","Stream","EE","inherits","Writable","Duplex","Transform","PassThrough","pipeline","pipe","dest","source","ondata","chunk","pause","ondrain","resume","_isStdio","didOnEnd","destroy","cleanup","base58_chars","base58Map","base58M","create_base58_map","base58String","match","lz","psz","base58_match","psz_Uint","base58_temp","lastValue","reduce","acc","filter","uint8array","objectKeys","method","allowHalfOpen","process","nextTick","onEndNT","getBuffer","destroyed","ReadableState","debug","EElistenerCount","OurUint8Array","g","window","debugUtil","debuglog","createReadableStreamAsyncIterator","BufferList","destroyImpl","_require$codes","ERR_STREAM_PUSH_AFTER_EOF","ERR_METHOD_NOT_IMPLEMENTED","ERR_STREAM_UNSHIFT_AFTER_END_EVENT","errorOrDestroy","kProxyEvents","readableObjectMode","pipes","pipesCount","flowing","reading","sync","needReadable","emittedReadable","readableListening","resumeScheduled","paused","emitClose","autoDestroy","defaultEncoding","awaitDrain","readingMore","decoder","_destroy","readableAddChunk","addToFront","skipChunkCheck","emitReadable","emitReadable_","onEofChunk","chunkInvalid","_uint8ArrayToBuffer","addChunk","maybeReadMore","_undestroy","undestroy","cb","isPaused","setEncoding","head","content","MAX_HWM","howMuchToRead","computeNewHighWaterMark","flow","maybeReadMore_","updateReadableListening","nReadingNextTick","resume_","fromList","consume","endReadable","endReadableNT","wState","xs","nOrig","doRead","pipeOpts","endFn","stdout","stderr","unpipe","onunpipe","unpipeInfo","hasUnpiped","cleanedUp","needDrain","pipeOnDrain","event","dests","splice","ev","wrap","_this","asyncIterator","_fromList","iterable","b64","lens","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","parts","maxChunkLength","len2","encodeChunk","lookup","output","_transform","ERR_MULTIPLE_CALLBACK","ERR_TRANSFORM_ALREADY_TRANSFORMING","ERR_TRANSFORM_WITH_LENGTH_0","afterTransform","ts","_transformState","transforming","writecb","writechunk","rs","needTransform","writeencoding","transform","flush","_flush","prefinish","done","_write","err2","config","localStorage","_","trace","ctor","superCtor","super_","TempCtor","ALPHABET","char","ENCODED_BLOCK_SIZES","FULL_ENCODED_BLOCK_SIZE","UINT64_MAX","CryptoNoteBase58","cn_decode","fullBlockCount","lastBlockSize","lastBlockDecodedSize","decodeBlock","cn_encode","_data","resSize","encodeBlock","resNum","order","div","CorkedRequest","entry","finish","corkReq","pendingcb","onCorkedFinish","corkedRequestsFree","WritableState","realHasInstance","internalUtil","deprecate","ERR_STREAM_CANNOT_PIPE","ERR_STREAM_DESTROYED","ERR_STREAM_NULL_VALUES","ERR_STREAM_WRITE_AFTER_END","ERR_UNKNOWN_ENCODING","nop","writableObjectMode","finalCalled","ending","noDecode","decodeStrings","writing","corked","bufferProcessing","onwrite","writelen","onwriteStateUpdate","finishMaybe","errorEmitted","onwriteError","needFinish","bufferedRequest","clearBuffer","afterWrite","lastBufferedRequest","prefinished","bufferedRequestCount","writev","_writev","final","_final","doWrite","onwriteDrain","holder","allBuffers","isBuf","callFinal","need","rState","current","hasInstance","object","writeAfterEnd","validChunk","newChunk","decodeChunk","writeOrBuffer","cork","uncork","setDefaultEncoding","endWritable","enumerableOnly","symbols","getOwnPropertyDescriptor","_objectSpread","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","_toPropertyKey","_defineProperties","props","descriptor","prim","hint","_toPrimitive","custom","instance","Constructor","_classCallCheck","tail","protoProps","hasStrings","_getString","_getBuffer","depth","customInspect","ERR_MISSING_ARGS","to","streams","popCallback","destroys","closed","destroyer","blob","_current_offset","unreadBytes","unread","unreadBuffer","compact","reset","skip","epoch","Date","peek","sizeMask","bytesLeft","nv","copyProps","SafeBuffer","emitErrorAndCloseNT","emitErrorNT","emitCloseNT","readableDestroyed","writableDestroyed","_Object$setPrototypeO","kLastResolve","kLastReject","kError","kEnded","kLastPromise","kHandlePromise","kStream","createIterResult","readAndResolve","iter","onReadable","AsyncIteratorPrototype","ReadableStreamAsyncIteratorPrototype","promise","lastPromise","then","wrapForNext","_this2","_Object$create","iterator","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","id","loaded","__webpack_modules__","globalThis","nmd","paths","children"],"ignoreList":[],"sourceRoot":""}