8 lines
75 KiB
Plaintext
8 lines
75 KiB
Plaintext
{
|
|
"version": 3,
|
|
"sources": ["../src/index.ts", "../src/utils/log.ts", "../src/handle-hot-update.ts", "../src/utils/compile.ts", "../src/utils/hash.ts", "../src/utils/id.ts", "../src/utils/options.ts", "../src/utils/load-svelte-config.ts", "../src/utils/constants.ts", "../src/utils/vite-plugin-svelte-cache.ts", "../src/utils/watch.ts", "../src/utils/resolve.ts", "../src/utils/preprocess.ts", "../src/utils/sourcemap.ts"],
|
|
"sourcesContent": ["import fs from 'fs';\nimport { HmrContext, ModuleNode, Plugin, ResolvedConfig, UserConfig } from 'vite';\nimport { handleHotUpdate } from './handle-hot-update';\nimport { log, logCompilerWarnings } from './utils/log';\nimport { CompileData, createCompileSvelte } from './utils/compile';\nimport { buildIdParser, IdParser, SvelteRequest } from './utils/id';\nimport {\n\tbuildExtraViteConfig,\n\tvalidateInlineOptions,\n\tOptions,\n\tResolvedOptions,\n\tresolveOptions\n} from './utils/options';\nimport { VitePluginSvelteCache } from './utils/vite-plugin-svelte-cache';\n\nimport { setupWatchers } from './utils/watch';\nimport { resolveViaPackageJsonSvelte } from './utils/resolve';\nimport { addExtraPreprocessors } from './utils/preprocess';\nimport { PartialResolvedId } from 'rollup';\n\nexport function svelte(inlineOptions?: Partial<Options>): Plugin {\n\tif (process.env.DEBUG != null) {\n\t\tlog.setLevel('debug');\n\t}\n\tvalidateInlineOptions(inlineOptions);\n\tconst cache = new VitePluginSvelteCache();\n\tconst pkg_export_errors = new Set();\n\t// updated in configResolved hook\n\tlet requestParser: IdParser;\n\tlet options: ResolvedOptions;\n\tlet viteConfig: ResolvedConfig;\n\t/* eslint-disable no-unused-vars */\n\tlet compileSvelte: (\n\t\tsvelteRequest: SvelteRequest,\n\t\tcode: string,\n\t\toptions: Partial<ResolvedOptions>\n\t) => Promise<CompileData>;\n\t/* eslint-enable no-unused-vars */\n\n\tlet resolvedSvelteSSR: Promise<PartialResolvedId | null>;\n\n\treturn {\n\t\tname: 'vite-plugin-svelte',\n\t\t// make sure our resolver runs before vite internal resolver to resolve svelte field correctly\n\t\tenforce: 'pre',\n\t\tasync config(config, configEnv): Promise<Partial<UserConfig>> {\n\t\t\t// setup logger\n\t\t\tif (process.env.DEBUG) {\n\t\t\t\tlog.setLevel('debug');\n\t\t\t} else if (config.logLevel) {\n\t\t\t\tlog.setLevel(config.logLevel);\n\t\t\t}\n\t\t\toptions = await resolveOptions(inlineOptions, config, configEnv);\n\t\t\t// extra vite config\n\t\t\tconst extraViteConfig = buildExtraViteConfig(options, config);\n\t\t\tlog.debug('additional vite config', extraViteConfig);\n\t\t\treturn extraViteConfig as Partial<UserConfig>;\n\t\t},\n\n\t\tasync configResolved(config) {\n\t\t\taddExtraPreprocessors(options, config);\n\t\t\trequestParser = buildIdParser(options);\n\t\t\tcompileSvelte = createCompileSvelte(options);\n\t\t\tviteConfig = config;\n\t\t\tlog.debug('resolved options', options);\n\t\t},\n\n\t\tconfigureServer(server) {\n\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\toptions.server = server;\n\t\t\tsetupWatchers(options, cache, requestParser);\n\t\t},\n\n\t\tload(id, ssr) {\n\t\t\tconst svelteRequest = requestParser(id, !!ssr);\n\t\t\tif (svelteRequest) {\n\t\t\t\tconst { filename, query } = svelteRequest;\n\t\t\t\t// virtual css module\n\t\t\t\tif (query.svelte && query.type === 'style') {\n\t\t\t\t\tconst css = cache.getCSS(svelteRequest);\n\t\t\t\t\tif (css) {\n\t\t\t\t\t\tlog.debug(`load returns css for ${filename}`);\n\t\t\t\t\t\treturn css;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t// prevent vite asset plugin from loading files as url that should be compiled in transform\n\t\t\t\tif (viteConfig.assetsInclude(filename)) {\n\t\t\t\t\tlog.debug(`load returns raw content for ${filename}`);\n\t\t\t\t\treturn fs.readFileSync(filename, 'utf-8');\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\tasync resolveId(importee, importer, customOptions, ssr) {\n\t\t\tconst svelteRequest = requestParser(importee, !!ssr);\n\t\t\tif (svelteRequest?.query.svelte) {\n\t\t\t\tif (svelteRequest.query.type === 'style') {\n\t\t\t\t\t// return cssId with root prefix so postcss pipeline of vite finds the directory correctly\n\t\t\t\t\t// see https://github.com/sveltejs/vite-plugin-svelte/issues/14\n\t\t\t\t\tlog.debug(`resolveId resolved virtual css module ${svelteRequest.cssId}`);\n\t\t\t\t\treturn svelteRequest.cssId;\n\t\t\t\t}\n\t\t\t\tlog.debug(`resolveId resolved ${importee}`);\n\t\t\t\treturn importee; // query with svelte tag, an id we generated, no need for further analysis\n\t\t\t}\n\n\t\t\tif (ssr && importee === 'svelte') {\n\t\t\t\tif (!resolvedSvelteSSR) {\n\t\t\t\t\tresolvedSvelteSSR = this.resolve('svelte/ssr', undefined, { skipSelf: true }).then(\n\t\t\t\t\t\t(svelteSSR) => {\n\t\t\t\t\t\t\tlog.debug('resolved svelte to svelte/ssr');\n\t\t\t\t\t\t\treturn svelteSSR;\n\t\t\t\t\t\t},\n\t\t\t\t\t\t(err) => {\n\t\t\t\t\t\t\tlog.debug(\n\t\t\t\t\t\t\t\t'failed to resolve svelte to svelte/ssr. Update svelte to a version that exports it',\n\t\t\t\t\t\t\t\terr\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\treturn null; // returning null here leads to svelte getting resolved regularly\n\t\t\t\t\t\t}\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\treturn resolvedSvelteSSR;\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\tconst resolved = resolveViaPackageJsonSvelte(importee, importer);\n\t\t\t\tif (resolved) {\n\t\t\t\t\tlog.debug(`resolveId resolved ${resolved} via package.json svelte field of ${importee}`);\n\t\t\t\t\treturn resolved;\n\t\t\t\t}\n\t\t\t} catch (err) {\n\t\t\t\tswitch (err.code) {\n\t\t\t\t\tcase 'ERR_PACKAGE_PATH_NOT_EXPORTED':\n\t\t\t\t\t\tpkg_export_errors.add(importee);\n\t\t\t\t\t\treturn null;\n\t\t\t\t\tcase 'MODULE_NOT_FOUND':\n\t\t\t\t\t\treturn null;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\tasync transform(code, id, ssr) {\n\t\t\tconst svelteRequest = requestParser(id, !!ssr);\n\t\t\tif (!svelteRequest) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst { filename, query } = svelteRequest;\n\n\t\t\tif (query.svelte) {\n\t\t\t\tif (query.type === 'style') {\n\t\t\t\t\tconst css = cache.getCSS(svelteRequest);\n\t\t\t\t\tif (css) {\n\t\t\t\t\t\tlog.debug(`transform returns css for ${filename}`);\n\t\t\t\t\t\treturn css; // TODO return code arg instead? it's the code from load hook.\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tlog.error('failed to transform tagged svelte request', svelteRequest);\n\t\t\t\tthrow new Error(`failed to transform tagged svelte request for id ${id}`);\n\t\t\t}\n\t\t\tconst compileData = await compileSvelte(svelteRequest, code, options);\n\t\t\tlogCompilerWarnings(compileData.compiled.warnings, options);\n\t\t\tcache.update(compileData);\n\t\t\tif (compileData.dependencies?.length && options.server) {\n\t\t\t\tcompileData.dependencies.forEach((d) => this.addWatchFile(d));\n\t\t\t}\n\t\t\tlog.debug(`transform returns compiled js for ${filename}`);\n\t\t\treturn compileData.compiled.js;\n\t\t},\n\n\t\thandleHotUpdate(ctx: HmrContext): void | Promise<Array<ModuleNode> | void> {\n\t\t\tif (!options.hot || !options.emitCss) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst svelteRequest = requestParser(ctx.file, false, ctx.timestamp);\n\t\t\tif (svelteRequest) {\n\t\t\t\treturn handleHotUpdate(compileSvelte, ctx, svelteRequest, cache, options);\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * All resolutions done; display warnings wrt `package.json` access.\n\t\t */\n\t\t// TODO generateBundle isn't called by vite, is buildEnd enough or should it be logged once per violation in resolve\n\t\tbuildEnd() {\n\t\t\tif (pkg_export_errors.size > 0) {\n\t\t\t\tlog.warn(\n\t\t\t\t\t`The following packages did not export their \\`package.json\\` file so we could not check the \"svelte\" field. If you had difficulties importing svelte components from a package, then please contact the author and ask them to export the package.json file.`,\n\t\t\t\t\tArray.from(pkg_export_errors, (s) => `- ${s}`).join('\\n')\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t};\n}\n\nexport {\n\tOptions,\n\tPreprocessor,\n\tPreprocessorGroup,\n\tCompileOptions,\n\tCssHashGetter,\n\tArrayable,\n\tMarkupPreprocessor,\n\tModuleFormat,\n\tProcessed,\n\tWarning\n} from './utils/options';\n", "/* eslint-disable no-unused-vars */\nimport { cyan, yellow, red } from 'kleur/colors';\nimport debug from 'debug';\nimport { ResolvedOptions, Warning } from './options';\n\nconst levels: string[] = ['debug', 'info', 'warn', 'error', 'silent'];\nconst prefix = 'vite-plugin-svelte';\nconst loggers: { [key: string]: any } = {\n\tdebug: {\n\t\tlog: debug(`vite:${prefix}`),\n\t\tenabled: false,\n\t\tisDebug: true\n\t},\n\tinfo: {\n\t\tcolor: cyan,\n\t\tlog: console.log,\n\t\tenabled: true\n\t},\n\twarn: {\n\t\tcolor: yellow,\n\t\tlog: console.warn,\n\t\tenabled: true\n\t},\n\terror: {\n\t\tcolor: red,\n\t\tlog: console.error,\n\t\tenabled: true\n\t},\n\tsilent: {\n\t\tenabled: false\n\t}\n};\n\nlet _level: string = 'info';\nfunction setLevel(level: string) {\n\tif (level === _level) {\n\t\treturn;\n\t}\n\tconst levelIndex = levels.indexOf(level);\n\tif (levelIndex > -1) {\n\t\t_level = level;\n\t\tfor (let i = 0; i < levels.length; i++) {\n\t\t\tloggers[levels[i]].enabled = i >= levelIndex;\n\t\t}\n\t} else {\n\t\t_log(loggers.error, `invalid log level: ${level} `);\n\t}\n}\n\nfunction _log(logger: any, message: string, payload?: any) {\n\tif (!logger.enabled) {\n\t\treturn;\n\t}\n\tif (logger.isDebug) {\n\t\tpayload !== undefined ? logger.log(message, payload) : logger.log(message);\n\t} else {\n\t\tlogger.log(logger.color(`${new Date().toLocaleTimeString()} [${prefix}] ${message}`));\n\t\tif (payload) {\n\t\t\tlogger.log(payload);\n\t\t}\n\t}\n}\n\nexport interface LogFn {\n\t(message: string, payload?: any): void;\n\tenabled: boolean;\n\tonce: (message: string, payload?: any) => void;\n}\n\nfunction createLogger(level: string): LogFn {\n\tconst logger = loggers[level];\n\tconst logFn: LogFn = _log.bind(null, logger) as LogFn;\n\tconst logged = new Set<String>();\n\tconst once = function (message: string, payload?: any) {\n\t\tif (logged.has(message)) {\n\t\t\treturn;\n\t\t}\n\t\tlogged.add(message);\n\t\tlogFn.apply(null, [message, payload]);\n\t};\n\tObject.defineProperty(logFn, 'enabled', {\n\t\tget() {\n\t\t\treturn logger.enabled;\n\t\t}\n\t});\n\tObject.defineProperty(logFn, 'once', {\n\t\tget() {\n\t\t\treturn once;\n\t\t}\n\t});\n\treturn logFn;\n}\n\nexport const log = {\n\tdebug: createLogger('debug'),\n\tinfo: createLogger('info'),\n\twarn: createLogger('warn'),\n\terror: createLogger('error'),\n\tsetLevel\n};\n\nexport function logCompilerWarnings(warnings: Warning[], options: ResolvedOptions) {\n\tconst { emitCss, onwarn, isBuild } = options;\n\tconst warn = isBuild ? warnBuild : warnDev;\n\twarnings?.forEach((warning) => {\n\t\tif (!emitCss && warning.code === 'css-unused-selector') {\n\t\t\treturn;\n\t\t}\n\t\tif (onwarn) {\n\t\t\tonwarn(warning, warn);\n\t\t} else {\n\t\t\twarn(warning);\n\t\t}\n\t});\n}\n\nfunction warnDev(w: Warning) {\n\tlog.info.enabled && log.info(buildExtendedLogMessage(w));\n}\n\nfunction warnBuild(w: Warning) {\n\tlog.warn.enabled && log.warn(buildExtendedLogMessage(w), w.frame);\n}\n\nfunction buildExtendedLogMessage(w: Warning) {\n\tconst parts = [];\n\tif (w.filename) {\n\t\tparts.push(w.filename);\n\t}\n\tif (w.start) {\n\t\tparts.push(':', w.start.line, ':', w.start.column);\n\t}\n\tif (w.message) {\n\t\tparts.push(' ', w.message);\n\t}\n\treturn parts.join('');\n}\n", "import { ModuleNode, HmrContext } from 'vite';\nimport { Code, CompileData } from './utils/compile';\nimport { log, logCompilerWarnings } from './utils/log';\nimport { SvelteRequest } from './utils/id';\nimport { VitePluginSvelteCache } from './utils/vite-plugin-svelte-cache';\nimport { ResolvedOptions } from './utils/options';\n\n/**\n * Vite-specific HMR handling\n */\nexport async function handleHotUpdate(\n\tcompileSvelte: Function,\n\tctx: HmrContext,\n\tsvelteRequest: SvelteRequest,\n\tcache: VitePluginSvelteCache,\n\toptions: ResolvedOptions\n): Promise<ModuleNode[] | void> {\n\tconst { read, server } = ctx;\n\n\tconst cachedJS = cache.getJS(svelteRequest);\n\tif (!cachedJS) {\n\t\t// file hasn't been requested yet (e.g. async component)\n\t\tlog.debug(`handleHotUpdate first call ${svelteRequest.id}`);\n\t\treturn;\n\t}\n\tconst cachedCss = cache.getCSS(svelteRequest);\n\n\tconst content = await read();\n\tconst compileData: CompileData = await compileSvelte(svelteRequest, content, options);\n\tcache.update(compileData);\n\n\tconst affectedModules = new Set<ModuleNode | undefined>();\n\n\tconst cssModule = server.moduleGraph.getModuleById(svelteRequest.cssId);\n\tconst mainModule = server.moduleGraph.getModuleById(svelteRequest.id);\n\tconst cssUpdated = cssModule && cssChanged(cachedCss, compileData.compiled.css);\n\tif (cssUpdated) {\n\t\tlog.debug('handleHotUpdate css changed');\n\t\taffectedModules.add(cssModule);\n\t}\n\tconst jsUpdated =\n\t\tmainModule && jsChanged(cachedJS, compileData.compiled.js, svelteRequest.filename);\n\tif (jsUpdated) {\n\t\tlog.debug('handleHotUpdate js changed');\n\t\taffectedModules.add(mainModule);\n\t}\n\n\tif (!jsUpdated) {\n\t\t// transform won't be called, log warnings here\n\t\tlogCompilerWarnings(compileData.compiled.warnings, options);\n\t}\n\n\tconst result = [...affectedModules].filter(Boolean) as ModuleNode[];\n\n\t// TODO is this enough? see also: https://github.com/vitejs/vite/issues/2274\n\tconst ssrModulesToInvalidate = result.filter((m) => !!m.ssrTransformResult);\n\tif (ssrModulesToInvalidate.length > 0) {\n\t\tlog.debug(`invalidating modules ${ssrModulesToInvalidate.map((m) => m.id).join(', ')}`);\n\t\tssrModulesToInvalidate.forEach((moduleNode) => server.moduleGraph.invalidateModule(moduleNode));\n\t}\n\tif (result.length > 0) {\n\t\tlog.debug(\n\t\t\t`handleHotUpdate for ${svelteRequest.id} result: ${result.map((m) => m.id).join(', ')}`\n\t\t);\n\t}\n\treturn result;\n}\n\nfunction cssChanged(prev?: Code, next?: Code): boolean {\n\treturn !isCodeEqual(prev?.code, next?.code);\n}\n\nfunction jsChanged(prev?: Code, next?: Code, filename?: string): boolean {\n\tconst prevJs = prev?.code;\n\tconst nextJs = next?.code;\n\tconst isStrictEqual = isCodeEqual(prevJs, nextJs);\n\tif (isStrictEqual) {\n\t\treturn false;\n\t}\n\tconst isLooseEqual = isCodeEqual(normalizeJsCode(prevJs), normalizeJsCode(nextJs));\n\tif (!isStrictEqual && isLooseEqual) {\n\t\tlog.warn(\n\t\t\t`ignoring compiler output js change for ${filename} as it is equal to previous output after normalization`\n\t\t);\n\t}\n\treturn !isLooseEqual;\n}\n\nfunction isCodeEqual(prev?: string, next?: string): boolean {\n\tif (!prev && !next) {\n\t\treturn true;\n\t}\n\tif ((!prev && next) || (prev && !next)) {\n\t\treturn false;\n\t}\n\treturn prev === next;\n}\n\n/**\n * remove code that only changes metadata and does not require a js update for the component to keep working\n *\n * 1) add_location() calls. These add location metadata to elements, only useful for tooling like sapper studio\n * 2) ... maybe more (or less) in the future\n * @param code\n */\nfunction normalizeJsCode(code?: string): string | undefined {\n\tif (!code) {\n\t\treturn code;\n\t}\n\treturn code.replace(/\\s*\\badd_location\\s*\\([^)]*\\)\\s*;?/g, '');\n}\n", "import { CompileOptions, ResolvedOptions } from './options';\nimport { compile, preprocess, walk } from 'svelte/compiler';\n// @ts-ignore\nimport { createMakeHot } from 'svelte-hmr';\nimport { SvelteRequest } from './id';\nimport { safeBase64Hash } from './hash';\nimport { log } from './log';\n\nconst _createCompileSvelte = (makeHot: Function) =>\n\tasync function compileSvelte(\n\t\tsvelteRequest: SvelteRequest,\n\t\tcode: string,\n\t\toptions: Partial<ResolvedOptions>\n\t): Promise<CompileData> {\n\t\tconst { filename, normalizedFilename, cssId, ssr } = svelteRequest;\n\t\tconst { emitCss = true } = options;\n\t\tconst dependencies = [];\n\n\t\tconst compileOptions: CompileOptions = {\n\t\t\t...options.compilerOptions,\n\t\t\tfilename,\n\t\t\tgenerate: ssr ? 'ssr' : 'dom'\n\t\t};\n\t\tif (options.hot && options.emitCss) {\n\t\t\tconst hash = `s-${safeBase64Hash(normalizedFilename)}`;\n\t\t\tlog.debug(`setting cssHash ${hash} for ${normalizedFilename}`);\n\t\t\tcompileOptions.cssHash = () => hash;\n\t\t}\n\n\t\tlet preprocessed;\n\n\t\tif (options.preprocess) {\n\t\t\tpreprocessed = await preprocess(code, options.preprocess, { filename });\n\t\t\tif (preprocessed.dependencies) dependencies.push(...preprocessed.dependencies);\n\t\t\tif (preprocessed.map) compileOptions.sourcemap = preprocessed.map;\n\t\t}\n\t\tconst finalCode = preprocessed ? preprocessed.code : code;\n\t\tconst dynamicCompileOptions = await options.experimental?.dynamicCompileOptions?.({\n\t\t\tfilename,\n\t\t\tcode: finalCode,\n\t\t\tcompileOptions\n\t\t});\n\t\tif (dynamicCompileOptions && log.debug.enabled) {\n\t\t\tlog.debug(\n\t\t\t\t`dynamic compile options for ${filename}: ${JSON.stringify(dynamicCompileOptions)}`\n\t\t\t);\n\t\t}\n\t\tconst finalCompileOptions = dynamicCompileOptions\n\t\t\t? {\n\t\t\t\t\t...compileOptions,\n\t\t\t\t\t...dynamicCompileOptions\n\t\t\t }\n\t\t\t: compileOptions;\n\t\tconst compiled = compile(finalCode, finalCompileOptions);\n\n\t\tif (emitCss && compiled.css.code) {\n\t\t\t// TODO properly update sourcemap?\n\t\t\tcompiled.js.code += `\\nimport ${JSON.stringify(cssId)};\\n`;\n\t\t}\n\n\t\t// only apply hmr when not in ssr context and hot options are set\n\t\tif (!ssr && makeHot) {\n\t\t\tcompiled.js.code = makeHot({\n\t\t\t\tid: filename,\n\t\t\t\tcompiledCode: compiled.js.code,\n\t\t\t\thotOptions: options.hot,\n\t\t\t\tcompiled,\n\t\t\t\toriginalCode: code,\n\t\t\t\tcompileOptions: finalCompileOptions\n\t\t\t});\n\t\t}\n\n\t\tcompiled.js.dependencies = dependencies;\n\n\t\treturn {\n\t\t\tfilename,\n\t\t\tnormalizedFilename,\n\t\t\t// @ts-ignore\n\t\t\tcompiled,\n\t\t\tssr,\n\t\t\tdependencies\n\t\t};\n\t};\n\nfunction buildMakeHot(options: ResolvedOptions) {\n\tconst needsMakeHot = options.hot !== false && options.isServe && !options.isProduction;\n\tif (needsMakeHot) {\n\t\t// @ts-ignore\n\t\tconst hotApi = options?.hot?.hotApi;\n\t\t// @ts-ignore\n\t\tconst adapter = options?.hot?.adapter;\n\t\treturn createMakeHot({\n\t\t\twalk,\n\t\t\thotApi,\n\t\t\tadapter,\n\t\t\thotOptions: { noOverlay: true, ...(options.hot as object) }\n\t\t});\n\t}\n}\n\nexport function createCompileSvelte(options: ResolvedOptions) {\n\tconst makeHot = buildMakeHot(options);\n\treturn _createCompileSvelte(makeHot);\n}\n\nexport interface Code {\n\tcode: string;\n\tmap?: any;\n\tdependencies?: any[];\n}\n\nexport interface Compiled {\n\tjs: Code;\n\tcss: Code;\n\tast: any; // TODO type\n\twarnings: any[]; // TODO type\n\tvars: {\n\t\tname: string;\n\t\texport_name: string;\n\t\tinjected: boolean;\n\t\tmodule: boolean;\n\t\tmutated: boolean;\n\t\treassigned: boolean;\n\t\treferenced: boolean;\n\t\twritable: boolean;\n\t\treferenced_from_script: boolean;\n\t}[];\n\tstats: {\n\t\ttimings: {\n\t\t\ttotal: number;\n\t\t};\n\t};\n}\n\nexport interface CompileData {\n\tfilename: string;\n\tnormalizedFilename: string;\n\tcompiled: Compiled;\n\tssr: boolean | undefined;\n\tdependencies: string[];\n}\n", "import * as crypto from 'crypto';\n\nconst hashes = Object.create(null);\n\n//TODO shorter?\nconst hash_length = 12;\n\nexport function safeBase64Hash(input: string) {\n\tif (hashes[input]) {\n\t\treturn hashes[input];\n\t}\n\t//TODO if performance really matters, use a faster one like xx-hash etc.\n\t// should be evenly distributed because short input length and similarities in paths could cause collisions otherwise\n\t// OR DON'T USE A HASH AT ALL, what about a simple counter?\n\tconst md5 = crypto.createHash('md5');\n\tmd5.update(input);\n\tconst hash = toSafe(md5.digest('base64')).substr(0, hash_length);\n\thashes[input] = hash;\n\treturn hash;\n}\n\nconst replacements: { [key: string]: string } = {\n\t'+': '-',\n\t'/': '_',\n\t'=': ''\n};\n\nconst replaceRE = new RegExp(`[${Object.keys(replacements).join('')}]`, 'g');\n\nfunction toSafe(base64: string) {\n\treturn base64.replace(replaceRE, (x) => replacements[x]);\n}\n", "/* eslint-disable no-unused-vars */\nimport { createFilter } from '@rollup/pluginutils';\nimport { Arrayable, ResolvedOptions } from './options';\nimport { normalizePath } from 'vite';\nimport * as fs from 'fs';\n\nconst VITE_FS_PREFIX = '/@fs/';\nconst IS_WINDOWS = process.platform === 'win32';\n\nexport type SvelteQueryTypes = 'style' | 'script';\n\nexport interface RequestQuery {\n\t// our own\n\tsvelte?: boolean;\n\ttype?: SvelteQueryTypes;\n\t// vite specific\n\turl?: boolean;\n\traw?: boolean;\n}\n\nexport interface SvelteRequest {\n\tid: string;\n\tcssId: string;\n\tfilename: string;\n\tnormalizedFilename: string;\n\tquery: RequestQuery;\n\ttimestamp: number;\n\tssr: boolean;\n}\n\nfunction splitId(id: string) {\n\tconst parts = id.split(`?`, 2);\n\tconst filename = parts[0];\n\tconst rawQuery = parts[1];\n\treturn { filename, rawQuery };\n}\n\nfunction parseToSvelteRequest(\n\tid: string,\n\tfilename: string,\n\trawQuery: string,\n\troot: string,\n\ttimestamp: number,\n\tssr: boolean\n): SvelteRequest | undefined {\n\tconst query = parseRequestQuery(rawQuery);\n\tif (query.url || query.raw) {\n\t\t// skip requests with special vite tags\n\t\treturn;\n\t}\n\tconst normalizedFilename = normalize(filename, root);\n\tconst cssId = createVirtualImportId(filename, root, 'style');\n\n\treturn {\n\t\tid,\n\t\tfilename,\n\t\tnormalizedFilename,\n\t\tcssId,\n\t\tquery,\n\t\ttimestamp,\n\t\tssr\n\t};\n}\n\nfunction createVirtualImportId(filename: string, root: string, type: SvelteQueryTypes) {\n\tconst parts = ['svelte', `type=${type}`];\n\tif (type === 'style') {\n\t\tparts.push('lang.css');\n\t}\n\tif (existsInRoot(filename, root)) {\n\t\tfilename = root + filename;\n\t} else if (filename.startsWith(VITE_FS_PREFIX)) {\n\t\tfilename = IS_WINDOWS\n\t\t\t? filename.slice(VITE_FS_PREFIX.length) // remove /@fs/ from /@fs/C:/...\n\t\t\t: filename.slice(VITE_FS_PREFIX.length - 1); // remove /@fs from /@fs/home/user\n\t}\n\t// return same virtual id format as vite-plugin-vue eg ...App.svelte?svelte&type=style&lang.css\n\treturn `${filename}?${parts.join('&')}`;\n}\n\nfunction parseRequestQuery(rawQuery: string): RequestQuery {\n\tconst query = Object.fromEntries(new URLSearchParams(rawQuery));\n\tfor (const key in query) {\n\t\tif (query[key] === '') {\n\t\t\t// @ts-ignore\n\t\t\tquery[key] = true;\n\t\t}\n\t}\n\treturn query as RequestQuery;\n}\n\n/**\n * posixify and remove root at start\n *\n * @param filename\n * @param normalizedRoot\n */\nfunction normalize(filename: string, normalizedRoot: string) {\n\treturn stripRoot(normalizePath(filename), normalizedRoot);\n}\n\nfunction existsInRoot(filename: string, root: string) {\n\tif (filename.startsWith(VITE_FS_PREFIX)) {\n\t\treturn false; // vite already tagged it as out of root\n\t}\n\treturn fs.existsSync(root + filename);\n}\n\nfunction stripRoot(normalizedFilename: string, normalizedRoot: string) {\n\treturn normalizedFilename.startsWith(normalizedRoot + '/')\n\t\t? normalizedFilename.slice(normalizedRoot.length)\n\t\t: normalizedFilename;\n}\n\nfunction buildFilter(\n\tinclude: Arrayable<string> | undefined,\n\texclude: Arrayable<string> | undefined,\n\textensions: string[]\n): (filename: string) => boolean {\n\tconst rollupFilter = createFilter(include, exclude);\n\treturn (filename) => rollupFilter(filename) && extensions.some((ext) => filename.endsWith(ext));\n}\n\nexport type IdParser = (id: string, ssr: boolean, timestamp?: number) => SvelteRequest | undefined;\nexport function buildIdParser(options: ResolvedOptions): IdParser {\n\tconst { include, exclude, extensions, root } = options;\n\tconst normalizedRoot = normalizePath(root);\n\tconst filter = buildFilter(include, exclude, extensions!);\n\treturn (id, ssr, timestamp = Date.now()) => {\n\t\tconst { filename, rawQuery } = splitId(id);\n\t\tif (filter(filename)) {\n\t\t\treturn parseToSvelteRequest(id, filename, rawQuery, normalizedRoot, timestamp, ssr);\n\t\t}\n\t};\n}\n", "/* eslint-disable no-unused-vars */\nimport { ConfigEnv, UserConfig, ViteDevServer, normalizePath } from 'vite';\nimport { log } from './log';\nimport { loadSvelteConfig } from './load-svelte-config';\nimport { SVELTE_HMR_IMPORTS, SVELTE_IMPORTS, SVELTE_RESOLVE_MAIN_FIELDS } from './constants';\n// eslint-disable-next-line node/no-missing-import\nimport { CompileOptions, Warning } from 'svelte/types/compiler/interfaces';\nimport {\n\tMarkupPreprocessor,\n\tPreprocessor,\n\tPreprocessorGroup,\n\tProcessed\n\t// eslint-disable-next-line node/no-missing-import\n} from 'svelte/types/compiler/preprocess';\nimport path from 'path';\n\nconst knownOptions = new Set([\n\t'configFile',\n\t'include',\n\t'exclude',\n\t'extensions',\n\t'emitCss',\n\t'compilerOptions',\n\t'onwarn',\n\t'preprocess',\n\t'hot',\n\t'ignorePluginPreprocessors',\n\t'experimental'\n]);\n\nfunction buildDefaultOptions(isProduction: boolean, options: Partial<Options>): Partial<Options> {\n\t// emit for prod, emit in dev unless css hmr is disabled\n\tconst emitCss = options?.emitCss != null ? options.emitCss : true;\n\t// no hmr in prod, only inject css in dev if emitCss is false\n\tconst hot = isProduction\n\t\t? false\n\t\t: {\n\t\t\t\tinjectCss: !emitCss\n\t\t };\n\tconst defaultOptions: Partial<Options> = {\n\t\textensions: ['.svelte'],\n\t\thot,\n\t\temitCss,\n\t\tcompilerOptions: {\n\t\t\tformat: 'esm',\n\t\t\tcss: !emitCss,\n\t\t\tdev: !isProduction\n\t\t}\n\t};\n\tlog.debug(`default options for ${isProduction ? 'production' : 'development'}`, defaultOptions);\n\treturn defaultOptions;\n}\n\nexport function validateInlineOptions(inlineOptions?: Partial<Options>) {\n\tconst invalidKeys = Object.keys(inlineOptions || {}).filter((key) => !knownOptions.has(key));\n\tif (invalidKeys.length) {\n\t\tlog.warn(`invalid plugin options \"${invalidKeys.join(', ')}\" in config`, inlineOptions);\n\t}\n}\n\nfunction enforceOptionsForHmr(options: ResolvedOptions) {\n\tif (options.hot) {\n\t\tif (!options.compilerOptions.dev) {\n\t\t\tlog.warn('hmr is enabled but compilerOptions.dev is false, forcing it to true');\n\t\t\toptions.compilerOptions.dev = true;\n\t\t}\n\t\tif (options.emitCss) {\n\t\t\tif (options.hot !== true && options.hot.injectCss) {\n\t\t\t\tlog.warn('hmr and emitCss are enabled but hot.injectCss is true, forcing it to false');\n\t\t\t\toptions.hot.injectCss = false;\n\t\t\t}\n\t\t\tif (options.compilerOptions.css) {\n\t\t\t\tlog.warn(\n\t\t\t\t\t'hmr and emitCss are enabled but compilerOptions.css is true, forcing it to false'\n\t\t\t\t);\n\t\t\t\toptions.compilerOptions.css = false;\n\t\t\t}\n\t\t} else {\n\t\t\tif (options.hot === true || !options.hot.injectCss) {\n\t\t\t\tlog.warn(\n\t\t\t\t\t'hmr with emitCss disabled requires option hot.injectCss to be enabled, forcing it to true'\n\t\t\t\t);\n\t\t\t\tif (options.hot === true) {\n\t\t\t\t\toptions.hot = { injectCss: true };\n\t\t\t\t} else {\n\t\t\t\t\toptions.hot.injectCss = true;\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!options.compilerOptions.css) {\n\t\t\t\tlog.warn(\n\t\t\t\t\t'hmr with emitCss disabled requires compilerOptions.css to be enabled, forcing it to true'\n\t\t\t\t);\n\t\t\t\toptions.compilerOptions.css = true;\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction enforceOptionsForProduction(options: ResolvedOptions) {\n\tif (options.isProduction) {\n\t\tif (options.hot) {\n\t\t\tlog.warn('options.hot is enabled but does not work on production build, forcing it to false');\n\t\t\toptions.hot = false;\n\t\t}\n\t\tif (options.compilerOptions.dev) {\n\t\t\tlog.warn(\n\t\t\t\t'you are building for production but compilerOptions.dev is true, forcing it to false'\n\t\t\t);\n\t\t\toptions.compilerOptions.dev = false;\n\t\t}\n\t}\n}\n\nfunction mergeOptions(\n\tdefaultOptions: Partial<Options>,\n\tsvelteConfig: Partial<Options>,\n\tinlineOptions: Partial<Options>,\n\tviteConfig: UserConfig,\n\tviteEnv: ConfigEnv\n): ResolvedOptions {\n\tconst merged = {\n\t\t...defaultOptions,\n\t\t...svelteConfig,\n\t\t...inlineOptions,\n\t\tcompilerOptions: {\n\t\t\t...defaultOptions.compilerOptions,\n\t\t\t...(svelteConfig?.compilerOptions || {}),\n\t\t\t...(inlineOptions?.compilerOptions || {})\n\t\t},\n\t\texperimental: {\n\t\t\t...(svelteConfig?.experimental || {}),\n\t\t\t...(inlineOptions?.experimental || {})\n\t\t},\n\t\troot: viteConfig.root!,\n\t\tisProduction: viteEnv.mode === 'production',\n\t\tisBuild: viteEnv.command === 'build',\n\t\tisServe: viteEnv.command === 'serve'\n\t};\n\t// configFile of svelteConfig contains the absolute path it was loaded from,\n\t// prefer it over the possibly relative inline path\n\tif (svelteConfig?.configFile) {\n\t\tmerged.configFile = svelteConfig.configFile;\n\t}\n\treturn merged;\n}\n\nexport async function resolveOptions(\n\tinlineOptions: Partial<Options> = {},\n\tviteConfig: UserConfig,\n\tviteEnv: ConfigEnv\n): Promise<ResolvedOptions> {\n\tconst viteConfigWithResolvedRoot = {\n\t\t...viteConfig,\n\t\troot: resolveViteRoot(viteConfig)\n\t};\n\tconst defaultOptions = buildDefaultOptions(viteEnv.mode === 'production', inlineOptions);\n\tconst svelteConfig = (await loadSvelteConfig(viteConfigWithResolvedRoot, inlineOptions)) || {};\n\tconst resolvedOptions = mergeOptions(\n\t\tdefaultOptions,\n\t\tsvelteConfig,\n\t\tinlineOptions,\n\t\tviteConfigWithResolvedRoot,\n\t\tviteEnv\n\t);\n\n\tenforceOptionsForProduction(resolvedOptions);\n\tenforceOptionsForHmr(resolvedOptions);\n\treturn resolvedOptions;\n}\n\n// vite passes unresolved `root`option to config hook but we need the resolved value, so do it here\n// https://github.com/sveltejs/vite-plugin-svelte/issues/113\n// https://github.com/vitejs/vite/blob/43c957de8a99bb326afd732c962f42127b0a4d1e/packages/vite/src/node/config.ts#L293\nfunction resolveViteRoot(viteConfig: UserConfig): string | undefined {\n\treturn normalizePath(viteConfig.root ? path.resolve(viteConfig.root) : process.cwd());\n}\n\nexport function buildExtraViteConfig(\n\toptions: ResolvedOptions,\n\tconfig: UserConfig\n): Partial<UserConfig> {\n\tconst allSvelteImports = [...SVELTE_IMPORTS, ...SVELTE_HMR_IMPORTS];\n\n\t// exclude svelte imports from optimization unless explicitly included\n\tconst excludeFromOptimize = allSvelteImports.filter(\n\t\t(x) => !config.optimizeDeps?.include?.includes(x)\n\t);\n\n\tconst extraViteConfig: Partial<UserConfig> = {\n\t\toptimizeDeps: {\n\t\t\texclude: excludeFromOptimize\n\t\t},\n\t\tresolve: {\n\t\t\tmainFields: [...SVELTE_RESOLVE_MAIN_FIELDS],\n\t\t\tdedupe: allSvelteImports\n\t\t}\n\t\t// this option is still awaiting a PR in vite to be supported\n\t\t// see https://github.com/sveltejs/vite-plugin-svelte/issues/60\n\t\t// @ts-ignore\n\t\t// knownJsSrcExtensions: options.extensions\n\t};\n\n\tif (options.isBuild && config.build?.ssr) {\n\t\t// add svelte to ssr.noExternal unless it is present in ssr.external\n\t\t// so we can resolve it with svelte/ssr\n\t\t// @ts-ignore\n\t\tif (!config.ssr?.external?.includes('svelte')) {\n\t\t\t// @ts-ignore\n\t\t\textraViteConfig.ssr = {\n\t\t\t\tnoExternal: ['svelte']\n\t\t\t};\n\t\t}\n\t}\n\n\tif (options.experimental?.useVitePreprocess) {\n\t\t// needed to transform svelte files with component imports\n\t\t// can cause issues with other typescript files, see https://github.com/sveltejs/vite-plugin-svelte/pull/20\n\t\textraViteConfig.esbuild = {\n\t\t\ttsconfigRaw: {\n\t\t\t\tcompilerOptions: {\n\t\t\t\t\timportsNotUsedAsValues: 'preserve'\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n\treturn extraViteConfig;\n}\n\nexport interface Options {\n\t// eslint-disable no-unused-vars\n\t/** path to svelte config file, either absolute or relative to vite root*/\n\tconfigFile?: string;\n\n\t/** One or more minimatch patterns */\n\tinclude?: Arrayable<string>;\n\n\t/** One or more minimatch patterns */\n\texclude?: Arrayable<string>;\n\n\t/**\n\t * By default, all \".svelte\" files are compiled\n\t * @default ['.svelte']\n\t */\n\textensions?: string[];\n\n\t/**\n\t * Optionally, preprocess components with svelte.preprocess:\n\t * \\@see https://svelte.dev/docs#svelte_preprocess\n\t */\n\tpreprocess?: Arrayable<PreprocessorGroup>;\n\n\t/** Emit Svelte styles as virtual CSS files for other plugins to process.\n\t * @default true\n\t */\n\temitCss?: boolean;\n\n\t/** Options passed to `svelte.compile` method. */\n\tcompilerOptions: Partial<CompileOptions>;\n\n\t/**\n\t * custom warning handler for svelte compiler warnings\n\t */\n\tonwarn?: (warning: Warning, defaultHandler?: (warning: Warning) => void) => void;\n\n\t/**\n\t * enable/disable hmr. You want this enabled.\n\t *\n\t * !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n\t * DO NOT CUSTOMIZE SVELTE-HMR OPTIONS UNLESS YOU KNOW EXACTLY WHAT YOU ARE DOING\n\t *\n\t * YOU HAVE BEEN WARNED\n\t * !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n\t *\n\t * set to object to pass custom options to svelte-hmr, see https://github.com/rixo/svelte-hmr#options\n\t *\n\t * @default true for development, always false for production\n\t */\n\thot?: boolean | { injectCss?: boolean; [key: string]: any };\n\n\t/**\n\t * vite plugins can contribute additional preprocessors by defining api.sveltePreprocess.\n\t * If you don't want to use them, set this to true to ignore them all or use an array of strings with plugin names to specify which\n\t *\n\t * @default false\n\t */\n\tignorePluginPreprocessors?: boolean | string[];\n\n\t/**\n\t * These options are considered experimental and breaking changes to them can occur in any release\n\t */\n\texperimental?: ExperimentalOptions;\n}\n\n/**\n * These options are considered experimental and breaking changes to them can occur in any release\n */\nexport interface ExperimentalOptions {\n\t/**\n\t * use extra preprocessors that delegate style and typescript preproessing to native vite plugins\n\t *\n\t * do not use together with svelte-preprocess!\n\t *\n\t * @default false\n\t */\n\tuseVitePreprocess?: boolean;\n\n\t/**\n\t * wrap all preprocessors in with a function that adds a sourcemap to the output if missing\n\t *\n\t * to use this option you have to install \"diff-match-patch\"\n\t */\n\tgenerateMissingPreprocessorSourcemaps?: boolean;\n\n\t/**\n\t * function to update compilerOptions before compilation\n\t *\n\t * data.filename is the file to be compiled,\n\t * data.code is the already preprocessed code\n\t * data.compileOptions are the compilerOptions that are going to be used\n\t *\n\t * to change one, you should return an object with the changes you need, eg:\n\t *\n\t * ```\n\t * ({filename,compileOptions}) => { if( compileWithHydratable(filename) && !compileOptions.hydratable ){ return {hydratable: true}}}\n\t * ```\n\t * @default undefined\n\t */\n\tdynamicCompileOptions?: (data: {\n\t\tfilename: string;\n\t\tcode: string;\n\t\tcompileOptions: Partial<CompileOptions>;\n\t}) => Promise<Partial<CompileOptions> | void> | Partial<CompileOptions> | void;\n}\n\nexport interface ResolvedOptions extends Options {\n\troot: string;\n\tisProduction: boolean;\n\tisBuild?: boolean;\n\tisServe?: boolean;\n\tserver?: ViteDevServer;\n}\n\nexport type {\n\tCompileOptions,\n\tProcessed,\n\tMarkupPreprocessor,\n\tPreprocessor,\n\tPreprocessorGroup,\n\tWarning\n};\n\nexport type ModuleFormat = NonNullable<CompileOptions['format']>;\n\nexport type CssHashGetter = NonNullable<CompileOptions['cssHash']>;\n\nexport type Arrayable<T> = T | T[];\n", "import path from 'path';\nimport fs from 'fs';\nimport { pathToFileURL } from 'url';\nimport { log } from './log';\nimport { Options } from './options';\nimport { UserConfig } from 'vite';\n\nexport const knownSvelteConfigNames = [\n\t'svelte.config.js',\n\t'svelte.config.cjs',\n\t'svelte.config.mjs'\n];\n\n// hide dynamic import from ts transform to prevent it turning into a require\n// see https://github.com/microsoft/TypeScript/issues/43329#issuecomment-811606238\n// also use timestamp query to avoid caching on reload\nconst dynamicImportDefault = new Function(\n\t'path',\n\t'return import(path + \"?t=\" + Date.now()).then(m => m.default)'\n);\n\nexport async function loadSvelteConfig(\n\tviteConfig: UserConfig,\n\tinlineOptions: Partial<Options>\n): Promise<Partial<Options> | undefined> {\n\tconst configFile = findConfigToLoad(viteConfig, inlineOptions);\n\tif (configFile) {\n\t\tlet err;\n\t\t// try to use dynamic import for svelte.config.js first\n\t\tif (configFile.endsWith('.js') || configFile.endsWith('.mjs')) {\n\t\t\ttry {\n\t\t\t\tconst result = await dynamicImportDefault(pathToFileURL(configFile).href);\n\t\t\t\tif (result != null) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\t...result,\n\t\t\t\t\t\tconfigFile\n\t\t\t\t\t};\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error(`invalid export in ${configFile}`);\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tlog.error(`failed to import config ${configFile}`, e);\n\t\t\t\terr = e;\n\t\t\t}\n\t\t}\n\t\t// cjs or error with dynamic import\n\t\tif (!configFile.endsWith('.mjs')) {\n\t\t\ttry {\n\t\t\t\t// avoid loading cached version on reload\n\t\t\t\tdelete require.cache[require.resolve(configFile)];\n\t\t\t\tconst result = require(configFile);\n\t\t\t\tif (result != null) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\t...result,\n\t\t\t\t\t\tconfigFile\n\t\t\t\t\t};\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error(`invalid export in ${configFile}`);\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tlog.error(`failed to require config ${configFile}`, e);\n\t\t\t\tif (!err) {\n\t\t\t\t\terr = e;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t// failed to load existing config file\n\t\tthrow err;\n\t}\n}\n\nfunction findConfigToLoad(viteConfig: UserConfig, inlineOptions: Partial<Options>) {\n\tconst root = viteConfig.root || process.cwd();\n\tif (inlineOptions.configFile) {\n\t\tconst abolutePath = path.isAbsolute(inlineOptions.configFile)\n\t\t\t? inlineOptions.configFile\n\t\t\t: path.resolve(root, inlineOptions.configFile);\n\t\tif (!fs.existsSync(abolutePath)) {\n\t\t\tthrow new Error(`failed to find svelte config file ${abolutePath}.`);\n\t\t}\n\t\treturn abolutePath;\n\t} else {\n\t\tconst existingKnownConfigFiles = knownSvelteConfigNames\n\t\t\t.map((candidate) => path.resolve(root, candidate))\n\t\t\t.filter((file) => fs.existsSync(file));\n\t\tif (existingKnownConfigFiles.length === 0) {\n\t\t\tlog.debug(`no svelte config found at ${root}`);\n\t\t\treturn;\n\t\t} else if (existingKnownConfigFiles.length > 1) {\n\t\t\tlog.warn(\n\t\t\t\t`found more than one svelte config file, using ${existingKnownConfigFiles[0]}. you should only have one!`,\n\t\t\t\texistingKnownConfigFiles\n\t\t\t);\n\t\t}\n\t\treturn existingKnownConfigFiles[0];\n\t}\n}\n", "const VITE_RESOLVE_MAIN_FIELDS = ['module', 'jsnext:main', 'jsnext'];\n\nexport const SVELTE_RESOLVE_MAIN_FIELDS = ['svelte', ...VITE_RESOLVE_MAIN_FIELDS];\n\nexport const SVELTE_IMPORTS = [\n\t'svelte/animate',\n\t'svelte/easing',\n\t'svelte/internal',\n\t'svelte/motion',\n\t'svelte/store',\n\t'svelte/transition',\n\t'svelte'\n];\n\nexport const SVELTE_HMR_IMPORTS = [\n\t'svelte-hmr/runtime/hot-api-esm.js',\n\t'svelte-hmr/runtime/proxy-adapter-dom.js',\n\t'svelte-hmr'\n];\n", "import { SvelteRequest } from './id';\nimport { Code, CompileData } from './compile';\n\nexport class VitePluginSvelteCache {\n\tprivate _css = new Map<string, Code>();\n\tprivate _js = new Map<string, Code>();\n\tprivate _dependencies = new Map<string, string[]>();\n\tprivate _dependants = new Map<string, Set<string>>();\n\n\tpublic update(compileData: CompileData) {\n\t\tthis.updateCSS(compileData);\n\t\tthis.updateJS(compileData);\n\t\tthis.updateDependencies(compileData);\n\t}\n\n\tprivate updateCSS(compileData: CompileData) {\n\t\tthis._css.set(compileData.normalizedFilename, compileData.compiled.css);\n\t}\n\n\tprivate updateJS(compileData: CompileData) {\n\t\tif (!compileData.ssr) {\n\t\t\t// do not cache SSR js\n\t\t\tthis._js.set(compileData.normalizedFilename, compileData.compiled.js);\n\t\t}\n\t}\n\n\tprivate updateDependencies(compileData: CompileData) {\n\t\tconst id = compileData.normalizedFilename;\n\t\tconst prevDependencies = this._dependencies.get(id) || [];\n\t\tconst dependencies = compileData.dependencies;\n\t\tthis._dependencies.set(id, dependencies);\n\t\tconst removed = prevDependencies.filter((d) => !dependencies.includes(d));\n\t\tconst added = dependencies.filter((d) => !prevDependencies.includes(d));\n\t\tadded.forEach((d) => {\n\t\t\tif (!this._dependants.has(d)) {\n\t\t\t\tthis._dependants.set(d, new Set<string>());\n\t\t\t}\n\t\t\tthis._dependants.get(d)!.add(compileData.filename);\n\t\t});\n\t\tremoved.forEach((d) => {\n\t\t\tthis._dependants.get(d)!.delete(compileData.filename);\n\t\t});\n\t}\n\n\tpublic remove(svelteRequest: SvelteRequest): boolean {\n\t\tconst id = svelteRequest.normalizedFilename;\n\t\tlet removed = false;\n\t\tif (this._js.delete(id)) {\n\t\t\tremoved = true;\n\t\t}\n\t\tif (this._css.delete(id)) {\n\t\t\tremoved = true;\n\t\t}\n\t\tconst dependencies = this._dependencies.get(id);\n\t\tif (dependencies) {\n\t\t\tremoved = true;\n\t\t\tdependencies.forEach((d) => {\n\t\t\t\tconst dependants = this._dependants.get(d);\n\t\t\t\tif (dependants && dependants.has(svelteRequest.filename)) {\n\t\t\t\t\tdependants.delete(svelteRequest.filename);\n\t\t\t\t}\n\t\t\t});\n\t\t\tthis._dependencies.delete(id);\n\t\t}\n\t\treturn removed;\n\t}\n\n\tpublic getCSS(svelteRequest: SvelteRequest) {\n\t\treturn this._css.get(svelteRequest.normalizedFilename);\n\t}\n\n\tpublic getJS(svelteRequest: SvelteRequest) {\n\t\tif (!svelteRequest.ssr) {\n\t\t\t// SSR js isn't cached\n\t\t\treturn this._js.get(svelteRequest.normalizedFilename);\n\t\t}\n\t}\n\n\tpublic getDependants(path: string): string[] {\n\t\tconst dependants = this._dependants.get(path);\n\t\treturn dependants ? [...dependants] : [];\n\t}\n}\n", "import { VitePluginSvelteCache } from './vite-plugin-svelte-cache';\nimport fs from 'fs';\nimport { log } from './log';\nimport { IdParser } from './id';\nimport { ResolvedOptions } from './options';\nimport { knownSvelteConfigNames } from './load-svelte-config';\nimport path from 'path';\n\nexport function setupWatchers(\n\toptions: ResolvedOptions,\n\tcache: VitePluginSvelteCache,\n\trequestParser: IdParser\n) {\n\tconst { server, configFile: svelteConfigFile } = options;\n\tif (!server) {\n\t\treturn;\n\t}\n\tconst { watcher, ws } = server;\n\tconst { configFile: viteConfigFile, root, server: serverConfig } = server.config;\n\n\tconst emitChangeEventOnDependants = (filename: string) => {\n\t\tconst dependants = cache.getDependants(filename);\n\t\tdependants.forEach((dependant) => {\n\t\t\tif (fs.existsSync(dependant)) {\n\t\t\t\tlog.debug(\n\t\t\t\t\t`emitting virtual change event for \"${dependant}\" because depdendency \"${filename}\" changed`\n\t\t\t\t);\n\t\t\t\twatcher.emit('change', dependant);\n\t\t\t}\n\t\t});\n\t};\n\n\tconst removeUnlinkedFromCache = (filename: string) => {\n\t\tconst svelteRequest = requestParser(filename, false);\n\t\tif (svelteRequest) {\n\t\t\tconst removedFromCache = cache.remove(svelteRequest);\n\t\t\tif (removedFromCache) {\n\t\t\t\tlog.debug(`cleared VitePluginSvelteCache for deleted file ${filename}`);\n\t\t\t}\n\t\t}\n\t};\n\n\tconst triggerViteRestart = (filename: string) => {\n\t\t// vite restart is triggered by simulating a change to vite config. This requires that vite config exists\n\t\t// also we do not restart in middleware-mode as it could be risky\n\t\tif (!!viteConfigFile && !serverConfig.middlewareMode) {\n\t\t\tlog.info(`svelte config changed: restarting vite server. - file: ${filename}`);\n\t\t\twatcher.emit('change', viteConfigFile);\n\t\t} else {\n\t\t\tconst message =\n\t\t\t\t'Svelte config change detected, restart your dev process to apply the changes.';\n\t\t\tlog.info(message, filename);\n\t\t\tws.send({\n\t\t\t\ttype: 'error',\n\t\t\t\terr: { message, stack: '', plugin: 'vite-plugin-svelte', id: filename }\n\t\t\t});\n\t\t}\n\t};\n\n\tconst possibleSvelteConfigs = knownSvelteConfigNames.map((cfg) => path.join(root, cfg));\n\tconst restartOnConfigAdd = (filename: string) => {\n\t\tif (possibleSvelteConfigs.includes(filename)) {\n\t\t\ttriggerViteRestart(filename);\n\t\t}\n\t};\n\n\tconst restartOnConfigChange = (filename: string) => {\n\t\tif (filename === svelteConfigFile) {\n\t\t\ttriggerViteRestart(filename);\n\t\t}\n\t};\n\n\t// collection of watcher listeners by event\n\tconst listeners = {\n\t\tadd: [],\n\t\tchange: [emitChangeEventOnDependants],\n\t\tunlink: [removeUnlinkedFromCache, emitChangeEventOnDependants]\n\t};\n\tif (svelteConfigFile) {\n\t\tlisteners.change.push(restartOnConfigChange);\n\t\tlisteners.unlink.push(restartOnConfigChange);\n\t} else {\n\t\t// @ts-ignore\n\t\tlisteners.add.push(restartOnConfigAdd);\n\t}\n\n\tObject.entries(listeners).forEach(([evt, listeners]) => {\n\t\tif (listeners.length > 0) {\n\t\t\twatcher.on(evt, (filename) => listeners.forEach((listener) => listener(filename)));\n\t\t}\n\t});\n}\n", "import path from 'path';\nimport fs from 'fs';\n// @ts-ignore\nimport relative from 'require-relative';\n\nexport function resolveViaPackageJsonSvelte(importee: string, importer?: string): string | void {\n\tif (importer && isBareImport(importee)) {\n\t\tconst importeePkgFile = relative.resolve(`${importee}/package.json`, path.dirname(importer));\n\t\tconst importeePkg = JSON.parse(fs.readFileSync(importeePkgFile, { encoding: 'utf-8' }));\n\t\tif (importeePkg.svelte) {\n\t\t\treturn path.resolve(path.dirname(importeePkgFile), importeePkg.svelte);\n\t\t}\n\t}\n}\n\nfunction isBareImport(importee: string): boolean {\n\tif (!importee || importee[0] === '.' || importee[0] === '\\0' || path.isAbsolute(importee)) {\n\t\treturn false;\n\t}\n\tconst parts = importee.split('/');\n\tswitch (parts.length) {\n\t\tcase 1:\n\t\t\treturn true;\n\t\tcase 2:\n\t\t\treturn parts[0].startsWith('@');\n\t\tdefault:\n\t\t\treturn false;\n\t}\n}\n", "import { ResolvedConfig, TransformResult, Plugin } from 'vite';\nimport MagicString from 'magic-string';\nimport { Preprocessor, PreprocessorGroup, Processed, ResolvedOptions } from './options';\nimport { TransformPluginContext } from 'rollup';\nimport { log } from './log';\nimport { buildSourceMap } from './sourcemap';\n\nconst supportedStyleLangs = ['css', 'less', 'sass', 'scss', 'styl', 'stylus', 'postcss'];\n\nconst supportedScriptLangs = ['ts'];\n\nfunction createPreprocessorFromVitePlugin(\n\tconfig: ResolvedConfig,\n\toptions: ResolvedOptions,\n\tpluginName: string,\n\tsupportedLangs: string[]\n): Preprocessor {\n\tconst plugin = config.plugins.find((p) => p.name === pluginName);\n\tif (!plugin) {\n\t\tthrow new Error(`failed to find plugin ${pluginName}`);\n\t}\n\tif (!plugin.transform) {\n\t\tthrow new Error(`plugin ${pluginName} has no transform`);\n\t}\n\tconst pluginTransform = plugin.transform!.bind(null as unknown as TransformPluginContext);\n\t// @ts-ignore\n\treturn async ({ attributes, content, filename }) => {\n\t\tconst lang = attributes.lang as string;\n\t\tif (!supportedLangs.includes(lang)) {\n\t\t\treturn { code: content };\n\t\t}\n\t\tconst moduleId = `${filename}.${lang}`;\n\t\tconst moduleGraph = options.server?.moduleGraph;\n\t\tif (moduleGraph && !moduleGraph.getModuleById(moduleId)) {\n\t\t\tawait moduleGraph.ensureEntryFromUrl(moduleId);\n\t\t}\n\t\tconst transformResult: TransformResult = (await pluginTransform(\n\t\t\tcontent,\n\t\t\tmoduleId\n\t\t)) as TransformResult;\n\t\t// TODO vite:css transform currently returns an empty mapping that would kill svelte compiler.\n\t\tconst hasMap = transformResult.map && transformResult.map?.mappings !== '';\n\t\tif (transformResult.map?.sources?.[0] === moduleId) {\n\t\t\ttransformResult.map.sources[0] = filename as string;\n\t\t}\n\t\treturn {\n\t\t\tcode: transformResult.code,\n\t\t\tmap: hasMap ? (transformResult.map as object) : undefined,\n\t\t\tdependencies: transformResult.deps\n\t\t};\n\t};\n}\n\nexport function createVitePreprocessorGroup(\n\tconfig: ResolvedConfig,\n\toptions: ResolvedOptions\n): PreprocessorGroup {\n\treturn {\n\t\tscript: createPreprocessorFromVitePlugin(config, options, 'vite:esbuild', supportedScriptLangs),\n\t\tstyle: createPreprocessorFromVitePlugin(config, options, 'vite:css', supportedStyleLangs)\n\t} as PreprocessorGroup;\n}\n\n/**\n * this appends a *{} rule to component styles to force the svelte compiler to add style classes to all nodes\n * That means adding/removing class rules from <style> node won't trigger js updates as the scope classes are not changed\n *\n * only used during dev with enabled css hmr\n */\nfunction createInjectScopeEverythingRulePreprocessorGroup(): PreprocessorGroup {\n\treturn {\n\t\tstyle({ content, filename }) {\n\t\t\tconst s = new MagicString(content);\n\t\t\ts.append(' *{}');\n\t\t\treturn {\n\t\t\t\tcode: s.toString(),\n\t\t\t\tmap: s.generateDecodedMap({ source: filename, hires: true })\n\t\t\t};\n\t\t}\n\t};\n}\n\nfunction buildExtraPreprocessors(options: ResolvedOptions, config: ResolvedConfig) {\n\tconst extraPreprocessors = [];\n\tif (options.experimental?.useVitePreprocess) {\n\t\tlog.debug('adding vite preprocessor');\n\t\textraPreprocessors.push(createVitePreprocessorGroup(config, options));\n\t}\n\n\t// @ts-ignore\n\tconst pluginsWithPreprocessorsDeprecated = config.plugins.filter((p) => p?.sveltePreprocess);\n\tif (pluginsWithPreprocessorsDeprecated.length > 0) {\n\t\tlog.warn(\n\t\t\t`The following plugins use the deprecated 'plugin.sveltePreprocess' field. Please contact their maintainers and ask them to move it to 'plugin.api.sveltePreprocess': ${pluginsWithPreprocessorsDeprecated\n\t\t\t\t.map((p) => p.name)\n\t\t\t\t.join(', ')}`\n\t\t);\n\t\t// patch plugin to avoid breaking\n\t\tpluginsWithPreprocessorsDeprecated.forEach((p) => {\n\t\t\tif (!p.api) {\n\t\t\t\tp.api = {};\n\t\t\t}\n\t\t\tif (p.api.sveltePreprocess === undefined) {\n\t\t\t\t// @ts-ignore\n\t\t\t\tp.api.sveltePreprocess = p.sveltePreprocess;\n\t\t\t} else {\n\t\t\t\tlog.error(\n\t\t\t\t\t`ignoring plugin.sveltePreprocess of ${p.name} because it already defined plugin.api.sveltePreprocess.`\n\t\t\t\t);\n\t\t\t}\n\t\t});\n\t}\n\n\tconst pluginsWithPreprocessors: Plugin[] = config.plugins.filter((p) => p?.api?.sveltePreprocess);\n\tconst ignored: Plugin[] = [],\n\t\tincluded: Plugin[] = [];\n\tfor (const p of pluginsWithPreprocessors) {\n\t\tif (\n\t\t\toptions.ignorePluginPreprocessors === true ||\n\t\t\t(Array.isArray(options.ignorePluginPreprocessors) &&\n\t\t\t\toptions.ignorePluginPreprocessors?.includes(p.name))\n\t\t) {\n\t\t\tignored.push(p);\n\t\t} else {\n\t\t\tincluded.push(p);\n\t\t}\n\t}\n\tif (ignored.length > 0) {\n\t\tlog.debug(\n\t\t\t`Ignoring svelte preprocessors defined by these vite plugins: ${ignored\n\t\t\t\t.map((p) => p.name)\n\t\t\t\t.join(', ')}`\n\t\t);\n\t}\n\tif (included.length > 0) {\n\t\tlog.debug(\n\t\t\t`Adding svelte preprocessors defined by these vite plugins: ${included\n\t\t\t\t.map((p) => p.name)\n\t\t\t\t.join(', ')}`\n\t\t);\n\t\textraPreprocessors.push(...pluginsWithPreprocessors.map((p) => p.api.sveltePreprocess));\n\t}\n\n\tif (options.hot && options.emitCss) {\n\t\textraPreprocessors.push(createInjectScopeEverythingRulePreprocessorGroup());\n\t}\n\n\treturn extraPreprocessors;\n}\n\nexport function addExtraPreprocessors(options: ResolvedOptions, config: ResolvedConfig) {\n\tconst extra = buildExtraPreprocessors(options, config);\n\tif (extra?.length > 0) {\n\t\tif (!options.preprocess) {\n\t\t\toptions.preprocess = extra;\n\t\t} else if (Array.isArray(options.preprocess)) {\n\t\t\toptions.preprocess.push(...extra);\n\t\t} else {\n\t\t\toptions.preprocess = [options.preprocess, ...extra];\n\t\t}\n\t}\n\tconst generateMissingSourceMaps = !!options.experimental?.generateMissingPreprocessorSourcemaps;\n\tif (options.preprocess && generateMissingSourceMaps) {\n\t\toptions.preprocess = Array.isArray(options.preprocess)\n\t\t\t? options.preprocess.map((p, i) => validateSourceMapOutputWrapper(p, i))\n\t\t\t: validateSourceMapOutputWrapper(options.preprocess, 0);\n\t}\n}\n\nfunction validateSourceMapOutputWrapper(group: PreprocessorGroup, i: number): PreprocessorGroup {\n\tconst wrapper: PreprocessorGroup = {};\n\n\tfor (const [processorType, processorFn] of Object.entries(group) as Array<\n\t\t// eslint-disable-next-line no-unused-vars\n\t\t[keyof PreprocessorGroup, (options: { filename?: string; content: string }) => Processed]\n\t>) {\n\t\twrapper[processorType] = async (options) => {\n\t\t\tconst result = await processorFn(options);\n\n\t\t\tif (result && result.code !== options.content) {\n\t\t\t\tlet invalidMap = false;\n\t\t\t\tif (!result.map) {\n\t\t\t\t\tinvalidMap = true;\n\t\t\t\t\tlog.warn.enabled &&\n\t\t\t\t\t\tlog.warn.once(\n\t\t\t\t\t\t\t`preprocessor at index ${i} did not return a sourcemap for ${processorType} transform`,\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfilename: options.filename,\n\t\t\t\t\t\t\t\ttype: processorType,\n\t\t\t\t\t\t\t\tprocessor: processorFn.toString()\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t);\n\t\t\t\t} else if ((result.map as any)?.mappings === '') {\n\t\t\t\t\tinvalidMap = true;\n\t\t\t\t\tlog.warn.enabled &&\n\t\t\t\t\t\tlog.warn.once(\n\t\t\t\t\t\t\t`preprocessor at index ${i} returned an invalid empty sourcemap for ${processorType} transform`,\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfilename: options.filename,\n\t\t\t\t\t\t\t\ttype: processorType,\n\t\t\t\t\t\t\t\tprocessor: processorFn.toString()\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tif (invalidMap) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tconst map = await buildSourceMap(options.content, result.code, options.filename);\n\t\t\t\t\t\tif (map) {\n\t\t\t\t\t\t\tlog.debug.enabled &&\n\t\t\t\t\t\t\t\tlog.debug(\n\t\t\t\t\t\t\t\t\t`adding generated sourcemap to preprocesor result for ${options.filename}`\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tresult.map = map;\n\t\t\t\t\t\t}\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\tlog.error(`failed to build sourcemap`, e);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn result;\n\t\t};\n\t}\n\n\treturn wrapper;\n}\n", "import MagicString, { MagicStringOptions } from 'magic-string';\nimport { log } from './log';\n\nexport async function buildMagicString(\n\tfrom: string,\n\tto: string,\n\toptions?: MagicStringOptions\n): Promise<MagicString | null> {\n\tlet diff_match_patch, DIFF_DELETE: number, DIFF_INSERT: number;\n\ttry {\n\t\tconst dmpPkg = await import('diff-match-patch');\n\t\tdiff_match_patch = dmpPkg.diff_match_patch;\n\t\tDIFF_INSERT = dmpPkg.DIFF_INSERT;\n\t\tDIFF_DELETE = dmpPkg.DIFF_DELETE;\n\t} catch (e) {\n\t\tlog.error.once(\n\t\t\t'Failed to import optional dependency \"diff-match-patch\". Please install it to enable generated sourcemaps.'\n\t\t);\n\t\treturn null;\n\t}\n\n\tconst dmp = new diff_match_patch();\n\tconst diffs = dmp.diff_main(from, to);\n\tdmp.diff_cleanupSemantic(diffs);\n\tconst m = new MagicString(from, options);\n\tlet pos = 0;\n\tfor (let i = 0; i < diffs.length; i++) {\n\t\tconst diff = diffs[i];\n\t\tconst nextDiff = diffs[i + 1];\n\t\tif (diff[0] === DIFF_DELETE) {\n\t\t\tif (nextDiff?.[0] === DIFF_INSERT) {\n\t\t\t\t// delete followed by insert, use overwrite and skip ahead\n\t\t\t\tm.overwrite(pos, pos + diff[1].length, nextDiff[1]);\n\t\t\t\ti++;\n\t\t\t} else {\n\t\t\t\tm.remove(pos, pos + diff[1].length);\n\t\t\t}\n\t\t\tpos += diff[1].length;\n\t\t} else if (diff[0] === DIFF_INSERT) {\n\t\t\tif (nextDiff) {\n\t\t\t\tm.appendRight(pos, diff[1]);\n\t\t\t} else {\n\t\t\t\tm.append(diff[1]);\n\t\t\t}\n\t\t} else {\n\t\t\t// unchanged block, advance pos\n\t\t\tpos += diff[1].length;\n\t\t}\n\t}\n\t// at this point m.toString() === to\n\treturn m;\n}\n\nexport async function buildSourceMap(from: string, to: string, filename?: string) {\n\t// @ts-ignore\n\tconst m = await buildMagicString(from, to, { filename });\n\treturn m ? m.generateDecodedMap({ source: filename, hires: true, includeContent: false }) : null;\n}\n"],
|
|
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA,iBAAe;;;ACCf,oBAAkC;AAClC,mBAAkB;AAGlB,IAAM,SAAmB,CAAC,SAAS,QAAQ,QAAQ,SAAS;AAC5D,IAAM,SAAS;AACf,IAAM,UAAkC;AAAA,EACvC,OAAO;AAAA,IACN,KAAK,0BAAM,QAAQ;AAAA,IACnB,SAAS;AAAA,IACT,SAAS;AAAA;AAAA,EAEV,MAAM;AAAA,IACL,OAAO;AAAA,IACP,KAAK,QAAQ;AAAA,IACb,SAAS;AAAA;AAAA,EAEV,MAAM;AAAA,IACL,OAAO;AAAA,IACP,KAAK,QAAQ;AAAA,IACb,SAAS;AAAA;AAAA,EAEV,OAAO;AAAA,IACN,OAAO;AAAA,IACP,KAAK,QAAQ;AAAA,IACb,SAAS;AAAA;AAAA,EAEV,QAAQ;AAAA,IACP,SAAS;AAAA;AAAA;AAIX,IAAI,SAAiB;AACrB,kBAAkB,OAAe;AAChC,MAAI,UAAU,QAAQ;AACrB;AAAA;AAED,QAAM,aAAa,OAAO,QAAQ;AAClC,MAAI,aAAa,IAAI;AACpB,aAAS;AACT,aAAS,IAAI,GAAG,IAAI,OAAO,QAAQ,KAAK;AACvC,cAAQ,OAAO,IAAI,UAAU,KAAK;AAAA;AAAA,SAE7B;AACN,SAAK,QAAQ,OAAO,sBAAsB;AAAA;AAAA;AAI5C,cAAc,QAAa,SAAiB,SAAe;AAC1D,MAAI,CAAC,OAAO,SAAS;AACpB;AAAA;AAED,MAAI,OAAO,SAAS;AACnB,gBAAY,SAAY,OAAO,IAAI,SAAS,WAAW,OAAO,IAAI;AAAA,SAC5D;AACN,WAAO,IAAI,OAAO,MAAM,GAAG,IAAI,OAAO,yBAAyB,WAAW;AAC1E,QAAI,SAAS;AACZ,aAAO,IAAI;AAAA;AAAA;AAAA;AAWd,sBAAsB,OAAsB;AAC3C,QAAM,SAAS,QAAQ;AACvB,QAAM,QAAe,KAAK,KAAK,MAAM;AACrC,QAAM,SAAS,IAAI;AACnB,QAAM,OAAO,SAAU,SAAiB,SAAe;AACtD,QAAI,OAAO,IAAI,UAAU;AACxB;AAAA;AAED,WAAO,IAAI;AACX,UAAM,MAAM,MAAM,CAAC,SAAS;AAAA;AAE7B,SAAO,eAAe,OAAO,WAAW;AAAA,IACvC,MAAM;AACL,aAAO,OAAO;AAAA;AAAA;AAGhB,SAAO,eAAe,OAAO,QAAQ;AAAA,IACpC,MAAM;AACL,aAAO;AAAA;AAAA;AAGT,SAAO;AAAA;AAGD,IAAM,MAAM;AAAA,EAClB,OAAO,aAAa;AAAA,EACpB,MAAM,aAAa;AAAA,EACnB,MAAM,aAAa;AAAA,EACnB,OAAO,aAAa;AAAA,EACpB;AAAA;AAGM,6BAA6B,UAAqB,SAA0B;AAClF,QAAM,EAAE,SAAS,QAAQ,YAAY;AACrC,QAAM,OAAO,UAAU,YAAY;AACnC,uCAAU,QAAQ,CAAC,YAAY;AAC9B,QAAI,CAAC,WAAW,QAAQ,SAAS,uBAAuB;AACvD;AAAA;AAED,QAAI,QAAQ;AACX,aAAO,SAAS;AAAA,WACV;AACN,WAAK;AAAA;AAAA;AAAA;AAKR,iBAAiB,GAAY;AAC5B,MAAI,KAAK,WAAW,IAAI,KAAK,wBAAwB;AAAA;AAGtD,mBAAmB,GAAY;AAC9B,MAAI,KAAK,WAAW,IAAI,KAAK,wBAAwB,IAAI,EAAE;AAAA;AAG5D,iCAAiC,GAAY;AAC5C,QAAM,QAAQ;AACd,MAAI,EAAE,UAAU;AACf,UAAM,KAAK,EAAE;AAAA;AAEd,MAAI,EAAE,OAAO;AACZ,UAAM,KAAK,KAAK,EAAE,MAAM,MAAM,KAAK,EAAE,MAAM;AAAA;AAE5C,MAAI,EAAE,SAAS;AACd,UAAM,KAAK,KAAK,EAAE;AAAA;AAEnB,SAAO,MAAM,KAAK;AAAA;;;AC7HnB,+BACC,eACA,KACA,eACA,OACA,SAC+B;AAC/B,QAAM,EAAE,MAAM,WAAW;AAEzB,QAAM,WAAW,MAAM,MAAM;AAC7B,MAAI,CAAC,UAAU;AAEd,QAAI,MAAM,8BAA8B,cAAc;AACtD;AAAA;AAED,QAAM,YAAY,MAAM,OAAO;AAE/B,QAAM,UAAU,MAAM;AACtB,QAAM,cAA2B,MAAM,cAAc,eAAe,SAAS;AAC7E,QAAM,OAAO;AAEb,QAAM,kBAAkB,IAAI;AAE5B,QAAM,YAAY,OAAO,YAAY,cAAc,cAAc;AACjE,QAAM,aAAa,OAAO,YAAY,cAAc,cAAc;AAClE,QAAM,aAAa,aAAa,WAAW,WAAW,YAAY,SAAS;AAC3E,MAAI,YAAY;AACf,QAAI,MAAM;AACV,oBAAgB,IAAI;AAAA;AAErB,QAAM,YACL,cAAc,UAAU,UAAU,YAAY,SAAS,IAAI,cAAc;AAC1E,MAAI,WAAW;AACd,QAAI,MAAM;AACV,oBAAgB,IAAI;AAAA;AAGrB,MAAI,CAAC,WAAW;AAEf,wBAAoB,YAAY,SAAS,UAAU;AAAA;AAGpD,QAAM,SAAS,CAAC,GAAG,iBAAiB,OAAO;AAG3C,QAAM,yBAAyB,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,EAAE;AACxD,MAAI,uBAAuB,SAAS,GAAG;AACtC,QAAI,MAAM,wBAAwB,uBAAuB,IAAI,CAAC,MAAM,EAAE,IAAI,KAAK;AAC/E,2BAAuB,QAAQ,CAAC,eAAe,OAAO,YAAY,iBAAiB;AAAA;AAEpF,MAAI,OAAO,SAAS,GAAG;AACtB,QAAI,MACH,uBAAuB,cAAc,cAAc,OAAO,IAAI,CAAC,MAAM,EAAE,IAAI,KAAK;AAAA;AAGlF,SAAO;AAAA;AAGR,oBAAoB,MAAa,MAAsB;AACtD,SAAO,CAAC,YAAY,6BAAM,MAAM,6BAAM;AAAA;AAGvC,mBAAmB,MAAa,MAAa,UAA4B;AACxE,QAAM,SAAS,6BAAM;AACrB,QAAM,SAAS,6BAAM;AACrB,QAAM,gBAAgB,YAAY,QAAQ;AAC1C,MAAI,eAAe;AAClB,WAAO;AAAA;AAER,QAAM,eAAe,YAAY,gBAAgB,SAAS,gBAAgB;AAC1E,MAAI,CAAC,iBAAiB,cAAc;AACnC,QAAI,KACH,0CAA0C;AAAA;AAG5C,SAAO,CAAC;AAAA;AAGT,qBAAqB,MAAe,MAAwB;AAC3D,MAAI,CAAC,QAAQ,CAAC,MAAM;AACnB,WAAO;AAAA;AAER,MAAK,CAAC,QAAQ,QAAU,QAAQ,CAAC,MAAO;AACvC,WAAO;AAAA;AAER,SAAO,SAAS;AAAA;AAUjB,yBAAyB,MAAmC;AAC3D,MAAI,CAAC,MAAM;AACV,WAAO;AAAA;AAER,SAAO,KAAK,QAAQ,uCAAuC;AAAA;;;AC5G5D,sBAA0C;AAE1C,wBAA8B;;;ACH9B,aAAwB;AAExB,IAAM,SAAS,OAAO,OAAO;AAG7B,IAAM,cAAc;AAEb,wBAAwB,OAAe;AAC7C,MAAI,OAAO,QAAQ;AAClB,WAAO,OAAO;AAAA;AAKf,QAAM,MAAM,AAAO,kBAAW;AAC9B,MAAI,OAAO;AACX,QAAM,OAAO,OAAO,IAAI,OAAO,WAAW,OAAO,GAAG;AACpD,SAAO,SAAS;AAChB,SAAO;AAAA;AAGR,IAAM,eAA0C;AAAA,EAC/C,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA;AAGN,IAAM,YAAY,IAAI,OAAO,IAAI,OAAO,KAAK,cAAc,KAAK,QAAQ;AAExE,gBAAgB,QAAgB;AAC/B,SAAO,OAAO,QAAQ,WAAW,CAAC,MAAM,aAAa;AAAA;;;ADtBtD,IAAM,uBAAuB,CAAC,YAC7B,6BACC,eACA,MACA,SACuB;AAbzB;AAcE,QAAM,EAAE,UAAU,oBAAoB,OAAO,QAAQ;AACrD,QAAM,EAAE,UAAU,SAAS;AAC3B,QAAM,eAAe;AAErB,QAAM,iBAAiC,iCACnC,QAAQ,kBAD2B;AAAA,IAEtC;AAAA,IACA,UAAU,MAAM,QAAQ;AAAA;AAEzB,MAAI,QAAQ,OAAO,QAAQ,SAAS;AACnC,UAAM,OAAO,KAAK,eAAe;AACjC,QAAI,MAAM,mBAAmB,YAAY;AACzC,mBAAe,UAAU,MAAM;AAAA;AAGhC,MAAI;AAEJ,MAAI,QAAQ,YAAY;AACvB,mBAAe,MAAM,gCAAW,MAAM,QAAQ,YAAY,EAAE;AAC5D,QAAI,aAAa;AAAc,mBAAa,KAAK,GAAG,aAAa;AACjE,QAAI,aAAa;AAAK,qBAAe,YAAY,aAAa;AAAA;AAE/D,QAAM,YAAY,eAAe,aAAa,OAAO;AACrD,QAAM,wBAAwB,MAAM,qBAAQ,iBAAR,mBAAsB,0BAAtB,4BAA8C;AAAA,IACjF;AAAA,IACA,MAAM;AAAA,IACN;AAAA;AAED,MAAI,yBAAyB,IAAI,MAAM,SAAS;AAC/C,QAAI,MACH,gCAAgC,aAAa,KAAK,UAAU;AAAA;AAG9D,QAAM,sBAAsB,wBACzB,kCACG,iBACA,yBAEH;AACH,QAAM,WAAW,6BAAQ,WAAW;AAEpC,MAAI,WAAW,SAAS,IAAI,MAAM;AAEjC,aAAS,GAAG,QAAQ;AAAA,SAAY,KAAK,UAAU;AAAA;AAAA;AAIhD,MAAI,CAAC,OAAO,SAAS;AACpB,aAAS,GAAG,OAAO,QAAQ;AAAA,MAC1B,IAAI;AAAA,MACJ,cAAc,SAAS,GAAG;AAAA,MAC1B,YAAY,QAAQ;AAAA,MACpB;AAAA,MACA,cAAc;AAAA,MACd,gBAAgB;AAAA;AAAA;AAIlB,WAAS,GAAG,eAAe;AAE3B,SAAO;AAAA,IACN;AAAA,IACA;AAAA,IAEA;AAAA,IACA;AAAA,IACA;AAAA;AAAA;AAIH,sBAAsB,SAA0B;AApFhD;AAqFC,QAAM,eAAe,QAAQ,QAAQ,SAAS,QAAQ,WAAW,CAAC,QAAQ;AAC1E,MAAI,cAAc;AAEjB,UAAM,SAAS,yCAAS,QAAT,mBAAc;AAE7B,UAAM,UAAU,yCAAS,QAAT,mBAAc;AAC9B,WAAO,qCAAc;AAAA,MACpB;AAAA,MACA;AAAA,MACA;AAAA,MACA,YAAY,iBAAE,WAAW,QAAU,QAAQ;AAAA;AAAA;AAAA;AAKvC,6BAA6B,SAA0B;AAC7D,QAAM,UAAU,aAAa;AAC7B,SAAO,qBAAqB;AAAA;;;AErG7B,yBAA6B;AAE7B,kBAA8B;AAC9B,SAAoB;AAEpB,IAAM,iBAAiB;AACvB,IAAM,aAAa,QAAQ,aAAa;AAuBxC,iBAAiB,IAAY;AAC5B,QAAM,QAAQ,GAAG,MAAM,KAAK;AAC5B,QAAM,WAAW,MAAM;AACvB,QAAM,WAAW,MAAM;AACvB,SAAO,EAAE,UAAU;AAAA;AAGpB,8BACC,IACA,UACA,UACA,MACA,WACA,KAC4B;AAC5B,QAAM,QAAQ,kBAAkB;AAChC,MAAI,MAAM,OAAO,MAAM,KAAK;AAE3B;AAAA;AAED,QAAM,qBAAqB,UAAU,UAAU;AAC/C,QAAM,QAAQ,sBAAsB,UAAU,MAAM;AAEpD,SAAO;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA;AAAA;AAIF,+BAA+B,UAAkB,MAAc,MAAwB;AACtF,QAAM,QAAQ,CAAC,UAAU,QAAQ;AACjC,MAAI,SAAS,SAAS;AACrB,UAAM,KAAK;AAAA;AAEZ,MAAI,aAAa,UAAU,OAAO;AACjC,eAAW,OAAO;AAAA,aACR,SAAS,WAAW,iBAAiB;AAC/C,eAAW,aACR,SAAS,MAAM,eAAe,UAC9B,SAAS,MAAM,eAAe,SAAS;AAAA;AAG3C,SAAO,GAAG,YAAY,MAAM,KAAK;AAAA;AAGlC,2BAA2B,UAAgC;AAC1D,QAAM,QAAQ,OAAO,YAAY,IAAI,gBAAgB;AACrD,aAAW,OAAO,OAAO;AACxB,QAAI,MAAM,SAAS,IAAI;AAEtB,YAAM,OAAO;AAAA;AAAA;AAGf,SAAO;AAAA;AASR,mBAAmB,UAAkB,gBAAwB;AAC5D,SAAO,UAAU,+BAAc,WAAW;AAAA;AAG3C,sBAAsB,UAAkB,MAAc;AACrD,MAAI,SAAS,WAAW,iBAAiB;AACxC,WAAO;AAAA;AAER,SAAO,AAAG,cAAW,OAAO;AAAA;AAG7B,mBAAmB,oBAA4B,gBAAwB;AACtE,SAAO,mBAAmB,WAAW,iBAAiB,OACnD,mBAAmB,MAAM,eAAe,UACxC;AAAA;AAGJ,qBACC,SACA,SACA,YACgC;AAChC,QAAM,eAAe,qCAAa,SAAS;AAC3C,SAAO,CAAC,aAAa,aAAa,aAAa,WAAW,KAAK,CAAC,QAAQ,SAAS,SAAS;AAAA;AAIpF,uBAAuB,SAAoC;AACjE,QAAM,EAAE,SAAS,SAAS,YAAY,SAAS;AAC/C,QAAM,iBAAiB,+BAAc;AACrC,QAAM,SAAS,YAAY,SAAS,SAAS;AAC7C,SAAO,CAAC,IAAI,KAAK,YAAY,KAAK,UAAU;AAC3C,UAAM,EAAE,UAAU,aAAa,QAAQ;AACvC,QAAI,OAAO,WAAW;AACrB,aAAO,qBAAqB,IAAI,UAAU,UAAU,gBAAgB,WAAW;AAAA;AAAA;AAAA;;;AClIlF,mBAAoE;;;ACDpE,kBAAiB;AACjB,gBAAe;AACf,iBAA8B;AAKvB,IAAM,yBAAyB;AAAA,EACrC;AAAA,EACA;AAAA,EACA;AAAA;AAMD,IAAM,uBAAuB,IAAI,SAChC,QACA;AAGD,gCACC,YACA,eACwC;AACxC,QAAM,aAAa,iBAAiB,YAAY;AAChD,MAAI,YAAY;AACf,QAAI;AAEJ,QAAI,WAAW,SAAS,UAAU,WAAW,SAAS,SAAS;AAC9D,UAAI;AACH,cAAM,SAAS,MAAM,qBAAqB,8BAAc,YAAY;AACpE,YAAI,UAAU,MAAM;AACnB,iBAAO,iCACH,SADG;AAAA,YAEN;AAAA;AAAA,eAEK;AACN,gBAAM,IAAI,MAAM,qBAAqB;AAAA;AAAA,eAE9B,GAAP;AACD,YAAI,MAAM,2BAA2B,cAAc;AACnD,cAAM;AAAA;AAAA;AAIR,QAAI,CAAC,WAAW,SAAS,SAAS;AACjC,UAAI;AAEH,eAAO,QAAQ,MAAsB,AAAhB,QAAQ,QAAQ;AACrC,cAAM,SAAS,QAAQ;AACvB,YAAI,UAAU,MAAM;AACnB,iBAAO,iCACH,SADG;AAAA,YAEN;AAAA;AAAA,eAEK;AACN,gBAAM,IAAI,MAAM,qBAAqB;AAAA;AAAA,eAE9B,GAAP;AACD,YAAI,MAAM,4BAA4B,cAAc;AACpD,YAAI,CAAC,KAAK;AACT,gBAAM;AAAA;AAAA;AAAA;AAKT,UAAM;AAAA;AAAA;AAIR,0BAA0B,YAAwB,eAAiC;AAClF,QAAM,OAAO,WAAW,QAAQ,QAAQ;AACxC,MAAI,cAAc,YAAY;AAC7B,UAAM,cAAc,oBAAK,WAAW,cAAc,cAC/C,cAAc,aACd,oBAAK,QAAQ,MAAM,cAAc;AACpC,QAAI,CAAC,kBAAG,WAAW,cAAc;AAChC,YAAM,IAAI,MAAM,qCAAqC;AAAA;AAEtD,WAAO;AAAA,SACD;AACN,UAAM,2BAA2B,uBAC/B,IAAI,CAAC,cAAc,oBAAK,QAAQ,MAAM,YACtC,OAAO,CAAC,SAAS,kBAAG,WAAW;AACjC,QAAI,yBAAyB,WAAW,GAAG;AAC1C,UAAI,MAAM,6BAA6B;AACvC;AAAA,eACU,yBAAyB,SAAS,GAAG;AAC/C,UAAI,KACH,iDAAiD,yBAAyB,iCAC1E;AAAA;AAGF,WAAO,yBAAyB;AAAA;AAAA;;;AC9FlC,IAAM,2BAA2B,CAAC,UAAU,eAAe;AAEpD,IAAM,6BAA6B,CAAC,UAAU,GAAG;AAEjD,IAAM,iBAAiB;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA;AAGM,IAAM,qBAAqB;AAAA,EACjC;AAAA,EACA;AAAA,EACA;AAAA;;;AFHD,mBAAiB;AAEjB,IAAM,eAAe,IAAI,IAAI;AAAA,EAC5B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA;AAGD,6BAA6B,cAAuB,SAA6C;AAEhG,QAAM,UAAU,oCAAS,YAAW,OAAO,QAAQ,UAAU;AAE7D,QAAM,MAAM,eACT,QACA;AAAA,IACA,WAAW,CAAC;AAAA;AAEf,QAAM,iBAAmC;AAAA,IACxC,YAAY,CAAC;AAAA,IACb;AAAA,IACA;AAAA,IACA,iBAAiB;AAAA,MAChB,QAAQ;AAAA,MACR,KAAK,CAAC;AAAA,MACN,KAAK,CAAC;AAAA;AAAA;AAGR,MAAI,MAAM,uBAAuB,eAAe,eAAe,iBAAiB;AAChF,SAAO;AAAA;AAGD,+BAA+B,eAAkC;AACvE,QAAM,cAAc,OAAO,KAAK,iBAAiB,IAAI,OAAO,CAAC,QAAQ,CAAC,aAAa,IAAI;AACvF,MAAI,YAAY,QAAQ;AACvB,QAAI,KAAK,2BAA2B,YAAY,KAAK,oBAAoB;AAAA;AAAA;AAI3E,8BAA8B,SAA0B;AACvD,MAAI,QAAQ,KAAK;AAChB,QAAI,CAAC,QAAQ,gBAAgB,KAAK;AACjC,UAAI,KAAK;AACT,cAAQ,gBAAgB,MAAM;AAAA;AAE/B,QAAI,QAAQ,SAAS;AACpB,UAAI,QAAQ,QAAQ,QAAQ,QAAQ,IAAI,WAAW;AAClD,YAAI,KAAK;AACT,gBAAQ,IAAI,YAAY;AAAA;AAEzB,UAAI,QAAQ,gBAAgB,KAAK;AAChC,YAAI,KACH;AAED,gBAAQ,gBAAgB,MAAM;AAAA;AAAA,WAEzB;AACN,UAAI,QAAQ,QAAQ,QAAQ,CAAC,QAAQ,IAAI,WAAW;AACnD,YAAI,KACH;AAED,YAAI,QAAQ,QAAQ,MAAM;AACzB,kBAAQ,MAAM,EAAE,WAAW;AAAA,eACrB;AACN,kBAAQ,IAAI,YAAY;AAAA;AAAA;AAG1B,UAAI,CAAC,QAAQ,gBAAgB,KAAK;AACjC,YAAI,KACH;AAED,gBAAQ,gBAAgB,MAAM;AAAA;AAAA;AAAA;AAAA;AAMlC,qCAAqC,SAA0B;AAC9D,MAAI,QAAQ,cAAc;AACzB,QAAI,QAAQ,KAAK;AAChB,UAAI,KAAK;AACT,cAAQ,MAAM;AAAA;AAEf,QAAI,QAAQ,gBAAgB,KAAK;AAChC,UAAI,KACH;AAED,cAAQ,gBAAgB,MAAM;AAAA;AAAA;AAAA;AAKjC,sBACC,gBACA,cACA,eACA,YACA,SACkB;AAClB,QAAM,SAAS,+DACX,iBACA,eACA,gBAHW;AAAA,IAId,iBAAiB,iDACb,eAAe,kBACd,8CAAc,oBAAmB,KACjC,gDAAe,oBAAmB;AAAA,IAEvC,cAAc,kCACT,8CAAc,iBAAgB,KAC9B,gDAAe,iBAAgB;AAAA,IAEpC,MAAM,WAAW;AAAA,IACjB,cAAc,QAAQ,SAAS;AAAA,IAC/B,SAAS,QAAQ,YAAY;AAAA,IAC7B,SAAS,QAAQ,YAAY;AAAA;AAI9B,MAAI,6CAAc,YAAY;AAC7B,WAAO,aAAa,aAAa;AAAA;AAElC,SAAO;AAAA;AAGR,8BACC,gBAAkC,IAClC,YACA,SAC2B;AAC3B,QAAM,6BAA6B,iCAC/B,aAD+B;AAAA,IAElC,MAAM,gBAAgB;AAAA;AAEvB,QAAM,iBAAiB,oBAAoB,QAAQ,SAAS,cAAc;AAC1E,QAAM,eAAgB,MAAM,iBAAiB,4BAA4B,kBAAmB;AAC5F,QAAM,kBAAkB,aACvB,gBACA,cACA,eACA,4BACA;AAGD,8BAA4B;AAC5B,uBAAqB;AACrB,SAAO;AAAA;AAMR,yBAAyB,YAA4C;AACpE,SAAO,gCAAc,WAAW,OAAO,qBAAK,QAAQ,WAAW,QAAQ,QAAQ;AAAA;AAGzE,8BACN,SACA,QACsB;AApLvB;AAqLC,QAAM,mBAAmB,CAAC,GAAG,gBAAgB,GAAG;AAGhD,QAAM,sBAAsB,iBAAiB,OAC5C,CAAC,MAAG;AAzLN;AAyLS,YAAC,sBAAO,iBAAP,oBAAqB,YAArB,oBAA8B,SAAS;AAAA;AAGhD,QAAM,kBAAuC;AAAA,IAC5C,cAAc;AAAA,MACb,SAAS;AAAA;AAAA,IAEV,SAAS;AAAA,MACR,YAAY,CAAC,GAAG;AAAA,MAChB,QAAQ;AAAA;AAAA;AAQV,MAAI,QAAQ,WAAW,cAAO,UAAP,mBAAc,MAAK;AAIzC,QAAI,CAAC,oBAAO,QAAP,mBAAY,aAAZ,mBAAsB,SAAS,YAAW;AAE9C,sBAAgB,MAAM;AAAA,QACrB,YAAY,CAAC;AAAA;AAAA;AAAA;AAKhB,MAAI,cAAQ,iBAAR,mBAAsB,mBAAmB;AAG5C,oBAAgB,UAAU;AAAA,MACzB,aAAa;AAAA,QACZ,iBAAiB;AAAA,UAChB,wBAAwB;AAAA;AAAA;AAAA;AAAA;AAK5B,SAAO;AAAA;;;AG9ND,kCAA4B;AAAA,EAA5B,cAHP;AAIS,gBAAO,IAAI;AACX,eAAM,IAAI;AACV,yBAAgB,IAAI;AACpB,uBAAc,IAAI;AAAA;AAAA,EAEnB,OAAO,aAA0B;AACvC,SAAK,UAAU;AACf,SAAK,SAAS;AACd,SAAK,mBAAmB;AAAA;AAAA,EAGjB,UAAU,aAA0B;AAC3C,SAAK,KAAK,IAAI,YAAY,oBAAoB,YAAY,SAAS;AAAA;AAAA,EAG5D,SAAS,aAA0B;AAC1C,QAAI,CAAC,YAAY,KAAK;AAErB,WAAK,IAAI,IAAI,YAAY,oBAAoB,YAAY,SAAS;AAAA;AAAA;AAAA,EAI5D,mBAAmB,aAA0B;AACpD,UAAM,KAAK,YAAY;AACvB,UAAM,mBAAmB,KAAK,cAAc,IAAI,OAAO;AACvD,UAAM,eAAe,YAAY;AACjC,SAAK,cAAc,IAAI,IAAI;AAC3B,UAAM,UAAU,iBAAiB,OAAO,CAAC,MAAM,CAAC,aAAa,SAAS;AACtE,UAAM,QAAQ,aAAa,OAAO,CAAC,MAAM,CAAC,iBAAiB,SAAS;AACpE,UAAM,QAAQ,CAAC,MAAM;AACpB,UAAI,CAAC,KAAK,YAAY,IAAI,IAAI;AAC7B,aAAK,YAAY,IAAI,GAAG,IAAI;AAAA;AAE7B,WAAK,YAAY,IAAI,GAAI,IAAI,YAAY;AAAA;AAE1C,YAAQ,QAAQ,CAAC,MAAM;AACtB,WAAK,YAAY,IAAI,GAAI,OAAO,YAAY;AAAA;AAAA;AAAA,EAIvC,OAAO,eAAuC;AACpD,UAAM,KAAK,cAAc;AACzB,QAAI,UAAU;AACd,QAAI,KAAK,IAAI,OAAO,KAAK;AACxB,gBAAU;AAAA;AAEX,QAAI,KAAK,KAAK,OAAO,KAAK;AACzB,gBAAU;AAAA;AAEX,UAAM,eAAe,KAAK,cAAc,IAAI;AAC5C,QAAI,cAAc;AACjB,gBAAU;AACV,mBAAa,QAAQ,CAAC,MAAM;AAC3B,cAAM,aAAa,KAAK,YAAY,IAAI;AACxC,YAAI,cAAc,WAAW,IAAI,cAAc,WAAW;AACzD,qBAAW,OAAO,cAAc;AAAA;AAAA;AAGlC,WAAK,cAAc,OAAO;AAAA;AAE3B,WAAO;AAAA;AAAA,EAGD,OAAO,eAA8B;AAC3C,WAAO,KAAK,KAAK,IAAI,cAAc;AAAA;AAAA,EAG7B,MAAM,eAA8B;AAC1C,QAAI,CAAC,cAAc,KAAK;AAEvB,aAAO,KAAK,IAAI,IAAI,cAAc;AAAA;AAAA;AAAA,EAI7B,cAAc,OAAwB;AAC5C,UAAM,aAAa,KAAK,YAAY,IAAI;AACxC,WAAO,aAAa,CAAC,GAAG,cAAc;AAAA;AAAA;;;AC/ExC,iBAAe;AAKf,mBAAiB;AAEV,uBACN,SACA,OACA,eACC;AACD,QAAM,EAAE,QAAQ,YAAY,qBAAqB;AACjD,MAAI,CAAC,QAAQ;AACZ;AAAA;AAED,QAAM,EAAE,SAAS,OAAO;AACxB,QAAM,EAAE,YAAY,gBAAgB,MAAM,QAAQ,iBAAiB,OAAO;AAE1E,QAAM,8BAA8B,CAAC,aAAqB;AACzD,UAAM,aAAa,MAAM,cAAc;AACvC,eAAW,QAAQ,CAAC,cAAc;AACjC,UAAI,mBAAG,WAAW,YAAY;AAC7B,YAAI,MACH,sCAAsC,mCAAmC;AAE1E,gBAAQ,KAAK,UAAU;AAAA;AAAA;AAAA;AAK1B,QAAM,0BAA0B,CAAC,aAAqB;AACrD,UAAM,gBAAgB,cAAc,UAAU;AAC9C,QAAI,eAAe;AAClB,YAAM,mBAAmB,MAAM,OAAO;AACtC,UAAI,kBAAkB;AACrB,YAAI,MAAM,kDAAkD;AAAA;AAAA;AAAA;AAK/D,QAAM,qBAAqB,CAAC,aAAqB;AAGhD,QAAI,CAAC,CAAC,kBAAkB,CAAC,aAAa,gBAAgB;AACrD,UAAI,KAAK,0DAA0D;AACnE,cAAQ,KAAK,UAAU;AAAA,WACjB;AACN,YAAM,UACL;AACD,UAAI,KAAK,SAAS;AAClB,SAAG,KAAK;AAAA,QACP,MAAM;AAAA,QACN,KAAK,EAAE,SAAS,OAAO,IAAI,QAAQ,sBAAsB,IAAI;AAAA;AAAA;AAAA;AAKhE,QAAM,wBAAwB,uBAAuB,IAAI,CAAC,QAAQ,qBAAK,KAAK,MAAM;AAClF,QAAM,qBAAqB,CAAC,aAAqB;AAChD,QAAI,sBAAsB,SAAS,WAAW;AAC7C,yBAAmB;AAAA;AAAA;AAIrB,QAAM,wBAAwB,CAAC,aAAqB;AACnD,QAAI,aAAa,kBAAkB;AAClC,yBAAmB;AAAA;AAAA;AAKrB,QAAM,YAAY;AAAA,IACjB,KAAK;AAAA,IACL,QAAQ,CAAC;AAAA,IACT,QAAQ,CAAC,yBAAyB;AAAA;AAEnC,MAAI,kBAAkB;AACrB,cAAU,OAAO,KAAK;AACtB,cAAU,OAAO,KAAK;AAAA,SAChB;AAEN,cAAU,IAAI,KAAK;AAAA;AAGpB,SAAO,QAAQ,WAAW,QAAQ,CAAC,CAAC,KAAK,gBAAe;AACvD,QAAI,WAAU,SAAS,GAAG;AACzB,cAAQ,GAAG,KAAK,CAAC,aAAa,WAAU,QAAQ,CAAC,aAAa,SAAS;AAAA;AAAA;AAAA;;;ACxF1E,mBAAiB;AACjB,iBAAe;AAEf,8BAAqB;AAEd,qCAAqC,UAAkB,UAAkC;AAC/F,MAAI,YAAY,aAAa,WAAW;AACvC,UAAM,kBAAkB,gCAAS,QAAQ,GAAG,yBAAyB,qBAAK,QAAQ;AAClF,UAAM,cAAc,KAAK,MAAM,mBAAG,aAAa,iBAAiB,EAAE,UAAU;AAC5E,QAAI,YAAY,QAAQ;AACvB,aAAO,qBAAK,QAAQ,qBAAK,QAAQ,kBAAkB,YAAY;AAAA;AAAA;AAAA;AAKlE,sBAAsB,UAA2B;AAChD,MAAI,CAAC,YAAY,SAAS,OAAO,OAAO,SAAS,OAAO,QAAQ,qBAAK,WAAW,WAAW;AAC1F,WAAO;AAAA;AAER,QAAM,QAAQ,SAAS,MAAM;AAC7B,UAAQ,MAAM;AAAA,SACR;AACJ,aAAO;AAAA,SACH;AACJ,aAAO,MAAM,GAAG,WAAW;AAAA;AAE3B,aAAO;AAAA;AAAA;;;ACzBV,2BAAwB;;;ACDxB,0BAAgD;AAGhD,gCACC,MACA,IACA,SAC8B;AAC9B,MAAI,kBAAkB,aAAqB;AAC3C,MAAI;AACH,UAAM,SAAS,MAAM,gDAAO;AAC5B,uBAAmB,OAAO;AAC1B,kBAAc,OAAO;AACrB,kBAAc,OAAO;AAAA,WACb,GAAP;AACD,QAAI,MAAM,KACT;AAED,WAAO;AAAA;AAGR,QAAM,MAAM,IAAI;AAChB,QAAM,QAAQ,IAAI,UAAU,MAAM;AAClC,MAAI,qBAAqB;AACzB,QAAM,IAAI,IAAI,4BAAY,MAAM;AAChC,MAAI,MAAM;AACV,WAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;AACtC,UAAM,OAAO,MAAM;AACnB,UAAM,WAAW,MAAM,IAAI;AAC3B,QAAI,KAAK,OAAO,aAAa;AAC5B,UAAI,sCAAW,QAAO,aAAa;AAElC,UAAE,UAAU,KAAK,MAAM,KAAK,GAAG,QAAQ,SAAS;AAChD;AAAA,aACM;AACN,UAAE,OAAO,KAAK,MAAM,KAAK,GAAG;AAAA;AAE7B,aAAO,KAAK,GAAG;AAAA,eACL,KAAK,OAAO,aAAa;AACnC,UAAI,UAAU;AACb,UAAE,YAAY,KAAK,KAAK;AAAA,aAClB;AACN,UAAE,OAAO,KAAK;AAAA;AAAA,WAET;AAEN,aAAO,KAAK,GAAG;AAAA;AAAA;AAIjB,SAAO;AAAA;AAGR,8BAAqC,MAAc,IAAY,UAAmB;AAEjF,QAAM,IAAI,MAAM,iBAAiB,MAAM,IAAI,EAAE;AAC7C,SAAO,IAAI,EAAE,mBAAmB,EAAE,QAAQ,UAAU,OAAO,MAAM,gBAAgB,WAAW;AAAA;;;ADjD7F,IAAM,sBAAsB,CAAC,OAAO,QAAQ,QAAQ,QAAQ,QAAQ,UAAU;AAE9E,IAAM,uBAAuB,CAAC;AAE9B,0CACC,QACA,SACA,YACA,gBACe;AACf,QAAM,SAAS,OAAO,QAAQ,KAAK,CAAC,MAAM,EAAE,SAAS;AACrD,MAAI,CAAC,QAAQ;AACZ,UAAM,IAAI,MAAM,yBAAyB;AAAA;AAE1C,MAAI,CAAC,OAAO,WAAW;AACtB,UAAM,IAAI,MAAM,UAAU;AAAA;AAE3B,QAAM,kBAAkB,OAAO,UAAW,KAAK;AAE/C,SAAO,OAAO,EAAE,YAAY,SAAS,eAAe;AA1BrD;AA2BE,UAAM,OAAO,WAAW;AACxB,QAAI,CAAC,eAAe,SAAS,OAAO;AACnC,aAAO,EAAE,MAAM;AAAA;AAEhB,UAAM,WAAW,GAAG,YAAY;AAChC,UAAM,cAAc,cAAQ,WAAR,mBAAgB;AACpC,QAAI,eAAe,CAAC,YAAY,cAAc,WAAW;AACxD,YAAM,YAAY,mBAAmB;AAAA;AAEtC,UAAM,kBAAoC,MAAM,gBAC/C,SACA;AAGD,UAAM,SAAS,gBAAgB,OAAO,uBAAgB,QAAhB,mBAAqB,cAAa;AACxE,QAAI,6BAAgB,QAAhB,mBAAqB,YAArB,mBAA+B,QAAO,UAAU;AACnD,sBAAgB,IAAI,QAAQ,KAAK;AAAA;AAElC,WAAO;AAAA,MACN,MAAM,gBAAgB;AAAA,MACtB,KAAK,SAAU,gBAAgB,MAAiB;AAAA,MAChD,cAAc,gBAAgB;AAAA;AAAA;AAAA;AAK1B,qCACN,QACA,SACoB;AACpB,SAAO;AAAA,IACN,QAAQ,iCAAiC,QAAQ,SAAS,gBAAgB;AAAA,IAC1E,OAAO,iCAAiC,QAAQ,SAAS,YAAY;AAAA;AAAA;AAUvE,4DAA+E;AAC9E,SAAO;AAAA,IACN,MAAM,EAAE,SAAS,YAAY;AAC5B,YAAM,IAAI,IAAI,6BAAY;AAC1B,QAAE,OAAO;AACT,aAAO;AAAA,QACN,MAAM,EAAE;AAAA,QACR,KAAK,EAAE,mBAAmB,EAAE,QAAQ,UAAU,OAAO;AAAA;AAAA;AAAA;AAAA;AAMzD,iCAAiC,SAA0B,QAAwB;AAlFnF;AAmFC,QAAM,qBAAqB;AAC3B,MAAI,cAAQ,iBAAR,mBAAsB,mBAAmB;AAC5C,QAAI,MAAM;AACV,uBAAmB,KAAK,4BAA4B,QAAQ;AAAA;AAI7D,QAAM,qCAAqC,OAAO,QAAQ,OAAO,CAAC,MAAM,uBAAG;AAC3E,MAAI,mCAAmC,SAAS,GAAG;AAClD,QAAI,KACH,wKAAwK,mCACtK,IAAI,CAAC,MAAM,EAAE,MACb,KAAK;AAGR,uCAAmC,QAAQ,CAAC,MAAM;AACjD,UAAI,CAAC,EAAE,KAAK;AACX,UAAE,MAAM;AAAA;AAET,UAAI,EAAE,IAAI,qBAAqB,QAAW;AAEzC,UAAE,IAAI,mBAAmB,EAAE;AAAA,aACrB;AACN,YAAI,MACH,uCAAuC,EAAE;AAAA;AAAA;AAAA;AAM7C,QAAM,2BAAqC,OAAO,QAAQ,OAAO,CAAC,MAAG;AAjHtE;AAiHyE,yCAAG,QAAH,oBAAQ;AAAA;AAChF,QAAM,UAAoB,IACzB,WAAqB;AACtB,aAAW,KAAK,0BAA0B;AACzC,QACC,QAAQ,8BAA8B,QACrC,MAAM,QAAQ,QAAQ,8BACtB,eAAQ,8BAAR,mBAAmC,SAAS,EAAE,QAC9C;AACD,cAAQ,KAAK;AAAA,WACP;AACN,eAAS,KAAK;AAAA;AAAA;AAGhB,MAAI,QAAQ,SAAS,GAAG;AACvB,QAAI,MACH,gEAAgE,QAC9D,IAAI,CAAC,MAAM,EAAE,MACb,KAAK;AAAA;AAGT,MAAI,SAAS,SAAS,GAAG;AACxB,QAAI,MACH,8DAA8D,SAC5D,IAAI,CAAC,MAAM,EAAE,MACb,KAAK;AAER,uBAAmB,KAAK,GAAG,yBAAyB,IAAI,CAAC,MAAM,EAAE,IAAI;AAAA;AAGtE,MAAI,QAAQ,OAAO,QAAQ,SAAS;AACnC,uBAAmB,KAAK;AAAA;AAGzB,SAAO;AAAA;AAGD,+BAA+B,SAA0B,QAAwB;AAtJxF;AAuJC,QAAM,QAAQ,wBAAwB,SAAS;AAC/C,MAAI,gCAAO,UAAS,GAAG;AACtB,QAAI,CAAC,QAAQ,YAAY;AACxB,cAAQ,aAAa;AAAA,eACX,MAAM,QAAQ,QAAQ,aAAa;AAC7C,cAAQ,WAAW,KAAK,GAAG;AAAA,WACrB;AACN,cAAQ,aAAa,CAAC,QAAQ,YAAY,GAAG;AAAA;AAAA;AAG/C,QAAM,4BAA4B,CAAC,CAAC,eAAQ,iBAAR,mBAAsB;AAC1D,MAAI,QAAQ,cAAc,2BAA2B;AACpD,YAAQ,aAAa,MAAM,QAAQ,QAAQ,cACxC,QAAQ,WAAW,IAAI,CAAC,GAAG,MAAM,+BAA+B,GAAG,MACnE,+BAA+B,QAAQ,YAAY;AAAA;AAAA;AAIxD,wCAAwC,OAA0B,GAA8B;AAC/F,QAAM,UAA6B;AAEnC,aAAW,CAAC,eAAe,gBAAgB,OAAO,QAAQ,QAGvD;AACF,YAAQ,iBAAiB,OAAO,YAAY;AAhL9C;AAiLG,YAAM,SAAS,MAAM,YAAY;AAEjC,UAAI,UAAU,OAAO,SAAS,QAAQ,SAAS;AAC9C,YAAI,aAAa;AACjB,YAAI,CAAC,OAAO,KAAK;AAChB,uBAAa;AACb,cAAI,KAAK,WACR,IAAI,KAAK,KACR,yBAAyB,oCAAoC,2BAC7D;AAAA,YACC,UAAU,QAAQ;AAAA,YAClB,MAAM;AAAA,YACN,WAAW,YAAY;AAAA;AAAA,mBAGf,cAAO,QAAP,mBAAoB,cAAa,IAAI;AAChD,uBAAa;AACb,cAAI,KAAK,WACR,IAAI,KAAK,KACR,yBAAyB,6CAA6C,2BACtE;AAAA,YACC,UAAU,QAAQ;AAAA,YAClB,MAAM;AAAA,YACN,WAAW,YAAY;AAAA;AAAA;AAI3B,YAAI,YAAY;AACf,cAAI;AACH,kBAAM,MAAM,MAAM,eAAe,QAAQ,SAAS,OAAO,MAAM,QAAQ;AACvE,gBAAI,KAAK;AACR,kBAAI,MAAM,WACT,IAAI,MACH,wDAAwD,QAAQ;AAElE,qBAAO,MAAM;AAAA;AAAA,mBAEN,GAAP;AACD,gBAAI,MAAM,6BAA6B;AAAA;AAAA;AAAA;AAI1C,aAAO;AAAA;AAAA;AAIT,SAAO;AAAA;;;AZ3MD,gBAAgB,eAA0C;AAChE,MAAI,QAAQ,IAAI,SAAS,MAAM;AAC9B,QAAI,SAAS;AAAA;AAEd,wBAAsB;AACtB,QAAM,QAAQ,IAAI;AAClB,QAAM,oBAAoB,IAAI;AAE9B,MAAI;AACJ,MAAI;AACJ,MAAI;AAEJ,MAAI;AAOJ,MAAI;AAEJ,SAAO;AAAA,IACN,MAAM;AAAA,IAEN,SAAS;AAAA,UACH,OAAO,QAAQ,WAAyC;AAE7D,UAAI,QAAQ,IAAI,OAAO;AACtB,YAAI,SAAS;AAAA,iBACH,OAAO,UAAU;AAC3B,YAAI,SAAS,OAAO;AAAA;AAErB,gBAAU,MAAM,eAAe,eAAe,QAAQ;AAEtD,YAAM,kBAAkB,qBAAqB,SAAS;AACtD,UAAI,MAAM,0BAA0B;AACpC,aAAO;AAAA;AAAA,UAGF,eAAe,QAAQ;AAC5B,4BAAsB,SAAS;AAC/B,sBAAgB,cAAc;AAC9B,sBAAgB,oBAAoB;AACpC,mBAAa;AACb,UAAI,MAAM,oBAAoB;AAAA;AAAA,IAG/B,gBAAgB,QAAQ;AAEvB,cAAQ,SAAS;AACjB,oBAAc,SAAS,OAAO;AAAA;AAAA,IAG/B,KAAK,IAAI,KAAK;AACb,YAAM,gBAAgB,cAAc,IAAI,CAAC,CAAC;AAC1C,UAAI,eAAe;AAClB,cAAM,EAAE,UAAU,UAAU;AAE5B,YAAI,MAAM,UAAU,MAAM,SAAS,SAAS;AAC3C,gBAAM,MAAM,MAAM,OAAO;AACzB,cAAI,KAAK;AACR,gBAAI,MAAM,wBAAwB;AAClC,mBAAO;AAAA;AAAA;AAIT,YAAI,WAAW,cAAc,WAAW;AACvC,cAAI,MAAM,gCAAgC;AAC1C,iBAAO,mBAAG,aAAa,UAAU;AAAA;AAAA;AAAA;AAAA,UAK9B,UAAU,UAAU,UAAU,eAAe,KAAK;AACvD,YAAM,gBAAgB,cAAc,UAAU,CAAC,CAAC;AAChD,UAAI,+CAAe,MAAM,QAAQ;AAChC,YAAI,cAAc,MAAM,SAAS,SAAS;AAGzC,cAAI,MAAM,yCAAyC,cAAc;AACjE,iBAAO,cAAc;AAAA;AAEtB,YAAI,MAAM,sBAAsB;AAChC,eAAO;AAAA;AAGR,UAAI,OAAO,aAAa,UAAU;AACjC,YAAI,CAAC,mBAAmB;AACvB,8BAAoB,KAAK,QAAQ,cAAc,QAAW,EAAE,UAAU,QAAQ,KAC7E,CAAC,cAAc;AACd,gBAAI,MAAM;AACV,mBAAO;AAAA,aAER,CAAC,QAAQ;AACR,gBAAI,MACH,sFACA;AAED,mBAAO;AAAA;AAAA;AAIV,eAAO;AAAA;AAGR,UAAI;AACH,cAAM,WAAW,4BAA4B,UAAU;AACvD,YAAI,UAAU;AACb,cAAI,MAAM,sBAAsB,6CAA6C;AAC7E,iBAAO;AAAA;AAAA,eAEA,KAAP;AACD,gBAAQ,IAAI;AAAA,eACN;AACJ,8BAAkB,IAAI;AACtB,mBAAO;AAAA,eACH;AACJ,mBAAO;AAAA;AAEP,kBAAM;AAAA;AAAA;AAAA;AAAA,UAKJ,UAAU,MAAM,IAAI,KAAK;AAhJjC;AAiJG,YAAM,gBAAgB,cAAc,IAAI,CAAC,CAAC;AAC1C,UAAI,CAAC,eAAe;AACnB;AAAA;AAED,YAAM,EAAE,UAAU,UAAU;AAE5B,UAAI,MAAM,QAAQ;AACjB,YAAI,MAAM,SAAS,SAAS;AAC3B,gBAAM,MAAM,MAAM,OAAO;AACzB,cAAI,KAAK;AACR,gBAAI,MAAM,6BAA6B;AACvC,mBAAO;AAAA;AAAA;AAGT,YAAI,MAAM,6CAA6C;AACvD,cAAM,IAAI,MAAM,oDAAoD;AAAA;AAErE,YAAM,cAAc,MAAM,cAAc,eAAe,MAAM;AAC7D,0BAAoB,YAAY,SAAS,UAAU;AACnD,YAAM,OAAO;AACb,UAAI,mBAAY,iBAAZ,mBAA0B,WAAU,QAAQ,QAAQ;AACvD,oBAAY,aAAa,QAAQ,CAAC,MAAM,KAAK,aAAa;AAAA;AAE3D,UAAI,MAAM,qCAAqC;AAC/C,aAAO,YAAY,SAAS;AAAA;AAAA,IAG7B,gBAAgB,KAA2D;AAC1E,UAAI,CAAC,QAAQ,OAAO,CAAC,QAAQ,SAAS;AACrC;AAAA;AAED,YAAM,gBAAgB,cAAc,IAAI,MAAM,OAAO,IAAI;AACzD,UAAI,eAAe;AAClB,eAAO,gBAAgB,eAAe,KAAK,eAAe,OAAO;AAAA;AAAA;AAAA,IAQnE,WAAW;AACV,UAAI,kBAAkB,OAAO,GAAG;AAC/B,YAAI,KACH,gQACA,MAAM,KAAK,mBAAmB,CAAC,MAAM,KAAK,KAAK,KAAK;AAAA;AAAA;AAAA;AAAA;",
|
|
"names": []
|
|
}
|