emsdk-env 0.2.0 → 0.4.0
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/README.md +21 -4
- package/dist/__vite-browser-external-2Ng8QIWW.js +15 -0
- package/dist/__vite-browser-external-2Ng8QIWW.js.map +1 -0
- package/dist/__vite-browser-external-DES75WN9.cjs +15 -0
- package/dist/__vite-browser-external-DES75WN9.cjs.map +1 -0
- package/dist/{build-oenTJc-4.cjs → build-DwIdyC2W.cjs} +403 -80
- package/dist/build-DwIdyC2W.cjs.map +1 -0
- package/dist/{build-qp0IEBnb.js → build-oSzNI6Av.js} +405 -82
- package/dist/build-oSzNI6Av.js.map +1 -0
- package/dist/index.cjs +3 -3
- package/dist/index.d.ts +197 -33
- package/dist/index.mjs +3 -3
- package/dist/vite.cjs +32 -8
- package/dist/vite.cjs.map +1 -1
- package/dist/vite.d.ts +183 -27
- package/dist/vite.mjs +32 -8
- package/dist/vite.mjs.map +1 -1
- package/package.json +7 -7
- package/dist/build-oenTJc-4.cjs.map +0 -1
- package/dist/build-qp0IEBnb.js.map +0 -1
package/dist/vite.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vite.mjs","sources":["../node_modules/ms/index.js","../node_modules/debug/src/common.js","../node_modules/debug/src/browser.js","../src/vite/logger.ts","../src/vite/index.ts"],"sourcesContent":["/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function (val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '')\n\t\t\t.trim()\n\t\t\t.replace(/\\s+/g, ',')\n\t\t\t.split(',')\n\t\t\t.filter(Boolean);\n\n\t\tfor (const ns of split) {\n\t\t\tif (ns[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(ns.slice(1));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(ns);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Checks if the given string matches a namespace template, honoring\n\t * asterisks as wildcards.\n\t *\n\t * @param {String} search\n\t * @param {String} template\n\t * @return {Boolean}\n\t */\n\tfunction matchesTemplate(search, template) {\n\t\tlet searchIndex = 0;\n\t\tlet templateIndex = 0;\n\t\tlet starIndex = -1;\n\t\tlet matchIndex = 0;\n\n\t\twhile (searchIndex < search.length) {\n\t\t\tif (templateIndex < template.length && (template[templateIndex] === search[searchIndex] || template[templateIndex] === '*')) {\n\t\t\t\t// Match character or proceed with wildcard\n\t\t\t\tif (template[templateIndex] === '*') {\n\t\t\t\t\tstarIndex = templateIndex;\n\t\t\t\t\tmatchIndex = searchIndex;\n\t\t\t\t\ttemplateIndex++; // Skip the '*'\n\t\t\t\t} else {\n\t\t\t\t\tsearchIndex++;\n\t\t\t\t\ttemplateIndex++;\n\t\t\t\t}\n\t\t\t} else if (starIndex !== -1) { // eslint-disable-line no-negated-condition\n\t\t\t\t// Backtrack to the last '*' and try to match more characters\n\t\t\t\ttemplateIndex = starIndex + 1;\n\t\t\t\tmatchIndex++;\n\t\t\t\tsearchIndex = matchIndex;\n\t\t\t} else {\n\t\t\t\treturn false; // No match\n\t\t\t}\n\t\t}\n\n\t\t// Handle trailing '*' in template\n\t\twhile (templateIndex < template.length && template[templateIndex] === '*') {\n\t\t\ttemplateIndex++;\n\t\t}\n\n\t\treturn templateIndex === template.length;\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names,\n\t\t\t...createDebug.skips.map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tfor (const skip of createDebug.skips) {\n\t\t\tif (matchesTemplate(name, skip)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (const ns of createDebug.names) {\n\t\t\tif (matchesTemplate(name, ns)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\tlet m;\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\t// eslint-disable-next-line no-return-assign\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && (m = navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/)) && parseInt(m[1], 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug') || exports.storage.getItem('DEBUG') ;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport type { LogLevel, Logger as ViteLogger } from 'vite';\nimport createDebug from 'debug';\n\nimport { Logger } from '../types';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\n// Vite logger adapter with prefix\nexport const createViteLoggerAdapter = (\n viteLogger: ViteLogger,\n logLevel: LogLevel,\n prefix: string\n): Logger => {\n // Create debug instance with vite:plugin:prettier-max namespace\n const debug = createDebug('vite:plugin:emsdk-vite');\n\n return {\n debug: (msg: string) => {\n // Use debug module for debug level (enabled with vite --debug or DEBUG=vite:*)\n debug(msg);\n },\n info:\n logLevel !== 'silent'\n ? (msg: string) => viteLogger.info(`[${prefix}]: ${msg}`)\n : () => {},\n warn:\n logLevel === 'warn' || logLevel === 'info' || logLevel === 'error'\n ? (msg: string) => viteLogger.warn(`[${prefix}]: ${msg}`)\n : () => {},\n error:\n logLevel !== 'silent'\n ? (msg: string) => viteLogger.error(`[${prefix}]: ${msg}`)\n : () => {},\n };\n};\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport { isAbsolute, relative, resolve } from 'path';\nimport type { Plugin, ResolvedConfig, ViteDevServer } from 'vite';\n\nimport type { EmsdkVitePluginOptions } from './types';\nimport { createViteLoggerAdapter } from './logger';\nimport { buildWasm } from '../index';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nconst DEFAULT_WASM_SRC_DIR = 'wasm';\nconst buildRuns = new Map<string, Promise<void>>();\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nconst resolvePath = (rootDir: string, value: string) =>\n isAbsolute(value) ? value : resolve(rootDir, value);\n\nconst expandPlaceholders = (\n value: string,\n env: Record<string, string>,\n label: string\n) =>\n value.replace(/\\{([A-Z0-9_]+)\\}/g, (_match, key: string) => {\n const replacement = env[key];\n if (replacement === undefined) {\n throw new Error(`Unknown placeholder {${key}} in ${label}.`);\n }\n return replacement;\n });\n\nconst expandArray = (\n values: string[],\n env: Record<string, string>,\n label: string\n) => values.map((value) => expandPlaceholders(value, env, label));\n\nconst resolveIncludeDirs = (\n includeDirs: string[],\n env: Record<string, string>,\n rootDir: string\n) => {\n const expanded = expandArray(includeDirs, env, 'includeDirs');\n return expanded.map((value) => resolvePath(rootDir, value));\n};\n\nconst createBuildOptions = (\n options: EmsdkVitePluginOptions,\n resolvedConfig: ResolvedConfig,\n logger: ReturnType<typeof createViteLoggerAdapter>\n) => {\n const { emsdk, srcDir, outDir, buildDir, cleanupBuildDir, ...rule } = options;\n return {\n rule,\n root: resolvedConfig.root,\n logger,\n ...(emsdk !== undefined ? { emsdk } : {}),\n ...(srcDir !== undefined ? { srcDir } : {}),\n ...(outDir !== undefined ? { outDir } : {}),\n ...(buildDir !== undefined ? { buildDir } : {}),\n ...(cleanupBuildDir !== undefined ? { cleanupBuildDir } : {}),\n };\n};\n\nconst isSubPath = (parentDir: string, targetPath: string) => {\n const rel = relative(parentDir, targetPath);\n if (rel === '') {\n return true;\n }\n return !rel.startsWith('..') && !isAbsolute(rel);\n};\n\nconst resolveWatchTargets = (\n options: EmsdkVitePluginOptions,\n resolvedConfig: ResolvedConfig\n) => {\n const rootDir = resolvedConfig.root;\n const baseEnv = {\n ROOT: rootDir,\n };\n const rawSrcDir = expandPlaceholders(\n options.srcDir ?? DEFAULT_WASM_SRC_DIR,\n baseEnv,\n 'srcDir'\n );\n const srcDir = resolvePath(rootDir, rawSrcDir);\n\n const envWithDirs = {\n ROOT: rootDir,\n SRC_DIR: srcDir,\n };\n\n const patterns = new Set<string>();\n const baseDirs = new Set<string>();\n const resolvedIncludeDirs: string[] = [];\n patterns.add(srcDir);\n baseDirs.add(srcDir);\n\n const addIncludePatterns = (\n targetIncludeDirs: string[] | undefined,\n targetName: string | undefined\n ) => {\n if (!targetIncludeDirs || targetIncludeDirs.length === 0) {\n return;\n }\n const env = targetName\n ? { ...envWithDirs, TARGET_NAME: targetName }\n : envWithDirs;\n const resolvedDirs = resolveIncludeDirs(targetIncludeDirs, env, rootDir);\n for (const dir of resolvedDirs) {\n patterns.add(dir);\n baseDirs.add(dir);\n resolvedIncludeDirs.push(dir);\n }\n };\n\n addIncludePatterns(options.common?.includeDirs, undefined);\n for (const [targetName, target] of Object.entries(options.targets)) {\n addIncludePatterns(target.includeDirs, targetName);\n }\n\n return {\n srcDir,\n includeDirs: resolvedIncludeDirs,\n patterns: [...patterns],\n baseDirs: [...baseDirs],\n };\n};\n\nconst setupDevServer = async (\n server: ViteDevServer,\n options: EmsdkVitePluginOptions,\n resolvedConfig: ResolvedConfig\n) => {\n const logger = createViteLoggerAdapter(\n resolvedConfig.logger,\n resolvedConfig.logLevel ?? 'info',\n 'emsdk-env'\n );\n const buildOptions = createBuildOptions(options, resolvedConfig, logger);\n\n const watchTargets = resolveWatchTargets(options, resolvedConfig);\n logger.debug(`watch root: ${resolvedConfig.root}`);\n logger.debug(`watch srcDir: ${watchTargets.srcDir}`);\n logger.debug(\n `watch includeDirs: ${\n watchTargets.includeDirs.length > 0\n ? watchTargets.includeDirs.join(', ')\n : '(none)'\n }`\n );\n logger.debug(`watch patterns: ${watchTargets.patterns.join(', ')}`);\n logger.debug(`watch baseDirs: ${watchTargets.baseDirs.join(', ')}`);\n if (watchTargets.patterns.length > 0) {\n server.watcher.add(watchTargets.patterns);\n }\n\n let buildQueue = Promise.resolve();\n const queueBuild = async (shouldReload: boolean) => {\n buildQueue = buildQueue.then(async () => {\n try {\n await buildWasm(buildOptions);\n if (shouldReload) {\n server.ws.send({ type: 'full-reload' });\n }\n } catch (error) {\n const message =\n error instanceof Error ? error.message : 'Unknown wasm build error.';\n logger.error(`Wasm build failed: ${message}`);\n }\n });\n return buildQueue;\n };\n\n const onWatchEvent = async (eventPath: string) => {\n const resolvedPath = isAbsolute(eventPath)\n ? eventPath\n : resolve(resolvedConfig.root, eventPath);\n if (!watchTargets.baseDirs.some((dir) => isSubPath(dir, resolvedPath))) {\n return;\n }\n await queueBuild(true);\n };\n\n server.watcher.on('add', onWatchEvent);\n server.watcher.on('change', onWatchEvent);\n server.watcher.on('unlink', onWatchEvent);\n\n await queueBuild(false);\n};\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nconst emsdkEnv = (options: EmsdkVitePluginOptions): Plugin => {\n let resolvedConfig: ResolvedConfig | undefined;\n return {\n name: 'emsdkEnv',\n enforce: 'pre',\n configResolved(config) {\n resolvedConfig = config;\n },\n async buildStart() {\n if (!resolvedConfig) {\n throw new Error('Vite config was not resolved.');\n }\n if (resolvedConfig.command !== 'build') {\n return;\n }\n const logger = createViteLoggerAdapter(\n resolvedConfig.logger,\n resolvedConfig.logLevel ?? 'info',\n 'emsdk-env'\n );\n const buildOptions = createBuildOptions(options, resolvedConfig, logger);\n const buildKey = resolvedConfig.root;\n const existing = buildRuns.get(buildKey);\n if (existing) {\n await existing;\n return;\n }\n const run = (async () => {\n try {\n await buildWasm(buildOptions);\n } finally {\n buildRuns.delete(buildKey);\n }\n })();\n buildRuns.set(buildKey, run);\n await run;\n },\n async configureServer(server) {\n if (!resolvedConfig) {\n throw new Error('Vite config was not resolved.');\n }\n if (resolvedConfig.command !== 'serve') {\n return;\n }\n await setupDevServer(server, options, resolvedConfig);\n },\n };\n};\n\nexport default emsdkEnv;\n"],"names":["ms","createDebug","require$$0","exports"],"mappings":"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","x_google_ignoreList":[0,1,2]}
|
|
1
|
+
{"version":3,"file":"vite.mjs","sources":["../node_modules/ms/index.js","../node_modules/debug/src/common.js","../node_modules/debug/src/browser.js","../src/vite/logger.ts","../src/vite/index.ts"],"sourcesContent":["/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function (val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '')\n\t\t\t.trim()\n\t\t\t.replace(/\\s+/g, ',')\n\t\t\t.split(',')\n\t\t\t.filter(Boolean);\n\n\t\tfor (const ns of split) {\n\t\t\tif (ns[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(ns.slice(1));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(ns);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Checks if the given string matches a namespace template, honoring\n\t * asterisks as wildcards.\n\t *\n\t * @param {String} search\n\t * @param {String} template\n\t * @return {Boolean}\n\t */\n\tfunction matchesTemplate(search, template) {\n\t\tlet searchIndex = 0;\n\t\tlet templateIndex = 0;\n\t\tlet starIndex = -1;\n\t\tlet matchIndex = 0;\n\n\t\twhile (searchIndex < search.length) {\n\t\t\tif (templateIndex < template.length && (template[templateIndex] === search[searchIndex] || template[templateIndex] === '*')) {\n\t\t\t\t// Match character or proceed with wildcard\n\t\t\t\tif (template[templateIndex] === '*') {\n\t\t\t\t\tstarIndex = templateIndex;\n\t\t\t\t\tmatchIndex = searchIndex;\n\t\t\t\t\ttemplateIndex++; // Skip the '*'\n\t\t\t\t} else {\n\t\t\t\t\tsearchIndex++;\n\t\t\t\t\ttemplateIndex++;\n\t\t\t\t}\n\t\t\t} else if (starIndex !== -1) { // eslint-disable-line no-negated-condition\n\t\t\t\t// Backtrack to the last '*' and try to match more characters\n\t\t\t\ttemplateIndex = starIndex + 1;\n\t\t\t\tmatchIndex++;\n\t\t\t\tsearchIndex = matchIndex;\n\t\t\t} else {\n\t\t\t\treturn false; // No match\n\t\t\t}\n\t\t}\n\n\t\t// Handle trailing '*' in template\n\t\twhile (templateIndex < template.length && template[templateIndex] === '*') {\n\t\t\ttemplateIndex++;\n\t\t}\n\n\t\treturn templateIndex === template.length;\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names,\n\t\t\t...createDebug.skips.map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tfor (const skip of createDebug.skips) {\n\t\t\tif (matchesTemplate(name, skip)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (const ns of createDebug.names) {\n\t\t\tif (matchesTemplate(name, ns)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\tlet m;\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\t// eslint-disable-next-line no-return-assign\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && (m = navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/)) && parseInt(m[1], 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug') || exports.storage.getItem('DEBUG') ;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport type { LogLevel, Logger as ViteLogger } from 'vite';\nimport createDebug from 'debug';\n\nimport { Logger } from '../types';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\n// Vite logger adapter with prefix\nexport const createViteLoggerAdapter = (\n viteLogger: ViteLogger,\n logLevel: LogLevel,\n prefix: string\n): Logger => {\n // Create debug instance with vite:plugin:prettier-max namespace\n const debug = createDebug('vite:plugin:emsdk-vite');\n\n return {\n debug: (msg: string) => {\n // Use debug module for debug level (enabled with vite --debug or DEBUG=vite:*)\n debug(msg);\n },\n info:\n logLevel !== 'silent'\n ? (msg: string) => viteLogger.info(`[${prefix}]: ${msg}`)\n : () => {},\n warn:\n logLevel === 'warn' || logLevel === 'info' || logLevel === 'error'\n ? (msg: string) => viteLogger.warn(`[${prefix}]: ${msg}`)\n : () => {},\n error:\n logLevel !== 'silent'\n ? (msg: string) => viteLogger.error(`[${prefix}]: ${msg}`)\n : () => {},\n };\n};\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport { isAbsolute, relative, resolve } from 'path';\nimport type { Plugin, ResolvedConfig, ViteDevServer } from 'vite';\n\nimport type { BuildWasmOptions, Logger } from '../types';\nimport { buildWasm } from '../build';\nimport type { EmsdkVitePluginOptions } from './types';\nimport { createViteLoggerAdapter } from './logger';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nconst DEFAULT_WASM_SRC_DIR = 'wasm';\nconst DEFAULT_WASM_INCLUDE_DIR = 'include';\nconst buildRuns = new Map<string, Promise<void>>();\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nconst resolvePath = (rootDir: string, value: string) =>\n isAbsolute(value) ? value : resolve(rootDir, value);\n\nconst expandPlaceholders = (\n value: string,\n env: Record<string, string>,\n label: string\n) =>\n value.replace(/\\{([A-Z0-9_]+)\\}/g, (_match, key: string) => {\n const replacement = env[key];\n if (replacement === undefined) {\n throw new Error(`Unknown placeholder {${key}} in ${label}.`);\n }\n return replacement;\n });\n\nconst expandArray = (\n values: readonly string[],\n env: Record<string, string>,\n label: string\n) => values.map((value) => expandPlaceholders(value, env, label));\n\nconst resolveIncludeDirs = (\n includeDirs: readonly string[],\n env: Record<string, string>,\n rootDir: string\n) => {\n const expanded = expandArray(includeDirs, env, 'includeDirs');\n return expanded.map((value) => resolvePath(rootDir, value));\n};\n\nconst createBuildOptions = (\n options: EmsdkVitePluginOptions,\n resolvedConfig: ResolvedConfig,\n logger: Logger\n): BuildWasmOptions => {\n const {\n emsdk,\n srcDir,\n includeDir,\n imports,\n outDir,\n libDir,\n buildDir,\n cleanupBuildDir,\n parallel,\n ...rule\n } = options;\n return {\n rule,\n root: resolvedConfig.root,\n logger,\n ...(emsdk !== undefined ? { emsdk } : {}),\n ...(srcDir !== undefined ? { srcDir } : {}),\n ...(includeDir !== undefined ? { includeDir } : {}),\n ...(imports !== undefined ? { imports } : {}),\n ...(outDir !== undefined ? { outDir } : {}),\n ...(libDir !== undefined ? { libDir } : {}),\n ...(buildDir !== undefined ? { buildDir } : {}),\n ...(cleanupBuildDir !== undefined ? { cleanupBuildDir } : {}),\n ...(parallel !== undefined ? { parallel } : {}),\n };\n};\n\nconst isSubPath = (parentDir: string, targetPath: string) => {\n const rel = relative(parentDir, targetPath);\n if (rel === '') {\n return true;\n }\n return !rel.startsWith('..') && !isAbsolute(rel);\n};\n\nconst resolveWatchTargets = (\n options: EmsdkVitePluginOptions,\n resolvedConfig: ResolvedConfig\n) => {\n const rootDir = resolvedConfig.root;\n const baseEnv = {\n ROOT: rootDir,\n };\n const rawSrcDir = expandPlaceholders(\n options.srcDir ?? DEFAULT_WASM_SRC_DIR,\n baseEnv,\n 'srcDir'\n );\n const rawIncludeDir = expandPlaceholders(\n options.includeDir ?? DEFAULT_WASM_INCLUDE_DIR,\n baseEnv,\n 'includeDir'\n );\n const srcDir = resolvePath(rootDir, rawSrcDir);\n const includeDir = resolvePath(rootDir, rawIncludeDir);\n\n const envWithDirs = {\n ROOT: rootDir,\n SRC_DIR: srcDir,\n INCLUDE_DIR: includeDir,\n };\n\n const patterns = new Set<string>();\n const baseDirs = new Set<string>();\n const resolvedIncludeDirs: string[] = [];\n patterns.add(srcDir);\n baseDirs.add(srcDir);\n\n const addIncludePatterns = (\n targetIncludeDirs: readonly string[] | undefined,\n targetName: string | undefined\n ) => {\n if (!targetIncludeDirs || targetIncludeDirs.length === 0) {\n return;\n }\n const env = targetName\n ? { ...envWithDirs, TARGET_NAME: targetName }\n : envWithDirs;\n const resolvedDirs = resolveIncludeDirs(targetIncludeDirs, env, rootDir);\n for (const dir of resolvedDirs) {\n patterns.add(dir);\n baseDirs.add(dir);\n resolvedIncludeDirs.push(dir);\n }\n };\n\n const commonIncludeDirs =\n options.common?.includeDirs === undefined\n ? [rawIncludeDir]\n : options.common.includeDirs;\n addIncludePatterns(commonIncludeDirs, undefined);\n for (const [targetName, target] of Object.entries(options.targets)) {\n addIncludePatterns(target.includeDirs, targetName);\n }\n\n return {\n srcDir,\n includeDirs: resolvedIncludeDirs,\n patterns: [...patterns],\n baseDirs: [...baseDirs],\n };\n};\n\nconst setupDevServer = async (\n server: ViteDevServer,\n options: EmsdkVitePluginOptions,\n resolvedConfig: ResolvedConfig\n) => {\n const logger = createViteLoggerAdapter(\n resolvedConfig.logger,\n resolvedConfig.logLevel ?? 'info',\n 'emsdk-env'\n );\n const buildOptions = createBuildOptions(options, resolvedConfig, logger);\n\n const watchTargets = resolveWatchTargets(options, resolvedConfig);\n logger.debug(`watch root: ${resolvedConfig.root}`);\n logger.debug(`watch srcDir: ${watchTargets.srcDir}`);\n logger.debug(\n `watch includeDirs: ${\n watchTargets.includeDirs.length > 0\n ? watchTargets.includeDirs.join(', ')\n : '(none)'\n }`\n );\n logger.debug(`watch patterns: ${watchTargets.patterns.join(', ')}`);\n logger.debug(`watch baseDirs: ${watchTargets.baseDirs.join(', ')}`);\n if (watchTargets.patterns.length > 0) {\n server.watcher.add(watchTargets.patterns);\n }\n\n let buildQueue = Promise.resolve();\n const queueBuild = async (shouldReload: boolean) => {\n buildQueue = buildQueue.then(async () => {\n try {\n await buildWasm(buildOptions);\n if (shouldReload) {\n server.ws.send({ type: 'full-reload' });\n }\n } catch (error) {\n const message =\n error instanceof Error ? error.message : 'Unknown wasm build error.';\n logger.error(`Wasm build failed: ${message}`);\n }\n });\n return buildQueue;\n };\n\n const onWatchEvent = async (eventPath: string) => {\n const resolvedPath = isAbsolute(eventPath)\n ? eventPath\n : resolve(resolvedConfig.root, eventPath);\n if (!watchTargets.baseDirs.some((dir) => isSubPath(dir, resolvedPath))) {\n return;\n }\n await queueBuild(true);\n };\n\n server.watcher.on('add', onWatchEvent);\n server.watcher.on('change', onWatchEvent);\n server.watcher.on('unlink', onWatchEvent);\n\n await queueBuild(false);\n};\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Vite plugin that builds C/C++ sources into WASM using the Emscripten SDK.\n *\n * In dev (`vite serve`), it watches source/include directories and rebuilds on\n * changes. In build (`vite build`), it performs a one-shot build before bundling.\n *\n * @param options - Plugin options including build rules.\n * @returns Vite plugin instance.\n */\nconst emsdkEnv = (options: EmsdkVitePluginOptions): Plugin => {\n let resolvedConfig: ResolvedConfig | undefined;\n return {\n name: 'emsdkEnv',\n enforce: 'pre',\n configResolved(config) {\n resolvedConfig = config;\n },\n async buildStart() {\n if (!resolvedConfig) {\n throw new Error('Vite config was not resolved.');\n }\n if (resolvedConfig.command !== 'build') {\n return;\n }\n const logger = createViteLoggerAdapter(\n resolvedConfig.logger,\n resolvedConfig.logLevel ?? 'info',\n 'emsdk-env'\n );\n const buildOptions = createBuildOptions(options, resolvedConfig, logger);\n const buildKey = resolvedConfig.root;\n const existing = buildRuns.get(buildKey);\n if (existing) {\n await existing;\n return;\n }\n const run = (async () => {\n try {\n await buildWasm(buildOptions);\n } finally {\n buildRuns.delete(buildKey);\n }\n })();\n buildRuns.set(buildKey, run);\n await run;\n },\n async configureServer(server) {\n if (!resolvedConfig) {\n throw new Error('Vite config was not resolved.');\n }\n if (resolvedConfig.command !== 'serve') {\n return;\n }\n await setupDevServer(server, options, resolvedConfig);\n },\n };\n};\n\nexport default emsdkEnv;\n"],"names":["ms","createDebug","require$$0","exports"],"mappings":";;;;;;;;;;;AAIA,MAAI,IAAI;AACR,MAAI,IAAI,IAAI;AACZ,MAAI,IAAI,IAAI;AACZ,MAAI,IAAI,IAAI;AACZ,MAAI,IAAI,IAAI;AACZ,MAAI,IAAI,IAAI;AAgBZ,OAAiB,SAAU,KAAK,SAAS;AACvC,cAAU,WAAW,CAAA;AACrB,QAAI,OAAO,OAAO;AAClB,QAAI,SAAS,YAAY,IAAI,SAAS,GAAG;AACvC,aAAO,MAAM,GAAG;AAAA,IACpB,WAAa,SAAS,YAAY,SAAS,GAAG,GAAG;AAC7C,aAAO,QAAQ,OAAO,QAAQ,GAAG,IAAI,SAAS,GAAG;AAAA,IACrD;AACE,UAAM,IAAI;AAAA,MACR,0DACE,KAAK,UAAU,GAAG;AAAA;EAExB;AAUA,WAAS,MAAM,KAAK;AAClB,UAAM,OAAO,GAAG;AAChB,QAAI,IAAI,SAAS,KAAK;AACpB;AAAA,IACJ;AACE,QAAI,QAAQ,mIAAmI;AAAA,MAC7I;AAAA;AAEF,QAAI,CAAC,OAAO;AACV;AAAA,IACJ;AACE,QAAI,IAAI,WAAW,MAAM,CAAC,CAAC;AAC3B,QAAI,QAAQ,MAAM,CAAC,KAAK,MAAM,YAAW;AACzC,YAAQ,MAAI;AAAA,MACV,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO,IAAI;AAAA,MACb,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO,IAAI;AAAA,MACb,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO,IAAI;AAAA,MACb,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO,IAAI;AAAA,MACb,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO,IAAI;AAAA,MACb,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO,IAAI;AAAA,MACb,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO;AAAA,MACT;AACE,eAAO;AAAA,IACb;AAAA,EACA;AAUA,WAAS,SAASA,KAAI;AACpB,QAAI,QAAQ,KAAK,IAAIA,GAAE;AACvB,QAAI,SAAS,GAAG;AACd,aAAO,KAAK,MAAMA,MAAK,CAAC,IAAI;AAAA,IAChC;AACE,QAAI,SAAS,GAAG;AACd,aAAO,KAAK,MAAMA,MAAK,CAAC,IAAI;AAAA,IAChC;AACE,QAAI,SAAS,GAAG;AACd,aAAO,KAAK,MAAMA,MAAK,CAAC,IAAI;AAAA,IAChC;AACE,QAAI,SAAS,GAAG;AACd,aAAO,KAAK,MAAMA,MAAK,CAAC,IAAI;AAAA,IAChC;AACE,WAAOA,MAAK;AAAA,EACd;AAUA,WAAS,QAAQA,KAAI;AACnB,QAAI,QAAQ,KAAK,IAAIA,GAAE;AACvB,QAAI,SAAS,GAAG;AACd,aAAO,OAAOA,KAAI,OAAO,GAAG,KAAK;AAAA,IACrC;AACE,QAAI,SAAS,GAAG;AACd,aAAO,OAAOA,KAAI,OAAO,GAAG,MAAM;AAAA,IACtC;AACE,QAAI,SAAS,GAAG;AACd,aAAO,OAAOA,KAAI,OAAO,GAAG,QAAQ;AAAA,IACxC;AACE,QAAI,SAAS,GAAG;AACd,aAAO,OAAOA,KAAI,OAAO,GAAG,QAAQ;AAAA,IACxC;AACE,WAAOA,MAAK;AAAA,EACd;AAMA,WAAS,OAAOA,KAAI,OAAO,GAAG,MAAM;AAClC,QAAI,WAAW,SAAS,IAAI;AAC5B,WAAO,KAAK,MAAMA,MAAK,CAAC,IAAI,MAAM,QAAQ,WAAW,MAAM;AAAA,EAC7D;;;;;;;;AC3JA,WAAS,MAAM,KAAK;AACnB,IAAAC,aAAY,QAAQA;AACpB,IAAAA,aAAY,UAAUA;AACtB,IAAAA,aAAY,SAAS;AACrB,IAAAA,aAAY,UAAU;AACtB,IAAAA,aAAY,SAAS;AACrB,IAAAA,aAAY,UAAU;AACtB,IAAAA,aAAY,WAAWC,UAAA;AACvB,IAAAD,aAAY,UAAU;AAEtB,WAAO,KAAK,GAAG,EAAE,QAAQ,SAAO;AAC/B,MAAAA,aAAY,GAAG,IAAI,IAAI,GAAG;AAAA,IAC5B,CAAE;AAMD,IAAAA,aAAY,QAAQ,CAAA;AACpB,IAAAA,aAAY,QAAQ,CAAA;AAOpB,IAAAA,aAAY,aAAa,CAAA;AAQzB,aAAS,YAAY,WAAW;AAC/B,UAAI,OAAO;AAEX,eAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAC1C,gBAAS,QAAQ,KAAK,OAAQ,UAAU,WAAW,CAAC;AACpD,gBAAQ;AAAA,MACX;AAEE,aAAOA,aAAY,OAAO,KAAK,IAAI,IAAI,IAAIA,aAAY,OAAO,MAAM;AAAA,IACtE;AACC,IAAAA,aAAY,cAAc;AAS1B,aAASA,aAAY,WAAW;AAC/B,UAAI;AACJ,UAAI,iBAAiB;AACrB,UAAI;AACJ,UAAI;AAEJ,eAAS,SAAS,MAAM;AAEvB,YAAI,CAAC,MAAM,SAAS;AACnB;AAAA,QACJ;AAEG,cAAM,OAAO;AAGb,cAAM,OAAO,OAAO,oBAAI,MAAM;AAC9B,cAAMD,MAAK,QAAQ,YAAY;AAC/B,aAAK,OAAOA;AACZ,aAAK,OAAO;AACZ,aAAK,OAAO;AACZ,mBAAW;AAEX,aAAK,CAAC,IAAIC,aAAY,OAAO,KAAK,CAAC,CAAC;AAEpC,YAAI,OAAO,KAAK,CAAC,MAAM,UAAU;AAEhC,eAAK,QAAQ,IAAI;AAAA,QACrB;AAGG,YAAI,QAAQ;AACZ,aAAK,CAAC,IAAI,KAAK,CAAC,EAAE,QAAQ,iBAAiB,CAAC,OAAO,WAAW;AAE7D,cAAI,UAAU,MAAM;AACnB,mBAAO;AAAA,UACZ;AACI;AACA,gBAAM,YAAYA,aAAY,WAAW,MAAM;AAC/C,cAAI,OAAO,cAAc,YAAY;AACpC,kBAAM,MAAM,KAAK,KAAK;AACtB,oBAAQ,UAAU,KAAK,MAAM,GAAG;AAGhC,iBAAK,OAAO,OAAO,CAAC;AACpB;AAAA,UACL;AACI,iBAAO;AAAA,QACX,CAAI;AAGD,QAAAA,aAAY,WAAW,KAAK,MAAM,IAAI;AAEtC,cAAM,QAAQ,KAAK,OAAOA,aAAY;AACtC,cAAM,MAAM,MAAM,IAAI;AAAA,MACzB;AAEE,YAAM,YAAY;AAClB,YAAM,YAAYA,aAAY,UAAS;AACvC,YAAM,QAAQA,aAAY,YAAY,SAAS;AAC/C,YAAM,SAAS;AACf,YAAM,UAAUA,aAAY;AAE5B,aAAO,eAAe,OAAO,WAAW;AAAA,QACvC,YAAY;AAAA,QACZ,cAAc;AAAA,QACd,KAAK,MAAM;AACV,cAAI,mBAAmB,MAAM;AAC5B,mBAAO;AAAA,UACZ;AACI,cAAI,oBAAoBA,aAAY,YAAY;AAC/C,8BAAkBA,aAAY;AAC9B,2BAAeA,aAAY,QAAQ,SAAS;AAAA,UACjD;AAEI,iBAAO;AAAA,QACX;AAAA,QACG,KAAK,OAAK;AACT,2BAAiB;AAAA,QACrB;AAAA,MACA,CAAG;AAGD,UAAI,OAAOA,aAAY,SAAS,YAAY;AAC3C,QAAAA,aAAY,KAAK,KAAK;AAAA,MACzB;AAEE,aAAO;AAAA,IACT;AAEC,aAAS,OAAO,WAAW,WAAW;AACrC,YAAM,WAAWA,aAAY,KAAK,aAAa,OAAO,cAAc,cAAc,MAAM,aAAa,SAAS;AAC9G,eAAS,MAAM,KAAK;AACpB,aAAO;AAAA,IACT;AASC,aAAS,OAAO,YAAY;AAC3B,MAAAA,aAAY,KAAK,UAAU;AAC3B,MAAAA,aAAY,aAAa;AAEzB,MAAAA,aAAY,QAAQ,CAAA;AACpB,MAAAA,aAAY,QAAQ,CAAA;AAEpB,YAAM,SAAS,OAAO,eAAe,WAAW,aAAa,IAC3D,KAAI,EACJ,QAAQ,QAAQ,GAAG,EACnB,MAAM,GAAG,EACT,OAAO,OAAO;AAEhB,iBAAW,MAAM,OAAO;AACvB,YAAI,GAAG,CAAC,MAAM,KAAK;AAClB,UAAAA,aAAY,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC;AAAA,QACtC,OAAU;AACN,UAAAA,aAAY,MAAM,KAAK,EAAE;AAAA,QAC7B;AAAA,MACA;AAAA,IACA;AAUC,aAAS,gBAAgB,QAAQ,UAAU;AAC1C,UAAI,cAAc;AAClB,UAAI,gBAAgB;AACpB,UAAI,YAAY;AAChB,UAAI,aAAa;AAEjB,aAAO,cAAc,OAAO,QAAQ;AACnC,YAAI,gBAAgB,SAAS,WAAW,SAAS,aAAa,MAAM,OAAO,WAAW,KAAK,SAAS,aAAa,MAAM,MAAM;AAE5H,cAAI,SAAS,aAAa,MAAM,KAAK;AACpC,wBAAY;AACZ,yBAAa;AACb;AAAA,UACL,OAAW;AACN;AACA;AAAA,UACL;AAAA,QACA,WAAc,cAAc,IAAI;AAE5B,0BAAgB,YAAY;AAC5B;AACA,wBAAc;AAAA,QAClB,OAAU;AACN,iBAAO;AAAA,QACX;AAAA,MACA;AAGE,aAAO,gBAAgB,SAAS,UAAU,SAAS,aAAa,MAAM,KAAK;AAC1E;AAAA,MACH;AAEE,aAAO,kBAAkB,SAAS;AAAA,IACpC;AAQC,aAAS,UAAU;AAClB,YAAM,aAAa;AAAA,QAClB,GAAGA,aAAY;AAAA,QACf,GAAGA,aAAY,MAAM,IAAI,eAAa,MAAM,SAAS;AAAA,MACxD,EAAI,KAAK,GAAG;AACV,MAAAA,aAAY,OAAO,EAAE;AACrB,aAAO;AAAA,IACT;AASC,aAAS,QAAQ,MAAM;AACtB,iBAAW,QAAQA,aAAY,OAAO;AACrC,YAAI,gBAAgB,MAAM,IAAI,GAAG;AAChC,iBAAO;AAAA,QACX;AAAA,MACA;AAEE,iBAAW,MAAMA,aAAY,OAAO;AACnC,YAAI,gBAAgB,MAAM,EAAE,GAAG;AAC9B,iBAAO;AAAA,QACX;AAAA,MACA;AAEE,aAAO;AAAA,IACT;AASC,aAAS,OAAO,KAAK;AACpB,UAAI,eAAe,OAAO;AACzB,eAAO,IAAI,SAAS,IAAI;AAAA,MAC3B;AACE,aAAO;AAAA,IACT;AAMC,aAAS,UAAU;AAClB,cAAQ,KAAK,uIAAuI;AAAA,IACtJ;AAEC,IAAAA,aAAY,OAAOA,aAAY,MAAM;AAErC,WAAOA;AAAA,EACR;AAEA,WAAiB;;;;;;;;AC7RjBE,cAAA,aAAqB;AACrBA,cAAA,OAAe;AACfA,cAAA,OAAe;AACfA,cAAA,YAAoB;AACpBA,cAAA,UAAkB,aAAY;AAC9BA,cAAA,UAAmB,uBAAM;AACxB,UAAI,SAAS;AAEb,aAAO,MAAM;AACZ,YAAI,CAAC,QAAQ;AACZ,mBAAS;AACT,kBAAQ,KAAK,uIAAuI;AAAA,QACvJ;AAAA,MACA;AAAA,IACA,GAAC;AAMDA,cAAA,SAAiB;AAAA,MAChB;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA;AAYD,aAAS,YAAY;AAIpB,UAAI,OAAO,WAAW,eAAe,OAAO,YAAY,OAAO,QAAQ,SAAS,cAAc,OAAO,QAAQ,SAAS;AACrH,eAAO;AAAA,MACT;AAGC,UAAI,OAAO,cAAc,eAAe,UAAU,aAAa,UAAU,UAAU,YAAW,EAAG,MAAM,uBAAuB,GAAG;AAChI,eAAO;AAAA,MACT;AAEC,UAAI;AAKJ,aAAQ,OAAO,aAAa,eAAe,SAAS,mBAAmB,SAAS,gBAAgB,SAAS,SAAS,gBAAgB,MAAM;AAAA,MAEtI,OAAO,WAAW,eAAe,OAAO,YAAY,OAAO,QAAQ,WAAY,OAAO,QAAQ,aAAa,OAAO,QAAQ;AAAA;AAAA,MAG1H,OAAO,cAAc,eAAe,UAAU,cAAc,IAAI,UAAU,UAAU,YAAW,EAAG,MAAM,gBAAgB,MAAM,SAAS,EAAE,CAAC,GAAG,EAAE,KAAK;AAAA,MAEpJ,OAAO,cAAc,eAAe,UAAU,aAAa,UAAU,UAAU,YAAW,EAAG,MAAM,oBAAoB;AAAA,IAC1H;AAQA,aAAS,WAAW,MAAM;AACzB,WAAK,CAAC,KAAK,KAAK,YAAY,OAAO,MAClC,KAAK,aACJ,KAAK,YAAY,QAAQ,OAC1B,KAAK,CAAC,KACL,KAAK,YAAY,QAAQ,OAC1B,MAAM,OAAO,QAAQ,SAAS,KAAK,IAAI;AAExC,UAAI,CAAC,KAAK,WAAW;AACpB;AAAA,MACF;AAEC,YAAM,IAAI,YAAY,KAAK;AAC3B,WAAK,OAAO,GAAG,GAAG,GAAG,gBAAgB;AAKrC,UAAI,QAAQ;AACZ,UAAI,QAAQ;AACZ,WAAK,CAAC,EAAE,QAAQ,eAAe,WAAS;AACvC,YAAI,UAAU,MAAM;AACnB;AAAA,QACH;AACE;AACA,YAAI,UAAU,MAAM;AAGnB,kBAAQ;AAAA,QACX;AAAA,MACA,CAAE;AAED,WAAK,OAAO,OAAO,GAAG,CAAC;AAAA,IACxB;AAUAA,cAAA,MAAc,QAAQ,SAAS,QAAQ,QAAQ,MAAM;AAAA,IAAA;AAQrD,aAAS,KAAK,YAAY;AACzB,UAAI;AACH,YAAI,YAAY;AACfA,oBAAQ,QAAQ,QAAQ,SAAS,UAAU;AAAA,QAC9C,OAAS;AACNA,oBAAQ,QAAQ,WAAW,OAAO;AAAA,QACrC;AAAA,MACA,SAAU,OAAO;AAAA,MAGjB;AAAA,IACA;AAQA,aAAS,OAAO;AACf,UAAI;AACJ,UAAI;AACH,YAAIA,UAAQ,QAAQ,QAAQ,OAAO,KAAKA,UAAQ,QAAQ,QAAQ,OAAO;AAAA,MACzE,SAAU,OAAO;AAAA,MAGjB;AAGC,UAAI,CAAC,KAAK,OAAO,YAAY,eAAe,SAAS,SAAS;AAC7D,YAAI,QAAQ,IAAI;AAAA,MAClB;AAEC,aAAO;AAAA,IACR;AAaA,aAAS,eAAe;AACvB,UAAI;AAGH,eAAO;AAAA,MACT,SAAU,OAAO;AAAA,MAGjB;AAAA,IACA;AAEA,WAAA,UAAiBD,cAAA,EAAoBC,SAAO;AAE5C,UAAM,EAAC,WAAU,IAAI,OAAO;AAM5B,eAAW,IAAI,SAAU,GAAG;AAC3B,UAAI;AACH,eAAO,KAAK,UAAU,CAAC;AAAA,MACzB,SAAU,OAAO;AACf,eAAO,iCAAiC,MAAM;AAAA,MAChD;AAAA,IACA;AAAA;;;;;ACxQA,MAAM,cAAc,uBAAuB,6BAAoC;AAI/E,WAAW,gCAAgC;AAC3C,SAAS,uBAA0B,QAA6B,OAAmB;AACjF,QAAM,YACJ,OAAO,eAAe,eACrB,WAAmB,kCAAkC;AACxD,QAAM,QAAQ;AACd,QAAM,aAAa,CAAC,EAAE,SAAS,OAAO,UAAU,YAAY,aAAa;AACzE,QAAM,yBAAyB,CAAC,UAA4B;AAC1D,QAAI,CAAC,SAAS,OAAO,UAAU,UAAU;AACvC,aAAO;AAAA,IACT;AACA,UAAM,QAAQ;AACd,UAAM,WACJ,MAAM,eAAe,QACpB,OAAO,WAAW,eAChB,MAAc,OAAO,WAAW,MAAM;AAC3C,QAAI,YAAY,aAAa,OAAO;AAClC,aAAO,MAAM;AAAA,IACf;AACA,WAAO;AAAA,EACT;AACA,QAAM,kBAAkB,aACpB,uBAAwB,MAAc,OAAO,IAC7C;AAEJ,MAAI,WAAW;AACb,WAAO,aAAe,4CAA0B,SAAiB;AAAA,EACnE;AASA,SAAO,aAAe,4CAA0B,SAAiB;AACnE;AAMO,MAAM,0BAA0B,CACrC,YACA,UACA,WACW;AAEX,QAAM,QAAQ,YAAY,wBAAwB;AAElD,SAAO;AAAA,IACL,OAAO,CAAC,QAAgB;AAEtB,YAAM,GAAG;AAAA,IACX;AAAA,IACA,MACE,aAAa,WACT,CAAC,QAAgB,WAAW,KAAK,IAAI,MAAM,MAAM,GAAG,EAAE,IACtD,MAAM;AAAA,IAAC;AAAA,IACb,MACE,aAAa,UAAU,aAAa,UAAU,aAAa,UACvD,CAAC,QAAgB,WAAW,KAAK,IAAI,MAAM,MAAM,GAAG,EAAE,IACtD,MAAM;AAAA,IAAC;AAAA,IACb,OACE,aAAa,WACT,CAAC,QAAgB,WAAW,MAAM,IAAI,MAAM,MAAM,GAAG,EAAE,IACvD,MAAM;AAAA,IAAC;AAAA,EAAA;AAEjB;ACjEA,MAAM,uBAAuB;AAC7B,MAAM,2BAA2B;AACjC,MAAM,gCAAgB,IAAA;AAItB,MAAM,cAAc,CAAC,SAAiB,UACpC,WAAW,KAAK,IAAI,QAAQ,QAAQ,SAAS,KAAK;AAEpD,MAAM,qBAAqB,CACzB,OACA,KACA,UAEA,MAAM,QAAQ,qBAAqB,CAAC,QAAQ,QAAgB;AAC1D,QAAM,cAAc,IAAI,GAAG;AAC3B,MAAI,gBAAgB,QAAW;AAC7B,UAAM,IAAI,MAAM,wBAAwB,GAAG,QAAQ,KAAK,GAAG;AAAA,EAC7D;AACA,SAAO;AACT,CAAC;AAEH,MAAM,cAAc,CAClB,QACA,KACA,UACG,OAAO,IAAI,CAAC,UAAU,mBAAmB,OAAO,KAAK,KAAK,CAAC;AAEhE,MAAM,qBAAqB,CACzB,aACA,KACA,YACG;AACH,QAAM,WAAW,YAAY,aAAa,KAAK,aAAa;AAC5D,SAAO,SAAS,IAAI,CAAC,UAAU,YAAY,SAAS,KAAK,CAAC;AAC5D;AAEA,MAAM,qBAAqB,CACzB,SACA,gBACA,WACqB;AACrB,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EAAA,IACD;AACJ,SAAO;AAAA,IACL;AAAA,IACA,MAAM,eAAe;AAAA,IACrB;AAAA,IACA,GAAI,UAAU,SAAY,EAAE,MAAA,IAAU,CAAA;AAAA,IACtC,GAAI,WAAW,SAAY,EAAE,OAAA,IAAW,CAAA;AAAA,IACxC,GAAI,eAAe,SAAY,EAAE,WAAA,IAAe,CAAA;AAAA,IAChD,GAAI,YAAY,SAAY,EAAE,QAAA,IAAY,CAAA;AAAA,IAC1C,GAAI,WAAW,SAAY,EAAE,OAAA,IAAW,CAAA;AAAA,IACxC,GAAI,WAAW,SAAY,EAAE,OAAA,IAAW,CAAA;AAAA,IACxC,GAAI,aAAa,SAAY,EAAE,SAAA,IAAa,CAAA;AAAA,IAC5C,GAAI,oBAAoB,SAAY,EAAE,gBAAA,IAAoB,CAAA;AAAA,IAC1D,GAAI,aAAa,SAAY,EAAE,aAAa,CAAA;AAAA,EAAC;AAEjD;AAEA,MAAM,YAAY,CAAC,WAAmB,eAAuB;AAC3D,QAAM,MAAM,SAAS,WAAW,UAAU;AAC1C,MAAI,QAAQ,IAAI;AACd,WAAO;AAAA,EACT;AACA,SAAO,CAAC,IAAI,WAAW,IAAI,KAAK,CAAC,WAAW,GAAG;AACjD;AAEA,MAAM,sBAAsB,CAC1B,SACA,mBACG;;AACH,QAAM,UAAU,eAAe;AAC/B,QAAM,UAAU;AAAA,IACd,MAAM;AAAA,EAAA;AAER,QAAM,YAAY;AAAA,KAChB,aAAQ,WAAR,YAAkB;AAAA,IAClB;AAAA,IACA;AAAA,EAAA;AAEF,QAAM,gBAAgB;AAAA,KACpB,aAAQ,eAAR,YAAsB;AAAA,IACtB;AAAA,IACA;AAAA,EAAA;AAEF,QAAM,SAAS,YAAY,SAAS,SAAS;AAC7C,QAAM,aAAa,YAAY,SAAS,aAAa;AAErD,QAAM,cAAc;AAAA,IAClB,MAAM;AAAA,IACN,SAAS;AAAA,IACT,aAAa;AAAA,EAAA;AAGf,QAAM,+BAAe,IAAA;AACrB,QAAM,+BAAe,IAAA;AACrB,QAAM,sBAAgC,CAAA;AACtC,WAAS,IAAI,MAAM;AACnB,WAAS,IAAI,MAAM;AAEnB,QAAM,qBAAqB,CACzB,mBACA,eACG;AACH,QAAI,CAAC,qBAAqB,kBAAkB,WAAW,GAAG;AACxD;AAAA,IACF;AACA,UAAM,MAAM,aACR,EAAE,GAAG,aAAa,aAAa,eAC/B;AACJ,UAAM,eAAe,mBAAmB,mBAAmB,KAAK,OAAO;AACvE,eAAW,OAAO,cAAc;AAC9B,eAAS,IAAI,GAAG;AAChB,eAAS,IAAI,GAAG;AAChB,0BAAoB,KAAK,GAAG;AAAA,IAC9B;AAAA,EACF;AAEA,QAAM,sBACJ,aAAQ,WAAR,mBAAgB,iBAAgB,SAC5B,CAAC,aAAa,IACd,QAAQ,OAAO;AACrB,qBAAmB,mBAAmB,MAAS;AAC/C,aAAW,CAAC,YAAY,MAAM,KAAK,OAAO,QAAQ,QAAQ,OAAO,GAAG;AAClE,uBAAmB,OAAO,aAAa,UAAU;AAAA,EACnD;AAEA,SAAO;AAAA,IACL;AAAA,IACA,aAAa;AAAA,IACb,UAAU,CAAC,GAAG,QAAQ;AAAA,IACtB,UAAU,CAAC,GAAG,QAAQ;AAAA,EAAA;AAE1B;AAEA,MAAM,iBAAiB,OACrB,QACA,SACA,mBACG;;AACH,QAAM,SAAS;AAAA,IACb,eAAe;AAAA,KACf,oBAAe,aAAf,YAA2B;AAAA,IAC3B;AAAA,EAAA;AAEF,QAAM,eAAe,mBAAmB,SAAS,gBAAgB,MAAM;AAEvE,QAAM,eAAe,oBAAoB,SAAS,cAAc;AAChE,SAAO,MAAM,eAAe,eAAe,IAAI,EAAE;AACjD,SAAO,MAAM,iBAAiB,aAAa,MAAM,EAAE;AACnD,SAAO;AAAA,IACL,sBACE,aAAa,YAAY,SAAS,IAC9B,aAAa,YAAY,KAAK,IAAI,IAClC,QACN;AAAA,EAAA;AAEF,SAAO,MAAM,mBAAmB,aAAa,SAAS,KAAK,IAAI,CAAC,EAAE;AAClE,SAAO,MAAM,mBAAmB,aAAa,SAAS,KAAK,IAAI,CAAC,EAAE;AAClE,MAAI,aAAa,SAAS,SAAS,GAAG;AACpC,WAAO,QAAQ,IAAI,aAAa,QAAQ;AAAA,EAC1C;AAEA,MAAI,aAAa,QAAQ,QAAA;AACzB,QAAM,aAAa,OAAO,iBAA0B;AAClD,iBAAa,WAAW,KAAK,YAAY;AACvC,UAAI;AACF,cAAM,UAAU,YAAY;AAC5B,YAAI,cAAc;AAChB,iBAAO,GAAG,KAAK,EAAE,MAAM,eAAe;AAAA,QACxC;AAAA,MACF,SAAS,OAAO;AACd,cAAM,UACJ,iBAAiB,QAAQ,MAAM,UAAU;AAC3C,eAAO,MAAM,sBAAsB,OAAO,EAAE;AAAA,MAC9C;AAAA,IACF,CAAC;AACD,WAAO;AAAA,EACT;AAEA,QAAM,eAAe,OAAO,cAAsB;AAChD,UAAM,eAAe,WAAW,SAAS,IACrC,YACA,QAAQ,eAAe,MAAM,SAAS;AAC1C,QAAI,CAAC,aAAa,SAAS,KAAK,CAAC,QAAQ,UAAU,KAAK,YAAY,CAAC,GAAG;AACtE;AAAA,IACF;AACA,UAAM,WAAW,IAAI;AAAA,EACvB;AAEA,SAAO,QAAQ,GAAG,OAAO,YAAY;AACrC,SAAO,QAAQ,GAAG,UAAU,YAAY;AACxC,SAAO,QAAQ,GAAG,UAAU,YAAY;AAExC,QAAM,WAAW,KAAK;AACxB;AAaA,MAAM,WAAW,CAAC,YAA4C;AAC5D,MAAI;AACJ,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,eAAe,QAAQ;AACrB,uBAAiB;AAAA,IACnB;AAAA,IACA,MAAM,aAAa;;AACjB,UAAI,CAAC,gBAAgB;AACnB,cAAM,IAAI,MAAM,+BAA+B;AAAA,MACjD;AACA,UAAI,eAAe,YAAY,SAAS;AACtC;AAAA,MACF;AACA,YAAM,SAAS;AAAA,QACb,eAAe;AAAA,SACf,oBAAe,aAAf,YAA2B;AAAA,QAC3B;AAAA,MAAA;AAEF,YAAM,eAAe,mBAAmB,SAAS,gBAAgB,MAAM;AACvE,YAAM,WAAW,eAAe;AAChC,YAAM,WAAW,UAAU,IAAI,QAAQ;AACvC,UAAI,UAAU;AACZ,cAAM;AACN;AAAA,MACF;AACA,YAAM,OAAO,YAAY;AACvB,YAAI;AACF,gBAAM,UAAU,YAAY;AAAA,QAC9B,UAAA;AACE,oBAAU,OAAO,QAAQ;AAAA,QAC3B;AAAA,MACF,GAAA;AACA,gBAAU,IAAI,UAAU,GAAG;AAC3B,YAAM;AAAA,IACR;AAAA,IACA,MAAM,gBAAgB,QAAQ;AAC5B,UAAI,CAAC,gBAAgB;AACnB,cAAM,IAAI,MAAM,+BAA+B;AAAA,MACjD;AACA,UAAI,eAAe,YAAY,SAAS;AACtC;AAAA,MACF;AACA,YAAM,eAAe,QAAQ,SAAS,cAAc;AAAA,IACtD;AAAA,EAAA;AAEJ;","x_google_ignoreList":[0,1,2]}
|
package/package.json
CHANGED
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
{
|
|
2
2
|
"git": {
|
|
3
3
|
"tags": [
|
|
4
|
-
"0.
|
|
4
|
+
"0.4.0"
|
|
5
5
|
],
|
|
6
6
|
"branches": [
|
|
7
7
|
"main"
|
|
8
8
|
],
|
|
9
|
-
"version": "0.
|
|
9
|
+
"version": "0.4.0",
|
|
10
10
|
"commit": {
|
|
11
|
-
"hash": "
|
|
12
|
-
"shortHash": "
|
|
13
|
-
"date": "2026-02-
|
|
11
|
+
"hash": "cd0d8e53bf52b98940dd50343a9d3a39200306bd",
|
|
12
|
+
"shortHash": "cd0d8e5",
|
|
13
|
+
"date": "2026-02-20T14:55:40+09:00",
|
|
14
14
|
"message": "Merge branch 'develop'"
|
|
15
15
|
}
|
|
16
16
|
},
|
|
17
|
-
"version": "0.
|
|
17
|
+
"version": "0.4.0",
|
|
18
18
|
"name": "emsdk-env",
|
|
19
19
|
"description": "Emscripten environment builder",
|
|
20
20
|
"author": "Kouji Matsui (@kekyo@mi.kekyo.net)",
|
|
@@ -74,5 +74,5 @@
|
|
|
74
74
|
"vite-plugin-dts": ">=4.5.0",
|
|
75
75
|
"vitest": ">=1.0.0"
|
|
76
76
|
},
|
|
77
|
-
"buildDate": "2026-02-
|
|
77
|
+
"buildDate": "2026-02-20T15:00:59+09:00"
|
|
78
78
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"build-oenTJc-4.cjs","sources":["../node_modules/async-primitives/dist/index.mjs","../src/commands.ts","../src/fs-utils.ts","../src/emsdk.ts","../src/env.ts","../src/logger.ts","../src/build.ts"],"sourcesContent":["/*!\n * name: async-primitives\n * version: 1.5.0\n * description: A collection of primitive functions for asynchronous operations\n * author: Kouji Matsui (@kekyo@mi.kekyo.net)\n * license: MIT\n * repository.url: https://github.com/kekyo/async-primitives.git\n * git.commit.hash: cd35465b7e9b9945049186e7eaeecc0bfba65766\n */\nconst __NOOP_HANDLER = () => {\n};\nconst __NOOP_RELEASABLE = {\n release: __NOOP_HANDLER,\n [Symbol.dispose]: __NOOP_HANDLER\n};\nconst toAbortError = (reason) => {\n if (reason instanceof Error) {\n return reason;\n }\n if (typeof reason === \"string\") {\n return new Error(reason);\n }\n return new Error(\"Operation aborted\");\n};\nconst onAbort = (signal, callback) => {\n if (!signal) {\n return __NOOP_RELEASABLE;\n }\n if (signal.aborted) {\n try {\n callback(toAbortError(signal.reason));\n } catch (error) {\n console.warn(\"AbortHook callback error: \", error);\n }\n return __NOOP_RELEASABLE;\n }\n let abortHandler;\n abortHandler = () => {\n if (abortHandler) {\n const reason = signal.reason;\n signal.removeEventListener(\"abort\", abortHandler);\n abortHandler = void 0;\n try {\n callback(toAbortError(reason));\n } catch (error) {\n console.warn(\"AbortHook callback error: \", error);\n }\n }\n };\n const release = () => {\n if (abortHandler) {\n signal.removeEventListener(\"abort\", abortHandler);\n abortHandler = void 0;\n }\n };\n signal.addEventListener(\"abort\", abortHandler, { once: true });\n const handle = {\n release,\n [Symbol.dispose]: release\n };\n return handle;\n};\nconst delay = (msec, signal) => {\n if (signal) {\n if (signal.aborted) {\n throw new Error(\"Delay was aborted\");\n }\n return new Promise((resolve, reject) => {\n const abortHandle = onAbort(signal, () => {\n clearTimeout(timeoutId);\n reject(new Error(\"Delay was aborted\"));\n });\n const timeoutId = setTimeout(() => {\n abortHandle.release();\n resolve();\n }, msec);\n });\n } else {\n return new Promise((resolve) => {\n setTimeout(resolve, msec);\n });\n }\n};\nconst defer = (fn) => {\n if (typeof setImmediate === \"function\") {\n setImmediate(fn);\n } else {\n setTimeout(fn, 0);\n }\n};\nconst ABORTED_ERROR$2 = () => new Error(\"Lock acquisition was aborted\");\nconst createLockHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nconst createMutex = (maxConsecutiveCalls = 20) => {\n let isLocked = false;\n const queue = [];\n let count = 0;\n const processQueue = () => {\n var _a;\n if (isLocked || queue.length === 0) {\n return;\n }\n const item = queue.shift();\n if ((_a = item.signal) == null ? void 0 : _a.aborted) {\n item.reject(ABORTED_ERROR$2());\n scheduleNextProcess();\n return;\n }\n isLocked = true;\n const lockHandle = createLockHandle(releaseLock);\n item.resolve(lockHandle);\n };\n const scheduleNextProcess = () => {\n count++;\n if (count >= maxConsecutiveCalls) {\n count = 0;\n defer(processQueue);\n } else {\n processQueue();\n }\n };\n const releaseLock = () => {\n if (!isLocked) {\n return;\n }\n isLocked = false;\n scheduleNextProcess();\n };\n const removeFromQueue = (item) => {\n const index = queue.indexOf(item);\n if (index !== -1) {\n queue.splice(index, 1);\n }\n };\n const lock = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR$2();\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromQueue(queueItem);\n reject(ABORTED_ERROR$2());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n queue.push(queueItem);\n processQueue();\n });\n } else {\n return new Promise((resolve, reject) => {\n queue.push({\n resolve,\n reject\n });\n processQueue();\n });\n }\n };\n const result = {\n lock,\n waiter: {\n wait: lock\n },\n get isLocked() {\n return isLocked;\n },\n get pendingCount() {\n return queue.length;\n }\n };\n return result;\n};\nconst createDeferred = (signal) => {\n let resolve;\n let reject;\n const promise = new Promise((res, rej) => {\n resolve = res;\n reject = rej;\n });\n const disposer = onAbort(signal, () => {\n const _reject = reject;\n if (_reject) {\n resolve = void 0;\n reject = void 0;\n _reject(new Error(\"Deferred aborted\"));\n }\n });\n return {\n // The promise that resolves to the result\n promise,\n // Resolve the promise with a result\n resolve: (value) => {\n const _resolve = resolve;\n if (_resolve) {\n resolve = void 0;\n reject = void 0;\n disposer.release();\n _resolve(value);\n }\n },\n // Reject the promise with an error\n reject: (error) => {\n const _reject = reject;\n if (_reject) {\n resolve = void 0;\n reject = void 0;\n disposer.release();\n _reject(error);\n }\n }\n };\n};\nconst __NOOP_DUMMY_HANDLE = {\n get isActive() {\n return false;\n },\n release: __NOOP_HANDLER,\n [Symbol.dispose]: __NOOP_HANDLER\n};\nconst createConditional = () => {\n const waiters = [];\n const trigger = () => {\n if (waiters.length >= 1) {\n waiters.shift().resolve();\n }\n };\n const wait = async (signal) => {\n if (signal == null ? void 0 : signal.aborted) {\n throw new Error(\"Conditional aborted\");\n }\n const waiter = createDeferred();\n waiters.push(waiter);\n const disposer = onAbort(signal, () => {\n waiters.splice(waiters.indexOf(waiter), 1);\n waiter.reject(new Error(\"Conditional aborted\"));\n });\n try {\n await waiter.promise;\n } finally {\n disposer.release();\n }\n return __NOOP_DUMMY_HANDLE;\n };\n const result = {\n trigger,\n wait,\n waiter: {\n wait\n }\n };\n return result;\n};\nconst createManuallyConditional = (initialState) => {\n const waiters = [];\n let raised = initialState != null ? initialState : false;\n const trigger = () => {\n raised = false;\n const waiter = waiters.shift();\n if (waiter) {\n waiter.resolve();\n raised = false;\n }\n };\n const raise = () => {\n while (waiters.length >= 1) {\n raised = true;\n waiters.shift().resolve();\n }\n raised = true;\n };\n const drop = () => {\n raised = false;\n };\n const wait = async (signal) => {\n if (raised) {\n return __NOOP_DUMMY_HANDLE;\n }\n if (signal == null ? void 0 : signal.aborted) {\n throw new Error(\"Conditional aborted\");\n }\n const waiter = createDeferred();\n waiters.push(waiter);\n const disposer = onAbort(signal, () => {\n waiters.splice(waiters.indexOf(waiter), 1);\n waiter.reject(new Error(\"Conditional aborted\"));\n });\n try {\n await waiter.promise;\n } finally {\n disposer.release();\n }\n return __NOOP_DUMMY_HANDLE;\n };\n const result = {\n trigger,\n raise,\n drop,\n wait,\n waiter: {\n wait\n }\n };\n return result;\n};\nconst createDeferredGenerator = (options) => {\n const maxItemReserved = options == null ? void 0 : options.maxItemReserved;\n const signal = options == null ? void 0 : options.signal;\n const queue = [];\n const arrived = createManuallyConditional();\n const canReserve = maxItemReserved ? createManuallyConditional(true) : void 0;\n const generator = (async function* () {\n while (true) {\n while (true) {\n const item = queue.shift();\n if (maxItemReserved && queue.length === maxItemReserved - 1) {\n canReserve.raise();\n }\n if (!item) {\n break;\n }\n switch (item.kind) {\n // Yield return a value\n case \"value\":\n yield item.value;\n break;\n // Completed, exit the generator\n case \"completed\":\n return;\n // Error, throw an error\n case \"error\":\n throw item.error;\n }\n if (signal == null ? void 0 : signal.aborted) {\n throw new Error(\"Deferred generator aborted\");\n }\n }\n arrived.drop();\n try {\n await arrived.wait(signal);\n } catch (error) {\n if (error instanceof Error && error.message === \"Conditional aborted\") {\n error.message = \"Deferred generator aborted\";\n }\n throw error;\n }\n }\n })();\n const enqueue = async (item, signal2) => {\n while (true) {\n if (!maxItemReserved || queue.length < maxItemReserved) {\n const remains = queue.push(item);\n if (remains === 1) {\n arrived.raise();\n }\n if (remains === maxItemReserved) {\n canReserve.drop();\n }\n break;\n }\n try {\n await canReserve.wait(signal2);\n } catch (error) {\n if (error instanceof Error && error.message === \"Conditional aborted\") {\n error.message = \"Deferred generator aborted\";\n }\n throw error;\n }\n }\n };\n return {\n // The async generator that yields values\n generator,\n // Yield a value to the generator\n yield: (value, signal2) => enqueue({ kind: \"value\", value }, signal2),\n // Complete the generator (equivalent to return)\n return: (signal2) => enqueue({ kind: \"completed\" }, signal2),\n // Throw an error to the generator\n throw: (error, signal2) => enqueue({ kind: \"error\", error }, signal2)\n };\n};\nconst createLogicalContext = (id) => {\n return { id, data: /* @__PURE__ */ new Map() };\n};\nlet currentLogicalContext = createLogicalContext(Symbol(\"[root]\"));\nconst setCurrentLogicalContext = (context) => {\n currentLogicalContext = context;\n};\nconst trampoline = (adjustment, callback, thisArg, ...args) => {\n const previousLogicalContext = currentLogicalContext;\n currentLogicalContext = adjustment.contextToUse;\n try {\n return callback.call(thisArg, ...args);\n } finally {\n adjustment.contextAfter = currentLogicalContext;\n currentLogicalContext = previousLogicalContext;\n }\n};\nlet isPrepared = false;\nconst prepare = () => {\n if (isPrepared) {\n return;\n }\n isPrepared = true;\n if (typeof globalThis.setTimeout !== \"undefined\") {\n const __setTimeout = globalThis.setTimeout;\n globalThis.setTimeout = ((handler, timeout, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __setTimeout(\n (...args2) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, handler, void 0, ...args2);\n },\n timeout,\n ...args\n );\n });\n }\n if (typeof globalThis.setInterval !== \"undefined\") {\n const __setInterval = globalThis.setInterval;\n globalThis.setInterval = ((handler, timeout, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __setInterval(\n (...args2) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, handler, void 0, ...args2);\n },\n timeout,\n ...args\n );\n });\n }\n if (typeof globalThis.queueMicrotask !== \"undefined\") {\n const __queueMicrotask = globalThis.queueMicrotask;\n globalThis.queueMicrotask = (callback) => {\n const capturedLogicalContext = currentLogicalContext;\n return __queueMicrotask(() => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, callback, void 0);\n });\n };\n }\n if (typeof globalThis.setImmediate !== \"undefined\") {\n const __setImmediate = globalThis.setImmediate;\n globalThis.setImmediate = ((callback, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __setImmediate(\n (...callbackArgs) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, callback, void 0, ...callbackArgs);\n },\n ...args\n );\n });\n }\n if (typeof process !== \"undefined\" && process.nextTick) {\n const __nextTick = process.nextTick;\n process.nextTick = (callback, ...args) => {\n const capturedLogicalContext = currentLogicalContext;\n return __nextTick(() => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n trampoline(adjustment, callback, void 0, ...args);\n });\n };\n }\n if (typeof Promise !== \"undefined\") {\n const __then = Promise.prototype.then;\n const __catch = Promise.prototype.catch;\n const __finally = Promise.prototype.finally;\n Promise.prototype.then = function(onFulfilled, onRejected) {\n const capturedLogicalContext = currentLogicalContext;\n const resultPromise = __then.call(\n this,\n onFulfilled ? (value) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onFulfilled, void 0, value);\n } : void 0,\n onRejected ? (reason) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onRejected, void 0, reason);\n } : void 0\n );\n return resultPromise;\n };\n Promise.prototype.catch = function(onRejected) {\n const capturedLogicalContext = currentLogicalContext;\n const resultPromise = __catch.call(\n this,\n onRejected ? (reason) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onRejected, void 0, reason);\n } : void 0\n );\n return resultPromise;\n };\n Promise.prototype.finally = function(onFinally) {\n const capturedLogicalContext = currentLogicalContext;\n const resultPromise = __finally.call(\n this,\n onFinally ? () => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, onFinally, void 0);\n } : void 0\n );\n return resultPromise;\n };\n }\n if (typeof EventTarget !== \"undefined\" && EventTarget.prototype && EventTarget.prototype.addEventListener) {\n const __eventTargetAddEventListener = EventTarget.prototype.addEventListener;\n EventTarget.prototype.addEventListener = function(type, listener, options) {\n if (listener === null || listener === void 0) {\n return __eventTargetAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n }\n if (typeof listener === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return __eventTargetAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return __eventTargetAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n }\n return __eventTargetAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n };\n }\n if (typeof Element !== \"undefined\" && Element.prototype && Element.prototype.addEventListener) {\n const __elementAddEventListener = Element.prototype.addEventListener;\n Element.prototype.addEventListener = function(type, listener, options) {\n if (listener === null || listener === void 0) {\n return __elementAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n }\n if (typeof listener === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return __elementAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return __elementAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n }\n return __elementAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n };\n }\n if (typeof globalThis.requestAnimationFrame !== \"undefined\") {\n const __requestAnimationFrame = globalThis.requestAnimationFrame;\n globalThis.requestAnimationFrame = (callback) => {\n const capturedLogicalContext = currentLogicalContext;\n return __requestAnimationFrame((time) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, callback, void 0, time);\n });\n };\n }\n if (typeof globalThis.XMLHttpRequest !== \"undefined\") {\n const __XMLHttpRequest = globalThis.XMLHttpRequest;\n globalThis.XMLHttpRequest = class extends __XMLHttpRequest {\n constructor() {\n super();\n this._userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\n \"onreadystatechange\",\n \"onloadstart\",\n \"onprogress\",\n \"onabort\",\n \"onerror\",\n \"onload\",\n \"ontimeout\",\n \"onloadend\"\n ];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(this, prop, {\n get: () => this._userHandlers.get(prop) || null,\n set: (newHandler) => {\n this._userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, wrappedHandler);\n } else {\n this[`_${prop}`] = wrappedHandler;\n }\n } else {\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, null);\n } else {\n this[`_${prop}`] = null;\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n }\n addEventListener(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return super.addEventListener(type, listener, options);\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return super.addEventListener(type, wrappedListener, options);\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return super.addEventListener(type, wrappedListener, options);\n }\n return super.addEventListener(type, listener, options);\n }\n };\n }\n if (typeof globalThis.WebSocket !== \"undefined\") {\n const __WebSocket = globalThis.WebSocket;\n globalThis.WebSocket = class extends __WebSocket {\n constructor(url, protocols) {\n super(url, protocols);\n this._userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\n \"onopen\",\n \"onmessage\",\n \"onerror\",\n \"onclose\"\n ];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(this, prop, {\n get: () => this._userHandlers.get(prop) || null,\n set: (newHandler) => {\n this._userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, wrappedHandler);\n } else {\n this[`_${prop}`] = wrappedHandler;\n }\n } else {\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, null);\n } else {\n this[`_${prop}`] = null;\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n }\n addEventListener(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return super.addEventListener(type, listener, options);\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return super.addEventListener(type, wrappedListener, options);\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return super.addEventListener(type, wrappedListener, options);\n }\n return super.addEventListener(type, listener, options);\n }\n };\n }\n if (typeof globalThis.MutationObserver !== \"undefined\") {\n const __MutationObserver = globalThis.MutationObserver;\n globalThis.MutationObserver = class extends __MutationObserver {\n constructor(callback) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedCallback = (mutations, observer) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(\n adjustment,\n callback,\n void 0,\n mutations,\n observer\n );\n };\n super(wrappedCallback);\n }\n };\n }\n if (typeof globalThis.ResizeObserver !== \"undefined\") {\n const __ResizeObserver = globalThis.ResizeObserver;\n globalThis.ResizeObserver = class extends __ResizeObserver {\n constructor(callback) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedCallback = (entries, observer) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, callback, void 0, entries, observer);\n };\n super(wrappedCallback);\n }\n };\n }\n if (typeof globalThis.IntersectionObserver !== \"undefined\") {\n const __IntersectionObserver = globalThis.IntersectionObserver;\n globalThis.IntersectionObserver = class extends __IntersectionObserver {\n constructor(callback, options) {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedCallback = (entries, observer) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, callback, void 0, entries, observer);\n };\n super(wrappedCallback, options);\n }\n };\n }\n if (typeof globalThis.Worker !== \"undefined\") {\n const __Worker = globalThis.Worker;\n globalThis.Worker = class extends __Worker {\n constructor(scriptURL, options) {\n super(scriptURL, options);\n this._userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\n \"onmessage\",\n \"onmessageerror\",\n \"onerror\"\n ];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(this, prop, {\n get: () => this._userHandlers.get(prop) || null,\n set: (newHandler) => {\n this._userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, wrappedHandler);\n } else {\n this[`_${prop}`] = wrappedHandler;\n }\n } else {\n const parentProto = Object.getPrototypeOf(\n Object.getPrototypeOf(this)\n );\n const descriptor = Object.getOwnPropertyDescriptor(\n parentProto,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(this, null);\n } else {\n this[`_${prop}`] = null;\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n }\n addEventListener(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return super.addEventListener(type, listener, options);\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return super.addEventListener(type, wrappedListener, options);\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return super.addEventListener(type, wrappedListener, options);\n }\n return super.addEventListener(type, listener, options);\n }\n };\n }\n if (typeof globalThis.MessagePort !== \"undefined\") {\n const __MessagePort = globalThis.MessagePort;\n const createMessagePortWrapper = (originalPort) => {\n const _userHandlers = /* @__PURE__ */ new Map();\n const eventHandlerProperties = [\"onmessage\", \"onmessageerror\"];\n eventHandlerProperties.forEach((prop) => {\n Object.defineProperty(originalPort, prop, {\n get: () => _userHandlers.get(prop) || null,\n set: (newHandler) => {\n _userHandlers.set(prop, newHandler);\n if (newHandler && typeof newHandler === \"function\") {\n const capturedLogicalContext = currentLogicalContext;\n const wrappedHandler = function(event) {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, newHandler, this, event);\n };\n const descriptor = Object.getOwnPropertyDescriptor(\n __MessagePort.prototype,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(originalPort, wrappedHandler);\n }\n } else {\n const descriptor = Object.getOwnPropertyDescriptor(\n __MessagePort.prototype,\n prop\n );\n if (descriptor && descriptor.set) {\n descriptor.set.call(originalPort, null);\n }\n }\n },\n configurable: true,\n enumerable: true\n });\n });\n const originalAddEventListener = originalPort.addEventListener;\n originalPort.addEventListener = function(type, listener, options) {\n const capturedLogicalContext = currentLogicalContext;\n if (!listener) {\n return originalAddEventListener.call(\n this,\n type,\n listener,\n options\n );\n }\n if (typeof listener === \"function\") {\n const wrappedListener = (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, listener, event.currentTarget, event);\n };\n return originalAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n } else if (typeof listener === \"object\" && \"handleEvent\" in listener) {\n const wrappedListener = {\n handleEvent: (event) => {\n const adjustment = {\n contextToUse: capturedLogicalContext\n };\n return trampoline(adjustment, () => listener.handleEvent(event));\n }\n };\n return originalAddEventListener.call(\n this,\n type,\n wrappedListener,\n options\n );\n }\n return originalAddEventListener.call(this, type, listener, options);\n };\n return originalPort;\n };\n if (typeof globalThis.MessageChannel !== \"undefined\") {\n const __MessageChannel = globalThis.MessageChannel;\n globalThis.MessageChannel = class extends __MessageChannel {\n constructor() {\n super();\n createMessagePortWrapper(this.port1);\n createMessagePortWrapper(this.port2);\n }\n };\n }\n }\n};\nconst setLogicalContextValue = (key, value) => {\n prepare();\n if (value !== void 0) {\n currentLogicalContext.data.set(key, value);\n } else {\n currentLogicalContext.data.delete(key);\n }\n};\nconst getLogicalContextValue = (key) => {\n prepare();\n return currentLogicalContext.data.get(key);\n};\nconst runOnNewLogicalContext = (prefix, handler) => {\n const previousLogicalContext = currentLogicalContext;\n setCurrentLogicalContext(\n createLogicalContext(Symbol(`${prefix}-${crypto.randomUUID()}`))\n );\n try {\n return handler();\n } finally {\n setCurrentLogicalContext(previousLogicalContext);\n }\n};\nconst getCurrentLogicalContextId = () => {\n prepare();\n return currentLogicalContext.id;\n};\nconst createAsyncLocal = () => {\n const key = Symbol(`async-local-${crypto.randomUUID()}`);\n return {\n setValue: (value) => {\n setLogicalContextValue(key, value);\n },\n getValue: () => {\n return getLogicalContextValue(key);\n }\n };\n};\nconst ABORTED_ERROR$1 = () => new Error(\"Semaphore acquisition was aborted\");\nconst INVALID_COUNT_ERROR = () => new Error(\"Semaphore count must be greater than 0\");\nconst createSemaphoreHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nconst createSemaphore = (count, maxConsecutiveCalls = 20) => {\n if (count < 1) {\n throw INVALID_COUNT_ERROR();\n }\n let availableCount = count;\n const queue = [];\n let consecutiveCallCount = 0;\n const processQueue = () => {\n var _a;\n while (availableCount > 0 && queue.length > 0) {\n const item = queue.shift();\n if ((_a = item.signal) == null ? void 0 : _a.aborted) {\n item.reject(ABORTED_ERROR$1());\n continue;\n }\n availableCount--;\n const semaphoreHandle = createSemaphoreHandle(releaseSemaphore);\n item.resolve(semaphoreHandle);\n }\n };\n const scheduleNextProcess = () => {\n consecutiveCallCount++;\n if (consecutiveCallCount >= maxConsecutiveCalls) {\n consecutiveCallCount = 0;\n defer(processQueue);\n } else {\n processQueue();\n }\n };\n const releaseSemaphore = () => {\n availableCount++;\n scheduleNextProcess();\n };\n const removeFromQueue = (item) => {\n const index = queue.indexOf(item);\n if (index !== -1) {\n queue.splice(index, 1);\n }\n };\n const acquire = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR$1();\n }\n if (availableCount > 0) {\n availableCount--;\n return createSemaphoreHandle(releaseSemaphore);\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromQueue(queueItem);\n reject(ABORTED_ERROR$1());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n queue.push(queueItem);\n processQueue();\n });\n } else {\n if (availableCount > 0) {\n availableCount--;\n return createSemaphoreHandle(releaseSemaphore);\n }\n return new Promise((resolve, reject) => {\n queue.push({\n resolve,\n reject\n });\n processQueue();\n });\n }\n };\n const result = {\n acquire,\n waiter: {\n wait: acquire\n },\n get availableCount() {\n return availableCount;\n },\n get pendingCount() {\n return queue.length;\n }\n };\n return result;\n};\nconst ABORTED_ERROR = () => new Error(\"Lock acquisition was aborted\");\nconst createReadLockHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nconst createWriteLockHandle = (releaseCallback) => {\n let isActive = true;\n const release = () => {\n if (!isActive) {\n return;\n }\n isActive = false;\n releaseCallback();\n };\n return {\n get isActive() {\n return isActive;\n },\n release,\n [Symbol.dispose]: release\n };\n};\nfunction createReaderWriterLock(optionsOrMaxCalls) {\n var _a, _b;\n let policy = \"write-preferring\";\n let maxConsecutiveCalls = 20;\n if (typeof optionsOrMaxCalls === \"number\") {\n maxConsecutiveCalls = optionsOrMaxCalls;\n } else if (optionsOrMaxCalls) {\n policy = (_a = optionsOrMaxCalls.policy) != null ? _a : \"write-preferring\";\n maxConsecutiveCalls = (_b = optionsOrMaxCalls.maxConsecutiveCalls) != null ? _b : 20;\n }\n let currentReaders = 0;\n let hasWriter = false;\n const readQueue = [];\n const writeQueue = [];\n let consecutiveCallCount = 0;\n const processQueues = () => {\n var _a2, _b2, _c, _d;\n if (policy === \"write-preferring\") {\n if (!hasWriter && currentReaders === 0 && writeQueue.length > 0) {\n const item = writeQueue.shift();\n if ((_a2 = item.signal) == null ? void 0 : _a2.aborted) {\n item.reject(ABORTED_ERROR());\n scheduleNextProcess();\n return;\n }\n hasWriter = true;\n const writeLockHandle = createWriteLockHandle(releaseWriteLock);\n item.resolve(writeLockHandle);\n } else if (!hasWriter && writeQueue.length === 0 && readQueue.length > 0) {\n const readersToProcess = [];\n while (readQueue.length > 0) {\n const item = readQueue.shift();\n if ((_b2 = item.signal) == null ? void 0 : _b2.aborted) {\n item.reject(ABORTED_ERROR());\n } else {\n readersToProcess.push(item);\n }\n }\n for (const item of readersToProcess) {\n currentReaders++;\n const readLockHandle = createReadLockHandle(releaseReadLock);\n item.resolve(readLockHandle);\n }\n }\n } else {\n if (!hasWriter && readQueue.length > 0) {\n const readersToProcess = [];\n while (readQueue.length > 0) {\n const item = readQueue.shift();\n if ((_c = item.signal) == null ? void 0 : _c.aborted) {\n item.reject(ABORTED_ERROR());\n } else {\n readersToProcess.push(item);\n }\n }\n for (const item of readersToProcess) {\n currentReaders++;\n const readLockHandle = createReadLockHandle(releaseReadLock);\n item.resolve(readLockHandle);\n }\n } else if (!hasWriter && currentReaders === 0 && writeQueue.length > 0) {\n const item = writeQueue.shift();\n if ((_d = item.signal) == null ? void 0 : _d.aborted) {\n item.reject(ABORTED_ERROR());\n scheduleNextProcess();\n return;\n }\n hasWriter = true;\n const writeLockHandle = createWriteLockHandle(releaseWriteLock);\n item.resolve(writeLockHandle);\n }\n }\n };\n const scheduleNextProcess = () => {\n consecutiveCallCount++;\n if (consecutiveCallCount >= maxConsecutiveCalls) {\n consecutiveCallCount = 0;\n defer(processQueues);\n } else {\n processQueues();\n }\n };\n const releaseReadLock = () => {\n if (currentReaders > 0) {\n currentReaders--;\n if (currentReaders === 0) {\n scheduleNextProcess();\n }\n }\n };\n const releaseWriteLock = () => {\n if (hasWriter) {\n hasWriter = false;\n scheduleNextProcess();\n }\n };\n const removeFromReadQueue = (item) => {\n const index = readQueue.indexOf(item);\n if (index !== -1) {\n readQueue.splice(index, 1);\n }\n };\n const removeFromWriteQueue = (item) => {\n const index = writeQueue.indexOf(item);\n if (index !== -1) {\n writeQueue.splice(index, 1);\n }\n };\n const readLock = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR();\n }\n const canAcquireImmediately = policy === \"read-preferring\" ? !hasWriter : !hasWriter && writeQueue.length === 0;\n if (canAcquireImmediately) {\n currentReaders++;\n return createReadLockHandle(releaseReadLock);\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromReadQueue(queueItem);\n reject(ABORTED_ERROR());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n readQueue.push(queueItem);\n processQueues();\n });\n } else {\n const canAcquireImmediately = policy === \"read-preferring\" ? !hasWriter : !hasWriter && writeQueue.length === 0;\n if (canAcquireImmediately) {\n currentReaders++;\n return createReadLockHandle(releaseReadLock);\n }\n return new Promise((resolve, reject) => {\n readQueue.push({\n resolve,\n reject\n });\n processQueues();\n });\n }\n };\n const writeLock = async (signal) => {\n if (signal) {\n if (signal.aborted) {\n throw ABORTED_ERROR();\n }\n if (!hasWriter && currentReaders === 0) {\n hasWriter = true;\n return createWriteLockHandle(releaseWriteLock);\n }\n return new Promise((resolve, reject) => {\n const queueItem = {\n resolve: void 0,\n reject: void 0,\n signal\n };\n const abortHandle = onAbort(signal, () => {\n removeFromWriteQueue(queueItem);\n reject(ABORTED_ERROR());\n });\n queueItem.resolve = (handle) => {\n abortHandle.release();\n resolve(handle);\n };\n queueItem.reject = (error) => {\n abortHandle.release();\n reject(error);\n };\n writeQueue.push(queueItem);\n processQueues();\n });\n } else {\n if (!hasWriter && currentReaders === 0) {\n hasWriter = true;\n return createWriteLockHandle(releaseWriteLock);\n }\n return new Promise((resolve, reject) => {\n writeQueue.push({\n resolve,\n reject\n });\n processQueues();\n });\n }\n };\n const readWaiter = {\n wait: readLock\n };\n const writeWaiter = {\n wait: writeLock\n };\n return {\n readLock,\n writeLock,\n readWaiter,\n writeWaiter,\n get currentReaders() {\n return currentReaders;\n },\n get hasWriter() {\n return hasWriter;\n },\n get pendingReadersCount() {\n return readQueue.length;\n },\n get pendingWritersCount() {\n return writeQueue.length;\n }\n };\n}\nexport {\n createAsyncLocal,\n createMutex as createAsyncLock,\n createConditional,\n createDeferred,\n createDeferredGenerator,\n createManuallyConditional,\n createManuallyConditional as createManuallySignal,\n createMutex,\n createReaderWriterLock,\n createSemaphore,\n createConditional as createSignal,\n defer,\n delay,\n getCurrentLogicalContextId,\n getLogicalContextValue,\n onAbort,\n runOnNewLogicalContext,\n setLogicalContextValue\n};\n//# sourceMappingURL=index.mjs.map\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport { spawn } from 'child_process';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nconst createAbortError = () => {\n const error = new Error('The operation was aborted.');\n error.name = 'AbortError';\n return error;\n};\n\nexport const runCommand = async (\n command: string,\n args: string[],\n cwd: string,\n signal: AbortSignal | undefined\n) => {\n signal?.throwIfAborted();\n return new Promise<void>((resolvePromise, rejectPromise) => {\n const child = spawn(command, args, {\n cwd,\n stdio: 'inherit',\n });\n let settled = false;\n const onAbort = () => {\n if (settled) {\n return;\n }\n settled = true;\n child.kill();\n rejectPromise(createAbortError());\n };\n signal?.addEventListener('abort', onAbort, { once: true });\n const cleanup = () => {\n signal?.removeEventListener('abort', onAbort);\n };\n child.once('error', (error) => {\n if (settled) {\n return;\n }\n settled = true;\n cleanup();\n rejectPromise(error);\n });\n child.once('close', (code) => {\n if (settled) {\n return;\n }\n settled = true;\n cleanup();\n if (code === 0) {\n resolvePromise();\n return;\n }\n rejectPromise(\n new Error(\n `Command failed: ${command} ${args.join(' ')} (exit code ${code})`\n )\n );\n });\n });\n};\n\nexport const runCommandWithEnv = async (\n command: string,\n args: string[],\n cwd: string,\n env: NodeJS.ProcessEnv,\n signal: AbortSignal | undefined\n) => {\n signal?.throwIfAborted();\n return new Promise<void>((resolvePromise, rejectPromise) => {\n const child = spawn(command, args, {\n cwd,\n env,\n stdio: 'inherit',\n });\n let settled = false;\n const onAbort = () => {\n if (settled) {\n return;\n }\n settled = true;\n child.kill();\n rejectPromise(createAbortError());\n };\n signal?.addEventListener('abort', onAbort, { once: true });\n const cleanup = () => {\n signal?.removeEventListener('abort', onAbort);\n };\n child.once('error', (error) => {\n if (settled) {\n return;\n }\n settled = true;\n cleanup();\n rejectPromise(error);\n });\n child.once('close', (code) => {\n if (settled) {\n return;\n }\n settled = true;\n cleanup();\n if (code === 0) {\n resolvePromise();\n return;\n }\n rejectPromise(\n new Error(\n `Command failed: ${command} ${args.join(' ')} (exit code ${code})`\n )\n );\n });\n });\n};\n\nexport const runCommandCapture = async (\n command: string,\n args: string[],\n cwd: string,\n signal: AbortSignal | undefined\n) => {\n signal?.throwIfAborted();\n return new Promise<Buffer>((resolvePromise, rejectPromise) => {\n const stdoutChunks: Buffer[] = [];\n const stderrChunks: Buffer[] = [];\n const child = spawn(command, args, {\n cwd,\n stdio: ['ignore', 'pipe', 'pipe'],\n });\n let settled = false;\n const onAbort = () => {\n if (settled) {\n return;\n }\n settled = true;\n child.kill();\n rejectPromise(createAbortError());\n };\n signal?.addEventListener('abort', onAbort, { once: true });\n const cleanup = () => {\n signal?.removeEventListener('abort', onAbort);\n };\n child.stdout.on('data', (chunk: Buffer) => {\n stdoutChunks.push(chunk);\n });\n child.stderr.on('data', (chunk: Buffer) => {\n stderrChunks.push(chunk);\n });\n child.once('error', (error) => {\n if (settled) {\n return;\n }\n settled = true;\n cleanup();\n rejectPromise(error);\n });\n child.once('close', (code) => {\n if (settled) {\n return;\n }\n settled = true;\n cleanup();\n if (code === 0) {\n resolvePromise(Buffer.concat(stdoutChunks));\n return;\n }\n const stderrText = Buffer.concat(stderrChunks).toString('utf8');\n rejectPromise(\n new Error(\n `Command failed: ${command} ${args.join(' ')} (exit code ${code})${\n stderrText ? `\\n${stderrText}` : ''\n }`\n )\n );\n });\n });\n};\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport { constants, access, mkdir } from 'fs/promises';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nexport const pathExists = async (targetPath: string) => {\n try {\n await access(targetPath, constants.F_OK);\n return true;\n } catch {\n return false;\n }\n};\n\nexport const ensureDirectory = async (targetPath: string) => {\n await mkdir(targetPath, { recursive: true });\n};\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport { mkdtemp, rename, rm } from 'fs/promises';\nimport { homedir } from 'os';\nimport { join, resolve } from 'path';\nimport { createMutex } from 'async-primitives';\n\nimport { runCommand } from './commands';\nimport { ensureDirectory, pathExists } from './fs-utils';\nimport type { PrepareEmsdkOptions } from './types';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nconst DEFAULT_REPO_URL = 'https://github.com/emscripten-core/emsdk.git';\nconst DEFAULT_GIT_REF = 'main';\nconst DEFAULT_CACHE_DIR = join(homedir(), '.cache', 'emsdk-env');\nconst DEFAULT_TARGET_VERSION = 'latest';\n\nconst versionMutexes = new Map<string, ReturnType<typeof createMutex>>();\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nconst getVersionMutex = (key: string) => {\n let mutex = versionMutexes.get(key);\n if (!mutex) {\n mutex = createMutex();\n versionMutexes.set(key, mutex);\n }\n return mutex;\n};\n\nconst ensureNonEmpty = (value: string, label: string) => {\n if (value.trim().length === 0) {\n throw new TypeError(`${label} must be a non-empty string.`);\n }\n};\n\nconst sanitizeSegment = (value: string) => {\n const trimmed = value.trim();\n ensureNonEmpty(trimmed, 'targetVersion');\n const sanitized = trimmed.replace(/[^A-Za-z0-9._-]/g, '_');\n if (sanitized === '.' || sanitized === '..' || sanitized.length === 0) {\n throw new TypeError('targetVersion results in an unsafe path segment.');\n }\n return sanitized;\n};\n\nconst resolveEmsdkCommand = () =>\n process.platform === 'win32' ? 'emsdk.bat' : './emsdk';\n\nconst runEmsdk = async (\n repoDir: string,\n args: string[],\n signal: AbortSignal | undefined\n) => {\n if (process.platform === 'win32') {\n await runCommand('cmd', ['/c', 'emsdk.bat', ...args], repoDir, signal);\n return;\n }\n await runCommand(resolveEmsdkCommand(), args, repoDir, signal);\n};\n\nconst runGitClone = async (\n gitPath: string,\n repoUrl: string,\n targetDir: string,\n cwd: string,\n signal: AbortSignal | undefined\n) => {\n await runCommand(\n gitPath,\n ['clone', repoUrl, targetDir, '--depth', '1', '--branch', DEFAULT_GIT_REF],\n cwd,\n signal\n );\n};\n\nconst isAlreadyExistsError = (error: unknown) =>\n error instanceof Error &&\n 'code' in error &&\n (error as NodeJS.ErrnoException).code !== undefined &&\n ['EEXIST', 'ENOTEMPTY', 'EISDIR'].includes(\n String((error as NodeJS.ErrnoException).code)\n );\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nexport const prepareEmsdk = async (\n options: PrepareEmsdkOptions\n): Promise<string> => {\n if (!options) {\n throw new TypeError('options must be provided.');\n }\n if (\n options.targetVersion !== undefined &&\n typeof options.targetVersion !== 'string'\n ) {\n throw new TypeError('targetVersion must be a string.');\n }\n const targetVersion = options.targetVersion ?? DEFAULT_TARGET_VERSION;\n ensureNonEmpty(targetVersion, 'targetVersion');\n options.signal?.throwIfAborted();\n\n const cacheDir = resolve(options.cacheDir ?? DEFAULT_CACHE_DIR);\n const repoUrl = options.repoUrl ?? DEFAULT_REPO_URL;\n const gitPath = options.gitPath ?? 'git';\n\n const versionDir = sanitizeSegment(targetVersion);\n const finalDir = resolve(cacheDir, versionDir);\n\n const mutex = getVersionMutex(finalDir);\n const lock = await mutex.lock(options.signal);\n try {\n options.signal?.throwIfAborted();\n if (await pathExists(finalDir)) {\n return finalDir;\n }\n\n await ensureDirectory(cacheDir);\n\n const tempRoot = await mkdtemp(join(cacheDir, '.tmp-'));\n const tempRepoDir = join(tempRoot, 'emsdk');\n\n try {\n await runGitClone(\n gitPath,\n repoUrl,\n tempRepoDir,\n cacheDir,\n options.signal\n );\n options.signal?.throwIfAborted();\n await runEmsdk(tempRepoDir, ['install', targetVersion], options.signal);\n\n try {\n await rename(tempRepoDir, finalDir);\n } catch (error) {\n if (isAlreadyExistsError(error)) {\n return finalDir;\n }\n throw error;\n }\n } finally {\n await rm(tempRoot, { recursive: true, force: true });\n }\n\n options.signal?.throwIfAborted();\n await runEmsdk(finalDir, ['activate', targetVersion], options.signal);\n return finalDir;\n } finally {\n lock.release();\n }\n};\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport { join, resolve } from 'path';\n\nimport { runCommandCapture } from './commands';\nimport { pathExists } from './fs-utils';\nimport type { Logger } from './types';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nconst shellQuote = (value: string) =>\n `'${String(value).replace(/'/g, `'\\\"'\\\"'`)}'`;\n\nconst parseEnvBuffer = (buffer: Buffer) => {\n const entries = buffer.toString('utf8').split('\\u0000');\n const env: Record<string, string> = {};\n for (const entry of entries) {\n if (!entry) {\n continue;\n }\n const delimiterIndex = entry.indexOf('=');\n if (delimiterIndex <= 0) {\n continue;\n }\n const key = entry.slice(0, delimiterIndex);\n const value = entry.slice(delimiterIndex + 1);\n env[key] = value;\n }\n return env;\n};\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nexport const loadEmsdkEnv = async (\n emsdkRoot: string,\n logger: Logger,\n signal: AbortSignal | undefined\n) => {\n if (process.platform === 'win32') {\n throw new Error(\n 'Emscripten environment extraction on Windows is not implemented yet.'\n );\n }\n const envScript = resolve(emsdkRoot, 'emsdk_env.sh');\n if (!(await pathExists(envScript))) {\n throw new Error(`emsdk_env.sh not found: ${envScript}`);\n }\n const command = `. ${shellQuote(envScript)} >/dev/null 2>&1; env -0`;\n logger.debug(`Loading emsdk environment: ${envScript}`);\n const output = await runCommandCapture(\n 'bash',\n ['-lc', command],\n emsdkRoot,\n signal\n );\n return parseEnvBuffer(output);\n};\n\nexport const resolveEmccCommand = async (\n env: Record<string, string>,\n emsdkRoot: string\n) => {\n if (env.EMCC) {\n return env.EMCC;\n }\n if (env.EMSCRIPTEN) {\n const candidate = join(env.EMSCRIPTEN, 'emcc');\n if (await pathExists(candidate)) {\n return candidate;\n }\n }\n const fallback = join(emsdkRoot, 'upstream', 'emscripten', 'emcc');\n if (await pathExists(fallback)) {\n return fallback;\n }\n return 'emcc';\n};\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport { Logger } from './types';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\n// Simple logger implementation with prefix\nexport const createConsoleLogger = (prefix: string): Logger => {\n return {\n debug: (msg: string) => console.debug(`[${prefix}]: ${msg}`),\n info: (msg: string) => console.info(`[${prefix}]: ${msg}`),\n warn: (msg: string) => console.warn(`[${prefix}]: ${msg}`),\n error: (msg: string) => console.error(`[${prefix}]: ${msg}`),\n };\n};\n","// emsdk-env - Emscripten environment builder\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/emsdk-env\n\nimport { rm } from 'fs/promises';\nimport { tmpdir } from 'os';\nimport { glob } from 'glob';\nimport { isAbsolute, join, relative, resolve } from 'path';\n\nimport { runCommandWithEnv } from './commands';\nimport { loadEmsdkEnv, resolveEmccCommand } from './env';\nimport { prepareEmsdk } from './emsdk';\nimport { ensureDirectory } from './fs-utils';\nimport { createConsoleLogger } from './logger';\nimport type {\n BuildWasmOptions,\n BuildWasmResult,\n DefineValue,\n PrepareEmsdkOptions,\n} from './types';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nconst DEFAULT_WASM_SRC_DIR = 'wasm';\nconst DEFAULT_WASM_OUT_DIR = join('src', 'wasm');\nconst DEFAULT_WASM_BUILD_DIR = join(tmpdir(), 'emsdk-env');\nconst DEFAULT_EMSDK_TARGET_VERSION = 'latest';\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nlet buildSequence = 0;\n\nconst padNumber = (value: number, length = 2) =>\n String(value).padStart(length, '0');\n\nconst formatTimestamp = (date: Date) => {\n const year = date.getFullYear();\n const month = padNumber(date.getMonth() + 1);\n const day = padNumber(date.getDate());\n const hour = padNumber(date.getHours());\n const minute = padNumber(date.getMinutes());\n const second = padNumber(date.getSeconds());\n return `${year}${month}${day}_${hour}${minute}${second}`;\n};\n\nconst createBuildId = () => {\n buildSequence += 1;\n const timestamp = formatTimestamp(new Date());\n const seq = String(buildSequence).padStart(4, '0');\n return `${timestamp}_${seq}_${process.pid}`;\n};\n\nconst ensureArray = (value?: string[]) => (value ? [...value] : []);\n\nconst normalizePrepareOptions = (\n options: PrepareEmsdkOptions | undefined\n): PrepareEmsdkOptions => {\n const { targetVersion, ...rest } = options ?? {};\n return {\n targetVersion: targetVersion ?? DEFAULT_EMSDK_TARGET_VERSION,\n ...rest,\n };\n};\n\nconst mergeDefines = (\n common?: Record<string, DefineValue>,\n target?: Record<string, DefineValue>\n) => ({\n ...(common ?? {}),\n ...(target ?? {}),\n});\n\nconst resolvePath = (rootDir: string, value: string) =>\n isAbsolute(value) ? value : resolve(rootDir, value);\n\nconst expandPlaceholders = (\n value: string,\n env: Record<string, string>,\n label: string\n) =>\n value.replace(/\\{([A-Z0-9_]+)\\}/g, (_match, key: string) => {\n const replacement = env[key];\n if (replacement === undefined) {\n throw new Error(`Unknown placeholder {${key}} in ${label}.`);\n }\n return replacement;\n });\n\nconst expandArray = (\n values: string[],\n env: Record<string, string>,\n label: string\n) => values.map((value) => expandPlaceholders(value, env, label));\n\nconst resolveDefines = (\n defines: Record<string, DefineValue>,\n env: Record<string, string>\n) => {\n const resolved: Record<string, DefineValue> = {};\n for (const [key, value] of Object.entries(defines)) {\n if (typeof value === 'string') {\n resolved[key] = expandPlaceholders(value, env, `defines.${key}`);\n } else {\n resolved[key] = value;\n }\n }\n return resolved;\n};\n\nconst resolveIncludeDirs = (\n includeDirs: string[],\n env: Record<string, string>,\n rootDir: string\n) => {\n const expanded = expandArray(includeDirs, env, 'includeDirs');\n return expanded.map((value) => resolvePath(rootDir, value));\n};\n\nconst resolveOutFile = (\n outFile: string,\n env: Record<string, string>,\n outDir: string\n) => {\n const expanded = expandPlaceholders(outFile, env, 'outFile');\n return resolvePath(outDir, expanded);\n};\n\nconst resolveSourcePatterns = (\n patterns: string[],\n env: Record<string, string>,\n srcDir: string\n) => {\n const expanded = expandArray(patterns, env, 'sources');\n return expanded.map((value) => resolvePath(srcDir, value));\n};\n\nconst buildDefineFlags = (defines: Record<string, DefineValue>) =>\n Object.entries(defines).map(([key, value]) => `-D${key}=${String(value)}`);\n\nconst buildExportFlags = (exports: string[]) => {\n if (exports.length === 0) {\n return [];\n }\n return ['-s', `EXPORTED_FUNCTIONS=${JSON.stringify(exports)}`];\n};\n\nconst createEnvForBuild = (\n baseEnv: Record<string, string>,\n overrides: Record<string, string>\n) => ({\n ...process.env,\n ...baseEnv,\n ...overrides,\n});\n\nconst resolveTargetOutFile = (\n targetName: string,\n targetOutFile: string | undefined,\n env: Record<string, string>,\n outDir: string\n) => {\n if (targetOutFile) {\n return resolveOutFile(targetOutFile, env, outDir);\n }\n return resolve(outDir, `${targetName}.wasm`);\n};\n\nconst resolveTargetSources = async (\n targetSources: string[] | undefined,\n env: Record<string, string>,\n srcDir: string\n) => {\n const patterns =\n targetSources && targetSources.length > 0\n ? targetSources\n : [join(srcDir, '**', '*.c'), join(srcDir, '**', '*.cpp')];\n const resolvedPatterns = resolveSourcePatterns(patterns, env, srcDir);\n const results = await Promise.all(\n resolvedPatterns.map((pattern) => glob(pattern, { nodir: true }))\n );\n const sources = results.flat();\n sources.sort();\n return sources;\n};\n\nconst toSafeObjectName = (rootDir: string, sourcePath: string) =>\n relative(rootDir, sourcePath)\n .replace(/[\\\\/]/g, '_')\n .replace(/[^A-Za-z0-9._-]/g, '_');\n\n/////////////////////////////////////////////////////////////////////////////////////////////////\n\nexport const buildWasm = async (\n options: BuildWasmOptions\n): Promise<BuildWasmResult> => {\n if (!options) {\n throw new TypeError('options must be provided.');\n }\n if (!options.rule || !options.rule.targets) {\n throw new TypeError('rule targets must be provided.');\n }\n const targets = Object.entries(options.rule.targets);\n if (targets.length === 0) {\n throw new TypeError('rule targets must not be empty.');\n }\n\n const logger = options.logger ?? createConsoleLogger('emsdk-env');\n const rootDir = resolve(options.root ?? process.cwd());\n\n const emsdkOptions = normalizePrepareOptions(options.emsdk);\n const emsdkRoot = await prepareEmsdk(emsdkOptions);\n const emsdkEnv = await loadEmsdkEnv(emsdkRoot, logger, emsdkOptions.signal);\n\n const baseEnv = {\n ...emsdkEnv,\n ROOT: rootDir,\n };\n\n const rawSrcDir = expandPlaceholders(\n options.srcDir ?? DEFAULT_WASM_SRC_DIR,\n baseEnv,\n 'srcDir'\n );\n const rawOutDir = expandPlaceholders(\n options.outDir ?? DEFAULT_WASM_OUT_DIR,\n baseEnv,\n 'outDir'\n );\n const rawBuildDir = expandPlaceholders(\n options.buildDir ?? DEFAULT_WASM_BUILD_DIR,\n baseEnv,\n 'buildDir'\n );\n\n const srcDir = resolvePath(rootDir, rawSrcDir);\n const outDir = resolvePath(rootDir, rawOutDir);\n const buildDir = resolvePath(rootDir, rawBuildDir);\n const buildId = createBuildId();\n const buildRunDir = resolve(buildDir, buildId);\n const cleanupBuildDir = options.cleanupBuildDir ?? true;\n const parallel = options.parallel ?? true;\n\n const envWithDirs = {\n ...emsdkEnv,\n ROOT: rootDir,\n SRC_DIR: srcDir,\n OUT_DIR: outDir,\n BUILD_DIR: buildDir,\n };\n\n const emccCommand = await resolveEmccCommand(envWithDirs, emsdkRoot);\n const common = options.rule.common ?? {};\n\n await ensureDirectory(outDir);\n await ensureDirectory(buildDir);\n await rm(buildRunDir, { recursive: true, force: true });\n await ensureDirectory(buildRunDir);\n\n const outFiles: Record<string, string> = {};\n\n try {\n for (const [targetName, target] of targets) {\n const mergedOptions = [\n ...ensureArray(common.options),\n ...ensureArray(target.options),\n ];\n const mergedLinkOptions = [\n ...ensureArray(common.linkOptions),\n ...ensureArray(target.linkOptions),\n ];\n const mergedExports = [\n ...ensureArray(common.exports),\n ...ensureArray(target.exports),\n ];\n const mergedIncludeDirs = [\n ...ensureArray(common.includeDirs),\n ...ensureArray(target.includeDirs),\n ];\n const mergedDefines = mergeDefines(common.defines, target.defines);\n\n const targetEnv = {\n ...envWithDirs,\n TARGET_NAME: targetName,\n };\n const buildEnv = createEnvForBuild(targetEnv, {});\n\n const resolvedOutFile = resolveTargetOutFile(\n targetName,\n target.outFile,\n targetEnv,\n outDir\n );\n\n const sources = await resolveTargetSources(\n target.sources,\n targetEnv,\n srcDir\n );\n if (sources.length === 0) {\n throw new Error(`No sources matched for target: ${targetName}`);\n }\n\n const targetBuildDir = resolve(buildRunDir, targetName);\n await rm(targetBuildDir, { recursive: true, force: true });\n await ensureDirectory(targetBuildDir);\n\n const resolvedOptions = expandArray(mergedOptions, targetEnv, 'options');\n const resolvedLinkOptions = expandArray(\n mergedLinkOptions,\n targetEnv,\n 'linkOptions'\n );\n const resolvedExports = expandArray(mergedExports, targetEnv, 'exports');\n const exportArgs = buildExportFlags(resolvedExports);\n const includeArgs = resolveIncludeDirs(\n mergedIncludeDirs,\n targetEnv,\n rootDir\n ).map((dir) => `-I${dir}`);\n const defineArgs = buildDefineFlags(\n resolveDefines(mergedDefines, targetEnv)\n );\n\n logger.info(`Compiling target: ${targetName}`);\n const compileSource = async (source: string) => {\n const objectName = toSafeObjectName(rootDir, source);\n const outputObject = resolve(targetBuildDir, `${objectName}.o`);\n const args = [\n '-c',\n source,\n '-o',\n outputObject,\n ...resolvedOptions,\n ...includeArgs,\n ...defineArgs,\n ];\n logger.debug(`emcc ${args.join(' ')}`);\n await runCommandWithEnv(\n emccCommand,\n args,\n rootDir,\n buildEnv,\n emsdkOptions.signal\n );\n return outputObject;\n };\n const buildObjectsSequential = async () => {\n const objectFiles: string[] = [];\n for (const source of sources) {\n objectFiles.push(await compileSource(source));\n }\n return objectFiles;\n };\n const objectFiles = parallel\n ? await Promise.all(sources.map((source) => compileSource(source)))\n : await buildObjectsSequential();\n\n logger.info(`Linking target: ${targetName}`);\n const linkArgs = [\n ...objectFiles,\n '-o',\n resolvedOutFile,\n ...resolvedLinkOptions,\n ...exportArgs,\n ];\n logger.debug(`emcc ${linkArgs.join(' ')}`);\n await runCommandWithEnv(\n emccCommand,\n linkArgs,\n rootDir,\n buildEnv,\n emsdkOptions.signal\n );\n\n outFiles[targetName] = resolvedOutFile;\n }\n } finally {\n if (cleanupBuildDir) {\n await rm(buildRunDir, { recursive: true, force: true });\n }\n }\n\n return {\n emsdkRoot,\n outFiles,\n };\n};\n"],"names":["spawn","onAbort","access","constants","mkdir","join","homedir","resolve","mkdtemp","rename","rm","tmpdir","isAbsolute","exports","glob","relative","objectFiles"],"mappings":";;;;;;;;;;;;;;;;AASA,MAAM,iBAAiB,MAAM;AAC7B;AACA,MAAM,oBAAoB;AAAA,EACxB,SAAS;AAAA,EACT,CAAC,OAAO,OAAO,GAAG;AACpB;AACA,MAAM,eAAe,CAAC,WAAW;AAC/B,MAAI,kBAAkB,OAAO;AAC3B,WAAO;AAAA,EACT;AACA,MAAI,OAAO,WAAW,UAAU;AAC9B,WAAO,IAAI,MAAM,MAAM;AAAA,EACzB;AACA,SAAO,IAAI,MAAM,mBAAmB;AACtC;AACA,MAAM,UAAU,CAAC,QAAQ,aAAa;AACpC,MAAI,CAAC,QAAQ;AACX,WAAO;AAAA,EACT;AACA,MAAI,OAAO,SAAS;AAClB,QAAI;AACF,eAAS,aAAa,OAAO,MAAM,CAAC;AAAA,IACtC,SAAS,OAAO;AACd,cAAQ,KAAK,8BAA8B,KAAK;AAAA,IAClD;AACA,WAAO;AAAA,EACT;AACA,MAAI;AACJ,iBAAe,MAAM;AACnB,QAAI,cAAc;AAChB,YAAM,SAAS,OAAO;AACtB,aAAO,oBAAoB,SAAS,YAAY;AAChD,qBAAe;AACf,UAAI;AACF,iBAAS,aAAa,MAAM,CAAC;AAAA,MAC/B,SAAS,OAAO;AACd,gBAAQ,KAAK,8BAA8B,KAAK;AAAA,MAClD;AAAA,IACF;AAAA,EACF;AACA,QAAM,UAAU,MAAM;AACpB,QAAI,cAAc;AAChB,aAAO,oBAAoB,SAAS,YAAY;AAChD,qBAAe;AAAA,IACjB;AAAA,EACF;AACA,SAAO,iBAAiB,SAAS,cAAc,EAAE,MAAM,MAAM;AAC7D,QAAM,SAAS;AAAA,IACb;AAAA,IACA,CAAC,OAAO,OAAO,GAAG;AAAA,EACtB;AACE,SAAO;AACT;AAsBA,MAAM,QAAQ,CAAC,OAAO;AACpB,MAAI,OAAO,iBAAiB,YAAY;AACtC,iBAAa,EAAE;AAAA,EACjB,OAAO;AACL,eAAW,IAAI,CAAC;AAAA,EAClB;AACF;AACA,MAAM,kBAAkB,MAAM,IAAI,MAAM,8BAA8B;AACtE,MAAM,mBAAmB,CAAC,oBAAoB;AAC5C,MAAI,WAAW;AACf,QAAM,UAAU,MAAM;AACpB,QAAI,CAAC,UAAU;AACb;AAAA,IACF;AACA,eAAW;AACX,oBAAe;AAAA,EACjB;AACA,SAAO;AAAA,IACL,IAAI,WAAW;AACb,aAAO;AAAA,IACT;AAAA,IACA;AAAA,IACA,CAAC,OAAO,OAAO,GAAG;AAAA,EACtB;AACA;AACA,MAAM,cAAc,CAAC,sBAAsB,OAAO;AAChD,MAAI,WAAW;AACf,QAAM,QAAQ,CAAA;AACd,MAAI,QAAQ;AACZ,QAAM,eAAe,MAAM;AACzB,QAAI;AACJ,QAAI,YAAY,MAAM,WAAW,GAAG;AAClC;AAAA,IACF;AACA,UAAM,OAAO,MAAM,MAAK;AACxB,SAAK,KAAK,KAAK,WAAW,OAAO,SAAS,GAAG,SAAS;AACpD,WAAK,OAAO,iBAAiB;AAC7B,0BAAmB;AACnB;AAAA,IACF;AACA,eAAW;AACX,UAAM,aAAa,iBAAiB,WAAW;AAC/C,SAAK,QAAQ,UAAU;AAAA,EACzB;AACA,QAAM,sBAAsB,MAAM;AAChC;AACA,QAAI,SAAS,qBAAqB;AAChC,cAAQ;AACR,YAAM,YAAY;AAAA,IACpB,OAAO;AACL,mBAAY;AAAA,IACd;AAAA,EACF;AACA,QAAM,cAAc,MAAM;AACxB,QAAI,CAAC,UAAU;AACb;AAAA,IACF;AACA,eAAW;AACX,wBAAmB;AAAA,EACrB;AACA,QAAM,kBAAkB,CAAC,SAAS;AAChC,UAAM,QAAQ,MAAM,QAAQ,IAAI;AAChC,QAAI,UAAU,IAAI;AAChB,YAAM,OAAO,OAAO,CAAC;AAAA,IACvB;AAAA,EACF;AACA,QAAM,OAAO,OAAO,WAAW;AAC7B,QAAI,QAAQ;AACV,UAAI,OAAO,SAAS;AAClB,cAAM,gBAAe;AAAA,MACvB;AACA,aAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,cAAM,YAAY;AAAA,UAChB,SAAS;AAAA,UACT,QAAQ;AAAA,UACR;AAAA,QACV;AACQ,cAAM,cAAc,QAAQ,QAAQ,MAAM;AACxC,0BAAgB,SAAS;AACzB,iBAAO,gBAAe,CAAE;AAAA,QAC1B,CAAC;AACD,kBAAU,UAAU,CAAC,WAAW;AAC9B,sBAAY,QAAO;AACnB,kBAAQ,MAAM;AAAA,QAChB;AACA,kBAAU,SAAS,CAAC,UAAU;AAC5B,sBAAY,QAAO;AACnB,iBAAO,KAAK;AAAA,QACd;AACA,cAAM,KAAK,SAAS;AACpB,qBAAY;AAAA,MACd,CAAC;AAAA,IACH,OAAO;AACL,aAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,cAAM,KAAK;AAAA,UACT;AAAA,UACA;AAAA,QACV,CAAS;AACD,qBAAY;AAAA,MACd,CAAC;AAAA,IACH;AAAA,EACF;AACA,QAAM,SAAS;AAAA,IACb;AAAA,IACA,QAAQ;AAAA,MACN,MAAM;AAAA,IACZ;AAAA,IACI,IAAI,WAAW;AACb,aAAO;AAAA,IACT;AAAA,IACA,IAAI,eAAe;AACjB,aAAO,MAAM;AAAA,IACf;AAAA,EACJ;AACE,SAAO;AACT;AC7LA,MAAM,mBAAmB,MAAM;AAC7B,QAAM,QAAQ,IAAI,MAAM,4BAA4B;AACpD,QAAM,OAAO;AACb,SAAO;AACT;AAEO,MAAM,aAAa,OACxB,SACA,MACA,KACA,WACG;AACH,mCAAQ;AACR,SAAO,IAAI,QAAc,CAAC,gBAAgB,kBAAkB;AAC1D,UAAM,QAAQA,cAAAA,MAAM,SAAS,MAAM;AAAA,MACjC;AAAA,MACA,OAAO;AAAA,IAAA,CACR;AACD,QAAI,UAAU;AACd,UAAMC,WAAU,MAAM;AACpB,UAAI,SAAS;AACX;AAAA,MACF;AACA,gBAAU;AACV,YAAM,KAAA;AACN,oBAAc,kBAAkB;AAAA,IAClC;AACA,qCAAQ,iBAAiB,SAASA,UAAS,EAAE,MAAM;AACnD,UAAM,UAAU,MAAM;AACpB,uCAAQ,oBAAoB,SAASA;AAAA,IACvC;AACA,UAAM,KAAK,SAAS,CAAC,UAAU;AAC7B,UAAI,SAAS;AACX;AAAA,MACF;AACA,gBAAU;AACV,cAAA;AACA,oBAAc,KAAK;AAAA,IACrB,CAAC;AACD,UAAM,KAAK,SAAS,CAAC,SAAS;AAC5B,UAAI,SAAS;AACX;AAAA,MACF;AACA,gBAAU;AACV,cAAA;AACA,UAAI,SAAS,GAAG;AACd,uBAAA;AACA;AAAA,MACF;AACA;AAAA,QACE,IAAI;AAAA,UACF,mBAAmB,OAAO,IAAI,KAAK,KAAK,GAAG,CAAC,eAAe,IAAI;AAAA,QAAA;AAAA,MACjE;AAAA,IAEJ,CAAC;AAAA,EACH,CAAC;AACH;AAEO,MAAM,oBAAoB,OAC/B,SACA,MACA,KACA,KACA,WACG;AACH,mCAAQ;AACR,SAAO,IAAI,QAAc,CAAC,gBAAgB,kBAAkB;AAC1D,UAAM,QAAQD,cAAAA,MAAM,SAAS,MAAM;AAAA,MACjC;AAAA,MACA;AAAA,MACA,OAAO;AAAA,IAAA,CACR;AACD,QAAI,UAAU;AACd,UAAMC,WAAU,MAAM;AACpB,UAAI,SAAS;AACX;AAAA,MACF;AACA,gBAAU;AACV,YAAM,KAAA;AACN,oBAAc,kBAAkB;AAAA,IAClC;AACA,qCAAQ,iBAAiB,SAASA,UAAS,EAAE,MAAM;AACnD,UAAM,UAAU,MAAM;AACpB,uCAAQ,oBAAoB,SAASA;AAAA,IACvC;AACA,UAAM,KAAK,SAAS,CAAC,UAAU;AAC7B,UAAI,SAAS;AACX;AAAA,MACF;AACA,gBAAU;AACV,cAAA;AACA,oBAAc,KAAK;AAAA,IACrB,CAAC;AACD,UAAM,KAAK,SAAS,CAAC,SAAS;AAC5B,UAAI,SAAS;AACX;AAAA,MACF;AACA,gBAAU;AACV,cAAA;AACA,UAAI,SAAS,GAAG;AACd,uBAAA;AACA;AAAA,MACF;AACA;AAAA,QACE,IAAI;AAAA,UACF,mBAAmB,OAAO,IAAI,KAAK,KAAK,GAAG,CAAC,eAAe,IAAI;AAAA,QAAA;AAAA,MACjE;AAAA,IAEJ,CAAC;AAAA,EACH,CAAC;AACH;AAEO,MAAM,oBAAoB,OAC/B,SACA,MACA,KACA,WACG;AACH,mCAAQ;AACR,SAAO,IAAI,QAAgB,CAAC,gBAAgB,kBAAkB;AAC5D,UAAM,eAAyB,CAAA;AAC/B,UAAM,eAAyB,CAAA;AAC/B,UAAM,QAAQD,cAAAA,MAAM,SAAS,MAAM;AAAA,MACjC;AAAA,MACA,OAAO,CAAC,UAAU,QAAQ,MAAM;AAAA,IAAA,CACjC;AACD,QAAI,UAAU;AACd,UAAMC,WAAU,MAAM;AACpB,UAAI,SAAS;AACX;AAAA,MACF;AACA,gBAAU;AACV,YAAM,KAAA;AACN,oBAAc,kBAAkB;AAAA,IAClC;AACA,qCAAQ,iBAAiB,SAASA,UAAS,EAAE,MAAM;AACnD,UAAM,UAAU,MAAM;AACpB,uCAAQ,oBAAoB,SAASA;AAAA,IACvC;AACA,UAAM,OAAO,GAAG,QAAQ,CAAC,UAAkB;AACzC,mBAAa,KAAK,KAAK;AAAA,IACzB,CAAC;AACD,UAAM,OAAO,GAAG,QAAQ,CAAC,UAAkB;AACzC,mBAAa,KAAK,KAAK;AAAA,IACzB,CAAC;AACD,UAAM,KAAK,SAAS,CAAC,UAAU;AAC7B,UAAI,SAAS;AACX;AAAA,MACF;AACA,gBAAU;AACV,cAAA;AACA,oBAAc,KAAK;AAAA,IACrB,CAAC;AACD,UAAM,KAAK,SAAS,CAAC,SAAS;AAC5B,UAAI,SAAS;AACX;AAAA,MACF;AACA,gBAAU;AACV,cAAA;AACA,UAAI,SAAS,GAAG;AACd,uBAAe,OAAO,OAAO,YAAY,CAAC;AAC1C;AAAA,MACF;AACA,YAAM,aAAa,OAAO,OAAO,YAAY,EAAE,SAAS,MAAM;AAC9D;AAAA,QACE,IAAI;AAAA,UACF,mBAAmB,OAAO,IAAI,KAAK,KAAK,GAAG,CAAC,eAAe,IAAI,IAC7D,aAAa;AAAA,EAAK,UAAU,KAAK,EACnC;AAAA,QAAA;AAAA,MACF;AAAA,IAEJ,CAAC;AAAA,EACH,CAAC;AACH;AC7KO,MAAM,aAAa,OAAO,eAAuB;AACtD,MAAI;AACF,UAAMC,gBAAO,YAAYC,SAAAA,UAAU,IAAI;AACvC,WAAO;AAAA,EACT,SAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEO,MAAM,kBAAkB,OAAO,eAAuB;AAC3D,QAAMC,SAAAA,MAAM,YAAY,EAAE,WAAW,MAAM;AAC7C;ACJA,MAAM,mBAAmB;AACzB,MAAM,kBAAkB;AACxB,MAAM,oBAAoBC,KAAAA,KAAKC,GAAAA,WAAW,UAAU,WAAW;AAC/D,MAAM,yBAAyB;AAE/B,MAAM,qCAAqB,IAAA;AAI3B,MAAM,kBAAkB,CAAC,QAAgB;AACvC,MAAI,QAAQ,eAAe,IAAI,GAAG;AAClC,MAAI,CAAC,OAAO;AACV,YAAQ,YAAA;AACR,mBAAe,IAAI,KAAK,KAAK;AAAA,EAC/B;AACA,SAAO;AACT;AAEA,MAAM,iBAAiB,CAAC,OAAe,UAAkB;AACvD,MAAI,MAAM,OAAO,WAAW,GAAG;AAC7B,UAAM,IAAI,UAAU,GAAG,KAAK,8BAA8B;AAAA,EAC5D;AACF;AAEA,MAAM,kBAAkB,CAAC,UAAkB;AACzC,QAAM,UAAU,MAAM,KAAA;AACtB,iBAAe,SAAS,eAAe;AACvC,QAAM,YAAY,QAAQ,QAAQ,oBAAoB,GAAG;AACzD,MAAI,cAAc,OAAO,cAAc,QAAQ,UAAU,WAAW,GAAG;AACrE,UAAM,IAAI,UAAU,kDAAkD;AAAA,EACxE;AACA,SAAO;AACT;AAEA,MAAM,sBAAsB,MAC1B,QAAQ,aAAa,UAAU,cAAc;AAE/C,MAAM,WAAW,OACf,SACA,MACA,WACG;AACH,MAAI,QAAQ,aAAa,SAAS;AAChC,UAAM,WAAW,OAAO,CAAC,MAAM,aAAa,GAAG,IAAI,GAAG,SAAS,MAAM;AACrE;AAAA,EACF;AACA,QAAM,WAAW,oBAAA,GAAuB,MAAM,SAAS,MAAM;AAC/D;AAEA,MAAM,cAAc,OAClB,SACA,SACA,WACA,KACA,WACG;AACH,QAAM;AAAA,IACJ;AAAA,IACA,CAAC,SAAS,SAAS,WAAW,WAAW,KAAK,YAAY,eAAe;AAAA,IACzE;AAAA,IACA;AAAA,EAAA;AAEJ;AAEA,MAAM,uBAAuB,CAAC,UAC5B,iBAAiB,SACjB,UAAU,SACT,MAAgC,SAAS,UAC1C,CAAC,UAAU,aAAa,QAAQ,EAAE;AAAA,EAChC,OAAQ,MAAgC,IAAI;AAC9C;AAIK,MAAM,eAAe,OAC1B,YACoB;;AACpB,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI,UAAU,2BAA2B;AAAA,EACjD;AACA,MACE,QAAQ,kBAAkB,UAC1B,OAAO,QAAQ,kBAAkB,UACjC;AACA,UAAM,IAAI,UAAU,iCAAiC;AAAA,EACvD;AACA,QAAM,iBAAgB,aAAQ,kBAAR,YAAyB;AAC/C,iBAAe,eAAe,eAAe;AAC7C,gBAAQ,WAAR,mBAAgB;AAEhB,QAAM,WAAWC,KAAAA,SAAQ,aAAQ,aAAR,YAAoB,iBAAiB;AAC9D,QAAM,WAAU,aAAQ,YAAR,YAAmB;AACnC,QAAM,WAAU,aAAQ,YAAR,YAAmB;AAEnC,QAAM,aAAa,gBAAgB,aAAa;AAChD,QAAM,WAAWA,KAAAA,QAAQ,UAAU,UAAU;AAE7C,QAAM,QAAQ,gBAAgB,QAAQ;AACtC,QAAM,OAAO,MAAM,MAAM,KAAK,QAAQ,MAAM;AAC5C,MAAI;AACF,kBAAQ,WAAR,mBAAgB;AAChB,QAAI,MAAM,WAAW,QAAQ,GAAG;AAC9B,aAAO;AAAA,IACT;AAEA,UAAM,gBAAgB,QAAQ;AAE9B,UAAM,WAAW,MAAMC,SAAAA,QAAQH,KAAAA,KAAK,UAAU,OAAO,CAAC;AACtD,UAAM,cAAcA,KAAAA,KAAK,UAAU,OAAO;AAE1C,QAAI;AACF,YAAM;AAAA,QACJ;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,QAAQ;AAAA,MAAA;AAEV,oBAAQ,WAAR,mBAAgB;AAChB,YAAM,SAAS,aAAa,CAAC,WAAW,aAAa,GAAG,QAAQ,MAAM;AAEtE,UAAI;AACF,cAAMI,SAAAA,OAAO,aAAa,QAAQ;AAAA,MACpC,SAAS,OAAO;AACd,YAAI,qBAAqB,KAAK,GAAG;AAC/B,iBAAO;AAAA,QACT;AACA,cAAM;AAAA,MACR;AAAA,IACF,UAAA;AACE,YAAMC,SAAAA,GAAG,UAAU,EAAE,WAAW,MAAM,OAAO,MAAM;AAAA,IACrD;AAEA,kBAAQ,WAAR,mBAAgB;AAChB,UAAM,SAAS,UAAU,CAAC,YAAY,aAAa,GAAG,QAAQ,MAAM;AACpE,WAAO;AAAA,EACT,UAAA;AACE,SAAK,QAAA;AAAA,EACP;AACF;AC9IA,MAAM,aAAa,CAAC,UAClB,IAAI,OAAO,KAAK,EAAE,QAAQ,MAAM,OAAS,CAAC;AAE5C,MAAM,iBAAiB,CAAC,WAAmB;AACzC,QAAM,UAAU,OAAO,SAAS,MAAM,EAAE,MAAM,IAAQ;AACtD,QAAM,MAA8B,CAAA;AACpC,aAAW,SAAS,SAAS;AAC3B,QAAI,CAAC,OAAO;AACV;AAAA,IACF;AACA,UAAM,iBAAiB,MAAM,QAAQ,GAAG;AACxC,QAAI,kBAAkB,GAAG;AACvB;AAAA,IACF;AACA,UAAM,MAAM,MAAM,MAAM,GAAG,cAAc;AACzC,UAAM,QAAQ,MAAM,MAAM,iBAAiB,CAAC;AAC5C,QAAI,GAAG,IAAI;AAAA,EACb;AACA,SAAO;AACT;AAIO,MAAM,eAAe,OAC1B,WACA,QACA,WACG;AACH,MAAI,QAAQ,aAAa,SAAS;AAChC,UAAM,IAAI;AAAA,MACR;AAAA,IAAA;AAAA,EAEJ;AACA,QAAM,YAAYH,KAAAA,QAAQ,WAAW,cAAc;AACnD,MAAI,CAAE,MAAM,WAAW,SAAS,GAAI;AAClC,UAAM,IAAI,MAAM,2BAA2B,SAAS,EAAE;AAAA,EACxD;AACA,QAAM,UAAU,KAAK,WAAW,SAAS,CAAC;AAC1C,SAAO,MAAM,8BAA8B,SAAS,EAAE;AACtD,QAAM,SAAS,MAAM;AAAA,IACnB;AAAA,IACA,CAAC,OAAO,OAAO;AAAA,IACf;AAAA,IACA;AAAA,EAAA;AAEF,SAAO,eAAe,MAAM;AAC9B;AAEO,MAAM,qBAAqB,OAChC,KACA,cACG;AACH,MAAI,IAAI,MAAM;AACZ,WAAO,IAAI;AAAA,EACb;AACA,MAAI,IAAI,YAAY;AAClB,UAAM,YAAYF,KAAAA,KAAK,IAAI,YAAY,MAAM;AAC7C,QAAI,MAAM,WAAW,SAAS,GAAG;AAC/B,aAAO;AAAA,IACT;AAAA,EACF;AACA,QAAM,WAAWA,KAAAA,KAAK,WAAW,YAAY,cAAc,MAAM;AACjE,MAAI,MAAM,WAAW,QAAQ,GAAG;AAC9B,WAAO;AAAA,EACT;AACA,SAAO;AACT;ACrEO,MAAM,sBAAsB,CAAC,WAA2B;AAC7D,SAAO;AAAA,IACL,OAAO,CAAC,QAAgB,QAAQ,MAAM,IAAI,MAAM,MAAM,GAAG,EAAE;AAAA,IAC3D,MAAM,CAAC,QAAgB,QAAQ,KAAK,IAAI,MAAM,MAAM,GAAG,EAAE;AAAA,IACzD,MAAM,CAAC,QAAgB,QAAQ,KAAK,IAAI,MAAM,MAAM,GAAG,EAAE;AAAA,IACzD,OAAO,CAAC,QAAgB,QAAQ,MAAM,IAAI,MAAM,MAAM,GAAG,EAAE;AAAA,EAAA;AAE/D;ACOA,MAAM,uBAAuB;AAC7B,MAAM,uBAAuBA,KAAAA,KAAK,OAAO,MAAM;AAC/C,MAAM,yBAAyBA,KAAAA,KAAKM,UAAA,GAAU,WAAW;AACzD,MAAM,+BAA+B;AAIrC,IAAI,gBAAgB;AAEpB,MAAM,YAAY,CAAC,OAAe,SAAS,MACzC,OAAO,KAAK,EAAE,SAAS,QAAQ,GAAG;AAEpC,MAAM,kBAAkB,CAAC,SAAe;AACtC,QAAM,OAAO,KAAK,YAAA;AAClB,QAAM,QAAQ,UAAU,KAAK,SAAA,IAAa,CAAC;AAC3C,QAAM,MAAM,UAAU,KAAK,QAAA,CAAS;AACpC,QAAM,OAAO,UAAU,KAAK,SAAA,CAAU;AACtC,QAAM,SAAS,UAAU,KAAK,WAAA,CAAY;AAC1C,QAAM,SAAS,UAAU,KAAK,WAAA,CAAY;AAC1C,SAAO,GAAG,IAAI,GAAG,KAAK,GAAG,GAAG,IAAI,IAAI,GAAG,MAAM,GAAG,MAAM;AACxD;AAEA,MAAM,gBAAgB,MAAM;AAC1B,mBAAiB;AACjB,QAAM,YAAY,gBAAgB,oBAAI,MAAM;AAC5C,QAAM,MAAM,OAAO,aAAa,EAAE,SAAS,GAAG,GAAG;AACjD,SAAO,GAAG,SAAS,IAAI,GAAG,IAAI,QAAQ,GAAG;AAC3C;AAEA,MAAM,cAAc,CAAC,UAAsB,QAAQ,CAAC,GAAG,KAAK,IAAI,CAAA;AAEhE,MAAM,0BAA0B,CAC9B,YACwB;AACxB,QAAM,EAAE,eAAe,GAAG,KAAA,IAAS,4BAAW,CAAA;AAC9C,SAAO;AAAA,IACL,eAAe,wCAAiB;AAAA,IAChC,GAAG;AAAA,EAAA;AAEP;AAEA,MAAM,eAAe,CACnB,QACA,YACI;AAAA,EACJ,GAAI,0BAAU,CAAA;AAAA,EACd,GAAI,0BAAU,CAAA;AAChB;AAEA,MAAM,cAAc,CAAC,SAAiB,UACpCC,KAAAA,WAAW,KAAK,IAAI,QAAQL,KAAAA,QAAQ,SAAS,KAAK;AAEpD,MAAM,qBAAqB,CACzB,OACA,KACA,UAEA,MAAM,QAAQ,qBAAqB,CAAC,QAAQ,QAAgB;AAC1D,QAAM,cAAc,IAAI,GAAG;AAC3B,MAAI,gBAAgB,QAAW;AAC7B,UAAM,IAAI,MAAM,wBAAwB,GAAG,QAAQ,KAAK,GAAG;AAAA,EAC7D;AACA,SAAO;AACT,CAAC;AAEH,MAAM,cAAc,CAClB,QACA,KACA,UACG,OAAO,IAAI,CAAC,UAAU,mBAAmB,OAAO,KAAK,KAAK,CAAC;AAEhE,MAAM,iBAAiB,CACrB,SACA,QACG;AACH,QAAM,WAAwC,CAAA;AAC9C,aAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,OAAO,GAAG;AAClD,QAAI,OAAO,UAAU,UAAU;AAC7B,eAAS,GAAG,IAAI,mBAAmB,OAAO,KAAK,WAAW,GAAG,EAAE;AAAA,IACjE,OAAO;AACL,eAAS,GAAG,IAAI;AAAA,IAClB;AAAA,EACF;AACA,SAAO;AACT;AAEA,MAAM,qBAAqB,CACzB,aACA,KACA,YACG;AACH,QAAM,WAAW,YAAY,aAAa,KAAK,aAAa;AAC5D,SAAO,SAAS,IAAI,CAAC,UAAU,YAAY,SAAS,KAAK,CAAC;AAC5D;AAEA,MAAM,iBAAiB,CACrB,SACA,KACA,WACG;AACH,QAAM,WAAW,mBAAmB,SAAS,KAAK,SAAS;AAC3D,SAAO,YAAY,QAAQ,QAAQ;AACrC;AAEA,MAAM,wBAAwB,CAC5B,UACA,KACA,WACG;AACH,QAAM,WAAW,YAAY,UAAU,KAAK,SAAS;AACrD,SAAO,SAAS,IAAI,CAAC,UAAU,YAAY,QAAQ,KAAK,CAAC;AAC3D;AAEA,MAAM,mBAAmB,CAAC,YACxB,OAAO,QAAQ,OAAO,EAAE,IAAI,CAAC,CAAC,KAAK,KAAK,MAAM,KAAK,GAAG,IAAI,OAAO,KAAK,CAAC,EAAE;AAE3E,MAAM,mBAAmB,CAACM,cAAsB;AAC9C,MAAIA,UAAQ,WAAW,GAAG;AACxB,WAAO,CAAA;AAAA,EACT;AACA,SAAO,CAAC,MAAM,sBAAsB,KAAK,UAAUA,SAAO,CAAC,EAAE;AAC/D;AAEA,MAAM,oBAAoB,CACxB,SACA,eACI;AAAA,EACJ,GAAG,QAAQ;AAAA,EACX,GAAG;AAAA,EACH,GAAG;AACL;AAEA,MAAM,uBAAuB,CAC3B,YACA,eACA,KACA,WACG;AACH,MAAI,eAAe;AACjB,WAAO,eAAe,eAAe,KAAK,MAAM;AAAA,EAClD;AACA,SAAON,KAAAA,QAAQ,QAAQ,GAAG,UAAU,OAAO;AAC7C;AAEA,MAAM,uBAAuB,OAC3B,eACA,KACA,WACG;AACH,QAAM,WACJ,iBAAiB,cAAc,SAAS,IACpC,gBACA,CAACF,KAAAA,KAAK,QAAQ,MAAM,KAAK,GAAGA,KAAAA,KAAK,QAAQ,MAAM,OAAO,CAAC;AAC7D,QAAM,mBAAmB,sBAAsB,UAAU,KAAK,MAAM;AACpE,QAAM,UAAU,MAAM,QAAQ;AAAA,IAC5B,iBAAiB,IAAI,CAAC,YAAYS,KAAAA,KAAK,SAAS,EAAE,OAAO,MAAM,CAAC;AAAA,EAAA;AAElE,QAAM,UAAU,QAAQ,KAAA;AACxB,UAAQ,KAAA;AACR,SAAO;AACT;AAEA,MAAM,mBAAmB,CAAC,SAAiB,eACzCC,KAAAA,SAAS,SAAS,UAAU,EACzB,QAAQ,UAAU,GAAG,EACrB,QAAQ,oBAAoB,GAAG;AAI7B,MAAM,YAAY,OACvB,YAC6B;;AAC7B,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI,UAAU,2BAA2B;AAAA,EACjD;AACA,MAAI,CAAC,QAAQ,QAAQ,CAAC,QAAQ,KAAK,SAAS;AAC1C,UAAM,IAAI,UAAU,gCAAgC;AAAA,EACtD;AACA,QAAM,UAAU,OAAO,QAAQ,QAAQ,KAAK,OAAO;AACnD,MAAI,QAAQ,WAAW,GAAG;AACxB,UAAM,IAAI,UAAU,iCAAiC;AAAA,EACvD;AAEA,QAAM,UAAS,aAAQ,WAAR,YAAkB,oBAAoB,WAAW;AAChE,QAAM,UAAUR,KAAAA,SAAQ,aAAQ,SAAR,YAAgB,QAAQ,KAAK;AAErD,QAAM,eAAe,wBAAwB,QAAQ,KAAK;AAC1D,QAAM,YAAY,MAAM,aAAa,YAAY;AACjD,QAAM,WAAW,MAAM,aAAa,WAAW,QAAQ,aAAa,MAAM;AAE1E,QAAM,UAAU;AAAA,IACd,GAAG;AAAA,IACH,MAAM;AAAA,EAAA;AAGR,QAAM,YAAY;AAAA,KAChB,aAAQ,WAAR,YAAkB;AAAA,IAClB;AAAA,IACA;AAAA,EAAA;AAEF,QAAM,YAAY;AAAA,KAChB,aAAQ,WAAR,YAAkB;AAAA,IAClB;AAAA,IACA;AAAA,EAAA;AAEF,QAAM,cAAc;AAAA,KAClB,aAAQ,aAAR,YAAoB;AAAA,IACpB;AAAA,IACA;AAAA,EAAA;AAGF,QAAM,SAAS,YAAY,SAAS,SAAS;AAC7C,QAAM,SAAS,YAAY,SAAS,SAAS;AAC7C,QAAM,WAAW,YAAY,SAAS,WAAW;AACjD,QAAM,UAAU,cAAA;AAChB,QAAM,cAAcA,KAAAA,QAAQ,UAAU,OAAO;AAC7C,QAAM,mBAAkB,aAAQ,oBAAR,YAA2B;AACnD,QAAM,YAAW,aAAQ,aAAR,YAAoB;AAErC,QAAM,cAAc;AAAA,IAClB,GAAG;AAAA,IACH,MAAM;AAAA,IACN,SAAS;AAAA,IACT,SAAS;AAAA,IACT,WAAW;AAAA,EAAA;AAGb,QAAM,cAAc,MAAM,mBAAmB,aAAa,SAAS;AACnE,QAAM,UAAS,aAAQ,KAAK,WAAb,YAAuB,CAAA;AAEtC,QAAM,gBAAgB,MAAM;AAC5B,QAAM,gBAAgB,QAAQ;AAC9B,QAAMG,SAAAA,GAAG,aAAa,EAAE,WAAW,MAAM,OAAO,MAAM;AACtD,QAAM,gBAAgB,WAAW;AAEjC,QAAM,WAAmC,CAAA;AAEzC,MAAI;AACF,eAAW,CAAC,YAAY,MAAM,KAAK,SAAS;AAC1C,YAAM,gBAAgB;AAAA,QACpB,GAAG,YAAY,OAAO,OAAO;AAAA,QAC7B,GAAG,YAAY,OAAO,OAAO;AAAA,MAAA;AAE/B,YAAM,oBAAoB;AAAA,QACxB,GAAG,YAAY,OAAO,WAAW;AAAA,QACjC,GAAG,YAAY,OAAO,WAAW;AAAA,MAAA;AAEnC,YAAM,gBAAgB;AAAA,QACpB,GAAG,YAAY,OAAO,OAAO;AAAA,QAC7B,GAAG,YAAY,OAAO,OAAO;AAAA,MAAA;AAE/B,YAAM,oBAAoB;AAAA,QACxB,GAAG,YAAY,OAAO,WAAW;AAAA,QACjC,GAAG,YAAY,OAAO,WAAW;AAAA,MAAA;AAEnC,YAAM,gBAAgB,aAAa,OAAO,SAAS,OAAO,OAAO;AAEjE,YAAM,YAAY;AAAA,QAChB,GAAG;AAAA,QACH,aAAa;AAAA,MAAA;AAEf,YAAM,WAAW,kBAAkB,WAAW,EAAE;AAEhD,YAAM,kBAAkB;AAAA,QACtB;AAAA,QACA,OAAO;AAAA,QACP;AAAA,QACA;AAAA,MAAA;AAGF,YAAM,UAAU,MAAM;AAAA,QACpB,OAAO;AAAA,QACP;AAAA,QACA;AAAA,MAAA;AAEF,UAAI,QAAQ,WAAW,GAAG;AACxB,cAAM,IAAI,MAAM,kCAAkC,UAAU,EAAE;AAAA,MAChE;AAEA,YAAM,iBAAiBH,KAAAA,QAAQ,aAAa,UAAU;AACtD,YAAMG,SAAAA,GAAG,gBAAgB,EAAE,WAAW,MAAM,OAAO,MAAM;AACzD,YAAM,gBAAgB,cAAc;AAEpC,YAAM,kBAAkB,YAAY,eAAe,WAAW,SAAS;AACvE,YAAM,sBAAsB;AAAA,QAC1B;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAEF,YAAM,kBAAkB,YAAY,eAAe,WAAW,SAAS;AACvE,YAAM,aAAa,iBAAiB,eAAe;AACnD,YAAM,cAAc;AAAA,QAClB;AAAA,QACA;AAAA,QACA;AAAA,MAAA,EACA,IAAI,CAAC,QAAQ,KAAK,GAAG,EAAE;AACzB,YAAM,aAAa;AAAA,QACjB,eAAe,eAAe,SAAS;AAAA,MAAA;AAGzC,aAAO,KAAK,qBAAqB,UAAU,EAAE;AAC7C,YAAM,gBAAgB,OAAO,WAAmB;AAC9C,cAAM,aAAa,iBAAiB,SAAS,MAAM;AACnD,cAAM,eAAeH,KAAAA,QAAQ,gBAAgB,GAAG,UAAU,IAAI;AAC9D,cAAM,OAAO;AAAA,UACX;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA,GAAG;AAAA,UACH,GAAG;AAAA,UACH,GAAG;AAAA,QAAA;AAEL,eAAO,MAAM,QAAQ,KAAK,KAAK,GAAG,CAAC,EAAE;AACrC,cAAM;AAAA,UACJ;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA,aAAa;AAAA,QAAA;AAEf,eAAO;AAAA,MACT;AACA,YAAM,yBAAyB,YAAY;AACzC,cAAMS,eAAwB,CAAA;AAC9B,mBAAW,UAAU,SAAS;AAC5BA,uBAAY,KAAK,MAAM,cAAc,MAAM,CAAC;AAAA,QAC9C;AACA,eAAOA;AAAAA,MACT;AACA,YAAM,cAAc,WAChB,MAAM,QAAQ,IAAI,QAAQ,IAAI,CAAC,WAAW,cAAc,MAAM,CAAC,CAAC,IAChE,MAAM,uBAAA;AAEV,aAAO,KAAK,mBAAmB,UAAU,EAAE;AAC3C,YAAM,WAAW;AAAA,QACf,GAAG;AAAA,QACH;AAAA,QACA;AAAA,QACA,GAAG;AAAA,QACH,GAAG;AAAA,MAAA;AAEL,aAAO,MAAM,QAAQ,SAAS,KAAK,GAAG,CAAC,EAAE;AACzC,YAAM;AAAA,QACJ;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,aAAa;AAAA,MAAA;AAGf,eAAS,UAAU,IAAI;AAAA,IACzB;AAAA,EACF,UAAA;AACE,QAAI,iBAAiB;AACnB,YAAMN,SAAAA,GAAG,aAAa,EAAE,WAAW,MAAM,OAAO,MAAM;AAAA,IACxD;AAAA,EACF;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,EAAA;AAEJ;;;","x_google_ignoreList":[0]}
|