isomorphic-git 1.33.0 → 1.33.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.
- package/browser-tests.json +6 -3
- package/index.cjs +2 -2
- package/index.js +2 -2
- package/index.umd.min.js +6 -2
- package/index.umd.min.js.map +1 -1
- package/managers/index.umd.min.js +6 -2
- package/managers/index.umd.min.js.map +1 -1
- package/models/index.umd.min.js +2 -2
- package/models/index.umd.min.js.map +1 -1
- package/package.json +2 -2
- package/size_report.html +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["webpack://git/webpack/universalModuleDefinition","webpack://git/webpack/bootstrap","webpack://git/./node_modules/path-browserify/index.js","webpack://git/./src/utils/types.js","webpack://git/(webpack)/buildin/global.js","webpack://git/./node_modules/node-libs-browser/node_modules/base64-js/index.js","webpack://git/./node_modules/ieee754/index.js","webpack://git/./node_modules/isarray/index.js","webpack://git/./src/models/index.js","webpack://git/./src/utils/dirname.js","webpack://git/./src/utils/compareStrings.js","webpack://git/./src/models/FileSystem.js","webpack://git/./node_modules/process/browser.js","webpack://git/./node_modules/pify/index.js","webpack://git/./node_modules/node-libs-browser/node_modules/buffer/index.js","webpack://git/./src/utils/rmRecursive.js"],"names":["root","factory","exports","module","define","amd","self","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","assertPath","path","TypeError","JSON","stringify","normalizeStringPosix","allowAboveRoot","code","res","lastSegmentLength","lastSlash","dots","length","charCodeAt","lastSlashIndex","lastIndexOf","slice","posix","resolve","cwd","resolvedPath","resolvedAbsolute","arguments","undefined","process","normalize","isAbsolute","trailingSeparator","join","joined","arg","relative","from","to","fromStart","fromEnd","fromLen","toStart","toLen","lastCommonSep","fromCode","out","_makeLong","dirname","hasRoot","end","matchedSlash","basename","ext","start","extIdx","firstNonSlashEnd","extname","startDot","startPart","preDotState","format","pathObject","sep","dir","base","_format","parse","ret","delimiter","win32","isPromiseLike","obj","isObject","isFunction","then","catch","g","this","Function","e","window","byteLength","b64","lens","getLens","validLen","placeHoldersLen","toByteArray","tmp","arr","Arr","_byteLength","curByte","len","revLookup","fromByteArray","uint8","extraBytes","parts","len2","push","encodeChunk","lookup","Uint8Array","Array","Error","indexOf","num","output","read","buffer","offset","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","NaN","Infinity","Math","pow","write","rt","abs","isNaN","floor","log","LN2","toString","isArray","last","max","compareStrings","a","b","isPromiseFs","fs","targetFs","readFile","test","commands","bindFs","target","command","pify","rm","_rm","rmdir","rmRecursive","FileSystem","constructor","_original_unwrapped_fs","promises","getOwnPropertyDescriptor","exists","filepath","options","_stat","err","includes","console","_readFile","autocrlf","TextDecoder","fatal","decode","replace","TextEncoder","encode","error","Buffer","contents","_writeFile","mkdir","_selfCall","_mkdir","parent","_unlink","opts","recursive","_rmdir","readdir","names","_readdir","sort","readdirDeep","subdirs","Promise","all","map","subdir","isDirectory","reduce","f","concat","lstat","filename","_lstat","readlink","encoding","link","_readlink","isBuffer","writelink","_symlink","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","setTimeout","clearTimeout","currentQueue","queue","draining","queueIndex","cleanUpNextTick","drainQueue","timeout","run","marker","runClearTimeout","Item","array","noop","nextTick","args","apply","title","browser","env","argv","version","versions","on","addListener","once","off","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","binding","chdir","umask","processFn","fn","P","promiseModule","reject","multiArgs","result","errorFirst","shift","input","assign","exclude","objType","filter","match","pattern","include","some","excludeMain","getPrototypeOf","base64","ieee754","kMaxLength","TYPED_ARRAY_SUPPORT","createBuffer","that","RangeError","__proto__","encodingOrOffset","allocUnsafe","ArrayBuffer","byteOffset","fromArrayLike","fromArrayBuffer","string","isEncoding","actual","fromString","checked","copy","val","type","data","fromObject","assertSize","size","isView","loweredCase","utf8ToBytes","base64ToBytes","toLowerCase","slowToString","hexSlice","utf8Slice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","bidirectionalIndexOf","arrayIndexOf","indexSize","arrLength","valLength","String","buf","readUInt16BE","foundIndex","found","j","hexWrite","Number","remaining","strLen","parsed","parseInt","substr","utf8Write","blitBuffer","asciiWrite","str","byteArray","asciiToBytes","latin1Write","base64Write","ucs2Write","units","hi","lo","utf16leToBytes","min","secondByte","thirdByte","fourthByte","tempCodePoint","firstByte","codePoint","bytesPerSequence","codePoints","fromCharCode","decodeCodePointsArray","SlowBuffer","alloc","INSPECT_MAX_BYTES","global","foo","subarray","typedArraySupport","poolSize","_augment","species","configurable","fill","allocUnsafeSlow","_isBuffer","compare","x","y","list","pos","swap16","swap32","swap64","equals","inspect","thisStart","thisEnd","thisCopy","targetCopy","isFinite","toJSON","_arr","toHex","bytes","checkOffset","checkInt","objectWriteUInt16","littleEndian","objectWriteUInt32","checkIEEE754","writeFloat","noAssert","writeDouble","newBuf","sliceLen","readUIntLE","mul","readUIntBE","readUInt8","readUInt16LE","readUInt32LE","readUInt32BE","readIntLE","readIntBE","readInt8","readInt16LE","readInt16BE","readInt32LE","readInt32BE","readFloatLE","readFloatBE","readDoubleLE","readDoubleBE","writeUIntLE","writeUIntBE","writeUInt8","writeUInt16LE","writeUInt16BE","writeUInt32LE","writeUInt32BE","writeIntLE","limit","sub","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","writeFloatLE","writeFloatBE","writeDoubleLE","writeDoubleBE","targetStart","set","INVALID_BASE64_RE","leadSurrogate","trim","stringtrim","base64clean","src","dst","entries","entry","subpath","stat"],"mappings":"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","file":"models/index.umd.min.js","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 if(typeof exports === 'object')\n\t\texports[\"git\"] = factory();\n\telse\n\t\troot[\"git\"] = factory();\n})(self, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 174);\n","// 'path' module extracted from Node.js v8.11.1 (only the posix part)\n// transplited with Babel\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\nfunction assertPath(path) {\n if (typeof path !== 'string') {\n throw new TypeError('Path must be a string. Received ' + JSON.stringify(path));\n }\n}\n\n// Resolves . and .. elements in a path with directory names\nfunction normalizeStringPosix(path, allowAboveRoot) {\n var res = '';\n var lastSegmentLength = 0;\n var lastSlash = -1;\n var dots = 0;\n var code;\n for (var i = 0; i <= path.length; ++i) {\n if (i < path.length)\n code = path.charCodeAt(i);\n else if (code === 47 /*/*/)\n break;\n else\n code = 47 /*/*/;\n if (code === 47 /*/*/) {\n if (lastSlash === i - 1 || dots === 1) {\n // NOOP\n } else if (lastSlash !== i - 1 && dots === 2) {\n if (res.length < 2 || lastSegmentLength !== 2 || res.charCodeAt(res.length - 1) !== 46 /*.*/ || res.charCodeAt(res.length - 2) !== 46 /*.*/) {\n if (res.length > 2) {\n var lastSlashIndex = res.lastIndexOf('/');\n if (lastSlashIndex !== res.length - 1) {\n if (lastSlashIndex === -1) {\n res = '';\n lastSegmentLength = 0;\n } else {\n res = res.slice(0, lastSlashIndex);\n lastSegmentLength = res.length - 1 - res.lastIndexOf('/');\n }\n lastSlash = i;\n dots = 0;\n continue;\n }\n } else if (res.length === 2 || res.length === 1) {\n res = '';\n lastSegmentLength = 0;\n lastSlash = i;\n dots = 0;\n continue;\n }\n }\n if (allowAboveRoot) {\n if (res.length > 0)\n res += '/..';\n else\n res = '..';\n lastSegmentLength = 2;\n }\n } else {\n if (res.length > 0)\n res += '/' + path.slice(lastSlash + 1, i);\n else\n res = path.slice(lastSlash + 1, i);\n lastSegmentLength = i - lastSlash - 1;\n }\n lastSlash = i;\n dots = 0;\n } else if (code === 46 /*.*/ && dots !== -1) {\n ++dots;\n } else {\n dots = -1;\n }\n }\n return res;\n}\n\nfunction _format(sep, pathObject) {\n var dir = pathObject.dir || pathObject.root;\n var base = pathObject.base || (pathObject.name || '') + (pathObject.ext || '');\n if (!dir) {\n return base;\n }\n if (dir === pathObject.root) {\n return dir + base;\n }\n return dir + sep + base;\n}\n\nvar posix = {\n // path.resolve([from ...], to)\n resolve: function resolve() {\n var resolvedPath = '';\n var resolvedAbsolute = false;\n var cwd;\n\n for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n var path;\n if (i >= 0)\n path = arguments[i];\n else {\n if (cwd === undefined)\n cwd = process.cwd();\n path = cwd;\n }\n\n assertPath(path);\n\n // Skip empty entries\n if (path.length === 0) {\n continue;\n }\n\n resolvedPath = path + '/' + resolvedPath;\n resolvedAbsolute = path.charCodeAt(0) === 47 /*/*/;\n }\n\n // At this point the path should be resolved to a full absolute path, but\n // handle relative paths to be safe (might happen when process.cwd() fails)\n\n // Normalize the path\n resolvedPath = normalizeStringPosix(resolvedPath, !resolvedAbsolute);\n\n if (resolvedAbsolute) {\n if (resolvedPath.length > 0)\n return '/' + resolvedPath;\n else\n return '/';\n } else if (resolvedPath.length > 0) {\n return resolvedPath;\n } else {\n return '.';\n }\n },\n\n normalize: function normalize(path) {\n assertPath(path);\n\n if (path.length === 0) return '.';\n\n var isAbsolute = path.charCodeAt(0) === 47 /*/*/;\n var trailingSeparator = path.charCodeAt(path.length - 1) === 47 /*/*/;\n\n // Normalize the path\n path = normalizeStringPosix(path, !isAbsolute);\n\n if (path.length === 0 && !isAbsolute) path = '.';\n if (path.length > 0 && trailingSeparator) path += '/';\n\n if (isAbsolute) return '/' + path;\n return path;\n },\n\n isAbsolute: function isAbsolute(path) {\n assertPath(path);\n return path.length > 0 && path.charCodeAt(0) === 47 /*/*/;\n },\n\n join: function join() {\n if (arguments.length === 0)\n return '.';\n var joined;\n for (var i = 0; i < arguments.length; ++i) {\n var arg = arguments[i];\n assertPath(arg);\n if (arg.length > 0) {\n if (joined === undefined)\n joined = arg;\n else\n joined += '/' + arg;\n }\n }\n if (joined === undefined)\n return '.';\n return posix.normalize(joined);\n },\n\n relative: function relative(from, to) {\n assertPath(from);\n assertPath(to);\n\n if (from === to) return '';\n\n from = posix.resolve(from);\n to = posix.resolve(to);\n\n if (from === to) return '';\n\n // Trim any leading backslashes\n var fromStart = 1;\n for (; fromStart < from.length; ++fromStart) {\n if (from.charCodeAt(fromStart) !== 47 /*/*/)\n break;\n }\n var fromEnd = from.length;\n var fromLen = fromEnd - fromStart;\n\n // Trim any leading backslashes\n var toStart = 1;\n for (; toStart < to.length; ++toStart) {\n if (to.charCodeAt(toStart) !== 47 /*/*/)\n break;\n }\n var toEnd = to.length;\n var toLen = toEnd - toStart;\n\n // Compare paths to find the longest common path from root\n var length = fromLen < toLen ? fromLen : toLen;\n var lastCommonSep = -1;\n var i = 0;\n for (; i <= length; ++i) {\n if (i === length) {\n if (toLen > length) {\n if (to.charCodeAt(toStart + i) === 47 /*/*/) {\n // We get here if `from` is the exact base path for `to`.\n // For example: from='/foo/bar'; to='/foo/bar/baz'\n return to.slice(toStart + i + 1);\n } else if (i === 0) {\n // We get here if `from` is the root\n // For example: from='/'; to='/foo'\n return to.slice(toStart + i);\n }\n } else if (fromLen > length) {\n if (from.charCodeAt(fromStart + i) === 47 /*/*/) {\n // We get here if `to` is the exact base path for `from`.\n // For example: from='/foo/bar/baz'; to='/foo/bar'\n lastCommonSep = i;\n } else if (i === 0) {\n // We get here if `to` is the root.\n // For example: from='/foo'; to='/'\n lastCommonSep = 0;\n }\n }\n break;\n }\n var fromCode = from.charCodeAt(fromStart + i);\n var toCode = to.charCodeAt(toStart + i);\n if (fromCode !== toCode)\n break;\n else if (fromCode === 47 /*/*/)\n lastCommonSep = i;\n }\n\n var out = '';\n // Generate the relative path based on the path difference between `to`\n // and `from`\n for (i = fromStart + lastCommonSep + 1; i <= fromEnd; ++i) {\n if (i === fromEnd || from.charCodeAt(i) === 47 /*/*/) {\n if (out.length === 0)\n out += '..';\n else\n out += '/..';\n }\n }\n\n // Lastly, append the rest of the destination (`to`) path that comes after\n // the common path parts\n if (out.length > 0)\n return out + to.slice(toStart + lastCommonSep);\n else {\n toStart += lastCommonSep;\n if (to.charCodeAt(toStart) === 47 /*/*/)\n ++toStart;\n return to.slice(toStart);\n }\n },\n\n _makeLong: function _makeLong(path) {\n return path;\n },\n\n dirname: function dirname(path) {\n assertPath(path);\n if (path.length === 0) return '.';\n var code = path.charCodeAt(0);\n var hasRoot = code === 47 /*/*/;\n var end = -1;\n var matchedSlash = true;\n for (var i = path.length - 1; i >= 1; --i) {\n code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n if (!matchedSlash) {\n end = i;\n break;\n }\n } else {\n // We saw the first non-path separator\n matchedSlash = false;\n }\n }\n\n if (end === -1) return hasRoot ? '/' : '.';\n if (hasRoot && end === 1) return '//';\n return path.slice(0, end);\n },\n\n basename: function basename(path, ext) {\n if (ext !== undefined && typeof ext !== 'string') throw new TypeError('\"ext\" argument must be a string');\n assertPath(path);\n\n var start = 0;\n var end = -1;\n var matchedSlash = true;\n var i;\n\n if (ext !== undefined && ext.length > 0 && ext.length <= path.length) {\n if (ext.length === path.length && ext === path) return '';\n var extIdx = ext.length - 1;\n var firstNonSlashEnd = -1;\n for (i = path.length - 1; i >= 0; --i) {\n var code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n } else {\n if (firstNonSlashEnd === -1) {\n // We saw the first non-path separator, remember this index in case\n // we need it if the extension ends up not matching\n matchedSlash = false;\n firstNonSlashEnd = i + 1;\n }\n if (extIdx >= 0) {\n // Try to match the explicit extension\n if (code === ext.charCodeAt(extIdx)) {\n if (--extIdx === -1) {\n // We matched the extension, so mark this as the end of our path\n // component\n end = i;\n }\n } else {\n // Extension does not match, so our result is the entire path\n // component\n extIdx = -1;\n end = firstNonSlashEnd;\n }\n }\n }\n }\n\n if (start === end) end = firstNonSlashEnd;else if (end === -1) end = path.length;\n return path.slice(start, end);\n } else {\n for (i = path.length - 1; i >= 0; --i) {\n if (path.charCodeAt(i) === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n } else if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // path component\n matchedSlash = false;\n end = i + 1;\n }\n }\n\n if (end === -1) return '';\n return path.slice(start, end);\n }\n },\n\n extname: function extname(path) {\n assertPath(path);\n var startDot = -1;\n var startPart = 0;\n var end = -1;\n var matchedSlash = true;\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n var preDotState = 0;\n for (var i = path.length - 1; i >= 0; --i) {\n var code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === 46 /*.*/) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1)\n startDot = i;\n else if (preDotState !== 1)\n preDotState = 1;\n } else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n\n if (startDot === -1 || end === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {\n return '';\n }\n return path.slice(startDot, end);\n },\n\n format: function format(pathObject) {\n if (pathObject === null || typeof pathObject !== 'object') {\n throw new TypeError('The \"pathObject\" argument must be of type Object. Received type ' + typeof pathObject);\n }\n return _format('/', pathObject);\n },\n\n parse: function parse(path) {\n assertPath(path);\n\n var ret = { root: '', dir: '', base: '', ext: '', name: '' };\n if (path.length === 0) return ret;\n var code = path.charCodeAt(0);\n var isAbsolute = code === 47 /*/*/;\n var start;\n if (isAbsolute) {\n ret.root = '/';\n start = 1;\n } else {\n start = 0;\n }\n var startDot = -1;\n var startPart = 0;\n var end = -1;\n var matchedSlash = true;\n var i = path.length - 1;\n\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n var preDotState = 0;\n\n // Get non-dir info\n for (; i >= start; --i) {\n code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === 46 /*.*/) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1) startDot = i;else if (preDotState !== 1) preDotState = 1;\n } else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n\n if (startDot === -1 || end === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {\n if (end !== -1) {\n if (startPart === 0 && isAbsolute) ret.base = ret.name = path.slice(1, end);else ret.base = ret.name = path.slice(startPart, end);\n }\n } else {\n if (startPart === 0 && isAbsolute) {\n ret.name = path.slice(1, startDot);\n ret.base = path.slice(1, end);\n } else {\n ret.name = path.slice(startPart, startDot);\n ret.base = path.slice(startPart, end);\n }\n ret.ext = path.slice(startDot, end);\n }\n\n if (startPart > 0) ret.dir = path.slice(0, startPart - 1);else if (isAbsolute) ret.dir = '/';\n\n return ret;\n },\n\n sep: '/',\n delimiter: ':',\n win32: null,\n posix: null\n};\n\nposix.posix = posix;\n\nmodule.exports = posix;\n","export function isPromiseLike(obj) {\n return isObject(obj) && isFunction(obj.then) && isFunction(obj.catch)\n}\n\nexport function isObject(obj) {\n return obj && typeof obj === 'object'\n}\n\nexport function isFunction(obj) {\n return typeof obj === 'function'\n}\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","'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(\n uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)\n ))\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","exports.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","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","export { FileSystem } from './FileSystem'\n","export function dirname(path) {\n const last = Math.max(path.lastIndexOf('/'), path.lastIndexOf('\\\\'))\n if (last === -1) return '.'\n if (last === 0) return '/'\n return path.slice(0, last)\n}\n","export function compareStrings(a, b) {\n // https://stackoverflow.com/a/40355107/2168416\n return -(a < b) || +(a > b)\n}\n","import pify from 'pify'\n\nimport { compareStrings } from '../utils/compareStrings.js'\nimport { dirname } from '../utils/dirname.js'\nimport { rmRecursive } from '../utils/rmRecursive.js'\nimport { isPromiseLike } from '../utils/types.js'\n\nfunction isPromiseFs(fs) {\n const test = targetFs => {\n try {\n // If readFile returns a promise then we can probably assume the other\n // commands do as well\n return targetFs.readFile().catch(e => e)\n } catch (e) {\n return e\n }\n }\n return isPromiseLike(test(fs))\n}\n\n// List of commands all filesystems are expected to provide. `rm` is not\n// included since it may not exist and must be handled as a special case\nconst commands = [\n 'readFile',\n 'writeFile',\n 'mkdir',\n 'rmdir',\n 'unlink',\n 'stat',\n 'lstat',\n 'readdir',\n 'readlink',\n 'symlink',\n]\n\nfunction bindFs(target, fs) {\n if (isPromiseFs(fs)) {\n for (const command of commands) {\n target[`_${command}`] = fs[command].bind(fs)\n }\n } else {\n for (const command of commands) {\n target[`_${command}`] = pify(fs[command].bind(fs))\n }\n }\n\n // Handle the special case of `rm`\n if (isPromiseFs(fs)) {\n if (fs.rm) target._rm = fs.rm.bind(fs)\n else if (fs.rmdir.length > 1) target._rm = fs.rmdir.bind(fs)\n else target._rm = rmRecursive.bind(null, target)\n } else {\n if (fs.rm) target._rm = pify(fs.rm.bind(fs))\n else if (fs.rmdir.length > 2) target._rm = pify(fs.rmdir.bind(fs))\n else target._rm = rmRecursive.bind(null, target)\n }\n}\n\n/**\n * A wrapper class for file system operations, providing a consistent API for both promise-based\n * and callback-based file systems. It includes utility methods for common file system tasks.\n */\nexport class FileSystem {\n /**\n * Creates an instance of FileSystem.\n *\n * @param {Object} fs - A file system implementation to wrap.\n */\n constructor(fs) {\n if (typeof fs._original_unwrapped_fs !== 'undefined') return fs\n\n const promises = Object.getOwnPropertyDescriptor(fs, 'promises')\n if (promises && promises.enumerable) {\n bindFs(this, fs.promises)\n } else {\n bindFs(this, fs)\n }\n this._original_unwrapped_fs = fs\n }\n\n /**\n * Return true if a file exists, false if it doesn't exist.\n * Rethrows errors that aren't related to file existence.\n *\n * @param {string} filepath - The path to the file.\n * @param {Object} [options] - Additional options.\n * @returns {Promise<boolean>} - `true` if the file exists, `false` otherwise.\n */\n async exists(filepath, options = {}) {\n try {\n await this._stat(filepath)\n return true\n } catch (err) {\n if (\n err.code === 'ENOENT' ||\n err.code === 'ENOTDIR' ||\n (err.code || '').includes('ENS')\n ) {\n return false\n } else {\n console.log('Unhandled error in \"FileSystem.exists()\" function', err)\n throw err\n }\n }\n }\n\n /**\n * Return the contents of a file if it exists, otherwise returns null.\n *\n * @param {string} filepath - The path to the file.\n * @param {Object} [options] - Options for reading the file.\n * @returns {Promise<Buffer|string|null>} - The file contents, or `null` if the file doesn't exist.\n */\n async read(filepath, options = {}) {\n try {\n let buffer = await this._readFile(filepath, options)\n if (options.autocrlf === 'true') {\n try {\n buffer = new TextDecoder('utf8', { fatal: true }).decode(buffer)\n buffer = buffer.replace(/\\r\\n/g, '\\n')\n buffer = new TextEncoder().encode(buffer)\n } catch (error) {\n // non utf8 file\n }\n }\n // Convert plain ArrayBuffers to Buffers\n if (typeof buffer !== 'string') {\n buffer = Buffer.from(buffer)\n }\n return buffer\n } catch (err) {\n return null\n }\n }\n\n /**\n * Write a file (creating missing directories if need be) without throwing errors.\n *\n * @param {string} filepath - The path to the file.\n * @param {Buffer|Uint8Array|string} contents - The data to write.\n * @param {Object|string} [options] - Options for writing the file.\n * @returns {Promise<void>}\n */\n async write(filepath, contents, options = {}) {\n try {\n await this._writeFile(filepath, contents, options)\n return\n } catch (err) {\n // Hmm. Let's try mkdirp and try again.\n await this.mkdir(dirname(filepath))\n await this._writeFile(filepath, contents, options)\n }\n }\n\n /**\n * Make a directory (or series of nested directories) without throwing an error if it already exists.\n *\n * @param {string} filepath - The path to the directory.\n * @param {boolean} [_selfCall=false] - Internal flag to prevent infinite recursion.\n * @returns {Promise<void>}\n */\n async mkdir(filepath, _selfCall = false) {\n try {\n await this._mkdir(filepath)\n return\n } catch (err) {\n // If err is null then operation succeeded!\n if (err === null) return\n // If the directory already exists, that's OK!\n if (err.code === 'EEXIST') return\n // Avoid infinite loops of failure\n if (_selfCall) throw err\n // If we got a \"no such file or directory error\" backup and try again.\n if (err.code === 'ENOENT') {\n const parent = dirname(filepath)\n // Check to see if we've gone too far\n if (parent === '.' || parent === '/' || parent === filepath) throw err\n // Infinite recursion, what could go wrong?\n await this.mkdir(parent)\n await this.mkdir(filepath, true)\n }\n }\n }\n\n /**\n * Delete a file without throwing an error if it is already deleted.\n *\n * @param {string} filepath - The path to the file.\n * @returns {Promise<void>}\n */\n async rm(filepath) {\n try {\n await this._unlink(filepath)\n } catch (err) {\n if (err.code !== 'ENOENT') throw err\n }\n }\n\n /**\n * Delete a directory without throwing an error if it is already deleted.\n *\n * @param {string} filepath - The path to the directory.\n * @param {Object} [opts] - Options for deleting the directory.\n * @returns {Promise<void>}\n */\n async rmdir(filepath, opts) {\n try {\n if (opts && opts.recursive) {\n await this._rm(filepath, opts)\n } else {\n await this._rmdir(filepath)\n }\n } catch (err) {\n if (err.code !== 'ENOENT') throw err\n }\n }\n\n /**\n * Read a directory without throwing an error is the directory doesn't exist\n *\n * @param {string} filepath - The path to the directory.\n * @returns {Promise<string[]|null>} - An array of file names, or `null` if the path is not a directory.\n */\n async readdir(filepath) {\n try {\n const names = await this._readdir(filepath)\n // Ordering is not guaranteed, and system specific (Windows vs Unix)\n // so we must sort them ourselves.\n names.sort(compareStrings)\n return names\n } catch (err) {\n if (err.code === 'ENOTDIR') return null\n return []\n }\n }\n\n /**\n * Return a flat list of all the files nested inside a directory\n *\n * Based on an elegant concurrent recursive solution from SO\n * https://stackoverflow.com/a/45130990/2168416\n *\n * @param {string} dir - The directory to read.\n * @returns {Promise<string[]>} - A flat list of all files in the directory.\n */\n async readdirDeep(dir) {\n const subdirs = await this._readdir(dir)\n const files = await Promise.all(\n subdirs.map(async subdir => {\n const res = dir + '/' + subdir\n return (await this._stat(res)).isDirectory()\n ? this.readdirDeep(res)\n : res\n })\n )\n return files.reduce((a, f) => a.concat(f), [])\n }\n\n /**\n * Return the Stats of a file/symlink if it exists, otherwise returns null.\n * Rethrows errors that aren't related to file existence.\n *\n * @param {string} filename - The path to the file or symlink.\n * @returns {Promise<Object|null>} - The stats object, or `null` if the file doesn't exist.\n */\n async lstat(filename) {\n try {\n const stats = await this._lstat(filename)\n return stats\n } catch (err) {\n if (err.code === 'ENOENT' || (err.code || '').includes('ENS')) {\n return null\n }\n throw err\n }\n }\n\n /**\n * Reads the contents of a symlink if it exists, otherwise returns null.\n * Rethrows errors that aren't related to file existence.\n *\n * @param {string} filename - The path to the symlink.\n * @param {Object} [opts={ encoding: 'buffer' }] - Options for reading the symlink.\n * @returns {Promise<Buffer|null>} - The symlink target, or `null` if it doesn't exist.\n */\n async readlink(filename, opts = { encoding: 'buffer' }) {\n // Note: FileSystem.readlink returns a buffer by default\n // so we can dump it into GitObject.write just like any other file.\n try {\n const link = await this._readlink(filename, opts)\n return Buffer.isBuffer(link) ? link : Buffer.from(link)\n } catch (err) {\n if (err.code === 'ENOENT' || (err.code || '').includes('ENS')) {\n return null\n }\n throw err\n }\n }\n\n /**\n * Write the contents of buffer to a symlink.\n *\n * @param {string} filename - The path to the symlink.\n * @param {Buffer} buffer - The symlink target.\n * @returns {Promise<void>}\n */\n async writelink(filename, buffer) {\n return this._symlink(buffer.toString('utf8'), filename)\n }\n}\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","'use strict';\n\nconst processFn = (fn, options) => function (...args) {\n\tconst P = options.promiseModule;\n\n\treturn new P((resolve, reject) => {\n\t\tif (options.multiArgs) {\n\t\t\targs.push((...result) => {\n\t\t\t\tif (options.errorFirst) {\n\t\t\t\t\tif (result[0]) {\n\t\t\t\t\t\treject(result);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult.shift();\n\t\t\t\t\t\tresolve(result);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tresolve(result);\n\t\t\t\t}\n\t\t\t});\n\t\t} else if (options.errorFirst) {\n\t\t\targs.push((error, result) => {\n\t\t\t\tif (error) {\n\t\t\t\t\treject(error);\n\t\t\t\t} else {\n\t\t\t\t\tresolve(result);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\targs.push(resolve);\n\t\t}\n\n\t\tfn.apply(this, args);\n\t});\n};\n\nmodule.exports = (input, options) => {\n\toptions = Object.assign({\n\t\texclude: [/.+(Sync|Stream)$/],\n\t\terrorFirst: true,\n\t\tpromiseModule: Promise\n\t}, options);\n\n\tconst objType = typeof input;\n\tif (!(input !== null && (objType === 'object' || objType === 'function'))) {\n\t\tthrow new TypeError(`Expected \\`input\\` to be a \\`Function\\` or \\`Object\\`, got \\`${input === null ? 'null' : objType}\\``);\n\t}\n\n\tconst filter = key => {\n\t\tconst match = pattern => typeof pattern === 'string' ? key === pattern : pattern.test(key);\n\t\treturn options.include ? options.include.some(match) : !options.exclude.some(match);\n\t};\n\n\tlet ret;\n\tif (objType === 'function') {\n\t\tret = function (...args) {\n\t\t\treturn options.excludeMain ? input(...args) : processFn(input, options).apply(this, args);\n\t\t};\n\t} else {\n\t\tret = Object.create(Object.getPrototypeOf(input));\n\t}\n\n\tfor (const key in input) { // eslint-disable-line guard-for-in\n\t\tconst property = input[key];\n\t\tret[key] = typeof property === 'function' && filter(key) ? processFn(property, options) : property;\n\t}\n\n\treturn ret;\n};\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh <http://feross.org>\n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('isarray')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Use Object 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 * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n * incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n ? global.TYPED_ARRAY_SUPPORT\n : typedArraySupport()\n\n/*\n * Export kMaxLength after typed array support is determined.\n */\nexports.kMaxLength = kMaxLength()\n\nfunction typedArraySupport () {\n try {\n var arr = new Uint8Array(1)\n arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n return arr.foo() === 42 && // typed array instances can be augmented\n typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n } catch (e) {\n return false\n }\n}\n\nfunction kMaxLength () {\n return Buffer.TYPED_ARRAY_SUPPORT\n ? 0x7fffffff\n : 0x3fffffff\n}\n\nfunction createBuffer (that, length) {\n if (kMaxLength() < length) {\n throw new RangeError('Invalid typed array length')\n }\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = new Uint8Array(length)\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n if (that === null) {\n that = new Buffer(length)\n }\n that.length = length\n }\n\n return that\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 if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {\n return new Buffer(arg, encodingOrOffset, length)\n }\n\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new Error(\n 'If encoding is specified then the first argument must be a string'\n )\n }\n return allocUnsafe(this, arg)\n }\n return from(this, arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\n// TODO: Legacy, not needed anymore. Remove in next major version.\nBuffer._augment = function (arr) {\n arr.__proto__ = Buffer.prototype\n return arr\n}\n\nfunction from (that, value, encodingOrOffset, length) {\n if (typeof value === 'number') {\n throw new TypeError('\"value\" argument must not be a number')\n }\n\n if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n return fromArrayBuffer(that, value, encodingOrOffset, length)\n }\n\n if (typeof value === 'string') {\n return fromString(that, value, encodingOrOffset)\n }\n\n return fromObject(that, value)\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(null, value, encodingOrOffset, length)\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n Buffer.prototype.__proto__ = Uint8Array.prototype\n Buffer.__proto__ = Uint8Array\n if (typeof Symbol !== 'undefined' && Symbol.species &&\n Buffer[Symbol.species] === Buffer) {\n // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n Object.defineProperty(Buffer, Symbol.species, {\n value: null,\n configurable: true\n })\n }\n}\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be a number')\n } else if (size < 0) {\n throw new RangeError('\"size\" argument must not be negative')\n }\n}\n\nfunction alloc (that, size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(that, 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 interpretted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(that, size).fill(fill, encoding)\n : createBuffer(that, size).fill(fill)\n }\n return createBuffer(that, 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(null, size, fill, encoding)\n}\n\nfunction allocUnsafe (that, size) {\n assertSize(size)\n that = createBuffer(that, size < 0 ? 0 : checked(size) | 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) {\n for (var i = 0; i < size; ++i) {\n that[i] = 0\n }\n }\n return that\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(null, 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(null, size)\n}\n\nfunction fromString (that, string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('\"encoding\" must be a valid string encoding')\n }\n\n var length = byteLength(string, encoding) | 0\n that = createBuffer(that, length)\n\n var actual = that.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 that = that.slice(0, actual)\n }\n\n return that\n}\n\nfunction fromArrayLike (that, array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n that = createBuffer(that, length)\n for (var i = 0; i < length; i += 1) {\n that[i] = array[i] & 255\n }\n return that\n}\n\nfunction fromArrayBuffer (that, array, byteOffset, length) {\n array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\\'offset\\' is out of bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\\'length\\' is out of bounds')\n }\n\n if (byteOffset === undefined && length === undefined) {\n array = new Uint8Array(array)\n } else if (length === undefined) {\n array = new Uint8Array(array, byteOffset)\n } else {\n array = new Uint8Array(array, byteOffset, length)\n }\n\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = array\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n that = fromArrayLike(that, array)\n }\n return that\n}\n\nfunction fromObject (that, obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n that = createBuffer(that, len)\n\n if (that.length === 0) {\n return that\n }\n\n obj.copy(that, 0, 0, len)\n return that\n }\n\n if (obj) {\n if ((typeof ArrayBuffer !== 'undefined' &&\n obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n if (typeof obj.length !== 'number' || isnan(obj.length)) {\n return createBuffer(that, 0)\n }\n return fromArrayLike(that, obj)\n }\n\n if (obj.type === 'Buffer' && isArray(obj.data)) {\n return fromArrayLike(that, obj.data)\n }\n }\n\n throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n // Note: cannot use `length < kMaxLength()` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= kMaxLength()) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + kMaxLength().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)\n}\n\nBuffer.compare = function compare (a, b) {\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError('Arguments must be Buffers')\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var 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 (!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 var 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 var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n buf.copy(buffer, pos)\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 (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n string = '' + string\n }\n\n var len = string.length\n if (len === 0) return 0\n\n // Use a for loop to avoid recursion\n var 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 case undefined:\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) return utf8ToBytes(string).length // assume utf8\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var 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 coersion 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// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var 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 var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var 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 var length = this.length | 0\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.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 var str = ''\n var max = exports.INSPECT_MAX_BYTES\n if (this.length > 0) {\n str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n if (this.length > max) str += ' ... '\n }\n return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (!Buffer.isBuffer(target)) {\n throw new TypeError('Argument must be a Buffer')\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 var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var 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 (isNaN(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 (Buffer.TYPED_ARRAY_SUPPORT &&\n 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 var indexSize = 1\n var arrLength = arr.length\n var 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 var i\n if (dir) {\n var 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 var found = true\n for (var 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 var 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 // must be an even number of digits\n var strLen = string.length\n if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (isNaN(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 latin1Write (buf, string, offset, length) {\n return asciiWrite(buf, string, 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 // legacy write(string, encoding, offset, length) - remove in v0.13\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var 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 var 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 return asciiWrite(this, string, offset, length)\n\n case 'latin1':\n case 'binary':\n return latin1Write(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 var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF) ? 4\n : (firstByte > 0xDF) ? 3\n : (firstByte > 0xBF) ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var 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\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var 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 var res = ''\n var 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 var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += toHex(buf[i])\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n for (var i = 0; i < bytes.length; 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 var 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 var newBuf\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n newBuf = this.subarray(start, end)\n newBuf.__proto__ = Buffer.prototype\n } else {\n var sliceLen = end - start\n newBuf = new Buffer(sliceLen, undefined)\n for (var i = 0; i < sliceLen; ++i) {\n newBuf[i] = this[i + start]\n }\n }\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 = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\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 var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\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 = function readUInt32BE (offset, noAssert) {\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.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var 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 var i = byteLength\n var mul = 1\n var 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 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 if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\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 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.readFloatLE = function readFloatLE (offset, noAssert) {\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 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 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 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 = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var 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 = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var 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 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) {\n buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n (littleEndian ? i : 1 - i) * 8\n }\n}\n\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\n return offset + 2\n}\n\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\n return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffffffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) {\n buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n }\n}\n\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\n return offset + 4\n}\n\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var 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 var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var 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 (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\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 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 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 (!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('sourceStart out of bounds')\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 var len = end - start\n var i\n\n if (this === target && start < targetStart && targetStart < end) {\n // descending copy from end\n for (i = len - 1; i >= 0; --i) {\n target[i + targetStart] = this[i + start]\n }\n } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n // ascending copy from start\n for (i = 0; i < len; ++i) {\n target[i + targetStart] = this[i + start]\n }\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, start + len),\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 (val.length === 1) {\n var code = val.charCodeAt(0)\n if (code < 256) {\n val = code\n }\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 } else if (typeof val === 'number') {\n val = val & 255\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 var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : utf8ToBytes(new Buffer(val, encoding).toString())\n var len = bytes.length\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = stringtrim(str).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 stringtrim (str) {\n if (str.trim) return str.trim()\n return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n if (n < 16) return '0' + n.toString(16)\n return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var 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 var byteArray = []\n for (var 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 var c, hi, lo\n var byteArray = []\n for (var 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 for (var 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\nfunction isnan (val) {\n return val !== val // eslint-disable-line no-self-compare\n}\n","import { join } from './join'\n\n/**\n * Removes the directory at the specified filepath recursively. Used internally to replicate the behavior of\n * fs.promises.rm({ recursive: true, force: true }) from Node.js 14 and above when not available. If the provided\n * filepath resolves to a file, it will be removed.\n *\n * @param {import('../models/FileSystem.js').FileSystem} fs\n * @param {string} filepath - The file or directory to remove.\n */\nexport async function rmRecursive(fs, filepath) {\n const entries = await fs.readdir(filepath)\n if (entries == null) {\n await fs.rm(filepath)\n } else if (entries.length) {\n await Promise.all(\n entries.map(entry => {\n const subpath = join(filepath, entry)\n return fs.lstat(subpath).then(stat => {\n if (!stat) return\n return stat.isDirectory() ? rmRecursive(fs, subpath) : fs.rm(subpath)\n })\n })\n ).then(() => fs.rmdir(filepath))\n } else {\n await fs.rmdir(filepath)\n }\n}\n"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"sources":["webpack://git/webpack/universalModuleDefinition","webpack://git/webpack/bootstrap","webpack://git/./src/utils/rmRecursive.js","webpack://git/./node_modules/path-browserify/index.js","webpack://git/./src/utils/types.js","webpack://git/./node_modules/node-libs-browser/node_modules/base64-js/index.js","webpack://git/./node_modules/ieee754/index.js","webpack://git/./node_modules/isarray/index.js","webpack://git/./src/models/index.js","webpack://git/./src/utils/dirname.js","webpack://git/./src/utils/compareStrings.js","webpack://git/./src/models/FileSystem.js","webpack://git/./node_modules/process/browser.js","webpack://git/./node_modules/pify/index.js","webpack://git/(webpack)/buildin/global.js","webpack://git/./node_modules/node-libs-browser/node_modules/buffer/index.js"],"names":["root","factory","exports","module","define","amd","self","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","rmRecursive","fs","filepath","entries","readdir","rm","length","Promise","all","map","entry","subpath","join","lstat","then","stat","isDirectory","rmdir","assertPath","path","TypeError","JSON","stringify","normalizeStringPosix","allowAboveRoot","code","res","lastSegmentLength","lastSlash","dots","charCodeAt","lastSlashIndex","lastIndexOf","slice","posix","resolve","cwd","resolvedPath","resolvedAbsolute","arguments","undefined","process","normalize","isAbsolute","trailingSeparator","joined","arg","relative","from","to","fromStart","fromEnd","fromLen","toStart","toLen","lastCommonSep","fromCode","out","_makeLong","dirname","hasRoot","end","matchedSlash","basename","ext","start","extIdx","firstNonSlashEnd","extname","startDot","startPart","preDotState","format","pathObject","sep","dir","base","_format","parse","ret","delimiter","win32","isPromiseLike","obj","isObject","isFunction","catch","byteLength","b64","lens","getLens","validLen","placeHoldersLen","toByteArray","tmp","arr","Arr","_byteLength","curByte","len","revLookup","fromByteArray","uint8","extraBytes","parts","len2","push","encodeChunk","lookup","Uint8Array","Array","Error","indexOf","num","output","read","buffer","offset","isLE","mLen","nBytes","e","eLen","eMax","eBias","nBits","NaN","Infinity","Math","pow","write","rt","abs","isNaN","floor","log","LN2","toString","isArray","last","max","compareStrings","a","b","isPromiseFs","targetFs","readFile","test","commands","bindFs","target","command","pify","_rm","FileSystem","constructor","_original_unwrapped_fs","promises","getOwnPropertyDescriptor","this","exists","options","_stat","err","includes","console","_readFile","autocrlf","TextDecoder","fatal","decode","replace","TextEncoder","encode","error","Buffer","contents","_writeFile","mkdir","_selfCall","_mkdir","parent","_unlink","opts","recursive","_rmdir","names","_readdir","sort","readdirDeep","subdirs","subdir","reduce","f","concat","filename","_lstat","readlink","encoding","link","_readlink","isBuffer","writelink","_symlink","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","setTimeout","clearTimeout","currentQueue","queue","draining","queueIndex","cleanUpNextTick","drainQueue","timeout","run","marker","runClearTimeout","Item","array","noop","nextTick","args","apply","title","browser","env","argv","version","versions","on","addListener","once","off","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","binding","chdir","umask","processFn","fn","P","promiseModule","reject","multiArgs","result","errorFirst","shift","input","assign","exclude","objType","filter","match","pattern","include","some","excludeMain","getPrototypeOf","g","Function","window","base64","ieee754","kMaxLength","TYPED_ARRAY_SUPPORT","createBuffer","that","RangeError","__proto__","encodingOrOffset","allocUnsafe","ArrayBuffer","byteOffset","fromArrayLike","fromArrayBuffer","string","isEncoding","actual","fromString","checked","copy","val","type","data","fromObject","assertSize","size","isView","loweredCase","utf8ToBytes","base64ToBytes","toLowerCase","slowToString","hexSlice","utf8Slice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","bidirectionalIndexOf","arrayIndexOf","indexSize","arrLength","valLength","String","buf","readUInt16BE","foundIndex","found","j","hexWrite","Number","remaining","strLen","parsed","parseInt","substr","utf8Write","blitBuffer","asciiWrite","str","byteArray","asciiToBytes","latin1Write","base64Write","ucs2Write","units","hi","lo","utf16leToBytes","min","secondByte","thirdByte","fourthByte","tempCodePoint","firstByte","codePoint","bytesPerSequence","codePoints","fromCharCode","decodeCodePointsArray","SlowBuffer","alloc","INSPECT_MAX_BYTES","global","foo","subarray","typedArraySupport","poolSize","_augment","species","configurable","fill","allocUnsafeSlow","_isBuffer","compare","x","y","list","pos","swap16","swap32","swap64","equals","inspect","thisStart","thisEnd","thisCopy","targetCopy","isFinite","toJSON","_arr","toHex","bytes","checkOffset","checkInt","objectWriteUInt16","littleEndian","objectWriteUInt32","checkIEEE754","writeFloat","noAssert","writeDouble","newBuf","sliceLen","readUIntLE","mul","readUIntBE","readUInt8","readUInt16LE","readUInt32LE","readUInt32BE","readIntLE","readIntBE","readInt8","readInt16LE","readInt16BE","readInt32LE","readInt32BE","readFloatLE","readFloatBE","readDoubleLE","readDoubleBE","writeUIntLE","writeUIntBE","writeUInt8","writeUInt16LE","writeUInt16BE","writeUInt32LE","writeUInt32BE","writeIntLE","limit","sub","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","writeFloatLE","writeFloatBE","writeDoubleLE","writeDoubleBE","targetStart","set","INVALID_BASE64_RE","leadSurrogate","trim","stringtrim","base64clean","src","dst"],"mappings":"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","file":"models/index.umd.min.js","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 if(typeof exports === 'object')\n\t\texports[\"git\"] = factory();\n\telse\n\t\troot[\"git\"] = factory();\n})(self, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 225);\n","import { join } from './join'\n\n/**\n * Removes the directory at the specified filepath recursively. Used internally to replicate the behavior of\n * fs.promises.rm({ recursive: true, force: true }) from Node.js 14 and above when not available. If the provided\n * filepath resolves to a file, it will be removed.\n *\n * @param {import('../models/FileSystem.js').FileSystem} fs\n * @param {string} filepath - The file or directory to remove.\n */\nexport async function rmRecursive(fs, filepath) {\n const entries = await fs.readdir(filepath)\n if (entries == null) {\n await fs.rm(filepath)\n } else if (entries.length) {\n await Promise.all(\n entries.map(entry => {\n const subpath = join(filepath, entry)\n return fs.lstat(subpath).then(stat => {\n if (!stat) return\n return stat.isDirectory() ? rmRecursive(fs, subpath) : fs.rm(subpath)\n })\n })\n ).then(() => fs.rmdir(filepath))\n } else {\n await fs.rmdir(filepath)\n }\n}\n","// 'path' module extracted from Node.js v8.11.1 (only the posix part)\n// transplited with Babel\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\nfunction assertPath(path) {\n if (typeof path !== 'string') {\n throw new TypeError('Path must be a string. Received ' + JSON.stringify(path));\n }\n}\n\n// Resolves . and .. elements in a path with directory names\nfunction normalizeStringPosix(path, allowAboveRoot) {\n var res = '';\n var lastSegmentLength = 0;\n var lastSlash = -1;\n var dots = 0;\n var code;\n for (var i = 0; i <= path.length; ++i) {\n if (i < path.length)\n code = path.charCodeAt(i);\n else if (code === 47 /*/*/)\n break;\n else\n code = 47 /*/*/;\n if (code === 47 /*/*/) {\n if (lastSlash === i - 1 || dots === 1) {\n // NOOP\n } else if (lastSlash !== i - 1 && dots === 2) {\n if (res.length < 2 || lastSegmentLength !== 2 || res.charCodeAt(res.length - 1) !== 46 /*.*/ || res.charCodeAt(res.length - 2) !== 46 /*.*/) {\n if (res.length > 2) {\n var lastSlashIndex = res.lastIndexOf('/');\n if (lastSlashIndex !== res.length - 1) {\n if (lastSlashIndex === -1) {\n res = '';\n lastSegmentLength = 0;\n } else {\n res = res.slice(0, lastSlashIndex);\n lastSegmentLength = res.length - 1 - res.lastIndexOf('/');\n }\n lastSlash = i;\n dots = 0;\n continue;\n }\n } else if (res.length === 2 || res.length === 1) {\n res = '';\n lastSegmentLength = 0;\n lastSlash = i;\n dots = 0;\n continue;\n }\n }\n if (allowAboveRoot) {\n if (res.length > 0)\n res += '/..';\n else\n res = '..';\n lastSegmentLength = 2;\n }\n } else {\n if (res.length > 0)\n res += '/' + path.slice(lastSlash + 1, i);\n else\n res = path.slice(lastSlash + 1, i);\n lastSegmentLength = i - lastSlash - 1;\n }\n lastSlash = i;\n dots = 0;\n } else if (code === 46 /*.*/ && dots !== -1) {\n ++dots;\n } else {\n dots = -1;\n }\n }\n return res;\n}\n\nfunction _format(sep, pathObject) {\n var dir = pathObject.dir || pathObject.root;\n var base = pathObject.base || (pathObject.name || '') + (pathObject.ext || '');\n if (!dir) {\n return base;\n }\n if (dir === pathObject.root) {\n return dir + base;\n }\n return dir + sep + base;\n}\n\nvar posix = {\n // path.resolve([from ...], to)\n resolve: function resolve() {\n var resolvedPath = '';\n var resolvedAbsolute = false;\n var cwd;\n\n for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n var path;\n if (i >= 0)\n path = arguments[i];\n else {\n if (cwd === undefined)\n cwd = process.cwd();\n path = cwd;\n }\n\n assertPath(path);\n\n // Skip empty entries\n if (path.length === 0) {\n continue;\n }\n\n resolvedPath = path + '/' + resolvedPath;\n resolvedAbsolute = path.charCodeAt(0) === 47 /*/*/;\n }\n\n // At this point the path should be resolved to a full absolute path, but\n // handle relative paths to be safe (might happen when process.cwd() fails)\n\n // Normalize the path\n resolvedPath = normalizeStringPosix(resolvedPath, !resolvedAbsolute);\n\n if (resolvedAbsolute) {\n if (resolvedPath.length > 0)\n return '/' + resolvedPath;\n else\n return '/';\n } else if (resolvedPath.length > 0) {\n return resolvedPath;\n } else {\n return '.';\n }\n },\n\n normalize: function normalize(path) {\n assertPath(path);\n\n if (path.length === 0) return '.';\n\n var isAbsolute = path.charCodeAt(0) === 47 /*/*/;\n var trailingSeparator = path.charCodeAt(path.length - 1) === 47 /*/*/;\n\n // Normalize the path\n path = normalizeStringPosix(path, !isAbsolute);\n\n if (path.length === 0 && !isAbsolute) path = '.';\n if (path.length > 0 && trailingSeparator) path += '/';\n\n if (isAbsolute) return '/' + path;\n return path;\n },\n\n isAbsolute: function isAbsolute(path) {\n assertPath(path);\n return path.length > 0 && path.charCodeAt(0) === 47 /*/*/;\n },\n\n join: function join() {\n if (arguments.length === 0)\n return '.';\n var joined;\n for (var i = 0; i < arguments.length; ++i) {\n var arg = arguments[i];\n assertPath(arg);\n if (arg.length > 0) {\n if (joined === undefined)\n joined = arg;\n else\n joined += '/' + arg;\n }\n }\n if (joined === undefined)\n return '.';\n return posix.normalize(joined);\n },\n\n relative: function relative(from, to) {\n assertPath(from);\n assertPath(to);\n\n if (from === to) return '';\n\n from = posix.resolve(from);\n to = posix.resolve(to);\n\n if (from === to) return '';\n\n // Trim any leading backslashes\n var fromStart = 1;\n for (; fromStart < from.length; ++fromStart) {\n if (from.charCodeAt(fromStart) !== 47 /*/*/)\n break;\n }\n var fromEnd = from.length;\n var fromLen = fromEnd - fromStart;\n\n // Trim any leading backslashes\n var toStart = 1;\n for (; toStart < to.length; ++toStart) {\n if (to.charCodeAt(toStart) !== 47 /*/*/)\n break;\n }\n var toEnd = to.length;\n var toLen = toEnd - toStart;\n\n // Compare paths to find the longest common path from root\n var length = fromLen < toLen ? fromLen : toLen;\n var lastCommonSep = -1;\n var i = 0;\n for (; i <= length; ++i) {\n if (i === length) {\n if (toLen > length) {\n if (to.charCodeAt(toStart + i) === 47 /*/*/) {\n // We get here if `from` is the exact base path for `to`.\n // For example: from='/foo/bar'; to='/foo/bar/baz'\n return to.slice(toStart + i + 1);\n } else if (i === 0) {\n // We get here if `from` is the root\n // For example: from='/'; to='/foo'\n return to.slice(toStart + i);\n }\n } else if (fromLen > length) {\n if (from.charCodeAt(fromStart + i) === 47 /*/*/) {\n // We get here if `to` is the exact base path for `from`.\n // For example: from='/foo/bar/baz'; to='/foo/bar'\n lastCommonSep = i;\n } else if (i === 0) {\n // We get here if `to` is the root.\n // For example: from='/foo'; to='/'\n lastCommonSep = 0;\n }\n }\n break;\n }\n var fromCode = from.charCodeAt(fromStart + i);\n var toCode = to.charCodeAt(toStart + i);\n if (fromCode !== toCode)\n break;\n else if (fromCode === 47 /*/*/)\n lastCommonSep = i;\n }\n\n var out = '';\n // Generate the relative path based on the path difference between `to`\n // and `from`\n for (i = fromStart + lastCommonSep + 1; i <= fromEnd; ++i) {\n if (i === fromEnd || from.charCodeAt(i) === 47 /*/*/) {\n if (out.length === 0)\n out += '..';\n else\n out += '/..';\n }\n }\n\n // Lastly, append the rest of the destination (`to`) path that comes after\n // the common path parts\n if (out.length > 0)\n return out + to.slice(toStart + lastCommonSep);\n else {\n toStart += lastCommonSep;\n if (to.charCodeAt(toStart) === 47 /*/*/)\n ++toStart;\n return to.slice(toStart);\n }\n },\n\n _makeLong: function _makeLong(path) {\n return path;\n },\n\n dirname: function dirname(path) {\n assertPath(path);\n if (path.length === 0) return '.';\n var code = path.charCodeAt(0);\n var hasRoot = code === 47 /*/*/;\n var end = -1;\n var matchedSlash = true;\n for (var i = path.length - 1; i >= 1; --i) {\n code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n if (!matchedSlash) {\n end = i;\n break;\n }\n } else {\n // We saw the first non-path separator\n matchedSlash = false;\n }\n }\n\n if (end === -1) return hasRoot ? '/' : '.';\n if (hasRoot && end === 1) return '//';\n return path.slice(0, end);\n },\n\n basename: function basename(path, ext) {\n if (ext !== undefined && typeof ext !== 'string') throw new TypeError('\"ext\" argument must be a string');\n assertPath(path);\n\n var start = 0;\n var end = -1;\n var matchedSlash = true;\n var i;\n\n if (ext !== undefined && ext.length > 0 && ext.length <= path.length) {\n if (ext.length === path.length && ext === path) return '';\n var extIdx = ext.length - 1;\n var firstNonSlashEnd = -1;\n for (i = path.length - 1; i >= 0; --i) {\n var code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n } else {\n if (firstNonSlashEnd === -1) {\n // We saw the first non-path separator, remember this index in case\n // we need it if the extension ends up not matching\n matchedSlash = false;\n firstNonSlashEnd = i + 1;\n }\n if (extIdx >= 0) {\n // Try to match the explicit extension\n if (code === ext.charCodeAt(extIdx)) {\n if (--extIdx === -1) {\n // We matched the extension, so mark this as the end of our path\n // component\n end = i;\n }\n } else {\n // Extension does not match, so our result is the entire path\n // component\n extIdx = -1;\n end = firstNonSlashEnd;\n }\n }\n }\n }\n\n if (start === end) end = firstNonSlashEnd;else if (end === -1) end = path.length;\n return path.slice(start, end);\n } else {\n for (i = path.length - 1; i >= 0; --i) {\n if (path.charCodeAt(i) === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n } else if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // path component\n matchedSlash = false;\n end = i + 1;\n }\n }\n\n if (end === -1) return '';\n return path.slice(start, end);\n }\n },\n\n extname: function extname(path) {\n assertPath(path);\n var startDot = -1;\n var startPart = 0;\n var end = -1;\n var matchedSlash = true;\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n var preDotState = 0;\n for (var i = path.length - 1; i >= 0; --i) {\n var code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === 46 /*.*/) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1)\n startDot = i;\n else if (preDotState !== 1)\n preDotState = 1;\n } else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n\n if (startDot === -1 || end === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {\n return '';\n }\n return path.slice(startDot, end);\n },\n\n format: function format(pathObject) {\n if (pathObject === null || typeof pathObject !== 'object') {\n throw new TypeError('The \"pathObject\" argument must be of type Object. Received type ' + typeof pathObject);\n }\n return _format('/', pathObject);\n },\n\n parse: function parse(path) {\n assertPath(path);\n\n var ret = { root: '', dir: '', base: '', ext: '', name: '' };\n if (path.length === 0) return ret;\n var code = path.charCodeAt(0);\n var isAbsolute = code === 47 /*/*/;\n var start;\n if (isAbsolute) {\n ret.root = '/';\n start = 1;\n } else {\n start = 0;\n }\n var startDot = -1;\n var startPart = 0;\n var end = -1;\n var matchedSlash = true;\n var i = path.length - 1;\n\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n var preDotState = 0;\n\n // Get non-dir info\n for (; i >= start; --i) {\n code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === 46 /*.*/) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1) startDot = i;else if (preDotState !== 1) preDotState = 1;\n } else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n\n if (startDot === -1 || end === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {\n if (end !== -1) {\n if (startPart === 0 && isAbsolute) ret.base = ret.name = path.slice(1, end);else ret.base = ret.name = path.slice(startPart, end);\n }\n } else {\n if (startPart === 0 && isAbsolute) {\n ret.name = path.slice(1, startDot);\n ret.base = path.slice(1, end);\n } else {\n ret.name = path.slice(startPart, startDot);\n ret.base = path.slice(startPart, end);\n }\n ret.ext = path.slice(startDot, end);\n }\n\n if (startPart > 0) ret.dir = path.slice(0, startPart - 1);else if (isAbsolute) ret.dir = '/';\n\n return ret;\n },\n\n sep: '/',\n delimiter: ':',\n win32: null,\n posix: null\n};\n\nposix.posix = posix;\n\nmodule.exports = posix;\n","export function isPromiseLike(obj) {\n return isObject(obj) && isFunction(obj.then) && isFunction(obj.catch)\n}\n\nexport function isObject(obj) {\n return obj && typeof obj === 'object'\n}\n\nexport function isFunction(obj) {\n return typeof obj === 'function'\n}\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(\n uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)\n ))\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","exports.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","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","export { FileSystem } from './FileSystem'\n","export function dirname(path) {\n const last = Math.max(path.lastIndexOf('/'), path.lastIndexOf('\\\\'))\n if (last === -1) return '.'\n if (last === 0) return '/'\n return path.slice(0, last)\n}\n","export function compareStrings(a, b) {\n // https://stackoverflow.com/a/40355107/2168416\n return -(a < b) || +(a > b)\n}\n","import pify from 'pify'\n\nimport { compareStrings } from '../utils/compareStrings.js'\nimport { dirname } from '../utils/dirname.js'\nimport { rmRecursive } from '../utils/rmRecursive.js'\nimport { isPromiseLike } from '../utils/types.js'\n\nfunction isPromiseFs(fs) {\n const test = targetFs => {\n try {\n // If readFile returns a promise then we can probably assume the other\n // commands do as well\n return targetFs.readFile().catch(e => e)\n } catch (e) {\n return e\n }\n }\n return isPromiseLike(test(fs))\n}\n\n// List of commands all filesystems are expected to provide. `rm` is not\n// included since it may not exist and must be handled as a special case\nconst commands = [\n 'readFile',\n 'writeFile',\n 'mkdir',\n 'rmdir',\n 'unlink',\n 'stat',\n 'lstat',\n 'readdir',\n 'readlink',\n 'symlink',\n]\n\nfunction bindFs(target, fs) {\n if (isPromiseFs(fs)) {\n for (const command of commands) {\n target[`_${command}`] = fs[command].bind(fs)\n }\n } else {\n for (const command of commands) {\n target[`_${command}`] = pify(fs[command].bind(fs))\n }\n }\n\n // Handle the special case of `rm`\n if (isPromiseFs(fs)) {\n if (fs.rm) target._rm = fs.rm.bind(fs)\n else if (fs.rmdir.length > 1) target._rm = fs.rmdir.bind(fs)\n else target._rm = rmRecursive.bind(null, target)\n } else {\n if (fs.rm) target._rm = pify(fs.rm.bind(fs))\n else if (fs.rmdir.length > 2) target._rm = pify(fs.rmdir.bind(fs))\n else target._rm = rmRecursive.bind(null, target)\n }\n}\n\n/**\n * A wrapper class for file system operations, providing a consistent API for both promise-based\n * and callback-based file systems. It includes utility methods for common file system tasks.\n */\nexport class FileSystem {\n /**\n * Creates an instance of FileSystem.\n *\n * @param {Object} fs - A file system implementation to wrap.\n */\n constructor(fs) {\n if (typeof fs._original_unwrapped_fs !== 'undefined') return fs\n\n const promises = Object.getOwnPropertyDescriptor(fs, 'promises')\n if (promises && promises.enumerable) {\n bindFs(this, fs.promises)\n } else {\n bindFs(this, fs)\n }\n this._original_unwrapped_fs = fs\n }\n\n /**\n * Return true if a file exists, false if it doesn't exist.\n * Rethrows errors that aren't related to file existence.\n *\n * @param {string} filepath - The path to the file.\n * @param {Object} [options] - Additional options.\n * @returns {Promise<boolean>} - `true` if the file exists, `false` otherwise.\n */\n async exists(filepath, options = {}) {\n try {\n await this._stat(filepath)\n return true\n } catch (err) {\n if (\n err.code === 'ENOENT' ||\n err.code === 'ENOTDIR' ||\n (err.code || '').includes('ENS')\n ) {\n return false\n } else {\n console.log('Unhandled error in \"FileSystem.exists()\" function', err)\n throw err\n }\n }\n }\n\n /**\n * Return the contents of a file if it exists, otherwise returns null.\n *\n * @param {string} filepath - The path to the file.\n * @param {Object} [options] - Options for reading the file.\n * @returns {Promise<Buffer|string|null>} - The file contents, or `null` if the file doesn't exist.\n */\n async read(filepath, options = {}) {\n try {\n let buffer = await this._readFile(filepath, options)\n if (options.autocrlf === 'true') {\n try {\n buffer = new TextDecoder('utf8', { fatal: true }).decode(buffer)\n buffer = buffer.replace(/\\r\\n/g, '\\n')\n buffer = new TextEncoder().encode(buffer)\n } catch (error) {\n // non utf8 file\n }\n }\n // Convert plain ArrayBuffers to Buffers\n if (typeof buffer !== 'string') {\n buffer = Buffer.from(buffer)\n }\n return buffer\n } catch (err) {\n return null\n }\n }\n\n /**\n * Write a file (creating missing directories if need be) without throwing errors.\n *\n * @param {string} filepath - The path to the file.\n * @param {Buffer|Uint8Array|string} contents - The data to write.\n * @param {Object|string} [options] - Options for writing the file.\n * @returns {Promise<void>}\n */\n async write(filepath, contents, options = {}) {\n try {\n await this._writeFile(filepath, contents, options)\n return\n } catch (err) {\n // Hmm. Let's try mkdirp and try again.\n await this.mkdir(dirname(filepath))\n await this._writeFile(filepath, contents, options)\n }\n }\n\n /**\n * Make a directory (or series of nested directories) without throwing an error if it already exists.\n *\n * @param {string} filepath - The path to the directory.\n * @param {boolean} [_selfCall=false] - Internal flag to prevent infinite recursion.\n * @returns {Promise<void>}\n */\n async mkdir(filepath, _selfCall = false) {\n try {\n await this._mkdir(filepath)\n return\n } catch (err) {\n // If err is null then operation succeeded!\n if (err === null) return\n // If the directory already exists, that's OK!\n if (err.code === 'EEXIST') return\n // Avoid infinite loops of failure\n if (_selfCall) throw err\n // If we got a \"no such file or directory error\" backup and try again.\n if (err.code === 'ENOENT') {\n const parent = dirname(filepath)\n // Check to see if we've gone too far\n if (parent === '.' || parent === '/' || parent === filepath) throw err\n // Infinite recursion, what could go wrong?\n await this.mkdir(parent)\n await this.mkdir(filepath, true)\n }\n }\n }\n\n /**\n * Delete a file without throwing an error if it is already deleted.\n *\n * @param {string} filepath - The path to the file.\n * @returns {Promise<void>}\n */\n async rm(filepath) {\n try {\n await this._unlink(filepath)\n } catch (err) {\n if (err.code !== 'ENOENT') throw err\n }\n }\n\n /**\n * Delete a directory without throwing an error if it is already deleted.\n *\n * @param {string} filepath - The path to the directory.\n * @param {Object} [opts] - Options for deleting the directory.\n * @returns {Promise<void>}\n */\n async rmdir(filepath, opts) {\n try {\n if (opts && opts.recursive) {\n await this._rm(filepath, opts)\n } else {\n await this._rmdir(filepath)\n }\n } catch (err) {\n if (err.code !== 'ENOENT') throw err\n }\n }\n\n /**\n * Read a directory without throwing an error is the directory doesn't exist\n *\n * @param {string} filepath - The path to the directory.\n * @returns {Promise<string[]|null>} - An array of file names, or `null` if the path is not a directory.\n */\n async readdir(filepath) {\n try {\n const names = await this._readdir(filepath)\n // Ordering is not guaranteed, and system specific (Windows vs Unix)\n // so we must sort them ourselves.\n names.sort(compareStrings)\n return names\n } catch (err) {\n if (err.code === 'ENOTDIR') return null\n return []\n }\n }\n\n /**\n * Return a flat list of all the files nested inside a directory\n *\n * Based on an elegant concurrent recursive solution from SO\n * https://stackoverflow.com/a/45130990/2168416\n *\n * @param {string} dir - The directory to read.\n * @returns {Promise<string[]>} - A flat list of all files in the directory.\n */\n async readdirDeep(dir) {\n const subdirs = await this._readdir(dir)\n const files = await Promise.all(\n subdirs.map(async subdir => {\n const res = dir + '/' + subdir\n return (await this._stat(res)).isDirectory()\n ? this.readdirDeep(res)\n : res\n })\n )\n return files.reduce((a, f) => a.concat(f), [])\n }\n\n /**\n * Return the Stats of a file/symlink if it exists, otherwise returns null.\n * Rethrows errors that aren't related to file existence.\n *\n * @param {string} filename - The path to the file or symlink.\n * @returns {Promise<Object|null>} - The stats object, or `null` if the file doesn't exist.\n */\n async lstat(filename) {\n try {\n const stats = await this._lstat(filename)\n return stats\n } catch (err) {\n if (err.code === 'ENOENT' || (err.code || '').includes('ENS')) {\n return null\n }\n throw err\n }\n }\n\n /**\n * Reads the contents of a symlink if it exists, otherwise returns null.\n * Rethrows errors that aren't related to file existence.\n *\n * @param {string} filename - The path to the symlink.\n * @param {Object} [opts={ encoding: 'buffer' }] - Options for reading the symlink.\n * @returns {Promise<Buffer|null>} - The symlink target, or `null` if it doesn't exist.\n */\n async readlink(filename, opts = { encoding: 'buffer' }) {\n // Note: FileSystem.readlink returns a buffer by default\n // so we can dump it into GitObject.write just like any other file.\n try {\n const link = await this._readlink(filename, opts)\n return Buffer.isBuffer(link) ? link : Buffer.from(link)\n } catch (err) {\n if (err.code === 'ENOENT' || (err.code || '').includes('ENS')) {\n return null\n }\n throw err\n }\n }\n\n /**\n * Write the contents of buffer to a symlink.\n *\n * @param {string} filename - The path to the symlink.\n * @param {Buffer} buffer - The symlink target.\n * @returns {Promise<void>}\n */\n async writelink(filename, buffer) {\n return this._symlink(buffer.toString('utf8'), filename)\n }\n}\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","'use strict';\n\nconst processFn = (fn, options) => function (...args) {\n\tconst P = options.promiseModule;\n\n\treturn new P((resolve, reject) => {\n\t\tif (options.multiArgs) {\n\t\t\targs.push((...result) => {\n\t\t\t\tif (options.errorFirst) {\n\t\t\t\t\tif (result[0]) {\n\t\t\t\t\t\treject(result);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult.shift();\n\t\t\t\t\t\tresolve(result);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tresolve(result);\n\t\t\t\t}\n\t\t\t});\n\t\t} else if (options.errorFirst) {\n\t\t\targs.push((error, result) => {\n\t\t\t\tif (error) {\n\t\t\t\t\treject(error);\n\t\t\t\t} else {\n\t\t\t\t\tresolve(result);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\targs.push(resolve);\n\t\t}\n\n\t\tfn.apply(this, args);\n\t});\n};\n\nmodule.exports = (input, options) => {\n\toptions = Object.assign({\n\t\texclude: [/.+(Sync|Stream)$/],\n\t\terrorFirst: true,\n\t\tpromiseModule: Promise\n\t}, options);\n\n\tconst objType = typeof input;\n\tif (!(input !== null && (objType === 'object' || objType === 'function'))) {\n\t\tthrow new TypeError(`Expected \\`input\\` to be a \\`Function\\` or \\`Object\\`, got \\`${input === null ? 'null' : objType}\\``);\n\t}\n\n\tconst filter = key => {\n\t\tconst match = pattern => typeof pattern === 'string' ? key === pattern : pattern.test(key);\n\t\treturn options.include ? options.include.some(match) : !options.exclude.some(match);\n\t};\n\n\tlet ret;\n\tif (objType === 'function') {\n\t\tret = function (...args) {\n\t\t\treturn options.excludeMain ? input(...args) : processFn(input, options).apply(this, args);\n\t\t};\n\t} else {\n\t\tret = Object.create(Object.getPrototypeOf(input));\n\t}\n\n\tfor (const key in input) { // eslint-disable-line guard-for-in\n\t\tconst property = input[key];\n\t\tret[key] = typeof property === 'function' && filter(key) ? processFn(property, options) : property;\n\t}\n\n\treturn ret;\n};\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh <http://feross.org>\n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('isarray')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Use Object 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 * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n * incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n ? global.TYPED_ARRAY_SUPPORT\n : typedArraySupport()\n\n/*\n * Export kMaxLength after typed array support is determined.\n */\nexports.kMaxLength = kMaxLength()\n\nfunction typedArraySupport () {\n try {\n var arr = new Uint8Array(1)\n arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n return arr.foo() === 42 && // typed array instances can be augmented\n typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n } catch (e) {\n return false\n }\n}\n\nfunction kMaxLength () {\n return Buffer.TYPED_ARRAY_SUPPORT\n ? 0x7fffffff\n : 0x3fffffff\n}\n\nfunction createBuffer (that, length) {\n if (kMaxLength() < length) {\n throw new RangeError('Invalid typed array length')\n }\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = new Uint8Array(length)\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n if (that === null) {\n that = new Buffer(length)\n }\n that.length = length\n }\n\n return that\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 if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {\n return new Buffer(arg, encodingOrOffset, length)\n }\n\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new Error(\n 'If encoding is specified then the first argument must be a string'\n )\n }\n return allocUnsafe(this, arg)\n }\n return from(this, arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\n// TODO: Legacy, not needed anymore. Remove in next major version.\nBuffer._augment = function (arr) {\n arr.__proto__ = Buffer.prototype\n return arr\n}\n\nfunction from (that, value, encodingOrOffset, length) {\n if (typeof value === 'number') {\n throw new TypeError('\"value\" argument must not be a number')\n }\n\n if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n return fromArrayBuffer(that, value, encodingOrOffset, length)\n }\n\n if (typeof value === 'string') {\n return fromString(that, value, encodingOrOffset)\n }\n\n return fromObject(that, value)\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(null, value, encodingOrOffset, length)\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n Buffer.prototype.__proto__ = Uint8Array.prototype\n Buffer.__proto__ = Uint8Array\n if (typeof Symbol !== 'undefined' && Symbol.species &&\n Buffer[Symbol.species] === Buffer) {\n // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n Object.defineProperty(Buffer, Symbol.species, {\n value: null,\n configurable: true\n })\n }\n}\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be a number')\n } else if (size < 0) {\n throw new RangeError('\"size\" argument must not be negative')\n }\n}\n\nfunction alloc (that, size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(that, 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 interpretted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(that, size).fill(fill, encoding)\n : createBuffer(that, size).fill(fill)\n }\n return createBuffer(that, 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(null, size, fill, encoding)\n}\n\nfunction allocUnsafe (that, size) {\n assertSize(size)\n that = createBuffer(that, size < 0 ? 0 : checked(size) | 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) {\n for (var i = 0; i < size; ++i) {\n that[i] = 0\n }\n }\n return that\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(null, 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(null, size)\n}\n\nfunction fromString (that, string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('\"encoding\" must be a valid string encoding')\n }\n\n var length = byteLength(string, encoding) | 0\n that = createBuffer(that, length)\n\n var actual = that.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 that = that.slice(0, actual)\n }\n\n return that\n}\n\nfunction fromArrayLike (that, array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n that = createBuffer(that, length)\n for (var i = 0; i < length; i += 1) {\n that[i] = array[i] & 255\n }\n return that\n}\n\nfunction fromArrayBuffer (that, array, byteOffset, length) {\n array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\\'offset\\' is out of bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\\'length\\' is out of bounds')\n }\n\n if (byteOffset === undefined && length === undefined) {\n array = new Uint8Array(array)\n } else if (length === undefined) {\n array = new Uint8Array(array, byteOffset)\n } else {\n array = new Uint8Array(array, byteOffset, length)\n }\n\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = array\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n that = fromArrayLike(that, array)\n }\n return that\n}\n\nfunction fromObject (that, obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n that = createBuffer(that, len)\n\n if (that.length === 0) {\n return that\n }\n\n obj.copy(that, 0, 0, len)\n return that\n }\n\n if (obj) {\n if ((typeof ArrayBuffer !== 'undefined' &&\n obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n if (typeof obj.length !== 'number' || isnan(obj.length)) {\n return createBuffer(that, 0)\n }\n return fromArrayLike(that, obj)\n }\n\n if (obj.type === 'Buffer' && isArray(obj.data)) {\n return fromArrayLike(that, obj.data)\n }\n }\n\n throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n // Note: cannot use `length < kMaxLength()` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= kMaxLength()) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + kMaxLength().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)\n}\n\nBuffer.compare = function compare (a, b) {\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError('Arguments must be Buffers')\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var 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 (!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 var 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 var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n buf.copy(buffer, pos)\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 (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n string = '' + string\n }\n\n var len = string.length\n if (len === 0) return 0\n\n // Use a for loop to avoid recursion\n var 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 case undefined:\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) return utf8ToBytes(string).length // assume utf8\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var 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 coersion 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// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var 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 var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var 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 var length = this.length | 0\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.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 var str = ''\n var max = exports.INSPECT_MAX_BYTES\n if (this.length > 0) {\n str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n if (this.length > max) str += ' ... '\n }\n return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (!Buffer.isBuffer(target)) {\n throw new TypeError('Argument must be a Buffer')\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 var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var 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 (isNaN(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 (Buffer.TYPED_ARRAY_SUPPORT &&\n 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 var indexSize = 1\n var arrLength = arr.length\n var 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 var i\n if (dir) {\n var 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 var found = true\n for (var 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 var 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 // must be an even number of digits\n var strLen = string.length\n if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (isNaN(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 latin1Write (buf, string, offset, length) {\n return asciiWrite(buf, string, 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 // legacy write(string, encoding, offset, length) - remove in v0.13\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var 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 var 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 return asciiWrite(this, string, offset, length)\n\n case 'latin1':\n case 'binary':\n return latin1Write(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 var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF) ? 4\n : (firstByte > 0xDF) ? 3\n : (firstByte > 0xBF) ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var 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\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var 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 var res = ''\n var 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 var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += toHex(buf[i])\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n for (var i = 0; i < bytes.length; 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 var 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 var newBuf\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n newBuf = this.subarray(start, end)\n newBuf.__proto__ = Buffer.prototype\n } else {\n var sliceLen = end - start\n newBuf = new Buffer(sliceLen, undefined)\n for (var i = 0; i < sliceLen; ++i) {\n newBuf[i] = this[i + start]\n }\n }\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 = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\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 var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\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 = function readUInt32BE (offset, noAssert) {\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.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var 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 var i = byteLength\n var mul = 1\n var 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 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 if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\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 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.readFloatLE = function readFloatLE (offset, noAssert) {\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 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 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 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 = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var 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 = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var 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 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) {\n buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n (littleEndian ? i : 1 - i) * 8\n }\n}\n\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\n return offset + 2\n}\n\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\n return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffffffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) {\n buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n }\n}\n\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\n return offset + 4\n}\n\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var 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 var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var 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 (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\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 if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\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 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 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 (!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('sourceStart out of bounds')\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 var len = end - start\n var i\n\n if (this === target && start < targetStart && targetStart < end) {\n // descending copy from end\n for (i = len - 1; i >= 0; --i) {\n target[i + targetStart] = this[i + start]\n }\n } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n // ascending copy from start\n for (i = 0; i < len; ++i) {\n target[i + targetStart] = this[i + start]\n }\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, start + len),\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 (val.length === 1) {\n var code = val.charCodeAt(0)\n if (code < 256) {\n val = code\n }\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 } else if (typeof val === 'number') {\n val = val & 255\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 var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : utf8ToBytes(new Buffer(val, encoding).toString())\n var len = bytes.length\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = stringtrim(str).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 stringtrim (str) {\n if (str.trim) return str.trim()\n return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n if (n < 16) return '0' + n.toString(16)\n return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var 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 var byteArray = []\n for (var 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 var c, hi, lo\n var byteArray = []\n for (var 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 for (var 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\nfunction isnan (val) {\n return val !== val // eslint-disable-line no-self-compare\n}\n"],"sourceRoot":""}
|