@highstate/cli 0.9.14 → 0.9.16

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/main.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/main.ts","../package.json","../src/commands/designer.ts","../src/shared/logger.ts","../src/shared/services.ts","../src/shared/schema-transformer.ts","../../../node_modules/@jridgewell/sourcemap-codec/src/vlq.ts","../../../node_modules/@jridgewell/sourcemap-codec/src/strings.ts","../../../node_modules/@jridgewell/sourcemap-codec/src/scopes.ts","../../../node_modules/@jridgewell/sourcemap-codec/src/sourcemap-codec.ts","../../../node_modules/magic-string/src/BitSet.js","../../../node_modules/magic-string/src/Chunk.js","../../../node_modules/magic-string/src/SourceMap.js","../../../node_modules/magic-string/src/utils/guessIndent.js","../../../node_modules/magic-string/src/utils/getRelativePath.js","../../../node_modules/magic-string/src/utils/isObject.js","../../../node_modules/magic-string/src/utils/getLocator.js","../../../node_modules/magic-string/src/utils/Mappings.js","../../../node_modules/magic-string/src/MagicString.js","../../../node_modules/magic-string/src/Bundle.js","../src/shared/source-hash-calculator.ts","../src/shared/bin-transformer.ts","../src/commands/build.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { Builtins, Cli } from \"clipanion\"\nimport { version } from \"../package.json\"\nimport { DesignerCommand } from \"./commands/designer\"\nimport { BuildCommand } from \"./commands/build\"\n\nconst cli = new Cli({\n binaryName: \"highstate\",\n binaryLabel: \"Highstate\",\n binaryVersion: version,\n})\n\ncli.register(BuildCommand)\ncli.register(DesignerCommand)\ncli.register(Builtins.HelpCommand)\ncli.register(Builtins.VersionCommand)\n\nawait cli.runExit(process.argv.slice(2))\n","{\n \"name\": \"@highstate/cli\",\n \"version\": \"0.9.13\",\n \"description\": \"The CLI for the Highstate project.\",\n \"type\": \"module\",\n \"files\": [\n \"assets\",\n \"dist\",\n \"src\"\n ],\n \"bin\": {\n \"highstate\": \"./dist/main.js\"\n },\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"scripts\": {\n \"build\": \"highstate build\"\n },\n \"dependencies\": {\n \"@highstate/backend\": \"workspace:^0.9.13\",\n \"clipanion\": \"^4.0.0-rc.4\",\n \"consola\": \"^3.4.0\",\n \"crypto-hash\": \"^3.1.0\",\n \"get-port-please\": \"^3.1.2\",\n \"import-meta-resolve\": \"^4.1.0\",\n \"nypm\": \"^0.6.0\",\n \"oxc-parser\": \"^0.63.0\",\n \"oxc-walker\": \"^0.2.4\",\n \"pino\": \"^9.6.0\",\n \"pkg-types\": \"^1.2.1\",\n \"remeda\": \"^2.21.2\",\n \"tsup\": \"^8.4.0\"\n },\n \"devDependencies\": {\n \"highstate-cli-bootstrap\": \"npm:@highstate/cli@0.7.6\"\n }\n}\n","import { Command, UsageError } from \"clipanion\"\nimport { readPackageJSON } from \"pkg-types\"\nimport { addDevDependency } from \"nypm\"\nimport { consola } from \"consola\"\nimport { colorize } from \"consola/utils\"\nimport { getPort } from \"get-port-please\"\nimport { getBackendServices, logger } from \"../shared\"\n\nexport class DesignerCommand extends Command {\n static paths = [[\"designer\"]]\n\n static usage = Command.Usage({\n category: \"Designer\",\n description: \"Starts the Highstate designer in the current project.\",\n })\n\n async execute(): Promise<void> {\n const packageJson = await readPackageJSON()\n if (!packageJson.devDependencies?.[\"@highstate/cli\"]) {\n throw new UsageError(\n \"This project is not a Highstate project.\\n@highstate/cli must be installed as a devDependency.\",\n )\n }\n\n if (!packageJson.devDependencies?.[\"@highstate/designer\"]) {\n logger.info(\"Installing @highstate/designer...\")\n\n await addDevDependency([\"@highstate/designer\", \"classic-level\"])\n }\n\n logger.info(\"starting highstate designer...\")\n\n await getBackendServices()\n\n const oldConsoleLog = console.log\n\n const port = await getPort()\n\n process.env.NITRO_PORT = port.toString()\n process.env.NITRO_HOST = \"0.0.0.0\"\n\n await new Promise<void>(resolve => {\n console.log = (message: string) => {\n if (message.startsWith(\"Listening on\")) {\n resolve()\n }\n }\n\n const path = \"@highstate/designer/.output/server/index.mjs\"\n void import(path)\n })\n\n console.log = oldConsoleLog\n\n consola.log(\n [\n \"\\n \",\n colorize(\"bold\", colorize(\"cyanBright\", \"Highstate Designer\")),\n \"\\n \",\n colorize(\"greenBright\", \"➜ Local: \"),\n colorize(\"underline\", colorize(\"cyanBright\", `http://localhost:${port}`)),\n \"\\n\",\n ].join(\"\"),\n )\n\n process.on(\"SIGINT\", () => {\n process.stdout.write(\"\\r\")\n consola.info(\"shutting down highstate designer...\")\n\n setTimeout(() => process.exit(0), 1000)\n })\n }\n}\n","import { PassThrough } from \"node:stream\"\nimport pino, { levels } from \"pino\"\nimport { consola, LogLevels } from \"consola\"\n\nexport const logger = pino(\n {\n name: \"highstate-cli\",\n level: process.env.LOG_LEVEL ?? \"info\",\n },\n createConsolaStream(),\n)\n\nconsola.level = LogLevels[(process.env.LOG_LEVEL as keyof typeof LogLevels) ?? \"info\"]\n\nfunction createConsolaStream() {\n const stream = new PassThrough()\n\n stream.on(\"data\", data => {\n const { level, msg, error } = JSON.parse(String(data)) as {\n msg: string\n level: number\n error?: unknown\n }\n\n const levelLabel = levels.labels[level]\n\n switch (levelLabel) {\n case \"info\":\n consola.info(msg)\n break\n case \"warn\":\n consola.warn(msg)\n break\n case \"error\":\n if (error) {\n consola.error(msg, error)\n } else {\n consola.error(msg)\n }\n break\n case \"debug\":\n consola.debug(msg)\n break\n case \"fatal\":\n consola.fatal(msg)\n break\n case \"trace\":\n consola.trace(msg)\n break\n }\n })\n\n return stream\n}\n","import type { Services } from \"@highstate/backend\"\nimport { logger } from \"./logger\"\n\nlet services: Promise<Services> | undefined\n\nexport function getBackendServices() {\n if (services) {\n return services\n }\n\n services = import(\"@highstate/backend\").then(({ getSharedServices }) => {\n return getSharedServices({\n services: {\n logger: logger.child({}, { msgPrefix: \"[backend] \" }),\n },\n })\n })\n\n return services\n}\n","import type { Plugin } from \"esbuild\"\nimport { readFile } from \"node:fs/promises\"\nimport { parseAsync, type Comment } from \"oxc-parser\"\nimport { walk, type Node } from \"oxc-walker\"\nimport MagicString from \"magic-string\"\n\nexport const schemaTransformerPlugin: Plugin = {\n name: \"schema-transformer\",\n setup(build) {\n build.onLoad({ filter: /src\\/.*\\.ts$/ }, async args => {\n const content = await readFile(args.path, \"utf-8\")\n\n return {\n contents: await applySchemaTransformations(content),\n loader: \"ts\",\n }\n })\n },\n}\n\nexport async function applySchemaTransformations(content: string): Promise<string> {\n const magicString = new MagicString(content)\n const { program, comments } = await parseAsync(\"file.ts\", content)\n\n walk(program, {\n enter(node) {\n if (node.type !== \"Property\" || node.key.type !== \"Identifier\") {\n return\n }\n\n const jsdoc = comments.find(comment => isLeadingComment(content, node, comment))\n if (!jsdoc || !jsdoc.value.includes(\"@schema\")) {\n return\n }\n\n magicString.update(\n node.value.start,\n node.value.end,\n `{\n ...${content.substring(node.value.start, node.value.end)},\n description: \\`${cleanJsdoc(jsdoc.value)}\\`,\n}`,\n )\n },\n })\n\n return magicString.toString()\n}\n\nfunction isLeadingComment(content: string, node: Node, comment: Comment) {\n if (comment.end > node.start) {\n return false\n }\n\n const contentRange = content.substring(comment.end, node.start)\n\n return contentRange.trim().length === 0\n}\n\nfunction cleanJsdoc(str: string) {\n return (\n str\n // remove leading asterisks\n .replace(/^\\s*\\*/gm, \"\")\n\n // remove @schema tag\n .replace(\"@schema\", \"\")\n\n // escape backticks and dollar signs\n .replace(/\\\\/g, \"\\\\\\\\\")\n .replace(/`/g, \"\\\\`\")\n .replace(/\\${/g, \"\\\\${\")\n .trim()\n )\n}\n","import type { StringReader, StringWriter } from './strings';\n\nexport const comma = ','.charCodeAt(0);\nexport const semicolon = ';'.charCodeAt(0);\n\nconst chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\nconst intToChar = new Uint8Array(64); // 64 possible chars.\nconst charToInt = new Uint8Array(128); // z is 122 in ASCII\n\nfor (let i = 0; i < chars.length; i++) {\n const c = chars.charCodeAt(i);\n intToChar[i] = c;\n charToInt[c] = i;\n}\n\nexport function decodeInteger(reader: StringReader, relative: number): number {\n let value = 0;\n let shift = 0;\n let integer = 0;\n\n do {\n const c = reader.next();\n integer = charToInt[c];\n value |= (integer & 31) << shift;\n shift += 5;\n } while (integer & 32);\n\n const shouldNegate = value & 1;\n value >>>= 1;\n\n if (shouldNegate) {\n value = -0x80000000 | -value;\n }\n\n return relative + value;\n}\n\nexport function encodeInteger(builder: StringWriter, num: number, relative: number): number {\n let delta = num - relative;\n\n delta = delta < 0 ? (-delta << 1) | 1 : delta << 1;\n do {\n let clamped = delta & 0b011111;\n delta >>>= 5;\n if (delta > 0) clamped |= 0b100000;\n builder.write(intToChar[clamped]);\n } while (delta > 0);\n\n return num;\n}\n\nexport function hasMoreVlq(reader: StringReader, max: number) {\n if (reader.pos >= max) return false;\n return reader.peek() !== comma;\n}\n","const bufLength = 1024 * 16;\n\n// Provide a fallback for older environments.\nconst td =\n typeof TextDecoder !== 'undefined'\n ? /* #__PURE__ */ new TextDecoder()\n : typeof Buffer !== 'undefined'\n ? {\n decode(buf: Uint8Array): string {\n const out = Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength);\n return out.toString();\n },\n }\n : {\n decode(buf: Uint8Array): string {\n let out = '';\n for (let i = 0; i < buf.length; i++) {\n out += String.fromCharCode(buf[i]);\n }\n return out;\n },\n };\n\nexport class StringWriter {\n pos = 0;\n private out = '';\n private buffer = new Uint8Array(bufLength);\n\n write(v: number): void {\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\n flush(): string {\n const { buffer, out, pos } = this;\n return pos > 0 ? out + td.decode(buffer.subarray(0, pos)) : out;\n }\n}\n\nexport class StringReader {\n pos = 0;\n private declare buffer: string;\n\n constructor(buffer: string) {\n this.buffer = buffer;\n }\n\n next(): number {\n return this.buffer.charCodeAt(this.pos++);\n }\n\n peek(): number {\n return this.buffer.charCodeAt(this.pos);\n }\n\n indexOf(char: string): number {\n const { buffer, pos } = this;\n const idx = buffer.indexOf(char, pos);\n return idx === -1 ? buffer.length : idx;\n }\n}\n","import { StringReader, StringWriter } from './strings';\nimport { comma, decodeInteger, encodeInteger, hasMoreVlq, semicolon } from './vlq';\n\nconst EMPTY: any[] = [];\n\ntype Line = number;\ntype Column = number;\ntype Kind = number;\ntype Name = number;\ntype Var = number;\ntype SourcesIndex = number;\ntype ScopesIndex = number;\n\ntype Mix<A, B, O> = (A & O) | (B & O);\n\nexport type OriginalScope = Mix<\n [Line, Column, Line, Column, Kind],\n [Line, Column, Line, Column, Kind, Name],\n { vars: Var[] }\n>;\n\nexport type GeneratedRange = Mix<\n [Line, Column, Line, Column],\n [Line, Column, Line, Column, SourcesIndex, ScopesIndex],\n {\n callsite: CallSite | null;\n bindings: Binding[];\n isScope: boolean;\n }\n>;\nexport type CallSite = [SourcesIndex, Line, Column];\ntype Binding = BindingExpressionRange[];\nexport type BindingExpressionRange = [Name] | [Name, Line, Column];\n\nexport function decodeOriginalScopes(input: string): OriginalScope[] {\n const { length } = input;\n const reader = new StringReader(input);\n const scopes: OriginalScope[] = [];\n const stack: OriginalScope[] = [];\n let line = 0;\n\n for (; reader.pos < length; reader.pos++) {\n line = decodeInteger(reader, line);\n const column = decodeInteger(reader, 0);\n\n if (!hasMoreVlq(reader, length)) {\n const last = stack.pop()!;\n last[2] = line;\n last[3] = column;\n continue;\n }\n\n const kind = decodeInteger(reader, 0);\n const fields = decodeInteger(reader, 0);\n const hasName = fields & 0b0001;\n\n const scope: OriginalScope = (\n hasName ? [line, column, 0, 0, kind, decodeInteger(reader, 0)] : [line, column, 0, 0, kind]\n ) as OriginalScope;\n\n let vars: Var[] = 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\n scopes.push(scope);\n stack.push(scope);\n }\n\n return scopes;\n}\n\nexport function encodeOriginalScopes(scopes: OriginalScope[]): string {\n const writer = new StringWriter();\n\n for (let i = 0; i < scopes.length; ) {\n i = _encodeOriginalScopes(scopes, i, writer, [0]);\n }\n\n return writer.flush();\n}\n\nfunction _encodeOriginalScopes(\n scopes: OriginalScope[],\n index: number,\n writer: StringWriter,\n state: [\n number, // GenColumn\n ],\n): number {\n const scope = scopes[index];\n const { 0: startLine, 1: startColumn, 2: endLine, 3: endColumn, 4: kind, vars } = scope;\n\n if (index > 0) writer.write(comma);\n\n state[0] = encodeInteger(writer, startLine, state[0]);\n encodeInteger(writer, startColumn, 0);\n encodeInteger(writer, kind, 0);\n\n const fields = scope.length === 6 ? 0b0001 : 0;\n encodeInteger(writer, fields, 0);\n if (scope.length === 6) encodeInteger(writer, scope[5], 0);\n\n for (const v of vars) {\n encodeInteger(writer, v, 0);\n }\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\n writer.write(comma);\n state[0] = encodeInteger(writer, endLine, state[0]);\n encodeInteger(writer, endColumn, 0);\n\n return index;\n}\n\nexport function decodeGeneratedRanges(input: string): GeneratedRange[] {\n const { length } = input;\n const reader = new StringReader(input);\n const ranges: GeneratedRange[] = [];\n const stack: GeneratedRange[] = [];\n\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\n do {\n const semi = reader.indexOf(';');\n let genColumn = 0;\n\n for (; reader.pos < semi; reader.pos++) {\n genColumn = decodeInteger(reader, genColumn);\n\n if (!hasMoreVlq(reader, semi)) {\n const last = stack.pop()!;\n last[2] = genLine;\n last[3] = genColumn;\n continue;\n }\n\n const fields = decodeInteger(reader, 0);\n const hasDefinition = fields & 0b0001;\n const hasCallsite = fields & 0b0010;\n const hasScope = fields & 0b0100;\n\n let callsite: CallSite | null = null;\n let bindings: Binding[] = EMPTY;\n let range: GeneratedRange;\n if (hasDefinition) {\n const defSourcesIndex = decodeInteger(reader, definitionSourcesIndex);\n definitionScopeIndex = decodeInteger(\n reader,\n definitionSourcesIndex === defSourcesIndex ? definitionScopeIndex : 0,\n );\n\n definitionSourcesIndex = defSourcesIndex;\n range = [genLine, genColumn, 0, 0, defSourcesIndex, definitionScopeIndex] as GeneratedRange;\n } else {\n range = [genLine, genColumn, 0, 0] as GeneratedRange;\n }\n\n range.isScope = !!hasScope;\n\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(\n reader,\n sameSource && prevLine === callsiteLine ? callsiteColumn : 0,\n );\n\n callsite = [callsiteSourcesIndex, callsiteLine, callsiteColumn];\n }\n range.callsite = callsite;\n\n if (hasMoreVlq(reader, semi)) {\n bindings = [];\n do {\n bindingLine = genLine;\n bindingColumn = genColumn;\n const expressionsCount = decodeInteger(reader, 0);\n let expressionRanges: BindingExpressionRange[];\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 } else {\n expressionRanges = [[expressionsCount]];\n }\n bindings.push(expressionRanges);\n } while (hasMoreVlq(reader, semi));\n }\n range.bindings = bindings;\n\n ranges.push(range);\n stack.push(range);\n }\n\n genLine++;\n reader.pos = semi + 1;\n } while (reader.pos < length);\n\n return ranges;\n}\n\nexport function encodeGeneratedRanges(ranges: GeneratedRange[]): string {\n if (ranges.length === 0) return '';\n\n const writer = new StringWriter();\n\n for (let i = 0; i < ranges.length; ) {\n i = _encodeGeneratedRanges(ranges, i, writer, [0, 0, 0, 0, 0, 0, 0]);\n }\n\n return writer.flush();\n}\n\nfunction _encodeGeneratedRanges(\n ranges: GeneratedRange[],\n index: number,\n writer: StringWriter,\n state: [\n number, // GenLine\n number, // GenColumn\n number, // DefSourcesIndex\n number, // DefScopesIndex\n number, // CallSourcesIndex\n number, // CallLine\n number, // CallColumn\n ],\n): number {\n const range = ranges[index];\n const {\n 0: startLine,\n 1: startColumn,\n 2: endLine,\n 3: endColumn,\n isScope,\n callsite,\n bindings,\n } = range;\n\n if (state[0] < startLine) {\n catchupLine(writer, state[0], startLine);\n state[0] = startLine;\n state[1] = 0;\n } else if (index > 0) {\n writer.write(comma);\n }\n\n state[1] = encodeInteger(writer, range[1], state[1]);\n\n const fields =\n (range.length === 6 ? 0b0001 : 0) | (callsite ? 0b0010 : 0) | (isScope ? 0b0100 : 0);\n encodeInteger(writer, fields, 0);\n\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\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 } 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\n if (bindings) {\n for (const binding of bindings) {\n if (binding.length > 1) 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\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\n if (state[0] < endLine) {\n catchupLine(writer, state[0], endLine);\n state[0] = endLine;\n state[1] = 0;\n } else {\n writer.write(comma);\n }\n state[1] = encodeInteger(writer, endColumn, state[1]);\n\n return index;\n}\n\nfunction catchupLine(writer: StringWriter, lastLine: number, line: number) {\n do {\n writer.write(semicolon);\n } while (++lastLine < line);\n}\n","import { comma, decodeInteger, encodeInteger, hasMoreVlq, semicolon } from './vlq';\nimport { StringWriter, StringReader } from './strings';\n\nexport {\n decodeOriginalScopes,\n encodeOriginalScopes,\n decodeGeneratedRanges,\n encodeGeneratedRanges,\n} from './scopes';\nexport type { OriginalScope, GeneratedRange, CallSite, BindingExpressionRange } from './scopes';\n\nexport type SourceMapSegment =\n | [number]\n | [number, number, number, number]\n | [number, number, number, number, number];\nexport type SourceMapLine = SourceMapSegment[];\nexport type SourceMapMappings = SourceMapLine[];\n\nexport function decode(mappings: string): SourceMapMappings {\n const { length } = mappings;\n const reader = new StringReader(mappings);\n const decoded: SourceMapMappings = [];\n let genColumn = 0;\n let sourcesIndex = 0;\n let sourceLine = 0;\n let sourceColumn = 0;\n let namesIndex = 0;\n\n do {\n const semi = reader.indexOf(';');\n const line: SourceMapLine = [];\n let sorted = true;\n let lastCol = 0;\n genColumn = 0;\n\n while (reader.pos < semi) {\n let seg: SourceMapSegment;\n\n genColumn = decodeInteger(reader, genColumn);\n if (genColumn < lastCol) sorted = false;\n lastCol = genColumn;\n\n if (hasMoreVlq(reader, semi)) {\n sourcesIndex = decodeInteger(reader, sourcesIndex);\n sourceLine = decodeInteger(reader, sourceLine);\n sourceColumn = decodeInteger(reader, sourceColumn);\n\n if (hasMoreVlq(reader, semi)) {\n namesIndex = decodeInteger(reader, namesIndex);\n seg = [genColumn, sourcesIndex, sourceLine, sourceColumn, namesIndex];\n } else {\n seg = [genColumn, sourcesIndex, sourceLine, sourceColumn];\n }\n } else {\n seg = [genColumn];\n }\n\n line.push(seg);\n reader.pos++;\n }\n\n if (!sorted) sort(line);\n decoded.push(line);\n reader.pos = semi + 1;\n } while (reader.pos <= length);\n\n return decoded;\n}\n\nfunction sort(line: SourceMapSegment[]) {\n line.sort(sortComparator);\n}\n\nfunction sortComparator(a: SourceMapSegment, b: SourceMapSegment): number {\n return a[0] - b[0];\n}\n\nexport function encode(decoded: SourceMapMappings): string;\nexport function encode(decoded: Readonly<SourceMapMappings>): string;\nexport function encode(decoded: Readonly<SourceMapMappings>): string {\n const writer = new StringWriter();\n let sourcesIndex = 0;\n let sourceLine = 0;\n let sourceColumn = 0;\n let namesIndex = 0;\n\n for (let i = 0; i < decoded.length; i++) {\n const line = decoded[i];\n if (i > 0) writer.write(semicolon);\n if (line.length === 0) continue;\n\n let genColumn = 0;\n\n for (let j = 0; j < line.length; j++) {\n const segment = line[j];\n if (j > 0) writer.write(comma);\n\n genColumn = encodeInteger(writer, segment[0], genColumn);\n\n if (segment.length === 1) continue;\n sourcesIndex = encodeInteger(writer, segment[1], sourcesIndex);\n sourceLine = encodeInteger(writer, segment[2], sourceLine);\n sourceColumn = encodeInteger(writer, segment[3], sourceColumn);\n\n if (segment.length === 4) continue;\n namesIndex = encodeInteger(writer, segment[4], namesIndex);\n }\n }\n\n return writer.flush();\n}\n","export default class 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","export default class 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\tif (DEBUG) {\n\t\t\t// we make these non-enumerable, for sanity while debugging\n\t\t\tObject.defineProperties(this, {\n\t\t\t\tprevious: { writable: true, value: null },\n\t\t\t\tnext: { writable: true, value: null },\n\t\t\t});\n\t\t} else {\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","import { encode } from '@jridgewell/sourcemap-codec';\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\nexport default class 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","export default function 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","export default function 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","const toString = Object.prototype.toString;\n\nexport default function isObject(thing) {\n\treturn toString.call(thing) === '[object Object]';\n}\n","export default function 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","const wordRegex = /\\w/;\n\nexport default class 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","import BitSet from './BitSet.js';\nimport Chunk from './Chunk.js';\nimport SourceMap from './SourceMap.js';\nimport guessIndent from './utils/guessIndent.js';\nimport getRelativePath from './utils/getRelativePath.js';\nimport isObject from './utils/isObject.js';\nimport getLocator from './utils/getLocator.js';\nimport Mappings from './utils/Mappings.js';\nimport Stats from './utils/Stats.js';\n\nconst n = '\\n';\n\nconst warned = {\n\tinsertLeft: false,\n\tinsertRight: false,\n\tstoreName: false,\n};\n\nexport default class 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\tif (DEBUG) {\n\t\t\tObject.defineProperty(this, 'stats', { value: new Stats() });\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\tif (DEBUG) this.stats.time('appendLeft');\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\n\t\tif (DEBUG) this.stats.timeEnd('appendLeft');\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\tif (DEBUG) this.stats.time('appendRight');\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\n\t\tif (DEBUG) this.stats.timeEnd('appendRight');\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\tif (DEBUG) this.stats.time('move');\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\n\t\tif (DEBUG) this.stats.timeEnd('move');\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\tif (DEBUG) this.stats.time('overwrite');\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\n\t\tif (DEBUG) this.stats.timeEnd('overwrite');\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\tif (DEBUG) this.stats.time('insertRight');\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\n\t\tif (DEBUG) this.stats.timeEnd('insertRight');\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\tif (DEBUG) this.stats.time('insertRight');\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\n\t\tif (DEBUG) this.stats.timeEnd('insertRight');\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\tif (DEBUG) this.stats.time('remove');\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\n\t\tif (DEBUG) this.stats.timeEnd('remove');\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\tif (DEBUG) this.stats.time('reset');\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\n\t\tif (DEBUG) this.stats.timeEnd('reset');\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\tif (DEBUG) this.stats.time('_split');\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\tif (DEBUG) this.stats.timeEnd('_split');\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","import MagicString from './MagicString.js';\nimport SourceMap from './SourceMap.js';\nimport getRelativePath from './utils/getRelativePath.js';\nimport isObject from './utils/isObject.js';\nimport getLocator from './utils/getLocator.js';\nimport Mappings from './utils/Mappings.js';\n\nconst hasOwnProp = Object.prototype.hasOwnProperty;\n\nexport default class 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","import type { Logger } from \"pino\"\nimport { dirname, relative, resolve } from \"node:path\"\nimport { readFile, writeFile } from \"node:fs/promises\"\nimport { fileURLToPath, pathToFileURL } from \"node:url\"\nimport { readPackageJSON, resolvePackageJSON, type PackageJson } from \"pkg-types\"\nimport { sha256 } from \"crypto-hash\"\nimport { resolve as importMetaResolve } from \"import-meta-resolve\"\n\nexport type HighstateManifestJson = {\n sourceHashes?: Record<string, string>\n}\n\ntype FileDependency =\n | {\n type: \"relative\"\n id: string\n fullPath: string\n }\n | {\n type: \"npm\"\n id: string\n package: string\n }\n\nexport class SourceHashCalculator {\n private readonly dependencyHashes = new Map<string, Promise<string>>()\n private readonly fileHashes = new Map<string, Promise<string>>()\n\n constructor(\n private readonly packageJsonPath: string,\n private readonly packageJson: PackageJson,\n private readonly logger: Logger,\n ) {}\n\n async writeHighstateManifest(distBasePath: string, distPaths: string[]): Promise<void> {\n const promises: Promise<{ distPath: string; hash: string }>[] = []\n\n for (const distPath of distPaths) {\n const fullPath = resolve(distPath)\n\n promises.push(\n this.getFileHash(fullPath).then(hash => ({\n distPath,\n hash,\n })),\n )\n }\n\n const manifest: HighstateManifestJson = {\n sourceHashes: {},\n }\n\n const hashes = await Promise.all(promises)\n for (const { distPath, hash } of hashes) {\n manifest.sourceHashes![distPath] = hash\n }\n\n const manifestPath = resolve(distBasePath, \"highstate.manifest.json\")\n await writeFile(manifestPath, JSON.stringify(manifest, null, 2), \"utf8\")\n }\n\n private async getFileHash(fullPath: string): Promise<string> {\n const existingHash = this.fileHashes.get(fullPath)\n if (existingHash) {\n return existingHash\n }\n\n const hash = this.calculateFileHash(fullPath)\n this.fileHashes.set(fullPath, hash)\n\n return hash\n }\n\n private async calculateFileHash(fullPath: string): Promise<string> {\n const content = await readFile(fullPath, \"utf8\")\n const fileDeps = this.parseDependencies(fullPath, content)\n\n const hashes = await Promise.all([\n sha256(content),\n ...fileDeps.map(dep => this.getDependencyHash(dep)),\n ])\n\n return await sha256(hashes.join(\"\"))\n }\n\n getDependencyHash(dependency: FileDependency): Promise<string> {\n const existingHash = this.dependencyHashes.get(dependency.id)\n if (existingHash) {\n return existingHash\n }\n\n const hash = this.calculateDependencyHash(dependency)\n this.dependencyHashes.set(dependency.id, hash)\n\n return hash\n }\n\n private async calculateDependencyHash(dependency: FileDependency): Promise<string> {\n switch (dependency.type) {\n case \"relative\": {\n return await this.getFileHash(dependency.fullPath)\n }\n case \"npm\": {\n let resolvedUrl\n try {\n const baseUrl = pathToFileURL(dirname(this.packageJsonPath))\n\n resolvedUrl = importMetaResolve(dependency.package, baseUrl.toString())\n } catch (error) {\n this.logger.error(`failed to resolve package \"%s\"`, dependency.package)\n throw error\n }\n\n if (resolvedUrl.startsWith(\"node:\")) {\n throw new Error(`\"${dependency.package}\" imported without \"node:\" prefix`)\n }\n\n const resolvedPath = fileURLToPath(resolvedUrl)\n\n const [depPackageJsonPath, depPackageJson] = await this.getPackageJson(resolvedPath)\n const packageName = depPackageJson.name!\n\n this.logger.debug(\n `resolved package.json for \"%s\": \"%s\"`,\n dependency.package,\n depPackageJsonPath,\n )\n\n if (\n !this.packageJson.dependencies?.[packageName] &&\n !this.packageJson.peerDependencies?.[packageName]\n ) {\n this.logger.warn(`package \"%s\" is not listed in package.json dependencies`, packageName)\n }\n\n let relativePath = relative(dirname(depPackageJsonPath), resolvedPath)\n relativePath = relativePath.startsWith(\".\") ? relativePath : `./${relativePath}`\n\n const highstateManifestPath = resolve(\n dirname(depPackageJsonPath),\n \"dist\",\n \"highstate.manifest.json\",\n )\n\n let manifest: HighstateManifestJson | undefined\n try {\n const manifestContent = await readFile(highstateManifestPath, \"utf8\")\n manifest = JSON.parse(manifestContent) as HighstateManifestJson\n } catch (error) {\n this.logger.debug(\n { error },\n `failed to read highstate manifest for package \"%s\"`,\n packageName,\n )\n }\n\n const sourceHash = manifest?.sourceHashes?.[relativePath]\n\n if (sourceHash) {\n this.logger.debug(`resolved source hash for package \"%s\"`, packageName)\n return sourceHash\n }\n\n // use the package version as a fallback hash\n // this case will be applied for most npm packages\n this.logger.debug(`using package version as a fallback hash for \"%s\"`, packageName)\n return depPackageJson.version ?? \"0.0.0\"\n }\n }\n }\n\n private async getPackageJson(basePath: string): Promise<[string, PackageJson]> {\n while (true) {\n const packageJson = await readPackageJSON(basePath)\n if (packageJson.name) {\n const packageJsonPath = await resolvePackageJSON(basePath)\n\n return [packageJsonPath, packageJson]\n }\n\n basePath = resolve(dirname(basePath), \"..\")\n }\n }\n\n private parseDependencies(filePath: string, content: string): FileDependency[] {\n type DependencyMatch = {\n relativePath?: string\n nodeBuiltin?: string\n npmPackage?: string\n }\n\n const dependencyRegex =\n /^[ \\t]*import[\\s\\S]*?\\bfrom\\s*[\"']((?<relativePath>\\.\\.?\\/[^\"']+)|(?<nodeBuiltin>node:[^\"']+)|(?<npmPackage>[^\"']+))[\"']/gm\n\n const matches = content.matchAll(dependencyRegex)\n const dependencies: FileDependency[] = []\n\n for (const match of matches) {\n const { nodeBuiltin, npmPackage, relativePath } = match.groups as DependencyMatch\n\n if (relativePath) {\n const fullPath = resolve(dirname(filePath), relativePath)\n\n dependencies.push({\n type: \"relative\",\n id: `relative:${fullPath}`,\n fullPath,\n })\n } else if (npmPackage) {\n dependencies.push({\n type: \"npm\",\n id: `npm:${npmPackage}`,\n package: npmPackage,\n })\n } else if (nodeBuiltin) {\n // ignore node built-in modules\n }\n }\n\n return dependencies\n }\n}\n","import type { Plugin } from \"esbuild\"\nimport { readFile } from \"node:fs/promises\"\nimport { logger } from \"./logger\"\n\nexport function createBinTransformerPlugin(sourceFilePaths: string[]): Plugin {\n const filter = new RegExp(`(${sourceFilePaths.join(\"|\")})$`)\n\n logger.debug(\"created bin transformer plugin with filter: %s\", filter)\n\n return {\n name: \"bin-transformer\",\n setup(build) {\n build.onLoad({ filter }, async args => {\n const content = await readFile(args.path, \"utf-8\")\n\n return {\n contents: `#!/usr/bin/env node\\n\\n${content}`,\n loader: \"ts\",\n }\n })\n },\n }\n}\n","import type { Plugin } from \"esbuild\"\nimport { Command, Option } from \"clipanion\"\nimport { readPackageJSON, resolvePackageJSON } from \"pkg-types\"\nimport { mapKeys, mapValues, pipe } from \"remeda\"\nimport { build } from \"tsup\"\nimport {\n createBinTransformerPlugin,\n logger,\n schemaTransformerPlugin,\n SourceHashCalculator,\n} from \"../shared\"\n\nexport class BuildCommand extends Command {\n static paths = [[\"build\"]]\n\n static usage = Command.Usage({\n category: \"Builder\",\n description: \"Builds the Highstate library or unit package.\",\n })\n\n watch = Option.Boolean(\"--watch\", false)\n library = Option.Boolean(\"--library\", false)\n silent = Option.Boolean(\"--silent\", true)\n\n async execute(): Promise<void> {\n const packageJson = await readPackageJSON()\n const exports = packageJson.exports\n let bin = packageJson.bin\n\n if (!packageJson.name) {\n throw new Error(\"package.json must have a name field\")\n }\n\n if (!exports && !bin) {\n logger.warn(\"no exports or bin found in package.json\")\n return\n }\n\n if (exports !== undefined && (typeof exports !== \"object\" || Array.isArray(exports))) {\n throw new Error(\"Exports field in package.json must be an object\")\n }\n\n if (bin !== undefined && typeof bin !== \"object\") {\n bin = { [packageJson.name]: bin }\n }\n\n const entry = pipe(\n {\n ...mapValues(exports ?? {}, value => ({ value, isBin: false })),\n ...mapValues(bin ?? {}, value => ({ value, isBin: true })),\n },\n mapValues(({ value, isBin }, key) => {\n let distPath\n\n if (typeof value === \"string\") {\n distPath = value\n } else if (typeof value === \"object\" && !Array.isArray(value)) {\n if (!value.default) {\n throw new Error(`Export \"${key}\" must have a default field in package.json`)\n }\n\n if (typeof value.default !== \"string\") {\n throw new Error(`Export \"${key}\" default field must be a string in package.json`)\n }\n\n distPath = value.default\n } else {\n throw new Error(`Export \"${key}\" must be a string or an object in package.json`)\n }\n\n if (!distPath.startsWith(\"./dist/\")) {\n throw new Error(\n `The default value of export \"${key}\" must start with \"./dist/\" in package.json, got \"${distPath}\"`,\n )\n }\n\n if (!distPath.endsWith(\".js\")) {\n throw new Error(\n `The default value of export \"${key}\" must end with \".js\" in package.json, got \"${distPath}\"`,\n )\n }\n\n const targetName = distPath.slice(7).slice(0, -3)\n\n return {\n entryPoint: `./src/${targetName}.ts`,\n targetName,\n distPath,\n isBin,\n }\n }),\n mapKeys((_, value) => value.targetName),\n )\n\n const esbuildPlugins: Plugin[] = []\n\n const binSourceFilePaths = Object.values(entry)\n .filter(value => value.isBin)\n .map(value => value.entryPoint.slice(2)) // remove \"./\"\n\n if (this.library) {\n esbuildPlugins.push(schemaTransformerPlugin)\n }\n\n if (binSourceFilePaths.length > 0) {\n esbuildPlugins.push(createBinTransformerPlugin(binSourceFilePaths))\n }\n\n await build({\n entry: mapValues(entry, value => value.entryPoint),\n outDir: \"dist\",\n watch: this.watch,\n sourcemap: true,\n clean: true,\n format: \"esm\",\n target: \"esnext\",\n external: [\"@pulumi/pulumi\"],\n esbuildPlugins,\n silent: this.silent || [\"warn\", \"error\", \"fatal\"].includes(logger.level),\n })\n\n const packageJsonPath = await resolvePackageJSON()\n const upToDatePackageJson = await readPackageJSON()\n\n // do not write highstate manifest for library packages since their changes are tracked more granularly\n if (!this.library) {\n const sourceHashCalculator = new SourceHashCalculator(\n packageJsonPath,\n upToDatePackageJson,\n logger,\n )\n const distPaths = Object.values(entry).map(value => value.distPath)\n\n await sourceHashCalculator.writeHighstateManifest(\"./dist\", distPaths)\n }\n }\n}\n"],"mappings":";;;AAEA,SAAS,UAAU,WAAW;;;ACA5B,cAAW;;;ACFb,SAAS,SAAS,kBAAkB;AACpC,SAAS,mBAAAA,wBAAuB;AAChC,SAAS,wBAAwB;AACjC,SAAS,WAAAC,gBAAe;AACxB,SAAS,gBAAgB;AACzB,SAAS,eAAe;;;ACLxB,SAAS,mBAAmB;AAC5B,OAAO,QAAQ,cAAc;AAC7B,SAAS,SAAS,iBAAiB;AAE5B,IAAM,SAAS;AAAA,EACpB;AAAA,IACE,MAAM;AAAA,IACN,OAAO,QAAQ,IAAI,aAAa;AAAA,EAClC;AAAA,EACA,oBAAoB;AACtB;AAEA,QAAQ,QAAQ,UAAW,QAAQ,IAAI,aAAwC,MAAM;AAErF,SAAS,sBAAsB;AAC7B,QAAM,SAAS,IAAI,YAAY;AAE/B,SAAO,GAAG,QAAQ,UAAQ;AACxB,UAAM,EAAE,OAAO,KAAK,MAAM,IAAI,KAAK,MAAM,OAAO,IAAI,CAAC;AAMrD,UAAM,aAAa,OAAO,OAAO,KAAK;AAEtC,YAAQ,YAAY;AAAA,MAClB,KAAK;AACH,gBAAQ,KAAK,GAAG;AAChB;AAAA,MACF,KAAK;AACH,gBAAQ,KAAK,GAAG;AAChB;AAAA,MACF,KAAK;AACH,YAAI,OAAO;AACT,kBAAQ,MAAM,KAAK,KAAK;AAAA,QAC1B,OAAO;AACL,kBAAQ,MAAM,GAAG;AAAA,QACnB;AACA;AAAA,MACF,KAAK;AACH,gBAAQ,MAAM,GAAG;AACjB;AAAA,MACF,KAAK;AACH,gBAAQ,MAAM,GAAG;AACjB;AAAA,MACF,KAAK;AACH,gBAAQ,MAAM,GAAG;AACjB;AAAA,IACJ;AAAA,EACF,CAAC;AAED,SAAO;AACT;;;AClDA,IAAI;AAEG,SAAS,qBAAqB;AACnC,MAAI,UAAU;AACZ,WAAO;AAAA,EACT;AAEA,aAAW,OAAO,oBAAoB,EAAE,KAAK,CAAC,EAAE,kBAAkB,MAAM;AACtE,WAAO,kBAAkB;AAAA,MACvB,UAAU;AAAA,QACR,QAAQ,OAAO,MAAM,CAAC,GAAG,EAAE,WAAW,aAAa,CAAC;AAAA,MACtD;AAAA,IACF,CAAC;AAAA,EACH,CAAC;AAED,SAAO;AACT;;;AClBA,SAAS,gBAAgB;AACzB,SAAS,kBAAgC;AACzC,SAAS,YAAuB;;;ACDzB,IAAM,QAAQ,IAAI,WAAW,CAAC;AAC9B,IAAM,YAAY,IAAI,WAAW,CAAC;AAEzC,IAAM,QAAQ;AACd,IAAM,YAAY,IAAI,WAAW,EAAE;AACnC,IAAM,YAAY,IAAI,WAAW,GAAG;AAEpC,SAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;AACrC,QAAM,IAAI,MAAM,WAAW,CAAC;AAC5B,YAAU,CAAC,IAAI;AACf,YAAU,CAAC,IAAI;;SAyBD,cAAc,SAAuB,KAAaC,WAAgB;AAChF,MAAI,QAAQ,MAAMA;AAElB,UAAQ,QAAQ,IAAK,CAAC,SAAS,IAAK,IAAI,SAAS;AACjD,KAAG;AACD,QAAI,UAAU,QAAQ;AACtB,eAAW;AACX,QAAI,QAAQ;AAAG,iBAAW;AAC1B,YAAQ,MAAM,UAAU,OAAO,CAAC;WACzB,QAAQ;AAEjB,SAAO;AACT;ACjDA,IAAM,YAAY,OAAO;AAGzB,IAAM,KACJ,OAAO,gBAAgB,cACH,oBAAI,YAAW,IAC/B,OAAO,WAAW,cAClB;EACE,OAAO,KAAe;AACpB,UAAM,MAAM,OAAO,KAAK,IAAI,QAAQ,IAAI,YAAY,IAAI,UAAU;AAClE,WAAO,IAAI,SAAQ;;IAGvB;EACE,OAAO,KAAe;AACpB,QAAI,MAAM;AACV,aAAS,IAAI,GAAG,IAAI,IAAI,QAAQ,KAAK;AACnC,aAAO,OAAO,aAAa,IAAI,CAAC,CAAC;;AAEnC,WAAO;;;IAIJ,qBAAY;EAAzB,cAAA;AACE,SAAA,MAAM;AACE,SAAA,MAAM;AACN,SAAA,SAAS,IAAI,WAAW,SAAS;;EAEzC,MAAM,GAAS;AACb,UAAM,EAAE,OAAM,IAAK;AACnB,WAAO,KAAK,KAAK,IAAI;AACrB,QAAI,KAAK,QAAQ,WAAW;AAC1B,WAAK,OAAO,GAAG,OAAO,MAAM;AAC5B,WAAK,MAAM;;;EAIf,QAAK;AACH,UAAM,EAAE,QAAQ,KAAK,IAAG,IAAK;AAC7B,WAAO,MAAM,IAAI,MAAM,GAAG,OAAO,OAAO,SAAS,GAAG,GAAG,CAAC,IAAI;;;SEwChD,OAAO,SAAoC;AACzD,QAAM,SAAS,IAAI,aAAY;AAC/B,MAAI,eAAe;AACnB,MAAI,aAAa;AACjB,MAAI,eAAe;AACnB,MAAI,aAAa;AAEjB,WAAS,IAAI,GAAG,IAAI,QAAQ,QAAQ,KAAK;AACvC,UAAM,OAAO,QAAQ,CAAC;AACtB,QAAI,IAAI;AAAG,aAAO,MAAM,SAAS;AACjC,QAAI,KAAK,WAAW;AAAG;AAEvB,QAAI,YAAY;AAEhB,aAAS,IAAI,GAAG,IAAI,KAAK,QAAQ,KAAK;AACpC,YAAM,UAAU,KAAK,CAAC;AACtB,UAAI,IAAI;AAAG,eAAO,MAAM,KAAK;AAE7B,kBAAY,cAAc,QAAQ,QAAQ,CAAC,GAAG,SAAS;AAEvD,UAAI,QAAQ,WAAW;AAAG;AAC1B,qBAAe,cAAc,QAAQ,QAAQ,CAAC,GAAG,YAAY;AAC7D,mBAAa,cAAc,QAAQ,QAAQ,CAAC,GAAG,UAAU;AACzD,qBAAe,cAAc,QAAQ,QAAQ,CAAC,GAAG,YAAY;AAE7D,UAAI,QAAQ,WAAW;AAAG;AAC1B,mBAAa,cAAc,QAAQ,QAAQ,CAAC,GAAG,UAAU;;;AAI7D,SAAO,OAAO,MAAK;AACrB;;;AC9Ge,IAAM,SAAN,MAAM,QAAO;EAC3B,YAAY,KAAK;AAChB,SAAK,OAAO,eAAe,UAAS,IAAI,KAAK,MAAK,IAAK,CAAA;EACzD;EAEC,IAAIC,IAAG;AACN,SAAK,KAAKA,MAAK,CAAC,KAAK,MAAMA,KAAI;EACjC;EAEC,IAAIA,IAAG;AACN,WAAO,CAAC,EAAE,KAAK,KAAKA,MAAK,CAAC,IAAK,MAAMA,KAAI;EAC3C;AACA;ACZe,IAAM,QAAN,MAAM,OAAM;EAC1B,YAAY,OAAO,KAAK,SAAS;AAChC,SAAK,QAAQ;AACb,SAAK,MAAM;AACX,SAAK,WAAW;AAEhB,SAAK,QAAQ;AACb,SAAK,QAAQ;AAEb,SAAK,UAAU;AACf,SAAK,YAAY;AACjB,SAAK,SAAS;AAQP;AACN,WAAK,WAAW;AAChB,WAAK,OAAO;IACf;EACA;EAEC,WAAW,SAAS;AACnB,SAAK,SAAS;EAChB;EAEC,YAAY,SAAS;AACpB,SAAK,QAAQ,KAAK,QAAQ;EAC5B;EAEC,QAAQ;AACP,UAAM,QAAQ,IAAI,OAAM,KAAK,OAAO,KAAK,KAAK,KAAK,QAAQ;AAE3D,UAAM,QAAQ,KAAK;AACnB,UAAM,QAAQ,KAAK;AACnB,UAAM,UAAU,KAAK;AACrB,UAAM,YAAY,KAAK;AACvB,UAAM,SAAS,KAAK;AAEpB,WAAO;EACT;EAEC,SAAS,OAAO;AACf,WAAO,KAAK,QAAQ,SAAS,QAAQ,KAAK;EAC5C;EAEC,SAAS,IAAI;AACZ,QAAI,QAAQ;AACZ,WAAO,OAAO;AACb,SAAG,KAAK;AACR,cAAQ,MAAM;IACjB;EACA;EAEC,aAAa,IAAI;AAChB,QAAI,QAAQ;AACZ,WAAO,OAAO;AACb,SAAG,KAAK;AACR,cAAQ,MAAM;IACjB;EACA;EAEC,KAAK,SAAS,WAAW,aAAa;AACrC,SAAK,UAAU;AACf,QAAI,CAAC,aAAa;AACjB,WAAK,QAAQ;AACb,WAAK,QAAQ;IAChB;AACE,SAAK,YAAY;AAEjB,SAAK,SAAS;AAEd,WAAO;EACT;EAEC,YAAY,SAAS;AACpB,SAAK,QAAQ,UAAU,KAAK;EAC9B;EAEC,aAAa,SAAS;AACrB,SAAK,QAAQ,UAAU,KAAK;EAC9B;EAEC,QAAQ;AACP,SAAK,QAAQ;AACb,SAAK,QAAQ;AACb,QAAI,KAAK,QAAQ;AAChB,WAAK,UAAU,KAAK;AACpB,WAAK,YAAY;AACjB,WAAK,SAAS;IACjB;EACA;EAEC,MAAM,OAAO;AACZ,UAAM,aAAa,QAAQ,KAAK;AAEhC,UAAM,iBAAiB,KAAK,SAAS,MAAM,GAAG,UAAU;AACxD,UAAM,gBAAgB,KAAK,SAAS,MAAM,UAAU;AAEpD,SAAK,WAAW;AAEhB,UAAM,WAAW,IAAI,OAAM,OAAO,KAAK,KAAK,aAAa;AACzD,aAAS,QAAQ,KAAK;AACtB,SAAK,QAAQ;AAEb,SAAK,MAAM;AAEX,QAAI,KAAK,QAAQ;AAShB,eAAS,KAAK,IAAI,KAAK;AACvB,WAAK,UAAU;IAClB,OAAS;AACN,WAAK,UAAU;IAClB;AAEE,aAAS,OAAO,KAAK;AACrB,QAAI,SAAS,KAAM,UAAS,KAAK,WAAW;AAC5C,aAAS,WAAW;AACpB,SAAK,OAAO;AAEZ,WAAO;EACT;EAEC,WAAW;AACV,WAAO,KAAK,QAAQ,KAAK,UAAU,KAAK;EAC1C;EAEC,QAAQ,IAAI;AACX,SAAK,QAAQ,KAAK,MAAM,QAAQ,IAAI,EAAE;AACtC,QAAI,KAAK,MAAM,OAAQ,QAAO;AAE9B,UAAM,UAAU,KAAK,QAAQ,QAAQ,IAAI,EAAE;AAE3C,QAAI,QAAQ,QAAQ;AACnB,UAAI,YAAY,KAAK,SAAS;AAC7B,aAAK,MAAM,KAAK,QAAQ,QAAQ,MAAM,EAAE,KAAK,IAAI,QAAW,IAAI;AAChE,YAAI,KAAK,QAAQ;AAEhB,eAAK,KAAK,SAAS,KAAK,WAAW,IAAI;QAC5C;MACA;AACG,aAAO;IACV,OAAS;AACN,WAAK,KAAK,IAAI,QAAW,IAAI;AAE7B,WAAK,QAAQ,KAAK,MAAM,QAAQ,IAAI,EAAE;AACtC,UAAI,KAAK,MAAM,OAAQ,QAAO;IACjC;EACA;EAEC,UAAU,IAAI;AACb,SAAK,QAAQ,KAAK,MAAM,QAAQ,IAAI,EAAE;AACtC,QAAI,KAAK,MAAM,OAAQ,QAAO;AAE9B,UAAM,UAAU,KAAK,QAAQ,QAAQ,IAAI,EAAE;AAE3C,QAAI,QAAQ,QAAQ;AACnB,UAAI,YAAY,KAAK,SAAS;AAC7B,cAAM,WAAW,KAAK,MAAM,KAAK,MAAM,QAAQ,MAAM;AACrD,YAAI,KAAK,QAAQ;AAEhB,mBAAS,KAAK,SAAS,KAAK,WAAW,IAAI;QAChD;AACI,aAAK,KAAK,IAAI,QAAW,IAAI;MACjC;AACG,aAAO;IACV,OAAS;AACN,WAAK,KAAK,IAAI,QAAW,IAAI;AAE7B,WAAK,QAAQ,KAAK,MAAM,QAAQ,IAAI,EAAE;AACtC,UAAI,KAAK,MAAM,OAAQ,QAAO;IACjC;EACA;AACA;ACrLA,SAAS,UAAU;AAClB,MAAI,OAAO,eAAe,eAAe,OAAO,WAAW,SAAS,YAAY;AAC/E,WAAO,CAAC,QAAQ,WAAW,KAAK,SAAS,mBAAmB,GAAG,CAAC,CAAC;EACnE,WAAY,OAAO,WAAW,YAAY;AACxC,WAAO,CAAC,QAAQ,OAAO,KAAK,KAAK,OAAO,EAAE,SAAS,QAAQ;EAC7D,OAAQ;AACN,WAAO,MAAM;AACZ,YAAM,IAAI,MAAM,yEAAyE;IAC5F;EACA;AACA;AAEA,IAAM,OAAqB,wBAAO;AAEnB,IAAM,YAAN,MAAgB;EAC9B,YAAY,YAAY;AACvB,SAAK,UAAU;AACf,SAAK,OAAO,WAAW;AACvB,SAAK,UAAU,WAAW;AAC1B,SAAK,iBAAiB,WAAW;AACjC,SAAK,QAAQ,WAAW;AACxB,SAAK,WAAW,OAAO,WAAW,QAAQ;AAC1C,QAAI,OAAO,WAAW,wBAAwB,aAAa;AAC1D,WAAK,sBAAsB,WAAW;IACzC;AACE,QAAI,OAAO,WAAW,YAAY,aAAa;AAC9C,WAAK,UAAU,WAAW;IAC7B;EACA;EAEC,WAAW;AACV,WAAO,KAAK,UAAU,IAAI;EAC5B;EAEC,QAAQ;AACP,WAAO,gDAAgD,KAAK,KAAK,SAAQ,CAAE;EAC7E;AACA;ACvCe,SAAS,YAAY,MAAM;AACzC,QAAM,QAAQ,KAAK,MAAM,IAAI;AAE7B,QAAM,SAAS,MAAM,OAAO,CAAC,SAAS,OAAO,KAAK,IAAI,CAAC;AACvD,QAAM,SAAS,MAAM,OAAO,CAAC,SAAS,SAAS,KAAK,IAAI,CAAC;AAEzD,MAAI,OAAO,WAAW,KAAK,OAAO,WAAW,GAAG;AAC/C,WAAO;EACT;AAKC,MAAI,OAAO,UAAU,OAAO,QAAQ;AACnC,WAAO;EACT;AAGC,QAAM,MAAM,OAAO,OAAO,CAAC,UAAU,YAAY;AAChD,UAAM,YAAY,MAAM,KAAK,OAAO,EAAE,CAAC,EAAE;AACzC,WAAO,KAAK,IAAI,WAAW,QAAQ;EACrC,GAAI,QAAQ;AAEX,SAAO,IAAI,MAAM,MAAM,CAAC,EAAE,KAAK,GAAG;AACnC;ACxBe,SAAS,gBAAgB,MAAM,IAAI;AACjD,QAAM,YAAY,KAAK,MAAM,OAAO;AACpC,QAAM,UAAU,GAAG,MAAM,OAAO;AAEhC,YAAU,IAAG;AAEb,SAAO,UAAU,CAAC,MAAM,QAAQ,CAAC,GAAG;AACnC,cAAU,MAAK;AACf,YAAQ,MAAK;EACf;AAEC,MAAI,UAAU,QAAQ;AACrB,QAAI,IAAI,UAAU;AAClB,WAAO,IAAK,WAAU,CAAC,IAAI;EAC7B;AAEC,SAAO,UAAU,OAAO,OAAO,EAAE,KAAK,GAAG;AAC1C;ACjBA,IAAM,WAAW,OAAO,UAAU;AAEnB,SAAS,SAAS,OAAO;AACvC,SAAO,SAAS,KAAK,KAAK,MAAM;AACjC;ACJe,SAAS,WAAW,QAAQ;AAC1C,QAAM,gBAAgB,OAAO,MAAM,IAAI;AACvC,QAAM,cAAc,CAAA;AAEpB,WAAS,IAAI,GAAG,MAAM,GAAG,IAAI,cAAc,QAAQ,KAAK;AACvD,gBAAY,KAAK,GAAG;AACpB,WAAO,cAAc,CAAC,EAAE,SAAS;EACnC;AAEC,SAAO,SAAS,OAAO,OAAO;AAC7B,QAAI,IAAI;AACR,QAAI,IAAI,YAAY;AACpB,WAAO,IAAI,GAAG;AACb,YAAM,IAAK,IAAI,KAAM;AACrB,UAAI,QAAQ,YAAY,CAAC,GAAG;AAC3B,YAAI;MACR,OAAU;AACN,YAAI,IAAI;MACZ;IACA;AACE,UAAM,OAAO,IAAI;AACjB,UAAM,SAAS,QAAQ,YAAY,IAAI;AACvC,WAAO,EAAE,MAAM,OAAM;EACvB;AACA;ACxBA,IAAM,YAAY;AAEH,IAAM,WAAN,MAAe;EAC7B,YAAY,OAAO;AAClB,SAAK,QAAQ;AACb,SAAK,oBAAoB;AACzB,SAAK,sBAAsB;AAC3B,SAAK,MAAM,CAAA;AACX,SAAK,cAAc,KAAK,IAAI,KAAK,iBAAiB,IAAI,CAAA;AACtD,SAAK,UAAU;EACjB;EAEC,QAAQ,aAAa,SAAS,KAAK,WAAW;AAC7C,QAAI,QAAQ,QAAQ;AACnB,YAAM,wBAAwB,QAAQ,SAAS;AAC/C,UAAI,iBAAiB,QAAQ,QAAQ,MAAM,CAAC;AAC5C,UAAI,yBAAyB;AAG7B,aAAO,kBAAkB,KAAK,wBAAwB,gBAAgB;AACrE,cAAMC,WAAU,CAAC,KAAK,qBAAqB,aAAa,IAAI,MAAM,IAAI,MAAM;AAC5E,YAAI,aAAa,GAAG;AACnB,UAAAA,SAAQ,KAAK,SAAS;QAC3B;AACI,aAAK,YAAY,KAAKA,QAAO;AAE7B,aAAK,qBAAqB;AAC1B,aAAK,IAAI,KAAK,iBAAiB,IAAI,KAAK,cAAc,CAAA;AACtD,aAAK,sBAAsB;AAE3B,iCAAyB;AACzB,yBAAiB,QAAQ,QAAQ,MAAM,iBAAiB,CAAC;MAC7D;AAEG,YAAM,UAAU,CAAC,KAAK,qBAAqB,aAAa,IAAI,MAAM,IAAI,MAAM;AAC5E,UAAI,aAAa,GAAG;AACnB,gBAAQ,KAAK,SAAS;MAC1B;AACG,WAAK,YAAY,KAAK,OAAO;AAE7B,WAAK,QAAQ,QAAQ,MAAM,yBAAyB,CAAC,CAAC;IACzD,WAAa,KAAK,SAAS;AACxB,WAAK,YAAY,KAAK,KAAK,OAAO;AAClC,WAAK,QAAQ,OAAO;IACvB;AAEE,SAAK,UAAU;EACjB;EAEC,iBAAiB,aAAa,OAAO,UAAU,KAAK,oBAAoB;AACvE,QAAI,oBAAoB,MAAM;AAC9B,QAAI,QAAQ;AAEZ,QAAI,sBAAsB;AAE1B,WAAO,oBAAoB,MAAM,KAAK;AACrC,UAAI,SAAS,iBAAiB,MAAM,MAAM;AACzC,YAAI,QAAQ;AACZ,YAAI,SAAS;AACb,aAAK,qBAAqB;AAC1B,aAAK,IAAI,KAAK,iBAAiB,IAAI,KAAK,cAAc,CAAA;AACtD,aAAK,sBAAsB;AAC3B,gBAAQ;AACR,8BAAsB;MAC1B,OAAU;AACN,YAAI,KAAK,SAAS,SAAS,mBAAmB,IAAI,iBAAiB,GAAG;AACrE,gBAAM,UAAU,CAAC,KAAK,qBAAqB,aAAa,IAAI,MAAM,IAAI,MAAM;AAE5E,cAAI,KAAK,UAAU,YAAY;AAE9B,gBAAI,UAAU,KAAK,SAAS,iBAAiB,CAAC,GAAG;AAEhD,kBAAI,CAAC,qBAAqB;AACzB,qBAAK,YAAY,KAAK,OAAO;AAC7B,sCAAsB;cAC9B;YACA,OAAa;AAEN,mBAAK,YAAY,KAAK,OAAO;AAC7B,oCAAsB;YAC7B;UACA,OAAY;AACN,iBAAK,YAAY,KAAK,OAAO;UACnC;QACA;AAEI,YAAI,UAAU;AACd,aAAK,uBAAuB;AAC5B,gBAAQ;MACZ;AAEG,2BAAqB;IACxB;AAEE,SAAK,UAAU;EACjB;EAEC,QAAQ,KAAK;AACZ,QAAI,CAAC,IAAK;AAEV,UAAM,QAAQ,IAAI,MAAM,IAAI;AAE5B,QAAI,MAAM,SAAS,GAAG;AACrB,eAAS,IAAI,GAAG,IAAI,MAAM,SAAS,GAAG,KAAK;AAC1C,aAAK;AACL,aAAK,IAAI,KAAK,iBAAiB,IAAI,KAAK,cAAc,CAAA;MAC1D;AACG,WAAK,sBAAsB;IAC9B;AAEE,SAAK,uBAAuB,MAAM,MAAM,SAAS,CAAC,EAAE;EACtD;AACA;ACtGA,IAAM,IAAI;AAEV,IAAM,SAAS;EACd,YAAY;EACZ,aAAa;EACb,WAAW;AACZ;AAEe,IAAM,cAAN,MAAM,aAAY;EAChC,YAAY,QAAQ,UAAU,CAAA,GAAI;AACjC,UAAM,QAAQ,IAAI,MAAM,GAAG,OAAO,QAAQ,MAAM;AAEhD,WAAO,iBAAiB,MAAM;MAC7B,UAAU,EAAE,UAAU,MAAM,OAAO,OAAM;MACzC,OAAO,EAAE,UAAU,MAAM,OAAO,GAAE;MAClC,OAAO,EAAE,UAAU,MAAM,OAAO,GAAE;MAClC,YAAY,EAAE,UAAU,MAAM,OAAO,MAAK;MAC1C,WAAW,EAAE,UAAU,MAAM,OAAO,MAAK;MACzC,mBAAmB,EAAE,UAAU,MAAM,OAAO,MAAK;MACjD,SAAS,EAAE,UAAU,MAAM,OAAO,CAAA,EAAE;MACpC,OAAO,EAAE,UAAU,MAAM,OAAO,CAAA,EAAE;MAClC,UAAU,EAAE,UAAU,MAAM,OAAO,QAAQ,SAAQ;MACnD,uBAAuB,EAAE,UAAU,MAAM,OAAO,QAAQ,sBAAqB;MAC7E,oBAAoB,EAAE,UAAU,MAAM,OAAO,IAAI,OAAM,EAAE;MACzD,aAAa,EAAE,UAAU,MAAM,OAAO,CAAA,EAAE;MACxC,WAAW,EAAE,UAAU,MAAM,OAAO,OAAS;MAC7C,YAAY,EAAE,UAAU,MAAM,OAAO,QAAQ,WAAU;MACvD,QAAQ,EAAE,UAAU,MAAM,OAAO,QAAQ,UAAU,EAAC;IACvD,CAAG;AAMD,SAAK,QAAQ,CAAC,IAAI;AAClB,SAAK,MAAM,OAAO,MAAM,IAAI;EAC9B;EAEC,qBAAqB,MAAM;AAC1B,SAAK,mBAAmB,IAAI,IAAI;EAClC;EAEC,OAAO,SAAS;AACf,QAAI,OAAO,YAAY,SAAU,OAAM,IAAI,UAAU,gCAAgC;AAErF,SAAK,SAAS;AACd,WAAO;EACT;EAEC,WAAW,OAAO,SAAS;AAC1B,YAAQ,QAAQ,KAAK;AAErB,QAAI,OAAO,YAAY,SAAU,OAAM,IAAI,UAAU,mCAAmC;AAIxF,SAAK,OAAO,KAAK;AAEjB,UAAM,QAAQ,KAAK,MAAM,KAAK;AAE9B,QAAI,OAAO;AACV,YAAM,WAAW,OAAO;IAC3B,OAAS;AACN,WAAK,SAAS;IACjB;AAGE,WAAO;EACT;EAEC,YAAY,OAAO,SAAS;AAC3B,YAAQ,QAAQ,KAAK;AAErB,QAAI,OAAO,YAAY,SAAU,OAAM,IAAI,UAAU,mCAAmC;AAIxF,SAAK,OAAO,KAAK;AAEjB,UAAM,QAAQ,KAAK,QAAQ,KAAK;AAEhC,QAAI,OAAO;AACV,YAAM,YAAY,OAAO;IAC5B,OAAS;AACN,WAAK,SAAS;IACjB;AAGE,WAAO;EACT;EAEC,QAAQ;AACP,UAAM,SAAS,IAAI,aAAY,KAAK,UAAU,EAAE,UAAU,KAAK,UAAU,QAAQ,KAAK,OAAM,CAAE;AAE9F,QAAI,gBAAgB,KAAK;AACzB,QAAI,cAAe,OAAO,aAAa,OAAO,oBAAoB,cAAc,MAAK;AAErF,WAAO,eAAe;AACrB,aAAO,QAAQ,YAAY,KAAK,IAAI;AACpC,aAAO,MAAM,YAAY,GAAG,IAAI;AAEhC,YAAM,oBAAoB,cAAc;AACxC,YAAM,kBAAkB,qBAAqB,kBAAkB,MAAK;AAEpE,UAAI,iBAAiB;AACpB,oBAAY,OAAO;AACnB,wBAAgB,WAAW;AAE3B,sBAAc;MAClB;AAEG,sBAAgB;IACnB;AAEE,WAAO,YAAY;AAEnB,QAAI,KAAK,uBAAuB;AAC/B,aAAO,wBAAwB,KAAK,sBAAsB,MAAK;IAClE;AAEE,WAAO,qBAAqB,IAAI,OAAO,KAAK,kBAAkB;AAE9D,WAAO,QAAQ,KAAK;AACpB,WAAO,QAAQ,KAAK;AAEpB,WAAO;EACT;EAEC,mBAAmB,SAAS;AAC3B,cAAU,WAAW,CAAA;AAErB,UAAM,cAAc;AACpB,UAAM,QAAQ,OAAO,KAAK,KAAK,WAAW;AAC1C,UAAM,WAAW,IAAI,SAAS,QAAQ,KAAK;AAE3C,UAAM,SAAS,WAAW,KAAK,QAAQ;AAEvC,QAAI,KAAK,OAAO;AACf,eAAS,QAAQ,KAAK,KAAK;IAC9B;AAEE,SAAK,WAAW,SAAS,CAAC,UAAU;AACnC,YAAM,MAAM,OAAO,MAAM,KAAK;AAE9B,UAAI,MAAM,MAAM,OAAQ,UAAS,QAAQ,MAAM,KAAK;AAEpD,UAAI,MAAM,QAAQ;AACjB,iBAAS;UACR;UACA,MAAM;UACN;UACA,MAAM,YAAY,MAAM,QAAQ,MAAM,QAAQ,IAAI;QACvD;MACA,OAAU;AACN,iBAAS,iBAAiB,aAAa,OAAO,KAAK,UAAU,KAAK,KAAK,kBAAkB;MAC7F;AAEG,UAAI,MAAM,MAAM,OAAQ,UAAS,QAAQ,MAAM,KAAK;IACvD,CAAG;AAED,WAAO;MACN,MAAM,QAAQ,OAAO,QAAQ,KAAK,MAAM,OAAO,EAAE,IAAG,IAAK;MACzD,SAAS;QACR,QAAQ,SAAS,gBAAgB,QAAQ,QAAQ,IAAI,QAAQ,MAAM,IAAI,QAAQ,QAAQ;MAC3F;MACG,gBAAgB,QAAQ,iBAAiB,CAAC,KAAK,QAAQ,IAAI;MAC3D;MACA,UAAU,SAAS;MACnB,qBAAqB,KAAK,aAAa,CAAC,WAAW,IAAI;IAC1D;EACA;EAEC,YAAY,SAAS;AACpB,WAAO,IAAI,UAAU,KAAK,mBAAmB,OAAO,CAAC;EACvD;EAEC,mBAAmB;AAClB,QAAI,KAAK,cAAc,QAAW;AACjC,WAAK,YAAY,YAAY,KAAK,QAAQ;IAC7C;EACA;EAEC,sBAAsB;AACrB,SAAK,iBAAgB;AACrB,WAAO,KAAK;EACd;EAEC,kBAAkB;AACjB,SAAK,iBAAgB;AACrB,WAAO,KAAK,cAAc,OAAO,MAAO,KAAK;EAC/C;EAEC,OAAO,WAAW,SAAS;AAC1B,UAAM,UAAU;AAEhB,QAAI,SAAS,SAAS,GAAG;AACxB,gBAAU;AACV,kBAAY;IACf;AAEE,QAAI,cAAc,QAAW;AAC5B,WAAK,iBAAgB;AACrB,kBAAY,KAAK,aAAa;IACjC;AAEE,QAAI,cAAc,GAAI,QAAO;AAE7B,cAAU,WAAW,CAAA;AAGrB,UAAM,aAAa,CAAA;AAEnB,QAAI,QAAQ,SAAS;AACpB,YAAM,aACL,OAAO,QAAQ,QAAQ,CAAC,MAAM,WAAW,CAAC,QAAQ,OAAO,IAAI,QAAQ;AACtE,iBAAW,QAAQ,CAAC,cAAc;AACjC,iBAAS,IAAI,UAAU,CAAC,GAAG,IAAI,UAAU,CAAC,GAAG,KAAK,GAAG;AACpD,qBAAW,CAAC,IAAI;QACrB;MACA,CAAI;IACJ;AAEE,QAAI,4BAA4B,QAAQ,gBAAgB;AACxD,UAAM,WAAW,CAAC,UAAU;AAC3B,UAAI,0BAA2B,QAAO,GAAG,SAAS,GAAG,KAAK;AAC1D,kCAA4B;AAC5B,aAAO;IACV;AAEE,SAAK,QAAQ,KAAK,MAAM,QAAQ,SAAS,QAAQ;AAEjD,QAAI,YAAY;AAChB,QAAI,QAAQ,KAAK;AAEjB,WAAO,OAAO;AACb,YAAM,MAAM,MAAM;AAElB,UAAI,MAAM,QAAQ;AACjB,YAAI,CAAC,WAAW,SAAS,GAAG;AAC3B,gBAAM,UAAU,MAAM,QAAQ,QAAQ,SAAS,QAAQ;AAEvD,cAAI,MAAM,QAAQ,QAAQ;AACzB,wCAA4B,MAAM,QAAQ,MAAM,QAAQ,SAAS,CAAC,MAAM;UAC9E;QACA;MACA,OAAU;AACN,oBAAY,MAAM;AAElB,eAAO,YAAY,KAAK;AACvB,cAAI,CAAC,WAAW,SAAS,GAAG;AAC3B,kBAAM,OAAO,KAAK,SAAS,SAAS;AAEpC,gBAAI,SAAS,MAAM;AAClB,0CAA4B;YACnC,WAAiB,SAAS,QAAQ,2BAA2B;AACtD,0CAA4B;AAE5B,kBAAI,cAAc,MAAM,OAAO;AAC9B,sBAAM,aAAa,SAAS;cACpC,OAAc;AACN,qBAAK,YAAY,OAAO,SAAS;AACjC,wBAAQ,MAAM;AACd,sBAAM,aAAa,SAAS;cACpC;YACA;UACA;AAEK,uBAAa;QAClB;MACA;AAEG,kBAAY,MAAM;AAClB,cAAQ,MAAM;IACjB;AAEE,SAAK,QAAQ,KAAK,MAAM,QAAQ,SAAS,QAAQ;AAEjD,WAAO;EACT;EAEC,SAAS;AACR,UAAM,IAAI;MACT;IACH;EACA;EAEC,WAAW,OAAO,SAAS;AAC1B,QAAI,CAAC,OAAO,YAAY;AACvB,cAAQ;QACP;MACJ;AACG,aAAO,aAAa;IACvB;AAEE,WAAO,KAAK,WAAW,OAAO,OAAO;EACvC;EAEC,YAAY,OAAO,SAAS;AAC3B,QAAI,CAAC,OAAO,aAAa;AACxB,cAAQ;QACP;MACJ;AACG,aAAO,cAAc;IACxB;AAEE,WAAO,KAAK,aAAa,OAAO,OAAO;EACzC;EAEC,KAAK,OAAO,KAAK,OAAO;AACvB,YAAQ,QAAQ,KAAK;AACrB,UAAM,MAAM,KAAK;AACjB,YAAQ,QAAQ,KAAK;AAErB,QAAI,SAAS,SAAS,SAAS,IAAK,OAAM,IAAI,MAAM,uCAAuC;AAI3F,SAAK,OAAO,KAAK;AACjB,SAAK,OAAO,GAAG;AACf,SAAK,OAAO,KAAK;AAEjB,UAAM,QAAQ,KAAK,QAAQ,KAAK;AAChC,UAAM,OAAO,KAAK,MAAM,GAAG;AAE3B,UAAM,UAAU,MAAM;AACtB,UAAM,WAAW,KAAK;AAEtB,UAAM,WAAW,KAAK,QAAQ,KAAK;AACnC,QAAI,CAAC,YAAY,SAAS,KAAK,UAAW,QAAO;AACjD,UAAM,UAAU,WAAW,SAAS,WAAW,KAAK;AAEpD,QAAI,QAAS,SAAQ,OAAO;AAC5B,QAAI,SAAU,UAAS,WAAW;AAElC,QAAI,QAAS,SAAQ,OAAO;AAC5B,QAAI,SAAU,UAAS,WAAW;AAElC,QAAI,CAAC,MAAM,SAAU,MAAK,aAAa,KAAK;AAC5C,QAAI,CAAC,KAAK,MAAM;AACf,WAAK,YAAY,MAAM;AACvB,WAAK,UAAU,OAAO;IACzB;AAEE,UAAM,WAAW;AACjB,SAAK,OAAO,YAAY;AAExB,QAAI,CAAC,QAAS,MAAK,aAAa;AAChC,QAAI,CAAC,SAAU,MAAK,YAAY;AAGhC,WAAO;EACT;EAEC,UAAU,OAAO,KAAK,SAAS,SAAS;AACvC,cAAU,WAAW,CAAA;AACrB,WAAO,KAAK,OAAO,OAAO,KAAK,SAAS,EAAE,GAAG,SAAS,WAAW,CAAC,QAAQ,YAAW,CAAE;EACzF;EAEC,OAAO,OAAO,KAAK,SAAS,SAAS;AACpC,YAAQ,QAAQ,KAAK;AACrB,UAAM,MAAM,KAAK;AAEjB,QAAI,OAAO,YAAY,SAAU,OAAM,IAAI,UAAU,sCAAsC;AAE3F,QAAI,KAAK,SAAS,WAAW,GAAG;AAC/B,aAAO,QAAQ,EAAG,UAAS,KAAK,SAAS;AACzC,aAAO,MAAM,EAAG,QAAO,KAAK,SAAS;IACxC;AAEE,QAAI,MAAM,KAAK,SAAS,OAAQ,OAAM,IAAI,MAAM,sBAAsB;AACtE,QAAI,UAAU;AACb,YAAM,IAAI;QACT;MACJ;AAIE,SAAK,OAAO,KAAK;AACjB,SAAK,OAAO,GAAG;AAEf,QAAI,YAAY,MAAM;AACrB,UAAI,CAAC,OAAO,WAAW;AACtB,gBAAQ;UACP;QACL;AACI,eAAO,YAAY;MACvB;AAEG,gBAAU,EAAE,WAAW,KAAI;IAC9B;AACE,UAAM,YAAY,YAAY,SAAY,QAAQ,YAAY;AAC9D,UAAM,YAAY,YAAY,SAAY,QAAQ,YAAY;AAE9D,QAAI,WAAW;AACd,YAAM,WAAW,KAAK,SAAS,MAAM,OAAO,GAAG;AAC/C,aAAO,eAAe,KAAK,aAAa,UAAU;QACjD,UAAU;QACV,OAAO;QACP,YAAY;MAChB,CAAI;IACJ;AAEE,UAAM,QAAQ,KAAK,QAAQ,KAAK;AAChC,UAAM,OAAO,KAAK,MAAM,GAAG;AAE3B,QAAI,OAAO;AACV,UAAI,QAAQ;AACZ,aAAO,UAAU,MAAM;AACtB,YAAI,MAAM,SAAS,KAAK,QAAQ,MAAM,GAAG,GAAG;AAC3C,gBAAM,IAAI,MAAM,uCAAuC;QAC5D;AACI,gBAAQ,MAAM;AACd,cAAM,KAAK,IAAI,KAAK;MACxB;AAEG,YAAM,KAAK,SAAS,WAAW,CAAC,SAAS;IAC5C,OAAS;AAEN,YAAM,WAAW,IAAI,MAAM,OAAO,KAAK,EAAE,EAAE,KAAK,SAAS,SAAS;AAGlE,WAAK,OAAO;AACZ,eAAS,WAAW;IACvB;AAGE,WAAO;EACT;EAEC,QAAQ,SAAS;AAChB,QAAI,OAAO,YAAY,SAAU,OAAM,IAAI,UAAU,gCAAgC;AAErF,SAAK,QAAQ,UAAU,KAAK;AAC5B,WAAO;EACT;EAEC,YAAY,OAAO,SAAS;AAC3B,YAAQ,QAAQ,KAAK;AAErB,QAAI,OAAO,YAAY,SAAU,OAAM,IAAI,UAAU,mCAAmC;AAIxF,SAAK,OAAO,KAAK;AAEjB,UAAM,QAAQ,KAAK,MAAM,KAAK;AAE9B,QAAI,OAAO;AACV,YAAM,YAAY,OAAO;IAC5B,OAAS;AACN,WAAK,QAAQ,UAAU,KAAK;IAC/B;AAGE,WAAO;EACT;EAEC,aAAa,OAAO,SAAS;AAC5B,YAAQ,QAAQ,KAAK;AAErB,QAAI,OAAO,YAAY,SAAU,OAAM,IAAI,UAAU,mCAAmC;AAIxF,SAAK,OAAO,KAAK;AAEjB,UAAM,QAAQ,KAAK,QAAQ,KAAK;AAEhC,QAAI,OAAO;AACV,YAAM,aAAa,OAAO;IAC7B,OAAS;AACN,WAAK,QAAQ,UAAU,KAAK;IAC/B;AAGE,WAAO;EACT;EAEC,OAAO,OAAO,KAAK;AAClB,YAAQ,QAAQ,KAAK;AACrB,UAAM,MAAM,KAAK;AAEjB,QAAI,KAAK,SAAS,WAAW,GAAG;AAC/B,aAAO,QAAQ,EAAG,UAAS,KAAK,SAAS;AACzC,aAAO,MAAM,EAAG,QAAO,KAAK,SAAS;IACxC;AAEE,QAAI,UAAU,IAAK,QAAO;AAE1B,QAAI,QAAQ,KAAK,MAAM,KAAK,SAAS,OAAQ,OAAM,IAAI,MAAM,4BAA4B;AACzF,QAAI,QAAQ,IAAK,OAAM,IAAI,MAAM,gCAAgC;AAIjE,SAAK,OAAO,KAAK;AACjB,SAAK,OAAO,GAAG;AAEf,QAAI,QAAQ,KAAK,QAAQ,KAAK;AAE9B,WAAO,OAAO;AACb,YAAM,QAAQ;AACd,YAAM,QAAQ;AACd,YAAM,KAAK,EAAE;AAEb,cAAQ,MAAM,MAAM,MAAM,KAAK,QAAQ,MAAM,GAAG,IAAI;IACvD;AAGE,WAAO;EACT;EAEC,MAAM,OAAO,KAAK;AACjB,YAAQ,QAAQ,KAAK;AACrB,UAAM,MAAM,KAAK;AAEjB,QAAI,KAAK,SAAS,WAAW,GAAG;AAC/B,aAAO,QAAQ,EAAG,UAAS,KAAK,SAAS;AACzC,aAAO,MAAM,EAAG,QAAO,KAAK,SAAS;IACxC;AAEE,QAAI,UAAU,IAAK,QAAO;AAE1B,QAAI,QAAQ,KAAK,MAAM,KAAK,SAAS,OAAQ,OAAM,IAAI,MAAM,4BAA4B;AACzF,QAAI,QAAQ,IAAK,OAAM,IAAI,MAAM,gCAAgC;AAIjE,SAAK,OAAO,KAAK;AACjB,SAAK,OAAO,GAAG;AAEf,QAAI,QAAQ,KAAK,QAAQ,KAAK;AAE9B,WAAO,OAAO;AACb,YAAM,MAAK;AAEX,cAAQ,MAAM,MAAM,MAAM,KAAK,QAAQ,MAAM,GAAG,IAAI;IACvD;AAGE,WAAO;EACT;EAEC,WAAW;AACV,QAAI,KAAK,MAAM,OAAQ,QAAO,KAAK,MAAM,KAAK,MAAM,SAAS,CAAC;AAC9D,QAAI,QAAQ,KAAK;AACjB,OAAG;AACF,UAAI,MAAM,MAAM,OAAQ,QAAO,MAAM,MAAM,MAAM,MAAM,SAAS,CAAC;AACjE,UAAI,MAAM,QAAQ,OAAQ,QAAO,MAAM,QAAQ,MAAM,QAAQ,SAAS,CAAC;AACvE,UAAI,MAAM,MAAM,OAAQ,QAAO,MAAM,MAAM,MAAM,MAAM,SAAS,CAAC;IACpE,SAAY,QAAQ,MAAM;AACxB,QAAI,KAAK,MAAM,OAAQ,QAAO,KAAK,MAAM,KAAK,MAAM,SAAS,CAAC;AAC9D,WAAO;EACT;EAEC,WAAW;AACV,QAAI,YAAY,KAAK,MAAM,YAAY,CAAC;AACxC,QAAI,cAAc,GAAI,QAAO,KAAK,MAAM,OAAO,YAAY,CAAC;AAC5D,QAAI,UAAU,KAAK;AACnB,QAAI,QAAQ,KAAK;AACjB,OAAG;AACF,UAAI,MAAM,MAAM,SAAS,GAAG;AAC3B,oBAAY,MAAM,MAAM,YAAY,CAAC;AACrC,YAAI,cAAc,GAAI,QAAO,MAAM,MAAM,OAAO,YAAY,CAAC,IAAI;AACjE,kBAAU,MAAM,QAAQ;MAC5B;AAEG,UAAI,MAAM,QAAQ,SAAS,GAAG;AAC7B,oBAAY,MAAM,QAAQ,YAAY,CAAC;AACvC,YAAI,cAAc,GAAI,QAAO,MAAM,QAAQ,OAAO,YAAY,CAAC,IAAI;AACnE,kBAAU,MAAM,UAAU;MAC9B;AAEG,UAAI,MAAM,MAAM,SAAS,GAAG;AAC3B,oBAAY,MAAM,MAAM,YAAY,CAAC;AACrC,YAAI,cAAc,GAAI,QAAO,MAAM,MAAM,OAAO,YAAY,CAAC,IAAI;AACjE,kBAAU,MAAM,QAAQ;MAC5B;IACA,SAAY,QAAQ,MAAM;AACxB,gBAAY,KAAK,MAAM,YAAY,CAAC;AACpC,QAAI,cAAc,GAAI,QAAO,KAAK,MAAM,OAAO,YAAY,CAAC,IAAI;AAChE,WAAO,KAAK,QAAQ;EACtB;EAEC,MAAM,QAAQ,GAAG,MAAM,KAAK,SAAS,SAAS,KAAK,QAAQ;AAC1D,YAAQ,QAAQ,KAAK;AACrB,UAAM,MAAM,KAAK;AAEjB,QAAI,KAAK,SAAS,WAAW,GAAG;AAC/B,aAAO,QAAQ,EAAG,UAAS,KAAK,SAAS;AACzC,aAAO,MAAM,EAAG,QAAO,KAAK,SAAS;IACxC;AAEE,QAAI,SAAS;AAGb,QAAI,QAAQ,KAAK;AACjB,WAAO,UAAU,MAAM,QAAQ,SAAS,MAAM,OAAO,QAAQ;AAE5D,UAAI,MAAM,QAAQ,OAAO,MAAM,OAAO,KAAK;AAC1C,eAAO;MACX;AAEG,cAAQ,MAAM;IACjB;AAEE,QAAI,SAAS,MAAM,UAAU,MAAM,UAAU;AAC5C,YAAM,IAAI,MAAM,iCAAiC,KAAK,yBAAyB;AAEhF,UAAM,aAAa;AACnB,WAAO,OAAO;AACb,UAAI,MAAM,UAAU,eAAe,SAAS,MAAM,UAAU,QAAQ;AACnE,kBAAU,MAAM;MACpB;AAEG,YAAM,cAAc,MAAM,QAAQ,OAAO,MAAM,OAAO;AACtD,UAAI,eAAe,MAAM,UAAU,MAAM,QAAQ;AAChD,cAAM,IAAI,MAAM,iCAAiC,GAAG,uBAAuB;AAE5E,YAAM,aAAa,eAAe,QAAQ,QAAQ,MAAM,QAAQ;AAChE,YAAM,WAAW,cAAc,MAAM,QAAQ,SAAS,MAAM,MAAM,MAAM,MAAM,QAAQ;AAEtF,gBAAU,MAAM,QAAQ,MAAM,YAAY,QAAQ;AAElD,UAAI,MAAM,UAAU,CAAC,eAAe,MAAM,QAAQ,MAAM;AACvD,kBAAU,MAAM;MACpB;AAEG,UAAI,aAAa;AAChB;MACJ;AAEG,cAAQ,MAAM;IACjB;AAEE,WAAO;EACT;;EAGC,KAAK,OAAO,KAAK;AAChB,UAAM,QAAQ,KAAK,MAAK;AACxB,UAAM,OAAO,GAAG,KAAK;AACrB,UAAM,OAAO,KAAK,MAAM,SAAS,MAAM;AAEvC,WAAO;EACT;EAEC,OAAO,OAAO;AACb,QAAI,KAAK,QAAQ,KAAK,KAAK,KAAK,MAAM,KAAK,EAAG;AAI9C,QAAI,QAAQ,KAAK;AACjB,UAAM,gBAAgB,QAAQ,MAAM;AAEpC,WAAO,OAAO;AACb,UAAI,MAAM,SAAS,KAAK,EAAG,QAAO,KAAK,YAAY,OAAO,KAAK;AAE/D,cAAQ,gBAAgB,KAAK,QAAQ,MAAM,GAAG,IAAI,KAAK,MAAM,MAAM,KAAK;IAC3E;EACA;EAEC,YAAY,OAAO,OAAO;AACzB,QAAI,MAAM,UAAU,MAAM,QAAQ,QAAQ;AAEzC,YAAM,MAAM,WAAW,KAAK,QAAQ,EAAE,KAAK;AAC3C,YAAM,IAAI;QACT,sDAAsD,IAAI,IAAI,IAAI,IAAI,MAAM,YAAO,MAAM,QAAQ;MACrG;IACA;AAEE,UAAM,WAAW,MAAM,MAAM,KAAK;AAElC,SAAK,MAAM,KAAK,IAAI;AACpB,SAAK,QAAQ,KAAK,IAAI;AACtB,SAAK,MAAM,SAAS,GAAG,IAAI;AAE3B,QAAI,UAAU,KAAK,UAAW,MAAK,YAAY;AAE/C,SAAK,oBAAoB;AAEzB,WAAO;EACT;EAEC,WAAW;AACV,QAAI,MAAM,KAAK;AAEf,QAAI,QAAQ,KAAK;AACjB,WAAO,OAAO;AACb,aAAO,MAAM,SAAQ;AACrB,cAAQ,MAAM;IACjB;AAEE,WAAO,MAAM,KAAK;EACpB;EAEC,UAAU;AACT,QAAI,QAAQ,KAAK;AACjB,OAAG;AACF,UACE,MAAM,MAAM,UAAU,MAAM,MAAM,KAAI,KACtC,MAAM,QAAQ,UAAU,MAAM,QAAQ,KAAI,KAC1C,MAAM,MAAM,UAAU,MAAM,MAAM,KAAI;AAEvC,eAAO;IACX,SAAY,QAAQ,MAAM;AACxB,WAAO;EACT;EAEC,SAAS;AACR,QAAI,QAAQ,KAAK;AACjB,QAAI,SAAS;AACb,OAAG;AACF,gBAAU,MAAM,MAAM,SAAS,MAAM,QAAQ,SAAS,MAAM,MAAM;IACrE,SAAY,QAAQ,MAAM;AACxB,WAAO;EACT;EAEC,YAAY;AACX,WAAO,KAAK,KAAK,UAAU;EAC7B;EAEC,KAAK,UAAU;AACd,WAAO,KAAK,UAAU,QAAQ,EAAE,QAAQ,QAAQ;EAClD;EAEC,eAAe,UAAU;AACxB,UAAM,KAAK,IAAI,QAAQ,YAAY,SAAS,IAAI;AAEhD,SAAK,QAAQ,KAAK,MAAM,QAAQ,IAAI,EAAE;AACtC,QAAI,KAAK,MAAM,OAAQ,QAAO;AAE9B,QAAI,QAAQ,KAAK;AAEjB,OAAG;AACF,YAAM,MAAM,MAAM;AAClB,YAAM,UAAU,MAAM,QAAQ,EAAE;AAGhC,UAAI,MAAM,QAAQ,KAAK;AACtB,YAAI,KAAK,cAAc,OAAO;AAC7B,eAAK,YAAY,MAAM;QAC5B;AAEI,aAAK,MAAM,MAAM,GAAG,IAAI;AACxB,aAAK,QAAQ,MAAM,KAAK,KAAK,IAAI,MAAM;AACvC,aAAK,MAAM,MAAM,KAAK,GAAG,IAAI,MAAM;MACvC;AAEG,UAAI,QAAS,QAAO;AACpB,cAAQ,MAAM;IACjB,SAAW;AAET,WAAO;EACT;EAEC,QAAQ,UAAU;AACjB,SAAK,eAAe,QAAQ;AAC5B,WAAO;EACT;EACC,iBAAiB,UAAU;AAC1B,UAAM,KAAK,IAAI,OAAO,OAAO,YAAY,SAAS,GAAG;AAErD,SAAK,QAAQ,KAAK,MAAM,QAAQ,IAAI,EAAE;AACtC,QAAI,KAAK,MAAM,OAAQ,QAAO;AAE9B,QAAI,QAAQ,KAAK;AAEjB,OAAG;AACF,YAAM,MAAM,MAAM;AAClB,YAAM,UAAU,MAAM,UAAU,EAAE;AAElC,UAAI,MAAM,QAAQ,KAAK;AAEtB,YAAI,UAAU,KAAK,UAAW,MAAK,YAAY,MAAM;AAErD,aAAK,MAAM,MAAM,GAAG,IAAI;AACxB,aAAK,QAAQ,MAAM,KAAK,KAAK,IAAI,MAAM;AACvC,aAAK,MAAM,MAAM,KAAK,GAAG,IAAI,MAAM;MACvC;AAEG,UAAI,QAAS,QAAO;AACpB,cAAQ,MAAM;IACjB,SAAW;AAET,WAAO;EACT;EAEC,UAAU,UAAU;AACnB,SAAK,iBAAiB,QAAQ;AAC9B,WAAO;EACT;EAEC,aAAa;AACZ,WAAO,KAAK,aAAa,KAAK,SAAQ;EACxC;EAEC,eAAe,aAAa,aAAa;AACxC,aAAS,eAAe,OAAO,KAAK;AACnC,UAAI,OAAO,gBAAgB,UAAU;AACpC,eAAO,YAAY,QAAQ,iBAAiB,CAAC,GAAG,MAAM;AAErD,cAAI,MAAM,IAAK,QAAO;AACtB,cAAI,MAAM,IAAK,QAAO,MAAM,CAAC;AAC7B,gBAAM,MAAM,CAAC;AACb,cAAI,MAAM,MAAM,OAAQ,QAAO,MAAM,CAAC,CAAC;AACvC,iBAAO,IAAI,CAAC;QACjB,CAAK;MACL,OAAU;AACN,eAAO,YAAY,GAAG,OAAO,MAAM,OAAO,KAAK,MAAM,MAAM;MAC/D;IACA;AACE,aAAS,SAAS,IAAI,KAAK;AAC1B,UAAI;AACJ,YAAM,UAAU,CAAA;AAChB,aAAQ,QAAQ,GAAG,KAAK,GAAG,GAAI;AAC9B,gBAAQ,KAAK,KAAK;MACtB;AACG,aAAO;IACV;AACE,QAAI,YAAY,QAAQ;AACvB,YAAM,UAAU,SAAS,aAAa,KAAK,QAAQ;AACnD,cAAQ,QAAQ,CAAC,UAAU;AAC1B,YAAI,MAAM,SAAS,MAAM;AACxB,gBAAMC,eAAc,eAAe,OAAO,KAAK,QAAQ;AACvD,cAAIA,iBAAgB,MAAM,CAAC,GAAG;AAC7B,iBAAK,UAAU,MAAM,OAAO,MAAM,QAAQ,MAAM,CAAC,EAAE,QAAQA,YAAW;UAC5E;QACA;MACA,CAAI;IACJ,OAAS;AACN,YAAM,QAAQ,KAAK,SAAS,MAAM,WAAW;AAC7C,UAAI,SAAS,MAAM,SAAS,MAAM;AACjC,cAAMA,eAAc,eAAe,OAAO,KAAK,QAAQ;AACvD,YAAIA,iBAAgB,MAAM,CAAC,GAAG;AAC7B,eAAK,UAAU,MAAM,OAAO,MAAM,QAAQ,MAAM,CAAC,EAAE,QAAQA,YAAW;QAC3E;MACA;IACA;AACE,WAAO;EACT;EAEC,eAAe,QAAQ,aAAa;AACnC,UAAM,EAAE,SAAQ,IAAK;AACrB,UAAM,QAAQ,SAAS,QAAQ,MAAM;AAErC,QAAI,UAAU,IAAI;AACjB,WAAK,UAAU,OAAO,QAAQ,OAAO,QAAQ,WAAW;IAC3D;AAEE,WAAO;EACT;EAEC,QAAQ,aAAa,aAAa;AACjC,QAAI,OAAO,gBAAgB,UAAU;AACpC,aAAO,KAAK,eAAe,aAAa,WAAW;IACtD;AAEE,WAAO,KAAK,eAAe,aAAa,WAAW;EACrD;EAEC,kBAAkB,QAAQ,aAAa;AACtC,UAAM,EAAE,SAAQ,IAAK;AACrB,UAAM,eAAe,OAAO;AAC5B,aACK,QAAQ,SAAS,QAAQ,MAAM,GACnC,UAAU,IACV,QAAQ,SAAS,QAAQ,QAAQ,QAAQ,YAAY,GACpD;AACD,YAAM,WAAW,SAAS,MAAM,OAAO,QAAQ,YAAY;AAC3D,UAAI,aAAa,YAAa,MAAK,UAAU,OAAO,QAAQ,cAAc,WAAW;IACxF;AAEE,WAAO;EACT;EAEC,WAAW,aAAa,aAAa;AACpC,QAAI,OAAO,gBAAgB,UAAU;AACpC,aAAO,KAAK,kBAAkB,aAAa,WAAW;IACzD;AAEE,QAAI,CAAC,YAAY,QAAQ;AACxB,YAAM,IAAI;QACT;MACJ;IACA;AAEE,WAAO,KAAK,eAAe,aAAa,WAAW;EACrD;AACA;;;Ab53BO,IAAM,0BAAkC;AAAA,EAC7C,MAAM;AAAA,EACN,MAAMC,QAAO;AACX,IAAAA,OAAM,OAAO,EAAE,QAAQ,eAAe,GAAG,OAAM,SAAQ;AACrD,YAAM,UAAU,MAAM,SAAS,KAAK,MAAM,OAAO;AAEjD,aAAO;AAAA,QACL,UAAU,MAAM,2BAA2B,OAAO;AAAA,QAClD,QAAQ;AAAA,MACV;AAAA,IACF,CAAC;AAAA,EACH;AACF;AAEA,eAAsB,2BAA2B,SAAkC;AACjF,QAAM,cAAc,IAAI,YAAY,OAAO;AAC3C,QAAM,EAAE,SAAS,SAAS,IAAI,MAAM,WAAW,WAAW,OAAO;AAEjE,OAAK,SAAS;AAAA,IACZ,MAAM,MAAM;AACV,UAAI,KAAK,SAAS,cAAc,KAAK,IAAI,SAAS,cAAc;AAC9D;AAAA,MACF;AAEA,YAAM,QAAQ,SAAS,KAAK,aAAW,iBAAiB,SAAS,MAAM,OAAO,CAAC;AAC/E,UAAI,CAAC,SAAS,CAAC,MAAM,MAAM,SAAS,SAAS,GAAG;AAC9C;AAAA,MACF;AAEA,kBAAY;AAAA,QACV,KAAK,MAAM;AAAA,QACX,KAAK,MAAM;AAAA,QACX;AAAA,OACD,QAAQ,UAAU,KAAK,MAAM,OAAO,KAAK,MAAM,GAAG,CAAC;AAAA,mBACvC,WAAW,MAAM,KAAK,CAAC;AAAA;AAAA,MAEpC;AAAA,IACF;AAAA,EACF,CAAC;AAED,SAAO,YAAY,SAAS;AAC9B;AAEA,SAAS,iBAAiB,SAAiB,MAAY,SAAkB;AACvE,MAAI,QAAQ,MAAM,KAAK,OAAO;AAC5B,WAAO;AAAA,EACT;AAEA,QAAM,eAAe,QAAQ,UAAU,QAAQ,KAAK,KAAK,KAAK;AAE9D,SAAO,aAAa,KAAK,EAAE,WAAW;AACxC;AAEA,SAAS,WAAW,KAAa;AAC/B,SACE,IAEG,QAAQ,YAAY,EAAE,EAGtB,QAAQ,WAAW,EAAE,EAGrB,QAAQ,OAAO,MAAM,EACrB,QAAQ,MAAM,KAAK,EACnB,QAAQ,QAAQ,MAAM,EACtB,KAAK;AAEZ;;;AezEA,SAAS,SAAS,UAAU,eAAe;AAC3C,SAAS,YAAAC,WAAU,iBAAiB;AACpC,SAAS,eAAe,qBAAqB;AAC7C,SAAS,iBAAiB,0BAA4C;AACtE,SAAS,cAAc;AACvB,SAAS,WAAW,yBAAyB;AAkBtC,IAAM,uBAAN,MAA2B;AAAA,EAIhC,YACmB,iBACA,aACAC,SACjB;AAHiB;AACA;AACA,kBAAAA;AAAA,EAChB;AAAA,EAPc,mBAAmB,oBAAI,IAA6B;AAAA,EACpD,aAAa,oBAAI,IAA6B;AAAA,EAQ/D,MAAM,uBAAuB,cAAsB,WAAoC;AACrF,UAAM,WAA0D,CAAC;AAEjE,eAAW,YAAY,WAAW;AAChC,YAAM,WAAW,QAAQ,QAAQ;AAEjC,eAAS;AAAA,QACP,KAAK,YAAY,QAAQ,EAAE,KAAK,WAAS;AAAA,UACvC;AAAA,UACA;AAAA,QACF,EAAE;AAAA,MACJ;AAAA,IACF;AAEA,UAAM,WAAkC;AAAA,MACtC,cAAc,CAAC;AAAA,IACjB;AAEA,UAAM,SAAS,MAAM,QAAQ,IAAI,QAAQ;AACzC,eAAW,EAAE,UAAU,KAAK,KAAK,QAAQ;AACvC,eAAS,aAAc,QAAQ,IAAI;AAAA,IACrC;AAEA,UAAM,eAAe,QAAQ,cAAc,yBAAyB;AACpE,UAAM,UAAU,cAAc,KAAK,UAAU,UAAU,MAAM,CAAC,GAAG,MAAM;AAAA,EACzE;AAAA,EAEA,MAAc,YAAY,UAAmC;AAC3D,UAAM,eAAe,KAAK,WAAW,IAAI,QAAQ;AACjD,QAAI,cAAc;AAChB,aAAO;AAAA,IACT;AAEA,UAAM,OAAO,KAAK,kBAAkB,QAAQ;AAC5C,SAAK,WAAW,IAAI,UAAU,IAAI;AAElC,WAAO;AAAA,EACT;AAAA,EAEA,MAAc,kBAAkB,UAAmC;AACjE,UAAM,UAAU,MAAMD,UAAS,UAAU,MAAM;AAC/C,UAAM,WAAW,KAAK,kBAAkB,UAAU,OAAO;AAEzD,UAAM,SAAS,MAAM,QAAQ,IAAI;AAAA,MAC/B,OAAO,OAAO;AAAA,MACd,GAAG,SAAS,IAAI,SAAO,KAAK,kBAAkB,GAAG,CAAC;AAAA,IACpD,CAAC;AAED,WAAO,MAAM,OAAO,OAAO,KAAK,EAAE,CAAC;AAAA,EACrC;AAAA,EAEA,kBAAkB,YAA6C;AAC7D,UAAM,eAAe,KAAK,iBAAiB,IAAI,WAAW,EAAE;AAC5D,QAAI,cAAc;AAChB,aAAO;AAAA,IACT;AAEA,UAAM,OAAO,KAAK,wBAAwB,UAAU;AACpD,SAAK,iBAAiB,IAAI,WAAW,IAAI,IAAI;AAE7C,WAAO;AAAA,EACT;AAAA,EAEA,MAAc,wBAAwB,YAA6C;AACjF,YAAQ,WAAW,MAAM;AAAA,MACvB,KAAK,YAAY;AACf,eAAO,MAAM,KAAK,YAAY,WAAW,QAAQ;AAAA,MACnD;AAAA,MACA,KAAK,OAAO;AACV,YAAI;AACJ,YAAI;AACF,gBAAM,UAAU,cAAc,QAAQ,KAAK,eAAe,CAAC;AAE3D,wBAAc,kBAAkB,WAAW,SAAS,QAAQ,SAAS,CAAC;AAAA,QACxE,SAAS,OAAO;AACd,eAAK,OAAO,MAAM,kCAAkC,WAAW,OAAO;AACtE,gBAAM;AAAA,QACR;AAEA,YAAI,YAAY,WAAW,OAAO,GAAG;AACnC,gBAAM,IAAI,MAAM,IAAI,WAAW,OAAO,mCAAmC;AAAA,QAC3E;AAEA,cAAM,eAAe,cAAc,WAAW;AAE9C,cAAM,CAAC,oBAAoB,cAAc,IAAI,MAAM,KAAK,eAAe,YAAY;AACnF,cAAM,cAAc,eAAe;AAEnC,aAAK,OAAO;AAAA,UACV;AAAA,UACA,WAAW;AAAA,UACX;AAAA,QACF;AAEA,YACE,CAAC,KAAK,YAAY,eAAe,WAAW,KAC5C,CAAC,KAAK,YAAY,mBAAmB,WAAW,GAChD;AACA,eAAK,OAAO,KAAK,2DAA2D,WAAW;AAAA,QACzF;AAEA,YAAI,eAAe,SAAS,QAAQ,kBAAkB,GAAG,YAAY;AACrE,uBAAe,aAAa,WAAW,GAAG,IAAI,eAAe,KAAK,YAAY;AAE9E,cAAM,wBAAwB;AAAA,UAC5B,QAAQ,kBAAkB;AAAA,UAC1B;AAAA,UACA;AAAA,QACF;AAEA,YAAI;AACJ,YAAI;AACF,gBAAM,kBAAkB,MAAMA,UAAS,uBAAuB,MAAM;AACpE,qBAAW,KAAK,MAAM,eAAe;AAAA,QACvC,SAAS,OAAO;AACd,eAAK,OAAO;AAAA,YACV,EAAE,MAAM;AAAA,YACR;AAAA,YACA;AAAA,UACF;AAAA,QACF;AAEA,cAAM,aAAa,UAAU,eAAe,YAAY;AAExD,YAAI,YAAY;AACd,eAAK,OAAO,MAAM,yCAAyC,WAAW;AACtE,iBAAO;AAAA,QACT;AAIA,aAAK,OAAO,MAAM,qDAAqD,WAAW;AAClF,eAAO,eAAe,WAAW;AAAA,MACnC;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAc,eAAe,UAAkD;AAC7E,WAAO,MAAM;AACX,YAAM,cAAc,MAAM,gBAAgB,QAAQ;AAClD,UAAI,YAAY,MAAM;AACpB,cAAM,kBAAkB,MAAM,mBAAmB,QAAQ;AAEzD,eAAO,CAAC,iBAAiB,WAAW;AAAA,MACtC;AAEA,iBAAW,QAAQ,QAAQ,QAAQ,GAAG,IAAI;AAAA,IAC5C;AAAA,EACF;AAAA,EAEQ,kBAAkB,UAAkB,SAAmC;AAO7E,UAAM,kBACJ;AAEF,UAAM,UAAU,QAAQ,SAAS,eAAe;AAChD,UAAM,eAAiC,CAAC;AAExC,eAAW,SAAS,SAAS;AAC3B,YAAM,EAAE,aAAa,YAAY,aAAa,IAAI,MAAM;AAExD,UAAI,cAAc;AAChB,cAAM,WAAW,QAAQ,QAAQ,QAAQ,GAAG,YAAY;AAExD,qBAAa,KAAK;AAAA,UAChB,MAAM;AAAA,UACN,IAAI,YAAY,QAAQ;AAAA,UACxB;AAAA,QACF,CAAC;AAAA,MACH,WAAW,YAAY;AACrB,qBAAa,KAAK;AAAA,UAChB,MAAM;AAAA,UACN,IAAI,OAAO,UAAU;AAAA,UACrB,SAAS;AAAA,QACX,CAAC;AAAA,MACH,WAAW,aAAa;AAAA,MAExB;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AACF;;;AC5NA,SAAS,YAAAE,iBAAgB;AAGlB,SAAS,2BAA2B,iBAAmC;AAC5E,QAAM,SAAS,IAAI,OAAO,IAAI,gBAAgB,KAAK,GAAG,CAAC,IAAI;AAE3D,SAAO,MAAM,kDAAkD,MAAM;AAErE,SAAO;AAAA,IACL,MAAM;AAAA,IACN,MAAMC,QAAO;AACX,MAAAA,OAAM,OAAO,EAAE,OAAO,GAAG,OAAM,SAAQ;AACrC,cAAM,UAAU,MAAMC,UAAS,KAAK,MAAM,OAAO;AAEjD,eAAO;AAAA,UACL,UAAU;AAAA;AAAA,EAA0B,OAAO;AAAA,UAC3C,QAAQ;AAAA,QACV;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AACF;;;AnBdO,IAAM,kBAAN,cAA8B,QAAQ;AAAA,EAC3C,OAAO,QAAQ,CAAC,CAAC,UAAU,CAAC;AAAA,EAE5B,OAAO,QAAQ,QAAQ,MAAM;AAAA,IAC3B,UAAU;AAAA,IACV,aAAa;AAAA,EACf,CAAC;AAAA,EAED,MAAM,UAAyB;AAC7B,UAAM,cAAc,MAAMC,iBAAgB;AAC1C,QAAI,CAAC,YAAY,kBAAkB,gBAAgB,GAAG;AACpD,YAAM,IAAI;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAEA,QAAI,CAAC,YAAY,kBAAkB,qBAAqB,GAAG;AACzD,aAAO,KAAK,mCAAmC;AAE/C,YAAM,iBAAiB,CAAC,uBAAuB,eAAe,CAAC;AAAA,IACjE;AAEA,WAAO,KAAK,gCAAgC;AAE5C,UAAM,mBAAmB;AAEzB,UAAM,gBAAgB,QAAQ;AAE9B,UAAM,OAAO,MAAM,QAAQ;AAE3B,YAAQ,IAAI,aAAa,KAAK,SAAS;AACvC,YAAQ,IAAI,aAAa;AAEzB,UAAM,IAAI,QAAc,CAAAC,aAAW;AACjC,cAAQ,MAAM,CAAC,YAAoB;AACjC,YAAI,QAAQ,WAAW,cAAc,GAAG;AACtC,UAAAA,SAAQ;AAAA,QACV;AAAA,MACF;AAEA,YAAM,OAAO;AACb,WAAK,OAAO;AAAA,IACd,CAAC;AAED,YAAQ,MAAM;AAEd,IAAAC,SAAQ;AAAA,MACN;AAAA,QACE;AAAA,QACA,SAAS,QAAQ,SAAS,cAAc,oBAAoB,CAAC;AAAA,QAC7D;AAAA,QACA,SAAS,eAAe,iBAAY;AAAA,QACpC,SAAS,aAAa,SAAS,cAAc,oBAAoB,IAAI,EAAE,CAAC;AAAA,QACxE;AAAA,MACF,EAAE,KAAK,EAAE;AAAA,IACX;AAEA,YAAQ,GAAG,UAAU,MAAM;AACzB,cAAQ,OAAO,MAAM,IAAI;AACzB,MAAAA,SAAQ,KAAK,qCAAqC;AAElD,iBAAW,MAAM,QAAQ,KAAK,CAAC,GAAG,GAAI;AAAA,IACxC,CAAC;AAAA,EACH;AACF;;;AoBvEA,SAAS,WAAAC,UAAS,cAAc;AAChC,SAAS,mBAAAC,kBAAiB,sBAAAC,2BAA0B;AACpD,SAAS,SAAS,WAAW,YAAY;AACzC,SAAS,aAAa;AAQf,IAAM,eAAN,cAA2BC,SAAQ;AAAA,EACxC,OAAO,QAAQ,CAAC,CAAC,OAAO,CAAC;AAAA,EAEzB,OAAO,QAAQA,SAAQ,MAAM;AAAA,IAC3B,UAAU;AAAA,IACV,aAAa;AAAA,EACf,CAAC;AAAA,EAED,QAAQ,OAAO,QAAQ,WAAW,KAAK;AAAA,EACvC,UAAU,OAAO,QAAQ,aAAa,KAAK;AAAA,EAC3C,SAAS,OAAO,QAAQ,YAAY,IAAI;AAAA,EAExC,MAAM,UAAyB;AAC7B,UAAM,cAAc,MAAMC,iBAAgB;AAC1C,UAAM,UAAU,YAAY;AAC5B,QAAI,MAAM,YAAY;AAEtB,QAAI,CAAC,YAAY,MAAM;AACrB,YAAM,IAAI,MAAM,qCAAqC;AAAA,IACvD;AAEA,QAAI,CAAC,WAAW,CAAC,KAAK;AACpB,aAAO,KAAK,yCAAyC;AACrD;AAAA,IACF;AAEA,QAAI,YAAY,WAAc,OAAO,YAAY,YAAY,MAAM,QAAQ,OAAO,IAAI;AACpF,YAAM,IAAI,MAAM,iDAAiD;AAAA,IACnE;AAEA,QAAI,QAAQ,UAAa,OAAO,QAAQ,UAAU;AAChD,YAAM,EAAE,CAAC,YAAY,IAAI,GAAG,IAAI;AAAA,IAClC;AAEA,UAAM,QAAQ;AAAA,MACZ;AAAA,QACE,GAAG,UAAU,WAAW,CAAC,GAAG,YAAU,EAAE,OAAO,OAAO,MAAM,EAAE;AAAA,QAC9D,GAAG,UAAU,OAAO,CAAC,GAAG,YAAU,EAAE,OAAO,OAAO,KAAK,EAAE;AAAA,MAC3D;AAAA,MACA,UAAU,CAAC,EAAE,OAAO,MAAM,GAAG,QAAQ;AACnC,YAAI;AAEJ,YAAI,OAAO,UAAU,UAAU;AAC7B,qBAAW;AAAA,QACb,WAAW,OAAO,UAAU,YAAY,CAAC,MAAM,QAAQ,KAAK,GAAG;AAC7D,cAAI,CAAC,MAAM,SAAS;AAClB,kBAAM,IAAI,MAAM,WAAW,GAAG,6CAA6C;AAAA,UAC7E;AAEA,cAAI,OAAO,MAAM,YAAY,UAAU;AACrC,kBAAM,IAAI,MAAM,WAAW,GAAG,kDAAkD;AAAA,UAClF;AAEA,qBAAW,MAAM;AAAA,QACnB,OAAO;AACL,gBAAM,IAAI,MAAM,WAAW,GAAG,iDAAiD;AAAA,QACjF;AAEA,YAAI,CAAC,SAAS,WAAW,SAAS,GAAG;AACnC,gBAAM,IAAI;AAAA,YACR,gCAAgC,GAAG,qDAAqD,QAAQ;AAAA,UAClG;AAAA,QACF;AAEA,YAAI,CAAC,SAAS,SAAS,KAAK,GAAG;AAC7B,gBAAM,IAAI;AAAA,YACR,gCAAgC,GAAG,+CAA+C,QAAQ;AAAA,UAC5F;AAAA,QACF;AAEA,cAAM,aAAa,SAAS,MAAM,CAAC,EAAE,MAAM,GAAG,EAAE;AAEhD,eAAO;AAAA,UACL,YAAY,SAAS,UAAU;AAAA,UAC/B;AAAA,UACA;AAAA,UACA;AAAA,QACF;AAAA,MACF,CAAC;AAAA,MACD,QAAQ,CAAC,GAAG,UAAU,MAAM,UAAU;AAAA,IACxC;AAEA,UAAM,iBAA2B,CAAC;AAElC,UAAM,qBAAqB,OAAO,OAAO,KAAK,EAC3C,OAAO,WAAS,MAAM,KAAK,EAC3B,IAAI,WAAS,MAAM,WAAW,MAAM,CAAC,CAAC;AAEzC,QAAI,KAAK,SAAS;AAChB,qBAAe,KAAK,uBAAuB;AAAA,IAC7C;AAEA,QAAI,mBAAmB,SAAS,GAAG;AACjC,qBAAe,KAAK,2BAA2B,kBAAkB,CAAC;AAAA,IACpE;AAEA,UAAM,MAAM;AAAA,MACV,OAAO,UAAU,OAAO,WAAS,MAAM,UAAU;AAAA,MACjD,QAAQ;AAAA,MACR,OAAO,KAAK;AAAA,MACZ,WAAW;AAAA,MACX,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,UAAU,CAAC,gBAAgB;AAAA,MAC3B;AAAA,MACA,QAAQ,KAAK,UAAU,CAAC,QAAQ,SAAS,OAAO,EAAE,SAAS,OAAO,KAAK;AAAA,IACzE,CAAC;AAED,UAAM,kBAAkB,MAAMC,oBAAmB;AACjD,UAAM,sBAAsB,MAAMD,iBAAgB;AAGlD,QAAI,CAAC,KAAK,SAAS;AACjB,YAAM,uBAAuB,IAAI;AAAA,QAC/B;AAAA,QACA;AAAA,QACA;AAAA,MACF;AACA,YAAM,YAAY,OAAO,OAAO,KAAK,EAAE,IAAI,WAAS,MAAM,QAAQ;AAElE,YAAM,qBAAqB,uBAAuB,UAAU,SAAS;AAAA,IACvE;AAAA,EACF;AACF;;;AtBjIA,IAAM,MAAM,IAAI,IAAI;AAAA,EAClB,YAAY;AAAA,EACZ,aAAa;AAAA,EACb,eAAe;AACjB,CAAC;AAED,IAAI,SAAS,YAAY;AACzB,IAAI,SAAS,eAAe;AAC5B,IAAI,SAAS,SAAS,WAAW;AACjC,IAAI,SAAS,SAAS,cAAc;AAEpC,MAAM,IAAI,QAAQ,QAAQ,KAAK,MAAM,CAAC,CAAC;","names":["readPackageJSON","consola","relative","n","segment","replacement","build","readFile","logger","readFile","build","readFile","readPackageJSON","resolve","consola","Command","readPackageJSON","resolvePackageJSON","Command","readPackageJSON","resolvePackageJSON"]}
1
+ {"version":3,"sources":["../src/main.ts","../package.json","../src/commands/designer.ts","../src/shared/logger.ts","../src/shared/services.ts","../src/shared/schema-transformer.ts","../src/shared/source-hash-calculator.ts","../src/shared/schemas.ts","../src/shared/bin-transformer.ts","../src/commands/build.ts","../src/commands/backend/identity.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { Builtins, Cli } from \"clipanion\"\nimport { version } from \"../package.json\"\nimport { DesignerCommand } from \"./commands/designer\"\nimport { BuildCommand } from \"./commands/build\"\nimport { BackendIdentityCommand } from \"./commands/backend/identity\"\n\nconst cli = new Cli({\n binaryName: \"highstate\",\n binaryLabel: \"Highstate\",\n binaryVersion: version,\n})\n\ncli.register(BuildCommand)\ncli.register(DesignerCommand)\ncli.register(BackendIdentityCommand)\ncli.register(Builtins.HelpCommand)\ncli.register(Builtins.VersionCommand)\n\nawait cli.runExit(process.argv.slice(2))\n","{\n \"name\": \"@highstate/cli\",\n \"version\": \"0.9.15\",\n \"description\": \"The CLI for the Highstate project.\",\n \"type\": \"module\",\n \"files\": [\n \"assets\",\n \"dist\",\n \"src\"\n ],\n \"bin\": {\n \"highstate\": \"./dist/main.js\"\n },\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"scripts\": {\n \"build\": \"highstate build\",\n \"test\": \"vitest run\"\n },\n \"dependencies\": {\n \"@aws-crypto/crc32\": \"^5.2.0\",\n \"@highstate/backend\": \"workspace:^0.9.15\",\n \"@highstate/contract\": \"workspace:^\",\n \"@msgpack/msgpack\": \"^3.1.2\",\n \"age-encryption\": \"^0.2.4\",\n \"ajv\": \"^8.17.1\",\n \"clipanion\": \"^4.0.0-rc.4\",\n \"consola\": \"^3.4.0\",\n \"crypto-hash\": \"^3.1.0\",\n \"get-port-please\": \"^3.1.2\",\n \"import-meta-resolve\": \"^4.1.0\",\n \"magic-string\": \"^0.30.17\",\n \"nypm\": \"^0.6.0\",\n \"oxc-parser\": \"^0.63.0\",\n \"oxc-walker\": \"^0.2.4\",\n \"pino\": \"^9.6.0\",\n \"pkg-types\": \"^1.2.1\",\n \"remeda\": \"^2.21.2\",\n \"tsup\": \"^8.4.0\",\n \"zod\": \"^4.0.5\"\n },\n \"peerDependencies\": {\n \"@pulumi/pulumi\": \"^3.163.0\",\n \"classic-level\": \"^2.0.0\"\n },\n \"peerDependenciesMeta\": {\n \"@pulumi/pulumi\": {\n \"optional\": true\n },\n \"classic-level\": {\n \"optional\": true\n }\n },\n \"devDependencies\": {\n \"highstate-cli-bootstrap\": \"npm:@highstate/cli@0.7.6\",\n \"vitest\": \"^2.1.8\"\n }\n}\n","import { Command, UsageError } from \"clipanion\"\nimport { readPackageJSON } from \"pkg-types\"\nimport { addDevDependency } from \"nypm\"\nimport { consola } from \"consola\"\nimport { colorize } from \"consola/utils\"\nimport { getPort } from \"get-port-please\"\nimport { getBackendServices, logger } from \"../shared\"\n\nexport class DesignerCommand extends Command {\n static paths = [[\"designer\"]]\n\n static usage = Command.Usage({\n category: \"Designer\",\n description: \"Starts the Highstate designer in the current project.\",\n })\n\n async execute(): Promise<void> {\n const packageJson = await readPackageJSON()\n if (!packageJson.devDependencies?.[\"@highstate/cli\"]) {\n throw new UsageError(\n \"This project is not a Highstate project.\\n@highstate/cli must be installed as a devDependency.\",\n )\n }\n\n if (!packageJson.devDependencies?.[\"@highstate/designer\"]) {\n logger.info(\"Installing @highstate/designer...\")\n\n await addDevDependency([\"@highstate/designer\", \"classic-level\"])\n }\n\n logger.info(\"starting highstate designer...\")\n\n await getBackendServices()\n\n const oldConsoleLog = console.log\n\n const port = await getPort()\n\n process.env.NITRO_PORT = port.toString()\n process.env.NITRO_HOST = \"0.0.0.0\"\n\n await new Promise<void>(resolve => {\n console.log = (message: string) => {\n if (message.startsWith(\"Listening on\")) {\n resolve()\n }\n }\n\n const path = \"@highstate/designer/.output/server/index.mjs\"\n void import(path)\n })\n\n console.log = oldConsoleLog\n\n consola.log(\n [\n \"\\n \",\n colorize(\"bold\", colorize(\"cyanBright\", \"Highstate Designer\")),\n \"\\n \",\n colorize(\"greenBright\", \"➜ Local: \"),\n colorize(\"underline\", colorize(\"cyanBright\", `http://localhost:${port}`)),\n \"\\n\",\n ].join(\"\"),\n )\n\n process.on(\"SIGINT\", () => {\n process.stdout.write(\"\\r\")\n consola.info(\"shutting down highstate designer...\")\n\n setTimeout(() => process.exit(0), 1000)\n })\n }\n}\n","import { PassThrough } from \"node:stream\"\nimport pino, { levels } from \"pino\"\nimport { consola, LogLevels } from \"consola\"\n\nexport const logger = pino(\n {\n name: \"highstate-cli\",\n level: process.env.LOG_LEVEL ?? \"info\",\n },\n createConsolaStream(),\n)\n\nconsola.level = LogLevels[(process.env.LOG_LEVEL as keyof typeof LogLevels) ?? \"info\"]\n\nfunction createConsolaStream() {\n const stream = new PassThrough()\n\n stream.on(\"data\", data => {\n const { level, msg, error } = JSON.parse(String(data)) as {\n msg: string\n level: number\n error?: unknown\n }\n\n const levelLabel = levels.labels[level]\n\n switch (levelLabel) {\n case \"info\":\n consola.info(msg)\n break\n case \"warn\":\n consola.warn(msg)\n break\n case \"error\":\n if (error) {\n consola.error(msg, error)\n } else {\n consola.error(msg)\n }\n break\n case \"debug\":\n consola.debug(msg)\n break\n case \"fatal\":\n consola.fatal(msg)\n break\n case \"trace\":\n consola.trace(msg)\n break\n }\n })\n\n return stream\n}\n","import type { Services } from \"@highstate/backend\"\nimport { logger } from \"./logger\"\n\nlet services: Promise<Services> | undefined\n\nexport function getBackendServices() {\n if (services) {\n return services\n }\n\n services = import(\"@highstate/backend\").then(({ getSharedServices }) => {\n return getSharedServices({\n services: {\n logger: logger.child({}, { msgPrefix: \"[backend] \" }),\n },\n })\n })\n\n return services\n}\n","import type { Plugin } from \"esbuild\"\nimport { readFile } from \"node:fs/promises\"\nimport { parseAsync, type Comment } from \"oxc-parser\"\nimport { walk, type Node } from \"oxc-walker\"\nimport MagicString from \"magic-string\"\n\nexport const schemaTransformerPlugin: Plugin = {\n name: \"schema-transformer\",\n setup(build) {\n build.onLoad({ filter: /src\\/.*\\.ts$/ }, async args => {\n const content = await readFile(args.path, \"utf-8\")\n\n return {\n contents: await applySchemaTransformations(content),\n loader: \"ts\",\n }\n })\n },\n}\n\nexport async function applySchemaTransformations(content: string): Promise<string> {\n const magicString = new MagicString(content)\n const { program, comments } = await parseAsync(\"file.ts\", content)\n\n const parentStack: Node[] = []\n\n walk(program, {\n enter(node) {\n parentStack.push(node)\n\n if (node.type !== \"Property\" || node.key.type !== \"Identifier\") {\n return\n }\n\n const parentKey = getParentObjectKey(parentStack) || getMarkerFunctionName(parentStack)\n if (!parentKey || ![\"inputs\", \"outputs\", \"args\", \"secrets\"].includes(parentKey)) {\n return\n }\n\n const jsdoc = comments.find(comment => isLeadingComment(content, node, comment))\n if (!jsdoc) {\n return\n }\n\n const description = cleanJsdoc(jsdoc.value)\n const originalValue = content.substring(node.value.start, node.value.end)\n\n const entityField = [\"inputs\", \"outputs\"].includes(parentKey) ? \"entity\" : \"schema\"\n\n // Check if the value already has entity/schema structure\n const isAlreadyStructured = isStructuredValue(originalValue, entityField)\n\n if (isAlreadyStructured) {\n // For already structured values, inject description directly into the object\n const modifiedValue = injectDescriptionIntoObject(originalValue, description)\n magicString.update(node.value.start, node.value.end, modifiedValue)\n } else {\n // Transform to new structure\n magicString.update(\n node.value.start,\n node.value.end,\n `{\n ${entityField}: ${originalValue},\n meta: {\n description: \\`${description}\\`,\n },\n}`,\n )\n }\n },\n leave() {\n parentStack.pop()\n },\n })\n\n return magicString.toString()\n}\n\nfunction injectDescriptionIntoObject(objectString: string, description: string): string {\n const trimmed = objectString.trim()\n\n // Check if the object already has a meta field\n const metaRegex = /meta\\s*:\\s*\\{/\n\n if (metaRegex.test(trimmed)) {\n // Find the meta field and inject description into it\n return trimmed.replace(\n /meta\\s*:\\s*\\{/,\n `meta: {\n description: \\`${description}\\`,`,\n )\n } else {\n // Add meta field at the end of the object (before the closing brace)\n const lastBraceIndex = trimmed.lastIndexOf(\"}\")\n if (lastBraceIndex === -1) {\n // Invalid object structure, return as is\n return trimmed\n }\n\n const beforeBrace = trimmed.substring(0, lastBraceIndex)\n const afterBrace = trimmed.substring(lastBraceIndex)\n\n // Check if we need a comma before adding meta\n const needsComma = beforeBrace.trim().length > 1 && !beforeBrace.trim().endsWith(\",\")\n const comma = needsComma ? \",\" : \"\"\n\n return `${beforeBrace}${comma}\n meta: {\n description: \\`${description}\\`,\n },\n${afterBrace}`\n }\n}\n\nfunction isStructuredValue(value: string, expectedField: string): boolean {\n const trimmed = value.trim()\n if (!trimmed.startsWith(\"{\")) {\n return false\n }\n\n // Check if it contains the expected field (entity or schema) at the top level\n const fieldPattern = new RegExp(`^\\\\s*{[^}]*\\\\b${expectedField}\\\\s*:`, \"s\")\n return fieldPattern.test(trimmed)\n}\n\nfunction getMarkerFunctionName(parentStack: Node[]): string | null {\n // Look for marker functions like $args, $inputs, $outputs, $secrets\n for (let i = parentStack.length - 1; i >= 0; i--) {\n const node = parentStack[i]\n if (node.type === \"CallExpression\" && node.callee.type === \"Identifier\") {\n const functionName = node.callee.name\n if (\n functionName.startsWith(\"$\") &&\n [\"$args\", \"$inputs\", \"$outputs\", \"$secrets\"].includes(functionName)\n ) {\n return functionName.substring(1) // Remove the $ prefix\n }\n }\n }\n return null\n}\n\nfunction getParentObjectKey(parentStack: Node[]): string | null {\n // Walk up the parent stack to find the parent object property\n for (let i = parentStack.length - 2; i >= 0; i--) {\n const node = parentStack[i]\n if (node.type === \"Property\" && node.key.type === \"Identifier\") {\n return node.key.name\n }\n }\n return null\n}\n\nfunction isLeadingComment(content: string, node: Node, comment: Comment) {\n if (comment.end > node.start) {\n return false\n }\n\n const contentRange = content.substring(comment.end, node.start)\n\n return contentRange.trim().length === 0\n}\n\nfunction cleanJsdoc(str: string) {\n return (\n str\n // remove leading asterisks\n .replace(/^\\s*\\*/gm, \"\")\n\n // escape backticks and dollar signs\n .replace(/\\\\/g, \"\\\\\\\\\")\n .replace(/`/g, \"\\\\`\")\n .replace(/\\${/g, \"\\\\${\")\n .trim()\n )\n}\n","import type { Logger } from \"pino\"\nimport { dirname, relative, resolve } from \"node:path\"\nimport { readFile, writeFile } from \"node:fs/promises\"\nimport { fileURLToPath, pathToFileURL } from \"node:url\"\nimport { readPackageJSON, resolvePackageJSON, type PackageJson } from \"pkg-types\"\nimport { crc32 } from \"@aws-crypto/crc32\"\nimport { resolve as importMetaResolve } from \"import-meta-resolve\"\nimport { z } from \"zod\"\nimport { int32ToBytes } from \"@highstate/backend/shared\"\nimport {\n type HighstateManifest,\n type HighstateConfig,\n type SourceHashConfig,\n highstateConfigSchema,\n highstateManifestSchema,\n sourceHashConfigSchema,\n} from \"./schemas\"\n\ntype FileDependency =\n | {\n type: \"relative\"\n id: string\n fullPath: string\n }\n | {\n type: \"npm\"\n id: string\n package: string\n }\n\nexport class SourceHashCalculator {\n private readonly dependencyHashes = new Map<string, Promise<number>>()\n private readonly fileHashes = new Map<string, Promise<number>>()\n\n constructor(\n private readonly packageJsonPath: string,\n private readonly packageJson: PackageJson,\n private readonly logger: Logger,\n ) {}\n\n /**\n * Calculates CRC32 hash of a string.\n */\n private hashString(input: string): number {\n return crc32(Buffer.from(input))\n }\n\n /**\n * Gets the highstate configuration from package.json with defaults.\n */\n private getHighstateConfig(packageJson: PackageJson): HighstateConfig {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const rawConfig = packageJson.highstate\n if (!rawConfig) {\n return { type: \"source\" }\n }\n\n try {\n return highstateConfigSchema.parse(rawConfig)\n } catch (error) {\n this.logger.warn(\n { error, packageName: packageJson.name },\n \"invalid highstate configuration, using defaults\",\n )\n return { type: \"source\" }\n }\n }\n\n /**\n * Gets the effective source hash configuration with defaults for a specific output.\n */\n private getSourceHashConfig(\n highstateConfig: HighstateConfig,\n exportKey?: string,\n ): SourceHashConfig {\n if (highstateConfig.sourceHash) {\n // Try to parse as a single config first\n const singleConfigResult = sourceHashConfigSchema.safeParse(highstateConfig.sourceHash)\n if (singleConfigResult.success) {\n return singleConfigResult.data\n }\n\n // Try to parse as a record of configs\n const recordConfigResult = z\n .record(z.string(), sourceHashConfigSchema)\n .safeParse(highstateConfig.sourceHash)\n if (recordConfigResult.success && exportKey) {\n const perOutputConfig = recordConfigResult.data[exportKey]\n if (perOutputConfig) {\n return perOutputConfig\n }\n }\n }\n\n if (highstateConfig.type === \"library\") {\n return { mode: \"none\" }\n }\n\n return { mode: \"auto\" }\n }\n\n async writeHighstateManifest(\n distBasePath: string,\n distPathToExportKey: Map<string, string>,\n ): Promise<void> {\n const highstateConfig = this.getHighstateConfig(this.packageJson)\n\n const promises: Promise<{ distPath: string; hash: number }>[] = []\n\n for (const [distPath, exportKey] of distPathToExportKey) {\n const fullPath = resolve(distPath)\n const sourceHashConfig = this.getSourceHashConfig(highstateConfig, exportKey)\n\n switch (sourceHashConfig.mode) {\n case \"manual\":\n promises.push(\n Promise.resolve({\n distPath,\n hash: this.hashString(sourceHashConfig.version),\n }),\n )\n break\n case \"version\":\n promises.push(\n Promise.resolve({\n distPath,\n hash: this.hashString(this.packageJson.version ?? \"\"),\n }),\n )\n break\n case \"none\":\n promises.push(\n Promise.resolve({\n distPath,\n hash: 0,\n }),\n )\n break\n case \"auto\":\n default:\n promises.push(\n this.getFileHash(fullPath).then(hash => ({\n distPath,\n hash,\n })),\n )\n break\n }\n }\n\n const manifest: HighstateManifest = {\n sourceHashes: {},\n }\n\n const hashes = await Promise.all(promises)\n for (const { distPath, hash } of hashes) {\n manifest.sourceHashes![distPath] = hash\n }\n\n const manifestPath = resolve(distBasePath, \"highstate.manifest.json\")\n await writeFile(manifestPath, JSON.stringify(manifest, null, 2), \"utf8\")\n }\n\n private async getFileHash(fullPath: string): Promise<number> {\n const existingHash = this.fileHashes.get(fullPath)\n if (existingHash) {\n return existingHash\n }\n\n const hash = this.calculateFileHash(fullPath)\n this.fileHashes.set(fullPath, hash)\n\n return hash\n }\n\n private async calculateFileHash(fullPath: string): Promise<number> {\n const content = await readFile(fullPath, \"utf8\")\n const fileDeps = this.parseDependencies(fullPath, content)\n\n const hashes = await Promise.all([\n this.hashString(content),\n ...fileDeps.map(dep => this.getDependencyHash(dep)),\n ])\n\n return crc32(Buffer.concat(hashes.map(int32ToBytes)))\n }\n\n getDependencyHash(dependency: FileDependency): Promise<number> {\n const existingHash = this.dependencyHashes.get(dependency.id)\n if (existingHash) {\n return existingHash\n }\n\n const hash = this.calculateDependencyHash(dependency)\n this.dependencyHashes.set(dependency.id, hash)\n\n return hash\n }\n\n private async calculateDependencyHash(dependency: FileDependency): Promise<number> {\n switch (dependency.type) {\n case \"relative\": {\n return await this.getFileHash(dependency.fullPath)\n }\n case \"npm\": {\n let resolvedUrl\n try {\n const baseUrl = pathToFileURL(dirname(this.packageJsonPath))\n\n resolvedUrl = importMetaResolve(dependency.package, baseUrl.toString())\n } catch (error) {\n this.logger.error(`failed to resolve package \"%s\"`, dependency.package)\n throw error\n }\n\n if (resolvedUrl.startsWith(\"node:\")) {\n throw new Error(`\"${dependency.package}\" imported without \"node:\" prefix`)\n }\n\n const resolvedPath = fileURLToPath(resolvedUrl)\n\n const [depPackageJsonPath, depPackageJson] = await this.getPackageJson(resolvedPath)\n const packageName = depPackageJson.name!\n\n this.logger.debug(\n `resolved package.json for \"%s\": \"%s\"`,\n dependency.package,\n depPackageJsonPath,\n )\n\n if (\n !this.packageJson.dependencies?.[packageName] &&\n !this.packageJson.peerDependencies?.[packageName]\n ) {\n this.logger.warn(`package \"%s\" is not listed in package.json dependencies`, packageName)\n }\n\n // try to get source hash from manifest first\n let relativePath = relative(dirname(depPackageJsonPath), resolvedPath)\n relativePath = relativePath.startsWith(\".\") ? relativePath : `./${relativePath}`\n\n const highstateManifestPath = resolve(\n dirname(depPackageJsonPath),\n \"dist\",\n \"highstate.manifest.json\",\n )\n\n let manifest: HighstateManifest | undefined\n try {\n const manifestContent = await readFile(highstateManifestPath, \"utf8\")\n manifest = highstateManifestSchema.parse(JSON.parse(manifestContent))\n } catch (error) {\n this.logger.debug(\n { error },\n `failed to read highstate manifest for package \"%s\"`,\n packageName,\n )\n }\n\n const sourceHash = manifest?.sourceHashes?.[relativePath]\n\n if (sourceHash) {\n this.logger.debug(`resolved source hash for package \"%s\"`, packageName)\n return sourceHash\n }\n\n // use the package version as a fallback hash\n // this case will be applied for most npm packages\n this.logger.debug(`using package version as a fallback hash for \"%s\"`, packageName)\n return this.hashString(depPackageJson.version ?? \"0.0.0\")\n }\n }\n }\n\n private async getPackageJson(basePath: string): Promise<[string, PackageJson]> {\n while (true) {\n const packageJson = await readPackageJSON(basePath)\n if (packageJson.name) {\n const packageJsonPath = await resolvePackageJSON(basePath)\n\n return [packageJsonPath, packageJson]\n }\n\n basePath = resolve(dirname(basePath), \"..\")\n }\n }\n\n private parseDependencies(filePath: string, content: string): FileDependency[] {\n type DependencyMatch = {\n relativePath?: string\n nodeBuiltin?: string\n npmPackage?: string\n }\n\n const dependencyRegex =\n /^[ \\t]*import[\\s\\S]*?\\bfrom\\s*[\"']((?<relativePath>\\.\\.?\\/[^\"']+)|(?<nodeBuiltin>node:[^\"']+)|(?<npmPackage>[^\"']+))[\"']/gm\n\n const matches = content.matchAll(dependencyRegex)\n const dependencies: FileDependency[] = []\n\n for (const match of matches) {\n const { nodeBuiltin, npmPackage, relativePath } = match.groups as DependencyMatch\n\n if (relativePath) {\n const fullPath = resolve(dirname(filePath), relativePath)\n\n dependencies.push({\n type: \"relative\",\n id: `relative:${fullPath}`,\n fullPath,\n })\n } else if (npmPackage) {\n dependencies.push({\n type: \"npm\",\n id: `npm:${npmPackage}`,\n package: npmPackage,\n })\n } else if (nodeBuiltin) {\n // ignore node built-in modules\n }\n }\n\n return dependencies\n }\n}\n","import { z } from \"zod\"\n\n/**\n * Schema for the sourceHash configuration in package.json\n */\nexport const sourceHashConfigSchema = z.discriminatedUnion(\"mode\", [\n z.object({\n mode: z.literal(\"manual\"),\n version: z.string(),\n }),\n z.object({\n mode: z.literal(\"auto\"),\n }),\n z.object({\n mode: z.literal(\"version\"),\n }),\n z.object({\n mode: z.literal(\"none\"),\n }),\n])\n\n/**\n * Schema for the highstate configuration in package.json\n */\nexport const highstateConfigSchema = z.object({\n type: z.enum([\"source\", \"library\", \"worker\"]).default(\"source\"),\n sourceHash: z\n .union([sourceHashConfigSchema, z.record(z.string(), sourceHashConfigSchema)])\n .optional(),\n})\n\n/**\n * Schema for the highstate manifest file\n */\nexport const highstateManifestSchema = z.object({\n sourceHashes: z.record(z.string(), z.number()).optional(),\n})\n\nexport type SourceHashConfig = z.infer<typeof sourceHashConfigSchema>\nexport type HighstateConfig = z.infer<typeof highstateConfigSchema>\nexport type HighstateManifest = z.infer<typeof highstateManifestSchema>\n","import type { Plugin } from \"esbuild\"\nimport { readFile } from \"node:fs/promises\"\nimport { logger } from \"./logger\"\n\nexport function createBinTransformerPlugin(sourceFilePaths: string[]): Plugin {\n const filter = new RegExp(`(${sourceFilePaths.join(\"|\")})$`)\n\n logger.debug(\"created bin transformer plugin with filter: %s\", filter)\n\n return {\n name: \"bin-transformer\",\n setup(build) {\n build.onLoad({ filter }, async args => {\n const content = await readFile(args.path, \"utf-8\")\n\n return {\n contents: `#!/usr/bin/env node\\n\\n${content}`,\n loader: \"ts\",\n }\n })\n },\n }\n}\n","import type { Plugin } from \"esbuild\"\nimport { resolve } from \"node:path\"\nimport { writeFile } from \"node:fs/promises\"\nimport { Command, Option } from \"clipanion\"\nimport { readPackageJSON, resolvePackageJSON } from \"pkg-types\"\nimport { mapKeys, mapValues, pipe } from \"remeda\"\nimport { build } from \"tsup\"\nimport { encode } from \"@msgpack/msgpack\"\nimport {\n createBinTransformerPlugin,\n logger,\n schemaTransformerPlugin,\n SourceHashCalculator,\n highstateConfigSchema,\n} from \"../shared\"\n\nexport class BuildCommand extends Command {\n static paths = [[\"build\"]]\n\n static usage = Command.Usage({\n category: \"Builder\",\n description: \"Builds the Highstate library or unit package.\",\n })\n\n watch = Option.Boolean(\"--watch\", false)\n library = Option.Boolean(\"--library\", false)\n silent = Option.Boolean(\"--silent\", true)\n noSourceHash = Option.Boolean(\"--no-source-hash\", false)\n\n async execute(): Promise<void> {\n const packageJson = await readPackageJSON()\n\n const highstateConfig = highstateConfigSchema.parse(packageJson.highstate ?? {})\n if (highstateConfig.type === \"library\") {\n this.library = true\n }\n\n if (highstateConfig.type === \"worker\") {\n this.noSourceHash = true\n }\n\n const exports = packageJson.exports\n let bin = packageJson.bin\n\n if (!packageJson.name) {\n throw new Error(\"package.json must have a name field\")\n }\n\n if (!exports && !bin) {\n logger.warn(\"no exports or bin found in package.json\")\n return\n }\n\n if (exports !== undefined && (typeof exports !== \"object\" || Array.isArray(exports))) {\n throw new Error(\"Exports field in package.json must be an object\")\n }\n\n if (bin !== undefined && typeof bin !== \"object\") {\n bin = { [packageJson.name]: bin }\n }\n\n const entry = pipe(\n {\n ...mapValues(exports ?? {}, value => ({ value, isBin: false })),\n ...mapValues(bin ?? {}, value => ({ value, isBin: true })),\n },\n mapValues(({ value, isBin }, key) => {\n let distPath\n\n if (typeof value === \"string\") {\n distPath = value\n } else if (typeof value === \"object\" && !Array.isArray(value)) {\n if (!value.default) {\n throw new Error(`Export \"${key}\" must have a default field in package.json`)\n }\n\n if (typeof value.default !== \"string\") {\n throw new Error(`Export \"${key}\" default field must be a string in package.json`)\n }\n\n distPath = value.default\n } else {\n throw new Error(`Export \"${key}\" must be a string or an object in package.json`)\n }\n\n if (!distPath.startsWith(\"./dist/\")) {\n throw new Error(\n `The default value of export \"${key}\" must start with \"./dist/\" in package.json, got \"${distPath}\"`,\n )\n }\n\n if (!distPath.endsWith(\".js\")) {\n throw new Error(\n `The default value of export \"${key}\" must end with \".js\" in package.json, got \"${distPath}\"`,\n )\n }\n\n const targetName = distPath.slice(7).slice(0, -3)\n\n return {\n entryPoint: `./src/${targetName}.ts`,\n targetName,\n distPath,\n isBin,\n key,\n }\n }),\n mapKeys((_, value) => value.targetName),\n )\n\n const esbuildPlugins: Plugin[] = []\n\n const binSourceFilePaths = Object.values(entry)\n .filter(value => value.isBin)\n .map(value => value.entryPoint.slice(2)) // remove \"./\"\n\n if (this.library) {\n esbuildPlugins.push(schemaTransformerPlugin)\n }\n\n if (binSourceFilePaths.length > 0) {\n esbuildPlugins.push(createBinTransformerPlugin(binSourceFilePaths))\n }\n\n await build({\n entry: mapValues(entry, value => value.entryPoint),\n outDir: \"dist\",\n watch: this.watch,\n sourcemap: true,\n clean: true,\n format: \"esm\",\n target: \"es2024\",\n platform: \"node\",\n external: [\"@pulumi/pulumi\"],\n esbuildPlugins,\n treeshake: true,\n silent: this.silent || [\"warn\", \"error\", \"fatal\"].includes(logger.level),\n })\n\n const packageJsonPath = await resolvePackageJSON()\n const upToDatePackageJson = await readPackageJSON()\n\n if (!this.noSourceHash) {\n const sourceHashCalculator = new SourceHashCalculator(\n packageJsonPath,\n upToDatePackageJson,\n logger,\n )\n\n const distPathToExportKey = new Map<string, string>()\n for (const value of Object.values(entry)) {\n distPathToExportKey.set(value.distPath, value.key)\n }\n\n await sourceHashCalculator.writeHighstateManifest(\"./dist\", distPathToExportKey)\n }\n\n // write the \"highstate.library.json\" file if the library flag is set\n if (this.library) {\n const { loadLibrary } = await import(\"../shared/library-loader.js\")\n const fullModulePaths = Object.values(entry).map(value => resolve(value.distPath))\n\n logger.info(\"evaluating library components from modules: %s\", fullModulePaths.join(\", \"))\n\n const library = await loadLibrary(logger, fullModulePaths)\n const libraryPath = resolve(\"./dist\", \"highstate.library.msgpack\")\n\n await writeFile(libraryPath, encode(library), \"utf8\")\n }\n\n logger.info(\"build completed successfully\")\n }\n}\n","import { Command } from \"clipanion\"\nimport { identityToRecipient } from \"age-encryption\"\nimport { logger } from \"../../shared\"\n\nexport class BackendIdentityCommand extends Command {\n static paths = [[\"backend\", \"identity\"]]\n\n static usage = Command.Usage({\n category: \"Backend\",\n description: \"Ensures the backend identity is set up and returns the recipient.\",\n })\n\n async execute(): Promise<void> {\n // do not initialize the backend services here, because the state might not be available yet\n const backendLogger = logger.child({}, { msgPrefix: \"[backend] \" })\n const { getOrCreateBackendIdentity } = await import(\"@highstate/backend\")\n\n const backendIdentity = await getOrCreateBackendIdentity(backendLogger)\n const recipient = await identityToRecipient(backendIdentity)\n\n logger.info(`stored backend identity is: ${recipient}`)\n logger.info(`run \"highstate backend unlock-method add ${recipient}\" on other authorized device`)\n }\n}\n"],"mappings":"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","names":["readPackageJSON","consola","build","readFile","z","logger","z","readFile","readFile","build","readFile","readPackageJSON","resolve","consola","resolve","writeFile","Command","readPackageJSON","resolvePackageJSON","Command","readPackageJSON","resolvePackageJSON","resolve","writeFile","Command","Command"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@highstate/cli",
3
- "version": "0.9.14",
3
+ "version": "0.9.16",
4
4
  "description": "The CLI for the Highstate project.",
5
5
  "type": "module",
6
6
  "files": [
@@ -15,25 +15,46 @@
15
15
  "access": "public"
16
16
  },
17
17
  "scripts": {
18
- "build": "highstate build"
18
+ "build": "highstate build",
19
+ "test": "vitest run"
19
20
  },
20
21
  "dependencies": {
21
- "@highstate/backend": "^0.9.14",
22
+ "@aws-crypto/crc32": "^5.2.0",
23
+ "@highstate/backend": "^0.9.16",
24
+ "@highstate/contract": "^0.9.16",
25
+ "@msgpack/msgpack": "^3.1.2",
26
+ "age-encryption": "^0.2.4",
27
+ "ajv": "^8.17.1",
22
28
  "clipanion": "^4.0.0-rc.4",
23
29
  "consola": "^3.4.0",
24
30
  "crypto-hash": "^3.1.0",
25
31
  "get-port-please": "^3.1.2",
26
32
  "import-meta-resolve": "^4.1.0",
33
+ "magic-string": "^0.30.17",
27
34
  "nypm": "^0.6.0",
28
35
  "oxc-parser": "^0.63.0",
29
36
  "oxc-walker": "^0.2.4",
30
37
  "pino": "^9.6.0",
31
38
  "pkg-types": "^1.2.1",
32
39
  "remeda": "^2.21.2",
33
- "tsup": "^8.4.0"
40
+ "tsup": "^8.4.0",
41
+ "zod": "^4.0.5"
42
+ },
43
+ "peerDependencies": {
44
+ "@pulumi/pulumi": "^3.163.0",
45
+ "classic-level": "^2.0.0"
46
+ },
47
+ "peerDependenciesMeta": {
48
+ "@pulumi/pulumi": {
49
+ "optional": true
50
+ },
51
+ "classic-level": {
52
+ "optional": true
53
+ }
34
54
  },
35
55
  "devDependencies": {
36
- "highstate-cli-bootstrap": "npm:@highstate/cli@0.7.6"
56
+ "highstate-cli-bootstrap": "npm:@highstate/cli@0.7.6",
57
+ "vitest": "^2.1.8"
37
58
  },
38
- "gitHead": "8b5d1079961cc5bf9cf8ea3c10f7313384e3a2ff"
59
+ "gitHead": "458d6f1f9f6d4aec0ba75a2b2c4c01408cb9c8df"
39
60
  }
@@ -0,0 +1,24 @@
1
+ import { Command } from "clipanion"
2
+ import { identityToRecipient } from "age-encryption"
3
+ import { logger } from "../../shared"
4
+
5
+ export class BackendIdentityCommand extends Command {
6
+ static paths = [["backend", "identity"]]
7
+
8
+ static usage = Command.Usage({
9
+ category: "Backend",
10
+ description: "Ensures the backend identity is set up and returns the recipient.",
11
+ })
12
+
13
+ async execute(): Promise<void> {
14
+ // do not initialize the backend services here, because the state might not be available yet
15
+ const backendLogger = logger.child({}, { msgPrefix: "[backend] " })
16
+ const { getOrCreateBackendIdentity } = await import("@highstate/backend")
17
+
18
+ const backendIdentity = await getOrCreateBackendIdentity(backendLogger)
19
+ const recipient = await identityToRecipient(backendIdentity)
20
+
21
+ logger.info(`stored backend identity is: ${recipient}`)
22
+ logger.info(`run "highstate backend unlock-method add ${recipient}" on other authorized device`)
23
+ }
24
+ }
@@ -1,13 +1,17 @@
1
1
  import type { Plugin } from "esbuild"
2
+ import { resolve } from "node:path"
3
+ import { writeFile } from "node:fs/promises"
2
4
  import { Command, Option } from "clipanion"
3
5
  import { readPackageJSON, resolvePackageJSON } from "pkg-types"
4
6
  import { mapKeys, mapValues, pipe } from "remeda"
5
7
  import { build } from "tsup"
8
+ import { encode } from "@msgpack/msgpack"
6
9
  import {
7
10
  createBinTransformerPlugin,
8
11
  logger,
9
12
  schemaTransformerPlugin,
10
13
  SourceHashCalculator,
14
+ highstateConfigSchema,
11
15
  } from "../shared"
12
16
 
13
17
  export class BuildCommand extends Command {
@@ -21,9 +25,20 @@ export class BuildCommand extends Command {
21
25
  watch = Option.Boolean("--watch", false)
22
26
  library = Option.Boolean("--library", false)
23
27
  silent = Option.Boolean("--silent", true)
28
+ noSourceHash = Option.Boolean("--no-source-hash", false)
24
29
 
25
30
  async execute(): Promise<void> {
26
31
  const packageJson = await readPackageJSON()
32
+
33
+ const highstateConfig = highstateConfigSchema.parse(packageJson.highstate ?? {})
34
+ if (highstateConfig.type === "library") {
35
+ this.library = true
36
+ }
37
+
38
+ if (highstateConfig.type === "worker") {
39
+ this.noSourceHash = true
40
+ }
41
+
27
42
  const exports = packageJson.exports
28
43
  let bin = packageJson.bin
29
44
 
@@ -87,6 +102,7 @@ export class BuildCommand extends Command {
87
102
  targetName,
88
103
  distPath,
89
104
  isBin,
105
+ key,
90
106
  }
91
107
  }),
92
108
  mapKeys((_, value) => value.targetName),
@@ -113,25 +129,45 @@ export class BuildCommand extends Command {
113
129
  sourcemap: true,
114
130
  clean: true,
115
131
  format: "esm",
116
- target: "esnext",
132
+ target: "es2024",
133
+ platform: "node",
117
134
  external: ["@pulumi/pulumi"],
118
135
  esbuildPlugins,
136
+ treeshake: true,
119
137
  silent: this.silent || ["warn", "error", "fatal"].includes(logger.level),
120
138
  })
121
139
 
122
140
  const packageJsonPath = await resolvePackageJSON()
123
141
  const upToDatePackageJson = await readPackageJSON()
124
142
 
125
- // do not write highstate manifest for library packages since their changes are tracked more granularly
126
- if (!this.library) {
143
+ if (!this.noSourceHash) {
127
144
  const sourceHashCalculator = new SourceHashCalculator(
128
145
  packageJsonPath,
129
146
  upToDatePackageJson,
130
147
  logger,
131
148
  )
132
- const distPaths = Object.values(entry).map(value => value.distPath)
133
149
 
134
- await sourceHashCalculator.writeHighstateManifest("./dist", distPaths)
150
+ const distPathToExportKey = new Map<string, string>()
151
+ for (const value of Object.values(entry)) {
152
+ distPathToExportKey.set(value.distPath, value.key)
153
+ }
154
+
155
+ await sourceHashCalculator.writeHighstateManifest("./dist", distPathToExportKey)
135
156
  }
157
+
158
+ // write the "highstate.library.json" file if the library flag is set
159
+ if (this.library) {
160
+ const { loadLibrary } = await import("../shared/library-loader.js")
161
+ const fullModulePaths = Object.values(entry).map(value => resolve(value.distPath))
162
+
163
+ logger.info("evaluating library components from modules: %s", fullModulePaths.join(", "))
164
+
165
+ const library = await loadLibrary(logger, fullModulePaths)
166
+ const libraryPath = resolve("./dist", "highstate.library.msgpack")
167
+
168
+ await writeFile(libraryPath, encode(library), "utf8")
169
+ }
170
+
171
+ logger.info("build completed successfully")
136
172
  }
137
173
  }
package/src/main.ts CHANGED
@@ -2,6 +2,7 @@ import { Builtins, Cli } from "clipanion"
2
2
  import { version } from "../package.json"
3
3
  import { DesignerCommand } from "./commands/designer"
4
4
  import { BuildCommand } from "./commands/build"
5
+ import { BackendIdentityCommand } from "./commands/backend/identity"
5
6
 
6
7
  const cli = new Cli({
7
8
  binaryName: "highstate",
@@ -11,6 +12,7 @@ const cli = new Cli({
11
12
 
12
13
  cli.register(BuildCommand)
13
14
  cli.register(DesignerCommand)
15
+ cli.register(BackendIdentityCommand)
14
16
  cli.register(Builtins.HelpCommand)
15
17
  cli.register(Builtins.VersionCommand)
16
18
 
@@ -3,3 +3,4 @@ export * from "./logger"
3
3
  export * from "./schema-transformer"
4
4
  export * from "./source-hash-calculator"
5
5
  export * from "./bin-transformer"
6
+ export * from "./schemas"