@fnet/cli 0.3.7 → 0.3.8

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,10 +1,10 @@
1
1
  #!/usr/bin/env node
2
2
  import{a as z0,b as W0}from"./index.2084z2ed.js";import{c as k,d as Z5,e as D}from"./index.r19p3bpa.js";var Y5=Z5((P3,J5)=>{J5.exports=X5;function X5($,Q,Z){if($ instanceof RegExp)$=Q5($,Z);if(Q instanceof RegExp)Q=Q5(Q,Z);var X=q5($,Q,Z);return X&&{start:X[0],end:X[1],pre:Z.slice(0,X[0]),body:Z.slice(X[0]+$.length,X[1]),post:Z.slice(X[1]+Q.length)}}function Q5($,Q){var Z=Q.match($);return Z?Z[0]:null}X5.range=q5;function q5($,Q,Z){var X,q,J,V,Y,W=Z.indexOf($),H=Z.indexOf(Q,W+1),K=W;if(W>=0&&H>0){if($===Q)return[W,H];X=[],J=Z.length;while(K>=0&&!Y){if(K==W)X.push(K),W=Z.indexOf($,K+1);else if(X.length==1)Y=[X.pop(),H];else{if(q=X.pop(),q<J)J=q,V=H;H=Z.indexOf(Q,K+1)}K=W<H&&W>=0?W:H}if(X.length)Y=[J,V]}return Y}});var U5=Z5((N3,z5)=>{var V5=Y5();z5.exports=y7;var W5="\x00SLASH"+Math.random()+"\x00",H5="\x00OPEN"+Math.random()+"\x00",v$="\x00CLOSE"+Math.random()+"\x00",K5="\x00COMMA"+Math.random()+"\x00",_5="\x00PERIOD"+Math.random()+"\x00";function D$($){return parseInt($,10)==$?parseInt($,10):$.charCodeAt(0)}function v7($){return $.split("\\\\").join(W5).split("\\{").join(H5).split("\\}").join(v$).split("\\,").join(K5).split("\\.").join(_5)}function E7($){return $.split(W5).join("\\").split(H5).join("{").split(v$).join("}").split(K5).join(",").split(_5).join(".")}function G5($){if(!$)return[""];var Q=[],Z=V5("{","}",$);if(!Z)return $.split(",");var{pre:X,body:q,post:J}=Z,V=X.split(",");V[V.length-1]+="{"+q+"}";var Y=G5(J);if(J.length)V[V.length-1]+=Y.shift(),V.push.apply(V,Y);return Q.push.apply(Q,V),Q}function y7($){if(!$)return[];if($.substr(0,2)==="{}")$="\\{\\}"+$.substr(2);return c0(v7($),!0).map(E7)}function x7($){return"{"+$+"}"}function u7($){return/^-?0\d/.test($)}function f7($,Q){return $<=Q}function h7($,Q){return $>=Q}function c0($,Q){var Z=[],X=V5("{","}",$);if(!X)return[$];var q=X.pre,J=X.post.length?c0(X.post,!1):[""];if(/\$$/.test(X.pre))for(var V=0;V<J.length;V++){var Y=q+"{"+X.body+"}"+J[V];Z.push(Y)}else{var W=/^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(X.body),H=/^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(X.body),K=W||H,G=X.body.indexOf(",")>=0;if(!K&&!G){if(X.post.match(/,.*\}/))return $=X.pre+"{"+X.body+v$+X.post,c0($);return[$]}var _;if(K)_=X.body.split(/\.\./);else if(_=G5(X.body),_.length===1){if(_=c0(_[0],!1).map(x7),_.length===1)return J.map(function(d1){return X.pre+_[0]+d1})}var O;if(K){var M=D$(_[0]),z=D$(_[1]),U=Math.max(_[0].length,_[1].length),A=_.length==3?Math.abs(D$(_[2])):1,B=f7,C=z<M;if(C)A*=-1,B=h7;var T=_.some(u7);O=[];for(var p=M;B(p,z);p+=A){var x;if(H){if(x=String.fromCharCode(p),x==="\\")x=""}else if(x=String(p),T){var Q0=U-x.length;if(Q0>0){var b0=Array(Q0+1).join("0");if(p<0)x="-"+b0+x.slice(1);else x=b0+x}}O.push(x)}}else{O=[];for(var Z0=0;Z0<_.length;Z0++)O.push.apply(O,c0(_[Z0],!1))}for(var Z0=0;Z0<O.length;Z0++)for(var V=0;V<J.length;V++){var Y=q+O[Z0]+J[V];if(!Q||K||Y)Z.push(Y)}}return Z}});import b2 from"yargs";import l1 from"chalk";import{promisify as p1}from"node:util";import i1 from"tree-kill";var M6=p1(i1),j0=!1;async function m8($,Q){if(j0)return;if(j0=!0,!$.killed&&$.pid)try{if(await M6($.pid,"SIGTERM").catch(()=>{}),await new Promise((X)=>setTimeout(X,500)),!$.killed)await M6($.pid,"SIGKILL").catch(()=>{})}catch(X){}await new Promise((X)=>setTimeout(X,100));let Z=Q==="SIGINT"?130:Q==="SIGTERM"?143:1;process.exit(Z)}function c8($){["SIGINT","SIGTERM","SIGQUIT"].forEach((Q)=>{process.once(Q,async()=>{await m8($,Q)})}),process.on("uncaughtException",async(Q)=>{await m8($)}),process.on("unhandledRejection",async(Q)=>{await m8($)}),$.on("close",(Q)=>{if(!j0)process.exit(Q)})}function O6(){process.on("uncaughtException",($)=>{if(!j0)j0=!0,setTimeout(()=>process.exit(1),500)}),process.on("unhandledRejection",($)=>{if(!j0)j0=!0,setTimeout(()=>process.exit(1),500)})}import m0 from"node:path";import{spawn as A6}from"node:child_process";import W8 from"node:fs";import g0 from"chalk";import n1 from"@fnet/config";function l($,{name:Q,bin:Z,preArgs:X=[],createContext:q}){if(typeof Z==="function")Z=Z();return $.command(`${Q||Z} [commands..]`,`${Z} ${X.join(" ")}`,(J)=>{return J.help(!1).version(!1)},async(J)=>{try{let V=await q(J),{projectDir:Y}=V,W=(M)=>{if(!M.includes(" "))return M;if(process.platform==="win32")return`"${M.replace(/(["^])/g,"^$1")}"`;else return`"${M.replace(/(["\\$`])/g,"\\$1")}"`},H=process.argv.slice(3).map(W),K={...process.env},G=m0.join(Y,"node_modules");K.NODE_PATH=G;let _=K.NODE_OPTIONS||"";K.NODE_OPTIONS=`${_} --preserve-symlinks`.trim();let O=A6(Z,[...X,...H],{cwd:Y,stdio:"inherit",shell:!0,detached:!0,env:K});c8(O)}catch(V){console.error(V.message),process.exit(1)}})}function B6($,{name:Q,preArgs:Z=[],createContext:X}){return $.command(`${Q} <config> <command> [options..]`,"Run a command with a config context",(q)=>{return q.positional("config",{type:"string"}).positional("command",{type:"string"}).help(!1).version(!1)},async(q)=>{try{let J=await X(q),{projectDir:V}=J,Y=q.config,H=(await n1({name:Y,dir:V,transferEnv:!1,optional:!0,tags:J.tags}))?.data?.env||void 0,K=q.command,G=process.argv.slice(5),_=A6(K,[...Z,...G],{cwd:W8.existsSync(V)?V:process.cwd(),stdio:"inherit",shell:!0,detached:!0,env:{...process.env,...H}});c8(_)}catch(J){console.error(J.message),process.exit(1)}})}function R6($,{name:Q,projectType:Z="auto"}){return $.command(`${Q} group [options..]`,"Run a command group.",(X)=>{return X.positional("group",{type:"string"}).option("ftag",{type:"array"}).help(!1).version(!1)},async(X)=>{try{let{runCommandGroup:q}=await import("./index.0jcm9pn5.js");await q({projectType:Z,group:X.group,tags:X.ftag,args:X,argv:process.argv})}catch(q){console.error(q.message),process.exit(1)}})}function C6($,{name:Q,createContext:Z}){return $.command(`${Q} [options]`,"Install the project as a binary",(X)=>{return X.option("name",{alias:"n",describe:"Name to use for the installed binary",type:"string"}).option("force",{alias:"f",describe:"Force overwrite if binary already exists",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Automatically answer yes to all prompts",type:"boolean",default:!1})},async(X)=>{try{let q=await Z(X),{projectDir:J}=q;console.log(g0.blue("Compiling project..."));let V=m0.join(J,".bin");if(!W8.existsSync(V))W8.mkdirSync(V,{recursive:!0});let Y=m0.basename(m0.dirname(J)),W=q.project?.projectFileParsed?.features?.cli?.bin,H=X.name||W||Y;console.log(g0.blue(`Using binary name: ${H}`));let K=m0.join(V,H),{spawn:G}=await import("child_process"),_=G("bun",["build","./dist/cli/esm/index.js","--compile",`--outfile=${K}`],{cwd:J,stdio:"inherit",shell:!0});if(await new Promise((z,U)=>{_.on("close",(A)=>{if(A===0)z();else U(Error(`Compilation failed with code ${A}`))}),_.on("error",(A)=>{U(A)})}),process.platform!=="win32")W8.chmodSync(K,493);console.log(g0.green(`Binary compiled successfully: ${K}`)),console.log(g0.blue("Installing binary..."));let O=["install",K];if(X.name)O.push("--name",X.name);if(X.force)O.push("--force");if(X.yes)O.push("--yes");let M=G("fbin",O,{stdio:"inherit",shell:!0});await new Promise((z,U)=>{M.on("close",(A)=>{if(A===0)z();else U(Error(`Installation failed with code ${A}`))}),M.on("error",(A)=>{U(A)})})}catch(q){console.error(g0.red(`Failed to install binary: ${q.message}`)),process.exit(1)}})}import V0 from"node:path";import T0 from"node:fs";import l8 from"@fnet/yaml";import r1 from"yaml";async function w($){if($.id)return{id:$.id,buildId:$.buildId,mode:$.mode,protocol:$.protocol||"ac:",templateDir:z0("./template/fnet/node"),coreDir:z0("./template/fnet/core"),projectDir:V0.resolve(process.cwd(),`./.output/${$.id}`),tags:$.ftag,dev:$.dev};else try{let Q=await s1({tags:$.ftag});return{buildId:$.buildId,mode:$.mode,protocol:$.protocol||"src:",templateDir:z0("./template/fnet/node"),coreDir:z0("./template/fnet/core"),projectDir:V0.resolve(Q.projectDir,"./.workspace"),projectSrcDir:V0.resolve(Q.projectDir,"./src"),project:Q,tags:$.ftag,dev:$.dev}}catch(Q){return console.warn(`Warning: Could not load project: ${Q.message}`),{projectDir:process.cwd(),tags:$.ftag}}}async function s1({tags:$}){let Q=a1(process.cwd());if(!T0.existsSync(Q))throw Error("fnet.yaml file not found in current directory.");let{raw:Z,parsed:X}=await l8({file:Q,tags:$}),q=V0.dirname(Q);X.features=X.features||{};let J=X.features;J.runtime=J.runtime||{},J.runtime.type=J.runtime.type||"node";let V;if(typeof X.flows==="object")V=X.flows;else{let G="flow.main.yaml";if(T0.existsSync(V0.join(q,"fnet","flows.yaml")))G=V0.join("fnet","flows.yaml");let _=X.main||G,O=V0.resolve(q,_);if(!T0.existsSync(O))V={main:{steps:[]}};else{let{parsed:M}=await l8({file:O,tags:$});V=M}}let W={workflowAtom:{doc:{...X,content:V}},projectDir:q,projectFilePath:Q,projectFileContent:Z,projectFileParsed:X,runtime:J.runtime},H=V0.resolve(q,"fnet/targets.yaml");if(T0.existsSync(H)){let{raw:G,parsed:_}=await l8({file:H,tags:$}),O=r1.parseDocument(G);W.devops={filePath:H,fileContent:G,yamlDocument:O,doc:{..._},type:"workflow.deploy",save:async()=>{T0.writeFileSync(W.devops.filePath,O.toString())}}}let K=V0.resolve(q,"readme.md");if(T0.existsSync(K)){let G=T0.readFileSync(K,"utf8");W.readme={filePath:K,fileContent:G,doc:{content:G,"content-type":"markdown"},type:"wiki"}}return W}function a1($){return V0.resolve($,"fnet.yaml")}import o1 from"node:path";import I6 from"node:fs";import t1 from"node:os";import e1 from"@flownet/lib-render-templates-dir";import d8 from"@fnet/shelljs";var $7={command:"create",describe:"Initialize a new fnet project",builder:($)=>{return $.option("name",{type:"string",describe:"Project name"}).option("vscode",{type:"boolean",default:!0,alias:"vs",describe:"Open in VS Code after creation"}).option("runtime",{type:"string",default:"node",choices:["node"],describe:"Runtime environment"})},handler:async($)=>{try{let Q=process.cwd(),Z=z0("./template/fnet/project"),X=o1.resolve(Q,$.name);if(!I6.existsSync(X))I6.mkdirSync(X);await e1({dir:Z,outDir:X,context:$,copyUnmatchedAlso:!0,platform:t1.platform()});let q=await d8("fnet build",{cwd:X});if(q.code!==0)throw Error("Failed to build project.");if(W0("git")){if(q=await d8("git init --initial-branch=main",{cwd:X}),q.code!==0)throw Error("Failed to initialize git.")}if(W0("code")&&$.vscode){if(q=await d8(`cd ${X} && code .`),q.code!==0)throw Error("Failed to open vscode.")}console.log("Creating project succeeded!"),process.exit(0)}catch(Q){console.error("Initialization failed!",Q.message),process.exit(1)}}},L6=$7;import Q7 from"node:os";import Z7 from"@flownet/lib-render-templates-dir";import X7 from"@fnet/shelljs";var q7={command:"project",describe:"Manage fnet project",builder:($)=>{return $.option("update",{type:"boolean",default:!1,alias:"-u",describe:"Update project files"})},handler:async($)=>{try{let Q=z0("./template/fnet/project"),Z=process.cwd(),X=await w($);if($.update){if(await Z7({dir:Q,outDir:Z,context:{name:X.project.projectFileParsed.name,runtime:"node"},copyUnmatchedAlso:!0,platform:Q7.platform()}),(await X7("fnet build",{cwd:Z})).code!==0)throw Error("Failed to build project.");console.log("Updating project succeeded!")}process.exit(0)}catch(Q){console.error("Project failed.",Q.message),process.exit(1)}}},F6=q7;import L from"node:fs";import S from"node:path";import j1 from"yaml";import T1 from"@fnet/shelljs";import V8 from"nunjucks";import S1 from"lodash.clonedeep";import X2 from"isobject";import{randomUUID as w1}from"node:crypto";import p8 from"winston";var{combine:j6,timestamp:T6,printf:J7,colorize:Y7}=p8.format,S6=J7(({level:$,message:Q,timestamp:Z,category:X,depth:q,...J})=>{let V=" ".repeat(q||0),Y=X?`[${X}]`:"",W=`${Z} ${$} ${Y} ${V}${Q}`;if(Object.keys(J).length>0)W+=`
3
- ${V} ${JSON.stringify(J,null,2)}`;return W}),H8=p8.createLogger({level:process.env.FNET_LOG_LEVEL||"info",format:j6(T6({format:"HH:mm:ss.SSS"}),S6),transports:[new p8.transports.Console({format:j6(Y7(),T6({format:"HH:mm:ss.SSS"}),S6)})]}),P6=($)=>{return{debug:(Q,Z={})=>H8.debug(Q,{category:$,...Z}),info:(Q,Z={})=>H8.info(Q,{category:$,...Z}),warn:(Q,Z={})=>H8.warn(Q,{category:$,...Z}),error:(Q,Z={})=>H8.error(Q,{category:$,...Z})}},N=P6("tree"),s=P6("bpmn"),w6=process.env.FNET_LOG_CATEGORIES?.split(",")||[],F=($)=>{if(w6.length===0)return!1;return w6.includes($)};import{Api as K8}from"@flownet/lib-atom-api-js";class N6{init({config:$,accessToken:Q}){return new Promise((Z,X)=>{if(K8.set_api_url($.data.url),Q){K8.set_req_token(Q),Z(Q);return}fetch(`${$.data.issuer}/protocol/openid-connect/token`,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams($.data.grant.params)}).then(async(q)=>{if(!q.ok)throw Error(await q.text());return q.json()}).then((q)=>{K8.set_req_token(q.access_token),Z(q.access_token)}).catch((q)=>{K8.set_req_token(),X(q)})})}}import k0 from"lodash.merge";import _8 from"node:fs";import X0 from"node:path";import D0 from"@flownet/lib-parse-imports-js";import V7 from"lodash.merge";function P({feature:$,features:Q,packageDevDependencies:Z}){let{name:X,packages:q,options:J,extraCheck:V,explicit:Y}=$,W=`${X}_enabled`,H=Q.rollup_output||{},K=Object.keys(H),G=J||{},_=Q[X]?.options;if(_)G=V7(G,_);let O=!Q[X]||Q[X]?.enabled===!1;K.forEach((z)=>{let U=Q.rollup_output[z];if(!U)return;if(Reflect.has(U,X)){if(O||!U[X]||U[X]?.enabled===!1){delete U[X];return}if(U[X]===!0)U[X]={enabled:!0,options:G}}else if(!O&&!Y&&Q[W]!==!1)U[X]={enabled:!0};else return;U[X]=U[X]||{},U[X].options={...G,...U[X].options}});let M=K.some((z)=>Q.rollup_output[z][X]?.enabled===!0);if(V)M=V()&&M;if(Q[W]=M,M)q.forEach((z)=>Z.push({package:z[0],version:z[1]}))}function i8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"workbox",packages:[["rollup-plugin-workbox","^8"]],options:{generate:{swDest:"dist/app/esm/sw.js",globDirectory:"dist/app/esm",globPatterns:["**/*.{html,js,css,png,jpg}"],skipWaiting:!0,clientsClaim:!0}},explicit:!0},features:X,packageDevDependencies:Z})}function n8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:X,packageDevDependencies:Z})}function r8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:X,packageDevDependencies:Z})}function s8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:X,packageDevDependencies:Z})}function a8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]],expilicit:!0},features:X,packageDevDependencies:Z})}function o8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:X,packageDevDependencies:Z})}function t8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:X,packageDevDependencies:Z})}function e8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:X,packageDevDependencies:Z})}function $$($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;if(X.runtime.type==="bun")return;P({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:X,packageDevDependencies:Z})}function Q$($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:X,packageDevDependencies:Z})}function Z$($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:X,packageDevDependencies:Z})}function X$($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;if(X.runtime.type==="bun")return;let q={};if(X.app?.enabled===!0){if(q.targets=q.targets||[],q.targets.push({src:"./src/app/index.html",dest:X.app.dir}),!Reflect.has(X.app,"copy")){if(!Reflect.has(X,"copy"))X.copy=!0}}P({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:q},features:X,packageDevDependencies:Z})}function q$($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features,q=X.css&&X.css.enabled!==!1,J=[];if(q)J.push(["rollup-plugin-postcss","^4"]),J.push(["sass","^1.66"]),(X.css?.options?.plugins||[]).forEach((Y)=>{switch(Y.name){case"postcss-import":J.push(["postcss-import","^15"]);break;case"postcss-url":J.push(["postcss-url","^10"]);break;case"postcss-preset-env":J.push(["postcss-preset-env","^9"]);break;case"autoprefixer":J.push(["autoprefixer","^10"]);break;case"cssnano":J.push(["cssnano","^6"]);break}});P({feature:{name:"css",packages:J},features:X,packageDevDependencies:Z})}function J$({dir:$,name:Q="index"}){let Z=X0.resolve($,`./${Q}.tsx`);if(!_8.existsSync(Z))Z=X0.resolve($,`./${Q}.ts`);if(!_8.existsSync(Z))Z=X0.resolve($,`./${Q}.jsx`);if(!_8.existsSync(Z))Z=X0.resolve($,`./${Q}.js`);if(!_8.existsSync(Z))return{};let X=Z,q=X0.extname(Z);return{file:X,ext:q,ts:q===".ts"||q===".tsx",name:Q}}async function Y$($){let{atom:Q,context:Z,setProgress:X}=$;X("Initializing features..."),Q.doc.features=Q.doc.features||{};let q=Q.doc.features;q.project=q.project||{},q.project.format=q.project.format||q.project_format||"esm",q.project_format=q.project.format,q.dts_enabled=q.dts===!0||typeof q.dts<"u"&&q.dts!==!1;let J=X0.resolve(Z.project.projectDir),V=J$({dir:X0.resolve(J,"./app")});if(V.file){X("Parsing app entry imports...");let z=await D0({file:V.file,recursive:!0}),U=z.all.some((A)=>A.usesJSX===!0&&A.type==="local");q.app_uses_jsx=U,q.app_has_entry=!0,z=await D0({file:V.file}),U=z.all.some((A)=>A.usesJSX===!0&&A.type==="local"),q.app_entry_uses_jsx=U,q.app_entry_is_ts=V.ts,q.app_entry_ext=V.ext}let Y=J$({dir:X0.resolve(J,"./cli")});if(Y.file){X("Parsing cli entry imports...");let z=await D0({file:Y.file,recursive:!0}),U=z.all.some((A)=>A.usesJSX===!0&&A.type==="local");q.cli_uses_jsx=U,q.cli_has_entry=!0,z=await D0({file:Y.file}),U=z.all.some((A)=>A.usesJSX===!0&&A.type==="local"),q.cli_entry_uses_jsx=U,q.cli_entry_is_ts=Y.ts,q.cli_entry_ext=Y.ext}if(Q.type==="workflow.lib"){let z=J$({dir:X0.resolve(J,"./src")});if(z.file){X("Parsing src entry imports...");let U=await D0({file:z.file,recursive:!0}),A=U.all.some((B)=>B.usesJSX===!0&&B.type==="local");q.src_uses_jsx=A,q.src_has_entry=!0,U=await D0({file:z.file}),A=U.all.some((B)=>B.usesJSX===!0&&B.type==="local"),q.src_entry_uses_jsx=A,q.src_entry_is_ts=z.ts,q.src_entry_ext=z.ext}}let W=Reflect.has(q,"app_entry_uses_jsx")?q.app_entry_uses_jsx===!0:q.src_entry_uses_jsx===!0,H=Reflect.has(q,"cli_entry_uses_jsx")?q.cli_entry_uses_jsx===!0:q.src_entry_uses_jsx===!0;if(q.form_enabled=W||H||q.form===!0||q.form?.enabled===!0,q.multiple_enabled=q.multiple_enabled||q.multiple===!0||q.multiple?.enabled===!0,q.app===!1)q.app={enabled:!1};else if(q.app===!0)q.app={enabled:!0,extend:q.app_has_entry===!0,export:!0,react:W};else q.app={enabled:!0,extend:q.app_has_entry===!0,export:!0,react:W,...q.app||{}};if(q.app.enabled=q.app.enabled===!0&&(Q.doc.features.form_enabled===!0||q.app.extend===!0||q.app.enabled===!0),q.app.format=q.app.format||"esm",q.app.folder=q.app.folder||q.app.format||"default",q.cli===!1)q.cli={enabled:!1};else if(q.cli===!0)q.cli={enabled:!0,extend:q.cli_has_entry===!0,export:!0,react:H};else q.cli={enabled:!0,extend:q.cli_has_entry===!0,export:!0,react:H,...q.cli||{}};if(q.cli.enabled=q.cli.enabled===!0&&(Q.doc.features.form_enabled===!1||q.cli.extend===!0||q.cli.enabled===!0),q.cli.format=q.cli.format||"esm",q.cli.folder=q.cli.folder||q.cli.folder||"esm",q.cli.node_options=q.cli.node?.options||q.cli.node_options||"",q.cli.bin=q.cli.bin||Q.doc.name,q.cli.installable=q.cli.installable===!0,q.cli.enabled)Q.doc["npm::bin"]=q.cli.bin;q.json=q.cli.enabled||q.json;let K={cjs:{format:"cjs",context:q.form_enabled?"window":"global",babel:q.src_uses_jsx===!0||!1,browser:!1,replace:!0,terser:!0,enabled:q.cjs!==!1,copy:!1},esm:{format:"esm",context:q.form_enabled?"window":"global",babel:q.src_uses_jsx===!0||!1,browser:!1,replace:!0,terser:!1,enabled:q.esm!==!1,copy:!0},iife:{format:"iife",context:q.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:q.iife===!0,terser:!0,copy:!1}},G={targets:{browsers:"last 9 versions, not dead",node:"18"}},_={};if(q.webos===!0)K.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",copy:!1,babel_options:{targets:{chrome:"79"}}};if(q.electron===!0)K.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/electron"};if(q.nextjs===!0)K.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"};if(q.ios===!0)K.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/ios"};if(q.macos===!0)K.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/macos"};if(q.app.enabled===!0)q.app.dir=`./dist/app/${q.app.folder}`,q.app.output={file:`./dist/app/${q.app.folder}/index.js`,dir:`./dist/app/${q.app.folder}/`,...q.app.output||{}},q.app.input={file:"./src/app/index.js",dir:"./src/app/",...q.app.input||{}},K.app={format:q.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:q.app.input.file,output_dir:q.app.dir,terser:!0,output_exports:q.app.export===!1?"none":"auto",browsersync:!0};if(q.cli.enabled===!0)q.cli.dir=`./dist/cli/${q.cli.folder}`,q.cli.output={file:`./dist/cli/${q.cli.folder}/index.js`,dir:`./dist/cli/${q.cli.folder}/`,...q.cli.output||{}},q.cli.input={file:"./src/cli/index.js",dir:"./src/cli/",...q.cli.input||{}},K.cli={format:q.cli.format,context:"global",babel:q.src_uses_jsx===!0||q.cli_uses_jsx===!0||!1,browser:!1,replace:!0,enabled:!0,input:q.cli.input.file,output_dir:q.cli.dir,banner:"#!/usr/bin/env bun",terser:!0,output_exports:q.cli.export===!1?"none":"auto"};let O={server:".",startPath:`${X0.normalize(q.app.dir||".")}`,files:[X0.normalize("./dist/**/*")],cors:!0,open:!1};if(q.babel_options=k0(G,q.babel_options||q.babel?.options),q.browsersync_options=k0(O,q.browsersync_options||q.browsersync?.options||{}),q.replace_options=k0(_,q.replace_options||q.replace?.options||{}),Reflect.has(q.browsersync_options,"proxy"))delete q.browsersync_options.server;q.rollup=q.rollup||{},q.rollup_output=k0(K,q.rollup_output||q.rollup?.output||{}),q.preact_enabled=q.preact===!0||q.preact&&q.preact?.enabled!==!1;let M=Object.keys(K);for(let z of M){let U=K[z];if(!U)continue;if(q.rollup[z]===!1){delete q.rollup_output[z];continue}if(U.babel_options=U.babel_options||q.babel_options,U.browsersync_options=k0(q.browsersync_options,U.browsersync_options),U.replace_options=k0(q.replace_options,U.replace_options),q.preact_enabled)U.alias_enabled=!0,U.alias=U.alias||{},U.alias.entries=U.alias.entries||{},U.alias.entries.react="preact/compat",U.alias.entries["react-dom"]="preact/compat";if(q.form_enabled||q.babel)U.babel=!0}M=Object.keys(q.rollup_output),q.babel_enabled=M.some((z)=>q.rollup_output[z].babel===!0),q.browser_enabled=M.some((z)=>q.rollup_output[z].babel===!0),q.browsersync_enabled=q.browsersync!==!1&&M.some((z)=>q.rollup_output[z].browsersync===!0),q.browsersync_enabled=q.browsersync_enabled&&q.app.enabled,q.dependency_auto_enabled=q.dependency_auto!==!1&&q.dependency_auto?.enabled!==!1,q.npm_install_flags=q.npm_install_flags||"",q.react_version=q.react_version||q.react?.version||18,q$($),X$($),Z$($),Q$($),$$($),t8($),e8($),o8($),a8($),s8($),r8($),i8($),n8($)}import W7 from"@fnet/npm-list-versions";async function V$({atom:$,packageDependencies:Q,packageDevDependencies:Z,setProgress:X}){X("Initializing dependencies");let q=$.doc.dependencies||[];if(q.filter((J)=>!J.dev).forEach((J)=>Q.push(J)),q.filter((J)=>J.dev).forEach((J)=>Z.push(J)),$.type==="workflow")Q.push({package:"get-value",version:"^3"}),Q.push({package:"set-value",version:"^4"});if($.doc.features.form_enabled){if($.doc.features.dependency_auto_enabled){let J="^18.2";if(X("Fetching React versions"),J=`^${(await W7({name:"react",groupBy:{major:!0}})).find((W)=>W[0]===$.doc.features.react_version.toString())[0]}`,Q.push({package:"react",version:J}),Q.push({package:"react-dom",version:J}),$.type==="workflow")Q.push({package:"@fnet/react-app",version:"^0.1"}),Q.push({package:"@fnet/react-app-state",version:"^0.1"})}}if($.doc.features.preact_enabled)Q.push({package:"preact",version:"^10"});if($.doc.features.cli.enabled===!0){if(Q.push({package:"@fnet/args",version:"^0.1"}),$.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1)Q.push({package:"@fnet/config",version:"0.2.21"});if($.doc.features.cli.mcp&&$.doc.features.cli.mcp.enabled===!0)Q.push({package:"@modelcontextprotocol/sdk",version:"^1.10"}),Q.push({package:"express",version:"^4.18"})}if($.doc.features.render&&$.doc.features.render.enabled!==!1)Z.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"});if(Z.push({package:"@babel/core",version:"^7"}),Z.push({package:"@rollup/plugin-commonjs",version:"^28"}),Z.push({package:"@rollup/plugin-node-resolve",version:"^16"}),Z.push({package:"@rollup/plugin-replace",version:"^6"}),Z.push({package:"rollup",version:"^4"}),$.doc.features.dts_enabled)Z.push({package:"rollup-plugin-dts",version:"^6"});if(Z.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),Z.push({package:"@rollup/plugin-alias",version:"^5"}),Z.push({package:"fs-extra",version:"^11"}),$.doc.features.babel_enabled)Z.push({package:"@rollup/plugin-babel",version:"^6"}),Z.push({package:"@babel/preset-env",version:"^7"}),Z.push({package:"@babel/preset-react",version:"^7"}),$.doc.features.babel?.options?.plugins?.forEach((J)=>{switch(J[0]){case"@babel/plugin-proposal-decorators":Z.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":Z.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":Z.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":Z.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":Z.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"});break}});if(Z.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),$.doc.features.browsersync_enabled)Z.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})}import H7 from"@fnet/npm-list-versions";async function W$({atom:$,packageDependencies:Q,packageDevDependencies:Z,setProgress:X}){X("Initializing dependencies for Bun");let q=$.doc.dependencies||[];if(q.filter((J)=>!J.dev).forEach((J)=>Q.push(J)),q.filter((J)=>J.dev).forEach((J)=>Z.push(J)),$.type==="workflow")Q.push({package:"get-value",version:"^3"}),Q.push({package:"set-value",version:"^4"});if($.doc.features.form_enabled){if($.doc.features.dependency_auto_enabled){let J="^18.2";if(X("Fetching React versions"),J=`^${(await H7({name:"react",groupBy:{major:!0}})).find((W)=>W[0]===$.doc.features.react_version.toString())[0]}`,Q.push({package:"react",version:J}),Q.push({package:"react-dom",version:J}),$.type==="workflow")Q.push({package:"@fnet/react-app",version:"^0.1"}),Q.push({package:"@fnet/react-app-state",version:"^0.1"})}}if($.doc.features.preact_enabled)Q.push({package:"preact",version:"^10"});if($.doc.features.cli.enabled===!0){if(Q.push({package:"@fnet/args",version:"^0.1"}),$.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1)Q.push({package:"@fnet/config",version:"0.2.21"});if($.doc.features.cli.mcp&&$.doc.features.cli.mcp.enabled===!0)Q.push({package:"@modelcontextprotocol/sdk",version:"^1.10"}),Q.push({package:"express",version:"^4.18"})}if($.doc.features.render&&$.doc.features.render.enabled!==!1)Z.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"})}import b6 from"node:fs";import k6 from"node:path";import K7 from"@flownet/lib-render-templates-dir";async function H$({atom:$,setProgress:Q,context:Z,packageDependencies:X}){if($.doc.features.app.enabled!==!0)return;await Q({message:"Creating app folder"});let q={atom:$,packageDependencies:X,ts:Date.now()},J=Z.templateDir,V=k6.resolve(Z.projectDir,"src/app");if(!b6.existsSync(V))b6.mkdirSync(V,{recursive:!0});let Y=["index.js.njk"];if($.doc.features.app.html!==!1)Y.push("index.html.njk");await K7({pattern:Y,dir:k6.resolve(J,"src/app"),outDir:V,context:q})}import v6 from"nunjucks";import U0 from"node:fs";import R0 from"node:path";import z7 from"@flownet/lib-parse-imports-js";import _7 from"@fnet/npm-pick-versions";import G7 from"object-hash";import G8 from"node:fs";import D6 from"node:path";async function v0({projectDir:$,name:Q,setProgress:Z,count:X=1}){let q,V=G7(["npm-pick-versions",Q,X]),Y=D6.join($,".cache"),W=D6.join(Y,V+".json");if(G8.existsSync(W)){if(Z)Z(`Picking npm version of ${Q} from cache ...`);q=JSON.parse(G8.readFileSync(W,"utf8"))}else{if(Z)Z(`Picking npm version of ${Q} ...`);q=await _7({name:Q,count:X}),G8.mkdirSync(Y,{recursive:!0}),G8.writeFileSync(W,JSON.stringify(q),"utf8")}return q}async function K$({atom:$,context:Q,packageDependencies:Z,packageDevDependencies:X,setProgress:q}){await q({message:"Creating package.json."}),Z.filter((U)=>U.dev===!0).forEach((U)=>{if(!X.find((B)=>B.package===U.package))X.push(U);let A=Z.findIndex((B)=>B.package===U.package);Z.splice(A,1)});let V=Z.find((U)=>U.package==="react"),Y=Z.find((U)=>U.package==="react-dom");if(V&&!Y)Z.push({package:"react-dom",version:V.version});else if(V&&Y)Y.version=V.version;if(V&&$.doc.features.react_version>=17){if(!Z.find((U)=>U.package==="@emotion/react"))Z.push({package:"@emotion/react",version:"^11"});if(!Z.find((U)=>U.package==="@emotion/styled"))Z.push({package:"@emotion/styled",version:"^11"})}let W=[];if($.doc.features.app.enabled===!0)W.push({file:R0.resolve(Q.projectDir,"src/app/index.js"),dev:$.doc.features.app.dev!==!1});if($.doc.features.cli.enabled===!0)W.push({file:R0.resolve(Q.projectDir,"src/cli/index.js"),dev:$.doc.features.cli.dev!==!1});for await(let U of W){let A=U.file;if(!U0.existsSync(A))throw Error(`App file not found: ${A}`);let C=(await z7({file:A,recursive:!0,verbose:!1})).all;for await(let T of C){if(T.type!=="npm")continue;if(Z.find((Q0)=>Q0.package===T.package))continue;if(X.find((Q0)=>Q0.package===T.package))continue;let p=await v0({name:T.package,projectDir:Q.projectDir,setProgress:q});(U.dev===!0?X:Z).push({package:T.package,subpath:T.subpath,version:p.minorRange,type:"npm"})}}let H={atom:$,packageDependencies:Z,packageDevDependencies:X},K=Q.templateDir,_=v6.compile(U0.readFileSync(R0.resolve(K,"package.json.njk"),"utf8"),v6.configure(K)).render(H),O=Q.projectDir,M=R0.resolve(O,"package.json");U0.writeFileSync(M,_,"utf8");let z=R0.resolve(Q.project.projectDir,"fnet");if(U0.existsSync(z)){let U=R0.resolve(Q.projectDir,"fnet");if(!U0.existsSync(U))U0.mkdirSync(U);let A=U0.readdirSync(z);for(let B of A){let C=R0.resolve(z,B);if(!U0.lstatSync(C).isFile())continue;let T=R0.resolve(U,B);U0.copyFileSync(C,T)}}}import E6 from"node:fs";import y6 from"node:path";import U7 from"@flownet/lib-render-templates-dir";async function _$({atom:$,setProgress:Q,context:Z,packageDependencies:X}){if($.doc.features.cli.enabled!==!0)return;await Q({message:"Creating cli."});let q={atom:$,packageDependencies:X},J=Z.templateDir,V=y6.resolve(Z.projectDir,"src/cli");if(!E6.existsSync(V))E6.mkdirSync(V,{recursive:!0});await U7({pattern:["index.js.njk"],dir:y6.resolve(J,"src/cli"),outDir:V,context:q})}import G$ from"node:fs";import z$ from"node:path";import x6 from"nunjucks";import M7 from"@flownet/lib-parse-imports-js";async function U$({atom:$,setProgress:Q,context:Z,packageDependencies:X}){await Q({message:"Creating rollup file."});let q={atom:$,packageDependencies:X},J=z$.resolve(Z.projectDir,"src","default/index.js");if(!G$.existsSync(J))throw Error(`Entry file not found: ${J}`);let Y=(await M7({file:J,recursive:!0})).all.filter((z)=>z.type==="node").map((z)=>z.path),W=$.doc.features.rollup_output,H=Object.keys(W);for(let z=0;z<H.length;z++){let U=H[z],A=W[U];if(A.browser===!0){if(Y.length>0){A.globals_enabled=!0,A.globals=A.globals||[],A.globals=A.globals.concat(Y.map((B)=>{return{key:B,value:B}})),A.alias_enabled=!0,A.alias=A.alias||{},A.alias.entries=A.alias.entries||{};for(let B=0;B<Y.length;B++){let C=Y[B];A.alias.entries[C]=`node:${C}`,A.alias.entries[`node:${C}`]=C}A.external_enabled=!0,A.external=A.external||[],A.external=A.external.concat(Y)}}}let K=Z.templateDir,_=x6.compile(G$.readFileSync(z$.resolve(K,"rollup.config.mjs.njk"),"utf8"),x6.configure(K)).render(q),O=Z.projectDir,M=z$.resolve(O,"rollup.config.mjs");G$.writeFileSync(M,_,"utf8")}import M$ from"node:fs";import u6 from"node:path";import f6 from"nunjucks";async function O$({atom:$,setProgress:Q,context:Z,packageDependencies:X}){await Q({message:"Creating build.js file."});let q={atom:$,packageDependencies:X},J=Z.templateDir,Y=f6.compile(M$.readFileSync(u6.resolve(J,"build.js.njk"),"utf8"),f6.configure(J)).render(q),W=Z.projectDir,H=u6.resolve(W,"build.js");M$.writeFileSync(H,Y,"utf8"),M$.chmodSync(H,"755")}import A$ from"node:fs";import B$ from"node:path";import O7 from"nunjucks";import A7 from"ajv/dist/2020.js";import B7 from"ajv/dist/standalone/index.js";import R7 from"ajv-formats";async function R$({atom:$,setProgress:Q,context:Z,njEnv:X}){if($.doc.features.cli.enabled!==!0)return;await Q({message:"Creating input args."});let q={},J=[];if($.doc.input)q=$.doc.input;else q={type:"object",properties:{},required:[]};if($.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1){let A=$.doc.features.cli.fargs,B={type:"string",description:"Config name to load args",hidden:!1},C={type:"array",description:"Tags to filter the config",hidden:!1};if(Reflect.has(A,"default"))B.default=A.default}let Y={imports:J,atom:$},W=Z.templateDir,K=O7.compile(A$.readFileSync(B$.resolve(W,"src/default/input.args.js.njk"),"utf8"),X).render(Y),G=Z.projectDir,_=B$.resolve(G,"src/default/input.args.js");A$.writeFileSync(_,K,"utf8");let O=new A7({allErrors:!0,useDefaults:!0,formats:{},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});R7(O);let M=O.compile(q),U=B7(O,M)+`
3
+ ${V} ${JSON.stringify(J,null,2)}`;return W}),H8=p8.createLogger({level:process.env.FNET_LOG_LEVEL||"info",format:j6(T6({format:"HH:mm:ss.SSS"}),S6),transports:[new p8.transports.Console({format:j6(Y7(),T6({format:"HH:mm:ss.SSS"}),S6)})]}),P6=($)=>{return{debug:(Q,Z={})=>H8.debug(Q,{category:$,...Z}),info:(Q,Z={})=>H8.info(Q,{category:$,...Z}),warn:(Q,Z={})=>H8.warn(Q,{category:$,...Z}),error:(Q,Z={})=>H8.error(Q,{category:$,...Z})}},N=P6("tree"),s=P6("bpmn"),w6=process.env.FNET_LOG_CATEGORIES?.split(",")||[],F=($)=>{if(w6.length===0)return!1;return w6.includes($)};import{Api as K8}from"@flownet/lib-atom-api-js";class N6{init({config:$,accessToken:Q}){return new Promise((Z,X)=>{if(K8.set_api_url($.data.url),Q){K8.set_req_token(Q),Z(Q);return}fetch(`${$.data.issuer}/protocol/openid-connect/token`,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams($.data.grant.params)}).then(async(q)=>{if(!q.ok)throw Error(await q.text());return q.json()}).then((q)=>{K8.set_req_token(q.access_token),Z(q.access_token)}).catch((q)=>{K8.set_req_token(),X(q)})})}}import k0 from"lodash.merge";import _8 from"node:fs";import X0 from"node:path";import D0 from"@flownet/lib-parse-imports-js";import V7 from"lodash.merge";function P({feature:$,features:Q,packageDevDependencies:Z}){let{name:X,packages:q,options:J,extraCheck:V,explicit:Y}=$,W=`${X}_enabled`,H=Q.rollup_output||{},K=Object.keys(H),G=J||{},_=Q[X]?.options;if(_)G=V7(G,_);let O=!Q[X]||Q[X]?.enabled===!1;K.forEach((z)=>{let U=Q.rollup_output[z];if(!U)return;if(Reflect.has(U,X)){if(O||!U[X]||U[X]?.enabled===!1){delete U[X];return}if(U[X]===!0)U[X]={enabled:!0,options:G}}else if(!O&&!Y&&Q[W]!==!1)U[X]={enabled:!0};else return;U[X]=U[X]||{},U[X].options={...G,...U[X].options}});let M=K.some((z)=>Q.rollup_output[z][X]?.enabled===!0);if(V)M=V()&&M;if(Q[W]=M,M)q.forEach((z)=>Z.push({package:z[0],version:z[1]}))}function i8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"workbox",packages:[["rollup-plugin-workbox","^8"]],options:{generate:{swDest:"dist/app/esm/sw.js",globDirectory:"dist/app/esm",globPatterns:["**/*.{html,js,css,png,jpg}"],skipWaiting:!0,clientsClaim:!0}},explicit:!0},features:X,packageDevDependencies:Z})}function n8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:X,packageDevDependencies:Z})}function r8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:X,packageDevDependencies:Z})}function s8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:X,packageDevDependencies:Z})}function a8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]],expilicit:!0},features:X,packageDevDependencies:Z})}function o8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:X,packageDevDependencies:Z})}function t8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:X,packageDevDependencies:Z})}function e8($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:X,packageDevDependencies:Z})}function $$($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;if(X.runtime.type==="bun")return;P({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:X,packageDevDependencies:Z})}function Q$($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:X,packageDevDependencies:Z})}function Z$($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;P({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:X,packageDevDependencies:Z})}function X$($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features;if(X.runtime.type==="bun")return;let q={};if(X.app?.enabled===!0){if(q.targets=q.targets||[],q.targets.push({src:"./src/app/index.html",dest:X.app.dir}),!Reflect.has(X.app,"copy")){if(!Reflect.has(X,"copy"))X.copy=!0}}P({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:q},features:X,packageDevDependencies:Z})}function q$($){let{atom:Q,packageDevDependencies:Z}=$,X=Q.doc.features,q=X.css&&X.css.enabled!==!1,J=[];if(q)J.push(["rollup-plugin-postcss","^4"]),J.push(["sass","^1.66"]),(X.css?.options?.plugins||[]).forEach((Y)=>{switch(Y.name){case"postcss-import":J.push(["postcss-import","^15"]);break;case"postcss-url":J.push(["postcss-url","^10"]);break;case"postcss-preset-env":J.push(["postcss-preset-env","^9"]);break;case"autoprefixer":J.push(["autoprefixer","^10"]);break;case"cssnano":J.push(["cssnano","^6"]);break}});P({feature:{name:"css",packages:J},features:X,packageDevDependencies:Z})}function J$({dir:$,name:Q="index"}){let Z=X0.resolve($,`./${Q}.tsx`);if(!_8.existsSync(Z))Z=X0.resolve($,`./${Q}.ts`);if(!_8.existsSync(Z))Z=X0.resolve($,`./${Q}.jsx`);if(!_8.existsSync(Z))Z=X0.resolve($,`./${Q}.js`);if(!_8.existsSync(Z))return{};let X=Z,q=X0.extname(Z);return{file:X,ext:q,ts:q===".ts"||q===".tsx",name:Q}}async function Y$($){let{atom:Q,context:Z,setProgress:X}=$;X("Initializing features..."),Q.doc.features=Q.doc.features||{};let q=Q.doc.features;q.project=q.project||{},q.project.format=q.project.format||q.project_format||"esm",q.project_format=q.project.format,q.dts_enabled=q.dts===!0||typeof q.dts<"u"&&q.dts!==!1;let J=X0.resolve(Z.project.projectDir),V=J$({dir:X0.resolve(J,"./app")});if(V.file){X("Parsing app entry imports...");let z=await D0({file:V.file,recursive:!0}),U=z.all.some((A)=>A.usesJSX===!0&&A.type==="local");q.app_uses_jsx=U,q.app_has_entry=!0,z=await D0({file:V.file}),U=z.all.some((A)=>A.usesJSX===!0&&A.type==="local"),q.app_entry_uses_jsx=U,q.app_entry_is_ts=V.ts,q.app_entry_ext=V.ext}let Y=J$({dir:X0.resolve(J,"./cli")});if(Y.file){X("Parsing cli entry imports...");let z=await D0({file:Y.file,recursive:!0}),U=z.all.some((A)=>A.usesJSX===!0&&A.type==="local");q.cli_uses_jsx=U,q.cli_has_entry=!0,z=await D0({file:Y.file}),U=z.all.some((A)=>A.usesJSX===!0&&A.type==="local"),q.cli_entry_uses_jsx=U,q.cli_entry_is_ts=Y.ts,q.cli_entry_ext=Y.ext}if(Q.type==="workflow.lib"){let z=J$({dir:X0.resolve(J,"./src")});if(z.file){X("Parsing src entry imports...");let U=await D0({file:z.file,recursive:!0}),A=U.all.some((B)=>B.usesJSX===!0&&B.type==="local");q.src_uses_jsx=A,q.src_has_entry=!0,U=await D0({file:z.file}),A=U.all.some((B)=>B.usesJSX===!0&&B.type==="local"),q.src_entry_uses_jsx=A,q.src_entry_is_ts=z.ts,q.src_entry_ext=z.ext}}let W=Reflect.has(q,"app_entry_uses_jsx")?q.app_entry_uses_jsx===!0:q.src_entry_uses_jsx===!0,H=Reflect.has(q,"cli_entry_uses_jsx")?q.cli_entry_uses_jsx===!0:q.src_entry_uses_jsx===!0;if(q.form_enabled=W||H||q.form===!0||q.form?.enabled===!0,q.multiple_enabled=q.multiple_enabled||q.multiple===!0||q.multiple?.enabled===!0,q.app===!1)q.app={enabled:!1};else if(q.app===!0)q.app={enabled:!0,extend:q.app_has_entry===!0,export:!0,react:W};else q.app={enabled:!0,extend:q.app_has_entry===!0,export:!0,react:W,...q.app||{}};if(q.app.enabled=q.app.enabled===!0&&(Q.doc.features.form_enabled===!0||q.app.extend===!0||q.app.enabled===!0),q.app.format=q.app.format||"esm",q.app.folder=q.app.folder||q.app.format||"default",q.cli===!1)q.cli={enabled:!1};else if(q.cli===!0)q.cli={enabled:!0,extend:q.cli_has_entry===!0,export:!0,react:H};else q.cli={enabled:!0,extend:q.cli_has_entry===!0,export:!0,react:H,...q.cli||{}};if(q.cli.enabled=q.cli.enabled===!0&&(Q.doc.features.form_enabled===!1||q.cli.extend===!0||q.cli.enabled===!0),q.cli.format=q.cli.format||"esm",q.cli.folder=q.cli.folder||q.cli.folder||"esm",q.cli.node_options=q.cli.node?.options||q.cli.node_options||"",q.cli.bin=q.cli.bin||Q.doc.name,q.cli.installable=q.cli.installable===!0,q.cli.enabled)Q.doc["npm::bin"]=q.cli.bin;q.json=q.cli.enabled||q.json;let K={cjs:{format:"cjs",context:q.form_enabled?"window":"global",babel:q.src_uses_jsx===!0||!1,browser:!1,replace:!0,terser:!0,enabled:q.cjs!==!1,copy:!1},esm:{format:"esm",context:q.form_enabled?"window":"global",babel:q.src_uses_jsx===!0||!1,browser:!1,replace:!0,terser:!1,enabled:q.esm!==!1,copy:!0},iife:{format:"iife",context:q.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:q.iife===!0,terser:!0,copy:!1}},G={targets:{browsers:"last 9 versions, not dead",node:"18"}},_={};if(q.webos===!0)K.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",copy:!1,babel_options:{targets:{chrome:"79"}}};if(q.electron===!0)K.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/electron"};if(q.nextjs===!0)K.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"};if(q.ios===!0)K.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/ios"};if(q.macos===!0)K.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/macos"};if(q.app.enabled===!0)q.app.dir=`./dist/app/${q.app.folder}`,q.app.output={file:`./dist/app/${q.app.folder}/index.js`,dir:`./dist/app/${q.app.folder}/`,...q.app.output||{}},q.app.input={file:"./src/app/index.js",dir:"./src/app/",...q.app.input||{}},K.app={format:q.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:q.app.input.file,output_dir:q.app.dir,terser:!0,output_exports:q.app.export===!1?"none":"auto",browsersync:!0};if(q.cli.enabled===!0)q.cli.dir=`./dist/cli/${q.cli.folder}`,q.cli.output={file:`./dist/cli/${q.cli.folder}/index.js`,dir:`./dist/cli/${q.cli.folder}/`,...q.cli.output||{}},q.cli.input={file:"./src/cli/index.js",dir:"./src/cli/",...q.cli.input||{}},K.cli={format:q.cli.format,context:"global",babel:q.src_uses_jsx===!0||q.cli_uses_jsx===!0||!1,browser:!1,replace:!0,enabled:!0,input:q.cli.input.file,output_dir:q.cli.dir,banner:"#!/usr/bin/env bun",terser:!0,output_exports:q.cli.export===!1?"none":"auto"};let O={server:".",startPath:`${X0.normalize(q.app.dir||".")}`,files:[X0.normalize("./dist/**/*")],cors:!0,open:!1};if(q.babel_options=k0(G,q.babel_options||q.babel?.options),q.browsersync_options=k0(O,q.browsersync_options||q.browsersync?.options||{}),q.replace_options=k0(_,q.replace_options||q.replace?.options||{}),Reflect.has(q.browsersync_options,"proxy"))delete q.browsersync_options.server;q.rollup=q.rollup||{},q.rollup_output=k0(K,q.rollup_output||q.rollup?.output||{}),q.preact_enabled=q.preact===!0||q.preact&&q.preact?.enabled!==!1;let M=Object.keys(K);for(let z of M){let U=K[z];if(!U)continue;if(q.rollup[z]===!1){delete q.rollup_output[z];continue}if(U.babel_options=U.babel_options||q.babel_options,U.browsersync_options=k0(q.browsersync_options,U.browsersync_options),U.replace_options=k0(q.replace_options,U.replace_options),q.preact_enabled)U.alias_enabled=!0,U.alias=U.alias||{},U.alias.entries=U.alias.entries||{},U.alias.entries.react="preact/compat",U.alias.entries["react-dom"]="preact/compat";if(q.form_enabled||q.babel)U.babel=!0}M=Object.keys(q.rollup_output),q.babel_enabled=M.some((z)=>q.rollup_output[z].babel===!0),q.browser_enabled=M.some((z)=>q.rollup_output[z].babel===!0),q.browsersync_enabled=q.browsersync!==!1&&M.some((z)=>q.rollup_output[z].browsersync===!0),q.browsersync_enabled=q.browsersync_enabled&&q.app.enabled,q.dependency_auto_enabled=q.dependency_auto!==!1&&q.dependency_auto?.enabled!==!1,q.npm_install_flags=q.npm_install_flags||"",q.react_version=q.react_version||q.react?.version||18,q.bpmn=q.bpmn||{},q.bpmn.enabled=q.bpmn.enabled!==!1,q.bpmn.per_flow=q.bpmn.per_flow===!0,q$($),X$($),Z$($),Q$($),$$($),t8($),e8($),o8($),a8($),s8($),r8($),i8($),n8($)}import W7 from"@fnet/npm-list-versions";async function V$({atom:$,packageDependencies:Q,packageDevDependencies:Z,setProgress:X}){X("Initializing dependencies");let q=$.doc.dependencies||[];if(q.filter((J)=>!J.dev).forEach((J)=>Q.push(J)),q.filter((J)=>J.dev).forEach((J)=>Z.push(J)),$.type==="workflow")Q.push({package:"get-value",version:"^3"}),Q.push({package:"set-value",version:"^4"});if($.doc.features.form_enabled){if($.doc.features.dependency_auto_enabled){let J="^18.2";if(X("Fetching React versions"),J=`^${(await W7({name:"react",groupBy:{major:!0}})).find((W)=>W[0]===$.doc.features.react_version.toString())[0]}`,Q.push({package:"react",version:J}),Q.push({package:"react-dom",version:J}),$.type==="workflow")Q.push({package:"@fnet/react-app",version:"^0.1"}),Q.push({package:"@fnet/react-app-state",version:"^0.1"})}}if($.doc.features.preact_enabled)Q.push({package:"preact",version:"^10"});if($.doc.features.cli.enabled===!0){if(Q.push({package:"@fnet/args",version:"^0.1"}),$.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1)Q.push({package:"@fnet/config",version:"0.2.21"});if($.doc.features.cli.mcp&&$.doc.features.cli.mcp.enabled===!0)Q.push({package:"@modelcontextprotocol/sdk",version:"^1.10"}),Q.push({package:"express",version:"^4.18"})}if($.doc.features.render&&$.doc.features.render.enabled!==!1)Z.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"});if(Z.push({package:"@babel/core",version:"^7"}),Z.push({package:"@rollup/plugin-commonjs",version:"^28"}),Z.push({package:"@rollup/plugin-node-resolve",version:"^16"}),Z.push({package:"@rollup/plugin-replace",version:"^6"}),Z.push({package:"rollup",version:"^4"}),$.doc.features.dts_enabled)Z.push({package:"rollup-plugin-dts",version:"^6"});if(Z.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),Z.push({package:"@rollup/plugin-alias",version:"^5"}),Z.push({package:"fs-extra",version:"^11"}),$.doc.features.babel_enabled)Z.push({package:"@rollup/plugin-babel",version:"^6"}),Z.push({package:"@babel/preset-env",version:"^7"}),Z.push({package:"@babel/preset-react",version:"^7"}),$.doc.features.babel?.options?.plugins?.forEach((J)=>{switch(J[0]){case"@babel/plugin-proposal-decorators":Z.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":Z.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":Z.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":Z.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":Z.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"});break}});if(Z.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),$.doc.features.browsersync_enabled)Z.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})}import H7 from"@fnet/npm-list-versions";async function W$({atom:$,packageDependencies:Q,packageDevDependencies:Z,setProgress:X}){X("Initializing dependencies for Bun");let q=$.doc.dependencies||[];if(q.filter((J)=>!J.dev).forEach((J)=>Q.push(J)),q.filter((J)=>J.dev).forEach((J)=>Z.push(J)),$.type==="workflow")Q.push({package:"get-value",version:"^3"}),Q.push({package:"set-value",version:"^4"});if($.doc.features.form_enabled){if($.doc.features.dependency_auto_enabled){let J="^18.2";if(X("Fetching React versions"),J=`^${(await H7({name:"react",groupBy:{major:!0}})).find((W)=>W[0]===$.doc.features.react_version.toString())[0]}`,Q.push({package:"react",version:J}),Q.push({package:"react-dom",version:J}),$.type==="workflow")Q.push({package:"@fnet/react-app",version:"^0.1"}),Q.push({package:"@fnet/react-app-state",version:"^0.1"})}}if($.doc.features.preact_enabled)Q.push({package:"preact",version:"^10"});if($.doc.features.cli.enabled===!0){if(Q.push({package:"@fnet/args",version:"^0.1"}),$.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1)Q.push({package:"@fnet/config",version:"0.2.21"});if($.doc.features.cli.mcp&&$.doc.features.cli.mcp.enabled===!0)Q.push({package:"@modelcontextprotocol/sdk",version:"^1.10"}),Q.push({package:"express",version:"^4.18"})}if($.doc.features.render&&$.doc.features.render.enabled!==!1)Z.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"})}import b6 from"node:fs";import k6 from"node:path";import K7 from"@flownet/lib-render-templates-dir";async function H$({atom:$,setProgress:Q,context:Z,packageDependencies:X}){if($.doc.features.app.enabled!==!0)return;await Q({message:"Creating app folder"});let q={atom:$,packageDependencies:X,ts:Date.now()},J=Z.templateDir,V=k6.resolve(Z.projectDir,"src/app");if(!b6.existsSync(V))b6.mkdirSync(V,{recursive:!0});let Y=["index.js.njk"];if($.doc.features.app.html!==!1)Y.push("index.html.njk");await K7({pattern:Y,dir:k6.resolve(J,"src/app"),outDir:V,context:q})}import v6 from"nunjucks";import U0 from"node:fs";import R0 from"node:path";import z7 from"@flownet/lib-parse-imports-js";import _7 from"@fnet/npm-pick-versions";import G7 from"object-hash";import G8 from"node:fs";import D6 from"node:path";async function v0({projectDir:$,name:Q,setProgress:Z,count:X=1}){let q,V=G7(["npm-pick-versions",Q,X]),Y=D6.join($,".cache"),W=D6.join(Y,V+".json");if(G8.existsSync(W)){if(Z)Z(`Picking npm version of ${Q} from cache ...`);q=JSON.parse(G8.readFileSync(W,"utf8"))}else{if(Z)Z(`Picking npm version of ${Q} ...`);q=await _7({name:Q,count:X}),G8.mkdirSync(Y,{recursive:!0}),G8.writeFileSync(W,JSON.stringify(q),"utf8")}return q}async function K$({atom:$,context:Q,packageDependencies:Z,packageDevDependencies:X,setProgress:q}){await q({message:"Creating package.json."}),Z.filter((U)=>U.dev===!0).forEach((U)=>{if(!X.find((B)=>B.package===U.package))X.push(U);let A=Z.findIndex((B)=>B.package===U.package);Z.splice(A,1)});let V=Z.find((U)=>U.package==="react"),Y=Z.find((U)=>U.package==="react-dom");if(V&&!Y)Z.push({package:"react-dom",version:V.version});else if(V&&Y)Y.version=V.version;if(V&&$.doc.features.react_version>=17){if(!Z.find((U)=>U.package==="@emotion/react"))Z.push({package:"@emotion/react",version:"^11"});if(!Z.find((U)=>U.package==="@emotion/styled"))Z.push({package:"@emotion/styled",version:"^11"})}let W=[];if($.doc.features.app.enabled===!0)W.push({file:R0.resolve(Q.projectDir,"src/app/index.js"),dev:$.doc.features.app.dev!==!1});if($.doc.features.cli.enabled===!0)W.push({file:R0.resolve(Q.projectDir,"src/cli/index.js"),dev:$.doc.features.cli.dev!==!1});for await(let U of W){let A=U.file;if(!U0.existsSync(A))throw Error(`App file not found: ${A}`);let C=(await z7({file:A,recursive:!0,verbose:!1})).all;for await(let T of C){if(T.type!=="npm")continue;if(Z.find((Q0)=>Q0.package===T.package))continue;if(X.find((Q0)=>Q0.package===T.package))continue;let p=await v0({name:T.package,projectDir:Q.projectDir,setProgress:q});(U.dev===!0?X:Z).push({package:T.package,subpath:T.subpath,version:p.minorRange,type:"npm"})}}let H={atom:$,packageDependencies:Z,packageDevDependencies:X},K=Q.templateDir,_=v6.compile(U0.readFileSync(R0.resolve(K,"package.json.njk"),"utf8"),v6.configure(K)).render(H),O=Q.projectDir,M=R0.resolve(O,"package.json");U0.writeFileSync(M,_,"utf8");let z=R0.resolve(Q.project.projectDir,"fnet");if(U0.existsSync(z)){let U=R0.resolve(Q.projectDir,"fnet");if(!U0.existsSync(U))U0.mkdirSync(U);let A=U0.readdirSync(z);for(let B of A){let C=R0.resolve(z,B);if(!U0.lstatSync(C).isFile())continue;let T=R0.resolve(U,B);U0.copyFileSync(C,T)}}}import E6 from"node:fs";import y6 from"node:path";import U7 from"@flownet/lib-render-templates-dir";async function _$({atom:$,setProgress:Q,context:Z,packageDependencies:X}){if($.doc.features.cli.enabled!==!0)return;await Q({message:"Creating cli."});let q={atom:$,packageDependencies:X},J=Z.templateDir,V=y6.resolve(Z.projectDir,"src/cli");if(!E6.existsSync(V))E6.mkdirSync(V,{recursive:!0});await U7({pattern:["index.js.njk"],dir:y6.resolve(J,"src/cli"),outDir:V,context:q})}import G$ from"node:fs";import z$ from"node:path";import x6 from"nunjucks";import M7 from"@flownet/lib-parse-imports-js";async function U$({atom:$,setProgress:Q,context:Z,packageDependencies:X}){await Q({message:"Creating rollup file."});let q={atom:$,packageDependencies:X},J=z$.resolve(Z.projectDir,"src","default/index.js");if(!G$.existsSync(J))throw Error(`Entry file not found: ${J}`);let Y=(await M7({file:J,recursive:!0})).all.filter((z)=>z.type==="node").map((z)=>z.path),W=$.doc.features.rollup_output,H=Object.keys(W);for(let z=0;z<H.length;z++){let U=H[z],A=W[U];if(A.browser===!0){if(Y.length>0){A.globals_enabled=!0,A.globals=A.globals||[],A.globals=A.globals.concat(Y.map((B)=>{return{key:B,value:B}})),A.alias_enabled=!0,A.alias=A.alias||{},A.alias.entries=A.alias.entries||{};for(let B=0;B<Y.length;B++){let C=Y[B];A.alias.entries[C]=`node:${C}`,A.alias.entries[`node:${C}`]=C}A.external_enabled=!0,A.external=A.external||[],A.external=A.external.concat(Y)}}}let K=Z.templateDir,_=x6.compile(G$.readFileSync(z$.resolve(K,"rollup.config.mjs.njk"),"utf8"),x6.configure(K)).render(q),O=Z.projectDir,M=z$.resolve(O,"rollup.config.mjs");G$.writeFileSync(M,_,"utf8")}import M$ from"node:fs";import u6 from"node:path";import f6 from"nunjucks";async function O$({atom:$,setProgress:Q,context:Z,packageDependencies:X}){await Q({message:"Creating build.js file."});let q={atom:$,packageDependencies:X},J=Z.templateDir,Y=f6.compile(M$.readFileSync(u6.resolve(J,"build.js.njk"),"utf8"),f6.configure(J)).render(q),W=Z.projectDir,H=u6.resolve(W,"build.js");M$.writeFileSync(H,Y,"utf8"),M$.chmodSync(H,"755")}import A$ from"node:fs";import B$ from"node:path";import O7 from"nunjucks";import A7 from"ajv/dist/2020.js";import B7 from"ajv/dist/standalone/index.js";import R7 from"ajv-formats";async function R$({atom:$,setProgress:Q,context:Z,njEnv:X}){if($.doc.features.cli.enabled!==!0)return;await Q({message:"Creating input args."});let q={},J=[];if($.doc.input)q=$.doc.input;else q={type:"object",properties:{},required:[]};if($.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1){let A=$.doc.features.cli.fargs,B={type:"string",description:"Config name to load args",hidden:!1},C={type:"array",description:"Tags to filter the config",hidden:!1};if(Reflect.has(A,"default"))B.default=A.default}let Y={imports:J,atom:$},W=Z.templateDir,K=O7.compile(A$.readFileSync(B$.resolve(W,"src/default/input.args.js.njk"),"utf8"),X).render(Y),G=Z.projectDir,_=B$.resolve(G,"src/default/input.args.js");A$.writeFileSync(_,K,"utf8");let O=new A7({allErrors:!0,useDefaults:!0,formats:{},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});R7(O);let M=O.compile(q),U=B7(O,M)+`
4
4
  export { schema31 as schema };`;A$.writeFileSync(B$.resolve(G,"src/default/validate_input.js"),U,"utf8")}import h6 from"node:fs";import g6 from"node:path";import m6 from"nunjucks";async function C$({atom:$,setProgress:Q,context:Z,packageDependencies:X}){await Q({message:"Creating .gitignore"});let q={atom:$,packageDependencies:X},J=Z.templateDir,Y=m6.compile(h6.readFileSync(g6.resolve(J,".gitignore.njk"),"utf8"),m6.configure(J)).render(q),W=Z.projectDir,H=g6.resolve(W,".gitignore");h6.writeFileSync(H,Y,"utf8")}import c6 from"node:fs";import l6 from"node:path";import d6 from"nunjucks";async function I$({atom:$,setProgress:Q,context:Z,packageDependencies:X}){await Q({message:"Creating tsconfig.json."});let q={atom:$,packageDependencies:X},J=Z.templateDir,Y=d6.compile(c6.readFileSync(l6.resolve(J,"tsconfig.json.njk"),"utf8"),d6.configure(J)).render(q),W=Z.projectDir,H=l6.resolve(W,"tsconfig.json");c6.writeFileSync(H,Y,"utf8")}import z8 from"nunjucks";import C0 from"node:fs";import S0 from"node:path";import p6 from"@fnet/yaml";async function L$({atom:$,context:Q,setProgress:Z,Atom:X}){if(await Z({message:"Creating readme.md"}),Q.project?.readme){let V=Q.projectDir,Y={content:Q.project.readme.doc.content},W=S0.resolve(Q.project.projectDir,"fnet/how-to.md");if(C0.existsSync(W)){let z=C0.readFileSync(W,"utf8");Y.howto=z}let H=S0.resolve(Q.project.projectDir,"fnet/input.yaml");if(C0.existsSync(H)){let z=await p6({file:H,tags:Q.tags});Y.input=z.content}let K=S0.resolve(Q.project.projectDir,"fnet/output.yaml");if(C0.existsSync(K)){let z=await p6({file:K,tags:Q.tags});Y.output=z.content}let G=Q.templateDir,O=z8.compile(C0.readFileSync(S0.resolve(G,"readme.md.njk"),"utf8"),z8.configure(G)).render(Y),M=S0.resolve(V,"readme.md");C0.writeFileSync(M,O,"utf8")}else if($.id){let V=await X.first({type:"wiki",parent_id:$.id});if(!V||V.doc?.["content-type"]!=="markdown")return;let{content:Y,...W}=V.doc,H={content:Y},K=Q.templateDir,_=z8.compile(C0.readFileSync(S0.resolve(K,"readme.md.njk"),"utf8"),z8.configure(K)).render(H),O=Q.projectDir,M=S0.resolve(O,"readme.md");C0.writeFileSync(M,_,"utf8")}}import C7 from"node:path";import i6 from"@fnet/shelljs";async function F$({setProgress:$,context:Q}){let Z=Q.projectDir;await $({message:"Prettifiying source files."});let X=C7.join("src","**","*");if(W0("bun")){let q=await i6(`prettier --write ${X} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:Z});if(q.code!==0)throw Error(q.stderr)}else{let q=await i6(`prettier --write ${X} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:Z});if(q.code!==0)throw Error(q.stderr)}}import I7 from"@fnet/shelljs";async function j$({atom:$,setProgress:Q,context:Z}){if(!$.doc.features.dts_enabled)return;let X=Z.projectDir;if(await Q({message:"Creating .d.ts"}),(await I7("tsc",{cwd:X})).code!==0)throw Error("Couldnt create .d.ts files.")}import n6 from"@fnet/shelljs";async function T$({setProgress:$,atom:Q,context:Z}){let X=Z.projectDir;if(await $({message:"Installing npm packages."}),W0("bun")){if((await n6(`bun install ${Q.doc.features.npm_install_flags}`,{cwd:X})).code!==0)throw Error("Couldnt install npm packages.")}else if((await n6(`npm install ${Q.doc.features.npm_install_flags}`,{cwd:X})).code!==0)throw Error("Couldnt install npm packages.")}import r6 from"node:fs";import L7 from"node:path";import{spawn as F7}from"node:child_process";async function s6($){let{projectDir:Q,scriptName:Z,args:X=[],env:q=process.env,shell:J=!0,detached:V=!0,onSpawn:Y}=$;if(!Q||!Z)throw Error("projectDir and scriptName are required");let W=L7.resolve(Q,"package.json");if(!r6.existsSync(W))throw Error(`package.json not found at ${W}`);let H=JSON.parse(r6.readFileSync(W,"utf8")),K=H.scripts?.[Z];if(!K){let O=Object.keys(H.scripts||{}).join(", ");throw Error(`Script '${Z}' not found. Available: ${O}`)}let G=X.length>0?`${K} ${X.join(" ")}`:K,_=F7(G,[],{cwd:Q,shell:J,detached:V,env:{...q}});if(Y)Y(_);return new Promise((O,M)=>{_.on("error",(z)=>{M(Error(`Failed to start '${Z}': ${z.message}`))}),_.on("close",(z)=>{O({subprocess:_,exitCode:z})})})}import j7 from"node:path";async function S$({setProgress:$,context:Q}){let Z=Q.projectDir;await $({message:"Building main project."});let X=Q.dev?"build:dev":"build",q={...process.env},J=j7.join(Z,"node_modules");q.NODE_PATH=J;let V=q.NODE_OPTIONS||"";q.NODE_OPTIONS=`${V} --preserve-symlinks`.trim(),await s6({projectDir:Z,scriptName:X,shell:!0,detached:!0,env:q})}var a6=async($)=>{let{atom:Q,packageDependencies:Z,context:X,deploymentProjectTarget:q,setProgress:J,deploymentProject:V,yamlTarget:Y}=$;if(q.enabled!==!0)return;let W=q.type;try{if(W==="lib")await(await import("./index.p0zb7e1b.js")).default({...$});else if(W==="red")await(await import("./index.490y87nc.js")).default({...$});else if(W==="npm")await(await import("./index.gh75wt1m.js")).default({...$});else if(W==="gcs")await(await import("./index.hzsfswvp.js")).default({...$});else if(W==="gitlab")await(await import("./index.jgpc3grc.js")).default({...$});else if(W==="fnet-package")await(await import("./index.r82rtnmz.js")).default({...$});else if(W==="fnet-form")await(await import("./index.3exge2js.js")).default({...$});else if(W==="fnet-node")await(await import("./index.4jkat7r4.js")).default({...$});else if(W==="fnet-flow")await(await import("./index.s662t98v.js")).default({...$});else if(W==="nextjs")await(await import("./index.7vw06nrn.js")).default({atom:Q,target:q,onProgress:J,projectDir:X.projectDir,dependencies:Z,context:X,yamlTarget:Y}),V.isDirty=!0;else if(W==="webos")await(await import("./index.zm4kesg6.js")).default({atom:Q,target:q,onProgress:J,projectDir:X.projectDir,dependencies:Z,context:X,yamlTarget:Y}),V.isDirty=!0;else if(W==="electron")await(await import("./index.9567fa9x.js")).default({atom:Q,target:q,onProgress:J,projectDir:X.projectDir,dependencies:Z,context:X,yamlTarget:Y}),V.isDirty=!0;else if(W==="docker")await(await import("./index.w74dpnpn.js")).default({atom:Q,target:q,onProgress:J,projectDir:X.projectDir,dependencies:Z,context:X,yamlTarget:Y}),V.isDirty=!0;else if(W==="ios")await(await import("./index.7crx8ky1.js")).default({atom:Q,target:q,onProgress:J,projectDir:X.projectDir,dependencies:Z,context:X,yamlTarget:Y}),V.isDirty=!0;else if(W==="macos")await(await import("./index.xeaw5xa9.js")).default({atom:Q,target:q,onProgress:J,projectDir:X.projectDir,dependencies:Z,context:X,yamlTarget:Y}),V.isDirty=!0;else if(W==="rust")await(await import("./index.3kfx538h.js")).default({atom:Q,target:q,onProgress:J,projectDir:X.projectDir,dependencies:Z,context:X,yamlTarget:Y}),V.isDirty=!0;else if(W==="pypi")await(await import("./index.33f1ggpr.js")).default({atom:Q,target:q,onProgress:J,projectDir:X.projectDir,dependencies:Z,context:X,yamlTarget:Y}),V.isDirty=!0;else{console.warn(`No deployer found for type: ${W}`);return}}catch(H){throw console.error(`Error during deployment for type "${W}":`,H),H}};import{Atom as G0}from"@flownet/lib-atom-api-js";import q2 from"@flownet/lib-parse-node-url";import t6 from"bpmn-moddle";import o6 from"dagre";import N$ from"lodash.clonedeep";var w$={name:"ATOM",uri:"http://atom.org/bpmn",prefix:"atom",types:[{name:"AtomExtension",extends:["bpmn:BaseElement"],properties:[{name:"atom",type:"atom:Atom",isMany:!1}]},{name:"Atom",properties:[{name:"type",type:"String",isAttr:!0}]}]};function e6($){let{nodes:Q,nodeIndex:Z,root:X}=$,q=[],J=new Set,V=(Y)=>{if(J.has(Y.indexKey))return;if(J.add(Y.indexKey),Y.hasReturn&&Y.type!=="return"){let W=`${Y.indexKey}/_inline_end`;if(Z[W])return;let H={name:"",type:"return",virtual:!0,parent:Y.parent,childs:[],definition:{return:Y.definition.return},index:Y.parent.childs.length,indexKey:W,pathKey:`${Y.pathKey}._inline_end`,codeKey:`${Y.codeKey}_inline_end`,context:{next:null},hasReturn:!0,_inlineParent:Y};if(q.push(H),F("bpmn"))s.info(` \uD83C\uDFC1 INLINE RETURN → EndEvent: ${H.indexKey}`,{parentNode:Y.indexKey,nodeType:Y.type,hasReturn:!0})}Y.childs.forEach((W)=>V(W))};Q.forEach((Y)=>V(Y)),q.forEach((Y)=>{Y.parent.childs.push(Y),Z[Y.indexKey]=Y,Q.push(Y)}),Q.forEach((Y)=>{let W=[],H=[],K=(M)=>{let z=q.find((U)=>U._inlineParent===M);if(z)W.push({from:M,to:z,type:"bpmn:SequenceFlow"});else if(M.context.next){if(W.push({from:M,to:M.context.next,type:"bpmn:SequenceFlow"}),M===Y)H.push({to:M.context.next,type:"bpmn:SequenceFlow",next:!0})}M.childs.forEach((U)=>{if(M===Y){if(Y.type==="switch"){if(!(U.indexKey&&U.indexKey.endsWith("/_inline_end")))H.push({to:U,type:"bpmn:SequenceFlow"})}}K(U)})};K(Y);let G=W.filter((M)=>M.to.parent.indexKey===Y.parent.indexKey).map((M)=>{return{...M,from:Y.indexKey,to:M.to.indexKey}}),_=W.filter((M)=>M.to.parent.indexKey!==Y.parent.indexKey&&!M.to.indexKey.startsWith(Y.indexKey+"/")).map((M)=>{return{...M,from:Y.indexKey,to:M.to.indexKey}}),O=H.map((M)=>{return{...M,to:M.to.indexKey}});if(Y.bpmn=Y.bpmn||{},Y.bpmn.edges=P$(G,"to"),Y.bpmn.outside=P$(_,"to"),Y.bpmn.starts=P$(O,"to"),Y.bpmn.type=S7(Y),Y.bpmn.width=120,Y.bpmn.height=80,Y.type==="return")Y.bpmn.width=36,Y.bpmn.height=36;if(Y.bpmn.type==="bpmn:CallActivity")Y.bpmn.fill="#E1F5FE",Y.bpmn.stroke="#0277BD"})}function S7($){let Q;if($.type==="call"){if($.context?.lib?.type==="subworkflow"||$.context?.lib?.type==="workflow"){if(Q="bpmn:CallActivity",F("bpmn"))s.info(` \uD83D\uDCE6 CALL → CallActivity (subworkflow): ${$.indexKey}`,{nodeType:$.type,bpmnType:Q,calledElement:$.context?.lib?.name||"unknown",isChip:!0})}else if(Q="bpmn:ServiceTask",F("bpmn"))s.info(` \uD83D\uDCDE CALL → ServiceTask (external): ${$.indexKey}`,{nodeType:$.type,bpmnType:Q,target:$.context?.lib?.name||"unknown",isChip:!1})}else if($.type==="form"){if(Q="bpmn:UserTask",F("bpmn"))s.info(` \uD83D\uDCDD FORM → UserTask: ${$.indexKey}`,{nodeType:$.type,bpmnType:Q})}else if($.type==="return"){if(Q="bpmn:EndEvent",F("bpmn"))s.info(` \uD83C\uDFC1 RETURN → EndEvent: ${$.indexKey}`,{nodeType:$.type,bpmnType:Q})}else if(Q="bpmn:Task",F("bpmn"))s.info(` \uD83D\uDCCB ${$.type.toUpperCase()} → Task: ${$.indexKey}`,{nodeType:$.type,bpmnType:Q});return Q}function P$($,Q){return $.filter((Z,X,q)=>{return q.map((J)=>J[Q]).indexOf(Z[Q])===X})}function b$($){let{nodes:Q,nodeIndex:Z,root:X}=$,q=$.targetNodes||X.childs;q.forEach((J)=>{let V=J.type==="workflow"||J.type==="subworkflow",Y=!V&&J.childs.filter((W)=>!W.virtual).length>0;if(Y)J.bpmn.type="bpmn:SubProcess";if(V||Y){let W=J.childs.filter((z)=>z.module!==!0&&!z.indexKey.endsWith("/_inline_end"))[0];J.childs.filter((z)=>z.module===!0).forEach((z)=>{let U=M0({...$,parent:J,bpmnType:"bpmn:IntermediateCatchEvent",type:"inter",definitions:[{type:"bpmn:SignalEventDefinition"}]});U.bpmn.edges=[{from:U.indexKey,to:z.indexKey,type:"bpmn:SequenceFlow"}]});let K=J.childs.find((z)=>z.name==="try"&&J.type==="tryexcept"),G=J.childs.filter((z)=>z.name==="except"&&J.type==="tryexcept");if(K&&G.length)G.forEach((z)=>{let U=M0({location:J.childs.indexOf(z),...$,parent:J,bpmnType:"bpmn:BoundaryEvent",type:"boundary",attrs:{attachedToRef:K},definitions:[{type:"bpmn:ErrorEventDefinition"}]});U.bpmn.edges=[{from:U.indexKey,to:z.indexKey,type:"bpmn:SequenceFlow"}]});let _=J.childs.find((z)=>z.type==="raise");if(_){let z=M0({...$,parent:J,bpmnType:"bpmn:EndEvent",type:"end",name:"ERROR",definitions:[{type:"bpmn:ErrorEventDefinition"}]});_.bpmn.edges=[{from:_.indexKey,to:z.indexKey,type:"bpmn:SequenceFlow"}]}if(W)if(J.bpmn.starts.length>1){let z=M0({...$,parent:J,bpmnType:"bpmn:StartEvent",type:"start"}),U=M0({...$,parent:J,bpmnType:"bpmn:ExclusiveGateway",type:"switch"});z.bpmn.edges=[{from:z.indexKey,to:U.indexKey,type:"bpmn:SequenceFlow"}],U.bpmn.edges=J.bpmn.starts.map((B)=>{return{...B,from:U.indexKey}});let A=U.bpmn.edges.find((B)=>B.next===!0);if(A){let B=M0({...$,parent:J,bpmnType:"bpmn:EndEvent",type:"end",name:A.to});A.to=B.indexKey}}else{let z=M0({...$,parent:J,bpmnType:"bpmn:StartEvent",type:"start"});z.bpmn.edges.push({from:z.indexKey,to:W.indexKey,type:"bpmn:SequenceFlow"})}else if(F("bpmn"))s.info(" \uD83D\uDEAB START EVENT skipped (no valid firstNode)",{subprocess:J.indexKey,reason:"Only modules or inline end events in subprocess"});J.childs.filter((z)=>z.virtual!==!0&&z.bpmn.outside.length&&z.bpmn.type!=="bpmn:EndEvent").forEach((z)=>{z.bpmn.outside.forEach((U)=>{let A=q.indexOf(J),B=M0({...$,parent:J,bpmnType:"bpmn:EndEvent",type:"end",name:U.to,location:A+1});z.bpmn.edges.push({from:z.indexKey,to:B.indexKey,type:"bpmn:SequenceFlow"})})}),J.childs.filter((z)=>z.virtual!==!0&&z.bpmn.edges.length>1).forEach((z)=>{let U=q.indexOf(z),A=M0({...$,parent:J,bpmnType:"bpmn:ExclusiveGateway",type:"switch",location:U+1});A.bpmn.edges=z.bpmn.edges.map((B)=>{return{...B,from:A.indexKey}}),z.bpmn.edges=[{from:z.indexKey,to:A.indexKey,type:"bpmn:SequenceFlow"}],z.bpmn.outside=[]})}b$({...$,targetNodes:J.childs})})}function M0($){let{parent:Q,nodes:Z,nodeIndex:X,bpmnType:q,type:J,name:V,outside:Y,location:W,definitions:H,attrs:K}=$,G=Q.childs.filter((O)=>O.type===`v${J}`).length;if(F("bpmn"))s.info(` \uD83D\uDD37 VIRTUAL ${J.toUpperCase()} → ${q}`,{parent:Q.indexKey,type:`v${J}`,bpmnType:q,name:V||`${J}${G}`});let _={indexKey:`${Q.indexKey}/_${J}${G}`,pathKey:`${Q.pathKey}._${J}${G}`,type:`v${J}`,name:V,bpmn:{edges:[],outside:[],type:q,width:36,height:36,fill:"#c8e6c9",stroke:"#205022",definitions:H,attrs:K},virtual:!0,childs:[]};return Q.childs.splice(W||0,0,_),Z.push(_),X[_.indexKey]=_,_}function k$($){let{targetNode:Q,targetFlowElementsContainer:Z,targetPlaneElement:X,moddle:q,elementIndex:J,nodeIndex:V,diagrams:Y,nodes:W}=$;w7($),P7($),N7($),b7($)}function w7($){let{targetNode:Q,targetFlowElementsContainer:Z,targetPlaneElement:X,moddle:q,elementIndex:J,nodeIndex:V,nodes:Y}=$,W=Z.get("flowElements");if(Z.$nodes=Z.$nodes||[],F("bpmn"))s.info(`\uD83C\uDFA8 Creating BPMN elements for: ${Q.indexKey}`,{childCount:Q.childs.length});Q.childs.forEach((H)=>{let K=q.create(H.bpmn.type,{id:`node.${H.pathKey}`,name:H.definition?.title||H.name});if(J[K.id]=K,K.$isNode=!0,K.$node=H,H.$flow=K,Z.$nodes.push(K),W.push(K),H.bpmn.type==="bpmn:CallActivity"&&H.context?.lib){if(K.calledElement=H.context.lib.name,F("bpmn"))s.info(` ✨ Created: ${H.bpmn.type} (chip!)`,{id:K.id,name:K.name,calledElement:K.calledElement,nodeType:H.type,virtual:H.virtual||!1})}else if(F("bpmn"))s.info(` ✨ Created: ${H.bpmn.type}`,{id:K.id,name:K.name,nodeType:H.type,virtual:H.virtual||!1});if(H.bpmn.attrs)Object.keys(H.bpmn.attrs).forEach((_)=>{if(_==="attachedToRef")K.set(_,H.bpmn.attrs[_].$flow)});if(H.bpmn.definitions){let G=H.bpmn.definitions.map((_)=>{let O=q.create(_.type);return Object.keys(_.attrs||{}).forEach((z)=>{O.set(z,_.attrs[z])}),O});K.eventDefinitions=G}})}function P7($){let{targetNode:Q,targetFlowElementsContainer:Z,targetPlaneElement:X,moddle:q,elementIndex:J,nodeIndex:V}=$,Y=Z.get("flowElements");Z.$edges=Z.$edges||[],Q.childs.forEach((W)=>{W.bpmn.edges.forEach((K)=>{let G=W,_=V[K.to],O=`edge.${G.pathKey}_${_.pathKey}`;if(J[O])return;let M=J[`node.${G.pathKey}`],z=J[`node.${_.pathKey}`],U=q.create(K.type,{id:O,sourceRef:M,targetRef:z});J[U.id]=U,U.$is_edge=!0,M.get("outgoing").push(U),z.get("incoming").push(U),Z.$edges.push({from:M,to:z,flow:U}),Y.push(U)})})}function N7($){let{targetNode:Q,targetFlowElementsContainer:Z,targetPlaneElement:X,moddle:q,elementIndex:J,nodeIndex:V}=$,Y=120,W=80,H=160,K=160,G=new o6.graphlib.Graph;G.setDefaultEdgeLabel(()=>({})),G.setGraph({rankdir:"TB",nodesep:120,ranksep:80,xranker:"longest-path"}),Z.$nodes.forEach((_)=>{G.setNode(_.id,{width:_.$node?.bpmn.width||120,height:_.$node?.bpmn.height||80,label:_.id})}),Z.$edges.forEach((_)=>{G.setEdge(_.from.id,_.to.id)}),o6.layout(G),Z.$nodes.forEach((_)=>{let O=G.node(_.id),M=O.width,z=O.height,U=q.create("bpmndi:BPMNShape",{id:`shape.${_.id}`,bpmnElement:_,bounds:q.create("dc:Bounds",{x:160+O.x-O.width/2,y:160+O.y-O.height/2,width:M,height:z}),label:q.create("bpmndi:BPMNLabel")});if(_.$node.bpmn.fill)U.set("bioc:fill",_.$node.bpmn.fill);if(_.$node.bpmn.stroke)U.set("bioc:stroke",_.$node.bpmn.stroke);X.get("planeElement").push(U)}),Z.$edges.forEach((_)=>{let O=G.edge(_.from.id,_.to.id),M=q.create("bpmndi:BPMNEdge",{id:`edge.${_.from.id}_${_.to.id}`,bpmnElement:_.flow,label:q.create("bpmndi:BPMNLabel")});O.points.forEach((U)=>{let A=q.create("dc:Point",{x:160+U.x,y:160+U.y});M.get("waypoint").push(A)}),X.get("planeElement").push(M)})}function b7($){let{targetNode:Q,targetFlowElementsContainer:Z,targetPlaneElement:X,moddle:q,elementIndex:J,nodeIndex:V,diagrams:Y}=$;Q.childs.filter((H)=>H.bpmn.type==="bpmn:SubProcess").forEach((H)=>{let K=J[`node.${H.pathKey}`],G=q.create("bpmndi:BPMNDiagram",{id:`diagram_${H.pathKey}`});J[G.id]=G,Y.push(G);let _=q.create("bpmndi:BPMNPlane",{id:`plane_${H.pathKey}`});J[_.id]=_,G.plane=_,_.bpmnElement=K,k$({...$,targetNode:H,targetFlowElementsContainer:K,targetPlaneElement:_})})}async function k7($){let Q=$.root,Z=Q.context.index,X=Object.keys(Z).map((H)=>Z[H]);e6({nodes:X,nodeIndex:Z,root:Q}),b$({nodes:X,nodeIndex:Z,root:Q});let q=void 0,J=new t6({atom:w$}),V={},Y=J.create("bpmn:Definitions",{id:"definitions_0"});V[Y.id]=Y;for await(let H of Q.childs){let K=Y.get("rootElements"),G=Y.get("diagrams"),_=J.create("bpmn:Process",{id:`process_${H.pathKey}`,name:H.name,documentation:[J.create("bpmn:Documentation",{text:`Workflow - ${H.name}`})]});V[_.id]=_,_.isExecutable=!0,K.push(_);let O=J.create("bpmndi:BPMNDiagram",{id:`diagram_${H.pathKey}`});V[O.id]=O,G.push(O);let M=J.create("bpmndi:BPMNPlane",{id:`plane_${H.pathKey}`});V[M.id]=M,O.plane=M,M.bpmnElement=_,k$({targetNode:H,targetFlowElementsContainer:_,targetPlaneElement:M,moddle:J,elementIndex:V,nodeIndex:Z,nodes:X,diagrams:G})}let W=await J.toXML(Y,{format:!0});return{diagramXML:q||W.xml}}async function D7($){let{root:Q,flowName:Z}=$,X=N$(Q),q=X.childs.find((T)=>T.name===Z);if(!q)throw Error(`Flow "${Z}" not found`);let J={...X,childs:[q]},V=J.context.index,Y=Object.keys(V).map((T)=>V[T]);e6({nodes:Y,nodeIndex:V,root:J}),b$({nodes:Y,nodeIndex:V,root:J});let W=new t6({atom:w$}),H={},K=W.create("bpmn:Definitions",{id:`definitions_${Z}`});H[K.id]=K;let G=K.get("rootElements"),_=K.get("diagrams"),O=W.create("bpmn:Process",{id:`process_${q.pathKey}`,name:q.name,documentation:[W.create("bpmn:Documentation",{text:`Workflow - ${q.name}`})]});H[O.id]=O,O.isExecutable=!0,G.push(O);let M=W.create("bpmndi:BPMNDiagram",{id:`diagram_${q.pathKey}`});H[M.id]=M,_.push(M);let z=W.create("bpmndi:BPMNPlane",{id:`plane_${q.pathKey}`});return H[z.id]=z,M.plane=z,z.bpmnElement=O,k$({targetNode:q,targetFlowElementsContainer:O,targetPlaneElement:z,moddle:W,elementIndex:H,nodeIndex:V,nodes:Y,diagrams:_}),{diagramXML:(await W.toXML(K,{format:!0})).xml,flowName:q.name}}async function U8($={}){return await k7(N$($))}async function $5($={}){let Q=N$($),{root:Z}=Q,X=[];for(let q of Z.childs){let J=await D7({root:Z,flowName:q.name});X.push(J)}return X}import J2 from"@fnet/config";import Y2 from"@flownet/lib-parse-imports-js";import P1 from"@fnet/expression";import V2 from"@fnet/yaml";import W2 from"chalk";var L5=k(U5(),1);var l0=($)=>{if(typeof $!=="string")throw TypeError("invalid pattern");if($.length>65536)throw TypeError("pattern is too long")};var g7={"[:alnum:]":["\\p{L}\\p{Nl}\\p{Nd}",!0],"[:alpha:]":["\\p{L}\\p{Nl}",!0],"[:ascii:]":["\\x00-\\x7f",!1],"[:blank:]":["\\p{Zs}\\t",!0],"[:cntrl:]":["\\p{Cc}",!0],"[:digit:]":["\\p{Nd}",!0],"[:graph:]":["\\p{Z}\\p{C}",!0,!0],"[:lower:]":["\\p{Ll}",!0],"[:print:]":["\\p{C}",!0],"[:punct:]":["\\p{P}",!0],"[:space:]":["\\p{Z}\\t\\r\\n\\v\\f",!0],"[:upper:]":["\\p{Lu}",!0],"[:word:]":["\\p{L}\\p{Nl}\\p{Nd}\\p{Pc}",!0],"[:xdigit:]":["A-Fa-f0-9",!1]},d0=($)=>$.replace(/[[\]\\-]/g,"\\$&"),m7=($)=>$.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),M5=($)=>$.join(""),O5=($,Q)=>{let Z=Q;if($.charAt(Z)!=="[")throw Error("not in a brace expression");let X=[],q=[],J=Z+1,V=!1,Y=!1,W=!1,H=!1,K=Z,G="";$:while(J<$.length){let z=$.charAt(J);if((z==="!"||z==="^")&&J===Z+1){H=!0,J++;continue}if(z==="]"&&V&&!W){K=J+1;break}if(V=!0,z==="\\"){if(!W){W=!0,J++;continue}}if(z==="["&&!W){for(let[U,[A,B,C]]of Object.entries(g7))if($.startsWith(U,J)){if(G)return["$.",!1,$.length-Z,!0];if(J+=U.length,C)q.push(A);else X.push(A);Y=Y||B;continue $}}if(W=!1,G){if(z>G)X.push(d0(G)+"-"+d0(z));else if(z===G)X.push(d0(z));G="",J++;continue}if($.startsWith("-]",J+1)){X.push(d0(z+"-")),J+=2;continue}if($.startsWith("-",J+1)){G=z,J+=2;continue}X.push(d0(z)),J++}if(K<J)return["",!1,0,!1];if(!X.length&&!q.length)return["$.",!1,$.length-Z,!0];if(q.length===0&&X.length===1&&/^\\?.$/.test(X[0])&&!H){let z=X[0].length===2?X[0].slice(-1):X[0];return[m7(z),!1,K-Z,!1]}let _="["+(H?"^":"")+M5(X)+"]",O="["+(H?"":"^")+M5(q)+"]";return[X.length&&q.length?"("+_+"|"+O+")":X.length?_:O,Y,K-Z,!0]};var q0=($,{windowsPathsNoEscape:Q=!1}={})=>{return Q?$.replace(/\[([^\/\\])\]/g,"$1"):$.replace(/((?!\\).|^)\[([^\/\\])\]/g,"$1$2").replace(/\\([^\/])/g,"$1")};var c7=new Set(["!","?","+","*","@"]),A5=($)=>c7.has($),l7="(?!(?:^|/)\\.\\.?(?:$|/))",M8="(?!\\.)",d7=new Set(["[","."]),p7=new Set(["..","."]),i7=new Set("().*{}+?[]^$\\!"),n7=($)=>$.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),E$="[^/]",B5=E$+"*?",R5=E$+"+?";class g{type;#Q;#$;#Z=!1;#X=[];#J;#I;#C;#H=!1;#G;#W;#_=!1;constructor($,Q,Z={}){if(this.type=$,$)this.#$=!0;if(this.#J=Q,this.#Q=this.#J?this.#J.#Q:this,this.#G=this.#Q===this?Z:this.#Q.#G,this.#C=this.#Q===this?[]:this.#Q.#C,$==="!"&&!this.#Q.#H)this.#C.push(this);this.#I=this.#J?this.#J.#X.length:0}get hasMagic(){if(this.#$!==void 0)return this.#$;for(let $ of this.#X){if(typeof $==="string")continue;if($.type||$.hasMagic)return this.#$=!0}return this.#$}toString(){if(this.#W!==void 0)return this.#W;if(!this.type)return this.#W=this.#X.map(($)=>String($)).join("");else return this.#W=this.type+"("+this.#X.map(($)=>String($)).join("|")+")"}#q(){if(this!==this.#Q)throw Error("should only call on root");if(this.#H)return this;this.toString(),this.#H=!0;let $;while($=this.#C.pop()){if($.type!=="!")continue;let Q=$,Z=Q.#J;while(Z){for(let X=Q.#I+1;!Z.type&&X<Z.#X.length;X++)for(let q of $.#X){if(typeof q==="string")throw Error("string part in extglob AST??");q.copyIn(Z.#X[X])}Q=Z,Z=Q.#J}}return this}push(...$){for(let Q of $){if(Q==="")continue;if(typeof Q!=="string"&&!(Q instanceof g&&Q.#J===this))throw Error("invalid part: "+Q);this.#X.push(Q)}}toJSON(){let $=this.type===null?this.#X.slice().map((Q)=>typeof Q==="string"?Q:Q.toJSON()):[this.type,...this.#X.map((Q)=>Q.toJSON())];if(this.isStart()&&!this.type)$.unshift([]);if(this.isEnd()&&(this===this.#Q||this.#Q.#H&&this.#J?.type==="!"))$.push({});return $}isStart(){if(this.#Q===this)return!0;if(!this.#J?.isStart())return!1;if(this.#I===0)return!0;let $=this.#J;for(let Q=0;Q<this.#I;Q++){let Z=$.#X[Q];if(!(Z instanceof g&&Z.type==="!"))return!1}return!0}isEnd(){if(this.#Q===this)return!0;if(this.#J?.type==="!")return!0;if(!this.#J?.isEnd())return!1;if(!this.type)return this.#J?.isEnd();let $=this.#J?this.#J.#X.length:0;return this.#I===$-1}copyIn($){if(typeof $==="string")this.push($);else this.push($.clone(this))}clone($){let Q=new g(this.type,$);for(let Z of this.#X)Q.copyIn(Z);return Q}static#O($,Q,Z,X){let q=!1,J=!1,V=-1,Y=!1;if(Q.type===null){let _=Z,O="";while(_<$.length){let M=$.charAt(_++);if(q||M==="\\"){q=!q,O+=M;continue}if(J){if(_===V+1){if(M==="^"||M==="!")Y=!0}else if(M==="]"&&!(_===V+2&&Y))J=!1;O+=M;continue}else if(M==="["){J=!0,V=_,Y=!1,O+=M;continue}if(!X.noext&&A5(M)&&$.charAt(_)==="("){Q.push(O),O="";let z=new g(M,Q);_=g.#O($,z,_,X),Q.push(z);continue}O+=M}return Q.push(O),_}let W=Z+1,H=new g(null,Q),K=[],G="";while(W<$.length){let _=$.charAt(W++);if(q||_==="\\"){q=!q,G+=_;continue}if(J){if(W===V+1){if(_==="^"||_==="!")Y=!0}else if(_==="]"&&!(W===V+2&&Y))J=!1;G+=_;continue}else if(_==="["){J=!0,V=W,Y=!1,G+=_;continue}if(A5(_)&&$.charAt(W)==="("){H.push(G),G="";let O=new g(_,H);H.push(O),W=g.#O($,O,W,X);continue}if(_==="|"){H.push(G),G="",K.push(H),H=new g(null,Q);continue}if(_===")"){if(G===""&&Q.#X.length===0)Q.#_=!0;return H.push(G),G="",Q.push(...K,H),W}G+=_}return Q.type=null,Q.#$=void 0,Q.#X=[$.substring(Z-1)],W}static fromGlob($,Q={}){let Z=new g(null,void 0,Q);return g.#O($,Z,0,Q),Z}toMMPattern(){if(this!==this.#Q)return this.#Q.toMMPattern();let $=this.toString(),[Q,Z,X,q]=this.toRegExpSource();if(!(X||this.#$||this.#G.nocase&&!this.#G.nocaseMagicOnly&&$.toUpperCase()!==$.toLowerCase()))return Z;let V=(this.#G.nocase?"i":"")+(q?"u":"");return Object.assign(new RegExp(`^${Q}$`,V),{_src:Q,_glob:$})}get options(){return this.#G}toRegExpSource($){let Q=$??!!this.#G.dot;if(this.#Q===this)this.#q();if(!this.type){let Y=this.isStart()&&this.isEnd(),W=this.#X.map((_)=>{let[O,M,z,U]=typeof _==="string"?g.#U(_,this.#$,Y):_.toRegExpSource($);return this.#$=this.#$||z,this.#Z=this.#Z||U,O}).join(""),H="";if(this.isStart()){if(typeof this.#X[0]==="string"){if(!(this.#X.length===1&&p7.has(this.#X[0]))){let O=d7,M=Q&&O.has(W.charAt(0))||W.startsWith("\\.")&&O.has(W.charAt(2))||W.startsWith("\\.\\.")&&O.has(W.charAt(4)),z=!Q&&!$&&O.has(W.charAt(0));H=M?l7:z?M8:""}}}let K="";if(this.isEnd()&&this.#Q.#H&&this.#J?.type==="!")K="(?:$|\\/)";return[H+W+K,q0(W),this.#$=!!this.#$,this.#Z]}let Z=this.type==="*"||this.type==="+",X=this.type==="!"?"(?:(?!(?:":"(?:",q=this.#M(Q);if(this.isStart()&&this.isEnd()&&!q&&this.type!=="!"){let Y=this.toString();return this.#X=[Y],this.type=null,this.#$=void 0,[Y,q0(this.toString()),!1,!1]}let J=!Z||$||Q||!M8?"":this.#M(!0);if(J===q)J="";if(J)q=`(?:${q})(?:${J})*?`;let V="";if(this.type==="!"&&this.#_)V=(this.isStart()&&!Q?M8:"")+R5;else{let Y=this.type==="!"?"))"+(this.isStart()&&!Q&&!$?M8:"")+B5+")":this.type==="@"?")":this.type==="?"?")?":this.type==="+"&&J?")":this.type==="*"&&J?")?":`)${this.type}`;V=X+q+Y}return[V,q0(q),this.#$=!!this.#$,this.#Z]}#M($){return this.#X.map((Q)=>{if(typeof Q==="string")throw Error("string type in extglob ast??");let[Z,X,q,J]=Q.toRegExpSource($);return this.#Z=this.#Z||J,Z}).filter((Q)=>!(this.isStart()&&this.isEnd())||!!Q).join("|")}static#U($,Q,Z=!1){let X=!1,q="",J=!1;for(let V=0;V<$.length;V++){let Y=$.charAt(V);if(X){X=!1,q+=(i7.has(Y)?"\\":"")+Y;continue}if(Y==="\\"){if(V===$.length-1)q+="\\\\";else X=!0;continue}if(Y==="["){let[W,H,K,G]=O5($,V);if(K){q+=W,J=J||H,V+=K-1,Q=Q||G;continue}}if(Y==="*"){if(Z&&$==="*")q+=R5;else q+=B5;Q=!0;continue}if(Y==="?"){q+=E$,Q=!0;continue}q+=n7(Y)}return[q,q0($),!!Q,J]}}var E0=($,{windowsPathsNoEscape:Q=!1}={})=>{return Q?$.replace(/[?*()[\]]/g,"[$&]"):$.replace(/[?*()[\]\\]/g,"\\$&")};var i=($,Q,Z={})=>{if(l0(Q),!Z.nocomment&&Q.charAt(0)==="#")return!1;return new t(Q,Z).match($)},r7=/^\*+([^+@!?\*\[\(]*)$/,s7=($)=>(Q)=>!Q.startsWith(".")&&Q.endsWith($),a7=($)=>(Q)=>Q.endsWith($),o7=($)=>{return $=$.toLowerCase(),(Q)=>!Q.startsWith(".")&&Q.toLowerCase().endsWith($)},t7=($)=>{return $=$.toLowerCase(),(Q)=>Q.toLowerCase().endsWith($)},e7=/^\*+\.\*+$/,$9=($)=>!$.startsWith(".")&&$.includes("."),Q9=($)=>$!=="."&&$!==".."&&$.includes("."),Z9=/^\.\*+$/,X9=($)=>$!=="."&&$!==".."&&$.startsWith("."),q9=/^\*+$/,J9=($)=>$.length!==0&&!$.startsWith("."),Y9=($)=>$.length!==0&&$!=="."&&$!=="..",V9=/^\?+([^+@!?\*\[\(]*)?$/,W9=([$,Q=""])=>{let Z=F5([$]);if(!Q)return Z;return Q=Q.toLowerCase(),(X)=>Z(X)&&X.toLowerCase().endsWith(Q)},H9=([$,Q=""])=>{let Z=j5([$]);if(!Q)return Z;return Q=Q.toLowerCase(),(X)=>Z(X)&&X.toLowerCase().endsWith(Q)},K9=([$,Q=""])=>{let Z=j5([$]);return!Q?Z:(X)=>Z(X)&&X.endsWith(Q)},_9=([$,Q=""])=>{let Z=F5([$]);return!Q?Z:(X)=>Z(X)&&X.endsWith(Q)},F5=([$])=>{let Q=$.length;return(Z)=>Z.length===Q&&!Z.startsWith(".")},j5=([$])=>{let Q=$.length;return(Z)=>Z.length===Q&&Z!=="."&&Z!==".."},T5=typeof process==="object"&&process?typeof process.env==="object"&&process.env&&process.env.__MINIMATCH_TESTING_PLATFORM__||process.platform:"posix",C5={win32:{sep:"\\"},posix:{sep:"/"}},G9=T5==="win32"?C5.win32.sep:C5.posix.sep;i.sep=G9;var m=Symbol("globstar **");i.GLOBSTAR=m;var z9="[^/]",U9=z9+"*?",M9="(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?",O9="(?:(?!(?:\\/|^)\\.).)*?",A9=($,Q={})=>(Z)=>i(Z,$,Q);i.filter=A9;var o=($,Q={})=>Object.assign({},$,Q),B9=($)=>{if(!$||typeof $!=="object"||!Object.keys($).length)return i;let Q=i;return Object.assign((X,q,J={})=>Q(X,q,o($,J)),{Minimatch:class extends Q.Minimatch{constructor(q,J={}){super(q,o($,J))}static defaults(q){return Q.defaults(o($,q)).Minimatch}},AST:class extends Q.AST{constructor(q,J,V={}){super(q,J,o($,V))}static fromGlob(q,J={}){return Q.AST.fromGlob(q,o($,J))}},unescape:(X,q={})=>Q.unescape(X,o($,q)),escape:(X,q={})=>Q.escape(X,o($,q)),filter:(X,q={})=>Q.filter(X,o($,q)),defaults:(X)=>Q.defaults(o($,X)),makeRe:(X,q={})=>Q.makeRe(X,o($,q)),braceExpand:(X,q={})=>Q.braceExpand(X,o($,q)),match:(X,q,J={})=>Q.match(X,q,o($,J)),sep:Q.sep,GLOBSTAR:m})};i.defaults=B9;var S5=($,Q={})=>{if(l0($),Q.nobrace||!/\{(?:(?!\{).)*\}/.test($))return[$];return L5.default($)};i.braceExpand=S5;var R9=($,Q={})=>new t($,Q).makeRe();i.makeRe=R9;var C9=($,Q,Z={})=>{let X=new t(Q,Z);if($=$.filter((q)=>X.match(q)),X.options.nonull&&!$.length)$.push(Q);return $};i.match=C9;var I5=/[?*]|[+@!]\(.*?\)|\[|\]/,I9=($)=>$.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&");class t{options;set;pattern;windowsPathsNoEscape;nonegate;negate;comment;empty;preserveMultipleSlashes;partial;globSet;globParts;nocase;isWindows;platform;windowsNoMagicRoot;regexp;constructor($,Q={}){if(l0($),Q=Q||{},this.options=Q,this.pattern=$,this.platform=Q.platform||T5,this.isWindows=this.platform==="win32",this.windowsPathsNoEscape=!!Q.windowsPathsNoEscape||Q.allowWindowsEscape===!1,this.windowsPathsNoEscape)this.pattern=this.pattern.replace(/\\/g,"/");this.preserveMultipleSlashes=!!Q.preserveMultipleSlashes,this.regexp=null,this.negate=!1,this.nonegate=!!Q.nonegate,this.comment=!1,this.empty=!1,this.partial=!!Q.partial,this.nocase=!!this.options.nocase,this.windowsNoMagicRoot=Q.windowsNoMagicRoot!==void 0?Q.windowsNoMagicRoot:!!(this.isWindows&&this.nocase),this.globSet=[],this.globParts=[],this.set=[],this.make()}hasMagic(){if(this.options.magicalBraces&&this.set.length>1)return!0;for(let $ of this.set)for(let Q of $)if(typeof Q!=="string")return!0;return!1}debug(...$){}make(){let $=this.pattern,Q=this.options;if(!Q.nocomment&&$.charAt(0)==="#"){this.comment=!0;return}if(!$){this.empty=!0;return}if(this.parseNegate(),this.globSet=[...new Set(this.braceExpand())],Q.debug)this.debug=(...q)=>console.error(...q);this.debug(this.pattern,this.globSet);let Z=this.globSet.map((q)=>this.slashSplit(q));this.globParts=this.preprocess(Z),this.debug(this.pattern,this.globParts);let X=this.globParts.map((q,J,V)=>{if(this.isWindows&&this.windowsNoMagicRoot){let Y=q[0]===""&&q[1]===""&&(q[2]==="?"||!I5.test(q[2]))&&!I5.test(q[3]),W=/^[a-z]:/i.test(q[0]);if(Y)return[...q.slice(0,4),...q.slice(4).map((H)=>this.parse(H))];else if(W)return[q[0],...q.slice(1).map((H)=>this.parse(H))]}return q.map((Y)=>this.parse(Y))});if(this.debug(this.pattern,X),this.set=X.filter((q)=>q.indexOf(!1)===-1),this.isWindows)for(let q=0;q<this.set.length;q++){let J=this.set[q];if(J[0]===""&&J[1]===""&&this.globParts[q][2]==="?"&&typeof J[3]==="string"&&/^[a-z]:$/i.test(J[3]))J[2]="?"}this.debug(this.pattern,this.set)}preprocess($){if(this.options.noglobstar){for(let Z=0;Z<$.length;Z++)for(let X=0;X<$[Z].length;X++)if($[Z][X]==="**")$[Z][X]="*"}let{optimizationLevel:Q=1}=this.options;if(Q>=2)$=this.firstPhasePreProcess($),$=this.secondPhasePreProcess($);else if(Q>=1)$=this.levelOneOptimize($);else $=this.adjascentGlobstarOptimize($);return $}adjascentGlobstarOptimize($){return $.map((Q)=>{let Z=-1;while((Z=Q.indexOf("**",Z+1))!==-1){let X=Z;while(Q[X+1]==="**")X++;if(X!==Z)Q.splice(Z,X-Z)}return Q})}levelOneOptimize($){return $.map((Q)=>{return Q=Q.reduce((Z,X)=>{let q=Z[Z.length-1];if(X==="**"&&q==="**")return Z;if(X===".."){if(q&&q!==".."&&q!=="."&&q!=="**")return Z.pop(),Z}return Z.push(X),Z},[]),Q.length===0?[""]:Q})}levelTwoFileOptimize($){if(!Array.isArray($))$=this.slashSplit($);let Q=!1;do{if(Q=!1,!this.preserveMultipleSlashes){for(let X=1;X<$.length-1;X++){let q=$[X];if(X===1&&q===""&&$[0]==="")continue;if(q==="."||q==="")Q=!0,$.splice(X,1),X--}if($[0]==="."&&$.length===2&&($[1]==="."||$[1]===""))Q=!0,$.pop()}let Z=0;while((Z=$.indexOf("..",Z+1))!==-1){let X=$[Z-1];if(X&&X!=="."&&X!==".."&&X!=="**")Q=!0,$.splice(Z-1,2),Z-=2}}while(Q);return $.length===0?[""]:$}firstPhasePreProcess($){let Q=!1;do{Q=!1;for(let Z of $){let X=-1;while((X=Z.indexOf("**",X+1))!==-1){let J=X;while(Z[J+1]==="**")J++;if(J>X)Z.splice(X+1,J-X);let V=Z[X+1],Y=Z[X+2],W=Z[X+3];if(V!=="..")continue;if(!Y||Y==="."||Y===".."||!W||W==="."||W==="..")continue;Q=!0,Z.splice(X,1);let H=Z.slice(0);H[X]="**",$.push(H),X--}if(!this.preserveMultipleSlashes){for(let J=1;J<Z.length-1;J++){let V=Z[J];if(J===1&&V===""&&Z[0]==="")continue;if(V==="."||V==="")Q=!0,Z.splice(J,1),J--}if(Z[0]==="."&&Z.length===2&&(Z[1]==="."||Z[1]===""))Q=!0,Z.pop()}let q=0;while((q=Z.indexOf("..",q+1))!==-1){let J=Z[q-1];if(J&&J!=="."&&J!==".."&&J!=="**"){Q=!0;let Y=q===1&&Z[q+1]==="**"?["."]:[];if(Z.splice(q-1,2,...Y),Z.length===0)Z.push("");q-=2}}}}while(Q);return $}secondPhasePreProcess($){for(let Q=0;Q<$.length-1;Q++)for(let Z=Q+1;Z<$.length;Z++){let X=this.partsMatch($[Q],$[Z],!this.preserveMultipleSlashes);if(X){$[Q]=[],$[Z]=X;break}}return $.filter((Q)=>Q.length)}partsMatch($,Q,Z=!1){let X=0,q=0,J=[],V="";while(X<$.length&&q<Q.length)if($[X]===Q[q])J.push(V==="b"?Q[q]:$[X]),X++,q++;else if(Z&&$[X]==="**"&&Q[q]===$[X+1])J.push($[X]),X++;else if(Z&&Q[q]==="**"&&$[X]===Q[q+1])J.push(Q[q]),q++;else if($[X]==="*"&&Q[q]&&(this.options.dot||!Q[q].startsWith("."))&&Q[q]!=="**"){if(V==="b")return!1;V="a",J.push($[X]),X++,q++}else if(Q[q]==="*"&&$[X]&&(this.options.dot||!$[X].startsWith("."))&&$[X]!=="**"){if(V==="a")return!1;V="b",J.push(Q[q]),X++,q++}else return!1;return $.length===Q.length&&J}parseNegate(){if(this.nonegate)return;let $=this.pattern,Q=!1,Z=0;for(let X=0;X<$.length&&$.charAt(X)==="!";X++)Q=!Q,Z++;if(Z)this.pattern=$.slice(Z);this.negate=Q}matchOne($,Q,Z=!1){let X=this.options;if(this.isWindows){let M=typeof $[0]==="string"&&/^[a-z]:$/i.test($[0]),z=!M&&$[0]===""&&$[1]===""&&$[2]==="?"&&/^[a-z]:$/i.test($[3]),U=typeof Q[0]==="string"&&/^[a-z]:$/i.test(Q[0]),A=!U&&Q[0]===""&&Q[1]===""&&Q[2]==="?"&&typeof Q[3]==="string"&&/^[a-z]:$/i.test(Q[3]),B=z?3:M?0:void 0,C=A?3:U?0:void 0;if(typeof B==="number"&&typeof C==="number"){let[T,p]=[$[B],Q[C]];if(T.toLowerCase()===p.toLowerCase()){if(Q[C]=T,C>B)Q=Q.slice(C);else if(B>C)$=$.slice(B)}}}let{optimizationLevel:q=1}=this.options;if(q>=2)$=this.levelTwoFileOptimize($);this.debug("matchOne",this,{file:$,pattern:Q}),this.debug("matchOne",$.length,Q.length);for(var J=0,V=0,Y=$.length,W=Q.length;J<Y&&V<W;J++,V++){this.debug("matchOne loop");var H=Q[V],K=$[J];if(this.debug(Q,H,K),H===!1)return!1;if(H===m){this.debug("GLOBSTAR",[Q,H,K]);var G=J,_=V+1;if(_===W){this.debug("** at the end");for(;J<Y;J++)if($[J]==="."||$[J]===".."||!X.dot&&$[J].charAt(0)===".")return!1;return!0}while(G<Y){var O=$[G];if(this.debug(`
5
5
  globstar while`,$,G,Q,_,O),this.matchOne($.slice(G),Q.slice(_),Z))return this.debug("globstar found match!",G,Y,O),!0;else{if(O==="."||O===".."||!X.dot&&O.charAt(0)==="."){this.debug("dot detected!",$,G,Q,_);break}this.debug("globstar swallow a segment, and continue"),G++}}if(Z){if(this.debug(`
6
6
  >>> no match, partial?`,$,G,Q,_),G===Y)return!0}return!1}let M;if(typeof H==="string")M=K===H,this.debug("string match",H,K,M);else M=H.test(K),this.debug("pattern match",H,K,M);if(!M)return!1}if(J===Y&&V===W)return!0;else if(J===Y)return Z;else if(V===W)return J===Y-1&&$[J]==="";else throw Error("wtf?")}braceExpand(){return S5(this.pattern,this.options)}parse($){l0($);let Q=this.options;if($==="**")return m;if($==="")return"";let Z,X=null;if(Z=$.match(q9))X=Q.dot?Y9:J9;else if(Z=$.match(r7))X=(Q.nocase?Q.dot?t7:o7:Q.dot?a7:s7)(Z[1]);else if(Z=$.match(V9))X=(Q.nocase?Q.dot?H9:W9:Q.dot?K9:_9)(Z);else if(Z=$.match(e7))X=Q.dot?Q9:$9;else if(Z=$.match(Z9))X=X9;let q=g.fromGlob($,this.options).toMMPattern();if(X&&typeof q==="object")Reflect.defineProperty(q,"test",{value:X});return q}makeRe(){if(this.regexp||this.regexp===!1)return this.regexp;let $=this.set;if(!$.length)return this.regexp=!1,this.regexp;let Q=this.options,Z=Q.noglobstar?U9:Q.dot?M9:O9,X=new Set(Q.nocase?["i"]:[]),q=$.map((Y)=>{let W=Y.map((H)=>{if(H instanceof RegExp)for(let K of H.flags.split(""))X.add(K);return typeof H==="string"?I9(H):H===m?m:H._src});return W.forEach((H,K)=>{let G=W[K+1],_=W[K-1];if(H!==m||_===m)return;if(_===void 0)if(G!==void 0&&G!==m)W[K+1]="(?:\\/|"+Z+"\\/)?"+G;else W[K]=Z;else if(G===void 0)W[K-1]=_+"(?:\\/|"+Z+")?";else if(G!==m)W[K-1]=_+"(?:\\/|\\/"+Z+"\\/)"+G,W[K+1]=m}),W.filter((H)=>H!==m).join("/")}).join("|"),[J,V]=$.length>1?["(?:",")"]:["",""];if(q="^"+J+q+V+"$",this.negate)q="^(?!"+q+").+$";try{this.regexp=new RegExp(q,[...X].join(""))}catch(Y){this.regexp=!1}return this.regexp}slashSplit($){if(this.preserveMultipleSlashes)return $.split("/");else if(this.isWindows&&/^\/\/[^\/]+/.test($))return["",...$.split(/\/+/)];else return $.split(/\/+/)}match($,Q=this.partial){if(this.debug("match",$,this.pattern),this.comment)return!1;if(this.empty)return $==="";if($==="/"&&Q)return!0;let Z=this.options;if(this.isWindows)$=$.split("\\").join("/");let X=this.slashSplit($);this.debug(this.pattern,"split",X);let q=this.set;this.debug(this.pattern,"set",q);let J=X[X.length-1];if(!J)for(let V=X.length-2;!J&&V>=0;V--)J=X[V];for(let V=0;V<q.length;V++){let Y=q[V],W=X;if(Z.matchBase&&Y.length===1)W=[J];if(this.matchOne(W,Y,Q)){if(Z.flipNegate)return!0;return!this.negate}}if(Z.flipNegate)return!1;return this.negate}static defaults($){return i.defaults($).Minimatch}}i.AST=g;i.Minimatch=t;i.escape=E0;i.unescape=q0;import{fileURLToPath as e9}from"node:url";var y0=typeof performance==="object"&&performance&&typeof performance.now==="function"?performance:Date,P5=new Set,y$=typeof process==="object"&&!!process?process:{},N5=($,Q,Z,X)=>{typeof y$.emitWarning==="function"?y$.emitWarning($,Q,Z,X):console.error(`[${Z}] ${Q}: ${$}`)},O8=globalThis.AbortController,w5=globalThis.AbortSignal;if(typeof O8>"u"){w5=class{onabort;_onabort=[];reason;aborted=!1;addEventListener(X,q){this._onabort.push(q)}},O8=class{constructor(){Q()}signal=new w5;abort(X){if(this.signal.aborted)return;this.signal.reason=X,this.signal.aborted=!0;for(let q of this.signal._onabort)q(X);this.signal.onabort?.(X)}};let $=y$.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",Q=()=>{if(!$)return;$=!1,N5("AbortController is not defined. If using lru-cache in node 14, load an AbortController polyfill from the `node-abort-controller` package. A minimal polyfill is provided for use by LRUCache.fetch(), but it should not be relied upon in other contexts (eg, passing it to other APIs that use AbortController/AbortSignal might have undesirable effects). You may disable this with LRU_CACHE_IGNORE_AC_WARNING=1 in the env.","NO_ABORT_CONTROLLER","ENOTSUP",Q)}}var L9=($)=>!P5.has($),p3=Symbol("type"),I0=($)=>$&&$===Math.floor($)&&$>0&&isFinite($),b5=($)=>!I0($)?null:$<=Math.pow(2,8)?Uint8Array:$<=Math.pow(2,16)?Uint16Array:$<=Math.pow(2,32)?Uint32Array:$<=Number.MAX_SAFE_INTEGER?p0:null;class p0 extends Array{constructor($){super($);this.fill(0)}}class x0{heap;length;static#Q=!1;static create($){let Q=b5($);if(!Q)return[];x0.#Q=!0;let Z=new x0($,Q);return x0.#Q=!1,Z}constructor($,Q){if(!x0.#Q)throw TypeError("instantiate Stack using Stack.create(n)");this.heap=new Q($),this.length=0}push($){this.heap[this.length++]=$}pop(){return this.heap[--this.length]}}class i0{#Q;#$;#Z;#X;#J;#I;#C;ttl;ttlResolution;ttlAutopurge;updateAgeOnGet;updateAgeOnHas;allowStale;noDisposeOnSet;noUpdateTTL;maxEntrySize;sizeCalculation;noDeleteOnFetchRejection;noDeleteOnStaleGet;allowStaleOnFetchAbort;allowStaleOnFetchRejection;ignoreFetchAbort;#H;#G;#W;#_;#q;#O;#M;#U;#A;#j;#R;#F;#V;#L;#K;#T;#B;#b;static unsafeExposeInternals($){return{starts:$.#V,ttls:$.#L,sizes:$.#F,keyMap:$.#W,keyList:$.#_,valList:$.#q,next:$.#O,prev:$.#M,get head(){return $.#U},get tail(){return $.#A},free:$.#j,isBackgroundFetch:(Q)=>$.#z(Q),backgroundFetch:(Q,Z,X,q)=>$.#y(Q,Z,X,q),moveToTail:(Q)=>$.#f(Q),indexes:(Q)=>$.#P(Q),rindexes:(Q)=>$.#N(Q),isStale:(Q)=>$.#w(Q)}}get max(){return this.#Q}get maxSize(){return this.#$}get calculatedSize(){return this.#G}get size(){return this.#H}get fetchMethod(){return this.#I}get memoMethod(){return this.#C}get dispose(){return this.#Z}get onInsert(){return this.#X}get disposeAfter(){return this.#J}constructor($){let{max:Q=0,ttl:Z,ttlResolution:X=1,ttlAutopurge:q,updateAgeOnGet:J,updateAgeOnHas:V,allowStale:Y,dispose:W,onInsert:H,disposeAfter:K,noDisposeOnSet:G,noUpdateTTL:_,maxSize:O=0,maxEntrySize:M=0,sizeCalculation:z,fetchMethod:U,memoMethod:A,noDeleteOnFetchRejection:B,noDeleteOnStaleGet:C,allowStaleOnFetchRejection:T,allowStaleOnFetchAbort:p,ignoreFetchAbort:x}=$;if(Q!==0&&!I0(Q))throw TypeError("max option must be a nonnegative integer");let Q0=Q?b5(Q):Array;if(!Q0)throw Error("invalid max value: "+Q);if(this.#Q=Q,this.#$=O,this.maxEntrySize=M||this.#$,this.sizeCalculation=z,this.sizeCalculation){if(!this.#$&&!this.maxEntrySize)throw TypeError("cannot set sizeCalculation without setting maxSize or maxEntrySize");if(typeof this.sizeCalculation!=="function")throw TypeError("sizeCalculation set to non-function")}if(A!==void 0&&typeof A!=="function")throw TypeError("memoMethod must be a function if defined");if(this.#C=A,U!==void 0&&typeof U!=="function")throw TypeError("fetchMethod must be a function if specified");if(this.#I=U,this.#T=!!U,this.#W=new Map,this.#_=Array(Q).fill(void 0),this.#q=Array(Q).fill(void 0),this.#O=new Q0(Q),this.#M=new Q0(Q),this.#U=0,this.#A=0,this.#j=x0.create(Q),this.#H=0,this.#G=0,typeof W==="function")this.#Z=W;if(typeof H==="function")this.#X=H;if(typeof K==="function")this.#J=K,this.#R=[];else this.#J=void 0,this.#R=void 0;if(this.#K=!!this.#Z,this.#b=!!this.#X,this.#B=!!this.#J,this.noDisposeOnSet=!!G,this.noUpdateTTL=!!_,this.noDeleteOnFetchRejection=!!B,this.allowStaleOnFetchRejection=!!T,this.allowStaleOnFetchAbort=!!p,this.ignoreFetchAbort=!!x,this.maxEntrySize!==0){if(this.#$!==0){if(!I0(this.#$))throw TypeError("maxSize must be a positive integer if specified")}if(!I0(this.maxEntrySize))throw TypeError("maxEntrySize must be a positive integer if specified");this.#g()}if(this.allowStale=!!Y,this.noDeleteOnStaleGet=!!C,this.updateAgeOnGet=!!J,this.updateAgeOnHas=!!V,this.ttlResolution=I0(X)||X===0?X:1,this.ttlAutopurge=!!q,this.ttl=Z||0,this.ttl){if(!I0(this.ttl))throw TypeError("ttl must be a positive integer if specified");this.#Y()}if(this.#Q===0&&this.ttl===0&&this.#$===0)throw TypeError("At least one of max, maxSize, or ttl is required");if(!this.ttlAutopurge&&!this.#Q&&!this.#$){if(L9("LRU_CACHE_UNBOUNDED"))P5.add("LRU_CACHE_UNBOUNDED"),N5("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning","LRU_CACHE_UNBOUNDED",i0)}}getRemainingTTL($){return this.#W.has($)?1/0:0}#Y(){let $=new p0(this.#Q),Q=new p0(this.#Q);this.#L=$,this.#V=Q,this.#k=(q,J,V=y0.now())=>{if(Q[q]=J!==0?V:0,$[q]=J,J!==0&&this.ttlAutopurge){let Y=setTimeout(()=>{if(this.#w(q))this.#D(this.#_[q],"expire")},J+1);if(Y.unref)Y.unref()}},this.#v=(q)=>{Q[q]=$[q]!==0?y0.now():0},this.#S=(q,J)=>{if($[J]){let V=$[J],Y=Q[J];if(!V||!Y)return;q.ttl=V,q.start=Y,q.now=Z||X();let W=q.now-Y;q.remainingTTL=V-W}};let Z=0,X=()=>{let q=y0.now();if(this.ttlResolution>0){Z=q;let J=setTimeout(()=>Z=0,this.ttlResolution);if(J.unref)J.unref()}return q};this.getRemainingTTL=(q)=>{let J=this.#W.get(q);if(J===void 0)return 0;let V=$[J],Y=Q[J];if(!V||!Y)return 1/0;let W=(Z||X())-Y;return V-W},this.#w=(q)=>{let J=Q[q],V=$[q];return!!V&&!!J&&(Z||X())-J>V}}#v=()=>{};#S=()=>{};#k=()=>{};#w=()=>!1;#g(){let $=new p0(this.#Q);this.#G=0,this.#F=$,this.#E=(Q)=>{this.#G-=$[Q],$[Q]=0},this.#m=(Q,Z,X,q)=>{if(this.#z(Z))return 0;if(!I0(X))if(q){if(typeof q!=="function")throw TypeError("sizeCalculation must be a function");if(X=q(Z,Q),!I0(X))throw TypeError("sizeCalculation return invalid (expect positive integer)")}else throw TypeError("invalid size value (must be positive integer). When maxSize or maxEntrySize is used, sizeCalculation or size must be set.");return X},this.#x=(Q,Z,X)=>{if($[Q]=Z,this.#$){let q=this.#$-$[Q];while(this.#G>q)this.#u(!0)}if(this.#G+=$[Q],X)X.entrySize=Z,X.totalCalculatedSize=this.#G}}#E=($)=>{};#x=($,Q,Z)=>{};#m=($,Q,Z,X)=>{if(Z||X)throw TypeError("cannot set size without setting maxSize or maxEntrySize on cache");return 0};*#P({allowStale:$=this.allowStale}={}){if(this.#H)for(let Q=this.#A;;){if(!this.#c(Q))break;if($||!this.#w(Q))yield Q;if(Q===this.#U)break;else Q=this.#M[Q]}}*#N({allowStale:$=this.allowStale}={}){if(this.#H)for(let Q=this.#U;;){if(!this.#c(Q))break;if($||!this.#w(Q))yield Q;if(Q===this.#A)break;else Q=this.#O[Q]}}#c($){return $!==void 0&&this.#W.get(this.#_[$])===$}*entries(){for(let $ of this.#P())if(this.#q[$]!==void 0&&this.#_[$]!==void 0&&!this.#z(this.#q[$]))yield[this.#_[$],this.#q[$]]}*rentries(){for(let $ of this.#N())if(this.#q[$]!==void 0&&this.#_[$]!==void 0&&!this.#z(this.#q[$]))yield[this.#_[$],this.#q[$]]}*keys(){for(let $ of this.#P()){let Q=this.#_[$];if(Q!==void 0&&!this.#z(this.#q[$]))yield Q}}*rkeys(){for(let $ of this.#N()){let Q=this.#_[$];if(Q!==void 0&&!this.#z(this.#q[$]))yield Q}}*values(){for(let $ of this.#P())if(this.#q[$]!==void 0&&!this.#z(this.#q[$]))yield this.#q[$]}*rvalues(){for(let $ of this.#N())if(this.#q[$]!==void 0&&!this.#z(this.#q[$]))yield this.#q[$]}[Symbol.iterator](){return this.entries()}[Symbol.toStringTag]="LRUCache";find($,Q={}){for(let Z of this.#P()){let X=this.#q[Z],q=this.#z(X)?X.__staleWhileFetching:X;if(q===void 0)continue;if($(q,this.#_[Z],this))return this.get(this.#_[Z],Q)}}forEach($,Q=this){for(let Z of this.#P()){let X=this.#q[Z],q=this.#z(X)?X.__staleWhileFetching:X;if(q===void 0)continue;$.call(Q,q,this.#_[Z],this)}}rforEach($,Q=this){for(let Z of this.#N()){let X=this.#q[Z],q=this.#z(X)?X.__staleWhileFetching:X;if(q===void 0)continue;$.call(Q,q,this.#_[Z],this)}}purgeStale(){let $=!1;for(let Q of this.#N({allowStale:!0}))if(this.#w(Q))this.#D(this.#_[Q],"expire"),$=!0;return $}info($){let Q=this.#W.get($);if(Q===void 0)return;let Z=this.#q[Q],X=this.#z(Z)?Z.__staleWhileFetching:Z;if(X===void 0)return;let q={value:X};if(this.#L&&this.#V){let J=this.#L[Q],V=this.#V[Q];if(J&&V){let Y=J-(y0.now()-V);q.ttl=Y,q.start=Date.now()}}if(this.#F)q.size=this.#F[Q];return q}dump(){let $=[];for(let Q of this.#P({allowStale:!0})){let Z=this.#_[Q],X=this.#q[Q],q=this.#z(X)?X.__staleWhileFetching:X;if(q===void 0||Z===void 0)continue;let J={value:q};if(this.#L&&this.#V){J.ttl=this.#L[Q];let V=y0.now()-this.#V[Q];J.start=Math.floor(Date.now()-V)}if(this.#F)J.size=this.#F[Q];$.unshift([Z,J])}return $}load($){this.clear();for(let[Q,Z]of $){if(Z.start){let X=Date.now()-Z.start;Z.start=y0.now()-X}this.set(Q,Z.value,Z)}}set($,Q,Z={}){if(Q===void 0)return this.delete($),this;let{ttl:X=this.ttl,start:q,noDisposeOnSet:J=this.noDisposeOnSet,sizeCalculation:V=this.sizeCalculation,status:Y}=Z,{noUpdateTTL:W=this.noUpdateTTL}=Z,H=this.#m($,Q,Z.size||0,V);if(this.maxEntrySize&&H>this.maxEntrySize){if(Y)Y.set="miss",Y.maxEntrySizeExceeded=!0;return this.#D($,"set"),this}let K=this.#H===0?void 0:this.#W.get($);if(K===void 0){if(K=this.#H===0?this.#A:this.#j.length!==0?this.#j.pop():this.#H===this.#Q?this.#u(!1):this.#H,this.#_[K]=$,this.#q[K]=Q,this.#W.set($,K),this.#O[this.#A]=K,this.#M[K]=this.#A,this.#A=K,this.#H++,this.#x(K,H,Y),Y)Y.set="add";if(W=!1,this.#b)this.#X?.(Q,$,"add")}else{this.#f(K);let G=this.#q[K];if(Q!==G){if(this.#T&&this.#z(G)){G.__abortController.abort(Error("replaced"));let{__staleWhileFetching:_}=G;if(_!==void 0&&!J){if(this.#K)this.#Z?.(_,$,"set");if(this.#B)this.#R?.push([_,$,"set"])}}else if(!J){if(this.#K)this.#Z?.(G,$,"set");if(this.#B)this.#R?.push([G,$,"set"])}if(this.#E(K),this.#x(K,H,Y),this.#q[K]=Q,Y){Y.set="replace";let _=G&&this.#z(G)?G.__staleWhileFetching:G;if(_!==void 0)Y.oldValue=_}}else if(Y)Y.set="update";if(this.#b)this.onInsert?.(Q,$,Q===G?"update":"replace")}if(X!==0&&!this.#L)this.#Y();if(this.#L){if(!W)this.#k(K,X,q);if(Y)this.#S(Y,K)}if(!J&&this.#B&&this.#R){let G=this.#R,_;while(_=G?.shift())this.#J?.(..._)}return this}pop(){try{while(this.#H){let $=this.#q[this.#U];if(this.#u(!0),this.#z($)){if($.__staleWhileFetching)return $.__staleWhileFetching}else if($!==void 0)return $}}finally{if(this.#B&&this.#R){let $=this.#R,Q;while(Q=$?.shift())this.#J?.(...Q)}}}#u($){let Q=this.#U,Z=this.#_[Q],X=this.#q[Q];if(this.#T&&this.#z(X))X.__abortController.abort(Error("evicted"));else if(this.#K||this.#B){if(this.#K)this.#Z?.(X,Z,"evict");if(this.#B)this.#R?.push([X,Z,"evict"])}if(this.#E(Q),$)this.#_[Q]=void 0,this.#q[Q]=void 0,this.#j.push(Q);if(this.#H===1)this.#U=this.#A=0,this.#j.length=0;else this.#U=this.#O[Q];return this.#W.delete(Z),this.#H--,Q}has($,Q={}){let{updateAgeOnHas:Z=this.updateAgeOnHas,status:X}=Q,q=this.#W.get($);if(q!==void 0){let J=this.#q[q];if(this.#z(J)&&J.__staleWhileFetching===void 0)return!1;if(!this.#w(q)){if(Z)this.#v(q);if(X)X.has="hit",this.#S(X,q);return!0}else if(X)X.has="stale",this.#S(X,q)}else if(X)X.has="miss";return!1}peek($,Q={}){let{allowStale:Z=this.allowStale}=Q,X=this.#W.get($);if(X===void 0||!Z&&this.#w(X))return;let q=this.#q[X];return this.#z(q)?q.__staleWhileFetching:q}#y($,Q,Z,X){let q=Q===void 0?void 0:this.#q[Q];if(this.#z(q))return q;let J=new O8,{signal:V}=Z;V?.addEventListener("abort",()=>J.abort(V.reason),{signal:J.signal});let Y={signal:J.signal,options:Z,context:X},W=(M,z=!1)=>{let{aborted:U}=J.signal,A=Z.ignoreFetchAbort&&M!==void 0;if(Z.status)if(U&&!z){if(Z.status.fetchAborted=!0,Z.status.fetchError=J.signal.reason,A)Z.status.fetchAbortIgnored=!0}else Z.status.fetchResolved=!0;if(U&&!A&&!z)return K(J.signal.reason);let B=_;if(this.#q[Q]===_)if(M===void 0)if(B.__staleWhileFetching)this.#q[Q]=B.__staleWhileFetching;else this.#D($,"fetch");else{if(Z.status)Z.status.fetchUpdated=!0;this.set($,M,Y.options)}return M},H=(M)=>{if(Z.status)Z.status.fetchRejected=!0,Z.status.fetchError=M;return K(M)},K=(M)=>{let{aborted:z}=J.signal,U=z&&Z.allowStaleOnFetchAbort,A=U||Z.allowStaleOnFetchRejection,B=A||Z.noDeleteOnFetchRejection,C=_;if(this.#q[Q]===_){if(!B||C.__staleWhileFetching===void 0)this.#D($,"fetch");else if(!U)this.#q[Q]=C.__staleWhileFetching}if(A){if(Z.status&&C.__staleWhileFetching!==void 0)Z.status.returnedStale=!0;return C.__staleWhileFetching}else if(C.__returned===C)throw M},G=(M,z)=>{let U=this.#I?.($,q,Y);if(U&&U instanceof Promise)U.then((A)=>M(A===void 0?void 0:A),z);J.signal.addEventListener("abort",()=>{if(!Z.ignoreFetchAbort||Z.allowStaleOnFetchAbort){if(M(void 0),Z.allowStaleOnFetchAbort)M=(A)=>W(A,!0)}})};if(Z.status)Z.status.fetchDispatched=!0;let _=new Promise(G).then(W,H),O=Object.assign(_,{__abortController:J,__staleWhileFetching:q,__returned:void 0});if(Q===void 0)this.set($,O,{...Y.options,status:void 0}),Q=this.#W.get($);else this.#q[Q]=O;return O}#z($){if(!this.#T)return!1;let Q=$;return!!Q&&Q instanceof Promise&&Q.hasOwnProperty("__staleWhileFetching")&&Q.__abortController instanceof O8}async fetch($,Q={}){let{allowStale:Z=this.allowStale,updateAgeOnGet:X=this.updateAgeOnGet,noDeleteOnStaleGet:q=this.noDeleteOnStaleGet,ttl:J=this.ttl,noDisposeOnSet:V=this.noDisposeOnSet,size:Y=0,sizeCalculation:W=this.sizeCalculation,noUpdateTTL:H=this.noUpdateTTL,noDeleteOnFetchRejection:K=this.noDeleteOnFetchRejection,allowStaleOnFetchRejection:G=this.allowStaleOnFetchRejection,ignoreFetchAbort:_=this.ignoreFetchAbort,allowStaleOnFetchAbort:O=this.allowStaleOnFetchAbort,context:M,forceRefresh:z=!1,status:U,signal:A}=Q;if(!this.#T){if(U)U.fetch="get";return this.get($,{allowStale:Z,updateAgeOnGet:X,noDeleteOnStaleGet:q,status:U})}let B={allowStale:Z,updateAgeOnGet:X,noDeleteOnStaleGet:q,ttl:J,noDisposeOnSet:V,size:Y,sizeCalculation:W,noUpdateTTL:H,noDeleteOnFetchRejection:K,allowStaleOnFetchRejection:G,allowStaleOnFetchAbort:O,ignoreFetchAbort:_,status:U,signal:A},C=this.#W.get($);if(C===void 0){if(U)U.fetch="miss";let T=this.#y($,C,B,M);return T.__returned=T}else{let T=this.#q[C];if(this.#z(T)){let Z0=Z&&T.__staleWhileFetching!==void 0;if(U){if(U.fetch="inflight",Z0)U.returnedStale=!0}return Z0?T.__staleWhileFetching:T.__returned=T}let p=this.#w(C);if(!z&&!p){if(U)U.fetch="hit";if(this.#f(C),X)this.#v(C);if(U)this.#S(U,C);return T}let x=this.#y($,C,B,M),b0=x.__staleWhileFetching!==void 0&&Z;if(U){if(U.fetch=p?"stale":"refresh",b0&&p)U.returnedStale=!0}return b0?x.__staleWhileFetching:x.__returned=x}}async forceFetch($,Q={}){let Z=await this.fetch($,Q);if(Z===void 0)throw Error("fetch() returned undefined");return Z}memo($,Q={}){let Z=this.#C;if(!Z)throw Error("no memoMethod provided to constructor");let{context:X,forceRefresh:q,...J}=Q,V=this.get($,J);if(!q&&V!==void 0)return V;let Y=Z($,V,{options:J,context:X});return this.set($,Y,J),Y}get($,Q={}){let{allowStale:Z=this.allowStale,updateAgeOnGet:X=this.updateAgeOnGet,noDeleteOnStaleGet:q=this.noDeleteOnStaleGet,status:J}=Q,V=this.#W.get($);if(V!==void 0){let Y=this.#q[V],W=this.#z(Y);if(J)this.#S(J,V);if(this.#w(V)){if(J)J.get="stale";if(!W){if(!q)this.#D($,"expire");if(J&&Z)J.returnedStale=!0;return Z?Y:void 0}else{if(J&&Z&&Y.__staleWhileFetching!==void 0)J.returnedStale=!0;return Z?Y.__staleWhileFetching:void 0}}else{if(J)J.get="hit";if(W)return Y.__staleWhileFetching;if(this.#f(V),X)this.#v(V);return Y}}else if(J)J.get="miss"}#l($,Q){this.#M[Q]=$,this.#O[$]=Q}#f($){if($!==this.#A){if($===this.#U)this.#U=this.#O[$];else this.#l(this.#M[$],this.#O[$]);this.#l(this.#A,$),this.#A=$}}delete($){return this.#D($,"delete")}#D($,Q){let Z=!1;if(this.#H!==0){let X=this.#W.get($);if(X!==void 0)if(Z=!0,this.#H===1)this.#h(Q);else{this.#E(X);let q=this.#q[X];if(this.#z(q))q.__abortController.abort(Error("deleted"));else if(this.#K||this.#B){if(this.#K)this.#Z?.(q,$,Q);if(this.#B)this.#R?.push([q,$,Q])}if(this.#W.delete($),this.#_[X]=void 0,this.#q[X]=void 0,X===this.#A)this.#A=this.#M[X];else if(X===this.#U)this.#U=this.#O[X];else{let J=this.#M[X];this.#O[J]=this.#O[X];let V=this.#O[X];this.#M[V]=this.#M[X]}this.#H--,this.#j.push(X)}}if(this.#B&&this.#R?.length){let X=this.#R,q;while(q=X?.shift())this.#J?.(...q)}return Z}clear(){return this.#h("delete")}#h($){for(let Q of this.#N({allowStale:!0})){let Z=this.#q[Q];if(this.#z(Z))Z.__abortController.abort(Error("deleted"));else{let X=this.#_[Q];if(this.#K)this.#Z?.(Z,X,$);if(this.#B)this.#R?.push([Z,X,$])}}if(this.#W.clear(),this.#q.fill(void 0),this.#_.fill(void 0),this.#L&&this.#V)this.#L.fill(0),this.#V.fill(0);if(this.#F)this.#F.fill(0);if(this.#U=0,this.#A=0,this.#j.length=0,this.#G=0,this.#H=0,this.#B&&this.#R){let Q=this.#R,Z;while(Z=Q?.shift())this.#J?.(...Z)}}}import{posix as v9,win32 as p$}from"node:path";import{fileURLToPath as E9}from"node:url";import{lstatSync as y9,readdir as x9,readdirSync as u9,readlinkSync as f9,realpathSync as h9}from"fs";import*as g9 from"node:fs";import{lstat as c9,readdir as l9,readlink as d9,realpath as p9}from"node:fs/promises";import{EventEmitter as m$}from"node:events";import y5 from"node:stream";import{StringDecoder as F9}from"node:string_decoder";var k5=typeof process==="object"&&process?process:{stdout:null,stderr:null},j9=($)=>!!$&&typeof $==="object"&&($ instanceof P0||$ instanceof y5||T9($)||S9($)),T9=($)=>!!$&&typeof $==="object"&&$ instanceof m$&&typeof $.pipe==="function"&&$.pipe!==y5.Writable.prototype.pipe,S9=($)=>!!$&&typeof $==="object"&&$ instanceof m$&&typeof $.write==="function"&&typeof $.end==="function",O0=Symbol("EOF"),A0=Symbol("maybeEmitEnd"),L0=Symbol("emittedEnd"),A8=Symbol("emittingEnd"),n0=Symbol("emittedError"),B8=Symbol("closed"),D5=Symbol("read"),R8=Symbol("flush"),v5=Symbol("flushChunk"),J0=Symbol("encoding"),u0=Symbol("decoder"),u=Symbol("flowing"),r0=Symbol("paused"),f0=Symbol("resume"),f=Symbol("buffer"),n=Symbol("pipes"),h=Symbol("bufferLength"),x$=Symbol("bufferPush"),C8=Symbol("bufferShift"),d=Symbol("objectMode"),v=Symbol("destroyed"),u$=Symbol("error"),f$=Symbol("emitData"),E5=Symbol("emitEnd"),h$=Symbol("emitEnd2"),H0=Symbol("async"),g$=Symbol("abort"),I8=Symbol("aborted"),s0=Symbol("signal"),w0=Symbol("dataListeners"),a=Symbol("discarded"),a0=($)=>Promise.resolve().then($),w9=($)=>$(),P9=($)=>$==="end"||$==="finish"||$==="prefinish",N9=($)=>$ instanceof ArrayBuffer||!!$&&typeof $==="object"&&$.constructor&&$.constructor.name==="ArrayBuffer"&&$.byteLength>=0,b9=($)=>!Buffer.isBuffer($)&&ArrayBuffer.isView($);class c${src;dest;opts;ondrain;constructor($,Q,Z){this.src=$,this.dest=Q,this.opts=Z,this.ondrain=()=>$[f0](),this.dest.on("drain",this.ondrain)}unpipe(){this.dest.removeListener("drain",this.ondrain)}proxyErrors($){}end(){if(this.unpipe(),this.opts.end)this.dest.end()}}class x5 extends c${unpipe(){this.src.removeListener("error",this.proxyErrors),super.unpipe()}constructor($,Q,Z){super($,Q,Z);this.proxyErrors=(X)=>Q.emit("error",X),$.on("error",this.proxyErrors)}}var k9=($)=>!!$.objectMode,D9=($)=>!$.objectMode&&!!$.encoding&&$.encoding!=="buffer";class P0 extends m${[u]=!1;[r0]=!1;[n]=[];[f]=[];[d];[J0];[H0];[u0];[O0]=!1;[L0]=!1;[A8]=!1;[B8]=!1;[n0]=null;[h]=0;[v]=!1;[s0];[I8]=!1;[w0]=0;[a]=!1;writable=!0;readable=!0;constructor(...$){let Q=$[0]||{};super();if(Q.objectMode&&typeof Q.encoding==="string")throw TypeError("Encoding and objectMode may not be used together");if(k9(Q))this[d]=!0,this[J0]=null;else if(D9(Q))this[J0]=Q.encoding,this[d]=!1;else this[d]=!1,this[J0]=null;if(this[H0]=!!Q.async,this[u0]=this[J0]?new F9(this[J0]):null,Q&&Q.debugExposeBuffer===!0)Object.defineProperty(this,"buffer",{get:()=>this[f]});if(Q&&Q.debugExposePipes===!0)Object.defineProperty(this,"pipes",{get:()=>this[n]});let{signal:Z}=Q;if(Z)if(this[s0]=Z,Z.aborted)this[g$]();else Z.addEventListener("abort",()=>this[g$]())}get bufferLength(){return this[h]}get encoding(){return this[J0]}set encoding($){throw Error("Encoding must be set at instantiation time")}setEncoding($){throw Error("Encoding must be set at instantiation time")}get objectMode(){return this[d]}set objectMode($){throw Error("objectMode must be set at instantiation time")}get["async"](){return this[H0]}set["async"]($){this[H0]=this[H0]||!!$}[g$](){this[I8]=!0,this.emit("abort",this[s0]?.reason),this.destroy(this[s0]?.reason)}get aborted(){return this[I8]}set aborted($){}write($,Q,Z){if(this[I8])return!1;if(this[O0])throw Error("write after end");if(this[v])return this.emit("error",Object.assign(Error("Cannot call write after a stream was destroyed"),{code:"ERR_STREAM_DESTROYED"})),!0;if(typeof Q==="function")Z=Q,Q="utf8";if(!Q)Q="utf8";let X=this[H0]?a0:w9;if(!this[d]&&!Buffer.isBuffer($)){if(b9($))$=Buffer.from($.buffer,$.byteOffset,$.byteLength);else if(N9($))$=Buffer.from($);else if(typeof $!=="string")throw Error("Non-contiguous data written to non-objectMode stream")}if(this[d]){if(this[u]&&this[h]!==0)this[R8](!0);if(this[u])this.emit("data",$);else this[x$]($);if(this[h]!==0)this.emit("readable");if(Z)X(Z);return this[u]}if(!$.length){if(this[h]!==0)this.emit("readable");if(Z)X(Z);return this[u]}if(typeof $==="string"&&!(Q===this[J0]&&!this[u0]?.lastNeed))$=Buffer.from($,Q);if(Buffer.isBuffer($)&&this[J0])$=this[u0].write($);if(this[u]&&this[h]!==0)this[R8](!0);if(this[u])this.emit("data",$);else this[x$]($);if(this[h]!==0)this.emit("readable");if(Z)X(Z);return this[u]}read($){if(this[v])return null;if(this[a]=!1,this[h]===0||$===0||$&&$>this[h])return this[A0](),null;if(this[d])$=null;if(this[f].length>1&&!this[d])this[f]=[this[J0]?this[f].join(""):Buffer.concat(this[f],this[h])];let Q=this[D5]($||null,this[f][0]);return this[A0](),Q}[D5]($,Q){if(this[d])this[C8]();else{let Z=Q;if($===Z.length||$===null)this[C8]();else if(typeof Z==="string")this[f][0]=Z.slice($),Q=Z.slice(0,$),this[h]-=$;else this[f][0]=Z.subarray($),Q=Z.subarray(0,$),this[h]-=$}if(this.emit("data",Q),!this[f].length&&!this[O0])this.emit("drain");return Q}end($,Q,Z){if(typeof $==="function")Z=$,$=void 0;if(typeof Q==="function")Z=Q,Q="utf8";if($!==void 0)this.write($,Q);if(Z)this.once("end",Z);if(this[O0]=!0,this.writable=!1,this[u]||!this[r0])this[A0]();return this}[f0](){if(this[v])return;if(!this[w0]&&!this[n].length)this[a]=!0;if(this[r0]=!1,this[u]=!0,this.emit("resume"),this[f].length)this[R8]();else if(this[O0])this[A0]();else this.emit("drain")}resume(){return this[f0]()}pause(){this[u]=!1,this[r0]=!0,this[a]=!1}get destroyed(){return this[v]}get flowing(){return this[u]}get paused(){return this[r0]}[x$]($){if(this[d])this[h]+=1;else this[h]+=$.length;this[f].push($)}[C8](){if(this[d])this[h]-=1;else this[h]-=this[f][0].length;return this[f].shift()}[R8]($=!1){do;while(this[v5](this[C8]())&&this[f].length);if(!$&&!this[f].length&&!this[O0])this.emit("drain")}[v5]($){return this.emit("data",$),this[u]}pipe($,Q){if(this[v])return $;this[a]=!1;let Z=this[L0];if(Q=Q||{},$===k5.stdout||$===k5.stderr)Q.end=!1;else Q.end=Q.end!==!1;if(Q.proxyErrors=!!Q.proxyErrors,Z){if(Q.end)$.end()}else if(this[n].push(!Q.proxyErrors?new c$(this,$,Q):new x5(this,$,Q)),this[H0])a0(()=>this[f0]());else this[f0]();return $}unpipe($){let Q=this[n].find((Z)=>Z.dest===$);if(Q){if(this[n].length===1){if(this[u]&&this[w0]===0)this[u]=!1;this[n]=[]}else this[n].splice(this[n].indexOf(Q),1);Q.unpipe()}}addListener($,Q){return this.on($,Q)}on($,Q){let Z=super.on($,Q);if($==="data"){if(this[a]=!1,this[w0]++,!this[n].length&&!this[u])this[f0]()}else if($==="readable"&&this[h]!==0)super.emit("readable");else if(P9($)&&this[L0])super.emit($),this.removeAllListeners($);else if($==="error"&&this[n0]){let X=Q;if(this[H0])a0(()=>X.call(this,this[n0]));else X.call(this,this[n0])}return Z}removeListener($,Q){return this.off($,Q)}off($,Q){let Z=super.off($,Q);if($==="data"){if(this[w0]=this.listeners("data").length,this[w0]===0&&!this[a]&&!this[n].length)this[u]=!1}return Z}removeAllListeners($){let Q=super.removeAllListeners($);if($==="data"||$===void 0){if(this[w0]=0,!this[a]&&!this[n].length)this[u]=!1}return Q}get emittedEnd(){return this[L0]}[A0](){if(!this[A8]&&!this[L0]&&!this[v]&&this[f].length===0&&this[O0]){if(this[A8]=!0,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[B8])this.emit("close");this[A8]=!1}}emit($,...Q){let Z=Q[0];if($!=="error"&&$!=="close"&&$!==v&&this[v])return!1;else if($==="data")return!this[d]&&!Z?!1:this[H0]?(a0(()=>this[f$](Z)),!0):this[f$](Z);else if($==="end")return this[E5]();else if($==="close"){if(this[B8]=!0,!this[L0]&&!this[v])return!1;let q=super.emit("close");return this.removeAllListeners("close"),q}else if($==="error"){this[n0]=Z,super.emit(u$,Z);let q=!this[s0]||this.listeners("error").length?super.emit("error",Z):!1;return this[A0](),q}else if($==="resume"){let q=super.emit("resume");return this[A0](),q}else if($==="finish"||$==="prefinish"){let q=super.emit($);return this.removeAllListeners($),q}let X=super.emit($,...Q);return this[A0](),X}[f$]($){for(let Z of this[n])if(Z.dest.write($)===!1)this.pause();let Q=this[a]?!1:super.emit("data",$);return this[A0](),Q}[E5](){if(this[L0])return!1;return this[L0]=!0,this.readable=!1,this[H0]?(a0(()=>this[h$]()),!0):this[h$]()}[h$](){if(this[u0]){let Q=this[u0].end();if(Q){for(let Z of this[n])Z.dest.write(Q);if(!this[a])super.emit("data",Q)}}for(let Q of this[n])Q.end();let $=super.emit("end");return this.removeAllListeners("end"),$}async collect(){let $=Object.assign([],{dataLength:0});if(!this[d])$.dataLength=0;let Q=this.promise();return this.on("data",(Z)=>{if($.push(Z),!this[d])$.dataLength+=Z.length}),await Q,$}async concat(){if(this[d])throw Error("cannot concat in objectMode");let $=await this.collect();return this[J0]?$.join(""):Buffer.concat($,$.dataLength)}async promise(){return new Promise(($,Q)=>{this.on(v,()=>Q(Error("stream destroyed"))),this.on("error",(Z)=>Q(Z)),this.on("end",()=>$())})}[Symbol.asyncIterator](){this[a]=!1;let $=!1,Q=async()=>{return this.pause(),$=!0,{value:void 0,done:!0}};return{next:()=>{if($)return Q();let X=this.read();if(X!==null)return Promise.resolve({done:!1,value:X});if(this[O0])return Q();let q,J,V=(K)=>{this.off("data",Y),this.off("end",W),this.off(v,H),Q(),J(K)},Y=(K)=>{this.off("error",V),this.off("end",W),this.off(v,H),this.pause(),q({value:K,done:!!this[O0]})},W=()=>{this.off("error",V),this.off("data",Y),this.off(v,H),Q(),q({done:!0,value:void 0})},H=()=>V(Error("stream destroyed"));return new Promise((K,G)=>{J=G,q=K,this.once(v,H),this.once("error",V),this.once("end",W),this.once("data",Y)})},throw:Q,return:Q,[Symbol.asyncIterator](){return this}}}[Symbol.iterator](){this[a]=!1;let $=!1,Q=()=>{return this.pause(),this.off(u$,Q),this.off(v,Q),this.off("end",Q),$=!0,{done:!0,value:void 0}},Z=()=>{if($)return Q();let X=this.read();return X===null?Q():{done:!1,value:X}};return this.once("end",Q),this.once(u$,Q),this.once(v,Q),{next:Z,throw:Q,return:Q,[Symbol.iterator](){return this}}}destroy($){if(this[v]){if($)this.emit("error",$);else this.emit(v);return this}this[v]=!0,this[a]=!0,this[f].length=0,this[h]=0;let Q=this;if(typeof Q.close==="function"&&!this[B8])Q.close();if($)this.emit("error",$);else this.emit(v);return this}static get isStream(){return j9}}var m9=h9.native,t0={lstatSync:y9,readdir:x9,readdirSync:u9,readlinkSync:f9,realpathSync:m9,promises:{lstat:c9,readdir:l9,readlink:d9,realpath:p9}},m5=($)=>!$||$===t0||$===g9?t0:{...t0,...$,promises:{...t0.promises,...$.promises||{}}},c5=/^\\\\\?\\([a-z]:)\\?$/i,i9=($)=>$.replace(/\//g,"\\").replace(c5,"$1\\"),n9=/[\\\/]/,$0=0,l5=1,d5=2,K0=4,p5=6,i5=8,N0=10,n5=12,e=15,o0=~e,l$=16,u5=32,e0=64,Y0=128,L8=256,j8=512,f5=e0|Y0|j8,r9=1023,d$=($)=>$.isFile()?i5:$.isDirectory()?K0:$.isSymbolicLink()?N0:$.isCharacterDevice()?d5:$.isBlockDevice()?p5:$.isSocket()?n5:$.isFIFO()?l5:$0,h5=new Map,$8=($)=>{let Q=h5.get($);if(Q)return Q;let Z=$.normalize("NFKD");return h5.set($,Z),Z},g5=new Map,F8=($)=>{let Q=g5.get($);if(Q)return Q;let Z=$8($.toLowerCase());return g5.set($,Z),Z};class i$ extends i0{constructor(){super({max:256})}}class r5 extends i0{constructor($=16384){super({maxSize:$,sizeCalculation:(Q)=>Q.length+1})}}var s5=Symbol("PathScurry setAsCwd");class r{name;root;roots;parent;nocase;isCWD=!1;#Q;#$;get dev(){return this.#$}#Z;get mode(){return this.#Z}#X;get nlink(){return this.#X}#J;get uid(){return this.#J}#I;get gid(){return this.#I}#C;get rdev(){return this.#C}#H;get blksize(){return this.#H}#G;get ino(){return this.#G}#W;get size(){return this.#W}#_;get blocks(){return this.#_}#q;get atimeMs(){return this.#q}#O;get mtimeMs(){return this.#O}#M;get ctimeMs(){return this.#M}#U;get birthtimeMs(){return this.#U}#A;get atime(){return this.#A}#j;get mtime(){return this.#j}#R;get ctime(){return this.#R}#F;get birthtime(){return this.#F}#V;#L;#K;#T;#B;#b;#Y;#v;#S;#k;get parentPath(){return(this.parent||this).fullpath()}get path(){return this.parentPath}constructor($,Q=$0,Z,X,q,J,V){if(this.name=$,this.#V=q?F8($):$8($),this.#Y=Q&r9,this.nocase=q,this.roots=X,this.root=Z||this,this.#v=J,this.#K=V.fullpath,this.#B=V.relative,this.#b=V.relativePosix,this.parent=V.parent,this.parent)this.#Q=this.parent.#Q;else this.#Q=m5(V.fs)}depth(){if(this.#L!==void 0)return this.#L;if(!this.parent)return this.#L=0;return this.#L=this.parent.depth()+1}childrenCache(){return this.#v}resolve($){if(!$)return this;let Q=this.getRootString($),X=$.substring(Q.length).split(this.splitSep);return Q?this.getRoot(Q).#w(X):this.#w(X)}#w($){let Q=this;for(let Z of $)Q=Q.child(Z);return Q}children(){let $=this.#v.get(this);if($)return $;let Q=Object.assign([],{provisional:0});return this.#v.set(this,Q),this.#Y&=~l$,Q}child($,Q){if($===""||$===".")return this;if($==="..")return this.parent||this;let Z=this.children(),X=this.nocase?F8($):$8($);for(let Y of Z)if(Y.#V===X)return Y;let q=this.parent?this.sep:"",J=this.#K?this.#K+q+$:void 0,V=this.newChild($,$0,{...Q,parent:this,fullpath:J});if(!this.canReaddir())V.#Y|=Y0;return Z.push(V),V}relative(){if(this.isCWD)return"";if(this.#B!==void 0)return this.#B;let $=this.name,Q=this.parent;if(!Q)return this.#B=this.name;let Z=Q.relative();return Z+(!Z||!Q.parent?"":this.sep)+$}relativePosix(){if(this.sep==="/")return this.relative();if(this.isCWD)return"";if(this.#b!==void 0)return this.#b;let $=this.name,Q=this.parent;if(!Q)return this.#b=this.fullpathPosix();let Z=Q.relativePosix();return Z+(!Z||!Q.parent?"":"/")+$}fullpath(){if(this.#K!==void 0)return this.#K;let $=this.name,Q=this.parent;if(!Q)return this.#K=this.name;let X=Q.fullpath()+(!Q.parent?"":this.sep)+$;return this.#K=X}fullpathPosix(){if(this.#T!==void 0)return this.#T;if(this.sep==="/")return this.#T=this.fullpath();if(!this.parent){let X=this.fullpath().replace(/\\/g,"/");if(/^[a-z]:\//i.test(X))return this.#T=`//?/${X}`;else return this.#T=X}let $=this.parent,Q=$.fullpathPosix(),Z=Q+(!Q||!$.parent?"":"/")+this.name;return this.#T=Z}isUnknown(){return(this.#Y&e)===$0}isType($){return this[`is${$}`]()}getType(){return this.isUnknown()?"Unknown":this.isDirectory()?"Directory":this.isFile()?"File":this.isSymbolicLink()?"SymbolicLink":this.isFIFO()?"FIFO":this.isCharacterDevice()?"CharacterDevice":this.isBlockDevice()?"BlockDevice":this.isSocket()?"Socket":"Unknown"}isFile(){return(this.#Y&e)===i5}isDirectory(){return(this.#Y&e)===K0}isCharacterDevice(){return(this.#Y&e)===d5}isBlockDevice(){return(this.#Y&e)===p5}isFIFO(){return(this.#Y&e)===l5}isSocket(){return(this.#Y&e)===n5}isSymbolicLink(){return(this.#Y&N0)===N0}lstatCached(){return this.#Y&u5?this:void 0}readlinkCached(){return this.#S}realpathCached(){return this.#k}readdirCached(){let $=this.children();return $.slice(0,$.provisional)}canReadlink(){if(this.#S)return!0;if(!this.parent)return!1;let $=this.#Y&e;return!($!==$0&&$!==N0||this.#Y&L8||this.#Y&Y0)}calledReaddir(){return!!(this.#Y&l$)}isENOENT(){return!!(this.#Y&Y0)}isNamed($){return!this.nocase?this.#V===$8($):this.#V===F8($)}async readlink(){let $=this.#S;if($)return $;if(!this.canReadlink())return;if(!this.parent)return;try{let Q=await this.#Q.promises.readlink(this.fullpath()),Z=(await this.parent.realpath())?.resolve(Q);if(Z)return this.#S=Z}catch(Q){this.#u(Q.code);return}}readlinkSync(){let $=this.#S;if($)return $;if(!this.canReadlink())return;if(!this.parent)return;try{let Q=this.#Q.readlinkSync(this.fullpath()),Z=this.parent.realpathSync()?.resolve(Q);if(Z)return this.#S=Z}catch(Q){this.#u(Q.code);return}}#g($){this.#Y|=l$;for(let Q=$.provisional;Q<$.length;Q++){let Z=$[Q];if(Z)Z.#E()}}#E(){if(this.#Y&Y0)return;this.#Y=(this.#Y|Y0)&o0,this.#x()}#x(){let $=this.children();$.provisional=0;for(let Q of $)Q.#E()}#m(){this.#Y|=j8,this.#P()}#P(){if(this.#Y&e0)return;let $=this.#Y;if(($&e)===K0)$&=o0;this.#Y=$|e0,this.#x()}#N($=""){if($==="ENOTDIR"||$==="EPERM")this.#P();else if($==="ENOENT")this.#E();else this.children().provisional=0}#c($=""){if($==="ENOTDIR")this.parent.#P();else if($==="ENOENT")this.#E()}#u($=""){let Q=this.#Y;if(Q|=L8,$==="ENOENT")Q|=Y0;if($==="EINVAL"||$==="UNKNOWN")Q&=o0;if(this.#Y=Q,$==="ENOTDIR"&&this.parent)this.parent.#P()}#y($,Q){return this.#l($,Q)||this.#z($,Q)}#z($,Q){let Z=d$($),X=this.newChild($.name,Z,{parent:this}),q=X.#Y&e;if(q!==K0&&q!==N0&&q!==$0)X.#Y|=e0;return Q.unshift(X),Q.provisional++,X}#l($,Q){for(let Z=Q.provisional;Z<Q.length;Z++){let X=Q[Z];if((this.nocase?F8($.name):$8($.name))!==X.#V)continue;return this.#f($,X,Z,Q)}}#f($,Q,Z,X){let q=Q.name;if(Q.#Y=Q.#Y&o0|d$($),q!==$.name)Q.name=$.name;if(Z!==X.provisional){if(Z===X.length-1)X.pop();else X.splice(Z,1);X.unshift(Q)}return X.provisional++,Q}async lstat(){if((this.#Y&Y0)===0)try{return this.#D(await this.#Q.promises.lstat(this.fullpath())),this}catch($){this.#c($.code)}}lstatSync(){if((this.#Y&Y0)===0)try{return this.#D(this.#Q.lstatSync(this.fullpath())),this}catch($){this.#c($.code)}}#D($){let{atime:Q,atimeMs:Z,birthtime:X,birthtimeMs:q,blksize:J,blocks:V,ctime:Y,ctimeMs:W,dev:H,gid:K,ino:G,mode:_,mtime:O,mtimeMs:M,nlink:z,rdev:U,size:A,uid:B}=$;this.#A=Q,this.#q=Z,this.#F=X,this.#U=q,this.#H=J,this.#_=V,this.#R=Y,this.#M=W,this.#$=H,this.#I=K,this.#G=G,this.#Z=_,this.#j=O,this.#O=M,this.#X=z,this.#C=U,this.#W=A,this.#J=B;let C=d$($);if(this.#Y=this.#Y&o0|C|u5,C!==$0&&C!==K0&&C!==N0)this.#Y|=e0}#h=[];#p=!1;#i($){this.#p=!1;let Q=this.#h.slice();this.#h.length=0,Q.forEach((Z)=>Z(null,$))}readdirCB($,Q=!1){if(!this.canReaddir()){if(Q)$(null,[]);else queueMicrotask(()=>$(null,[]));return}let Z=this.children();if(this.calledReaddir()){let q=Z.slice(0,Z.provisional);if(Q)$(null,q);else queueMicrotask(()=>$(null,q));return}if(this.#h.push($),this.#p)return;this.#p=!0;let X=this.fullpath();this.#Q.readdir(X,{withFileTypes:!0},(q,J)=>{if(q)this.#N(q.code),Z.provisional=0;else{for(let V of J)this.#y(V,Z);this.#g(Z)}this.#i(Z.slice(0,Z.provisional));return})}#d;async readdir(){if(!this.canReaddir())return[];let $=this.children();if(this.calledReaddir())return $.slice(0,$.provisional);let Q=this.fullpath();if(this.#d)await this.#d;else{let Z=()=>{};this.#d=new Promise((X)=>Z=X);try{for(let X of await this.#Q.promises.readdir(Q,{withFileTypes:!0}))this.#y(X,$);this.#g($)}catch(X){this.#N(X.code),$.provisional=0}this.#d=void 0,Z()}return $.slice(0,$.provisional)}readdirSync(){if(!this.canReaddir())return[];let $=this.children();if(this.calledReaddir())return $.slice(0,$.provisional);let Q=this.fullpath();try{for(let Z of this.#Q.readdirSync(Q,{withFileTypes:!0}))this.#y(Z,$);this.#g($)}catch(Z){this.#N(Z.code),$.provisional=0}return $.slice(0,$.provisional)}canReaddir(){if(this.#Y&f5)return!1;let $=e&this.#Y;if(!($===$0||$===K0||$===N0))return!1;return!0}shouldWalk($,Q){return(this.#Y&K0)===K0&&!(this.#Y&f5)&&!$.has(this)&&(!Q||Q(this))}async realpath(){if(this.#k)return this.#k;if((j8|L8|Y0)&this.#Y)return;try{let $=await this.#Q.promises.realpath(this.fullpath());return this.#k=this.resolve($)}catch($){this.#m()}}realpathSync(){if(this.#k)return this.#k;if((j8|L8|Y0)&this.#Y)return;try{let $=this.#Q.realpathSync(this.fullpath());return this.#k=this.resolve($)}catch($){this.#m()}}[s5]($){if($===this)return;$.isCWD=!1,this.isCWD=!0;let Q=new Set([]),Z=[],X=this;while(X&&X.parent)Q.add(X),X.#B=Z.join(this.sep),X.#b=Z.join("/"),X=X.parent,Z.push("..");X=$;while(X&&X.parent&&!Q.has(X))X.#B=void 0,X.#b=void 0,X=X.parent}}class T8 extends r{sep="\\";splitSep=n9;constructor($,Q=$0,Z,X,q,J,V){super($,Q,Z,X,q,J,V)}newChild($,Q=$0,Z={}){return new T8($,Q,this.root,this.roots,this.nocase,this.childrenCache(),Z)}getRootString($){return p$.parse($).root}getRoot($){if($=i9($.toUpperCase()),$===this.root.name)return this.root;for(let[Q,Z]of Object.entries(this.roots))if(this.sameRoot($,Q))return this.roots[$]=Z;return this.roots[$]=new Q8($,this).root}sameRoot($,Q=this.root.name){return $=$.toUpperCase().replace(/\//g,"\\").replace(c5,"$1\\"),$===Q}}class S8 extends r{splitSep="/";sep="/";constructor($,Q=$0,Z,X,q,J,V){super($,Q,Z,X,q,J,V)}getRootString($){return $.startsWith("/")?"/":""}getRoot($){return this.root}newChild($,Q=$0,Z={}){return new S8($,Q,this.root,this.roots,this.nocase,this.childrenCache(),Z)}}class n${root;rootPath;roots;cwd;#Q;#$;#Z;nocase;#X;constructor($=process.cwd(),Q,Z,{nocase:X,childrenCacheSize:q=16384,fs:J=t0}={}){if(this.#X=m5(J),$ instanceof URL||$.startsWith("file://"))$=E9($);let V=Q.resolve($);this.roots=Object.create(null),this.rootPath=this.parseRootPath(V),this.#Q=new i$,this.#$=new i$,this.#Z=new r5(q);let Y=V.substring(this.rootPath.length).split(Z);if(Y.length===1&&!Y[0])Y.pop();if(X===void 0)throw TypeError("must provide nocase setting to PathScurryBase ctor");this.nocase=X,this.root=this.newRoot(this.#X),this.roots[this.rootPath]=this.root;let W=this.root,H=Y.length-1,K=Q.sep,G=this.rootPath,_=!1;for(let O of Y){let M=H--;W=W.child(O,{relative:Array(M).fill("..").join(K),relativePosix:Array(M).fill("..").join("/"),fullpath:G+=(_?"":K)+O}),_=!0}this.cwd=W}depth($=this.cwd){if(typeof $==="string")$=this.cwd.resolve($);return $.depth()}childrenCache(){return this.#Z}resolve(...$){let Q="";for(let q=$.length-1;q>=0;q--){let J=$[q];if(!J||J===".")continue;if(Q=Q?`${J}/${Q}`:J,this.isAbsolute(J))break}let Z=this.#Q.get(Q);if(Z!==void 0)return Z;let X=this.cwd.resolve(Q).fullpath();return this.#Q.set(Q,X),X}resolvePosix(...$){let Q="";for(let q=$.length-1;q>=0;q--){let J=$[q];if(!J||J===".")continue;if(Q=Q?`${J}/${Q}`:J,this.isAbsolute(J))break}let Z=this.#$.get(Q);if(Z!==void 0)return Z;let X=this.cwd.resolve(Q).fullpathPosix();return this.#$.set(Q,X),X}relative($=this.cwd){if(typeof $==="string")$=this.cwd.resolve($);return $.relative()}relativePosix($=this.cwd){if(typeof $==="string")$=this.cwd.resolve($);return $.relativePosix()}basename($=this.cwd){if(typeof $==="string")$=this.cwd.resolve($);return $.name}dirname($=this.cwd){if(typeof $==="string")$=this.cwd.resolve($);return($.parent||$).fullpath()}async readdir($=this.cwd,Q={withFileTypes:!0}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$,$=this.cwd;let{withFileTypes:Z}=Q;if(!$.canReaddir())return[];else{let X=await $.readdir();return Z?X:X.map((q)=>q.name)}}readdirSync($=this.cwd,Q={withFileTypes:!0}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$,$=this.cwd;let{withFileTypes:Z=!0}=Q;if(!$.canReaddir())return[];else if(Z)return $.readdirSync();else return $.readdirSync().map((X)=>X.name)}async lstat($=this.cwd){if(typeof $==="string")$=this.cwd.resolve($);return $.lstat()}lstatSync($=this.cwd){if(typeof $==="string")$=this.cwd.resolve($);return $.lstatSync()}async readlink($=this.cwd,{withFileTypes:Q}={withFileTypes:!1}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$.withFileTypes,$=this.cwd;let Z=await $.readlink();return Q?Z:Z?.fullpath()}readlinkSync($=this.cwd,{withFileTypes:Q}={withFileTypes:!1}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$.withFileTypes,$=this.cwd;let Z=$.readlinkSync();return Q?Z:Z?.fullpath()}async realpath($=this.cwd,{withFileTypes:Q}={withFileTypes:!1}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$.withFileTypes,$=this.cwd;let Z=await $.realpath();return Q?Z:Z?.fullpath()}realpathSync($=this.cwd,{withFileTypes:Q}={withFileTypes:!1}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$.withFileTypes,$=this.cwd;let Z=$.realpathSync();return Q?Z:Z?.fullpath()}async walk($=this.cwd,Q={}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$,$=this.cwd;let{withFileTypes:Z=!0,follow:X=!1,filter:q,walkFilter:J}=Q,V=[];if(!q||q($))V.push(Z?$:$.fullpath());let Y=new Set,W=(K,G)=>{Y.add(K),K.readdirCB((_,O)=>{if(_)return G(_);let M=O.length;if(!M)return G();let z=()=>{if(--M===0)G()};for(let U of O){if(!q||q(U))V.push(Z?U:U.fullpath());if(X&&U.isSymbolicLink())U.realpath().then((A)=>A?.isUnknown()?A.lstat():A).then((A)=>A?.shouldWalk(Y,J)?W(A,z):z());else if(U.shouldWalk(Y,J))W(U,z);else z()}},!0)},H=$;return new Promise((K,G)=>{W(H,(_)=>{if(_)return G(_);K(V)})})}walkSync($=this.cwd,Q={}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$,$=this.cwd;let{withFileTypes:Z=!0,follow:X=!1,filter:q,walkFilter:J}=Q,V=[];if(!q||q($))V.push(Z?$:$.fullpath());let Y=new Set([$]);for(let W of Y){let H=W.readdirSync();for(let K of H){if(!q||q(K))V.push(Z?K:K.fullpath());let G=K;if(K.isSymbolicLink()){if(!(X&&(G=K.realpathSync())))continue;if(G.isUnknown())G.lstatSync()}if(G.shouldWalk(Y,J))Y.add(G)}}return V}[Symbol.asyncIterator](){return this.iterate()}iterate($=this.cwd,Q={}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$,$=this.cwd;return this.stream($,Q)[Symbol.asyncIterator]()}[Symbol.iterator](){return this.iterateSync()}*iterateSync($=this.cwd,Q={}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$,$=this.cwd;let{withFileTypes:Z=!0,follow:X=!1,filter:q,walkFilter:J}=Q;if(!q||q($))yield Z?$:$.fullpath();let V=new Set([$]);for(let Y of V){let W=Y.readdirSync();for(let H of W){if(!q||q(H))yield Z?H:H.fullpath();let K=H;if(H.isSymbolicLink()){if(!(X&&(K=H.realpathSync())))continue;if(K.isUnknown())K.lstatSync()}if(K.shouldWalk(V,J))V.add(K)}}}stream($=this.cwd,Q={}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$,$=this.cwd;let{withFileTypes:Z=!0,follow:X=!1,filter:q,walkFilter:J}=Q,V=new P0({objectMode:!0});if(!q||q($))V.write(Z?$:$.fullpath());let Y=new Set,W=[$],H=0,K=()=>{let G=!1;while(!G){let _=W.shift();if(!_){if(H===0)V.end();return}H++,Y.add(_);let O=(z,U,A=!1)=>{if(z)return V.emit("error",z);if(X&&!A){let B=[];for(let C of U)if(C.isSymbolicLink())B.push(C.realpath().then((T)=>T?.isUnknown()?T.lstat():T));if(B.length){Promise.all(B).then(()=>O(null,U,!0));return}}for(let B of U)if(B&&(!q||q(B))){if(!V.write(Z?B:B.fullpath()))G=!0}H--;for(let B of U){let C=B.realpathCached()||B;if(C.shouldWalk(Y,J))W.push(C)}if(G&&!V.flowing)V.once("drain",K);else if(!M)K()},M=!0;_.readdirCB(O,!0),M=!1}};return K(),V}streamSync($=this.cwd,Q={}){if(typeof $==="string")$=this.cwd.resolve($);else if(!($ instanceof r))Q=$,$=this.cwd;let{withFileTypes:Z=!0,follow:X=!1,filter:q,walkFilter:J}=Q,V=new P0({objectMode:!0}),Y=new Set;if(!q||q($))V.write(Z?$:$.fullpath());let W=[$],H=0,K=()=>{let G=!1;while(!G){let _=W.shift();if(!_){if(H===0)V.end();return}H++,Y.add(_);let O=_.readdirSync();for(let M of O)if(!q||q(M)){if(!V.write(Z?M:M.fullpath()))G=!0}H--;for(let M of O){let z=M;if(M.isSymbolicLink()){if(!(X&&(z=M.realpathSync())))continue;if(z.isUnknown())z.lstatSync()}if(z.shouldWalk(Y,J))W.push(z)}}if(G&&!V.flowing)V.once("drain",K)};return K(),V}chdir($=this.cwd){let Q=this.cwd;this.cwd=typeof $==="string"?this.cwd.resolve($):$,this.cwd[s5](Q)}}class Q8 extends n${sep="\\";constructor($=process.cwd(),Q={}){let{nocase:Z=!0}=Q;super($,p$,"\\",{...Q,nocase:Z});this.nocase=Z;for(let X=this.cwd;X;X=X.parent)X.nocase=this.nocase}parseRootPath($){return p$.parse($).root.toUpperCase()}newRoot($){return new T8(this.rootPath,K0,void 0,this.roots,this.nocase,this.childrenCache(),{fs:$})}isAbsolute($){return $.startsWith("/")||$.startsWith("\\")||/^[a-z]:(\/|\\)/i.test($)}}class Z8 extends n${sep="/";constructor($=process.cwd(),Q={}){let{nocase:Z=!1}=Q;super($,v9,"/",{...Q,nocase:Z});this.nocase=Z}parseRootPath($){return"/"}newRoot($){return new S8(this.rootPath,K0,void 0,this.roots,this.nocase,this.childrenCache(),{fs:$})}isAbsolute($){return $.startsWith("/")}}class w8 extends Z8{constructor($=process.cwd(),Q={}){let{nocase:Z=!0}=Q;super($,{...Q,nocase:Z})}}var XX=process.platform==="win32"?T8:S8,a5=process.platform==="win32"?Q8:process.platform==="darwin"?w8:Z8;var s9=($)=>$.length>=1,a9=($)=>$.length>=1;class h0{#Q;#$;#Z;length;#X;#J;#I;#C;#H;#G;#W=!0;constructor($,Q,Z,X){if(!s9($))throw TypeError("empty pattern list");if(!a9(Q))throw TypeError("empty glob list");if(Q.length!==$.length)throw TypeError("mismatched pattern list and glob list lengths");if(this.length=$.length,Z<0||Z>=this.length)throw TypeError("index out of range");if(this.#Q=$,this.#$=Q,this.#Z=Z,this.#X=X,this.#Z===0){if(this.isUNC()){let[q,J,V,Y,...W]=this.#Q,[H,K,G,_,...O]=this.#$;if(W[0]==="")W.shift(),O.shift();let M=[q,J,V,Y,""].join("/"),z=[H,K,G,_,""].join("/");this.#Q=[M,...W],this.#$=[z,...O],this.length=this.#Q.length}else if(this.isDrive()||this.isAbsolute()){let[q,...J]=this.#Q,[V,...Y]=this.#$;if(J[0]==="")J.shift(),Y.shift();let W=q+"/",H=V+"/";this.#Q=[W,...J],this.#$=[H,...Y],this.length=this.#Q.length}}}pattern(){return this.#Q[this.#Z]}isString(){return typeof this.#Q[this.#Z]==="string"}isGlobstar(){return this.#Q[this.#Z]===m}isRegExp(){return this.#Q[this.#Z]instanceof RegExp}globString(){return this.#I=this.#I||(this.#Z===0?this.isAbsolute()?this.#$[0]+this.#$.slice(1).join("/"):this.#$.join("/"):this.#$.slice(this.#Z).join("/"))}hasMore(){return this.length>this.#Z+1}rest(){if(this.#J!==void 0)return this.#J;if(!this.hasMore())return this.#J=null;return this.#J=new h0(this.#Q,this.#$,this.#Z+1,this.#X),this.#J.#G=this.#G,this.#J.#H=this.#H,this.#J.#C=this.#C,this.#J}isUNC(){let $=this.#Q;return this.#H!==void 0?this.#H:this.#H=this.#X==="win32"&&this.#Z===0&&$[0]===""&&$[1]===""&&typeof $[2]==="string"&&!!$[2]&&typeof $[3]==="string"&&!!$[3]}isDrive(){let $=this.#Q;return this.#C!==void 0?this.#C:this.#C=this.#X==="win32"&&this.#Z===0&&this.length>1&&typeof $[0]==="string"&&/^[a-z]:$/i.test($[0])}isAbsolute(){let $=this.#Q;return this.#G!==void 0?this.#G:this.#G=$[0]===""&&$.length>1||this.isDrive()||this.isUNC()}root(){let $=this.#Q[0];return typeof $==="string"&&this.isAbsolute()&&this.#Z===0?$:""}checkFollowGlobstar(){return!(this.#Z===0||!this.isGlobstar()||!this.#W)}markFollowGlobstar(){if(this.#Z===0||!this.isGlobstar()||!this.#W)return!1;return this.#W=!1,!0}}var o9=typeof process==="object"&&process&&typeof process.platform==="string"?process.platform:"linux";class X8{relative;relativeChildren;absolute;absoluteChildren;platform;mmopts;constructor($,{nobrace:Q,nocase:Z,noext:X,noglobstar:q,platform:J=o9}){this.relative=[],this.absolute=[],this.relativeChildren=[],this.absoluteChildren=[],this.platform=J,this.mmopts={dot:!0,nobrace:Q,nocase:Z,noext:X,noglobstar:q,optimizationLevel:2,platform:J,nocomment:!0,nonegate:!0};for(let V of $)this.add(V)}add($){let Q=new t($,this.mmopts);for(let Z=0;Z<Q.set.length;Z++){let X=Q.set[Z],q=Q.globParts[Z];if(!X||!q)throw Error("invalid pattern object");while(X[0]==="."&&q[0]===".")X.shift(),q.shift();let J=new h0(X,q,0,this.platform),V=new t(J.globString(),this.mmopts),Y=q[q.length-1]==="**",W=J.isAbsolute();if(W)this.absolute.push(V);else this.relative.push(V);if(Y)if(W)this.absoluteChildren.push(V);else this.relativeChildren.push(V)}}ignored($){let Q=$.fullpath(),Z=`${Q}/`,X=$.relative()||".",q=`${X}/`;for(let J of this.relative)if(J.match(X)||J.match(q))return!0;for(let J of this.absolute)if(J.match(Q)||J.match(Z))return!0;return!1}childrenIgnored($){let Q=$.fullpath()+"/",Z=($.relative()||".")+"/";for(let X of this.relativeChildren)if(X.match(Z))return!0;for(let X of this.absoluteChildren)if(X.match(Q))return!0;return!1}}class r${store;constructor($=new Map){this.store=$}copy(){return new r$(new Map(this.store))}hasWalked($,Q){return this.store.get($.fullpath())?.has(Q.globString())}storeWalked($,Q){let Z=$.fullpath(),X=this.store.get(Z);if(X)X.add(Q.globString());else this.store.set(Z,new Set([Q.globString()]))}}class o5{store=new Map;add($,Q,Z){let X=(Q?2:0)|(Z?1:0),q=this.store.get($);this.store.set($,q===void 0?X:X&q)}entries(){return[...this.store.entries()].map(([$,Q])=>[$,!!(Q&2),!!(Q&1)])}}class t5{store=new Map;add($,Q){if(!$.canReaddir())return;let Z=this.store.get($);if(Z){if(!Z.find((X)=>X.globString()===Q.globString()))Z.push(Q)}else this.store.set($,[Q])}get($){let Q=this.store.get($);if(!Q)throw Error("attempting to walk unknown path");return Q}entries(){return this.keys().map(($)=>[$,this.store.get($)])}keys(){return[...this.store.keys()].filter(($)=>$.canReaddir())}}class q8{hasWalkedCache;matches=new o5;subwalks=new t5;patterns;follow;dot;opts;constructor($,Q){this.opts=$,this.follow=!!$.follow,this.dot=!!$.dot,this.hasWalkedCache=Q?Q.copy():new r$}processPatterns($,Q){this.patterns=Q;let Z=Q.map((X)=>[$,X]);for(let[X,q]of Z){this.hasWalkedCache.storeWalked(X,q);let J=q.root(),V=q.isAbsolute()&&this.opts.absolute!==!1;if(J){X=X.resolve(J==="/"&&this.opts.root!==void 0?this.opts.root:J);let K=q.rest();if(!K){this.matches.add(X,!0,!1);continue}else q=K}if(X.isENOENT())continue;let Y,W,H=!1;while(typeof(Y=q.pattern())==="string"&&(W=q.rest()))X=X.resolve(Y),q=W,H=!0;if(Y=q.pattern(),W=q.rest(),H){if(this.hasWalkedCache.hasWalked(X,q))continue;this.hasWalkedCache.storeWalked(X,q)}if(typeof Y==="string"){let K=Y===".."||Y===""||Y===".";this.matches.add(X.resolve(Y),V,K);continue}else if(Y===m){if(!X.isSymbolicLink()||this.follow||q.checkFollowGlobstar())this.subwalks.add(X,q);let K=W?.pattern(),G=W?.rest();if(!W||(K===""||K===".")&&!G)this.matches.add(X,V,K===""||K===".");else if(K===".."){let _=X.parent||X;if(!G)this.matches.add(_,V,!0);else if(!this.hasWalkedCache.hasWalked(_,G))this.subwalks.add(_,G)}}else if(Y instanceof RegExp)this.subwalks.add(X,q)}return this}subwalkTargets(){return this.subwalks.keys()}child(){return new q8(this.opts,this.hasWalkedCache)}filterEntries($,Q){let Z=this.subwalks.get($),X=this.child();for(let q of Q)for(let J of Z){let V=J.isAbsolute(),Y=J.pattern(),W=J.rest();if(Y===m)X.testGlobstar(q,J,W,V);else if(Y instanceof RegExp)X.testRegExp(q,Y,W,V);else X.testString(q,Y,W,V)}return X}testGlobstar($,Q,Z,X){if(this.dot||!$.name.startsWith(".")){if(!Q.hasMore())this.matches.add($,X,!1);if($.canReaddir()){if(this.follow||!$.isSymbolicLink())this.subwalks.add($,Q);else if($.isSymbolicLink()){if(Z&&Q.checkFollowGlobstar())this.subwalks.add($,Z);else if(Q.markFollowGlobstar())this.subwalks.add($,Q)}}}if(Z){let q=Z.pattern();if(typeof q==="string"&&q!==".."&&q!==""&&q!==".")this.testString($,q,Z.rest(),X);else if(q===".."){let J=$.parent||$;this.subwalks.add(J,Z)}else if(q instanceof RegExp)this.testRegExp($,q,Z.rest(),X)}}testRegExp($,Q,Z,X){if(!Q.test($.name))return;if(!Z)this.matches.add($,X,!1);else this.subwalks.add($,Z)}testString($,Q,Z,X){if(!$.isNamed(Q))return;if(!Z)this.matches.add($,X,!1);else this.subwalks.add($,Z)}}var t9=($,Q)=>typeof $==="string"?new X8([$],Q):Array.isArray($)?new X8($,Q):$;class s${path;patterns;opts;seen=new Set;paused=!1;aborted=!1;#Q=[];#$;#Z;signal;maxDepth;includeChildMatches;constructor($,Q,Z){if(this.patterns=$,this.path=Q,this.opts=Z,this.#Z=!Z.posix&&Z.platform==="win32"?"\\":"/",this.includeChildMatches=Z.includeChildMatches!==!1,Z.ignore||!this.includeChildMatches){if(this.#$=t9(Z.ignore??[],Z),!this.includeChildMatches&&typeof this.#$.add!=="function")throw Error("cannot ignore child matches, ignore lacks add() method.")}if(this.maxDepth=Z.maxDepth||1/0,Z.signal)this.signal=Z.signal,this.signal.addEventListener("abort",()=>{this.#Q.length=0})}#X($){return this.seen.has($)||!!this.#$?.ignored?.($)}#J($){return!!this.#$?.childrenIgnored?.($)}pause(){this.paused=!0}resume(){if(this.signal?.aborted)return;this.paused=!1;let $=void 0;while(!this.paused&&($=this.#Q.shift()))$()}onResume($){if(this.signal?.aborted)return;if(!this.paused)$();else this.#Q.push($)}async matchCheck($,Q){if(Q&&this.opts.nodir)return;let Z;if(this.opts.realpath){if(Z=$.realpathCached()||await $.realpath(),!Z)return;$=Z}let q=$.isUnknown()||this.opts.stat?await $.lstat():$;if(this.opts.follow&&this.opts.nodir&&q?.isSymbolicLink()){let J=await q.realpath();if(J&&(J.isUnknown()||this.opts.stat))await J.lstat()}return this.matchCheckTest(q,Q)}matchCheckTest($,Q){return $&&(this.maxDepth===1/0||$.depth()<=this.maxDepth)&&(!Q||$.canReaddir())&&(!this.opts.nodir||!$.isDirectory())&&(!this.opts.nodir||!this.opts.follow||!$.isSymbolicLink()||!$.realpathCached()?.isDirectory())&&!this.#X($)?$:void 0}matchCheckSync($,Q){if(Q&&this.opts.nodir)return;let Z;if(this.opts.realpath){if(Z=$.realpathCached()||$.realpathSync(),!Z)return;$=Z}let q=$.isUnknown()||this.opts.stat?$.lstatSync():$;if(this.opts.follow&&this.opts.nodir&&q?.isSymbolicLink()){let J=q.realpathSync();if(J&&(J?.isUnknown()||this.opts.stat))J.lstatSync()}return this.matchCheckTest(q,Q)}matchFinish($,Q){if(this.#X($))return;if(!this.includeChildMatches&&this.#$?.add){let q=`${$.relativePosix()}/**`;this.#$.add(q)}let Z=this.opts.absolute===void 0?Q:this.opts.absolute;this.seen.add($);let X=this.opts.mark&&$.isDirectory()?this.#Z:"";if(this.opts.withFileTypes)this.matchEmit($);else if(Z){let q=this.opts.posix?$.fullpathPosix():$.fullpath();this.matchEmit(q+X)}else{let q=this.opts.posix?$.relativePosix():$.relative(),J=this.opts.dotRelative&&!q.startsWith(".."+this.#Z)?"."+this.#Z:"";this.matchEmit(!q?"."+X:J+q+X)}}async match($,Q,Z){let X=await this.matchCheck($,Z);if(X)this.matchFinish(X,Q)}matchSync($,Q,Z){let X=this.matchCheckSync($,Z);if(X)this.matchFinish(X,Q)}walkCB($,Q,Z){if(this.signal?.aborted)Z();this.walkCB2($,Q,new q8(this.opts),Z)}walkCB2($,Q,Z,X){if(this.#J($))return X();if(this.signal?.aborted)X();if(this.paused){this.onResume(()=>this.walkCB2($,Q,Z,X));return}Z.processPatterns($,Q);let q=1,J=()=>{if(--q===0)X()};for(let[V,Y,W]of Z.matches.entries()){if(this.#X(V))continue;q++,this.match(V,Y,W).then(()=>J())}for(let V of Z.subwalkTargets()){if(this.maxDepth!==1/0&&V.depth()>=this.maxDepth)continue;q++;let Y=V.readdirCached();if(V.calledReaddir())this.walkCB3(V,Y,Z,J);else V.readdirCB((W,H)=>this.walkCB3(V,H,Z,J),!0)}J()}walkCB3($,Q,Z,X){Z=Z.filterEntries($,Q);let q=1,J=()=>{if(--q===0)X()};for(let[V,Y,W]of Z.matches.entries()){if(this.#X(V))continue;q++,this.match(V,Y,W).then(()=>J())}for(let[V,Y]of Z.subwalks.entries())q++,this.walkCB2(V,Y,Z.child(),J);J()}walkCBSync($,Q,Z){if(this.signal?.aborted)Z();this.walkCB2Sync($,Q,new q8(this.opts),Z)}walkCB2Sync($,Q,Z,X){if(this.#J($))return X();if(this.signal?.aborted)X();if(this.paused){this.onResume(()=>this.walkCB2Sync($,Q,Z,X));return}Z.processPatterns($,Q);let q=1,J=()=>{if(--q===0)X()};for(let[V,Y,W]of Z.matches.entries()){if(this.#X(V))continue;this.matchSync(V,Y,W)}for(let V of Z.subwalkTargets()){if(this.maxDepth!==1/0&&V.depth()>=this.maxDepth)continue;q++;let Y=V.readdirSync();this.walkCB3Sync(V,Y,Z,J)}J()}walkCB3Sync($,Q,Z,X){Z=Z.filterEntries($,Q);let q=1,J=()=>{if(--q===0)X()};for(let[V,Y,W]of Z.matches.entries()){if(this.#X(V))continue;this.matchSync(V,Y,W)}for(let[V,Y]of Z.subwalks.entries())q++,this.walkCB2Sync(V,Y,Z.child(),J);J()}}class P8 extends s${matches=new Set;constructor($,Q,Z){super($,Q,Z)}matchEmit($){this.matches.add($)}async walk(){if(this.signal?.aborted)throw this.signal.reason;if(this.path.isUnknown())await this.path.lstat();return await new Promise(($,Q)=>{this.walkCB(this.path,this.patterns,()=>{if(this.signal?.aborted)Q(this.signal.reason);else $(this.matches)})}),this.matches}walkSync(){if(this.signal?.aborted)throw this.signal.reason;if(this.path.isUnknown())this.path.lstatSync();return this.walkCBSync(this.path,this.patterns,()=>{if(this.signal?.aborted)throw this.signal.reason}),this.matches}}class N8 extends s${results;constructor($,Q,Z){super($,Q,Z);this.results=new P0({signal:this.signal,objectMode:!0}),this.results.on("drain",()=>this.resume()),this.results.on("resume",()=>this.resume())}matchEmit($){if(this.results.write($),!this.results.flowing)this.pause()}stream(){let $=this.path;if($.isUnknown())$.lstat().then(()=>{this.walkCB($,this.patterns,()=>this.results.end())});else this.walkCB($,this.patterns,()=>this.results.end());return this.results}streamSync(){if(this.path.isUnknown())this.path.lstatSync();return this.walkCBSync(this.path,this.patterns,()=>this.results.end()),this.results}}var $Q=typeof process==="object"&&process&&typeof process.platform==="string"?process.platform:"linux";class _0{absolute;cwd;root;dot;dotRelative;follow;ignore;magicalBraces;mark;matchBase;maxDepth;nobrace;nocase;nodir;noext;noglobstar;pattern;platform;realpath;scurry;stat;signal;windowsPathsNoEscape;withFileTypes;includeChildMatches;opts;patterns;constructor($,Q){if(!Q)throw TypeError("glob options required");if(this.withFileTypes=!!Q.withFileTypes,this.signal=Q.signal,this.follow=!!Q.follow,this.dot=!!Q.dot,this.dotRelative=!!Q.dotRelative,this.nodir=!!Q.nodir,this.mark=!!Q.mark,!Q.cwd)this.cwd="";else if(Q.cwd instanceof URL||Q.cwd.startsWith("file://"))Q.cwd=e9(Q.cwd);if(this.cwd=Q.cwd||"",this.root=Q.root,this.magicalBraces=!!Q.magicalBraces,this.nobrace=!!Q.nobrace,this.noext=!!Q.noext,this.realpath=!!Q.realpath,this.absolute=Q.absolute,this.includeChildMatches=Q.includeChildMatches!==!1,this.noglobstar=!!Q.noglobstar,this.matchBase=!!Q.matchBase,this.maxDepth=typeof Q.maxDepth==="number"?Q.maxDepth:1/0,this.stat=!!Q.stat,this.ignore=Q.ignore,this.withFileTypes&&this.absolute!==void 0)throw Error("cannot set absolute and withFileTypes:true");if(typeof $==="string")$=[$];if(this.windowsPathsNoEscape=!!Q.windowsPathsNoEscape||Q.allowWindowsEscape===!1,this.windowsPathsNoEscape)$=$.map((Y)=>Y.replace(/\\/g,"/"));if(this.matchBase){if(Q.noglobstar)throw TypeError("base matching requires globstar");$=$.map((Y)=>Y.includes("/")?Y:`./**/${Y}`)}if(this.pattern=$,this.platform=Q.platform||$Q,this.opts={...Q,platform:this.platform},Q.scurry){if(this.scurry=Q.scurry,Q.nocase!==void 0&&Q.nocase!==Q.scurry.nocase)throw Error("nocase option contradicts provided scurry option")}else{let Y=Q.platform==="win32"?Q8:Q.platform==="darwin"?w8:Q.platform?Z8:a5;this.scurry=new Y(this.cwd,{nocase:Q.nocase,fs:Q.fs})}this.nocase=this.scurry.nocase;let Z=this.platform==="darwin"||this.platform==="win32",X={...Q,dot:this.dot,matchBase:this.matchBase,nobrace:this.nobrace,nocase:this.nocase,nocaseMagicOnly:Z,nocomment:!0,noext:this.noext,nonegate:!0,optimizationLevel:2,platform:this.platform,windowsPathsNoEscape:this.windowsPathsNoEscape,debug:!!this.opts.debug},q=this.pattern.map((Y)=>new t(Y,X)),[J,V]=q.reduce((Y,W)=>{return Y[0].push(...W.set),Y[1].push(...W.globParts),Y},[[],[]]);this.patterns=J.map((Y,W)=>{let H=V[W];if(!H)throw Error("invalid pattern object");return new h0(Y,H,0,this.platform)})}async walk(){return[...await new P8(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).walk()]}walkSync(){return[...new P8(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).walkSync()]}stream(){return new N8(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).stream()}streamSync(){return new N8(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).streamSync()}iterateSync(){return this.streamSync()[Symbol.iterator]()}[Symbol.iterator](){return this.iterateSync()}iterate(){return this.stream()[Symbol.asyncIterator]()}[Symbol.asyncIterator](){return this.iterate()}}var a$=($,Q={})=>{if(!Array.isArray($))$=[$];for(let Z of $)if(new t(Z,Q).hasMagic())return!0;return!1};function b8($,Q={}){return new _0($,Q).streamSync()}function Q1($,Q={}){return new _0($,Q).stream()}function k8($,Q={}){return new _0($,Q).walkSync()}async function e5($,Q={}){return new _0($,Q).walk()}function D8($,Q={}){return new _0($,Q).iterateSync()}function Z1($,Q={}){return new _0($,Q).iterate()}var QQ=b8,ZQ=Object.assign(Q1,{sync:b8}),XQ=D8,qQ=Object.assign(Z1,{sync:D8}),JQ=Object.assign(k8,{stream:b8,iterate:D8}),$1=Object.assign(e5,{glob:e5,globSync:k8,sync:JQ,globStream:Q1,stream:ZQ,globStreamSync:b8,streamSync:QQ,globIterate:Z1,iterate:qQ,globIterateSync:D8,iterateSync:XQ,Glob:_0,hasMagic:a$,escape:E0,unescape:q0});$1.glob=$1;import YQ from"node:path";var X1=({dir:$,pattern:Q="*",nodir:Z=!1,dot:X=!0,ignore:q=[],absolute:J=!1,matchBase:V=!1,follow:Y=!1})=>{if($=$||process.cwd(),$=YQ.resolve($),Q&&!Array.isArray(Q))Q=[Q];else Q=Q||["*"];if(q&&!Array.isArray(q))q=[q];else q=q||[];return k8(Q,{cwd:$,nodir:Z,dot:X,ignore:q,absolute:J,matchBase:V,follow:Y})};import Y1 from"@fnet/expression";import q1 from"lodash.clonedeep";import VQ from"@fnet/key-value-transformer";import WQ from"@fnet/expression";async function y({node:$,initNode:Q,extra:Z=!0}){if(Reflect.has($.definition,"modules")&&!Array.isArray($.definition.modules)){let X=$.definition.modules;$.definition.modules=[],Object.keys(X).forEach((q)=>{let J={...X[q]};if(typeof J.export==="boolean")J.export=J.export===!0?q:!1;else if(typeof J.export==="string")J.export=J.export;else delete J.export;$.definition.modules.push({[q]:J})})}if(Z){let X=[],q=await VQ({data:$.definition,callback:(J,V,Y)=>{let W=WQ({expression:J});if(W?.processor==="m"){let H=Y.slice(0,-1);H.push(W.statement);let K=H.join("_");return X.push({[K]:V}),[W.statement,`m::${K}`]}return[J,V]}});if(X.length>0)$.definition=q,$.definition.modules=$.definition.modules||[],$.definition.modules=$.definition.modules.concat(X)}$.hasModules=$.definition.modules?.length>0;for(let X=0;X<$.definition.modules?.length;X++){let q=$.definition.modules[X],J=Object.keys(q)[0],V={name:J,childs:[],parent:$,definition:q[J],module:!0,blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1,index:$.childs.length,context:{}};$.childs.push(V),await Q({node:V})}}async function b({node:$,transformExpression:Q}){let Z=$.context.transform;if(Reflect.has(Z,"export"))Z.export=await Q(Z.export);if(Reflect.has(Z,"return"))$.hasReturn=!0,Z.return=await Q(Z.return);if(Reflect.has(Z,"output"))Z.output=await Q(Z.output);if(Reflect.has(Z,"assign"))for(let X=0;X<Z.assign?.length;X++){let q=Z.assign[X],J=Object.keys(q)[0],V=q[J],Y={key:await Q(J),value:await Q(V)};Z.assign[X]=Y}}async function HQ({node:$}){if(!$.definition.hasOwnProperty("switch"))return!1;return!0}async function KQ({node:$,initNode:Q}){$.type="switch";let Z=$.definition.switch||[];if(!Z.every((V)=>V.hasOwnProperty("condition")||V.hasOwnProperty("default")))throw Error("Switch must have condition or default");if(Z.filter((V)=>V.hasOwnProperty("condition")).length===0)throw Error("Switch must have at least one condition");let J=Z.filter((V)=>V.hasOwnProperty("default"));if(J.length>1)throw Error("Switch must have only one default");if(J.length===1&&!Z[Z.length-1].hasOwnProperty("default"))throw Error("Switch default must be the last child");$.hasDefaultCondition=J.length===1,await y({node:$,initNode:Q,extra:!1}),$.blockAutoJumpToParent=!1,$.blockAutoJumpToSibling=!0;for(let V=0;V<$.definition.switch.length;V++){let Y=$.definition.switch[V],W=`${V}`;if(Y.hasOwnProperty("default"))W="default",Y=Y.default;let H={name:Y.condition||W,childs:[],parent:$,definition:Y,index:$.childs.length,context:{}};$.childs.push(H),await Q({node:H})}$.resolve=J1}async function J1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X}){$.context.transform=$.context.transform||q1($.definition);let q=$.context.transform;for(let J of $.childs)if(J.context.transform=J.context.transform||q1(J.definition),J.definition.hasOwnProperty("condition"))J.context.transform.condition=await X(J.definition.condition);await b({node:$,transformExpression:X}),await Q({node:$}),Z({node:$})}var J8={hits:HQ,init:KQ,resolve:J1};async function _Q({node:$}){if(Object.keys($.definition).map((q)=>Y1({expression:q})).filter((q)=>q?.processor==="if").length===1)return!0;if($.definition.if&&typeof $.definition.if==="object")return!0;return!1}async function GQ($){let{node:Q}=$,X=Object.keys(Q.definition).map((W)=>Y1({expression:W})),q=[],J=X.find((W)=>W?.processor==="if");if(J){let W=Q.definition[J.expression];q.push({name:`${Q.name}_if`,definition:W,processor:J}),delete Q.definition[J.expression]}else if(Q.definition.if){let{condition:W,...H}=Q.definition.if;q.push({name:`${Q.name}_if`,definition:H,processor:{expression:`if::${W}`,statement:W}}),delete Q.definition.if}let V=X.filter((W)=>W?.processor==="elseif"),Y=0;for(let W of V){let H=Q.definition[W.expression];q.push({name:`${Q.name}_elseif_${Y++}`,definition:H,processor:W}),delete Q.definition[W.expression]}if(Q.definition.elseif){let{condition:W,...H}=Q.definition.elseif;q.push({name:`${Q.name}_elseif_${Y++}`,definition:H,processor:{expression:`elseif::${W}`,statement:W}}),delete Q.definition.elseif}Q.definition.switch=[];for(let W of q)Q.definition.switch.push({condition:W.processor.statement,...W.definition});if(Q.definition?.else){let W=Q.definition.else;Q.definition.switch.push({default:W}),delete Q.definition.else}await J8.init($)}var o$={hits:_Q,init:GQ};import V1 from"lodash.clonedeep";async function zQ({node:$}){return $.definition.hasOwnProperty("try")&&$.definition.hasOwnProperty("except")}async function UQ({node:$,initNode:Q}){if($.type="tryexcept",await y({node:$,initNode:Q,extra:!1}),$.blockAutoJumpToParent=!1,$.blockAutoJumpToSibling=!0,$.definition.try){let X={name:"try",childs:[],parent:$,definition:$.definition.try,index:$.childs.length,context:{}};$.childs.push(X),await Q({node:X})}if($.definition.except){let X={name:"except",childs:[],parent:$,definition:$.definition.except,index:$.childs.length,context:{}};$.childs.push(X),await Q({node:X})}$.resolve=W1}async function W1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X}){$.context.transform=$.context.transform||V1($.definition);let q=$.context.transform;if($.context.try=$.childs.find((J)=>J.name==="try"),$.context.except=$.childs.find((J)=>J.name==="except"),$.context.except){let J=$.context.except;if(J.context.transform=J.context.transform||V1(J.definition),!J.context.transform.hasOwnProperty("as"))J.context.transform.as="error"}await b({node:$,transformExpression:X}),await Q({node:$}),Z({node:$})}var t$={hits:zQ,init:UQ,resolve:W1};import MQ from"lodash.clonedeep";async function OQ({node:$}){return $.definition.hasOwnProperty("assign")}async function AQ({node:$,initNode:Q}){$.type="assign",await y({node:$,initNode:Q}),$.resolve=H1}async function H1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X}){$.context.transform=$.context.transform||MQ($.definition);let q=$.context.transform;await b({node:$,transformExpression:X}),await Q({node:$}),Z({node:$})}var e$={hits:OQ,init:AQ,resolve:H1};import BQ from"lodash.clonedeep";async function RQ({node:$}){return $.definition.hasOwnProperty("for")}async function CQ({node:$,initNode:Q}){if($.type="for",await y({node:$,initNode:Q,extra:!1}),$.blockAutoJumpToParent=!0,$.blockAutoJumpToSibling=!1,!$.definition.for.hasOwnProperty("steps")){let{value:Z,in:X,...q}=$.definition.for,J={};if(Z!==void 0)J.value=Z;if(X!==void 0)J.in=X;$.definition.for=J,$.definition.for.steps=[{[`${$.name}_step`]:q}]}if(!Array.isArray($.definition.for.steps))$.definition.for.steps=[{[`${$.name}_step`]:$.definition.for.steps}];for(let Z=0;Z<$.definition.for.steps.length;Z++){let X=$.definition.for.steps[Z],q=Object.keys(X)[0],J={name:q,childs:[],parent:$,definition:X[q],index:$.childs.length,context:{}};$.childs.push(J),await Q({node:J})}$.resolve=K1}async function K1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X}){$.context.transform=$.context.transform||BQ($.definition);let q=$.context.transform;q.for.in=await X($.definition.for.in),await b({node:$,transformExpression:X}),await Q({node:$}),Z({node:$})}var $6={hits:RQ,init:CQ,resolve:K1};async function IQ({node:$}){return!1}async function LQ({node:$,initNode:Q}){}async function FQ({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X,transformValue:q}){}var Q6={hits:IQ,init:LQ,resolve:FQ};import jQ from"lodash.clonedeep";async function TQ({node:$}){return $.definition.hasOwnProperty("raise")}async function SQ({node:$,initNode:Q}){$.type="raise",$.resolve=_1}async function _1({node:$,resolveTypeCommon:Q,transformExpression:Z}){$.context.transform=$.context.transform||jQ($.definition);let X=$.context.transform;X.raise=await Z(X.raise),await Q({node:$})}var Z6={hits:TQ,init:SQ,resolve:_1};import wQ from"lodash.clonedeep";async function PQ({node:$}){return $.definition.hasOwnProperty("return")}async function NQ({node:$,initNode:Q}){$.type="return",$.resolve=G1}async function G1({node:$,resolveTypeCommon:Q,transformExpression:Z}){$.context.transform=$.context.transform||wQ($.definition);let X=$.context.transform;$.hasReturn=!0,X.return=await Z(X.return),await Q({node:$})}var X6={hits:PQ,init:NQ,resolve:G1};import bQ from"lodash.clonedeep";async function kQ({node:$}){return $.definition.hasOwnProperty("call")}async function DQ({node:$,initNode:Q}){$.type="call",await y({node:$,initNode:Q}),$.resolve=z1}async function z1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X}){$.context.transform=$.context.transform||bQ($.definition);let q=$.context.transform,J=q.from||q.import||q.call;if($.target?.atom?.doc?.type==="function"){if(Reflect.has(q,"from"))J=q.from,q.from=await X($.target.atom.name);else if(Reflect.has(q,"import"))J=q.import,q.import=await X($.target.atom.name);else if(Reflect.has(q,"call"))q.call=await X($.target.atom.name),J=q.call}else if(Reflect.has(q,"from")||Reflect.has(q,"import")){if(q.call.startsWith("use:e::")){let Y=q.call.substring(7);q.libExp=await X(`e::LIBRARY.${Y}`)}}if(q.args)q.args=await X(q.args);if(q.new)q.new=await X(q.new);if(q.context)q.context=await X(q.context);if(q.result){if(typeof q.result==="string")q.result=[{[q.result]:"e::result"}];for(let Y=0;Y<q.result?.length;Y++){let W=q.result[Y],H=Object.keys(W)[0],K=W[H],G={key:await X(H),value:await X(K)};q.result[Y]=G}}let V=$.workflow.parent;$.context.lib=V.context.libs.find((Y)=>Y.name===J),await b({node:$,transformExpression:X}),await Q({node:$}),Z({node:$})}var Y8={hits:kQ,init:DQ,resolve:z1};import vQ from"lodash.clonedeep";async function EQ({node:$}){return $.definition.hasOwnProperty("steps")}async function yQ({node:$,initNode:Q}){if(!$.type)$.type="steps";let Z=$.definition.steps||[];for await(let X of Z){let q=Object.keys(X)[0],J={name:q,childs:[],parent:$,definition:X[q],index:$.childs.length,context:{}};$.childs.push(J),await Q({node:J})}$.resolve=U1}async function U1({node:$,transformExpression:Q}){$.context.next=$.childs[0],$.context.transform=$.context.transform||vQ($.definition),await b({node:$,transformExpression:Q})}var q6={hits:EQ,init:yQ,resolve:U1};import xQ from"lodash.clonedeep";async function uQ({node:$}){return $.definition.hasOwnProperty("form")}async function fQ({node:$,initNode:Q}){$.type="form",await y({node:$,initNode:Q}),$.resolve=M1}async function M1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X}){$.context.transform=$.context.transform||xQ($.definition);let q=$.context.transform;if(q.props)q.props=await X(q.props);let J=$.workflow.parent;$.context.lib=J.context.libs.find((V)=>V.name===q.form),await b({node:$,transformExpression:X}),await Q({node:$}),Z({node:$})}var J6={hits:uQ,init:fQ,resolve:M1};import hQ from"lodash.clonedeep";async function gQ({node:$}){return $.definition.hasOwnProperty("signal")}async function mQ({node:$,initNode:Q}){$.type="signal",$.resolve=O1}async function O1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X,transformValue:q}){$.context.transform=$.context.transform||hQ($.definition),await Q({node:$}),Z({node:$})}var Y6={hits:gQ,init:mQ,resolve:O1};import cQ from"lodash.clonedeep";async function lQ({node:$}){return $.definition.hasOwnProperty("wait")}async function dQ({node:$,initNode:Q}){$.type="wait",$.resolve=A1}async function A1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X,transformValue:q}){$.context.transform=$.context.transform||cQ($.definition),await Q({node:$}),Z({node:$})}var V6={hits:lQ,init:dQ,resolve:A1};import pQ from"lodash.clonedeep";async function iQ({node:$}){return $.definition.hasOwnProperty("next")}async function nQ({node:$,initNode:Q}){$.type="next",$.resolve=B1}async function B1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X}){$.context.transform=$.context.transform||pQ($.definition);let q=$.context.transform;q.next=await X(q.next),await b({node:$,transformExpression:X}),await Q({node:$}),Z({node:$})}var W6={hits:iQ,init:nQ,resolve:B1};import rQ from"lodash.clonedeep";async function sQ({node:$}){return $.definition.hasOwnProperty("modules")}async function aQ({node:$,initNode:Q}){$.type="modules",await y({node:$,initNode:Q}),$.resolve=R1}async function R1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X}){$.context.transform=$.context.transform||rQ($.definition);let q=$.context.transform;await b({node:$,transformExpression:X}),await Q({node:$}),Z({node:$})}var H6={hits:sQ,init:aQ,resolve:R1};function K6({node:$}){let Q=$.definition;if($.hasReturn){if(F("tree"))N.info(" └─ RETURN (no next)",{depth:$.depth+1,node:$.indexKey});return}if(Q.next==="end"){if(F("tree"))N.info(" └─ EXPLICIT END",{depth:$.depth+1,node:$.indexKey})}else if(Q.next==="stop"){if(F("tree"))N.info(" └─ EXPLICIT STOP",{depth:$.depth+1,node:$.indexKey})}else if(Q.next==="none"){if(F("tree"))N.info(" └─ EXPLICIT NONE",{depth:$.depth+1,node:$.indexKey})}else if(Q.next){if(F("tree"))N.info(` \uD83D\uDD0D EXPLICIT NEXT: "${Q.next}" (searching...)`,{depth:$.depth+1,from:$.indexKey});let Z=$.parent;while(Z.parent){let X=Z.childs.find((q)=>q.name===Q.next);if(X){if($.context.next=X,F("tree"))N.info(` └─ ✅ FOUND: ${X.indexKey}`,{depth:$.depth+1,nextNode:X.indexKey});break}Z=Z.parent}if(!$.context.next&&F("tree"))N.warn(` └─ ⚠️ NOT FOUND: "${Q.next}"`,{depth:$.depth+1})}else{if($.module===!0){if(F("tree"))N.info(" └─ MODULE ROOT (no auto next)",{depth:$.depth+1,node:$.indexKey});return}if(F("tree"))N.info(" \uD83D\uDC1C AUTO NEXT (karınca yürüyüşü başlıyor...)",{depth:$.depth+1,from:$.indexKey});let Z=$.parent,X=$.index+1,q=0;while(Z.parent)if(q++,Z.blockAutoJumpToParent&&Z.blockAutoJumpToSibling){if(F("tree"))N.info(` ${q}. ⛔ Both jumps disabled at ${Z.indexKey}`,{depth:$.depth+2});break}else if(!Reflect.has(Z,"blockAutoJumpToParent")&&!Reflect.has(Z,"blockAutoJumpToSibling")){let J=Z.childs.find((V)=>V.index===X);if(J){if($.context.next=J,F("tree"))N.info(` ${q}. ✅ SIBLING FOUND: ${J.indexKey}`,{depth:$.depth+2,nextNode:J.indexKey});break}else{if(F("tree"))N.info(` ${q}. ⬆️ No sibling, climbing to parent: ${Z.parent?.indexKey}`,{depth:$.depth+2,targetIndex:X});X=Z.index+1,Z=Z.parent;continue}}else if(Z.blockAutoJumpToParent){let J=Z.childs.find((V)=>V.index===X);if(J){if($.context.next=J,F("tree"))N.info(` ${q}. ✅ SIBLING FOUND (parent jump disabled): ${J.indexKey}`,{depth:$.depth+2,nextNode:J.indexKey})}else if(F("tree"))N.info(` ${q}. ⛔ No sibling, parent jump disabled`,{depth:$.depth+2});break}else if(!Z.blockAutoJumpToParent){if(F("tree"))N.info(` ${q}. ⬆️ Sibling disabled, climbing to parent: ${Z.parent?.indexKey}`,{depth:$.depth+2});X=Z.index+1,Z=Z.parent;continue}if($.context.next&&F("tree"))N.info(` └─ \uD83C\uDFAF AUTO NEXT RESOLVED: ${$.context.next.indexKey}`,{depth:$.depth+1,steps:q,nextNode:$.context.next.indexKey});else if(F("tree"))N.info(" └─ ⚠️ NO NEXT FOUND (end of flow)",{depth:$.depth+1,steps:q})}}class C1{#Q;#$;#Z;#X;constructor({key:$,npm:Q,master:Z,extras:X}){this.#Q=$,this.#$=Q,this.#Z=Z,this.#X=X}hits({node:$}){return $.definition.hasOwnProperty(this.#Q)}async init($){let{node:Q}=$,Z=this.#Q,X=Q.definition,q=typeof X[Z];if(X.call=`npm:${this.#$}`,q!=="object")X.args={...X.args,[`${this.#Z}`]:X[Z]};else X.args=X[Z];if(delete X[Z],this.#X)for(let J in this.#X)X[J]=this.#X[J];console.log(`[npm-block] ${this.#Q} --> ${this.#$}`),await Y8.init($)}}function c($){return new C1($)}import oQ from"lodash.clonedeep";async function tQ({node:$}){return $.definition.hasOwnProperty("new")}async function eQ({node:$,initNode:Q}){$.type="new",await y({node:$,initNode:Q}),$.resolve=I1}async function I1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X}){$.context.transform=$.context.transform||oQ($.definition);let q=$.context.transform,J=q.from||q.import;if($.target?.atom?.doc?.type==="function"){if(Reflect.has(q,"from"))J=q.from,q.from=await X($.target.atom.name);else if(Reflect.has(q,"import"))J=q.import,q.import=await X($.target.atom.name)}if(q.args)q.args=await X(q.args);if(q.new)q.new=await X(q.new);if(q.result){if(typeof q.result==="string")q.result=[{[q.result]:"e::result"}];for(let Y=0;Y<q.result?.length;Y++){let W=q.result[Y],H=Object.keys(W)[0],K=W[H],G={key:await X(H),value:await X(K)};q.result[Y]=G}}let V=$.workflow.parent;$.context.lib=V.context.libs.find((Y)=>Y.name===J),await b({node:$,transformExpression:X}),await Q({node:$}),Z({node:$})}var _6={hits:tQ,init:eQ,resolve:I1};import $2 from"lodash.clonedeep";async function Q2({node:$}){return $.definition.hasOwnProperty("output")}async function Z2({node:$,initNode:Q}){$.type="output",await y({node:$,initNode:Q}),$.resolve=L1}async function L1({node:$,resolveTypeCommon:Q,resolveNextBlock:Z,transformExpression:X}){$.context.transform=$.context.transform||$2($.definition),await b({node:$,transformExpression:X}),await Q({node:$}),Z({node:$})}var G6={hits:Q2,init:Z2,resolve:L1};var F1=({path:$})=>{if(!$)throw Error("Path is required");let Q=/^@([^\/]+\/[^\/]+)(?:\/(.+))?$/,Z=/^([^\/]+)(?:\/(.+))?$/,X;if(X=$.match(Q))return{path:$,package:"@"+X[1],subpath:X[2]||null};else if(X=$.match(Z))return{path:$,package:X[1],subpath:X[2]||null};return null};class N1{#Q;#$;#Z;#X;#J;#I;#C;#H;#G;#W;#_;#q;#O;#M;#U;#A;#j;#R;#F;#V;#L;#K=[];constructor($){this.#Q=new N6,this.#$=$,this.#I=[],this.#C=[],this.#H={},this._expire_ttl=3600,this._expire_ttl_short=300,this.#K.push(c({key:"config",npm:"@fnet/config",master:"name"})),this.#K.push(c({key:"yaml",npm:"@fnet/yaml",master:"file"})),this.#K.push(c({key:"prompt",npm:"@fnet/prompt",master:"message"})),this.#K.push(c({key:"html-link",npm:"@flownet/lib-load-browser-link-url",master:"src"})),this.#K.push(c({key:"html-script",npm:"@flownet/lib-load-browser-script-url",master:"src"})),this.#K.push(c({key:"http-server",npm:"@fnet/node-express",master:"server_port"})),this.#K.push(c({key:"shell",npm:"@fnet/shell-flow",master:"commands"})),this.#K.push(c({key:"list-files",npm:"@fnet/list-files",master:"pattern"})),this.#K.push(c({key:"up-list-files",npm:"@fnet/up-list-files",master:"pattern"})),this.#K.push(c({key:"auto-conda-env",npm:"@fnet/auto-conda-env",master:"envDir"})),this.#K.push(c({key:"ollama-chat",npm:"@fnet/ollama-chat",master:"model"})),this.#K.push(c({key:"ai",npm:"@fnet/ai",master:"prompt",extras:{subtype:"flow"}})),this.#K.push(c({key:"invoke",npm:"@fnet/invoke",master:"method",extras:{}})),this.#K.push(c({key:"fetch",npm:"@fnet/fetch",master:"url",extras:{}})),this.#K.push(c({key:"filemap",npm:"@fnet/filemap",master:"target",extras:{}})),this.#V={packageDependencies:this.#I,packageDevDependencies:this.#C,setProgress:this.setProgress.bind(this),context:this.#$,Atom:G0,registerToPackageManager:this.registerToPackageManager.bind(this)},this.#L={initNode:this.initNode.bind(this),cloneDeep:S1,resolveTypeCommon:this.resolveTypeCommon.bind(this),resolveNextBlock:K6,transformExpression:this.transformExpression.bind(this),transformValue:this.transformValue.bind(this)}}async _cache_set($,Q,Z){}async init(){this.#_=this.#$.buildId||w1(),this.#V.buildId=this.#_,this.#U=this.#$.mode,this.#A=["all","deploy","build","file"].includes(this.#U),this.#j=["all","deploy","build"].includes(this.#U),this.#R=["all","deploy"].includes(this.#U),this.#F=["all","deploy","build","file","bpmn"].includes(this.#U),this.#O=this.#$.protocol,this.#q="BUILD:"+this.#_,this.#M=(await J2({optional:!0,name:"atom",dir:this.#$.projectDir,tags:this.#$.tags}))?.data;try{await this.setProgress({message:"Initialization started."});let $=this.#V.context.project;await this.initAuth(),await this.initWorkflow(),this.transformWorkflow({workflow:this.#X});let Q=await this.initNodeTree({workflow:this.#X});if(await this.initNodeTreeIndex({root:Q}),await this.initNodeCalls({root:Q}),await this.initNodeCallLibs({root:Q}),await this.initNodeForms({root:Q}),await this.initNodeFormLibs({root:Q}),await this.initEntryFiles({root:Q,features:this.#Z.doc.features}),await this.initFeaturesFromNodes({childs:Q.childs,features:this.#Z.doc.features}),await Y$(this.#V),$.runtime.type==="bun")await W$(this.#V);else await V$(this.#V);await this.initAtomLibsAndDeps({libs:Q.context.libs,packageDependencies:this.#I}),await this.resolveNodeTree({root:Q}),this.#W=Q}catch($){throw await this._cache_set(this.#q,{status:"FAILED",message:$?.message||$}),$}}async initAuth(){if(!this.#$.id)return;this.#G=await this.#Q.init({config:this.#M}),this.#V.atomAccessToken=this.#G}async initWorkflow(){let $=this.#$.id;this.#Z=this.#$.project?.workflowAtom||await G0.get({id:$}),this.#X=typeof this.#Z.doc.content==="string"?(await V2({content:this.#Z.doc.content,tags:this.#$.tags})).parsed:this.#Z.doc.content;let Q=this.#Z.doc.bundleName;Q=Q||(this.#Z.doc.name||"").toUpperCase().replace(/[^A-Z0-9]/g,"_"),this.#Z.doc.bundleName=Q,this.#Z.type=this.#Z.type||"workflow",this.#V.atom=this.#Z,this.#Z.doc.features=this.#Z.doc.features||{}}#T($){if(console.log("filePath",$),L.statSync($).isDirectory())L.readdirSync($).forEach((Q)=>{let Z=S.join($,Q);this.#T(Z)}),L.rmSync($);else L.unlinkSync($)}#B($,Q){let Z=L.existsSync($),X=Z&&L.statSync($);if(Z&&X.isDirectory())L.mkdirSync(Q,{recursive:!0}),L.readdirSync($).forEach((J)=>{this.#B(S.join($,J),S.join(Q,J))});else L.copyFileSync($,Q)}async initWorkflowDir(){this.setProgress({message:"Initializing library directory."});let $=this.#$.projectDir,Q=this.#$.coreDir;this.setProgress({message:"Cleaning project directory."});let Z=X1({dir:$,ignore:[".cache","node_modules",".conda",".bin",".dev"],absolute:!0});for(let Y of Z)L.rmSync(Y,{recursive:!0,force:!0});if(this.setProgress({message:"Creating project directory."}),!L.existsSync($))L.mkdirSync($,{recursive:!0});let X=S.join($,"src");if(!L.existsSync(X))L.mkdirSync(X,{recursive:!0});let q=S.join(X,"core");this.#B(Q,q);let J=S.join(X,"default","blocks");if(!L.existsSync(J))L.mkdirSync(J,{recursive:!0});let V=S.join($,".dev");if(!L.existsSync(V))L.mkdirSync(V,{recursive:!0})}async initNunjucks(){this.setProgress({message:"Initializing nunjucks."});let $=this.#$.templateDir;this.#J=V8.configure($,{watch:!1,dev:!0}),this.#V.njEnv=this.#J}transformWorkflow({workflow:$}){for(let Q of Object.values($))Q.steps=Q.steps||[],Q.steps=Q.steps.filter((Z)=>Object.keys(Z).length>0),Q.steps=Q.steps.map((Z)=>this.transformStep({step:Z}))}transformStep({step:$}){if(Array.isArray($))throw Error("Step must be an object.");let[Q,Z]=Object.entries($)[0];if(Z.hasOwnProperty("onerror")){let{onerror:X,...q}=Z;$[Q]={try:q,except:X}}if($[Q].hasOwnProperty("steps")){let X=$[Q].steps;if(!Array.isArray(X))throw Error("Steps must be an array.");$[Q].steps=X.map((q)=>this.transformStep({step:q}))}return $}async initNodeTree({workflow:$}){let Q=Object.keys($);if(F("tree"))N.info("\uD83C\uDF33 Creating root node",{depth:0});let Z={definition:$,name:void 0,type:"root",parent:void 0,childs:[],blockAutoJumpToParent:!0,blockAutoJumpToSibling:!0,index:0,depth:0,context:{libs:[],atom:this.#Z}};Q.forEach((X)=>{if(F("tree"))N.info(`\uD83D\uDCE6 Creating ${X==="main"?"workflow":"subworkflow"}: ${X}`,{depth:1,index:Z.childs.length,type:X==="main"?"workflow":"subworkflow"});let q={name:X,type:X==="main"?"workflow":"subworkflow",childs:[],parent:Z,definition:$[X],index:Z.childs.length,depth:Z.depth+1,context:{},blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1};Z.childs.push(q)});for await(let X of Z.childs){if(F("tree"))N.info(`\uD83D\uDD27 Initializing node: ${X.name}`,{depth:X.depth});await this.initNode({node:X})}if(F("tree"))N.info("✅ Root node tree created",{depth:0,totalFlows:Z.childs.length});return Z}async initNode({node:$}){let Q={...this.#L,node:$};$.workflow=$.parent.workflow||$,$.depth=$.parent.depth+1;let Z="unknown";if(await t$.hits(Q))Z="tryexcept",await t$.init(Q);else if(await $6.hits(Q))Z="for",await $6.init(Q);else if(await J8.hits(Q))Z="switch",await J8.init(Q);else if(await o$.hits(Q))Z="if",await o$.init(Q);else if(await Q6.hits(Q))Z="parallel",await Q6.init(Q);else if(await Y8.hits(Q))Z="call",await Y8.init(Q);else if(await _6.hits(Q))Z="new",await _6.init(Q);else if(await Z6.hits(Q))Z="raise",await Z6.init(Q);else if(await J6.hits(Q))Z="form",await J6.init(Q);else if(await Y6.hits(Q))Z="signal",await Y6.init(Q);else if(await V6.hits(Q))Z="wait",await V6.init(Q);else if(await q6.hits(Q))Z="steps",await q6.init(Q);else if(await W6.hits(Q))Z="next",await W6.init(Q);else if(await H6.hits(Q))Z="modules",await H6.init(Q);else if(await X6.hits(Q))Z="return",await X6.init(Q);else if(this.#K.find((X)=>X.hits(Q)))Z="npm-block",await this.#K.find((X)=>X.hits(Q)).init(Q);else if(await e$.hits(Q))Z="assign",await e$.init(Q);else if(await G6.hits(Q))Z="output",await G6.init(Q);else throw Error("Undefined step type.");if(F("tree"))N.info(` ├─ ${Z}: ${$.name}`,{depth:$.depth,index:$.index,type:Z,hasChilds:$.childs?.length>0,childCount:$.childs?.length||0})}async initNodeTreeIndex({root:$}){let Q={};$.indexKey="/";for await(let Z of $.childs)await this.initNodeIndex({node:Z,index:Q});return $.context.index=Q,Q}async initNodeIndex({node:$,index:Q}){let Z=S.join($.parent.indexKey,$.name);$.indexKey=Z,Q[Z]=$;let X=[],q=$;while(q?.parent)X.push(q.index),q=q.parent;X.reverse(),$.codeKey=`B_${X.join("_")}_${$.type}`,$.pathKey=`${X.join(".")}`,$.typeId=w1();for await(let J of $.childs)await this.initNodeIndex({node:J,index:Q})}async initNodeCalls({root:$}){let Q=$.context.index,Z=[];for await(let X of Object.keys(Q)){let q=Q[X];if(q.type!=="call"&&q.type!=="new")continue;Z.push(q)}return $.context.calls=Z,Z}async initNodeCallLibs({root:$}){let Q=[],Z=$.context.calls;for await(let X of Z){let q=X.definition.from||X.definition.import||X.definition.call,J=await this.findNodeCallTarget({refNode:X,curNode:X.parent})||{name:q,type:"atom",definition:X.definition},V=Q.find((Y)=>Y.name===J.name&&Y.type===J.type);if(!V)Q.push(J);X.target=V||J}return $.context.callLibs=Q,$.context.libs=[...$.context.libs,...Q],Q}async findNodeCallTarget({refNode:$,curNode:Q}){if(!Q)return;let Z=$.definition.call,X=Q.childs.find((q)=>q.name===Z&&q.type==="subworkflow");if(X)return X;else return await this.findNodeCallTarget({refNode:$,curNode:Q.parent})}async initNodeForms({root:$}){let Q=$.context.index,Z=[];for await(let X of Object.keys(Q)){let q=Q[X];if(q.type!=="form")continue;Z.push(q)}return $.context.forms=Z,Z}async initNodeFormLibs({root:$}){let Q=[],Z=$.context.forms;for await(let X of Z){let q=X.definition.from||X.definition.import||X.definition.form,J=await this.findNodeCallTarget({refNode:X,curNode:X.parent})||{name:q,type:"atom"},V=Q.find((Y)=>Y.name===J.name&&Y.type===J.type);if(!V)Q.push(J);X.target=V||J}return $.context.formLibs=Q,$.context.libs=[...$.context.libs,...Q],Q}async initFeaturesFromNodes({childs:$,features:Q}){for await(let Z of $){if(Z.type==="form"&&!Reflect.has(Q,"form"))Q.form=!0;await this.initFeaturesFromNodes({childs:Z.childs,features:Q})}}async initEntryFiles({root:$,features:Q}){for await(let Z of $.childs){let X;if(Z.name==="main")X="index.js";else if(Z.name==="cli")X="cli.js";else if(Z.name==="app")X="app.js";else if(Z.name==="api")X="api.js";else continue;Q[`${Z.name}_default_entry_file`]=X,Z.entryFile=X}}async findNodeFormTarget({refNode:$,curNode:Q}){if(!Q)return;let Z=$.definition.form,X=Q.childs.find((q)=>q.name===Z&&q.type==="subworkflow");if(X)return X;else return await this.findNodeFormTarget({refNode:$,curNode:Q.parent})}async initAtomLibsAndDeps({libs:$,packageDependencies:Q}){let Z=$.filter((X)=>X.type==="atom");for(let X=0;X<Z.length;X++){let q=Z[X],J=await this.findAtomLibrary({url:q.name,libRef:q});q.atom=J,J.doc.dependencies?.filter((Y)=>typeof Y.repo>"u"||Y.repo==="npm")?.forEach((Y)=>{let W=Q.find((H)=>H.package===Y.package);if(W){if(typeof Y.path==="string"){if(!(W.path||[]).some((H)=>H===Y.path))W.path=W.path||[],W.path.push(Y.path)}else if(Array.isArray(Y.path))Y.path.forEach((H)=>{if(!(W.path||[]).some((K)=>K===H))W.path=W.path||[],W.path.push(H)})}else Q.push(Y)})}Q.sort((X,q)=>X.package?.localeCompare(q.package))}async findAtomLibrary({url:$,libRef:Q}){let Z=q2({url:$});if(!Z)throw Error(`Invalid package name: ${$}`);if(!Z.protocol)Z.protocol=this.#O;if(Z.protocol==="src:"){let X=S.resolve(this.#$.projectSrcDir,`${Z.pathname}.js`),q=[],V=(await Y2({file:X,recursive:!0})).all;for await(let W of V){if(W.type!=="npm")continue;if(q.find((K)=>K.package===W.package))continue;let H=await v0({name:W.package,projectDir:this.#$.projectDir,setProgress:this.#V.setProgress});q.push({package:W.package,subpath:W.subpath,version:H.minorRange,type:"npm"})}return{name:Z.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:q},protocol:Z.protocol}}else if(Z.protocol==="npm:"){let X=F1({path:Z.pathname}),q=await v0({name:X.package,subpath:X.subpath,projectDir:this.#$.projectDir,setProgress:this.#V.setProgress});return{name:Z.pathname,doc:{type:"workflow.lib",subtype:Q?.definition?.subtype==="flow"?"workflow":null,"content-type":"javascript",language:"js",dependencies:[{package:X.package,version:q.minorRange,type:"npm"}]},protocol:Z.protocol}}else if(Z.protocol==="use:")return{name:Z.pathname,doc:{type:"function",dependencies:[]},protocol:Z.protocol};else if(Z.protocol==="node:")return{name:Z.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:[]},protocol:Z.protocol};else if(Z.protocol==="ac:"){let X=Z.pathname.split("/");if(X.length===1)return await G0.first({where:{name:$,parent_id:this.#M.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(X.length===2){let q=await G0.first({where:{name:X[0],parent_id:this.#M.env.ATOM_LIBRARIES_ID,type:"folder"}});return await G0.first({where:{name:X[1],parent_id:q.id,type:"workflow.lib"}})}}}async resolveNodeTree({root:$}){for await(let Q of $.childs)await this.resolveTypeWorkflow({node:Q})}async resolveTypeWorkflow({node:$}){$.context.transform=$.context.transform||S1($.definition);let Q=$.context.transform;for(let Z=0;Z<Q.params?.length;Z++){let X=Q.params[Z];if(typeof X==="string")Q.params[Z]={key:X,hasDefault:!1};else{let q=Object.keys(X)[0];Q.params[Z]={key:q,hasDefault:!0,default:X[q],type:typeof X[q]}}}$.context.next=$.childs[0];for await(let Z of $.childs)await this.resolveType({node:Z})}async resolveType({node:$}){let Q={...this.#L,node:$};if(typeof $.resolve==="function")await $.resolve(Q);for await(let Z of $.childs)await this.resolveType({node:Z})}async resolveTypeCommon({node:$}){let Q=$.context.transform;if(Q.hasOwnProperty("page"))Q.page=await this.transformExpression(Q.page);if(Q.hasOwnProperty("print"))Q.print=await this.transformExpression(Q.print);if(Q.hasOwnProperty("sleep"))Q.sleep=await this.transformExpression(Q.sleep);if(Q.hasOwnProperty("assert"))Q.assert=await this.transformExpression(Q.assert)}async createAtomLibFiles({root:$}){await this.setProgress({message:"Creating external lib files."}),this.#Z.typesDir="./types";let Z=$.context.libs.filter((X)=>X.type==="atom");for(let X=0;X<Z.length;X++){let J=Z[X].atom,V=this.#$.projectDir;if(J.protocol==="src:"){let Y=S.resolve(this.#$.projectSrcDir,`${J.fileName||J.name}.js`),W=S.relative(`${this.#$.projectDir}/src/default/blocks`,Y);if(!L.existsSync(Y)){L.mkdirSync(S.dirname(Y),{recursive:!0});let H=`export default async (input)=>{
7
- `;H+="}",L.writeFileSync(Y,H,"utf8")}J.relativePath=W.split(S.sep).join("/"),this.#Z.typesDir=`./types/${S.basename(V)}/src`}else if(J.protocol==="npm:")J.relativePath=J.name;else if(J.protocol==="node:")J.relativePath=J.name;else if(J.protocol==="use:");else{let Y=`${V}/src/libs/${J.id}.js`,W=J.doc.contents?.find((H)=>H.format==="esm")||J.doc;L.writeFileSync(S.normalize(Y),W.content,"utf8")}}}async createEngine({root:$}){await this.setProgress({message:"Creating engine file."});let Q=this.#$.templateDir,Z=V8.compile(L.readFileSync(S.resolve(Q,"src/default/engine.js.njk"),"utf8"),this.#J);for(let X=0;X<$.childs.length;X++){let q=$.childs[X];if(!q.entryFile)continue;let J=Z.render({flow:q,ui:{package:"@fnet/react-app"}}),V=this.#$.projectDir,Y=S.resolve(V,`src/default/${q.entryFile}`);L.writeFileSync(Y,J,"utf8")}}async createNodeTree({root:$}){await this.setProgress({message:"Creating block files."});for await(let Q of $.childs)await this.createTypeWorkflow({node:Q})}async createTypeWorkflow({node:$}){let Q=this.#$.templateDir,X=V8.compile(L.readFileSync(S.resolve(Q,"src/default/workflow.js.njk"),"utf8"),this.#J).render($),q=this.#$.projectDir,J=S.resolve(q,`src/default/${$.codeKey}.js`);L.writeFileSync(J,X,"utf8");for await(let V of $.childs)await this.createType({node:V})}async createType({node:$}){switch($.type){case"assign":case"steps":case"return":case"call":case"new":case"form":case"raise":case"switch":case"next":case"tryexcept":case"for":case"signal":case"wait":case"modules":case"output":this.createBlockFromTemplate({node:$});break;default:break}for await(let Q of $.childs)await this.createType({node:Q})}createBlockFromTemplate({node:$}){let Q=this.getBlockTemplate({node:$});$.context.render=Q.render($),this.createStepFile({node:$})}getBlockTemplate({node:$}){let Q=this.#H[$.type];if(Q)return Q;let Z=this.#$.templateDir;return Q=V8.compile(L.readFileSync(S.resolve(Z,`src/default/blocks/${$.type}.js.njk`),"utf8"),this.#J),this.#H[$.type]=Q,Q}createStepFile({node:$}){let Q=this.#$.projectDir,Z=`${$.codeKey}.js`,X=S.resolve(Q,`src/default/blocks/${Z}`);L.writeFileSync(X,$.context.render,"utf8"),$.context.fileName=Z,$.context.filePath=X}async transformExpression($){let Q=await this.transformValue($);return Q=JSON.stringify(Q),Q=this.replaceSpecialPattern(Q),Q}async transformValue($){if(Array.isArray($))for(let Q=0;Q<$.length;Q++)$[Q]=await this.transformValue($[Q]);else if(X2($)){let Q=Object.keys($);for(let Z=0;Z<Q.length;Z++){let X=Q[Z],q=P1({expression:X});if(q)if(q.processor==="e"){let J=$[X].replace(/(\r\n|\n|\r)/g,"");$[q.statement]=`$::${J}::`,delete $[X]}else $[X]=await this.transformValue($[X]);else $[X]=await this.transformValue($[X])}}else if(typeof $==="string"){let Q=P1({expression:$});if(Q){let{processor:Z,statement:X}=Q;switch(Z){case"v":$=`$::v.${X}::`;break;case"e":$=`$::${X}::`;break;case"m":$=`$::c.module?.${X}||flow.module?.${X}::`;break;case"f":$=`$::c.form.${X}::`;break;case"for":$=`$::caller.for.${X}::`;break}}}return $}replaceSpecialPattern($){let Q=/"\$::(.*?)::"/g;return $.replace(Q,"$1")}replaceExpressionLegacy($){let Q=/(?<outer>"\${(?<inner>[^{]*)}")/g;return $.replaceAll(Q,"$2")}async createProjectYaml(){await this.setProgress({message:"Creating fnet.yaml"});let{content:Z,...X}=this.#Z.doc,q=this.#$.projectDir,J=S.resolve(q,"fnet.yaml");L.writeFileSync(J,j1.stringify(X),"utf8")}async createProjectMainYaml(){await this.setProgress({message:"Creating flow.main.yaml"});let Z={content:j1.stringify(this.#X)},X=this.#$.templateDir,J=V8.compile(L.readFileSync(S.resolve(X,"flow.main.yaml.njk"),"utf8"),this.#J).render(Z),V=this.#$.projectDir,Y=S.resolve(V,"flow.main.yaml");L.writeFileSync(Y,J,"utf8")}async runPrettifier(){let $=this.#$.projectDir;if(W0("bun")){let Q=await T1("prettier --write .",{cwd:S.resolve($,"src")});if(Q.code!==0)throw Error(Q.stderr)}else{let Q=await T1("prettier --write .",{cwd:S.resolve($,"src")});if(Q.code!==0)throw Error(Q.stderr)}}async deploy(){if(await this.setProgress({message:"Deploying."}),this.#$.project?.devops){let $=[this.#$.project?.devops];for(let Q=0;Q<$.length;Q++){let Z=$[Q];if(await this.deployProject({deploymentProject:Z}),Z.isDirty===!0)await Z.save()}}else if(this.#Z.id){let $=await G0.list({type:"workflow.deploy",parent_id:this.#Z.id});for(let Q=0;Q<$.length;Q++){let Z=$[Q];if(await this.deployProject({deploymentProject:Z}),Z.isDirty===!0)Z=await G0.update(Z,{id:Z.id})}}}async deployProject($){let{deploymentProject:Q}=$,{yamlDocument:Z}=Q;if(Q.doc.targets&&Array.isArray(Q.doc.targets))throw Error("Deployment project targets are deprecated. Please update targets in the yaml file.");let X=Object.keys(Q.doc||{}),q=Z||{};for(let J=0;J<X.length;J++){let V=Q.doc[X[J]];V.name=X[J];let Y=q.get(X[J]);await a6({...this.#V,deploymentProject:Q,deploymentProjectTarget:V,yamlTarget:Y})}}async registerToPackageManager($){let{target:Q,packageJSON:Z}=$;if(!this.#$.id)return;let X=await G0.first({name:Q.params.name,parent_id:this.#M.env.ATOM_PACKAGES_ID});if(!X)X=await G0.create({parent_id:this.#M.env.ATOM_PACKAGES_ID,doc:{name:Q.params.name,type:"pm",versions:[{v:Z.version}]}});else X.doc.versions.splice(0,0,{v:Z.version}),await G0.update(X,{id:X.id})}async setProgress($){let Q=typeof $==="string"?$:$?.message;console.log(W2.blue(Q)),await this._cache_set(this.#q,{status:"IN_PROGRESS",message:Q})}async build(){if(this.#F&&!this.#A)return await this.createNetwork();try{let $=this.#F?await U8({root:this.#W}):void 0;if(this.#A){let Q=this.#V.context.project;if(await this.initWorkflowDir(),await this.initNunjucks(),this.#F){let Z=this.#$.project?.projectDir||this.#$.projectDir;if(Z=S.resolve(Z,"fnet"),L.existsSync(Z)){if(L.existsSync(S.resolve(Z,"flow.bpmn")))L.unlinkSync(S.resolve(Z,"flow.bpmn"));L.writeFileSync(S.resolve(Z,"flows.bpmn"),$.diagramXML,"utf8");let X=S.resolve(Z,"bpmn");if(!L.existsSync(X))L.mkdirSync(X,{recursive:!0});let q=await $5({root:this.#W});for(let J of q){let V=`${J.flowName}.bpmn`,Y=S.resolve(X,V);L.writeFileSync(Y,J.diagramXML,"utf8")}}}if(await this.createAtomLibFiles({root:this.#W}),await this.createEngine({root:this.#W}),await this.createNodeTree({root:this.#W}),await this.createProjectYaml(),await L$(this.#V),await I$(this.#V),await C$(this.#V),await R$(this.#V),await _$(this.#V),await H$(this.#V),Q.runtime.type==="bun")await O$(this.#V);else await U$(this.#V);if(await K$(this.#V),await F$(this.#V),await j$(this.#V),this.#j){if(await T$(this.#V),await S$(this.#V),this.#R)await this.deploy()}}await this._cache_set(this.#q,{status:"COMPLETED",data:{network:$}})}catch($){throw await this._cache_set(this.#q,{status:"FAILED",message:$.message||$}),$}}async createNetwork(){try{let $=await U8({root:this.#W});await this._cache_set(this.#q,{status:"COMPLETED",data:{...$}})}catch($){throw await this._cache_set(this.#q,{status:"FAILED",message:$.message||$}),$}}}var F0=N1;var H2={command:"build",describe:"Build flownet project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"})},handler:async($)=>{try{let Q=await w($),Z=new F0(Q);await Z.init(),await Z.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(Q){console.error("Building workflow failed!",Q.message),process.exit(1)}}},b1=H2;var K2={command:"build:dev",describe:"Build flownet project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"})},handler:async($)=>{try{$.dev=!0;let Q=await w($),Z=new F0(Q);await Z.init(),await Z.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(Q){console.error("Building workflow failed!",Q.message),process.exit(1)}}},k1=K2;var _2={command:"deploy",describe:"Build and deploy flownet project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"})},handler:async($)=>{try{let Q=await w({...$,mode:"all"}),Z=new F0(Q);await Z.init(),await Z.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(Q){console.error("Building workflow failed!",Q.message),process.exit(1)}}},D1=_2;var G2={command:"file",describe:"Just create files",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"})},handler:async($)=>{try{let Q=await w({...$,mode:"file"}),Z=new F0(Q);await Z.init(),await Z.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(Q){console.error("Building workflow failed!",Q.message),process.exit(1)}}},v1=G2;import E1 from"node:path";import v8 from"node:fs";import z2 from"@fnet/prompt";var U2={command:"input [name]",describe:"Create or modify an input config file",builder:($)=>{return $.positional("name",{type:"string",demandOption:!1,describe:"Input name"})},handler:async($)=>{try{let Q=await w($),{project:Z}=Q,{projectDir:X,projectFileParsed:q}=Z,J=q.input;if(!J)throw Error("Config schema not found in project file.");if(!Reflect.has($,"name")){let{inputName:G}=await z2({type:"input",name:"inputName",message:"Input name:",initial:"dev"});$.name=G}let V=E1.resolve(X,".fnet");if(!v8.existsSync(V))v8.mkdirSync(V);let Y=E1.resolve(V,`${$.name}.fnet`),W=v8.existsSync(Y),H=(await import("@fnet/object-from-schema")).default,K=await H({schema:J,format:"yaml",ref:W?Y:void 0});v8.writeFileSync(Y,K)}catch(Q){console.error(Q.message),process.exit(1)}}},y1=U2;import j from"node:path";import I from"node:fs";import y8 from"node:os";import{spawn as x8}from"node:child_process";import R from"chalk";import B0 from"@fnet/prompt";import E8 from"chalk";import x1 from"@fnet/prompt";async function M2($){let{items:Q,message:Z,nameField:X="name",valueField:q="name",initialValue:J=null,allowAbort:V=!0}=$;if(!Q||Q.length===0)return console.log(E8.yellow("No items available for selection.")),null;if(Q.length===1&&!V){let G=Q[0],_=typeof G==="string"?G:G[q];return console.log(E8.blue(`Only one option available: ${typeof G==="string"?G:G[X]}`)),_}let Y=Q.map((G)=>{if(typeof G==="string")return{name:G,value:G,message:G};else return{name:G[q],value:G[q],message:G[X]||G[q]}});if(V)Y.push({name:"cancel",value:null,message:E8.yellow("Cancel")});let W=null;if(J){let G=Y.findIndex((_)=>_.name===J);if(G!==-1)W=G}let H="selectedItem",{[H]:K}=await x1({type:"select",name:H,message:Z,choices:Y,initial:W});if(K==="cancel")return null;return K}async function O2($){let{items:Q,message:Z,nameField:X="name",valueField:q="name",initialValues:J=[],allowAbort:V=!0}=$;if(!Q||Q.length===0)return console.log(E8.yellow("No items available for selection.")),null;let Y=Q.map((G)=>{if(typeof G==="string")return{name:G,value:G,message:G};else return{name:G[q],value:G[q],message:G[X]||G[q]}}),W=[];if(J&&J.length>0)W=Y.map((G,_)=>J.includes(G.name)?_:-1).filter((G)=>G!==-1);let H="selectedItems",K=await x1({type:"multiselect",name:H,message:Z,choices:Y,initial:W,hint:"(Use space to select, enter to confirm)",validate:(G)=>{if(G.length===0&&!V)return"Please select at least one item";return!0}});if(V&&K[H].length===0)return null;return K[H]}var z6={promptForSelection:M2,promptForMultipleSelection:O2};var E=j.join(y8.homedir(),".fnet","express");async function f1($){$.command(["$0 [project-name]","create [project-name]"],"Create a new express project",(Q)=>{return Q.positional("project-name",{describe:"Name of the project",type:"string"}).option("yes",{alias:"y",describe:"Skip all prompts and use defaults",type:"boolean",default:!1}).option("runtime",{describe:"Runtime to use (node)",type:"string",choices:["node"],default:"node"})},async(Q)=>{await A2(Q)}).command("list","List express projects",(Q)=>{return Q.option("today",{describe:"Show only projects created today",type:"boolean",default:!1}).option("type",{describe:"Filter by project type (fnode or fnet)",type:"string",choices:["fnode","fnet"]}).option("all",{describe:"Show all projects regardless of type",type:"boolean",default:!1,alias:"a"}).option("name",{describe:"Filter by project name",type:"string"})},async(Q)=>{await B2(Q)}).command("open [project-name]","Open an express project",(Q)=>{return Q.positional("project-name",{describe:"Name of the project to open",type:"string"}).option("latest",{describe:"Open the most recent project",type:"boolean",default:!1})},async(Q)=>{await R2(Q)}).command("move [project-name] [destination]","Move an express project to a real project location",(Q)=>{return Q.positional("project-name",{describe:"Name of the project to move",type:"string"}).positional("destination",{describe:"Destination directory",type:"string"}).option("latest",{describe:"Move the most recent project",type:"boolean",default:!1})},async(Q)=>{await C2(Q)}).command("remove [project-name]","Remove an express project",(Q)=>{return Q.positional("project-name",{describe:"Name of the project to remove",type:"string"}).option("latest",{describe:"Remove the most recent project",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Skip confirmation prompt",type:"boolean",default:!1})},async(Q)=>{await L2(Q)}).command("enter [project-name]","Enter the directory of an express project in the active terminal",(Q)=>{return Q.positional("project-name",{describe:"Name of the project to enter",type:"string"}).option("latest",{describe:"Enter the most recent project directory",type:"boolean",default:!1})},async(Q)=>{await F2(Q)}).demandCommand(1,"You need to specify a command").help()}async function A2($){try{if(!I.existsSync(E))I.mkdirSync(E,{recursive:!0});let Q=new Date().toISOString().slice(0,10).replace(/-/g,""),Z=j.join(E,Q);if(!I.existsSync(Z))I.mkdirSync(Z,{recursive:!0});let X=$.projectName,q,J=$.runtime;if(!$.yes){if(!X){let _=I.readdirSync(Z).filter((U)=>U.startsWith("fnet-")).map((U)=>parseInt(U.replace("fnet-",""),10)).filter((U)=>!isNaN(U)),M=`fnet-${_.length>0?Math.max(..._)+1:1}`;X=(await B0([{type:"input",name:"projectName",message:"Enter project name:",default:M}])).projectName}J=(await B0({type:"select",name:"runtime",message:"Select runtime:",choices:["node"],initial:J||"node"})).runtime}else{if(!X){let K=I.readdirSync(Z).filter((_)=>_.startsWith("fnet-")).map((_)=>parseInt(_.replace("fnet-",""),10)).filter((_)=>!isNaN(_));X=`fnet-${K.length>0?Math.max(...K)+1:1}`}if(!J)J="node"}if(q=j.join(Z,X),I.existsSync(q)){let K=1;while(I.existsSync(j.join(Z,`${X}-${K}`)))K++;X=`${X}-${K}`,q=j.join(Z,X)}if(!$.yes){if(!(await B0([{type:"confirm",name:"proceed",message:`Create express project "${X}" in ${q}?`,default:!0}])).proceed){console.log(R.yellow("Project creation cancelled."));return}}console.log(R.blue(`Creating express project "${X}" in ${q}...`));let V=j.dirname(q),W=["create","--name",j.basename(q)];if(W.push("--runtime",J),$.yes)W.push("--yes");if(!I.existsSync(V))I.mkdirSync(V,{recursive:!0});let H=x8("fnet",W,{stdio:"inherit",shell:!0,cwd:V});return new Promise((K,G)=>{H.on("close",(_)=>{if(_===0)if(console.log(R.green(`
7
+ `;H+="}",L.writeFileSync(Y,H,"utf8")}J.relativePath=W.split(S.sep).join("/"),this.#Z.typesDir=`./types/${S.basename(V)}/src`}else if(J.protocol==="npm:")J.relativePath=J.name;else if(J.protocol==="node:")J.relativePath=J.name;else if(J.protocol==="use:");else{let Y=`${V}/src/libs/${J.id}.js`,W=J.doc.contents?.find((H)=>H.format==="esm")||J.doc;L.writeFileSync(S.normalize(Y),W.content,"utf8")}}}async createEngine({root:$}){await this.setProgress({message:"Creating engine file."});let Q=this.#$.templateDir,Z=V8.compile(L.readFileSync(S.resolve(Q,"src/default/engine.js.njk"),"utf8"),this.#J);for(let X=0;X<$.childs.length;X++){let q=$.childs[X];if(!q.entryFile)continue;let J=Z.render({flow:q,ui:{package:"@fnet/react-app"}}),V=this.#$.projectDir,Y=S.resolve(V,`src/default/${q.entryFile}`);L.writeFileSync(Y,J,"utf8")}}async createNodeTree({root:$}){await this.setProgress({message:"Creating block files."});for await(let Q of $.childs)await this.createTypeWorkflow({node:Q})}async createTypeWorkflow({node:$}){let Q=this.#$.templateDir,X=V8.compile(L.readFileSync(S.resolve(Q,"src/default/workflow.js.njk"),"utf8"),this.#J).render($),q=this.#$.projectDir,J=S.resolve(q,`src/default/${$.codeKey}.js`);L.writeFileSync(J,X,"utf8");for await(let V of $.childs)await this.createType({node:V})}async createType({node:$}){switch($.type){case"assign":case"steps":case"return":case"call":case"new":case"form":case"raise":case"switch":case"next":case"tryexcept":case"for":case"signal":case"wait":case"modules":case"output":this.createBlockFromTemplate({node:$});break;default:break}for await(let Q of $.childs)await this.createType({node:Q})}createBlockFromTemplate({node:$}){let Q=this.getBlockTemplate({node:$});$.context.render=Q.render($),this.createStepFile({node:$})}getBlockTemplate({node:$}){let Q=this.#H[$.type];if(Q)return Q;let Z=this.#$.templateDir;return Q=V8.compile(L.readFileSync(S.resolve(Z,`src/default/blocks/${$.type}.js.njk`),"utf8"),this.#J),this.#H[$.type]=Q,Q}createStepFile({node:$}){let Q=this.#$.projectDir,Z=`${$.codeKey}.js`,X=S.resolve(Q,`src/default/blocks/${Z}`);L.writeFileSync(X,$.context.render,"utf8"),$.context.fileName=Z,$.context.filePath=X}async transformExpression($){let Q=await this.transformValue($);return Q=JSON.stringify(Q),Q=this.replaceSpecialPattern(Q),Q}async transformValue($){if(Array.isArray($))for(let Q=0;Q<$.length;Q++)$[Q]=await this.transformValue($[Q]);else if(X2($)){let Q=Object.keys($);for(let Z=0;Z<Q.length;Z++){let X=Q[Z],q=P1({expression:X});if(q)if(q.processor==="e"){let J=$[X].replace(/(\r\n|\n|\r)/g,"");$[q.statement]=`$::${J}::`,delete $[X]}else $[X]=await this.transformValue($[X]);else $[X]=await this.transformValue($[X])}}else if(typeof $==="string"){let Q=P1({expression:$});if(Q){let{processor:Z,statement:X}=Q;switch(Z){case"v":$=`$::v.${X}::`;break;case"e":$=`$::${X}::`;break;case"m":$=`$::c.module?.${X}||flow.module?.${X}::`;break;case"f":$=`$::c.form.${X}::`;break;case"for":$=`$::caller.for.${X}::`;break}}}return $}replaceSpecialPattern($){let Q=/"\$::(.*?)::"/g;return $.replace(Q,"$1")}replaceExpressionLegacy($){let Q=/(?<outer>"\${(?<inner>[^{]*)}")/g;return $.replaceAll(Q,"$2")}async createProjectYaml(){await this.setProgress({message:"Creating fnet.yaml"});let{content:Z,...X}=this.#Z.doc,q=this.#$.projectDir,J=S.resolve(q,"fnet.yaml");L.writeFileSync(J,j1.stringify(X),"utf8")}async createProjectMainYaml(){await this.setProgress({message:"Creating flow.main.yaml"});let Z={content:j1.stringify(this.#X)},X=this.#$.templateDir,J=V8.compile(L.readFileSync(S.resolve(X,"flow.main.yaml.njk"),"utf8"),this.#J).render(Z),V=this.#$.projectDir,Y=S.resolve(V,"flow.main.yaml");L.writeFileSync(Y,J,"utf8")}async runPrettifier(){let $=this.#$.projectDir;if(W0("bun")){let Q=await T1("prettier --write .",{cwd:S.resolve($,"src")});if(Q.code!==0)throw Error(Q.stderr)}else{let Q=await T1("prettier --write .",{cwd:S.resolve($,"src")});if(Q.code!==0)throw Error(Q.stderr)}}async deploy(){if(await this.setProgress({message:"Deploying."}),this.#$.project?.devops){let $=[this.#$.project?.devops];for(let Q=0;Q<$.length;Q++){let Z=$[Q];if(await this.deployProject({deploymentProject:Z}),Z.isDirty===!0)await Z.save()}}else if(this.#Z.id){let $=await G0.list({type:"workflow.deploy",parent_id:this.#Z.id});for(let Q=0;Q<$.length;Q++){let Z=$[Q];if(await this.deployProject({deploymentProject:Z}),Z.isDirty===!0)Z=await G0.update(Z,{id:Z.id})}}}async deployProject($){let{deploymentProject:Q}=$,{yamlDocument:Z}=Q;if(Q.doc.targets&&Array.isArray(Q.doc.targets))throw Error("Deployment project targets are deprecated. Please update targets in the yaml file.");let X=Object.keys(Q.doc||{}),q=Z||{};for(let J=0;J<X.length;J++){let V=Q.doc[X[J]];V.name=X[J];let Y=q.get(X[J]);await a6({...this.#V,deploymentProject:Q,deploymentProjectTarget:V,yamlTarget:Y})}}async registerToPackageManager($){let{target:Q,packageJSON:Z}=$;if(!this.#$.id)return;let X=await G0.first({name:Q.params.name,parent_id:this.#M.env.ATOM_PACKAGES_ID});if(!X)X=await G0.create({parent_id:this.#M.env.ATOM_PACKAGES_ID,doc:{name:Q.params.name,type:"pm",versions:[{v:Z.version}]}});else X.doc.versions.splice(0,0,{v:Z.version}),await G0.update(X,{id:X.id})}async setProgress($){let Q=typeof $==="string"?$:$?.message;console.log(W2.blue(Q)),await this._cache_set(this.#q,{status:"IN_PROGRESS",message:Q})}async build(){if(this.#F&&!this.#A)return await this.createNetwork();try{let $=this.#F?await U8({root:this.#W}):void 0;if(this.#A){let Q=this.#V.context.project;if(await this.initWorkflowDir(),await this.initNunjucks(),this.#F){let Z=this.#$.project?.projectDir||this.#$.projectDir;if(Z=S.resolve(Z,"fnet"),L.existsSync(Z)){if(L.existsSync(S.resolve(Z,"flow.bpmn")))L.unlinkSync(S.resolve(Z,"flow.bpmn"));if(L.writeFileSync(S.resolve(Z,"flows.bpmn"),$.diagramXML,"utf8"),((this.#Z.doc.features||{}).bpmn||{}).per_flow===!0){let V=S.resolve(Z,"bpmn");if(!L.existsSync(V))L.mkdirSync(V,{recursive:!0});let Y=await $5({root:this.#W});for(let W of Y){let H=`${W.flowName}.bpmn`,K=S.resolve(V,H);L.writeFileSync(K,W.diagramXML,"utf8")}}}}if(await this.createAtomLibFiles({root:this.#W}),await this.createEngine({root:this.#W}),await this.createNodeTree({root:this.#W}),await this.createProjectYaml(),await L$(this.#V),await I$(this.#V),await C$(this.#V),await R$(this.#V),await _$(this.#V),await H$(this.#V),Q.runtime.type==="bun")await O$(this.#V);else await U$(this.#V);if(await K$(this.#V),await F$(this.#V),await j$(this.#V),this.#j){if(await T$(this.#V),await S$(this.#V),this.#R)await this.deploy()}}await this._cache_set(this.#q,{status:"COMPLETED",data:{network:$}})}catch($){throw await this._cache_set(this.#q,{status:"FAILED",message:$.message||$}),$}}async createNetwork(){try{let $=await U8({root:this.#W});await this._cache_set(this.#q,{status:"COMPLETED",data:{...$}})}catch($){throw await this._cache_set(this.#q,{status:"FAILED",message:$.message||$}),$}}}var F0=N1;var H2={command:"build",describe:"Build flownet project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"})},handler:async($)=>{try{let Q=await w($),Z=new F0(Q);await Z.init(),await Z.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(Q){console.error("Building workflow failed!",Q.message),process.exit(1)}}},b1=H2;var K2={command:"build:dev",describe:"Build flownet project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"})},handler:async($)=>{try{$.dev=!0;let Q=await w($),Z=new F0(Q);await Z.init(),await Z.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(Q){console.error("Building workflow failed!",Q.message),process.exit(1)}}},k1=K2;var _2={command:"deploy",describe:"Build and deploy flownet project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"})},handler:async($)=>{try{let Q=await w({...$,mode:"all"}),Z=new F0(Q);await Z.init(),await Z.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(Q){console.error("Building workflow failed!",Q.message),process.exit(1)}}},D1=_2;var G2={command:"file",describe:"Just create files",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"})},handler:async($)=>{try{let Q=await w({...$,mode:"file"}),Z=new F0(Q);await Z.init(),await Z.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(Q){console.error("Building workflow failed!",Q.message),process.exit(1)}}},v1=G2;import E1 from"node:path";import v8 from"node:fs";import z2 from"@fnet/prompt";var U2={command:"input [name]",describe:"Create or modify an input config file",builder:($)=>{return $.positional("name",{type:"string",demandOption:!1,describe:"Input name"})},handler:async($)=>{try{let Q=await w($),{project:Z}=Q,{projectDir:X,projectFileParsed:q}=Z,J=q.input;if(!J)throw Error("Config schema not found in project file.");if(!Reflect.has($,"name")){let{inputName:G}=await z2({type:"input",name:"inputName",message:"Input name:",initial:"dev"});$.name=G}let V=E1.resolve(X,".fnet");if(!v8.existsSync(V))v8.mkdirSync(V);let Y=E1.resolve(V,`${$.name}.fnet`),W=v8.existsSync(Y),H=(await import("@fnet/object-from-schema")).default,K=await H({schema:J,format:"yaml",ref:W?Y:void 0});v8.writeFileSync(Y,K)}catch(Q){console.error(Q.message),process.exit(1)}}},y1=U2;import j from"node:path";import I from"node:fs";import y8 from"node:os";import{spawn as x8}from"node:child_process";import R from"chalk";import B0 from"@fnet/prompt";import E8 from"chalk";import x1 from"@fnet/prompt";async function M2($){let{items:Q,message:Z,nameField:X="name",valueField:q="name",initialValue:J=null,allowAbort:V=!0}=$;if(!Q||Q.length===0)return console.log(E8.yellow("No items available for selection.")),null;if(Q.length===1&&!V){let G=Q[0],_=typeof G==="string"?G:G[q];return console.log(E8.blue(`Only one option available: ${typeof G==="string"?G:G[X]}`)),_}let Y=Q.map((G)=>{if(typeof G==="string")return{name:G,value:G,message:G};else return{name:G[q],value:G[q],message:G[X]||G[q]}});if(V)Y.push({name:"cancel",value:null,message:E8.yellow("Cancel")});let W=null;if(J){let G=Y.findIndex((_)=>_.name===J);if(G!==-1)W=G}let H="selectedItem",{[H]:K}=await x1({type:"select",name:H,message:Z,choices:Y,initial:W});if(K==="cancel")return null;return K}async function O2($){let{items:Q,message:Z,nameField:X="name",valueField:q="name",initialValues:J=[],allowAbort:V=!0}=$;if(!Q||Q.length===0)return console.log(E8.yellow("No items available for selection.")),null;let Y=Q.map((G)=>{if(typeof G==="string")return{name:G,value:G,message:G};else return{name:G[q],value:G[q],message:G[X]||G[q]}}),W=[];if(J&&J.length>0)W=Y.map((G,_)=>J.includes(G.name)?_:-1).filter((G)=>G!==-1);let H="selectedItems",K=await x1({type:"multiselect",name:H,message:Z,choices:Y,initial:W,hint:"(Use space to select, enter to confirm)",validate:(G)=>{if(G.length===0&&!V)return"Please select at least one item";return!0}});if(V&&K[H].length===0)return null;return K[H]}var z6={promptForSelection:M2,promptForMultipleSelection:O2};var E=j.join(y8.homedir(),".fnet","express");async function f1($){$.command(["$0 [project-name]","create [project-name]"],"Create a new express project",(Q)=>{return Q.positional("project-name",{describe:"Name of the project",type:"string"}).option("yes",{alias:"y",describe:"Skip all prompts and use defaults",type:"boolean",default:!1}).option("runtime",{describe:"Runtime to use (node)",type:"string",choices:["node"],default:"node"})},async(Q)=>{await A2(Q)}).command("list","List express projects",(Q)=>{return Q.option("today",{describe:"Show only projects created today",type:"boolean",default:!1}).option("type",{describe:"Filter by project type (fnode or fnet)",type:"string",choices:["fnode","fnet"]}).option("all",{describe:"Show all projects regardless of type",type:"boolean",default:!1,alias:"a"}).option("name",{describe:"Filter by project name",type:"string"})},async(Q)=>{await B2(Q)}).command("open [project-name]","Open an express project",(Q)=>{return Q.positional("project-name",{describe:"Name of the project to open",type:"string"}).option("latest",{describe:"Open the most recent project",type:"boolean",default:!1})},async(Q)=>{await R2(Q)}).command("move [project-name] [destination]","Move an express project to a real project location",(Q)=>{return Q.positional("project-name",{describe:"Name of the project to move",type:"string"}).positional("destination",{describe:"Destination directory",type:"string"}).option("latest",{describe:"Move the most recent project",type:"boolean",default:!1})},async(Q)=>{await C2(Q)}).command("remove [project-name]","Remove an express project",(Q)=>{return Q.positional("project-name",{describe:"Name of the project to remove",type:"string"}).option("latest",{describe:"Remove the most recent project",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Skip confirmation prompt",type:"boolean",default:!1})},async(Q)=>{await L2(Q)}).command("enter [project-name]","Enter the directory of an express project in the active terminal",(Q)=>{return Q.positional("project-name",{describe:"Name of the project to enter",type:"string"}).option("latest",{describe:"Enter the most recent project directory",type:"boolean",default:!1})},async(Q)=>{await F2(Q)}).demandCommand(1,"You need to specify a command").help()}async function A2($){try{if(!I.existsSync(E))I.mkdirSync(E,{recursive:!0});let Q=new Date().toISOString().slice(0,10).replace(/-/g,""),Z=j.join(E,Q);if(!I.existsSync(Z))I.mkdirSync(Z,{recursive:!0});let X=$.projectName,q,J=$.runtime;if(!$.yes){if(!X){let _=I.readdirSync(Z).filter((U)=>U.startsWith("fnet-")).map((U)=>parseInt(U.replace("fnet-",""),10)).filter((U)=>!isNaN(U)),M=`fnet-${_.length>0?Math.max(..._)+1:1}`;X=(await B0([{type:"input",name:"projectName",message:"Enter project name:",default:M}])).projectName}J=(await B0({type:"select",name:"runtime",message:"Select runtime:",choices:["node"],initial:J||"node"})).runtime}else{if(!X){let K=I.readdirSync(Z).filter((_)=>_.startsWith("fnet-")).map((_)=>parseInt(_.replace("fnet-",""),10)).filter((_)=>!isNaN(_));X=`fnet-${K.length>0?Math.max(...K)+1:1}`}if(!J)J="node"}if(q=j.join(Z,X),I.existsSync(q)){let K=1;while(I.existsSync(j.join(Z,`${X}-${K}`)))K++;X=`${X}-${K}`,q=j.join(Z,X)}if(!$.yes){if(!(await B0([{type:"confirm",name:"proceed",message:`Create express project "${X}" in ${q}?`,default:!0}])).proceed){console.log(R.yellow("Project creation cancelled."));return}}console.log(R.blue(`Creating express project "${X}" in ${q}...`));let V=j.dirname(q),W=["create","--name",j.basename(q)];if(W.push("--runtime",J),$.yes)W.push("--yes");if(!I.existsSync(V))I.mkdirSync(V,{recursive:!0});let H=x8("fnet",W,{stdio:"inherit",shell:!0,cwd:V});return new Promise((K,G)=>{H.on("close",(_)=>{if(_===0)if(console.log(R.green(`
8
8
  Express project "${X}" created successfully!`)),console.log(R.blue(`
9
9
  Project location: ${q}`)),!$.yes)I2(q);else K();else console.error(R.red(`
10
10
  Failed to create express project "${X}".`)),G(Error(`Process exited with code ${_}`))})})}catch(Q){console.error(R.red(`Error creating express project: ${Q.message}`)),process.exit(1)}}async function B2($){try{if(!I.existsSync(E)){console.log(R.yellow("No express projects found."));return}let Q=I.readdirSync(E).filter((V)=>/^\d{8}$/.test(V)).sort((V,Y)=>Y.localeCompare(V));if($.today){let V=new Date().toISOString().slice(0,10).replace(/-/g,""),Y=Q.indexOf(V);if(Y===-1){console.log(R.yellow("No express projects found for today."));return}Q.splice(0,Y),Q.splice(1)}let Z=[];if(!$.type&&!$.all)$.type="fnet";for(let V of Q){let Y=j.join(E,V),W=I.readdirSync(Y);for(let H of W){let K=j.join(Y,H),G=I.statSync(K),_="unknown";if(H.startsWith("fnode-")||I.existsSync(j.join(K,"fnode.yaml")))_="fnode";else if(H.startsWith("fnet-")||I.existsSync(j.join(K,"fnet.yaml")))_="fnet";if($.type&&_!==$.type)continue;if($.name&&!H.includes($.name))continue;let O=`${V.slice(0,4)}-${V.slice(4,6)}-${V.slice(6,8)}`;Z.push({name:H,type:_,date:O,path:K,created:G.birthtime})}}if(Z.sort((V,Y)=>Y.created-V.created),Z.length===0){console.log(R.yellow("No express projects found matching the criteria."));return}console.log(R.blue(`
@@ -1,3 +1,3 @@
1
- import{b as CT,c as jT,d as lT}from"./index.s0nk6cv8.js";import{f as j}from"./index.05n3mvs9.js";import"./index.cvxrf34y.js";import F from"node:fs";import b from"node:path";import aT from"nunjucks";import eT from"@flownet/lib-parse-imports-js";import T0 from"@flownet/lib-parse-node-url";import I from"lodash.merge";import l from"node:fs";import N from"node:path";import _ from"@flownet/lib-parse-imports-js";import wT from"lodash.merge";function S({feature:$,features:O,packageDevDependencies:z}){let{name:W,packages:T,options:K,extraCheck:Q,explicit:G}=$,Y=`${W}_enabled`,M=O.rollup_output||{},A=Object.keys(M),J=K||{},V=O[W]?.options;if(V)J=wT(J,V);let X=!O[W]||O[W]?.enabled===!1;A.forEach((Z)=>{let q=O.rollup_output[Z];if(!q)return;if(Reflect.has(q,W)){if(X||!q[W]||q[W]?.enabled===!1){delete q[W];return}if(q[W]===!0)q[W]={enabled:!0,options:J}}else if(!X&&!G&&O[Y]!==!1)q[W]={enabled:!0};else return;q[W]=q[W]||{},q[W].options={...J,...q[W].options}});let y=A.some((Z)=>O.rollup_output[Z][W]?.enabled===!0);if(Q)y=Q()&&y;if(O[Y]=y,y)T.forEach((Z)=>z.push({package:Z[0],version:Z[1]}))}function w($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"workbox",packages:[["rollup-plugin-workbox","^8"]],options:{generate:{swDest:"dist/app/esm/sw.js",globDirectory:"dist/app/esm",globPatterns:["**/*.{html,js,css,png,jpg}"],skipWaiting:!0,clientsClaim:!0}},explicit:!0},features:W,packageDevDependencies:z})}function P($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:W,packageDevDependencies:z})}function v($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:W,packageDevDependencies:z})}function m($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:W,packageDevDependencies:z})}function k($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]],expilicit:!0},features:W,packageDevDependencies:z})}function f($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:W,packageDevDependencies:z})}function g($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:W,packageDevDependencies:z})}function o($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:W,packageDevDependencies:z})}function i($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;if(W.runtime.type==="bun")return;S({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:W,packageDevDependencies:z})}function u($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:W,packageDevDependencies:z})}function d($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:W,packageDevDependencies:z})}function D($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;if(W.runtime.type==="bun")return;let T={};if(W.app?.enabled===!0){if(T.targets=T.targets||[],T.targets.push({src:"./src/app/index.html",dest:W.app.dir}),!Reflect.has(W.app,"copy")){if(!Reflect.has(W,"copy"))W.copy=!0}}S({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:T},features:W,packageDevDependencies:z})}function c($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features,T=W.css&&W.css.enabled!==!1,K=[];if(T)K.push(["rollup-plugin-postcss","^4"]),K.push(["sass","^1.66"]),(W.css?.options?.plugins||[]).forEach((G)=>{switch(G.name){case"postcss-import":K.push(["postcss-import","^15"]);break;case"postcss-url":K.push(["postcss-url","^10"]);break;case"postcss-preset-env":K.push(["postcss-preset-env","^9"]);break;case"autoprefixer":K.push(["autoprefixer","^10"]);break;case"cssnano":K.push(["cssnano","^6"]);break}});S({feature:{name:"css",packages:K},features:W,packageDevDependencies:z})}function r({dir:$,name:O="index"}){let z=N.resolve($,`./${O}.tsx`);if(!l.existsSync(z))z=N.resolve($,`./${O}.ts`);if(!l.existsSync(z))z=N.resolve($,`./${O}.jsx`);if(!l.existsSync(z))z=N.resolve($,`./${O}.js`);if(!l.existsSync(z))return{};let W=z,T=N.extname(z);return{file:W,ext:T,ts:T===".ts"||T===".tsx",name:O}}async function n($){let{atom:O,context:z,setProgress:W}=$;W("Initializing features..."),O.doc.features=O.doc.features||{};let T=O.doc.features;T.project=T.project||{},T.project.format=T.project.format||T.project_format||"esm",T.project_format=T.project.format,T.dts_enabled=T.dts===!0||typeof T.dts<"u"&&T.dts!==!1;let K=N.resolve(z.project.projectDir),Q=r({dir:N.resolve(K,"./app")});if(Q.file){W("Parsing app entry imports...");let Z=await _({file:Q.file,recursive:!0}),q=Z.all.some((H)=>H.usesJSX===!0&&H.type==="local");T.app_uses_jsx=q,T.app_has_entry=!0,Z=await _({file:Q.file}),q=Z.all.some((H)=>H.usesJSX===!0&&H.type==="local"),T.app_entry_uses_jsx=q,T.app_entry_is_ts=Q.ts,T.app_entry_ext=Q.ext}let G=r({dir:N.resolve(K,"./cli")});if(G.file){W("Parsing cli entry imports...");let Z=await _({file:G.file,recursive:!0}),q=Z.all.some((H)=>H.usesJSX===!0&&H.type==="local");T.cli_uses_jsx=q,T.cli_has_entry=!0,Z=await _({file:G.file}),q=Z.all.some((H)=>H.usesJSX===!0&&H.type==="local"),T.cli_entry_uses_jsx=q,T.cli_entry_is_ts=G.ts,T.cli_entry_ext=G.ext}if(O.type==="workflow.lib"){let Z=r({dir:N.resolve(K,"./src")});if(Z.file){W("Parsing src entry imports...");let q=await _({file:Z.file,recursive:!0}),H=q.all.some((U)=>U.usesJSX===!0&&U.type==="local");T.src_uses_jsx=H,T.src_has_entry=!0,q=await _({file:Z.file}),H=q.all.some((U)=>U.usesJSX===!0&&U.type==="local"),T.src_entry_uses_jsx=H,T.src_entry_is_ts=Z.ts,T.src_entry_ext=Z.ext}}let Y=Reflect.has(T,"app_entry_uses_jsx")?T.app_entry_uses_jsx===!0:T.src_entry_uses_jsx===!0,M=Reflect.has(T,"cli_entry_uses_jsx")?T.cli_entry_uses_jsx===!0:T.src_entry_uses_jsx===!0;if(T.form_enabled=Y||M||T.form===!0||T.form?.enabled===!0,T.multiple_enabled=T.multiple_enabled||T.multiple===!0||T.multiple?.enabled===!0,T.app===!1)T.app={enabled:!1};else if(T.app===!0)T.app={enabled:!0,extend:T.app_has_entry===!0,export:!0,react:Y};else T.app={enabled:!0,extend:T.app_has_entry===!0,export:!0,react:Y,...T.app||{}};if(T.app.enabled=T.app.enabled===!0&&(O.doc.features.form_enabled===!0||T.app.extend===!0||T.app.enabled===!0),T.app.format=T.app.format||"esm",T.app.folder=T.app.folder||T.app.format||"default",T.cli===!1)T.cli={enabled:!1};else if(T.cli===!0)T.cli={enabled:!0,extend:T.cli_has_entry===!0,export:!0,react:M};else T.cli={enabled:!0,extend:T.cli_has_entry===!0,export:!0,react:M,...T.cli||{}};if(T.cli.enabled=T.cli.enabled===!0&&(O.doc.features.form_enabled===!1||T.cli.extend===!0||T.cli.enabled===!0),T.cli.format=T.cli.format||"esm",T.cli.folder=T.cli.folder||T.cli.folder||"esm",T.cli.node_options=T.cli.node?.options||T.cli.node_options||"",T.cli.bin=T.cli.bin||O.doc.name,T.cli.installable=T.cli.installable===!0,T.cli.enabled)O.doc["npm::bin"]=T.cli.bin;T.json=T.cli.enabled||T.json;let A={cjs:{format:"cjs",context:T.form_enabled?"window":"global",babel:T.src_uses_jsx===!0||!1,browser:!1,replace:!0,terser:!0,enabled:T.cjs!==!1,copy:!1},esm:{format:"esm",context:T.form_enabled?"window":"global",babel:T.src_uses_jsx===!0||!1,browser:!1,replace:!0,terser:!1,enabled:T.esm!==!1,copy:!0},iife:{format:"iife",context:T.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:T.iife===!0,terser:!0,copy:!1}},J={targets:{browsers:"last 9 versions, not dead",node:"18"}},V={};if(T.webos===!0)A.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",copy:!1,babel_options:{targets:{chrome:"79"}}};if(T.electron===!0)A.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/electron"};if(T.nextjs===!0)A.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"};if(T.ios===!0)A.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/ios"};if(T.macos===!0)A.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/macos"};if(T.app.enabled===!0)T.app.dir=`./dist/app/${T.app.folder}`,T.app.output={file:`./dist/app/${T.app.folder}/index.js`,dir:`./dist/app/${T.app.folder}/`,...T.app.output||{}},T.app.input={file:"./src/app/index.js",dir:"./src/app/",...T.app.input||{}},A.app={format:T.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:T.app.input.file,output_dir:T.app.dir,terser:!0,output_exports:T.app.export===!1?"none":"auto",browsersync:!0};if(T.cli.enabled===!0)T.cli.dir=`./dist/cli/${T.cli.folder}`,T.cli.output={file:`./dist/cli/${T.cli.folder}/index.js`,dir:`./dist/cli/${T.cli.folder}/`,...T.cli.output||{}},T.cli.input={file:"./src/cli/index.js",dir:"./src/cli/",...T.cli.input||{}},A.cli={format:T.cli.format,context:"global",babel:T.src_uses_jsx===!0||T.cli_uses_jsx===!0||!1,browser:!1,replace:!0,enabled:!0,input:T.cli.input.file,output_dir:T.cli.dir,banner:"#!/usr/bin/env bun",terser:!0,output_exports:T.cli.export===!1?"none":"auto"};let X={server:".",startPath:`${N.normalize(T.app.dir||".")}`,files:[N.normalize("./dist/**/*")],cors:!0,open:!1};if(T.babel_options=I(J,T.babel_options||T.babel?.options),T.browsersync_options=I(X,T.browsersync_options||T.browsersync?.options||{}),T.replace_options=I(V,T.replace_options||T.replace?.options||{}),Reflect.has(T.browsersync_options,"proxy"))delete T.browsersync_options.server;T.rollup=T.rollup||{},T.rollup_output=I(A,T.rollup_output||T.rollup?.output||{}),T.preact_enabled=T.preact===!0||T.preact&&T.preact?.enabled!==!1;let y=Object.keys(A);for(let Z of y){let q=A[Z];if(!q)continue;if(T.rollup[Z]===!1){delete T.rollup_output[Z];continue}if(q.babel_options=q.babel_options||T.babel_options,q.browsersync_options=I(T.browsersync_options,q.browsersync_options),q.replace_options=I(T.replace_options,q.replace_options),T.preact_enabled)q.alias_enabled=!0,q.alias=q.alias||{},q.alias.entries=q.alias.entries||{},q.alias.entries.react="preact/compat",q.alias.entries["react-dom"]="preact/compat";if(T.form_enabled||T.babel)q.babel=!0}y=Object.keys(T.rollup_output),T.babel_enabled=y.some((Z)=>T.rollup_output[Z].babel===!0),T.browser_enabled=y.some((Z)=>T.rollup_output[Z].babel===!0),T.browsersync_enabled=T.browsersync!==!1&&y.some((Z)=>T.rollup_output[Z].browsersync===!0),T.browsersync_enabled=T.browsersync_enabled&&T.app.enabled,T.dependency_auto_enabled=T.dependency_auto!==!1&&T.dependency_auto?.enabled!==!1,T.npm_install_flags=T.npm_install_flags||"",T.react_version=T.react_version||T.react?.version||18,c($),D($),d($),u($),i($),g($),o($),f($),k($),m($),v($),w($),P($)}import PT from"@fnet/npm-list-versions";async function p({atom:$,packageDependencies:O,packageDevDependencies:z,setProgress:W}){W("Initializing dependencies");let T=$.doc.dependencies||[];if(T.filter((K)=>!K.dev).forEach((K)=>O.push(K)),T.filter((K)=>K.dev).forEach((K)=>z.push(K)),$.type==="workflow")O.push({package:"get-value",version:"^3"}),O.push({package:"set-value",version:"^4"});if($.doc.features.form_enabled){if($.doc.features.dependency_auto_enabled){let K="^18.2";if(W("Fetching React versions"),K=`^${(await PT({name:"react",groupBy:{major:!0}})).find((Y)=>Y[0]===$.doc.features.react_version.toString())[0]}`,O.push({package:"react",version:K}),O.push({package:"react-dom",version:K}),$.type==="workflow")O.push({package:"@fnet/react-app",version:"^0.1"}),O.push({package:"@fnet/react-app-state",version:"^0.1"})}}if($.doc.features.preact_enabled)O.push({package:"preact",version:"^10"});if($.doc.features.cli.enabled===!0){if(O.push({package:"@fnet/args",version:"^0.1"}),$.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1)O.push({package:"@fnet/config",version:"0.2.21"});if($.doc.features.cli.mcp&&$.doc.features.cli.mcp.enabled===!0)O.push({package:"@modelcontextprotocol/sdk",version:"^1.10"}),O.push({package:"express",version:"^4.18"})}if($.doc.features.render&&$.doc.features.render.enabled!==!1)z.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"});if(z.push({package:"@babel/core",version:"^7"}),z.push({package:"@rollup/plugin-commonjs",version:"^28"}),z.push({package:"@rollup/plugin-node-resolve",version:"^16"}),z.push({package:"@rollup/plugin-replace",version:"^6"}),z.push({package:"rollup",version:"^4"}),$.doc.features.dts_enabled)z.push({package:"rollup-plugin-dts",version:"^6"});if(z.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),z.push({package:"@rollup/plugin-alias",version:"^5"}),z.push({package:"fs-extra",version:"^11"}),$.doc.features.babel_enabled)z.push({package:"@rollup/plugin-babel",version:"^6"}),z.push({package:"@babel/preset-env",version:"^7"}),z.push({package:"@babel/preset-react",version:"^7"}),$.doc.features.babel?.options?.plugins?.forEach((K)=>{switch(K[0]){case"@babel/plugin-proposal-decorators":z.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":z.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":z.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":z.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":z.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"});break}});if(z.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),$.doc.features.browsersync_enabled)z.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})}import vT from"@fnet/npm-list-versions";async function s({atom:$,packageDependencies:O,packageDevDependencies:z,setProgress:W}){W("Initializing dependencies for Bun");let T=$.doc.dependencies||[];if(T.filter((K)=>!K.dev).forEach((K)=>O.push(K)),T.filter((K)=>K.dev).forEach((K)=>z.push(K)),$.type==="workflow")O.push({package:"get-value",version:"^3"}),O.push({package:"set-value",version:"^4"});if($.doc.features.form_enabled){if($.doc.features.dependency_auto_enabled){let K="^18.2";if(W("Fetching React versions"),K=`^${(await vT({name:"react",groupBy:{major:!0}})).find((Y)=>Y[0]===$.doc.features.react_version.toString())[0]}`,O.push({package:"react",version:K}),O.push({package:"react-dom",version:K}),$.type==="workflow")O.push({package:"@fnet/react-app",version:"^0.1"}),O.push({package:"@fnet/react-app-state",version:"^0.1"})}}if($.doc.features.preact_enabled)O.push({package:"preact",version:"^10"});if($.doc.features.cli.enabled===!0){if(O.push({package:"@fnet/args",version:"^0.1"}),$.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1)O.push({package:"@fnet/config",version:"0.2.21"});if($.doc.features.cli.mcp&&$.doc.features.cli.mcp.enabled===!0)O.push({package:"@modelcontextprotocol/sdk",version:"^1.10"}),O.push({package:"express",version:"^4.18"})}if($.doc.features.render&&$.doc.features.render.enabled!==!1)z.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"})}import AT from"node:fs";import ST from"node:path";import mT from"@flownet/lib-render-templates-dir";async function t({atom:$,setProgress:O,context:z,packageDependencies:W}){if($.doc.features.app.enabled!==!0)return;await O({message:"Creating app folder"});let T={atom:$,packageDependencies:W,ts:Date.now()},K=z.templateDir,Q=ST.resolve(z.projectDir,"src/app");if(!AT.existsSync(Q))AT.mkdirSync(Q,{recursive:!0});let G=["index.js.njk"];if($.doc.features.app.html!==!1)G.push("index.html.njk");await mT({pattern:G,dir:ST.resolve(K,"src/app"),outDir:Q,context:T})}import yT from"nunjucks";import B from"node:fs";import E from"node:path";import gT from"@flownet/lib-parse-imports-js";import kT from"@fnet/npm-pick-versions";import fT from"object-hash";import h from"node:fs";import UT from"node:path";async function C({projectDir:$,name:O,setProgress:z,count:W=1}){let T,Q=fT(["npm-pick-versions",O,W]),G=UT.join($,".cache"),Y=UT.join(G,Q+".json");if(h.existsSync(Y)){if(z)z(`Picking npm version of ${O} from cache ...`);T=JSON.parse(h.readFileSync(Y,"utf8"))}else{if(z)z(`Picking npm version of ${O} ...`);T=await kT({name:O,count:W}),h.mkdirSync(G,{recursive:!0}),h.writeFileSync(Y,JSON.stringify(T),"utf8")}return T}async function a({atom:$,context:O,packageDependencies:z,packageDevDependencies:W,setProgress:T}){await T({message:"Creating package.json."}),z.filter((q)=>q.dev===!0).forEach((q)=>{if(!W.find((U)=>U.package===q.package))W.push(q);let H=z.findIndex((U)=>U.package===q.package);z.splice(H,1)});let Q=z.find((q)=>q.package==="react"),G=z.find((q)=>q.package==="react-dom");if(Q&&!G)z.push({package:"react-dom",version:Q.version});else if(Q&&G)G.version=Q.version;if(Q&&$.doc.features.react_version>=17){if(!z.find((q)=>q.package==="@emotion/react"))z.push({package:"@emotion/react",version:"^11"});if(!z.find((q)=>q.package==="@emotion/styled"))z.push({package:"@emotion/styled",version:"^11"})}let Y=[];if($.doc.features.app.enabled===!0)Y.push({file:E.resolve(O.projectDir,"src/app/index.js"),dev:$.doc.features.app.dev!==!1});if($.doc.features.cli.enabled===!0)Y.push({file:E.resolve(O.projectDir,"src/cli/index.js"),dev:$.doc.features.cli.dev!==!1});for await(let q of Y){let H=q.file;if(!B.existsSync(H))throw Error(`App file not found: ${H}`);let R=(await gT({file:H,recursive:!0,verbose:!1})).all;for await(let L of R){if(L.type!=="npm")continue;if(z.find((x)=>x.package===L.package))continue;if(W.find((x)=>x.package===L.package))continue;let xT=await C({name:L.package,projectDir:O.projectDir,setProgress:T});(q.dev===!0?W:z).push({package:L.package,subpath:L.subpath,version:xT.minorRange,type:"npm"})}}let M={atom:$,packageDependencies:z,packageDevDependencies:W},A=O.templateDir,V=yT.compile(B.readFileSync(E.resolve(A,"package.json.njk"),"utf8"),yT.configure(A)).render(M),X=O.projectDir,y=E.resolve(X,"package.json");B.writeFileSync(y,V,"utf8");let Z=E.resolve(O.project.projectDir,"fnet");if(B.existsSync(Z)){let q=E.resolve(O.projectDir,"fnet");if(!B.existsSync(q))B.mkdirSync(q);let H=B.readdirSync(Z);for(let U of H){let R=E.resolve(Z,U);if(!B.lstatSync(R).isFile())continue;let L=E.resolve(q,U);B.copyFileSync(R,L)}}}import XT from"node:fs";import VT from"node:path";import oT from"@flownet/lib-render-templates-dir";async function e({atom:$,setProgress:O,context:z,packageDependencies:W}){if($.doc.features.cli.enabled!==!0)return;await O({message:"Creating cli."});let T={atom:$,packageDependencies:W},K=z.templateDir,Q=VT.resolve(z.projectDir,"src/cli");if(!XT.existsSync(Q))XT.mkdirSync(Q,{recursive:!0});await oT({pattern:["index.js.njk"],dir:VT.resolve(K,"src/cli"),outDir:Q,context:T})}import TT from"node:fs";import $T from"node:path";import JT from"nunjucks";import iT from"@flownet/lib-parse-imports-js";async function zT({atom:$,setProgress:O,context:z,packageDependencies:W}){await O({message:"Creating rollup file."});let T={atom:$,packageDependencies:W},K=$T.resolve(z.projectDir,"src","default/index.js");if(!TT.existsSync(K))throw Error(`Entry file not found: ${K}`);let G=(await iT({file:K,recursive:!0})).all.filter((Z)=>Z.type==="node").map((Z)=>Z.path),Y=$.doc.features.rollup_output,M=Object.keys(Y);for(let Z=0;Z<M.length;Z++){let q=M[Z],H=Y[q];if(H.browser===!0){if(G.length>0){H.globals_enabled=!0,H.globals=H.globals||[],H.globals=H.globals.concat(G.map((U)=>{return{key:U,value:U}})),H.alias_enabled=!0,H.alias=H.alias||{},H.alias.entries=H.alias.entries||{};for(let U=0;U<G.length;U++){let R=G[U];H.alias.entries[R]=`node:${R}`,H.alias.entries[`node:${R}`]=R}H.external_enabled=!0,H.external=H.external||[],H.external=H.external.concat(G)}}}let A=z.templateDir,V=JT.compile(TT.readFileSync($T.resolve(A,"rollup.config.mjs.njk"),"utf8"),JT.configure(A)).render(T),X=z.projectDir,y=$T.resolve(X,"rollup.config.mjs");TT.writeFileSync(y,V,"utf8")}import OT from"node:fs";import bT from"node:path";import NT from"nunjucks";async function WT({atom:$,setProgress:O,context:z,packageDependencies:W}){await O({message:"Creating build.js file."});let T={atom:$,packageDependencies:W},K=z.templateDir,G=NT.compile(OT.readFileSync(bT.resolve(K,"build.js.njk"),"utf8"),NT.configure(K)).render(T),Y=z.projectDir,M=bT.resolve(Y,"build.js");OT.writeFileSync(M,G,"utf8"),OT.chmodSync(M,"755")}import KT from"node:fs";import qT from"node:path";import uT from"nunjucks";import dT from"ajv/dist/2020.js";import DT from"ajv/dist/standalone/index.js";import cT from"ajv-formats";async function GT({atom:$,setProgress:O,context:z,njEnv:W}){if($.doc.features.cli.enabled!==!0)return;await O({message:"Creating input args."});let T={},K=[];if($.doc.input)T=$.doc.input;else T={type:"object",properties:{},required:[]};if($.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1){let H=$.doc.features.cli.fargs,U={type:"string",description:"Config name to load args",hidden:!1},R={type:"array",description:"Tags to filter the config",hidden:!1};if(Reflect.has(H,"default"))U.default=H.default}let G={imports:K,atom:$},Y=z.templateDir,A=uT.compile(KT.readFileSync(qT.resolve(Y,"src/default/input.args.js.njk"),"utf8"),W).render(G),J=z.projectDir,V=qT.resolve(J,"src/default/input.args.js");KT.writeFileSync(V,A,"utf8");let X=new dT({allErrors:!0,useDefaults:!0,formats:{},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});cT(X);let y=X.compile(T),q=DT(X,y)+`
2
- export { schema31 as schema };`;KT.writeFileSync(qT.resolve(J,"src/default/validate_input.js"),q,"utf8")}import RT from"node:fs";import BT from"node:path";import LT from"nunjucks";async function QT({atom:$,setProgress:O,context:z,packageDependencies:W}){await O({message:"Creating tsconfig.json."});let T={atom:$,packageDependencies:W},K=z.templateDir,G=LT.compile(RT.readFileSync(BT.resolve(K,"tsconfig.json.njk"),"utf8"),LT.configure(K)).render(T),Y=z.projectDir,M=BT.resolve(Y,"tsconfig.json");RT.writeFileSync(M,G,"utf8")}import rT from"node:path";import ET from"@fnet/shelljs";async function YT({setProgress:$,context:O}){let z=O.projectDir;await $({message:"Prettifiying source files."});let W=rT.join("src","**","*");if(j("bun")){let T=await ET(`prettier --write ${W} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:z});if(T.code!==0)throw Error(T.stderr)}else{let T=await ET(`prettier --write ${W} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:z});if(T.code!==0)throw Error(T.stderr)}}import nT from"@fnet/shelljs";async function ZT({atom:$,setProgress:O,context:z}){if(!$.doc.features.dts_enabled)return;let W=z.projectDir;if(await O({message:"Creating .d.ts"}),(await nT("tsc",{cwd:W})).code!==0)throw Error("Couldnt create .d.ts files.")}import IT from"@fnet/shelljs";async function HT({setProgress:$,atom:O,context:z}){let W=z.projectDir;if(await $({message:"Installing npm packages."}),j("bun")){if((await IT(`bun install ${O.doc.features.npm_install_flags}`,{cwd:W})).code!==0)throw Error("Couldnt install npm packages.")}else if((await IT(`npm install ${O.doc.features.npm_install_flags}`,{cwd:W})).code!==0)throw Error("Couldnt install npm packages.")}import _T from"node:fs";import pT from"node:path";import{spawn as sT}from"node:child_process";async function FT($){let{projectDir:O,scriptName:z,args:W=[],env:T=process.env,shell:K=!0,detached:Q=!0,onSpawn:G}=$;if(!O||!z)throw Error("projectDir and scriptName are required");let Y=pT.resolve(O,"package.json");if(!_T.existsSync(Y))throw Error(`package.json not found at ${Y}`);let M=JSON.parse(_T.readFileSync(Y,"utf8")),A=M.scripts?.[z];if(!A){let X=Object.keys(M.scripts||{}).join(", ");throw Error(`Script '${z}' not found. Available: ${X}`)}let J=W.length>0?`${A} ${W.join(" ")}`:A,V=sT(J,[],{cwd:O,shell:K,detached:Q,env:{...T}});if(G)G(V);return new Promise((X,y)=>{V.on("error",(Z)=>{y(Error(`Failed to start '${z}': ${Z.message}`))}),V.on("close",(Z)=>{X({subprocess:V,exitCode:Z})})})}import tT from"node:path";async function MT({setProgress:$,context:O}){let z=O.projectDir;await $({message:"Building main project."});let W=O.dev?"build:dev":"build",T={...process.env},K=tT.join(z,"node_modules");T.NODE_PATH=K;let Q=T.NODE_OPTIONS||"";T.NODE_OPTIONS=`${Q} --preserve-symlinks`.trim(),await FT({projectDir:z,scriptName:W,shell:!0,detached:!0,env:T})}class hT extends CT{async initRuntime(){if(await n(this.apiContext),this.apiContext.context.project.runtime.type==="bun")await s(this.apiContext);else await p(this.apiContext);await this.initLibraryDir(),await this.initNunjucks(),await this.initLibs()}async initLibs(){this.setProgress({message:"Initializing external libs."});let $=[{name:this.atom.doc.name,type:"atom",parent_id:this.atom.parent_id}];this.libs=$,await this.initAtomLibsAndDeps({libs:$,packageDependencies:this.apiContext.packageDependencies})}async initAtomLibsAndDeps({libs:$,packageDependencies:O}){let z=$.filter((W)=>W.type==="atom");for(let W=0;W<z.length;W++){let T=z[W],K=await this.findAtomLibrary({url:T.name});T.atom=K,K.doc.dependencies?.filter((G)=>typeof G.repo>"u"||G.repo==="npm")?.forEach((G)=>{let Y=O.find((M)=>M.package===G.package);if(Y){if(typeof G.path==="string"){if(!(Y.path||[]).some((M)=>M===G.path))Y.path=Y.path||[],Y.path.push(G.path)}else if(Array.isArray(G.path))G.path.forEach((M)=>{if(!(Y.path||[]).some((A)=>A===M))Y.path=Y.path||[],Y.path.push(M)})}else O.push(G)})}O.sort((W,T)=>W.package?.localeCompare(T.package))}async findAtomLibrary({url:$}){let O=T0({url:$});if(!O)throw Error(`Invalid package name: ${$}`);if(!O.protocol)O.protocol=this.context.protocol;if(O.protocol==="ac:"){let z=O.pathname.split("/");if(z.length===1)return await this.apiContext.Atom.first({where:{name:$,parent_id:this.atomConfig.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(z.length===2){let W=await this.apiContext.Atom.first({where:{name:z[0],parent_id:this.atomConfig.env.ATOM_LIBRARIES_ID,type:"folder"}});return await this.apiContext.Atom.first({where:{name:z[1],parent_id:W.id,type:"workflow.lib"}})}}else if(O.protocol==="src:"){let z=this.atom;z.protocol="src:",z.doc.dependencies=z.doc.dependencies||[],z.name=z.doc.name;let W=b.resolve(this.context.projectSrcDir,"index.js"),T=await eT({file:W,recursive:!0}),K=z.doc.dependencies,Q=T.all;for await(let G of Q){if(G.type!=="npm")continue;if(K.find((M)=>M.package===G.package))continue;let Y=await C({name:G.package,projectDir:this.context.projectDir,setProgress:this.apiContext.setProgress});K.push({package:G.package,subpath:G.subpath,version:Y.minorRange,type:"npm"})}return z}}async createAtomLibFiles({libs:$}){await this.setProgress({message:"Creating external lib files."}),this.atom.typesDir="./types";let O=$.filter((z)=>z.type==="atom");for(let z=0;z<O.length;z++){let T=O[z].atom,K=this.context.projectDir;if(T.protocol==="src:"){let Q=b.resolve(this.context.projectSrcDir,`${T.fileName||T.name}.js`),G=b.relative(b.join(this.context.projectDir,"src","default"),Q);if(!F.existsSync(Q)){F.mkdirSync(b.dirname(Q),{recursive:!0});let Y=`export default async (input)=>{
3
- `;Y+="}",F.writeFileSync(Q,Y,"utf8")}T.relativePath=G.split(b.sep).join("/"),this.atom.typesDir=`./types/${b.basename(K)}/src`}else{let Q=b.join(K,"src","libs",`${T.id}.js`),G=T.doc.contents?.find((Y)=>Y.format==="esm")||T.doc;F.writeFileSync(Q,G.content,"utf8")}}}async createEngine(){await this.setProgress({message:"Creating engine file."});let O={libs:this.libs.filter((G)=>G.type==="atom"),libraryAtom:this.atom,atom:this.atom},z=this.context.templateDir,T=aT.compile(F.readFileSync(b.resolve(z,b.join("src","default","engine.js.njk")),"utf8"),this.apiContext.njEnv).render(O),K=this.context.projectDir,Q=b.resolve(K,b.join("src","default","index.js"));F.writeFileSync(Q,T,"utf8")}async build(){try{if(this.fileMode){let $=this.apiContext.context.project;if(await this.createAtomLibFiles({libs:this.libs}),await this.createEngine(),await this.createProjectYaml(),await lT(this.apiContext),await QT(this.apiContext),await jT(this.apiContext),await GT(this.apiContext),await e(this.apiContext),await t(this.apiContext),$.runtime.type==="bun")await WT(this.apiContext);else await zT(this.apiContext);if(await a(this.apiContext),await YT(this.apiContext),await ZT(this.apiContext),this.buildMode){if(await HT(this.apiContext),await MT(this.apiContext),this.deployMode)await this.deploy()}}await this._cache_set(this.buildKey,{status:"COMPLETED"})}catch($){throw await this._cache_set(this.buildKey,{status:"FAILED",message:$.message||$}),console.log($),$}}}var L1=hT;export{L1 as default};
1
+ import{b as CT,c as jT,d as hT}from"./index.s0nk6cv8.js";import{f as j}from"./index.05n3mvs9.js";import"./index.cvxrf34y.js";import F from"node:fs";import b from"node:path";import aT from"nunjucks";import eT from"@flownet/lib-parse-imports-js";import T0 from"@flownet/lib-parse-node-url";import I from"lodash.merge";import h from"node:fs";import R from"node:path";import _ from"@flownet/lib-parse-imports-js";import wT from"lodash.merge";function S({feature:$,features:O,packageDevDependencies:z}){let{name:W,packages:T,options:K,extraCheck:Q,explicit:G}=$,Y=`${W}_enabled`,M=O.rollup_output||{},A=Object.keys(M),J=K||{},V=O[W]?.options;if(V)J=wT(J,V);let X=!O[W]||O[W]?.enabled===!1;A.forEach((Z)=>{let q=O.rollup_output[Z];if(!q)return;if(Reflect.has(q,W)){if(X||!q[W]||q[W]?.enabled===!1){delete q[W];return}if(q[W]===!0)q[W]={enabled:!0,options:J}}else if(!X&&!G&&O[Y]!==!1)q[W]={enabled:!0};else return;q[W]=q[W]||{},q[W].options={...J,...q[W].options}});let y=A.some((Z)=>O.rollup_output[Z][W]?.enabled===!0);if(Q)y=Q()&&y;if(O[Y]=y,y)T.forEach((Z)=>z.push({package:Z[0],version:Z[1]}))}function w($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"workbox",packages:[["rollup-plugin-workbox","^8"]],options:{generate:{swDest:"dist/app/esm/sw.js",globDirectory:"dist/app/esm",globPatterns:["**/*.{html,js,css,png,jpg}"],skipWaiting:!0,clientsClaim:!0}},explicit:!0},features:W,packageDevDependencies:z})}function P($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:W,packageDevDependencies:z})}function v($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:W,packageDevDependencies:z})}function m($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:W,packageDevDependencies:z})}function k($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]],expilicit:!0},features:W,packageDevDependencies:z})}function g($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:W,packageDevDependencies:z})}function f($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:W,packageDevDependencies:z})}function o($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:W,packageDevDependencies:z})}function i($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;if(W.runtime.type==="bun")return;S({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:W,packageDevDependencies:z})}function u($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:W,packageDevDependencies:z})}function d($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;S({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:W,packageDevDependencies:z})}function D($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features;if(W.runtime.type==="bun")return;let T={};if(W.app?.enabled===!0){if(T.targets=T.targets||[],T.targets.push({src:"./src/app/index.html",dest:W.app.dir}),!Reflect.has(W.app,"copy")){if(!Reflect.has(W,"copy"))W.copy=!0}}S({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:T},features:W,packageDevDependencies:z})}function c($){let{atom:O,packageDevDependencies:z}=$,W=O.doc.features,T=W.css&&W.css.enabled!==!1,K=[];if(T)K.push(["rollup-plugin-postcss","^4"]),K.push(["sass","^1.66"]),(W.css?.options?.plugins||[]).forEach((G)=>{switch(G.name){case"postcss-import":K.push(["postcss-import","^15"]);break;case"postcss-url":K.push(["postcss-url","^10"]);break;case"postcss-preset-env":K.push(["postcss-preset-env","^9"]);break;case"autoprefixer":K.push(["autoprefixer","^10"]);break;case"cssnano":K.push(["cssnano","^6"]);break}});S({feature:{name:"css",packages:K},features:W,packageDevDependencies:z})}function r({dir:$,name:O="index"}){let z=R.resolve($,`./${O}.tsx`);if(!h.existsSync(z))z=R.resolve($,`./${O}.ts`);if(!h.existsSync(z))z=R.resolve($,`./${O}.jsx`);if(!h.existsSync(z))z=R.resolve($,`./${O}.js`);if(!h.existsSync(z))return{};let W=z,T=R.extname(z);return{file:W,ext:T,ts:T===".ts"||T===".tsx",name:O}}async function n($){let{atom:O,context:z,setProgress:W}=$;W("Initializing features..."),O.doc.features=O.doc.features||{};let T=O.doc.features;T.project=T.project||{},T.project.format=T.project.format||T.project_format||"esm",T.project_format=T.project.format,T.dts_enabled=T.dts===!0||typeof T.dts<"u"&&T.dts!==!1;let K=R.resolve(z.project.projectDir),Q=r({dir:R.resolve(K,"./app")});if(Q.file){W("Parsing app entry imports...");let Z=await _({file:Q.file,recursive:!0}),q=Z.all.some((H)=>H.usesJSX===!0&&H.type==="local");T.app_uses_jsx=q,T.app_has_entry=!0,Z=await _({file:Q.file}),q=Z.all.some((H)=>H.usesJSX===!0&&H.type==="local"),T.app_entry_uses_jsx=q,T.app_entry_is_ts=Q.ts,T.app_entry_ext=Q.ext}let G=r({dir:R.resolve(K,"./cli")});if(G.file){W("Parsing cli entry imports...");let Z=await _({file:G.file,recursive:!0}),q=Z.all.some((H)=>H.usesJSX===!0&&H.type==="local");T.cli_uses_jsx=q,T.cli_has_entry=!0,Z=await _({file:G.file}),q=Z.all.some((H)=>H.usesJSX===!0&&H.type==="local"),T.cli_entry_uses_jsx=q,T.cli_entry_is_ts=G.ts,T.cli_entry_ext=G.ext}if(O.type==="workflow.lib"){let Z=r({dir:R.resolve(K,"./src")});if(Z.file){W("Parsing src entry imports...");let q=await _({file:Z.file,recursive:!0}),H=q.all.some((U)=>U.usesJSX===!0&&U.type==="local");T.src_uses_jsx=H,T.src_has_entry=!0,q=await _({file:Z.file}),H=q.all.some((U)=>U.usesJSX===!0&&U.type==="local"),T.src_entry_uses_jsx=H,T.src_entry_is_ts=Z.ts,T.src_entry_ext=Z.ext}}let Y=Reflect.has(T,"app_entry_uses_jsx")?T.app_entry_uses_jsx===!0:T.src_entry_uses_jsx===!0,M=Reflect.has(T,"cli_entry_uses_jsx")?T.cli_entry_uses_jsx===!0:T.src_entry_uses_jsx===!0;if(T.form_enabled=Y||M||T.form===!0||T.form?.enabled===!0,T.multiple_enabled=T.multiple_enabled||T.multiple===!0||T.multiple?.enabled===!0,T.app===!1)T.app={enabled:!1};else if(T.app===!0)T.app={enabled:!0,extend:T.app_has_entry===!0,export:!0,react:Y};else T.app={enabled:!0,extend:T.app_has_entry===!0,export:!0,react:Y,...T.app||{}};if(T.app.enabled=T.app.enabled===!0&&(O.doc.features.form_enabled===!0||T.app.extend===!0||T.app.enabled===!0),T.app.format=T.app.format||"esm",T.app.folder=T.app.folder||T.app.format||"default",T.cli===!1)T.cli={enabled:!1};else if(T.cli===!0)T.cli={enabled:!0,extend:T.cli_has_entry===!0,export:!0,react:M};else T.cli={enabled:!0,extend:T.cli_has_entry===!0,export:!0,react:M,...T.cli||{}};if(T.cli.enabled=T.cli.enabled===!0&&(O.doc.features.form_enabled===!1||T.cli.extend===!0||T.cli.enabled===!0),T.cli.format=T.cli.format||"esm",T.cli.folder=T.cli.folder||T.cli.folder||"esm",T.cli.node_options=T.cli.node?.options||T.cli.node_options||"",T.cli.bin=T.cli.bin||O.doc.name,T.cli.installable=T.cli.installable===!0,T.cli.enabled)O.doc["npm::bin"]=T.cli.bin;T.json=T.cli.enabled||T.json;let A={cjs:{format:"cjs",context:T.form_enabled?"window":"global",babel:T.src_uses_jsx===!0||!1,browser:!1,replace:!0,terser:!0,enabled:T.cjs!==!1,copy:!1},esm:{format:"esm",context:T.form_enabled?"window":"global",babel:T.src_uses_jsx===!0||!1,browser:!1,replace:!0,terser:!1,enabled:T.esm!==!1,copy:!0},iife:{format:"iife",context:T.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:T.iife===!0,terser:!0,copy:!1}},J={targets:{browsers:"last 9 versions, not dead",node:"18"}},V={};if(T.webos===!0)A.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",copy:!1,babel_options:{targets:{chrome:"79"}}};if(T.electron===!0)A.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/electron"};if(T.nextjs===!0)A.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"};if(T.ios===!0)A.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/ios"};if(T.macos===!0)A.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/macos"};if(T.app.enabled===!0)T.app.dir=`./dist/app/${T.app.folder}`,T.app.output={file:`./dist/app/${T.app.folder}/index.js`,dir:`./dist/app/${T.app.folder}/`,...T.app.output||{}},T.app.input={file:"./src/app/index.js",dir:"./src/app/",...T.app.input||{}},A.app={format:T.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:T.app.input.file,output_dir:T.app.dir,terser:!0,output_exports:T.app.export===!1?"none":"auto",browsersync:!0};if(T.cli.enabled===!0)T.cli.dir=`./dist/cli/${T.cli.folder}`,T.cli.output={file:`./dist/cli/${T.cli.folder}/index.js`,dir:`./dist/cli/${T.cli.folder}/`,...T.cli.output||{}},T.cli.input={file:"./src/cli/index.js",dir:"./src/cli/",...T.cli.input||{}},A.cli={format:T.cli.format,context:"global",babel:T.src_uses_jsx===!0||T.cli_uses_jsx===!0||!1,browser:!1,replace:!0,enabled:!0,input:T.cli.input.file,output_dir:T.cli.dir,banner:"#!/usr/bin/env bun",terser:!0,output_exports:T.cli.export===!1?"none":"auto"};let X={server:".",startPath:`${R.normalize(T.app.dir||".")}`,files:[R.normalize("./dist/**/*")],cors:!0,open:!1};if(T.babel_options=I(J,T.babel_options||T.babel?.options),T.browsersync_options=I(X,T.browsersync_options||T.browsersync?.options||{}),T.replace_options=I(V,T.replace_options||T.replace?.options||{}),Reflect.has(T.browsersync_options,"proxy"))delete T.browsersync_options.server;T.rollup=T.rollup||{},T.rollup_output=I(A,T.rollup_output||T.rollup?.output||{}),T.preact_enabled=T.preact===!0||T.preact&&T.preact?.enabled!==!1;let y=Object.keys(A);for(let Z of y){let q=A[Z];if(!q)continue;if(T.rollup[Z]===!1){delete T.rollup_output[Z];continue}if(q.babel_options=q.babel_options||T.babel_options,q.browsersync_options=I(T.browsersync_options,q.browsersync_options),q.replace_options=I(T.replace_options,q.replace_options),T.preact_enabled)q.alias_enabled=!0,q.alias=q.alias||{},q.alias.entries=q.alias.entries||{},q.alias.entries.react="preact/compat",q.alias.entries["react-dom"]="preact/compat";if(T.form_enabled||T.babel)q.babel=!0}y=Object.keys(T.rollup_output),T.babel_enabled=y.some((Z)=>T.rollup_output[Z].babel===!0),T.browser_enabled=y.some((Z)=>T.rollup_output[Z].babel===!0),T.browsersync_enabled=T.browsersync!==!1&&y.some((Z)=>T.rollup_output[Z].browsersync===!0),T.browsersync_enabled=T.browsersync_enabled&&T.app.enabled,T.dependency_auto_enabled=T.dependency_auto!==!1&&T.dependency_auto?.enabled!==!1,T.npm_install_flags=T.npm_install_flags||"",T.react_version=T.react_version||T.react?.version||18,T.bpmn=T.bpmn||{},T.bpmn.enabled=T.bpmn.enabled!==!1,T.bpmn.per_flow=T.bpmn.per_flow===!0,c($),D($),d($),u($),i($),f($),o($),g($),k($),m($),v($),w($),P($)}import PT from"@fnet/npm-list-versions";async function p({atom:$,packageDependencies:O,packageDevDependencies:z,setProgress:W}){W("Initializing dependencies");let T=$.doc.dependencies||[];if(T.filter((K)=>!K.dev).forEach((K)=>O.push(K)),T.filter((K)=>K.dev).forEach((K)=>z.push(K)),$.type==="workflow")O.push({package:"get-value",version:"^3"}),O.push({package:"set-value",version:"^4"});if($.doc.features.form_enabled){if($.doc.features.dependency_auto_enabled){let K="^18.2";if(W("Fetching React versions"),K=`^${(await PT({name:"react",groupBy:{major:!0}})).find((Y)=>Y[0]===$.doc.features.react_version.toString())[0]}`,O.push({package:"react",version:K}),O.push({package:"react-dom",version:K}),$.type==="workflow")O.push({package:"@fnet/react-app",version:"^0.1"}),O.push({package:"@fnet/react-app-state",version:"^0.1"})}}if($.doc.features.preact_enabled)O.push({package:"preact",version:"^10"});if($.doc.features.cli.enabled===!0){if(O.push({package:"@fnet/args",version:"^0.1"}),$.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1)O.push({package:"@fnet/config",version:"0.2.21"});if($.doc.features.cli.mcp&&$.doc.features.cli.mcp.enabled===!0)O.push({package:"@modelcontextprotocol/sdk",version:"^1.10"}),O.push({package:"express",version:"^4.18"})}if($.doc.features.render&&$.doc.features.render.enabled!==!1)z.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"});if(z.push({package:"@babel/core",version:"^7"}),z.push({package:"@rollup/plugin-commonjs",version:"^28"}),z.push({package:"@rollup/plugin-node-resolve",version:"^16"}),z.push({package:"@rollup/plugin-replace",version:"^6"}),z.push({package:"rollup",version:"^4"}),$.doc.features.dts_enabled)z.push({package:"rollup-plugin-dts",version:"^6"});if(z.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),z.push({package:"@rollup/plugin-alias",version:"^5"}),z.push({package:"fs-extra",version:"^11"}),$.doc.features.babel_enabled)z.push({package:"@rollup/plugin-babel",version:"^6"}),z.push({package:"@babel/preset-env",version:"^7"}),z.push({package:"@babel/preset-react",version:"^7"}),$.doc.features.babel?.options?.plugins?.forEach((K)=>{switch(K[0]){case"@babel/plugin-proposal-decorators":z.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":z.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":z.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":z.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":z.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"});break}});if(z.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),$.doc.features.browsersync_enabled)z.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})}import vT from"@fnet/npm-list-versions";async function s({atom:$,packageDependencies:O,packageDevDependencies:z,setProgress:W}){W("Initializing dependencies for Bun");let T=$.doc.dependencies||[];if(T.filter((K)=>!K.dev).forEach((K)=>O.push(K)),T.filter((K)=>K.dev).forEach((K)=>z.push(K)),$.type==="workflow")O.push({package:"get-value",version:"^3"}),O.push({package:"set-value",version:"^4"});if($.doc.features.form_enabled){if($.doc.features.dependency_auto_enabled){let K="^18.2";if(W("Fetching React versions"),K=`^${(await vT({name:"react",groupBy:{major:!0}})).find((Y)=>Y[0]===$.doc.features.react_version.toString())[0]}`,O.push({package:"react",version:K}),O.push({package:"react-dom",version:K}),$.type==="workflow")O.push({package:"@fnet/react-app",version:"^0.1"}),O.push({package:"@fnet/react-app-state",version:"^0.1"})}}if($.doc.features.preact_enabled)O.push({package:"preact",version:"^10"});if($.doc.features.cli.enabled===!0){if(O.push({package:"@fnet/args",version:"^0.1"}),$.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1)O.push({package:"@fnet/config",version:"0.2.21"});if($.doc.features.cli.mcp&&$.doc.features.cli.mcp.enabled===!0)O.push({package:"@modelcontextprotocol/sdk",version:"^1.10"}),O.push({package:"express",version:"^4.18"})}if($.doc.features.render&&$.doc.features.render.enabled!==!1)z.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"})}import AT from"node:fs";import ST from"node:path";import mT from"@flownet/lib-render-templates-dir";async function t({atom:$,setProgress:O,context:z,packageDependencies:W}){if($.doc.features.app.enabled!==!0)return;await O({message:"Creating app folder"});let T={atom:$,packageDependencies:W,ts:Date.now()},K=z.templateDir,Q=ST.resolve(z.projectDir,"src/app");if(!AT.existsSync(Q))AT.mkdirSync(Q,{recursive:!0});let G=["index.js.njk"];if($.doc.features.app.html!==!1)G.push("index.html.njk");await mT({pattern:G,dir:ST.resolve(K,"src/app"),outDir:Q,context:T})}import yT from"nunjucks";import L from"node:fs";import E from"node:path";import fT from"@flownet/lib-parse-imports-js";import kT from"@fnet/npm-pick-versions";import gT from"object-hash";import l from"node:fs";import UT from"node:path";async function C({projectDir:$,name:O,setProgress:z,count:W=1}){let T,Q=gT(["npm-pick-versions",O,W]),G=UT.join($,".cache"),Y=UT.join(G,Q+".json");if(l.existsSync(Y)){if(z)z(`Picking npm version of ${O} from cache ...`);T=JSON.parse(l.readFileSync(Y,"utf8"))}else{if(z)z(`Picking npm version of ${O} ...`);T=await kT({name:O,count:W}),l.mkdirSync(G,{recursive:!0}),l.writeFileSync(Y,JSON.stringify(T),"utf8")}return T}async function a({atom:$,context:O,packageDependencies:z,packageDevDependencies:W,setProgress:T}){await T({message:"Creating package.json."}),z.filter((q)=>q.dev===!0).forEach((q)=>{if(!W.find((U)=>U.package===q.package))W.push(q);let H=z.findIndex((U)=>U.package===q.package);z.splice(H,1)});let Q=z.find((q)=>q.package==="react"),G=z.find((q)=>q.package==="react-dom");if(Q&&!G)z.push({package:"react-dom",version:Q.version});else if(Q&&G)G.version=Q.version;if(Q&&$.doc.features.react_version>=17){if(!z.find((q)=>q.package==="@emotion/react"))z.push({package:"@emotion/react",version:"^11"});if(!z.find((q)=>q.package==="@emotion/styled"))z.push({package:"@emotion/styled",version:"^11"})}let Y=[];if($.doc.features.app.enabled===!0)Y.push({file:E.resolve(O.projectDir,"src/app/index.js"),dev:$.doc.features.app.dev!==!1});if($.doc.features.cli.enabled===!0)Y.push({file:E.resolve(O.projectDir,"src/cli/index.js"),dev:$.doc.features.cli.dev!==!1});for await(let q of Y){let H=q.file;if(!L.existsSync(H))throw Error(`App file not found: ${H}`);let N=(await fT({file:H,recursive:!0,verbose:!1})).all;for await(let B of N){if(B.type!=="npm")continue;if(z.find((x)=>x.package===B.package))continue;if(W.find((x)=>x.package===B.package))continue;let xT=await C({name:B.package,projectDir:O.projectDir,setProgress:T});(q.dev===!0?W:z).push({package:B.package,subpath:B.subpath,version:xT.minorRange,type:"npm"})}}let M={atom:$,packageDependencies:z,packageDevDependencies:W},A=O.templateDir,V=yT.compile(L.readFileSync(E.resolve(A,"package.json.njk"),"utf8"),yT.configure(A)).render(M),X=O.projectDir,y=E.resolve(X,"package.json");L.writeFileSync(y,V,"utf8");let Z=E.resolve(O.project.projectDir,"fnet");if(L.existsSync(Z)){let q=E.resolve(O.projectDir,"fnet");if(!L.existsSync(q))L.mkdirSync(q);let H=L.readdirSync(Z);for(let U of H){let N=E.resolve(Z,U);if(!L.lstatSync(N).isFile())continue;let B=E.resolve(q,U);L.copyFileSync(N,B)}}}import XT from"node:fs";import VT from"node:path";import oT from"@flownet/lib-render-templates-dir";async function e({atom:$,setProgress:O,context:z,packageDependencies:W}){if($.doc.features.cli.enabled!==!0)return;await O({message:"Creating cli."});let T={atom:$,packageDependencies:W},K=z.templateDir,Q=VT.resolve(z.projectDir,"src/cli");if(!XT.existsSync(Q))XT.mkdirSync(Q,{recursive:!0});await oT({pattern:["index.js.njk"],dir:VT.resolve(K,"src/cli"),outDir:Q,context:T})}import TT from"node:fs";import $T from"node:path";import JT from"nunjucks";import iT from"@flownet/lib-parse-imports-js";async function zT({atom:$,setProgress:O,context:z,packageDependencies:W}){await O({message:"Creating rollup file."});let T={atom:$,packageDependencies:W},K=$T.resolve(z.projectDir,"src","default/index.js");if(!TT.existsSync(K))throw Error(`Entry file not found: ${K}`);let G=(await iT({file:K,recursive:!0})).all.filter((Z)=>Z.type==="node").map((Z)=>Z.path),Y=$.doc.features.rollup_output,M=Object.keys(Y);for(let Z=0;Z<M.length;Z++){let q=M[Z],H=Y[q];if(H.browser===!0){if(G.length>0){H.globals_enabled=!0,H.globals=H.globals||[],H.globals=H.globals.concat(G.map((U)=>{return{key:U,value:U}})),H.alias_enabled=!0,H.alias=H.alias||{},H.alias.entries=H.alias.entries||{};for(let U=0;U<G.length;U++){let N=G[U];H.alias.entries[N]=`node:${N}`,H.alias.entries[`node:${N}`]=N}H.external_enabled=!0,H.external=H.external||[],H.external=H.external.concat(G)}}}let A=z.templateDir,V=JT.compile(TT.readFileSync($T.resolve(A,"rollup.config.mjs.njk"),"utf8"),JT.configure(A)).render(T),X=z.projectDir,y=$T.resolve(X,"rollup.config.mjs");TT.writeFileSync(y,V,"utf8")}import OT from"node:fs";import bT from"node:path";import RT from"nunjucks";async function WT({atom:$,setProgress:O,context:z,packageDependencies:W}){await O({message:"Creating build.js file."});let T={atom:$,packageDependencies:W},K=z.templateDir,G=RT.compile(OT.readFileSync(bT.resolve(K,"build.js.njk"),"utf8"),RT.configure(K)).render(T),Y=z.projectDir,M=bT.resolve(Y,"build.js");OT.writeFileSync(M,G,"utf8"),OT.chmodSync(M,"755")}import KT from"node:fs";import qT from"node:path";import uT from"nunjucks";import dT from"ajv/dist/2020.js";import DT from"ajv/dist/standalone/index.js";import cT from"ajv-formats";async function GT({atom:$,setProgress:O,context:z,njEnv:W}){if($.doc.features.cli.enabled!==!0)return;await O({message:"Creating input args."});let T={},K=[];if($.doc.input)T=$.doc.input;else T={type:"object",properties:{},required:[]};if($.doc.features.cli.fargs&&$.doc.features.cli.fargs?.enabled!==!1){let H=$.doc.features.cli.fargs,U={type:"string",description:"Config name to load args",hidden:!1},N={type:"array",description:"Tags to filter the config",hidden:!1};if(Reflect.has(H,"default"))U.default=H.default}let G={imports:K,atom:$},Y=z.templateDir,A=uT.compile(KT.readFileSync(qT.resolve(Y,"src/default/input.args.js.njk"),"utf8"),W).render(G),J=z.projectDir,V=qT.resolve(J,"src/default/input.args.js");KT.writeFileSync(V,A,"utf8");let X=new dT({allErrors:!0,useDefaults:!0,formats:{},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});cT(X);let y=X.compile(T),q=DT(X,y)+`
2
+ export { schema31 as schema };`;KT.writeFileSync(qT.resolve(J,"src/default/validate_input.js"),q,"utf8")}import NT from"node:fs";import LT from"node:path";import BT from"nunjucks";async function QT({atom:$,setProgress:O,context:z,packageDependencies:W}){await O({message:"Creating tsconfig.json."});let T={atom:$,packageDependencies:W},K=z.templateDir,G=BT.compile(NT.readFileSync(LT.resolve(K,"tsconfig.json.njk"),"utf8"),BT.configure(K)).render(T),Y=z.projectDir,M=LT.resolve(Y,"tsconfig.json");NT.writeFileSync(M,G,"utf8")}import rT from"node:path";import ET from"@fnet/shelljs";async function YT({setProgress:$,context:O}){let z=O.projectDir;await $({message:"Prettifiying source files."});let W=rT.join("src","**","*");if(j("bun")){let T=await ET(`prettier --write ${W} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:z});if(T.code!==0)throw Error(T.stderr)}else{let T=await ET(`prettier --write ${W} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:z});if(T.code!==0)throw Error(T.stderr)}}import nT from"@fnet/shelljs";async function ZT({atom:$,setProgress:O,context:z}){if(!$.doc.features.dts_enabled)return;let W=z.projectDir;if(await O({message:"Creating .d.ts"}),(await nT("tsc",{cwd:W})).code!==0)throw Error("Couldnt create .d.ts files.")}import IT from"@fnet/shelljs";async function HT({setProgress:$,atom:O,context:z}){let W=z.projectDir;if(await $({message:"Installing npm packages."}),j("bun")){if((await IT(`bun install ${O.doc.features.npm_install_flags}`,{cwd:W})).code!==0)throw Error("Couldnt install npm packages.")}else if((await IT(`npm install ${O.doc.features.npm_install_flags}`,{cwd:W})).code!==0)throw Error("Couldnt install npm packages.")}import _T from"node:fs";import pT from"node:path";import{spawn as sT}from"node:child_process";async function FT($){let{projectDir:O,scriptName:z,args:W=[],env:T=process.env,shell:K=!0,detached:Q=!0,onSpawn:G}=$;if(!O||!z)throw Error("projectDir and scriptName are required");let Y=pT.resolve(O,"package.json");if(!_T.existsSync(Y))throw Error(`package.json not found at ${Y}`);let M=JSON.parse(_T.readFileSync(Y,"utf8")),A=M.scripts?.[z];if(!A){let X=Object.keys(M.scripts||{}).join(", ");throw Error(`Script '${z}' not found. Available: ${X}`)}let J=W.length>0?`${A} ${W.join(" ")}`:A,V=sT(J,[],{cwd:O,shell:K,detached:Q,env:{...T}});if(G)G(V);return new Promise((X,y)=>{V.on("error",(Z)=>{y(Error(`Failed to start '${z}': ${Z.message}`))}),V.on("close",(Z)=>{X({subprocess:V,exitCode:Z})})})}import tT from"node:path";async function MT({setProgress:$,context:O}){let z=O.projectDir;await $({message:"Building main project."});let W=O.dev?"build:dev":"build",T={...process.env},K=tT.join(z,"node_modules");T.NODE_PATH=K;let Q=T.NODE_OPTIONS||"";T.NODE_OPTIONS=`${Q} --preserve-symlinks`.trim(),await FT({projectDir:z,scriptName:W,shell:!0,detached:!0,env:T})}class lT extends CT{async initRuntime(){if(await n(this.apiContext),this.apiContext.context.project.runtime.type==="bun")await s(this.apiContext);else await p(this.apiContext);await this.initLibraryDir(),await this.initNunjucks(),await this.initLibs()}async initLibs(){this.setProgress({message:"Initializing external libs."});let $=[{name:this.atom.doc.name,type:"atom",parent_id:this.atom.parent_id}];this.libs=$,await this.initAtomLibsAndDeps({libs:$,packageDependencies:this.apiContext.packageDependencies})}async initAtomLibsAndDeps({libs:$,packageDependencies:O}){let z=$.filter((W)=>W.type==="atom");for(let W=0;W<z.length;W++){let T=z[W],K=await this.findAtomLibrary({url:T.name});T.atom=K,K.doc.dependencies?.filter((G)=>typeof G.repo>"u"||G.repo==="npm")?.forEach((G)=>{let Y=O.find((M)=>M.package===G.package);if(Y){if(typeof G.path==="string"){if(!(Y.path||[]).some((M)=>M===G.path))Y.path=Y.path||[],Y.path.push(G.path)}else if(Array.isArray(G.path))G.path.forEach((M)=>{if(!(Y.path||[]).some((A)=>A===M))Y.path=Y.path||[],Y.path.push(M)})}else O.push(G)})}O.sort((W,T)=>W.package?.localeCompare(T.package))}async findAtomLibrary({url:$}){let O=T0({url:$});if(!O)throw Error(`Invalid package name: ${$}`);if(!O.protocol)O.protocol=this.context.protocol;if(O.protocol==="ac:"){let z=O.pathname.split("/");if(z.length===1)return await this.apiContext.Atom.first({where:{name:$,parent_id:this.atomConfig.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(z.length===2){let W=await this.apiContext.Atom.first({where:{name:z[0],parent_id:this.atomConfig.env.ATOM_LIBRARIES_ID,type:"folder"}});return await this.apiContext.Atom.first({where:{name:z[1],parent_id:W.id,type:"workflow.lib"}})}}else if(O.protocol==="src:"){let z=this.atom;z.protocol="src:",z.doc.dependencies=z.doc.dependencies||[],z.name=z.doc.name;let W=b.resolve(this.context.projectSrcDir,"index.js"),T=await eT({file:W,recursive:!0}),K=z.doc.dependencies,Q=T.all;for await(let G of Q){if(G.type!=="npm")continue;if(K.find((M)=>M.package===G.package))continue;let Y=await C({name:G.package,projectDir:this.context.projectDir,setProgress:this.apiContext.setProgress});K.push({package:G.package,subpath:G.subpath,version:Y.minorRange,type:"npm"})}return z}}async createAtomLibFiles({libs:$}){await this.setProgress({message:"Creating external lib files."}),this.atom.typesDir="./types";let O=$.filter((z)=>z.type==="atom");for(let z=0;z<O.length;z++){let T=O[z].atom,K=this.context.projectDir;if(T.protocol==="src:"){let Q=b.resolve(this.context.projectSrcDir,`${T.fileName||T.name}.js`),G=b.relative(b.join(this.context.projectDir,"src","default"),Q);if(!F.existsSync(Q)){F.mkdirSync(b.dirname(Q),{recursive:!0});let Y=`export default async (input)=>{
3
+ `;Y+="}",F.writeFileSync(Q,Y,"utf8")}T.relativePath=G.split(b.sep).join("/"),this.atom.typesDir=`./types/${b.basename(K)}/src`}else{let Q=b.join(K,"src","libs",`${T.id}.js`),G=T.doc.contents?.find((Y)=>Y.format==="esm")||T.doc;F.writeFileSync(Q,G.content,"utf8")}}}async createEngine(){await this.setProgress({message:"Creating engine file."});let O={libs:this.libs.filter((G)=>G.type==="atom"),libraryAtom:this.atom,atom:this.atom},z=this.context.templateDir,T=aT.compile(F.readFileSync(b.resolve(z,b.join("src","default","engine.js.njk")),"utf8"),this.apiContext.njEnv).render(O),K=this.context.projectDir,Q=b.resolve(K,b.join("src","default","index.js"));F.writeFileSync(Q,T,"utf8")}async build(){try{if(this.fileMode){let $=this.apiContext.context.project;if(await this.createAtomLibFiles({libs:this.libs}),await this.createEngine(),await this.createProjectYaml(),await hT(this.apiContext),await QT(this.apiContext),await jT(this.apiContext),await GT(this.apiContext),await e(this.apiContext),await t(this.apiContext),$.runtime.type==="bun")await WT(this.apiContext);else await zT(this.apiContext);if(await a(this.apiContext),await YT(this.apiContext),await ZT(this.apiContext),this.buildMode){if(await HT(this.apiContext),await MT(this.apiContext),this.deployMode)await this.deploy()}}await this._cache_set(this.buildKey,{status:"COMPLETED"})}catch($){throw await this._cache_set(this.buildKey,{status:"FAILED",message:$.message||$}),console.log($),$}}}var B1=lT;export{B1 as default};
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{e as E}from"./index.9qgtmxq3.js";import{f as o}from"./index.05n3mvs9.js";import{g as k,i as S}from"./index.cvxrf34y.js";import q$ from"yargs";import B1 from"chalk";import{promisify as I1}from"node:util";import F1 from"tree-kill";var a=I1(F1),x=!1;async function n($,W){if(x)return;if(x=!0,!$.killed&&$.pid)try{if(await a($.pid,"SIGTERM").catch(()=>{}),await new Promise((q)=>setTimeout(q,500)),!$.killed)await a($.pid,"SIGKILL").catch(()=>{})}catch(q){}await new Promise((q)=>setTimeout(q,100));let z=W==="SIGINT"?130:W==="SIGTERM"?143:1;process.exit(z)}function u($){["SIGINT","SIGTERM","SIGQUIT"].forEach((W)=>{process.once(W,async()=>{await n($,W)})}),process.on("uncaughtException",async(W)=>{await n($)}),process.on("unhandledRejection",async(W)=>{await n($)}),$.on("close",(W)=>{if(!x)process.exit(W)})}function t(){process.on("uncaughtException",($)=>{if(!x)x=!0,setTimeout(()=>process.exit(1),500)}),process.on("unhandledRejection",($)=>{if(!x)x=!0,setTimeout(()=>process.exit(1),500)})}import b from"node:path";import{spawn as c}from"node:child_process";import v from"node:fs";import y from"chalk";import _1 from"@fnet/config";function C($,{name:W,bin:z,preArgs:q=[],createContext:G}){if(typeof z==="function")z=z();return $.command(`${W||z} [commands..]`,`${z} ${q.join(" ")}`,(Z)=>{return Z.help(!1).version(!1)},async(Z)=>{try{let Q=await G(Z),{projectDir:Y}=Q,O=(_)=>{if(!_.includes(" "))return _;if(process.platform==="win32")return`"${_.replace(/(["^])/g,"^$1")}"`;else return`"${_.replace(/(["\\$`])/g,"\\$1")}"`},M=process.argv.slice(3).map(O),H={...process.env},U=b.join(Y,"node_modules");H.NODE_PATH=U;let T=H.NODE_OPTIONS||"";H.NODE_OPTIONS=`${T} --preserve-symlinks`.trim();let F=c(z,[...q,...M],{cwd:Y,stdio:"inherit",shell:!0,detached:!0,env:H});u(F)}catch(Q){console.error(Q.message),process.exit(1)}})}function D($,{name:W,bin:z,preArgs:q=[],createContext:G}){return $.command(`${W||z} [commands..]`,`${z} ${q.join(" ")}`,(Z)=>{return Z.help(!1).version(!1)},async(Z)=>{try{let Q=await G(Z),{projectDir:Y}=Q,O=(U)=>{if(!U.includes(" "))return U;if(process.platform==="win32")return`"${U.replace(/(["^])/g,"^$1")}"`;else return`"${U.replace(/(["\\$`])/g,"\\$1")}"`},M=process.argv.slice(3).map(O);z=b.join(Y,".conda","bin",z||W);let H=c(z,[...q,...M],{cwd:Y,stdio:"inherit",shell:!0,detached:!0,env:{PYTHONPATH:Y}});u(H)}catch(Q){console.error(Q.message),process.exit(1)}})}function e($,{name:W,preArgs:z=[],createContext:q}){return $.command(`${W} <config> <command> [options..]`,"Run a command with a config context",(G)=>{return G.positional("config",{type:"string"}).positional("command",{type:"string"}).help(!1).version(!1)},async(G)=>{try{let Z=await q(G),{projectDir:Q}=Z,Y=G.config,M=(await _1({name:Y,dir:Q,transferEnv:!1,optional:!0,tags:Z.tags}))?.data?.env||void 0,H=G.command,U=process.argv.slice(5),T=c(H,[...z,...U],{cwd:v.existsSync(Q)?Q:process.cwd(),stdio:"inherit",shell:!0,detached:!0,env:{...process.env,...M}});u(T)}catch(Z){console.error(Z.message),process.exit(1)}})}function $1($,{name:W,projectType:z="auto"}){return $.command(`${W} group [options..]`,"Run a command group.",(q)=>{return q.positional("group",{type:"string"}).option("ftag",{type:"array"}).help(!1).version(!1)},async(q)=>{try{let{runCommandGroup:G}=await import("./index.2pnjg6dc.js");await G({projectType:z,group:q.group,tags:q.ftag,args:q,argv:process.argv})}catch(G){console.error(G.message),process.exit(1)}})}function W1($,{name:W,createContext:z}){return $.command(`${W} [options]`,"Install the project as a binary",(q)=>{return q.option("name",{alias:"n",describe:"Name to use for the installed binary",type:"string"}).option("force",{alias:"f",describe:"Force overwrite if binary already exists",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Automatically answer yes to all prompts",type:"boolean",default:!1})},async(q)=>{try{let G=await z(q),{projectDir:Z}=G;console.log(y.blue("Compiling project..."));let Q=b.join(Z,".bin");if(!v.existsSync(Q))v.mkdirSync(Q,{recursive:!0});let Y=b.basename(b.dirname(Z)),O=G.project?.projectFileParsed?.features?.cli?.bin,M=q.name||O||Y;console.log(y.blue(`Using binary name: ${M}`));let H=b.join(Q,M),{spawn:U}=await import("child_process"),T=U("bun",["build","./dist/cli/esm/index.js","--compile",`--outfile=${H}`],{cwd:Z,stdio:"inherit",shell:!0});if(await new Promise((f,B)=>{T.on("close",(A)=>{if(A===0)f();else B(Error(`Compilation failed with code ${A}`))}),T.on("error",(A)=>{B(A)})}),process.platform!=="win32")v.chmodSync(H,493);console.log(y.green(`Binary compiled successfully: ${H}`)),console.log(y.blue("Installing binary..."));let F=["install",H];if(q.name)F.push("--name",q.name);if(q.force)F.push("--force");if(q.yes)F.push("--yes");let _=U("fbin",F,{stdio:"inherit",shell:!0});await new Promise((f,B)=>{_.on("close",(A)=>{if(A===0)f();else B(Error(`Installation failed with code ${A}`))}),_.on("error",(A)=>{B(A)})})}catch(G){console.error(y.red(`Failed to install binary: ${G.message}`)),process.exit(1)}})}import I from"node:path";import w from"node:fs";import q1 from"@fnet/yaml";import A1 from"yaml";async function V($){if($.id)return{id:$.id,buildId:$.buildId,mode:$.mode,protocol:$.protocol||"ac:",templateDir:E("./template/fnode/node"),projectDir:I.resolve(process.cwd(),`./.output/${$.id}`),tags:$.ftag,dev:$.dev};else try{let W=await R1({tags:$.ftag}),z=W.runtime.type==="bun"?"node":W.runtime.type;return{buildId:$.buildId,mode:$.mode,protocol:$.protocol||"src:",templateDir:E(`./template/fnode/${z}`),projectDir:I.resolve(W.projectDir,"./.workspace"),projectSrcDir:I.resolve(W.projectDir,"./src"),project:W,tags:$.ftag,dev:$.dev}}catch(W){return console.warn(`Warning: Could not load project: ${W.message}`),{projectDir:process.cwd(),tags:$.ftag}}}async function R1({tags:$}){let W=N1(process.cwd());if(!w.existsSync(W))throw Error("fnode.yaml file not found in current directory.");let{raw:z,parsed:q}=await q1({file:W,tags:$}),G=I.dirname(W);q.features=q.features||{};let Z=q.features;if(Z.runtime=Z.runtime||{},Z.runtime.type=Z.runtime.type||"node",Z.runtime.type==="python")Z.runtime.template=Z.runtime.template||"python";else if(Z.runtime.type==="bun")Z.runtime.template=Z.runtime.template||"node";else Z.runtime.template=Z.runtime.template||"node";let Q={libraryAtom:{doc:{...q},fileName:"index"},projectDir:G,projectFilePath:W,projectFileContent:z,projectFileParsed:q,runtime:Z.runtime},Y=I.resolve(G,"fnet/targets.yaml");if(!w.existsSync(Y)){if(Y=I.resolve(G,"node.devops.yaml"),w.existsSync(Y)){let M=I.resolve(G,"fnet");if(!w.existsSync(M))w.mkdirSync(M);w.copyFileSync(Y,I.resolve(G,"fnet/targets.yaml")),w.unlinkSync(Y)}}if(w.existsSync(Y)){let{raw:M,parsed:H}=await q1({file:Y,tags:$}),U=A1.parseDocument(M);Q.devops={filePath:Y,fileContent:M,yamlDocument:U,doc:{...H},type:"library.deploy",save:async()=>{w.writeFileSync(Q.devops.filePath,U.toString())}}}let O=I.resolve(G,"readme.md");if(w.existsSync(O)){let M=w.readFileSync(O,"utf8");Q.readme={filePath:O,fileContent:M,doc:{content:M,"content-type":"markdown"},type:"wiki"}}return Q}function N1($){let W=I.resolve($,"node.yaml"),z=I.resolve($,"fnode.yaml");if(w.existsSync(z))return z;if(w.existsSync(W))try{let q=w.readFileSync(W,"utf8");return w.writeFileSync(z,q,"utf8"),w.unlinkSync(W),console.log(`Migrated node.yaml to fnode.yaml in ${$}`),z}catch(q){return console.error(`Error migrating node.yaml to fnode.yaml: ${q.message}`),W}return z}import x1 from"node:path";import z1 from"node:fs";import k1 from"node:os";import S1 from"@flownet/lib-render-templates-dir";import i from"@fnet/shelljs";var E1={command:"create",describe:"Create a new fnode project",builder:($)=>{return $.option("name",{type:"string",describe:"Project name",demandOption:!0}).option("vscode",{type:"boolean",default:!0,alias:"vs",describe:"Open in VS Code after creation"}).option("runtime",{type:"string",default:"node",choices:["node","python","bun"],describe:"Runtime environment"})},handler:async($)=>{try{let W=process.cwd(),z=E("./template/fnode/project"),q=x1.resolve(W,$.name);if(!z1.existsSync(q))z1.mkdirSync(q);await S1({dir:z,outDir:q,context:{name:$.name,runtime:$.runtime,platform:k1.platform()},copyUnmatchedAlso:!0});let G=await i("fnode build",{cwd:q});if(G.code!==0)throw Error("Failed to build project.");if(o("git")){if(G=await i("git init --initial-branch=main",{cwd:q}),G.code!==0)throw Error("Failed to initialize git.")}if(o("code")&&$.vscode){if(G=await i(`cd ${q} && code .`),G.code!==0)throw Error("Failed to open vscode.")}console.log("Creating project succeeded!"),process.exit(0)}catch(W){console.error("Initialization failed!",W.message),process.exit(1)}}},G1=E1;import b1 from"node:os";import y1 from"@flownet/lib-render-templates-dir";import D1 from"@fnet/shelljs";var f1={command:"project",describe:"Manage fnode project",builder:($)=>{return $.option("update",{type:"boolean",default:!1,alias:"-u",describe:"Update project files"})},handler:async($)=>{try{let W=E("./template/fnode/project"),z=process.cwd(),q=await V($);if($.update){if(await y1({dir:W,outDir:z,context:{name:q.project.projectFileParsed.name,runtime:q.project.runtime.type,platform:b1.platform()},copyUnmatchedAlso:!0}),(await D1("fnode build",{cwd:z})).code!==0)throw Error("Failed to build project.");console.log("Updating project succeeded!")}process.exit(0)}catch(W){console.error("Project failed.",W.message),process.exit(1)}}},Q1=f1;class Z1{static async createBuilder($){if(!$.project)return console.warn("No project provided, defaulting to node runtime"),new(await import("./index.rte67vt1.js")).default($);let W=$.project?.runtime?.type||"node";try{return new(await this.loadBuilderClass(W))($)}catch(z){throw Error(`Failed to create builder for runtime '${W}': ${z.message}`)}}static async loadBuilderClass($){switch($.toLowerCase()){case"node":case"bun":return(await import("./index.rte67vt1.js")).default;case"python":return(await import("./index.hv4s25f0.js")).default;default:throw Error(`Unsupported runtime type: ${$}`)}}}var N=Z1;var u1={command:"build",describe:"Build fnode project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"})},handler:async($)=>{try{let W=await V($),z=await N.createBuilder(W);await z.init(),await z.build(),console.log("Building library succeeded!"),process.exit(0)}catch(W){console.error("Building library failed!",W.message),process.exit(1)}}},Y1=u1;var v1={command:"build:dev",describe:"Build fnode project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"})},handler:async($)=>{try{$.dev=!0;let W=await V($),z=await N.createBuilder(W);await z.init(),await z.build(),console.log("Building library succeeded!"),process.exit(0)}catch(W){console.error("Building library failed!",W.message),process.exit(1)}}},K1=v1;var P1={command:"deploy",describe:"Build and deploy fnode project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"})},handler:async($)=>{try{let W=await V({...$,mode:"all"}),z=await N.createBuilder(W);await z.init(),await z.build(),console.log("Building library succeeded!"),process.exit(0)}catch(W){console.error("Building library failed!",W.message),process.exit(1)}}},U1=P1;var j1={command:"file",describe:"Just create files",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"})},handler:async($)=>{try{let W=await V({...$,mode:"file"}),z=await N.createBuilder(W);await z.init(),await z.build(),console.log("Building library succeeded!"),process.exit(0)}catch(W){console.error("Building library failed!",W.message),process.exit(1)}}},H1=j1;import J1 from"node:path";import P from"node:fs";import d1 from"@fnet/prompt";var m1={command:"input [name]",describe:"Create or modify an input config file",builder:($)=>{return $.positional("name",{type:"string",demandOption:!1,describe:"Input name"})},handler:async($)=>{try{let W=await V($),{project:z}=W,{projectDir:q,projectFileParsed:G}=z,Z=G.input;if(!Z)throw Error("Config schema not found in project file.");if(!Reflect.has($,"name")){let{inputName:U}=await d1({type:"input",name:"inputName",message:"Input name:",initial:"dev"});$.name=U}let Q=J1.resolve(q,".fnet");if(!P.existsSync(Q))P.mkdirSync(Q);let Y=J1.resolve(Q,`${$.name}.fnet`),O=P.existsSync(Y),M=(await import("@fnet/object-from-schema")).default,H=await M({schema:Z,format:"yaml",ref:O?Y:void 0});P.writeFileSync(Y,H)}catch(W){console.error(W.message),process.exit(1)}}},M1=m1;import L from"node:path";import J from"node:fs";import d from"node:os";import{spawn as m}from"node:child_process";import K from"chalk";import R from"@fnet/prompt";import j from"chalk";import L1 from"@fnet/prompt";async function g1($){let{items:W,message:z,nameField:q="name",valueField:G="name",initialValue:Z=null,allowAbort:Q=!0}=$;if(!W||W.length===0)return console.log(j.yellow("No items available for selection.")),null;if(W.length===1&&!Q){let U=W[0],T=typeof U==="string"?U:U[G];return console.log(j.blue(`Only one option available: ${typeof U==="string"?U:U[q]}`)),T}let Y=W.map((U)=>{if(typeof U==="string")return{name:U,value:U,message:U};else return{name:U[G],value:U[G],message:U[q]||U[G]}});if(Q)Y.push({name:"cancel",value:null,message:j.yellow("Cancel")});let O=null;if(Z){let U=Y.findIndex((T)=>T.name===Z);if(U!==-1)O=U}let M="selectedItem",{[M]:H}=await L1({type:"select",name:M,message:z,choices:Y,initial:O});if(H==="cancel")return null;return H}async function h1($){let{items:W,message:z,nameField:q="name",valueField:G="name",initialValues:Z=[],allowAbort:Q=!0}=$;if(!W||W.length===0)return console.log(j.yellow("No items available for selection.")),null;let Y=W.map((U)=>{if(typeof U==="string")return{name:U,value:U,message:U};else return{name:U[G],value:U[G],message:U[q]||U[G]}}),O=[];if(Z&&Z.length>0)O=Y.map((U,T)=>Z.includes(U.name)?T:-1).filter((U)=>U!==-1);let M="selectedItems",H=await L1({type:"multiselect",name:M,message:z,choices:Y,initial:O,hint:"(Use space to select, enter to confirm)",validate:(U)=>{if(U.length===0&&!Q)return"Please select at least one item";return!0}});if(Q&&H[M].length===0)return null;return H[M]}var s={promptForSelection:g1,promptForMultipleSelection:h1};var X=L.join(d.homedir(),".fnet","express");async function V1($){$.command(["$0 [project-name]","create [project-name]"],"Create a new express project",(W)=>{return W.positional("project-name",{describe:"Name of the project",type:"string"}).option("yes",{alias:"y",describe:"Skip all prompts and use defaults",type:"boolean",default:!1}).option("runtime",{describe:"Runtime to use (node, python, bun)",type:"string",choices:["node","python","bun"],default:"node"})},async(W)=>{await l1(W)}).command("list","List express projects",(W)=>{return W.option("today",{describe:"Show only projects created today",type:"boolean",default:!1}).option("type",{describe:"Filter by project type (fnode or fnet)",type:"string",choices:["fnode","fnet"]}).option("all",{describe:"Show all projects regardless of type",type:"boolean",default:!1,alias:"a"}).option("name",{describe:"Filter by project name",type:"string"})},async(W)=>{await p1(W)}).command("open [project-name]","Open an express project",(W)=>{return W.positional("project-name",{describe:"Name of the project to open",type:"string"}).option("latest",{describe:"Open the most recent project",type:"boolean",default:!1})},async(W)=>{await n1(W)}).command("move [project-name] [destination]","Move an express project to a real project location",(W)=>{return W.positional("project-name",{describe:"Name of the project to move",type:"string"}).positional("destination",{describe:"Destination directory",type:"string"}).option("latest",{describe:"Move the most recent project",type:"boolean",default:!1})},async(W)=>{await c1(W)}).command("remove [project-name]","Remove an express project",(W)=>{return W.positional("project-name",{describe:"Name of the project to remove",type:"string"}).option("latest",{describe:"Remove the most recent project",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Skip confirmation prompt",type:"boolean",default:!1})},async(W)=>{await o1(W)}).command("enter [project-name]","Enter the directory of an express project in the active terminal",(W)=>{return W.positional("project-name",{describe:"Name of the project to enter",type:"string"}).option("latest",{describe:"Enter the most recent project directory",type:"boolean",default:!1})},async(W)=>{await s1(W)}).demandCommand(1,"You need to specify a command").help()}async function l1($){try{if(!J.existsSync(X))J.mkdirSync(X,{recursive:!0});let W=new Date().toISOString().slice(0,10).replace(/-/g,""),z=L.join(X,W);if(!J.existsSync(z))J.mkdirSync(z,{recursive:!0});let q=$.projectName,G,Z=$.runtime;if(!$.yes){if(!q){let T=J.readdirSync(z).filter((B)=>B.startsWith("fnode-")).map((B)=>parseInt(B.replace("fnode-",""),10)).filter((B)=>!isNaN(B)),_=`fnode-${T.length>0?Math.max(...T)+1:1}`;q=(await R([{type:"input",name:"projectName",message:"Enter project name:",default:_}])).projectName}Z=(await R({type:"select",name:"runtime",message:"Select runtime:",choices:["node","python","bun"],initial:Z||"node"})).runtime}else{if(!q){let H=J.readdirSync(z).filter((T)=>T.startsWith("fnode-")).map((T)=>parseInt(T.replace("fnode-",""),10)).filter((T)=>!isNaN(T));q=`fnode-${H.length>0?Math.max(...H)+1:1}`}if(!Z)Z="node"}if(G=L.join(z,q),J.existsSync(G)){let H=1;while(J.existsSync(L.join(z,`${q}-${H}`)))H++;q=`${q}-${H}`,G=L.join(z,q)}if(!$.yes){if(!(await R([{type:"confirm",name:"proceed",message:`Create express project "${q}" in ${G}?`,default:!0}])).proceed){console.log(K.yellow("Project creation cancelled."));return}}console.log(K.blue(`Creating express project "${q}" in ${G}...`));let Q=L.dirname(G),O=["create","--name",L.basename(G)];if(O.push("--runtime",Z),$.yes)O.push("--yes");if(!J.existsSync(Q))J.mkdirSync(Q,{recursive:!0});let M=m("fnode",O,{stdio:"inherit",shell:!0,cwd:Q});return new Promise((H,U)=>{M.on("close",(T)=>{if(T===0)if(console.log(K.green(`
2
+ import{e as E}from"./index.9qgtmxq3.js";import{f as o}from"./index.05n3mvs9.js";import{g as k,i as S}from"./index.cvxrf34y.js";import q$ from"yargs";import B1 from"chalk";import{promisify as I1}from"node:util";import F1 from"tree-kill";var a=I1(F1),x=!1;async function n($,W){if(x)return;if(x=!0,!$.killed&&$.pid)try{if(await a($.pid,"SIGTERM").catch(()=>{}),await new Promise((q)=>setTimeout(q,500)),!$.killed)await a($.pid,"SIGKILL").catch(()=>{})}catch(q){}await new Promise((q)=>setTimeout(q,100));let z=W==="SIGINT"?130:W==="SIGTERM"?143:1;process.exit(z)}function u($){["SIGINT","SIGTERM","SIGQUIT"].forEach((W)=>{process.once(W,async()=>{await n($,W)})}),process.on("uncaughtException",async(W)=>{await n($)}),process.on("unhandledRejection",async(W)=>{await n($)}),$.on("close",(W)=>{if(!x)process.exit(W)})}function t(){process.on("uncaughtException",($)=>{if(!x)x=!0,setTimeout(()=>process.exit(1),500)}),process.on("unhandledRejection",($)=>{if(!x)x=!0,setTimeout(()=>process.exit(1),500)})}import b from"node:path";import{spawn as c}from"node:child_process";import v from"node:fs";import y from"chalk";import _1 from"@fnet/config";function C($,{name:W,bin:z,preArgs:q=[],createContext:G}){if(typeof z==="function")z=z();return $.command(`${W||z} [commands..]`,`${z} ${q.join(" ")}`,(Z)=>{return Z.help(!1).version(!1)},async(Z)=>{try{let Q=await G(Z),{projectDir:Y}=Q,O=(_)=>{if(!_.includes(" "))return _;if(process.platform==="win32")return`"${_.replace(/(["^])/g,"^$1")}"`;else return`"${_.replace(/(["\\$`])/g,"\\$1")}"`},M=process.argv.slice(3).map(O),H={...process.env},U=b.join(Y,"node_modules");H.NODE_PATH=U;let T=H.NODE_OPTIONS||"";H.NODE_OPTIONS=`${T} --preserve-symlinks`.trim();let F=c(z,[...q,...M],{cwd:Y,stdio:"inherit",shell:!0,detached:!0,env:H});u(F)}catch(Q){console.error(Q.message),process.exit(1)}})}function D($,{name:W,bin:z,preArgs:q=[],createContext:G}){return $.command(`${W||z} [commands..]`,`${z} ${q.join(" ")}`,(Z)=>{return Z.help(!1).version(!1)},async(Z)=>{try{let Q=await G(Z),{projectDir:Y}=Q,O=(U)=>{if(!U.includes(" "))return U;if(process.platform==="win32")return`"${U.replace(/(["^])/g,"^$1")}"`;else return`"${U.replace(/(["\\$`])/g,"\\$1")}"`},M=process.argv.slice(3).map(O);z=b.join(Y,".conda","bin",z||W);let H=c(z,[...q,...M],{cwd:Y,stdio:"inherit",shell:!0,detached:!0,env:{PYTHONPATH:Y}});u(H)}catch(Q){console.error(Q.message),process.exit(1)}})}function e($,{name:W,preArgs:z=[],createContext:q}){return $.command(`${W} <config> <command> [options..]`,"Run a command with a config context",(G)=>{return G.positional("config",{type:"string"}).positional("command",{type:"string"}).help(!1).version(!1)},async(G)=>{try{let Z=await q(G),{projectDir:Q}=Z,Y=G.config,M=(await _1({name:Y,dir:Q,transferEnv:!1,optional:!0,tags:Z.tags}))?.data?.env||void 0,H=G.command,U=process.argv.slice(5),T=c(H,[...z,...U],{cwd:v.existsSync(Q)?Q:process.cwd(),stdio:"inherit",shell:!0,detached:!0,env:{...process.env,...M}});u(T)}catch(Z){console.error(Z.message),process.exit(1)}})}function $1($,{name:W,projectType:z="auto"}){return $.command(`${W} group [options..]`,"Run a command group.",(q)=>{return q.positional("group",{type:"string"}).option("ftag",{type:"array"}).help(!1).version(!1)},async(q)=>{try{let{runCommandGroup:G}=await import("./index.2pnjg6dc.js");await G({projectType:z,group:q.group,tags:q.ftag,args:q,argv:process.argv})}catch(G){console.error(G.message),process.exit(1)}})}function W1($,{name:W,createContext:z}){return $.command(`${W} [options]`,"Install the project as a binary",(q)=>{return q.option("name",{alias:"n",describe:"Name to use for the installed binary",type:"string"}).option("force",{alias:"f",describe:"Force overwrite if binary already exists",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Automatically answer yes to all prompts",type:"boolean",default:!1})},async(q)=>{try{let G=await z(q),{projectDir:Z}=G;console.log(y.blue("Compiling project..."));let Q=b.join(Z,".bin");if(!v.existsSync(Q))v.mkdirSync(Q,{recursive:!0});let Y=b.basename(b.dirname(Z)),O=G.project?.projectFileParsed?.features?.cli?.bin,M=q.name||O||Y;console.log(y.blue(`Using binary name: ${M}`));let H=b.join(Q,M),{spawn:U}=await import("child_process"),T=U("bun",["build","./dist/cli/esm/index.js","--compile",`--outfile=${H}`],{cwd:Z,stdio:"inherit",shell:!0});if(await new Promise((f,B)=>{T.on("close",(A)=>{if(A===0)f();else B(Error(`Compilation failed with code ${A}`))}),T.on("error",(A)=>{B(A)})}),process.platform!=="win32")v.chmodSync(H,493);console.log(y.green(`Binary compiled successfully: ${H}`)),console.log(y.blue("Installing binary..."));let F=["install",H];if(q.name)F.push("--name",q.name);if(q.force)F.push("--force");if(q.yes)F.push("--yes");let _=U("fbin",F,{stdio:"inherit",shell:!0});await new Promise((f,B)=>{_.on("close",(A)=>{if(A===0)f();else B(Error(`Installation failed with code ${A}`))}),_.on("error",(A)=>{B(A)})})}catch(G){console.error(y.red(`Failed to install binary: ${G.message}`)),process.exit(1)}})}import I from"node:path";import w from"node:fs";import q1 from"@fnet/yaml";import A1 from"yaml";async function V($){if($.id)return{id:$.id,buildId:$.buildId,mode:$.mode,protocol:$.protocol||"ac:",templateDir:E("./template/fnode/node"),projectDir:I.resolve(process.cwd(),`./.output/${$.id}`),tags:$.ftag,dev:$.dev};else try{let W=await R1({tags:$.ftag}),z=W.runtime.type==="bun"?"node":W.runtime.type;return{buildId:$.buildId,mode:$.mode,protocol:$.protocol||"src:",templateDir:E(`./template/fnode/${z}`),projectDir:I.resolve(W.projectDir,"./.workspace"),projectSrcDir:I.resolve(W.projectDir,"./src"),project:W,tags:$.ftag,dev:$.dev}}catch(W){return console.warn(`Warning: Could not load project: ${W.message}`),{projectDir:process.cwd(),tags:$.ftag}}}async function R1({tags:$}){let W=N1(process.cwd());if(!w.existsSync(W))throw Error("fnode.yaml file not found in current directory.");let{raw:z,parsed:q}=await q1({file:W,tags:$}),G=I.dirname(W);q.features=q.features||{};let Z=q.features;if(Z.runtime=Z.runtime||{},Z.runtime.type=Z.runtime.type||"node",Z.runtime.type==="python")Z.runtime.template=Z.runtime.template||"python";else if(Z.runtime.type==="bun")Z.runtime.template=Z.runtime.template||"node";else Z.runtime.template=Z.runtime.template||"node";let Q={libraryAtom:{doc:{...q},fileName:"index"},projectDir:G,projectFilePath:W,projectFileContent:z,projectFileParsed:q,runtime:Z.runtime},Y=I.resolve(G,"fnet/targets.yaml");if(!w.existsSync(Y)){if(Y=I.resolve(G,"node.devops.yaml"),w.existsSync(Y)){let M=I.resolve(G,"fnet");if(!w.existsSync(M))w.mkdirSync(M);w.copyFileSync(Y,I.resolve(G,"fnet/targets.yaml")),w.unlinkSync(Y)}}if(w.existsSync(Y)){let{raw:M,parsed:H}=await q1({file:Y,tags:$}),U=A1.parseDocument(M);Q.devops={filePath:Y,fileContent:M,yamlDocument:U,doc:{...H},type:"library.deploy",save:async()=>{w.writeFileSync(Q.devops.filePath,U.toString())}}}let O=I.resolve(G,"readme.md");if(w.existsSync(O)){let M=w.readFileSync(O,"utf8");Q.readme={filePath:O,fileContent:M,doc:{content:M,"content-type":"markdown"},type:"wiki"}}return Q}function N1($){let W=I.resolve($,"node.yaml"),z=I.resolve($,"fnode.yaml");if(w.existsSync(z))return z;if(w.existsSync(W))try{let q=w.readFileSync(W,"utf8");return w.writeFileSync(z,q,"utf8"),w.unlinkSync(W),console.log(`Migrated node.yaml to fnode.yaml in ${$}`),z}catch(q){return console.error(`Error migrating node.yaml to fnode.yaml: ${q.message}`),W}return z}import x1 from"node:path";import z1 from"node:fs";import k1 from"node:os";import S1 from"@flownet/lib-render-templates-dir";import i from"@fnet/shelljs";var E1={command:"create",describe:"Create a new fnode project",builder:($)=>{return $.option("name",{type:"string",describe:"Project name",demandOption:!0}).option("vscode",{type:"boolean",default:!0,alias:"vs",describe:"Open in VS Code after creation"}).option("runtime",{type:"string",default:"node",choices:["node","python","bun"],describe:"Runtime environment"})},handler:async($)=>{try{let W=process.cwd(),z=E("./template/fnode/project"),q=x1.resolve(W,$.name);if(!z1.existsSync(q))z1.mkdirSync(q);await S1({dir:z,outDir:q,context:{name:$.name,runtime:$.runtime,platform:k1.platform()},copyUnmatchedAlso:!0});let G=await i("fnode build",{cwd:q});if(G.code!==0)throw Error("Failed to build project.");if(o("git")){if(G=await i("git init --initial-branch=main",{cwd:q}),G.code!==0)throw Error("Failed to initialize git.")}if(o("code")&&$.vscode){if(G=await i(`cd ${q} && code .`),G.code!==0)throw Error("Failed to open vscode.")}console.log("Creating project succeeded!"),process.exit(0)}catch(W){console.error("Initialization failed!",W.message),process.exit(1)}}},G1=E1;import b1 from"node:os";import y1 from"@flownet/lib-render-templates-dir";import D1 from"@fnet/shelljs";var f1={command:"project",describe:"Manage fnode project",builder:($)=>{return $.option("update",{type:"boolean",default:!1,alias:"-u",describe:"Update project files"})},handler:async($)=>{try{let W=E("./template/fnode/project"),z=process.cwd(),q=await V($);if($.update){if(await y1({dir:W,outDir:z,context:{name:q.project.projectFileParsed.name,runtime:q.project.runtime.type,platform:b1.platform()},copyUnmatchedAlso:!0}),(await D1("fnode build",{cwd:z})).code!==0)throw Error("Failed to build project.");console.log("Updating project succeeded!")}process.exit(0)}catch(W){console.error("Project failed.",W.message),process.exit(1)}}},Q1=f1;class Z1{static async createBuilder($){if(!$.project)return console.warn("No project provided, defaulting to node runtime"),new(await import("./index.a9tw7vtc.js")).default($);let W=$.project?.runtime?.type||"node";try{return new(await this.loadBuilderClass(W))($)}catch(z){throw Error(`Failed to create builder for runtime '${W}': ${z.message}`)}}static async loadBuilderClass($){switch($.toLowerCase()){case"node":case"bun":return(await import("./index.a9tw7vtc.js")).default;case"python":return(await import("./index.hv4s25f0.js")).default;default:throw Error(`Unsupported runtime type: ${$}`)}}}var N=Z1;var u1={command:"build",describe:"Build fnode project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"})},handler:async($)=>{try{let W=await V($),z=await N.createBuilder(W);await z.init(),await z.build(),console.log("Building library succeeded!"),process.exit(0)}catch(W){console.error("Building library failed!",W.message),process.exit(1)}}},Y1=u1;var v1={command:"build:dev",describe:"Build fnode project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"})},handler:async($)=>{try{$.dev=!0;let W=await V($),z=await N.createBuilder(W);await z.init(),await z.build(),console.log("Building library succeeded!"),process.exit(0)}catch(W){console.error("Building library failed!",W.message),process.exit(1)}}},K1=v1;var P1={command:"deploy",describe:"Build and deploy fnode project",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"})},handler:async($)=>{try{let W=await V({...$,mode:"all"}),z=await N.createBuilder(W);await z.init(),await z.build(),console.log("Building library succeeded!"),process.exit(0)}catch(W){console.error("Building library failed!",W.message),process.exit(1)}}},U1=P1;var j1={command:"file",describe:"Just create files",builder:($)=>{return $.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"})},handler:async($)=>{try{let W=await V({...$,mode:"file"}),z=await N.createBuilder(W);await z.init(),await z.build(),console.log("Building library succeeded!"),process.exit(0)}catch(W){console.error("Building library failed!",W.message),process.exit(1)}}},H1=j1;import J1 from"node:path";import P from"node:fs";import d1 from"@fnet/prompt";var m1={command:"input [name]",describe:"Create or modify an input config file",builder:($)=>{return $.positional("name",{type:"string",demandOption:!1,describe:"Input name"})},handler:async($)=>{try{let W=await V($),{project:z}=W,{projectDir:q,projectFileParsed:G}=z,Z=G.input;if(!Z)throw Error("Config schema not found in project file.");if(!Reflect.has($,"name")){let{inputName:U}=await d1({type:"input",name:"inputName",message:"Input name:",initial:"dev"});$.name=U}let Q=J1.resolve(q,".fnet");if(!P.existsSync(Q))P.mkdirSync(Q);let Y=J1.resolve(Q,`${$.name}.fnet`),O=P.existsSync(Y),M=(await import("@fnet/object-from-schema")).default,H=await M({schema:Z,format:"yaml",ref:O?Y:void 0});P.writeFileSync(Y,H)}catch(W){console.error(W.message),process.exit(1)}}},M1=m1;import L from"node:path";import J from"node:fs";import d from"node:os";import{spawn as m}from"node:child_process";import K from"chalk";import R from"@fnet/prompt";import j from"chalk";import L1 from"@fnet/prompt";async function g1($){let{items:W,message:z,nameField:q="name",valueField:G="name",initialValue:Z=null,allowAbort:Q=!0}=$;if(!W||W.length===0)return console.log(j.yellow("No items available for selection.")),null;if(W.length===1&&!Q){let U=W[0],T=typeof U==="string"?U:U[G];return console.log(j.blue(`Only one option available: ${typeof U==="string"?U:U[q]}`)),T}let Y=W.map((U)=>{if(typeof U==="string")return{name:U,value:U,message:U};else return{name:U[G],value:U[G],message:U[q]||U[G]}});if(Q)Y.push({name:"cancel",value:null,message:j.yellow("Cancel")});let O=null;if(Z){let U=Y.findIndex((T)=>T.name===Z);if(U!==-1)O=U}let M="selectedItem",{[M]:H}=await L1({type:"select",name:M,message:z,choices:Y,initial:O});if(H==="cancel")return null;return H}async function h1($){let{items:W,message:z,nameField:q="name",valueField:G="name",initialValues:Z=[],allowAbort:Q=!0}=$;if(!W||W.length===0)return console.log(j.yellow("No items available for selection.")),null;let Y=W.map((U)=>{if(typeof U==="string")return{name:U,value:U,message:U};else return{name:U[G],value:U[G],message:U[q]||U[G]}}),O=[];if(Z&&Z.length>0)O=Y.map((U,T)=>Z.includes(U.name)?T:-1).filter((U)=>U!==-1);let M="selectedItems",H=await L1({type:"multiselect",name:M,message:z,choices:Y,initial:O,hint:"(Use space to select, enter to confirm)",validate:(U)=>{if(U.length===0&&!Q)return"Please select at least one item";return!0}});if(Q&&H[M].length===0)return null;return H[M]}var s={promptForSelection:g1,promptForMultipleSelection:h1};var X=L.join(d.homedir(),".fnet","express");async function V1($){$.command(["$0 [project-name]","create [project-name]"],"Create a new express project",(W)=>{return W.positional("project-name",{describe:"Name of the project",type:"string"}).option("yes",{alias:"y",describe:"Skip all prompts and use defaults",type:"boolean",default:!1}).option("runtime",{describe:"Runtime to use (node, python, bun)",type:"string",choices:["node","python","bun"],default:"node"})},async(W)=>{await l1(W)}).command("list","List express projects",(W)=>{return W.option("today",{describe:"Show only projects created today",type:"boolean",default:!1}).option("type",{describe:"Filter by project type (fnode or fnet)",type:"string",choices:["fnode","fnet"]}).option("all",{describe:"Show all projects regardless of type",type:"boolean",default:!1,alias:"a"}).option("name",{describe:"Filter by project name",type:"string"})},async(W)=>{await p1(W)}).command("open [project-name]","Open an express project",(W)=>{return W.positional("project-name",{describe:"Name of the project to open",type:"string"}).option("latest",{describe:"Open the most recent project",type:"boolean",default:!1})},async(W)=>{await n1(W)}).command("move [project-name] [destination]","Move an express project to a real project location",(W)=>{return W.positional("project-name",{describe:"Name of the project to move",type:"string"}).positional("destination",{describe:"Destination directory",type:"string"}).option("latest",{describe:"Move the most recent project",type:"boolean",default:!1})},async(W)=>{await c1(W)}).command("remove [project-name]","Remove an express project",(W)=>{return W.positional("project-name",{describe:"Name of the project to remove",type:"string"}).option("latest",{describe:"Remove the most recent project",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Skip confirmation prompt",type:"boolean",default:!1})},async(W)=>{await o1(W)}).command("enter [project-name]","Enter the directory of an express project in the active terminal",(W)=>{return W.positional("project-name",{describe:"Name of the project to enter",type:"string"}).option("latest",{describe:"Enter the most recent project directory",type:"boolean",default:!1})},async(W)=>{await s1(W)}).demandCommand(1,"You need to specify a command").help()}async function l1($){try{if(!J.existsSync(X))J.mkdirSync(X,{recursive:!0});let W=new Date().toISOString().slice(0,10).replace(/-/g,""),z=L.join(X,W);if(!J.existsSync(z))J.mkdirSync(z,{recursive:!0});let q=$.projectName,G,Z=$.runtime;if(!$.yes){if(!q){let T=J.readdirSync(z).filter((B)=>B.startsWith("fnode-")).map((B)=>parseInt(B.replace("fnode-",""),10)).filter((B)=>!isNaN(B)),_=`fnode-${T.length>0?Math.max(...T)+1:1}`;q=(await R([{type:"input",name:"projectName",message:"Enter project name:",default:_}])).projectName}Z=(await R({type:"select",name:"runtime",message:"Select runtime:",choices:["node","python","bun"],initial:Z||"node"})).runtime}else{if(!q){let H=J.readdirSync(z).filter((T)=>T.startsWith("fnode-")).map((T)=>parseInt(T.replace("fnode-",""),10)).filter((T)=>!isNaN(T));q=`fnode-${H.length>0?Math.max(...H)+1:1}`}if(!Z)Z="node"}if(G=L.join(z,q),J.existsSync(G)){let H=1;while(J.existsSync(L.join(z,`${q}-${H}`)))H++;q=`${q}-${H}`,G=L.join(z,q)}if(!$.yes){if(!(await R([{type:"confirm",name:"proceed",message:`Create express project "${q}" in ${G}?`,default:!0}])).proceed){console.log(K.yellow("Project creation cancelled."));return}}console.log(K.blue(`Creating express project "${q}" in ${G}...`));let Q=L.dirname(G),O=["create","--name",L.basename(G)];if(O.push("--runtime",Z),$.yes)O.push("--yes");if(!J.existsSync(Q))J.mkdirSync(Q,{recursive:!0});let M=m("fnode",O,{stdio:"inherit",shell:!0,cwd:Q});return new Promise((H,U)=>{M.on("close",(T)=>{if(T===0)if(console.log(K.green(`
3
3
  Express project "${q}" created successfully!`)),console.log(K.blue(`
4
4
  Project location: ${G}`)),!$.yes)i1(G);else H();else console.error(K.red(`
5
5
  Failed to create express project "${q}".`)),U(Error(`Process exited with code ${T}`))})})}catch(W){console.error(K.red(`Error creating express project: ${W.message}`)),process.exit(1)}}async function p1($){try{if(!J.existsSync(X)){console.log(K.yellow("No express projects found."));return}let W=J.readdirSync(X).filter((Q)=>/^\d{8}$/.test(Q)).sort((Q,Y)=>Y.localeCompare(Q));if($.today){let Q=new Date().toISOString().slice(0,10).replace(/-/g,""),Y=W.indexOf(Q);if(Y===-1){console.log(K.yellow("No express projects found for today."));return}W.splice(0,Y),W.splice(1)}let z=[];if(!$.type&&!$.all)$.type="fnode";for(let Q of W){let Y=L.join(X,Q),O=J.readdirSync(Y);for(let M of O){let H=L.join(Y,M),U=J.statSync(H),T="unknown";if(M.startsWith("fnode-")||J.existsSync(L.join(H,"fnode.yaml")))T="fnode";else if(M.startsWith("fnet-")||J.existsSync(L.join(H,"fnet.yaml")))T="fnet";if($.type&&T!==$.type)continue;if($.name&&!M.includes($.name))continue;let F=`${Q.slice(0,4)}-${Q.slice(4,6)}-${Q.slice(6,8)}`;z.push({name:M,type:T,date:F,path:H,created:U.birthtime})}}if(z.sort((Q,Y)=>Y.created-Q.created),z.length===0){console.log(K.yellow("No express projects found matching the criteria."));return}console.log(K.blue(`
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fnet/cli",
3
- "version": "0.3.7",
3
+ "version": "0.3.8",
4
4
  "files": [
5
5
  "dist",
6
6
  "template"