@powerlines/plugin-tsdown 0.1.2 → 0.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,44 +0,0 @@
1
- var e=Object.create,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,r=Object.getOwnPropertyNames,i=Object.getPrototypeOf,a=Object.prototype.hasOwnProperty,o=(e,i,o,s)=>{if(i&&typeof i==`object`||typeof i==`function`)for(var c=r(i),l=0,u=c.length,d;l<u;l++)d=c[l],!a.call(e,d)&&d!==o&&t(e,d,{get:(e=>i[e]).bind(null,d),enumerable:!(s=n(i,d))||s.enumerable});return e},s=(n,r,a)=>(a=n==null?{}:e(i(n)),o(r||!n||!n.__esModule?t(a,`default`,{value:n,enumerable:!0}):a,n));let c=require(`@storm-software/config-tools/types`),l=require(`defu`);l=s(l);let u=require(`@stryke/convert/parse-type-definition`),d=require(`@stryke/convert/to-array`),ee=require(`@stryke/helpers/omit`),f=require(`@stryke/path/append`),p=require(`@stryke/path/replace`),te=require(`@stryke/fs/get-workspace-root`),ne=require(`unplugin`),re=require(`@babel/core`),ie=require(`@storm-software/config-tools/logger/console`),m=require(`@stryke/fs/helpers`),ae=require(`@stryke/fs/install`),h=require(`@stryke/fs/list-files`),g=require(`@stryke/fs/package-fns`),_=require(`@stryke/fs/resolve`),v=require(`@stryke/path/join-paths`),oe=require(`@stryke/type-checks/is-error`),y=require(`@stryke/type-checks/is-function`),se=require(`@stryke/type-checks/is-number`),ce=require(`@stryke/type-checks/is-object`),le=require(`@stryke/type-checks/is-promise`),ue=require(`@stryke/type-checks/is-set`),b=require(`@stryke/type-checks/is-set-object`),x=require(`@stryke/type-checks/is-set-string`),S=require(`chalk`);S=s(S);let C=require(`handlebars`);C=s(C);let de=require(`@babel/helper-plugin-utils`),w=require(`@babel/types`);w=s(w);let T=require(`typescript`);T=s(T);let fe=require(`ts-morph`),E=require(`@stryke/type-checks/is-string`),D=require(`@stryke/string-format/package`),pe=require(`@donedeal0/superdiff`),O=require(`@stryke/fs/json`),k=require(`@stryke/json/storm-json`),A=require(`@stryke/path/file-path-fns`),j=require(`@stryke/string-format/title-case`),M=require(`@stryke/fs/exists`),me=require(`@storm-software/config-tools/get-config`),he=require(`c12`),ge=require(`@stryke/env/get-env-paths`),_e=require(`@stryke/hash/hash-files`),N=require(`@stryke/hash/murmurhash`),P=require(`@stryke/helpers/get-unique`),ve=require(`@stryke/http/fetch`),F=require(`@stryke/path/is-type`),I=require(`@stryke/path/join`),ye=require(`@stryke/type-checks/is-null`),be=require(`@stryke/unique-id/uuid`),L=require(`bundle-require`),xe=require(`flat-cache`),Se=require(`oxc-parser`),R=require(`undici`),Ce=require(`jiti`),z=require(`@stryke/type-checks/is-undefined`),we=require(`@stryke/fs/is-file`),B=require(`@stryke/capnp`);B=s(B);let Te=require(`@stryke/fs/buffer`),V=require(`@stryke/path/is-parent-path`),Ee=require(`@stryke/string-format/pretty-bytes`),De=require(`node:buffer`),H=require(`node:url`),Oe=require(`prettier`),ke=require(`@storm-software/config-tools/logger`),Ae=require(`@storm-software/config-tools/utilities/colors`),je=require(`@stryke/helpers/noop`),Me=require(`@stryke/path/correct-path`),Ne=require(`@stryke/path/slash`),Pe=require(`@stryke/fs/read-file`),Fe=require(`@stryke/fs/write-file`),Ie=require(`node:fs`),Le=require(`node:fs/promises`),Re=require(`node:path`);require(`@stryke/fs/remove-file`);let ze=require(`@stryke/string-format/kebab-case`);require(`magic-string`);function Be(e,t){if(!w.isStringLiteral(e.node))return;let n=e.node.value,r=t.context?.fs.resolveSync(n);r&&e.replaceWith(w.stringLiteral(r.replace(/\.(?:ts|mts|cts)x?$/,``)))}const Ve=[`require`,`require.resolve`,`System.import`,`jest.genMockFromModule`,`jest.mock`,`jest.unmock`,`jest.doMock`,`jest.dontMock`,`jest.setMock`,`jest.requireActual`,`jest.requireMock`,`require.requireActual`,`require.requireMock`];function He(e,t,n){let{node:r}=t;if(w.isMemberExpression(r))return t.matchesPattern(n);if(!w.isIdentifier(r)||n.includes(`.`))return!1;let i=n.split(`.`)[0];return r.name===i}const Ue={CallExpression:(e,t)=>{if(t.moduleResolverVisited.has(e))return;let n=e.get(`callee`);(n&&Ve.some(e=>He(t,n,e))||w.isImport(e.node.callee))&&(t.moduleResolverVisited.add(e),Be(e.get(`arguments.0`),t))},"ImportDeclaration|ExportDeclaration|ExportAllDeclaration":(e,t)=>{!e||!e.get(`source`)||t.moduleResolverVisited.has(e)||(t.moduleResolverVisited.add(e),Be(e.get(`source`),t))}},We=e=>(0,de.declare)(function(t){let n=new Set;return{name:`powerlines:module-resolver`,manipulateOptions(e){e.filename??=`unknown`},pre(){n=new Set},visitor:{Program:{enter(r,i){r.traverse(Ue,{...i,context:e,moduleResolverVisited:n,api:t})},exit(r,i){r.traverse(Ue,{...i,context:e,moduleResolverVisited:n,api:t})}}},post(){n.clear()}}});var Ge=class extends fe.InMemoryFileSystemHost{#e;constructor(e){super(),this.#e=e}deleteSync(e){this.#e.fs.removeSync(e)}readDirSync(e){return this.#e.fs.isDirectorySync(e)?this.#e.fs.listSync(e).reduce((e,t)=>{let n=this.#e.fs.resolveSync(t);return n&&e.push({name:t,isDirectory:this.#e.fs.isDirectorySync(n),isFile:this.#e.fs.isFileSync(n),isSymlink:!1}),e},[]):[]}async readFile(e){return this.#e.fs.isFileSync(e)?await this.#e.fs.read(e):``}readFileSync(e){return this.#e.fs.isFileSync(e)?this.#e.fs.readSync(e):``}async writeFile(e,t){return this.#e.fs.write(e,t)}writeFileSync(e,t){this.#e.fs.writeSync(e,t)}async mkdir(e){await this.#e.fs.mkdir(e)}mkdirSync(e){this.#e.fs.mkdirSync(e)}async move(e,t){await this.#e.fs.move(e,t)}moveSync(e,t){this.#e.fs.moveSync(e,t)}async copy(e,t){await this.#e.fs.copy(e,t)}copySync(e,t){this.#e.fs.copySync(e,t)}async fileExists(e){return this.#e.fs.isFile(e)}fileExistsSync(e){return this.#e.fs.isFileSync(e)}async directoryExists(e){return this.#e.fs.isDirectory(e)}directoryExistsSync(e){return this.#e.fs.isDirectorySync(e)}realpathSync(e){return this.#e.fs.resolveSync(e)||e}getCurrentDirectory(){return this.#e.workspaceConfig.workspaceRoot}async glob(e){return this.#e.fs.glob(e)}globSync(e){return this.#e.fs.globSync(e)}};function Ke(e,t){return e.log(c.LogLevelLabel.TRACE,`Creating ts-morph Project instance with configuration from: ${e.tsconfig.tsconfigFilePath}.`),new fe.Project((0,l.default)(t??{},{skipAddingFilesFromTsConfig:!1,tsConfigFilePath:e.tsconfig.tsconfigFilePath,fileSystem:new Ge(e),compilerOptions:(0,l.default)(e.tsconfig.options??{},{lib:[`lib.esnext.full.d.ts`]})}))}function qe(e){return e.replace(/import\s*(?:type\s*)?\{?[\w,\s]*(?:\}\s*)?from\s*(?:'|")@?[a-zA-Z0-9-\\/.]*(?:'|");?/g,``).replaceAll(`#private;`,``).replace(/__Ω/g,``)}async function Je(e,t){e.log(c.LogLevelLabel.TRACE,`Running the TypeScript compiler for ${t.length} generated runtime files.`);let n=Ke(e,{skipAddingFilesFromTsConfig:!0});n.addSourceFilesAtPaths(t);let r=n.emitToMemory({emitOnlyDtsFiles:!0}),i=``;for(let t of r.getFiles())if(!t.filePath.endsWith(`.map`)&&e.builtins.some(n=>n===t.filePath||e.fs.metadata[n]?.id&&e.fs.metadata[n]?.id===t.filePath)){let n=await e.fs.resolve(t.filePath);i+=`
2
- declare module "${n}" {
3
- ${t.text.trim().replace(/^\s*export\s*declare\s*/gm,`export `).replace(/^\s*declare\s*/gm,``)}
4
- }
5
- `}let a=[];r.getDiagnostics().forEach(e=>{e.getSourceFile()?.getBaseName()?a.push(`${e.getSourceFile()?.getBaseName()} (${(e.getLineNumber()??0)+1}): ${(0,T.flattenDiagnosticMessageText)(e.getMessageText().toString(),`
6
- `)}`):a.push((0,T.flattenDiagnosticMessageText)(e.getMessageText().toString(),`
7
- `))});let o=a.join(`
8
- `);if(o)throw Error(`TypeScript compilation failed: \n\n${o.length>5e3?`${o.slice(0,5e3)}...`:o}`);return qe(i)}const Ye=(0,l.createDefu)((e,t,n)=>(0,E.isString)(e[t])&&(0,E.isString)(n)?(e[t]=`${e[t]||``}\n${n||``}`.trim(),!0):!1);async function Xe(e,t,n,...r){let i=e.selectHooks(t,n);if(i.length>0){e.log(c.LogLevelLabel.DEBUG,` 🧩 Calling plugin hook: ${S.default.bold.cyanBright(`${t}${n?.order?` (${n.order})`:``}`)}`);let a=[];if(n?.sequential===!1)a=await Promise.all(i.map(async e=>{if(!(0,y.isFunction)(e.handle))throw Error(`Plugin hook handler for hook "${t}" is not a function.`);return Promise.resolve(e.handle.apply(e.context,[...r]))}));else for(let e of i){if(!(0,y.isFunction)(e.handle))throw Error(`Plugin hook handler for hook "${t}" is not a function.`);if(n?.result===`first`||n?.asNextParam===!1){if(a.push(await Promise.resolve(e.handle.apply(e.context,[...r]))),n?.result===`first`&&(0,ue.isSet)(a[a.length-1]))break}else{let t=[...r];a.length>0&&t.length>0&&(t[0]=(0,y.isFunction)(n.asNextParam)?await Promise.resolve(n.asNextParam(a[0])):a[0]);let i=await Promise.resolve(e.handle.apply(e.context,[...t]));i&&(n?.result===`last`?a=[i]:(0,E.isString)(i)?a=[`${(0,E.isString)(a[0])&&a[0]||``}\n${i||``}`.trim()]:(0,ce.isObject)(i)&&(a=[Ye(i,a[0]??{})]))}}let o=a.filter(e=>(0,ue.isSet)(e));if(o.length>0){let e;for(let t of o)e=(0,l.defu)(t,e??{});return e}}}async function Ze(e,t,n=!1){if(await(0,g.isPackageListed)((0,D.getPackageName)(t),{cwd:e.config.projectRoot})){if((0,D.hasPackageVersion)(t)&&!process.env.POWERLINES_SKIP_VERSION_CHECK&&!await(0,g.doesPackageMatch)((0,D.getPackageName)(t),(0,D.getPackageVersion)(t),e.config.projectRoot)){let n=await(0,g.getPackageListing)((0,D.getPackageName)(t),{cwd:e.config.projectRoot});!n?.version.startsWith(`catalog:`)&&!n?.version.startsWith(`workspace:`)&&e.log(c.LogLevelLabel.WARN,`The package "${(0,D.getPackageName)(t)}" is installed but does not match the expected version ${(0,D.getPackageVersion)(t)} (installed version: ${n?.version||`<Unknown>`}). Please ensure this is intentional before proceeding. Note: You can skip this validation with the "STORM_STACK_SKIP_VERSION_CHECK" environment variable.`)}}else if(e.config.skipInstalls!==!0){e.log(c.LogLevelLabel.WARN,`The package "${t}" is not installed. It will be installed automatically.`);let r=await(0,ae.install)(t,{cwd:e.config.projectRoot,dev:n});if((0,se.isNumber)(r.exitCode)&&r.exitCode>0)throw e.log(c.LogLevelLabel.ERROR,r.stderr),Error(`An error occurred while installing the package "${t}"`)}else e.log(c.LogLevelLabel.WARN,`The package "${t}" is not installed. Since the "skipInstalls" option is set to true, it will not be installed automatically.`)}async function Qe(e){if(e.log(c.LogLevelLabel.TRACE,`Checking and installing missing project dependencies.`),e.dependencies??={},e.devDependencies??={},Object.keys(e.dependencies).length===0&&Object.keys(e.devDependencies).length===0){e.log(c.LogLevelLabel.TRACE,`No dependencies or devDependencies to install. Skipping installation step.`);return}e.log(c.LogLevelLabel.DEBUG,`The following packages are required: \nDependencies: \n${Object.entries(e.dependencies).map(([e,t])=>`- ${e}@${String(t)}`).join(`
9
- `)}\n\nDevDependencies: \n${Object.entries(e.devDependencies).map(([e,t])=>`- ${e}@${String(t)}`).join(`
10
- `)}`),await Promise.all([Promise.all(Object.entries(e.dependencies).map(async([t,n])=>Ze(e,`${(0,D.getPackageName)(t)}@${String(n)}`,!1))),Promise.all(Object.entries(e.devDependencies).map(async([t,n])=>Ze(e,`${(0,D.getPackageName)(t)}@${String(n)}`,!0)))])}function U(e,t,n){let r;if(n?r=W(e,t,n):(r=W(e,t,`tsconfig.app.json`),r||(r=W(e,t,`tsconfig.lib.json`),r||=W(e,t,`tsconfig.json`))),!r)throw Error(`Cannot find the \`tsconfig.json\` configuration file for the project at ${t}.`);return r}function W(e,t,n){let r=n;if(!(!(0,M.existsSync)(r)&&(r=(0,f.appendPath)(n,t),!(0,M.existsSync)(r)&&(r=(0,f.appendPath)(n,(0,f.appendPath)(t,e)),!(0,M.existsSync)(r)))))return r}function $e(e,t,n=[`.ts`,`.tsx`,`.d.ts`]){return t.find(t=>e?.toString().toLowerCase()===t?.toString().toLowerCase()||e?.toString().toLowerCase()===`./${t?.toString().toLowerCase()}`||`./${e?.toString().toLowerCase()}`===t?.toString().toLowerCase()||n.some(n=>`${e?.toString().toLowerCase()}${n}`===t?.toString().toLowerCase()||`${e?.toString().toLowerCase()}${n}`==`./${t?.toString().toLowerCase()}`||`${t?.toString().toLowerCase()}${n}`==`./${e?.toString().toLowerCase()}`||e?.toString().toLowerCase()===`${t?.toString().toLowerCase()}${n}`||e?.toString().toLowerCase()===`./${t?.toString().toLowerCase()}${n}`||t?.toString().toLowerCase()===`./${e?.toString().toLowerCase()}${n}`))}function et(e,t){return $e(e,t,`.ts,.tsx,.d.ts,.js,.jsx,.mjs,.cjs,.mts,.cts,/*.ts,/*.tsx,/*.d.ts,/*.js,/*.jsx,/*.mjs,/*.cjs,/*.mts,/*.cts,/**/*.ts,/**/*.tsx,/**/*.d.ts,/**/*.js,/**/*.jsx,/**/*.mjs,/**/*.cjs,/**/*.mts,/**/*.cts`.split(`,`))}function tt(e,t){return et(e,t)!==void 0}function G(e,t,n,r={},i,a=T.default.sys){let o=U(e,t,n),s=(0,O.readJsonFileSync)(o);if(!s)throw Error(`Cannot find the \`tsconfig.json\` configuration file at ${(0,v.joinPaths)(t,n??`tsconfig.json`)}`);let c=T.default.parseJsonConfigFileContent((0,l.default)(r??{},s),a,(0,f.appendPath)(t,e));if(c.errors.length>0){let e=`Cannot parse the TypeScript compiler options. Please investigate the following issues:
11
- ${c.errors.map(e=>`- ${(e.category!==void 0&&e.code?`[${e.category}-${e.code}]: `:``)+e.messageText.toString()}`).join(`
12
- `)}
13
- `;throw Error(e)}return{...c,originalTsconfigJson:i??s,tsconfigJson:s,tsconfigFilePath:o}}function nt(e){return(0,v.joinPaths)((0,A.relativePath)((0,v.joinPaths)(e.workspaceConfig.workspaceRoot,e.config.projectRoot),(0,A.findFilePath)(e.dtsPath)),(0,A.findFileName)(e.dtsPath))}async function rt(e){let t=G(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig,e.config.tsconfigRaw),n=await(0,O.readJsonFile)(U(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig));if(n.compilerOptions??={},e.config.output.dts!==!1){let t=nt(e);n.include?.some(n=>tt(n,[e.dtsPath,t]))||(n.include??=[],n.include.push(t.startsWith(`./`)?t.slice(2):t))}return t.options.lib?.some(e=>[`lib.esnext.d.ts`,`lib.es2021.d.ts`,`lib.es2022.d.ts`,`lib.es2023.d.ts`].includes(e.toLowerCase()))||(n.compilerOptions.lib??=[],n.compilerOptions.lib.push(`esnext`)),t.options.esModuleInterop!==!0&&(n.compilerOptions.esModuleInterop=!0),t.options.isolatedModules!==!0&&(n.compilerOptions.isolatedModules=!0),e.config.build.platform===`node`&&(t.options.types?.some(e=>e.toLowerCase()===`node`||e.toLowerCase()===`@types/node`)||(n.compilerOptions.types??=[],n.compilerOptions.types.push(`node`))),n}async function it(e){if(e.log(c.LogLevelLabel.TRACE,`Initializing TypeScript configuration (tsconfig.json) for the Powerlines project.`),!(0,g.isPackageExists)(`typescript`))throw Error(`The TypeScript package is not installed. Please install the package using the command: "npm install typescript --save-dev"`);let t=U(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig);e.tsconfig.originalTsconfigJson=await(0,O.readJsonFile)(t),e.tsconfig.tsconfigJson=await rt(e),e.log(c.LogLevelLabel.TRACE,`Writing updated TypeScript configuration (tsconfig.json) file to disk.`),await e.fs.write(t,k.StormJSON.stringify(e.tsconfig.tsconfigJson)),e.tsconfig=G(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig,e.config.tsconfigRaw,e.tsconfig.originalTsconfigJson)}async function at(e){let t=await(0,O.readJsonFile)(e.tsconfig.tsconfigFilePath);t?.compilerOptions?.types&&Array.isArray(t.compilerOptions.types)&&!t.compilerOptions.types.length&&delete t.compilerOptions.types;let n=(0,pe.getObjectDiff)(e.tsconfig.originalTsconfigJson,t,{ignoreArrayOrder:!0,showOnly:{statuses:[`added`,`deleted`,`updated`],granularity:`deep`}}),r=[],i=(e,t)=>{if(e.status===`added`||e.status===`deleted`||e.status===`updated`)if(e.diff)for(let n of e.diff)i(n,t?`${t}.${e.property}`:e.property);else r.push({field:t?`${t}.${e.property}`:e.property,status:e.status,previous:e.status===`added`?`---`:k.StormJSON.stringify(e.previousValue),current:e.status===`deleted`?`---`:k.StormJSON.stringify(e.currentValue)})};for(let e of n.diff)i(e);if(r.length>0&&e.log(c.LogLevelLabel.WARN,`Updating the following configuration values in "${e.tsconfig.tsconfigFilePath}" file:
14
-
15
- ${r.map((e,t)=>`${S.default.bold.whiteBright(`${t+1}. ${(0,j.titleCase)(e.status)} the ${e.field} field: `)}
16
- ${S.default.red(` - Previous: ${e.previous} `)}
17
- ${S.default.green(` - Updated: ${e.current} `)}
18
- `).join(`
19
- `)}
20
- `),await e.fs.write(e.tsconfig.tsconfigFilePath,k.StormJSON.stringify(t)),e.tsconfig=G(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig),!e.tsconfig)throw Error(`Failed to parse the TypeScript configuration file.`)}const ot=`default`;function st(e,t){return(0,l.default)(t.environments?.[e]??{},{name:e,title:t.title||(0,j.titleCase)(t.name),ssr:!1,mainFields:t.build?.platform===`browser`?[`browser`,`module`,`jsnext:main`,`jsnext`]:[`module`,`jsnext:main`,`jsnext`],extensions:[`.mjs`,`.js`,`.mts`,`.ts`,`.jsx`,`.tsx`,`.json`],consumer:t.build?.platform===`browser`?`client`:`server`,preview:t.build?.platform===`browser`?{port:5173,open:!0,strictPort:!1,host:`localhost`,allowedHosts:[`.`],cors:!0,headers:{}}:void 0},t)}function ct(e){return st(`default`,e)}async function lt(e,t){return(0,l.default)({workspaceRoot:e},await(0,me.getWorkspaceConfig)(!0,{cwd:t,workspaceRoot:e,useDefault:!0}))}async function ut(e,t,n,r,i=`production`,a,o=`powerlines`){let s={},c;if(a&&(c=(0,M.existsSync)((0,p.replacePath)(a,e))?(0,p.replacePath)(a,e):(0,M.existsSync)((0,v.joinPaths)((0,f.appendPath)(e,t),(0,p.replacePath)(a,e)))?(0,v.joinPaths)((0,f.appendPath)(e,t),(0,p.replacePath)(a,e)):(0,M.existsSync)((0,v.joinPaths)((0,f.appendPath)(e,t),a))?(0,v.joinPaths)((0,f.appendPath)(e,t),a):void 0),c||=(0,M.existsSync)((0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.${i}.config.ts`))?(0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.${i}.config.ts`):(0,M.existsSync)((0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.${i}.config.js`))?(0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.${i}.config.js`):(0,M.existsSync)((0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.${i}.config.mts`))?(0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.${i}.config.mts`):(0,M.existsSync)((0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.${i}.config.mjs`))?(0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.${i}.config.mjs`):(0,M.existsSync)((0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.config.ts`))?(0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.config.ts`):(0,M.existsSync)((0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.config.js`))?(0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.config.js`):(0,M.existsSync)((0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.config.mts`))?(0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.config.mts`):(0,M.existsSync)((0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.config.mjs`))?(0,v.joinPaths)((0,f.appendPath)(e,t),`${o}.config.mjs`):void 0,c){let e=await n.import(n.esmResolve(c));if(e){let t={};(0,y.isFunction)(e)&&(t=await Promise.resolve(e({command:r,mode:i,isSsrBuild:!1,isPreview:!1}))),(0,b.isSetObject)(t)&&(s={...t,config:t,configFile:c})}}let u=await(0,he.loadConfig)({cwd:e,name:o,envName:i,globalRc:!0,packageJson:!0,dotenv:!0,jiti:n});return(0,l.default)(s,(0,b.isSetObject)(u?.config)?{...u.config,...u}:{})}function dt(e){return(0,l.default)(e,{interopDefault:!0,fsCache:e.mode===`development`?!1:(0,v.joinPaths)(e.cacheDir,`jiti`),moduleCache:e.mode!==`development`})}function ft(e){return(0,Ce.createJiti)((0,v.joinPaths)(e.workspaceRoot,e.projectRoot),dt({...e}))}function pt(e){let t=(0,Ce.createJiti)((0,v.joinPaths)(e.workspaceRoot,e.projectRoot),dt(e));return t.plugin=ft(e),t}const mt=[`new`,`clean`,`prepare`,`lint`,`test`,`build`,`docs`,`deploy`,`finalize`];function K(e){return(0,b.isSetObject)(e)&&`name`in e&&(0,x.isSetString)(e.name)&&((0,z.isUndefined)(e.applyToEnvironment)||`applyToEnvironment`in e&&(0,y.isFunction)(e.applyToEnvironment))&&((0,z.isUndefined)(e.dedupe)||`dedupe`in e&&(0,y.isFunction)(e.dedupe))&&((0,z.isUndefined)(e.dependsOn)||`dependsOn`in e&&Array.isArray(e.dependsOn)&&e.dependsOn.every(_t))&&mt.every(t=>(0,z.isUndefined)(e[t])||t in e&&((0,y.isFunction)(e[t])||(0,b.isSetObject)(e[t])&&`handler`in e[t]&&(0,y.isFunction)(e[t].handler)))}function ht(e){return(0,b.isSetObject)(e)&&`plugin`in e&&(((0,x.isSetString)(e.plugin)||(0,y.isFunction)(e.plugin))&&`options`in e&&(0,b.isSetObject)(e.options)||K(e.plugin))}function gt(e){return Array.isArray(e)&&(e.length===1||e.length===2)&&(((0,x.isSetString)(e[0])||(0,y.isFunction)(e[0]))&&e.length>1&&(0,b.isSetObject)(e[1])||K(e[0]))}function _t(e){return(0,x.isSetString)(e)||(0,y.isFunction)(e)||K(e)||ht(e)||gt(e)}function vt(e){return(0,y.isFunction)(e)||(0,b.isSetObject)(e)&&`handler`in e&&(0,y.isFunction)(e.handler)}function yt(e){return(0,b.isSetObject)(e)&&`handler`in e&&(0,y.isFunction)(e.handler)}function bt(e){return vt(e)||yt(e)}function xt(e){return(0,y.isFunction)(e)?e:e.handler}function St(e){return e.startsWith(`vite:`)||e.startsWith(`esbuild:`)||e.startsWith(`rolldown:`)||e.startsWith(`rollup:`)||e.startsWith(`webpack:`)||e.startsWith(`rspack:`)||e.startsWith(`farm:`)}function q(e,t){return e.dedupe===!1||t.some(t=>t.dedupe!==!1&&((0,y.isFunction)(t.dedupe)&&t.dedupe(e)||t.name===e.name))}function Ct(e,t,n,r){q(t,r.map(e=>e.plugin))||r.push((0,y.isFunction)(n)?{plugin:t,handler:xt(n).bind(e)}:{plugin:t,...n,handler:xt(n).bind(e)})}function J(e,t){return t&&t.replaceAll(`{workspaceRoot}`,e.workspaceConfig.workspaceRoot).replaceAll(`{root}`,e.config.projectRoot).replaceAll(`{projectRoot}`,e.config.projectRoot).replaceAll(`{sourceRoot}`,e.config.sourceRoot).replaceAll(`{powerlinesPath}`,e.powerlinesPath).replaceAll(`{cachePath}`,e.cachePath).replaceAll(`{dataPath}`,e.dataPath).replaceAll(`{logPath}`,e.envPaths.log).replaceAll(`{tempPath}`,e.envPaths.temp).replaceAll(`{configPath}`,e.envPaths.config).replaceAll(`{outputPath}`,e.config.output.outputPath).replaceAll(`{buildPath}`,e.config.output.buildPath).replaceAll(`{artifactsPath}`,(0,p.replacePath)(e.artifactsPath,e.workspaceConfig.workspaceRoot)).replaceAll(`{builtinPath}`,(0,p.replacePath)(e.builtinsPath,e.workspaceConfig.workspaceRoot)).replaceAll(`{entryPath}`,(0,p.replacePath)(e.entryPath,e.workspaceConfig.workspaceRoot))}function wt(e,t){return(0,p.replacePath)(t.file,(0,v.joinPaths)(e.workspaceConfig.workspaceRoot,e.config.projectRoot))}function Tt(e,t){return{file:wt(e,t),name:t.name}}function Et(e,t){return(0,p.replaceExtension)((0,p.replacePath)((0,p.replacePath)((0,p.replacePath)((0,p.replacePath)((0,p.replacePath)(t.file,(0,v.joinPaths)(e.workspaceConfig.workspaceRoot,e.config.sourceRoot)),(0,v.joinPaths)(e.workspaceConfig.workspaceRoot,e.config.projectRoot)),e.config.sourceRoot),e.config.projectRoot),(0,p.replacePath)(e.config.sourceRoot,e.config.projectRoot)))}function Dt(e,t){let n=Tt(e,t);return{...n,input:n,output:Et(e,t)}}function Ot(e,t){return t.map(t=>(0,E.isString)(t)?J(e,t):J(e,t.file)).map(t=>{let n=(0,u.parseTypeDefinition)(t),r=(0,f.appendPath)(n.file,e.config.projectRoot);return(0,we.isFile)(r)?Dt(e,{file:(0,p.replacePath)(r,e.config.projectRoot),name:n.name}):(0,h.listFilesSync)(r).map(t=>Dt(e,{file:t,name:n.name}))}).flat().filter(Boolean)}function kt(e=[]){return(0,P.getUniqueBy)((0,d.toArray)(e),e=>(0,x.isSetString)(e)?e:(0,N.murmurhash)(e??{},{maxLength:24}))}var At=class extends B.Struct{static _capnp={displayName:`KeyValuePair`,id:`eabb26cf58b2a14c`,size:new B.ObjectSize(0,2)};get key(){return B.utils.getText(0,this)}set key(e){B.utils.setText(0,e,this)}get value(){return B.utils.getText(1,this)}set value(e){B.utils.setText(1,e,this)}toString(){return`FileMetadata_KeyValuePair_`+super.toString()}},jt=class e extends B.Struct{static KeyValuePair=At;static _capnp={displayName:`FileMetadata`,id:`8e2cab5d7e28c7b3`,size:new B.ObjectSize(8,3),defaultType:`normal`};static _Properties;get id(){return B.utils.getText(0,this)}set id(e){B.utils.setText(0,e,this)}get type(){return B.utils.getText(1,this,e._capnp.defaultType)}set type(e){B.utils.setText(1,e,this)}get timestamp(){return B.utils.getUint32(0,this)}set timestamp(e){B.utils.setUint32(0,e,this)}_adoptProperties(e){B.utils.adopt(e,B.utils.getPointer(2,this))}_disownProperties(){return B.utils.disown(this.properties)}get properties(){return B.utils.getList(2,e._Properties,this)}_hasProperties(){return!B.utils.isNull(B.utils.getPointer(2,this))}_initProperties(t){return B.utils.initList(2,e._Properties,t,this)}set properties(e){B.utils.copyFrom(e,B.utils.getPointer(2,this))}toString(){return`FileMetadata_`+super.toString()}},Mt=class extends B.Struct{static _capnp={displayName:`FileId`,id:`990d6a471072f997`,size:new B.ObjectSize(0,2)};get id(){return B.utils.getText(0,this)}set id(e){B.utils.setText(0,e,this)}get path(){return B.utils.getText(1,this)}set path(e){B.utils.setText(1,e,this)}toString(){return`FileId_`+super.toString()}},Nt=class extends B.Struct{static _capnp={displayName:`FileStorage`,id:`9dca66ac858c9ebe`,size:new B.ObjectSize(0,2)};get path(){return B.utils.getText(0,this)}set path(e){B.utils.setText(0,e,this)}get code(){return B.utils.getText(1,this)}set code(e){B.utils.setText(1,e,this)}toString(){return`FileStorage_`+super.toString()}},Y=class e extends B.Struct{static _capnp={displayName:`FileSystem`,id:`ae0c23d43e56abcf`,size:new B.ObjectSize(0,3)};static _Ids;static _Storage;static _Metadata;_adoptIds(e){B.utils.adopt(e,B.utils.getPointer(0,this))}_disownIds(){return B.utils.disown(this.ids)}get ids(){return B.utils.getList(0,e._Ids,this)}_hasIds(){return!B.utils.isNull(B.utils.getPointer(0,this))}_initIds(t){return B.utils.initList(0,e._Ids,t,this)}set ids(e){B.utils.copyFrom(e,B.utils.getPointer(0,this))}_adoptStorage(e){B.utils.adopt(e,B.utils.getPointer(1,this))}_disownStorage(){return B.utils.disown(this.storage)}get storage(){return B.utils.getList(1,e._Storage,this)}_hasStorage(){return!B.utils.isNull(B.utils.getPointer(1,this))}_initStorage(t){return B.utils.initList(1,e._Storage,t,this)}set storage(e){B.utils.copyFrom(e,B.utils.getPointer(1,this))}_adoptMetadata(e){B.utils.adopt(e,B.utils.getPointer(2,this))}_disownMetadata(){return B.utils.disown(this.metadata)}get metadata(){return B.utils.getList(2,e._Metadata,this)}_hasMetadata(){return!B.utils.isNull(B.utils.getPointer(2,this))}_initMetadata(t){return B.utils.initList(2,e._Metadata,t,this)}set metadata(e){B.utils.copyFrom(e,B.utils.getPointer(2,this))}toString(){return`FileSystem_`+super.toString()}};jt._Properties=B.CompositeList(At),Y._Ids=B.CompositeList(Mt),Y._Storage=B.CompositeList(Nt),Y._Metadata=B.CompositeList(jt);let Pt=function(e){return e.VIRTUAL=`virtual`,e.FS=`fs`,e}({});const Ft=(e,t={})=>{let n=t.logLevel===null?c.LogLevelLabel.SILENT:t.logLevel||c.LogLevelLabel.INFO;return n===c.LogLevelLabel.SILENT?je.noop:t.customLogger?t.customLogger:(r,...i)=>(0,ke.getLogFn)((0,ke.getLogLevel)(r),{...t,logLevel:n})(`${S.default.bold.hex((0,Ae.getColor)(`brand`,t))(`powerlines${e?`:${e}`:``}${t.name?` ${S.default.gray(`> `)}${t.name}`:``} ${S.default.gray(`> `)}`)}${i.join(` `)} `.trim())},It=[`#00A0DD`,`#6FCE4E`,`#FBBF24`,`#F43F5E`,`#3B82F6`,`#A855F7`,`#469592`,`#288EDF`,`#10B981`,`#EF4444`,`#F0EC56`,`#F472B6`,`#22D3EE`,`#EAB308`,`#84CC16`,`#F87171`,`#0EA5E9`,`#D946EF`,`#FACC15`,`#34D399`],Lt=(e,t)=>(n,...r)=>e(n,` ${S.default.inverse.hex(It[t.split(``).map(e=>e.charCodeAt(0)).reduce((e,t)=>e+t,0)%It.length]||It[0])(` ${(0,j.titleCase)(t)} `)} ${r.join(` `)} `);function Rt(e){return(0,oe.isError)(e)&&`code`in e&&e.code}function X(e){return Rt(e)&&(e.code===`ENOENT`||e.code===`EISDIR`?null:e)}function Z(e){return(0,Me.correctPath)((0,Ne.slash)(e?.toString()||`.`).replace(/^file:\/\//,``))}function zt(e,t=`powerlines`){return e.replace(/^\\0/,``).startsWith(`${t.replace(/:$/,``)}`)}function Bt(e,t=`powerlines`){return`${t.replace(/:$/,``)}:${Z(e).replace(RegExp(`^${t.replace(/:$/,``)}:`),``).replace(/^\\0/,``).replace((0,A.findFileDotExtensionSafe)(Z(e)),``)}`}function Vt(e,t,n=`powerlines`){return(0,F.isAbsolutePath)(e)?e:zt(Z(e),n)?Bt(Z(e),n).replace(RegExp(`^${n.replace(/:$/,``)}:`),t):Z(e)}function Ht(e,t){return(0,P.getUnique)((0,d.toArray)(t).map(t=>(0,b.isSetObject)(t)&&((0,x.isSetString)(t.input)||(0,x.isSetString)(t.glob))?(0,I.joinPaths)(t.input||e,t.glob||`**/*`):(0,x.isSetString)(t)?t:void 0).filter(x.isSetString))}var Ut=class{#e=!1;options;constructor(e={base:`/`}){this.options=e,this.options.base=(0,Re.resolve)(e.base),this.options.isReadOnly=!!e.isReadOnly}async exists(e){return this.existsSync(e)}async get(e){return this.getSync(e)}async set(e,t){this.options.isReadOnly||this.setSync(e,t)}mkdirSync(e){}async mkdir(e){return Promise.resolve(this.mkdirSync(e))}async remove(e){this.options.isReadOnly||this.removeSync(e)}clearSync(e){if(!this.options.isReadOnly){let t=this.listSync(e||this.options.base);if(!t.length)return;t.map(t=>this.removeSync(e&&!t.startsWith(e)?(0,I.joinPaths)(e,t):t))}}async clear(e){if(!this.options.isReadOnly){let t=await this.list(e||this.options.base);if(!t.length)return;await Promise.all(t.map(async t=>this.remove(e&&!t.startsWith(e)?(0,I.joinPaths)(e,t):t)))}}async list(e){return this.listSync(e)}isDirectorySync(e){return!1}async isDirectory(e){return Promise.resolve(this.isDirectorySync(e))}isFileSync(e){return this.existsSync(e)&&!this.isDirectorySync(e)}async isFile(e){return Promise.resolve(this.isFileSync(e))}dispose(){return Promise.resolve()}async[Symbol.asyncDispose](){return this._dispose()}resolve(e=this.options.base){if(/\.\.:|\.\.$/.test(e))throw Error(`[${this.name}]: Invalid key: ${JSON.stringify(e)} provided to storage adapter.`);return(0,f.appendPath)((0,Me.correctPath)(e).replace(/:/g,`/`),this.options.base)}async _dispose(){this.#e||=(await Promise.resolve(this.dispose()),!0)}},Wt=class extends Ut{name=`file-system`;constructor(e){super(e)}existsSync(e){return(0,M.existsSync)(this.resolve(e))}async exists(e){return(0,M.exists)(this.resolve(e))}getSync(e){return(0,Pe.readFileSync)(this.resolve(e))}async get(e){return(0,Pe.readFile)(this.resolve(e))}setSync(e,t){if(!this.options.isReadOnly)return(0,Fe.writeFileSync)(this.resolve(e),t)}async set(e,t){if(!this.options.isReadOnly)return(0,Fe.writeFile)(this.resolve(e),t)}removeSync(e){if(!this.options.isReadOnly)try{return(0,Ie.unlinkSync)(this.resolve(e))}catch(e){return X(e)}}async remove(e){if(!this.options.isReadOnly)return(0,Le.unlink)(this.resolve(e)).catch(X)}mkdirSync(e){(0,m.createDirectorySync)(this.resolve(e))}async mkdir(e){await(0,m.createDirectory)(this.resolve(e))}listSync(e){try{return(0,h.listFilesSync)(this.resolve(e),{ignore:this.options.ignore})}catch(e){return X(e)??[]}}async list(e){return(0,h.listFiles)(this.resolve(e),{ignore:this.options.ignore}).catch(X).then(e=>e||[])}isDirectorySync(e){return(0,we.isDirectory)(this.resolve(e))}isFileSync(e){return!(0,we.isFile)(this.resolve(e))}},Q=class extends Ut{name=`virtual`;data=new Map;constructor(e){super(e)}existsSync(e){return this.data.has(this.resolve(e))}getSync(e){return this.data.get(this.resolve(e))??null}setSync(e,t){this.options.isReadOnly||this.data.set(this.resolve(e),t)}removeSync(e){this.options.isReadOnly||this.data.delete(this.resolve(e))}listSync(e){return[...this.data.keys().filter(t=>e?(0,V.isParentPath)(t,this.resolve(e)):!0)]}async dispose(){return this.clear()}},Gt=class e{#e;#t;#n;#r={"":new Wt};#i;#a=!1;#o;#s;#c(e){let t=e;return(0,V.isParentPath)(t,this.#o.builtinsPath)&&(t=(0,p.replacePath)(t,this.#o.builtinsPath)),Bt(t,this.#o.config.output.builtinPrefix)}#l(e){return Vt(e.includes(`{`)||e.includes(`}`)?J(this.#o,e):e,this.#o.builtinsPath,this.#o.config.output.builtinPrefix)}#u(e){let t=`::GLOBSTAR::`;return RegExp(`^${this.#l(e).replace(/\*\*/g,t).replace(/[.+^${}()|[\]\\]/g,`\\$&`).replace(/\*/g,`[^/]*`).replace(/\?/g,`[^/]`).replace(new RegExp(t,`g`),`.*`)}$`)}#d(e){let t=this.resolveSync(this.#l(e))||e;for(let e of Object.keys(this.#r).filter(Boolean).sort().reverse())if((0,V.isParentPath)(t,e))return{base:e,relativeKey:(0,p.replacePath)(t,e),adapter:this.#r[e]};return{base:``,relativeKey:t,adapter:this.#r[``]}}#f(e=``,t=!1){return Object.keys(this.#r).sort().reverse().filter(n=>(0,V.isParentPath)(n,e)||t&&(0,V.isParentPath)(e,n)).map(t=>({relativeBase:e.length>t.length?e.slice(t.length):void 0,base:t,adapter:this.#r[t]}))}static async create(t){if(!t.config.skipCache&&(0,M.existsSync)((0,v.joinPaths)(t.dataPath,`fs.bin`))){let n=await(0,Te.readFileBuffer)((0,v.joinPaths)(t.dataPath,`fs.bin`)),r=new B.Message(n,!1).getRoot(Y),i=new e(t,r);r._hasStorage()&&r.storage.length>0&&await Promise.all(r.storage.values().map(async e=>{await i.write(e.path,e.code)}))}return new e(t,new B.Message().initRoot(Y))}static createSync(t){if(!t.config.skipCache&&(0,M.existsSync)((0,v.joinPaths)(t.dataPath,`fs.bin`))){let n=(0,Te.readFileBufferSync)((0,v.joinPaths)(t.dataPath,`fs.bin`)),r=new B.Message(n,!1).getRoot(Y),i=new e(t,r);r._hasStorage()&&r.storage.length>0&&r.storage.values().map(e=>{i.writeSync(e.path,e.code)})}return new e(t,new B.Message().initRoot(Y))}get metadata(){return new Proxy(this.#e,{get:(e,t)=>e[this.#c(t)]})}get ids(){return new Proxy(this.#n,{get:(e,t)=>e[this.#l(t)]})}get paths(){return new Proxy(this.#n,{get:(e,t)=>e[this.#c(t)]})}get resolverCache(){return this.#i||=(0,xe.create)({cacheId:`module-resolution`,cacheDir:this.#o.cachePath,ttl:3600*1e3,lruSize:5e3,persistInterval:100}),this.#i}constructor(e,t){this.#o=e,(0,b.isSetObject)(this.#o.config.output.storage)&&(this.#r={...this.#r,...this.#o.config.output.storage}),this.#r.virtual??=new Q({base:`/_virtual`}),this.#o.config.output.storage!==Pt.FS&&(this.#r[this.#o.artifactsPath]??=new Q({base:this.#o.artifactsPath}),this.#r[this.#o.builtinsPath]??=new Q({base:this.#o.builtinsPath}),this.#r[this.#o.entryPath]??=new Q({base:this.#o.entryPath})),this.#e={},t._hasMetadata()&&(this.#e=t.metadata.values().reduce((e,t)=>(e[t.id]={id:t.id,type:t.type,timestamp:t.timestamp||Date.now(),properties:t._hasProperties()?t.properties.values().reduce((e,t)=>(e[t.key]=t.value,e),{}):{}},e),{})),this.#t={},this.#n={},t._hasIds()&&(this.#t=t.ids.values().reduce((e,t)=>(e[t.path]??=t.id,e),{}),this.#n=t.ids.values().reduce((e,t)=>(e[t.id]??=t.path,e),{})),this.#s=Lt(this.#o.log,`file-system`)}async exists(e){let{relativeKey:t,adapter:n}=this.#d(e);return n.exists(t)}existsSync(e){let{relativeKey:t,adapter:n}=this.#d(e);return n.existsSync(t)}isVirtual(e){let t=this.resolveSync(e);return t?this.#d(t)?.adapter?.name===`virtual`:!1}isDirectorySync(e){let t=this.resolveSync(e);return t?!!(this.existsSync(t)&&this.#d(t)?.adapter?.isDirectorySync(t)):!1}async isDirectory(e){let t=await this.resolve(e);return t?!!(await this.exists(t)&&await this.#d(t)?.adapter?.isDirectory(t)):!1}isFileSync(e){let t=this.resolveSync(e);return t?this.#d(t)?.adapter?.isFileSync(t)??!1:!1}async isFile(e){let t=await this.resolve(e);return t?await this.#d(t)?.adapter?.isFile(t)??!1:!1}listSync(e){return(0,P.getUnique)(this.#f(e,!0).map(e=>e.adapter.listSync(e.relativeBase?e.base?(0,f.appendPath)(e.relativeBase,e.base):e.relativeBase:e.base)).flat())}async list(e){return(0,P.getUnique)((await Promise.all(this.#f(e,!0).map(async e=>e.adapter.list(e.relativeBase?e.base?(0,f.appendPath)(e.relativeBase,e.base):e.relativeBase:e.base)))).flat())}async remove(e){let t=this.#l(e);this.#s(c.LogLevelLabel.TRACE,`Removing file: ${t}`);let{relativeKey:n,adapter:r}=this.#d(t);(0,A.hasFileExtension)(t)?await r.remove(n):await r.clear(n);let i=this.#t[t];i&&this.#e[i]&&(delete this.#e[i],delete this.#t[t],delete this.#n[i])}removeSync(e){let t=this.#l(e);this.#s(c.LogLevelLabel.TRACE,`Removing file: ${t}`);let{relativeKey:n,adapter:r}=this.#d(t);(0,A.hasFileExtension)(t)?r.removeSync(n):r.clearSync(n);let i=this.#t[t];i&&this.#e[i]&&(delete this.#e[i],delete this.#t[t],delete this.#n[i])}async glob(e){let t=[];for(let n of Ht(this.#o.workspaceConfig.workspaceRoot,e)){let e=this.#l(n);if(!/[*?[\]{}]/.test(e)&&!e.includes(`**`)){if(this.isDirectorySync(e))t.push(...await this.list(e));else{let n=await this.resolve(e);n&&!t.includes(n)&&t.push(n)}continue}let r=(0,F.isAbsolutePath)(e)?e:this.#l((0,v.joinPaths)(this.#o.workspaceConfig.workspaceRoot,e)),i=r.search(/[*?[\]{}]/),a=i===-1?(0,A.findFilePath)(r):r.slice(0,Math.max(0,r.lastIndexOf(`/`,i)));await Promise.all((await this.list(a&&(0,F.isAbsolutePath)(a)?a:this.#o.workspaceConfig.workspaceRoot)).map(async e=>{if(this.#u(r).test(e)){let n=this.resolveSync(e);n&&!t.includes(n)&&t.push(n)}}))}return t}globSync(e){let t=[];for(let n of Ht(this.#o.workspaceConfig.workspaceRoot,e)){let e=this.#l(n);if(!/[*?[\]{}]/.test(e)&&!e.includes(`**`)){if(this.isDirectorySync(e))t.push(...this.listSync(e));else{let n=this.resolveSync(e);n&&!t.includes(n)&&t.push(n)}continue}let r=(0,F.isAbsolutePath)(e)?e:this.#l((0,v.joinPaths)(this.#o.workspaceConfig.workspaceRoot,e)),i=r.search(/[*?[\]{}]/),a=i===-1?(0,A.findFilePath)(r):r.slice(0,Math.max(0,r.lastIndexOf(`/`,i))),o=this.listSync(a&&(0,F.isAbsolutePath)(a)?a:this.#o.workspaceConfig.workspaceRoot);for(let e of o)if(this.#u(r).test(e)){let n=this.resolveSync(e);n&&!t.includes(n)&&t.push(n)}}return t}async copy(e,t){let n=e instanceof URL?(0,H.fileURLToPath)(e):e,r=t instanceof URL?(0,H.fileURLToPath)(t):t;if(!(0,x.isSetString)(n)&&(!(0,b.isSetObject)(n)||!(0,x.isSetString)(n.input))||!(0,x.isSetString)(r))return;let i=(0,E.isString)(n)?n:n.input?n.input:this.#o.workspaceConfig.workspaceRoot,a=await this.resolve(i);if(a)if(this.isDirectorySync(a)||(0,x.isSetString)(n)&&n.includes(`*`)||(0,b.isSetObject)(n)&&(0,x.isSetString)(n.glob))await Promise.all((await this.glob(n)).map(async e=>this.copy(e,(0,f.appendPath)((0,p.replacePath)(e,i),r))));else{let e=await this.read(a);e!==void 0&&await this.write(this.#l(r),e,{skipFormat:!0})}}copySync(e,t){let n=e instanceof URL?(0,H.fileURLToPath)(e):e,r=t instanceof URL?(0,H.fileURLToPath)(t):t;if(!(0,x.isSetString)(n)&&(!(0,b.isSetObject)(n)||!(0,x.isSetString)(n.input))||!(0,x.isSetString)(r))return;let i=(0,E.isString)(n)?n:n.input?n.input:this.#o.workspaceConfig.workspaceRoot,a=this.resolveSync(i);if(a)if(this.isDirectorySync(a)||(0,x.isSetString)(n)&&n.includes(`*`)||(0,b.isSetObject)(n)&&(0,x.isSetString)(n.glob))this.globSync(n).map(e=>this.copySync(e,(0,f.appendPath)((0,A.findFilePath)((0,p.replacePath)(e,i)),r)));else{let e=this.readSync(a);e!==void 0&&this.writeSync(this.#l((0,A.hasFileExtension)(r)?r:(0,f.appendPath)((0,A.findFileName)(a),r)),e,{skipFormat:!0})}}async move(e,t){(0,A.hasFileExtension)(e)?(await this.copy(e,t),await this.remove(e)):await Promise.all((await this.list(e)).map(async e=>{await this.copy(e,t),await this.remove(e)}))}moveSync(e,t){(0,A.hasFileExtension)(e)?(this.copySync(e,t),this.removeSync(e)):this.listSync(e).forEach(e=>{this.copySync(e,t),this.removeSync(e)})}async read(e){let t=await this.resolve(e);if(!t)return;let{relativeKey:n,adapter:r}=this.#d(t);return this.#s(c.LogLevelLabel.TRACE,`Reading ${r.name} file: ${t}`),await r.get(n)??void 0}readSync(e){let t=this.resolveSync(e);if(!t)return;let{relativeKey:n,adapter:r}=this.#d(t);return this.#s(c.LogLevelLabel.TRACE,`Reading ${r.name} file: ${t}`),r.getSync(n)??void 0}async write(e,t=``,n={}){let r=t;if(!n.skipFormat){let n=await(0,Oe.resolveConfig)(this.#l(e));n&&(r=await(0,Oe.format)(t,{absolutePath:this.#l(e),...n}))}let{relativeKey:i,adapter:a}=this.#d(e);this.#s(c.LogLevelLabel.TRACE,`Writing ${this.#l(i)} to ${a.name===`virtual`?`the virtual file system`:a.name===`file-system`?`the local file system`:a.name} (size: ${(0,Ee.prettyBytes)(new De.Blob((0,d.toArray)(r)).size)})`);let o=n?.meta?.id||this.#c(i);return this.#e[o]={variant:`normal`,timestamp:Date.now(),...n.meta??{}},this.#n[o]=this.#l(i),this.#t[this.#l(i)]=o,a.set(i,r)}writeSync(e,t=``,n={}){let{relativeKey:r,adapter:i}=this.#d(e);this.#s(c.LogLevelLabel.TRACE,`Writing ${this.#l(r)} file to ${i.name===`virtual`?`the virtual file system`:i.name===`file-system`?`the local file system`:i.name} (size: ${(0,Ee.prettyBytes)(new De.Blob((0,d.toArray)(t)).size)})`);let a=n?.meta?.id||this.#c(r);return this.#e[a]={variant:`normal`,timestamp:Date.now(),...n.meta??{}},this.#n[a]=this.#l(r),this.#t[this.#l(r)]=a,i.setSync(r,t)}mkdirSync(e){return this.#d(e)?.adapter?.mkdirSync(e)}async mkdir(e){return this.#d(e)?.adapter?.mkdir(e)}getMetadata(e){let t=this.resolveSync(e);if(t&&this.metadata[t])return this.metadata[t]}async resolve(e,t,n={}){let r=e;if((r.includes(`{`)||r.includes(`}`))&&(r=J(this.#o,r)),(0,F.isAbsolutePath)(r))return r;let i=(0,N.murmurhash)({path:this.#c(r),importer:t,options:n}),a;if(!this.#o.config.skipCache&&(a=this.resolverCache.get(i),a))return a;if(a=this.paths[this.#c(r)],!a){let e=n.paths??[];t&&!e.includes(t)&&e.push(t),e.push(this.#o.workspaceConfig.workspaceRoot),e.push((0,f.appendPath)(this.#o.config.projectRoot,this.#o.workspaceConfig.workspaceRoot)),e.push((0,f.appendPath)(this.#o.config.sourceRoot,this.#o.workspaceConfig.workspaceRoot)),e.push(...Object.keys(this.#o.tsconfig?.options?.paths??{}).filter(e=>r.startsWith(e.replace(/\*$/,``))).map(e=>this.#o.tsconfig?.options?.paths?.[e]).flat().filter(Boolean).map(e=>(0,f.appendPath)(e,this.#o.workspaceConfig.workspaceRoot)));for(let t of(0,_.getResolutionCombinations)(r,{paths:e})){let{relativeKey:e,adapter:n}=this.#d(t);if(await n.exists(e)){a=t;break}}if(!a)try{a=await(0,_.resolve)(r,{...n,paths:e})}catch{}}return a&&!this.#o.config.skipCache&&this.resolverCache.set(i,a),a}resolveSync(e,t,n={}){let r=e;if((r.includes(`{`)||r.includes(`}`))&&(r=J(this.#o,r)),(0,F.isAbsolutePath)(r))return r;let i;if(!this.#o.config.skipCache&&(i=this.resolverCache.get(this.#c(r)),i))return i;if(i=this.paths[this.#c(r)],!i){let e=n.paths??[];t&&!e.includes(t)&&e.push(t),e.push(this.#o.workspaceConfig.workspaceRoot),e.push((0,f.appendPath)(this.#o.config.projectRoot,this.#o.workspaceConfig.workspaceRoot)),e.push((0,f.appendPath)(this.#o.config.sourceRoot,this.#o.workspaceConfig.workspaceRoot)),e.push(...Object.keys(this.#o.tsconfig?.options?.paths??{}).filter(e=>r.startsWith(e.replace(/\*$/,``))).map(e=>this.#o.tsconfig?.options?.paths?.[e]).flat().filter(Boolean).map(e=>(0,f.appendPath)(e,this.#o.workspaceConfig.workspaceRoot)));for(let t of(0,_.getResolutionCombinations)(r,{paths:e})){let{relativeKey:e,adapter:n}=this.#d(t);if(n.existsSync(e)){i=t;break}}if(!i)try{i=(0,_.resolveSync)(r,{...n,paths:e})}catch{}}return i&&!this.#o.config.skipCache&&this.resolverCache.set(this.#c(r),i),i}async dispose(){if(!this.#a){this.#a=!0,this.#s(c.LogLevelLabel.DEBUG,`Disposing virtual file system...`),await this.remove((0,v.joinPaths)(this.#o.dataPath,`fs.bin`));let e=new B.Message,t=e.initRoot(Y),n=await this.list(),r=t._initStorage(n.length);await Promise.all(n.map(async(e,t)=>{let n=await this.read(e),i=r.get(t);i.path=e,i.code=n||``}));let i=t._initIds(Object.keys(this.ids).length);Object.entries(this.ids).filter(([,e])=>e).forEach(([e,t],n)=>{let r=i.get(n);r.id=e,r.path=t});let a=t._initMetadata(Object.keys(this.metadata).length);Object.entries(this.metadata).filter(([,e])=>e).forEach(([e,t],n)=>{let r=a.get(n);if(r.id=e,r.type=t.type,r.timestamp=t.timestamp??BigInt(Date.now()),t.properties){let e=r._initProperties(Object.keys(t.properties).length);Object.entries(t.properties).forEach(([t,n],r)=>{let i=e.get(r);i.key=t,i.value=n})}}),await(0,Te.writeFileBuffer)((0,v.joinPaths)(this.#o.dataPath,`fs.bin`),e.toArrayBuffer()),this.#o.config.skipCache||this.#i.save(!0),await Promise.all(this.#f().map(async e=>e.adapter.dispose())),this.#s(c.LogLevelLabel.TRACE,`Virtual file system has been disposed.`)}}async[Symbol.asyncDispose](){return this.dispose()}};const Kt=45,qt=62;function Jt(e,t){let n=`${(0,ze.kebabCase)(e)}_${t}`;return n.length>45?n.slice(0,45):n}async function Yt(e){let t=(0,v.joinPaths)(e.dataPath,`meta.json`);e.log(c.LogLevelLabel.DEBUG,`Writing runtime metadata to ${t}`),await e.fs.write(t,JSON.stringify(e.meta,null,2))}const $=new WeakMap;(0,R.setGlobalDispatcher)(new R.Agent({keepAliveTimeout:1e4}).compose(R.interceptors.retry({maxRetries:3,minTimeout:1e3,maxTimeout:1e4,timeoutFactor:2,retryAfter:!0})));var Xt=class e{#e={};#t;#n=null;#r=(0,be.uuid)();#i=(0,be.uuid)();#a=Date.now();#o;#s;#c;#l;#u;#d;#f(e={}){return{variant:e.build?.variant,projectType:e.type,projectRoot:e.root,name:e.name,title:e.title,description:e.description,sourceRoot:e.sourceRoot,configFile:e.configFile,customLogger:e.customLogger,logLevel:e.logLevel,tsconfig:e.tsconfig,tsconfigRaw:e.tsconfigRaw,skipCache:e.skipCache,skipInstalls:e.skipInstalls,entry:e.entry,output:e.output,plugins:e.plugins,mode:e.mode,lint:e.lint,transform:e.transform,build:e.build,framework:e.framework,...e}}static async from(t,n){let r=new e(await lt(t,n.root));if(await r.withUserConfig(n),r.powerlinesPath=await(0,_.resolvePackage)(`powerlines`),!r.powerlinesPath)throw Error("Could not resolve `powerlines` package location.");return r}dependencies={};devDependencies={};persistedMeta=void 0;powerlinesPath;packageJson;projectJson=void 0;resolver;resolvePatterns=[];get $$internal(){return this.#e}set $$internal(e){this.#e=e}get entry(){return Ot(this,(0,d.toArray)(this.config.entry))}get tsconfig(){return this.#c||(this.tsconfig={tsconfigFilePath:this.config.tsconfig}),this.#c}set tsconfig(e){this.#c=e,this.resolvePatterns=(0,L.tsconfigPathsToRegExp)(e?.options?.paths??{})}get fs(){return this.#s||=Gt.createSync(this),this.#s}get checksum(){return this.#n}get meta(){return{buildId:this.#r,releaseId:this.#i,checksum:this.#n,timestamp:this.#a,projectRootHash:(0,N.murmurhash)({workspaceRoot:this.workspaceConfig?.workspaceRoot,projectRoot:this.config?.projectRoot},{maxLength:45}),configHash:(0,N.murmurhash)(this.config,{maxLength:62})}}get config(){return this.resolvedConfig??{}}get log(){return this.logFn||=this.createLog(),this.logFn}get workspaceConfig(){return this.#t}get envPaths(){return this.#o||=(0,ge.getEnvPaths)({orgId:`storm-software`,appId:`powerlines`,workspaceRoot:this.workspaceConfig.workspaceRoot}),this.#o}get artifactsPath(){return(0,I.joinPaths)(this.workspaceConfig.workspaceRoot,this.config.projectRoot,this.config.output.artifactsPath)}get builtinsPath(){return(0,I.joinPaths)(this.artifactsPath,`builtins`)}get entryPath(){return(0,I.joinPaths)(this.artifactsPath,`entry`)}get dataPath(){return(0,I.joinPaths)(this.envPaths.data,`projects`,Jt(this.config.name,this.meta.projectRootHash))}get cachePath(){return(0,I.joinPaths)(this.envPaths.cache,`projects`,(0,N.murmurhash)({checksum:this.#n,config:this.meta.configHash},{maxLength:62}))}get dtsPath(){return this.config.output.dts?(0,f.appendPath)(this.config.output.dts,this.workspaceConfig.workspaceRoot):(0,I.joinPaths)(this.workspaceConfig.workspaceRoot,this.config.projectRoot,`powerlines.d.ts`)}get relativeToWorkspaceRoot(){return(0,te.relativeToWorkspaceRoot)(this.config.projectRoot)}get builtins(){return Object.values(this.fs.metadata).filter(e=>e&&e.type===`builtin`).map(e=>e?.id).filter(Boolean)}get program(){return this.#l||=Ke(this,{skipAddingFilesFromTsConfig:!0}),this.#l}get parserCache(){return this.#u||=(0,xe.create)({cacheId:`parser`,cacheDir:this.cachePath,ttl:7200*1e3,lruSize:5e3,persistInterval:250}),this.#u}get requestCache(){return this.#d||=(0,xe.create)({cacheId:`http`,cacheDir:this.cachePath,ttl:300*1e3,lruSize:5e3,persistInterval:250}),this.#d}async fetch(e,t={}){let n=(0,N.murmurhash)({input:e.toString(),options:JSON.stringify(t)});if(!this.config.skipCache&&!t.skipCache){let e=this.requestCache.get(n);if(e)return new R.Response(e.body,{status:e.status,statusText:e.statusText,headers:e.headers})}let r=await(0,ve.fetchRequest)(e,{timeout:12e3,...t}),i={body:await r.text(),status:r.status,statusText:r.statusText,headers:Object.fromEntries(r.headers.entries())};if(!this.config.skipCache&&!t.skipCache)try{this.requestCache.set(n,i)}catch{}return new R.Response(i.body,{status:i.status,statusText:i.statusText,headers:i.headers})}async parse(e,t={}){let n=(0,N.murmurhash)({code:e,options:t}),r;return!this.config.skipCache&&(r=this.parserCache.get(n),r)?r:(r=await(0,Se.parse)(`source.${t.lang||`ts`}`,e,{...t,sourceType:`module`,showSemanticErrors:this.config.mode===`development`}),this.config.skipCache||this.parserCache.set(n,r),r)}async resolve(e,t,n={}){let r=e;if(this.config.build.alias)if(Array.isArray(this.config.build.alias)){let e=this.config.build.alias.find(e=>(0,L.match)(r,[e.find]));e&&(r=e.replacement)}else (0,b.isSetObject)(this.config.build.alias)&&this.config.build.alias[e]&&(r=this.config.build.alias[e]);if(this.fs.isVirtual(r)){let e=await this.fs.resolve(r,t,{conditions:this.config.build.conditions,extensions:this.config.build.extensions,...n});return e?{id:`\0${e}`,external:this.config.projectType!==`application`}:void 0}if(this.config.build.skipNodeModulesBundle){if((0,L.match)(r,this.resolvePatterns)||(0,L.match)(r,this.config.build.noExternal))return;if((0,L.match)(r,this.config.build.external)||r.startsWith(`node:`)||!/^[A-Z]:[/\\]|^\.{0,2}\/|^\.{1,2}$/.test(r))return{id:r,external:!0}}else{if((0,L.match)(r,this.config.build.noExternal))return;if((0,L.match)(r,this.config.build.external)||r.startsWith(`node:`))return{id:r,external:!0}}}async load(e){let t=await this.fs.resolve(e);if(!t)return;let n=await this.fs.read(t);if(n)return{code:n,map:null}}async getBuiltins(){return Promise.all(Object.entries(this.fs.metadata).filter(([,e])=>e&&e.type===`builtin`).map(async([e,t])=>{let n=await this.fs.read(e);return{...t,path:e,code:n}}))}async emitEntry(e,t,n={}){return this.fs.write((0,F.isAbsolute)(t)?t:(0,f.appendPath)(t,this.entryPath),e,(0,l.default)(n,{type:`entry`}))}async emitBuiltin(e,t,n,r={}){return this.fs.write(n?(0,F.isAbsolute)(n)?n:(0,I.joinPaths)(this.builtinsPath,n):(0,f.appendPath)(t,this.builtinsPath),e,(0,l.default)(r,{type:`builtin`}))}async withUserConfig(e,t={isHighPriority:!0}){this.mergeUserConfig(e),await this.init(this.config.userConfig,t)}async withInlineConfig(e,t={isHighPriority:!0}){if(this.config.inlineConfig=e,e.command===`new`){let e=(0,I.joinPaths)(this.workspaceConfig.workspaceRoot,`package.json`);if(!(0,M.existsSync)(e))throw Error(`The workspace package.json file could not be found at ${e}`);this.packageJson=await(0,O.readJsonFile)(e),this.workspaceConfig.repository??=(0,x.isSetString)(this.packageJson?.repository)?this.packageJson.repository:this.packageJson?.repository?.url}await this.init(this.config.inlineConfig,t)}fatal(e){this.log(c.LogLevelLabel.FATAL,(0,E.isString)(e)?e:k.StormJSON.stringify(e))}error(e){this.log(c.LogLevelLabel.ERROR,(0,E.isString)(e)?e:k.StormJSON.stringify(e))}warn(e){this.log(c.LogLevelLabel.WARN,(0,E.isString)(e)?e:k.StormJSON.stringify(e))}info(e){this.log(c.LogLevelLabel.INFO,(0,E.isString)(e)?e:k.StormJSON.stringify(e))}debug(e){this.log(c.LogLevelLabel.DEBUG,(0,E.isString)(e)?e:k.StormJSON.stringify(e))}trace(e){this.log(c.LogLevelLabel.TRACE,(0,E.isString)(e)?e:k.StormJSON.stringify(e))}createLog(e=null){return Ft(e,{...this.config,logLevel:(0,ye.isNull)(this.config.logLevel)?`silent`:this.config.logLevel})}extendLog(e){return Lt(this.log,e)}async generateChecksum(e=this.config.projectRoot){return this.#n=await(0,_e.hashDirectory)(e,{ignore:[`node_modules`,`.git`,`.nx`,`.cache`,`.storm`,`tmp`,`dist`]}),this.#n}constructor(e){this.#t=e,this.#o=(0,ge.getEnvPaths)({orgId:`storm-software`,appId:`powerlines`,workspaceRoot:e.workspaceRoot})}resolvedConfig={};logFn;async init(e={},t={isHighPriority:!0}){let n={projectRoot:e.root??this.config.projectRoot??this.config.userConfig?.root??this.config.inlineConfig?.root,mode:(e.mode??this.config.mode)||this.workspaceConfig.mode,skipCache:e.skipCache??this.config.skipCache??!1,configFile:e.configFile??this.config.configFile,framework:e.framework??this.config.framework??`powerlines`,command:this.config.inlineConfig?.command};if($.has(n)){let e=$.get(n);this.projectJson=e.projectJson,this.packageJson=e.packageJson,this.#n=e.checksum,this.resolver=e.resolver,this.mergeUserConfig(e.userConfig.config,this.config.userConfig)}else{let t=(0,I.joinPaths)(n.projectRoot,`project.json`);(0,M.existsSync)(t)&&(this.projectJson=await(0,O.readJsonFile)(t));let r=(0,I.joinPaths)(n.projectRoot,`package.json`);(0,M.existsSync)(r)&&(this.packageJson=await(0,O.readJsonFile)(r)),this.#n=await this.generateChecksum(n.projectRoot),this.resolver=pt({workspaceRoot:this.workspaceConfig.workspaceRoot,projectRoot:n.projectRoot,cacheDir:this.cachePath,mode:n.mode,logLevel:e.logLevel||this.config?.logLevel||this.workspaceConfig.logLevel||`info`,skipCache:n.skipCache});let i=await ut(n.projectRoot,this.workspaceConfig.workspaceRoot,this.resolver,n.command,n.mode,n.configFile,n.framework);this.mergeUserConfig(i.config),$.set(n,{projectJson:this.projectJson,packageJson:this.packageJson,checksum:this.#n,resolver:this.resolver,userConfig:i})}e.tsconfig??=U(this.workspaceConfig.workspaceRoot,n.projectRoot,e.tsconfig),(0,b.isSetObject)(e)&&(this.resolvedConfig=(0,l.default)({inlineConfig:this.config.inlineConfig,userConfig:this.config.userConfig},t.isHighPriority?this.#f(e):{},{command:this.config.inlineConfig?.command,...this.#f(this.config.inlineConfig)},this.#f(this.config.userConfig),{mode:this.workspaceConfig?.mode,logLevel:this.workspaceConfig?.logLevel,skipCache:this.workspaceConfig?.skipCache},{name:this.projectJson?.name||this.packageJson?.name,version:this.packageJson?.version,description:this.packageJson?.description,sourceRoot:this.projectJson?.sourceRoot||(0,f.appendPath)(`src`,n.projectRoot),output:(0,l.default)(e.output??{},{outputPath:n.projectRoot?(0,I.joinPaths)(this.workspaceConfig?.directories?.build||`dist`,n.projectRoot):this.workspaceConfig?.directories?.build||`dist`,artifactsPath:(0,I.joinPaths)(n.projectRoot,`.${e.framework??`powerlines`}`),dts:(0,I.joinPaths)(n.projectRoot,`${e.framework??`powerlines`}.d.ts`),builtinPrefix:e.framework??`powerlines`,assets:[{glob:`LICENSE`},{input:n.projectRoot,glob:`*.md`},{input:n.projectRoot,glob:`package.json`}]})},t.isHighPriority?{}:this.#f(e),{inlineConfig:{},userConfig:{},framework:`powerlines`,platform:`neutral`,mode:`production`,projectType:`application`,logLevel:`info`,preview:!1,environments:{},transform:{babel:{plugins:[],presets:[]}},lint:{eslint:{}},build:{target:`esnext`,override:{}}})),this.config.entry=kt(this.config.entry),this.config.name?.startsWith(`@`)&&this.config.name.split(`/`).filter(Boolean).length>1&&(this.config.name=this.config.name.split(`/`).filter(Boolean)[1]),this.config.title??=(0,j.titleCase)(this.config.name),this.config.userConfig.build?.external&&(this.config.userConfig.build.external=(0,P.getUnique)(this.config.userConfig.build.external)),this.config.userConfig.build?.noExternal&&(this.config.userConfig.build.noExternal=(0,P.getUnique)(this.config.userConfig.build.noExternal)),this.config.build.external&&(this.config.build.external=(0,P.getUnique)(this.config.build.external)),this.config.build.noExternal&&(this.config.build.noExternal=(0,P.getUnique)(this.config.build.noExternal)),this.config.output.format=(0,P.getUnique)((0,d.toArray)(this.config.output?.format??(this.config.projectType===`library`?[`cjs`,`esm`]:[`esm`]))),this.config.projectRoot&&this.config.projectRoot!==`.`&&this.config.projectRoot!==`./`&&this.config.projectRoot!==this.workspaceConfig.workspaceRoot?(this.config.output.outputPath??=(0,I.joinPaths)(`dist`,this.config.projectRoot),this.config.output.buildPath??=(0,I.joinPaths)(this.config.projectRoot,`dist`)):(this.config.output.outputPath??=`dist`,this.config.output.buildPath??=`dist`),this.config.output.assets=(0,P.getUnique)(this.config.output.assets.map(e=>({glob:(0,b.isSetObject)(e)?e.glob:e,input:(0,E.isString)(e)||!e.input||e.input===`.`||e.input===`/`||e.input===`./`?this.workspaceConfig.workspaceRoot:(0,f.appendPath)(e.input,this.workspaceConfig.workspaceRoot),output:(0,f.appendPath)((0,b.isSetObject)(e)&&e.output?(0,I.joinPaths)(this.config.output.outputPath,(0,p.replacePath)(e.output,this.config.output.outputPath)):this.config.output.outputPath,this.workspaceConfig.workspaceRoot),ignore:(0,b.isSetObject)(e)&&e.ignore?(0,d.toArray)(e.ignore):void 0}))),this.config.plugins=(this.config.plugins??[]).filter(Boolean).reduce((e,t)=>(K(t)&&q(t,e.filter(e=>K(e)))||e.push(t),e),[]),this.config.tsconfig&&(this.config.tsconfig=J(this,this.config.tsconfig)),this.config.output.dts&&(this.config.output.dts=J(this,this.config.output.dts)),this.config.build.polyfill&&(this.config.build.polyfill=this.config.build.polyfill.map(e=>J(this,e))),this.config.output.assets&&(this.config.output.assets=this.config.output.assets.map(e=>({...e,glob:J(this,e.glob),ignore:e.ignore?e.ignore.map(e=>J(this,e)):void 0,input:J(this,e.input),output:J(this,e.output)}))),this.#s??=await Gt.create(this)}mergeUserConfig(e={},t=this.config.userConfig??{}){this.config.userConfig=(0,l.default)({entry:Array.isArray(e.entry)&&e.entry.length>0?e.entry:Array.isArray(t?.entry)&&t.entry.length>0?t.entry:[]},(0,ee.omit)(e??{},[`entry`]),(0,ee.omit)(t??{},[`entry`])),this.config.userConfig.output?.format&&(this.config.userConfig.output.format=(0,P.getUnique)((0,d.toArray)(this.config.userConfig.output?.format))),this.config.userConfig.plugins=(this.config.userConfig.plugins??[]).filter(Boolean).reduce((e,t)=>(K(t)&&q(t,e.filter(e=>K(e)))||e.push(t),e),[])}};const Zt=[`name`,`api`,`enforce`,`dedupe`,`dependsOn`,`applyToEnvironment`];function Qt(e,t){let n=e=>(0,E.isString)(e)?e:e.message,r=t.extendLog(e.name),i=async(e,n,...r)=>t.$$internal.api.callHook(e,{sequential:!0,result:`merge`,...n,environment:t},...r);return new Proxy({},{get(e,a){return a===`$$internal`?{...t.$$internal,environment:t,callHook:i}:a===`log`||a===`logger`?r:a===`error`?e=>{r(c.LogLevelLabel.ERROR,n(e))}:a===`warn`?e=>{r(c.LogLevelLabel.WARN,n(e))}:a===`info`?e=>{r(c.LogLevelLabel.INFO,n(e))}:a===`debug`?e=>{r(c.LogLevelLabel.DEBUG,n(e))}:a===`trace`?e=>{r(c.LogLevelLabel.TRACE,n(e))}:t[a]},set(e,n,i){return[`$$internal`,`environment`,`config`,`log`,`logger`,`error`,`warn`,`plugins`,`hooks`,`addPlugin`,`selectHooks`].includes(n)?(r(c.LogLevelLabel.WARN,`Cannot set read-only property "${String(n)}"`),!1):(t[n]=i,!0)}})}var $t=class e extends Xt{#e={};static async fromConfig(t,n){let r=new e(n,t);if(await r.init(),r.powerlinesPath=await(0,_.resolvePackage)(`powerlines`),!r.powerlinesPath)throw Error("Could not resolve `powerlines` package location.");return r}environment;plugins=[];get config(){return super.config}get hooks(){return this.#e}async addPlugin(e){let t=e;if(e.applyToEnvironment){let n=await Promise.resolve(e.applyToEnvironment(this.environment));if(!n||(0,ce.isObject)(n)&&Object.keys(n).length===0)return;t=K(n)?n:e}let n=Qt(t,this);this.plugins.push({plugin:t,context:n}),this.#e=Object.keys(t).filter(e=>!Zt.includes(e)).reduce((e,r)=>{let i=r,a=t[i];if(!bt(a))return e;if(St(i))e[i]??=[],e[i].push({plugin:t,hook:xt(a).bind(n)});else{if(e[i]??={},t.enforce)return e[i][`${t.enforce}Enforced`]??=[],Ct(n,t,a,e[i][`${t.enforce}Enforced`]),e;if((0,y.isFunction)(a)||!a.order)return e[i].normal??=[],Ct(n,t,a,e[i].normal),e;e[i][`${a.order}Ordered`]??=[],Ct(n,t,a,e[i][`${a.order}Ordered`])}return e},this.hooks)}selectHooks(e,t){let n=[];if(this.hooks[e])if(St(e))n.push(...this.hooks[e].map(e=>{let t=this.plugins.find(t=>t.plugin.name===e.plugin.name);if(!t)throw Error(`Could not find plugin context for plugin "${e.plugin.name}".`);return{handle:e.handler,context:t.context}}));else{let r=this.hooks[e];t?.order?t?.order===`pre`?(n.push(...(r.preOrdered??[]).map(e=>{let t=this.plugins.find(t=>t.plugin.name===e.plugin.name);if(!t)throw Error(`Could not find plugin context for plugin "${e.plugin.name}".`);return{handle:e.handler,context:t.context}})),n.push(...(r.preEnforced??[]).map(e=>{let t=this.plugins.find(t=>t.plugin.name===e.plugin.name);if(!t)throw Error(`Could not find plugin context for plugin "${e.plugin.name}".`);return{handle:e.handler,context:t.context}}))):t?.order===`post`?(n.push(...(r.postOrdered??[]).map(e=>{let t=this.plugins.find(t=>t.plugin.name===e.plugin.name);if(!t)throw Error(`Could not find plugin context for plugin "${e.plugin.name}".`);return{handle:e.handler,context:t.context}})),n.push(...(r.postEnforced??[]).map(e=>{let t=this.plugins.find(t=>t.plugin.name===e.plugin.name);if(!t)throw Error(`Could not find plugin context for plugin "${e.plugin.name}".`);return{handle:e.handler,context:t.context}}))):n.push(...(r.normal??[]).map(e=>{let t=this.plugins.find(t=>t.plugin.name===e.plugin.name);if(!t)throw Error(`Could not find plugin context for plugin "${e.plugin.name}".`);return{handle:e.handler,context:t.context}})):(n.push(...this.selectHooks(e,{order:`pre`})),n.push(...this.selectHooks(e,{order:`normal`})),n.push(...this.selectHooks(e,{order:`post`})))}return n}constructor(e,t){super(t),this.resolvedConfig=e}},en=class e extends Xt{#e={};#t=[];#n;static async from(t,n){let r=new e(await lt(t,n.root));if(await r.withUserConfig(n),r.powerlinesPath=await(0,_.resolvePackage)(`powerlines`),!r.powerlinesPath)throw Error("Could not resolve `powerlines` package location.");return r}get $$internal(){return super.$$internal}set $$internal(e){super.$$internal=e;for(let e of Object.values(this.environments))e.$$internal=super.$$internal}get environments(){return this.#e}get log(){return this.#n||=this.createLog(`engine`),this.#n}get plugins(){return this.#t}constructor(e){super(e)}async init(e={}){await super.init(e),await Promise.all((0,d.toArray)(this.config.userConfig.environments&&Object.keys(this.config.userConfig.environments).length>0?Object.keys(this.config.userConfig.environments).map(e=>st(e,this.config.userConfig)):ct(this.config.userConfig)).map(async e=>{this.#e[e.name]=await this.in(e)}))}async in(e){let t;t=this.environments[e.name]?this.environments[e.name]:await $t.fromConfig(this.workspaceConfig,this.config),(0,b.isSetObject)(this.config.inlineConfig)&&await t.withInlineConfig(this.config.inlineConfig),t.environment=e,t.plugins=[];for(let e of this.plugins)await t.addPlugin(e);return t}async withUserConfig(e,t={isHighPriority:!0}){await super.withUserConfig(e,t),await Promise.all(Object.keys(this.#e).map(async n=>{await this.#e[n].withUserConfig(e,t)}))}async withInlineConfig(e,t={isHighPriority:!0}){await super.withInlineConfig(e,t),await Promise.all(Object.keys(this.#e).map(async n=>{await this.#e[n].withInlineConfig(e,t)}))}async addPlugin(e){this.plugins.push(e),await Promise.all(Object.keys(this.environments).map(async t=>{await this.environments[t].addPlugin(e)}))}async getEnvironment(e){let t;if(e&&(t=this.environments[e]),Object.keys(this.environments).length===1&&(t=this.environments[Object.keys(this.environments)[0]],this.log(c.LogLevelLabel.DEBUG,`Applying the only configured environment: ${S.default.bold.cyanBright(t?.environment.name)}`)),!t){if(e)throw Error(`Environment "${e}" not found.`);t=await this.in(ct(this.config.userConfig)),this.log(c.LogLevelLabel.WARN,`No environment specified, and no default environment found. Using a temporary default environment: ${S.default.bold.cyanBright(t?.environment.name)}`)}return t}async getEnvironmentSafe(e){try{return await this.getEnvironment(e)}catch{return}}};function tn(e){return`
21
- // Generated with ${(0,j.titleCase)(e.config.framework)}
22
- // Note: Do not edit this file manually - it will be overwritten automatically
23
- `}function nn(e,t={}){let{directive:n=null,prettierIgnore:r=!1}=t;return`/* eslint-disable */
24
- // biome-ignore lint: disable
25
- ${r?`// prettier-ignore`:``}${n?`\n\n${n}\n`:`
26
- `}
27
- ${tn(e)}
28
-
29
- `}var rn=class e{#e;get context(){return this.#e}constructor(e){this.#e=e}static async from(t,n){let r=new e(await en.from(t,n));r.#e.$$internal={api:r};for(let e of r.context.config.plugins??[])await r.#r(e);r.context.plugins.length===0&&r.context.log(c.LogLevelLabel.WARN,`No Powerlines plugins were specified in the options. Please ensure this is correct, as it is generally not recommended.`);let i=await r.callHook(`config`,{environment:await r.context.getEnvironment(),sequential:!0,result:`merge`});return await r.context.withUserConfig(i,{isHighPriority:!1}),r}async prepare(e={command:`prepare`}){this.context.log(c.LogLevelLabel.TRACE,` 🏗️ Preparing the Powerlines project`),this.context.log(c.LogLevelLabel.TRACE,` ⚙️ Aggregating configuration options for the Powerlines project`),await this.context.withInlineConfig(e),await this.#n(async e=>{if(e.log(c.LogLevelLabel.TRACE,`Initializing the processing options for the Powerlines project.`),await this.callHook(`configResolved`,{environment:e,order:`pre`}),await it(e),await this.callHook(`configResolved`,{environment:e,order:`normal`}),e.log(c.LogLevelLabel.DEBUG,`The configuration provided ${(0,d.toArray)(e.config.entry).length} entry point(s), Powerlines has found ${e.entry.length} entry files(s) for the ${e.config.title} project${e.entry.length>0&&e.entry.length<10?`: \n${e.entry.map(e=>`- ${e.input.file||e.file}${e.output?` -> ${e.output}`:``}`).join(`
30
- `)}`:``}.`),await at(e),await Qe(e),await this.callHook(`configResolved`,{environment:e,order:`post`}),e.log(c.LogLevelLabel.TRACE,`Powerlines configuration has been resolved: \n\n${(0,ie.formatLogMessage)(e.config)}`),e.fs.existsSync(e.cachePath)||await(0,m.createDirectory)(e.cachePath),e.fs.existsSync(e.dataPath)||await(0,m.createDirectory)(e.dataPath),await this.callHook(`prepare`,{environment:e,order:`pre`}),await this.callHook(`prepare`,{environment:e,order:`normal`}),e.config.output.dts!==!1){e.log(c.LogLevelLabel.TRACE,`Preparing the TypeScript definitions for the Powerlines project.`),e.fs.existsSync(e.dtsPath)&&await e.fs.remove(e.dtsPath),e.log(c.LogLevelLabel.TRACE,`Transforming built-ins runtime modules files.`);let t=await Promise.all((await e.getBuiltins()).map(async t=>{let n=await(0,re.transformAsync)(t.code.toString(),{highlightCode:!0,code:!0,ast:!1,cloneInputAst:!1,comments:!0,sourceType:`module`,configFile:!1,babelrc:!1,envName:e.config.mode,caller:{name:`powerlines`},...e.config.transform.babel,filename:t.path,plugins:[[`@babel/plugin-syntax-typescript`],[We(e)]]});if(!n?.code)throw Error(`Powerlines - Generate Types failed to compile ${t.id}`);return e.log(c.LogLevelLabel.TRACE,`Writing transformed built-in runtime file ${t.id}.`),await e.emitBuiltin(n.code,t.id,t.path),t.path}));if(!await(0,_.resolvePackage)(`typescript`))throw Error(`Could not resolve TypeScript package location. Please ensure TypeScript is installed.`);let n=t.reduce((t,n)=>{let r=(0,p.replacePath)(n,e.workspaceConfig.workspaceRoot);return t.includes(r)||t.push(r),t},[]);e.log(c.LogLevelLabel.TRACE,`Parsing TypeScript configuration for the Powerlines project.`);let r=await Je(e,n);e.log(c.LogLevelLabel.TRACE,`Generating TypeScript declaration file ${e.dtsPath}.`);let i=[],a=e=>(0,ce.isObject)(e)?e.code:e,o=await this.callHook(`types`,{environment:e,sequential:!0,order:`pre`,result:`merge`,asNextParam:a},r);if(o&&((0,b.isSetObject)(o)?(r=o.code,Array.isArray(o.directives)&&o.directives.length>0&&i.push(...o.directives)):(0,x.isSetString)(o)&&(r=o)),o=await this.callHook(`types`,{environment:e,sequential:!0,order:`normal`,result:`merge`,asNextParam:a},r),o&&((0,b.isSetObject)(o)?(r=o.code,Array.isArray(o.directives)&&o.directives.length>0&&i.push(...o.directives)):(0,x.isSetString)(o)&&(r=o)),o=await this.callHook(`types`,{environment:e,sequential:!0,order:`post`,result:`merge`,asNextParam:a},r),o&&((0,b.isSetObject)(o)?(r=o.code,Array.isArray(o.directives)&&o.directives.length>0&&i.push(...o.directives)):(0,x.isSetString)(o)&&(r=o)),r?.trim()||i.length>0)await e.fs.write(e.dtsPath,`${i?`${i.map(e=>`/// <reference types="${e}" />`).join(`
31
- `)}
32
-
33
- `:``}${nn(e,{directive:null,prettierIgnore:!1})}
34
-
35
- ${qe(r)}
36
- `);else{let t=nt(e);if(e.tsconfig.tsconfigJson.include&&tt(t,e.tsconfig.tsconfigJson.include)){let n=t.startsWith(`./`)?t.slice(2):t;e.tsconfig.tsconfigJson.include=e.tsconfig.tsconfigJson.include.filter(e=>e?.toString()!==n),await e.fs.write(e.tsconfig.tsconfigFilePath,JSON.stringify(e.tsconfig.tsconfigJson,null,2))}}}if(e.tsconfig=G(e.workspaceConfig.workspaceRoot,e.config.projectRoot,e.config.tsconfig),!e.tsconfig)throw Error(`Failed to parse the TypeScript configuration file.`);await this.callHook(`prepare`,{environment:e,order:`post`}),await Yt(e),e.persistedMeta=e.meta}),this.context.log(c.LogLevelLabel.INFO,`Powerlines API has been prepared successfully`)}async new(e){this.context.log(c.LogLevelLabel.INFO,`🆕 Creating a new Powerlines project`),await this.prepare(e),await this.#n(async e=>{e.log(c.LogLevelLabel.TRACE,`Initializing the processing options for the Powerlines project.`),await this.callHook(`new`,{environment:e,order:`pre`});let t=await(0,h.listFiles)((0,v.joinPaths)(e.powerlinesPath,`files/common/**/*.hbs`));for(let n of t){e.log(c.LogLevelLabel.TRACE,`Adding template file: ${n}`);let t=C.default.compile(n);await e.fs.write((0,v.joinPaths)(e.config.projectRoot,n.replace(`.hbs`,``)),t(e))}if(await this.callHook(`new`,{environment:e,order:`normal`}),e.config.projectType===`application`){let t=await(0,h.listFiles)((0,v.joinPaths)(e.powerlinesPath,`files/application/**/*.hbs`));for(let n of t){e.log(c.LogLevelLabel.TRACE,`Adding application template file: ${n}`);let t=C.default.compile(n);await e.fs.write((0,v.joinPaths)(e.config.projectRoot,n.replace(`.hbs`,``)),t(e))}}else{let t=await(0,h.listFiles)((0,v.joinPaths)(e.powerlinesPath,`files/library/**/*.hbs`));for(let n of t){e.log(c.LogLevelLabel.TRACE,`Adding library template file: ${n}`);let t=C.default.compile(n);await e.fs.write((0,v.joinPaths)(e.config.projectRoot,n.replace(`.hbs`,``)),t(e))}}await this.callHook(`new`,{environment:e,order:`post`})}),this.context.log(c.LogLevelLabel.TRACE,`Powerlines - New command completed`)}async clean(e={command:`clean`}){this.context.log(c.LogLevelLabel.INFO,`🧹 Cleaning the previous Powerlines artifacts`),await this.prepare(e),await this.#n(async e=>{this.context.log(c.LogLevelLabel.TRACE,`Cleaning the project's dist and artifacts directories.`),await e.fs.remove((0,v.joinPaths)(e.workspaceConfig.workspaceRoot,e.config.output.buildPath)),await e.fs.remove((0,v.joinPaths)(e.workspaceConfig.workspaceRoot,e.config.output.artifactsPath)),await this.callHook(`clean`,{environment:e,sequential:!1})}),this.context.log(c.LogLevelLabel.TRACE,`Powerlines - Clean command completed`)}async lint(e={command:`lint`}){this.context.log(c.LogLevelLabel.INFO,`📋 Linting the Powerlines project`),await this.prepare(e),await this.#n(async e=>{e.config.lint!==!1&&await this.callHook(`lint`,{environment:e,sequential:!1})}),this.context.log(c.LogLevelLabel.TRACE,`Powerlines linting completed`)}async build(e={command:`build`}){this.context.log(c.LogLevelLabel.INFO,`📦 Building the Powerlines project`),await this.prepare(e),await this.#n(async e=>{if(await this.callHook(`build`,{environment:e,order:`pre`}),await this.callHook(`build`,{environment:e,order:`normal`}),e.config.output.buildPath!==e.config.output.outputPath){let t=(0,f.appendPath)(e.config.output.buildPath,e.workspaceConfig.workspaceRoot),n=(0,v.joinPaths)((0,f.appendPath)(e.config.output.outputPath,e.workspaceConfig.workspaceRoot),`dist`);t!==n&&(e.log(c.LogLevelLabel.INFO,`Copying build output files from project's build directory (${e.config.output.buildPath}) to the workspace's output directory (${e.config.output.outputPath}).`),await e.fs.copy(t,n))}await Promise.all(e.config.output.assets.map(async t=>{e.log(c.LogLevelLabel.DEBUG,`Copying asset(s): ${S.default.redBright(e.workspaceConfig.workspaceRoot===t.input?t.glob:(0,v.joinPaths)((0,p.replacePath)(t.input,e.workspaceConfig.workspaceRoot),t.glob))} -> ${S.default.greenBright((0,v.joinPaths)((0,p.replacePath)(t.output,e.workspaceConfig.workspaceRoot),t.glob))} ${Array.isArray(t.ignore)&&t.ignore.length>0?` (ignoring: ${t.ignore.map(e=>S.default.yellowBright(e)).join(`, `)})`:``}`),await e.fs.copy(t,t.output)})),await this.callHook(`build`,{environment:e,order:`post`})}),this.context.log(c.LogLevelLabel.TRACE,`Powerlines build completed`)}async docs(e={command:`docs`}){this.context.log(c.LogLevelLabel.INFO,`📓 Generating documentation for the Powerlines project`),await this.prepare(e),await this.#n(async t=>{t.log(c.LogLevelLabel.TRACE,`Writing documentation for the Powerlines project artifacts.`),await this.prepare(e),await this.#n(async e=>{await this.callHook(`docs`,{environment:e})})}),this.#e.log(c.LogLevelLabel.TRACE,`Powerlines documentation generation completed`)}async deploy(e={command:`deploy`}){this.context.log(c.LogLevelLabel.INFO,`📦 Deploying the Powerlines project`),await this.prepare(e),await this.#n(async e=>{await this.callHook(`deploy`,{environment:e})}),this.context.log(c.LogLevelLabel.TRACE,`Powerlines deploy completed`)}async finalize(){this.context.log(c.LogLevelLabel.TRACE,`Powerlines finalize execution started`),await this.#n(async e=>{await this.callHook(`finalize`,{environment:e}),await e.fs.dispose()}),this.context.log(c.LogLevelLabel.TRACE,`Powerlines finalize execution completed`)}async callHook(e,t,...n){return Xe((0,b.isSetObject)(t?.environment)?t.environment:await this.#e.getEnvironment(t?.environment),e,{sequential:!0,...t},...n)}async[Symbol.asyncDispose](){await this.finalize()}async#t(){return!this.context.config.environments||Object.keys(this.context.config.environments).length<=1?(this.context.log(c.LogLevelLabel.DEBUG,`No environments are configured for this Powerlines project. Using the default environment.`),[await this.context.getEnvironment()]):(this.context.log(c.LogLevelLabel.DEBUG,`Found ${Object.keys(this.context.config.environments).length} configured environment(s) for this Powerlines project.`),(await Promise.all(Object.entries(this.context.config.environments).map(async([e,t])=>{if(!await this.context.getEnvironmentSafe(e)){let n=await this.callHook(`configEnvironment`,{environment:e},e,t);n&&(this.context.environments[e]=await this.context.in(n))}return this.context.environments[e]}))).filter(e=>(0,ue.isSet)(e)))}async#n(e){await Promise.all((await this.#t()).map(async t=>Promise.resolve(e(t))))}async#r(e){if(e){let t=await this.#i(e);if(!t)return;if(t.dependsOn)for(let e of t.dependsOn)await this.#r(e);this.context.log(c.LogLevelLabel.DEBUG,`Successfully initialized the ${S.default.bold.cyanBright(t.name)} plugin`),await this.context.addPlugin(t)}}async#i(e){let t=e;if((0,le.isPromiseLike)(e)&&(t=await Promise.resolve(e)),!_t(t))throw Error(`Invalid plugin specified in the configuration - ${JSON.stringify(t)}. Please ensure the value is a plugin name, an object with the \`plugin\` and \`props\` properties, or an instance of \`Plugin\`.`);let n;if(K(t))n=t;else if((0,y.isFunction)(t))n=await Promise.resolve(t());else if((0,x.isSetString)(t)){let e=await this.#a(t);n=(0,y.isFunction)(e)?await Promise.resolve(e()):e}else if(gt(t)||ht(t)){let e,r;if(gt(t)?(e=t[0],r=t?.length===2?t[1]:void 0):(e=t.plugin,r=t.options),(0,x.isSetString)(e)){let t=await this.#a(e);n=(0,y.isFunction)(t)?await Promise.resolve(r?t(r):t()):t}else (0,y.isFunction)(e)?n=await Promise.resolve(e(r)):K(e)&&(n=e)}if(!n)throw Error(`The plugin configuration ${JSON.stringify(t)} is invalid. This configuration must point to a valid Powerlines plugin module.`);if(!K(n))throw Error(`The plugin option ${JSON.stringify(n)} does not export a valid module. This configuration must point to a valid Powerlines plugin module.`);return q(n,this.context.plugins)?(this.context.log(c.LogLevelLabel.TRACE,`Duplicate ${S.default.bold.cyanBright(n.name)} plugin dependency detected - Skipping initialization.`),null):(this.context.log(c.LogLevelLabel.TRACE,`Initializing the ${S.default.bold.cyanBright(n.name)} plugin...`),n)}async#a(e){if(e.startsWith(`@`)&&e.split(`/`).filter(Boolean).length>2){let t=e.split(`/`).filter(Boolean);e=`${t[0]}/${t[1]}`}let t=(0,g.isPackageExists)(e,{paths:[this.context.workspaceConfig.workspaceRoot,this.context.config.projectRoot]});if(!t&&this.context.config.skipInstalls!==!0){this.#e.log(c.LogLevelLabel.WARN,`The plugin package "${e}" is not installed. It will be installed automatically.`);let t=await(0,ae.install)(e,{cwd:this.context.config.projectRoot});if((0,se.isNumber)(t.exitCode)&&t.exitCode>0)throw this.#e.log(c.LogLevelLabel.ERROR,t.stderr),Error(`An error occurred while installing the build plugin package "${e}" `)}try{let t=await this.context.resolver.plugin.import(this.context.resolver.plugin.esmResolve((0,v.joinPaths)(e,`plugin`))),n=t.plugin??t.default;if(!n)throw Error(`The plugin package "${e}" does not export a valid module.`);return n}catch(n){try{let t=await this.context.resolver.plugin.import(this.context.resolver.plugin.esmResolve(e)),n=t.plugin??t.default;if(!n)throw Error(`The plugin package "${e}" does not export a valid module.`);return n}catch{throw t?Error(`An error occurred while importing the build plugin package "${e}":
37
- ${(0,oe.isError)(n)?n.message:String(n)}
38
-
39
- Note: Please ensure the plugin package's default export is a class that extends \`Plugin\` with a constructor that excepts a single arguments of type \`PluginOptions\`.`):Error(`The plugin package "${e}" is not installed. Please install the package using the command: "npm install ${e} --save-dev"`)}}}};function an(e){return e?(0,E.isString)(e)?e:(0,b.isSetObject)(e)&&`code`in e?e.code:e.toString():``}function on(e,t){return(0,l.defu)(e,t)}function sn(e){let t=e;return(0,ne.setParseImpl)(t.parse),()=>{let e=Lt(t.log,`unplugin`);e(c.LogLevelLabel.DEBUG,`Initializing Unplugin`);try{async function n(){e(c.LogLevelLabel.DEBUG,`Powerlines build plugin starting...`),await t.$$internal.callHook(`buildStart`,{sequential:!0})}async function r(e,n,r={isEntry:!1}){let i=await(async()=>{let i=await t.$$internal.callHook(`resolveId`,{sequential:!0,result:`first`,order:`pre`},e,n,r);return i||(i=await t.$$internal.callHook(`resolveId`,{sequential:!0,result:`first`,order:`normal`},e,n,r),i)||(i=await t.resolve(e,n,r),i)?i:t.$$internal.callHook(`resolveId`,{sequential:!0,result:`first`,order:`post`},e,n,r)})();if(i&&r.isEntry&&t.config.build.polyfill&&t.config.build.polyfill.length>0){let e=t.entry.find(e=>e.file===((0,E.isString)(i)?i:i.id));if(e)return e.file=`${(0,p.replaceExtension)((0,E.isString)(i)?i:i.id)}-polyfill.ts`,e.output||=e.output?.replace((0,A.findFileName)(e.output,{withExtension:!0}),e.file),await t.emitEntry(`
40
- ${t.config.build.polyfill.map(e=>`import "${e}";`).join(`
41
- `)}
42
-
43
- export * from "${(0,E.isString)(i)?i:i.id}";
44
- `,e.file),e.file}return i}async function i(e){let n=await t.$$internal.callHook(`load`,{sequential:!0,result:`first`,order:`pre`},e);return n||(n=await t.$$internal.callHook(`load`,{sequential:!0,result:`first`,order:`normal`},e),n)||(n=await t.load(e),n)?n:t.$$internal.callHook(`load`,{sequential:!0,result:`first`,order:`post`},e)}async function a(e,n){let r=e;for(let e of t.$$internal.environment.selectHooks(`transform`)){let i=await e.handle.apply(on(t,this),[an(r),n]);i&&(r=i)}return r}async function o(){return e(c.LogLevelLabel.DEBUG,`Powerlines build plugin finishing...`),t.$$internal.callHook(`buildEnd`,{sequential:!0})}async function s(){return e(c.LogLevelLabel.DEBUG,`Finalizing Powerlines project output...`),t.$$internal.callHook(`writeBundle`,{sequential:!0})}return{name:`powerlines`,api:t.$$internal.api,resolveId:{filter:{id:{include:[/.*/]}},handler:r},load:{filter:{id:{include:[/.*/]}},handler:i},transform:a,buildStart:n,buildEnd:o,writeBundle:s,vite:{sharedDuringBuild:!0}}}catch(t){throw e(c.LogLevelLabel.FATAL,t?.message),t}}}function cn(e){return(0,ne.createRolldownPlugin)(sn(e))({})}Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return s}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return cn}});
@@ -1 +0,0 @@
1
- {"version":3,"file":"unplugin-RGhxc0bb.d.mts","names":[],"sources":["../src/helpers/unplugin.ts"],"sourcesContent":[],"mappings":";;;;iBAsBgB,kBAAA,UAA4B,sBAAmB,SAAA,CAAA,cAAA,SAAA,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"unplugin-SHGDrJv0.d.cts","names":[],"sources":["../src/helpers/unplugin.ts"],"sourcesContent":[],"mappings":";;;;iBAsBgB,kBAAA,UAA4B,sBAAmB,SAAA,CAAA,cAAA,SAAA,CAAA"}