cli-nano 1.1.0 → 1.1.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/dist/index.d.ts +3 -8
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +255 -3
- package/dist/index.js.map +1 -0
- package/dist/interfaces.d.ts +92 -2
- package/dist/interfaces.d.ts.map +1 -0
- package/dist/interfaces.js +2 -0
- package/dist/interfaces.js.map +1 -0
- package/package.json +1 -1
- package/dist/__tests__/parse-args.spec.d.ts +0 -1
- package/dist/__tests__/parse-args.spec.js +0 -16083
- package/dist/__tests__/parse-args.spec.js.map +0 -1
- package/dist/interfaces-CqSzltdU.d.ts +0 -84
- package/dist/interfaces-CqSzltdU.d.ts.map +0 -1
- package/dist/magic-string.es-MPKlglyd.js +0 -1015
- package/dist/magic-string.es-MPKlglyd.js.map +0 -1
- package/dist/src-DQnZ842s.js +0 -217
- package/dist/src-DQnZ842s.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"magic-string.es-MPKlglyd.js","names":["n","segment","replacement"],"sources":["../node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.mjs","../node_modules/magic-string/dist/magic-string.es.mjs"],"sourcesContent":["const comma = ','.charCodeAt(0);\nconst semicolon = ';'.charCodeAt(0);\nconst chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\nconst intToChar = new Uint8Array(64); // 64 possible chars.\nconst charToInt = new Uint8Array(128); // z is 122 in ASCII\nfor (let i = 0; i < chars.length; i++) {\n const c = chars.charCodeAt(i);\n intToChar[i] = c;\n charToInt[c] = i;\n}\nfunction decodeInteger(reader, relative) {\n let value = 0;\n let shift = 0;\n let integer = 0;\n do {\n const c = reader.next();\n integer = charToInt[c];\n value |= (integer & 31) << shift;\n shift += 5;\n } while (integer & 32);\n const shouldNegate = value & 1;\n value >>>= 1;\n if (shouldNegate) {\n value = -0x80000000 | -value;\n }\n return relative + value;\n}\nfunction encodeInteger(builder, num, relative) {\n let delta = num - relative;\n delta = delta < 0 ? (-delta << 1) | 1 : delta << 1;\n do {\n let clamped = delta & 0b011111;\n delta >>>= 5;\n if (delta > 0)\n clamped |= 0b100000;\n builder.write(intToChar[clamped]);\n } while (delta > 0);\n return num;\n}\nfunction hasMoreVlq(reader, max) {\n if (reader.pos >= max)\n return false;\n return reader.peek() !== comma;\n}\n\nconst bufLength = 1024 * 16;\n// Provide a fallback for older environments.\nconst td = typeof TextDecoder !== 'undefined'\n ? /* #__PURE__ */ new TextDecoder()\n : typeof Buffer !== 'undefined'\n ? {\n decode(buf) {\n const out = Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength);\n return out.toString();\n },\n }\n : {\n decode(buf) {\n let out = '';\n for (let i = 0; i < buf.length; i++) {\n out += String.fromCharCode(buf[i]);\n }\n return out;\n },\n };\nclass StringWriter {\n constructor() {\n this.pos = 0;\n this.out = '';\n this.buffer = new Uint8Array(bufLength);\n }\n write(v) {\n const { buffer } = this;\n buffer[this.pos++] = v;\n if (this.pos === bufLength) {\n this.out += td.decode(buffer);\n this.pos = 0;\n }\n }\n flush() {\n const { buffer, out, pos } = this;\n return pos > 0 ? out + td.decode(buffer.subarray(0, pos)) : out;\n }\n}\nclass StringReader {\n constructor(buffer) {\n this.pos = 0;\n this.buffer = buffer;\n }\n next() {\n return this.buffer.charCodeAt(this.pos++);\n }\n peek() {\n return this.buffer.charCodeAt(this.pos);\n }\n indexOf(char) {\n const { buffer, pos } = this;\n const idx = buffer.indexOf(char, pos);\n return idx === -1 ? buffer.length : idx;\n }\n}\n\nconst EMPTY = [];\nfunction decodeOriginalScopes(input) {\n const { length } = input;\n const reader = new StringReader(input);\n const scopes = [];\n const stack = [];\n let line = 0;\n for (; reader.pos < length; reader.pos++) {\n line = decodeInteger(reader, line);\n const column = decodeInteger(reader, 0);\n if (!hasMoreVlq(reader, length)) {\n const last = stack.pop();\n last[2] = line;\n last[3] = column;\n continue;\n }\n const kind = decodeInteger(reader, 0);\n const fields = decodeInteger(reader, 0);\n const hasName = fields & 0b0001;\n const scope = (hasName ? [line, column, 0, 0, kind, decodeInteger(reader, 0)] : [line, column, 0, 0, kind]);\n let vars = EMPTY;\n if (hasMoreVlq(reader, length)) {\n vars = [];\n do {\n const varsIndex = decodeInteger(reader, 0);\n vars.push(varsIndex);\n } while (hasMoreVlq(reader, length));\n }\n scope.vars = vars;\n scopes.push(scope);\n stack.push(scope);\n }\n return scopes;\n}\nfunction encodeOriginalScopes(scopes) {\n const writer = new StringWriter();\n for (let i = 0; i < scopes.length;) {\n i = _encodeOriginalScopes(scopes, i, writer, [0]);\n }\n return writer.flush();\n}\nfunction _encodeOriginalScopes(scopes, index, writer, state) {\n const scope = scopes[index];\n const { 0: startLine, 1: startColumn, 2: endLine, 3: endColumn, 4: kind, vars } = scope;\n if (index > 0)\n writer.write(comma);\n state[0] = encodeInteger(writer, startLine, state[0]);\n encodeInteger(writer, startColumn, 0);\n encodeInteger(writer, kind, 0);\n const fields = scope.length === 6 ? 0b0001 : 0;\n encodeInteger(writer, fields, 0);\n if (scope.length === 6)\n encodeInteger(writer, scope[5], 0);\n for (const v of vars) {\n encodeInteger(writer, v, 0);\n }\n for (index++; index < scopes.length;) {\n const next = scopes[index];\n const { 0: l, 1: c } = next;\n if (l > endLine || (l === endLine && c >= endColumn)) {\n break;\n }\n index = _encodeOriginalScopes(scopes, index, writer, state);\n }\n writer.write(comma);\n state[0] = encodeInteger(writer, endLine, state[0]);\n encodeInteger(writer, endColumn, 0);\n return index;\n}\nfunction decodeGeneratedRanges(input) {\n const { length } = input;\n const reader = new StringReader(input);\n const ranges = [];\n const stack = [];\n let genLine = 0;\n let definitionSourcesIndex = 0;\n let definitionScopeIndex = 0;\n let callsiteSourcesIndex = 0;\n let callsiteLine = 0;\n let callsiteColumn = 0;\n let bindingLine = 0;\n let bindingColumn = 0;\n do {\n const semi = reader.indexOf(';');\n let genColumn = 0;\n for (; reader.pos < semi; reader.pos++) {\n genColumn = decodeInteger(reader, genColumn);\n if (!hasMoreVlq(reader, semi)) {\n const last = stack.pop();\n last[2] = genLine;\n last[3] = genColumn;\n continue;\n }\n const fields = decodeInteger(reader, 0);\n const hasDefinition = fields & 0b0001;\n const hasCallsite = fields & 0b0010;\n const hasScope = fields & 0b0100;\n let callsite = null;\n let bindings = EMPTY;\n let range;\n if (hasDefinition) {\n const defSourcesIndex = decodeInteger(reader, definitionSourcesIndex);\n definitionScopeIndex = decodeInteger(reader, definitionSourcesIndex === defSourcesIndex ? definitionScopeIndex : 0);\n definitionSourcesIndex = defSourcesIndex;\n range = [genLine, genColumn, 0, 0, defSourcesIndex, definitionScopeIndex];\n }\n else {\n range = [genLine, genColumn, 0, 0];\n }\n range.isScope = !!hasScope;\n if (hasCallsite) {\n const prevCsi = callsiteSourcesIndex;\n const prevLine = callsiteLine;\n callsiteSourcesIndex = decodeInteger(reader, callsiteSourcesIndex);\n const sameSource = prevCsi === callsiteSourcesIndex;\n callsiteLine = decodeInteger(reader, sameSource ? callsiteLine : 0);\n callsiteColumn = decodeInteger(reader, sameSource && prevLine === callsiteLine ? callsiteColumn : 0);\n callsite = [callsiteSourcesIndex, callsiteLine, callsiteColumn];\n }\n range.callsite = callsite;\n if (hasMoreVlq(reader, semi)) {\n bindings = [];\n do {\n bindingLine = genLine;\n bindingColumn = genColumn;\n const expressionsCount = decodeInteger(reader, 0);\n let expressionRanges;\n if (expressionsCount < -1) {\n expressionRanges = [[decodeInteger(reader, 0)]];\n for (let i = -1; i > expressionsCount; i--) {\n const prevBl = bindingLine;\n bindingLine = decodeInteger(reader, bindingLine);\n bindingColumn = decodeInteger(reader, bindingLine === prevBl ? bindingColumn : 0);\n const expression = decodeInteger(reader, 0);\n expressionRanges.push([expression, bindingLine, bindingColumn]);\n }\n }\n else {\n expressionRanges = [[expressionsCount]];\n }\n bindings.push(expressionRanges);\n } while (hasMoreVlq(reader, semi));\n }\n range.bindings = bindings;\n ranges.push(range);\n stack.push(range);\n }\n genLine++;\n reader.pos = semi + 1;\n } while (reader.pos < length);\n return ranges;\n}\nfunction encodeGeneratedRanges(ranges) {\n if (ranges.length === 0)\n return '';\n const writer = new StringWriter();\n for (let i = 0; i < ranges.length;) {\n i = _encodeGeneratedRanges(ranges, i, writer, [0, 0, 0, 0, 0, 0, 0]);\n }\n return writer.flush();\n}\nfunction _encodeGeneratedRanges(ranges, index, writer, state) {\n const range = ranges[index];\n const { 0: startLine, 1: startColumn, 2: endLine, 3: endColumn, isScope, callsite, bindings, } = range;\n if (state[0] < startLine) {\n catchupLine(writer, state[0], startLine);\n state[0] = startLine;\n state[1] = 0;\n }\n else if (index > 0) {\n writer.write(comma);\n }\n state[1] = encodeInteger(writer, range[1], state[1]);\n const fields = (range.length === 6 ? 0b0001 : 0) | (callsite ? 0b0010 : 0) | (isScope ? 0b0100 : 0);\n encodeInteger(writer, fields, 0);\n if (range.length === 6) {\n const { 4: sourcesIndex, 5: scopesIndex } = range;\n if (sourcesIndex !== state[2]) {\n state[3] = 0;\n }\n state[2] = encodeInteger(writer, sourcesIndex, state[2]);\n state[3] = encodeInteger(writer, scopesIndex, state[3]);\n }\n if (callsite) {\n const { 0: sourcesIndex, 1: callLine, 2: callColumn } = range.callsite;\n if (sourcesIndex !== state[4]) {\n state[5] = 0;\n state[6] = 0;\n }\n else if (callLine !== state[5]) {\n state[6] = 0;\n }\n state[4] = encodeInteger(writer, sourcesIndex, state[4]);\n state[5] = encodeInteger(writer, callLine, state[5]);\n state[6] = encodeInteger(writer, callColumn, state[6]);\n }\n if (bindings) {\n for (const binding of bindings) {\n if (binding.length > 1)\n encodeInteger(writer, -binding.length, 0);\n const expression = binding[0][0];\n encodeInteger(writer, expression, 0);\n let bindingStartLine = startLine;\n let bindingStartColumn = startColumn;\n for (let i = 1; i < binding.length; i++) {\n const expRange = binding[i];\n bindingStartLine = encodeInteger(writer, expRange[1], bindingStartLine);\n bindingStartColumn = encodeInteger(writer, expRange[2], bindingStartColumn);\n encodeInteger(writer, expRange[0], 0);\n }\n }\n }\n for (index++; index < ranges.length;) {\n const next = ranges[index];\n const { 0: l, 1: c } = next;\n if (l > endLine || (l === endLine && c >= endColumn)) {\n break;\n }\n index = _encodeGeneratedRanges(ranges, index, writer, state);\n }\n if (state[0] < endLine) {\n catchupLine(writer, state[0], endLine);\n state[0] = endLine;\n state[1] = 0;\n }\n else {\n writer.write(comma);\n }\n state[1] = encodeInteger(writer, endColumn, state[1]);\n return index;\n}\nfunction catchupLine(writer, lastLine, line) {\n do {\n writer.write(semicolon);\n } while (++lastLine < line);\n}\n\nfunction decode(mappings) {\n const { length } = mappings;\n const reader = new StringReader(mappings);\n const decoded = [];\n let genColumn = 0;\n let sourcesIndex = 0;\n let sourceLine = 0;\n let sourceColumn = 0;\n let namesIndex = 0;\n do {\n const semi = reader.indexOf(';');\n const line = [];\n let sorted = true;\n let lastCol = 0;\n genColumn = 0;\n while (reader.pos < semi) {\n let seg;\n genColumn = decodeInteger(reader, genColumn);\n if (genColumn < lastCol)\n sorted = false;\n lastCol = genColumn;\n if (hasMoreVlq(reader, semi)) {\n sourcesIndex = decodeInteger(reader, sourcesIndex);\n sourceLine = decodeInteger(reader, sourceLine);\n sourceColumn = decodeInteger(reader, sourceColumn);\n if (hasMoreVlq(reader, semi)) {\n namesIndex = decodeInteger(reader, namesIndex);\n seg = [genColumn, sourcesIndex, sourceLine, sourceColumn, namesIndex];\n }\n else {\n seg = [genColumn, sourcesIndex, sourceLine, sourceColumn];\n }\n }\n else {\n seg = [genColumn];\n }\n line.push(seg);\n reader.pos++;\n }\n if (!sorted)\n sort(line);\n decoded.push(line);\n reader.pos = semi + 1;\n } while (reader.pos <= length);\n return decoded;\n}\nfunction sort(line) {\n line.sort(sortComparator);\n}\nfunction sortComparator(a, b) {\n return a[0] - b[0];\n}\nfunction encode(decoded) {\n const writer = new StringWriter();\n let sourcesIndex = 0;\n let sourceLine = 0;\n let sourceColumn = 0;\n let namesIndex = 0;\n for (let i = 0; i < decoded.length; i++) {\n const line = decoded[i];\n if (i > 0)\n writer.write(semicolon);\n if (line.length === 0)\n continue;\n let genColumn = 0;\n for (let j = 0; j < line.length; j++) {\n const segment = line[j];\n if (j > 0)\n writer.write(comma);\n genColumn = encodeInteger(writer, segment[0], genColumn);\n if (segment.length === 1)\n continue;\n sourcesIndex = encodeInteger(writer, segment[1], sourcesIndex);\n sourceLine = encodeInteger(writer, segment[2], sourceLine);\n sourceColumn = encodeInteger(writer, segment[3], sourceColumn);\n if (segment.length === 4)\n continue;\n namesIndex = encodeInteger(writer, segment[4], namesIndex);\n }\n }\n return writer.flush();\n}\n\nexport { decode, decodeGeneratedRanges, decodeOriginalScopes, encode, encodeGeneratedRanges, encodeOriginalScopes };\n//# sourceMappingURL=sourcemap-codec.mjs.map\n","import { encode } from '@jridgewell/sourcemap-codec';\n\nclass BitSet {\n\tconstructor(arg) {\n\t\tthis.bits = arg instanceof BitSet ? arg.bits.slice() : [];\n\t}\n\n\tadd(n) {\n\t\tthis.bits[n >> 5] |= 1 << (n & 31);\n\t}\n\n\thas(n) {\n\t\treturn !!(this.bits[n >> 5] & (1 << (n & 31)));\n\t}\n}\n\nclass Chunk {\n\tconstructor(start, end, content) {\n\t\tthis.start = start;\n\t\tthis.end = end;\n\t\tthis.original = content;\n\n\t\tthis.intro = '';\n\t\tthis.outro = '';\n\n\t\tthis.content = content;\n\t\tthis.storeName = false;\n\t\tthis.edited = false;\n\n\t\t{\n\t\t\tthis.previous = null;\n\t\t\tthis.next = null;\n\t\t}\n\t}\n\n\tappendLeft(content) {\n\t\tthis.outro += content;\n\t}\n\n\tappendRight(content) {\n\t\tthis.intro = this.intro + content;\n\t}\n\n\tclone() {\n\t\tconst chunk = new Chunk(this.start, this.end, this.original);\n\n\t\tchunk.intro = this.intro;\n\t\tchunk.outro = this.outro;\n\t\tchunk.content = this.content;\n\t\tchunk.storeName = this.storeName;\n\t\tchunk.edited = this.edited;\n\n\t\treturn chunk;\n\t}\n\n\tcontains(index) {\n\t\treturn this.start < index && index < this.end;\n\t}\n\n\teachNext(fn) {\n\t\tlet chunk = this;\n\t\twhile (chunk) {\n\t\t\tfn(chunk);\n\t\t\tchunk = chunk.next;\n\t\t}\n\t}\n\n\teachPrevious(fn) {\n\t\tlet chunk = this;\n\t\twhile (chunk) {\n\t\t\tfn(chunk);\n\t\t\tchunk = chunk.previous;\n\t\t}\n\t}\n\n\tedit(content, storeName, contentOnly) {\n\t\tthis.content = content;\n\t\tif (!contentOnly) {\n\t\t\tthis.intro = '';\n\t\t\tthis.outro = '';\n\t\t}\n\t\tthis.storeName = storeName;\n\n\t\tthis.edited = true;\n\n\t\treturn this;\n\t}\n\n\tprependLeft(content) {\n\t\tthis.outro = content + this.outro;\n\t}\n\n\tprependRight(content) {\n\t\tthis.intro = content + this.intro;\n\t}\n\n\treset() {\n\t\tthis.intro = '';\n\t\tthis.outro = '';\n\t\tif (this.edited) {\n\t\t\tthis.content = this.original;\n\t\t\tthis.storeName = false;\n\t\t\tthis.edited = false;\n\t\t}\n\t}\n\n\tsplit(index) {\n\t\tconst sliceIndex = index - this.start;\n\n\t\tconst originalBefore = this.original.slice(0, sliceIndex);\n\t\tconst originalAfter = this.original.slice(sliceIndex);\n\n\t\tthis.original = originalBefore;\n\n\t\tconst newChunk = new Chunk(index, this.end, originalAfter);\n\t\tnewChunk.outro = this.outro;\n\t\tthis.outro = '';\n\n\t\tthis.end = index;\n\n\t\tif (this.edited) {\n\t\t\t// after split we should save the edit content record into the correct chunk\n\t\t\t// to make sure sourcemap correct\n\t\t\t// For example:\n\t\t\t// ' test'.trim()\n\t\t\t// split -> ' ' + 'test'\n\t\t\t// ✔️ edit -> '' + 'test'\n\t\t\t// ✖️ edit -> 'test' + ''\n\t\t\t// TODO is this block necessary?...\n\t\t\tnewChunk.edit('', false);\n\t\t\tthis.content = '';\n\t\t} else {\n\t\t\tthis.content = originalBefore;\n\t\t}\n\n\t\tnewChunk.next = this.next;\n\t\tif (newChunk.next) newChunk.next.previous = newChunk;\n\t\tnewChunk.previous = this;\n\t\tthis.next = newChunk;\n\n\t\treturn newChunk;\n\t}\n\n\ttoString() {\n\t\treturn this.intro + this.content + this.outro;\n\t}\n\n\ttrimEnd(rx) {\n\t\tthis.outro = this.outro.replace(rx, '');\n\t\tif (this.outro.length) return true;\n\n\t\tconst trimmed = this.content.replace(rx, '');\n\n\t\tif (trimmed.length) {\n\t\t\tif (trimmed !== this.content) {\n\t\t\t\tthis.split(this.start + trimmed.length).edit('', undefined, true);\n\t\t\t\tif (this.edited) {\n\t\t\t\t\t// save the change, if it has been edited\n\t\t\t\t\tthis.edit(trimmed, this.storeName, true);\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t} else {\n\t\t\tthis.edit('', undefined, true);\n\n\t\t\tthis.intro = this.intro.replace(rx, '');\n\t\t\tif (this.intro.length) return true;\n\t\t}\n\t}\n\n\ttrimStart(rx) {\n\t\tthis.intro = this.intro.replace(rx, '');\n\t\tif (this.intro.length) return true;\n\n\t\tconst trimmed = this.content.replace(rx, '');\n\n\t\tif (trimmed.length) {\n\t\t\tif (trimmed !== this.content) {\n\t\t\t\tconst newChunk = this.split(this.end - trimmed.length);\n\t\t\t\tif (this.edited) {\n\t\t\t\t\t// save the change, if it has been edited\n\t\t\t\t\tnewChunk.edit(trimmed, this.storeName, true);\n\t\t\t\t}\n\t\t\t\tthis.edit('', undefined, true);\n\t\t\t}\n\t\t\treturn true;\n\t\t} else {\n\t\t\tthis.edit('', undefined, true);\n\n\t\t\tthis.outro = this.outro.replace(rx, '');\n\t\t\tif (this.outro.length) return true;\n\t\t}\n\t}\n}\n\nfunction getBtoa() {\n\tif (typeof globalThis !== 'undefined' && typeof globalThis.btoa === 'function') {\n\t\treturn (str) => globalThis.btoa(unescape(encodeURIComponent(str)));\n\t} else if (typeof Buffer === 'function') {\n\t\treturn (str) => Buffer.from(str, 'utf-8').toString('base64');\n\t} else {\n\t\treturn () => {\n\t\t\tthrow new Error('Unsupported environment: `window.btoa` or `Buffer` should be supported.');\n\t\t};\n\t}\n}\n\nconst btoa = /*#__PURE__*/ getBtoa();\n\nclass SourceMap {\n\tconstructor(properties) {\n\t\tthis.version = 3;\n\t\tthis.file = properties.file;\n\t\tthis.sources = properties.sources;\n\t\tthis.sourcesContent = properties.sourcesContent;\n\t\tthis.names = properties.names;\n\t\tthis.mappings = encode(properties.mappings);\n\t\tif (typeof properties.x_google_ignoreList !== 'undefined') {\n\t\t\tthis.x_google_ignoreList = properties.x_google_ignoreList;\n\t\t}\n\t\tif (typeof properties.debugId !== 'undefined') {\n\t\t\tthis.debugId = properties.debugId;\n\t\t}\n\t}\n\n\ttoString() {\n\t\treturn JSON.stringify(this);\n\t}\n\n\ttoUrl() {\n\t\treturn 'data:application/json;charset=utf-8;base64,' + btoa(this.toString());\n\t}\n}\n\nfunction guessIndent(code) {\n\tconst lines = code.split('\\n');\n\n\tconst tabbed = lines.filter((line) => /^\\t+/.test(line));\n\tconst spaced = lines.filter((line) => /^ {2,}/.test(line));\n\n\tif (tabbed.length === 0 && spaced.length === 0) {\n\t\treturn null;\n\t}\n\n\t// More lines tabbed than spaced? Assume tabs, and\n\t// default to tabs in the case of a tie (or nothing\n\t// to go on)\n\tif (tabbed.length >= spaced.length) {\n\t\treturn '\\t';\n\t}\n\n\t// Otherwise, we need to guess the multiple\n\tconst min = spaced.reduce((previous, current) => {\n\t\tconst numSpaces = /^ +/.exec(current)[0].length;\n\t\treturn Math.min(numSpaces, previous);\n\t}, Infinity);\n\n\treturn new Array(min + 1).join(' ');\n}\n\nfunction getRelativePath(from, to) {\n\tconst fromParts = from.split(/[/\\\\]/);\n\tconst toParts = to.split(/[/\\\\]/);\n\n\tfromParts.pop(); // get dirname\n\n\twhile (fromParts[0] === toParts[0]) {\n\t\tfromParts.shift();\n\t\ttoParts.shift();\n\t}\n\n\tif (fromParts.length) {\n\t\tlet i = fromParts.length;\n\t\twhile (i--) fromParts[i] = '..';\n\t}\n\n\treturn fromParts.concat(toParts).join('/');\n}\n\nconst toString = Object.prototype.toString;\n\nfunction isObject(thing) {\n\treturn toString.call(thing) === '[object Object]';\n}\n\nfunction getLocator(source) {\n\tconst originalLines = source.split('\\n');\n\tconst lineOffsets = [];\n\n\tfor (let i = 0, pos = 0; i < originalLines.length; i++) {\n\t\tlineOffsets.push(pos);\n\t\tpos += originalLines[i].length + 1;\n\t}\n\n\treturn function locate(index) {\n\t\tlet i = 0;\n\t\tlet j = lineOffsets.length;\n\t\twhile (i < j) {\n\t\t\tconst m = (i + j) >> 1;\n\t\t\tif (index < lineOffsets[m]) {\n\t\t\t\tj = m;\n\t\t\t} else {\n\t\t\t\ti = m + 1;\n\t\t\t}\n\t\t}\n\t\tconst line = i - 1;\n\t\tconst column = index - lineOffsets[line];\n\t\treturn { line, column };\n\t};\n}\n\nconst wordRegex = /\\w/;\n\nclass Mappings {\n\tconstructor(hires) {\n\t\tthis.hires = hires;\n\t\tthis.generatedCodeLine = 0;\n\t\tthis.generatedCodeColumn = 0;\n\t\tthis.raw = [];\n\t\tthis.rawSegments = this.raw[this.generatedCodeLine] = [];\n\t\tthis.pending = null;\n\t}\n\n\taddEdit(sourceIndex, content, loc, nameIndex) {\n\t\tif (content.length) {\n\t\t\tconst contentLengthMinusOne = content.length - 1;\n\t\t\tlet contentLineEnd = content.indexOf('\\n', 0);\n\t\t\tlet previousContentLineEnd = -1;\n\t\t\t// Loop through each line in the content and add a segment, but stop if the last line is empty,\n\t\t\t// else code afterwards would fill one line too many\n\t\t\twhile (contentLineEnd >= 0 && contentLengthMinusOne > contentLineEnd) {\n\t\t\t\tconst segment = [this.generatedCodeColumn, sourceIndex, loc.line, loc.column];\n\t\t\t\tif (nameIndex >= 0) {\n\t\t\t\t\tsegment.push(nameIndex);\n\t\t\t\t}\n\t\t\t\tthis.rawSegments.push(segment);\n\n\t\t\t\tthis.generatedCodeLine += 1;\n\t\t\t\tthis.raw[this.generatedCodeLine] = this.rawSegments = [];\n\t\t\t\tthis.generatedCodeColumn = 0;\n\n\t\t\t\tpreviousContentLineEnd = contentLineEnd;\n\t\t\t\tcontentLineEnd = content.indexOf('\\n', contentLineEnd + 1);\n\t\t\t}\n\n\t\t\tconst segment = [this.generatedCodeColumn, sourceIndex, loc.line, loc.column];\n\t\t\tif (nameIndex >= 0) {\n\t\t\t\tsegment.push(nameIndex);\n\t\t\t}\n\t\t\tthis.rawSegments.push(segment);\n\n\t\t\tthis.advance(content.slice(previousContentLineEnd + 1));\n\t\t} else if (this.pending) {\n\t\t\tthis.rawSegments.push(this.pending);\n\t\t\tthis.advance(content);\n\t\t}\n\n\t\tthis.pending = null;\n\t}\n\n\taddUneditedChunk(sourceIndex, chunk, original, loc, sourcemapLocations) {\n\t\tlet originalCharIndex = chunk.start;\n\t\tlet first = true;\n\t\t// when iterating each char, check if it's in a word boundary\n\t\tlet charInHiresBoundary = false;\n\n\t\twhile (originalCharIndex < chunk.end) {\n\t\t\tif (original[originalCharIndex] === '\\n') {\n\t\t\t\tloc.line += 1;\n\t\t\t\tloc.column = 0;\n\t\t\t\tthis.generatedCodeLine += 1;\n\t\t\t\tthis.raw[this.generatedCodeLine] = this.rawSegments = [];\n\t\t\t\tthis.generatedCodeColumn = 0;\n\t\t\t\tfirst = true;\n\t\t\t\tcharInHiresBoundary = false;\n\t\t\t} else {\n\t\t\t\tif (this.hires || first || sourcemapLocations.has(originalCharIndex)) {\n\t\t\t\t\tconst segment = [this.generatedCodeColumn, sourceIndex, loc.line, loc.column];\n\n\t\t\t\t\tif (this.hires === 'boundary') {\n\t\t\t\t\t\t// in hires \"boundary\", group segments per word boundary than per char\n\t\t\t\t\t\tif (wordRegex.test(original[originalCharIndex])) {\n\t\t\t\t\t\t\t// for first char in the boundary found, start the boundary by pushing a segment\n\t\t\t\t\t\t\tif (!charInHiresBoundary) {\n\t\t\t\t\t\t\t\tthis.rawSegments.push(segment);\n\t\t\t\t\t\t\t\tcharInHiresBoundary = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// for non-word char, end the boundary by pushing a segment\n\t\t\t\t\t\t\tthis.rawSegments.push(segment);\n\t\t\t\t\t\t\tcharInHiresBoundary = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.rawSegments.push(segment);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tloc.column += 1;\n\t\t\t\tthis.generatedCodeColumn += 1;\n\t\t\t\tfirst = false;\n\t\t\t}\n\n\t\t\toriginalCharIndex += 1;\n\t\t}\n\n\t\tthis.pending = null;\n\t}\n\n\tadvance(str) {\n\t\tif (!str) return;\n\n\t\tconst lines = str.split('\\n');\n\n\t\tif (lines.length > 1) {\n\t\t\tfor (let i = 0; i < lines.length - 1; i++) {\n\t\t\t\tthis.generatedCodeLine++;\n\t\t\t\tthis.raw[this.generatedCodeLine] = this.rawSegments = [];\n\t\t\t}\n\t\t\tthis.generatedCodeColumn = 0;\n\t\t}\n\n\t\tthis.generatedCodeColumn += lines[lines.length - 1].length;\n\t}\n}\n\nconst n = '\\n';\n\nconst warned = {\n\tinsertLeft: false,\n\tinsertRight: false,\n\tstoreName: false,\n};\n\nclass MagicString {\n\tconstructor(string, options = {}) {\n\t\tconst chunk = new Chunk(0, string.length, string);\n\n\t\tObject.defineProperties(this, {\n\t\t\toriginal: { writable: true, value: string },\n\t\t\toutro: { writable: true, value: '' },\n\t\t\tintro: { writable: true, value: '' },\n\t\t\tfirstChunk: { writable: true, value: chunk },\n\t\t\tlastChunk: { writable: true, value: chunk },\n\t\t\tlastSearchedChunk: { writable: true, value: chunk },\n\t\t\tbyStart: { writable: true, value: {} },\n\t\t\tbyEnd: { writable: true, value: {} },\n\t\t\tfilename: { writable: true, value: options.filename },\n\t\t\tindentExclusionRanges: { writable: true, value: options.indentExclusionRanges },\n\t\t\tsourcemapLocations: { writable: true, value: new BitSet() },\n\t\t\tstoredNames: { writable: true, value: {} },\n\t\t\tindentStr: { writable: true, value: undefined },\n\t\t\tignoreList: { writable: true, value: options.ignoreList },\n\t\t\toffset: { writable: true, value: options.offset || 0 },\n\t\t});\n\n\t\tthis.byStart[0] = chunk;\n\t\tthis.byEnd[string.length] = chunk;\n\t}\n\n\taddSourcemapLocation(char) {\n\t\tthis.sourcemapLocations.add(char);\n\t}\n\n\tappend(content) {\n\t\tif (typeof content !== 'string') throw new TypeError('outro content must be a string');\n\n\t\tthis.outro += content;\n\t\treturn this;\n\t}\n\n\tappendLeft(index, content) {\n\t\tindex = index + this.offset;\n\n\t\tif (typeof content !== 'string') throw new TypeError('inserted content must be a string');\n\n\t\tthis._split(index);\n\n\t\tconst chunk = this.byEnd[index];\n\n\t\tif (chunk) {\n\t\t\tchunk.appendLeft(content);\n\t\t} else {\n\t\t\tthis.intro += content;\n\t\t}\n\t\treturn this;\n\t}\n\n\tappendRight(index, content) {\n\t\tindex = index + this.offset;\n\n\t\tif (typeof content !== 'string') throw new TypeError('inserted content must be a string');\n\n\t\tthis._split(index);\n\n\t\tconst chunk = this.byStart[index];\n\n\t\tif (chunk) {\n\t\t\tchunk.appendRight(content);\n\t\t} else {\n\t\t\tthis.outro += content;\n\t\t}\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\tconst cloned = new MagicString(this.original, { filename: this.filename, offset: this.offset });\n\n\t\tlet originalChunk = this.firstChunk;\n\t\tlet clonedChunk = (cloned.firstChunk = cloned.lastSearchedChunk = originalChunk.clone());\n\n\t\twhile (originalChunk) {\n\t\t\tcloned.byStart[clonedChunk.start] = clonedChunk;\n\t\t\tcloned.byEnd[clonedChunk.end] = clonedChunk;\n\n\t\t\tconst nextOriginalChunk = originalChunk.next;\n\t\t\tconst nextClonedChunk = nextOriginalChunk && nextOriginalChunk.clone();\n\n\t\t\tif (nextClonedChunk) {\n\t\t\t\tclonedChunk.next = nextClonedChunk;\n\t\t\t\tnextClonedChunk.previous = clonedChunk;\n\n\t\t\t\tclonedChunk = nextClonedChunk;\n\t\t\t}\n\n\t\t\toriginalChunk = nextOriginalChunk;\n\t\t}\n\n\t\tcloned.lastChunk = clonedChunk;\n\n\t\tif (this.indentExclusionRanges) {\n\t\t\tcloned.indentExclusionRanges = this.indentExclusionRanges.slice();\n\t\t}\n\n\t\tcloned.sourcemapLocations = new BitSet(this.sourcemapLocations);\n\n\t\tcloned.intro = this.intro;\n\t\tcloned.outro = this.outro;\n\n\t\treturn cloned;\n\t}\n\n\tgenerateDecodedMap(options) {\n\t\toptions = options || {};\n\n\t\tconst sourceIndex = 0;\n\t\tconst names = Object.keys(this.storedNames);\n\t\tconst mappings = new Mappings(options.hires);\n\n\t\tconst locate = getLocator(this.original);\n\n\t\tif (this.intro) {\n\t\t\tmappings.advance(this.intro);\n\t\t}\n\n\t\tthis.firstChunk.eachNext((chunk) => {\n\t\t\tconst loc = locate(chunk.start);\n\n\t\t\tif (chunk.intro.length) mappings.advance(chunk.intro);\n\n\t\t\tif (chunk.edited) {\n\t\t\t\tmappings.addEdit(\n\t\t\t\t\tsourceIndex,\n\t\t\t\t\tchunk.content,\n\t\t\t\t\tloc,\n\t\t\t\t\tchunk.storeName ? names.indexOf(chunk.original) : -1,\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tmappings.addUneditedChunk(sourceIndex, chunk, this.original, loc, this.sourcemapLocations);\n\t\t\t}\n\n\t\t\tif (chunk.outro.length) mappings.advance(chunk.outro);\n\t\t});\n\n\t\treturn {\n\t\t\tfile: options.file ? options.file.split(/[/\\\\]/).pop() : undefined,\n\t\t\tsources: [\n\t\t\t\toptions.source ? getRelativePath(options.file || '', options.source) : options.file || '',\n\t\t\t],\n\t\t\tsourcesContent: options.includeContent ? [this.original] : undefined,\n\t\t\tnames,\n\t\t\tmappings: mappings.raw,\n\t\t\tx_google_ignoreList: this.ignoreList ? [sourceIndex] : undefined,\n\t\t};\n\t}\n\n\tgenerateMap(options) {\n\t\treturn new SourceMap(this.generateDecodedMap(options));\n\t}\n\n\t_ensureindentStr() {\n\t\tif (this.indentStr === undefined) {\n\t\t\tthis.indentStr = guessIndent(this.original);\n\t\t}\n\t}\n\n\t_getRawIndentString() {\n\t\tthis._ensureindentStr();\n\t\treturn this.indentStr;\n\t}\n\n\tgetIndentString() {\n\t\tthis._ensureindentStr();\n\t\treturn this.indentStr === null ? '\\t' : this.indentStr;\n\t}\n\n\tindent(indentStr, options) {\n\t\tconst pattern = /^[^\\r\\n]/gm;\n\n\t\tif (isObject(indentStr)) {\n\t\t\toptions = indentStr;\n\t\t\tindentStr = undefined;\n\t\t}\n\n\t\tif (indentStr === undefined) {\n\t\t\tthis._ensureindentStr();\n\t\t\tindentStr = this.indentStr || '\\t';\n\t\t}\n\n\t\tif (indentStr === '') return this; // noop\n\n\t\toptions = options || {};\n\n\t\t// Process exclusion ranges\n\t\tconst isExcluded = {};\n\n\t\tif (options.exclude) {\n\t\t\tconst exclusions =\n\t\t\t\ttypeof options.exclude[0] === 'number' ? [options.exclude] : options.exclude;\n\t\t\texclusions.forEach((exclusion) => {\n\t\t\t\tfor (let i = exclusion[0]; i < exclusion[1]; i += 1) {\n\t\t\t\t\tisExcluded[i] = true;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\tlet shouldIndentNextCharacter = options.indentStart !== false;\n\t\tconst replacer = (match) => {\n\t\t\tif (shouldIndentNextCharacter) return `${indentStr}${match}`;\n\t\t\tshouldIndentNextCharacter = true;\n\t\t\treturn match;\n\t\t};\n\n\t\tthis.intro = this.intro.replace(pattern, replacer);\n\n\t\tlet charIndex = 0;\n\t\tlet chunk = this.firstChunk;\n\n\t\twhile (chunk) {\n\t\t\tconst end = chunk.end;\n\n\t\t\tif (chunk.edited) {\n\t\t\t\tif (!isExcluded[charIndex]) {\n\t\t\t\t\tchunk.content = chunk.content.replace(pattern, replacer);\n\n\t\t\t\t\tif (chunk.content.length) {\n\t\t\t\t\t\tshouldIndentNextCharacter = chunk.content[chunk.content.length - 1] === '\\n';\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tcharIndex = chunk.start;\n\n\t\t\t\twhile (charIndex < end) {\n\t\t\t\t\tif (!isExcluded[charIndex]) {\n\t\t\t\t\t\tconst char = this.original[charIndex];\n\n\t\t\t\t\t\tif (char === '\\n') {\n\t\t\t\t\t\t\tshouldIndentNextCharacter = true;\n\t\t\t\t\t\t} else if (char !== '\\r' && shouldIndentNextCharacter) {\n\t\t\t\t\t\t\tshouldIndentNextCharacter = false;\n\n\t\t\t\t\t\t\tif (charIndex === chunk.start) {\n\t\t\t\t\t\t\t\tchunk.prependRight(indentStr);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tthis._splitChunk(chunk, charIndex);\n\t\t\t\t\t\t\t\tchunk = chunk.next;\n\t\t\t\t\t\t\t\tchunk.prependRight(indentStr);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tcharIndex += 1;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tcharIndex = chunk.end;\n\t\t\tchunk = chunk.next;\n\t\t}\n\n\t\tthis.outro = this.outro.replace(pattern, replacer);\n\n\t\treturn this;\n\t}\n\n\tinsert() {\n\t\tthrow new Error(\n\t\t\t'magicString.insert(...) is deprecated. Use prependRight(...) or appendLeft(...)',\n\t\t);\n\t}\n\n\tinsertLeft(index, content) {\n\t\tif (!warned.insertLeft) {\n\t\t\tconsole.warn(\n\t\t\t\t'magicString.insertLeft(...) is deprecated. Use magicString.appendLeft(...) instead',\n\t\t\t);\n\t\t\twarned.insertLeft = true;\n\t\t}\n\n\t\treturn this.appendLeft(index, content);\n\t}\n\n\tinsertRight(index, content) {\n\t\tif (!warned.insertRight) {\n\t\t\tconsole.warn(\n\t\t\t\t'magicString.insertRight(...) is deprecated. Use magicString.prependRight(...) instead',\n\t\t\t);\n\t\t\twarned.insertRight = true;\n\t\t}\n\n\t\treturn this.prependRight(index, content);\n\t}\n\n\tmove(start, end, index) {\n\t\tstart = start + this.offset;\n\t\tend = end + this.offset;\n\t\tindex = index + this.offset;\n\n\t\tif (index >= start && index <= end) throw new Error('Cannot move a selection inside itself');\n\n\t\tthis._split(start);\n\t\tthis._split(end);\n\t\tthis._split(index);\n\n\t\tconst first = this.byStart[start];\n\t\tconst last = this.byEnd[end];\n\n\t\tconst oldLeft = first.previous;\n\t\tconst oldRight = last.next;\n\n\t\tconst newRight = this.byStart[index];\n\t\tif (!newRight && last === this.lastChunk) return this;\n\t\tconst newLeft = newRight ? newRight.previous : this.lastChunk;\n\n\t\tif (oldLeft) oldLeft.next = oldRight;\n\t\tif (oldRight) oldRight.previous = oldLeft;\n\n\t\tif (newLeft) newLeft.next = first;\n\t\tif (newRight) newRight.previous = last;\n\n\t\tif (!first.previous) this.firstChunk = last.next;\n\t\tif (!last.next) {\n\t\t\tthis.lastChunk = first.previous;\n\t\t\tthis.lastChunk.next = null;\n\t\t}\n\n\t\tfirst.previous = newLeft;\n\t\tlast.next = newRight || null;\n\n\t\tif (!newLeft) this.firstChunk = first;\n\t\tif (!newRight) this.lastChunk = last;\n\t\treturn this;\n\t}\n\n\toverwrite(start, end, content, options) {\n\t\toptions = options || {};\n\t\treturn this.update(start, end, content, { ...options, overwrite: !options.contentOnly });\n\t}\n\n\tupdate(start, end, content, options) {\n\t\tstart = start + this.offset;\n\t\tend = end + this.offset;\n\n\t\tif (typeof content !== 'string') throw new TypeError('replacement content must be a string');\n\n\t\tif (this.original.length !== 0) {\n\t\t\twhile (start < 0) start += this.original.length;\n\t\t\twhile (end < 0) end += this.original.length;\n\t\t}\n\n\t\tif (end > this.original.length) throw new Error('end is out of bounds');\n\t\tif (start === end)\n\t\t\tthrow new Error(\n\t\t\t\t'Cannot overwrite a zero-length range – use appendLeft or prependRight instead',\n\t\t\t);\n\n\t\tthis._split(start);\n\t\tthis._split(end);\n\n\t\tif (options === true) {\n\t\t\tif (!warned.storeName) {\n\t\t\t\tconsole.warn(\n\t\t\t\t\t'The final argument to magicString.overwrite(...) should be an options object. See https://github.com/rich-harris/magic-string',\n\t\t\t\t);\n\t\t\t\twarned.storeName = true;\n\t\t\t}\n\n\t\t\toptions = { storeName: true };\n\t\t}\n\t\tconst storeName = options !== undefined ? options.storeName : false;\n\t\tconst overwrite = options !== undefined ? options.overwrite : false;\n\n\t\tif (storeName) {\n\t\t\tconst original = this.original.slice(start, end);\n\t\t\tObject.defineProperty(this.storedNames, original, {\n\t\t\t\twritable: true,\n\t\t\t\tvalue: true,\n\t\t\t\tenumerable: true,\n\t\t\t});\n\t\t}\n\n\t\tconst first = this.byStart[start];\n\t\tconst last = this.byEnd[end];\n\n\t\tif (first) {\n\t\t\tlet chunk = first;\n\t\t\twhile (chunk !== last) {\n\t\t\t\tif (chunk.next !== this.byStart[chunk.end]) {\n\t\t\t\t\tthrow new Error('Cannot overwrite across a split point');\n\t\t\t\t}\n\t\t\t\tchunk = chunk.next;\n\t\t\t\tchunk.edit('', false);\n\t\t\t}\n\n\t\t\tfirst.edit(content, storeName, !overwrite);\n\t\t} else {\n\t\t\t// must be inserting at the end\n\t\t\tconst newChunk = new Chunk(start, end, '').edit(content, storeName);\n\n\t\t\t// TODO last chunk in the array may not be the last chunk, if it's moved...\n\t\t\tlast.next = newChunk;\n\t\t\tnewChunk.previous = last;\n\t\t}\n\t\treturn this;\n\t}\n\n\tprepend(content) {\n\t\tif (typeof content !== 'string') throw new TypeError('outro content must be a string');\n\n\t\tthis.intro = content + this.intro;\n\t\treturn this;\n\t}\n\n\tprependLeft(index, content) {\n\t\tindex = index + this.offset;\n\n\t\tif (typeof content !== 'string') throw new TypeError('inserted content must be a string');\n\n\t\tthis._split(index);\n\n\t\tconst chunk = this.byEnd[index];\n\n\t\tif (chunk) {\n\t\t\tchunk.prependLeft(content);\n\t\t} else {\n\t\t\tthis.intro = content + this.intro;\n\t\t}\n\t\treturn this;\n\t}\n\n\tprependRight(index, content) {\n\t\tindex = index + this.offset;\n\n\t\tif (typeof content !== 'string') throw new TypeError('inserted content must be a string');\n\n\t\tthis._split(index);\n\n\t\tconst chunk = this.byStart[index];\n\n\t\tif (chunk) {\n\t\t\tchunk.prependRight(content);\n\t\t} else {\n\t\t\tthis.outro = content + this.outro;\n\t\t}\n\t\treturn this;\n\t}\n\n\tremove(start, end) {\n\t\tstart = start + this.offset;\n\t\tend = end + this.offset;\n\n\t\tif (this.original.length !== 0) {\n\t\t\twhile (start < 0) start += this.original.length;\n\t\t\twhile (end < 0) end += this.original.length;\n\t\t}\n\n\t\tif (start === end) return this;\n\n\t\tif (start < 0 || end > this.original.length) throw new Error('Character is out of bounds');\n\t\tif (start > end) throw new Error('end must be greater than start');\n\n\t\tthis._split(start);\n\t\tthis._split(end);\n\n\t\tlet chunk = this.byStart[start];\n\n\t\twhile (chunk) {\n\t\t\tchunk.intro = '';\n\t\t\tchunk.outro = '';\n\t\t\tchunk.edit('');\n\n\t\t\tchunk = end > chunk.end ? this.byStart[chunk.end] : null;\n\t\t}\n\t\treturn this;\n\t}\n\n\treset(start, end) {\n\t\tstart = start + this.offset;\n\t\tend = end + this.offset;\n\n\t\tif (this.original.length !== 0) {\n\t\t\twhile (start < 0) start += this.original.length;\n\t\t\twhile (end < 0) end += this.original.length;\n\t\t}\n\n\t\tif (start === end) return this;\n\n\t\tif (start < 0 || end > this.original.length) throw new Error('Character is out of bounds');\n\t\tif (start > end) throw new Error('end must be greater than start');\n\n\t\tthis._split(start);\n\t\tthis._split(end);\n\n\t\tlet chunk = this.byStart[start];\n\n\t\twhile (chunk) {\n\t\t\tchunk.reset();\n\n\t\t\tchunk = end > chunk.end ? this.byStart[chunk.end] : null;\n\t\t}\n\t\treturn this;\n\t}\n\n\tlastChar() {\n\t\tif (this.outro.length) return this.outro[this.outro.length - 1];\n\t\tlet chunk = this.lastChunk;\n\t\tdo {\n\t\t\tif (chunk.outro.length) return chunk.outro[chunk.outro.length - 1];\n\t\t\tif (chunk.content.length) return chunk.content[chunk.content.length - 1];\n\t\t\tif (chunk.intro.length) return chunk.intro[chunk.intro.length - 1];\n\t\t} while ((chunk = chunk.previous));\n\t\tif (this.intro.length) return this.intro[this.intro.length - 1];\n\t\treturn '';\n\t}\n\n\tlastLine() {\n\t\tlet lineIndex = this.outro.lastIndexOf(n);\n\t\tif (lineIndex !== -1) return this.outro.substr(lineIndex + 1);\n\t\tlet lineStr = this.outro;\n\t\tlet chunk = this.lastChunk;\n\t\tdo {\n\t\t\tif (chunk.outro.length > 0) {\n\t\t\t\tlineIndex = chunk.outro.lastIndexOf(n);\n\t\t\t\tif (lineIndex !== -1) return chunk.outro.substr(lineIndex + 1) + lineStr;\n\t\t\t\tlineStr = chunk.outro + lineStr;\n\t\t\t}\n\n\t\t\tif (chunk.content.length > 0) {\n\t\t\t\tlineIndex = chunk.content.lastIndexOf(n);\n\t\t\t\tif (lineIndex !== -1) return chunk.content.substr(lineIndex + 1) + lineStr;\n\t\t\t\tlineStr = chunk.content + lineStr;\n\t\t\t}\n\n\t\t\tif (chunk.intro.length > 0) {\n\t\t\t\tlineIndex = chunk.intro.lastIndexOf(n);\n\t\t\t\tif (lineIndex !== -1) return chunk.intro.substr(lineIndex + 1) + lineStr;\n\t\t\t\tlineStr = chunk.intro + lineStr;\n\t\t\t}\n\t\t} while ((chunk = chunk.previous));\n\t\tlineIndex = this.intro.lastIndexOf(n);\n\t\tif (lineIndex !== -1) return this.intro.substr(lineIndex + 1) + lineStr;\n\t\treturn this.intro + lineStr;\n\t}\n\n\tslice(start = 0, end = this.original.length - this.offset) {\n\t\tstart = start + this.offset;\n\t\tend = end + this.offset;\n\n\t\tif (this.original.length !== 0) {\n\t\t\twhile (start < 0) start += this.original.length;\n\t\t\twhile (end < 0) end += this.original.length;\n\t\t}\n\n\t\tlet result = '';\n\n\t\t// find start chunk\n\t\tlet chunk = this.firstChunk;\n\t\twhile (chunk && (chunk.start > start || chunk.end <= start)) {\n\t\t\t// found end chunk before start\n\t\t\tif (chunk.start < end && chunk.end >= end) {\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\tchunk = chunk.next;\n\t\t}\n\n\t\tif (chunk && chunk.edited && chunk.start !== start)\n\t\t\tthrow new Error(`Cannot use replaced character ${start} as slice start anchor.`);\n\n\t\tconst startChunk = chunk;\n\t\twhile (chunk) {\n\t\t\tif (chunk.intro && (startChunk !== chunk || chunk.start === start)) {\n\t\t\t\tresult += chunk.intro;\n\t\t\t}\n\n\t\t\tconst containsEnd = chunk.start < end && chunk.end >= end;\n\t\t\tif (containsEnd && chunk.edited && chunk.end !== end)\n\t\t\t\tthrow new Error(`Cannot use replaced character ${end} as slice end anchor.`);\n\n\t\t\tconst sliceStart = startChunk === chunk ? start - chunk.start : 0;\n\t\t\tconst sliceEnd = containsEnd ? chunk.content.length + end - chunk.end : chunk.content.length;\n\n\t\t\tresult += chunk.content.slice(sliceStart, sliceEnd);\n\n\t\t\tif (chunk.outro && (!containsEnd || chunk.end === end)) {\n\t\t\t\tresult += chunk.outro;\n\t\t\t}\n\n\t\t\tif (containsEnd) {\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tchunk = chunk.next;\n\t\t}\n\n\t\treturn result;\n\t}\n\n\t// TODO deprecate this? not really very useful\n\tsnip(start, end) {\n\t\tconst clone = this.clone();\n\t\tclone.remove(0, start);\n\t\tclone.remove(end, clone.original.length);\n\n\t\treturn clone;\n\t}\n\n\t_split(index) {\n\t\tif (this.byStart[index] || this.byEnd[index]) return;\n\n\t\tlet chunk = this.lastSearchedChunk;\n\t\tconst searchForward = index > chunk.end;\n\n\t\twhile (chunk) {\n\t\t\tif (chunk.contains(index)) return this._splitChunk(chunk, index);\n\n\t\t\tchunk = searchForward ? this.byStart[chunk.end] : this.byEnd[chunk.start];\n\t\t}\n\t}\n\n\t_splitChunk(chunk, index) {\n\t\tif (chunk.edited && chunk.content.length) {\n\t\t\t// zero-length edited chunks are a special case (overlapping replacements)\n\t\t\tconst loc = getLocator(this.original)(index);\n\t\t\tthrow new Error(\n\t\t\t\t`Cannot split a chunk that has already been edited (${loc.line}:${loc.column} – \"${chunk.original}\")`,\n\t\t\t);\n\t\t}\n\n\t\tconst newChunk = chunk.split(index);\n\n\t\tthis.byEnd[index] = chunk;\n\t\tthis.byStart[index] = newChunk;\n\t\tthis.byEnd[newChunk.end] = newChunk;\n\n\t\tif (chunk === this.lastChunk) this.lastChunk = newChunk;\n\n\t\tthis.lastSearchedChunk = chunk;\n\t\treturn true;\n\t}\n\n\ttoString() {\n\t\tlet str = this.intro;\n\n\t\tlet chunk = this.firstChunk;\n\t\twhile (chunk) {\n\t\t\tstr += chunk.toString();\n\t\t\tchunk = chunk.next;\n\t\t}\n\n\t\treturn str + this.outro;\n\t}\n\n\tisEmpty() {\n\t\tlet chunk = this.firstChunk;\n\t\tdo {\n\t\t\tif (\n\t\t\t\t(chunk.intro.length && chunk.intro.trim()) ||\n\t\t\t\t(chunk.content.length && chunk.content.trim()) ||\n\t\t\t\t(chunk.outro.length && chunk.outro.trim())\n\t\t\t)\n\t\t\t\treturn false;\n\t\t} while ((chunk = chunk.next));\n\t\treturn true;\n\t}\n\n\tlength() {\n\t\tlet chunk = this.firstChunk;\n\t\tlet length = 0;\n\t\tdo {\n\t\t\tlength += chunk.intro.length + chunk.content.length + chunk.outro.length;\n\t\t} while ((chunk = chunk.next));\n\t\treturn length;\n\t}\n\n\ttrimLines() {\n\t\treturn this.trim('[\\\\r\\\\n]');\n\t}\n\n\ttrim(charType) {\n\t\treturn this.trimStart(charType).trimEnd(charType);\n\t}\n\n\ttrimEndAborted(charType) {\n\t\tconst rx = new RegExp((charType || '\\\\s') + '+$');\n\n\t\tthis.outro = this.outro.replace(rx, '');\n\t\tif (this.outro.length) return true;\n\n\t\tlet chunk = this.lastChunk;\n\n\t\tdo {\n\t\t\tconst end = chunk.end;\n\t\t\tconst aborted = chunk.trimEnd(rx);\n\n\t\t\t// if chunk was trimmed, we have a new lastChunk\n\t\t\tif (chunk.end !== end) {\n\t\t\t\tif (this.lastChunk === chunk) {\n\t\t\t\t\tthis.lastChunk = chunk.next;\n\t\t\t\t}\n\n\t\t\t\tthis.byEnd[chunk.end] = chunk;\n\t\t\t\tthis.byStart[chunk.next.start] = chunk.next;\n\t\t\t\tthis.byEnd[chunk.next.end] = chunk.next;\n\t\t\t}\n\n\t\t\tif (aborted) return true;\n\t\t\tchunk = chunk.previous;\n\t\t} while (chunk);\n\n\t\treturn false;\n\t}\n\n\ttrimEnd(charType) {\n\t\tthis.trimEndAborted(charType);\n\t\treturn this;\n\t}\n\ttrimStartAborted(charType) {\n\t\tconst rx = new RegExp('^' + (charType || '\\\\s') + '+');\n\n\t\tthis.intro = this.intro.replace(rx, '');\n\t\tif (this.intro.length) return true;\n\n\t\tlet chunk = this.firstChunk;\n\n\t\tdo {\n\t\t\tconst end = chunk.end;\n\t\t\tconst aborted = chunk.trimStart(rx);\n\n\t\t\tif (chunk.end !== end) {\n\t\t\t\t// special case...\n\t\t\t\tif (chunk === this.lastChunk) this.lastChunk = chunk.next;\n\n\t\t\t\tthis.byEnd[chunk.end] = chunk;\n\t\t\t\tthis.byStart[chunk.next.start] = chunk.next;\n\t\t\t\tthis.byEnd[chunk.next.end] = chunk.next;\n\t\t\t}\n\n\t\t\tif (aborted) return true;\n\t\t\tchunk = chunk.next;\n\t\t} while (chunk);\n\n\t\treturn false;\n\t}\n\n\ttrimStart(charType) {\n\t\tthis.trimStartAborted(charType);\n\t\treturn this;\n\t}\n\n\thasChanged() {\n\t\treturn this.original !== this.toString();\n\t}\n\n\t_replaceRegexp(searchValue, replacement) {\n\t\tfunction getReplacement(match, str) {\n\t\t\tif (typeof replacement === 'string') {\n\t\t\t\treturn replacement.replace(/\\$(\\$|&|\\d+)/g, (_, i) => {\n\t\t\t\t\t// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace#specifying_a_string_as_a_parameter\n\t\t\t\t\tif (i === '$') return '$';\n\t\t\t\t\tif (i === '&') return match[0];\n\t\t\t\t\tconst num = +i;\n\t\t\t\t\tif (num < match.length) return match[+i];\n\t\t\t\t\treturn `$${i}`;\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\treturn replacement(...match, match.index, str, match.groups);\n\t\t\t}\n\t\t}\n\t\tfunction matchAll(re, str) {\n\t\t\tlet match;\n\t\t\tconst matches = [];\n\t\t\twhile ((match = re.exec(str))) {\n\t\t\t\tmatches.push(match);\n\t\t\t}\n\t\t\treturn matches;\n\t\t}\n\t\tif (searchValue.global) {\n\t\t\tconst matches = matchAll(searchValue, this.original);\n\t\t\tmatches.forEach((match) => {\n\t\t\t\tif (match.index != null) {\n\t\t\t\t\tconst replacement = getReplacement(match, this.original);\n\t\t\t\t\tif (replacement !== match[0]) {\n\t\t\t\t\t\tthis.overwrite(match.index, match.index + match[0].length, replacement);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tconst match = this.original.match(searchValue);\n\t\t\tif (match && match.index != null) {\n\t\t\t\tconst replacement = getReplacement(match, this.original);\n\t\t\t\tif (replacement !== match[0]) {\n\t\t\t\t\tthis.overwrite(match.index, match.index + match[0].length, replacement);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn this;\n\t}\n\n\t_replaceString(string, replacement) {\n\t\tconst { original } = this;\n\t\tconst index = original.indexOf(string);\n\n\t\tif (index !== -1) {\n\t\t\tthis.overwrite(index, index + string.length, replacement);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\treplace(searchValue, replacement) {\n\t\tif (typeof searchValue === 'string') {\n\t\t\treturn this._replaceString(searchValue, replacement);\n\t\t}\n\n\t\treturn this._replaceRegexp(searchValue, replacement);\n\t}\n\n\t_replaceAllString(string, replacement) {\n\t\tconst { original } = this;\n\t\tconst stringLength = string.length;\n\t\tfor (\n\t\t\tlet index = original.indexOf(string);\n\t\t\tindex !== -1;\n\t\t\tindex = original.indexOf(string, index + stringLength)\n\t\t) {\n\t\t\tconst previous = original.slice(index, index + stringLength);\n\t\t\tif (previous !== replacement) this.overwrite(index, index + stringLength, replacement);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\treplaceAll(searchValue, replacement) {\n\t\tif (typeof searchValue === 'string') {\n\t\t\treturn this._replaceAllString(searchValue, replacement);\n\t\t}\n\n\t\tif (!searchValue.global) {\n\t\t\tthrow new TypeError(\n\t\t\t\t'MagicString.prototype.replaceAll called with a non-global RegExp argument',\n\t\t\t);\n\t\t}\n\n\t\treturn this._replaceRegexp(searchValue, replacement);\n\t}\n}\n\nconst hasOwnProp = Object.prototype.hasOwnProperty;\n\nclass Bundle {\n\tconstructor(options = {}) {\n\t\tthis.intro = options.intro || '';\n\t\tthis.separator = options.separator !== undefined ? options.separator : '\\n';\n\t\tthis.sources = [];\n\t\tthis.uniqueSources = [];\n\t\tthis.uniqueSourceIndexByFilename = {};\n\t}\n\n\taddSource(source) {\n\t\tif (source instanceof MagicString) {\n\t\t\treturn this.addSource({\n\t\t\t\tcontent: source,\n\t\t\t\tfilename: source.filename,\n\t\t\t\tseparator: this.separator,\n\t\t\t});\n\t\t}\n\n\t\tif (!isObject(source) || !source.content) {\n\t\t\tthrow new Error(\n\t\t\t\t'bundle.addSource() takes an object with a `content` property, which should be an instance of MagicString, and an optional `filename`',\n\t\t\t);\n\t\t}\n\n\t\t['filename', 'ignoreList', 'indentExclusionRanges', 'separator'].forEach((option) => {\n\t\t\tif (!hasOwnProp.call(source, option)) source[option] = source.content[option];\n\t\t});\n\n\t\tif (source.separator === undefined) {\n\t\t\t// TODO there's a bunch of this sort of thing, needs cleaning up\n\t\t\tsource.separator = this.separator;\n\t\t}\n\n\t\tif (source.filename) {\n\t\t\tif (!hasOwnProp.call(this.uniqueSourceIndexByFilename, source.filename)) {\n\t\t\t\tthis.uniqueSourceIndexByFilename[source.filename] = this.uniqueSources.length;\n\t\t\t\tthis.uniqueSources.push({ filename: source.filename, content: source.content.original });\n\t\t\t} else {\n\t\t\t\tconst uniqueSource = this.uniqueSources[this.uniqueSourceIndexByFilename[source.filename]];\n\t\t\t\tif (source.content.original !== uniqueSource.content) {\n\t\t\t\t\tthrow new Error(`Illegal source: same filename (${source.filename}), different contents`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.sources.push(source);\n\t\treturn this;\n\t}\n\n\tappend(str, options) {\n\t\tthis.addSource({\n\t\t\tcontent: new MagicString(str),\n\t\t\tseparator: (options && options.separator) || '',\n\t\t});\n\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\tconst bundle = new Bundle({\n\t\t\tintro: this.intro,\n\t\t\tseparator: this.separator,\n\t\t});\n\n\t\tthis.sources.forEach((source) => {\n\t\t\tbundle.addSource({\n\t\t\t\tfilename: source.filename,\n\t\t\t\tcontent: source.content.clone(),\n\t\t\t\tseparator: source.separator,\n\t\t\t});\n\t\t});\n\n\t\treturn bundle;\n\t}\n\n\tgenerateDecodedMap(options = {}) {\n\t\tconst names = [];\n\t\tlet x_google_ignoreList = undefined;\n\t\tthis.sources.forEach((source) => {\n\t\t\tObject.keys(source.content.storedNames).forEach((name) => {\n\t\t\t\tif (!~names.indexOf(name)) names.push(name);\n\t\t\t});\n\t\t});\n\n\t\tconst mappings = new Mappings(options.hires);\n\n\t\tif (this.intro) {\n\t\t\tmappings.advance(this.intro);\n\t\t}\n\n\t\tthis.sources.forEach((source, i) => {\n\t\t\tif (i > 0) {\n\t\t\t\tmappings.advance(this.separator);\n\t\t\t}\n\n\t\t\tconst sourceIndex = source.filename ? this.uniqueSourceIndexByFilename[source.filename] : -1;\n\t\t\tconst magicString = source.content;\n\t\t\tconst locate = getLocator(magicString.original);\n\n\t\t\tif (magicString.intro) {\n\t\t\t\tmappings.advance(magicString.intro);\n\t\t\t}\n\n\t\t\tmagicString.firstChunk.eachNext((chunk) => {\n\t\t\t\tconst loc = locate(chunk.start);\n\n\t\t\t\tif (chunk.intro.length) mappings.advance(chunk.intro);\n\n\t\t\t\tif (source.filename) {\n\t\t\t\t\tif (chunk.edited) {\n\t\t\t\t\t\tmappings.addEdit(\n\t\t\t\t\t\t\tsourceIndex,\n\t\t\t\t\t\t\tchunk.content,\n\t\t\t\t\t\t\tloc,\n\t\t\t\t\t\t\tchunk.storeName ? names.indexOf(chunk.original) : -1,\n\t\t\t\t\t\t);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tmappings.addUneditedChunk(\n\t\t\t\t\t\t\tsourceIndex,\n\t\t\t\t\t\t\tchunk,\n\t\t\t\t\t\t\tmagicString.original,\n\t\t\t\t\t\t\tloc,\n\t\t\t\t\t\t\tmagicString.sourcemapLocations,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tmappings.advance(chunk.content);\n\t\t\t\t}\n\n\t\t\t\tif (chunk.outro.length) mappings.advance(chunk.outro);\n\t\t\t});\n\n\t\t\tif (magicString.outro) {\n\t\t\t\tmappings.advance(magicString.outro);\n\t\t\t}\n\n\t\t\tif (source.ignoreList && sourceIndex !== -1) {\n\t\t\t\tif (x_google_ignoreList === undefined) {\n\t\t\t\t\tx_google_ignoreList = [];\n\t\t\t\t}\n\t\t\t\tx_google_ignoreList.push(sourceIndex);\n\t\t\t}\n\t\t});\n\n\t\treturn {\n\t\t\tfile: options.file ? options.file.split(/[/\\\\]/).pop() : undefined,\n\t\t\tsources: this.uniqueSources.map((source) => {\n\t\t\t\treturn options.file ? getRelativePath(options.file, source.filename) : source.filename;\n\t\t\t}),\n\t\t\tsourcesContent: this.uniqueSources.map((source) => {\n\t\t\t\treturn options.includeContent ? source.content : null;\n\t\t\t}),\n\t\t\tnames,\n\t\t\tmappings: mappings.raw,\n\t\t\tx_google_ignoreList,\n\t\t};\n\t}\n\n\tgenerateMap(options) {\n\t\treturn new SourceMap(this.generateDecodedMap(options));\n\t}\n\n\tgetIndentString() {\n\t\tconst indentStringCounts = {};\n\n\t\tthis.sources.forEach((source) => {\n\t\t\tconst indentStr = source.content._getRawIndentString();\n\n\t\t\tif (indentStr === null) return;\n\n\t\t\tif (!indentStringCounts[indentStr]) indentStringCounts[indentStr] = 0;\n\t\t\tindentStringCounts[indentStr] += 1;\n\t\t});\n\n\t\treturn (\n\t\t\tObject.keys(indentStringCounts).sort((a, b) => {\n\t\t\t\treturn indentStringCounts[a] - indentStringCounts[b];\n\t\t\t})[0] || '\\t'\n\t\t);\n\t}\n\n\tindent(indentStr) {\n\t\tif (!arguments.length) {\n\t\t\tindentStr = this.getIndentString();\n\t\t}\n\n\t\tif (indentStr === '') return this; // noop\n\n\t\tlet trailingNewline = !this.intro || this.intro.slice(-1) === '\\n';\n\n\t\tthis.sources.forEach((source, i) => {\n\t\t\tconst separator = source.separator !== undefined ? source.separator : this.separator;\n\t\t\tconst indentStart = trailingNewline || (i > 0 && /\\r?\\n$/.test(separator));\n\n\t\t\tsource.content.indent(indentStr, {\n\t\t\t\texclude: source.indentExclusionRanges,\n\t\t\t\tindentStart, //: trailingNewline || /\\r?\\n$/.test( separator ) //true///\\r?\\n/.test( separator )\n\t\t\t});\n\n\t\t\ttrailingNewline = source.content.lastChar() === '\\n';\n\t\t});\n\n\t\tif (this.intro) {\n\t\t\tthis.intro =\n\t\t\t\tindentStr +\n\t\t\t\tthis.intro.replace(/^[^\\n]/gm, (match, index) => {\n\t\t\t\t\treturn index > 0 ? indentStr + match : match;\n\t\t\t\t});\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tprepend(str) {\n\t\tthis.intro = str + this.intro;\n\t\treturn this;\n\t}\n\n\ttoString() {\n\t\tconst body = this.sources\n\t\t\t.map((source, i) => {\n\t\t\t\tconst separator = source.separator !== undefined ? source.separator : this.separator;\n\t\t\t\tconst str = (i > 0 ? separator : '') + source.content.toString();\n\n\t\t\t\treturn str;\n\t\t\t})\n\t\t\t.join('');\n\n\t\treturn this.intro + body;\n\t}\n\n\tisEmpty() {\n\t\tif (this.intro.length && this.intro.trim()) return false;\n\t\tif (this.sources.some((source) => !source.content.isEmpty())) return false;\n\t\treturn true;\n\t}\n\n\tlength() {\n\t\treturn this.sources.reduce(\n\t\t\t(length, source) => length + source.content.length(),\n\t\t\tthis.intro.length,\n\t\t);\n\t}\n\n\ttrimLines() {\n\t\treturn this.trim('[\\\\r\\\\n]');\n\t}\n\n\ttrim(charType) {\n\t\treturn this.trimStart(charType).trimEnd(charType);\n\t}\n\n\ttrimStart(charType) {\n\t\tconst rx = new RegExp('^' + (charType || '\\\\s') + '+');\n\t\tthis.intro = this.intro.replace(rx, '');\n\n\t\tif (!this.intro) {\n\t\t\tlet source;\n\t\t\tlet i = 0;\n\n\t\t\tdo {\n\t\t\t\tsource = this.sources[i++];\n\t\t\t\tif (!source) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t} while (!source.content.trimStartAborted(charType));\n\t\t}\n\n\t\treturn this;\n\t}\n\n\ttrimEnd(charType) {\n\t\tconst rx = new RegExp((charType || '\\\\s') + '+$');\n\n\t\tlet source;\n\t\tlet i = this.sources.length - 1;\n\n\t\tdo {\n\t\t\tsource = this.sources[i--];\n\t\t\tif (!source) {\n\t\t\t\tthis.intro = this.intro.replace(rx, '');\n\t\t\t\tbreak;\n\t\t\t}\n\t\t} while (!source.content.trimEndAborted(charType));\n\n\t\treturn this;\n\t}\n}\n\nexport { Bundle, SourceMap, MagicString as default };\n//# sourceMappingURL=magic-string.es.mjs.map\n"],"x_google_ignoreList":[0,1],"mappings":"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"}
|
package/dist/src-DQnZ842s.js
DELETED
|
@@ -1,217 +0,0 @@
|
|
|
1
|
-
//#region src/index.ts
|
|
2
|
-
const defaultOptions = {
|
|
3
|
-
help: {
|
|
4
|
-
alias: "h",
|
|
5
|
-
description: "Show help",
|
|
6
|
-
type: "boolean"
|
|
7
|
-
},
|
|
8
|
-
version: {
|
|
9
|
-
alias: "v",
|
|
10
|
-
description: "Show version number",
|
|
11
|
-
type: "boolean"
|
|
12
|
-
}
|
|
13
|
-
};
|
|
14
|
-
function parseArgs(config) {
|
|
15
|
-
const { command, options, version } = config;
|
|
16
|
-
const args = process.argv.slice(2).flatMap((arg) => {
|
|
17
|
-
if (/^--?\w[\w-]*=/.test(arg)) {
|
|
18
|
-
const [flag, ...rest] = arg.split("=");
|
|
19
|
-
return [flag, rest.join("=")];
|
|
20
|
-
}
|
|
21
|
-
return arg;
|
|
22
|
-
});
|
|
23
|
-
const result = {};
|
|
24
|
-
const aliasMap = /* @__PURE__ */ new Map();
|
|
25
|
-
for (const [key, opt] of Object.entries(options)) if (opt.alias) {
|
|
26
|
-
if (aliasMap.has(opt.alias)) throw new Error(`Duplicate alias detected: "${opt.alias}" used for both "${aliasMap.get(opt.alias)}" and "${key}"`);
|
|
27
|
-
aliasMap.set(opt.alias, key);
|
|
28
|
-
}
|
|
29
|
-
if (args.includes("--help") || args.includes("-h")) {
|
|
30
|
-
printHelp(config);
|
|
31
|
-
process.exit(0);
|
|
32
|
-
}
|
|
33
|
-
if (version && args.includes("--version") || args.includes("-v")) {
|
|
34
|
-
console.log(version || "No version specified");
|
|
35
|
-
process.exit(0);
|
|
36
|
-
}
|
|
37
|
-
const positionals = command.positionals ?? [];
|
|
38
|
-
let foundOptional = false;
|
|
39
|
-
for (const pos of positionals) {
|
|
40
|
-
if (!pos.required) foundOptional = true;
|
|
41
|
-
if (foundOptional && pos.required) throw new Error(`Invalid positional argument configuration: required positional "${pos.name}" cannot follow optional positional(s).`);
|
|
42
|
-
}
|
|
43
|
-
let argIndex = 0;
|
|
44
|
-
const nonOptionArgs = [];
|
|
45
|
-
while (argIndex < args.length && !args[argIndex].startsWith("-")) {
|
|
46
|
-
nonOptionArgs.push(args[argIndex]);
|
|
47
|
-
argIndex++;
|
|
48
|
-
}
|
|
49
|
-
let nonOptionIndex = 0;
|
|
50
|
-
for (let i = 0; i < positionals.length; i++) {
|
|
51
|
-
const pos = positionals[i];
|
|
52
|
-
if (pos.variadic) {
|
|
53
|
-
const remaining = positionals.length - (i + 1);
|
|
54
|
-
const values = nonOptionArgs.slice(nonOptionIndex, nonOptionArgs.length - remaining);
|
|
55
|
-
if (pos.required && values.length === 0) {
|
|
56
|
-
const usagePositionals = buildUsagePositionals(positionals);
|
|
57
|
-
throw new Error(`Missing required positional argument, i.e.: "${command.name} ${usagePositionals}"`);
|
|
58
|
-
}
|
|
59
|
-
result[pos.name] = !pos.required && values.length === 0 && pos.default !== void 0 ? pos.default : values;
|
|
60
|
-
nonOptionIndex += values.length;
|
|
61
|
-
} else {
|
|
62
|
-
const value = nonOptionArgs[nonOptionIndex];
|
|
63
|
-
const requiredLeft = positionals.slice(i).filter((p) => p.required).length;
|
|
64
|
-
const argsLeft = nonOptionArgs.length - nonOptionIndex;
|
|
65
|
-
if (value !== void 0 && (argsLeft > requiredLeft - (pos.required ? 1 : 0) || pos.required)) {
|
|
66
|
-
result[pos.name] = value;
|
|
67
|
-
nonOptionIndex++;
|
|
68
|
-
} else if (!pos.required && pos.default !== void 0) result[pos.name] = pos.default;
|
|
69
|
-
else if (pos.required) {
|
|
70
|
-
const usagePositionals = buildUsagePositionals(positionals);
|
|
71
|
-
throw new Error(`Missing required positional argument, i.e.: "${command.name} ${usagePositionals}"`);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
argIndex = 0;
|
|
76
|
-
const consumedArgs = /* @__PURE__ */ new Set();
|
|
77
|
-
let tempNonOptionIndex = 0;
|
|
78
|
-
for (let i = 0; i < positionals.length; i++) {
|
|
79
|
-
const pos = positionals[i];
|
|
80
|
-
if (pos.variadic) {
|
|
81
|
-
const remaining = positionals.length - (i + 1);
|
|
82
|
-
const values = nonOptionArgs.slice(tempNonOptionIndex, nonOptionArgs.length - remaining);
|
|
83
|
-
for (let j = tempNonOptionIndex; j < tempNonOptionIndex + values.length; j++) consumedArgs.add(args.findIndex((a, idx) => !a.startsWith("-") && !consumedArgs.has(idx) && a === nonOptionArgs[j]));
|
|
84
|
-
tempNonOptionIndex += values.length;
|
|
85
|
-
} else {
|
|
86
|
-
const value = nonOptionArgs[tempNonOptionIndex++];
|
|
87
|
-
consumedArgs.add(args.findIndex((a, idx) => !a.startsWith("-") && !consumedArgs.has(idx) && a === value));
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
while (argIndex < args.length) {
|
|
91
|
-
if (consumedArgs.has(argIndex)) {
|
|
92
|
-
argIndex++;
|
|
93
|
-
continue;
|
|
94
|
-
}
|
|
95
|
-
const argOrg = args[argIndex] || "";
|
|
96
|
-
let arg = argOrg;
|
|
97
|
-
let option;
|
|
98
|
-
let configKey;
|
|
99
|
-
if (argOrg.startsWith("-")) {
|
|
100
|
-
if (argOrg.startsWith("--")) {
|
|
101
|
-
arg = argOrg.slice(2);
|
|
102
|
-
[option, configKey] = findOption(options, arg);
|
|
103
|
-
} else if (argOrg.startsWith("-")) {
|
|
104
|
-
arg = argOrg.slice(1);
|
|
105
|
-
[option, configKey] = findOption(options, arg);
|
|
106
|
-
}
|
|
107
|
-
if (!option) {
|
|
108
|
-
const isNegated = arg.startsWith("no-");
|
|
109
|
-
const optionName = isNegated ? arg.slice(3) : arg;
|
|
110
|
-
const camelOptionName = kebabToCamel(optionName);
|
|
111
|
-
option = options[optionName] || options[camelOptionName];
|
|
112
|
-
configKey = camelOptionName in options ? camelOptionName : optionName;
|
|
113
|
-
if (option?.type === "boolean") {
|
|
114
|
-
if (result[optionName] !== void 0 || result[camelOptionName] !== void 0) throw new Error("Providing same negated and truthy argument are not allowed");
|
|
115
|
-
result[configKey] = !isNegated;
|
|
116
|
-
argIndex++;
|
|
117
|
-
continue;
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
if (!option || !configKey) throw new Error(`Unknown CLI option: ${arg}`);
|
|
121
|
-
switch (option.type) {
|
|
122
|
-
case "boolean":
|
|
123
|
-
if (result[configKey] !== void 0) throw new Error("Providing same negated and truthy argument are not allowed");
|
|
124
|
-
result[configKey] = !argOrg.startsWith("--no-") && !argOrg.startsWith("-no-");
|
|
125
|
-
break;
|
|
126
|
-
case "number":
|
|
127
|
-
if (args[argIndex + 1] === void 0 || args[argIndex + 1].startsWith("-")) throw new Error(`Missing value for option: ${configKey}`);
|
|
128
|
-
result[configKey] = Number(args[++argIndex]);
|
|
129
|
-
break;
|
|
130
|
-
case "array": {
|
|
131
|
-
if (!result[configKey]) result[configKey] = [];
|
|
132
|
-
const arrayValue = args[++argIndex];
|
|
133
|
-
if (arrayValue === void 0 || arrayValue.startsWith("-")) throw new Error(`Missing value for array option: ${configKey}`);
|
|
134
|
-
result[configKey].push(arrayValue);
|
|
135
|
-
break;
|
|
136
|
-
}
|
|
137
|
-
case "string":
|
|
138
|
-
default:
|
|
139
|
-
if (args[argIndex + 1] === void 0 || args[argIndex + 1].startsWith("-")) throw new Error(`Missing value for option: ${configKey}`);
|
|
140
|
-
result[configKey] = args[++argIndex];
|
|
141
|
-
break;
|
|
142
|
-
}
|
|
143
|
-
} else throw new Error(`Unknown argument: ${arg}`);
|
|
144
|
-
argIndex++;
|
|
145
|
-
}
|
|
146
|
-
Object.entries(options).forEach(([key, opt]) => {
|
|
147
|
-
if (result[key] === void 0 && opt.default !== void 0) result[key] = opt.default;
|
|
148
|
-
if (opt.required && result[key] === void 0) {
|
|
149
|
-
const aliasStr = opt.alias ? `-${opt.alias}, ` : "";
|
|
150
|
-
throw new Error(`Missing required option: ${aliasStr}--${key}`);
|
|
151
|
-
}
|
|
152
|
-
});
|
|
153
|
-
return result;
|
|
154
|
-
}
|
|
155
|
-
/** Format a text to a fixed length, truncating and padding as needed. */
|
|
156
|
-
function formatHelpText(text, max) {
|
|
157
|
-
const truncated = text.length > max ? `${text.slice(0, max - 3)}...` : text;
|
|
158
|
-
return truncated.padEnd(max);
|
|
159
|
-
}
|
|
160
|
-
/** Build the usage string for positionals, e.g. "<input..> [output]" */
|
|
161
|
-
function buildUsagePositionals(positionals = []) {
|
|
162
|
-
return positionals.map((p) => {
|
|
163
|
-
const variadic = p.variadic ? ".." : "";
|
|
164
|
-
return p.required ? `<${p.name}${variadic}>` : `[${p.name}${variadic}]`;
|
|
165
|
-
}).join(" ");
|
|
166
|
-
}
|
|
167
|
-
/** Format the option/argument type for help output */
|
|
168
|
-
function formatOptionType(type, variadic, required) {
|
|
169
|
-
const t = type || "string";
|
|
170
|
-
const variadicStr = variadic ? ".." : "";
|
|
171
|
-
return required ? `<${t}${variadicStr}>` : `[${t}${variadicStr}]`;
|
|
172
|
-
}
|
|
173
|
-
/** Helper to find an option and its config key by argument name or alias. */
|
|
174
|
-
function findOption(options, arg) {
|
|
175
|
-
const option = options[arg] || options[kebabToCamel(arg)] || options[camelToKebab(arg).replace(/-/g, "")];
|
|
176
|
-
if (option) {
|
|
177
|
-
const configKey = Object.keys(options).find((key) => options[key] === option);
|
|
178
|
-
return [option, configKey];
|
|
179
|
-
}
|
|
180
|
-
for (const key of Object.keys(options)) {
|
|
181
|
-
const opt = options[key];
|
|
182
|
-
if (opt.alias && (opt.alias === arg || opt.alias === kebabToCamel(arg) || opt.alias === camelToKebab(arg))) return [opt, key];
|
|
183
|
-
}
|
|
184
|
-
return [void 0, void 0];
|
|
185
|
-
}
|
|
186
|
-
/** Print CLI help documentation to the screen */
|
|
187
|
-
function printHelp(config) {
|
|
188
|
-
const { command, options, version, helpOptLength = 20, helpDescLength = 65 } = config;
|
|
189
|
-
const usagePositionals = buildUsagePositionals(command.positionals);
|
|
190
|
-
console.log("Usage:");
|
|
191
|
-
console.log(` ${command.name} ${usagePositionals} [options] ${command.description}`);
|
|
192
|
-
console.log("\nArguments:");
|
|
193
|
-
command.positionals?.forEach((arg) => {
|
|
194
|
-
console.log(` ${formatHelpText(arg.name, helpOptLength)}${formatHelpText(arg.description, helpDescLength)} ${formatOptionType(arg.type, arg.variadic, arg.required)}`);
|
|
195
|
-
});
|
|
196
|
-
console.log("\nOptions:");
|
|
197
|
-
for (const [key, option] of Object.entries({
|
|
198
|
-
...options,
|
|
199
|
-
...defaultOptions
|
|
200
|
-
})) {
|
|
201
|
-
const aliasStr = option.alias ? `-${option.alias}, ` : "";
|
|
202
|
-
if (!version && key === "version") continue;
|
|
203
|
-
console.log(` ${aliasStr.padEnd(4)}--${formatHelpText(key, helpOptLength - 6)}${formatHelpText(option.description || "", helpDescLength)} ${formatOptionType(option.type, false, option.required)}`);
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
/** Utility to convert kebab-case to camelCase */
|
|
207
|
-
function kebabToCamel(str) {
|
|
208
|
-
return str.replace(/-([a-z])/g, (_, c) => c.toUpperCase());
|
|
209
|
-
}
|
|
210
|
-
/** Utility to convert camelCase to kebab-case */
|
|
211
|
-
function camelToKebab(str) {
|
|
212
|
-
return str.replace(/([a-z0-9])([A-Z])/g, "$1-$2").toLowerCase();
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
//#endregion
|
|
216
|
-
export { parseArgs };
|
|
217
|
-
//# sourceMappingURL=src-DQnZ842s.js.map
|
package/dist/src-DQnZ842s.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"src-DQnZ842s.js","names":["defaultOptions: Record<string, ArgumentOptions>","config: C","result: Record<string, any>","nonOptionArgs: string[]","option: ArgumentOptions | undefined","configKey: string | undefined","text: string","max: number","positionals: readonly any[]","type: string | undefined","variadic?: boolean","required?: boolean","options: Record<string, ArgumentOptions>","arg: string","config: Config","str: string"],"sources":["../src/index.ts"],"sourcesContent":["import type { ArgsResult, ArgumentOptions, Config } from './interfaces.js';\n\nexport type * from './interfaces.js';\n\nconst defaultOptions: Record<string, ArgumentOptions> = {\n help: { alias: 'h', description: 'Show help', type: 'boolean' },\n version: { alias: 'v', description: 'Show version number', type: 'boolean' },\n};\n\nexport function parseArgs<C extends Config>(config: C): ArgsResult<C> {\n const { command, options, version } = config;\n\n // Normalize args to support --option=value and -o=value\n const args = process.argv.slice(2).flatMap(arg => {\n if (/^--?\\w[\\w-]*=/.test(arg)) {\n const [flag, ...rest] = arg.split('=');\n return [flag, rest.join('=')];\n }\n return arg;\n });\n const result: Record<string, any> = {};\n\n // Check for duplicate aliases\n const aliasMap = new Map<string, string>();\n for (const [key, opt] of Object.entries(options)) {\n if (opt.alias) {\n if (aliasMap.has(opt.alias)) {\n throw new Error(`Duplicate alias detected: \"${opt.alias}\" used for both \"${aliasMap.get(opt.alias)}\" and \"${key}\"`);\n }\n aliasMap.set(opt.alias, key);\n }\n }\n\n // Handle --help and --version before anything else\n if (args.includes('--help') || args.includes('-h')) {\n printHelp(config);\n process.exit(0);\n }\n if ((version && args.includes('--version')) || args.includes('-v')) {\n console.log(version || 'No version specified');\n process.exit(0);\n }\n\n // Validate: required positionals must come before optional ones\n const positionals = command.positionals ?? [];\n let foundOptional = false;\n for (const pos of positionals) {\n if (!pos.required) {\n foundOptional = true;\n }\n if (foundOptional && pos.required) {\n throw new Error(`Invalid positional argument configuration: required positional \"${pos.name}\" cannot follow optional positional(s).`);\n }\n }\n\n // Handle positional arguments\n let argIndex = 0;\n const nonOptionArgs: string[] = [];\n while (argIndex < args.length && !args[argIndex].startsWith('-')) {\n nonOptionArgs.push(args[argIndex]);\n argIndex++;\n }\n\n let nonOptionIndex = 0;\n for (let i = 0; i < positionals.length; i++) {\n const pos = positionals[i];\n if (pos.variadic) {\n const remaining = positionals.length - (i + 1);\n const values = nonOptionArgs.slice(nonOptionIndex, nonOptionArgs.length - remaining);\n if (pos.required && values.length === 0) {\n const usagePositionals = buildUsagePositionals(positionals);\n throw new Error(`Missing required positional argument, i.e.: \"${command.name} ${usagePositionals}\"`);\n }\n result[pos.name] = !pos.required && values.length === 0 && pos.default !== undefined ? pos.default : values;\n nonOptionIndex += values.length;\n } else {\n const value = nonOptionArgs[nonOptionIndex];\n // Check if there are enough args left for required positionals\n const requiredLeft = positionals.slice(i).filter(p => p.required).length;\n const argsLeft = nonOptionArgs.length - nonOptionIndex;\n if (value !== undefined && (argsLeft > requiredLeft - (pos.required ? 1 : 0) || pos.required)) {\n result[pos.name] = value;\n nonOptionIndex++;\n } else if (!pos.required && pos.default !== undefined) {\n result[pos.name] = pos.default;\n } else if (pos.required) {\n const usagePositionals = buildUsagePositionals(positionals);\n throw new Error(`Missing required positional argument, i.e.: \"${command.name} ${usagePositionals}\"`);\n }\n }\n }\n\n // Handle options\n argIndex = 0;\n const consumedArgs = new Set<number>();\n // Mark all nonOptionArgs indices as consumed for positionals\n let tempNonOptionIndex = 0;\n for (let i = 0; i < positionals.length; i++) {\n const pos = positionals[i];\n if (pos.variadic) {\n const remaining = positionals.length - (i + 1);\n const values = nonOptionArgs.slice(tempNonOptionIndex, nonOptionArgs.length - remaining);\n for (let j = tempNonOptionIndex; j < tempNonOptionIndex + values.length; j++) {\n consumedArgs.add(args.findIndex((a, idx) => !a.startsWith('-') && !consumedArgs.has(idx) && a === nonOptionArgs[j]));\n }\n tempNonOptionIndex += values.length;\n } else {\n const value = nonOptionArgs[tempNonOptionIndex++];\n consumedArgs.add(args.findIndex((a, idx) => !a.startsWith('-') && !consumedArgs.has(idx) && a === value));\n }\n }\n\n while (argIndex < args.length) {\n if (consumedArgs.has(argIndex)) {\n argIndex++;\n continue;\n }\n const argOrg = args[argIndex] || '';\n let arg = argOrg;\n let option: ArgumentOptions | undefined;\n let configKey: string | undefined;\n\n if (argOrg.startsWith('-')) {\n if (argOrg.startsWith('--')) {\n arg = argOrg.slice(2);\n [option, configKey] = findOption(options, arg);\n } else if (argOrg.startsWith('-')) {\n arg = argOrg.slice(1);\n [option, configKey] = findOption(options, arg);\n }\n\n // Handle negated boolean in both forms\n if (!option) {\n const isNegated = arg.startsWith('no-');\n const optionName = isNegated ? arg.slice(3) : arg;\n const camelOptionName = kebabToCamel(optionName);\n option = options[optionName] || options[camelOptionName];\n configKey = camelOptionName in options ? camelOptionName : optionName;\n if (option?.type === 'boolean') {\n if (result[optionName] !== undefined || result[camelOptionName] !== undefined) {\n throw new Error('Providing same negated and truthy argument are not allowed');\n }\n result[configKey] = !isNegated;\n argIndex++;\n continue;\n }\n }\n\n if (!option || !configKey) {\n throw new Error(`Unknown CLI option: ${arg}`);\n }\n\n switch (option.type) {\n case 'boolean':\n if (result[configKey] !== undefined) {\n throw new Error('Providing same negated and truthy argument are not allowed');\n }\n result[configKey] = !argOrg.startsWith('--no-') && !argOrg.startsWith('-no-');\n break;\n case 'number':\n if (args[argIndex + 1] === undefined || args[argIndex + 1].startsWith('-')) {\n throw new Error(`Missing value for option: ${configKey}`);\n }\n result[configKey] = Number(args[++argIndex]);\n break;\n case 'array': {\n if (!result[configKey]) result[configKey] = [];\n const arrayValue = args[++argIndex];\n if (arrayValue === undefined || arrayValue.startsWith('-')) {\n throw new Error(`Missing value for array option: ${configKey}`);\n }\n result[configKey].push(arrayValue);\n break;\n }\n case 'string':\n default:\n if (args[argIndex + 1] === undefined || args[argIndex + 1].startsWith('-')) {\n throw new Error(`Missing value for option: ${configKey}`);\n }\n result[configKey] = args[++argIndex];\n break;\n }\n } else {\n throw new Error(`Unknown argument: ${arg}`);\n }\n argIndex++;\n }\n\n // After all parsing, assign any `default` CLI options when undefined\n // and check for any missing `required` CLI options\n Object.entries(options).forEach(([key, opt]) => {\n if (result[key] === undefined && opt.default !== undefined) {\n result[key] = opt.default;\n }\n if (opt.required && result[key] === undefined) {\n const aliasStr = opt.alias ? `-${opt.alias}, ` : '';\n throw new Error(`Missing required option: ${aliasStr}--${key}`);\n }\n });\n\n return result as ArgsResult<C>;\n}\n\n/** Format a text to a fixed length, truncating and padding as needed. */\nfunction formatHelpText(text: string, max: number) {\n const truncated = text.length > max ? `${text.slice(0, max - 3)}...` : text;\n return truncated.padEnd(max);\n}\n\n/** Build the usage string for positionals, e.g. \"<input..> [output]\" */\nfunction buildUsagePositionals(positionals: readonly any[] = []) {\n return positionals\n .map(p => {\n const variadic = p.variadic ? '..' : '';\n return p.required ? `<${p.name}${variadic}>` : `[${p.name}${variadic}]`;\n })\n .join(' ');\n}\n\n/** Format the option/argument type for help output */\nfunction formatOptionType(type: string | undefined, variadic?: boolean, required?: boolean) {\n const t = type || 'string';\n const variadicStr = variadic ? '..' : '';\n return required ? `<${t}${variadicStr}>` : `[${t}${variadicStr}]`;\n}\n\n/** Helper to find an option and its config key by argument name or alias. */\nfunction findOption(options: Record<string, ArgumentOptions>, arg: string): [ArgumentOptions | undefined, string | undefined] {\n // Try all forms: as-is, kebab-to-camel, camel-to-kebab\n const option = options[arg] || options[kebabToCamel(arg)] || options[camelToKebab(arg).replace(/-/g, '')];\n if (option) {\n const configKey = Object.keys(options).find(key => options[key] === option);\n return [option, configKey];\n }\n // Try matching alias in all forms\n for (const key of Object.keys(options)) {\n const opt = options[key];\n if (opt.alias && (opt.alias === arg || opt.alias === kebabToCamel(arg) || opt.alias === camelToKebab(arg))) {\n return [opt, key];\n }\n }\n return [undefined, undefined];\n}\n\n/** Print CLI help documentation to the screen */\nfunction printHelp(config: Config) {\n const { command, options, version, helpOptLength = 20, helpDescLength = 65 } = config;\n const usagePositionals = buildUsagePositionals(command.positionals);\n\n console.log('Usage:');\n console.log(` ${command.name} ${usagePositionals} [options] ${command.description}`);\n console.log('\\nArguments:');\n command.positionals?.forEach(arg => {\n console.log(\n ` ${formatHelpText(arg.name, helpOptLength)}${formatHelpText(arg.description, helpDescLength)} ${formatOptionType(arg.type, arg.variadic, arg.required)}`,\n );\n });\n\n console.log('\\nOptions:');\n for (const [key, option] of Object.entries({ ...options, ...defaultOptions })) {\n const aliasStr = option.alias ? `-${option.alias}, ` : '';\n if (!version && key === 'version') {\n continue;\n }\n console.log(\n ` ${aliasStr.padEnd(4)}--${formatHelpText(key, helpOptLength - 6)}${formatHelpText(option.description || '', helpDescLength)} ${formatOptionType(option.type, false, option.required)}`,\n );\n }\n}\n\n/** Utility to convert kebab-case to camelCase */\nfunction kebabToCamel(str: string) {\n return str.replace(/-([a-z])/g, (_, c) => c.toUpperCase());\n}\n\n/** Utility to convert camelCase to kebab-case */\nfunction camelToKebab(str: string) {\n return str.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase();\n}\n"],"mappings":"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"}
|