hablas-ai 1.2.0 → 1.2.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.
Files changed (2) hide show
  1. package/dist/index.js +128 -128
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -1,46 +1,46 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var ry=Object.create;var xs=Object.defineProperty;var iy=Object.getOwnPropertyDescriptor;var oy=Object.getOwnPropertyNames;var ay=Object.getPrototypeOf,ly=Object.prototype.hasOwnProperty;var N=(n,e)=>()=>(n&&(e=n(n=0)),e);var j=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports),Ne=(n,e)=>{for(var t in e)xs(n,t,{get:e[t],enumerable:!0})},ec=(n,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of oy(e))!ly.call(n,r)&&r!==t&&xs(n,r,{get:()=>e[r],enumerable:!(s=iy(e,r))||s.enumerable});return n};var O=(n,e,t)=>(t=n!=null?ry(ay(n)):{},ec(e||!n||!n.__esModule?xs(t,"default",{value:n,enumerable:!0}):t,n)),cy=n=>ec(xs({},"__esModule",{value:!0}),n);var In=j(Qr=>{var Ss=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}},Jr=class extends Ss{constructor(e){super(1,"commander.invalidArgument",e),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name}};Qr.CommanderError=Ss;Qr.InvalidArgumentError=Jr});var _s=j(Zr=>{var{InvalidArgumentError:uy}=In(),Xr=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 uy(`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 dy(n){let e=n.name()+(n.variadic===!0?"...":"");return n.required?"<"+e+">":"["+e+"]"}Zr.Argument=Xr;Zr.humanReadableArgName=dy});var ti=j(tc=>{var{humanReadableArgName:fy}=_s(),ei=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=>fy(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 x=`${p.padEnd(s+o)}${g}`;return t.wrap(x,r-i,s+o)}return p}function l(p){return p.join(`
2
+ "use strict";var ry=Object.create;var Ss=Object.defineProperty;var iy=Object.getOwnPropertyDescriptor;var oy=Object.getOwnPropertyNames;var ay=Object.getPrototypeOf,ly=Object.prototype.hasOwnProperty;var N=(n,e)=>()=>(n&&(e=n(n=0)),e);var j=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports),Ne=(n,e)=>{for(var t in e)Ss(n,t,{get:e[t],enumerable:!0})},tc=(n,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of oy(e))!ly.call(n,r)&&r!==t&&Ss(n,r,{get:()=>e[r],enumerable:!(s=iy(e,r))||s.enumerable});return n};var O=(n,e,t)=>(t=n!=null?ry(ay(n)):{},tc(e||!n||!n.__esModule?Ss(t,"default",{value:n,enumerable:!0}):t,n)),cy=n=>tc(Ss({},"__esModule",{value:!0}),n);var Mn=j(ei=>{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}},Zr=class extends _s{constructor(e){super(1,"commander.invalidArgument",e),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name}};ei.CommanderError=_s;ei.InvalidArgumentError=Zr});var As=j(ni=>{var{InvalidArgumentError:uy}=Mn(),ti=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 uy(`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 dy(n){let e=n.name()+(n.variadic===!0?"...":"");return n.required?"<"+e+">":"["+e+"]"}ni.Argument=ti;ni.humanReadableArgName=dy});var ri=j(nc=>{var{humanReadableArgName:fy}=As(),si=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=>fy(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 x=`${p.padEnd(s+o)}${g}`;return t.wrap(x,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
  `,`
6
6
  `),d=" ".repeat(s),h="\\s\u200B",m=new RegExp(`
7
7
  |.{1,${a-1}}([${h}]|$)|[^${h}]+?([${h}]|$)`,"g"),p=u.match(m)||[];return l+p.map((g,x)=>g===`
8
8
  `?"":(x>0?d:"")+g.trimEnd()).join(`
9
- `)}};tc.Help=ei});var ii=j(ri=>{var{InvalidArgumentError:py}=In(),ni=class{constructor(e,t){this.flags=e,this.description=t||"",this.required=e.includes("<"),this.optional=e.includes("["),this.variadic=/\w\.\.\.[>\]]$/.test(e),this.mandatory=!1;let s=my(e);this.short=s.shortFlag,this.long=s.longFlag,this.negate=!1,this.long&&(this.negate=this.long.startsWith("--no-")),this.defaultValue=void 0,this.defaultValueDescription=void 0,this.presetArg=void 0,this.envVar=void 0,this.parseArg=void 0,this.hidden=!1,this.argChoices=void 0,this.conflictsWith=[],this.implied=void 0}default(e,t){return this.defaultValue=e,this.defaultValueDescription=t,this}preset(e){return this.presetArg=e,this}conflicts(e){return this.conflictsWith=this.conflictsWith.concat(e),this}implies(e){let t=e;return typeof e=="string"&&(t={[e]:!0}),this.implied=Object.assign(this.implied||{},t),this}env(e){return this.envVar=e,this}argParser(e){return this.parseArg=e,this}makeOptionMandatory(e=!0){return this.mandatory=!!e,this}hideHelp(e=!0){return this.hidden=!!e,this}_concatValue(e,t){return t===this.defaultValue||!Array.isArray(t)?[e]:t.concat(e)}choices(e){return this.argChoices=e.slice(),this.parseArg=(t,s)=>{if(!this.argChoices.includes(t))throw new py(`Allowed choices are ${this.argChoices.join(", ")}.`);return this.variadic?this._concatValue(t,s):t},this}name(){return this.long?this.long.replace(/^--/,""):this.short.replace(/^-/,"")}attributeName(){return hy(this.name().replace(/^no-/,""))}is(e){return this.short===e||this.long===e}isBoolean(){return!this.required&&!this.optional&&!this.negate}},si=class{constructor(e){this.positiveOptions=new Map,this.negativeOptions=new Map,this.dualOptions=new Set,e.forEach(t=>{t.negate?this.negativeOptions.set(t.attributeName(),t):this.positiveOptions.set(t.attributeName(),t)}),this.negativeOptions.forEach((t,s)=>{this.positiveOptions.has(s)&&this.dualOptions.add(s)})}valueFromOption(e,t){let s=t.attributeName();if(!this.dualOptions.has(s))return!0;let r=this.negativeOptions.get(s).presetArg,i=r!==void 0?r:!1;return t.negate===(i===e)}};function hy(n){return n.split("-").reduce((e,t)=>e+t[0].toUpperCase()+t.slice(1))}function my(n){let e,t,s=n.split(/[ |,]+/);return s.length>1&&!/^[[<]/.test(s[1])&&(e=s.shift()),t=s.shift(),!e&&/^-[^-]$/.test(t)&&(e=t,t=void 0),{shortFlag:e,longFlag:t}}ri.Option=ni;ri.DualOptions=si});var sc=j(nc=>{function gy(n,e){if(Math.abs(n.length-e.length)>3)return Math.max(n.length,e.length);let t=[];for(let s=0;s<=n.length;s++)t[s]=[s];for(let s=0;s<=e.length;s++)t[0][s]=s;for(let s=1;s<=e.length;s++)for(let r=1;r<=n.length;r++){let i=1;n[r-1]===e[s-1]?i=0:i=1,t[r][s]=Math.min(t[r-1][s]+1,t[r][s-1]+1,t[r-1][s-1]+i),r>1&&s>1&&n[r-1]===e[s-2]&&n[r-2]===e[s-1]&&(t[r][s]=Math.min(t[r][s],t[r-2][s-2]+1))}return t[n.length][e.length]}function yy(n,e){if(!e||e.length===0)return"";e=Array.from(new Set(e));let t=n.startsWith("--");t&&(n=n.slice(2),e=e.map(o=>o.slice(2)));let s=[],r=3,i=.4;return e.forEach(o=>{if(o.length<=1)return;let a=gy(n,o),l=Math.max(n.length,o.length);(l-a)/l>i&&(a<r?(r=a,s=[o]):a===r&&s.push(o))}),s.sort((o,a)=>o.localeCompare(a)),t&&(s=s.map(o=>`--${o}`)),s.length>1?`
9
+ `)}};nc.Help=si});var li=j(ai=>{var{InvalidArgumentError:py}=Mn(),ii=class{constructor(e,t){this.flags=e,this.description=t||"",this.required=e.includes("<"),this.optional=e.includes("["),this.variadic=/\w\.\.\.[>\]]$/.test(e),this.mandatory=!1;let s=my(e);this.short=s.shortFlag,this.long=s.longFlag,this.negate=!1,this.long&&(this.negate=this.long.startsWith("--no-")),this.defaultValue=void 0,this.defaultValueDescription=void 0,this.presetArg=void 0,this.envVar=void 0,this.parseArg=void 0,this.hidden=!1,this.argChoices=void 0,this.conflictsWith=[],this.implied=void 0}default(e,t){return this.defaultValue=e,this.defaultValueDescription=t,this}preset(e){return this.presetArg=e,this}conflicts(e){return this.conflictsWith=this.conflictsWith.concat(e),this}implies(e){let t=e;return typeof e=="string"&&(t={[e]:!0}),this.implied=Object.assign(this.implied||{},t),this}env(e){return this.envVar=e,this}argParser(e){return this.parseArg=e,this}makeOptionMandatory(e=!0){return this.mandatory=!!e,this}hideHelp(e=!0){return this.hidden=!!e,this}_concatValue(e,t){return t===this.defaultValue||!Array.isArray(t)?[e]:t.concat(e)}choices(e){return this.argChoices=e.slice(),this.parseArg=(t,s)=>{if(!this.argChoices.includes(t))throw new py(`Allowed choices are ${this.argChoices.join(", ")}.`);return this.variadic?this._concatValue(t,s):t},this}name(){return this.long?this.long.replace(/^--/,""):this.short.replace(/^-/,"")}attributeName(){return hy(this.name().replace(/^no-/,""))}is(e){return this.short===e||this.long===e}isBoolean(){return!this.required&&!this.optional&&!this.negate}},oi=class{constructor(e){this.positiveOptions=new Map,this.negativeOptions=new Map,this.dualOptions=new Set,e.forEach(t=>{t.negate?this.negativeOptions.set(t.attributeName(),t):this.positiveOptions.set(t.attributeName(),t)}),this.negativeOptions.forEach((t,s)=>{this.positiveOptions.has(s)&&this.dualOptions.add(s)})}valueFromOption(e,t){let s=t.attributeName();if(!this.dualOptions.has(s))return!0;let r=this.negativeOptions.get(s).presetArg,i=r!==void 0?r:!1;return t.negate===(i===e)}};function hy(n){return n.split("-").reduce((e,t)=>e+t[0].toUpperCase()+t.slice(1))}function my(n){let e,t,s=n.split(/[ |,]+/);return s.length>1&&!/^[[<]/.test(s[1])&&(e=s.shift()),t=s.shift(),!e&&/^-[^-]$/.test(t)&&(e=t,t=void 0),{shortFlag:e,longFlag:t}}ai.Option=ii;ai.DualOptions=oi});var rc=j(sc=>{function gy(n,e){if(Math.abs(n.length-e.length)>3)return Math.max(n.length,e.length);let t=[];for(let s=0;s<=n.length;s++)t[s]=[s];for(let s=0;s<=e.length;s++)t[0][s]=s;for(let s=1;s<=e.length;s++)for(let r=1;r<=n.length;r++){let i=1;n[r-1]===e[s-1]?i=0:i=1,t[r][s]=Math.min(t[r-1][s]+1,t[r][s-1]+1,t[r-1][s-1]+i),r>1&&s>1&&n[r-1]===e[s-2]&&n[r-2]===e[s-1]&&(t[r][s]=Math.min(t[r][s],t[r-2][s-2]+1))}return t[n.length][e.length]}function yy(n,e){if(!e||e.length===0)return"";e=Array.from(new Set(e));let t=n.startsWith("--");t&&(n=n.slice(2),e=e.map(o=>o.slice(2)));let s=[],r=3,i=.4;return e.forEach(o=>{if(o.length<=1)return;let a=gy(n,o),l=Math.max(n.length,o.length);(l-a)/l>i&&(a<r?(r=a,s=[o]):a===r&&s.push(o))}),s.sort((o,a)=>o.localeCompare(a)),t&&(s=s.map(o=>`--${o}`)),s.length>1?`
10
10
  (Did you mean one of ${s.join(", ")}?)`:s.length===1?`
11
- (Did you mean ${s[0]}?)`:""}nc.suggestSimilar=yy});var lc=j(ac=>{var by=require("node:events").EventEmitter,oi=require("node:child_process"),St=require("node:path"),ai=require("node:fs"),de=require("node:process"),{Argument:vy,humanReadableArgName:wy}=_s(),{CommanderError:li}=In(),{Help:xy}=ti(),{Option:rc,DualOptions:Sy}=ii(),{suggestSimilar:ic}=sc(),ci=class n extends by{constructor(e){super(),this.commands=[],this.options=[],this.parent=null,this._allowUnknownOption=!1,this._allowExcessArguments=!0,this.registeredArguments=[],this._args=this.registeredArguments,this.args=[],this.rawArgs=[],this.processedArgs=[],this._scriptPath=null,this._name=e||"",this._optionValues={},this._optionValueSources={},this._storeOptionsAsProperties=!1,this._actionHandler=null,this._executableHandler=!1,this._executableFile=null,this._executableDir=null,this._defaultCommandName=null,this._exitCallback=null,this._aliases=[],this._combineFlagAndOptionalValue=!0,this._description="",this._summary="",this._argsDescription=void 0,this._enablePositionalOptions=!1,this._passThroughOptions=!1,this._lifeCycleHooks={},this._showHelpAfterError=!1,this._showSuggestionAfterError=!0,this._outputConfiguration={writeOut:t=>de.stdout.write(t),writeErr:t=>de.stderr.write(t),getOutHelpWidth:()=>de.stdout.isTTY?de.stdout.columns:void 0,getErrHelpWidth:()=>de.stderr.isTTY?de.stderr.columns:void 0,outputError:(t,s)=>s(t)},this._hidden=!1,this._helpOption=void 0,this._addImplicitHelpCommand=void 0,this._helpCommand=void 0,this._helpConfiguration={}}copyInheritedSettings(e){return this._outputConfiguration=e._outputConfiguration,this._helpOption=e._helpOption,this._helpCommand=e._helpCommand,this._helpConfiguration=e._helpConfiguration,this._exitCallback=e._exitCallback,this._storeOptionsAsProperties=e._storeOptionsAsProperties,this._combineFlagAndOptionalValue=e._combineFlagAndOptionalValue,this._allowExcessArguments=e._allowExcessArguments,this._enablePositionalOptions=e._enablePositionalOptions,this._showHelpAfterError=e._showHelpAfterError,this._showSuggestionAfterError=e._showSuggestionAfterError,this}_getCommandAndAncestors(){let e=[];for(let t=this;t;t=t.parent)e.push(t);return e}command(e,t,s){let r=t,i=s;typeof r=="object"&&r!==null&&(i=r,r=null),i=i||{};let[,o,a]=e.match(/([^ ]+) *(.*)/),l=this.createCommand(o);return r&&(l.description(r),l._executableHandler=!0),i.isDefault&&(this._defaultCommandName=l._name),l._hidden=!!(i.noHelp||i.hidden),l._executableFile=i.executableFile||null,a&&l.arguments(a),this._registerCommand(l),l.parent=this,l.copyInheritedSettings(this),r?this:l}createCommand(e){return new n(e)}createHelp(){return Object.assign(new xy,this.configureHelp())}configureHelp(e){return e===void 0?this._helpConfiguration:(this._helpConfiguration=e,this)}configureOutput(e){return e===void 0?this._outputConfiguration:(Object.assign(this._outputConfiguration,e),this)}showHelpAfterError(e=!0){return typeof e!="string"&&(e=!!e),this._showHelpAfterError=e,this}showSuggestionAfterError(e=!0){return this._showSuggestionAfterError=!!e,this}addCommand(e,t){if(!e._name)throw new Error(`Command passed to .addCommand() must have a name
11
+ (Did you mean ${s[0]}?)`:""}sc.suggestSimilar=yy});var cc=j(lc=>{var by=require("node:events").EventEmitter,ci=require("node:child_process"),St=require("node:path"),ui=require("node:fs"),de=require("node:process"),{Argument:vy,humanReadableArgName:wy}=As(),{CommanderError:di}=Mn(),{Help:xy}=ri(),{Option:ic,DualOptions:Sy}=li(),{suggestSimilar:oc}=rc(),fi=class n extends by{constructor(e){super(),this.commands=[],this.options=[],this.parent=null,this._allowUnknownOption=!1,this._allowExcessArguments=!0,this.registeredArguments=[],this._args=this.registeredArguments,this.args=[],this.rawArgs=[],this.processedArgs=[],this._scriptPath=null,this._name=e||"",this._optionValues={},this._optionValueSources={},this._storeOptionsAsProperties=!1,this._actionHandler=null,this._executableHandler=!1,this._executableFile=null,this._executableDir=null,this._defaultCommandName=null,this._exitCallback=null,this._aliases=[],this._combineFlagAndOptionalValue=!0,this._description="",this._summary="",this._argsDescription=void 0,this._enablePositionalOptions=!1,this._passThroughOptions=!1,this._lifeCycleHooks={},this._showHelpAfterError=!1,this._showSuggestionAfterError=!0,this._outputConfiguration={writeOut:t=>de.stdout.write(t),writeErr:t=>de.stderr.write(t),getOutHelpWidth:()=>de.stdout.isTTY?de.stdout.columns:void 0,getErrHelpWidth:()=>de.stderr.isTTY?de.stderr.columns:void 0,outputError:(t,s)=>s(t)},this._hidden=!1,this._helpOption=void 0,this._addImplicitHelpCommand=void 0,this._helpCommand=void 0,this._helpConfiguration={}}copyInheritedSettings(e){return this._outputConfiguration=e._outputConfiguration,this._helpOption=e._helpOption,this._helpCommand=e._helpCommand,this._helpConfiguration=e._helpConfiguration,this._exitCallback=e._exitCallback,this._storeOptionsAsProperties=e._storeOptionsAsProperties,this._combineFlagAndOptionalValue=e._combineFlagAndOptionalValue,this._allowExcessArguments=e._allowExcessArguments,this._enablePositionalOptions=e._enablePositionalOptions,this._showHelpAfterError=e._showHelpAfterError,this._showSuggestionAfterError=e._showSuggestionAfterError,this}_getCommandAndAncestors(){let e=[];for(let t=this;t;t=t.parent)e.push(t);return e}command(e,t,s){let r=t,i=s;typeof r=="object"&&r!==null&&(i=r,r=null),i=i||{};let[,o,a]=e.match(/([^ ]+) *(.*)/),l=this.createCommand(o);return r&&(l.description(r),l._executableHandler=!0),i.isDefault&&(this._defaultCommandName=l._name),l._hidden=!!(i.noHelp||i.hidden),l._executableFile=i.executableFile||null,a&&l.arguments(a),this._registerCommand(l),l.parent=this,l.copyInheritedSettings(this),r?this:l}createCommand(e){return new n(e)}createHelp(){return Object.assign(new xy,this.configureHelp())}configureHelp(e){return e===void 0?this._helpConfiguration:(this._helpConfiguration=e,this)}configureOutput(e){return e===void 0?this._outputConfiguration:(Object.assign(this._outputConfiguration,e),this)}showHelpAfterError(e=!0){return typeof e!="string"&&(e=!!e),this._showHelpAfterError=e,this}showSuggestionAfterError(e=!0){return this._showSuggestionAfterError=!!e,this}addCommand(e,t){if(!e._name)throw new Error(`Command passed to .addCommand() must have a name
12
12
  - specify the name in Command constructor or using .name()`);return t=t||{},t.isDefault&&(this._defaultCommandName=e._name),(t.noHelp||t.hidden)&&(e._hidden=!0),this._registerCommand(e),e.parent=this,e._checkForBrokenPassThrough(),this}createArgument(e,t){return new vy(e,t)}argument(e,t,s,r){let i=this.createArgument(e,t);return typeof s=="function"?i.default(r).argParser(s):i.default(s),this.addArgument(i),this}arguments(e){return e.trim().split(/ +/).forEach(t=>{this.argument(t)}),this}addArgument(e){let t=this.registeredArguments.slice(-1)[0];if(t&&t.variadic)throw new Error(`only the last argument can be variadic '${t.name()}'`);if(e.required&&e.defaultValue!==void 0&&e.parseArg===void 0)throw new Error(`a default value for a required argument is never used: '${e.name()}'`);return this.registeredArguments.push(e),this}helpCommand(e,t){if(typeof e=="boolean")return this._addImplicitHelpCommand=e,this;e=e??"help [command]";let[,s,r]=e.match(/([^ ]+) *(.*)/),i=t??"display help for command",o=this.createCommand(s);return o.helpOption(!1),r&&o.arguments(r),i&&o.description(i),this._addImplicitHelpCommand=!0,this._helpCommand=o,this}addHelpCommand(e,t){return typeof e!="object"?(this.helpCommand(e,t),this):(this._addImplicitHelpCommand=!0,this._helpCommand=e,this)}_getHelpCommand(){return this._addImplicitHelpCommand??(this.commands.length&&!this._actionHandler&&!this._findCommand("help"))?(this._helpCommand===void 0&&this.helpCommand(void 0,void 0),this._helpCommand):null}hook(e,t){let s=["preSubcommand","preAction","postAction"];if(!s.includes(e))throw new Error(`Unexpected value for event passed to hook : '${e}'.
13
- Expecting one of '${s.join("', '")}'`);return this._lifeCycleHooks[e]?this._lifeCycleHooks[e].push(t):this._lifeCycleHooks[e]=[t],this}exitOverride(e){return e?this._exitCallback=e:this._exitCallback=t=>{if(t.code!=="commander.executeSubCommandAsync")throw t},this}_exit(e,t,s){this._exitCallback&&this._exitCallback(new li(e,t,s)),de.exit(e)}action(e){let t=s=>{let r=this.registeredArguments.length,i=s.slice(0,r);return this._storeOptionsAsProperties?i[r]=this:i[r]=this.opts(),i.push(this),e.apply(this,i)};return this._actionHandler=t,this}createOption(e,t){return new rc(e,t)}_callParseArg(e,t,s,r){try{return e.parseArg(t,s)}catch(i){if(i.code==="commander.invalidArgument"){let o=`${r} ${i.message}`;this.error(o,{exitCode:i.exitCode,code:i.code})}throw i}}_registerOption(e){let t=e.short&&this._findOption(e.short)||e.long&&this._findOption(e.long);if(t){let s=e.long&&this._findOption(e.long)?e.long:e.short;throw new Error(`Cannot add option '${e.flags}'${this._name&&` to command '${this._name}'`} due to conflicting flag '${s}'
14
- - already used by option '${t.flags}'`)}this.options.push(e)}_registerCommand(e){let t=r=>[r.name()].concat(r.aliases()),s=t(e).find(r=>this._findCommand(r));if(s){let r=t(this._findCommand(s)).join("|"),i=t(e).join("|");throw new Error(`cannot add command '${i}' as already have command '${r}'`)}this.commands.push(e)}addOption(e){this._registerOption(e);let t=e.name(),s=e.attributeName();if(e.negate){let i=e.long.replace(/^--no-/,"--");this._findOption(i)||this.setOptionValueWithSource(s,e.defaultValue===void 0?!0:e.defaultValue,"default")}else e.defaultValue!==void 0&&this.setOptionValueWithSource(s,e.defaultValue,"default");let r=(i,o,a)=>{i==null&&e.presetArg!==void 0&&(i=e.presetArg);let l=this.getOptionValue(s);i!==null&&e.parseArg?i=this._callParseArg(e,i,l,o):i!==null&&e.variadic&&(i=e._concatValue(i,l)),i==null&&(e.negate?i=!1:e.isBoolean()||e.optional?i=!0:i=""),this.setOptionValueWithSource(s,i,a)};return this.on("option:"+t,i=>{let o=`error: option '${e.flags}' argument '${i}' is invalid.`;r(i,o,"cli")}),e.envVar&&this.on("optionEnv:"+t,i=>{let o=`error: option '${e.flags}' value '${i}' from env '${e.envVar}' is invalid.`;r(i,o,"env")}),this}_optionEx(e,t,s,r,i){if(typeof t=="object"&&t instanceof rc)throw new Error("To add an Option object use addOption() instead of option() or requiredOption()");let o=this.createOption(t,s);if(o.makeOptionMandatory(!!e.mandatory),typeof r=="function")o.default(i).argParser(r);else if(r instanceof RegExp){let a=r;r=(l,u)=>{let d=a.exec(l);return d?d[0]:u},o.default(i).argParser(r)}else o.default(r);return this.addOption(o)}option(e,t,s,r){return this._optionEx({},e,t,s,r)}requiredOption(e,t,s,r){return this._optionEx({mandatory:!0},e,t,s,r)}combineFlagAndOptionalValue(e=!0){return this._combineFlagAndOptionalValue=!!e,this}allowUnknownOption(e=!0){return this._allowUnknownOption=!!e,this}allowExcessArguments(e=!0){return this._allowExcessArguments=!!e,this}enablePositionalOptions(e=!0){return this._enablePositionalOptions=!!e,this}passThroughOptions(e=!0){return this._passThroughOptions=!!e,this._checkForBrokenPassThrough(),this}_checkForBrokenPassThrough(){if(this.parent&&this._passThroughOptions&&!this.parent._enablePositionalOptions)throw new Error(`passThroughOptions cannot be used for '${this._name}' without turning on enablePositionalOptions for parent command(s)`)}storeOptionsAsProperties(e=!0){if(this.options.length)throw new Error("call .storeOptionsAsProperties() before adding options");if(Object.keys(this._optionValues).length)throw new Error("call .storeOptionsAsProperties() before setting option values");return this._storeOptionsAsProperties=!!e,this}getOptionValue(e){return this._storeOptionsAsProperties?this[e]:this._optionValues[e]}setOptionValue(e,t){return this.setOptionValueWithSource(e,t,void 0)}setOptionValueWithSource(e,t,s){return this._storeOptionsAsProperties?this[e]=t:this._optionValues[e]=t,this._optionValueSources[e]=s,this}getOptionValueSource(e){return this._optionValueSources[e]}getOptionValueSourceWithGlobals(e){let t;return this._getCommandAndAncestors().forEach(s=>{s.getOptionValueSource(e)!==void 0&&(t=s.getOptionValueSource(e))}),t}_prepareUserArgs(e,t){if(e!==void 0&&!Array.isArray(e))throw new Error("first parameter to parse must be array or undefined");if(t=t||{},e===void 0&&t.from===void 0){de.versions?.electron&&(t.from="electron");let r=de.execArgv??[];(r.includes("-e")||r.includes("--eval")||r.includes("-p")||r.includes("--print"))&&(t.from="eval")}e===void 0&&(e=de.argv),this.rawArgs=e.slice();let s;switch(t.from){case void 0:case"node":this._scriptPath=e[1],s=e.slice(2);break;case"electron":de.defaultApp?(this._scriptPath=e[1],s=e.slice(2)):s=e.slice(1);break;case"user":s=e.slice(0);break;case"eval":s=e.slice(1);break;default:throw new Error(`unexpected parse option { from: '${t.from}' }`)}return!this._name&&this._scriptPath&&this.nameFromFilename(this._scriptPath),this._name=this._name||"program",s}parse(e,t){let s=this._prepareUserArgs(e,t);return this._parseCommand([],s),this}async parseAsync(e,t){let s=this._prepareUserArgs(e,t);return await this._parseCommand([],s),this}_executeSubCommand(e,t){t=t.slice();let s=!1,r=[".js",".ts",".tsx",".mjs",".cjs"];function i(d,f){let h=St.resolve(d,f);if(ai.existsSync(h))return h;if(r.includes(St.extname(f)))return;let m=r.find(p=>ai.existsSync(`${h}${p}`));if(m)return`${h}${m}`}this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();let o=e._executableFile||`${this._name}-${e._name}`,a=this._executableDir||"";if(this._scriptPath){let d;try{d=ai.realpathSync(this._scriptPath)}catch{d=this._scriptPath}a=St.resolve(St.dirname(d),a)}if(a){let d=i(a,o);if(!d&&!e._executableFile&&this._scriptPath){let f=St.basename(this._scriptPath,St.extname(this._scriptPath));f!==this._name&&(d=i(a,`${f}-${e._name}`))}o=d||o}s=r.includes(St.extname(o));let l;de.platform!=="win32"?s?(t.unshift(o),t=oc(de.execArgv).concat(t),l=oi.spawn(de.argv[0],t,{stdio:"inherit"})):l=oi.spawn(o,t,{stdio:"inherit"}):(t.unshift(o),t=oc(de.execArgv).concat(t),l=oi.spawn(de.execPath,t,{stdio:"inherit"})),l.killed||["SIGUSR1","SIGUSR2","SIGTERM","SIGINT","SIGHUP"].forEach(f=>{de.on(f,()=>{l.killed===!1&&l.exitCode===null&&l.kill(f)})});let u=this._exitCallback;l.on("close",d=>{d=d??1,u?u(new li(d,"commander.executeSubCommandAsync","(close)")):de.exit(d)}),l.on("error",d=>{if(d.code==="ENOENT"){let f=a?`searched for local subcommand relative to directory '${a}'`:"no directory for search for local subcommand, use .executableDir() to supply a custom directory",h=`'${o}' does not exist
13
+ Expecting one of '${s.join("', '")}'`);return this._lifeCycleHooks[e]?this._lifeCycleHooks[e].push(t):this._lifeCycleHooks[e]=[t],this}exitOverride(e){return e?this._exitCallback=e:this._exitCallback=t=>{if(t.code!=="commander.executeSubCommandAsync")throw t},this}_exit(e,t,s){this._exitCallback&&this._exitCallback(new di(e,t,s)),de.exit(e)}action(e){let t=s=>{let r=this.registeredArguments.length,i=s.slice(0,r);return this._storeOptionsAsProperties?i[r]=this:i[r]=this.opts(),i.push(this),e.apply(this,i)};return this._actionHandler=t,this}createOption(e,t){return new ic(e,t)}_callParseArg(e,t,s,r){try{return e.parseArg(t,s)}catch(i){if(i.code==="commander.invalidArgument"){let o=`${r} ${i.message}`;this.error(o,{exitCode:i.exitCode,code:i.code})}throw i}}_registerOption(e){let t=e.short&&this._findOption(e.short)||e.long&&this._findOption(e.long);if(t){let s=e.long&&this._findOption(e.long)?e.long:e.short;throw new Error(`Cannot add option '${e.flags}'${this._name&&` to command '${this._name}'`} due to conflicting flag '${s}'
14
+ - already used by option '${t.flags}'`)}this.options.push(e)}_registerCommand(e){let t=r=>[r.name()].concat(r.aliases()),s=t(e).find(r=>this._findCommand(r));if(s){let r=t(this._findCommand(s)).join("|"),i=t(e).join("|");throw new Error(`cannot add command '${i}' as already have command '${r}'`)}this.commands.push(e)}addOption(e){this._registerOption(e);let t=e.name(),s=e.attributeName();if(e.negate){let i=e.long.replace(/^--no-/,"--");this._findOption(i)||this.setOptionValueWithSource(s,e.defaultValue===void 0?!0:e.defaultValue,"default")}else e.defaultValue!==void 0&&this.setOptionValueWithSource(s,e.defaultValue,"default");let r=(i,o,a)=>{i==null&&e.presetArg!==void 0&&(i=e.presetArg);let l=this.getOptionValue(s);i!==null&&e.parseArg?i=this._callParseArg(e,i,l,o):i!==null&&e.variadic&&(i=e._concatValue(i,l)),i==null&&(e.negate?i=!1:e.isBoolean()||e.optional?i=!0:i=""),this.setOptionValueWithSource(s,i,a)};return this.on("option:"+t,i=>{let o=`error: option '${e.flags}' argument '${i}' is invalid.`;r(i,o,"cli")}),e.envVar&&this.on("optionEnv:"+t,i=>{let o=`error: option '${e.flags}' value '${i}' from env '${e.envVar}' is invalid.`;r(i,o,"env")}),this}_optionEx(e,t,s,r,i){if(typeof t=="object"&&t instanceof ic)throw new Error("To add an Option object use addOption() instead of option() or requiredOption()");let o=this.createOption(t,s);if(o.makeOptionMandatory(!!e.mandatory),typeof r=="function")o.default(i).argParser(r);else if(r instanceof RegExp){let a=r;r=(l,u)=>{let d=a.exec(l);return d?d[0]:u},o.default(i).argParser(r)}else o.default(r);return this.addOption(o)}option(e,t,s,r){return this._optionEx({},e,t,s,r)}requiredOption(e,t,s,r){return this._optionEx({mandatory:!0},e,t,s,r)}combineFlagAndOptionalValue(e=!0){return this._combineFlagAndOptionalValue=!!e,this}allowUnknownOption(e=!0){return this._allowUnknownOption=!!e,this}allowExcessArguments(e=!0){return this._allowExcessArguments=!!e,this}enablePositionalOptions(e=!0){return this._enablePositionalOptions=!!e,this}passThroughOptions(e=!0){return this._passThroughOptions=!!e,this._checkForBrokenPassThrough(),this}_checkForBrokenPassThrough(){if(this.parent&&this._passThroughOptions&&!this.parent._enablePositionalOptions)throw new Error(`passThroughOptions cannot be used for '${this._name}' without turning on enablePositionalOptions for parent command(s)`)}storeOptionsAsProperties(e=!0){if(this.options.length)throw new Error("call .storeOptionsAsProperties() before adding options");if(Object.keys(this._optionValues).length)throw new Error("call .storeOptionsAsProperties() before setting option values");return this._storeOptionsAsProperties=!!e,this}getOptionValue(e){return this._storeOptionsAsProperties?this[e]:this._optionValues[e]}setOptionValue(e,t){return this.setOptionValueWithSource(e,t,void 0)}setOptionValueWithSource(e,t,s){return this._storeOptionsAsProperties?this[e]=t:this._optionValues[e]=t,this._optionValueSources[e]=s,this}getOptionValueSource(e){return this._optionValueSources[e]}getOptionValueSourceWithGlobals(e){let t;return this._getCommandAndAncestors().forEach(s=>{s.getOptionValueSource(e)!==void 0&&(t=s.getOptionValueSource(e))}),t}_prepareUserArgs(e,t){if(e!==void 0&&!Array.isArray(e))throw new Error("first parameter to parse must be array or undefined");if(t=t||{},e===void 0&&t.from===void 0){de.versions?.electron&&(t.from="electron");let r=de.execArgv??[];(r.includes("-e")||r.includes("--eval")||r.includes("-p")||r.includes("--print"))&&(t.from="eval")}e===void 0&&(e=de.argv),this.rawArgs=e.slice();let s;switch(t.from){case void 0:case"node":this._scriptPath=e[1],s=e.slice(2);break;case"electron":de.defaultApp?(this._scriptPath=e[1],s=e.slice(2)):s=e.slice(1);break;case"user":s=e.slice(0);break;case"eval":s=e.slice(1);break;default:throw new Error(`unexpected parse option { from: '${t.from}' }`)}return!this._name&&this._scriptPath&&this.nameFromFilename(this._scriptPath),this._name=this._name||"program",s}parse(e,t){let s=this._prepareUserArgs(e,t);return this._parseCommand([],s),this}async parseAsync(e,t){let s=this._prepareUserArgs(e,t);return await this._parseCommand([],s),this}_executeSubCommand(e,t){t=t.slice();let s=!1,r=[".js",".ts",".tsx",".mjs",".cjs"];function i(d,f){let h=St.resolve(d,f);if(ui.existsSync(h))return h;if(r.includes(St.extname(f)))return;let m=r.find(p=>ui.existsSync(`${h}${p}`));if(m)return`${h}${m}`}this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();let o=e._executableFile||`${this._name}-${e._name}`,a=this._executableDir||"";if(this._scriptPath){let d;try{d=ui.realpathSync(this._scriptPath)}catch{d=this._scriptPath}a=St.resolve(St.dirname(d),a)}if(a){let d=i(a,o);if(!d&&!e._executableFile&&this._scriptPath){let f=St.basename(this._scriptPath,St.extname(this._scriptPath));f!==this._name&&(d=i(a,`${f}-${e._name}`))}o=d||o}s=r.includes(St.extname(o));let l;de.platform!=="win32"?s?(t.unshift(o),t=ac(de.execArgv).concat(t),l=ci.spawn(de.argv[0],t,{stdio:"inherit"})):l=ci.spawn(o,t,{stdio:"inherit"}):(t.unshift(o),t=ac(de.execArgv).concat(t),l=ci.spawn(de.execPath,t,{stdio:"inherit"})),l.killed||["SIGUSR1","SIGUSR2","SIGTERM","SIGINT","SIGHUP"].forEach(f=>{de.on(f,()=>{l.killed===!1&&l.exitCode===null&&l.kill(f)})});let u=this._exitCallback;l.on("close",d=>{d=d??1,u?u(new di(d,"commander.executeSubCommandAsync","(close)")):de.exit(d)}),l.on("error",d=>{if(d.code==="ENOENT"){let f=a?`searched for local subcommand relative to directory '${a}'`:"no directory for search for local subcommand, use .executableDir() to supply a custom directory",h=`'${o}' does not exist
15
15
  - if '${e._name}' is not meant to be an executable command, remove description parameter from '.command()' and use '.description()' instead
16
16
  - if the default executable name is not suitable, use the executableFile option to supply a custom name or path
17
- - ${f}`;throw new Error(h)}else if(d.code==="EACCES")throw new Error(`'${o}' not executable`);if(!u)de.exit(1);else{let f=new li(1,"commander.executeSubCommandAsync","(error)");f.nestedError=d,u(f)}}),this.runningCommand=l}_dispatchSubcommand(e,t,s){let r=this._findCommand(e);r||this.help({error:!0});let i;return i=this._chainOrCallSubCommandHook(i,r,"preSubcommand"),i=this._chainOrCall(i,()=>{if(r._executableHandler)this._executeSubCommand(r,t.concat(s));else return r._parseCommand(t,s)}),i}_dispatchHelpCommand(e){e||this.help();let t=this._findCommand(e);return t&&!t._executableHandler&&t.help(),this._dispatchSubcommand(e,[],[this._getHelpOption()?.long??this._getHelpOption()?.short??"--help"])}_checkNumberOfArguments(){this.registeredArguments.forEach((e,t)=>{e.required&&this.args[t]==null&&this.missingArgument(e.name())}),!(this.registeredArguments.length>0&&this.registeredArguments[this.registeredArguments.length-1].variadic)&&this.args.length>this.registeredArguments.length&&this._excessArguments(this.args)}_processArguments(){let e=(s,r,i)=>{let o=r;if(r!==null&&s.parseArg){let a=`error: command-argument value '${r}' is invalid for argument '${s.name()}'.`;o=this._callParseArg(s,r,i,a)}return o};this._checkNumberOfArguments();let t=[];this.registeredArguments.forEach((s,r)=>{let i=s.defaultValue;s.variadic?r<this.args.length?(i=this.args.slice(r),s.parseArg&&(i=i.reduce((o,a)=>e(s,a,o),s.defaultValue))):i===void 0&&(i=[]):r<this.args.length&&(i=this.args[r],s.parseArg&&(i=e(s,i,s.defaultValue))),t[r]=i}),this.processedArgs=t}_chainOrCall(e,t){return e&&e.then&&typeof e.then=="function"?e.then(()=>t()):t()}_chainOrCallHooks(e,t){let s=e,r=[];return this._getCommandAndAncestors().reverse().filter(i=>i._lifeCycleHooks[t]!==void 0).forEach(i=>{i._lifeCycleHooks[t].forEach(o=>{r.push({hookedCommand:i,callback:o})})}),t==="postAction"&&r.reverse(),r.forEach(i=>{s=this._chainOrCall(s,()=>i.callback(i.hookedCommand,this))}),s}_chainOrCallSubCommandHook(e,t,s){let r=e;return this._lifeCycleHooks[s]!==void 0&&this._lifeCycleHooks[s].forEach(i=>{r=this._chainOrCall(r,()=>i(this,t))}),r}_parseCommand(e,t){let s=this.parseOptions(t);if(this._parseOptionsEnv(),this._parseOptionsImplied(),e=e.concat(s.operands),t=s.unknown,this.args=e.concat(t),e&&this._findCommand(e[0]))return this._dispatchSubcommand(e[0],e.slice(1),t);if(this._getHelpCommand()&&e[0]===this._getHelpCommand().name())return this._dispatchHelpCommand(e[1]);if(this._defaultCommandName)return this._outputHelpIfRequested(t),this._dispatchSubcommand(this._defaultCommandName,e,t);this.commands.length&&this.args.length===0&&!this._actionHandler&&!this._defaultCommandName&&this.help({error:!0}),this._outputHelpIfRequested(s.unknown),this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();let r=()=>{s.unknown.length>0&&this.unknownOption(s.unknown[0])},i=`command:${this.name()}`;if(this._actionHandler){r(),this._processArguments();let o;return o=this._chainOrCallHooks(o,"preAction"),o=this._chainOrCall(o,()=>this._actionHandler(this.processedArgs)),this.parent&&(o=this._chainOrCall(o,()=>{this.parent.emit(i,e,t)})),o=this._chainOrCallHooks(o,"postAction"),o}if(this.parent&&this.parent.listenerCount(i))r(),this._processArguments(),this.parent.emit(i,e,t);else if(e.length){if(this._findCommand("*"))return this._dispatchSubcommand("*",e,t);this.listenerCount("command:*")?this.emit("command:*",e,t):this.commands.length?this.unknownCommand():(r(),this._processArguments())}else this.commands.length?(r(),this.help({error:!0})):(r(),this._processArguments())}_findCommand(e){if(e)return this.commands.find(t=>t._name===e||t._aliases.includes(e))}_findOption(e){return this.options.find(t=>t.is(e))}_checkForMissingMandatoryOptions(){this._getCommandAndAncestors().forEach(e=>{e.options.forEach(t=>{t.mandatory&&e.getOptionValue(t.attributeName())===void 0&&e.missingMandatoryOptionValue(t)})})}_checkForConflictingLocalOptions(){let e=this.options.filter(s=>{let r=s.attributeName();return this.getOptionValue(r)===void 0?!1:this.getOptionValueSource(r)!=="default"});e.filter(s=>s.conflictsWith.length>0).forEach(s=>{let r=e.find(i=>s.conflictsWith.includes(i.attributeName()));r&&this._conflictingOption(s,r)})}_checkForConflictingOptions(){this._getCommandAndAncestors().forEach(e=>{e._checkForConflictingLocalOptions()})}parseOptions(e){let t=[],s=[],r=t,i=e.slice();function o(l){return l.length>1&&l[0]==="-"}let a=null;for(;i.length;){let l=i.shift();if(l==="--"){r===s&&r.push(l),r.push(...i);break}if(a&&!o(l)){this.emit(`option:${a.name()}`,l);continue}if(a=null,o(l)){let u=this._findOption(l);if(u){if(u.required){let d=i.shift();d===void 0&&this.optionMissingArgument(u),this.emit(`option:${u.name()}`,d)}else if(u.optional){let d=null;i.length>0&&!o(i[0])&&(d=i.shift()),this.emit(`option:${u.name()}`,d)}else this.emit(`option:${u.name()}`);a=u.variadic?u:null;continue}}if(l.length>2&&l[0]==="-"&&l[1]!=="-"){let u=this._findOption(`-${l[1]}`);if(u){u.required||u.optional&&this._combineFlagAndOptionalValue?this.emit(`option:${u.name()}`,l.slice(2)):(this.emit(`option:${u.name()}`),i.unshift(`-${l.slice(2)}`));continue}}if(/^--[^=]+=/.test(l)){let u=l.indexOf("="),d=this._findOption(l.slice(0,u));if(d&&(d.required||d.optional)){this.emit(`option:${d.name()}`,l.slice(u+1));continue}}if(o(l)&&(r=s),(this._enablePositionalOptions||this._passThroughOptions)&&t.length===0&&s.length===0){if(this._findCommand(l)){t.push(l),i.length>0&&s.push(...i);break}else if(this._getHelpCommand()&&l===this._getHelpCommand().name()){t.push(l),i.length>0&&t.push(...i);break}else if(this._defaultCommandName){s.push(l),i.length>0&&s.push(...i);break}}if(this._passThroughOptions){r.push(l),i.length>0&&r.push(...i);break}r.push(l)}return{operands:t,unknown:s}}opts(){if(this._storeOptionsAsProperties){let e={},t=this.options.length;for(let s=0;s<t;s++){let r=this.options[s].attributeName();e[r]=r===this._versionOptionName?this._version:this[r]}return e}return this._optionValues}optsWithGlobals(){return this._getCommandAndAncestors().reduce((e,t)=>Object.assign(e,t.opts()),{})}error(e,t){this._outputConfiguration.outputError(`${e}
17
+ - ${f}`;throw new Error(h)}else if(d.code==="EACCES")throw new Error(`'${o}' not executable`);if(!u)de.exit(1);else{let f=new di(1,"commander.executeSubCommandAsync","(error)");f.nestedError=d,u(f)}}),this.runningCommand=l}_dispatchSubcommand(e,t,s){let r=this._findCommand(e);r||this.help({error:!0});let i;return i=this._chainOrCallSubCommandHook(i,r,"preSubcommand"),i=this._chainOrCall(i,()=>{if(r._executableHandler)this._executeSubCommand(r,t.concat(s));else return r._parseCommand(t,s)}),i}_dispatchHelpCommand(e){e||this.help();let t=this._findCommand(e);return t&&!t._executableHandler&&t.help(),this._dispatchSubcommand(e,[],[this._getHelpOption()?.long??this._getHelpOption()?.short??"--help"])}_checkNumberOfArguments(){this.registeredArguments.forEach((e,t)=>{e.required&&this.args[t]==null&&this.missingArgument(e.name())}),!(this.registeredArguments.length>0&&this.registeredArguments[this.registeredArguments.length-1].variadic)&&this.args.length>this.registeredArguments.length&&this._excessArguments(this.args)}_processArguments(){let e=(s,r,i)=>{let o=r;if(r!==null&&s.parseArg){let a=`error: command-argument value '${r}' is invalid for argument '${s.name()}'.`;o=this._callParseArg(s,r,i,a)}return o};this._checkNumberOfArguments();let t=[];this.registeredArguments.forEach((s,r)=>{let i=s.defaultValue;s.variadic?r<this.args.length?(i=this.args.slice(r),s.parseArg&&(i=i.reduce((o,a)=>e(s,a,o),s.defaultValue))):i===void 0&&(i=[]):r<this.args.length&&(i=this.args[r],s.parseArg&&(i=e(s,i,s.defaultValue))),t[r]=i}),this.processedArgs=t}_chainOrCall(e,t){return e&&e.then&&typeof e.then=="function"?e.then(()=>t()):t()}_chainOrCallHooks(e,t){let s=e,r=[];return this._getCommandAndAncestors().reverse().filter(i=>i._lifeCycleHooks[t]!==void 0).forEach(i=>{i._lifeCycleHooks[t].forEach(o=>{r.push({hookedCommand:i,callback:o})})}),t==="postAction"&&r.reverse(),r.forEach(i=>{s=this._chainOrCall(s,()=>i.callback(i.hookedCommand,this))}),s}_chainOrCallSubCommandHook(e,t,s){let r=e;return this._lifeCycleHooks[s]!==void 0&&this._lifeCycleHooks[s].forEach(i=>{r=this._chainOrCall(r,()=>i(this,t))}),r}_parseCommand(e,t){let s=this.parseOptions(t);if(this._parseOptionsEnv(),this._parseOptionsImplied(),e=e.concat(s.operands),t=s.unknown,this.args=e.concat(t),e&&this._findCommand(e[0]))return this._dispatchSubcommand(e[0],e.slice(1),t);if(this._getHelpCommand()&&e[0]===this._getHelpCommand().name())return this._dispatchHelpCommand(e[1]);if(this._defaultCommandName)return this._outputHelpIfRequested(t),this._dispatchSubcommand(this._defaultCommandName,e,t);this.commands.length&&this.args.length===0&&!this._actionHandler&&!this._defaultCommandName&&this.help({error:!0}),this._outputHelpIfRequested(s.unknown),this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();let r=()=>{s.unknown.length>0&&this.unknownOption(s.unknown[0])},i=`command:${this.name()}`;if(this._actionHandler){r(),this._processArguments();let o;return o=this._chainOrCallHooks(o,"preAction"),o=this._chainOrCall(o,()=>this._actionHandler(this.processedArgs)),this.parent&&(o=this._chainOrCall(o,()=>{this.parent.emit(i,e,t)})),o=this._chainOrCallHooks(o,"postAction"),o}if(this.parent&&this.parent.listenerCount(i))r(),this._processArguments(),this.parent.emit(i,e,t);else if(e.length){if(this._findCommand("*"))return this._dispatchSubcommand("*",e,t);this.listenerCount("command:*")?this.emit("command:*",e,t):this.commands.length?this.unknownCommand():(r(),this._processArguments())}else this.commands.length?(r(),this.help({error:!0})):(r(),this._processArguments())}_findCommand(e){if(e)return this.commands.find(t=>t._name===e||t._aliases.includes(e))}_findOption(e){return this.options.find(t=>t.is(e))}_checkForMissingMandatoryOptions(){this._getCommandAndAncestors().forEach(e=>{e.options.forEach(t=>{t.mandatory&&e.getOptionValue(t.attributeName())===void 0&&e.missingMandatoryOptionValue(t)})})}_checkForConflictingLocalOptions(){let e=this.options.filter(s=>{let r=s.attributeName();return this.getOptionValue(r)===void 0?!1:this.getOptionValueSource(r)!=="default"});e.filter(s=>s.conflictsWith.length>0).forEach(s=>{let r=e.find(i=>s.conflictsWith.includes(i.attributeName()));r&&this._conflictingOption(s,r)})}_checkForConflictingOptions(){this._getCommandAndAncestors().forEach(e=>{e._checkForConflictingLocalOptions()})}parseOptions(e){let t=[],s=[],r=t,i=e.slice();function o(l){return l.length>1&&l[0]==="-"}let a=null;for(;i.length;){let l=i.shift();if(l==="--"){r===s&&r.push(l),r.push(...i);break}if(a&&!o(l)){this.emit(`option:${a.name()}`,l);continue}if(a=null,o(l)){let u=this._findOption(l);if(u){if(u.required){let d=i.shift();d===void 0&&this.optionMissingArgument(u),this.emit(`option:${u.name()}`,d)}else if(u.optional){let d=null;i.length>0&&!o(i[0])&&(d=i.shift()),this.emit(`option:${u.name()}`,d)}else this.emit(`option:${u.name()}`);a=u.variadic?u:null;continue}}if(l.length>2&&l[0]==="-"&&l[1]!=="-"){let u=this._findOption(`-${l[1]}`);if(u){u.required||u.optional&&this._combineFlagAndOptionalValue?this.emit(`option:${u.name()}`,l.slice(2)):(this.emit(`option:${u.name()}`),i.unshift(`-${l.slice(2)}`));continue}}if(/^--[^=]+=/.test(l)){let u=l.indexOf("="),d=this._findOption(l.slice(0,u));if(d&&(d.required||d.optional)){this.emit(`option:${d.name()}`,l.slice(u+1));continue}}if(o(l)&&(r=s),(this._enablePositionalOptions||this._passThroughOptions)&&t.length===0&&s.length===0){if(this._findCommand(l)){t.push(l),i.length>0&&s.push(...i);break}else if(this._getHelpCommand()&&l===this._getHelpCommand().name()){t.push(l),i.length>0&&t.push(...i);break}else if(this._defaultCommandName){s.push(l),i.length>0&&s.push(...i);break}}if(this._passThroughOptions){r.push(l),i.length>0&&r.push(...i);break}r.push(l)}return{operands:t,unknown:s}}opts(){if(this._storeOptionsAsProperties){let e={},t=this.options.length;for(let s=0;s<t;s++){let r=this.options[s].attributeName();e[r]=r===this._versionOptionName?this._version:this[r]}return e}return this._optionValues}optsWithGlobals(){return this._getCommandAndAncestors().reduce((e,t)=>Object.assign(e,t.opts()),{})}error(e,t){this._outputConfiguration.outputError(`${e}
18
18
  `,this._outputConfiguration.writeErr),typeof this._showHelpAfterError=="string"?this._outputConfiguration.writeErr(`${this._showHelpAfterError}
19
19
  `):this._showHelpAfterError&&(this._outputConfiguration.writeErr(`
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 de.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()}`,de.env[e.envVar]):this.emit(`optionEnv:${e.name()}`))}})}_parseOptionsImplied(){let e=new Sy(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=ic(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=ic(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}
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 de.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()}`,de.env[e.envVar]):this.emit(`optionEnv:${e.name()}`))}})}_parseOptionsImplied(){let e=new Sy(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=>wy(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=St.basename(e,St.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=de.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 oc(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})}ac.Command=ci});var fc=j(Ve=>{var{Argument:cc}=_s(),{Command:ui}=lc(),{CommanderError:_y,InvalidArgumentError:uc}=In(),{Help:Ay}=ti(),{Option:dc}=ii();Ve.program=new ui;Ve.createCommand=n=>new ui(n);Ve.createOption=(n,e)=>new dc(n,e);Ve.createArgument=(n,e)=>new cc(n,e);Ve.Command=ui;Ve.Option=dc;Ve.Argument=cc;Ve.Help=Ay;Ve.CommanderError=_y;Ve.InvalidArgumentError=uc;Ve.InvalidOptionArgumentError=uc});var mc={};Ne(mc,{DEFAULT_CONFIG:()=>Mn,NVIDIA_PROVIDER:()=>Dt});var Mn,Dt,Ln=N(()=>{"use strict";Mn={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:""}},Dt={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 As,gc=N(()=>{"use strict";As=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
- `);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 vc(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?.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 Ey(n){return n.map(e=>({type:"function",function:e.function}))}function Cy(n){return n.filter(e=>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 wc(n){return new Promise(e=>setTimeout(e,n))}function xc(n,e){return!(n.name==="AbortError"||e&&e>=400&&e<500&&e!==429)}var yc,ky,ks,bc,$y,Gt,di=N(()=>{"use strict";yc=12e4,ky=6e4,ks=3,bc=1e3,$y=20;Gt=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<$y;){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(ky)});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:vc(e)};t.length>0&&(i.tools=Ey(t),i.tool_choice="auto");let o=null;for(let a=0;a<=ks;a++)try{let l=new AbortController,u=setTimeout(()=>l.abort(),yc),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(!xc(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<ks){let x=bc*Math.pow(2,a);await wc(x);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?Cy(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(xc(f)&&(o=f,a<ks)){let h=bc*Math.pow(2,a);await wc(h);continue}throw f}}catch(l){if(l.name==="AbortError")throw l;if(o=l,a>=ks)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:vc(e),stream:!0}),signal:t||AbortSignal.timeout(yc)});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 Fe(n){if(n.provider==="nvidia"){let e={...n,provider:"custom",apiUrl:Dt.apiUrl};return new Gt(e)}return n.provider==="custom"&&n.apiUrl?new Gt(n):new As(n)}function $s(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 Dn=N(()=>{"use strict";Ln();gc();di()});var Sc=N(()=>{"use strict"});function Wt(){let n={providers:[],activeProvider:null,activeModel:null};try{if(_t.existsSync(pi)){let e=_t.readFileSync(pi,"utf-8"),t=JSON.parse(e);return{...n,...t}}}catch{}return n}function mi(n){_t.existsSync(fi)||_t.mkdirSync(fi,{recursive:!0}),_t.writeFileSync(pi,JSON.stringify(n,null,2),"utf-8")}function nt(n){let e=Wt();e.providers=e.providers.filter(t=>t.name!==n.name),e.providers.push(n),mi(e)}function Ac(n){let e=Wt(),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),mi(e),!0):!1}function kc(n){return Wt().providers.find(t=>t.name.toLowerCase()===n.toLowerCase())}function Es(){return Wt().providers}function $c(n,e){let t=Wt(),s=t.providers.find(r=>r.name===n);s&&(t.activeProvider=n,t.activeModel=e||s.defaultModel,mi(t))}function Ec(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
- `)}var _t,hi,_c,fi,pi,gi=N(()=>{"use strict";_t=O(require("fs")),hi=O(require("path")),_c=O(require("os"));Sc();fi=hi.join(_c.homedir(),".hablas"),pi=hi.join(fi,"models.json")});function Rs(){try{if(At.existsSync(Cs))return JSON.parse(At.readFileSync(Cs,"utf-8"))}catch{}return{}}function Tc(n){let e=Ts.dirname(Cs);At.existsSync(e)||At.mkdirSync(e,{recursive:!0}),At.writeFileSync(Cs,JSON.stringify(n,null,2),"utf-8")}function Rc(n,e){let t=Rs();t[n]=e,Tc(t)}function Oc(n){let e=Rs();return e[n]?(delete e[n],Tc(e),!0):!1}function Pc(n){let e=Rs(),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=Rs(),e=Object.entries(n);return e.length===0?` No aliases defined.
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=fi});var pc=j(Ve=>{var{Argument:uc}=As(),{Command:pi}=cc(),{CommanderError:_y,InvalidArgumentError:dc}=Mn(),{Help:Ay}=ri(),{Option:fc}=li();Ve.program=new pi;Ve.createCommand=n=>new pi(n);Ve.createOption=(n,e)=>new fc(n,e);Ve.createArgument=(n,e)=>new uc(n,e);Ve.Command=pi;Ve.Option=fc;Ve.Argument=uc;Ve.Help=Ay;Ve.CommanderError=_y;Ve.InvalidArgumentError=dc;Ve.InvalidOptionArgumentError=dc});var gc={};Ne(gc,{DEFAULT_CONFIG:()=>Ln,NVIDIA_PROVIDER:()=>Dt});var Ln,Dt,Dn=N(()=>{"use strict";Ln={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:""}},Dt={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 ks,yc=N(()=>{"use strict";ks=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
+ `);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?.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 Ey(n){return n.map(e=>({type:"function",function:e.function}))}function Cy(n){return n.filter(e=>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,ky,$s,vc,$y,Gt,hi=N(()=>{"use strict";bc=12e4,ky=6e4,$s=3,vc=1e3,$y=20;Gt=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<$y;){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(ky)});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=Ey(t),i.tool_choice="auto");let o=null;for(let a=0;a<=$s;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<$s){let x=vc*Math.pow(2,a);await xc(x);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?Cy(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<$s)){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>=$s)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 Fe(n){if(n.provider==="nvidia"){let e={...n,provider:"custom",apiUrl:Dt.apiUrl};return new Gt(e)}return n.provider==="custom"&&n.apiUrl?new Gt(n):new ks(n)}function Es(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 Nn=N(()=>{"use strict";Dn();yc();hi()});var _c=N(()=>{"use strict"});function Wt(){let n={providers:[],activeProvider:null,activeModel:null};try{if(_t.existsSync(gi)){let e=_t.readFileSync(gi,"utf-8"),t=JSON.parse(e);return{...n,...t}}}catch{}return n}function bi(n){_t.existsSync(mi)||_t.mkdirSync(mi,{recursive:!0}),_t.writeFileSync(gi,JSON.stringify(n,null,2),"utf-8")}function nt(n){let e=Wt();e.providers=e.providers.filter(t=>t.name!==n.name),e.providers.push(n),bi(e)}function kc(n){let e=Wt(),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),bi(e),!0):!1}function $c(n){return Wt().providers.find(t=>t.name.toLowerCase()===n.toLowerCase())}function Cs(){return Wt().providers}function Ec(n,e){let t=Wt(),s=t.providers.find(r=>r.name===n);s&&(t.activeProvider=n,t.activeModel=e||s.defaultModel,bi(t))}function Cc(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
+ `)}var _t,yi,Ac,mi,gi,vi=N(()=>{"use strict";_t=O(require("fs")),yi=O(require("path")),Ac=O(require("os"));_c();mi=yi.join(Ac.homedir(),".hablas"),gi=yi.join(mi,"models.json")});function Os(){try{if(At.existsSync(Ts))return JSON.parse(At.readFileSync(Ts,"utf-8"))}catch{}return{}}function Rc(n){let e=Rs.dirname(Ts);At.existsSync(e)||At.mkdirSync(e,{recursive:!0}),At.writeFileSync(Ts,JSON.stringify(n,null,2),"utf-8")}function Oc(n,e){let t=Os();t[n]=e,Rc(t)}function Pc(n){let e=Os();return e[n]?(delete e[n],Rc(e),!0):!1}function Ic(n){let e=Os(),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 Mc(){let n=Os(),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 At,Ts,Cc,Cs,yi=N(()=>{"use strict";At=O(require("fs")),Ts=O(require("path")),Cc=O(require("os")),Cs=Ts.join(Cc.homedir(),".hablas","aliases.json")});var Dc={};Ne(Dc,{disablePlugin:()=>xi,enablePlugin:()=>wi,ensurePluginsDir:()=>Is,listPlugins:()=>Lc,renderPlugins:()=>Si});function vi(){try{if(je.existsSync(Ps))return JSON.parse(je.readFileSync(Ps,"utf-8"))}catch{}return{disabled:[]}}function Mc(n){let e=ln.dirname(Ps);je.existsSync(e)||je.mkdirSync(e,{recursive:!0}),je.writeFileSync(Ps,JSON.stringify(n,null,2),"utf-8")}function Is(){je.existsSync(Os)||je.mkdirSync(Os,{recursive:!0})}function Lc(){Is();let n=vi(),e=[];try{let t=je.readdirSync(Os).filter(s=>s.endsWith(".js"));for(let s of t){let r=ln.join(Os,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 wi(n){let e=vi(),t=e.disabled.indexOf(n);return t!==-1?(e.disabled.splice(t,1),Mc(e),!0):!1}function xi(n){let e=vi();return e.disabled.includes(n)?!1:(e.disabled.push(n),Mc(e),!0)}function Si(){let n=Lc();return n.length===0?` No plugins installed.
28
+ `)}var At,Rs,Tc,Ts,wi=N(()=>{"use strict";At=O(require("fs")),Rs=O(require("path")),Tc=O(require("os")),Ts=Rs.join(Tc.homedir(),".hablas","aliases.json")});var Nc={};Ne(Nc,{disablePlugin:()=>Ai,enablePlugin:()=>_i,ensurePluginsDir:()=>Ms,listPlugins:()=>Dc,renderPlugins:()=>ki});function Si(){try{if(je.existsSync(Is))return JSON.parse(je.readFileSync(Is,"utf-8"))}catch{}return{disabled:[]}}function Lc(n){let e=cn.dirname(Is);je.existsSync(e)||je.mkdirSync(e,{recursive:!0}),je.writeFileSync(Is,JSON.stringify(n,null,2),"utf-8")}function Ms(){je.existsSync(Ps)||je.mkdirSync(Ps,{recursive:!0})}function Dc(){Ms();let n=Si(),e=[];try{let t=je.readdirSync(Ps).filter(s=>s.endsWith(".js"));for(let s of t){let r=cn.join(Ps,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=Si(),t=e.disabled.indexOf(n);return t!==-1?(e.disabled.splice(t,1),Lc(e),!0):!1}function Ai(n){let e=Si();return e.disabled.includes(n)?!1:(e.disabled.push(n),Lc(e),!0)}function ki(){let n=Dc();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 je,ln,bi,Os,Ps,_i=N(()=>{"use strict";je=O(require("fs")),ln=O(require("path")),bi=O(require("os")),Os=ln.join(bi.homedir(),".hablas","plugins"),Ps=ln.join(bi.homedir(),".hablas","plugins.json")});var jc={};Ne(jc,{renderDiagnostics:()=>$i,runDiagnostics:()=>ki});async function ki(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(st.homedir(),".hablas");if(e.push({name:"Config directory",status:Ai.existsSync(r)?"ok":"warn",message:Ai.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=st.homedir();if(process.platform!=="win32"){let a=(0,Fc.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:`${st.platform()} ${st.arch()} \u2014 ${st.cpus().length} cores, ${Math.round(st.totalmem()/1024/1024/1024)}GB RAM`}),e}function $i(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
- `)}var Ai,Nc,st,Fc,Ei=N(()=>{"use strict";Ai=O(require("fs")),Nc=O(require("path")),st=O(require("os")),Fc=require("child_process")});function Ci(n){let e=n.trim();return!!(e.length<15&&!Hc.test(e)||Ty.test(e)||Ry.test(e)||Oy.test(e)||Py.test(e))}function Ti(n){let e=n.toLowerCase(),t=["hablas"];return Ci(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&&Hc.test(n)&&t.push("alex")),t}function Bc(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 Ri(){let n=[];for(let e of we){let s=e.role==="hablas"?" \u2605":"";n.push(` @${e.name}${s} \u2014 ${e.title}`),n.push(` ${e.description}`)}return n.join(`
34
- `)}var we,Ty,Ry,Oy,Py,Hc,cn=N(()=>{"use strict";we=[{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"]}],Ty=/^(hi|hello|hey|howdy|yo|sup|hiya|good\s*(morning|afternoon|evening|night)|what'?s\s*up|greetings)\b/i,Ry=/^(مرحبا|أهلا|أهلاً|هلا|السلام\s*عليكم|وعليكم\s*السلام|كيف\s*حالك|كيفك|شلونك|صباح\s*الخير|مساء\s*الخير|شكرا|شكراً|يعطيك\s*العافية|تمام|اهلين|هلو|مرحبتين|الله\s*يسلمك|حياك|حياك\s*الله|يا\s*هلا|كيف\s*الحال|اخبارك|شخبارك)/i,Oy=/^(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,Py=/^(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,Hc=/\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 Nn(){try{if(un.existsSync(Oi)){let n=un.readFileSync(Oi,"utf-8"),e=JSON.parse(n);return{...Uc,...e}}}catch{}return{...Uc}}function Kc(){return Oi}var un,Pi,qc,Oi,Uc,Ii=N(()=>{"use strict";un=O(require("fs")),Pi=O(require("path")),qc=O(require("os")),Oi=Pi.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 Bi={};Ne(Bi,{formatStats:()=>Dy,loadStats:()=>Fn,saveStats:()=>dn,trackAgentUsage:()=>Hi,trackFileModified:()=>My,trackMessage:()=>Fi,trackSession:()=>Ni,trackToolCall:()=>ji});function Fn(){try{if(kt.existsSync(Li))return JSON.parse(kt.readFileSync(Li,"utf-8"))}catch{}return Iy()}function dn(n){try{kt.existsSync(Mi)||kt.mkdirSync(Mi,{recursive:!0}),kt.writeFileSync(Li,JSON.stringify(n,null,2))}catch{}}function Iy(){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 Ni(n){return n.totalSessions++,n.lastUsed=new Date().toISOString(),Ly(n),n}function Fi(n,e=0){n.totalMessages++,n.totalTokensUsed+=e;let t=Ms();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 ji(n,e){n.totalToolCalls++,n.commandUsage[e]=(n.commandUsage[e]||0)+1;let t=Ms();return n.dailyActivity[t]||(n.dailyActivity[t]={messages:0,tokens:0,toolCalls:0,filesModified:0,linesWritten:0}),n.dailyActivity[t].toolCalls++,n}function Hi(n,e){return n.agentUsage[e]=(n.agentUsage[e]||0)+1,n}function My(n,e=0){n.totalFilesModified++,n.totalLinesWritten+=e;let t=Ms();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 Ly(n){let e=Ms(),t=Wc(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 Ms(){return Wc(new Date)}function Wc(n){return n.toISOString().split("T")[0]}function Dy(n){let e=[];e.push(`
32
+ `)}var je,cn,xi,Ps,Is,$i=N(()=>{"use strict";je=O(require("fs")),cn=O(require("path")),xi=O(require("os")),Ps=cn.join(xi.homedir(),".hablas","plugins"),Is=cn.join(xi.homedir(),".hablas","plugins.json")});var Hc={};Ne(Hc,{renderDiagnostics:()=>Ti,runDiagnostics:()=>Ci});async function Ci(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=Fc.join(st.homedir(),".hablas");if(e.push({name:"Config directory",status:Ei.existsSync(r)?"ok":"warn",message:Ei.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=st.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:`${st.platform()} ${st.arch()} \u2014 ${st.cpus().length} cores, ${Math.round(st.totalmem()/1024/1024/1024)}GB RAM`}),e}function Ti(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
+ `)}var Ei,Fc,st,jc,Ri=N(()=>{"use strict";Ei=O(require("fs")),Fc=O(require("path")),st=O(require("os")),jc=require("child_process")});function Vt(n){let e=n.trim();return!!(e.length<15&&!Bc.test(e)||Ty.test(e)||Ry.test(e)||Oy.test(e)||Py.test(e))}function Oi(n){let e=n.toLowerCase(),t=["hablas"];return Vt(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 Uc(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 qc(){let n=[];for(let e of we){let s=e.role==="hablas"?" \u2605":"";n.push(` @${e.name}${s} \u2014 ${e.title}`),n.push(` ${e.description}`)}return n.join(`
34
+ `)}var we,Ty,Ry,Oy,Py,Bc,un=N(()=>{"use strict";we=[{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"]}],Ty=/^(hi|hello|hey|howdy|yo|sup|hiya|good\s*(morning|afternoon|evening|night)|what'?s\s*up|greetings)\b/i,Ry=/^(مرحبا|أهلا|أهلاً|هلا|السلام\s*عليكم|وعليكم\s*السلام|كيف\s*حالك|كيفك|شلونك|صباح\s*الخير|مساء\s*الخير|شكرا|شكراً|يعطيك\s*العافية|تمام|اهلين|هلو|مرحبتين|الله\s*يسلمك|حياك|حياك\s*الله|يا\s*هلا|كيف\s*الحال|اخبارك|شخبارك)/i,Oy=/^(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,Py=/^(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 Fn(){try{if(dn.existsSync(Pi)){let n=dn.readFileSync(Pi,"utf-8"),e=JSON.parse(n);return{...Kc,...e}}}catch{}return{...Kc}}function Wc(){return Pi}var dn,Ii,Gc,Pi,Kc,Mi=N(()=>{"use strict";dn=O(require("fs")),Ii=O(require("path")),Gc=O(require("os")),Pi=Ii.join(Gc.homedir(),".hablas","agents.json"),Kc={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 Ui={};Ne(Ui,{formatStats:()=>Dy,loadStats:()=>jn,saveStats:()=>fn,trackAgentUsage:()=>Bi,trackFileModified:()=>My,trackMessage:()=>ji,trackSession:()=>Fi,trackToolCall:()=>Hi});function jn(){try{if(kt.existsSync(Di))return JSON.parse(kt.readFileSync(Di,"utf-8"))}catch{}return Iy()}function fn(n){try{kt.existsSync(Li)||kt.mkdirSync(Li,{recursive:!0}),kt.writeFileSync(Di,JSON.stringify(n,null,2))}catch{}}function Iy(){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 Fi(n){return n.totalSessions++,n.lastUsed=new Date().toISOString(),Ly(n),n}function ji(n,e=0){n.totalMessages++,n.totalTokensUsed+=e;let t=Ls();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 Hi(n,e){n.totalToolCalls++,n.commandUsage[e]=(n.commandUsage[e]||0)+1;let t=Ls();return n.dailyActivity[t]||(n.dailyActivity[t]={messages:0,tokens:0,toolCalls:0,filesModified:0,linesWritten:0}),n.dailyActivity[t].toolCalls++,n}function Bi(n,e){return n.agentUsage[e]=(n.agentUsage[e]||0)+1,n}function My(n,e=0){n.totalFilesModified++,n.totalLinesWritten+=e;let t=Ls();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 Ly(n){let e=Ls(),t=zc(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 Ls(){return zc(new Date)}function zc(n){return n.toISOString().split("T")[0]}function Dy(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,Di,Gc,Mi,Li,jn=N(()=>{"use strict";kt=O(require("fs")),Di=O(require("path")),Gc=O(require("os")),Mi=Di.join(Gc.homedir(),".hablas"),Li=Di.join(Mi,"analytics.json")});var zc={};Ne(zc,{formatScanResults:()=>qi,runSecurityScan:()=>Ui});function Hy(n,e){let t=[],s=e.split(`
36
+ `)}var kt,Ni,Vc,Li,Di,Hn=N(()=>{"use strict";kt=O(require("fs")),Ni=O(require("path")),Vc=O(require("os")),Li=Ni.join(Vc.homedir(),".hablas"),Di=Ni.join(Li,"analytics.json")});var Jc={};Ne(Jc,{formatScanResults:()=>Ki,runSecurityScan:()=>qi});function Hy(n,e){let t=[],s=e.split(`
37
37
  `);for(let{pattern:r,name:i,severity:o}of Ny){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 By(n,e){let t=[],s=e.split(`
39
- `),r=Vt.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=Ls.readdirSync(n,{withFileTypes:!0});for(let s of t){if(Fy.has(s.name))continue;let r=Vt.join(n,s.name);if(s.isDirectory())Vc(r,e);else if(s.isFile()){let i=Vt.extname(s.name);jy.has(i)||e.push(r)}}}catch{}return e}function Ui(n){let e=Date.now(),t=Vc(n),s=[];for(let o of t)try{let a=Ls.readFileSync(o,"utf-8"),l=Vt.relative(n,o),u=Hy(l,a);s.push(...u);let d=By(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 qi(n){let e=[];if(e.push(`
39
+ `),r=zt.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 Yc(n,e=[]){try{let t=Ds.readdirSync(n,{withFileTypes:!0});for(let s of t){if(Fy.has(s.name))continue;let r=zt.join(n,s.name);if(s.isDirectory())Yc(r,e);else if(s.isFile()){let i=zt.extname(s.name);jy.has(i)||e.push(r)}}}catch{}return e}function qi(n){let e=Date.now(),t=Yc(n),s=[];for(let o of t)try{let a=Ds.readFileSync(o,"utf-8"),l=zt.relative(n,o),u=Hy(l,a);s.push(...u);let d=By(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 Ki(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 Ls,Vt,Ny,Fy,jy,Ki=N(()=>{"use strict";Ls=O(require("fs")),Vt=O(require("path")),Ny=[{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"}],Fy=new Set(["node_modules",".git","dist","build",".next","__pycache__","venv",".venv","target","vendor",".cache"]),jy=new Set([".png",".jpg",".jpeg",".gif",".svg",".ico",".woff",".woff2",".ttf",".eot",".mp4",".mp3",".zip",".tar",".gz",".lock"])});var Hn={};Ne(Hn,{formatGitStatus:()=>zy,generateChangelogPrompt:()=>Vy,generateCommitPrompt:()=>Gy,generatePRPrompt:()=>Wy,getDetailedDiff:()=>qy,getGitStatus:()=>Gi,getRecentCommits:()=>Ky,getStagedDiff:()=>Uy});async function Gi(n){try{let{stdout:e}=await fn("git branch --show-current",{cwd:n}),{stdout:t}=await fn("git status --porcelain",{cwd:n}),s=e.trim(),r=[],i=[],o=[];for(let u of t.split(`
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 fn("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 Uy(n){try{let{stdout:e}=await fn("git diff --cached --stat",{cwd:n});return e.trim()}catch{return""}}async function qy(n){try{let{stdout:e}=await fn("git diff --cached",{cwd:n,maxBuffer:1048576});return e.length>1e4?e.substring(0,1e4)+`
43
- ... (truncated)`:e.trim()}catch{return""}}async function Ky(n,e=20){try{let{stdout:t}=await fn(`git log --oneline --format="%H|%s|%an|%ai" -n ${e}`,{cwd:n});return t.trim().split(`
41
+ `)}var Ds,zt,Ny,Fy,jy,Gi=N(()=>{"use strict";Ds=O(require("fs")),zt=O(require("path")),Ny=[{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"}],Fy=new Set(["node_modules",".git","dist","build",".next","__pycache__","venv",".venv","target","vendor",".cache"]),jy=new Set([".png",".jpg",".jpeg",".gif",".svg",".ico",".woff",".woff2",".ttf",".eot",".mp4",".mp3",".zip",".tar",".gz",".lock"])});var Bn={};Ne(Bn,{formatGitStatus:()=>zy,generateChangelogPrompt:()=>Vy,generateCommitPrompt:()=>Gy,generatePRPrompt:()=>Wy,getDetailedDiff:()=>qy,getGitStatus:()=>Wi,getRecentCommits:()=>Ky,getStagedDiff:()=>Uy});async function Wi(n){try{let{stdout:e}=await pn("git branch --show-current",{cwd:n}),{stdout:t}=await pn("git status --porcelain",{cwd:n}),s=e.trim(),r=[],i=[],o=[];for(let u of t.split(`
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 pn("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 Uy(n){try{let{stdout:e}=await pn("git diff --cached --stat",{cwd:n});return e.trim()}catch{return""}}async function qy(n){try{let{stdout:e}=await pn("git diff --cached",{cwd:n,maxBuffer:1048576});return e.length>1e4?e.substring(0,1e4)+`
43
+ ... (truncated)`:e.trim()}catch{return""}}async function Ky(n,e=20){try{let{stdout:t}=await pn(`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 Gy(n,e){return`Based on the following git diff, generate a concise, conventional commit message.
45
45
 
46
46
  Rules:
@@ -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 zy(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,fn,pn=N(()=>{"use strict";Yc=require("child_process"),Jc=require("util"),fn=(0,Jc.promisify)(Yc.exec)});var tu={};Ne(tu,{detectFramework:()=>Qc,detectLanguage:()=>Zc,detectPackageManager:()=>Xc,formatWorkspaceInfo:()=>Wi,getGitBranch:()=>eu,scanWorkspace:()=>Ds});function Qc(n){let e=z.join(n,"package.json");if(W.existsSync(e))try{let t=JSON.parse(W.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(W.existsSync(z.join(n,"requirements.txt"))||W.existsSync(z.join(n,"pyproject.toml")))try{let t=W.existsSync(z.join(n,"requirements.txt"))?W.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(W.existsSync(z.join(n,"Cargo.toml")))try{if(W.readFileSync(z.join(n,"Cargo.toml"),"utf-8").includes("actix"))return"rust-actix"}catch{}if(W.existsSync(z.join(n,"go.mod")))try{if(W.readFileSync(z.join(n,"go.mod"),"utf-8").includes("fiber"))return"go-fiber"}catch{}return"unknown"}function Xc(n){return W.existsSync(z.join(n,"pnpm-lock.yaml"))?"pnpm":W.existsSync(z.join(n,"yarn.lock"))?"yarn":W.existsSync(z.join(n,"bun.lockb"))?"bun":W.existsSync(z.join(n,"package-lock.json"))?"npm":W.existsSync(z.join(n,"Cargo.toml"))?"cargo":W.existsSync(z.join(n,"go.mod"))?"go":W.existsSync(z.join(n,"requirements.txt"))||W.existsSync(z.join(n,"pyproject.toml"))?"pip":"unknown"}function Zc(n){return W.existsSync(z.join(n,"tsconfig.json"))?"TypeScript":W.existsSync(z.join(n,"package.json"))?"JavaScript":W.existsSync(z.join(n,"Cargo.toml"))?"Rust":W.existsSync(z.join(n,"go.mod"))?"Go":W.existsSync(z.join(n,"pyproject.toml"))||W.existsSync(z.join(n,"requirements.txt"))?"Python":"Unknown"}function eu(n){let e=z.join(n,".git","HEAD");if(!W.existsSync(e))return null;try{let t=W.readFileSync(e,"utf-8").trim();return t.startsWith("ref: refs/heads/")?t.replace("ref: refs/heads/",""):t.substring(0,8)}catch{return null}}function Ds(n){let e=Qc(n),t=Xc(n),s=Zc(n),r=eu(n),i=W.existsSync(z.join(n,"Dockerfile"))||W.existsSync(z.join(n,"docker-compose.yml"))||W.existsSync(z.join(n,"docker-compose.yaml")),o=W.existsSync(z.join(n,".github","workflows"))||W.existsSync(z.join(n,".gitlab-ci.yml"))||W.existsSync(z.join(n,"Jenkinsfile")),a=W.existsSync(z.join(n,"__tests__"))||W.existsSync(z.join(n,"tests"))||W.existsSync(z.join(n,"test"))||W.existsSync(z.join(n,"spec")),l=W.existsSync(z.join(n,".git")),u=[],d=[".env",".env.local",".env.development",".env.production",".env.example"];for(let g of d)W.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)W.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)W.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 Wi(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 W,z,Vi=N(()=>{"use strict";W=O(require("fs")),z=O(require("path"))});function nu(){return`
102
+ `)}var Qc,Xc,pn,hn=N(()=>{"use strict";Qc=require("child_process"),Xc=require("util"),pn=(0,Xc.promisify)(Qc.exec)});var su={};Ne(su,{detectFramework:()=>Zc,detectLanguage:()=>tu,detectPackageManager:()=>eu,formatWorkspaceInfo:()=>Vi,getGitBranch:()=>nu,scanWorkspace:()=>Ns});function Zc(n){let e=z.join(n,"package.json");if(W.existsSync(e))try{let t=JSON.parse(W.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(W.existsSync(z.join(n,"requirements.txt"))||W.existsSync(z.join(n,"pyproject.toml")))try{let t=W.existsSync(z.join(n,"requirements.txt"))?W.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(W.existsSync(z.join(n,"Cargo.toml")))try{if(W.readFileSync(z.join(n,"Cargo.toml"),"utf-8").includes("actix"))return"rust-actix"}catch{}if(W.existsSync(z.join(n,"go.mod")))try{if(W.readFileSync(z.join(n,"go.mod"),"utf-8").includes("fiber"))return"go-fiber"}catch{}return"unknown"}function eu(n){return W.existsSync(z.join(n,"pnpm-lock.yaml"))?"pnpm":W.existsSync(z.join(n,"yarn.lock"))?"yarn":W.existsSync(z.join(n,"bun.lockb"))?"bun":W.existsSync(z.join(n,"package-lock.json"))?"npm":W.existsSync(z.join(n,"Cargo.toml"))?"cargo":W.existsSync(z.join(n,"go.mod"))?"go":W.existsSync(z.join(n,"requirements.txt"))||W.existsSync(z.join(n,"pyproject.toml"))?"pip":"unknown"}function tu(n){return W.existsSync(z.join(n,"tsconfig.json"))?"TypeScript":W.existsSync(z.join(n,"package.json"))?"JavaScript":W.existsSync(z.join(n,"Cargo.toml"))?"Rust":W.existsSync(z.join(n,"go.mod"))?"Go":W.existsSync(z.join(n,"pyproject.toml"))||W.existsSync(z.join(n,"requirements.txt"))?"Python":"Unknown"}function nu(n){let e=z.join(n,".git","HEAD");if(!W.existsSync(e))return null;try{let t=W.readFileSync(e,"utf-8").trim();return t.startsWith("ref: refs/heads/")?t.replace("ref: refs/heads/",""):t.substring(0,8)}catch{return null}}function Ns(n){let e=Zc(n),t=eu(n),s=tu(n),r=nu(n),i=W.existsSync(z.join(n,"Dockerfile"))||W.existsSync(z.join(n,"docker-compose.yml"))||W.existsSync(z.join(n,"docker-compose.yaml")),o=W.existsSync(z.join(n,".github","workflows"))||W.existsSync(z.join(n,".gitlab-ci.yml"))||W.existsSync(z.join(n,"Jenkinsfile")),a=W.existsSync(z.join(n,"__tests__"))||W.existsSync(z.join(n,"tests"))||W.existsSync(z.join(n,"test"))||W.existsSync(z.join(n,"spec")),l=W.existsSync(z.join(n,".git")),u=[],d=[".env",".env.local",".env.development",".env.production",".env.example"];for(let g of d)W.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)W.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)W.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 Vi(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 W,z,zi=N(()=>{"use strict";W=O(require("fs")),z=O(require("path"))});function ru(){return`
104
104
  ## Available Tools (HEP-1 Protocol)
105
105
 
106
106
  You can execute tools by outputting a strict JSON block wrapped inside <action>...</action> tags.
@@ -181,39 +181,39 @@ You MUST NOT write any conversational text or explanation outside of these tags
181
181
  1. ONLY ONE tool execution per turn. Wait for result before calling another.
182
182
  2. The JSON block inside <action>...</action> MUST be valid JSON (use double quotes, escape newlines properly).
183
183
  3. If you have no tools to run, output your response inside <response>...</response> tags. Do NOT use <action> tags if you are answering.
184
- `.trim()}var su=N(()=>{"use strict"});function Yy(){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 fe(n,e){return lu||!hn?n:`${e}${n}\x1B[0m`}function Jy(n){let e=Pe();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 Qy(n,e=2){let t=Pe()-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(`
184
+ `.trim()}var iu=N(()=>{"use strict"});function Yy(){try{let n=[Fs.resolve(__dirname,"..","..","package.json"),Fs.resolve(__dirname,"..","package.json"),Fs.resolve(__dirname,"package.json")];for(let e of n)if(js.existsSync(e)){let t=JSON.parse(js.readFileSync(e,"utf-8"));if(t.version)return t.version}return"1.2.0"}catch{return"1.2.0"}}function fe(n,e){return lu||!mn?n:`${e}${n}\x1B[0m`}function Jy(n){let e=Pe();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 Qy(n,e=2){let t=Pe()-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(`
185
185
  `)}function Xy(n){let e=Math.max(...n.map(([t])=>t.length));return n.map(([t,s])=>` ${c.muted(t.padEnd(e))} ${s}`).join(`
186
- `)}function Zy(n){if(lu||!hn)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=Pe(),s=e?e.replace(Ji.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"),x=c.muted(`SYSTEM VERSION: v${au}`),A=c.warning(`CORE MODEL: ${n}`);return["",r,f,m,u?g:"",i,` ${c.muted("\u25B8")} ${x}`,` ${c.muted("\u25B8")} ${A}`,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(`
186
+ `)}function Zy(n){if(lu||!mn)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=Pe(),s=e?e.replace(Qi.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"),x=c.muted(`SYSTEM VERSION: v${au}`),A=c.warning(`CORE MODEL: ${n}`);return["",r,f,m,u?g:"",i,` ${c.muted("\u25B8")} ${x}`,` ${c.muted("\u25B8")} ${A}`,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(`
187
187
  `)}function du(){let n=Pe();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(`
188
- `)}function Un(n,e){return`
188
+ `)}function qn(n,e){return`
189
189
  ${(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(`
190
190
  `)}function pu(){let n=Pe(),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(`
191
191
  `)}function hu(){let n=Pe();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(`
192
192
  `)}function mu(){return["",` ${Zy("\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(`
193
- `)}function ru(n,e){let t=Math.min(Pe()-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 qn(n){let e=n.split(`
194
- `),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=zi(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]+".")} ${zi(l[2])}`);continue}}if(!o.trim()){t.push("");continue}let a=Qy(zi(o),2);t.push(...a.split(`
195
- `))}return s&&i.length>0&&t.push(...ru(i,r)),`
193
+ `)}function ou(n,e){let t=Math.min(Pe()-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 Kn(n){let e=n.split(`
194
+ `),t=[],s=!1,r="",i=[];for(let o of e){if(o.trimStart().startsWith("```")){s?(t.push(...ou(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=Yi(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]+".")} ${Yi(l[2])}`);continue}}if(!o.trim()){t.push("");continue}let a=Qy(Yi(o),2);t.push(...a.split(`
195
+ `))}return s&&i.length>0&&t.push(...ou(i,r)),`
196
196
  `+t.join(`
197
197
  `)+`
198
- `}function zi(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=Pe(),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`
198
+ `}function Yi(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=Pe(),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`
199
199
  ${r}
200
200
  ${i}${" ".repeat(a)} ${c.border("\u2502")}`}function yu(n,e,t){let s=Pe(),r=c.muted(`${t}ms`),i="";if(n){let u=e.split(`
201
201
  `).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(`
202
202
  `)[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")}
203
203
  ${l}
204
- `}function Qi(n){let e=n.split(`
204
+ `}function Xi(n){let e=n.split(`
205
205
  `),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(`
206
206
  `)}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`
207
207
  `+Jy(t)+`
208
208
  `}function $e(n){return` ${c.error("\u2717")} ${n}`}function He(n,e){return` ${c.error("\u2717")} ${n}
209
- ${c.warning("\u2192")} ${c.muted(e)}`}function J(n){return` ${c.success("\u2713")} ${n}`}function he(n){return` ${c.muted(n)}`}function B(n){return` ${c.warning("\u26A0")} ${n}`}function eb(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=Pe(),t=n.connected?c.success("\u25CF connected"):c.error("\u25CB offline"),s=eb(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(Ji.homedir(),"~"))],["context",`${s} ${c.muted(`${n.cacheFiles} files \xB7 ${n.cacheTokens}/${n.budgetTokens} tokens`)}`],["turns",c.muted(String(n.turnCount))],["status",t]];return`
209
+ ${c.warning("\u2192")} ${c.muted(e)}`}function J(n){return` ${c.success("\u2713")} ${n}`}function he(n){return` ${c.muted(n)}`}function B(n){return` ${c.warning("\u26A0")} ${n}`}function eb(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=Pe(),t=n.connected?c.success("\u25CF connected"):c.error("\u25CB offline"),s=eb(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(Qi.homedir(),"~"))],["context",`${s} ${c.muted(`${n.cacheFiles} files \xB7 ${n.cacheTokens}/${n.budgetTokens} tokens`)}`],["turns",c.muted(String(n.turnCount))],["status",t]];return`
210
210
  `+c.chrome("\u256D"+"\u2500".repeat(e-2)+"\u256E")+`
211
211
  ${c.accent("\u2726")} ${c.strong("Status")}
212
212
 
213
213
  `+Xy(r)+`
214
214
 
215
215
  `+c.chrome("\u2570"+"\u2500".repeat(e-2)+"\u256F")+`
216
- `}function wu(){let n=Pe(),e=Math.max(...Yi.map(r=>r.cmd.length+(r.arg?r.arg.length+1:0))),t=Yi.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`
216
+ `}function wu(){let n=Pe(),e=Math.max(...Ji.map(r=>r.cmd.length+(r.arg?r.arg.length+1:0))),t=Ji.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`
217
217
  `+c.chrome("\u256D"+"\u2500".repeat(n-2)+"\u256E")+`
218
218
  ${c.accent("\u2726")} ${c.strong("Commands")}
219
219
 
@@ -223,13 +223,13 @@ ${l}
223
223
  `)+`
224
224
 
225
225
  `+c.chrome("\u2570"+"\u2500".repeat(n-2)+"\u256F")+`
226
- `}function Xi(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(`
226
+ `}function Zi(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(`
227
227
  `)}function xu(n,e){let t=Pe(),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=nb[u.status](tb[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(`
228
228
  `)}function Su(n){let e=Pe(),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(`
229
- `)}function Zi(n){let e=Math.min(Pe(),80),t=[],s=`\u250C${"\u2500".repeat(e-2)}\u2510`,r=`\u251C${"\u2500".repeat(e-2)}\u2524`,i=`\u2514${"\u2500".repeat(e-2)}\u2518`;t.push(` ${c.border(s)}`);let a=`\u2605 MISSION STATUS: ${n.taskTitle}`.slice(0,e-4).padEnd(e-4);t.push(` ${c.border("\u2502")} ${c.strong(a)} ${c.border("\u2502")}`),t.push(` ${c.border(r)}`);let u=`Phase: ${n.currentPhase}`.slice(0,e-4).padEnd(e-4);t.push(` ${c.border("\u2502")} ${c.primary(u)} ${c.border("\u2502")}`);let d=[];for(let[y,v]of Object.entries(n.roster)){let b=y==="Hablas"?c.leader:y==="Bob"?c.architect:y==="Alex"?c.engineer:y==="David"?c.analyst:c.product,w="";v==="done"?w=c.success("\u2713"):v==="active"?w=c.highlight("\u25CF"):w=c.muted("\u25CB"),d.push(`@${b(y)} ${w}`)}let f=`Roster: ${d.join(" ")}`,h=f.replace(/\x1b\[[0-9;]*m/g,""),m=Math.max(0,e-4-h.length);t.push(` ${c.border("\u2502")} ${f}${" ".repeat(m)} ${c.border("\u2502")}`);let p=`Active: @${n.activeAgent} (${n.activeAgentTitle})`,g=p.replace(/\x1b\[[0-9;]*m/g,""),x=Math.max(0,e-4-g.length);t.push(` ${c.border("\u2502")} ${p}${" ".repeat(x)} ${c.border("\u2502")}`);let A=`Action: ${n.currentActivity}`,$=A.replace(/\x1b\[[0-9;]*m/g,""),_=Math.max(0,e-4-$.length);return t.push(` ${c.border("\u2502")} ${c.secondary(A)}${" ".repeat(_)} ${c.border("\u2502")}`),t.push(` ${c.border(i)}`),t.join(`
230
- `)}var Ji,iu,ou,au,hn,lu,cu,Pe,c,ze,Yi,tb,nb,Bn,eo,mn=N(()=>{"use strict";Ji=O(require("os")),iu=O(require("fs")),ou=O(require("path"));au=Yy(),hn=process.stdout.isTTY===!0,lu=process.env.NO_COLOR!==void 0||process.env.TERM==="dumb",cu=process.stdout.columns||80;hn&&process.stdout.on("resize",()=>{cu=process.stdout.columns||80});Pe=()=>Math.min(cu-4,100);c={primary:n=>fe(n,"\x1B[38;5;253m"),secondary:n=>fe(n,"\x1B[38;5;247m"),muted:n=>fe(n,"\x1B[38;5;242m"),strong:n=>fe(n,"\x1B[1;38;5;255m"),accent:n=>fe(n,"\x1B[38;5;145m"),highlight:n=>fe(n,"\x1B[38;5;231m"),success:n=>fe(n,"\x1B[38;5;108m"),error:n=>fe(n,"\x1B[38;5;167m"),warning:n=>fe(n,"\x1B[38;5;179m"),info:n=>fe(n,"\x1B[38;5;110m"),codeBlock:n=>fe(n,"\x1B[38;5;188m"),lineNum:n=>fe(n,"\x1B[38;5;239m"),border:n=>fe(n,"\x1B[38;5;237m"),chrome:n=>fe(n,"\x1B[38;5;235m"),added:n=>fe(n,"\x1B[38;5;108m"),removed:n=>fe(n,"\x1B[38;5;167m"),hunk:n=>fe(n,"\x1B[38;5;145m"),leader:n=>fe(n,"\x1B[38;5;179m"),architect:n=>fe(n,"\x1B[38;5;250m"),engineer:n=>fe(n,"\x1B[38;5;145m"),analyst:n=>fe(n,"\x1B[38;5;108m"),product:n=>fe(n,"\x1B[38;5;180m")};ze=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(),!hn){process.stderr.write(` ${this.message}...
231
- `);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(hn&&process.stdout.write("\r"+" ".repeat(80)+"\r"),e&&hn){let s=c.muted(`${t}ms`);console.log(` ${c.muted("\xB7")} ${c.secondary(e)} ${s}`)}}};Yi=[{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"}];tb={pending:"\u25CB",running:"\u25C9",done:"\u2713",failed:"\u2717",skipped:"\u2013"},nb={pending:c.muted,running:c.accent,done:c.success,failed:c.error,skipped:c.muted};Bn=class{lastBoxHeight=0;isPinned=!1;render(e){let t=Zi(e),s=t.split(`
232
- `);this.isPinned&&(process.stdout.write(`\x1B[${this.lastBoxHeight}A`),process.stdout.write("\x1B[J")),console.log(t),this.lastBoxHeight=s.length,this.isPinned=!0}unpin(){this.isPinned=!1,this.lastBoxHeight=0}},eo=Yi.map(n=>n.cmd).concat(["/exit","/addmodel","/listmodels","/removemodel","/usemodel","/provider","/task","/memory","/mindset","/mindsets","/alias","/doctor","/plugins","/team","/agents","/delegate"])});function to(n){let e=rt.join(n,"package.json");if(Be.existsSync(e))try{let t=JSON.parse(Be.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(Be.existsSync(rt.join(n,"pytest.ini"))||Be.existsSync(rt.join(n,"pyproject.toml"))||Be.existsSync(rt.join(n,"setup.py")))try{let t=Be.existsSync(rt.join(n,"requirements.txt"))?Be.readFileSync(rt.join(n,"requirements.txt"),"utf-8"):"",s=Be.existsSync(rt.join(n,"pyproject.toml"))?Be.readFileSync(rt.join(n,"pyproject.toml"),"utf-8"):"";if(t.includes("pytest")||s.includes("pytest"))return"pytest"}catch{}return Be.existsSync(rt.join(n,"go.mod"))?"go":Be.existsSync(rt.join(n,"Cargo.toml"))?"cargo":"unknown"}function sb(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 Au(n,e){let t=to(n),s=sb(t,e),r=Date.now(),i="",o="",a=!1;try{i=(0,_u.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}=rb(i+`
229
+ `)}function eo(n){let e=Math.min(Pe(),80),t=[],s=`\u250C${"\u2500".repeat(e-2)}\u2510`,r=`\u251C${"\u2500".repeat(e-2)}\u2524`,i=`\u2514${"\u2500".repeat(e-2)}\u2518`;t.push(` ${c.border(s)}`);let a=`\u2605 MISSION STATUS: ${n.taskTitle}`.slice(0,e-4).padEnd(e-4);t.push(` ${c.border("\u2502")} ${c.strong(a)} ${c.border("\u2502")}`),t.push(` ${c.border(r)}`);let u=`Phase: ${n.currentPhase}`.slice(0,e-4).padEnd(e-4);t.push(` ${c.border("\u2502")} ${c.primary(u)} ${c.border("\u2502")}`);let d=[];for(let[y,v]of Object.entries(n.roster)){let b=y==="Hablas"?c.leader:y==="Bob"?c.architect:y==="Alex"?c.engineer:y==="David"?c.analyst:c.product,w="";v==="done"?w=c.success("\u2713"):v==="active"?w=c.highlight("\u25CF"):w=c.muted("\u25CB"),d.push(`@${b(y)} ${w}`)}let f=`Roster: ${d.join(" ")}`,h=f.replace(/\x1b\[[0-9;]*m/g,""),m=Math.max(0,e-4-h.length);t.push(` ${c.border("\u2502")} ${f}${" ".repeat(m)} ${c.border("\u2502")}`);let p=`Active: @${n.activeAgent} (${n.activeAgentTitle})`,g=p.replace(/\x1b\[[0-9;]*m/g,""),x=Math.max(0,e-4-g.length);t.push(` ${c.border("\u2502")} ${p}${" ".repeat(x)} ${c.border("\u2502")}`);let A=`Action: ${n.currentActivity}`,$=A.replace(/\x1b\[[0-9;]*m/g,""),_=Math.max(0,e-4-$.length);return t.push(` ${c.border("\u2502")} ${c.secondary(A)}${" ".repeat(_)} ${c.border("\u2502")}`),t.push(` ${c.border(i)}`),t.join(`
230
+ `)}var Qi,js,Fs,au,mn,lu,cu,Pe,c,ze,Ji,tb,nb,Un,to,gn=N(()=>{"use strict";Qi=O(require("os")),js=O(require("fs")),Fs=O(require("path"));au=Yy(),mn=process.stdout.isTTY===!0,lu=process.env.NO_COLOR!==void 0||process.env.TERM==="dumb",cu=process.stdout.columns||80;mn&&process.stdout.on("resize",()=>{cu=process.stdout.columns||80});Pe=()=>Math.min(cu-4,100);c={primary:n=>fe(n,"\x1B[38;5;253m"),secondary:n=>fe(n,"\x1B[38;5;247m"),muted:n=>fe(n,"\x1B[38;5;242m"),strong:n=>fe(n,"\x1B[1;38;5;255m"),accent:n=>fe(n,"\x1B[38;5;145m"),highlight:n=>fe(n,"\x1B[38;5;231m"),success:n=>fe(n,"\x1B[38;5;108m"),error:n=>fe(n,"\x1B[38;5;167m"),warning:n=>fe(n,"\x1B[38;5;179m"),info:n=>fe(n,"\x1B[38;5;110m"),codeBlock:n=>fe(n,"\x1B[38;5;188m"),lineNum:n=>fe(n,"\x1B[38;5;239m"),border:n=>fe(n,"\x1B[38;5;237m"),chrome:n=>fe(n,"\x1B[38;5;235m"),added:n=>fe(n,"\x1B[38;5;108m"),removed:n=>fe(n,"\x1B[38;5;167m"),hunk:n=>fe(n,"\x1B[38;5;145m"),leader:n=>fe(n,"\x1B[38;5;179m"),architect:n=>fe(n,"\x1B[38;5;250m"),engineer:n=>fe(n,"\x1B[38;5;145m"),analyst:n=>fe(n,"\x1B[38;5;108m"),product:n=>fe(n,"\x1B[38;5;180m")};ze=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(),!mn){process.stderr.write(` ${this.message}...
231
+ `);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(mn&&process.stdout.write("\r"+" ".repeat(80)+"\r"),e&&mn){let s=c.muted(`${t}ms`);console.log(` ${c.muted("\xB7")} ${c.secondary(e)} ${s}`)}}};Ji=[{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"}];tb={pending:"\u25CB",running:"\u25C9",done:"\u2713",failed:"\u2717",skipped:"\u2013"},nb={pending:c.muted,running:c.accent,done:c.success,failed:c.error,skipped:c.muted};Un=class{lastBoxHeight=0;isPinned=!1;render(e){let t=eo(e),s=t.split(`
232
+ `);this.isPinned&&(process.stdout.write(`\x1B[${this.lastBoxHeight}A`),process.stdout.write("\x1B[J")),console.log(t),this.lastBoxHeight=s.length,this.isPinned=!0}unpin(){this.isPinned=!1,this.lastBoxHeight=0}},to=Ji.map(n=>n.cmd).concat(["/exit","/addmodel","/listmodels","/removemodel","/usemodel","/provider","/task","/memory","/mindset","/mindsets","/alias","/doctor","/plugins","/team","/agents","/delegate"])});function no(n){let e=rt.join(n,"package.json");if(Be.existsSync(e))try{let t=JSON.parse(Be.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(Be.existsSync(rt.join(n,"pytest.ini"))||Be.existsSync(rt.join(n,"pyproject.toml"))||Be.existsSync(rt.join(n,"setup.py")))try{let t=Be.existsSync(rt.join(n,"requirements.txt"))?Be.readFileSync(rt.join(n,"requirements.txt"),"utf-8"):"",s=Be.existsSync(rt.join(n,"pyproject.toml"))?Be.readFileSync(rt.join(n,"pyproject.toml"),"utf-8"):"";if(t.includes("pytest")||s.includes("pytest"))return"pytest"}catch{}return Be.existsSync(rt.join(n,"go.mod"))?"go":Be.existsSync(rt.join(n,"Cargo.toml"))?"cargo":"unknown"}function sb(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 Au(n,e){let t=no(n),s=sb(t,e),r=Date.now(),i="",o="",a=!1;try{i=(0,_u.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}=rb(i+`
233
233
  `+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 rb(n,e){let t=0,s=0,r=0,i=[],o=n.split(`
234
234
  `);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(`
235
235
  `)}function $u(n){return`The following tests are failing. Analyze the error output and fix the code.
@@ -252,21 +252,21 @@ Instructions:
252
252
  1. Read the failing test files to understand what's expected
253
253
  2. Read the source files being tested
254
254
  3. Fix the source code (not the tests) to make them pass
255
- 4. After fixing, explain what was wrong and what you changed`}var _u,Be,rt,Eu=N(()=>{"use strict";_u=require("child_process"),Be=O(require("fs")),rt=O(require("path"))});function Fs(n){let e=Buffer.from(n).toString("base64url").slice(0,16);return Ie.join(ib,e)}async function Tu(n,e,t){let s=Fs(n);Ee.existsSync(s)||Ee.mkdirSync(s,{recursive:!0});let r=`cp_${Date.now()}`,i=[];for(let f of t){let h=Ie.resolve(n,f);if(Ee.existsSync(h))try{let m=await $t.readFile(h,"utf-8");i.push({path:f,content:m})}catch{}}try{let f=(0,Ns.execSync)("git ls-files -m",{cwd:n,encoding:"utf-8",timeout:5e3}).split(`
256
- `).filter(Boolean);for(let h of f)if(!i.find(m=>m.path===h))try{let m=await $t.readFile(Ie.resolve(n,h),"utf-8");i.push({path:h,content:m})}catch{}}catch{}let o,a;try{o=(0,Ns.execSync)("git branch --show-current",{cwd:n,encoding:"utf-8",timeout:5e3}).trim(),a=(0,Ns.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=Ie.join(s,`${r}.json`);await $t.writeFile(u,JSON.stringify(l,null,2),"utf-8");let d=Ee.readdirSync(s).filter(f=>f.endsWith(".json")).sort();if(d.length>20)for(let f of d.slice(0,d.length-20))try{Ee.unlinkSync(Ie.join(s,f))}catch{}return{id:r,label:e,timestamp:l.timestamp,fileCount:i.length,projectPath:n}}function Ru(n){let e=Fs(n);if(!Ee.existsSync(e))return[];let t=Ee.readdirSync(e).filter(r=>r.endsWith(".json")).sort().reverse(),s=[];for(let r of t)try{let i=JSON.parse(Ee.readFileSync(Ie.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 Ou(n,e){let t=Fs(n),s=Ie.join(t,`${e}.json`);if(!Ee.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=Ie.resolve(n,o.path);await $t.mkdir(Ie.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=Fs(n),s=Ie.join(t,`${e}.json`);try{if(Ee.existsSync(s))return Ee.unlinkSync(s),!0}catch{}return!1}function Iu(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(`
257
- `)}var Ee,$t,Ie,Cu,Ns,ib,Mu=N(()=>{"use strict";Ee=O(require("fs")),$t=O(require("fs/promises")),Ie=O(require("path")),Cu=O(require("os")),Ns=require("child_process"),ib=Ie.join(Cu.homedir(),".hablas","checkpoints")});function Et(){}function ob(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,x){var A=s[d+x];return A.length>g.length?A: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 ab(n,e,t){return oo.diff(n,e,t)}function js(n){"@babel/helpers - typeof";return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?js=function(e){return typeof e}:js=function(e){return e&&typeof Symbol=="function"&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},js(n)}function no(n){return ub(n)||db(n)||fb(n)||pb()}function ub(n){if(Array.isArray(n))return so(n)}function db(n){if(typeof Symbol<"u"&&Symbol.iterator in Object(n))return Array.from(n)}function fb(n,e){if(n){if(typeof n=="string")return so(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 so(n,e)}}function so(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 pb(){throw new TypeError(`Invalid attempt to spread non-iterable instance.
258
- In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function ro(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(hb.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]=ro(n[i],e,t,s,r);return e.pop(),t.pop(),o}if(n&&n.toJSON&&(n=n.toJSON()),js(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]=ro(n[l],e,t,s,l);e.pop(),t.pop()}else o=n;return o}function mb(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]||`
255
+ 4. After fixing, explain what was wrong and what you changed`}var _u,Be,rt,Eu=N(()=>{"use strict";_u=require("child_process"),Be=O(require("fs")),rt=O(require("path"))});function Bs(n){let e=Buffer.from(n).toString("base64url").slice(0,16);return Ie.join(ib,e)}async function Tu(n,e,t){let s=Bs(n);Ee.existsSync(s)||Ee.mkdirSync(s,{recursive:!0});let r=`cp_${Date.now()}`,i=[];for(let f of t){let h=Ie.resolve(n,f);if(Ee.existsSync(h))try{let m=await $t.readFile(h,"utf-8");i.push({path:f,content:m})}catch{}}try{let f=(0,Hs.execSync)("git ls-files -m",{cwd:n,encoding:"utf-8",timeout:5e3}).split(`
256
+ `).filter(Boolean);for(let h of f)if(!i.find(m=>m.path===h))try{let m=await $t.readFile(Ie.resolve(n,h),"utf-8");i.push({path:h,content:m})}catch{}}catch{}let o,a;try{o=(0,Hs.execSync)("git branch --show-current",{cwd:n,encoding:"utf-8",timeout:5e3}).trim(),a=(0,Hs.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=Ie.join(s,`${r}.json`);await $t.writeFile(u,JSON.stringify(l,null,2),"utf-8");let d=Ee.readdirSync(s).filter(f=>f.endsWith(".json")).sort();if(d.length>20)for(let f of d.slice(0,d.length-20))try{Ee.unlinkSync(Ie.join(s,f))}catch{}return{id:r,label:e,timestamp:l.timestamp,fileCount:i.length,projectPath:n}}function Ru(n){let e=Bs(n);if(!Ee.existsSync(e))return[];let t=Ee.readdirSync(e).filter(r=>r.endsWith(".json")).sort().reverse(),s=[];for(let r of t)try{let i=JSON.parse(Ee.readFileSync(Ie.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 Ou(n,e){let t=Bs(n),s=Ie.join(t,`${e}.json`);if(!Ee.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=Ie.resolve(n,o.path);await $t.mkdir(Ie.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=Bs(n),s=Ie.join(t,`${e}.json`);try{if(Ee.existsSync(s))return Ee.unlinkSync(s),!0}catch{}return!1}function Iu(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(`
257
+ `)}var Ee,$t,Ie,Cu,Hs,ib,Mu=N(()=>{"use strict";Ee=O(require("fs")),$t=O(require("fs/promises")),Ie=O(require("path")),Cu=O(require("os")),Hs=require("child_process"),ib=Ie.join(Cu.homedir(),".hablas","checkpoints")});function Et(){}function ob(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,x){var A=s[d+x];return A.length>g.length?A: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 ab(n,e,t){return ao.diff(n,e,t)}function Us(n){"@babel/helpers - typeof";return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?Us=function(e){return typeof e}:Us=function(e){return e&&typeof Symbol=="function"&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},Us(n)}function so(n){return ub(n)||db(n)||fb(n)||pb()}function ub(n){if(Array.isArray(n))return ro(n)}function db(n){if(typeof Symbol<"u"&&Symbol.iterator in Object(n))return Array.from(n)}function fb(n,e){if(n){if(typeof n=="string")return ro(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 ro(n,e)}}function ro(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 pb(){throw new TypeError(`Invalid attempt to spread non-iterable instance.
258
+ In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function io(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(hb.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]=io(n[i],e,t,s,r);return e.pop(),t.pop(),o}if(n&&n.toJSON&&(n=n.toJSON()),Us(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]=io(n[l],e,t,s,l);e.pop(),t.pop()}else o=n;return o}function mb(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]||`
259
259
  `),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 gb(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=mb(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(C,E,Y,D){return E===D},a=0,l=t.fuzzFactor||0,u=0,d=0,f,h;function m(C,E){for(var Y=0;Y<C.lines.length;Y++){var D=C.lines[Y],X=D.length>0?D[0]:" ",ee=D.length>0?D.substr(1):D;if(X===" "||X==="-"){if(!o(E+1,s[E],X,ee)&&(a++,a>l))return!1;E++}}return!0}for(var p=0;p<i.length;p++){for(var g=i[p],x=s.length-g.oldLines,A=0,$=d+g.oldStart-1,_=gb($,u,x);A!==void 0;A=_())if(m(g,$+A)){g.offset=d+=A;break}if(A===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],w=b.oldStart+b.offset+y-1;y+=b.newLines-b.oldLines;for(var S=0;S<b.lines.length;S++){var T=b.lines[S],M=T.length>0?T[0]:" ",k=T.length>0?T.substr(1):T,F=b.linedelimiters&&b.linedelimiters[S]||`
260
260
  `;if(M===" ")w++;else if(M==="-")s.splice(w,1),r.splice(w,1);else if(M==="+")s.splice(w,0,k),r.splice(w,0,F),w++;else if(M==="\\"){var H=b.lines[S-1]?b.lines[S-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(`
261
261
  `));for(var V=0;V<s.length-1;V++)s[V]=s[V]+r[V];return s.join("")}function yb(n,e,t,s,r,i,o){o||(o={}),typeof o.context>"u"&&(o.context=4);var a=ab(t,s,o);if(!a)return;a.push({value:"",lines:[]});function l(A){return A.map(function($){return" "+$})}for(var u=[],d=0,f=0,h=[],m=1,p=1,g=function($){var _=a[$],y=_.lines||_.value.replace(/\n$/,"").split(`
262
- `);if(_.lines=y,_.added||_.removed){var v;if(!d){var b=a[$-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,no(y.map(function(V){return(_.added?"+":"-")+V}))),_.added?p+=y.length:m+=y.length}else{if(d)if(y.length<=o.context*2&&$<a.length-2){var w;(w=h).push.apply(w,no(l(y)))}else{var S,T=Math.min(y.length,o.context);(S=h).push.apply(S,no(l(y.slice(0,T))));var M={oldStart:d,oldLines:m-d+T,newStart:f,newLines:p-f+T,lines:h};if($>=a.length-2&&y.length<=o.context){var k=/\n$/.test(t),F=/\n$/.test(s),H=y.length==0&&h.length>M.oldLines;!k&&H&&t.length>0&&h.splice(M.oldLines,0,"\"),(!k&&!H||!F)&&h.push("\")}u.push(M),d=0,f=0,h=[]}m+=y.length,p+=y.length}},x=0;x<a.length;x++)g(x);return{oldFileName:n,newFileName:e,oldHeader:r,newHeader:i,hunks:u}}function ju(n){if(Array.isArray(n))return n.map(ju).join(`
262
+ `);if(_.lines=y,_.added||_.removed){var v;if(!d){var b=a[$-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,so(y.map(function(V){return(_.added?"+":"-")+V}))),_.added?p+=y.length:m+=y.length}else{if(d)if(y.length<=o.context*2&&$<a.length-2){var w;(w=h).push.apply(w,so(l(y)))}else{var S,T=Math.min(y.length,o.context);(S=h).push.apply(S,so(l(y.slice(0,T))));var M={oldStart:d,oldLines:m-d+T,newStart:f,newLines:p-f+T,lines:h};if($>=a.length-2&&y.length<=o.context){var k=/\n$/.test(t),F=/\n$/.test(s),H=y.length==0&&h.length>M.oldLines;!k&&H&&t.length>0&&h.splice(M.oldLines,0,"\"),(!k&&!H||!F)&&h.push("\")}u.push(M),d=0,f=0,h=[]}m+=y.length,p+=y.length}},x=0;x<a.length;x++)g(x);return{oldFileName:n,newFileName:e,oldHeader:r,newHeader:i,hunks:u}}function ju(n){if(Array.isArray(n))return n.map(ju).join(`
263
263
  `);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(`
264
264
  `)+`
265
- `}function bb(n,e,t,s,r,i,o){return ju(yb(n,e,t,s,r,i,o))}function Hu(n,e,t,s,r,i){return bb(n,n,e,t,s,r,i)}var HE,Lu,Du,Nu,oo,lb,cb,hb,Kn,io,Bu=N(()=>{Et.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 x=-1/0,A=1/0;function $(){for(var y=Math.max(x,-d);y<=Math.min(A,d);y+=2){var v=void 0,b=p[y-1],w=p[y+1];b&&(p[y-1]=void 0);var S=!1;if(w){var T=w.oldPos-y;S=w&&0<=T&&T<l}var M=b&&b.oldPos+1<u;if(!S&&!M){p[y]=void 0;continue}if(!M||S&&b.oldPos+1<w.oldPos?v=o.addToPath(w,!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(ob(o,v.lastComponent,t,e,o.useLongestToken));p[y]=v,v.oldPos+1>=u&&(A=Math.min(A,y-1)),g+1>=l&&(x=Math.max(x,y+1))}d++}if(i)(function y(){setTimeout(function(){if(d>f||Date.now()>m)return i();$()||y()},0)})();else for(;d<=f&&Date.now()<=m;){var _=$();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("")}};HE=new Et,Lu=/^[A-Za-z\xC0-\u02C6\u02C8-\u02D7\u02DE-\u02FF\u1E00-\u1EFF]+$/,Du=/\S/,Nu=new Et;Nu.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)};Nu.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]&&Lu.test(e[t])&&Lu.test(e[t+2])&&(e[t]+=e[t+2],e.splice(t+1,2),t--);return e};oo=new Et;oo.tokenize=function(n){this.options.stripTrailingCr&&(n=n.replace(/\r\n/g,`
266
- `));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};lb=new Et;lb.tokenize=function(n){return n.split(/(\S.+?[.!?])(?=\s+|$)/)};cb=new Et;cb.tokenize=function(n){return n.split(/([{}:;,]|\s+)/)};hb=Object.prototype.toString,Kn=new Et;Kn.useLongestToken=!0;Kn.tokenize=oo.tokenize;Kn.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(ro(n,null,null,r),r," ")};Kn.equals=function(n,e){return Et.prototype.equals.call(Kn,n.replace(/,([\r\n])/g,"$1"),e.replace(/,([\r\n])/g,"$1"))};io=new Et;io.tokenize=function(n){return n.slice()};io.join=io.removeEmpty=function(n){return n}});var Uu={};Ne(Uu,{applyDiff:()=>vb,formatDiffForDisplay:()=>wb,generateDiff:()=>Hs});function Hs(n,e,t){return Hu(n,e,t,"original","modified")}function vb(n,e){return Fu(n,e)}function wb(n){return n.split(`
265
+ `}function bb(n,e,t,s,r,i,o){return ju(yb(n,e,t,s,r,i,o))}function Hu(n,e,t,s,r,i){return bb(n,n,e,t,s,r,i)}var HE,Lu,Du,Nu,ao,lb,cb,hb,Gn,oo,Bu=N(()=>{Et.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 x=-1/0,A=1/0;function $(){for(var y=Math.max(x,-d);y<=Math.min(A,d);y+=2){var v=void 0,b=p[y-1],w=p[y+1];b&&(p[y-1]=void 0);var S=!1;if(w){var T=w.oldPos-y;S=w&&0<=T&&T<l}var M=b&&b.oldPos+1<u;if(!S&&!M){p[y]=void 0;continue}if(!M||S&&b.oldPos+1<w.oldPos?v=o.addToPath(w,!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(ob(o,v.lastComponent,t,e,o.useLongestToken));p[y]=v,v.oldPos+1>=u&&(A=Math.min(A,y-1)),g+1>=l&&(x=Math.max(x,y+1))}d++}if(i)(function y(){setTimeout(function(){if(d>f||Date.now()>m)return i();$()||y()},0)})();else for(;d<=f&&Date.now()<=m;){var _=$();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("")}};HE=new Et,Lu=/^[A-Za-z\xC0-\u02C6\u02C8-\u02D7\u02DE-\u02FF\u1E00-\u1EFF]+$/,Du=/\S/,Nu=new Et;Nu.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)};Nu.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]&&Lu.test(e[t])&&Lu.test(e[t+2])&&(e[t]+=e[t+2],e.splice(t+1,2),t--);return e};ao=new Et;ao.tokenize=function(n){this.options.stripTrailingCr&&(n=n.replace(/\r\n/g,`
266
+ `));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};lb=new Et;lb.tokenize=function(n){return n.split(/(\S.+?[.!?])(?=\s+|$)/)};cb=new Et;cb.tokenize=function(n){return n.split(/([{}:;,]|\s+)/)};hb=Object.prototype.toString,Gn=new Et;Gn.useLongestToken=!0;Gn.tokenize=ao.tokenize;Gn.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(io(n,null,null,r),r," ")};Gn.equals=function(n,e){return Et.prototype.equals.call(Gn,n.replace(/,([\r\n])/g,"$1"),e.replace(/,([\r\n])/g,"$1"))};oo=new Et;oo.tokenize=function(n){return n.slice()};oo.join=oo.removeEmpty=function(n){return n}});var Uu={};Ne(Uu,{applyDiff:()=>vb,formatDiffForDisplay:()=>wb,generateDiff:()=>qs});function qs(n,e,t){return Hu(n,e,t,"original","modified")}function vb(n,e){return Fu(n,e)}function wb(n){return n.split(`
267
267
  `).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(`
268
- `)}var ao=N(()=>{"use strict";Bu()});async function gn(n,e){let t=[],s=ke.join(n,"package.json");if(me.existsSync(s))try{let o=JSON.parse(me.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=Ds(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 Gi(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=>me.existsSync(ke.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=>me.existsSync(ke.join(n,o)));if(i.length>0&&t.push(`Config: ${i.join(", ")}`),e?.context?.projectGraph)try{let o=me.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=me.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(`
269
- `)}function yn(n,e,t,s){let r=n+`
268
+ `)}var lo=N(()=>{"use strict";Bu()});async function yn(n,e){let t=[],s=ke.join(n,"package.json");if(me.existsSync(s))try{let o=JSON.parse(me.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=Ns(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 Wi(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=>me.existsSync(ke.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=>me.existsSync(ke.join(n,o)));if(i.length>0&&t.push(`Config: ${i.join(", ")}`),e?.context?.projectGraph)try{let o=me.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=me.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(`
269
+ `)}function bn(n,e,t,s){let r=n+`
270
270
 
271
271
  ## Current Project
272
272
  `+e;if(t){let i=t.getSummary();i&&(r+=`
@@ -276,14 +276,14 @@ In order to be iterable, non-array objects must have a [Symbol.iterator]() metho
276
276
  ## Shared Context
277
277
  `+i)}return r+=`
278
278
 
279
- `+nu(),r}async function xb(n){try{if(!me.existsSync(lo))return null;let t=(await Nt.readdir(lo)).filter(f=>f.endsWith(".bak"));if(n){let f=ke.basename(n);t=t.filter(h=>h.startsWith(`${f}.`))}if(t.length===0)return null;t.sort().reverse();let s=t[0],r=ke.join(lo,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 qu(n,e,t,s,r,i,o,a,l,u,d,f,h,m,p,g,x){let A=n.split(/\s+/),$=A[0],_=A.slice(1).join(" ");switch($){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(Ri()),console.log();break}case"/model":if(_){let y=await t.listModels();t.setModel(_),y.includes(_)?console.log(J(`Model: ${_}`)):console.log(B(`Model set to "${_}" (not found locally)`))}else console.log(he(`Current model: ${t.getModel()}`)),console.log(c.muted(" Usage: /model <name>"));break;case"/models":{let y=_.trim(),v=1,b="";if(y){let E=parseInt(y);!isNaN(E)&&E>0?v=E:b=y.toLowerCase()}let w=new ze("Fetching models");w.start();let S=await t.listModels();if(w.stop(S.length>0?`${S.length} found`:void 0),S.length===0){console.log(B("No models found \u2014 check your connection")),console.log(c.muted(" Use /provider test to verify"));break}let T=S;if(b&&(T=S.filter(E=>E.toLowerCase().includes(b)),T.length===0)){console.log(B(`No models matching: "${b}"`)),console.log(c.muted(` ${S.length} models available. Try a different search.`));break}let M=20,k=Math.ceil(T.length/M),F=Math.max(1,Math.min(v,k)),H=(F-1)*M,V=H+M,C=T.slice(H,V);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Available Models")} ${c.muted(`(${T.length} total \xB7 page ${F}/${k})`)}`),console.log();for(let E=0;E<C.length;E++){let Y=H+E+1,X=C[E]===t.getModel()?` ${c.success("\u25CF active")}`:"";console.log(` ${c.muted(String(Y).padStart(3," "))}. ${c.secondary(C[E])}${X}`)}console.log(),k>1&&console.log(c.muted(` /models ${F<k?F+1:1} \u2014 next page`)),b&&console.log(c.muted(` Filtered: ${T.length} of ${S.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(`
279
+ `+ru(),r}async function xb(n){try{if(!me.existsSync(co))return null;let t=(await Nt.readdir(co)).filter(f=>f.endsWith(".bak"));if(n){let f=ke.basename(n);t=t.filter(h=>h.startsWith(`${f}.`))}if(t.length===0)return null;t.sort().reverse();let s=t[0],r=ke.join(co,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 qu(n,e,t,s,r,i,o,a,l,u,d,f,h,m,p,g,x){let A=n.split(/\s+/),$=A[0],_=A.slice(1).join(" ");switch($){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"/model":if(_){let y=await t.listModels();t.setModel(_),y.includes(_)?console.log(J(`Model: ${_}`)):console.log(B(`Model set to "${_}" (not found locally)`))}else console.log(he(`Current model: ${t.getModel()}`)),console.log(c.muted(" Usage: /model <name>"));break;case"/models":{let y=_.trim(),v=1,b="";if(y){let E=parseInt(y);!isNaN(E)&&E>0?v=E:b=y.toLowerCase()}let w=new ze("Fetching models");w.start();let S=await t.listModels();if(w.stop(S.length>0?`${S.length} found`:void 0),S.length===0){console.log(B("No models found \u2014 check your connection")),console.log(c.muted(" Use /provider test to verify"));break}let T=S;if(b&&(T=S.filter(E=>E.toLowerCase().includes(b)),T.length===0)){console.log(B(`No models matching: "${b}"`)),console.log(c.muted(` ${S.length} models available. Try a different search.`));break}let M=20,k=Math.ceil(T.length/M),F=Math.max(1,Math.min(v,k)),H=(F-1)*M,V=H+M,C=T.slice(H,V);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Available Models")} ${c.muted(`(${T.length} total \xB7 page ${F}/${k})`)}`),console.log();for(let E=0;E<C.length;E++){let Y=H+E+1,X=C[E]===t.getModel()?` ${c.success("\u25CF active")}`:"";console.log(` ${c.muted(String(Y).padStart(3," "))}. ${c.secondary(C[E])}${X}`)}console.log(),k>1&&console.log(c.muted(` /models ${F<k?F+1:1} \u2014 next page`)),b&&console.log(c.muted(` Filtered: ${T.length} of ${S.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(`
280
280
  ${v.output}
281
281
  `)}break}case"/status":{let y=await t.checkConnection(),v=u?u.getActiveName():"planner",b=f?f.size():0,w=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}`)),w&&w.total>0&&console.log(c.muted(` Tasks: ${w.done}/${w.total} done`)),console.log();break}case"/clear":r.clear(),i.clear(),console.log(J("History cleared"));break;case"/history":{let y=parseInt(_)||10,v=i.getHistory().slice(-y);if(v.length===0){console.log(he("No history yet"));break}console.log(),v.forEach(b=>{let w=b.role==="user"?c.primary("You"):b.role==="assistant"?c.success("Hablas"):c.muted("tool"),S=b.content.slice(0,120).replace(/\n/g," ");console.log(` ${w}: ${c.muted(S)}`)}),console.log();break}case"/undo":{if(!g){let y=await xb(_||void 0);if(!y){console.log(B("No backups found"));break}let v=_?ke.resolve(o,_):ke.resolve(o,y.originalName);if(await a.confirm(`Restore ${y.originalName} from backup (${y.age})?`))try{let w=await Nt.readFile(y.backupPath,"utf-8");await Nt.writeFile(v,w,"utf-8"),console.log(J(`Restored ${y.originalName} from backup (${y.age})`))}catch(w){console.log($e(`Failed: ${w.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(he("Nothing to undo"));break}if(await a.confirm(`Undo ALL ${y} changes?`)){let b=await g.undoAll(),w=b.filter(S=>S.success).length;console.log(J(`Reverted ${w}/${b.length} changes`))}}else{let y=_&&parseInt(_)||1;if(g.getUndoableCount()===0){console.log(he("Nothing to undo"));break}let v=await g.undo(y);for(let b of v)b.success?console.log(J(`Reverted: ${b.file}`)):console.log($e(`Failed to revert ${b.file}: ${b.error}`))}break}case"/config":console.log(`
282
282
  ${c.muted(JSON.stringify(e,null,2))}
283
- `),console.log(c.muted(" ~/.hablas/config.json")),console.log();break;case"/mindset":{if(!u){console.log(B("Mindset system not available"));break}if(_)if(u.setActive(_)){let v=u.getActive(),b=await gn(o,e),w=yn(v.systemPrompt,b,f,m);i.updateSystemPrompt(w),console.log(J(`Mindset: ${v.name} \u2014 ${v.description}`))}else{let v=u.listNames().join(", ");console.log(He(`Unknown mindset: "${_}"`,`Available: ${v}`))}else{let y=u.getActive();y&&console.log(he(`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(B("Mindset system not available"));break}let y=u.list(),v=u.getActiveName();console.log();for(let b of y){let S=b.name===v?c.success(" \u25CF active"):"";console.log(` ${c.accent("\u25C6")} ${c.primary(b.name)}${S}`),console.log(` ${c.muted(b.description)}`)}console.log(),console.log(c.muted(" Switch: /mindset <name>")),console.log();break}case"/task":{if(!d){console.log(B("Task queue not available"));break}let y=A[1],v=A.slice(2).join(" ");switch(y){case"add":if(v){let b=d.add(v);console.log(J(`Task #${b.id} added: ${v}`))}else console.log(B("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(J(`Task #${b} marked as done`))):console.log(B("Usage: /task done <id>"));break}case"fail":{let b=parseInt(v);b?(d.fail(b,"Manually marked as failed"),console.log(B(`Task #${b} marked as failed`))):console.log(B("Usage: /task fail <id>"));break}case"clear":d.clear(),console.log(J("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(B("Cancelled \u2014 name is required"));break}let w=(await a.prompt(` ${c.muted("API URL (e.g. https://api.openai.com/v1):")} `)).trim();if(!w){console.log(B("Cancelled \u2014 URL is required"));break}let T=(await a.prompt(` ${c.muted("API Key (leave empty if none):")} `)).trim(),k=(await a.prompt(` ${c.muted("Default model ID (e.g. gpt-4o):")} `)).trim()||"default",F={name:v,apiUrl:w,apiKey:T,models:[k],defaultModel:k,addedAt:new Date().toISOString()};nt(F),console.log(),console.log(J(`Provider "${v}" saved!`)),console.log(c.muted(` Use: /usemodel ${v}`)),console.log();break}case"/listmodels":{let y=Wt();console.log(),console.log(Ec(y.providers,y.activeProvider));break}case"/removemodel":{let y=_.trim();if(!y){console.log(B("Usage: /removemodel <provider-name>"));break}if(Ac(y))console.log(J(`Provider "${y}" removed`));else{console.log(B(`Provider "${y}" not found`));let b=Es();b.length>0&&console.log(c.muted(` Available: ${b.map(w=>w.name).join(", ")}`))}break}case"/usemodel":{let y=_.trim();if(!y){console.log(B("Usage: /usemodel <provider-name> [model-id]"));let F=Es();F.length>0&&console.log(c.muted(` Available: ${F.map(H=>H.name).join(", ")}`));break}let v=y.split(/\s+/),b=v[0],w=v[1],S=kc(b);if(!S){console.log(B(`Provider "${b}" not found`));let F=Es();F.length>0&&console.log(c.muted(` Available: ${F.map(H=>H.name).join(", ")}`));break}e.provider="custom",e.apiUrl=S.apiUrl,e.apiKey=S.apiKey,e.model=w||S.defaultModel;let T=Fe(e);h&&h(T),$c(S.name,e.model),console.log(J(`Switched to ${S.name} \xB7 Model: ${e.model}`));let M=new ze("Testing");M.start();let k=await T.checkConnection();M.stop(k?"connected":void 0),k||console.log(B("Connection test failed \u2014 check URL and key"));break}case"/provider":{let y=A[1],v=A.slice(2).join(" ");if(!y){let b=$s(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(J("Switched to Ollama (local)"));break}case"nvidia":{let b=A[2];if(!b&&!e.apiKey){console.log(B("Usage: /provider nvidia <api-key>")),console.log(c.muted(" Get your key at: https://build.nvidia.com/"));break}e.provider="nvidia",e.apiUrl=Dt.apiUrl,b&&(e.apiKey=b),(!e.model||!Dt.models.includes(e.model))&&(e.model=Dt.defaultModel);let w=Fe(e);h&&h(w),console.log(J(`Switched to NVIDIA NIM \xB7 Model: ${e.model}`)),console.log(c.muted(` Available models: ${Dt.models.length}`));let S=new ze("Testing NVIDIA connection");S.start();let T=await w.checkConnection();S.stop(T?"connected":void 0),T||(console.log(B("Connection test failed \u2014 check your API key")),console.log(c.muted(" Get key: https://build.nvidia.com/")));break}case"custom":{let b=A[2],w=A[3];if(!b){console.log(B("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,w&&(e.apiKey=w);let S=Fe(e);h&&h(S),console.log(J(`Switched to Custom API: ${b}`)),!w&&!e.apiKey&&console.log(B("No API key set. Use: /provider custom <url> <key>"));break}case"test":{let b=new ze("Testing connection");b.start();let w=await t.checkConnection();if(b.stop(w?"connected":void 0),w){let S=await t.listModels();console.log(J(`Connected! ${S.length} models available.`)),S.length>0&&console.log(c.muted(` Models: ${S.slice(0,5).join(", ")}${S.length>5?"...":""}`))}else console.log($e("Connection failed"));break}case"key":{v?(e.apiKey=A[2],t instanceof Gt&&t.setApiKey(e.apiKey),console.log(J("API key updated"))):console.log(B("Usage: /provider key <api-key>"));break}default:console.log(He(`Unknown: /provider ${y}`,"Type /provider for help"))}break}case"/memory":{if(!f){console.log(B("Project memory not available"));break}let y=A[1],v=A.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],w=v.slice(1).join(" ");f.set(b,w),console.log(J(`Memory stored: ${b}`));let S=u?.getActive(),T=S?S.systemPrompt:Gn,M=await gn(o,e);i.updateSystemPrompt(yn(T,M,f,m))}else console.log(B("Usage: /memory set <key> <value>"));break}case"del":case"delete":{if(v[0]){let b=f.delete(v[0]);console.log(b?J(`Memory deleted: ${v[0]}`):B(`Memory key not found: ${v[0]}`))}else console.log(B("Usage: /memory del <key>"));break}case"search":{if(v[0]){let b=f.search(v.join(" "));b.length>0?(console.log(),b.forEach(w=>console.log(` \xB7 ${w.entry.key}: ${w.entry.value}`)),console.log()):console.log(he("No matching memories found"))}else console.log(B("Usage: /memory search <query>"));break}case"clear":f.clear(),console.log(J("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=A[1],v=A.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],w=v.slice(1).join(" ");Rc(b,w),console.log(J(`Alias set: ${b} \u2192 ${w}`))}else console.log(B("Usage: /alias set <name> <expansion>"));break}case"del":case"remove":{if(v[0]){let b=Oc(v[0]);console.log(b?J(`Alias removed: ${v[0]}`):B(`Alias not found: ${v[0]}`))}else console.log(B("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 ze("Running diagnostics");y.start();let v=await ki({ollamaHost:e.ollamaHost,model:t.getModel(),provider:e.provider,apiUrl:e.apiUrl});y.stop(),console.log($i(v));break}case"/plugins":{let y=A[1],v=A.slice(2).join(" ");switch(y){case"enable":v?(wi(v),console.log(J(`Plugin "${v}" enabled`))):console.log(B("Usage: /plugins enable <name>"));break;case"disable":v?(xi(v),console.log(B(`Plugin "${v}" disabled`))):console.log(B("Usage: /plugins disable <name>"));break;default:Is(),console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Plugins")}`),console.log(),console.log(Si()),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=A[1];if(y==="on")e.agents.enabled=!0,console.log(J("Multi-agent orchestration enabled"));else if(y==="off")e.agents.enabled=!1,console.log(J("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(Ri()),console.log();else if(y==="models"){let v=Nn();console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Agent Models")}`),console.log();for(let b of we){let w=v[b.role];console.log(w?` ${c.primary(b.name.padEnd(8))} \u2192 ${c.highlight(w.model)}${w.temperature!==void 0?c.muted(` (temp: ${w.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=Ui(o);console.log(qi(y));break}case"/git":{if(A[1]==="status")try{let{getGitStatus:v,formatGitStatus:b}=await Promise.resolve().then(()=>(pn(),Hn)),w=await v(o);w?(console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Git Status")}`),console.log(b(w)),console.log()):console.log(B("Not a git repository"))}catch{console.log(B("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=Ds(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Workspace Information")}`),console.log(),console.log(Wi(y)),console.log();break}case"/stats":{let{loadStats:y,formatStats:v}=await Promise.resolve().then(()=>(jn(),Bi)),b=y();console.log(v(b));break}case"/context":{if(!m){console.log(B("Shared context not available"));break}let y=A[1],v=A.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],w=v.slice(1).join(" ");m.set(b,w),console.log(J(`Context stored: ${b}`))}else console.log(B("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(B(`Context key not found: ${v[0]}`))}else console.log(B("Usage: /context get <key>"));break}case"del":case"delete":{if(v[0]){let b=m.delete(v[0]);console.log(b?J(`Context deleted: ${v[0]}`):B(`Context key not found: ${v[0]}`))}else console.log(B("Usage: /context del <key>"));break}case"decisions":{let b=m.getDecisions();if(b.length===0)console.log(he("No decisions logged yet"));else{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Decisions")}`),console.log();for(let w of b)console.log(` ${c.muted(w.timestamp)} ${c.primary(w.by)}: ${w.decision}`),w.rationale&&console.log(` ${c.muted(w.rationale)}`);console.log()}break}case"clear":m.clear(),console.log(J("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(B("Plan manager not available"));break}let y=A[1],v=A.slice(2).join(" ");switch(y){case"status":{let w=p.getActivePlan();if(!w){console.log(he("No active plan"));break}let S=p.getProgress();console.log(xu(w,{percent:S.percentage,done:S.done,total:S.total}));break}case"finish":{if(v){p.finishTask(v),console.log(J(`Task finished: ${v}`));let w=p.getProgress();console.log(c.muted(` Progress: ${w.done}/${w.total} (${w.percentage}%)`))}else console.log(B("Usage: /plan finish <task_id>"));break}case"reset":{p.reset(),console.log(J("Plan manager reset"));break}case"next":{let w=p.getNextTask();console.log(w?he(`Next task: [${w.task_id}] ${w.description} \u2192 @${w.assignee}`):he("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 w=p.getProgress();console.log(` Active plan: ${b.title} (${w.percentage}% done)`),console.log(` Tasks: ${w.done}/${w.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(B('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 gn(o,e),b=u?.getActive(),w=b?b.systemPrompt:Gn,S=yn(w,v,f,m);i.updateSystemPrompt(S)}console.log(J(`Learned: "${_}"`)),console.log(c.muted(" This will be remembered across sessions and injected into every prompt."));break}case"/test":{let y=to(o);if(y==="unknown"&&!_){console.log(B("No test framework detected. Install jest, vitest, pytest, etc."));break}console.log(he(`Running tests (${y})...`));let v=Au(o,_==="--fix"?void 0:_||void 0);if(console.log(),console.log(ku(v)),console.log(),!v.passed&&_==="--fix"){console.log(he("Tests failed \u2014 adding fix request to conversation..."));let b=$u(v);i.addUserMessage(b),console.log(he("Type your next message or let the agent work on the fix."))}break}case"/checkpoint":{let y=A[1],v=A.slice(2).join(" ");if(y==="save"){let b=v||`Checkpoint at turn ${l}`,w=g?.getModifiedFiles?.()||[],S=await Tu(o,b,w);console.log(J(`Checkpoint saved: ${S.id} "${b}" (${S.fileCount} files)`))}else if(y==="list"){let b=Ru(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Checkpoints")}`),console.log(),console.log(Iu(b)),console.log()}else if(y==="restore"){if(!v){console.log(B("Usage: /checkpoint restore <id>"));break}let b=await Ou(o,v);b.success?console.log(J(`Restored checkpoint: ${v} (${b.filesRestored} files)`)):console.log($e(b.error||"Restore failed"))}else y==="delete"?v&&Pu(o,v)?console.log(J(`Deleted checkpoint: ${v}`)):console.log(B("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=A.slice(1);if(y.length===2)try{let v=await Nt.readFile(ke.resolve(o,y[0]),"utf-8"),b=await Nt.readFile(ke.resolve(o,y[1]),"utf-8"),{generateDiff:w}=await Promise.resolve().then(()=>(ao(),Uu)),S=w(y[0]+" vs "+y[1],v,b);console.log(Qi(S))}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(Qi(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=Fn(),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[w,S]of b.sort((T,M)=>M[1]-T[1]))console.log(` @${w}: ${S} invocations`)}console.log();break}case"/delegate":{if(!e.agents.enabled){console.log(B("Multi-agent system is disabled. Enable with /agents on"));break}let y=A[1]?.toLowerCase(),v=A.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(B(`Unknown agent: "${y}". Valid: ${b.join(", ")}`));break}let w=we.find(S=>S.role===y);if(w){if(!x){console.log(B("Agent runner not initialized. Cannot delegate."));break}console.log(fu("Hablas",w.name,w.title,v)),console.log(Un(w.name,w.title));let S=s.getOllamaTools(),T=await x.runAgent(y,v,void 0,S);T.success&&T.output?(console.log(qn(T.output)),i.addAssistantMessage(`[@${w.name}]: ${T.output}`)):T.error?console.log(B(`${w.name} failed: ${T.error}`)):console.log(he(`${w.name} completed without output.`))}break}case"/session":{let y=A[1],v=A.slice(2).join(" "),b=ke.join(co.homedir(),".hablas","sessions");if(y==="save"){let w=v||`session_${Date.now()}`;try{me.existsSync(b)||me.mkdirSync(b,{recursive:!0});let S=i.toJSON(),T=ke.join(b,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);me.writeFileSync(T,S,"utf-8"),console.log(J(`Session saved: "${w}"`))}catch(S){console.log($e(`Save failed: ${S.message}`))}}else if(y==="list")try{if(!me.existsSync(b)){console.log(he("No saved sessions"));break}let w=me.readdirSync(b).filter(S=>S.endsWith(".json"));console.log();for(let S of w){let T=me.statSync(ke.join(b,S));console.log(` ${S.replace(".json","")} (${new Date(T.mtime).toLocaleString()})`)}console.log()}catch{console.log(he("No saved sessions"))}else if(y==="load"){let w=v;if(!w){console.log($e("Please specify the session label to load: /session load <label>"));break}try{let S=ke.join(b,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);if(!me.existsSync(S)){console.log($e(`Session file not found: ${w}`));break}let T=me.readFileSync(S,"utf-8");i.fromJSON(T),console.log(J(`Session successfully loaded: "${w}"`))}catch(S){console.log($e(`Load failed: ${S.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(()=>(Ct(),Ft));if(!y){console.log(B("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(`
283
+ `),console.log(c.muted(" ~/.hablas/config.json")),console.log();break;case"/mindset":{if(!u){console.log(B("Mindset system not available"));break}if(_)if(u.setActive(_)){let v=u.getActive(),b=await yn(o,e),w=bn(v.systemPrompt,b,f,m);i.updateSystemPrompt(w),console.log(J(`Mindset: ${v.name} \u2014 ${v.description}`))}else{let v=u.listNames().join(", ");console.log(He(`Unknown mindset: "${_}"`,`Available: ${v}`))}else{let y=u.getActive();y&&console.log(he(`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(B("Mindset system not available"));break}let y=u.list(),v=u.getActiveName();console.log();for(let b of y){let S=b.name===v?c.success(" \u25CF active"):"";console.log(` ${c.accent("\u25C6")} ${c.primary(b.name)}${S}`),console.log(` ${c.muted(b.description)}`)}console.log(),console.log(c.muted(" Switch: /mindset <name>")),console.log();break}case"/task":{if(!d){console.log(B("Task queue not available"));break}let y=A[1],v=A.slice(2).join(" ");switch(y){case"add":if(v){let b=d.add(v);console.log(J(`Task #${b.id} added: ${v}`))}else console.log(B("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(J(`Task #${b} marked as done`))):console.log(B("Usage: /task done <id>"));break}case"fail":{let b=parseInt(v);b?(d.fail(b,"Manually marked as failed"),console.log(B(`Task #${b} marked as failed`))):console.log(B("Usage: /task fail <id>"));break}case"clear":d.clear(),console.log(J("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(B("Cancelled \u2014 name is required"));break}let w=(await a.prompt(` ${c.muted("API URL (e.g. https://api.openai.com/v1):")} `)).trim();if(!w){console.log(B("Cancelled \u2014 URL is required"));break}let T=(await a.prompt(` ${c.muted("API Key (leave empty if none):")} `)).trim(),k=(await a.prompt(` ${c.muted("Default model ID (e.g. gpt-4o):")} `)).trim()||"default",F={name:v,apiUrl:w,apiKey:T,models:[k],defaultModel:k,addedAt:new Date().toISOString()};nt(F),console.log(),console.log(J(`Provider "${v}" saved!`)),console.log(c.muted(` Use: /usemodel ${v}`)),console.log();break}case"/listmodels":{let y=Wt();console.log(),console.log(Cc(y.providers,y.activeProvider));break}case"/removemodel":{let y=_.trim();if(!y){console.log(B("Usage: /removemodel <provider-name>"));break}if(kc(y))console.log(J(`Provider "${y}" removed`));else{console.log(B(`Provider "${y}" not found`));let b=Cs();b.length>0&&console.log(c.muted(` Available: ${b.map(w=>w.name).join(", ")}`))}break}case"/usemodel":{let y=_.trim();if(!y){console.log(B("Usage: /usemodel <provider-name> [model-id]"));let F=Cs();F.length>0&&console.log(c.muted(` Available: ${F.map(H=>H.name).join(", ")}`));break}let v=y.split(/\s+/),b=v[0],w=v[1],S=$c(b);if(!S){console.log(B(`Provider "${b}" not found`));let F=Cs();F.length>0&&console.log(c.muted(` Available: ${F.map(H=>H.name).join(", ")}`));break}e.provider="custom",e.apiUrl=S.apiUrl,e.apiKey=S.apiKey,e.model=w||S.defaultModel;let T=Fe(e);h&&h(T),Ec(S.name,e.model),console.log(J(`Switched to ${S.name} \xB7 Model: ${e.model}`));let M=new ze("Testing");M.start();let k=await T.checkConnection();M.stop(k?"connected":void 0),k||console.log(B("Connection test failed \u2014 check URL and key"));break}case"/provider":{let y=A[1],v=A.slice(2).join(" ");if(!y){let b=Es(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(J("Switched to Ollama (local)"));break}case"nvidia":{let b=A[2];if(!b&&!e.apiKey){console.log(B("Usage: /provider nvidia <api-key>")),console.log(c.muted(" Get your key at: https://build.nvidia.com/"));break}e.provider="nvidia",e.apiUrl=Dt.apiUrl,b&&(e.apiKey=b),(!e.model||!Dt.models.includes(e.model))&&(e.model=Dt.defaultModel);let w=Fe(e);h&&h(w),console.log(J(`Switched to NVIDIA NIM \xB7 Model: ${e.model}`)),console.log(c.muted(` Available models: ${Dt.models.length}`));let S=new ze("Testing NVIDIA connection");S.start();let T=await w.checkConnection();S.stop(T?"connected":void 0),T||(console.log(B("Connection test failed \u2014 check your API key")),console.log(c.muted(" Get key: https://build.nvidia.com/")));break}case"custom":{let b=A[2],w=A[3];if(!b){console.log(B("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,w&&(e.apiKey=w);let S=Fe(e);h&&h(S),console.log(J(`Switched to Custom API: ${b}`)),!w&&!e.apiKey&&console.log(B("No API key set. Use: /provider custom <url> <key>"));break}case"test":{let b=new ze("Testing connection");b.start();let w=await t.checkConnection();if(b.stop(w?"connected":void 0),w){let S=await t.listModels();console.log(J(`Connected! ${S.length} models available.`)),S.length>0&&console.log(c.muted(` Models: ${S.slice(0,5).join(", ")}${S.length>5?"...":""}`))}else console.log($e("Connection failed"));break}case"key":{v?(e.apiKey=A[2],t instanceof Gt&&t.setApiKey(e.apiKey),console.log(J("API key updated"))):console.log(B("Usage: /provider key <api-key>"));break}default:console.log(He(`Unknown: /provider ${y}`,"Type /provider for help"))}break}case"/memory":{if(!f){console.log(B("Project memory not available"));break}let y=A[1],v=A.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],w=v.slice(1).join(" ");f.set(b,w),console.log(J(`Memory stored: ${b}`));let S=u?.getActive(),T=S?S.systemPrompt:Wn,M=await yn(o,e);i.updateSystemPrompt(bn(T,M,f,m))}else console.log(B("Usage: /memory set <key> <value>"));break}case"del":case"delete":{if(v[0]){let b=f.delete(v[0]);console.log(b?J(`Memory deleted: ${v[0]}`):B(`Memory key not found: ${v[0]}`))}else console.log(B("Usage: /memory del <key>"));break}case"search":{if(v[0]){let b=f.search(v.join(" "));b.length>0?(console.log(),b.forEach(w=>console.log(` \xB7 ${w.entry.key}: ${w.entry.value}`)),console.log()):console.log(he("No matching memories found"))}else console.log(B("Usage: /memory search <query>"));break}case"clear":f.clear(),console.log(J("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=A[1],v=A.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],w=v.slice(1).join(" ");Oc(b,w),console.log(J(`Alias set: ${b} \u2192 ${w}`))}else console.log(B("Usage: /alias set <name> <expansion>"));break}case"del":case"remove":{if(v[0]){let b=Pc(v[0]);console.log(b?J(`Alias removed: ${v[0]}`):B(`Alias not found: ${v[0]}`))}else console.log(B("Usage: /alias del <name>"));break}default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Aliases")}`),console.log(),console.log(Mc()),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 ze("Running diagnostics");y.start();let v=await Ci({ollamaHost:e.ollamaHost,model:t.getModel(),provider:e.provider,apiUrl:e.apiUrl});y.stop(),console.log(Ti(v));break}case"/plugins":{let y=A[1],v=A.slice(2).join(" ");switch(y){case"enable":v?(_i(v),console.log(J(`Plugin "${v}" enabled`))):console.log(B("Usage: /plugins enable <name>"));break;case"disable":v?(Ai(v),console.log(B(`Plugin "${v}" disabled`))):console.log(B("Usage: /plugins disable <name>"));break;default:Ms(),console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Plugins")}`),console.log(),console.log(ki()),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=A[1];if(y==="on")e.agents.enabled=!0,console.log(J("Multi-agent orchestration enabled"));else if(y==="off")e.agents.enabled=!1,console.log(J("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(qc()),console.log();else if(y==="models"){let v=Fn();console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Agent Models")}`),console.log();for(let b of we){let w=v[b.role];console.log(w?` ${c.primary(b.name.padEnd(8))} \u2192 ${c.highlight(w.model)}${w.temperature!==void 0?c.muted(` (temp: ${w.temperature})`):""}`:` ${c.primary(b.name.padEnd(8))} \u2192 ${c.muted("(default)")}`)}console.log(),console.log(c.muted(` Config: ${Wc()}`)),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=qi(o);console.log(Ki(y));break}case"/git":{if(A[1]==="status")try{let{getGitStatus:v,formatGitStatus:b}=await Promise.resolve().then(()=>(hn(),Bn)),w=await v(o);w?(console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Git Status")}`),console.log(b(w)),console.log()):console.log(B("Not a git repository"))}catch{console.log(B("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=Ns(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Workspace Information")}`),console.log(),console.log(Vi(y)),console.log();break}case"/stats":{let{loadStats:y,formatStats:v}=await Promise.resolve().then(()=>(Hn(),Ui)),b=y();console.log(v(b));break}case"/context":{if(!m){console.log(B("Shared context not available"));break}let y=A[1],v=A.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],w=v.slice(1).join(" ");m.set(b,w),console.log(J(`Context stored: ${b}`))}else console.log(B("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(B(`Context key not found: ${v[0]}`))}else console.log(B("Usage: /context get <key>"));break}case"del":case"delete":{if(v[0]){let b=m.delete(v[0]);console.log(b?J(`Context deleted: ${v[0]}`):B(`Context key not found: ${v[0]}`))}else console.log(B("Usage: /context del <key>"));break}case"decisions":{let b=m.getDecisions();if(b.length===0)console.log(he("No decisions logged yet"));else{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Decisions")}`),console.log();for(let w of b)console.log(` ${c.muted(w.timestamp)} ${c.primary(w.by)}: ${w.decision}`),w.rationale&&console.log(` ${c.muted(w.rationale)}`);console.log()}break}case"clear":m.clear(),console.log(J("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(B("Plan manager not available"));break}let y=A[1],v=A.slice(2).join(" ");switch(y){case"status":{let w=p.getActivePlan();if(!w){console.log(he("No active plan"));break}let S=p.getProgress();console.log(xu(w,{percent:S.percentage,done:S.done,total:S.total}));break}case"finish":{if(v){p.finishTask(v),console.log(J(`Task finished: ${v}`));let w=p.getProgress();console.log(c.muted(` Progress: ${w.done}/${w.total} (${w.percentage}%)`))}else console.log(B("Usage: /plan finish <task_id>"));break}case"reset":{p.reset(),console.log(J("Plan manager reset"));break}case"next":{let w=p.getNextTask();console.log(w?he(`Next task: [${w.task_id}] ${w.description} \u2192 @${w.assignee}`):he("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 w=p.getProgress();console.log(` Active plan: ${b.title} (${w.percentage}% done)`),console.log(` Tasks: ${w.done}/${w.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(B('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 yn(o,e),b=u?.getActive(),w=b?b.systemPrompt:Wn,S=bn(w,v,f,m);i.updateSystemPrompt(S)}console.log(J(`Learned: "${_}"`)),console.log(c.muted(" This will be remembered across sessions and injected into every prompt."));break}case"/test":{let y=no(o);if(y==="unknown"&&!_){console.log(B("No test framework detected. Install jest, vitest, pytest, etc."));break}console.log(he(`Running tests (${y})...`));let v=Au(o,_==="--fix"?void 0:_||void 0);if(console.log(),console.log(ku(v)),console.log(),!v.passed&&_==="--fix"){console.log(he("Tests failed \u2014 adding fix request to conversation..."));let b=$u(v);i.addUserMessage(b),console.log(he("Type your next message or let the agent work on the fix."))}break}case"/checkpoint":{let y=A[1],v=A.slice(2).join(" ");if(y==="save"){let b=v||`Checkpoint at turn ${l}`,w=g?.getModifiedFiles?.()||[],S=await Tu(o,b,w);console.log(J(`Checkpoint saved: ${S.id} "${b}" (${S.fileCount} files)`))}else if(y==="list"){let b=Ru(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Checkpoints")}`),console.log(),console.log(Iu(b)),console.log()}else if(y==="restore"){if(!v){console.log(B("Usage: /checkpoint restore <id>"));break}let b=await Ou(o,v);b.success?console.log(J(`Restored checkpoint: ${v} (${b.filesRestored} files)`)):console.log($e(b.error||"Restore failed"))}else y==="delete"?v&&Pu(o,v)?console.log(J(`Deleted checkpoint: ${v}`)):console.log(B("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=A.slice(1);if(y.length===2)try{let v=await Nt.readFile(ke.resolve(o,y[0]),"utf-8"),b=await Nt.readFile(ke.resolve(o,y[1]),"utf-8"),{generateDiff:w}=await Promise.resolve().then(()=>(lo(),Uu)),S=w(y[0]+" vs "+y[1],v,b);console.log(Xi(S))}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(Xi(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=jn(),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[w,S]of b.sort((T,M)=>M[1]-T[1]))console.log(` @${w}: ${S} invocations`)}console.log();break}case"/delegate":{if(!e.agents.enabled){console.log(B("Multi-agent system is disabled. Enable with /agents on"));break}let y=A[1]?.toLowerCase(),v=A.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(B(`Unknown agent: "${y}". Valid: ${b.join(", ")}`));break}let w=we.find(S=>S.role===y);if(w){if(!x){console.log(B("Agent runner not initialized. Cannot delegate."));break}console.log(fu("Hablas",w.name,w.title,v)),console.log(qn(w.name,w.title));let S=s.getOllamaTools(),T=await x.runAgent(y,v,void 0,S);T.success&&T.output?(console.log(Kn(T.output)),i.addAssistantMessage(`[@${w.name}]: ${T.output}`)):T.error?console.log(B(`${w.name} failed: ${T.error}`)):console.log(he(`${w.name} completed without output.`))}break}case"/session":{let y=A[1],v=A.slice(2).join(" "),b=ke.join(uo.homedir(),".hablas","sessions");if(y==="save"){let w=v||`session_${Date.now()}`;try{me.existsSync(b)||me.mkdirSync(b,{recursive:!0});let S=i.toJSON(),T=ke.join(b,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);me.writeFileSync(T,S,"utf-8"),console.log(J(`Session saved: "${w}"`))}catch(S){console.log($e(`Save failed: ${S.message}`))}}else if(y==="list")try{if(!me.existsSync(b)){console.log(he("No saved sessions"));break}let w=me.readdirSync(b).filter(S=>S.endsWith(".json"));console.log();for(let S of w){let T=me.statSync(ke.join(b,S));console.log(` ${S.replace(".json","")} (${new Date(T.mtime).toLocaleString()})`)}console.log()}catch{console.log(he("No saved sessions"))}else if(y==="load"){let w=v;if(!w){console.log($e("Please specify the session label to load: /session load <label>"));break}try{let S=ke.join(b,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);if(!me.existsSync(S)){console.log($e(`Session file not found: ${w}`));break}let T=me.readFileSync(S,"utf-8");i.fromJSON(T),console.log(J(`Session successfully loaded: "${w}"`))}catch(S){console.log($e(`Load failed: ${S.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(()=>(Ct(),Ft));if(!y){console.log(B("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(`
284
284
  `+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 S=(v.sessions||[]).filter(T=>T.developer_name!==v.my_username);if(S.length===0)console.log(c.border("\u2551")+" (awaiting colleagues...)"+" ".repeat(Math.max(1,b-31))+c.border("\u2551"));else for(let T of S){let M=` @${T.developer_name} [${T.active_section||"idle"}] - ${T.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")+`
285
285
  `),console.log(c.muted(` Verify that "Room Fingerprint" matches on all devices to ensure connectivity.
286
- `));break}case"/msg":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(Ct(),Ft));if(!y){console.log(B("Team mode is not active. Use hablas --team to start."));break}let v=_.split(/\s+/),b=v[0],w=v.slice(1).join(" ");if(!b||!w){console.log(B("Usage: /msg <username> <content>"));break}let S=await y.sendMessage(b,w);console.log(S?J(`Message sent to @${b}`):$e(`Failed to send message to @${b}`));break}default:console.log(He(`Unknown: ${$}`,"Type /help for commands"))}}var me,Nt,ke,co,Gn,lo,Ku=N(()=>{"use strict";me=O(require("fs")),Nt=O(require("fs/promises")),ke=O(require("path")),co=O(require("os"));Ln();Dn();di();gi();yi();_i();Ei();cn();Ii();jn();Ki();pn();Vi();su();mn();Eu();Mu();Gn=`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.
286
+ `));break}case"/msg":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(Ct(),Ft));if(!y){console.log(B("Team mode is not active. Use hablas --team to start."));break}let v=_.split(/\s+/),b=v[0],w=v.slice(1).join(" ");if(!b||!w){console.log(B("Usage: /msg <username> <content>"));break}let S=await y.sendMessage(b,w);console.log(S?J(`Message sent to @${b}`):$e(`Failed to send message to @${b}`));break}default:console.log(He(`Unknown: ${$}`,"Type /help for commands"))}}var me,Nt,ke,uo,Wn,co,Ku=N(()=>{"use strict";me=O(require("fs")),Nt=O(require("fs/promises")),ke=O(require("path")),uo=O(require("os"));Dn();Nn();hi();vi();wi();$i();Ri();un();Mi();Hn();Gi();hn();zi();iu();gn();Eu();Mu();Wn=`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.
287
287
 
288
288
  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.
289
289
 
@@ -321,9 +321,9 @@ Your role is to orchestrate, coordinate, and synthesize the work of your special
321
321
  ## Important
322
322
  Never output tool calls as text or JSON in your response.
323
323
  Always use the tool_calls field provided by the API.
324
- If you cannot complete a task, explain why with absolute technical objectivity.`;lo=ke.join(co.homedir(),".hablas","backup")});var Wn=j((dC,Yu)=>{"use strict";var Sb=require("path"),ht="\\\\/",Gu=`[^${ht}]`,_b=0,Tt="\\.",Ab="\\+",kb="\\?",Bs="\\/",$b="(?=.)",Wu="[^/]",uo=`(?:${Bs}|$)`,Vu=`(?:^|${Bs})`,fo=`${Tt}{1,2}${uo}`,Eb=`(?!${Tt})`,Cb=`(?!${Vu}${fo})`,Tb=`(?!${Tt}{0,1}${uo})`,Rb=`(?!${fo})`,Ob=`[^.${Bs}]`,Pb=`${Wu}*?`,zu={DOT_LITERAL:Tt,PLUS_LITERAL:Ab,QMARK_LITERAL:kb,SLASH_LITERAL:Bs,ONE_CHAR:$b,QMARK:Wu,END_ANCHOR:uo,DOTS_SLASH:fo,NO_DOT:Eb,NO_DOTS:Cb,NO_DOT_SLASH:Tb,NO_DOTS_SLASH:Rb,QMARK_NO_DOT:Ob,STAR:Pb,START_ANCHOR:Vu},Ib={...zu,SLASH_LITERAL:`[${ht}]`,QMARK:Gu,STAR:`${Gu}*?`,DOTS_SLASH:`${Tt}{1,2}(?:[${ht}]|$)`,NO_DOT:`(?!${Tt})`,NO_DOTS:`(?!(?:^|[${ht}])${Tt}{1,2}(?:[${ht}]|$))`,NO_DOT_SLASH:`(?!${Tt}{0,1}(?:[${ht}]|$))`,NO_DOTS_SLASH:`(?!${Tt}{1,2}(?:[${ht}]|$))`,QMARK_NO_DOT:`[^.${ht}]`,START_ANCHOR:`(?:^|[${ht}])`,END_ANCHOR:`(?:[${ht}]|$)`},Mb={__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"};Yu.exports={DEFAULT_MAX_EXTGLOB_RECURSION:_b,MAX_LENGTH:1024*64,POSIX_REGEX_SOURCE:Mb,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:Sb.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?Ib:zu}}});var Us=j(Me=>{"use strict";var Lb=require("path"),Db=process.platform==="win32",{REGEX_BACKSLASH:Nb,REGEX_REMOVE_BACKSLASH:Fb,REGEX_SPECIAL_CHARS:jb,REGEX_SPECIAL_CHARS_GLOBAL:Hb}=Wn();Me.isObject=n=>n!==null&&typeof n=="object"&&!Array.isArray(n);Me.hasRegexChars=n=>jb.test(n);Me.isRegexChar=n=>n.length===1&&Me.hasRegexChars(n);Me.escapeRegex=n=>n.replace(Hb,"\\$1");Me.toPosixSlashes=n=>n.replace(Nb,"/");Me.removeBackslashes=n=>n.replace(Fb,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:Db===!0||Lb.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 sd=j((pC,nd)=>{"use strict";var Ju=Us(),{CHAR_ASTERISK:po,CHAR_AT:Bb,CHAR_BACKWARD_SLASH:Vn,CHAR_COMMA:Ub,CHAR_DOT:ho,CHAR_EXCLAMATION_MARK:mo,CHAR_FORWARD_SLASH:td,CHAR_LEFT_CURLY_BRACE:go,CHAR_LEFT_PARENTHESES:yo,CHAR_LEFT_SQUARE_BRACKET:qb,CHAR_PLUS:Kb,CHAR_QUESTION_MARK:Qu,CHAR_RIGHT_CURLY_BRACE:Gb,CHAR_RIGHT_PARENTHESES:Xu,CHAR_RIGHT_SQUARE_BRACKET:Wb}=Wn(),Zu=n=>n===td||n===Vn,ed=n=>{n.isPrefix!==!0&&(n.depth=n.isGlobstar?1/0:1)},Vb=(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,x=!1,A=!1,$=!1,_=!1,y=!1,v=!1,b=0,w,S,T={value:"",depth:0,isGlob:!1},M=()=>u>=s,k=()=>l.charCodeAt(u+1),F=()=>(w=S,l.charCodeAt(++u));for(;u<s;){S=F();let Y;if(S===Vn){$=T.backslashes=!0,S=F(),S===go&&(A=!0);continue}if(A===!0||S===go){for(b++;M()!==!0&&(S=F());){if(S===Vn){$=T.backslashes=!0,F();continue}if(S===go){b++;continue}if(A!==!0&&S===ho&&(S=F())===ho){if(h=T.isBrace=!0,p=T.isGlob=!0,v=!0,r===!0)continue;break}if(A!==!0&&S===Ub){if(h=T.isBrace=!0,p=T.isGlob=!0,v=!0,r===!0)continue;break}if(S===Gb&&(b--,b===0)){A=!1,h=T.isBrace=!0,v=!0;break}}if(r===!0)continue;break}if(S===td){if(i.push(u),o.push(T),T={value:"",depth:0,isGlob:!1},v===!0)continue;if(w===ho&&u===d+1){d+=2;continue}f=u+1;continue}if(t.noext!==!0&&(S===Kb||S===Bb||S===po||S===Qu||S===mo)===!0&&k()===yo){if(p=T.isGlob=!0,g=T.isExtglob=!0,v=!0,S===mo&&u===d&&(y=!0),r===!0){for(;M()!==!0&&(S=F());){if(S===Vn){$=T.backslashes=!0,S=F();continue}if(S===Xu){p=T.isGlob=!0,v=!0;break}}continue}break}if(S===po){if(w===po&&(x=T.isGlobstar=!0),p=T.isGlob=!0,v=!0,r===!0)continue;break}if(S===Qu){if(p=T.isGlob=!0,v=!0,r===!0)continue;break}if(S===qb){for(;M()!==!0&&(Y=F());){if(Y===Vn){$=T.backslashes=!0,F();continue}if(Y===Wb){m=T.isBracket=!0,p=T.isGlob=!0,v=!0;break}}if(r===!0)continue;break}if(t.nonegate!==!0&&S===mo&&u===d){_=T.negated=!0,d++;continue}if(t.noparen!==!0&&S===yo){if(p=T.isGlob=!0,r===!0){for(;M()!==!0&&(S=F());){if(S===yo){$=T.backslashes=!0,S=F();continue}if(S===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,V="",C="";d>0&&(V=l.slice(0,d),l=l.slice(d),f-=d),H&&p===!0&&f>0?(H=l.slice(0,f),C=l.slice(f)):p===!0?(H="",C=l):H=l,H&&H!==""&&H!=="/"&&H!==l&&Zu(H.charCodeAt(H.length-1))&&(H=H.slice(0,-1)),t.unescape===!0&&(C&&(C=Ju.removeBackslashes(C)),H&&$===!0&&(H=Ju.removeBackslashes(H)));let E={prefix:V,input:n,start:d,base:H,glob:C,isBrace:h,isBracket:m,isGlob:p,isExtglob:g,isGlobstar:x,negated:_,negatedExtglob:y};if(t.tokens===!0&&(E.maxDepth=0,Zu(S)||o.push(T),E.tokens=o),t.parts===!0||t.tokens===!0){let Y;for(let D=0;D<i.length;D++){let X=Y?Y+1:d,ee=i[D],te=n.slice(X,ee);t.tokens&&(D===0&&d!==0?(o[D].isPrefix=!0,o[D].value=V):o[D].value=te,ed(o[D]),E.maxDepth+=o[D].depth),(D!==0||te!=="")&&a.push(te),Y=ee}if(Y&&Y+1<n.length){let D=n.slice(Y+1);a.push(D),t.tokens&&(o[o.length-1].value=D,ed(o[o.length-1]),E.maxDepth+=o[o.length-1].depth)}E.slashes=i,E.parts=a}return E};nd.exports=Vb});var ld=j((hC,ad)=>{"use strict";var zn=Wn(),Ce=Us(),{MAX_LENGTH:qs,POSIX_REGEX_SOURCE:zb,REGEX_NON_SPECIAL_CHARS:Yb,REGEX_SPECIAL_CHARS_BACKREF:Jb,REPLACEMENTS:rd}=zn,Qb=(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},bn=(n,e)=>`Missing ${n}: "${e}" - use "\\\\${e}" to match literal characters`,id=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},Xb=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},od=n=>{let e=n.trim(),t=!0;for(;t===!0;)t=!1,/^@\([^\\()[\]{}|]+\)$/.test(e)&&(e=e.slice(2,-1),t=!0);if(Xb(e))return e.replace(/\\(.)/g,"$1")},Zb=n=>{let e=n.map(od).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},bo=(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}}}}},ev=n=>{let e=0,t=[];for(;e<n.length;){let r=bo(n.slice(e),!1);if(!r||r.type!=="*")return;let i=id(r.body).map(a=>a.trim());if(i.length!==1)return;let o=od(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("")}]`}*`},tv=n=>{let e=0,t=n.trim(),s=bo(t);for(;s;)e++,t=s.body.trim(),s=bo(t);return e},nv=(n,e)=>{if(e.maxExtglobRecursion===!1)return{risky:!1};let t=typeof e.maxExtglobRecursion=="number"?e.maxExtglobRecursion:zn.DEFAULT_MAX_EXTGLOB_RECURSION,s=id(n).map(r=>r.trim());if(s.length>1&&(s.some(r=>r==="")||s.some(r=>/^[*?]+$/.test(r))||Zb(s)))return{risky:!0};for(let r of s){let i=ev(r);if(i)return{risky:!0,safeOutput:i};if(tv(r)>t)return{risky:!0}}return{risky:!1}},vo=(n,e)=>{if(typeof n!="string")throw new TypeError("Expected a string");n=rd[n]||n;let t={...e},s=typeof t.maxLength=="number"?Math.min(qs,t.maxLength):qs,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=zn.globChars(l),d=zn.extglobChars(u),{DOT_LITERAL:f,PLUS_LITERAL:h,SLASH_LITERAL:m,ONE_CHAR:p,DOTS_SLASH:g,NO_DOT:x,NO_DOT_SLASH:A,NO_DOTS_SLASH:$,QMARK:_,QMARK_NO_DOT:y,STAR:v,START_ANCHOR:b}=u,w=I=>`(${a}(?:(?!${b}${I.dot?g:f}).)*?)`,S=t.dot?"":x,T=t.dot?_:y,M=t.bash===!0?w(t):v;t.capture&&(M=`(${M})`),typeof t.noext=="boolean"&&(t.noextglob=t.noext);let k={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,k),r=n.length;let F=[],H=[],V=[],C=i,E,Y=()=>k.index===r-1,D=k.peek=(I=1)=>n[k.index+I],X=k.advance=()=>n[++k.index]||"",ee=()=>n.slice(k.index+1),te=(I="",Z=0)=>{k.consumed+=I,k.index+=Z},_e=I=>{k.output+=I.output!=null?I.output:I.value,te(I.value)},Q=()=>{let I=1;for(;D()==="!"&&(D(2)!=="("||D(3)==="?");)X(),k.start++,I++;return I%2===0?!1:(k.negated=!0,k.start++,!0)},Ae=I=>{k[I]++,V.push(I)},ve=I=>{k[I]--,V.pop()},q=I=>{if(C.type==="globstar"){let Z=k.braces>0&&(I.type==="comma"||I.type==="brace"),P=I.extglob===!0||F.length&&(I.type==="pipe"||I.type==="paren");I.type!=="slash"&&I.type!=="paren"&&!Z&&!P&&(k.output=k.output.slice(0,-C.output.length),C.type="star",C.value="*",C.output=M,k.output+=C.output)}if(F.length&&I.type!=="paren"&&(F[F.length-1].inner+=I.value),(I.value||I.output)&&_e(I),C&&C.type==="text"&&I.type==="text"){C.value+=I.value,C.output=(C.output||"")+I.value;return}I.prev=C,o.push(I),C=I},ue=(I,Z)=>{let P={...d[Z],conditions:1,inner:""};P.prev=C,P.parens=k.parens,P.output=k.output,P.startIndex=k.index,P.tokensIndex=o.length;let G=(t.capture?"(":"")+P.open;Ae("parens"),q({type:I,value:Z,output:k.output?"":p}),q({type:"paren",extglob:!0,value:X(),output:G}),F.push(P)},Ge=I=>{let Z=n.slice(I.startIndex,k.index+1),P=n.slice(I.startIndex+2,k.index),G=nv(P,t);if((I.type==="plus"||I.type==="star")&&G.risky){let ie=G.safeOutput?(I.output?"":p)+(t.capture?`(${G.safeOutput})`:G.safeOutput):void 0,Oe=o[I.tokensIndex];Oe.type="text",Oe.value=Z,Oe.output=ie||Ce.escapeRegex(Z);for(let We=I.tokensIndex+1;We<o.length;We++)o[We].value="",o[We].output="",delete o[We].suffix;k.output=I.output+Oe.output,k.backtrack=!0,q({type:"paren",extglob:!0,value:E,output:""}),ve("parens");return}let ne=I.close+(t.capture?")":""),pe;if(I.type==="negate"){let ie=M;if(I.inner&&I.inner.length>1&&I.inner.includes("/")&&(ie=w(t)),(ie!==M||Y()||/^\)+$/.test(ee()))&&(ne=I.close=`)$))${ie}`),I.inner.includes("*")&&(pe=ee())&&/^\.[^\\/.]+$/.test(pe)){let Oe=vo(pe,{...e,fastpaths:!1}).output;ne=I.close=`)${Oe})${ie})`}I.prev.type==="bos"&&(k.negatedExtglob=!0)}q({type:"paren",extglob:!0,value:E,output:ne}),ve("parens")};if(t.fastpaths!==!1&&!/(^[*!]|[/()[\]{}"])/.test(n)){let I=!1,Z=n.replace(Jb,(P,G,ne,pe,ie,Oe)=>pe==="\\"?(I=!0,P):pe==="?"?G?G+pe+(ie?_.repeat(ie.length):""):Oe===0?T+(ie?_.repeat(ie.length):""):_.repeat(ne.length):pe==="."?f.repeat(ne.length):pe==="*"?G?G+pe+(ie?M:""):M:G?P:`\\${P}`);return I===!0&&(t.unescape===!0?Z=Z.replace(/\\/g,""):Z=Z.replace(/\\+/g,P=>P.length%2===0?"\\\\":P?"\\":"")),Z===n&&t.contains===!0?(k.output=n,k):(k.output=Ce.wrapOutput(Z,k,e),k)}for(;!Y();){if(E=X(),E==="\0")continue;if(E==="\\"){let P=D();if(P==="/"&&t.bash!==!0||P==="."||P===";")continue;if(!P){E+="\\",q({type:"text",value:E});continue}let G=/^\\+/.exec(ee()),ne=0;if(G&&G[0].length>2&&(ne=G[0].length,k.index+=ne,ne%2!==0&&(E+="\\")),t.unescape===!0?E=X():E+=X(),k.brackets===0){q({type:"text",value:E});continue}}if(k.brackets>0&&(E!=="]"||C.value==="["||C.value==="[^")){if(t.posix!==!1&&E===":"){let P=C.value.slice(1);if(P.includes("[")&&(C.posix=!0,P.includes(":"))){let G=C.value.lastIndexOf("["),ne=C.value.slice(0,G),pe=C.value.slice(G+2),ie=zb[pe];if(ie){C.value=ne+ie,k.backtrack=!0,X(),!i.output&&o.indexOf(C)===1&&(i.output=p);continue}}}(E==="["&&D()!==":"||E==="-"&&D()==="]")&&(E=`\\${E}`),E==="]"&&(C.value==="["||C.value==="[^")&&(E=`\\${E}`),t.posix===!0&&E==="!"&&C.value==="["&&(E="^"),C.value+=E,_e({value:E});continue}if(k.quotes===1&&E!=='"'){E=Ce.escapeRegex(E),C.value+=E,_e({value:E});continue}if(E==='"'){k.quotes=k.quotes===1?0:1,t.keepQuotes===!0&&q({type:"text",value:E});continue}if(E==="("){Ae("parens"),q({type:"paren",value:E});continue}if(E===")"){if(k.parens===0&&t.strictBrackets===!0)throw new SyntaxError(bn("opening","("));let P=F[F.length-1];if(P&&k.parens===P.parens+1){Ge(F.pop());continue}q({type:"paren",value:E,output:k.parens?")":"\\)"}),ve("parens");continue}if(E==="["){if(t.nobracket===!0||!ee().includes("]")){if(t.nobracket!==!0&&t.strictBrackets===!0)throw new SyntaxError(bn("closing","]"));E=`\\${E}`}else Ae("brackets");q({type:"bracket",value:E});continue}if(E==="]"){if(t.nobracket===!0||C&&C.type==="bracket"&&C.value.length===1){q({type:"text",value:E,output:`\\${E}`});continue}if(k.brackets===0){if(t.strictBrackets===!0)throw new SyntaxError(bn("opening","["));q({type:"text",value:E,output:`\\${E}`});continue}ve("brackets");let P=C.value.slice(1);if(C.posix!==!0&&P[0]==="^"&&!P.includes("/")&&(E=`/${E}`),C.value+=E,_e({value:E}),t.literalBrackets===!1||Ce.hasRegexChars(P))continue;let G=Ce.escapeRegex(C.value);if(k.output=k.output.slice(0,-C.value.length),t.literalBrackets===!0){k.output+=G,C.value=G;continue}C.value=`(${a}${G}|${C.value})`,k.output+=C.value;continue}if(E==="{"&&t.nobrace!==!0){Ae("braces");let P={type:"brace",value:E,output:"(",outputIndex:k.output.length,tokensIndex:k.tokens.length};H.push(P),q(P);continue}if(E==="}"){let P=H[H.length-1];if(t.nobrace===!0||!P){q({type:"text",value:E,output:E});continue}let G=")";if(P.dots===!0){let ne=o.slice(),pe=[];for(let ie=ne.length-1;ie>=0&&(o.pop(),ne[ie].type!=="brace");ie--)ne[ie].type!=="dots"&&pe.unshift(ne[ie].value);G=Qb(pe,t),k.backtrack=!0}if(P.comma!==!0&&P.dots!==!0){let ne=k.output.slice(0,P.outputIndex),pe=k.tokens.slice(P.tokensIndex);P.value=P.output="\\{",E=G="\\}",k.output=ne;for(let ie of pe)k.output+=ie.output||ie.value}q({type:"brace",value:E,output:G}),ve("braces"),H.pop();continue}if(E==="|"){F.length>0&&F[F.length-1].conditions++,q({type:"text",value:E});continue}if(E===","){let P=E,G=H[H.length-1];G&&V[V.length-1]==="braces"&&(G.comma=!0,P="|"),q({type:"comma",value:E,output:P});continue}if(E==="/"){if(C.type==="dot"&&k.index===k.start+1){k.start=k.index+1,k.consumed="",k.output="",o.pop(),C=i;continue}q({type:"slash",value:E,output:m});continue}if(E==="."){if(k.braces>0&&C.type==="dot"){C.value==="."&&(C.output=f);let P=H[H.length-1];C.type="dots",C.output+=E,C.value+=E,P.dots=!0;continue}if(k.braces+k.parens===0&&C.type!=="bos"&&C.type!=="slash"){q({type:"text",value:E,output:f});continue}q({type:"dot",value:E,output:f});continue}if(E==="?"){if(!(C&&C.value==="(")&&t.noextglob!==!0&&D()==="("&&D(2)!=="?"){ue("qmark",E);continue}if(C&&C.type==="paren"){let G=D(),ne=E;if(G==="<"&&!Ce.supportsLookbehinds())throw new Error("Node.js v10 or higher is required for regex lookbehinds");(C.value==="("&&!/[!=<:]/.test(G)||G==="<"&&!/<([!=]|\w+>)/.test(ee()))&&(ne=`\\${E}`),q({type:"text",value:E,output:ne});continue}if(t.dot!==!0&&(C.type==="slash"||C.type==="bos")){q({type:"qmark",value:E,output:y});continue}q({type:"qmark",value:E,output:_});continue}if(E==="!"){if(t.noextglob!==!0&&D()==="("&&(D(2)!=="?"||!/[!=<:]/.test(D(3)))){ue("negate",E);continue}if(t.nonegate!==!0&&k.index===0){Q();continue}}if(E==="+"){if(t.noextglob!==!0&&D()==="("&&D(2)!=="?"){ue("plus",E);continue}if(C&&C.value==="("||t.regex===!1){q({type:"plus",value:E,output:h});continue}if(C&&(C.type==="bracket"||C.type==="paren"||C.type==="brace")||k.parens>0){q({type:"plus",value:E});continue}q({type:"plus",value:h});continue}if(E==="@"){if(t.noextglob!==!0&&D()==="("&&D(2)!=="?"){q({type:"at",extglob:!0,value:E,output:""});continue}q({type:"text",value:E});continue}if(E!=="*"){(E==="$"||E==="^")&&(E=`\\${E}`);let P=Yb.exec(ee());P&&(E+=P[0],k.index+=P[0].length),q({type:"text",value:E});continue}if(C&&(C.type==="globstar"||C.star===!0)){C.type="star",C.star=!0,C.value+=E,C.output=M,k.backtrack=!0,k.globstar=!0,te(E);continue}let I=ee();if(t.noextglob!==!0&&/^\([^?]/.test(I)){ue("star",E);continue}if(C.type==="star"){if(t.noglobstar===!0){te(E);continue}let P=C.prev,G=P.prev,ne=P.type==="slash"||P.type==="bos",pe=G&&(G.type==="star"||G.type==="globstar");if(t.bash===!0&&(!ne||I[0]&&I[0]!=="/")){q({type:"star",value:E,output:""});continue}let ie=k.braces>0&&(P.type==="comma"||P.type==="brace"),Oe=F.length&&(P.type==="pipe"||P.type==="paren");if(!ne&&P.type!=="paren"&&!ie&&!Oe){q({type:"star",value:E,output:""});continue}for(;I.slice(0,3)==="/**";){let We=n[k.index+4];if(We&&We!=="/")break;I=I.slice(3),te("/**",3)}if(P.type==="bos"&&Y()){C.type="globstar",C.value+=E,C.output=w(t),k.output=C.output,k.globstar=!0,te(E);continue}if(P.type==="slash"&&P.prev.type!=="bos"&&!pe&&Y()){k.output=k.output.slice(0,-(P.output+C.output).length),P.output=`(?:${P.output}`,C.type="globstar",C.output=w(t)+(t.strictSlashes?")":"|$)"),C.value+=E,k.globstar=!0,k.output+=P.output+C.output,te(E);continue}if(P.type==="slash"&&P.prev.type!=="bos"&&I[0]==="/"){let We=I[1]!==void 0?"|$":"";k.output=k.output.slice(0,-(P.output+C.output).length),P.output=`(?:${P.output}`,C.type="globstar",C.output=`${w(t)}${m}|${m}${We})`,C.value+=E,k.output+=P.output+C.output,k.globstar=!0,te(E+X()),q({type:"slash",value:"/",output:""});continue}if(P.type==="bos"&&I[0]==="/"){C.type="globstar",C.value+=E,C.output=`(?:^|${m}|${w(t)}${m})`,k.output=C.output,k.globstar=!0,te(E+X()),q({type:"slash",value:"/",output:""});continue}k.output=k.output.slice(0,-C.output.length),C.type="globstar",C.output=w(t),C.value+=E,k.output+=C.output,k.globstar=!0,te(E);continue}let Z={type:"star",value:E,output:M};if(t.bash===!0){Z.output=".*?",(C.type==="bos"||C.type==="slash")&&(Z.output=S+Z.output),q(Z);continue}if(C&&(C.type==="bracket"||C.type==="paren")&&t.regex===!0){Z.output=E,q(Z);continue}(k.index===k.start||C.type==="slash"||C.type==="dot")&&(C.type==="dot"?(k.output+=A,C.output+=A):t.dot===!0?(k.output+=$,C.output+=$):(k.output+=S,C.output+=S),D()!=="*"&&(k.output+=p,C.output+=p)),q(Z)}for(;k.brackets>0;){if(t.strictBrackets===!0)throw new SyntaxError(bn("closing","]"));k.output=Ce.escapeLast(k.output,"["),ve("brackets")}for(;k.parens>0;){if(t.strictBrackets===!0)throw new SyntaxError(bn("closing",")"));k.output=Ce.escapeLast(k.output,"("),ve("parens")}for(;k.braces>0;){if(t.strictBrackets===!0)throw new SyntaxError(bn("closing","}"));k.output=Ce.escapeLast(k.output,"{"),ve("braces")}if(t.strictSlashes!==!0&&(C.type==="star"||C.type==="bracket")&&q({type:"maybe_slash",value:"",output:`${m}?`}),k.backtrack===!0){k.output="";for(let I of k.tokens)k.output+=I.output!=null?I.output:I.value,I.suffix&&(k.output+=I.suffix)}return k};vo.fastpaths=(n,e)=>{let t={...e},s=typeof t.maxLength=="number"?Math.min(qs,t.maxLength):qs,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);n=rd[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}=zn.globChars(i),g=t.dot?f:d,x=t.dot?h:d,A=t.capture?"":"?:",$={negated:!1,prefix:""},_=t.bash===!0?".*?":m;t.capture&&(_=`(${_})`);let y=S=>S.noglobstar===!0?_:`(${A}(?:(?!${p}${S.dot?u:o}).)*?)`,v=S=>{switch(S){case"*":return`${g}${l}${_}`;case".*":return`${o}${l}${_}`;case"*.*":return`${g}${_}${o}${l}${_}`;case"*/*":return`${g}${_}${a}${l}${x}${_}`;case"**":return g+y(t);case"**/*":return`(?:${g}${y(t)}${a})?${x}${l}${_}`;case"**/*.*":return`(?:${g}${y(t)}${a})?${x}${_}${o}${l}${_}`;case"**/.*":return`(?:${g}${y(t)}${a})?${o}${l}${_}`;default:{let T=/^(.*?)\.(\w+)$/.exec(S);if(!T)return;let M=v(T[1]);return M?M+o+T[2]:void 0}}},b=Ce.removePrefix(n,$),w=v(b);return w&&t.strictSlashes!==!0&&(w+=`${a}?`),w};ad.exports=vo});var ud=j((mC,cd)=>{"use strict";var sv=require("path"),rv=sd(),wo=ld(),xo=Us(),iv=Wn(),ov=n=>n&&typeof n=="object"&&!Array.isArray(n),ge=(n,e,t=!1)=>{if(Array.isArray(n)){let d=n.map(h=>ge(h,e,t));return h=>{for(let m of d){let p=m(h);if(p)return p}return!1}}let s=ov(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=xo.isWindows(e),o=s?ge.compileRe(n,e):ge.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=ge(r.ignore,d,t)}let u=(d,f=!1)=>{let{isMatch:h,match:m,output:p}=ge.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};ge.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?xo.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=ge.matchBase(n,e,t,r):a=e.exec(l)),{isMatch:!!a,match:a,output:l}};ge.matchBase=(n,e,t,s=xo.isWindows(t))=>(e instanceof RegExp?e:ge.makeRe(e,t)).test(sv.basename(n));ge.isMatch=(n,e,t)=>ge(e,t)(n);ge.parse=(n,e)=>Array.isArray(n)?n.map(t=>ge.parse(t,e)):wo(n,{...e,fastpaths:!1});ge.scan=(n,e)=>rv(n,e);ge.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=ge.toRegex(a,e);return s===!0&&(l.state=n),l};ge.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=wo.fastpaths(n,e)),r.output||(r=wo(n,e)),ge.compileRe(r,e,t,s)};ge.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/$^/}};ge.constants=iv;cd.exports=ge});var So=j((gC,dd)=>{"use strict";dd.exports=ud()});var vd=j((yC,bd)=>{"use strict";var Jn=require("fs"),{Readable:av}=require("stream"),Yn=require("path"),{promisify:Vs}=require("util"),_o=So(),lv=Vs(Jn.readdir),cv=Vs(Jn.stat),fd=Vs(Jn.lstat),uv=Vs(Jn.realpath),dv="!",gd="READDIRP_RECURSIVE_ERROR",fv=new Set(["ENOENT","EPERM","EACCES","ELOOP",gd]),Ao="files",yd="directories",Gs="files_directories",Ks="all",pd=[Ao,yd,Gs,Ks],pv=n=>fv.has(n.code),[hd,hv]=process.versions.node.split(".").slice(0,2).map(n=>Number.parseInt(n,10)),mv=process.platform==="win32"&&(hd>10||hd===10&&hv>=5),md=n=>{if(n!==void 0){if(typeof n=="function")return n;if(typeof n=="string"){let e=_o(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)===dv?t.push(_o(r.slice(1))):e.push(_o(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))}}},Ws=class n extends av{static get defaultOptions(){return{root:".",fileFilter:e=>!0,directoryFilter:e=>!0,type:Ao,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=md(t.fileFilter),this._directoryFilter=md(t.directoryFilter);let i=t.lstat?fd:cv;mv?this._stat=o=>i(o,{bigint:!0}):this._stat=i,this._maxDepth=t.depth,this._wantsDir=[yd,Gs,Ks].includes(r),this._wantsFile=[Ao,Gs,Ks].includes(r),this._wantsEverything=r===Ks,this._root=Yn.resolve(s),this._isDirent="Dirent"in Jn&&!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 lv(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=Yn.resolve(Yn.join(t,r));s={path:Yn.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){pv(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 uv(s),i=await fd(r);if(i.isFile())return"file";if(i.isDirectory()){let o=r.length;if(s.startsWith(r)&&s.substr(o,1)===Yn.sep){let a=new Error(`Circular symlink detected: "${s}" points to "${r}"`);return a.code=gd,this._onError(a)}return"directory"}}catch(r){this._onError(r)}}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}},vn=(n,e={})=>{let t=e.entryType||e.type;if(t==="both"&&(t=Gs),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&&!pd.includes(t))throw new Error(`readdirp: Invalid type passed. Use one of ${pd.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return e.root=n,new Ws(e)},gv=(n,e={})=>new Promise((t,s)=>{let r=[];vn(n,e).on("data",i=>r.push(i)).on("end",()=>t(r)).on("error",i=>s(i))});vn.promise=gv;vn.ReaddirpStream=Ws;vn.default=vn;bd.exports=vn});var ko=j((bC,wd)=>{wd.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 $d=j((Ad,kd)=>{"use strict";Object.defineProperty(Ad,"__esModule",{value:!0});var _d=So(),yv=ko(),xd="!",bv={returnIndex:!1},vv=n=>Array.isArray(n)?n:[n],wv=(n,e)=>{if(typeof n=="function")return n;if(typeof n=="string"){let t=_d(n,e);return s=>n===s||t(s)}return n instanceof RegExp?t=>n.test(t):t=>!1},Sd=(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=yv(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},$o=(n,e,t=bv)=>{if(n==null)throw new TypeError("anymatch: specify first argument");let s=typeof t=="boolean"?{returnIndex:t}:t,r=s.returnIndex||!1,i=vv(n),o=i.filter(l=>typeof l=="string"&&l.charAt(0)===xd).map(l=>l.slice(1)).map(l=>_d(l,s)),a=i.filter(l=>typeof l!="string"||typeof l=="string"&&l.charAt(0)!==xd).map(l=>wv(l,s));return e==null?(l,u=!1)=>Sd(a,o,l,typeof u=="boolean"?u:!1):Sd(a,o,e,r)};$o.default=$o;kd.exports=$o});var Cd=j((vC,Ed)=>{Ed.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=j((wC,Rd)=>{var xv=Cd(),Td={"{":"}","(":")","[":"]"},Sv=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},_v=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};Rd.exports=function(e,t){if(typeof e!="string"||e==="")return!1;if(xv(e))return!0;var s=Sv;return t&&t.strict===!1&&(s=_v),s(e)}});var Pd=j((xC,Od)=>{"use strict";var Av=Eo(),kv=require("path").posix.dirname,$v=require("os").platform()==="win32",Co="/",Ev=/\\/g,Cv=/[\{\[].*[\}\]]$/,Tv=/(^|[^\\])([\{\[]|\([^\)]+$)/,Rv=/\\([\!\*\?\|\[\]\(\)\{\}])/g;Od.exports=function(e,t){var s=Object.assign({flipBackslashes:!0},t);s.flipBackslashes&&$v&&e.indexOf(Co)<0&&(e=e.replace(Ev,Co)),Cv.test(e)&&(e+=Co),e+="a";do e=kv(e);while(Av(e)||Tv.test(e));return e.replace(Rv,"$1")}});var zs=j(Ye=>{"use strict";Ye.isInteger=n=>typeof n=="number"?Number.isInteger(n):typeof n=="string"&&n.trim()!==""?Number.isInteger(Number(n)):!1;Ye.find=(n,e)=>n.nodes.find(t=>t.type===e);Ye.exceedsLimit=(n,e,t=1,s)=>s===!1||!Ye.isInteger(n)||!Ye.isInteger(e)?!1:(Number(e)-Number(n))/Number(t)>=s;Ye.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)};Ye.encloseBrace=n=>n.type!=="brace"?!1:n.commas>>0+n.ranges>>0===0?(n.invalid=!0,!0):!1;Ye.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;Ye.isOpenOrClose=n=>n.type==="open"||n.type==="close"?!0:n.open===!0||n.close===!0;Ye.reduce=n=>n.reduce((e,t)=>(t.type==="text"&&e.push(t.value),t.type==="range"&&(t.type="text"),e),[]);Ye.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 Ys=j((_C,Md)=>{"use strict";var Id=zs();Md.exports=(n,e={})=>{let t=(s,r={})=>{let i=e.escapeInvalid&&Id.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a="";if(s.value)return(i||o)&&Id.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=j((AC,Ld)=>{"use strict";Ld.exports=function(n){return typeof n=="number"?n-n===0:typeof n=="string"&&n.trim()!==""?Number.isFinite?Number.isFinite(+n):isFinite(+n):!1}});var Gd=j((kC,Kd)=>{"use strict";var Nd=Dd(),zt=(n,e,t)=>{if(Nd(n)===!1)throw new TypeError("toRegexRange: expected the first argument to be a number");if(e===void 0||n===e)return String(n);if(Nd(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(zt.cache.hasOwnProperty(l))return zt.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=qd(n)||qd(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=Ov(p,m,s),s.capture===!0?h.result=`(${h.result})`:s.wrap!==!1&&m.length+p.length>1&&(h.result=`(?:${h.result})`),zt.cache[l]=h,h.result};function Ov(n,e,t){let s=To(n,e,"-",!1,t)||[],r=To(e,n,"",!1,t)||[],i=To(n,e,"-?",!0,t)||[];return s.concat(i).concat(r).join("|")}function Pv(n,e){let t=1,s=1,r=Hd(n,t),i=new Set([e]);for(;n<=r&&r<=e;)i.add(r),t+=1,r=Hd(n,t);for(r=Bd(e+1,s)-1;n<r&&r<=e;)i.add(r),s+=1,r=Bd(e+1,s)-1;return i=[...i],i.sort(Lv),i}function Iv(n,e,t){if(n===e)return{pattern:n,count:[],digits:0};let s=Mv(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+=Dv(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=Pv(n,e),i=[],o=n,a;for(let l=0;l<r.length;l++){let u=r[l],d=Iv(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+Ud(a.count),o=u+1;continue}t.isPadded&&(f=Nv(u,t,s)),d.string=f+d.pattern+Ud(d.count),i.push(d),o=u+1,a=d}return i}function To(n,e,t,s,r){let i=[];for(let o of n){let{string:a}=o;!s&&!jd(e,"string",a)&&i.push(t+a),s&&jd(e,"string",a)&&i.push(t+a)}return i}function Mv(n,e){let t=[];for(let s=0;s<n.length;s++)t.push([n[s],e[s]]);return t}function Lv(n,e){return n>e?1:e>n?-1:0}function jd(n,e,t){return n.some(s=>s[e]===t)}function Hd(n,e){return Number(String(n).slice(0,-e)+"9".repeat(e))}function Bd(n,e){return n-n%Math.pow(10,e)}function Ud(n){let[e=0,t=""]=n;return t||e>1?`{${e+(t?","+t:"")}}`:""}function Dv(n,e,t){return`[${n}${e-n===1?"":"-"}${e}]`}function qd(n){return/^-?(0+)\d/.test(n)}function Nv(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}}`}}zt.cache={};zt.clearCache=()=>zt.cache={};Kd.exports=zt});var Po=j(($C,Xd)=>{"use strict";var Fv=require("util"),Vd=Gd(),Wd=n=>n!==null&&typeof n=="object"&&!Array.isArray(n),jv=n=>e=>n===!0?Number(e):String(e),Ro=n=>typeof n=="number"||typeof n=="string"&&n!=="",Qn=n=>Number.isInteger(+n),Oo=n=>{let e=`${n}`,t=-1;if(e[0]==="-"&&(e=e.slice(1)),e==="0")return!1;for(;e[++t]==="0";);return t>0},Hv=(n,e,t)=>typeof n=="string"||typeof e=="string"?!0:t.stringify===!0,Bv=(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},Qs=(n,e)=>{let t=n[0]==="-"?"-":"";for(t&&(n=n.slice(1),e--);n.length<e;)n="0"+n;return t?"-"+n:n},Uv=(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=>Qs(String(a),t)).join("|")),n.negatives.length&&(i=`-(${s}${n.negatives.map(a=>Qs(String(a),t)).join("|")})`),r&&i?o=`${r}|${i}`:o=r||i,e.wrap?`(${s}${o})`:o},zd=(n,e,t,s)=>{if(t)return Vd(n,e,{wrap:!1,...s});let r=String.fromCharCode(n);if(n===e)return r;let i=String.fromCharCode(e);return`[${r}-${i}]`},Yd=(n,e,t)=>{if(Array.isArray(n)){let s=t.wrap===!0,r=t.capture?"":"?:";return s?`(${r}${n.join("|")})`:n.join("|")}return Vd(n,e,t)},Jd=(...n)=>new RangeError("Invalid range arguments: "+Fv.inspect(...n)),Qd=(n,e,t)=>{if(t.strictRanges===!0)throw Jd([n,e]);return[]},qv=(n,e)=>{if(e.strictRanges===!0)throw new TypeError(`Expected step "${n}" to be a number`);return[]},Kv=(n,e,t=1,s={})=>{let r=Number(n),i=Number(e);if(!Number.isInteger(r)||!Number.isInteger(i)){if(s.strictRanges===!0)throw Jd([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=Oo(a)||Oo(l)||Oo(u),f=d?Math.max(a.length,l.length,u.length):0,h=d===!1&&Hv(n,e,s)===!1,m=s.transform||jv(h);if(s.toRegex&&t===1)return zd(Qs(n,f),Qs(e,f),!0,s);let p={negatives:[],positives:[]},g=$=>p[$<0?"negatives":"positives"].push(Math.abs($)),x=[],A=0;for(;o?r>=i:r<=i;)s.toRegex===!0&&t>1?g(r):x.push(Bv(m(r,A),f,h)),r=o?r-t:r+t,A++;return s.toRegex===!0?t>1?Uv(p,s,f):Yd(x,null,{wrap:!1,...s}):x},Gv=(n,e,t=1,s={})=>{if(!Qn(n)&&n.length>1||!Qn(e)&&e.length>1)return Qd(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 zd(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?Yd(d,null,{wrap:!1,options:s}):d},Js=(n,e,t,s={})=>{if(e==null&&Ro(n))return[n];if(!Ro(n)||!Ro(e))return Qd(n,e,s);if(typeof t=="function")return Js(n,e,1,{transform:t});if(Wd(t))return Js(n,e,0,t);let r={...s};return r.capture===!0&&(r.wrap=!0),t=t||r.step||1,Qn(t)?Qn(n)&&Qn(e)?Kv(n,e,t,r):Gv(n,e,Math.max(Math.abs(t),1),r):t!=null&&!Wd(t)?qv(t,r):Js(n,e,1,t)};Xd.exports=Js});var tf=j((EC,ef)=>{"use strict";var Wv=Po(),Zd=zs(),Vv=(n,e={})=>{let t=(s,r={})=>{let i=Zd.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=Zd.reduce(s.nodes),f=Wv(...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)};ef.exports=Vv});var rf=j((CC,sf)=>{"use strict";var zv=Po(),nf=Ys(),wn=zs(),Yt=(n="",e="",t=!1)=>{let s=[];if(n=[].concat(n),e=[].concat(e),!e.length)return n;if(!n.length)return t?wn.flatten(e).map(r=>`{${r}}`):e;for(let r of n)if(Array.isArray(r))for(let i of r)s.push(Yt(i,e,t));else for(let i of e)t===!0&&typeof i=="string"&&(i=`{${i}}`),s.push(Array.isArray(i)?Yt(r,i,t):r+i);return wn.flatten(s)},Yv=(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(Yt(a.pop(),nf(r,e)));return}if(r.type==="brace"&&r.invalid!==!0&&r.nodes.length===2){a.push(Yt(a.pop(),["{}"]));return}if(r.nodes&&r.ranges>0){let f=wn.reduce(r.nodes);if(wn.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=zv(...f,e);h.length===0&&(h=nf(r,e)),a.push(Yt(a.pop(),h)),r.nodes=[];return}let l=wn.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(Yt(a.pop(),u,l));continue}if(h.value&&h.type!=="open"){u.push(Yt(u.pop(),h.value));continue}h.nodes&&s(h,r)}return u};return wn.flatten(s(n))};sf.exports=Yv});var af=j((TC,of)=>{"use strict";of.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:`
325
- `,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 ff=j((RC,df)=>{"use strict";var Jv=Ys(),{MAX_LENGTH:lf,CHAR_BACKSLASH:Io,CHAR_BACKTICK:Qv,CHAR_COMMA:Xv,CHAR_DOT:Zv,CHAR_LEFT_PARENTHESES:ew,CHAR_RIGHT_PARENTHESES:tw,CHAR_LEFT_CURLY_BRACE:nw,CHAR_RIGHT_CURLY_BRACE:sw,CHAR_LEFT_SQUARE_BRACKET:cf,CHAR_RIGHT_SQUARE_BRACKET:uf,CHAR_DOUBLE_QUOTE:rw,CHAR_SINGLE_QUOTE:iw,CHAR_NO_BREAK_SPACE:ow,CHAR_ZERO_WIDTH_NOBREAK_SPACE:aw}=af(),lw=(n,e={})=>{if(typeof n!="string")throw new TypeError("Expected a string");let t=e||{},s=typeof t.maxLength=="number"?Math.min(lf,t.maxLength):lf;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===aw||h===ow)){if(h===Io){p({type:"text",value:(e.keepEscaping?h:"")+m()});continue}if(h===uf){p({type:"text",value:"\\"+h});continue}if(h===cf){l++;let g;for(;d<u&&(g=m());){if(h+=g,g===cf){l++;continue}if(g===Io){h+=m();continue}if(g===uf&&(l--,l===0))break}p({type:"text",value:h});continue}if(h===ew){o=p({type:"paren",nodes:[]}),i.push(o),p({type:"text",value:h});continue}if(h===tw){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===rw||h===iw||h===Qv){let g=h,x;for(e.keepQuotes!==!0&&(h="");d<u&&(x=m());){if(x===Io){h+=x+m();continue}if(x===g){e.keepQuotes===!0&&(h+=x);break}h+=x}p({type:"text",value:h});continue}if(h===nw){f++;let x={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(x),i.push(o),p({type:"open",value:h});continue}if(h===sw){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===Xv&&f>0){if(o.ranges>0){o.ranges=0;let g=o.nodes.shift();o.nodes=[g,{type:"text",value:Jv(o)}]}p({type:"comma",value:h}),o.commas++;continue}if(h===Zv&&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 x=g[g.length-1];x.value+=a.value+h,a=x,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(A=>{A.nodes||(A.type==="open"&&(A.isOpen=!0),A.type==="close"&&(A.isClose=!0),A.nodes||(A.type="text"),A.invalid=!0)});let g=i[i.length-1],x=g.nodes.indexOf(o);g.nodes.splice(x,1,...o.nodes)}while(i.length>0);return p({type:"eos"}),r};df.exports=lw});var mf=j((OC,hf)=>{"use strict";var pf=Ys(),cw=tf(),uw=rf(),dw=ff(),Ue=(n,e={})=>{let t=[];if(Array.isArray(n))for(let s of n){let r=Ue.create(s,e);Array.isArray(r)?t.push(...r):t.push(r)}else t=[].concat(Ue.create(n,e));return e&&e.expand===!0&&e.nodupes===!0&&(t=[...new Set(t)]),t};Ue.parse=(n,e={})=>dw(n,e);Ue.stringify=(n,e={})=>pf(typeof n=="string"?Ue.parse(n,e):n,e);Ue.compile=(n,e={})=>(typeof n=="string"&&(n=Ue.parse(n,e)),cw(n,e));Ue.expand=(n,e={})=>{typeof n=="string"&&(n=Ue.parse(n,e));let t=uw(n,e);return e.noempty===!0&&(t=t.filter(Boolean)),e.nodupes===!0&&(t=[...new Set(t)]),t};Ue.create=(n,e={})=>n===""||n.length<3?[n]:e.expand!==!0?Ue.compile(n,e):Ue.expand(n,e);hf.exports=Ue});var gf=j((PC,fw)=>{fw.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 bf=j((IC,yf)=>{yf.exports=gf()});var wf=j((MC,vf)=>{"use strict";var pw=require("path"),hw=bf(),mw=new Set(hw);vf.exports=n=>mw.has(pw.extname(n).slice(1).toLowerCase())});var Xs=j(U=>{"use strict";var{sep:gw}=require("path"),{platform:Mo}=process,yw=require("os");U.EV_ALL="all";U.EV_READY="ready";U.EV_ADD="add";U.EV_CHANGE="change";U.EV_ADD_DIR="addDir";U.EV_UNLINK="unlink";U.EV_UNLINK_DIR="unlinkDir";U.EV_RAW="raw";U.EV_ERROR="error";U.STR_DATA="data";U.STR_END="end";U.STR_CLOSE="close";U.FSEVENT_CREATED="created";U.FSEVENT_MODIFIED="modified";U.FSEVENT_DELETED="deleted";U.FSEVENT_MOVED="moved";U.FSEVENT_CLONED="cloned";U.FSEVENT_UNKNOWN="unknown";U.FSEVENT_FLAG_MUST_SCAN_SUBDIRS=1;U.FSEVENT_TYPE_FILE="file";U.FSEVENT_TYPE_DIRECTORY="directory";U.FSEVENT_TYPE_SYMLINK="symlink";U.KEY_LISTENERS="listeners";U.KEY_ERR="errHandlers";U.KEY_RAW="rawEmitters";U.HANDLER_KEYS=[U.KEY_LISTENERS,U.KEY_ERR,U.KEY_RAW];U.DOT_SLASH=`.${gw}`;U.BACK_SLASH_RE=/\\/g;U.DOUBLE_SLASH_RE=/\/\//;U.SLASH_OR_BACK_SLASH_RE=/[/\\]/;U.DOT_RE=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/;U.REPLACER_RE=/^\.[/\\]/;U.SLASH="/";U.SLASH_SLASH="//";U.BRACE_START="{";U.BANG="!";U.ONE_DOT=".";U.TWO_DOTS="..";U.STAR="*";U.GLOBSTAR="**";U.ROOT_GLOBSTAR="/**/*";U.SLASH_GLOBSTAR="/**";U.DIR_SUFFIX="Dir";U.ANYMATCH_OPTS={dot:!0};U.STRING_TYPE="string";U.FUNCTION_TYPE="function";U.EMPTY_STR="";U.EMPTY_FN=()=>{};U.IDENTITY_FN=n=>n;U.isWindows=Mo==="win32";U.isMacos=Mo==="darwin";U.isLinux=Mo==="linux";U.isIBMi=yw.type()==="OS400"});var $f=j((DC,kf)=>{"use strict";var Rt=require("fs"),xe=require("path"),{promisify:ts}=require("util"),bw=wf(),{isWindows:vw,isLinux:ww,EMPTY_FN:xw,EMPTY_STR:Sw,KEY_LISTENERS:xn,KEY_ERR:Lo,KEY_RAW:Xn,HANDLER_KEYS:_w,EV_CHANGE:er,EV_ADD:Zs,EV_ADD_DIR:Aw,EV_ERROR:Sf,STR_DATA:kw,STR_END:$w,BRACE_START:Ew,STAR:Cw}=Xs(),Tw="watch",Rw=ts(Rt.open),_f=ts(Rt.stat),Ow=ts(Rt.lstat),Pw=ts(Rt.close),Do=ts(Rt.realpath),Iw={lstat:Ow,stat:_f},Fo=(n,e)=>{n instanceof Set?n.forEach(e):e(n)},Zn=(n,e,t)=>{let s=n[e];s instanceof Set||(n[e]=s=new Set([s])),s.add(t)},Mw=n=>e=>{let t=n[e];t instanceof Set?t.clear():delete n[e]},es=(n,e,t)=>{let s=n[e];s instanceof Set?s.delete(t):s===t&&delete n[e]},Af=n=>n instanceof Set?n.size===0:!n,tr=new Map;function xf(n,e,t,s,r){let i=(o,a)=>{t(n),r(o,a,{watchedPath:n}),a&&n!==a&&nr(xe.resolve(n,a),xn,xe.join(n,a))};try{return Rt.watch(n,e,i)}catch(o){s(o)}}var nr=(n,e,t,s,r)=>{let i=tr.get(n);i&&Fo(i[e],o=>{o(t,s,r)})},Lw=(n,e,t,s)=>{let{listener:r,errHandler:i,rawEmitter:o}=s,a=tr.get(e),l;if(!t.persistent)return l=xf(n,t,r,i,o),l.close.bind(l);if(a)Zn(a,xn,r),Zn(a,Lo,i),Zn(a,Xn,o);else{if(l=xf(n,t,nr.bind(null,e,xn),i,nr.bind(null,e,Xn)),!l)return;l.on(Sf,async u=>{let d=nr.bind(null,e,Lo);if(a.watcherUnusable=!0,vw&&u.code==="EPERM")try{let f=await Rw(n,"r");await Pw(f),d(u)}catch{}else d(u)}),a={listeners:r,errHandlers:i,rawEmitters:o,watcher:l},tr.set(e,a)}return()=>{es(a,xn,r),es(a,Lo,i),es(a,Xn,o),Af(a.listeners)&&(a.watcher.close(),tr.delete(e),_w.forEach(Mw(a)),a.watcher=void 0,Object.freeze(a))}},No=new Map,Dw=(n,e,t,s)=>{let{listener:r,rawEmitter:i}=s,o=No.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?(Zn(o,xn,r),Zn(o,Xn,i)):(o={listeners:r,rawEmitters:i,options:t,watcher:Rt.watchFile(e,t,(d,f)=>{Fo(o.rawEmitters,m=>{m(er,e,{curr:d,prev:f})});let h=d.mtimeMs;(d.size!==f.size||h>f.mtimeMs||h===0)&&Fo(o.listeners,m=>m(n,d))})},No.set(e,o)),()=>{es(o,xn,r),es(o,Xn,i),Af(o.listeners)&&(No.delete(e),Rt.unwatchFile(e),o.options=o.watcher=void 0,Object.freeze(o))}},jo=class{constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let s=this.fsw.options,r=xe.dirname(e),i=xe.basename(e);this.fsw._getWatchedDir(r).add(i);let a=xe.resolve(e),l={persistent:s.persistent};t||(t=xw);let u;return s.usePolling?(l.interval=s.enableBinaryInterval&&bw(i)?s.binaryInterval:s.interval,u=Dw(e,a,l,{listener:t,rawEmitter:this.fsw._emitRaw})):u=Lw(e,a,l,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw}),u}_handleFile(e,t,s){if(this.fsw.closed)return;let r=xe.dirname(e),i=xe.basename(e),o=this.fsw._getWatchedDir(r),a=t;if(o.has(i))return;let l=async(d,f)=>{if(this.fsw._throttle(Tw,e,5)){if(!f||f.mtimeMs===0)try{let h=await _f(e);if(this.fsw.closed)return;let m=h.atimeMs,p=h.mtimeMs;(!m||m<=p||p!==a.mtimeMs)&&this.fsw._emit(er,e,h),ww&&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(er,e,f),a=f}}},u=this._watchWithNodeFs(e,l);if(!(s&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(Zs,e,0))return;this.fsw._emit(Zs,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 Do(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(er,s,e.stats)):(o.add(r),this.fsw._symlinkPaths.set(i,a),this.fsw._emit(Zs,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=xe.join(e,Sw),!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(kw,async f=>{if(this.fsw.closed){d=void 0;return}let h=f.path,m=xe.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=xe.join(i,xe.relative(i,m)),this._addToNodeFs(m,t,s,o+1))}}).on(Sf,this._boundHandleError);return new Promise(f=>d.once($w,()=>{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:xe.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(xe.dirname(e)),u=l.has(xe.basename(e));!(s&&this.fsw.options.ignoreInitial)&&!i&&!u&&(!o.hasGlob||o.globFilter(e))&&this.fsw._emit(Aw,e,t),l.add(xe.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 Iw[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(Cw)&&!e.includes(Ew),d;if(l.isDirectory()){let f=xe.resolve(e),h=u?await Do(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 Do(e):e;if(this.fsw.closed)return;let h=xe.dirname(a.watchPath);if(this.fsw._getWatchedDir(h).add(a.watchPath),this.fsw._emit(Zs,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(xe.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=jo});var If=j((NC,Vo)=>{"use strict";var Go=require("fs"),Se=require("path"),{promisify:Wo}=require("util"),Sn;try{Sn=require("fsevents")}catch(n){process.env.CHOKIDAR_PRINT_FSEVENTS_REQUIRE_ERROR&&console.error(n)}if(Sn){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&&(Sn=void 0)}}var{EV_ADD:Ho,EV_CHANGE:Nw,EV_ADD_DIR:Ef,EV_UNLINK:sr,EV_ERROR:Fw,STR_DATA:jw,STR_END:Hw,FSEVENT_CREATED:Bw,FSEVENT_MODIFIED:Uw,FSEVENT_DELETED:qw,FSEVENT_MOVED:Kw,FSEVENT_UNKNOWN:Gw,FSEVENT_FLAG_MUST_SCAN_SUBDIRS:Ww,FSEVENT_TYPE_FILE:Vw,FSEVENT_TYPE_DIRECTORY:ns,FSEVENT_TYPE_SYMLINK:Pf,ROOT_GLOBSTAR:Cf,DIR_SUFFIX:zw,DOT_SLASH:Tf,FUNCTION_TYPE:Bo,EMPTY_FN:Yw,IDENTITY_FN:Jw}=Xs(),Qw=n=>isNaN(n)?{}:{depth:n},qo=Wo(Go.stat),Xw=Wo(Go.lstat),Rf=Wo(Go.realpath),Zw={stat:qo,lstat:Xw},Jt=new Map,ex=10,tx=new Set([69888,70400,71424,72704,73472,131328,131840,262912]),nx=(n,e)=>({stop:Sn.watch(n,e)});function sx(n,e,t,s){let r=Se.extname(e)?Se.dirname(e):e,i=Se.dirname(r),o=Jt.get(r);rx(i)&&(r=i);let a=Se.resolve(n),l=a!==e,u=(f,h,m)=>{l&&(f=f.replace(e,a)),(f===a||!f.indexOf(a+Se.sep))&&t(f,h,m)},d=!1;for(let f of Jt.keys())if(e.indexOf(Se.resolve(f)+Se.sep)===0){r=f,o=Jt.get(r),d=!0;break}return o||d?o.listeners.add(u):(o={listeners:new Set([u]),rawEmitter:s,watcher:nx(r,(f,h)=>{if(!o.listeners.size||h&Ww)return;let m=Sn.getInfo(f,h);o.listeners.forEach(p=>{p(f,h,m)}),o.rawEmitter(m.event,f,m)})},Jt.set(r,o)),()=>{let f=o.listeners;if(f.delete(u),!f.size&&(Jt.delete(r),o.watcher))return o.watcher.stop().then(()=>{o.rawEmitter=o.watcher=void 0,Object.freeze(o)})}}var rx=n=>{let e=0;for(let t of Jt.keys())if(t.indexOf(n)===0&&(e++,e>=ex))return!0;return!1},ix=()=>Sn&&Jt.size<128,Uo=(n,e)=>{let t=0;for(;!n.indexOf(e)&&(n=Se.dirname(n))!==e;)t++;return t},Of=(n,e)=>n.type===ns&&e.isDirectory()||n.type===Pf&&e.isSymbolicLink()||n.type===Vw&&e.isFile(),Ko=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)?Nw:Ho;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 qo(e);if(this.fsw.closed)return;Of(a,u)?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(sr,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(sr,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===sr){let d=l.type===ns;(d||o.has(a))&&this.fsw._remove(i,a,d)}else{if(e===Ho){if(l.type===ns&&this.fsw._getWatchedDir(t),l.type===Pf&&u.followSymlinks){let f=u.depth===void 0?void 0:Uo(s,r)+1;return this._addToFsEvents(t,!1,!0,f)}this.fsw._getWatchedDir(i).add(a)}let d=l.type===ns?e+zw:e;this.fsw._emit(d,t),d===Ef&&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=sx(e,t,async(l,u,d)=>{if(this.fsw.closed||i.depth!==void 0&&Uo(l,t)>i.depth)return;let f=s(Se.join(e,Se.relative(e,l)));if(r&&!r(f))return;let h=Se.dirname(f),m=Se.basename(f),p=this.fsw._getWatchedDir(d.type===ns?f:h);if(tx.has(u)||d.event===Gw)if(typeof i.ignored===Bo){let g;try{g=await qo(f)}catch{}if(this.fsw.closed||this.checkIgnored(f,g))return;Of(d,g)?this.addOrChange(f,l,t,h,p,m,d,i):this.handleEvent(sr,f,l,t,h,p,m,d,i)}else this.checkExists(f,l,t,h,p,m,d,i);else switch(d.event){case Bw:case Uw:return this.addOrChange(f,l,t,h,p,m,d,i);case qw:case Kw: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 Rf(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=Se.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(Se.dirname(o)),u=Se.basename(o);a&&this.fsw._getWatchedDir(o),!l.has(u)&&(l.add(u),(!r.ignoreInitial||i===!0)&&this.fsw._emit(a?Ef:Ho,o,t))}initWatch(e,t,s,r){if(this.fsw.closed)return;let i=this._watchWithFsEvents(s.watchPath,Se.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===Bo?t:Jw,a=this.fsw._getWatchHelpers(e);try{let l=await Zw[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),...Qw(i.depth-(r||0))}).on(jw,u=>{if(this.fsw.closed||u.stats.isDirectory()&&!a.filterPath(u))return;let d=Se.join(a.watchPath,u.path),{fullPath:f}=u;if(a.followSymlinks&&u.stats.isSymbolicLink()){let h=i.depth===void 0?void 0:Uo(d,Se.resolve(a.watchPath))+1;this._handleFsEventsSymlink(d,f,o,h)}else this.emitAdd(d,u.stats,o,i,s)}).on(Fw,Yw).on(Hw,()=>{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===Bo)this.initWatch(void 0,e,a,o);else{let l;try{l=await Rf(a.watchPath)}catch{}this.initWatch(l,e,a,o)}}};Vo.exports=Ko;Vo.exports.canUse=ix});var Kf=j(la=>{"use strict";var{EventEmitter:ox}=require("events"),oa=require("fs"),se=require("path"),{promisify:Hf}=require("util"),ax=vd(),Zo=$d().default,lx=Pd(),zo=Eo(),cx=mf(),ux=ko(),dx=$f(),Mf=If(),{EV_ALL:Yo,EV_READY:fx,EV_ADD:rr,EV_CHANGE:ss,EV_UNLINK:Lf,EV_ADD_DIR:px,EV_UNLINK_DIR:hx,EV_RAW:mx,EV_ERROR:Jo,STR_CLOSE:gx,STR_END:yx,BACK_SLASH_RE:bx,DOUBLE_SLASH_RE:Df,SLASH_OR_BACK_SLASH_RE:vx,DOT_RE:wx,REPLACER_RE:xx,SLASH:Qo,SLASH_SLASH:Sx,BRACE_START:_x,BANG:ea,ONE_DOT:Bf,TWO_DOTS:Ax,GLOBSTAR:kx,SLASH_GLOBSTAR:Xo,ANYMATCH_OPTS:ta,STRING_TYPE:aa,FUNCTION_TYPE:$x,EMPTY_STR:na,EMPTY_FN:Ex,isWindows:Cx,isMacos:Tx,isIBMi:Rx}=Xs(),Ox=Hf(oa.stat),Px=Hf(oa.readdir),sa=(n=[])=>Array.isArray(n)?n:[n],Uf=(n,e=[])=>(n.forEach(t=>{Array.isArray(t)?Uf(t,e):e.push(t)}),e),Nf=n=>{let e=Uf(sa(n));if(!e.every(t=>typeof t===aa))throw new TypeError(`Non-string provided as watch path: ${e}`);return e.map(qf)},Ff=n=>{let e=n.replace(bx,Qo),t=!1;for(e.startsWith(Sx)&&(t=!0);e.match(Df);)e=e.replace(Df,Qo);return t&&(e=Qo+e),e},qf=n=>Ff(se.normalize(Ff(n))),jf=(n=na)=>e=>typeof e!==aa?e:qf(se.isAbsolute(e)?e:se.join(n,e)),Ix=(n,e)=>se.isAbsolute(n)?n:n.startsWith(ea)?ea+se.join(e,n.slice(1)):se.join(e,n),it=(n,e)=>n[e]===void 0,ra=class{constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==Bf&&e!==Ax&&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 Px(s)}catch{this._removeWatcher&&this._removeWatcher(se.dirname(s),se.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)}},Mx="stat",Lx="lstat",ia=class{constructor(e,t,s,r){this.fsw=r,this.path=e=e.replace(xx,na),this.watchPath=t,this.fullWatchPath=se.resolve(t),this.hasGlob=t!==e,e===na&&(this.hasGlob=!1),this.globSymlink=this.hasGlob&&s?void 0:!1,this.globFilter=this.hasGlob?Zo(e,void 0,ta):!1,this.dirParts=this.getDirParts(e),this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=s,this.statMethod=s?Mx:Lx}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 se.join(this.watchPath,se.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===$x?this.globFilter(s):!0)&&this.fsw._isntIgnored(s,t)&&this.fsw._hasReadPermissions(t)}getDirParts(e){if(!this.hasGlob)return[];let t=[];return(e.includes(_x)?cx.expand(e):[e]).forEach(r=>{t.push(se.relative(this.watchPath,r).split(vx))}),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===kx&&(s=!0),s||!t[0][o]||Zo(i,t[0][o],ta))))}return!this.unmatchedGlob&&this.fsw._isntIgnored(this.entryPath(e),e.stats)}},ir=class extends ox{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,it(t,"persistent")&&(t.persistent=!0),it(t,"ignoreInitial")&&(t.ignoreInitial=!1),it(t,"ignorePermissionErrors")&&(t.ignorePermissionErrors=!1),it(t,"interval")&&(t.interval=100),it(t,"binaryInterval")&&(t.binaryInterval=300),it(t,"disableGlobbing")&&(t.disableGlobbing=!1),t.enableBinaryInterval=t.binaryInterval!==t.interval,it(t,"useFsEvents")&&(t.useFsEvents=!t.usePolling),Mf.canUse()||(t.useFsEvents=!1),it(t,"usePolling")&&!t.useFsEvents&&(t.usePolling=Tx),Rx&&(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)),it(t,"atomic")&&(t.atomic=!t.usePolling&&!t.useFsEvents),t.atomic&&(this._pendingUnlinks=new Map),it(t,"followSymlinks")&&(t.followSymlinks=!0),it(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=sa(t.ignored));let a=0;this._emitReady=()=>{a++,a>=this._readyCount&&(this._emitReady=Ex,this._readyEmitted=!0,process.nextTick(()=>this.emit(fx)))},this._emitRaw=(...l)=>this.emit(mx,...l),this._readyEmitted=!1,this.options=t,t.useFsEvents?this._fsEventsHandler=new Mf(this):this._nodeFsHandler=new dx(this),Object.freeze(t)}add(e,t,s){let{cwd:r,disableGlobbing:i}=this.options;this.closed=!1;let o=Nf(e);return r&&(o=o.map(a=>{let l=Ix(a,r);return i||!zo(a)?l:ux(l)})),o=o.filter(a=>a.startsWith(ea)?(this._ignoredPaths.add(a.slice(1)),!1):(this._ignoredPaths.delete(a),this._ignoredPaths.delete(a+Xo),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(se.dirname(l),se.basename(t||l))})})),this}unwatch(e){if(this.closed)return this;let t=Nf(e),{cwd:s}=this.options;return t.forEach(r=>{!se.isAbsolute(r)&&!this._closers.has(r)&&(s&&(r=se.join(s,r)),r=se.resolve(r)),this._closePath(r),this._ignoredPaths.add(r),this._watched.has(r)&&this._ignoredPaths.add(r+Xo),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?se.relative(this.options.cwd,s):s;e[r||Bf]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(...t),e!==Jo&&this.emit(Yo,...t)}async _emit(e,t,s,r,i){if(this.closed)return;let o=this.options;Cx&&(t=se.normalize(t)),o.cwd&&(t=se.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===Lf)return this._pendingUnlinks.set(t,a),setTimeout(()=>{this._pendingUnlinks.forEach((d,f)=>{this.emit(...d),this.emit(Yo,...d),this._pendingUnlinks.delete(f)})},typeof o.atomic=="number"?o.atomic:100),this;e===rr&&this._pendingUnlinks.has(t)&&(e=a[0]=ss,this._pendingUnlinks.delete(t))}if(l&&(e===rr||e===ss)&&this._readyEmitted){let d=(f,h)=>{f?(e=a[0]=Jo,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===ss&&!this._throttle(ss,t,50))return this;if(o.alwaysStat&&s===void 0&&(e===rr||e===px||e===ss)){let d=o.cwd?se.join(o.cwd,t):t,f;try{f=await Ox(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(Jo,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&&!se.isAbsolute(e)&&(o=se.join(this.options.cwd,e));let a=new Date,l=u=>{oa.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&&wx.test(e))return!0;if(!this._userIgnored){let{cwd:s}=this.options,r=this.options.ignored,i=r&&r.map(jf(s)),o=sa(i).filter(l=>typeof l===aa&&!zo(l)).map(l=>l+Xo),a=this._getGlobIgnored().map(jf(s)).concat(i,o);this._userIgnored=Zo(a,void 0,ta)}return this._userIgnored([e,t])}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e,t){let s=t||this.options.disableGlobbing||!zo(e)?e:lx(e),r=this.options.followSymlinks;return new ia(e,s,r,this)}_getWatchedDir(e){this._boundRemove||(this._boundRemove=this._remove.bind(this));let t=se.resolve(e);return this._watched.has(t)||this._watched.set(t,new ra(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=se.join(e,t),i=se.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=se.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(d)&&this._pendingWrites.get(d).cancelWait()===rr)return;this._watched.delete(r),this._watched.delete(i);let f=s?hx:Lf;u&&!this._isIgnored(r)&&this._emit(f,r),this.options.useFsEvents||this._closePath(r)}_closePath(e){this._closeFile(e);let t=se.dirname(e);this._getWatchedDir(t).remove(se.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:Yo,alwaysStat:!0,lstat:!0,...t},r=ax(e,s);return this._streams.add(r),r.once(gx,()=>{r=void 0}),r.once(yx,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};la.FSWatcher=ir;var Dx=(n,e)=>{let t=new ir(e);return t.add(n),t};la.watch=Dx});var zf={};Ne(zf,{CollaborationManager:()=>rs,addTeamMember:()=>jx,formatTeamConfig:()=>Hx,initTeamConfig:()=>Fx,loadTeamConfig:()=>Nx,saveTeamConfig:()=>Vf});function Nx(n){let e=Je.join(n,".hablas","team.json");if(ye.existsSync(e))try{return JSON.parse(ye.readFileSync(e,"utf-8"))}catch{return null}return null}function Fx(n,e){let t={name:e,members:[]};return Vf(n,t),t}function Vf(n,e){let t=Je.join(n,".hablas","team.json"),s=Je.dirname(t);ye.existsSync(s)||ye.mkdirSync(s,{recursive:!0}),ye.writeFileSync(t,JSON.stringify(e,null,2),"utf-8")}function jx(n,e,t){return n.members.push({name:e,email:t}),n}function Hx(n){return[`Team: ${n.name}`,"Members:",...n.members.map(t=>` - ${t.name} (${t.email})`)].join(`
326
- `)}var ye,Je,or,Gf,Wf,rs,ca=N(()=>{"use strict";ye=O(require("fs")),Je=O(require("path")),or=O(require("os")),Gf=O(require("crypto")),Wf=O(Kf());mn();rs=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||or.userInfo().username||"developer",this.teamKey=r||"default-team",this.localStatePath=Je.join(this.workingDir,".hablas","collaboration.json");let i=this.getProjectIdentifier();console.log(`
324
+ If you cannot complete a task, explain why with absolute technical objectivity.`;co=ke.join(uo.homedir(),".hablas","backup")});var Vn=j((dC,Yu)=>{"use strict";var Sb=require("path"),ht="\\\\/",Gu=`[^${ht}]`,_b=0,Tt="\\.",Ab="\\+",kb="\\?",Ks="\\/",$b="(?=.)",Wu="[^/]",fo=`(?:${Ks}|$)`,Vu=`(?:^|${Ks})`,po=`${Tt}{1,2}${fo}`,Eb=`(?!${Tt})`,Cb=`(?!${Vu}${po})`,Tb=`(?!${Tt}{0,1}${fo})`,Rb=`(?!${po})`,Ob=`[^.${Ks}]`,Pb=`${Wu}*?`,zu={DOT_LITERAL:Tt,PLUS_LITERAL:Ab,QMARK_LITERAL:kb,SLASH_LITERAL:Ks,ONE_CHAR:$b,QMARK:Wu,END_ANCHOR:fo,DOTS_SLASH:po,NO_DOT:Eb,NO_DOTS:Cb,NO_DOT_SLASH:Tb,NO_DOTS_SLASH:Rb,QMARK_NO_DOT:Ob,STAR:Pb,START_ANCHOR:Vu},Ib={...zu,SLASH_LITERAL:`[${ht}]`,QMARK:Gu,STAR:`${Gu}*?`,DOTS_SLASH:`${Tt}{1,2}(?:[${ht}]|$)`,NO_DOT:`(?!${Tt})`,NO_DOTS:`(?!(?:^|[${ht}])${Tt}{1,2}(?:[${ht}]|$))`,NO_DOT_SLASH:`(?!${Tt}{0,1}(?:[${ht}]|$))`,NO_DOTS_SLASH:`(?!${Tt}{1,2}(?:[${ht}]|$))`,QMARK_NO_DOT:`[^.${ht}]`,START_ANCHOR:`(?:^|[${ht}])`,END_ANCHOR:`(?:[${ht}]|$)`},Mb={__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"};Yu.exports={DEFAULT_MAX_EXTGLOB_RECURSION:_b,MAX_LENGTH:1024*64,POSIX_REGEX_SOURCE:Mb,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:Sb.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?Ib:zu}}});var Gs=j(Me=>{"use strict";var Lb=require("path"),Db=process.platform==="win32",{REGEX_BACKSLASH:Nb,REGEX_REMOVE_BACKSLASH:Fb,REGEX_SPECIAL_CHARS:jb,REGEX_SPECIAL_CHARS_GLOBAL:Hb}=Vn();Me.isObject=n=>n!==null&&typeof n=="object"&&!Array.isArray(n);Me.hasRegexChars=n=>jb.test(n);Me.isRegexChar=n=>n.length===1&&Me.hasRegexChars(n);Me.escapeRegex=n=>n.replace(Hb,"\\$1");Me.toPosixSlashes=n=>n.replace(Nb,"/");Me.removeBackslashes=n=>n.replace(Fb,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:Db===!0||Lb.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 sd=j((pC,nd)=>{"use strict";var Ju=Gs(),{CHAR_ASTERISK:ho,CHAR_AT:Bb,CHAR_BACKWARD_SLASH:zn,CHAR_COMMA:Ub,CHAR_DOT:mo,CHAR_EXCLAMATION_MARK:go,CHAR_FORWARD_SLASH:td,CHAR_LEFT_CURLY_BRACE:yo,CHAR_LEFT_PARENTHESES:bo,CHAR_LEFT_SQUARE_BRACKET:qb,CHAR_PLUS:Kb,CHAR_QUESTION_MARK:Qu,CHAR_RIGHT_CURLY_BRACE:Gb,CHAR_RIGHT_PARENTHESES:Xu,CHAR_RIGHT_SQUARE_BRACKET:Wb}=Vn(),Zu=n=>n===td||n===zn,ed=n=>{n.isPrefix!==!0&&(n.depth=n.isGlobstar?1/0:1)},Vb=(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,x=!1,A=!1,$=!1,_=!1,y=!1,v=!1,b=0,w,S,T={value:"",depth:0,isGlob:!1},M=()=>u>=s,k=()=>l.charCodeAt(u+1),F=()=>(w=S,l.charCodeAt(++u));for(;u<s;){S=F();let Y;if(S===zn){$=T.backslashes=!0,S=F(),S===yo&&(A=!0);continue}if(A===!0||S===yo){for(b++;M()!==!0&&(S=F());){if(S===zn){$=T.backslashes=!0,F();continue}if(S===yo){b++;continue}if(A!==!0&&S===mo&&(S=F())===mo){if(h=T.isBrace=!0,p=T.isGlob=!0,v=!0,r===!0)continue;break}if(A!==!0&&S===Ub){if(h=T.isBrace=!0,p=T.isGlob=!0,v=!0,r===!0)continue;break}if(S===Gb&&(b--,b===0)){A=!1,h=T.isBrace=!0,v=!0;break}}if(r===!0)continue;break}if(S===td){if(i.push(u),o.push(T),T={value:"",depth:0,isGlob:!1},v===!0)continue;if(w===mo&&u===d+1){d+=2;continue}f=u+1;continue}if(t.noext!==!0&&(S===Kb||S===Bb||S===ho||S===Qu||S===go)===!0&&k()===bo){if(p=T.isGlob=!0,g=T.isExtglob=!0,v=!0,S===go&&u===d&&(y=!0),r===!0){for(;M()!==!0&&(S=F());){if(S===zn){$=T.backslashes=!0,S=F();continue}if(S===Xu){p=T.isGlob=!0,v=!0;break}}continue}break}if(S===ho){if(w===ho&&(x=T.isGlobstar=!0),p=T.isGlob=!0,v=!0,r===!0)continue;break}if(S===Qu){if(p=T.isGlob=!0,v=!0,r===!0)continue;break}if(S===qb){for(;M()!==!0&&(Y=F());){if(Y===zn){$=T.backslashes=!0,F();continue}if(Y===Wb){m=T.isBracket=!0,p=T.isGlob=!0,v=!0;break}}if(r===!0)continue;break}if(t.nonegate!==!0&&S===go&&u===d){_=T.negated=!0,d++;continue}if(t.noparen!==!0&&S===bo){if(p=T.isGlob=!0,r===!0){for(;M()!==!0&&(S=F());){if(S===bo){$=T.backslashes=!0,S=F();continue}if(S===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,V="",C="";d>0&&(V=l.slice(0,d),l=l.slice(d),f-=d),H&&p===!0&&f>0?(H=l.slice(0,f),C=l.slice(f)):p===!0?(H="",C=l):H=l,H&&H!==""&&H!=="/"&&H!==l&&Zu(H.charCodeAt(H.length-1))&&(H=H.slice(0,-1)),t.unescape===!0&&(C&&(C=Ju.removeBackslashes(C)),H&&$===!0&&(H=Ju.removeBackslashes(H)));let E={prefix:V,input:n,start:d,base:H,glob:C,isBrace:h,isBracket:m,isGlob:p,isExtglob:g,isGlobstar:x,negated:_,negatedExtglob:y};if(t.tokens===!0&&(E.maxDepth=0,Zu(S)||o.push(T),E.tokens=o),t.parts===!0||t.tokens===!0){let Y;for(let D=0;D<i.length;D++){let X=Y?Y+1:d,ee=i[D],te=n.slice(X,ee);t.tokens&&(D===0&&d!==0?(o[D].isPrefix=!0,o[D].value=V):o[D].value=te,ed(o[D]),E.maxDepth+=o[D].depth),(D!==0||te!=="")&&a.push(te),Y=ee}if(Y&&Y+1<n.length){let D=n.slice(Y+1);a.push(D),t.tokens&&(o[o.length-1].value=D,ed(o[o.length-1]),E.maxDepth+=o[o.length-1].depth)}E.slashes=i,E.parts=a}return E};nd.exports=Vb});var ld=j((hC,ad)=>{"use strict";var Yn=Vn(),Ce=Gs(),{MAX_LENGTH:Ws,POSIX_REGEX_SOURCE:zb,REGEX_NON_SPECIAL_CHARS:Yb,REGEX_SPECIAL_CHARS_BACKREF:Jb,REPLACEMENTS:rd}=Yn,Qb=(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},vn=(n,e)=>`Missing ${n}: "${e}" - use "\\\\${e}" to match literal characters`,id=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},Xb=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},od=n=>{let e=n.trim(),t=!0;for(;t===!0;)t=!1,/^@\([^\\()[\]{}|]+\)$/.test(e)&&(e=e.slice(2,-1),t=!0);if(Xb(e))return e.replace(/\\(.)/g,"$1")},Zb=n=>{let e=n.map(od).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},vo=(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}}}}},ev=n=>{let e=0,t=[];for(;e<n.length;){let r=vo(n.slice(e),!1);if(!r||r.type!=="*")return;let i=id(r.body).map(a=>a.trim());if(i.length!==1)return;let o=od(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("")}]`}*`},tv=n=>{let e=0,t=n.trim(),s=vo(t);for(;s;)e++,t=s.body.trim(),s=vo(t);return e},nv=(n,e)=>{if(e.maxExtglobRecursion===!1)return{risky:!1};let t=typeof e.maxExtglobRecursion=="number"?e.maxExtglobRecursion:Yn.DEFAULT_MAX_EXTGLOB_RECURSION,s=id(n).map(r=>r.trim());if(s.length>1&&(s.some(r=>r==="")||s.some(r=>/^[*?]+$/.test(r))||Zb(s)))return{risky:!0};for(let r of s){let i=ev(r);if(i)return{risky:!0,safeOutput:i};if(tv(r)>t)return{risky:!0}}return{risky:!1}},wo=(n,e)=>{if(typeof n!="string")throw new TypeError("Expected a string");n=rd[n]||n;let t={...e},s=typeof t.maxLength=="number"?Math.min(Ws,t.maxLength):Ws,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=Yn.globChars(l),d=Yn.extglobChars(u),{DOT_LITERAL:f,PLUS_LITERAL:h,SLASH_LITERAL:m,ONE_CHAR:p,DOTS_SLASH:g,NO_DOT:x,NO_DOT_SLASH:A,NO_DOTS_SLASH:$,QMARK:_,QMARK_NO_DOT:y,STAR:v,START_ANCHOR:b}=u,w=I=>`(${a}(?:(?!${b}${I.dot?g:f}).)*?)`,S=t.dot?"":x,T=t.dot?_:y,M=t.bash===!0?w(t):v;t.capture&&(M=`(${M})`),typeof t.noext=="boolean"&&(t.noextglob=t.noext);let k={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,k),r=n.length;let F=[],H=[],V=[],C=i,E,Y=()=>k.index===r-1,D=k.peek=(I=1)=>n[k.index+I],X=k.advance=()=>n[++k.index]||"",ee=()=>n.slice(k.index+1),te=(I="",Z=0)=>{k.consumed+=I,k.index+=Z},_e=I=>{k.output+=I.output!=null?I.output:I.value,te(I.value)},Q=()=>{let I=1;for(;D()==="!"&&(D(2)!=="("||D(3)==="?");)X(),k.start++,I++;return I%2===0?!1:(k.negated=!0,k.start++,!0)},Ae=I=>{k[I]++,V.push(I)},ve=I=>{k[I]--,V.pop()},q=I=>{if(C.type==="globstar"){let Z=k.braces>0&&(I.type==="comma"||I.type==="brace"),P=I.extglob===!0||F.length&&(I.type==="pipe"||I.type==="paren");I.type!=="slash"&&I.type!=="paren"&&!Z&&!P&&(k.output=k.output.slice(0,-C.output.length),C.type="star",C.value="*",C.output=M,k.output+=C.output)}if(F.length&&I.type!=="paren"&&(F[F.length-1].inner+=I.value),(I.value||I.output)&&_e(I),C&&C.type==="text"&&I.type==="text"){C.value+=I.value,C.output=(C.output||"")+I.value;return}I.prev=C,o.push(I),C=I},ue=(I,Z)=>{let P={...d[Z],conditions:1,inner:""};P.prev=C,P.parens=k.parens,P.output=k.output,P.startIndex=k.index,P.tokensIndex=o.length;let G=(t.capture?"(":"")+P.open;Ae("parens"),q({type:I,value:Z,output:k.output?"":p}),q({type:"paren",extglob:!0,value:X(),output:G}),F.push(P)},Ge=I=>{let Z=n.slice(I.startIndex,k.index+1),P=n.slice(I.startIndex+2,k.index),G=nv(P,t);if((I.type==="plus"||I.type==="star")&&G.risky){let ie=G.safeOutput?(I.output?"":p)+(t.capture?`(${G.safeOutput})`:G.safeOutput):void 0,Oe=o[I.tokensIndex];Oe.type="text",Oe.value=Z,Oe.output=ie||Ce.escapeRegex(Z);for(let We=I.tokensIndex+1;We<o.length;We++)o[We].value="",o[We].output="",delete o[We].suffix;k.output=I.output+Oe.output,k.backtrack=!0,q({type:"paren",extglob:!0,value:E,output:""}),ve("parens");return}let ne=I.close+(t.capture?")":""),pe;if(I.type==="negate"){let ie=M;if(I.inner&&I.inner.length>1&&I.inner.includes("/")&&(ie=w(t)),(ie!==M||Y()||/^\)+$/.test(ee()))&&(ne=I.close=`)$))${ie}`),I.inner.includes("*")&&(pe=ee())&&/^\.[^\\/.]+$/.test(pe)){let Oe=wo(pe,{...e,fastpaths:!1}).output;ne=I.close=`)${Oe})${ie})`}I.prev.type==="bos"&&(k.negatedExtglob=!0)}q({type:"paren",extglob:!0,value:E,output:ne}),ve("parens")};if(t.fastpaths!==!1&&!/(^[*!]|[/()[\]{}"])/.test(n)){let I=!1,Z=n.replace(Jb,(P,G,ne,pe,ie,Oe)=>pe==="\\"?(I=!0,P):pe==="?"?G?G+pe+(ie?_.repeat(ie.length):""):Oe===0?T+(ie?_.repeat(ie.length):""):_.repeat(ne.length):pe==="."?f.repeat(ne.length):pe==="*"?G?G+pe+(ie?M:""):M:G?P:`\\${P}`);return I===!0&&(t.unescape===!0?Z=Z.replace(/\\/g,""):Z=Z.replace(/\\+/g,P=>P.length%2===0?"\\\\":P?"\\":"")),Z===n&&t.contains===!0?(k.output=n,k):(k.output=Ce.wrapOutput(Z,k,e),k)}for(;!Y();){if(E=X(),E==="\0")continue;if(E==="\\"){let P=D();if(P==="/"&&t.bash!==!0||P==="."||P===";")continue;if(!P){E+="\\",q({type:"text",value:E});continue}let G=/^\\+/.exec(ee()),ne=0;if(G&&G[0].length>2&&(ne=G[0].length,k.index+=ne,ne%2!==0&&(E+="\\")),t.unescape===!0?E=X():E+=X(),k.brackets===0){q({type:"text",value:E});continue}}if(k.brackets>0&&(E!=="]"||C.value==="["||C.value==="[^")){if(t.posix!==!1&&E===":"){let P=C.value.slice(1);if(P.includes("[")&&(C.posix=!0,P.includes(":"))){let G=C.value.lastIndexOf("["),ne=C.value.slice(0,G),pe=C.value.slice(G+2),ie=zb[pe];if(ie){C.value=ne+ie,k.backtrack=!0,X(),!i.output&&o.indexOf(C)===1&&(i.output=p);continue}}}(E==="["&&D()!==":"||E==="-"&&D()==="]")&&(E=`\\${E}`),E==="]"&&(C.value==="["||C.value==="[^")&&(E=`\\${E}`),t.posix===!0&&E==="!"&&C.value==="["&&(E="^"),C.value+=E,_e({value:E});continue}if(k.quotes===1&&E!=='"'){E=Ce.escapeRegex(E),C.value+=E,_e({value:E});continue}if(E==='"'){k.quotes=k.quotes===1?0:1,t.keepQuotes===!0&&q({type:"text",value:E});continue}if(E==="("){Ae("parens"),q({type:"paren",value:E});continue}if(E===")"){if(k.parens===0&&t.strictBrackets===!0)throw new SyntaxError(vn("opening","("));let P=F[F.length-1];if(P&&k.parens===P.parens+1){Ge(F.pop());continue}q({type:"paren",value:E,output:k.parens?")":"\\)"}),ve("parens");continue}if(E==="["){if(t.nobracket===!0||!ee().includes("]")){if(t.nobracket!==!0&&t.strictBrackets===!0)throw new SyntaxError(vn("closing","]"));E=`\\${E}`}else Ae("brackets");q({type:"bracket",value:E});continue}if(E==="]"){if(t.nobracket===!0||C&&C.type==="bracket"&&C.value.length===1){q({type:"text",value:E,output:`\\${E}`});continue}if(k.brackets===0){if(t.strictBrackets===!0)throw new SyntaxError(vn("opening","["));q({type:"text",value:E,output:`\\${E}`});continue}ve("brackets");let P=C.value.slice(1);if(C.posix!==!0&&P[0]==="^"&&!P.includes("/")&&(E=`/${E}`),C.value+=E,_e({value:E}),t.literalBrackets===!1||Ce.hasRegexChars(P))continue;let G=Ce.escapeRegex(C.value);if(k.output=k.output.slice(0,-C.value.length),t.literalBrackets===!0){k.output+=G,C.value=G;continue}C.value=`(${a}${G}|${C.value})`,k.output+=C.value;continue}if(E==="{"&&t.nobrace!==!0){Ae("braces");let P={type:"brace",value:E,output:"(",outputIndex:k.output.length,tokensIndex:k.tokens.length};H.push(P),q(P);continue}if(E==="}"){let P=H[H.length-1];if(t.nobrace===!0||!P){q({type:"text",value:E,output:E});continue}let G=")";if(P.dots===!0){let ne=o.slice(),pe=[];for(let ie=ne.length-1;ie>=0&&(o.pop(),ne[ie].type!=="brace");ie--)ne[ie].type!=="dots"&&pe.unshift(ne[ie].value);G=Qb(pe,t),k.backtrack=!0}if(P.comma!==!0&&P.dots!==!0){let ne=k.output.slice(0,P.outputIndex),pe=k.tokens.slice(P.tokensIndex);P.value=P.output="\\{",E=G="\\}",k.output=ne;for(let ie of pe)k.output+=ie.output||ie.value}q({type:"brace",value:E,output:G}),ve("braces"),H.pop();continue}if(E==="|"){F.length>0&&F[F.length-1].conditions++,q({type:"text",value:E});continue}if(E===","){let P=E,G=H[H.length-1];G&&V[V.length-1]==="braces"&&(G.comma=!0,P="|"),q({type:"comma",value:E,output:P});continue}if(E==="/"){if(C.type==="dot"&&k.index===k.start+1){k.start=k.index+1,k.consumed="",k.output="",o.pop(),C=i;continue}q({type:"slash",value:E,output:m});continue}if(E==="."){if(k.braces>0&&C.type==="dot"){C.value==="."&&(C.output=f);let P=H[H.length-1];C.type="dots",C.output+=E,C.value+=E,P.dots=!0;continue}if(k.braces+k.parens===0&&C.type!=="bos"&&C.type!=="slash"){q({type:"text",value:E,output:f});continue}q({type:"dot",value:E,output:f});continue}if(E==="?"){if(!(C&&C.value==="(")&&t.noextglob!==!0&&D()==="("&&D(2)!=="?"){ue("qmark",E);continue}if(C&&C.type==="paren"){let G=D(),ne=E;if(G==="<"&&!Ce.supportsLookbehinds())throw new Error("Node.js v10 or higher is required for regex lookbehinds");(C.value==="("&&!/[!=<:]/.test(G)||G==="<"&&!/<([!=]|\w+>)/.test(ee()))&&(ne=`\\${E}`),q({type:"text",value:E,output:ne});continue}if(t.dot!==!0&&(C.type==="slash"||C.type==="bos")){q({type:"qmark",value:E,output:y});continue}q({type:"qmark",value:E,output:_});continue}if(E==="!"){if(t.noextglob!==!0&&D()==="("&&(D(2)!=="?"||!/[!=<:]/.test(D(3)))){ue("negate",E);continue}if(t.nonegate!==!0&&k.index===0){Q();continue}}if(E==="+"){if(t.noextglob!==!0&&D()==="("&&D(2)!=="?"){ue("plus",E);continue}if(C&&C.value==="("||t.regex===!1){q({type:"plus",value:E,output:h});continue}if(C&&(C.type==="bracket"||C.type==="paren"||C.type==="brace")||k.parens>0){q({type:"plus",value:E});continue}q({type:"plus",value:h});continue}if(E==="@"){if(t.noextglob!==!0&&D()==="("&&D(2)!=="?"){q({type:"at",extglob:!0,value:E,output:""});continue}q({type:"text",value:E});continue}if(E!=="*"){(E==="$"||E==="^")&&(E=`\\${E}`);let P=Yb.exec(ee());P&&(E+=P[0],k.index+=P[0].length),q({type:"text",value:E});continue}if(C&&(C.type==="globstar"||C.star===!0)){C.type="star",C.star=!0,C.value+=E,C.output=M,k.backtrack=!0,k.globstar=!0,te(E);continue}let I=ee();if(t.noextglob!==!0&&/^\([^?]/.test(I)){ue("star",E);continue}if(C.type==="star"){if(t.noglobstar===!0){te(E);continue}let P=C.prev,G=P.prev,ne=P.type==="slash"||P.type==="bos",pe=G&&(G.type==="star"||G.type==="globstar");if(t.bash===!0&&(!ne||I[0]&&I[0]!=="/")){q({type:"star",value:E,output:""});continue}let ie=k.braces>0&&(P.type==="comma"||P.type==="brace"),Oe=F.length&&(P.type==="pipe"||P.type==="paren");if(!ne&&P.type!=="paren"&&!ie&&!Oe){q({type:"star",value:E,output:""});continue}for(;I.slice(0,3)==="/**";){let We=n[k.index+4];if(We&&We!=="/")break;I=I.slice(3),te("/**",3)}if(P.type==="bos"&&Y()){C.type="globstar",C.value+=E,C.output=w(t),k.output=C.output,k.globstar=!0,te(E);continue}if(P.type==="slash"&&P.prev.type!=="bos"&&!pe&&Y()){k.output=k.output.slice(0,-(P.output+C.output).length),P.output=`(?:${P.output}`,C.type="globstar",C.output=w(t)+(t.strictSlashes?")":"|$)"),C.value+=E,k.globstar=!0,k.output+=P.output+C.output,te(E);continue}if(P.type==="slash"&&P.prev.type!=="bos"&&I[0]==="/"){let We=I[1]!==void 0?"|$":"";k.output=k.output.slice(0,-(P.output+C.output).length),P.output=`(?:${P.output}`,C.type="globstar",C.output=`${w(t)}${m}|${m}${We})`,C.value+=E,k.output+=P.output+C.output,k.globstar=!0,te(E+X()),q({type:"slash",value:"/",output:""});continue}if(P.type==="bos"&&I[0]==="/"){C.type="globstar",C.value+=E,C.output=`(?:^|${m}|${w(t)}${m})`,k.output=C.output,k.globstar=!0,te(E+X()),q({type:"slash",value:"/",output:""});continue}k.output=k.output.slice(0,-C.output.length),C.type="globstar",C.output=w(t),C.value+=E,k.output+=C.output,k.globstar=!0,te(E);continue}let Z={type:"star",value:E,output:M};if(t.bash===!0){Z.output=".*?",(C.type==="bos"||C.type==="slash")&&(Z.output=S+Z.output),q(Z);continue}if(C&&(C.type==="bracket"||C.type==="paren")&&t.regex===!0){Z.output=E,q(Z);continue}(k.index===k.start||C.type==="slash"||C.type==="dot")&&(C.type==="dot"?(k.output+=A,C.output+=A):t.dot===!0?(k.output+=$,C.output+=$):(k.output+=S,C.output+=S),D()!=="*"&&(k.output+=p,C.output+=p)),q(Z)}for(;k.brackets>0;){if(t.strictBrackets===!0)throw new SyntaxError(vn("closing","]"));k.output=Ce.escapeLast(k.output,"["),ve("brackets")}for(;k.parens>0;){if(t.strictBrackets===!0)throw new SyntaxError(vn("closing",")"));k.output=Ce.escapeLast(k.output,"("),ve("parens")}for(;k.braces>0;){if(t.strictBrackets===!0)throw new SyntaxError(vn("closing","}"));k.output=Ce.escapeLast(k.output,"{"),ve("braces")}if(t.strictSlashes!==!0&&(C.type==="star"||C.type==="bracket")&&q({type:"maybe_slash",value:"",output:`${m}?`}),k.backtrack===!0){k.output="";for(let I of k.tokens)k.output+=I.output!=null?I.output:I.value,I.suffix&&(k.output+=I.suffix)}return k};wo.fastpaths=(n,e)=>{let t={...e},s=typeof t.maxLength=="number"?Math.min(Ws,t.maxLength):Ws,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);n=rd[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}=Yn.globChars(i),g=t.dot?f:d,x=t.dot?h:d,A=t.capture?"":"?:",$={negated:!1,prefix:""},_=t.bash===!0?".*?":m;t.capture&&(_=`(${_})`);let y=S=>S.noglobstar===!0?_:`(${A}(?:(?!${p}${S.dot?u:o}).)*?)`,v=S=>{switch(S){case"*":return`${g}${l}${_}`;case".*":return`${o}${l}${_}`;case"*.*":return`${g}${_}${o}${l}${_}`;case"*/*":return`${g}${_}${a}${l}${x}${_}`;case"**":return g+y(t);case"**/*":return`(?:${g}${y(t)}${a})?${x}${l}${_}`;case"**/*.*":return`(?:${g}${y(t)}${a})?${x}${_}${o}${l}${_}`;case"**/.*":return`(?:${g}${y(t)}${a})?${o}${l}${_}`;default:{let T=/^(.*?)\.(\w+)$/.exec(S);if(!T)return;let M=v(T[1]);return M?M+o+T[2]:void 0}}},b=Ce.removePrefix(n,$),w=v(b);return w&&t.strictSlashes!==!0&&(w+=`${a}?`),w};ad.exports=wo});var ud=j((mC,cd)=>{"use strict";var sv=require("path"),rv=sd(),xo=ld(),So=Gs(),iv=Vn(),ov=n=>n&&typeof n=="object"&&!Array.isArray(n),ge=(n,e,t=!1)=>{if(Array.isArray(n)){let d=n.map(h=>ge(h,e,t));return h=>{for(let m of d){let p=m(h);if(p)return p}return!1}}let s=ov(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=So.isWindows(e),o=s?ge.compileRe(n,e):ge.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=ge(r.ignore,d,t)}let u=(d,f=!1)=>{let{isMatch:h,match:m,output:p}=ge.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};ge.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?So.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=ge.matchBase(n,e,t,r):a=e.exec(l)),{isMatch:!!a,match:a,output:l}};ge.matchBase=(n,e,t,s=So.isWindows(t))=>(e instanceof RegExp?e:ge.makeRe(e,t)).test(sv.basename(n));ge.isMatch=(n,e,t)=>ge(e,t)(n);ge.parse=(n,e)=>Array.isArray(n)?n.map(t=>ge.parse(t,e)):xo(n,{...e,fastpaths:!1});ge.scan=(n,e)=>rv(n,e);ge.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=ge.toRegex(a,e);return s===!0&&(l.state=n),l};ge.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=xo.fastpaths(n,e)),r.output||(r=xo(n,e)),ge.compileRe(r,e,t,s)};ge.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/$^/}};ge.constants=iv;cd.exports=ge});var _o=j((gC,dd)=>{"use strict";dd.exports=ud()});var vd=j((yC,bd)=>{"use strict";var Qn=require("fs"),{Readable:av}=require("stream"),Jn=require("path"),{promisify:Js}=require("util"),Ao=_o(),lv=Js(Qn.readdir),cv=Js(Qn.stat),fd=Js(Qn.lstat),uv=Js(Qn.realpath),dv="!",gd="READDIRP_RECURSIVE_ERROR",fv=new Set(["ENOENT","EPERM","EACCES","ELOOP",gd]),ko="files",yd="directories",zs="files_directories",Vs="all",pd=[ko,yd,zs,Vs],pv=n=>fv.has(n.code),[hd,hv]=process.versions.node.split(".").slice(0,2).map(n=>Number.parseInt(n,10)),mv=process.platform==="win32"&&(hd>10||hd===10&&hv>=5),md=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)===dv?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))}}},Ys=class n extends av{static get defaultOptions(){return{root:".",fileFilter:e=>!0,directoryFilter:e=>!0,type:ko,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=md(t.fileFilter),this._directoryFilter=md(t.directoryFilter);let i=t.lstat?fd:cv;mv?this._stat=o=>i(o,{bigint:!0}):this._stat=i,this._maxDepth=t.depth,this._wantsDir=[yd,zs,Vs].includes(r),this._wantsFile=[ko,zs,Vs].includes(r),this._wantsEverything=r===Vs,this._root=Jn.resolve(s),this._isDirent="Dirent"in Qn&&!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 lv(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=Jn.resolve(Jn.join(t,r));s={path:Jn.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){pv(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 uv(s),i=await fd(r);if(i.isFile())return"file";if(i.isDirectory()){let o=r.length;if(s.startsWith(r)&&s.substr(o,1)===Jn.sep){let a=new Error(`Circular symlink detected: "${s}" points to "${r}"`);return a.code=gd,this._onError(a)}return"directory"}}catch(r){this._onError(r)}}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}},wn=(n,e={})=>{let t=e.entryType||e.type;if(t==="both"&&(t=zs),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&&!pd.includes(t))throw new Error(`readdirp: Invalid type passed. Use one of ${pd.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return e.root=n,new Ys(e)},gv=(n,e={})=>new Promise((t,s)=>{let r=[];wn(n,e).on("data",i=>r.push(i)).on("end",()=>t(r)).on("error",i=>s(i))});wn.promise=gv;wn.ReaddirpStream=Ys;wn.default=wn;bd.exports=wn});var $o=j((bC,wd)=>{wd.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 $d=j((Ad,kd)=>{"use strict";Object.defineProperty(Ad,"__esModule",{value:!0});var _d=_o(),yv=$o(),xd="!",bv={returnIndex:!1},vv=n=>Array.isArray(n)?n:[n],wv=(n,e)=>{if(typeof n=="function")return n;if(typeof n=="string"){let t=_d(n,e);return s=>n===s||t(s)}return n instanceof RegExp?t=>n.test(t):t=>!1},Sd=(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=yv(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},Eo=(n,e,t=bv)=>{if(n==null)throw new TypeError("anymatch: specify first argument");let s=typeof t=="boolean"?{returnIndex:t}:t,r=s.returnIndex||!1,i=vv(n),o=i.filter(l=>typeof l=="string"&&l.charAt(0)===xd).map(l=>l.slice(1)).map(l=>_d(l,s)),a=i.filter(l=>typeof l!="string"||typeof l=="string"&&l.charAt(0)!==xd).map(l=>wv(l,s));return e==null?(l,u=!1)=>Sd(a,o,l,typeof u=="boolean"?u:!1):Sd(a,o,e,r)};Eo.default=Eo;kd.exports=Eo});var Cd=j((vC,Ed)=>{Ed.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 Co=j((wC,Rd)=>{var xv=Cd(),Td={"{":"}","(":")","[":"]"},Sv=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},_v=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};Rd.exports=function(e,t){if(typeof e!="string"||e==="")return!1;if(xv(e))return!0;var s=Sv;return t&&t.strict===!1&&(s=_v),s(e)}});var Pd=j((xC,Od)=>{"use strict";var Av=Co(),kv=require("path").posix.dirname,$v=require("os").platform()==="win32",To="/",Ev=/\\/g,Cv=/[\{\[].*[\}\]]$/,Tv=/(^|[^\\])([\{\[]|\([^\)]+$)/,Rv=/\\([\!\*\?\|\[\]\(\)\{\}])/g;Od.exports=function(e,t){var s=Object.assign({flipBackslashes:!0},t);s.flipBackslashes&&$v&&e.indexOf(To)<0&&(e=e.replace(Ev,To)),Cv.test(e)&&(e+=To),e+="a";do e=kv(e);while(Av(e)||Tv.test(e));return e.replace(Rv,"$1")}});var Qs=j(Ye=>{"use strict";Ye.isInteger=n=>typeof n=="number"?Number.isInteger(n):typeof n=="string"&&n.trim()!==""?Number.isInteger(Number(n)):!1;Ye.find=(n,e)=>n.nodes.find(t=>t.type===e);Ye.exceedsLimit=(n,e,t=1,s)=>s===!1||!Ye.isInteger(n)||!Ye.isInteger(e)?!1:(Number(e)-Number(n))/Number(t)>=s;Ye.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)};Ye.encloseBrace=n=>n.type!=="brace"?!1:n.commas>>0+n.ranges>>0===0?(n.invalid=!0,!0):!1;Ye.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;Ye.isOpenOrClose=n=>n.type==="open"||n.type==="close"?!0:n.open===!0||n.close===!0;Ye.reduce=n=>n.reduce((e,t)=>(t.type==="text"&&e.push(t.value),t.type==="range"&&(t.type="text"),e),[]);Ye.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 Xs=j((_C,Md)=>{"use strict";var Id=Qs();Md.exports=(n,e={})=>{let t=(s,r={})=>{let i=e.escapeInvalid&&Id.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a="";if(s.value)return(i||o)&&Id.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=j((AC,Ld)=>{"use strict";Ld.exports=function(n){return typeof n=="number"?n-n===0:typeof n=="string"&&n.trim()!==""?Number.isFinite?Number.isFinite(+n):isFinite(+n):!1}});var Gd=j((kC,Kd)=>{"use strict";var Nd=Dd(),Yt=(n,e,t)=>{if(Nd(n)===!1)throw new TypeError("toRegexRange: expected the first argument to be a number");if(e===void 0||n===e)return String(n);if(Nd(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(Yt.cache.hasOwnProperty(l))return Yt.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=qd(n)||qd(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=Ov(p,m,s),s.capture===!0?h.result=`(${h.result})`:s.wrap!==!1&&m.length+p.length>1&&(h.result=`(?:${h.result})`),Yt.cache[l]=h,h.result};function Ov(n,e,t){let s=Ro(n,e,"-",!1,t)||[],r=Ro(e,n,"",!1,t)||[],i=Ro(n,e,"-?",!0,t)||[];return s.concat(i).concat(r).join("|")}function Pv(n,e){let t=1,s=1,r=Hd(n,t),i=new Set([e]);for(;n<=r&&r<=e;)i.add(r),t+=1,r=Hd(n,t);for(r=Bd(e+1,s)-1;n<r&&r<=e;)i.add(r),s+=1,r=Bd(e+1,s)-1;return i=[...i],i.sort(Lv),i}function Iv(n,e,t){if(n===e)return{pattern:n,count:[],digits:0};let s=Mv(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+=Dv(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=Pv(n,e),i=[],o=n,a;for(let l=0;l<r.length;l++){let u=r[l],d=Iv(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+Ud(a.count),o=u+1;continue}t.isPadded&&(f=Nv(u,t,s)),d.string=f+d.pattern+Ud(d.count),i.push(d),o=u+1,a=d}return i}function Ro(n,e,t,s,r){let i=[];for(let o of n){let{string:a}=o;!s&&!jd(e,"string",a)&&i.push(t+a),s&&jd(e,"string",a)&&i.push(t+a)}return i}function Mv(n,e){let t=[];for(let s=0;s<n.length;s++)t.push([n[s],e[s]]);return t}function Lv(n,e){return n>e?1:e>n?-1:0}function jd(n,e,t){return n.some(s=>s[e]===t)}function Hd(n,e){return Number(String(n).slice(0,-e)+"9".repeat(e))}function Bd(n,e){return n-n%Math.pow(10,e)}function Ud(n){let[e=0,t=""]=n;return t||e>1?`{${e+(t?","+t:"")}}`:""}function Dv(n,e,t){return`[${n}${e-n===1?"":"-"}${e}]`}function qd(n){return/^-?(0+)\d/.test(n)}function Nv(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}}`}}Yt.cache={};Yt.clearCache=()=>Yt.cache={};Kd.exports=Yt});var Io=j(($C,Xd)=>{"use strict";var Fv=require("util"),Vd=Gd(),Wd=n=>n!==null&&typeof n=="object"&&!Array.isArray(n),jv=n=>e=>n===!0?Number(e):String(e),Oo=n=>typeof n=="number"||typeof n=="string"&&n!=="",Xn=n=>Number.isInteger(+n),Po=n=>{let e=`${n}`,t=-1;if(e[0]==="-"&&(e=e.slice(1)),e==="0")return!1;for(;e[++t]==="0";);return t>0},Hv=(n,e,t)=>typeof n=="string"||typeof e=="string"?!0:t.stringify===!0,Bv=(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},er=(n,e)=>{let t=n[0]==="-"?"-":"";for(t&&(n=n.slice(1),e--);n.length<e;)n="0"+n;return t?"-"+n:n},Uv=(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=>er(String(a),t)).join("|")),n.negatives.length&&(i=`-(${s}${n.negatives.map(a=>er(String(a),t)).join("|")})`),r&&i?o=`${r}|${i}`:o=r||i,e.wrap?`(${s}${o})`:o},zd=(n,e,t,s)=>{if(t)return Vd(n,e,{wrap:!1,...s});let r=String.fromCharCode(n);if(n===e)return r;let i=String.fromCharCode(e);return`[${r}-${i}]`},Yd=(n,e,t)=>{if(Array.isArray(n)){let s=t.wrap===!0,r=t.capture?"":"?:";return s?`(${r}${n.join("|")})`:n.join("|")}return Vd(n,e,t)},Jd=(...n)=>new RangeError("Invalid range arguments: "+Fv.inspect(...n)),Qd=(n,e,t)=>{if(t.strictRanges===!0)throw Jd([n,e]);return[]},qv=(n,e)=>{if(e.strictRanges===!0)throw new TypeError(`Expected step "${n}" to be a number`);return[]},Kv=(n,e,t=1,s={})=>{let r=Number(n),i=Number(e);if(!Number.isInteger(r)||!Number.isInteger(i)){if(s.strictRanges===!0)throw Jd([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=Po(a)||Po(l)||Po(u),f=d?Math.max(a.length,l.length,u.length):0,h=d===!1&&Hv(n,e,s)===!1,m=s.transform||jv(h);if(s.toRegex&&t===1)return zd(er(n,f),er(e,f),!0,s);let p={negatives:[],positives:[]},g=$=>p[$<0?"negatives":"positives"].push(Math.abs($)),x=[],A=0;for(;o?r>=i:r<=i;)s.toRegex===!0&&t>1?g(r):x.push(Bv(m(r,A),f,h)),r=o?r-t:r+t,A++;return s.toRegex===!0?t>1?Uv(p,s,f):Yd(x,null,{wrap:!1,...s}):x},Gv=(n,e,t=1,s={})=>{if(!Xn(n)&&n.length>1||!Xn(e)&&e.length>1)return Qd(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 zd(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?Yd(d,null,{wrap:!1,options:s}):d},Zs=(n,e,t,s={})=>{if(e==null&&Oo(n))return[n];if(!Oo(n)||!Oo(e))return Qd(n,e,s);if(typeof t=="function")return Zs(n,e,1,{transform:t});if(Wd(t))return Zs(n,e,0,t);let r={...s};return r.capture===!0&&(r.wrap=!0),t=t||r.step||1,Xn(t)?Xn(n)&&Xn(e)?Kv(n,e,t,r):Gv(n,e,Math.max(Math.abs(t),1),r):t!=null&&!Wd(t)?qv(t,r):Zs(n,e,1,t)};Xd.exports=Zs});var tf=j((EC,ef)=>{"use strict";var Wv=Io(),Zd=Qs(),Vv=(n,e={})=>{let t=(s,r={})=>{let i=Zd.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=Zd.reduce(s.nodes),f=Wv(...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)};ef.exports=Vv});var rf=j((CC,sf)=>{"use strict";var zv=Io(),nf=Xs(),xn=Qs(),Jt=(n="",e="",t=!1)=>{let s=[];if(n=[].concat(n),e=[].concat(e),!e.length)return n;if(!n.length)return t?xn.flatten(e).map(r=>`{${r}}`):e;for(let r of n)if(Array.isArray(r))for(let i of r)s.push(Jt(i,e,t));else for(let i of e)t===!0&&typeof i=="string"&&(i=`{${i}}`),s.push(Array.isArray(i)?Jt(r,i,t):r+i);return xn.flatten(s)},Yv=(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(Jt(a.pop(),nf(r,e)));return}if(r.type==="brace"&&r.invalid!==!0&&r.nodes.length===2){a.push(Jt(a.pop(),["{}"]));return}if(r.nodes&&r.ranges>0){let f=xn.reduce(r.nodes);if(xn.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=zv(...f,e);h.length===0&&(h=nf(r,e)),a.push(Jt(a.pop(),h)),r.nodes=[];return}let l=xn.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(Jt(a.pop(),u,l));continue}if(h.value&&h.type!=="open"){u.push(Jt(u.pop(),h.value));continue}h.nodes&&s(h,r)}return u};return xn.flatten(s(n))};sf.exports=Yv});var af=j((TC,of)=>{"use strict";of.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:`
325
+ `,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 ff=j((RC,df)=>{"use strict";var Jv=Xs(),{MAX_LENGTH:lf,CHAR_BACKSLASH:Mo,CHAR_BACKTICK:Qv,CHAR_COMMA:Xv,CHAR_DOT:Zv,CHAR_LEFT_PARENTHESES:ew,CHAR_RIGHT_PARENTHESES:tw,CHAR_LEFT_CURLY_BRACE:nw,CHAR_RIGHT_CURLY_BRACE:sw,CHAR_LEFT_SQUARE_BRACKET:cf,CHAR_RIGHT_SQUARE_BRACKET:uf,CHAR_DOUBLE_QUOTE:rw,CHAR_SINGLE_QUOTE:iw,CHAR_NO_BREAK_SPACE:ow,CHAR_ZERO_WIDTH_NOBREAK_SPACE:aw}=af(),lw=(n,e={})=>{if(typeof n!="string")throw new TypeError("Expected a string");let t=e||{},s=typeof t.maxLength=="number"?Math.min(lf,t.maxLength):lf;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===aw||h===ow)){if(h===Mo){p({type:"text",value:(e.keepEscaping?h:"")+m()});continue}if(h===uf){p({type:"text",value:"\\"+h});continue}if(h===cf){l++;let g;for(;d<u&&(g=m());){if(h+=g,g===cf){l++;continue}if(g===Mo){h+=m();continue}if(g===uf&&(l--,l===0))break}p({type:"text",value:h});continue}if(h===ew){o=p({type:"paren",nodes:[]}),i.push(o),p({type:"text",value:h});continue}if(h===tw){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===rw||h===iw||h===Qv){let g=h,x;for(e.keepQuotes!==!0&&(h="");d<u&&(x=m());){if(x===Mo){h+=x+m();continue}if(x===g){e.keepQuotes===!0&&(h+=x);break}h+=x}p({type:"text",value:h});continue}if(h===nw){f++;let x={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(x),i.push(o),p({type:"open",value:h});continue}if(h===sw){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===Xv&&f>0){if(o.ranges>0){o.ranges=0;let g=o.nodes.shift();o.nodes=[g,{type:"text",value:Jv(o)}]}p({type:"comma",value:h}),o.commas++;continue}if(h===Zv&&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 x=g[g.length-1];x.value+=a.value+h,a=x,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(A=>{A.nodes||(A.type==="open"&&(A.isOpen=!0),A.type==="close"&&(A.isClose=!0),A.nodes||(A.type="text"),A.invalid=!0)});let g=i[i.length-1],x=g.nodes.indexOf(o);g.nodes.splice(x,1,...o.nodes)}while(i.length>0);return p({type:"eos"}),r};df.exports=lw});var mf=j((OC,hf)=>{"use strict";var pf=Xs(),cw=tf(),uw=rf(),dw=ff(),Ue=(n,e={})=>{let t=[];if(Array.isArray(n))for(let s of n){let r=Ue.create(s,e);Array.isArray(r)?t.push(...r):t.push(r)}else t=[].concat(Ue.create(n,e));return e&&e.expand===!0&&e.nodupes===!0&&(t=[...new Set(t)]),t};Ue.parse=(n,e={})=>dw(n,e);Ue.stringify=(n,e={})=>pf(typeof n=="string"?Ue.parse(n,e):n,e);Ue.compile=(n,e={})=>(typeof n=="string"&&(n=Ue.parse(n,e)),cw(n,e));Ue.expand=(n,e={})=>{typeof n=="string"&&(n=Ue.parse(n,e));let t=uw(n,e);return e.noempty===!0&&(t=t.filter(Boolean)),e.nodupes===!0&&(t=[...new Set(t)]),t};Ue.create=(n,e={})=>n===""||n.length<3?[n]:e.expand!==!0?Ue.compile(n,e):Ue.expand(n,e);hf.exports=Ue});var gf=j((PC,fw)=>{fw.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 bf=j((IC,yf)=>{yf.exports=gf()});var wf=j((MC,vf)=>{"use strict";var pw=require("path"),hw=bf(),mw=new Set(hw);vf.exports=n=>mw.has(pw.extname(n).slice(1).toLowerCase())});var tr=j(U=>{"use strict";var{sep:gw}=require("path"),{platform:Lo}=process,yw=require("os");U.EV_ALL="all";U.EV_READY="ready";U.EV_ADD="add";U.EV_CHANGE="change";U.EV_ADD_DIR="addDir";U.EV_UNLINK="unlink";U.EV_UNLINK_DIR="unlinkDir";U.EV_RAW="raw";U.EV_ERROR="error";U.STR_DATA="data";U.STR_END="end";U.STR_CLOSE="close";U.FSEVENT_CREATED="created";U.FSEVENT_MODIFIED="modified";U.FSEVENT_DELETED="deleted";U.FSEVENT_MOVED="moved";U.FSEVENT_CLONED="cloned";U.FSEVENT_UNKNOWN="unknown";U.FSEVENT_FLAG_MUST_SCAN_SUBDIRS=1;U.FSEVENT_TYPE_FILE="file";U.FSEVENT_TYPE_DIRECTORY="directory";U.FSEVENT_TYPE_SYMLINK="symlink";U.KEY_LISTENERS="listeners";U.KEY_ERR="errHandlers";U.KEY_RAW="rawEmitters";U.HANDLER_KEYS=[U.KEY_LISTENERS,U.KEY_ERR,U.KEY_RAW];U.DOT_SLASH=`.${gw}`;U.BACK_SLASH_RE=/\\/g;U.DOUBLE_SLASH_RE=/\/\//;U.SLASH_OR_BACK_SLASH_RE=/[/\\]/;U.DOT_RE=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/;U.REPLACER_RE=/^\.[/\\]/;U.SLASH="/";U.SLASH_SLASH="//";U.BRACE_START="{";U.BANG="!";U.ONE_DOT=".";U.TWO_DOTS="..";U.STAR="*";U.GLOBSTAR="**";U.ROOT_GLOBSTAR="/**/*";U.SLASH_GLOBSTAR="/**";U.DIR_SUFFIX="Dir";U.ANYMATCH_OPTS={dot:!0};U.STRING_TYPE="string";U.FUNCTION_TYPE="function";U.EMPTY_STR="";U.EMPTY_FN=()=>{};U.IDENTITY_FN=n=>n;U.isWindows=Lo==="win32";U.isMacos=Lo==="darwin";U.isLinux=Lo==="linux";U.isIBMi=yw.type()==="OS400"});var $f=j((DC,kf)=>{"use strict";var Rt=require("fs"),xe=require("path"),{promisify:ns}=require("util"),bw=wf(),{isWindows:vw,isLinux:ww,EMPTY_FN:xw,EMPTY_STR:Sw,KEY_LISTENERS:Sn,KEY_ERR:Do,KEY_RAW:Zn,HANDLER_KEYS:_w,EV_CHANGE:sr,EV_ADD:nr,EV_ADD_DIR:Aw,EV_ERROR:Sf,STR_DATA:kw,STR_END:$w,BRACE_START:Ew,STAR:Cw}=tr(),Tw="watch",Rw=ns(Rt.open),_f=ns(Rt.stat),Ow=ns(Rt.lstat),Pw=ns(Rt.close),No=ns(Rt.realpath),Iw={lstat:Ow,stat:_f},jo=(n,e)=>{n instanceof Set?n.forEach(e):e(n)},es=(n,e,t)=>{let s=n[e];s instanceof Set||(n[e]=s=new Set([s])),s.add(t)},Mw=n=>e=>{let t=n[e];t instanceof Set?t.clear():delete n[e]},ts=(n,e,t)=>{let s=n[e];s instanceof Set?s.delete(t):s===t&&delete n[e]},Af=n=>n instanceof Set?n.size===0:!n,rr=new Map;function xf(n,e,t,s,r){let i=(o,a)=>{t(n),r(o,a,{watchedPath:n}),a&&n!==a&&ir(xe.resolve(n,a),Sn,xe.join(n,a))};try{return Rt.watch(n,e,i)}catch(o){s(o)}}var ir=(n,e,t,s,r)=>{let i=rr.get(n);i&&jo(i[e],o=>{o(t,s,r)})},Lw=(n,e,t,s)=>{let{listener:r,errHandler:i,rawEmitter:o}=s,a=rr.get(e),l;if(!t.persistent)return l=xf(n,t,r,i,o),l.close.bind(l);if(a)es(a,Sn,r),es(a,Do,i),es(a,Zn,o);else{if(l=xf(n,t,ir.bind(null,e,Sn),i,ir.bind(null,e,Zn)),!l)return;l.on(Sf,async u=>{let d=ir.bind(null,e,Do);if(a.watcherUnusable=!0,vw&&u.code==="EPERM")try{let f=await Rw(n,"r");await Pw(f),d(u)}catch{}else d(u)}),a={listeners:r,errHandlers:i,rawEmitters:o,watcher:l},rr.set(e,a)}return()=>{ts(a,Sn,r),ts(a,Do,i),ts(a,Zn,o),Af(a.listeners)&&(a.watcher.close(),rr.delete(e),_w.forEach(Mw(a)),a.watcher=void 0,Object.freeze(a))}},Fo=new Map,Dw=(n,e,t,s)=>{let{listener:r,rawEmitter:i}=s,o=Fo.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?(es(o,Sn,r),es(o,Zn,i)):(o={listeners:r,rawEmitters:i,options:t,watcher:Rt.watchFile(e,t,(d,f)=>{jo(o.rawEmitters,m=>{m(sr,e,{curr:d,prev:f})});let h=d.mtimeMs;(d.size!==f.size||h>f.mtimeMs||h===0)&&jo(o.listeners,m=>m(n,d))})},Fo.set(e,o)),()=>{ts(o,Sn,r),ts(o,Zn,i),Af(o.listeners)&&(Fo.delete(e),Rt.unwatchFile(e),o.options=o.watcher=void 0,Object.freeze(o))}},Ho=class{constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let s=this.fsw.options,r=xe.dirname(e),i=xe.basename(e);this.fsw._getWatchedDir(r).add(i);let a=xe.resolve(e),l={persistent:s.persistent};t||(t=xw);let u;return s.usePolling?(l.interval=s.enableBinaryInterval&&bw(i)?s.binaryInterval:s.interval,u=Dw(e,a,l,{listener:t,rawEmitter:this.fsw._emitRaw})):u=Lw(e,a,l,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw}),u}_handleFile(e,t,s){if(this.fsw.closed)return;let r=xe.dirname(e),i=xe.basename(e),o=this.fsw._getWatchedDir(r),a=t;if(o.has(i))return;let l=async(d,f)=>{if(this.fsw._throttle(Tw,e,5)){if(!f||f.mtimeMs===0)try{let h=await _f(e);if(this.fsw.closed)return;let m=h.atimeMs,p=h.mtimeMs;(!m||m<=p||p!==a.mtimeMs)&&this.fsw._emit(sr,e,h),ww&&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(sr,e,f),a=f}}},u=this._watchWithNodeFs(e,l);if(!(s&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(nr,e,0))return;this.fsw._emit(nr,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(sr,s,e.stats)):(o.add(r),this.fsw._symlinkPaths.set(i,a),this.fsw._emit(nr,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=xe.join(e,Sw),!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(kw,async f=>{if(this.fsw.closed){d=void 0;return}let h=f.path,m=xe.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=xe.join(i,xe.relative(i,m)),this._addToNodeFs(m,t,s,o+1))}}).on(Sf,this._boundHandleError);return new Promise(f=>d.once($w,()=>{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:xe.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(xe.dirname(e)),u=l.has(xe.basename(e));!(s&&this.fsw.options.ignoreInitial)&&!i&&!u&&(!o.hasGlob||o.globFilter(e))&&this.fsw._emit(Aw,e,t),l.add(xe.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 Iw[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(Cw)&&!e.includes(Ew),d;if(l.isDirectory()){let f=xe.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=xe.dirname(a.watchPath);if(this.fsw._getWatchedDir(h).add(a.watchPath),this.fsw._emit(nr,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(xe.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=Ho});var If=j((NC,zo)=>{"use strict";var Wo=require("fs"),Se=require("path"),{promisify:Vo}=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:Bo,EV_CHANGE:Nw,EV_ADD_DIR:Ef,EV_UNLINK:or,EV_ERROR:Fw,STR_DATA:jw,STR_END:Hw,FSEVENT_CREATED:Bw,FSEVENT_MODIFIED:Uw,FSEVENT_DELETED:qw,FSEVENT_MOVED:Kw,FSEVENT_UNKNOWN:Gw,FSEVENT_FLAG_MUST_SCAN_SUBDIRS:Ww,FSEVENT_TYPE_FILE:Vw,FSEVENT_TYPE_DIRECTORY:ss,FSEVENT_TYPE_SYMLINK:Pf,ROOT_GLOBSTAR:Cf,DIR_SUFFIX:zw,DOT_SLASH:Tf,FUNCTION_TYPE:Uo,EMPTY_FN:Yw,IDENTITY_FN:Jw}=tr(),Qw=n=>isNaN(n)?{}:{depth:n},Ko=Vo(Wo.stat),Xw=Vo(Wo.lstat),Rf=Vo(Wo.realpath),Zw={stat:Ko,lstat:Xw},Qt=new Map,ex=10,tx=new Set([69888,70400,71424,72704,73472,131328,131840,262912]),nx=(n,e)=>({stop:_n.watch(n,e)});function sx(n,e,t,s){let r=Se.extname(e)?Se.dirname(e):e,i=Se.dirname(r),o=Qt.get(r);rx(i)&&(r=i);let a=Se.resolve(n),l=a!==e,u=(f,h,m)=>{l&&(f=f.replace(e,a)),(f===a||!f.indexOf(a+Se.sep))&&t(f,h,m)},d=!1;for(let f of Qt.keys())if(e.indexOf(Se.resolve(f)+Se.sep)===0){r=f,o=Qt.get(r),d=!0;break}return o||d?o.listeners.add(u):(o={listeners:new Set([u]),rawEmitter:s,watcher:nx(r,(f,h)=>{if(!o.listeners.size||h&Ww)return;let m=_n.getInfo(f,h);o.listeners.forEach(p=>{p(f,h,m)}),o.rawEmitter(m.event,f,m)})},Qt.set(r,o)),()=>{let f=o.listeners;if(f.delete(u),!f.size&&(Qt.delete(r),o.watcher))return o.watcher.stop().then(()=>{o.rawEmitter=o.watcher=void 0,Object.freeze(o)})}}var rx=n=>{let e=0;for(let t of Qt.keys())if(t.indexOf(n)===0&&(e++,e>=ex))return!0;return!1},ix=()=>_n&&Qt.size<128,qo=(n,e)=>{let t=0;for(;!n.indexOf(e)&&(n=Se.dirname(n))!==e;)t++;return t},Of=(n,e)=>n.type===ss&&e.isDirectory()||n.type===Pf&&e.isSymbolicLink()||n.type===Vw&&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)?Nw:Bo;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 Ko(e);if(this.fsw.closed)return;Of(a,u)?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(or,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(or,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===or){let d=l.type===ss;(d||o.has(a))&&this.fsw._remove(i,a,d)}else{if(e===Bo){if(l.type===ss&&this.fsw._getWatchedDir(t),l.type===Pf&&u.followSymlinks){let f=u.depth===void 0?void 0:qo(s,r)+1;return this._addToFsEvents(t,!1,!0,f)}this.fsw._getWatchedDir(i).add(a)}let d=l.type===ss?e+zw:e;this.fsw._emit(d,t),d===Ef&&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=sx(e,t,async(l,u,d)=>{if(this.fsw.closed||i.depth!==void 0&&qo(l,t)>i.depth)return;let f=s(Se.join(e,Se.relative(e,l)));if(r&&!r(f))return;let h=Se.dirname(f),m=Se.basename(f),p=this.fsw._getWatchedDir(d.type===ss?f:h);if(tx.has(u)||d.event===Gw)if(typeof i.ignored===Uo){let g;try{g=await Ko(f)}catch{}if(this.fsw.closed||this.checkIgnored(f,g))return;Of(d,g)?this.addOrChange(f,l,t,h,p,m,d,i):this.handleEvent(or,f,l,t,h,p,m,d,i)}else this.checkExists(f,l,t,h,p,m,d,i);else switch(d.event){case Bw:case Uw:return this.addOrChange(f,l,t,h,p,m,d,i);case qw:case Kw: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 Rf(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=Se.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(Se.dirname(o)),u=Se.basename(o);a&&this.fsw._getWatchedDir(o),!l.has(u)&&(l.add(u),(!r.ignoreInitial||i===!0)&&this.fsw._emit(a?Ef:Bo,o,t))}initWatch(e,t,s,r){if(this.fsw.closed)return;let i=this._watchWithFsEvents(s.watchPath,Se.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===Uo?t:Jw,a=this.fsw._getWatchHelpers(e);try{let l=await Zw[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),...Qw(i.depth-(r||0))}).on(jw,u=>{if(this.fsw.closed||u.stats.isDirectory()&&!a.filterPath(u))return;let d=Se.join(a.watchPath,u.path),{fullPath:f}=u;if(a.followSymlinks&&u.stats.isSymbolicLink()){let h=i.depth===void 0?void 0:qo(d,Se.resolve(a.watchPath))+1;this._handleFsEventsSymlink(d,f,o,h)}else this.emitAdd(d,u.stats,o,i,s)}).on(Fw,Yw).on(Hw,()=>{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===Uo)this.initWatch(void 0,e,a,o);else{let l;try{l=await Rf(a.watchPath)}catch{}this.initWatch(l,e,a,o)}}};zo.exports=Go;zo.exports.canUse=ix});var Kf=j(ca=>{"use strict";var{EventEmitter:ox}=require("events"),aa=require("fs"),se=require("path"),{promisify:Hf}=require("util"),ax=vd(),ea=$d().default,lx=Pd(),Yo=Co(),cx=mf(),ux=$o(),dx=$f(),Mf=If(),{EV_ALL:Jo,EV_READY:fx,EV_ADD:ar,EV_CHANGE:rs,EV_UNLINK:Lf,EV_ADD_DIR:px,EV_UNLINK_DIR:hx,EV_RAW:mx,EV_ERROR:Qo,STR_CLOSE:gx,STR_END:yx,BACK_SLASH_RE:bx,DOUBLE_SLASH_RE:Df,SLASH_OR_BACK_SLASH_RE:vx,DOT_RE:wx,REPLACER_RE:xx,SLASH:Xo,SLASH_SLASH:Sx,BRACE_START:_x,BANG:ta,ONE_DOT:Bf,TWO_DOTS:Ax,GLOBSTAR:kx,SLASH_GLOBSTAR:Zo,ANYMATCH_OPTS:na,STRING_TYPE:la,FUNCTION_TYPE:$x,EMPTY_STR:sa,EMPTY_FN:Ex,isWindows:Cx,isMacos:Tx,isIBMi:Rx}=tr(),Ox=Hf(aa.stat),Px=Hf(aa.readdir),ra=(n=[])=>Array.isArray(n)?n:[n],Uf=(n,e=[])=>(n.forEach(t=>{Array.isArray(t)?Uf(t,e):e.push(t)}),e),Nf=n=>{let e=Uf(ra(n));if(!e.every(t=>typeof t===la))throw new TypeError(`Non-string provided as watch path: ${e}`);return e.map(qf)},Ff=n=>{let e=n.replace(bx,Xo),t=!1;for(e.startsWith(Sx)&&(t=!0);e.match(Df);)e=e.replace(Df,Xo);return t&&(e=Xo+e),e},qf=n=>Ff(se.normalize(Ff(n))),jf=(n=sa)=>e=>typeof e!==la?e:qf(se.isAbsolute(e)?e:se.join(n,e)),Ix=(n,e)=>se.isAbsolute(n)?n:n.startsWith(ta)?ta+se.join(e,n.slice(1)):se.join(e,n),it=(n,e)=>n[e]===void 0,ia=class{constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==Bf&&e!==Ax&&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 Px(s)}catch{this._removeWatcher&&this._removeWatcher(se.dirname(s),se.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)}},Mx="stat",Lx="lstat",oa=class{constructor(e,t,s,r){this.fsw=r,this.path=e=e.replace(xx,sa),this.watchPath=t,this.fullWatchPath=se.resolve(t),this.hasGlob=t!==e,e===sa&&(this.hasGlob=!1),this.globSymlink=this.hasGlob&&s?void 0:!1,this.globFilter=this.hasGlob?ea(e,void 0,na):!1,this.dirParts=this.getDirParts(e),this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=s,this.statMethod=s?Mx:Lx}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 se.join(this.watchPath,se.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===$x?this.globFilter(s):!0)&&this.fsw._isntIgnored(s,t)&&this.fsw._hasReadPermissions(t)}getDirParts(e){if(!this.hasGlob)return[];let t=[];return(e.includes(_x)?cx.expand(e):[e]).forEach(r=>{t.push(se.relative(this.watchPath,r).split(vx))}),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===kx&&(s=!0),s||!t[0][o]||ea(i,t[0][o],na))))}return!this.unmatchedGlob&&this.fsw._isntIgnored(this.entryPath(e),e.stats)}},lr=class extends ox{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,it(t,"persistent")&&(t.persistent=!0),it(t,"ignoreInitial")&&(t.ignoreInitial=!1),it(t,"ignorePermissionErrors")&&(t.ignorePermissionErrors=!1),it(t,"interval")&&(t.interval=100),it(t,"binaryInterval")&&(t.binaryInterval=300),it(t,"disableGlobbing")&&(t.disableGlobbing=!1),t.enableBinaryInterval=t.binaryInterval!==t.interval,it(t,"useFsEvents")&&(t.useFsEvents=!t.usePolling),Mf.canUse()||(t.useFsEvents=!1),it(t,"usePolling")&&!t.useFsEvents&&(t.usePolling=Tx),Rx&&(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)),it(t,"atomic")&&(t.atomic=!t.usePolling&&!t.useFsEvents),t.atomic&&(this._pendingUnlinks=new Map),it(t,"followSymlinks")&&(t.followSymlinks=!0),it(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=ra(t.ignored));let a=0;this._emitReady=()=>{a++,a>=this._readyCount&&(this._emitReady=Ex,this._readyEmitted=!0,process.nextTick(()=>this.emit(fx)))},this._emitRaw=(...l)=>this.emit(mx,...l),this._readyEmitted=!1,this.options=t,t.useFsEvents?this._fsEventsHandler=new Mf(this):this._nodeFsHandler=new dx(this),Object.freeze(t)}add(e,t,s){let{cwd:r,disableGlobbing:i}=this.options;this.closed=!1;let o=Nf(e);return r&&(o=o.map(a=>{let l=Ix(a,r);return i||!Yo(a)?l:ux(l)})),o=o.filter(a=>a.startsWith(ta)?(this._ignoredPaths.add(a.slice(1)),!1):(this._ignoredPaths.delete(a),this._ignoredPaths.delete(a+Zo),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(se.dirname(l),se.basename(t||l))})})),this}unwatch(e){if(this.closed)return this;let t=Nf(e),{cwd:s}=this.options;return t.forEach(r=>{!se.isAbsolute(r)&&!this._closers.has(r)&&(s&&(r=se.join(s,r)),r=se.resolve(r)),this._closePath(r),this._ignoredPaths.add(r),this._watched.has(r)&&this._ignoredPaths.add(r+Zo),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?se.relative(this.options.cwd,s):s;e[r||Bf]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(...t),e!==Qo&&this.emit(Jo,...t)}async _emit(e,t,s,r,i){if(this.closed)return;let o=this.options;Cx&&(t=se.normalize(t)),o.cwd&&(t=se.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===Lf)return this._pendingUnlinks.set(t,a),setTimeout(()=>{this._pendingUnlinks.forEach((d,f)=>{this.emit(...d),this.emit(Jo,...d),this._pendingUnlinks.delete(f)})},typeof o.atomic=="number"?o.atomic:100),this;e===ar&&this._pendingUnlinks.has(t)&&(e=a[0]=rs,this._pendingUnlinks.delete(t))}if(l&&(e===ar||e===rs)&&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===rs&&!this._throttle(rs,t,50))return this;if(o.alwaysStat&&s===void 0&&(e===ar||e===px||e===rs)){let d=o.cwd?se.join(o.cwd,t):t,f;try{f=await Ox(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&&!se.isAbsolute(e)&&(o=se.join(this.options.cwd,e));let a=new Date,l=u=>{aa.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&&wx.test(e))return!0;if(!this._userIgnored){let{cwd:s}=this.options,r=this.options.ignored,i=r&&r.map(jf(s)),o=ra(i).filter(l=>typeof l===la&&!Yo(l)).map(l=>l+Zo),a=this._getGlobIgnored().map(jf(s)).concat(i,o);this._userIgnored=ea(a,void 0,na)}return this._userIgnored([e,t])}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e,t){let s=t||this.options.disableGlobbing||!Yo(e)?e:lx(e),r=this.options.followSymlinks;return new oa(e,s,r,this)}_getWatchedDir(e){this._boundRemove||(this._boundRemove=this._remove.bind(this));let t=se.resolve(e);return this._watched.has(t)||this._watched.set(t,new ia(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=se.join(e,t),i=se.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=se.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(d)&&this._pendingWrites.get(d).cancelWait()===ar)return;this._watched.delete(r),this._watched.delete(i);let f=s?hx:Lf;u&&!this._isIgnored(r)&&this._emit(f,r),this.options.useFsEvents||this._closePath(r)}_closePath(e){this._closeFile(e);let t=se.dirname(e);this._getWatchedDir(t).remove(se.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:Jo,alwaysStat:!0,lstat:!0,...t},r=ax(e,s);return this._streams.add(r),r.once(gx,()=>{r=void 0}),r.once(yx,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};ca.FSWatcher=lr;var Dx=(n,e)=>{let t=new lr(e);return t.add(n),t};ca.watch=Dx});var zf={};Ne(zf,{CollaborationManager:()=>is,addTeamMember:()=>jx,formatTeamConfig:()=>Hx,initTeamConfig:()=>Fx,loadTeamConfig:()=>Nx,saveTeamConfig:()=>Vf});function Nx(n){let e=Je.join(n,".hablas","team.json");if(ye.existsSync(e))try{return JSON.parse(ye.readFileSync(e,"utf-8"))}catch{return null}return null}function Fx(n,e){let t={name:e,members:[]};return Vf(n,t),t}function Vf(n,e){let t=Je.join(n,".hablas","team.json"),s=Je.dirname(t);ye.existsSync(s)||ye.mkdirSync(s,{recursive:!0}),ye.writeFileSync(t,JSON.stringify(e,null,2),"utf-8")}function jx(n,e,t){return n.members.push({name:e,email:t}),n}function Hx(n){return[`Team: ${n.name}`,"Members:",...n.members.map(t=>` - ${t.name} (${t.email})`)].join(`
326
+ `)}var ye,Je,cr,Gf,Wf,is,ua=N(()=>{"use strict";ye=O(require("fs")),Je=O(require("path")),cr=O(require("os")),Gf=O(require("crypto")),Wf=O(Kf());gn();is=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||cr.userInfo().username||"developer",this.teamKey=r||"default-team",this.localStatePath=Je.join(this.workingDir,".hablas","collaboration.json");let i=this.getProjectIdentifier();console.log(`
327
327
  ${c.muted("[Debug] Project Context:")} ${c.highlight(i)}`),this.projectTeamToken=Gf.createHash("sha256").update(`${i}:${this.teamKey}`).digest("hex"),console.log(` ${c.muted("[Debug] Session Fingerprint:")} ${c.muted(this.projectTeamToken.slice(0,16))}...
328
328
  `),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=Je.dirname(this.localStatePath);return ye.existsSync(e)||ye.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};ye.writeFileSync(this.localStatePath,JSON.stringify(s,null,2),"utf-8")}getLocalState(){if(ye.existsSync(this.localStatePath))try{return JSON.parse(ye.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(`
329
329
  ${c.success("\u2713")} ${c.muted("[Team]")} Cloud sync reconnected \u2014 session restored.
@@ -337,36 +337,36 @@ If you cannot complete a task, explain why with absolute technical objectivity.`
337
337
  `));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(`
338
338
  `+r),console.log(l),console.log(f),console.log(i+`
339
339
  `)}registerCleanups(){this.signalHandler||(this.signalHandler=()=>{this.shutdown()},process.on("SIGTERM",this.signalHandler),process.once("beforeExit",this.signalHandler))}loadSupabaseConfig(){let e=Je.join(this.workingDir,".env");if(ye.existsSync(e))try{let s=ye.readFileSync(e,"utf-8").split(`
340
- `);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=Je.join(or.homedir(),".hablas","config.json");if(ye.existsSync(e))try{let t=JSON.parse(ye.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=Je.join(this.workingDir,"package.json");if(ye.existsSync(t)){let s=JSON.parse(ye.readFileSync(t,"utf-8"));s.name&&(e=s.name.toLowerCase())}}catch{}return e||(e=Je.basename(this.workingDir).toLowerCase()),e.replace(/\s+/g,"")}}});async function Qt(n){try{if(!ua.existsSync(n))return;ua.existsSync(is)||await mt.mkdir(is,{recursive:!0});let e=await mt.readFile(n,"utf-8"),t=_n.basename(n),s=Date.now(),r=`${t}.${s}.bak`,i=_n.join(is,r);await mt.writeFile(i,e,"utf-8");let a=(await mt.readdir(is)).filter(l=>l.startsWith(`${t}.`)&&l.endsWith(".bak")).sort().reverse();if(a.length>Yf)for(let l of a.slice(Yf))await mt.unlink(_n.join(is,l))}catch{}}var mt,ua,_n,Jf,is,Yf,Qf=N(()=>{"use strict";mt=O(require("fs/promises")),ua=O(require("fs")),_n=O(require("path")),Jf=O(require("os")),is=_n.join(Jf.homedir(),".hablas","backup"),Yf=10});function ep(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),x=(await ae.readFile(p,"utf-8")).split(`
340
+ `);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=Je.join(cr.homedir(),".hablas","config.json");if(ye.existsSync(e))try{let t=JSON.parse(ye.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=Je.join(this.workingDir,"package.json");if(ye.existsSync(t)){let s=JSON.parse(ye.readFileSync(t,"utf-8"));s.name&&(e=s.name.toLowerCase())}}catch{}return e||(e=Je.basename(this.workingDir).toLowerCase()),e.replace(/\s+/g,"")}}});async function Xt(n){try{if(!da.existsSync(n))return;da.existsSync(os)||await mt.mkdir(os,{recursive:!0});let e=await mt.readFile(n,"utf-8"),t=An.basename(n),s=Date.now(),r=`${t}.${s}.bak`,i=An.join(os,r);await mt.writeFile(i,e,"utf-8");let a=(await mt.readdir(os)).filter(l=>l.startsWith(`${t}.`)&&l.endsWith(".bak")).sort().reverse();if(a.length>Yf)for(let l of a.slice(Yf))await mt.unlink(An.join(os,l))}catch{}}var mt,da,An,Jf,os,Yf,Qf=N(()=>{"use strict";mt=O(require("fs/promises")),da=O(require("fs")),An=O(require("path")),Jf=O(require("os")),os=An.join(Jf.homedir(),".hablas","backup"),Yf=10});function ep(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),x=(await ae.readFile(p,"utf-8")).split(`
341
341
  `),A=x.length,$=m.start_line?Math.max(1,m.start_line):1,_=m.end_line?Math.min(A,m.end_line):Math.min(A,$+Xf-1),y=Math.min(_,$+Xf-1),v=x.slice($-1,y),b=String(y).length,w=v.map((M,k)=>`${String($+k).padStart(b," ")} | ${M}`),S=`[${m.path} \u2014 lines ${$}-${y} of ${A}]`,T=y<A?`
342
342
  ... [File has ${A} total lines. Use start_line/end_line to read more.]`:"";return{success:!0,output:`${S}
343
343
  ${w.join(`
344
- `)}${T}`}}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 da.existsSync(p)&&await Qt(p),await ae.mkdir(jt.dirname(p),{recursive:!0}),await ae.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 ae.readFile(p,"utf-8"),x=m.old_content,A=m.new_content,$=Zf(g,x);if($===0)return{success:!1,output:"",error:"[edit_file]: Old content not found in file"};if($>1)return{success:!1,output:"",error:`[edit_file]: old_content matches ${$} locations in the file. Provide more surrounding context to be specific.`};await Qt(p);let _=g.replace(x,A);await ae.writeFile(p,_,"utf-8");let y=Hs(m.path,g,_);return{success:!0,output:`Edited: ${m.path}
344
+ `)}${T}`}}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 fa.existsSync(p)&&await Xt(p),await ae.mkdir(jt.dirname(p),{recursive:!0}),await ae.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 ae.readFile(p,"utf-8"),x=m.old_content,A=m.new_content,$=Zf(g,x);if($===0)return{success:!1,output:"",error:"[edit_file]: Old content not found in file"};if($>1)return{success:!1,output:"",error:`[edit_file]: old_content matches ${$} locations in the file. Provide more surrounding context to be specific.`};await Xt(p);let _=g.replace(x,A);await ae.writeFile(p,_,"utf-8");let y=qs(m.path,g,_);return{success:!0,output:`Edited: ${m.path}
345
345
  ${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 ae.readFile(p,"utf-8"),x=g.split(`
346
- `),A=x.length,$=m.start_line,_=m.end_line;if($<1||$>A)return{success:!1,output:"",error:`[patch_file]: start_line ${$} is out of range (file has ${A} lines)`};if(_<$||_>A)return{success:!1,output:"",error:`[patch_file]: end_line ${_} is out of range (start_line=${$}, total=${A})`};await Qt(p);let y=x.slice(0,$-1),v=x.slice(_),b=m.new_content.split(`
346
+ `),A=x.length,$=m.start_line,_=m.end_line;if($<1||$>A)return{success:!1,output:"",error:`[patch_file]: start_line ${$} is out of range (file has ${A} lines)`};if(_<$||_>A)return{success:!1,output:"",error:`[patch_file]: end_line ${_} is out of range (start_line=${$}, total=${A})`};await Xt(p);let y=x.slice(0,$-1),v=x.slice(_),b=m.new_content.split(`
347
347
  `),w=[...y,...b,...v].join(`
348
- `);await ae.writeFile(p,w,"utf-8");let S=Hs(m.path,g,w),T=_-$+1,M=b.length;return{success:!0,output:`Patched: ${m.path} (replaced ${T} lines with ${M})
349
- ${S}`}}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 ae.readFile(p,"utf-8"),x=m.search,A=m.replace,$=m.is_regex;await Qt(p);let _,y;if($){let v=new RegExp(x,"g");y=(g.match(v)||[]).length,_=g.replace(v,A)}else y=Zf(g,x),_=g.split(x).join(A);return y===0?{success:!1,output:"",error:"[search_and_replace]: Pattern not found in file"}:(await ae.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 ae.mkdir(jt.dirname(p),{recursive:!0}),da.existsSync(p)&&await Qt(p),await ae.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 Qt(p),await ae.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 ae.mkdir(jt.dirname(g),{recursive:!0}),await ae.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 ae.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 tp(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 ae.stat(p);return{success:!0,output:[`Path: ${m.path}`,`Size: ${Ux(g.size)}`,`Type: ${g.isDirectory()?"directory":"file"}`,`Modified: ${g.mtime.toISOString()}`,`Created: ${g.birthtime.toISOString()}`].join(`
348
+ `);await ae.writeFile(p,w,"utf-8");let S=qs(m.path,g,w),T=_-$+1,M=b.length;return{success:!0,output:`Patched: ${m.path} (replaced ${T} lines with ${M})
349
+ ${S}`}}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 ae.readFile(p,"utf-8"),x=m.search,A=m.replace,$=m.is_regex;await Xt(p);let _,y;if($){let v=new RegExp(x,"g");y=(g.match(v)||[]).length,_=g.replace(v,A)}else y=Zf(g,x),_=g.split(x).join(A);return y===0?{success:!1,output:"",error:"[search_and_replace]: Pattern not found in file"}:(await ae.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 ae.mkdir(jt.dirname(p),{recursive:!0}),fa.existsSync(p)&&await Xt(p),await ae.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 Xt(p),await ae.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 ae.mkdir(jt.dirname(g),{recursive:!0}),await ae.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 ae.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 tp(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 ae.stat(p);return{success:!0,output:[`Path: ${m.path}`,`Size: ${Ux(g.size)}`,`Type: ${g.isDirectory()?"directory":"file"}`,`Modified: ${g.mtime.toISOString()}`,`Created: ${g.birthtime.toISOString()}`].join(`
350
350
  `)}}catch(p){return{success:!1,output:"",error:`[get_file_info]: ${p.message}`}}}}]}function Zf(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 tp(n,e,t,s){if(s>=t)return"";let i=(await ae.readdir(n,{withFileTypes:!0})).filter(a=>!Bx.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}
351
- `,l.isDirectory()){let h=e+(u?" ":"\u2502 ");o+=await tp(jt.join(n,l.name),h,t,s+1)}}return o}function Ux(n){return n<1024?`${n} B`:n<1024*1024?`${(n/1024).toFixed(1)} KB`:`${(n/(1024*1024)).toFixed(1)} MB`}var ae,da,jt,Xf,Bx,np=N(()=>{"use strict";ae=O(require("fs/promises")),da=O(require("fs")),jt=O(require("path"));ao();Qf();Xf=300;Bx=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next"])});var sp,ar,rp=N(()=>{"use strict";sp=require("child_process"),ar=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,sp.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+=`
351
+ `,l.isDirectory()){let h=e+(u?" ":"\u2502 ");o+=await tp(jt.join(n,l.name),h,t,s+1)}}return o}function Ux(n){return n<1024?`${n} B`:n<1024*1024?`${(n/1024).toFixed(1)} KB`:`${(n/(1024*1024)).toFixed(1)} MB`}var ae,fa,jt,Xf,Bx,np=N(()=>{"use strict";ae=O(require("fs/promises")),fa=O(require("fs")),jt=O(require("path"));lo();Qf();Xf=300;Bx=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next"])});var sp,ur,rp=N(()=>{"use strict";sp=require("child_process"),ur=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,sp.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+=`
352
352
  Error: ${a.message}`}),r>0&&setTimeout(()=>{o.status==="running"&&(this.kill(s),o.status="timeout",o.stderr+=`
353
353
  Process timed out after ${r}ms`)},r),this.processes.set(s,o),s}readOutput(e,t){let s=this.processes.get(e);if(!s)return{success:!1,output:"",status:"not_found",error:`Background process ${e} not found`};let r=t?.type||"both",i="";return(r==="stdout"||r==="both")&&(i+=s.stdout),(r==="stderr"||r==="both")&&(i&&(i+=`
354
354
  `),i+=s.stderr),t?.lastLines&&(i=i.split(`
355
355
  `).slice(-t.lastLines).join(`
356
- `)),{success:!0,output:i,status:s.status}}kill(e){let t=this.processes.get(e);if(!t)return!1;if(t.process.pid)try{process.kill(-t.process.pid,"SIGTERM")}catch{try{process.kill(t.process.pid,"SIGTERM")}catch{}}return t.status="killed",!0}killAll(){let e=0;for(let t of this.processes.keys())this.kill(t)&&e++;return e}listProcesses(){let e=[];for(let[t,s]of this.processes){let r=Date.now()-s.startTime,i=this.formatUptime(r);e.push({id:t,command:s.command,status:s.status,pid:s.pid,startTime:s.startTime,uptime:i})}return e}getProcess(e){return this.processes.get(e)}cleanup(){let e=0;for(let[t,s]of this.processes)(s.status==="finished"||s.status==="killed"||s.status==="timeout")&&(this.processes.delete(t),e++);return e}formatUptime(e){let t=Math.floor(e/1e3);if(t<60)return`${t}s`;let s=Math.floor(t/60);return s<60?`${s}m ${t%60}s`:`${Math.floor(s/60)}h ${s%60}m`}}});function ip(n){return fa||(fa=new ar({workingDir:n})),fa}function ap(n,e){return{name:"run_command",description:"Execute any shell command and return output. Set run_in_background=true for long-running processes (servers, watchers). Use bash_output to read output later.",safety:"confirm",parameters:{command:{type:"string",description:"Shell command to execute",required:!0},run_in_background:{type:"boolean",description:"Run in background for long processes (default: false)",required:!1},timeout:{type:"number",description:"Timeout in ms (default: 120000)",required:!1}},execute:async t=>{let s=t.command,r=t.run_in_background===!0,i=t.timeout||e.tools.runCommand.timeout||12e4,o=e.tools.runCommand.blocklist||[],a=[...qx,...o];if(a.length>0){for(let l of a)if(s.includes(l))return{success:!1,output:"",error:`Blocked pattern: "${l}". This command is prohibited due to security risks.`}}if(r){let l=ip(n).start(s,{timeout:i});return{success:!0,output:`Background process started: ${l}
356
+ `)),{success:!0,output:i,status:s.status}}kill(e){let t=this.processes.get(e);if(!t)return!1;if(t.process.pid)try{process.kill(-t.process.pid,"SIGTERM")}catch{try{process.kill(t.process.pid,"SIGTERM")}catch{}}return t.status="killed",!0}killAll(){let e=0;for(let t of this.processes.keys())this.kill(t)&&e++;return e}listProcesses(){let e=[];for(let[t,s]of this.processes){let r=Date.now()-s.startTime,i=this.formatUptime(r);e.push({id:t,command:s.command,status:s.status,pid:s.pid,startTime:s.startTime,uptime:i})}return e}getProcess(e){return this.processes.get(e)}cleanup(){let e=0;for(let[t,s]of this.processes)(s.status==="finished"||s.status==="killed"||s.status==="timeout")&&(this.processes.delete(t),e++);return e}formatUptime(e){let t=Math.floor(e/1e3);if(t<60)return`${t}s`;let s=Math.floor(t/60);return s<60?`${s}m ${t%60}s`:`${Math.floor(s/60)}h ${s%60}m`}}});function ip(n){return pa||(pa=new ur({workingDir:n})),pa}function ap(n,e){return{name:"run_command",description:"Execute any shell command and return output. Set run_in_background=true for long-running processes (servers, watchers). Use bash_output to read output later.",safety:"confirm",parameters:{command:{type:"string",description:"Shell command to execute",required:!0},run_in_background:{type:"boolean",description:"Run in background for long processes (default: false)",required:!1},timeout:{type:"number",description:"Timeout in ms (default: 120000)",required:!1}},execute:async t=>{let s=t.command,r=t.run_in_background===!0,i=t.timeout||e.tools.runCommand.timeout||12e4,o=e.tools.runCommand.blocklist||[],a=[...qx,...o];if(a.length>0){for(let l of a)if(s.includes(l))return{success:!1,output:"",error:`Blocked pattern: "${l}". This command is prohibited due to security risks.`}}if(r){let l=ip(n).start(s,{timeout:i});return{success:!0,output:`Background process started: ${l}
357
357
  PID: ${ip(n).getProcess(l)?.pid}
358
- Use bash_output to read output: bash_output(process_id="${l}")`}}return new Promise(l=>{let u=(0,op.exec)(s,{cwd:n,timeout:i,maxBuffer:10485760,env:{...process.env,FORCE_COLOR:"0"}}),d="",f="";u.stdout?.on("data",h=>{d+=h}),u.stderr?.on("data",h=>{f+=h}),u.on("close",h=>{l(h===0?{success:!0,output:d||"(no output)"}:{success:!1,output:d,error:f||`Exit code: ${h}`})}),u.on("error",h=>{l({success:!1,output:"",error:h.message})})})}}}var op,qx,fa,lp=N(()=>{"use strict";op=require("child_process");rp();qx=["rm -rf /","rm -rf /*","rm -rf ~","rm -rf $HOME","rm -rf /home","mkfs",":(){ :|:& };:"],fa=null});function cp(n){return{name:"search_codebase",description:"Search for a pattern across all code files in the project",safety:"safe",parameters:{query:{type:"string",description:"Search pattern (regex supported)",required:!0},path:{type:"string",description:"Subdirectory to search in (default: .)",required:!1}},execute:async e=>{try{let t=e.query,s=Ht.resolve(n,e.path||"."),r=new RegExp(t,"gi"),i=[];if(await up(s,r,i,n),i.length===0)return{success:!0,output:`No matches found for: "${t}"`};let o=i.slice(0,50).join(`
358
+ Use bash_output to read output: bash_output(process_id="${l}")`}}return new Promise(l=>{let u=(0,op.exec)(s,{cwd:n,timeout:i,maxBuffer:10485760,env:{...process.env,FORCE_COLOR:"0"}}),d="",f="";u.stdout?.on("data",h=>{d+=h}),u.stderr?.on("data",h=>{f+=h}),u.on("close",h=>{l(h===0?{success:!0,output:d||"(no output)"}:{success:!1,output:d,error:f||`Exit code: ${h}`})}),u.on("error",h=>{l({success:!1,output:"",error:h.message})})})}}}var op,qx,pa,lp=N(()=>{"use strict";op=require("child_process");rp();qx=["rm -rf /","rm -rf /*","rm -rf ~","rm -rf $HOME","rm -rf /home","mkfs",":(){ :|:& };:"],pa=null});function cp(n){return{name:"search_codebase",description:"Search for a pattern across all code files in the project",safety:"safe",parameters:{query:{type:"string",description:"Search pattern (regex supported)",required:!0},path:{type:"string",description:"Subdirectory to search in (default: .)",required:!1}},execute:async e=>{try{let t=e.query,s=Ht.resolve(n,e.path||"."),r=new RegExp(t,"gi"),i=[];if(await up(s,r,i,n),i.length===0)return{success:!0,output:`No matches found for: "${t}"`};let o=i.slice(0,50).join(`
359
359
  `),a=i.length>50?`
360
- ... and ${i.length-50} more matches`:"";return{success:!0,output:o+a}}catch(t){return{success:!1,output:"",error:`Search failed: ${t.message}`}}}}}async function up(n,e,t,s){let r=await lr.readdir(n,{withFileTypes:!0});for(let i of r){if(Kx.has(i.name)||i.name.startsWith("."))continue;let o=Ht.join(n,i.name);if(i.isDirectory())await up(o,e,t,s);else if(Gx.has(Ht.extname(i.name)))try{let l=(await lr.readFile(o,"utf-8")).split(`
361
- `),u=Ht.relative(s,o);for(let d=0;d<l.length;d++)e.test(l[d])&&(t.push(`${u}:${d+1}: ${l[d].trim()}`),e.lastIndex=0)}catch{}}}var lr,Ht,Kx,Gx,dp=N(()=>{"use strict";lr=O(require("fs/promises")),Ht=O(require("path")),Kx=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next",".cache"]),Gx=new Set([".ts",".js",".tsx",".jsx",".py",".go",".rs",".java",".c",".cpp",".h",".css",".html",".json",".md",".yaml",".yml",".toml"])});function Wx(n){let e=[],t=Bt.join(n,"tsconfig.json");if(!Qe.existsSync(t))return e;try{(0,pa.execSync)("npx tsc --noEmit 2>&1",{cwd:n,encoding:"utf-8",timeout:3e4})}catch(s){let r=s,o=(r.stdout||r.message||"").split(`
362
- `);for(let a of o){let l=a.match(/^(.+?)\((\d+),\d+\):\s*(error|warning)\s+TS\d+:\s*(.+)$/);l&&e.push({file:l[1],line:parseInt(l[2],10),severity:l[3]==="error"?"error":"warning",message:l[4].trim(),source:"typescript"})}}return e}function Vx(n){let e=[];if(![".eslintrc.json",".eslintrc.js",".eslintrc.yml","eslint.config.js","eslint.config.mjs"].some(s=>Qe.existsSync(Bt.join(n,s))))return e;try{(0,pa.execSync)("npx eslint . --format json 2>&1",{cwd:n,encoding:"utf-8",timeout:3e4})}catch(s){let i=s.stdout||"";try{let o=JSON.parse(i);for(let a of o)for(let l of a.messages||[])e.push({file:Bt.relative(n,a.filePath),line:l.line||0,severity:l.severity===2?"error":"warning",message:`${l.message} (${l.ruleId||"unknown"})`,source:"eslint"})}catch{let o=i.split(`
360
+ ... and ${i.length-50} more matches`:"";return{success:!0,output:o+a}}catch(t){return{success:!1,output:"",error:`Search failed: ${t.message}`}}}}}async function up(n,e,t,s){let r=await dr.readdir(n,{withFileTypes:!0});for(let i of r){if(Kx.has(i.name)||i.name.startsWith("."))continue;let o=Ht.join(n,i.name);if(i.isDirectory())await up(o,e,t,s);else if(Gx.has(Ht.extname(i.name)))try{let l=(await dr.readFile(o,"utf-8")).split(`
361
+ `),u=Ht.relative(s,o);for(let d=0;d<l.length;d++)e.test(l[d])&&(t.push(`${u}:${d+1}: ${l[d].trim()}`),e.lastIndex=0)}catch{}}}var dr,Ht,Kx,Gx,dp=N(()=>{"use strict";dr=O(require("fs/promises")),Ht=O(require("path")),Kx=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next",".cache"]),Gx=new Set([".ts",".js",".tsx",".jsx",".py",".go",".rs",".java",".c",".cpp",".h",".css",".html",".json",".md",".yaml",".yml",".toml"])});function Wx(n){let e=[],t=Bt.join(n,"tsconfig.json");if(!Qe.existsSync(t))return e;try{(0,ha.execSync)("npx tsc --noEmit 2>&1",{cwd:n,encoding:"utf-8",timeout:3e4})}catch(s){let r=s,o=(r.stdout||r.message||"").split(`
362
+ `);for(let a of o){let l=a.match(/^(.+?)\((\d+),\d+\):\s*(error|warning)\s+TS\d+:\s*(.+)$/);l&&e.push({file:l[1],line:parseInt(l[2],10),severity:l[3]==="error"?"error":"warning",message:l[4].trim(),source:"typescript"})}}return e}function Vx(n){let e=[];if(![".eslintrc.json",".eslintrc.js",".eslintrc.yml","eslint.config.js","eslint.config.mjs"].some(s=>Qe.existsSync(Bt.join(n,s))))return e;try{(0,ha.execSync)("npx eslint . --format json 2>&1",{cwd:n,encoding:"utf-8",timeout:3e4})}catch(s){let i=s.stdout||"";try{let o=JSON.parse(i);for(let a of o)for(let l of a.messages||[])e.push({file:Bt.relative(n,a.filePath),line:l.line||0,severity:l.severity===2?"error":"warning",message:`${l.message} (${l.ruleId||"unknown"})`,source:"eslint"})}catch{let o=i.split(`
363
363
  `);for(let a of o){let l=a.match(/^\s*(\d+):(\d+)\s+(error|warning)\s+(.+?)\s+(\S+)$/);l&&e.push({file:"unknown",line:parseInt(l[1],10),severity:l[3]==="error"?"error":"warning",message:`${l[4]} (${l[5]})`,source:"eslint"})}}}return e}function zx(n,e,t){let s;try{s=Qe.readFileSync(n,"utf-8")}catch{return}let r=Bt.relative(e,n),i=s.split(`
364
364
  `);for(let o=0;o<i.length;o++){let a=i[o],l=o+1;/\bconsole\.(log|debug)\b/.test(a)&&!/\/\//.test(a.split("console")[0])&&t.push({file:r,line:l,severity:"info",message:"console.log/debug statement found (consider removing for production)",source:"pattern",suggestedFix:"Remove or replace with proper logging"}),/\b(TODO|FIXME|HACK|XXX)\b/.test(a)&&t.push({file:r,line:l,severity:"info",message:`Unresolved ${a.match(/\b(TODO|FIXME|HACK|XXX)\b/)?.[0]} comment`,source:"pattern"}),/catch\s*\([^)]*\)\s*\{\s*\}/.test(a)&&t.push({file:r,line:l,severity:"warning",message:"Empty catch block \u2014 errors are silently swallowed",source:"pattern",suggestedFix:"Add error handling or at least log the error"}),/:\s*any\b/.test(a)&&!a.trim().startsWith("//")&&t.push({file:r,line:l,severity:"info",message:"Usage of `any` type \u2014 consider using a specific type",source:"pattern",suggestedFix:"Replace with a proper TypeScript type"})}}function Yx(n){let e=[],t=[".ts",".tsx",".js",".jsx"];function s(r,i=0){if(i>5)return;let o=["node_modules",".git","dist","build",".next","coverage"],a;try{a=Qe.readdirSync(r)}catch{return}for(let l of a){if(o.includes(l))continue;let u=Bt.join(r,l),d;try{d=Qe.statSync(u)}catch{continue}d.isDirectory()?s(u,i+1):t.some(f=>l.endsWith(f))&&zx(u,n,e)}}return s(n),e.slice(0,20)}function Jx(n){let e=[];e.push(...Wx(n)),e.push(...Vx(n)),e.push(...Yx(n));let t={error:0,warning:1,info:2};return e.sort((s,r)=>t[s.severity]-t[r.severity]),e}function fp(n){if(n.length===0)return" \u2713 No bugs detected";let e=[],t=n.filter(i=>i.severity==="error").length,s=n.filter(i=>i.severity==="warning").length,r=n.filter(i=>i.severity==="info").length;e.push(` Found ${n.length} issue${n.length>1?"s":""}: ${t} errors, ${s} warnings, ${r} info`),e.push("");for(let i of n.slice(0,15)){let o=i.severity==="error"?"\u2717":i.severity==="warning"?"\u26A0":"\u2139",a=i.line>0?`:${i.line}`:"";e.push(` ${o} ${i.file}${a}`),e.push(` ${i.message}`),i.suggestedFix&&e.push(` \u2192 ${i.suggestedFix}`)}return n.length>15&&e.push(` ... and ${n.length-15} more`),e.join(`
365
365
  `)}function Qx(n,e){let t=[];for(let s of n)if(s.source==="pattern"&&s.message.includes("console.log")){let r=Bt.join(e,s.file);try{let o=Qe.readFileSync(r,"utf-8").split(`
366
366
  `);s.line>0&&s.line<=o.length&&(o[s.line-1]="// "+o[s.line-1],Qe.writeFileSync(r,o.join(`
367
367
  `),"utf-8"),t.push({bug:s,fixed:!0,action:"Commented out console.log"}))}catch{t.push({bug:s,fixed:!1,action:"Failed to read/write file"})}}else t.push({bug:s,fixed:!1,action:"Requires manual fix or LLM assistance"});return t}function pp(n){return{name:"detect_bugs",description:"Scan the project for bugs using TypeScript checking, ESLint, and pattern analysis. Returns a report of found issues.",safety:"safe",parameters:{path:{type:"string",description:"Project path to scan (default: current directory)",required:!1},fix:{type:"string",description:'Set to "true" to auto-fix simple issues',required:!1}},execute:async e=>{let t=e.path||n,s=e.fix==="true"||e.fix===!0;try{let r=Jx(t);if(s&&r.length>0){let o=Qx(r,t).filter(l=>l.fixed).length;return{success:!0,output:`${fp(r)}
368
368
 
369
- Auto-fixed: ${o}/${r.length} issues`}}return{success:!0,output:fp(r)}}catch(r){return{success:!1,output:"",error:`Bug detection failed: ${r instanceof Error?r.message:String(r)}`}}}}}var pa,Qe,Bt,hp=N(()=>{"use strict";pa=require("child_process"),Qe=O(require("fs")),Bt=O(require("path"))});function Zx(n){let e=n;return e=e.replace(/<(script|style|nav|footer|header|aside|iframe|noscript)[^>]*>[\s\S]*?<\/\1>/gi,""),e=e.replace(/<!--[\s\S]*?-->/g,""),e=e.replace(/<\/(p|div|section|article|li|tr|h[1-6])>/gi,`
369
+ Auto-fixed: ${o}/${r.length} issues`}}return{success:!0,output:fp(r)}}catch(r){return{success:!1,output:"",error:`Bug detection failed: ${r instanceof Error?r.message:String(r)}`}}}}}var ha,Qe,Bt,hp=N(()=>{"use strict";ha=require("child_process"),Qe=O(require("fs")),Bt=O(require("path"))});function Zx(n){let e=n;return e=e.replace(/<(script|style|nav|footer|header|aside|iframe|noscript)[^>]*>[\s\S]*?<\/\1>/gi,""),e=e.replace(/<!--[\s\S]*?-->/g,""),e=e.replace(/<\/(p|div|section|article|li|tr|h[1-6])>/gi,`
370
370
  `),e=e.replace(/<(br|hr)\s*\/?>/gi,`
371
371
  `),e=e.replace(/<\/?(ul|ol)>/gi,`
372
372
  `),e=e.replace(/<h([1-6])[^>]*>([\s\S]*?)<\/h\1>/gi,(t,s,r)=>`
@@ -379,13 +379,13 @@ ${"#".repeat(parseInt(s))} ${r.replace(/<[^>]+>/g,"").trim()}
379
379
  `)}}catch(t){let s=t instanceof Error?t.message:String(t);return{success:!1,output:"",error:`Failed to scrape ${e}: ${s}`}}}},{name:"extract_links",description:"Extract all links (URLs) from a web page. Returns a list of link text and URLs. Useful for finding documentation pages, navigation, or related resources.",safety:"safe",parameters:{url:{type:"string",description:"The URL to extract links from",required:!0},filter:{type:"string",description:"Optional: only return links containing this text in URL or link text",required:!1}},execute:async n=>{let e=n.url,t=n.filter?.toLowerCase()||"";if(!e)return{success:!1,output:"",error:"URL is required"};if(!e.startsWith("http://")&&!e.startsWith("https://"))return{success:!1,output:"",error:"URL must start with http:// or https://"};try{let{html:s,finalUrl:r,status:i}=await bp(e);if(!s||i>=400)return{success:!1,output:"",error:`HTTP ${i} \u2014 could not fetch ${e}`};let o=tS(s,r);if(t&&(o=o.filter(l=>l.url.toLowerCase().includes(t)||l.text.toLowerCase().includes(t))),o.length===0)return{success:!0,output:"No links found"+(t?` matching "${t}"`:"")};let a=o.slice(0,100).map((l,u)=>`${u+1}. [${l.text}](${l.url})`).join(`
380
380
  `);return{success:!0,output:`Found ${o.length} links:
381
381
 
382
- ${a}`}}catch(s){let r=s instanceof Error?s.message:String(s);return{success:!1,output:"",error:`Failed to extract links from ${e}: ${r}`}}}}]}var mp,gp,yp,Xx,wp=N(()=>{"use strict";mp=2*1024*1024,gp=15e3,yp=32e3,Xx="HablasBot/2.0 (+https://hablas.dev)"});function sS(n){let e=An.get(n.toLowerCase().trim());return e?Date.now()-e.timestamp>nS?(An.delete(n.toLowerCase().trim()),null):e.results:null}function rS(n,e){if(An.size>200){let t=An.keys().next().value;t!==void 0&&An.delete(t)}An.set(n.toLowerCase().trim(),{results:e,timestamp:Date.now()})}async function iS(n,e){let t=process.env.BRAVE_API_KEY||process.env.BRAVE_SEARCH_API_KEY;if(!t)return null;try{let s=new URLSearchParams({q:n,count:String(Math.min(e,10))}),r=await fetch(`https://api.search.brave.com/res/v1/web/search?${s}`,{headers:{Accept:"application/json","Accept-Encoding":"gzip","X-Subscription-Token":t},signal:AbortSignal.timeout(1e4)});return r.ok?((await r.json()).web?.results??[]).slice(0,e).map(a=>({title:a.title||"",url:a.url||"",snippet:a.description||"",source:"brave"})):null}catch{return null}}async function oS(n,e){try{let t=new URLSearchParams({q:n}),s=await fetch(`https://html.duckduckgo.com/html/?${t}`,{headers:{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36"},signal:AbortSignal.timeout(1e4)});if(!s.ok)return null;let r=await s.text(),i=[],o=/<a[^>]+class="result__a"[^>]+href="([^"]+)"[^>]*>([\s\S]*?)<\/a>[\s\S]*?<a[^>]+class="result__snippet"[^>]*>([\s\S]*?)<\/a>/gi,a;for(;(a=o.exec(r))!==null&&i.length<e;){let l=a[1],u=a[2].replace(/<[^>]+>/g,"").trim(),d=a[3].replace(/<[^>]+>/g,"").trim(),f=l.match(/uddg=([^&]+)/);if(f)try{l=decodeURIComponent(f[1])}catch{}u&&l&&!l.startsWith("/")&&i.push({title:u,url:l,snippet:d,source:"duckduckgo"})}if(i.length===0){let l=/<a[^>]+href="(https?:\/\/[^"]+)"[^>]*>([\s\S]*?)<\/a>/gi,u=new Set;for(;(a=l.exec(r))!==null&&i.length<e;){let d=a[1],f=a[2].replace(/<[^>]+>/g,"").trim();f&&f.length>5&&!u.has(d)&&!d.includes("duckduckgo.com")&&(u.add(d),i.push({title:f,url:d,snippet:"",source:"duckduckgo"}))}}return i.length>0?i:null}catch{return null}}async function aS(n,e=5){let t=sS(n);if(t)return t.slice(0,e);let s=[{name:"brave",fn:()=>iS(n,e)},{name:"duckduckgo",fn:()=>oS(n,e)}];for(let r of s)try{let i=await r.fn();if(i&&i.length>0)return rS(n,i),i}catch{}return[]}function xp(){return{name:"web_search",description:"Search the web for current information. Returns titles, URLs, and snippets from search results. Use this to find documentation, answers, latest versions, news, or any information not in your training data.",safety:"safe",parameters:{query:{type:"string",description:"The search query",required:!0},max_results:{type:"number",description:"Max results to return (default: 5, max: 10)",required:!1}},execute:async n=>{let e=n.query;if(!e?.trim())return{success:!1,output:"",error:"Search query is required"};let t=Math.min(Math.max(1,n.max_results||5),10);try{let s=await aS(e.trim(),t);if(s.length===0)return{success:!0,output:`No results found for: "${e}". Try rephrasing the search query.`};let r=[`Search results for: "${e}" (${s.length} results, source: ${s[0].source})`,""];for(let i=0;i<s.length;i++){let o=s[i];r.push(`[${i+1}] ${o.title}`),r.push(` ${o.url}`),o.snippet&&r.push(` ${o.snippet}`),r.push("")}return{success:!0,output:r.join(`
383
- `)}}catch(s){return{success:!1,output:"",error:`Search failed: ${s instanceof Error?s.message:String(s)}`}}}}}var nS,An,Sp=N(()=>{"use strict";nS=3600*1e3,An=new Map});function kp(n){let e=n.toString("latin1"),t={},s=[],r=0,i=e.match(/\/Type\s*\/Page\b/g);r=i?i.length:0;let o=e.match(/\/Title\s*\(([^)]*)\)/);o&&(t.title=Xt(o[1]));let a=e.match(/\/Author\s*\(([^)]*)\)/);a&&(t.author=Xt(a[1]));let l=e.match(/\/Subject\s*\(([^)]*)\)/);l&&(t.subject=Xt(l[1]));let u=e.match(/\/Creator\s*\(([^)]*)\)/);u&&(t.creator=Xt(u[1]));let d=/stream\r?\n([\s\S]*?)\r?\nendstream/g,f;for(;(f=d.exec(e))!==null;){let m=f[1],p=$p(m);p.trim()&&s.push(p);try{let g=require("zlib"),x=Buffer.from(m,"latin1"),A=g.inflateSync(x).toString("latin1"),$=$p(A);$.trim()&&!s.includes($)&&s.push($)}catch{}}return{text:s.join(`
382
+ ${a}`}}catch(s){let r=s instanceof Error?s.message:String(s);return{success:!1,output:"",error:`Failed to extract links from ${e}: ${r}`}}}}]}var mp,gp,yp,Xx,wp=N(()=>{"use strict";mp=2*1024*1024,gp=15e3,yp=32e3,Xx="HablasBot/2.0 (+https://hablas.dev)"});function sS(n){let e=kn.get(n.toLowerCase().trim());return e?Date.now()-e.timestamp>nS?(kn.delete(n.toLowerCase().trim()),null):e.results:null}function rS(n,e){if(kn.size>200){let t=kn.keys().next().value;t!==void 0&&kn.delete(t)}kn.set(n.toLowerCase().trim(),{results:e,timestamp:Date.now()})}async function iS(n,e){let t=process.env.BRAVE_API_KEY||process.env.BRAVE_SEARCH_API_KEY;if(!t)return null;try{let s=new URLSearchParams({q:n,count:String(Math.min(e,10))}),r=await fetch(`https://api.search.brave.com/res/v1/web/search?${s}`,{headers:{Accept:"application/json","Accept-Encoding":"gzip","X-Subscription-Token":t},signal:AbortSignal.timeout(1e4)});return r.ok?((await r.json()).web?.results??[]).slice(0,e).map(a=>({title:a.title||"",url:a.url||"",snippet:a.description||"",source:"brave"})):null}catch{return null}}async function oS(n,e){try{let t=new URLSearchParams({q:n}),s=await fetch(`https://html.duckduckgo.com/html/?${t}`,{headers:{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36"},signal:AbortSignal.timeout(1e4)});if(!s.ok)return null;let r=await s.text(),i=[],o=/<a[^>]+class="result__a"[^>]+href="([^"]+)"[^>]*>([\s\S]*?)<\/a>[\s\S]*?<a[^>]+class="result__snippet"[^>]*>([\s\S]*?)<\/a>/gi,a;for(;(a=o.exec(r))!==null&&i.length<e;){let l=a[1],u=a[2].replace(/<[^>]+>/g,"").trim(),d=a[3].replace(/<[^>]+>/g,"").trim(),f=l.match(/uddg=([^&]+)/);if(f)try{l=decodeURIComponent(f[1])}catch{}u&&l&&!l.startsWith("/")&&i.push({title:u,url:l,snippet:d,source:"duckduckgo"})}if(i.length===0){let l=/<a[^>]+href="(https?:\/\/[^"]+)"[^>]*>([\s\S]*?)<\/a>/gi,u=new Set;for(;(a=l.exec(r))!==null&&i.length<e;){let d=a[1],f=a[2].replace(/<[^>]+>/g,"").trim();f&&f.length>5&&!u.has(d)&&!d.includes("duckduckgo.com")&&(u.add(d),i.push({title:f,url:d,snippet:"",source:"duckduckgo"}))}}return i.length>0?i:null}catch{return null}}async function aS(n,e=5){let t=sS(n);if(t)return t.slice(0,e);let s=[{name:"brave",fn:()=>iS(n,e)},{name:"duckduckgo",fn:()=>oS(n,e)}];for(let r of s)try{let i=await r.fn();if(i&&i.length>0)return rS(n,i),i}catch{}return[]}function xp(){return{name:"web_search",description:"Search the web for current information. Returns titles, URLs, and snippets from search results. Use this to find documentation, answers, latest versions, news, or any information not in your training data.",safety:"safe",parameters:{query:{type:"string",description:"The search query",required:!0},max_results:{type:"number",description:"Max results to return (default: 5, max: 10)",required:!1}},execute:async n=>{let e=n.query;if(!e?.trim())return{success:!1,output:"",error:"Search query is required"};let t=Math.min(Math.max(1,n.max_results||5),10);try{let s=await aS(e.trim(),t);if(s.length===0)return{success:!0,output:`No results found for: "${e}". Try rephrasing the search query.`};let r=[`Search results for: "${e}" (${s.length} results, source: ${s[0].source})`,""];for(let i=0;i<s.length;i++){let o=s[i];r.push(`[${i+1}] ${o.title}`),r.push(` ${o.url}`),o.snippet&&r.push(` ${o.snippet}`),r.push("")}return{success:!0,output:r.join(`
383
+ `)}}catch(s){return{success:!1,output:"",error:`Search failed: ${s instanceof Error?s.message:String(s)}`}}}}}var nS,kn,Sp=N(()=>{"use strict";nS=3600*1e3,kn=new Map});function kp(n){let e=n.toString("latin1"),t={},s=[],r=0,i=e.match(/\/Type\s*\/Page\b/g);r=i?i.length:0;let o=e.match(/\/Title\s*\(([^)]*)\)/);o&&(t.title=Zt(o[1]));let a=e.match(/\/Author\s*\(([^)]*)\)/);a&&(t.author=Zt(a[1]));let l=e.match(/\/Subject\s*\(([^)]*)\)/);l&&(t.subject=Zt(l[1]));let u=e.match(/\/Creator\s*\(([^)]*)\)/);u&&(t.creator=Zt(u[1]));let d=/stream\r?\n([\s\S]*?)\r?\nendstream/g,f;for(;(f=d.exec(e))!==null;){let m=f[1],p=$p(m);p.trim()&&s.push(p);try{let g=require("zlib"),x=Buffer.from(m,"latin1"),A=g.inflateSync(x).toString("latin1"),$=$p(A);$.trim()&&!s.includes($)&&s.push($)}catch{}}return{text:s.join(`
384
384
  `).replace(/\r\n/g,`
385
385
  `).replace(/\n{3,}/g,`
386
386
 
387
- `).trim(),pages:r,metadata:t}}function $p(n){let e=[],t=/\(([^)]*)\)\s*Tj/g,s;for(;(s=t.exec(n))!==null;)e.push(Xt(s[1]));let r=/\[((?:\([^)]*\)|[^])*?)\]\s*TJ/g;for(;(s=r.exec(n))!==null;){let l=s[1].match(/\(([^)]*)\)/g);if(l){let u=l.map(d=>Xt(d.slice(1,-1))).join("");e.push(u)}}let i=/\(([^)]*)\)\s*'/g;for(;(s=i.exec(n))!==null;)e.push(Xt(s[1]));let o=e.join(" ");return o=o.replace(/\\n/g,`
388
- `).replace(/\\r/g,"").replace(/\\t/g," ").replace(/\\\(/g,"(").replace(/\\\)/g,")").replace(/\\\\/g,"\\"),o}function Xt(n){return n.replace(/\\n/g,`
387
+ `).trim(),pages:r,metadata:t}}function $p(n){let e=[],t=/\(([^)]*)\)\s*Tj/g,s;for(;(s=t.exec(n))!==null;)e.push(Zt(s[1]));let r=/\[((?:\([^)]*\)|[^])*?)\]\s*TJ/g;for(;(s=r.exec(n))!==null;){let l=s[1].match(/\(([^)]*)\)/g);if(l){let u=l.map(d=>Zt(d.slice(1,-1))).join("");e.push(u)}}let i=/\(([^)]*)\)\s*'/g;for(;(s=i.exec(n))!==null;)e.push(Zt(s[1]));let o=e.join(" ");return o=o.replace(/\\n/g,`
388
+ `).replace(/\\r/g,"").replace(/\\t/g," ").replace(/\\\(/g,"(").replace(/\\\)/g,")").replace(/\\\\/g,"\\"),o}function Zt(n){return n.replace(/\\n/g,`
389
389
  `).replace(/\\r/g,"\r").replace(/\\t/g," ").replace(/\\\(/g,"(").replace(/\\\)/g,")").replace(/\\\\/g,"\\").replace(/\\(\d{3})/g,(e,t)=>String.fromCharCode(parseInt(t,8)))}function Cp(n){let e=t=>Ep.resolve(n,t);return[{name:"read_pdf",description:"Read a PDF file and extract its text content. Returns the text from the PDF, useful for reading documentation, papers, specifications, contracts, etc. For scanned PDFs (images only), text extraction may be limited.",safety:"safe",parameters:{path:{type:"string",description:"Path to the PDF file (relative to working directory)",required:!0},page:{type:"number",description:"Optional: specific page number to extract (1-based)",required:!1}},execute:async t=>{let s=e(t.path);if(!Ot.existsSync(s))return{success:!1,output:"",error:`File not found: ${t.path}`};if(!s.toLowerCase().endsWith(".pdf"))return{success:!1,output:"",error:`Not a PDF file: ${t.path}`};let r=Ot.statSync(s);if(r.size>_p)return{success:!1,output:"",error:`File too large: ${(r.size/1024/1024).toFixed(1)}MB (max: ${_p/1024/1024}MB)`};try{let i=Ot.readFileSync(s),{text:o,pages:a,metadata:l}=kp(i);if(!o||o.length<10)return{success:!0,output:`PDF: ${t.path} (${a} pages)
390
390
 
391
391
  [No extractable text found \u2014 this may be a scanned/image-only PDF. Use OCR tools for scanned documents.]`};let u=o;return u.length>Ap&&(u=u.slice(0,Ap)+`
@@ -393,29 +393,29 @@ ${a}`}}catch(s){let r=s instanceof Error?s.message:String(s);return{success:!1,o
393
393
  [... content truncated ...]`),{success:!0,output:`${[`PDF: ${t.path}`,`Pages: ${a}`,l.title?`Title: ${l.title}`:"",l.author?`Author: ${l.author}`:"",`Size: ${(r.size/1024).toFixed(1)}KB`,""].filter(Boolean).join(`
394
394
  `)}
395
395
  ${u}`}}catch(i){return{success:!1,output:"",error:`Failed to read PDF: ${i instanceof Error?i.message:String(i)}`}}}},{name:"pdf_metadata",description:"Get metadata from a PDF file: page count, title, author, file size. Quick way to inspect a PDF without reading its full content.",safety:"safe",parameters:{path:{type:"string",description:"Path to the PDF file",required:!0}},execute:async t=>{let s=e(t.path);if(!Ot.existsSync(s))return{success:!1,output:"",error:`File not found: ${t.path}`};try{let r=Ot.statSync(s),i=Ot.readFileSync(s),{pages:o,metadata:a}=kp(i);return{success:!0,output:[`File: ${t.path}`,`Size: ${(r.size/1024).toFixed(1)}KB`,`Pages: ${o}`,a.title?`Title: ${a.title}`:null,a.author?`Author: ${a.author}`:null,a.subject?`Subject: ${a.subject}`:null,a.creator?`Creator: ${a.creator}`:null,`Modified: ${r.mtime.toISOString()}`].filter(Boolean).join(`
396
- `)}}catch(r){return{success:!1,output:"",error:`Failed to read PDF metadata: ${r instanceof Error?r.message:String(r)}`}}}}]}var Ot,Ep,_p,Ap,Tp=N(()=>{"use strict";Ot=O(require("fs")),Ep=O(require("path")),_p=50*1024*1024,Ap=4e4});function kn(n){try{let{execSync:e}=require("child_process");return e(`which ${n} 2>/dev/null || where ${n} 2>NUL`,{stdio:"ignore"}),!0}catch{return!1}}async function lS(n,e,t=Lp){let s=Op[e];if(!s)return{success:!1,stdout:"",stderr:`Unsupported language: "${e}". Supported: ${Object.keys(Op).join(", ")}`,exitCode:1,duration:0,language:e};if(!s.available())return{success:!1,stdout:"",stderr:`Language "${e}" is not available on this system. Install the runtime first.`,exitCode:1,duration:0,language:e};let r=Ip.tmpdir(),i=Mp.join(r,`hablas_exec_${Date.now()}${s.extension}`);try{cr.writeFileSync(i,n,"utf-8");let o=s.command(i),a=Date.now();return await new Promise(l=>{let u=(0,Pp.exec)(o,{timeout:t,maxBuffer:5242880,cwd:r,env:{...process.env,NODE_ENV:"production",FORCE_COLOR:"0"}}),d="",f="";u.stdout?.on("data",h=>{d+=h}),u.stderr?.on("data",h=>{f+=h}),u.on("close",h=>{let m=Date.now()-a;l({success:h===0,stdout:d.slice(0,Rp),stderr:f.slice(0,Rp/2),exitCode:h??1,duration:m,language:e})}),u.on("error",h=>{let m=Date.now()-a;l({success:!1,stdout:"",stderr:h.message,exitCode:1,duration:m,language:e})})})}finally{try{cr.unlinkSync(i)}catch{}}}function cS(n){return/\b(interface|type|enum|as\s+\w|:\s*(string|number|boolean|any)\b|<[A-Z]\w*>)/.test(n)?"typescript":/^(import\s+\w|from\s+\w|def\s+\w|class\s+\w|print\s*\(|if\s+__name__)/m.test(n)?"python":/^(#!\/bin\/bash|echo\s|export\s|if\s+\[|for\s+\w+\s+in)/m.test(n)?"bash":"javascript"}function Dp(){return[{name:"execute_code",description:"Execute a code snippet and return the output. Supports JavaScript, TypeScript, Python, and Bash. Code runs in a temporary file with a timeout. Use this to test code, run calculations, verify logic, or prototype solutions.",safety:"confirm",parameters:{code:{type:"string",description:"The code to execute",required:!0},language:{type:"string",description:"Language: javascript, typescript, python, bash (auto-detected if omitted)",required:!1},timeout:{type:"number",description:"Timeout in milliseconds (default: 10000, max: 30000)",required:!1}},execute:async n=>{let e=n.code;if(!e?.trim())return{success:!1,output:"",error:"Code is required"};let t=n.language?.toLowerCase()||cS(e),s=Math.min(Math.max(1e3,n.timeout||Lp),3e4),r=await lS(e,t,s),i=[];return i.push(`Language: ${r.language} | Exit: ${r.exitCode} | Duration: ${r.duration}ms`),i.push(""),r.stdout&&(i.push("Output:"),i.push(r.stdout)),r.stderr&&(i.push(r.stdout?`
396
+ `)}}catch(r){return{success:!1,output:"",error:`Failed to read PDF metadata: ${r instanceof Error?r.message:String(r)}`}}}}]}var Ot,Ep,_p,Ap,Tp=N(()=>{"use strict";Ot=O(require("fs")),Ep=O(require("path")),_p=50*1024*1024,Ap=4e4});function $n(n){try{let{execSync:e}=require("child_process");return e(`which ${n} 2>/dev/null || where ${n} 2>NUL`,{stdio:"ignore"}),!0}catch{return!1}}async function lS(n,e,t=Lp){let s=Op[e];if(!s)return{success:!1,stdout:"",stderr:`Unsupported language: "${e}". Supported: ${Object.keys(Op).join(", ")}`,exitCode:1,duration:0,language:e};if(!s.available())return{success:!1,stdout:"",stderr:`Language "${e}" is not available on this system. Install the runtime first.`,exitCode:1,duration:0,language:e};let r=Ip.tmpdir(),i=Mp.join(r,`hablas_exec_${Date.now()}${s.extension}`);try{fr.writeFileSync(i,n,"utf-8");let o=s.command(i),a=Date.now();return await new Promise(l=>{let u=(0,Pp.exec)(o,{timeout:t,maxBuffer:5242880,cwd:r,env:{...process.env,NODE_ENV:"production",FORCE_COLOR:"0"}}),d="",f="";u.stdout?.on("data",h=>{d+=h}),u.stderr?.on("data",h=>{f+=h}),u.on("close",h=>{let m=Date.now()-a;l({success:h===0,stdout:d.slice(0,Rp),stderr:f.slice(0,Rp/2),exitCode:h??1,duration:m,language:e})}),u.on("error",h=>{let m=Date.now()-a;l({success:!1,stdout:"",stderr:h.message,exitCode:1,duration:m,language:e})})})}finally{try{fr.unlinkSync(i)}catch{}}}function cS(n){return/\b(interface|type|enum|as\s+\w|:\s*(string|number|boolean|any)\b|<[A-Z]\w*>)/.test(n)?"typescript":/^(import\s+\w|from\s+\w|def\s+\w|class\s+\w|print\s*\(|if\s+__name__)/m.test(n)?"python":/^(#!\/bin\/bash|echo\s|export\s|if\s+\[|for\s+\w+\s+in)/m.test(n)?"bash":"javascript"}function Dp(){return[{name:"execute_code",description:"Execute a code snippet and return the output. Supports JavaScript, TypeScript, Python, and Bash. Code runs in a temporary file with a timeout. Use this to test code, run calculations, verify logic, or prototype solutions.",safety:"confirm",parameters:{code:{type:"string",description:"The code to execute",required:!0},language:{type:"string",description:"Language: javascript, typescript, python, bash (auto-detected if omitted)",required:!1},timeout:{type:"number",description:"Timeout in milliseconds (default: 10000, max: 30000)",required:!1}},execute:async n=>{let e=n.code;if(!e?.trim())return{success:!1,output:"",error:"Code is required"};let t=n.language?.toLowerCase()||cS(e),s=Math.min(Math.max(1e3,n.timeout||Lp),3e4),r=await lS(e,t,s),i=[];return i.push(`Language: ${r.language} | Exit: ${r.exitCode} | Duration: ${r.duration}ms`),i.push(""),r.stdout&&(i.push("Output:"),i.push(r.stdout)),r.stderr&&(i.push(r.stdout?`
397
397
  Errors/Warnings:`:"Errors:"),i.push(r.stderr)),!r.stdout&&!r.stderr&&i.push("(no output)"),{success:r.success,output:i.join(`
398
- `),error:r.success?void 0:r.stderr||`Exit code: ${r.exitCode}`}}}]}var Pp,cr,Ip,Mp,Lp,Rp,Op,Np=N(()=>{"use strict";Pp=require("child_process"),cr=O(require("fs")),Ip=O(require("os")),Mp=O(require("path")),Lp=1e4,Rp=16e3;Op={javascript:{extension:".js",command:n=>`node --no-warnings "${n}"`,available:()=>!0},typescript:{extension:".ts",command:n=>kn("tsx")?`tsx "${n}"`:kn("ts-node")?`ts-node --transpileOnly "${n}"`:`node --no-warnings -e "require('esbuild').buildSync({entryPoints:['${n}'],write:false,format:'cjs'}).outputFiles.forEach(f=>eval(f.text))"`,available:()=>!0},python:{extension:".py",command:n=>kn("python3")?`python3 "${n}"`:`python "${n}"`,available:()=>kn("python3")||kn("python")},bash:{extension:".sh",command:n=>`bash "${n}"`,available:()=>kn("bash")}}});var os,Fp=N(()=>{"use strict";np();lp();dp();hp();wp();Sp();Tp();Np();os=class{tools=new Map;constructor(e,t){let s=ep(e);for(let r of s)this.tools.set(r.name,r);this.tools.set("run_command",ap(e,t)),this.tools.set("search_codebase",cp(e)),this.tools.set("detect_bugs",pp(e)),this.tools.set("web_search",xp());for(let r of vp())this.tools.set(r.name,r);for(let r of Cp(e))this.tools.set(r.name,r);for(let r of Dp())this.tools.set(r.name,r)}get(e){return this.tools.get(e)}getAll(){return Array.from(this.tools.values())}getSafetyLevel(e){return this.tools.get(e)?.safety}async execute(e){let t=this.tools.get(e.name);return t?t.execute(e.arguments):{success:!1,output:"",error:`Unknown tool: ${e.name}`}}getOllamaTools(){return this.getAll().map(e=>{let t={},s=[];for(let[r,i]of Object.entries(e.parameters))t[r]={type:i.type==="number"?"number":"string",description:i.description},i.required&&s.push(r);return{type:"function",function:{name:e.name,description:e.description,parameters:{type:"object",properties:t,required:s}}}})}getToolDescriptions(){return this.getAll().map(t=>{let s=Object.entries(t.parameters).map(([r,i])=>` ${r}: ${i.type} \u2014 ${i.description}`).join(`
398
+ `),error:r.success?void 0:r.stderr||`Exit code: ${r.exitCode}`}}}]}var Pp,fr,Ip,Mp,Lp,Rp,Op,Np=N(()=>{"use strict";Pp=require("child_process"),fr=O(require("fs")),Ip=O(require("os")),Mp=O(require("path")),Lp=1e4,Rp=16e3;Op={javascript:{extension:".js",command:n=>`node --no-warnings "${n}"`,available:()=>!0},typescript:{extension:".ts",command:n=>$n("tsx")?`tsx "${n}"`:$n("ts-node")?`ts-node --transpileOnly "${n}"`:`node --no-warnings -e "require('esbuild').buildSync({entryPoints:['${n}'],write:false,format:'cjs'}).outputFiles.forEach(f=>eval(f.text))"`,available:()=>!0},python:{extension:".py",command:n=>$n("python3")?`python3 "${n}"`:`python "${n}"`,available:()=>$n("python3")||$n("python")},bash:{extension:".sh",command:n=>`bash "${n}"`,available:()=>$n("bash")}}});var as,Fp=N(()=>{"use strict";np();lp();dp();hp();wp();Sp();Tp();Np();as=class{tools=new Map;constructor(e,t){let s=ep(e);for(let r of s)this.tools.set(r.name,r);this.tools.set("run_command",ap(e,t)),this.tools.set("search_codebase",cp(e)),this.tools.set("detect_bugs",pp(e)),this.tools.set("web_search",xp());for(let r of vp())this.tools.set(r.name,r);for(let r of Cp(e))this.tools.set(r.name,r);for(let r of Dp())this.tools.set(r.name,r)}get(e){return this.tools.get(e)}getAll(){return Array.from(this.tools.values())}getSafetyLevel(e){return this.tools.get(e)?.safety}async execute(e){let t=this.tools.get(e.name);return t?t.execute(e.arguments):{success:!1,output:"",error:`Unknown tool: ${e.name}`}}getOllamaTools(){return this.getAll().map(e=>{let t={},s=[];for(let[r,i]of Object.entries(e.parameters))t[r]={type:i.type==="number"?"number":"string",description:i.description},i.required&&s.push(r);return{type:"function",function:{name:e.name,description:e.description,parameters:{type:"object",properties:t,required:s}}}})}getToolDescriptions(){return this.getAll().map(t=>{let s=Object.entries(t.parameters).map(([r,i])=>` ${r}: ${i.type} \u2014 ${i.description}`).join(`
399
399
  `);return`- ${t.name} [${t.safety}]: ${t.description}
400
400
  ${s}`}).join(`
401
401
 
402
- `)}}});function ha(n){return Math.ceil(n.length/3.5)}function as(n,e){let t=Math.floor(e*3.5);return n.length<=t?n:n.slice(0,t)+`
403
- ... [truncated to fit context budget]`}var ma=N(()=>{"use strict"});var jp,Zt,ga=N(()=>{"use strict";jp=O(require("crypto"));ma();Zt=class{cache=new Map;budget;usedTokens=0;accessHistory=[];constructor(e){this.budget=e.contextBudget}addFile(e,t,s){let r=this.computeHash(t),i=this.cache.get(e);if(i&&i.hash===r){i.lastUsed=Date.now(),i.accessCount++;return}let o=ha(t),a=s?.importance??this.autoImportance(e,t);this.usedTokens+o>this.budget&&this.evictToFit(o);let l={path:e,content:t,hash:r,lastUsed:Date.now(),tokenCount:o,importance:a,accessCount:i?i.accessCount+1:1,relatedFiles:i?.relatedFiles||[],summarized:!1,tags:s?.tags||this.autoTag(e)};i&&(this.usedTokens-=i.tokenCount),this.cache.set(e,l),this.usedTokens+=o,this.recordAccess(e)}hasChanged(e,t){let s=this.cache.get(e);return s?s.hash!==this.computeHash(t):!0}buildContext(e){let t=e||this.budget,s=Array.from(this.cache.values()).map(o=>({...o,score:this.computeScore(o)})).sort((o,a)=>a.score-o.score),r=0,i=[];for(let o of s){if(r+o.tokenCount>t){if(o.importance>=7){let a=t-r;if(a>200){let l=as(o.content,a);i.push(`--- ${o.path} (truncated, importance: ${o.importance}) ---
402
+ `)}}});function ma(n){return Math.ceil(n.length/3.5)}function ls(n,e){let t=Math.floor(e*3.5);return n.length<=t?n:n.slice(0,t)+`
403
+ ... [truncated to fit context budget]`}var ga=N(()=>{"use strict"});var jp,en,ya=N(()=>{"use strict";jp=O(require("crypto"));ga();en=class{cache=new Map;budget;usedTokens=0;accessHistory=[];constructor(e){this.budget=e.contextBudget}addFile(e,t,s){let r=this.computeHash(t),i=this.cache.get(e);if(i&&i.hash===r){i.lastUsed=Date.now(),i.accessCount++;return}let o=ma(t),a=s?.importance??this.autoImportance(e,t);this.usedTokens+o>this.budget&&this.evictToFit(o);let l={path:e,content:t,hash:r,lastUsed:Date.now(),tokenCount:o,importance:a,accessCount:i?i.accessCount+1:1,relatedFiles:i?.relatedFiles||[],summarized:!1,tags:s?.tags||this.autoTag(e)};i&&(this.usedTokens-=i.tokenCount),this.cache.set(e,l),this.usedTokens+=o,this.recordAccess(e)}hasChanged(e,t){let s=this.cache.get(e);return s?s.hash!==this.computeHash(t):!0}buildContext(e){let t=e||this.budget,s=Array.from(this.cache.values()).map(o=>({...o,score:this.computeScore(o)})).sort((o,a)=>a.score-o.score),r=0,i=[];for(let o of s){if(r+o.tokenCount>t){if(o.importance>=7){let a=t-r;if(a>200){let l=ls(o.content,a);i.push(`--- ${o.path} (truncated, importance: ${o.importance}) ---
404
404
  ${l}`),r+=a}}continue}i.push(`--- ${o.path} ---
405
405
  ${o.content}`),r+=o.tokenCount}return i.join(`
406
406
 
407
407
  `)}buildAgentContext(e,t){let s=t||Math.floor(this.budget*.5),i={alex:[".ts",".js",".tsx",".jsx",".py",".go",".rs",".css",".html"],bob:[".md",".json",".yaml",".yml",".toml",".xml","schema","config"],david:[".md",".csv",".json",".txt",".sql"],emma:[".md",".txt",".json"],hablas:[]}[e]||[],o=Array.from(this.cache.values()).filter(u=>i.length===0?!0:i.some(d=>u.path.includes(d))).sort((u,d)=>this.computeScore(d)-this.computeScore(u)),a=0,l=[];for(let u of o){if(a+u.tokenCount>s)break;l.push(`--- ${u.path} ---
408
408
  ${u.content}`),a+=u.tokenCount}return l.join(`
409
409
 
410
- `)}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=ha(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 jp.createHash("md5").update(e).digest("hex")}}});function ls(){return`msg_${Date.now()}_${++uS}`}function $n(n){return Math.ceil(n.length/4)}var uS,en,ya=N(()=>{"use strict";uS=0;en=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=$n(e);this.messages.push({id:ls(),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=ls(),r=$n(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=ls(),i=$n(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=ls(),r=$n(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=$n(e),s=this.messages.filter(r=>r.priority==="critical"&&r.role!=="system");this.messages=[{id:ls(),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)+`
410
+ `)}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=ma(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 jp.createHash("md5").update(e).digest("hex")}}});function cs(){return`msg_${Date.now()}_${++uS}`}function En(n){return Math.ceil(n.length/4)}var uS,tn,ba=N(()=>{"use strict";uS=0;tn=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=En(e);this.messages.push({id:cs(),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=cs(),r=En(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=cs(),i=En(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=cs(),r=En(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=En(e),s=this.messages.filter(r=>r.priority==="critical"&&r.role!=="system");this.messages=[{id:cs(),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)+`
411
411
  ...(compressed from `+t+" chars)":e.content=e.content.slice(0,400)+`
412
- ...(compressed from `+t+" chars)",e.compressed=!0,e.originalLength=t,e.tokenEstimate=$n(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 Hp,Xe,qe,Bp,ur,ba,dS,fS,pS,cs,Up=N(()=>{"use strict";Hp=O(require("readline")),Xe=O(require("fs")),qe=O(require("path")),Bp=O(require("os"));mn();ur=qe.join(Bp.homedir(),".hablas","history"),ba=500,dS=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"]),fS=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next",".cache"]),pS=["read ","edit ","write ","delete ","open ","patch "],cs=class{rl;history=[];workingDir;fileCache=[];fileCacheTime=0;constructor(e){this.workingDir=e||process.cwd(),this.loadHistory(),this.rl=this.createReadline()}createReadline(){return Hp.createInterface({input:process.stdin,output:process.stdout,terminal:!0,history:this.history,historySize:ba,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(`
412
+ ...(compressed from `+t+" chars)",e.compressed=!0,e.originalLength=t,e.tokenEstimate=En(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 Hp,Xe,qe,Bp,pr,va,dS,fS,pS,us,Up=N(()=>{"use strict";Hp=O(require("readline")),Xe=O(require("fs")),qe=O(require("path")),Bp=O(require("os"));gn();pr=qe.join(Bp.homedir(),".hablas","history"),va=500,dS=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"]),fS=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next",".cache"]),pS=["read ","edit ","write ","delete ","open ","patch "],us=class{rl;history=[];workingDir;fileCache=[];fileCacheTime=0;constructor(e){this.workingDir=e||process.cwd(),this.loadHistory(),this.rl=this.createReadline()}createReadline(){return Hp.createInterface({input:process.stdin,output:process.stdout,terminal:!0,history:this.history,historySize:va,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(`
413
413
  ${c.error("\u26A0")} ${c.error(c.strong(e))}`),console.log(` ${c.muted('This action cannot be undone. Type "yes" to confirm.')}
414
- `);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=eo.filter(r=>r.startsWith(e));return[s.length?s:eo,e]}for(let s of pS)if(e.toLowerCase().includes(s)){let r=e.split(s).pop()??"";if(r&&!r.includes(" "))try{let i=qe.dirname(r)||".",o=qe.basename(r),a=qe.resolve(this.workingDir,i),l=Xe.readdirSync(a).filter(u=>u.startsWith(o)).slice(0,8).map(u=>e.slice(0,e.lastIndexOf(r))+qe.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(".")||fS.has(a.name))continue;let l=t?`${t}/${a.name}`:a.name;if(a.isDirectory())this.scanDir(qe.join(e,a.name),l,s,r,i+1);else{let u=qe.extname(a.name).toLowerCase();(dS.has(u)||a.name==="Dockerfile"||a.name==="Makefile")&&s.push(l)}}}catch{}}loadHistory(){try{if(Xe.existsSync(ur)){let e=Xe.readFileSync(ur,"utf-8");this.history=e.split(`
415
- `).filter(Boolean).slice(-ba)}}catch{}}saveHistory(){try{let e=qe.dirname(ur);Xe.existsSync(e)||Xe.mkdirSync(e,{recursive:!0});let t=this.history.slice(-ba);Xe.writeFileSync(ur,t.join(`
416
- `),"utf-8")}catch{}}}});function Ze(n={}){let e={};if(ot.existsSync(va))try{let s=ot.readFileSync(va,"utf-8");e=JSON.parse(s)}catch{}let t={...Mn,...e,tools:{...Mn.tools,...e.tools||{}},ui:{...Mn.ui,...e.ui||{}}};if(process.env.HABLAS_API_URL&&(t.apiUrl=process.env.HABLAS_API_URL),process.env.HABLAS_API_KEY&&(t.apiKey=process.env.HABLAS_API_KEY),process.env.HABLAS_PROVIDER){let s=process.env.HABLAS_PROVIDER;(s==="ollama"||s==="custom")&&(t.provider=s)}if(process.env.HABLAS_MODEL&&(t.model=process.env.HABLAS_MODEL),n.model&&(t.model=n.model),n.host&&(t.ollamaHost=n.host),n.project&&(t.workingDirectory=tn.resolve(n.project)),n.provider){let s=n.provider;(s==="ollama"||s==="custom")&&(t.provider=s)}return n.apiUrl&&(t.apiUrl=n.apiUrl),n.apiKey&&(t.apiKey=n.apiKey),n.team&&(t.team||(t.team={enabled:!1,user:"",key:""}),t.team.enabled=!0),n.user&&(t.team||(t.team={enabled:!1,user:"",key:""}),t.team.user=n.user),n.teamKey&&(t.team||(t.team={enabled:!1,user:"",key:""}),t.team.key=n.teamKey),t.apiUrl&&t.provider==="ollama"&&(t.provider="custom"),t}function gt(n){ot.existsSync(En)||ot.mkdirSync(En,{recursive:!0}),ot.writeFileSync(va,JSON.stringify(n,null,2),"utf-8")}function Kp(){let n=[En,tn.join(En,"logs"),tn.join(En,"backup")];for(let e of n)ot.existsSync(e)||ot.mkdirSync(e,{recursive:!0})}var ot,tn,qp,En,va,dr=N(()=>{"use strict";ot=O(require("fs")),tn=O(require("path")),qp=O(require("os"));Ln();En=tn.join(qp.homedir(),".hablas"),va=tn.join(En,"config.json")});var us,wa=N(()=>{"use strict";us=class{mindsets=new Map;activeMindset="planner";history=[];lastActivatedAt=Date.now();listeners=[];register(e){this.mindsets.set(e.name,e)}get(e){return this.mindsets.get(e)}list(){return Array.from(this.mindsets.values())}listNames(){return Array.from(this.mindsets.keys())}getActive(){return this.mindsets.get(this.activeMindset)}getActiveName(){return this.activeMindset}setActive(e){if(!this.mindsets.has(e))return!1;if(this.activeMindset===e)return!0;let t=this.activeMindset;if(this.history.length>0){let s=this.history[this.history.length-1];s.duration=Date.now()-this.lastActivatedAt}this.activeMindset=e,this.lastActivatedAt=Date.now(),this.history.push({name:e,timestamp:Date.now()}),this.history.length>50&&(this.history=this.history.slice(-50));for(let s of this.listeners)try{s(t,e)}catch{}return!0}has(e){return this.mindsets.has(e)}getHistory(){return[...this.history]}getMostUsed(){let e={};for(let s of this.history)e[s.name]=(e[s.name]||0)+1;let t=Object.entries(e).sort((s,r)=>r[1]-s[1]);return t.length>0?t[0][0]:null}onChange(e){this.listeners.push(e)}createComposite(e,t,s){let r=this.mindsets.get(t),i=this.mindsets.get(s);if(!r||!i)return null;let o={name:e,description:`${r.description} + ${i.description}`,systemPrompt:r.systemPrompt+`
414
+ `);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=to.filter(r=>r.startsWith(e));return[s.length?s:to,e]}for(let s of pS)if(e.toLowerCase().includes(s)){let r=e.split(s).pop()??"";if(r&&!r.includes(" "))try{let i=qe.dirname(r)||".",o=qe.basename(r),a=qe.resolve(this.workingDir,i),l=Xe.readdirSync(a).filter(u=>u.startsWith(o)).slice(0,8).map(u=>e.slice(0,e.lastIndexOf(r))+qe.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(".")||fS.has(a.name))continue;let l=t?`${t}/${a.name}`:a.name;if(a.isDirectory())this.scanDir(qe.join(e,a.name),l,s,r,i+1);else{let u=qe.extname(a.name).toLowerCase();(dS.has(u)||a.name==="Dockerfile"||a.name==="Makefile")&&s.push(l)}}}catch{}}loadHistory(){try{if(Xe.existsSync(pr)){let e=Xe.readFileSync(pr,"utf-8");this.history=e.split(`
415
+ `).filter(Boolean).slice(-va)}}catch{}}saveHistory(){try{let e=qe.dirname(pr);Xe.existsSync(e)||Xe.mkdirSync(e,{recursive:!0});let t=this.history.slice(-va);Xe.writeFileSync(pr,t.join(`
416
+ `),"utf-8")}catch{}}}});function Ze(n={}){let e={};if(ot.existsSync(wa))try{let s=ot.readFileSync(wa,"utf-8");e=JSON.parse(s)}catch{}let t={...Ln,...e,tools:{...Ln.tools,...e.tools||{}},ui:{...Ln.ui,...e.ui||{}}};if(process.env.HABLAS_API_URL&&(t.apiUrl=process.env.HABLAS_API_URL),process.env.HABLAS_API_KEY&&(t.apiKey=process.env.HABLAS_API_KEY),process.env.HABLAS_PROVIDER){let s=process.env.HABLAS_PROVIDER;(s==="ollama"||s==="custom")&&(t.provider=s)}if(process.env.HABLAS_MODEL&&(t.model=process.env.HABLAS_MODEL),n.model&&(t.model=n.model),n.host&&(t.ollamaHost=n.host),n.project&&(t.workingDirectory=nn.resolve(n.project)),n.provider){let s=n.provider;(s==="ollama"||s==="custom")&&(t.provider=s)}return n.apiUrl&&(t.apiUrl=n.apiUrl),n.apiKey&&(t.apiKey=n.apiKey),n.team&&(t.team||(t.team={enabled:!1,user:"",key:""}),t.team.enabled=!0),n.user&&(t.team||(t.team={enabled:!1,user:"",key:""}),t.team.user=n.user),n.teamKey&&(t.team||(t.team={enabled:!1,user:"",key:""}),t.team.key=n.teamKey),t.apiUrl&&t.provider==="ollama"&&(t.provider="custom"),t}function gt(n){ot.existsSync(Cn)||ot.mkdirSync(Cn,{recursive:!0}),ot.writeFileSync(wa,JSON.stringify(n,null,2),"utf-8")}function Kp(){let n=[Cn,nn.join(Cn,"logs"),nn.join(Cn,"backup")];for(let e of n)ot.existsSync(e)||ot.mkdirSync(e,{recursive:!0})}var ot,nn,qp,Cn,wa,hr=N(()=>{"use strict";ot=O(require("fs")),nn=O(require("path")),qp=O(require("os"));Dn();Cn=nn.join(qp.homedir(),".hablas"),wa=nn.join(Cn,"config.json")});var ds,xa=N(()=>{"use strict";ds=class{mindsets=new Map;activeMindset="planner";history=[];lastActivatedAt=Date.now();listeners=[];register(e){this.mindsets.set(e.name,e)}get(e){return this.mindsets.get(e)}list(){return Array.from(this.mindsets.values())}listNames(){return Array.from(this.mindsets.keys())}getActive(){return this.mindsets.get(this.activeMindset)}getActiveName(){return this.activeMindset}setActive(e){if(!this.mindsets.has(e))return!1;if(this.activeMindset===e)return!0;let t=this.activeMindset;if(this.history.length>0){let s=this.history[this.history.length-1];s.duration=Date.now()-this.lastActivatedAt}this.activeMindset=e,this.lastActivatedAt=Date.now(),this.history.push({name:e,timestamp:Date.now()}),this.history.length>50&&(this.history=this.history.slice(-50));for(let s of this.listeners)try{s(t,e)}catch{}return!0}has(e){return this.mindsets.has(e)}getHistory(){return[...this.history]}getMostUsed(){let e={};for(let s of this.history)e[s.name]=(e[s.name]||0)+1;let t=Object.entries(e).sort((s,r)=>r[1]-s[1]);return t.length>0?t[0][0]:null}onChange(e){this.listeners.push(e)}createComposite(e,t,s){let r=this.mindsets.get(t),i=this.mindsets.get(s);if(!r||!i)return null;let o={name:e,description:`${r.description} + ${i.description}`,systemPrompt:r.systemPrompt+`
417
417
 
418
- `+i.systemPrompt,toolPreferences:[...new Set([...i.toolPreferences,...r.toolPreferences])],behaviorModifiers:{...r.behaviorModifiers,...i.behaviorModifiers}};return this.register(o),o}}});var xa,Sa=N(()=>{"use strict";xa={name:"coder",description:"Expert coding assistant \u2014 direct file operations, precise edits, production-quality code",systemPrompt:`You are Alex, the Engineer on the Hablas multi-agent team. You are an expert full-stack developer.
418
+ `+i.systemPrompt,toolPreferences:[...new Set([...i.toolPreferences,...r.toolPreferences])],behaviorModifiers:{...r.behaviorModifiers,...i.behaviorModifiers}};return this.register(o),o}}});var Sa,_a=N(()=>{"use strict";Sa={name:"coder",description:"Expert coding assistant \u2014 direct file operations, precise edits, production-quality code",systemPrompt:`You are Alex, the Engineer on the Hablas multi-agent team. You are an expert full-stack developer.
419
419
 
420
420
  ## Your Strengths
421
421
  - Writing clean, production-ready code with proper error handling
@@ -447,7 +447,7 @@ ${u.content}`),a+=u.tokenCount}return l.join(`
447
447
 
448
448
  ## Important
449
449
  Never output tool calls as text or JSON in your response.
450
- 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 _a,Aa=N(()=>{"use strict";_a={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.
450
+ 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,ka=N(()=>{"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.
451
451
  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.
452
452
 
453
453
  ## Your Persona (Supportive, Empathetic & Expert Engineering Lead)
@@ -489,7 +489,7 @@ Then execute step by step.
489
489
 
490
490
  ## Important
491
491
  Never output tool calls as text or JSON in your response.
492
- Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","search_codebase","list_dir","write_file","patch_file","run_command"],behaviorModifiers:{planFirst:!0,maxIterations:0,verbosity:"normal",autoConfirmSafe:!0,reasoning:"systematic",askWhenUncertain:!0,canDelegate:!0,contextPriority:"all"}}});var ka,$a=N(()=>{"use strict";ka={name:"reviewer",description:"Code reviewer \u2014 quality audit, anti-patterns, security issues, performance bottlenecks",systemPrompt:`You are an expert code reviewer. You audit code quality and provide actionable feedback.
492
+ Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","search_codebase","list_dir","write_file","patch_file","run_command"],behaviorModifiers:{planFirst:!0,maxIterations:0,verbosity:"normal",autoConfirmSafe:!0,reasoning:"systematic",askWhenUncertain:!0,canDelegate:!0,contextPriority:"all"}}});var $a,Ea=N(()=>{"use strict";$a={name:"reviewer",description:"Code reviewer \u2014 quality audit, anti-patterns, security issues, performance bottlenecks",systemPrompt:`You are an expert code reviewer. You audit code quality and provide actionable feedback.
493
493
 
494
494
  ## Review Checklist
495
495
  - Security vulnerabilities (injection, XSS, CSRF, auth bypass)
@@ -523,7 +523,7 @@ For each issue:
523
523
 
524
524
  ## Important
525
525
  Never output tool calls as text or JSON in your response.
526
- Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","search_codebase","list_dir","get_file_info"],behaviorModifiers:{planFirst:!1,maxIterations:0,verbosity:"verbose",autoConfirmSafe:!0,reasoning:"analytical",askWhenUncertain:!1,canDelegate:!1,contextPriority:"code"},filePatterns:["*.ts","*.js","*.tsx","*.jsx","*.py"]}});var Ea,Ca=N(()=>{"use strict";Ea={name:"debugger",description:"Bug hunter \u2014 traces errors, root cause analysis, targeted fixes, regression prevention",systemPrompt:`You are a systematic debugging expert. You find and fix bugs through methodical investigation.
526
+ Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","search_codebase","list_dir","get_file_info"],behaviorModifiers:{planFirst:!1,maxIterations:0,verbosity:"verbose",autoConfirmSafe:!0,reasoning:"analytical",askWhenUncertain:!1,canDelegate:!1,contextPriority:"code"},filePatterns:["*.ts","*.js","*.tsx","*.jsx","*.py"]}});var Ca,Ta=N(()=>{"use strict";Ca={name:"debugger",description:"Bug hunter \u2014 traces errors, root cause analysis, targeted fixes, regression prevention",systemPrompt:`You are a systematic debugging expert. You find and fix bugs through methodical investigation.
527
527
 
528
528
  ## Debugging Process
529
529
  1. **Reproduce**: Understand the symptom and error message
@@ -545,7 +545,7 @@ Always use the tool_calls field provided by the API.`,toolPreferences:["read_fil
545
545
  ## Important
546
546
  Never output tool calls as text or JSON in your response.
547
547
  Always use the tool_calls field provided by the API.
548
- Focus on the ROOT CAUSE, not symptoms.`,toolPreferences:["read_file","search_codebase","run_command","patch_file","edit_file"],behaviorModifiers:{planFirst:!1,maxIterations:0,verbosity:"normal",autoConfirmSafe:!0,reasoning:"analytical",askWhenUncertain:!0,canDelegate:!1,contextPriority:"code"},filePatterns:["*.ts","*.js","*.py","*.go","*.log","*.json"]}});var Ta,Ra=N(()=>{"use strict";Ta={name:"architect",description:"System architecture \u2014 schemas, APIs, project structure, scalability, ADRs",systemPrompt:`You are Bob, the System Architect on the Hablas multi-agent team.
548
+ Focus on the ROOT CAUSE, not symptoms.`,toolPreferences:["read_file","search_codebase","run_command","patch_file","edit_file"],behaviorModifiers:{planFirst:!1,maxIterations:0,verbosity:"normal",autoConfirmSafe:!0,reasoning:"analytical",askWhenUncertain:!0,canDelegate:!1,contextPriority:"code"},filePatterns:["*.ts","*.js","*.py","*.go","*.log","*.json"]}});var Ra,Oa=N(()=>{"use strict";Ra={name:"architect",description:"System architecture \u2014 schemas, APIs, project structure, scalability, ADRs",systemPrompt:`You are Bob, the System Architect on the Hablas multi-agent team.
549
549
  Your role is to design robust, scalable, maintainable system architectures.
550
550
 
551
551
  ## Your Strengths
@@ -581,7 +581,7 @@ Your role is to design robust, scalable, maintainable system architectures.
581
581
 
582
582
  ## Important
583
583
  Never output tool calls as text or JSON in your response.
584
- Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","list_dir","write_file","search_codebase"],behaviorModifiers:{planFirst:!0,maxIterations:15,verbosity:"verbose",autoConfirmSafe:!0,reasoning:"analytical",askWhenUncertain:!0,canDelegate:!0,contextPriority:"architecture"},filePatterns:["*.md","*.json","*.yaml","*.yml","*.toml","*.xml","schema*","config*"]}});var Oa,Pa=N(()=>{"use strict";Oa={name:"devops",description:"DevOps \u2014 Docker, CI/CD, cloud, monitoring, deployment, infrastructure as code",systemPrompt:`You are a DevOps expert. You handle infrastructure, deployment, and operational concerns.
584
+ Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","list_dir","write_file","search_codebase"],behaviorModifiers:{planFirst:!0,maxIterations:15,verbosity:"verbose",autoConfirmSafe:!0,reasoning:"analytical",askWhenUncertain:!0,canDelegate:!0,contextPriority:"architecture"},filePatterns:["*.md","*.json","*.yaml","*.yml","*.toml","*.xml","schema*","config*"]}});var Pa,Ia=N(()=>{"use strict";Pa={name:"devops",description:"DevOps \u2014 Docker, CI/CD, cloud, monitoring, deployment, infrastructure as code",systemPrompt:`You are a DevOps expert. You handle infrastructure, deployment, and operational concerns.
585
585
 
586
586
  ## Your Expertise
587
587
  - Docker & container orchestration (Kubernetes, Docker Compose)
@@ -612,7 +612,7 @@ Always use the tool_calls field provided by the API.`,toolPreferences:["read_fil
612
612
 
613
613
  ## Important
614
614
  Never output tool calls as text or JSON in your response.
615
- Always use the tool_calls field provided by the API.`,toolPreferences:["run_command","write_file","read_file","list_dir"],behaviorModifiers:{planFirst:!0,maxIterations:20,verbosity:"normal",autoConfirmSafe:!1,reasoning:"systematic",askWhenUncertain:!0,canDelegate:!1,contextPriority:"all"},filePatterns:["Dockerfile*","docker-compose*","*.yml","*.yaml",".github/*","Makefile","*.sh"]}});var Ia,Ma=N(()=>{"use strict";Ia={name:"researcher",description:"Research & analysis \u2014 documentation, APIs, best practices, data analysis, benchmarks",systemPrompt:`You are David, the Data & Research Specialist on the Hablas multi-agent team.
615
+ Always use the tool_calls field provided by the API.`,toolPreferences:["run_command","write_file","read_file","list_dir"],behaviorModifiers:{planFirst:!0,maxIterations:20,verbosity:"normal",autoConfirmSafe:!1,reasoning:"systematic",askWhenUncertain:!0,canDelegate:!1,contextPriority:"all"},filePatterns:["Dockerfile*","docker-compose*","*.yml","*.yaml",".github/*","Makefile","*.sh"]}});var Ma,La=N(()=>{"use strict";Ma={name:"researcher",description:"Research & analysis \u2014 documentation, APIs, best practices, data analysis, benchmarks",systemPrompt:`You are David, the Data & Research Specialist on the Hablas multi-agent team.
616
616
  Your role is to find information, analyze data, and provide well-researched context.
617
617
 
618
618
  ## Your Strengths
@@ -649,7 +649,7 @@ Your role is to find information, analyze data, and provide well-researched cont
649
649
 
650
650
  ## Important
651
651
  Never output tool calls as text or JSON in your response.
652
- Always use the tool_calls field provided by the API.`,toolPreferences:["search_codebase","read_file","run_command","list_dir","web_search"],behaviorModifiers:{planFirst:!1,maxIterations:10,verbosity:"verbose",autoConfirmSafe:!0,reasoning:"exploratory",askWhenUncertain:!0,canDelegate:!1,contextPriority:"data"},filePatterns:["*.md","*.txt","*.csv","*.json","*.sql","*.yml","*.yaml"]}});var La,Da=N(()=>{"use strict";La={name:"product-manager",description:"Product Manager \u2014 requirements, PRDs, user stories, market research, competitive analysis",systemPrompt:`You are Emma, the Product Manager on the Hablas multi-agent team.
652
+ Always use the tool_calls field provided by the API.`,toolPreferences:["search_codebase","read_file","run_command","list_dir","web_search"],behaviorModifiers:{planFirst:!1,maxIterations:10,verbosity:"verbose",autoConfirmSafe:!0,reasoning:"exploratory",askWhenUncertain:!0,canDelegate:!1,contextPriority:"data"},filePatterns:["*.md","*.txt","*.csv","*.json","*.sql","*.yml","*.yaml"]}});var Da,Na=N(()=>{"use strict";Da={name:"product-manager",description:"Product Manager \u2014 requirements, PRDs, user stories, market research, competitive analysis",systemPrompt:`You are Emma, the Product Manager on the Hablas multi-agent team.
653
653
  Your role is to analyze needs, create detailed specs, and ensure the team builds the right thing.
654
654
 
655
655
  ## Your Strengths
@@ -684,7 +684,7 @@ Every PRD you create should include:
684
684
 
685
685
  ## Important
686
686
  Never output tool calls as text or JSON in your response.
687
- Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","write_file","search_codebase","run_command"],behaviorModifiers:{planFirst:!0,maxIterations:15,verbosity:"verbose",autoConfirmSafe:!0,reasoning:"analytical",askWhenUncertain:!0,canDelegate:!0,contextPriority:"requirements"},filePatterns:["*.md","*.txt","*.json","package.json","README*"]}});var Na,Fa=N(()=>{"use strict";Na={name:"sync",description:"Team Coordinator & Diplomatic Consul \u2014 handles lock negotiations, git sync, and team messaging",systemPrompt:`You are @Consul, the Software Diplomat on the Hablas multi-agent team.
687
+ Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","write_file","search_codebase","run_command"],behaviorModifiers:{planFirst:!0,maxIterations:15,verbosity:"verbose",autoConfirmSafe:!0,reasoning:"analytical",askWhenUncertain:!0,canDelegate:!0,contextPriority:"requirements"},filePatterns:["*.md","*.txt","*.json","package.json","README*"]}});var Fa,ja=N(()=>{"use strict";Fa={name:"sync",description:"Team Coordinator & Diplomatic Consul \u2014 handles lock negotiations, git sync, and team messaging",systemPrompt:`You are @Consul, the Software Diplomat on the Hablas multi-agent team.
688
688
  Your absolute priority is to ensure smooth, conflict-free collaboration between human developers and machine agents.
689
689
 
690
690
  ## Your Personality (INTJ + Diplomatic Coordinator)
@@ -706,34 +706,34 @@ Your absolute priority is to ensure smooth, conflict-free collaboration between
706
706
 
707
707
  ## Important
708
708
  Never output tool calls as text or JSON in your response.
709
- 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 fr(){let n=new us;return n.register(xa),n.register(_a),n.register(ka),n.register(Ea),n.register(Ta),n.register(Oa),n.register(Ia),n.register(La),n.register(Na),n}var ja=N(()=>{"use strict";wa();Sa();Aa();$a();Ca();Ra();Pa();Ma();Da();Fa();wa();Sa();Aa();$a();Ca();Ra();Pa();Ma();Da();Fa()});var pr,Gp=N(()=>{"use strict";pr=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(`
710
- `)}}});var Le,hr,Wp,Vp,Cn,ds,zp=N(()=>{"use strict";Le=O(require("fs")),hr=O(require("path")),Wp=O(require("os")),Vp=O(require("crypto")),Cn=hr.join(Wp.homedir(),".hablas","memory"),ds=class{entries=new Map;agentLanes=new Map;projectHash;filePath;agentLanesPath;constructor(e){this.projectHash=Vp.createHash("md5").update(e).digest("hex").slice(0,12),this.filePath=hr.join(Cn,`${this.projectHash}.json`),this.agentLanesPath=hr.join(Cn,`${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
709
+ 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 mr(){let n=new ds;return n.register(Sa),n.register(Aa),n.register($a),n.register(Ca),n.register(Ra),n.register(Pa),n.register(Ma),n.register(Da),n.register(Fa),n}var Ha=N(()=>{"use strict";xa();_a();ka();Ea();Ta();Oa();Ia();La();Na();ja();xa();_a();ka();Ea();Ta();Oa();Ia();La();Na();ja()});var gr,Gp=N(()=>{"use strict";gr=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(`
710
+ `)}}});var Le,yr,Wp,Vp,Tn,fs,zp=N(()=>{"use strict";Le=O(require("fs")),yr=O(require("path")),Wp=O(require("os")),Vp=O(require("crypto")),Tn=yr.join(Wp.homedir(),".hablas","memory"),fs=class{entries=new Map;agentLanes=new Map;projectHash;filePath;agentLanesPath;constructor(e){this.projectHash=Vp.createHash("md5").update(e).digest("hex").slice(0,12),this.filePath=yr.join(Tn,`${this.projectHash}.json`),this.agentLanesPath=yr.join(Tn,`${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
711
711
  `+i.map(a=>`- [${a.category}${a.importance>=7?" \u2605":""}] ${a.key}: ${a.value}`).join(`
712
712
  `)}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(`
713
713
  `)}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(`
714
- `)}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(Le.existsSync(this.filePath)){let e=JSON.parse(Le.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{Le.existsSync(Cn)||Le.mkdirSync(Cn,{recursive:!0});let e=Array.from(this.entries.values());Le.writeFileSync(this.filePath,JSON.stringify(e,null,2),"utf-8")}catch{}}loadAgentLanes(){try{if(Le.existsSync(this.agentLanesPath)){let e=JSON.parse(Le.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{Le.existsSync(Cn)||Le.mkdirSync(Cn,{recursive:!0});let e={};for(let[t,s]of this.agentLanes)e[t]=Array.from(s.values());Le.writeFileSync(this.agentLanesPath,JSON.stringify(e,null,2),"utf-8")}catch{}}}});var Ba=j((XT,Qp)=>{"use strict";var fs=n=>n&&typeof n.message=="string",Ha=n=>{if(!n)return;let e=n.cause;if(typeof e=="function"){let t=n.cause();return fs(t)?t:void 0}else return fs(e)?e:void 0},Yp=(n,e)=>{if(!fs(n))return"";let t=n.stack||"";if(e.has(n))return t+`
715
- causes have become circular...`;let s=Ha(n);return s?(e.add(n),t+`
716
- caused by: `+Yp(s,e)):t},hS=n=>Yp(n,new Set),Jp=(n,e,t)=>{if(!fs(n))return"";let s=t?"":n.message||"";if(e.has(n))return s+": ...";let r=Ha(n);if(r){e.add(n);let i=typeof n.cause=="function";return s+(i?"":": ")+Jp(r,e,i)}else return s},mS=n=>Jp(n,new Set);Qp.exports={isErrorLike:fs,getErrorCause:Ha,stackWithCauses:hS,messageWithCauses:mS}});var Ua=j((ZT,Zp)=>{"use strict";var gS=Symbol("circular-ref-tag"),mr=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[mr]},set:function(n){this[mr]=n}}});Object.defineProperty(Xp,mr,{writable:!0,value:{}});Zp.exports={pinoErrProto:Xp,pinoErrorSymbols:{seen:gS,rawSymbol:mr}}});var nh=j((eR,th)=>{"use strict";th.exports=Ka;var{messageWithCauses:yS,stackWithCauses:bS,isErrorLike:eh}=Ba(),{pinoErrProto:vS,pinoErrorSymbols:wS}=Ua(),{seen:qa}=wS,{toString:xS}=Object.prototype;function Ka(n){if(!eh(n))return n;n[qa]=void 0;let e=Object.create(vS);e.type=xS.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=yS(n),e.stack=bS(n),Array.isArray(n.errors)&&(e.aggregateErrors=n.errors.map(t=>Ka(t)));for(let t in n)if(e[t]===void 0){let s=n[t];eh(s)?t!=="cause"&&!Object.prototype.hasOwnProperty.call(s,qa)&&(e[t]=Ka(s)):e[t]=s}return delete n[qa],e.raw=n,e}});var rh=j((tR,sh)=>{"use strict";sh.exports=yr;var{isErrorLike:Ga}=Ba(),{pinoErrProto:SS,pinoErrorSymbols:_S}=Ua(),{seen:gr}=_S,{toString:AS}=Object.prototype;function yr(n){if(!Ga(n))return n;n[gr]=void 0;let e=Object.create(SS);e.type=AS.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=>yr(t))),Ga(n.cause)&&!Object.prototype.hasOwnProperty.call(n.cause,gr)&&(e.cause=yr(n.cause));for(let t in n)if(e[t]===void 0){let s=n[t];Ga(s)?Object.prototype.hasOwnProperty.call(s,gr)||(e[t]=yr(s)):e[t]=s}return delete n[gr],e.raw=n,e}});var lh=j((nR,ah)=>{"use strict";ah.exports={mapHttpRequest:kS,reqSerializer:oh};var Wa=Symbol("pino-raw-req-ref"),ih=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[Wa]},set:function(n){this[Wa]=n}}});Object.defineProperty(ih,Wa,{writable:!0,value:{}});function oh(n){let e=n.info||n.socket,t=Object.create(ih);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 kS(n){return{req:oh(n)}}});var fh=j((sR,dh)=>{"use strict";dh.exports={mapHttpResponse:$S,resSerializer:uh};var Va=Symbol("pino-raw-res-ref"),ch=Object.create({},{statusCode:{enumerable:!0,writable:!0,value:0},headers:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[Va]},set:function(n){this[Va]=n}}});Object.defineProperty(ch,Va,{writable:!0,value:{}});function uh(n){let e=Object.create(ch);return e.statusCode=n.headersSent?n.statusCode:null,e.headers=n.getHeaders?n.getHeaders():n._headers,e.raw=n,e}function $S(n){return{res:uh(n)}}});var Ya=j((rR,ph)=>{"use strict";var za=nh(),ES=rh(),br=lh(),vr=fh();ph.exports={err:za,errWithCause:ES,mapHttpRequest:br.mapHttpRequest,mapHttpResponse:vr.mapHttpResponse,req:br.reqSerializer,res:vr.resSerializer,wrapErrorSerializer:function(e){return e===za?e:function(s){return e(za(s))}},wrapRequestSerializer:function(e){return e===br.reqSerializer?e:function(s){return e(br.reqSerializer(s))}},wrapResponseSerializer:function(e){return e===vr.resSerializer?e:function(s){return e(vr.resSerializer(s))}}}});var Ja=j((iR,hh)=>{"use strict";function CS(n,e){return e}hh.exports=function(){let e=Error.prepareStackTrace;Error.prepareStackTrace=CS;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 wh=j((oR,vh)=>{"use strict";function Qa(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]=Qa(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]=Qa(n[t]));return e}return n}function mh(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 gh(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 yh(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 wr=Symbol("PATH_NOT_FOUND");function TS(n,e){let t=n;for(let s of e){if(t==null||typeof t!="object"||t===null||!(s in t))return wr;t=t[s]}return t}function RS(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 OS(n,e,t,s=!1){for(let r of e){let i=mh(r);if(i.includes("*"))bh(n,i,t,r,s);else if(s)yh(n,i);else{let o=TS(n,i);if(o===wr)continue;let a=typeof t=="function"?t(o,i):t;gh(n,i,a)}}}function bh(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 PS(n,e,t,i,s,r)}function PS(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("*"))bh(d,a,typeof t=="function"?(m,p)=>{let g=[...l.slice(0,f),...p];return t(m,g)}:t,r,i);else if(i)yh(d,a);else{let h=typeof t=="function"?t(RS(d,a),[...l.slice(0,f),...a]):t;gh(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 IS(n){if(n.length===0)return null;let e=new Map;for(let t of n){let s=mh(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 MS(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 LS(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 DS(n){if(!Array.isArray(n))throw new TypeError("paths must be an array");for(let e of n)LS(e)}function NS(n={}){let{paths:e=[],censor:t="[REDACTED]",serialize:s=JSON.stringify,strict:r=!0,remove:i=!1}=n;DS(e);let o=IS(e);return function(l){if(r&&(l===null||typeof l!="object")&&(l==null||typeof l!="object"))return s?s(l):l;let u=MS(l,o),d=l,f=t;return typeof t=="function"&&(f=t),OS(u,e,f,i),s===!1?(u.restore=function(){return Qa(d)},u):typeof s=="function"?s(u):JSON.stringify(u)}}vh.exports=NS});var Tn=j((aR,xh)=>{"use strict";var FS=Symbol("pino.setLevel"),jS=Symbol("pino.getLevel"),HS=Symbol("pino.levelVal"),BS=Symbol("pino.levelComp"),US=Symbol("pino.useLevelLabels"),qS=Symbol("pino.useOnlyCustomLevels"),KS=Symbol("pino.mixin"),GS=Symbol("pino.lsCache"),WS=Symbol("pino.chindings"),VS=Symbol("pino.asJson"),zS=Symbol("pino.write"),YS=Symbol("pino.redactFmt"),JS=Symbol("pino.time"),QS=Symbol("pino.timeSliceIndex"),XS=Symbol("pino.stream"),ZS=Symbol("pino.stringify"),e_=Symbol("pino.stringifySafe"),t_=Symbol("pino.stringifiers"),n_=Symbol("pino.end"),s_=Symbol("pino.formatOpts"),r_=Symbol("pino.messageKey"),i_=Symbol("pino.errorKey"),o_=Symbol("pino.nestedKey"),a_=Symbol("pino.nestedKeyStr"),l_=Symbol("pino.mixinMergeStrategy"),c_=Symbol("pino.msgPrefix"),u_=Symbol("pino.wildcardFirst"),d_=Symbol.for("pino.serializers"),f_=Symbol.for("pino.formatters"),p_=Symbol.for("pino.hooks"),h_=Symbol.for("pino.metadata");xh.exports={setLevelSym:FS,getLevelSym:jS,levelValSym:HS,levelCompSym:BS,useLevelLabelsSym:US,mixinSym:KS,lsCacheSym:GS,chindingsSym:WS,asJsonSym:VS,writeSym:zS,serializersSym:d_,redactFmtSym:YS,timeSym:JS,timeSliceIndexSym:QS,streamSym:XS,stringifySym:ZS,stringifySafeSym:e_,stringifiersSym:t_,endSym:n_,formatOptsSym:s_,messageKeySym:r_,errorKeySym:i_,nestedKeySym:o_,wildcardFirstSym:u_,needsMetadataGsym:h_,useOnlyCustomLevelsSym:qS,formattersSym:f_,hooksSym:p_,nestedKeyStrSym:a_,mixinMergeStrategySym:l_,msgPrefixSym:c_}});var Za=j((lR,kh)=>{"use strict";var Sh=wh(),{redactFmtSym:m_,wildcardFirstSym:xr}=Tn(),Xa=/[^.[\]]+|\[([^[\]]*?)\]/g,_h="[Redacted]",Ah=!1;function g_(n,e){let{paths:t,censor:s,remove:r}=y_(n),i=t.reduce((l,u)=>{Xa.lastIndex=0;let d=Xa.exec(u),f=Xa.exec(u),h=d[1]!==void 0?d[1].replace(/^(?:"|'|`)(.*)(?:"|'|`)$/,"$1"):d[0];if(h==="*"&&(h=xr),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!==xr&&l[h].length===0&&l[h].push(...l[xr]||[]),h===xr&&Object.keys(l).forEach(function(g){l[g]&&l[g].push(p)}),l[h].push(p),l},{}),o={[m_]:Sh({paths:t,censor:s,serialize:e,strict:Ah,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]=Sh({paths:i[u],censor:d,serialize:e,strict:Ah,remove:r})}return l},o)}function y_(n){if(Array.isArray(n))return n={paths:n,censor:_h},n;let{paths:e,censor:t=_h,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=g_});var Ch=j((cR,Eh)=>{"use strict";var b_=()=>"",v_=()=>`,"time":${Date.now()}`,w_=()=>`,"time":${Math.round(Date.now()/1e3)}`,x_=()=>`,"time":"${new Date(Date.now()).toISOString()}"`,S_=1000000n,$h=1000000000n,__=BigInt(Date.now())*S_,A_=process.hrtime.bigint(),k_=()=>{let n=process.hrtime.bigint()-A_,e=__+n,t=e/$h,s=e%$h,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"`};Eh.exports={nullTime:b_,epochTime:v_,unixTime:w_,isoTime:x_,isoTimeNano:k_}});var Rh=j((uR,Th)=>{"use strict";function $_(n){try{return JSON.stringify(n)}catch{return'"[Circular]"'}}Th.exports=E_;function E_(n,e,t){var s=t&&t.stringify||$_,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 tl=j((dR,el)=>{"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));el.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(););};el.exports=n}});var Fh=j((fR,Nh)=>{"use strict";var le=require("fs"),C_=require("events"),T_=require("util").inherits,Oh=require("path"),sl=tl(),R_=require("assert"),Sr=100,_r=Buffer.allocUnsafe(0),O_=16*1024,Ph="buffer",Ih="utf8",[P_,I_]=(process.versions.node||"0.0").split(".").map(Number),M_=P_>=22&&I_>=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&&le.mkdirSync(Oh.dirname(n),{recursive:!0});let i=le.openSync(n,s,r);t(null,i)}catch(i){throw t(i),i}else e.mkdir?le.mkdir(Oh.dirname(n),{recursive:!0},i=>{if(i)return t(i);le.open(n,s,r,t)}):le.open(n,s,r,t)}function at(n){if(!(this instanceof at))return new at(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||O_,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=_r,this.write=N_,this.flush=j_,this.flushSync=B_,this._actualWrite=q_,p=()=>le.writeSync(this.fd,this._writingBuf),g=()=>le.write(this.fd,this._writingBuf,this.release);else if(h===void 0||h===Ih)this._writingBuf="",this.write=D_,this.flush=F_,this.flushSync=H_,this._actualWrite=U_,p=()=>Buffer.isBuffer(this._writingBuf)?le.writeSync(this.fd,this._writingBuf):le.writeSync(this.fd,this._writingBuf,"utf8"),g=()=>Buffer.isBuffer(this._writingBuf)?le.write(this.fd,this._writingBuf,this.release):le.write(this.fd,this._writingBuf,"utf8",this.release);else throw new Error(`SonicBoom supports "${Ih}" 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=(x,A)=>{if(x){if((x.code==="EAGAIN"||x.code==="EBUSY")&&this.retryEAGAIN(x,this._writingBuf.length,this._len-this._writingBuf.length))if(this.sync)try{sl(Sr),this.release(void 0,0)}catch(y){this.release(y)}else setTimeout(g,Sr);else this._writing=!1,this.emit("error",x);return}this.emit("write",A);let $=nl(this._writingBuf,this._len,A);if(this._len=$.len,this._writingBuf=$.writingBuf,this._writingBuf.length){if(!this.sync){g();return}try{do{let y=p(),v=nl(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&&le.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,Ar(this)):(this._writing=!1,this.sync?this._asyncDrainScheduled||(this._asyncDrainScheduled=!0,process.nextTick(L_,this)):this.emit("drain"))},this.on("newListener",function(x){x==="drain"&&(this._asyncDrainScheduled=!1)}),this._periodicFlush!==0&&(this._periodicFlushTimer=setInterval(()=>this.flush(null),this._periodicFlush),this._periodicFlushTimer.unref())}function nl(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 L_(n){n.listenerCount("drain")>0&&(n._asyncDrainScheduled=!1,n.emit("drain"))}T_(at,C_);function Lh(n,e){return n.length===0?_r:n.length===1?n[0]:Buffer.concat(n,e)}function D_(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 N_(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{le.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 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._actualWrite())}function j_(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())}at.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&&le.close(e,t=>{if(t)return this.emit("error",t)})}),Mh(this.file,this)};at.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():Ar(this)))};function H_(){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)?le.writeSync(this.fd,n):le.writeSync(this.fd,n,"utf8"),t=nl(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;sl(Sr)}}try{le.fsyncSync(this.fd)}catch{}}function B_(){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=_r);let n=_r;for(;this._bufs.length||n.length;){n.length<=0&&(n=Lh(this._bufs[0],this._lens[0]));try{let e=le.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;sl(Sr)}}}at.prototype.destroy=function(){this.destroyed||Ar(this)};function U_(){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)?le.writeSync(this.fd,this._writingBuf):le.writeSync(this.fd,this._writingBuf,"utf8");n(null,e)}catch(e){n(e)}else le.write(this.fd,this._writingBuf,n)}function q_(){let n=this.release;if(this._writing=!0,this._writingBuf=this._writingBuf.length?this._writingBuf:Lh(this._bufs.shift(),this._lens.shift()),this.sync)try{let e=le.writeSync(this.fd,this._writingBuf);n(null,e)}catch(e){n(e)}else M_&&(this._writingBuf=Buffer.from(this._writingBuf)),le.write(this.fd,this._writingBuf,n)}function Ar(n){if(n.fd===-1){n.once("ready",Ar.bind(null,n));return}n._periodicFlushTimer!==void 0&&clearInterval(n._periodicFlushTimer),n.destroyed=!0,n._bufs=[],n._lens=[],R_(typeof n.fd=="number",`sonic.fd must be a number, got ${typeof n.fd}`);try{le.fsync(n.fd,e)}catch{}function e(){n.fd!==1&&n.fd!==2?le.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")}}at.SonicBoom=at;at.default=at;Nh.exports=at});var rl=j((pR,qh)=>{"use strict";var lt={exit:[],beforeExit:[]},jh={exit:W_,beforeExit:V_},Rn;function K_(){Rn===void 0&&(Rn=new FinalizationRegistry(z_))}function G_(n){lt[n].length>0||process.on(n,jh[n])}function Hh(n){lt[n].length>0||(process.removeListener(n,jh[n]),lt.exit.length===0&&lt.beforeExit.length===0&&(Rn=void 0))}function W_(){Bh("exit")}function V_(){Bh("beforeExit")}function Bh(n){for(let e of lt[n]){let t=e.deref(),s=e.fn;t!==void 0&&s(t,n)}lt[n]=[]}function z_(n){for(let e of["exit","beforeExit"]){let t=lt[e].indexOf(n);lt[e].splice(t,t+1),Hh(e)}}function Uh(n,e,t){if(e===void 0)throw new Error("the object can't be undefined");G_(n);let s=new WeakRef(e);s.fn=t,K_(),Rn.register(e,s),lt[n].push(s)}function Y_(n,e){Uh("exit",n,e)}function J_(n,e){Uh("beforeExit",n,e)}function Q_(n){if(Rn!==void 0){Rn.unregister(n);for(let e of["exit","beforeExit"])lt[e]=lt[e].filter(t=>{let s=t.deref();return s&&s!==n}),Hh(e)}}qh.exports={register:Y_,registerBeforeExit:J_,unregister:Q_}});var Kh=j((hR,X_)=>{X_.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=j((mR,Gh)=>{"use strict";function Z_(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 eA(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()}Gh.exports={wait:Z_,waitDiff:eA}});var zh=j((gR,Vh)=>{"use strict";Vh.exports={WRITE_INDEX:4,READ_INDEX:8,SEQ_INDEX:2}});var om=j((yR,im)=>{"use strict";var{version:tA}=Kh(),{EventEmitter:nA}=require("events"),{Worker:sA}=require("worker_threads"),{join:rA}=require("path"),{pathToFileURL:iA}=require("url"),{wait:oA}=Wh(),{WRITE_INDEX:Pt,READ_INDEX:nn,SEQ_INDEX:il}=zh(),aA=require("buffer"),lA=require("assert"),R=Symbol("kImpl"),cA=aA.constants.MAX_STRING_LENGTH;function Yh(){}function cl(n,e){Atomics.add(n[R].state,il,1),e(),Atomics.add(n[R].state,il,1),Atomics.notify(n[R].state,il)}function Jh(n){cl(n,()=>{Atomics.store(n[R].state,nn,0),Atomics.store(n[R].state,Pt,0)})}var ps=class{constructor(e){this._value=e}deref(){return this._value}},kr=class{register(){}unregister(){}},uA=process.env.NODE_V8_COVERAGE?kr:global.FinalizationRegistry||kr,dA=process.env.NODE_V8_COVERAGE?ps:global.WeakRef||ps,Qh=new uA(n=>{n.exited||n.terminate()});function fA(n,e){let{filename:t,workerData:s}=e,i=("__bundlerPathsOverrides"in globalThis?globalThis.__bundlerPathsOverrides:{})["thread-stream-worker"]||rA(__dirname,"lib","worker.js"),o=new sA(i,{...e.workerOpts,name:e.workerOpts?.name||"thread-stream",trackUnmanagedFds:!1,workerData:{filename:t.indexOf("file://")===0?t:iA(t).href,dataBuf:n[R].dataBuf,stateBuf:n[R].stateBuf,workerData:{$context:{threadStreamVersion:tA},...s}}});return o.stream=new ps(n),o.on("message",pA),o.on("exit",em),Qh.register(n,o),o}function Xh(n){lA(!n[R].sync),n[R].needDrain&&(n[R].needDrain=!1,n.emit("drain"))}function Zh(n){for(;;){let e=Atomics.load(n[R].state,Pt),t=n[R].data.length-e;if(t>0){if(n[R].bufLen===0){n[R].flushing=!1,n[R].ending?ul(n):n[R].needDrain&&process.nextTick(Xh,n);return}sm(n,t,Yh);continue}if(t===0){if(e===0&&n[R].bufLen===0)return;$r(n,()=>{n.destroyed||(Jh(n),Zh(n))});return}et(n,new Error("overwritten"));return}}function pA(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 dA(e),$r(e,()=>{e[R].ready=!0,e.emit("ready")});break;case"ERROR":et(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"){et(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:et(e,new Error("this should not happen: "+n.code))}}function em(n){let e=this.stream.deref();e!==void 0&&(Qh.unregister(e),e.worker.exited=!0,e.worker.off("exit",em),et(e,n!==0?new Error("the worker thread exited"):null))}var al=class extends nA{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=fA(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 ll(this,new Error("the worker has exited")),!1;if(this[R].ending)return ll(this,new Error("the worker is ending")),!1;if(this[R].flushing&&this[R].bufLen+t.length>=cA)try{ol(this),this[R].flushing=!0}catch(s){return et(this,s),!1}if(this[R].buf.push(t),this[R].bufLen+=t.length,this[R].sync)try{return ol(this),!0}catch(s){return et(this,s),!1}return this[R].flushing||(this[R].flushing=!0,setImmediate(Zh,this)),this[R].needDrain=this[R].data.length-this[R].bufLen-Atomics.load(this[R].state,Pt)<=0,!this[R].needDrain}end(){this[R].destroyed||(this[R].ending=!0,ul(this))}flush(e){e=typeof e=="function"?e:Yh,tm(this,t=>{if(t){process.nextTick(e,t);return}nm(this,e)})}flushSync(){this[R].destroyed||(ol(this),rm(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 tm(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(tm,n,e);return}$r(n,e)}function $r(n,e){let t=Atomics.load(n[R].state,Pt);oA(n[R].state,nn,t,1/0,(s,r)=>{if(s){et(n,s),e(s);return}if(r!=="ok"){$r(n,e);return}e()})}function nm(n,e){if(n[R].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[R].ready){let s=()=>{i(),nm(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),et(n,s),process.nextTick(e,s)}}function hA(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 ll(n,e){setImmediate(()=>{n.emit("error",e)})}function et(n,e){n[R].destroyed||(n[R].destroyed=!0,hA(n,e),e&&(n[R].errored=e,ll(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 sm(n,e,t){let r=Atomics.load(n[R].state,Pt),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 cl(n,()=>{Atomics.store(n[R].state,Pt,r)}),t(),!0}function ul(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,nn);cl(n,()=>{Atomics.store(n[R].state,Pt,-1)});let t=0;for(;e!==-1;){if(Atomics.wait(n[R].state,nn,e,1e3),e=Atomics.load(n[R].state,nn),e===-2){et(n,new Error("end() failed"));return}if(++t===10){et(n,new Error("end() took too long (10s)"));return}}process.nextTick(()=>{n[R].finished=!0,n.emit("finish")})}catch(e){et(n,e)}}}function ol(n){let e=()=>{n[R].ending?ul(n):n[R].needDrain&&process.nextTick(Xh,n)};for(n[R].flushing=!1;n[R].bufLen!==0;){let t=Atomics.load(n[R].state,Pt),s=n[R].data.length-t;if(s===0){rm(n),Jh(n);continue}else if(s<0)throw new Error("overwritten");sm(n,s,e)}}function rm(n){if(n[R].flushing)throw new Error("unable to flush while flushing");let e=Atomics.load(n[R].state,Pt),t=0;for(;;){let s=Atomics.load(n[R].state,nn);if(s===-2)throw Error("_flushSync failed");if(s!==e)Atomics.wait(n[R].state,nn,s,1e3);else break;if(++t===10)throw new Error("_flushSync took too long (10s)")}}im.exports=al});var pl=j((bR,cm)=>{"use strict";var{createRequire:mA}=require("module"),{existsSync:gA}=require("node:fs"),yA=Ja(),{join:dl,isAbsolute:lm,sep:bA}=require("node:path"),{fileURLToPath:vA}=require("node:url"),wA=tl(),fl=rl(),xA=om();function SA(n){fl.register(n,EA),fl.registerBeforeExit(n,CA),n.on("close",function(){fl.unregister(n)})}function _A(){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 AA(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&&am(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(am(o)){s=!0;continue}}t.push(i)}return s?t.join(" "):n}function am(n){let e=kA(n);if(!e)return!1;let t=e;if(t.startsWith("file://"))try{t=vA(t)}catch{return!1}return lm(t)&&!gA(t)}function kA(n){let e=n[0],t=n[n.length-1];return e==='"'&&t==='"'||e==="'"&&t==="'"?n.slice(1,-1):n}function $A(n,e,t,s,r){if(!t.execArgv&&_A()&&require.main===void 0&&(t={...t,execArgv:[]}),!t.env&&process.env.NODE_OPTIONS){let l=AA(process.env.NODE_OPTIONS);l!==process.env.NODE_OPTIONS&&(t={...t,env:{...process.env,NODE_OPTIONS:l}})}t={...t,name:r};let i=new xA({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&&SA(i)}function a(){i.closed||(i.flushSync(),wA(100),i.end())}return i}function EA(n){n.ref(),n.flushSync(),n.end(),n.once("close",function(){n.unref()})}function CA(n){n.flushSync()}function TA(n){let{pipeline:e,targets:t,levels:s,dedupe:r,worker:i={},caller:o=yA(),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"]||dl(__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"]||dl(__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 $A(m(f),l,i,a,h);function m(p){if(p=d[p]||p,lm(p)||p.indexOf("file://")===0)return p;if(p==="pino/file")return dl(__dirname,"..","file.js");let g;for(let x of u)try{let A=x==="node:repl"?process.cwd()+bA:x;g=mA(A).resolve(p);break}catch{continue}if(!g)throw new Error(`unable to determine transport target for "${p}"`);return g}}cm.exports=TA});var Tr=j((vR,Sm)=>{"use strict";var RA=require("node:diagnostics_channel"),um=Rh(),{mapHttpRequest:OA,mapHttpResponse:PA}=Ya(),ml=Fh(),dm=rl(),{lsCacheSym:IA,chindingsSym:gm,writeSym:fm,serializersSym:ym,formatOptsSym:pm,endSym:MA,stringifiersSym:bm,stringifySym:vm,stringifySafeSym:gl,wildcardFirstSym:wm,nestedKeySym:LA,formattersSym:xm,messageKeySym:DA,errorKeySym:NA,nestedKeyStrSym:FA,msgPrefixSym:Er}=Tn(),{isMainThread:jA}=require("worker_threads"),HA=pl(),[BA]=process.versions.node.split(".").map(n=>Number(n)),hm=RA.tracingChannel("pino_asJson"),hl=BA>=25?n=>JSON.stringify(n):qA;function On(){}function UA(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=OA(s):typeof s.setHeader=="function"&&(s=PA(s)));let o;i===null&&r.length===0?o=[null]:(i=r.shift(),o=r),typeof this[Er]=="string"&&i!==void 0&&i!==null&&(i=this[Er]+i),this[fm](s,um(i,o,this[pm]),n)}else{let i=s===void 0?r.shift():s;typeof this[Er]=="string"&&i!==void 0&&i!==null&&(i=this[Er]+i),this[fm](null,um(i,r,this[pm]),n)}}}function qA(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 KA(n,e,t,s){if(hm.hasSubscribers===!1)return mm.call(this,n,e,t,s);let r={instance:this,arguments};return hm.traceSync(mm,r,this,n,e,t,s)}function mm(n,e,t,s){let r=this[vm],i=this[gl],o=this[bm],a=this[MA],l=this[gm],u=this[ym],d=this[xm],f=this[DA],h=this[NA],m=this[IA][t]+s;m=m+l;let p;d.log&&(n=d.log(n));let g=o[wm],x="";for(let $ in n)if(p=n[$],Object.prototype.hasOwnProperty.call(n,$)&&p!==void 0){u[$]?p=u[$](p):$===h&&u.err&&(p=u.err(p));let _=o[$]||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=(_||hl)(p);break;default:p=(_||r)(p,i)}if(p===void 0)continue;let y=hl($);x+=","+y+":"+p}let A="";if(e!==void 0){p=u[f]?u[f](e):e;let $=o[f]||g;switch(typeof p){case"function":break;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":$&&(p=$(p)),A=',"'+f+'":'+p;break;case"string":p=($||hl)(p),A=',"'+f+'":'+p;break;default:p=($||r)(p,i),A=',"'+f+'":'+p}}return this[LA]&&x?m+this[FA]+x.slice(1)+"}"+A+a:m+x+A+a}function GA(n,e){let t,s=n[gm],r=n[vm],i=n[gl],o=n[bm],a=o[wm],l=n[ym],u=n[xm].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 WA(n){return n.write!==n.constructor.prototype.write}function Cr(n){let e=new ml(n);return e.on("error",t),!n.sync&&jA&&(dm.register(e,VA),e.on("close",function(){dm.unregister(e)})),e;function t(s){if(s.code==="EPIPE"){e.write=On,e.end=On,e.flushSync=On,e.destroy=On;return}e.removeListener("error",t),e.emit("error",s)}}function VA(n,e){n.destroyed||(e==="beforeExit"?(n.flush(),n.on("drain",function(){n.end()})):n.flushSync())}function zA(n){return function(t,s,r={},i){if(typeof r=="string")i=Cr({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=Cr({dest:i})}else if(r instanceof ml||r.writable||r._writableState)i=r,r={};else if(r.transport){if(r.transport instanceof ml||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=HA({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=On),i||(WA(process.stdout)?i=process.stdout:i=Cr({fd:process.stdout.fd||1})),{opts:r,stream:i}}}function YA(n,e){try{return JSON.stringify(n)}catch{try{return(e||this[gl])(n)}catch{return'"[unable to serialize, circular reference is too complex to analyze]"'}}}function JA(n,e,t){return{level:n,bindings:e,log:t}}function QA(n){let e=Number(n);return typeof n=="string"&&Number.isFinite(e)?e:n===void 0?1:n}Sm.exports={noop:On,buildSafeSonicBoom:Cr,asChindings:GA,asJson:KA,genLog:UA,createArgsNormalizer:zA,stringify:YA,buildFormatters:JA,normalizeDestFileDescriptor:QA}});var Rr=j((wR,_m)=>{var XA={trace:10,debug:20,info:30,warn:40,error:50,fatal:60},ZA={ASC:"ASC",DESC:"DESC"};_m.exports={DEFAULT_LEVELS:XA,SORTING_ORDER:ZA}});var vl=j((xR,Em)=>{"use strict";var{lsCacheSym:ek,levelValSym:yl,useOnlyCustomLevelsSym:tk,streamSym:nk,formattersSym:sk,hooksSym:rk,levelCompSym:Am}=Tn(),{noop:ik,genLog:sn}=Tr(),{DEFAULT_LEVELS:yt,SORTING_ORDER:km}=Rr(),$m={fatal:n=>{let e=sn(yt.fatal,n);return function(...t){let s=this[nk];if(e.call(this,...t),typeof s.flushSync=="function")try{s.flushSync()}catch{}}},error:n=>sn(yt.error,n),warn:n=>sn(yt.warn,n),info:n=>sn(yt.info,n),debug:n=>sn(yt.debug,n),trace:n=>sn(yt.trace,n)},bl=Object.keys(yt).reduce((n,e)=>(n[yt[e]]=e,n),{}),ok=Object.keys(bl).reduce((n,e)=>(n[e]='{"level":'+Number(e),n),{});function ak(n){let e=n[sk].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[ek]=s,n}function lk(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 ck(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[yl],r=this[yl]=t[n],i=this[tk],o=this[Am],a=this[rk].logMethod;for(let l in t){if(o(t[l],r)===!1){this[l]=ik;continue}this[l]=lk(l,i)?$m[l](a):sn(t[l],a)}this.emit("level-change",n,r,e[s],s,this)}function uk(n){let{levels:e,levelVal:t}=this;return e&&e.labels?e.labels[t]:""}function dk(n){let{values:e}=this.levels,t=e[n];return t!==void 0&&this[Am](t,this[yl])}function fk(n,e,t){return n===km.DESC?e<=t:e>=t}function pk(n){return typeof n=="string"?fk.bind(null,n):n}function hk(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:bl,t),r=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),e?null:yt,n);return{labels:s,values:r}}function mk(n,e,t){if(typeof n=="number"){if(![].concat(Object.keys(e||{}).map(i=>e[i]),t?[]:Object.keys(bl).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:yt,e);if(!(n in s))throw Error(`default level:${n} must be included in custom levels`)}function gk(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 yk(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')}Em.exports={initialLsCache:ok,genLsCache:ak,levelMethods:$m,getLevel:uk,setLevel:ck,isLevelEnabled:dk,mappings:hk,assertNoLevelCollisions:gk,assertDefaultLevelFound:mk,genLevelComparison:pk,assertLevelComparison:yk}});var wl=j((SR,Cm)=>{"use strict";Cm.exports={version:"10.3.1"}});var Dm=j((AR,Lm)=>{"use strict";var{EventEmitter:bk}=require("node:events"),{lsCacheSym:vk,levelValSym:wk,setLevelSym:Sl,getLevelSym:Tm,chindingsSym:Pr,mixinSym:xk,asJsonSym:Om,writeSym:Sk,mixinMergeStrategySym:_k,timeSym:Ak,timeSliceIndexSym:kk,streamSym:Pm,serializersSym:rn,formattersSym:hs,errorKeySym:$k,messageKeySym:Ek,useOnlyCustomLevelsSym:Ck,needsMetadataGsym:Tk,redactFmtSym:Rk,stringifySym:Ok,formatOptsSym:Pk,stringifiersSym:Ik,msgPrefixSym:_l,hooksSym:Mk}=Tn(),{getLevel:Lk,setLevel:Dk,isLevelEnabled:Nk,mappings:Fk,initialLsCache:jk,genLsCache:Hk,assertNoLevelCollisions:Bk}=vl(),{asChindings:Al,asJson:Uk,buildFormatters:xl,stringify:Rm,noop:Im}=Tr(),{version:qk}=wl(),Kk=Za(),Gk=class{},Mm={constructor:Gk,child:Wk,bindings:Vk,setBindings:zk,flush:Qk,isLevelEnabled:Nk,version:qk,get level(){return this[Tm]()},set level(n){this[Sl](n)},get levelVal(){return this[wk]},set levelVal(n){throw Error("levelVal is read-only")},get msgPrefix(){return this[_l]},get[Symbol.toStringTag](){return"Pino"},[vk]:jk,[Sk]:Jk,[Om]:Uk,[Tm]:Lk,[Sl]:Dk};Object.setPrototypeOf(Mm,bk.prototype);Lm.exports=function(){return Object.create(Mm)};var Or=n=>n;function Wk(n,e){if(!n)throw Error("missing bindings for child Pino");let t=this[rn],s=this[hs],r=Object.create(this);if(e==null)return r[hs].bindings!==Or&&(r[hs]=xl(s.level,Or,s.log)),r[Pr]=Al(r,n),this.onChild!==Im&&this.onChild(r),r;if(e.hasOwnProperty("serializers")===!0){r[rn]=Object.create(null);for(let u in t)r[rn][u]=t[u];let a=Object.getOwnPropertySymbols(t);for(var i=0;i<a.length;i++){let u=a[i];r[rn][u]=t[u]}for(let u in e.serializers)r[rn][u]=e.serializers[u];let l=Object.getOwnPropertySymbols(e.serializers);for(var o=0;o<l.length;o++){let u=l[o];r[rn][u]=e.serializers[u]}}else r[rn]=t;if(e.hasOwnProperty("formatters")){let{level:a,bindings:l,log:u}=e.formatters;r[hs]=xl(a||s.level,l||Or,u||s.log)}else r[hs]=xl(s.level,Or,s.log);if(e.hasOwnProperty("customLevels")===!0&&(Bk(this.levels,e.customLevels),r.levels=Fk(e.customLevels,r[Ck]),Hk(r)),typeof e.redact=="object"&&e.redact!==null||Array.isArray(e.redact)){r.redact=e.redact;let a=Kk(r.redact,Rm),l={stringify:a[Rk]};r[Ok]=Rm,r[Ik]=a,r[Pk]=l}if(typeof e.msgPrefix=="string"&&(r[_l]=(this[_l]||"")+e.msgPrefix),r[Pr]=Al(r,n),e.level!==void 0&&e.level!==this.level||e.hasOwnProperty("customLevels")){let a=e.level||this.level;r[Sl](a)}return this.onChild(r),r}function Vk(){let e=`{${this[Pr].substr(1)}}`,t=JSON.parse(e);return delete t.pid,delete t.hostname,t}function zk(n){let e=Al(this,n);this[Pr]=e}function Yk(n,e){return Object.assign(e,n)}function Jk(n,e,t){let s=this[Ak](),r=this[xk],i=this[$k],o=this[Ek],a=this[_k]||Yk,l,u=this[Mk].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[Om](l,e,t,s),f=this[Pm];f[Tk]===!0&&(f.lastLevel=t,f.lastObj=l,f.lastMsg=e,f.lastTime=s.slice(this[kk]),f.lastLogger=this),f.write(u?u(d):d)}function Qk(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||Im):n&&n()}});var Hm=j((Cl,jm)=>{"use strict";var{hasOwnProperty:ms}=Object.prototype,an=El();an.configure=El;an.stringify=an;an.default=an;Cl.stringify=an;Cl.configure=El;jm.exports=an;var Xk=/[\u0000-\u001f\u0022\u005c\ud800-\udfff]/;function Ut(n){return n.length<5e3&&!Xk.test(n)?`"${n}"`:JSON.stringify(n)}function kl(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 Zk=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(Object.getPrototypeOf(new Int8Array)),Symbol.toStringTag).get;function $l(n){return Zk.call(n)!==void 0&&n.length!==0}function Nm(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 e$(n){if(ms.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 t$(n){let e;if(ms.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 n$(n,e){let t;if(ms.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(ms.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 on(n){return n===1?"1 item":`${n} items`}function s$(n){let e=new Set;for(let t of n)(typeof t=="string"||typeof t=="number")&&e.add(String(t));return e}function r$(n){if(ms.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=r$(n);e&&(n.bigint===void 0&&(n.bigint=!1),"circularValue"in n||(n.circularValue=Error));let t=e$(n),s=n$(n,"bigint"),r=t$(n),i=typeof r=="function"?r:void 0,o=Fm(n,"maximumDepth"),a=Fm(n,"maximumBreadth");function l(m,p,g,x,A,$){let _=p[m];switch(typeof _=="object"&&_!==null&&typeof _.toJSON=="function"&&(_=_.toJSON(m)),_=x.call(p,m,_),typeof _){case"string":return Ut(_);case"object":{if(_===null)return"null";if(g.indexOf(_)!==-1)return t;let y="",v=",",b=$;if(Array.isArray(_)){if(_.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(_),A!==""&&($+=A,y+=`
714
+ `)}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(Le.existsSync(this.filePath)){let e=JSON.parse(Le.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{Le.existsSync(Tn)||Le.mkdirSync(Tn,{recursive:!0});let e=Array.from(this.entries.values());Le.writeFileSync(this.filePath,JSON.stringify(e,null,2),"utf-8")}catch{}}loadAgentLanes(){try{if(Le.existsSync(this.agentLanesPath)){let e=JSON.parse(Le.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{Le.existsSync(Tn)||Le.mkdirSync(Tn,{recursive:!0});let e={};for(let[t,s]of this.agentLanes)e[t]=Array.from(s.values());Le.writeFileSync(this.agentLanesPath,JSON.stringify(e,null,2),"utf-8")}catch{}}}});var Ua=j((XT,Qp)=>{"use strict";var ps=n=>n&&typeof n.message=="string",Ba=n=>{if(!n)return;let e=n.cause;if(typeof e=="function"){let t=n.cause();return ps(t)?t:void 0}else return ps(e)?e:void 0},Yp=(n,e)=>{if(!ps(n))return"";let t=n.stack||"";if(e.has(n))return t+`
715
+ causes have become circular...`;let s=Ba(n);return s?(e.add(n),t+`
716
+ caused by: `+Yp(s,e)):t},hS=n=>Yp(n,new Set),Jp=(n,e,t)=>{if(!ps(n))return"";let s=t?"":n.message||"";if(e.has(n))return s+": ...";let r=Ba(n);if(r){e.add(n);let i=typeof n.cause=="function";return s+(i?"":": ")+Jp(r,e,i)}else return s},mS=n=>Jp(n,new Set);Qp.exports={isErrorLike:ps,getErrorCause:Ba,stackWithCauses:hS,messageWithCauses:mS}});var qa=j((ZT,Zp)=>{"use strict";var gS=Symbol("circular-ref-tag"),br=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[br]},set:function(n){this[br]=n}}});Object.defineProperty(Xp,br,{writable:!0,value:{}});Zp.exports={pinoErrProto:Xp,pinoErrorSymbols:{seen:gS,rawSymbol:br}}});var nh=j((eR,th)=>{"use strict";th.exports=Ga;var{messageWithCauses:yS,stackWithCauses:bS,isErrorLike:eh}=Ua(),{pinoErrProto:vS,pinoErrorSymbols:wS}=qa(),{seen:Ka}=wS,{toString:xS}=Object.prototype;function Ga(n){if(!eh(n))return n;n[Ka]=void 0;let e=Object.create(vS);e.type=xS.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=yS(n),e.stack=bS(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];eh(s)?t!=="cause"&&!Object.prototype.hasOwnProperty.call(s,Ka)&&(e[t]=Ga(s)):e[t]=s}return delete n[Ka],e.raw=n,e}});var rh=j((tR,sh)=>{"use strict";sh.exports=wr;var{isErrorLike:Wa}=Ua(),{pinoErrProto:SS,pinoErrorSymbols:_S}=qa(),{seen:vr}=_S,{toString:AS}=Object.prototype;function wr(n){if(!Wa(n))return n;n[vr]=void 0;let e=Object.create(SS);e.type=AS.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=>wr(t))),Wa(n.cause)&&!Object.prototype.hasOwnProperty.call(n.cause,vr)&&(e.cause=wr(n.cause));for(let t in n)if(e[t]===void 0){let s=n[t];Wa(s)?Object.prototype.hasOwnProperty.call(s,vr)||(e[t]=wr(s)):e[t]=s}return delete n[vr],e.raw=n,e}});var lh=j((nR,ah)=>{"use strict";ah.exports={mapHttpRequest:kS,reqSerializer:oh};var Va=Symbol("pino-raw-req-ref"),ih=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[Va]},set:function(n){this[Va]=n}}});Object.defineProperty(ih,Va,{writable:!0,value:{}});function oh(n){let e=n.info||n.socket,t=Object.create(ih);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 kS(n){return{req:oh(n)}}});var fh=j((sR,dh)=>{"use strict";dh.exports={mapHttpResponse:$S,resSerializer:uh};var za=Symbol("pino-raw-res-ref"),ch=Object.create({},{statusCode:{enumerable:!0,writable:!0,value:0},headers:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[za]},set:function(n){this[za]=n}}});Object.defineProperty(ch,za,{writable:!0,value:{}});function uh(n){let e=Object.create(ch);return e.statusCode=n.headersSent?n.statusCode:null,e.headers=n.getHeaders?n.getHeaders():n._headers,e.raw=n,e}function $S(n){return{res:uh(n)}}});var Ja=j((rR,ph)=>{"use strict";var Ya=nh(),ES=rh(),xr=lh(),Sr=fh();ph.exports={err:Ya,errWithCause:ES,mapHttpRequest:xr.mapHttpRequest,mapHttpResponse:Sr.mapHttpResponse,req:xr.reqSerializer,res:Sr.resSerializer,wrapErrorSerializer:function(e){return e===Ya?e:function(s){return e(Ya(s))}},wrapRequestSerializer:function(e){return e===xr.reqSerializer?e:function(s){return e(xr.reqSerializer(s))}},wrapResponseSerializer:function(e){return e===Sr.resSerializer?e:function(s){return e(Sr.resSerializer(s))}}}});var Qa=j((iR,hh)=>{"use strict";function CS(n,e){return e}hh.exports=function(){let e=Error.prepareStackTrace;Error.prepareStackTrace=CS;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 wh=j((oR,vh)=>{"use strict";function Xa(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]=Xa(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]=Xa(n[t]));return e}return n}function mh(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 gh(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 yh(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 TS(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 RS(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 OS(n,e,t,s=!1){for(let r of e){let i=mh(r);if(i.includes("*"))bh(n,i,t,r,s);else if(s)yh(n,i);else{let o=TS(n,i);if(o===_r)continue;let a=typeof t=="function"?t(o,i):t;gh(n,i,a)}}}function bh(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 PS(n,e,t,i,s,r)}function PS(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("*"))bh(d,a,typeof t=="function"?(m,p)=>{let g=[...l.slice(0,f),...p];return t(m,g)}:t,r,i);else if(i)yh(d,a);else{let h=typeof t=="function"?t(RS(d,a),[...l.slice(0,f),...a]):t;gh(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 IS(n){if(n.length===0)return null;let e=new Map;for(let t of n){let s=mh(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 MS(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 LS(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 DS(n){if(!Array.isArray(n))throw new TypeError("paths must be an array");for(let e of n)LS(e)}function NS(n={}){let{paths:e=[],censor:t="[REDACTED]",serialize:s=JSON.stringify,strict:r=!0,remove:i=!1}=n;DS(e);let o=IS(e);return function(l){if(r&&(l===null||typeof l!="object")&&(l==null||typeof l!="object"))return s?s(l):l;let u=MS(l,o),d=l,f=t;return typeof t=="function"&&(f=t),OS(u,e,f,i),s===!1?(u.restore=function(){return Xa(d)},u):typeof s=="function"?s(u):JSON.stringify(u)}}vh.exports=NS});var Rn=j((aR,xh)=>{"use strict";var FS=Symbol("pino.setLevel"),jS=Symbol("pino.getLevel"),HS=Symbol("pino.levelVal"),BS=Symbol("pino.levelComp"),US=Symbol("pino.useLevelLabels"),qS=Symbol("pino.useOnlyCustomLevels"),KS=Symbol("pino.mixin"),GS=Symbol("pino.lsCache"),WS=Symbol("pino.chindings"),VS=Symbol("pino.asJson"),zS=Symbol("pino.write"),YS=Symbol("pino.redactFmt"),JS=Symbol("pino.time"),QS=Symbol("pino.timeSliceIndex"),XS=Symbol("pino.stream"),ZS=Symbol("pino.stringify"),e_=Symbol("pino.stringifySafe"),t_=Symbol("pino.stringifiers"),n_=Symbol("pino.end"),s_=Symbol("pino.formatOpts"),r_=Symbol("pino.messageKey"),i_=Symbol("pino.errorKey"),o_=Symbol("pino.nestedKey"),a_=Symbol("pino.nestedKeyStr"),l_=Symbol("pino.mixinMergeStrategy"),c_=Symbol("pino.msgPrefix"),u_=Symbol("pino.wildcardFirst"),d_=Symbol.for("pino.serializers"),f_=Symbol.for("pino.formatters"),p_=Symbol.for("pino.hooks"),h_=Symbol.for("pino.metadata");xh.exports={setLevelSym:FS,getLevelSym:jS,levelValSym:HS,levelCompSym:BS,useLevelLabelsSym:US,mixinSym:KS,lsCacheSym:GS,chindingsSym:WS,asJsonSym:VS,writeSym:zS,serializersSym:d_,redactFmtSym:YS,timeSym:JS,timeSliceIndexSym:QS,streamSym:XS,stringifySym:ZS,stringifySafeSym:e_,stringifiersSym:t_,endSym:n_,formatOptsSym:s_,messageKeySym:r_,errorKeySym:i_,nestedKeySym:o_,wildcardFirstSym:u_,needsMetadataGsym:h_,useOnlyCustomLevelsSym:qS,formattersSym:f_,hooksSym:p_,nestedKeyStrSym:a_,mixinMergeStrategySym:l_,msgPrefixSym:c_}});var el=j((lR,kh)=>{"use strict";var Sh=wh(),{redactFmtSym:m_,wildcardFirstSym:Ar}=Rn(),Za=/[^.[\]]+|\[([^[\]]*?)\]/g,_h="[Redacted]",Ah=!1;function g_(n,e){let{paths:t,censor:s,remove:r}=y_(n),i=t.reduce((l,u)=>{Za.lastIndex=0;let d=Za.exec(u),f=Za.exec(u),h=d[1]!==void 0?d[1].replace(/^(?:"|'|`)(.*)(?:"|'|`)$/,"$1"):d[0];if(h==="*"&&(h=Ar),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!==Ar&&l[h].length===0&&l[h].push(...l[Ar]||[]),h===Ar&&Object.keys(l).forEach(function(g){l[g]&&l[g].push(p)}),l[h].push(p),l},{}),o={[m_]:Sh({paths:t,censor:s,serialize:e,strict:Ah,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]=Sh({paths:i[u],censor:d,serialize:e,strict:Ah,remove:r})}return l},o)}function y_(n){if(Array.isArray(n))return n={paths:n,censor:_h},n;let{paths:e,censor:t=_h,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=g_});var Ch=j((cR,Eh)=>{"use strict";var b_=()=>"",v_=()=>`,"time":${Date.now()}`,w_=()=>`,"time":${Math.round(Date.now()/1e3)}`,x_=()=>`,"time":"${new Date(Date.now()).toISOString()}"`,S_=1000000n,$h=1000000000n,__=BigInt(Date.now())*S_,A_=process.hrtime.bigint(),k_=()=>{let n=process.hrtime.bigint()-A_,e=__+n,t=e/$h,s=e%$h,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"`};Eh.exports={nullTime:b_,epochTime:v_,unixTime:w_,isoTime:x_,isoTimeNano:k_}});var Rh=j((uR,Th)=>{"use strict";function $_(n){try{return JSON.stringify(n)}catch{return'"[Circular]"'}}Th.exports=E_;function E_(n,e,t){var s=t&&t.stringify||$_,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 nl=j((dR,tl)=>{"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));tl.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(););};tl.exports=n}});var Fh=j((fR,Nh)=>{"use strict";var le=require("fs"),C_=require("events"),T_=require("util").inherits,Oh=require("path"),rl=nl(),R_=require("assert"),kr=100,$r=Buffer.allocUnsafe(0),O_=16*1024,Ph="buffer",Ih="utf8",[P_,I_]=(process.versions.node||"0.0").split(".").map(Number),M_=P_>=22&&I_>=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&&le.mkdirSync(Oh.dirname(n),{recursive:!0});let i=le.openSync(n,s,r);t(null,i)}catch(i){throw t(i),i}else e.mkdir?le.mkdir(Oh.dirname(n),{recursive:!0},i=>{if(i)return t(i);le.open(n,s,r,t)}):le.open(n,s,r,t)}function at(n){if(!(this instanceof at))return new at(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||O_,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=$r,this.write=N_,this.flush=j_,this.flushSync=B_,this._actualWrite=q_,p=()=>le.writeSync(this.fd,this._writingBuf),g=()=>le.write(this.fd,this._writingBuf,this.release);else if(h===void 0||h===Ih)this._writingBuf="",this.write=D_,this.flush=F_,this.flushSync=H_,this._actualWrite=U_,p=()=>Buffer.isBuffer(this._writingBuf)?le.writeSync(this.fd,this._writingBuf):le.writeSync(this.fd,this._writingBuf,"utf8"),g=()=>Buffer.isBuffer(this._writingBuf)?le.write(this.fd,this._writingBuf,this.release):le.write(this.fd,this._writingBuf,"utf8",this.release);else throw new Error(`SonicBoom supports "${Ih}" 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=(x,A)=>{if(x){if((x.code==="EAGAIN"||x.code==="EBUSY")&&this.retryEAGAIN(x,this._writingBuf.length,this._len-this._writingBuf.length))if(this.sync)try{rl(kr),this.release(void 0,0)}catch(y){this.release(y)}else setTimeout(g,kr);else this._writing=!1,this.emit("error",x);return}this.emit("write",A);let $=sl(this._writingBuf,this._len,A);if(this._len=$.len,this._writingBuf=$.writingBuf,this._writingBuf.length){if(!this.sync){g();return}try{do{let y=p(),v=sl(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&&le.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,Er(this)):(this._writing=!1,this.sync?this._asyncDrainScheduled||(this._asyncDrainScheduled=!0,process.nextTick(L_,this)):this.emit("drain"))},this.on("newListener",function(x){x==="drain"&&(this._asyncDrainScheduled=!1)}),this._periodicFlush!==0&&(this._periodicFlushTimer=setInterval(()=>this.flush(null),this._periodicFlush),this._periodicFlushTimer.unref())}function sl(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 L_(n){n.listenerCount("drain")>0&&(n._asyncDrainScheduled=!1,n.emit("drain"))}T_(at,C_);function Lh(n,e){return n.length===0?$r:n.length===1?n[0]:Buffer.concat(n,e)}function D_(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 N_(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{le.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 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._actualWrite())}function j_(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())}at.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&&le.close(e,t=>{if(t)return this.emit("error",t)})}),Mh(this.file,this)};at.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():Er(this)))};function H_(){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)?le.writeSync(this.fd,n):le.writeSync(this.fd,n,"utf8"),t=sl(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;rl(kr)}}try{le.fsyncSync(this.fd)}catch{}}function B_(){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=$r);let n=$r;for(;this._bufs.length||n.length;){n.length<=0&&(n=Lh(this._bufs[0],this._lens[0]));try{let e=le.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;rl(kr)}}}at.prototype.destroy=function(){this.destroyed||Er(this)};function U_(){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)?le.writeSync(this.fd,this._writingBuf):le.writeSync(this.fd,this._writingBuf,"utf8");n(null,e)}catch(e){n(e)}else le.write(this.fd,this._writingBuf,n)}function q_(){let n=this.release;if(this._writing=!0,this._writingBuf=this._writingBuf.length?this._writingBuf:Lh(this._bufs.shift(),this._lens.shift()),this.sync)try{let e=le.writeSync(this.fd,this._writingBuf);n(null,e)}catch(e){n(e)}else M_&&(this._writingBuf=Buffer.from(this._writingBuf)),le.write(this.fd,this._writingBuf,n)}function Er(n){if(n.fd===-1){n.once("ready",Er.bind(null,n));return}n._periodicFlushTimer!==void 0&&clearInterval(n._periodicFlushTimer),n.destroyed=!0,n._bufs=[],n._lens=[],R_(typeof n.fd=="number",`sonic.fd must be a number, got ${typeof n.fd}`);try{le.fsync(n.fd,e)}catch{}function e(){n.fd!==1&&n.fd!==2?le.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")}}at.SonicBoom=at;at.default=at;Nh.exports=at});var il=j((pR,qh)=>{"use strict";var lt={exit:[],beforeExit:[]},jh={exit:W_,beforeExit:V_},On;function K_(){On===void 0&&(On=new FinalizationRegistry(z_))}function G_(n){lt[n].length>0||process.on(n,jh[n])}function Hh(n){lt[n].length>0||(process.removeListener(n,jh[n]),lt.exit.length===0&&lt.beforeExit.length===0&&(On=void 0))}function W_(){Bh("exit")}function V_(){Bh("beforeExit")}function Bh(n){for(let e of lt[n]){let t=e.deref(),s=e.fn;t!==void 0&&s(t,n)}lt[n]=[]}function z_(n){for(let e of["exit","beforeExit"]){let t=lt[e].indexOf(n);lt[e].splice(t,t+1),Hh(e)}}function Uh(n,e,t){if(e===void 0)throw new Error("the object can't be undefined");G_(n);let s=new WeakRef(e);s.fn=t,K_(),On.register(e,s),lt[n].push(s)}function Y_(n,e){Uh("exit",n,e)}function J_(n,e){Uh("beforeExit",n,e)}function Q_(n){if(On!==void 0){On.unregister(n);for(let e of["exit","beforeExit"])lt[e]=lt[e].filter(t=>{let s=t.deref();return s&&s!==n}),Hh(e)}}qh.exports={register:Y_,registerBeforeExit:J_,unregister:Q_}});var Kh=j((hR,X_)=>{X_.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=j((mR,Gh)=>{"use strict";function Z_(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 eA(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()}Gh.exports={wait:Z_,waitDiff:eA}});var zh=j((gR,Vh)=>{"use strict";Vh.exports={WRITE_INDEX:4,READ_INDEX:8,SEQ_INDEX:2}});var om=j((yR,im)=>{"use strict";var{version:tA}=Kh(),{EventEmitter:nA}=require("events"),{Worker:sA}=require("worker_threads"),{join:rA}=require("path"),{pathToFileURL:iA}=require("url"),{wait:oA}=Wh(),{WRITE_INDEX:Pt,READ_INDEX:sn,SEQ_INDEX:ol}=zh(),aA=require("buffer"),lA=require("assert"),R=Symbol("kImpl"),cA=aA.constants.MAX_STRING_LENGTH;function Yh(){}function ul(n,e){Atomics.add(n[R].state,ol,1),e(),Atomics.add(n[R].state,ol,1),Atomics.notify(n[R].state,ol)}function Jh(n){ul(n,()=>{Atomics.store(n[R].state,sn,0),Atomics.store(n[R].state,Pt,0)})}var hs=class{constructor(e){this._value=e}deref(){return this._value}},Cr=class{register(){}unregister(){}},uA=process.env.NODE_V8_COVERAGE?Cr:global.FinalizationRegistry||Cr,dA=process.env.NODE_V8_COVERAGE?hs:global.WeakRef||hs,Qh=new uA(n=>{n.exited||n.terminate()});function fA(n,e){let{filename:t,workerData:s}=e,i=("__bundlerPathsOverrides"in globalThis?globalThis.__bundlerPathsOverrides:{})["thread-stream-worker"]||rA(__dirname,"lib","worker.js"),o=new sA(i,{...e.workerOpts,name:e.workerOpts?.name||"thread-stream",trackUnmanagedFds:!1,workerData:{filename:t.indexOf("file://")===0?t:iA(t).href,dataBuf:n[R].dataBuf,stateBuf:n[R].stateBuf,workerData:{$context:{threadStreamVersion:tA},...s}}});return o.stream=new hs(n),o.on("message",pA),o.on("exit",em),Qh.register(n,o),o}function Xh(n){lA(!n[R].sync),n[R].needDrain&&(n[R].needDrain=!1,n.emit("drain"))}function Zh(n){for(;;){let e=Atomics.load(n[R].state,Pt),t=n[R].data.length-e;if(t>0){if(n[R].bufLen===0){n[R].flushing=!1,n[R].ending?dl(n):n[R].needDrain&&process.nextTick(Xh,n);return}sm(n,t,Yh);continue}if(t===0){if(e===0&&n[R].bufLen===0)return;Tr(n,()=>{n.destroyed||(Jh(n),Zh(n))});return}et(n,new Error("overwritten"));return}}function pA(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 dA(e),Tr(e,()=>{e[R].ready=!0,e.emit("ready")});break;case"ERROR":et(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"){et(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:et(e,new Error("this should not happen: "+n.code))}}function em(n){let e=this.stream.deref();e!==void 0&&(Qh.unregister(e),e.worker.exited=!0,e.worker.off("exit",em),et(e,n!==0?new Error("the worker thread exited"):null))}var ll=class extends nA{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=fA(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 cl(this,new Error("the worker has exited")),!1;if(this[R].ending)return cl(this,new Error("the worker is ending")),!1;if(this[R].flushing&&this[R].bufLen+t.length>=cA)try{al(this),this[R].flushing=!0}catch(s){return et(this,s),!1}if(this[R].buf.push(t),this[R].bufLen+=t.length,this[R].sync)try{return al(this),!0}catch(s){return et(this,s),!1}return this[R].flushing||(this[R].flushing=!0,setImmediate(Zh,this)),this[R].needDrain=this[R].data.length-this[R].bufLen-Atomics.load(this[R].state,Pt)<=0,!this[R].needDrain}end(){this[R].destroyed||(this[R].ending=!0,dl(this))}flush(e){e=typeof e=="function"?e:Yh,tm(this,t=>{if(t){process.nextTick(e,t);return}nm(this,e)})}flushSync(){this[R].destroyed||(al(this),rm(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 tm(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(tm,n,e);return}Tr(n,e)}function Tr(n,e){let t=Atomics.load(n[R].state,Pt);oA(n[R].state,sn,t,1/0,(s,r)=>{if(s){et(n,s),e(s);return}if(r!=="ok"){Tr(n,e);return}e()})}function nm(n,e){if(n[R].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[R].ready){let s=()=>{i(),nm(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),et(n,s),process.nextTick(e,s)}}function hA(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 cl(n,e){setImmediate(()=>{n.emit("error",e)})}function et(n,e){n[R].destroyed||(n[R].destroyed=!0,hA(n,e),e&&(n[R].errored=e,cl(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 sm(n,e,t){let r=Atomics.load(n[R].state,Pt),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 ul(n,()=>{Atomics.store(n[R].state,Pt,r)}),t(),!0}function dl(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,sn);ul(n,()=>{Atomics.store(n[R].state,Pt,-1)});let t=0;for(;e!==-1;){if(Atomics.wait(n[R].state,sn,e,1e3),e=Atomics.load(n[R].state,sn),e===-2){et(n,new Error("end() failed"));return}if(++t===10){et(n,new Error("end() took too long (10s)"));return}}process.nextTick(()=>{n[R].finished=!0,n.emit("finish")})}catch(e){et(n,e)}}}function al(n){let e=()=>{n[R].ending?dl(n):n[R].needDrain&&process.nextTick(Xh,n)};for(n[R].flushing=!1;n[R].bufLen!==0;){let t=Atomics.load(n[R].state,Pt),s=n[R].data.length-t;if(s===0){rm(n),Jh(n);continue}else if(s<0)throw new Error("overwritten");sm(n,s,e)}}function rm(n){if(n[R].flushing)throw new Error("unable to flush while flushing");let e=Atomics.load(n[R].state,Pt),t=0;for(;;){let s=Atomics.load(n[R].state,sn);if(s===-2)throw Error("_flushSync failed");if(s!==e)Atomics.wait(n[R].state,sn,s,1e3);else break;if(++t===10)throw new Error("_flushSync took too long (10s)")}}im.exports=ll});var hl=j((bR,cm)=>{"use strict";var{createRequire:mA}=require("module"),{existsSync:gA}=require("node:fs"),yA=Qa(),{join:fl,isAbsolute:lm,sep:bA}=require("node:path"),{fileURLToPath:vA}=require("node:url"),wA=nl(),pl=il(),xA=om();function SA(n){pl.register(n,EA),pl.registerBeforeExit(n,CA),n.on("close",function(){pl.unregister(n)})}function _A(){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 AA(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&&am(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(am(o)){s=!0;continue}}t.push(i)}return s?t.join(" "):n}function am(n){let e=kA(n);if(!e)return!1;let t=e;if(t.startsWith("file://"))try{t=vA(t)}catch{return!1}return lm(t)&&!gA(t)}function kA(n){let e=n[0],t=n[n.length-1];return e==='"'&&t==='"'||e==="'"&&t==="'"?n.slice(1,-1):n}function $A(n,e,t,s,r){if(!t.execArgv&&_A()&&require.main===void 0&&(t={...t,execArgv:[]}),!t.env&&process.env.NODE_OPTIONS){let l=AA(process.env.NODE_OPTIONS);l!==process.env.NODE_OPTIONS&&(t={...t,env:{...process.env,NODE_OPTIONS:l}})}t={...t,name:r};let i=new xA({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&&SA(i)}function a(){i.closed||(i.flushSync(),wA(100),i.end())}return i}function EA(n){n.ref(),n.flushSync(),n.end(),n.once("close",function(){n.unref()})}function CA(n){n.flushSync()}function TA(n){let{pipeline:e,targets:t,levels:s,dedupe:r,worker:i={},caller:o=yA(),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"]||fl(__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"]||fl(__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 $A(m(f),l,i,a,h);function m(p){if(p=d[p]||p,lm(p)||p.indexOf("file://")===0)return p;if(p==="pino/file")return fl(__dirname,"..","file.js");let g;for(let x of u)try{let A=x==="node:repl"?process.cwd()+bA:x;g=mA(A).resolve(p);break}catch{continue}if(!g)throw new Error(`unable to determine transport target for "${p}"`);return g}}cm.exports=TA});var Pr=j((vR,Sm)=>{"use strict";var RA=require("node:diagnostics_channel"),um=Rh(),{mapHttpRequest:OA,mapHttpResponse:PA}=Ja(),gl=Fh(),dm=il(),{lsCacheSym:IA,chindingsSym:gm,writeSym:fm,serializersSym:ym,formatOptsSym:pm,endSym:MA,stringifiersSym:bm,stringifySym:vm,stringifySafeSym:yl,wildcardFirstSym:wm,nestedKeySym:LA,formattersSym:xm,messageKeySym:DA,errorKeySym:NA,nestedKeyStrSym:FA,msgPrefixSym:Rr}=Rn(),{isMainThread:jA}=require("worker_threads"),HA=hl(),[BA]=process.versions.node.split(".").map(n=>Number(n)),hm=RA.tracingChannel("pino_asJson"),ml=BA>=25?n=>JSON.stringify(n):qA;function Pn(){}function UA(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=OA(s):typeof s.setHeader=="function"&&(s=PA(s)));let o;i===null&&r.length===0?o=[null]:(i=r.shift(),o=r),typeof this[Rr]=="string"&&i!==void 0&&i!==null&&(i=this[Rr]+i),this[fm](s,um(i,o,this[pm]),n)}else{let i=s===void 0?r.shift():s;typeof this[Rr]=="string"&&i!==void 0&&i!==null&&(i=this[Rr]+i),this[fm](null,um(i,r,this[pm]),n)}}}function qA(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 KA(n,e,t,s){if(hm.hasSubscribers===!1)return mm.call(this,n,e,t,s);let r={instance:this,arguments};return hm.traceSync(mm,r,this,n,e,t,s)}function mm(n,e,t,s){let r=this[vm],i=this[yl],o=this[bm],a=this[MA],l=this[gm],u=this[ym],d=this[xm],f=this[DA],h=this[NA],m=this[IA][t]+s;m=m+l;let p;d.log&&(n=d.log(n));let g=o[wm],x="";for(let $ in n)if(p=n[$],Object.prototype.hasOwnProperty.call(n,$)&&p!==void 0){u[$]?p=u[$](p):$===h&&u.err&&(p=u.err(p));let _=o[$]||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=(_||ml)(p);break;default:p=(_||r)(p,i)}if(p===void 0)continue;let y=ml($);x+=","+y+":"+p}let A="";if(e!==void 0){p=u[f]?u[f](e):e;let $=o[f]||g;switch(typeof p){case"function":break;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":$&&(p=$(p)),A=',"'+f+'":'+p;break;case"string":p=($||ml)(p),A=',"'+f+'":'+p;break;default:p=($||r)(p,i),A=',"'+f+'":'+p}}return this[LA]&&x?m+this[FA]+x.slice(1)+"}"+A+a:m+x+A+a}function GA(n,e){let t,s=n[gm],r=n[vm],i=n[yl],o=n[bm],a=o[wm],l=n[ym],u=n[xm].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 WA(n){return n.write!==n.constructor.prototype.write}function Or(n){let e=new gl(n);return e.on("error",t),!n.sync&&jA&&(dm.register(e,VA),e.on("close",function(){dm.unregister(e)})),e;function t(s){if(s.code==="EPIPE"){e.write=Pn,e.end=Pn,e.flushSync=Pn,e.destroy=Pn;return}e.removeListener("error",t),e.emit("error",s)}}function VA(n,e){n.destroyed||(e==="beforeExit"?(n.flush(),n.on("drain",function(){n.end()})):n.flushSync())}function zA(n){return function(t,s,r={},i){if(typeof r=="string")i=Or({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=Or({dest:i})}else if(r instanceof gl||r.writable||r._writableState)i=r,r={};else if(r.transport){if(r.transport instanceof gl||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=HA({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=Pn),i||(WA(process.stdout)?i=process.stdout:i=Or({fd:process.stdout.fd||1})),{opts:r,stream:i}}}function YA(n,e){try{return JSON.stringify(n)}catch{try{return(e||this[yl])(n)}catch{return'"[unable to serialize, circular reference is too complex to analyze]"'}}}function JA(n,e,t){return{level:n,bindings:e,log:t}}function QA(n){let e=Number(n);return typeof n=="string"&&Number.isFinite(e)?e:n===void 0?1:n}Sm.exports={noop:Pn,buildSafeSonicBoom:Or,asChindings:GA,asJson:KA,genLog:UA,createArgsNormalizer:zA,stringify:YA,buildFormatters:JA,normalizeDestFileDescriptor:QA}});var Ir=j((wR,_m)=>{var XA={trace:10,debug:20,info:30,warn:40,error:50,fatal:60},ZA={ASC:"ASC",DESC:"DESC"};_m.exports={DEFAULT_LEVELS:XA,SORTING_ORDER:ZA}});var wl=j((xR,Em)=>{"use strict";var{lsCacheSym:ek,levelValSym:bl,useOnlyCustomLevelsSym:tk,streamSym:nk,formattersSym:sk,hooksSym:rk,levelCompSym:Am}=Rn(),{noop:ik,genLog:rn}=Pr(),{DEFAULT_LEVELS:yt,SORTING_ORDER:km}=Ir(),$m={fatal:n=>{let e=rn(yt.fatal,n);return function(...t){let s=this[nk];if(e.call(this,...t),typeof s.flushSync=="function")try{s.flushSync()}catch{}}},error:n=>rn(yt.error,n),warn:n=>rn(yt.warn,n),info:n=>rn(yt.info,n),debug:n=>rn(yt.debug,n),trace:n=>rn(yt.trace,n)},vl=Object.keys(yt).reduce((n,e)=>(n[yt[e]]=e,n),{}),ok=Object.keys(vl).reduce((n,e)=>(n[e]='{"level":'+Number(e),n),{});function ak(n){let e=n[sk].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[ek]=s,n}function lk(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 ck(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[bl],r=this[bl]=t[n],i=this[tk],o=this[Am],a=this[rk].logMethod;for(let l in t){if(o(t[l],r)===!1){this[l]=ik;continue}this[l]=lk(l,i)?$m[l](a):rn(t[l],a)}this.emit("level-change",n,r,e[s],s,this)}function uk(n){let{levels:e,levelVal:t}=this;return e&&e.labels?e.labels[t]:""}function dk(n){let{values:e}=this.levels,t=e[n];return t!==void 0&&this[Am](t,this[bl])}function fk(n,e,t){return n===km.DESC?e<=t:e>=t}function pk(n){return typeof n=="string"?fk.bind(null,n):n}function hk(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:vl,t),r=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),e?null:yt,n);return{labels:s,values:r}}function mk(n,e,t){if(typeof n=="number"){if(![].concat(Object.keys(e||{}).map(i=>e[i]),t?[]:Object.keys(vl).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:yt,e);if(!(n in s))throw Error(`default level:${n} must be included in custom levels`)}function gk(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 yk(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')}Em.exports={initialLsCache:ok,genLsCache:ak,levelMethods:$m,getLevel:uk,setLevel:ck,isLevelEnabled:dk,mappings:hk,assertNoLevelCollisions:gk,assertDefaultLevelFound:mk,genLevelComparison:pk,assertLevelComparison:yk}});var xl=j((SR,Cm)=>{"use strict";Cm.exports={version:"10.3.1"}});var Dm=j((AR,Lm)=>{"use strict";var{EventEmitter:bk}=require("node:events"),{lsCacheSym:vk,levelValSym:wk,setLevelSym:_l,getLevelSym:Tm,chindingsSym:Lr,mixinSym:xk,asJsonSym:Om,writeSym:Sk,mixinMergeStrategySym:_k,timeSym:Ak,timeSliceIndexSym:kk,streamSym:Pm,serializersSym:on,formattersSym:ms,errorKeySym:$k,messageKeySym:Ek,useOnlyCustomLevelsSym:Ck,needsMetadataGsym:Tk,redactFmtSym:Rk,stringifySym:Ok,formatOptsSym:Pk,stringifiersSym:Ik,msgPrefixSym:Al,hooksSym:Mk}=Rn(),{getLevel:Lk,setLevel:Dk,isLevelEnabled:Nk,mappings:Fk,initialLsCache:jk,genLsCache:Hk,assertNoLevelCollisions:Bk}=wl(),{asChindings:kl,asJson:Uk,buildFormatters:Sl,stringify:Rm,noop:Im}=Pr(),{version:qk}=xl(),Kk=el(),Gk=class{},Mm={constructor:Gk,child:Wk,bindings:Vk,setBindings:zk,flush:Qk,isLevelEnabled:Nk,version:qk,get level(){return this[Tm]()},set level(n){this[_l](n)},get levelVal(){return this[wk]},set levelVal(n){throw Error("levelVal is read-only")},get msgPrefix(){return this[Al]},get[Symbol.toStringTag](){return"Pino"},[vk]:jk,[Sk]:Jk,[Om]:Uk,[Tm]:Lk,[_l]:Dk};Object.setPrototypeOf(Mm,bk.prototype);Lm.exports=function(){return Object.create(Mm)};var Mr=n=>n;function Wk(n,e){if(!n)throw Error("missing bindings for child Pino");let t=this[on],s=this[ms],r=Object.create(this);if(e==null)return r[ms].bindings!==Mr&&(r[ms]=Sl(s.level,Mr,s.log)),r[Lr]=kl(r,n),this.onChild!==Im&&this.onChild(r),r;if(e.hasOwnProperty("serializers")===!0){r[on]=Object.create(null);for(let u in t)r[on][u]=t[u];let a=Object.getOwnPropertySymbols(t);for(var i=0;i<a.length;i++){let u=a[i];r[on][u]=t[u]}for(let u in e.serializers)r[on][u]=e.serializers[u];let l=Object.getOwnPropertySymbols(e.serializers);for(var o=0;o<l.length;o++){let u=l[o];r[on][u]=e.serializers[u]}}else r[on]=t;if(e.hasOwnProperty("formatters")){let{level:a,bindings:l,log:u}=e.formatters;r[ms]=Sl(a||s.level,l||Mr,u||s.log)}else r[ms]=Sl(s.level,Mr,s.log);if(e.hasOwnProperty("customLevels")===!0&&(Bk(this.levels,e.customLevels),r.levels=Fk(e.customLevels,r[Ck]),Hk(r)),typeof e.redact=="object"&&e.redact!==null||Array.isArray(e.redact)){r.redact=e.redact;let a=Kk(r.redact,Rm),l={stringify:a[Rk]};r[Ok]=Rm,r[Ik]=a,r[Pk]=l}if(typeof e.msgPrefix=="string"&&(r[Al]=(this[Al]||"")+e.msgPrefix),r[Lr]=kl(r,n),e.level!==void 0&&e.level!==this.level||e.hasOwnProperty("customLevels")){let a=e.level||this.level;r[_l](a)}return this.onChild(r),r}function Vk(){let e=`{${this[Lr].substr(1)}}`,t=JSON.parse(e);return delete t.pid,delete t.hostname,t}function zk(n){let e=kl(this,n);this[Lr]=e}function Yk(n,e){return Object.assign(e,n)}function Jk(n,e,t){let s=this[Ak](),r=this[xk],i=this[$k],o=this[Ek],a=this[_k]||Yk,l,u=this[Mk].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[Om](l,e,t,s),f=this[Pm];f[Tk]===!0&&(f.lastLevel=t,f.lastObj=l,f.lastMsg=e,f.lastTime=s.slice(this[kk]),f.lastLogger=this),f.write(u?u(d):d)}function Qk(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||Im):n&&n()}});var Hm=j((Tl,jm)=>{"use strict";var{hasOwnProperty:gs}=Object.prototype,ln=Cl();ln.configure=Cl;ln.stringify=ln;ln.default=ln;Tl.stringify=ln;Tl.configure=Cl;jm.exports=ln;var Xk=/[\u0000-\u001f\u0022\u005c\ud800-\udfff]/;function Ut(n){return n.length<5e3&&!Xk.test(n)?`"${n}"`:JSON.stringify(n)}function $l(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 Zk=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(Object.getPrototypeOf(new Int8Array)),Symbol.toStringTag).get;function El(n){return Zk.call(n)!==void 0&&n.length!==0}function Nm(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 e$(n){if(gs.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 t$(n){let e;if(gs.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 n$(n,e){let t;if(gs.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(gs.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 an(n){return n===1?"1 item":`${n} items`}function s$(n){let e=new Set;for(let t of n)(typeof t=="string"||typeof t=="number")&&e.add(String(t));return e}function r$(n){if(gs.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 Cl(n){n={...n};let e=r$(n);e&&(n.bigint===void 0&&(n.bigint=!1),"circularValue"in n||(n.circularValue=Error));let t=e$(n),s=n$(n,"bigint"),r=t$(n),i=typeof r=="function"?r:void 0,o=Fm(n,"maximumDepth"),a=Fm(n,"maximumBreadth");function l(m,p,g,x,A,$){let _=p[m];switch(typeof _=="object"&&_!==null&&typeof _.toJSON=="function"&&(_=_.toJSON(m)),_=x.call(p,m,_),typeof _){case"string":return Ut(_);case"object":{if(_===null)return"null";if(g.indexOf(_)!==-1)return t;let y="",v=",",b=$;if(Array.isArray(_)){if(_.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(_),A!==""&&($+=A,y+=`
717
717
  ${$}`,v=`,
718
- ${$}`);let F=Math.min(_.length,a),H=0;for(;H<F-1;H++){let C=l(String(H),_,g,x,A,$);y+=C!==void 0?C:"null",y+=v}let V=l(String(H),_,g,x,A,$);if(y+=V!==void 0?V:"null",_.length-1>a){let C=_.length-a-1;y+=`${v}"... ${on(C)} not stringified"`}return A!==""&&(y+=`
718
+ ${$}`);let F=Math.min(_.length,a),H=0;for(;H<F-1;H++){let C=l(String(H),_,g,x,A,$);y+=C!==void 0?C:"null",y+=v}let V=l(String(H),_,g,x,A,$);if(y+=V!==void 0?V:"null",_.length-1>a){let C=_.length-a-1;y+=`${v}"... ${an(C)} not stringified"`}return A!==""&&(y+=`
719
719
  ${b}`),g.pop(),`[${y}]`}let w=Object.keys(_),S=w.length;if(S===0)return"{}";if(o<g.length+1)return'"[Object]"';let T="",M="";A!==""&&($+=A,v=`,
720
- ${$}`,T=" ");let k=Math.min(S,a);r&&!$l(_)&&(w=kl(w,i)),g.push(_);for(let F=0;F<k;F++){let H=w[F],V=l(H,_,g,x,A,$);V!==void 0&&(y+=`${M}${Ut(H)}:${T}${V}`,M=v)}if(S>a){let F=S-a;y+=`${M}"...":${T}"${on(F)} not stringified"`,M=v}return A!==""&&M.length>1&&(y=`
720
+ ${$}`,T=" ");let k=Math.min(S,a);r&&!El(_)&&(w=$l(w,i)),g.push(_);for(let F=0;F<k;F++){let H=w[F],V=l(H,_,g,x,A,$);V!==void 0&&(y+=`${M}${Ut(H)}:${T}${V}`,M=v)}if(S>a){let F=S-a;y+=`${M}"...":${T}"${an(F)} not stringified"`,M=v}return A!==""&&M.length>1&&(y=`
721
721
  ${$}${y}
722
722
  ${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,x,A,$){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 _=$,y="",v=",";if(Array.isArray(p)){if(p.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(p),A!==""&&($+=A,y+=`
723
723
  ${$}`,v=`,
724
- ${$}`);let S=Math.min(p.length,a),T=0;for(;T<S-1;T++){let k=u(String(T),p[T],g,x,A,$);y+=k!==void 0?k:"null",y+=v}let M=u(String(T),p[T],g,x,A,$);if(y+=M!==void 0?M:"null",p.length-1>a){let k=p.length-a-1;y+=`${v}"... ${on(k)} not stringified"`}return A!==""&&(y+=`
724
+ ${$}`);let S=Math.min(p.length,a),T=0;for(;T<S-1;T++){let k=u(String(T),p[T],g,x,A,$);y+=k!==void 0?k:"null",y+=v}let M=u(String(T),p[T],g,x,A,$);if(y+=M!==void 0?M:"null",p.length-1>a){let k=p.length-a-1;y+=`${v}"... ${an(k)} not stringified"`}return A!==""&&(y+=`
725
725
  ${_}`),g.pop(),`[${y}]`}g.push(p);let b="";A!==""&&($+=A,v=`,
726
726
  ${$}`,b=" ");let w="";for(let S of x){let T=u(S,p[S],g,x,A,$);T!==void 0&&(y+=`${w}${Ut(S)}:${b}${T}`,w=v)}return A!==""&&w.length>1&&(y=`
727
727
  ${$}${y}
728
728
  ${_}`),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,x,A){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,x,A);if(p===null)return"null"}if(g.indexOf(p)!==-1)return t;let $=A;if(Array.isArray(p)){if(p.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(p),A+=x;let T=`
729
729
  ${A}`,M=`,
730
- ${A}`,k=Math.min(p.length,a),F=0;for(;F<k-1;F++){let V=d(String(F),p[F],g,x,A);T+=V!==void 0?V:"null",T+=M}let H=d(String(F),p[F],g,x,A);if(T+=H!==void 0?H:"null",p.length-1>a){let V=p.length-a-1;T+=`${M}"... ${on(V)} not stringified"`}return T+=`
730
+ ${A}`,k=Math.min(p.length,a),F=0;for(;F<k-1;F++){let V=d(String(F),p[F],g,x,A);T+=V!==void 0?V:"null",T+=M}let H=d(String(F),p[F],g,x,A);if(T+=H!==void 0?H:"null",p.length-1>a){let V=p.length-a-1;T+=`${M}"... ${an(V)} not stringified"`}return T+=`
731
731
  ${$}`,g.pop(),`[${T}]`}let _=Object.keys(p),y=_.length;if(y===0)return"{}";if(o<g.length+1)return'"[Object]"';A+=x;let v=`,
732
- ${A}`,b="",w="",S=Math.min(y,a);$l(p)&&(b+=Nm(p,v,a),_=_.slice(p.length),S-=p.length,w=v),r&&(_=kl(_,i)),g.push(p);for(let T=0;T<S;T++){let M=_[T],k=d(M,p[M],g,x,A);k!==void 0&&(b+=`${w}${Ut(M)}: ${k}`,w=v)}if(y>a){let T=y-a;b+=`${w}"...": "${on(T)} not stringified"`,w=v}return w!==""&&(b=`
732
+ ${A}`,b="",w="",S=Math.min(y,a);El(p)&&(b+=Nm(p,v,a),_=_.slice(p.length),S-=p.length,w=v),r&&(_=$l(_,i)),g.push(p);for(let T=0;T<S;T++){let M=_[T],k=d(M,p[M],g,x,A);k!==void 0&&(b+=`${w}${Ut(M)}: ${k}`,w=v)}if(y>a){let T=y-a;b+=`${w}"...": "${an(T)} not stringified"`,w=v}return w!==""&&(b=`
733
733
  ${A}${b}
734
- ${$}`),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 x="",A=p.length!==void 0;if(A&&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),w=0;for(;w<b-1;w++){let T=f(String(w),p[w],g);x+=T!==void 0?T:"null",x+=","}let S=f(String(w),p[w],g);if(x+=S!==void 0?S:"null",p.length-1>a){let T=p.length-a-1;x+=`,"... ${on(T)} not stringified"`}return g.pop(),`[${x}]`}let $=Object.keys(p),_=$.length;if(_===0)return"{}";if(o<g.length+1)return'"[Object]"';let y="",v=Math.min(_,a);A&&$l(p)&&(x+=Nm(p,",",a),$=$.slice(p.length),v-=p.length,y=","),r&&($=kl($,i)),g.push(p);for(let b=0;b<v;b++){let w=$[b],S=f(w,p[w],g);S!==void 0&&(x+=`${y}${Ut(w)}:${S}`,y=",")}if(_>a){let b=_-a;x+=`${y}"...":"${on(b)} not stringified"`}return g.pop(),`{${x}}`}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 x="";if(typeof g=="number"?x=" ".repeat(Math.min(g,10)):typeof g=="string"&&(x=g.slice(0,10)),p!=null){if(typeof p=="function")return l("",{"":m},[],p,x,"");if(Array.isArray(p))return u("",m,[],s$(p),x,"")}if(x.length!==0)return d("",m,[],x,"")}return f("",m,[])}return h}});var Km=j((kR,qm)=>{"use strict";var Tl=Symbol.for("pino.metadata"),{DEFAULT_LEVELS:Um}=Rr(),i$=Um.info;function o$(n,e){n=n||[],e=e||{dedupe:!1};let t=Object.create(Um);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,[Tl]:!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,x;for(let A=a$(p.length,e.dedupe);c$(A,p.length,e.dedupe);A=l$(A,e.dedupe))if(h=p[A],h.level<=m){if(g!==0&&g!==h.level)break;if(x=h.stream,x[Tl]){let{lastTime:$,lastMsg:_,lastObj:y,lastLogger:v}=this;x.lastLevel=m,x.lastTime=$,x.lastMsg=_,x.lastObj=y,x.lastLogger=v}x.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,x;typeof f.levelVal=="number"?x=f.levelVal:typeof f.level=="string"?x=g[f.level]:typeof f.level=="number"?x=f.level:x=i$;let A={stream:m,level:x,levelVal:void 0,id:++s.lastId};return p.unshift(A),p.sort(Bm),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(Bm),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,[Tl]:!0}}}function Bm(n,e){return n.level-e.level}function a$(n,e){return e?n-1:0}function l$(n,e){return e?n-1:n+1}function c$(n,e,t){return t?n>=0:n<e}qm.exports=o$});var Il=j(($R,tt)=>{"use strict";var u$=require("node:os"),Xm=Ya(),d$=Ja(),f$=Za(),Zm=Ch(),p$=Dm(),eg=Tn(),{configure:h$}=Hm(),{assertDefaultLevelFound:m$,mappings:tg,genLsCache:g$,genLevelComparison:y$,assertLevelComparison:b$}=vl(),{DEFAULT_LEVELS:ng,SORTING_ORDER:v$}=Rr(),{createArgsNormalizer:w$,asChindings:x$,buildSafeSonicBoom:Gm,buildFormatters:S$,stringify:Rl,normalizeDestFileDescriptor:Wm,noop:_$}=Tr(),{version:A$}=wl(),{chindingsSym:Vm,redactFmtSym:k$,serializersSym:zm,timeSym:$$,timeSliceIndexSym:E$,streamSym:C$,stringifySym:Ym,stringifySafeSym:Ol,stringifiersSym:Jm,setLevelSym:T$,endSym:R$,formatOptsSym:O$,messageKeySym:P$,errorKeySym:I$,nestedKeySym:M$,mixinSym:L$,levelCompSym:D$,useOnlyCustomLevelsSym:N$,formattersSym:Qm,hooksSym:F$,nestedKeyStrSym:j$,mixinMergeStrategySym:H$,msgPrefixSym:B$}=eg,{epochTime:sg,nullTime:U$}=Zm,{pid:q$}=process,K$=u$.hostname(),G$=Xm.err,W$={level:"info",levelComparison:v$.ASC,levels:ng,messageKey:"msg",errorKey:"err",nestedKey:null,enabled:!0,base:{pid:q$,hostname:K$},serializers:Object.assign(Object.create(null),{err:G$}),formatters:Object.assign(Object.create(null),{bindings(n){return n},level(n,e){return{level:e}}}),hooks:{logMethod:void 0,streamWrite:void 0},timestamp:sg,name:void 0,redact:null,customLevels:null,useOnlyCustomLevels:!1,depthLimit:5,edgeLimit:100},V$=w$(W$),z$=Object.assign(Object.create(null),Xm);function Pl(...n){let e={},{opts:t,stream:s}=V$(e,d$(),...n);t.level&&typeof t.level=="string"&&ng[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:x,mixinMergeStrategy:A,useOnlyCustomLevels:$,formatters:_,hooks:y,depthLimit:v,edgeLimit:b,onChild:w,msgPrefix:S}=t,T=h$({maximumDepth:v,maximumBreadth:b}),M=S$(_.level,_.bindings,_.log),k=Rl.bind({[Ol]:T}),F=r?f$(r,k):{},H=r?{stringify:F[k$]}:{stringify:k},V="}"+(i?`\r
734
+ ${$}`),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 x="",A=p.length!==void 0;if(A&&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),w=0;for(;w<b-1;w++){let T=f(String(w),p[w],g);x+=T!==void 0?T:"null",x+=","}let S=f(String(w),p[w],g);if(x+=S!==void 0?S:"null",p.length-1>a){let T=p.length-a-1;x+=`,"... ${an(T)} not stringified"`}return g.pop(),`[${x}]`}let $=Object.keys(p),_=$.length;if(_===0)return"{}";if(o<g.length+1)return'"[Object]"';let y="",v=Math.min(_,a);A&&El(p)&&(x+=Nm(p,",",a),$=$.slice(p.length),v-=p.length,y=","),r&&($=$l($,i)),g.push(p);for(let b=0;b<v;b++){let w=$[b],S=f(w,p[w],g);S!==void 0&&(x+=`${y}${Ut(w)}:${S}`,y=",")}if(_>a){let b=_-a;x+=`${y}"...":"${an(b)} not stringified"`}return g.pop(),`{${x}}`}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 x="";if(typeof g=="number"?x=" ".repeat(Math.min(g,10)):typeof g=="string"&&(x=g.slice(0,10)),p!=null){if(typeof p=="function")return l("",{"":m},[],p,x,"");if(Array.isArray(p))return u("",m,[],s$(p),x,"")}if(x.length!==0)return d("",m,[],x,"")}return f("",m,[])}return h}});var Km=j((kR,qm)=>{"use strict";var Rl=Symbol.for("pino.metadata"),{DEFAULT_LEVELS:Um}=Ir(),i$=Um.info;function o$(n,e){n=n||[],e=e||{dedupe:!1};let t=Object.create(Um);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,[Rl]:!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,x;for(let A=a$(p.length,e.dedupe);c$(A,p.length,e.dedupe);A=l$(A,e.dedupe))if(h=p[A],h.level<=m){if(g!==0&&g!==h.level)break;if(x=h.stream,x[Rl]){let{lastTime:$,lastMsg:_,lastObj:y,lastLogger:v}=this;x.lastLevel=m,x.lastTime=$,x.lastMsg=_,x.lastObj=y,x.lastLogger=v}x.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,x;typeof f.levelVal=="number"?x=f.levelVal:typeof f.level=="string"?x=g[f.level]:typeof f.level=="number"?x=f.level:x=i$;let A={stream:m,level:x,levelVal:void 0,id:++s.lastId};return p.unshift(A),p.sort(Bm),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(Bm),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,[Rl]:!0}}}function Bm(n,e){return n.level-e.level}function a$(n,e){return e?n-1:0}function l$(n,e){return e?n-1:n+1}function c$(n,e,t){return t?n>=0:n<e}qm.exports=o$});var Ml=j(($R,tt)=>{"use strict";var u$=require("node:os"),Xm=Ja(),d$=Qa(),f$=el(),Zm=Ch(),p$=Dm(),eg=Rn(),{configure:h$}=Hm(),{assertDefaultLevelFound:m$,mappings:tg,genLsCache:g$,genLevelComparison:y$,assertLevelComparison:b$}=wl(),{DEFAULT_LEVELS:ng,SORTING_ORDER:v$}=Ir(),{createArgsNormalizer:w$,asChindings:x$,buildSafeSonicBoom:Gm,buildFormatters:S$,stringify:Ol,normalizeDestFileDescriptor:Wm,noop:_$}=Pr(),{version:A$}=xl(),{chindingsSym:Vm,redactFmtSym:k$,serializersSym:zm,timeSym:$$,timeSliceIndexSym:E$,streamSym:C$,stringifySym:Ym,stringifySafeSym:Pl,stringifiersSym:Jm,setLevelSym:T$,endSym:R$,formatOptsSym:O$,messageKeySym:P$,errorKeySym:I$,nestedKeySym:M$,mixinSym:L$,levelCompSym:D$,useOnlyCustomLevelsSym:N$,formattersSym:Qm,hooksSym:F$,nestedKeyStrSym:j$,mixinMergeStrategySym:H$,msgPrefixSym:B$}=eg,{epochTime:sg,nullTime:U$}=Zm,{pid:q$}=process,K$=u$.hostname(),G$=Xm.err,W$={level:"info",levelComparison:v$.ASC,levels:ng,messageKey:"msg",errorKey:"err",nestedKey:null,enabled:!0,base:{pid:q$,hostname:K$},serializers:Object.assign(Object.create(null),{err:G$}),formatters:Object.assign(Object.create(null),{bindings(n){return n},level(n,e){return{level:e}}}),hooks:{logMethod:void 0,streamWrite:void 0},timestamp:sg,name:void 0,redact:null,customLevels:null,useOnlyCustomLevels:!1,depthLimit:5,edgeLimit:100},V$=w$(W$),z$=Object.assign(Object.create(null),Xm);function Il(...n){let e={},{opts:t,stream:s}=V$(e,d$(),...n);t.level&&typeof t.level=="string"&&ng[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:x,mixinMergeStrategy:A,useOnlyCustomLevels:$,formatters:_,hooks:y,depthLimit:v,edgeLimit:b,onChild:w,msgPrefix:S}=t,T=h$({maximumDepth:v,maximumBreadth:b}),M=S$(_.level,_.bindings,_.log),k=Ol.bind({[Pl]:T}),F=r?f$(r,k):{},H=r?{stringify:F[k$]}:{stringify:k},V="}"+(i?`\r
735
735
  `:`
736
- `),C=x$.bind(null,{[Vm]:"",[zm]:o,[Jm]:F,[Ym]:Rl,[Ol]:T,[Qm]:M}),E="";f!==null&&(h===void 0?E=C(f):E=C(Object.assign({},f,{name:h})));let Y=a instanceof Function?a:a?sg:U$,D=Y().indexOf(":")+1;if($&&!p)throw Error("customLevels is required if useOnlyCustomLevels is set true");if(x&&typeof x!="function")throw Error(`Unknown mixin type "${typeof x}" - expected "function"`);if(S&&typeof S!="string")throw Error(`Unknown msgPrefix type "${typeof S}" - expected "string"`);m$(m,p,$);let X=tg(p,$);typeof s.emit=="function"&&s.emit("message",{code:"PINO_CONFIG",config:{levels:X,messageKey:l,errorKey:u}}),b$(g);let ee=y$(g);return Object.assign(e,{levels:X,[D$]:ee,[N$]:$,[C$]:s,[$$]:Y,[E$]:D,[Ym]:Rl,[Ol]:T,[Jm]:F,[R$]:V,[O$]:H,[P$]:l,[I$]:u,[M$]:d,[j$]:d?`,${JSON.stringify(d)}:{`:"",[zm]:o,[L$]:x,[H$]:A,[Vm]:E,[Qm]:M,[F$]:y,silent:_$,onChild:w,[B$]:S}),Object.setPrototypeOf(e,p$()),g$(e),e[T$](m),e}tt.exports=Pl;tt.exports.destination=(n=process.stdout.fd)=>typeof n=="object"?(n.dest=Wm(n.dest||process.stdout.fd),Gm(n)):Gm({dest:Wm(n),minLength:0});tt.exports.transport=pl();tt.exports.multistream=Km();tt.exports.levels=tg();tt.exports.stdSerializers=z$;tt.exports.stdTimeFunctions=Object.assign({},Zm);tt.exports.symbols=eg;tt.exports.version=A$;tt.exports.default=Pl;tt.exports.pino=Pl});function gs(n){return new Ml(n)}var Y$,J$,Q$,Ml,Ll=N(()=>{"use strict";Y$={maxSteps:150,thinkingEnabled:!0,selfEvalEnabled:!0,minConfidence:.6,showThinking:!1},J$=`
736
+ `),C=x$.bind(null,{[Vm]:"",[zm]:o,[Jm]:F,[Ym]:Ol,[Pl]:T,[Qm]:M}),E="";f!==null&&(h===void 0?E=C(f):E=C(Object.assign({},f,{name:h})));let Y=a instanceof Function?a:a?sg:U$,D=Y().indexOf(":")+1;if($&&!p)throw Error("customLevels is required if useOnlyCustomLevels is set true");if(x&&typeof x!="function")throw Error(`Unknown mixin type "${typeof x}" - expected "function"`);if(S&&typeof S!="string")throw Error(`Unknown msgPrefix type "${typeof S}" - expected "string"`);m$(m,p,$);let X=tg(p,$);typeof s.emit=="function"&&s.emit("message",{code:"PINO_CONFIG",config:{levels:X,messageKey:l,errorKey:u}}),b$(g);let ee=y$(g);return Object.assign(e,{levels:X,[D$]:ee,[N$]:$,[C$]:s,[$$]:Y,[E$]:D,[Ym]:Ol,[Pl]:T,[Jm]:F,[R$]:V,[O$]:H,[P$]:l,[I$]:u,[M$]:d,[j$]:d?`,${JSON.stringify(d)}:{`:"",[zm]:o,[L$]:x,[H$]:A,[Vm]:E,[Qm]:M,[F$]:y,silent:_$,onChild:w,[B$]:S}),Object.setPrototypeOf(e,p$()),g$(e),e[T$](m),e}tt.exports=Il;tt.exports.destination=(n=process.stdout.fd)=>typeof n=="object"?(n.dest=Wm(n.dest||process.stdout.fd),Gm(n)):Gm({dest:Wm(n),minLength:0});tt.exports.transport=hl();tt.exports.multistream=Km();tt.exports.levels=tg();tt.exports.stdSerializers=z$;tt.exports.stdTimeFunctions=Object.assign({},Zm);tt.exports.symbols=eg;tt.exports.version=A$;tt.exports.default=Il;tt.exports.pino=Il});function ys(n){return new Ll(n)}var Y$,J$,Q$,Ll,Dl=N(()=>{"use strict";Y$={maxSteps:150,thinkingEnabled:!0,selfEvalEnabled:!0,minConfidence:.6,showThinking:!1},J$=`
737
737
  ## Reasoning Protocol
738
738
 
739
739
  Before taking ANY action, you MUST think step-by-step inside <thinking> tags.
@@ -766,7 +766,7 @@ After receiving a tool result, think again:
766
766
  ## Reasoning
767
767
  For non-trivial requests, think briefly inside <thinking>...</thinking> before acting.
768
768
  The user will NOT see thinking blocks. One tool call per turn.
769
- `.trim(),Ml=class{config;turnSteps=[];stepCounter=0;constructor(e){this.config={...Y$,...e}}updateConfig(e){Object.assign(this.config,e)}getConfig(){return{...this.config}}enrichSystemPrompt(e,t="M"){return!this.config.thinkingEnabled||t==="XS"?e:t==="S"?`${e}
769
+ `.trim(),Ll=class{config;turnSteps=[];stepCounter=0;constructor(e){this.config={...Y$,...e}}updateConfig(e){Object.assign(this.config,e)}getConfig(){return{...this.config}}enrichSystemPrompt(e,t="M"){return!this.config.thinkingEnabled||t==="XS"?e:t==="S"?`${e}
770
770
 
771
771
  ${Q$}`:`${e}
772
772
 
@@ -793,11 +793,11 @@ Rate your work. Reply with ONLY a JSON object \u2014 no other text:
793
793
  }
794
794
  </self_eval>
795
795
  `.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(`
796
- `)}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 ys(n=3){return new Dl(n)}var X$,Dl,Nl=N(()=>{"use strict";X$=[{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}],Dl=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 X$)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(`
797
- `)}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 Z$(){try{if(It.existsSync(Ir))return JSON.parse(It.readFileSync(Ir,"utf-8"))}catch{}return{}}function e0(n){try{let e=Mr.dirname(Ir);It.existsSync(e)||It.mkdirSync(e,{recursive:!0}),It.writeFileSync(Ir,JSON.stringify(n,null,2),"utf-8")}catch{}}function Bl(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 bs(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 t0(n){return n.replace(/&quot;/g,'"').replace(/&apos;/g,"'").replace(/&lt;/g,"<").replace(/&gt;/g,">").replace(/&amp;/g,"&")}function n0(n){let e=[],t=/<<?action\s*>>?([\s\S]*?)(?:<<?\/action\s*>>?|$)/gi,s;for(;(s=t.exec(n))!==null;){let r=s[1].trim();if(r)try{let i=JSON.parse(r);i.tool&&i.args&&typeof i.args=="object"&&e.push({tool:i.tool,args:i.args,format:"action_tag_json",rawMatch:s[0]})}catch{let i=Bl(r,r.indexOf("{"));if(i)try{let o=JSON.parse(i);o.tool&&o.args&&typeof o.args=="object"&&e.push({tool:o.tool,args:o.args,format:"action_tag_json",rawMatch:s[0]})}catch{}}}return e}function s0(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=bs(r);i&&e.push({...i,format:"xml_tags",rawMatch:s[0]})}catch{}return e}function r0(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=bs(r);i&&e.push({...i,format:"hermes",rawMatch:s[0]})}}catch{}return e}function i0(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=ig(r);for(let o of i)e.push({...o,format:"xml_tool_call_wrapper",rawMatch:s[0]})}return e}function ig(n){let e=[],t=["read_file","write_file","edit_file","search_and_replace","run_command","search_codebase","list_dir","create_dir","delete_file","append_to_file","patch_file","move_file","get_file_info"];for(let s of t){let r=new RegExp(`<<?${s}(\\s+[\\s\\S]*?)?(?:>>?([\\s\\S]*?)<<?\\/${s}>>?|\\s*\\/?>>?)`,"gi"),i;for(;(i=r.exec(n))!==null;){let o=i[1]||"",a=i[2]||"",l={},u=/(\w+)\s*=\s*(?:"([^"]*)"|'([^']*)'|(\S+))/g,d;for(;(d=u.exec(o))!==null;){let h=d[1].toLowerCase(),m=d[2]??d[3]??d[4];l[h]=t0(m)}let f=a.trim();f&&(s==="write_file"||s==="append_to_file"?l.content=a:s==="run_command"?l.command=f:s==="patch_file"&&(l.new_content=a)),l.start_line&&(l.start_line=parseInt(l.start_line)),l.end_line&&(l.end_line=parseInt(l.end_line)),l.depth&&(l.depth=parseInt(l.depth)),s==="edit_file"?e.push({tool:"search_and_replace",args:l,format:"xml_prompt",rawMatch:i[0]}):e.push({tool:s,args:l,format:"xml_prompt",rawMatch:i[0]})}}return e}function o0(n){return ig(n)}function a0(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=bs(r);i&&e.push({...i,format:"markdown_json",rawMatch:s[0]})}catch{}return e}function l0(n){let e=[],t=/\{\s*"function"\s*:/g,s;for(;(s=t.exec(n))!==null;){let r=Bl(n,s.index);if(r)try{let i=JSON.parse(r),o=bs(i);o&&e.push({...o,format:"function_call",rawMatch:r})}catch{}}return e}function c0(n){let e=[],t=/\{\s*"(?:name|tool)"\s*:/g,s;for(;(s=t.exec(n))!==null;){let r=Bl(n,s.index);if(r)try{let i=JSON.parse(r),o=bs(i);o&&e.push({...o,format:"json_object",rawMatch:r})}catch{}}return e}function u0(n){let e=[],t=/<<?tool[-_]call\s*>>?([\s\S]*?)(?:<<?\/tool[-_]call\s*>>?|$)/gi,s,r=!1;for(;(s=t.exec(n))!==null;){let i=s[1],o=/<function=([^>]+)>/i.exec(i);if(o){r=!0;let a=o[1].trim(),l={},u=/<parameter=([^>]+)>([\s\S]*?)<\/parameter>/gi,d;for(;(d=u.exec(i))!==null;){let f=d[1].trim(),h=d[2].trim();h==="true"?h=!0:h==="false"?h=!1:!isNaN(Number(h))&&h!==""&&(h=Number(h)),l[f]=h}e.push({tool:a,args:l,format:"xml_parameters",rawMatch:s[0]})}}if(!r&&/<function=([^>]+)>/i.test(n)){let i=/<function=([^>]+)>/i.exec(n);if(i){let o=i[1].trim(),a={},l=/<parameter=([^>]+)>([\s\S]*?)<\/parameter>/gi,u;for(;(u=l.exec(n))!==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:n})}}return e}function og(){return jl||(jl=new Hl),jl}var It,Mr,rg,Ir,Fl,Hl,jl,ag=N(()=>{"use strict";It=O(require("fs")),Mr=O(require("path")),rg=O(require("os")),Ir=Mr.join(rg.homedir(),".hablas","model-formats.json");Fl=[{format:"action_tag_json",parse:n0},{format:"xml_tool_call_wrapper",parse:i0},{format:"xml_prompt",parse:o0},{format:"xml_tags",parse:s0},{format:"xml_parameters",parse:u0},{format:"hermes",parse:r0},{format:"markdown_json",parse:a0},{format:"function_call",parse:l0},{format:"json_object",parse:c0}],Hl=class{registry;constructor(){this.registry=Z$()}parse(e,t,s){if(t&&Array.isArray(t)&&t.length>0){let o=t.filter(a=>a?.function?.name&&typeof a.function.name=="string");if(o.length>0){let a=o.map(l=>({function:{name:l.function.name,arguments:l.function.arguments||{}}}));return s&&this.learnFormat(s,"native"),{toolCalls:a,displayContent:(e||"").trim(),format:"native"}}}let r=e||"";if(!r.trim())return{toolCalls:[],displayContent:"",format:"unknown"};if(s){let o=this.registry[s];if(o&&o.format!=="native"){let a=Fl.find(l=>l.format===o.format);if(a){let l=a.parse(r);if(l.length>0)return this.learnFormat(s,o.format),this.buildResult(l,r)}}}for(let{parse:o}of Fl){let a=o(r);if(a.length>0){let l=a[0].format;return s&&this.learnFormat(s,l),this.buildResult(a,r)}}let i=r.trim();return i=i.replace(/<<?thinking>>?[\s\S]*?<<?\/thinking>>?/gi,""),i=i.replace(/<<?think>>?[\s\S]*?<<?\/think>>?/gi,""),i=i.replace(/<<?action>>?[\s\S]*?<<?\/action>>?/gi,""),i=i.replace(/<<?response>>?/gi,"").replace(/<<?\/response>>?/gi,""),{toolCalls:[],displayContent:i.trim(),format:"unknown"}}mightContainToolCall(e){if(!e)return!1;let t=e.trim();return!!(/<<?action[\s>]/i.test(t)||/<<?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 Fl)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()},e0(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(/<<?action>>?[\s\S]*?<<?\/action>>?/gi,""),r=r.replace(/<<?response>>?/gi,"").replace(/<<?\/response>>?/gi,""),r=r.replace(/\n{3,}/g,`
796
+ `)}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 bs(n=3){return new Nl(n)}var X$,Nl,Fl=N(()=>{"use strict";X$=[{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 X$)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(`
797
+ `)}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 Z$(){try{if(It.existsSync(Dr))return JSON.parse(It.readFileSync(Dr,"utf-8"))}catch{}return{}}function e0(n){try{let e=Nr.dirname(Dr);It.existsSync(e)||It.mkdirSync(e,{recursive:!0}),It.writeFileSync(Dr,JSON.stringify(n,null,2),"utf-8")}catch{}}function Ul(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 vs(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 t0(n){return n.replace(/&quot;/g,'"').replace(/&apos;/g,"'").replace(/&lt;/g,"<").replace(/&gt;/g,">").replace(/&amp;/g,"&")}function n0(n){let e=[],t=/<<?action\s*>>?([\s\S]*?)(?:<<?\/action\s*>>?|$)/gi,s;for(;(s=t.exec(n))!==null;){let r=s[1].trim();if(r)try{let i=JSON.parse(r);i.tool&&i.args&&typeof i.args=="object"&&e.push({tool:i.tool,args:i.args,format:"action_tag_json",rawMatch:s[0]})}catch{let i=Ul(r,r.indexOf("{"));if(i)try{let o=JSON.parse(i);o.tool&&o.args&&typeof o.args=="object"&&e.push({tool:o.tool,args:o.args,format:"action_tag_json",rawMatch:s[0]})}catch{}}}return e}function s0(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=vs(r);i&&e.push({...i,format:"xml_tags",rawMatch:s[0]})}catch{}return e}function r0(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=vs(r);i&&e.push({...i,format:"hermes",rawMatch:s[0]})}}catch{}return e}function i0(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=ig(r);for(let o of i)e.push({...o,format:"xml_tool_call_wrapper",rawMatch:s[0]})}return e}function ig(n){let e=[],t=["read_file","write_file","edit_file","search_and_replace","run_command","search_codebase","list_dir","create_dir","delete_file","append_to_file","patch_file","move_file","get_file_info"];for(let s of t){let r=new RegExp(`<<?${s}(\\s+[\\s\\S]*?)?(?:>>?([\\s\\S]*?)<<?\\/${s}>>?|\\s*\\/?>>?)`,"gi"),i;for(;(i=r.exec(n))!==null;){let o=i[1]||"",a=i[2]||"",l={},u=/(\w+)\s*=\s*(?:"([^"]*)"|'([^']*)'|(\S+))/g,d;for(;(d=u.exec(o))!==null;){let h=d[1].toLowerCase(),m=d[2]??d[3]??d[4];l[h]=t0(m)}let f=a.trim();f&&(s==="write_file"||s==="append_to_file"?l.content=a:s==="run_command"?l.command=f:s==="patch_file"&&(l.new_content=a)),l.start_line&&(l.start_line=parseInt(l.start_line)),l.end_line&&(l.end_line=parseInt(l.end_line)),l.depth&&(l.depth=parseInt(l.depth)),s==="edit_file"?e.push({tool:"search_and_replace",args:l,format:"xml_prompt",rawMatch:i[0]}):e.push({tool:s,args:l,format:"xml_prompt",rawMatch:i[0]})}}return e}function o0(n){return ig(n)}function a0(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=vs(r);i&&e.push({...i,format:"markdown_json",rawMatch:s[0]})}catch{}return e}function l0(n){let e=[],t=/\{\s*"function"\s*:/g,s;for(;(s=t.exec(n))!==null;){let r=Ul(n,s.index);if(r)try{let i=JSON.parse(r),o=vs(i);o&&e.push({...o,format:"function_call",rawMatch:r})}catch{}}return e}function c0(n){let e=[],t=/\{\s*"(?:name|tool)"\s*:/g,s;for(;(s=t.exec(n))!==null;){let r=Ul(n,s.index);if(r)try{let i=JSON.parse(r),o=vs(i);o&&e.push({...o,format:"json_object",rawMatch:r})}catch{}}return e}function u0(n){let e=[],t=/<<?tool[-_]call\s*>>?([\s\S]*?)(?:<<?\/tool[-_]call\s*>>?|$)/gi,s,r=!1;for(;(s=t.exec(n))!==null;){let i=s[1],o=/<function=([^>]+)>/i.exec(i);if(o){r=!0;let a=o[1].trim(),l={},u=/<parameter=([^>]+)>([\s\S]*?)<\/parameter>/gi,d;for(;(d=u.exec(i))!==null;){let f=d[1].trim(),h=d[2].trim();h==="true"?h=!0:h==="false"?h=!1:!isNaN(Number(h))&&h!==""&&(h=Number(h)),l[f]=h}e.push({tool:a,args:l,format:"xml_parameters",rawMatch:s[0]})}}if(!r&&/<function=([^>]+)>/i.test(n)){let i=/<function=([^>]+)>/i.exec(n);if(i){let o=i[1].trim(),a={},l=/<parameter=([^>]+)>([\s\S]*?)<\/parameter>/gi,u;for(;(u=l.exec(n))!==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:n})}}return e}function og(){return Hl||(Hl=new Bl),Hl}var It,Nr,rg,Dr,jl,Bl,Hl,ag=N(()=>{"use strict";It=O(require("fs")),Nr=O(require("path")),rg=O(require("os")),Dr=Nr.join(rg.homedir(),".hablas","model-formats.json");jl=[{format:"action_tag_json",parse:n0},{format:"xml_tool_call_wrapper",parse:i0},{format:"xml_prompt",parse:o0},{format:"xml_tags",parse:s0},{format:"xml_parameters",parse:u0},{format:"hermes",parse:r0},{format:"markdown_json",parse:a0},{format:"function_call",parse:l0},{format:"json_object",parse:c0}],Bl=class{registry;constructor(){this.registry=Z$()}parse(e,t,s){if(t&&Array.isArray(t)&&t.length>0){let o=t.filter(a=>a?.function?.name&&typeof a.function.name=="string");if(o.length>0){let a=o.map(l=>({function:{name:l.function.name,arguments:l.function.arguments||{}}}));return s&&this.learnFormat(s,"native"),{toolCalls:a,displayContent:(e||"").trim(),format:"native"}}}let r=e||"";if(!r.trim())return{toolCalls:[],displayContent:"",format:"unknown"};if(s){let o=this.registry[s];if(o&&o.format!=="native"){let a=jl.find(l=>l.format===o.format);if(a){let l=a.parse(r);if(l.length>0)return this.learnFormat(s,o.format),this.buildResult(l,r)}}}for(let{parse:o}of jl){let a=o(r);if(a.length>0){let l=a[0].format;return s&&this.learnFormat(s,l),this.buildResult(a,r)}}let i=r.trim();return i=i.replace(/<<?thinking>>?[\s\S]*?<<?\/thinking>>?/gi,""),i=i.replace(/<<?think>>?[\s\S]*?<<?\/think>>?/gi,""),i=i.replace(/<<?action>>?[\s\S]*?<<?\/action>>?/gi,""),i=i.replace(/<<?response>>?/gi,"").replace(/<<?\/response>>?/gi,""),{toolCalls:[],displayContent:i.trim(),format:"unknown"}}mightContainToolCall(e){if(!e)return!1;let t=e.trim();return!!(/<<?action[\s>]/i.test(t)||/<<?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 jl)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()},e0(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(/<<?action>>?[\s\S]*?<<?\/action>>?/gi,""),r=r.replace(/<<?response>>?/gi,"").replace(/<<?\/response>>?/gi,""),r=r.replace(/\n{3,}/g,`
798
798
 
799
- `),{toolCalls:s,displayContent:r.trim(),format:e[0]?.format??"unknown"}}},jl=null});function f0(n,e,t){let r=og().parse(e,n,t);return{toolCalls:r.toolCalls,displayContent:r.displayContent}}function p0(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 h0(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 ug(n,e,t,s){let r=0,i=Date.now();for(;r<=cg;){let o=await n.execute({name:e,arguments:t});if(o.success||r>=cg)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 Dr(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??gs(),h=n.errorRecovery??ys(),m=d?[]:s.getOllamaTools(),p=t.getModel(),g=n.maxIterations??150,x="IDLE",A=0,$=(T,M)=>{let k=d0[x];if(!k||!k.includes(T))throw new Error(`\u{1F6AB} Illegal State Transition Attempt: ${x} \u2501\u2501\u25B6 ${T} (Reason: ${M??"none"})`);o.info({from:x,to:T,reason:M},"FSM State Transition"),x=T},_=[],y=[],v=[],b="",w=0,S=!1;for($("THINKING","Starting agentic turn");w<g;){if(w++,u?.aborted)return $("TERMINAL_ABORT","Operation aborted by signal"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:"Aborted",completedNaturally:S};let T=f.buildBudgetWarningPrompt();T&&r.addUserMessage(T,{priority:"critical",tags:["system-budget"]});let M;try{M=await t.chatWithTools(r.getMessages(),m,u)}catch(E){if(E.name==="AbortError"||u?.aborted)return $("TERMINAL_ABORT","Aborted during inference"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:"Aborted",completedNaturally:S};if(w<=1){a.onNotice?.(`Transient model error: ${E.message??"unknown"} \u2014 retrying\u2026`,"retry"),await new Promise(Y=>setTimeout(Y,1e3)),w--;continue}return $("TERMINAL_ABORT","Inference failure"),a.onError?.(E.message??"Model request failed"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:E.message,completedNaturally:S}}let k=M.message?.content||"",F=M.message?.tool_calls,H=f.parseThinking(k);H.hasThinking&&(f.recordStep({thought:H.thinking}),o.debug({thinking:H.thinking.slice(0,200)},"ReAct thinking")),$("PARSE_VALIDATING","Received model response, parsing");let{toolCalls:V,displayContent:C}=f0(F,k,p);if(V.length===0&&k.toLowerCase().includes("<action>")){if(A++,A>=Lr){$("STATE_RECONCILIATION",`Self-correction loop exhausted after ${A} attempts`);let Y=`Failed to execute after ${Lr} syntax corrections. Rollback initiated.`;a.onError?.(Y);try{let D=s.get("undo");D&&await D.execute({count:100})}catch{}return $("TERMINAL_ABORT","Fatal syntactic self-correction exhaustion"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:Y,completedNaturally:S}}let E=`[SYSTEM ERROR - RETRY ${A}/${Lr}] Malformed action block detected inside <action> tags. Expected a valid JSON object matching the HEP-1 tool schema.
800
- Please correct your format and try again. Ensure all JSON keys/values are double-quoted and correctly escaped.`;$("ERROR_HEALING",`Syntax error inside action tags (attempt ${A})`),a.onNotice?.(`Malformed action block detected \u2014 healing attempt ${A}/${Lr}\u2026`,"retry"),r.addToolMessage(E),$("THINKING","Error injected, waiting for next generation");continue}if(C&&C.trim()&&(b=C,await a.onAssistantText?.(C,e)),k.includes("ESCALATE_SCOPE")||v.length>3){$("ESCALATING","Detected need for scope escalation"),a.onNotice?.("Escalating scope: Task requires more specialized agents.","info"),r.addAssistantMessage(k,V,e.role),S=!0;break}if(V.length===0){r.addAssistantMessage(k,void 0,e.role),S=!0,$("SYNTHESIZING","Completed execution naturally");break}$("ACTION_READY","Action parsed and verified"),r.addAssistantMessage(k,V,e.role);for(let E=0;E<V.length;E++){let Y=V[E];if(!Y?.function?.name)continue;let D=Y.function.name,X=Y.function.arguments||{},ee=s.getSafetyLevel(D)??"confirm";if(!s.get(D)){$("ERROR_HEALING",`Unknown tool execution: ${D}`),a.onNotice?.(`Unknown tool: ${D} \u2014 skipping`,"warn"),r.addToolMessage(`Error: Unknown tool "${D}". Available: ${s.getAll().map(ve=>ve.name).join(", ")}`),$("THINKING","Returning to thought loop");continue}if(await l(D,ee,X)==="skip"){r.addToolMessage(`Tool ${D} was skipped by policy/user.`);break}_.push(D),typeof X.path=="string"&&v.push(X.path);let _e=p0(D,X);a.onToolStart?.(D,_e,X),a.onToolCall?.(),f.recordStep({thought:H.hasThinking?`Executing: ${D}`:"",action:D,actionInput:X}),$("EXECUTING_TOOL",`Executing tool: ${D}`);let Q=await ug(s,D,X,o);a.onToolEnd?.(D,Q.success,Q.error||Q.output,Q.duration,X);let Ae;if(Q.success)Ae=as(Q.output,lg),f.recordObservation(Ae.slice(0,300)),y.push({tool:D,success:!0,summary:Q.output.slice(0,150)}),$("THINKING",`Successfully executed tool: ${D}`);else{let ve=Q.error||"Unknown error";if(h0(ve)){$("STATE_RECONCILIATION",`Critical failure in tool ${D}: ${ve}`),a.onNotice?.("Critical tool failure \u2014 aborting and rolling back changes.","warn");try{let ue=s.get("undo");ue&&await ue.execute({count:100})}catch{}return $("TERMINAL_ABORT","State reverted due to critical failure"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:ve,completedNaturally:S}}let q=h.analyze(D,ve,X);if(Ae=h.buildRecoveryMessage(q,ve),f.recordObservation(`FAILED: ${ve}`,`Recovery: ${q.strategy} \u2014 ${q.suggestion}`),y.push({tool:D,success:!1,summary:ve.slice(0,150)}),q.autoRetry&&!f.isOverBudget()){$("ERROR_HEALING","Attempting auto-recovery for transient error"),a.onNotice?.("Auto-retrying (transient error)\u2026","retry");let ue=await ug(s,D,X,o);a.onToolEnd?.(D,ue.success,ue.output,ue.duration,X),ue.success?(Ae=as(ue.output,lg),f.recordObservation(Ae.slice(0,300),"Auto-retry succeeded"),y[y.length-1]={tool:D,success:!0,summary:ue.output.slice(0,150)},$("THINKING","Recovery successful")):$("THINKING","Recovery failed, continuing turn")}else $("THINKING","Continuing turn with failed step")}r.addToolMessage(Ae),Q.success&&D==="read_file"&&typeof X.path=="string"&&i?.addFile(X.path,Q.output),o.info({tool:D,success:Q.success,durationMs:Q.duration,retries:Q.retries},"Tool executed")}f.isOverBudget()&&a.onNotice?.(`Reached max reasoning steps (${f.getConfig().maxSteps}). Wrapping up.`,"warn")}return w>=g&&!S?(a.onNotice?.(`Reached max iterations (${g}). Stopping.`,"warn"),$("TERMINAL_ABORT","Max iterations boundary exceeded"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:"Max iterations exceeded",completedNaturally:S}):($("TERMINAL_SUCCESS","Turn finalized successfully"),x="IDLE",{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!0,completedNaturally:S})}function De(n){return[...new Set(n)]}function dg(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 fg(){return(n,e)=>e==="dangerous"?"skip":"allow"}var lg,cg,Lr,d0,Ul=N(()=>{"use strict";ma();Ll();Nl();ag();lg=2e3,cg=2,Lr=3,d0={IDLE:["THINKING"],THINKING:["PARSE_VALIDATING","TERMINAL_ABORT","ESCALATING"],PARSE_VALIDATING:["ACTION_READY","ERROR_HEALING","SYNTHESIZING","TERMINAL_ABORT"],ACTION_READY:["EXECUTING_TOOL","STATE_RECONCILIATION","TERMINAL_ABORT"],EXECUTING_TOOL:["THINKING","ERROR_HEALING","STATE_RECONCILIATION","TERMINAL_ABORT","ESCALATING"],ERROR_HEALING:["THINKING","STATE_RECONCILIATION","TERMINAL_ABORT"],STATE_RECONCILIATION:["TERMINAL_ABORT"],SYNTHESIZING:["TERMINAL_SUCCESS","TERMINAL_ABORT"],ESCALATING:["SYNTHESIZING","TERMINAL_ABORT"],TERMINAL_SUCCESS:["IDLE"],TERMINAL_ABORT:["IDLE"]}});var hg,m0,g0,y0,pg,Nr,mg=N(()=>{"use strict";hg=O(Il());Dn();ya();ga();cn();Ii();ja();Ul();m0={hablas:"planner",bob:"architect",alex:"coder",david:"researcher",emma:"product-manager"},g0=(0,hg.default)({level:"silent"}),y0=40,pg={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}},Nr=class{baseConfig;agentModels;toolRegistry=null;onOutput=null;channel=null;mindsetRegistry=fr();sharedContext=null;contextManager;constructor(e){this.baseConfig=e,this.agentModels=Nn(),this.contextManager=new Zt(e)}setSharedContext(e){this.sharedContext=e}setChannel(e){this.channel=e}setToolRegistry(e){this.toolRegistry=e}setOutputCallback(e){this.onOutput=e}reloadModels(){this.agentModels=Nn()}getAgentModel(e){let t=this.agentModels[e];if(t)return{model:t.model,temperature:t.temperature??pg[e]?.temperature??.5};let s=pg[e];return{model:s.model,temperature:s.temperature??.5}}async runAgent(e,t,s,r,i){let o=Date.now(),a=we.find($=>$.role===e),l=this.getAgentModel(e),u=i?.maxIterations||y0,d={...this.baseConfig,model:l.model},f=Fe(d),h=this.buildAgentPrompt(a,s),m=new en(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:$=>{this.emit(a.name,"speaking",$.slice(0,200))},onToolStart:($,_,y)=>{this.emit(a.name,"tool",_),this.channel&&this.channel.emitEvent({type:"act",agent:a.name,toolName:$,toolArgs:this.safeArgs(y),content:_})},onToolEnd:($,_,y)=>{this.channel&&this.channel.emitEvent({type:"observe",agent:a.name,toolName:$,success:_,content:_?this.summarizeOk($,y):`error: ${y.slice(0,120)}`})},onError:$=>this.emit(a.name,"error",$)},x=await Dr({identity:p,client:f,registry:this.toolRegistry,session:m,contextManager:this.contextManager,logger:g0,io:g,safetyPolicy:fg(),abortSignal:i?.abortSignal,skipTools:(!r||r.length===0,!1),maxIterations:u});if(this.sharedContext&&x.touchedFiles.length)try{this.sharedContext.set(`files:@${a.name}`,x.touchedFiles.join(", "))}catch{}let A=x.touchedFiles.length?[`@${a.name} touched: ${x.touchedFiles.join(", ")}`]:[];return{agent:e,agentName:a.name,output:x.output||(x.success?"Done.":x.error??"No output"),toolsUsed:x.toolsUsed,toolResults:x.toolResults,duration:Date.now()-o,iterations:x.iterations,success:x.success,error:x.error,discoveries:A,touchedFiles:x.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(`
799
+ `),{toolCalls:s,displayContent:r.trim(),format:e[0]?.format??"unknown"}}},Hl=null});function f0(n,e,t){let r=og().parse(e,n,t);return{toolCalls:r.toolCalls,displayContent:r.displayContent}}function p0(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 h0(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 ug(n,e,t,s){let r=0,i=Date.now();for(;r<=cg;){let o=await n.execute({name:e,arguments:t});if(o.success||r>=cg)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 jr(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??ys(),h=n.errorRecovery??bs(),m=d?[]:s.getOllamaTools(),p=t.getModel(),g=n.maxIterations??150,x="IDLE",A=0,$=(T,M)=>{let k=d0[x];if(!k||!k.includes(T))throw new Error(`\u{1F6AB} Illegal State Transition Attempt: ${x} \u2501\u2501\u25B6 ${T} (Reason: ${M??"none"})`);o.info({from:x,to:T,reason:M},"FSM State Transition"),x=T},_=[],y=[],v=[],b="",w=0,S=!1;for($("THINKING","Starting agentic turn");w<g;){if(w++,u?.aborted)return $("TERMINAL_ABORT","Operation aborted by signal"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:"Aborted",completedNaturally:S};let T=f.buildBudgetWarningPrompt();T&&r.addUserMessage(T,{priority:"critical",tags:["system-budget"]});let M;try{M=await t.chatWithTools(r.getMessages(),m,u)}catch(E){if(E.name==="AbortError"||u?.aborted)return $("TERMINAL_ABORT","Aborted during inference"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:"Aborted",completedNaturally:S};if(w<=1){a.onNotice?.(`Transient model error: ${E.message??"unknown"} \u2014 retrying\u2026`,"retry"),await new Promise(Y=>setTimeout(Y,1e3)),w--;continue}return $("TERMINAL_ABORT","Inference failure"),a.onError?.(E.message??"Model request failed"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:E.message,completedNaturally:S}}let k=M.message?.content||"",F=M.message?.tool_calls,H=f.parseThinking(k);H.hasThinking&&(f.recordStep({thought:H.thinking}),o.debug({thinking:H.thinking.slice(0,200)},"ReAct thinking")),$("PARSE_VALIDATING","Received model response, parsing");let{toolCalls:V,displayContent:C}=f0(F,k,p);if(V.length===0&&k.toLowerCase().includes("<action>")){if(A++,A>=Fr){$("STATE_RECONCILIATION",`Self-correction loop exhausted after ${A} attempts`);let Y=`Failed to execute after ${Fr} syntax corrections. Rollback initiated.`;a.onError?.(Y);try{let D=s.get("undo");D&&await D.execute({count:100})}catch{}return $("TERMINAL_ABORT","Fatal syntactic self-correction exhaustion"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:Y,completedNaturally:S}}let E=`[SYSTEM ERROR - RETRY ${A}/${Fr}] Malformed action block detected inside <action> tags. Expected a valid JSON object matching the HEP-1 tool schema.
800
+ Please correct your format and try again. Ensure all JSON keys/values are double-quoted and correctly escaped.`;$("ERROR_HEALING",`Syntax error inside action tags (attempt ${A})`),a.onNotice?.(`Malformed action block detected \u2014 healing attempt ${A}/${Fr}\u2026`,"retry"),r.addToolMessage(E),$("THINKING","Error injected, waiting for next generation");continue}if(C&&C.trim()&&(b=C,await a.onAssistantText?.(C,e)),k.includes("ESCALATE_SCOPE")||v.length>3){$("ESCALATING","Detected need for scope escalation"),a.onNotice?.("Escalating scope: Task requires more specialized agents.","info"),r.addAssistantMessage(k,V,e.role),S=!0;break}if(V.length===0){r.addAssistantMessage(k,void 0,e.role),S=!0,$("SYNTHESIZING","Completed execution naturally");break}$("ACTION_READY","Action parsed and verified"),r.addAssistantMessage(k,V,e.role);for(let E=0;E<V.length;E++){let Y=V[E];if(!Y?.function?.name)continue;let D=Y.function.name,X=Y.function.arguments||{},ee=s.getSafetyLevel(D)??"confirm";if(!s.get(D)){$("ERROR_HEALING",`Unknown tool execution: ${D}`),a.onNotice?.(`Unknown tool: ${D} \u2014 skipping`,"warn"),r.addToolMessage(`Error: Unknown tool "${D}". Available: ${s.getAll().map(ve=>ve.name).join(", ")}`),$("THINKING","Returning to thought loop");continue}if(await l(D,ee,X)==="skip"){r.addToolMessage(`Tool ${D} was skipped by policy/user.`);break}_.push(D),typeof X.path=="string"&&v.push(X.path);let _e=p0(D,X);a.onToolStart?.(D,_e,X),a.onToolCall?.(),f.recordStep({thought:H.hasThinking?`Executing: ${D}`:"",action:D,actionInput:X}),$("EXECUTING_TOOL",`Executing tool: ${D}`);let Q=await ug(s,D,X,o);a.onToolEnd?.(D,Q.success,Q.error||Q.output,Q.duration,X);let Ae;if(Q.success)Ae=ls(Q.output,lg),f.recordObservation(Ae.slice(0,300)),y.push({tool:D,success:!0,summary:Q.output.slice(0,150)}),$("THINKING",`Successfully executed tool: ${D}`);else{let ve=Q.error||"Unknown error";if(h0(ve)){$("STATE_RECONCILIATION",`Critical failure in tool ${D}: ${ve}`),a.onNotice?.("Critical tool failure \u2014 aborting and rolling back changes.","warn");try{let ue=s.get("undo");ue&&await ue.execute({count:100})}catch{}return $("TERMINAL_ABORT","State reverted due to critical failure"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:ve,completedNaturally:S}}let q=h.analyze(D,ve,X);if(Ae=h.buildRecoveryMessage(q,ve),f.recordObservation(`FAILED: ${ve}`,`Recovery: ${q.strategy} \u2014 ${q.suggestion}`),y.push({tool:D,success:!1,summary:ve.slice(0,150)}),q.autoRetry&&!f.isOverBudget()){$("ERROR_HEALING","Attempting auto-recovery for transient error"),a.onNotice?.("Auto-retrying (transient error)\u2026","retry");let ue=await ug(s,D,X,o);a.onToolEnd?.(D,ue.success,ue.output,ue.duration,X),ue.success?(Ae=ls(ue.output,lg),f.recordObservation(Ae.slice(0,300),"Auto-retry succeeded"),y[y.length-1]={tool:D,success:!0,summary:ue.output.slice(0,150)},$("THINKING","Recovery successful")):$("THINKING","Recovery failed, continuing turn")}else $("THINKING","Continuing turn with failed step")}r.addToolMessage(Ae),Q.success&&D==="read_file"&&typeof X.path=="string"&&i?.addFile(X.path,Q.output),o.info({tool:D,success:Q.success,durationMs:Q.duration,retries:Q.retries},"Tool executed")}f.isOverBudget()&&a.onNotice?.(`Reached max reasoning steps (${f.getConfig().maxSteps}). Wrapping up.`,"warn")}return w>=g&&!S?(a.onNotice?.(`Reached max iterations (${g}). Stopping.`,"warn"),$("TERMINAL_ABORT","Max iterations boundary exceeded"),{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!1,error:"Max iterations exceeded",completedNaturally:S}):($("TERMINAL_SUCCESS","Turn finalized successfully"),x="IDLE",{output:b,toolsUsed:De(_),toolResults:y,touchedFiles:De(v),iterations:w,success:!0,completedNaturally:S})}function De(n){return[...new Set(n)]}function dg(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 fg(){return(n,e)=>e==="dangerous"?"skip":"allow"}var lg,cg,Fr,d0,ql=N(()=>{"use strict";ga();Dl();Fl();ag();lg=2e3,cg=2,Fr=3,d0={IDLE:["THINKING"],THINKING:["PARSE_VALIDATING","TERMINAL_ABORT","ESCALATING"],PARSE_VALIDATING:["ACTION_READY","ERROR_HEALING","SYNTHESIZING","TERMINAL_ABORT"],ACTION_READY:["EXECUTING_TOOL","STATE_RECONCILIATION","TERMINAL_ABORT"],EXECUTING_TOOL:["THINKING","ERROR_HEALING","STATE_RECONCILIATION","TERMINAL_ABORT","ESCALATING"],ERROR_HEALING:["THINKING","STATE_RECONCILIATION","TERMINAL_ABORT"],STATE_RECONCILIATION:["TERMINAL_ABORT"],SYNTHESIZING:["TERMINAL_SUCCESS","TERMINAL_ABORT"],ESCALATING:["SYNTHESIZING","TERMINAL_ABORT"],TERMINAL_SUCCESS:["IDLE"],TERMINAL_ABORT:["IDLE"]}});var hg,m0,g0,y0,pg,Hr,mg=N(()=>{"use strict";hg=O(Ml());Nn();ba();ya();un();Mi();Ha();ql();m0={hablas:"planner",bob:"architect",alex:"coder",david:"researcher",emma:"product-manager"},g0=(0,hg.default)({level:"silent"}),y0=40,pg={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}},Hr=class{baseConfig;agentModels;toolRegistry=null;onOutput=null;channel=null;mindsetRegistry=mr();sharedContext=null;contextManager;constructor(e){this.baseConfig=e,this.agentModels=Fn(),this.contextManager=new en(e)}setSharedContext(e){this.sharedContext=e}setChannel(e){this.channel=e}setToolRegistry(e){this.toolRegistry=e}setOutputCallback(e){this.onOutput=e}reloadModels(){this.agentModels=Fn()}getAgentModel(e){let t=this.agentModels[e];if(t)return{model:t.model,temperature:t.temperature??pg[e]?.temperature??.5};let s=pg[e];return{model:s.model,temperature:s.temperature??.5}}async runAgent(e,t,s,r,i){let o=Date.now(),a=we.find($=>$.role===e),l=this.getAgentModel(e),u=i?.maxIterations||y0,d={...this.baseConfig,model:l.model},f=Fe(d),h=this.buildAgentPrompt(a,s),m=new tn(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:$=>{this.emit(a.name,"speaking",$.slice(0,200))},onToolStart:($,_,y)=>{this.emit(a.name,"tool",_),this.channel&&this.channel.emitEvent({type:"act",agent:a.name,toolName:$,toolArgs:this.safeArgs(y),content:_})},onToolEnd:($,_,y)=>{this.channel&&this.channel.emitEvent({type:"observe",agent:a.name,toolName:$,success:_,content:_?this.summarizeOk($,y):`error: ${y.slice(0,120)}`})},onError:$=>this.emit(a.name,"error",$)},x=await jr({identity:p,client:f,registry:this.toolRegistry,session:m,contextManager:this.contextManager,logger:g0,io:g,safetyPolicy:fg(),abortSignal:i?.abortSignal,skipTools:(!r||r.length===0,!1),maxIterations:u});if(this.sharedContext&&x.touchedFiles.length)try{this.sharedContext.set(`files:@${a.name}`,x.touchedFiles.join(", "))}catch{}let A=x.touchedFiles.length?[`@${a.name} touched: ${x.touchedFiles.join(", ")}`]:[];return{agent:e,agentName:a.name,output:x.output||(x.success?"Done.":x.error??"No output"),toolsUsed:x.toolsUsed,toolResults:x.toolResults,duration:Date.now()-o,iterations:x.iterations,success:x.success,error:x.error,discoveries:A,touchedFiles:x.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(`
801
801
  ## Handoff Chain`);for(let p of o)d.push(`- @${p.from} \u2192 @${p.to}: ${p.context.slice(0,100)}`)}let f=d.join(`
802
802
  `),h=we.find(p=>p.role===l);if(h&&a>0){let p=e[a-1].role,g=we.find(x=>x.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+=`
803
803
 
@@ -869,7 +869,7 @@ Expertise: ${e.expertise.join(", ")}
869
869
  ${t}`),this.sharedContext){let a=this.sharedContext.getSummary();a&&(o+=`
870
870
 
871
871
  ## Shared Team Context
872
- ${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 gg,Fr,yg=N(()=>{"use strict";gg=require("events"),Fr=class extends gg.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 b0,bt,jr,Hr,bg=N(()=>{"use strict";Dn();b0={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."},bt={hablas:"Hablas",emma:"Emma",bob:"Bob",alex:"Alex",david:"David"},jr={handoff:(n,e,t)=>{let s=bt[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, @${bt[e]}. Proceeding.`,review:(n,e)=>`@${bt[e]}, structurally sound. Watch the boundaries on the next pass.`,reviewAck:(n,e)=>`Noted, @${bt[e]}. Integrating.`},Hr=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=Fe(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),()=>jr.handoff(e,t,s))}async generateAckLine(e,t){return this.generate(`ack:${e}:${t}`,this.buildPrompt(e,t,"ack"),()=>jr.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)),()=>jr.review(e,t))}async generateReviewAck(e,t){return this.generate(`reviewAck:${e}:${t}`,this.buildPrompt(e,t,"reviewAck"),()=>jr.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 ${bt[e]}, speaking in your own voice.
872
+ ${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 gg,Br,yg=N(()=>{"use strict";gg=require("events"),Br=class extends gg.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 b0,bt,Ur,qr,bg=N(()=>{"use strict";Nn();b0={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."},bt={hablas:"Hablas",emma:"Emma",bob:"Bob",alex:"Alex",david:"David"},Ur={handoff:(n,e,t)=>{let s=bt[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, @${bt[e]}. Proceeding.`,review:(n,e)=>`@${bt[e]}, structurally sound. Watch the boundaries on the next pass.`,reviewAck:(n,e)=>`Noted, @${bt[e]}. Integrating.`},qr=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=Fe(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),()=>Ur.handoff(e,t,s))}async generateAckLine(e,t){return this.generate(`ack:${e}:${t}`,this.buildPrompt(e,t,"ack"),()=>Ur.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)),()=>Ur.review(e,t))}async generateReviewAck(e,t){return this.generate(`reviewAck:${e}:${t}`,this.buildPrompt(e,t,"reviewAck"),()=>Ur.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 ${bt[e]}, speaking in your own voice.
873
873
  ${b0[e]}
874
874
 
875
875
  Hard constraints:
@@ -877,7 +877,7 @@ Hard constraints:
877
877
  - No prefix, no quotes, no markdown, no emojis, no role labels.
878
878
  - Maximum ${this.opts.maxChars} characters.
879
879
  - Address @${bt[t]} directly.
880
- - Stay in character. Be useful, not chatty.`,o;switch(s){case"handoff":o=`You are about to hand the following task to @${bt[t]}. Write a single in-character line that briefly frames what you need from them. Task: "${(r||"").slice(0,300)}"`;break;case"ack":o=`@${bt[t]} just handed you a task. Write a single in-character line acknowledging it and stating your immediate next move.`;break;case"review":o=`You just reviewed @${bt[t]}'s output below. Write a single in-character line of feedback \u2014 substantive but extremely brief. Output excerpt: """${(r||"").slice(0,400)}"""`;break;case"reviewAck":o=`@${bt[t]} just reviewed your work and gave you feedback. Write a single in-character line acknowledging it and noting the integration.`;break}return[{role:"system",content:i},{role:"user",content:o}]}cleanLine(e){let t=e.trim();return t=t.replace(/^```[a-z]*\n?|```$/gi,"").trim(),t=t.split(/\r?\n/)[0].trim(),t=t.replace(/^@?[A-Z][a-zA-Z]+\s*:\s*/,"").trim(),t=t.replace(/^["'`«»“”]+|["'`«»“”]+$/g,"").trim(),t.length>this.opts.maxChars&&(t=t.slice(0,this.opts.maxChars-1).trim()+"\u2026"),t}hash(e){let t=2166136261;for(let s=0;s<e.length;s++)t^=e.charCodeAt(s),t=t+((t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24))>>>0;return t.toString(36)}}});var re,ct,v0,wg,w0,xg,vg,Pn,ql=N(()=>{"use strict";re=O(require("fs")),ct=O(require("path")),v0=".hablas",wg=`# Project Context
880
+ - Stay in character. Be useful, not chatty.`,o;switch(s){case"handoff":o=`You are about to hand the following task to @${bt[t]}. Write a single in-character line that briefly frames what you need from them. Task: "${(r||"").slice(0,300)}"`;break;case"ack":o=`@${bt[t]} just handed you a task. Write a single in-character line acknowledging it and stating your immediate next move.`;break;case"review":o=`You just reviewed @${bt[t]}'s output below. Write a single in-character line of feedback \u2014 substantive but extremely brief. Output excerpt: """${(r||"").slice(0,400)}"""`;break;case"reviewAck":o=`@${bt[t]} just reviewed your work and gave you feedback. Write a single in-character line acknowledging it and noting the integration.`;break}return[{role:"system",content:i},{role:"user",content:o}]}cleanLine(e){let t=e.trim();return t=t.replace(/^```[a-z]*\n?|```$/gi,"").trim(),t=t.split(/\r?\n/)[0].trim(),t=t.replace(/^@?[A-Z][a-zA-Z]+\s*:\s*/,"").trim(),t=t.replace(/^["'`«»“”]+|["'`«»“”]+$/g,"").trim(),t.length>this.opts.maxChars&&(t=t.slice(0,this.opts.maxChars-1).trim()+"\u2026"),t}hash(e){let t=2166136261;for(let s=0;s<e.length;s++)t^=e.charCodeAt(s),t=t+((t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24))>>>0;return t.toString(36)}}});var re,ct,v0,wg,w0,xg,vg,In,Kl=N(()=>{"use strict";re=O(require("fs")),ct=O(require("path")),v0=".hablas",wg=`# Project Context
881
881
 
882
882
  ## Overview
883
883
  <!-- Auto-generated by hablas. Describe your project here. -->
@@ -901,7 +901,7 @@ Hard constraints:
901
901
 
902
902
  ## Completed
903
903
  <!-- Format: - [x] Task description (@agent) \u2014 result -->
904
- `,vg={"CONTEXT.md":wg,"DECISIONS.md":w0,"TASKS.md":xg},Pn=class{contextDir;constructor(e){this.contextDir=ct.join(e,v0)}init(){let e=ct.join(ct.dirname(this.contextDir),".flowagent");if(re.existsSync(e)&&!re.existsSync(this.contextDir))try{re.renameSync(e,this.contextDir)}catch{}re.existsSync(this.contextDir)||re.mkdirSync(this.contextDir,{recursive:!0});for(let[t,s]of Object.entries(vg)){let r=ct.join(this.contextDir,t);re.existsSync(r)||re.writeFileSync(r,s,"utf-8")}}exists(){return re.existsSync(this.contextDir)}read(e){let t=ct.join(this.contextDir,e);return re.existsSync(t)?re.readFileSync(t,"utf-8"):null}write(e,t){this.ensureDir();let s=ct.join(this.contextDir,e);re.writeFileSync(s,t,"utf-8")}append(e,t){this.ensureDir();let s=ct.join(this.contextDir,e),r=re.existsSync(s)?re.readFileSync(s,"utf-8"):"";re.writeFileSync(s,r+`
904
+ `,vg={"CONTEXT.md":wg,"DECISIONS.md":w0,"TASKS.md":xg},In=class{contextDir;constructor(e){this.contextDir=ct.join(e,v0)}init(){let e=ct.join(ct.dirname(this.contextDir),".flowagent");if(re.existsSync(e)&&!re.existsSync(this.contextDir))try{re.renameSync(e,this.contextDir)}catch{}re.existsSync(this.contextDir)||re.mkdirSync(this.contextDir,{recursive:!0});for(let[t,s]of Object.entries(vg)){let r=ct.join(this.contextDir,t);re.existsSync(r)||re.writeFileSync(r,s,"utf-8")}}exists(){return re.existsSync(this.contextDir)}read(e){let t=ct.join(this.contextDir,e);return re.existsSync(t)?re.readFileSync(t,"utf-8"):null}write(e,t){this.ensureDir();let s=ct.join(this.contextDir,e);re.writeFileSync(s,t,"utf-8")}append(e,t){this.ensureDir();let s=ct.join(this.contextDir,e),r=re.existsSync(s)?re.readFileSync(s,"utf-8"):"";re.writeFileSync(s,r+`
905
905
  `+t,"utf-8")}logDecision(e,t,s){let i=`| ${new Date().toISOString().split("T")[0]} | ${e} | ${t} | ${s} |`;this.append("DECISIONS.md",i)}addTask(e,t){let s=`- [ ] ${e} (@${t})`,i=(this.read("TASKS.md")||xg).replace(`## Active Tasks
906
906
  `,`## Active Tasks
907
907
  ${s}
@@ -914,9 +914,9 @@ ${t.content}`).join(`
914
914
  `)}persistKV(){if(this.kvStore.size===0)return;let e=this.read("CONTEXT.md")||wg,t=Array.from(this.kvStore.entries()).map(([i,o])=>`- **${i}**: ${o}`).join(`
915
915
  `),s=/## Notes\n[\s\S]*$/,r=e.replace(s,`## Notes
916
916
  ${t}
917
- `);this.write("CONTEXT.md",r)}ensureDir(){re.existsSync(this.contextDir)||re.mkdirSync(this.contextDir,{recursive:!0})}}});function Kl(n){return we.find(e=>e.role===n)?.name||n}var Br,Sg=N(()=>{"use strict";cn();ql();Br=class{channel;runner;chat;constructor(e,t,s,r){this.channel=e,this.runner=t,this.chat=s,this.runner.setChannel(e),this.chat.resetBudget()}async run(e,t,s,r={}){this.chat.setAbortSignal(r.abortSignal);let i=r.peerReview!==!1,o=new Pn(process.cwd());this.runner.setSharedContext(o),this.channel.emitEvent({type:"phase",agent:"System",content:"Delegating to the team"});let a=t.tasks.filter(h=>h.role!=="hablas").map(h=>({role:h.role,task:`${h.description}
917
+ `);this.write("CONTEXT.md",r)}ensureDir(){re.existsSync(this.contextDir)||re.mkdirSync(this.contextDir,{recursive:!0})}}});function Gl(n){return we.find(e=>e.role===n)?.name||n}var Kr,Sg=N(()=>{"use strict";un();Kl();Kr=class{channel;runner;chat;constructor(e,t,s,r){this.channel=e,this.runner=t,this.chat=s,this.runner.setChannel(e),this.chat.resetBudget()}async run(e,t,s,r={}){this.chat.setAbortSignal(r.abortSignal);let i=r.peerReview!==!1,o=new In(process.cwd());this.runner.setSharedContext(o),this.channel.emitEvent({type:"phase",agent:"System",content:"Delegating to the team"});let a=t.tasks.filter(h=>h.role!=="hablas").map(h=>({role:h.role,task:`${h.description}
918
918
 
919
- Original request: ${e}`})),l=[],u="hablas",d=null;for(let h of a){if(r.abortSignal?.aborted)break;let m=we.find($=>$.role===h.role);if(!m)continue;this.channel.emitEvent({type:"handoff",agent:Kl(u),to:m.name});let p=await this.chat.generateHandoffLine(u,h.role,h.task);this.channel.emitEvent({type:"speak",agent:Kl(u),to:m.name,content:p});let g=await this.chat.generateAckLine(h.role,u);this.channel.emitEvent({type:"speak",agent:m.name,to:Kl(u),content:g});let x=Date.now(),A=await this.runner.runAgent(h.role,h.task,void 0,s,{abortSignal:r.abortSignal});l.push(A),A.success&&A.output?(this.channel.emitEvent({type:"summary",agent:m.name,durationMs:Date.now()-x}),h.role==="alex"&&(d=A.output),i&&h.role==="alex"&&t.tasks.some($=>$.role==="bob")&&d&&await this.runPeerReview("bob","alex",d,r.abortSignal)):A.error&&this.channel.emitEvent({type:"error",agent:m.name,content:A.error}),u=h.role}this.channel.emitEvent({type:"phase",agent:"System",content:"Hablas compiling final report"});let f=await this.synthesize(e,l,s,r.abortSignal);return this.channel.emitEvent({type:"done",agent:"Hablas"}),f}async runPeerReview(e,t,s,r){let i=we.find(u=>u.role===e),o=we.find(u=>u.role===t);if(!i||!o)return;let a=await this.chat.generateReviewLine(e,t,s);this.channel.emitEvent({type:"review",agent:i.name,to:o.name,content:a});let l=await this.chat.generateReviewAck(t,e);this.channel.emitEvent({type:"speak",agent:o.name,to:i.name,content:l}),r?.aborted}async synthesize(e,t,s,r){let i=t.filter(d=>d.success&&d.output);if(i.length===0)return{results:t,finalSynthesis:"The team encountered errors and could not complete the task. Please review the logs and try again.",synthesisOk:!1};let o=i.map(d=>{let f=we.find(h=>h.role===d.agent);return`### Report from @${d.agentName} (${f?.title??d.agent}):
919
+ Original request: ${e}`})),l=[],u="hablas",d=null;for(let h of a){if(r.abortSignal?.aborted)break;let m=we.find($=>$.role===h.role);if(!m)continue;this.channel.emitEvent({type:"handoff",agent:Gl(u),to:m.name});let p=await this.chat.generateHandoffLine(u,h.role,h.task);this.channel.emitEvent({type:"speak",agent:Gl(u),to:m.name,content:p});let g=await this.chat.generateAckLine(h.role,u);this.channel.emitEvent({type:"speak",agent:m.name,to:Gl(u),content:g});let x=Date.now(),A=await this.runner.runAgent(h.role,h.task,void 0,s,{abortSignal:r.abortSignal});l.push(A),A.success&&A.output?(this.channel.emitEvent({type:"summary",agent:m.name,durationMs:Date.now()-x}),h.role==="alex"&&(d=A.output),i&&h.role==="alex"&&t.tasks.some($=>$.role==="bob")&&d&&await this.runPeerReview("bob","alex",d,r.abortSignal)):A.error&&this.channel.emitEvent({type:"error",agent:m.name,content:A.error}),u=h.role}this.channel.emitEvent({type:"phase",agent:"System",content:"Hablas compiling final report"});let f=await this.synthesize(e,l,s,r.abortSignal);return this.channel.emitEvent({type:"done",agent:"Hablas"}),f}async runPeerReview(e,t,s,r){let i=we.find(u=>u.role===e),o=we.find(u=>u.role===t);if(!i||!o)return;let a=await this.chat.generateReviewLine(e,t,s);this.channel.emitEvent({type:"review",agent:i.name,to:o.name,content:a});let l=await this.chat.generateReviewAck(t,e);this.channel.emitEvent({type:"speak",agent:o.name,to:i.name,content:l}),r?.aborted}async synthesize(e,t,s,r){let i=t.filter(d=>d.success&&d.output);if(i.length===0)return{results:t,finalSynthesis:"The team encountered errors and could not complete the task. Please review the logs and try again.",synthesisOk:!1};let o=i.map(d=>{let f=we.find(h=>h.role===d.agent);return`### Report from @${d.agentName} (${f?.title??d.agent}):
920
920
  ${d.output}`}).join(`
921
921
 
922
922
  `),a=`You are Hablas, the Team Leader. Your team has completed a multi-agent workflow for the user's request: "${e}".
@@ -929,10 +929,10 @@ ${o}
929
929
  Please compile, synthesize, and present the final unified response to the user. Describe what was achieved, the files modified/created (if any), and any next steps. Speak in your characteristic Hablas voice \u2014 INTJ, authoritative, terse, engineering-precise. Speak directly to the user.`,l=await this.runner.runAgent("hablas",a,void 0,s,{abortSignal:r});if(l.success&&l.output)return{results:t,finalSynthesis:l.output,synthesisOk:!0};let u=i.map(d=>{let f=we.find(h=>h.role===d.agent);return`### @${d.agentName} (${f?.title??d.agent}):
930
930
  ${d.output}`}).join(`
931
931
 
932
- `);return{results:t,finalSynthesis:u,synthesisOk:!1}}}});function ut(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 Ur(n){return n==="Hablas"?"\u2605":"\u25C6"}function vs(n,e=140){let t=(n||"").replace(/\s+/g," ").trim();return t.length>e?t.slice(0,e-1)+"\u2026":t}function Gl(n){return n==="Hablas"?"Team Leader":n==="Bob"?"Architect":n==="Alex"?"Engineer":n==="David"?"Data Analyst":n==="Emma"?"Product Manager":"Specialist"}var qr,_g=N(()=>{"use strict";mn();qr=class{channel;opts;attached=!1;listener;lastThinking=null;lastLine="";state={taskTitle:"Autonomous Codebase Engineering",currentPhase:"Initializing",activeAgent:"Hablas",activeAgentTitle:"Team Leader",currentActivity:"Analyzing workspace",roster:{Hablas:"active",Emma:"pending",Bob:"pending",Alex:"pending",David:"pending"}};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.state.currentPhase=t,(t.includes("compiling")||t.includes("report")||t.includes("synthesizing"))&&(this.state.activeAgent="Hablas",this.state.activeAgentTitle="Team Leader",this.state.roster.Hablas="active",this.state.currentActivity="Compiling individual reports and synthesizing final unified solution"),this.print(`
933
- ${c.accent("\u25B8")} ${c.strong(t.toUpperCase())}`),this.lastThinking=null)}renderHandoff(e){let t=e.agent,s=e.to||"";if(!s)return;let r=ut(t),i=ut(s);this.state.roster[t]&&(this.state.roster[t]="done"),this.state.roster[s]="active",this.state.activeAgent=s,this.state.activeAgentTitle=Gl(s),this.state.currentPhase=`Task Handoff to @${s}`,this.state.currentActivity=`Transitioning task context from @${t} to @${s}`,this.print(` ${r(Ur(t))} ${r(t)} ${c.muted("\u2501\u2501\u25B6")} ${i(Ur(s))} ${i(s)}`),this.lastThinking=null}renderThinking(e){if(this.opts.hideThinking||this.lastThinking===e.agent)return;this.lastThinking=e.agent;let t=ut(e.agent);this.state.activeAgent=e.agent,this.state.activeAgentTitle=Gl(e.agent),this.state.roster[e.agent]="active",this.state.currentActivity="Analyzing workspace & formulating reasoning steps",this.print(` ${t("\u25C9")} [Active Agent: ${e.agent}] is thinking & formulating response\u2026`)}renderSpeak(e){let t=vs(e.content||"",this.opts.maxChars);if(!t)return;let s=ut(e.agent),r=e.to?` ${c.muted("\u2192")} ${ut(e.to)("@"+e.to)}`:"",i=`speak:${e.agent}:${e.to||""}:${t}`;i!==this.lastLine&&(this.lastLine=i,this.print(` ${s(Ur(e.agent))} ${s(e.agent)}${r}${c.muted(":")} ${c.secondary(t)}`),this.lastThinking=null)}renderAct(e){if(this.opts.hideActs)return;let t=ut(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.state.activeAgent=e.agent,this.state.activeAgentTitle=Gl(e.agent),this.state.roster[e.agent]="active",this.state.currentActivity=`Executing ${s}${i}`,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=vs(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=vs(e.content||"",this.opts.maxChars);if(!r)return;let i=ut(t),o=ut(s);this.print(`
934
- ${i("\u270E")} ${c.strong("@"+t)} ${c.muted("reviewing")} ${o("@"+s)}${c.muted(":")} ${c.secondary(r)}`),this.lastThinking=null}renderSummary(e){let t=ut(e.agent),s=e.durationMs?` ${c.muted(`(${(e.durationMs/1e3).toFixed(1)}s)`)}`:"";this.print(` ${t(Ur(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=vs(e.content||"",this.opts.maxChars);if(!t)return;let s=ut(e.agent);this.print(` ${s("\u25C6")} ${s(e.agent)} ${c.muted("decision:")} ${c.secondary(t)}`)}renderDone(e){this.print(`
935
- ${c.chrome("\u2500".repeat(56))}`),this.lastThinking=null}renderError(e){let t=ut(e.agent),s=vs(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 Kr,Ag=N(()=>{"use strict";Kr=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 ce,dt,x0,S0,_0,A0,k0,$0,E0,Gr,kg=N(()=>{"use strict";ce=O(require("fs")),dt=O(require("path")),x0=".hablas",S0=`# Project Context \u2014 Hablas AI
932
+ `);return{results:t,finalSynthesis:u,synthesisOk:!1}}}});function ut(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 ws(n,e=140){let t=(n||"").replace(/\s+/g," ").trim();return t.length>e?t.slice(0,e-1)+"\u2026":t}function Wl(n){return n==="Hablas"?"Team Leader":n==="Bob"?"Architect":n==="Alex"?"Engineer":n==="David"?"Data Analyst":n==="Emma"?"Product Manager":"Specialist"}var Wr,_g=N(()=>{"use strict";gn();Wr=class{channel;opts;attached=!1;listener;lastThinking=null;lastLine="";state={taskTitle:"Autonomous Codebase Engineering",currentPhase:"Initializing",activeAgent:"Hablas",activeAgentTitle:"Team Leader",currentActivity:"Analyzing workspace",roster:{Hablas:"active",Emma:"pending",Bob:"pending",Alex:"pending",David:"pending"}};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.state.currentPhase=t,(t.includes("compiling")||t.includes("report")||t.includes("synthesizing"))&&(this.state.activeAgent="Hablas",this.state.activeAgentTitle="Team Leader",this.state.roster.Hablas="active",this.state.currentActivity="Compiling individual reports and synthesizing final unified solution"),this.print(`
933
+ ${c.accent("\u25B8")} ${c.strong(t.toUpperCase())}`),this.lastThinking=null)}renderHandoff(e){let t=e.agent,s=e.to||"";if(!s)return;let r=ut(t),i=ut(s);this.state.roster[t]&&(this.state.roster[t]="done"),this.state.roster[s]="active",this.state.activeAgent=s,this.state.activeAgentTitle=Wl(s),this.state.currentPhase=`Task Handoff to @${s}`,this.state.currentActivity=`Transitioning task context from @${t} to @${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=ut(e.agent);this.state.activeAgent=e.agent,this.state.activeAgentTitle=Wl(e.agent),this.state.roster[e.agent]="active",this.state.currentActivity="Analyzing workspace & formulating reasoning steps",this.print(` ${t("\u25C9")} [Active Agent: ${e.agent}] is thinking & formulating response\u2026`)}renderSpeak(e){let t=ws(e.content||"",this.opts.maxChars);if(!t)return;let s=ut(e.agent),r=e.to?` ${c.muted("\u2192")} ${ut(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=ut(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.state.activeAgent=e.agent,this.state.activeAgentTitle=Wl(e.agent),this.state.roster[e.agent]="active",this.state.currentActivity=`Executing ${s}${i}`,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=ws(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=ws(e.content||"",this.opts.maxChars);if(!r)return;let i=ut(t),o=ut(s);this.print(`
934
+ ${i("\u270E")} ${c.strong("@"+t)} ${c.muted("reviewing")} ${o("@"+s)}${c.muted(":")} ${c.secondary(r)}`),this.lastThinking=null}renderSummary(e){let t=ut(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=ws(e.content||"",this.opts.maxChars);if(!t)return;let s=ut(e.agent);this.print(` ${s("\u25C6")} ${s(e.agent)} ${c.muted("decision:")} ${c.secondary(t)}`)}renderDone(e){this.print(`
935
+ ${c.chrome("\u2500".repeat(56))}`),this.lastThinking=null}renderError(e){let t=ut(e.agent),s=ws(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 Vr,Ag=N(()=>{"use strict";Vr=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 ce,dt,x0,S0,_0,A0,k0,$0,E0,zr,kg=N(()=>{"use strict";ce=O(require("fs")),dt=O(require("path")),x0=".hablas",S0=`# Project Context \u2014 Hablas AI
936
936
 
937
937
  ## Project Overview
938
938
  <!-- Auto-populated by Hablas on first scan -->
@@ -1026,7 +1026,7 @@ ${d.output}`}).join(`
1026
1026
 
1027
1027
  ## Dependency Notes
1028
1028
  <!-- Important notes about dependencies and versions -->
1029
- `,E0={"HABLAS.md":S0,"PROGRESS.md":_0,"ARCHITECTURE.md":A0,"AGENTS.md":k0,"MEMORY.md":$0},Gr=class{contextDir;sessionDelegations=[];sessionDiscoveries=[];constructor(e){this.contextDir=dt.join(e,x0)}init(){let e=dt.join(dt.dirname(this.contextDir),".hablas-legacy");if(ce.existsSync(e)&&!ce.existsSync(this.contextDir))try{ce.renameSync(e,this.contextDir);let t=dt.join(this.contextDir,"LEGACY.md"),s=dt.join(this.contextDir,"HABLAS.md");ce.existsSync(t)&&!ce.existsSync(s)&&ce.renameSync(t,s)}catch{}ce.existsSync(this.contextDir)||ce.mkdirSync(this.contextDir,{recursive:!0});for(let[t,s]of Object.entries(E0)){let r=dt.join(this.contextDir,t);ce.existsSync(r)||ce.writeFileSync(r,s,"utf-8")}}exists(){return ce.existsSync(this.contextDir)}readContext(e){let t=dt.join(this.contextDir,e);return ce.existsSync(t)?ce.readFileSync(t,"utf-8"):null}updateProgress(e){let t=new Date().toISOString().split("T")[0],s=new Date().toISOString().split("T")[1].split(".")[0],r=`- [${t} ${s}] ${e}`;this.appendToSection("PROGRESS.md","## Progress Log",r)}addTask(e,t){let s=new Date().toISOString().split("T")[0],r=`| ${e} | @${t} | \u{1F535} pending | ${s} | \u2014 |`;this.appendToSection("PROGRESS.md","## Task Breakdown",r)}updateSprint(e){this.updateSection("PROGRESS.md","## Current Sprint",e)}recordDecision(e,t,s,r="medium"){let o=`| ${new Date().toISOString().split("T")[0]} | ${e} | ${t} | ${s} | ${r} |`;this.appendToSection("HABLAS.md","## Key Decisions",o)}updateArchitecture(e,t){this.updateSection("ARCHITECTURE.md",e,t)}recordADR(e,t,s="accepted"){let r=new Date().toISOString().split("T")[0],a=`| ${((this.readContext("ARCHITECTURE.md")||"").match(/^\|/gm)||[]).length} | ${e} | ${s} | ${r} | ${t} |`;this.appendToSection("ARCHITECTURE.md","## Architecture Decision Records (ADRs)",a)}logDelegation(e){this.sessionDelegations.push(e);let t=`| ${e.time} | ${e.from} | ${e.to} | ${e.task.slice(0,50)} | ${e.model} | ${e.result} | ${e.durationMs}ms |`;this.appendToSection("AGENTS.md","## Delegation Log",t)}logSession(e){let t=`| ${e.sessionId} | ${e.date} | ${Math.round(e.duration/1e3)}s | ${e.agentsUsed.join(", ")} | ${e.tasksCompleted} |`;this.appendToSection("AGENTS.md","## Session History",t)}updateAgentPerformance(e,t,s,r,i){let o=`| @${e} | ${t} | ${Math.round(s*100)}% | ${Math.round(r)}ms | ${i.join(", ")} |`;this.appendToSection("AGENTS.md","## Agent Performance",o)}logAgentComm(e,t,s){let i=`- [${new Date().toISOString()}] **@${e}** \u2192 **@${t}**: ${s.slice(0,200)}`;this.appendToSection("AGENTS.md","## Inter-Agent Communication",i)}addConvention(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] ${e} *(found by ${t})*`;this.appendToSection("MEMORY.md","## Project Conventions",r),this.sessionDiscoveries.push({type:"convention",description:e,source:t,date:s})}addPattern(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] ${e} *(found by ${t})*`;this.appendToSection("MEMORY.md","## Discovered Patterns",r),this.sessionDiscoveries.push({type:"pattern",description:e,source:t,date:s})}addGotcha(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] \u26A0\uFE0F ${e} *(found by ${t})*`;this.appendToSection("MEMORY.md","## Known Gotchas",r),this.sessionDiscoveries.push({type:"gotcha",description:e,source:t,date:s})}addAutoDiscovery(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] \u{1F50D} ${e} *(by ${t})*`;this.appendToSection("MEMORY.md","## Auto-Discoveries",r),this.sessionDiscoveries.push({type:"pattern",description:e,source:t,date:s})}getSummary(e=8e3){let t=["HABLAS.md","PROGRESS.md","ARCHITECTURE.md","MEMORY.md"],s=[],r=0;for(let i of t){let o=this.readContext(i);if(o&&o.trim().length>0){let a=e-r;if(a<=200)break;let l=o.length>a?o.slice(0,a)+`
1029
+ `,E0={"HABLAS.md":S0,"PROGRESS.md":_0,"ARCHITECTURE.md":A0,"AGENTS.md":k0,"MEMORY.md":$0},zr=class{contextDir;sessionDelegations=[];sessionDiscoveries=[];constructor(e){this.contextDir=dt.join(e,x0)}init(){let e=dt.join(dt.dirname(this.contextDir),".hablas-legacy");if(ce.existsSync(e)&&!ce.existsSync(this.contextDir))try{ce.renameSync(e,this.contextDir);let t=dt.join(this.contextDir,"LEGACY.md"),s=dt.join(this.contextDir,"HABLAS.md");ce.existsSync(t)&&!ce.existsSync(s)&&ce.renameSync(t,s)}catch{}ce.existsSync(this.contextDir)||ce.mkdirSync(this.contextDir,{recursive:!0});for(let[t,s]of Object.entries(E0)){let r=dt.join(this.contextDir,t);ce.existsSync(r)||ce.writeFileSync(r,s,"utf-8")}}exists(){return ce.existsSync(this.contextDir)}readContext(e){let t=dt.join(this.contextDir,e);return ce.existsSync(t)?ce.readFileSync(t,"utf-8"):null}updateProgress(e){let t=new Date().toISOString().split("T")[0],s=new Date().toISOString().split("T")[1].split(".")[0],r=`- [${t} ${s}] ${e}`;this.appendToSection("PROGRESS.md","## Progress Log",r)}addTask(e,t){let s=new Date().toISOString().split("T")[0],r=`| ${e} | @${t} | \u{1F535} pending | ${s} | \u2014 |`;this.appendToSection("PROGRESS.md","## Task Breakdown",r)}updateSprint(e){this.updateSection("PROGRESS.md","## Current Sprint",e)}recordDecision(e,t,s,r="medium"){let o=`| ${new Date().toISOString().split("T")[0]} | ${e} | ${t} | ${s} | ${r} |`;this.appendToSection("HABLAS.md","## Key Decisions",o)}updateArchitecture(e,t){this.updateSection("ARCHITECTURE.md",e,t)}recordADR(e,t,s="accepted"){let r=new Date().toISOString().split("T")[0],a=`| ${((this.readContext("ARCHITECTURE.md")||"").match(/^\|/gm)||[]).length} | ${e} | ${s} | ${r} | ${t} |`;this.appendToSection("ARCHITECTURE.md","## Architecture Decision Records (ADRs)",a)}logDelegation(e){this.sessionDelegations.push(e);let t=`| ${e.time} | ${e.from} | ${e.to} | ${e.task.slice(0,50)} | ${e.model} | ${e.result} | ${e.durationMs}ms |`;this.appendToSection("AGENTS.md","## Delegation Log",t)}logSession(e){let t=`| ${e.sessionId} | ${e.date} | ${Math.round(e.duration/1e3)}s | ${e.agentsUsed.join(", ")} | ${e.tasksCompleted} |`;this.appendToSection("AGENTS.md","## Session History",t)}updateAgentPerformance(e,t,s,r,i){let o=`| @${e} | ${t} | ${Math.round(s*100)}% | ${Math.round(r)}ms | ${i.join(", ")} |`;this.appendToSection("AGENTS.md","## Agent Performance",o)}logAgentComm(e,t,s){let i=`- [${new Date().toISOString()}] **@${e}** \u2192 **@${t}**: ${s.slice(0,200)}`;this.appendToSection("AGENTS.md","## Inter-Agent Communication",i)}addConvention(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] ${e} *(found by ${t})*`;this.appendToSection("MEMORY.md","## Project Conventions",r),this.sessionDiscoveries.push({type:"convention",description:e,source:t,date:s})}addPattern(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] ${e} *(found by ${t})*`;this.appendToSection("MEMORY.md","## Discovered Patterns",r),this.sessionDiscoveries.push({type:"pattern",description:e,source:t,date:s})}addGotcha(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] \u26A0\uFE0F ${e} *(found by ${t})*`;this.appendToSection("MEMORY.md","## Known Gotchas",r),this.sessionDiscoveries.push({type:"gotcha",description:e,source:t,date:s})}addAutoDiscovery(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] \u{1F50D} ${e} *(by ${t})*`;this.appendToSection("MEMORY.md","## Auto-Discoveries",r),this.sessionDiscoveries.push({type:"pattern",description:e,source:t,date:s})}getSummary(e=8e3){let t=["HABLAS.md","PROGRESS.md","ARCHITECTURE.md","MEMORY.md"],s=[],r=0;for(let i of t){let o=this.readContext(i);if(o&&o.trim().length>0){let a=e-r;if(a<=200)break;let l=o.length>a?o.slice(0,a)+`
1030
1030
  ...(truncated)`:o;s.push(`### ${i}
1031
1031
  ${l}`),r+=l.length}}return s.length>0?s.join(`
1032
1032
 
@@ -1044,7 +1044,7 @@ ${d}`),o+=d.length}}}extractSection(e,t){let s=e.split(`
1044
1044
  `),a=o.findIndex(u=>u.trim()===t);if(a===-1){ce.writeFileSync(r,i+`
1045
1045
  `+s+`
1046
1046
  `,"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),ce.writeFileSync(r,o.join(`
1047
- `),"utf-8")}}});function $g(n){let t=n.trim().toLowerCase(),s=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|html|env|vue|svelte|go|rs|sh|toml)/gi,r=t.match(s)||[];return C0.test(t)?"ECOSYSTEM":T0.test(t)?"APPLICATION":R0.test(t)||r.length>=3?"SERVICE":O0.test(t)||r.length===2?"COMPONENT":"FILE"}var C0,T0,R0,O0,Eg=N(()=>{"use strict";C0=/\b(deploy|ci|cd|docker|docker-compose|gvisor|kubernetes|aws|gcp|vercel|heroku|server|cloud)\b/i,T0=/\b(full\s+system|complete\s+project|from\s+scratch|entire\s+application|prd|end-to-end|database.*api.*frontend)\b/i,R0=/\b(service|module|auth|login|session|api|controller|middleware|backend|database|schema)\b/i,O0=/\b(component|widget|screen|page|interface|view|button|sidebar|header|footer|form|ui)\b/i});function Cg(n){let e=n.toLowerCase();return/\b(how|why|what|tell\s+me|explain)\b/i.test(e)&&!/\b(build|fix|add)\b/i.test(e)?"QUESTION":/\b(research|find|search|docs|compare|analyze)\b/i.test(e)?"RESEARCH":/\b(fix|bug|issue|error|solve|debug)\b/i.test(e)?"DEBUGGING":/\b(refactor|cleanup|restructure|rewrite)\b/i.test(e)?"REFACTORING":/\b(design|architect|schema|blueprint|structure)\b/i.test(e)?"ARCHITECTURE":/\b(review|check|audit|verify)\b/i.test(e)?"REVIEW":"IMPLEMENTATION"}function Tg(n){let e=n.trim(),t=e.toLowerCase();if(!e)return 0;let r=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|html|env|vue|svelte|go|rs|sh|toml)/i.test(e)?1:0,o=/\b(read_file|write_file|run_command|edit_file|search_codebase|list_dir|create_dir|delete_file|patch_file|search_and_replace)\b/i.test(e)?1:0,a=e.startsWith("/")?1:0,u=/\b(something|fix\s+it|make\s+better|do\s+stuff|change\s+things|some\s+file|مشكلة|شيء)\b/i.test(t)?1:0,d=.4*r+.3*o+.3*a-.5*u;return Math.max(0,Math.min(1,d))}var Rg=N(()=>{"use strict"});function Pg(n){let e=n.trim();if(e.length<20||Ci(e)||Og.test(e)||e.includes("```")||I0.test(e)||/\/[\w-]+\.[\w]+/.test(e)||e.length<60&&Og.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 Ig(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,Og,I0,Mg=N(()=>{"use strict";cn();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"}]}],Og=/[\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,I0=/\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 Wr,vt,zr,Vr,Lg=N(()=>{"use strict";Wr=O(require("fs")),vt=O(require("fs/promises")),zr=O(require("path")),Vr=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=zr.resolve(this.workingDir,e),a=null;try{Wr.existsSync(o)&&(a=await vt.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?(Wr.existsSync(i.absolutePath)&&await vt.unlink(i.absolutePath),t.push({file:i.filePath,success:!0})):(await vt.mkdir(zr.dirname(i.absolutePath),{recursive:!0}),await vt.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?Wr.existsSync(r.absolutePath)&&await vt.unlink(r.absolutePath):await vt.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(`
1047
+ `),"utf-8")}}});function $g(n){let t=n.trim().toLowerCase(),s=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|html|env|vue|svelte|go|rs|sh|toml)/gi,r=t.match(s)||[];return C0.test(t)?"ECOSYSTEM":T0.test(t)?"APPLICATION":R0.test(t)||r.length>=3?"SERVICE":O0.test(t)||r.length===2?"COMPONENT":"FILE"}var C0,T0,R0,O0,Eg=N(()=>{"use strict";C0=/\b(deploy|ci|cd|docker|docker-compose|gvisor|kubernetes|aws|gcp|vercel|heroku|server|cloud)\b/i,T0=/\b(full\s+system|complete\s+project|from\s+scratch|entire\s+application|prd|end-to-end|database.*api.*frontend)\b/i,R0=/\b(service|module|auth|login|session|api|controller|middleware|backend|database|schema)\b/i,O0=/\b(component|widget|screen|page|interface|view|button|sidebar|header|footer|form|ui)\b/i});function Cg(n){let e=n.toLowerCase();return/\b(how|why|what|tell\s+me|explain)\b/i.test(e)&&!/\b(build|fix|add)\b/i.test(e)?"QUESTION":/\b(research|find|search|docs|compare|analyze)\b/i.test(e)?"RESEARCH":/\b(fix|bug|issue|error|solve|debug)\b/i.test(e)?"DEBUGGING":/\b(refactor|cleanup|restructure|rewrite)\b/i.test(e)?"REFACTORING":/\b(design|architect|schema|blueprint|structure)\b/i.test(e)?"ARCHITECTURE":/\b(review|check|audit|verify)\b/i.test(e)?"REVIEW":"IMPLEMENTATION"}function Tg(n){let e=n.trim(),t=e.toLowerCase();if(!e)return 0;let r=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|html|env|vue|svelte|go|rs|sh|toml)/i.test(e)?1:0,o=/\b(read_file|write_file|run_command|edit_file|search_codebase|list_dir|create_dir|delete_file|patch_file|search_and_replace)\b/i.test(e)?1:0,a=e.startsWith("/")?1:0,u=/\b(something|fix\s+it|make\s+better|do\s+stuff|change\s+things|some\s+file|مشكلة|شيء)\b/i.test(t)?1:0,d=.4*r+.3*o+.3*a-.5*u;return Math.max(0,Math.min(1,d))}var Rg=N(()=>{"use strict"});function Pg(n){let e=n.trim();if(e.length<20||Vt(e)||Og.test(e)||e.includes("```")||I0.test(e)||/\/[\w-]+\.[\w]+/.test(e)||e.length<60&&Og.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 Ig(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,Og,I0,Mg=N(()=>{"use strict";un();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"}]}],Og=/[\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,I0=/\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 Yr,vt,Qr,Jr,Lg=N(()=>{"use strict";Yr=O(require("fs")),vt=O(require("fs/promises")),Qr=O(require("path")),Jr=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{Yr.existsSync(o)&&(a=await vt.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?(Yr.existsSync(i.absolutePath)&&await vt.unlink(i.absolutePath),t.push({file:i.filePath,success:!0})):(await vt.mkdir(Qr.dirname(i.absolutePath),{recursive:!0}),await vt.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?Yr.existsSync(r.absolutePath)&&await vt.unlink(r.absolutePath):await vt.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(`
1048
1048
  `)}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=Te.resolve(e,r);ft.existsSync(i)&&t.push(r)}return[...new Set(t)]}function L0(n,e,t){let s=[],r=Te.extname(e),i=Te.dirname(Te.resolve(t,e));if([".ts",".tsx",".js",".jsx",".mjs",".cjs"].includes(r)){let o;for(Ng.lastIndex=0;(o=Ng.exec(n))!==null;){let a=o[1]||o[2];if(!a||!a.startsWith(".")&&!a.startsWith("/"))continue;let l=D0(a,i);l&&s.push(Te.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=Te.resolve(i,l);ft.existsSync(u)&&s.push(Te.relative(t,u))}}return[...new Set(s)]}function D0(n,e){let t=[".ts",".tsx",".js",".jsx",".mjs",".cjs"],s=Te.resolve(e,n);if(ft.existsSync(s)&&ft.statSync(s).isFile())return s;for(let r of t){let i=s+r;if(ft.existsSync(i))return i}for(let r of t){let i=Te.join(s,`index${r}`);if(ft.existsSync(i))return i}return null}function jg(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=Te.resolve(e,d),h=ft.readFileSync(f,"utf-8"),m=h.split(`
1049
1049
  `).length,p=Math.ceil(h.length/4);if(p>4e3){let g=h.split(`
1050
1050
  `).slice(0,200).join(`
@@ -1054,24 +1054,24 @@ ${d}`),o+=d.length}}}extractSection(e,t){let s=e.split(`
1054
1054
  `).slice(0,100).join(`
1055
1055
  `)+`
1056
1056
  ...(truncated)`,b=Math.ceil(v.length/4);u+b<=r&&(a.push({path:x,content:v,source:"imported",lineCount:100}),u+=b)}else u+_<=r&&(a.push({path:x,content:$,source:"imported",lineCount:y}),u+=_)}catch{}}}}}catch{}}}return{files:a,totalTokensEstimate:u,mentionedPaths:o}}function Hg(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(`
1057
- `)}var ft,Te,Dg,Ng,Fg,Bg=N(()=>{"use strict";ft=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,Ng=/(?:import\s+.*?\s+from\s+['"]([^'"]+)['"]|require\s*\(\s*['"]([^'"]+)['"]\s*\))/g,Fg=/(?:from\s+(\S+)\s+import|import\s+(\S+))/g});var qg={};Ne(qg,{runSetupWizard:()=>Wl});function be(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 Wl(n){let e=Ug.createInterface({input:process.stdin,output:process.stdout});switch(console.log(),console.log(`${qt}${Ke} \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${L}`),console.log(`${qt}${Ke} hablas \u2014 Setup Wizard${L}`),console.log(`${K} Configure your AI provider and model${L}`),console.log(`${qt}${Ke} \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${L}`),console.log(),console.log(`${qt} Choose your setup:${L}`),console.log(),console.log(` ${N0}${qt}1${L}. ${qt}Hablas Integrated Engine${L} ${wt}(instant \u2014 no setup needed)${L}`),console.log(` ${K}Pre-configured cloud AI, ready to use immediately${L}`),console.log(),console.log(` ${Ke}${qt}2${L}. ${qt}Custom Provider${L} ${K}(bring your own API key)${L}`),console.log(` ${K}Choose from Ollama, OpenAI, Groq, OpenRouter, and more${L}`),console.log(),(await be(e,` ${K}Your choice (1-2):${L} `)).trim()){case"1":{n.provider=Kt.provider,n.apiUrl=Kt.apiUrl,n.apiKey=F0(),n.model=Kt.model,gt(n),nt({name:Kt.name,apiUrl:Kt.apiUrl,apiKey:n.apiKey,models:["stepfun-ai/step-3.7-flash","nvidia/llama-3.3-70b-instruct","deepseek-ai/deepseek-r1"],defaultModel:Kt.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Hablas Integrated Engine activated!${L}`),console.log(`${K} Model: ${Kt.model}${L}`),console.log(`${K} API: ${Kt.apiUrl}${L}`),console.log(`${K} No API key needed \u2014 everything is pre-configured.${L}`);break}case"2":{switch(console.log(),console.log(`${K} Select your provider:${L}`),console.log(` ${Ke}a${L}. Ollama (local, free, private)`),console.log(` ${Ke}b${L}. OpenAI API`),console.log(` ${Ke}c${L}. Groq (fast, free tier)`),console.log(` ${Ke}d${L}. OpenRouter (many models)`),console.log(` ${Ke}e${L}. Together AI`),console.log(` ${Ke}f${L}. DeepSeek`),console.log(` ${Ke}g${L}. Custom OpenAI-compatible API`),console.log(` ${Ke}h${L}. NVIDIA NIM (powerful cloud models)`),console.log(),(await be(e,` ${K}Your choice (a-h):${L} `)).trim().toLowerCase()){case"a":{n.provider="ollama";let r=await be(e,` ${K}Ollama host [http://localhost:11434]:${L} `);r.trim()&&(n.ollamaHost=r.trim());let i=await be(e,` ${K}Model [qwen2.5-coder:7b]:${L} `);i.trim()&&(n.model=i.trim()),gt(n),console.log(),console.log(`${wt} \u2713 Configured for Ollama${L}`),console.log(`${K} Model: ${n.model}${L}`),console.log(`${K} Host: ${n.ollamaHost}${L}`),console.log(`${K} Make sure Ollama is running: ollama serve${L}`);break}case"b":{let r=await be(e,` ${K}OpenAI API Key (sk-...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await be(e,` ${K}Model [gpt-4o]:${L} `);n.provider="custom",n.apiUrl="https://api.openai.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"gpt-4o",gt(n),nt({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(`${wt} \u2713 Configured for OpenAI${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"c":{let r=await be(e,` ${K}Groq API Key (gsk_...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await be(e,` ${K}Model [llama-3.3-70b-versatile]:${L} `);n.provider="custom",n.apiUrl="https://api.groq.com/openai/v1",n.apiKey=r.trim(),n.model=i.trim()||"llama-3.3-70b-versatile",gt(n),nt({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(`${wt} \u2713 Configured for Groq${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"d":{let r=await be(e,` ${K}OpenRouter API Key (sk-or-...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await be(e,` ${K}Model [anthropic/claude-3.5-sonnet]:${L} `);n.provider="custom",n.apiUrl="https://openrouter.ai/api/v1",n.apiKey=r.trim(),n.model=i.trim()||"anthropic/claude-3.5-sonnet",gt(n),nt({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(`${wt} \u2713 Configured for OpenRouter${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"e":{let r=await be(e,` ${K}Together API Key:${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await be(e,` ${K}Model [meta-llama/Llama-3.3-70B-Instruct-Turbo]:${L} `);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",gt(n),nt({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(`${wt} \u2713 Configured for Together AI${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"f":{let r=await be(e,` ${K}DeepSeek API Key:${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await be(e,` ${K}Model [deepseek-chat]:${L} `);n.provider="custom",n.apiUrl="https://api.deepseek.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"deepseek-chat",gt(n),nt({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(`${wt} \u2713 Configured for DeepSeek${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"g":{let r=await be(e,` ${K}Provider name:${L} `);if(!r.trim()){console.log(`${xt} \u26A0 Cancelled${L}`);break}let i=await be(e,` ${K}API base URL:${L} `);if(!i.trim()){console.log(`${xt} \u26A0 URL is required \u2014 cancelled${L}`);break}let o=await be(e,` ${K}API Key (leave empty if none):${L} `),a=await be(e,` ${K}Default model ID:${L} `);n.provider="custom",n.apiUrl=i.trim(),n.apiKey=o.trim(),n.model=a.trim()||"default",gt(n),nt({name:r.trim(),apiUrl:i.trim(),apiKey:o.trim(),models:[n.model],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for ${r.trim()}${L}`),console.log(`${K} URL: ${i.trim()}${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"h":{let r=await be(e,` ${K}NVIDIA API Key (nvapi-...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`),console.log(`${K} Get your key at: https://build.nvidia.com/${L}`);break}let{NVIDIA_PROVIDER:i}=await Promise.resolve().then(()=>(Ln(),mc));console.log(),console.log(`${K} Available NVIDIA models:${L}`),i.models.forEach((u,d)=>{console.log(` ${Ke}${d+1}${L}. ${u}`)}),console.log();let o=await be(e,` ${K}Model number [1]:${L} `),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,gt(n),nt({name:"NVIDIA",apiUrl:i.apiUrl,apiKey:r.trim(),models:i.models,defaultModel:l,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for NVIDIA NIM${L}`),console.log(`${K} Model: ${l}${L}`),console.log(`${K} API: ${i.apiUrl}${L}`);break}default:console.log(`${xt} \u26A0 Invalid choice${L}`)}break}default:console.log(`${xt} \u26A0 Invalid choice \u2014 please select 1 or 2${L}`)}console.log(),console.log(`${K} Run 'hablas' to start chatting!${L}`),console.log(),e.close()}var Ug,Ke,wt,xt,K,qt,L,N0,Kt,Vl=N(()=>{"use strict";Ug=O(require("readline"));dr();gi();Ke="\x1B[36m",wt="\x1B[32m",xt="\x1B[33m",K="\x1B[2m",qt="\x1B[1m",L="\x1B[0m",N0="\x1B[35m";Kt={provider:"nvidia",apiUrl:"https://integrate.api.nvidia.com/v1",model:"stepfun-ai/step-3.7-flash",name:"Hablas Integrated Engine"}});var Ft={};Ne(Ft,{activeCollabManager:()=>Re,runSingleCommand:()=>G0,startRepl:()=>Jl});function U0(){return!pt.existsSync(zl)}function Kg(){return pt.existsSync(j0)}function q0(){let n=Mt.dirname(zl);pt.existsSync(n)||pt.mkdirSync(n,{recursive:!0}),pt.writeFileSync(zl,new Date().toISOString(),"utf-8")}async function K0(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 Vg(n,e,t,s,r){let{interactive:i,autoMode:o,input:a,logger:l,abortSignal:u,onToolCall:d,skipTools:f}=r,h=r.reactEngine??gs(),m=r.errorRecovery??ys(),p=n.getMessages().filter(b=>b.role==="user").pop()?.content||"Solo Execution",x={taskTitle:p.length>45?p.slice(0,45)+"...":p,currentPhase:"Cognitive Reasoning & Planning",activeAgent:"Hablas",activeAgentTitle:"Team Leader",currentActivity:"Analyzing workspace & preparing reasoning path",roster:{Hablas:"active",Emma:"pending",Bob:"pending",Alex:"pending",David:"pending"}},A=new Bn;A.render(x);let $=new ze("Hablas is thinking");$.start();let _=b=>{$&&($.stop(b),$=null)},y=dg({autoMode:o,interactive:i,confirm:a?b=>a.confirm(b):void 0,confirmDangerous:a?b=>a.confirmDangerous(b):void 0});await Dr({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 b=>{_(),console.log(Un("Hablas","Team Leader")),await K0(qn(b))},onToolStart:(b,w)=>{_(),x.currentActivity=`Executing: ${b}`,A.render(x),console.log(gu(b,w)),$=new ze("Continuing"),$.start()},onToolEnd:(b,w,S,T)=>{_(),console.log(yu(w,S,T))},onNotice:(b,w)=>{_(),console.log(w==="retry"?c.muted(` \u21BB ${b}`):B(b))},onError:b=>{_(),b.includes("ECONNREFUSED")?console.log(He("Connection lost","Check your provider connection or run /provider test")):/timeout/i.test(b)?console.log(He("Request timed out (120s)","The API is slow. Try again or use a faster model.")):b.includes("429")?console.log(He("Rate limited by API","Wait a moment and try again, or switch providers.")):b.includes("model")?console.log(He("Model error","Check model availability: /models")):console.log(He(`Error: ${b}`,"Try again or check /status"))},onToolCall:()=>{d&&d()}},safetyPolicy:y,abortSignal:u,skipTools:f,maxIterations:H0}),_()}async function Jl(n,e){Kp();let t=n.workingDirectory==="."?process.cwd():n.workingDirectory,s=ee=>pt.existsSync(Mt.join(ee,".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.")}
1057
+ `)}var ft,Te,Dg,Ng,Fg,Bg=N(()=>{"use strict";ft=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,Ng=/(?:import\s+.*?\s+from\s+['"]([^'"]+)['"]|require\s*\(\s*['"]([^'"]+)['"]\s*\))/g,Fg=/(?:from\s+(\S+)\s+import|import\s+(\S+))/g});var qg={};Ne(qg,{runSetupWizard:()=>Vl});function be(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=Ug.createInterface({input:process.stdin,output:process.stdout});switch(console.log(),console.log(`${qt}${Ke} \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${L}`),console.log(`${qt}${Ke} hablas \u2014 Setup Wizard${L}`),console.log(`${K} Configure your AI provider and model${L}`),console.log(`${qt}${Ke} \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${L}`),console.log(),console.log(`${qt} Choose your setup:${L}`),console.log(),console.log(` ${N0}${qt}1${L}. ${qt}Hablas Integrated Engine${L} ${wt}(instant \u2014 no setup needed)${L}`),console.log(` ${K}Pre-configured cloud AI, ready to use immediately${L}`),console.log(),console.log(` ${Ke}${qt}2${L}. ${qt}Custom Provider${L} ${K}(bring your own API key)${L}`),console.log(` ${K}Choose from Ollama, OpenAI, Groq, OpenRouter, and more${L}`),console.log(),(await be(e,` ${K}Your choice (1-2):${L} `)).trim()){case"1":{n.provider=Kt.provider,n.apiUrl=Kt.apiUrl,n.apiKey=F0(),n.model=Kt.model,gt(n),nt({name:Kt.name,apiUrl:Kt.apiUrl,apiKey:n.apiKey,models:["stepfun-ai/step-3.7-flash","nvidia/llama-3.3-70b-instruct","deepseek-ai/deepseek-r1"],defaultModel:Kt.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Hablas Integrated Engine activated!${L}`),console.log(`${K} Model: ${Kt.model}${L}`),console.log(`${K} API: ${Kt.apiUrl}${L}`),console.log(`${K} No API key needed \u2014 everything is pre-configured.${L}`);break}case"2":{switch(console.log(),console.log(`${K} Select your provider:${L}`),console.log(` ${Ke}a${L}. Ollama (local, free, private)`),console.log(` ${Ke}b${L}. OpenAI API`),console.log(` ${Ke}c${L}. Groq (fast, free tier)`),console.log(` ${Ke}d${L}. OpenRouter (many models)`),console.log(` ${Ke}e${L}. Together AI`),console.log(` ${Ke}f${L}. DeepSeek`),console.log(` ${Ke}g${L}. Custom OpenAI-compatible API`),console.log(` ${Ke}h${L}. NVIDIA NIM (powerful cloud models)`),console.log(),(await be(e,` ${K}Your choice (a-h):${L} `)).trim().toLowerCase()){case"a":{n.provider="ollama";let r=await be(e,` ${K}Ollama host [http://localhost:11434]:${L} `);r.trim()&&(n.ollamaHost=r.trim());let i=await be(e,` ${K}Model [qwen2.5-coder:7b]:${L} `);i.trim()&&(n.model=i.trim()),gt(n),console.log(),console.log(`${wt} \u2713 Configured for Ollama${L}`),console.log(`${K} Model: ${n.model}${L}`),console.log(`${K} Host: ${n.ollamaHost}${L}`),console.log(`${K} Make sure Ollama is running: ollama serve${L}`);break}case"b":{let r=await be(e,` ${K}OpenAI API Key (sk-...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await be(e,` ${K}Model [gpt-4o]:${L} `);n.provider="custom",n.apiUrl="https://api.openai.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"gpt-4o",gt(n),nt({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(`${wt} \u2713 Configured for OpenAI${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"c":{let r=await be(e,` ${K}Groq API Key (gsk_...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await be(e,` ${K}Model [llama-3.3-70b-versatile]:${L} `);n.provider="custom",n.apiUrl="https://api.groq.com/openai/v1",n.apiKey=r.trim(),n.model=i.trim()||"llama-3.3-70b-versatile",gt(n),nt({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(`${wt} \u2713 Configured for Groq${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"d":{let r=await be(e,` ${K}OpenRouter API Key (sk-or-...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await be(e,` ${K}Model [anthropic/claude-3.5-sonnet]:${L} `);n.provider="custom",n.apiUrl="https://openrouter.ai/api/v1",n.apiKey=r.trim(),n.model=i.trim()||"anthropic/claude-3.5-sonnet",gt(n),nt({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(`${wt} \u2713 Configured for OpenRouter${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"e":{let r=await be(e,` ${K}Together API Key:${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await be(e,` ${K}Model [meta-llama/Llama-3.3-70B-Instruct-Turbo]:${L} `);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",gt(n),nt({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(`${wt} \u2713 Configured for Together AI${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"f":{let r=await be(e,` ${K}DeepSeek API Key:${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await be(e,` ${K}Model [deepseek-chat]:${L} `);n.provider="custom",n.apiUrl="https://api.deepseek.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"deepseek-chat",gt(n),nt({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(`${wt} \u2713 Configured for DeepSeek${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"g":{let r=await be(e,` ${K}Provider name:${L} `);if(!r.trim()){console.log(`${xt} \u26A0 Cancelled${L}`);break}let i=await be(e,` ${K}API base URL:${L} `);if(!i.trim()){console.log(`${xt} \u26A0 URL is required \u2014 cancelled${L}`);break}let o=await be(e,` ${K}API Key (leave empty if none):${L} `),a=await be(e,` ${K}Default model ID:${L} `);n.provider="custom",n.apiUrl=i.trim(),n.apiKey=o.trim(),n.model=a.trim()||"default",gt(n),nt({name:r.trim(),apiUrl:i.trim(),apiKey:o.trim(),models:[n.model],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for ${r.trim()}${L}`),console.log(`${K} URL: ${i.trim()}${L}`),console.log(`${K} Model: ${n.model}${L}`);break}case"h":{let r=await be(e,` ${K}NVIDIA API Key (nvapi-...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`),console.log(`${K} Get your key at: https://build.nvidia.com/${L}`);break}let{NVIDIA_PROVIDER:i}=await Promise.resolve().then(()=>(Dn(),gc));console.log(),console.log(`${K} Available NVIDIA models:${L}`),i.models.forEach((u,d)=>{console.log(` ${Ke}${d+1}${L}. ${u}`)}),console.log();let o=await be(e,` ${K}Model number [1]:${L} `),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,gt(n),nt({name:"NVIDIA",apiUrl:i.apiUrl,apiKey:r.trim(),models:i.models,defaultModel:l,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for NVIDIA NIM${L}`),console.log(`${K} Model: ${l}${L}`),console.log(`${K} API: ${i.apiUrl}${L}`);break}default:console.log(`${xt} \u26A0 Invalid choice${L}`)}break}default:console.log(`${xt} \u26A0 Invalid choice \u2014 please select 1 or 2${L}`)}console.log(),console.log(`${K} Run 'hablas' to start chatting!${L}`),console.log(),e.close()}var Ug,Ke,wt,xt,K,qt,L,N0,Kt,zl=N(()=>{"use strict";Ug=O(require("readline"));hr();vi();Ke="\x1B[36m",wt="\x1B[32m",xt="\x1B[33m",K="\x1B[2m",qt="\x1B[1m",L="\x1B[0m",N0="\x1B[35m";Kt={provider:"nvidia",apiUrl:"https://integrate.api.nvidia.com/v1",model:"stepfun-ai/step-3.7-flash",name:"Hablas Integrated Engine"}});var Ft={};Ne(Ft,{activeCollabManager:()=>Re,runSingleCommand:()=>G0,startRepl:()=>Ql});function U0(){return!pt.existsSync(Yl)}function Kg(){return pt.existsSync(j0)}function q0(){let n=Mt.dirname(Yl);pt.existsSync(n)||pt.mkdirSync(n,{recursive:!0}),pt.writeFileSync(Yl,new Date().toISOString(),"utf-8")}async function K0(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 Vg(n,e,t,s,r){let{interactive:i,autoMode:o,input:a,logger:l,abortSignal:u,onToolCall:d,skipTools:f}=r,h=r.reactEngine??ys(),m=r.errorRecovery??bs(),p=n.getMessages().filter(b=>b.role==="user").pop()?.content||"Solo Execution",x={taskTitle:p.length>45?p.slice(0,45)+"...":p,currentPhase:"Cognitive Reasoning & Planning",activeAgent:"Hablas",activeAgentTitle:"Team Leader",currentActivity:"Analyzing workspace & preparing reasoning path",roster:{Hablas:"active",Emma:"pending",Bob:"pending",Alex:"pending",David:"pending"}},A=new Un;A.render(x);let $=new ze("Hablas is thinking");$.start();let _=b=>{$&&($.stop(b),$=null)},y=dg({autoMode:o,interactive:i,confirm:a?b=>a.confirm(b):void 0,confirmDangerous:a?b=>a.confirmDangerous(b):void 0});await jr({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 b=>{_(),console.log(qn("Hablas","Team Leader")),await K0(Kn(b))},onToolStart:(b,w)=>{_(),x.currentActivity=`Executing: ${b}`,A.render(x),console.log(gu(b,w)),$=new ze("Continuing"),$.start()},onToolEnd:(b,w,S,T)=>{_(),console.log(yu(w,S,T))},onNotice:(b,w)=>{_(),console.log(w==="retry"?c.muted(` \u21BB ${b}`):B(b))},onError:b=>{_(),b.includes("ECONNREFUSED")?console.log(He("Connection lost","Check your provider connection or run /provider test")):/timeout/i.test(b)?console.log(He("Request timed out (120s)","The API is slow. Try again or use a faster model.")):b.includes("429")?console.log(He("Rate limited by API","Wait a moment and try again, or switch providers.")):b.includes("model")?console.log(He("Model error","Check model availability: /models")):console.log(He(`Error: ${b}`,"Try again or check /status"))},onToolCall:()=>{d&&d()}},safetyPolicy:y,abortSignal:u,skipTools:f,maxIterations:H0}),_()}async function Ql(n,e){Kp();let t=n.workingDirectory==="."?process.cwd():n.workingDirectory,s=ee=>pt.existsSync(Mt.join(ee,".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.")}
1058
1058
  `);else if(n.team?.enabled&&!s(t)){console.log(`
1059
1059
  ${c.accent("\u2726")} ${c.strong("Team Mode Strategy Required")}`),console.log(` ${c.muted("Collaboration requires a stable Git repository root.")}
1060
- `);let te=await new cs(t).prompt(` ${c.primary("\u203A")} Specify repo path OR type 'init' to start here: `);if(te.trim().toLowerCase()==="init")try{(0,Wg.execSync)("git init",{cwd:t,stdio:"ignore"}),console.log(` ${c.success("\u2713")} Git repository initialized in ${c.highlight(t)}
1060
+ `);let te=await new us(t).prompt(` ${c.primary("\u203A")} Specify repo path OR type 'init' to start here: `);if(te.trim().toLowerCase()==="init")try{(0,Wg.execSync)("git init",{cwd:t,stdio:"ignore"}),console.log(` ${c.success("\u2713")} Git repository initialized in ${c.highlight(t)}
1061
1061
  `)}catch{console.log($e("Failed to initialize Git. Please run git init manually.")),process.exit(1)}else{let _e=Mt.resolve(t,te.trim());pt.existsSync(_e)&&s(_e)?(t=_e,n.workingDirectory=t,console.log(` ${c.success("\u2713")} Context switched to repository: ${c.highlight(t)}
1062
- `)):(console.log($e(`Path "${_e}" is not a valid Git repository.`)),process.exit(1))}}let r=Fe(n),i=new os(t,n),o=new Zt(n),a=new cs(t),l=fr(),u=new pr,d=new ds(t),f=new Pn(t),h=new Kr,m=new Nr(n);m.setToolRegistry(i);let p=new Fr,g=new qr(p).attach(),x=new Hr(n,{tokenBudget:500,maxChars:140});if(m.setChannel(p),n.team?.enabled){let ee=n.team.user||"developer",te=n.team.key||"default-key";Re=new rs(t,n,ee,te),await Re.init()&&console.log(` ${c.success("\u2713")} ${c.muted("[Team]")} Scoped cooperative sync initialized successfully.
1063
- `)}let A=new Vr(t),$=new Bn;f.init();let _=null;n.context?.hablasCoreEnabled&&(_=new Gr(t),_.init());let y=await gn(t,n),v=l.getActive(),b=v?v.systemPrompt:Gn,w=yn(b,y,d,f),S=gs({thinkingEnabled:!0,selfEvalEnabled:!0,showThinking:!1,maxSteps:150,minConfidence:.6}),T=ys(3),M=new en(w,n.historySize),k=Fn();k=Ni(k),dn(k);let F=0,H=0,V=Date.now(),C=n.autoMode||!1,E=0,Y=new AbortController;process.on("SIGINT",()=>{let ee=Date.now();if(ee-E<B0){console.log(Xi({turns:F,duration:Date.now()-V,toolCalls:H}));let te=Re?Re.shutdown():Promise.resolve();Promise.resolve(te).finally(()=>process.exit(0)),setTimeout(()=>process.exit(0),2e3);return}E=ee,Y.abort(),Y=new AbortController,process.stdout.write(`
1064
- `),console.log(B("Operation cancelled \u2014 press Ctrl+C again to exit"))});let D=$s(n);if(console.log(uu(n.model,t)),n.provider==="custom"&&console.log(he(`Provider: ${D}`)),C&&console.log(he("Auto mode enabled \u2014 tool confirmations skipped (plan approval still required)")),(U0()||!Kg())&&(console.log(pu()),console.log(""),console.log(he("First run detected \u2014 launching setup wizard...")),console.log(""),a.close(),await Wl(n),q0(),r=Fe(n),a.reinitialize()),Kg()){let ee=new ze("Connecting");ee.start();let te=await r.checkConnection();if(ee.stop(te?"ready":void 0),te){let _e=await r.listModels();console.log(J(`Connected \xB7 ${_e.length} models available`)),n.provider==="ollama"&&!_e.includes(n.model)&&console.log(B(`Model "${n.model}" not found. Pull: ollama pull ${n.model}`))}else n.provider==="custom"?console.log(He(`Cannot connect to ${n.apiUrl}`,"Check your --api-url and --api-key, or run /provider test")):n.provider==="nvidia"?console.log(He("Cannot connect to NVIDIA NIM","Check your API key or run: hablas --setup")):console.log(He("Cannot connect to Ollama","Start it with: ollama serve \u2014 or switch provider: /provider"))}console.log(du()),console.log();let X=!0;for(;X;)try{let te=(await a.prompt(` ${c.primary("\u203A")} `)).trim();if(!te)continue;if(te.startsWith("/")){if(await qu(te,n,r,i,o,M,t,a,F,l,u,d,ue=>{r=ue},f,h,A,m)==="quit"){X=!1;break}continue}e.info({input:te},"Processing user input");let _e=Pc(te),Q=zg(_e,t);if(F++,console.log(bu(F)),k=Fi(k),dn(k),!C){let q=Pg(Q);if(q){console.log(Su(q));let ue=await a.prompt(` ${c.muted("\u203A")} `),Ge=Ig(ue,q);Q=`${Q}
1062
+ `)):(console.log($e(`Path "${_e}" is not a valid Git repository.`)),process.exit(1))}}let r=Fe(n),i=new as(t,n),o=new en(n),a=new us(t),l=mr(),u=new gr,d=new fs(t),f=new In(t),h=new Vr,m=new Hr(n);m.setToolRegistry(i);let p=new Br,g=new Wr(p).attach(),x=new qr(n,{tokenBudget:500,maxChars:140});if(m.setChannel(p),n.team?.enabled){let ee=n.team.user||"developer",te=n.team.key||"default-key";Re=new is(t,n,ee,te),await Re.init()&&console.log(` ${c.success("\u2713")} ${c.muted("[Team]")} Scoped cooperative sync initialized successfully.
1063
+ `)}let A=new Jr(t),$=new Un;f.init();let _=null;n.context?.hablasCoreEnabled&&(_=new zr(t),_.init());let y=await yn(t,n),v=l.getActive(),b=v?v.systemPrompt:Wn,w=bn(b,y,d,f),S=ys({thinkingEnabled:!0,selfEvalEnabled:!0,showThinking:!1,maxSteps:150,minConfidence:.6}),T=bs(3),M=new tn(w,n.historySize),k=jn();k=Fi(k),fn(k);let F=0,H=0,V=Date.now(),C=n.autoMode||!1,E=0,Y=new AbortController;process.on("SIGINT",()=>{let ee=Date.now();if(ee-E<B0){console.log(Zi({turns:F,duration:Date.now()-V,toolCalls:H}));let te=Re?Re.shutdown():Promise.resolve();Promise.resolve(te).finally(()=>process.exit(0)),setTimeout(()=>process.exit(0),2e3);return}E=ee,Y.abort(),Y=new AbortController,process.stdout.write(`
1064
+ `),console.log(B("Operation cancelled \u2014 press Ctrl+C again to exit"))});let D=Es(n);if(console.log(uu(n.model,t)),n.provider==="custom"&&console.log(he(`Provider: ${D}`)),C&&console.log(he("Auto mode enabled \u2014 tool confirmations skipped (plan approval still required)")),(U0()||!Kg())&&(console.log(pu()),console.log(""),console.log(he("First run detected \u2014 launching setup wizard...")),console.log(""),a.close(),await Vl(n),q0(),r=Fe(n),a.reinitialize()),Kg()){let ee=new ze("Connecting");ee.start();let te=await r.checkConnection();if(ee.stop(te?"ready":void 0),te){let _e=await r.listModels();console.log(J(`Connected \xB7 ${_e.length} models available`)),n.provider==="ollama"&&!_e.includes(n.model)&&console.log(B(`Model "${n.model}" not found. Pull: ollama pull ${n.model}`))}else n.provider==="custom"?console.log(He(`Cannot connect to ${n.apiUrl}`,"Check your --api-url and --api-key, or run /provider test")):n.provider==="nvidia"?console.log(He("Cannot connect to NVIDIA NIM","Check your API key or run: hablas --setup")):console.log(He("Cannot connect to Ollama","Start it with: ollama serve \u2014 or switch provider: /provider"))}console.log(du()),console.log();let X=!0;for(;X;)try{let te=(await a.prompt(` ${c.primary("\u203A")} `)).trim();if(!te)continue;if(te.startsWith("/")){if(await qu(te,n,r,i,o,M,t,a,F,l,u,d,ue=>{r=ue},f,h,A,m)==="quit"){X=!1;break}continue}e.info({input:te},"Processing user input");let _e=Ic(te),Q=zg(_e,t);if(F++,console.log(bu(F)),k=ji(k),fn(k),!C){let q=Pg(Q);if(q){console.log(Su(q));let ue=await a.prompt(` ${c.muted("\u203A")} `),Ge=Ig(ue,q);Q=`${Q}
1065
1065
  [Clarification: ${Ge.join(", ")}]`}}let Ae=jg(Q,t,{maxFiles:8,maxTokens:6e3});if(Ae.files.length>0){let q=Hg(Ae);M.addUserMessage(`[Auto-loaded ${Ae.files.length} file(s): ${Ae.mentionedPaths.join(", ")}]
1066
1066
  ${q}`,{priority:"low",tags:["auto-inject"]})}if(n.team?.enabled&&Re){let q=n.team?.user||Re.getLocalState().my_username,ue=Ae.mentionedPaths||[];if(ue.length>0){let Ge=await Re.fetchLocks(),I=ue.map(Z=>Ge.find(P=>P.file_path===Z&&P.locked_by!==q)).filter(Z=>!!Z);if(I.length>0){let Z=I[0];console.log(`
1067
1067
  ${c.architect("\u25C6")} ${c.strong("@Consul")} [Coordinator] detected an active lock held by a teammate.`),console.log(`
1068
1068
  ${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(Z.file_path.padEnd(44))} held by ${c.strong(`@${(Z.locked_by||"").padEnd(12)}`)} ${c.error("\u2551")}`),console.log(` ${c.error("\u2551")} Context: ${c.muted((Z.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 P of I)await Re.sendMessage(P.locked_by,`@${q} needs to edit ${P.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.")}
1069
1069
  `);continue}for(let Z of ue)if(!await Re.acquireLock(Z,Q.slice(0,100))){console.log(`
1070
1070
  ${c.warning("\u26A0")} ${c.strong("@Consul")}: a teammate locked ${c.highlight(Z)} first. Halting to avoid a conflict.
1071
- `);continue}}Re.setActivity(Q.slice(0,80))}if(n.agents.enabled&&n.agents.orchestration==="auto"){let q=Cg(Q),ue=Tg(Q),Ge="SOLO",I="FILE";ue<.7&&!isSimpleInteraction(Q)?Ge="NORMALIZER":isSimpleInteraction(Q)||q==="QUESTION"?Ge="SOLO":(I=$g(Q),Ge=I==="FILE"||I==="COMPONENT"?"SOLO":"TEAM");let Z={bob:"architect",alex:"coder",david:"researcher",hablas:"planner",emma:"product-manager"};if(Ge==="SOLO"){let G=Ti(Q).find(ne=>ne!=="hablas")||"alex";q!=="QUESTION"&&!isSimpleInteraction(Q)&&(k=Hi(k,G),dn(k)),M.addUserMessage(Q)}else{let P=Ti(Q),G=Bc(Q,P),ne={taskTitle:Q.length>40?Q.slice(0,37)+"...":Q,currentPhase:Ge==="NORMALIZER"?"Requirements Normalization":"Strategic Planning",activeAgent:"Hablas",activeAgentTitle:"Team Leader",currentActivity:Ge==="NORMALIZER"?"Refining vague user intent":"Orchestrating specialized team",roster:{Hablas:"active",Emma:P.includes("emma")?"pending":"done",Bob:P.includes("bob")?"pending":"done",Alex:P.includes("alex")?"pending":"done",David:P.includes("david")?"pending":"done"}};console.log(`
1072
- `+Zi(ne));let pe=i.getOllamaTools(),ie=new Br(p,m,x,n),{finalSynthesis:Oe,synthesisOk:We}=await ie.run(Q,G,pe,{abortSignal:Y?.signal,peerReview:I==="SERVICE"||I==="APPLICATION"});console.log(Un("Hablas","Team Leader")),console.log(qn(Oe)),M.addAssistantMessage(We?Oe:`[Team Execution Summary]
1071
+ `);continue}}Re.setActivity(Q.slice(0,80))}if(n.agents.enabled&&n.agents.orchestration==="auto"){let q=Cg(Q),ue=Tg(Q),Ge="SOLO",I="FILE";ue<.7&&!Vt(Q)?Ge="NORMALIZER":Vt(Q)||q==="QUESTION"?Ge="SOLO":(I=$g(Q),Ge=I==="FILE"||I==="COMPONENT"?"SOLO":"TEAM");let Z={bob:"architect",alex:"coder",david:"researcher",hablas:"planner",emma:"product-manager"};if(Ge==="SOLO"){let G=Oi(Q).find(ne=>ne!=="hablas")||"alex";q!=="QUESTION"&&!Vt(Q)&&(k=Bi(k,G),fn(k)),M.addUserMessage(Q)}else{let P=Oi(Q),G=Uc(Q,P),ne={taskTitle:Q.length>40?Q.slice(0,37)+"...":Q,currentPhase:Ge==="NORMALIZER"?"Requirements Normalization":"Strategic Planning",activeAgent:"Hablas",activeAgentTitle:"Team Leader",currentActivity:Ge==="NORMALIZER"?"Refining vague user intent":"Orchestrating specialized team",roster:{Hablas:"active",Emma:P.includes("emma")?"pending":"done",Bob:P.includes("bob")?"pending":"done",Alex:P.includes("alex")?"pending":"done",David:P.includes("david")?"pending":"done"}};console.log(`
1072
+ `+eo(ne));let pe=i.getOllamaTools(),ie=new Kr(p,m,x,n),{finalSynthesis:Oe,synthesisOk:We}=await ie.run(Q,G,pe,{abortSignal:Y?.signal,peerReview:I==="SERVICE"||I==="APPLICATION"});console.log(qn("Hablas","Team Leader")),console.log(Kn(Oe)),M.addAssistantMessage(We?Oe:`[Team Execution Summary]
1073
1073
 
1074
- ${Oe}`),await Gg(n,t);continue}}else M.addUserMessage(Q);Y=new AbortController,S.startTurn(),T.resetTurn(),await Vg(M,r,i,o,{interactive:!0,autoMode:C,input:a,logger:e,config:n,abortSignal:Y.signal,reactEngine:S,errorRecovery:T,skipTools:!1,onToolCall:()=>{H++,k=ji(k,"tool_call"),dn(k)}}),await Gg(n,t)}catch(ee){if(ee.code==="ERR_USE_AFTER_CLOSE")break;if(ee.name==="AbortError")continue;console.log($e(ee.message)),e.error(ee,"REPL error")}a.close(),Re&&await Re.shutdown(),console.log(Xi({turns:F,duration:Date.now()-V,toolCalls:H}))}async function G0(n,e,t){let s=e.workingDirectory==="."?process.cwd():e.workingDirectory,r=Fe(e),i=new os(s,e),o=new Zt(e),a=new ds(s),l=await gn(s,e),u=yn(Gn,l,a),d=new en(u,e.historySize),f=zg(n,s);d.addUserMessage(f),await Vg(d,r,i,o,{interactive:!1,autoMode:e.autoMode||!1,logger:t,config:e})}function zg(n,e){let t=/#([\w./-]+)/g,s=n,r;for(;(r=t.exec(n))!==null;){let i=r[1],o=Mt.resolve(e,i);pt.existsSync(o)&&(s=s.replace(`#${i}`,i))}return s}async function Gg(n,e){if(!(n.team?.enabled&&Re))return;if(await Re.releaseAllMyLocks(),!n.workspace?.autoPush){console.log(`
1074
+ ${Oe}`),await Gg(n,t);continue}}else M.addUserMessage(Q);Y=new AbortController,S.startTurn(),T.resetTurn(),await Vg(M,r,i,o,{interactive:!0,autoMode:C,input:a,logger:e,config:n,abortSignal:Y.signal,reactEngine:S,errorRecovery:T,skipTools:!1,onToolCall:()=>{H++,k=Hi(k,"tool_call"),fn(k)}}),await Gg(n,t)}catch(ee){if(ee.code==="ERR_USE_AFTER_CLOSE")break;if(ee.name==="AbortError")continue;console.log($e(ee.message)),e.error(ee,"REPL error")}a.close(),Re&&await Re.shutdown(),console.log(Zi({turns:F,duration:Date.now()-V,toolCalls:H}))}async function G0(n,e,t){let s=e.workingDirectory==="."?process.cwd():e.workingDirectory,r=Fe(e),i=new as(s,e),o=new en(e),a=new fs(s),l=await yn(s,e),u=bn(Wn,l,a),d=new tn(u,e.historySize),f=zg(n,s);d.addUserMessage(f),await Vg(d,r,i,o,{interactive:!1,autoMode:e.autoMode||!1,logger:t,config:e})}function zg(n,e){let t=/#([\w./-]+)/g,s=n,r;for(;(r=t.exec(n))!==null;){let i=r[1],o=Mt.resolve(e,i);pt.existsSync(o)&&(s=s.replace(`#${i}`,i))}return s}async function Gg(n,e){if(!(n.team?.enabled&&Re))return;if(await Re.releaseAllMyLocks(),!n.workspace?.autoPush){console.log(`
1075
1075
  ${c.info("\u2139")} ${c.strong("@Consul")}: "Changes tracked. Auto-push is off \u2014 commit & push manually when ready."
1076
1076
  `);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(`
1077
1077
  ${c.muted("@Consul: workspace clean \u2014 nothing to push.")}
@@ -1082,16 +1082,16 @@ ${Oe}`),await Gg(n,t);continue}}else M.addUserMessage(Q);Y=new AbortController,S
1082
1082
  `),s("git add -A"),s('git commit -m "sync(team): automatic updates via @Consul" --no-verify');return}console.log(`
1083
1083
  ${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."
1084
1084
  `)}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)}
1085
- `)}}var pt,Wg,Mt,Yl,Re,zl,j0,H0,B0,Ct=N(()=>{"use strict";Ku();ca();pt=O(require("fs")),Wg=require("child_process"),Mt=O(require("path")),Yl=O(require("os"));Dn();Fp();ga();ya();Up();dr();ja();Gp();zp();yi();cn();mg();yg();bg();Sg();_g();jn();ql();Ag();kg();Eg();Rg();Mg();mn();Lg();Bg();Vl();Ll();Nl();Ul();Re=null,zl=Mt.join(Yl.homedir(),".hablas",".first_run_done"),j0=Mt.join(Yl.homedir(),".hablas","config.json"),H0=150,B0=1500});function Lt(n){let e=Xl.join(Yg.homedir(),".hablas","logs");Yr.existsSync(e)||Yr.mkdirSync(e,{recursive:!0});let t=Xl.join(e,`session-${Date.now()}.log`);return(0,Ql.default)({level:"info"},Ql.default.destination({dest:t,sync:!1}))}var Ql,Xl,Yg,Yr,Zl=N(()=>{"use strict";Ql=O(Il()),Xl=O(require("path")),Yg=O(require("os")),Yr=O(require("fs"))});var ey={};Ne(ey,{createApiServer:()=>Zg,startApiServer:()=>Y0});function W0(){try{return JSON.parse(Qg.readFileSync(Xg.resolve(__dirname,"..","..","package.json"),"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function Zg(n){let e=Lt(n),t=z0(n);return Jg.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 z0(n){return[{method:"GET",path:"/api/v1/health",handler:async()=>({status:200,body:{status:"ok",version:V0,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 Y0(n){return new Promise((e,t)=>{let s=Zg(n);s.on("error",t),s.listen(n.api.port,n.api.host,()=>{e(s)})})}var Jg,Qg,Xg,V0,ty=N(()=>{"use strict";Jg=O(require("http")),Qg=O(require("fs")),Xg=O(require("path"));Zl();V0=W0()});var Q0={};Ne(Q0,{CLI_VERSION:()=>ws});module.exports=cy(Q0);var pc=O(fc(),1),{program:oE,createCommand:aE,createArgument:lE,createOption:cE,CommanderError:uE,InvalidArgumentError:dE,InvalidOptionArgumentError:fE,Command:hc,Argument:pE,Option:hE,Help:mE}=pc.default;Ct();dr();Zl();var ny=O(require("fs")),sy=O(require("path"));function J0(){try{let n=sy.resolve(__dirname,"..","package.json");return JSON.parse(ny.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}var ws=J0(),oe=new hc;oe.name("hablas").description(`hablas CLI v${ws} by Abdulmoin Hablas \u2014 Multi-agent AI development system. Local-first via Ollama, NVIDIA NIM, or any OpenAI-compatible API.`).version(ws).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");oe.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=oe.opts(),s=Ze({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=Lt(s),{runSingleCommand:i}=await Promise.resolve().then(()=>(Ct(),Ft)),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)});oe.command("commit").description("Generate a smart commit message from staged changes").action(async()=>{let n=oe.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),t=Lt(e),{getGitStatus:s,getDetailedDiff:r,generateCommitPrompt:i}=await Promise.resolve().then(()=>(pn(),Hn)),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(()=>(Ct(),Ft));await d(u,e,t)});oe.command("pr").description("Generate a PR description from branch commits").option("--base <branch>","Base branch","main").action(async n=>{let e=oe.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=Lt(t),{getGitStatus:r,getRecentCommits:i,generatePRPrompt:o}=await Promise.resolve().then(()=>(pn(),Hn)),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(()=>(Ct(),Ft));await f(d,t,s)});oe.command("changelog").description("Generate changelog from recent commits").option("--version <ver>","Version number",ws).option("-n, --count <n>","Number of commits to include","30").action(async n=>{let e=oe.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=Lt(t),{getRecentCommits:r,generateChangelogPrompt:i}=await Promise.resolve().then(()=>(pn(),Hn)),o=t.workingDirectory||process.cwd(),a=await r(o,parseInt(n.count)),l=i(a,n.version),{runSingleCommand:u}=await Promise.resolve().then(()=>(Ct(),Ft));await u(l,t,s)});oe.command("security").description("Run security scan on the project").option("--fix","Auto-fix issues where possible").action(async n=>{let e=oe.opts(),t=Ze({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(()=>(Ki(),zc)),i=t.workingDirectory||process.cwd();console.log(`
1085
+ `)}}var pt,Wg,Mt,Jl,Re,Yl,j0,H0,B0,Ct=N(()=>{"use strict";Ku();ua();pt=O(require("fs")),Wg=require("child_process"),Mt=O(require("path")),Jl=O(require("os"));Nn();Fp();ya();ba();Up();hr();Ha();Gp();zp();wi();un();mg();yg();bg();Sg();_g();Hn();Kl();Ag();kg();Eg();Rg();Mg();gn();Lg();Bg();zl();Dl();Fl();ql();Re=null,Yl=Mt.join(Jl.homedir(),".hablas",".first_run_done"),j0=Mt.join(Jl.homedir(),".hablas","config.json"),H0=150,B0=1500});function Lt(n){let e=Zl.join(Yg.homedir(),".hablas","logs");Xr.existsSync(e)||Xr.mkdirSync(e,{recursive:!0});let t=Zl.join(e,`session-${Date.now()}.log`);return(0,Xl.default)({level:"info"},Xl.default.destination({dest:t,sync:!1}))}var Xl,Zl,Yg,Xr,ec=N(()=>{"use strict";Xl=O(Ml()),Zl=O(require("path")),Yg=O(require("os")),Xr=O(require("fs"))});var ey={};Ne(ey,{createApiServer:()=>Zg,startApiServer:()=>Y0});function W0(){try{return JSON.parse(Qg.readFileSync(Xg.resolve(__dirname,"..","..","package.json"),"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function Zg(n){let e=Lt(n),t=z0(n);return Jg.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 z0(n){return[{method:"GET",path:"/api/v1/health",handler:async()=>({status:200,body:{status:"ok",version:V0,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 Y0(n){return new Promise((e,t)=>{let s=Zg(n);s.on("error",t),s.listen(n.api.port,n.api.host,()=>{e(s)})})}var Jg,Qg,Xg,V0,ty=N(()=>{"use strict";Jg=O(require("http")),Qg=O(require("fs")),Xg=O(require("path"));ec();V0=W0()});var Q0={};Ne(Q0,{CLI_VERSION:()=>xs});module.exports=cy(Q0);var hc=O(pc(),1),{program:oE,createCommand:aE,createArgument:lE,createOption:cE,CommanderError:uE,InvalidArgumentError:dE,InvalidOptionArgumentError:fE,Command:mc,Argument:pE,Option:hE,Help:mE}=hc.default;Ct();hr();ec();var ny=O(require("fs")),sy=O(require("path"));function J0(){try{let n=sy.resolve(__dirname,"..","package.json");return JSON.parse(ny.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}var xs=J0(),oe=new mc;oe.name("hablas").description(`hablas CLI v${xs} by Abdulmoin Hablas \u2014 Multi-agent AI development system. Local-first via Ollama, NVIDIA NIM, or any OpenAI-compatible API.`).version(xs).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");oe.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=oe.opts(),s=Ze({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=Lt(s),{runSingleCommand:i}=await Promise.resolve().then(()=>(Ct(),Ft)),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)});oe.command("commit").description("Generate a smart commit message from staged changes").action(async()=>{let n=oe.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),t=Lt(e),{getGitStatus:s,getDetailedDiff:r,generateCommitPrompt:i}=await Promise.resolve().then(()=>(hn(),Bn)),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(()=>(Ct(),Ft));await d(u,e,t)});oe.command("pr").description("Generate a PR description from branch commits").option("--base <branch>","Base branch","main").action(async n=>{let e=oe.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=Lt(t),{getGitStatus:r,getRecentCommits:i,generatePRPrompt:o}=await Promise.resolve().then(()=>(hn(),Bn)),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(()=>(Ct(),Ft));await f(d,t,s)});oe.command("changelog").description("Generate changelog from recent commits").option("--version <ver>","Version number",xs).option("-n, --count <n>","Number of commits to include","30").action(async n=>{let e=oe.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=Lt(t),{getRecentCommits:r,generateChangelogPrompt:i}=await Promise.resolve().then(()=>(hn(),Bn)),o=t.workingDirectory||process.cwd(),a=await r(o,parseInt(n.count)),l=i(a,n.version),{runSingleCommand:u}=await Promise.resolve().then(()=>(Ct(),Ft));await u(l,t,s)});oe.command("security").description("Run security scan on the project").option("--fix","Auto-fix issues where possible").action(async n=>{let e=oe.opts(),t=Ze({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(()=>(Gi(),Jc)),i=t.workingDirectory||process.cwd();console.log(`
1086
1086
  \u{1F512} Running security scan...
1087
- `);let o=s(i);console.log(r(o))});oe.command("stats").description("Show developer analytics and usage statistics").action(async()=>{let{loadStats:n,formatStats:e}=await Promise.resolve().then(()=>(jn(),Bi)),t=n();console.log(e(t))});oe.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=oe.opts(),t=Ze({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(()=>(ca(),zf)),l=t.workingDirectory||process.cwd();if(n.init)r(l,n.init),console.log(`
1087
+ `);let o=s(i);console.log(r(o))});oe.command("stats").description("Show developer analytics and usage statistics").action(async()=>{let{loadStats:n,formatStats:e}=await Promise.resolve().then(()=>(Hn(),Ui)),t=n();console.log(e(t))});oe.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=oe.opts(),t=Ze({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(()=>(ua(),zf)),l=t.workingDirectory||process.cwd();if(n.init)r(l,n.init),console.log(`
1088
1088
  \u2713 Team "${n.init}" initialized.`),console.log(` Config saved to: .hablas/team.json
1089
- `);else if(n.add){let u=s(l);if(!u){console.log(" \u26A0 No team config found. Run `hablas team --init <name>` first.");return}let d=i(u,n.add.split("@")[0],n.add);o(l,d),console.log(` \u2713 Added ${n.add} to team.`)}else{let u=s(l);if(!u){console.log(" No team config found. Run `hablas team --init <name>` to create one.");return}console.log(a(u))}});oe.command("info").description("Show workspace information and detected configuration").action(async()=>{let n=oe.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),{scanWorkspace:t,formatWorkspaceInfo:s}=await Promise.resolve().then(()=>(Vi(),tu)),r=e.workingDirectory||process.cwd();console.log(`
1089
+ `);else if(n.add){let u=s(l);if(!u){console.log(" \u26A0 No team config found. Run `hablas team --init <name>` first.");return}let d=i(u,n.add.split("@")[0],n.add);o(l,d),console.log(` \u2713 Added ${n.add} to team.`)}else{let u=s(l);if(!u){console.log(" No team config found. Run `hablas team --init <name>` to create one.");return}console.log(a(u))}});oe.command("info").description("Show workspace information and detected configuration").action(async()=>{let n=oe.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),{scanWorkspace:t,formatWorkspaceInfo:s}=await Promise.resolve().then(()=>(zi(),su)),r=e.workingDirectory||process.cwd();console.log(`
1090
1090
  \u25C6 Workspace Information
1091
1091
  `);let i=t(r);console.log(s(i)),console.log("")});oe.command("api").description("Start the REST API server").option("--port <port>","Port number","8080").option("--key <key>","API key for authentication").action(async n=>{let e=oe.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey});t.api.enabled=!0,t.api.port=parseInt(n.port),n.key&&(t.api.apiKey=n.key);let{startApiServer:s}=await Promise.resolve().then(()=>(ty(),ey));console.log(`
1092
- \u25C6 Hablas API Server v${ws}`),console.log(" \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"),console.log(` Starting on port ${t.api.port}...`);try{await s(t),console.log(` \u2713 API server running at http://${t.api.host}:${t.api.port}`),console.log(" Endpoints:"),console.log(" GET /api/v1/health \u2014 Health check"),console.log(" GET /api/v1/agents \u2014 List agents"),console.log(" GET /api/v1/models \u2014 List models"),console.log(" POST /api/v1/chat \u2014 Send message"),console.log(" POST /api/v1/plan \u2014 Generate plan"),console.log(" POST /api/v1/execute \u2014 Execute command"),console.log(" GET /api/v1/stats \u2014 Usage stats"),console.log(`
1092
+ \u25C6 Hablas API Server v${xs}`),console.log(" \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"),console.log(` Starting on port ${t.api.port}...`);try{await s(t),console.log(` \u2713 API server running at http://${t.api.host}:${t.api.port}`),console.log(" Endpoints:"),console.log(" GET /api/v1/health \u2014 Health check"),console.log(" GET /api/v1/agents \u2014 List agents"),console.log(" GET /api/v1/models \u2014 List models"),console.log(" POST /api/v1/chat \u2014 Send message"),console.log(" POST /api/v1/plan \u2014 Generate plan"),console.log(" POST /api/v1/execute \u2014 Execute command"),console.log(" GET /api/v1/stats \u2014 Usage stats"),console.log(`
1093
1093
  Press Ctrl+C to stop.
1094
- `)}catch(r){console.error(` \u2717 Failed to start API server: ${r}`)}});oe.command("run <prompt>").description("Run a single command non-interactively").action(async n=>{let e=oe.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey});e.auto&&(t.autoMode=!0),e.timeout&&(t.timeout=parseInt(e.timeout,10));let s=Lt(t),{runSingleCommand:r}=await Promise.resolve().then(()=>(Ct(),Ft));await r(n,t,s)});oe.command("doctor").description("Run system diagnostics").action(async()=>{let n=oe.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),{runDiagnostics:t,renderDiagnostics:s}=await Promise.resolve().then(()=>(Ei(),jc)),r=await t({ollamaHost:e.ollamaHost,model:e.model,provider:e.provider,apiUrl:e.apiUrl});console.log(s(r))});oe.command("plugins").description("Manage plugins").option("--enable <name>","Enable a plugin").option("--disable <name>","Disable a plugin").option("--search <query>","Search plugin marketplace").option("--install <name>","Install a plugin from marketplace").action(async n=>{let{enablePlugin:e,disablePlugin:t,renderPlugins:s,ensurePluginsDir:r}=await Promise.resolve().then(()=>(_i(),Dc));r(),n.enable?(e(n.enable),console.log(` \u2713 Plugin "${n.enable}" enabled`)):n.disable?(t(n.disable),console.log(` \u26A0 Plugin "${n.disable}" disabled`)):n.search?(console.log(`
1094
+ `)}catch(r){console.error(` \u2717 Failed to start API server: ${r}`)}});oe.command("run <prompt>").description("Run a single command non-interactively").action(async n=>{let e=oe.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey});e.auto&&(t.autoMode=!0),e.timeout&&(t.timeout=parseInt(e.timeout,10));let s=Lt(t),{runSingleCommand:r}=await Promise.resolve().then(()=>(Ct(),Ft));await r(n,t,s)});oe.command("doctor").description("Run system diagnostics").action(async()=>{let n=oe.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),{runDiagnostics:t,renderDiagnostics:s}=await Promise.resolve().then(()=>(Ri(),Hc)),r=await t({ollamaHost:e.ollamaHost,model:e.model,provider:e.provider,apiUrl:e.apiUrl});console.log(s(r))});oe.command("plugins").description("Manage plugins").option("--enable <name>","Enable a plugin").option("--disable <name>","Disable a plugin").option("--search <query>","Search plugin marketplace").option("--install <name>","Install a plugin from marketplace").action(async n=>{let{enablePlugin:e,disablePlugin:t,renderPlugins:s,ensurePluginsDir:r}=await Promise.resolve().then(()=>($i(),Nc));r(),n.enable?(e(n.enable),console.log(` \u2713 Plugin "${n.enable}" enabled`)):n.disable?(t(n.disable),console.log(` \u26A0 Plugin "${n.disable}" disabled`)):n.search?(console.log(`
1095
1095
  \u{1F50D} Searching marketplace for "${n.search}"...`),console.log(" (Marketplace: https://registry.hablas.dev/plugins)"),console.log(`
1096
1096
  Available plugins:`),console.log(" hablas-docker \u2014 Docker integration"),console.log(" hablas-aws \u2014 AWS toolkit"),console.log(" hablas-firebase \u2014 Firebase integration"),console.log(" hablas-supabase \u2014 Supabase toolkit"),console.log(" hablas-stripe \u2014 Stripe payment integration"),console.log(`
1097
1097
  Install: hablas plugins --install <name>
@@ -1101,7 +1101,7 @@ ${Oe}`),await Gg(n,t);continue}}else M.addUserMessage(Q);Y=new AbortController,S
1101
1101
  \u25C6 Installed Plugins
1102
1102
  `),console.log(s()),console.log(`
1103
1103
  Plugins directory: ~/.hablas/plugins/`),console.log(" Search: hablas plugins --search <query>"),console.log(" Install: hablas plugins --install <name>"),console.log(" Enable: hablas plugins --enable <name>"),console.log(` Disable: hablas plugins --disable <name>
1104
- `))});oe.action(async()=>{let n=oe.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey,team:n.team,user:n.user,teamKey:n.teamKey});if(n.auto&&(e.autoMode=!0),n.timeout&&(e.timeout=parseInt(n.timeout,10)),n.theme&&(e.ui.theme=n.theme),n.dashboard&&(e.ui.dashboard=!0),n.setup){let{runSetupWizard:s}=await Promise.resolve().then(()=>(Vl(),qg));await s(e);return}let t=Lt(e);await Jl(e,t)});oe.parse();0&&(module.exports={CLI_VERSION});
1104
+ `))});oe.action(async()=>{let n=oe.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey,team:n.team,user:n.user,teamKey:n.teamKey});if(n.auto&&(e.autoMode=!0),n.timeout&&(e.timeout=parseInt(n.timeout,10)),n.theme&&(e.ui.theme=n.theme),n.dashboard&&(e.ui.dashboard=!0),n.setup){let{runSetupWizard:s}=await Promise.resolve().then(()=>(zl(),qg));await s(e);return}let t=Lt(e);await Ql(e,t)});oe.parse();0&&(module.exports={CLI_VERSION});
1105
1105
  /*! Bundled license information:
1106
1106
 
1107
1107
  normalize-path/index.js: