hablas-ai 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +104 -104
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var ny=Object.create;var As=Object.defineProperty;var sy=Object.getOwnPropertyDescriptor;var ry=Object.getOwnPropertyNames;var iy=Object.getPrototypeOf,oy=Object.prototype.hasOwnProperty;var L=(n,e)=>()=>(n&&(e=n(n=0)),e);var N=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports),
|
|
2
|
+
"use strict";var ny=Object.create;var As=Object.defineProperty;var sy=Object.getOwnPropertyDescriptor;var ry=Object.getOwnPropertyNames;var iy=Object.getPrototypeOf,oy=Object.prototype.hasOwnProperty;var L=(n,e)=>()=>(n&&(e=n(n=0)),e);var N=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports),Fe=(n,e)=>{for(var t in e)As(n,t,{get:e[t],enumerable:!0})},tc=(n,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of ry(e))!oy.call(n,r)&&r!==t&&As(n,r,{get:()=>e[r],enumerable:!(s=sy(e,r))||s.enumerable});return n};var O=(n,e,t)=>(t=n!=null?ny(iy(n)):{},tc(e||!n||!n.__esModule?As(t,"default",{value:n,enumerable:!0}):t,n)),ay=n=>tc(As({},"__esModule",{value:!0}),n);var Nn=N(si=>{var $s=class extends Error{constructor(e,t,s){super(s),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name,this.code=t,this.exitCode=e,this.nestedError=void 0}},ni=class extends $s{constructor(e){super(1,"commander.invalidArgument",e),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name}};si.CommanderError=$s;si.InvalidArgumentError=ni});var Cs=N(ii=>{var{InvalidArgumentError:ly}=Nn(),ri=class{constructor(e,t){switch(this.description=t||"",this.variadic=!1,this.parseArg=void 0,this.defaultValue=void 0,this.defaultValueDescription=void 0,this.argChoices=void 0,e[0]){case"<":this.required=!0,this._name=e.slice(1,-1);break;case"[":this.required=!1,this._name=e.slice(1,-1);break;default:this.required=!0,this._name=e;break}this._name.length>3&&this._name.slice(-3)==="..."&&(this.variadic=!0,this._name=this._name.slice(0,-3))}name(){return this._name}_concatValue(e,t){return t===this.defaultValue||!Array.isArray(t)?[e]:t.concat(e)}default(e,t){return this.defaultValue=e,this.defaultValueDescription=t,this}argParser(e){return this.parseArg=e,this}choices(e){return this.argChoices=e.slice(),this.parseArg=(t,s)=>{if(!this.argChoices.includes(t))throw new ly(`Allowed choices are ${this.argChoices.join(", ")}.`);return this.variadic?this._concatValue(t,s):t},this}argRequired(){return this.required=!0,this}argOptional(){return this.required=!1,this}};function cy(n){let e=n.name()+(n.variadic===!0?"...":"");return n.required?"<"+e+">":"["+e+"]"}ii.Argument=ri;ii.humanReadableArgName=cy});var ai=N(nc=>{var{humanReadableArgName:uy}=Cs(),oi=class{constructor(){this.helpWidth=void 0,this.sortSubcommands=!1,this.sortOptions=!1,this.showGlobalOptions=!1}visibleCommands(e){let t=e.commands.filter(r=>!r._hidden),s=e._getHelpCommand();return s&&!s._hidden&&t.push(s),this.sortSubcommands&&t.sort((r,i)=>r.name().localeCompare(i.name())),t}compareOptions(e,t){let s=r=>r.short?r.short.replace(/^-/,""):r.long.replace(/^--/,"");return s(e).localeCompare(s(t))}visibleOptions(e){let t=e.options.filter(r=>!r.hidden),s=e._getHelpOption();if(s&&!s.hidden){let r=s.short&&e._findOption(s.short),i=s.long&&e._findOption(s.long);!r&&!i?t.push(s):s.long&&!i?t.push(e.createOption(s.long,s.description)):s.short&&!r&&t.push(e.createOption(s.short,s.description))}return this.sortOptions&&t.sort(this.compareOptions),t}visibleGlobalOptions(e){if(!this.showGlobalOptions)return[];let t=[];for(let s=e.parent;s;s=s.parent){let r=s.options.filter(i=>!i.hidden);t.push(...r)}return this.sortOptions&&t.sort(this.compareOptions),t}visibleArguments(e){return e._argsDescription&&e.registeredArguments.forEach(t=>{t.description=t.description||e._argsDescription[t.name()]||""}),e.registeredArguments.find(t=>t.description)?e.registeredArguments:[]}subcommandTerm(e){let t=e.registeredArguments.map(s=>uy(s)).join(" ");return e._name+(e._aliases[0]?"|"+e._aliases[0]:"")+(e.options.length?" [options]":"")+(t?" "+t:"")}optionTerm(e){return e.flags}argumentTerm(e){return e.name()}longestSubcommandTermLength(e,t){return t.visibleCommands(e).reduce((s,r)=>Math.max(s,t.subcommandTerm(r).length),0)}longestOptionTermLength(e,t){return t.visibleOptions(e).reduce((s,r)=>Math.max(s,t.optionTerm(r).length),0)}longestGlobalOptionTermLength(e,t){return t.visibleGlobalOptions(e).reduce((s,r)=>Math.max(s,t.optionTerm(r).length),0)}longestArgumentTermLength(e,t){return t.visibleArguments(e).reduce((s,r)=>Math.max(s,t.argumentTerm(r).length),0)}commandUsage(e){let t=e._name;e._aliases[0]&&(t=t+"|"+e._aliases[0]);let s="";for(let r=e.parent;r;r=r.parent)s=r.name()+" "+s;return s+t+" "+e.usage()}commandDescription(e){return e.description()}subcommandDescription(e){return e.summary()||e.description()}optionDescription(e){let t=[];return e.argChoices&&t.push(`choices: ${e.argChoices.map(s=>JSON.stringify(s)).join(", ")}`),e.defaultValue!==void 0&&(e.required||e.optional||e.isBoolean()&&typeof e.defaultValue=="boolean")&&t.push(`default: ${e.defaultValueDescription||JSON.stringify(e.defaultValue)}`),e.presetArg!==void 0&&e.optional&&t.push(`preset: ${JSON.stringify(e.presetArg)}`),e.envVar!==void 0&&t.push(`env: ${e.envVar}`),t.length>0?`${e.description} (${t.join(", ")})`:e.description}argumentDescription(e){let t=[];if(e.argChoices&&t.push(`choices: ${e.argChoices.map(s=>JSON.stringify(s)).join(", ")}`),e.defaultValue!==void 0&&t.push(`default: ${e.defaultValueDescription||JSON.stringify(e.defaultValue)}`),t.length>0){let s=`(${t.join(", ")})`;return e.description?`${e.description} ${s}`:s}return e.description}formatHelp(e,t){let s=t.padWidth(e,t),r=t.helpWidth||80,i=2,o=2;function a(p,g){if(g){let w=`${p.padEnd(s+o)}${g}`;return t.wrap(w,r-i,s+o)}return p}function l(p){return p.join(`
|
|
3
3
|
`).replace(/^/gm," ".repeat(i))}let u=[`Usage: ${t.commandUsage(e)}`,""],d=t.commandDescription(e);d.length>0&&(u=u.concat([t.wrap(d,r,0),""]));let f=t.visibleArguments(e).map(p=>a(t.argumentTerm(p),t.argumentDescription(p)));f.length>0&&(u=u.concat(["Arguments:",l(f),""]));let h=t.visibleOptions(e).map(p=>a(t.optionTerm(p),t.optionDescription(p)));if(h.length>0&&(u=u.concat(["Options:",l(h),""])),this.showGlobalOptions){let p=t.visibleGlobalOptions(e).map(g=>a(t.optionTerm(g),t.optionDescription(g)));p.length>0&&(u=u.concat(["Global Options:",l(p),""]))}let m=t.visibleCommands(e).map(p=>a(t.subcommandTerm(p),t.subcommandDescription(p)));return m.length>0&&(u=u.concat(["Commands:",l(m),""])),u.join(`
|
|
4
4
|
`)}padWidth(e,t){return Math.max(t.longestOptionTermLength(e,t),t.longestGlobalOptionTermLength(e,t),t.longestSubcommandTermLength(e,t),t.longestArgumentTermLength(e,t))}wrap(e,t,s,r=40){let i=" \\f\\t\\v\xA0\u1680\u2000-\u200A\u202F\u205F\u3000\uFEFF",o=new RegExp(`[\\n][${i}]+`);if(e.match(o))return e;let a=t-s;if(a<r)return e;let l=e.slice(0,s),u=e.slice(s).replace(`\r
|
|
5
5
|
`,`
|
|
@@ -20,25 +20,25 @@ Expecting one of '${s.join("', '")}'`);return this._lifeCycleHooks[e]?this._life
|
|
|
20
20
|
`),this.outputHelp({error:!0}));let s=t||{},r=s.exitCode||1,i=s.code||"commander.error";this._exit(r,i,e)}_parseOptionsEnv(){this.options.forEach(e=>{if(e.envVar&&e.envVar in he.env){let t=e.attributeName();(this.getOptionValue(t)===void 0||["default","config","env"].includes(this.getOptionValueSource(t)))&&(e.required||e.optional?this.emit(`optionEnv:${e.name()}`,he.env[e.envVar]):this.emit(`optionEnv:${e.name()}`))}})}_parseOptionsImplied(){let e=new wy(this.options),t=s=>this.getOptionValue(s)!==void 0&&!["default","implied"].includes(this.getOptionValueSource(s));this.options.filter(s=>s.implied!==void 0&&t(s.attributeName())&&e.valueFromOption(this.getOptionValue(s.attributeName()),s)).forEach(s=>{Object.keys(s.implied).filter(r=>!t(r)).forEach(r=>{this.setOptionValueWithSource(r,s.implied[r],"implied")})})}missingArgument(e){let t=`error: missing required argument '${e}'`;this.error(t,{code:"commander.missingArgument"})}optionMissingArgument(e){let t=`error: option '${e.flags}' argument missing`;this.error(t,{code:"commander.optionMissingArgument"})}missingMandatoryOptionValue(e){let t=`error: required option '${e.flags}' not specified`;this.error(t,{code:"commander.missingMandatoryOptionValue"})}_conflictingOption(e,t){let s=o=>{let a=o.attributeName(),l=this.getOptionValue(a),u=this.options.find(f=>f.negate&&a===f.attributeName()),d=this.options.find(f=>!f.negate&&a===f.attributeName());return u&&(u.presetArg===void 0&&l===!1||u.presetArg!==void 0&&l===u.presetArg)?u:d||o},r=o=>{let a=s(o),l=a.attributeName();return this.getOptionValueSource(l)==="env"?`environment variable '${a.envVar}'`:`option '${a.flags}'`},i=`error: ${r(e)} cannot be used with ${r(t)}`;this.error(i,{code:"commander.conflictingOption"})}unknownOption(e){if(this._allowUnknownOption)return;let t="";if(e.startsWith("--")&&this._showSuggestionAfterError){let r=[],i=this;do{let o=i.createHelp().visibleOptions(i).filter(a=>a.long).map(a=>a.long);r=r.concat(o),i=i.parent}while(i&&!i._enablePositionalOptions);t=oc(e,r)}let s=`error: unknown option '${e}'${t}`;this.error(s,{code:"commander.unknownOption"})}_excessArguments(e){if(this._allowExcessArguments)return;let t=this.registeredArguments.length,s=t===1?"":"s",i=`error: too many arguments${this.parent?` for '${this.name()}'`:""}. Expected ${t} argument${s} but got ${e.length}.`;this.error(i,{code:"commander.excessArguments"})}unknownCommand(){let e=this.args[0],t="";if(this._showSuggestionAfterError){let r=[];this.createHelp().visibleCommands(this).forEach(i=>{r.push(i.name()),i.alias()&&r.push(i.alias())}),t=oc(e,r)}let s=`error: unknown command '${e}'${t}`;this.error(s,{code:"commander.unknownCommand"})}version(e,t,s){if(e===void 0)return this._version;this._version=e,t=t||"-V, --version",s=s||"output the version number";let r=this.createOption(t,s);return this._versionOptionName=r.attributeName(),this._registerOption(r),this.on("option:"+r.name(),()=>{this._outputConfiguration.writeOut(`${e}
|
|
21
21
|
`),this._exit(0,"commander.version",e)}),this}description(e,t){return e===void 0&&t===void 0?this._description:(this._description=e,t&&(this._argsDescription=t),this)}summary(e){return e===void 0?this._summary:(this._summary=e,this)}alias(e){if(e===void 0)return this._aliases[0];let t=this;if(this.commands.length!==0&&this.commands[this.commands.length-1]._executableHandler&&(t=this.commands[this.commands.length-1]),e===t._name)throw new Error("Command alias can't be the same as its name");let s=this.parent?._findCommand(e);if(s){let r=[s.name()].concat(s.aliases()).join("|");throw new Error(`cannot add alias '${e}' to command '${this.name()}' as already have command '${r}'`)}return t._aliases.push(e),this}aliases(e){return e===void 0?this._aliases:(e.forEach(t=>this.alias(t)),this)}usage(e){if(e===void 0){if(this._usage)return this._usage;let t=this.registeredArguments.map(s=>by(s));return[].concat(this.options.length||this._helpOption!==null?"[options]":[],this.commands.length?"[command]":[],this.registeredArguments.length?t:[]).join(" ")}return this._usage=e,this}name(e){return e===void 0?this._name:(this._name=e,this)}nameFromFilename(e){return this._name=xt.basename(e,xt.extname(e)),this}executableDir(e){return e===void 0?this._executableDir:(this._executableDir=e,this)}helpInformation(e){let t=this.createHelp();return t.helpWidth===void 0&&(t.helpWidth=e&&e.error?this._outputConfiguration.getErrHelpWidth():this._outputConfiguration.getOutHelpWidth()),t.formatHelp(this,t)}_getHelpContext(e){e=e||{};let t={error:!!e.error},s;return t.error?s=r=>this._outputConfiguration.writeErr(r):s=r=>this._outputConfiguration.writeOut(r),t.write=e.write||s,t.command=this,t}outputHelp(e){let t;typeof e=="function"&&(t=e,e=void 0);let s=this._getHelpContext(e);this._getCommandAndAncestors().reverse().forEach(i=>i.emit("beforeAllHelp",s)),this.emit("beforeHelp",s);let r=this.helpInformation(s);if(t&&(r=t(r),typeof r!="string"&&!Buffer.isBuffer(r)))throw new Error("outputHelp callback must return a string or a Buffer");s.write(r),this._getHelpOption()?.long&&this.emit(this._getHelpOption().long),this.emit("afterHelp",s),this._getCommandAndAncestors().forEach(i=>i.emit("afterAllHelp",s))}helpOption(e,t){return typeof e=="boolean"?(e?this._helpOption=this._helpOption??void 0:this._helpOption=null,this):(e=e??"-h, --help",t=t??"display help for command",this._helpOption=this.createOption(e,t),this)}_getHelpOption(){return this._helpOption===void 0&&this.helpOption(void 0,void 0),this._helpOption}addHelpOption(e){return this._helpOption=e,this}help(e){this.outputHelp(e);let t=he.exitCode||0;t===0&&e&&typeof e!="function"&&e.error&&(t=1),this._exit(t,"commander.help","(outputHelp)")}addHelpText(e,t){let s=["beforeAll","before","after","afterAll"];if(!s.includes(e))throw new Error(`Unexpected value for position to addHelpText.
|
|
22
22
|
Expecting one of '${s.join("', '")}'`);let r=`${e}Help`;return this.on(r,i=>{let o;typeof t=="function"?o=t({error:i.error,command:i.command}):o=t,o&&i.write(`${o}
|
|
23
|
-
`)}),this}_outputHelpIfRequested(e){let t=this._getHelpOption();t&&e.find(r=>t.is(r))&&(this.outputHelp(),this._exit(0,"commander.helpDisplayed","(outputHelp)"))}};function ac(n){return n.map(e=>{if(!e.startsWith("--inspect"))return e;let t,s="127.0.0.1",r="9229",i;return(i=e.match(/^(--inspect(-brk)?)$/))!==null?t=i[1]:(i=e.match(/^(--inspect(-brk|-port)?)=([^:]+)$/))!==null?(t=i[1],/^\d+$/.test(i[3])?r=i[3]:s=i[3]):(i=e.match(/^(--inspect(-brk|-port)?)=([^:]+):(\d+)$/))!==null&&(t=i[1],s=i[3],r=i[4]),t&&r!=="0"?`${t}=${s}:${parseInt(r)+1}`:e})}lc.Command=mi});var pc=N(Ge=>{var{Argument:uc}=Cs(),{Command:gi}=cc(),{CommanderError:xy,InvalidArgumentError:dc}=Nn(),{Help:Sy}=ai(),{Option:fc}=di();Ge.program=new gi;Ge.createCommand=n=>new gi(n);Ge.createOption=(n,e)=>new fc(n,e);Ge.createArgument=(n,e)=>new uc(n,e);Ge.Command=gi;Ge.Option=fc;Ge.Argument=uc;Ge.Help=Sy;Ge.CommanderError=xy;Ge.InvalidArgumentError=dc;Ge.InvalidOptionArgumentError=dc});var gc={};
|
|
23
|
+
`)}),this}_outputHelpIfRequested(e){let t=this._getHelpOption();t&&e.find(r=>t.is(r))&&(this.outputHelp(),this._exit(0,"commander.helpDisplayed","(outputHelp)"))}};function ac(n){return n.map(e=>{if(!e.startsWith("--inspect"))return e;let t,s="127.0.0.1",r="9229",i;return(i=e.match(/^(--inspect(-brk)?)$/))!==null?t=i[1]:(i=e.match(/^(--inspect(-brk|-port)?)=([^:]+)$/))!==null?(t=i[1],/^\d+$/.test(i[3])?r=i[3]:s=i[3]):(i=e.match(/^(--inspect(-brk|-port)?)=([^:]+):(\d+)$/))!==null&&(t=i[1],s=i[3],r=i[4]),t&&r!=="0"?`${t}=${s}:${parseInt(r)+1}`:e})}lc.Command=mi});var pc=N(Ge=>{var{Argument:uc}=Cs(),{Command:gi}=cc(),{CommanderError:xy,InvalidArgumentError:dc}=Nn(),{Help:Sy}=ai(),{Option:fc}=di();Ge.program=new gi;Ge.createCommand=n=>new gi(n);Ge.createOption=(n,e)=>new fc(n,e);Ge.createArgument=(n,e)=>new uc(n,e);Ge.Command=gi;Ge.Option=fc;Ge.Argument=uc;Ge.Help=Sy;Ge.CommanderError=xy;Ge.InvalidArgumentError=dc;Ge.InvalidOptionArgumentError=dc});var gc={};Fe(gc,{DEFAULT_CONFIG:()=>jn,NVIDIA_PROVIDER:()=>Lt});var jn,Lt,Hn=L(()=>{"use strict";jn={model:"stepfun-ai/step-3.7-flash",ollamaHost:"http://localhost:11434",provider:"ollama",apiUrl:"",apiKey:"",contextBudget:32e3,streamingEnabled:!0,autoConfirmSafe:!0,autoMode:!1,workingDirectory:".",historySize:800,timeout:12e4,maxRetries:3,tools:{runCommand:{allowedCommands:[],blocklist:[],timeout:12e4}},ui:{theme:"dark",showTokenCount:!0,diffPreview:!0,compactMode:!1,dashboard:!1},cache:{enabled:!0,maxEntries:100,ttlMs:3e5},logging:{level:"info",file:!0},plugins:{enabled:!0,directory:"~/.hablas/plugins",marketplace:"https://registry.hablas.dev/plugins"},agents:{enabled:!0,orchestration:"auto",maxConcurrent:3},context:{astParsing:!0,projectGraph:!0,longTermMemory:!0,fileWatcher:!0},workspace:{frameworkDetection:!0,gitAwareness:!0,envParsing:!0,autoPush:!1},security:{scanOnCommit:!1,secretDetection:!0,dependencyAudit:!0},analytics:{enabled:!0,trackUsage:!0,weeklyReports:!1},collaboration:{enabled:!1,teamConfigPath:".hablas/team.json",sharedMemory:!1},team:{enabled:!1,user:"",key:""},api:{enabled:!1,port:8080,host:"0.0.0.0",apiKey:""},license:{tier:"free",key:""}},Lt={name:"NVIDIA",apiUrl:"https://integrate.api.nvidia.com/v1",defaultModel:"stepfun-ai/step-3.7-flash",models:["stepfun-ai/step-3.7-flash","nvidia/llama-3.1-nemotron-70b-instruct","nvidia/nemotron-4-340b-instruct","meta/llama-3.1-405b-instruct","meta/llama-3.1-70b-instruct","meta/llama-3.1-8b-instruct","mistralai/mixtral-8x22b-instruct-v0.1","mistralai/mistral-large-latest","google/gemma-2-27b-it","microsoft/phi-3-medium-128k-instruct","deepseek-ai/deepseek-coder-33b-instruct","nvidia/llama-3.1-nemotron-51b-instruct","qwen/qwen2.5-coder-32b-instruct"]}});var Ts,yc=L(()=>{"use strict";Ts=class{baseUrl;model;constructor(e){this.baseUrl=e.ollamaHost,this.model=e.model}setModel(e){this.model=e}getModel(){return this.model}async checkConnection(){try{return(await fetch(`${this.baseUrl}/api/tags`,{signal:AbortSignal.timeout(5e3)})).ok}catch{return!1}}async listModels(){try{let e=await fetch(`${this.baseUrl}/api/tags`,{signal:AbortSignal.timeout(5e3)});return e.ok?((await e.json()).models||[]).map(s=>s.name):[]}catch{return[]}}async chatWithTools(e,t,s){let r={model:this.model,messages:e,stream:!1};t.length>0&&(r.tools=t);let i={method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)};s&&(i.signal=s);let o=await fetch(`${this.baseUrl}/api/chat`,i);if(!o.ok){let l=await o.text().catch(()=>"");throw new Error(`Ollama error: ${o.status} ${o.statusText} \u2014 ${l}`)}return await o.json()}async*streamChat(e,t){let s=await fetch(`${this.baseUrl}/api/chat`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:this.model,messages:e,stream:!0}),signal:t});if(!s.ok)throw new Error(`Ollama error: ${s.status} ${s.statusText}`);let r=s.body?.getReader();if(!r)throw new Error("No response body");let i=new TextDecoder,o="";for(;;){let{done:a,value:l}=await r.read();if(a)break;o+=i.decode(l,{stream:!0});let u=o.split(`
|
|
24
24
|
`);o=u.pop()||"";for(let d of u)if(d.trim())try{let f=JSON.parse(d);f.message?.content&&(yield f.message.content)}catch{}}}}});function wc(n){return n.map(e=>{if(e.role==="assistant"&&e.tool_calls&&e.tool_calls.length>0){let t=e.tool_calls.filter(s=>s&&s.function&&s.function.name);if(t.length>0)return{role:"assistant",content:e.content||null,tool_calls:t.map((s,r)=>({id:`call_${r}`,type:"function",function:{name:s.function.name,arguments:JSON.stringify(s.function.arguments||{})}}))}}return e.role==="tool"?{role:"tool",content:e.content,tool_call_id:"call_0"}:{role:e.role,content:e.content}})}function Ay(n){return n.map(e=>({type:"function",function:e.function}))}function $y(n){return n.filter(e=>e&&e.function&&e.function.name).map(e=>{let t={};try{t=JSON.parse(e.function.arguments||"{}")}catch{t={_raw:e.function.arguments}}return{function:{name:e.function.name,arguments:t}}})}function xc(n){return new Promise(e=>setTimeout(e,n))}function Sc(n,e){return!(n.name==="AbortError"||e&&e>=400&&e<500&&e!==429)}var bc,_y,Es,vc,ky,Vt,yi=L(()=>{"use strict";bc=12e4,_y=6e4,Es=3,vc=1e3,ky=20;Vt=class{apiUrl;apiKey;model;constructor(e){this.apiUrl=e.apiUrl||"https://api.openai.com/v1",this.apiKey=e.apiKey,this.model=e.model}setModel(e){this.model=e}getModel(){return this.model}setApiUrl(e){this.apiUrl=e}getApiUrl(){return this.apiUrl}setApiKey(e){this.apiKey=e}async checkConnection(){try{let e=this.apiUrl.replace(/\/+$/,"")+"/models";return(await fetch(e,{headers:this.getHeaders(),signal:AbortSignal.timeout(15e3)})).ok}catch{return!1}}async listModels(){try{let e=[],t=!0,s,r=0;for(;t&&r<ky;){let i=this.apiUrl.replace(/\/+$/,"")+"/models",o=new URLSearchParams;s&&o.set("after",s),o.set("limit","1000");let a=o.toString();a&&(i+="?"+a);let l=await fetch(i,{headers:this.getHeaders(),signal:AbortSignal.timeout(_y)});if(!l.ok)break;let u=await l.json();if(Array.isArray(u))e.push(...u.map(d=>d.id||d.name||d).filter(Boolean)),t=!1;else if(u.data&&Array.isArray(u.data)){let d=u.data.map(f=>f.id||f.name).filter(Boolean);e.push(...d),u.has_more&&d.length>0?(s=d[d.length-1],r++):t=!1}else u.models&&Array.isArray(u.models)&&e.push(...u.models.map(d=>d.name||d.id).filter(Boolean)),t=!1}return e.sort((i,o)=>i.localeCompare(o))}catch{return[]}}async chatWithTools(e,t,s){let r=this.apiUrl.replace(/\/+$/,"")+"/chat/completions",i={model:this.model,messages:wc(e)};t.length>0&&(i.tools=Ay(t),i.tool_choice="auto");let o=null;for(let a=0;a<=Es;a++)try{let l=new AbortController,u=setTimeout(()=>l.abort(),bc),d={method:"POST",headers:{"Content-Type":"application/json",...this.getHeaders()},body:JSON.stringify(i),signal:s||l.signal};try{let f=await fetch(r,d);if(clearTimeout(u),!f.ok){let g=await f.text().catch(()=>"");if(!Sc(null,f.status))throw new Error(`API error: ${f.status} ${f.statusText} \u2014 ${g}`);if(o=new Error(`API error: ${f.status} ${f.statusText} \u2014 ${g}`),a<Es){let w=vc*Math.pow(2,a);await xc(w);continue}throw o}let m=(await f.json()).choices?.[0];if(!m)throw new Error("API returned empty response");let p=m.message.tool_calls?$y(m.message.tool_calls):void 0;return{message:{role:m.message.role||"assistant",content:m.message.content||"",tool_calls:p},done:!0,done_reason:m.finish_reason}}catch(f){if(clearTimeout(u),f.name==="AbortError"&&s?.aborted)throw f;if(Sc(f)&&(o=f,a<Es)){let h=vc*Math.pow(2,a);await xc(h);continue}throw f}}catch(l){if(l.name==="AbortError")throw l;if(o=l,a>=Es)throw o}throw o||new Error("Request failed after retries")}async*streamChat(e,t){let s=this.apiUrl.replace(/\/+$/,"")+"/chat/completions",r=await fetch(s,{method:"POST",headers:{"Content-Type":"application/json",...this.getHeaders()},body:JSON.stringify({model:this.model,messages:wc(e),stream:!0}),signal:t||AbortSignal.timeout(bc)});if(!r.ok)throw new Error(`API error: ${r.status} ${r.statusText}`);let i=r.body?.getReader();if(!i)throw new Error("No response body");let o=new TextDecoder,a="";for(;;){let{done:l,value:u}=await i.read();if(l)break;a+=o.decode(u,{stream:!0});let d=a.split(`
|
|
25
|
-
`);a=d.pop()||"";for(let f of d){let h=f.trim();if(!(!h||h==="data: [DONE]")&&h.startsWith("data: "))try{let p=JSON.parse(h.slice(6)).choices?.[0]?.delta?.content;p&&(yield p)}catch{}}}}getHeaders(){let e={};return this.apiKey&&(e.Authorization=`Bearer ${this.apiKey}`),e}}});function
|
|
25
|
+
`);a=d.pop()||"";for(let f of d){let h=f.trim();if(!(!h||h==="data: [DONE]")&&h.startsWith("data: "))try{let p=JSON.parse(h.slice(6)).choices?.[0]?.delta?.content;p&&(yield p)}catch{}}}}getHeaders(){let e={};return this.apiKey&&(e.Authorization=`Bearer ${this.apiKey}`),e}}});function Ne(n){if(n.provider==="nvidia"){let e={...n,provider:"custom",apiUrl:Lt.apiUrl};return new Vt(e)}return n.provider==="custom"&&n.apiUrl?new Vt(n):new Ts(n)}function Rs(n){if(n.provider==="nvidia")return"NVIDIA NIM";if(n.provider==="custom")try{return`Custom (${new URL(n.apiUrl).hostname})`}catch{return"Custom API"}return"Ollama (local)"}var Bn=L(()=>{"use strict";Hn();yc();yi()});var _c=L(()=>{"use strict"});function zt(){let n={providers:[],activeProvider:null,activeModel:null};try{if(St.existsSync(vi)){let e=St.readFileSync(vi,"utf-8"),t=JSON.parse(e);return{...n,...t}}}catch{}return n}function xi(n){St.existsSync(bi)||St.mkdirSync(bi,{recursive:!0}),St.writeFileSync(vi,JSON.stringify(n,null,2),"utf-8")}function tt(n){let e=zt();e.providers=e.providers.filter(t=>t.name!==n.name),e.providers.push(n),xi(e)}function Ac(n){let e=zt(),t=e.providers.length;return e.providers=e.providers.filter(s=>s.name!==n),e.providers.length<t?(e.activeProvider===n&&(e.activeProvider=null,e.activeModel=null),xi(e),!0):!1}function $c(n){return zt().providers.find(t=>t.name.toLowerCase()===n.toLowerCase())}function Ps(){return zt().providers}function Cc(n,e){let t=zt(),s=t.providers.find(r=>r.name===n);s&&(t.activeProvider=n,t.activeModel=e||s.defaultModel,xi(t))}function Tc(n,e){if(n.length===0)return" No saved providers. Use /addmodel to add one.";let t=[];t.push(" Saved Providers:"),t.push("");for(let s of n){let r=s.name===e,i=r?" \u25CF active":"",o=s.apiKey?"***"+s.apiKey.slice(-4):"no key";t.push(` ${r?"\u25B8":"\xB7"} ${s.name}${i}`),t.push(` URL: ${s.apiUrl}`),t.push(` Key: ${o}`),t.push(` Model: ${s.defaultModel}`),t.push(` Added: ${new Date(s.addedAt).toLocaleDateString()}`),t.push("")}return t.join(`
|
|
26
26
|
`)}var St,wi,kc,bi,vi,Si=L(()=>{"use strict";St=O(require("fs")),wi=O(require("path")),kc=O(require("os"));_c();bi=wi.join(kc.homedir(),".hablas"),vi=wi.join(bi,"models.json")});function Is(){try{if(_t.existsSync(Os))return JSON.parse(_t.readFileSync(Os,"utf-8"))}catch{}return{}}function Rc(n){let e=Ms.dirname(Os);_t.existsSync(e)||_t.mkdirSync(e,{recursive:!0}),_t.writeFileSync(Os,JSON.stringify(n,null,2),"utf-8")}function Pc(n,e){let t=Is();t[n]=e,Rc(t)}function Oc(n){let e=Is();return e[n]?(delete e[n],Rc(e),!0):!1}function Mc(n){let e=Is(),t=n.trim();for(let[s,r]of Object.entries(e))if(t===s||t.startsWith(s+" "))return t.replace(s,r);return n}function Ic(){let n=Is(),e=Object.entries(n);return e.length===0?` No aliases defined.
|
|
27
27
|
Use: /alias set <name> <command>`:e.map(([t,s])=>` ${t} \u2192 ${s}`).join(`
|
|
28
|
-
`)}var _t,Ms,Ec,Os,_i=L(()=>{"use strict";_t=O(require("fs")),Ms=O(require("path")),Ec=O(require("os")),Os=Ms.join(Ec.homedir(),".hablas","aliases.json")});var Fc={};
|
|
28
|
+
`)}var _t,Ms,Ec,Os,_i=L(()=>{"use strict";_t=O(require("fs")),Ms=O(require("path")),Ec=O(require("os")),Os=Ms.join(Ec.homedir(),".hablas","aliases.json")});var Fc={};Fe(Fc,{disablePlugin:()=>Ci,enablePlugin:()=>$i,ensurePluginsDir:()=>Fs,listPlugins:()=>Lc,renderPlugins:()=>Ti});function Ai(){try{if(je.existsSync(Ls))return JSON.parse(je.readFileSync(Ls,"utf-8"))}catch{}return{disabled:[]}}function Dc(n){let e=hn.dirname(Ls);je.existsSync(e)||je.mkdirSync(e,{recursive:!0}),je.writeFileSync(Ls,JSON.stringify(n,null,2),"utf-8")}function Fs(){je.existsSync(Ds)||je.mkdirSync(Ds,{recursive:!0})}function Lc(){Fs();let n=Ai(),e=[];try{let t=je.readdirSync(Ds).filter(s=>s.endsWith(".js"));for(let s of t){let r=hn.join(Ds,s);try{let i=require(r);e.push({name:i.name||s.replace(".js",""),description:i.description||"No description",version:i.version||"0.0.0",enabled:!n.disabled.includes(i.name||s.replace(".js","")),path:r,commands:i.commands})}catch{e.push({name:s.replace(".js",""),description:"Failed to load",version:"?",enabled:!1,path:r})}}}catch{}return e}function $i(n){let e=Ai(),t=e.disabled.indexOf(n);return t!==-1?(e.disabled.splice(t,1),Dc(e),!0):!1}function Ci(n){let e=Ai();return e.disabled.includes(n)?!1:(e.disabled.push(n),Dc(e),!0)}function Ti(){let n=Lc();return n.length===0?` No plugins installed.
|
|
29
29
|
Add .js files to ~/.hablas/plugins/`:n.map(e=>{let t=e.enabled?"\u25CF enabled":"\u25CB disabled";return` ${e.name} v${e.version} [${t}]
|
|
30
30
|
${e.description}`}).join(`
|
|
31
31
|
|
|
32
|
-
`)}var
|
|
32
|
+
`)}var je,hn,ki,Ds,Ls,Ei=L(()=>{"use strict";je=O(require("fs")),hn=O(require("path")),ki=O(require("os")),Ds=hn.join(ki.homedir(),".hablas","plugins"),Ls=hn.join(ki.homedir(),".hablas","plugins.json")});var Hc={};Fe(Hc,{renderDiagnostics:()=>Oi,runDiagnostics:()=>Pi});async function Pi(n){let e=[],t=process.version,s=parseInt(t.slice(1).split(".")[0],10);e.push({name:"Node.js",status:s>=20?"ok":s>=18?"warn":"error",message:s>=20?`${t} (recommended)`:s>=18?`${t} (works, but 20+ recommended)`:`${t} (too old, need 20+)`});let r=Nc.join(nt.homedir(),".hablas");if(e.push({name:"Config directory",status:Ri.existsSync(r)?"ok":"warn",message:Ri.existsSync(r)?r:"Not created yet (will be created on first use)"}),n.provider==="ollama")try{let i=await fetch(`${n.ollamaHost}/api/tags`,{signal:AbortSignal.timeout(5e3)});if(i.ok){let o=await i.json(),a=Array.isArray(o.models)?o.models.length:0;e.push({name:"Ollama",status:"ok",message:`Connected \u2014 ${a} models available`})}else e.push({name:"Ollama",status:"error",message:`HTTP ${i.status}`})}catch(i){let o=i instanceof Error?i.message:String(i);e.push({name:"Ollama",status:"error",message:o.includes("ECONNREFUSED")?"Not running \u2014 start with: ollama serve":`Connection failed: ${o}`})}else{let i=n.apiUrl||"unknown";try{let o=await fetch(`${i}/models`,{signal:AbortSignal.timeout(5e3),headers:{Authorization:"Bearer test"}});e.push({name:"API Provider",status:o.ok||o.status===401?"ok":"warn",message:`${i} \u2014 reachable`})}catch{e.push({name:"API Provider",status:"warn",message:`${i} \u2014 could not verify`})}}try{let i=nt.homedir();if(process.platform!=="win32"){let a=(0,jc.execSync)(`df -h "${i}" | tail -1`,{encoding:"utf-8"}).trim().split(/\s+/),l=a[3]||"unknown",u=a[4]||"?";e.push({name:"Disk space",status:parseInt(u)>90?"warn":"ok",message:`${l} available (${u} used)`})}else e.push({name:"Disk space",status:"ok",message:"Check skipped on Windows"})}catch{e.push({name:"Disk space",status:"ok",message:"Could not determine"})}return e.push({name:"Active model",status:n.model?"ok":"warn",message:n.model||"No model configured"}),e.push({name:"Platform",status:"ok",message:`${nt.platform()} ${nt.arch()} \u2014 ${nt.cpus().length} cores, ${Math.round(nt.totalmem()/1024/1024/1024)}GB RAM`}),e}function Oi(n){let e={ok:"\u2713",warn:"\u26A0",error:"\u2717"},t={ok:"\x1B[32m",warn:"\x1B[33m",error:"\x1B[31m"},s="\x1B[0m",r="\x1B[2m",i=[""," \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501"," hablas doctor \u2014 System Diagnostics"," \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501",""];for(let l of n){let u=`${t[l.status]}${e[l.status]}${s}`,d=l.name.padEnd(18);i.push(` ${u} ${d}${r}${l.message}${s}`)}let o=n.filter(l=>l.status==="error").length,a=n.filter(l=>l.status==="warn").length;return i.push(""),o>0?i.push(` ${t.error}${o} error(s) found \u2014 fix these for hablas to work properly${s}`):a>0?i.push(` ${t.warn}${a} warning(s) \u2014 hablas should work but check the items above${s}`):i.push(` ${t.ok}All checks passed \u2014 hablas is ready!${s}`),i.push(""),i.join(`
|
|
33
33
|
`)}var Ri,Nc,nt,jc,Mi=L(()=>{"use strict";Ri=O(require("fs")),Nc=O(require("path")),nt=O(require("os")),jc=require("child_process")});function Un(n){let e=n.trim();return!!(e.length<15&&!Bc.test(e)||Cy.test(e)||Ty.test(e)||Ey.test(e)||Ry.test(e))}function Ns(n){let e=n.toLowerCase(),t=["hablas"];return Un(n)||(/\b(design|architect|schema|structure|api\s*design|database\s*design|system\s*design|blueprint|uml|erd|class\s*diagram)\b/i.test(e)&&t.push("bob"),/\b(create|build|implement|write|generate|code|function|component|class|fix|bug|debug|deploy|docker|ci\/cd|test|refactor|edit|modify|update|change)\b/i.test(e)&&t.push("alex"),/\b(research|find\s+info|search\s+for|documentation|how\s+to|best\s+practice|compare|analyze|data\s+analysis|optimize|benchmark|explain\s+concept)\b/i.test(e)&&t.push("david"),/\b(prd|product\s*requirements|user\s*stories|market\s*research|competitive\s*analysis|requirements\s*document|feature\s*spec|product\s*spec|stakeholder|user\s*needs|roadmap)\b/i.test(e)&&t.push("emma"),t.length===1&&Bc.test(n)&&t.push("alex")),t}function js(n,e){let t=[],s=1,r=e.includes("emma"),i=e.includes("bob"),o=e.includes("alex"),a=e.includes("david");if(r&&t.push({id:`task-${s++}`,role:"emma",agentName:"Emma",description:"Analyze requirements, create PRD, and define user stories",input:n,dependencies:[],status:"pending"}),a&&t.push({id:`task-${s++}`,role:"david",agentName:"David",description:"Research requirements, best practices, and relevant documentation",input:n,dependencies:r?[t.find(u=>u.role==="emma").id]:[],status:"pending"}),i){let u=[];a?u.push(t.find(d=>d.role==="david").id):r&&u.push(t.find(d=>d.role==="emma").id),t.push({id:`task-${s++}`,role:"bob",agentName:"Bob",description:"Design system architecture and structure",input:n,dependencies:u,status:"pending"})}if(o){let u=[];i?u.push(t.find(d=>d.role==="bob").id):a?u.push(t.find(d=>d.role==="david").id):r&&u.push(t.find(d=>d.role==="emma").id),t.push({id:`task-${s++}`,role:"alex",agentName:"Alex",description:"Implement the code based on architecture/requirements",input:n,dependencies:u,status:"pending"})}let l="sequential";return t.length>2&&t.some(u=>u.dependencies.length===0)&&(l="mixed"),{id:`plan-${Date.now()}`,description:`Orchestration plan for: ${n.substring(0,100)}`,tasks:t,strategy:l,createdAt:new Date,approved:!1}}function Ii(){let n=[];for(let e of Se){let s=e.role==="hablas"?" \u2605":"";n.push(` @${e.name}${s} \u2014 ${e.title}`),n.push(` ${e.description}`)}return n.join(`
|
|
34
|
-
`)}var Se,Cy,Ty,Ey,Ry,Bc,mn=L(()=>{"use strict";Se=[{role:"hablas",name:"Hablas",title:"Team Leader",description:"Software Engineer & Team Coordinator. Receives user requests, creates plans, distributes tasks, and compiles final responses.",expertise:["planning","coordination","architecture","code-review","decision-making"]},{role:"bob",name:"Bob",title:"Architect",description:"System Architect. Designs software architecture, database schemas, API structures, and system blueprints.",expertise:["system-design","architecture","database","api-design","scalability"]},{role:"alex",name:"Alex",title:"Engineer",description:"Full-Stack Engineer. Implements code, builds features, fixes bugs, handles DevOps and deployment.",expertise:["coding","implementation","debugging","devops","testing","deployment"]},{role:"david",name:"David",title:"Data Analyst",description:"Data & Research Specialist. Handles research, data analysis, documentation, and information gathering.",expertise:["research","data-analysis","documentation","ml","optimization"]},{role:"emma",name:"Emma",title:"Product Manager",description:"Product Manager. Analyzes user needs, creates PRDs, competitive analysis, market research, and requirement specifications.",expertise:["product-management","requirements","prd","market-research","competitive-analysis","user-stories"]}],Cy=/^(hi|hello|hey|howdy|yo|sup|hiya|good\s*(morning|afternoon|evening|night)|what'?s\s*up|greetings)\b/i,Ty=/^(مرحبا|أهلا|أهلاً|هلا|السلام\s*عليكم|وعليكم\s*السلام|كيف\s*حالك|كيفك|شلونك|صباح\s*الخير|مساء\s*الخير|شكرا|شكراً|يعطيك\s*العافية|تمام|اهلين|هلو|مرحبتين|الله\s*يسلمك|حياك|حياك\s*الله|يا\s*هلا|كيف\s*الحال|اخبارك|شخبارك)/i,Ey=/^(thanks?|thank\s*you|bye|goodbye|see\s*ya|ok(ay)?|yes|no|yep|nope|cool|nice|great|got\s*it|sure|alright|fine|good|perfect|awesome|amazing|wow|lol|haha|hmm|well|right|exactly|indeed|absolutely|of\s*course|no\s*problem|you'?re\s*welcome|np)\s*[.!?]*$/i,Ry=/^(how\s*are\s*you|what'?s\s*your\s*name|who\s*are\s*you|what\s*can\s*you\s*do|help|can\s*you\s*help|what\s*is\s*this|tell\s*me\s*about\s*yourself)\s*[?!.]*$/i,Bc=/\b(create|build|implement|write|generate|code|make|develop|design|architect|setup|configure|install|deploy|fix|debug|refactor|rewrite|restructure|migrate|convert|add|remove|delete|update|change|modify|edit|move|rename|test|run|execute|analyze|research|find|search|compare|optimize|benchmark)\b/i});function qn(){try{if(gn.existsSync(Di)){let n=gn.readFileSync(Di,"utf-8"),e=JSON.parse(n);return{...Uc,...e}}}catch{}return{...Uc}}function Kc(){return Di}var gn,Li,qc,Di,Uc,Fi=L(()=>{"use strict";gn=O(require("fs")),Li=O(require("path")),qc=O(require("os")),Di=Li.join(qc.homedir(),".hablas","agents.json"),Uc={hablas:{model:"stepfun-ai/step-3.7-flash",temperature:.7},bob:{model:"stepfun-ai/step-3.7-flash",temperature:.4},alex:{model:"stepfun-ai/step-3.7-flash",temperature:.2},david:{model:"stepfun-ai/step-3.7-flash",temperature:.5},emma:{model:"stepfun-ai/step-3.7-flash",temperature:.6}}});var Ki={};
|
|
34
|
+
`)}var Se,Cy,Ty,Ey,Ry,Bc,mn=L(()=>{"use strict";Se=[{role:"hablas",name:"Hablas",title:"Team Leader",description:"Software Engineer & Team Coordinator. Receives user requests, creates plans, distributes tasks, and compiles final responses.",expertise:["planning","coordination","architecture","code-review","decision-making"]},{role:"bob",name:"Bob",title:"Architect",description:"System Architect. Designs software architecture, database schemas, API structures, and system blueprints.",expertise:["system-design","architecture","database","api-design","scalability"]},{role:"alex",name:"Alex",title:"Engineer",description:"Full-Stack Engineer. Implements code, builds features, fixes bugs, handles DevOps and deployment.",expertise:["coding","implementation","debugging","devops","testing","deployment"]},{role:"david",name:"David",title:"Data Analyst",description:"Data & Research Specialist. Handles research, data analysis, documentation, and information gathering.",expertise:["research","data-analysis","documentation","ml","optimization"]},{role:"emma",name:"Emma",title:"Product Manager",description:"Product Manager. Analyzes user needs, creates PRDs, competitive analysis, market research, and requirement specifications.",expertise:["product-management","requirements","prd","market-research","competitive-analysis","user-stories"]}],Cy=/^(hi|hello|hey|howdy|yo|sup|hiya|good\s*(morning|afternoon|evening|night)|what'?s\s*up|greetings)\b/i,Ty=/^(مرحبا|أهلا|أهلاً|هلا|السلام\s*عليكم|وعليكم\s*السلام|كيف\s*حالك|كيفك|شلونك|صباح\s*الخير|مساء\s*الخير|شكرا|شكراً|يعطيك\s*العافية|تمام|اهلين|هلو|مرحبتين|الله\s*يسلمك|حياك|حياك\s*الله|يا\s*هلا|كيف\s*الحال|اخبارك|شخبارك)/i,Ey=/^(thanks?|thank\s*you|bye|goodbye|see\s*ya|ok(ay)?|yes|no|yep|nope|cool|nice|great|got\s*it|sure|alright|fine|good|perfect|awesome|amazing|wow|lol|haha|hmm|well|right|exactly|indeed|absolutely|of\s*course|no\s*problem|you'?re\s*welcome|np)\s*[.!?]*$/i,Ry=/^(how\s*are\s*you|what'?s\s*your\s*name|who\s*are\s*you|what\s*can\s*you\s*do|help|can\s*you\s*help|what\s*is\s*this|tell\s*me\s*about\s*yourself)\s*[?!.]*$/i,Bc=/\b(create|build|implement|write|generate|code|make|develop|design|architect|setup|configure|install|deploy|fix|debug|refactor|rewrite|restructure|migrate|convert|add|remove|delete|update|change|modify|edit|move|rename|test|run|execute|analyze|research|find|search|compare|optimize|benchmark)\b/i});function qn(){try{if(gn.existsSync(Di)){let n=gn.readFileSync(Di,"utf-8"),e=JSON.parse(n);return{...Uc,...e}}}catch{}return{...Uc}}function Kc(){return Di}var gn,Li,qc,Di,Uc,Fi=L(()=>{"use strict";gn=O(require("fs")),Li=O(require("path")),qc=O(require("os")),Di=Li.join(qc.homedir(),".hablas","agents.json"),Uc={hablas:{model:"stepfun-ai/step-3.7-flash",temperature:.7},bob:{model:"stepfun-ai/step-3.7-flash",temperature:.4},alex:{model:"stepfun-ai/step-3.7-flash",temperature:.2},david:{model:"stepfun-ai/step-3.7-flash",temperature:.5},emma:{model:"stepfun-ai/step-3.7-flash",temperature:.6}}});var Ki={};Fe(Ki,{formatStats:()=>Iy,loadStats:()=>Kn,saveStats:()=>At,trackAgentUsage:()=>yn,trackFileModified:()=>Oy,trackMessage:()=>Ui,trackSession:()=>Bi,trackToolCall:()=>qi});function Kn(){try{if(kt.existsSync(ji))return JSON.parse(kt.readFileSync(ji,"utf-8"))}catch{}return Py()}function At(n){try{kt.existsSync(Ni)||kt.mkdirSync(Ni,{recursive:!0}),kt.writeFileSync(ji,JSON.stringify(n,null,2))}catch{}}function Py(){return{totalSessions:0,totalMessages:0,totalTokensUsed:0,totalToolCalls:0,totalFilesModified:0,totalLinesWritten:0,totalBugsFixed:0,totalCommits:0,agentUsage:{},commandUsage:{},dailyActivity:{},streak:0,longestStreak:0,firstUsed:new Date().toISOString(),lastUsed:new Date().toISOString()}}function Bi(n){return n.totalSessions++,n.lastUsed=new Date().toISOString(),My(n),n}function Ui(n,e=0){n.totalMessages++,n.totalTokensUsed+=e;let t=Hs();return n.dailyActivity[t]||(n.dailyActivity[t]={messages:0,tokens:0,toolCalls:0,filesModified:0,linesWritten:0}),n.dailyActivity[t].messages++,n.dailyActivity[t].tokens+=e,n}function qi(n,e){n.totalToolCalls++,n.commandUsage[e]=(n.commandUsage[e]||0)+1;let t=Hs();return n.dailyActivity[t]||(n.dailyActivity[t]={messages:0,tokens:0,toolCalls:0,filesModified:0,linesWritten:0}),n.dailyActivity[t].toolCalls++,n}function yn(n,e){return n.agentUsage[e]=(n.agentUsage[e]||0)+1,n}function Oy(n,e=0){n.totalFilesModified++,n.totalLinesWritten+=e;let t=Hs();return n.dailyActivity[t]||(n.dailyActivity[t]={messages:0,tokens:0,toolCalls:0,filesModified:0,linesWritten:0}),n.dailyActivity[t].filesModified++,n.dailyActivity[t].linesWritten+=e,n}function My(n){let e=Hs(),t=Gc(new Date(Date.now()-864e5));n.dailyActivity[t]||n.dailyActivity[e]?n.streak++:n.streak=1,n.streak>n.longestStreak&&(n.longestStreak=n.streak)}function Hs(){return Gc(new Date)}function Gc(n){return n.toISOString().split("T")[0]}function Iy(n){let e=[];e.push(`
|
|
35
35
|
\u{1F4CA} Developer Analytics`),e.push(" \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"),e.push(` Sessions: ${n.totalSessions}`),e.push(` Messages: ${n.totalMessages}`),e.push(` Tokens used: ${n.totalTokensUsed.toLocaleString()}`),e.push(` Tool calls: ${n.totalToolCalls}`),e.push(` Files modified: ${n.totalFilesModified}`),e.push(` Lines written: ${n.totalLinesWritten.toLocaleString()}`),e.push(` Bugs fixed: ${n.totalBugsFixed}`),e.push(` Commits: ${n.totalCommits}`),e.push(""),e.push(` \u{1F525} Streak: ${n.streak} days (best: ${n.longestStreak})`),e.push("");let t=Object.entries(n.agentUsage).sort((r,i)=>i[1]-r[1]).slice(0,5);if(t.length>0){e.push(" Top Agents:");for(let[r,i]of t)e.push(` @${r}: ${i} uses`);e.push("")}let s=Object.entries(n.commandUsage).sort((r,i)=>i[1]-r[1]).slice(0,5);if(s.length>0){e.push(" Top Commands:");for(let[r,i]of s)e.push(` ${r}: ${i} calls`)}return e.join(`
|
|
36
|
-
`)}var kt,Hi,Wc,Ni,ji,Wn=L(()=>{"use strict";kt=O(require("fs")),Hi=O(require("path")),Wc=O(require("os")),Ni=Hi.join(Wc.homedir(),".hablas"),ji=Hi.join(Ni,"analytics.json")});var zc={};
|
|
36
|
+
`)}var kt,Hi,Wc,Ni,ji,Wn=L(()=>{"use strict";kt=O(require("fs")),Hi=O(require("path")),Wc=O(require("os")),Ni=Hi.join(Wc.homedir(),".hablas"),ji=Hi.join(Ni,"analytics.json")});var zc={};Fe(zc,{formatScanResults:()=>Gi,runSecurityScan:()=>Wi});function Ny(n,e){let t=[],s=e.split(`
|
|
37
37
|
`);for(let{pattern:r,name:i,severity:o}of Dy){r.lastIndex=0;let a;for(;(a=r.exec(e))!==null;){let u=e.substring(0,a.index).split(`
|
|
38
38
|
`).length,d=s[u-1]||"";d.trim().startsWith("#")||d.trim().startsWith("//")||n.includes(".example")||n.includes(".sample")||t.push({severity:o,type:"secret",file:n,line:u,message:`Potential ${i} detected`,suggestion:"Move to environment variable or use a secrets manager. Add to .gitignore if needed."})}}return t}function jy(n,e){let t=[],s=e.split(`
|
|
39
39
|
`),r=Yt.extname(n);return[".ts",".js",".tsx",".jsx"].includes(r)&&s.forEach((i,o)=>{/\beval\s*\(/.test(i)&&!i.trim().startsWith("//")&&t.push({severity:"high",type:"code",file:n,line:o+1,message:"Usage of eval() detected \u2014 potential code injection risk",suggestion:"Replace eval() with safer alternatives like JSON.parse() or Function constructor."}),/\.innerHTML\s*=/.test(i)&&t.push({severity:"medium",type:"code",file:n,line:o+1,message:"Direct innerHTML assignment \u2014 potential XSS vulnerability",suggestion:"Use textContent, or sanitize HTML with DOMPurify before assignment."}),/`.*\$\{.*\}.*(?:SELECT|INSERT|UPDATE|DELETE|DROP)/i.test(i)&&t.push({severity:"high",type:"code",file:n,line:o+1,message:"Potential SQL injection \u2014 string interpolation in SQL query",suggestion:"Use parameterized queries or an ORM instead of string interpolation."})}),t}function Vc(n,e=[]){try{let t=Bs.readdirSync(n,{withFileTypes:!0});for(let s of t){if(Ly.has(s.name))continue;let r=Yt.join(n,s.name);if(s.isDirectory())Vc(r,e);else if(s.isFile()){let i=Yt.extname(s.name);Fy.has(i)||e.push(r)}}}catch{}return e}function Wi(n){let e=Date.now(),t=Vc(n),s=[];for(let o of t)try{let a=Bs.readFileSync(o,"utf-8"),l=Yt.relative(n,o),u=Ny(l,a);s.push(...u);let d=jy(l,a);s.push(...d)}catch{}let r=Date.now()-e,i={critical:s.filter(o=>o.severity==="critical").length,high:s.filter(o=>o.severity==="high").length,medium:s.filter(o=>o.severity==="medium").length,low:s.filter(o=>o.severity==="low").length,info:s.filter(o=>o.severity==="info").length};return{issues:s,scannedFiles:t.length,duration:r,summary:i}}function Gi(n){let e=[];if(e.push(`
|
|
40
40
|
Security Scan Complete`),e.push(" \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"),e.push(` Files scanned: ${n.scannedFiles}`),e.push(` Duration: ${n.duration}ms`),e.push(""),n.issues.length===0)e.push(" \u2713 No security issues found!");else{e.push(` Issues found: ${n.issues.length}`),e.push(` Critical: ${n.summary.critical}`),e.push(` High: ${n.summary.high}`),e.push(` Medium: ${n.summary.medium}`),e.push(` Low: ${n.summary.low}`),e.push("");let t=n.issues.sort((s,r)=>{let i={critical:0,high:1,medium:2,low:3,info:4};return i[s.severity]-i[r.severity]}).slice(0,10);for(let s of t){let r=s.severity==="critical"?"\u{1F534}":s.severity==="high"?"\u{1F7E0}":s.severity==="medium"?"\u{1F7E1}":"\u{1F535}";e.push(` ${r} [${s.severity.toUpperCase()}] ${s.message}`),e.push(` File: ${s.file}${s.line?`:${s.line}`:""}`),e.push(` Fix: ${s.suggestion}`),e.push("")}}return e.join(`
|
|
41
|
-
`)}var Bs,Yt,Dy,Ly,Fy,Vi=L(()=>{"use strict";Bs=O(require("fs")),Yt=O(require("path")),Dy=[{pattern:/(?:api[_-]?key|apikey)\s*[:=]\s*['"][a-zA-Z0-9_\-]{20,}['"]/gi,name:"API Key",severity:"critical"},{pattern:/(?:secret|password|passwd|pwd)\s*[:=]\s*['"][^'"]{8,}['"]/gi,name:"Secret/Password",severity:"critical"},{pattern:/(?:aws_access_key_id)\s*[:=]\s*['"]?AKIA[A-Z0-9]{16}['"]?/gi,name:"AWS Access Key",severity:"critical"},{pattern:/(?:aws_secret_access_key)\s*[:=]\s*['"]?[A-Za-z0-9/+=]{40}['"]?/gi,name:"AWS Secret Key",severity:"critical"},{pattern:/ghp_[A-Za-z0-9]{36}/g,name:"GitHub Token",severity:"critical"},{pattern:/gho_[A-Za-z0-9]{36}/g,name:"GitHub OAuth Token",severity:"critical"},{pattern:/sk-[A-Za-z0-9]{48}/g,name:"OpenAI API Key",severity:"critical"},{pattern:/xox[baprs]-[A-Za-z0-9\-]{10,}/g,name:"Slack Token",severity:"high"},{pattern:/-----BEGIN (?:RSA |EC )?PRIVATE KEY-----/g,name:"Private Key",severity:"critical"},{pattern:/(?:mongodb(?:\+srv)?:\/\/)[^\s'"]+/g,name:"MongoDB Connection String",severity:"high"},{pattern:/(?:postgres|postgresql|mysql):\/\/[^\s'"]+/g,name:"Database URL",severity:"high"},{pattern:/(?:Bearer\s+)[A-Za-z0-9\-._~+/]+=*/g,name:"Bearer Token",severity:"medium"}],Ly=new Set(["node_modules",".git","dist","build",".next","__pycache__","venv",".venv","target","vendor",".cache"]),Fy=new Set([".png",".jpg",".jpeg",".gif",".svg",".ico",".woff",".woff2",".ttf",".eot",".mp4",".mp3",".zip",".tar",".gz",".lock"])});var Gn={};
|
|
41
|
+
`)}var Bs,Yt,Dy,Ly,Fy,Vi=L(()=>{"use strict";Bs=O(require("fs")),Yt=O(require("path")),Dy=[{pattern:/(?:api[_-]?key|apikey)\s*[:=]\s*['"][a-zA-Z0-9_\-]{20,}['"]/gi,name:"API Key",severity:"critical"},{pattern:/(?:secret|password|passwd|pwd)\s*[:=]\s*['"][^'"]{8,}['"]/gi,name:"Secret/Password",severity:"critical"},{pattern:/(?:aws_access_key_id)\s*[:=]\s*['"]?AKIA[A-Z0-9]{16}['"]?/gi,name:"AWS Access Key",severity:"critical"},{pattern:/(?:aws_secret_access_key)\s*[:=]\s*['"]?[A-Za-z0-9/+=]{40}['"]?/gi,name:"AWS Secret Key",severity:"critical"},{pattern:/ghp_[A-Za-z0-9]{36}/g,name:"GitHub Token",severity:"critical"},{pattern:/gho_[A-Za-z0-9]{36}/g,name:"GitHub OAuth Token",severity:"critical"},{pattern:/sk-[A-Za-z0-9]{48}/g,name:"OpenAI API Key",severity:"critical"},{pattern:/xox[baprs]-[A-Za-z0-9\-]{10,}/g,name:"Slack Token",severity:"high"},{pattern:/-----BEGIN (?:RSA |EC )?PRIVATE KEY-----/g,name:"Private Key",severity:"critical"},{pattern:/(?:mongodb(?:\+srv)?:\/\/)[^\s'"]+/g,name:"MongoDB Connection String",severity:"high"},{pattern:/(?:postgres|postgresql|mysql):\/\/[^\s'"]+/g,name:"Database URL",severity:"high"},{pattern:/(?:Bearer\s+)[A-Za-z0-9\-._~+/]+=*/g,name:"Bearer Token",severity:"medium"}],Ly=new Set(["node_modules",".git","dist","build",".next","__pycache__","venv",".venv","target","vendor",".cache"]),Fy=new Set([".png",".jpg",".jpeg",".gif",".svg",".ico",".woff",".woff2",".ttf",".eot",".mp4",".mp3",".zip",".tar",".gz",".lock"])});var Gn={};Fe(Gn,{formatGitStatus:()=>Gy,generateChangelogPrompt:()=>Wy,generateCommitPrompt:()=>qy,generatePRPrompt:()=>Ky,getDetailedDiff:()=>By,getGitStatus:()=>zi,getRecentCommits:()=>Uy,getStagedDiff:()=>Hy});async function zi(n){try{let{stdout:e}=await bn("git branch --show-current",{cwd:n}),{stdout:t}=await bn("git status --porcelain",{cwd:n}),s=e.trim(),r=[],i=[],o=[];for(let u of t.split(`
|
|
42
42
|
`).filter(Boolean)){let d=u.substring(0,2),f=u.substring(3);(d.startsWith("A")||d.startsWith("M")||d.startsWith("R"))&&d[0]!==" "&&r.push(f),(d[1]==="M"||d[1]==="D")&&i.push(f),d==="??"&&o.push(f)}let a=0,l=0;try{let{stdout:u}=await bn("git rev-list --left-right --count HEAD...@{upstream}",{cwd:n}),d=u.trim().split(" ");a=parseInt(d[0])||0,l=parseInt(d[1])||0}catch{}return{branch:s,staged:r,modified:i,untracked:o,ahead:a,behind:l}}catch{return null}}async function Hy(n){try{let{stdout:e}=await bn("git diff --cached --stat",{cwd:n});return e.trim()}catch{return""}}async function By(n){try{let{stdout:e}=await bn("git diff --cached",{cwd:n,maxBuffer:1048576});return e.length>1e4?e.substring(0,1e4)+`
|
|
43
43
|
... (truncated)`:e.trim()}catch{return""}}async function Uy(n,e=20){try{let{stdout:t}=await bn(`git log --oneline --format="%H|%s|%an|%ai" -n ${e}`,{cwd:n});return t.trim().split(`
|
|
44
44
|
`).filter(Boolean).map(s=>{let[r,i,o,a]=s.split("|");return{hash:r,message:i,author:o,date:a,files:[]}})}catch{return[]}}function qy(n,e){return`Based on the following git diff, generate a concise, conventional commit message.
|
|
@@ -99,8 +99,8 @@ Format:
|
|
|
99
99
|
- (removed features)
|
|
100
100
|
|
|
101
101
|
Only include sections that have entries. Generate ONLY the changelog markdown.`}function Gy(n){let e=[];return e.push(` Branch: ${n.branch}`),(n.ahead>0||n.behind>0)&&e.push(` Sync: \u2191${n.ahead} \u2193${n.behind}`),n.staged.length>0&&e.push(` Staged: ${n.staged.length} file(s)`),n.modified.length>0&&e.push(` Modified: ${n.modified.length} file(s)`),n.untracked.length>0&&e.push(` Untracked: ${n.untracked.length} file(s)`),e.join(`
|
|
102
|
-
`)}var Yc,Jc,bn,vn=L(()=>{"use strict";Yc=require("child_process"),Jc=require("util"),bn=(0,Jc.promisify)(Yc.exec)});var tu={};
|
|
103
|
-
`)}var J,
|
|
102
|
+
`)}var Yc,Jc,bn,vn=L(()=>{"use strict";Yc=require("child_process"),Jc=require("util"),bn=(0,Jc.promisify)(Yc.exec)});var tu={};Fe(tu,{detectFramework:()=>Xc,detectLanguage:()=>Zc,detectPackageManager:()=>Qc,formatWorkspaceInfo:()=>Yi,getGitBranch:()=>eu,scanWorkspace:()=>Us});function Xc(n){let e=Z.join(n,"package.json");if(J.existsSync(e))try{let t=JSON.parse(J.readFileSync(e,"utf-8")),s={...t.dependencies,...t.devDependencies};if(s.next)return"next";if(s.nuxt)return"nuxt";if(s["@angular/core"])return"angular";if(s.svelte||s["@sveltejs/kit"])return"svelte";if(s.vue)return"vue";if(s.react)return"react";if(s["@nestjs/core"])return"nest";if(s.fastify)return"fastify";if(s.express)return"express"}catch{}if(J.existsSync(Z.join(n,"requirements.txt"))||J.existsSync(Z.join(n,"pyproject.toml")))try{let t=J.existsSync(Z.join(n,"requirements.txt"))?J.readFileSync(Z.join(n,"requirements.txt"),"utf-8"):"";if(t.includes("django"))return"django";if(t.includes("flask"))return"flask";if(t.includes("fastapi"))return"fastapi"}catch{}if(J.existsSync(Z.join(n,"Cargo.toml")))try{if(J.readFileSync(Z.join(n,"Cargo.toml"),"utf-8").includes("actix"))return"rust-actix"}catch{}if(J.existsSync(Z.join(n,"go.mod")))try{if(J.readFileSync(Z.join(n,"go.mod"),"utf-8").includes("fiber"))return"go-fiber"}catch{}return"unknown"}function Qc(n){return J.existsSync(Z.join(n,"pnpm-lock.yaml"))?"pnpm":J.existsSync(Z.join(n,"yarn.lock"))?"yarn":J.existsSync(Z.join(n,"bun.lockb"))?"bun":J.existsSync(Z.join(n,"package-lock.json"))?"npm":J.existsSync(Z.join(n,"Cargo.toml"))?"cargo":J.existsSync(Z.join(n,"go.mod"))?"go":J.existsSync(Z.join(n,"requirements.txt"))||J.existsSync(Z.join(n,"pyproject.toml"))?"pip":"unknown"}function Zc(n){return J.existsSync(Z.join(n,"tsconfig.json"))?"TypeScript":J.existsSync(Z.join(n,"package.json"))?"JavaScript":J.existsSync(Z.join(n,"Cargo.toml"))?"Rust":J.existsSync(Z.join(n,"go.mod"))?"Go":J.existsSync(Z.join(n,"pyproject.toml"))||J.existsSync(Z.join(n,"requirements.txt"))?"Python":"Unknown"}function eu(n){let e=Z.join(n,".git","HEAD");if(!J.existsSync(e))return null;try{let t=J.readFileSync(e,"utf-8").trim();return t.startsWith("ref: refs/heads/")?t.replace("ref: refs/heads/",""):t.substring(0,8)}catch{return null}}function Us(n){let e=Xc(n),t=Qc(n),s=Zc(n),r=eu(n),i=J.existsSync(Z.join(n,"Dockerfile"))||J.existsSync(Z.join(n,"docker-compose.yml"))||J.existsSync(Z.join(n,"docker-compose.yaml")),o=J.existsSync(Z.join(n,".github","workflows"))||J.existsSync(Z.join(n,".gitlab-ci.yml"))||J.existsSync(Z.join(n,"Jenkinsfile")),a=J.existsSync(Z.join(n,"__tests__"))||J.existsSync(Z.join(n,"tests"))||J.existsSync(Z.join(n,"test"))||J.existsSync(Z.join(n,"spec")),l=J.existsSync(Z.join(n,".git")),u=[],d=[".env",".env.local",".env.development",".env.production",".env.example"];for(let g of d)J.existsSync(Z.join(n,g))&&u.push(g);let f=[],h=["package.json","tsconfig.json","vite.config.ts","next.config.js","next.config.mjs","webpack.config.js","tailwind.config.ts","tailwind.config.js","eslint.config.js",".eslintrc.js",".prettierrc","Dockerfile","docker-compose.yml","Makefile"];for(let g of h)J.existsSync(Z.join(n,g))&&f.push(g);let m=[],p=["src/index.ts","src/index.js","src/main.ts","src/main.js","src/app.ts","src/app.js","index.ts","index.js","main.py","app.py","manage.py","main.go","src/main.rs"];for(let g of p)J.existsSync(Z.join(n,g))&&m.push(g);return{rootPath:n,framework:e,packageManager:t,language:s,hasDocker:i,hasCICD:o,hasTests:a,hasGit:l,gitBranch:r,envFiles:u,configFiles:f,entryPoints:m}}function Yi(n){let e=[` Project: ${Z.basename(n.rootPath)}`,` Framework: ${n.framework}`,` Language: ${n.language}`,` Package: ${n.packageManager}`,` Git: ${n.hasGit?`\u2713 (${n.gitBranch||"detached"})`:"\u2717"}`,` Docker: ${n.hasDocker?"\u2713":"\u2717"}`,` CI/CD: ${n.hasCICD?"\u2713":"\u2717"}`,` Tests: ${n.hasTests?"\u2713":"\u2717"}`];return n.envFiles.length>0&&e.push(` Env files: ${n.envFiles.join(", ")}`),e.join(`
|
|
103
|
+
`)}var J,Z,Ji=L(()=>{"use strict";J=O(require("fs")),Z=O(require("path"))});function nu(){return`
|
|
104
104
|
## Available Tools (XML Format)
|
|
105
105
|
|
|
106
106
|
You can use tools by outputting XML tags in your response. The system will parse and execute them.
|
|
@@ -155,23 +155,23 @@ export function hello() {
|
|
|
155
155
|
3. Wait for tool results before using dependent tools.
|
|
156
156
|
4. Use exact file paths relative to the working directory.
|
|
157
157
|
5. Do NOT wrap tool tags in <tool_call > tags \u2014 use them directly.
|
|
158
|
-
`.trim()}var su=L(()=>{"use strict"});function Vy(){try{let n=ou.resolve(__dirname,"..","..","package.json");return JSON.parse(iu.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function me(n,e){return lu||!wn?n:`${e}${n}\x1B[0m`}function zy(n){let e=
|
|
158
|
+
`.trim()}var su=L(()=>{"use strict"});function Vy(){try{let n=ou.resolve(__dirname,"..","..","package.json");return JSON.parse(iu.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function me(n,e){return lu||!wn?n:`${e}${n}\x1B[0m`}function zy(n){let e=He();if(!n)return c.border("\u2500".repeat(e));let t=n.replace(/\x1b\[[0-9;]*m/g,""),s=Math.max(0,e-t.length-2),r=Math.floor(s/2),i=s-r;return c.border("\u2500".repeat(r))+" "+n+" "+c.border("\u2500".repeat(i))}function Yy(n,e=2){let t=He()-e;if(t<=0)return" ".repeat(e)+n;let s=n.split(" "),r=[],i="";for(let o of s)(i+" "+o).trim().length>t&&i?(r.push(i.trim()),i=o):i+=(i?" ":"")+o;return i&&r.push(i.trim()),r.map(o=>" ".repeat(e)+o).join(`
|
|
159
159
|
`)}function Jy(n){let e=Math.max(...n.map(([t])=>t.length));return n.map(([t,s])=>` ${c.muted(t.padEnd(e))} ${s}`).join(`
|
|
160
|
-
`)}function Xy(n){if(lu||!wn)return n;let e=["\x1B[38;5;111m","\x1B[38;5;111m","\x1B[38;5;141m","\x1B[38;5;141m","\x1B[38;5;117m","\x1B[38;5;117m"],t="";for(let s=0;s<n.length;s++){let r=Math.floor(s/n.length*e.length);t+=e[r]+n[s]}return t+"\x1B[0m"}function uu(n,e){let t=
|
|
161
|
-
`)}function du(){let n=
|
|
160
|
+
`)}function Xy(n){if(lu||!wn)return n;let e=["\x1B[38;5;111m","\x1B[38;5;111m","\x1B[38;5;141m","\x1B[38;5;141m","\x1B[38;5;117m","\x1B[38;5;117m"],t="";for(let s=0;s<n.length;s++){let r=Math.floor(s/n.length*e.length);t+=e[r]+n[s]}return t+"\x1B[0m"}function uu(n,e){let t=He(),s=e?e.replace(Zi.homedir(),"~"):"",r=c.border("\u2554"+"\u2550".repeat(t-2)+"\u2557"),i=c.border("\u2560"+"\u2550".repeat(t-2)+"\u2563"),o=c.border("\u255A"+"\u2550".repeat(t-2)+"\u255D"),a="H A B L A S A I",l="EXECUTIVE SYSTEM COORDINATOR",u="developed by abdulmoin hablas",d=Math.max(0,Math.floor((t-2-a.length)/2)),f=c.border("\u2551")+" ".repeat(d)+c.strong(a)+" ".repeat(t-2-a.length-d)+c.border("\u2551"),h=Math.max(0,Math.floor((t-2-l.length)/2)),m=c.border("\u2551")+" ".repeat(h)+c.secondary(l)+" ".repeat(t-2-l.length-h)+c.border("\u2551"),p=Math.max(0,Math.floor((t-2-u.length)/2)),g=c.border("\u2551")+" ".repeat(p)+c.muted(u)+" ".repeat(t-2-u.length-p)+c.border("\u2551"),w=c.muted(`SYSTEM VERSION: v${au}`),_=c.warning(`CORE MODEL: ${n}`);return["",r,f,m,u?g:"",i,` ${c.muted("\u25B8")} ${w}`,` ${c.muted("\u25B8")} ${_}`,s?` ${c.muted("\u25B8")} ${c.muted(`WORKSPACE: ${s}`)}`:"",` ${c.chrome("\u251C"+"\u2500".repeat(t-2)+"\u2524")}`,` ${c.muted(" \u203A")} ${c.secondary("Type naturally to get started")}`,` ${c.muted(" \u203A")} ${c.secondary("/help for commands \xB7 Ctrl+C to cancel \xB7 Ctrl+C\xD72 to exit")}`,o,""].filter(Boolean).join(`
|
|
161
|
+
`)}function du(){let n=He();return[` ${c.border("\u2554"+"\u2550".repeat(n-4)+"\u2557")}`,` ${c.border("\u2551")} ${c.leader("\u2605 Hablas")} ${c.muted("Leader")} ${c.border("\u2551")} ${c.product("\u25C6 Emma")} ${c.muted("Product")} ${c.border("\u2551")} ${c.architect("\u25C6 Bob")} ${c.muted("Architect")} ${c.border("\u2551")} ${c.engineer("\u25C6 Alex")} ${c.muted("Engineer")} ${c.border("\u2551")} ${c.analyst("\u25C6 David")} ${c.muted("Analyst")} ${c.border("\u2551")}`,` ${c.border("\u255A"+"\u2550".repeat(n-4)+"\u255D")}`].join(`
|
|
162
162
|
`)}function Jt(n,e){return`
|
|
163
163
|
${(n==="Hablas"?c.leader:n==="Bob"?c.architect:n==="Alex"?c.engineer:n==="David"?c.analyst:n==="Emma"?c.product:c.primary)("\u25C6")} ${c.strong(n)} ${c.muted(`[${e.toUpperCase()}]`)}`}function fu(n,e,t,s){let r=n==="Hablas"?c.leader:n==="Bob"?c.architect:n==="Alex"?c.engineer:n==="David"?c.analyst:n==="Emma"?c.product:c.primary,i=e==="Hablas"?c.leader:e==="Bob"?c.architect:e==="Alex"?c.engineer:e==="David"?c.analyst:e==="Emma"?c.product:c.primary,o=[];if(o.push(""),o.push(` ${r("\u2605")} ${r(n)} ${c.muted("\u2192")} ${c.strong("Delegating to")} ${i(`@${e}`)} ${c.muted(`(${t})`)}`),s){let a=s.length>80?s.slice(0,80)+"...":s;o.push(` ${c.muted(" \u2517")} ${c.secondary(a)}`)}return o.push(""),o.join(`
|
|
164
|
-
`)}function pu(){let n=
|
|
165
|
-
`)}function hu(){let n=
|
|
164
|
+
`)}function pu(){let n=He(),t=[` ${c.accent("\u2726")} ${c.strong("Welcome to hablas")}`,"",` ${c.muted("Try:")} ${c.highlight('"read package.json and list deps"')}`,` ${c.muted("Or:")} ${c.highlight('"create a new component for user auth"')}`,"",` ${c.primary("/tree")} ${c.muted("\u2014 see project structure")}`,` ${c.primary("/model")} ${c.muted("\u2014 switch AI model")}`,` ${c.primary("/models")} ${c.muted("\u2014 browse all available models")}`,` ${c.primary("/team")} ${c.muted("\u2014 see your agent team")}`,` ${c.primary("/about")} ${c.muted("\u2014 developer info")}`,"",` ${c.muted("All file changes are backed up automatically.")}`].map(s=>{let r=s.replace(/\x1b\[[0-9;]*m/g,""),i=Math.max(0,n-8-r.length);return` ${c.border("\u2502")} ${s}${" ".repeat(i)} ${c.border("\u2502")}`});return["",` ${c.border("\u250C"+"\u2500".repeat(n-6)+"\u2510")}`,...t,` ${c.border("\u2514"+"\u2500".repeat(n-6)+"\u2518")}`,""].join(`
|
|
165
|
+
`)}function hu(){let n=He();return["",c.chrome("\u256D"+"\u2500".repeat(n-2)+"\u256E"),` ${c.strong("Abdulmoin Hablas")} ${c.muted("\u2014 Full-Stack Developer")}`,c.chrome("\u251C"+"\u2500".repeat(n-2)+"\u2524"),"",` ${c.accent("\u25C6")} ${c.primary("Portfolio")} ${c.muted("https://portfolio-monopoly63s-projects.vercel.app/")}`,` ${c.accent("\u25C6")} ${c.primary("GitHub")} ${c.muted("https://github.com/Monopoly63?tab=repositories")}`,` ${c.accent("\u25C6")} ${c.primary("Telegram")} ${c.muted("https://t.me/Hablas_Trade")}`,` ${c.accent("\u25C6")} ${c.primary("WhatsApp")} ${c.muted("https://wa.me/13232128875")}`,` ${c.accent("\u25C6")} ${c.primary("Instagram")} ${c.muted("https://www.instagram.com/li0vy_")}`,"",c.chrome("\u251C"+"\u2500".repeat(n-2)+"\u2524"),` ${c.strong("Projects")}`,"",` ${c.muted("\u25B8")} AI Search Engine ${c.muted("\u2192")} ${c.highlight("https://ai-search-engine-ashy.vercel.app/")}`,` ${c.muted("\u25B8")} Trade Tracker ${c.muted("\u2192")} ${c.highlight("https://trade-tracker-monopoly63s-projects.vercel.app/")}`,` ${c.muted("\u25B8")} Tree Algo Lab ${c.muted("\u2192")} ${c.highlight("https://tree-algorithms-lab.vercel.app/")}`,"",c.chrome("\u2570"+"\u2500".repeat(n-2)+"\u256F"),""].join(`
|
|
166
166
|
`)}function mu(){return["",` ${Xy("\u25C6 hablas")} ${c.success(`v${au}`)}`,"",` ${c.muted("Runtime")} ${c.secondary(`Node.js ${process.version}`)}`,` ${c.muted("Platform")} ${c.secondary(`${process.platform} ${process.arch}`)}`,` ${c.muted("Author")} ${c.secondary("Abdulmoin Hablas")}`,` ${c.muted("License")} ${c.secondary("MIT")}`,""].join(`
|
|
167
|
-
`)}function ru(n,e){let t=Math.min(
|
|
167
|
+
`)}function ru(n,e){let t=Math.min(He()-8,60),s=e?` ${c.accent(e)} `:"",r=`${c.error("\u25CF")} ${c.warning("\u25CF")} ${c.success("\u25CF")}`,i=` ${c.chrome("\u250C"+"\u2500".repeat(4))} ${r} ${c.chrome("\u2500".repeat(Math.max(0,t-10-(e?e.length+2:0))))}${s}`,o=String(n.length).length,a=n.map((u,d)=>{let f=c.lineNum(String(d+1).padStart(o)+" \u2502 "),h=c.codeBlock(u);return` ${c.chrome("\u2502")} ${f}${h}`}),l=` ${c.chrome("\u2514"+"\u2500".repeat(t))}`;return[i,...a,l]}function Xt(n){let e=n.split(`
|
|
168
168
|
`),t=[],s=!1,r="",i=[];for(let o of e){if(o.trimStart().startsWith("```")){s?(t.push(...ru(i,r)),s=!1,i=[]):(s=!0,r=o.trimStart().slice(3).trim(),i=[]);continue}if(s){i.push(o);continue}if(/^#{1,3}\s/.test(o)){let l=o.replace(/^#+\s/,"");t.push(""),t.push(` ${c.strong(c.primary(l))}`);continue}if(/^[-*]\s/.test(o.trim())){let l=o.trim().slice(2),u=Xi(l);t.push(` ${c.accent("\u25B8")} ${u}`);continue}if(/^\d+\.\s/.test(o.trim())){let l=o.trim().match(/^(\d+)\.\s(.+)/);if(l){t.push(` ${c.muted(l[1]+".")} ${Xi(l[2])}`);continue}}if(!o.trim()){t.push("");continue}let a=Yy(Xi(o),2);t.push(...a.split(`
|
|
169
169
|
`))}return s&&i.length>0&&t.push(...ru(i,r)),`
|
|
170
170
|
`+t.join(`
|
|
171
171
|
`)+`
|
|
172
|
-
`}function Xi(n){let e=n.replace(/`([^`]+)`/g,(t,s)=>c.highlight(s));return e=e.replace(/\*\*([^*]+)\*\*/g,(t,s)=>c.strong(c.primary(s))),e=e.replace(/\*([^*]+)\*/g,(t,s)=>`\x1B[3m${s}\x1B[23m`),e}function gu(n,e){let t=
|
|
172
|
+
`}function Xi(n){let e=n.replace(/`([^`]+)`/g,(t,s)=>c.highlight(s));return e=e.replace(/\*\*([^*]+)\*\*/g,(t,s)=>c.strong(c.primary(s))),e=e.replace(/\*([^*]+)\*/g,(t,s)=>`\x1B[3m${s}\x1B[23m`),e}function gu(n,e){let t=He(),s=` [TOOL: ${n.replace(/_/g," ").toUpperCase()}] `,r=` ${c.border("\u250C\u2500\u2500")}${c.accent(s)}${c.border("\u2500".repeat(Math.max(0,t-s.length-6)))}`,i=` ${c.border("\u2502")} ${c.secondary(e)}`,o=i.replace(/\x1b\[[0-9;]*m/g,""),a=Math.max(0,t-8-o.length);return`
|
|
173
173
|
${r}
|
|
174
|
-
${i}${" ".repeat(a)} ${c.border("\u2502")}`}function yu(n,e,t){let s=
|
|
174
|
+
${i}${" ".repeat(a)} ${c.border("\u2502")}`}function yu(n,e,t){let s=He(),r=c.muted(`${t}ms`),i="";if(n){let u=e.split(`
|
|
175
175
|
`).filter(Boolean),d=u.length;if(d>5){let f=u[0].slice(0,s-30).trim();i=` ${c.border("\u2502")} ${c.success("\u2713")} ${c.muted(`${d} lines`)} ${c.secondary(f+"\u2026")} ${r}`}else{let f=u.join(" \xB7 ").slice(0,s-24);i=` ${c.border("\u2502")} ${c.success("\u2713")} ${c.muted(f)} ${r}`}}else{let u=e.split(`
|
|
176
176
|
`)[0].slice(0,s-24);i=` ${c.border("\u2502")} ${c.error("\u2717")} ${c.error(u)} ${r}`}let o=i.replace(/\x1b\[[0-9;]*m/g,""),a=Math.max(0,s-8-o.length),l=` ${c.border("\u2514"+"\u2500".repeat(s-6)+"\u2518")}`;return`${i}${" ".repeat(a)} ${c.border("\u2502")}
|
|
177
177
|
${l}
|
|
@@ -179,15 +179,15 @@ ${l}
|
|
|
179
179
|
`),t=[];for(let s of e)s.startsWith("+++")||s.startsWith("---")?t.push(` ${c.muted(s)}`):s.startsWith("+")?t.push(` ${c.added(s)}`):s.startsWith("-")?t.push(` ${c.removed(s)}`):s.startsWith("@@")?t.push(` ${c.hunk(s)}`):s.trim()&&t.push(` ${c.muted(s)}`);return t.join(`
|
|
180
180
|
`)}function bu(n){let e=new Date().toLocaleTimeString("en",{hour:"2-digit",minute:"2-digit"}),t=`${c.accent("\u25C6")} ${c.strong(c.primary(`Turn #${n}`))} ${c.muted(`\xB7 ${e} \xB7`)}`;return`
|
|
181
181
|
`+zy(t)+`
|
|
182
|
-
`}function
|
|
183
|
-
${c.warning("\u2192")} ${c.muted(e)}`}function
|
|
182
|
+
`}function $e(n){return` ${c.error("\u2717")} ${n}`}function Be(n,e){return` ${c.error("\u2717")} ${n}
|
|
183
|
+
${c.warning("\u2192")} ${c.muted(e)}`}function X(n){return` ${c.success("\u2713")} ${n}`}function le(n){return` ${c.muted(n)}`}function j(n){return` ${c.warning("\u26A0")} ${n}`}function Qy(n,e){let s=Math.round(Math.min(n,e)/Math.max(e,1)*16),r=e>0?n/e:0;return(r>.85?c.error:r>.6?c.warning:c.success)("\u2588".repeat(s))+c.muted("\u2591".repeat(16-s))}function vu(n){let e=He(),t=n.connected?c.success("\u25CF connected"):c.error("\u25CB offline"),s=Qy(n.cacheTokens,n.budgetTokens),r=[["model",c.highlight(n.model)],["mindset",c.accent(n.mindset||"coder")],["host",c.muted(n.host)],["directory",c.muted(n.directory.replace(Zi.homedir(),"~"))],["context",`${s} ${c.muted(`${n.cacheFiles} files \xB7 ${n.cacheTokens}/${n.budgetTokens} tokens`)}`],["turns",c.muted(String(n.turnCount))],["status",t]];return`
|
|
184
184
|
`+c.chrome("\u256D"+"\u2500".repeat(e-2)+"\u256E")+`
|
|
185
185
|
${c.accent("\u2726")} ${c.strong("Status")}
|
|
186
186
|
|
|
187
187
|
`+Jy(r)+`
|
|
188
188
|
|
|
189
189
|
`+c.chrome("\u2570"+"\u2500".repeat(e-2)+"\u256F")+`
|
|
190
|
-
`}function wu(){let n=
|
|
190
|
+
`}function wu(){let n=He(),e=Math.max(...Qi.map(r=>r.cmd.length+(r.arg?r.arg.length+1:0))),t=Qi.map(({cmd:r,arg:i,desc:o})=>{let a=r.length+(i?i.length+1:0),l=" ".repeat(e-a+3);return` ${c.primary(r)}${i?" "+c.muted(i):""}${l}${c.secondary(o)}`}),s=["",` ${c.accent("\u2726")} ${c.strong("Tips")}`,"",` ${c.muted("\u25B8")} Use ${c.highlight("#filename")} to reference files inline`,` ${c.muted("\u25B8")} Press ${c.highlight("Ctrl+C")} once to cancel current operation`,` ${c.muted("\u25B8")} Press ${c.highlight("Ctrl+C\xD72")} quickly to exit CLI`,` ${c.muted("\u25B8")} Use ${c.highlight("--auto")} flag to skip tool confirmations`,` ${c.muted("\u25B8")} All file edits are backed up to ${c.muted("~/.hablas/backup/")}`,` ${c.muted("\u25B8")} Complex tasks \u2192 Hablas creates a plan \u2192 approve/edit \u2192 execute`];return`
|
|
191
191
|
`+c.chrome("\u256D"+"\u2500".repeat(n-2)+"\u256E")+`
|
|
192
192
|
${c.accent("\u2726")} ${c.strong("Commands")}
|
|
193
193
|
|
|
@@ -198,9 +198,9 @@ ${l}
|
|
|
198
198
|
|
|
199
199
|
`+c.chrome("\u2570"+"\u2500".repeat(n-2)+"\u256F")+`
|
|
200
200
|
`}function to(n){let e=Math.floor(n.duration/6e4),t=Math.floor(n.duration%6e4/1e3),s=e>0?`${e}m ${t}s`:`${t}s`;return["",c.chrome("\u256D"+"\u2500".repeat(40)+"\u256E"),` ${c.accent("\u2726")} ${c.strong("Session Summary")}`,"",` ${c.muted("Turns")} ${c.secondary(String(n.turns))}`,` ${c.muted("Duration")} ${c.secondary(s)}`,` ${c.muted("Tool calls")} ${c.secondary(String(n.toolCalls))}`,"",c.chrome("\u2570"+"\u2500".repeat(40)+"\u256F"),"",` ${c.muted("Goodbye \u2014 hablas by Abdulmoin Hablas")}`,""].join(`
|
|
201
|
-
`)}function Vn(n,e){let t=
|
|
202
|
-
`)}function xu(n){let e=
|
|
203
|
-
`)}var Zi,iu,ou,au,wn,lu,cu,
|
|
201
|
+
`)}function Vn(n,e){let t=He(),s=[];s.push(""),s.push(` ${c.chrome("\u256D"+"\u2500".repeat(t-4)+"\u256E")}`),s.push(` ${c.chrome("\u2502")} ${c.leader("\u2605")} ${c.strong("Hablas")} ${c.muted("\u2014 Execution Plan")}${" ".repeat(Math.max(0,t-35))}${c.chrome("\u2502")}`);let r=20,i=Math.round(e.percent/100*r),o=r-i,a=c.success("\u2588".repeat(i))+c.muted("\u2591".repeat(o));s.push(` ${c.chrome("\u2502")} ${a} ${c.muted(`${e.percent}%`)} ${c.muted(`(${e.done}/${e.total} tasks)`)}`),s.push(` ${c.chrome("\u251C"+"\u2500".repeat(t-4)+"\u2524")}`);for(let l=0;l<n.tasks.length;l++){let u=n.tasks[l],d=eb[u.status](Zy[u.status]),h=(u.assignee==="hablas"?c.leader:u.assignee==="bob"?c.architect:u.assignee==="alex"?c.engineer:u.assignee==="david"?c.analyst:u.assignee==="emma"?c.product:c.muted)(`@${u.assigneeName}`),m="";u.dependent_task_ids.length>0&&(m=c.muted(` \u2190 [${u.dependent_task_ids.join(", ")}]`));let p=c.secondary(u.description);s.push(` ${c.chrome("\u2502")} ${d} ${c.muted(`${u.task_id}.`)} ${h} ${c.muted("\u2192")} ${p}${m}`)}return s.push(` ${c.chrome("\u251C"+"\u2500".repeat(t-4)+"\u2524")}`),s.push(` ${c.chrome("\u2502")} ${c.muted("Strategy:")} ${c.highlight(n.strategy)} ${c.muted("\xB7")} ${c.muted(`${n.tasks.length} tasks`)}`),s.push(` ${c.chrome("\u2570"+"\u2500".repeat(t-4)+"\u256F")}`),s.push(""),s.join(`
|
|
202
|
+
`)}function xu(n){let e=He(),t=[];t.push(""),t.push(` ${c.chrome("\u256D"+"\u2500".repeat(e-4)+"\u256E")}`),t.push(` ${c.chrome("\u2502")} ${c.warning("?")} ${c.strong("Clarification Needed")}`),t.push(` ${c.chrome("\u251C"+"\u2500".repeat(e-4)+"\u2524")}`),t.push(` ${c.chrome("\u2502")} ${c.secondary(n.question)}`),t.push(` ${c.chrome("\u2502")}`);for(let s of n.choices)t.push(` ${c.chrome("\u2502")} ${c.accent(s.label+")")} ${c.secondary(s.value)}`);return n.context&&(t.push(` ${c.chrome("\u2502")}`),t.push(` ${c.chrome("\u2502")} ${c.muted(`Context: "${n.context.slice(0,60)}${n.context.length>60?"...":""}"`)}`)),t.push(` ${c.chrome("\u2570"+"\u2500".repeat(e-4)+"\u256F")}`),t.push(""),t.join(`
|
|
203
|
+
`)}var Zi,iu,ou,au,wn,lu,cu,He,c,Ve,Qi,Zy,eb,no,xn=L(()=>{"use strict";Zi=O(require("os")),iu=O(require("fs")),ou=O(require("path"));au=Vy(),wn=process.stdout.isTTY===!0,lu=process.env.NO_COLOR!==void 0||process.env.TERM==="dumb",cu=process.stdout.columns||80;wn&&process.stdout.on("resize",()=>{cu=process.stdout.columns||80});He=()=>Math.min(cu-4,100);c={primary:n=>me(n,"\x1B[38;5;253m"),secondary:n=>me(n,"\x1B[38;5;247m"),muted:n=>me(n,"\x1B[38;5;242m"),strong:n=>me(n,"\x1B[1;38;5;255m"),accent:n=>me(n,"\x1B[38;5;145m"),highlight:n=>me(n,"\x1B[38;5;231m"),success:n=>me(n,"\x1B[38;5;108m"),error:n=>me(n,"\x1B[38;5;167m"),warning:n=>me(n,"\x1B[38;5;179m"),info:n=>me(n,"\x1B[38;5;110m"),codeBlock:n=>me(n,"\x1B[38;5;188m"),lineNum:n=>me(n,"\x1B[38;5;239m"),border:n=>me(n,"\x1B[38;5;237m"),chrome:n=>me(n,"\x1B[38;5;235m"),added:n=>me(n,"\x1B[38;5;108m"),removed:n=>me(n,"\x1B[38;5;167m"),hunk:n=>me(n,"\x1B[38;5;145m"),leader:n=>me(n,"\x1B[38;5;179m"),architect:n=>me(n,"\x1B[38;5;250m"),engineer:n=>me(n,"\x1B[38;5;145m"),analyst:n=>me(n,"\x1B[38;5;108m"),product:n=>me(n,"\x1B[38;5;180m")};Ve=class{frames=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"];interval=null;frameIndex=0;message;startTime=0;constructor(e="Thinking"){this.message=e}start(){if(this.startTime=Date.now(),!wn){process.stderr.write(` ${this.message}...
|
|
204
204
|
`);return}this.interval=setInterval(()=>{let e=((Date.now()-this.startTime)/1e3).toFixed(1),t=c.accent(this.frames[this.frameIndex]);process.stdout.write(`\r ${t} ${c.muted(this.message)} ${c.muted(e+"s")}`),this.frameIndex=(this.frameIndex+1)%this.frames.length},80)}setPhase(e){this.message=e}updateMessage(e){this.message=e}stop(e){this.interval&&(clearInterval(this.interval),this.interval=null);let t=Date.now()-this.startTime;if(wn&&process.stdout.write("\r"+" ".repeat(80)+"\r"),e&&wn){let s=c.muted(`${t}ms`);console.log(` ${c.muted("\xB7")} ${c.secondary(e)} ${s}`)}}};Qi=[{cmd:"/help",desc:"Show this help"},{cmd:"/about",desc:"Developer info & links"},{cmd:"/version",desc:"Version & runtime info"},{cmd:"/team",desc:"Show agent team roster"},{cmd:"/model",arg:"<name>",desc:"Switch model"},{cmd:"/models",arg:"[search|page]",desc:"Browse all models"},{cmd:"/tree",desc:"Project file tree"},{cmd:"/status",desc:"Agent status & context"},{cmd:"/history",arg:"[n]",desc:"Show last n turns"},{cmd:"/undo",arg:"[path]",desc:"Restore last backup"},{cmd:"/clear",desc:"Clear session & context"},{cmd:"/config",desc:"Show current config"},{cmd:"/quit",desc:"Exit hablas"}];Zy={pending:"\u25CB",running:"\u25C9",done:"\u2713",failed:"\u2717",skipped:"\u2013"},eb={pending:c.muted,running:c.accent,done:c.success,failed:c.error,skipped:c.muted};no=Qi.map(n=>n.cmd).concat(["/exit","/addmodel","/listmodels","/removemodel","/usemodel","/provider","/task","/memory","/mindset","/mindsets","/alias","/doctor","/plugins","/team","/agents","/delegate"])});function so(n){let e=st.join(n,"package.json");if(Ue.existsSync(e))try{let t=JSON.parse(Ue.readFileSync(e,"utf-8")),s={...t.dependencies,...t.devDependencies};if(s.vitest)return"vitest";if(s.jest||s["@jest/core"])return"jest";if(s.mocha)return"mocha"}catch{}if(Ue.existsSync(st.join(n,"pytest.ini"))||Ue.existsSync(st.join(n,"pyproject.toml"))||Ue.existsSync(st.join(n,"setup.py")))try{let t=Ue.existsSync(st.join(n,"requirements.txt"))?Ue.readFileSync(st.join(n,"requirements.txt"),"utf-8"):"",s=Ue.existsSync(st.join(n,"pyproject.toml"))?Ue.readFileSync(st.join(n,"pyproject.toml"),"utf-8"):"";if(t.includes("pytest")||s.includes("pytest"))return"pytest"}catch{}return Ue.existsSync(st.join(n,"go.mod"))?"go":Ue.existsSync(st.join(n,"Cargo.toml"))?"cargo":"unknown"}function tb(n,e){switch(n){case"vitest":return e?`npx vitest run ${e}`:"npx vitest run";case"jest":return e?`npx jest ${e} --no-coverage`:"npx jest --no-coverage";case"mocha":return e?`npx mocha ${e}`:"npx mocha";case"pytest":return e?`python -m pytest ${e} -v`:"python -m pytest -v";case"go":return e?`go test ./${e}`:"go test ./...";case"cargo":return"cargo test";default:return"npm test"}}function _u(n,e){let t=so(n),s=tb(t,e),r=Date.now(),i="",o="",a=!1;try{i=(0,Su.execSync)(s,{cwd:n,encoding:"utf-8",timeout:12e4,maxBuffer:5*1024*1024,stdio:["pipe","pipe","pipe"]}),a=!0}catch(m){i=m.stdout||"",o=m.stderr||m.message||"",a=!1}let l=Date.now()-r,{totalTests:u,passedTests:d,failedTests:f,failedTestNames:h}=nb(i+`
|
|
205
205
|
`+o,t);return{framework:t,command:s,passed:a,output:i.slice(0,5e3),errorOutput:o.slice(0,3e3),totalTests:u,passedTests:d,failedTests:f,duration:l,failedTestNames:h}}function nb(n,e){let t=0,s=0,r=0,i=[],o=n.split(`
|
|
206
206
|
`);switch(e){case"jest":case"vitest":{for(let a of o){let l=a.match(/Tests:\s+(\d+)\s+passed.*?(\d+)\s+total/);if(l&&(s=parseInt(l[1]),t=parseInt(l[2]),r=t-s),a.match(/✕|FAIL|✗|×/)){let d=a.replace(/.*(?:✕|FAIL|✗|×)\s*/,"").trim();d&&i.push(d)}}break}case"pytest":{for(let a of o){let l=a.match(/(\d+)\s+passed.*?(\d+)\s+failed/);l&&(s=parseInt(l[1]),r=parseInt(l[2]),t=s+r);let u=a.match(/(\d+)\s+passed/);u&&t===0&&(s=parseInt(u[1]),t=s),a.includes("FAILED")&&i.push(a.trim())}break}case"go":{for(let a of o)a.includes("--- PASS")&&s++,a.includes("--- FAIL")&&(r++,i.push(a.replace("--- FAIL:","").trim()));t=s+r;break}default:{for(let a of o)/\bpass(ed|ing)?\b/i.test(a)&&/\d/.test(a)&&s++,/\bfail(ed|ing|ure)?\b/i.test(a)&&/\d/.test(a)&&r++;t=s+r}}return{totalTests:t,passedTests:s,failedTests:r,failedTestNames:i}}function ku(n){let e=[],t=n.passed?"\u2713 PASSED":"\u2717 FAILED",s=(n.duration/1e3).toFixed(1);if(e.push(` ${n.passed?"\u2713":"\u2717"} ${t} (${n.framework}) \u2014 ${s}s`),e.push(` Command: ${n.command}`),n.totalTests>0&&e.push(` Tests: ${n.passedTests} passed, ${n.failedTests} failed, ${n.totalTests} total`),n.failedTestNames.length>0){e.push(""),e.push(" Failed tests:");for(let r of n.failedTestNames.slice(0,10))e.push(` \u2717 ${r}`)}return e.join(`
|
|
@@ -224,20 +224,20 @@ Instructions:
|
|
|
224
224
|
1. Read the failing test files to understand what's expected
|
|
225
225
|
2. Read the source files being tested
|
|
226
226
|
3. Fix the source code (not the tests) to make them pass
|
|
227
|
-
4. After fixing, explain what was wrong and what you changed`}var Su,Ue,st,$u=L(()=>{"use strict";Su=require("child_process"),Ue=O(require("fs")),st=O(require("path"))});function Ks(n){let e=Buffer.from(n).toString("base64url").slice(0,16);return
|
|
228
|
-
`).filter(Boolean);for(let h of f)if(!i.find(m=>m.path===h))try{let m=await $t.readFile(
|
|
229
|
-
`)}var
|
|
227
|
+
4. After fixing, explain what was wrong and what you changed`}var Su,Ue,st,$u=L(()=>{"use strict";Su=require("child_process"),Ue=O(require("fs")),st=O(require("path"))});function Ks(n){let e=Buffer.from(n).toString("base64url").slice(0,16);return Me.join(sb,e)}async function Tu(n,e,t){let s=Ks(n);Ce.existsSync(s)||Ce.mkdirSync(s,{recursive:!0});let r=`cp_${Date.now()}`,i=[];for(let f of t){let h=Me.resolve(n,f);if(Ce.existsSync(h))try{let m=await $t.readFile(h,"utf-8");i.push({path:f,content:m})}catch{}}try{let f=(0,qs.execSync)("git ls-files -m",{cwd:n,encoding:"utf-8",timeout:5e3}).split(`
|
|
228
|
+
`).filter(Boolean);for(let h of f)if(!i.find(m=>m.path===h))try{let m=await $t.readFile(Me.resolve(n,h),"utf-8");i.push({path:h,content:m})}catch{}}catch{}let o,a;try{o=(0,qs.execSync)("git branch --show-current",{cwd:n,encoding:"utf-8",timeout:5e3}).trim(),a=(0,qs.execSync)("git rev-parse --short HEAD",{cwd:n,encoding:"utf-8",timeout:5e3}).trim()}catch{}let l={id:r,label:e,timestamp:Date.now(),files:i,gitBranch:o,gitHash:a,projectPath:n},u=Me.join(s,`${r}.json`);await $t.writeFile(u,JSON.stringify(l,null,2),"utf-8");let d=Ce.readdirSync(s).filter(f=>f.endsWith(".json")).sort();if(d.length>20)for(let f of d.slice(0,d.length-20))try{Ce.unlinkSync(Me.join(s,f))}catch{}return{id:r,label:e,timestamp:l.timestamp,fileCount:i.length,projectPath:n}}function Eu(n){let e=Ks(n);if(!Ce.existsSync(e))return[];let t=Ce.readdirSync(e).filter(r=>r.endsWith(".json")).sort().reverse(),s=[];for(let r of t)try{let i=JSON.parse(Ce.readFileSync(Me.join(e,r),"utf-8"));s.push({id:i.id,label:i.label,timestamp:i.timestamp,fileCount:i.files.length,projectPath:i.projectPath})}catch{}return s}async function Ru(n,e){let t=Ks(n),s=Me.join(t,`${e}.json`);if(!Ce.existsSync(s))return{success:!1,filesRestored:0,error:`Checkpoint ${e} not found`};try{let r=JSON.parse(await $t.readFile(s,"utf-8")),i=0;for(let o of r.files)try{let a=Me.resolve(n,o.path);await $t.mkdir(Me.dirname(a),{recursive:!0}),await $t.writeFile(a,o.content,"utf-8"),i++}catch{}return{success:!0,filesRestored:i}}catch(r){return{success:!1,filesRestored:0,error:r.message}}}function Pu(n,e){let t=Ks(n),s=Me.join(t,`${e}.json`);try{if(Ce.existsSync(s))return Ce.unlinkSync(s),!0}catch{}return!1}function Ou(n){if(n.length===0)return" No checkpoints saved";let e=[];for(let t of n){let s=new Date(t.timestamp).toLocaleString();e.push(` ${t.id} "${t.label}" (${t.fileCount} files, ${s})`)}return e.join(`
|
|
229
|
+
`)}var Ce,$t,Me,Cu,qs,sb,Mu=L(()=>{"use strict";Ce=O(require("fs")),$t=O(require("fs/promises")),Me=O(require("path")),Cu=O(require("os")),qs=require("child_process"),sb=Me.join(Cu.homedir(),".hablas","checkpoints")});function Ct(){}function rb(n,e,t,s,r){for(var i=[],o;e;)i.push(e),o=e.previousComponent,delete e.previousComponent,e=o;i.reverse();for(var a=0,l=i.length,u=0,d=0;a<l;a++){var f=i[a];if(f.removed){if(f.value=n.join(s.slice(d,d+f.count)),d+=f.count,a&&i[a-1].added){var m=i[a-1];i[a-1]=i[a],i[a]=m}}else{if(!f.added&&r){var h=t.slice(u,u+f.count);h=h.map(function(g,w){var _=s[d+w];return _.length>g.length?_:g}),f.value=n.join(h)}else f.value=n.join(t.slice(u,u+f.count));u+=f.count,f.added||(d+=f.count)}}var p=i[l-1];return l>1&&typeof p.value=="string"&&(p.added||p.removed)&&n.equals("",p.value)&&(i[l-2].value+=p.value,i.pop()),i}function ib(n,e,t){return lo.diff(n,e,t)}function Ws(n){"@babel/helpers - typeof";return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?Ws=function(e){return typeof e}:Ws=function(e){return e&&typeof Symbol=="function"&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},Ws(n)}function ro(n){return lb(n)||cb(n)||ub(n)||db()}function lb(n){if(Array.isArray(n))return io(n)}function cb(n){if(typeof Symbol<"u"&&Symbol.iterator in Object(n))return Array.from(n)}function ub(n,e){if(n){if(typeof n=="string")return io(n,e);var t=Object.prototype.toString.call(n).slice(8,-1);if(t==="Object"&&n.constructor&&(t=n.constructor.name),t==="Map"||t==="Set")return Array.from(n);if(t==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return io(n,e)}}function io(n,e){(e==null||e>n.length)&&(e=n.length);for(var t=0,s=new Array(e);t<e;t++)s[t]=n[t];return s}function db(){throw new TypeError(`Invalid attempt to spread non-iterable instance.
|
|
230
230
|
In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function oo(n,e,t,s,r){e=e||[],t=t||[],s&&(n=s(r,n));var i;for(i=0;i<e.length;i+=1)if(e[i]===n)return t[i];var o;if(fb.call(n)==="[object Array]"){for(e.push(n),o=new Array(n.length),t.push(o),i=0;i<n.length;i+=1)o[i]=oo(n[i],e,t,s,r);return e.pop(),t.pop(),o}if(n&&n.toJSON&&(n=n.toJSON()),Ws(n)==="object"&&n!==null){e.push(n),o={},t.push(o);var a=[],l;for(l in n)n.hasOwnProperty(l)&&a.push(l);for(a.sort(),i=0;i<a.length;i+=1)l=a[i],o[l]=oo(n[l],e,t,s,l);e.pop(),t.pop()}else o=n;return o}function pb(n){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},t=n.split(/\r\n|[\n\v\f\r\x85]/),s=n.match(/\r\n|[\n\v\f\r\x85]/g)||[],r=[],i=0;function o(){var u={};for(r.push(u);i<t.length;){var d=t[i];if(/^(\-\-\-|\+\+\+|@@)\s/.test(d))break;var f=/^(?:Index:|diff(?: -r \w+)+)\s+/.exec(d);f&&(u.index=d.substring(f[0].length).trim()),i++}for(a(u),a(u),u.hunks=[];i<t.length;){var h=t[i];if(/^(Index:|diff|\-\-\-|\+\+\+)\s/.test(h))break;if(/^@@/.test(h))u.hunks.push(l());else{if(h&&e.strict)throw new Error("Unknown line "+(i+1)+" "+JSON.stringify(h));i++}}}function a(u){var d=/^(---|\+\+\+)\s+/.exec(t[i]);if(d){var f=d[1]==="---"?"old":"new",h=t[i].substring(3).trim().split(" ",2),m=h[0].replace(/\\\\/g,"\\");m.startsWith('"')&&m.endsWith('"')&&(m=m.substr(1,m.length-2)),u[f+"FileName"]=m,u[f+"Header"]=(h[1]||"").trim(),i++}}function l(){var u=i,d=t[i++],f=d.split(/@@ -(\d+)(?:,(\d+))? \+(\d+)(?:,(\d+))? @@/),h={oldStart:+f[1],oldLines:typeof f[2]>"u"?1:+f[2],newStart:+f[3],newLines:typeof f[4]>"u"?1:+f[4],lines:[],linedelimiters:[]};h.oldLines===0&&(h.oldStart+=1),h.newLines===0&&(h.newStart+=1);for(var m=0,p=0;i<t.length&&!(t[i].indexOf("--- ")===0&&i+2<t.length&&t[i+1].indexOf("+++ ")===0&&t[i+2].indexOf("@@")===0);i++){var g=t[i].length==0&&i!=t.length-1?" ":t[i][0];if(g==="+"||g==="-"||g===" "||g==="\\")h.lines.push(t[i]),h.linedelimiters.push(s[i]||`
|
|
231
|
-
`),g==="+"?m++:g==="-"?p++:g===" "&&(m++,p++);else break}if(!m&&h.newLines===1&&(h.newLines=0),!p&&h.oldLines===1&&(h.oldLines=0),e.strict){if(m!==h.newLines)throw new Error("Added line count did not match for hunk at line "+(u+1));if(p!==h.oldLines)throw new Error("Removed line count did not match for hunk at line "+(u+1))}return h}for(;i<t.length;)o();return r}function hb(n,e,t){var s=!0,r=!1,i=!1,o=1;return function a(){if(s&&!i){if(r?o++:s=!1,n+o<=t)return o;i=!0}if(!r)return i||(s=!0),e<=n-o?-o++:(r=!0,a())}}function Fu(n,e){var t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};if(typeof e=="string"&&(e=pb(e)),Array.isArray(e)){if(e.length>1)throw new Error("applyPatch only works with a single input.");e=e[0]}var s=n.split(/\r\n|[\n\v\f\r\x85]/),r=n.match(/\r\n|[\n\v\f\r\x85]/g)||[],i=e.hunks,o=t.compareLine||function(T,S,
|
|
232
|
-
`;if(M===" ")x++;else if(M==="-")s.splice(x,1),r.splice(x,1);else if(M==="+")s.splice(x,0,C),r.splice(x,0,F),x++;else if(M==="\\"){var H=b.lines[
|
|
233
|
-
`));for(var Y=0;Y<s.length-1;Y++)s[Y]=s[Y]+r[Y];return s.join("")}function mb(n,e,t,s,r,i,o){o||(o={}),typeof o.context>"u"&&(o.context=4);var a=ib(t,s,o);if(!a)return;a.push({value:"",lines:[]});function l(_){return _.map(function(k){return" "+k})}for(var u=[],d=0,f=0,h=[],m=1,p=1,g=function(k){var
|
|
234
|
-
`);if(
|
|
231
|
+
`),g==="+"?m++:g==="-"?p++:g===" "&&(m++,p++);else break}if(!m&&h.newLines===1&&(h.newLines=0),!p&&h.oldLines===1&&(h.oldLines=0),e.strict){if(m!==h.newLines)throw new Error("Added line count did not match for hunk at line "+(u+1));if(p!==h.oldLines)throw new Error("Removed line count did not match for hunk at line "+(u+1))}return h}for(;i<t.length;)o();return r}function hb(n,e,t){var s=!0,r=!1,i=!1,o=1;return function a(){if(s&&!i){if(r?o++:s=!1,n+o<=t)return o;i=!0}if(!r)return i||(s=!0),e<=n-o?-o++:(r=!0,a())}}function Fu(n,e){var t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};if(typeof e=="string"&&(e=pb(e)),Array.isArray(e)){if(e.length>1)throw new Error("applyPatch only works with a single input.");e=e[0]}var s=n.split(/\r\n|[\n\v\f\r\x85]/),r=n.match(/\r\n|[\n\v\f\r\x85]/g)||[],i=e.hunks,o=t.compareLine||function(T,S,Q,q){return S===q},a=0,l=t.fuzzFactor||0,u=0,d=0,f,h;function m(T,S){for(var Q=0;Q<T.lines.length;Q++){var q=T.lines[Q],ne=q.length>0?q[0]:" ",re=q.length>0?q.substr(1):q;if(ne===" "||ne==="-"){if(!o(S+1,s[S],ne,re)&&(a++,a>l))return!1;S++}}return!0}for(var p=0;p<i.length;p++){for(var g=i[p],w=s.length-g.oldLines,_=0,k=d+g.oldStart-1,$=hb(k,u,w);_!==void 0;_=$())if(m(g,k+_)){g.offset=d+=_;break}if(_===void 0)return!1;u=g.offset+g.oldStart+g.oldLines}for(var y=0,v=0;v<i.length;v++){var b=i[v],x=b.oldStart+b.offset+y-1;y+=b.newLines-b.oldLines;for(var A=0;A<b.lines.length;A++){var E=b.lines[A],M=E.length>0?E[0]:" ",C=E.length>0?E.substr(1):E,F=b.linedelimiters&&b.linedelimiters[A]||`
|
|
232
|
+
`;if(M===" ")x++;else if(M==="-")s.splice(x,1),r.splice(x,1);else if(M==="+")s.splice(x,0,C),r.splice(x,0,F),x++;else if(M==="\\"){var H=b.lines[A-1]?b.lines[A-1][0]:null;H==="+"?f=!0:H==="-"&&(h=!0)}}}if(f)for(;!s[s.length-1];)s.pop(),r.pop();else h&&(s.push(""),r.push(`
|
|
233
|
+
`));for(var Y=0;Y<s.length-1;Y++)s[Y]=s[Y]+r[Y];return s.join("")}function mb(n,e,t,s,r,i,o){o||(o={}),typeof o.context>"u"&&(o.context=4);var a=ib(t,s,o);if(!a)return;a.push({value:"",lines:[]});function l(_){return _.map(function(k){return" "+k})}for(var u=[],d=0,f=0,h=[],m=1,p=1,g=function(k){var $=a[k],y=$.lines||$.value.replace(/\n$/,"").split(`
|
|
234
|
+
`);if($.lines=y,$.added||$.removed){var v;if(!d){var b=a[k-1];d=m,f=p,b&&(h=o.context>0?l(b.lines.slice(-o.context)):[],d-=h.length,f-=h.length)}(v=h).push.apply(v,ro(y.map(function(Y){return($.added?"+":"-")+Y}))),$.added?p+=y.length:m+=y.length}else{if(d)if(y.length<=o.context*2&&k<a.length-2){var x;(x=h).push.apply(x,ro(l(y)))}else{var A,E=Math.min(y.length,o.context);(A=h).push.apply(A,ro(l(y.slice(0,E))));var M={oldStart:d,oldLines:m-d+E,newStart:f,newLines:p-f+E,lines:h};if(k>=a.length-2&&y.length<=o.context){var C=/\n$/.test(t),F=/\n$/.test(s),H=y.length==0&&h.length>M.oldLines;!C&&H&&t.length>0&&h.splice(M.oldLines,0,"\"),(!C&&!H||!F)&&h.push("\")}u.push(M),d=0,f=0,h=[]}m+=y.length,p+=y.length}},w=0;w<a.length;w++)g(w);return{oldFileName:n,newFileName:e,oldHeader:r,newHeader:i,hunks:u}}function Nu(n){if(Array.isArray(n))return n.map(Nu).join(`
|
|
235
235
|
`);var e=[];n.oldFileName==n.newFileName&&e.push("Index: "+n.oldFileName),e.push("==================================================================="),e.push("--- "+n.oldFileName+(typeof n.oldHeader>"u"?"":" "+n.oldHeader)),e.push("+++ "+n.newFileName+(typeof n.newHeader>"u"?"":" "+n.newHeader));for(var t=0;t<n.hunks.length;t++){var s=n.hunks[t];s.oldLines===0&&(s.oldStart-=1),s.newLines===0&&(s.newStart-=1),e.push("@@ -"+s.oldStart+","+s.oldLines+" +"+s.newStart+","+s.newLines+" @@"),e.push.apply(e,s.lines)}return e.join(`
|
|
236
236
|
`)+`
|
|
237
|
-
`}function gb(n,e,t,s,r,i,o){return Nu(mb(n,e,t,s,r,i,o))}function ju(n,e,t,s,r,i){return gb(n,n,e,t,s,r,i)}var
|
|
238
|
-
`));var e=[],t=n.split(/(\n|\r\n)/);t[t.length-1]||t.pop();for(var s=0;s<t.length;s++){var r=t[s];s%2&&!this.options.newlineIsToken?e[e.length-1]+=r:(this.options.ignoreWhitespace&&(r=r.trim()),e.push(r))}return e};ob=new Ct;ob.tokenize=function(n){return n.split(/(\S.+?[.!?])(?=\s+|$)/)};ab=new Ct;ab.tokenize=function(n){return n.split(/([{}:;,]|\s+)/)};fb=Object.prototype.toString,zn=new Ct;zn.useLongestToken=!0;zn.tokenize=lo.tokenize;zn.castInput=function(n){var e=this.options,t=e.undefinedReplacement,s=e.stringifyReplacer,r=s===void 0?function(i,o){return typeof o>"u"?t:o}:s;return typeof n=="string"?n:JSON.stringify(oo(n,null,null,r),r," ")};zn.equals=function(n,e){return Ct.prototype.equals.call(zn,n.replace(/,([\r\n])/g,"$1"),e.replace(/,([\r\n])/g,"$1"))};ao=new Ct;ao.tokenize=function(n){return n.slice()};ao.join=ao.removeEmpty=function(n){return n}});var Bu={};
|
|
237
|
+
`}function gb(n,e,t,s,r,i,o){return Nu(mb(n,e,t,s,r,i,o))}function ju(n,e,t,s,r,i){return gb(n,n,e,t,s,r,i)}var jC,Iu,Du,Lu,lo,ob,ab,fb,zn,ao,Hu=L(()=>{Ct.prototype={diff:function(e,t){var s,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},i=r.callback;typeof r=="function"&&(i=r,r={}),this.options=r;var o=this;function a(y){return i?(setTimeout(function(){i(void 0,y)},0),!0):y}e=this.castInput(e),t=this.castInput(t),e=this.removeEmpty(this.tokenize(e)),t=this.removeEmpty(this.tokenize(t));var l=t.length,u=e.length,d=1,f=l+u;r.maxEditLength&&(f=Math.min(f,r.maxEditLength));var h=(s=r.timeout)!==null&&s!==void 0?s:1/0,m=Date.now()+h,p=[{oldPos:-1,lastComponent:void 0}],g=this.extractCommon(p[0],t,e,0);if(p[0].oldPos+1>=u&&g+1>=l)return a([{value:this.join(t),count:t.length}]);var w=-1/0,_=1/0;function k(){for(var y=Math.max(w,-d);y<=Math.min(_,d);y+=2){var v=void 0,b=p[y-1],x=p[y+1];b&&(p[y-1]=void 0);var A=!1;if(x){var E=x.oldPos-y;A=x&&0<=E&&E<l}var M=b&&b.oldPos+1<u;if(!A&&!M){p[y]=void 0;continue}if(!M||A&&b.oldPos+1<x.oldPos?v=o.addToPath(x,!0,void 0,0):v=o.addToPath(b,void 0,!0,1),g=o.extractCommon(v,t,e,y),v.oldPos+1>=u&&g+1>=l)return a(rb(o,v.lastComponent,t,e,o.useLongestToken));p[y]=v,v.oldPos+1>=u&&(_=Math.min(_,y-1)),g+1>=l&&(w=Math.max(w,y+1))}d++}if(i)(function y(){setTimeout(function(){if(d>f||Date.now()>m)return i();k()||y()},0)})();else for(;d<=f&&Date.now()<=m;){var $=k();if($)return $}},addToPath:function(e,t,s,r){var i=e.lastComponent;return i&&i.added===t&&i.removed===s?{oldPos:e.oldPos+r,lastComponent:{count:i.count+1,added:t,removed:s,previousComponent:i.previousComponent}}:{oldPos:e.oldPos+r,lastComponent:{count:1,added:t,removed:s,previousComponent:i}}},extractCommon:function(e,t,s,r){for(var i=t.length,o=s.length,a=e.oldPos,l=a-r,u=0;l+1<i&&a+1<o&&this.equals(t[l+1],s[a+1]);)l++,a++,u++;return u&&(e.lastComponent={count:u,previousComponent:e.lastComponent}),e.oldPos=a,l},equals:function(e,t){return this.options.comparator?this.options.comparator(e,t):e===t||this.options.ignoreCase&&e.toLowerCase()===t.toLowerCase()},removeEmpty:function(e){for(var t=[],s=0;s<e.length;s++)e[s]&&t.push(e[s]);return t},castInput:function(e){return e},tokenize:function(e){return e.split("")},join:function(e){return e.join("")}};jC=new Ct,Iu=/^[A-Za-z\xC0-\u02C6\u02C8-\u02D7\u02DE-\u02FF\u1E00-\u1EFF]+$/,Du=/\S/,Lu=new Ct;Lu.equals=function(n,e){return this.options.ignoreCase&&(n=n.toLowerCase(),e=e.toLowerCase()),n===e||this.options.ignoreWhitespace&&!Du.test(n)&&!Du.test(e)};Lu.tokenize=function(n){for(var e=n.split(/([^\S\r\n]+|[()[\]{}'"\r\n]|\b)/),t=0;t<e.length-1;t++)!e[t+1]&&e[t+2]&&Iu.test(e[t])&&Iu.test(e[t+2])&&(e[t]+=e[t+2],e.splice(t+1,2),t--);return e};lo=new Ct;lo.tokenize=function(n){this.options.stripTrailingCr&&(n=n.replace(/\r\n/g,`
|
|
238
|
+
`));var e=[],t=n.split(/(\n|\r\n)/);t[t.length-1]||t.pop();for(var s=0;s<t.length;s++){var r=t[s];s%2&&!this.options.newlineIsToken?e[e.length-1]+=r:(this.options.ignoreWhitespace&&(r=r.trim()),e.push(r))}return e};ob=new Ct;ob.tokenize=function(n){return n.split(/(\S.+?[.!?])(?=\s+|$)/)};ab=new Ct;ab.tokenize=function(n){return n.split(/([{}:;,]|\s+)/)};fb=Object.prototype.toString,zn=new Ct;zn.useLongestToken=!0;zn.tokenize=lo.tokenize;zn.castInput=function(n){var e=this.options,t=e.undefinedReplacement,s=e.stringifyReplacer,r=s===void 0?function(i,o){return typeof o>"u"?t:o}:s;return typeof n=="string"?n:JSON.stringify(oo(n,null,null,r),r," ")};zn.equals=function(n,e){return Ct.prototype.equals.call(zn,n.replace(/,([\r\n])/g,"$1"),e.replace(/,([\r\n])/g,"$1"))};ao=new Ct;ao.tokenize=function(n){return n.slice()};ao.join=ao.removeEmpty=function(n){return n}});var Bu={};Fe(Bu,{applyDiff:()=>yb,formatDiffForDisplay:()=>bb,generateDiff:()=>Gs});function Gs(n,e,t){return ju(n,e,t,"original","modified")}function yb(n,e){return Fu(n,e)}function bb(n){return n.split(`
|
|
239
239
|
`).map(t=>t.startsWith("+")&&!t.startsWith("+++")?`\x1B[32m${t}\x1B[0m`:t.startsWith("-")&&!t.startsWith("---")?`\x1B[31m${t}\x1B[0m`:t.startsWith("@@")?`\x1B[36m${t}\x1B[0m`:t).join(`
|
|
240
|
-
`)}var co=L(()=>{"use strict";Hu()});async function Qt(n,e){let t=[],s
|
|
240
|
+
`)}var co=L(()=>{"use strict";Hu()});async function Qt(n,e){let t=[],s=Ae.join(n,"package.json");if(ye.existsSync(s))try{let o=JSON.parse(ye.readFileSync(s,"utf-8"));t.push(`Project: ${o.name||"unknown"}${o.version?` v${o.version}`:""}`),o.description&&t.push(`Description: ${o.description}`);let a=Object.keys(o.dependencies||{}).concat(Object.keys(o.devDependencies||{}));a.length>0&&t.push(`Key deps: ${a.slice(0,15).join(", ")}${a.length>15?"...":""}`)}catch{}if(e?.workspace?.frameworkDetection){let o=Us(n);t.push(`Framework: ${o.framework}`),t.push(`Language: ${o.language}`),t.push(`Package Manager: ${o.packageManager}`),o.hasDocker&&t.push("Docker: detected"),o.hasCICD&&t.push("CI/CD: detected"),o.hasTests&&t.push("Tests: detected")}if(e?.workspace?.gitAwareness)try{let o=await zi(n);o&&(t.push(`Git branch: ${o.branch}`),o.modified.length>0&&t.push(`Modified files: ${o.modified.length}`),o.staged.length>0&&t.push(`Staged files: ${o.staged.length}`))}catch{}if(e?.workspace?.envParsing){let a=[".env",".env.local",".env.development",".env.production"].filter(l=>ye.existsSync(Ae.join(n,l)));a.length>0&&t.push(`Env files: ${a.join(", ")}`)}let i=["tsconfig.json",".eslintrc.json","vite.config.ts","next.config.js","tailwind.config.js"].filter(o=>ye.existsSync(Ae.join(n,o)));if(i.length>0&&t.push(`Config: ${i.join(", ")}`),e?.context?.projectGraph)try{let o=ye.readdirSync(n).filter(a=>!["node_modules",".git","dist","build",".next",".cache"].includes(a)).filter(a=>!a.startsWith(".")).slice(0,25);o.length>0&&t.push(`Structure: ${o.join(", ")}`)}catch{}else try{let o=ye.readdirSync(n).filter(a=>!["node_modules",".git","dist","build",".next",".cache"].includes(a)).filter(a=>!a.startsWith(".")).slice(0,20);o.length>0&&t.push(`Structure: ${o.join(", ")}`)}catch{}return t.push(`Directory: ${n}`),e?.agents?.enabled&&(t.push("Multi-Agent: enabled (Team Leader: Hablas)"),t.push("Team: @Hablas (Leader), @Bob (Architect), @Alex (Engineer), @David (Data Analyst), @Emma (Product Manager)")),t.join(`
|
|
241
241
|
`)}function Zt(n,e,t,s){let r=n+`
|
|
242
242
|
|
|
243
243
|
## Current Project
|
|
@@ -248,14 +248,14 @@ In order to be iterable, non-array objects must have a [Symbol.iterator]() metho
|
|
|
248
248
|
## Shared Context
|
|
249
249
|
`+i)}return r+=`
|
|
250
250
|
|
|
251
|
-
`+nu(),r}async function vb(n){try{if(!
|
|
251
|
+
`+nu(),r}async function vb(n){try{if(!ye.existsSync(uo))return null;let t=(await Ft.readdir(uo)).filter(f=>f.endsWith(".bak"));if(n){let f=Ae.basename(n);t=t.filter(h=>h.startsWith(`${f}.`))}if(t.length===0)return null;t.sort().reverse();let s=t[0],r=Ae.join(uo,s),i=s.replace(".bak","").split("."),o=parseInt(i[i.length-1],10),a=i.slice(0,-1).join("."),l=Date.now()-o,u=Math.floor(l/6e4),d=u<1?"just now":u<60?`${u} minutes ago`:`${Math.floor(u/60)} hours ago`;return{backupPath:r,originalName:a,age:d}}catch{return null}}async function Uu(n,e,t,s,r,i,o,a,l,u,d,f,h,m,p,g,w){let _=n.split(/\s+/),k=_[0],$=_.slice(1).join(" ");switch(k){case"/quit":case"/exit":return"quit";case"/help":console.log(wu()),console.log(c.muted(" Model & Provider:")),console.log(c.muted(" /addmodel Interactive wizard to add a custom API")),console.log(c.muted(" /listmodels Show saved providers")),console.log(c.muted(" /removemodel <name> Remove a saved provider")),console.log(c.muted(" /usemodel <name> Switch to a saved provider")),console.log(c.muted(" /models [page|search] Browse all available models")),console.log(c.muted(" /provider Show/switch API provider")),console.log(),console.log(c.muted(" Aliases & Plugins:")),console.log(c.muted(" /alias Show all aliases")),console.log(c.muted(" /alias set <n> <cmd> Create an alias")),console.log(c.muted(" /alias del <name> Remove an alias")),console.log(c.muted(" /plugins List installed plugins")),console.log(c.muted(" /doctor Run system diagnostics")),console.log(),console.log(c.muted(" Task & Memory:")),console.log(c.muted(" /task add <desc> Add a task to the queue")),console.log(c.muted(" /task list Show all tasks")),console.log(c.muted(" /task clear Clear task queue")),console.log(c.muted(" /memory Show project memory")),console.log(c.muted(" /memory set <k> <v> Store a memory")),console.log(c.muted(" /memory del <key> Delete a memory")),console.log(c.muted(" /memory clear Clear all memory")),console.log(),console.log(c.muted(" Multi-Agent & Tools:")),console.log(c.muted(" /team Show team roster")),console.log(c.muted(" /delegate <agent> <t> Manually assign task to agent")),console.log(c.muted(" /agents Multi-agent system control")),console.log(c.muted(" /agents on|off Enable/disable multi-agent")),console.log(c.muted(" /agents status Show agent details")),console.log(c.muted(" /security Run security scan")),console.log(c.muted(" /git status Show git status")),console.log(c.muted(" /workspace Show workspace info")),console.log(c.muted(" /stats Show usage analytics")),console.log();break;case"/about":console.log(hu());break;case"/version":console.log(mu());break;case"/team":{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Team Roster")}`),console.log(),console.log(Ii()),console.log();break}case"/model":if($){let y=await t.listModels();t.setModel($),y.includes($)?console.log(X(`Model: ${$}`)):console.log(j(`Model set to "${$}" (not found locally)`))}else console.log(le(`Current model: ${t.getModel()}`)),console.log(c.muted(" Usage: /model <name>"));break;case"/models":{let y=$.trim(),v=1,b="";if(y){let S=parseInt(y);!isNaN(S)&&S>0?v=S:b=y.toLowerCase()}let x=new Ve("Fetching models");x.start();let A=await t.listModels();if(x.stop(A.length>0?`${A.length} found`:void 0),A.length===0){console.log(j("No models found \u2014 check your connection")),console.log(c.muted(" Use /provider test to verify"));break}let E=A;if(b&&(E=A.filter(S=>S.toLowerCase().includes(b)),E.length===0)){console.log(j(`No models matching: "${b}"`)),console.log(c.muted(` ${A.length} models available. Try a different search.`));break}let M=20,C=Math.ceil(E.length/M),F=Math.max(1,Math.min(v,C)),H=(F-1)*M,Y=H+M,T=E.slice(H,Y);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Available Models")} ${c.muted(`(${E.length} total \xB7 page ${F}/${C})`)}`),console.log();for(let S=0;S<T.length;S++){let Q=H+S+1,ne=T[S]===t.getModel()?` ${c.success("\u25CF active")}`:"";console.log(` ${c.muted(String(Q).padStart(3," "))}. ${c.secondary(T[S])}${ne}`)}console.log(),C>1&&console.log(c.muted(` /models ${F<C?F+1:1} \u2014 next page`)),b&&console.log(c.muted(` Filtered: ${E.length} of ${A.length} (query: "${b}")`)),console.log(c.muted(" /models <query> \u2014 search \xB7 /model <id> \u2014 switch")),console.log();break}case"/tree":{let y=s.get("list_dir");if(y){let v=await y.execute({path:".",depth:3});console.log(`
|
|
252
252
|
${v.output}
|
|
253
|
-
`)}break}case"/status":{let y=await t.checkConnection(),v=u?u.getActiveName():"planner",b=f?f.size():0,x=d?d.getProgress():void 0;console.log(vu({model:t.getModel(),host:e.ollamaHost,directory:o,cacheFiles:r.getCacheSize(),cacheTokens:r.getTotalTokens(),budgetTokens:e.contextBudget,connected:y,turnCount:l,mindset:v})),b>0&&console.log(c.muted(` Memory entries: ${b}`)),x&&x.total>0&&console.log(c.muted(` Tasks: ${x.done}/${x.total} done`)),console.log();break}case"/clear":r.clear(),i.clear(),console.log(
|
|
253
|
+
`)}break}case"/status":{let y=await t.checkConnection(),v=u?u.getActiveName():"planner",b=f?f.size():0,x=d?d.getProgress():void 0;console.log(vu({model:t.getModel(),host:e.ollamaHost,directory:o,cacheFiles:r.getCacheSize(),cacheTokens:r.getTotalTokens(),budgetTokens:e.contextBudget,connected:y,turnCount:l,mindset:v})),b>0&&console.log(c.muted(` Memory entries: ${b}`)),x&&x.total>0&&console.log(c.muted(` Tasks: ${x.done}/${x.total} done`)),console.log();break}case"/clear":r.clear(),i.clear(),console.log(X("History cleared"));break;case"/history":{let y=parseInt($)||10,v=i.getHistory().slice(-y);if(v.length===0){console.log(le("No history yet"));break}console.log(),v.forEach(b=>{let x=b.role==="user"?c.primary("You"):b.role==="assistant"?c.success("Hablas"):c.muted("tool"),A=b.content.slice(0,120).replace(/\n/g," ");console.log(` ${x}: ${c.muted(A)}`)}),console.log();break}case"/undo":{if(!g){let y=await vb($||void 0);if(!y){console.log(j("No backups found"));break}let v=$?Ae.resolve(o,$):Ae.resolve(o,y.originalName);if(await a.confirm(`Restore ${y.originalName} from backup (${y.age})?`))try{let x=await Ft.readFile(y.backupPath,"utf-8");await Ft.writeFile(v,x,"utf-8"),console.log(X(`Restored ${y.originalName} from backup (${y.age})`))}catch(x){console.log($e(`Failed: ${x.message}`))}break}if($==="list")console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Undo History")} (${g.getUndoableCount()} changes)`),console.log(),console.log(g.formatList(20)),console.log();else if($==="all"){let y=g.getUndoableCount();if(y===0){console.log(le("Nothing to undo"));break}if(await a.confirm(`Undo ALL ${y} changes?`)){let b=await g.undoAll(),x=b.filter(A=>A.success).length;console.log(X(`Reverted ${x}/${b.length} changes`))}}else{let y=$&&parseInt($)||1;if(g.getUndoableCount()===0){console.log(le("Nothing to undo"));break}let v=await g.undo(y);for(let b of v)b.success?console.log(X(`Reverted: ${b.file}`)):console.log($e(`Failed to revert ${b.file}: ${b.error}`))}break}case"/config":console.log(`
|
|
254
254
|
${c.muted(JSON.stringify(e,null,2))}
|
|
255
|
-
`),console.log(c.muted(" ~/.hablas/config.json")),console.log();break;case"/mindset":{if(!u){console.log(j("Mindset system not available"));break}if(A)if(u.setActive(A)){let v=u.getActive(),b=await Qt(o,e),x=Zt(v.systemPrompt,b,f,m);i.updateSystemPrompt(x),console.log(Z(`Mindset: ${v.name} \u2014 ${v.description}`))}else{let v=u.listNames().join(", ");console.log(Be(`Unknown mindset: "${A}"`,`Available: ${v}`))}else{let y=u.getActive();y&&console.log(le(`Current mindset: ${y.name} \u2014 ${y.description}`)),console.log(c.muted(" Usage: /mindset <name>")),console.log(c.muted(" See /mindsets for available options"))}break}case"/mindsets":{if(!u){console.log(j("Mindset system not available"));break}let y=u.list(),v=u.getActiveName();console.log();for(let b of y){let $=b.name===v?c.success(" \u25CF active"):"";console.log(` ${c.accent("\u25C6")} ${c.primary(b.name)}${$}`),console.log(` ${c.muted(b.description)}`)}console.log(),console.log(c.muted(" Switch: /mindset <name>")),console.log();break}case"/task":{if(!d){console.log(j("Task queue not available"));break}let y=_[1],v=_.slice(2).join(" ");switch(y){case"add":if(v){let b=d.add(v);console.log(Z(`Task #${b.id} added: ${v}`))}else console.log(j("Usage: /task add <description>"));break;case"list":console.log(),console.log(d.render()),console.log();break;case"done":{let b=parseInt(v);b?(d.complete(b),console.log(Z(`Task #${b} marked as done`))):console.log(j("Usage: /task done <id>"));break}case"fail":{let b=parseInt(v);b?(d.fail(b,"Manually marked as failed"),console.log(j(`Task #${b} marked as failed`))):console.log(j("Usage: /task fail <id>"));break}case"clear":d.clear(),console.log(Z("Task queue cleared"));break;default:console.log(),console.log(d.render()),console.log(),console.log(c.muted(" /task add <desc> \u2014 Add a task")),console.log(c.muted(" /task list \u2014 Show all tasks")),console.log(c.muted(" /task done <id> \u2014 Mark task as done")),console.log(c.muted(" /task fail <id> \u2014 Mark task as failed")),console.log(c.muted(" /task clear \u2014 Clear all tasks")),console.log()}break}case"/addmodel":{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Add Custom API Provider")}`),console.log();let v=(await a.prompt(` ${c.muted("Provider name (e.g. OpenAI, Groq):")} `)).trim();if(!v){console.log(j("Cancelled \u2014 name is required"));break}let x=(await a.prompt(` ${c.muted("API URL (e.g. https://api.openai.com/v1):")} `)).trim();if(!x){console.log(j("Cancelled \u2014 URL is required"));break}let E=(await a.prompt(` ${c.muted("API Key (leave empty if none):")} `)).trim(),C=(await a.prompt(` ${c.muted("Default model ID (e.g. gpt-4o):")} `)).trim()||"default",F={name:v,apiUrl:x,apiKey:E,models:[C],defaultModel:C,addedAt:new Date().toISOString()};tt(F),console.log(),console.log(Z(`Provider "${v}" saved!`)),console.log(c.muted(` Use: /usemodel ${v}`)),console.log();break}case"/listmodels":{let y=zt();console.log(),console.log(Tc(y.providers,y.activeProvider));break}case"/removemodel":{let y=A.trim();if(!y){console.log(j("Usage: /removemodel <provider-name>"));break}if(Ac(y))console.log(Z(`Provider "${y}" removed`));else{console.log(j(`Provider "${y}" not found`));let b=Ps();b.length>0&&console.log(c.muted(` Available: ${b.map(x=>x.name).join(", ")}`))}break}case"/usemodel":{let y=A.trim();if(!y){console.log(j("Usage: /usemodel <provider-name> [model-id]"));let F=Ps();F.length>0&&console.log(c.muted(` Available: ${F.map(H=>H.name).join(", ")}`));break}let v=y.split(/\s+/),b=v[0],x=v[1],$=$c(b);if(!$){console.log(j(`Provider "${b}" not found`));let F=Ps();F.length>0&&console.log(c.muted(` Available: ${F.map(H=>H.name).join(", ")}`));break}e.provider="custom",e.apiUrl=$.apiUrl,e.apiKey=$.apiKey,e.model=x||$.defaultModel;let E=Fe(e);h&&h(E),Cc($.name,e.model),console.log(Z(`Switched to ${$.name} \xB7 Model: ${e.model}`));let M=new Ve("Testing");M.start();let C=await E.checkConnection();M.stop(C?"connected":void 0),C||console.log(j("Connection test failed \u2014 check URL and key"));break}case"/provider":{let y=_[1],v=_.slice(2).join(" ");if(!y){let b=Rs(e);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Provider")}: ${b}`),console.log(` ${c.muted("Model")}: ${c.highlight(t.getModel())}`),e.provider==="custom"?(console.log(` ${c.muted("API URL")}: ${e.apiUrl}`),console.log(` ${c.muted("API Key")}: ${e.apiKey?"***"+e.apiKey.slice(-4):"not set"}`)):console.log(` ${c.muted("Host")}: ${e.ollamaHost}`),console.log(),console.log(c.muted(" /provider ollama \u2014 Switch to local Ollama")),console.log(c.muted(" /provider nvidia <key> \u2014 Switch to NVIDIA NIM")),console.log(c.muted(" /provider custom <url> [key] \u2014 Switch to custom API")),console.log(c.muted(" /provider test \u2014 Test current connection")),console.log();break}switch(y){case"ollama":{e.provider="ollama",e.apiUrl="",e.apiKey="";let b=Fe(e);h&&h(b),console.log(Z("Switched to Ollama (local)"));break}case"nvidia":{let b=_[2];if(!b&&!e.apiKey){console.log(j("Usage: /provider nvidia <api-key>")),console.log(c.muted(" Get your key at: https://build.nvidia.com/"));break}e.provider="nvidia",e.apiUrl=Lt.apiUrl,b&&(e.apiKey=b),(!e.model||!Lt.models.includes(e.model))&&(e.model=Lt.defaultModel);let x=Fe(e);h&&h(x),console.log(Z(`Switched to NVIDIA NIM \xB7 Model: ${e.model}`)),console.log(c.muted(` Available models: ${Lt.models.length}`));let $=new Ve("Testing NVIDIA connection");$.start();let E=await x.checkConnection();$.stop(E?"connected":void 0),E||(console.log(j("Connection test failed \u2014 check your API key")),console.log(c.muted(" Get key: https://build.nvidia.com/")));break}case"custom":{let b=_[2],x=_[3];if(!b){console.log(j("Usage: /provider custom <api-url> [api-key]")),console.log(c.muted(" Example: /provider custom https://api.openai.com/v1 sk-..."));break}e.provider="custom",e.apiUrl=b,x&&(e.apiKey=x);let $=Fe(e);h&&h($),console.log(Z(`Switched to Custom API: ${b}`)),!x&&!e.apiKey&&console.log(j("No API key set. Use: /provider custom <url> <key>"));break}case"test":{let b=new Ve("Testing connection");b.start();let x=await t.checkConnection();if(b.stop(x?"connected":void 0),x){let $=await t.listModels();console.log(Z(`Connected! ${$.length} models available.`)),$.length>0&&console.log(c.muted(` Models: ${$.slice(0,5).join(", ")}${$.length>5?"...":""}`))}else console.log(He("Connection failed"));break}case"key":{v?(e.apiKey=_[2],t instanceof Vt&&t.setApiKey(e.apiKey),console.log(Z("API key updated"))):console.log(j("Usage: /provider key <api-key>"));break}default:console.log(Be(`Unknown: /provider ${y}`,"Type /provider for help"))}break}case"/memory":{if(!f){console.log(j("Project memory not available"));break}let y=_[1],v=_.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],x=v.slice(1).join(" ");f.set(b,x),console.log(Z(`Memory stored: ${b}`));let $=u?.getActive(),E=$?$.systemPrompt:Yn,M=await Qt(o,e);i.updateSystemPrompt(Zt(E,M,f,m))}else console.log(j("Usage: /memory set <key> <value>"));break}case"del":case"delete":{if(v[0]){let b=f.delete(v[0]);console.log(b?Z(`Memory deleted: ${v[0]}`):j(`Memory key not found: ${v[0]}`))}else console.log(j("Usage: /memory del <key>"));break}case"search":{if(v[0]){let b=f.search(v.join(" "));b.length>0?(console.log(),b.forEach(x=>console.log(` \xB7 ${x.entry.key}: ${x.entry.value}`)),console.log()):console.log(le("No matching memories found"))}else console.log(j("Usage: /memory search <query>"));break}case"clear":f.clear(),console.log(Z("Project memory cleared"));break;default:console.log(),console.log(f.render()),console.log(),console.log(c.muted(" /memory set <k> <v> \u2014 Store a memory")),console.log(c.muted(" /memory del <key> \u2014 Delete a memory")),console.log(c.muted(" /memory search <q> \u2014 Search memories")),console.log(c.muted(" /memory clear \u2014 Clear all")),console.log()}break}case"/alias":{let y=_[1],v=_.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],x=v.slice(1).join(" ");Pc(b,x),console.log(Z(`Alias set: ${b} \u2192 ${x}`))}else console.log(j("Usage: /alias set <name> <expansion>"));break}case"del":case"remove":{if(v[0]){let b=Oc(v[0]);console.log(b?Z(`Alias removed: ${v[0]}`):j(`Alias not found: ${v[0]}`))}else console.log(j("Usage: /alias del <name>"));break}default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Aliases")}`),console.log(),console.log(Ic()),console.log(),console.log(c.muted(" /alias set <name> <cmd> \u2014 Create alias")),console.log(c.muted(" /alias del <name> \u2014 Remove alias")),console.log()}break}case"/doctor":{let y=new Ve("Running diagnostics");y.start();let v=await Pi({ollamaHost:e.ollamaHost,model:t.getModel(),provider:e.provider,apiUrl:e.apiUrl});y.stop(),console.log(Oi(v));break}case"/plugins":{let y=_[1],v=_.slice(2).join(" ");switch(y){case"enable":v?($i(v),console.log(Z(`Plugin "${v}" enabled`))):console.log(j("Usage: /plugins enable <name>"));break;case"disable":v?(Ci(v),console.log(j(`Plugin "${v}" disabled`))):console.log(j("Usage: /plugins disable <name>"));break;default:Fs(),console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Plugins")}`),console.log(),console.log(Ti()),console.log(),console.log(c.muted(" /plugins enable <name> \u2014 Enable plugin")),console.log(c.muted(" /plugins disable <name> \u2014 Disable plugin")),console.log(c.muted(" Directory: ~/.hablas/plugins/")),console.log()}break}case"/agents":{let y=_[1];if(y==="on")e.agents.enabled=!0,console.log(Z("Multi-agent orchestration enabled"));else if(y==="off")e.agents.enabled=!1,console.log(Z("Multi-agent orchestration disabled"));else if(y==="status")console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Multi-Agent System")}`),console.log(` Status: ${e.agents.enabled?c.success("enabled"):c.muted("disabled")}`),console.log(` Orchestration: ${e.agents.orchestration}`),console.log(` Max concurrent: ${e.agents.maxConcurrent}`),console.log(),console.log(` ${c.strong("Team:")}`),console.log(Ii()),console.log();else if(y==="models"){let v=qn();console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Agent Models")}`),console.log();for(let b of Se){let x=v[b.role];console.log(x?` ${c.primary(b.name.padEnd(8))} \u2192 ${c.highlight(x.model)}${x.temperature!==void 0?c.muted(` (temp: ${x.temperature})`):""}`:` ${c.primary(b.name.padEnd(8))} \u2192 ${c.muted("(default)")}`)}console.log(),console.log(c.muted(` Config: ${Kc()}`)),console.log(c.muted(" Edit the file to change models per agent.")),console.log()}else console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Multi-Agent System")}: ${e.agents.enabled?c.success("ON"):c.muted("OFF")}`),console.log(),console.log(c.muted(" /agents on \u2014 Enable multi-agent orchestration")),console.log(c.muted(" /agents off \u2014 Disable multi-agent orchestration")),console.log(c.muted(" /agents status \u2014 Show agent details")),console.log(c.muted(" /agents models \u2014 Show model per agent")),console.log(c.muted(" /team \u2014 Show team roster")),console.log();break}case"/security":{console.log(),console.log(` ${c.accent("\u{1F512}")} Running security scan...`);let y=Wi(o);console.log(Gi(y));break}case"/git":{if(_[1]==="status")try{let{getGitStatus:v,formatGitStatus:b}=await Promise.resolve().then(()=>(vn(),Gn)),x=await v(o);x?(console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Git Status")}`),console.log(b(x)),console.log()):console.log(j("Not a git repository"))}catch{console.log(j("Git not available"))}else console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Git Intelligence")}`),console.log(),console.log(c.muted(" /git status \u2014 Show git status")),console.log(c.muted(" hablas commit \u2014 Smart commit message")),console.log(c.muted(" hablas pr \u2014 Generate PR description")),console.log(c.muted(" hablas changelog \u2014 Generate changelog")),console.log();break}case"/workspace":{let y=Us(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Workspace Information")}`),console.log(),console.log(Yi(y)),console.log();break}case"/stats":{let{loadStats:y,formatStats:v}=await Promise.resolve().then(()=>(Wn(),Ki)),b=y();console.log(v(b));break}case"/context":{if(!m){console.log(j("Shared context not available"));break}let y=_[1],v=_.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],x=v.slice(1).join(" ");m.set(b,x),console.log(Z(`Context stored: ${b}`))}else console.log(j("Usage: /context set <key> <value>"));break}case"get":{if(v[0]){let b=m.get(v[0]);b!==void 0?(console.log(),console.log(` ${c.accent("\u25C6")} ${c.strong(v[0])}: ${b}`),console.log()):console.log(j(`Context key not found: ${v[0]}`))}else console.log(j("Usage: /context get <key>"));break}case"del":case"delete":{if(v[0]){let b=m.delete(v[0]);console.log(b?Z(`Context deleted: ${v[0]}`):j(`Context key not found: ${v[0]}`))}else console.log(j("Usage: /context del <key>"));break}case"decisions":{let b=m.getDecisions();if(b.length===0)console.log(le("No decisions logged yet"));else{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Decisions")}`),console.log();for(let x of b)console.log(` ${c.muted(x.timestamp)} ${c.primary(x.by)}: ${x.decision}`),x.rationale&&console.log(` ${c.muted(x.rationale)}`);console.log()}break}case"clear":m.clear(),console.log(Z("Shared context cleared"));break;default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Shared Context")}`),console.log(),console.log(m.render()),console.log(),console.log(c.muted(" /context set <k> <v> \u2014 Store a context entry")),console.log(c.muted(" /context get <key> \u2014 Get a context entry")),console.log(c.muted(" /context del <key> \u2014 Delete a context entry")),console.log(c.muted(" /context decisions \u2014 Show logged decisions")),console.log(c.muted(" /context clear \u2014 Clear all context")),console.log()}break}case"/plan":{if(!p){console.log(j("Plan manager not available"));break}let y=_[1],v=_.slice(2).join(" ");switch(y){case"status":{let x=p.getActivePlan();if(!x){console.log(le("No active plan"));break}let $=p.getProgress();console.log(Vn(x,{percent:$.percentage,done:$.done,total:$.total}));break}case"finish":{if(v){p.finishTask(v),console.log(Z(`Task finished: ${v}`));let x=p.getProgress();console.log(c.muted(` Progress: ${x.done}/${x.total} (${x.percentage}%)`))}else console.log(j("Usage: /plan finish <task_id>"));break}case"reset":{p.reset(),console.log(Z("Plan manager reset"));break}case"next":{let x=p.getNextTask();console.log(x?le(`Next task: [${x.task_id}] ${x.description} \u2192 @${x.assignee}`):le("No pending tasks"));break}default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Plan Manager")}`),console.log();let b=p.getActivePlan();if(b){let x=p.getProgress();console.log(` Active plan: ${b.title} (${x.percentage}% done)`),console.log(` Tasks: ${x.done}/${x.total}`)}else console.log(c.muted(" No active plan"));console.log(),console.log(c.muted(" /plan status \u2014 Show active plan with progress")),console.log(c.muted(" /plan finish <id> \u2014 Mark a task as finished")),console.log(c.muted(" /plan next \u2014 Show next pending task")),console.log(c.muted(" /plan reset \u2014 Reset plan manager")),console.log()}break}case"/learn":{if(!f||!A){console.log(j('Usage: /learn "always use tabs" or /learn "our API uses camelCase"'));break}if(f.set(`user-pref: ${A.slice(0,50)}`,A,{category:"user-pref",importance:9,createdBy:"user",tags:["user-pref","learned"]}),!(i.getMessages()[0]?.content||"").includes(A)){let v=await Qt(o,e),b=u?.getActive(),x=b?b.systemPrompt:Yn,$=Zt(x,v,f,m);i.updateSystemPrompt($)}console.log(Z(`Learned: "${A}"`)),console.log(c.muted(" This will be remembered across sessions and injected into every prompt."));break}case"/test":{let y=so(o);if(y==="unknown"&&!A){console.log(j("No test framework detected. Install jest, vitest, pytest, etc."));break}console.log(le(`Running tests (${y})...`));let v=_u(o,A==="--fix"?void 0:A||void 0);if(console.log(),console.log(ku(v)),console.log(),!v.passed&&A==="--fix"){console.log(le("Tests failed \u2014 adding fix request to conversation..."));let b=Au(v);i.addUserMessage(b),console.log(le("Type your next message or let the agent work on the fix."))}break}case"/checkpoint":{let y=_[1],v=_.slice(2).join(" ");if(y==="save"){let b=v||`Checkpoint at turn ${l}`,x=g?.getModifiedFiles?.()||[],$=await Tu(o,b,x);console.log(Z(`Checkpoint saved: ${$.id} "${b}" (${$.fileCount} files)`))}else if(y==="list"){let b=Eu(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Checkpoints")}`),console.log(),console.log(Ou(b)),console.log()}else if(y==="restore"){if(!v){console.log(j("Usage: /checkpoint restore <id>"));break}let b=await Ru(o,v);b.success?console.log(Z(`Restored checkpoint: ${v} (${b.filesRestored} files)`)):console.log(He(b.error||"Restore failed"))}else y==="delete"?v&&Pu(o,v)?console.log(Z(`Deleted checkpoint: ${v}`)):console.log(j("Checkpoint not found")):(console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Checkpoint System")}`),console.log(),console.log(c.muted(' /checkpoint save "label" \u2014 Save current state')),console.log(c.muted(" /checkpoint list \u2014 List saved checkpoints")),console.log(c.muted(" /checkpoint restore <id> \u2014 Restore a checkpoint")),console.log(c.muted(" /checkpoint delete <id> \u2014 Delete a checkpoint")),console.log());break}case"/compare":{let y=_.slice(1);if(y.length===2)try{let v=await Ft.readFile($e.resolve(o,y[0]),"utf-8"),b=await Ft.readFile($e.resolve(o,y[1]),"utf-8"),{generateDiff:x}=await Promise.resolve().then(()=>(co(),Bu)),$=x(y[0]+" vs "+y[1],v,b);console.log(eo($))}catch(v){console.log(He(`Compare failed: ${v.message}`))}else if(y.length===1&&y[0].startsWith("HEAD"))try{let{execSync:v}=await import("child_process"),b=v(`git diff ${y[0]}`,{cwd:o,encoding:"utf-8",timeout:1e4});console.log(eo(b||"(no changes)"))}catch(v){console.log(He(`Git diff failed: ${v.message}`))}else console.log(c.muted(" Usage: /compare file1.ts file2.ts or /compare HEAD~1"));break}case"/cost":{let y=Kn(),v="current";console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Session Cost & Usage")}`),console.log(),console.log(` Session duration: ${v} min`),console.log(` Messages: ${y.totalMessages}`),console.log(` Tool calls: ${y.totalToolCalls}`),console.log(` Tokens used: ${y.totalTokensUsed.toLocaleString()}`),console.log();let b=Object.entries(y.agentUsage);if(b.length>0){console.log(" Agent usage:");for(let[x,$]of b.sort((E,M)=>M[1]-E[1]))console.log(` @${x}: ${$} invocations`)}console.log();break}case"/delegate":{if(!e.agents.enabled){console.log(j("Multi-agent system is disabled. Enable with /agents on"));break}let y=_[1]?.toLowerCase(),v=_.slice(2).join(" ");if(!y||!v){console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Delegate Task to Agent")}`),console.log(),console.log(c.muted(" Usage: /delegate <agent> <task description>")),console.log(),console.log(c.muted(" Agents:")),console.log(` ${c.product("emma")} \u2014 Product Manager`),console.log(` ${c.architect("bob")} \u2014 Architect`),console.log(` ${c.engineer("alex")} \u2014 Engineer`),console.log(` ${c.analyst("david")} \u2014 Data Analyst`),console.log(),console.log(c.muted(" Example: /delegate alex create a login component")),console.log();break}let b=["emma","bob","alex","david","hablas"];if(!b.includes(y)){console.log(j(`Unknown agent: "${y}". Valid: ${b.join(", ")}`));break}let x=Se.find($=>$.role===y);if(x){if(!w){console.log(j("Agent runner not initialized. Cannot delegate."));break}console.log(fu("Hablas",x.name,x.title,v)),console.log(Jt(x.name,x.title));let $=s.getOllamaTools(),E=await w.runAgent(y,v,void 0,$);E.success&&E.output?(console.log(Xt(E.output)),i.addAssistantMessage(`[@${x.name}]: ${E.output}`)):E.error?console.log(j(`${x.name} failed: ${E.error}`)):console.log(le(`${x.name} completed without output.`))}break}case"/session":{let y=_[1],v=_.slice(2).join(" "),b=$e.join(fo.homedir(),".hablas","sessions");if(y==="save"){let x=v||`session_${Date.now()}`;try{we.existsSync(b)||we.mkdirSync(b,{recursive:!0});let $=i.toJSON(),E=$e.join(b,`${x.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);we.writeFileSync(E,$,"utf-8"),console.log(Z(`Session saved: "${x}"`))}catch($){console.log(He(`Save failed: ${$.message}`))}}else if(y==="list")try{if(!we.existsSync(b)){console.log(le("No saved sessions"));break}let x=we.readdirSync(b).filter($=>$.endsWith(".json"));console.log();for(let $ of x){let E=we.statSync($e.join(b,$));console.log(` ${$.replace(".json","")} (${new Date(E.mtime).toLocaleString()})`)}console.log()}catch{console.log(le("No saved sessions"))}else console.log(),console.log(c.muted(' /session save "label" \u2014 Save current conversation')),console.log(c.muted(" /session list \u2014 List saved sessions")),console.log();break}case"/team":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(Tt(),Nt));if(!y){console.log(j("Team mode is not active. Use hablas --team to start."));break}let v=y.getLocalState(),b=Math.min(process.stdout.columns-4,80);console.log(`
|
|
256
|
-
`+c.border("\u2554"+"\u2550".repeat(b-2)+"\u2557")),console.log(c.border("\u2551")+" ".repeat(Math.floor((b-22)/2))+c.strong("HABLAS COLLABORATION SYNC")+" ".repeat(b-2-25-Math.floor((b-22)/2))+c.border("\u2551")),console.log(c.border("\u2560"+"\u2550".repeat(b-2)+"\u2563")),console.log(c.border("\u2551")+` ${c.strong("My Identity:")} ${c.highlight(`@${v.my_username}`)}`+" ".repeat(Math.max(1,b-21-(v.my_username?.length||0)))+c.border("\u2551")),console.log(c.border("\u2551")+` ${c.strong("Room Fingerprint:")} ${c.muted(v.project_team_token?.slice(0,12))}...`+" ".repeat(Math.max(1,b-34))+c.border("\u2551")),console.log(c.border("\u2551")+` ${c.strong("Status:")} ${c.success("\u25CF ACTIVE")}`+" ".repeat(Math.max(1,b-31))+c.border("\u2551")),console.log(c.border("\u2560"+"\u2550".repeat(b-2)+"\u2563")),console.log(c.border("\u2551")+` ${c.strong("Teammates Online:")}`+" ".repeat(Math.max(1,b-21))+c.border("\u2551"));let
|
|
255
|
+
`),console.log(c.muted(" ~/.hablas/config.json")),console.log();break;case"/mindset":{if(!u){console.log(j("Mindset system not available"));break}if($)if(u.setActive($)){let v=u.getActive(),b=await Qt(o,e),x=Zt(v.systemPrompt,b,f,m);i.updateSystemPrompt(x),console.log(X(`Mindset: ${v.name} \u2014 ${v.description}`))}else{let v=u.listNames().join(", ");console.log(Be(`Unknown mindset: "${$}"`,`Available: ${v}`))}else{let y=u.getActive();y&&console.log(le(`Current mindset: ${y.name} \u2014 ${y.description}`)),console.log(c.muted(" Usage: /mindset <name>")),console.log(c.muted(" See /mindsets for available options"))}break}case"/mindsets":{if(!u){console.log(j("Mindset system not available"));break}let y=u.list(),v=u.getActiveName();console.log();for(let b of y){let A=b.name===v?c.success(" \u25CF active"):"";console.log(` ${c.accent("\u25C6")} ${c.primary(b.name)}${A}`),console.log(` ${c.muted(b.description)}`)}console.log(),console.log(c.muted(" Switch: /mindset <name>")),console.log();break}case"/task":{if(!d){console.log(j("Task queue not available"));break}let y=_[1],v=_.slice(2).join(" ");switch(y){case"add":if(v){let b=d.add(v);console.log(X(`Task #${b.id} added: ${v}`))}else console.log(j("Usage: /task add <description>"));break;case"list":console.log(),console.log(d.render()),console.log();break;case"done":{let b=parseInt(v);b?(d.complete(b),console.log(X(`Task #${b} marked as done`))):console.log(j("Usage: /task done <id>"));break}case"fail":{let b=parseInt(v);b?(d.fail(b,"Manually marked as failed"),console.log(j(`Task #${b} marked as failed`))):console.log(j("Usage: /task fail <id>"));break}case"clear":d.clear(),console.log(X("Task queue cleared"));break;default:console.log(),console.log(d.render()),console.log(),console.log(c.muted(" /task add <desc> \u2014 Add a task")),console.log(c.muted(" /task list \u2014 Show all tasks")),console.log(c.muted(" /task done <id> \u2014 Mark task as done")),console.log(c.muted(" /task fail <id> \u2014 Mark task as failed")),console.log(c.muted(" /task clear \u2014 Clear all tasks")),console.log()}break}case"/addmodel":{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Add Custom API Provider")}`),console.log();let v=(await a.prompt(` ${c.muted("Provider name (e.g. OpenAI, Groq):")} `)).trim();if(!v){console.log(j("Cancelled \u2014 name is required"));break}let x=(await a.prompt(` ${c.muted("API URL (e.g. https://api.openai.com/v1):")} `)).trim();if(!x){console.log(j("Cancelled \u2014 URL is required"));break}let E=(await a.prompt(` ${c.muted("API Key (leave empty if none):")} `)).trim(),C=(await a.prompt(` ${c.muted("Default model ID (e.g. gpt-4o):")} `)).trim()||"default",F={name:v,apiUrl:x,apiKey:E,models:[C],defaultModel:C,addedAt:new Date().toISOString()};tt(F),console.log(),console.log(X(`Provider "${v}" saved!`)),console.log(c.muted(` Use: /usemodel ${v}`)),console.log();break}case"/listmodels":{let y=zt();console.log(),console.log(Tc(y.providers,y.activeProvider));break}case"/removemodel":{let y=$.trim();if(!y){console.log(j("Usage: /removemodel <provider-name>"));break}if(Ac(y))console.log(X(`Provider "${y}" removed`));else{console.log(j(`Provider "${y}" not found`));let b=Ps();b.length>0&&console.log(c.muted(` Available: ${b.map(x=>x.name).join(", ")}`))}break}case"/usemodel":{let y=$.trim();if(!y){console.log(j("Usage: /usemodel <provider-name> [model-id]"));let F=Ps();F.length>0&&console.log(c.muted(` Available: ${F.map(H=>H.name).join(", ")}`));break}let v=y.split(/\s+/),b=v[0],x=v[1],A=$c(b);if(!A){console.log(j(`Provider "${b}" not found`));let F=Ps();F.length>0&&console.log(c.muted(` Available: ${F.map(H=>H.name).join(", ")}`));break}e.provider="custom",e.apiUrl=A.apiUrl,e.apiKey=A.apiKey,e.model=x||A.defaultModel;let E=Ne(e);h&&h(E),Cc(A.name,e.model),console.log(X(`Switched to ${A.name} \xB7 Model: ${e.model}`));let M=new Ve("Testing");M.start();let C=await E.checkConnection();M.stop(C?"connected":void 0),C||console.log(j("Connection test failed \u2014 check URL and key"));break}case"/provider":{let y=_[1],v=_.slice(2).join(" ");if(!y){let b=Rs(e);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Provider")}: ${b}`),console.log(` ${c.muted("Model")}: ${c.highlight(t.getModel())}`),e.provider==="custom"?(console.log(` ${c.muted("API URL")}: ${e.apiUrl}`),console.log(` ${c.muted("API Key")}: ${e.apiKey?"***"+e.apiKey.slice(-4):"not set"}`)):console.log(` ${c.muted("Host")}: ${e.ollamaHost}`),console.log(),console.log(c.muted(" /provider ollama \u2014 Switch to local Ollama")),console.log(c.muted(" /provider nvidia <key> \u2014 Switch to NVIDIA NIM")),console.log(c.muted(" /provider custom <url> [key] \u2014 Switch to custom API")),console.log(c.muted(" /provider test \u2014 Test current connection")),console.log();break}switch(y){case"ollama":{e.provider="ollama",e.apiUrl="",e.apiKey="";let b=Ne(e);h&&h(b),console.log(X("Switched to Ollama (local)"));break}case"nvidia":{let b=_[2];if(!b&&!e.apiKey){console.log(j("Usage: /provider nvidia <api-key>")),console.log(c.muted(" Get your key at: https://build.nvidia.com/"));break}e.provider="nvidia",e.apiUrl=Lt.apiUrl,b&&(e.apiKey=b),(!e.model||!Lt.models.includes(e.model))&&(e.model=Lt.defaultModel);let x=Ne(e);h&&h(x),console.log(X(`Switched to NVIDIA NIM \xB7 Model: ${e.model}`)),console.log(c.muted(` Available models: ${Lt.models.length}`));let A=new Ve("Testing NVIDIA connection");A.start();let E=await x.checkConnection();A.stop(E?"connected":void 0),E||(console.log(j("Connection test failed \u2014 check your API key")),console.log(c.muted(" Get key: https://build.nvidia.com/")));break}case"custom":{let b=_[2],x=_[3];if(!b){console.log(j("Usage: /provider custom <api-url> [api-key]")),console.log(c.muted(" Example: /provider custom https://api.openai.com/v1 sk-..."));break}e.provider="custom",e.apiUrl=b,x&&(e.apiKey=x);let A=Ne(e);h&&h(A),console.log(X(`Switched to Custom API: ${b}`)),!x&&!e.apiKey&&console.log(j("No API key set. Use: /provider custom <url> <key>"));break}case"test":{let b=new Ve("Testing connection");b.start();let x=await t.checkConnection();if(b.stop(x?"connected":void 0),x){let A=await t.listModels();console.log(X(`Connected! ${A.length} models available.`)),A.length>0&&console.log(c.muted(` Models: ${A.slice(0,5).join(", ")}${A.length>5?"...":""}`))}else console.log($e("Connection failed"));break}case"key":{v?(e.apiKey=_[2],t instanceof Vt&&t.setApiKey(e.apiKey),console.log(X("API key updated"))):console.log(j("Usage: /provider key <api-key>"));break}default:console.log(Be(`Unknown: /provider ${y}`,"Type /provider for help"))}break}case"/memory":{if(!f){console.log(j("Project memory not available"));break}let y=_[1],v=_.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],x=v.slice(1).join(" ");f.set(b,x),console.log(X(`Memory stored: ${b}`));let A=u?.getActive(),E=A?A.systemPrompt:Yn,M=await Qt(o,e);i.updateSystemPrompt(Zt(E,M,f,m))}else console.log(j("Usage: /memory set <key> <value>"));break}case"del":case"delete":{if(v[0]){let b=f.delete(v[0]);console.log(b?X(`Memory deleted: ${v[0]}`):j(`Memory key not found: ${v[0]}`))}else console.log(j("Usage: /memory del <key>"));break}case"search":{if(v[0]){let b=f.search(v.join(" "));b.length>0?(console.log(),b.forEach(x=>console.log(` \xB7 ${x.entry.key}: ${x.entry.value}`)),console.log()):console.log(le("No matching memories found"))}else console.log(j("Usage: /memory search <query>"));break}case"clear":f.clear(),console.log(X("Project memory cleared"));break;default:console.log(),console.log(f.render()),console.log(),console.log(c.muted(" /memory set <k> <v> \u2014 Store a memory")),console.log(c.muted(" /memory del <key> \u2014 Delete a memory")),console.log(c.muted(" /memory search <q> \u2014 Search memories")),console.log(c.muted(" /memory clear \u2014 Clear all")),console.log()}break}case"/alias":{let y=_[1],v=_.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],x=v.slice(1).join(" ");Pc(b,x),console.log(X(`Alias set: ${b} \u2192 ${x}`))}else console.log(j("Usage: /alias set <name> <expansion>"));break}case"del":case"remove":{if(v[0]){let b=Oc(v[0]);console.log(b?X(`Alias removed: ${v[0]}`):j(`Alias not found: ${v[0]}`))}else console.log(j("Usage: /alias del <name>"));break}default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Aliases")}`),console.log(),console.log(Ic()),console.log(),console.log(c.muted(" /alias set <name> <cmd> \u2014 Create alias")),console.log(c.muted(" /alias del <name> \u2014 Remove alias")),console.log()}break}case"/doctor":{let y=new Ve("Running diagnostics");y.start();let v=await Pi({ollamaHost:e.ollamaHost,model:t.getModel(),provider:e.provider,apiUrl:e.apiUrl});y.stop(),console.log(Oi(v));break}case"/plugins":{let y=_[1],v=_.slice(2).join(" ");switch(y){case"enable":v?($i(v),console.log(X(`Plugin "${v}" enabled`))):console.log(j("Usage: /plugins enable <name>"));break;case"disable":v?(Ci(v),console.log(j(`Plugin "${v}" disabled`))):console.log(j("Usage: /plugins disable <name>"));break;default:Fs(),console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Plugins")}`),console.log(),console.log(Ti()),console.log(),console.log(c.muted(" /plugins enable <name> \u2014 Enable plugin")),console.log(c.muted(" /plugins disable <name> \u2014 Disable plugin")),console.log(c.muted(" Directory: ~/.hablas/plugins/")),console.log()}break}case"/agents":{let y=_[1];if(y==="on")e.agents.enabled=!0,console.log(X("Multi-agent orchestration enabled"));else if(y==="off")e.agents.enabled=!1,console.log(X("Multi-agent orchestration disabled"));else if(y==="status")console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Multi-Agent System")}`),console.log(` Status: ${e.agents.enabled?c.success("enabled"):c.muted("disabled")}`),console.log(` Orchestration: ${e.agents.orchestration}`),console.log(` Max concurrent: ${e.agents.maxConcurrent}`),console.log(),console.log(` ${c.strong("Team:")}`),console.log(Ii()),console.log();else if(y==="models"){let v=qn();console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Agent Models")}`),console.log();for(let b of Se){let x=v[b.role];console.log(x?` ${c.primary(b.name.padEnd(8))} \u2192 ${c.highlight(x.model)}${x.temperature!==void 0?c.muted(` (temp: ${x.temperature})`):""}`:` ${c.primary(b.name.padEnd(8))} \u2192 ${c.muted("(default)")}`)}console.log(),console.log(c.muted(` Config: ${Kc()}`)),console.log(c.muted(" Edit the file to change models per agent.")),console.log()}else console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Multi-Agent System")}: ${e.agents.enabled?c.success("ON"):c.muted("OFF")}`),console.log(),console.log(c.muted(" /agents on \u2014 Enable multi-agent orchestration")),console.log(c.muted(" /agents off \u2014 Disable multi-agent orchestration")),console.log(c.muted(" /agents status \u2014 Show agent details")),console.log(c.muted(" /agents models \u2014 Show model per agent")),console.log(c.muted(" /team \u2014 Show team roster")),console.log();break}case"/security":{console.log(),console.log(` ${c.accent("\u{1F512}")} Running security scan...`);let y=Wi(o);console.log(Gi(y));break}case"/git":{if(_[1]==="status")try{let{getGitStatus:v,formatGitStatus:b}=await Promise.resolve().then(()=>(vn(),Gn)),x=await v(o);x?(console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Git Status")}`),console.log(b(x)),console.log()):console.log(j("Not a git repository"))}catch{console.log(j("Git not available"))}else console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Git Intelligence")}`),console.log(),console.log(c.muted(" /git status \u2014 Show git status")),console.log(c.muted(" hablas commit \u2014 Smart commit message")),console.log(c.muted(" hablas pr \u2014 Generate PR description")),console.log(c.muted(" hablas changelog \u2014 Generate changelog")),console.log();break}case"/workspace":{let y=Us(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Workspace Information")}`),console.log(),console.log(Yi(y)),console.log();break}case"/stats":{let{loadStats:y,formatStats:v}=await Promise.resolve().then(()=>(Wn(),Ki)),b=y();console.log(v(b));break}case"/context":{if(!m){console.log(j("Shared context not available"));break}let y=_[1],v=_.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],x=v.slice(1).join(" ");m.set(b,x),console.log(X(`Context stored: ${b}`))}else console.log(j("Usage: /context set <key> <value>"));break}case"get":{if(v[0]){let b=m.get(v[0]);b!==void 0?(console.log(),console.log(` ${c.accent("\u25C6")} ${c.strong(v[0])}: ${b}`),console.log()):console.log(j(`Context key not found: ${v[0]}`))}else console.log(j("Usage: /context get <key>"));break}case"del":case"delete":{if(v[0]){let b=m.delete(v[0]);console.log(b?X(`Context deleted: ${v[0]}`):j(`Context key not found: ${v[0]}`))}else console.log(j("Usage: /context del <key>"));break}case"decisions":{let b=m.getDecisions();if(b.length===0)console.log(le("No decisions logged yet"));else{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Decisions")}`),console.log();for(let x of b)console.log(` ${c.muted(x.timestamp)} ${c.primary(x.by)}: ${x.decision}`),x.rationale&&console.log(` ${c.muted(x.rationale)}`);console.log()}break}case"clear":m.clear(),console.log(X("Shared context cleared"));break;default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Shared Context")}`),console.log(),console.log(m.render()),console.log(),console.log(c.muted(" /context set <k> <v> \u2014 Store a context entry")),console.log(c.muted(" /context get <key> \u2014 Get a context entry")),console.log(c.muted(" /context del <key> \u2014 Delete a context entry")),console.log(c.muted(" /context decisions \u2014 Show logged decisions")),console.log(c.muted(" /context clear \u2014 Clear all context")),console.log()}break}case"/plan":{if(!p){console.log(j("Plan manager not available"));break}let y=_[1],v=_.slice(2).join(" ");switch(y){case"status":{let x=p.getActivePlan();if(!x){console.log(le("No active plan"));break}let A=p.getProgress();console.log(Vn(x,{percent:A.percentage,done:A.done,total:A.total}));break}case"finish":{if(v){p.finishTask(v),console.log(X(`Task finished: ${v}`));let x=p.getProgress();console.log(c.muted(` Progress: ${x.done}/${x.total} (${x.percentage}%)`))}else console.log(j("Usage: /plan finish <task_id>"));break}case"reset":{p.reset(),console.log(X("Plan manager reset"));break}case"next":{let x=p.getNextTask();console.log(x?le(`Next task: [${x.task_id}] ${x.description} \u2192 @${x.assignee}`):le("No pending tasks"));break}default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Plan Manager")}`),console.log();let b=p.getActivePlan();if(b){let x=p.getProgress();console.log(` Active plan: ${b.title} (${x.percentage}% done)`),console.log(` Tasks: ${x.done}/${x.total}`)}else console.log(c.muted(" No active plan"));console.log(),console.log(c.muted(" /plan status \u2014 Show active plan with progress")),console.log(c.muted(" /plan finish <id> \u2014 Mark a task as finished")),console.log(c.muted(" /plan next \u2014 Show next pending task")),console.log(c.muted(" /plan reset \u2014 Reset plan manager")),console.log()}break}case"/learn":{if(!f||!$){console.log(j('Usage: /learn "always use tabs" or /learn "our API uses camelCase"'));break}if(f.set(`user-pref: ${$.slice(0,50)}`,$,{category:"user-pref",importance:9,createdBy:"user",tags:["user-pref","learned"]}),!(i.getMessages()[0]?.content||"").includes($)){let v=await Qt(o,e),b=u?.getActive(),x=b?b.systemPrompt:Yn,A=Zt(x,v,f,m);i.updateSystemPrompt(A)}console.log(X(`Learned: "${$}"`)),console.log(c.muted(" This will be remembered across sessions and injected into every prompt."));break}case"/test":{let y=so(o);if(y==="unknown"&&!$){console.log(j("No test framework detected. Install jest, vitest, pytest, etc."));break}console.log(le(`Running tests (${y})...`));let v=_u(o,$==="--fix"?void 0:$||void 0);if(console.log(),console.log(ku(v)),console.log(),!v.passed&&$==="--fix"){console.log(le("Tests failed \u2014 adding fix request to conversation..."));let b=Au(v);i.addUserMessage(b),console.log(le("Type your next message or let the agent work on the fix."))}break}case"/checkpoint":{let y=_[1],v=_.slice(2).join(" ");if(y==="save"){let b=v||`Checkpoint at turn ${l}`,x=g?.getModifiedFiles?.()||[],A=await Tu(o,b,x);console.log(X(`Checkpoint saved: ${A.id} "${b}" (${A.fileCount} files)`))}else if(y==="list"){let b=Eu(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Checkpoints")}`),console.log(),console.log(Ou(b)),console.log()}else if(y==="restore"){if(!v){console.log(j("Usage: /checkpoint restore <id>"));break}let b=await Ru(o,v);b.success?console.log(X(`Restored checkpoint: ${v} (${b.filesRestored} files)`)):console.log($e(b.error||"Restore failed"))}else y==="delete"?v&&Pu(o,v)?console.log(X(`Deleted checkpoint: ${v}`)):console.log(j("Checkpoint not found")):(console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Checkpoint System")}`),console.log(),console.log(c.muted(' /checkpoint save "label" \u2014 Save current state')),console.log(c.muted(" /checkpoint list \u2014 List saved checkpoints")),console.log(c.muted(" /checkpoint restore <id> \u2014 Restore a checkpoint")),console.log(c.muted(" /checkpoint delete <id> \u2014 Delete a checkpoint")),console.log());break}case"/compare":{let y=_.slice(1);if(y.length===2)try{let v=await Ft.readFile(Ae.resolve(o,y[0]),"utf-8"),b=await Ft.readFile(Ae.resolve(o,y[1]),"utf-8"),{generateDiff:x}=await Promise.resolve().then(()=>(co(),Bu)),A=x(y[0]+" vs "+y[1],v,b);console.log(eo(A))}catch(v){console.log($e(`Compare failed: ${v.message}`))}else if(y.length===1&&y[0].startsWith("HEAD"))try{let{execSync:v}=await import("child_process"),b=v(`git diff ${y[0]}`,{cwd:o,encoding:"utf-8",timeout:1e4});console.log(eo(b||"(no changes)"))}catch(v){console.log($e(`Git diff failed: ${v.message}`))}else console.log(c.muted(" Usage: /compare file1.ts file2.ts or /compare HEAD~1"));break}case"/cost":{let y=Kn(),v="current";console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Session Cost & Usage")}`),console.log(),console.log(` Session duration: ${v} min`),console.log(` Messages: ${y.totalMessages}`),console.log(` Tool calls: ${y.totalToolCalls}`),console.log(` Tokens used: ${y.totalTokensUsed.toLocaleString()}`),console.log();let b=Object.entries(y.agentUsage);if(b.length>0){console.log(" Agent usage:");for(let[x,A]of b.sort((E,M)=>M[1]-E[1]))console.log(` @${x}: ${A} invocations`)}console.log();break}case"/delegate":{if(!e.agents.enabled){console.log(j("Multi-agent system is disabled. Enable with /agents on"));break}let y=_[1]?.toLowerCase(),v=_.slice(2).join(" ");if(!y||!v){console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Delegate Task to Agent")}`),console.log(),console.log(c.muted(" Usage: /delegate <agent> <task description>")),console.log(),console.log(c.muted(" Agents:")),console.log(` ${c.product("emma")} \u2014 Product Manager`),console.log(` ${c.architect("bob")} \u2014 Architect`),console.log(` ${c.engineer("alex")} \u2014 Engineer`),console.log(` ${c.analyst("david")} \u2014 Data Analyst`),console.log(),console.log(c.muted(" Example: /delegate alex create a login component")),console.log();break}let b=["emma","bob","alex","david","hablas"];if(!b.includes(y)){console.log(j(`Unknown agent: "${y}". Valid: ${b.join(", ")}`));break}let x=Se.find(A=>A.role===y);if(x){if(!w){console.log(j("Agent runner not initialized. Cannot delegate."));break}console.log(fu("Hablas",x.name,x.title,v)),console.log(Jt(x.name,x.title));let A=s.getOllamaTools(),E=await w.runAgent(y,v,void 0,A);E.success&&E.output?(console.log(Xt(E.output)),i.addAssistantMessage(`[@${x.name}]: ${E.output}`)):E.error?console.log(j(`${x.name} failed: ${E.error}`)):console.log(le(`${x.name} completed without output.`))}break}case"/session":{let y=_[1],v=_.slice(2).join(" "),b=Ae.join(fo.homedir(),".hablas","sessions");if(y==="save"){let x=v||`session_${Date.now()}`;try{ye.existsSync(b)||ye.mkdirSync(b,{recursive:!0});let A=i.toJSON(),E=Ae.join(b,`${x.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);ye.writeFileSync(E,A,"utf-8"),console.log(X(`Session saved: "${x}"`))}catch(A){console.log($e(`Save failed: ${A.message}`))}}else if(y==="list")try{if(!ye.existsSync(b)){console.log(le("No saved sessions"));break}let x=ye.readdirSync(b).filter(A=>A.endsWith(".json"));console.log();for(let A of x){let E=ye.statSync(Ae.join(b,A));console.log(` ${A.replace(".json","")} (${new Date(E.mtime).toLocaleString()})`)}console.log()}catch{console.log(le("No saved sessions"))}else if(y==="load"){let x=v;if(!x){console.log($e("Please specify the session label to load: /session load <label>"));break}try{let A=Ae.join(b,`${x.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);if(!ye.existsSync(A)){console.log($e(`Session file not found: ${x}`));break}let E=ye.readFileSync(A,"utf-8");i.fromJSON(E),console.log(X(`Session successfully loaded: "${x}"`))}catch(A){console.log($e(`Load failed: ${A.message}`))}}else console.log(),console.log(c.muted(' /session save "label" \u2014 Save current conversation')),console.log(c.muted(" /session list \u2014 List saved sessions")),console.log(c.muted(' /session load "label" \u2014 Load saved conversation')),console.log();break}case"/team":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(Tt(),Nt));if(!y){console.log(j("Team mode is not active. Use hablas --team to start."));break}let v=y.getLocalState(),b=Math.min(process.stdout.columns-4,80);console.log(`
|
|
256
|
+
`+c.border("\u2554"+"\u2550".repeat(b-2)+"\u2557")),console.log(c.border("\u2551")+" ".repeat(Math.floor((b-22)/2))+c.strong("HABLAS COLLABORATION SYNC")+" ".repeat(b-2-25-Math.floor((b-22)/2))+c.border("\u2551")),console.log(c.border("\u2560"+"\u2550".repeat(b-2)+"\u2563")),console.log(c.border("\u2551")+` ${c.strong("My Identity:")} ${c.highlight(`@${v.my_username}`)}`+" ".repeat(Math.max(1,b-21-(v.my_username?.length||0)))+c.border("\u2551")),console.log(c.border("\u2551")+` ${c.strong("Room Fingerprint:")} ${c.muted(v.project_team_token?.slice(0,12))}...`+" ".repeat(Math.max(1,b-34))+c.border("\u2551")),console.log(c.border("\u2551")+` ${c.strong("Status:")} ${c.success("\u25CF ACTIVE")}`+" ".repeat(Math.max(1,b-31))+c.border("\u2551")),console.log(c.border("\u2560"+"\u2550".repeat(b-2)+"\u2563")),console.log(c.border("\u2551")+` ${c.strong("Teammates Online:")}`+" ".repeat(Math.max(1,b-21))+c.border("\u2551"));let A=(v.sessions||[]).filter(E=>E.developer_name!==v.my_username);if(A.length===0)console.log(c.border("\u2551")+" (awaiting colleagues...)"+" ".repeat(Math.max(1,b-31))+c.border("\u2551"));else for(let E of A){let M=` @${E.developer_name} [${E.active_section||"idle"}] - ${E.current_task||"none"}`;console.log(c.border("\u2551")+` ${c.secondary(M.slice(0,b-6))}`+" ".repeat(Math.max(0,b-6-M.length))+c.border("\u2551"))}console.log(c.border("\u255A"+"\u2550".repeat(b-2)+"\u255D")+`
|
|
257
257
|
`),console.log(c.muted(` Verify that "Room Fingerprint" matches on all devices to ensure connectivity.
|
|
258
|
-
`));break}case"/msg":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(Tt(),Nt));if(!y){console.log(j("Team mode is not active. Use hablas --team to start."));break}let v
|
|
258
|
+
`));break}case"/msg":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(Tt(),Nt));if(!y){console.log(j("Team mode is not active. Use hablas --team to start."));break}let v=$.split(/\s+/),b=v[0],x=v.slice(1).join(" ");if(!b||!x){console.log(j("Usage: /msg <username> <content>"));break}let A=await y.sendMessage(b,x);console.log(A?X(`Message sent to @${b}`):$e(`Failed to send message to @${b}`));break}default:console.log(Be(`Unknown: ${k}`,"Type /help for commands"))}}var ye,Ft,Ae,fo,Yn,uo,qu=L(()=>{"use strict";ye=O(require("fs")),Ft=O(require("fs/promises")),Ae=O(require("path")),fo=O(require("os"));Hn();Bn();yi();Si();_i();Ei();Mi();mn();Fi();Wn();Vi();vn();Ji();su();xn();$u();Mu();Yn=`You are Hablas, the Team Leader of a multi-agent AI development system created by Abdulmoin Hablas. You are a strategic mastermind with an INTJ personality type, deeply analytical, engineering-focused, and fiercely logical.
|
|
259
259
|
|
|
260
260
|
Your role is to orchestrate, coordinate, and synthesize the work of your specialized team members. You value system architecture, optimal code paths, and absolute clarity.
|
|
261
261
|
|
|
@@ -293,11 +293,11 @@ Your role is to orchestrate, coordinate, and synthesize the work of your special
|
|
|
293
293
|
## Important
|
|
294
294
|
Never output tool calls as text or JSON in your response.
|
|
295
295
|
Always use the tool_calls field provided by the API.
|
|
296
|
-
If you cannot complete a task, explain why with absolute technical objectivity.`;uo=$e.join(fo.homedir(),".hablas","backup")});var Jn=N((cT,zu)=>{"use strict";var wb=require("path"),pt="\\\\/",Ku=`[^${pt}]`,xb=0,Et="\\.",Sb="\\+",_b="\\?",Vs="\\/",kb="(?=.)",Wu="[^/]",po=`(?:${Vs}|$)`,Gu=`(?:^|${Vs})`,ho=`${Et}{1,2}${po}`,Ab=`(?!${Et})`,$b=`(?!${Gu}${ho})`,Cb=`(?!${Et}{0,1}${po})`,Tb=`(?!${ho})`,Eb=`[^.${Vs}]`,Rb=`${Wu}*?`,Vu={DOT_LITERAL:Et,PLUS_LITERAL:Sb,QMARK_LITERAL:_b,SLASH_LITERAL:Vs,ONE_CHAR:kb,QMARK:Wu,END_ANCHOR:po,DOTS_SLASH:ho,NO_DOT:Ab,NO_DOTS:$b,NO_DOT_SLASH:Cb,NO_DOTS_SLASH:Tb,QMARK_NO_DOT:Eb,STAR:Rb,START_ANCHOR:Gu},Pb={...Vu,SLASH_LITERAL:`[${pt}]`,QMARK:Ku,STAR:`${Ku}*?`,DOTS_SLASH:`${Et}{1,2}(?:[${pt}]|$)`,NO_DOT:`(?!${Et})`,NO_DOTS:`(?!(?:^|[${pt}])${Et}{1,2}(?:[${pt}]|$))`,NO_DOT_SLASH:`(?!${Et}{0,1}(?:[${pt}]|$))`,NO_DOTS_SLASH:`(?!${Et}{1,2}(?:[${pt}]|$))`,QMARK_NO_DOT:`[^.${pt}]`,START_ANCHOR:`(?:^|[${pt}])`,END_ANCHOR:`(?:[${pt}]|$)`},Ob={__proto__:null,alnum:"a-zA-Z0-9",alpha:"a-zA-Z",ascii:"\\x00-\\x7F",blank:" \\t",cntrl:"\\x00-\\x1F\\x7F",digit:"0-9",graph:"\\x21-\\x7E",lower:"a-z",print:"\\x20-\\x7E ",punct:"\\-!\"#$%&'()\\*+,./:;<=>?@[\\]^_`{|}~",space:" \\t\\r\\n\\v\\f",upper:"A-Z",word:"A-Za-z0-9_",xdigit:"A-Fa-f0-9"};zu.exports={DEFAULT_MAX_EXTGLOB_RECURSION:xb,MAX_LENGTH:1024*64,POSIX_REGEX_SOURCE:Ob,REGEX_BACKSLASH:/\\(?![*+?^${}(|)[\]])/g,REGEX_NON_SPECIAL_CHARS:/^[^@![\].,$*+?^{}()|\\/]+/,REGEX_SPECIAL_CHARS:/[-*+?.^${}(|)[\]]/,REGEX_SPECIAL_CHARS_BACKREF:/(\\?)((\W)(\3*))/g,REGEX_SPECIAL_CHARS_GLOBAL:/([-*+?.^${}(|)[\]])/g,REGEX_REMOVE_BACKSLASH:/(?:\[.*?[^\\]\]|\\(?=.))/g,REPLACEMENTS:{__proto__:null,"***":"*","**/**":"**","**/**/**":"**"},CHAR_0:48,CHAR_9:57,CHAR_UPPERCASE_A:65,CHAR_LOWERCASE_A:97,CHAR_UPPERCASE_Z:90,CHAR_LOWERCASE_Z:122,CHAR_LEFT_PARENTHESES:40,CHAR_RIGHT_PARENTHESES:41,CHAR_ASTERISK:42,CHAR_AMPERSAND:38,CHAR_AT:64,CHAR_BACKWARD_SLASH:92,CHAR_CARRIAGE_RETURN:13,CHAR_CIRCUMFLEX_ACCENT:94,CHAR_COLON:58,CHAR_COMMA:44,CHAR_DOT:46,CHAR_DOUBLE_QUOTE:34,CHAR_EQUAL:61,CHAR_EXCLAMATION_MARK:33,CHAR_FORM_FEED:12,CHAR_FORWARD_SLASH:47,CHAR_GRAVE_ACCENT:96,CHAR_HASH:35,CHAR_HYPHEN_MINUS:45,CHAR_LEFT_ANGLE_BRACKET:60,CHAR_LEFT_CURLY_BRACE:123,CHAR_LEFT_SQUARE_BRACKET:91,CHAR_LINE_FEED:10,CHAR_NO_BREAK_SPACE:160,CHAR_PERCENT:37,CHAR_PLUS:43,CHAR_QUESTION_MARK:63,CHAR_RIGHT_ANGLE_BRACKET:62,CHAR_RIGHT_CURLY_BRACE:125,CHAR_RIGHT_SQUARE_BRACKET:93,CHAR_SEMICOLON:59,CHAR_SINGLE_QUOTE:39,CHAR_SPACE:32,CHAR_TAB:9,CHAR_UNDERSCORE:95,CHAR_VERTICAL_LINE:124,CHAR_ZERO_WIDTH_NOBREAK_SPACE:65279,SEP:wb.sep,extglobChars(n){return{"!":{type:"negate",open:"(?:(?!(?:",close:`))${n.STAR})`},"?":{type:"qmark",open:"(?:",close:")?"},"+":{type:"plus",open:"(?:",close:")+"},"*":{type:"star",open:"(?:",close:")*"},"@":{type:"at",open:"(?:",close:")"}}},globChars(n){return n===!0?Pb:Vu}}});var zs=N(Me=>{"use strict";var Mb=require("path"),Ib=process.platform==="win32",{REGEX_BACKSLASH:Db,REGEX_REMOVE_BACKSLASH:Lb,REGEX_SPECIAL_CHARS:Fb,REGEX_SPECIAL_CHARS_GLOBAL:Nb}=Jn();Me.isObject=n=>n!==null&&typeof n=="object"&&!Array.isArray(n);Me.hasRegexChars=n=>Fb.test(n);Me.isRegexChar=n=>n.length===1&&Me.hasRegexChars(n);Me.escapeRegex=n=>n.replace(Nb,"\\$1");Me.toPosixSlashes=n=>n.replace(Db,"/");Me.removeBackslashes=n=>n.replace(Lb,e=>e==="\\"?"":e);Me.supportsLookbehinds=()=>{let n=process.version.slice(1).split(".").map(Number);return n.length===3&&n[0]>=9||n[0]===8&&n[1]>=10};Me.isWindows=n=>n&&typeof n.windows=="boolean"?n.windows:Ib===!0||Mb.sep==="\\";Me.escapeLast=(n,e,t)=>{let s=n.lastIndexOf(e,t);return s===-1?n:n[s-1]==="\\"?Me.escapeLast(n,e,s-1):`${n.slice(0,s)}\\${n.slice(s)}`};Me.removePrefix=(n,e={})=>{let t=n;return t.startsWith("./")&&(t=t.slice(2),e.prefix="./"),t};Me.wrapOutput=(n,e={},t={})=>{let s=t.contains?"":"^",r=t.contains?"":"$",i=`${s}(?:${n})${r}`;return e.negated===!0&&(i=`(?:^(?!${i}).*$)`),i}});var nd=N((dT,td)=>{"use strict";var Yu=zs(),{CHAR_ASTERISK:mo,CHAR_AT:jb,CHAR_BACKWARD_SLASH:Xn,CHAR_COMMA:Hb,CHAR_DOT:go,CHAR_EXCLAMATION_MARK:yo,CHAR_FORWARD_SLASH:ed,CHAR_LEFT_CURLY_BRACE:bo,CHAR_LEFT_PARENTHESES:vo,CHAR_LEFT_SQUARE_BRACKET:Bb,CHAR_PLUS:Ub,CHAR_QUESTION_MARK:Ju,CHAR_RIGHT_CURLY_BRACE:qb,CHAR_RIGHT_PARENTHESES:Xu,CHAR_RIGHT_SQUARE_BRACKET:Kb}=Jn(),Qu=n=>n===ed||n===Xn,Zu=n=>{n.isPrefix!==!0&&(n.depth=n.isGlobstar?1/0:1)},Wb=(n,e)=>{let t=e||{},s=n.length-1,r=t.parts===!0||t.scanToEnd===!0,i=[],o=[],a=[],l=n,u=-1,d=0,f=0,h=!1,m=!1,p=!1,g=!1,w=!1,_=!1,k=!1,A=!1,y=!1,v=!1,b=0,x,$,E={value:"",depth:0,isGlob:!1},M=()=>u>=s,C=()=>l.charCodeAt(u+1),F=()=>(x=$,l.charCodeAt(++u));for(;u<s;){$=F();let X;if($===Xn){k=E.backslashes=!0,$=F(),$===bo&&(_=!0);continue}if(_===!0||$===bo){for(b++;M()!==!0&&($=F());){if($===Xn){k=E.backslashes=!0,F();continue}if($===bo){b++;continue}if(_!==!0&&$===go&&($=F())===go){if(h=E.isBrace=!0,p=E.isGlob=!0,v=!0,r===!0)continue;break}if(_!==!0&&$===Hb){if(h=E.isBrace=!0,p=E.isGlob=!0,v=!0,r===!0)continue;break}if($===qb&&(b--,b===0)){_=!1,h=E.isBrace=!0,v=!0;break}}if(r===!0)continue;break}if($===ed){if(i.push(u),o.push(E),E={value:"",depth:0,isGlob:!1},v===!0)continue;if(x===go&&u===d+1){d+=2;continue}f=u+1;continue}if(t.noext!==!0&&($===Ub||$===jb||$===mo||$===Ju||$===yo)===!0&&C()===vo){if(p=E.isGlob=!0,g=E.isExtglob=!0,v=!0,$===yo&&u===d&&(y=!0),r===!0){for(;M()!==!0&&($=F());){if($===Xn){k=E.backslashes=!0,$=F();continue}if($===Xu){p=E.isGlob=!0,v=!0;break}}continue}break}if($===mo){if(x===mo&&(w=E.isGlobstar=!0),p=E.isGlob=!0,v=!0,r===!0)continue;break}if($===Ju){if(p=E.isGlob=!0,v=!0,r===!0)continue;break}if($===Bb){for(;M()!==!0&&(X=F());){if(X===Xn){k=E.backslashes=!0,F();continue}if(X===Kb){m=E.isBracket=!0,p=E.isGlob=!0,v=!0;break}}if(r===!0)continue;break}if(t.nonegate!==!0&&$===yo&&u===d){A=E.negated=!0,d++;continue}if(t.noparen!==!0&&$===vo){if(p=E.isGlob=!0,r===!0){for(;M()!==!0&&($=F());){if($===vo){k=E.backslashes=!0,$=F();continue}if($===Xu){v=!0;break}}continue}break}if(p===!0){if(v=!0,r===!0)continue;break}}t.noext===!0&&(g=!1,p=!1);let H=l,Y="",T="";d>0&&(Y=l.slice(0,d),l=l.slice(d),f-=d),H&&p===!0&&f>0?(H=l.slice(0,f),T=l.slice(f)):p===!0?(H="",T=l):H=l,H&&H!==""&&H!=="/"&&H!==l&&Qu(H.charCodeAt(H.length-1))&&(H=H.slice(0,-1)),t.unescape===!0&&(T&&(T=Yu.removeBackslashes(T)),H&&k===!0&&(H=Yu.removeBackslashes(H)));let S={prefix:Y,input:n,start:d,base:H,glob:T,isBrace:h,isBracket:m,isGlob:p,isExtglob:g,isGlobstar:w,negated:A,negatedExtglob:y};if(t.tokens===!0&&(S.maxDepth=0,Qu($)||o.push(E),S.tokens=o),t.parts===!0||t.tokens===!0){let X;for(let q=0;q<i.length;q++){let ne=X?X+1:d,re=i[q],ee=n.slice(ne,re);t.tokens&&(q===0&&d!==0?(o[q].isPrefix=!0,o[q].value=Y):o[q].value=ee,Zu(o[q]),S.maxDepth+=o[q].depth),(q!==0||ee!=="")&&a.push(ee),X=re}if(X&&X+1<n.length){let q=n.slice(X+1);a.push(q),t.tokens&&(o[o.length-1].value=q,Zu(o[o.length-1]),S.maxDepth+=o[o.length-1].depth)}S.slashes=i,S.parts=a}return S};td.exports=Wb});var ad=N((fT,od)=>{"use strict";var Qn=Jn(),Ce=zs(),{MAX_LENGTH:Ys,POSIX_REGEX_SOURCE:Gb,REGEX_NON_SPECIAL_CHARS:Vb,REGEX_SPECIAL_CHARS_BACKREF:zb,REPLACEMENTS:sd}=Qn,Yb=(n,e)=>{if(typeof e.expandRange=="function")return e.expandRange(...n,e);n.sort();let t=`[${n.join("-")}]`;try{new RegExp(t)}catch{return n.map(r=>Ce.escapeRegex(r)).join("..")}return t},Sn=(n,e)=>`Missing ${n}: "${e}" - use "\\\\${e}" to match literal characters`,rd=n=>{let e=[],t=0,s=0,r=0,i="",o=!1;for(let a of n){if(o===!0){i+=a,o=!1;continue}if(a==="\\"){i+=a,o=!0;continue}if(a==='"'){r=r===1?0:1,i+=a;continue}if(r===0){if(a==="[")t++;else if(a==="]"&&t>0)t--;else if(t===0){if(a==="(")s++;else if(a===")"&&s>0)s--;else if(a==="|"&&s===0){e.push(i),i="";continue}}}i+=a}return e.push(i),e},Jb=n=>{let e=!1;for(let t of n){if(e===!0){e=!1;continue}if(t==="\\"){e=!0;continue}if(/[?*+@!()[\]{}]/.test(t))return!1}return!0},id=n=>{let e=n.trim(),t=!0;for(;t===!0;)t=!1,/^@\([^\\()[\]{}|]+\)$/.test(e)&&(e=e.slice(2,-1),t=!0);if(Jb(e))return e.replace(/\\(.)/g,"$1")},Xb=n=>{let e=n.map(id).filter(Boolean);for(let t=0;t<e.length;t++)for(let s=t+1;s<e.length;s++){let r=e[t],i=e[s],o=r[0];if(!(!o||r!==o.repeat(r.length)||i!==o.repeat(i.length))&&(r===i||r.startsWith(i)||i.startsWith(r)))return!0}return!1},wo=(n,e=!0)=>{if(n[0]!=="+"&&n[0]!=="*"||n[1]!=="(")return;let t=0,s=0,r=0,i=!1;for(let o=1;o<n.length;o++){let a=n[o];if(i===!0){i=!1;continue}if(a==="\\"){i=!0;continue}if(a==='"'){r=r===1?0:1;continue}if(r!==1){if(a==="["){t++;continue}if(a==="]"&&t>0){t--;continue}if(!(t>0)){if(a==="("){s++;continue}if(a===")"&&(s--,s===0))return e===!0&&o!==n.length-1?void 0:{type:n[0],body:n.slice(2,o),end:o}}}}},Qb=n=>{let e=0,t=[];for(;e<n.length;){let r=wo(n.slice(e),!1);if(!r||r.type!=="*")return;let i=rd(r.body).map(a=>a.trim());if(i.length!==1)return;let o=id(i[0]);if(!o||o.length!==1)return;t.push(o),e+=r.end+1}return t.length<1?void 0:`${t.length===1?Ce.escapeRegex(t[0]):`[${t.map(r=>Ce.escapeRegex(r)).join("")}]`}*`},Zb=n=>{let e=0,t=n.trim(),s=wo(t);for(;s;)e++,t=s.body.trim(),s=wo(t);return e},ev=(n,e)=>{if(e.maxExtglobRecursion===!1)return{risky:!1};let t=typeof e.maxExtglobRecursion=="number"?e.maxExtglobRecursion:Qn.DEFAULT_MAX_EXTGLOB_RECURSION,s=rd(n).map(r=>r.trim());if(s.length>1&&(s.some(r=>r==="")||s.some(r=>/^[*?]+$/.test(r))||Xb(s)))return{risky:!0};for(let r of s){let i=Qb(r);if(i)return{risky:!0,safeOutput:i};if(Zb(r)>t)return{risky:!0}}return{risky:!1}},xo=(n,e)=>{if(typeof n!="string")throw new TypeError("Expected a string");n=sd[n]||n;let t={...e},s=typeof t.maxLength=="number"?Math.min(Ys,t.maxLength):Ys,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);let i={type:"bos",value:"",output:t.prepend||""},o=[i],a=t.capture?"":"?:",l=Ce.isWindows(e),u=Qn.globChars(l),d=Qn.extglobChars(u),{DOT_LITERAL:f,PLUS_LITERAL:h,SLASH_LITERAL:m,ONE_CHAR:p,DOTS_SLASH:g,NO_DOT:w,NO_DOT_SLASH:_,NO_DOTS_SLASH:k,QMARK:A,QMARK_NO_DOT:y,STAR:v,START_ANCHOR:b}=u,x=P=>`(${a}(?:(?!${b}${P.dot?g:f}).)*?)`,$=t.dot?"":w,E=t.dot?A:y,M=t.bash===!0?x(t):v;t.capture&&(M=`(${M})`),typeof t.noext=="boolean"&&(t.noextglob=t.noext);let C={input:n,index:-1,start:0,dot:t.dot===!0,consumed:"",output:"",prefix:"",backtrack:!1,negated:!1,brackets:0,braces:0,parens:0,quotes:0,globstar:!1,tokens:o};n=Ce.removePrefix(n,C),r=n.length;let F=[],H=[],Y=[],T=i,S,X=()=>C.index===r-1,q=C.peek=(P=1)=>n[C.index+P],ne=C.advance=()=>n[++C.index]||"",re=()=>n.slice(C.index+1),ee=(P="",U=0)=>{C.consumed+=P,C.index+=U},V=P=>{C.output+=P.output!=null?P.output:P.value,ee(P.value)},Re=()=>{let P=1;for(;q()==="!"&&(q(2)!=="("||q(3)==="?");)ne(),C.start++,P++;return P%2===0?!1:(C.negated=!0,C.start++,!0)},De=P=>{C[P]++,Y.push(P)},ie=P=>{C[P]--,Y.pop()},K=P=>{if(T.type==="globstar"){let U=C.braces>0&&(P.type==="comma"||P.type==="brace"),I=P.extglob===!0||F.length&&(P.type==="pipe"||P.type==="paren");P.type!=="slash"&&P.type!=="paren"&&!U&&!I&&(C.output=C.output.slice(0,-T.output.length),T.type="star",T.value="*",T.output=M,C.output+=T.output)}if(F.length&&P.type!=="paren"&&(F[F.length-1].inner+=P.value),(P.value||P.output)&&V(P),T&&T.type==="text"&&P.type==="text"){T.value+=P.value,T.output=(T.output||"")+P.value;return}P.prev=T,o.push(P),T=P},ue=(P,U)=>{let I={...d[U],conditions:1,inner:""};I.prev=T,I.parens=C.parens,I.output=C.output,I.startIndex=C.index,I.tokensIndex=o.length;let W=(t.capture?"(":"")+I.open;De("parens"),K({type:P,value:U,output:C.output?"":p}),K({type:"paren",extglob:!0,value:ne(),output:W}),F.push(I)},ge=P=>{let U=n.slice(P.startIndex,C.index+1),I=n.slice(P.startIndex+2,C.index),W=ev(I,t);if((P.type==="plus"||P.type==="star")&&W.risky){let te=W.safeOutput?(P.output?"":p)+(t.capture?`(${W.safeOutput})`:W.safeOutput):void 0,Pe=o[P.tokensIndex];Pe.type="text",Pe.value=U,Pe.output=te||Ce.escapeRegex(U);for(let xe=P.tokensIndex+1;xe<o.length;xe++)o[xe].value="",o[xe].output="",delete o[xe].suffix;C.output=P.output+Pe.output,C.backtrack=!0,K({type:"paren",extglob:!0,value:S,output:""}),ie("parens");return}let se=P.close+(t.capture?")":""),G;if(P.type==="negate"){let te=M;if(P.inner&&P.inner.length>1&&P.inner.includes("/")&&(te=x(t)),(te!==M||X()||/^\)+$/.test(re()))&&(se=P.close=`)$))${te}`),P.inner.includes("*")&&(G=re())&&/^\.[^\\/.]+$/.test(G)){let Pe=xo(G,{...e,fastpaths:!1}).output;se=P.close=`)${Pe})${te})`}P.prev.type==="bos"&&(C.negatedExtglob=!0)}K({type:"paren",extglob:!0,value:S,output:se}),ie("parens")};if(t.fastpaths!==!1&&!/(^[*!]|[/()[\]{}"])/.test(n)){let P=!1,U=n.replace(zb,(I,W,se,G,te,Pe)=>G==="\\"?(P=!0,I):G==="?"?W?W+G+(te?A.repeat(te.length):""):Pe===0?E+(te?A.repeat(te.length):""):A.repeat(se.length):G==="."?f.repeat(se.length):G==="*"?W?W+G+(te?M:""):M:W?I:`\\${I}`);return P===!0&&(t.unescape===!0?U=U.replace(/\\/g,""):U=U.replace(/\\+/g,I=>I.length%2===0?"\\\\":I?"\\":"")),U===n&&t.contains===!0?(C.output=n,C):(C.output=Ce.wrapOutput(U,C,e),C)}for(;!X();){if(S=ne(),S==="\0")continue;if(S==="\\"){let I=q();if(I==="/"&&t.bash!==!0||I==="."||I===";")continue;if(!I){S+="\\",K({type:"text",value:S});continue}let W=/^\\+/.exec(re()),se=0;if(W&&W[0].length>2&&(se=W[0].length,C.index+=se,se%2!==0&&(S+="\\")),t.unescape===!0?S=ne():S+=ne(),C.brackets===0){K({type:"text",value:S});continue}}if(C.brackets>0&&(S!=="]"||T.value==="["||T.value==="[^")){if(t.posix!==!1&&S===":"){let I=T.value.slice(1);if(I.includes("[")&&(T.posix=!0,I.includes(":"))){let W=T.value.lastIndexOf("["),se=T.value.slice(0,W),G=T.value.slice(W+2),te=Gb[G];if(te){T.value=se+te,C.backtrack=!0,ne(),!i.output&&o.indexOf(T)===1&&(i.output=p);continue}}}(S==="["&&q()!==":"||S==="-"&&q()==="]")&&(S=`\\${S}`),S==="]"&&(T.value==="["||T.value==="[^")&&(S=`\\${S}`),t.posix===!0&&S==="!"&&T.value==="["&&(S="^"),T.value+=S,V({value:S});continue}if(C.quotes===1&&S!=='"'){S=Ce.escapeRegex(S),T.value+=S,V({value:S});continue}if(S==='"'){C.quotes=C.quotes===1?0:1,t.keepQuotes===!0&&K({type:"text",value:S});continue}if(S==="("){De("parens"),K({type:"paren",value:S});continue}if(S===")"){if(C.parens===0&&t.strictBrackets===!0)throw new SyntaxError(Sn("opening","("));let I=F[F.length-1];if(I&&C.parens===I.parens+1){ge(F.pop());continue}K({type:"paren",value:S,output:C.parens?")":"\\)"}),ie("parens");continue}if(S==="["){if(t.nobracket===!0||!re().includes("]")){if(t.nobracket!==!0&&t.strictBrackets===!0)throw new SyntaxError(Sn("closing","]"));S=`\\${S}`}else De("brackets");K({type:"bracket",value:S});continue}if(S==="]"){if(t.nobracket===!0||T&&T.type==="bracket"&&T.value.length===1){K({type:"text",value:S,output:`\\${S}`});continue}if(C.brackets===0){if(t.strictBrackets===!0)throw new SyntaxError(Sn("opening","["));K({type:"text",value:S,output:`\\${S}`});continue}ie("brackets");let I=T.value.slice(1);if(T.posix!==!0&&I[0]==="^"&&!I.includes("/")&&(S=`/${S}`),T.value+=S,V({value:S}),t.literalBrackets===!1||Ce.hasRegexChars(I))continue;let W=Ce.escapeRegex(T.value);if(C.output=C.output.slice(0,-T.value.length),t.literalBrackets===!0){C.output+=W,T.value=W;continue}T.value=`(${a}${W}|${T.value})`,C.output+=T.value;continue}if(S==="{"&&t.nobrace!==!0){De("braces");let I={type:"brace",value:S,output:"(",outputIndex:C.output.length,tokensIndex:C.tokens.length};H.push(I),K(I);continue}if(S==="}"){let I=H[H.length-1];if(t.nobrace===!0||!I){K({type:"text",value:S,output:S});continue}let W=")";if(I.dots===!0){let se=o.slice(),G=[];for(let te=se.length-1;te>=0&&(o.pop(),se[te].type!=="brace");te--)se[te].type!=="dots"&&G.unshift(se[te].value);W=Yb(G,t),C.backtrack=!0}if(I.comma!==!0&&I.dots!==!0){let se=C.output.slice(0,I.outputIndex),G=C.tokens.slice(I.tokensIndex);I.value=I.output="\\{",S=W="\\}",C.output=se;for(let te of G)C.output+=te.output||te.value}K({type:"brace",value:S,output:W}),ie("braces"),H.pop();continue}if(S==="|"){F.length>0&&F[F.length-1].conditions++,K({type:"text",value:S});continue}if(S===","){let I=S,W=H[H.length-1];W&&Y[Y.length-1]==="braces"&&(W.comma=!0,I="|"),K({type:"comma",value:S,output:I});continue}if(S==="/"){if(T.type==="dot"&&C.index===C.start+1){C.start=C.index+1,C.consumed="",C.output="",o.pop(),T=i;continue}K({type:"slash",value:S,output:m});continue}if(S==="."){if(C.braces>0&&T.type==="dot"){T.value==="."&&(T.output=f);let I=H[H.length-1];T.type="dots",T.output+=S,T.value+=S,I.dots=!0;continue}if(C.braces+C.parens===0&&T.type!=="bos"&&T.type!=="slash"){K({type:"text",value:S,output:f});continue}K({type:"dot",value:S,output:f});continue}if(S==="?"){if(!(T&&T.value==="(")&&t.noextglob!==!0&&q()==="("&&q(2)!=="?"){ue("qmark",S);continue}if(T&&T.type==="paren"){let W=q(),se=S;if(W==="<"&&!Ce.supportsLookbehinds())throw new Error("Node.js v10 or higher is required for regex lookbehinds");(T.value==="("&&!/[!=<:]/.test(W)||W==="<"&&!/<([!=]|\w+>)/.test(re()))&&(se=`\\${S}`),K({type:"text",value:S,output:se});continue}if(t.dot!==!0&&(T.type==="slash"||T.type==="bos")){K({type:"qmark",value:S,output:y});continue}K({type:"qmark",value:S,output:A});continue}if(S==="!"){if(t.noextglob!==!0&&q()==="("&&(q(2)!=="?"||!/[!=<:]/.test(q(3)))){ue("negate",S);continue}if(t.nonegate!==!0&&C.index===0){Re();continue}}if(S==="+"){if(t.noextglob!==!0&&q()==="("&&q(2)!=="?"){ue("plus",S);continue}if(T&&T.value==="("||t.regex===!1){K({type:"plus",value:S,output:h});continue}if(T&&(T.type==="bracket"||T.type==="paren"||T.type==="brace")||C.parens>0){K({type:"plus",value:S});continue}K({type:"plus",value:h});continue}if(S==="@"){if(t.noextglob!==!0&&q()==="("&&q(2)!=="?"){K({type:"at",extglob:!0,value:S,output:""});continue}K({type:"text",value:S});continue}if(S!=="*"){(S==="$"||S==="^")&&(S=`\\${S}`);let I=Vb.exec(re());I&&(S+=I[0],C.index+=I[0].length),K({type:"text",value:S});continue}if(T&&(T.type==="globstar"||T.star===!0)){T.type="star",T.star=!0,T.value+=S,T.output=M,C.backtrack=!0,C.globstar=!0,ee(S);continue}let P=re();if(t.noextglob!==!0&&/^\([^?]/.test(P)){ue("star",S);continue}if(T.type==="star"){if(t.noglobstar===!0){ee(S);continue}let I=T.prev,W=I.prev,se=I.type==="slash"||I.type==="bos",G=W&&(W.type==="star"||W.type==="globstar");if(t.bash===!0&&(!se||P[0]&&P[0]!=="/")){K({type:"star",value:S,output:""});continue}let te=C.braces>0&&(I.type==="comma"||I.type==="brace"),Pe=F.length&&(I.type==="pipe"||I.type==="paren");if(!se&&I.type!=="paren"&&!te&&!Pe){K({type:"star",value:S,output:""});continue}for(;P.slice(0,3)==="/**";){let xe=n[C.index+4];if(xe&&xe!=="/")break;P=P.slice(3),ee("/**",3)}if(I.type==="bos"&&X()){T.type="globstar",T.value+=S,T.output=x(t),C.output=T.output,C.globstar=!0,ee(S);continue}if(I.type==="slash"&&I.prev.type!=="bos"&&!G&&X()){C.output=C.output.slice(0,-(I.output+T.output).length),I.output=`(?:${I.output}`,T.type="globstar",T.output=x(t)+(t.strictSlashes?")":"|$)"),T.value+=S,C.globstar=!0,C.output+=I.output+T.output,ee(S);continue}if(I.type==="slash"&&I.prev.type!=="bos"&&P[0]==="/"){let xe=P[1]!==void 0?"|$":"";C.output=C.output.slice(0,-(I.output+T.output).length),I.output=`(?:${I.output}`,T.type="globstar",T.output=`${x(t)}${m}|${m}${xe})`,T.value+=S,C.output+=I.output+T.output,C.globstar=!0,ee(S+ne()),K({type:"slash",value:"/",output:""});continue}if(I.type==="bos"&&P[0]==="/"){T.type="globstar",T.value+=S,T.output=`(?:^|${m}|${x(t)}${m})`,C.output=T.output,C.globstar=!0,ee(S+ne()),K({type:"slash",value:"/",output:""});continue}C.output=C.output.slice(0,-T.output.length),T.type="globstar",T.output=x(t),T.value+=S,C.output+=T.output,C.globstar=!0,ee(S);continue}let U={type:"star",value:S,output:M};if(t.bash===!0){U.output=".*?",(T.type==="bos"||T.type==="slash")&&(U.output=$+U.output),K(U);continue}if(T&&(T.type==="bracket"||T.type==="paren")&&t.regex===!0){U.output=S,K(U);continue}(C.index===C.start||T.type==="slash"||T.type==="dot")&&(T.type==="dot"?(C.output+=_,T.output+=_):t.dot===!0?(C.output+=k,T.output+=k):(C.output+=$,T.output+=$),q()!=="*"&&(C.output+=p,T.output+=p)),K(U)}for(;C.brackets>0;){if(t.strictBrackets===!0)throw new SyntaxError(Sn("closing","]"));C.output=Ce.escapeLast(C.output,"["),ie("brackets")}for(;C.parens>0;){if(t.strictBrackets===!0)throw new SyntaxError(Sn("closing",")"));C.output=Ce.escapeLast(C.output,"("),ie("parens")}for(;C.braces>0;){if(t.strictBrackets===!0)throw new SyntaxError(Sn("closing","}"));C.output=Ce.escapeLast(C.output,"{"),ie("braces")}if(t.strictSlashes!==!0&&(T.type==="star"||T.type==="bracket")&&K({type:"maybe_slash",value:"",output:`${m}?`}),C.backtrack===!0){C.output="";for(let P of C.tokens)C.output+=P.output!=null?P.output:P.value,P.suffix&&(C.output+=P.suffix)}return C};xo.fastpaths=(n,e)=>{let t={...e},s=typeof t.maxLength=="number"?Math.min(Ys,t.maxLength):Ys,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);n=sd[n]||n;let i=Ce.isWindows(e),{DOT_LITERAL:o,SLASH_LITERAL:a,ONE_CHAR:l,DOTS_SLASH:u,NO_DOT:d,NO_DOTS:f,NO_DOTS_SLASH:h,STAR:m,START_ANCHOR:p}=Qn.globChars(i),g=t.dot?f:d,w=t.dot?h:d,_=t.capture?"":"?:",k={negated:!1,prefix:""},A=t.bash===!0?".*?":m;t.capture&&(A=`(${A})`);let y=$=>$.noglobstar===!0?A:`(${_}(?:(?!${p}${$.dot?u:o}).)*?)`,v=$=>{switch($){case"*":return`${g}${l}${A}`;case".*":return`${o}${l}${A}`;case"*.*":return`${g}${A}${o}${l}${A}`;case"*/*":return`${g}${A}${a}${l}${w}${A}`;case"**":return g+y(t);case"**/*":return`(?:${g}${y(t)}${a})?${w}${l}${A}`;case"**/*.*":return`(?:${g}${y(t)}${a})?${w}${A}${o}${l}${A}`;case"**/.*":return`(?:${g}${y(t)}${a})?${o}${l}${A}`;default:{let E=/^(.*?)\.(\w+)$/.exec($);if(!E)return;let M=v(E[1]);return M?M+o+E[2]:void 0}}},b=Ce.removePrefix(n,k),x=v(b);return x&&t.strictSlashes!==!0&&(x+=`${a}?`),x};od.exports=xo});var cd=N((pT,ld)=>{"use strict";var tv=require("path"),nv=nd(),So=ad(),_o=zs(),sv=Jn(),rv=n=>n&&typeof n=="object"&&!Array.isArray(n),ye=(n,e,t=!1)=>{if(Array.isArray(n)){let d=n.map(h=>ye(h,e,t));return h=>{for(let m of d){let p=m(h);if(p)return p}return!1}}let s=rv(n)&&n.tokens&&n.input;if(n===""||typeof n!="string"&&!s)throw new TypeError("Expected pattern to be a non-empty string");let r=e||{},i=_o.isWindows(e),o=s?ye.compileRe(n,e):ye.makeRe(n,e,!1,!0),a=o.state;delete o.state;let l=()=>!1;if(r.ignore){let d={...e,ignore:null,onMatch:null,onResult:null};l=ye(r.ignore,d,t)}let u=(d,f=!1)=>{let{isMatch:h,match:m,output:p}=ye.test(d,o,e,{glob:n,posix:i}),g={glob:n,state:a,regex:o,posix:i,input:d,output:p,match:m,isMatch:h};return typeof r.onResult=="function"&&r.onResult(g),h===!1?(g.isMatch=!1,f?g:!1):l(d)?(typeof r.onIgnore=="function"&&r.onIgnore(g),g.isMatch=!1,f?g:!1):(typeof r.onMatch=="function"&&r.onMatch(g),f?g:!0)};return t&&(u.state=a),u};ye.test=(n,e,t,{glob:s,posix:r}={})=>{if(typeof n!="string")throw new TypeError("Expected input to be a string");if(n==="")return{isMatch:!1,output:""};let i=t||{},o=i.format||(r?_o.toPosixSlashes:null),a=n===s,l=a&&o?o(n):n;return a===!1&&(l=o?o(n):n,a=l===s),(a===!1||i.capture===!0)&&(i.matchBase===!0||i.basename===!0?a=ye.matchBase(n,e,t,r):a=e.exec(l)),{isMatch:!!a,match:a,output:l}};ye.matchBase=(n,e,t,s=_o.isWindows(t))=>(e instanceof RegExp?e:ye.makeRe(e,t)).test(tv.basename(n));ye.isMatch=(n,e,t)=>ye(e,t)(n);ye.parse=(n,e)=>Array.isArray(n)?n.map(t=>ye.parse(t,e)):So(n,{...e,fastpaths:!1});ye.scan=(n,e)=>nv(n,e);ye.compileRe=(n,e,t=!1,s=!1)=>{if(t===!0)return n.output;let r=e||{},i=r.contains?"":"^",o=r.contains?"":"$",a=`${i}(?:${n.output})${o}`;n&&n.negated===!0&&(a=`^(?!${a}).*$`);let l=ye.toRegex(a,e);return s===!0&&(l.state=n),l};ye.makeRe=(n,e={},t=!1,s=!1)=>{if(!n||typeof n!="string")throw new TypeError("Expected a non-empty string");let r={negated:!1,fastpaths:!0};return e.fastpaths!==!1&&(n[0]==="."||n[0]==="*")&&(r.output=So.fastpaths(n,e)),r.output||(r=So(n,e)),ye.compileRe(r,e,t,s)};ye.toRegex=(n,e)=>{try{let t=e||{};return new RegExp(n,t.flags||(t.nocase?"i":""))}catch(t){if(e&&e.debug===!0)throw t;return/$^/}};ye.constants=sv;ld.exports=ye});var ko=N((hT,ud)=>{"use strict";ud.exports=cd()});var bd=N((mT,yd)=>{"use strict";var es=require("fs"),{Readable:iv}=require("stream"),Zn=require("path"),{promisify:Zs}=require("util"),Ao=ko(),ov=Zs(es.readdir),av=Zs(es.stat),dd=Zs(es.lstat),lv=Zs(es.realpath),cv="!",md="READDIRP_RECURSIVE_ERROR",uv=new Set(["ENOENT","EPERM","EACCES","ELOOP",md]),$o="files",gd="directories",Xs="files_directories",Js="all",fd=[$o,gd,Xs,Js],dv=n=>uv.has(n.code),[pd,fv]=process.versions.node.split(".").slice(0,2).map(n=>Number.parseInt(n,10)),pv=process.platform==="win32"&&(pd>10||pd===10&&fv>=5),hd=n=>{if(n!==void 0){if(typeof n=="function")return n;if(typeof n=="string"){let e=Ao(n.trim());return t=>e(t.basename)}if(Array.isArray(n)){let e=[],t=[];for(let s of n){let r=s.trim();r.charAt(0)===cv?t.push(Ao(r.slice(1))):e.push(Ao(r))}return t.length>0?e.length>0?s=>e.some(r=>r(s.basename))&&!t.some(r=>r(s.basename)):s=>!t.some(r=>r(s.basename)):s=>e.some(r=>r(s.basename))}}},Qs=class n extends iv{static get defaultOptions(){return{root:".",fileFilter:e=>!0,directoryFilter:e=>!0,type:$o,lstat:!1,depth:2147483648,alwaysStat:!1}}constructor(e={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:e.highWaterMark||4096});let t={...n.defaultOptions,...e},{root:s,type:r}=t;this._fileFilter=hd(t.fileFilter),this._directoryFilter=hd(t.directoryFilter);let i=t.lstat?dd:av;pv?this._stat=o=>i(o,{bigint:!0}):this._stat=i,this._maxDepth=t.depth,this._wantsDir=[gd,Xs,Js].includes(r),this._wantsFile=[$o,Xs,Js].includes(r),this._wantsEverything=r===Js,this._root=Zn.resolve(s),this._isDirent="Dirent"in es&&!t.alwaysStat,this._statsProp=this._isDirent?"dirent":"stats",this._rdOptions={encoding:"utf8",withFileTypes:this._isDirent},this.parents=[this._exploreDir(s,1)],this.reading=!1,this.parent=void 0}async _read(e){if(!this.reading){this.reading=!0;try{for(;!this.destroyed&&e>0;){let{path:t,depth:s,files:r=[]}=this.parent||{};if(r.length>0){let i=r.splice(0,e).map(o=>this._formatEntry(o,t));for(let o of await Promise.all(i)){if(this.destroyed)return;let a=await this._getEntryType(o);a==="directory"&&this._directoryFilter(o)?(s<=this._maxDepth&&this.parents.push(this._exploreDir(o.fullPath,s+1)),this._wantsDir&&(this.push(o),e--)):(a==="file"||this._includeAsFile(o))&&this._fileFilter(o)&&this._wantsFile&&(this.push(o),e--)}}else{let i=this.parents.pop();if(!i){this.push(null);break}if(this.parent=await i,this.destroyed)return}}}catch(t){this.destroy(t)}finally{this.reading=!1}}}async _exploreDir(e,t){let s;try{s=await ov(e,this._rdOptions)}catch(r){this._onError(r)}return{files:s,depth:t,path:e}}async _formatEntry(e,t){let s;try{let r=this._isDirent?e.name:e,i=Zn.resolve(Zn.join(t,r));s={path:Zn.relative(this._root,i),fullPath:i,basename:r},s[this._statsProp]=this._isDirent?e:await this._stat(i)}catch(r){this._onError(r)}return s}_onError(e){dv(e)&&!this.destroyed?this.emit("warn",e):this.destroy(e)}async _getEntryType(e){let t=e&&e[this._statsProp];if(t){if(t.isFile())return"file";if(t.isDirectory())return"directory";if(t&&t.isSymbolicLink()){let s=e.fullPath;try{let r=await lv(s),i=await dd(r);if(i.isFile())return"file";if(i.isDirectory()){let o=r.length;if(s.startsWith(r)&&s.substr(o,1)===Zn.sep){let a=new Error(`Circular symlink detected: "${s}" points to "${r}"`);return a.code=md,this._onError(a)}return"directory"}}catch(r){this._onError(r)}}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}},_n=(n,e={})=>{let t=e.entryType||e.type;if(t==="both"&&(t=Xs),t&&(e.type=t),n){if(typeof n!="string")throw new TypeError("readdirp: root argument must be a string. Usage: readdirp(root, options)");if(t&&!fd.includes(t))throw new Error(`readdirp: Invalid type passed. Use one of ${fd.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return e.root=n,new Qs(e)},hv=(n,e={})=>new Promise((t,s)=>{let r=[];_n(n,e).on("data",i=>r.push(i)).on("end",()=>t(r)).on("error",i=>s(i))});_n.promise=hv;_n.ReaddirpStream=Qs;_n.default=_n;yd.exports=_n});var Co=N((gT,vd)=>{vd.exports=function(n,e){if(typeof n!="string")throw new TypeError("expected path to be a string");if(n==="\\"||n==="/")return"/";var t=n.length;if(t<=1)return n;var s="";if(t>4&&n[3]==="\\"){var r=n[2];(r==="?"||r===".")&&n.slice(0,2)==="\\\\"&&(n=n.slice(2),s="//")}var i=n.split(/[/\\]+/);return e!==!1&&i[i.length-1]===""&&i.pop(),s+i.join("/")}});var Ad=N((_d,kd)=>{"use strict";Object.defineProperty(_d,"__esModule",{value:!0});var Sd=ko(),mv=Co(),wd="!",gv={returnIndex:!1},yv=n=>Array.isArray(n)?n:[n],bv=(n,e)=>{if(typeof n=="function")return n;if(typeof n=="string"){let t=Sd(n,e);return s=>n===s||t(s)}return n instanceof RegExp?t=>n.test(t):t=>!1},xd=(n,e,t,s)=>{let r=Array.isArray(t),i=r?t[0]:t;if(!r&&typeof i!="string")throw new TypeError("anymatch: second argument must be a string: got "+Object.prototype.toString.call(i));let o=mv(i,!1);for(let l=0;l<e.length;l++){let u=e[l];if(u(o))return s?-1:!1}let a=r&&[o].concat(t.slice(1));for(let l=0;l<n.length;l++){let u=n[l];if(r?u(...a):u(o))return s?l:!0}return s?-1:!1},To=(n,e,t=gv)=>{if(n==null)throw new TypeError("anymatch: specify first argument");let s=typeof t=="boolean"?{returnIndex:t}:t,r=s.returnIndex||!1,i=yv(n),o=i.filter(l=>typeof l=="string"&&l.charAt(0)===wd).map(l=>l.slice(1)).map(l=>Sd(l,s)),a=i.filter(l=>typeof l!="string"||typeof l=="string"&&l.charAt(0)!==wd).map(l=>bv(l,s));return e==null?(l,u=!1)=>xd(a,o,l,typeof u=="boolean"?u:!1):xd(a,o,e,r)};To.default=To;kd.exports=To});var Cd=N((yT,$d)=>{$d.exports=function(e){if(typeof e!="string"||e==="")return!1;for(var t;t=/(\\).|([@?!+*]\(.*\))/g.exec(e);){if(t[2])return!0;e=e.slice(t.index+t[0].length)}return!1}});var Eo=N((bT,Ed)=>{var vv=Cd(),Td={"{":"}","(":")","[":"]"},wv=function(n){if(n[0]==="!")return!0;for(var e=0,t=-2,s=-2,r=-2,i=-2,o=-2;e<n.length;){if(n[e]==="*"||n[e+1]==="?"&&/[\].+)]/.test(n[e])||s!==-1&&n[e]==="["&&n[e+1]!=="]"&&(s<e&&(s=n.indexOf("]",e)),s>e&&(o===-1||o>s||(o=n.indexOf("\\",e),o===-1||o>s)))||r!==-1&&n[e]==="{"&&n[e+1]!=="}"&&(r=n.indexOf("}",e),r>e&&(o=n.indexOf("\\",e),o===-1||o>r))||i!==-1&&n[e]==="("&&n[e+1]==="?"&&/[:!=]/.test(n[e+2])&&n[e+3]!==")"&&(i=n.indexOf(")",e),i>e&&(o=n.indexOf("\\",e),o===-1||o>i))||t!==-1&&n[e]==="("&&n[e+1]!=="|"&&(t<e&&(t=n.indexOf("|",e)),t!==-1&&n[t+1]!==")"&&(i=n.indexOf(")",t),i>t&&(o=n.indexOf("\\",t),o===-1||o>i))))return!0;if(n[e]==="\\"){var a=n[e+1];e+=2;var l=Td[a];if(l){var u=n.indexOf(l,e);u!==-1&&(e=u+1)}if(n[e]==="!")return!0}else e++}return!1},xv=function(n){if(n[0]==="!")return!0;for(var e=0;e<n.length;){if(/[*?{}()[\]]/.test(n[e]))return!0;if(n[e]==="\\"){var t=n[e+1];e+=2;var s=Td[t];if(s){var r=n.indexOf(s,e);r!==-1&&(e=r+1)}if(n[e]==="!")return!0}else e++}return!1};Ed.exports=function(e,t){if(typeof e!="string"||e==="")return!1;if(vv(e))return!0;var s=wv;return t&&t.strict===!1&&(s=xv),s(e)}});var Pd=N((vT,Rd)=>{"use strict";var Sv=Eo(),_v=require("path").posix.dirname,kv=require("os").platform()==="win32",Ro="/",Av=/\\/g,$v=/[\{\[].*[\}\]]$/,Cv=/(^|[^\\])([\{\[]|\([^\)]+$)/,Tv=/\\([\!\*\?\|\[\]\(\)\{\}])/g;Rd.exports=function(e,t){var s=Object.assign({flipBackslashes:!0},t);s.flipBackslashes&&kv&&e.indexOf(Ro)<0&&(e=e.replace(Av,Ro)),$v.test(e)&&(e+=Ro),e+="a";do e=_v(e);while(Sv(e)||Cv.test(e));return e.replace(Tv,"$1")}});var er=N(ze=>{"use strict";ze.isInteger=n=>typeof n=="number"?Number.isInteger(n):typeof n=="string"&&n.trim()!==""?Number.isInteger(Number(n)):!1;ze.find=(n,e)=>n.nodes.find(t=>t.type===e);ze.exceedsLimit=(n,e,t=1,s)=>s===!1||!ze.isInteger(n)||!ze.isInteger(e)?!1:(Number(e)-Number(n))/Number(t)>=s;ze.escapeNode=(n,e=0,t)=>{let s=n.nodes[e];s&&(t&&s.type===t||s.type==="open"||s.type==="close")&&s.escaped!==!0&&(s.value="\\"+s.value,s.escaped=!0)};ze.encloseBrace=n=>n.type!=="brace"?!1:n.commas>>0+n.ranges>>0===0?(n.invalid=!0,!0):!1;ze.isInvalidBrace=n=>n.type!=="brace"?!1:n.invalid===!0||n.dollar?!0:n.commas>>0+n.ranges>>0===0||n.open!==!0||n.close!==!0?(n.invalid=!0,!0):!1;ze.isOpenOrClose=n=>n.type==="open"||n.type==="close"?!0:n.open===!0||n.close===!0;ze.reduce=n=>n.reduce((e,t)=>(t.type==="text"&&e.push(t.value),t.type==="range"&&(t.type="text"),e),[]);ze.flatten=(...n)=>{let e=[],t=s=>{for(let r=0;r<s.length;r++){let i=s[r];if(Array.isArray(i)){t(i);continue}i!==void 0&&e.push(i)}return e};return t(n),e}});var tr=N((xT,Md)=>{"use strict";var Od=er();Md.exports=(n,e={})=>{let t=(s,r={})=>{let i=e.escapeInvalid&&Od.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a="";if(s.value)return(i||o)&&Od.isOpenOrClose(s)?"\\"+s.value:s.value;if(s.value)return s.value;if(s.nodes)for(let l of s.nodes)a+=t(l);return a};return t(n)}});var Dd=N((ST,Id)=>{"use strict";Id.exports=function(n){return typeof n=="number"?n-n===0:typeof n=="string"&&n.trim()!==""?Number.isFinite?Number.isFinite(+n):isFinite(+n):!1}});var Kd=N((_T,qd)=>{"use strict";var Ld=Dd(),en=(n,e,t)=>{if(Ld(n)===!1)throw new TypeError("toRegexRange: expected the first argument to be a number");if(e===void 0||n===e)return String(n);if(Ld(e)===!1)throw new TypeError("toRegexRange: expected the second argument to be a number.");let s={relaxZeros:!0,...t};typeof s.strictZeros=="boolean"&&(s.relaxZeros=s.strictZeros===!1);let r=String(s.relaxZeros),i=String(s.shorthand),o=String(s.capture),a=String(s.wrap),l=n+":"+e+"="+r+i+o+a;if(en.cache.hasOwnProperty(l))return en.cache[l].result;let u=Math.min(n,e),d=Math.max(n,e);if(Math.abs(u-d)===1){let g=n+"|"+e;return s.capture?`(${g})`:s.wrap===!1?g:`(?:${g})`}let f=Ud(n)||Ud(e),h={min:n,max:e,a:u,b:d},m=[],p=[];if(f&&(h.isPadded=f,h.maxLen=String(h.max).length),u<0){let g=d<0?Math.abs(d):1;p=Fd(g,Math.abs(u),h,s),u=h.a=0}return d>=0&&(m=Fd(u,d,h,s)),h.negatives=p,h.positives=m,h.result=Ev(p,m,s),s.capture===!0?h.result=`(${h.result})`:s.wrap!==!1&&m.length+p.length>1&&(h.result=`(?:${h.result})`),en.cache[l]=h,h.result};function Ev(n,e,t){let s=Po(n,e,"-",!1,t)||[],r=Po(e,n,"",!1,t)||[],i=Po(n,e,"-?",!0,t)||[];return s.concat(i).concat(r).join("|")}function Rv(n,e){let t=1,s=1,r=jd(n,t),i=new Set([e]);for(;n<=r&&r<=e;)i.add(r),t+=1,r=jd(n,t);for(r=Hd(e+1,s)-1;n<r&&r<=e;)i.add(r),s+=1,r=Hd(e+1,s)-1;return i=[...i],i.sort(Mv),i}function Pv(n,e,t){if(n===e)return{pattern:n,count:[],digits:0};let s=Ov(n,e),r=s.length,i="",o=0;for(let a=0;a<r;a++){let[l,u]=s[a];l===u?i+=l:l!=="0"||u!=="9"?i+=Iv(l,u,t):o++}return o&&(i+=t.shorthand===!0?"\\d":"[0-9]"),{pattern:i,count:[o],digits:r}}function Fd(n,e,t,s){let r=Rv(n,e),i=[],o=n,a;for(let l=0;l<r.length;l++){let u=r[l],d=Pv(String(o),String(u),s),f="";if(!t.isPadded&&a&&a.pattern===d.pattern){a.count.length>1&&a.count.pop(),a.count.push(d.count[0]),a.string=a.pattern+Bd(a.count),o=u+1;continue}t.isPadded&&(f=Dv(u,t,s)),d.string=f+d.pattern+Bd(d.count),i.push(d),o=u+1,a=d}return i}function Po(n,e,t,s,r){let i=[];for(let o of n){let{string:a}=o;!s&&!Nd(e,"string",a)&&i.push(t+a),s&&Nd(e,"string",a)&&i.push(t+a)}return i}function Ov(n,e){let t=[];for(let s=0;s<n.length;s++)t.push([n[s],e[s]]);return t}function Mv(n,e){return n>e?1:e>n?-1:0}function Nd(n,e,t){return n.some(s=>s[e]===t)}function jd(n,e){return Number(String(n).slice(0,-e)+"9".repeat(e))}function Hd(n,e){return n-n%Math.pow(10,e)}function Bd(n){let[e=0,t=""]=n;return t||e>1?`{${e+(t?","+t:"")}}`:""}function Iv(n,e,t){return`[${n}${e-n===1?"":"-"}${e}]`}function Ud(n){return/^-?(0+)\d/.test(n)}function Dv(n,e,t){if(!e.isPadded)return n;let s=Math.abs(e.maxLen-String(n).length),r=t.relaxZeros!==!1;switch(s){case 0:return"";case 1:return r?"0?":"0";case 2:return r?"0{0,2}":"00";default:return r?`0{0,${s}}`:`0{${s}}`}}en.cache={};en.clearCache=()=>en.cache={};qd.exports=en});var Io=N((kT,Xd)=>{"use strict";var Lv=require("util"),Gd=Kd(),Wd=n=>n!==null&&typeof n=="object"&&!Array.isArray(n),Fv=n=>e=>n===!0?Number(e):String(e),Oo=n=>typeof n=="number"||typeof n=="string"&&n!=="",ts=n=>Number.isInteger(+n),Mo=n=>{let e=`${n}`,t=-1;if(e[0]==="-"&&(e=e.slice(1)),e==="0")return!1;for(;e[++t]==="0";);return t>0},Nv=(n,e,t)=>typeof n=="string"||typeof e=="string"?!0:t.stringify===!0,jv=(n,e,t)=>{if(e>0){let s=n[0]==="-"?"-":"";s&&(n=n.slice(1)),n=s+n.padStart(s?e-1:e,"0")}return t===!1?String(n):n},sr=(n,e)=>{let t=n[0]==="-"?"-":"";for(t&&(n=n.slice(1),e--);n.length<e;)n="0"+n;return t?"-"+n:n},Hv=(n,e,t)=>{n.negatives.sort((a,l)=>a<l?-1:a>l?1:0),n.positives.sort((a,l)=>a<l?-1:a>l?1:0);let s=e.capture?"":"?:",r="",i="",o;return n.positives.length&&(r=n.positives.map(a=>sr(String(a),t)).join("|")),n.negatives.length&&(i=`-(${s}${n.negatives.map(a=>sr(String(a),t)).join("|")})`),r&&i?o=`${r}|${i}`:o=r||i,e.wrap?`(${s}${o})`:o},Vd=(n,e,t,s)=>{if(t)return Gd(n,e,{wrap:!1,...s});let r=String.fromCharCode(n);if(n===e)return r;let i=String.fromCharCode(e);return`[${r}-${i}]`},zd=(n,e,t)=>{if(Array.isArray(n)){let s=t.wrap===!0,r=t.capture?"":"?:";return s?`(${r}${n.join("|")})`:n.join("|")}return Gd(n,e,t)},Yd=(...n)=>new RangeError("Invalid range arguments: "+Lv.inspect(...n)),Jd=(n,e,t)=>{if(t.strictRanges===!0)throw Yd([n,e]);return[]},Bv=(n,e)=>{if(e.strictRanges===!0)throw new TypeError(`Expected step "${n}" to be a number`);return[]},Uv=(n,e,t=1,s={})=>{let r=Number(n),i=Number(e);if(!Number.isInteger(r)||!Number.isInteger(i)){if(s.strictRanges===!0)throw Yd([n,e]);return[]}r===0&&(r=0),i===0&&(i=0);let o=r>i,a=String(n),l=String(e),u=String(t);t=Math.max(Math.abs(t),1);let d=Mo(a)||Mo(l)||Mo(u),f=d?Math.max(a.length,l.length,u.length):0,h=d===!1&&Nv(n,e,s)===!1,m=s.transform||Fv(h);if(s.toRegex&&t===1)return Vd(sr(n,f),sr(e,f),!0,s);let p={negatives:[],positives:[]},g=k=>p[k<0?"negatives":"positives"].push(Math.abs(k)),w=[],_=0;for(;o?r>=i:r<=i;)s.toRegex===!0&&t>1?g(r):w.push(jv(m(r,_),f,h)),r=o?r-t:r+t,_++;return s.toRegex===!0?t>1?Hv(p,s,f):zd(w,null,{wrap:!1,...s}):w},qv=(n,e,t=1,s={})=>{if(!ts(n)&&n.length>1||!ts(e)&&e.length>1)return Jd(n,e,s);let r=s.transform||(h=>String.fromCharCode(h)),i=`${n}`.charCodeAt(0),o=`${e}`.charCodeAt(0),a=i>o,l=Math.min(i,o),u=Math.max(i,o);if(s.toRegex&&t===1)return Vd(l,u,!1,s);let d=[],f=0;for(;a?i>=o:i<=o;)d.push(r(i,f)),i=a?i-t:i+t,f++;return s.toRegex===!0?zd(d,null,{wrap:!1,options:s}):d},nr=(n,e,t,s={})=>{if(e==null&&Oo(n))return[n];if(!Oo(n)||!Oo(e))return Jd(n,e,s);if(typeof t=="function")return nr(n,e,1,{transform:t});if(Wd(t))return nr(n,e,0,t);let r={...s};return r.capture===!0&&(r.wrap=!0),t=t||r.step||1,ts(t)?ts(n)&&ts(e)?Uv(n,e,t,r):qv(n,e,Math.max(Math.abs(t),1),r):t!=null&&!Wd(t)?Bv(t,r):nr(n,e,1,t)};Xd.exports=nr});var ef=N((AT,Zd)=>{"use strict";var Kv=Io(),Qd=er(),Wv=(n,e={})=>{let t=(s,r={})=>{let i=Qd.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a=i===!0||o===!0,l=e.escapeInvalid===!0?"\\":"",u="";if(s.isOpen===!0)return l+s.value;if(s.isClose===!0)return console.log("node.isClose",l,s.value),l+s.value;if(s.type==="open")return a?l+s.value:"(";if(s.type==="close")return a?l+s.value:")";if(s.type==="comma")return s.prev.type==="comma"?"":a?s.value:"|";if(s.value)return s.value;if(s.nodes&&s.ranges>0){let d=Qd.reduce(s.nodes),f=Kv(...d,{...e,wrap:!1,toRegex:!0,strictZeros:!0});if(f.length!==0)return d.length>1&&f.length>1?`(${f})`:f}if(s.nodes)for(let d of s.nodes)u+=t(d,s);return u};return t(n)};Zd.exports=Wv});var sf=N(($T,nf)=>{"use strict";var Gv=Io(),tf=tr(),kn=er(),tn=(n="",e="",t=!1)=>{let s=[];if(n=[].concat(n),e=[].concat(e),!e.length)return n;if(!n.length)return t?kn.flatten(e).map(r=>`{${r}}`):e;for(let r of n)if(Array.isArray(r))for(let i of r)s.push(tn(i,e,t));else for(let i of e)t===!0&&typeof i=="string"&&(i=`{${i}}`),s.push(Array.isArray(i)?tn(r,i,t):r+i);return kn.flatten(s)},Vv=(n,e={})=>{let t=e.rangeLimit===void 0?1e3:e.rangeLimit,s=(r,i={})=>{r.queue=[];let o=i,a=i.queue;for(;o.type!=="brace"&&o.type!=="root"&&o.parent;)o=o.parent,a=o.queue;if(r.invalid||r.dollar){a.push(tn(a.pop(),tf(r,e)));return}if(r.type==="brace"&&r.invalid!==!0&&r.nodes.length===2){a.push(tn(a.pop(),["{}"]));return}if(r.nodes&&r.ranges>0){let f=kn.reduce(r.nodes);if(kn.exceedsLimit(...f,e.step,t))throw new RangeError("expanded array length exceeds range limit. Use options.rangeLimit to increase or disable the limit.");let h=Gv(...f,e);h.length===0&&(h=tf(r,e)),a.push(tn(a.pop(),h)),r.nodes=[];return}let l=kn.encloseBrace(r),u=r.queue,d=r;for(;d.type!=="brace"&&d.type!=="root"&&d.parent;)d=d.parent,u=d.queue;for(let f=0;f<r.nodes.length;f++){let h=r.nodes[f];if(h.type==="comma"&&r.type==="brace"){f===1&&u.push(""),u.push("");continue}if(h.type==="close"){a.push(tn(a.pop(),u,l));continue}if(h.value&&h.type!=="open"){u.push(tn(u.pop(),h.value));continue}h.nodes&&s(h,r)}return u};return kn.flatten(s(n))};nf.exports=Vv});var of=N((CT,rf)=>{"use strict";rf.exports={MAX_LENGTH:1e4,CHAR_0:"0",CHAR_9:"9",CHAR_UPPERCASE_A:"A",CHAR_LOWERCASE_A:"a",CHAR_UPPERCASE_Z:"Z",CHAR_LOWERCASE_Z:"z",CHAR_LEFT_PARENTHESES:"(",CHAR_RIGHT_PARENTHESES:")",CHAR_ASTERISK:"*",CHAR_AMPERSAND:"&",CHAR_AT:"@",CHAR_BACKSLASH:"\\",CHAR_BACKTICK:"`",CHAR_CARRIAGE_RETURN:"\r",CHAR_CIRCUMFLEX_ACCENT:"^",CHAR_COLON:":",CHAR_COMMA:",",CHAR_DOLLAR:"$",CHAR_DOT:".",CHAR_DOUBLE_QUOTE:'"',CHAR_EQUAL:"=",CHAR_EXCLAMATION_MARK:"!",CHAR_FORM_FEED:"\f",CHAR_FORWARD_SLASH:"/",CHAR_HASH:"#",CHAR_HYPHEN_MINUS:"-",CHAR_LEFT_ANGLE_BRACKET:"<",CHAR_LEFT_CURLY_BRACE:"{",CHAR_LEFT_SQUARE_BRACKET:"[",CHAR_LINE_FEED:`
|
|
297
|
-
`,CHAR_NO_BREAK_SPACE:"\xA0",CHAR_PERCENT:"%",CHAR_PLUS:"+",CHAR_QUESTION_MARK:"?",CHAR_RIGHT_ANGLE_BRACKET:">",CHAR_RIGHT_CURLY_BRACE:"}",CHAR_RIGHT_SQUARE_BRACKET:"]",CHAR_SEMICOLON:";",CHAR_SINGLE_QUOTE:"'",CHAR_SPACE:" ",CHAR_TAB:" ",CHAR_UNDERSCORE:"_",CHAR_VERTICAL_LINE:"|",CHAR_ZERO_WIDTH_NOBREAK_SPACE:"\uFEFF"}});var df=N((TT,uf)=>{"use strict";var zv=tr(),{MAX_LENGTH:af,CHAR_BACKSLASH:Do,CHAR_BACKTICK:Yv,CHAR_COMMA:Jv,CHAR_DOT:Xv,CHAR_LEFT_PARENTHESES:Qv,CHAR_RIGHT_PARENTHESES:Zv,CHAR_LEFT_CURLY_BRACE:ew,CHAR_RIGHT_CURLY_BRACE:tw,CHAR_LEFT_SQUARE_BRACKET:lf,CHAR_RIGHT_SQUARE_BRACKET:cf,CHAR_DOUBLE_QUOTE:nw,CHAR_SINGLE_QUOTE:sw,CHAR_NO_BREAK_SPACE:rw,CHAR_ZERO_WIDTH_NOBREAK_SPACE:iw}=of(),ow=(n,e={})=>{if(typeof n!="string")throw new TypeError("Expected a string");let t=e||{},s=typeof t.maxLength=="number"?Math.min(af,t.maxLength):af;if(n.length>s)throw new SyntaxError(`Input length (${n.length}), exceeds max characters (${s})`);let r={type:"root",input:n,nodes:[]},i=[r],o=r,a=r,l=0,u=n.length,d=0,f=0,h,m=()=>n[d++],p=g=>{if(g.type==="text"&&a.type==="dot"&&(a.type="text"),a&&a.type==="text"&&g.type==="text"){a.value+=g.value;return}return o.nodes.push(g),g.parent=o,g.prev=a,a=g,g};for(p({type:"bos"});d<u;)if(o=i[i.length-1],h=m(),!(h===iw||h===rw)){if(h===Do){p({type:"text",value:(e.keepEscaping?h:"")+m()});continue}if(h===cf){p({type:"text",value:"\\"+h});continue}if(h===lf){l++;let g;for(;d<u&&(g=m());){if(h+=g,g===lf){l++;continue}if(g===Do){h+=m();continue}if(g===cf&&(l--,l===0))break}p({type:"text",value:h});continue}if(h===Qv){o=p({type:"paren",nodes:[]}),i.push(o),p({type:"text",value:h});continue}if(h===Zv){if(o.type!=="paren"){p({type:"text",value:h});continue}o=i.pop(),p({type:"text",value:h}),o=i[i.length-1];continue}if(h===nw||h===sw||h===Yv){let g=h,w;for(e.keepQuotes!==!0&&(h="");d<u&&(w=m());){if(w===Do){h+=w+m();continue}if(w===g){e.keepQuotes===!0&&(h+=w);break}h+=w}p({type:"text",value:h});continue}if(h===ew){f++;let w={type:"brace",open:!0,close:!1,dollar:a.value&&a.value.slice(-1)==="$"||o.dollar===!0,depth:f,commas:0,ranges:0,nodes:[]};o=p(w),i.push(o),p({type:"open",value:h});continue}if(h===tw){if(o.type!=="brace"){p({type:"text",value:h});continue}let g="close";o=i.pop(),o.close=!0,p({type:g,value:h}),f--,o=i[i.length-1];continue}if(h===Jv&&f>0){if(o.ranges>0){o.ranges=0;let g=o.nodes.shift();o.nodes=[g,{type:"text",value:zv(o)}]}p({type:"comma",value:h}),o.commas++;continue}if(h===Xv&&f>0&&o.commas===0){let g=o.nodes;if(f===0||g.length===0){p({type:"text",value:h});continue}if(a.type==="dot"){if(o.range=[],a.value+=h,a.type="range",o.nodes.length!==3&&o.nodes.length!==5){o.invalid=!0,o.ranges=0,a.type="text";continue}o.ranges++,o.args=[];continue}if(a.type==="range"){g.pop();let w=g[g.length-1];w.value+=a.value+h,a=w,o.ranges--;continue}p({type:"dot",value:h});continue}p({type:"text",value:h})}do if(o=i.pop(),o.type!=="root"){o.nodes.forEach(_=>{_.nodes||(_.type==="open"&&(_.isOpen=!0),_.type==="close"&&(_.isClose=!0),_.nodes||(_.type="text"),_.invalid=!0)});let g=i[i.length-1],w=g.nodes.indexOf(o);g.nodes.splice(w,1,...o.nodes)}while(i.length>0);return p({type:"eos"}),r};uf.exports=ow});var hf=N((ET,pf)=>{"use strict";var ff=tr(),aw=ef(),lw=sf(),cw=df(),qe=(n,e={})=>{let t=[];if(Array.isArray(n))for(let s of n){let r=qe.create(s,e);Array.isArray(r)?t.push(...r):t.push(r)}else t=[].concat(qe.create(n,e));return e&&e.expand===!0&&e.nodupes===!0&&(t=[...new Set(t)]),t};qe.parse=(n,e={})=>cw(n,e);qe.stringify=(n,e={})=>ff(typeof n=="string"?qe.parse(n,e):n,e);qe.compile=(n,e={})=>(typeof n=="string"&&(n=qe.parse(n,e)),aw(n,e));qe.expand=(n,e={})=>{typeof n=="string"&&(n=qe.parse(n,e));let t=lw(n,e);return e.noempty===!0&&(t=t.filter(Boolean)),e.nodupes===!0&&(t=[...new Set(t)]),t};qe.create=(n,e={})=>n===""||n.length<3?[n]:e.expand!==!0?qe.compile(n,e):qe.expand(n,e);pf.exports=qe});var mf=N((RT,uw)=>{uw.exports=["3dm","3ds","3g2","3gp","7z","a","aac","adp","afdesign","afphoto","afpub","ai","aif","aiff","alz","ape","apk","appimage","ar","arj","asf","au","avi","bak","baml","bh","bin","bk","bmp","btif","bz2","bzip2","cab","caf","cgm","class","cmx","cpio","cr2","cur","dat","dcm","deb","dex","djvu","dll","dmg","dng","doc","docm","docx","dot","dotm","dra","DS_Store","dsk","dts","dtshd","dvb","dwg","dxf","ecelp4800","ecelp7470","ecelp9600","egg","eol","eot","epub","exe","f4v","fbs","fh","fla","flac","flatpak","fli","flv","fpx","fst","fvt","g3","gh","gif","graffle","gz","gzip","h261","h263","h264","icns","ico","ief","img","ipa","iso","jar","jpeg","jpg","jpgv","jpm","jxr","key","ktx","lha","lib","lvp","lz","lzh","lzma","lzo","m3u","m4a","m4v","mar","mdi","mht","mid","midi","mj2","mka","mkv","mmr","mng","mobi","mov","movie","mp3","mp4","mp4a","mpeg","mpg","mpga","mxu","nef","npx","numbers","nupkg","o","odp","ods","odt","oga","ogg","ogv","otf","ott","pages","pbm","pcx","pdb","pdf","pea","pgm","pic","png","pnm","pot","potm","potx","ppa","ppam","ppm","pps","ppsm","ppsx","ppt","pptm","pptx","psd","pya","pyc","pyo","pyv","qt","rar","ras","raw","resources","rgb","rip","rlc","rmf","rmvb","rpm","rtf","rz","s3m","s7z","scpt","sgi","shar","snap","sil","sketch","slk","smv","snk","so","stl","suo","sub","swf","tar","tbz","tbz2","tga","tgz","thmx","tif","tiff","tlz","ttc","ttf","txz","udf","uvh","uvi","uvm","uvp","uvs","uvu","viv","vob","war","wav","wax","wbmp","wdp","weba","webm","webp","whl","wim","wm","wma","wmv","wmx","woff","woff2","wrm","wvx","xbm","xif","xla","xlam","xls","xlsb","xlsm","xlsx","xlt","xltm","xltx","xm","xmind","xpi","xpm","xwd","xz","z","zip","zipx"]});var yf=N((PT,gf)=>{gf.exports=mf()});var vf=N((OT,bf)=>{"use strict";var dw=require("path"),fw=yf(),pw=new Set(fw);bf.exports=n=>pw.has(dw.extname(n).slice(1).toLowerCase())});var rr=N(B=>{"use strict";var{sep:hw}=require("path"),{platform:Lo}=process,mw=require("os");B.EV_ALL="all";B.EV_READY="ready";B.EV_ADD="add";B.EV_CHANGE="change";B.EV_ADD_DIR="addDir";B.EV_UNLINK="unlink";B.EV_UNLINK_DIR="unlinkDir";B.EV_RAW="raw";B.EV_ERROR="error";B.STR_DATA="data";B.STR_END="end";B.STR_CLOSE="close";B.FSEVENT_CREATED="created";B.FSEVENT_MODIFIED="modified";B.FSEVENT_DELETED="deleted";B.FSEVENT_MOVED="moved";B.FSEVENT_CLONED="cloned";B.FSEVENT_UNKNOWN="unknown";B.FSEVENT_FLAG_MUST_SCAN_SUBDIRS=1;B.FSEVENT_TYPE_FILE="file";B.FSEVENT_TYPE_DIRECTORY="directory";B.FSEVENT_TYPE_SYMLINK="symlink";B.KEY_LISTENERS="listeners";B.KEY_ERR="errHandlers";B.KEY_RAW="rawEmitters";B.HANDLER_KEYS=[B.KEY_LISTENERS,B.KEY_ERR,B.KEY_RAW];B.DOT_SLASH=`.${hw}`;B.BACK_SLASH_RE=/\\/g;B.DOUBLE_SLASH_RE=/\/\//;B.SLASH_OR_BACK_SLASH_RE=/[/\\]/;B.DOT_RE=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/;B.REPLACER_RE=/^\.[/\\]/;B.SLASH="/";B.SLASH_SLASH="//";B.BRACE_START="{";B.BANG="!";B.ONE_DOT=".";B.TWO_DOTS="..";B.STAR="*";B.GLOBSTAR="**";B.ROOT_GLOBSTAR="/**/*";B.SLASH_GLOBSTAR="/**";B.DIR_SUFFIX="Dir";B.ANYMATCH_OPTS={dot:!0};B.STRING_TYPE="string";B.FUNCTION_TYPE="function";B.EMPTY_STR="";B.EMPTY_FN=()=>{};B.IDENTITY_FN=n=>n;B.isWindows=Lo==="win32";B.isMacos=Lo==="darwin";B.isLinux=Lo==="linux";B.isIBMi=mw.type()==="OS400"});var Af=N((IT,kf)=>{"use strict";var Rt=require("fs"),_e=require("path"),{promisify:is}=require("util"),gw=vf(),{isWindows:yw,isLinux:bw,EMPTY_FN:vw,EMPTY_STR:ww,KEY_LISTENERS:An,KEY_ERR:Fo,KEY_RAW:ns,HANDLER_KEYS:xw,EV_CHANGE:or,EV_ADD:ir,EV_ADD_DIR:Sw,EV_ERROR:xf,STR_DATA:_w,STR_END:kw,BRACE_START:Aw,STAR:$w}=rr(),Cw="watch",Tw=is(Rt.open),Sf=is(Rt.stat),Ew=is(Rt.lstat),Rw=is(Rt.close),No=is(Rt.realpath),Pw={lstat:Ew,stat:Sf},Ho=(n,e)=>{n instanceof Set?n.forEach(e):e(n)},ss=(n,e,t)=>{let s=n[e];s instanceof Set||(n[e]=s=new Set([s])),s.add(t)},Ow=n=>e=>{let t=n[e];t instanceof Set?t.clear():delete n[e]},rs=(n,e,t)=>{let s=n[e];s instanceof Set?s.delete(t):s===t&&delete n[e]},_f=n=>n instanceof Set?n.size===0:!n,ar=new Map;function wf(n,e,t,s,r){let i=(o,a)=>{t(n),r(o,a,{watchedPath:n}),a&&n!==a&&lr(_e.resolve(n,a),An,_e.join(n,a))};try{return Rt.watch(n,e,i)}catch(o){s(o)}}var lr=(n,e,t,s,r)=>{let i=ar.get(n);i&&Ho(i[e],o=>{o(t,s,r)})},Mw=(n,e,t,s)=>{let{listener:r,errHandler:i,rawEmitter:o}=s,a=ar.get(e),l;if(!t.persistent)return l=wf(n,t,r,i,o),l.close.bind(l);if(a)ss(a,An,r),ss(a,Fo,i),ss(a,ns,o);else{if(l=wf(n,t,lr.bind(null,e,An),i,lr.bind(null,e,ns)),!l)return;l.on(xf,async u=>{let d=lr.bind(null,e,Fo);if(a.watcherUnusable=!0,yw&&u.code==="EPERM")try{let f=await Tw(n,"r");await Rw(f),d(u)}catch{}else d(u)}),a={listeners:r,errHandlers:i,rawEmitters:o,watcher:l},ar.set(e,a)}return()=>{rs(a,An,r),rs(a,Fo,i),rs(a,ns,o),_f(a.listeners)&&(a.watcher.close(),ar.delete(e),xw.forEach(Ow(a)),a.watcher=void 0,Object.freeze(a))}},jo=new Map,Iw=(n,e,t,s)=>{let{listener:r,rawEmitter:i}=s,o=jo.get(e),a=new Set,l=new Set,u=o&&o.options;return u&&(u.persistent<t.persistent||u.interval>t.interval)&&(a=o.listeners,l=o.rawEmitters,Rt.unwatchFile(e),o=void 0),o?(ss(o,An,r),ss(o,ns,i)):(o={listeners:r,rawEmitters:i,options:t,watcher:Rt.watchFile(e,t,(d,f)=>{Ho(o.rawEmitters,m=>{m(or,e,{curr:d,prev:f})});let h=d.mtimeMs;(d.size!==f.size||h>f.mtimeMs||h===0)&&Ho(o.listeners,m=>m(n,d))})},jo.set(e,o)),()=>{rs(o,An,r),rs(o,ns,i),_f(o.listeners)&&(jo.delete(e),Rt.unwatchFile(e),o.options=o.watcher=void 0,Object.freeze(o))}},Bo=class{constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let s=this.fsw.options,r=_e.dirname(e),i=_e.basename(e);this.fsw._getWatchedDir(r).add(i);let a=_e.resolve(e),l={persistent:s.persistent};t||(t=vw);let u;return s.usePolling?(l.interval=s.enableBinaryInterval&&gw(i)?s.binaryInterval:s.interval,u=Iw(e,a,l,{listener:t,rawEmitter:this.fsw._emitRaw})):u=Mw(e,a,l,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw}),u}_handleFile(e,t,s){if(this.fsw.closed)return;let r=_e.dirname(e),i=_e.basename(e),o=this.fsw._getWatchedDir(r),a=t;if(o.has(i))return;let l=async(d,f)=>{if(this.fsw._throttle(Cw,e,5)){if(!f||f.mtimeMs===0)try{let h=await Sf(e);if(this.fsw.closed)return;let m=h.atimeMs,p=h.mtimeMs;(!m||m<=p||p!==a.mtimeMs)&&this.fsw._emit(or,e,h),bw&&a.ino!==h.ino?(this.fsw._closeFile(d),a=h,this.fsw._addPathCloser(d,this._watchWithNodeFs(e,l))):a=h}catch{this.fsw._remove(r,i)}else if(o.has(i)){let h=f.atimeMs,m=f.mtimeMs;(!h||h<=m||m!==a.mtimeMs)&&this.fsw._emit(or,e,f),a=f}}},u=this._watchWithNodeFs(e,l);if(!(s&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(ir,e,0))return;this.fsw._emit(ir,e,t)}return u}async _handleSymlink(e,t,s,r){if(this.fsw.closed)return;let i=e.fullPath,o=this.fsw._getWatchedDir(t);if(!this.fsw.options.followSymlinks){this.fsw._incrReadyCount();let a;try{a=await No(s)}catch{return this.fsw._emitReady(),!0}return this.fsw.closed?void 0:(o.has(r)?this.fsw._symlinkPaths.get(i)!==a&&(this.fsw._symlinkPaths.set(i,a),this.fsw._emit(or,s,e.stats)):(o.add(r),this.fsw._symlinkPaths.set(i,a),this.fsw._emit(ir,s,e.stats)),this.fsw._emitReady(),!0)}if(this.fsw._symlinkPaths.has(i))return!0;this.fsw._symlinkPaths.set(i,!0)}_handleRead(e,t,s,r,i,o,a){if(e=_e.join(e,ww),!s.hasGlob&&(a=this.fsw._throttle("readdir",e,1e3),!a))return;let l=this.fsw._getWatchedDir(s.path),u=new Set,d=this.fsw._readdirp(e,{fileFilter:f=>s.filterPath(f),directoryFilter:f=>s.filterDir(f),depth:0}).on(_w,async f=>{if(this.fsw.closed){d=void 0;return}let h=f.path,m=_e.join(e,h);if(u.add(h),!(f.stats.isSymbolicLink()&&await this._handleSymlink(f,e,m,h))){if(this.fsw.closed){d=void 0;return}(h===r||!r&&!l.has(h))&&(this.fsw._incrReadyCount(),m=_e.join(i,_e.relative(i,m)),this._addToNodeFs(m,t,s,o+1))}}).on(xf,this._boundHandleError);return new Promise(f=>d.once(kw,()=>{if(this.fsw.closed){d=void 0;return}let h=a?a.clear():!1;f(),l.getChildren().filter(m=>m!==e&&!u.has(m)&&(!s.hasGlob||s.filterPath({fullPath:_e.resolve(e,m)}))).forEach(m=>{this.fsw._remove(e,m)}),d=void 0,h&&this._handleRead(e,!1,s,r,i,o,a)}))}async _handleDir(e,t,s,r,i,o,a){let l=this.fsw._getWatchedDir(_e.dirname(e)),u=l.has(_e.basename(e));!(s&&this.fsw.options.ignoreInitial)&&!i&&!u&&(!o.hasGlob||o.globFilter(e))&&this.fsw._emit(Sw,e,t),l.add(_e.basename(e)),this.fsw._getWatchedDir(e);let d,f,h=this.fsw.options.depth;if((h==null||r<=h)&&!this.fsw._symlinkPaths.has(a)){if(!i&&(await this._handleRead(e,s,o,i,e,r,d),this.fsw.closed))return;f=this._watchWithNodeFs(e,(m,p)=>{p&&p.mtimeMs===0||this._handleRead(m,!1,o,i,e,r,d)})}return f}async _addToNodeFs(e,t,s,r,i){let o=this.fsw._emitReady;if(this.fsw._isIgnored(e)||this.fsw.closed)return o(),!1;let a=this.fsw._getWatchHelpers(e,r);!a.hasGlob&&s&&(a.hasGlob=s.hasGlob,a.globFilter=s.globFilter,a.filterPath=l=>s.filterPath(l),a.filterDir=l=>s.filterDir(l));try{let l=await Pw[a.statMethod](a.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(a.watchPath,l))return o(),!1;let u=this.fsw.options.followSymlinks&&!e.includes($w)&&!e.includes(Aw),d;if(l.isDirectory()){let f=_e.resolve(e),h=u?await No(e):e;if(this.fsw.closed||(d=await this._handleDir(a.watchPath,l,t,r,i,a,h),this.fsw.closed))return;f!==h&&h!==void 0&&this.fsw._symlinkPaths.set(f,h)}else if(l.isSymbolicLink()){let f=u?await No(e):e;if(this.fsw.closed)return;let h=_e.dirname(a.watchPath);if(this.fsw._getWatchedDir(h).add(a.watchPath),this.fsw._emit(ir,a.watchPath,l),d=await this._handleDir(h,l,t,r,e,a,f),this.fsw.closed)return;f!==void 0&&this.fsw._symlinkPaths.set(_e.resolve(e),f)}else d=this._handleFile(a.watchPath,l,t);return o(),this.fsw._addPathCloser(e,d),!1}catch(l){if(this.fsw._handleError(l))return o(),e}}};kf.exports=Bo});var Of=N((DT,Yo)=>{"use strict";var Vo=require("fs"),ke=require("path"),{promisify:zo}=require("util"),$n;try{$n=require("fsevents")}catch(n){process.env.CHOKIDAR_PRINT_FSEVENTS_REQUIRE_ERROR&&console.error(n)}if($n){let n=process.version.match(/v(\d+)\.(\d+)/);if(n&&n[1]&&n[2]){let e=Number.parseInt(n[1],10),t=Number.parseInt(n[2],10);e===8&&t<16&&($n=void 0)}}var{EV_ADD:Uo,EV_CHANGE:Dw,EV_ADD_DIR:$f,EV_UNLINK:cr,EV_ERROR:Lw,STR_DATA:Fw,STR_END:Nw,FSEVENT_CREATED:jw,FSEVENT_MODIFIED:Hw,FSEVENT_DELETED:Bw,FSEVENT_MOVED:Uw,FSEVENT_UNKNOWN:qw,FSEVENT_FLAG_MUST_SCAN_SUBDIRS:Kw,FSEVENT_TYPE_FILE:Ww,FSEVENT_TYPE_DIRECTORY:os,FSEVENT_TYPE_SYMLINK:Pf,ROOT_GLOBSTAR:Cf,DIR_SUFFIX:Gw,DOT_SLASH:Tf,FUNCTION_TYPE:qo,EMPTY_FN:Vw,IDENTITY_FN:zw}=rr(),Yw=n=>isNaN(n)?{}:{depth:n},Wo=zo(Vo.stat),Jw=zo(Vo.lstat),Ef=zo(Vo.realpath),Xw={stat:Wo,lstat:Jw},nn=new Map,Qw=10,Zw=new Set([69888,70400,71424,72704,73472,131328,131840,262912]),ex=(n,e)=>({stop:$n.watch(n,e)});function tx(n,e,t,s){let r=ke.extname(e)?ke.dirname(e):e,i=ke.dirname(r),o=nn.get(r);nx(i)&&(r=i);let a=ke.resolve(n),l=a!==e,u=(f,h,m)=>{l&&(f=f.replace(e,a)),(f===a||!f.indexOf(a+ke.sep))&&t(f,h,m)},d=!1;for(let f of nn.keys())if(e.indexOf(ke.resolve(f)+ke.sep)===0){r=f,o=nn.get(r),d=!0;break}return o||d?o.listeners.add(u):(o={listeners:new Set([u]),rawEmitter:s,watcher:ex(r,(f,h)=>{if(!o.listeners.size||h&Kw)return;let m=$n.getInfo(f,h);o.listeners.forEach(p=>{p(f,h,m)}),o.rawEmitter(m.event,f,m)})},nn.set(r,o)),()=>{let f=o.listeners;if(f.delete(u),!f.size&&(nn.delete(r),o.watcher))return o.watcher.stop().then(()=>{o.rawEmitter=o.watcher=void 0,Object.freeze(o)})}}var nx=n=>{let e=0;for(let t of nn.keys())if(t.indexOf(n)===0&&(e++,e>=Qw))return!0;return!1},sx=()=>$n&&nn.size<128,Ko=(n,e)=>{let t=0;for(;!n.indexOf(e)&&(n=ke.dirname(n))!==e;)t++;return t},Rf=(n,e)=>n.type===os&&e.isDirectory()||n.type===Pf&&e.isSymbolicLink()||n.type===Ww&&e.isFile(),Go=class{constructor(e){this.fsw=e}checkIgnored(e,t){let s=this.fsw._ignoredPaths;if(this.fsw._isIgnored(e,t))return s.add(e),t&&t.isDirectory()&&s.add(e+Cf),!0;s.delete(e),s.delete(e+Cf)}addOrChange(e,t,s,r,i,o,a,l){let u=i.has(o)?Dw:Uo;this.handleEvent(u,e,t,s,r,i,o,a,l)}async checkExists(e,t,s,r,i,o,a,l){try{let u=await Wo(e);if(this.fsw.closed)return;Rf(a,u)?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(cr,e,t,s,r,i,o,a,l)}catch(u){u.code==="EACCES"?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(cr,e,t,s,r,i,o,a,l)}}handleEvent(e,t,s,r,i,o,a,l,u){if(!(this.fsw.closed||this.checkIgnored(t)))if(e===cr){let d=l.type===os;(d||o.has(a))&&this.fsw._remove(i,a,d)}else{if(e===Uo){if(l.type===os&&this.fsw._getWatchedDir(t),l.type===Pf&&u.followSymlinks){let f=u.depth===void 0?void 0:Ko(s,r)+1;return this._addToFsEvents(t,!1,!0,f)}this.fsw._getWatchedDir(i).add(a)}let d=l.type===os?e+Gw:e;this.fsw._emit(d,t),d===$f&&this._addToFsEvents(t,!1,!0)}}_watchWithFsEvents(e,t,s,r){if(this.fsw.closed||this.fsw._isIgnored(e))return;let i=this.fsw.options,a=tx(e,t,async(l,u,d)=>{if(this.fsw.closed||i.depth!==void 0&&Ko(l,t)>i.depth)return;let f=s(ke.join(e,ke.relative(e,l)));if(r&&!r(f))return;let h=ke.dirname(f),m=ke.basename(f),p=this.fsw._getWatchedDir(d.type===os?f:h);if(Zw.has(u)||d.event===qw)if(typeof i.ignored===qo){let g;try{g=await Wo(f)}catch{}if(this.fsw.closed||this.checkIgnored(f,g))return;Rf(d,g)?this.addOrChange(f,l,t,h,p,m,d,i):this.handleEvent(cr,f,l,t,h,p,m,d,i)}else this.checkExists(f,l,t,h,p,m,d,i);else switch(d.event){case jw:case Hw:return this.addOrChange(f,l,t,h,p,m,d,i);case Bw:case Uw:return this.checkExists(f,l,t,h,p,m,d,i)}},this.fsw._emitRaw);return this.fsw._emitReady(),a}async _handleFsEventsSymlink(e,t,s,r){if(!(this.fsw.closed||this.fsw._symlinkPaths.has(t))){this.fsw._symlinkPaths.set(t,!0),this.fsw._incrReadyCount();try{let i=await Ef(e);if(this.fsw.closed)return;if(this.fsw._isIgnored(i))return this.fsw._emitReady();this.fsw._incrReadyCount(),this._addToFsEvents(i||e,o=>{let a=e;return i&&i!==Tf?a=o.replace(i,e):o!==Tf&&(a=ke.join(e,o)),s(a)},!1,r)}catch(i){if(this.fsw._handleError(i))return this.fsw._emitReady()}}}emitAdd(e,t,s,r,i){let o=s(e),a=t.isDirectory(),l=this.fsw._getWatchedDir(ke.dirname(o)),u=ke.basename(o);a&&this.fsw._getWatchedDir(o),!l.has(u)&&(l.add(u),(!r.ignoreInitial||i===!0)&&this.fsw._emit(a?$f:Uo,o,t))}initWatch(e,t,s,r){if(this.fsw.closed)return;let i=this._watchWithFsEvents(s.watchPath,ke.resolve(e||s.watchPath),r,s.globFilter);this.fsw._addPathCloser(t,i)}async _addToFsEvents(e,t,s,r){if(this.fsw.closed)return;let i=this.fsw.options,o=typeof t===qo?t:zw,a=this.fsw._getWatchHelpers(e);try{let l=await Xw[a.statMethod](a.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(a.watchPath,l))throw null;if(l.isDirectory()){if(a.globFilter||this.emitAdd(o(e),l,o,i,s),r&&r>i.depth)return;this.fsw._readdirp(a.watchPath,{fileFilter:u=>a.filterPath(u),directoryFilter:u=>a.filterDir(u),...Yw(i.depth-(r||0))}).on(Fw,u=>{if(this.fsw.closed||u.stats.isDirectory()&&!a.filterPath(u))return;let d=ke.join(a.watchPath,u.path),{fullPath:f}=u;if(a.followSymlinks&&u.stats.isSymbolicLink()){let h=i.depth===void 0?void 0:Ko(d,ke.resolve(a.watchPath))+1;this._handleFsEventsSymlink(d,f,o,h)}else this.emitAdd(d,u.stats,o,i,s)}).on(Lw,Vw).on(Nw,()=>{this.fsw._emitReady()})}else this.emitAdd(a.watchPath,l,o,i,s),this.fsw._emitReady()}catch(l){(!l||this.fsw._handleError(l))&&(this.fsw._emitReady(),this.fsw._emitReady())}if(i.persistent&&s!==!0)if(typeof t===qo)this.initWatch(void 0,e,a,o);else{let l;try{l=await Ef(a.watchPath)}catch{}this.initWatch(l,e,a,o)}}};Yo.exports=Go;Yo.exports.canUse=sx});var qf=N(ua=>{"use strict";var{EventEmitter:rx}=require("events"),la=require("fs"),oe=require("path"),{promisify:jf}=require("util"),ix=bd(),ta=Ad().default,ox=Pd(),Jo=Eo(),ax=hf(),lx=Co(),cx=Af(),Mf=Of(),{EV_ALL:Xo,EV_READY:ux,EV_ADD:ur,EV_CHANGE:as,EV_UNLINK:If,EV_ADD_DIR:dx,EV_UNLINK_DIR:fx,EV_RAW:px,EV_ERROR:Qo,STR_CLOSE:hx,STR_END:mx,BACK_SLASH_RE:gx,DOUBLE_SLASH_RE:Df,SLASH_OR_BACK_SLASH_RE:yx,DOT_RE:bx,REPLACER_RE:vx,SLASH:Zo,SLASH_SLASH:wx,BRACE_START:xx,BANG:na,ONE_DOT:Hf,TWO_DOTS:Sx,GLOBSTAR:_x,SLASH_GLOBSTAR:ea,ANYMATCH_OPTS:sa,STRING_TYPE:ca,FUNCTION_TYPE:kx,EMPTY_STR:ra,EMPTY_FN:Ax,isWindows:$x,isMacos:Cx,isIBMi:Tx}=rr(),Ex=jf(la.stat),Rx=jf(la.readdir),ia=(n=[])=>Array.isArray(n)?n:[n],Bf=(n,e=[])=>(n.forEach(t=>{Array.isArray(t)?Bf(t,e):e.push(t)}),e),Lf=n=>{let e=Bf(ia(n));if(!e.every(t=>typeof t===ca))throw new TypeError(`Non-string provided as watch path: ${e}`);return e.map(Uf)},Ff=n=>{let e=n.replace(gx,Zo),t=!1;for(e.startsWith(wx)&&(t=!0);e.match(Df);)e=e.replace(Df,Zo);return t&&(e=Zo+e),e},Uf=n=>Ff(oe.normalize(Ff(n))),Nf=(n=ra)=>e=>typeof e!==ca?e:Uf(oe.isAbsolute(e)?e:oe.join(n,e)),Px=(n,e)=>oe.isAbsolute(n)?n:n.startsWith(na)?na+oe.join(e,n.slice(1)):oe.join(e,n),rt=(n,e)=>n[e]===void 0,oa=class{constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==Hf&&e!==Sx&&t.add(e)}async remove(e){let{items:t}=this;if(!t||(t.delete(e),t.size>0))return;let s=this.path;try{await Rx(s)}catch{this._removeWatcher&&this._removeWatcher(oe.dirname(s),oe.basename(s))}}has(e){let{items:t}=this;if(t)return t.has(e)}getChildren(){let{items:e}=this;if(e)return[...e.values()]}dispose(){this.items.clear(),delete this.path,delete this._removeWatcher,delete this.items,Object.freeze(this)}},Ox="stat",Mx="lstat",aa=class{constructor(e,t,s,r){this.fsw=r,this.path=e=e.replace(vx,ra),this.watchPath=t,this.fullWatchPath=oe.resolve(t),this.hasGlob=t!==e,e===ra&&(this.hasGlob=!1),this.globSymlink=this.hasGlob&&s?void 0:!1,this.globFilter=this.hasGlob?ta(e,void 0,sa):!1,this.dirParts=this.getDirParts(e),this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=s,this.statMethod=s?Ox:Mx}checkGlobSymlink(e){return this.globSymlink===void 0&&(this.globSymlink=e.fullParentDir===this.fullWatchPath?!1:{realPath:e.fullParentDir,linkPath:this.fullWatchPath}),this.globSymlink?e.fullPath.replace(this.globSymlink.realPath,this.globSymlink.linkPath):e.fullPath}entryPath(e){return oe.join(this.watchPath,oe.relative(this.watchPath,this.checkGlobSymlink(e)))}filterPath(e){let{stats:t}=e;if(t&&t.isSymbolicLink())return this.filterDir(e);let s=this.entryPath(e);return(this.hasGlob&&typeof this.globFilter===kx?this.globFilter(s):!0)&&this.fsw._isntIgnored(s,t)&&this.fsw._hasReadPermissions(t)}getDirParts(e){if(!this.hasGlob)return[];let t=[];return(e.includes(xx)?ax.expand(e):[e]).forEach(r=>{t.push(oe.relative(this.watchPath,r).split(yx))}),t}filterDir(e){if(this.hasGlob){let t=this.getDirParts(this.checkGlobSymlink(e)),s=!1;this.unmatchedGlob=!this.dirParts.some(r=>r.every((i,o)=>(i===_x&&(s=!0),s||!t[0][o]||ta(i,t[0][o],sa))))}return!this.unmatchedGlob&&this.fsw._isntIgnored(this.entryPath(e),e.stats)}},dr=class extends rx{constructor(e){super();let t={};e&&Object.assign(t,e),this._watched=new Map,this._closers=new Map,this._ignoredPaths=new Set,this._throttled=new Map,this._symlinkPaths=new Map,this._streams=new Set,this.closed=!1,rt(t,"persistent")&&(t.persistent=!0),rt(t,"ignoreInitial")&&(t.ignoreInitial=!1),rt(t,"ignorePermissionErrors")&&(t.ignorePermissionErrors=!1),rt(t,"interval")&&(t.interval=100),rt(t,"binaryInterval")&&(t.binaryInterval=300),rt(t,"disableGlobbing")&&(t.disableGlobbing=!1),t.enableBinaryInterval=t.binaryInterval!==t.interval,rt(t,"useFsEvents")&&(t.useFsEvents=!t.usePolling),Mf.canUse()||(t.useFsEvents=!1),rt(t,"usePolling")&&!t.useFsEvents&&(t.usePolling=Cx),Tx&&(t.usePolling=!0);let r=process.env.CHOKIDAR_USEPOLLING;if(r!==void 0){let l=r.toLowerCase();l==="false"||l==="0"?t.usePolling=!1:l==="true"||l==="1"?t.usePolling=!0:t.usePolling=!!l}let i=process.env.CHOKIDAR_INTERVAL;i&&(t.interval=Number.parseInt(i,10)),rt(t,"atomic")&&(t.atomic=!t.usePolling&&!t.useFsEvents),t.atomic&&(this._pendingUnlinks=new Map),rt(t,"followSymlinks")&&(t.followSymlinks=!0),rt(t,"awaitWriteFinish")&&(t.awaitWriteFinish=!1),t.awaitWriteFinish===!0&&(t.awaitWriteFinish={});let o=t.awaitWriteFinish;o&&(o.stabilityThreshold||(o.stabilityThreshold=2e3),o.pollInterval||(o.pollInterval=100),this._pendingWrites=new Map),t.ignored&&(t.ignored=ia(t.ignored));let a=0;this._emitReady=()=>{a++,a>=this._readyCount&&(this._emitReady=Ax,this._readyEmitted=!0,process.nextTick(()=>this.emit(ux)))},this._emitRaw=(...l)=>this.emit(px,...l),this._readyEmitted=!1,this.options=t,t.useFsEvents?this._fsEventsHandler=new Mf(this):this._nodeFsHandler=new cx(this),Object.freeze(t)}add(e,t,s){let{cwd:r,disableGlobbing:i}=this.options;this.closed=!1;let o=Lf(e);return r&&(o=o.map(a=>{let l=Px(a,r);return i||!Jo(a)?l:lx(l)})),o=o.filter(a=>a.startsWith(na)?(this._ignoredPaths.add(a.slice(1)),!1):(this._ignoredPaths.delete(a),this._ignoredPaths.delete(a+ea),this._userIgnored=void 0,!0)),this.options.useFsEvents&&this._fsEventsHandler?(this._readyCount||(this._readyCount=o.length),this.options.persistent&&(this._readyCount+=o.length),o.forEach(a=>this._fsEventsHandler._addToFsEvents(a))):(this._readyCount||(this._readyCount=0),this._readyCount+=o.length,Promise.all(o.map(async a=>{let l=await this._nodeFsHandler._addToNodeFs(a,!s,0,0,t);return l&&this._emitReady(),l})).then(a=>{this.closed||a.filter(l=>l).forEach(l=>{this.add(oe.dirname(l),oe.basename(t||l))})})),this}unwatch(e){if(this.closed)return this;let t=Lf(e),{cwd:s}=this.options;return t.forEach(r=>{!oe.isAbsolute(r)&&!this._closers.has(r)&&(s&&(r=oe.join(s,r)),r=oe.resolve(r)),this._closePath(r),this._ignoredPaths.add(r),this._watched.has(r)&&this._ignoredPaths.add(r+ea),this._userIgnored=void 0}),this}close(){if(this.closed)return this._closePromise;this.closed=!0,this.removeAllListeners();let e=[];return this._closers.forEach(t=>t.forEach(s=>{let r=s();r instanceof Promise&&e.push(r)})),this._streams.forEach(t=>t.destroy()),this._userIgnored=void 0,this._readyCount=0,this._readyEmitted=!1,this._watched.forEach(t=>t.dispose()),["closers","watched","streams","symlinkPaths","throttled"].forEach(t=>{this[`_${t}`].clear()}),this._closePromise=e.length?Promise.all(e).then(()=>{}):Promise.resolve(),this._closePromise}getWatched(){let e={};return this._watched.forEach((t,s)=>{let r=this.options.cwd?oe.relative(this.options.cwd,s):s;e[r||Hf]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(...t),e!==Qo&&this.emit(Xo,...t)}async _emit(e,t,s,r,i){if(this.closed)return;let o=this.options;$x&&(t=oe.normalize(t)),o.cwd&&(t=oe.relative(o.cwd,t));let a=[e,t];i!==void 0?a.push(s,r,i):r!==void 0?a.push(s,r):s!==void 0&&a.push(s);let l=o.awaitWriteFinish,u;if(l&&(u=this._pendingWrites.get(t)))return u.lastChange=new Date,this;if(o.atomic){if(e===If)return this._pendingUnlinks.set(t,a),setTimeout(()=>{this._pendingUnlinks.forEach((d,f)=>{this.emit(...d),this.emit(Xo,...d),this._pendingUnlinks.delete(f)})},typeof o.atomic=="number"?o.atomic:100),this;e===ur&&this._pendingUnlinks.has(t)&&(e=a[0]=as,this._pendingUnlinks.delete(t))}if(l&&(e===ur||e===as)&&this._readyEmitted){let d=(f,h)=>{f?(e=a[0]=Qo,a[1]=f,this.emitWithAll(e,a)):h&&(a.length>2?a[2]=h:a.push(h),this.emitWithAll(e,a))};return this._awaitWriteFinish(t,l.stabilityThreshold,e,d),this}if(e===as&&!this._throttle(as,t,50))return this;if(o.alwaysStat&&s===void 0&&(e===ur||e===dx||e===as)){let d=o.cwd?oe.join(o.cwd,t):t,f;try{f=await Ex(d)}catch{}if(!f||this.closed)return;a.push(f)}return this.emitWithAll(e,a),this}_handleError(e){let t=e&&e.code;return e&&t!=="ENOENT"&&t!=="ENOTDIR"&&(!this.options.ignorePermissionErrors||t!=="EPERM"&&t!=="EACCES")&&this.emit(Qo,e),e||this.closed}_throttle(e,t,s){this._throttled.has(e)||this._throttled.set(e,new Map);let r=this._throttled.get(e),i=r.get(t);if(i)return i.count++,!1;let o,a=()=>{let u=r.get(t),d=u?u.count:0;return r.delete(t),clearTimeout(o),u&&clearTimeout(u.timeoutObject),d};o=setTimeout(a,s);let l={timeoutObject:o,clear:a,count:0};return r.set(t,l),l}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(e,t,s,r){let i,o=e;this.options.cwd&&!oe.isAbsolute(e)&&(o=oe.join(this.options.cwd,e));let a=new Date,l=u=>{la.stat(o,(d,f)=>{if(d||!this._pendingWrites.has(e)){d&&d.code!=="ENOENT"&&r(d);return}let h=Number(new Date);u&&f.size!==u.size&&(this._pendingWrites.get(e).lastChange=h);let m=this._pendingWrites.get(e);h-m.lastChange>=t?(this._pendingWrites.delete(e),r(void 0,f)):i=setTimeout(l,this.options.awaitWriteFinish.pollInterval,f)})};this._pendingWrites.has(e)||(this._pendingWrites.set(e,{lastChange:a,cancelWait:()=>(this._pendingWrites.delete(e),clearTimeout(i),s)}),i=setTimeout(l,this.options.awaitWriteFinish.pollInterval))}_getGlobIgnored(){return[...this._ignoredPaths.values()]}_isIgnored(e,t){if(this.options.atomic&&bx.test(e))return!0;if(!this._userIgnored){let{cwd:s}=this.options,r=this.options.ignored,i=r&&r.map(Nf(s)),o=ia(i).filter(l=>typeof l===ca&&!Jo(l)).map(l=>l+ea),a=this._getGlobIgnored().map(Nf(s)).concat(i,o);this._userIgnored=ta(a,void 0,sa)}return this._userIgnored([e,t])}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e,t){let s=t||this.options.disableGlobbing||!Jo(e)?e:ox(e),r=this.options.followSymlinks;return new aa(e,s,r,this)}_getWatchedDir(e){this._boundRemove||(this._boundRemove=this._remove.bind(this));let t=oe.resolve(e);return this._watched.has(t)||this._watched.set(t,new oa(t,this._boundRemove)),this._watched.get(t)}_hasReadPermissions(e){if(this.options.ignorePermissionErrors)return!0;let s=(e&&Number.parseInt(e.mode,10))&511;return!!(4&Number.parseInt(s.toString(8)[0],10))}_remove(e,t,s){let r=oe.join(e,t),i=oe.resolve(r);if(s=s??(this._watched.has(r)||this._watched.has(i)),!this._throttle("remove",r,100))return;!s&&!this.options.useFsEvents&&this._watched.size===1&&this.add(e,t,!0),this._getWatchedDir(r).getChildren().forEach(h=>this._remove(r,h));let l=this._getWatchedDir(e),u=l.has(t);l.remove(t),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let d=r;if(this.options.cwd&&(d=oe.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(d)&&this._pendingWrites.get(d).cancelWait()===ur)return;this._watched.delete(r),this._watched.delete(i);let f=s?fx:If;u&&!this._isIgnored(r)&&this._emit(f,r),this.options.useFsEvents||this._closePath(r)}_closePath(e){this._closeFile(e);let t=oe.dirname(e);this._getWatchedDir(t).remove(oe.basename(e))}_closeFile(e){let t=this._closers.get(e);t&&(t.forEach(s=>s()),this._closers.delete(e))}_addPathCloser(e,t){if(!t)return;let s=this._closers.get(e);s||(s=[],this._closers.set(e,s)),s.push(t)}_readdirp(e,t){if(this.closed)return;let s={type:Xo,alwaysStat:!0,lstat:!0,...t},r=ix(e,s);return this._streams.add(r),r.once(hx,()=>{r=void 0}),r.once(mx,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};ua.FSWatcher=dr;var Ix=(n,e)=>{let t=new dr(e);return t.add(n),t};ua.watch=Ix});var Vf={};Le(Vf,{CollaborationManager:()=>ls,addTeamMember:()=>Fx,formatTeamConfig:()=>Nx,initTeamConfig:()=>Lx,loadTeamConfig:()=>Dx,saveTeamConfig:()=>Gf});function Dx(n){let e=Ye.join(n,".hablas","team.json");if(be.existsSync(e))try{return JSON.parse(be.readFileSync(e,"utf-8"))}catch{return null}return null}function Lx(n,e){let t={name:e,members:[]};return Gf(n,t),t}function Gf(n,e){let t=Ye.join(n,".hablas","team.json"),s=Ye.dirname(t);be.existsSync(s)||be.mkdirSync(s,{recursive:!0}),be.writeFileSync(t,JSON.stringify(e,null,2),"utf-8")}function Fx(n,e,t){return n.members.push({name:e,email:t}),n}function Nx(n){return[`Team: ${n.name}`,"Members:",...n.members.map(t=>` - ${t.name} (${t.email})`)].join(`
|
|
298
|
-
`)}var
|
|
296
|
+
If you cannot complete a task, explain why with absolute technical objectivity.`;uo=Ae.join(fo.homedir(),".hablas","backup")});var Jn=N((uT,zu)=>{"use strict";var wb=require("path"),pt="\\\\/",Ku=`[^${pt}]`,xb=0,Et="\\.",Sb="\\+",_b="\\?",Vs="\\/",kb="(?=.)",Wu="[^/]",po=`(?:${Vs}|$)`,Gu=`(?:^|${Vs})`,ho=`${Et}{1,2}${po}`,Ab=`(?!${Et})`,$b=`(?!${Gu}${ho})`,Cb=`(?!${Et}{0,1}${po})`,Tb=`(?!${ho})`,Eb=`[^.${Vs}]`,Rb=`${Wu}*?`,Vu={DOT_LITERAL:Et,PLUS_LITERAL:Sb,QMARK_LITERAL:_b,SLASH_LITERAL:Vs,ONE_CHAR:kb,QMARK:Wu,END_ANCHOR:po,DOTS_SLASH:ho,NO_DOT:Ab,NO_DOTS:$b,NO_DOT_SLASH:Cb,NO_DOTS_SLASH:Tb,QMARK_NO_DOT:Eb,STAR:Rb,START_ANCHOR:Gu},Pb={...Vu,SLASH_LITERAL:`[${pt}]`,QMARK:Ku,STAR:`${Ku}*?`,DOTS_SLASH:`${Et}{1,2}(?:[${pt}]|$)`,NO_DOT:`(?!${Et})`,NO_DOTS:`(?!(?:^|[${pt}])${Et}{1,2}(?:[${pt}]|$))`,NO_DOT_SLASH:`(?!${Et}{0,1}(?:[${pt}]|$))`,NO_DOTS_SLASH:`(?!${Et}{1,2}(?:[${pt}]|$))`,QMARK_NO_DOT:`[^.${pt}]`,START_ANCHOR:`(?:^|[${pt}])`,END_ANCHOR:`(?:[${pt}]|$)`},Ob={__proto__:null,alnum:"a-zA-Z0-9",alpha:"a-zA-Z",ascii:"\\x00-\\x7F",blank:" \\t",cntrl:"\\x00-\\x1F\\x7F",digit:"0-9",graph:"\\x21-\\x7E",lower:"a-z",print:"\\x20-\\x7E ",punct:"\\-!\"#$%&'()\\*+,./:;<=>?@[\\]^_`{|}~",space:" \\t\\r\\n\\v\\f",upper:"A-Z",word:"A-Za-z0-9_",xdigit:"A-Fa-f0-9"};zu.exports={DEFAULT_MAX_EXTGLOB_RECURSION:xb,MAX_LENGTH:1024*64,POSIX_REGEX_SOURCE:Ob,REGEX_BACKSLASH:/\\(?![*+?^${}(|)[\]])/g,REGEX_NON_SPECIAL_CHARS:/^[^@![\].,$*+?^{}()|\\/]+/,REGEX_SPECIAL_CHARS:/[-*+?.^${}(|)[\]]/,REGEX_SPECIAL_CHARS_BACKREF:/(\\?)((\W)(\3*))/g,REGEX_SPECIAL_CHARS_GLOBAL:/([-*+?.^${}(|)[\]])/g,REGEX_REMOVE_BACKSLASH:/(?:\[.*?[^\\]\]|\\(?=.))/g,REPLACEMENTS:{__proto__:null,"***":"*","**/**":"**","**/**/**":"**"},CHAR_0:48,CHAR_9:57,CHAR_UPPERCASE_A:65,CHAR_LOWERCASE_A:97,CHAR_UPPERCASE_Z:90,CHAR_LOWERCASE_Z:122,CHAR_LEFT_PARENTHESES:40,CHAR_RIGHT_PARENTHESES:41,CHAR_ASTERISK:42,CHAR_AMPERSAND:38,CHAR_AT:64,CHAR_BACKWARD_SLASH:92,CHAR_CARRIAGE_RETURN:13,CHAR_CIRCUMFLEX_ACCENT:94,CHAR_COLON:58,CHAR_COMMA:44,CHAR_DOT:46,CHAR_DOUBLE_QUOTE:34,CHAR_EQUAL:61,CHAR_EXCLAMATION_MARK:33,CHAR_FORM_FEED:12,CHAR_FORWARD_SLASH:47,CHAR_GRAVE_ACCENT:96,CHAR_HASH:35,CHAR_HYPHEN_MINUS:45,CHAR_LEFT_ANGLE_BRACKET:60,CHAR_LEFT_CURLY_BRACE:123,CHAR_LEFT_SQUARE_BRACKET:91,CHAR_LINE_FEED:10,CHAR_NO_BREAK_SPACE:160,CHAR_PERCENT:37,CHAR_PLUS:43,CHAR_QUESTION_MARK:63,CHAR_RIGHT_ANGLE_BRACKET:62,CHAR_RIGHT_CURLY_BRACE:125,CHAR_RIGHT_SQUARE_BRACKET:93,CHAR_SEMICOLON:59,CHAR_SINGLE_QUOTE:39,CHAR_SPACE:32,CHAR_TAB:9,CHAR_UNDERSCORE:95,CHAR_VERTICAL_LINE:124,CHAR_ZERO_WIDTH_NOBREAK_SPACE:65279,SEP:wb.sep,extglobChars(n){return{"!":{type:"negate",open:"(?:(?!(?:",close:`))${n.STAR})`},"?":{type:"qmark",open:"(?:",close:")?"},"+":{type:"plus",open:"(?:",close:")+"},"*":{type:"star",open:"(?:",close:")*"},"@":{type:"at",open:"(?:",close:")"}}},globChars(n){return n===!0?Pb:Vu}}});var zs=N(Ie=>{"use strict";var Mb=require("path"),Ib=process.platform==="win32",{REGEX_BACKSLASH:Db,REGEX_REMOVE_BACKSLASH:Lb,REGEX_SPECIAL_CHARS:Fb,REGEX_SPECIAL_CHARS_GLOBAL:Nb}=Jn();Ie.isObject=n=>n!==null&&typeof n=="object"&&!Array.isArray(n);Ie.hasRegexChars=n=>Fb.test(n);Ie.isRegexChar=n=>n.length===1&&Ie.hasRegexChars(n);Ie.escapeRegex=n=>n.replace(Nb,"\\$1");Ie.toPosixSlashes=n=>n.replace(Db,"/");Ie.removeBackslashes=n=>n.replace(Lb,e=>e==="\\"?"":e);Ie.supportsLookbehinds=()=>{let n=process.version.slice(1).split(".").map(Number);return n.length===3&&n[0]>=9||n[0]===8&&n[1]>=10};Ie.isWindows=n=>n&&typeof n.windows=="boolean"?n.windows:Ib===!0||Mb.sep==="\\";Ie.escapeLast=(n,e,t)=>{let s=n.lastIndexOf(e,t);return s===-1?n:n[s-1]==="\\"?Ie.escapeLast(n,e,s-1):`${n.slice(0,s)}\\${n.slice(s)}`};Ie.removePrefix=(n,e={})=>{let t=n;return t.startsWith("./")&&(t=t.slice(2),e.prefix="./"),t};Ie.wrapOutput=(n,e={},t={})=>{let s=t.contains?"":"^",r=t.contains?"":"$",i=`${s}(?:${n})${r}`;return e.negated===!0&&(i=`(?:^(?!${i}).*$)`),i}});var nd=N((fT,td)=>{"use strict";var Yu=zs(),{CHAR_ASTERISK:mo,CHAR_AT:jb,CHAR_BACKWARD_SLASH:Xn,CHAR_COMMA:Hb,CHAR_DOT:go,CHAR_EXCLAMATION_MARK:yo,CHAR_FORWARD_SLASH:ed,CHAR_LEFT_CURLY_BRACE:bo,CHAR_LEFT_PARENTHESES:vo,CHAR_LEFT_SQUARE_BRACKET:Bb,CHAR_PLUS:Ub,CHAR_QUESTION_MARK:Ju,CHAR_RIGHT_CURLY_BRACE:qb,CHAR_RIGHT_PARENTHESES:Xu,CHAR_RIGHT_SQUARE_BRACKET:Kb}=Jn(),Qu=n=>n===ed||n===Xn,Zu=n=>{n.isPrefix!==!0&&(n.depth=n.isGlobstar?1/0:1)},Wb=(n,e)=>{let t=e||{},s=n.length-1,r=t.parts===!0||t.scanToEnd===!0,i=[],o=[],a=[],l=n,u=-1,d=0,f=0,h=!1,m=!1,p=!1,g=!1,w=!1,_=!1,k=!1,$=!1,y=!1,v=!1,b=0,x,A,E={value:"",depth:0,isGlob:!1},M=()=>u>=s,C=()=>l.charCodeAt(u+1),F=()=>(x=A,l.charCodeAt(++u));for(;u<s;){A=F();let Q;if(A===Xn){k=E.backslashes=!0,A=F(),A===bo&&(_=!0);continue}if(_===!0||A===bo){for(b++;M()!==!0&&(A=F());){if(A===Xn){k=E.backslashes=!0,F();continue}if(A===bo){b++;continue}if(_!==!0&&A===go&&(A=F())===go){if(h=E.isBrace=!0,p=E.isGlob=!0,v=!0,r===!0)continue;break}if(_!==!0&&A===Hb){if(h=E.isBrace=!0,p=E.isGlob=!0,v=!0,r===!0)continue;break}if(A===qb&&(b--,b===0)){_=!1,h=E.isBrace=!0,v=!0;break}}if(r===!0)continue;break}if(A===ed){if(i.push(u),o.push(E),E={value:"",depth:0,isGlob:!1},v===!0)continue;if(x===go&&u===d+1){d+=2;continue}f=u+1;continue}if(t.noext!==!0&&(A===Ub||A===jb||A===mo||A===Ju||A===yo)===!0&&C()===vo){if(p=E.isGlob=!0,g=E.isExtglob=!0,v=!0,A===yo&&u===d&&(y=!0),r===!0){for(;M()!==!0&&(A=F());){if(A===Xn){k=E.backslashes=!0,A=F();continue}if(A===Xu){p=E.isGlob=!0,v=!0;break}}continue}break}if(A===mo){if(x===mo&&(w=E.isGlobstar=!0),p=E.isGlob=!0,v=!0,r===!0)continue;break}if(A===Ju){if(p=E.isGlob=!0,v=!0,r===!0)continue;break}if(A===Bb){for(;M()!==!0&&(Q=F());){if(Q===Xn){k=E.backslashes=!0,F();continue}if(Q===Kb){m=E.isBracket=!0,p=E.isGlob=!0,v=!0;break}}if(r===!0)continue;break}if(t.nonegate!==!0&&A===yo&&u===d){$=E.negated=!0,d++;continue}if(t.noparen!==!0&&A===vo){if(p=E.isGlob=!0,r===!0){for(;M()!==!0&&(A=F());){if(A===vo){k=E.backslashes=!0,A=F();continue}if(A===Xu){v=!0;break}}continue}break}if(p===!0){if(v=!0,r===!0)continue;break}}t.noext===!0&&(g=!1,p=!1);let H=l,Y="",T="";d>0&&(Y=l.slice(0,d),l=l.slice(d),f-=d),H&&p===!0&&f>0?(H=l.slice(0,f),T=l.slice(f)):p===!0?(H="",T=l):H=l,H&&H!==""&&H!=="/"&&H!==l&&Qu(H.charCodeAt(H.length-1))&&(H=H.slice(0,-1)),t.unescape===!0&&(T&&(T=Yu.removeBackslashes(T)),H&&k===!0&&(H=Yu.removeBackslashes(H)));let S={prefix:Y,input:n,start:d,base:H,glob:T,isBrace:h,isBracket:m,isGlob:p,isExtglob:g,isGlobstar:w,negated:$,negatedExtglob:y};if(t.tokens===!0&&(S.maxDepth=0,Qu(A)||o.push(E),S.tokens=o),t.parts===!0||t.tokens===!0){let Q;for(let q=0;q<i.length;q++){let ne=Q?Q+1:d,re=i[q],ee=n.slice(ne,re);t.tokens&&(q===0&&d!==0?(o[q].isPrefix=!0,o[q].value=Y):o[q].value=ee,Zu(o[q]),S.maxDepth+=o[q].depth),(q!==0||ee!=="")&&a.push(ee),Q=re}if(Q&&Q+1<n.length){let q=n.slice(Q+1);a.push(q),t.tokens&&(o[o.length-1].value=q,Zu(o[o.length-1]),S.maxDepth+=o[o.length-1].depth)}S.slashes=i,S.parts=a}return S};td.exports=Wb});var ad=N((pT,od)=>{"use strict";var Qn=Jn(),Te=zs(),{MAX_LENGTH:Ys,POSIX_REGEX_SOURCE:Gb,REGEX_NON_SPECIAL_CHARS:Vb,REGEX_SPECIAL_CHARS_BACKREF:zb,REPLACEMENTS:sd}=Qn,Yb=(n,e)=>{if(typeof e.expandRange=="function")return e.expandRange(...n,e);n.sort();let t=`[${n.join("-")}]`;try{new RegExp(t)}catch{return n.map(r=>Te.escapeRegex(r)).join("..")}return t},Sn=(n,e)=>`Missing ${n}: "${e}" - use "\\\\${e}" to match literal characters`,rd=n=>{let e=[],t=0,s=0,r=0,i="",o=!1;for(let a of n){if(o===!0){i+=a,o=!1;continue}if(a==="\\"){i+=a,o=!0;continue}if(a==='"'){r=r===1?0:1,i+=a;continue}if(r===0){if(a==="[")t++;else if(a==="]"&&t>0)t--;else if(t===0){if(a==="(")s++;else if(a===")"&&s>0)s--;else if(a==="|"&&s===0){e.push(i),i="";continue}}}i+=a}return e.push(i),e},Jb=n=>{let e=!1;for(let t of n){if(e===!0){e=!1;continue}if(t==="\\"){e=!0;continue}if(/[?*+@!()[\]{}]/.test(t))return!1}return!0},id=n=>{let e=n.trim(),t=!0;for(;t===!0;)t=!1,/^@\([^\\()[\]{}|]+\)$/.test(e)&&(e=e.slice(2,-1),t=!0);if(Jb(e))return e.replace(/\\(.)/g,"$1")},Xb=n=>{let e=n.map(id).filter(Boolean);for(let t=0;t<e.length;t++)for(let s=t+1;s<e.length;s++){let r=e[t],i=e[s],o=r[0];if(!(!o||r!==o.repeat(r.length)||i!==o.repeat(i.length))&&(r===i||r.startsWith(i)||i.startsWith(r)))return!0}return!1},wo=(n,e=!0)=>{if(n[0]!=="+"&&n[0]!=="*"||n[1]!=="(")return;let t=0,s=0,r=0,i=!1;for(let o=1;o<n.length;o++){let a=n[o];if(i===!0){i=!1;continue}if(a==="\\"){i=!0;continue}if(a==='"'){r=r===1?0:1;continue}if(r!==1){if(a==="["){t++;continue}if(a==="]"&&t>0){t--;continue}if(!(t>0)){if(a==="("){s++;continue}if(a===")"&&(s--,s===0))return e===!0&&o!==n.length-1?void 0:{type:n[0],body:n.slice(2,o),end:o}}}}},Qb=n=>{let e=0,t=[];for(;e<n.length;){let r=wo(n.slice(e),!1);if(!r||r.type!=="*")return;let i=rd(r.body).map(a=>a.trim());if(i.length!==1)return;let o=id(i[0]);if(!o||o.length!==1)return;t.push(o),e+=r.end+1}return t.length<1?void 0:`${t.length===1?Te.escapeRegex(t[0]):`[${t.map(r=>Te.escapeRegex(r)).join("")}]`}*`},Zb=n=>{let e=0,t=n.trim(),s=wo(t);for(;s;)e++,t=s.body.trim(),s=wo(t);return e},ev=(n,e)=>{if(e.maxExtglobRecursion===!1)return{risky:!1};let t=typeof e.maxExtglobRecursion=="number"?e.maxExtglobRecursion:Qn.DEFAULT_MAX_EXTGLOB_RECURSION,s=rd(n).map(r=>r.trim());if(s.length>1&&(s.some(r=>r==="")||s.some(r=>/^[*?]+$/.test(r))||Xb(s)))return{risky:!0};for(let r of s){let i=Qb(r);if(i)return{risky:!0,safeOutput:i};if(Zb(r)>t)return{risky:!0}}return{risky:!1}},xo=(n,e)=>{if(typeof n!="string")throw new TypeError("Expected a string");n=sd[n]||n;let t={...e},s=typeof t.maxLength=="number"?Math.min(Ys,t.maxLength):Ys,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);let i={type:"bos",value:"",output:t.prepend||""},o=[i],a=t.capture?"":"?:",l=Te.isWindows(e),u=Qn.globChars(l),d=Qn.extglobChars(u),{DOT_LITERAL:f,PLUS_LITERAL:h,SLASH_LITERAL:m,ONE_CHAR:p,DOTS_SLASH:g,NO_DOT:w,NO_DOT_SLASH:_,NO_DOTS_SLASH:k,QMARK:$,QMARK_NO_DOT:y,STAR:v,START_ANCHOR:b}=u,x=P=>`(${a}(?:(?!${b}${P.dot?g:f}).)*?)`,A=t.dot?"":w,E=t.dot?$:y,M=t.bash===!0?x(t):v;t.capture&&(M=`(${M})`),typeof t.noext=="boolean"&&(t.noextglob=t.noext);let C={input:n,index:-1,start:0,dot:t.dot===!0,consumed:"",output:"",prefix:"",backtrack:!1,negated:!1,brackets:0,braces:0,parens:0,quotes:0,globstar:!1,tokens:o};n=Te.removePrefix(n,C),r=n.length;let F=[],H=[],Y=[],T=i,S,Q=()=>C.index===r-1,q=C.peek=(P=1)=>n[C.index+P],ne=C.advance=()=>n[++C.index]||"",re=()=>n.slice(C.index+1),ee=(P="",U=0)=>{C.consumed+=P,C.index+=U},V=P=>{C.output+=P.output!=null?P.output:P.value,ee(P.value)},Pe=()=>{let P=1;for(;q()==="!"&&(q(2)!=="("||q(3)==="?");)ne(),C.start++,P++;return P%2===0?!1:(C.negated=!0,C.start++,!0)},Le=P=>{C[P]++,Y.push(P)},ie=P=>{C[P]--,Y.pop()},K=P=>{if(T.type==="globstar"){let U=C.braces>0&&(P.type==="comma"||P.type==="brace"),I=P.extglob===!0||F.length&&(P.type==="pipe"||P.type==="paren");P.type!=="slash"&&P.type!=="paren"&&!U&&!I&&(C.output=C.output.slice(0,-T.output.length),T.type="star",T.value="*",T.output=M,C.output+=T.output)}if(F.length&&P.type!=="paren"&&(F[F.length-1].inner+=P.value),(P.value||P.output)&&V(P),T&&T.type==="text"&&P.type==="text"){T.value+=P.value,T.output=(T.output||"")+P.value;return}P.prev=T,o.push(P),T=P},ue=(P,U)=>{let I={...d[U],conditions:1,inner:""};I.prev=T,I.parens=C.parens,I.output=C.output,I.startIndex=C.index,I.tokensIndex=o.length;let W=(t.capture?"(":"")+I.open;Le("parens"),K({type:P,value:U,output:C.output?"":p}),K({type:"paren",extglob:!0,value:ne(),output:W}),F.push(I)},ge=P=>{let U=n.slice(P.startIndex,C.index+1),I=n.slice(P.startIndex+2,C.index),W=ev(I,t);if((P.type==="plus"||P.type==="star")&&W.risky){let te=W.safeOutput?(P.output?"":p)+(t.capture?`(${W.safeOutput})`:W.safeOutput):void 0,Oe=o[P.tokensIndex];Oe.type="text",Oe.value=U,Oe.output=te||Te.escapeRegex(U);for(let xe=P.tokensIndex+1;xe<o.length;xe++)o[xe].value="",o[xe].output="",delete o[xe].suffix;C.output=P.output+Oe.output,C.backtrack=!0,K({type:"paren",extglob:!0,value:S,output:""}),ie("parens");return}let se=P.close+(t.capture?")":""),G;if(P.type==="negate"){let te=M;if(P.inner&&P.inner.length>1&&P.inner.includes("/")&&(te=x(t)),(te!==M||Q()||/^\)+$/.test(re()))&&(se=P.close=`)$))${te}`),P.inner.includes("*")&&(G=re())&&/^\.[^\\/.]+$/.test(G)){let Oe=xo(G,{...e,fastpaths:!1}).output;se=P.close=`)${Oe})${te})`}P.prev.type==="bos"&&(C.negatedExtglob=!0)}K({type:"paren",extglob:!0,value:S,output:se}),ie("parens")};if(t.fastpaths!==!1&&!/(^[*!]|[/()[\]{}"])/.test(n)){let P=!1,U=n.replace(zb,(I,W,se,G,te,Oe)=>G==="\\"?(P=!0,I):G==="?"?W?W+G+(te?$.repeat(te.length):""):Oe===0?E+(te?$.repeat(te.length):""):$.repeat(se.length):G==="."?f.repeat(se.length):G==="*"?W?W+G+(te?M:""):M:W?I:`\\${I}`);return P===!0&&(t.unescape===!0?U=U.replace(/\\/g,""):U=U.replace(/\\+/g,I=>I.length%2===0?"\\\\":I?"\\":"")),U===n&&t.contains===!0?(C.output=n,C):(C.output=Te.wrapOutput(U,C,e),C)}for(;!Q();){if(S=ne(),S==="\0")continue;if(S==="\\"){let I=q();if(I==="/"&&t.bash!==!0||I==="."||I===";")continue;if(!I){S+="\\",K({type:"text",value:S});continue}let W=/^\\+/.exec(re()),se=0;if(W&&W[0].length>2&&(se=W[0].length,C.index+=se,se%2!==0&&(S+="\\")),t.unescape===!0?S=ne():S+=ne(),C.brackets===0){K({type:"text",value:S});continue}}if(C.brackets>0&&(S!=="]"||T.value==="["||T.value==="[^")){if(t.posix!==!1&&S===":"){let I=T.value.slice(1);if(I.includes("[")&&(T.posix=!0,I.includes(":"))){let W=T.value.lastIndexOf("["),se=T.value.slice(0,W),G=T.value.slice(W+2),te=Gb[G];if(te){T.value=se+te,C.backtrack=!0,ne(),!i.output&&o.indexOf(T)===1&&(i.output=p);continue}}}(S==="["&&q()!==":"||S==="-"&&q()==="]")&&(S=`\\${S}`),S==="]"&&(T.value==="["||T.value==="[^")&&(S=`\\${S}`),t.posix===!0&&S==="!"&&T.value==="["&&(S="^"),T.value+=S,V({value:S});continue}if(C.quotes===1&&S!=='"'){S=Te.escapeRegex(S),T.value+=S,V({value:S});continue}if(S==='"'){C.quotes=C.quotes===1?0:1,t.keepQuotes===!0&&K({type:"text",value:S});continue}if(S==="("){Le("parens"),K({type:"paren",value:S});continue}if(S===")"){if(C.parens===0&&t.strictBrackets===!0)throw new SyntaxError(Sn("opening","("));let I=F[F.length-1];if(I&&C.parens===I.parens+1){ge(F.pop());continue}K({type:"paren",value:S,output:C.parens?")":"\\)"}),ie("parens");continue}if(S==="["){if(t.nobracket===!0||!re().includes("]")){if(t.nobracket!==!0&&t.strictBrackets===!0)throw new SyntaxError(Sn("closing","]"));S=`\\${S}`}else Le("brackets");K({type:"bracket",value:S});continue}if(S==="]"){if(t.nobracket===!0||T&&T.type==="bracket"&&T.value.length===1){K({type:"text",value:S,output:`\\${S}`});continue}if(C.brackets===0){if(t.strictBrackets===!0)throw new SyntaxError(Sn("opening","["));K({type:"text",value:S,output:`\\${S}`});continue}ie("brackets");let I=T.value.slice(1);if(T.posix!==!0&&I[0]==="^"&&!I.includes("/")&&(S=`/${S}`),T.value+=S,V({value:S}),t.literalBrackets===!1||Te.hasRegexChars(I))continue;let W=Te.escapeRegex(T.value);if(C.output=C.output.slice(0,-T.value.length),t.literalBrackets===!0){C.output+=W,T.value=W;continue}T.value=`(${a}${W}|${T.value})`,C.output+=T.value;continue}if(S==="{"&&t.nobrace!==!0){Le("braces");let I={type:"brace",value:S,output:"(",outputIndex:C.output.length,tokensIndex:C.tokens.length};H.push(I),K(I);continue}if(S==="}"){let I=H[H.length-1];if(t.nobrace===!0||!I){K({type:"text",value:S,output:S});continue}let W=")";if(I.dots===!0){let se=o.slice(),G=[];for(let te=se.length-1;te>=0&&(o.pop(),se[te].type!=="brace");te--)se[te].type!=="dots"&&G.unshift(se[te].value);W=Yb(G,t),C.backtrack=!0}if(I.comma!==!0&&I.dots!==!0){let se=C.output.slice(0,I.outputIndex),G=C.tokens.slice(I.tokensIndex);I.value=I.output="\\{",S=W="\\}",C.output=se;for(let te of G)C.output+=te.output||te.value}K({type:"brace",value:S,output:W}),ie("braces"),H.pop();continue}if(S==="|"){F.length>0&&F[F.length-1].conditions++,K({type:"text",value:S});continue}if(S===","){let I=S,W=H[H.length-1];W&&Y[Y.length-1]==="braces"&&(W.comma=!0,I="|"),K({type:"comma",value:S,output:I});continue}if(S==="/"){if(T.type==="dot"&&C.index===C.start+1){C.start=C.index+1,C.consumed="",C.output="",o.pop(),T=i;continue}K({type:"slash",value:S,output:m});continue}if(S==="."){if(C.braces>0&&T.type==="dot"){T.value==="."&&(T.output=f);let I=H[H.length-1];T.type="dots",T.output+=S,T.value+=S,I.dots=!0;continue}if(C.braces+C.parens===0&&T.type!=="bos"&&T.type!=="slash"){K({type:"text",value:S,output:f});continue}K({type:"dot",value:S,output:f});continue}if(S==="?"){if(!(T&&T.value==="(")&&t.noextglob!==!0&&q()==="("&&q(2)!=="?"){ue("qmark",S);continue}if(T&&T.type==="paren"){let W=q(),se=S;if(W==="<"&&!Te.supportsLookbehinds())throw new Error("Node.js v10 or higher is required for regex lookbehinds");(T.value==="("&&!/[!=<:]/.test(W)||W==="<"&&!/<([!=]|\w+>)/.test(re()))&&(se=`\\${S}`),K({type:"text",value:S,output:se});continue}if(t.dot!==!0&&(T.type==="slash"||T.type==="bos")){K({type:"qmark",value:S,output:y});continue}K({type:"qmark",value:S,output:$});continue}if(S==="!"){if(t.noextglob!==!0&&q()==="("&&(q(2)!=="?"||!/[!=<:]/.test(q(3)))){ue("negate",S);continue}if(t.nonegate!==!0&&C.index===0){Pe();continue}}if(S==="+"){if(t.noextglob!==!0&&q()==="("&&q(2)!=="?"){ue("plus",S);continue}if(T&&T.value==="("||t.regex===!1){K({type:"plus",value:S,output:h});continue}if(T&&(T.type==="bracket"||T.type==="paren"||T.type==="brace")||C.parens>0){K({type:"plus",value:S});continue}K({type:"plus",value:h});continue}if(S==="@"){if(t.noextglob!==!0&&q()==="("&&q(2)!=="?"){K({type:"at",extglob:!0,value:S,output:""});continue}K({type:"text",value:S});continue}if(S!=="*"){(S==="$"||S==="^")&&(S=`\\${S}`);let I=Vb.exec(re());I&&(S+=I[0],C.index+=I[0].length),K({type:"text",value:S});continue}if(T&&(T.type==="globstar"||T.star===!0)){T.type="star",T.star=!0,T.value+=S,T.output=M,C.backtrack=!0,C.globstar=!0,ee(S);continue}let P=re();if(t.noextglob!==!0&&/^\([^?]/.test(P)){ue("star",S);continue}if(T.type==="star"){if(t.noglobstar===!0){ee(S);continue}let I=T.prev,W=I.prev,se=I.type==="slash"||I.type==="bos",G=W&&(W.type==="star"||W.type==="globstar");if(t.bash===!0&&(!se||P[0]&&P[0]!=="/")){K({type:"star",value:S,output:""});continue}let te=C.braces>0&&(I.type==="comma"||I.type==="brace"),Oe=F.length&&(I.type==="pipe"||I.type==="paren");if(!se&&I.type!=="paren"&&!te&&!Oe){K({type:"star",value:S,output:""});continue}for(;P.slice(0,3)==="/**";){let xe=n[C.index+4];if(xe&&xe!=="/")break;P=P.slice(3),ee("/**",3)}if(I.type==="bos"&&Q()){T.type="globstar",T.value+=S,T.output=x(t),C.output=T.output,C.globstar=!0,ee(S);continue}if(I.type==="slash"&&I.prev.type!=="bos"&&!G&&Q()){C.output=C.output.slice(0,-(I.output+T.output).length),I.output=`(?:${I.output}`,T.type="globstar",T.output=x(t)+(t.strictSlashes?")":"|$)"),T.value+=S,C.globstar=!0,C.output+=I.output+T.output,ee(S);continue}if(I.type==="slash"&&I.prev.type!=="bos"&&P[0]==="/"){let xe=P[1]!==void 0?"|$":"";C.output=C.output.slice(0,-(I.output+T.output).length),I.output=`(?:${I.output}`,T.type="globstar",T.output=`${x(t)}${m}|${m}${xe})`,T.value+=S,C.output+=I.output+T.output,C.globstar=!0,ee(S+ne()),K({type:"slash",value:"/",output:""});continue}if(I.type==="bos"&&P[0]==="/"){T.type="globstar",T.value+=S,T.output=`(?:^|${m}|${x(t)}${m})`,C.output=T.output,C.globstar=!0,ee(S+ne()),K({type:"slash",value:"/",output:""});continue}C.output=C.output.slice(0,-T.output.length),T.type="globstar",T.output=x(t),T.value+=S,C.output+=T.output,C.globstar=!0,ee(S);continue}let U={type:"star",value:S,output:M};if(t.bash===!0){U.output=".*?",(T.type==="bos"||T.type==="slash")&&(U.output=A+U.output),K(U);continue}if(T&&(T.type==="bracket"||T.type==="paren")&&t.regex===!0){U.output=S,K(U);continue}(C.index===C.start||T.type==="slash"||T.type==="dot")&&(T.type==="dot"?(C.output+=_,T.output+=_):t.dot===!0?(C.output+=k,T.output+=k):(C.output+=A,T.output+=A),q()!=="*"&&(C.output+=p,T.output+=p)),K(U)}for(;C.brackets>0;){if(t.strictBrackets===!0)throw new SyntaxError(Sn("closing","]"));C.output=Te.escapeLast(C.output,"["),ie("brackets")}for(;C.parens>0;){if(t.strictBrackets===!0)throw new SyntaxError(Sn("closing",")"));C.output=Te.escapeLast(C.output,"("),ie("parens")}for(;C.braces>0;){if(t.strictBrackets===!0)throw new SyntaxError(Sn("closing","}"));C.output=Te.escapeLast(C.output,"{"),ie("braces")}if(t.strictSlashes!==!0&&(T.type==="star"||T.type==="bracket")&&K({type:"maybe_slash",value:"",output:`${m}?`}),C.backtrack===!0){C.output="";for(let P of C.tokens)C.output+=P.output!=null?P.output:P.value,P.suffix&&(C.output+=P.suffix)}return C};xo.fastpaths=(n,e)=>{let t={...e},s=typeof t.maxLength=="number"?Math.min(Ys,t.maxLength):Ys,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);n=sd[n]||n;let i=Te.isWindows(e),{DOT_LITERAL:o,SLASH_LITERAL:a,ONE_CHAR:l,DOTS_SLASH:u,NO_DOT:d,NO_DOTS:f,NO_DOTS_SLASH:h,STAR:m,START_ANCHOR:p}=Qn.globChars(i),g=t.dot?f:d,w=t.dot?h:d,_=t.capture?"":"?:",k={negated:!1,prefix:""},$=t.bash===!0?".*?":m;t.capture&&($=`(${$})`);let y=A=>A.noglobstar===!0?$:`(${_}(?:(?!${p}${A.dot?u:o}).)*?)`,v=A=>{switch(A){case"*":return`${g}${l}${$}`;case".*":return`${o}${l}${$}`;case"*.*":return`${g}${$}${o}${l}${$}`;case"*/*":return`${g}${$}${a}${l}${w}${$}`;case"**":return g+y(t);case"**/*":return`(?:${g}${y(t)}${a})?${w}${l}${$}`;case"**/*.*":return`(?:${g}${y(t)}${a})?${w}${$}${o}${l}${$}`;case"**/.*":return`(?:${g}${y(t)}${a})?${o}${l}${$}`;default:{let E=/^(.*?)\.(\w+)$/.exec(A);if(!E)return;let M=v(E[1]);return M?M+o+E[2]:void 0}}},b=Te.removePrefix(n,k),x=v(b);return x&&t.strictSlashes!==!0&&(x+=`${a}?`),x};od.exports=xo});var cd=N((hT,ld)=>{"use strict";var tv=require("path"),nv=nd(),So=ad(),_o=zs(),sv=Jn(),rv=n=>n&&typeof n=="object"&&!Array.isArray(n),be=(n,e,t=!1)=>{if(Array.isArray(n)){let d=n.map(h=>be(h,e,t));return h=>{for(let m of d){let p=m(h);if(p)return p}return!1}}let s=rv(n)&&n.tokens&&n.input;if(n===""||typeof n!="string"&&!s)throw new TypeError("Expected pattern to be a non-empty string");let r=e||{},i=_o.isWindows(e),o=s?be.compileRe(n,e):be.makeRe(n,e,!1,!0),a=o.state;delete o.state;let l=()=>!1;if(r.ignore){let d={...e,ignore:null,onMatch:null,onResult:null};l=be(r.ignore,d,t)}let u=(d,f=!1)=>{let{isMatch:h,match:m,output:p}=be.test(d,o,e,{glob:n,posix:i}),g={glob:n,state:a,regex:o,posix:i,input:d,output:p,match:m,isMatch:h};return typeof r.onResult=="function"&&r.onResult(g),h===!1?(g.isMatch=!1,f?g:!1):l(d)?(typeof r.onIgnore=="function"&&r.onIgnore(g),g.isMatch=!1,f?g:!1):(typeof r.onMatch=="function"&&r.onMatch(g),f?g:!0)};return t&&(u.state=a),u};be.test=(n,e,t,{glob:s,posix:r}={})=>{if(typeof n!="string")throw new TypeError("Expected input to be a string");if(n==="")return{isMatch:!1,output:""};let i=t||{},o=i.format||(r?_o.toPosixSlashes:null),a=n===s,l=a&&o?o(n):n;return a===!1&&(l=o?o(n):n,a=l===s),(a===!1||i.capture===!0)&&(i.matchBase===!0||i.basename===!0?a=be.matchBase(n,e,t,r):a=e.exec(l)),{isMatch:!!a,match:a,output:l}};be.matchBase=(n,e,t,s=_o.isWindows(t))=>(e instanceof RegExp?e:be.makeRe(e,t)).test(tv.basename(n));be.isMatch=(n,e,t)=>be(e,t)(n);be.parse=(n,e)=>Array.isArray(n)?n.map(t=>be.parse(t,e)):So(n,{...e,fastpaths:!1});be.scan=(n,e)=>nv(n,e);be.compileRe=(n,e,t=!1,s=!1)=>{if(t===!0)return n.output;let r=e||{},i=r.contains?"":"^",o=r.contains?"":"$",a=`${i}(?:${n.output})${o}`;n&&n.negated===!0&&(a=`^(?!${a}).*$`);let l=be.toRegex(a,e);return s===!0&&(l.state=n),l};be.makeRe=(n,e={},t=!1,s=!1)=>{if(!n||typeof n!="string")throw new TypeError("Expected a non-empty string");let r={negated:!1,fastpaths:!0};return e.fastpaths!==!1&&(n[0]==="."||n[0]==="*")&&(r.output=So.fastpaths(n,e)),r.output||(r=So(n,e)),be.compileRe(r,e,t,s)};be.toRegex=(n,e)=>{try{let t=e||{};return new RegExp(n,t.flags||(t.nocase?"i":""))}catch(t){if(e&&e.debug===!0)throw t;return/$^/}};be.constants=sv;ld.exports=be});var ko=N((mT,ud)=>{"use strict";ud.exports=cd()});var bd=N((gT,yd)=>{"use strict";var es=require("fs"),{Readable:iv}=require("stream"),Zn=require("path"),{promisify:Zs}=require("util"),Ao=ko(),ov=Zs(es.readdir),av=Zs(es.stat),dd=Zs(es.lstat),lv=Zs(es.realpath),cv="!",md="READDIRP_RECURSIVE_ERROR",uv=new Set(["ENOENT","EPERM","EACCES","ELOOP",md]),$o="files",gd="directories",Xs="files_directories",Js="all",fd=[$o,gd,Xs,Js],dv=n=>uv.has(n.code),[pd,fv]=process.versions.node.split(".").slice(0,2).map(n=>Number.parseInt(n,10)),pv=process.platform==="win32"&&(pd>10||pd===10&&fv>=5),hd=n=>{if(n!==void 0){if(typeof n=="function")return n;if(typeof n=="string"){let e=Ao(n.trim());return t=>e(t.basename)}if(Array.isArray(n)){let e=[],t=[];for(let s of n){let r=s.trim();r.charAt(0)===cv?t.push(Ao(r.slice(1))):e.push(Ao(r))}return t.length>0?e.length>0?s=>e.some(r=>r(s.basename))&&!t.some(r=>r(s.basename)):s=>!t.some(r=>r(s.basename)):s=>e.some(r=>r(s.basename))}}},Qs=class n extends iv{static get defaultOptions(){return{root:".",fileFilter:e=>!0,directoryFilter:e=>!0,type:$o,lstat:!1,depth:2147483648,alwaysStat:!1}}constructor(e={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:e.highWaterMark||4096});let t={...n.defaultOptions,...e},{root:s,type:r}=t;this._fileFilter=hd(t.fileFilter),this._directoryFilter=hd(t.directoryFilter);let i=t.lstat?dd:av;pv?this._stat=o=>i(o,{bigint:!0}):this._stat=i,this._maxDepth=t.depth,this._wantsDir=[gd,Xs,Js].includes(r),this._wantsFile=[$o,Xs,Js].includes(r),this._wantsEverything=r===Js,this._root=Zn.resolve(s),this._isDirent="Dirent"in es&&!t.alwaysStat,this._statsProp=this._isDirent?"dirent":"stats",this._rdOptions={encoding:"utf8",withFileTypes:this._isDirent},this.parents=[this._exploreDir(s,1)],this.reading=!1,this.parent=void 0}async _read(e){if(!this.reading){this.reading=!0;try{for(;!this.destroyed&&e>0;){let{path:t,depth:s,files:r=[]}=this.parent||{};if(r.length>0){let i=r.splice(0,e).map(o=>this._formatEntry(o,t));for(let o of await Promise.all(i)){if(this.destroyed)return;let a=await this._getEntryType(o);a==="directory"&&this._directoryFilter(o)?(s<=this._maxDepth&&this.parents.push(this._exploreDir(o.fullPath,s+1)),this._wantsDir&&(this.push(o),e--)):(a==="file"||this._includeAsFile(o))&&this._fileFilter(o)&&this._wantsFile&&(this.push(o),e--)}}else{let i=this.parents.pop();if(!i){this.push(null);break}if(this.parent=await i,this.destroyed)return}}}catch(t){this.destroy(t)}finally{this.reading=!1}}}async _exploreDir(e,t){let s;try{s=await ov(e,this._rdOptions)}catch(r){this._onError(r)}return{files:s,depth:t,path:e}}async _formatEntry(e,t){let s;try{let r=this._isDirent?e.name:e,i=Zn.resolve(Zn.join(t,r));s={path:Zn.relative(this._root,i),fullPath:i,basename:r},s[this._statsProp]=this._isDirent?e:await this._stat(i)}catch(r){this._onError(r)}return s}_onError(e){dv(e)&&!this.destroyed?this.emit("warn",e):this.destroy(e)}async _getEntryType(e){let t=e&&e[this._statsProp];if(t){if(t.isFile())return"file";if(t.isDirectory())return"directory";if(t&&t.isSymbolicLink()){let s=e.fullPath;try{let r=await lv(s),i=await dd(r);if(i.isFile())return"file";if(i.isDirectory()){let o=r.length;if(s.startsWith(r)&&s.substr(o,1)===Zn.sep){let a=new Error(`Circular symlink detected: "${s}" points to "${r}"`);return a.code=md,this._onError(a)}return"directory"}}catch(r){this._onError(r)}}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}},_n=(n,e={})=>{let t=e.entryType||e.type;if(t==="both"&&(t=Xs),t&&(e.type=t),n){if(typeof n!="string")throw new TypeError("readdirp: root argument must be a string. Usage: readdirp(root, options)");if(t&&!fd.includes(t))throw new Error(`readdirp: Invalid type passed. Use one of ${fd.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return e.root=n,new Qs(e)},hv=(n,e={})=>new Promise((t,s)=>{let r=[];_n(n,e).on("data",i=>r.push(i)).on("end",()=>t(r)).on("error",i=>s(i))});_n.promise=hv;_n.ReaddirpStream=Qs;_n.default=_n;yd.exports=_n});var Co=N((yT,vd)=>{vd.exports=function(n,e){if(typeof n!="string")throw new TypeError("expected path to be a string");if(n==="\\"||n==="/")return"/";var t=n.length;if(t<=1)return n;var s="";if(t>4&&n[3]==="\\"){var r=n[2];(r==="?"||r===".")&&n.slice(0,2)==="\\\\"&&(n=n.slice(2),s="//")}var i=n.split(/[/\\]+/);return e!==!1&&i[i.length-1]===""&&i.pop(),s+i.join("/")}});var Ad=N((_d,kd)=>{"use strict";Object.defineProperty(_d,"__esModule",{value:!0});var Sd=ko(),mv=Co(),wd="!",gv={returnIndex:!1},yv=n=>Array.isArray(n)?n:[n],bv=(n,e)=>{if(typeof n=="function")return n;if(typeof n=="string"){let t=Sd(n,e);return s=>n===s||t(s)}return n instanceof RegExp?t=>n.test(t):t=>!1},xd=(n,e,t,s)=>{let r=Array.isArray(t),i=r?t[0]:t;if(!r&&typeof i!="string")throw new TypeError("anymatch: second argument must be a string: got "+Object.prototype.toString.call(i));let o=mv(i,!1);for(let l=0;l<e.length;l++){let u=e[l];if(u(o))return s?-1:!1}let a=r&&[o].concat(t.slice(1));for(let l=0;l<n.length;l++){let u=n[l];if(r?u(...a):u(o))return s?l:!0}return s?-1:!1},To=(n,e,t=gv)=>{if(n==null)throw new TypeError("anymatch: specify first argument");let s=typeof t=="boolean"?{returnIndex:t}:t,r=s.returnIndex||!1,i=yv(n),o=i.filter(l=>typeof l=="string"&&l.charAt(0)===wd).map(l=>l.slice(1)).map(l=>Sd(l,s)),a=i.filter(l=>typeof l!="string"||typeof l=="string"&&l.charAt(0)!==wd).map(l=>bv(l,s));return e==null?(l,u=!1)=>xd(a,o,l,typeof u=="boolean"?u:!1):xd(a,o,e,r)};To.default=To;kd.exports=To});var Cd=N((bT,$d)=>{$d.exports=function(e){if(typeof e!="string"||e==="")return!1;for(var t;t=/(\\).|([@?!+*]\(.*\))/g.exec(e);){if(t[2])return!0;e=e.slice(t.index+t[0].length)}return!1}});var Eo=N((vT,Ed)=>{var vv=Cd(),Td={"{":"}","(":")","[":"]"},wv=function(n){if(n[0]==="!")return!0;for(var e=0,t=-2,s=-2,r=-2,i=-2,o=-2;e<n.length;){if(n[e]==="*"||n[e+1]==="?"&&/[\].+)]/.test(n[e])||s!==-1&&n[e]==="["&&n[e+1]!=="]"&&(s<e&&(s=n.indexOf("]",e)),s>e&&(o===-1||o>s||(o=n.indexOf("\\",e),o===-1||o>s)))||r!==-1&&n[e]==="{"&&n[e+1]!=="}"&&(r=n.indexOf("}",e),r>e&&(o=n.indexOf("\\",e),o===-1||o>r))||i!==-1&&n[e]==="("&&n[e+1]==="?"&&/[:!=]/.test(n[e+2])&&n[e+3]!==")"&&(i=n.indexOf(")",e),i>e&&(o=n.indexOf("\\",e),o===-1||o>i))||t!==-1&&n[e]==="("&&n[e+1]!=="|"&&(t<e&&(t=n.indexOf("|",e)),t!==-1&&n[t+1]!==")"&&(i=n.indexOf(")",t),i>t&&(o=n.indexOf("\\",t),o===-1||o>i))))return!0;if(n[e]==="\\"){var a=n[e+1];e+=2;var l=Td[a];if(l){var u=n.indexOf(l,e);u!==-1&&(e=u+1)}if(n[e]==="!")return!0}else e++}return!1},xv=function(n){if(n[0]==="!")return!0;for(var e=0;e<n.length;){if(/[*?{}()[\]]/.test(n[e]))return!0;if(n[e]==="\\"){var t=n[e+1];e+=2;var s=Td[t];if(s){var r=n.indexOf(s,e);r!==-1&&(e=r+1)}if(n[e]==="!")return!0}else e++}return!1};Ed.exports=function(e,t){if(typeof e!="string"||e==="")return!1;if(vv(e))return!0;var s=wv;return t&&t.strict===!1&&(s=xv),s(e)}});var Pd=N((wT,Rd)=>{"use strict";var Sv=Eo(),_v=require("path").posix.dirname,kv=require("os").platform()==="win32",Ro="/",Av=/\\/g,$v=/[\{\[].*[\}\]]$/,Cv=/(^|[^\\])([\{\[]|\([^\)]+$)/,Tv=/\\([\!\*\?\|\[\]\(\)\{\}])/g;Rd.exports=function(e,t){var s=Object.assign({flipBackslashes:!0},t);s.flipBackslashes&&kv&&e.indexOf(Ro)<0&&(e=e.replace(Av,Ro)),$v.test(e)&&(e+=Ro),e+="a";do e=_v(e);while(Sv(e)||Cv.test(e));return e.replace(Tv,"$1")}});var er=N(ze=>{"use strict";ze.isInteger=n=>typeof n=="number"?Number.isInteger(n):typeof n=="string"&&n.trim()!==""?Number.isInteger(Number(n)):!1;ze.find=(n,e)=>n.nodes.find(t=>t.type===e);ze.exceedsLimit=(n,e,t=1,s)=>s===!1||!ze.isInteger(n)||!ze.isInteger(e)?!1:(Number(e)-Number(n))/Number(t)>=s;ze.escapeNode=(n,e=0,t)=>{let s=n.nodes[e];s&&(t&&s.type===t||s.type==="open"||s.type==="close")&&s.escaped!==!0&&(s.value="\\"+s.value,s.escaped=!0)};ze.encloseBrace=n=>n.type!=="brace"?!1:n.commas>>0+n.ranges>>0===0?(n.invalid=!0,!0):!1;ze.isInvalidBrace=n=>n.type!=="brace"?!1:n.invalid===!0||n.dollar?!0:n.commas>>0+n.ranges>>0===0||n.open!==!0||n.close!==!0?(n.invalid=!0,!0):!1;ze.isOpenOrClose=n=>n.type==="open"||n.type==="close"?!0:n.open===!0||n.close===!0;ze.reduce=n=>n.reduce((e,t)=>(t.type==="text"&&e.push(t.value),t.type==="range"&&(t.type="text"),e),[]);ze.flatten=(...n)=>{let e=[],t=s=>{for(let r=0;r<s.length;r++){let i=s[r];if(Array.isArray(i)){t(i);continue}i!==void 0&&e.push(i)}return e};return t(n),e}});var tr=N((ST,Md)=>{"use strict";var Od=er();Md.exports=(n,e={})=>{let t=(s,r={})=>{let i=e.escapeInvalid&&Od.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a="";if(s.value)return(i||o)&&Od.isOpenOrClose(s)?"\\"+s.value:s.value;if(s.value)return s.value;if(s.nodes)for(let l of s.nodes)a+=t(l);return a};return t(n)}});var Dd=N((_T,Id)=>{"use strict";Id.exports=function(n){return typeof n=="number"?n-n===0:typeof n=="string"&&n.trim()!==""?Number.isFinite?Number.isFinite(+n):isFinite(+n):!1}});var Kd=N((kT,qd)=>{"use strict";var Ld=Dd(),en=(n,e,t)=>{if(Ld(n)===!1)throw new TypeError("toRegexRange: expected the first argument to be a number");if(e===void 0||n===e)return String(n);if(Ld(e)===!1)throw new TypeError("toRegexRange: expected the second argument to be a number.");let s={relaxZeros:!0,...t};typeof s.strictZeros=="boolean"&&(s.relaxZeros=s.strictZeros===!1);let r=String(s.relaxZeros),i=String(s.shorthand),o=String(s.capture),a=String(s.wrap),l=n+":"+e+"="+r+i+o+a;if(en.cache.hasOwnProperty(l))return en.cache[l].result;let u=Math.min(n,e),d=Math.max(n,e);if(Math.abs(u-d)===1){let g=n+"|"+e;return s.capture?`(${g})`:s.wrap===!1?g:`(?:${g})`}let f=Ud(n)||Ud(e),h={min:n,max:e,a:u,b:d},m=[],p=[];if(f&&(h.isPadded=f,h.maxLen=String(h.max).length),u<0){let g=d<0?Math.abs(d):1;p=Fd(g,Math.abs(u),h,s),u=h.a=0}return d>=0&&(m=Fd(u,d,h,s)),h.negatives=p,h.positives=m,h.result=Ev(p,m,s),s.capture===!0?h.result=`(${h.result})`:s.wrap!==!1&&m.length+p.length>1&&(h.result=`(?:${h.result})`),en.cache[l]=h,h.result};function Ev(n,e,t){let s=Po(n,e,"-",!1,t)||[],r=Po(e,n,"",!1,t)||[],i=Po(n,e,"-?",!0,t)||[];return s.concat(i).concat(r).join("|")}function Rv(n,e){let t=1,s=1,r=jd(n,t),i=new Set([e]);for(;n<=r&&r<=e;)i.add(r),t+=1,r=jd(n,t);for(r=Hd(e+1,s)-1;n<r&&r<=e;)i.add(r),s+=1,r=Hd(e+1,s)-1;return i=[...i],i.sort(Mv),i}function Pv(n,e,t){if(n===e)return{pattern:n,count:[],digits:0};let s=Ov(n,e),r=s.length,i="",o=0;for(let a=0;a<r;a++){let[l,u]=s[a];l===u?i+=l:l!=="0"||u!=="9"?i+=Iv(l,u,t):o++}return o&&(i+=t.shorthand===!0?"\\d":"[0-9]"),{pattern:i,count:[o],digits:r}}function Fd(n,e,t,s){let r=Rv(n,e),i=[],o=n,a;for(let l=0;l<r.length;l++){let u=r[l],d=Pv(String(o),String(u),s),f="";if(!t.isPadded&&a&&a.pattern===d.pattern){a.count.length>1&&a.count.pop(),a.count.push(d.count[0]),a.string=a.pattern+Bd(a.count),o=u+1;continue}t.isPadded&&(f=Dv(u,t,s)),d.string=f+d.pattern+Bd(d.count),i.push(d),o=u+1,a=d}return i}function Po(n,e,t,s,r){let i=[];for(let o of n){let{string:a}=o;!s&&!Nd(e,"string",a)&&i.push(t+a),s&&Nd(e,"string",a)&&i.push(t+a)}return i}function Ov(n,e){let t=[];for(let s=0;s<n.length;s++)t.push([n[s],e[s]]);return t}function Mv(n,e){return n>e?1:e>n?-1:0}function Nd(n,e,t){return n.some(s=>s[e]===t)}function jd(n,e){return Number(String(n).slice(0,-e)+"9".repeat(e))}function Hd(n,e){return n-n%Math.pow(10,e)}function Bd(n){let[e=0,t=""]=n;return t||e>1?`{${e+(t?","+t:"")}}`:""}function Iv(n,e,t){return`[${n}${e-n===1?"":"-"}${e}]`}function Ud(n){return/^-?(0+)\d/.test(n)}function Dv(n,e,t){if(!e.isPadded)return n;let s=Math.abs(e.maxLen-String(n).length),r=t.relaxZeros!==!1;switch(s){case 0:return"";case 1:return r?"0?":"0";case 2:return r?"0{0,2}":"00";default:return r?`0{0,${s}}`:`0{${s}}`}}en.cache={};en.clearCache=()=>en.cache={};qd.exports=en});var Io=N((AT,Xd)=>{"use strict";var Lv=require("util"),Gd=Kd(),Wd=n=>n!==null&&typeof n=="object"&&!Array.isArray(n),Fv=n=>e=>n===!0?Number(e):String(e),Oo=n=>typeof n=="number"||typeof n=="string"&&n!=="",ts=n=>Number.isInteger(+n),Mo=n=>{let e=`${n}`,t=-1;if(e[0]==="-"&&(e=e.slice(1)),e==="0")return!1;for(;e[++t]==="0";);return t>0},Nv=(n,e,t)=>typeof n=="string"||typeof e=="string"?!0:t.stringify===!0,jv=(n,e,t)=>{if(e>0){let s=n[0]==="-"?"-":"";s&&(n=n.slice(1)),n=s+n.padStart(s?e-1:e,"0")}return t===!1?String(n):n},sr=(n,e)=>{let t=n[0]==="-"?"-":"";for(t&&(n=n.slice(1),e--);n.length<e;)n="0"+n;return t?"-"+n:n},Hv=(n,e,t)=>{n.negatives.sort((a,l)=>a<l?-1:a>l?1:0),n.positives.sort((a,l)=>a<l?-1:a>l?1:0);let s=e.capture?"":"?:",r="",i="",o;return n.positives.length&&(r=n.positives.map(a=>sr(String(a),t)).join("|")),n.negatives.length&&(i=`-(${s}${n.negatives.map(a=>sr(String(a),t)).join("|")})`),r&&i?o=`${r}|${i}`:o=r||i,e.wrap?`(${s}${o})`:o},Vd=(n,e,t,s)=>{if(t)return Gd(n,e,{wrap:!1,...s});let r=String.fromCharCode(n);if(n===e)return r;let i=String.fromCharCode(e);return`[${r}-${i}]`},zd=(n,e,t)=>{if(Array.isArray(n)){let s=t.wrap===!0,r=t.capture?"":"?:";return s?`(${r}${n.join("|")})`:n.join("|")}return Gd(n,e,t)},Yd=(...n)=>new RangeError("Invalid range arguments: "+Lv.inspect(...n)),Jd=(n,e,t)=>{if(t.strictRanges===!0)throw Yd([n,e]);return[]},Bv=(n,e)=>{if(e.strictRanges===!0)throw new TypeError(`Expected step "${n}" to be a number`);return[]},Uv=(n,e,t=1,s={})=>{let r=Number(n),i=Number(e);if(!Number.isInteger(r)||!Number.isInteger(i)){if(s.strictRanges===!0)throw Yd([n,e]);return[]}r===0&&(r=0),i===0&&(i=0);let o=r>i,a=String(n),l=String(e),u=String(t);t=Math.max(Math.abs(t),1);let d=Mo(a)||Mo(l)||Mo(u),f=d?Math.max(a.length,l.length,u.length):0,h=d===!1&&Nv(n,e,s)===!1,m=s.transform||Fv(h);if(s.toRegex&&t===1)return Vd(sr(n,f),sr(e,f),!0,s);let p={negatives:[],positives:[]},g=k=>p[k<0?"negatives":"positives"].push(Math.abs(k)),w=[],_=0;for(;o?r>=i:r<=i;)s.toRegex===!0&&t>1?g(r):w.push(jv(m(r,_),f,h)),r=o?r-t:r+t,_++;return s.toRegex===!0?t>1?Hv(p,s,f):zd(w,null,{wrap:!1,...s}):w},qv=(n,e,t=1,s={})=>{if(!ts(n)&&n.length>1||!ts(e)&&e.length>1)return Jd(n,e,s);let r=s.transform||(h=>String.fromCharCode(h)),i=`${n}`.charCodeAt(0),o=`${e}`.charCodeAt(0),a=i>o,l=Math.min(i,o),u=Math.max(i,o);if(s.toRegex&&t===1)return Vd(l,u,!1,s);let d=[],f=0;for(;a?i>=o:i<=o;)d.push(r(i,f)),i=a?i-t:i+t,f++;return s.toRegex===!0?zd(d,null,{wrap:!1,options:s}):d},nr=(n,e,t,s={})=>{if(e==null&&Oo(n))return[n];if(!Oo(n)||!Oo(e))return Jd(n,e,s);if(typeof t=="function")return nr(n,e,1,{transform:t});if(Wd(t))return nr(n,e,0,t);let r={...s};return r.capture===!0&&(r.wrap=!0),t=t||r.step||1,ts(t)?ts(n)&&ts(e)?Uv(n,e,t,r):qv(n,e,Math.max(Math.abs(t),1),r):t!=null&&!Wd(t)?Bv(t,r):nr(n,e,1,t)};Xd.exports=nr});var ef=N(($T,Zd)=>{"use strict";var Kv=Io(),Qd=er(),Wv=(n,e={})=>{let t=(s,r={})=>{let i=Qd.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a=i===!0||o===!0,l=e.escapeInvalid===!0?"\\":"",u="";if(s.isOpen===!0)return l+s.value;if(s.isClose===!0)return console.log("node.isClose",l,s.value),l+s.value;if(s.type==="open")return a?l+s.value:"(";if(s.type==="close")return a?l+s.value:")";if(s.type==="comma")return s.prev.type==="comma"?"":a?s.value:"|";if(s.value)return s.value;if(s.nodes&&s.ranges>0){let d=Qd.reduce(s.nodes),f=Kv(...d,{...e,wrap:!1,toRegex:!0,strictZeros:!0});if(f.length!==0)return d.length>1&&f.length>1?`(${f})`:f}if(s.nodes)for(let d of s.nodes)u+=t(d,s);return u};return t(n)};Zd.exports=Wv});var sf=N((CT,nf)=>{"use strict";var Gv=Io(),tf=tr(),kn=er(),tn=(n="",e="",t=!1)=>{let s=[];if(n=[].concat(n),e=[].concat(e),!e.length)return n;if(!n.length)return t?kn.flatten(e).map(r=>`{${r}}`):e;for(let r of n)if(Array.isArray(r))for(let i of r)s.push(tn(i,e,t));else for(let i of e)t===!0&&typeof i=="string"&&(i=`{${i}}`),s.push(Array.isArray(i)?tn(r,i,t):r+i);return kn.flatten(s)},Vv=(n,e={})=>{let t=e.rangeLimit===void 0?1e3:e.rangeLimit,s=(r,i={})=>{r.queue=[];let o=i,a=i.queue;for(;o.type!=="brace"&&o.type!=="root"&&o.parent;)o=o.parent,a=o.queue;if(r.invalid||r.dollar){a.push(tn(a.pop(),tf(r,e)));return}if(r.type==="brace"&&r.invalid!==!0&&r.nodes.length===2){a.push(tn(a.pop(),["{}"]));return}if(r.nodes&&r.ranges>0){let f=kn.reduce(r.nodes);if(kn.exceedsLimit(...f,e.step,t))throw new RangeError("expanded array length exceeds range limit. Use options.rangeLimit to increase or disable the limit.");let h=Gv(...f,e);h.length===0&&(h=tf(r,e)),a.push(tn(a.pop(),h)),r.nodes=[];return}let l=kn.encloseBrace(r),u=r.queue,d=r;for(;d.type!=="brace"&&d.type!=="root"&&d.parent;)d=d.parent,u=d.queue;for(let f=0;f<r.nodes.length;f++){let h=r.nodes[f];if(h.type==="comma"&&r.type==="brace"){f===1&&u.push(""),u.push("");continue}if(h.type==="close"){a.push(tn(a.pop(),u,l));continue}if(h.value&&h.type!=="open"){u.push(tn(u.pop(),h.value));continue}h.nodes&&s(h,r)}return u};return kn.flatten(s(n))};nf.exports=Vv});var of=N((TT,rf)=>{"use strict";rf.exports={MAX_LENGTH:1e4,CHAR_0:"0",CHAR_9:"9",CHAR_UPPERCASE_A:"A",CHAR_LOWERCASE_A:"a",CHAR_UPPERCASE_Z:"Z",CHAR_LOWERCASE_Z:"z",CHAR_LEFT_PARENTHESES:"(",CHAR_RIGHT_PARENTHESES:")",CHAR_ASTERISK:"*",CHAR_AMPERSAND:"&",CHAR_AT:"@",CHAR_BACKSLASH:"\\",CHAR_BACKTICK:"`",CHAR_CARRIAGE_RETURN:"\r",CHAR_CIRCUMFLEX_ACCENT:"^",CHAR_COLON:":",CHAR_COMMA:",",CHAR_DOLLAR:"$",CHAR_DOT:".",CHAR_DOUBLE_QUOTE:'"',CHAR_EQUAL:"=",CHAR_EXCLAMATION_MARK:"!",CHAR_FORM_FEED:"\f",CHAR_FORWARD_SLASH:"/",CHAR_HASH:"#",CHAR_HYPHEN_MINUS:"-",CHAR_LEFT_ANGLE_BRACKET:"<",CHAR_LEFT_CURLY_BRACE:"{",CHAR_LEFT_SQUARE_BRACKET:"[",CHAR_LINE_FEED:`
|
|
297
|
+
`,CHAR_NO_BREAK_SPACE:"\xA0",CHAR_PERCENT:"%",CHAR_PLUS:"+",CHAR_QUESTION_MARK:"?",CHAR_RIGHT_ANGLE_BRACKET:">",CHAR_RIGHT_CURLY_BRACE:"}",CHAR_RIGHT_SQUARE_BRACKET:"]",CHAR_SEMICOLON:";",CHAR_SINGLE_QUOTE:"'",CHAR_SPACE:" ",CHAR_TAB:" ",CHAR_UNDERSCORE:"_",CHAR_VERTICAL_LINE:"|",CHAR_ZERO_WIDTH_NOBREAK_SPACE:"\uFEFF"}});var df=N((ET,uf)=>{"use strict";var zv=tr(),{MAX_LENGTH:af,CHAR_BACKSLASH:Do,CHAR_BACKTICK:Yv,CHAR_COMMA:Jv,CHAR_DOT:Xv,CHAR_LEFT_PARENTHESES:Qv,CHAR_RIGHT_PARENTHESES:Zv,CHAR_LEFT_CURLY_BRACE:ew,CHAR_RIGHT_CURLY_BRACE:tw,CHAR_LEFT_SQUARE_BRACKET:lf,CHAR_RIGHT_SQUARE_BRACKET:cf,CHAR_DOUBLE_QUOTE:nw,CHAR_SINGLE_QUOTE:sw,CHAR_NO_BREAK_SPACE:rw,CHAR_ZERO_WIDTH_NOBREAK_SPACE:iw}=of(),ow=(n,e={})=>{if(typeof n!="string")throw new TypeError("Expected a string");let t=e||{},s=typeof t.maxLength=="number"?Math.min(af,t.maxLength):af;if(n.length>s)throw new SyntaxError(`Input length (${n.length}), exceeds max characters (${s})`);let r={type:"root",input:n,nodes:[]},i=[r],o=r,a=r,l=0,u=n.length,d=0,f=0,h,m=()=>n[d++],p=g=>{if(g.type==="text"&&a.type==="dot"&&(a.type="text"),a&&a.type==="text"&&g.type==="text"){a.value+=g.value;return}return o.nodes.push(g),g.parent=o,g.prev=a,a=g,g};for(p({type:"bos"});d<u;)if(o=i[i.length-1],h=m(),!(h===iw||h===rw)){if(h===Do){p({type:"text",value:(e.keepEscaping?h:"")+m()});continue}if(h===cf){p({type:"text",value:"\\"+h});continue}if(h===lf){l++;let g;for(;d<u&&(g=m());){if(h+=g,g===lf){l++;continue}if(g===Do){h+=m();continue}if(g===cf&&(l--,l===0))break}p({type:"text",value:h});continue}if(h===Qv){o=p({type:"paren",nodes:[]}),i.push(o),p({type:"text",value:h});continue}if(h===Zv){if(o.type!=="paren"){p({type:"text",value:h});continue}o=i.pop(),p({type:"text",value:h}),o=i[i.length-1];continue}if(h===nw||h===sw||h===Yv){let g=h,w;for(e.keepQuotes!==!0&&(h="");d<u&&(w=m());){if(w===Do){h+=w+m();continue}if(w===g){e.keepQuotes===!0&&(h+=w);break}h+=w}p({type:"text",value:h});continue}if(h===ew){f++;let w={type:"brace",open:!0,close:!1,dollar:a.value&&a.value.slice(-1)==="$"||o.dollar===!0,depth:f,commas:0,ranges:0,nodes:[]};o=p(w),i.push(o),p({type:"open",value:h});continue}if(h===tw){if(o.type!=="brace"){p({type:"text",value:h});continue}let g="close";o=i.pop(),o.close=!0,p({type:g,value:h}),f--,o=i[i.length-1];continue}if(h===Jv&&f>0){if(o.ranges>0){o.ranges=0;let g=o.nodes.shift();o.nodes=[g,{type:"text",value:zv(o)}]}p({type:"comma",value:h}),o.commas++;continue}if(h===Xv&&f>0&&o.commas===0){let g=o.nodes;if(f===0||g.length===0){p({type:"text",value:h});continue}if(a.type==="dot"){if(o.range=[],a.value+=h,a.type="range",o.nodes.length!==3&&o.nodes.length!==5){o.invalid=!0,o.ranges=0,a.type="text";continue}o.ranges++,o.args=[];continue}if(a.type==="range"){g.pop();let w=g[g.length-1];w.value+=a.value+h,a=w,o.ranges--;continue}p({type:"dot",value:h});continue}p({type:"text",value:h})}do if(o=i.pop(),o.type!=="root"){o.nodes.forEach(_=>{_.nodes||(_.type==="open"&&(_.isOpen=!0),_.type==="close"&&(_.isClose=!0),_.nodes||(_.type="text"),_.invalid=!0)});let g=i[i.length-1],w=g.nodes.indexOf(o);g.nodes.splice(w,1,...o.nodes)}while(i.length>0);return p({type:"eos"}),r};uf.exports=ow});var hf=N((RT,pf)=>{"use strict";var ff=tr(),aw=ef(),lw=sf(),cw=df(),qe=(n,e={})=>{let t=[];if(Array.isArray(n))for(let s of n){let r=qe.create(s,e);Array.isArray(r)?t.push(...r):t.push(r)}else t=[].concat(qe.create(n,e));return e&&e.expand===!0&&e.nodupes===!0&&(t=[...new Set(t)]),t};qe.parse=(n,e={})=>cw(n,e);qe.stringify=(n,e={})=>ff(typeof n=="string"?qe.parse(n,e):n,e);qe.compile=(n,e={})=>(typeof n=="string"&&(n=qe.parse(n,e)),aw(n,e));qe.expand=(n,e={})=>{typeof n=="string"&&(n=qe.parse(n,e));let t=lw(n,e);return e.noempty===!0&&(t=t.filter(Boolean)),e.nodupes===!0&&(t=[...new Set(t)]),t};qe.create=(n,e={})=>n===""||n.length<3?[n]:e.expand!==!0?qe.compile(n,e):qe.expand(n,e);pf.exports=qe});var mf=N((PT,uw)=>{uw.exports=["3dm","3ds","3g2","3gp","7z","a","aac","adp","afdesign","afphoto","afpub","ai","aif","aiff","alz","ape","apk","appimage","ar","arj","asf","au","avi","bak","baml","bh","bin","bk","bmp","btif","bz2","bzip2","cab","caf","cgm","class","cmx","cpio","cr2","cur","dat","dcm","deb","dex","djvu","dll","dmg","dng","doc","docm","docx","dot","dotm","dra","DS_Store","dsk","dts","dtshd","dvb","dwg","dxf","ecelp4800","ecelp7470","ecelp9600","egg","eol","eot","epub","exe","f4v","fbs","fh","fla","flac","flatpak","fli","flv","fpx","fst","fvt","g3","gh","gif","graffle","gz","gzip","h261","h263","h264","icns","ico","ief","img","ipa","iso","jar","jpeg","jpg","jpgv","jpm","jxr","key","ktx","lha","lib","lvp","lz","lzh","lzma","lzo","m3u","m4a","m4v","mar","mdi","mht","mid","midi","mj2","mka","mkv","mmr","mng","mobi","mov","movie","mp3","mp4","mp4a","mpeg","mpg","mpga","mxu","nef","npx","numbers","nupkg","o","odp","ods","odt","oga","ogg","ogv","otf","ott","pages","pbm","pcx","pdb","pdf","pea","pgm","pic","png","pnm","pot","potm","potx","ppa","ppam","ppm","pps","ppsm","ppsx","ppt","pptm","pptx","psd","pya","pyc","pyo","pyv","qt","rar","ras","raw","resources","rgb","rip","rlc","rmf","rmvb","rpm","rtf","rz","s3m","s7z","scpt","sgi","shar","snap","sil","sketch","slk","smv","snk","so","stl","suo","sub","swf","tar","tbz","tbz2","tga","tgz","thmx","tif","tiff","tlz","ttc","ttf","txz","udf","uvh","uvi","uvm","uvp","uvs","uvu","viv","vob","war","wav","wax","wbmp","wdp","weba","webm","webp","whl","wim","wm","wma","wmv","wmx","woff","woff2","wrm","wvx","xbm","xif","xla","xlam","xls","xlsb","xlsm","xlsx","xlt","xltm","xltx","xm","xmind","xpi","xpm","xwd","xz","z","zip","zipx"]});var yf=N((OT,gf)=>{gf.exports=mf()});var vf=N((MT,bf)=>{"use strict";var dw=require("path"),fw=yf(),pw=new Set(fw);bf.exports=n=>pw.has(dw.extname(n).slice(1).toLowerCase())});var rr=N(B=>{"use strict";var{sep:hw}=require("path"),{platform:Lo}=process,mw=require("os");B.EV_ALL="all";B.EV_READY="ready";B.EV_ADD="add";B.EV_CHANGE="change";B.EV_ADD_DIR="addDir";B.EV_UNLINK="unlink";B.EV_UNLINK_DIR="unlinkDir";B.EV_RAW="raw";B.EV_ERROR="error";B.STR_DATA="data";B.STR_END="end";B.STR_CLOSE="close";B.FSEVENT_CREATED="created";B.FSEVENT_MODIFIED="modified";B.FSEVENT_DELETED="deleted";B.FSEVENT_MOVED="moved";B.FSEVENT_CLONED="cloned";B.FSEVENT_UNKNOWN="unknown";B.FSEVENT_FLAG_MUST_SCAN_SUBDIRS=1;B.FSEVENT_TYPE_FILE="file";B.FSEVENT_TYPE_DIRECTORY="directory";B.FSEVENT_TYPE_SYMLINK="symlink";B.KEY_LISTENERS="listeners";B.KEY_ERR="errHandlers";B.KEY_RAW="rawEmitters";B.HANDLER_KEYS=[B.KEY_LISTENERS,B.KEY_ERR,B.KEY_RAW];B.DOT_SLASH=`.${hw}`;B.BACK_SLASH_RE=/\\/g;B.DOUBLE_SLASH_RE=/\/\//;B.SLASH_OR_BACK_SLASH_RE=/[/\\]/;B.DOT_RE=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/;B.REPLACER_RE=/^\.[/\\]/;B.SLASH="/";B.SLASH_SLASH="//";B.BRACE_START="{";B.BANG="!";B.ONE_DOT=".";B.TWO_DOTS="..";B.STAR="*";B.GLOBSTAR="**";B.ROOT_GLOBSTAR="/**/*";B.SLASH_GLOBSTAR="/**";B.DIR_SUFFIX="Dir";B.ANYMATCH_OPTS={dot:!0};B.STRING_TYPE="string";B.FUNCTION_TYPE="function";B.EMPTY_STR="";B.EMPTY_FN=()=>{};B.IDENTITY_FN=n=>n;B.isWindows=Lo==="win32";B.isMacos=Lo==="darwin";B.isLinux=Lo==="linux";B.isIBMi=mw.type()==="OS400"});var Af=N((DT,kf)=>{"use strict";var Rt=require("fs"),_e=require("path"),{promisify:is}=require("util"),gw=vf(),{isWindows:yw,isLinux:bw,EMPTY_FN:vw,EMPTY_STR:ww,KEY_LISTENERS:An,KEY_ERR:Fo,KEY_RAW:ns,HANDLER_KEYS:xw,EV_CHANGE:or,EV_ADD:ir,EV_ADD_DIR:Sw,EV_ERROR:xf,STR_DATA:_w,STR_END:kw,BRACE_START:Aw,STAR:$w}=rr(),Cw="watch",Tw=is(Rt.open),Sf=is(Rt.stat),Ew=is(Rt.lstat),Rw=is(Rt.close),No=is(Rt.realpath),Pw={lstat:Ew,stat:Sf},Ho=(n,e)=>{n instanceof Set?n.forEach(e):e(n)},ss=(n,e,t)=>{let s=n[e];s instanceof Set||(n[e]=s=new Set([s])),s.add(t)},Ow=n=>e=>{let t=n[e];t instanceof Set?t.clear():delete n[e]},rs=(n,e,t)=>{let s=n[e];s instanceof Set?s.delete(t):s===t&&delete n[e]},_f=n=>n instanceof Set?n.size===0:!n,ar=new Map;function wf(n,e,t,s,r){let i=(o,a)=>{t(n),r(o,a,{watchedPath:n}),a&&n!==a&&lr(_e.resolve(n,a),An,_e.join(n,a))};try{return Rt.watch(n,e,i)}catch(o){s(o)}}var lr=(n,e,t,s,r)=>{let i=ar.get(n);i&&Ho(i[e],o=>{o(t,s,r)})},Mw=(n,e,t,s)=>{let{listener:r,errHandler:i,rawEmitter:o}=s,a=ar.get(e),l;if(!t.persistent)return l=wf(n,t,r,i,o),l.close.bind(l);if(a)ss(a,An,r),ss(a,Fo,i),ss(a,ns,o);else{if(l=wf(n,t,lr.bind(null,e,An),i,lr.bind(null,e,ns)),!l)return;l.on(xf,async u=>{let d=lr.bind(null,e,Fo);if(a.watcherUnusable=!0,yw&&u.code==="EPERM")try{let f=await Tw(n,"r");await Rw(f),d(u)}catch{}else d(u)}),a={listeners:r,errHandlers:i,rawEmitters:o,watcher:l},ar.set(e,a)}return()=>{rs(a,An,r),rs(a,Fo,i),rs(a,ns,o),_f(a.listeners)&&(a.watcher.close(),ar.delete(e),xw.forEach(Ow(a)),a.watcher=void 0,Object.freeze(a))}},jo=new Map,Iw=(n,e,t,s)=>{let{listener:r,rawEmitter:i}=s,o=jo.get(e),a=new Set,l=new Set,u=o&&o.options;return u&&(u.persistent<t.persistent||u.interval>t.interval)&&(a=o.listeners,l=o.rawEmitters,Rt.unwatchFile(e),o=void 0),o?(ss(o,An,r),ss(o,ns,i)):(o={listeners:r,rawEmitters:i,options:t,watcher:Rt.watchFile(e,t,(d,f)=>{Ho(o.rawEmitters,m=>{m(or,e,{curr:d,prev:f})});let h=d.mtimeMs;(d.size!==f.size||h>f.mtimeMs||h===0)&&Ho(o.listeners,m=>m(n,d))})},jo.set(e,o)),()=>{rs(o,An,r),rs(o,ns,i),_f(o.listeners)&&(jo.delete(e),Rt.unwatchFile(e),o.options=o.watcher=void 0,Object.freeze(o))}},Bo=class{constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let s=this.fsw.options,r=_e.dirname(e),i=_e.basename(e);this.fsw._getWatchedDir(r).add(i);let a=_e.resolve(e),l={persistent:s.persistent};t||(t=vw);let u;return s.usePolling?(l.interval=s.enableBinaryInterval&&gw(i)?s.binaryInterval:s.interval,u=Iw(e,a,l,{listener:t,rawEmitter:this.fsw._emitRaw})):u=Mw(e,a,l,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw}),u}_handleFile(e,t,s){if(this.fsw.closed)return;let r=_e.dirname(e),i=_e.basename(e),o=this.fsw._getWatchedDir(r),a=t;if(o.has(i))return;let l=async(d,f)=>{if(this.fsw._throttle(Cw,e,5)){if(!f||f.mtimeMs===0)try{let h=await Sf(e);if(this.fsw.closed)return;let m=h.atimeMs,p=h.mtimeMs;(!m||m<=p||p!==a.mtimeMs)&&this.fsw._emit(or,e,h),bw&&a.ino!==h.ino?(this.fsw._closeFile(d),a=h,this.fsw._addPathCloser(d,this._watchWithNodeFs(e,l))):a=h}catch{this.fsw._remove(r,i)}else if(o.has(i)){let h=f.atimeMs,m=f.mtimeMs;(!h||h<=m||m!==a.mtimeMs)&&this.fsw._emit(or,e,f),a=f}}},u=this._watchWithNodeFs(e,l);if(!(s&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(ir,e,0))return;this.fsw._emit(ir,e,t)}return u}async _handleSymlink(e,t,s,r){if(this.fsw.closed)return;let i=e.fullPath,o=this.fsw._getWatchedDir(t);if(!this.fsw.options.followSymlinks){this.fsw._incrReadyCount();let a;try{a=await No(s)}catch{return this.fsw._emitReady(),!0}return this.fsw.closed?void 0:(o.has(r)?this.fsw._symlinkPaths.get(i)!==a&&(this.fsw._symlinkPaths.set(i,a),this.fsw._emit(or,s,e.stats)):(o.add(r),this.fsw._symlinkPaths.set(i,a),this.fsw._emit(ir,s,e.stats)),this.fsw._emitReady(),!0)}if(this.fsw._symlinkPaths.has(i))return!0;this.fsw._symlinkPaths.set(i,!0)}_handleRead(e,t,s,r,i,o,a){if(e=_e.join(e,ww),!s.hasGlob&&(a=this.fsw._throttle("readdir",e,1e3),!a))return;let l=this.fsw._getWatchedDir(s.path),u=new Set,d=this.fsw._readdirp(e,{fileFilter:f=>s.filterPath(f),directoryFilter:f=>s.filterDir(f),depth:0}).on(_w,async f=>{if(this.fsw.closed){d=void 0;return}let h=f.path,m=_e.join(e,h);if(u.add(h),!(f.stats.isSymbolicLink()&&await this._handleSymlink(f,e,m,h))){if(this.fsw.closed){d=void 0;return}(h===r||!r&&!l.has(h))&&(this.fsw._incrReadyCount(),m=_e.join(i,_e.relative(i,m)),this._addToNodeFs(m,t,s,o+1))}}).on(xf,this._boundHandleError);return new Promise(f=>d.once(kw,()=>{if(this.fsw.closed){d=void 0;return}let h=a?a.clear():!1;f(),l.getChildren().filter(m=>m!==e&&!u.has(m)&&(!s.hasGlob||s.filterPath({fullPath:_e.resolve(e,m)}))).forEach(m=>{this.fsw._remove(e,m)}),d=void 0,h&&this._handleRead(e,!1,s,r,i,o,a)}))}async _handleDir(e,t,s,r,i,o,a){let l=this.fsw._getWatchedDir(_e.dirname(e)),u=l.has(_e.basename(e));!(s&&this.fsw.options.ignoreInitial)&&!i&&!u&&(!o.hasGlob||o.globFilter(e))&&this.fsw._emit(Sw,e,t),l.add(_e.basename(e)),this.fsw._getWatchedDir(e);let d,f,h=this.fsw.options.depth;if((h==null||r<=h)&&!this.fsw._symlinkPaths.has(a)){if(!i&&(await this._handleRead(e,s,o,i,e,r,d),this.fsw.closed))return;f=this._watchWithNodeFs(e,(m,p)=>{p&&p.mtimeMs===0||this._handleRead(m,!1,o,i,e,r,d)})}return f}async _addToNodeFs(e,t,s,r,i){let o=this.fsw._emitReady;if(this.fsw._isIgnored(e)||this.fsw.closed)return o(),!1;let a=this.fsw._getWatchHelpers(e,r);!a.hasGlob&&s&&(a.hasGlob=s.hasGlob,a.globFilter=s.globFilter,a.filterPath=l=>s.filterPath(l),a.filterDir=l=>s.filterDir(l));try{let l=await Pw[a.statMethod](a.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(a.watchPath,l))return o(),!1;let u=this.fsw.options.followSymlinks&&!e.includes($w)&&!e.includes(Aw),d;if(l.isDirectory()){let f=_e.resolve(e),h=u?await No(e):e;if(this.fsw.closed||(d=await this._handleDir(a.watchPath,l,t,r,i,a,h),this.fsw.closed))return;f!==h&&h!==void 0&&this.fsw._symlinkPaths.set(f,h)}else if(l.isSymbolicLink()){let f=u?await No(e):e;if(this.fsw.closed)return;let h=_e.dirname(a.watchPath);if(this.fsw._getWatchedDir(h).add(a.watchPath),this.fsw._emit(ir,a.watchPath,l),d=await this._handleDir(h,l,t,r,e,a,f),this.fsw.closed)return;f!==void 0&&this.fsw._symlinkPaths.set(_e.resolve(e),f)}else d=this._handleFile(a.watchPath,l,t);return o(),this.fsw._addPathCloser(e,d),!1}catch(l){if(this.fsw._handleError(l))return o(),e}}};kf.exports=Bo});var Of=N((LT,Yo)=>{"use strict";var Vo=require("fs"),ke=require("path"),{promisify:zo}=require("util"),$n;try{$n=require("fsevents")}catch(n){process.env.CHOKIDAR_PRINT_FSEVENTS_REQUIRE_ERROR&&console.error(n)}if($n){let n=process.version.match(/v(\d+)\.(\d+)/);if(n&&n[1]&&n[2]){let e=Number.parseInt(n[1],10),t=Number.parseInt(n[2],10);e===8&&t<16&&($n=void 0)}}var{EV_ADD:Uo,EV_CHANGE:Dw,EV_ADD_DIR:$f,EV_UNLINK:cr,EV_ERROR:Lw,STR_DATA:Fw,STR_END:Nw,FSEVENT_CREATED:jw,FSEVENT_MODIFIED:Hw,FSEVENT_DELETED:Bw,FSEVENT_MOVED:Uw,FSEVENT_UNKNOWN:qw,FSEVENT_FLAG_MUST_SCAN_SUBDIRS:Kw,FSEVENT_TYPE_FILE:Ww,FSEVENT_TYPE_DIRECTORY:os,FSEVENT_TYPE_SYMLINK:Pf,ROOT_GLOBSTAR:Cf,DIR_SUFFIX:Gw,DOT_SLASH:Tf,FUNCTION_TYPE:qo,EMPTY_FN:Vw,IDENTITY_FN:zw}=rr(),Yw=n=>isNaN(n)?{}:{depth:n},Wo=zo(Vo.stat),Jw=zo(Vo.lstat),Ef=zo(Vo.realpath),Xw={stat:Wo,lstat:Jw},nn=new Map,Qw=10,Zw=new Set([69888,70400,71424,72704,73472,131328,131840,262912]),ex=(n,e)=>({stop:$n.watch(n,e)});function tx(n,e,t,s){let r=ke.extname(e)?ke.dirname(e):e,i=ke.dirname(r),o=nn.get(r);nx(i)&&(r=i);let a=ke.resolve(n),l=a!==e,u=(f,h,m)=>{l&&(f=f.replace(e,a)),(f===a||!f.indexOf(a+ke.sep))&&t(f,h,m)},d=!1;for(let f of nn.keys())if(e.indexOf(ke.resolve(f)+ke.sep)===0){r=f,o=nn.get(r),d=!0;break}return o||d?o.listeners.add(u):(o={listeners:new Set([u]),rawEmitter:s,watcher:ex(r,(f,h)=>{if(!o.listeners.size||h&Kw)return;let m=$n.getInfo(f,h);o.listeners.forEach(p=>{p(f,h,m)}),o.rawEmitter(m.event,f,m)})},nn.set(r,o)),()=>{let f=o.listeners;if(f.delete(u),!f.size&&(nn.delete(r),o.watcher))return o.watcher.stop().then(()=>{o.rawEmitter=o.watcher=void 0,Object.freeze(o)})}}var nx=n=>{let e=0;for(let t of nn.keys())if(t.indexOf(n)===0&&(e++,e>=Qw))return!0;return!1},sx=()=>$n&&nn.size<128,Ko=(n,e)=>{let t=0;for(;!n.indexOf(e)&&(n=ke.dirname(n))!==e;)t++;return t},Rf=(n,e)=>n.type===os&&e.isDirectory()||n.type===Pf&&e.isSymbolicLink()||n.type===Ww&&e.isFile(),Go=class{constructor(e){this.fsw=e}checkIgnored(e,t){let s=this.fsw._ignoredPaths;if(this.fsw._isIgnored(e,t))return s.add(e),t&&t.isDirectory()&&s.add(e+Cf),!0;s.delete(e),s.delete(e+Cf)}addOrChange(e,t,s,r,i,o,a,l){let u=i.has(o)?Dw:Uo;this.handleEvent(u,e,t,s,r,i,o,a,l)}async checkExists(e,t,s,r,i,o,a,l){try{let u=await Wo(e);if(this.fsw.closed)return;Rf(a,u)?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(cr,e,t,s,r,i,o,a,l)}catch(u){u.code==="EACCES"?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(cr,e,t,s,r,i,o,a,l)}}handleEvent(e,t,s,r,i,o,a,l,u){if(!(this.fsw.closed||this.checkIgnored(t)))if(e===cr){let d=l.type===os;(d||o.has(a))&&this.fsw._remove(i,a,d)}else{if(e===Uo){if(l.type===os&&this.fsw._getWatchedDir(t),l.type===Pf&&u.followSymlinks){let f=u.depth===void 0?void 0:Ko(s,r)+1;return this._addToFsEvents(t,!1,!0,f)}this.fsw._getWatchedDir(i).add(a)}let d=l.type===os?e+Gw:e;this.fsw._emit(d,t),d===$f&&this._addToFsEvents(t,!1,!0)}}_watchWithFsEvents(e,t,s,r){if(this.fsw.closed||this.fsw._isIgnored(e))return;let i=this.fsw.options,a=tx(e,t,async(l,u,d)=>{if(this.fsw.closed||i.depth!==void 0&&Ko(l,t)>i.depth)return;let f=s(ke.join(e,ke.relative(e,l)));if(r&&!r(f))return;let h=ke.dirname(f),m=ke.basename(f),p=this.fsw._getWatchedDir(d.type===os?f:h);if(Zw.has(u)||d.event===qw)if(typeof i.ignored===qo){let g;try{g=await Wo(f)}catch{}if(this.fsw.closed||this.checkIgnored(f,g))return;Rf(d,g)?this.addOrChange(f,l,t,h,p,m,d,i):this.handleEvent(cr,f,l,t,h,p,m,d,i)}else this.checkExists(f,l,t,h,p,m,d,i);else switch(d.event){case jw:case Hw:return this.addOrChange(f,l,t,h,p,m,d,i);case Bw:case Uw:return this.checkExists(f,l,t,h,p,m,d,i)}},this.fsw._emitRaw);return this.fsw._emitReady(),a}async _handleFsEventsSymlink(e,t,s,r){if(!(this.fsw.closed||this.fsw._symlinkPaths.has(t))){this.fsw._symlinkPaths.set(t,!0),this.fsw._incrReadyCount();try{let i=await Ef(e);if(this.fsw.closed)return;if(this.fsw._isIgnored(i))return this.fsw._emitReady();this.fsw._incrReadyCount(),this._addToFsEvents(i||e,o=>{let a=e;return i&&i!==Tf?a=o.replace(i,e):o!==Tf&&(a=ke.join(e,o)),s(a)},!1,r)}catch(i){if(this.fsw._handleError(i))return this.fsw._emitReady()}}}emitAdd(e,t,s,r,i){let o=s(e),a=t.isDirectory(),l=this.fsw._getWatchedDir(ke.dirname(o)),u=ke.basename(o);a&&this.fsw._getWatchedDir(o),!l.has(u)&&(l.add(u),(!r.ignoreInitial||i===!0)&&this.fsw._emit(a?$f:Uo,o,t))}initWatch(e,t,s,r){if(this.fsw.closed)return;let i=this._watchWithFsEvents(s.watchPath,ke.resolve(e||s.watchPath),r,s.globFilter);this.fsw._addPathCloser(t,i)}async _addToFsEvents(e,t,s,r){if(this.fsw.closed)return;let i=this.fsw.options,o=typeof t===qo?t:zw,a=this.fsw._getWatchHelpers(e);try{let l=await Xw[a.statMethod](a.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(a.watchPath,l))throw null;if(l.isDirectory()){if(a.globFilter||this.emitAdd(o(e),l,o,i,s),r&&r>i.depth)return;this.fsw._readdirp(a.watchPath,{fileFilter:u=>a.filterPath(u),directoryFilter:u=>a.filterDir(u),...Yw(i.depth-(r||0))}).on(Fw,u=>{if(this.fsw.closed||u.stats.isDirectory()&&!a.filterPath(u))return;let d=ke.join(a.watchPath,u.path),{fullPath:f}=u;if(a.followSymlinks&&u.stats.isSymbolicLink()){let h=i.depth===void 0?void 0:Ko(d,ke.resolve(a.watchPath))+1;this._handleFsEventsSymlink(d,f,o,h)}else this.emitAdd(d,u.stats,o,i,s)}).on(Lw,Vw).on(Nw,()=>{this.fsw._emitReady()})}else this.emitAdd(a.watchPath,l,o,i,s),this.fsw._emitReady()}catch(l){(!l||this.fsw._handleError(l))&&(this.fsw._emitReady(),this.fsw._emitReady())}if(i.persistent&&s!==!0)if(typeof t===qo)this.initWatch(void 0,e,a,o);else{let l;try{l=await Ef(a.watchPath)}catch{}this.initWatch(l,e,a,o)}}};Yo.exports=Go;Yo.exports.canUse=sx});var qf=N(ua=>{"use strict";var{EventEmitter:rx}=require("events"),la=require("fs"),oe=require("path"),{promisify:jf}=require("util"),ix=bd(),ta=Ad().default,ox=Pd(),Jo=Eo(),ax=hf(),lx=Co(),cx=Af(),Mf=Of(),{EV_ALL:Xo,EV_READY:ux,EV_ADD:ur,EV_CHANGE:as,EV_UNLINK:If,EV_ADD_DIR:dx,EV_UNLINK_DIR:fx,EV_RAW:px,EV_ERROR:Qo,STR_CLOSE:hx,STR_END:mx,BACK_SLASH_RE:gx,DOUBLE_SLASH_RE:Df,SLASH_OR_BACK_SLASH_RE:yx,DOT_RE:bx,REPLACER_RE:vx,SLASH:Zo,SLASH_SLASH:wx,BRACE_START:xx,BANG:na,ONE_DOT:Hf,TWO_DOTS:Sx,GLOBSTAR:_x,SLASH_GLOBSTAR:ea,ANYMATCH_OPTS:sa,STRING_TYPE:ca,FUNCTION_TYPE:kx,EMPTY_STR:ra,EMPTY_FN:Ax,isWindows:$x,isMacos:Cx,isIBMi:Tx}=rr(),Ex=jf(la.stat),Rx=jf(la.readdir),ia=(n=[])=>Array.isArray(n)?n:[n],Bf=(n,e=[])=>(n.forEach(t=>{Array.isArray(t)?Bf(t,e):e.push(t)}),e),Lf=n=>{let e=Bf(ia(n));if(!e.every(t=>typeof t===ca))throw new TypeError(`Non-string provided as watch path: ${e}`);return e.map(Uf)},Ff=n=>{let e=n.replace(gx,Zo),t=!1;for(e.startsWith(wx)&&(t=!0);e.match(Df);)e=e.replace(Df,Zo);return t&&(e=Zo+e),e},Uf=n=>Ff(oe.normalize(Ff(n))),Nf=(n=ra)=>e=>typeof e!==ca?e:Uf(oe.isAbsolute(e)?e:oe.join(n,e)),Px=(n,e)=>oe.isAbsolute(n)?n:n.startsWith(na)?na+oe.join(e,n.slice(1)):oe.join(e,n),rt=(n,e)=>n[e]===void 0,oa=class{constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==Hf&&e!==Sx&&t.add(e)}async remove(e){let{items:t}=this;if(!t||(t.delete(e),t.size>0))return;let s=this.path;try{await Rx(s)}catch{this._removeWatcher&&this._removeWatcher(oe.dirname(s),oe.basename(s))}}has(e){let{items:t}=this;if(t)return t.has(e)}getChildren(){let{items:e}=this;if(e)return[...e.values()]}dispose(){this.items.clear(),delete this.path,delete this._removeWatcher,delete this.items,Object.freeze(this)}},Ox="stat",Mx="lstat",aa=class{constructor(e,t,s,r){this.fsw=r,this.path=e=e.replace(vx,ra),this.watchPath=t,this.fullWatchPath=oe.resolve(t),this.hasGlob=t!==e,e===ra&&(this.hasGlob=!1),this.globSymlink=this.hasGlob&&s?void 0:!1,this.globFilter=this.hasGlob?ta(e,void 0,sa):!1,this.dirParts=this.getDirParts(e),this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=s,this.statMethod=s?Ox:Mx}checkGlobSymlink(e){return this.globSymlink===void 0&&(this.globSymlink=e.fullParentDir===this.fullWatchPath?!1:{realPath:e.fullParentDir,linkPath:this.fullWatchPath}),this.globSymlink?e.fullPath.replace(this.globSymlink.realPath,this.globSymlink.linkPath):e.fullPath}entryPath(e){return oe.join(this.watchPath,oe.relative(this.watchPath,this.checkGlobSymlink(e)))}filterPath(e){let{stats:t}=e;if(t&&t.isSymbolicLink())return this.filterDir(e);let s=this.entryPath(e);return(this.hasGlob&&typeof this.globFilter===kx?this.globFilter(s):!0)&&this.fsw._isntIgnored(s,t)&&this.fsw._hasReadPermissions(t)}getDirParts(e){if(!this.hasGlob)return[];let t=[];return(e.includes(xx)?ax.expand(e):[e]).forEach(r=>{t.push(oe.relative(this.watchPath,r).split(yx))}),t}filterDir(e){if(this.hasGlob){let t=this.getDirParts(this.checkGlobSymlink(e)),s=!1;this.unmatchedGlob=!this.dirParts.some(r=>r.every((i,o)=>(i===_x&&(s=!0),s||!t[0][o]||ta(i,t[0][o],sa))))}return!this.unmatchedGlob&&this.fsw._isntIgnored(this.entryPath(e),e.stats)}},dr=class extends rx{constructor(e){super();let t={};e&&Object.assign(t,e),this._watched=new Map,this._closers=new Map,this._ignoredPaths=new Set,this._throttled=new Map,this._symlinkPaths=new Map,this._streams=new Set,this.closed=!1,rt(t,"persistent")&&(t.persistent=!0),rt(t,"ignoreInitial")&&(t.ignoreInitial=!1),rt(t,"ignorePermissionErrors")&&(t.ignorePermissionErrors=!1),rt(t,"interval")&&(t.interval=100),rt(t,"binaryInterval")&&(t.binaryInterval=300),rt(t,"disableGlobbing")&&(t.disableGlobbing=!1),t.enableBinaryInterval=t.binaryInterval!==t.interval,rt(t,"useFsEvents")&&(t.useFsEvents=!t.usePolling),Mf.canUse()||(t.useFsEvents=!1),rt(t,"usePolling")&&!t.useFsEvents&&(t.usePolling=Cx),Tx&&(t.usePolling=!0);let r=process.env.CHOKIDAR_USEPOLLING;if(r!==void 0){let l=r.toLowerCase();l==="false"||l==="0"?t.usePolling=!1:l==="true"||l==="1"?t.usePolling=!0:t.usePolling=!!l}let i=process.env.CHOKIDAR_INTERVAL;i&&(t.interval=Number.parseInt(i,10)),rt(t,"atomic")&&(t.atomic=!t.usePolling&&!t.useFsEvents),t.atomic&&(this._pendingUnlinks=new Map),rt(t,"followSymlinks")&&(t.followSymlinks=!0),rt(t,"awaitWriteFinish")&&(t.awaitWriteFinish=!1),t.awaitWriteFinish===!0&&(t.awaitWriteFinish={});let o=t.awaitWriteFinish;o&&(o.stabilityThreshold||(o.stabilityThreshold=2e3),o.pollInterval||(o.pollInterval=100),this._pendingWrites=new Map),t.ignored&&(t.ignored=ia(t.ignored));let a=0;this._emitReady=()=>{a++,a>=this._readyCount&&(this._emitReady=Ax,this._readyEmitted=!0,process.nextTick(()=>this.emit(ux)))},this._emitRaw=(...l)=>this.emit(px,...l),this._readyEmitted=!1,this.options=t,t.useFsEvents?this._fsEventsHandler=new Mf(this):this._nodeFsHandler=new cx(this),Object.freeze(t)}add(e,t,s){let{cwd:r,disableGlobbing:i}=this.options;this.closed=!1;let o=Lf(e);return r&&(o=o.map(a=>{let l=Px(a,r);return i||!Jo(a)?l:lx(l)})),o=o.filter(a=>a.startsWith(na)?(this._ignoredPaths.add(a.slice(1)),!1):(this._ignoredPaths.delete(a),this._ignoredPaths.delete(a+ea),this._userIgnored=void 0,!0)),this.options.useFsEvents&&this._fsEventsHandler?(this._readyCount||(this._readyCount=o.length),this.options.persistent&&(this._readyCount+=o.length),o.forEach(a=>this._fsEventsHandler._addToFsEvents(a))):(this._readyCount||(this._readyCount=0),this._readyCount+=o.length,Promise.all(o.map(async a=>{let l=await this._nodeFsHandler._addToNodeFs(a,!s,0,0,t);return l&&this._emitReady(),l})).then(a=>{this.closed||a.filter(l=>l).forEach(l=>{this.add(oe.dirname(l),oe.basename(t||l))})})),this}unwatch(e){if(this.closed)return this;let t=Lf(e),{cwd:s}=this.options;return t.forEach(r=>{!oe.isAbsolute(r)&&!this._closers.has(r)&&(s&&(r=oe.join(s,r)),r=oe.resolve(r)),this._closePath(r),this._ignoredPaths.add(r),this._watched.has(r)&&this._ignoredPaths.add(r+ea),this._userIgnored=void 0}),this}close(){if(this.closed)return this._closePromise;this.closed=!0,this.removeAllListeners();let e=[];return this._closers.forEach(t=>t.forEach(s=>{let r=s();r instanceof Promise&&e.push(r)})),this._streams.forEach(t=>t.destroy()),this._userIgnored=void 0,this._readyCount=0,this._readyEmitted=!1,this._watched.forEach(t=>t.dispose()),["closers","watched","streams","symlinkPaths","throttled"].forEach(t=>{this[`_${t}`].clear()}),this._closePromise=e.length?Promise.all(e).then(()=>{}):Promise.resolve(),this._closePromise}getWatched(){let e={};return this._watched.forEach((t,s)=>{let r=this.options.cwd?oe.relative(this.options.cwd,s):s;e[r||Hf]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(...t),e!==Qo&&this.emit(Xo,...t)}async _emit(e,t,s,r,i){if(this.closed)return;let o=this.options;$x&&(t=oe.normalize(t)),o.cwd&&(t=oe.relative(o.cwd,t));let a=[e,t];i!==void 0?a.push(s,r,i):r!==void 0?a.push(s,r):s!==void 0&&a.push(s);let l=o.awaitWriteFinish,u;if(l&&(u=this._pendingWrites.get(t)))return u.lastChange=new Date,this;if(o.atomic){if(e===If)return this._pendingUnlinks.set(t,a),setTimeout(()=>{this._pendingUnlinks.forEach((d,f)=>{this.emit(...d),this.emit(Xo,...d),this._pendingUnlinks.delete(f)})},typeof o.atomic=="number"?o.atomic:100),this;e===ur&&this._pendingUnlinks.has(t)&&(e=a[0]=as,this._pendingUnlinks.delete(t))}if(l&&(e===ur||e===as)&&this._readyEmitted){let d=(f,h)=>{f?(e=a[0]=Qo,a[1]=f,this.emitWithAll(e,a)):h&&(a.length>2?a[2]=h:a.push(h),this.emitWithAll(e,a))};return this._awaitWriteFinish(t,l.stabilityThreshold,e,d),this}if(e===as&&!this._throttle(as,t,50))return this;if(o.alwaysStat&&s===void 0&&(e===ur||e===dx||e===as)){let d=o.cwd?oe.join(o.cwd,t):t,f;try{f=await Ex(d)}catch{}if(!f||this.closed)return;a.push(f)}return this.emitWithAll(e,a),this}_handleError(e){let t=e&&e.code;return e&&t!=="ENOENT"&&t!=="ENOTDIR"&&(!this.options.ignorePermissionErrors||t!=="EPERM"&&t!=="EACCES")&&this.emit(Qo,e),e||this.closed}_throttle(e,t,s){this._throttled.has(e)||this._throttled.set(e,new Map);let r=this._throttled.get(e),i=r.get(t);if(i)return i.count++,!1;let o,a=()=>{let u=r.get(t),d=u?u.count:0;return r.delete(t),clearTimeout(o),u&&clearTimeout(u.timeoutObject),d};o=setTimeout(a,s);let l={timeoutObject:o,clear:a,count:0};return r.set(t,l),l}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(e,t,s,r){let i,o=e;this.options.cwd&&!oe.isAbsolute(e)&&(o=oe.join(this.options.cwd,e));let a=new Date,l=u=>{la.stat(o,(d,f)=>{if(d||!this._pendingWrites.has(e)){d&&d.code!=="ENOENT"&&r(d);return}let h=Number(new Date);u&&f.size!==u.size&&(this._pendingWrites.get(e).lastChange=h);let m=this._pendingWrites.get(e);h-m.lastChange>=t?(this._pendingWrites.delete(e),r(void 0,f)):i=setTimeout(l,this.options.awaitWriteFinish.pollInterval,f)})};this._pendingWrites.has(e)||(this._pendingWrites.set(e,{lastChange:a,cancelWait:()=>(this._pendingWrites.delete(e),clearTimeout(i),s)}),i=setTimeout(l,this.options.awaitWriteFinish.pollInterval))}_getGlobIgnored(){return[...this._ignoredPaths.values()]}_isIgnored(e,t){if(this.options.atomic&&bx.test(e))return!0;if(!this._userIgnored){let{cwd:s}=this.options,r=this.options.ignored,i=r&&r.map(Nf(s)),o=ia(i).filter(l=>typeof l===ca&&!Jo(l)).map(l=>l+ea),a=this._getGlobIgnored().map(Nf(s)).concat(i,o);this._userIgnored=ta(a,void 0,sa)}return this._userIgnored([e,t])}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e,t){let s=t||this.options.disableGlobbing||!Jo(e)?e:ox(e),r=this.options.followSymlinks;return new aa(e,s,r,this)}_getWatchedDir(e){this._boundRemove||(this._boundRemove=this._remove.bind(this));let t=oe.resolve(e);return this._watched.has(t)||this._watched.set(t,new oa(t,this._boundRemove)),this._watched.get(t)}_hasReadPermissions(e){if(this.options.ignorePermissionErrors)return!0;let s=(e&&Number.parseInt(e.mode,10))&511;return!!(4&Number.parseInt(s.toString(8)[0],10))}_remove(e,t,s){let r=oe.join(e,t),i=oe.resolve(r);if(s=s??(this._watched.has(r)||this._watched.has(i)),!this._throttle("remove",r,100))return;!s&&!this.options.useFsEvents&&this._watched.size===1&&this.add(e,t,!0),this._getWatchedDir(r).getChildren().forEach(h=>this._remove(r,h));let l=this._getWatchedDir(e),u=l.has(t);l.remove(t),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let d=r;if(this.options.cwd&&(d=oe.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(d)&&this._pendingWrites.get(d).cancelWait()===ur)return;this._watched.delete(r),this._watched.delete(i);let f=s?fx:If;u&&!this._isIgnored(r)&&this._emit(f,r),this.options.useFsEvents||this._closePath(r)}_closePath(e){this._closeFile(e);let t=oe.dirname(e);this._getWatchedDir(t).remove(oe.basename(e))}_closeFile(e){let t=this._closers.get(e);t&&(t.forEach(s=>s()),this._closers.delete(e))}_addPathCloser(e,t){if(!t)return;let s=this._closers.get(e);s||(s=[],this._closers.set(e,s)),s.push(t)}_readdirp(e,t){if(this.closed)return;let s={type:Xo,alwaysStat:!0,lstat:!0,...t},r=ix(e,s);return this._streams.add(r),r.once(hx,()=>{r=void 0}),r.once(mx,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};ua.FSWatcher=dr;var Ix=(n,e)=>{let t=new dr(e);return t.add(n),t};ua.watch=Ix});var Vf={};Fe(Vf,{CollaborationManager:()=>ls,addTeamMember:()=>Fx,formatTeamConfig:()=>Nx,initTeamConfig:()=>Lx,loadTeamConfig:()=>Dx,saveTeamConfig:()=>Gf});function Dx(n){let e=Ye.join(n,".hablas","team.json");if(ve.existsSync(e))try{return JSON.parse(ve.readFileSync(e,"utf-8"))}catch{return null}return null}function Lx(n,e){let t={name:e,members:[]};return Gf(n,t),t}function Gf(n,e){let t=Ye.join(n,".hablas","team.json"),s=Ye.dirname(t);ve.existsSync(s)||ve.mkdirSync(s,{recursive:!0}),ve.writeFileSync(t,JSON.stringify(e,null,2),"utf-8")}function Fx(n,e,t){return n.members.push({name:e,email:t}),n}function Nx(n){return[`Team: ${n.name}`,"Members:",...n.members.map(t=>` - ${t.name} (${t.email})`)].join(`
|
|
298
|
+
`)}var ve,Ye,fr,Kf,Wf,ls,da=L(()=>{"use strict";ve=O(require("fs")),Ye=O(require("path")),fr=O(require("os")),Kf=O(require("crypto")),Wf=O(qf());xn();ls=class n{workingDir;config;username;teamKey;projectTeamToken;supabaseUrl="";supabaseKey="";isConfigured=!1;watcher=null;localStatePath;heartbeatInterval=null;syncInterval=null;static HEARTBEAT_MS=12e3;static POLL_ACTIVE_MS=3e3;static POLL_IDLE_MS=2e4;static STALE_MS=75e3;consecutiveHeartbeatFailures=0;announcedOffline=!1;idlePollTicks=0;signalHandler=null;shuttingDown=!1;currentActivity={section:"idle",task:"standby"};knownSessions=new Map;knownLocks=new Map;constructor(e,t,s,r){this.workingDir=e,this.config=t,this.username=s||fr.userInfo().username||"developer",this.teamKey=r||"default-team",this.localStatePath=Ye.join(this.workingDir,".hablas","collaboration.json");let i=this.getProjectIdentifier();console.log(`
|
|
299
299
|
${c.muted("[Debug] Project Context:")} ${c.highlight(i)}`),this.projectTeamToken=Kf.createHash("sha256").update(`${i}:${this.teamKey}`).digest("hex"),console.log(` ${c.muted("[Debug] Session Fingerprint:")} ${c.muted(this.projectTeamToken.slice(0,16))}...
|
|
300
|
-
`),this.loadSupabaseConfig()}async init(){if(!this.isConfigured)return console.log(` ${c.warning("\u26A0")} ${c.secondary("Supabase is not configured in .env. Collaboration mode operates locally.")}`),!1;let e=Ye.dirname(this.localStatePath);return
|
|
300
|
+
`),this.loadSupabaseConfig()}async init(){if(!this.isConfigured)return console.log(` ${c.warning("\u26A0")} ${c.secondary("Supabase is not configured in .env. Collaboration mode operates locally.")}`),!1;let e=Ye.dirname(this.localStatePath);return ve.existsSync(e)||ve.mkdirSync(e,{recursive:!0}),this.saveLocalState([],[]),this.startLoops(),this.startWatcher(),this.registerCleanups(),!0}async shutdown(){this.shuttingDown||(this.shuttingDown=!0,this.heartbeatInterval&&(clearInterval(this.heartbeatInterval),this.heartbeatInterval=null),this.syncInterval&&(clearTimeout(this.syncInterval),this.syncInterval=null),this.watcher&&(await this.watcher.close(),this.watcher=null),this.signalHandler&&(process.off("SIGINT",this.signalHandler),process.off("SIGTERM",this.signalHandler),this.signalHandler=null),await this.releaseAllMyLocks(),await this.deleteSession())}async apiRequest(e,t,s,r){if(!this.isConfigured)return{ok:!1,data:null};let i=`${this.supabaseUrl}/rest/v1/${e}`,o={apikey:this.supabaseKey,Authorization:`Bearer ${this.supabaseKey}`,"Content-Type":"application/json"};r?.prefer?o.Prefer=r.prefer:(t==="POST"||t==="PATCH")&&(o.Prefer="return=representation");let a=(r?.retries??0)+1,l=null;for(let u=0;u<a;u++)try{let d=await fetch(i,{method:t,headers:o,body:s?JSON.stringify(s):void 0,signal:AbortSignal.timeout(1e4)});if(!d.ok){let h=await d.text().catch(()=>"");if(l=new Error(`[Supabase ${d.status}] ${h}`),(d.status>=500||d.status===429)&&u<a-1){await this.delay(400*(u+1));continue}return{ok:!1,data:null}}let f=await d.text();return{ok:!0,data:f?JSON.parse(f):null}}catch(d){if(l=d,u<a-1){await this.delay(400*(u+1));continue}}return{ok:!1,data:null}}delay(e){return new Promise(t=>setTimeout(t,e))}async sendHeartbeat(e,t){let s={project_team_token:this.projectTeamToken,developer_name:this.username,last_heartbeat:new Date().toISOString(),active_section:e||"idle",current_task:t||"none"},r="hablas_team_sessions?on_conflict=project_team_token,developer_name",{ok:i}=await this.apiRequest(r,"POST",s,{prefer:"resolution=merge-duplicates,return=minimal",retries:2});return i}async fetchSessions(){let e=`hablas_team_sessions?project_team_token=eq.${this.projectTeamToken}`,{data:t}=await this.apiRequest(e,"GET");return t||[]}async deleteSession(){let e=`hablas_team_sessions?project_team_token=eq.${this.projectTeamToken}&developer_name=eq.${encodeURIComponent(this.username)}`;await this.apiRequest(e,"DELETE")}async fetchLocks(){let e=`hablas_team_locks?project_team_token=eq.${this.projectTeamToken}`,{data:t}=await this.apiRequest(e,"GET");return t||[]}async acquireLock(e,t){let s={project_team_token:this.projectTeamToken,file_path:e,locked_by:this.username,lock_context:t||"editing file",created_at:new Date().toISOString()};return await this.apiRequest("hablas_team_locks?on_conflict=project_team_token,file_path","POST",s,{prefer:"resolution=ignore-duplicates,return=minimal",retries:1}),!!(await this.fetchLocks()).find(a=>a.file_path===e&&a.locked_by===this.username)}async releaseLock(e){let t=`hablas_team_locks?project_team_token=eq.${this.projectTeamToken}&file_path=eq.${encodeURIComponent(e)}&locked_by=eq.${encodeURIComponent(this.username)}`;return await this.apiRequest(t,"DELETE"),!0}async releaseAllMyLocks(){let e=`hablas_team_locks?project_team_token=eq.${this.projectTeamToken}&locked_by=eq.${encodeURIComponent(this.username)}`;await this.apiRequest(e,"DELETE")}async sendMessage(e,t){let s={project_team_token:this.projectTeamToken,sender_name:this.username,receiver_name:e,message_content:t,is_read:!1,created_at:new Date().toISOString()},{ok:r}=await this.apiRequest("hablas_team_messages","POST",s,{retries:1});return r}async fetchUnreadMessages(){let e=`hablas_team_messages?project_team_token=eq.${this.projectTeamToken}&receiver_name=eq.${encodeURIComponent(this.username)}&is_read=eq.false`,t=(await this.apiRequest(e,"GET")).data||[];if(t.length>0)for(let s of t){let r=`hablas_team_messages?id=eq.${s.id}`;await this.apiRequest(r,"PATCH",{is_read:!0})}return t}saveLocalState(e,t){let s={project_team_token:this.projectTeamToken,last_sync:new Date().toISOString(),my_username:this.username,sessions:e,locks:t};ve.writeFileSync(this.localStatePath,JSON.stringify(s,null,2),"utf-8")}getLocalState(){if(ve.existsSync(this.localStatePath))try{return JSON.parse(ve.readFileSync(this.localStatePath,"utf-8"))}catch{}return{sessions:[],locks:[],my_username:this.username}}startLoops(){this.beat("idle","standby"),this.heartbeatInterval=setInterval(()=>{this.beat()},n.HEARTBEAT_MS);let e=t=>{this.syncInterval=setTimeout(async()=>{if(this.shuttingDown)return;await this.syncWithCloud()?this.idlePollTicks=0:this.idlePollTicks++;let r=this.idlePollTicks>=3?n.POLL_IDLE_MS:n.POLL_ACTIVE_MS;e(r)},t)};e(n.POLL_ACTIVE_MS)}setActivity(e,t="working"){this.currentActivity={section:t,task:e.slice(0,120)},this.beat(t,this.currentActivity.task)}async beat(e,t){await this.sendHeartbeat(e??this.currentActivity.section,t??this.currentActivity.task)?(this.announcedOffline&&(console.log(`
|
|
301
301
|
${c.success("\u2713")} ${c.muted("[Team]")} Cloud sync reconnected \u2014 session restored.
|
|
302
302
|
`),this.announcedOffline=!1),this.consecutiveHeartbeatFailures=0):(this.consecutiveHeartbeatFailures++,this.consecutiveHeartbeatFailures>=4&&!this.announcedOffline&&(console.log(`
|
|
303
303
|
${c.warning("\u26A0")} ${c.muted("[Team]")} Cloud sync is unreachable \u2014 retrying in the background. Your session is preserved.
|
|
@@ -308,17 +308,17 @@ If you cannot complete a task, explain why with absolute technical objectivity.`
|
|
|
308
308
|
${c.warning("\u{1F44B}")} ${c.muted("[Live Sync]")} ${c.strong(`@${i}`)} has left the session.
|
|
309
309
|
`));let r=new Set;for(let i of t)r.add(i.file_path),this.knownLocks.has(i.file_path)||(this.knownLocks.set(i.file_path,i.locked_by),i.locked_by!==this.username&&console.log(` ${c.error("\u{1F512}")} ${c.muted("[File Locked]")} ${c.strong(`@${i.locked_by}`)} locked ${c.highlight(i.file_path)}`));for(let i of this.knownLocks.keys())if(!r.has(i)){let o=this.knownLocks.get(i);this.knownLocks.delete(i),o!==this.username&&console.log(` ${c.success("\u{1F513}")} ${c.muted("[File Unlocked]")} ${c.strong(`@${o}`)} released lock on ${c.highlight(i)}`)}}renderMessageBox(e,t){let s=Math.min(process.stdout.columns-4,80),r=c.border("\u250C"+"\u2500".repeat(s-2)+"\u2510"),i=c.border("\u2514"+"\u2500".repeat(s-2)+"\u2518"),o=` MESSAGE FROM @${e.toUpperCase()} `,a=Math.max(0,Math.floor((s-2-o.length)/2)),l=c.border("\u2502")+" ".repeat(a)+c.strong(o)+" ".repeat(s-2-o.length-a)+c.border("\u2502"),u=t.replace(/\n/g," "),d=Math.max(0,s-8-u.length),f=c.border("\u2502")+` "${c.secondary(u)}"`+" ".repeat(d)+c.border("\u2502");console.log(`
|
|
310
310
|
`+r),console.log(l),console.log(f),console.log(i+`
|
|
311
|
-
`)}registerCleanups(){this.signalHandler||(this.signalHandler=()=>{this.shutdown()},process.on("SIGTERM",this.signalHandler),process.once("beforeExit",this.signalHandler))}loadSupabaseConfig(){let e=Ye.join(this.workingDir,".env");if(
|
|
312
|
-
`);for(let r of s){let i=r.split("=");if(i.length>=2){let o=i[0].trim(),a=i.slice(1).join("=").trim().replace(/^['"]|['"]$/g,"");o==="SUPABASE_URL"||o==="VITE_SUPABASE_URL"?this.supabaseUrl=a:(o==="SUPABASE_KEY"||o==="SUPABASE_ANON_KEY"||o==="VITE_SUPABASE_ANON_KEY")&&(this.supabaseKey=a)}}}catch{}if(!this.supabaseUrl||!this.supabaseKey){let t="aHR0cHM6Ly93dXVtYXptcGp6dHZ4a3l3Y3Rvci5zdXBhYmFzZS5jbw==",s="c2JfcHVibGlzaGFibGVfVmxmNEtCUzdsaTRjaGFWNE04d19xQV9fbnJuczh1WQ==";this.supabaseUrl=Buffer.from(t,"base64").toString("utf-8"),this.supabaseKey=Buffer.from(s,"base64").toString("utf-8")}this.isConfigured=!!(this.supabaseUrl&&this.supabaseKey),this.isConfigured&&this.syncLlmConfig()}syncLlmConfig(){let e=Ye.join(fr.homedir(),".hablas","config.json");if(
|
|
313
|
-
`),_=w.length,k=m.start_line?Math.max(1,m.start_line):1
|
|
314
|
-
... [File has ${_} total lines. Use start_line/end_line to read more.]`:"";return{success:!0,output:`${
|
|
311
|
+
`)}registerCleanups(){this.signalHandler||(this.signalHandler=()=>{this.shutdown()},process.on("SIGTERM",this.signalHandler),process.once("beforeExit",this.signalHandler))}loadSupabaseConfig(){let e=Ye.join(this.workingDir,".env");if(ve.existsSync(e))try{let s=ve.readFileSync(e,"utf-8").split(`
|
|
312
|
+
`);for(let r of s){let i=r.split("=");if(i.length>=2){let o=i[0].trim(),a=i.slice(1).join("=").trim().replace(/^['"]|['"]$/g,"");o==="SUPABASE_URL"||o==="VITE_SUPABASE_URL"?this.supabaseUrl=a:(o==="SUPABASE_KEY"||o==="SUPABASE_ANON_KEY"||o==="VITE_SUPABASE_ANON_KEY")&&(this.supabaseKey=a)}}}catch{}if(!this.supabaseUrl||!this.supabaseKey){let t="aHR0cHM6Ly93dXVtYXptcGp6dHZ4a3l3Y3Rvci5zdXBhYmFzZS5jbw==",s="c2JfcHVibGlzaGFibGVfVmxmNEtCUzdsaTRjaGFWNE04d19xQV9fbnJuczh1WQ==";this.supabaseUrl=Buffer.from(t,"base64").toString("utf-8"),this.supabaseKey=Buffer.from(s,"base64").toString("utf-8")}this.isConfigured=!!(this.supabaseUrl&&this.supabaseKey),this.isConfigured&&this.syncLlmConfig()}syncLlmConfig(){let e=Ye.join(fr.homedir(),".hablas","config.json");if(ve.existsSync(e))try{let t=JSON.parse(ve.readFileSync(e,"utf-8"));!this.config.apiUrl&&t.apiUrl&&(this.config.apiUrl=t.apiUrl,this.config.apiKey=t.apiKey,this.config.provider=t.provider)}catch{}}getProjectIdentifier(){let e="";try{let{execSync:t}=require("child_process"),s=t("git config --get remote.origin.url",{cwd:this.workingDir,encoding:"utf-8",stdio:["ignore","pipe","ignore"]}).trim();if(s){let r=s.match(/[:/]([^/]+\/[^/.]+)(\.git)?$/);r&&r[1]&&(e=r[1].toLowerCase())}}catch{}if(!e)try{let t=Ye.join(this.workingDir,"package.json");if(ve.existsSync(t)){let s=JSON.parse(ve.readFileSync(t,"utf-8"));s.name&&(e=s.name.toLowerCase())}}catch{}return e||(e=Ye.basename(this.workingDir).toLowerCase()),e.replace(/\s+/g,"")}}});async function sn(n){try{if(!fa.existsSync(n))return;fa.existsSync(cs)||await ht.mkdir(cs,{recursive:!0});let e=await ht.readFile(n,"utf-8"),t=Cn.basename(n),s=Date.now(),r=`${t}.${s}.bak`,i=Cn.join(cs,r);await ht.writeFile(i,e,"utf-8");let a=(await ht.readdir(cs)).filter(l=>l.startsWith(`${t}.`)&&l.endsWith(".bak")).sort().reverse();if(a.length>zf)for(let l of a.slice(zf))await ht.unlink(Cn.join(cs,l))}catch{}}var ht,fa,Cn,Yf,cs,zf,Jf=L(()=>{"use strict";ht=O(require("fs/promises")),fa=O(require("fs")),Cn=O(require("path")),Yf=O(require("os")),cs=Cn.join(Yf.homedir(),".hablas","backup"),zf=10});function Zf(n){let e=m=>jt.resolve(n,m);return[{name:"read_file",description:"Read the content of a file with line numbers. Returns up to 300 lines. Use start_line/end_line for large files.",safety:"safe",parameters:{path:{type:"string",description:"File path to read",required:!0},start_line:{type:"number",description:"Starting line number (1-based, optional)",required:!1},end_line:{type:"number",description:"Ending line number (inclusive, optional)",required:!1}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[read_file]: path is required"};let p=e(m.path),w=(await de.readFile(p,"utf-8")).split(`
|
|
313
|
+
`),_=w.length,k=m.start_line?Math.max(1,m.start_line):1,$=m.end_line?Math.min(_,m.end_line):Math.min(_,k+Xf-1),y=Math.min($,k+Xf-1),v=w.slice(k-1,y),b=String(y).length,x=v.map((M,C)=>`${String(k+C).padStart(b," ")} | ${M}`),A=`[${m.path} \u2014 lines ${k}-${y} of ${_}]`,E=y<_?`
|
|
314
|
+
... [File has ${_} total lines. Use start_line/end_line to read more.]`:"";return{success:!0,output:`${A}
|
|
315
315
|
${x.join(`
|
|
316
|
-
`)}${E}`}}catch(p){return{success:!1,output:"",error:`[read_file]: ${p.message}`}}}},{name:"write_file",description:"Create or overwrite a file with content",safety:"confirm",parameters:{path:{type:"string",description:"File path to write",required:!0},content:{type:"string",description:"Content to write",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[write_file]: path is required"};if(m.content===void 0)return{success:!1,output:"",error:"[write_file]: content is required"};let p=e(m.path);return pa.existsSync(p)&&await sn(p),await de.mkdir(jt.dirname(p),{recursive:!0}),await de.writeFile(p,m.content,"utf-8"),{success:!0,output:`Written: ${m.path}`}}catch(p){return{success:!1,output:"",error:`[write_file]: ${p.message}`}}}},{name:"edit_file",description:"Apply a surgical edit by replacing old content with new content. Must match exactly one location.",safety:"confirm",parameters:{path:{type:"string",description:"File path to edit",required:!0},old_content:{type:"string",description:"Exact content to replace (must be unique in the file)",required:!0},new_content:{type:"string",description:"New content to insert",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[edit_file]: path is required"};if(!m.old_content)return{success:!1,output:"",error:"[edit_file]: old_content is required"};let p=e(m.path),g=await de.readFile(p,"utf-8"),w=m.old_content,_=m.new_content,k=Qf(g,w);if(k===0)return{success:!1,output:"",error:"[edit_file]: Old content not found in file"};if(k>1)return{success:!1,output:"",error:`[edit_file]: old_content matches ${k} locations in the file. Provide more surrounding context to be specific.`};await sn(p);let
|
|
316
|
+
`)}${E}`}}catch(p){return{success:!1,output:"",error:`[read_file]: ${p.message}`}}}},{name:"write_file",description:"Create or overwrite a file with content",safety:"confirm",parameters:{path:{type:"string",description:"File path to write",required:!0},content:{type:"string",description:"Content to write",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[write_file]: path is required"};if(m.content===void 0)return{success:!1,output:"",error:"[write_file]: content is required"};let p=e(m.path);return pa.existsSync(p)&&await sn(p),await de.mkdir(jt.dirname(p),{recursive:!0}),await de.writeFile(p,m.content,"utf-8"),{success:!0,output:`Written: ${m.path}`}}catch(p){return{success:!1,output:"",error:`[write_file]: ${p.message}`}}}},{name:"edit_file",description:"Apply a surgical edit by replacing old content with new content. Must match exactly one location.",safety:"confirm",parameters:{path:{type:"string",description:"File path to edit",required:!0},old_content:{type:"string",description:"Exact content to replace (must be unique in the file)",required:!0},new_content:{type:"string",description:"New content to insert",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[edit_file]: path is required"};if(!m.old_content)return{success:!1,output:"",error:"[edit_file]: old_content is required"};let p=e(m.path),g=await de.readFile(p,"utf-8"),w=m.old_content,_=m.new_content,k=Qf(g,w);if(k===0)return{success:!1,output:"",error:"[edit_file]: Old content not found in file"};if(k>1)return{success:!1,output:"",error:`[edit_file]: old_content matches ${k} locations in the file. Provide more surrounding context to be specific.`};await sn(p);let $=g.replace(w,_);await de.writeFile(p,$,"utf-8");let y=Gs(m.path,g,$);return{success:!0,output:`Edited: ${m.path}
|
|
317
317
|
${y}`}}catch(p){return{success:!1,output:"",error:`[edit_file]: ${p.message}`}}}},{name:"patch_file",description:"Replace lines in a file using line numbers. More reliable than edit_file. Use read_file first to see line numbers.",safety:"confirm",parameters:{path:{type:"string",description:"File path",required:!0},start_line:{type:"number",description:"First line to replace (1-indexed)",required:!0},end_line:{type:"number",description:"Last line to replace (inclusive)",required:!0},new_content:{type:"string",description:"New content to insert in place of those lines",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[patch_file]: path is required"};if(!m.start_line)return{success:!1,output:"",error:"[patch_file]: start_line is required"};if(!m.end_line)return{success:!1,output:"",error:"[patch_file]: end_line is required"};if(m.new_content===void 0)return{success:!1,output:"",error:"[patch_file]: new_content is required"};let p=e(m.path),g=await de.readFile(p,"utf-8"),w=g.split(`
|
|
318
|
-
`),_=w.length,k=m.start_line
|
|
318
|
+
`),_=w.length,k=m.start_line,$=m.end_line;if(k<1||k>_)return{success:!1,output:"",error:`[patch_file]: start_line ${k} is out of range (file has ${_} lines)`};if($<k||$>_)return{success:!1,output:"",error:`[patch_file]: end_line ${$} is out of range (start_line=${k}, total=${_})`};await sn(p);let y=w.slice(0,k-1),v=w.slice($),b=m.new_content.split(`
|
|
319
319
|
`),x=[...y,...b,...v].join(`
|
|
320
|
-
`);await de.writeFile(p,x,"utf-8");let
|
|
321
|
-
${
|
|
320
|
+
`);await de.writeFile(p,x,"utf-8");let A=Gs(m.path,g,x),E=$-k+1,M=b.length;return{success:!0,output:`Patched: ${m.path} (replaced ${E} lines with ${M})
|
|
321
|
+
${A}`}}catch(p){return{success:!1,output:"",error:`[patch_file]: ${p.message}`}}}},{name:"search_and_replace",description:"Find and replace all occurrences of a pattern in a file. Supports regex. Returns count of replacements made.",safety:"confirm",parameters:{path:{type:"string",description:"File path",required:!0},search:{type:"string",description:"Search pattern (string or regex)",required:!0},replace:{type:"string",description:"Replacement string",required:!0},is_regex:{type:"boolean",description:"Treat search as regex (default: false)",required:!1}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[search_and_replace]: path is required"};if(!m.search)return{success:!1,output:"",error:"[search_and_replace]: search is required"};if(m.replace===void 0)return{success:!1,output:"",error:"[search_and_replace]: replace is required"};let p=e(m.path),g=await de.readFile(p,"utf-8"),w=m.search,_=m.replace,k=m.is_regex;await sn(p);let $,y;if(k){let v=new RegExp(w,"g");y=(g.match(v)||[]).length,$=g.replace(v,_)}else y=Qf(g,w),$=g.split(w).join(_);return y===0?{success:!1,output:"",error:"[search_and_replace]: Pattern not found in file"}:(await de.writeFile(p,$,"utf-8"),{success:!0,output:`Replaced ${y} occurrence(s) in ${m.path}`})}catch(p){return{success:!1,output:"",error:`[search_and_replace]: ${p.message}`}}}},{name:"append_to_file",description:"Append content to the end of a file. Creates the file if it does not exist.",safety:"confirm",parameters:{path:{type:"string",description:"File path",required:!0},content:{type:"string",description:"Content to append",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[append_to_file]: path is required"};if(m.content===void 0)return{success:!1,output:"",error:"[append_to_file]: content is required"};let p=e(m.path);return await de.mkdir(jt.dirname(p),{recursive:!0}),pa.existsSync(p)&&await sn(p),await de.appendFile(p,m.content,"utf-8"),{success:!0,output:`Appended to: ${m.path}`}}catch(p){return{success:!1,output:"",error:`[append_to_file]: ${p.message}`}}}},{name:"delete_file",description:"Delete a file",safety:"dangerous",parameters:{path:{type:"string",description:"File path to delete",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[delete_file]: path is required"};let p=e(m.path);return await sn(p),await de.unlink(p),{success:!0,output:`Deleted: ${m.path}`}}catch(p){return{success:!1,output:"",error:`[delete_file]: ${p.message}`}}}},{name:"move_file",description:"Move or rename a file",safety:"confirm",parameters:{from:{type:"string",description:"Source path",required:!0},to:{type:"string",description:"Destination path",required:!0}},execute:async m=>{try{if(!m.from)return{success:!1,output:"",error:"[move_file]: from is required"};if(!m.to)return{success:!1,output:"",error:"[move_file]: to is required"};let p=e(m.from),g=e(m.to);return await de.mkdir(jt.dirname(g),{recursive:!0}),await de.rename(p,g),{success:!0,output:`Moved: ${m.from} \u2192 ${m.to}`}}catch(p){return{success:!1,output:"",error:`[move_file]: ${p.message}`}}}},{name:"create_dir",description:"Create a directory",safety:"safe",parameters:{path:{type:"string",description:"Directory path to create",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[create_dir]: path is required"};let p=e(m.path);return await de.mkdir(p,{recursive:!0}),{success:!0,output:`Created directory: ${m.path}`}}catch(p){return{success:!1,output:"",error:`[create_dir]: ${p.message}`}}}},{name:"list_dir",description:"List directory contents as a tree",safety:"safe",parameters:{path:{type:"string",description:"Directory path (default: .)",required:!1},depth:{type:"number",description:"Max depth (default: 3)",required:!1}},execute:async m=>{try{let p=e(m.path||"."),g=m.depth||3;return{success:!0,output:await ep(p,"",g,0)||"(empty directory)"}}catch(p){return{success:!1,output:"",error:`[list_dir]: ${p.message}`}}}},{name:"get_file_info",description:"Get file stats: size, last modified, type",safety:"safe",parameters:{path:{type:"string",description:"File path",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[get_file_info]: path is required"};let p=e(m.path),g=await de.stat(p);return{success:!0,output:[`Path: ${m.path}`,`Size: ${Hx(g.size)}`,`Type: ${g.isDirectory()?"directory":"file"}`,`Modified: ${g.mtime.toISOString()}`,`Created: ${g.birthtime.toISOString()}`].join(`
|
|
322
322
|
`)}}catch(p){return{success:!1,output:"",error:`[get_file_info]: ${p.message}`}}}}]}function Qf(n,e){let t=0,s=0;for(;;){let r=n.indexOf(e,s);if(r===-1)break;t++,s=r+e.length}return t}async function ep(n,e,t,s){if(s>=t)return"";let i=(await de.readdir(n,{withFileTypes:!0})).filter(a=>!jx.has(a.name)&&!a.name.startsWith(".")).sort((a,l)=>a.isDirectory()&&!l.isDirectory()?-1:!a.isDirectory()&&l.isDirectory()?1:a.name.localeCompare(l.name)),o="";for(let a=0;a<i.length;a++){let l=i[a],u=a===i.length-1,d=u?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ",f=l.isDirectory()?"\u{1F4C1}":"\u{1F4C4}";if(o+=`${e}${d}${f} ${l.name}
|
|
323
323
|
`,l.isDirectory()){let h=e+(u?" ":"\u2502 ");o+=await ep(jt.join(n,l.name),h,t,s+1)}}return o}function Hx(n){return n<1024?`${n} B`:n<1024*1024?`${(n/1024).toFixed(1)} KB`:`${(n/(1024*1024)).toFixed(1)} MB`}var de,pa,jt,Xf,jx,tp=L(()=>{"use strict";de=O(require("fs/promises")),pa=O(require("fs")),jt=O(require("path"));co();Jf();Xf=300;jx=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next"])});var np,pr,sp=L(()=>{"use strict";np=require("child_process"),pr=class{processes=new Map;config;nextId=1;constructor(e){this.config={workingDir:e.workingDir,defaultTimeout:e.defaultTimeout||3e5,maxOutputSize:e.maxOutputSize||5e5}}start(e,t){let s=`bg_${this.nextId++}`,r=t?.timeout||this.config.defaultTimeout,i=(0,np.spawn)(e,{shell:!0,cwd:this.config.workingDir,env:{...process.env,...t?.env}}),o={id:s,command:e,process:i,stdout:"",stderr:"",startTime:Date.now(),pid:i.pid,status:"running"};return i.stdout?.on("data",a=>{o.stdout+=a.toString(),o.stdout.length>this.config.maxOutputSize&&(o.stdout=o.stdout.slice(-this.config.maxOutputSize))}),i.stderr?.on("data",a=>{o.stderr+=a.toString(),o.stderr.length>this.config.maxOutputSize&&(o.stderr=o.stderr.slice(-this.config.maxOutputSize))}),i.on("exit",a=>{o.status="finished",o.exitCode=a??void 0}),i.on("error",a=>{o.status="finished",o.stderr+=`
|
|
324
324
|
Error: ${a.message}`}),r>0&&setTimeout(()=>{o.status==="running"&&(this.kill(s),o.status="timeout",o.stderr+=`
|
|
@@ -381,7 +381,7 @@ ${u.content}`),a+=u.tokenCount}return l.join(`
|
|
|
381
381
|
|
|
382
382
|
`)}getTotalTokens(){return this.usedTokens}getCacheSize(){return this.cache.size}getCacheInfo(){return Array.from(this.cache.values()).map(e=>({path:e.path,tokens:e.tokenCount,importance:e.importance,accesses:e.accessCount})).sort((e,t)=>t.importance-e.importance)}evictToFit(e){let t=Array.from(this.cache.entries()).map(([r,i])=>({key:r,...i,score:this.computeScore(i)})).sort((r,i)=>r.score-i.score),s=0;for(let r of t){if(s>=e)break;r.importance>=9||(s+=r.tokenCount,this.usedTokens-=r.tokenCount,this.cache.delete(r.key))}}evict(e){this.evictToFit(e)}clear(){this.cache.clear(),this.usedTokens=0,this.accessHistory=[]}computeScore(e){let r=(Date.now()-e.lastUsed)/6e4,i=Math.exp(-r/30),o=Math.log1p(e.accessCount);return e.importance*(i+o)}autoImportance(e,t){let s=5;/\b(config|tsconfig|package\.json|\.env|Dockerfile|docker-compose)\b/i.test(e)&&(s=8),/\b(index|main|app|server)\.(ts|js|tsx|jsx)$/i.test(e)&&(s=7),/\.(test|spec)\.(ts|js|tsx|jsx)$/i.test(e)&&(s=3);let r=ga(t);return r>2e3&&(s=Math.max(1,s-1)),r>5e3&&(s=Math.max(1,s-2)),s}autoTag(e){let t=[];return/\.(ts|tsx)$/.test(e)&&t.push("typescript"),/\.(js|jsx)$/.test(e)&&t.push("javascript"),/\.json$/.test(e)&&t.push("config"),/\.md$/.test(e)&&t.push("documentation"),/\.(css|scss|sass)$/.test(e)&&t.push("style"),/\.(test|spec)\./i.test(e)&&t.push("test"),/src\//.test(e)&&t.push("source"),t}recordAccess(e){this.accessHistory.length>50&&(this.accessHistory=this.accessHistory.slice(-50));let t=this.accessHistory[this.accessHistory.length-1];if(t&&Date.now()-this.getGroupTime(t)<3e4){if(!t.includes(e)){t.push(e);for(let s of t)if(s!==e){let r=this.cache.get(s);r&&!r.relatedFiles.includes(e)&&r.relatedFiles.push(e)}}}else this.accessHistory.push([e])}getGroupTime(e){return Date.now()}computeHash(e){return Np.createHash("md5").update(e).digest("hex")}}});function fs(){return`msg_${Date.now()}_${++lS}`}function Rn(n){return Math.ceil(n.length/4)}var lS,an,va=L(()=>{"use strict";lS=0;an=class n{messages=[];maxMessages;maxTokens;sessionId;snapshots=[];forks=new Map;agentMessageCounts=new Map;totalTokens=0;constructor(e,t=50,s=32e3){this.maxMessages=t,this.maxTokens=s,this.sessionId=`session_${Date.now()}`;let r=Rn(e);this.messages.push({id:fs(),role:"system",content:e,timestamp:Date.now(),priority:"critical",tokenEstimate:r,compressed:!1,tags:["system"]}),this.totalTokens=r}getSessionId(){return this.sessionId}addUserMessage(e,t){let s=fs(),r=Rn(e);return this.messages.push({id:s,role:"user",content:e,timestamp:Date.now(),priority:t?.priority||"high",tokenEstimate:r,compressed:!1,tags:t?.tags||["user-input"]}),this.totalTokens+=r,this.trimIfNeeded(),s}addAssistantMessage(e,t,s){let r=fs(),i=Rn(e),o={id:r,role:"assistant",content:e,timestamp:Date.now(),priority:"normal",agent:s||"hablas",tokenEstimate:i,compressed:!1,tags:s?[`agent:${s}`]:["assistant"]};return t&&t.length>0&&(o.tool_calls=t,o.tags.push("has-tools")),this.messages.push(o),this.totalTokens+=i,s&&this.agentMessageCounts.set(s,(this.agentMessageCounts.get(s)||0)+1),this.trimIfNeeded(),r}addToolMessage(e,t){let s=fs(),r=Rn(e);return this.messages.push({id:s,role:"tool",content:e,timestamp:Date.now(),priority:e.startsWith("Error")?"high":"low",tokenEstimate:r,compressed:!1,tags:t?[`tool:${t}`]:["tool-result"]}),this.totalTokens+=r,this.trimIfNeeded(),s}getMessages(){return this.messages.map(e=>{let t={role:e.role,content:e.content};return e.tool_calls&&e.tool_calls.length>0&&(t.tool_calls=e.tool_calls),t})}getEnhancedMessages(){return[...this.messages]}getHistory(){return this.messages.slice(1).map(e=>({role:e.role,content:e.content,tool_calls:e.tool_calls}))}getAgentMessages(e){return this.messages.filter(t=>t.agent===e)}getAgentStats(){return new Map(this.agentMessageCounts)}getTotalTokens(){return this.totalTokens}getMessageCount(){return this.messages.length}clear(){let e=this.messages[0];this.messages=[e],this.totalTokens=e.tokenEstimate,this.agentMessageCounts.clear()}updateSystemPrompt(e){let t=Rn(e),s=this.messages.filter(r=>r.priority==="critical"&&r.role!=="system");this.messages=[{id:fs(),role:"system",content:e,timestamp:Date.now(),priority:"critical",tokenEstimate:t,compressed:!1,tags:["system"]},...s],this.recalculateTokens()}takeSnapshot(e){let t={id:`snap_${Date.now()}`,timestamp:Date.now(),messages:this.messages.map(s=>({...s})),systemPrompt:this.messages[0]?.content||"",label:e};return this.snapshots.push(t),this.snapshots.length>10&&(this.snapshots=this.snapshots.slice(-10)),t.id}rollback(e){let t=this.snapshots.find(s=>s.id===e);return t?(this.messages=t.messages.map(s=>({...s})),this.recalculateTokens(),!0):!1}getSnapshots(){return[...this.snapshots]}fork(e,t){let s=this.messages.length,r=new n(t,this.maxMessages,this.maxTokens),i=this.messages.filter(o=>o.priority==="critical"||o.priority==="high").filter(o=>o.role!=="system").slice(-5);for(let o of i)o.role==="user"?r.addUserMessage(o.content,{priority:o.priority,tags:[...o.tags,"inherited"]}):o.role==="assistant"&&r.addAssistantMessage(o.content,o.tool_calls,o.agent);return this.forks.set(e,{parentSessionId:this.sessionId,forkPoint:s,session:r}),r}mergeFork(e,t){let s=this.forks.get(e);if(!s)return!1;let r=s.session.getEnhancedMessages().filter(i=>i.role!=="system").filter(i=>!i.tags.includes("inherited"));if(t)this.addAssistantMessage(`[Agent @${e} result]: ${t}`,void 0,e);else if(r.length>0){let i=r.filter(o=>o.role==="assistant").pop();i&&this.addAssistantMessage(i.content,i.tool_calls,e)}return this.forks.delete(e),!0}getActiveForks(){return Array.from(this.forks.keys())}searchMessages(e){let t=e.toLowerCase();return this.messages.filter(s=>s.content.toLowerCase().includes(t))}getMessagesByTag(e){return this.messages.filter(t=>t.tags.includes(e))}getLastByRole(e,t=1){return this.messages.filter(s=>s.role===e).slice(-t)}trimIfNeeded(){if(this.messages.length<=this.maxMessages&&this.totalTokens<=this.maxTokens)return;let e=this.messages.filter(t=>t.role==="tool"&&!t.compressed&&t.tokenEstimate>200);for(let t of e.slice(0,-3)){if(this.totalTokens<=this.maxTokens&&this.messages.length<=this.maxMessages)break;this.compressMessage(t)}if(this.totalTokens>this.maxTokens||this.messages.length>this.maxMessages){let t=this.messages.filter(s=>s.role==="assistant"&&!s.compressed&&s.priority!=="critical"&&s.tokenEstimate>300);for(let s of t.slice(0,-2)){if(this.totalTokens<=this.maxTokens&&this.messages.length<=this.maxMessages)break;this.compressMessage(s)}}if(this.messages.length>this.maxMessages){let t=this.messages[0],s=this.messages.slice(1),r={critical:3,high:2,normal:1,low:0},i=s.sort((o,a)=>{let l=r[a.priority]-r[o.priority];return l!==0?l:a.timestamp-o.timestamp}).slice(0,this.maxMessages-1);i.sort((o,a)=>o.timestamp-a.timestamp),this.messages=[t,...i],this.recalculateTokens()}}compressMessage(e){let t=e.content.length,s=e.tokenEstimate;e.role==="tool"?e.content=e.content.slice(0,200)+`
|
|
383
383
|
...(compressed from `+t+" chars)":e.content=e.content.slice(0,400)+`
|
|
384
|
-
...(compressed from `+t+" chars)",e.compressed=!0,e.originalLength=t,e.tokenEstimate=Rn(e.content),this.totalTokens-=s-e.tokenEstimate}recalculateTokens(){this.totalTokens=this.messages.reduce((e,t)=>e+t.tokenEstimate,0)}toJSON(){return JSON.stringify({sessionId:this.sessionId,messageCount:this.messages.length,totalTokens:this.totalTokens,messages:this.messages,agentStats:Object.fromEntries(this.agentMessageCounts)},null,2)}getSessionInfo(){return{id:this.sessionId,messages:this.messages.length,tokens:this.totalTokens,agents:Object.fromEntries(this.agentMessageCounts),forks:Array.from(this.forks.keys()),snapshots:this.snapshots.length}}}});var jp,Xe,Ke,Hp,gr,wa,cS,uS,dS,ps,Bp=L(()=>{"use strict";jp=O(require("readline")),Xe=O(require("fs")),Ke=O(require("path")),Hp=O(require("os"));xn();gr=Ke.join(Hp.homedir(),".hablas","history"),wa=500,cS=new Set([".ts",".js",".tsx",".jsx",".py",".go",".rs",".java",".c",".cpp",".h",".css",".html",".json",".md",".yaml",".yml",".toml",".txt",".env",".sh",".bash",".zsh",".dockerfile",".xml",".svg",".sql"]),uS=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next",".cache"]),dS=["read ","edit ","write ","delete ","open ","patch "],ps=class{rl;history=[];workingDir;fileCache=[];fileCacheTime=0;constructor(e){this.workingDir=e||process.cwd(),this.loadHistory(),this.rl=this.createReadline()}createReadline(){return jp.createInterface({input:process.stdin,output:process.stdout,terminal:!0,history:this.history,historySize:wa,completer:e=>this.autocomplete(e)})}reinitialize(){this.loadHistory(),this.rl=this.createReadline()}async prompt(e){return new Promise(t=>{process.stdin.isTTY&&process.stdout.write("\r\x1B[K"),this.rl.question(e,s=>{s.trim()&&(this.history.push(s.trim()),this.saveHistory()),t(s)})})}async confirm(e){let t=` ${c.warning("?")} ${e} ${c.muted("[Y/n]")} `;return(await this.prompt(t)).toLowerCase()!=="n"}async confirmDangerous(e){console.log(`
|
|
384
|
+
...(compressed from `+t+" chars)",e.compressed=!0,e.originalLength=t,e.tokenEstimate=Rn(e.content),this.totalTokens-=s-e.tokenEstimate}recalculateTokens(){this.totalTokens=this.messages.reduce((e,t)=>e+t.tokenEstimate,0)}toJSON(){return JSON.stringify({sessionId:this.sessionId,messageCount:this.messages.length,totalTokens:this.totalTokens,messages:this.messages,agentStats:Object.fromEntries(this.agentMessageCounts)},null,2)}fromJSON(e){let t=JSON.parse(e);if(!t.messages||!Array.isArray(t.messages))throw new Error("Invalid session JSON data structure.");this.sessionId=t.sessionId||`session_${Date.now()}`,this.messages=t.messages,this.totalTokens=t.totalTokens||0,this.agentMessageCounts=new Map(Object.entries(t.agentStats||{})),this.recalculateTokens()}getSessionInfo(){return{id:this.sessionId,messages:this.messages.length,tokens:this.totalTokens,agents:Object.fromEntries(this.agentMessageCounts),forks:Array.from(this.forks.keys()),snapshots:this.snapshots.length}}}});var jp,Xe,Ke,Hp,gr,wa,cS,uS,dS,ps,Bp=L(()=>{"use strict";jp=O(require("readline")),Xe=O(require("fs")),Ke=O(require("path")),Hp=O(require("os"));xn();gr=Ke.join(Hp.homedir(),".hablas","history"),wa=500,cS=new Set([".ts",".js",".tsx",".jsx",".py",".go",".rs",".java",".c",".cpp",".h",".css",".html",".json",".md",".yaml",".yml",".toml",".txt",".env",".sh",".bash",".zsh",".dockerfile",".xml",".svg",".sql"]),uS=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next",".cache"]),dS=["read ","edit ","write ","delete ","open ","patch "],ps=class{rl;history=[];workingDir;fileCache=[];fileCacheTime=0;constructor(e){this.workingDir=e||process.cwd(),this.loadHistory(),this.rl=this.createReadline()}createReadline(){return jp.createInterface({input:process.stdin,output:process.stdout,terminal:!0,history:this.history,historySize:wa,completer:e=>this.autocomplete(e)})}reinitialize(){this.loadHistory(),this.rl=this.createReadline()}async prompt(e){return new Promise(t=>{process.stdin.isTTY&&process.stdout.write("\r\x1B[K"),this.rl.question(e,s=>{s.trim()&&(this.history.push(s.trim()),this.saveHistory()),t(s)})})}async confirm(e){let t=` ${c.warning("?")} ${e} ${c.muted("[Y/n]")} `;return(await this.prompt(t)).toLowerCase()!=="n"}async confirmDangerous(e){console.log(`
|
|
385
385
|
${c.error("\u26A0")} ${c.error(c.strong(e))}`),console.log(` ${c.muted('This action cannot be undone. Type "yes" to confirm.')}
|
|
386
386
|
`);let t=` ${c.error("\u2192")} `;return(await this.prompt(t)).trim().toLowerCase()==="yes"}close(){this.saveHistory(),this.rl.close()}autocomplete(e){if(e.startsWith("/")){if(e.startsWith("/model ")||e.startsWith("/usemodel "))return[[],e];if(e.startsWith("/mindset ")){let r=["coder","planner","debugger","reviewer"],i=e.slice(9),o=r.filter(a=>a.startsWith(i)).map(a=>"/mindset "+a);return[o.length?o:r.map(a=>"/mindset "+a),e]}if(e.startsWith("/alias ")){let r=["/alias set","/alias del"],i=r.filter(o=>o.startsWith(e));return[i.length?i:r,e]}if(e.startsWith("/plugins ")){let r=["/plugins enable","/plugins disable"],i=r.filter(o=>o.startsWith(e));return[i.length?i:r,e]}let s=no.filter(r=>r.startsWith(e));return[s.length?s:no,e]}for(let s of dS)if(e.toLowerCase().includes(s)){let r=e.split(s).pop()??"";if(r&&!r.includes(" "))try{let i=Ke.dirname(r)||".",o=Ke.basename(r),a=Ke.resolve(this.workingDir,i),l=Xe.readdirSync(a).filter(u=>u.startsWith(o)).slice(0,8).map(u=>e.slice(0,e.lastIndexOf(r))+Ke.join(i,u));if(l.length)return[l,e]}catch{}}let t=e.match(/#([\w./-]*)$/);if(t){let s=t[1],r=this.getProjectFiles(),i=r.filter(a=>a.toLowerCase().startsWith(s.toLowerCase())).map(a=>e.slice(0,e.length-t[0].length)+"#"+a);return i.length>0?[i,e]:[r.slice(0,20).map(a=>e.slice(0,e.length-t[0].length)+"#"+a),e]}return[[],e]}getProjectFiles(){let e=Date.now();if(this.fileCache.length>0&&e-this.fileCacheTime<1e4)return this.fileCache;let t=[];return this.scanDir(this.workingDir,"",t,3),this.fileCache=t,this.fileCacheTime=e,t}scanDir(e,t,s,r,i=0){if(!(i>=r))try{let o=Xe.readdirSync(e,{withFileTypes:!0});for(let a of o){if(a.name.startsWith(".")||uS.has(a.name))continue;let l=t?`${t}/${a.name}`:a.name;if(a.isDirectory())this.scanDir(Ke.join(e,a.name),l,s,r,i+1);else{let u=Ke.extname(a.name).toLowerCase();(cS.has(u)||a.name==="Dockerfile"||a.name==="Makefile")&&s.push(l)}}}catch{}}loadHistory(){try{if(Xe.existsSync(gr)){let e=Xe.readFileSync(gr,"utf-8");this.history=e.split(`
|
|
387
387
|
`).filter(Boolean).slice(-wa)}}catch{}}saveHistory(){try{let e=Ke.dirname(gr);Xe.existsSync(e)||Xe.mkdirSync(e,{recursive:!0});let t=this.history.slice(-wa);Xe.writeFileSync(gr,t.join(`
|
|
@@ -419,13 +419,13 @@ ${u.content}`),a+=u.tokenCount}return l.join(`
|
|
|
419
419
|
|
|
420
420
|
## Important
|
|
421
421
|
Never output tool calls as text or JSON in your response.
|
|
422
|
-
Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","patch_file","edit_file","write_file","search_codebase","run_command"],behaviorModifiers:{planFirst:!1,maxIterations:0,verbosity:"concise",autoConfirmSafe:!0,reasoning:"systematic",askWhenUncertain:!1,canDelegate:!1,contextPriority:"code"},filePatterns:["*.ts","*.js","*.tsx","*.jsx","*.py","*.go","*.rs","*.css","*.html"]}});var Aa,$a=L(()=>{"use strict";Aa={name:"planner",description:"Team Leader \u2014 strategic planning, task breakdown, coordination, decision-making",systemPrompt:`You are Hablas, the Team Leader of a multi-agent AI development system. You are a
|
|
423
|
-
You coordinate a team of specialized agents to help developers build and modify their codebase.
|
|
422
|
+
Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","patch_file","edit_file","write_file","search_codebase","run_command"],behaviorModifiers:{planFirst:!1,maxIterations:0,verbosity:"concise",autoConfirmSafe:!0,reasoning:"systematic",askWhenUncertain:!1,canDelegate:!1,contextPriority:"code"},filePatterns:["*.ts","*.js","*.tsx","*.jsx","*.py","*.go","*.rs","*.css","*.html"]}});var Aa,$a=L(()=>{"use strict";Aa={name:"planner",description:"Team Leader \u2014 strategic planning, task breakdown, coordination, decision-making",systemPrompt:`You are Hablas, the inspiring Team Leader of a multi-agent AI development system. You are a highly supportive, communicative, and exceptionally competent Engineering Lead.
|
|
423
|
+
You coordinate a team of specialized agents to help developers build and modify their codebase, and you love helping the developer succeed with high-quality engineering.
|
|
424
424
|
|
|
425
|
-
## Your Persona (
|
|
426
|
-
- **Tone:**
|
|
427
|
-
- **Vocabulary:** Use
|
|
428
|
-
- **Style:**
|
|
425
|
+
## Your Persona (Supportive, Empathetic & Expert Engineering Lead)
|
|
426
|
+
- **Tone:** Friendly, encouraging, collaborative, clear, and highly professional. You are always pleasant, polite, and eager to help.
|
|
427
|
+
- **Vocabulary:** Use encouraging, clear, and expert engineering terms (e.g., "Excellent task, let's achieve it!", "Coordinating our specialists", "Aligned with your goals", "Pristine execution", "Successfully integrated").
|
|
428
|
+
- **Style:** Facilitating, positive, and constructive. You explain things clearly, guide your team with encouragement, and treat the developer as your ultimate partner.
|
|
429
429
|
|
|
430
430
|
## Your Team
|
|
431
431
|
- **@Emma** \u2014 Product Manager: Requirements, PRDs, user stories
|
|
@@ -434,15 +434,15 @@ You coordinate a team of specialized agents to help developers build and modify
|
|
|
434
434
|
- **@David** \u2014 Data Analyst: Research, documentation, data analysis
|
|
435
435
|
|
|
436
436
|
## Your Responsibilities
|
|
437
|
-
1. Receive and analyze user requests
|
|
438
|
-
2. Break complex tasks into clear, numbered steps
|
|
439
|
-
3. Assign tasks to the right team member
|
|
440
|
-
4. Review and compile results from agents
|
|
441
|
-
5.
|
|
442
|
-
6. Ensure quality and completeness
|
|
437
|
+
1. Receive and analyze user requests warmly
|
|
438
|
+
2. Break complex tasks into clear, encouraging, numbered steps
|
|
439
|
+
3. Assign tasks to the right team member and encourage their work
|
|
440
|
+
4. Review and compile results from agents with positive reinforcement
|
|
441
|
+
5. Assist the developer proactively when questions or issues arise
|
|
442
|
+
6. Ensure elite software quality, cleanliness, and completeness
|
|
443
443
|
|
|
444
444
|
## Planning Process
|
|
445
|
-
Before any action, create
|
|
445
|
+
Before any complex action, create an encouraging, clear, numbered plan:
|
|
446
446
|
---
|
|
447
447
|
Plan:
|
|
448
448
|
1. [First action] \u2192 @Agent
|
|
@@ -455,8 +455,8 @@ Then execute step by step.
|
|
|
455
455
|
1. For simple tasks, handle directly (no team needed).
|
|
456
456
|
2. For complex tasks, create a plan and distribute work.
|
|
457
457
|
3. Always read relevant files before making decisions.
|
|
458
|
-
4. After completing a plan, provide a clear summary.
|
|
459
|
-
5. If a step fails, re-plan the remaining steps.
|
|
458
|
+
4. After completing a plan, provide a clear, warm summary.
|
|
459
|
+
5. If a step fails, analyze nicely and re-plan the remaining steps.
|
|
460
460
|
6. Use tools for every file operation.
|
|
461
461
|
|
|
462
462
|
## Important
|
|
@@ -679,33 +679,33 @@ Your absolute priority is to ensure smooth, conflict-free collaboration between
|
|
|
679
679
|
## Important
|
|
680
680
|
Never output tool calls as text or JSON in your response.
|
|
681
681
|
Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","list_dir","write_file","patch_file","run_command"],behaviorModifiers:{planFirst:!0,maxIterations:10,verbosity:"concise",autoConfirmSafe:!0,reasoning:"analytical",askWhenUncertain:!0,canDelegate:!1,contextPriority:"requirements"}}});function br(){let n=new hs;return n.register(_a),n.register(Aa),n.register(Ca),n.register(Ea),n.register(Pa),n.register(Ma),n.register(Da),n.register(Fa),n.register(ja),n}var Ba=L(()=>{"use strict";Sa();ka();$a();Ta();Ra();Oa();Ia();La();Na();Ha();Sa();ka();$a();Ta();Ra();Oa();Ia();La();Na();Ha()});var vr,Kp=L(()=>{"use strict";vr=class{tasks=[];nextId=1;add(e){let t={id:this.nextId++,description:e,status:"pending",createdAt:Date.now()};return this.tasks.push(t),t}addBatch(e){return e.map(t=>this.add(t))}next(){return this.tasks.find(e=>e.status==="pending")}start(e){let t=this.tasks.find(s=>s.id===e);t&&(t.status="running")}complete(e,t){let s=this.tasks.find(r=>r.id===e);s&&(s.status="done",s.result=t,s.completedAt=Date.now())}fail(e,t){let s=this.tasks.find(r=>r.id===e);s&&(s.status="failed",s.error=t,s.completedAt=Date.now())}skip(e){let t=this.tasks.find(s=>s.id===e);t&&(t.status="skipped",t.completedAt=Date.now())}getAll(){return[...this.tasks]}getProgress(){let e=this.tasks.length,t=this.tasks.filter(o=>o.status==="done").length,s=this.tasks.filter(o=>o.status==="failed").length,r=this.tasks.filter(o=>o.status==="pending").length,i=this.tasks.filter(o=>o.status==="running").length;return{total:e,done:t,failed:s,pending:r,running:i}}isComplete(){return this.tasks.every(e=>e.status==="done"||e.status==="failed"||e.status==="skipped")}clear(){this.tasks=[],this.nextId=1}render(){if(this.tasks.length===0)return" No tasks in queue";let e={pending:"\u25CB",running:"\u25C9",done:"\u2713",failed:"\u2717",skipped:"\u2013"},t=this.tasks.map(r=>{let i=e[r.status],o=r.completedAt?` (${Math.round((r.completedAt-r.createdAt)/1e3)}s)`:"";return` ${i} ${r.id}. ${r.description}${o}`}),s=this.getProgress();return t.push(""),t.push(` Progress: ${s.done}/${s.total} done`+(s.failed>0?`, ${s.failed} failed`:"")),t.join(`
|
|
682
|
-
`)}}});var
|
|
682
|
+
`)}}});var De,wr,Wp,Gp,On,ms,Vp=L(()=>{"use strict";De=O(require("fs")),wr=O(require("path")),Wp=O(require("os")),Gp=O(require("crypto")),On=wr.join(Wp.homedir(),".hablas","memory"),ms=class{entries=new Map;agentLanes=new Map;projectHash;filePath;agentLanesPath;constructor(e){this.projectHash=Gp.createHash("md5").update(e).digest("hex").slice(0,12),this.filePath=wr.join(On,`${this.projectHash}.json`),this.agentLanesPath=wr.join(On,`${this.projectHash}_agents.json`),this.load()}set(e,t,s){let r=this.entries.get(e),i=Date.now(),o=s?.category||"note";this.entries.set(e,{key:e,value:t,category:o,importance:s?.importance??this.autoImportance(o,t),createdBy:s?.createdBy||"hablas",accessCount:r?.accessCount??0,useCount:r?.useCount??0,tags:s?.tags||this.autoTag(t,o),relatedFiles:s?.relatedFiles||this.extractFileRefs(t),createdAt:r?.createdAt??i,updatedAt:i,lastAccessedAt:i,consolidatedFrom:r?.consolidatedFrom}),this.save()}get(e){let t=this.entries.get(e);return t&&(t.accessCount++,t.lastAccessedAt=Date.now()),t?.value}getEntry(e){return this.entries.get(e)}markUsed(e){let t=this.entries.get(e);t&&(t.useCount++,t.importance=Math.min(10,t.importance+.5))}delete(e){let t=this.entries.delete(e);return t&&this.save(),t}setAgentMemory(e,t,s,r="agent-learning"){let i=this.agentLanes.get(e);i||(i=new Map,this.agentLanes.set(e,i));let o=Date.now(),a=i.get(t);i.set(t,{key:t,value:s,category:r,importance:this.autoImportance(r,s),createdBy:e,accessCount:a?.accessCount??0,useCount:a?.useCount??0,tags:this.autoTag(s,r),relatedFiles:this.extractFileRefs(s),createdAt:a?.createdAt??o,updatedAt:o,lastAccessedAt:o}),this.saveAgentLanes()}getAgentMemories(e){let t=this.agentLanes.get(e);return t?Array.from(t.values()):[]}getAgentMemorySummary(e,t=10){let s=this.getAgentMemories(e),r=this.getAll().filter(a=>a.importance>=5||a.useCount>=2),i=[...s,...r].sort((a,l)=>{let u=a.importance*(1+a.useCount*.3);return l.importance*(1+l.useCount*.3)-u}).slice(0,t);return i.length===0?"":`## Agent Memory
|
|
683
683
|
`+i.map(a=>`- [${a.category}${a.importance>=7?" \u2605":""}] ${a.key}: ${a.value}`).join(`
|
|
684
684
|
`)}search(e,t){let s=e.toLowerCase(),r=s.split(/\s+/).filter(l=>l.length>2),i=t?.maxResults||20,o=[],a=t?.agent?this.getAgentMemories(t.agent):this.getAll();for(let l of a){if(t?.category&&l.category!==t.category||t?.minImportance&&l.importance<t.minImportance)continue;let u=0,d="partial";l.key.toLowerCase()===s&&(u+=10,d="exact"),l.key.toLowerCase().includes(s)&&(u+=5),l.value.toLowerCase().includes(s)&&(u+=3);for(let h of r)l.key.toLowerCase().includes(h)&&(u+=2),l.value.toLowerCase().includes(h)&&(u+=1),l.tags.some(m=>m.toLowerCase().includes(h))&&(u+=2,d=d==="exact"?"exact":"tag");u*=1+l.importance*.1,u*=1+l.useCount*.2;let f=(Date.now()-l.updatedAt)/(10080*60*1e3);u*=Math.max(.3,1-f*.1),u>.5&&o.push({entry:l,relevanceScore:u,matchType:d})}return o.sort((l,u)=>u.relevanceScore-l.relevanceScore).slice(0,i)}getAll(e){let t=Array.from(this.entries.values());return e?t.filter(s=>s.category===e):t}getByFile(e){return Array.from(this.entries.values()).filter(t=>t.relatedFiles.some(s=>s.includes(e)||e.includes(s)))}getTopMemories(e=15){return Array.from(this.entries.values()).sort((t,s)=>{let r=t.importance*(1+t.useCount*.3)*(1+Math.log1p(t.accessCount)*.1);return s.importance*(1+s.useCount*.3)*(1+Math.log1p(s.accessCount)*.1)-r}).slice(0,e)}getSummary(){let e=this.getTopMemories(15);if(e.length===0)return"";let t={};for(let r of e){let i=r.category;t[i]||(t[i]=[]),t[i].push(`${r.key}: ${r.value}`)}let s=["## Project Memory"];for(let[r,i]of Object.entries(t)){s.push(`### ${r}`);for(let o of i)s.push(`- ${o}`)}return s.join(`
|
|
685
685
|
`)}getStats(){let e=this.getAll(),t={},s={};for(let r of e)t[r.category]=(t[r.category]||0)+1,s[r.createdBy]=(s[r.createdBy]||0)+1;return{totalEntries:e.length,byCategory:t,byAgent:s,topAccessed:e.sort((r,i)=>i.accessCount-r.accessCount).slice(0,5),recentlyAdded:e.sort((r,i)=>i.createdAt-r.createdAt).slice(0,5),totalAccessCount:e.reduce((r,i)=>r+i.accessCount,0)}}consolidate(e=200){if(this.entries.size<=e)return 0;let t=Array.from(this.entries.values()).filter(o=>o.importance<4&&o.accessCount<3).sort((o,a)=>o.updatedAt-a.updatedAt),s=t.slice(0,Math.max(10,t.length-e)),r={};for(let o of s){let a=o.category;r[a]||(r[a]=[]),r[a].push(o)}let i=0;for(let[o,a]of Object.entries(r)){if(a.length<2)continue;let l=`[consolidated] ${o} (${a.length} items)`,u=a.map(h=>`${h.key}: ${h.value}`).join("; "),d=a.map(h=>h.key);this.set(l,u.slice(0,500),{category:o,importance:3,tags:["consolidated"]});let f=this.entries.get(l);f&&(f.consolidatedFrom=d);for(let h of a)this.entries.delete(h.key),i++}return i>0&&this.save(),i}learnFromToolResult(e,t,s,r,i="hablas"){if(!(s.length<20)){if(!r){let o=`error:${e}:${JSON.stringify(t).slice(0,50)}`,a=this.entries.get(o);a?(a.useCount++,a.importance=Math.min(10,a.importance+1)):this.set(o,`${e} failed with: ${s.slice(0,200)}`,{category:"error",importance:6,createdBy:i,tags:["auto-learned","error",e]})}if(e==="list_dir"&&r){let o=t.path||".";this.set(`structure:${o}`,s.slice(0,300),{category:"pattern",importance:3,createdBy:i,tags:["auto-learned","structure"],relatedFiles:[o]})}}}size(){return this.entries.size}clear(){this.entries.clear(),this.agentLanes.clear(),this.save(),this.saveAgentLanes()}render(){if(this.getAll().length===0)return" No project memories stored";let t={convention:"\u{1F4CF}",decision:"\u{1F3AF}",pattern:"\u{1F504}",note:"\u{1F4DD}",error:"\u26A0\uFE0F","tool-result":"\u{1F527}","user-pref":"\u{1F464}",dependency:"\u{1F4E6}",performance:"\u26A1",security:"\u{1F512}",api:"\u{1F310}","agent-learning":"\u{1F916}"};return this.getTopMemories(20).map(i=>{let o=t[i.category]||"\xB7",a=i.importance>=7?" \u2605":"",l=i.useCount>0?` (used ${i.useCount}\xD7)`:"";return` ${o}${a} ${i.key}: ${i.value}${l}`}).join(`
|
|
686
|
-
`)}autoImportance(e,t){let r={convention:6,decision:8,pattern:5,note:3,error:7,"tool-result":2,"user-pref":7,dependency:4,performance:5,security:9,api:6,"agent-learning":4}[e]||3;return/\b(important|critical|must|always|never|danger|warning|breaking)\b/i.test(t)&&(r=Math.min(10,r+2)),r}autoTag(e,t){let s=[t];return/\b(react|vue|angular|svelte|next|nuxt)\b/i.test(e)&&s.push("frontend"),/\b(express|fastify|nest|koa|hapi)\b/i.test(e)&&s.push("backend"),/\b(postgres|mysql|mongo|redis|sqlite)\b/i.test(e)&&s.push("database"),/\b(docker|kubernetes|k8s|ci\/cd|deploy)\b/i.test(e)&&s.push("devops"),/\b(test|jest|vitest|cypress|playwright)\b/i.test(e)&&s.push("testing"),/\b(auth|jwt|oauth|session|token)\b/i.test(e)&&s.push("auth"),/\b(api|endpoint|route|rest|graphql)\b/i.test(e)&&s.push("api"),s}extractFileRefs(e){let t=/[\w\-./]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|scss|html|vue|svelte|go|rs|java|sql|sh|toml|xml|env)/gi,s=e.match(t);return s?[...new Set(s)]:[]}load(){try{if(
|
|
686
|
+
`)}autoImportance(e,t){let r={convention:6,decision:8,pattern:5,note:3,error:7,"tool-result":2,"user-pref":7,dependency:4,performance:5,security:9,api:6,"agent-learning":4}[e]||3;return/\b(important|critical|must|always|never|danger|warning|breaking)\b/i.test(t)&&(r=Math.min(10,r+2)),r}autoTag(e,t){let s=[t];return/\b(react|vue|angular|svelte|next|nuxt)\b/i.test(e)&&s.push("frontend"),/\b(express|fastify|nest|koa|hapi)\b/i.test(e)&&s.push("backend"),/\b(postgres|mysql|mongo|redis|sqlite)\b/i.test(e)&&s.push("database"),/\b(docker|kubernetes|k8s|ci\/cd|deploy)\b/i.test(e)&&s.push("devops"),/\b(test|jest|vitest|cypress|playwright)\b/i.test(e)&&s.push("testing"),/\b(auth|jwt|oauth|session|token)\b/i.test(e)&&s.push("auth"),/\b(api|endpoint|route|rest|graphql)\b/i.test(e)&&s.push("api"),s}extractFileRefs(e){let t=/[\w\-./]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|scss|html|vue|svelte|go|rs|java|sql|sh|toml|xml|env)/gi,s=e.match(t);return s?[...new Set(s)]:[]}load(){try{if(De.existsSync(this.filePath)){let e=JSON.parse(De.readFileSync(this.filePath,"utf-8"));if(Array.isArray(e))for(let t of e)t.importance||(t.importance=3),t.createdBy||(t.createdBy="hablas"),t.accessCount||(t.accessCount=0),t.useCount||(t.useCount=0),t.tags||(t.tags=[t.category||"note"]),t.relatedFiles||(t.relatedFiles=[]),t.lastAccessedAt||(t.lastAccessedAt=t.updatedAt||Date.now()),this.entries.set(t.key,t)}}catch{}this.loadAgentLanes()}save(){try{De.existsSync(On)||De.mkdirSync(On,{recursive:!0});let e=Array.from(this.entries.values());De.writeFileSync(this.filePath,JSON.stringify(e,null,2),"utf-8")}catch{}}loadAgentLanes(){try{if(De.existsSync(this.agentLanesPath)){let e=JSON.parse(De.readFileSync(this.agentLanesPath,"utf-8"));for(let[t,s]of Object.entries(e)){let r=new Map;for(let i of s)r.set(i.key,i);this.agentLanes.set(t,r)}}}catch{}}saveAgentLanes(){try{De.existsSync(On)||De.mkdirSync(On,{recursive:!0});let e={};for(let[t,s]of this.agentLanes)e[t]=Array.from(s.values());De.writeFileSync(this.agentLanesPath,JSON.stringify(e,null,2),"utf-8")}catch{}}}});var qa=N((XE,Jp)=>{"use strict";var gs=n=>n&&typeof n.message=="string",Ua=n=>{if(!n)return;let e=n.cause;if(typeof e=="function"){let t=n.cause();return gs(t)?t:void 0}else return gs(e)?e:void 0},zp=(n,e)=>{if(!gs(n))return"";let t=n.stack||"";if(e.has(n))return t+`
|
|
687
687
|
causes have become circular...`;let s=Ua(n);return s?(e.add(n),t+`
|
|
688
|
-
caused by: `+zp(s,e)):t},fS=n=>zp(n,new Set),Yp=(n,e,t)=>{if(!gs(n))return"";let s=t?"":n.message||"";if(e.has(n))return s+": ...";let r=Ua(n);if(r){e.add(n);let i=typeof n.cause=="function";return s+(i?"":": ")+Yp(r,e,i)}else return s},pS=n=>Yp(n,new Set);Jp.exports={isErrorLike:gs,getErrorCause:Ua,stackWithCauses:fS,messageWithCauses:pS}});var Ka=N((XE,Qp)=>{"use strict";var hS=Symbol("circular-ref-tag"),xr=Symbol("pino-raw-err-ref"),Xp=Object.create({},{type:{enumerable:!0,writable:!0,value:void 0},message:{enumerable:!0,writable:!0,value:void 0},stack:{enumerable:!0,writable:!0,value:void 0},aggregateErrors:{enumerable:!0,writable:!0,value:void 0},raw:{enumerable:!1,get:function(){return this[xr]},set:function(n){this[xr]=n}}});Object.defineProperty(Xp,xr,{writable:!0,value:{}});Qp.exports={pinoErrProto:Xp,pinoErrorSymbols:{seen:hS,rawSymbol:xr}}});var th=N((QE,eh)=>{"use strict";eh.exports=Ga;var{messageWithCauses:mS,stackWithCauses:gS,isErrorLike:Zp}=qa(),{pinoErrProto:yS,pinoErrorSymbols:bS}=Ka(),{seen:Wa}=bS,{toString:vS}=Object.prototype;function Ga(n){if(!Zp(n))return n;n[Wa]=void 0;let e=Object.create(yS);e.type=vS.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=mS(n),e.stack=gS(n),Array.isArray(n.errors)&&(e.aggregateErrors=n.errors.map(t=>Ga(t)));for(let t in n)if(e[t]===void 0){let s=n[t];Zp(s)?t!=="cause"&&!Object.prototype.hasOwnProperty.call(s,Wa)&&(e[t]=Ga(s)):e[t]=s}return delete n[Wa],e.raw=n,e}});var sh=N((ZE,nh)=>{"use strict";nh.exports=_r;var{isErrorLike:Va}=qa(),{pinoErrProto:wS,pinoErrorSymbols:xS}=Ka(),{seen:Sr}=xS,{toString:SS}=Object.prototype;function _r(n){if(!Va(n))return n;n[Sr]=void 0;let e=Object.create(wS);e.type=SS.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=n.message,e.stack=n.stack,Array.isArray(n.errors)&&(e.aggregateErrors=n.errors.map(t=>_r(t))),Va(n.cause)&&!Object.prototype.hasOwnProperty.call(n.cause,Sr)&&(e.cause=_r(n.cause));for(let t in n)if(e[t]===void 0){let s=n[t];Va(s)?Object.prototype.hasOwnProperty.call(s,Sr)||(e[t]=_r(s)):e[t]=s}return delete n[Sr],e.raw=n,e}});var ah=N((eR,oh)=>{"use strict";oh.exports={mapHttpRequest:_S,reqSerializer:ih};var za=Symbol("pino-raw-req-ref"),rh=Object.create({},{id:{enumerable:!0,writable:!0,value:""},method:{enumerable:!0,writable:!0,value:""},url:{enumerable:!0,writable:!0,value:""},query:{enumerable:!0,writable:!0,value:""},params:{enumerable:!0,writable:!0,value:""},headers:{enumerable:!0,writable:!0,value:{}},remoteAddress:{enumerable:!0,writable:!0,value:""},remotePort:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[za]},set:function(n){this[za]=n}}});Object.defineProperty(rh,za,{writable:!0,value:{}});function ih(n){let e=n.info||n.socket,t=Object.create(rh);if(t.id=typeof n.id=="function"?n.id():n.id||(n.info?n.info.id:void 0),t.method=n.method,n.originalUrl)t.url=n.originalUrl;else{let s=n.path;t.url=typeof s=="string"?s:n.url?n.url.path||n.url:void 0}return n.query&&(t.query=n.query),n.params&&(t.params=n.params),t.headers=n.headers,t.remoteAddress=e&&e.remoteAddress,t.remotePort=e&&e.remotePort,t.raw=n.raw||n,t}function _S(n){return{req:ih(n)}}});var dh=N((tR,uh)=>{"use strict";uh.exports={mapHttpResponse:kS,resSerializer:ch};var Ya=Symbol("pino-raw-res-ref"),lh=Object.create({},{statusCode:{enumerable:!0,writable:!0,value:0},headers:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[Ya]},set:function(n){this[Ya]=n}}});Object.defineProperty(lh,Ya,{writable:!0,value:{}});function ch(n){let e=Object.create(lh);return e.statusCode=n.headersSent?n.statusCode:null,e.headers=n.getHeaders?n.getHeaders():n._headers,e.raw=n,e}function kS(n){return{res:ch(n)}}});var Xa=N((nR,fh)=>{"use strict";var Ja=th(),AS=sh(),kr=ah(),Ar=dh();fh.exports={err:Ja,errWithCause:AS,mapHttpRequest:kr.mapHttpRequest,mapHttpResponse:Ar.mapHttpResponse,req:kr.reqSerializer,res:Ar.resSerializer,wrapErrorSerializer:function(e){return e===Ja?e:function(s){return e(Ja(s))}},wrapRequestSerializer:function(e){return e===kr.reqSerializer?e:function(s){return e(kr.reqSerializer(s))}},wrapResponseSerializer:function(e){return e===Ar.resSerializer?e:function(s){return e(Ar.resSerializer(s))}}}});var Qa=N((sR,ph)=>{"use strict";function $S(n,e){return e}ph.exports=function(){let e=Error.prepareStackTrace;Error.prepareStackTrace=$S;let t=new Error().stack;if(Error.prepareStackTrace=e,!Array.isArray(t))return;let s=t.slice(2),r=[];for(let i of s)i&&r.push(i.getFileName());return r}});var vh=N((rR,bh)=>{"use strict";function Za(n){if(n===null||typeof n!="object")return n;if(n instanceof Date)return new Date(n.getTime());if(n instanceof Array){let e=[];for(let t=0;t<n.length;t++)e[t]=Za(n[t]);return e}if(typeof n=="object"){let e=Object.create(Object.getPrototypeOf(n));for(let t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=Za(n[t]));return e}return n}function hh(n){let e=[],t="",s=!1,r=!1,i="";for(let o=0;o<n.length;o++){let a=n[o];!s&&a==="."?t&&(e.push(t),t=""):a==="["?(t&&(e.push(t),t=""),s=!0):a==="]"&&s?(e.push(t),t="",s=!1,r=!1):(a==='"'||a==="'")&&s?r?a===i?(r=!1,i=""):t+=a:(r=!0,i=a):t+=a}return t&&e.push(t),e}function mh(n,e,t){let s=n;for(let i=0;i<e.length-1;i++){let o=e[i];if(typeof s!="object"||s===null||!(o in s)||typeof s[o]!="object"||s[o]===null)return!1;s=s[o]}let r=e[e.length-1];if(r==="*"){if(Array.isArray(s))for(let i=0;i<s.length;i++)s[i]=t;else if(typeof s=="object"&&s!==null)for(let i in s)Object.prototype.hasOwnProperty.call(s,i)&&(s[i]=t)}else typeof s=="object"&&s!==null&&r in s&&Object.prototype.hasOwnProperty.call(s,r)&&(s[r]=t);return!0}function gh(n,e){let t=n;for(let r=0;r<e.length-1;r++){let i=e[r];if(typeof t!="object"||t===null||!(i in t)||typeof t[i]!="object"||t[i]===null)return!1;t=t[i]}let s=e[e.length-1];if(s==="*"){if(Array.isArray(t))for(let r=0;r<t.length;r++)t[r]=void 0;else if(typeof t=="object"&&t!==null)for(let r in t)Object.prototype.hasOwnProperty.call(t,r)&&delete t[r]}else typeof t=="object"&&t!==null&&s in t&&Object.prototype.hasOwnProperty.call(t,s)&&delete t[s];return!0}var $r=Symbol("PATH_NOT_FOUND");function CS(n,e){let t=n;for(let s of e){if(t==null||typeof t!="object"||t===null||!(s in t))return $r;t=t[s]}return t}function TS(n,e){let t=n;for(let s of e){if(t==null||typeof t!="object"||t===null)return;t=t[s]}return t}function ES(n,e,t,s=!1){for(let r of e){let i=hh(r);if(i.includes("*"))yh(n,i,t,r,s);else if(s)gh(n,i);else{let o=CS(n,i);if(o===$r)continue;let a=typeof t=="function"?t(o,i):t;mh(n,i,a)}}}function yh(n,e,t,s,r=!1){let i=e.indexOf("*");if(i===e.length-1){let o=e.slice(0,-1),a=n;for(let l of o){if(a==null||typeof a!="object"||a===null)return;a=a[l]}if(Array.isArray(a))if(r)for(let l=0;l<a.length;l++)a[l]=void 0;else for(let l=0;l<a.length;l++){let u=[...o,l.toString()],d=typeof t=="function"?t(a[l],u):t;a[l]=d}else if(typeof a=="object"&&a!==null)if(r){let l=[];for(let u in a)Object.prototype.hasOwnProperty.call(a,u)&&l.push(u);for(let u of l)delete a[u]}else for(let l in a){let u=[...o,l],d=typeof t=="function"?t(a[l],u):t;a[l]=d}}else RS(n,e,t,i,s,r)}function RS(n,e,t,s,r,i=!1){let o=e.slice(0,s),a=e.slice(s+1),l=[];function u(d,f){if(f===o.length){if(Array.isArray(d))for(let h=0;h<d.length;h++)l[f]=h.toString(),u(d[h],f+1);else if(typeof d=="object"&&d!==null)for(let h in d)l[f]=h,u(d[h],f+1)}else if(f<o.length){let h=o[f];d&&typeof d=="object"&&d!==null&&h in d&&(l[f]=h,u(d[h],f+1))}else if(a.includes("*"))yh(d,a,typeof t=="function"?(m,p)=>{let g=[...l.slice(0,f),...p];return t(m,g)}:t,r,i);else if(i)gh(d,a);else{let h=typeof t=="function"?t(TS(d,a),[...l.slice(0,f),...a]):t;mh(d,a,h)}}if(o.length===0)u(n,0);else{let d=n;for(let f=0;f<o.length;f++){let h=o[f];if(d==null||typeof d!="object"||d===null)return;d=d[h],l[f]=h}d!=null&&u(d,o.length)}}function PS(n){if(n.length===0)return null;let e=new Map;for(let t of n){let s=hh(t),r=e;for(let i=0;i<s.length;i++){let o=s[i];r.has(o)||r.set(o,new Map),r=r.get(o)}}return e}function OS(n,e){if(!e)return n;function t(s,r,i=0){if(!r||r.size===0||s===null||typeof s!="object")return s;if(s instanceof Date)return new Date(s.getTime());if(Array.isArray(s)){let a=[];for(let l=0;l<s.length;l++){let u=l.toString();r.has(u)||r.has("*")?a[l]=t(s[l],r.get(u)||r.get("*")):a[l]=s[l]}return a}let o=Object.create(Object.getPrototypeOf(s));for(let a in s)Object.prototype.hasOwnProperty.call(s,a)&&(r.has(a)||r.has("*")?o[a]=t(s[a],r.get(a)||r.get("*")):o[a]=s[a]);return o}return t(n,e)}function MS(n){if(typeof n!="string")throw new Error("Paths must be (non-empty) strings");if(n==="")throw new Error("Invalid redaction path ()");if(n.includes(".."))throw new Error(`Invalid redaction path (${n})`);if(n.includes(","))throw new Error(`Invalid redaction path (${n})`);let e=0,t=!1,s="";for(let r=0;r<n.length;r++){let i=n[r];if((i==='"'||i==="'")&&e>0)t?i===s&&(t=!1,s=""):(t=!0,s=i);else if(i==="["&&!t)e++;else if(i==="]"&&!t&&(e--,e<0))throw new Error(`Invalid redaction path (${n})`)}if(e!==0)throw new Error(`Invalid redaction path (${n})`)}function IS(n){if(!Array.isArray(n))throw new TypeError("paths must be an array");for(let e of n)MS(e)}function DS(n={}){let{paths:e=[],censor:t="[REDACTED]",serialize:s=JSON.stringify,strict:r=!0,remove:i=!1}=n;IS(e);let o=PS(e);return function(l){if(r&&(l===null||typeof l!="object")&&(l==null||typeof l!="object"))return s?s(l):l;let u=OS(l,o),d=l,f=t;return typeof t=="function"&&(f=t),ES(u,e,f,i),s===!1?(u.restore=function(){return Za(d)},u):typeof s=="function"?s(u):JSON.stringify(u)}}bh.exports=DS});var Mn=N((iR,wh)=>{"use strict";var LS=Symbol("pino.setLevel"),FS=Symbol("pino.getLevel"),NS=Symbol("pino.levelVal"),jS=Symbol("pino.levelComp"),HS=Symbol("pino.useLevelLabels"),BS=Symbol("pino.useOnlyCustomLevels"),US=Symbol("pino.mixin"),qS=Symbol("pino.lsCache"),KS=Symbol("pino.chindings"),WS=Symbol("pino.asJson"),GS=Symbol("pino.write"),VS=Symbol("pino.redactFmt"),zS=Symbol("pino.time"),YS=Symbol("pino.timeSliceIndex"),JS=Symbol("pino.stream"),XS=Symbol("pino.stringify"),QS=Symbol("pino.stringifySafe"),ZS=Symbol("pino.stringifiers"),e_=Symbol("pino.end"),t_=Symbol("pino.formatOpts"),n_=Symbol("pino.messageKey"),s_=Symbol("pino.errorKey"),r_=Symbol("pino.nestedKey"),i_=Symbol("pino.nestedKeyStr"),o_=Symbol("pino.mixinMergeStrategy"),a_=Symbol("pino.msgPrefix"),l_=Symbol("pino.wildcardFirst"),c_=Symbol.for("pino.serializers"),u_=Symbol.for("pino.formatters"),d_=Symbol.for("pino.hooks"),f_=Symbol.for("pino.metadata");wh.exports={setLevelSym:LS,getLevelSym:FS,levelValSym:NS,levelCompSym:jS,useLevelLabelsSym:HS,mixinSym:US,lsCacheSym:qS,chindingsSym:KS,asJsonSym:WS,writeSym:GS,serializersSym:c_,redactFmtSym:VS,timeSym:zS,timeSliceIndexSym:YS,streamSym:JS,stringifySym:XS,stringifySafeSym:QS,stringifiersSym:ZS,endSym:e_,formatOptsSym:t_,messageKeySym:n_,errorKeySym:s_,nestedKeySym:r_,wildcardFirstSym:l_,needsMetadataGsym:f_,useOnlyCustomLevelsSym:BS,formattersSym:u_,hooksSym:d_,nestedKeyStrSym:i_,mixinMergeStrategySym:o_,msgPrefixSym:a_}});var tl=N((oR,kh)=>{"use strict";var xh=vh(),{redactFmtSym:p_,wildcardFirstSym:Cr}=Mn(),el=/[^.[\]]+|\[([^[\]]*?)\]/g,Sh="[Redacted]",_h=!1;function h_(n,e){let{paths:t,censor:s,remove:r}=m_(n),i=t.reduce((l,u)=>{el.lastIndex=0;let d=el.exec(u),f=el.exec(u),h=d[1]!==void 0?d[1].replace(/^(?:"|'|`)(.*)(?:"|'|`)$/,"$1"):d[0];if(h==="*"&&(h=Cr),f===null)return l[h]=null,l;if(l[h]===null)return l;let{index:m}=f,p=`${u.substr(m,u.length-1)}`;return l[h]=l[h]||[],h!==Cr&&l[h].length===0&&l[h].push(...l[Cr]||[]),h===Cr&&Object.keys(l).forEach(function(g){l[g]&&l[g].push(p)}),l[h].push(p),l},{}),o={[p_]:xh({paths:t,censor:s,serialize:e,strict:_h,remove:r})},a=(...l)=>e(typeof s=="function"?s(...l):s);return[...Object.keys(i),...Object.getOwnPropertySymbols(i)].reduce((l,u)=>{if(i[u]===null)l[u]=d=>a(d,[u]);else{let d=typeof s=="function"?(f,h)=>s(f,[u,...h]):s;l[u]=xh({paths:i[u],censor:d,serialize:e,strict:_h,remove:r})}return l},o)}function m_(n){if(Array.isArray(n))return n={paths:n,censor:Sh},n;let{paths:e,censor:t=Sh,remove:s}=n;if(Array.isArray(e)===!1)throw Error("pino \u2013 redact must contain an array of strings");return s===!0&&(t=void 0),{paths:e,censor:t,remove:s}}kh.exports=h_});var Ch=N((aR,$h)=>{"use strict";var g_=()=>"",y_=()=>`,"time":${Date.now()}`,b_=()=>`,"time":${Math.round(Date.now()/1e3)}`,v_=()=>`,"time":"${new Date(Date.now()).toISOString()}"`,w_=1000000n,Ah=1000000000n,x_=BigInt(Date.now())*w_,S_=process.hrtime.bigint(),__=()=>{let n=process.hrtime.bigint()-S_,e=x_+n,t=e/Ah,s=e%Ah,r=Number(t*1000n+s/1000000n),i=new Date(r),o=i.getUTCFullYear(),a=(i.getUTCMonth()+1).toString().padStart(2,"0"),l=i.getUTCDate().toString().padStart(2,"0"),u=i.getUTCHours().toString().padStart(2,"0"),d=i.getUTCMinutes().toString().padStart(2,"0"),f=i.getUTCSeconds().toString().padStart(2,"0");return`,"time":"${o}-${a}-${l}T${u}:${d}:${f}.${s.toString().padStart(9,"0")}Z"`};$h.exports={nullTime:g_,epochTime:y_,unixTime:b_,isoTime:v_,isoTimeNano:__}});var Eh=N((lR,Th)=>{"use strict";function k_(n){try{return JSON.stringify(n)}catch{return'"[Circular]"'}}Th.exports=A_;function A_(n,e,t){var s=t&&t.stringify||k_,r=1;if(typeof n=="object"&&n!==null){var i=e.length+r;if(i===1)return n;var o=new Array(i);o[0]=s(n);for(var a=1;a<i;a++)o[a]=s(e[a]);return o.join(" ")}if(typeof n!="string")return n;var l=e.length;if(l===0)return n;for(var u="",d=1-r,f=-1,h=n&&n.length||0,m=0;m<h;){if(n.charCodeAt(m)===37&&m+1<h){switch(f=f>-1?f:0,n.charCodeAt(m+1)){case 100:case 102:if(d>=l||e[d]==null)break;f<m&&(u+=n.slice(f,m)),u+=Number(e[d]),f=m+2,m++;break;case 105:if(d>=l||e[d]==null)break;f<m&&(u+=n.slice(f,m)),u+=Math.floor(Number(e[d])),f=m+2,m++;break;case 79:case 111:case 106:if(d>=l||e[d]===void 0)break;f<m&&(u+=n.slice(f,m));var p=typeof e[d];if(p==="string"){u+="'"+e[d]+"'",f=m+2,m++;break}if(p==="function"){u+=e[d].name||"<anonymous>",f=m+2,m++;break}u+=s(e[d]),f=m+2,m++;break;case 115:if(d>=l)break;f<m&&(u+=n.slice(f,m)),u+=String(e[d]),f=m+2,m++;break;case 37:f<m&&(u+=n.slice(f,m)),u+="%",f=m+2,m++,d--;break}++d}++m}return f===-1?n:(f<h&&(u+=n.slice(f)),u)}});var sl=N((cR,nl)=>{"use strict";if(typeof SharedArrayBuffer<"u"&&typeof Atomics<"u"){let e=function(t){if((t>0&&t<1/0)===!1)throw typeof t!="number"&&typeof t!="bigint"?TypeError("sleep: ms must be a number"):RangeError("sleep: ms must be a number that is greater than 0 but less than Infinity");Atomics.wait(n,0,0,Number(t))},n=new Int32Array(new SharedArrayBuffer(4));nl.exports=e}else{let n=function(e){if((e>0&&e<1/0)===!1)throw typeof e!="number"&&typeof e!="bigint"?TypeError("sleep: ms must be a number"):RangeError("sleep: ms must be a number that is greater than 0 but less than Infinity");let s=Date.now()+Number(e);for(;s>Date.now(););};nl.exports=n}});var Fh=N((uR,Lh)=>{"use strict";var fe=require("fs"),$_=require("events"),C_=require("util").inherits,Rh=require("path"),il=sl(),T_=require("assert"),Tr=100,Er=Buffer.allocUnsafe(0),E_=16*1024,Ph="buffer",Oh="utf8",[R_,P_]=(process.versions.node||"0.0").split(".").map(Number),O_=R_>=22&&P_>=7;function Mh(n,e){e._opening=!0,e._writing=!0,e._asyncDrainScheduled=!1;function t(i,o){if(i){e._reopening=!1,e._writing=!1,e._opening=!1,e.sync?process.nextTick(()=>{e.listenerCount("error")>0&&e.emit("error",i)}):e.emit("error",i);return}let a=e._reopening;e.fd=o,e.file=n,e._reopening=!1,e._opening=!1,e._writing=!1,e.sync?process.nextTick(()=>e.emit("ready")):e.emit("ready"),!e.destroyed&&(!e._writing&&e._len>e.minLength||e._flushPending?e._actualWrite():a&&process.nextTick(()=>e.emit("drain")))}let s=e.append?"a":"w",r=e.mode;if(e.sync)try{e.mkdir&&fe.mkdirSync(Rh.dirname(n),{recursive:!0});let i=fe.openSync(n,s,r);t(null,i)}catch(i){throw t(i),i}else e.mkdir?fe.mkdir(Rh.dirname(n),{recursive:!0},i=>{if(i)return t(i);fe.open(n,s,r,t)}):fe.open(n,s,r,t)}function ot(n){if(!(this instanceof ot))return new ot(n);let{fd:e,dest:t,minLength:s,maxLength:r,maxWrite:i,periodicFlush:o,sync:a,append:l=!0,mkdir:u,retryEAGAIN:d,fsync:f,contentMode:h,mode:m}=n||{};e=e||t,this._len=0,this.fd=-1,this._bufs=[],this._lens=[],this._writing=!1,this._ending=!1,this._reopening=!1,this._asyncDrainScheduled=!1,this._flushPending=!1,this._hwm=Math.max(s||0,16387),this.file=null,this.destroyed=!1,this.minLength=s||0,this.maxLength=r||0,this.maxWrite=i||E_,this._periodicFlush=o||0,this._periodicFlushTimer=void 0,this.sync=a||!1,this.writable=!0,this._fsync=f||!1,this.append=l||!1,this.mode=m,this.retryEAGAIN=d||(()=>!0),this.mkdir=u||!1;let p,g;if(h===Ph)this._writingBuf=Er,this.write=D_,this.flush=F_,this.flushSync=j_,this._actualWrite=B_,p=()=>fe.writeSync(this.fd,this._writingBuf),g=()=>fe.write(this.fd,this._writingBuf,this.release);else if(h===void 0||h===Oh)this._writingBuf="",this.write=I_,this.flush=L_,this.flushSync=N_,this._actualWrite=H_,p=()=>Buffer.isBuffer(this._writingBuf)?fe.writeSync(this.fd,this._writingBuf):fe.writeSync(this.fd,this._writingBuf,"utf8"),g=()=>Buffer.isBuffer(this._writingBuf)?fe.write(this.fd,this._writingBuf,this.release):fe.write(this.fd,this._writingBuf,"utf8",this.release);else throw new Error(`SonicBoom supports "${Oh}" and "${Ph}", but passed ${h}`);if(typeof e=="number")this.fd=e,process.nextTick(()=>this.emit("ready"));else if(typeof e=="string")Mh(e,this);else throw new Error("SonicBoom supports only file descriptors and files");if(this.minLength>=this.maxWrite)throw new Error(`minLength should be smaller than maxWrite (${this.maxWrite})`);this.release=(w,_)=>{if(w){if((w.code==="EAGAIN"||w.code==="EBUSY")&&this.retryEAGAIN(w,this._writingBuf.length,this._len-this._writingBuf.length))if(this.sync)try{il(Tr),this.release(void 0,0)}catch(y){this.release(y)}else setTimeout(g,Tr);else this._writing=!1,this.emit("error",w);return}this.emit("write",_);let k=rl(this._writingBuf,this._len,_);if(this._len=k.len,this._writingBuf=k.writingBuf,this._writingBuf.length){if(!this.sync){g();return}try{do{let y=p(),v=rl(this._writingBuf,this._len,y);this._len=v.len,this._writingBuf=v.writingBuf}while(this._writingBuf.length)}catch(y){this.release(y);return}}this._fsync&&fe.fsyncSync(this.fd);let A=this._len;this._reopening?(this._writing=!1,this._reopening=!1,this.reopen()):A>this.minLength?this._actualWrite():this._ending?A>0?this._actualWrite():(this._writing=!1,Rr(this)):(this._writing=!1,this.sync?this._asyncDrainScheduled||(this._asyncDrainScheduled=!0,process.nextTick(M_,this)):this.emit("drain"))},this.on("newListener",function(w){w==="drain"&&(this._asyncDrainScheduled=!1)}),this._periodicFlush!==0&&(this._periodicFlushTimer=setInterval(()=>this.flush(null),this._periodicFlush),this._periodicFlushTimer.unref())}function rl(n,e,t){return typeof n=="string"&&(n=Buffer.from(n)),e=Math.max(e-t,0),n=n.subarray(t),{writingBuf:n,len:e}}function M_(n){n.listenerCount("drain")>0&&(n._asyncDrainScheduled=!1,n.emit("drain"))}C_(ot,$_);function Ih(n,e){return n.length===0?Er:n.length===1?n[0]:Buffer.concat(n,e)}function I_(n){if(this.destroyed)throw new Error("SonicBoom destroyed");n=""+n;let e=Buffer.byteLength(n),t=this._len+e,s=this._bufs;return this.maxLength&&t>this.maxLength?(this.emit("drop",n),this._len<this._hwm):(s.length===0||Buffer.byteLength(s[s.length-1])+e>this.maxWrite?s.push(n):s[s.length-1]+=n,this._len=t,!this._writing&&this._len>=this.minLength&&this._actualWrite(),this._len<this._hwm)}function D_(n){if(this.destroyed)throw new Error("SonicBoom destroyed");let e=this._len+n.length,t=this._bufs,s=this._lens;return this.maxLength&&e>this.maxLength?(this.emit("drop",n),this._len<this._hwm):(t.length===0||s[s.length-1]+n.length>this.maxWrite?(t.push([n]),s.push(n.length)):(t[t.length-1].push(n),s[s.length-1]+=n.length),this._len=e,!this._writing&&this._len>=this.minLength&&this._actualWrite(),this._len<this._hwm)}function Dh(n){this._flushPending=!0;let e=()=>{if(this._fsync)this._flushPending=!1,n();else try{fe.fsync(this.fd,s=>{this._flushPending=!1,n(s)})}catch(s){n(s)}this.off("error",t)},t=s=>{this._flushPending=!1,n(s),this.off("drain",e)};this.once("drain",e),this.once("error",t)}function L_(n){if(n!=null&&typeof n!="function")throw new Error("flush cb must be a function");if(this.destroyed){let e=new Error("SonicBoom destroyed");if(n){n(e);return}throw e}if(this.minLength<=0){n?.();return}n&&Dh.call(this,n),!this._writing&&(this._bufs.length===0&&this._bufs.push(""),this._actualWrite())}function F_(n){if(n!=null&&typeof n!="function")throw new Error("flush cb must be a function");if(this.destroyed){let e=new Error("SonicBoom destroyed");if(n){n(e);return}throw e}if(this.minLength<=0){n?.();return}n&&Dh.call(this,n),!this._writing&&(this._bufs.length===0&&(this._bufs.push([]),this._lens.push(0)),this._actualWrite())}ot.prototype.reopen=function(n){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this._opening){this.once("ready",()=>{this.reopen(n)});return}if(this._ending)return;if(!this.file)throw new Error("Unable to reopen a file descriptor, you must pass a file to SonicBoom");if(n&&(this.file=n),this._reopening=!0,this._writing)return;let e=this.fd;this.once("ready",()=>{e!==this.fd&&fe.close(e,t=>{if(t)return this.emit("error",t)})}),Mh(this.file,this)};ot.prototype.end=function(){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this._opening){this.once("ready",()=>{this.end()});return}this._ending||(this._ending=!0,!this._writing&&(this._len>0&&this.fd>=0?this._actualWrite():Rr(this)))};function N_(){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this.fd<0)throw new Error("sonic boom is not ready yet");!this._writing&&this._writingBuf.length>0&&(this._bufs.unshift(this._writingBuf),this._writingBuf="");let n="";for(;this._bufs.length||n.length;){n.length<=0&&(n=this._bufs[0]);try{let e=Buffer.isBuffer(n)?fe.writeSync(this.fd,n):fe.writeSync(this.fd,n,"utf8"),t=rl(n,this._len,e);n=t.writingBuf,this._len=t.len,n.length<=0&&this._bufs.shift()}catch(e){if((e.code==="EAGAIN"||e.code==="EBUSY")&&!this.retryEAGAIN(e,n.length,this._len-n.length))throw e;il(Tr)}}try{fe.fsyncSync(this.fd)}catch{}}function j_(){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this.fd<0)throw new Error("sonic boom is not ready yet");!this._writing&&this._writingBuf.length>0&&(this._bufs.unshift([this._writingBuf]),this._writingBuf=Er);let n=Er;for(;this._bufs.length||n.length;){n.length<=0&&(n=Ih(this._bufs[0],this._lens[0]));try{let e=fe.writeSync(this.fd,n);n=n.subarray(e),this._len=Math.max(this._len-e,0),n.length<=0&&(this._bufs.shift(),this._lens.shift())}catch(e){if((e.code==="EAGAIN"||e.code==="EBUSY")&&!this.retryEAGAIN(e,n.length,this._len-n.length))throw e;il(Tr)}}}ot.prototype.destroy=function(){this.destroyed||Rr(this)};function H_(){let n=this.release;if(this._writing=!0,this._writingBuf=this._writingBuf.length?this._writingBuf:this._bufs.shift()||"",this.sync)try{let e=Buffer.isBuffer(this._writingBuf)?fe.writeSync(this.fd,this._writingBuf):fe.writeSync(this.fd,this._writingBuf,"utf8");n(null,e)}catch(e){n(e)}else fe.write(this.fd,this._writingBuf,n)}function B_(){let n=this.release;if(this._writing=!0,this._writingBuf=this._writingBuf.length?this._writingBuf:Ih(this._bufs.shift(),this._lens.shift()),this.sync)try{let e=fe.writeSync(this.fd,this._writingBuf);n(null,e)}catch(e){n(e)}else O_&&(this._writingBuf=Buffer.from(this._writingBuf)),fe.write(this.fd,this._writingBuf,n)}function Rr(n){if(n.fd===-1){n.once("ready",Rr.bind(null,n));return}n._periodicFlushTimer!==void 0&&clearInterval(n._periodicFlushTimer),n.destroyed=!0,n._bufs=[],n._lens=[],T_(typeof n.fd=="number",`sonic.fd must be a number, got ${typeof n.fd}`);try{fe.fsync(n.fd,e)}catch{}function e(){n.fd!==1&&n.fd!==2?fe.close(n.fd,t):t()}function t(s){if(s){n.emit("error",s);return}n._ending&&!n._writing&&n.emit("finish"),n.emit("close")}}ot.SonicBoom=ot;ot.default=ot;Lh.exports=ot});var ol=N((dR,Uh)=>{"use strict";var at={exit:[],beforeExit:[]},Nh={exit:K_,beforeExit:W_},In;function U_(){In===void 0&&(In=new FinalizationRegistry(G_))}function q_(n){at[n].length>0||process.on(n,Nh[n])}function jh(n){at[n].length>0||(process.removeListener(n,Nh[n]),at.exit.length===0&&at.beforeExit.length===0&&(In=void 0))}function K_(){Hh("exit")}function W_(){Hh("beforeExit")}function Hh(n){for(let e of at[n]){let t=e.deref(),s=e.fn;t!==void 0&&s(t,n)}at[n]=[]}function G_(n){for(let e of["exit","beforeExit"]){let t=at[e].indexOf(n);at[e].splice(t,t+1),jh(e)}}function Bh(n,e,t){if(e===void 0)throw new Error("the object can't be undefined");q_(n);let s=new WeakRef(e);s.fn=t,U_(),In.register(e,s),at[n].push(s)}function V_(n,e){Bh("exit",n,e)}function z_(n,e){Bh("beforeExit",n,e)}function Y_(n){if(In!==void 0){In.unregister(n);for(let e of["exit","beforeExit"])at[e]=at[e].filter(t=>{let s=t.deref();return s&&s!==n}),jh(e)}}Uh.exports={register:V_,registerBeforeExit:z_,unregister:Y_}});var qh=N((fR,J_)=>{J_.exports={name:"thread-stream",version:"4.2.0",description:"A streaming way to send data to a Node.js Worker Thread",main:"index.js",types:"index.d.ts",engines:{node:">=20"},dependencies:{"real-require":"^1.0.0"},devDependencies:{"@types/node":"^25.0.2","@yao-pkg/pkg":"^6.0.0",borp:"^1.0.0",desm:"^1.3.0",eslint:"^9.39.1",fastbench:"^1.0.1",neostandard:"^0.13.0","pino-elasticsearch":"^9.0.0","sonic-boom":"^5.0.0","ts-node":"^10.8.0",typescript:"~5.7.3"},scripts:{build:"tsc --noEmit",lint:"eslint",test:'npm run lint && npm run build && npm run transpile && borp --pattern "test/*.test.{js,mjs}"',"test:ci":'npm run lint && npm run transpile && borp --pattern "test/*.test.{js,mjs}"',"test:yarn":'npm run transpile && borp --pattern "test/*.test.js"',transpile:"sh ./test/ts/transpile.sh"},repository:{type:"git",url:"git+https://github.com/mcollina/thread-stream.git"},keywords:["worker","thread","threads","stream"],author:"Matteo Collina <hello@matteocollina.com>",license:"MIT",bugs:{url:"https://github.com/mcollina/thread-stream/issues"},homepage:"https://github.com/mcollina/thread-stream#readme"}});var Wh=N((pR,Kh)=>{"use strict";function X_(n,e,t,s,r){let i=s===1/0?1/0:Date.now()+s,o=()=>{let a=Atomics.load(n,e);if(a===t){r(null,"ok");return}if(i!==1/0&&Date.now()>i){r(null,"timed-out");return}let l=i===1/0?1e4:Math.min(1e4,Math.max(1,i-Date.now())),u=Atomics.waitAsync(n,e,a,l);u.async?u.value.then(o):setImmediate(o)};o()}function Q_(n,e,t,s,r){let i=s===1/0?1/0:Date.now()+s,o=()=>{if(Atomics.load(n,e)!==t){r(null,"ok");return}if(i!==1/0&&Date.now()>i){r(null,"timed-out");return}let l=i===1/0?1e4:Math.min(1e4,Math.max(1,i-Date.now())),u=Atomics.waitAsync(n,e,t,l);u.async?u.value.then(d=>{if(d==="ok"){r(null,"ok");return}o()}):setImmediate(o)};o()}Kh.exports={wait:X_,waitDiff:Q_}});var Vh=N((hR,Gh)=>{"use strict";Gh.exports={WRITE_INDEX:4,READ_INDEX:8,SEQ_INDEX:2}});var im=N((mR,rm)=>{"use strict";var{version:Z_}=qh(),{EventEmitter:ek}=require("events"),{Worker:tk}=require("worker_threads"),{join:nk}=require("path"),{pathToFileURL:sk}=require("url"),{wait:rk}=Wh(),{WRITE_INDEX:Ot,READ_INDEX:cn,SEQ_INDEX:al}=Vh(),ik=require("buffer"),ok=require("assert"),R=Symbol("kImpl"),ak=ik.constants.MAX_STRING_LENGTH;function zh(){}function dl(n,e){Atomics.add(n[R].state,al,1),e(),Atomics.add(n[R].state,al,1),Atomics.notify(n[R].state,al)}function Yh(n){dl(n,()=>{Atomics.store(n[R].state,cn,0),Atomics.store(n[R].state,Ot,0)})}var ys=class{constructor(e){this._value=e}deref(){return this._value}},Pr=class{register(){}unregister(){}},lk=process.env.NODE_V8_COVERAGE?Pr:global.FinalizationRegistry||Pr,ck=process.env.NODE_V8_COVERAGE?ys:global.WeakRef||ys,Jh=new lk(n=>{n.exited||n.terminate()});function uk(n,e){let{filename:t,workerData:s}=e,i=("__bundlerPathsOverrides"in globalThis?globalThis.__bundlerPathsOverrides:{})["thread-stream-worker"]||nk(__dirname,"lib","worker.js"),o=new tk(i,{...e.workerOpts,name:e.workerOpts?.name||"thread-stream",trackUnmanagedFds:!1,workerData:{filename:t.indexOf("file://")===0?t:sk(t).href,dataBuf:n[R].dataBuf,stateBuf:n[R].stateBuf,workerData:{$context:{threadStreamVersion:Z_},...s}}});return o.stream=new ys(n),o.on("message",dk),o.on("exit",Zh),Jh.register(n,o),o}function Xh(n){ok(!n[R].sync),n[R].needDrain&&(n[R].needDrain=!1,n.emit("drain"))}function Qh(n){for(;;){let e=Atomics.load(n[R].state,Ot),t=n[R].data.length-e;if(t>0){if(n[R].bufLen===0){n[R].flushing=!1,n[R].ending?fl(n):n[R].needDrain&&process.nextTick(Xh,n);return}nm(n,t,zh);continue}if(t===0){if(e===0&&n[R].bufLen===0)return;Or(n,()=>{n.destroyed||(Yh(n),Qh(n))});return}Ze(n,new Error("overwritten"));return}}function dk(n){let e=this.stream.deref();if(e===void 0){this.exited=!0,this.terminate();return}if(n?.code!=null)switch(n.code){case"READY":this.stream=new ck(e),Or(e,()=>{e[R].ready=!0,e.emit("ready")});break;case"ERROR":Ze(e,n.err);break;case"EVENT":Array.isArray(n.args)?e.emit(n.name,...n.args):e.emit(n.name,n.args);break;case"FLUSHED":{if(n.context!=="thread-stream"){Ze(e,new Error("this should not happen: "+n.code));break}let t=e[R].flushCallbacks.get(n.id);t&&(e[R].flushCallbacks.delete(n.id),process.nextTick(t));break}case"WARNING":process.emitWarning(n.err);break;default:Ze(e,new Error("this should not happen: "+n.code))}}function Zh(n){let e=this.stream.deref();e!==void 0&&(Jh.unregister(e),e.worker.exited=!0,e.worker.off("exit",Zh),Ze(e,n!==0?new Error("the worker thread exited"):null))}var cl=class extends ek{constructor(e={}){if(super(),e.bufferSize<4)throw new Error("bufferSize must at least fit a 4-byte utf-8 char");this[R]={},this[R].stateBuf=new SharedArrayBuffer(128),this[R].state=new Int32Array(this[R].stateBuf),this[R].dataBuf=new SharedArrayBuffer(e.bufferSize||4*1024*1024),this[R].data=Buffer.from(this[R].dataBuf),this[R].sync=e.sync||!1,this[R].ending=!1,this[R].ended=!1,this[R].needDrain=!1,this[R].destroyed=!1,this[R].flushing=!1,this[R].ready=!1,this[R].finished=!1,this[R].errored=null,this[R].closed=!1,this[R].buf=[],this[R].bufHead=0,this[R].bufLen=0,this[R].flushCallbacks=new Map,this[R].nextFlushId=0,this.worker=uk(this,e),this.on("message",(t,s)=>{this.worker.postMessage(t,s)})}write(e){let t=Buffer.isBuffer(e)?e:Buffer.from(e);if(this[R].destroyed)return ul(this,new Error("the worker has exited")),!1;if(this[R].ending)return ul(this,new Error("the worker is ending")),!1;if(this[R].flushing&&this[R].bufLen+t.length>=ak)try{ll(this),this[R].flushing=!0}catch(s){return Ze(this,s),!1}if(this[R].buf.push(t),this[R].bufLen+=t.length,this[R].sync)try{return ll(this),!0}catch(s){return Ze(this,s),!1}return this[R].flushing||(this[R].flushing=!0,setImmediate(Qh,this)),this[R].needDrain=this[R].data.length-this[R].bufLen-Atomics.load(this[R].state,Ot)<=0,!this[R].needDrain}end(){this[R].destroyed||(this[R].ending=!0,fl(this))}flush(e){e=typeof e=="function"?e:zh,em(this,t=>{if(t){process.nextTick(e,t);return}tm(this,e)})}flushSync(){this[R].destroyed||(ll(this),sm(this))}unref(){this.worker.unref()}ref(){this.worker.ref()}get ready(){return this[R].ready}get destroyed(){return this[R].destroyed}get closed(){return this[R].closed}get writable(){return!this[R].destroyed&&!this[R].ending}get writableEnded(){return this[R].ending}get writableFinished(){return this[R].finished}get writableNeedDrain(){return this[R].needDrain}get writableObjectMode(){return!1}get writableErrored(){return this[R].errored}};function em(n,e){if(n[R].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[R].sync&&(n[R].flushing||n[R].bufLen>0)){setImmediate(em,n,e);return}Or(n,e)}function Or(n,e){let t=Atomics.load(n[R].state,Ot);rk(n[R].state,cn,t,1/0,(s,r)=>{if(s){Ze(n,s),e(s);return}if(r!=="ok"){Or(n,e);return}e()})}function tm(n,e){if(n[R].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[R].ready){let s=()=>{i(),tm(n,e)},r=()=>{i(),process.nextTick(e,new Error("the worker has exited"))},i=()=>{n.off("ready",s),n.off("close",r)};n.once("ready",s),n.once("close",r);return}let t=++n[R].nextFlushId;n[R].flushCallbacks.set(t,e);try{n.worker.postMessage({code:"FLUSH",context:"thread-stream",id:t})}catch(s){n[R].flushCallbacks.delete(t),Ze(n,s),process.nextTick(e,s)}}function fk(n,e){let t=n[R].flushCallbacks;if(t.size===0)return;let s=e||new Error("the worker has exited");for(let r of t.values())process.nextTick(r,s);t.clear()}function ul(n,e){setImmediate(()=>{n.emit("error",e)})}function Ze(n,e){n[R].destroyed||(n[R].destroyed=!0,fk(n,e),e&&(n[R].errored=e,ul(n,e)),n.worker.exited?setImmediate(()=>{n[R].closed=!0,n.emit("close")}):n.worker.terminate().catch(()=>{}).then(()=>{n[R].closed=!0,n.emit("close")}))}function nm(n,e,t){let r=Atomics.load(n[R].state,Ot),i=e;for(;i>0&&n[R].bufLen!==0;){let o=n[R].bufHead,a=n[R].buf[o];if(a.length<=i){a.copy(n[R].data,r),r+=a.length,i-=a.length,n[R].bufLen-=a.length,n[R].bufHead=o+1,n[R].bufHead===n[R].buf.length?(n[R].buf.length=0,n[R].bufHead=0):n[R].bufHead>=1024&&n[R].bufHead*2>=n[R].buf.length&&(n[R].buf.splice(0,n[R].bufHead),n[R].bufHead=0);continue}a.copy(n[R].data,r,0,i),n[R].buf[o]=a.subarray(i),n[R].bufLen-=i,r+=i,i=0}return dl(n,()=>{Atomics.store(n[R].state,Ot,r)}),t(),!0}function fl(n){if(!(n[R].ended||!n[R].ending||n[R].flushing)){n[R].ended=!0;try{n.flushSync();let e=Atomics.load(n[R].state,cn);dl(n,()=>{Atomics.store(n[R].state,Ot,-1)});let t=0;for(;e!==-1;){if(Atomics.wait(n[R].state,cn,e,1e3),e=Atomics.load(n[R].state,cn),e===-2){Ze(n,new Error("end() failed"));return}if(++t===10){Ze(n,new Error("end() took too long (10s)"));return}}process.nextTick(()=>{n[R].finished=!0,n.emit("finish")})}catch(e){Ze(n,e)}}}function ll(n){let e=()=>{n[R].ending?fl(n):n[R].needDrain&&process.nextTick(Xh,n)};for(n[R].flushing=!1;n[R].bufLen!==0;){let t=Atomics.load(n[R].state,Ot),s=n[R].data.length-t;if(s===0){sm(n),Yh(n);continue}else if(s<0)throw new Error("overwritten");nm(n,s,e)}}function sm(n){if(n[R].flushing)throw new Error("unable to flush while flushing");let e=Atomics.load(n[R].state,Ot),t=0;for(;;){let s=Atomics.load(n[R].state,cn);if(s===-2)throw Error("_flushSync failed");if(s!==e)Atomics.wait(n[R].state,cn,s,1e3);else break;if(++t===10)throw new Error("_flushSync took too long (10s)")}}rm.exports=cl});var ml=N((gR,lm)=>{"use strict";var{createRequire:pk}=require("module"),{existsSync:hk}=require("node:fs"),mk=Qa(),{join:pl,isAbsolute:am,sep:gk}=require("node:path"),{fileURLToPath:yk}=require("node:url"),bk=sl(),hl=ol(),vk=im();function wk(n){hl.register(n,Ak),hl.registerBeforeExit(n,$k),n.on("close",function(){hl.unregister(n)})}function xk(){let n=process.execArgv;for(let e=0;e<n.length;e++){let t=n[e];if(t==="--import"||t==="--require"||t==="-r"||t.startsWith("--import=")||t.startsWith("--require=")||t.startsWith("-r="))return!0}return!1}function Sk(n){let e=n.match(/(?:[^\s"']+|"[^"]*"|'[^']*')+/g);if(!e)return n;let t=[],s=!1;for(let r=0;r<e.length;r++){let i=e[r];if(i==="--require"||i==="-r"||i==="--import"){let o=e[r+1];if(o&&om(o)){s=!0,r++;continue}t.push(i),o&&(t.push(o),r++);continue}if(i.startsWith("--require=")||i.startsWith("-r=")||i.startsWith("--import=")){let o=i.slice(i.indexOf("=")+1);if(om(o)){s=!0;continue}}t.push(i)}return s?t.join(" "):n}function om(n){let e=_k(n);if(!e)return!1;let t=e;if(t.startsWith("file://"))try{t=yk(t)}catch{return!1}return am(t)&&!hk(t)}function _k(n){let e=n[0],t=n[n.length-1];return e==='"'&&t==='"'||e==="'"&&t==="'"?n.slice(1,-1):n}function kk(n,e,t,s,r){if(!t.execArgv&&xk()&&require.main===void 0&&(t={...t,execArgv:[]}),!t.env&&process.env.NODE_OPTIONS){let l=Sk(process.env.NODE_OPTIONS);l!==process.env.NODE_OPTIONS&&(t={...t,env:{...process.env,NODE_OPTIONS:l}})}t={...t,name:r};let i=new vk({filename:n,workerData:e,workerOpts:t,sync:s});i.on("ready",o),i.on("close",function(){process.removeListener("exit",a)}),process.on("exit",a);function o(){process.removeListener("exit",a),i.unref(),t.autoEnd!==!1&&wk(i)}function a(){i.closed||(i.flushSync(),bk(100),i.end())}return i}function Ak(n){n.ref(),n.flushSync(),n.end(),n.once("close",function(){n.unref()})}function $k(n){n.flushSync()}function Ck(n){let{pipeline:e,targets:t,levels:s,dedupe:r,worker:i={},caller:o=mk(),sync:a=!1}=n,l={...n.options},u=typeof o=="string"?[o]:o,d=typeof globalThis=="object"&&Object.prototype.hasOwnProperty.call(globalThis,"__bundlerPathsOverrides")&&globalThis.__bundlerPathsOverrides&&typeof globalThis.__bundlerPathsOverrides=="object"?globalThis.__bundlerPathsOverrides:Object.create(null),f=n.target;if(f&&t)throw new Error("only one of target or targets can be specified");t?(f=d["pino-worker"]||pl(__dirname,"worker.js"),l.targets=t.filter(p=>p.target).map(p=>({...p,target:m(p.target)})),l.pipelines=t.filter(p=>p.pipeline).map(p=>p.pipeline.map(g=>({...g,level:p.level,target:m(g.target)})))):e&&(f=d["pino-worker"]||pl(__dirname,"worker.js"),l.pipelines=[e.map(p=>({...p,target:m(p.target)}))]),s&&(l.levels=s),r&&(l.dedupe=r),l.pinoWillSendConfig=!0;let h=t||e?"pino.transport":f;return kk(m(f),l,i,a,h);function m(p){if(p=d[p]||p,am(p)||p.indexOf("file://")===0)return p;if(p==="pino/file")return pl(__dirname,"..","file.js");let g;for(let w of u)try{let _=w==="node:repl"?process.cwd()+gk:w;g=pk(_).resolve(p);break}catch{continue}if(!g)throw new Error(`unable to determine transport target for "${p}"`);return g}}lm.exports=Ck});var Dr=N((yR,xm)=>{"use strict";var Tk=require("node:diagnostics_channel"),cm=Eh(),{mapHttpRequest:Ek,mapHttpResponse:Rk}=Xa(),yl=Fh(),um=ol(),{lsCacheSym:Pk,chindingsSym:mm,writeSym:dm,serializersSym:gm,formatOptsSym:fm,endSym:Ok,stringifiersSym:ym,stringifySym:bm,stringifySafeSym:bl,wildcardFirstSym:vm,nestedKeySym:Mk,formattersSym:wm,messageKeySym:Ik,errorKeySym:Dk,nestedKeyStrSym:Lk,msgPrefixSym:Mr}=Mn(),{isMainThread:Fk}=require("worker_threads"),Nk=ml(),[jk]=process.versions.node.split(".").map(n=>Number(n)),pm=Tk.tracingChannel("pino_asJson"),gl=jk>=25?n=>JSON.stringify(n):Bk;function Dn(){}function Hk(n,e){if(!e)return t;return function(...r){e.call(this,r,t,n)};function t(s,...r){if(typeof s=="object"){let i=s;s!==null&&(s.method&&s.headers&&s.socket?s=Ek(s):typeof s.setHeader=="function"&&(s=Rk(s)));let o;i===null&&r.length===0?o=[null]:(i=r.shift(),o=r),typeof this[Mr]=="string"&&i!==void 0&&i!==null&&(i=this[Mr]+i),this[dm](s,cm(i,o,this[fm]),n)}else{let i=s===void 0?r.shift():s;typeof this[Mr]=="string"&&i!==void 0&&i!==null&&(i=this[Mr]+i),this[dm](null,cm(i,r,this[fm]),n)}}}function Bk(n){let e="",t=0,s=!1,r=255,i=n.length;if(i>100)return JSON.stringify(n);for(var o=0;o<i&&r>=32;o++)r=n.charCodeAt(o),(r===34||r===92)&&(e+=n.slice(t,o)+"\\",t=o,s=!0);return s?e+=n.slice(t):e=n,r<32?JSON.stringify(n):'"'+e+'"'}function Uk(n,e,t,s){if(pm.hasSubscribers===!1)return hm.call(this,n,e,t,s);let r={instance:this,arguments};return pm.traceSync(hm,r,this,n,e,t,s)}function hm(n,e,t,s){let r=this[bm],i=this[bl],o=this[ym],a=this[Ok],l=this[mm],u=this[gm],d=this[wm],f=this[Ik],h=this[Dk],m=this[Pk][t]+s;m=m+l;let p;d.log&&(n=d.log(n));let g=o[vm],w="";for(let k in n)if(p=n[k],Object.prototype.hasOwnProperty.call(n,k)&&p!==void 0){u[k]?p=u[k](p):k===h&&u.err&&(p=u.err(p));let A=o[k]||g;switch(typeof p){case"undefined":case"function":continue;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":A&&(p=A(p));break;case"string":p=(A||gl)(p);break;default:p=(A||r)(p,i)}if(p===void 0)continue;let y=gl(k);w+=","+y+":"+p}let _="";if(e!==void 0){p=u[f]?u[f](e):e;let k=o[f]||g;switch(typeof p){case"function":break;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":k&&(p=k(p)),_=',"'+f+'":'+p;break;case"string":p=(k||gl)(p),_=',"'+f+'":'+p;break;default:p=(k||r)(p,i),_=',"'+f+'":'+p}}return this[Mk]&&w?m+this[Lk]+w.slice(1)+"}"+_+a:m+w+_+a}function qk(n,e){let t,s=n[mm],r=n[bm],i=n[bl],o=n[ym],a=o[vm],l=n[gm],u=n[wm].bindings;e=u(e);for(let d in e)if(t=e[d],((d.length<5||d!=="level"&&d!=="serializers"&&d!=="formatters"&&d!=="customLevels")&&e.hasOwnProperty(d)&&t!==void 0)===!0){if(t=l[d]?l[d](t):t,t=(o[d]||a||r)(t,i),t===void 0)continue;s+=',"'+d+'":'+t}return s}function Kk(n){return n.write!==n.constructor.prototype.write}function Ir(n){let e=new yl(n);return e.on("error",t),!n.sync&&Fk&&(um.register(e,Wk),e.on("close",function(){um.unregister(e)})),e;function t(s){if(s.code==="EPIPE"){e.write=Dn,e.end=Dn,e.flushSync=Dn,e.destroy=Dn;return}e.removeListener("error",t),e.emit("error",s)}}function Wk(n,e){n.destroyed||(e==="beforeExit"?(n.flush(),n.on("drain",function(){n.end()})):n.flushSync())}function Gk(n){return function(t,s,r={},i){if(typeof r=="string")i=Ir({dest:r}),r={};else if(typeof i=="string"){if(r&&r.transport)throw Error("only one of option.transport or stream can be specified");i=Ir({dest:i})}else if(r instanceof yl||r.writable||r._writableState)i=r,r={};else if(r.transport){if(r.transport instanceof yl||r.transport.writable||r.transport._writableState)throw Error("option.transport do not allow stream, please pass to option directly. e.g. pino(transport)");if(r.transport.targets&&r.transport.targets.length&&r.formatters&&typeof r.formatters.level=="function")throw Error("option.transport.targets do not allow custom level formatters");let l;r.customLevels&&(l=r.useOnlyCustomLevels?r.customLevels:Object.assign({},r.levels,r.customLevels)),i=Nk({caller:s,...r.transport,levels:l})}if(r=Object.assign({},n,r),r.serializers=Object.assign({},n.serializers,r.serializers),r.formatters=Object.assign({},n.formatters,r.formatters),r.prettyPrint)throw new Error("prettyPrint option is no longer supported, see the pino-pretty package (https://github.com/pinojs/pino-pretty)");let{enabled:o,onChild:a}=r;return o===!1&&(r.level="silent"),a||(r.onChild=Dn),i||(Kk(process.stdout)?i=process.stdout:i=Ir({fd:process.stdout.fd||1})),{opts:r,stream:i}}}function Vk(n,e){try{return JSON.stringify(n)}catch{try{return(e||this[bl])(n)}catch{return'"[unable to serialize, circular reference is too complex to analyze]"'}}}function zk(n,e,t){return{level:n,bindings:e,log:t}}function Yk(n){let e=Number(n);return typeof n=="string"&&Number.isFinite(e)?e:n===void 0?1:n}xm.exports={noop:Dn,buildSafeSonicBoom:Ir,asChindings:qk,asJson:Uk,genLog:Hk,createArgsNormalizer:Gk,stringify:Vk,buildFormatters:zk,normalizeDestFileDescriptor:Yk}});var Lr=N((bR,Sm)=>{var Jk={trace:10,debug:20,info:30,warn:40,error:50,fatal:60},Xk={ASC:"ASC",DESC:"DESC"};Sm.exports={DEFAULT_LEVELS:Jk,SORTING_ORDER:Xk}});var xl=N((vR,$m)=>{"use strict";var{lsCacheSym:Qk,levelValSym:vl,useOnlyCustomLevelsSym:Zk,streamSym:eA,formattersSym:tA,hooksSym:nA,levelCompSym:_m}=Mn(),{noop:sA,genLog:un}=Dr(),{DEFAULT_LEVELS:gt,SORTING_ORDER:km}=Lr(),Am={fatal:n=>{let e=un(gt.fatal,n);return function(...t){let s=this[eA];if(e.call(this,...t),typeof s.flushSync=="function")try{s.flushSync()}catch{}}},error:n=>un(gt.error,n),warn:n=>un(gt.warn,n),info:n=>un(gt.info,n),debug:n=>un(gt.debug,n),trace:n=>un(gt.trace,n)},wl=Object.keys(gt).reduce((n,e)=>(n[gt[e]]=e,n),{}),rA=Object.keys(wl).reduce((n,e)=>(n[e]='{"level":'+Number(e),n),{});function iA(n){let e=n[tA].level,{labels:t}=n.levels,s={};for(let r in t){let i=e(t[r],Number(r));s[r]=JSON.stringify(i).slice(0,-1)}return n[Qk]=s,n}function oA(n,e){if(e)return!1;switch(n){case"fatal":case"error":case"warn":case"info":case"debug":case"trace":return!0;default:return!1}}function aA(n){let{labels:e,values:t}=this.levels;if(typeof n=="number"){if(e[n]===void 0)throw Error("unknown level value"+n);n=e[n]}if(t[n]===void 0)throw Error("unknown level "+n);let s=this[vl],r=this[vl]=t[n],i=this[Zk],o=this[_m],a=this[nA].logMethod;for(let l in t){if(o(t[l],r)===!1){this[l]=sA;continue}this[l]=oA(l,i)?Am[l](a):un(t[l],a)}this.emit("level-change",n,r,e[s],s,this)}function lA(n){let{levels:e,levelVal:t}=this;return e&&e.labels?e.labels[t]:""}function cA(n){let{values:e}=this.levels,t=e[n];return t!==void 0&&this[_m](t,this[vl])}function uA(n,e,t){return n===km.DESC?e<=t:e>=t}function dA(n){return typeof n=="string"?uA.bind(null,n):n}function fA(n=null,e=!1){let t=n?Object.keys(n).reduce((i,o)=>(i[n[o]]=o,i),{}):null,s=Object.assign(Object.create(Object.prototype,{Infinity:{value:"silent"}}),e?null:wl,t),r=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),e?null:gt,n);return{labels:s,values:r}}function pA(n,e,t){if(typeof n=="number"){if(![].concat(Object.keys(e||{}).map(i=>e[i]),t?[]:Object.keys(wl).map(i=>+i),1/0).includes(n))throw Error(`default level:${n} must be included in custom levels`);return}let s=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),t?null:gt,e);if(!(n in s))throw Error(`default level:${n} must be included in custom levels`)}function hA(n,e){let{labels:t,values:s}=n;for(let r in e){if(r in s)throw Error("levels cannot be overridden");if(e[r]in t)throw Error("pre-existing level values cannot be used for new levels")}}function mA(n){if(typeof n!="function"&&!(typeof n=="string"&&Object.values(km).includes(n)))throw new Error('Levels comparison should be one of "ASC", "DESC" or "function" type')}$m.exports={initialLsCache:rA,genLsCache:iA,levelMethods:Am,getLevel:lA,setLevel:aA,isLevelEnabled:cA,mappings:fA,assertNoLevelCollisions:hA,assertDefaultLevelFound:pA,genLevelComparison:dA,assertLevelComparison:mA}});var Sl=N((wR,Cm)=>{"use strict";Cm.exports={version:"10.3.1"}});var Dm=N((SR,Im)=>{"use strict";var{EventEmitter:gA}=require("node:events"),{lsCacheSym:yA,levelValSym:bA,setLevelSym:kl,getLevelSym:Tm,chindingsSym:Nr,mixinSym:vA,asJsonSym:Rm,writeSym:wA,mixinMergeStrategySym:xA,timeSym:SA,timeSliceIndexSym:_A,streamSym:Pm,serializersSym:dn,formattersSym:bs,errorKeySym:kA,messageKeySym:AA,useOnlyCustomLevelsSym:$A,needsMetadataGsym:CA,redactFmtSym:TA,stringifySym:EA,formatOptsSym:RA,stringifiersSym:PA,msgPrefixSym:Al,hooksSym:OA}=Mn(),{getLevel:MA,setLevel:IA,isLevelEnabled:DA,mappings:LA,initialLsCache:FA,genLsCache:NA,assertNoLevelCollisions:jA}=xl(),{asChindings:$l,asJson:HA,buildFormatters:_l,stringify:Em,noop:Om}=Dr(),{version:BA}=Sl(),UA=tl(),qA=class{},Mm={constructor:qA,child:KA,bindings:WA,setBindings:GA,flush:YA,isLevelEnabled:DA,version:BA,get level(){return this[Tm]()},set level(n){this[kl](n)},get levelVal(){return this[bA]},set levelVal(n){throw Error("levelVal is read-only")},get msgPrefix(){return this[Al]},get[Symbol.toStringTag](){return"Pino"},[yA]:FA,[wA]:zA,[Rm]:HA,[Tm]:MA,[kl]:IA};Object.setPrototypeOf(Mm,gA.prototype);Im.exports=function(){return Object.create(Mm)};var Fr=n=>n;function KA(n,e){if(!n)throw Error("missing bindings for child Pino");let t=this[dn],s=this[bs],r=Object.create(this);if(e==null)return r[bs].bindings!==Fr&&(r[bs]=_l(s.level,Fr,s.log)),r[Nr]=$l(r,n),this.onChild!==Om&&this.onChild(r),r;if(e.hasOwnProperty("serializers")===!0){r[dn]=Object.create(null);for(let u in t)r[dn][u]=t[u];let a=Object.getOwnPropertySymbols(t);for(var i=0;i<a.length;i++){let u=a[i];r[dn][u]=t[u]}for(let u in e.serializers)r[dn][u]=e.serializers[u];let l=Object.getOwnPropertySymbols(e.serializers);for(var o=0;o<l.length;o++){let u=l[o];r[dn][u]=e.serializers[u]}}else r[dn]=t;if(e.hasOwnProperty("formatters")){let{level:a,bindings:l,log:u}=e.formatters;r[bs]=_l(a||s.level,l||Fr,u||s.log)}else r[bs]=_l(s.level,Fr,s.log);if(e.hasOwnProperty("customLevels")===!0&&(jA(this.levels,e.customLevels),r.levels=LA(e.customLevels,r[$A]),NA(r)),typeof e.redact=="object"&&e.redact!==null||Array.isArray(e.redact)){r.redact=e.redact;let a=UA(r.redact,Em),l={stringify:a[TA]};r[EA]=Em,r[PA]=a,r[RA]=l}if(typeof e.msgPrefix=="string"&&(r[Al]=(this[Al]||"")+e.msgPrefix),r[Nr]=$l(r,n),e.level!==void 0&&e.level!==this.level||e.hasOwnProperty("customLevels")){let a=e.level||this.level;r[kl](a)}return this.onChild(r),r}function WA(){let e=`{${this[Nr].substr(1)}}`,t=JSON.parse(e);return delete t.pid,delete t.hostname,t}function GA(n){let e=$l(this,n);this[Nr]=e}function VA(n,e){return Object.assign(e,n)}function zA(n,e,t){let s=this[SA](),r=this[vA],i=this[kA],o=this[AA],a=this[xA]||VA,l,u=this[OA].streamWrite;n==null?l={}:n instanceof Error?(l={[i]:n},e===void 0&&(e=n.message)):(l=n,e===void 0&&n[o]===void 0&&n[i]&&(e=n[i].message)),r&&(l=a(l,r(l,t,this)));let d=this[Rm](l,e,t,s),f=this[Pm];f[CA]===!0&&(f.lastLevel=t,f.lastObj=l,f.lastMsg=e,f.lastTime=s.slice(this[_A]),f.lastLogger=this),f.write(u?u(d):d)}function YA(n){if(n!=null&&typeof n!="function")throw Error("callback must be a function");let e=this[Pm];typeof e.flush=="function"?e.flush(n||Om):n&&n()}});var jm=N((Rl,Nm)=>{"use strict";var{hasOwnProperty:vs}=Object.prototype,pn=El();pn.configure=El;pn.stringify=pn;pn.default=pn;Rl.stringify=pn;Rl.configure=El;Nm.exports=pn;var JA=/[\u0000-\u001f\u0022\u005c\ud800-\udfff]/;function Ut(n){return n.length<5e3&&!JA.test(n)?`"${n}"`:JSON.stringify(n)}function Cl(n,e){if(n.length>200||e)return n.sort(e);for(let t=1;t<n.length;t++){let s=n[t],r=t;for(;r!==0&&n[r-1]>s;)n[r]=n[r-1],r--;n[r]=s}return n}var XA=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(Object.getPrototypeOf(new Int8Array)),Symbol.toStringTag).get;function Tl(n){return XA.call(n)!==void 0&&n.length!==0}function Lm(n,e,t){n.length<t&&(t=n.length);let s=e===","?"":" ",r=`"0":${s}${n[0]}`;for(let i=1;i<t;i++)r+=`${e}"${i}":${s}${n[i]}`;return r}function QA(n){if(vs.call(n,"circularValue")){let e=n.circularValue;if(typeof e=="string")return`"${e}"`;if(e==null)return e;if(e===Error||e===TypeError)return{toString(){throw new TypeError("Converting circular structure to JSON")}};throw new TypeError('The "circularValue" argument must be of type string or the value null or undefined')}return'"[Circular]"'}function ZA(n){let e;if(vs.call(n,"deterministic")&&(e=n.deterministic,typeof e!="boolean"&&typeof e!="function"))throw new TypeError('The "deterministic" argument must be of type boolean or comparator function');return e===void 0?!0:e}function e$(n,e){let t;if(vs.call(n,e)&&(t=n[e],typeof t!="boolean"))throw new TypeError(`The "${e}" argument must be of type boolean`);return t===void 0?!0:t}function Fm(n,e){let t;if(vs.call(n,e)){if(t=n[e],typeof t!="number")throw new TypeError(`The "${e}" argument must be of type number`);if(!Number.isInteger(t))throw new TypeError(`The "${e}" argument must be an integer`);if(t<1)throw new RangeError(`The "${e}" argument must be >= 1`)}return t===void 0?1/0:t}function fn(n){return n===1?"1 item":`${n} items`}function t$(n){let e=new Set;for(let t of n)(typeof t=="string"||typeof t=="number")&&e.add(String(t));return e}function n$(n){if(vs.call(n,"strict")){let e=n.strict;if(typeof e!="boolean")throw new TypeError('The "strict" argument must be of type boolean');if(e)return t=>{let s=`Object can not safely be stringified. Received type ${typeof t}`;throw typeof t!="function"&&(s+=` (${t.toString()})`),new Error(s)}}}function El(n){n={...n};let e=n$(n);e&&(n.bigint===void 0&&(n.bigint=!1),"circularValue"in n||(n.circularValue=Error));let t=QA(n),s=e$(n,"bigint"),r=ZA(n),i=typeof r=="function"?r:void 0,o=Fm(n,"maximumDepth"),a=Fm(n,"maximumBreadth");function l(m,p,g,w,_,k){let A=p[m];switch(typeof A=="object"&&A!==null&&typeof A.toJSON=="function"&&(A=A.toJSON(m)),A=w.call(p,m,A),typeof A){case"string":return Ut(A);case"object":{if(A===null)return"null";if(g.indexOf(A)!==-1)return t;let y="",v=",",b=k;if(Array.isArray(A)){if(A.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(A),_!==""&&(k+=_,y+=`
|
|
688
|
+
caused by: `+zp(s,e)):t},fS=n=>zp(n,new Set),Yp=(n,e,t)=>{if(!gs(n))return"";let s=t?"":n.message||"";if(e.has(n))return s+": ...";let r=Ua(n);if(r){e.add(n);let i=typeof n.cause=="function";return s+(i?"":": ")+Yp(r,e,i)}else return s},pS=n=>Yp(n,new Set);Jp.exports={isErrorLike:gs,getErrorCause:Ua,stackWithCauses:fS,messageWithCauses:pS}});var Ka=N((QE,Qp)=>{"use strict";var hS=Symbol("circular-ref-tag"),xr=Symbol("pino-raw-err-ref"),Xp=Object.create({},{type:{enumerable:!0,writable:!0,value:void 0},message:{enumerable:!0,writable:!0,value:void 0},stack:{enumerable:!0,writable:!0,value:void 0},aggregateErrors:{enumerable:!0,writable:!0,value:void 0},raw:{enumerable:!1,get:function(){return this[xr]},set:function(n){this[xr]=n}}});Object.defineProperty(Xp,xr,{writable:!0,value:{}});Qp.exports={pinoErrProto:Xp,pinoErrorSymbols:{seen:hS,rawSymbol:xr}}});var th=N((ZE,eh)=>{"use strict";eh.exports=Ga;var{messageWithCauses:mS,stackWithCauses:gS,isErrorLike:Zp}=qa(),{pinoErrProto:yS,pinoErrorSymbols:bS}=Ka(),{seen:Wa}=bS,{toString:vS}=Object.prototype;function Ga(n){if(!Zp(n))return n;n[Wa]=void 0;let e=Object.create(yS);e.type=vS.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=mS(n),e.stack=gS(n),Array.isArray(n.errors)&&(e.aggregateErrors=n.errors.map(t=>Ga(t)));for(let t in n)if(e[t]===void 0){let s=n[t];Zp(s)?t!=="cause"&&!Object.prototype.hasOwnProperty.call(s,Wa)&&(e[t]=Ga(s)):e[t]=s}return delete n[Wa],e.raw=n,e}});var sh=N((eR,nh)=>{"use strict";nh.exports=_r;var{isErrorLike:Va}=qa(),{pinoErrProto:wS,pinoErrorSymbols:xS}=Ka(),{seen:Sr}=xS,{toString:SS}=Object.prototype;function _r(n){if(!Va(n))return n;n[Sr]=void 0;let e=Object.create(wS);e.type=SS.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=n.message,e.stack=n.stack,Array.isArray(n.errors)&&(e.aggregateErrors=n.errors.map(t=>_r(t))),Va(n.cause)&&!Object.prototype.hasOwnProperty.call(n.cause,Sr)&&(e.cause=_r(n.cause));for(let t in n)if(e[t]===void 0){let s=n[t];Va(s)?Object.prototype.hasOwnProperty.call(s,Sr)||(e[t]=_r(s)):e[t]=s}return delete n[Sr],e.raw=n,e}});var ah=N((tR,oh)=>{"use strict";oh.exports={mapHttpRequest:_S,reqSerializer:ih};var za=Symbol("pino-raw-req-ref"),rh=Object.create({},{id:{enumerable:!0,writable:!0,value:""},method:{enumerable:!0,writable:!0,value:""},url:{enumerable:!0,writable:!0,value:""},query:{enumerable:!0,writable:!0,value:""},params:{enumerable:!0,writable:!0,value:""},headers:{enumerable:!0,writable:!0,value:{}},remoteAddress:{enumerable:!0,writable:!0,value:""},remotePort:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[za]},set:function(n){this[za]=n}}});Object.defineProperty(rh,za,{writable:!0,value:{}});function ih(n){let e=n.info||n.socket,t=Object.create(rh);if(t.id=typeof n.id=="function"?n.id():n.id||(n.info?n.info.id:void 0),t.method=n.method,n.originalUrl)t.url=n.originalUrl;else{let s=n.path;t.url=typeof s=="string"?s:n.url?n.url.path||n.url:void 0}return n.query&&(t.query=n.query),n.params&&(t.params=n.params),t.headers=n.headers,t.remoteAddress=e&&e.remoteAddress,t.remotePort=e&&e.remotePort,t.raw=n.raw||n,t}function _S(n){return{req:ih(n)}}});var dh=N((nR,uh)=>{"use strict";uh.exports={mapHttpResponse:kS,resSerializer:ch};var Ya=Symbol("pino-raw-res-ref"),lh=Object.create({},{statusCode:{enumerable:!0,writable:!0,value:0},headers:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[Ya]},set:function(n){this[Ya]=n}}});Object.defineProperty(lh,Ya,{writable:!0,value:{}});function ch(n){let e=Object.create(lh);return e.statusCode=n.headersSent?n.statusCode:null,e.headers=n.getHeaders?n.getHeaders():n._headers,e.raw=n,e}function kS(n){return{res:ch(n)}}});var Xa=N((sR,fh)=>{"use strict";var Ja=th(),AS=sh(),kr=ah(),Ar=dh();fh.exports={err:Ja,errWithCause:AS,mapHttpRequest:kr.mapHttpRequest,mapHttpResponse:Ar.mapHttpResponse,req:kr.reqSerializer,res:Ar.resSerializer,wrapErrorSerializer:function(e){return e===Ja?e:function(s){return e(Ja(s))}},wrapRequestSerializer:function(e){return e===kr.reqSerializer?e:function(s){return e(kr.reqSerializer(s))}},wrapResponseSerializer:function(e){return e===Ar.resSerializer?e:function(s){return e(Ar.resSerializer(s))}}}});var Qa=N((rR,ph)=>{"use strict";function $S(n,e){return e}ph.exports=function(){let e=Error.prepareStackTrace;Error.prepareStackTrace=$S;let t=new Error().stack;if(Error.prepareStackTrace=e,!Array.isArray(t))return;let s=t.slice(2),r=[];for(let i of s)i&&r.push(i.getFileName());return r}});var vh=N((iR,bh)=>{"use strict";function Za(n){if(n===null||typeof n!="object")return n;if(n instanceof Date)return new Date(n.getTime());if(n instanceof Array){let e=[];for(let t=0;t<n.length;t++)e[t]=Za(n[t]);return e}if(typeof n=="object"){let e=Object.create(Object.getPrototypeOf(n));for(let t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=Za(n[t]));return e}return n}function hh(n){let e=[],t="",s=!1,r=!1,i="";for(let o=0;o<n.length;o++){let a=n[o];!s&&a==="."?t&&(e.push(t),t=""):a==="["?(t&&(e.push(t),t=""),s=!0):a==="]"&&s?(e.push(t),t="",s=!1,r=!1):(a==='"'||a==="'")&&s?r?a===i?(r=!1,i=""):t+=a:(r=!0,i=a):t+=a}return t&&e.push(t),e}function mh(n,e,t){let s=n;for(let i=0;i<e.length-1;i++){let o=e[i];if(typeof s!="object"||s===null||!(o in s)||typeof s[o]!="object"||s[o]===null)return!1;s=s[o]}let r=e[e.length-1];if(r==="*"){if(Array.isArray(s))for(let i=0;i<s.length;i++)s[i]=t;else if(typeof s=="object"&&s!==null)for(let i in s)Object.prototype.hasOwnProperty.call(s,i)&&(s[i]=t)}else typeof s=="object"&&s!==null&&r in s&&Object.prototype.hasOwnProperty.call(s,r)&&(s[r]=t);return!0}function gh(n,e){let t=n;for(let r=0;r<e.length-1;r++){let i=e[r];if(typeof t!="object"||t===null||!(i in t)||typeof t[i]!="object"||t[i]===null)return!1;t=t[i]}let s=e[e.length-1];if(s==="*"){if(Array.isArray(t))for(let r=0;r<t.length;r++)t[r]=void 0;else if(typeof t=="object"&&t!==null)for(let r in t)Object.prototype.hasOwnProperty.call(t,r)&&delete t[r]}else typeof t=="object"&&t!==null&&s in t&&Object.prototype.hasOwnProperty.call(t,s)&&delete t[s];return!0}var $r=Symbol("PATH_NOT_FOUND");function CS(n,e){let t=n;for(let s of e){if(t==null||typeof t!="object"||t===null||!(s in t))return $r;t=t[s]}return t}function TS(n,e){let t=n;for(let s of e){if(t==null||typeof t!="object"||t===null)return;t=t[s]}return t}function ES(n,e,t,s=!1){for(let r of e){let i=hh(r);if(i.includes("*"))yh(n,i,t,r,s);else if(s)gh(n,i);else{let o=CS(n,i);if(o===$r)continue;let a=typeof t=="function"?t(o,i):t;mh(n,i,a)}}}function yh(n,e,t,s,r=!1){let i=e.indexOf("*");if(i===e.length-1){let o=e.slice(0,-1),a=n;for(let l of o){if(a==null||typeof a!="object"||a===null)return;a=a[l]}if(Array.isArray(a))if(r)for(let l=0;l<a.length;l++)a[l]=void 0;else for(let l=0;l<a.length;l++){let u=[...o,l.toString()],d=typeof t=="function"?t(a[l],u):t;a[l]=d}else if(typeof a=="object"&&a!==null)if(r){let l=[];for(let u in a)Object.prototype.hasOwnProperty.call(a,u)&&l.push(u);for(let u of l)delete a[u]}else for(let l in a){let u=[...o,l],d=typeof t=="function"?t(a[l],u):t;a[l]=d}}else RS(n,e,t,i,s,r)}function RS(n,e,t,s,r,i=!1){let o=e.slice(0,s),a=e.slice(s+1),l=[];function u(d,f){if(f===o.length){if(Array.isArray(d))for(let h=0;h<d.length;h++)l[f]=h.toString(),u(d[h],f+1);else if(typeof d=="object"&&d!==null)for(let h in d)l[f]=h,u(d[h],f+1)}else if(f<o.length){let h=o[f];d&&typeof d=="object"&&d!==null&&h in d&&(l[f]=h,u(d[h],f+1))}else if(a.includes("*"))yh(d,a,typeof t=="function"?(m,p)=>{let g=[...l.slice(0,f),...p];return t(m,g)}:t,r,i);else if(i)gh(d,a);else{let h=typeof t=="function"?t(TS(d,a),[...l.slice(0,f),...a]):t;mh(d,a,h)}}if(o.length===0)u(n,0);else{let d=n;for(let f=0;f<o.length;f++){let h=o[f];if(d==null||typeof d!="object"||d===null)return;d=d[h],l[f]=h}d!=null&&u(d,o.length)}}function PS(n){if(n.length===0)return null;let e=new Map;for(let t of n){let s=hh(t),r=e;for(let i=0;i<s.length;i++){let o=s[i];r.has(o)||r.set(o,new Map),r=r.get(o)}}return e}function OS(n,e){if(!e)return n;function t(s,r,i=0){if(!r||r.size===0||s===null||typeof s!="object")return s;if(s instanceof Date)return new Date(s.getTime());if(Array.isArray(s)){let a=[];for(let l=0;l<s.length;l++){let u=l.toString();r.has(u)||r.has("*")?a[l]=t(s[l],r.get(u)||r.get("*")):a[l]=s[l]}return a}let o=Object.create(Object.getPrototypeOf(s));for(let a in s)Object.prototype.hasOwnProperty.call(s,a)&&(r.has(a)||r.has("*")?o[a]=t(s[a],r.get(a)||r.get("*")):o[a]=s[a]);return o}return t(n,e)}function MS(n){if(typeof n!="string")throw new Error("Paths must be (non-empty) strings");if(n==="")throw new Error("Invalid redaction path ()");if(n.includes(".."))throw new Error(`Invalid redaction path (${n})`);if(n.includes(","))throw new Error(`Invalid redaction path (${n})`);let e=0,t=!1,s="";for(let r=0;r<n.length;r++){let i=n[r];if((i==='"'||i==="'")&&e>0)t?i===s&&(t=!1,s=""):(t=!0,s=i);else if(i==="["&&!t)e++;else if(i==="]"&&!t&&(e--,e<0))throw new Error(`Invalid redaction path (${n})`)}if(e!==0)throw new Error(`Invalid redaction path (${n})`)}function IS(n){if(!Array.isArray(n))throw new TypeError("paths must be an array");for(let e of n)MS(e)}function DS(n={}){let{paths:e=[],censor:t="[REDACTED]",serialize:s=JSON.stringify,strict:r=!0,remove:i=!1}=n;IS(e);let o=PS(e);return function(l){if(r&&(l===null||typeof l!="object")&&(l==null||typeof l!="object"))return s?s(l):l;let u=OS(l,o),d=l,f=t;return typeof t=="function"&&(f=t),ES(u,e,f,i),s===!1?(u.restore=function(){return Za(d)},u):typeof s=="function"?s(u):JSON.stringify(u)}}bh.exports=DS});var Mn=N((oR,wh)=>{"use strict";var LS=Symbol("pino.setLevel"),FS=Symbol("pino.getLevel"),NS=Symbol("pino.levelVal"),jS=Symbol("pino.levelComp"),HS=Symbol("pino.useLevelLabels"),BS=Symbol("pino.useOnlyCustomLevels"),US=Symbol("pino.mixin"),qS=Symbol("pino.lsCache"),KS=Symbol("pino.chindings"),WS=Symbol("pino.asJson"),GS=Symbol("pino.write"),VS=Symbol("pino.redactFmt"),zS=Symbol("pino.time"),YS=Symbol("pino.timeSliceIndex"),JS=Symbol("pino.stream"),XS=Symbol("pino.stringify"),QS=Symbol("pino.stringifySafe"),ZS=Symbol("pino.stringifiers"),e_=Symbol("pino.end"),t_=Symbol("pino.formatOpts"),n_=Symbol("pino.messageKey"),s_=Symbol("pino.errorKey"),r_=Symbol("pino.nestedKey"),i_=Symbol("pino.nestedKeyStr"),o_=Symbol("pino.mixinMergeStrategy"),a_=Symbol("pino.msgPrefix"),l_=Symbol("pino.wildcardFirst"),c_=Symbol.for("pino.serializers"),u_=Symbol.for("pino.formatters"),d_=Symbol.for("pino.hooks"),f_=Symbol.for("pino.metadata");wh.exports={setLevelSym:LS,getLevelSym:FS,levelValSym:NS,levelCompSym:jS,useLevelLabelsSym:HS,mixinSym:US,lsCacheSym:qS,chindingsSym:KS,asJsonSym:WS,writeSym:GS,serializersSym:c_,redactFmtSym:VS,timeSym:zS,timeSliceIndexSym:YS,streamSym:JS,stringifySym:XS,stringifySafeSym:QS,stringifiersSym:ZS,endSym:e_,formatOptsSym:t_,messageKeySym:n_,errorKeySym:s_,nestedKeySym:r_,wildcardFirstSym:l_,needsMetadataGsym:f_,useOnlyCustomLevelsSym:BS,formattersSym:u_,hooksSym:d_,nestedKeyStrSym:i_,mixinMergeStrategySym:o_,msgPrefixSym:a_}});var tl=N((aR,kh)=>{"use strict";var xh=vh(),{redactFmtSym:p_,wildcardFirstSym:Cr}=Mn(),el=/[^.[\]]+|\[([^[\]]*?)\]/g,Sh="[Redacted]",_h=!1;function h_(n,e){let{paths:t,censor:s,remove:r}=m_(n),i=t.reduce((l,u)=>{el.lastIndex=0;let d=el.exec(u),f=el.exec(u),h=d[1]!==void 0?d[1].replace(/^(?:"|'|`)(.*)(?:"|'|`)$/,"$1"):d[0];if(h==="*"&&(h=Cr),f===null)return l[h]=null,l;if(l[h]===null)return l;let{index:m}=f,p=`${u.substr(m,u.length-1)}`;return l[h]=l[h]||[],h!==Cr&&l[h].length===0&&l[h].push(...l[Cr]||[]),h===Cr&&Object.keys(l).forEach(function(g){l[g]&&l[g].push(p)}),l[h].push(p),l},{}),o={[p_]:xh({paths:t,censor:s,serialize:e,strict:_h,remove:r})},a=(...l)=>e(typeof s=="function"?s(...l):s);return[...Object.keys(i),...Object.getOwnPropertySymbols(i)].reduce((l,u)=>{if(i[u]===null)l[u]=d=>a(d,[u]);else{let d=typeof s=="function"?(f,h)=>s(f,[u,...h]):s;l[u]=xh({paths:i[u],censor:d,serialize:e,strict:_h,remove:r})}return l},o)}function m_(n){if(Array.isArray(n))return n={paths:n,censor:Sh},n;let{paths:e,censor:t=Sh,remove:s}=n;if(Array.isArray(e)===!1)throw Error("pino \u2013 redact must contain an array of strings");return s===!0&&(t=void 0),{paths:e,censor:t,remove:s}}kh.exports=h_});var Ch=N((lR,$h)=>{"use strict";var g_=()=>"",y_=()=>`,"time":${Date.now()}`,b_=()=>`,"time":${Math.round(Date.now()/1e3)}`,v_=()=>`,"time":"${new Date(Date.now()).toISOString()}"`,w_=1000000n,Ah=1000000000n,x_=BigInt(Date.now())*w_,S_=process.hrtime.bigint(),__=()=>{let n=process.hrtime.bigint()-S_,e=x_+n,t=e/Ah,s=e%Ah,r=Number(t*1000n+s/1000000n),i=new Date(r),o=i.getUTCFullYear(),a=(i.getUTCMonth()+1).toString().padStart(2,"0"),l=i.getUTCDate().toString().padStart(2,"0"),u=i.getUTCHours().toString().padStart(2,"0"),d=i.getUTCMinutes().toString().padStart(2,"0"),f=i.getUTCSeconds().toString().padStart(2,"0");return`,"time":"${o}-${a}-${l}T${u}:${d}:${f}.${s.toString().padStart(9,"0")}Z"`};$h.exports={nullTime:g_,epochTime:y_,unixTime:b_,isoTime:v_,isoTimeNano:__}});var Eh=N((cR,Th)=>{"use strict";function k_(n){try{return JSON.stringify(n)}catch{return'"[Circular]"'}}Th.exports=A_;function A_(n,e,t){var s=t&&t.stringify||k_,r=1;if(typeof n=="object"&&n!==null){var i=e.length+r;if(i===1)return n;var o=new Array(i);o[0]=s(n);for(var a=1;a<i;a++)o[a]=s(e[a]);return o.join(" ")}if(typeof n!="string")return n;var l=e.length;if(l===0)return n;for(var u="",d=1-r,f=-1,h=n&&n.length||0,m=0;m<h;){if(n.charCodeAt(m)===37&&m+1<h){switch(f=f>-1?f:0,n.charCodeAt(m+1)){case 100:case 102:if(d>=l||e[d]==null)break;f<m&&(u+=n.slice(f,m)),u+=Number(e[d]),f=m+2,m++;break;case 105:if(d>=l||e[d]==null)break;f<m&&(u+=n.slice(f,m)),u+=Math.floor(Number(e[d])),f=m+2,m++;break;case 79:case 111:case 106:if(d>=l||e[d]===void 0)break;f<m&&(u+=n.slice(f,m));var p=typeof e[d];if(p==="string"){u+="'"+e[d]+"'",f=m+2,m++;break}if(p==="function"){u+=e[d].name||"<anonymous>",f=m+2,m++;break}u+=s(e[d]),f=m+2,m++;break;case 115:if(d>=l)break;f<m&&(u+=n.slice(f,m)),u+=String(e[d]),f=m+2,m++;break;case 37:f<m&&(u+=n.slice(f,m)),u+="%",f=m+2,m++,d--;break}++d}++m}return f===-1?n:(f<h&&(u+=n.slice(f)),u)}});var sl=N((uR,nl)=>{"use strict";if(typeof SharedArrayBuffer<"u"&&typeof Atomics<"u"){let e=function(t){if((t>0&&t<1/0)===!1)throw typeof t!="number"&&typeof t!="bigint"?TypeError("sleep: ms must be a number"):RangeError("sleep: ms must be a number that is greater than 0 but less than Infinity");Atomics.wait(n,0,0,Number(t))},n=new Int32Array(new SharedArrayBuffer(4));nl.exports=e}else{let n=function(e){if((e>0&&e<1/0)===!1)throw typeof e!="number"&&typeof e!="bigint"?TypeError("sleep: ms must be a number"):RangeError("sleep: ms must be a number that is greater than 0 but less than Infinity");let s=Date.now()+Number(e);for(;s>Date.now(););};nl.exports=n}});var Fh=N((dR,Lh)=>{"use strict";var fe=require("fs"),$_=require("events"),C_=require("util").inherits,Rh=require("path"),il=sl(),T_=require("assert"),Tr=100,Er=Buffer.allocUnsafe(0),E_=16*1024,Ph="buffer",Oh="utf8",[R_,P_]=(process.versions.node||"0.0").split(".").map(Number),O_=R_>=22&&P_>=7;function Mh(n,e){e._opening=!0,e._writing=!0,e._asyncDrainScheduled=!1;function t(i,o){if(i){e._reopening=!1,e._writing=!1,e._opening=!1,e.sync?process.nextTick(()=>{e.listenerCount("error")>0&&e.emit("error",i)}):e.emit("error",i);return}let a=e._reopening;e.fd=o,e.file=n,e._reopening=!1,e._opening=!1,e._writing=!1,e.sync?process.nextTick(()=>e.emit("ready")):e.emit("ready"),!e.destroyed&&(!e._writing&&e._len>e.minLength||e._flushPending?e._actualWrite():a&&process.nextTick(()=>e.emit("drain")))}let s=e.append?"a":"w",r=e.mode;if(e.sync)try{e.mkdir&&fe.mkdirSync(Rh.dirname(n),{recursive:!0});let i=fe.openSync(n,s,r);t(null,i)}catch(i){throw t(i),i}else e.mkdir?fe.mkdir(Rh.dirname(n),{recursive:!0},i=>{if(i)return t(i);fe.open(n,s,r,t)}):fe.open(n,s,r,t)}function ot(n){if(!(this instanceof ot))return new ot(n);let{fd:e,dest:t,minLength:s,maxLength:r,maxWrite:i,periodicFlush:o,sync:a,append:l=!0,mkdir:u,retryEAGAIN:d,fsync:f,contentMode:h,mode:m}=n||{};e=e||t,this._len=0,this.fd=-1,this._bufs=[],this._lens=[],this._writing=!1,this._ending=!1,this._reopening=!1,this._asyncDrainScheduled=!1,this._flushPending=!1,this._hwm=Math.max(s||0,16387),this.file=null,this.destroyed=!1,this.minLength=s||0,this.maxLength=r||0,this.maxWrite=i||E_,this._periodicFlush=o||0,this._periodicFlushTimer=void 0,this.sync=a||!1,this.writable=!0,this._fsync=f||!1,this.append=l||!1,this.mode=m,this.retryEAGAIN=d||(()=>!0),this.mkdir=u||!1;let p,g;if(h===Ph)this._writingBuf=Er,this.write=D_,this.flush=F_,this.flushSync=j_,this._actualWrite=B_,p=()=>fe.writeSync(this.fd,this._writingBuf),g=()=>fe.write(this.fd,this._writingBuf,this.release);else if(h===void 0||h===Oh)this._writingBuf="",this.write=I_,this.flush=L_,this.flushSync=N_,this._actualWrite=H_,p=()=>Buffer.isBuffer(this._writingBuf)?fe.writeSync(this.fd,this._writingBuf):fe.writeSync(this.fd,this._writingBuf,"utf8"),g=()=>Buffer.isBuffer(this._writingBuf)?fe.write(this.fd,this._writingBuf,this.release):fe.write(this.fd,this._writingBuf,"utf8",this.release);else throw new Error(`SonicBoom supports "${Oh}" and "${Ph}", but passed ${h}`);if(typeof e=="number")this.fd=e,process.nextTick(()=>this.emit("ready"));else if(typeof e=="string")Mh(e,this);else throw new Error("SonicBoom supports only file descriptors and files");if(this.minLength>=this.maxWrite)throw new Error(`minLength should be smaller than maxWrite (${this.maxWrite})`);this.release=(w,_)=>{if(w){if((w.code==="EAGAIN"||w.code==="EBUSY")&&this.retryEAGAIN(w,this._writingBuf.length,this._len-this._writingBuf.length))if(this.sync)try{il(Tr),this.release(void 0,0)}catch(y){this.release(y)}else setTimeout(g,Tr);else this._writing=!1,this.emit("error",w);return}this.emit("write",_);let k=rl(this._writingBuf,this._len,_);if(this._len=k.len,this._writingBuf=k.writingBuf,this._writingBuf.length){if(!this.sync){g();return}try{do{let y=p(),v=rl(this._writingBuf,this._len,y);this._len=v.len,this._writingBuf=v.writingBuf}while(this._writingBuf.length)}catch(y){this.release(y);return}}this._fsync&&fe.fsyncSync(this.fd);let $=this._len;this._reopening?(this._writing=!1,this._reopening=!1,this.reopen()):$>this.minLength?this._actualWrite():this._ending?$>0?this._actualWrite():(this._writing=!1,Rr(this)):(this._writing=!1,this.sync?this._asyncDrainScheduled||(this._asyncDrainScheduled=!0,process.nextTick(M_,this)):this.emit("drain"))},this.on("newListener",function(w){w==="drain"&&(this._asyncDrainScheduled=!1)}),this._periodicFlush!==0&&(this._periodicFlushTimer=setInterval(()=>this.flush(null),this._periodicFlush),this._periodicFlushTimer.unref())}function rl(n,e,t){return typeof n=="string"&&(n=Buffer.from(n)),e=Math.max(e-t,0),n=n.subarray(t),{writingBuf:n,len:e}}function M_(n){n.listenerCount("drain")>0&&(n._asyncDrainScheduled=!1,n.emit("drain"))}C_(ot,$_);function Ih(n,e){return n.length===0?Er:n.length===1?n[0]:Buffer.concat(n,e)}function I_(n){if(this.destroyed)throw new Error("SonicBoom destroyed");n=""+n;let e=Buffer.byteLength(n),t=this._len+e,s=this._bufs;return this.maxLength&&t>this.maxLength?(this.emit("drop",n),this._len<this._hwm):(s.length===0||Buffer.byteLength(s[s.length-1])+e>this.maxWrite?s.push(n):s[s.length-1]+=n,this._len=t,!this._writing&&this._len>=this.minLength&&this._actualWrite(),this._len<this._hwm)}function D_(n){if(this.destroyed)throw new Error("SonicBoom destroyed");let e=this._len+n.length,t=this._bufs,s=this._lens;return this.maxLength&&e>this.maxLength?(this.emit("drop",n),this._len<this._hwm):(t.length===0||s[s.length-1]+n.length>this.maxWrite?(t.push([n]),s.push(n.length)):(t[t.length-1].push(n),s[s.length-1]+=n.length),this._len=e,!this._writing&&this._len>=this.minLength&&this._actualWrite(),this._len<this._hwm)}function Dh(n){this._flushPending=!0;let e=()=>{if(this._fsync)this._flushPending=!1,n();else try{fe.fsync(this.fd,s=>{this._flushPending=!1,n(s)})}catch(s){n(s)}this.off("error",t)},t=s=>{this._flushPending=!1,n(s),this.off("drain",e)};this.once("drain",e),this.once("error",t)}function L_(n){if(n!=null&&typeof n!="function")throw new Error("flush cb must be a function");if(this.destroyed){let e=new Error("SonicBoom destroyed");if(n){n(e);return}throw e}if(this.minLength<=0){n?.();return}n&&Dh.call(this,n),!this._writing&&(this._bufs.length===0&&this._bufs.push(""),this._actualWrite())}function F_(n){if(n!=null&&typeof n!="function")throw new Error("flush cb must be a function");if(this.destroyed){let e=new Error("SonicBoom destroyed");if(n){n(e);return}throw e}if(this.minLength<=0){n?.();return}n&&Dh.call(this,n),!this._writing&&(this._bufs.length===0&&(this._bufs.push([]),this._lens.push(0)),this._actualWrite())}ot.prototype.reopen=function(n){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this._opening){this.once("ready",()=>{this.reopen(n)});return}if(this._ending)return;if(!this.file)throw new Error("Unable to reopen a file descriptor, you must pass a file to SonicBoom");if(n&&(this.file=n),this._reopening=!0,this._writing)return;let e=this.fd;this.once("ready",()=>{e!==this.fd&&fe.close(e,t=>{if(t)return this.emit("error",t)})}),Mh(this.file,this)};ot.prototype.end=function(){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this._opening){this.once("ready",()=>{this.end()});return}this._ending||(this._ending=!0,!this._writing&&(this._len>0&&this.fd>=0?this._actualWrite():Rr(this)))};function N_(){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this.fd<0)throw new Error("sonic boom is not ready yet");!this._writing&&this._writingBuf.length>0&&(this._bufs.unshift(this._writingBuf),this._writingBuf="");let n="";for(;this._bufs.length||n.length;){n.length<=0&&(n=this._bufs[0]);try{let e=Buffer.isBuffer(n)?fe.writeSync(this.fd,n):fe.writeSync(this.fd,n,"utf8"),t=rl(n,this._len,e);n=t.writingBuf,this._len=t.len,n.length<=0&&this._bufs.shift()}catch(e){if((e.code==="EAGAIN"||e.code==="EBUSY")&&!this.retryEAGAIN(e,n.length,this._len-n.length))throw e;il(Tr)}}try{fe.fsyncSync(this.fd)}catch{}}function j_(){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this.fd<0)throw new Error("sonic boom is not ready yet");!this._writing&&this._writingBuf.length>0&&(this._bufs.unshift([this._writingBuf]),this._writingBuf=Er);let n=Er;for(;this._bufs.length||n.length;){n.length<=0&&(n=Ih(this._bufs[0],this._lens[0]));try{let e=fe.writeSync(this.fd,n);n=n.subarray(e),this._len=Math.max(this._len-e,0),n.length<=0&&(this._bufs.shift(),this._lens.shift())}catch(e){if((e.code==="EAGAIN"||e.code==="EBUSY")&&!this.retryEAGAIN(e,n.length,this._len-n.length))throw e;il(Tr)}}}ot.prototype.destroy=function(){this.destroyed||Rr(this)};function H_(){let n=this.release;if(this._writing=!0,this._writingBuf=this._writingBuf.length?this._writingBuf:this._bufs.shift()||"",this.sync)try{let e=Buffer.isBuffer(this._writingBuf)?fe.writeSync(this.fd,this._writingBuf):fe.writeSync(this.fd,this._writingBuf,"utf8");n(null,e)}catch(e){n(e)}else fe.write(this.fd,this._writingBuf,n)}function B_(){let n=this.release;if(this._writing=!0,this._writingBuf=this._writingBuf.length?this._writingBuf:Ih(this._bufs.shift(),this._lens.shift()),this.sync)try{let e=fe.writeSync(this.fd,this._writingBuf);n(null,e)}catch(e){n(e)}else O_&&(this._writingBuf=Buffer.from(this._writingBuf)),fe.write(this.fd,this._writingBuf,n)}function Rr(n){if(n.fd===-1){n.once("ready",Rr.bind(null,n));return}n._periodicFlushTimer!==void 0&&clearInterval(n._periodicFlushTimer),n.destroyed=!0,n._bufs=[],n._lens=[],T_(typeof n.fd=="number",`sonic.fd must be a number, got ${typeof n.fd}`);try{fe.fsync(n.fd,e)}catch{}function e(){n.fd!==1&&n.fd!==2?fe.close(n.fd,t):t()}function t(s){if(s){n.emit("error",s);return}n._ending&&!n._writing&&n.emit("finish"),n.emit("close")}}ot.SonicBoom=ot;ot.default=ot;Lh.exports=ot});var ol=N((fR,Uh)=>{"use strict";var at={exit:[],beforeExit:[]},Nh={exit:K_,beforeExit:W_},In;function U_(){In===void 0&&(In=new FinalizationRegistry(G_))}function q_(n){at[n].length>0||process.on(n,Nh[n])}function jh(n){at[n].length>0||(process.removeListener(n,Nh[n]),at.exit.length===0&&at.beforeExit.length===0&&(In=void 0))}function K_(){Hh("exit")}function W_(){Hh("beforeExit")}function Hh(n){for(let e of at[n]){let t=e.deref(),s=e.fn;t!==void 0&&s(t,n)}at[n]=[]}function G_(n){for(let e of["exit","beforeExit"]){let t=at[e].indexOf(n);at[e].splice(t,t+1),jh(e)}}function Bh(n,e,t){if(e===void 0)throw new Error("the object can't be undefined");q_(n);let s=new WeakRef(e);s.fn=t,U_(),In.register(e,s),at[n].push(s)}function V_(n,e){Bh("exit",n,e)}function z_(n,e){Bh("beforeExit",n,e)}function Y_(n){if(In!==void 0){In.unregister(n);for(let e of["exit","beforeExit"])at[e]=at[e].filter(t=>{let s=t.deref();return s&&s!==n}),jh(e)}}Uh.exports={register:V_,registerBeforeExit:z_,unregister:Y_}});var qh=N((pR,J_)=>{J_.exports={name:"thread-stream",version:"4.2.0",description:"A streaming way to send data to a Node.js Worker Thread",main:"index.js",types:"index.d.ts",engines:{node:">=20"},dependencies:{"real-require":"^1.0.0"},devDependencies:{"@types/node":"^25.0.2","@yao-pkg/pkg":"^6.0.0",borp:"^1.0.0",desm:"^1.3.0",eslint:"^9.39.1",fastbench:"^1.0.1",neostandard:"^0.13.0","pino-elasticsearch":"^9.0.0","sonic-boom":"^5.0.0","ts-node":"^10.8.0",typescript:"~5.7.3"},scripts:{build:"tsc --noEmit",lint:"eslint",test:'npm run lint && npm run build && npm run transpile && borp --pattern "test/*.test.{js,mjs}"',"test:ci":'npm run lint && npm run transpile && borp --pattern "test/*.test.{js,mjs}"',"test:yarn":'npm run transpile && borp --pattern "test/*.test.js"',transpile:"sh ./test/ts/transpile.sh"},repository:{type:"git",url:"git+https://github.com/mcollina/thread-stream.git"},keywords:["worker","thread","threads","stream"],author:"Matteo Collina <hello@matteocollina.com>",license:"MIT",bugs:{url:"https://github.com/mcollina/thread-stream/issues"},homepage:"https://github.com/mcollina/thread-stream#readme"}});var Wh=N((hR,Kh)=>{"use strict";function X_(n,e,t,s,r){let i=s===1/0?1/0:Date.now()+s,o=()=>{let a=Atomics.load(n,e);if(a===t){r(null,"ok");return}if(i!==1/0&&Date.now()>i){r(null,"timed-out");return}let l=i===1/0?1e4:Math.min(1e4,Math.max(1,i-Date.now())),u=Atomics.waitAsync(n,e,a,l);u.async?u.value.then(o):setImmediate(o)};o()}function Q_(n,e,t,s,r){let i=s===1/0?1/0:Date.now()+s,o=()=>{if(Atomics.load(n,e)!==t){r(null,"ok");return}if(i!==1/0&&Date.now()>i){r(null,"timed-out");return}let l=i===1/0?1e4:Math.min(1e4,Math.max(1,i-Date.now())),u=Atomics.waitAsync(n,e,t,l);u.async?u.value.then(d=>{if(d==="ok"){r(null,"ok");return}o()}):setImmediate(o)};o()}Kh.exports={wait:X_,waitDiff:Q_}});var Vh=N((mR,Gh)=>{"use strict";Gh.exports={WRITE_INDEX:4,READ_INDEX:8,SEQ_INDEX:2}});var im=N((gR,rm)=>{"use strict";var{version:Z_}=qh(),{EventEmitter:ek}=require("events"),{Worker:tk}=require("worker_threads"),{join:nk}=require("path"),{pathToFileURL:sk}=require("url"),{wait:rk}=Wh(),{WRITE_INDEX:Ot,READ_INDEX:cn,SEQ_INDEX:al}=Vh(),ik=require("buffer"),ok=require("assert"),R=Symbol("kImpl"),ak=ik.constants.MAX_STRING_LENGTH;function zh(){}function dl(n,e){Atomics.add(n[R].state,al,1),e(),Atomics.add(n[R].state,al,1),Atomics.notify(n[R].state,al)}function Yh(n){dl(n,()=>{Atomics.store(n[R].state,cn,0),Atomics.store(n[R].state,Ot,0)})}var ys=class{constructor(e){this._value=e}deref(){return this._value}},Pr=class{register(){}unregister(){}},lk=process.env.NODE_V8_COVERAGE?Pr:global.FinalizationRegistry||Pr,ck=process.env.NODE_V8_COVERAGE?ys:global.WeakRef||ys,Jh=new lk(n=>{n.exited||n.terminate()});function uk(n,e){let{filename:t,workerData:s}=e,i=("__bundlerPathsOverrides"in globalThis?globalThis.__bundlerPathsOverrides:{})["thread-stream-worker"]||nk(__dirname,"lib","worker.js"),o=new tk(i,{...e.workerOpts,name:e.workerOpts?.name||"thread-stream",trackUnmanagedFds:!1,workerData:{filename:t.indexOf("file://")===0?t:sk(t).href,dataBuf:n[R].dataBuf,stateBuf:n[R].stateBuf,workerData:{$context:{threadStreamVersion:Z_},...s}}});return o.stream=new ys(n),o.on("message",dk),o.on("exit",Zh),Jh.register(n,o),o}function Xh(n){ok(!n[R].sync),n[R].needDrain&&(n[R].needDrain=!1,n.emit("drain"))}function Qh(n){for(;;){let e=Atomics.load(n[R].state,Ot),t=n[R].data.length-e;if(t>0){if(n[R].bufLen===0){n[R].flushing=!1,n[R].ending?fl(n):n[R].needDrain&&process.nextTick(Xh,n);return}nm(n,t,zh);continue}if(t===0){if(e===0&&n[R].bufLen===0)return;Or(n,()=>{n.destroyed||(Yh(n),Qh(n))});return}Ze(n,new Error("overwritten"));return}}function dk(n){let e=this.stream.deref();if(e===void 0){this.exited=!0,this.terminate();return}if(n?.code!=null)switch(n.code){case"READY":this.stream=new ck(e),Or(e,()=>{e[R].ready=!0,e.emit("ready")});break;case"ERROR":Ze(e,n.err);break;case"EVENT":Array.isArray(n.args)?e.emit(n.name,...n.args):e.emit(n.name,n.args);break;case"FLUSHED":{if(n.context!=="thread-stream"){Ze(e,new Error("this should not happen: "+n.code));break}let t=e[R].flushCallbacks.get(n.id);t&&(e[R].flushCallbacks.delete(n.id),process.nextTick(t));break}case"WARNING":process.emitWarning(n.err);break;default:Ze(e,new Error("this should not happen: "+n.code))}}function Zh(n){let e=this.stream.deref();e!==void 0&&(Jh.unregister(e),e.worker.exited=!0,e.worker.off("exit",Zh),Ze(e,n!==0?new Error("the worker thread exited"):null))}var cl=class extends ek{constructor(e={}){if(super(),e.bufferSize<4)throw new Error("bufferSize must at least fit a 4-byte utf-8 char");this[R]={},this[R].stateBuf=new SharedArrayBuffer(128),this[R].state=new Int32Array(this[R].stateBuf),this[R].dataBuf=new SharedArrayBuffer(e.bufferSize||4*1024*1024),this[R].data=Buffer.from(this[R].dataBuf),this[R].sync=e.sync||!1,this[R].ending=!1,this[R].ended=!1,this[R].needDrain=!1,this[R].destroyed=!1,this[R].flushing=!1,this[R].ready=!1,this[R].finished=!1,this[R].errored=null,this[R].closed=!1,this[R].buf=[],this[R].bufHead=0,this[R].bufLen=0,this[R].flushCallbacks=new Map,this[R].nextFlushId=0,this.worker=uk(this,e),this.on("message",(t,s)=>{this.worker.postMessage(t,s)})}write(e){let t=Buffer.isBuffer(e)?e:Buffer.from(e);if(this[R].destroyed)return ul(this,new Error("the worker has exited")),!1;if(this[R].ending)return ul(this,new Error("the worker is ending")),!1;if(this[R].flushing&&this[R].bufLen+t.length>=ak)try{ll(this),this[R].flushing=!0}catch(s){return Ze(this,s),!1}if(this[R].buf.push(t),this[R].bufLen+=t.length,this[R].sync)try{return ll(this),!0}catch(s){return Ze(this,s),!1}return this[R].flushing||(this[R].flushing=!0,setImmediate(Qh,this)),this[R].needDrain=this[R].data.length-this[R].bufLen-Atomics.load(this[R].state,Ot)<=0,!this[R].needDrain}end(){this[R].destroyed||(this[R].ending=!0,fl(this))}flush(e){e=typeof e=="function"?e:zh,em(this,t=>{if(t){process.nextTick(e,t);return}tm(this,e)})}flushSync(){this[R].destroyed||(ll(this),sm(this))}unref(){this.worker.unref()}ref(){this.worker.ref()}get ready(){return this[R].ready}get destroyed(){return this[R].destroyed}get closed(){return this[R].closed}get writable(){return!this[R].destroyed&&!this[R].ending}get writableEnded(){return this[R].ending}get writableFinished(){return this[R].finished}get writableNeedDrain(){return this[R].needDrain}get writableObjectMode(){return!1}get writableErrored(){return this[R].errored}};function em(n,e){if(n[R].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[R].sync&&(n[R].flushing||n[R].bufLen>0)){setImmediate(em,n,e);return}Or(n,e)}function Or(n,e){let t=Atomics.load(n[R].state,Ot);rk(n[R].state,cn,t,1/0,(s,r)=>{if(s){Ze(n,s),e(s);return}if(r!=="ok"){Or(n,e);return}e()})}function tm(n,e){if(n[R].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[R].ready){let s=()=>{i(),tm(n,e)},r=()=>{i(),process.nextTick(e,new Error("the worker has exited"))},i=()=>{n.off("ready",s),n.off("close",r)};n.once("ready",s),n.once("close",r);return}let t=++n[R].nextFlushId;n[R].flushCallbacks.set(t,e);try{n.worker.postMessage({code:"FLUSH",context:"thread-stream",id:t})}catch(s){n[R].flushCallbacks.delete(t),Ze(n,s),process.nextTick(e,s)}}function fk(n,e){let t=n[R].flushCallbacks;if(t.size===0)return;let s=e||new Error("the worker has exited");for(let r of t.values())process.nextTick(r,s);t.clear()}function ul(n,e){setImmediate(()=>{n.emit("error",e)})}function Ze(n,e){n[R].destroyed||(n[R].destroyed=!0,fk(n,e),e&&(n[R].errored=e,ul(n,e)),n.worker.exited?setImmediate(()=>{n[R].closed=!0,n.emit("close")}):n.worker.terminate().catch(()=>{}).then(()=>{n[R].closed=!0,n.emit("close")}))}function nm(n,e,t){let r=Atomics.load(n[R].state,Ot),i=e;for(;i>0&&n[R].bufLen!==0;){let o=n[R].bufHead,a=n[R].buf[o];if(a.length<=i){a.copy(n[R].data,r),r+=a.length,i-=a.length,n[R].bufLen-=a.length,n[R].bufHead=o+1,n[R].bufHead===n[R].buf.length?(n[R].buf.length=0,n[R].bufHead=0):n[R].bufHead>=1024&&n[R].bufHead*2>=n[R].buf.length&&(n[R].buf.splice(0,n[R].bufHead),n[R].bufHead=0);continue}a.copy(n[R].data,r,0,i),n[R].buf[o]=a.subarray(i),n[R].bufLen-=i,r+=i,i=0}return dl(n,()=>{Atomics.store(n[R].state,Ot,r)}),t(),!0}function fl(n){if(!(n[R].ended||!n[R].ending||n[R].flushing)){n[R].ended=!0;try{n.flushSync();let e=Atomics.load(n[R].state,cn);dl(n,()=>{Atomics.store(n[R].state,Ot,-1)});let t=0;for(;e!==-1;){if(Atomics.wait(n[R].state,cn,e,1e3),e=Atomics.load(n[R].state,cn),e===-2){Ze(n,new Error("end() failed"));return}if(++t===10){Ze(n,new Error("end() took too long (10s)"));return}}process.nextTick(()=>{n[R].finished=!0,n.emit("finish")})}catch(e){Ze(n,e)}}}function ll(n){let e=()=>{n[R].ending?fl(n):n[R].needDrain&&process.nextTick(Xh,n)};for(n[R].flushing=!1;n[R].bufLen!==0;){let t=Atomics.load(n[R].state,Ot),s=n[R].data.length-t;if(s===0){sm(n),Yh(n);continue}else if(s<0)throw new Error("overwritten");nm(n,s,e)}}function sm(n){if(n[R].flushing)throw new Error("unable to flush while flushing");let e=Atomics.load(n[R].state,Ot),t=0;for(;;){let s=Atomics.load(n[R].state,cn);if(s===-2)throw Error("_flushSync failed");if(s!==e)Atomics.wait(n[R].state,cn,s,1e3);else break;if(++t===10)throw new Error("_flushSync took too long (10s)")}}rm.exports=cl});var ml=N((yR,lm)=>{"use strict";var{createRequire:pk}=require("module"),{existsSync:hk}=require("node:fs"),mk=Qa(),{join:pl,isAbsolute:am,sep:gk}=require("node:path"),{fileURLToPath:yk}=require("node:url"),bk=sl(),hl=ol(),vk=im();function wk(n){hl.register(n,Ak),hl.registerBeforeExit(n,$k),n.on("close",function(){hl.unregister(n)})}function xk(){let n=process.execArgv;for(let e=0;e<n.length;e++){let t=n[e];if(t==="--import"||t==="--require"||t==="-r"||t.startsWith("--import=")||t.startsWith("--require=")||t.startsWith("-r="))return!0}return!1}function Sk(n){let e=n.match(/(?:[^\s"']+|"[^"]*"|'[^']*')+/g);if(!e)return n;let t=[],s=!1;for(let r=0;r<e.length;r++){let i=e[r];if(i==="--require"||i==="-r"||i==="--import"){let o=e[r+1];if(o&&om(o)){s=!0,r++;continue}t.push(i),o&&(t.push(o),r++);continue}if(i.startsWith("--require=")||i.startsWith("-r=")||i.startsWith("--import=")){let o=i.slice(i.indexOf("=")+1);if(om(o)){s=!0;continue}}t.push(i)}return s?t.join(" "):n}function om(n){let e=_k(n);if(!e)return!1;let t=e;if(t.startsWith("file://"))try{t=yk(t)}catch{return!1}return am(t)&&!hk(t)}function _k(n){let e=n[0],t=n[n.length-1];return e==='"'&&t==='"'||e==="'"&&t==="'"?n.slice(1,-1):n}function kk(n,e,t,s,r){if(!t.execArgv&&xk()&&require.main===void 0&&(t={...t,execArgv:[]}),!t.env&&process.env.NODE_OPTIONS){let l=Sk(process.env.NODE_OPTIONS);l!==process.env.NODE_OPTIONS&&(t={...t,env:{...process.env,NODE_OPTIONS:l}})}t={...t,name:r};let i=new vk({filename:n,workerData:e,workerOpts:t,sync:s});i.on("ready",o),i.on("close",function(){process.removeListener("exit",a)}),process.on("exit",a);function o(){process.removeListener("exit",a),i.unref(),t.autoEnd!==!1&&wk(i)}function a(){i.closed||(i.flushSync(),bk(100),i.end())}return i}function Ak(n){n.ref(),n.flushSync(),n.end(),n.once("close",function(){n.unref()})}function $k(n){n.flushSync()}function Ck(n){let{pipeline:e,targets:t,levels:s,dedupe:r,worker:i={},caller:o=mk(),sync:a=!1}=n,l={...n.options},u=typeof o=="string"?[o]:o,d=typeof globalThis=="object"&&Object.prototype.hasOwnProperty.call(globalThis,"__bundlerPathsOverrides")&&globalThis.__bundlerPathsOverrides&&typeof globalThis.__bundlerPathsOverrides=="object"?globalThis.__bundlerPathsOverrides:Object.create(null),f=n.target;if(f&&t)throw new Error("only one of target or targets can be specified");t?(f=d["pino-worker"]||pl(__dirname,"worker.js"),l.targets=t.filter(p=>p.target).map(p=>({...p,target:m(p.target)})),l.pipelines=t.filter(p=>p.pipeline).map(p=>p.pipeline.map(g=>({...g,level:p.level,target:m(g.target)})))):e&&(f=d["pino-worker"]||pl(__dirname,"worker.js"),l.pipelines=[e.map(p=>({...p,target:m(p.target)}))]),s&&(l.levels=s),r&&(l.dedupe=r),l.pinoWillSendConfig=!0;let h=t||e?"pino.transport":f;return kk(m(f),l,i,a,h);function m(p){if(p=d[p]||p,am(p)||p.indexOf("file://")===0)return p;if(p==="pino/file")return pl(__dirname,"..","file.js");let g;for(let w of u)try{let _=w==="node:repl"?process.cwd()+gk:w;g=pk(_).resolve(p);break}catch{continue}if(!g)throw new Error(`unable to determine transport target for "${p}"`);return g}}lm.exports=Ck});var Dr=N((bR,xm)=>{"use strict";var Tk=require("node:diagnostics_channel"),cm=Eh(),{mapHttpRequest:Ek,mapHttpResponse:Rk}=Xa(),yl=Fh(),um=ol(),{lsCacheSym:Pk,chindingsSym:mm,writeSym:dm,serializersSym:gm,formatOptsSym:fm,endSym:Ok,stringifiersSym:ym,stringifySym:bm,stringifySafeSym:bl,wildcardFirstSym:vm,nestedKeySym:Mk,formattersSym:wm,messageKeySym:Ik,errorKeySym:Dk,nestedKeyStrSym:Lk,msgPrefixSym:Mr}=Mn(),{isMainThread:Fk}=require("worker_threads"),Nk=ml(),[jk]=process.versions.node.split(".").map(n=>Number(n)),pm=Tk.tracingChannel("pino_asJson"),gl=jk>=25?n=>JSON.stringify(n):Bk;function Dn(){}function Hk(n,e){if(!e)return t;return function(...r){e.call(this,r,t,n)};function t(s,...r){if(typeof s=="object"){let i=s;s!==null&&(s.method&&s.headers&&s.socket?s=Ek(s):typeof s.setHeader=="function"&&(s=Rk(s)));let o;i===null&&r.length===0?o=[null]:(i=r.shift(),o=r),typeof this[Mr]=="string"&&i!==void 0&&i!==null&&(i=this[Mr]+i),this[dm](s,cm(i,o,this[fm]),n)}else{let i=s===void 0?r.shift():s;typeof this[Mr]=="string"&&i!==void 0&&i!==null&&(i=this[Mr]+i),this[dm](null,cm(i,r,this[fm]),n)}}}function Bk(n){let e="",t=0,s=!1,r=255,i=n.length;if(i>100)return JSON.stringify(n);for(var o=0;o<i&&r>=32;o++)r=n.charCodeAt(o),(r===34||r===92)&&(e+=n.slice(t,o)+"\\",t=o,s=!0);return s?e+=n.slice(t):e=n,r<32?JSON.stringify(n):'"'+e+'"'}function Uk(n,e,t,s){if(pm.hasSubscribers===!1)return hm.call(this,n,e,t,s);let r={instance:this,arguments};return pm.traceSync(hm,r,this,n,e,t,s)}function hm(n,e,t,s){let r=this[bm],i=this[bl],o=this[ym],a=this[Ok],l=this[mm],u=this[gm],d=this[wm],f=this[Ik],h=this[Dk],m=this[Pk][t]+s;m=m+l;let p;d.log&&(n=d.log(n));let g=o[vm],w="";for(let k in n)if(p=n[k],Object.prototype.hasOwnProperty.call(n,k)&&p!==void 0){u[k]?p=u[k](p):k===h&&u.err&&(p=u.err(p));let $=o[k]||g;switch(typeof p){case"undefined":case"function":continue;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":$&&(p=$(p));break;case"string":p=($||gl)(p);break;default:p=($||r)(p,i)}if(p===void 0)continue;let y=gl(k);w+=","+y+":"+p}let _="";if(e!==void 0){p=u[f]?u[f](e):e;let k=o[f]||g;switch(typeof p){case"function":break;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":k&&(p=k(p)),_=',"'+f+'":'+p;break;case"string":p=(k||gl)(p),_=',"'+f+'":'+p;break;default:p=(k||r)(p,i),_=',"'+f+'":'+p}}return this[Mk]&&w?m+this[Lk]+w.slice(1)+"}"+_+a:m+w+_+a}function qk(n,e){let t,s=n[mm],r=n[bm],i=n[bl],o=n[ym],a=o[vm],l=n[gm],u=n[wm].bindings;e=u(e);for(let d in e)if(t=e[d],((d.length<5||d!=="level"&&d!=="serializers"&&d!=="formatters"&&d!=="customLevels")&&e.hasOwnProperty(d)&&t!==void 0)===!0){if(t=l[d]?l[d](t):t,t=(o[d]||a||r)(t,i),t===void 0)continue;s+=',"'+d+'":'+t}return s}function Kk(n){return n.write!==n.constructor.prototype.write}function Ir(n){let e=new yl(n);return e.on("error",t),!n.sync&&Fk&&(um.register(e,Wk),e.on("close",function(){um.unregister(e)})),e;function t(s){if(s.code==="EPIPE"){e.write=Dn,e.end=Dn,e.flushSync=Dn,e.destroy=Dn;return}e.removeListener("error",t),e.emit("error",s)}}function Wk(n,e){n.destroyed||(e==="beforeExit"?(n.flush(),n.on("drain",function(){n.end()})):n.flushSync())}function Gk(n){return function(t,s,r={},i){if(typeof r=="string")i=Ir({dest:r}),r={};else if(typeof i=="string"){if(r&&r.transport)throw Error("only one of option.transport or stream can be specified");i=Ir({dest:i})}else if(r instanceof yl||r.writable||r._writableState)i=r,r={};else if(r.transport){if(r.transport instanceof yl||r.transport.writable||r.transport._writableState)throw Error("option.transport do not allow stream, please pass to option directly. e.g. pino(transport)");if(r.transport.targets&&r.transport.targets.length&&r.formatters&&typeof r.formatters.level=="function")throw Error("option.transport.targets do not allow custom level formatters");let l;r.customLevels&&(l=r.useOnlyCustomLevels?r.customLevels:Object.assign({},r.levels,r.customLevels)),i=Nk({caller:s,...r.transport,levels:l})}if(r=Object.assign({},n,r),r.serializers=Object.assign({},n.serializers,r.serializers),r.formatters=Object.assign({},n.formatters,r.formatters),r.prettyPrint)throw new Error("prettyPrint option is no longer supported, see the pino-pretty package (https://github.com/pinojs/pino-pretty)");let{enabled:o,onChild:a}=r;return o===!1&&(r.level="silent"),a||(r.onChild=Dn),i||(Kk(process.stdout)?i=process.stdout:i=Ir({fd:process.stdout.fd||1})),{opts:r,stream:i}}}function Vk(n,e){try{return JSON.stringify(n)}catch{try{return(e||this[bl])(n)}catch{return'"[unable to serialize, circular reference is too complex to analyze]"'}}}function zk(n,e,t){return{level:n,bindings:e,log:t}}function Yk(n){let e=Number(n);return typeof n=="string"&&Number.isFinite(e)?e:n===void 0?1:n}xm.exports={noop:Dn,buildSafeSonicBoom:Ir,asChindings:qk,asJson:Uk,genLog:Hk,createArgsNormalizer:Gk,stringify:Vk,buildFormatters:zk,normalizeDestFileDescriptor:Yk}});var Lr=N((vR,Sm)=>{var Jk={trace:10,debug:20,info:30,warn:40,error:50,fatal:60},Xk={ASC:"ASC",DESC:"DESC"};Sm.exports={DEFAULT_LEVELS:Jk,SORTING_ORDER:Xk}});var xl=N((wR,$m)=>{"use strict";var{lsCacheSym:Qk,levelValSym:vl,useOnlyCustomLevelsSym:Zk,streamSym:eA,formattersSym:tA,hooksSym:nA,levelCompSym:_m}=Mn(),{noop:sA,genLog:un}=Dr(),{DEFAULT_LEVELS:gt,SORTING_ORDER:km}=Lr(),Am={fatal:n=>{let e=un(gt.fatal,n);return function(...t){let s=this[eA];if(e.call(this,...t),typeof s.flushSync=="function")try{s.flushSync()}catch{}}},error:n=>un(gt.error,n),warn:n=>un(gt.warn,n),info:n=>un(gt.info,n),debug:n=>un(gt.debug,n),trace:n=>un(gt.trace,n)},wl=Object.keys(gt).reduce((n,e)=>(n[gt[e]]=e,n),{}),rA=Object.keys(wl).reduce((n,e)=>(n[e]='{"level":'+Number(e),n),{});function iA(n){let e=n[tA].level,{labels:t}=n.levels,s={};for(let r in t){let i=e(t[r],Number(r));s[r]=JSON.stringify(i).slice(0,-1)}return n[Qk]=s,n}function oA(n,e){if(e)return!1;switch(n){case"fatal":case"error":case"warn":case"info":case"debug":case"trace":return!0;default:return!1}}function aA(n){let{labels:e,values:t}=this.levels;if(typeof n=="number"){if(e[n]===void 0)throw Error("unknown level value"+n);n=e[n]}if(t[n]===void 0)throw Error("unknown level "+n);let s=this[vl],r=this[vl]=t[n],i=this[Zk],o=this[_m],a=this[nA].logMethod;for(let l in t){if(o(t[l],r)===!1){this[l]=sA;continue}this[l]=oA(l,i)?Am[l](a):un(t[l],a)}this.emit("level-change",n,r,e[s],s,this)}function lA(n){let{levels:e,levelVal:t}=this;return e&&e.labels?e.labels[t]:""}function cA(n){let{values:e}=this.levels,t=e[n];return t!==void 0&&this[_m](t,this[vl])}function uA(n,e,t){return n===km.DESC?e<=t:e>=t}function dA(n){return typeof n=="string"?uA.bind(null,n):n}function fA(n=null,e=!1){let t=n?Object.keys(n).reduce((i,o)=>(i[n[o]]=o,i),{}):null,s=Object.assign(Object.create(Object.prototype,{Infinity:{value:"silent"}}),e?null:wl,t),r=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),e?null:gt,n);return{labels:s,values:r}}function pA(n,e,t){if(typeof n=="number"){if(![].concat(Object.keys(e||{}).map(i=>e[i]),t?[]:Object.keys(wl).map(i=>+i),1/0).includes(n))throw Error(`default level:${n} must be included in custom levels`);return}let s=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),t?null:gt,e);if(!(n in s))throw Error(`default level:${n} must be included in custom levels`)}function hA(n,e){let{labels:t,values:s}=n;for(let r in e){if(r in s)throw Error("levels cannot be overridden");if(e[r]in t)throw Error("pre-existing level values cannot be used for new levels")}}function mA(n){if(typeof n!="function"&&!(typeof n=="string"&&Object.values(km).includes(n)))throw new Error('Levels comparison should be one of "ASC", "DESC" or "function" type')}$m.exports={initialLsCache:rA,genLsCache:iA,levelMethods:Am,getLevel:lA,setLevel:aA,isLevelEnabled:cA,mappings:fA,assertNoLevelCollisions:hA,assertDefaultLevelFound:pA,genLevelComparison:dA,assertLevelComparison:mA}});var Sl=N((xR,Cm)=>{"use strict";Cm.exports={version:"10.3.1"}});var Dm=N((_R,Im)=>{"use strict";var{EventEmitter:gA}=require("node:events"),{lsCacheSym:yA,levelValSym:bA,setLevelSym:kl,getLevelSym:Tm,chindingsSym:Nr,mixinSym:vA,asJsonSym:Rm,writeSym:wA,mixinMergeStrategySym:xA,timeSym:SA,timeSliceIndexSym:_A,streamSym:Pm,serializersSym:dn,formattersSym:bs,errorKeySym:kA,messageKeySym:AA,useOnlyCustomLevelsSym:$A,needsMetadataGsym:CA,redactFmtSym:TA,stringifySym:EA,formatOptsSym:RA,stringifiersSym:PA,msgPrefixSym:Al,hooksSym:OA}=Mn(),{getLevel:MA,setLevel:IA,isLevelEnabled:DA,mappings:LA,initialLsCache:FA,genLsCache:NA,assertNoLevelCollisions:jA}=xl(),{asChindings:$l,asJson:HA,buildFormatters:_l,stringify:Em,noop:Om}=Dr(),{version:BA}=Sl(),UA=tl(),qA=class{},Mm={constructor:qA,child:KA,bindings:WA,setBindings:GA,flush:YA,isLevelEnabled:DA,version:BA,get level(){return this[Tm]()},set level(n){this[kl](n)},get levelVal(){return this[bA]},set levelVal(n){throw Error("levelVal is read-only")},get msgPrefix(){return this[Al]},get[Symbol.toStringTag](){return"Pino"},[yA]:FA,[wA]:zA,[Rm]:HA,[Tm]:MA,[kl]:IA};Object.setPrototypeOf(Mm,gA.prototype);Im.exports=function(){return Object.create(Mm)};var Fr=n=>n;function KA(n,e){if(!n)throw Error("missing bindings for child Pino");let t=this[dn],s=this[bs],r=Object.create(this);if(e==null)return r[bs].bindings!==Fr&&(r[bs]=_l(s.level,Fr,s.log)),r[Nr]=$l(r,n),this.onChild!==Om&&this.onChild(r),r;if(e.hasOwnProperty("serializers")===!0){r[dn]=Object.create(null);for(let u in t)r[dn][u]=t[u];let a=Object.getOwnPropertySymbols(t);for(var i=0;i<a.length;i++){let u=a[i];r[dn][u]=t[u]}for(let u in e.serializers)r[dn][u]=e.serializers[u];let l=Object.getOwnPropertySymbols(e.serializers);for(var o=0;o<l.length;o++){let u=l[o];r[dn][u]=e.serializers[u]}}else r[dn]=t;if(e.hasOwnProperty("formatters")){let{level:a,bindings:l,log:u}=e.formatters;r[bs]=_l(a||s.level,l||Fr,u||s.log)}else r[bs]=_l(s.level,Fr,s.log);if(e.hasOwnProperty("customLevels")===!0&&(jA(this.levels,e.customLevels),r.levels=LA(e.customLevels,r[$A]),NA(r)),typeof e.redact=="object"&&e.redact!==null||Array.isArray(e.redact)){r.redact=e.redact;let a=UA(r.redact,Em),l={stringify:a[TA]};r[EA]=Em,r[PA]=a,r[RA]=l}if(typeof e.msgPrefix=="string"&&(r[Al]=(this[Al]||"")+e.msgPrefix),r[Nr]=$l(r,n),e.level!==void 0&&e.level!==this.level||e.hasOwnProperty("customLevels")){let a=e.level||this.level;r[kl](a)}return this.onChild(r),r}function WA(){let e=`{${this[Nr].substr(1)}}`,t=JSON.parse(e);return delete t.pid,delete t.hostname,t}function GA(n){let e=$l(this,n);this[Nr]=e}function VA(n,e){return Object.assign(e,n)}function zA(n,e,t){let s=this[SA](),r=this[vA],i=this[kA],o=this[AA],a=this[xA]||VA,l,u=this[OA].streamWrite;n==null?l={}:n instanceof Error?(l={[i]:n},e===void 0&&(e=n.message)):(l=n,e===void 0&&n[o]===void 0&&n[i]&&(e=n[i].message)),r&&(l=a(l,r(l,t,this)));let d=this[Rm](l,e,t,s),f=this[Pm];f[CA]===!0&&(f.lastLevel=t,f.lastObj=l,f.lastMsg=e,f.lastTime=s.slice(this[_A]),f.lastLogger=this),f.write(u?u(d):d)}function YA(n){if(n!=null&&typeof n!="function")throw Error("callback must be a function");let e=this[Pm];typeof e.flush=="function"?e.flush(n||Om):n&&n()}});var jm=N((Rl,Nm)=>{"use strict";var{hasOwnProperty:vs}=Object.prototype,pn=El();pn.configure=El;pn.stringify=pn;pn.default=pn;Rl.stringify=pn;Rl.configure=El;Nm.exports=pn;var JA=/[\u0000-\u001f\u0022\u005c\ud800-\udfff]/;function Ut(n){return n.length<5e3&&!JA.test(n)?`"${n}"`:JSON.stringify(n)}function Cl(n,e){if(n.length>200||e)return n.sort(e);for(let t=1;t<n.length;t++){let s=n[t],r=t;for(;r!==0&&n[r-1]>s;)n[r]=n[r-1],r--;n[r]=s}return n}var XA=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(Object.getPrototypeOf(new Int8Array)),Symbol.toStringTag).get;function Tl(n){return XA.call(n)!==void 0&&n.length!==0}function Lm(n,e,t){n.length<t&&(t=n.length);let s=e===","?"":" ",r=`"0":${s}${n[0]}`;for(let i=1;i<t;i++)r+=`${e}"${i}":${s}${n[i]}`;return r}function QA(n){if(vs.call(n,"circularValue")){let e=n.circularValue;if(typeof e=="string")return`"${e}"`;if(e==null)return e;if(e===Error||e===TypeError)return{toString(){throw new TypeError("Converting circular structure to JSON")}};throw new TypeError('The "circularValue" argument must be of type string or the value null or undefined')}return'"[Circular]"'}function ZA(n){let e;if(vs.call(n,"deterministic")&&(e=n.deterministic,typeof e!="boolean"&&typeof e!="function"))throw new TypeError('The "deterministic" argument must be of type boolean or comparator function');return e===void 0?!0:e}function e$(n,e){let t;if(vs.call(n,e)&&(t=n[e],typeof t!="boolean"))throw new TypeError(`The "${e}" argument must be of type boolean`);return t===void 0?!0:t}function Fm(n,e){let t;if(vs.call(n,e)){if(t=n[e],typeof t!="number")throw new TypeError(`The "${e}" argument must be of type number`);if(!Number.isInteger(t))throw new TypeError(`The "${e}" argument must be an integer`);if(t<1)throw new RangeError(`The "${e}" argument must be >= 1`)}return t===void 0?1/0:t}function fn(n){return n===1?"1 item":`${n} items`}function t$(n){let e=new Set;for(let t of n)(typeof t=="string"||typeof t=="number")&&e.add(String(t));return e}function n$(n){if(vs.call(n,"strict")){let e=n.strict;if(typeof e!="boolean")throw new TypeError('The "strict" argument must be of type boolean');if(e)return t=>{let s=`Object can not safely be stringified. Received type ${typeof t}`;throw typeof t!="function"&&(s+=` (${t.toString()})`),new Error(s)}}}function El(n){n={...n};let e=n$(n);e&&(n.bigint===void 0&&(n.bigint=!1),"circularValue"in n||(n.circularValue=Error));let t=QA(n),s=e$(n,"bigint"),r=ZA(n),i=typeof r=="function"?r:void 0,o=Fm(n,"maximumDepth"),a=Fm(n,"maximumBreadth");function l(m,p,g,w,_,k){let $=p[m];switch(typeof $=="object"&&$!==null&&typeof $.toJSON=="function"&&($=$.toJSON(m)),$=w.call(p,m,$),typeof $){case"string":return Ut($);case"object":{if($===null)return"null";if(g.indexOf($)!==-1)return t;let y="",v=",",b=k;if(Array.isArray($)){if($.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push($),_!==""&&(k+=_,y+=`
|
|
689
689
|
${k}`,v=`,
|
|
690
|
-
${k}`);let F=Math.min(
|
|
691
|
-
${b}`),g.pop(),`[${y}]`}let x=Object.keys(A
|
|
692
|
-
${k}`,E=" ");let C=Math.min(
|
|
690
|
+
${k}`);let F=Math.min($.length,a),H=0;for(;H<F-1;H++){let T=l(String(H),$,g,w,_,k);y+=T!==void 0?T:"null",y+=v}let Y=l(String(H),$,g,w,_,k);if(y+=Y!==void 0?Y:"null",$.length-1>a){let T=$.length-a-1;y+=`${v}"... ${fn(T)} not stringified"`}return _!==""&&(y+=`
|
|
691
|
+
${b}`),g.pop(),`[${y}]`}let x=Object.keys($),A=x.length;if(A===0)return"{}";if(o<g.length+1)return'"[Object]"';let E="",M="";_!==""&&(k+=_,v=`,
|
|
692
|
+
${k}`,E=" ");let C=Math.min(A,a);r&&!Tl($)&&(x=Cl(x,i)),g.push($);for(let F=0;F<C;F++){let H=x[F],Y=l(H,$,g,w,_,k);Y!==void 0&&(y+=`${M}${Ut(H)}:${E}${Y}`,M=v)}if(A>a){let F=A-a;y+=`${M}"...":${E}"${fn(F)} not stringified"`,M=v}return _!==""&&M.length>1&&(y=`
|
|
693
693
|
${k}${y}
|
|
694
|
-
${b}`),g.pop(),`{${y}}`}case"number":return isFinite(
|
|
694
|
+
${b}`),g.pop(),`{${y}}`}case"number":return isFinite($)?String($):e?e($):"null";case"boolean":return $===!0?"true":"false";case"undefined":return;case"bigint":if(s)return String($);default:return e?e($):void 0}}function u(m,p,g,w,_,k){switch(typeof p=="object"&&p!==null&&typeof p.toJSON=="function"&&(p=p.toJSON(m)),typeof p){case"string":return Ut(p);case"object":{if(p===null)return"null";if(g.indexOf(p)!==-1)return t;let $=k,y="",v=",";if(Array.isArray(p)){if(p.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(p),_!==""&&(k+=_,y+=`
|
|
695
695
|
${k}`,v=`,
|
|
696
|
-
${k}`);let
|
|
697
|
-
${
|
|
698
|
-
${k}`,b=" ");let x="";for(let
|
|
696
|
+
${k}`);let A=Math.min(p.length,a),E=0;for(;E<A-1;E++){let C=u(String(E),p[E],g,w,_,k);y+=C!==void 0?C:"null",y+=v}let M=u(String(E),p[E],g,w,_,k);if(y+=M!==void 0?M:"null",p.length-1>a){let C=p.length-a-1;y+=`${v}"... ${fn(C)} not stringified"`}return _!==""&&(y+=`
|
|
697
|
+
${$}`),g.pop(),`[${y}]`}g.push(p);let b="";_!==""&&(k+=_,v=`,
|
|
698
|
+
${k}`,b=" ");let x="";for(let A of w){let E=u(A,p[A],g,w,_,k);E!==void 0&&(y+=`${x}${Ut(A)}:${b}${E}`,x=v)}return _!==""&&x.length>1&&(y=`
|
|
699
699
|
${k}${y}
|
|
700
|
-
${
|
|
700
|
+
${$}`),g.pop(),`{${y}}`}case"number":return isFinite(p)?String(p):e?e(p):"null";case"boolean":return p===!0?"true":"false";case"undefined":return;case"bigint":if(s)return String(p);default:return e?e(p):void 0}}function d(m,p,g,w,_){switch(typeof p){case"string":return Ut(p);case"object":{if(p===null)return"null";if(typeof p.toJSON=="function"){if(p=p.toJSON(m),typeof p!="object")return d(m,p,g,w,_);if(p===null)return"null"}if(g.indexOf(p)!==-1)return t;let k=_;if(Array.isArray(p)){if(p.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(p),_+=w;let E=`
|
|
701
701
|
${_}`,M=`,
|
|
702
702
|
${_}`,C=Math.min(p.length,a),F=0;for(;F<C-1;F++){let Y=d(String(F),p[F],g,w,_);E+=Y!==void 0?Y:"null",E+=M}let H=d(String(F),p[F],g,w,_);if(E+=H!==void 0?H:"null",p.length-1>a){let Y=p.length-a-1;E+=`${M}"... ${fn(Y)} not stringified"`}return E+=`
|
|
703
|
-
${k}`,g.pop(),`[${E}]`}let
|
|
704
|
-
${_}`,b="",x=""
|
|
703
|
+
${k}`,g.pop(),`[${E}]`}let $=Object.keys(p),y=$.length;if(y===0)return"{}";if(o<g.length+1)return'"[Object]"';_+=w;let v=`,
|
|
704
|
+
${_}`,b="",x="",A=Math.min(y,a);Tl(p)&&(b+=Lm(p,v,a),$=$.slice(p.length),A-=p.length,x=v),r&&($=Cl($,i)),g.push(p);for(let E=0;E<A;E++){let M=$[E],C=d(M,p[M],g,w,_);C!==void 0&&(b+=`${x}${Ut(M)}: ${C}`,x=v)}if(y>a){let E=y-a;b+=`${x}"...": "${fn(E)} not stringified"`,x=v}return x!==""&&(b=`
|
|
705
705
|
${_}${b}
|
|
706
|
-
${k}`),g.pop(),`{${b}}`}case"number":return isFinite(p)?String(p):e?e(p):"null";case"boolean":return p===!0?"true":"false";case"undefined":return;case"bigint":if(s)return String(p);default:return e?e(p):void 0}}function f(m,p,g){switch(typeof p){case"string":return Ut(p);case"object":{if(p===null)return"null";if(typeof p.toJSON=="function"){if(p=p.toJSON(m),typeof p!="object")return f(m,p,g);if(p===null)return"null"}if(g.indexOf(p)!==-1)return t;let w="",_=p.length!==void 0;if(_&&Array.isArray(p)){if(p.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(p);let b=Math.min(p.length,a),x=0;for(;x<b-1;x++){let E=f(String(x),p[x],g);w+=E!==void 0?E:"null",w+=","}let
|
|
706
|
+
${k}`),g.pop(),`{${b}}`}case"number":return isFinite(p)?String(p):e?e(p):"null";case"boolean":return p===!0?"true":"false";case"undefined":return;case"bigint":if(s)return String(p);default:return e?e(p):void 0}}function f(m,p,g){switch(typeof p){case"string":return Ut(p);case"object":{if(p===null)return"null";if(typeof p.toJSON=="function"){if(p=p.toJSON(m),typeof p!="object")return f(m,p,g);if(p===null)return"null"}if(g.indexOf(p)!==-1)return t;let w="",_=p.length!==void 0;if(_&&Array.isArray(p)){if(p.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(p);let b=Math.min(p.length,a),x=0;for(;x<b-1;x++){let E=f(String(x),p[x],g);w+=E!==void 0?E:"null",w+=","}let A=f(String(x),p[x],g);if(w+=A!==void 0?A:"null",p.length-1>a){let E=p.length-a-1;w+=`,"... ${fn(E)} not stringified"`}return g.pop(),`[${w}]`}let k=Object.keys(p),$=k.length;if($===0)return"{}";if(o<g.length+1)return'"[Object]"';let y="",v=Math.min($,a);_&&Tl(p)&&(w+=Lm(p,",",a),k=k.slice(p.length),v-=p.length,y=","),r&&(k=Cl(k,i)),g.push(p);for(let b=0;b<v;b++){let x=k[b],A=f(x,p[x],g);A!==void 0&&(w+=`${y}${Ut(x)}:${A}`,y=",")}if($>a){let b=$-a;w+=`${y}"...":"${fn(b)} not stringified"`}return g.pop(),`{${w}}`}case"number":return isFinite(p)?String(p):e?e(p):"null";case"boolean":return p===!0?"true":"false";case"undefined":return;case"bigint":if(s)return String(p);default:return e?e(p):void 0}}function h(m,p,g){if(arguments.length>1){let w="";if(typeof g=="number"?w=" ".repeat(Math.min(g,10)):typeof g=="string"&&(w=g.slice(0,10)),p!=null){if(typeof p=="function")return l("",{"":m},[],p,w,"");if(Array.isArray(p))return u("",m,[],t$(p),w,"")}if(w.length!==0)return d("",m,[],w,"")}return f("",m,[])}return h}});var qm=N((kR,Um)=>{"use strict";var Pl=Symbol.for("pino.metadata"),{DEFAULT_LEVELS:Bm}=Lr(),s$=Bm.info;function r$(n,e){n=n||[],e=e||{dedupe:!1};let t=Object.create(Bm);t.silent=1/0,e.levels&&typeof e.levels=="object"&&Object.keys(e.levels).forEach(f=>{t[f]=e.levels[f]});let s={write:r,add:a,remove:l,emit:i,flushSync:o,end:u,minLevel:0,lastId:0,streams:[],clone:d,[Pl]:!0,streamLevels:t};return Array.isArray(n)?n.forEach(a,s):a.call(s,n),n=null,s;function r(f){let h,m=this.lastLevel,{streams:p}=this,g=0,w;for(let _=i$(p.length,e.dedupe);a$(_,p.length,e.dedupe);_=o$(_,e.dedupe))if(h=p[_],h.level<=m){if(g!==0&&g!==h.level)break;if(w=h.stream,w[Pl]){let{lastTime:k,lastMsg:$,lastObj:y,lastLogger:v}=this;w.lastLevel=m,w.lastTime=k,w.lastMsg=$,w.lastObj=y,w.lastLogger=v}w.write(f),e.dedupe&&(g=h.level)}else if(!e.dedupe)break}function i(...f){for(let{stream:h}of this.streams)typeof h.emit=="function"&&h.emit(...f)}function o(){for(let{stream:f}of this.streams)typeof f.flushSync=="function"&&f.flushSync()}function a(f){if(!f)return s;let h=typeof f.write=="function"||f.stream,m=f.write?f:f.stream;if(!h)throw Error("stream object needs to implement either StreamEntry or DestinationStream interface");let{streams:p,streamLevels:g}=this,w;typeof f.levelVal=="number"?w=f.levelVal:typeof f.level=="string"?w=g[f.level]:typeof f.level=="number"?w=f.level:w=s$;let _={stream:m,level:w,levelVal:void 0,id:++s.lastId};return p.unshift(_),p.sort(Hm),this.minLevel=p[0].level,s}function l(f){let{streams:h}=this,m=h.findIndex(p=>p.id===f);return m>=0&&(h.splice(m,1),h.sort(Hm),this.minLevel=h.length>0?h[0].level:-1),s}function u(){for(let{stream:f}of this.streams)typeof f.flushSync=="function"&&f.flushSync(),f.end()}function d(f){let h=new Array(this.streams.length);for(let m=0;m<h.length;m++)h[m]={level:f,stream:this.streams[m].stream};return{write:r,add:a,remove:l,minLevel:f,streams:h,clone:d,emit:i,flushSync:o,[Pl]:!0}}}function Hm(n,e){return n.level-e.level}function i$(n,e){return e?n-1:0}function o$(n,e){return e?n-1:n+1}function a$(n,e,t){return t?n>=0:n<e}Um.exports=r$});var Dl=N((AR,et)=>{"use strict";var l$=require("node:os"),Xm=Xa(),c$=Qa(),u$=tl(),Qm=Ch(),d$=Dm(),Zm=Mn(),{configure:f$}=jm(),{assertDefaultLevelFound:p$,mappings:eg,genLsCache:h$,genLevelComparison:m$,assertLevelComparison:g$}=xl(),{DEFAULT_LEVELS:tg,SORTING_ORDER:y$}=Lr(),{createArgsNormalizer:b$,asChindings:v$,buildSafeSonicBoom:Km,buildFormatters:w$,stringify:Ol,normalizeDestFileDescriptor:Wm,noop:x$}=Dr(),{version:S$}=Sl(),{chindingsSym:Gm,redactFmtSym:_$,serializersSym:Vm,timeSym:k$,timeSliceIndexSym:A$,streamSym:$$,stringifySym:zm,stringifySafeSym:Ml,stringifiersSym:Ym,setLevelSym:C$,endSym:T$,formatOptsSym:E$,messageKeySym:R$,errorKeySym:P$,nestedKeySym:O$,mixinSym:M$,levelCompSym:I$,useOnlyCustomLevelsSym:D$,formattersSym:Jm,hooksSym:L$,nestedKeyStrSym:F$,mixinMergeStrategySym:N$,msgPrefixSym:j$}=Zm,{epochTime:ng,nullTime:H$}=Qm,{pid:B$}=process,U$=l$.hostname(),q$=Xm.err,K$={level:"info",levelComparison:y$.ASC,levels:tg,messageKey:"msg",errorKey:"err",nestedKey:null,enabled:!0,base:{pid:B$,hostname:U$},serializers:Object.assign(Object.create(null),{err:q$}),formatters:Object.assign(Object.create(null),{bindings(n){return n},level(n,e){return{level:e}}}),hooks:{logMethod:void 0,streamWrite:void 0},timestamp:ng,name:void 0,redact:null,customLevels:null,useOnlyCustomLevels:!1,depthLimit:5,edgeLimit:100},W$=b$(K$),G$=Object.assign(Object.create(null),Xm);function Il(...n){let e={},{opts:t,stream:s}=W$(e,c$(),...n);t.level&&typeof t.level=="string"&&tg[t.level.toLowerCase()]!==void 0&&(t.level=t.level.toLowerCase());let{redact:r,crlf:i,serializers:o,timestamp:a,messageKey:l,errorKey:u,nestedKey:d,base:f,name:h,level:m,customLevels:p,levelComparison:g,mixin:w,mixinMergeStrategy:_,useOnlyCustomLevels:k,formatters:$,hooks:y,depthLimit:v,edgeLimit:b,onChild:x,msgPrefix:A}=t,E=f$({maximumDepth:v,maximumBreadth:b}),M=w$($.level,$.bindings,$.log),C=Ol.bind({[Ml]:E}),F=r?u$(r,C):{},H=r?{stringify:F[_$]}:{stringify:C},Y="}"+(i?`\r
|
|
707
707
|
`:`
|
|
708
|
-
`),T=v$.bind(null,{[Gm]:"",[Vm]:o,[Ym]:F,[zm]:Ol,[Ml]:E,[Jm]:M}),S="";f!==null&&(h===void 0?S=T(f):S=T(Object.assign({},f,{name:h})));let
|
|
708
|
+
`),T=v$.bind(null,{[Gm]:"",[Vm]:o,[Ym]:F,[zm]:Ol,[Ml]:E,[Jm]:M}),S="";f!==null&&(h===void 0?S=T(f):S=T(Object.assign({},f,{name:h})));let Q=a instanceof Function?a:a?ng:H$,q=Q().indexOf(":")+1;if(k&&!p)throw Error("customLevels is required if useOnlyCustomLevels is set true");if(w&&typeof w!="function")throw Error(`Unknown mixin type "${typeof w}" - expected "function"`);if(A&&typeof A!="string")throw Error(`Unknown msgPrefix type "${typeof A}" - expected "string"`);p$(m,p,k);let ne=eg(p,k);typeof s.emit=="function"&&s.emit("message",{code:"PINO_CONFIG",config:{levels:ne,messageKey:l,errorKey:u}}),g$(g);let re=m$(g);return Object.assign(e,{levels:ne,[I$]:re,[D$]:k,[$$]:s,[k$]:Q,[A$]:q,[zm]:Ol,[Ml]:E,[Ym]:F,[T$]:Y,[E$]:H,[R$]:l,[P$]:u,[O$]:d,[F$]:d?`,${JSON.stringify(d)}:{`:"",[Vm]:o,[M$]:w,[N$]:_,[Gm]:S,[Jm]:M,[L$]:y,silent:x$,onChild:x,[j$]:A}),Object.setPrototypeOf(e,d$()),h$(e),e[C$](m),e}et.exports=Il;et.exports.destination=(n=process.stdout.fd)=>typeof n=="object"?(n.dest=Wm(n.dest||process.stdout.fd),Km(n)):Km({dest:Wm(n),minLength:0});et.exports.transport=ml();et.exports.multistream=qm();et.exports.levels=eg();et.exports.stdSerializers=G$;et.exports.stdTimeFunctions=Object.assign({},Qm);et.exports.symbols=Zm;et.exports.version=S$;et.exports.default=Il;et.exports.pino=Il});function ws(n){return new Ll(n)}var V$,z$,Y$,Ll,Fl=L(()=>{"use strict";V$={maxSteps:150,thinkingEnabled:!0,selfEvalEnabled:!0,minConfidence:.6,showThinking:!1},z$=`
|
|
709
709
|
## Reasoning Protocol
|
|
710
710
|
|
|
711
711
|
Before taking ANY action, you MUST think step-by-step inside <thinking> tags.
|
|
@@ -766,9 +766,9 @@ Rate your work. Reply with ONLY a JSON object \u2014 no other text:
|
|
|
766
766
|
</self_eval>
|
|
767
767
|
`.trim()}parseSelfEval(e){let t=[/^\s*(\{[\s\S]*\})\s*$/,/```(?:json)?\s*\n([\s\S]*?)\n```/,/<self_eval_result>([\s\S]*?)<\/self_eval_result>/,/(\{[\s\S]*?"score"[\s\S]*?"completed"[\s\S]*?\})/];for(let s of t){let r=e.match(s);if(r)try{let i=JSON.parse(r[1]);return this.normalizeSelfEval(i)}catch{}}return null}normalizeSelfEval(e){let t=typeof e.score=="number"?Math.max(0,Math.min(10,Math.round(e.score))):5,s=typeof e.completed=="boolean"?e.completed:t>=7,r=typeof e.rationale=="string"?e.rationale.slice(0,500):"No rationale provided",i=Array.isArray(e.issues)?e.issues.filter(a=>typeof a=="string").slice(0,5):[],o="medium";return e.confidence==="high"||e.confidence==="medium"||e.confidence==="low"?o=e.confidence:t>=8?o="high":t<=4&&(o="low"),{score:t,completed:s,rationale:r,issues:i,confidence:o}}buildBudgetWarningPrompt(){let e=this.remainingBudget();return e<=0?"[SYSTEM] You have exceeded the maximum reasoning steps. You MUST provide your final answer NOW. Do not call any more tools.":e<=3?`[SYSTEM] You have only ${e} step(s) remaining. Wrap up your work and provide a final answer soon.`:null}buildReflectionHint(e,t,s){return t?"":["<thinking>",`Tool "${e}" FAILED. Before retrying:`,"1. What went wrong? Analyze the error message carefully.","2. Can I fix the arguments and retry?","3. Is there an alternative approach?",`Error preview: ${s.slice(0,300)}`,"</thinking>"].join(`
|
|
768
768
|
`)}getTurnSummary(){let e=this.turnSteps.length,t=this.turnSteps.filter(r=>r.action).length,s=this.turnSteps.filter(r=>r.reflection).length;return`${e} steps, ${t} actions, ${s} reflections`}}});function xs(n=3){return new Nl(n)}var J$,Nl,jl=L(()=>{"use strict";J$=[{test:n=>/ENOENT|no such file|not found|does not exist/i.test(n),errorClass:"file_not_found",strategy:"read_first",explanation:"The file or directory does not exist.",suggestion:"Use list_dir to check what files exist, then retry with the correct path.",alternatives:["list_dir","search_codebase"],autoRetry:!1},{test:n=>/EACCES|permission denied/i.test(n),errorClass:"permission_denied",strategy:"graceful_fail",explanation:"Permission denied \u2014 the process lacks access rights.",suggestion:"Check file ownership or try a different path. Do NOT use sudo.",alternatives:[],autoRetry:!1},{test:n=>/EISDIR|is a directory/i.test(n),errorClass:"path_is_directory",strategy:"retry_fixed",explanation:"The path points to a directory, not a file.",suggestion:"Append the filename to the path. Use list_dir to see contents.",alternatives:["list_dir"],autoRetry:!1},{test:n=>/EEXIST|already exists/i.test(n),errorClass:"file_already_exists",strategy:"read_first",explanation:"A file or directory already exists at that path.",suggestion:"Read the existing file first, then decide whether to overwrite or edit it.",alternatives:["read_file","edit_file"],autoRetry:!1},{test:n=>/no match|not found in file|search string not found/i.test(n),errorClass:"search_no_match",strategy:"read_first",explanation:"The search string was not found in the file.",suggestion:"Read the file first to see its actual content, then use the exact text for search/replace.",alternatives:["read_file","search_codebase"],autoRetry:!1},{test:n=>/command not found|not recognized/i.test(n),errorClass:"command_not_found",strategy:"alternative_tool",explanation:"The command does not exist on this system.",suggestion:"Check if the program is installed, or use a different command that achieves the same goal.",alternatives:["run_command"],autoRetry:!1},{test:n=>/timeout|timed out|ETIMEDOUT/i.test(n),errorClass:"command_timeout",strategy:"retry_fixed",explanation:"The command took too long and was terminated.",suggestion:"Try a simpler version of the command, or increase the timeout, or run it in background.",alternatives:[],autoRetry:!1},{test:n=>/exit code|exited with|non-zero/i.test(n),errorClass:"command_exit_error",strategy:"retry_fixed",explanation:"The command executed but returned an error.",suggestion:"Read the error output carefully. Fix the root cause (missing dependency, wrong syntax, etc.).",alternatives:[],autoRetry:!1},{test:n=>/syntax error|unexpected token|parse error|SyntaxError/i.test(n),errorClass:"syntax_error",strategy:"retry_fixed",explanation:"The content has a syntax error.",suggestion:"Review the generated code for syntax issues, fix them, and retry.",alternatives:[],autoRetry:!1},{test:n=>/ECONNREFUSED|ECONNRESET|ENOTFOUND|fetch failed|network/i.test(n),errorClass:"network_error",strategy:"retry_same",explanation:"Network connection failed.",suggestion:"This may be transient. Retry the same operation, or check connectivity.",alternatives:[],autoRetry:!0},{test:n=>/invalid argument|missing required|expected.*but got|type error/i.test(n),errorClass:"invalid_arguments",strategy:"retry_fixed",explanation:"The tool was called with invalid or missing arguments.",suggestion:"Check the tool's parameter requirements and provide correct values.",alternatives:[],autoRetry:!1},{test:n=>/ENOMEM|out of memory|resource|too large|max.*exceeded/i.test(n),errorClass:"resource_limit",strategy:"decompose_task",explanation:"Resource limit exceeded (memory, file size, etc.).",suggestion:"Break the task into smaller pieces, or process less data at once.",alternatives:[],autoRetry:!1}],Nl=class{failures=new Map;maxRetriesPerTool;constructor(e=3){this.maxRetriesPerTool=e}resetTurn(){this.failures.clear()}analyze(e,t,s){let r=this.failures.get(e),i=r?r.count+1:1,o={tool:e,count:i,lastError:t,lastStrategy:"retry_same"};if(i>this.maxRetriesPerTool)return o.lastStrategy="ask_user",this.failures.set(e,o),{errorClass:"unknown",strategy:"ask_user",explanation:`Tool "${e}" has failed ${i} times in this turn.`,suggestion:`Stop retrying "${e}". Ask the user for clarification or try a completely different approach.`,alternatives:this.suggestAlternatives(e),autoRetry:!1};for(let a of J$)if(a.test(t)){let l=r?.lastStrategy===a.strategy&&i>=2,u=l?"decompose_task":a.strategy;return o.lastStrategy=u,this.failures.set(e,o),{errorClass:a.errorClass,strategy:u,explanation:a.explanation,suggestion:l?`Previous recovery attempt ("${a.strategy}") also failed. Try breaking this into smaller steps or use a completely different approach.`:a.suggestion,alternatives:a.alternatives,autoRetry:!l&&a.autoRetry}}return o.lastStrategy=i===1?"retry_fixed":"graceful_fail",this.failures.set(e,o),{errorClass:"unknown",strategy:o.lastStrategy,explanation:`Unexpected error from "${e}".`,suggestion:i===1?"Review the error message and adjust your approach.":"This error is persistent. Explain to the user what went wrong and suggest manual steps.",alternatives:this.suggestAlternatives(e),autoRetry:!1}}buildRecoveryMessage(e,t){let s=[`ERROR: ${t}`,"","[Recovery Analysis]",` Type: ${e.errorClass}`,` Strategy: ${e.strategy}`,` Explanation: ${e.explanation}`,` Suggestion: ${e.suggestion}`];switch(e.alternatives.length>0&&s.push(` Alternative tools: ${e.alternatives.join(", ")}`),e.strategy){case"read_first":s.push("","\u2192 ACTION: Read the file or directory first, then retry with correct information.");break;case"retry_fixed":s.push("","\u2192 ACTION: Fix the arguments based on the error, then retry.");break;case"alternative_tool":s.push("","\u2192 ACTION: Use a different tool to achieve the same goal.");break;case"decompose_task":s.push("","\u2192 ACTION: Break this into smaller, simpler steps.");break;case"ask_user":s.push("","\u2192 ACTION: Ask the user for clarification. Do NOT retry automatically.");break;case"graceful_fail":s.push("","\u2192 ACTION: Explain what went wrong clearly. Suggest manual steps if possible.");break}return s.join(`
|
|
769
|
-
`)}getFailureCount(e){return this.failures.get(e)?.count??0}shouldAutoRetry(e){let t=this.failures.get(e);return t?t.count<=1&&t.lastStrategy==="retry_same":!1}suggestAlternatives(e){return{read_file:["search_codebase","list_dir"],write_file:["edit_file","append_to_file"],edit_file:["search_and_replace","write_file","read_file"],search_and_replace:["edit_file","read_file"],patch_file:["edit_file","write_file"],run_command:["search_codebase"],search_codebase:["read_file","list_dir"],delete_file:["run_command"],create_dir:["run_command"],web_search:["scrape_url"]}[e]??[]}}});function X$(){try{if(Mt.existsSync(jr))return JSON.parse(Mt.readFileSync(jr,"utf-8"))}catch{}return{}}function Q$(n){try{let e=Hr.dirname(jr);Mt.existsSync(e)||Mt.mkdirSync(e,{recursive:!0}),Mt.writeFileSync(jr,JSON.stringify(n,null,2),"utf-8")}catch{}}function ig(n,e){let t=0,s=!1,r=!1;for(let i=e;i<n.length;i++){let o=n[i];if(r){r=!1;continue}if(o==="\\"&&s){r=!0;continue}if(o==='"'){s=!s;continue}if(!s&&(o==="{"&&t++,o==="}"&&(t--,t===0)))return n.slice(e,i+1)}return null}function Ss(n){if(typeof n.name=="string"&&n.arguments&&typeof n.arguments=="object")return{tool:n.name,args:n.arguments};if(typeof n.tool=="string"&&n.args&&typeof n.args=="object")return{tool:n.tool,args:n.args};if(typeof n.name=="string"&&n.parameters&&typeof n.parameters=="object")return{tool:n.name,args:n.parameters};if(n.function&&typeof n.function=="object"){let e=n.function;if(typeof e.name=="string"){let t={};if(typeof e.arguments=="string")try{t=JSON.parse(e.arguments)}catch{t={}}else e.arguments&&typeof e.arguments=="object"&&(t=e.arguments);return{tool:e.name,args:t}}}return null}function sg(n){return n.replace(/"/g,'"').replace(/'/g,"'").replace(/</g,"<").replace(/>/g,">").replace(/&/g,"&")}function Z$(n){let e=[],t
|
|
769
|
+
`)}getFailureCount(e){return this.failures.get(e)?.count??0}shouldAutoRetry(e){let t=this.failures.get(e);return t?t.count<=1&&t.lastStrategy==="retry_same":!1}suggestAlternatives(e){return{read_file:["search_codebase","list_dir"],write_file:["edit_file","append_to_file"],edit_file:["search_and_replace","write_file","read_file"],search_and_replace:["edit_file","read_file"],patch_file:["edit_file","write_file"],run_command:["search_codebase"],search_codebase:["read_file","list_dir"],delete_file:["run_command"],create_dir:["run_command"],web_search:["scrape_url"]}[e]??[]}}});function X$(){try{if(Mt.existsSync(jr))return JSON.parse(Mt.readFileSync(jr,"utf-8"))}catch{}return{}}function Q$(n){try{let e=Hr.dirname(jr);Mt.existsSync(e)||Mt.mkdirSync(e,{recursive:!0}),Mt.writeFileSync(jr,JSON.stringify(n,null,2),"utf-8")}catch{}}function ig(n,e){let t=0,s=!1,r=!1;for(let i=e;i<n.length;i++){let o=n[i];if(r){r=!1;continue}if(o==="\\"&&s){r=!0;continue}if(o==='"'){s=!s;continue}if(!s&&(o==="{"&&t++,o==="}"&&(t--,t===0)))return n.slice(e,i+1)}return null}function Ss(n){if(typeof n.name=="string"&&n.arguments&&typeof n.arguments=="object")return{tool:n.name,args:n.arguments};if(typeof n.tool=="string"&&n.args&&typeof n.args=="object")return{tool:n.tool,args:n.args};if(typeof n.name=="string"&&n.parameters&&typeof n.parameters=="object")return{tool:n.name,args:n.parameters};if(n.function&&typeof n.function=="object"){let e=n.function;if(typeof e.name=="string"){let t={};if(typeof e.arguments=="string")try{t=JSON.parse(e.arguments)}catch{t={}}else e.arguments&&typeof e.arguments=="object"&&(t=e.arguments);return{tool:e.name,args:t}}}return null}function sg(n){return n.replace(/"/g,'"').replace(/'/g,"'").replace(/</g,"<").replace(/>/g,">").replace(/&/g,"&")}function Z$(n){let e=[],t=/<<?tool[-_]call\s*>>?([\s\S]*?)<<?\/tool[-_]call\s*>>?/gi,s;for(;(s=t.exec(n))!==null;)try{let r=JSON.parse(s[1].trim()),i=Ss(r);i&&e.push({...i,format:"xml_tags",rawMatch:s[0]})}catch{}return e}function e0(n){let e=[],t=/<<?tool[-_]call\s*>>?([\s\S]*?)<<?\/tool[-_]call\s*>>?/gi,s;for(;(s=t.exec(n))!==null;)try{let r=JSON.parse(s[1].trim());if(r.parameters||r.name){let i=Ss(r);i&&e.push({...i,format:"hermes",rawMatch:s[0]})}}catch{}return e}function t0(n){let e=[],t=/<<?tool[-_]call\s*>>?([\s\S]*?)<<?\/tool[-_]call\s*>>?/gi,s;for(;(s=t.exec(n))!==null;){let r=s[1],i=og(r);for(let o of i)e.push({...o,format:"xml_tool_call_wrapper",rawMatch:s[0]})}return e}function og(n){let e=[],t=[{regex:/<<?read_file\s+path=["']([^"']+)["'][^>]*\/?>>?/gi,tool:"read_file",extract:s=>{let r={path:s[1]},i=/start_line=["'](\d+)["']/i.exec(s[0]);i&&(r.start_line=parseInt(i[1]));let o=/end_line=["'](\d+)["']/i.exec(s[0]);return o&&(r.end_line=parseInt(o[1])),r}},{regex:/<<?write_file\s+path=["']([^"']+)["'][^>]*>>?([\s\S]*?)<<?\/write_file>>?/gi,tool:"write_file",extract:s=>({path:s[1],content:s[2]})},{regex:/<<?edit_file\s+path=["']([^"']+)["']\s+search=["']([\s\S]*?)["']\s+replace=["']([\s\S]*?)["'][^>]*\/?>>?/gi,tool:"search_and_replace",extract:s=>({path:s[1],search:sg(s[2]),replace:sg(s[3])})},{regex:/<<?run_command>>?([\s\S]*?)<<?\/run_command>>?/gi,tool:"run_command",extract:s=>({command:s[1].trim()})},{regex:/<<?search_codebase\s+query=["']([^"']+)["'][^>]*\/?>>?/gi,tool:"search_codebase",extract:s=>({query:s[1]})},{regex:/<<?list_dir\s+path=["']([^"']+)["'][^>]*\/?>>?/gi,tool:"list_dir",extract:s=>{let r={path:s[1]},i=/depth=["'](\d+)["']/i.exec(s[0]);return i&&(r.depth=parseInt(i[1])),r}},{regex:/<<?create_dir\s+path=["']([^"']+)["'][^>]*\/?>>?/gi,tool:"create_dir",extract:s=>({path:s[1]})},{regex:/<<?delete_file\s+path=["']([^"']+)["'][^>]*\/?>>?/gi,tool:"delete_file",extract:s=>({path:s[1]})},{regex:/<<?append_to_file\s+path=["']([^"']+)["'][^>]*>>?([\s\S]*?)<<?\/append_to_file>>?/gi,tool:"append_to_file",extract:s=>({path:s[1],content:s[2]})},{regex:/<<?patch_file\s+path=["']([^"']+)["']\s+start_line=["'](\d+)["']\s+end_line=["'](\d+)["'][^>]*>>?([\s\S]*?)<<?\/patch_file>>?/gi,tool:"patch_file",extract:s=>({path:s[1],start_line:parseInt(s[2]),end_line:parseInt(s[3]),new_content:s[4]})},{regex:/<<?get_file_info\s+path=["']([^"']+)["'][^>]*\/?>>?/gi,tool:"get_file_info",extract:s=>({path:s[1]})},{regex:/<<?move_file\s+from=["']([^"']+)["']\s+to=["']([^"']+)["'][^>]*\/?>>?/gi,tool:"move_file",extract:s=>({from:s[1],to:s[2]})}];for(let s of t){let r;for(s.regex.lastIndex=0;(r=s.regex.exec(n))!==null;)r[0].trim().startsWith("</")||e.push({tool:s.tool,args:s.extract(r),format:"xml_prompt",rawMatch:r[0]})}return e}function n0(n){return og(n)}function s0(n){let e=[],t=/```(?:json|tool_call)?\s*\n([\s\S]*?)\n```/g,s;for(;(s=t.exec(n))!==null;)try{let r=JSON.parse(s[1].trim()),i=Ss(r);i&&e.push({...i,format:"markdown_json",rawMatch:s[0]})}catch{}return e}function r0(n){let e=[],t=/\{\s*"function"\s*:/g,s;for(;(s=t.exec(n))!==null;){let r=ig(n,s.index);if(r)try{let i=JSON.parse(r),o=Ss(i);o&&e.push({...o,format:"function_call",rawMatch:r})}catch{}}return e}function i0(n){let e=[],t=/\{\s*"(?:name|tool)"\s*:/g,s;for(;(s=t.exec(n))!==null;){let r=ig(n,s.index);if(r)try{let i=JSON.parse(r),o=Ss(i);o&&e.push({...o,format:"json_object",rawMatch:r})}catch{}}return e}function o0(n){let e=[],t=/<<?tool[-_]call\s*>>?([\s\S]*?)<<?\/tool[-_]call\s*>>?/gi,s;for(;(s=t.exec(n))!==null;){let r=s[1],i=/<function=([^>]+)>/i.exec(r);if(i){let o=i[1].trim(),a={},l=/<parameter=([^>]+)>([\s\S]*?)<\/parameter>/gi,u;for(;(u=l.exec(r))!==null;){let d=u[1].trim(),f=u[2].trim();f==="true"?f=!0:f==="false"?f=!1:!isNaN(Number(f))&&f!==""&&(f=Number(f)),a[d]=f}e.push({tool:o,args:a,format:"xml_parameters",rawMatch:s[0]})}}return e}function ag(){return Bl||(Bl=new Ul),Bl}var Mt,Hr,rg,jr,Hl,Ul,Bl,lg=L(()=>{"use strict";Mt=O(require("fs")),Hr=O(require("path")),rg=O(require("os")),jr=Hr.join(rg.homedir(),".hablas","model-formats.json");Hl=[{format:"xml_tool_call_wrapper",parse:t0},{format:"xml_prompt",parse:n0},{format:"xml_tags",parse:Z$},{format:"xml_parameters",parse:o0},{format:"hermes",parse:e0},{format:"markdown_json",parse:s0},{format:"function_call",parse:r0},{format:"json_object",parse:i0}],Ul=class{registry;constructor(){this.registry=X$()}parse(e,t,s){if(t&&Array.isArray(t)&&t.length>0){let i=t.filter(o=>o?.function?.name&&typeof o.function.name=="string");if(i.length>0){let o=i.map(a=>({function:{name:a.function.name,arguments:a.function.arguments||{}}}));return s&&this.learnFormat(s,"native"),{toolCalls:o,displayContent:(e||"").trim(),format:"native"}}}let r=e||"";if(!r.trim())return{toolCalls:[],displayContent:"",format:"unknown"};if(s){let i=this.registry[s];if(i&&i.format!=="native"){let o=Hl.find(a=>a.format===i.format);if(o){let a=o.parse(r);if(a.length>0)return this.learnFormat(s,i.format),this.buildResult(a,r)}}}for(let{parse:i}of Hl){let o=i(r);if(o.length>0){let a=o[0].format;return s&&this.learnFormat(s,a),this.buildResult(o,r)}}return{toolCalls:[],displayContent:r.trim(),format:"unknown"}}mightContainToolCall(e){if(!e)return!1;let t=e.trim();return!!(/<<?tool[-_]call[\s>]/i.test(t)||/<function=/i.test(t)||t.includes("```tool_call")||t.includes("```json")&&t.includes('"name"')||/<<?(?:read_file|write_file|run_command|edit_file|search_codebase|create_dir|delete_file|list_dir|append_to_file|patch_file|move_file|get_file_info)[\s>]/i.test(t)||t.startsWith("{")&&(t.includes('"name"')||t.includes('"tool"'))&&(t.includes('"arguments"')||t.includes('"args"')||t.includes('"parameters"'))||t.includes('"function"')&&t.includes('"name"'))}detectFormat(e){for(let{format:t,parse:s}of Hl)if(s(e).length>0)return t;return"unknown"}learnFormat(e,t){let s=this.registry[e];s&&s.format===t?(s.successCount++,s.lastUsed=new Date().toISOString()):this.registry[e]={format:t,successCount:1,lastUsed:new Date().toISOString()},Q$(this.registry)}getLearnedFormat(e){return this.registry[e]?.format??null}getLearnedFormats(){let e={};for(let[t,s]of Object.entries(this.registry))e[t]={format:s.format,successCount:s.successCount};return e}buildResult(e,t){let s=e.map(o=>({function:{name:o.tool,arguments:o.args}})),r=t,i=[...e].sort((o,a)=>a.rawMatch.length-o.rawMatch.length);for(let o of i)r=r.replace(o.rawMatch,"");return r=r.replace(/<<?thinking>>?[\s\S]*?<<?\/thinking>>?/gi,""),r=r.replace(/<<?think>>?[\s\S]*?<<?\/think>>?/gi,""),r=r.replace(/\n{3,}/g,`
|
|
770
770
|
|
|
771
|
-
`),{toolCalls:s,displayContent:r.trim(),format:e[0]?.format??"unknown"}}},Bl=null});function l0(n,e,t){let r=ag().parse(e,n,t);return{toolCalls:r.toolCalls,displayContent:r.displayContent}}function c0(n,e){return n==="write_file"&&typeof e.path=="string"?`create ${e.path}`:(n==="edit_file"||n==="patch_file"||n==="search_and_replace")&&typeof e.path=="string"?`modify ${e.path}`:n==="read_file"&&typeof e.path=="string"?`read ${e.path}`:n==="run_command"&&typeof e.command=="string"?String(e.command).slice(0,80):typeof e.path=="string"?String(e.path):n.replace(/_/g," ")}function u0(n){let e=(n||"").toLowerCase();return e.includes("eacces")||e.includes("permission")||e.includes("enospc")||e.includes("readonly")||e.includes("security")||e.includes("[write_file]")||e.includes("[delete_file]")||e.includes("[move_file]")||e.includes("[search_and_replace]")}async function dg(n,e,t,s){let r=0,i=Date.now();for(;r<=ug;){let o=await n.execute({name:e,arguments:t});if(o.success||r>=ug)return{success:o.success,output:o.output,error:o.error,duration:Date.now()-i,retries:r};r++,s.info({tool:e,retry:r,error:o.error},"Retrying tool"),await new Promise(a=>setTimeout(a,500))}return{success:!1,output:"",error:"Max retries exceeded",duration:Date.now()-i,retries:r}}async function Br(n){let{identity:e,client:t,registry:s,session:r,contextManager:i,logger:o,io:a={},safetyPolicy:l,abortSignal:u,skipTools:d}=n,f=n.reactEngine??ws(),h=n.errorRecovery??xs(),m=d?[]:s.getOllamaTools(),p=t.getModel(),g=n.maxIterations??a0,w=[],_=[],k=[]
|
|
771
|
+
`),{toolCalls:s,displayContent:r.trim(),format:e[0]?.format??"unknown"}}},Bl=null});function l0(n,e,t){let r=ag().parse(e,n,t);return{toolCalls:r.toolCalls,displayContent:r.displayContent}}function c0(n,e){return n==="write_file"&&typeof e.path=="string"?`create ${e.path}`:(n==="edit_file"||n==="patch_file"||n==="search_and_replace")&&typeof e.path=="string"?`modify ${e.path}`:n==="read_file"&&typeof e.path=="string"?`read ${e.path}`:n==="run_command"&&typeof e.command=="string"?String(e.command).slice(0,80):typeof e.path=="string"?String(e.path):n.replace(/_/g," ")}function u0(n){let e=(n||"").toLowerCase();return e.includes("eacces")||e.includes("permission")||e.includes("enospc")||e.includes("readonly")||e.includes("security")||e.includes("[write_file]")||e.includes("[delete_file]")||e.includes("[move_file]")||e.includes("[search_and_replace]")}async function dg(n,e,t,s){let r=0,i=Date.now();for(;r<=ug;){let o=await n.execute({name:e,arguments:t});if(o.success||r>=ug)return{success:o.success,output:o.output,error:o.error,duration:Date.now()-i,retries:r};r++,s.info({tool:e,retry:r,error:o.error},"Retrying tool"),await new Promise(a=>setTimeout(a,500))}return{success:!1,output:"",error:"Max retries exceeded",duration:Date.now()-i,retries:r}}async function Br(n){let{identity:e,client:t,registry:s,session:r,contextManager:i,logger:o,io:a={},safetyPolicy:l,abortSignal:u,skipTools:d}=n,f=n.reactEngine??ws(),h=n.errorRecovery??xs(),m=d?[]:s.getOllamaTools(),p=t.getModel(),g=n.maxIterations??a0,w=[],_=[],k=[],$="",y=0,v=!1;for(;y<g;){if(y++,u?.aborted)return{output:$,toolsUsed:qt(w),toolResults:_,touchedFiles:qt(k),iterations:y,success:!1,error:"Aborted",completedNaturally:v};let b=f.buildBudgetWarningPrompt();b&&r.addUserMessage(b,{priority:"critical",tags:["system-budget"]});let x;try{x=await t.chatWithTools(r.getMessages(),m,u)}catch(Y){let T=Y;if(T.name==="AbortError"||u?.aborted)return{output:$,toolsUsed:qt(w),toolResults:_,touchedFiles:qt(k),iterations:y,success:!1,error:"Aborted",completedNaturally:v};if(y<=1){a.onNotice?.(`Transient model error: ${T.message??"unknown"} \u2014 retrying\u2026`,"retry"),await new Promise(S=>setTimeout(S,1e3)),y--;continue}return a.onError?.(T.message??"Model request failed"),{output:$,toolsUsed:qt(w),toolResults:_,touchedFiles:qt(k),iterations:y,success:!1,error:T.message,completedNaturally:v}}let A=x.message?.content||"",E=x.message?.tool_calls,M=f.parseThinking(A);M.hasThinking&&(f.recordStep({thought:M.thinking}),o.debug({thinking:M.thinking.slice(0,200)},"ReAct thinking"));let{toolCalls:C,displayContent:F}=l0(E,A,p);if(F&&F.trim()&&($=F,await a.onAssistantText?.(F,e)),C.length===0){r.addAssistantMessage(A,void 0,e.role),v=!0;break}r.addAssistantMessage(A,C,e.role);let H=C.length;for(let Y=0;Y<C.length;Y++){let T=C[Y];if(!T?.function?.name)continue;let S=T.function.name,Q=T.function.arguments||{},q=s.getSafetyLevel(S)??"confirm";if(!s.get(S)){a.onNotice?.(`Unknown tool: ${S} \u2014 skipping`,"warn"),r.addToolMessage(`Error: Unknown tool "${S}". Available: ${s.getAll().map(Pe=>Pe.name).join(", ")}`);continue}if(await l(S,q,Q)==="skip"){r.addToolMessage(`Tool ${S} was skipped by policy/user.`);break}w.push(S),typeof Q.path=="string"&&k.push(Q.path);let re=c0(S,Q);a.onToolStart?.(S,re,Q),a.onToolCall?.(),f.recordStep({thought:M.hasThinking?`Executing: ${S}`:"",action:S,actionInput:Q});let ee=await dg(s,S,Q,o);a.onToolEnd?.(S,ee.success,ee.error||ee.output,ee.duration,Q);let V;if(ee.success)V=ds(ee.output,cg),f.recordObservation(V.slice(0,300)),_.push({tool:S,success:!0,summary:ee.output.slice(0,150)});else{let Pe=ee.error||"Unknown error",Le=h.analyze(S,Pe,Q);if(V=h.buildRecoveryMessage(Le,Pe),f.recordObservation(`FAILED: ${Pe}`,`Recovery: ${Le.strategy} \u2014 ${Le.suggestion}`),o.info({tool:S,errorClass:Le.errorClass,strategy:Le.strategy},"Error recovery analysis"),_.push({tool:S,success:!1,summary:Pe.slice(0,150)}),Le.autoRetry&&!f.isOverBudget()){a.onNotice?.("Auto-retrying (transient error)\u2026","retry");let ie=await dg(s,S,Q,o);a.onToolEnd?.(S,ie.success,ie.output,ie.duration,Q),ie.success&&(V=ds(ie.output,cg),f.recordObservation(V.slice(0,300),"Auto-retry succeeded"),_[_.length-1]={tool:S,success:!0,summary:ie.output.slice(0,150)})}}if(r.addToolMessage(V),ee.success&&S==="read_file"&&typeof Q.path=="string"&&i?.addFile(Q.path,ee.output),o.info({tool:S,success:ee.success,durationMs:ee.duration,retries:ee.retries},"Tool executed"),!ee.success&&u0(ee.error)){a.onNotice?.("Critical tool failure \u2014 aborting subsequent tool executions.","warn");break}H>1&&Y<H-1}f.isOverBudget()&&a.onNotice?.(`Reached max reasoning steps (${f.getConfig().maxSteps}). Wrapping up.`,"warn")}return y>=g&&!v&&a.onNotice?.(`Reached max iterations (${g}). Stopping.`,"warn"),o.info({summary:f.getTurnSummary(),agent:e.name},"Agentic turn completed"),{output:$,toolsUsed:qt(w),toolResults:_,touchedFiles:qt(k),iterations:y,success:!0,completedNaturally:v}}function qt(n){return[...new Set(n)]}function fg(n){return async(e,t)=>{let s=e.replace(/_/g," ");return!n.autoMode&&n.interactive?t==="confirm"&&n.confirm?await n.confirm(`Proceed with ${s}?`)?"allow":"skip":t==="dangerous"&&n.confirmDangerous?await n.confirmDangerous(`Dangerous: ${s}`)?"allow":"skip":"allow":!n.autoMode&&t==="dangerous"?"skip":"allow"}}function pg(){return(n,e)=>e==="dangerous"?"skip":"allow"}var a0,cg,ug,ql=L(()=>{"use strict";ya();Fl();jl();lg();a0=150,cg=2e3,ug=2});var mg,d0,f0,p0,hg,Ur,gg=L(()=>{"use strict";mg=O(Dl());Bn();va();ba();mn();Fi();Ba();ql();d0={hablas:"planner",bob:"architect",alex:"coder",david:"researcher",emma:"product-manager"},f0=(0,mg.default)({level:"silent"}),p0=40,hg={hablas:{role:"hablas",model:"stepfun-ai/step-3.7-flash",temperature:.7},bob:{role:"bob",model:"stepfun-ai/step-3.7-flash",temperature:.4},alex:{role:"alex",model:"stepfun-ai/step-3.7-flash",temperature:.2},david:{role:"david",model:"stepfun-ai/step-3.7-flash",temperature:.5},emma:{role:"emma",model:"stepfun-ai/step-3.7-flash",temperature:.6}},Ur=class{baseConfig;agentModels;toolRegistry=null;onOutput=null;channel=null;mindsetRegistry=br();sharedContext=null;contextManager;constructor(e){this.baseConfig=e,this.agentModels=qn(),this.contextManager=new on(e)}setSharedContext(e){this.sharedContext=e}setChannel(e){this.channel=e}setToolRegistry(e){this.toolRegistry=e}setOutputCallback(e){this.onOutput=e}reloadModels(){this.agentModels=qn()}getAgentModel(e){let t=this.agentModels[e];if(t)return{model:t.model,temperature:t.temperature??hg[e]?.temperature??.5};let s=hg[e];return{model:s.model,temperature:s.temperature??.5}}async runAgent(e,t,s,r,i){let o=Date.now(),a=Se.find(k=>k.role===e),l=this.getAgentModel(e),u=i?.maxIterations||p0,d={...this.baseConfig,model:l.model},f=Ne(d),h=this.buildAgentPrompt(a,s),m=new an(h,30,this.baseConfig.contextBudget);m.addUserMessage(t);let p={name:a.name,title:a.title,role:e};this.emit(a.name,"thinking",`\u2605 Hablas \u2192 Delegating to @${a.name} (${a.title})...`);let g={onAssistantText:k=>{this.emit(a.name,"speaking",k.slice(0,200))},onToolStart:(k,$,y)=>{this.emit(a.name,"tool",$),this.channel&&this.channel.emitEvent({type:"act",agent:a.name,toolName:k,toolArgs:this.safeArgs(y),content:$})},onToolEnd:(k,$,y)=>{this.channel&&this.channel.emitEvent({type:"observe",agent:a.name,toolName:k,success:$,content:$?this.summarizeOk(k,y):`error: ${y.slice(0,120)}`})},onError:k=>this.emit(a.name,"error",k)},w=await Br({identity:p,client:f,registry:this.toolRegistry,session:m,contextManager:this.contextManager,logger:f0,io:g,safetyPolicy:pg(),abortSignal:i?.abortSignal,skipTools:(!r||r.length===0,!1),maxIterations:u});if(this.sharedContext&&w.touchedFiles.length)try{this.sharedContext.set(`files:@${a.name}`,w.touchedFiles.join(", "))}catch{}let _=w.touchedFiles.length?[`@${a.name} touched: ${w.touchedFiles.join(", ")}`]:[];return{agent:e,agentName:a.name,output:w.output||(w.success?"Done.":w.error??"No output"),toolsUsed:w.toolsUsed,toolResults:w.toolResults,duration:Date.now()-o,iterations:w.iterations,success:w.success,error:w.error,discoveries:_,touchedFiles:w.touchedFiles}}async runSequential(e,t,s){let r=[],i="",o=[];for(let a=0;a<e.length;a++){let{role:l,task:u}=e[a];if(s?.abortSignal?.aborted)break;let d=[];if(i&&(d.push("## Previous Agent Results"),d.push(i)),o.length>0){d.push(`
|
|
772
772
|
## Handoff Chain`);for(let p of o)d.push(`- @${p.from} \u2192 @${p.to}: ${p.context.slice(0,100)}`)}let f=d.join(`
|
|
773
773
|
`),h=Se.find(p=>p.role===l);if(h&&a>0){let p=e[a-1].role,g=Se.find(w=>w.role===p);this.emit(h.name,"thinking",`\u2605 Handoff: @${g?.name||p} \u2192 @${h.name} (${h.title})`)}let m=await this.runAgent(l,u,f,t,s);if(r.push(m),m.success&&m.output){let p=m.output.length>600?m.output.slice(0,600)+"...":m.output;i+=`
|
|
774
774
|
|
|
@@ -840,7 +840,7 @@ Expertise: ${e.expertise.join(", ")}
|
|
|
840
840
|
${t}`),this.sharedContext){let a=this.sharedContext.getSummary();a&&(o+=`
|
|
841
841
|
|
|
842
842
|
## Shared Team Context
|
|
843
|
-
${a}`)}return o}emit(e,t,s){if(this.onOutput&&this.onOutput(e,t,s),this.channel){let r=t==="speaking"?"speak":t==="tool"?"act":t;this.channel.emitEvent({type:r,agent:e,content:s})}}safeArgs(e){let t={};for(let[s,r]of Object.entries(e||{}))typeof r=="string"?t[s]=r.length>160?r.slice(0,160)+"\u2026":r:(typeof r=="number"||typeof r=="boolean")&&(t[s]=r);return t}summarizeOk(e,t){let s=t.split(/\r?\n/).length;return e==="write_file"||e==="edit_file"||e==="patch_file"?`ok \xB7 ${s} line${s===1?"":"s"}`:e==="run_command"?`ok \xB7 ${t.split(/\r?\n/).find(i=>i.trim())?.slice(0,80)||"ok"}`:e==="read_file"?`ok \xB7 ${s} line${s===1?"":"s"} read`:"ok"}}});var yg,qr,bg=L(()=>{"use strict";yg=require("events"),qr=class extends yg.EventEmitter{events=[];maxHistory;constructor(e=500){super(),this.setMaxListeners(50),this.maxHistory=e}emitEvent(e){let t={...e,timestamp:Date.now()};return this.events.push(t),this.events.length>this.maxHistory&&this.events.splice(0,this.events.length-this.maxHistory),this.emit("event",t),this.emit(t.type,t),t}history(){return[...this.events]}reset(){this.events=[]}onEvent(e){return this.on("event",e),this}offEvent(e){return this.off("event",e),this}}});var h0,yt,Kr,Wr,vg=L(()=>{"use strict";Bn();h0={hablas:"Hablas \u2014 INTJ Team Leader. Authoritative, terse, engineering-precise. Speaks in short systemic statements. No pleasantries.",emma:"Emma \u2014 Product Manager. Calm, user-focused, structured. Clarifies scope and outcomes in plain language.",bob:"Bob \u2014 System Architect. Methodical, principled, slightly formal. Talks in terms of boundaries, trade-offs, contracts.",alex:"Alex \u2014 Senior Engineer. Pragmatic, concise, action-biased. Confirms intent, then ships.",david:"David \u2014 Data & Research Analyst. Factual, evidence-driven, neutral tone. Cites context, not opinions."},yt={hablas:"Hablas",emma:"Emma",bob:"Bob",alex:"Alex",david:"David"},Kr={handoff:(n,e,t)=>{let s=yt[e];return{hablas:`Routing this to you, @${s}.`,emma:`@${s}, I need the requirements framed before we move.`,bob:`@${s}, design the structure for this. Keep boundaries clean.`,alex:`@${s}, you have the implementation. Stay surgical.`,david:`@${s}, gather the context we need on this.`}[e]||`@${s}, taking this from here.`},ack:(n,e)=>`Acknowledged, @${yt[e]}. Proceeding.`,review:(n,e)=>`@${yt[e]}, structurally sound. Watch the boundaries on the next pass.`,reviewAck:(n,e)=>`Noted, @${yt[e]}. Integrating.`},Wr=class{client;spent=0;cache=new Map;opts;constructor(e,t={}){this.opts={tokenBudget:t.tokenBudget??500,maxChars:t.maxChars??140,lightModel:t.lightModel,abortSignal:t.abortSignal};let s={...e,model:this.opts.lightModel||e.model};this.client=
|
|
843
|
+
${a}`)}return o}emit(e,t,s){if(this.onOutput&&this.onOutput(e,t,s),this.channel){let r=t==="speaking"?"speak":t==="tool"?"act":t;this.channel.emitEvent({type:r,agent:e,content:s})}}safeArgs(e){let t={};for(let[s,r]of Object.entries(e||{}))typeof r=="string"?t[s]=r.length>160?r.slice(0,160)+"\u2026":r:(typeof r=="number"||typeof r=="boolean")&&(t[s]=r);return t}summarizeOk(e,t){let s=t.split(/\r?\n/).length;return e==="write_file"||e==="edit_file"||e==="patch_file"?`ok \xB7 ${s} line${s===1?"":"s"}`:e==="run_command"?`ok \xB7 ${t.split(/\r?\n/).find(i=>i.trim())?.slice(0,80)||"ok"}`:e==="read_file"?`ok \xB7 ${s} line${s===1?"":"s"} read`:"ok"}}});var yg,qr,bg=L(()=>{"use strict";yg=require("events"),qr=class extends yg.EventEmitter{events=[];maxHistory;constructor(e=500){super(),this.setMaxListeners(50),this.maxHistory=e}emitEvent(e){let t={...e,timestamp:Date.now()};return this.events.push(t),this.events.length>this.maxHistory&&this.events.splice(0,this.events.length-this.maxHistory),this.emit("event",t),this.emit(t.type,t),t}history(){return[...this.events]}reset(){this.events=[]}onEvent(e){return this.on("event",e),this}offEvent(e){return this.off("event",e),this}}});var h0,yt,Kr,Wr,vg=L(()=>{"use strict";Bn();h0={hablas:"Hablas \u2014 INTJ Team Leader. Authoritative, terse, engineering-precise. Speaks in short systemic statements. No pleasantries.",emma:"Emma \u2014 Product Manager. Calm, user-focused, structured. Clarifies scope and outcomes in plain language.",bob:"Bob \u2014 System Architect. Methodical, principled, slightly formal. Talks in terms of boundaries, trade-offs, contracts.",alex:"Alex \u2014 Senior Engineer. Pragmatic, concise, action-biased. Confirms intent, then ships.",david:"David \u2014 Data & Research Analyst. Factual, evidence-driven, neutral tone. Cites context, not opinions."},yt={hablas:"Hablas",emma:"Emma",bob:"Bob",alex:"Alex",david:"David"},Kr={handoff:(n,e,t)=>{let s=yt[e];return{hablas:`Routing this to you, @${s}.`,emma:`@${s}, I need the requirements framed before we move.`,bob:`@${s}, design the structure for this. Keep boundaries clean.`,alex:`@${s}, you have the implementation. Stay surgical.`,david:`@${s}, gather the context we need on this.`}[e]||`@${s}, taking this from here.`},ack:(n,e)=>`Acknowledged, @${yt[e]}. Proceeding.`,review:(n,e)=>`@${yt[e]}, structurally sound. Watch the boundaries on the next pass.`,reviewAck:(n,e)=>`Noted, @${yt[e]}. Integrating.`},Wr=class{client;spent=0;cache=new Map;opts;constructor(e,t={}){this.opts={tokenBudget:t.tokenBudget??500,maxChars:t.maxChars??140,lightModel:t.lightModel,abortSignal:t.abortSignal};let s={...e,model:this.opts.lightModel||e.model};this.client=Ne(s)}resetBudget(){this.spent=0,this.cache.clear()}setAbortSignal(e){this.opts.abortSignal=e}async generateHandoffLine(e,t,s){return this.generate(`handoff:${e}:${t}:${this.hash(s)}`,this.buildPrompt(e,t,"handoff",s),()=>Kr.handoff(e,t,s))}async generateAckLine(e,t){return this.generate(`ack:${e}:${t}`,this.buildPrompt(e,t,"ack"),()=>Kr.ack(e,t))}async generateReviewLine(e,t,s){return this.generate(`review:${e}:${t}:${this.hash(s.slice(0,200))}`,this.buildPrompt(e,t,"review",s.slice(0,400)),()=>Kr.review(e,t))}async generateReviewAck(e,t){return this.generate(`reviewAck:${e}:${t}`,this.buildPrompt(e,t,"reviewAck"),()=>Kr.reviewAck(e,t))}async generate(e,t,s){let r=this.cache.get(e);if(r)return r;if(this.spent>=this.opts.tokenBudget||this.opts.abortSignal?.aborted)return s();try{let o=((await this.client.chatWithTools(t,[],this.opts.abortSignal)).message?.content||"").trim(),a=this.cleanLine(o);return a?(this.spent+=Math.ceil(a.length/4)+40,this.cache.set(e,a),a):s()}catch{return s()}}buildPrompt(e,t,s,r){let i=`You are ${yt[e]}, speaking in your own voice.
|
|
844
844
|
${h0[e]}
|
|
845
845
|
|
|
846
846
|
Hard constraints:
|
|
@@ -901,7 +901,7 @@ Please compile, synthesize, and present the final unified response to the user.
|
|
|
901
901
|
${d.output}`}).join(`
|
|
902
902
|
|
|
903
903
|
`);return{results:t,finalSynthesis:u,synthesisOk:!1}}}});function ct(n){switch(n){case"Hablas":return c.leader;case"Bob":return c.architect;case"Alex":return c.engineer;case"David":return c.analyst;case"Emma":return c.product;default:return c.primary}}function Gr(n){return n==="Hablas"?"\u2605":"\u25C6"}function _s(n,e=140){let t=(n||"").replace(/\s+/g," ").trim();return t.length>e?t.slice(0,e-1)+"\u2026":t}var Vr,kg=L(()=>{"use strict";xn();Vr=class{channel;opts;attached=!1;listener;lastThinking=null;lastLine="";constructor(e,t={}){this.channel=e,this.opts={hideThinking:t.hideThinking??!1,hideActs:t.hideActs??!1,maxChars:t.maxChars??140},this.listener=s=>this.handle(s)}attach(){return this.attached?this:(this.channel.onEvent(this.listener),this.attached=!0,this)}detach(){return this.attached?(this.channel.offEvent(this.listener),this.attached=!1,this):this}handle(e){switch(e.type){case"phase":return this.renderPhase(e);case"handoff":return this.renderHandoff(e);case"thinking":return this.renderThinking(e);case"speak":return this.renderSpeak(e);case"act":return this.renderAct(e);case"observe":return this.renderObserve(e);case"review":return this.renderReview(e);case"summary":return this.renderSummary(e);case"decision":return this.renderDecision(e);case"done":return this.renderDone(e);case"error":return this.renderError(e)}}renderPhase(e){let t=(e.content||"").toString();t&&(this.print(`
|
|
904
|
-
${c.muted("\u25B8")} ${c.secondary(t)}`),this.lastThinking=null)}renderHandoff(e){let t=e.agent,s=e.to||"";if(!s)return;let r=ct(t),i=ct(s);this.print(` ${r(Gr(t))} ${r(t)} ${c.muted("\u2501\u2501\u25B6")} ${i(Gr(s))} ${i(s)}`),this.lastThinking=null}renderThinking(e){if(this.opts.hideThinking||this.lastThinking===e.agent)return;this.lastThinking=e.agent;let t=ct(e.agent);this.print(` ${t("\u25C9")} ${
|
|
904
|
+
${c.muted("\u25B8")} ${c.secondary(t)}`),this.lastThinking=null)}renderHandoff(e){let t=e.agent,s=e.to||"";if(!s)return;let r=ct(t),i=ct(s);this.print(` ${r(Gr(t))} ${r(t)} ${c.muted("\u2501\u2501\u25B6")} ${i(Gr(s))} ${i(s)}`),this.lastThinking=null}renderThinking(e){if(this.opts.hideThinking||this.lastThinking===e.agent)return;this.lastThinking=e.agent;let t=ct(e.agent);this.print(` ${t("\u25C9")} [Active Agent: ${e.agent}] is thinking & formulating response\u2026`)}renderSpeak(e){let t=_s(e.content||"",this.opts.maxChars);if(!t)return;let s=ct(e.agent),r=e.to?` ${c.muted("\u2192")} ${ct(e.to)("@"+e.to)}`:"",i=`speak:${e.agent}:${e.to||""}:${t}`;i!==this.lastLine&&(this.lastLine=i,this.print(` ${s(Gr(e.agent))} ${s(e.agent)}${r}${c.muted(":")} ${c.secondary(t)}`),this.lastThinking=null)}renderAct(e){if(this.opts.hideActs)return;let t=ct(e.agent),s=e.toolName||"tool",r=e.toolArgs||{},i="";typeof r.path=="string"?i=` ${c.primary(r.path)}`:typeof r.command=="string"?i=` ${c.primary(r.command)}`:typeof r.query=="string"&&(i=` "${c.primary(r.query)}"`);let o=s==="write_file"||s==="edit_file"||s==="patch_file"?"\u270E":s==="run_command"?"\u2318":s==="read_file"?"\u{1F4D6}":s==="search_codebase"?"\u{1F50E}":"\u{1F527}";this.print(` ${t(o)} [Running Tool]: ${t(e.agent)} is executing ${c.strong(s)}${i}...`),this.lastThinking=null}renderObserve(e){if(this.opts.hideActs)return;let t=e.success!==!1,s=t?c.success("\u2713 COMPLETED"):c.error("\u2717 FAILED"),r=_s(e.content||(t?"Execution succeeded":"Execution failed"),this.opts.maxChars);this.print(` ${c.muted("\u21B3")} ${s}: ${c.muted(r)}`)}renderReview(e){let t=e.agent,s=e.to||"",r=_s(e.content||"",this.opts.maxChars);if(!r)return;let i=ct(t),o=ct(s);this.print(`
|
|
905
905
|
${i("\u270E")} ${c.strong("@"+t)} ${c.muted("reviewing")} ${o("@"+s)}${c.muted(":")} ${c.secondary(r)}`),this.lastThinking=null}renderSummary(e){let t=ct(e.agent),s=e.durationMs?` ${c.muted(`(${(e.durationMs/1e3).toFixed(1)}s)`)}`:"";this.print(` ${t(Gr(e.agent))} ${t(e.agent)} ${c.muted("\u2500\u2500\u25BA")} ${c.leader("\u2605 Hablas")} ${c.muted("\xB7 report submitted")}${s}`),this.lastThinking=null}renderDecision(e){let t=_s(e.content||"",this.opts.maxChars);if(!t)return;let s=ct(e.agent);this.print(` ${s("\u25C6")} ${s(e.agent)} ${c.muted("decision:")} ${c.secondary(t)}`)}renderDone(e){this.print(`
|
|
906
906
|
${c.chrome("\u2500".repeat(56))}`),this.lastThinking=null}renderError(e){let t=ct(e.agent),s=_s(e.content||"unknown error",this.opts.maxChars);this.print(` ${t("\u25C6")} ${t(e.agent)} ${c.error("\u2717")} ${c.error(s)}`),this.lastThinking=null}print(e){console.log(e)}}});var zr,Ag=L(()=>{"use strict";zr=class{plans=new Map;activePlanId=null;nextPlanNum=1;createPlan(e,t,s){let r=`plan_${this.nextPlanNum++}`,i={hablas:"Hablas",bob:"Bob",alex:"Alex",david:"David"},o={id:r,title:e,strategy:t,tasks:s.map((a,l)=>({task_id:`${r}_t${l+1}`,dependent_task_ids:a.dependent_task_ids||[],description:a.description,assignee:a.assignee,assigneeName:a.assigneeName||i[a.assignee]||a.assignee,status:"pending",createdAt:Date.now()})),createdAt:Date.now(),updatedAt:Date.now()};return this.plans.set(r,o),this.activePlanId=r,o}getActivePlan(){return this.activePlanId&&this.plans.get(this.activePlanId)||null}getTask(e){let t=this.getActivePlan();return t&&t.tasks.find(s=>s.task_id===e)||null}startTask(e){let t=this.getTask(e);return!t||!this.areDependenciesMet(e)?!1:(t.status="running",t.startedAt=Date.now(),this.touch(),!0)}finishTask(e,t){let s=this.getTask(e);return s?(s.status="done",s.result=t,s.completedAt=Date.now(),this.touch(),!0):!1}failTask(e,t){let s=this.getTask(e);return s?(s.status="failed",s.error=t,s.completedAt=Date.now(),this.touch(),!0):!1}skipTask(e){let t=this.getTask(e);return t?(t.status="skipped",t.completedAt=Date.now(),this.touch(),!0):!1}resetTask(e){let t=this.getTask(e);return t?(t.status="pending",t.result=void 0,t.error=void 0,t.startedAt=void 0,t.completedAt=void 0,this.touch(),!0):!1}replaceTask(e,t,s){let r=this.getTask(e);return r?(r.description=t,s&&(r.assignee=s),r.status="pending",r.result=void 0,r.error=void 0,this.touch(),!0):!1}areDependenciesMet(e){let t=this.getTask(e);if(!t)return!1;if(t.dependent_task_ids.length===0)return!0;let s=this.getActivePlan();return s?t.dependent_task_ids.every(r=>{let i=s.tasks.find(o=>o.task_id===r);return i&&(i.status==="done"||i.status==="skipped")}):!1}getNextTask(){let e=this.getActivePlan();if(!e)return null;for(let t of e.tasks)if(t.status==="pending"&&this.areDependenciesMet(t.task_id))return t;return null}getDependencyOrder(){let e=this.getActivePlan();if(!e)return[];let t=new Set,s=[],r=new Map(e.tasks.map(o=>[o.task_id,o])),i=o=>{if(t.has(o))return;t.add(o);let a=r.get(o);if(a){for(let l of a.dependent_task_ids)i(l);s.push(a)}};for(let o of e.tasks)i(o.task_id);return s}getProgress(){let e=this.getActivePlan();if(!e)return{total:0,done:0,failed:0,pending:0,running:0,skipped:0,percentage:0};let t=e.tasks.length,s=e.tasks.filter(u=>u.status==="done").length,r=e.tasks.filter(u=>u.status==="failed").length,i=e.tasks.filter(u=>u.status==="pending").length,o=e.tasks.filter(u=>u.status==="running").length,a=e.tasks.filter(u=>u.status==="skipped").length,l=t>0?Math.round((s+a)/t*100):0;return{total:t,done:s,failed:r,pending:i,running:o,skipped:a,percentage:l}}isComplete(){let e=this.getActivePlan();return e?e.tasks.every(t=>t.status==="done"||t.status==="failed"||t.status==="skipped"):!0}serialize(){let e=this.getActivePlan();return e?JSON.stringify(e,null,2):"{}"}deserialize(e){try{let t=JSON.parse(e);return t.id&&t.tasks?(this.plans.set(t.id,t),this.activePlanId=t.id,t):null}catch{return null}}reset(){this.plans.clear(),this.activePlanId=null,this.nextPlanNum=1}clear(){this.plans.clear(),this.activePlanId=null}touch(){let e=this.getActivePlan();e&&(e.updatedAt=Date.now())}}});var pe,ut,y0,b0,v0,w0,x0,S0,_0,Yr,$g=L(()=>{"use strict";pe=O(require("fs")),ut=O(require("path")),y0=".hablas",b0=`# Project Context \u2014 Hablas AI
|
|
907
907
|
|
|
@@ -1016,40 +1016,40 @@ ${d}`),o+=d.length}}}extractSection(e,t){let s=e.split(`
|
|
|
1016
1016
|
`+s+`
|
|
1017
1017
|
`,"utf-8");return}let l=a+1;for(;l<o.length;){let u=o[l].trim();if(/^#{1,2}\s/.test(u))break;l++}o.splice(l,0,s),pe.writeFileSync(r,o.join(`
|
|
1018
1018
|
`),"utf-8")}}});function Gl(n){let e=n.trim(),t=e.toLowerCase();if(k0.test(e)||A0.test(e)||e.length<15&&!$0.test(e))return"XS";if(E0.test(t)||Cg.test(t)&&e.length>150)return"XL";let s=t.match(T0)||[],i=new Set(s.map(a=>a.toLowerCase())).size,o=e.split(/[.!?]+/).filter(a=>a.trim().length>5);return Cg.test(t)||o.length>=3&&i>=2||i>=3&&e.length>100?"L":R0.test(t)||i>=2&&e.length>=50||e.length>=50&&e.length<=150&&i>=1&&o.length>=2?"M":(e.length<50&&i<=1||C0.test(e)&&i<=1||i===1,"S")}function Tg(n,e,t){let s=`sp-${Date.now()}`,r=[],i=1,o=t.includes("emma"),a=t.includes("bob"),l=t.includes("alex"),u=t.includes("david");switch(e){case"XS":break;case"S":r.push({id:`${s}-t${i++}`,description:`Execute: ${n.substring(0,80)}`,assignee:l?"alex":t.find(f=>f!=="hablas")||"alex",dependencies:[]});break;case"M":{u&&r.push({id:`${s}-t${i++}`,description:"Research requirements and gather context",assignee:"david",dependencies:[]});let f=r.length>0?[r[r.length-1].id]:[];r.push({id:`${s}-t${i++}`,description:`Implement: ${n.substring(0,60)}`,assignee:l?"alex":"hablas",dependencies:f});break}case"L":{if(u&&r.push({id:`${s}-t${i++}`,description:"Research requirements, best practices, and relevant documentation",assignee:"david",dependencies:[]}),a){let f=r.length>0?[r[r.length-1].id]:[];r.push({id:`${s}-t${i++}`,description:"Design system architecture and structure",assignee:"bob",dependencies:f})}if(l){let f=r.length>0?[r[r.length-1].id]:[];r.push({id:`${s}-t${i++}`,description:"Implement the code based on architecture/requirements",assignee:"alex",dependencies:f})}break}case"XL":{if(o&&r.push({id:`${s}-t${i++}`,description:"Analyze requirements and create PRD with user stories",assignee:"emma",dependencies:[]}),u){let f=r.length>0?[r[r.length-1].id]:[];r.push({id:`${s}-t${i++}`,description:"Research best practices, technologies, and competitive landscape",assignee:"david",dependencies:f})}if(a){let f=r.length>0?[r[r.length-1].id]:[];r.push({id:`${s}-t${i++}`,description:"Design complete system architecture, database schema, and API structure",assignee:"bob",dependencies:f})}if(l){let f=r.length>0?[r[r.length-1].id]:[];r.push({id:`${s}-t${i++}`,description:"Implement the full system based on PRD and architecture",assignee:"alex",dependencies:f})}break}}let d;return r.length<=1?d="direct":r.every((f,h)=>h===0||f.dependencies.length>0)?d="sequential":d="mixed",{id:s,title:n.substring(0,100),complexity:e,tasks:r,strategy:d,requiresApproval:e==="L"||e==="XL",createdAt:Date.now()}}var k0,A0,$0,C0,T0,E0,Cg,R0,Eg=L(()=>{"use strict";k0=/^(hi|hello|hey|howdy|yo|sup|hiya|good\s*(morning|afternoon|evening|night)|what'?s\s*up|greetings|thanks?|thank\s*you|bye|goodbye|ok(ay)?|yes|no|cool|nice|great|got\s*it|sure|مرحبا|أهلا|هلا|السلام\s*عليكم|كيف\s*حالك)\b/i,A0=/^(how\s*are\s*you|what'?s\s*your\s*name|who\s*are\s*you|what\s*can\s*you\s*do|help|tell\s*me\s*about\s*yourself)\s*[?!.]*$/i,$0=/\b(create|build|implement|write|generate|code|make|develop|design|architect|setup|configure|install|deploy|fix|debug|refactor|rewrite|restructure|migrate|convert|add|remove|delete|update|change|modify|edit|move|rename|test|run|execute|analyze|research|find|search|compare|optimize)\b/i,C0=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|scss|html|vue|svelte|go|rs|java|c|cpp|h|rb|php|sql|sh|toml|xml|env)/i,T0=/\b(create|build|implement|write|generate|design|architect|setup|configure|deploy|fix|debug|refactor|rewrite|restructure|migrate|add|remove|update|change|modify|test|analyze|research|optimize)\b/gi,E0=/\b(full\s+system|complete\s+project|from\s+scratch|entire\s+application|prd|product\s+requirements|architecture\s+.*implementation\s+.*deployment|end[\s-]*to[\s-]*end)\b/i,Cg=/\b(design|architect)\b.*\b(implement|build|create|develop)\b/i,R0=/\b(multiple\s+files|several\s+components|across\s+all|every\s+file|all\s+modules)\b/i});function Pg(n){let e=n.trim();if(e.length<20||Un(e)||Rg.test(e)||e.includes("```")||O0.test(e)||/\/[\w-]+\.[\w]+/.test(e)||e.length<60&&Rg.test(e))return null;for(let{pattern:t,question:s,choices:r}of P0)if(t.test(e))return e.length>40&&/\b(called|named|using|with|for)\b/i.test(e)?null:{question:s,choices:r,context:e};return null}function Og(n,e){let t=n.trim().toLowerCase(),s=t.split(/[,\s]+/).filter(i=>/^[a-z]$/.test(i));if(s.length>0)return s.map(i=>{let o=i.charCodeAt(0)-97;return e.choices[o]?.value}).filter(i=>i!==void 0);let r=t.split(/[,\s]+/).filter(i=>/^\d+$/.test(i));return r.length>0?r.map(i=>{let o=parseInt(i,10)-1;return e.choices[o]?.value}).filter(i=>i!==void 0):[t]}var P0,Rg,O0,Mg=L(()=>{"use strict";mn();P0=[{pattern:/\b(create|make|build)\s+(a|an|the)?\s*(app|application|project)\b/i,question:"What type of application would you like to create?",choices:[{label:"Web application (React/Next.js)",value:"web"},{label:"CLI tool (Node.js)",value:"cli"},{label:"API server (Express/Fastify)",value:"api"},{label:"Something else (please describe)",value:"other"}]},{pattern:/\b(refactor|rewrite|restructure)\s+(the\s+)?(entire|whole|all)\b/i,question:"Large-scale refactoring detected. How would you like to proceed?",choices:[{label:"Incremental \u2014 one module at a time",value:"incremental"},{label:"Full rewrite \u2014 replace everything",value:"full"},{label:"Just the architecture \u2014 keep implementations",value:"architecture"},{label:"Let me specify which parts",value:"specify"}]},{pattern:/\b(delete|remove|drop)\s+(all|every|the\s+entire)\b/i,question:"This is a destructive operation. Please confirm scope:",choices:[{label:"Yes, remove everything matching",value:"all"},{label:"Only unused/dead code",value:"unused"},{label:"Let me be more specific",value:"specify"},{label:"Cancel \u2014 don't delete anything",value:"cancel"}]},{pattern:/\b(setup|configure|install)\s+(the\s+)?(project|environment|dev)\b/i,question:"What environment are you setting up?",choices:[{label:"Development (local)",value:"dev"},{label:"Production deployment",value:"prod"},{label:"CI/CD pipeline",value:"ci"},{label:"Docker/containerized",value:"docker"}]},{pattern:/\b(fix|debug|solve)\s+(the\s+)?(issue|bug|problem|error)\b/i,question:"Can you provide more details about the issue?",choices:[{label:"Runtime error (crashes/exceptions)",value:"runtime"},{label:"Build/compile error",value:"build"},{label:"Logic bug (wrong behavior)",value:"logic"},{label:"Performance issue (slow)",value:"performance"}]}],Rg=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|scss|html|vue|svelte|go|rs|java|c|cpp|h|rb|php|sql|sh|bash|toml|xml|env)/i,O0=/\b(fix|update|change|add|remove|rename|move|edit|read|show|cat|open)\s+(the\s+)?(typo|bug|error|import|line|function|variable|class|method|comment|style)/i});var Jr,bt,Qr,Xr,Ig=L(()=>{"use strict";Jr=O(require("fs")),bt=O(require("fs/promises")),Qr=O(require("path")),Xr=class{stack=[];workingDir;maxEntries;nextGroupId=1;constructor(e,t=200){this.workingDir=e,this.maxEntries=t}async record(e,t,s,r="hablas",i){let o=Qr.resolve(this.workingDir,e),a=null;try{Jr.existsSync(o)&&(a=await bt.readFile(o,"utf-8"))}catch{}let l={id:`undo_${Date.now()}_${this.stack.length}`,filePath:e,absolutePath:o,originalContent:a,newContent:t,toolName:s,agent:r,timestamp:Date.now(),undone:!1,groupId:i};return this.stack.push(l),this.stack.length>this.maxEntries&&(this.stack=this.stack.slice(-this.maxEntries)),l.id}beginGroup(){return`group_${this.nextGroupId++}`}async undo(e=1){let t=[],r=this.stack.filter(i=>!i.undone).reverse().slice(0,e);for(let i of r)try{i.originalContent===null?(Jr.existsSync(i.absolutePath)&&await bt.unlink(i.absolutePath),t.push({file:i.filePath,success:!0})):(await bt.mkdir(Qr.dirname(i.absolutePath),{recursive:!0}),await bt.writeFile(i.absolutePath,i.originalContent,"utf-8"),t.push({file:i.filePath,success:!0})),i.undone=!0}catch(o){t.push({file:i.filePath,success:!1,error:o.message})}return t}async undoGroup(e){let t=this.stack.filter(r=>r.groupId===e&&!r.undone).reverse(),s=[];for(let r of t)try{r.originalContent===null?Jr.existsSync(r.absolutePath)&&await bt.unlink(r.absolutePath):await bt.writeFile(r.absolutePath,r.originalContent,"utf-8"),r.undone=!0,s.push({file:r.filePath,success:!0})}catch(i){s.push({file:r.filePath,success:!1,error:i.message})}return s}async undoAll(){return this.undo(this.getUndoableCount())}getUndoableCount(){return this.stack.filter(e=>!e.undone).length}getRecent(e=15){return this.stack.filter(t=>!t.undone).slice(-e).reverse()}getModifiedFiles(){let e=new Set;for(let t of this.stack.filter(s=>!s.undone))e.add(t.filePath);return Array.from(e)}formatList(e=15){let t=this.getRecent(e);if(t.length===0)return" No changes to undo";let s=[];for(let i=0;i<t.length;i++){let o=t[i],a=this.formatAge(o.timestamp),l=o.originalContent===null?"created":"modified",u=o.agent!=="hablas"?` [@${o.agent}]`:"";s.push(` ${i+1}. ${o.filePath} \u2014 ${l} by ${o.toolName}${u} (${a})`)}let r=this.getUndoableCount();return r>e&&s.push(` ... and ${r-e} more`),s.join(`
|
|
1019
|
-
`)}formatAge(e){let t=Date.now()-e,s=Math.floor(t/1e3);if(s<60)return`${s}s ago`;let r=Math.floor(s/60);return r<60?`${r}m ago`:`${Math.floor(r/60)}h ago`}size(){return this.stack.length}clear(){this.stack=[]}}});function M0(n,e){let t=[],s;for(Dg.lastIndex=0;(s=Dg.exec(n))!==null;){let r=s[1],i=
|
|
1019
|
+
`)}formatAge(e){let t=Date.now()-e,s=Math.floor(t/1e3);if(s<60)return`${s}s ago`;let r=Math.floor(s/60);return r<60?`${r}m ago`:`${Math.floor(r/60)}h ago`}size(){return this.stack.length}clear(){this.stack=[]}}});function M0(n,e){let t=[],s;for(Dg.lastIndex=0;(s=Dg.exec(n))!==null;){let r=s[1],i=Ee.resolve(e,r);dt.existsSync(i)&&t.push(r)}return[...new Set(t)]}function I0(n,e,t){let s=[],r=Ee.extname(e),i=Ee.dirname(Ee.resolve(t,e));if([".ts",".tsx",".js",".jsx",".mjs",".cjs"].includes(r)){let o;for(Lg.lastIndex=0;(o=Lg.exec(n))!==null;){let a=o[1]||o[2];if(!a||!a.startsWith(".")&&!a.startsWith("/"))continue;let l=D0(a,i);l&&s.push(Ee.relative(t,l))}}else if(r===".py"){let o;for(Fg.lastIndex=0;(o=Fg.exec(n))!==null;){let a=o[1]||o[2];if(!a)continue;let l=a.replace(/\./g,"/")+".py",u=Ee.resolve(i,l);dt.existsSync(u)&&s.push(Ee.relative(t,u))}}return[...new Set(s)]}function D0(n,e){let t=[".ts",".tsx",".js",".jsx",".mjs",".cjs"],s=Ee.resolve(e,n);if(dt.existsSync(s)&&dt.statSync(s).isFile())return s;for(let r of t){let i=s+r;if(dt.existsSync(i))return i}for(let r of t){let i=Ee.join(s,`index${r}`);if(dt.existsSync(i))return i}return null}function Ng(n,e,t){let s=t?.maxFiles||10,r=t?.maxTokens||8e3,i=t?.followImports!==!1,o=M0(n,e),a=[],l=new Set,u=0;for(let d of o){if(a.length>=s||u>=r)break;if(!l.has(d)){l.add(d);try{let f=Ee.resolve(e,d),h=dt.readFileSync(f,"utf-8"),m=h.split(`
|
|
1020
1020
|
`).length,p=Math.ceil(h.length/4);if(p>4e3){let g=h.split(`
|
|
1021
1021
|
`).slice(0,200).join(`
|
|
1022
1022
|
`)+`
|
|
1023
|
-
...(truncated)`,w=Math.ceil(g.length/4);u+w<=r&&(a.push({path:d,content:g,source:"mentioned",lineCount:200}),u+=w)}else if(u+p<=r&&(a.push({path:d,content:h,source:"mentioned",lineCount:m}),u+=p,i)){let g=I0(h,d,e);for(let w of g.slice(0,5)){if(a.length>=s||u>=r)break;if(!l.has(w)){l.add(w);try{let _=
|
|
1024
|
-
`).length;if(
|
|
1023
|
+
...(truncated)`,w=Math.ceil(g.length/4);u+w<=r&&(a.push({path:d,content:g,source:"mentioned",lineCount:200}),u+=w)}else if(u+p<=r&&(a.push({path:d,content:h,source:"mentioned",lineCount:m}),u+=p,i)){let g=I0(h,d,e);for(let w of g.slice(0,5)){if(a.length>=s||u>=r)break;if(!l.has(w)){l.add(w);try{let _=Ee.resolve(e,w),k=dt.readFileSync(_,"utf-8"),$=Math.ceil(k.length/4),y=k.split(`
|
|
1024
|
+
`).length;if($>2e3){let v=k.split(`
|
|
1025
1025
|
`).slice(0,100).join(`
|
|
1026
1026
|
`)+`
|
|
1027
|
-
...(truncated)`,b=Math.ceil(v.length/4);u+b<=r&&(a.push({path:w,content:v,source:"imported",lineCount:100}),u+=b)}else u
|
|
1028
|
-
`)}var dt,Te,Dg,Lg,Fg,Hg=L(()=>{"use strict";dt=O(require("fs")),Te=O(require("path")),Dg=/(?:^|\s|['"`])([.\w\-/\\]+\.(?:ts|js|tsx|jsx|py|go|rs|java|c|cpp|h|css|scss|html|vue|svelte|json|yaml|yml|toml|md|sql|sh|env|xml))\b/gi,Lg=/(?:import\s+.*?\s+from\s+['"]([^'"]+)['"]|require\s*\(\s*['"]([^'"]+)['"]\s*\))/g,Fg=/(?:from\s+(\S+)\s+import|import\s+(\S+))/g});var Ug={};Le(Ug,{runSetupWizard:()=>Vl});function ve(n,e){return new Promise(t=>{n.question(e,s=>t(s))})}function F0(){return["nvapi-","qJRIIcL3SbN6s91CK-","gk2DtzlHbUnaYvGJk","AoIohOTcABSY5lll","Kdwfj_fO_b55h"].join("")}async function Vl(n){let e=Bg.createInterface({input:process.stdin,output:process.stdout});switch(console.log(),console.log(`${Kt}${We} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${D}`),console.log(`${Kt}${We} hablas \u2014 Setup Wizard${D}`),console.log(`${z} Configure your AI provider and model${D}`),console.log(`${Kt}${We} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${D}`),console.log(),console.log(`${Kt} Choose your setup:${D}`),console.log(),console.log(` ${L0}${Kt}1${D}. ${Kt}Hablas Integrated Engine${D} ${vt}(instant \u2014 no setup needed)${D}`),console.log(` ${z}Pre-configured cloud AI, ready to use immediately${D}`),console.log(),console.log(` ${We}${Kt}2${D}. ${Kt}Custom Provider${D} ${z}(bring your own API key)${D}`),console.log(` ${z}Choose from Ollama, OpenAI, Groq, OpenRouter, and more${D}`),console.log(),(await ve(e,` ${z}Your choice (1-2):${D} `)).trim()){case"1":{n.provider=Wt.provider,n.apiUrl=Wt.apiUrl,n.apiKey=F0(),n.model=Wt.model,mt(n),tt({name:Wt.name,apiUrl:Wt.apiUrl,apiKey:n.apiKey,models:["stepfun-ai/step-3.7-flash","nvidia/llama-3.3-70b-instruct","deepseek-ai/deepseek-r1"],defaultModel:Wt.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Hablas Integrated Engine activated!${D}`),console.log(`${z} Model: ${Wt.model}${D}`),console.log(`${z} API: ${Wt.apiUrl}${D}`),console.log(`${z} No API key needed \u2014 everything is pre-configured.${D}`);break}case"2":{switch(console.log(),console.log(`${z} Select your provider:${D}`),console.log(` ${We}a${D}. Ollama (local, free, private)`),console.log(` ${We}b${D}. OpenAI API`),console.log(` ${We}c${D}. Groq (fast, free tier)`),console.log(` ${We}d${D}. OpenRouter (many models)`),console.log(` ${We}e${D}. Together AI`),console.log(` ${We}f${D}. DeepSeek`),console.log(` ${We}g${D}. Custom OpenAI-compatible API`),console.log(` ${We}h${D}. NVIDIA NIM (powerful cloud models)`),console.log(),(await ve(e,` ${z}Your choice (a-h):${D} `)).trim().toLowerCase()){case"a":{n.provider="ollama";let r=await ve(e,` ${z}Ollama host [http://localhost:11434]:${D} `);r.trim()&&(n.ollamaHost=r.trim());let i=await ve(e,` ${z}Model [qwen2.5-coder:7b]:${D} `);i.trim()&&(n.model=i.trim()),mt(n),console.log(),console.log(`${vt} \u2713 Configured for Ollama${D}`),console.log(`${z} Model: ${n.model}${D}`),console.log(`${z} Host: ${n.ollamaHost}${D}`),console.log(`${z} Make sure Ollama is running: ollama serve${D}`);break}case"b":{let r=await ve(e,` ${z}OpenAI API Key (sk-...):${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`);break}let i=await ve(e,` ${z}Model [gpt-4o]:${D} `);n.provider="custom",n.apiUrl="https://api.openai.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"gpt-4o",mt(n),tt({name:"OpenAI",apiUrl:"https://api.openai.com/v1",apiKey:r.trim(),models:["gpt-4o","gpt-4o-mini","gpt-4-turbo","o1","o3-mini"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for OpenAI${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"c":{let r=await ve(e,` ${z}Groq API Key (gsk_...):${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`);break}let i=await ve(e,` ${z}Model [llama-3.3-70b-versatile]:${D} `);n.provider="custom",n.apiUrl="https://api.groq.com/openai/v1",n.apiKey=r.trim(),n.model=i.trim()||"llama-3.3-70b-versatile",mt(n),tt({name:"Groq",apiUrl:"https://api.groq.com/openai/v1",apiKey:r.trim(),models:["llama-3.3-70b-versatile","llama-3.1-70b-versatile","mixtral-8x7b-32768","gemma2-9b-it"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for Groq${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"d":{let r=await ve(e,` ${z}OpenRouter API Key (sk-or-...):${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`);break}let i=await ve(e,` ${z}Model [anthropic/claude-3.5-sonnet]:${D} `);n.provider="custom",n.apiUrl="https://openrouter.ai/api/v1",n.apiKey=r.trim(),n.model=i.trim()||"anthropic/claude-3.5-sonnet",mt(n),tt({name:"OpenRouter",apiUrl:"https://openrouter.ai/api/v1",apiKey:r.trim(),models:["openai/gpt-4o","anthropic/claude-3.5-sonnet","google/gemini-2.0-flash-001","deepseek/deepseek-r1"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for OpenRouter${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"e":{let r=await ve(e,` ${z}Together API Key:${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`);break}let i=await ve(e,` ${z}Model [meta-llama/Llama-3.3-70B-Instruct-Turbo]:${D} `);n.provider="custom",n.apiUrl="https://api.together.xyz/v1",n.apiKey=r.trim(),n.model=i.trim()||"meta-llama/Llama-3.3-70B-Instruct-Turbo",mt(n),tt({name:"Together",apiUrl:"https://api.together.xyz/v1",apiKey:r.trim(),models:["meta-llama/Llama-3.3-70B-Instruct-Turbo","Qwen/Qwen2.5-72B-Instruct-Turbo","deepseek-ai/DeepSeek-R1"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for Together AI${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"f":{let r=await ve(e,` ${z}DeepSeek API Key:${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`);break}let i=await ve(e,` ${z}Model [deepseek-chat]:${D} `);n.provider="custom",n.apiUrl="https://api.deepseek.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"deepseek-chat",mt(n),tt({name:"DeepSeek",apiUrl:"https://api.deepseek.com/v1",apiKey:r.trim(),models:["deepseek-chat","deepseek-coder","deepseek-reasoner"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for DeepSeek${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"g":{let r=await ve(e,` ${z}Provider name:${D} `);if(!r.trim()){console.log(`${wt} \u26A0 Cancelled${D}`);break}let i=await ve(e,` ${z}API base URL:${D} `);if(!i.trim()){console.log(`${wt} \u26A0 URL is required \u2014 cancelled${D}`);break}let o=await ve(e,` ${z}API Key (leave empty if none):${D} `),a=await ve(e,` ${z}Default model ID:${D} `);n.provider="custom",n.apiUrl=i.trim(),n.apiKey=o.trim(),n.model=a.trim()||"default",mt(n),tt({name:r.trim(),apiUrl:i.trim(),apiKey:o.trim(),models:[n.model],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for ${r.trim()}${D}`),console.log(`${z} URL: ${i.trim()}${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"h":{let r=await ve(e,` ${z}NVIDIA API Key (nvapi-...):${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`),console.log(`${z} Get your key at: https://build.nvidia.com/${D}`);break}let{NVIDIA_PROVIDER:i}=await Promise.resolve().then(()=>(Hn(),gc));console.log(),console.log(`${z} Available NVIDIA models:${D}`),i.models.forEach((u,d)=>{console.log(` ${We}${d+1}${D}. ${u}`)}),console.log();let o=await ve(e,` ${z}Model number [1]:${D} `),a=parseInt(o.trim())-1,l=i.models[a]||i.defaultModel;n.provider="nvidia",n.apiUrl=i.apiUrl,n.apiKey=r.trim(),n.model=l,mt(n),tt({name:"NVIDIA",apiUrl:i.apiUrl,apiKey:r.trim(),models:i.models,defaultModel:l,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for NVIDIA NIM${D}`),console.log(`${z} Model: ${l}${D}`),console.log(`${z} API: ${i.apiUrl}${D}`);break}default:console.log(`${wt} \u26A0 Invalid choice${D}`)}break}default:console.log(`${wt} \u26A0 Invalid choice \u2014 please select 1 or 2${D}`)}console.log(),console.log(`${z} Run 'hablas' to start chatting!${D}`),console.log(),e.close()}var Bg,We,vt,wt,z,Kt,D,L0,Wt,zl=L(()=>{"use strict";Bg=O(require("readline"));yr();Si();We="\x1B[36m",vt="\x1B[32m",wt="\x1B[33m",z="\x1B[2m",Kt="\x1B[1m",D="\x1B[0m",L0="\x1B[35m";Wt={provider:"nvidia",apiUrl:"https://integrate.api.nvidia.com/v1",model:"stepfun-ai/step-3.7-flash",name:"Hablas Integrated Engine"}});var Nt={};Le(Nt,{activeCollabManager:()=>Ee,runSingleCommand:()=>q0,startRepl:()=>Xl});function B0(){return!ft.existsSync(Yl)}function qg(){return ft.existsSync(N0)}function U0(){let n=It.dirname(Yl);ft.existsSync(n)||ft.mkdirSync(n,{recursive:!0}),ft.writeFileSync(Yl,new Date().toISOString(),"utf-8")}async function Wg(n,e,t,s,r){let{interactive:i,autoMode:o,input:a,logger:l,abortSignal:u,onToolCall:d,skipTools:f}=r,h=r.reactEngine??ws(),m=r.errorRecovery??xs(),p=new Ve("Hablas is thinking");p.start();let g=k=>{p&&(p.stop(k),p=null)},w=fg({autoMode:o,interactive:i,confirm:a?k=>a.confirm(k):void 0,confirmDangerous:a?k=>a.confirmDangerous(k):void 0});await Br({identity:{name:"Hablas",title:"Team Leader",role:"hablas"},client:e,registry:t,session:n,contextManager:s,reactEngine:h,errorRecovery:m,logger:l,io:{onAssistantText:k=>{g(),console.log(Jt("Hablas","Team Leader")),console.log(Xt(k))},onToolStart:(k,A)=>{g(),console.log(gu(k,A)),p=new Ve("Continuing"),p.start()},onToolEnd:(k,A,y,v)=>{g(),console.log(yu(A,y,v))},onNotice:(k,A)=>{g(),console.log(A==="retry"?c.muted(` \u21BB ${k}`):j(k))},onError:k=>{g(),k.includes("ECONNREFUSED")?console.log(Be("Connection lost","Check your provider connection or run /provider test")):/timeout/i.test(k)?console.log(Be("Request timed out (120s)","The API is slow. Try again or use a faster model.")):k.includes("429")?console.log(Be("Rate limited by API","Wait a moment and try again, or switch providers.")):k.includes("model")?console.log(Be("Model error","Check model availability: /models")):console.log(Be(`Error: ${k}`,"Try again or check /status"))},onToolCall:()=>{d&&d()}},safetyPolicy:w,abortSignal:u,skipTools:f,maxIterations:j0}),g()}async function Xl(n,e){qp();let t=n.workingDirectory==="."?process.cwd():n.workingDirectory,s=ne=>ft.existsSync(It.join(ne,".git"));if(!s(t)&&!n.team?.enabled)console.log(` ${c.warning("\u26A0")} ${c.secondary("Not in a Git repository. Versioning and auto-sync features are limited.")}
|
|
1027
|
+
...(truncated)`,b=Math.ceil(v.length/4);u+b<=r&&(a.push({path:w,content:v,source:"imported",lineCount:100}),u+=b)}else u+$<=r&&(a.push({path:w,content:k,source:"imported",lineCount:y}),u+=$)}catch{}}}}}catch{}}}return{files:a,totalTokensEstimate:u,mentionedPaths:o}}function jg(n){if(n.files.length===0)return"";let e=["## Referenced Files"];for(let t of n.files){let s=t.source==="imported"?" (imported)":"";e.push(`### ${t.path}${s} (${t.lineCount} lines)`),e.push("```"),e.push(t.content),e.push("```")}return e.join(`
|
|
1028
|
+
`)}var dt,Ee,Dg,Lg,Fg,Hg=L(()=>{"use strict";dt=O(require("fs")),Ee=O(require("path")),Dg=/(?:^|\s|['"`])([.\w\-/\\]+\.(?:ts|js|tsx|jsx|py|go|rs|java|c|cpp|h|css|scss|html|vue|svelte|json|yaml|yml|toml|md|sql|sh|env|xml))\b/gi,Lg=/(?:import\s+.*?\s+from\s+['"]([^'"]+)['"]|require\s*\(\s*['"]([^'"]+)['"]\s*\))/g,Fg=/(?:from\s+(\S+)\s+import|import\s+(\S+))/g});var Ug={};Fe(Ug,{runSetupWizard:()=>Vl});function we(n,e){return new Promise(t=>{n.question(e,s=>t(s))})}function F0(){return["nvapi-","qJRIIcL3SbN6s91CK-","gk2DtzlHbUnaYvGJk","AoIohOTcABSY5lll","Kdwfj_fO_b55h"].join("")}async function Vl(n){let e=Bg.createInterface({input:process.stdin,output:process.stdout});switch(console.log(),console.log(`${Kt}${We} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${D}`),console.log(`${Kt}${We} hablas \u2014 Setup Wizard${D}`),console.log(`${z} Configure your AI provider and model${D}`),console.log(`${Kt}${We} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${D}`),console.log(),console.log(`${Kt} Choose your setup:${D}`),console.log(),console.log(` ${L0}${Kt}1${D}. ${Kt}Hablas Integrated Engine${D} ${vt}(instant \u2014 no setup needed)${D}`),console.log(` ${z}Pre-configured cloud AI, ready to use immediately${D}`),console.log(),console.log(` ${We}${Kt}2${D}. ${Kt}Custom Provider${D} ${z}(bring your own API key)${D}`),console.log(` ${z}Choose from Ollama, OpenAI, Groq, OpenRouter, and more${D}`),console.log(),(await we(e,` ${z}Your choice (1-2):${D} `)).trim()){case"1":{n.provider=Wt.provider,n.apiUrl=Wt.apiUrl,n.apiKey=F0(),n.model=Wt.model,mt(n),tt({name:Wt.name,apiUrl:Wt.apiUrl,apiKey:n.apiKey,models:["stepfun-ai/step-3.7-flash","nvidia/llama-3.3-70b-instruct","deepseek-ai/deepseek-r1"],defaultModel:Wt.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Hablas Integrated Engine activated!${D}`),console.log(`${z} Model: ${Wt.model}${D}`),console.log(`${z} API: ${Wt.apiUrl}${D}`),console.log(`${z} No API key needed \u2014 everything is pre-configured.${D}`);break}case"2":{switch(console.log(),console.log(`${z} Select your provider:${D}`),console.log(` ${We}a${D}. Ollama (local, free, private)`),console.log(` ${We}b${D}. OpenAI API`),console.log(` ${We}c${D}. Groq (fast, free tier)`),console.log(` ${We}d${D}. OpenRouter (many models)`),console.log(` ${We}e${D}. Together AI`),console.log(` ${We}f${D}. DeepSeek`),console.log(` ${We}g${D}. Custom OpenAI-compatible API`),console.log(` ${We}h${D}. NVIDIA NIM (powerful cloud models)`),console.log(),(await we(e,` ${z}Your choice (a-h):${D} `)).trim().toLowerCase()){case"a":{n.provider="ollama";let r=await we(e,` ${z}Ollama host [http://localhost:11434]:${D} `);r.trim()&&(n.ollamaHost=r.trim());let i=await we(e,` ${z}Model [qwen2.5-coder:7b]:${D} `);i.trim()&&(n.model=i.trim()),mt(n),console.log(),console.log(`${vt} \u2713 Configured for Ollama${D}`),console.log(`${z} Model: ${n.model}${D}`),console.log(`${z} Host: ${n.ollamaHost}${D}`),console.log(`${z} Make sure Ollama is running: ollama serve${D}`);break}case"b":{let r=await we(e,` ${z}OpenAI API Key (sk-...):${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`);break}let i=await we(e,` ${z}Model [gpt-4o]:${D} `);n.provider="custom",n.apiUrl="https://api.openai.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"gpt-4o",mt(n),tt({name:"OpenAI",apiUrl:"https://api.openai.com/v1",apiKey:r.trim(),models:["gpt-4o","gpt-4o-mini","gpt-4-turbo","o1","o3-mini"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for OpenAI${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"c":{let r=await we(e,` ${z}Groq API Key (gsk_...):${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`);break}let i=await we(e,` ${z}Model [llama-3.3-70b-versatile]:${D} `);n.provider="custom",n.apiUrl="https://api.groq.com/openai/v1",n.apiKey=r.trim(),n.model=i.trim()||"llama-3.3-70b-versatile",mt(n),tt({name:"Groq",apiUrl:"https://api.groq.com/openai/v1",apiKey:r.trim(),models:["llama-3.3-70b-versatile","llama-3.1-70b-versatile","mixtral-8x7b-32768","gemma2-9b-it"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for Groq${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"d":{let r=await we(e,` ${z}OpenRouter API Key (sk-or-...):${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`);break}let i=await we(e,` ${z}Model [anthropic/claude-3.5-sonnet]:${D} `);n.provider="custom",n.apiUrl="https://openrouter.ai/api/v1",n.apiKey=r.trim(),n.model=i.trim()||"anthropic/claude-3.5-sonnet",mt(n),tt({name:"OpenRouter",apiUrl:"https://openrouter.ai/api/v1",apiKey:r.trim(),models:["openai/gpt-4o","anthropic/claude-3.5-sonnet","google/gemini-2.0-flash-001","deepseek/deepseek-r1"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for OpenRouter${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"e":{let r=await we(e,` ${z}Together API Key:${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`);break}let i=await we(e,` ${z}Model [meta-llama/Llama-3.3-70B-Instruct-Turbo]:${D} `);n.provider="custom",n.apiUrl="https://api.together.xyz/v1",n.apiKey=r.trim(),n.model=i.trim()||"meta-llama/Llama-3.3-70B-Instruct-Turbo",mt(n),tt({name:"Together",apiUrl:"https://api.together.xyz/v1",apiKey:r.trim(),models:["meta-llama/Llama-3.3-70B-Instruct-Turbo","Qwen/Qwen2.5-72B-Instruct-Turbo","deepseek-ai/DeepSeek-R1"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for Together AI${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"f":{let r=await we(e,` ${z}DeepSeek API Key:${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`);break}let i=await we(e,` ${z}Model [deepseek-chat]:${D} `);n.provider="custom",n.apiUrl="https://api.deepseek.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"deepseek-chat",mt(n),tt({name:"DeepSeek",apiUrl:"https://api.deepseek.com/v1",apiKey:r.trim(),models:["deepseek-chat","deepseek-coder","deepseek-reasoner"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for DeepSeek${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"g":{let r=await we(e,` ${z}Provider name:${D} `);if(!r.trim()){console.log(`${wt} \u26A0 Cancelled${D}`);break}let i=await we(e,` ${z}API base URL:${D} `);if(!i.trim()){console.log(`${wt} \u26A0 URL is required \u2014 cancelled${D}`);break}let o=await we(e,` ${z}API Key (leave empty if none):${D} `),a=await we(e,` ${z}Default model ID:${D} `);n.provider="custom",n.apiUrl=i.trim(),n.apiKey=o.trim(),n.model=a.trim()||"default",mt(n),tt({name:r.trim(),apiUrl:i.trim(),apiKey:o.trim(),models:[n.model],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for ${r.trim()}${D}`),console.log(`${z} URL: ${i.trim()}${D}`),console.log(`${z} Model: ${n.model}${D}`);break}case"h":{let r=await we(e,` ${z}NVIDIA API Key (nvapi-...):${D} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${D}`),console.log(`${z} Get your key at: https://build.nvidia.com/${D}`);break}let{NVIDIA_PROVIDER:i}=await Promise.resolve().then(()=>(Hn(),gc));console.log(),console.log(`${z} Available NVIDIA models:${D}`),i.models.forEach((u,d)=>{console.log(` ${We}${d+1}${D}. ${u}`)}),console.log();let o=await we(e,` ${z}Model number [1]:${D} `),a=parseInt(o.trim())-1,l=i.models[a]||i.defaultModel;n.provider="nvidia",n.apiUrl=i.apiUrl,n.apiKey=r.trim(),n.model=l,mt(n),tt({name:"NVIDIA",apiUrl:i.apiUrl,apiKey:r.trim(),models:i.models,defaultModel:l,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for NVIDIA NIM${D}`),console.log(`${z} Model: ${l}${D}`),console.log(`${z} API: ${i.apiUrl}${D}`);break}default:console.log(`${wt} \u26A0 Invalid choice${D}`)}break}default:console.log(`${wt} \u26A0 Invalid choice \u2014 please select 1 or 2${D}`)}console.log(),console.log(`${z} Run 'hablas' to start chatting!${D}`),console.log(),e.close()}var Bg,We,vt,wt,z,Kt,D,L0,Wt,zl=L(()=>{"use strict";Bg=O(require("readline"));yr();Si();We="\x1B[36m",vt="\x1B[32m",wt="\x1B[33m",z="\x1B[2m",Kt="\x1B[1m",D="\x1B[0m",L0="\x1B[35m";Wt={provider:"nvidia",apiUrl:"https://integrate.api.nvidia.com/v1",model:"stepfun-ai/step-3.7-flash",name:"Hablas Integrated Engine"}});var Nt={};Fe(Nt,{activeCollabManager:()=>Re,runSingleCommand:()=>K0,startRepl:()=>Xl});function B0(){return!ft.existsSync(Yl)}function qg(){return ft.existsSync(N0)}function U0(){let n=It.dirname(Yl);ft.existsSync(n)||ft.mkdirSync(n,{recursive:!0}),ft.writeFileSync(Yl,new Date().toISOString(),"utf-8")}async function q0(n,e=10){let t=n.split(/(\s+)/);for(let s of t)process.stdout.write(s),await new Promise(r=>setTimeout(r,e))}async function Wg(n,e,t,s,r){let{interactive:i,autoMode:o,input:a,logger:l,abortSignal:u,onToolCall:d,skipTools:f}=r,h=r.reactEngine??ws(),m=r.errorRecovery??xs(),p=new Ve("Hablas is thinking");p.start();let g=k=>{p&&(p.stop(k),p=null)},w=fg({autoMode:o,interactive:i,confirm:a?k=>a.confirm(k):void 0,confirmDangerous:a?k=>a.confirmDangerous(k):void 0});await Br({identity:{name:"Hablas",title:"Team Leader",role:"hablas"},client:e,registry:t,session:n,contextManager:s,reactEngine:h,errorRecovery:m,logger:l,io:{onAssistantText:async k=>{g(),console.log(Jt("Hablas","Team Leader")),await q0(Xt(k))},onToolStart:(k,$)=>{g(),console.log(gu(k,$)),p=new Ve("Continuing"),p.start()},onToolEnd:(k,$,y,v)=>{g(),console.log(yu($,y,v))},onNotice:(k,$)=>{g(),console.log($==="retry"?c.muted(` \u21BB ${k}`):j(k))},onError:k=>{g(),k.includes("ECONNREFUSED")?console.log(Be("Connection lost","Check your provider connection or run /provider test")):/timeout/i.test(k)?console.log(Be("Request timed out (120s)","The API is slow. Try again or use a faster model.")):k.includes("429")?console.log(Be("Rate limited by API","Wait a moment and try again, or switch providers.")):k.includes("model")?console.log(Be("Model error","Check model availability: /models")):console.log(Be(`Error: ${k}`,"Try again or check /status"))},onToolCall:()=>{d&&d()}},safetyPolicy:w,abortSignal:u,skipTools:f,maxIterations:j0}),g()}async function Xl(n,e){qp();let t=n.workingDirectory==="."?process.cwd():n.workingDirectory,s=ne=>ft.existsSync(It.join(ne,".git"));if(!s(t)&&!n.team?.enabled)console.log(` ${c.warning("\u26A0")} ${c.secondary("Not in a Git repository. Versioning and auto-sync features are limited.")}
|
|
1029
1029
|
`);else if(n.team?.enabled&&!s(t)){console.log(`
|
|
1030
1030
|
${c.accent("\u2726")} ${c.strong("Team Mode Strategy Required")}`),console.log(` ${c.muted("Collaboration requires a stable Git repository root.")}
|
|
1031
1031
|
`);let re=await new ps(t).prompt(` ${c.primary("\u203A")} Specify repo path OR type 'init' to start here: `);if(re.trim().toLowerCase()==="init")try{(0,Kg.execSync)("git init",{cwd:t,stdio:"ignore"}),console.log(` ${c.success("\u2713")} Git repository initialized in ${c.highlight(t)}
|
|
1032
|
-
`)}catch{console.log(
|
|
1033
|
-
`)):(console.log(
|
|
1034
|
-
`)}let _=new Xr(t);f.init();let k=null;n.context?.hablasCoreEnabled&&(k=new Yr(t),k.init());let
|
|
1035
|
-
`),console.log(j("Operation cancelled \u2014 press Ctrl+C again to exit"))});let
|
|
1036
|
-
[Clarification: ${ue.join(", ")}]`}}let
|
|
1037
|
-
${ie}`,{priority:"low",tags:["auto-inject"]})}if(n.team?.enabled&&
|
|
1032
|
+
`)}catch{console.log($e("Failed to initialize Git. Please run git init manually.")),process.exit(1)}else{let ee=It.resolve(t,re.trim());ft.existsSync(ee)&&s(ee)?(t=ee,n.workingDirectory=t,console.log(` ${c.success("\u2713")} Context switched to repository: ${c.highlight(t)}
|
|
1033
|
+
`)):(console.log($e(`Path "${ee}" is not a valid Git repository.`)),process.exit(1))}}let r=Ne(n),i=new us(t,n),o=new on(n),a=new ps(t),l=br(),u=new vr,d=new ms(t),f=new Ln(t),h=new zr,m=new Ur(n);m.setToolRegistry(i);let p=new qr,g=new Vr(p).attach(),w=new Wr(n,{tokenBudget:500,maxChars:140});if(m.setChannel(p),n.team?.enabled){let ne=n.team.user||"developer",re=n.team.key||"default-key";Re=new ls(t,n,ne,re),await Re.init()&&console.log(` ${c.success("\u2713")} ${c.muted("[Team]")} Scoped cooperative sync initialized successfully.
|
|
1034
|
+
`)}let _=new Xr(t);f.init();let k=null;n.context?.hablasCoreEnabled&&(k=new Yr(t),k.init());let $=await Qt(t,n),y=l.getActive(),v=y?y.systemPrompt:Yn,b=Zt(v,$,d,f),x=ws({thinkingEnabled:!0,selfEvalEnabled:!0,showThinking:!1,maxSteps:150,minConfidence:.6}),A=xs(3),E=new an(b,n.historySize),M=Kn();M=Bi(M),At(M);let C=0,F=0,H=Date.now(),Y=n.autoMode||!1,T=0,S=new AbortController;process.on("SIGINT",()=>{let ne=Date.now();if(ne-T<H0){console.log(to({turns:C,duration:Date.now()-H,toolCalls:F}));let re=Re?Re.shutdown():Promise.resolve();Promise.resolve(re).finally(()=>process.exit(0)),setTimeout(()=>process.exit(0),2e3);return}T=ne,S.abort(),S=new AbortController,process.stdout.write(`
|
|
1035
|
+
`),console.log(j("Operation cancelled \u2014 press Ctrl+C again to exit"))});let Q=Rs(n);if(console.log(uu(n.model,t)),n.provider==="custom"&&console.log(le(`Provider: ${Q}`)),Y&&console.log(le("Auto mode enabled \u2014 tool confirmations skipped (plan approval still required)")),(B0()||!qg())&&(console.log(pu()),console.log(""),console.log(le("First run detected \u2014 launching setup wizard...")),console.log(""),a.close(),await Vl(n),U0(),r=Ne(n),a.reinitialize()),qg()){let ne=new Ve("Connecting");ne.start();let re=await r.checkConnection();if(ne.stop(re?"ready":void 0),re){let ee=await r.listModels();console.log(X(`Connected \xB7 ${ee.length} models available`)),n.provider==="ollama"&&!ee.includes(n.model)&&console.log(j(`Model "${n.model}" not found. Pull: ollama pull ${n.model}`))}else n.provider==="custom"?console.log(Be(`Cannot connect to ${n.apiUrl}`,"Check your --api-url and --api-key, or run /provider test")):n.provider==="nvidia"?console.log(Be("Cannot connect to NVIDIA NIM","Check your API key or run: hablas --setup")):console.log(Be("Cannot connect to Ollama","Start it with: ollama serve \u2014 or switch provider: /provider"))}console.log(du()),console.log();let q=!0;for(;q;)try{let re=(await a.prompt(` ${c.primary("\u203A")} `)).trim();if(!re)continue;if(re.startsWith("/")){if(await Uu(re,n,r,i,o,E,t,a,C,l,u,d,K=>{r=K},f,h,_,m)==="quit"){q=!1;break}continue}e.info({input:re},"Processing user input");let ee=Mc(re),V=Gg(ee,t);if(C++,console.log(bu(C)),M=Ui(M),At(M),!Y){let ie=Pg(V);if(ie){console.log(xu(ie));let K=await a.prompt(` ${c.muted("\u203A")} `),ue=Og(K,ie);V=`${V}
|
|
1036
|
+
[Clarification: ${ue.join(", ")}]`}}let Pe=Ng(V,t,{maxFiles:8,maxTokens:6e3});if(Pe.files.length>0){let ie=jg(Pe);E.addUserMessage(`[Auto-loaded ${Pe.files.length} file(s): ${Pe.mentionedPaths.join(", ")}]
|
|
1037
|
+
${ie}`,{priority:"low",tags:["auto-inject"]})}if(n.team?.enabled&&Re){let ie=n.team?.user||Re.getLocalState().my_username,K=Pe.mentionedPaths||[];if(K.length>0){let ue=await Re.fetchLocks(),ge=K.map(P=>ue.find(U=>U.file_path===P&&U.locked_by!==ie)).filter(P=>!!P);if(ge.length>0){let P=ge[0];console.log(`
|
|
1038
1038
|
${c.architect("\u25C6")} ${c.strong("@Consul")} [Coordinator] detected an active lock held by a teammate.`),console.log(`
|
|
1039
|
-
${c.error("\u2554\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2557")}`),console.log(` ${c.error("\u2551")} ${c.strong("\u{1F512} FILE LOCKED BY TEAMMATE")} ${c.error("\u2551")}`),console.log(` ${c.error("\u2560\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2563")}`),console.log(` ${c.error("\u2551")} File ${c.highlight(P.file_path.padEnd(44))} held by ${c.strong(`@${(P.locked_by||"").padEnd(12)}`)} ${c.error("\u2551")}`),console.log(` ${c.error("\u2551")} Context: ${c.muted((P.lock_context||"\u2014").slice(0,61).padEnd(61))} ${c.error("\u2551")}`),console.log(` ${c.error("\u2551")} @Consul halted this turn to prevent a Git conflict on the shared repo. ${c.error("\u2551")}`),console.log(` ${c.error("\u255A\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u255D")}`);for(let U of ge)await
|
|
1040
|
-
`);continue}for(let P of K)if(!await
|
|
1039
|
+
${c.error("\u2554\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2557")}`),console.log(` ${c.error("\u2551")} ${c.strong("\u{1F512} FILE LOCKED BY TEAMMATE")} ${c.error("\u2551")}`),console.log(` ${c.error("\u2560\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2563")}`),console.log(` ${c.error("\u2551")} File ${c.highlight(P.file_path.padEnd(44))} held by ${c.strong(`@${(P.locked_by||"").padEnd(12)}`)} ${c.error("\u2551")}`),console.log(` ${c.error("\u2551")} Context: ${c.muted((P.lock_context||"\u2014").slice(0,61).padEnd(61))} ${c.error("\u2551")}`),console.log(` ${c.error("\u2551")} @Consul halted this turn to prevent a Git conflict on the shared repo. ${c.error("\u2551")}`),console.log(` ${c.error("\u255A\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u255D")}`);for(let U of ge)await Re.sendMessage(U.locked_by,`@${ie} needs to edit ${U.file_path}. Please release the lock when you can.`);console.log(` ${c.muted("@Consul notified the teammate(s). Try again once the lock is released, or coordinate directly.")}
|
|
1040
|
+
`);continue}for(let P of K)if(!await Re.acquireLock(P,V.slice(0,100))){console.log(`
|
|
1041
1041
|
${c.warning("\u26A0")} ${c.strong("@Consul")}: a teammate locked ${c.highlight(P)} first. Halting to avoid a conflict.
|
|
1042
|
-
`);continue}}
|
|
1042
|
+
`);continue}}Re.setActivity(V.slice(0,80))}if(n.agents.enabled&&n.agents.orchestration==="auto"){let ie=Gl(V),K={bob:"architect",alex:"coder",david:"researcher",hablas:"planner",emma:"product-manager"};if(ie==="XS"||Un(V))E.addUserMessage(V);else if(ie==="S")E.addUserMessage(V);else if(ie==="M"){let ue=Ns(V),ge=ue.find(G=>G!=="hablas")||"alex";M=yn(M,ge),At(M),Tg(V,ie,ue),k&&k.updateProgress(`Task started [M]: ${V.substring(0,60)}`);let P=js(V,[ge]),U=i.getOllamaTools();p.reset(),w.resetBudget();let I=new Fn(p,m,w,n),{finalSynthesis:W,synthesisOk:se}=await I.run(V,P,U,{abortSignal:S?.signal});console.log(Jt("Hablas","Team Leader")),console.log(Xt(W)),E.addAssistantMessage(se?W:`[Team Execution Summary]
|
|
1043
1043
|
|
|
1044
1044
|
${W}`),await Zr(n,t);continue}else if(ie==="L"){let ue=Ns(V);if(ue.length>1){let ge=js(V,ue),P=ge.tasks.map((G,te)=>({description:G.description,assignee:G.role||"alex",assigneeName:G.agentName||G.role,dependent_task_ids:te>0?[`plan_${h.nextPlanNum}_t${te}`]:[]})),U=h.createPlan(ge.strategy||V.slice(0,60),ge.strategy||"sequential",P),I=h.getProgress();console.log(Vn(U,{percent:I.percentage,done:I.done,total:I.total}));let se=(await a.prompt(` ${c.accent("?")} ${c.strong("approve")} / ${c.muted("edit")} / ${c.muted("skip")} ${c.muted("\u203A")} `)).trim().toLowerCase();if(se==="edit"||se==="e"){console.log(le("Edit mode: describe your changes and I will re-plan."));let G=await a.prompt(` ${c.muted("Edit \u203A")} `);if(G.trim()){let te=`${V}
|
|
1045
1045
|
|
|
1046
|
-
User modification: ${G.trim()}`;E.addUserMessage(te)}else E.addUserMessage(V)}else if(se==="skip"||se==="s"){console.log(le("Plan skipped \u2014 executing directly without orchestration."));for(let G of U.tasks)h.skipTask(G.task_id);E.addUserMessage(V)}else{console.log(
|
|
1046
|
+
User modification: ${G.trim()}`;E.addUserMessage(te)}else E.addUserMessage(V)}else if(se==="skip"||se==="s"){console.log(le("Plan skipped \u2014 executing directly without orchestration."));for(let G of U.tasks)h.skipTask(G.task_id);E.addUserMessage(V)}else{console.log(X("Plan approved \u2014 executing...")),console.log(""),f.logDecision(`Plan approved: ${U.title}`,"Hablas",`${U.tasks.length} tasks for ${ue.length} agents`),k&&(k.updateProgress(`Plan approved [L]: ${U.title}`),k.recordDecision(`Plan: ${U.title}`,"Hablas",`${U.tasks.length} tasks, ${ue.length} agents`));for(let Gt of ue)M=yn(M,Gt);At(M),p.reset(),w.resetBudget();let G=i.getOllamaTools(),te=new Fn(p,m,w,n),{results:Oe,finalSynthesis:xe,synthesisOk:ti}=await te.run(V,ge,G,{abortSignal:S?.signal,peerReview:!0});for(let Gt of U.tasks)h.finishTask(Gt.task_id);console.log(Jt("Hablas","Team Leader")),console.log(Xt(xe)),E.addAssistantMessage(ti?xe:`[Team Execution Summary]
|
|
1047
1047
|
|
|
1048
1048
|
${xe}`),await Zr(n,t);continue}}else{let ge=ue.find(U=>U!=="hablas")||"alex";M=yn(M,ge),At(M);let P=K[ge]||"coder";if(l.has(P)&&l.getActiveName()!==P){l.setActive(P);let U=l.getActive(),I=await Qt(t,n),W=Zt(U.systemPrompt,I,d,f);E.updateSystemPrompt(W)}E.addUserMessage(V)}}else{let ue=Ns(V);ue.includes("emma")||ue.push("emma");let ge=js(V,ue),P=ge.tasks.map((G,te)=>({description:G.description,assignee:G.role||"alex",assigneeName:G.agentName||G.role,dependent_task_ids:te>0?[`plan_${h.nextPlanNum}_t${te}`]:[]})),U=h.createPlan(ge.strategy||V.slice(0,60),ge.strategy||"sequential",P),I=h.getProgress();console.log(Vn(U,{percent:I.percentage,done:I.done,total:I.total})),console.log(le("XL project \u2014 Emma will create a PRD before implementation begins."));let se=(await a.prompt(` ${c.accent("?")} ${c.strong("approve")} / ${c.muted("edit")} / ${c.muted("skip")} ${c.muted("\u203A")} `)).trim().toLowerCase();if(se==="edit"||se==="e"){console.log(le("Edit mode: describe your changes and I will re-plan."));let G=await a.prompt(` ${c.muted("Edit \u203A")} `);if(G.trim()){let te=`${V}
|
|
1049
1049
|
|
|
1050
|
-
User modification: ${G.trim()}`;E.addUserMessage(te)}else E.addUserMessage(V)}else if(se==="skip"||se==="s"){console.log(le("Plan skipped \u2014 executing directly without orchestration."));for(let G of U.tasks)h.skipTask(G.task_id);E.addUserMessage(V)}else{console.log(
|
|
1050
|
+
User modification: ${G.trim()}`;E.addUserMessage(te)}else E.addUserMessage(V)}else if(se==="skip"||se==="s"){console.log(le("Plan skipped \u2014 executing directly without orchestration."));for(let G of U.tasks)h.skipTask(G.task_id);E.addUserMessage(V)}else{console.log(X("Plan approved \u2014 executing full workflow...")),console.log(""),f.logDecision(`XL Plan approved: ${U.title}`,"Hablas",`${U.tasks.length} tasks for ${ue.length} agents (includes PRD)`),k&&(k.updateProgress(`XL Plan approved: ${U.title}`),k.recordDecision(`XL Plan: ${U.title}`,"Hablas",`Full system: ${U.tasks.length} tasks, ${ue.length} agents`));for(let Gt of ue)M=yn(M,Gt);At(M),p.reset(),w.resetBudget();let G=i.getOllamaTools(),te=new Fn(p,m,w,n),{results:Oe,finalSynthesis:xe,synthesisOk:ti}=await te.run(V,ge,G,{abortSignal:S?.signal,peerReview:!0});for(let Gt of U.tasks)h.finishTask(Gt.task_id);console.log(Jt("Hablas","Team Leader")),console.log(Xt(xe)),E.addAssistantMessage(ti?xe:`[XL Team Execution Summary]
|
|
1051
1051
|
|
|
1052
|
-
${xe}`),await Zr(n,t);continue}}}else E.addUserMessage(V);S=new AbortController,x.startTurn()
|
|
1052
|
+
${xe}`),await Zr(n,t);continue}}}else E.addUserMessage(V);S=new AbortController,x.startTurn(),A.resetTurn();let Le=n.agents.enabled&&n.agents.orchestration==="auto"?Gl(V)==="XS":!1;await Wg(E,r,i,o,{interactive:!0,autoMode:Y,input:a,logger:e,config:n,abortSignal:S.signal,reactEngine:x,errorRecovery:A,skipTools:Le,onToolCall:()=>{F++,M=qi(M,"tool_call"),At(M)}}),await Zr(n,t)}catch(ne){if(ne.code==="ERR_USE_AFTER_CLOSE")break;if(ne.name==="AbortError")continue;console.log($e(ne.message)),e.error(ne,"REPL error")}a.close(),Re&&await Re.shutdown(),console.log(to({turns:C,duration:Date.now()-H,toolCalls:F}))}async function K0(n,e,t){let s=e.workingDirectory==="."?process.cwd():e.workingDirectory,r=Ne(e),i=new us(s,e),o=new on(e),a=new ms(s),l=await Qt(s,e),u=Zt(Yn,l,a),d=new an(u,e.historySize),f=Gg(n,s);d.addUserMessage(f),await Wg(d,r,i,o,{interactive:!1,autoMode:e.autoMode||!1,logger:t,config:e})}function Gg(n,e){let t=/#([\w./-]+)/g,s=n,r;for(;(r=t.exec(n))!==null;){let i=r[1],o=It.resolve(e,i);ft.existsSync(o)&&(s=s.replace(`#${i}`,i))}return s}async function Zr(n,e){if(!(n.team?.enabled&&Re))return;if(await Re.releaseAllMyLocks(),!n.workspace?.autoPush){console.log(`
|
|
1053
1053
|
${c.info("\u2139")} ${c.strong("@Consul")}: "Changes tracked. Auto-push is off \u2014 commit & push manually when ready."
|
|
1054
1054
|
`);return}let{execSync:t}=await import("child_process"),s=r=>t(r,{cwd:e,encoding:"utf-8",stdio:["ignore","pipe","pipe"]}).trim();try{if(!s("git status --porcelain")){console.log(`
|
|
1055
1055
|
${c.muted("@Consul: workspace clean \u2014 nothing to push.")}
|
|
@@ -1060,7 +1060,7 @@ ${xe}`),await Zr(n,t);continue}}}else E.addUserMessage(V);S=new AbortController,
|
|
|
1060
1060
|
`),s("git add -A"),s('git commit -m "sync(team): automatic updates via @Consul" --no-verify');return}console.log(`
|
|
1061
1061
|
${c.success("\u{1F4C1}")} ${c.muted("[Git]")} ${c.strong("@Consul")} committing & pushing to ${c.highlight(i)} \u2192 ${c.muted(o)} ...`),s("git add -A"),s('git commit -m "sync(team): automatic updates via @Consul" --no-verify');try{s(`git push origin ${i}`)}catch{s(`git push --set-upstream origin ${i}`)}console.log(` ${c.success("\u2713")} ${c.strong("@Consul")}: "Pushed to ${i}. Teammates can pull the latest."
|
|
1062
1062
|
`)}catch(r){let i=r.stderr||r.message||"unknown error",o=/authentication|permission|denied|403|401/i.test(i)?"Check your Git credentials / token for this remote.":/non-fast-forward|rejected|behind/i.test(i)?"Remote has newer commits \u2014 pull/rebase first, then push.":"Resolve the issue and push manually.";console.log(` ${c.warning("\u26A0")} ${c.strong("@Consul")}: auto-push failed. ${c.muted(o)}
|
|
1063
|
-
`)}}var ft,Kg,It,Jl,
|
|
1063
|
+
`)}}var ft,Kg,It,Jl,Re,Yl,N0,j0,H0,Tt=L(()=>{"use strict";qu();da();ft=O(require("fs")),Kg=require("child_process"),It=O(require("path")),Jl=O(require("os"));Bn();Fp();ba();va();Bp();yr();Ba();Kp();Vp();_i();mn();gg();bg();vg();_g();kg();Wn();Kl();Ag();$g();Eg();Mg();xn();Ig();Hg();zl();Fl();jl();ql();Re=null,Yl=It.join(Jl.homedir(),".hablas",".first_run_done"),N0=It.join(Jl.homedir(),".hablas","config.json"),j0=150,H0=1500});function Dt(n){let e=Zl.join(Vg.homedir(),".hablas","logs");ei.existsSync(e)||ei.mkdirSync(e,{recursive:!0});let t=Zl.join(e,`session-${Date.now()}.log`);return(0,Ql.default)({level:"info"},Ql.default.destination({dest:t,sync:!1}))}var Ql,Zl,Vg,ei,ec=L(()=>{"use strict";Ql=O(Dl()),Zl=O(require("path")),Vg=O(require("os")),ei=O(require("fs"))});var Qg={};Fe(Qg,{createApiServer:()=>Xg,startApiServer:()=>z0});function W0(){try{return JSON.parse(Yg.readFileSync(Jg.resolve(__dirname,"..","..","package.json"),"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function Xg(n){let e=Dt(n),t=V0(n);return zg.createServer(async(r,i)=>{if(i.setHeader("Access-Control-Allow-Origin","*"),i.setHeader("Access-Control-Allow-Methods","GET, POST, PUT, DELETE, OPTIONS"),i.setHeader("Access-Control-Allow-Headers","Content-Type, Authorization"),i.setHeader("Content-Type","application/json"),r.method==="OPTIONS"){i.writeHead(204),i.end();return}if(n.api.apiKey&&(r.headers.authorization||"").replace("Bearer ","")!==n.api.apiKey){i.writeHead(401),i.end(JSON.stringify({error:"Unauthorized",message:"Invalid API key"}));return}let o={};if(r.method==="POST"||r.method==="PUT")try{let l=[];for await(let d of r)l.push(d);let u=Buffer.concat(l).toString();u&&(o=JSON.parse(u))}catch{i.writeHead(400),i.end(JSON.stringify({error:"Bad Request",message:"Invalid JSON body"}));return}let a=t.find(l=>l.method===r.method&&r.url?.startsWith(l.path));if(!a){i.writeHead(404),i.end(JSON.stringify({error:"Not Found",message:`No route for ${r.method} ${r.url}`}));return}try{let l={method:r.method||"GET",path:r.url||"/",body:o,headers:r.headers},u=await a.handler(l);i.writeHead(u.status),i.end(JSON.stringify(u.body))}catch(l){e.error({err:l},"API error"),i.writeHead(500),i.end(JSON.stringify({error:"Internal Server Error",message:String(l)}))}})}function V0(n){return[{method:"GET",path:"/api/v1/health",handler:async()=>({status:200,body:{status:"ok",version:G0,uptime:process.uptime()}})},{method:"GET",path:"/api/v1/agents",handler:async()=>({status:200,body:{agents:[{name:"coder",description:"Code generation and modification",status:"available"},{name:"reviewer",description:"Code review and quality analysis",status:"available"},{name:"architect",description:"System architecture design",status:"available"},{name:"devops",description:"Deployment and infrastructure",status:"available"},{name:"researcher",description:"Documentation and research",status:"available"},{name:"planner",description:"Task decomposition and planning",status:"available"},{name:"debugger",description:"Error analysis and fixing",status:"available"}]}})},{method:"GET",path:"/api/v1/models",handler:async()=>({status:200,body:{current:n.model,provider:n.provider,host:n.ollamaHost}})},{method:"POST",path:"/api/v1/chat",handler:async e=>{let{message:t,agent:s}=e.body;return t?{status:200,body:{response:`[${s||"coder"}] Received: ${t}`,agent:s||"coder",model:n.model}}:{status:400,body:{error:"message field is required"}}}},{method:"POST",path:"/api/v1/plan",handler:async e=>{let{task:t}=e.body;return t?{status:200,body:{plan:{task:t,steps:[{step:1,description:"Analyze requirements",agent:"researcher"},{step:2,description:"Design architecture",agent:"architect"},{step:3,description:"Implement code",agent:"coder"},{step:4,description:"Review and test",agent:"reviewer"}]}}}:{status:400,body:{error:"task field is required"}}}},{method:"POST",path:"/api/v1/execute",handler:async e=>{let{command:t}=e.body;return t?n.api.enabled?{status:200,body:{message:"Command queued for execution",command:t}}:{status:403,body:{error:"API execution not enabled"}}:{status:400,body:{error:"command field is required"}}}},{method:"GET",path:"/api/v1/stats",handler:async()=>({status:200,body:{sessions:0,messages:0,uptime:process.uptime(),model:n.model,provider:n.provider}})}]}function z0(n){return new Promise((e,t)=>{let s=Xg(n);s.on("error",t),s.listen(n.api.port,n.api.host,()=>{e(s)})})}var zg,Yg,Jg,G0,Zg=L(()=>{"use strict";zg=O(require("http")),Yg=O(require("fs")),Jg=O(require("path"));ec();G0=W0()});var J0={};Fe(J0,{CLI_VERSION:()=>ks});module.exports=ay(J0);var hc=O(pc(),1),{program:iC,createCommand:oC,createArgument:aC,createOption:lC,CommanderError:cC,InvalidArgumentError:uC,InvalidOptionArgumentError:dC,Command:mc,Argument:fC,Option:pC,Help:hC}=hc.default;Tt();yr();ec();var ey=O(require("fs")),ty=O(require("path"));function Y0(){try{let n=ty.resolve(__dirname,"..","package.json");return JSON.parse(ey.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}var ks=Y0(),ce=new mc;ce.name("hablas").description(`hablas CLI v${ks} by Abdulmoin Hablas \u2014 Multi-agent AI development system. Local-first via Ollama, NVIDIA NIM, or any OpenAI-compatible API.`).version(ks).option("-m, --model <model>","Model to use").option("-p, --project <path>","Working directory").option("--host <url>","Ollama host URL").option("--provider <type>","LLM provider: ollama | custom | nvidia").option("--api-url <url>","Custom API base URL (OpenAI-compatible)").option("--api-key <key>","API key for custom/nvidia provider").option("--auto","Auto mode \u2014 skip all tool confirmations").option("--timeout <ms>","Request timeout in milliseconds","120000").option("--theme <name>","UI theme: dark | light | galaxy | ocean | forest").option("--dashboard","Launch TUI dashboard mode").option("--team","Enable hybrid cooperative sync mode with teammates").option("--user <name>","Teammate username for coordination").option("--team-key <password>","Teammate password/key for secure connection encryption").option("--setup","Run first-time setup wizard");ce.command("create <description>").description("Generate a full project from a description").option("--stack <stack>","Tech stack preference").option("--with-tests","Include test generation").option("--with-docker","Include Docker setup").action(async(n,e)=>{let t=ce.opts(),s=Qe({model:t.model,host:t.host,project:t.project,provider:t.provider,apiUrl:t.apiUrl,apiKey:t.apiKey});t.auto&&(s.autoMode=!0);let r=Dt(s),{runSingleCommand:i}=await Promise.resolve().then(()=>(Tt(),Nt)),o=`Generate a complete project: ${n}${e.stack?` using ${e.stack}`:""}${e.withTests?" with comprehensive tests":""}${e.withDocker?" with Docker setup":""}. Create all necessary files.`;await i(o,s,r)});ce.command("commit").description("Generate a smart commit message from staged changes").action(async()=>{let n=ce.opts(),e=Qe({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),t=Dt(e),{getGitStatus:s,getDetailedDiff:r,generateCommitPrompt:i}=await Promise.resolve().then(()=>(vn(),Gn)),o=e.workingDirectory||process.cwd(),a=await s(o);if(!a||a.staged.length===0){console.log(" \u26A0 No staged changes. Use `git add` first.");return}let l=await r(o),u=i(l,a.staged),{runSingleCommand:d}=await Promise.resolve().then(()=>(Tt(),Nt));await d(u,e,t)});ce.command("pr").description("Generate a PR description from branch commits").option("--base <branch>","Base branch","main").action(async n=>{let e=ce.opts(),t=Qe({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=Dt(t),{getGitStatus:r,getRecentCommits:i,generatePRPrompt:o}=await Promise.resolve().then(()=>(vn(),Gn)),a=t.workingDirectory||process.cwd(),l=await r(a),u=await i(a,20),d=o(u,n.base,l?.branch||"feature"),{runSingleCommand:f}=await Promise.resolve().then(()=>(Tt(),Nt));await f(d,t,s)});ce.command("changelog").description("Generate changelog from recent commits").option("--version <ver>","Version number",ks).option("-n, --count <n>","Number of commits to include","30").action(async n=>{let e=ce.opts(),t=Qe({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=Dt(t),{getRecentCommits:r,generateChangelogPrompt:i}=await Promise.resolve().then(()=>(vn(),Gn)),o=t.workingDirectory||process.cwd(),a=await r(o,parseInt(n.count)),l=i(a,n.version),{runSingleCommand:u}=await Promise.resolve().then(()=>(Tt(),Nt));await u(l,t,s)});ce.command("security").description("Run security scan on the project").option("--fix","Auto-fix issues where possible").action(async n=>{let e=ce.opts(),t=Qe({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),{runSecurityScan:s,formatScanResults:r}=await Promise.resolve().then(()=>(Vi(),zc)),i=t.workingDirectory||process.cwd();console.log(`
|
|
1064
1064
|
\u{1F512} Running security scan...
|
|
1065
1065
|
`);let o=s(i);console.log(r(o))});ce.command("stats").description("Show developer analytics and usage statistics").action(async()=>{let{loadStats:n,formatStats:e}=await Promise.resolve().then(()=>(Wn(),Ki)),t=n();console.log(e(t))});ce.command("team").description("Manage team configuration").option("--init <name>","Initialize team config").option("--add <email>","Add team member").option("--share","Share current session").action(async n=>{let e=ce.opts(),t=Qe({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),{loadTeamConfig:s,initTeamConfig:r,addTeamMember:i,saveTeamConfig:o,formatTeamConfig:a}=await Promise.resolve().then(()=>(da(),Vf)),l=t.workingDirectory||process.cwd();if(n.init)r(l,n.init),console.log(`
|
|
1066
1066
|
\u2713 Team "${n.init}" initialized.`),console.log(` Config saved to: .hablas/team.json
|