chore: 添加 vue-i18n 依赖并更新 package.json
This commit is contained in:
		
							
								
								
									
										66651
									
								
								node_modules/vite/dist/node/chunks/dep-42dae6ba.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										66651
									
								
								node_modules/vite/dist/node/chunks/dep-42dae6ba.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										914
									
								
								node_modules/vite/dist/node/chunks/dep-6e2b5186.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										914
									
								
								node_modules/vite/dist/node/chunks/dep-6e2b5186.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,914 @@ | ||||
| import { E as getDefaultExportFromCjs } from './dep-42dae6ba.js'; | ||||
| import require$$0 from 'path'; | ||||
| import require$$0__default from 'fs'; | ||||
| import { l as lib } from './dep-c423598f.js'; | ||||
|  | ||||
| import { fileURLToPath as __cjs_fileURLToPath } from 'node:url'; | ||||
| import { dirname as __cjs_dirname } from 'node:path'; | ||||
| import { createRequire as __cjs_createRequire } from 'node:module'; | ||||
|  | ||||
| const __filename = __cjs_fileURLToPath(import.meta.url); | ||||
| const __dirname = __cjs_dirname(__filename); | ||||
| const require = __cjs_createRequire(import.meta.url); | ||||
| const __require = require; | ||||
| function _mergeNamespaces(n, m) { | ||||
|   for (var i = 0; i < m.length; i++) { | ||||
|     var e = m[i]; | ||||
|     if (typeof e !== 'string' && !Array.isArray(e)) { for (var k in e) { | ||||
|       if (k !== 'default' && !(k in n)) { | ||||
|         n[k] = e[k]; | ||||
|       } | ||||
|     } } | ||||
|   } | ||||
|   return n; | ||||
| } | ||||
|  | ||||
| const startsWithKeywordRegexp = /^(all|not|only|print|screen)/i; | ||||
|  | ||||
| var joinMedia$1 = function (parentMedia, childMedia) { | ||||
|   if (!parentMedia.length && childMedia.length) return childMedia | ||||
|   if (parentMedia.length && !childMedia.length) return parentMedia | ||||
|   if (!parentMedia.length && !childMedia.length) return [] | ||||
|  | ||||
|   const media = []; | ||||
|  | ||||
|   parentMedia.forEach(parentItem => { | ||||
|     const parentItemStartsWithKeyword = startsWithKeywordRegexp.test(parentItem); | ||||
|  | ||||
|     childMedia.forEach(childItem => { | ||||
|       const childItemStartsWithKeyword = startsWithKeywordRegexp.test(childItem); | ||||
|       if (parentItem !== childItem) { | ||||
|         if (childItemStartsWithKeyword && !parentItemStartsWithKeyword) { | ||||
|           media.push(`${childItem} and ${parentItem}`); | ||||
|         } else { | ||||
|           media.push(`${parentItem} and ${childItem}`); | ||||
|         } | ||||
|       } | ||||
|     }); | ||||
|   }); | ||||
|  | ||||
|   return media | ||||
| }; | ||||
|  | ||||
| var joinLayer$1 = function (parentLayer, childLayer) { | ||||
|   if (!parentLayer.length && childLayer.length) return childLayer | ||||
|   if (parentLayer.length && !childLayer.length) return parentLayer | ||||
|   if (!parentLayer.length && !childLayer.length) return [] | ||||
|  | ||||
|   return parentLayer.concat(childLayer) | ||||
| }; | ||||
|  | ||||
| var readCache$1 = {exports: {}}; | ||||
|  | ||||
| var pify$2 = {exports: {}}; | ||||
|  | ||||
| var processFn = function (fn, P, opts) { | ||||
| 	return function () { | ||||
| 		var that = this; | ||||
| 		var args = new Array(arguments.length); | ||||
|  | ||||
| 		for (var i = 0; i < arguments.length; i++) { | ||||
| 			args[i] = arguments[i]; | ||||
| 		} | ||||
|  | ||||
| 		return new P(function (resolve, reject) { | ||||
| 			args.push(function (err, result) { | ||||
| 				if (err) { | ||||
| 					reject(err); | ||||
| 				} else if (opts.multiArgs) { | ||||
| 					var results = new Array(arguments.length - 1); | ||||
|  | ||||
| 					for (var i = 1; i < arguments.length; i++) { | ||||
| 						results[i - 1] = arguments[i]; | ||||
| 					} | ||||
|  | ||||
| 					resolve(results); | ||||
| 				} else { | ||||
| 					resolve(result); | ||||
| 				} | ||||
| 			}); | ||||
|  | ||||
| 			fn.apply(that, args); | ||||
| 		}); | ||||
| 	}; | ||||
| }; | ||||
|  | ||||
| var pify$1 = pify$2.exports = function (obj, P, opts) { | ||||
| 	if (typeof P !== 'function') { | ||||
| 		opts = P; | ||||
| 		P = Promise; | ||||
| 	} | ||||
|  | ||||
| 	opts = opts || {}; | ||||
| 	opts.exclude = opts.exclude || [/.+Sync$/]; | ||||
|  | ||||
| 	var filter = function (key) { | ||||
| 		var match = function (pattern) { | ||||
| 			return typeof pattern === 'string' ? key === pattern : pattern.test(key); | ||||
| 		}; | ||||
|  | ||||
| 		return opts.include ? opts.include.some(match) : !opts.exclude.some(match); | ||||
| 	}; | ||||
|  | ||||
| 	var ret = typeof obj === 'function' ? function () { | ||||
| 		if (opts.excludeMain) { | ||||
| 			return obj.apply(this, arguments); | ||||
| 		} | ||||
|  | ||||
| 		return processFn(obj, P, opts).apply(this, arguments); | ||||
| 	} : {}; | ||||
|  | ||||
| 	return Object.keys(obj).reduce(function (ret, key) { | ||||
| 		var x = obj[key]; | ||||
|  | ||||
| 		ret[key] = typeof x === 'function' && filter(key) ? processFn(x, P, opts) : x; | ||||
|  | ||||
| 		return ret; | ||||
| 	}, ret); | ||||
| }; | ||||
|  | ||||
| pify$1.all = pify$1; | ||||
|  | ||||
| var pifyExports = pify$2.exports; | ||||
|  | ||||
| var fs = require$$0__default; | ||||
| var path$2 = require$$0; | ||||
| var pify = pifyExports; | ||||
|  | ||||
| var stat = pify(fs.stat); | ||||
| var readFile = pify(fs.readFile); | ||||
| var resolve = path$2.resolve; | ||||
|  | ||||
| var cache = Object.create(null); | ||||
|  | ||||
| function convert(content, encoding) { | ||||
| 	if (Buffer.isEncoding(encoding)) { | ||||
| 		return content.toString(encoding); | ||||
| 	} | ||||
| 	return content; | ||||
| } | ||||
|  | ||||
| readCache$1.exports = function (path, encoding) { | ||||
| 	path = resolve(path); | ||||
|  | ||||
| 	return stat(path).then(function (stats) { | ||||
| 		var item = cache[path]; | ||||
|  | ||||
| 		if (item && item.mtime.getTime() === stats.mtime.getTime()) { | ||||
| 			return convert(item.content, encoding); | ||||
| 		} | ||||
|  | ||||
| 		return readFile(path).then(function (data) { | ||||
| 			cache[path] = { | ||||
| 				mtime: stats.mtime, | ||||
| 				content: data | ||||
| 			}; | ||||
|  | ||||
| 			return convert(data, encoding); | ||||
| 		}); | ||||
| 	}).catch(function (err) { | ||||
| 		cache[path] = null; | ||||
| 		return Promise.reject(err); | ||||
| 	}); | ||||
| }; | ||||
|  | ||||
| readCache$1.exports.sync = function (path, encoding) { | ||||
| 	path = resolve(path); | ||||
|  | ||||
| 	try { | ||||
| 		var stats = fs.statSync(path); | ||||
| 		var item = cache[path]; | ||||
|  | ||||
| 		if (item && item.mtime.getTime() === stats.mtime.getTime()) { | ||||
| 			return convert(item.content, encoding); | ||||
| 		} | ||||
|  | ||||
| 		var data = fs.readFileSync(path); | ||||
|  | ||||
| 		cache[path] = { | ||||
| 			mtime: stats.mtime, | ||||
| 			content: data | ||||
| 		}; | ||||
|  | ||||
| 		return convert(data, encoding); | ||||
| 	} catch (err) { | ||||
| 		cache[path] = null; | ||||
| 		throw err; | ||||
| 	} | ||||
|  | ||||
| }; | ||||
|  | ||||
| readCache$1.exports.get = function (path, encoding) { | ||||
| 	path = resolve(path); | ||||
| 	if (cache[path]) { | ||||
| 		return convert(cache[path].content, encoding); | ||||
| 	} | ||||
| 	return null; | ||||
| }; | ||||
|  | ||||
| readCache$1.exports.clear = function () { | ||||
| 	cache = Object.create(null); | ||||
| }; | ||||
|  | ||||
| var readCacheExports = readCache$1.exports; | ||||
|  | ||||
| const dataURLRegexp = /^data:text\/css;base64,/i; | ||||
|  | ||||
| function isValid(url) { | ||||
|   return dataURLRegexp.test(url) | ||||
| } | ||||
|  | ||||
| function contents(url) { | ||||
|   // "data:text/css;base64,".length === 21 | ||||
|   return Buffer.from(url.slice(21), "base64").toString() | ||||
| } | ||||
|  | ||||
| var dataUrl = { | ||||
|   isValid, | ||||
|   contents, | ||||
| }; | ||||
|  | ||||
| const readCache = readCacheExports; | ||||
| const dataURL$1 = dataUrl; | ||||
|  | ||||
| var loadContent$1 = filename => { | ||||
|   if (dataURL$1.isValid(filename)) { | ||||
|     return dataURL$1.contents(filename) | ||||
|   } | ||||
|  | ||||
|   return readCache(filename, "utf-8") | ||||
| }; | ||||
|  | ||||
| // builtin tooling | ||||
| const path$1 = require$$0; | ||||
|  | ||||
| // placeholder tooling | ||||
| let sugarss; | ||||
|  | ||||
| var processContent$1 = function processContent( | ||||
|   result, | ||||
|   content, | ||||
|   filename, | ||||
|   options, | ||||
|   postcss | ||||
| ) { | ||||
|   const { plugins } = options; | ||||
|   const ext = path$1.extname(filename); | ||||
|  | ||||
|   const parserList = []; | ||||
|  | ||||
|   // SugarSS support: | ||||
|   if (ext === ".sss") { | ||||
|     if (!sugarss) { | ||||
|       try { | ||||
|         sugarss = __require('sugarss'); | ||||
|       } catch {} // Ignore | ||||
|     } | ||||
|     if (sugarss) | ||||
|       return runPostcss(postcss, content, filename, plugins, [sugarss]) | ||||
|   } | ||||
|  | ||||
|   // Syntax support: | ||||
|   if (result.opts.syntax?.parse) { | ||||
|     parserList.push(result.opts.syntax.parse); | ||||
|   } | ||||
|  | ||||
|   // Parser support: | ||||
|   if (result.opts.parser) parserList.push(result.opts.parser); | ||||
|   // Try the default as a last resort: | ||||
|   parserList.push(null); | ||||
|  | ||||
|   return runPostcss(postcss, content, filename, plugins, parserList) | ||||
| }; | ||||
|  | ||||
| function runPostcss(postcss, content, filename, plugins, parsers, index) { | ||||
|   if (!index) index = 0; | ||||
|   return postcss(plugins) | ||||
|     .process(content, { | ||||
|       from: filename, | ||||
|       parser: parsers[index], | ||||
|     }) | ||||
|     .catch(err => { | ||||
|       // If there's an error, try the next parser | ||||
|       index++; | ||||
|       // If there are no parsers left, throw it | ||||
|       if (index === parsers.length) throw err | ||||
|       return runPostcss(postcss, content, filename, plugins, parsers, index) | ||||
|     }) | ||||
| } | ||||
|  | ||||
| // external tooling | ||||
| const valueParser = lib; | ||||
|  | ||||
| // extended tooling | ||||
| const { stringify } = valueParser; | ||||
|  | ||||
| function split(params, start) { | ||||
|   const list = []; | ||||
|   const last = params.reduce((item, node, index) => { | ||||
|     if (index < start) return "" | ||||
|     if (node.type === "div" && node.value === ",") { | ||||
|       list.push(item); | ||||
|       return "" | ||||
|     } | ||||
|     return item + stringify(node) | ||||
|   }, ""); | ||||
|   list.push(last); | ||||
|   return list | ||||
| } | ||||
|  | ||||
| var parseStatements$1 = function (result, styles) { | ||||
|   const statements = []; | ||||
|   let nodes = []; | ||||
|  | ||||
|   styles.each(node => { | ||||
|     let stmt; | ||||
|     if (node.type === "atrule") { | ||||
|       if (node.name === "import") stmt = parseImport(result, node); | ||||
|       else if (node.name === "media") stmt = parseMedia(result, node); | ||||
|       else if (node.name === "charset") stmt = parseCharset(result, node); | ||||
|     } | ||||
|  | ||||
|     if (stmt) { | ||||
|       if (nodes.length) { | ||||
|         statements.push({ | ||||
|           type: "nodes", | ||||
|           nodes, | ||||
|           media: [], | ||||
|           layer: [], | ||||
|         }); | ||||
|         nodes = []; | ||||
|       } | ||||
|       statements.push(stmt); | ||||
|     } else nodes.push(node); | ||||
|   }); | ||||
|  | ||||
|   if (nodes.length) { | ||||
|     statements.push({ | ||||
|       type: "nodes", | ||||
|       nodes, | ||||
|       media: [], | ||||
|       layer: [], | ||||
|     }); | ||||
|   } | ||||
|  | ||||
|   return statements | ||||
| }; | ||||
|  | ||||
| function parseMedia(result, atRule) { | ||||
|   const params = valueParser(atRule.params).nodes; | ||||
|   return { | ||||
|     type: "media", | ||||
|     node: atRule, | ||||
|     media: split(params, 0), | ||||
|     layer: [], | ||||
|   } | ||||
| } | ||||
|  | ||||
| function parseCharset(result, atRule) { | ||||
|   if (atRule.prev()) { | ||||
|     return result.warn("@charset must precede all other statements", { | ||||
|       node: atRule, | ||||
|     }) | ||||
|   } | ||||
|   return { | ||||
|     type: "charset", | ||||
|     node: atRule, | ||||
|     media: [], | ||||
|     layer: [], | ||||
|   } | ||||
| } | ||||
|  | ||||
| function parseImport(result, atRule) { | ||||
|   let prev = atRule.prev(); | ||||
|   if (prev) { | ||||
|     do { | ||||
|       if ( | ||||
|         prev.type !== "comment" && | ||||
|         (prev.type !== "atrule" || | ||||
|           (prev.name !== "import" && | ||||
|             prev.name !== "charset" && | ||||
|             !(prev.name === "layer" && !prev.nodes))) | ||||
|       ) { | ||||
|         return result.warn( | ||||
|           "@import must precede all other statements (besides @charset or empty @layer)", | ||||
|           { node: atRule } | ||||
|         ) | ||||
|       } | ||||
|       prev = prev.prev(); | ||||
|     } while (prev) | ||||
|   } | ||||
|  | ||||
|   if (atRule.nodes) { | ||||
|     return result.warn( | ||||
|       "It looks like you didn't end your @import statement correctly. " + | ||||
|         "Child nodes are attached to it.", | ||||
|       { node: atRule } | ||||
|     ) | ||||
|   } | ||||
|  | ||||
|   const params = valueParser(atRule.params).nodes; | ||||
|   const stmt = { | ||||
|     type: "import", | ||||
|     node: atRule, | ||||
|     media: [], | ||||
|     layer: [], | ||||
|   }; | ||||
|  | ||||
|   // prettier-ignore | ||||
|   if ( | ||||
|     !params.length || | ||||
|     ( | ||||
|       params[0].type !== "string" || | ||||
|       !params[0].value | ||||
|     ) && | ||||
|     ( | ||||
|       params[0].type !== "function" || | ||||
|       params[0].value !== "url" || | ||||
|       !params[0].nodes.length || | ||||
|       !params[0].nodes[0].value | ||||
|     ) | ||||
|   ) { | ||||
|     return result.warn(`Unable to find uri in '${  atRule.toString()  }'`, { | ||||
|       node: atRule, | ||||
|     }) | ||||
|   } | ||||
|  | ||||
|   if (params[0].type === "string") stmt.uri = params[0].value; | ||||
|   else stmt.uri = params[0].nodes[0].value; | ||||
|   stmt.fullUri = stringify(params[0]); | ||||
|  | ||||
|   let remainder = params; | ||||
|   if (remainder.length > 2) { | ||||
|     if ( | ||||
|       (remainder[2].type === "word" || remainder[2].type === "function") && | ||||
|       remainder[2].value === "layer" | ||||
|     ) { | ||||
|       if (remainder[1].type !== "space") { | ||||
|         return result.warn("Invalid import layer statement", { node: atRule }) | ||||
|       } | ||||
|  | ||||
|       if (remainder[2].nodes) { | ||||
|         stmt.layer = [stringify(remainder[2].nodes)]; | ||||
|       } else { | ||||
|         stmt.layer = [""]; | ||||
|       } | ||||
|       remainder = remainder.slice(2); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   if (remainder.length > 2) { | ||||
|     if (remainder[1].type !== "space") { | ||||
|       return result.warn("Invalid import media statement", { node: atRule }) | ||||
|     } | ||||
|  | ||||
|     stmt.media = split(remainder, 2); | ||||
|   } | ||||
|  | ||||
|   return stmt | ||||
| } | ||||
|  | ||||
| var assignLayerNames$1 = function (layer, node, state, options) { | ||||
|   layer.forEach((layerPart, i) => { | ||||
|     if (layerPart.trim() === "") { | ||||
|       if (options.nameLayer) { | ||||
|         layer[i] = options | ||||
|           .nameLayer(state.anonymousLayerCounter++, state.rootFilename) | ||||
|           .toString(); | ||||
|       } else { | ||||
|         throw node.error( | ||||
|           `When using anonymous layers in @import you must also set the "nameLayer" plugin option` | ||||
|         ) | ||||
|       } | ||||
|     } | ||||
|   }); | ||||
| }; | ||||
|  | ||||
| // builtin tooling | ||||
| const path = require$$0; | ||||
|  | ||||
| // internal tooling | ||||
| const joinMedia = joinMedia$1; | ||||
| const joinLayer = joinLayer$1; | ||||
| const resolveId = (id) => id; | ||||
| const loadContent = loadContent$1; | ||||
| const processContent = processContent$1; | ||||
| const parseStatements = parseStatements$1; | ||||
| const assignLayerNames = assignLayerNames$1; | ||||
| const dataURL = dataUrl; | ||||
|  | ||||
| function AtImport(options) { | ||||
|   options = { | ||||
|     root: process.cwd(), | ||||
|     path: [], | ||||
|     skipDuplicates: true, | ||||
|     resolve: resolveId, | ||||
|     load: loadContent, | ||||
|     plugins: [], | ||||
|     addModulesDirectories: [], | ||||
|     nameLayer: null, | ||||
|     ...options, | ||||
|   }; | ||||
|  | ||||
|   options.root = path.resolve(options.root); | ||||
|  | ||||
|   // convert string to an array of a single element | ||||
|   if (typeof options.path === "string") options.path = [options.path]; | ||||
|  | ||||
|   if (!Array.isArray(options.path)) options.path = []; | ||||
|  | ||||
|   options.path = options.path.map(p => path.resolve(options.root, p)); | ||||
|  | ||||
|   return { | ||||
|     postcssPlugin: "postcss-import", | ||||
|     Once(styles, { result, atRule, postcss }) { | ||||
|       const state = { | ||||
|         importedFiles: {}, | ||||
|         hashFiles: {}, | ||||
|         rootFilename: null, | ||||
|         anonymousLayerCounter: 0, | ||||
|       }; | ||||
|  | ||||
|       if (styles.source?.input?.file) { | ||||
|         state.rootFilename = styles.source.input.file; | ||||
|         state.importedFiles[styles.source.input.file] = {}; | ||||
|       } | ||||
|  | ||||
|       if (options.plugins && !Array.isArray(options.plugins)) { | ||||
|         throw new Error("plugins option must be an array") | ||||
|       } | ||||
|  | ||||
|       if (options.nameLayer && typeof options.nameLayer !== "function") { | ||||
|         throw new Error("nameLayer option must be a function") | ||||
|       } | ||||
|  | ||||
|       return parseStyles(result, styles, options, state, [], []).then( | ||||
|         bundle => { | ||||
|           applyRaws(bundle); | ||||
|           applyMedia(bundle); | ||||
|           applyStyles(bundle, styles); | ||||
|         } | ||||
|       ) | ||||
|  | ||||
|       function applyRaws(bundle) { | ||||
|         bundle.forEach((stmt, index) => { | ||||
|           if (index === 0) return | ||||
|  | ||||
|           if (stmt.parent) { | ||||
|             const { before } = stmt.parent.node.raws; | ||||
|             if (stmt.type === "nodes") stmt.nodes[0].raws.before = before; | ||||
|             else stmt.node.raws.before = before; | ||||
|           } else if (stmt.type === "nodes") { | ||||
|             stmt.nodes[0].raws.before = stmt.nodes[0].raws.before || "\n"; | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|  | ||||
|       function applyMedia(bundle) { | ||||
|         bundle.forEach(stmt => { | ||||
|           if ( | ||||
|             (!stmt.media.length && !stmt.layer.length) || | ||||
|             stmt.type === "charset" | ||||
|           ) { | ||||
|             return | ||||
|           } | ||||
|  | ||||
|           if (stmt.layer.length > 1) { | ||||
|             assignLayerNames(stmt.layer, stmt.node, state, options); | ||||
|           } | ||||
|  | ||||
|           if (stmt.type === "import") { | ||||
|             const parts = [stmt.fullUri]; | ||||
|  | ||||
|             const media = stmt.media.join(", "); | ||||
|  | ||||
|             if (stmt.layer.length) { | ||||
|               const layerName = stmt.layer.join("."); | ||||
|  | ||||
|               let layerParams = "layer"; | ||||
|               if (layerName) { | ||||
|                 layerParams = `layer(${layerName})`; | ||||
|               } | ||||
|  | ||||
|               parts.push(layerParams); | ||||
|             } | ||||
|  | ||||
|             if (media) { | ||||
|               parts.push(media); | ||||
|             } | ||||
|  | ||||
|             stmt.node.params = parts.join(" "); | ||||
|           } else if (stmt.type === "media") { | ||||
|             if (stmt.layer.length) { | ||||
|               const layerNode = atRule({ | ||||
|                 name: "layer", | ||||
|                 params: stmt.layer.join("."), | ||||
|                 source: stmt.node.source, | ||||
|               }); | ||||
|  | ||||
|               if (stmt.parentMedia?.length) { | ||||
|                 const mediaNode = atRule({ | ||||
|                   name: "media", | ||||
|                   params: stmt.parentMedia.join(", "), | ||||
|                   source: stmt.node.source, | ||||
|                 }); | ||||
|  | ||||
|                 mediaNode.append(layerNode); | ||||
|                 layerNode.append(stmt.node); | ||||
|                 stmt.node = mediaNode; | ||||
|               } else { | ||||
|                 layerNode.append(stmt.node); | ||||
|                 stmt.node = layerNode; | ||||
|               } | ||||
|             } else { | ||||
|               stmt.node.params = stmt.media.join(", "); | ||||
|             } | ||||
|           } else { | ||||
|             const { nodes } = stmt; | ||||
|             const { parent } = nodes[0]; | ||||
|  | ||||
|             let outerAtRule; | ||||
|             let innerAtRule; | ||||
|             if (stmt.media.length && stmt.layer.length) { | ||||
|               const mediaNode = atRule({ | ||||
|                 name: "media", | ||||
|                 params: stmt.media.join(", "), | ||||
|                 source: parent.source, | ||||
|               }); | ||||
|  | ||||
|               const layerNode = atRule({ | ||||
|                 name: "layer", | ||||
|                 params: stmt.layer.join("."), | ||||
|                 source: parent.source, | ||||
|               }); | ||||
|  | ||||
|               mediaNode.append(layerNode); | ||||
|               innerAtRule = layerNode; | ||||
|               outerAtRule = mediaNode; | ||||
|             } else if (stmt.media.length) { | ||||
|               const mediaNode = atRule({ | ||||
|                 name: "media", | ||||
|                 params: stmt.media.join(", "), | ||||
|                 source: parent.source, | ||||
|               }); | ||||
|  | ||||
|               innerAtRule = mediaNode; | ||||
|               outerAtRule = mediaNode; | ||||
|             } else if (stmt.layer.length) { | ||||
|               const layerNode = atRule({ | ||||
|                 name: "layer", | ||||
|                 params: stmt.layer.join("."), | ||||
|                 source: parent.source, | ||||
|               }); | ||||
|  | ||||
|               innerAtRule = layerNode; | ||||
|               outerAtRule = layerNode; | ||||
|             } | ||||
|  | ||||
|             parent.insertBefore(nodes[0], outerAtRule); | ||||
|  | ||||
|             // remove nodes | ||||
|             nodes.forEach(node => { | ||||
|               node.parent = undefined; | ||||
|             }); | ||||
|  | ||||
|             // better output | ||||
|             nodes[0].raws.before = nodes[0].raws.before || "\n"; | ||||
|  | ||||
|             // wrap new rules with media query and/or layer at rule | ||||
|             innerAtRule.append(nodes); | ||||
|  | ||||
|             stmt.type = "media"; | ||||
|             stmt.node = outerAtRule; | ||||
|             delete stmt.nodes; | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|  | ||||
|       function applyStyles(bundle, styles) { | ||||
|         styles.nodes = []; | ||||
|  | ||||
|         // Strip additional statements. | ||||
|         bundle.forEach(stmt => { | ||||
|           if (["charset", "import", "media"].includes(stmt.type)) { | ||||
|             stmt.node.parent = undefined; | ||||
|             styles.append(stmt.node); | ||||
|           } else if (stmt.type === "nodes") { | ||||
|             stmt.nodes.forEach(node => { | ||||
|               node.parent = undefined; | ||||
|               styles.append(node); | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|  | ||||
|       function parseStyles(result, styles, options, state, media, layer) { | ||||
|         const statements = parseStatements(result, styles); | ||||
|  | ||||
|         return Promise.resolve(statements) | ||||
|           .then(stmts => { | ||||
|             // process each statement in series | ||||
|             return stmts.reduce((promise, stmt) => { | ||||
|               return promise.then(() => { | ||||
|                 stmt.media = joinMedia(media, stmt.media || []); | ||||
|                 stmt.parentMedia = media; | ||||
|                 stmt.layer = joinLayer(layer, stmt.layer || []); | ||||
|  | ||||
|                 // skip protocol base uri (protocol://url) or protocol-relative | ||||
|                 if ( | ||||
|                   stmt.type !== "import" || | ||||
|                   /^(?:[a-z]+:)?\/\//i.test(stmt.uri) | ||||
|                 ) { | ||||
|                   return | ||||
|                 } | ||||
|  | ||||
|                 if (options.filter && !options.filter(stmt.uri)) { | ||||
|                   // rejected by filter | ||||
|                   return | ||||
|                 } | ||||
|  | ||||
|                 return resolveImportId(result, stmt, options, state) | ||||
|               }) | ||||
|             }, Promise.resolve()) | ||||
|           }) | ||||
|           .then(() => { | ||||
|             let charset; | ||||
|             const imports = []; | ||||
|             const bundle = []; | ||||
|  | ||||
|             function handleCharset(stmt) { | ||||
|               if (!charset) charset = stmt; | ||||
|               // charsets aren't case-sensitive, so convert to lower case to compare | ||||
|               else if ( | ||||
|                 stmt.node.params.toLowerCase() !== | ||||
|                 charset.node.params.toLowerCase() | ||||
|               ) { | ||||
|                 throw new Error( | ||||
|                   `Incompatable @charset statements: | ||||
|   ${stmt.node.params} specified in ${stmt.node.source.input.file} | ||||
|   ${charset.node.params} specified in ${charset.node.source.input.file}` | ||||
|                 ) | ||||
|               } | ||||
|             } | ||||
|  | ||||
|             // squash statements and their children | ||||
|             statements.forEach(stmt => { | ||||
|               if (stmt.type === "charset") handleCharset(stmt); | ||||
|               else if (stmt.type === "import") { | ||||
|                 if (stmt.children) { | ||||
|                   stmt.children.forEach((child, index) => { | ||||
|                     if (child.type === "import") imports.push(child); | ||||
|                     else if (child.type === "charset") handleCharset(child); | ||||
|                     else bundle.push(child); | ||||
|                     // For better output | ||||
|                     if (index === 0) child.parent = stmt; | ||||
|                   }); | ||||
|                 } else imports.push(stmt); | ||||
|               } else if (stmt.type === "media" || stmt.type === "nodes") { | ||||
|                 bundle.push(stmt); | ||||
|               } | ||||
|             }); | ||||
|  | ||||
|             return charset | ||||
|               ? [charset, ...imports.concat(bundle)] | ||||
|               : imports.concat(bundle) | ||||
|           }) | ||||
|       } | ||||
|  | ||||
|       function resolveImportId(result, stmt, options, state) { | ||||
|         if (dataURL.isValid(stmt.uri)) { | ||||
|           return loadImportContent(result, stmt, stmt.uri, options, state).then( | ||||
|             result => { | ||||
|               stmt.children = result; | ||||
|             } | ||||
|           ) | ||||
|         } | ||||
|  | ||||
|         const atRule = stmt.node; | ||||
|         let sourceFile; | ||||
|         if (atRule.source?.input?.file) { | ||||
|           sourceFile = atRule.source.input.file; | ||||
|         } | ||||
|         const base = sourceFile | ||||
|           ? path.dirname(atRule.source.input.file) | ||||
|           : options.root; | ||||
|  | ||||
|         return Promise.resolve(options.resolve(stmt.uri, base, options)) | ||||
|           .then(paths => { | ||||
|             if (!Array.isArray(paths)) paths = [paths]; | ||||
|             // Ensure that each path is absolute: | ||||
|             return Promise.all( | ||||
|               paths.map(file => { | ||||
|                 return !path.isAbsolute(file) | ||||
|                   ? resolveId(file) | ||||
|                   : file | ||||
|               }) | ||||
|             ) | ||||
|           }) | ||||
|           .then(resolved => { | ||||
|             // Add dependency messages: | ||||
|             resolved.forEach(file => { | ||||
|               result.messages.push({ | ||||
|                 type: "dependency", | ||||
|                 plugin: "postcss-import", | ||||
|                 file, | ||||
|                 parent: sourceFile, | ||||
|               }); | ||||
|             }); | ||||
|  | ||||
|             return Promise.all( | ||||
|               resolved.map(file => { | ||||
|                 return loadImportContent(result, stmt, file, options, state) | ||||
|               }) | ||||
|             ) | ||||
|           }) | ||||
|           .then(result => { | ||||
|             // Merge loaded statements | ||||
|             stmt.children = result.reduce((result, statements) => { | ||||
|               return statements ? result.concat(statements) : result | ||||
|             }, []); | ||||
|           }) | ||||
|       } | ||||
|  | ||||
|       function loadImportContent(result, stmt, filename, options, state) { | ||||
|         const atRule = stmt.node; | ||||
|         const { media, layer } = stmt; | ||||
|  | ||||
|         assignLayerNames(layer, atRule, state, options); | ||||
|  | ||||
|         if (options.skipDuplicates) { | ||||
|           // skip files already imported at the same scope | ||||
|           if (state.importedFiles[filename]?.[media]?.[layer]) { | ||||
|             return | ||||
|           } | ||||
|  | ||||
|           // save imported files to skip them next time | ||||
|           if (!state.importedFiles[filename]) { | ||||
|             state.importedFiles[filename] = {}; | ||||
|           } | ||||
|           if (!state.importedFiles[filename][media]) { | ||||
|             state.importedFiles[filename][media] = {}; | ||||
|           } | ||||
|           state.importedFiles[filename][media][layer] = true; | ||||
|         } | ||||
|  | ||||
|         return Promise.resolve(options.load(filename, options)).then( | ||||
|           content => { | ||||
|             if (content.trim() === "") { | ||||
|               result.warn(`${filename} is empty`, { node: atRule }); | ||||
|               return | ||||
|             } | ||||
|  | ||||
|             // skip previous imported files not containing @import rules | ||||
|             if (state.hashFiles[content]?.[media]?.[layer]) { | ||||
|               return | ||||
|             } | ||||
|  | ||||
|             return processContent( | ||||
|               result, | ||||
|               content, | ||||
|               filename, | ||||
|               options, | ||||
|               postcss | ||||
|             ).then(importedResult => { | ||||
|               const styles = importedResult.root; | ||||
|               result.messages = result.messages.concat(importedResult.messages); | ||||
|  | ||||
|               if (options.skipDuplicates) { | ||||
|                 const hasImport = styles.some(child => { | ||||
|                   return child.type === "atrule" && child.name === "import" | ||||
|                 }); | ||||
|                 if (!hasImport) { | ||||
|                   // save hash files to skip them next time | ||||
|                   if (!state.hashFiles[content]) { | ||||
|                     state.hashFiles[content] = {}; | ||||
|                   } | ||||
|                   if (!state.hashFiles[content][media]) { | ||||
|                     state.hashFiles[content][media] = {}; | ||||
|                   } | ||||
|                   state.hashFiles[content][media][layer] = true; | ||||
|                 } | ||||
|               } | ||||
|  | ||||
|               // recursion: import @import from imported file | ||||
|               return parseStyles(result, styles, options, state, media, layer) | ||||
|             }) | ||||
|           } | ||||
|         ) | ||||
|       } | ||||
|     }, | ||||
|   } | ||||
| } | ||||
|  | ||||
| AtImport.postcss = true; | ||||
|  | ||||
| var postcssImport = AtImport; | ||||
|  | ||||
| var index = /*@__PURE__*/getDefaultExportFromCjs(postcssImport); | ||||
|  | ||||
| var index$1 = /*#__PURE__*/_mergeNamespaces({ | ||||
|   __proto__: null, | ||||
|   default: index | ||||
| }, [postcssImport]); | ||||
|  | ||||
| export { index$1 as i }; | ||||
							
								
								
									
										561
									
								
								node_modules/vite/dist/node/chunks/dep-c423598f.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										561
									
								
								node_modules/vite/dist/node/chunks/dep-c423598f.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,561 @@ | ||||
| import { fileURLToPath as __cjs_fileURLToPath } from 'node:url'; | ||||
| import { dirname as __cjs_dirname } from 'node:path'; | ||||
| import { createRequire as __cjs_createRequire } from 'node:module'; | ||||
|  | ||||
| const __filename = __cjs_fileURLToPath(import.meta.url); | ||||
| const __dirname = __cjs_dirname(__filename); | ||||
| const require = __cjs_createRequire(import.meta.url); | ||||
| const __require = require; | ||||
| var openParentheses = "(".charCodeAt(0); | ||||
| var closeParentheses = ")".charCodeAt(0); | ||||
| var singleQuote = "'".charCodeAt(0); | ||||
| var doubleQuote = '"'.charCodeAt(0); | ||||
| var backslash = "\\".charCodeAt(0); | ||||
| var slash = "/".charCodeAt(0); | ||||
| var comma = ",".charCodeAt(0); | ||||
| var colon = ":".charCodeAt(0); | ||||
| var star = "*".charCodeAt(0); | ||||
| var uLower = "u".charCodeAt(0); | ||||
| var uUpper = "U".charCodeAt(0); | ||||
| var plus = "+".charCodeAt(0); | ||||
| var isUnicodeRange = /^[a-f0-9?-]+$/i; | ||||
|  | ||||
| var parse$1 = function(input) { | ||||
|   var tokens = []; | ||||
|   var value = input; | ||||
|  | ||||
|   var next, | ||||
|     quote, | ||||
|     prev, | ||||
|     token, | ||||
|     escape, | ||||
|     escapePos, | ||||
|     whitespacePos, | ||||
|     parenthesesOpenPos; | ||||
|   var pos = 0; | ||||
|   var code = value.charCodeAt(pos); | ||||
|   var max = value.length; | ||||
|   var stack = [{ nodes: tokens }]; | ||||
|   var balanced = 0; | ||||
|   var parent; | ||||
|  | ||||
|   var name = ""; | ||||
|   var before = ""; | ||||
|   var after = ""; | ||||
|  | ||||
|   while (pos < max) { | ||||
|     // Whitespaces | ||||
|     if (code <= 32) { | ||||
|       next = pos; | ||||
|       do { | ||||
|         next += 1; | ||||
|         code = value.charCodeAt(next); | ||||
|       } while (code <= 32); | ||||
|       token = value.slice(pos, next); | ||||
|  | ||||
|       prev = tokens[tokens.length - 1]; | ||||
|       if (code === closeParentheses && balanced) { | ||||
|         after = token; | ||||
|       } else if (prev && prev.type === "div") { | ||||
|         prev.after = token; | ||||
|         prev.sourceEndIndex += token.length; | ||||
|       } else if ( | ||||
|         code === comma || | ||||
|         code === colon || | ||||
|         (code === slash && | ||||
|           value.charCodeAt(next + 1) !== star && | ||||
|           (!parent || | ||||
|             (parent && parent.type === "function" && parent.value !== "calc"))) | ||||
|       ) { | ||||
|         before = token; | ||||
|       } else { | ||||
|         tokens.push({ | ||||
|           type: "space", | ||||
|           sourceIndex: pos, | ||||
|           sourceEndIndex: next, | ||||
|           value: token | ||||
|         }); | ||||
|       } | ||||
|  | ||||
|       pos = next; | ||||
|  | ||||
|       // Quotes | ||||
|     } else if (code === singleQuote || code === doubleQuote) { | ||||
|       next = pos; | ||||
|       quote = code === singleQuote ? "'" : '"'; | ||||
|       token = { | ||||
|         type: "string", | ||||
|         sourceIndex: pos, | ||||
|         quote: quote | ||||
|       }; | ||||
|       do { | ||||
|         escape = false; | ||||
|         next = value.indexOf(quote, next + 1); | ||||
|         if (~next) { | ||||
|           escapePos = next; | ||||
|           while (value.charCodeAt(escapePos - 1) === backslash) { | ||||
|             escapePos -= 1; | ||||
|             escape = !escape; | ||||
|           } | ||||
|         } else { | ||||
|           value += quote; | ||||
|           next = value.length - 1; | ||||
|           token.unclosed = true; | ||||
|         } | ||||
|       } while (escape); | ||||
|       token.value = value.slice(pos + 1, next); | ||||
|       token.sourceEndIndex = token.unclosed ? next : next + 1; | ||||
|       tokens.push(token); | ||||
|       pos = next + 1; | ||||
|       code = value.charCodeAt(pos); | ||||
|  | ||||
|       // Comments | ||||
|     } else if (code === slash && value.charCodeAt(pos + 1) === star) { | ||||
|       next = value.indexOf("*/", pos); | ||||
|  | ||||
|       token = { | ||||
|         type: "comment", | ||||
|         sourceIndex: pos, | ||||
|         sourceEndIndex: next + 2 | ||||
|       }; | ||||
|  | ||||
|       if (next === -1) { | ||||
|         token.unclosed = true; | ||||
|         next = value.length; | ||||
|         token.sourceEndIndex = next; | ||||
|       } | ||||
|  | ||||
|       token.value = value.slice(pos + 2, next); | ||||
|       tokens.push(token); | ||||
|  | ||||
|       pos = next + 2; | ||||
|       code = value.charCodeAt(pos); | ||||
|  | ||||
|       // Operation within calc | ||||
|     } else if ( | ||||
|       (code === slash || code === star) && | ||||
|       parent && | ||||
|       parent.type === "function" && | ||||
|       parent.value === "calc" | ||||
|     ) { | ||||
|       token = value[pos]; | ||||
|       tokens.push({ | ||||
|         type: "word", | ||||
|         sourceIndex: pos - before.length, | ||||
|         sourceEndIndex: pos + token.length, | ||||
|         value: token | ||||
|       }); | ||||
|       pos += 1; | ||||
|       code = value.charCodeAt(pos); | ||||
|  | ||||
|       // Dividers | ||||
|     } else if (code === slash || code === comma || code === colon) { | ||||
|       token = value[pos]; | ||||
|  | ||||
|       tokens.push({ | ||||
|         type: "div", | ||||
|         sourceIndex: pos - before.length, | ||||
|         sourceEndIndex: pos + token.length, | ||||
|         value: token, | ||||
|         before: before, | ||||
|         after: "" | ||||
|       }); | ||||
|       before = ""; | ||||
|  | ||||
|       pos += 1; | ||||
|       code = value.charCodeAt(pos); | ||||
|  | ||||
|       // Open parentheses | ||||
|     } else if (openParentheses === code) { | ||||
|       // Whitespaces after open parentheses | ||||
|       next = pos; | ||||
|       do { | ||||
|         next += 1; | ||||
|         code = value.charCodeAt(next); | ||||
|       } while (code <= 32); | ||||
|       parenthesesOpenPos = pos; | ||||
|       token = { | ||||
|         type: "function", | ||||
|         sourceIndex: pos - name.length, | ||||
|         value: name, | ||||
|         before: value.slice(parenthesesOpenPos + 1, next) | ||||
|       }; | ||||
|       pos = next; | ||||
|  | ||||
|       if (name === "url" && code !== singleQuote && code !== doubleQuote) { | ||||
|         next -= 1; | ||||
|         do { | ||||
|           escape = false; | ||||
|           next = value.indexOf(")", next + 1); | ||||
|           if (~next) { | ||||
|             escapePos = next; | ||||
|             while (value.charCodeAt(escapePos - 1) === backslash) { | ||||
|               escapePos -= 1; | ||||
|               escape = !escape; | ||||
|             } | ||||
|           } else { | ||||
|             value += ")"; | ||||
|             next = value.length - 1; | ||||
|             token.unclosed = true; | ||||
|           } | ||||
|         } while (escape); | ||||
|         // Whitespaces before closed | ||||
|         whitespacePos = next; | ||||
|         do { | ||||
|           whitespacePos -= 1; | ||||
|           code = value.charCodeAt(whitespacePos); | ||||
|         } while (code <= 32); | ||||
|         if (parenthesesOpenPos < whitespacePos) { | ||||
|           if (pos !== whitespacePos + 1) { | ||||
|             token.nodes = [ | ||||
|               { | ||||
|                 type: "word", | ||||
|                 sourceIndex: pos, | ||||
|                 sourceEndIndex: whitespacePos + 1, | ||||
|                 value: value.slice(pos, whitespacePos + 1) | ||||
|               } | ||||
|             ]; | ||||
|           } else { | ||||
|             token.nodes = []; | ||||
|           } | ||||
|           if (token.unclosed && whitespacePos + 1 !== next) { | ||||
|             token.after = ""; | ||||
|             token.nodes.push({ | ||||
|               type: "space", | ||||
|               sourceIndex: whitespacePos + 1, | ||||
|               sourceEndIndex: next, | ||||
|               value: value.slice(whitespacePos + 1, next) | ||||
|             }); | ||||
|           } else { | ||||
|             token.after = value.slice(whitespacePos + 1, next); | ||||
|             token.sourceEndIndex = next; | ||||
|           } | ||||
|         } else { | ||||
|           token.after = ""; | ||||
|           token.nodes = []; | ||||
|         } | ||||
|         pos = next + 1; | ||||
|         token.sourceEndIndex = token.unclosed ? next : pos; | ||||
|         code = value.charCodeAt(pos); | ||||
|         tokens.push(token); | ||||
|       } else { | ||||
|         balanced += 1; | ||||
|         token.after = ""; | ||||
|         token.sourceEndIndex = pos + 1; | ||||
|         tokens.push(token); | ||||
|         stack.push(token); | ||||
|         tokens = token.nodes = []; | ||||
|         parent = token; | ||||
|       } | ||||
|       name = ""; | ||||
|  | ||||
|       // Close parentheses | ||||
|     } else if (closeParentheses === code && balanced) { | ||||
|       pos += 1; | ||||
|       code = value.charCodeAt(pos); | ||||
|  | ||||
|       parent.after = after; | ||||
|       parent.sourceEndIndex += after.length; | ||||
|       after = ""; | ||||
|       balanced -= 1; | ||||
|       stack[stack.length - 1].sourceEndIndex = pos; | ||||
|       stack.pop(); | ||||
|       parent = stack[balanced]; | ||||
|       tokens = parent.nodes; | ||||
|  | ||||
|       // Words | ||||
|     } else { | ||||
|       next = pos; | ||||
|       do { | ||||
|         if (code === backslash) { | ||||
|           next += 1; | ||||
|         } | ||||
|         next += 1; | ||||
|         code = value.charCodeAt(next); | ||||
|       } while ( | ||||
|         next < max && | ||||
|         !( | ||||
|           code <= 32 || | ||||
|           code === singleQuote || | ||||
|           code === doubleQuote || | ||||
|           code === comma || | ||||
|           code === colon || | ||||
|           code === slash || | ||||
|           code === openParentheses || | ||||
|           (code === star && | ||||
|             parent && | ||||
|             parent.type === "function" && | ||||
|             parent.value === "calc") || | ||||
|           (code === slash && | ||||
|             parent.type === "function" && | ||||
|             parent.value === "calc") || | ||||
|           (code === closeParentheses && balanced) | ||||
|         ) | ||||
|       ); | ||||
|       token = value.slice(pos, next); | ||||
|  | ||||
|       if (openParentheses === code) { | ||||
|         name = token; | ||||
|       } else if ( | ||||
|         (uLower === token.charCodeAt(0) || uUpper === token.charCodeAt(0)) && | ||||
|         plus === token.charCodeAt(1) && | ||||
|         isUnicodeRange.test(token.slice(2)) | ||||
|       ) { | ||||
|         tokens.push({ | ||||
|           type: "unicode-range", | ||||
|           sourceIndex: pos, | ||||
|           sourceEndIndex: next, | ||||
|           value: token | ||||
|         }); | ||||
|       } else { | ||||
|         tokens.push({ | ||||
|           type: "word", | ||||
|           sourceIndex: pos, | ||||
|           sourceEndIndex: next, | ||||
|           value: token | ||||
|         }); | ||||
|       } | ||||
|  | ||||
|       pos = next; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   for (pos = stack.length - 1; pos; pos -= 1) { | ||||
|     stack[pos].unclosed = true; | ||||
|     stack[pos].sourceEndIndex = value.length; | ||||
|   } | ||||
|  | ||||
|   return stack[0].nodes; | ||||
| }; | ||||
|  | ||||
| var walk$1 = function walk(nodes, cb, bubble) { | ||||
|   var i, max, node, result; | ||||
|  | ||||
|   for (i = 0, max = nodes.length; i < max; i += 1) { | ||||
|     node = nodes[i]; | ||||
|     if (!bubble) { | ||||
|       result = cb(node, i, nodes); | ||||
|     } | ||||
|  | ||||
|     if ( | ||||
|       result !== false && | ||||
|       node.type === "function" && | ||||
|       Array.isArray(node.nodes) | ||||
|     ) { | ||||
|       walk(node.nodes, cb, bubble); | ||||
|     } | ||||
|  | ||||
|     if (bubble) { | ||||
|       cb(node, i, nodes); | ||||
|     } | ||||
|   } | ||||
| }; | ||||
|  | ||||
| function stringifyNode(node, custom) { | ||||
|   var type = node.type; | ||||
|   var value = node.value; | ||||
|   var buf; | ||||
|   var customResult; | ||||
|  | ||||
|   if (custom && (customResult = custom(node)) !== undefined) { | ||||
|     return customResult; | ||||
|   } else if (type === "word" || type === "space") { | ||||
|     return value; | ||||
|   } else if (type === "string") { | ||||
|     buf = node.quote || ""; | ||||
|     return buf + value + (node.unclosed ? "" : buf); | ||||
|   } else if (type === "comment") { | ||||
|     return "/*" + value + (node.unclosed ? "" : "*/"); | ||||
|   } else if (type === "div") { | ||||
|     return (node.before || "") + value + (node.after || ""); | ||||
|   } else if (Array.isArray(node.nodes)) { | ||||
|     buf = stringify$1(node.nodes, custom); | ||||
|     if (type !== "function") { | ||||
|       return buf; | ||||
|     } | ||||
|     return ( | ||||
|       value + | ||||
|       "(" + | ||||
|       (node.before || "") + | ||||
|       buf + | ||||
|       (node.after || "") + | ||||
|       (node.unclosed ? "" : ")") | ||||
|     ); | ||||
|   } | ||||
|   return value; | ||||
| } | ||||
|  | ||||
| function stringify$1(nodes, custom) { | ||||
|   var result, i; | ||||
|  | ||||
|   if (Array.isArray(nodes)) { | ||||
|     result = ""; | ||||
|     for (i = nodes.length - 1; ~i; i -= 1) { | ||||
|       result = stringifyNode(nodes[i], custom) + result; | ||||
|     } | ||||
|     return result; | ||||
|   } | ||||
|   return stringifyNode(nodes, custom); | ||||
| } | ||||
|  | ||||
| var stringify_1 = stringify$1; | ||||
|  | ||||
| var unit; | ||||
| var hasRequiredUnit; | ||||
|  | ||||
| function requireUnit () { | ||||
| 	if (hasRequiredUnit) return unit; | ||||
| 	hasRequiredUnit = 1; | ||||
| 	var minus = "-".charCodeAt(0); | ||||
| 	var plus = "+".charCodeAt(0); | ||||
| 	var dot = ".".charCodeAt(0); | ||||
| 	var exp = "e".charCodeAt(0); | ||||
| 	var EXP = "E".charCodeAt(0); | ||||
|  | ||||
| 	// Check if three code points would start a number | ||||
| 	// https://www.w3.org/TR/css-syntax-3/#starts-with-a-number | ||||
| 	function likeNumber(value) { | ||||
| 	  var code = value.charCodeAt(0); | ||||
| 	  var nextCode; | ||||
|  | ||||
| 	  if (code === plus || code === minus) { | ||||
| 	    nextCode = value.charCodeAt(1); | ||||
|  | ||||
| 	    if (nextCode >= 48 && nextCode <= 57) { | ||||
| 	      return true; | ||||
| 	    } | ||||
|  | ||||
| 	    var nextNextCode = value.charCodeAt(2); | ||||
|  | ||||
| 	    if (nextCode === dot && nextNextCode >= 48 && nextNextCode <= 57) { | ||||
| 	      return true; | ||||
| 	    } | ||||
|  | ||||
| 	    return false; | ||||
| 	  } | ||||
|  | ||||
| 	  if (code === dot) { | ||||
| 	    nextCode = value.charCodeAt(1); | ||||
|  | ||||
| 	    if (nextCode >= 48 && nextCode <= 57) { | ||||
| 	      return true; | ||||
| 	    } | ||||
|  | ||||
| 	    return false; | ||||
| 	  } | ||||
|  | ||||
| 	  if (code >= 48 && code <= 57) { | ||||
| 	    return true; | ||||
| 	  } | ||||
|  | ||||
| 	  return false; | ||||
| 	} | ||||
|  | ||||
| 	// Consume a number | ||||
| 	// https://www.w3.org/TR/css-syntax-3/#consume-number | ||||
| 	unit = function(value) { | ||||
| 	  var pos = 0; | ||||
| 	  var length = value.length; | ||||
| 	  var code; | ||||
| 	  var nextCode; | ||||
| 	  var nextNextCode; | ||||
|  | ||||
| 	  if (length === 0 || !likeNumber(value)) { | ||||
| 	    return false; | ||||
| 	  } | ||||
|  | ||||
| 	  code = value.charCodeAt(pos); | ||||
|  | ||||
| 	  if (code === plus || code === minus) { | ||||
| 	    pos++; | ||||
| 	  } | ||||
|  | ||||
| 	  while (pos < length) { | ||||
| 	    code = value.charCodeAt(pos); | ||||
|  | ||||
| 	    if (code < 48 || code > 57) { | ||||
| 	      break; | ||||
| 	    } | ||||
|  | ||||
| 	    pos += 1; | ||||
| 	  } | ||||
|  | ||||
| 	  code = value.charCodeAt(pos); | ||||
| 	  nextCode = value.charCodeAt(pos + 1); | ||||
|  | ||||
| 	  if (code === dot && nextCode >= 48 && nextCode <= 57) { | ||||
| 	    pos += 2; | ||||
|  | ||||
| 	    while (pos < length) { | ||||
| 	      code = value.charCodeAt(pos); | ||||
|  | ||||
| 	      if (code < 48 || code > 57) { | ||||
| 	        break; | ||||
| 	      } | ||||
|  | ||||
| 	      pos += 1; | ||||
| 	    } | ||||
| 	  } | ||||
|  | ||||
| 	  code = value.charCodeAt(pos); | ||||
| 	  nextCode = value.charCodeAt(pos + 1); | ||||
| 	  nextNextCode = value.charCodeAt(pos + 2); | ||||
|  | ||||
| 	  if ( | ||||
| 	    (code === exp || code === EXP) && | ||||
| 	    ((nextCode >= 48 && nextCode <= 57) || | ||||
| 	      ((nextCode === plus || nextCode === minus) && | ||||
| 	        nextNextCode >= 48 && | ||||
| 	        nextNextCode <= 57)) | ||||
| 	  ) { | ||||
| 	    pos += nextCode === plus || nextCode === minus ? 3 : 2; | ||||
|  | ||||
| 	    while (pos < length) { | ||||
| 	      code = value.charCodeAt(pos); | ||||
|  | ||||
| 	      if (code < 48 || code > 57) { | ||||
| 	        break; | ||||
| 	      } | ||||
|  | ||||
| 	      pos += 1; | ||||
| 	    } | ||||
| 	  } | ||||
|  | ||||
| 	  return { | ||||
| 	    number: value.slice(0, pos), | ||||
| 	    unit: value.slice(pos) | ||||
| 	  }; | ||||
| 	}; | ||||
| 	return unit; | ||||
| } | ||||
|  | ||||
| var parse = parse$1; | ||||
| var walk = walk$1; | ||||
| var stringify = stringify_1; | ||||
|  | ||||
| function ValueParser(value) { | ||||
|   if (this instanceof ValueParser) { | ||||
|     this.nodes = parse(value); | ||||
|     return this; | ||||
|   } | ||||
|   return new ValueParser(value); | ||||
| } | ||||
|  | ||||
| ValueParser.prototype.toString = function() { | ||||
|   return Array.isArray(this.nodes) ? stringify(this.nodes) : ""; | ||||
| }; | ||||
|  | ||||
| ValueParser.prototype.walk = function(cb, bubble) { | ||||
|   walk(this.nodes, cb, bubble); | ||||
|   return this; | ||||
| }; | ||||
|  | ||||
| ValueParser.unit = requireUnit(); | ||||
|  | ||||
| ValueParser.walk = walk; | ||||
|  | ||||
| ValueParser.stringify = stringify; | ||||
|  | ||||
| var lib = ValueParser; | ||||
|  | ||||
| export { lib as l }; | ||||
							
								
								
									
										7646
									
								
								node_modules/vite/dist/node/chunks/dep-e967375e.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7646
									
								
								node_modules/vite/dist/node/chunks/dep-e967375e.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										7930
									
								
								node_modules/vite/dist/node/chunks/dep-f0c7dae0.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7930
									
								
								node_modules/vite/dist/node/chunks/dep-f0c7dae0.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										929
									
								
								node_modules/vite/dist/node/cli.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										929
									
								
								node_modules/vite/dist/node/cli.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,929 @@ | ||||
| import path from 'node:path'; | ||||
| import fs from 'node:fs'; | ||||
| import { performance } from 'node:perf_hooks'; | ||||
| import { EventEmitter } from 'events'; | ||||
| import { C as colors, D as bindShortcuts, x as createLogger, h as resolveConfig } from './chunks/dep-42dae6ba.js'; | ||||
| import { VERSION } from './constants.js'; | ||||
| import 'node:fs/promises'; | ||||
| import 'node:url'; | ||||
| import 'node:util'; | ||||
| import 'node:module'; | ||||
| import 'node:crypto'; | ||||
| import 'tty'; | ||||
| import 'esbuild'; | ||||
| import 'path'; | ||||
| import 'fs'; | ||||
| import 'assert'; | ||||
| import 'util'; | ||||
| import 'net'; | ||||
| import 'url'; | ||||
| import 'http'; | ||||
| import 'stream'; | ||||
| import 'os'; | ||||
| import 'child_process'; | ||||
| import 'node:os'; | ||||
| import 'node:child_process'; | ||||
| import 'node:dns'; | ||||
| import 'crypto'; | ||||
| import 'node:buffer'; | ||||
| import 'module'; | ||||
| import 'node:assert'; | ||||
| import 'node:process'; | ||||
| import 'node:v8'; | ||||
| import 'rollup'; | ||||
| import 'worker_threads'; | ||||
| import 'node:http'; | ||||
| import 'node:https'; | ||||
| import 'zlib'; | ||||
| import 'buffer'; | ||||
| import 'https'; | ||||
| import 'tls'; | ||||
| import 'node:net'; | ||||
| import 'querystring'; | ||||
| import 'node:readline'; | ||||
| import 'node:zlib'; | ||||
|  | ||||
| function toArr(any) { | ||||
| 	return any == null ? [] : Array.isArray(any) ? any : [any]; | ||||
| } | ||||
|  | ||||
| function toVal(out, key, val, opts) { | ||||
| 	var x, old=out[key], nxt=( | ||||
| 		!!~opts.string.indexOf(key) ? (val == null || val === true ? '' : String(val)) | ||||
| 		: typeof val === 'boolean' ? val | ||||
| 		: !!~opts.boolean.indexOf(key) ? (val === 'false' ? false : val === 'true' || (out._.push((x = +val,x * 0 === 0) ? x : val),!!val)) | ||||
| 		: (x = +val,x * 0 === 0) ? x : val | ||||
| 	); | ||||
| 	out[key] = old == null ? nxt : (Array.isArray(old) ? old.concat(nxt) : [old, nxt]); | ||||
| } | ||||
|  | ||||
| function mri2 (args, opts) { | ||||
| 	args = args || []; | ||||
| 	opts = opts || {}; | ||||
|  | ||||
| 	var k, arr, arg, name, val, out={ _:[] }; | ||||
| 	var i=0, j=0, idx=0, len=args.length; | ||||
|  | ||||
| 	const alibi = opts.alias !== void 0; | ||||
| 	const strict = opts.unknown !== void 0; | ||||
| 	const defaults = opts.default !== void 0; | ||||
|  | ||||
| 	opts.alias = opts.alias || {}; | ||||
| 	opts.string = toArr(opts.string); | ||||
| 	opts.boolean = toArr(opts.boolean); | ||||
|  | ||||
| 	if (alibi) { | ||||
| 		for (k in opts.alias) { | ||||
| 			arr = opts.alias[k] = toArr(opts.alias[k]); | ||||
| 			for (i=0; i < arr.length; i++) { | ||||
| 				(opts.alias[arr[i]] = arr.concat(k)).splice(i, 1); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	for (i=opts.boolean.length; i-- > 0;) { | ||||
| 		arr = opts.alias[opts.boolean[i]] || []; | ||||
| 		for (j=arr.length; j-- > 0;) opts.boolean.push(arr[j]); | ||||
| 	} | ||||
|  | ||||
| 	for (i=opts.string.length; i-- > 0;) { | ||||
| 		arr = opts.alias[opts.string[i]] || []; | ||||
| 		for (j=arr.length; j-- > 0;) opts.string.push(arr[j]); | ||||
| 	} | ||||
|  | ||||
| 	if (defaults) { | ||||
| 		for (k in opts.default) { | ||||
| 			name = typeof opts.default[k]; | ||||
| 			arr = opts.alias[k] = opts.alias[k] || []; | ||||
| 			if (opts[name] !== void 0) { | ||||
| 				opts[name].push(k); | ||||
| 				for (i=0; i < arr.length; i++) { | ||||
| 					opts[name].push(arr[i]); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	const keys = strict ? Object.keys(opts.alias) : []; | ||||
|  | ||||
| 	for (i=0; i < len; i++) { | ||||
| 		arg = args[i]; | ||||
|  | ||||
| 		if (arg === '--') { | ||||
| 			out._ = out._.concat(args.slice(++i)); | ||||
| 			break; | ||||
| 		} | ||||
|  | ||||
| 		for (j=0; j < arg.length; j++) { | ||||
| 			if (arg.charCodeAt(j) !== 45) break; // "-" | ||||
| 		} | ||||
|  | ||||
| 		if (j === 0) { | ||||
| 			out._.push(arg); | ||||
| 		} else if (arg.substring(j, j + 3) === 'no-') { | ||||
| 			name = arg.substring(j + 3); | ||||
| 			if (strict && !~keys.indexOf(name)) { | ||||
| 				return opts.unknown(arg); | ||||
| 			} | ||||
| 			out[name] = false; | ||||
| 		} else { | ||||
| 			for (idx=j+1; idx < arg.length; idx++) { | ||||
| 				if (arg.charCodeAt(idx) === 61) break; // "=" | ||||
| 			} | ||||
|  | ||||
| 			name = arg.substring(j, idx); | ||||
| 			val = arg.substring(++idx) || (i+1 === len || (''+args[i+1]).charCodeAt(0) === 45 || args[++i]); | ||||
| 			arr = (j === 2 ? [name] : name); | ||||
|  | ||||
| 			for (idx=0; idx < arr.length; idx++) { | ||||
| 				name = arr[idx]; | ||||
| 				if (strict && !~keys.indexOf(name)) return opts.unknown('-'.repeat(j) + name); | ||||
| 				toVal(out, name, (idx + 1 < arr.length) || val, opts); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (defaults) { | ||||
| 		for (k in opts.default) { | ||||
| 			if (out[k] === void 0) { | ||||
| 				out[k] = opts.default[k]; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (alibi) { | ||||
| 		for (k in out) { | ||||
| 			arr = opts.alias[k] || []; | ||||
| 			while (arr.length > 0) { | ||||
| 				out[arr.shift()] = out[k]; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return out; | ||||
| } | ||||
|  | ||||
| const removeBrackets = (v) => v.replace(/[<[].+/, "").trim(); | ||||
| const findAllBrackets = (v) => { | ||||
|   const ANGLED_BRACKET_RE_GLOBAL = /<([^>]+)>/g; | ||||
|   const SQUARE_BRACKET_RE_GLOBAL = /\[([^\]]+)\]/g; | ||||
|   const res = []; | ||||
|   const parse = (match) => { | ||||
|     let variadic = false; | ||||
|     let value = match[1]; | ||||
|     if (value.startsWith("...")) { | ||||
|       value = value.slice(3); | ||||
|       variadic = true; | ||||
|     } | ||||
|     return { | ||||
|       required: match[0].startsWith("<"), | ||||
|       value, | ||||
|       variadic | ||||
|     }; | ||||
|   }; | ||||
|   let angledMatch; | ||||
|   while (angledMatch = ANGLED_BRACKET_RE_GLOBAL.exec(v)) { | ||||
|     res.push(parse(angledMatch)); | ||||
|   } | ||||
|   let squareMatch; | ||||
|   while (squareMatch = SQUARE_BRACKET_RE_GLOBAL.exec(v)) { | ||||
|     res.push(parse(squareMatch)); | ||||
|   } | ||||
|   return res; | ||||
| }; | ||||
| const getMriOptions = (options) => { | ||||
|   const result = {alias: {}, boolean: []}; | ||||
|   for (const [index, option] of options.entries()) { | ||||
|     if (option.names.length > 1) { | ||||
|       result.alias[option.names[0]] = option.names.slice(1); | ||||
|     } | ||||
|     if (option.isBoolean) { | ||||
|       if (option.negated) { | ||||
|         const hasStringTypeOption = options.some((o, i) => { | ||||
|           return i !== index && o.names.some((name) => option.names.includes(name)) && typeof o.required === "boolean"; | ||||
|         }); | ||||
|         if (!hasStringTypeOption) { | ||||
|           result.boolean.push(option.names[0]); | ||||
|         } | ||||
|       } else { | ||||
|         result.boolean.push(option.names[0]); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   return result; | ||||
| }; | ||||
| const findLongest = (arr) => { | ||||
|   return arr.sort((a, b) => { | ||||
|     return a.length > b.length ? -1 : 1; | ||||
|   })[0]; | ||||
| }; | ||||
| const padRight = (str, length) => { | ||||
|   return str.length >= length ? str : `${str}${" ".repeat(length - str.length)}`; | ||||
| }; | ||||
| const camelcase = (input) => { | ||||
|   return input.replace(/([a-z])-([a-z])/g, (_, p1, p2) => { | ||||
|     return p1 + p2.toUpperCase(); | ||||
|   }); | ||||
| }; | ||||
| const setDotProp = (obj, keys, val) => { | ||||
|   let i = 0; | ||||
|   let length = keys.length; | ||||
|   let t = obj; | ||||
|   let x; | ||||
|   for (; i < length; ++i) { | ||||
|     x = t[keys[i]]; | ||||
|     t = t[keys[i]] = i === length - 1 ? val : x != null ? x : !!~keys[i + 1].indexOf(".") || !(+keys[i + 1] > -1) ? {} : []; | ||||
|   } | ||||
| }; | ||||
| const setByType = (obj, transforms) => { | ||||
|   for (const key of Object.keys(transforms)) { | ||||
|     const transform = transforms[key]; | ||||
|     if (transform.shouldTransform) { | ||||
|       obj[key] = Array.prototype.concat.call([], obj[key]); | ||||
|       if (typeof transform.transformFunction === "function") { | ||||
|         obj[key] = obj[key].map(transform.transformFunction); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| }; | ||||
| const getFileName = (input) => { | ||||
|   const m = /([^\\\/]+)$/.exec(input); | ||||
|   return m ? m[1] : ""; | ||||
| }; | ||||
| const camelcaseOptionName = (name) => { | ||||
|   return name.split(".").map((v, i) => { | ||||
|     return i === 0 ? camelcase(v) : v; | ||||
|   }).join("."); | ||||
| }; | ||||
| class CACError extends Error { | ||||
|   constructor(message) { | ||||
|     super(message); | ||||
|     this.name = this.constructor.name; | ||||
|     if (typeof Error.captureStackTrace === "function") { | ||||
|       Error.captureStackTrace(this, this.constructor); | ||||
|     } else { | ||||
|       this.stack = new Error(message).stack; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| class Option { | ||||
|   constructor(rawName, description, config) { | ||||
|     this.rawName = rawName; | ||||
|     this.description = description; | ||||
|     this.config = Object.assign({}, config); | ||||
|     rawName = rawName.replace(/\.\*/g, ""); | ||||
|     this.negated = false; | ||||
|     this.names = removeBrackets(rawName).split(",").map((v) => { | ||||
|       let name = v.trim().replace(/^-{1,2}/, ""); | ||||
|       if (name.startsWith("no-")) { | ||||
|         this.negated = true; | ||||
|         name = name.replace(/^no-/, ""); | ||||
|       } | ||||
|       return camelcaseOptionName(name); | ||||
|     }).sort((a, b) => a.length > b.length ? 1 : -1); | ||||
|     this.name = this.names[this.names.length - 1]; | ||||
|     if (this.negated && this.config.default == null) { | ||||
|       this.config.default = true; | ||||
|     } | ||||
|     if (rawName.includes("<")) { | ||||
|       this.required = true; | ||||
|     } else if (rawName.includes("[")) { | ||||
|       this.required = false; | ||||
|     } else { | ||||
|       this.isBoolean = true; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| const processArgs = process.argv; | ||||
| const platformInfo = `${process.platform}-${process.arch} node-${process.version}`; | ||||
|  | ||||
| class Command { | ||||
|   constructor(rawName, description, config = {}, cli) { | ||||
|     this.rawName = rawName; | ||||
|     this.description = description; | ||||
|     this.config = config; | ||||
|     this.cli = cli; | ||||
|     this.options = []; | ||||
|     this.aliasNames = []; | ||||
|     this.name = removeBrackets(rawName); | ||||
|     this.args = findAllBrackets(rawName); | ||||
|     this.examples = []; | ||||
|   } | ||||
|   usage(text) { | ||||
|     this.usageText = text; | ||||
|     return this; | ||||
|   } | ||||
|   allowUnknownOptions() { | ||||
|     this.config.allowUnknownOptions = true; | ||||
|     return this; | ||||
|   } | ||||
|   ignoreOptionDefaultValue() { | ||||
|     this.config.ignoreOptionDefaultValue = true; | ||||
|     return this; | ||||
|   } | ||||
|   version(version, customFlags = "-v, --version") { | ||||
|     this.versionNumber = version; | ||||
|     this.option(customFlags, "Display version number"); | ||||
|     return this; | ||||
|   } | ||||
|   example(example) { | ||||
|     this.examples.push(example); | ||||
|     return this; | ||||
|   } | ||||
|   option(rawName, description, config) { | ||||
|     const option = new Option(rawName, description, config); | ||||
|     this.options.push(option); | ||||
|     return this; | ||||
|   } | ||||
|   alias(name) { | ||||
|     this.aliasNames.push(name); | ||||
|     return this; | ||||
|   } | ||||
|   action(callback) { | ||||
|     this.commandAction = callback; | ||||
|     return this; | ||||
|   } | ||||
|   isMatched(name) { | ||||
|     return this.name === name || this.aliasNames.includes(name); | ||||
|   } | ||||
|   get isDefaultCommand() { | ||||
|     return this.name === "" || this.aliasNames.includes("!"); | ||||
|   } | ||||
|   get isGlobalCommand() { | ||||
|     return this instanceof GlobalCommand; | ||||
|   } | ||||
|   hasOption(name) { | ||||
|     name = name.split(".")[0]; | ||||
|     return this.options.find((option) => { | ||||
|       return option.names.includes(name); | ||||
|     }); | ||||
|   } | ||||
|   outputHelp() { | ||||
|     const {name, commands} = this.cli; | ||||
|     const { | ||||
|       versionNumber, | ||||
|       options: globalOptions, | ||||
|       helpCallback | ||||
|     } = this.cli.globalCommand; | ||||
|     let sections = [ | ||||
|       { | ||||
|         body: `${name}${versionNumber ? `/${versionNumber}` : ""}` | ||||
|       } | ||||
|     ]; | ||||
|     sections.push({ | ||||
|       title: "Usage", | ||||
|       body: `  $ ${name} ${this.usageText || this.rawName}` | ||||
|     }); | ||||
|     const showCommands = (this.isGlobalCommand || this.isDefaultCommand) && commands.length > 0; | ||||
|     if (showCommands) { | ||||
|       const longestCommandName = findLongest(commands.map((command) => command.rawName)); | ||||
|       sections.push({ | ||||
|         title: "Commands", | ||||
|         body: commands.map((command) => { | ||||
|           return `  ${padRight(command.rawName, longestCommandName.length)}  ${command.description}`; | ||||
|         }).join("\n") | ||||
|       }); | ||||
|       sections.push({ | ||||
|         title: `For more info, run any command with the \`--help\` flag`, | ||||
|         body: commands.map((command) => `  $ ${name}${command.name === "" ? "" : ` ${command.name}`} --help`).join("\n") | ||||
|       }); | ||||
|     } | ||||
|     let options = this.isGlobalCommand ? globalOptions : [...this.options, ...globalOptions || []]; | ||||
|     if (!this.isGlobalCommand && !this.isDefaultCommand) { | ||||
|       options = options.filter((option) => option.name !== "version"); | ||||
|     } | ||||
|     if (options.length > 0) { | ||||
|       const longestOptionName = findLongest(options.map((option) => option.rawName)); | ||||
|       sections.push({ | ||||
|         title: "Options", | ||||
|         body: options.map((option) => { | ||||
|           return `  ${padRight(option.rawName, longestOptionName.length)}  ${option.description} ${option.config.default === void 0 ? "" : `(default: ${option.config.default})`}`; | ||||
|         }).join("\n") | ||||
|       }); | ||||
|     } | ||||
|     if (this.examples.length > 0) { | ||||
|       sections.push({ | ||||
|         title: "Examples", | ||||
|         body: this.examples.map((example) => { | ||||
|           if (typeof example === "function") { | ||||
|             return example(name); | ||||
|           } | ||||
|           return example; | ||||
|         }).join("\n") | ||||
|       }); | ||||
|     } | ||||
|     if (helpCallback) { | ||||
|       sections = helpCallback(sections) || sections; | ||||
|     } | ||||
|     console.log(sections.map((section) => { | ||||
|       return section.title ? `${section.title}: | ||||
| ${section.body}` : section.body; | ||||
|     }).join("\n\n")); | ||||
|   } | ||||
|   outputVersion() { | ||||
|     const {name} = this.cli; | ||||
|     const {versionNumber} = this.cli.globalCommand; | ||||
|     if (versionNumber) { | ||||
|       console.log(`${name}/${versionNumber} ${platformInfo}`); | ||||
|     } | ||||
|   } | ||||
|   checkRequiredArgs() { | ||||
|     const minimalArgsCount = this.args.filter((arg) => arg.required).length; | ||||
|     if (this.cli.args.length < minimalArgsCount) { | ||||
|       throw new CACError(`missing required args for command \`${this.rawName}\``); | ||||
|     } | ||||
|   } | ||||
|   checkUnknownOptions() { | ||||
|     const {options, globalCommand} = this.cli; | ||||
|     if (!this.config.allowUnknownOptions) { | ||||
|       for (const name of Object.keys(options)) { | ||||
|         if (name !== "--" && !this.hasOption(name) && !globalCommand.hasOption(name)) { | ||||
|           throw new CACError(`Unknown option \`${name.length > 1 ? `--${name}` : `-${name}`}\``); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   checkOptionValue() { | ||||
|     const {options: parsedOptions, globalCommand} = this.cli; | ||||
|     const options = [...globalCommand.options, ...this.options]; | ||||
|     for (const option of options) { | ||||
|       const value = parsedOptions[option.name.split(".")[0]]; | ||||
|       if (option.required) { | ||||
|         const hasNegated = options.some((o) => o.negated && o.names.includes(option.name)); | ||||
|         if (value === true || value === false && !hasNegated) { | ||||
|           throw new CACError(`option \`${option.rawName}\` value is missing`); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| class GlobalCommand extends Command { | ||||
|   constructor(cli) { | ||||
|     super("@@global@@", "", {}, cli); | ||||
|   } | ||||
| } | ||||
|  | ||||
| var __assign = Object.assign; | ||||
| class CAC extends EventEmitter { | ||||
|   constructor(name = "") { | ||||
|     super(); | ||||
|     this.name = name; | ||||
|     this.commands = []; | ||||
|     this.rawArgs = []; | ||||
|     this.args = []; | ||||
|     this.options = {}; | ||||
|     this.globalCommand = new GlobalCommand(this); | ||||
|     this.globalCommand.usage("<command> [options]"); | ||||
|   } | ||||
|   usage(text) { | ||||
|     this.globalCommand.usage(text); | ||||
|     return this; | ||||
|   } | ||||
|   command(rawName, description, config) { | ||||
|     const command = new Command(rawName, description || "", config, this); | ||||
|     command.globalCommand = this.globalCommand; | ||||
|     this.commands.push(command); | ||||
|     return command; | ||||
|   } | ||||
|   option(rawName, description, config) { | ||||
|     this.globalCommand.option(rawName, description, config); | ||||
|     return this; | ||||
|   } | ||||
|   help(callback) { | ||||
|     this.globalCommand.option("-h, --help", "Display this message"); | ||||
|     this.globalCommand.helpCallback = callback; | ||||
|     this.showHelpOnExit = true; | ||||
|     return this; | ||||
|   } | ||||
|   version(version, customFlags = "-v, --version") { | ||||
|     this.globalCommand.version(version, customFlags); | ||||
|     this.showVersionOnExit = true; | ||||
|     return this; | ||||
|   } | ||||
|   example(example) { | ||||
|     this.globalCommand.example(example); | ||||
|     return this; | ||||
|   } | ||||
|   outputHelp() { | ||||
|     if (this.matchedCommand) { | ||||
|       this.matchedCommand.outputHelp(); | ||||
|     } else { | ||||
|       this.globalCommand.outputHelp(); | ||||
|     } | ||||
|   } | ||||
|   outputVersion() { | ||||
|     this.globalCommand.outputVersion(); | ||||
|   } | ||||
|   setParsedInfo({args, options}, matchedCommand, matchedCommandName) { | ||||
|     this.args = args; | ||||
|     this.options = options; | ||||
|     if (matchedCommand) { | ||||
|       this.matchedCommand = matchedCommand; | ||||
|     } | ||||
|     if (matchedCommandName) { | ||||
|       this.matchedCommandName = matchedCommandName; | ||||
|     } | ||||
|     return this; | ||||
|   } | ||||
|   unsetMatchedCommand() { | ||||
|     this.matchedCommand = void 0; | ||||
|     this.matchedCommandName = void 0; | ||||
|   } | ||||
|   parse(argv = processArgs, { | ||||
|     run = true | ||||
|   } = {}) { | ||||
|     this.rawArgs = argv; | ||||
|     if (!this.name) { | ||||
|       this.name = argv[1] ? getFileName(argv[1]) : "cli"; | ||||
|     } | ||||
|     let shouldParse = true; | ||||
|     for (const command of this.commands) { | ||||
|       const parsed = this.mri(argv.slice(2), command); | ||||
|       const commandName = parsed.args[0]; | ||||
|       if (command.isMatched(commandName)) { | ||||
|         shouldParse = false; | ||||
|         const parsedInfo = __assign(__assign({}, parsed), { | ||||
|           args: parsed.args.slice(1) | ||||
|         }); | ||||
|         this.setParsedInfo(parsedInfo, command, commandName); | ||||
|         this.emit(`command:${commandName}`, command); | ||||
|       } | ||||
|     } | ||||
|     if (shouldParse) { | ||||
|       for (const command of this.commands) { | ||||
|         if (command.name === "") { | ||||
|           shouldParse = false; | ||||
|           const parsed = this.mri(argv.slice(2), command); | ||||
|           this.setParsedInfo(parsed, command); | ||||
|           this.emit(`command:!`, command); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     if (shouldParse) { | ||||
|       const parsed = this.mri(argv.slice(2)); | ||||
|       this.setParsedInfo(parsed); | ||||
|     } | ||||
|     if (this.options.help && this.showHelpOnExit) { | ||||
|       this.outputHelp(); | ||||
|       run = false; | ||||
|       this.unsetMatchedCommand(); | ||||
|     } | ||||
|     if (this.options.version && this.showVersionOnExit && this.matchedCommandName == null) { | ||||
|       this.outputVersion(); | ||||
|       run = false; | ||||
|       this.unsetMatchedCommand(); | ||||
|     } | ||||
|     const parsedArgv = {args: this.args, options: this.options}; | ||||
|     if (run) { | ||||
|       this.runMatchedCommand(); | ||||
|     } | ||||
|     if (!this.matchedCommand && this.args[0]) { | ||||
|       this.emit("command:*"); | ||||
|     } | ||||
|     return parsedArgv; | ||||
|   } | ||||
|   mri(argv, command) { | ||||
|     const cliOptions = [ | ||||
|       ...this.globalCommand.options, | ||||
|       ...command ? command.options : [] | ||||
|     ]; | ||||
|     const mriOptions = getMriOptions(cliOptions); | ||||
|     let argsAfterDoubleDashes = []; | ||||
|     const doubleDashesIndex = argv.indexOf("--"); | ||||
|     if (doubleDashesIndex > -1) { | ||||
|       argsAfterDoubleDashes = argv.slice(doubleDashesIndex + 1); | ||||
|       argv = argv.slice(0, doubleDashesIndex); | ||||
|     } | ||||
|     let parsed = mri2(argv, mriOptions); | ||||
|     parsed = Object.keys(parsed).reduce((res, name) => { | ||||
|       return __assign(__assign({}, res), { | ||||
|         [camelcaseOptionName(name)]: parsed[name] | ||||
|       }); | ||||
|     }, {_: []}); | ||||
|     const args = parsed._; | ||||
|     const options = { | ||||
|       "--": argsAfterDoubleDashes | ||||
|     }; | ||||
|     const ignoreDefault = command && command.config.ignoreOptionDefaultValue ? command.config.ignoreOptionDefaultValue : this.globalCommand.config.ignoreOptionDefaultValue; | ||||
|     let transforms = Object.create(null); | ||||
|     for (const cliOption of cliOptions) { | ||||
|       if (!ignoreDefault && cliOption.config.default !== void 0) { | ||||
|         for (const name of cliOption.names) { | ||||
|           options[name] = cliOption.config.default; | ||||
|         } | ||||
|       } | ||||
|       if (Array.isArray(cliOption.config.type)) { | ||||
|         if (transforms[cliOption.name] === void 0) { | ||||
|           transforms[cliOption.name] = Object.create(null); | ||||
|           transforms[cliOption.name]["shouldTransform"] = true; | ||||
|           transforms[cliOption.name]["transformFunction"] = cliOption.config.type[0]; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     for (const key of Object.keys(parsed)) { | ||||
|       if (key !== "_") { | ||||
|         const keys = key.split("."); | ||||
|         setDotProp(options, keys, parsed[key]); | ||||
|         setByType(options, transforms); | ||||
|       } | ||||
|     } | ||||
|     return { | ||||
|       args, | ||||
|       options | ||||
|     }; | ||||
|   } | ||||
|   runMatchedCommand() { | ||||
|     const {args, options, matchedCommand: command} = this; | ||||
|     if (!command || !command.commandAction) | ||||
|       return; | ||||
|     command.checkUnknownOptions(); | ||||
|     command.checkOptionValue(); | ||||
|     command.checkRequiredArgs(); | ||||
|     const actionArgs = []; | ||||
|     command.args.forEach((arg, index) => { | ||||
|       if (arg.variadic) { | ||||
|         actionArgs.push(args.slice(index)); | ||||
|       } else { | ||||
|         actionArgs.push(args[index]); | ||||
|       } | ||||
|     }); | ||||
|     actionArgs.push(options); | ||||
|     return command.commandAction.apply(this, actionArgs); | ||||
|   } | ||||
| } | ||||
|  | ||||
| const cac = (name = "") => new CAC(name); | ||||
|  | ||||
| const cli = cac('vite'); | ||||
| let profileSession = global.__vite_profile_session; | ||||
| let profileCount = 0; | ||||
| const stopProfiler = (log) => { | ||||
|     if (!profileSession) | ||||
|         return; | ||||
|     return new Promise((res, rej) => { | ||||
|         profileSession.post('Profiler.stop', (err, { profile }) => { | ||||
|             // Write profile to disk, upload, etc. | ||||
|             if (!err) { | ||||
|                 const outPath = path.resolve(`./vite-profile-${profileCount++}.cpuprofile`); | ||||
|                 fs.writeFileSync(outPath, JSON.stringify(profile)); | ||||
|                 log(colors.yellow(`CPU profile written to ${colors.white(colors.dim(outPath))}`)); | ||||
|                 profileSession = undefined; | ||||
|                 res(); | ||||
|             } | ||||
|             else { | ||||
|                 rej(err); | ||||
|             } | ||||
|         }); | ||||
|     }); | ||||
| }; | ||||
| const filterDuplicateOptions = (options) => { | ||||
|     for (const [key, value] of Object.entries(options)) { | ||||
|         if (Array.isArray(value)) { | ||||
|             options[key] = value[value.length - 1]; | ||||
|         } | ||||
|     } | ||||
| }; | ||||
| /** | ||||
|  * removing global flags before passing as command specific sub-configs | ||||
|  */ | ||||
| function cleanOptions(options) { | ||||
|     const ret = { ...options }; | ||||
|     delete ret['--']; | ||||
|     delete ret.c; | ||||
|     delete ret.config; | ||||
|     delete ret.base; | ||||
|     delete ret.l; | ||||
|     delete ret.logLevel; | ||||
|     delete ret.clearScreen; | ||||
|     delete ret.d; | ||||
|     delete ret.debug; | ||||
|     delete ret.f; | ||||
|     delete ret.filter; | ||||
|     delete ret.m; | ||||
|     delete ret.mode; | ||||
|     // convert the sourcemap option to a boolean if necessary | ||||
|     if ('sourcemap' in ret) { | ||||
|         const sourcemap = ret.sourcemap; | ||||
|         ret.sourcemap = | ||||
|             sourcemap === 'true' | ||||
|                 ? true | ||||
|                 : sourcemap === 'false' | ||||
|                     ? false | ||||
|                     : ret.sourcemap; | ||||
|     } | ||||
|     return ret; | ||||
| } | ||||
| /** | ||||
|  * host may be a number (like 0), should convert to string | ||||
|  */ | ||||
| const convertHost = (v) => { | ||||
|     if (typeof v === 'number') { | ||||
|         return String(v); | ||||
|     } | ||||
|     return v; | ||||
| }; | ||||
| /** | ||||
|  * base may be a number (like 0), should convert to empty string | ||||
|  */ | ||||
| const convertBase = (v) => { | ||||
|     if (v === 0) { | ||||
|         return ''; | ||||
|     } | ||||
|     return v; | ||||
| }; | ||||
| cli | ||||
|     .option('-c, --config <file>', `[string] use specified config file`) | ||||
|     .option('--base <path>', `[string] public base path (default: /)`, { | ||||
|     type: [convertBase], | ||||
| }) | ||||
|     .option('-l, --logLevel <level>', `[string] info | warn | error | silent`) | ||||
|     .option('--clearScreen', `[boolean] allow/disable clear screen when logging`) | ||||
|     .option('-d, --debug [feat]', `[string | boolean] show debug logs`) | ||||
|     .option('-f, --filter <filter>', `[string] filter debug logs`) | ||||
|     .option('-m, --mode <mode>', `[string] set env mode`); | ||||
| // dev | ||||
| cli | ||||
|     .command('[root]', 'start dev server') // default command | ||||
|     .alias('serve') // the command is called 'serve' in Vite's API | ||||
|     .alias('dev') // alias to align with the script name | ||||
|     .option('--host [host]', `[string] specify hostname`, { type: [convertHost] }) | ||||
|     .option('--port <port>', `[number] specify port`) | ||||
|     .option('--https', `[boolean] use TLS + HTTP/2`) | ||||
|     .option('--open [path]', `[boolean | string] open browser on startup`) | ||||
|     .option('--cors', `[boolean] enable CORS`) | ||||
|     .option('--strictPort', `[boolean] exit if specified port is already in use`) | ||||
|     .option('--force', `[boolean] force the optimizer to ignore the cache and re-bundle`) | ||||
|     .action(async (root, options) => { | ||||
|     filterDuplicateOptions(options); | ||||
|     // output structure is preserved even after bundling so require() | ||||
|     // is ok here | ||||
|     const { createServer } = await import('./chunks/dep-42dae6ba.js').then(function (n) { return n.I; }); | ||||
|     try { | ||||
|         const server = await createServer({ | ||||
|             root, | ||||
|             base: options.base, | ||||
|             mode: options.mode, | ||||
|             configFile: options.config, | ||||
|             logLevel: options.logLevel, | ||||
|             clearScreen: options.clearScreen, | ||||
|             optimizeDeps: { force: options.force }, | ||||
|             server: cleanOptions(options), | ||||
|         }); | ||||
|         if (!server.httpServer) { | ||||
|             throw new Error('HTTP server not available'); | ||||
|         } | ||||
|         await server.listen(); | ||||
|         const info = server.config.logger.info; | ||||
|         const viteStartTime = global.__vite_start_time ?? false; | ||||
|         const startupDurationString = viteStartTime | ||||
|             ? colors.dim(`ready in ${colors.reset(colors.bold(Math.ceil(performance.now() - viteStartTime)))} ms`) | ||||
|             : ''; | ||||
|         info(`\n  ${colors.green(`${colors.bold('VITE')} v${VERSION}`)}  ${startupDurationString}\n`, { clear: !server.config.logger.hasWarned }); | ||||
|         server.printUrls(); | ||||
|         bindShortcuts(server, { | ||||
|             print: true, | ||||
|             customShortcuts: [ | ||||
|                 profileSession && { | ||||
|                     key: 'p', | ||||
|                     description: 'start/stop the profiler', | ||||
|                     async action(server) { | ||||
|                         if (profileSession) { | ||||
|                             await stopProfiler(server.config.logger.info); | ||||
|                         } | ||||
|                         else { | ||||
|                             const inspector = await import('node:inspector').then((r) => r.default); | ||||
|                             await new Promise((res) => { | ||||
|                                 profileSession = new inspector.Session(); | ||||
|                                 profileSession.connect(); | ||||
|                                 profileSession.post('Profiler.enable', () => { | ||||
|                                     profileSession.post('Profiler.start', () => { | ||||
|                                         server.config.logger.info('Profiler started'); | ||||
|                                         res(); | ||||
|                                     }); | ||||
|                                 }); | ||||
|                             }); | ||||
|                         } | ||||
|                     }, | ||||
|                 }, | ||||
|             ], | ||||
|         }); | ||||
|     } | ||||
|     catch (e) { | ||||
|         const logger = createLogger(options.logLevel); | ||||
|         logger.error(colors.red(`error when starting dev server:\n${e.stack}`), { | ||||
|             error: e, | ||||
|         }); | ||||
|         stopProfiler(logger.info); | ||||
|         process.exit(1); | ||||
|     } | ||||
| }); | ||||
| // build | ||||
| cli | ||||
|     .command('build [root]', 'build for production') | ||||
|     .option('--target <target>', `[string] transpile target (default: 'modules')`) | ||||
|     .option('--outDir <dir>', `[string] output directory (default: dist)`) | ||||
|     .option('--assetsDir <dir>', `[string] directory under outDir to place assets in (default: assets)`) | ||||
|     .option('--assetsInlineLimit <number>', `[number] static asset base64 inline threshold in bytes (default: 4096)`) | ||||
|     .option('--ssr [entry]', `[string] build specified entry for server-side rendering`) | ||||
|     .option('--sourcemap [output]', `[boolean | "inline" | "hidden"] output source maps for build (default: false)`) | ||||
|     .option('--minify [minifier]', `[boolean | "terser" | "esbuild"] enable/disable minification, ` + | ||||
|     `or specify minifier to use (default: esbuild)`) | ||||
|     .option('--manifest [name]', `[boolean | string] emit build manifest json`) | ||||
|     .option('--ssrManifest [name]', `[boolean | string] emit ssr manifest json`) | ||||
|     .option('--force', `[boolean] force the optimizer to ignore the cache and re-bundle (experimental)`) | ||||
|     .option('--emptyOutDir', `[boolean] force empty outDir when it's outside of root`) | ||||
|     .option('-w, --watch', `[boolean] rebuilds when modules have changed on disk`) | ||||
|     .action(async (root, options) => { | ||||
|     filterDuplicateOptions(options); | ||||
|     const { build } = await import('./chunks/dep-42dae6ba.js').then(function (n) { return n.H; }); | ||||
|     const buildOptions = cleanOptions(options); | ||||
|     try { | ||||
|         await build({ | ||||
|             root, | ||||
|             base: options.base, | ||||
|             mode: options.mode, | ||||
|             configFile: options.config, | ||||
|             logLevel: options.logLevel, | ||||
|             clearScreen: options.clearScreen, | ||||
|             optimizeDeps: { force: options.force }, | ||||
|             build: buildOptions, | ||||
|         }); | ||||
|     } | ||||
|     catch (e) { | ||||
|         createLogger(options.logLevel).error(colors.red(`error during build:\n${e.stack}`), { error: e }); | ||||
|         process.exit(1); | ||||
|     } | ||||
|     finally { | ||||
|         stopProfiler((message) => createLogger(options.logLevel).info(message)); | ||||
|     } | ||||
| }); | ||||
| // optimize | ||||
| cli | ||||
|     .command('optimize [root]', 'pre-bundle dependencies') | ||||
|     .option('--force', `[boolean] force the optimizer to ignore the cache and re-bundle`) | ||||
|     .action(async (root, options) => { | ||||
|     filterDuplicateOptions(options); | ||||
|     const { optimizeDeps } = await import('./chunks/dep-42dae6ba.js').then(function (n) { return n.G; }); | ||||
|     try { | ||||
|         const config = await resolveConfig({ | ||||
|             root, | ||||
|             base: options.base, | ||||
|             configFile: options.config, | ||||
|             logLevel: options.logLevel, | ||||
|             mode: options.mode, | ||||
|         }, 'serve'); | ||||
|         await optimizeDeps(config, options.force, true); | ||||
|     } | ||||
|     catch (e) { | ||||
|         createLogger(options.logLevel).error(colors.red(`error when optimizing deps:\n${e.stack}`), { error: e }); | ||||
|         process.exit(1); | ||||
|     } | ||||
| }); | ||||
| // preview | ||||
| cli | ||||
|     .command('preview [root]', 'locally preview production build') | ||||
|     .option('--host [host]', `[string] specify hostname`, { type: [convertHost] }) | ||||
|     .option('--port <port>', `[number] specify port`) | ||||
|     .option('--strictPort', `[boolean] exit if specified port is already in use`) | ||||
|     .option('--https', `[boolean] use TLS + HTTP/2`) | ||||
|     .option('--open [path]', `[boolean | string] open browser on startup`) | ||||
|     .option('--outDir <dir>', `[string] output directory (default: dist)`) | ||||
|     .action(async (root, options) => { | ||||
|     filterDuplicateOptions(options); | ||||
|     const { preview } = await import('./chunks/dep-42dae6ba.js').then(function (n) { return n.J; }); | ||||
|     try { | ||||
|         const server = await preview({ | ||||
|             root, | ||||
|             base: options.base, | ||||
|             configFile: options.config, | ||||
|             logLevel: options.logLevel, | ||||
|             mode: options.mode, | ||||
|             build: { | ||||
|                 outDir: options.outDir, | ||||
|             }, | ||||
|             preview: { | ||||
|                 port: options.port, | ||||
|                 strictPort: options.strictPort, | ||||
|                 host: options.host, | ||||
|                 https: options.https, | ||||
|                 open: options.open, | ||||
|             }, | ||||
|         }); | ||||
|         server.printUrls(); | ||||
|         bindShortcuts(server, { print: true }); | ||||
|     } | ||||
|     catch (e) { | ||||
|         createLogger(options.logLevel).error(colors.red(`error when starting preview server:\n${e.stack}`), { error: e }); | ||||
|         process.exit(1); | ||||
|     } | ||||
|     finally { | ||||
|         stopProfiler((message) => createLogger(options.logLevel).info(message)); | ||||
|     } | ||||
| }); | ||||
| cli.help(); | ||||
| cli.version(VERSION); | ||||
| cli.parse(); | ||||
|  | ||||
| export { stopProfiler }; | ||||
							
								
								
									
										130
									
								
								node_modules/vite/dist/node/constants.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										130
									
								
								node_modules/vite/dist/node/constants.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,130 @@ | ||||
| import path, { resolve } from 'node:path'; | ||||
| import { fileURLToPath } from 'node:url'; | ||||
| import { readFileSync } from 'node:fs'; | ||||
|  | ||||
| const { version } = JSON.parse(readFileSync(new URL('../../package.json', import.meta.url)).toString()); | ||||
| const VERSION = version; | ||||
| const DEFAULT_MAIN_FIELDS = [ | ||||
|     'module', | ||||
|     'jsnext:main', | ||||
|     'jsnext', | ||||
| ]; | ||||
| // Baseline support browserslist | ||||
| // "defaults and supports es6-module and supports es6-module-dynamic-import" | ||||
| // Higher browser versions may be needed for extra features. | ||||
| const ESBUILD_MODULES_TARGET = [ | ||||
|     'es2020', | ||||
|     'edge88', | ||||
|     'firefox78', | ||||
|     'chrome87', | ||||
|     'safari14', | ||||
| ]; | ||||
| const DEFAULT_EXTENSIONS = [ | ||||
|     '.mjs', | ||||
|     '.js', | ||||
|     '.mts', | ||||
|     '.ts', | ||||
|     '.jsx', | ||||
|     '.tsx', | ||||
|     '.json', | ||||
| ]; | ||||
| const DEFAULT_CONFIG_FILES = [ | ||||
|     'vite.config.js', | ||||
|     'vite.config.mjs', | ||||
|     'vite.config.ts', | ||||
|     'vite.config.cjs', | ||||
|     'vite.config.mts', | ||||
|     'vite.config.cts', | ||||
| ]; | ||||
| const JS_TYPES_RE = /\.(?:j|t)sx?$|\.mjs$/; | ||||
| const CSS_LANGS_RE = /\.(css|less|sass|scss|styl|stylus|pcss|postcss|sss)(?:$|\?)/; | ||||
| const OPTIMIZABLE_ENTRY_RE = /\.[cm]?[jt]s$/; | ||||
| const SPECIAL_QUERY_RE = /[?&](?:worker|sharedworker|raw|url)\b/; | ||||
| /** | ||||
|  * Prefix for resolved fs paths, since windows paths may not be valid as URLs. | ||||
|  */ | ||||
| const FS_PREFIX = `/@fs/`; | ||||
| /** | ||||
|  * Prefix for resolved Ids that are not valid browser import specifiers | ||||
|  */ | ||||
| const VALID_ID_PREFIX = `/@id/`; | ||||
| /** | ||||
|  * Plugins that use 'virtual modules' (e.g. for helper functions), prefix the | ||||
|  * module ID with `\0`, a convention from the rollup ecosystem. | ||||
|  * This prevents other plugins from trying to process the id (like node resolution), | ||||
|  * and core features like sourcemaps can use this info to differentiate between | ||||
|  * virtual modules and regular files. | ||||
|  * `\0` is not a permitted char in import URLs so we have to replace them during | ||||
|  * import analysis. The id will be decoded back before entering the plugins pipeline. | ||||
|  * These encoded virtual ids are also prefixed by the VALID_ID_PREFIX, so virtual | ||||
|  * modules in the browser end up encoded as `/@id/__x00__{id}` | ||||
|  */ | ||||
| const NULL_BYTE_PLACEHOLDER = `__x00__`; | ||||
| const CLIENT_PUBLIC_PATH = `/@vite/client`; | ||||
| const ENV_PUBLIC_PATH = `/@vite/env`; | ||||
| const VITE_PACKAGE_DIR = resolve( | ||||
| // import.meta.url is `dist/node/constants.js` after bundle | ||||
| fileURLToPath(import.meta.url), '../../..'); | ||||
| const CLIENT_ENTRY = resolve(VITE_PACKAGE_DIR, 'dist/client/client.mjs'); | ||||
| const ENV_ENTRY = resolve(VITE_PACKAGE_DIR, 'dist/client/env.mjs'); | ||||
| const CLIENT_DIR = path.dirname(CLIENT_ENTRY); | ||||
| // ** READ THIS ** before editing `KNOWN_ASSET_TYPES`. | ||||
| //   If you add an asset to `KNOWN_ASSET_TYPES`, make sure to also add it | ||||
| //   to the TypeScript declaration file `packages/vite/client.d.ts` and | ||||
| //   add a mime type to the `registerCustomMime` in | ||||
| //   `packages/vite/src/node/plugin/assets.ts` if mime type cannot be | ||||
| //   looked up by mrmime. | ||||
| const KNOWN_ASSET_TYPES = [ | ||||
|     // images | ||||
|     'apng', | ||||
|     'png', | ||||
|     'jpe?g', | ||||
|     'jfif', | ||||
|     'pjpeg', | ||||
|     'pjp', | ||||
|     'gif', | ||||
|     'svg', | ||||
|     'ico', | ||||
|     'webp', | ||||
|     'avif', | ||||
|     // media | ||||
|     'mp4', | ||||
|     'webm', | ||||
|     'ogg', | ||||
|     'mp3', | ||||
|     'wav', | ||||
|     'flac', | ||||
|     'aac', | ||||
|     'opus', | ||||
|     // fonts | ||||
|     'woff2?', | ||||
|     'eot', | ||||
|     'ttf', | ||||
|     'otf', | ||||
|     // other | ||||
|     'webmanifest', | ||||
|     'pdf', | ||||
|     'txt', | ||||
| ]; | ||||
| const DEFAULT_ASSETS_RE = new RegExp(`\\.(` + KNOWN_ASSET_TYPES.join('|') + `)(\\?.*)?$`); | ||||
| const DEP_VERSION_RE = /[?&](v=[\w.-]+)\b/; | ||||
| const loopbackHosts = new Set([ | ||||
|     'localhost', | ||||
|     '127.0.0.1', | ||||
|     '::1', | ||||
|     '0000:0000:0000:0000:0000:0000:0000:0001', | ||||
| ]); | ||||
| const wildcardHosts = new Set([ | ||||
|     '0.0.0.0', | ||||
|     '::', | ||||
|     '0000:0000:0000:0000:0000:0000:0000:0000', | ||||
| ]); | ||||
| const DEFAULT_DEV_PORT = 5173; | ||||
| const DEFAULT_PREVIEW_PORT = 4173; | ||||
| // the regex to allow loopback address origins: | ||||
| // - localhost domains (which will always resolve to the loopback address by RFC 6761 section 6.3) | ||||
| // - 127.0.0.1 | ||||
| // - ::1 | ||||
| const defaultAllowedOrigins = /^https?:\/\/(?:(?:[^:]+\.)?localhost|127\.0\.0\.1|\[::1\])(?::\d+)?$/; | ||||
|  | ||||
| export { CLIENT_DIR, CLIENT_ENTRY, CLIENT_PUBLIC_PATH, CSS_LANGS_RE, DEFAULT_ASSETS_RE, DEFAULT_CONFIG_FILES, DEFAULT_DEV_PORT, DEFAULT_EXTENSIONS, DEFAULT_MAIN_FIELDS, DEFAULT_PREVIEW_PORT, DEP_VERSION_RE, ENV_ENTRY, ENV_PUBLIC_PATH, ESBUILD_MODULES_TARGET, FS_PREFIX, JS_TYPES_RE, KNOWN_ASSET_TYPES, NULL_BYTE_PLACEHOLDER, OPTIMIZABLE_ENTRY_RE, SPECIAL_QUERY_RE, VALID_ID_PREFIX, VERSION, VITE_PACKAGE_DIR, defaultAllowedOrigins, loopbackHosts, wildcardHosts }; | ||||
							
								
								
									
										3545
									
								
								node_modules/vite/dist/node/index.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3545
									
								
								node_modules/vite/dist/node/index.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										158
									
								
								node_modules/vite/dist/node/index.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								node_modules/vite/dist/node/index.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,158 @@ | ||||
| import { i as isInNodeModules } from './chunks/dep-42dae6ba.js'; | ||||
| export { b as build, e as buildErrorMessage, v as createFilter, x as createLogger, c as createServer, g as defineConfig, f as formatPostcssSourceMap, k as getDepOptimizationConfig, m as isDepsOptimizerEnabled, z as isFileServingAllowed, l as loadConfigFromFile, A as loadEnv, u as mergeAlias, q as mergeConfig, n as normalizePath, o as optimizeDeps, a as preprocessCSS, p as preview, j as resolveBaseUrl, h as resolveConfig, B as resolveEnvPrefix, d as resolvePackageData, r as resolvePackageEntry, y as searchForWorkspaceRoot, w as send, s as sortUserPlugins, t as transformWithEsbuild } from './chunks/dep-42dae6ba.js'; | ||||
| export { VERSION as version } from './constants.js'; | ||||
| export { version as esbuildVersion } from 'esbuild'; | ||||
| export { VERSION as rollupVersion } from 'rollup'; | ||||
| import 'node:fs'; | ||||
| import 'node:fs/promises'; | ||||
| import 'node:path'; | ||||
| import 'node:url'; | ||||
| import 'node:util'; | ||||
| import 'node:perf_hooks'; | ||||
| import 'node:module'; | ||||
| import 'node:crypto'; | ||||
| import 'tty'; | ||||
| import 'path'; | ||||
| import 'fs'; | ||||
| import 'events'; | ||||
| import 'assert'; | ||||
| import 'util'; | ||||
| import 'net'; | ||||
| import 'url'; | ||||
| import 'http'; | ||||
| import 'stream'; | ||||
| import 'os'; | ||||
| import 'child_process'; | ||||
| import 'node:os'; | ||||
| import 'node:child_process'; | ||||
| import 'node:dns'; | ||||
| import 'crypto'; | ||||
| import 'node:buffer'; | ||||
| import 'module'; | ||||
| import 'node:assert'; | ||||
| import 'node:process'; | ||||
| import 'node:v8'; | ||||
| import 'worker_threads'; | ||||
| import 'node:http'; | ||||
| import 'node:https'; | ||||
| import 'zlib'; | ||||
| import 'buffer'; | ||||
| import 'https'; | ||||
| import 'tls'; | ||||
| import 'node:net'; | ||||
| import 'querystring'; | ||||
| import 'node:readline'; | ||||
| import 'node:zlib'; | ||||
|  | ||||
| // This file will be built for both ESM and CJS. Avoid relying on other modules as possible. | ||||
| // copy from constants.ts | ||||
| const CSS_LANGS_RE =  | ||||
| // eslint-disable-next-line regexp/no-unused-capturing-group | ||||
| /\.(css|less|sass|scss|styl|stylus|pcss|postcss|sss)(?:$|\?)/; | ||||
| const isCSSRequest = (request) => CSS_LANGS_RE.test(request); | ||||
| // Use splitVendorChunkPlugin() to get the same manualChunks strategy as Vite 2.7 | ||||
| // We don't recommend using this strategy as a general solution moving forward | ||||
| // splitVendorChunk is a simple index/vendor strategy that was used in Vite | ||||
| // until v2.8. It is exposed to let people continue to use it in case it was | ||||
| // working well for their setups. | ||||
| // The cache needs to be reset on buildStart for watch mode to work correctly | ||||
| // Don't use this manualChunks strategy for ssr, lib mode, and 'umd' or 'iife' | ||||
| class SplitVendorChunkCache { | ||||
|     constructor() { | ||||
|         this.cache = new Map(); | ||||
|     } | ||||
|     reset() { | ||||
|         this.cache = new Map(); | ||||
|     } | ||||
| } | ||||
| function splitVendorChunk(options = {}) { | ||||
|     const cache = options.cache ?? new SplitVendorChunkCache(); | ||||
|     return (id, { getModuleInfo }) => { | ||||
|         if (isInNodeModules(id) && | ||||
|             !isCSSRequest(id) && | ||||
|             staticImportedByEntry(id, getModuleInfo, cache.cache)) { | ||||
|             return 'vendor'; | ||||
|         } | ||||
|     }; | ||||
| } | ||||
| function staticImportedByEntry(id, getModuleInfo, cache, importStack = []) { | ||||
|     if (cache.has(id)) { | ||||
|         return cache.get(id); | ||||
|     } | ||||
|     if (importStack.includes(id)) { | ||||
|         // circular deps! | ||||
|         cache.set(id, false); | ||||
|         return false; | ||||
|     } | ||||
|     const mod = getModuleInfo(id); | ||||
|     if (!mod) { | ||||
|         cache.set(id, false); | ||||
|         return false; | ||||
|     } | ||||
|     if (mod.isEntry) { | ||||
|         cache.set(id, true); | ||||
|         return true; | ||||
|     } | ||||
|     const someImporterIs = mod.importers.some((importer) => staticImportedByEntry(importer, getModuleInfo, cache, importStack.concat(id))); | ||||
|     cache.set(id, someImporterIs); | ||||
|     return someImporterIs; | ||||
| } | ||||
| function splitVendorChunkPlugin() { | ||||
|     const caches = []; | ||||
|     function createSplitVendorChunk(output, config) { | ||||
|         const cache = new SplitVendorChunkCache(); | ||||
|         caches.push(cache); | ||||
|         const build = config.build ?? {}; | ||||
|         const format = output?.format; | ||||
|         if (!build.ssr && !build.lib && format !== 'umd' && format !== 'iife') { | ||||
|             return splitVendorChunk({ cache }); | ||||
|         } | ||||
|     } | ||||
|     return { | ||||
|         name: 'vite:split-vendor-chunk', | ||||
|         config(config) { | ||||
|             let outputs = config?.build?.rollupOptions?.output; | ||||
|             if (outputs) { | ||||
|                 outputs = Array.isArray(outputs) ? outputs : [outputs]; | ||||
|                 for (const output of outputs) { | ||||
|                     const viteManualChunks = createSplitVendorChunk(output, config); | ||||
|                     if (viteManualChunks) { | ||||
|                         if (output.manualChunks) { | ||||
|                             if (typeof output.manualChunks === 'function') { | ||||
|                                 const userManualChunks = output.manualChunks; | ||||
|                                 output.manualChunks = (id, api) => { | ||||
|                                     return userManualChunks(id, api) ?? viteManualChunks(id, api); | ||||
|                                 }; | ||||
|                             } | ||||
|                             else { | ||||
|                                 // else, leave the object form of manualChunks untouched, as | ||||
|                                 // we can't safely replicate rollup handling. | ||||
|                                 // eslint-disable-next-line no-console | ||||
|                                 console.warn("(!) the `splitVendorChunk` plugin doesn't have any effect when using the object form of `build.rollupOptions.output.manualChunks`. Consider using the function form instead."); | ||||
|                             } | ||||
|                         } | ||||
|                         else { | ||||
|                             output.manualChunks = viteManualChunks; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             else { | ||||
|                 return { | ||||
|                     build: { | ||||
|                         rollupOptions: { | ||||
|                             output: { | ||||
|                                 manualChunks: createSplitVendorChunk({}, config), | ||||
|                             }, | ||||
|                         }, | ||||
|                     }, | ||||
|                 }; | ||||
|             } | ||||
|         }, | ||||
|         buildStart() { | ||||
|             caches.forEach((cache) => cache.reset()); | ||||
|         }, | ||||
|     }; | ||||
| } | ||||
|  | ||||
| export { isCSSRequest, splitVendorChunk, splitVendorChunkPlugin }; | ||||
		Reference in New Issue
	
	Block a user