hablas-ai 1.2.4 → 1.2.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +229 -216
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,47 +1,47 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var
|
|
3
|
-
`).replace(/^/gm," ".repeat(i))}let c=[`Usage: ${t.commandUsage(e)}`,""],
|
|
2
|
+
"use strict";var Sg=Object.create;var os=Object.defineProperty;var _g=Object.getOwnPropertyDescriptor;var Ag=Object.getOwnPropertyNames;var kg=Object.getPrototypeOf,$g=Object.prototype.hasOwnProperty;var F=(n,e)=>()=>(n&&(e=n(n=0)),e);var j=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports),Ee=(n,e)=>{for(var t in e)os(n,t,{get:e[t],enumerable:!0})},Al=(n,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Ag(e))!$g.call(n,r)&&r!==t&&os(n,r,{get:()=>e[r],enumerable:!(s=_g(e,r))||s.enumerable});return n};var O=(n,e,t)=>(t=n!=null?Sg(kg(n)):{},Al(e||!n||!n.__esModule?os(t,"default",{value:n,enumerable:!0}):t,n)),Cg=n=>Al(os({},"__esModule",{value:!0}),n);var vn=j(Or=>{var as=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}},Rr=class extends as{constructor(e){super(1,"commander.invalidArgument",e),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name}};Or.CommanderError=as;Or.InvalidArgumentError=Rr});var ls=j(Mr=>{var{InvalidArgumentError:Eg}=vn(),Pr=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 Eg(`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 Tg(n){let e=n.name()+(n.variadic===!0?"...":"");return n.required?"<"+e+">":"["+e+"]"}Mr.Argument=Pr;Mr.humanReadableArgName=Tg});var Lr=j(kl=>{var{humanReadableArgName:Rg}=ls(),Ir=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=>Rg(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
|
+
`).replace(/^/gm," ".repeat(i))}let c=[`Usage: ${t.commandUsage(e)}`,""],u=t.commandDescription(e);u.length>0&&(c=c.concat([t.wrap(u,r,0),""]));let f=t.visibleArguments(e).map(p=>a(t.argumentTerm(p),t.argumentDescription(p)));f.length>0&&(c=c.concat(["Arguments:",l(f),""]));let h=t.visibleOptions(e).map(p=>a(t.optionTerm(p),t.optionDescription(p)));if(h.length>0&&(c=c.concat(["Options:",l(h),""])),this.showGlobalOptions){let p=t.visibleGlobalOptions(e).map(g=>a(t.optionTerm(g),t.optionDescription(g)));p.length>0&&(c=c.concat(["Global Options:",l(p),""]))}let m=t.visibleCommands(e).map(p=>a(t.subcommandTerm(p),t.subcommandDescription(p)));return m.length>0&&(c=c.concat(["Commands:",l(m),""])),c.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),c=e.slice(s).replace(`\r
|
|
5
5
|
`,`
|
|
6
|
-
`),
|
|
7
|
-
|.{1,${a-1}}([${h}]|$)|[^${h}]+?([${h}]|$)`,"g"),p=c.match(m)||[];return l+p.map((
|
|
8
|
-
`?"":(
|
|
9
|
-
`)}}
|
|
6
|
+
`),u=" ".repeat(s),h="\\s\u200B",m=new RegExp(`
|
|
7
|
+
|.{1,${a-1}}([${h}]|$)|[^${h}]+?([${h}]|$)`,"g"),p=c.match(m)||[];return l+p.map((g,x)=>g===`
|
|
8
|
+
`?"":(x>0?u:"")+g.trimEnd()).join(`
|
|
9
|
+
`)}};kl.Help=Ir});var jr=j(Nr=>{var{InvalidArgumentError:Og}=vn(),Dr=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=Mg(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 Og(`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 Pg(this.name().replace(/^no-/,""))}is(e){return this.short===e||this.long===e}isBoolean(){return!this.required&&!this.optional&&!this.negate}},Fr=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 Pg(n){return n.split("-").reduce((e,t)=>e+t[0].toUpperCase()+t.slice(1))}function Mg(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}}Nr.Option=Dr;Nr.DualOptions=Fr});var Cl=j($l=>{function Ig(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 Lg(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=Ig(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]}?)`:""}
|
|
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
|
|
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
|
|
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
|
|
11
|
+
(Did you mean ${s[0]}?)`:""}$l.suggestSimilar=Lg});var Pl=j(Ol=>{var Dg=require("node:events").EventEmitter,Hr=require("node:child_process"),ut=require("node:path"),Br=require("node:fs"),oe=require("node:process"),{Argument:Fg,humanReadableArgName:Ng}=ls(),{CommanderError:Ur}=vn(),{Help:jg}=Lr(),{Option:El,DualOptions:Hg}=jr(),{suggestSimilar:Tl}=Cl(),qr=class n extends Dg{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=>oe.stdout.write(t),writeErr:t=>oe.stderr.write(t),getOutHelpWidth:()=>oe.stdout.isTTY?oe.stdout.columns:void 0,getErrHelpWidth:()=>oe.stderr.isTTY?oe.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 jg,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
|
+
- 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 Fg(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 Ur(e,t,s)),oe.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 El(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 El)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,c)=>{let u=a.exec(l);return u?u[0]:c},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){oe.versions?.electron&&(t.from="electron");let r=oe.execArgv??[];(r.includes("-e")||r.includes("--eval")||r.includes("-p")||r.includes("--print"))&&(t.from="eval")}e===void 0&&(e=oe.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":oe.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(u,f){let h=ut.resolve(u,f);if(Br.existsSync(h))return h;if(r.includes(ut.extname(f)))return;let m=r.find(p=>Br.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 u;try{u=Br.realpathSync(this._scriptPath)}catch{u=this._scriptPath}a=ut.resolve(ut.dirname(u),a)}if(a){let u=i(a,o);if(!u&&!e._executableFile&&this._scriptPath){let f=ut.basename(this._scriptPath,ut.extname(this._scriptPath));f!==this._name&&(u=i(a,`${f}-${e._name}`))}o=u||o}s=r.includes(ut.extname(o));let l;oe.platform!=="win32"?s?(t.unshift(o),t=Rl(oe.execArgv).concat(t),l=Hr.spawn(oe.argv[0],t,{stdio:"inherit"})):l=Hr.spawn(o,t,{stdio:"inherit"}):(t.unshift(o),t=Rl(oe.execArgv).concat(t),l=Hr.spawn(oe.execPath,t,{stdio:"inherit"})),l.killed||["SIGUSR1","SIGUSR2","SIGTERM","SIGINT","SIGHUP"].forEach(f=>{oe.on(f,()=>{l.killed===!1&&l.exitCode===null&&l.kill(f)})});let c=this._exitCallback;l.on("close",u=>{u=u??1,c?c(new Ur(u,"commander.executeSubCommandAsync","(close)")):oe.exit(u)}),l.on("error",u=>{if(u.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(
|
|
17
|
+
- ${f}`;throw new Error(h)}else if(u.code==="EACCES")throw new Error(`'${o}' not executable`);if(!c)oe.exit(1);else{let f=new Ur(1,"commander.executeSubCommandAsync","(error)");f.nestedError=u,c(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 c=this._findOption(l);if(c){if(c.required){let u=i.shift();u===void 0&&this.optionMissingArgument(c),this.emit(`option:${c.name()}`,u)}else if(c.optional){let u=null;i.length>0&&!o(i[0])&&(u=i.shift()),this.emit(`option:${c.name()}`,u)}else this.emit(`option:${c.name()}`);a=c.variadic?c:null;continue}}if(l.length>2&&l[0]==="-"&&l[1]!=="-"){let c=this._findOption(`-${l[1]}`);if(c){c.required||c.optional&&this._combineFlagAndOptionalValue?this.emit(`option:${c.name()}`,l.slice(2)):(this.emit(`option:${c.name()}`),i.unshift(`-${l.slice(2)}`));continue}}if(/^--[^=]+=/.test(l)){let c=l.indexOf("="),u=this._findOption(l.slice(0,c));if(u&&(u.required||u.optional)){this.emit(`option:${u.name()}`,l.slice(c+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 oe.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()}`,oe.env[e.envVar]):this.emit(`optionEnv:${e.name()}`))}})}_parseOptionsImplied(){let e=new
|
|
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=>
|
|
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 oe.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()}`,oe.env[e.envVar]):this.emit(`optionEnv:${e.name()}`))}})}_parseOptionsImplied(){let e=new Hg(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),c=this.options.find(f=>f.negate&&a===f.attributeName()),u=this.options.find(f=>!f.negate&&a===f.attributeName());return c&&(c.presetArg===void 0&&l===!1||c.presetArg!==void 0&&l===c.presetArg)?c:u||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=Tl(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=Tl(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
|
+
`),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=>Ng(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=ut.basename(e,ut.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=oe.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
|
|
24
|
-
`);o=c.pop()||"";for(let
|
|
25
|
-
`);a=
|
|
26
|
-
`)}var
|
|
23
|
+
`)}),this}_outputHelpIfRequested(e){let t=this._getHelpOption();t&&e.find(r=>t.is(r))&&(this.outputHelp(),this._exit(0,"commander.helpDisplayed","(outputHelp)"))}};function Rl(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})}Ol.Command=qr});var Dl=j(Ie=>{var{Argument:Ml}=ls(),{Command:Kr}=Pl(),{CommanderError:Bg,InvalidArgumentError:Il}=vn(),{Help:Ug}=Lr(),{Option:Ll}=jr();Ie.program=new Kr;Ie.createCommand=n=>new Kr(n);Ie.createOption=(n,e)=>new Ll(n,e);Ie.createArgument=(n,e)=>new Ml(n,e);Ie.Command=Kr;Ie.Option=Ll;Ie.Argument=Ml;Ie.Help=Ug;Ie.CommanderError=Bg;Ie.InvalidArgumentError=Il;Ie.InvalidOptionArgumentError=Il});var jl={};Ee(jl,{DEFAULT_CONFIG:()=>wn,NVIDIA_PROVIDER:()=>kt});var wn,kt,xn=F(()=>{"use strict";wn={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:""}},kt={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 cs,Hl=F(()=>{"use strict";cs=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 c=o.split(`
|
|
24
|
+
`);o=c.pop()||"";for(let u of c)if(u.trim())try{let f=JSON.parse(u);f.message?.content&&(yield f.message.content)}catch{}}}}});function ql(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 Wg(n){return n.map(e=>({type:"function",function:e.function}))}function Gg(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 Kl(n){return new Promise(e=>setTimeout(e,n))}function Wl(n,e){return!(n.name==="AbortError"||e&&e>=400&&e<500&&e!==429)}var Bl,qg,us,Ul,Kg,Ft,Wr=F(()=>{"use strict";Bl=12e4,qg=6e4,us=3,Ul=1e3,Kg=20;Ft=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<Kg;){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(qg)});if(!l.ok)break;let c=await l.json();if(Array.isArray(c))e.push(...c.map(u=>u.id||u.name||u).filter(Boolean)),t=!1;else if(c.data&&Array.isArray(c.data)){let u=c.data.map(f=>f.id||f.name).filter(Boolean);e.push(...u),c.has_more&&u.length>0?(s=u[u.length-1],r++):t=!1}else c.models&&Array.isArray(c.models)&&e.push(...c.models.map(u=>u.name||u.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:ql(e)};t.length>0&&(i.tools=Wg(t),i.tool_choice="auto");let o=null;for(let a=0;a<=us;a++)try{let l=new AbortController,c=setTimeout(()=>l.abort(),Bl),u={method:"POST",headers:{"Content-Type":"application/json",...this.getHeaders()},body:JSON.stringify(i),signal:s||l.signal};try{let f=await fetch(r,u);if(clearTimeout(c),!f.ok){let g=await f.text().catch(()=>"");if(!Wl(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<us){let x=Ul*Math.pow(2,a);await Kl(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?Gg(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(c),f.name==="AbortError"&&s?.aborted)throw f;if(Wl(f)&&(o=f,a<us)){let h=Ul*Math.pow(2,a);await Kl(h);continue}throw f}}catch(l){if(l.name==="AbortError")throw l;if(o=l,a>=us)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:ql(e),stream:!0}),signal:t||AbortSignal.timeout(Bl)});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:c}=await i.read();if(l)break;a+=o.decode(c,{stream:!0});let u=a.split(`
|
|
25
|
+
`);a=u.pop()||"";for(let f of u){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 Le(n){if(n.provider==="nvidia"){let e={...n,provider:"custom",apiUrl:kt.apiUrl};return new Ft(e)}return n.provider==="custom"&&n.apiUrl?new Ft(n):new cs(n)}function Gl(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 Sn=F(()=>{"use strict";xn();Hl();Wr()});var Vl=F(()=>{"use strict"});function Nt(){let n={providers:[],activeProvider:null,activeModel:null};try{if(dt.existsSync(Vr)){let e=dt.readFileSync(Vr,"utf-8"),t=JSON.parse(e);return{...n,...t}}}catch{}return n}function Yr(n){dt.existsSync(Gr)||dt.mkdirSync(Gr,{recursive:!0}),dt.writeFileSync(Vr,JSON.stringify(n,null,2),"utf-8")}function We(n){let e=Nt();e.providers=e.providers.filter(t=>t.name!==n.name),e.providers.push(n),Yr(e)}function Yl(n){let e=Nt(),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),Yr(e),!0):!1}function Jl(n){return Nt().providers.find(t=>t.name.toLowerCase()===n.toLowerCase())}function ds(){return Nt().providers}function Xl(n,e){let t=Nt(),s=t.providers.find(r=>r.name===n);s&&(t.activeProvider=n,t.activeModel=e||s.defaultModel,Yr(t))}function Ql(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 dt,zr,zl,Gr,Vr,Jr=F(()=>{"use strict";dt=O(require("fs")),zr=O(require("path")),zl=O(require("os"));Vl();Gr=zr.join(zl.homedir(),".hablas"),Vr=zr.join(Gr,"models.json")});function hs(){try{if(ft.existsSync(fs))return JSON.parse(ft.readFileSync(fs,"utf-8"))}catch{}return{}}function ec(n){let e=ps.dirname(fs);ft.existsSync(e)||ft.mkdirSync(e,{recursive:!0}),ft.writeFileSync(fs,JSON.stringify(n,null,2),"utf-8")}function tc(n,e){let t=hs();t[n]=e,ec(t)}function nc(n){let e=hs();return e[n]?(delete e[n],ec(e),!0):!1}function sc(n){let e=hs(),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 rc(){let n=hs(),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
|
|
28
|
+
`)}var ft,ps,Zl,fs,Xr=F(()=>{"use strict";ft=O(require("fs")),ps=O(require("path")),Zl=O(require("os")),fs=ps.join(Zl.homedir(),".hablas","aliases.json")});var ac={};Ee(ac,{disablePlugin:()=>ti,enablePlugin:()=>ei,ensurePluginsDir:()=>ys,listPlugins:()=>oc,renderPlugins:()=>ni});function Zr(){try{if(Te.existsSync(gs))return JSON.parse(Te.readFileSync(gs,"utf-8"))}catch{}return{disabled:[]}}function ic(n){let e=Jt.dirname(gs);Te.existsSync(e)||Te.mkdirSync(e,{recursive:!0}),Te.writeFileSync(gs,JSON.stringify(n,null,2),"utf-8")}function ys(){Te.existsSync(ms)||Te.mkdirSync(ms,{recursive:!0})}function oc(){ys();let n=Zr(),e=[];try{let t=Te.readdirSync(ms).filter(s=>s.endsWith(".js"));for(let s of t){let r=Jt.join(ms,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 ei(n){let e=Zr(),t=e.disabled.indexOf(n);return t!==-1?(e.disabled.splice(t,1),ic(e),!0):!1}function ti(n){let e=Zr();return e.disabled.includes(n)?!1:(e.disabled.push(n),ic(e),!0)}function ni(){let n=oc();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
|
|
33
|
-
`)}var
|
|
34
|
-
`)}var he,
|
|
32
|
+
`)}var Te,Jt,Qr,ms,gs,si=F(()=>{"use strict";Te=O(require("fs")),Jt=O(require("path")),Qr=O(require("os")),ms=Jt.join(Qr.homedir(),".hablas","plugins"),gs=Jt.join(Qr.homedir(),".hablas","plugins.json")});var uc={};Ee(uc,{renderDiagnostics:()=>oi,runDiagnostics:()=>ii});async function ii(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=lc.join(Ge.homedir(),".hablas");if(e.push({name:"Config directory",status:ri.existsSync(r)?"ok":"warn",message:ri.existsSync(r)?r:"Not created yet (will be created on first use)"}),n.provider==="ollama")try{let i=await fetch(`${n.ollamaHost}/api/tags`,{signal:AbortSignal.timeout(5e3)});if(i.ok){let o=await i.json(),a=Array.isArray(o.models)?o.models.length:0;e.push({name:"Ollama",status:"ok",message:`Connected \u2014 ${a} models available`})}else e.push({name:"Ollama",status:"error",message:`HTTP ${i.status}`})}catch(i){let o=i instanceof Error?i.message:String(i);e.push({name:"Ollama",status:"error",message:o.includes("ECONNREFUSED")?"Not running \u2014 start with: ollama serve":`Connection failed: ${o}`})}else{let i=n.apiUrl||"unknown";try{let o=await fetch(`${i}/models`,{signal:AbortSignal.timeout(5e3),headers:{Authorization:"Bearer test"}});e.push({name:"API Provider",status:o.ok||o.status===401?"ok":"warn",message:`${i} \u2014 reachable`})}catch{e.push({name:"API Provider",status:"warn",message:`${i} \u2014 could not verify`})}}try{let i=Ge.homedir();if(process.platform!=="win32"){let a=(0,cc.execSync)(`df -h "${i}" | tail -1`,{encoding:"utf-8"}).trim().split(/\s+/),l=a[3]||"unknown",c=a[4]||"?";e.push({name:"Disk space",status:parseInt(c)>90?"warn":"ok",message:`${l} available (${c} 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:`${Ge.platform()} ${Ge.arch()} \u2014 ${Ge.cpus().length} cores, ${Math.round(Ge.totalmem()/1024/1024/1024)}GB RAM`}),e}function oi(n){let e={ok:"\u2713",warn:"\u26A0",error:"\u2717"},t={ok:"\x1B[32m",warn:"\x1B[33m",error:"\x1B[31m"},s="\x1B[0m",r="\x1B[2m",i=[""," \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501"," hablas doctor \u2014 System Diagnostics"," \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501",""];for(let l of n){let c=`${t[l.status]}${e[l.status]}${s}`,u=l.name.padEnd(18);i.push(` ${c} ${u}${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 ri,lc,Ge,cc,ai=F(()=>{"use strict";ri=O(require("fs")),lc=O(require("path")),Ge=O(require("os")),cc=require("child_process")});function li(n){let e=n.trim();return!!(e.length<15&&!dc.test(e)||Vg.test(e)||zg.test(e)||Yg.test(e)||Jg.test(e))}function fc(n){let e=n.toLowerCase(),t=["hablas"];return li(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&&dc.test(n)&&t.push("alex")),t}function pc(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(c=>c.role==="emma").id]:[],status:"pending"}),i){let c=[];a?c.push(t.find(u=>u.role==="david").id):r&&c.push(t.find(u=>u.role==="emma").id),t.push({id:`task-${s++}`,role:"bob",agentName:"Bob",description:"Design system architecture and structure",input:n,dependencies:c,status:"pending"})}if(o){let c=[];i?c.push(t.find(u=>u.role==="bob").id):a?c.push(t.find(u=>u.role==="david").id):r&&c.push(t.find(u=>u.role==="emma").id),t.push({id:`task-${s++}`,role:"alex",agentName:"Alex",description:"Implement the code based on architecture/requirements",input:n,dependencies:c,status:"pending"})}let l="sequential";return t.length>2&&t.some(c=>c.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 ci(){let n=[];for(let e of he){let s=e.role==="hablas"?" \u2605":"";n.push(` @${e.name}${s} \u2014 ${e.title}`),n.push(` ${e.description}`)}return n.join(`
|
|
34
|
+
`)}var he,Vg,zg,Yg,Jg,dc,_n=F(()=>{"use strict";he=[{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"]}],Vg=/^(hi|hello|hey|howdy|yo|sup|hiya|good\s*(morning|afternoon|evening|night)|what'?s\s*up|greetings)\b/i,zg=/^(مرحبا|أهلا|أهلاً|هلا|السلام\s*عليكم|وعليكم\s*السلام|كيف\s*حالك|كيفك|شلونك|صباح\s*الخير|مساء\s*الخير|شكرا|شكراً|يعطيك\s*العافية|تمام|اهلين|هلو|مرحبتين|الله\s*يسلمك|حياك|حياك\s*الله|يا\s*هلا|كيف\s*الحال|اخبارك|شخبارك)/i,Yg=/^(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,Jg=/^(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,dc=/\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 An(){try{if(Xt.existsSync(ui)){let n=Xt.readFileSync(ui,"utf-8"),e=JSON.parse(n);return{...hc,...e}}}catch{}return{...hc}}function gc(){return ui}var Xt,di,mc,ui,hc,fi=F(()=>{"use strict";Xt=O(require("fs")),di=O(require("path")),mc=O(require("os")),ui=di.join(mc.homedir(),".hablas","agents.json"),hc={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={};Ee(bi,{formatStats:()=>ny,loadStats:()=>Qt,saveStats:()=>bs,trackAgentUsage:()=>Zg,trackFileModified:()=>ey,trackMessage:()=>gi,trackSession:()=>Qg,trackToolCall:()=>yi});function Qt(){try{if(pt.existsSync(hi))return JSON.parse(pt.readFileSync(hi,"utf-8"))}catch{}return Xg()}function bs(n){try{pt.existsSync(pi)||pt.mkdirSync(pi,{recursive:!0}),pt.writeFileSync(hi,JSON.stringify(n,null,2))}catch{}}function Xg(){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 Qg(n){return n.totalSessions++,n.lastUsed=new Date().toISOString(),ty(n),n}function gi(n,e=0){n.totalMessages++,n.totalTokensUsed+=e;let t=vs();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 yi(n,e){n.totalToolCalls++,n.commandUsage[e]=(n.commandUsage[e]||0)+1;let t=vs();return n.dailyActivity[t]||(n.dailyActivity[t]={messages:0,tokens:0,toolCalls:0,filesModified:0,linesWritten:0}),n.dailyActivity[t].toolCalls++,n}function Zg(n,e){return n.agentUsage[e]=(n.agentUsage[e]||0)+1,n}function ey(n,e=0){n.totalFilesModified++,n.totalLinesWritten+=e;let t=vs();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 ty(n){let e=vs(),t=bc(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 vs(){return bc(new Date)}function bc(n){return n.toISOString().split("T")[0]}function ny(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
|
|
37
|
-
`);for(let{pattern:r,name:i,severity:o}of
|
|
38
|
-
`).length,
|
|
39
|
-
`),r=
|
|
36
|
+
`)}var pt,mi,yc,pi,hi,kn=F(()=>{"use strict";pt=O(require("fs")),mi=O(require("path")),yc=O(require("os")),pi=mi.join(yc.homedir(),".hablas"),hi=mi.join(pi,"analytics.json")});var wc={};Ee(wc,{formatScanResults:()=>wi,runSecurityScan:()=>vi});function oy(n,e){let t=[],s=e.split(`
|
|
37
|
+
`);for(let{pattern:r,name:i,severity:o}of sy){r.lastIndex=0;let a;for(;(a=r.exec(e))!==null;){let c=e.substring(0,a.index).split(`
|
|
38
|
+
`).length,u=s[c-1]||"";u.trim().startsWith("#")||u.trim().startsWith("//")||n.includes(".example")||n.includes(".sample")||t.push({severity:o,type:"secret",file:n,line:c,message:`Potential ${i} detected`,suggestion:"Move to environment variable or use a secrets manager. Add to .gitignore if needed."})}}return t}function ay(n,e){let t=[],s=e.split(`
|
|
39
|
+
`),r=jt.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=ws.readdirSync(n,{withFileTypes:!0});for(let s of t){if(ry.has(s.name))continue;let r=jt.join(n,s.name);if(s.isDirectory())vc(r,e);else if(s.isFile()){let i=jt.extname(s.name);iy.has(i)||e.push(r)}}}catch{}return e}function vi(n){let e=Date.now(),t=vc(n),s=[];for(let o of t)try{let a=ws.readFileSync(o,"utf-8"),l=jt.relative(n,o),c=oy(l,a);s.push(...c);let u=ay(l,a);s.push(...u)}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 wi(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
|
|
42
|
-
`).filter(Boolean)){let
|
|
43
|
-
... (truncated)`:e.trim()}catch{return""}}async function
|
|
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
|
|
41
|
+
`)}var ws,jt,sy,ry,iy,xi=F(()=>{"use strict";ws=O(require("fs")),jt=O(require("path")),sy=[{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"}],ry=new Set(["node_modules",".git","dist","build",".next","__pycache__","venv",".venv","target","vendor",".cache"]),iy=new Set([".png",".jpg",".jpeg",".gif",".svg",".ico",".woff",".woff2",".ttf",".eot",".mp4",".mp3",".zip",".tar",".gz",".lock"])});var $n={};Ee($n,{formatGitStatus:()=>hy,generateChangelogPrompt:()=>py,generateCommitPrompt:()=>dy,generatePRPrompt:()=>fy,getDetailedDiff:()=>cy,getGitStatus:()=>Si,getRecentCommits:()=>uy,getStagedDiff:()=>ly});async function Si(n){try{let{stdout:e}=await Zt("git branch --show-current",{cwd:n}),{stdout:t}=await Zt("git status --porcelain",{cwd:n}),s=e.trim(),r=[],i=[],o=[];for(let c of t.split(`
|
|
42
|
+
`).filter(Boolean)){let u=c.substring(0,2),f=c.substring(3);(u.startsWith("A")||u.startsWith("M")||u.startsWith("R"))&&u[0]!==" "&&r.push(f),(u[1]==="M"||u[1]==="D")&&i.push(f),u==="??"&&o.push(f)}let a=0,l=0;try{let{stdout:c}=await Zt("git rev-list --left-right --count HEAD...@{upstream}",{cwd:n}),u=c.trim().split(" ");a=parseInt(u[0])||0,l=parseInt(u[1])||0}catch{}return{branch:s,staged:r,modified:i,untracked:o,ahead:a,behind:l}}catch{return null}}async function ly(n){try{let{stdout:e}=await Zt("git diff --cached --stat",{cwd:n});return e.trim()}catch{return""}}async function cy(n){try{let{stdout:e}=await Zt("git diff --cached",{cwd:n,maxBuffer:1048576});return e.length>1e4?e.substring(0,1e4)+`
|
|
43
|
+
... (truncated)`:e.trim()}catch{return""}}async function uy(n,e=20){try{let{stdout:t}=await Zt(`git log --oneline --format="%H|%s|%an|%ai" -n ${e}`,{cwd:n});return t.trim().split(`
|
|
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 dy(n,e){return`Based on the following git diff, generate a concise, conventional commit message.
|
|
45
45
|
|
|
46
46
|
Rules:
|
|
47
47
|
- Use conventional commits format: type(scope): description
|
|
@@ -55,7 +55,7 @@ Staged files: ${e.join(", ")}
|
|
|
55
55
|
Diff:
|
|
56
56
|
${n}
|
|
57
57
|
|
|
58
|
-
Generate ONLY the commit message, nothing else.`}function
|
|
58
|
+
Generate ONLY the commit message, nothing else.`}function fy(n,e,t){let s=n.map(r=>`- ${r.message}`).join(`
|
|
59
59
|
`);return`Generate a comprehensive Pull Request description.
|
|
60
60
|
|
|
61
61
|
Base branch: ${e}
|
|
@@ -77,7 +77,7 @@ Format:
|
|
|
77
77
|
## Notes
|
|
78
78
|
(Any additional context)
|
|
79
79
|
|
|
80
|
-
Generate ONLY the PR description in markdown.`}function
|
|
80
|
+
Generate ONLY the PR description in markdown.`}function py(n,e){let t=n.map(s=>`- ${s.hash.substring(0,7)} ${s.message} (${s.author})`).join(`
|
|
81
81
|
`);return`Generate a changelog entry for version ${e} from these commits.
|
|
82
82
|
|
|
83
83
|
Commits:
|
|
@@ -98,9 +98,9 @@ Format:
|
|
|
98
98
|
### Removed
|
|
99
99
|
- (removed features)
|
|
100
100
|
|
|
101
|
-
Only include sections that have entries. Generate ONLY the changelog markdown.`}function
|
|
102
|
-
`)}var
|
|
103
|
-
`)}var W,G,Ai=
|
|
101
|
+
Only include sections that have entries. Generate ONLY the changelog markdown.`}function hy(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 xc,Sc,Zt,en=F(()=>{"use strict";xc=require("child_process"),Sc=require("util"),Zt=(0,Sc.promisify)(xc.exec)});var Cc={};Ee(Cc,{detectFramework:()=>_c,detectLanguage:()=>kc,detectPackageManager:()=>Ac,formatWorkspaceInfo:()=>_i,getGitBranch:()=>$c,scanWorkspace:()=>xs});function _c(n){let e=G.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(G.join(n,"requirements.txt"))||W.existsSync(G.join(n,"pyproject.toml")))try{let t=W.existsSync(G.join(n,"requirements.txt"))?W.readFileSync(G.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(G.join(n,"Cargo.toml")))try{if(W.readFileSync(G.join(n,"Cargo.toml"),"utf-8").includes("actix"))return"rust-actix"}catch{}if(W.existsSync(G.join(n,"go.mod")))try{if(W.readFileSync(G.join(n,"go.mod"),"utf-8").includes("fiber"))return"go-fiber"}catch{}return"unknown"}function Ac(n){return W.existsSync(G.join(n,"pnpm-lock.yaml"))?"pnpm":W.existsSync(G.join(n,"yarn.lock"))?"yarn":W.existsSync(G.join(n,"bun.lockb"))?"bun":W.existsSync(G.join(n,"package-lock.json"))?"npm":W.existsSync(G.join(n,"Cargo.toml"))?"cargo":W.existsSync(G.join(n,"go.mod"))?"go":W.existsSync(G.join(n,"requirements.txt"))||W.existsSync(G.join(n,"pyproject.toml"))?"pip":"unknown"}function kc(n){return W.existsSync(G.join(n,"tsconfig.json"))?"TypeScript":W.existsSync(G.join(n,"package.json"))?"JavaScript":W.existsSync(G.join(n,"Cargo.toml"))?"Rust":W.existsSync(G.join(n,"go.mod"))?"Go":W.existsSync(G.join(n,"pyproject.toml"))||W.existsSync(G.join(n,"requirements.txt"))?"Python":"Unknown"}function $c(n){let e=G.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 xs(n){let e=_c(n),t=Ac(n),s=kc(n),r=$c(n),i=W.existsSync(G.join(n,"Dockerfile"))||W.existsSync(G.join(n,"docker-compose.yml"))||W.existsSync(G.join(n,"docker-compose.yaml")),o=W.existsSync(G.join(n,".github","workflows"))||W.existsSync(G.join(n,".gitlab-ci.yml"))||W.existsSync(G.join(n,"Jenkinsfile")),a=W.existsSync(G.join(n,"__tests__"))||W.existsSync(G.join(n,"tests"))||W.existsSync(G.join(n,"test"))||W.existsSync(G.join(n,"spec")),l=W.existsSync(G.join(n,".git")),c=[],u=[".env",".env.local",".env.development",".env.production",".env.example"];for(let g of u)W.existsSync(G.join(n,g))&&c.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(G.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(G.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:c,configFiles:f,entryPoints:m}}function _i(n){let e=[` Project: ${G.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,G,Ai=F(()=>{"use strict";W=O(require("fs")),G=O(require("path"))});function Ec(){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,47 +181,46 @@ 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
|
|
185
|
-
`)}function
|
|
186
|
-
`)}function
|
|
187
|
-
`)}function
|
|
188
|
-
${(n==="Hablas"?
|
|
189
|
-
`)}function
|
|
190
|
-
`)}function
|
|
191
|
-
`)}function
|
|
192
|
-
`),t=[],s=!1,r="",i=[];for(let o of e){if(o.trimStart().startsWith("```")){s?(t.push(...
|
|
193
|
-
`))}return s&&i.length>0&&t.push(...
|
|
184
|
+
`.trim()}var Tc=F(()=>{"use strict"});function my(){try{let n=Pc.resolve(__dirname,"..","..","package.json");return JSON.parse(Oc.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function ae(n,e){return Ic||!tn?n:`${e}${n}\x1B[0m`}function gy(n){let e=$t();if(!n)return d.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 d.border("\u2500".repeat(r))+" "+n+" "+d.border("\u2500".repeat(i))}function yy(n,e=2){let t=$t()-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
|
+
`)}function by(n){let e=Math.max(...n.map(([t])=>t.length));return n.map(([t,s])=>` ${d.muted(t.padEnd(e))} ${s}`).join(`
|
|
186
|
+
`)}function vy(n){if(Ic||!tn)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 Dc(n,e){let t=$t(),s=e?e.replace(Ci.homedir(),"~"):"",r=d.border("\u2554"+"\u2550".repeat(t-2)+"\u2557"),i=d.border("\u2560"+"\u2550".repeat(t-2)+"\u2563"),o=d.border("\u255A"+"\u2550".repeat(t-2)+"\u255D"),a="H A B L A S A I",l="EXECUTIVE SYSTEM COORDINATOR",c="developed by abdulmoin hablas",u=Math.max(0,Math.floor((t-2-a.length)/2)),f=d.border("\u2551")+" ".repeat(u)+d.strong(a)+" ".repeat(t-2-a.length-u)+d.border("\u2551"),h=Math.max(0,Math.floor((t-2-l.length)/2)),m=d.border("\u2551")+" ".repeat(h)+d.secondary(l)+" ".repeat(t-2-l.length-h)+d.border("\u2551"),p=Math.max(0,Math.floor((t-2-c.length)/2)),g=d.border("\u2551")+" ".repeat(p)+d.muted(c)+" ".repeat(t-2-c.length-p)+d.border("\u2551"),x=d.muted(`SYSTEM VERSION: v${Mc}`),S=d.warning(`CORE MODEL: ${n}`);return["",r,f,m,c?g:"",i,` ${d.muted("\u25B8")} ${x}`,` ${d.muted("\u25B8")} ${S}`,s?` ${d.muted("\u25B8")} ${d.muted(`WORKSPACE: ${s}`)}`:"",` ${d.chrome("\u251C"+"\u2500".repeat(t-2)+"\u2524")}`,` ${d.muted(" \u203A")} ${d.secondary("Type naturally to get started")}`,` ${d.muted(" \u203A")} ${d.secondary("/help for commands \xB7 Ctrl+C to cancel \xB7 Ctrl+C\xD72 to exit")}`,o,""].filter(Boolean).join(`
|
|
187
|
+
`)}function Cn(n,e){return`
|
|
188
|
+
${(n==="Hablas"?d.leader:n==="Bob"?d.architect:n==="Alex"?d.engineer:n==="David"?d.analyst:n==="Emma"?d.product:d.primary)("\u25C6")} ${d.strong(n)} ${d.muted(`[${e.toUpperCase()}]`)}`}function Fc(n,e,t,s){let r=n==="Hablas"?d.leader:n==="Bob"?d.architect:n==="Alex"?d.engineer:n==="David"?d.analyst:n==="Emma"?d.product:d.primary,i=e==="Hablas"?d.leader:e==="Bob"?d.architect:e==="Alex"?d.engineer:e==="David"?d.analyst:e==="Emma"?d.product:d.primary,o=[];if(o.push(""),o.push(` ${r("\u2605")} ${r(n)} ${d.muted("\u2192")} ${d.strong("Delegating to")} ${i(`@${e}`)} ${d.muted(`(${t})`)}`),s){let a=s.length>80?s.slice(0,80)+"...":s;o.push(` ${d.muted(" \u2517")} ${d.secondary(a)}`)}return o.push(""),o.join(`
|
|
189
|
+
`)}function Nc(){let n=$t();return["",d.chrome("\u256D"+"\u2500".repeat(n-2)+"\u256E"),` ${d.strong("Abdulmoin Hablas")} ${d.muted("\u2014 Full-Stack Developer")}`,d.chrome("\u251C"+"\u2500".repeat(n-2)+"\u2524"),"",` ${d.accent("\u25C6")} ${d.primary("Portfolio")} ${d.muted("https://portfolio-monopoly63s-projects.vercel.app/")}`,` ${d.accent("\u25C6")} ${d.primary("GitHub")} ${d.muted("https://github.com/Monopoly63?tab=repositories")}`,` ${d.accent("\u25C6")} ${d.primary("Telegram")} ${d.muted("https://t.me/Hablas_Trade")}`,` ${d.accent("\u25C6")} ${d.primary("WhatsApp")} ${d.muted("https://wa.me/13232128875")}`,` ${d.accent("\u25C6")} ${d.primary("Instagram")} ${d.muted("https://www.instagram.com/li0vy_")}`,"",d.chrome("\u251C"+"\u2500".repeat(n-2)+"\u2524"),` ${d.strong("Projects")}`,"",` ${d.muted("\u25B8")} AI Search Engine ${d.muted("\u2192")} ${d.highlight("https://ai-search-engine-ashy.vercel.app/")}`,` ${d.muted("\u25B8")} Trade Tracker ${d.muted("\u2192")} ${d.highlight("https://trade-tracker-monopoly63s-projects.vercel.app/")}`,` ${d.muted("\u25B8")} Tree Algo Lab ${d.muted("\u2192")} ${d.highlight("https://tree-algorithms-lab.vercel.app/")}`,"",d.chrome("\u2570"+"\u2500".repeat(n-2)+"\u256F"),""].join(`
|
|
190
|
+
`)}function jc(){return["",` ${vy("\u25C6 hablas")} ${d.success(`v${Mc}`)}`,"",` ${d.muted("Runtime")} ${d.secondary(`Node.js ${process.version}`)}`,` ${d.muted("Platform")} ${d.secondary(`${process.platform} ${process.arch}`)}`,` ${d.muted("Author")} ${d.secondary("Abdulmoin Hablas")}`,` ${d.muted("License")} ${d.secondary("MIT")}`,""].join(`
|
|
191
|
+
`)}function Rc(n,e){let t=Math.min($t()-8,60),s=e?` ${d.accent(e)} `:"",r=`${d.error("\u25CF")} ${d.warning("\u25CF")} ${d.success("\u25CF")}`,i=` ${d.chrome("\u250C"+"\u2500".repeat(4))} ${r} ${d.chrome("\u2500".repeat(Math.max(0,t-10-(e?e.length+2:0))))}${s}`,o=String(n.length).length,a=n.map((c,u)=>{let f=d.lineNum(String(u+1).padStart(o)+" \u2502 "),h=d.codeBlock(c);return` ${d.chrome("\u2502")} ${f}${h}`}),l=` ${d.chrome("\u2514"+"\u2500".repeat(t))}`;return[i,...a,l]}function En(n){let e=n.split(`
|
|
192
|
+
`),t=[],s=!1,r="",i=[];for(let o of e){if(o.trimStart().startsWith("```")){s?(t.push(...Rc(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(` ${d.strong(d.primary(l))}`);continue}if(/^[-*]\s/.test(o.trim())){let l=o.trim().slice(2),c=ki(l);t.push(` ${d.accent("\u25B8")} ${c}`);continue}if(/^\d+\.\s/.test(o.trim())){let l=o.trim().match(/^(\d+)\.\s(.+)/);if(l){t.push(` ${d.muted(l[1]+".")} ${ki(l[2])}`);continue}}if(!o.trim()){t.push("");continue}let a=yy(ki(o),2);t.push(...a.split(`
|
|
193
|
+
`))}return s&&i.length>0&&t.push(...Rc(i,r)),`
|
|
194
194
|
`+t.join(`
|
|
195
195
|
`)+`
|
|
196
|
-
`}function ki(n){let e=n.replace(/`([^`]+)`/g,(t,s)=>
|
|
197
|
-
`),t=[];for(let s of e)s.startsWith("+++")||s.startsWith("---")?t.push(` ${
|
|
198
|
-
`)}function
|
|
199
|
-
`+
|
|
200
|
-
`}function
|
|
201
|
-
${
|
|
202
|
-
`+
|
|
203
|
-
${
|
|
204
|
-
|
|
205
|
-
`+
|
|
206
|
-
|
|
207
|
-
`+
|
|
208
|
-
`}function Uc(){let n
|
|
209
|
-
`+
|
|
210
|
-
${
|
|
196
|
+
`}function ki(n){let e=n.replace(/`([^`]+)`/g,(t,s)=>d.highlight(s));return e=e.replace(/\*\*([^*]+)\*\*/g,(t,s)=>d.strong(d.primary(s))),e=e.replace(/\*([^*]+)\*/g,(t,s)=>`\x1B[3m${s}\x1B[23m`),e}function Ei(n){let e=n.split(`
|
|
197
|
+
`),t=[];for(let s of e)s.startsWith("+++")||s.startsWith("---")?t.push(` ${d.muted(s)}`):s.startsWith("+")?t.push(` ${d.added(s)}`):s.startsWith("-")?t.push(` ${d.removed(s)}`):s.startsWith("@@")?t.push(` ${d.hunk(s)}`):s.trim()&&t.push(` ${d.muted(s)}`);return t.join(`
|
|
198
|
+
`)}function Hc(n){let e=new Date().toLocaleTimeString("en",{hour:"2-digit",minute:"2-digit"}),t=`${d.accent("\u25C6")} ${d.strong(d.primary(`Turn #${n}`))} ${d.muted(`\xB7 ${e} \xB7`)}`;return`
|
|
199
|
+
`+gy(t)+`
|
|
200
|
+
`}function Ae(n){return` ${d.error("\u2717")} ${n}`}function Ss(n,e){return` ${d.error("\u2717")} ${n}
|
|
201
|
+
${d.warning("\u2192")} ${d.muted(e)}`}function Y(n){return` ${d.success("\u2713")} ${n}`}function ye(n){return` ${d.muted(n)}`}function B(n){return` ${d.warning("\u26A0")} ${n}`}function wy(n,e){let s=Math.round(Math.min(n,e)/Math.max(e,1)*16),r=e>0?n/e:0;return(r>.85?d.error:r>.6?d.warning:d.success)("\u2588".repeat(s))+d.muted("\u2591".repeat(16-s))}function Bc(n){let e=$t(),t=n.connected?d.success("\u25CF connected"):d.error("\u25CB offline"),s=wy(n.cacheTokens,n.budgetTokens),r=[["model",d.highlight(n.model)],["mindset",d.accent(n.mindset||"coder")],["host",d.muted(n.host)],["directory",d.muted(n.directory.replace(Ci.homedir(),"~"))],["context",`${s} ${d.muted(`${n.cacheFiles} files \xB7 ${n.cacheTokens}/${n.budgetTokens} tokens`)}`],["turns",d.muted(String(n.turnCount))],["status",t]];return`
|
|
202
|
+
`+d.chrome("\u256D"+"\u2500".repeat(e-2)+"\u256E")+`
|
|
203
|
+
${d.accent("\u2726")} ${d.strong("Status")}
|
|
204
|
+
|
|
205
|
+
`+by(r)+`
|
|
206
|
+
|
|
207
|
+
`+d.chrome("\u2570"+"\u2500".repeat(e-2)+"\u256F")+`
|
|
208
|
+
`}function Uc(){let n=$t(),e=Math.max(...$i.map(r=>r.cmd.length+(r.arg?r.arg.length+1:0))),t=$i.map(({cmd:r,arg:i,desc:o})=>{let a=r.length+(i?i.length+1:0),l=" ".repeat(e-a+3);return` ${d.primary(r)}${i?" "+d.muted(i):""}${l}${d.secondary(o)}`}),s=["",` ${d.accent("\u2726")} ${d.strong("Tips")}`,"",` ${d.muted("\u25B8")} Use ${d.highlight("#filename")} to reference files inline`,` ${d.muted("\u25B8")} Press ${d.highlight("Ctrl+C")} once to cancel current operation`,` ${d.muted("\u25B8")} Press ${d.highlight("Ctrl+C\xD72")} quickly to exit CLI`,` ${d.muted("\u25B8")} Use ${d.highlight("--auto")} flag to skip tool confirmations`,` ${d.muted("\u25B8")} All file edits are backed up to ${d.muted("~/.hablas/backup/")}`,` ${d.muted("\u25B8")} Complex tasks \u2192 Hablas creates a plan \u2192 approve/edit \u2192 execute`];return`
|
|
209
|
+
`+d.chrome("\u256D"+"\u2500".repeat(n-2)+"\u256E")+`
|
|
210
|
+
${d.accent("\u2726")} ${d.strong("Commands")}
|
|
211
211
|
|
|
212
212
|
`+t.join(`
|
|
213
213
|
`)+`
|
|
214
214
|
`+s.join(`
|
|
215
215
|
`)+`
|
|
216
216
|
|
|
217
|
-
`+
|
|
218
|
-
`}function
|
|
219
|
-
`)}
|
|
220
|
-
`)}
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
`)
|
|
224
|
-
`)}function zc(n){return`The following tests are failing. Analyze the error output and fix the code.
|
|
217
|
+
`+d.chrome("\u2570"+"\u2500".repeat(n-2)+"\u256F")+`
|
|
218
|
+
`}function qc(n,e){let t=$t(),s=[];s.push(""),s.push(` ${d.chrome("\u256D"+"\u2500".repeat(t-4)+"\u256E")}`),s.push(` ${d.chrome("\u2502")} ${d.leader("\u2605")} ${d.strong("Hablas")} ${d.muted("\u2014 Execution Plan")}${" ".repeat(Math.max(0,t-35))}${d.chrome("\u2502")}`);let r=20,i=Math.round(e.percent/100*r),o=r-i,a=d.success("\u2588".repeat(i))+d.muted("\u2591".repeat(o));s.push(` ${d.chrome("\u2502")} ${a} ${d.muted(`${e.percent}%`)} ${d.muted(`(${e.done}/${e.total} tasks)`)}`),s.push(` ${d.chrome("\u251C"+"\u2500".repeat(t-4)+"\u2524")}`);for(let l=0;l<n.tasks.length;l++){let c=n.tasks[l],u=Sy[c.status](xy[c.status]),h=(c.assignee==="hablas"?d.leader:c.assignee==="bob"?d.architect:c.assignee==="alex"?d.engineer:c.assignee==="david"?d.analyst:c.assignee==="emma"?d.product:d.muted)(`@${c.assigneeName}`),m="";c.dependent_task_ids.length>0&&(m=d.muted(` \u2190 [${c.dependent_task_ids.join(", ")}]`));let p=d.secondary(c.description);s.push(` ${d.chrome("\u2502")} ${u} ${d.muted(`${c.task_id}.`)} ${h} ${d.muted("\u2192")} ${p}${m}`)}return s.push(` ${d.chrome("\u251C"+"\u2500".repeat(t-4)+"\u2524")}`),s.push(` ${d.chrome("\u2502")} ${d.muted("Strategy:")} ${d.highlight(n.strategy)} ${d.muted("\xB7")} ${d.muted(`${n.tasks.length} tasks`)}`),s.push(` ${d.chrome("\u2570"+"\u2500".repeat(t-4)+"\u256F")}`),s.push(""),s.join(`
|
|
219
|
+
`)}var Ci,Oc,Pc,Mc,tn,Ic,Lc,$t,d,nt,$i,xy,Sy,Ti,nn=F(()=>{"use strict";Ci=O(require("os")),Oc=O(require("fs")),Pc=O(require("path"));Mc=my(),tn=process.stdout.isTTY===!0,Ic=process.env.NO_COLOR!==void 0||process.env.TERM==="dumb",Lc=process.stdout.columns||80;tn&&process.stdout.on("resize",()=>{Lc=process.stdout.columns||80});$t=()=>Math.min(Lc-4,100);d={primary:n=>ae(n,"\x1B[38;5;253m"),secondary:n=>ae(n,"\x1B[38;5;247m"),muted:n=>ae(n,"\x1B[38;5;242m"),strong:n=>ae(n,"\x1B[1;38;5;255m"),accent:n=>ae(n,"\x1B[38;5;145m"),highlight:n=>ae(n,"\x1B[38;5;231m"),success:n=>ae(n,"\x1B[38;5;108m"),error:n=>ae(n,"\x1B[38;5;167m"),warning:n=>ae(n,"\x1B[38;5;179m"),info:n=>ae(n,"\x1B[38;5;110m"),codeBlock:n=>ae(n,"\x1B[38;5;188m"),lineNum:n=>ae(n,"\x1B[38;5;239m"),border:n=>ae(n,"\x1B[38;5;237m"),chrome:n=>ae(n,"\x1B[38;5;235m"),added:n=>ae(n,"\x1B[38;5;108m"),removed:n=>ae(n,"\x1B[38;5;167m"),hunk:n=>ae(n,"\x1B[38;5;145m"),leader:n=>ae(n,"\x1B[38;5;179m"),architect:n=>ae(n,"\x1B[38;5;250m"),engineer:n=>ae(n,"\x1B[38;5;145m"),analyst:n=>ae(n,"\x1B[38;5;108m"),product:n=>ae(n,"\x1B[38;5;180m")};nt=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(),!tn){process.stderr.write(` ${this.message}...
|
|
220
|
+
`);return}this.interval=setInterval(()=>{let e=((Date.now()-this.startTime)/1e3).toFixed(1),t=d.accent(this.frames[this.frameIndex]);process.stdout.write(`\r ${t} ${d.muted(this.message)} ${d.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(tn&&process.stdout.write("\r"+" ".repeat(80)+"\r"),e&&tn){let s=d.muted(`${t}ms`);console.log(` ${d.muted("\xB7")} ${d.secondary(e)} ${s}`)}}};$i=[{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"}];xy={pending:"\u25CB",running:"\u25C9",done:"\u2713",failed:"\u2717",skipped:"\u2013"},Sy={pending:d.muted,running:d.accent,done:d.success,failed:d.error,skipped:d.muted};Ti=$i.map(n=>n.cmd).concat(["/exit","/addmodel","/listmodels","/removemodel","/usemodel","/provider","/task","/memory","/mindset","/mindsets","/alias","/doctor","/plugins","/team","/agents","/delegate"])});function Ri(n){let e=Ve.join(n,"package.json");if(Re.existsSync(e))try{let t=JSON.parse(Re.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(Re.existsSync(Ve.join(n,"pytest.ini"))||Re.existsSync(Ve.join(n,"pyproject.toml"))||Re.existsSync(Ve.join(n,"setup.py")))try{let t=Re.existsSync(Ve.join(n,"requirements.txt"))?Re.readFileSync(Ve.join(n,"requirements.txt"),"utf-8"):"",s=Re.existsSync(Ve.join(n,"pyproject.toml"))?Re.readFileSync(Ve.join(n,"pyproject.toml"),"utf-8"):"";if(t.includes("pytest")||s.includes("pytest"))return"pytest"}catch{}return Re.existsSync(Ve.join(n,"go.mod"))?"go":Re.existsSync(Ve.join(n,"Cargo.toml"))?"cargo":"unknown"}function _y(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 Wc(n,e){let t=Ri(n),s=_y(t,e),r=Date.now(),i="",o="",a=!1;try{i=(0,Kc.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:c,passedTests:u,failedTests:f,failedTestNames:h}=Ay(i+`
|
|
221
|
+
`+o,t);return{framework:t,command:s,passed:a,output:i.slice(0,5e3),errorOutput:o.slice(0,3e3),totalTests:c,passedTests:u,failedTests:f,duration:l,failedTestNames:h}}function Ay(n,e){let t=0,s=0,r=0,i=[],o=n.split(`
|
|
222
|
+
`);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 u=a.replace(/.*(?:✕|FAIL|✗|×)\s*/,"").trim();u&&i.push(u)}}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 c=a.match(/(\d+)\s+passed/);c&&t===0&&(s=parseInt(c[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 Gc(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(`
|
|
223
|
+
`)}function Vc(n){return`The following tests are failing. Analyze the error output and fix the code.
|
|
225
224
|
|
|
226
225
|
Test framework: ${n.framework}
|
|
227
226
|
Command: ${n.command}
|
|
@@ -241,21 +240,21 @@ Instructions:
|
|
|
241
240
|
1. Read the failing test files to understand what's expected
|
|
242
241
|
2. Read the source files being tested
|
|
243
242
|
3. Fix the source code (not the tests) to make them pass
|
|
244
|
-
4. After fixing, explain what was wrong and what you changed`}var
|
|
245
|
-
`).filter(Boolean);for(let h of f)if(!i.find(m=>m.path===h))try{let m=await ht.readFile(
|
|
246
|
-
`)}var we,ht
|
|
247
|
-
In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function
|
|
248
|
-
`),
|
|
249
|
-
`;if(
|
|
250
|
-
`));for(var
|
|
251
|
-
`);if(
|
|
243
|
+
4. After fixing, explain what was wrong and what you changed`}var Kc,Re,Ve,zc=F(()=>{"use strict";Kc=require("child_process"),Re=O(require("fs")),Ve=O(require("path"))});function As(n){let e=Buffer.from(n).toString("base64url").slice(0,16);return ke.join(ky,e)}async function Jc(n,e,t){let s=As(n);we.existsSync(s)||we.mkdirSync(s,{recursive:!0});let r=`cp_${Date.now()}`,i=[];for(let f of t){let h=ke.resolve(n,f);if(we.existsSync(h))try{let m=await ht.readFile(h,"utf-8");i.push({path:f,content:m})}catch{}}try{let f=(0,_s.execSync)("git ls-files -m",{cwd:n,encoding:"utf-8",timeout:5e3}).split(`
|
|
244
|
+
`).filter(Boolean);for(let h of f)if(!i.find(m=>m.path===h))try{let m=await ht.readFile(ke.resolve(n,h),"utf-8");i.push({path:h,content:m})}catch{}}catch{}let o,a;try{o=(0,_s.execSync)("git branch --show-current",{cwd:n,encoding:"utf-8",timeout:5e3}).trim(),a=(0,_s.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},c=ke.join(s,`${r}.json`);await ht.writeFile(c,JSON.stringify(l,null,2),"utf-8");let u=we.readdirSync(s).filter(f=>f.endsWith(".json")).sort();if(u.length>20)for(let f of u.slice(0,u.length-20))try{we.unlinkSync(ke.join(s,f))}catch{}return{id:r,label:e,timestamp:l.timestamp,fileCount:i.length,projectPath:n}}function Xc(n){let e=As(n);if(!we.existsSync(e))return[];let t=we.readdirSync(e).filter(r=>r.endsWith(".json")).sort().reverse(),s=[];for(let r of t)try{let i=JSON.parse(we.readFileSync(ke.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 Qc(n,e){let t=As(n),s=ke.join(t,`${e}.json`);if(!we.existsSync(s))return{success:!1,filesRestored:0,error:`Checkpoint ${e} not found`};try{let r=JSON.parse(await ht.readFile(s,"utf-8")),i=0;for(let o of r.files)try{let a=ke.resolve(n,o.path);await ht.mkdir(ke.dirname(a),{recursive:!0}),await ht.writeFile(a,o.content,"utf-8"),i++}catch{}return{success:!0,filesRestored:i}}catch(r){return{success:!1,filesRestored:0,error:r.message}}}function Zc(n,e){let t=As(n),s=ke.join(t,`${e}.json`);try{if(we.existsSync(s))return we.unlinkSync(s),!0}catch{}return!1}function eu(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(`
|
|
245
|
+
`)}var we,ht,ke,Yc,_s,ky,tu=F(()=>{"use strict";we=O(require("fs")),ht=O(require("fs/promises")),ke=O(require("path")),Yc=O(require("os")),_s=require("child_process"),ky=ke.join(Yc.homedir(),".hablas","checkpoints")});function mt(){}function $y(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,c=0,u=0;a<l;a++){var f=i[a];if(f.removed){if(f.value=n.join(s.slice(u,u+f.count)),u+=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(c,c+f.count);h=h.map(function(g,x){var S=s[u+x];return S.length>g.length?S:g}),f.value=n.join(h)}else f.value=n.join(t.slice(c,c+f.count));c+=f.count,f.added||(u+=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 Cy(n,e,t){return Li.diff(n,e,t)}function ks(n){"@babel/helpers - typeof";return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?ks=function(e){return typeof e}:ks=function(e){return e&&typeof Symbol=="function"&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},ks(n)}function Oi(n){return Ry(n)||Oy(n)||Py(n)||My()}function Ry(n){if(Array.isArray(n))return Pi(n)}function Oy(n){if(typeof Symbol<"u"&&Symbol.iterator in Object(n))return Array.from(n)}function Py(n,e){if(n){if(typeof n=="string")return Pi(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 Pi(n,e)}}function Pi(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 My(){throw new TypeError(`Invalid attempt to spread non-iterable instance.
|
|
246
|
+
In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function Mi(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(Iy.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]=Mi(n[i],e,t,s,r);return e.pop(),t.pop(),o}if(n&&n.toJSON&&(n=n.toJSON()),ks(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]=Mi(n[l],e,t,s,l);e.pop(),t.pop()}else o=n;return o}function Ly(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 c={};for(r.push(c);i<t.length;){var u=t[i];if(/^(\-\-\-|\+\+\+|@@)\s/.test(u))break;var f=/^(?:Index:|diff(?: -r \w+)+)\s+/.exec(u);f&&(c.index=u.substring(f[0].length).trim()),i++}for(a(c),a(c),c.hunks=[];i<t.length;){var h=t[i];if(/^(Index:|diff|\-\-\-|\+\+\+)\s/.test(h))break;if(/^@@/.test(h))c.hunks.push(l());else{if(h&&e.strict)throw new Error("Unknown line "+(i+1)+" "+JSON.stringify(h));i++}}}function a(c){var u=/^(---|\+\+\+)\s+/.exec(t[i]);if(u){var f=u[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)),c[f+"FileName"]=m,c[f+"Header"]=(h[1]||"").trim(),i++}}function l(){var c=i,u=t[i++],f=u.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]||`
|
|
247
|
+
`),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 "+(c+1));if(p!==h.oldLines)throw new Error("Removed line count did not match for hunk at line "+(c+1))}return h}for(;i<t.length;)o();return r}function Dy(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 iu(n,e){var t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};if(typeof e=="string"&&(e=Ly(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(E,A,V,q){return A===q},a=0,l=t.fuzzFactor||0,c=0,u=0,f,h;function m(E,A){for(var V=0;V<E.lines.length;V++){var q=E.lines[V],ue=q.length>0?q[0]:" ",ve=q.length>0?q.substr(1):q;if(ue===" "||ue==="-"){if(!o(A+1,s[A],ue,ve)&&(a++,a>l))return!1;A++}}return!0}for(var p=0;p<i.length;p++){for(var g=i[p],x=s.length-g.oldLines,S=0,C=u+g.oldStart-1,k=Dy(C,c,x);S!==void 0;S=k())if(m(g,C+S)){g.offset=u+=S;break}if(S===void 0)return!1;c=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 _=0;_<b.lines.length;_++){var R=b.lines[_],D=R.length>0?R[0]:" ",$=R.length>0?R.substr(1):R,M=b.linedelimiters&&b.linedelimiters[_]||`
|
|
248
|
+
`;if(D===" ")w++;else if(D==="-")s.splice(w,1),r.splice(w,1);else if(D==="+")s.splice(w,0,$),r.splice(w,0,M),w++;else if(D==="\\"){var N=b.lines[_-1]?b.lines[_-1][0]:null;N==="+"?f=!0:N==="-"&&(h=!0)}}}if(f)for(;!s[s.length-1];)s.pop(),r.pop();else h&&(s.push(""),r.push(`
|
|
249
|
+
`));for(var U=0;U<s.length-1;U++)s[U]=s[U]+r[U];return s.join("")}function Fy(n,e,t,s,r,i,o){o||(o={}),typeof o.context>"u"&&(o.context=4);var a=Cy(t,s,o);if(!a)return;a.push({value:"",lines:[]});function l(S){return S.map(function(C){return" "+C})}for(var c=[],u=0,f=0,h=[],m=1,p=1,g=function(C){var k=a[C],y=k.lines||k.value.replace(/\n$/,"").split(`
|
|
250
|
+
`);if(k.lines=y,k.added||k.removed){var v;if(!u){var b=a[C-1];u=m,f=p,b&&(h=o.context>0?l(b.lines.slice(-o.context)):[],u-=h.length,f-=h.length)}(v=h).push.apply(v,Oi(y.map(function(U){return(k.added?"+":"-")+U}))),k.added?p+=y.length:m+=y.length}else{if(u)if(y.length<=o.context*2&&C<a.length-2){var w;(w=h).push.apply(w,Oi(l(y)))}else{var _,R=Math.min(y.length,o.context);(_=h).push.apply(_,Oi(l(y.slice(0,R))));var D={oldStart:u,oldLines:m-u+R,newStart:f,newLines:p-f+R,lines:h};if(C>=a.length-2&&y.length<=o.context){var $=/\n$/.test(t),M=/\n$/.test(s),N=y.length==0&&h.length>D.oldLines;!$&&N&&t.length>0&&h.splice(D.oldLines,0,"\"),(!$&&!N||!M)&&h.push("\")}c.push(D),u=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:c}}function ou(n){if(Array.isArray(n))return n.map(ou).join(`
|
|
252
251
|
`);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(`
|
|
253
252
|
`)+`
|
|
254
|
-
`}function
|
|
255
|
-
`));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};
|
|
253
|
+
`}function Ny(n,e,t,s,r,i,o){return ou(Fy(n,e,t,s,r,i,o))}function au(n,e,t,s,r,i){return Ny(n,n,e,t,s,r,i)}var Q$,nu,su,ru,Li,Ey,Ty,Iy,Tn,Ii,lu=F(()=>{mt.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,c=e.length,u=1,f=l+c;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>=c&&g+1>=l)return a([{value:this.join(t),count:t.length}]);var x=-1/0,S=1/0;function C(){for(var y=Math.max(x,-u);y<=Math.min(S,u);y+=2){var v=void 0,b=p[y-1],w=p[y+1];b&&(p[y-1]=void 0);var _=!1;if(w){var R=w.oldPos-y;_=w&&0<=R&&R<l}var D=b&&b.oldPos+1<c;if(!_&&!D){p[y]=void 0;continue}if(!D||_&&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>=c&&g+1>=l)return a($y(o,v.lastComponent,t,e,o.useLongestToken));p[y]=v,v.oldPos+1>=c&&(S=Math.min(S,y-1)),g+1>=l&&(x=Math.max(x,y+1))}u++}if(i)(function y(){setTimeout(function(){if(u>f||Date.now()>m)return i();C()||y()},0)})();else for(;u<=f&&Date.now()<=m;){var k=C();if(k)return k}},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,c=0;l+1<i&&a+1<o&&this.equals(t[l+1],s[a+1]);)l++,a++,c++;return c&&(e.lastComponent={count:c,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("")}};Q$=new mt,nu=/^[A-Za-z\xC0-\u02C6\u02C8-\u02D7\u02DE-\u02FF\u1E00-\u1EFF]+$/,su=/\S/,ru=new mt;ru.equals=function(n,e){return this.options.ignoreCase&&(n=n.toLowerCase(),e=e.toLowerCase()),n===e||this.options.ignoreWhitespace&&!su.test(n)&&!su.test(e)};ru.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]&&nu.test(e[t])&&nu.test(e[t+2])&&(e[t]+=e[t+2],e.splice(t+1,2),t--);return e};Li=new mt;Li.tokenize=function(n){this.options.stripTrailingCr&&(n=n.replace(/\r\n/g,`
|
|
254
|
+
`));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};Ey=new mt;Ey.tokenize=function(n){return n.split(/(\S.+?[.!?])(?=\s+|$)/)};Ty=new mt;Ty.tokenize=function(n){return n.split(/([{}:;,]|\s+)/)};Iy=Object.prototype.toString,Tn=new mt;Tn.useLongestToken=!0;Tn.tokenize=Li.tokenize;Tn.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(Mi(n,null,null,r),r," ")};Tn.equals=function(n,e){return mt.prototype.equals.call(Tn,n.replace(/,([\r\n])/g,"$1"),e.replace(/,([\r\n])/g,"$1"))};Ii=new mt;Ii.tokenize=function(n){return n.slice()};Ii.join=Ii.removeEmpty=function(n){return n}});var cu={};Ee(cu,{applyDiff:()=>jy,formatDiffForDisplay:()=>Hy,generateDiff:()=>$s});function $s(n,e,t){return au(n,e,t,"original","modified")}function jy(n,e){return iu(n,e)}function Hy(n){return n.split(`
|
|
256
255
|
`).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(`
|
|
257
|
-
`)}var Di=
|
|
258
|
-
`)}function
|
|
256
|
+
`)}var Di=F(()=>{"use strict";lu()});async function Rn(n,e){let t=[],s=be.join(n,"package.json");if(le.existsSync(s))try{let o=JSON.parse(le.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=xs(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 Si(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=>le.existsSync(be.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=>le.existsSync(be.join(n,o)));if(i.length>0&&t.push(`Config: ${i.join(", ")}`),e?.context?.projectGraph)try{let o=le.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=le.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(`
|
|
257
|
+
`)}function On(n,e,t,s){let r=n+`
|
|
259
258
|
|
|
260
259
|
## Current Project
|
|
261
260
|
`+e;if(t){let i=t.getSummary();i&&(r+=`
|
|
@@ -265,14 +264,14 @@ In order to be iterable, non-array objects must have a [Symbol.iterator]() metho
|
|
|
265
264
|
## Shared Context
|
|
266
265
|
`+i)}return r+=`
|
|
267
266
|
|
|
268
|
-
`+
|
|
267
|
+
`+Ec(),r}async function By(n){try{if(!le.existsSync(Fi))return null;let t=(await Ct.readdir(Fi)).filter(f=>f.endsWith(".bak"));if(n){let f=be.basename(n);t=t.filter(h=>h.startsWith(`${f}.`))}if(t.length===0)return null;t.sort().reverse();let s=t[0],r=be.join(Fi,s),i=s.replace(".bak","").split("."),o=parseInt(i[i.length-1],10),a=i.slice(0,-1).join("."),l=Date.now()-o,c=Math.floor(l/6e4),u=c<1?"just now":c<60?`${c} minutes ago`:`${Math.floor(c/60)} hours ago`;return{backupPath:r,originalName:a,age:u}}catch{return null}}async function uu(n,e,t,s,r,i,o,a,l,c,u,f,h,m,p,g,x){let S=n.split(/\s+/),C=S[0],k=S.slice(1).join(" ");switch(C){case"/quit":case"/exit":return"quit";case"/help":console.log(Uc()),console.log(d.muted(" Model & Provider:")),console.log(d.muted(" /addmodel Interactive wizard to add a custom API")),console.log(d.muted(" /listmodels Show saved providers")),console.log(d.muted(" /removemodel <name> Remove a saved provider")),console.log(d.muted(" /usemodel <name> Switch to a saved provider")),console.log(d.muted(" /models [page|search] Browse all available models")),console.log(d.muted(" /provider Show/switch API provider")),console.log(),console.log(d.muted(" Aliases & Plugins:")),console.log(d.muted(" /alias Show all aliases")),console.log(d.muted(" /alias set <n> <cmd> Create an alias")),console.log(d.muted(" /alias del <name> Remove an alias")),console.log(d.muted(" /plugins List installed plugins")),console.log(d.muted(" /doctor Run system diagnostics")),console.log(),console.log(d.muted(" Task & Memory:")),console.log(d.muted(" /task add <desc> Add a task to the queue")),console.log(d.muted(" /task list Show all tasks")),console.log(d.muted(" /task clear Clear task queue")),console.log(d.muted(" /memory Show project memory")),console.log(d.muted(" /memory set <k> <v> Store a memory")),console.log(d.muted(" /memory del <key> Delete a memory")),console.log(d.muted(" /memory clear Clear all memory")),console.log(),console.log(d.muted(" Multi-Agent & Tools:")),console.log(d.muted(" /team Show team roster")),console.log(d.muted(" /delegate <agent> <t> Manually assign task to agent")),console.log(d.muted(" /agents Multi-agent system control")),console.log(d.muted(" /agents on|off Enable/disable multi-agent")),console.log(d.muted(" /agents status Show agent details")),console.log(d.muted(" /security Run security scan")),console.log(d.muted(" /git status Show git status")),console.log(d.muted(" /workspace Show workspace info")),console.log(d.muted(" /stats Show usage analytics")),console.log();break;case"/about":console.log(Nc());break;case"/version":console.log(jc());break;case"/team":{console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Team Roster")}`),console.log(),console.log(ci()),console.log();break}case"/model":if(k){let y=await t.listModels();t.setModel(k),y.includes(k)?console.log(Y(`Model: ${k}`)):console.log(B(`Model set to "${k}" (not found locally)`))}else console.log(ye(`Current model: ${t.getModel()}`)),console.log(d.muted(" Usage: /model <name>"));break;case"/models":{let y=k.trim(),v=1,b="";if(y){let A=parseInt(y);!isNaN(A)&&A>0?v=A:b=y.toLowerCase()}let w=new nt("Fetching models");w.start();let _=await t.listModels();if(w.stop(_.length>0?`${_.length} found`:void 0),_.length===0){console.log(B("No models found \u2014 check your connection")),console.log(d.muted(" Use /provider test to verify"));break}let R=_;if(b&&(R=_.filter(A=>A.toLowerCase().includes(b)),R.length===0)){console.log(B(`No models matching: "${b}"`)),console.log(d.muted(` ${_.length} models available. Try a different search.`));break}let D=20,$=Math.ceil(R.length/D),M=Math.max(1,Math.min(v,$)),N=(M-1)*D,U=N+D,E=R.slice(N,U);console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Available Models")} ${d.muted(`(${R.length} total \xB7 page ${M}/${$})`)}`),console.log();for(let A=0;A<E.length;A++){let V=N+A+1,ue=E[A]===t.getModel()?` ${d.success("\u25CF active")}`:"";console.log(` ${d.muted(String(V).padStart(3," "))}. ${d.secondary(E[A])}${ue}`)}console.log(),$>1&&console.log(d.muted(` /models ${M<$?M+1:1} \u2014 next page`)),b&&console.log(d.muted(` Filtered: ${R.length} of ${_.length} (query: "${b}")`)),console.log(d.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(`
|
|
269
268
|
${v.output}
|
|
270
|
-
`)}break}case"/status":{let
|
|
271
|
-
${
|
|
272
|
-
`),console.log(u.muted(" ~/.hablas/config.json")),console.log();break;case"/mindset":{if(!c){console.log(U("Mindset system not available"));break}if(A)if(c.setActive(A)){let v=c.getActive(),b=await Cn(o,e),w=Rn(v.systemPrompt,b,f,m);i.updateSystemPrompt(w),console.log(Y(`Mindset: ${v.name} \u2014 ${v.description}`))}else{let v=c.listNames().join(", ");console.log(vs(`Unknown mindset: "${A}"`,`Available: ${v}`))}else{let g=c.getActive();g&&console.log(ye(`Current mindset: ${g.name} \u2014 ${g.description}`)),console.log(u.muted(" Usage: /mindset <name>")),console.log(u.muted(" See /mindsets for available options"))}break}case"/mindsets":{if(!c){console.log(U("Mindset system not available"));break}let g=c.list(),v=c.getActiveName();console.log();for(let b of g){let x=b.name===v?u.success(" \u25CF active"):"";console.log(` ${u.accent("\u25C6")} ${u.primary(b.name)}${x}`),console.log(` ${u.muted(b.description)}`)}console.log(),console.log(u.muted(" Switch: /mindset <name>")),console.log();break}case"/task":{if(!d){console.log(U("Task queue not available"));break}let g=_[1],v=_.slice(2).join(" ");switch(g){case"add":if(v){let b=d.add(v);console.log(Y(`Task #${b.id} added: ${v}`))}else console.log(U("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(Y(`Task #${b} marked as done`))):console.log(U("Usage: /task done <id>"));break}case"fail":{let b=parseInt(v);b?(d.fail(b,"Manually marked as failed"),console.log(U(`Task #${b} marked as failed`))):console.log(U("Usage: /task fail <id>"));break}case"clear":d.clear(),console.log(Y("Task queue cleared"));break;default:console.log(),console.log(d.render()),console.log(),console.log(u.muted(" /task add <desc> \u2014 Add a task")),console.log(u.muted(" /task list \u2014 Show all tasks")),console.log(u.muted(" /task done <id> \u2014 Mark task as done")),console.log(u.muted(" /task fail <id> \u2014 Mark task as failed")),console.log(u.muted(" /task clear \u2014 Clear all tasks")),console.log()}break}case"/addmodel":{console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Add Custom API Provider")}`),console.log();let v=(await a.prompt(` ${u.muted("Provider name (e.g. OpenAI, Groq):")} `)).trim();if(!v){console.log(U("Cancelled \u2014 name is required"));break}let w=(await a.prompt(` ${u.muted("API URL (e.g. https://api.openai.com/v1):")} `)).trim();if(!w){console.log(U("Cancelled \u2014 URL is required"));break}let T=(await a.prompt(` ${u.muted("API Key (leave empty if none):")} `)).trim(),$=(await a.prompt(` ${u.muted("Default model ID (e.g. gpt-4o):")} `)).trim()||"default",F={name:v,apiUrl:w,apiKey:T,models:[$],defaultModel:$,addedAt:new Date().toISOString()};Ge(F),console.log(),console.log(Y(`Provider "${v}" saved!`)),console.log(u.muted(` Use: /usemodel ${v}`)),console.log();break}case"/listmodels":{let g=Lt();console.log(),console.log(Zl(g.providers,g.activeProvider));break}case"/removemodel":{let g=A.trim();if(!g){console.log(U("Usage: /removemodel <provider-name>"));break}if(Jl(g))console.log(Y(`Provider "${g}" removed`));else{console.log(U(`Provider "${g}" not found`));let b=os();b.length>0&&console.log(u.muted(` Available: ${b.map(w=>w.name).join(", ")}`))}break}case"/usemodel":{let g=A.trim();if(!g){console.log(U("Usage: /usemodel <provider-name> [model-id]"));let F=os();F.length>0&&console.log(u.muted(` Available: ${F.map(j=>j.name).join(", ")}`));break}let v=g.split(/\s+/),b=v[0],w=v[1],x=Ql(b);if(!x){console.log(U(`Provider "${b}" not found`));let F=os();F.length>0&&console.log(u.muted(` Available: ${F.map(j=>j.name).join(", ")}`));break}e.provider="custom",e.apiUrl=x.apiUrl,e.apiKey=x.apiKey,e.model=w||x.defaultModel;let T=We(e);h&&h(T),Xl(x.name,e.model),console.log(Y(`Switched to ${x.name} \xB7 Model: ${e.model}`));let P=new kt("Testing");P.start();let $=await T.checkConnection();P.stop($?"connected":void 0),$||console.log(U("Connection test failed \u2014 check URL and key"));break}case"/provider":{let g=_[1],v=_.slice(2).join(" ");if(!g){let b=Vl(e);console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Provider")}: ${b}`),console.log(` ${u.muted("Model")}: ${u.highlight(t.getModel())}`),e.provider==="custom"?(console.log(` ${u.muted("API URL")}: ${e.apiUrl}`),console.log(` ${u.muted("API Key")}: ${e.apiKey?"***"+e.apiKey.slice(-4):"not set"}`)):console.log(` ${u.muted("Host")}: ${e.ollamaHost}`),console.log(),console.log(u.muted(" /provider ollama \u2014 Switch to local Ollama")),console.log(u.muted(" /provider nvidia <key> \u2014 Switch to NVIDIA NIM")),console.log(u.muted(" /provider custom <url> [key] \u2014 Switch to custom API")),console.log(u.muted(" /provider test \u2014 Test current connection")),console.log();break}switch(g){case"ollama":{e.provider="ollama",e.apiUrl="",e.apiKey="";let b=We(e);h&&h(b),console.log(Y("Switched to Ollama (local)"));break}case"nvidia":{let b=_[2];if(!b&&!e.apiKey){console.log(U("Usage: /provider nvidia <api-key>")),console.log(u.muted(" Get your key at: https://build.nvidia.com/"));break}e.provider="nvidia",e.apiUrl=At.apiUrl,b&&(e.apiKey=b),(!e.model||!At.models.includes(e.model))&&(e.model=At.defaultModel);let w=We(e);h&&h(w),console.log(Y(`Switched to NVIDIA NIM \xB7 Model: ${e.model}`)),console.log(u.muted(` Available models: ${At.models.length}`));let x=new kt("Testing NVIDIA connection");x.start();let T=await w.checkConnection();x.stop(T?"connected":void 0),T||(console.log(U("Connection test failed \u2014 check your API key")),console.log(u.muted(" Get key: https://build.nvidia.com/")));break}case"custom":{let b=_[2],w=_[3];if(!b){console.log(U("Usage: /provider custom <api-url> [api-key]")),console.log(u.muted(" Example: /provider custom https://api.openai.com/v1 sk-..."));break}e.provider="custom",e.apiUrl=b,w&&(e.apiKey=w);let x=We(e);h&&h(x),console.log(Y(`Switched to Custom API: ${b}`)),!w&&!e.apiKey&&console.log(U("No API key set. Use: /provider custom <url> <key>"));break}case"test":{let b=new kt("Testing connection");b.start();let w=await t.checkConnection();if(b.stop(w?"connected":void 0),w){let x=await t.listModels();console.log(Y(`Connected! ${x.length} models available.`)),x.length>0&&console.log(u.muted(` Models: ${x.slice(0,5).join(", ")}${x.length>5?"...":""}`))}else console.log(ke("Connection failed"));break}case"key":{v?(e.apiKey=_[2],t instanceof Mt&&t.setApiKey(e.apiKey),console.log(Y("API key updated"))):console.log(U("Usage: /provider key <api-key>"));break}default:console.log(vs(`Unknown: /provider ${g}`,"Type /provider for help"))}break}case"/memory":{if(!f){console.log(U("Project memory not available"));break}let g=_[1],v=_.slice(2);switch(g){case"set":{if(v.length>=2){let b=v[0],w=v.slice(1).join(" ");f.set(b,w),console.log(Y(`Memory stored: ${b}`));let x=c?.getActive(),T=x?x.systemPrompt:As,P=await Cn(o,e);i.updateSystemPrompt(Rn(T,P,f,m))}else console.log(U("Usage: /memory set <key> <value>"));break}case"del":case"delete":{if(v[0]){let b=f.delete(v[0]);console.log(b?Y(`Memory deleted: ${v[0]}`):U(`Memory key not found: ${v[0]}`))}else console.log(U("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(ye("No matching memories found"))}else console.log(U("Usage: /memory search <query>"));break}case"clear":f.clear(),console.log(Y("Project memory cleared"));break;default:console.log(),console.log(f.render()),console.log(),console.log(u.muted(" /memory set <k> <v> \u2014 Store a memory")),console.log(u.muted(" /memory del <key> \u2014 Delete a memory")),console.log(u.muted(" /memory search <q> \u2014 Search memories")),console.log(u.muted(" /memory clear \u2014 Clear all")),console.log()}break}case"/alias":{let g=_[1],v=_.slice(2);switch(g){case"set":{if(v.length>=2){let b=v[0],w=v.slice(1).join(" ");nc(b,w),console.log(Y(`Alias set: ${b} \u2192 ${w}`))}else console.log(U("Usage: /alias set <name> <expansion>"));break}case"del":case"remove":{if(v[0]){let b=sc(v[0]);console.log(b?Y(`Alias removed: ${v[0]}`):U(`Alias not found: ${v[0]}`))}else console.log(U("Usage: /alias del <name>"));break}default:console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Aliases")}`),console.log(),console.log(ic()),console.log(),console.log(u.muted(" /alias set <name> <cmd> \u2014 Create alias")),console.log(u.muted(" /alias del <name> \u2014 Remove alias")),console.log()}break}case"/doctor":{let g=new kt("Running diagnostics");g.start();let v=await oi({ollamaHost:e.ollamaHost,model:t.getModel(),provider:e.provider,apiUrl:e.apiUrl});g.stop(),console.log(ai(v));break}case"/plugins":{let g=_[1],v=_.slice(2).join(" ");switch(g){case"enable":v?(ti(v),console.log(Y(`Plugin "${v}" enabled`))):console.log(U("Usage: /plugins enable <name>"));break;case"disable":v?(ni(v),console.log(U(`Plugin "${v}" disabled`))):console.log(U("Usage: /plugins disable <name>"));break;default:fs(),console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Plugins")}`),console.log(),console.log(si()),console.log(),console.log(u.muted(" /plugins enable <name> \u2014 Enable plugin")),console.log(u.muted(" /plugins disable <name> \u2014 Disable plugin")),console.log(u.muted(" Directory: ~/.hablas/plugins/")),console.log()}break}case"/agents":{let g=_[1];if(g==="on")e.agents.enabled=!0,console.log(Y("Multi-agent orchestration enabled"));else if(g==="off")e.agents.enabled=!1,console.log(Y("Multi-agent orchestration disabled"));else if(g==="status")console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Multi-Agent System")}`),console.log(` Status: ${e.agents.enabled?u.success("enabled"):u.muted("disabled")}`),console.log(` Orchestration: ${e.agents.orchestration}`),console.log(` Max concurrent: ${e.agents.maxConcurrent}`),console.log(),console.log(` ${u.strong("Team:")}`),console.log(mc()),console.log();else if(g==="models"){let v=_n();console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Agent Models")}`),console.log();for(let b of he){let w=v[b.role];console.log(w?` ${u.primary(b.name.padEnd(8))} \u2192 ${u.highlight(w.model)}${w.temperature!==void 0?u.muted(` (temp: ${w.temperature})`):""}`:` ${u.primary(b.name.padEnd(8))} \u2192 ${u.muted("(default)")}`)}console.log(),console.log(u.muted(` Config: ${bc()}`)),console.log(u.muted(" Edit the file to change models per agent.")),console.log()}else console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Multi-Agent System")}: ${e.agents.enabled?u.success("ON"):u.muted("OFF")}`),console.log(),console.log(u.muted(" /agents on \u2014 Enable multi-agent orchestration")),console.log(u.muted(" /agents off \u2014 Disable multi-agent orchestration")),console.log(u.muted(" /agents status \u2014 Show agent details")),console.log(u.muted(" /agents models \u2014 Show model per agent")),console.log(u.muted(" /team \u2014 Show team roster")),console.log();break}case"/security":{console.log(),console.log(` ${u.accent("\u{1F512}")} Running security scan...`);let g=vi(o);console.log(wi(g));break}case"/git":{if(_[1]==="status")try{let{getGitStatus:v,formatGitStatus:b}=await Promise.resolve().then(()=>(Xt(),kn)),w=await v(o);w?(console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Git Status")}`),console.log(b(w)),console.log()):console.log(U("Not a git repository"))}catch{console.log(U("Git not available"))}else console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Git Intelligence")}`),console.log(),console.log(u.muted(" /git status \u2014 Show git status")),console.log(u.muted(" hablas commit \u2014 Smart commit message")),console.log(u.muted(" hablas pr \u2014 Generate PR description")),console.log(u.muted(" hablas changelog \u2014 Generate changelog")),console.log();break}case"/workspace":{let g=gs(o);console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Workspace Information")}`),console.log(),console.log(_i(g)),console.log();break}case"/stats":{let{loadStats:g,formatStats:v}=await Promise.resolve().then(()=>(An(),bi)),b=g();console.log(v(b));break}case"/context":{if(!m){console.log(U("Shared context not available"));break}let g=_[1],v=_.slice(2);switch(g){case"set":{if(v.length>=2){let b=v[0],w=v.slice(1).join(" ");m.set(b,w),console.log(Y(`Context stored: ${b}`))}else console.log(U("Usage: /context set <key> <value>"));break}case"get":{if(v[0]){let b=m.get(v[0]);b!==void 0?(console.log(),console.log(` ${u.accent("\u25C6")} ${u.strong(v[0])}: ${b}`),console.log()):console.log(U(`Context key not found: ${v[0]}`))}else console.log(U("Usage: /context get <key>"));break}case"del":case"delete":{if(v[0]){let b=m.delete(v[0]);console.log(b?Y(`Context deleted: ${v[0]}`):U(`Context key not found: ${v[0]}`))}else console.log(U("Usage: /context del <key>"));break}case"decisions":{let b=m.getDecisions();if(b.length===0)console.log(ye("No decisions logged yet"));else{console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Decisions")}`),console.log();for(let w of b)console.log(` ${u.muted(w.timestamp)} ${u.primary(w.by)}: ${w.decision}`),w.rationale&&console.log(` ${u.muted(w.rationale)}`);console.log()}break}case"clear":m.clear(),console.log(Y("Shared context cleared"));break;default:console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Shared Context")}`),console.log(),console.log(m.render()),console.log(),console.log(u.muted(" /context set <k> <v> \u2014 Store a context entry")),console.log(u.muted(" /context get <key> \u2014 Get a context entry")),console.log(u.muted(" /context del <key> \u2014 Delete a context entry")),console.log(u.muted(" /context decisions \u2014 Show logged decisions")),console.log(u.muted(" /context clear \u2014 Clear all context")),console.log()}break}case"/plan":{if(!p){console.log(U("Plan manager not available"));break}let g=_[1],v=_.slice(2).join(" ");switch(g){case"status":{let w=p.getActivePlan();if(!w){console.log(ye("No active plan"));break}let x=p.getProgress();console.log(Kc(w,{percent:x.percentage,done:x.done,total:x.total}));break}case"finish":{if(v){p.finishTask(v),console.log(Y(`Task finished: ${v}`));let w=p.getProgress();console.log(u.muted(` Progress: ${w.done}/${w.total} (${w.percentage}%)`))}else console.log(U("Usage: /plan finish <task_id>"));break}case"reset":{p.reset(),console.log(Y("Plan manager reset"));break}case"next":{let w=p.getNextTask();console.log(w?ye(`Next task: [${w.task_id}] ${w.description} \u2192 @${w.assignee}`):ye("No pending tasks"));break}default:console.log(),console.log(` ${u.accent("\u2726")} ${u.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(u.muted(" No active plan"));console.log(),console.log(u.muted(" /plan status \u2014 Show active plan with progress")),console.log(u.muted(" /plan finish <id> \u2014 Mark a task as finished")),console.log(u.muted(" /plan next \u2014 Show next pending task")),console.log(u.muted(" /plan reset \u2014 Reset plan manager")),console.log()}break}case"/learn":{if(!f||!A){console.log(U('Usage: /learn "always use tabs" or /learn "our API uses camelCase"'));break}if(f.set(`user-pref: ${A.slice(0,50)}`,A,{category:"user-pref",importance:9,createdBy:"user",tags:["user-pref","learned"]}),!(i.getMessages()[0]?.content||"").includes(A)){let v=await Cn(o,e),b=c?.getActive(),w=b?b.systemPrompt:As,x=Rn(w,v,f,m);i.updateSystemPrompt(x)}console.log(Y(`Learned: "${A}"`)),console.log(u.muted(" This will be remembered across sessions and injected into every prompt."));break}case"/test":{let g=Ri(o);if(g==="unknown"&&!A){console.log(U("No test framework detected. Install jest, vitest, pytest, etc."));break}console.log(ye(`Running tests (${g})...`));let v=Gc(o,A==="--fix"?void 0:A||void 0);if(console.log(),console.log(Vc(v)),console.log(),!v.passed&&A==="--fix"){console.log(ye("Tests failed \u2014 adding fix request to conversation..."));let b=zc(v);i.addUserMessage(b),console.log(ye("Type your next message or let the agent work on the fix."))}break}case"/checkpoint":{let g=_[1],v=_.slice(2).join(" ");if(g==="save"){let b=v||`Checkpoint at turn ${l}`,w=y?.getModifiedFiles?.()||[],x=await Qc(o,b,w);console.log(Y(`Checkpoint saved: ${x.id} "${b}" (${x.fileCount} files)`))}else if(g==="list"){let b=Xc(o);console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Checkpoints")}`),console.log(),console.log(tu(b)),console.log()}else if(g==="restore"){if(!v){console.log(U("Usage: /checkpoint restore <id>"));break}let b=await Zc(o,v);b.success?console.log(Y(`Restored checkpoint: ${v} (${b.filesRestored} files)`)):console.log(ke(b.error||"Restore failed"))}else g==="delete"?v&&eu(o,v)?console.log(Y(`Deleted checkpoint: ${v}`)):console.log(U("Checkpoint not found")):(console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Checkpoint System")}`),console.log(),console.log(u.muted(' /checkpoint save "label" \u2014 Save current state')),console.log(u.muted(" /checkpoint list \u2014 List saved checkpoints")),console.log(u.muted(" /checkpoint restore <id> \u2014 Restore a checkpoint")),console.log(u.muted(" /checkpoint delete <id> \u2014 Delete a checkpoint")),console.log());break}case"/compare":{let g=_.slice(1);if(g.length===2)try{let v=await $t.readFile(be.resolve(o,g[0]),"utf-8"),b=await $t.readFile(be.resolve(o,g[1]),"utf-8"),{generateDiff:w}=await Promise.resolve().then(()=>(Di(),uu)),x=w(g[0]+" vs "+g[1],v,b);console.log(Ti(x))}catch(v){console.log(ke(`Compare failed: ${v.message}`))}else if(g.length===1&&g[0].startsWith("HEAD"))try{let{execSync:v}=await import("child_process"),b=v(`git diff ${g[0]}`,{cwd:o,encoding:"utf-8",timeout:1e4});console.log(Ti(b||"(no changes)"))}catch(v){console.log(ke(`Git diff failed: ${v.message}`))}else console.log(u.muted(" Usage: /compare file1.ts file2.ts or /compare HEAD~1"));break}case"/cost":{let g=Jt(),v="current";console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Session Cost & Usage")}`),console.log(),console.log(` Session duration: ${v} min`),console.log(` Messages: ${g.totalMessages}`),console.log(` Tool calls: ${g.totalToolCalls}`),console.log(` Tokens used: ${g.totalTokensUsed.toLocaleString()}`),console.log();let b=Object.entries(g.agentUsage);if(b.length>0){console.log(" Agent usage:");for(let[w,x]of b.sort((T,P)=>P[1]-T[1]))console.log(` @${w}: ${x} invocations`)}console.log();break}case"/delegate":{if(!e.agents.enabled){console.log(U("Multi-agent system is disabled. Enable with /agents on"));break}let g=_[1]?.toLowerCase(),v=_.slice(2).join(" ");if(!g||!v){console.log(),console.log(` ${u.accent("\u2726")} ${u.strong("Delegate Task to Agent")}`),console.log(),console.log(u.muted(" Usage: /delegate <agent> <task description>")),console.log(),console.log(u.muted(" Agents:")),console.log(` ${u.product("emma")} \u2014 Product Manager`),console.log(` ${u.architect("bob")} \u2014 Architect`),console.log(` ${u.engineer("alex")} \u2014 Engineer`),console.log(` ${u.analyst("david")} \u2014 Data Analyst`),console.log(),console.log(u.muted(" Example: /delegate alex create a login component")),console.log();break}let b=["emma","bob","alex","david","hablas"];if(!b.includes(g)){console.log(U(`Unknown agent: "${g}". Valid: ${b.join(", ")}`));break}let w=he.find(x=>x.role===g);if(w){if(!S){console.log(U("Agent runner not initialized. Cannot delegate."));break}console.log(Nc("Hablas",w.name,w.title,v)),console.log($n(w.name,w.title));let x=s.getOllamaTools(),T=await S.runAgent(g,v,void 0,x);T.success&&T.output?(console.log(En(T.output)),i.addAssistantMessage(`[@${w.name}]: ${T.output}`)):T.error?console.log(U(`${w.name} failed: ${T.error}`)):console.log(ye(`${w.name} completed without output.`))}break}case"/session":{let g=_[1],v=_.slice(2).join(" "),b=be.join(Fi.homedir(),".hablas","sessions");if(g==="save"){let w=v||`session_${Date.now()}`;try{le.existsSync(b)||le.mkdirSync(b,{recursive:!0});let x=i.toJSON(),T=be.join(b,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);le.writeFileSync(T,x,"utf-8"),console.log(Y(`Session saved: "${w}"`))}catch(x){console.log(ke(`Save failed: ${x.message}`))}}else if(g==="list")try{if(!le.existsSync(b)){console.log(ye("No saved sessions"));break}let w=le.readdirSync(b).filter(x=>x.endsWith(".json"));console.log();for(let x of w){let T=le.statSync(be.join(b,x));console.log(` ${x.replace(".json","")} (${new Date(T.mtime).toLocaleString()})`)}console.log()}catch{console.log(ye("No saved sessions"))}else if(g==="load"){let w=v;if(!w){console.log(ke("Please specify the session label to load: /session load <label>"));break}try{let x=be.join(b,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);if(!le.existsSync(x)){console.log(ke(`Session file not found: ${w}`));break}let T=le.readFileSync(x,"utf-8");i.fromJSON(T),console.log(Y(`Session successfully loaded: "${w}"`))}catch(x){console.log(ke(`Load failed: ${x.message}`))}}else console.log(),console.log(u.muted(' /session save "label" \u2014 Save current conversation')),console.log(u.muted(" /session list \u2014 List saved sessions")),console.log(u.muted(' /session load "label" \u2014 Load saved conversation')),console.log();break}case"/team":{let{activeCollabManager:g}=await Promise.resolve().then(()=>(gt(),Et));if(!g){console.log(U("Team mode is not active. Use hablas --team to start."));break}let v=g.getLocalState(),b=Math.min(process.stdout.columns-4,80);console.log(`
|
|
273
|
-
`+
|
|
274
|
-
`),console.log(
|
|
275
|
-
`));break}case"/msg":{let{activeCollabManager:
|
|
269
|
+
`)}break}case"/status":{let y=await t.checkConnection(),v=c?c.getActiveName():"planner",b=f?f.size():0,w=u?u.getProgress():void 0;console.log(Bc({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(d.muted(` Memory entries: ${b}`)),w&&w.total>0&&console.log(d.muted(` Tasks: ${w.done}/${w.total} done`)),console.log();break}case"/clear":r.clear(),i.clear(),console.log(Y("History cleared"));break;case"/history":{let y=parseInt(k)||10,v=i.getHistory().slice(-y);if(v.length===0){console.log(ye("No history yet"));break}console.log(),v.forEach(b=>{let w=b.role==="user"?d.primary("You"):b.role==="assistant"?d.success("Hablas"):d.muted("tool"),_=b.content.slice(0,120).replace(/\n/g," ");console.log(` ${w}: ${d.muted(_)}`)}),console.log();break}case"/undo":{if(!g){let y=await By(k||void 0);if(!y){console.log(B("No backups found"));break}let v=k?be.resolve(o,k):be.resolve(o,y.originalName);if(await a.confirm(`Restore ${y.originalName} from backup (${y.age})?`))try{let w=await Ct.readFile(y.backupPath,"utf-8");await Ct.writeFile(v,w,"utf-8"),console.log(Y(`Restored ${y.originalName} from backup (${y.age})`))}catch(w){console.log(Ae(`Failed: ${w.message}`))}break}if(k==="list")console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Undo History")} (${g.getUndoableCount()} changes)`),console.log(),console.log(g.formatList(20)),console.log();else if(k==="all"){let y=g.getUndoableCount();if(y===0){console.log(ye("Nothing to undo"));break}if(await a.confirm(`Undo ALL ${y} changes?`)){let b=await g.undoAll(),w=b.filter(_=>_.success).length;console.log(Y(`Reverted ${w}/${b.length} changes`))}}else{let y=k&&parseInt(k)||1;if(g.getUndoableCount()===0){console.log(ye("Nothing to undo"));break}let v=await g.undo(y);for(let b of v)b.success?console.log(Y(`Reverted: ${b.file}`)):console.log(Ae(`Failed to revert ${b.file}: ${b.error}`))}break}case"/config":console.log(`
|
|
270
|
+
${d.muted(JSON.stringify(e,null,2))}
|
|
271
|
+
`),console.log(d.muted(" ~/.hablas/config.json")),console.log();break;case"/mindset":{if(!c){console.log(B("Mindset system not available"));break}if(k)if(c.setActive(k)){let v=c.getActive(),b=await Rn(o,e),w=On(v.systemPrompt,b,f,m);i.updateSystemPrompt(w),console.log(Y(`Mindset: ${v.name} \u2014 ${v.description}`))}else{let v=c.listNames().join(", ");console.log(Ss(`Unknown mindset: "${k}"`,`Available: ${v}`))}else{let y=c.getActive();y&&console.log(ye(`Current mindset: ${y.name} \u2014 ${y.description}`)),console.log(d.muted(" Usage: /mindset <name>")),console.log(d.muted(" See /mindsets for available options"))}break}case"/mindsets":{if(!c){console.log(B("Mindset system not available"));break}let y=c.list(),v=c.getActiveName();console.log();for(let b of y){let _=b.name===v?d.success(" \u25CF active"):"";console.log(` ${d.accent("\u25C6")} ${d.primary(b.name)}${_}`),console.log(` ${d.muted(b.description)}`)}console.log(),console.log(d.muted(" Switch: /mindset <name>")),console.log();break}case"/task":{if(!u){console.log(B("Task queue not available"));break}let y=S[1],v=S.slice(2).join(" ");switch(y){case"add":if(v){let b=u.add(v);console.log(Y(`Task #${b.id} added: ${v}`))}else console.log(B("Usage: /task add <description>"));break;case"list":console.log(),console.log(u.render()),console.log();break;case"done":{let b=parseInt(v);b?(u.complete(b),console.log(Y(`Task #${b} marked as done`))):console.log(B("Usage: /task done <id>"));break}case"fail":{let b=parseInt(v);b?(u.fail(b,"Manually marked as failed"),console.log(B(`Task #${b} marked as failed`))):console.log(B("Usage: /task fail <id>"));break}case"clear":u.clear(),console.log(Y("Task queue cleared"));break;default:console.log(),console.log(u.render()),console.log(),console.log(d.muted(" /task add <desc> \u2014 Add a task")),console.log(d.muted(" /task list \u2014 Show all tasks")),console.log(d.muted(" /task done <id> \u2014 Mark task as done")),console.log(d.muted(" /task fail <id> \u2014 Mark task as failed")),console.log(d.muted(" /task clear \u2014 Clear all tasks")),console.log()}break}case"/addmodel":{console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Add Custom API Provider")}`),console.log();let v=(await a.prompt(` ${d.muted("Provider name (e.g. OpenAI, Groq):")} `)).trim();if(!v){console.log(B("Cancelled \u2014 name is required"));break}let w=(await a.prompt(` ${d.muted("API URL (e.g. https://api.openai.com/v1):")} `)).trim();if(!w){console.log(B("Cancelled \u2014 URL is required"));break}let R=(await a.prompt(` ${d.muted("API Key (leave empty if none):")} `)).trim(),$=(await a.prompt(` ${d.muted("Default model ID (e.g. gpt-4o):")} `)).trim()||"default",M={name:v,apiUrl:w,apiKey:R,models:[$],defaultModel:$,addedAt:new Date().toISOString()};We(M),console.log(),console.log(Y(`Provider "${v}" saved!`)),console.log(d.muted(` Use: /usemodel ${v}`)),console.log();break}case"/listmodels":{let y=Nt();console.log(),console.log(Ql(y.providers,y.activeProvider));break}case"/removemodel":{let y=k.trim();if(!y){console.log(B("Usage: /removemodel <provider-name>"));break}if(Yl(y))console.log(Y(`Provider "${y}" removed`));else{console.log(B(`Provider "${y}" not found`));let b=ds();b.length>0&&console.log(d.muted(` Available: ${b.map(w=>w.name).join(", ")}`))}break}case"/usemodel":{let y=k.trim();if(!y){console.log(B("Usage: /usemodel <provider-name> [model-id]"));let M=ds();M.length>0&&console.log(d.muted(` Available: ${M.map(N=>N.name).join(", ")}`));break}let v=y.split(/\s+/),b=v[0],w=v[1],_=Jl(b);if(!_){console.log(B(`Provider "${b}" not found`));let M=ds();M.length>0&&console.log(d.muted(` Available: ${M.map(N=>N.name).join(", ")}`));break}e.provider="custom",e.apiUrl=_.apiUrl,e.apiKey=_.apiKey,e.model=w||_.defaultModel;let R=Le(e);h&&h(R),Xl(_.name,e.model),console.log(Y(`Switched to ${_.name} \xB7 Model: ${e.model}`));let D=new nt("Testing");D.start();let $=await R.checkConnection();D.stop($?"connected":void 0),$||console.log(B("Connection test failed \u2014 check URL and key"));break}case"/provider":{let y=S[1],v=S.slice(2).join(" ");if(!y){let b=Gl(e);console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Provider")}: ${b}`),console.log(` ${d.muted("Model")}: ${d.highlight(t.getModel())}`),e.provider==="custom"?(console.log(` ${d.muted("API URL")}: ${e.apiUrl}`),console.log(` ${d.muted("API Key")}: ${e.apiKey?"***"+e.apiKey.slice(-4):"not set"}`)):console.log(` ${d.muted("Host")}: ${e.ollamaHost}`),console.log(),console.log(d.muted(" /provider ollama \u2014 Switch to local Ollama")),console.log(d.muted(" /provider nvidia <key> \u2014 Switch to NVIDIA NIM")),console.log(d.muted(" /provider custom <url> [key] \u2014 Switch to custom API")),console.log(d.muted(" /provider test \u2014 Test current connection")),console.log();break}switch(y){case"ollama":{e.provider="ollama",e.apiUrl="",e.apiKey="";let b=Le(e);h&&h(b),console.log(Y("Switched to Ollama (local)"));break}case"nvidia":{let b=S[2];if(!b&&!e.apiKey){console.log(B("Usage: /provider nvidia <api-key>")),console.log(d.muted(" Get your key at: https://build.nvidia.com/"));break}e.provider="nvidia",e.apiUrl=kt.apiUrl,b&&(e.apiKey=b),(!e.model||!kt.models.includes(e.model))&&(e.model=kt.defaultModel);let w=Le(e);h&&h(w),console.log(Y(`Switched to NVIDIA NIM \xB7 Model: ${e.model}`)),console.log(d.muted(` Available models: ${kt.models.length}`));let _=new nt("Testing NVIDIA connection");_.start();let R=await w.checkConnection();_.stop(R?"connected":void 0),R||(console.log(B("Connection test failed \u2014 check your API key")),console.log(d.muted(" Get key: https://build.nvidia.com/")));break}case"custom":{let b=S[2],w=S[3];if(!b){console.log(B("Usage: /provider custom <api-url> [api-key]")),console.log(d.muted(" Example: /provider custom https://api.openai.com/v1 sk-..."));break}e.provider="custom",e.apiUrl=b,w&&(e.apiKey=w);let _=Le(e);h&&h(_),console.log(Y(`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 nt("Testing connection");b.start();let w=await t.checkConnection();if(b.stop(w?"connected":void 0),w){let _=await t.listModels();console.log(Y(`Connected! ${_.length} models available.`)),_.length>0&&console.log(d.muted(` Models: ${_.slice(0,5).join(", ")}${_.length>5?"...":""}`))}else console.log(Ae("Connection failed"));break}case"key":{v?(e.apiKey=S[2],t instanceof Ft&&t.setApiKey(e.apiKey),console.log(Y("API key updated"))):console.log(B("Usage: /provider key <api-key>"));break}default:console.log(Ss(`Unknown: /provider ${y}`,"Type /provider for help"))}break}case"/memory":{if(!f){console.log(B("Project memory not available"));break}let y=S[1],v=S.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(Y(`Memory stored: ${b}`));let _=c?.getActive(),R=_?_.systemPrompt:Pn,D=await Rn(o,e);i.updateSystemPrompt(On(R,D,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?Y(`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(ye("No matching memories found"))}else console.log(B("Usage: /memory search <query>"));break}case"clear":f.clear(),console.log(Y("Project memory cleared"));break;default:console.log(),console.log(f.render()),console.log(),console.log(d.muted(" /memory set <k> <v> \u2014 Store a memory")),console.log(d.muted(" /memory del <key> \u2014 Delete a memory")),console.log(d.muted(" /memory search <q> \u2014 Search memories")),console.log(d.muted(" /memory clear \u2014 Clear all")),console.log()}break}case"/alias":{let y=S[1],v=S.slice(2);switch(y){case"set":{if(v.length>=2){let b=v[0],w=v.slice(1).join(" ");tc(b,w),console.log(Y(`Alias set: ${b} \u2192 ${w}`))}else console.log(B("Usage: /alias set <name> <expansion>"));break}case"del":case"remove":{if(v[0]){let b=nc(v[0]);console.log(b?Y(`Alias removed: ${v[0]}`):B(`Alias not found: ${v[0]}`))}else console.log(B("Usage: /alias del <name>"));break}default:console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Aliases")}`),console.log(),console.log(rc()),console.log(),console.log(d.muted(" /alias set <name> <cmd> \u2014 Create alias")),console.log(d.muted(" /alias del <name> \u2014 Remove alias")),console.log()}break}case"/doctor":{let y=new nt("Running diagnostics");y.start();let v=await ii({ollamaHost:e.ollamaHost,model:t.getModel(),provider:e.provider,apiUrl:e.apiUrl});y.stop(),console.log(oi(v));break}case"/plugins":{let y=S[1],v=S.slice(2).join(" ");switch(y){case"enable":v?(ei(v),console.log(Y(`Plugin "${v}" enabled`))):console.log(B("Usage: /plugins enable <name>"));break;case"disable":v?(ti(v),console.log(B(`Plugin "${v}" disabled`))):console.log(B("Usage: /plugins disable <name>"));break;default:ys(),console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Plugins")}`),console.log(),console.log(ni()),console.log(),console.log(d.muted(" /plugins enable <name> \u2014 Enable plugin")),console.log(d.muted(" /plugins disable <name> \u2014 Disable plugin")),console.log(d.muted(" Directory: ~/.hablas/plugins/")),console.log()}break}case"/agents":{let y=S[1];if(y==="on")e.agents.enabled=!0,console.log(Y("Multi-agent orchestration enabled"));else if(y==="off")e.agents.enabled=!1,console.log(Y("Multi-agent orchestration disabled"));else if(y==="status")console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Multi-Agent System")}`),console.log(` Status: ${e.agents.enabled?d.success("enabled"):d.muted("disabled")}`),console.log(` Orchestration: ${e.agents.orchestration}`),console.log(` Max concurrent: ${e.agents.maxConcurrent}`),console.log(),console.log(` ${d.strong("Team:")}`),console.log(ci()),console.log();else if(y==="models"){let v=An();console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Agent Models")}`),console.log();for(let b of he){let w=v[b.role];console.log(w?` ${d.primary(b.name.padEnd(8))} \u2192 ${d.highlight(w.model)}${w.temperature!==void 0?d.muted(` (temp: ${w.temperature})`):""}`:` ${d.primary(b.name.padEnd(8))} \u2192 ${d.muted("(default)")}`)}console.log(),console.log(d.muted(` Config: ${gc()}`)),console.log(d.muted(" Edit the file to change models per agent.")),console.log()}else console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Multi-Agent System")}: ${e.agents.enabled?d.success("ON"):d.muted("OFF")}`),console.log(),console.log(d.muted(" /agents on \u2014 Enable multi-agent orchestration")),console.log(d.muted(" /agents off \u2014 Disable multi-agent orchestration")),console.log(d.muted(" /agents status \u2014 Show agent details")),console.log(d.muted(" /agents models \u2014 Show model per agent")),console.log(d.muted(" /team \u2014 Show team roster")),console.log();break}case"/security":{console.log(),console.log(` ${d.accent("\u{1F512}")} Running security scan...`);let y=vi(o);console.log(wi(y));break}case"/git":{if(S[1]==="status")try{let{getGitStatus:v,formatGitStatus:b}=await Promise.resolve().then(()=>(en(),$n)),w=await v(o);w?(console.log(),console.log(` ${d.accent("\u2726")} ${d.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(` ${d.accent("\u2726")} ${d.strong("Git Intelligence")}`),console.log(),console.log(d.muted(" /git status \u2014 Show git status")),console.log(d.muted(" hablas commit \u2014 Smart commit message")),console.log(d.muted(" hablas pr \u2014 Generate PR description")),console.log(d.muted(" hablas changelog \u2014 Generate changelog")),console.log();break}case"/workspace":{let y=xs(o);console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Workspace Information")}`),console.log(),console.log(_i(y)),console.log();break}case"/stats":{let{loadStats:y,formatStats:v}=await Promise.resolve().then(()=>(kn(),bi)),b=y();console.log(v(b));break}case"/context":{if(!m){console.log(B("Shared context not available"));break}let y=S[1],v=S.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(Y(`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(` ${d.accent("\u25C6")} ${d.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?Y(`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(ye("No decisions logged yet"));else{console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Decisions")}`),console.log();for(let w of b)console.log(` ${d.muted(w.timestamp)} ${d.primary(w.by)}: ${w.decision}`),w.rationale&&console.log(` ${d.muted(w.rationale)}`);console.log()}break}case"clear":m.clear(),console.log(Y("Shared context cleared"));break;default:console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Shared Context")}`),console.log(),console.log(m.render()),console.log(),console.log(d.muted(" /context set <k> <v> \u2014 Store a context entry")),console.log(d.muted(" /context get <key> \u2014 Get a context entry")),console.log(d.muted(" /context del <key> \u2014 Delete a context entry")),console.log(d.muted(" /context decisions \u2014 Show logged decisions")),console.log(d.muted(" /context clear \u2014 Clear all context")),console.log()}break}case"/plan":{if(!p){console.log(B("Plan manager not available"));break}let y=S[1],v=S.slice(2).join(" ");switch(y){case"status":{let w=p.getActivePlan();if(!w){console.log(ye("No active plan"));break}let _=p.getProgress();console.log(qc(w,{percent:_.percentage,done:_.done,total:_.total}));break}case"finish":{if(v){p.finishTask(v),console.log(Y(`Task finished: ${v}`));let w=p.getProgress();console.log(d.muted(` Progress: ${w.done}/${w.total} (${w.percentage}%)`))}else console.log(B("Usage: /plan finish <task_id>"));break}case"reset":{p.reset(),console.log(Y("Plan manager reset"));break}case"next":{let w=p.getNextTask();console.log(w?ye(`Next task: [${w.task_id}] ${w.description} \u2192 @${w.assignee}`):ye("No pending tasks"));break}default:console.log(),console.log(` ${d.accent("\u2726")} ${d.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(d.muted(" No active plan"));console.log(),console.log(d.muted(" /plan status \u2014 Show active plan with progress")),console.log(d.muted(" /plan finish <id> \u2014 Mark a task as finished")),console.log(d.muted(" /plan next \u2014 Show next pending task")),console.log(d.muted(" /plan reset \u2014 Reset plan manager")),console.log()}break}case"/learn":{if(!f||!k){console.log(B('Usage: /learn "always use tabs" or /learn "our API uses camelCase"'));break}if(f.set(`user-pref: ${k.slice(0,50)}`,k,{category:"user-pref",importance:9,createdBy:"user",tags:["user-pref","learned"]}),!(i.getMessages()[0]?.content||"").includes(k)){let v=await Rn(o,e),b=c?.getActive(),w=b?b.systemPrompt:Pn,_=On(w,v,f,m);i.updateSystemPrompt(_)}console.log(Y(`Learned: "${k}"`)),console.log(d.muted(" This will be remembered across sessions and injected into every prompt."));break}case"/test":{let y=Ri(o);if(y==="unknown"&&!k){console.log(B("No test framework detected. Install jest, vitest, pytest, etc."));break}console.log(ye(`Running tests (${y})...`));let v=Wc(o,k==="--fix"?void 0:k||void 0);if(console.log(),console.log(Gc(v)),console.log(),!v.passed&&k==="--fix"){console.log(ye("Tests failed \u2014 adding fix request to conversation..."));let b=Vc(v);i.addUserMessage(b),console.log(ye("Type your next message or let the agent work on the fix."))}break}case"/checkpoint":{let y=S[1],v=S.slice(2).join(" ");if(y==="save"){let b=v||`Checkpoint at turn ${l}`,w=g?.getModifiedFiles?.()||[],_=await Jc(o,b,w);console.log(Y(`Checkpoint saved: ${_.id} "${b}" (${_.fileCount} files)`))}else if(y==="list"){let b=Xc(o);console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Checkpoints")}`),console.log(),console.log(eu(b)),console.log()}else if(y==="restore"){if(!v){console.log(B("Usage: /checkpoint restore <id>"));break}let b=await Qc(o,v);b.success?console.log(Y(`Restored checkpoint: ${v} (${b.filesRestored} files)`)):console.log(Ae(b.error||"Restore failed"))}else y==="delete"?v&&Zc(o,v)?console.log(Y(`Deleted checkpoint: ${v}`)):console.log(B("Checkpoint not found")):(console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Checkpoint System")}`),console.log(),console.log(d.muted(' /checkpoint save "label" \u2014 Save current state')),console.log(d.muted(" /checkpoint list \u2014 List saved checkpoints")),console.log(d.muted(" /checkpoint restore <id> \u2014 Restore a checkpoint")),console.log(d.muted(" /checkpoint delete <id> \u2014 Delete a checkpoint")),console.log());break}case"/compare":{let y=S.slice(1);if(y.length===2)try{let v=await Ct.readFile(be.resolve(o,y[0]),"utf-8"),b=await Ct.readFile(be.resolve(o,y[1]),"utf-8"),{generateDiff:w}=await Promise.resolve().then(()=>(Di(),cu)),_=w(y[0]+" vs "+y[1],v,b);console.log(Ei(_))}catch(v){console.log(Ae(`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(Ei(b||"(no changes)"))}catch(v){console.log(Ae(`Git diff failed: ${v.message}`))}else console.log(d.muted(" Usage: /compare file1.ts file2.ts or /compare HEAD~1"));break}case"/cost":{let y=Qt(),v="current";console.log(),console.log(` ${d.accent("\u2726")} ${d.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,_]of b.sort((R,D)=>D[1]-R[1]))console.log(` @${w}: ${_} 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=S[1]?.toLowerCase(),v=S.slice(2).join(" ");if(!y||!v){console.log(),console.log(` ${d.accent("\u2726")} ${d.strong("Delegate Task to Agent")}`),console.log(),console.log(d.muted(" Usage: /delegate <agent> <task description>")),console.log(),console.log(d.muted(" Agents:")),console.log(` ${d.product("emma")} \u2014 Product Manager`),console.log(` ${d.architect("bob")} \u2014 Architect`),console.log(` ${d.engineer("alex")} \u2014 Engineer`),console.log(` ${d.analyst("david")} \u2014 Data Analyst`),console.log(),console.log(d.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=he.find(_=>_.role===y);if(w){if(!x){console.log(B("Agent runner not initialized. Cannot delegate."));break}console.log(Fc("Hablas",w.name,w.title,v)),console.log(Cn(w.name,w.title));let _=s.getOllamaTools(),R=await x.runAgent(y,v,void 0,_);R.success&&R.output?(console.log(En(R.output)),i.addAssistantMessage(`[@${w.name}]: ${R.output}`)):R.error?console.log(B(`${w.name} failed: ${R.error}`)):console.log(ye(`${w.name} completed without output.`))}break}case"/session":{let y=S[1],v=S.slice(2).join(" "),b=be.join(Ni.homedir(),".hablas","sessions");if(y==="save"){let w=v||`session_${Date.now()}`;try{le.existsSync(b)||le.mkdirSync(b,{recursive:!0});let _=i.toJSON(),R=be.join(b,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);le.writeFileSync(R,_,"utf-8"),console.log(Y(`Session saved: "${w}"`))}catch(_){console.log(Ae(`Save failed: ${_.message}`))}}else if(y==="list")try{if(!le.existsSync(b)){console.log(ye("No saved sessions"));break}let w=le.readdirSync(b).filter(_=>_.endsWith(".json"));console.log();for(let _ of w){let R=le.statSync(be.join(b,_));console.log(` ${_.replace(".json","")} (${new Date(R.mtime).toLocaleString()})`)}console.log()}catch{console.log(ye("No saved sessions"))}else if(y==="load"){let w=v;if(!w){console.log(Ae("Please specify the session label to load: /session load <label>"));break}try{let _=be.join(b,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);if(!le.existsSync(_)){console.log(Ae(`Session file not found: ${w}`));break}let R=le.readFileSync(_,"utf-8");i.fromJSON(R),console.log(Y(`Session successfully loaded: "${w}"`))}catch(_){console.log(Ae(`Load failed: ${_.message}`))}}else console.log(),console.log(d.muted(' /session save "label" \u2014 Save current conversation')),console.log(d.muted(" /session list \u2014 List saved sessions")),console.log(d.muted(' /session load "label" \u2014 Load saved conversation')),console.log();break}case"/team":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(gt(),Et));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(`
|
|
272
|
+
`+d.border("\u2554"+"\u2550".repeat(b-2)+"\u2557")),console.log(d.border("\u2551")+" ".repeat(Math.floor((b-22)/2))+d.strong("HABLAS COLLABORATION SYNC")+" ".repeat(b-2-25-Math.floor((b-22)/2))+d.border("\u2551")),console.log(d.border("\u2560"+"\u2550".repeat(b-2)+"\u2563")),console.log(d.border("\u2551")+` ${d.strong("My Identity:")} ${d.highlight(`@${v.my_username}`)}`+" ".repeat(Math.max(1,b-21-(v.my_username?.length||0)))+d.border("\u2551")),console.log(d.border("\u2551")+` ${d.strong("Room Fingerprint:")} ${d.muted(v.project_team_token?.slice(0,12))}...`+" ".repeat(Math.max(1,b-34))+d.border("\u2551")),console.log(d.border("\u2551")+` ${d.strong("Status:")} ${d.success("\u25CF ACTIVE")}`+" ".repeat(Math.max(1,b-31))+d.border("\u2551")),console.log(d.border("\u2560"+"\u2550".repeat(b-2)+"\u2563")),console.log(d.border("\u2551")+` ${d.strong("Teammates Online:")}`+" ".repeat(Math.max(1,b-21))+d.border("\u2551"));let _=(v.sessions||[]).filter(R=>R.developer_name!==v.my_username);if(_.length===0)console.log(d.border("\u2551")+" (awaiting colleagues...)"+" ".repeat(Math.max(1,b-31))+d.border("\u2551"));else for(let R of _){let D=` @${R.developer_name} [${R.active_section||"idle"}] - ${R.current_task||"none"}`;console.log(d.border("\u2551")+` ${d.secondary(D.slice(0,b-6))}`+" ".repeat(Math.max(0,b-6-D.length))+d.border("\u2551"))}console.log(d.border("\u255A"+"\u2550".repeat(b-2)+"\u255D")+`
|
|
273
|
+
`),console.log(d.muted(` Verify that "Room Fingerprint" matches on all devices to ensure connectivity.
|
|
274
|
+
`));break}case"/msg":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(gt(),Et));if(!y){console.log(B("Team mode is not active. Use hablas --team to start."));break}let v=k.split(/\s+/),b=v[0],w=v.slice(1).join(" ");if(!b||!w){console.log(B("Usage: /msg <username> <content>"));break}let _=await y.sendMessage(b,w);console.log(_?Y(`Message sent to @${b}`):Ae(`Failed to send message to @${b}`));break}default:console.log(Ss(`Unknown: ${C}`,"Type /help for commands"))}}var le,Ct,be,Ni,Pn,Fi,du=F(()=>{"use strict";le=O(require("fs")),Ct=O(require("fs/promises")),be=O(require("path")),Ni=O(require("os"));xn();Sn();Wr();Jr();Xr();si();ai();_n();fi();kn();xi();en();Ai();Tc();nn();zc();tu();Pn=`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.
|
|
276
275
|
|
|
277
276
|
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.
|
|
278
277
|
|
|
@@ -310,85 +309,85 @@ Your role is to orchestrate, coordinate, and synthesize the work of your special
|
|
|
310
309
|
## Important
|
|
311
310
|
Never output tool calls as text or JSON in your response.
|
|
312
311
|
Always use the tool_calls field provided by the API.
|
|
313
|
-
If you cannot complete a task, explain why with absolute technical objectivity.`;
|
|
314
|
-
`),
|
|
315
|
-
... [File has ${
|
|
312
|
+
If you cannot complete a task, explain why with absolute technical objectivity.`;Fi=be.join(Ni.homedir(),".hablas","backup")});async function Ht(n){try{if(!ji.existsSync(n))return;ji.existsSync(Mn)||await st.mkdir(Mn,{recursive:!0});let e=await st.readFile(n,"utf-8"),t=sn.basename(n),s=Date.now(),r=`${t}.${s}.bak`,i=sn.join(Mn,r);await st.writeFile(i,e,"utf-8");let a=(await st.readdir(Mn)).filter(l=>l.startsWith(`${t}.`)&&l.endsWith(".bak")).sort().reverse();if(a.length>fu)for(let l of a.slice(fu))await st.unlink(sn.join(Mn,l))}catch{}}var st,ji,sn,pu,Mn,fu,hu=F(()=>{"use strict";st=O(require("fs/promises")),ji=O(require("fs")),sn=O(require("path")),pu=O(require("os")),Mn=sn.join(pu.homedir(),".hablas","backup"),fu=10});function yu(n){let e=m=>Tt.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 se.readFile(p,"utf-8")).split(`
|
|
313
|
+
`),S=x.length,C=m.start_line?Math.max(1,m.start_line):1,k=m.end_line?Math.min(S,m.end_line):Math.min(S,C+mu-1),y=Math.min(k,C+mu-1),v=x.slice(C-1,y),b=String(y).length,w=v.map((D,$)=>`${String(C+$).padStart(b," ")} | ${D}`),_=`[${m.path} \u2014 lines ${C}-${y} of ${S}]`,R=y<S?`
|
|
314
|
+
... [File has ${S} total lines. Use start_line/end_line to read more.]`:"";return{success:!0,output:`${_}
|
|
316
315
|
${w.join(`
|
|
317
|
-
`)}${
|
|
318
|
-
${
|
|
319
|
-
`),
|
|
320
|
-
`),w=[...
|
|
321
|
-
`);await se.writeFile(p,w,"utf-8");let
|
|
322
|
-
${
|
|
323
|
-
`)}}catch(p){return{success:!1,output:"",error:`[get_file_info]: ${p.message}`}}}}]}function
|
|
324
|
-
`,l.isDirectory()){let h=e+(c?" ":"\u2502 ");o+=await
|
|
316
|
+
`)}${R}`}}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 Hi.existsSync(p)&&await Ht(p),await se.mkdir(Tt.dirname(p),{recursive:!0}),await se.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 se.readFile(p,"utf-8"),x=m.old_content,S=m.new_content,C=gu(g,x);if(C===0)return{success:!1,output:"",error:"[edit_file]: Old content not found in file"};if(C>1)return{success:!1,output:"",error:`[edit_file]: old_content matches ${C} locations in the file. Provide more surrounding context to be specific.`};await Ht(p);let k=g.replace(x,S);await se.writeFile(p,k,"utf-8");let y=$s(m.path,g,k);return{success:!0,output:`Edited: ${m.path}
|
|
317
|
+
${y}`}}catch(p){return{success:!1,output:"",error:`[edit_file]: ${p.message}`}}}},{name:"patch_file",description:"Replace lines in a file using line numbers. More reliable than edit_file. Use read_file first to see line numbers.",safety:"confirm",parameters:{path:{type:"string",description:"File path",required:!0},start_line:{type:"number",description:"First line to replace (1-indexed)",required:!0},end_line:{type:"number",description:"Last line to replace (inclusive)",required:!0},new_content:{type:"string",description:"New content to insert in place of those lines",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[patch_file]: path is required"};if(!m.start_line)return{success:!1,output:"",error:"[patch_file]: start_line is required"};if(!m.end_line)return{success:!1,output:"",error:"[patch_file]: end_line is required"};if(m.new_content===void 0)return{success:!1,output:"",error:"[patch_file]: new_content is required"};let p=e(m.path),g=await se.readFile(p,"utf-8"),x=g.split(`
|
|
318
|
+
`),S=x.length,C=m.start_line,k=m.end_line;if(C<1||C>S)return{success:!1,output:"",error:`[patch_file]: start_line ${C} is out of range (file has ${S} lines)`};if(k<C||k>S)return{success:!1,output:"",error:`[patch_file]: end_line ${k} is out of range (start_line=${C}, total=${S})`};await Ht(p);let y=x.slice(0,C-1),v=x.slice(k),b=m.new_content.split(`
|
|
319
|
+
`),w=[...y,...b,...v].join(`
|
|
320
|
+
`);await se.writeFile(p,w,"utf-8");let _=$s(m.path,g,w),R=k-C+1,D=b.length;return{success:!0,output:`Patched: ${m.path} (replaced ${R} lines with ${D})
|
|
321
|
+
${_}`}}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 se.readFile(p,"utf-8"),x=m.search,S=m.replace,C=m.is_regex;await Ht(p);let k,y;if(C){let v=new RegExp(x,"g");y=(g.match(v)||[]).length,k=g.replace(v,S)}else y=gu(g,x),k=g.split(x).join(S);return y===0?{success:!1,output:"",error:"[search_and_replace]: Pattern not found in file"}:(await se.writeFile(p,k,"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 se.mkdir(Tt.dirname(p),{recursive:!0}),Hi.existsSync(p)&&await Ht(p),await se.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 Ht(p),await se.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 se.mkdir(Tt.dirname(g),{recursive:!0}),await se.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 se.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 bu(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 se.stat(p);return{success:!0,output:[`Path: ${m.path}`,`Size: ${qy(g.size)}`,`Type: ${g.isDirectory()?"directory":"file"}`,`Modified: ${g.mtime.toISOString()}`,`Created: ${g.birthtime.toISOString()}`].join(`
|
|
322
|
+
`)}}catch(p){return{success:!1,output:"",error:`[get_file_info]: ${p.message}`}}}}]}function gu(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 bu(n,e,t,s){if(s>=t)return"";let i=(await se.readdir(n,{withFileTypes:!0})).filter(a=>!Uy.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],c=a===i.length-1,u=c?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ",f=l.isDirectory()?"\u{1F4C1}":"\u{1F4C4}";if(o+=`${e}${u}${f} ${l.name}
|
|
323
|
+
`,l.isDirectory()){let h=e+(c?" ":"\u2502 ");o+=await bu(Tt.join(n,l.name),h,t,s+1)}}return o}function qy(n){return n<1024?`${n} B`:n<1024*1024?`${(n/1024).toFixed(1)} KB`:`${(n/(1024*1024)).toFixed(1)} MB`}var se,Hi,Tt,mu,Uy,vu=F(()=>{"use strict";se=O(require("fs/promises")),Hi=O(require("fs")),Tt=O(require("path"));Di();hu();mu=300;Uy=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next"])});var wu,Cs,xu=F(()=>{"use strict";wu=require("child_process"),Cs=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,wu.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+=`
|
|
325
324
|
Error: ${a.message}`}),r>0&&setTimeout(()=>{o.status==="running"&&(this.kill(s),o.status="timeout",o.stderr+=`
|
|
326
325
|
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+=`
|
|
327
326
|
`),i+=s.stderr),t?.lastLines&&(i=i.split(`
|
|
328
327
|
`).slice(-t.lastLines).join(`
|
|
329
|
-
`)),{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
|
|
330
|
-
PID: ${
|
|
331
|
-
Use bash_output to read output: bash_output(process_id="${l}")`}}return new Promise(l=>{let c=(0,
|
|
328
|
+
`)),{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 Su(n){return Bi||(Bi=new Cs({workingDir:n})),Bi}function Au(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=[...Ky,...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=Su(n).start(s,{timeout:i});return{success:!0,output:`Background process started: ${l}
|
|
329
|
+
PID: ${Su(n).getProcess(l)?.pid}
|
|
330
|
+
Use bash_output to read output: bash_output(process_id="${l}")`}}return new Promise(l=>{let c=(0,_u.exec)(s,{cwd:n,timeout:i,maxBuffer:10485760,env:{...process.env,FORCE_COLOR:"0"}}),u="",f="";c.stdout?.on("data",h=>{u+=h}),c.stderr?.on("data",h=>{f+=h}),c.on("close",h=>{l(h===0?{success:!0,output:u||"(no output)"}:{success:!1,output:u,error:f||`Exit code: ${h}`})}),c.on("error",h=>{l({success:!1,output:"",error:h.message})})})}}}var _u,Ky,Bi,ku=F(()=>{"use strict";_u=require("child_process");xu();Ky=["rm -rf /","rm -rf /*","rm -rf ~","rm -rf $HOME","rm -rf /home","mkfs",":(){ :|:& };:"],Bi=null});function $u(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=Rt.resolve(n,e.path||"."),r=new RegExp(t,"gi"),i=[];if(await Cu(s,r,i,n),i.length===0)return{success:!0,output:`No matches found for: "${t}"`};let o=i.slice(0,50).join(`
|
|
332
331
|
`),a=i.length>50?`
|
|
333
|
-
... 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
|
|
334
|
-
`),c=
|
|
335
|
-
`);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
|
|
336
|
-
`);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
|
|
337
|
-
`);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
|
|
338
|
-
`)}function
|
|
339
|
-
`);s.line>0&&s.line<=o.length&&(o[s.line-1]="// "+o[s.line-1],
|
|
340
|
-
`),"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
|
|
341
|
-
|
|
342
|
-
Auto-fixed: ${o}/${r.length} issues`}}return{success:!0,output:
|
|
332
|
+
... 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 Cu(n,e,t,s){let r=await Es.readdir(n,{withFileTypes:!0});for(let i of r){if(Wy.has(i.name)||i.name.startsWith("."))continue;let o=Rt.join(n,i.name);if(i.isDirectory())await Cu(o,e,t,s);else if(Gy.has(Rt.extname(i.name)))try{let l=(await Es.readFile(o,"utf-8")).split(`
|
|
333
|
+
`),c=Rt.relative(s,o);for(let u=0;u<l.length;u++)e.test(l[u])&&(t.push(`${c}:${u+1}: ${l[u].trim()}`),e.lastIndex=0)}catch{}}}var Es,Rt,Wy,Gy,Eu=F(()=>{"use strict";Es=O(require("fs/promises")),Rt=O(require("path")),Wy=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next",".cache"]),Gy=new Set([".ts",".js",".tsx",".jsx",".py",".go",".rs",".java",".c",".cpp",".h",".css",".html",".json",".md",".yaml",".yml",".toml"])});function Vy(n){let e=[],t=Ot.join(n,"tsconfig.json");if(!De.existsSync(t))return e;try{(0,Ui.execSync)("npx tsc --noEmit 2>&1",{cwd:n,encoding:"utf-8",timeout:3e4})}catch(s){let r=s,o=(r.stdout||r.message||"").split(`
|
|
334
|
+
`);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 zy(n){let e=[];if(![".eslintrc.json",".eslintrc.js",".eslintrc.yml","eslint.config.js","eslint.config.mjs"].some(s=>De.existsSync(Ot.join(n,s))))return e;try{(0,Ui.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:Ot.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(`
|
|
335
|
+
`);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 Yy(n,e,t){let s;try{s=De.readFileSync(n,"utf-8")}catch{return}let r=Ot.relative(e,n),i=s.split(`
|
|
336
|
+
`);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 Jy(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=De.readdirSync(r)}catch{return}for(let l of a){if(o.includes(l))continue;let c=Ot.join(r,l),u;try{u=De.statSync(c)}catch{continue}u.isDirectory()?s(c,i+1):t.some(f=>l.endsWith(f))&&Yy(c,n,e)}}return s(n),e.slice(0,20)}function Xy(n){let e=[];e.push(...Vy(n)),e.push(...zy(n)),e.push(...Jy(n));let t={error:0,warning:1,info:2};return e.sort((s,r)=>t[s.severity]-t[r.severity]),e}function Tu(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(`
|
|
337
|
+
`)}function Qy(n,e){let t=[];for(let s of n)if(s.source==="pattern"&&s.message.includes("console.log")){let r=Ot.join(e,s.file);try{let o=De.readFileSync(r,"utf-8").split(`
|
|
338
|
+
`);s.line>0&&s.line<=o.length&&(o[s.line-1]="// "+o[s.line-1],De.writeFileSync(r,o.join(`
|
|
339
|
+
`),"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 Ru(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=Xy(t);if(s&&r.length>0){let o=Qy(r,t).filter(l=>l.fixed).length;return{success:!0,output:`${Tu(r)}
|
|
340
|
+
|
|
341
|
+
Auto-fixed: ${o}/${r.length} issues`}}return{success:!0,output:Tu(r)}}catch(r){return{success:!1,output:"",error:`Bug detection failed: ${r instanceof Error?r.message:String(r)}`}}}}}var Ui,De,Ot,Ou=F(()=>{"use strict";Ui=require("child_process"),De=O(require("fs")),Ot=O(require("path"))});function eb(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,`
|
|
343
342
|
`),e=e.replace(/<(br|hr)\s*\/?>/gi,`
|
|
344
343
|
`),e=e.replace(/<\/?(ul|ol)>/gi,`
|
|
345
344
|
`),e=e.replace(/<h([1-6])[^>]*>([\s\S]*?)<\/h\1>/gi,(t,s,r)=>`
|
|
346
345
|
${"#".repeat(parseInt(s))} ${r.replace(/<[^>]+>/g,"").trim()}
|
|
347
346
|
`),e=e.replace(/<a[^>]+href=["']([^"']+)["'][^>]*>([\s\S]*?)<\/a>/gi,(t,s,r)=>{let i=r.replace(/<[^>]+>/g,"").trim();return i?`[${i}](${s})`:s}),e=e.replace(/<pre[^>]*>([\s\S]*?)<\/pre>/gi,(t,s)=>"\n```\n"+s.replace(/<[^>]+>/g,"").trim()+"\n```\n"),e=e.replace(/<code[^>]*>([\s\S]*?)<\/code>/gi,"`$1`"),e=e.replace(/<(b|strong)[^>]*>([\s\S]*?)<\/\1>/gi,"**$2**"),e=e.replace(/<(i|em)[^>]*>([\s\S]*?)<\/\1>/gi,"*$2*"),e=e.replace(/<li[^>]*>([\s\S]*?)<\/li>/gi,"\u2022 $1"),e=e.replace(/<[^>]+>/g,""),e=e.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,'"').replace(/'/g,"'").replace(/ /g," ").replace(/&#(\d+);/g,(t,s)=>String.fromCharCode(parseInt(s))).replace(/&[a-z]+;/gi,""),e=e.replace(/[ \t]+/g," "),e=e.replace(/\n{3,}/g,`
|
|
348
347
|
|
|
349
|
-
`),e=e.replace(/^\s+|\s+$/gm,""),e.trim()}function
|
|
348
|
+
`),e=e.replace(/^\s+|\s+$/gm,""),e.trim()}function tb(n){let e=n.match(/<title[^>]*>([\s\S]*?)<\/title>/i);if(e)return e[1].replace(/<[^>]+>/g,"").trim();let t=n.match(/<h1[^>]*>([\s\S]*?)<\/h1>/i);return t?t[1].replace(/<[^>]+>/g,"").trim():"Untitled"}function nb(n,e){let t=[],s=/<a[^>]+href=["']([^"']+)["'][^>]*>([\s\S]*?)<\/a>/gi,r,i=new Set;for(;(r=s.exec(n))!==null;){let o=r[1].trim(),a=r[2].replace(/<[^>]+>/g,"").trim();if(!(o.startsWith("#")||o.startsWith("javascript:")||o.startsWith("mailto:"))){try{o=new URL(o,e).href}catch{continue}i.has(o)||(i.add(o),t.push({text:a||o,url:o}))}}return t}async function Lu(n){let e=new AbortController,t=setTimeout(()=>e.abort(),Mu);try{let s=await fetch(n,{signal:e.signal,headers:{"User-Agent":Zy,Accept:"text/html,application/xhtml+xml,text/plain,*/*","Accept-Language":"en-US,en;q=0.9"},redirect:"follow"});if(clearTimeout(t),!s.ok)return{html:"",finalUrl:s.url||n,status:s.status};let r=s.headers.get("content-type")||"";if(!r.includes("text/")&&!r.includes("application/xhtml")&&!r.includes("application/json"))return{html:`[Binary content: ${r}]`,finalUrl:s.url||n,status:s.status};let i=s.body?.getReader();if(!i)return{html:"",finalUrl:s.url||n,status:s.status};let o=[],a=0;for(;a<Pu;){let{done:u,value:f}=await i.read();if(u)break;o.push(f),a+=f.length}if(a>=Pu)try{i.cancel()}catch{}let l=new TextDecoder("utf-8",{fatal:!1});return{html:o.map(u=>l.decode(u,{stream:!0})).join("")+l.decode(),finalUrl:s.url||n,status:s.status}}catch(s){clearTimeout(t);let r=s instanceof Error?s:new Error(String(s));throw r.name==="AbortError"?new Error(`Timeout after ${Mu/1e3}s`):r}}function Du(){return[{name:"scrape_url",description:"Fetch a web page and extract its readable text content. Returns clean text/markdown without HTML tags. Use this to read documentation, articles, blog posts, or any web page.",safety:"safe",parameters:{url:{type:"string",description:"The URL to scrape (must start with http:// or https://)",required:!0}},execute:async n=>{let e=n.url;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:t,finalUrl:s,status:r}=await Lu(e);if(!t||r>=400)return{success:!1,output:"",error:`HTTP ${r} \u2014 could not fetch ${e}`};let i=tb(t),o=eb(t);return o.length>Iu&&(o=o.slice(0,Iu)+`
|
|
350
349
|
|
|
351
350
|
[... content truncated ...]`),{success:!0,output:[`# ${i}`,`URL: ${s}`,`Fetched: ${new Date().toISOString()}`,"",o].join(`
|
|
352
|
-
`)}}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
|
|
351
|
+
`)}}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 Lu(e);if(!s||i>=400)return{success:!1,output:"",error:`HTTP ${i} \u2014 could not fetch ${e}`};let o=nb(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,c)=>`${c+1}. [${l.text}](${l.url})`).join(`
|
|
353
352
|
`);return{success:!0,output:`Found ${o.length} links:
|
|
354
353
|
|
|
355
|
-
${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
|
|
356
|
-
`)}}catch(s){return{success:!1,output:"",error:`Search failed: ${s instanceof Error?s.message:String(s)}`}}}}}var
|
|
354
|
+
${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 Pu,Mu,Iu,Zy,Fu=F(()=>{"use strict";Pu=2*1024*1024,Mu=15e3,Iu=32e3,Zy="HablasBot/2.0 (+https://hablas.dev)"});function rb(n){let e=rn.get(n.toLowerCase().trim());return e?Date.now()-e.timestamp>sb?(rn.delete(n.toLowerCase().trim()),null):e.results:null}function ib(n,e){if(rn.size>200){let t=rn.keys().next().value;t!==void 0&&rn.delete(t)}rn.set(n.toLowerCase().trim(),{results:e,timestamp:Date.now()})}async function ob(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 ab(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],c=a[2].replace(/<[^>]+>/g,"").trim(),u=a[3].replace(/<[^>]+>/g,"").trim(),f=l.match(/uddg=([^&]+)/);if(f)try{l=decodeURIComponent(f[1])}catch{}c&&l&&!l.startsWith("/")&&i.push({title:c,url:l,snippet:u,source:"duckduckgo"})}if(i.length===0){let l=/<a[^>]+href="(https?:\/\/[^"]+)"[^>]*>([\s\S]*?)<\/a>/gi,c=new Set;for(;(a=l.exec(r))!==null&&i.length<e;){let u=a[1],f=a[2].replace(/<[^>]+>/g,"").trim();f&&f.length>5&&!c.has(u)&&!u.includes("duckduckgo.com")&&(c.add(u),i.push({title:f,url:u,snippet:"",source:"duckduckgo"}))}}return i.length>0?i:null}catch{return null}}async function lb(n,e=5){let t=rb(n);if(t)return t.slice(0,e);let s=[{name:"brave",fn:()=>ob(n,e)},{name:"duckduckgo",fn:()=>ab(n,e)}];for(let r of s)try{let i=await r.fn();if(i&&i.length>0)return ib(n,i),i}catch{}return[]}function Nu(){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 lb(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(`
|
|
355
|
+
`)}}catch(s){return{success:!1,output:"",error:`Search failed: ${s instanceof Error?s.message:String(s)}`}}}}}var sb,rn,ju=F(()=>{"use strict";sb=3600*1e3,rn=new Map});function Uu(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=Bt(o[1]));let a=e.match(/\/Author\s*\(([^)]*)\)/);a&&(t.author=Bt(a[1]));let l=e.match(/\/Subject\s*\(([^)]*)\)/);l&&(t.subject=Bt(l[1]));let c=e.match(/\/Creator\s*\(([^)]*)\)/);c&&(t.creator=Bt(c[1]));let u=/stream\r?\n([\s\S]*?)\r?\nendstream/g,f;for(;(f=u.exec(e))!==null;){let m=f[1],p=qu(m);p.trim()&&s.push(p);try{let g=require("zlib"),x=Buffer.from(m,"latin1"),S=g.inflateSync(x).toString("latin1"),C=qu(S);C.trim()&&!s.includes(C)&&s.push(C)}catch{}}return{text:s.join(`
|
|
357
356
|
`).replace(/\r\n/g,`
|
|
358
357
|
`).replace(/\n{3,}/g,`
|
|
359
358
|
|
|
360
|
-
`).trim(),pages:r,metadata:t}}function qu(n){let e=[],t=/\(([^)]*)\)\s*Tj/g,s;for(;(s=t.exec(n))!==null;)e.push(
|
|
361
|
-
`).replace(/\\r/g,"").replace(/\\t/g," ").replace(/\\\(/g,"(").replace(/\\\)/g,")").replace(/\\\\/g,"\\"),o}function
|
|
362
|
-
`).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
|
|
359
|
+
`).trim(),pages:r,metadata:t}}function qu(n){let e=[],t=/\(([^)]*)\)\s*Tj/g,s;for(;(s=t.exec(n))!==null;)e.push(Bt(s[1]));let r=/\[((?:\([^)]*\)|[^])*?)\]\s*TJ/g;for(;(s=r.exec(n))!==null;){let l=s[1].match(/\(([^)]*)\)/g);if(l){let c=l.map(u=>Bt(u.slice(1,-1))).join("");e.push(c)}}let i=/\(([^)]*)\)\s*'/g;for(;(s=i.exec(n))!==null;)e.push(Bt(s[1]));let o=e.join(" ");return o=o.replace(/\\n/g,`
|
|
360
|
+
`).replace(/\\r/g,"").replace(/\\t/g," ").replace(/\\\(/g,"(").replace(/\\\)/g,")").replace(/\\\\/g,"\\"),o}function Bt(n){return n.replace(/\\n/g,`
|
|
361
|
+
`).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 Wu(n){let e=t=>Ku.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(!yt.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=yt.statSync(s);if(r.size>Hu)return{success:!1,output:"",error:`File too large: ${(r.size/1024/1024).toFixed(1)}MB (max: ${Hu/1024/1024}MB)`};try{let i=yt.readFileSync(s),{text:o,pages:a,metadata:l}=Uu(i);if(!o||o.length<10)return{success:!0,output:`PDF: ${t.path} (${a} pages)
|
|
363
362
|
|
|
364
|
-
[No extractable text found \u2014 this may be a scanned/image-only PDF. Use OCR tools for scanned documents.]`};let c=o;return c.length>
|
|
363
|
+
[No extractable text found \u2014 this may be a scanned/image-only PDF. Use OCR tools for scanned documents.]`};let c=o;return c.length>Bu&&(c=c.slice(0,Bu)+`
|
|
365
364
|
|
|
366
365
|
[... 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(`
|
|
367
366
|
`)}
|
|
368
|
-
${c}`}}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(!yt.existsSync(s))return{success:!1,output:"",error:`File not found: ${t.path}`};try{let r=yt.statSync(s),i=yt.readFileSync(s),{pages:o,metadata:a}=
|
|
369
|
-
`)}}catch(r){return{success:!1,output:"",error:`Failed to read PDF metadata: ${r instanceof Error?r.message:String(r)}`}}}}]}var yt,
|
|
367
|
+
${c}`}}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(!yt.existsSync(s))return{success:!1,output:"",error:`File not found: ${t.path}`};try{let r=yt.statSync(s),i=yt.readFileSync(s),{pages:o,metadata:a}=Uu(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(`
|
|
368
|
+
`)}}catch(r){return{success:!1,output:"",error:`Failed to read PDF metadata: ${r instanceof Error?r.message:String(r)}`}}}}]}var yt,Ku,Hu,Bu,Gu=F(()=>{"use strict";yt=O(require("fs")),Ku=O(require("path")),Hu=50*1024*1024,Bu=4e4});function on(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 cb(n,e,t=Qu){let s=zu[e];if(!s)return{success:!1,stdout:"",stderr:`Unsupported language: "${e}". Supported: ${Object.keys(zu).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=Ju.tmpdir(),i=Xu.join(r,`hablas_exec_${Date.now()}${s.extension}`);try{Ts.writeFileSync(i,n,"utf-8");let o=s.command(i),a=Date.now();return await new Promise(l=>{let c=(0,Yu.exec)(o,{timeout:t,maxBuffer:5242880,cwd:r,env:{...process.env,NODE_ENV:"production",FORCE_COLOR:"0"}}),u="",f="";c.stdout?.on("data",h=>{u+=h}),c.stderr?.on("data",h=>{f+=h}),c.on("close",h=>{let m=Date.now()-a;l({success:h===0,stdout:u.slice(0,Vu),stderr:f.slice(0,Vu/2),exitCode:h??1,duration:m,language:e})}),c.on("error",h=>{let m=Date.now()-a;l({success:!1,stdout:"",stderr:h.message,exitCode:1,duration:m,language:e})})})}finally{try{Ts.unlinkSync(i)}catch{}}}function ub(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 Zu(){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()||ub(e),s=Math.min(Math.max(1e3,n.timeout||Qu),3e4),r=await cb(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?`
|
|
370
369
|
Errors/Warnings:`:"Errors:"),i.push(r.stderr)),!r.stdout&&!r.stderr&&i.push("(no output)"),{success:r.success,output:i.join(`
|
|
371
|
-
`),error:r.success?void 0:r.stderr||`Exit code: ${r.exitCode}`}}}]}var Ju,
|
|
370
|
+
`),error:r.success?void 0:r.stderr||`Exit code: ${r.exitCode}`}}}]}var Yu,Ts,Ju,Xu,Qu,Vu,zu,ed=F(()=>{"use strict";Yu=require("child_process"),Ts=O(require("fs")),Ju=O(require("os")),Xu=O(require("path")),Qu=1e4,Vu=16e3;zu={javascript:{extension:".js",command:n=>`node --no-warnings "${n}"`,available:()=>!0},typescript:{extension:".ts",command:n=>on("tsx")?`tsx "${n}"`:on("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=>on("python3")?`python3 "${n}"`:`python "${n}"`,available:()=>on("python3")||on("python")},bash:{extension:".sh",command:n=>`bash "${n}"`,available:()=>on("bash")}}});var In,td=F(()=>{"use strict";vu();ku();Eu();Ou();Fu();ju();Gu();ed();In=class{tools=new Map;constructor(e,t){let s=yu(e);for(let r of s)this.tools.set(r.name,r);this.tools.set("run_command",Au(e,t)),this.tools.set("search_codebase",$u(e)),this.tools.set("detect_bugs",Ru(e)),this.tools.set("web_search",Nu());for(let r of Du())this.tools.set(r.name,r);for(let r of Wu(e))this.tools.set(r.name,r);for(let r of Zu())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(`
|
|
372
371
|
`);return`- ${t.name} [${t.safety}]: ${t.description}
|
|
373
372
|
${s}`}).join(`
|
|
374
373
|
|
|
375
|
-
`)}}});function
|
|
376
|
-
... [truncated to fit context budget]`}var
|
|
374
|
+
`)}}});function qi(n){return Math.ceil(n.length/3.5)}function Ln(n,e){let t=Math.floor(e*3.5);return n.length<=t?n:n.slice(0,t)+`
|
|
375
|
+
... [truncated to fit context budget]`}var Ki=F(()=>{"use strict"});var nd,an,Wi=F(()=>{"use strict";nd=O(require("crypto"));Ki();an=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=qi(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=Ln(o.content,a);i.push(`--- ${o.path} (truncated, importance: ${o.importance}) ---
|
|
377
376
|
${l}`),r+=a}}continue}i.push(`--- ${o.path} ---
|
|
378
377
|
${o.content}`),r+=o.tokenCount}return i.join(`
|
|
379
378
|
|
|
380
|
-
`)}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(c=>i.length===0?!0:i.some(
|
|
379
|
+
`)}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(c=>i.length===0?!0:i.some(u=>c.path.includes(u))).sort((c,u)=>this.computeScore(u)-this.computeScore(c)),a=0,l=[];for(let c of o){if(a+c.tokenCount>s)break;l.push(`--- ${c.path} ---
|
|
381
380
|
${c.content}`),a+=c.tokenCount}return l.join(`
|
|
382
381
|
|
|
383
|
-
`)}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=
|
|
382
|
+
`)}getTotalTokens(){return this.usedTokens}getCacheSize(){return this.cache.size}getCacheInfo(){return Array.from(this.cache.values()).map(e=>({path:e.path,tokens:e.tokenCount,importance:e.importance,accesses:e.accessCount})).sort((e,t)=>t.importance-e.importance)}evictToFit(e){let t=Array.from(this.cache.entries()).map(([r,i])=>({key:r,...i,score:this.computeScore(i)})).sort((r,i)=>r.score-i.score),s=0;for(let r of t){if(s>=e)break;r.importance>=9||(s+=r.tokenCount,this.usedTokens-=r.tokenCount,this.cache.delete(r.key))}}evict(e){this.evictToFit(e)}clear(){this.cache.clear(),this.usedTokens=0,this.accessHistory=[]}computeScore(e){let r=(Date.now()-e.lastUsed)/6e4,i=Math.exp(-r/30),o=Math.log1p(e.accessCount);return e.importance*(i+o)}autoImportance(e,t){let s=5;/\b(config|tsconfig|package\.json|\.env|Dockerfile|docker-compose)\b/i.test(e)&&(s=8),/\b(index|main|app|server)\.(ts|js|tsx|jsx)$/i.test(e)&&(s=7),/\.(test|spec)\.(ts|js|tsx|jsx)$/i.test(e)&&(s=3);let r=qi(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 nd.createHash("md5").update(e).digest("hex")}}});function Dn(){return`msg_${Date.now()}_${++db}`}function ln(n){return Math.ceil(n.length/4)}var db,Pt,Gi=F(()=>{"use strict";db=0;Pt=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=ln(e);this.messages.push({id:Dn(),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=Dn(),r=ln(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=Dn(),i=ln(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=Dn(),r=ln(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=ln(e),s=this.messages.filter(r=>r.priority==="critical"&&r.role!=="system");this.messages=[{id:Dn(),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)+`
|
|
384
383
|
...(compressed from `+t+" chars)":e.content=e.content.slice(0,400)+`
|
|
385
|
-
...(compressed from `+t+" chars)",e.compressed=!0,e.originalLength=t,e.tokenEstimate=
|
|
386
|
-
${
|
|
387
|
-
`);let t=` ${
|
|
388
|
-
`).filter(Boolean).slice(-Vi)}}catch{}}saveHistory(){try{let e=
|
|
389
|
-
`),"utf-8")}catch{}}}});var
|
|
384
|
+
...(compressed from `+t+" chars)",e.compressed=!0,e.originalLength=t,e.tokenEstimate=ln(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 sd,Fe,Oe,rd,Rs,Vi,fb,pb,hb,Os,id=F(()=>{"use strict";sd=O(require("readline")),Fe=O(require("fs")),Oe=O(require("path")),rd=O(require("os"));nn();Rs=Oe.join(rd.homedir(),".hablas","history"),Vi=500,fb=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"]),pb=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next",".cache"]),hb=["read ","edit ","write ","delete ","open ","patch "],Os=class{rl;history=[];workingDir;fileCache=[];fileCacheTime=0;constructor(e){this.workingDir=e||process.cwd(),this.loadHistory(),this.rl=this.createReadline()}createReadline(){return sd.createInterface({input:process.stdin,output:process.stdout,terminal:!0,history:this.history,historySize:Vi,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=` ${d.warning("?")} ${e} ${d.muted("[Y/n]")} `;return(await this.prompt(t)).toLowerCase()!=="n"}async confirmDangerous(e){console.log(`
|
|
385
|
+
${d.error("\u26A0")} ${d.error(d.strong(e))}`),console.log(` ${d.muted('This action cannot be undone. Type "yes" to confirm.')}
|
|
386
|
+
`);let t=` ${d.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=Ti.filter(r=>r.startsWith(e));return[s.length?s:Ti,e]}for(let s of hb)if(e.toLowerCase().includes(s)){let r=e.split(s).pop()??"";if(r&&!r.includes(" "))try{let i=Oe.dirname(r)||".",o=Oe.basename(r),a=Oe.resolve(this.workingDir,i),l=Fe.readdirSync(a).filter(c=>c.startsWith(o)).slice(0,8).map(c=>e.slice(0,e.lastIndexOf(r))+Oe.join(i,c));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=Fe.readdirSync(e,{withFileTypes:!0});for(let a of o){if(a.name.startsWith(".")||pb.has(a.name))continue;let l=t?`${t}/${a.name}`:a.name;if(a.isDirectory())this.scanDir(Oe.join(e,a.name),l,s,r,i+1);else{let c=Oe.extname(a.name).toLowerCase();(fb.has(c)||a.name==="Dockerfile"||a.name==="Makefile")&&s.push(l)}}}catch{}}loadHistory(){try{if(Fe.existsSync(Rs)){let e=Fe.readFileSync(Rs,"utf-8");this.history=e.split(`
|
|
387
|
+
`).filter(Boolean).slice(-Vi)}}catch{}}saveHistory(){try{let e=Oe.dirname(Rs);Fe.existsSync(e)||Fe.mkdirSync(e,{recursive:!0});let t=this.history.slice(-Vi);Fe.writeFileSync(Rs,t.join(`
|
|
388
|
+
`),"utf-8")}catch{}}}});var Fn,zi=F(()=>{"use strict";Fn=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+`
|
|
390
389
|
|
|
391
|
-
`+i.systemPrompt,toolPreferences:[...new Set([...i.toolPreferences,...r.toolPreferences])],behaviorModifiers:{...r.behaviorModifiers,...i.behaviorModifiers}};return this.register(o),o}}});var Yi,Ji=
|
|
390
|
+
`+i.systemPrompt,toolPreferences:[...new Set([...i.toolPreferences,...r.toolPreferences])],behaviorModifiers:{...r.behaviorModifiers,...i.behaviorModifiers}};return this.register(o),o}}});var Yi,Ji=F(()=>{"use strict";Yi={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.
|
|
392
391
|
|
|
393
392
|
## Your Strengths
|
|
394
393
|
- Writing clean, production-ready code with proper error handling
|
|
@@ -420,7 +419,7 @@ ${c.content}`),a+=c.tokenCount}return l.join(`
|
|
|
420
419
|
|
|
421
420
|
## Important
|
|
422
421
|
Never output tool calls as text or JSON in your response.
|
|
423
|
-
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 Qi
|
|
422
|
+
Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","patch_file","edit_file","write_file","search_codebase","run_command"],behaviorModifiers:{planFirst:!1,maxIterations:0,verbosity:"concise",autoConfirmSafe:!0,reasoning:"systematic",askWhenUncertain:!1,canDelegate:!1,contextPriority:"code"},filePatterns:["*.ts","*.js","*.tsx","*.jsx","*.py","*.go","*.rs","*.css","*.html"]}});var Xi,Qi=F(()=>{"use strict";Xi={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.
|
|
424
423
|
You coordinate a team of specialized agents to help developers build and modify their codebase, and you love helping the developer succeed with high-quality engineering.
|
|
425
424
|
|
|
426
425
|
## Your Persona (Supportive, Empathetic & Expert Engineering Lead)
|
|
@@ -462,7 +461,7 @@ Then execute step by step.
|
|
|
462
461
|
|
|
463
462
|
## Important
|
|
464
463
|
Never output tool calls as text or JSON in your response.
|
|
465
|
-
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 Zi,eo=
|
|
464
|
+
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 Zi,eo=F(()=>{"use strict";Zi={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.
|
|
466
465
|
|
|
467
466
|
## Review Checklist
|
|
468
467
|
- Security vulnerabilities (injection, XSS, CSRF, auth bypass)
|
|
@@ -496,7 +495,7 @@ For each issue:
|
|
|
496
495
|
|
|
497
496
|
## Important
|
|
498
497
|
Never output tool calls as text or JSON in your response.
|
|
499
|
-
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 to,no=
|
|
498
|
+
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 to,no=F(()=>{"use strict";to={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.
|
|
500
499
|
|
|
501
500
|
## Debugging Process
|
|
502
501
|
1. **Reproduce**: Understand the symptom and error message
|
|
@@ -518,7 +517,7 @@ Always use the tool_calls field provided by the API.`,toolPreferences:["read_fil
|
|
|
518
517
|
## Important
|
|
519
518
|
Never output tool calls as text or JSON in your response.
|
|
520
519
|
Always use the tool_calls field provided by the API.
|
|
521
|
-
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 so,ro=
|
|
520
|
+
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 so,ro=F(()=>{"use strict";so={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.
|
|
522
521
|
Your role is to design robust, scalable, maintainable system architectures.
|
|
523
522
|
|
|
524
523
|
## Your Strengths
|
|
@@ -554,7 +553,7 @@ Your role is to design robust, scalable, maintainable system architectures.
|
|
|
554
553
|
|
|
555
554
|
## Important
|
|
556
555
|
Never output tool calls as text or JSON in your response.
|
|
557
|
-
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 io,oo=
|
|
556
|
+
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 io,oo=F(()=>{"use strict";io={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.
|
|
558
557
|
|
|
559
558
|
## Your Expertise
|
|
560
559
|
- Docker & container orchestration (Kubernetes, Docker Compose)
|
|
@@ -585,7 +584,7 @@ Always use the tool_calls field provided by the API.`,toolPreferences:["read_fil
|
|
|
585
584
|
|
|
586
585
|
## Important
|
|
587
586
|
Never output tool calls as text or JSON in your response.
|
|
588
|
-
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 ao,lo=
|
|
587
|
+
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 ao,lo=F(()=>{"use strict";ao={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.
|
|
589
588
|
Your role is to find information, analyze data, and provide well-researched context.
|
|
590
589
|
|
|
591
590
|
## Your Strengths
|
|
@@ -622,7 +621,7 @@ Your role is to find information, analyze data, and provide well-researched cont
|
|
|
622
621
|
|
|
623
622
|
## Important
|
|
624
623
|
Never output tool calls as text or JSON in your response.
|
|
625
|
-
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 co,uo=
|
|
624
|
+
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 co,uo=F(()=>{"use strict";co={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.
|
|
626
625
|
Your role is to analyze needs, create detailed specs, and ensure the team builds the right thing.
|
|
627
626
|
|
|
628
627
|
## Your Strengths
|
|
@@ -657,7 +656,7 @@ Every PRD you create should include:
|
|
|
657
656
|
|
|
658
657
|
## Important
|
|
659
658
|
Never output tool calls as text or JSON in your response.
|
|
660
|
-
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 fo,po=
|
|
659
|
+
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 fo,po=F(()=>{"use strict";fo={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.
|
|
661
660
|
Your absolute priority is to ensure smooth, conflict-free collaboration between human developers and machine agents.
|
|
662
661
|
|
|
663
662
|
## Your Personality (INTJ + Diplomatic Coordinator)
|
|
@@ -679,33 +678,33 @@ Your absolute priority is to ensure smooth, conflict-free collaboration between
|
|
|
679
678
|
|
|
680
679
|
## Important
|
|
681
680
|
Never output tool calls as text or JSON in your response.
|
|
682
|
-
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
|
|
681
|
+
Always use the tool_calls field provided by the API.`,toolPreferences:["read_file","list_dir","write_file","patch_file","run_command"],behaviorModifiers:{planFirst:!0,maxIterations:10,verbosity:"concise",autoConfirmSafe:!0,reasoning:"analytical",askWhenUncertain:!0,canDelegate:!1,contextPriority:"requirements"}}});function Ps(){let n=new Fn;return n.register(Yi),n.register(Xi),n.register(Zi),n.register(to),n.register(so),n.register(io),n.register(ao),n.register(co),n.register(fo),n}var ho=F(()=>{"use strict";zi();Ji();Qi();eo();no();ro();oo();lo();uo();po();zi();Ji();Qi();eo();no();ro();oo();lo();uo();po()});var $e,Ms,od,ad,cn,Is,ld=F(()=>{"use strict";$e=O(require("fs")),Ms=O(require("path")),od=O(require("os")),ad=O(require("crypto")),cn=Ms.join(od.homedir(),".hablas","memory"),Is=class{entries=new Map;agentLanes=new Map;projectHash;filePath;agentLanesPath;constructor(e){this.projectHash=ad.createHash("md5").update(e).digest("hex").slice(0,12),this.filePath=Ms.join(cn,`${this.projectHash}.json`),this.agentLanesPath=Ms.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 c=a.importance*(1+a.useCount*.3);return l.importance*(1+l.useCount*.3)-c}).slice(0,t);return i.length===0?"":`## Agent Memory
|
|
683
682
|
`+i.map(a=>`- [${a.category}${a.importance>=7?" \u2605":""}] ${a.key}: ${a.value}`).join(`
|
|
684
|
-
`)}search(e,t){let s=e.toLowerCase(),r=s.split(/\s+/).filter(l=>l.length>2),i=t?.maxResults||20,o=[],a=t?.agent?this.getAgentMemories(t.agent):this.getAll();for(let l of a){if(t?.category&&l.category!==t.category||t?.minImportance&&l.importance<t.minImportance)continue;let c=0,
|
|
685
|
-
`)}getStats(){let e=this.getAll(),t={},s={};for(let r of e)t[r.category]=(t[r.category]||0)+1,s[r.createdBy]=(s[r.createdBy]||0)+1;return{totalEntries:e.length,byCategory:t,byAgent:s,topAccessed:e.sort((r,i)=>i.accessCount-r.accessCount).slice(0,5),recentlyAdded:e.sort((r,i)=>i.createdAt-r.createdAt).slice(0,5),totalAccessCount:e.reduce((r,i)=>r+i.accessCount,0)}}consolidate(e=200){if(this.entries.size<=e)return 0;let t=Array.from(this.entries.values()).filter(o=>o.importance<4&&o.accessCount<3).sort((o,a)=>o.updatedAt-a.updatedAt),s=t.slice(0,Math.max(10,t.length-e)),r={};for(let o of s){let a=o.category;r[a]||(r[a]=[]),r[a].push(o)}let i=0;for(let[o,a]of Object.entries(r)){if(a.length<2)continue;let l=`[consolidated] ${o} (${a.length} items)`,c=a.map(h=>`${h.key}: ${h.value}`).join("; "),
|
|
686
|
-
`)}autoImportance(e,t){let r={convention:6,decision:8,pattern:5,note:3,error:7,"tool-result":2,"user-pref":7,dependency:4,performance:5,security:9,api:6,"agent-learning":4}[e]||3;return/\b(important|critical|must|always|never|danger|warning|breaking)\b/i.test(t)&&(r=Math.min(10,r+2)),r}autoTag(e,t){let s=[t];return/\b(react|vue|angular|svelte|next|nuxt)\b/i.test(e)&&s.push("frontend"),/\b(express|fastify|nest|koa|hapi)\b/i.test(e)&&s.push("backend"),/\b(postgres|mysql|mongo|redis|sqlite)\b/i.test(e)&&s.push("database"),/\b(docker|kubernetes|k8s|ci\/cd|deploy)\b/i.test(e)&&s.push("devops"),/\b(test|jest|vitest|cypress|playwright)\b/i.test(e)&&s.push("testing"),/\b(auth|jwt|oauth|session|token)\b/i.test(e)&&s.push("auth"),/\b(api|endpoint|route|rest|graphql)\b/i.test(e)&&s.push("api"),s}extractFileRefs(e){let t=/[\w\-./]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|scss|html|vue|svelte|go|rs|java|sql|sh|toml|xml|env)/gi,s=e.match(t);return s?[...new Set(s)]:[]}load(){try{if(
|
|
683
|
+
`)}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 c=0,u="partial";l.key.toLowerCase()===s&&(c+=10,u="exact"),l.key.toLowerCase().includes(s)&&(c+=5),l.value.toLowerCase().includes(s)&&(c+=3);for(let h of r)l.key.toLowerCase().includes(h)&&(c+=2),l.value.toLowerCase().includes(h)&&(c+=1),l.tags.some(m=>m.toLowerCase().includes(h))&&(c+=2,u=u==="exact"?"exact":"tag");c*=1+l.importance*.1,c*=1+l.useCount*.2;let f=(Date.now()-l.updatedAt)/(10080*60*1e3);c*=Math.max(.3,1-f*.1),c>.5&&o.push({entry:l,relevanceScore:c,matchType:u})}return o.sort((l,c)=>c.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(`
|
|
684
|
+
`)}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)`,c=a.map(h=>`${h.key}: ${h.value}`).join("; "),u=a.map(h=>h.key);this.set(l,c.slice(0,500),{category:o,importance:3,tags:["consolidated"]});let f=this.entries.get(l);f&&(f.consolidatedFrom=u);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(`
|
|
685
|
+
`)}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($e.existsSync(this.filePath)){let e=JSON.parse($e.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{$e.existsSync(cn)||$e.mkdirSync(cn,{recursive:!0});let e=Array.from(this.entries.values());$e.writeFileSync(this.filePath,JSON.stringify(e,null,2),"utf-8")}catch{}}loadAgentLanes(){try{if($e.existsSync(this.agentLanesPath)){let e=JSON.parse($e.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{$e.existsSync(cn)||$e.mkdirSync(cn,{recursive:!0});let e={};for(let[t,s]of this.agentLanes)e[t]=Array.from(s.values());$e.writeFileSync(this.agentLanesPath,JSON.stringify(e,null,2),"utf-8")}catch{}}}});var go=j((RE,dd)=>{"use strict";var Nn=n=>n&&typeof n.message=="string",mo=n=>{if(!n)return;let e=n.cause;if(typeof e=="function"){let t=n.cause();return Nn(t)?t:void 0}else return Nn(e)?e:void 0},cd=(n,e)=>{if(!Nn(n))return"";let t=n.stack||"";if(e.has(n))return t+`
|
|
687
686
|
causes have become circular...`;let s=mo(n);return s?(e.add(n),t+`
|
|
688
|
-
caused by: `+ud(s,e)):t},cb=n=>ud(n,new Set),dd=(n,e,t)=>{if(!Ln(n))return"";let s=t?"":n.message||"";if(e.has(n))return s+": ...";let r=mo(n);if(r){e.add(n);let i=typeof n.cause=="function";return s+(i?"":": ")+dd(r,e,i)}else return s},ub=n=>dd(n,new Set);fd.exports={isErrorLike:Ln,getErrorCause:mo,stackWithCauses:cb,messageWithCauses:ub}});var yo=H((yT,hd)=>{"use strict";var db=Symbol("circular-ref-tag"),Ms=Symbol("pino-raw-err-ref"),pd=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[Ms]},set:function(n){this[Ms]=n}}});Object.defineProperty(pd,Ms,{writable:!0,value:{}});hd.exports={pinoErrProto:pd,pinoErrorSymbols:{seen:db,rawSymbol:Ms}}});var yd=H((bT,gd)=>{"use strict";gd.exports=vo;var{messageWithCauses:fb,stackWithCauses:pb,isErrorLike:md}=go(),{pinoErrProto:hb,pinoErrorSymbols:mb}=yo(),{seen:bo}=mb,{toString:gb}=Object.prototype;function vo(n){if(!md(n))return n;n[bo]=void 0;let e=Object.create(hb);e.type=gb.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=fb(n),e.stack=pb(n),Array.isArray(n.errors)&&(e.aggregateErrors=n.errors.map(t=>vo(t)));for(let t in n)if(e[t]===void 0){let s=n[t];md(s)?t!=="cause"&&!Object.prototype.hasOwnProperty.call(s,bo)&&(e[t]=vo(s)):e[t]=s}return delete n[bo],e.raw=n,e}});var vd=H((vT,bd)=>{"use strict";bd.exports=Ds;var{isErrorLike:wo}=go(),{pinoErrProto:yb,pinoErrorSymbols:bb}=yo(),{seen:Ls}=bb,{toString:vb}=Object.prototype;function Ds(n){if(!wo(n))return n;n[Ls]=void 0;let e=Object.create(yb);e.type=vb.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=>Ds(t))),wo(n.cause)&&!Object.prototype.hasOwnProperty.call(n.cause,Ls)&&(e.cause=Ds(n.cause));for(let t in n)if(e[t]===void 0){let s=n[t];wo(s)?Object.prototype.hasOwnProperty.call(s,Ls)||(e[t]=Ds(s)):e[t]=s}return delete n[Ls],e.raw=n,e}});var _d=H((wT,Sd)=>{"use strict";Sd.exports={mapHttpRequest:wb,reqSerializer:xd};var xo=Symbol("pino-raw-req-ref"),wd=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[xo]},set:function(n){this[xo]=n}}});Object.defineProperty(wd,xo,{writable:!0,value:{}});function xd(n){let e=n.info||n.socket,t=Object.create(wd);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 wb(n){return{req:xd(n)}}});var Ed=H((xT,$d)=>{"use strict";$d.exports={mapHttpResponse:xb,resSerializer:kd};var So=Symbol("pino-raw-res-ref"),Ad=Object.create({},{statusCode:{enumerable:!0,writable:!0,value:0},headers:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[So]},set:function(n){this[So]=n}}});Object.defineProperty(Ad,So,{writable:!0,value:{}});function kd(n){let e=Object.create(Ad);return e.statusCode=n.headersSent?n.statusCode:null,e.headers=n.getHeaders?n.getHeaders():n._headers,e.raw=n,e}function xb(n){return{res:kd(n)}}});var Ao=H((ST,Td)=>{"use strict";var _o=yd(),Sb=vd(),Ns=_d(),Fs=Ed();Td.exports={err:_o,errWithCause:Sb,mapHttpRequest:Ns.mapHttpRequest,mapHttpResponse:Fs.mapHttpResponse,req:Ns.reqSerializer,res:Fs.resSerializer,wrapErrorSerializer:function(e){return e===_o?e:function(s){return e(_o(s))}},wrapRequestSerializer:function(e){return e===Ns.reqSerializer?e:function(s){return e(Ns.reqSerializer(s))}},wrapResponseSerializer:function(e){return e===Fs.resSerializer?e:function(s){return e(Fs.resSerializer(s))}}}});var ko=H((_T,Cd)=>{"use strict";function _b(n,e){return e}Cd.exports=function(){let e=Error.prepareStackTrace;Error.prepareStackTrace=_b;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 Ld=H((AT,Md)=>{"use strict";function $o(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]=$o(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]=$o(n[t]));return e}return n}function Rd(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 Od(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 Pd(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 Hs=Symbol("PATH_NOT_FOUND");function Ab(n,e){let t=n;for(let s of e){if(t==null||typeof t!="object"||t===null||!(s in t))return Hs;t=t[s]}return t}function kb(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 $b(n,e,t,s=!1){for(let r of e){let i=Rd(r);if(i.includes("*"))Id(n,i,t,r,s);else if(s)Pd(n,i);else{let o=Ab(n,i);if(o===Hs)continue;let a=typeof t=="function"?t(o,i):t;Od(n,i,a)}}}function Id(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 c=[...o,l.toString()],d=typeof t=="function"?t(a[l],c):t;a[l]=d}else if(typeof a=="object"&&a!==null)if(r){let l=[];for(let c in a)Object.prototype.hasOwnProperty.call(a,c)&&l.push(c);for(let c of l)delete a[c]}else for(let l in a){let c=[...o,l],d=typeof t=="function"?t(a[l],c):t;a[l]=d}}else Eb(n,e,t,i,s,r)}function Eb(n,e,t,s,r,i=!1){let o=e.slice(0,s),a=e.slice(s+1),l=[];function c(d,f){if(f===o.length){if(Array.isArray(d))for(let h=0;h<d.length;h++)l[f]=h.toString(),c(d[h],f+1);else if(typeof d=="object"&&d!==null)for(let h in d)l[f]=h,c(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,c(d[h],f+1))}else if(a.includes("*"))Id(d,a,typeof t=="function"?(m,p)=>{let y=[...l.slice(0,f),...p];return t(m,y)}:t,r,i);else if(i)Pd(d,a);else{let h=typeof t=="function"?t(kb(d,a),[...l.slice(0,f),...a]):t;Od(d,a,h)}}if(o.length===0)c(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&&c(d,o.length)}}function Tb(n){if(n.length===0)return null;let e=new Map;for(let t of n){let s=Rd(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 Cb(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 c=l.toString();r.has(c)||r.has("*")?a[l]=t(s[l],r.get(c)||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 Rb(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 Ob(n){if(!Array.isArray(n))throw new TypeError("paths must be an array");for(let e of n)Rb(e)}function Pb(n={}){let{paths:e=[],censor:t="[REDACTED]",serialize:s=JSON.stringify,strict:r=!0,remove:i=!1}=n;Ob(e);let o=Tb(e);return function(l){if(r&&(l===null||typeof l!="object")&&(l==null||typeof l!="object"))return s?s(l):l;let c=Cb(l,o),d=l,f=t;return typeof t=="function"&&(f=t),$b(c,e,f,i),s===!1?(c.restore=function(){return $o(d)},c):typeof s=="function"?s(c):JSON.stringify(c)}}Md.exports=Pb});var cn=H((kT,Dd)=>{"use strict";var Ib=Symbol("pino.setLevel"),Mb=Symbol("pino.getLevel"),Lb=Symbol("pino.levelVal"),Db=Symbol("pino.levelComp"),Nb=Symbol("pino.useLevelLabels"),Fb=Symbol("pino.useOnlyCustomLevels"),Hb=Symbol("pino.mixin"),jb=Symbol("pino.lsCache"),Bb=Symbol("pino.chindings"),Ub=Symbol("pino.asJson"),Kb=Symbol("pino.write"),qb=Symbol("pino.redactFmt"),Wb=Symbol("pino.time"),Gb=Symbol("pino.timeSliceIndex"),Vb=Symbol("pino.stream"),zb=Symbol("pino.stringify"),Yb=Symbol("pino.stringifySafe"),Jb=Symbol("pino.stringifiers"),Qb=Symbol("pino.end"),Xb=Symbol("pino.formatOpts"),Zb=Symbol("pino.messageKey"),ev=Symbol("pino.errorKey"),tv=Symbol("pino.nestedKey"),nv=Symbol("pino.nestedKeyStr"),sv=Symbol("pino.mixinMergeStrategy"),rv=Symbol("pino.msgPrefix"),iv=Symbol("pino.wildcardFirst"),ov=Symbol.for("pino.serializers"),av=Symbol.for("pino.formatters"),lv=Symbol.for("pino.hooks"),cv=Symbol.for("pino.metadata");Dd.exports={setLevelSym:Ib,getLevelSym:Mb,levelValSym:Lb,levelCompSym:Db,useLevelLabelsSym:Nb,mixinSym:Hb,lsCacheSym:jb,chindingsSym:Bb,asJsonSym:Ub,writeSym:Kb,serializersSym:ov,redactFmtSym:qb,timeSym:Wb,timeSliceIndexSym:Gb,streamSym:Vb,stringifySym:zb,stringifySafeSym:Yb,stringifiersSym:Jb,endSym:Qb,formatOptsSym:Xb,messageKeySym:Zb,errorKeySym:ev,nestedKeySym:tv,wildcardFirstSym:iv,needsMetadataGsym:cv,useOnlyCustomLevelsSym:Fb,formattersSym:av,hooksSym:lv,nestedKeyStrSym:nv,mixinMergeStrategySym:sv,msgPrefixSym:rv}});var To=H(($T,jd)=>{"use strict";var Nd=Ld(),{redactFmtSym:uv,wildcardFirstSym:js}=cn(),Eo=/[^.[\]]+|\[([^[\]]*?)\]/g,Fd="[Redacted]",Hd=!1;function dv(n,e){let{paths:t,censor:s,remove:r}=fv(n),i=t.reduce((l,c)=>{Eo.lastIndex=0;let d=Eo.exec(c),f=Eo.exec(c),h=d[1]!==void 0?d[1].replace(/^(?:"|'|`)(.*)(?:"|'|`)$/,"$1"):d[0];if(h==="*"&&(h=js),f===null)return l[h]=null,l;if(l[h]===null)return l;let{index:m}=f,p=`${c.substr(m,c.length-1)}`;return l[h]=l[h]||[],h!==js&&l[h].length===0&&l[h].push(...l[js]||[]),h===js&&Object.keys(l).forEach(function(y){l[y]&&l[y].push(p)}),l[h].push(p),l},{}),o={[uv]:Nd({paths:t,censor:s,serialize:e,strict:Hd,remove:r})},a=(...l)=>e(typeof s=="function"?s(...l):s);return[...Object.keys(i),...Object.getOwnPropertySymbols(i)].reduce((l,c)=>{if(i[c]===null)l[c]=d=>a(d,[c]);else{let d=typeof s=="function"?(f,h)=>s(f,[c,...h]):s;l[c]=Nd({paths:i[c],censor:d,serialize:e,strict:Hd,remove:r})}return l},o)}function fv(n){if(Array.isArray(n))return n={paths:n,censor:Fd},n;let{paths:e,censor:t=Fd,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}}jd.exports=dv});var Kd=H((ET,Ud)=>{"use strict";var pv=()=>"",hv=()=>`,"time":${Date.now()}`,mv=()=>`,"time":${Math.round(Date.now()/1e3)}`,gv=()=>`,"time":"${new Date(Date.now()).toISOString()}"`,yv=1000000n,Bd=1000000000n,bv=BigInt(Date.now())*yv,vv=process.hrtime.bigint(),wv=()=>{let n=process.hrtime.bigint()-vv,e=bv+n,t=e/Bd,s=e%Bd,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"),c=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${c}:${d}:${f}.${s.toString().padStart(9,"0")}Z"`};Ud.exports={nullTime:pv,epochTime:hv,unixTime:mv,isoTime:gv,isoTimeNano:wv}});var Wd=H((TT,qd)=>{"use strict";function xv(n){try{return JSON.stringify(n)}catch{return'"[Circular]"'}}qd.exports=Sv;function Sv(n,e,t){var s=t&&t.stringify||xv,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 c="",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&&(c+=n.slice(f,m)),c+=Number(e[d]),f=m+2,m++;break;case 105:if(d>=l||e[d]==null)break;f<m&&(c+=n.slice(f,m)),c+=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&&(c+=n.slice(f,m));var p=typeof e[d];if(p==="string"){c+="'"+e[d]+"'",f=m+2,m++;break}if(p==="function"){c+=e[d].name||"<anonymous>",f=m+2,m++;break}c+=s(e[d]),f=m+2,m++;break;case 115:if(d>=l)break;f<m&&(c+=n.slice(f,m)),c+=String(e[d]),f=m+2,m++;break;case 37:f<m&&(c+=n.slice(f,m)),c+="%",f=m+2,m++,d--;break}++d}++m}return f===-1?n:(f<h&&(c+=n.slice(f)),c)}});var Ro=H((CT,Co)=>{"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));Co.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(););};Co.exports=n}});var Zd=H((RT,Xd)=>{"use strict";var re=require("fs"),_v=require("events"),Av=require("util").inherits,Gd=require("path"),Po=Ro(),kv=require("assert"),Bs=100,Us=Buffer.allocUnsafe(0),$v=16*1024,Vd="buffer",zd="utf8",[Ev,Tv]=(process.versions.node||"0.0").split(".").map(Number),Cv=Ev>=22&&Tv>=7;function Yd(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&&re.mkdirSync(Gd.dirname(n),{recursive:!0});let i=re.openSync(n,s,r);t(null,i)}catch(i){throw t(i),i}else e.mkdir?re.mkdir(Gd.dirname(n),{recursive:!0},i=>{if(i)return t(i);re.open(n,s,r,t)}):re.open(n,s,r,t)}function Ye(n){if(!(this instanceof Ye))return new Ye(n);let{fd:e,dest:t,minLength:s,maxLength:r,maxWrite:i,periodicFlush:o,sync:a,append:l=!0,mkdir:c,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||$v,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=c||!1;let p,y;if(h===Vd)this._writingBuf=Us,this.write=Pv,this.flush=Mv,this.flushSync=Dv,this._actualWrite=Fv,p=()=>re.writeSync(this.fd,this._writingBuf),y=()=>re.write(this.fd,this._writingBuf,this.release);else if(h===void 0||h===zd)this._writingBuf="",this.write=Ov,this.flush=Iv,this.flushSync=Lv,this._actualWrite=Nv,p=()=>Buffer.isBuffer(this._writingBuf)?re.writeSync(this.fd,this._writingBuf):re.writeSync(this.fd,this._writingBuf,"utf8"),y=()=>Buffer.isBuffer(this._writingBuf)?re.write(this.fd,this._writingBuf,this.release):re.write(this.fd,this._writingBuf,"utf8",this.release);else throw new Error(`SonicBoom supports "${zd}" and "${Vd}", but passed ${h}`);if(typeof e=="number")this.fd=e,process.nextTick(()=>this.emit("ready"));else if(typeof e=="string")Yd(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=(S,_)=>{if(S){if((S.code==="EAGAIN"||S.code==="EBUSY")&&this.retryEAGAIN(S,this._writingBuf.length,this._len-this._writingBuf.length))if(this.sync)try{Po(Bs),this.release(void 0,0)}catch(g){this.release(g)}else setTimeout(y,Bs);else this._writing=!1,this.emit("error",S);return}this.emit("write",_);let k=Oo(this._writingBuf,this._len,_);if(this._len=k.len,this._writingBuf=k.writingBuf,this._writingBuf.length){if(!this.sync){y();return}try{do{let g=p(),v=Oo(this._writingBuf,this._len,g);this._len=v.len,this._writingBuf=v.writingBuf}while(this._writingBuf.length)}catch(g){this.release(g);return}}this._fsync&&re.fsyncSync(this.fd);let A=this._len;this._reopening?(this._writing=!1,this._reopening=!1,this.reopen()):A>this.minLength?this._actualWrite():this._ending?A>0?this._actualWrite():(this._writing=!1,Ks(this)):(this._writing=!1,this.sync?this._asyncDrainScheduled||(this._asyncDrainScheduled=!0,process.nextTick(Rv,this)):this.emit("drain"))},this.on("newListener",function(S){S==="drain"&&(this._asyncDrainScheduled=!1)}),this._periodicFlush!==0&&(this._periodicFlushTimer=setInterval(()=>this.flush(null),this._periodicFlush),this._periodicFlushTimer.unref())}function Oo(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 Rv(n){n.listenerCount("drain")>0&&(n._asyncDrainScheduled=!1,n.emit("drain"))}Av(Ye,_v);function Jd(n,e){return n.length===0?Us:n.length===1?n[0]:Buffer.concat(n,e)}function Ov(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 Pv(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 Qd(n){this._flushPending=!0;let e=()=>{if(this._fsync)this._flushPending=!1,n();else try{re.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 Iv(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&&Qd.call(this,n),!this._writing&&(this._bufs.length===0&&this._bufs.push(""),this._actualWrite())}function Mv(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&&Qd.call(this,n),!this._writing&&(this._bufs.length===0&&(this._bufs.push([]),this._lens.push(0)),this._actualWrite())}Ye.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&&re.close(e,t=>{if(t)return this.emit("error",t)})}),Yd(this.file,this)};Ye.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():Ks(this)))};function Lv(){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)?re.writeSync(this.fd,n):re.writeSync(this.fd,n,"utf8"),t=Oo(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;Po(Bs)}}try{re.fsyncSync(this.fd)}catch{}}function Dv(){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=Us);let n=Us;for(;this._bufs.length||n.length;){n.length<=0&&(n=Jd(this._bufs[0],this._lens[0]));try{let e=re.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;Po(Bs)}}}Ye.prototype.destroy=function(){this.destroyed||Ks(this)};function Nv(){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)?re.writeSync(this.fd,this._writingBuf):re.writeSync(this.fd,this._writingBuf,"utf8");n(null,e)}catch(e){n(e)}else re.write(this.fd,this._writingBuf,n)}function Fv(){let n=this.release;if(this._writing=!0,this._writingBuf=this._writingBuf.length?this._writingBuf:Jd(this._bufs.shift(),this._lens.shift()),this.sync)try{let e=re.writeSync(this.fd,this._writingBuf);n(null,e)}catch(e){n(e)}else Cv&&(this._writingBuf=Buffer.from(this._writingBuf)),re.write(this.fd,this._writingBuf,n)}function Ks(n){if(n.fd===-1){n.once("ready",Ks.bind(null,n));return}n._periodicFlushTimer!==void 0&&clearInterval(n._periodicFlushTimer),n.destroyed=!0,n._bufs=[],n._lens=[],kv(typeof n.fd=="number",`sonic.fd must be a number, got ${typeof n.fd}`);try{re.fsync(n.fd,e)}catch{}function e(){n.fd!==1&&n.fd!==2?re.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")}}Ye.SonicBoom=Ye;Ye.default=Ye;Xd.exports=Ye});var Io=H((OT,rf)=>{"use strict";var Je={exit:[],beforeExit:[]},ef={exit:Bv,beforeExit:Uv},un;function Hv(){un===void 0&&(un=new FinalizationRegistry(Kv))}function jv(n){Je[n].length>0||process.on(n,ef[n])}function tf(n){Je[n].length>0||(process.removeListener(n,ef[n]),Je.exit.length===0&&Je.beforeExit.length===0&&(un=void 0))}function Bv(){nf("exit")}function Uv(){nf("beforeExit")}function nf(n){for(let e of Je[n]){let t=e.deref(),s=e.fn;t!==void 0&&s(t,n)}Je[n]=[]}function Kv(n){for(let e of["exit","beforeExit"]){let t=Je[e].indexOf(n);Je[e].splice(t,t+1),tf(e)}}function sf(n,e,t){if(e===void 0)throw new Error("the object can't be undefined");jv(n);let s=new WeakRef(e);s.fn=t,Hv(),un.register(e,s),Je[n].push(s)}function qv(n,e){sf("exit",n,e)}function Wv(n,e){sf("beforeExit",n,e)}function Gv(n){if(un!==void 0){un.unregister(n);for(let e of["exit","beforeExit"])Je[e]=Je[e].filter(t=>{let s=t.deref();return s&&s!==n}),tf(e)}}rf.exports={register:qv,registerBeforeExit:Wv,unregister:Gv}});var of=H((PT,Vv)=>{Vv.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 lf=H((IT,af)=>{"use strict";function zv(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())),c=Atomics.waitAsync(n,e,a,l);c.async?c.value.then(o):setImmediate(o)};o()}function Yv(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())),c=Atomics.waitAsync(n,e,t,l);c.async?c.value.then(d=>{if(d==="ok"){r(null,"ok");return}o()}):setImmediate(o)};o()}af.exports={wait:zv,waitDiff:Yv}});var uf=H((MT,cf)=>{"use strict";cf.exports={WRITE_INDEX:4,READ_INDEX:8,SEQ_INDEX:2}});var Sf=H((LT,xf)=>{"use strict";var{version:Jv}=of(),{EventEmitter:Qv}=require("events"),{Worker:Xv}=require("worker_threads"),{join:Zv}=require("path"),{pathToFileURL:ew}=require("url"),{wait:tw}=lf(),{WRITE_INDEX:bt,READ_INDEX:Ht,SEQ_INDEX:Mo}=uf(),nw=require("buffer"),sw=require("assert"),R=Symbol("kImpl"),rw=nw.constants.MAX_STRING_LENGTH;function df(){}function Fo(n,e){Atomics.add(n[R].state,Mo,1),e(),Atomics.add(n[R].state,Mo,1),Atomics.notify(n[R].state,Mo)}function ff(n){Fo(n,()=>{Atomics.store(n[R].state,Ht,0),Atomics.store(n[R].state,bt,0)})}var Dn=class{constructor(e){this._value=e}deref(){return this._value}},qs=class{register(){}unregister(){}},iw=process.env.NODE_V8_COVERAGE?qs:global.FinalizationRegistry||qs,ow=process.env.NODE_V8_COVERAGE?Dn:global.WeakRef||Dn,pf=new iw(n=>{n.exited||n.terminate()});function aw(n,e){let{filename:t,workerData:s}=e,i=("__bundlerPathsOverrides"in globalThis?globalThis.__bundlerPathsOverrides:{})["thread-stream-worker"]||Zv(__dirname,"lib","worker.js"),o=new Xv(i,{...e.workerOpts,name:e.workerOpts?.name||"thread-stream",trackUnmanagedFds:!1,workerData:{filename:t.indexOf("file://")===0?t:ew(t).href,dataBuf:n[R].dataBuf,stateBuf:n[R].stateBuf,workerData:{$context:{threadStreamVersion:Jv},...s}}});return o.stream=new Dn(n),o.on("message",lw),o.on("exit",gf),pf.register(n,o),o}function hf(n){sw(!n[R].sync),n[R].needDrain&&(n[R].needDrain=!1,n.emit("drain"))}function mf(n){for(;;){let e=Atomics.load(n[R].state,bt),t=n[R].data.length-e;if(t>0){if(n[R].bufLen===0){n[R].flushing=!1,n[R].ending?Ho(n):n[R].needDrain&&process.nextTick(hf,n);return}vf(n,t,df);continue}if(t===0){if(e===0&&n[R].bufLen===0)return;Ws(n,()=>{n.destroyed||(ff(n),mf(n))});return}He(n,new Error("overwritten"));return}}function lw(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 ow(e),Ws(e,()=>{e[R].ready=!0,e.emit("ready")});break;case"ERROR":He(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"){He(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:He(e,new Error("this should not happen: "+n.code))}}function gf(n){let e=this.stream.deref();e!==void 0&&(pf.unregister(e),e.worker.exited=!0,e.worker.off("exit",gf),He(e,n!==0?new Error("the worker thread exited"):null))}var Do=class extends Qv{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=aw(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 No(this,new Error("the worker has exited")),!1;if(this[R].ending)return No(this,new Error("the worker is ending")),!1;if(this[R].flushing&&this[R].bufLen+t.length>=rw)try{Lo(this),this[R].flushing=!0}catch(s){return He(this,s),!1}if(this[R].buf.push(t),this[R].bufLen+=t.length,this[R].sync)try{return Lo(this),!0}catch(s){return He(this,s),!1}return this[R].flushing||(this[R].flushing=!0,setImmediate(mf,this)),this[R].needDrain=this[R].data.length-this[R].bufLen-Atomics.load(this[R].state,bt)<=0,!this[R].needDrain}end(){this[R].destroyed||(this[R].ending=!0,Ho(this))}flush(e){e=typeof e=="function"?e:df,yf(this,t=>{if(t){process.nextTick(e,t);return}bf(this,e)})}flushSync(){this[R].destroyed||(Lo(this),wf(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 yf(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(yf,n,e);return}Ws(n,e)}function Ws(n,e){let t=Atomics.load(n[R].state,bt);tw(n[R].state,Ht,t,1/0,(s,r)=>{if(s){He(n,s),e(s);return}if(r!=="ok"){Ws(n,e);return}e()})}function bf(n,e){if(n[R].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[R].ready){let s=()=>{i(),bf(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),He(n,s),process.nextTick(e,s)}}function cw(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 No(n,e){setImmediate(()=>{n.emit("error",e)})}function He(n,e){n[R].destroyed||(n[R].destroyed=!0,cw(n,e),e&&(n[R].errored=e,No(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 vf(n,e,t){let r=Atomics.load(n[R].state,bt),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 Fo(n,()=>{Atomics.store(n[R].state,bt,r)}),t(),!0}function Ho(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,Ht);Fo(n,()=>{Atomics.store(n[R].state,bt,-1)});let t=0;for(;e!==-1;){if(Atomics.wait(n[R].state,Ht,e,1e3),e=Atomics.load(n[R].state,Ht),e===-2){He(n,new Error("end() failed"));return}if(++t===10){He(n,new Error("end() took too long (10s)"));return}}process.nextTick(()=>{n[R].finished=!0,n.emit("finish")})}catch(e){He(n,e)}}}function Lo(n){let e=()=>{n[R].ending?Ho(n):n[R].needDrain&&process.nextTick(hf,n)};for(n[R].flushing=!1;n[R].bufLen!==0;){let t=Atomics.load(n[R].state,bt),s=n[R].data.length-t;if(s===0){wf(n),ff(n);continue}else if(s<0)throw new Error("overwritten");vf(n,s,e)}}function wf(n){if(n[R].flushing)throw new Error("unable to flush while flushing");let e=Atomics.load(n[R].state,bt),t=0;for(;;){let s=Atomics.load(n[R].state,Ht);if(s===-2)throw Error("_flushSync failed");if(s!==e)Atomics.wait(n[R].state,Ht,s,1e3);else break;if(++t===10)throw new Error("_flushSync took too long (10s)")}}xf.exports=Do});var Uo=H((DT,kf)=>{"use strict";var{createRequire:uw}=require("module"),{existsSync:dw}=require("node:fs"),fw=ko(),{join:jo,isAbsolute:Af,sep:pw}=require("node:path"),{fileURLToPath:hw}=require("node:url"),mw=Ro(),Bo=Io(),gw=Sf();function yw(n){Bo.register(n,Sw),Bo.registerBeforeExit(n,_w),n.on("close",function(){Bo.unregister(n)})}function bw(){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 vw(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&&_f(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(_f(o)){s=!0;continue}}t.push(i)}return s?t.join(" "):n}function _f(n){let e=ww(n);if(!e)return!1;let t=e;if(t.startsWith("file://"))try{t=hw(t)}catch{return!1}return Af(t)&&!dw(t)}function ww(n){let e=n[0],t=n[n.length-1];return e==='"'&&t==='"'||e==="'"&&t==="'"?n.slice(1,-1):n}function xw(n,e,t,s,r){if(!t.execArgv&&bw()&&require.main===void 0&&(t={...t,execArgv:[]}),!t.env&&process.env.NODE_OPTIONS){let l=vw(process.env.NODE_OPTIONS);l!==process.env.NODE_OPTIONS&&(t={...t,env:{...process.env,NODE_OPTIONS:l}})}t={...t,name:r};let i=new gw({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&&yw(i)}function a(){i.closed||(i.flushSync(),mw(100),i.end())}return i}function Sw(n){n.ref(),n.flushSync(),n.end(),n.once("close",function(){n.unref()})}function _w(n){n.flushSync()}function Aw(n){let{pipeline:e,targets:t,levels:s,dedupe:r,worker:i={},caller:o=fw(),sync:a=!1}=n,l={...n.options},c=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"]||jo(__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(y=>({...y,level:p.level,target:m(y.target)})))):e&&(f=d["pino-worker"]||jo(__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 xw(m(f),l,i,a,h);function m(p){if(p=d[p]||p,Af(p)||p.indexOf("file://")===0)return p;if(p==="pino/file")return jo(__dirname,"..","file.js");let y;for(let S of c)try{let _=S==="node:repl"?process.cwd()+pw:S;y=uw(_).resolve(p);break}catch{continue}if(!y)throw new Error(`unable to determine transport target for "${p}"`);return y}}kf.exports=Aw});var zs=H((NT,Ff)=>{"use strict";var kw=require("node:diagnostics_channel"),$f=Wd(),{mapHttpRequest:$w,mapHttpResponse:Ew}=Ao(),qo=Zd(),Ef=Io(),{lsCacheSym:Tw,chindingsSym:Pf,writeSym:Tf,serializersSym:If,formatOptsSym:Cf,endSym:Cw,stringifiersSym:Mf,stringifySym:Lf,stringifySafeSym:Wo,wildcardFirstSym:Df,nestedKeySym:Rw,formattersSym:Nf,messageKeySym:Ow,errorKeySym:Pw,nestedKeyStrSym:Iw,msgPrefixSym:Gs}=cn(),{isMainThread:Mw}=require("worker_threads"),Lw=Uo(),[Dw]=process.versions.node.split(".").map(n=>Number(n)),Rf=kw.tracingChannel("pino_asJson"),Ko=Dw>=25?n=>JSON.stringify(n):Fw;function dn(){}function Nw(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=$w(s):typeof s.setHeader=="function"&&(s=Ew(s)));let o;i===null&&r.length===0?o=[null]:(i=r.shift(),o=r),typeof this[Gs]=="string"&&i!==void 0&&i!==null&&(i=this[Gs]+i),this[Tf](s,$f(i,o,this[Cf]),n)}else{let i=s===void 0?r.shift():s;typeof this[Gs]=="string"&&i!==void 0&&i!==null&&(i=this[Gs]+i),this[Tf](null,$f(i,r,this[Cf]),n)}}}function Fw(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 Hw(n,e,t,s){if(Rf.hasSubscribers===!1)return Of.call(this,n,e,t,s);let r={instance:this,arguments};return Rf.traceSync(Of,r,this,n,e,t,s)}function Of(n,e,t,s){let r=this[Lf],i=this[Wo],o=this[Mf],a=this[Cw],l=this[Pf],c=this[If],d=this[Nf],f=this[Ow],h=this[Pw],m=this[Tw][t]+s;m=m+l;let p;d.log&&(n=d.log(n));let y=o[Df],S="";for(let k in n)if(p=n[k],Object.prototype.hasOwnProperty.call(n,k)&&p!==void 0){c[k]?p=c[k](p):k===h&&c.err&&(p=c.err(p));let A=o[k]||y;switch(typeof p){case"undefined":case"function":continue;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":A&&(p=A(p));break;case"string":p=(A||Ko)(p);break;default:p=(A||r)(p,i)}if(p===void 0)continue;let g=Ko(k);S+=","+g+":"+p}let _="";if(e!==void 0){p=c[f]?c[f](e):e;let k=o[f]||y;switch(typeof p){case"function":break;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":k&&(p=k(p)),_=',"'+f+'":'+p;break;case"string":p=(k||Ko)(p),_=',"'+f+'":'+p;break;default:p=(k||r)(p,i),_=',"'+f+'":'+p}}return this[Rw]&&S?m+this[Iw]+S.slice(1)+"}"+_+a:m+S+_+a}function jw(n,e){let t,s=n[Pf],r=n[Lf],i=n[Wo],o=n[Mf],a=o[Df],l=n[If],c=n[Nf].bindings;e=c(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 Bw(n){return n.write!==n.constructor.prototype.write}function Vs(n){let e=new qo(n);return e.on("error",t),!n.sync&&Mw&&(Ef.register(e,Uw),e.on("close",function(){Ef.unregister(e)})),e;function t(s){if(s.code==="EPIPE"){e.write=dn,e.end=dn,e.flushSync=dn,e.destroy=dn;return}e.removeListener("error",t),e.emit("error",s)}}function Uw(n,e){n.destroyed||(e==="beforeExit"?(n.flush(),n.on("drain",function(){n.end()})):n.flushSync())}function Kw(n){return function(t,s,r={},i){if(typeof r=="string")i=Vs({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=Vs({dest:i})}else if(r instanceof qo||r.writable||r._writableState)i=r,r={};else if(r.transport){if(r.transport instanceof qo||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=Lw({caller:s,...r.transport,levels:l})}if(r=Object.assign({},n,r),r.serializers=Object.assign({},n.serializers,r.serializers),r.formatters=Object.assign({},n.formatters,r.formatters),r.prettyPrint)throw new Error("prettyPrint option is no longer supported, see the pino-pretty package (https://github.com/pinojs/pino-pretty)");let{enabled:o,onChild:a}=r;return o===!1&&(r.level="silent"),a||(r.onChild=dn),i||(Bw(process.stdout)?i=process.stdout:i=Vs({fd:process.stdout.fd||1})),{opts:r,stream:i}}}function qw(n,e){try{return JSON.stringify(n)}catch{try{return(e||this[Wo])(n)}catch{return'"[unable to serialize, circular reference is too complex to analyze]"'}}}function Ww(n,e,t){return{level:n,bindings:e,log:t}}function Gw(n){let e=Number(n);return typeof n=="string"&&Number.isFinite(e)?e:n===void 0?1:n}Ff.exports={noop:dn,buildSafeSonicBoom:Vs,asChindings:jw,asJson:Hw,genLog:Nw,createArgsNormalizer:Kw,stringify:qw,buildFormatters:Ww,normalizeDestFileDescriptor:Gw}});var Ys=H((FT,Hf)=>{var Vw={trace:10,debug:20,info:30,warn:40,error:50,fatal:60},zw={ASC:"ASC",DESC:"DESC"};Hf.exports={DEFAULT_LEVELS:Vw,SORTING_ORDER:zw}});var zo=H((HT,Kf)=>{"use strict";var{lsCacheSym:Yw,levelValSym:Go,useOnlyCustomLevelsSym:Jw,streamSym:Qw,formattersSym:Xw,hooksSym:Zw,levelCompSym:jf}=cn(),{noop:ex,genLog:jt}=zs(),{DEFAULT_LEVELS:st,SORTING_ORDER:Bf}=Ys(),Uf={fatal:n=>{let e=jt(st.fatal,n);return function(...t){let s=this[Qw];if(e.call(this,...t),typeof s.flushSync=="function")try{s.flushSync()}catch{}}},error:n=>jt(st.error,n),warn:n=>jt(st.warn,n),info:n=>jt(st.info,n),debug:n=>jt(st.debug,n),trace:n=>jt(st.trace,n)},Vo=Object.keys(st).reduce((n,e)=>(n[st[e]]=e,n),{}),tx=Object.keys(Vo).reduce((n,e)=>(n[e]='{"level":'+Number(e),n),{});function nx(n){let e=n[Xw].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[Yw]=s,n}function sx(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 rx(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[Go],r=this[Go]=t[n],i=this[Jw],o=this[jf],a=this[Zw].logMethod;for(let l in t){if(o(t[l],r)===!1){this[l]=ex;continue}this[l]=sx(l,i)?Uf[l](a):jt(t[l],a)}this.emit("level-change",n,r,e[s],s,this)}function ix(n){let{levels:e,levelVal:t}=this;return e&&e.labels?e.labels[t]:""}function ox(n){let{values:e}=this.levels,t=e[n];return t!==void 0&&this[jf](t,this[Go])}function ax(n,e,t){return n===Bf.DESC?e<=t:e>=t}function lx(n){return typeof n=="string"?ax.bind(null,n):n}function cx(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:Vo,t),r=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),e?null:st,n);return{labels:s,values:r}}function ux(n,e,t){if(typeof n=="number"){if(![].concat(Object.keys(e||{}).map(i=>e[i]),t?[]:Object.keys(Vo).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:st,e);if(!(n in s))throw Error(`default level:${n} must be included in custom levels`)}function dx(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 fx(n){if(typeof n!="function"&&!(typeof n=="string"&&Object.values(Bf).includes(n)))throw new Error('Levels comparison should be one of "ASC", "DESC" or "function" type')}Kf.exports={initialLsCache:tx,genLsCache:nx,levelMethods:Uf,getLevel:ix,setLevel:rx,isLevelEnabled:ox,mappings:cx,assertNoLevelCollisions:dx,assertDefaultLevelFound:ux,genLevelComparison:lx,assertLevelComparison:fx}});var Yo=H((jT,qf)=>{"use strict";qf.exports={version:"10.3.1"}});var Xf=H((UT,Qf)=>{"use strict";var{EventEmitter:px}=require("node:events"),{lsCacheSym:hx,levelValSym:mx,setLevelSym:Qo,getLevelSym:Wf,chindingsSym:Qs,mixinSym:gx,asJsonSym:Vf,writeSym:yx,mixinMergeStrategySym:bx,timeSym:vx,timeSliceIndexSym:wx,streamSym:zf,serializersSym:Bt,formattersSym:Nn,errorKeySym:xx,messageKeySym:Sx,useOnlyCustomLevelsSym:_x,needsMetadataGsym:Ax,redactFmtSym:kx,stringifySym:$x,formatOptsSym:Ex,stringifiersSym:Tx,msgPrefixSym:Xo,hooksSym:Cx}=cn(),{getLevel:Rx,setLevel:Ox,isLevelEnabled:Px,mappings:Ix,initialLsCache:Mx,genLsCache:Lx,assertNoLevelCollisions:Dx}=zo(),{asChindings:Zo,asJson:Nx,buildFormatters:Jo,stringify:Gf,noop:Yf}=zs(),{version:Fx}=Yo(),Hx=To(),jx=class{},Jf={constructor:jx,child:Bx,bindings:Ux,setBindings:Kx,flush:Gx,isLevelEnabled:Px,version:Fx,get level(){return this[Wf]()},set level(n){this[Qo](n)},get levelVal(){return this[mx]},set levelVal(n){throw Error("levelVal is read-only")},get msgPrefix(){return this[Xo]},get[Symbol.toStringTag](){return"Pino"},[hx]:Mx,[yx]:Wx,[Vf]:Nx,[Wf]:Rx,[Qo]:Ox};Object.setPrototypeOf(Jf,px.prototype);Qf.exports=function(){return Object.create(Jf)};var Js=n=>n;function Bx(n,e){if(!n)throw Error("missing bindings for child Pino");let t=this[Bt],s=this[Nn],r=Object.create(this);if(e==null)return r[Nn].bindings!==Js&&(r[Nn]=Jo(s.level,Js,s.log)),r[Qs]=Zo(r,n),this.onChild!==Yf&&this.onChild(r),r;if(e.hasOwnProperty("serializers")===!0){r[Bt]=Object.create(null);for(let c in t)r[Bt][c]=t[c];let a=Object.getOwnPropertySymbols(t);for(var i=0;i<a.length;i++){let c=a[i];r[Bt][c]=t[c]}for(let c in e.serializers)r[Bt][c]=e.serializers[c];let l=Object.getOwnPropertySymbols(e.serializers);for(var o=0;o<l.length;o++){let c=l[o];r[Bt][c]=e.serializers[c]}}else r[Bt]=t;if(e.hasOwnProperty("formatters")){let{level:a,bindings:l,log:c}=e.formatters;r[Nn]=Jo(a||s.level,l||Js,c||s.log)}else r[Nn]=Jo(s.level,Js,s.log);if(e.hasOwnProperty("customLevels")===!0&&(Dx(this.levels,e.customLevels),r.levels=Ix(e.customLevels,r[_x]),Lx(r)),typeof e.redact=="object"&&e.redact!==null||Array.isArray(e.redact)){r.redact=e.redact;let a=Hx(r.redact,Gf),l={stringify:a[kx]};r[$x]=Gf,r[Tx]=a,r[Ex]=l}if(typeof e.msgPrefix=="string"&&(r[Xo]=(this[Xo]||"")+e.msgPrefix),r[Qs]=Zo(r,n),e.level!==void 0&&e.level!==this.level||e.hasOwnProperty("customLevels")){let a=e.level||this.level;r[Qo](a)}return this.onChild(r),r}function Ux(){let e=`{${this[Qs].substr(1)}}`,t=JSON.parse(e);return delete t.pid,delete t.hostname,t}function Kx(n){let e=Zo(this,n);this[Qs]=e}function qx(n,e){return Object.assign(e,n)}function Wx(n,e,t){let s=this[vx](),r=this[gx],i=this[xx],o=this[Sx],a=this[bx]||qx,l,c=this[Cx].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[Vf](l,e,t,s),f=this[zf];f[Ax]===!0&&(f.lastLevel=t,f.lastObj=l,f.lastMsg=e,f.lastTime=s.slice(this[wx]),f.lastLogger=this),f.write(c?c(d):d)}function Gx(n){if(n!=null&&typeof n!="function")throw Error("callback must be a function");let e=this[zf];typeof e.flush=="function"?e.flush(n||Yf):n&&n()}});var np=H((sa,tp)=>{"use strict";var{hasOwnProperty:Fn}=Object.prototype,Kt=na();Kt.configure=na;Kt.stringify=Kt;Kt.default=Kt;sa.stringify=Kt;sa.configure=na;tp.exports=Kt;var Vx=/[\u0000-\u001f\u0022\u005c\ud800-\udfff]/;function Ot(n){return n.length<5e3&&!Vx.test(n)?`"${n}"`:JSON.stringify(n)}function ea(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 zx=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(Object.getPrototypeOf(new Int8Array)),Symbol.toStringTag).get;function ta(n){return zx.call(n)!==void 0&&n.length!==0}function Zf(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 Yx(n){if(Fn.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 Jx(n){let e;if(Fn.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 Qx(n,e){let t;if(Fn.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 ep(n,e){let t;if(Fn.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 Ut(n){return n===1?"1 item":`${n} items`}function Xx(n){let e=new Set;for(let t of n)(typeof t=="string"||typeof t=="number")&&e.add(String(t));return e}function Zx(n){if(Fn.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 na(n){n={...n};let e=Zx(n);e&&(n.bigint===void 0&&(n.bigint=!1),"circularValue"in n||(n.circularValue=Error));let t=Yx(n),s=Qx(n,"bigint"),r=Jx(n),i=typeof r=="function"?r:void 0,o=ep(n,"maximumDepth"),a=ep(n,"maximumBreadth");function l(m,p,y,S,_,k){let A=p[m];switch(typeof A=="object"&&A!==null&&typeof A.toJSON=="function"&&(A=A.toJSON(m)),A=S.call(p,m,A),typeof A){case"string":return Ot(A);case"object":{if(A===null)return"null";if(y.indexOf(A)!==-1)return t;let g="",v=",",b=k;if(Array.isArray(A)){if(A.length===0)return"[]";if(o<y.length+1)return'"[Array]"';y.push(A),_!==""&&(k+=_,g+=`
|
|
689
|
-
${
|
|
690
|
-
${
|
|
691
|
-
${b}`),
|
|
692
|
-
${
|
|
693
|
-
${
|
|
694
|
-
${b}`),
|
|
695
|
-
${
|
|
696
|
-
${
|
|
697
|
-
${
|
|
698
|
-
${
|
|
699
|
-
${
|
|
700
|
-
${
|
|
701
|
-
${
|
|
702
|
-
${
|
|
703
|
-
${
|
|
704
|
-
${
|
|
705
|
-
${
|
|
706
|
-
${
|
|
687
|
+
caused by: `+cd(s,e)):t},mb=n=>cd(n,new Set),ud=(n,e,t)=>{if(!Nn(n))return"";let s=t?"":n.message||"";if(e.has(n))return s+": ...";let r=mo(n);if(r){e.add(n);let i=typeof n.cause=="function";return s+(i?"":": ")+ud(r,e,i)}else return s},gb=n=>ud(n,new Set);dd.exports={isErrorLike:Nn,getErrorCause:mo,stackWithCauses:mb,messageWithCauses:gb}});var yo=j((OE,pd)=>{"use strict";var yb=Symbol("circular-ref-tag"),Ls=Symbol("pino-raw-err-ref"),fd=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[Ls]},set:function(n){this[Ls]=n}}});Object.defineProperty(fd,Ls,{writable:!0,value:{}});pd.exports={pinoErrProto:fd,pinoErrorSymbols:{seen:yb,rawSymbol:Ls}}});var gd=j((PE,md)=>{"use strict";md.exports=vo;var{messageWithCauses:bb,stackWithCauses:vb,isErrorLike:hd}=go(),{pinoErrProto:wb,pinoErrorSymbols:xb}=yo(),{seen:bo}=xb,{toString:Sb}=Object.prototype;function vo(n){if(!hd(n))return n;n[bo]=void 0;let e=Object.create(wb);e.type=Sb.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=bb(n),e.stack=vb(n),Array.isArray(n.errors)&&(e.aggregateErrors=n.errors.map(t=>vo(t)));for(let t in n)if(e[t]===void 0){let s=n[t];hd(s)?t!=="cause"&&!Object.prototype.hasOwnProperty.call(s,bo)&&(e[t]=vo(s)):e[t]=s}return delete n[bo],e.raw=n,e}});var bd=j((ME,yd)=>{"use strict";yd.exports=Fs;var{isErrorLike:wo}=go(),{pinoErrProto:_b,pinoErrorSymbols:Ab}=yo(),{seen:Ds}=Ab,{toString:kb}=Object.prototype;function Fs(n){if(!wo(n))return n;n[Ds]=void 0;let e=Object.create(_b);e.type=kb.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=>Fs(t))),wo(n.cause)&&!Object.prototype.hasOwnProperty.call(n.cause,Ds)&&(e.cause=Fs(n.cause));for(let t in n)if(e[t]===void 0){let s=n[t];wo(s)?Object.prototype.hasOwnProperty.call(s,Ds)||(e[t]=Fs(s)):e[t]=s}return delete n[Ds],e.raw=n,e}});var Sd=j((IE,xd)=>{"use strict";xd.exports={mapHttpRequest:$b,reqSerializer:wd};var xo=Symbol("pino-raw-req-ref"),vd=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[xo]},set:function(n){this[xo]=n}}});Object.defineProperty(vd,xo,{writable:!0,value:{}});function wd(n){let e=n.info||n.socket,t=Object.create(vd);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 $b(n){return{req:wd(n)}}});var $d=j((LE,kd)=>{"use strict";kd.exports={mapHttpResponse:Cb,resSerializer:Ad};var So=Symbol("pino-raw-res-ref"),_d=Object.create({},{statusCode:{enumerable:!0,writable:!0,value:0},headers:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[So]},set:function(n){this[So]=n}}});Object.defineProperty(_d,So,{writable:!0,value:{}});function Ad(n){let e=Object.create(_d);return e.statusCode=n.headersSent?n.statusCode:null,e.headers=n.getHeaders?n.getHeaders():n._headers,e.raw=n,e}function Cb(n){return{res:Ad(n)}}});var Ao=j((DE,Cd)=>{"use strict";var _o=gd(),Eb=bd(),Ns=Sd(),js=$d();Cd.exports={err:_o,errWithCause:Eb,mapHttpRequest:Ns.mapHttpRequest,mapHttpResponse:js.mapHttpResponse,req:Ns.reqSerializer,res:js.resSerializer,wrapErrorSerializer:function(e){return e===_o?e:function(s){return e(_o(s))}},wrapRequestSerializer:function(e){return e===Ns.reqSerializer?e:function(s){return e(Ns.reqSerializer(s))}},wrapResponseSerializer:function(e){return e===js.resSerializer?e:function(s){return e(js.resSerializer(s))}}}});var ko=j((FE,Ed)=>{"use strict";function Tb(n,e){return e}Ed.exports=function(){let e=Error.prepareStackTrace;Error.prepareStackTrace=Tb;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 Id=j((NE,Md)=>{"use strict";function $o(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]=$o(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]=$o(n[t]));return e}return n}function Td(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 Rd(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 Od(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 Hs=Symbol("PATH_NOT_FOUND");function Rb(n,e){let t=n;for(let s of e){if(t==null||typeof t!="object"||t===null||!(s in t))return Hs;t=t[s]}return t}function Ob(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 Pb(n,e,t,s=!1){for(let r of e){let i=Td(r);if(i.includes("*"))Pd(n,i,t,r,s);else if(s)Od(n,i);else{let o=Rb(n,i);if(o===Hs)continue;let a=typeof t=="function"?t(o,i):t;Rd(n,i,a)}}}function Pd(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 c=[...o,l.toString()],u=typeof t=="function"?t(a[l],c):t;a[l]=u}else if(typeof a=="object"&&a!==null)if(r){let l=[];for(let c in a)Object.prototype.hasOwnProperty.call(a,c)&&l.push(c);for(let c of l)delete a[c]}else for(let l in a){let c=[...o,l],u=typeof t=="function"?t(a[l],c):t;a[l]=u}}else Mb(n,e,t,i,s,r)}function Mb(n,e,t,s,r,i=!1){let o=e.slice(0,s),a=e.slice(s+1),l=[];function c(u,f){if(f===o.length){if(Array.isArray(u))for(let h=0;h<u.length;h++)l[f]=h.toString(),c(u[h],f+1);else if(typeof u=="object"&&u!==null)for(let h in u)l[f]=h,c(u[h],f+1)}else if(f<o.length){let h=o[f];u&&typeof u=="object"&&u!==null&&h in u&&(l[f]=h,c(u[h],f+1))}else if(a.includes("*"))Pd(u,a,typeof t=="function"?(m,p)=>{let g=[...l.slice(0,f),...p];return t(m,g)}:t,r,i);else if(i)Od(u,a);else{let h=typeof t=="function"?t(Ob(u,a),[...l.slice(0,f),...a]):t;Rd(u,a,h)}}if(o.length===0)c(n,0);else{let u=n;for(let f=0;f<o.length;f++){let h=o[f];if(u==null||typeof u!="object"||u===null)return;u=u[h],l[f]=h}u!=null&&c(u,o.length)}}function Ib(n){if(n.length===0)return null;let e=new Map;for(let t of n){let s=Td(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 Lb(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 c=l.toString();r.has(c)||r.has("*")?a[l]=t(s[l],r.get(c)||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 Db(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 Fb(n){if(!Array.isArray(n))throw new TypeError("paths must be an array");for(let e of n)Db(e)}function Nb(n={}){let{paths:e=[],censor:t="[REDACTED]",serialize:s=JSON.stringify,strict:r=!0,remove:i=!1}=n;Fb(e);let o=Ib(e);return function(l){if(r&&(l===null||typeof l!="object")&&(l==null||typeof l!="object"))return s?s(l):l;let c=Lb(l,o),u=l,f=t;return typeof t=="function"&&(f=t),Pb(c,e,f,i),s===!1?(c.restore=function(){return $o(u)},c):typeof s=="function"?s(c):JSON.stringify(c)}}Md.exports=Nb});var un=j((jE,Ld)=>{"use strict";var jb=Symbol("pino.setLevel"),Hb=Symbol("pino.getLevel"),Bb=Symbol("pino.levelVal"),Ub=Symbol("pino.levelComp"),qb=Symbol("pino.useLevelLabels"),Kb=Symbol("pino.useOnlyCustomLevels"),Wb=Symbol("pino.mixin"),Gb=Symbol("pino.lsCache"),Vb=Symbol("pino.chindings"),zb=Symbol("pino.asJson"),Yb=Symbol("pino.write"),Jb=Symbol("pino.redactFmt"),Xb=Symbol("pino.time"),Qb=Symbol("pino.timeSliceIndex"),Zb=Symbol("pino.stream"),ev=Symbol("pino.stringify"),tv=Symbol("pino.stringifySafe"),nv=Symbol("pino.stringifiers"),sv=Symbol("pino.end"),rv=Symbol("pino.formatOpts"),iv=Symbol("pino.messageKey"),ov=Symbol("pino.errorKey"),av=Symbol("pino.nestedKey"),lv=Symbol("pino.nestedKeyStr"),cv=Symbol("pino.mixinMergeStrategy"),uv=Symbol("pino.msgPrefix"),dv=Symbol("pino.wildcardFirst"),fv=Symbol.for("pino.serializers"),pv=Symbol.for("pino.formatters"),hv=Symbol.for("pino.hooks"),mv=Symbol.for("pino.metadata");Ld.exports={setLevelSym:jb,getLevelSym:Hb,levelValSym:Bb,levelCompSym:Ub,useLevelLabelsSym:qb,mixinSym:Wb,lsCacheSym:Gb,chindingsSym:Vb,asJsonSym:zb,writeSym:Yb,serializersSym:fv,redactFmtSym:Jb,timeSym:Xb,timeSliceIndexSym:Qb,streamSym:Zb,stringifySym:ev,stringifySafeSym:tv,stringifiersSym:nv,endSym:sv,formatOptsSym:rv,messageKeySym:iv,errorKeySym:ov,nestedKeySym:av,wildcardFirstSym:dv,needsMetadataGsym:mv,useOnlyCustomLevelsSym:Kb,formattersSym:pv,hooksSym:hv,nestedKeyStrSym:lv,mixinMergeStrategySym:cv,msgPrefixSym:uv}});var Eo=j((HE,jd)=>{"use strict";var Dd=Id(),{redactFmtSym:gv,wildcardFirstSym:Bs}=un(),Co=/[^.[\]]+|\[([^[\]]*?)\]/g,Fd="[Redacted]",Nd=!1;function yv(n,e){let{paths:t,censor:s,remove:r}=bv(n),i=t.reduce((l,c)=>{Co.lastIndex=0;let u=Co.exec(c),f=Co.exec(c),h=u[1]!==void 0?u[1].replace(/^(?:"|'|`)(.*)(?:"|'|`)$/,"$1"):u[0];if(h==="*"&&(h=Bs),f===null)return l[h]=null,l;if(l[h]===null)return l;let{index:m}=f,p=`${c.substr(m,c.length-1)}`;return l[h]=l[h]||[],h!==Bs&&l[h].length===0&&l[h].push(...l[Bs]||[]),h===Bs&&Object.keys(l).forEach(function(g){l[g]&&l[g].push(p)}),l[h].push(p),l},{}),o={[gv]:Dd({paths:t,censor:s,serialize:e,strict:Nd,remove:r})},a=(...l)=>e(typeof s=="function"?s(...l):s);return[...Object.keys(i),...Object.getOwnPropertySymbols(i)].reduce((l,c)=>{if(i[c]===null)l[c]=u=>a(u,[c]);else{let u=typeof s=="function"?(f,h)=>s(f,[c,...h]):s;l[c]=Dd({paths:i[c],censor:u,serialize:e,strict:Nd,remove:r})}return l},o)}function bv(n){if(Array.isArray(n))return n={paths:n,censor:Fd},n;let{paths:e,censor:t=Fd,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}}jd.exports=yv});var Ud=j((BE,Bd)=>{"use strict";var vv=()=>"",wv=()=>`,"time":${Date.now()}`,xv=()=>`,"time":${Math.round(Date.now()/1e3)}`,Sv=()=>`,"time":"${new Date(Date.now()).toISOString()}"`,_v=1000000n,Hd=1000000000n,Av=BigInt(Date.now())*_v,kv=process.hrtime.bigint(),$v=()=>{let n=process.hrtime.bigint()-kv,e=Av+n,t=e/Hd,s=e%Hd,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"),c=i.getUTCHours().toString().padStart(2,"0"),u=i.getUTCMinutes().toString().padStart(2,"0"),f=i.getUTCSeconds().toString().padStart(2,"0");return`,"time":"${o}-${a}-${l}T${c}:${u}:${f}.${s.toString().padStart(9,"0")}Z"`};Bd.exports={nullTime:vv,epochTime:wv,unixTime:xv,isoTime:Sv,isoTimeNano:$v}});var Kd=j((UE,qd)=>{"use strict";function Cv(n){try{return JSON.stringify(n)}catch{return'"[Circular]"'}}qd.exports=Ev;function Ev(n,e,t){var s=t&&t.stringify||Cv,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 c="",u=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(u>=l||e[u]==null)break;f<m&&(c+=n.slice(f,m)),c+=Number(e[u]),f=m+2,m++;break;case 105:if(u>=l||e[u]==null)break;f<m&&(c+=n.slice(f,m)),c+=Math.floor(Number(e[u])),f=m+2,m++;break;case 79:case 111:case 106:if(u>=l||e[u]===void 0)break;f<m&&(c+=n.slice(f,m));var p=typeof e[u];if(p==="string"){c+="'"+e[u]+"'",f=m+2,m++;break}if(p==="function"){c+=e[u].name||"<anonymous>",f=m+2,m++;break}c+=s(e[u]),f=m+2,m++;break;case 115:if(u>=l)break;f<m&&(c+=n.slice(f,m)),c+=String(e[u]),f=m+2,m++;break;case 37:f<m&&(c+=n.slice(f,m)),c+="%",f=m+2,m++,u--;break}++u}++m}return f===-1?n:(f<h&&(c+=n.slice(f)),c)}});var Ro=j((qE,To)=>{"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));To.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(););};To.exports=n}});var Qd=j((KE,Xd)=>{"use strict";var re=require("fs"),Tv=require("events"),Rv=require("util").inherits,Wd=require("path"),Po=Ro(),Ov=require("assert"),Us=100,qs=Buffer.allocUnsafe(0),Pv=16*1024,Gd="buffer",Vd="utf8",[Mv,Iv]=(process.versions.node||"0.0").split(".").map(Number),Lv=Mv>=22&&Iv>=7;function zd(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&&re.mkdirSync(Wd.dirname(n),{recursive:!0});let i=re.openSync(n,s,r);t(null,i)}catch(i){throw t(i),i}else e.mkdir?re.mkdir(Wd.dirname(n),{recursive:!0},i=>{if(i)return t(i);re.open(n,s,r,t)}):re.open(n,s,r,t)}function ze(n){if(!(this instanceof ze))return new ze(n);let{fd:e,dest:t,minLength:s,maxLength:r,maxWrite:i,periodicFlush:o,sync:a,append:l=!0,mkdir:c,retryEAGAIN:u,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||Pv,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=u||(()=>!0),this.mkdir=c||!1;let p,g;if(h===Gd)this._writingBuf=qs,this.write=Nv,this.flush=Hv,this.flushSync=Uv,this._actualWrite=Kv,p=()=>re.writeSync(this.fd,this._writingBuf),g=()=>re.write(this.fd,this._writingBuf,this.release);else if(h===void 0||h===Vd)this._writingBuf="",this.write=Fv,this.flush=jv,this.flushSync=Bv,this._actualWrite=qv,p=()=>Buffer.isBuffer(this._writingBuf)?re.writeSync(this.fd,this._writingBuf):re.writeSync(this.fd,this._writingBuf,"utf8"),g=()=>Buffer.isBuffer(this._writingBuf)?re.write(this.fd,this._writingBuf,this.release):re.write(this.fd,this._writingBuf,"utf8",this.release);else throw new Error(`SonicBoom supports "${Vd}" and "${Gd}", but passed ${h}`);if(typeof e=="number")this.fd=e,process.nextTick(()=>this.emit("ready"));else if(typeof e=="string")zd(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,S)=>{if(x){if((x.code==="EAGAIN"||x.code==="EBUSY")&&this.retryEAGAIN(x,this._writingBuf.length,this._len-this._writingBuf.length))if(this.sync)try{Po(Us),this.release(void 0,0)}catch(y){this.release(y)}else setTimeout(g,Us);else this._writing=!1,this.emit("error",x);return}this.emit("write",S);let C=Oo(this._writingBuf,this._len,S);if(this._len=C.len,this._writingBuf=C.writingBuf,this._writingBuf.length){if(!this.sync){g();return}try{do{let y=p(),v=Oo(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&&re.fsyncSync(this.fd);let k=this._len;this._reopening?(this._writing=!1,this._reopening=!1,this.reopen()):k>this.minLength?this._actualWrite():this._ending?k>0?this._actualWrite():(this._writing=!1,Ks(this)):(this._writing=!1,this.sync?this._asyncDrainScheduled||(this._asyncDrainScheduled=!0,process.nextTick(Dv,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 Oo(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 Dv(n){n.listenerCount("drain")>0&&(n._asyncDrainScheduled=!1,n.emit("drain"))}Rv(ze,Tv);function Yd(n,e){return n.length===0?qs:n.length===1?n[0]:Buffer.concat(n,e)}function Fv(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 Nv(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 Jd(n){this._flushPending=!0;let e=()=>{if(this._fsync)this._flushPending=!1,n();else try{re.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 jv(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&&Jd.call(this,n),!this._writing&&(this._bufs.length===0&&this._bufs.push(""),this._actualWrite())}function Hv(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&&Jd.call(this,n),!this._writing&&(this._bufs.length===0&&(this._bufs.push([]),this._lens.push(0)),this._actualWrite())}ze.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&&re.close(e,t=>{if(t)return this.emit("error",t)})}),zd(this.file,this)};ze.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():Ks(this)))};function Bv(){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)?re.writeSync(this.fd,n):re.writeSync(this.fd,n,"utf8"),t=Oo(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;Po(Us)}}try{re.fsyncSync(this.fd)}catch{}}function Uv(){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=qs);let n=qs;for(;this._bufs.length||n.length;){n.length<=0&&(n=Yd(this._bufs[0],this._lens[0]));try{let e=re.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;Po(Us)}}}ze.prototype.destroy=function(){this.destroyed||Ks(this)};function qv(){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)?re.writeSync(this.fd,this._writingBuf):re.writeSync(this.fd,this._writingBuf,"utf8");n(null,e)}catch(e){n(e)}else re.write(this.fd,this._writingBuf,n)}function Kv(){let n=this.release;if(this._writing=!0,this._writingBuf=this._writingBuf.length?this._writingBuf:Yd(this._bufs.shift(),this._lens.shift()),this.sync)try{let e=re.writeSync(this.fd,this._writingBuf);n(null,e)}catch(e){n(e)}else Lv&&(this._writingBuf=Buffer.from(this._writingBuf)),re.write(this.fd,this._writingBuf,n)}function Ks(n){if(n.fd===-1){n.once("ready",Ks.bind(null,n));return}n._periodicFlushTimer!==void 0&&clearInterval(n._periodicFlushTimer),n.destroyed=!0,n._bufs=[],n._lens=[],Ov(typeof n.fd=="number",`sonic.fd must be a number, got ${typeof n.fd}`);try{re.fsync(n.fd,e)}catch{}function e(){n.fd!==1&&n.fd!==2?re.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")}}ze.SonicBoom=ze;ze.default=ze;Xd.exports=ze});var Mo=j((WE,sf)=>{"use strict";var Ye={exit:[],beforeExit:[]},Zd={exit:Vv,beforeExit:zv},dn;function Wv(){dn===void 0&&(dn=new FinalizationRegistry(Yv))}function Gv(n){Ye[n].length>0||process.on(n,Zd[n])}function ef(n){Ye[n].length>0||(process.removeListener(n,Zd[n]),Ye.exit.length===0&&Ye.beforeExit.length===0&&(dn=void 0))}function Vv(){tf("exit")}function zv(){tf("beforeExit")}function tf(n){for(let e of Ye[n]){let t=e.deref(),s=e.fn;t!==void 0&&s(t,n)}Ye[n]=[]}function Yv(n){for(let e of["exit","beforeExit"]){let t=Ye[e].indexOf(n);Ye[e].splice(t,t+1),ef(e)}}function nf(n,e,t){if(e===void 0)throw new Error("the object can't be undefined");Gv(n);let s=new WeakRef(e);s.fn=t,Wv(),dn.register(e,s),Ye[n].push(s)}function Jv(n,e){nf("exit",n,e)}function Xv(n,e){nf("beforeExit",n,e)}function Qv(n){if(dn!==void 0){dn.unregister(n);for(let e of["exit","beforeExit"])Ye[e]=Ye[e].filter(t=>{let s=t.deref();return s&&s!==n}),ef(e)}}sf.exports={register:Jv,registerBeforeExit:Xv,unregister:Qv}});var rf=j((GE,Zv)=>{Zv.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 af=j((VE,of)=>{"use strict";function ew(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())),c=Atomics.waitAsync(n,e,a,l);c.async?c.value.then(o):setImmediate(o)};o()}function tw(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())),c=Atomics.waitAsync(n,e,t,l);c.async?c.value.then(u=>{if(u==="ok"){r(null,"ok");return}o()}):setImmediate(o)};o()}of.exports={wait:ew,waitDiff:tw}});var cf=j((zE,lf)=>{"use strict";lf.exports={WRITE_INDEX:4,READ_INDEX:8,SEQ_INDEX:2}});var xf=j((YE,wf)=>{"use strict";var{version:nw}=rf(),{EventEmitter:sw}=require("events"),{Worker:rw}=require("worker_threads"),{join:iw}=require("path"),{pathToFileURL:ow}=require("url"),{wait:aw}=af(),{WRITE_INDEX:bt,READ_INDEX:Ut,SEQ_INDEX:Io}=cf(),lw=require("buffer"),cw=require("assert"),T=Symbol("kImpl"),uw=lw.constants.MAX_STRING_LENGTH;function uf(){}function No(n,e){Atomics.add(n[T].state,Io,1),e(),Atomics.add(n[T].state,Io,1),Atomics.notify(n[T].state,Io)}function df(n){No(n,()=>{Atomics.store(n[T].state,Ut,0),Atomics.store(n[T].state,bt,0)})}var jn=class{constructor(e){this._value=e}deref(){return this._value}},Ws=class{register(){}unregister(){}},dw=process.env.NODE_V8_COVERAGE?Ws:global.FinalizationRegistry||Ws,fw=process.env.NODE_V8_COVERAGE?jn:global.WeakRef||jn,ff=new dw(n=>{n.exited||n.terminate()});function pw(n,e){let{filename:t,workerData:s}=e,i=("__bundlerPathsOverrides"in globalThis?globalThis.__bundlerPathsOverrides:{})["thread-stream-worker"]||iw(__dirname,"lib","worker.js"),o=new rw(i,{...e.workerOpts,name:e.workerOpts?.name||"thread-stream",trackUnmanagedFds:!1,workerData:{filename:t.indexOf("file://")===0?t:ow(t).href,dataBuf:n[T].dataBuf,stateBuf:n[T].stateBuf,workerData:{$context:{threadStreamVersion:nw},...s}}});return o.stream=new jn(n),o.on("message",hw),o.on("exit",mf),ff.register(n,o),o}function pf(n){cw(!n[T].sync),n[T].needDrain&&(n[T].needDrain=!1,n.emit("drain"))}function hf(n){for(;;){let e=Atomics.load(n[T].state,bt),t=n[T].data.length-e;if(t>0){if(n[T].bufLen===0){n[T].flushing=!1,n[T].ending?jo(n):n[T].needDrain&&process.nextTick(pf,n);return}bf(n,t,uf);continue}if(t===0){if(e===0&&n[T].bufLen===0)return;Gs(n,()=>{n.destroyed||(df(n),hf(n))});return}Ne(n,new Error("overwritten"));return}}function hw(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 fw(e),Gs(e,()=>{e[T].ready=!0,e.emit("ready")});break;case"ERROR":Ne(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"){Ne(e,new Error("this should not happen: "+n.code));break}let t=e[T].flushCallbacks.get(n.id);t&&(e[T].flushCallbacks.delete(n.id),process.nextTick(t));break}case"WARNING":process.emitWarning(n.err);break;default:Ne(e,new Error("this should not happen: "+n.code))}}function mf(n){let e=this.stream.deref();e!==void 0&&(ff.unregister(e),e.worker.exited=!0,e.worker.off("exit",mf),Ne(e,n!==0?new Error("the worker thread exited"):null))}var Do=class extends sw{constructor(e={}){if(super(),e.bufferSize<4)throw new Error("bufferSize must at least fit a 4-byte utf-8 char");this[T]={},this[T].stateBuf=new SharedArrayBuffer(128),this[T].state=new Int32Array(this[T].stateBuf),this[T].dataBuf=new SharedArrayBuffer(e.bufferSize||4*1024*1024),this[T].data=Buffer.from(this[T].dataBuf),this[T].sync=e.sync||!1,this[T].ending=!1,this[T].ended=!1,this[T].needDrain=!1,this[T].destroyed=!1,this[T].flushing=!1,this[T].ready=!1,this[T].finished=!1,this[T].errored=null,this[T].closed=!1,this[T].buf=[],this[T].bufHead=0,this[T].bufLen=0,this[T].flushCallbacks=new Map,this[T].nextFlushId=0,this.worker=pw(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[T].destroyed)return Fo(this,new Error("the worker has exited")),!1;if(this[T].ending)return Fo(this,new Error("the worker is ending")),!1;if(this[T].flushing&&this[T].bufLen+t.length>=uw)try{Lo(this),this[T].flushing=!0}catch(s){return Ne(this,s),!1}if(this[T].buf.push(t),this[T].bufLen+=t.length,this[T].sync)try{return Lo(this),!0}catch(s){return Ne(this,s),!1}return this[T].flushing||(this[T].flushing=!0,setImmediate(hf,this)),this[T].needDrain=this[T].data.length-this[T].bufLen-Atomics.load(this[T].state,bt)<=0,!this[T].needDrain}end(){this[T].destroyed||(this[T].ending=!0,jo(this))}flush(e){e=typeof e=="function"?e:uf,gf(this,t=>{if(t){process.nextTick(e,t);return}yf(this,e)})}flushSync(){this[T].destroyed||(Lo(this),vf(this))}unref(){this.worker.unref()}ref(){this.worker.ref()}get ready(){return this[T].ready}get destroyed(){return this[T].destroyed}get closed(){return this[T].closed}get writable(){return!this[T].destroyed&&!this[T].ending}get writableEnded(){return this[T].ending}get writableFinished(){return this[T].finished}get writableNeedDrain(){return this[T].needDrain}get writableObjectMode(){return!1}get writableErrored(){return this[T].errored}};function gf(n,e){if(n[T].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[T].sync&&(n[T].flushing||n[T].bufLen>0)){setImmediate(gf,n,e);return}Gs(n,e)}function Gs(n,e){let t=Atomics.load(n[T].state,bt);aw(n[T].state,Ut,t,1/0,(s,r)=>{if(s){Ne(n,s),e(s);return}if(r!=="ok"){Gs(n,e);return}e()})}function yf(n,e){if(n[T].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[T].ready){let s=()=>{i(),yf(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[T].nextFlushId;n[T].flushCallbacks.set(t,e);try{n.worker.postMessage({code:"FLUSH",context:"thread-stream",id:t})}catch(s){n[T].flushCallbacks.delete(t),Ne(n,s),process.nextTick(e,s)}}function mw(n,e){let t=n[T].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 Fo(n,e){setImmediate(()=>{n.emit("error",e)})}function Ne(n,e){n[T].destroyed||(n[T].destroyed=!0,mw(n,e),e&&(n[T].errored=e,Fo(n,e)),n.worker.exited?setImmediate(()=>{n[T].closed=!0,n.emit("close")}):n.worker.terminate().catch(()=>{}).then(()=>{n[T].closed=!0,n.emit("close")}))}function bf(n,e,t){let r=Atomics.load(n[T].state,bt),i=e;for(;i>0&&n[T].bufLen!==0;){let o=n[T].bufHead,a=n[T].buf[o];if(a.length<=i){a.copy(n[T].data,r),r+=a.length,i-=a.length,n[T].bufLen-=a.length,n[T].bufHead=o+1,n[T].bufHead===n[T].buf.length?(n[T].buf.length=0,n[T].bufHead=0):n[T].bufHead>=1024&&n[T].bufHead*2>=n[T].buf.length&&(n[T].buf.splice(0,n[T].bufHead),n[T].bufHead=0);continue}a.copy(n[T].data,r,0,i),n[T].buf[o]=a.subarray(i),n[T].bufLen-=i,r+=i,i=0}return No(n,()=>{Atomics.store(n[T].state,bt,r)}),t(),!0}function jo(n){if(!(n[T].ended||!n[T].ending||n[T].flushing)){n[T].ended=!0;try{n.flushSync();let e=Atomics.load(n[T].state,Ut);No(n,()=>{Atomics.store(n[T].state,bt,-1)});let t=0;for(;e!==-1;){if(Atomics.wait(n[T].state,Ut,e,1e3),e=Atomics.load(n[T].state,Ut),e===-2){Ne(n,new Error("end() failed"));return}if(++t===10){Ne(n,new Error("end() took too long (10s)"));return}}process.nextTick(()=>{n[T].finished=!0,n.emit("finish")})}catch(e){Ne(n,e)}}}function Lo(n){let e=()=>{n[T].ending?jo(n):n[T].needDrain&&process.nextTick(pf,n)};for(n[T].flushing=!1;n[T].bufLen!==0;){let t=Atomics.load(n[T].state,bt),s=n[T].data.length-t;if(s===0){vf(n),df(n);continue}else if(s<0)throw new Error("overwritten");bf(n,s,e)}}function vf(n){if(n[T].flushing)throw new Error("unable to flush while flushing");let e=Atomics.load(n[T].state,bt),t=0;for(;;){let s=Atomics.load(n[T].state,Ut);if(s===-2)throw Error("_flushSync failed");if(s!==e)Atomics.wait(n[T].state,Ut,s,1e3);else break;if(++t===10)throw new Error("_flushSync took too long (10s)")}}wf.exports=Do});var Uo=j((JE,Af)=>{"use strict";var{createRequire:gw}=require("module"),{existsSync:yw}=require("node:fs"),bw=ko(),{join:Ho,isAbsolute:_f,sep:vw}=require("node:path"),{fileURLToPath:ww}=require("node:url"),xw=Ro(),Bo=Mo(),Sw=xf();function _w(n){Bo.register(n,Ew),Bo.registerBeforeExit(n,Tw),n.on("close",function(){Bo.unregister(n)})}function Aw(){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 kw(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&&Sf(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(Sf(o)){s=!0;continue}}t.push(i)}return s?t.join(" "):n}function Sf(n){let e=$w(n);if(!e)return!1;let t=e;if(t.startsWith("file://"))try{t=ww(t)}catch{return!1}return _f(t)&&!yw(t)}function $w(n){let e=n[0],t=n[n.length-1];return e==='"'&&t==='"'||e==="'"&&t==="'"?n.slice(1,-1):n}function Cw(n,e,t,s,r){if(!t.execArgv&&Aw()&&require.main===void 0&&(t={...t,execArgv:[]}),!t.env&&process.env.NODE_OPTIONS){let l=kw(process.env.NODE_OPTIONS);l!==process.env.NODE_OPTIONS&&(t={...t,env:{...process.env,NODE_OPTIONS:l}})}t={...t,name:r};let i=new Sw({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&&_w(i)}function a(){i.closed||(i.flushSync(),xw(100),i.end())}return i}function Ew(n){n.ref(),n.flushSync(),n.end(),n.once("close",function(){n.unref()})}function Tw(n){n.flushSync()}function Rw(n){let{pipeline:e,targets:t,levels:s,dedupe:r,worker:i={},caller:o=bw(),sync:a=!1}=n,l={...n.options},c=typeof o=="string"?[o]:o,u=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=u["pino-worker"]||Ho(__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=u["pino-worker"]||Ho(__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 Cw(m(f),l,i,a,h);function m(p){if(p=u[p]||p,_f(p)||p.indexOf("file://")===0)return p;if(p==="pino/file")return Ho(__dirname,"..","file.js");let g;for(let x of c)try{let S=x==="node:repl"?process.cwd()+vw:x;g=gw(S).resolve(p);break}catch{continue}if(!g)throw new Error(`unable to determine transport target for "${p}"`);return g}}Af.exports=Rw});var Ys=j((XE,Ff)=>{"use strict";var Ow=require("node:diagnostics_channel"),kf=Kd(),{mapHttpRequest:Pw,mapHttpResponse:Mw}=Ao(),Ko=Qd(),$f=Mo(),{lsCacheSym:Iw,chindingsSym:Of,writeSym:Cf,serializersSym:Pf,formatOptsSym:Ef,endSym:Lw,stringifiersSym:Mf,stringifySym:If,stringifySafeSym:Wo,wildcardFirstSym:Lf,nestedKeySym:Dw,formattersSym:Df,messageKeySym:Fw,errorKeySym:Nw,nestedKeyStrSym:jw,msgPrefixSym:Vs}=un(),{isMainThread:Hw}=require("worker_threads"),Bw=Uo(),[Uw]=process.versions.node.split(".").map(n=>Number(n)),Tf=Ow.tracingChannel("pino_asJson"),qo=Uw>=25?n=>JSON.stringify(n):Kw;function fn(){}function qw(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=Pw(s):typeof s.setHeader=="function"&&(s=Mw(s)));let o;i===null&&r.length===0?o=[null]:(i=r.shift(),o=r),typeof this[Vs]=="string"&&i!==void 0&&i!==null&&(i=this[Vs]+i),this[Cf](s,kf(i,o,this[Ef]),n)}else{let i=s===void 0?r.shift():s;typeof this[Vs]=="string"&&i!==void 0&&i!==null&&(i=this[Vs]+i),this[Cf](null,kf(i,r,this[Ef]),n)}}}function Kw(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 Ww(n,e,t,s){if(Tf.hasSubscribers===!1)return Rf.call(this,n,e,t,s);let r={instance:this,arguments};return Tf.traceSync(Rf,r,this,n,e,t,s)}function Rf(n,e,t,s){let r=this[If],i=this[Wo],o=this[Mf],a=this[Lw],l=this[Of],c=this[Pf],u=this[Df],f=this[Fw],h=this[Nw],m=this[Iw][t]+s;m=m+l;let p;u.log&&(n=u.log(n));let g=o[Lf],x="";for(let C in n)if(p=n[C],Object.prototype.hasOwnProperty.call(n,C)&&p!==void 0){c[C]?p=c[C](p):C===h&&c.err&&(p=c.err(p));let k=o[C]||g;switch(typeof p){case"undefined":case"function":continue;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":k&&(p=k(p));break;case"string":p=(k||qo)(p);break;default:p=(k||r)(p,i)}if(p===void 0)continue;let y=qo(C);x+=","+y+":"+p}let S="";if(e!==void 0){p=c[f]?c[f](e):e;let C=o[f]||g;switch(typeof p){case"function":break;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":C&&(p=C(p)),S=',"'+f+'":'+p;break;case"string":p=(C||qo)(p),S=',"'+f+'":'+p;break;default:p=(C||r)(p,i),S=',"'+f+'":'+p}}return this[Dw]&&x?m+this[jw]+x.slice(1)+"}"+S+a:m+x+S+a}function Gw(n,e){let t,s=n[Of],r=n[If],i=n[Wo],o=n[Mf],a=o[Lf],l=n[Pf],c=n[Df].bindings;e=c(e);for(let u in e)if(t=e[u],((u.length<5||u!=="level"&&u!=="serializers"&&u!=="formatters"&&u!=="customLevels")&&e.hasOwnProperty(u)&&t!==void 0)===!0){if(t=l[u]?l[u](t):t,t=(o[u]||a||r)(t,i),t===void 0)continue;s+=',"'+u+'":'+t}return s}function Vw(n){return n.write!==n.constructor.prototype.write}function zs(n){let e=new Ko(n);return e.on("error",t),!n.sync&&Hw&&($f.register(e,zw),e.on("close",function(){$f.unregister(e)})),e;function t(s){if(s.code==="EPIPE"){e.write=fn,e.end=fn,e.flushSync=fn,e.destroy=fn;return}e.removeListener("error",t),e.emit("error",s)}}function zw(n,e){n.destroyed||(e==="beforeExit"?(n.flush(),n.on("drain",function(){n.end()})):n.flushSync())}function Yw(n){return function(t,s,r={},i){if(typeof r=="string")i=zs({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=zs({dest:i})}else if(r instanceof Ko||r.writable||r._writableState)i=r,r={};else if(r.transport){if(r.transport instanceof Ko||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=Bw({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=fn),i||(Vw(process.stdout)?i=process.stdout:i=zs({fd:process.stdout.fd||1})),{opts:r,stream:i}}}function Jw(n,e){try{return JSON.stringify(n)}catch{try{return(e||this[Wo])(n)}catch{return'"[unable to serialize, circular reference is too complex to analyze]"'}}}function Xw(n,e,t){return{level:n,bindings:e,log:t}}function Qw(n){let e=Number(n);return typeof n=="string"&&Number.isFinite(e)?e:n===void 0?1:n}Ff.exports={noop:fn,buildSafeSonicBoom:zs,asChindings:Gw,asJson:Ww,genLog:qw,createArgsNormalizer:Yw,stringify:Jw,buildFormatters:Xw,normalizeDestFileDescriptor:Qw}});var Js=j((QE,Nf)=>{var Zw={trace:10,debug:20,info:30,warn:40,error:50,fatal:60},ex={ASC:"ASC",DESC:"DESC"};Nf.exports={DEFAULT_LEVELS:Zw,SORTING_ORDER:ex}});var zo=j((ZE,Uf)=>{"use strict";var{lsCacheSym:tx,levelValSym:Go,useOnlyCustomLevelsSym:nx,streamSym:sx,formattersSym:rx,hooksSym:ix,levelCompSym:jf}=un(),{noop:ox,genLog:qt}=Ys(),{DEFAULT_LEVELS:rt,SORTING_ORDER:Hf}=Js(),Bf={fatal:n=>{let e=qt(rt.fatal,n);return function(...t){let s=this[sx];if(e.call(this,...t),typeof s.flushSync=="function")try{s.flushSync()}catch{}}},error:n=>qt(rt.error,n),warn:n=>qt(rt.warn,n),info:n=>qt(rt.info,n),debug:n=>qt(rt.debug,n),trace:n=>qt(rt.trace,n)},Vo=Object.keys(rt).reduce((n,e)=>(n[rt[e]]=e,n),{}),ax=Object.keys(Vo).reduce((n,e)=>(n[e]='{"level":'+Number(e),n),{});function lx(n){let e=n[rx].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[tx]=s,n}function cx(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 ux(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[Go],r=this[Go]=t[n],i=this[nx],o=this[jf],a=this[ix].logMethod;for(let l in t){if(o(t[l],r)===!1){this[l]=ox;continue}this[l]=cx(l,i)?Bf[l](a):qt(t[l],a)}this.emit("level-change",n,r,e[s],s,this)}function dx(n){let{levels:e,levelVal:t}=this;return e&&e.labels?e.labels[t]:""}function fx(n){let{values:e}=this.levels,t=e[n];return t!==void 0&&this[jf](t,this[Go])}function px(n,e,t){return n===Hf.DESC?e<=t:e>=t}function hx(n){return typeof n=="string"?px.bind(null,n):n}function mx(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:Vo,t),r=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),e?null:rt,n);return{labels:s,values:r}}function gx(n,e,t){if(typeof n=="number"){if(![].concat(Object.keys(e||{}).map(i=>e[i]),t?[]:Object.keys(Vo).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:rt,e);if(!(n in s))throw Error(`default level:${n} must be included in custom levels`)}function yx(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 bx(n){if(typeof n!="function"&&!(typeof n=="string"&&Object.values(Hf).includes(n)))throw new Error('Levels comparison should be one of "ASC", "DESC" or "function" type')}Uf.exports={initialLsCache:ax,genLsCache:lx,levelMethods:Bf,getLevel:dx,setLevel:ux,isLevelEnabled:fx,mappings:mx,assertNoLevelCollisions:yx,assertDefaultLevelFound:gx,genLevelComparison:hx,assertLevelComparison:bx}});var Yo=j((eT,qf)=>{"use strict";qf.exports={version:"10.3.1"}});var Xf=j((nT,Jf)=>{"use strict";var{EventEmitter:vx}=require("node:events"),{lsCacheSym:wx,levelValSym:xx,setLevelSym:Xo,getLevelSym:Kf,chindingsSym:Qs,mixinSym:Sx,asJsonSym:Gf,writeSym:_x,mixinMergeStrategySym:Ax,timeSym:kx,timeSliceIndexSym:$x,streamSym:Vf,serializersSym:Kt,formattersSym:Hn,errorKeySym:Cx,messageKeySym:Ex,useOnlyCustomLevelsSym:Tx,needsMetadataGsym:Rx,redactFmtSym:Ox,stringifySym:Px,formatOptsSym:Mx,stringifiersSym:Ix,msgPrefixSym:Qo,hooksSym:Lx}=un(),{getLevel:Dx,setLevel:Fx,isLevelEnabled:Nx,mappings:jx,initialLsCache:Hx,genLsCache:Bx,assertNoLevelCollisions:Ux}=zo(),{asChindings:Zo,asJson:qx,buildFormatters:Jo,stringify:Wf,noop:zf}=Ys(),{version:Kx}=Yo(),Wx=Eo(),Gx=class{},Yf={constructor:Gx,child:Vx,bindings:zx,setBindings:Yx,flush:Qx,isLevelEnabled:Nx,version:Kx,get level(){return this[Kf]()},set level(n){this[Xo](n)},get levelVal(){return this[xx]},set levelVal(n){throw Error("levelVal is read-only")},get msgPrefix(){return this[Qo]},get[Symbol.toStringTag](){return"Pino"},[wx]:Hx,[_x]:Xx,[Gf]:qx,[Kf]:Dx,[Xo]:Fx};Object.setPrototypeOf(Yf,vx.prototype);Jf.exports=function(){return Object.create(Yf)};var Xs=n=>n;function Vx(n,e){if(!n)throw Error("missing bindings for child Pino");let t=this[Kt],s=this[Hn],r=Object.create(this);if(e==null)return r[Hn].bindings!==Xs&&(r[Hn]=Jo(s.level,Xs,s.log)),r[Qs]=Zo(r,n),this.onChild!==zf&&this.onChild(r),r;if(e.hasOwnProperty("serializers")===!0){r[Kt]=Object.create(null);for(let c in t)r[Kt][c]=t[c];let a=Object.getOwnPropertySymbols(t);for(var i=0;i<a.length;i++){let c=a[i];r[Kt][c]=t[c]}for(let c in e.serializers)r[Kt][c]=e.serializers[c];let l=Object.getOwnPropertySymbols(e.serializers);for(var o=0;o<l.length;o++){let c=l[o];r[Kt][c]=e.serializers[c]}}else r[Kt]=t;if(e.hasOwnProperty("formatters")){let{level:a,bindings:l,log:c}=e.formatters;r[Hn]=Jo(a||s.level,l||Xs,c||s.log)}else r[Hn]=Jo(s.level,Xs,s.log);if(e.hasOwnProperty("customLevels")===!0&&(Ux(this.levels,e.customLevels),r.levels=jx(e.customLevels,r[Tx]),Bx(r)),typeof e.redact=="object"&&e.redact!==null||Array.isArray(e.redact)){r.redact=e.redact;let a=Wx(r.redact,Wf),l={stringify:a[Ox]};r[Px]=Wf,r[Ix]=a,r[Mx]=l}if(typeof e.msgPrefix=="string"&&(r[Qo]=(this[Qo]||"")+e.msgPrefix),r[Qs]=Zo(r,n),e.level!==void 0&&e.level!==this.level||e.hasOwnProperty("customLevels")){let a=e.level||this.level;r[Xo](a)}return this.onChild(r),r}function zx(){let e=`{${this[Qs].substr(1)}}`,t=JSON.parse(e);return delete t.pid,delete t.hostname,t}function Yx(n){let e=Zo(this,n);this[Qs]=e}function Jx(n,e){return Object.assign(e,n)}function Xx(n,e,t){let s=this[kx](),r=this[Sx],i=this[Cx],o=this[Ex],a=this[Ax]||Jx,l,c=this[Lx].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 u=this[Gf](l,e,t,s),f=this[Vf];f[Rx]===!0&&(f.lastLevel=t,f.lastObj=l,f.lastMsg=e,f.lastTime=s.slice(this[$x]),f.lastLogger=this),f.write(c?c(u):u)}function Qx(n){if(n!=null&&typeof n!="function")throw Error("callback must be a function");let e=this[Vf];typeof e.flush=="function"?e.flush(n||zf):n&&n()}});var tp=j((sa,ep)=>{"use strict";var{hasOwnProperty:Bn}=Object.prototype,Gt=na();Gt.configure=na;Gt.stringify=Gt;Gt.default=Gt;sa.stringify=Gt;sa.configure=na;ep.exports=Gt;var Zx=/[\u0000-\u001f\u0022\u005c\ud800-\udfff]/;function Mt(n){return n.length<5e3&&!Zx.test(n)?`"${n}"`:JSON.stringify(n)}function ea(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 eS=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(Object.getPrototypeOf(new Int8Array)),Symbol.toStringTag).get;function ta(n){return eS.call(n)!==void 0&&n.length!==0}function Qf(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 tS(n){if(Bn.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 nS(n){let e;if(Bn.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 sS(n,e){let t;if(Bn.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 Zf(n,e){let t;if(Bn.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 Wt(n){return n===1?"1 item":`${n} items`}function rS(n){let e=new Set;for(let t of n)(typeof t=="string"||typeof t=="number")&&e.add(String(t));return e}function iS(n){if(Bn.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 na(n){n={...n};let e=iS(n);e&&(n.bigint===void 0&&(n.bigint=!1),"circularValue"in n||(n.circularValue=Error));let t=tS(n),s=sS(n,"bigint"),r=nS(n),i=typeof r=="function"?r:void 0,o=Zf(n,"maximumDepth"),a=Zf(n,"maximumBreadth");function l(m,p,g,x,S,C){let k=p[m];switch(typeof k=="object"&&k!==null&&typeof k.toJSON=="function"&&(k=k.toJSON(m)),k=x.call(p,m,k),typeof k){case"string":return Mt(k);case"object":{if(k===null)return"null";if(g.indexOf(k)!==-1)return t;let y="",v=",",b=C;if(Array.isArray(k)){if(k.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(k),S!==""&&(C+=S,y+=`
|
|
688
|
+
${C}`,v=`,
|
|
689
|
+
${C}`);let M=Math.min(k.length,a),N=0;for(;N<M-1;N++){let E=l(String(N),k,g,x,S,C);y+=E!==void 0?E:"null",y+=v}let U=l(String(N),k,g,x,S,C);if(y+=U!==void 0?U:"null",k.length-1>a){let E=k.length-a-1;y+=`${v}"... ${Wt(E)} not stringified"`}return S!==""&&(y+=`
|
|
690
|
+
${b}`),g.pop(),`[${y}]`}let w=Object.keys(k),_=w.length;if(_===0)return"{}";if(o<g.length+1)return'"[Object]"';let R="",D="";S!==""&&(C+=S,v=`,
|
|
691
|
+
${C}`,R=" ");let $=Math.min(_,a);r&&!ta(k)&&(w=ea(w,i)),g.push(k);for(let M=0;M<$;M++){let N=w[M],U=l(N,k,g,x,S,C);U!==void 0&&(y+=`${D}${Mt(N)}:${R}${U}`,D=v)}if(_>a){let M=_-a;y+=`${D}"...":${R}"${Wt(M)} not stringified"`,D=v}return S!==""&&D.length>1&&(y=`
|
|
692
|
+
${C}${y}
|
|
693
|
+
${b}`),g.pop(),`{${y}}`}case"number":return isFinite(k)?String(k):e?e(k):"null";case"boolean":return k===!0?"true":"false";case"undefined":return;case"bigint":if(s)return String(k);default:return e?e(k):void 0}}function c(m,p,g,x,S,C){switch(typeof p=="object"&&p!==null&&typeof p.toJSON=="function"&&(p=p.toJSON(m)),typeof p){case"string":return Mt(p);case"object":{if(p===null)return"null";if(g.indexOf(p)!==-1)return t;let k=C,y="",v=",";if(Array.isArray(p)){if(p.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(p),S!==""&&(C+=S,y+=`
|
|
694
|
+
${C}`,v=`,
|
|
695
|
+
${C}`);let _=Math.min(p.length,a),R=0;for(;R<_-1;R++){let $=c(String(R),p[R],g,x,S,C);y+=$!==void 0?$:"null",y+=v}let D=c(String(R),p[R],g,x,S,C);if(y+=D!==void 0?D:"null",p.length-1>a){let $=p.length-a-1;y+=`${v}"... ${Wt($)} not stringified"`}return S!==""&&(y+=`
|
|
696
|
+
${k}`),g.pop(),`[${y}]`}g.push(p);let b="";S!==""&&(C+=S,v=`,
|
|
697
|
+
${C}`,b=" ");let w="";for(let _ of x){let R=c(_,p[_],g,x,S,C);R!==void 0&&(y+=`${w}${Mt(_)}:${b}${R}`,w=v)}return S!==""&&w.length>1&&(y=`
|
|
698
|
+
${C}${y}
|
|
699
|
+
${k}`),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 u(m,p,g,x,S){switch(typeof p){case"string":return Mt(p);case"object":{if(p===null)return"null";if(typeof p.toJSON=="function"){if(p=p.toJSON(m),typeof p!="object")return u(m,p,g,x,S);if(p===null)return"null"}if(g.indexOf(p)!==-1)return t;let C=S;if(Array.isArray(p)){if(p.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(p),S+=x;let R=`
|
|
700
|
+
${S}`,D=`,
|
|
701
|
+
${S}`,$=Math.min(p.length,a),M=0;for(;M<$-1;M++){let U=u(String(M),p[M],g,x,S);R+=U!==void 0?U:"null",R+=D}let N=u(String(M),p[M],g,x,S);if(R+=N!==void 0?N:"null",p.length-1>a){let U=p.length-a-1;R+=`${D}"... ${Wt(U)} not stringified"`}return R+=`
|
|
702
|
+
${C}`,g.pop(),`[${R}]`}let k=Object.keys(p),y=k.length;if(y===0)return"{}";if(o<g.length+1)return'"[Object]"';S+=x;let v=`,
|
|
703
|
+
${S}`,b="",w="",_=Math.min(y,a);ta(p)&&(b+=Qf(p,v,a),k=k.slice(p.length),_-=p.length,w=v),r&&(k=ea(k,i)),g.push(p);for(let R=0;R<_;R++){let D=k[R],$=u(D,p[D],g,x,S);$!==void 0&&(b+=`${w}${Mt(D)}: ${$}`,w=v)}if(y>a){let R=y-a;b+=`${w}"...": "${Wt(R)} not stringified"`,w=v}return w!==""&&(b=`
|
|
704
|
+
${S}${b}
|
|
705
|
+
${C}`),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 Mt(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="",S=p.length!==void 0;if(S&&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 R=f(String(w),p[w],g);x+=R!==void 0?R:"null",x+=","}let _=f(String(w),p[w],g);if(x+=_!==void 0?_:"null",p.length-1>a){let R=p.length-a-1;x+=`,"... ${Wt(R)} not stringified"`}return g.pop(),`[${x}]`}let C=Object.keys(p),k=C.length;if(k===0)return"{}";if(o<g.length+1)return'"[Object]"';let y="",v=Math.min(k,a);S&&ta(p)&&(x+=Qf(p,",",a),C=C.slice(p.length),v-=p.length,y=","),r&&(C=ea(C,i)),g.push(p);for(let b=0;b<v;b++){let w=C[b],_=f(w,p[w],g);_!==void 0&&(x+=`${y}${Mt(w)}:${_}`,y=",")}if(k>a){let b=k-a;x+=`${y}"...":"${Wt(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 c("",m,[],rS(p),x,"")}if(x.length!==0)return u("",m,[],x,"")}return f("",m,[])}return h}});var ip=j((sT,rp)=>{"use strict";var ra=Symbol.for("pino.metadata"),{DEFAULT_LEVELS:sp}=Js(),oS=sp.info;function aS(n,e){n=n||[],e=e||{dedupe:!1};let t=Object.create(sp);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:c,minLevel:0,lastId:0,streams:[],clone:u,[ra]:!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 S=lS(p.length,e.dedupe);uS(S,p.length,e.dedupe);S=cS(S,e.dedupe))if(h=p[S],h.level<=m){if(g!==0&&g!==h.level)break;if(x=h.stream,x[ra]){let{lastTime:C,lastMsg:k,lastObj:y,lastLogger:v}=this;x.lastLevel=m,x.lastTime=C,x.lastMsg=k,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=oS;let S={stream:m,level:x,levelVal:void 0,id:++s.lastId};return p.unshift(S),p.sort(np),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(np),this.minLevel=h.length>0?h[0].level:-1),s}function c(){for(let{stream:f}of this.streams)typeof f.flushSync=="function"&&f.flushSync(),f.end()}function u(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:u,emit:i,flushSync:o,[ra]:!0}}}function np(n,e){return n.level-e.level}function lS(n,e){return e?n-1:0}function cS(n,e){return e?n-1:n+1}function uS(n,e,t){return t?n>=0:n<e}rp.exports=aS});var la=j((rT,je)=>{"use strict";var dS=require("node:os"),pp=Ao(),fS=ko(),pS=Eo(),hp=Ud(),hS=Xf(),mp=un(),{configure:mS}=tp(),{assertDefaultLevelFound:gS,mappings:gp,genLsCache:yS,genLevelComparison:bS,assertLevelComparison:vS}=zo(),{DEFAULT_LEVELS:yp,SORTING_ORDER:wS}=Js(),{createArgsNormalizer:xS,asChindings:SS,buildSafeSonicBoom:op,buildFormatters:_S,stringify:ia,normalizeDestFileDescriptor:ap,noop:AS}=Ys(),{version:kS}=Yo(),{chindingsSym:lp,redactFmtSym:$S,serializersSym:cp,timeSym:CS,timeSliceIndexSym:ES,streamSym:TS,stringifySym:up,stringifySafeSym:oa,stringifiersSym:dp,setLevelSym:RS,endSym:OS,formatOptsSym:PS,messageKeySym:MS,errorKeySym:IS,nestedKeySym:LS,mixinSym:DS,levelCompSym:FS,useOnlyCustomLevelsSym:NS,formattersSym:fp,hooksSym:jS,nestedKeyStrSym:HS,mixinMergeStrategySym:BS,msgPrefixSym:US}=mp,{epochTime:bp,nullTime:qS}=hp,{pid:KS}=process,WS=dS.hostname(),GS=pp.err,VS={level:"info",levelComparison:wS.ASC,levels:yp,messageKey:"msg",errorKey:"err",nestedKey:null,enabled:!0,base:{pid:KS,hostname:WS},serializers:Object.assign(Object.create(null),{err:GS}),formatters:Object.assign(Object.create(null),{bindings(n){return n},level(n,e){return{level:e}}}),hooks:{logMethod:void 0,streamWrite:void 0},timestamp:bp,name:void 0,redact:null,customLevels:null,useOnlyCustomLevels:!1,depthLimit:5,edgeLimit:100},zS=xS(VS),YS=Object.assign(Object.create(null),pp);function aa(...n){let e={},{opts:t,stream:s}=zS(e,fS(),...n);t.level&&typeof t.level=="string"&&yp[t.level.toLowerCase()]!==void 0&&(t.level=t.level.toLowerCase());let{redact:r,crlf:i,serializers:o,timestamp:a,messageKey:l,errorKey:c,nestedKey:u,base:f,name:h,level:m,customLevels:p,levelComparison:g,mixin:x,mixinMergeStrategy:S,useOnlyCustomLevels:C,formatters:k,hooks:y,depthLimit:v,edgeLimit:b,onChild:w,msgPrefix:_}=t,R=mS({maximumDepth:v,maximumBreadth:b}),D=_S(k.level,k.bindings,k.log),$=ia.bind({[oa]:R}),M=r?pS(r,$):{},N=r?{stringify:M[$S]}:{stringify:$},U="}"+(i?`\r
|
|
707
706
|
`:`
|
|
708
|
-
`),
|
|
707
|
+
`),E=SS.bind(null,{[lp]:"",[cp]:o,[dp]:M,[up]:ia,[oa]:R,[fp]:D}),A="";f!==null&&(h===void 0?A=E(f):A=E(Object.assign({},f,{name:h})));let V=a instanceof Function?a:a?bp:qS,q=V().indexOf(":")+1;if(C&&!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(_&&typeof _!="string")throw Error(`Unknown msgPrefix type "${typeof _}" - expected "string"`);gS(m,p,C);let ue=gp(p,C);typeof s.emit=="function"&&s.emit("message",{code:"PINO_CONFIG",config:{levels:ue,messageKey:l,errorKey:c}}),vS(g);let ve=bS(g);return Object.assign(e,{levels:ue,[FS]:ve,[NS]:C,[TS]:s,[CS]:V,[ES]:q,[up]:ia,[oa]:R,[dp]:M,[OS]:U,[PS]:N,[MS]:l,[IS]:c,[LS]:u,[HS]:u?`,${JSON.stringify(u)}:{`:"",[cp]:o,[DS]:x,[BS]:S,[lp]:A,[fp]:D,[jS]:y,silent:AS,onChild:w,[US]:_}),Object.setPrototypeOf(e,hS()),yS(e),e[RS](m),e}je.exports=aa;je.exports.destination=(n=process.stdout.fd)=>typeof n=="object"?(n.dest=ap(n.dest||process.stdout.fd),op(n)):op({dest:ap(n),minLength:0});je.exports.transport=Uo();je.exports.multistream=ip();je.exports.levels=gp();je.exports.stdSerializers=YS;je.exports.stdTimeFunctions=Object.assign({},hp);je.exports.symbols=mp;je.exports.version=kS;je.exports.default=aa;je.exports.pino=aa});function vp(n){return new ca(n)}var JS,XS,QS,ca,wp=F(()=>{"use strict";JS={maxSteps:150,thinkingEnabled:!0,selfEvalEnabled:!0,minConfidence:.6,showThinking:!1},XS=`
|
|
709
708
|
## Reasoning Protocol
|
|
710
709
|
|
|
711
710
|
Before taking ANY action, you MUST think step-by-step inside <thinking> tags.
|
|
@@ -734,15 +733,15 @@ After receiving a tool result, think again:
|
|
|
734
733
|
- One tool call per turn. Wait for the result before the next call.
|
|
735
734
|
- If a tool fails, analyze the error in <thinking> before retrying.
|
|
736
735
|
- When done, give a concise final answer WITHOUT <thinking> tags.
|
|
737
|
-
`.trim(),
|
|
736
|
+
`.trim(),QS=`
|
|
738
737
|
## Reasoning
|
|
739
738
|
For non-trivial requests, think briefly inside <thinking>...</thinking> before acting.
|
|
740
739
|
The user will NOT see thinking blocks. One tool call per turn.
|
|
741
|
-
`.trim(),ca=class{config;turnSteps=[];stepCounter=0;constructor(e){this.config={...
|
|
740
|
+
`.trim(),ca=class{config;turnSteps=[];stepCounter=0;constructor(e){this.config={...JS,...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}
|
|
742
741
|
|
|
743
|
-
${
|
|
742
|
+
${QS}`:`${e}
|
|
744
743
|
|
|
745
|
-
${
|
|
744
|
+
${XS}`}parseThinking(e){if(!e)return{thinking:"",visibleContent:"",hasThinking:!1};let t=[],s=e,r=/<thinking>([\s\S]*?)<\/thinking>/gi,i;for(;(i=r.exec(e))!==null;)t.push(i[1].trim());s=s.replace(/<thinking>[\s\S]*?<\/thinking>/gi,"");let o=/<think>([\s\S]*?)<\/think>/gi;for(;(i=o.exec(e))!==null;)t.push(i[1].trim());s=s.replace(/<think>[\s\S]*?<\/think>/gi,"");let a=/<thinking>([\s\S]*)$/i.exec(s);a&&(t.push(a[1].trim()),s=s.replace(/<thinking>[\s\S]*$/i,""));let l=/<think>([\s\S]*)$/i.exec(s);return l&&(t.push(l[1].trim()),s=s.replace(/<think>[\s\S]*$/i,"")),{thinking:t.join(`
|
|
746
745
|
|
|
747
746
|
`).trim(),visibleContent:s.trim(),hasThinking:t.length>0}}startTurn(){this.turnSteps=[],this.stepCounter=0}recordStep(e){let t={...e,stepIndex:this.stepCounter++,timestamp:new Date().toISOString()};return this.turnSteps.push(t),t}recordObservation(e,t){let s=this.turnSteps[this.turnSteps.length-1];s&&(s.observation=e,t&&(s.reflection=t))}getSteps(){return this.turnSteps}isOverBudget(){return this.stepCounter>=this.config.maxSteps}remainingBudget(){return Math.max(0,this.config.maxSteps-this.stepCounter)}buildSelfEvalPrompt(e,t,s){return`
|
|
748
747
|
<self_eval>
|
|
@@ -765,22 +764,22 @@ Rate your work. Reply with ONLY a JSON object \u2014 no other text:
|
|
|
765
764
|
}
|
|
766
765
|
</self_eval>
|
|
767
766
|
`.trim()}parseSelfEval(e){let t=[/^\s*(\{[\s\S]*\})\s*$/,/```(?:json)?\s*\n([\s\S]*?)\n```/,/<self_eval_result>([\s\S]*?)<\/self_eval_result>/,/(\{[\s\S]*?"score"[\s\S]*?"completed"[\s\S]*?\})/];for(let s of t){let r=e.match(s);if(r)try{let i=JSON.parse(r[1]);return this.normalizeSelfEval(i)}catch{}}return null}normalizeSelfEval(e){let t=typeof e.score=="number"?Math.max(0,Math.min(10,Math.round(e.score))):5,s=typeof e.completed=="boolean"?e.completed:t>=7,r=typeof e.rationale=="string"?e.rationale.slice(0,500):"No rationale provided",i=Array.isArray(e.issues)?e.issues.filter(a=>typeof a=="string").slice(0,5):[],o="medium";return e.confidence==="high"||e.confidence==="medium"||e.confidence==="low"?o=e.confidence:t>=8?o="high":t<=4&&(o="low"),{score:t,completed:s,rationale:r,issues:i,confidence:o}}buildBudgetWarningPrompt(){let e=this.remainingBudget();return e<=0?"[SYSTEM] You have exceeded the maximum reasoning steps. You MUST provide your final answer NOW. Do not call any more tools.":e<=3?`[SYSTEM] You have only ${e} step(s) remaining. Wrap up your work and provide a final answer soon.`:null}buildReflectionHint(e,t,s){return t?"":["<thinking>",`Tool "${e}" FAILED. Before retrying:`,"1. What went wrong? Analyze the error message carefully.","2. Can I fix the arguments and retry?","3. Is there an alternative approach?",`Error preview: ${s.slice(0,300)}`,"</thinking>"].join(`
|
|
768
|
-
`)}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
|
|
769
|
-
`)}getFailureCount(e){return this.failures.get(e)?.count??0}shouldAutoRetry(e){let t=this.failures.get(e);return t?t.count<=1&&t.lastStrategy==="retry_same":!1}suggestAlternatives(e){return{read_file:["search_codebase","list_dir"],write_file:["edit_file","append_to_file"],edit_file:["search_and_replace","write_file","read_file"],search_and_replace:["edit_file","read_file"],patch_file:["edit_file","write_file"],run_command:["search_codebase"],search_codebase:["read_file","list_dir"],delete_file:["run_command"],create_dir:["run_command"],web_search:["scrape_url"]}[e]??[]}}});function
|
|
767
|
+
`)}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 xp(n=3){return new ua(n)}var ZS,ua,Sp=F(()=>{"use strict";ZS=[{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}],ua=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 ZS)if(a.test(t)){let l=r?.lastStrategy===a.strategy&&i>=2,c=l?"decompose_task":a.strategy;return o.lastStrategy=c,this.failures.set(e,o),{errorClass:a.errorClass,strategy:c,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(`
|
|
768
|
+
`)}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 e_(){try{if(vt.existsSync(Zs))return JSON.parse(vt.readFileSync(Zs,"utf-8"))}catch{}return{}}function t_(n){try{let e=er.dirname(Zs);vt.existsSync(e)||vt.mkdirSync(e,{recursive:!0}),vt.writeFileSync(Zs,JSON.stringify(n,null,2),"utf-8")}catch{}}function ha(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 Un(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 n_(n){return n.replace(/"/g,'"').replace(/'/g,"'").replace(/</g,"<").replace(/>/g,">").replace(/&/g,"&")}function s_(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=ha(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 r_(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=Un(r);i&&e.push({...i,format:"xml_tags",rawMatch:s[0]})}catch{}return e}function i_(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=Un(r);i&&e.push({...i,format:"hermes",rawMatch:s[0]})}}catch{}return e}function o_(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=Ap(r);for(let o of i)e.push({...o,format:"xml_tool_call_wrapper",rawMatch:s[0]})}return e}function Ap(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={},c=/(\w+)\s*=\s*(?:"([^"]*)"|'([^']*)'|(\S+))/g,u;for(;(u=c.exec(o))!==null;){let h=u[1].toLowerCase(),m=u[2]??u[3]??u[4];l[h]=n_(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 a_(n){return Ap(n)}function l_(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=Un(r);i&&e.push({...i,format:"markdown_json",rawMatch:s[0]})}catch{}return e}function c_(n){let e=[],t=/\{\s*"function"\s*:/g,s;for(;(s=t.exec(n))!==null;){let r=ha(n,s.index);if(r)try{let i=JSON.parse(r),o=Un(i);o&&e.push({...o,format:"function_call",rawMatch:r})}catch{}}return e}function u_(n){let e=[],t=/\{\s*"(?:name|tool)"\s*:/g,s;for(;(s=t.exec(n))!==null;){let r=ha(n,s.index);if(r)try{let i=JSON.parse(r),o=Un(i);o&&e.push({...o,format:"json_object",rawMatch:r})}catch{}}return e}function d_(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={},c=/<parameter=([^>]+)>([\s\S]*?)<\/parameter>/gi,u;for(;(u=c.exec(i))!==null;){let f=u[1].trim(),h=u[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,c;for(;(c=l.exec(n))!==null;){let u=c[1].trim(),f=c[2].trim();f==="true"?f=!0:f==="false"?f=!1:!isNaN(Number(f))&&f!==""&&(f=Number(f)),a[u]=f}e.push({tool:o,args:a,format:"xml_parameters",rawMatch:n})}}return e}function kp(){return fa||(fa=new pa),fa}var vt,er,_p,Zs,da,pa,fa,$p=F(()=>{"use strict";vt=O(require("fs")),er=O(require("path")),_p=O(require("os")),Zs=er.join(_p.homedir(),".hablas","model-formats.json");da=[{format:"action_tag_json",parse:s_},{format:"xml_tool_call_wrapper",parse:o_},{format:"xml_prompt",parse:a_},{format:"xml_tags",parse:r_},{format:"xml_parameters",parse:d_},{format:"hermes",parse:i_},{format:"markdown_json",parse:l_},{format:"function_call",parse:c_},{format:"json_object",parse:u_}],pa=class{registry;constructor(){this.registry=e_()}parse(e,t,s){if(t&&Array.isArray(t)&&t.length>0){let i=t.filter(o=>o?.function?.name&&typeof o.function.name=="string");if(i.length>0){let o=i.map(a=>({function:{name:a.function.name,arguments:a.function.arguments||{}}}));return s&&this.learnFormat(s,"native"),{toolCalls:o,displayContent:(e||"").trim(),format:"native"}}}let r=e||"";if(!r.trim())return{toolCalls:[],displayContent:"",format:"unknown"};if(s){let i=this.registry[s];if(i&&i.format!=="native"){let o=da.find(a=>a.format===i.format);if(o){let a=o.parse(r);if(a.length>0)return this.learnFormat(s,i.format),this.buildResult(a,r)}}}for(let{parse:i}of da){let o=i(r);if(o.length>0){let a=o[0].format;return s&&this.learnFormat(s,a),this.buildResult(o,r)}}return{toolCalls:[],displayContent:r.trim(),format:"unknown"}}mightContainToolCall(e){if(!e)return!1;let t=e.trim();return!!(/<<?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 da)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()},t_(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(/\n{3,}/g,`
|
|
770
769
|
|
|
771
|
-
`),{toolCalls:s,displayContent:r.trim(),format:e[0]?.format??"unknown"}}},fa=null});function
|
|
772
|
-
Please correct your format and try again. Ensure all JSON keys/values are double-quoted and correctly escaped.`;
|
|
773
|
-
## Handoff Chain`);for(let p of o)
|
|
774
|
-
`),h=he.find(p=>p.role===l);if(h&&a>0){let p=e[a-1].role,
|
|
770
|
+
`),{toolCalls:s,displayContent:r.trim(),format:e[0]?.format??"unknown"}}},fa=null});function p_(n,e,t){let r=kp().parse(e,n,t);return{toolCalls:r.toolCalls,displayContent:r.displayContent}}function h_(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 m_(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 Tp(n,e,t,s){let r=0,i=Date.now();for(;r<=Ep;){let o=await n.execute({name:e,arguments:t});if(o.success||r>=Ep)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 qn(n){let{identity:e,client:t,registry:s,session:r,contextManager:i,logger:o,io:a={},safetyPolicy:l,abortSignal:c,skipTools:u}=n,f=n.reactEngine??vp(),h=n.errorRecovery??xp(),m=u?[]:s.getOllamaTools(),p=t.getModel(),g=n.maxIterations??f_,x=[],S=[],C=[],k="",y=0,v=!1;for(;y<g;){if(y++,c?.aborted)return{output:k,toolsUsed:It(x),toolResults:S,touchedFiles:It(C),iterations:y,success:!1,error:"Aborted",completedNaturally:v};let b=f.buildBudgetWarningPrompt();b&&r.addUserMessage(b,{priority:"critical",tags:["system-budget"]});let w;try{w=await t.chatWithTools(r.getMessages(),m,c)}catch(U){let E=U;if(E.name==="AbortError"||c?.aborted)return{output:k,toolsUsed:It(x),toolResults:S,touchedFiles:It(C),iterations:y,success:!1,error:"Aborted",completedNaturally:v};if(y<=1){a.onNotice?.(`Transient model error: ${E.message??"unknown"} \u2014 retrying\u2026`,"retry"),await new Promise(A=>setTimeout(A,1e3)),y--;continue}return a.onError?.(E.message??"Model request failed"),{output:k,toolsUsed:It(x),toolResults:S,touchedFiles:It(C),iterations:y,success:!1,error:E.message,completedNaturally:v}}let _=w.message?.content||"",R=w.message?.tool_calls,D=f.parseThinking(_);D.hasThinking&&(f.recordStep({thought:D.thinking}),o.debug({thinking:D.thinking.slice(0,200)},"ReAct thinking"));let{toolCalls:$,displayContent:M}=p_(R,_,p);if($.length===0&&_.toLowerCase().includes("<action>")){let U=`[SYSTEM ERROR] Malformed action block detected inside <action> tags. Expected a valid JSON object matching the HEP-1 tool schema.
|
|
771
|
+
Please correct your format and try again. Ensure all JSON keys/values are double-quoted and correctly escaped.`;a.onNotice?.("Malformed action block detected \u2014 triggering self-correction loop\u2026","retry"),r.addToolMessage(U);continue}if(M&&M.trim()&&(k=M,await a.onAssistantText?.(M,e)),$.length===0){r.addAssistantMessage(_,void 0,e.role),v=!0;break}r.addAssistantMessage(_,$,e.role);let N=$.length;for(let U=0;U<$.length;U++){let E=$[U];if(!E?.function?.name)continue;let A=E.function.name,V=E.function.arguments||{},q=s.getSafetyLevel(A)??"confirm";if(!s.get(A)){a.onNotice?.(`Unknown tool: ${A} \u2014 skipping`,"warn"),r.addToolMessage(`Error: Unknown tool "${A}". Available: ${s.getAll().map(At=>At.name).join(", ")}`);continue}if(await l(A,q,V)==="skip"){r.addToolMessage(`Tool ${A} was skipped by policy/user.`);break}x.push(A),typeof V.path=="string"&&C.push(V.path);let ve=h_(A,V);a.onToolStart?.(A,ve,V),a.onToolCall?.(),f.recordStep({thought:D.hasThinking?`Executing: ${A}`:"",action:A,actionInput:V});let X=await Tp(s,A,V,o);a.onToolEnd?.(A,X.success,X.error||X.output,X.duration,V);let qe;if(X.success)qe=Ln(X.output,Cp),f.recordObservation(qe.slice(0,300)),S.push({tool:A,success:!0,summary:X.output.slice(0,150)});else{let At=X.error||"Unknown error",Ke=h.analyze(A,At,V);if(qe=h.buildRecoveryMessage(Ke,At),f.recordObservation(`FAILED: ${At}`,`Recovery: ${Ke.strategy} \u2014 ${Ke.suggestion}`),o.info({tool:A,errorClass:Ke.errorClass,strategy:Ke.strategy},"Error recovery analysis"),S.push({tool:A,success:!1,summary:At.slice(0,150)}),Ke.autoRetry&&!f.isOverBudget()){a.onNotice?.("Auto-retrying (transient error)\u2026","retry");let _e=await Tp(s,A,V,o);a.onToolEnd?.(A,_e.success,_e.output,_e.duration,V),_e.success&&(qe=Ln(_e.output,Cp),f.recordObservation(qe.slice(0,300),"Auto-retry succeeded"),S[S.length-1]={tool:A,success:!0,summary:_e.output.slice(0,150)})}}if(r.addToolMessage(qe),X.success&&A==="read_file"&&typeof V.path=="string"&&i?.addFile(V.path,X.output),o.info({tool:A,success:X.success,durationMs:X.duration,retries:X.retries},"Tool executed"),!X.success&&m_(X.error)){a.onNotice?.("Critical tool failure \u2014 aborting subsequent tool executions.","warn");break}N>1&&U<N-1}f.isOverBudget()&&a.onNotice?.(`Reached max reasoning steps (${f.getConfig().maxSteps}). Wrapping up.`,"warn")}return y>=g&&!v&&a.onNotice?.(`Reached max iterations (${g}). Stopping.`,"warn"),o.info({summary:f.getTurnSummary(),agent:e.name},"Agentic turn completed"),{output:k,toolsUsed:It(x),toolResults:S,touchedFiles:It(C),iterations:y,success:!0,completedNaturally:v}}function It(n){return[...new Set(n)]}function Rp(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 Op(){return(n,e)=>e==="dangerous"?"skip":"allow"}var f_,Cp,Ep,ma=F(()=>{"use strict";Ki();wp();Sp();$p();f_=150,Cp=2e3,Ep=2});var Mp,g_,y_,b_,Pp,tr,Ip=F(()=>{"use strict";Mp=O(la());Sn();Gi();Wi();_n();fi();ho();ma();g_={hablas:"planner",bob:"architect",alex:"coder",david:"researcher",emma:"product-manager"},y_=(0,Mp.default)({level:"silent"}),b_=40,Pp={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}},tr=class{baseConfig;agentModels;toolRegistry=null;onOutput=null;channel=null;mindsetRegistry=Ps();sharedContext=null;contextManager;constructor(e){this.baseConfig=e,this.agentModels=An(),this.contextManager=new an(e)}setSharedContext(e){this.sharedContext=e}setChannel(e){this.channel=e}setToolRegistry(e){this.toolRegistry=e}setOutputCallback(e){this.onOutput=e}reloadModels(){this.agentModels=An()}getAgentModel(e){let t=this.agentModels[e];if(t)return{model:t.model,temperature:t.temperature??Pp[e]?.temperature??.5};let s=Pp[e];return{model:s.model,temperature:s.temperature??.5}}async runAgent(e,t,s,r,i){let o=Date.now(),a=he.find(C=>C.role===e),l=this.getAgentModel(e),c=i?.maxIterations||b_,u={...this.baseConfig,model:l.model},f=Le(u),h=this.buildAgentPrompt(a,s),m=new Pt(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:C=>{this.emit(a.name,"speaking",C.slice(0,200))},onToolStart:(C,k,y)=>{this.emit(a.name,"tool",k),this.channel&&this.channel.emitEvent({type:"act",agent:a.name,toolName:C,toolArgs:this.safeArgs(y),content:k})},onToolEnd:(C,k,y)=>{this.channel&&this.channel.emitEvent({type:"observe",agent:a.name,toolName:C,success:k,content:k?this.summarizeOk(C,y):`error: ${y.slice(0,120)}`})},onError:C=>this.emit(a.name,"error",C)},x=await qn({identity:p,client:f,registry:this.toolRegistry,session:m,contextManager:this.contextManager,logger:y_,io:g,safetyPolicy:Op(),abortSignal:i?.abortSignal,skipTools:(!r||r.length===0,!1),maxIterations:c});if(this.sharedContext&&x.touchedFiles.length)try{this.sharedContext.set(`files:@${a.name}`,x.touchedFiles.join(", "))}catch{}let S=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:S,touchedFiles:x.touchedFiles}}async runSequential(e,t,s){let r=[],i="",o=[];for(let a=0;a<e.length;a++){let{role:l,task:c}=e[a];if(s?.abortSignal?.aborted)break;let u=[];if(i&&(u.push("## Previous Agent Results"),u.push(i)),o.length>0){u.push(`
|
|
772
|
+
## Handoff Chain`);for(let p of o)u.push(`- @${p.from} \u2192 @${p.to}: ${p.context.slice(0,100)}`)}let f=u.join(`
|
|
773
|
+
`),h=he.find(p=>p.role===l);if(h&&a>0){let p=e[a-1].role,g=he.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,c,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+=`
|
|
775
774
|
|
|
776
|
-
### @${m.agentName} (${he.find(
|
|
777
|
-
${p}`,a<e.length-1&&o.push({from:l,to:e[a+1].role,context:m.output.slice(0,200),artifacts:m.touchedFiles})}}return r}async runParallel(e,t,s){let r=s?.maxConcurrent||3,i=[];for(let o=0;o<e.length;o+=r){let a=e.slice(o,o+r),l=await Promise.all(a.map(({role:c,task:
|
|
775
|
+
### @${m.agentName} (${he.find(g=>g.role===l)?.title||l})
|
|
776
|
+
${p}`,a<e.length-1&&o.push({from:l,to:e[a+1].role,context:m.output.slice(0,200),artifacts:m.touchedFiles})}}return r}async runParallel(e,t,s){let r=s?.maxConcurrent||3,i=[];for(let o=0;o<e.length;o+=r){let a=e.slice(o,o+r),l=await Promise.all(a.map(({role:c,task:u})=>this.runAgent(c,u,void 0,t,s)));i.push(...l)}return i}async runWithEscalation(e,t,s,r){let i=await this.runAgent(e,t,s,r);if(i.success)return i;this.emit(he.find(a=>a.role===e)?.name||e,"error",`First attempt failed: ${i.error}. Retrying...`);let o=(s||"")+`
|
|
778
777
|
|
|
779
778
|
## Previous Attempt Failed
|
|
780
779
|
Error: ${i.error}
|
|
781
780
|
Please try a different approach.`;if(i=await this.runAgent(e,t,o,r),i.success)return i;if(e!=="hablas"){this.emit("Hablas","thinking",`@${he.find(l=>l.role===e)?.name} failed. Hablas taking over...`);let a=`Agent @${e} failed twice on this task.
|
|
782
781
|
Original error: ${i.error}
|
|
783
|
-
Please complete this task.`;return this.runAgent("hablas",t,a,r)}return i}buildAgentPrompt(e,t){let s=
|
|
782
|
+
Please complete this task.`;return this.runAgent("hablas",t,a,r)}return i}buildAgentPrompt(e,t){let s=g_[e.role]??"coder",r=this.mindsetRegistry.get(s),o=(r?`${r.systemPrompt}
|
|
784
783
|
|
|
785
784
|
---
|
|
786
785
|
|
|
@@ -841,15 +840,15 @@ Expertise: ${e.expertise.join(", ")}
|
|
|
841
840
|
${t}`),this.sharedContext){let a=this.sharedContext.getSummary();a&&(o+=`
|
|
842
841
|
|
|
843
842
|
## Shared Team Context
|
|
844
|
-
${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
|
|
845
|
-
${
|
|
843
|
+
${a}`)}return o}emit(e,t,s){if(this.onOutput&&this.onOutput(e,t,s),this.channel){let r=t==="speaking"?"speak":t==="tool"?"act":t;this.channel.emitEvent({type:r,agent:e,content:s})}}safeArgs(e){let t={};for(let[s,r]of Object.entries(e||{}))typeof r=="string"?t[s]=r.length>160?r.slice(0,160)+"\u2026":r:(typeof r=="number"||typeof r=="boolean")&&(t[s]=r);return t}summarizeOk(e,t){let s=t.split(/\r?\n/).length;return e==="write_file"||e==="edit_file"||e==="patch_file"?`ok \xB7 ${s} line${s===1?"":"s"}`:e==="run_command"?`ok \xB7 ${t.split(/\r?\n/).find(i=>i.trim())?.slice(0,80)||"ok"}`:e==="read_file"?`ok \xB7 ${s} line${s===1?"":"s"} read`:"ok"}}});var Lp,nr,Dp=F(()=>{"use strict";Lp=require("events"),nr=class extends Lp.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 v_,it,sr,rr,Fp=F(()=>{"use strict";Sn();v_={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."},it={hablas:"Hablas",emma:"Emma",bob:"Bob",alex:"Alex",david:"David"},sr={handoff:(n,e,t)=>{let s=it[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, @${it[e]}. Proceeding.`,review:(n,e)=>`@${it[e]}, structurally sound. Watch the boundaries on the next pass.`,reviewAck:(n,e)=>`Noted, @${it[e]}. Integrating.`},rr=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=Le(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),()=>sr.handoff(e,t,s))}async generateAckLine(e,t){return this.generate(`ack:${e}:${t}`,this.buildPrompt(e,t,"ack"),()=>sr.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)),()=>sr.review(e,t))}async generateReviewAck(e,t){return this.generate(`reviewAck:${e}:${t}`,this.buildPrompt(e,t,"reviewAck"),()=>sr.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 ${it[e]}, speaking in your own voice.
|
|
844
|
+
${v_[e]}
|
|
846
845
|
|
|
847
846
|
Hard constraints:
|
|
848
847
|
- Output exactly ONE sentence.
|
|
849
848
|
- No prefix, no quotes, no markdown, no emojis, no role labels.
|
|
850
849
|
- Maximum ${this.opts.maxChars} characters.
|
|
851
|
-
- Address @${
|
|
852
|
-
- Stay in character. Be useful, not chatty.`,o;switch(s){case"handoff":o=`You are about to hand the following task to @${
|
|
850
|
+
- Address @${it[t]} directly.
|
|
851
|
+
- Stay in character. Be useful, not chatty.`,o;switch(s){case"handoff":o=`You are about to hand the following task to @${it[t]}. Write a single in-character line that briefly frames what you need from them. Task: "${(r||"").slice(0,300)}"`;break;case"ack":o=`@${it[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 @${it[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=`@${it[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 Q,Je,w_,jp,x_,Hp,Np,pn,ga=F(()=>{"use strict";Q=O(require("fs")),Je=O(require("path")),w_=".hablas",jp=`# Project Context
|
|
853
852
|
|
|
854
853
|
## Overview
|
|
855
854
|
<!-- Auto-generated by hablas. Describe your project here. -->
|
|
@@ -862,34 +861,34 @@ Hard constraints:
|
|
|
862
861
|
|
|
863
862
|
## Notes
|
|
864
863
|
<!-- Miscellaneous context for agents -->
|
|
865
|
-
`,
|
|
864
|
+
`,x_=`# Decisions Log
|
|
866
865
|
|
|
867
866
|
| Date | Decision | By | Rationale |
|
|
868
867
|
|------|----------|-----|-----------|
|
|
869
|
-
`,
|
|
868
|
+
`,Hp=`# Task Assignments
|
|
870
869
|
|
|
871
870
|
## Active Tasks
|
|
872
871
|
<!-- Format: - [ ] Task description (@agent) -->
|
|
873
872
|
|
|
874
873
|
## Completed
|
|
875
874
|
<!-- Format: - [x] Task description (@agent) \u2014 result -->
|
|
876
|
-
`,
|
|
877
|
-
`+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")||
|
|
875
|
+
`,Np={"CONTEXT.md":jp,"DECISIONS.md":x_,"TASKS.md":Hp},pn=class{contextDir;constructor(e){this.contextDir=Je.join(e,w_)}init(){let e=Je.join(Je.dirname(this.contextDir),".flowagent");if(Q.existsSync(e)&&!Q.existsSync(this.contextDir))try{Q.renameSync(e,this.contextDir)}catch{}Q.existsSync(this.contextDir)||Q.mkdirSync(this.contextDir,{recursive:!0});for(let[t,s]of Object.entries(Np)){let r=Je.join(this.contextDir,t);Q.existsSync(r)||Q.writeFileSync(r,s,"utf-8")}}exists(){return Q.existsSync(this.contextDir)}read(e){let t=Je.join(this.contextDir,e);return Q.existsSync(t)?Q.readFileSync(t,"utf-8"):null}write(e,t){this.ensureDir();let s=Je.join(this.contextDir,e);Q.writeFileSync(s,t,"utf-8")}append(e,t){this.ensureDir();let s=Je.join(this.contextDir,e),r=Q.existsSync(s)?Q.readFileSync(s,"utf-8"):"";Q.writeFileSync(s,r+`
|
|
876
|
+
`+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")||Hp).replace(`## Active Tasks
|
|
878
877
|
`,`## Active Tasks
|
|
879
878
|
${s}
|
|
880
|
-
`);this.write("TASKS.md",i)}completeTask(e,t){let s=this.read("TASKS.md");if(!s)return;let r=`- [ ] ${e}`,i=`- [x] ${e}${t?" \u2014 "+t:""}`,o=s.replace(r,i);this.write("TASKS.md",o)}getAll(){return
|
|
879
|
+
`);this.write("TASKS.md",i)}completeTask(e,t){let s=this.read("TASKS.md");if(!s)return;let r=`- [ ] ${e}`,i=`- [x] ${e}${t?" \u2014 "+t:""}`,o=s.replace(r,i);this.write("TASKS.md",o)}getAll(){return Q.existsSync(this.contextDir)?Q.readdirSync(this.contextDir).filter(t=>t.endsWith(".md")).map(t=>{let s=Je.join(this.contextDir,t),r=Q.statSync(s);return{file:t,content:Q.readFileSync(s,"utf-8"),lastModified:r.mtime}}):[]}getSummary(){let e=this.getAll();return e.length===0?"":e.map(t=>`### ${t.file}
|
|
881
880
|
${t.content}`).join(`
|
|
882
881
|
|
|
883
|
-
`)}kvStore=new Map;set(e,t){this.kvStore.set(e,t),this.persistKV()}get(e){return this.kvStore.get(e)}delete(e){let t=this.kvStore.delete(e);return t&&this.persistKV(),t}clear(){this.kvStore.clear();for(let[e,t]of Object.entries(
|
|
882
|
+
`)}kvStore=new Map;set(e,t){this.kvStore.set(e,t),this.persistKV()}get(e){return this.kvStore.get(e)}delete(e){let t=this.kvStore.delete(e);return t&&this.persistKV(),t}clear(){this.kvStore.clear();for(let[e,t]of Object.entries(Np)){let s=Je.join(this.contextDir,e);Q.existsSync(s)&&Q.writeFileSync(s,t,"utf-8")}}getDecisions(){let e=this.read("DECISIONS.md");if(!e)return[];let t=e.split(`
|
|
884
883
|
`),s=[];for(let r of t){let i=r.match(/^\|\s*(\d{4}-\d{2}-\d{2})\s*\|\s*(.+?)\s*\|\s*(.+?)\s*\|\s*(.+?)\s*\|$/);i&&s.push({timestamp:i[1],decision:i[2].trim(),by:i[3].trim(),rationale:i[4].trim()})}return s}render(){let e=[];if(this.kvStore.size>0){e.push(" Key-Value Store:");for(let[r,i]of this.kvStore)e.push(` ${r}: ${i}`)}else e.push(" No key-value entries");let t=this.getAll();if(t.length>0){e.push(""),e.push(" Context Files:");for(let r of t){let i=r.content.split(`
|
|
885
884
|
`).length;e.push(` ${r.file} (${i} lines)`)}}let s=this.getDecisions();return s.length>0&&(e.push(""),e.push(` Decisions: ${s.length} logged`)),e.join(`
|
|
886
885
|
`)}persistKV(){if(this.kvStore.size===0)return;let e=this.read("CONTEXT.md")||jp,t=Array.from(this.kvStore.entries()).map(([i,o])=>`- **${i}**: ${o}`).join(`
|
|
887
886
|
`),s=/## Notes\n[\s\S]*$/,r=e.replace(s,`## Notes
|
|
888
887
|
${t}
|
|
889
|
-
`);this.write("CONTEXT.md",r)}ensureDir(){
|
|
888
|
+
`);this.write("CONTEXT.md",r)}ensureDir(){Q.existsSync(this.contextDir)||Q.mkdirSync(this.contextDir,{recursive:!0})}}});function ya(n){return he.find(e=>e.role===n)?.name||n}var ir,Bp=F(()=>{"use strict";_n();ga();ir=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}
|
|
890
889
|
|
|
891
|
-
Original request: ${e}`})),l=[],c="hablas",
|
|
892
|
-
${
|
|
890
|
+
Original request: ${e}`})),l=[],c="hablas",u=null;for(let h of a){if(r.abortSignal?.aborted)break;let m=he.find(C=>C.role===h.role);if(!m)continue;this.channel.emitEvent({type:"handoff",agent:ya(c),to:m.name});let p=await this.chat.generateHandoffLine(c,h.role,h.task);this.channel.emitEvent({type:"speak",agent:ya(c),to:m.name,content:p});let g=await this.chat.generateAckLine(h.role,c);this.channel.emitEvent({type:"speak",agent:m.name,to:ya(c),content:g});let x=Date.now(),S=await this.runner.runAgent(h.role,h.task,void 0,s,{abortSignal:r.abortSignal});l.push(S),S.success&&S.output?(this.channel.emitEvent({type:"summary",agent:m.name,durationMs:Date.now()-x}),h.role==="alex"&&(u=S.output),i&&h.role==="alex"&&t.tasks.some(C=>C.role==="bob")&&u&&await this.runPeerReview("bob","alex",u,r.abortSignal)):S.error&&this.channel.emitEvent({type:"error",agent:m.name,content:S.error}),c=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=he.find(c=>c.role===e),o=he.find(c=>c.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(u=>u.success&&u.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(u=>{let f=he.find(h=>h.role===u.agent);return`### Report from @${u.agentName} (${f?.title??u.agent}):
|
|
891
|
+
${u.output}`}).join(`
|
|
893
892
|
|
|
894
893
|
`),a=`You are Hablas, the Team Leader. Your team has completed a multi-agent workflow for the user's request: "${e}".
|
|
895
894
|
|
|
@@ -898,39 +897,53 @@ Here are the individual execution reports from your team members:
|
|
|
898
897
|
${o}
|
|
899
898
|
"""
|
|
900
899
|
|
|
901
|
-
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 c=i.map(
|
|
902
|
-
${
|
|
903
|
-
|
|
904
|
-
`);return{results:t,finalSynthesis:c,synthesisOk:!1}}}});function Xe(n){switch(n){case"Hablas":return
|
|
905
|
-
${
|
|
906
|
-
${i("\u270E")} ${
|
|
907
|
-
${
|
|
908
|
-
`+qc({taskTitle:A.slice(0,40),currentPhase:"Team Coordination",activeAgent:"Hablas",activeAgentTitle:"Team Leader",currentActivity:"Executing multi-agent plan",roster:{Hablas:"active",Emma:T.includes("emma")?"pending":"done",Bob:T.includes("bob")?"pending":"done",Alex:T.includes("alex")?"pending":"done",David:T.includes("david")?"pending":"done"}}));let $=new or(h,f,m,n),{finalSynthesis:F}=await $.run(A,P,r.getOllamaTools());console.log($n("Hablas","Team Leader")),console.log(En(F)),S.addAssistantMessage(F)}else S.addUserMessage(A),await tr({identity:{name:"Hablas",title:"Team Leader",role:"hablas"},client:s,registry:r,session:S,contextManager:i,logger:e,safetyPolicy:Op({autoMode:n.autoMode,interactive:!0,confirm:T=>o.confirm(T),confirmDangerous:T=>o.confirmDangerous(T)}),io:{onAssistantText:async T=>{console.log($n("Hablas","Team Leader")),console.log(En(T))},onToolStart:(T,P)=>console.log(u.muted(` \u2699 Executing ${T}: ${P}`)),onToolEnd:(T,P)=>console.log(P?u.success(` \u2713 ${T} done`):u.error(` \u2717 ${T} failed`)),onToolCall:()=>ps(yi(Jt(),"tool_call"))}})}catch(k){console.log(ke(k.message))}}function x_(n,e){return n.replace(/#([\w./-]+)/g,(t,s)=>{let r=Qp.resolve(e,s);return Jp.existsSync(r)?s:t})}var Jp,Qp,w_,gt=N(()=>{"use strict";fu();Jp=O(require("fs")),Qp=O(require("path"));xn();nd();Wi();Gi();od();ho();cd();Xr();Sn();Lp();Np();Fp();Up();Kp();An();ga();qp();Gp();Yp();en();ma();w_=null});function Be(n={}){let e={};if(wt.existsSync(xa))try{let s=wt.readFileSync(xa,"utf-8");e=JSON.parse(s)}catch{}let t={...vn,...e,tools:{...vn.tools,...e.tools||{}},ui:{...vn.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=Bn.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 it(n){wt.existsSync(wa)||wt.mkdirSync(wa,{recursive:!0}),wt.writeFileSync(xa,JSON.stringify(n,null,2),"utf-8")}var wt,Bn,Xp,wa,xa,Sa=N(()=>{"use strict";wt=O(require("fs")),Bn=O(require("path")),Xp=O(require("os"));wn();wa=Bn.join(Xp.homedir(),".hablas"),xa=Bn.join(wa,"config.json")});function xt(n){let e=Aa.join(Zp.homedir(),".hablas","logs");ur.existsSync(e)||ur.mkdirSync(e,{recursive:!0});let t=Aa.join(e,`session-${Date.now()}.log`);return(0,_a.default)({level:"info"},_a.default.destination({dest:t,sync:!1}))}var _a,Aa,Zp,ur,ka=N(()=>{"use strict";_a=O(la()),Aa=O(require("path")),Zp=O(require("os")),ur=O(require("fs"))});var Un=H((lR,rh)=>{"use strict";var S_=require("path"),ot="\\\\/",eh=`[^${ot}]`,__=0,St="\\.",A_="\\+",k_="\\?",dr="\\/",$_="(?=.)",th="[^/]",$a=`(?:${dr}|$)`,nh=`(?:^|${dr})`,Ea=`${St}{1,2}${$a}`,E_=`(?!${St})`,T_=`(?!${nh}${Ea})`,C_=`(?!${St}{0,1}${$a})`,R_=`(?!${Ea})`,O_=`[^.${dr}]`,P_=`${th}*?`,sh={DOT_LITERAL:St,PLUS_LITERAL:A_,QMARK_LITERAL:k_,SLASH_LITERAL:dr,ONE_CHAR:$_,QMARK:th,END_ANCHOR:$a,DOTS_SLASH:Ea,NO_DOT:E_,NO_DOTS:T_,NO_DOT_SLASH:C_,NO_DOTS_SLASH:R_,QMARK_NO_DOT:O_,STAR:P_,START_ANCHOR:nh},I_={...sh,SLASH_LITERAL:`[${ot}]`,QMARK:eh,STAR:`${eh}*?`,DOTS_SLASH:`${St}{1,2}(?:[${ot}]|$)`,NO_DOT:`(?!${St})`,NO_DOTS:`(?!(?:^|[${ot}])${St}{1,2}(?:[${ot}]|$))`,NO_DOT_SLASH:`(?!${St}{0,1}(?:[${ot}]|$))`,NO_DOTS_SLASH:`(?!${St}{1,2}(?:[${ot}]|$))`,QMARK_NO_DOT:`[^.${ot}]`,START_ANCHOR:`(?:^|[${ot}])`,END_ANCHOR:`(?:[${ot}]|$)`},M_={__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"};rh.exports={DEFAULT_MAX_EXTGLOB_RECURSION:__,MAX_LENGTH:1024*64,POSIX_REGEX_SOURCE:M_,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:S_.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?I_:sh}}});var fr=H(Ce=>{"use strict";var L_=require("path"),D_=process.platform==="win32",{REGEX_BACKSLASH:N_,REGEX_REMOVE_BACKSLASH:F_,REGEX_SPECIAL_CHARS:H_,REGEX_SPECIAL_CHARS_GLOBAL:j_}=Un();Ce.isObject=n=>n!==null&&typeof n=="object"&&!Array.isArray(n);Ce.hasRegexChars=n=>H_.test(n);Ce.isRegexChar=n=>n.length===1&&Ce.hasRegexChars(n);Ce.escapeRegex=n=>n.replace(j_,"\\$1");Ce.toPosixSlashes=n=>n.replace(N_,"/");Ce.removeBackslashes=n=>n.replace(F_,e=>e==="\\"?"":e);Ce.supportsLookbehinds=()=>{let n=process.version.slice(1).split(".").map(Number);return n.length===3&&n[0]>=9||n[0]===8&&n[1]>=10};Ce.isWindows=n=>n&&typeof n.windows=="boolean"?n.windows:D_===!0||L_.sep==="\\";Ce.escapeLast=(n,e,t)=>{let s=n.lastIndexOf(e,t);return s===-1?n:n[s-1]==="\\"?Ce.escapeLast(n,e,s-1):`${n.slice(0,s)}\\${n.slice(s)}`};Ce.removePrefix=(n,e={})=>{let t=n;return t.startsWith("./")&&(t=t.slice(2),e.prefix="./"),t};Ce.wrapOutput=(n,e={},t={})=>{let s=t.contains?"":"^",r=t.contains?"":"$",i=`${s}(?:${n})${r}`;return e.negated===!0&&(i=`(?:^(?!${i}).*$)`),i}});var fh=H((uR,dh)=>{"use strict";var ih=fr(),{CHAR_ASTERISK:Ta,CHAR_AT:B_,CHAR_BACKWARD_SLASH:Kn,CHAR_COMMA:U_,CHAR_DOT:Ca,CHAR_EXCLAMATION_MARK:Ra,CHAR_FORWARD_SLASH:uh,CHAR_LEFT_CURLY_BRACE:Oa,CHAR_LEFT_PARENTHESES:Pa,CHAR_LEFT_SQUARE_BRACKET:K_,CHAR_PLUS:q_,CHAR_QUESTION_MARK:oh,CHAR_RIGHT_CURLY_BRACE:W_,CHAR_RIGHT_PARENTHESES:ah,CHAR_RIGHT_SQUARE_BRACKET:G_}=Un(),lh=n=>n===uh||n===Kn,ch=n=>{n.isPrefix!==!0&&(n.depth=n.isGlobstar?1/0:1)},V_=(n,e)=>{let t=e||{},s=n.length-1,r=t.parts===!0||t.scanToEnd===!0,i=[],o=[],a=[],l=n,c=-1,d=0,f=0,h=!1,m=!1,p=!1,y=!1,S=!1,_=!1,k=!1,A=!1,g=!1,v=!1,b=0,w,x,T={value:"",depth:0,isGlob:!1},P=()=>c>=s,$=()=>l.charCodeAt(c+1),F=()=>(w=x,l.charCodeAt(++c));for(;c<s;){x=F();let J;if(x===Kn){k=T.backslashes=!0,x=F(),x===Oa&&(_=!0);continue}if(_===!0||x===Oa){for(b++;P()!==!0&&(x=F());){if(x===Kn){k=T.backslashes=!0,F();continue}if(x===Oa){b++;continue}if(_!==!0&&x===Ca&&(x=F())===Ca){if(h=T.isBrace=!0,p=T.isGlob=!0,v=!0,r===!0)continue;break}if(_!==!0&&x===U_){if(h=T.isBrace=!0,p=T.isGlob=!0,v=!0,r===!0)continue;break}if(x===W_&&(b--,b===0)){_=!1,h=T.isBrace=!0,v=!0;break}}if(r===!0)continue;break}if(x===uh){if(i.push(c),o.push(T),T={value:"",depth:0,isGlob:!1},v===!0)continue;if(w===Ca&&c===d+1){d+=2;continue}f=c+1;continue}if(t.noext!==!0&&(x===q_||x===B_||x===Ta||x===oh||x===Ra)===!0&&$()===Pa){if(p=T.isGlob=!0,y=T.isExtglob=!0,v=!0,x===Ra&&c===d&&(g=!0),r===!0){for(;P()!==!0&&(x=F());){if(x===Kn){k=T.backslashes=!0,x=F();continue}if(x===ah){p=T.isGlob=!0,v=!0;break}}continue}break}if(x===Ta){if(w===Ta&&(S=T.isGlobstar=!0),p=T.isGlob=!0,v=!0,r===!0)continue;break}if(x===oh){if(p=T.isGlob=!0,v=!0,r===!0)continue;break}if(x===K_){for(;P()!==!0&&(J=F());){if(J===Kn){k=T.backslashes=!0,F();continue}if(J===G_){m=T.isBracket=!0,p=T.isGlob=!0,v=!0;break}}if(r===!0)continue;break}if(t.nonegate!==!0&&x===Ra&&c===d){A=T.negated=!0,d++;continue}if(t.noparen!==!0&&x===Pa){if(p=T.isGlob=!0,r===!0){for(;P()!==!0&&(x=F());){if(x===Pa){k=T.backslashes=!0,x=F();continue}if(x===ah){v=!0;break}}continue}break}if(p===!0){if(v=!0,r===!0)continue;break}}t.noext===!0&&(y=!1,p=!1);let j=l,V="",C="";d>0&&(V=l.slice(0,d),l=l.slice(d),f-=d),j&&p===!0&&f>0?(j=l.slice(0,f),C=l.slice(f)):p===!0?(j="",C=l):j=l,j&&j!==""&&j!=="/"&&j!==l&&lh(j.charCodeAt(j.length-1))&&(j=j.slice(0,-1)),t.unescape===!0&&(C&&(C=ih.removeBackslashes(C)),j&&k===!0&&(j=ih.removeBackslashes(j)));let E={prefix:V,input:n,start:d,base:j,glob:C,isBrace:h,isBracket:m,isGlob:p,isExtglob:y,isGlobstar:S,negated:A,negatedExtglob:g};if(t.tokens===!0&&(E.maxDepth=0,lh(x)||o.push(T),E.tokens=o),t.parts===!0||t.tokens===!0){let J;for(let D=0;D<i.length;D++){let Q=J?J+1:d,ve=i[D],_e=n.slice(Q,ve);t.tokens&&(D===0&&d!==0?(o[D].isPrefix=!0,o[D].value=V):o[D].value=_e,ch(o[D]),E.maxDepth+=o[D].depth),(D!==0||_e!=="")&&a.push(_e),J=ve}if(J&&J+1<n.length){let D=n.slice(J+1);a.push(D),t.tokens&&(o[o.length-1].value=D,ch(o[o.length-1]),E.maxDepth+=o[o.length-1].depth)}E.slashes=i,E.parts=a}return E};dh.exports=V_});var yh=H((dR,gh)=>{"use strict";var qn=Un(),xe=fr(),{MAX_LENGTH:pr,POSIX_REGEX_SOURCE:z_,REGEX_NON_SPECIAL_CHARS:Y_,REGEX_SPECIAL_CHARS_BACKREF:J_,REPLACEMENTS:ph}=qn,Q_=(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=>xe.escapeRegex(r)).join("..")}return t},pn=(n,e)=>`Missing ${n}: "${e}" - use "\\\\${e}" to match literal characters`,hh=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},X_=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},mh=n=>{let e=n.trim(),t=!0;for(;t===!0;)t=!1,/^@\([^\\()[\]{}|]+\)$/.test(e)&&(e=e.slice(2,-1),t=!0);if(X_(e))return e.replace(/\\(.)/g,"$1")},Z_=n=>{let e=n.map(mh).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},Ia=(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}}}}},eA=n=>{let e=0,t=[];for(;e<n.length;){let r=Ia(n.slice(e),!1);if(!r||r.type!=="*")return;let i=hh(r.body).map(a=>a.trim());if(i.length!==1)return;let o=mh(i[0]);if(!o||o.length!==1)return;t.push(o),e+=r.end+1}return t.length<1?void 0:`${t.length===1?xe.escapeRegex(t[0]):`[${t.map(r=>xe.escapeRegex(r)).join("")}]`}*`},tA=n=>{let e=0,t=n.trim(),s=Ia(t);for(;s;)e++,t=s.body.trim(),s=Ia(t);return e},nA=(n,e)=>{if(e.maxExtglobRecursion===!1)return{risky:!1};let t=typeof e.maxExtglobRecursion=="number"?e.maxExtglobRecursion:qn.DEFAULT_MAX_EXTGLOB_RECURSION,s=hh(n).map(r=>r.trim());if(s.length>1&&(s.some(r=>r==="")||s.some(r=>/^[*?]+$/.test(r))||Z_(s)))return{risky:!0};for(let r of s){let i=eA(r);if(i)return{risky:!0,safeOutput:i};if(tA(r)>t)return{risky:!0}}return{risky:!1}},Ma=(n,e)=>{if(typeof n!="string")throw new TypeError("Expected a string");n=ph[n]||n;let t={...e},s=typeof t.maxLength=="number"?Math.min(pr,t.maxLength):pr,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=xe.isWindows(e),c=qn.globChars(l),d=qn.extglobChars(c),{DOT_LITERAL:f,PLUS_LITERAL:h,SLASH_LITERAL:m,ONE_CHAR:p,DOTS_SLASH:y,NO_DOT:S,NO_DOT_SLASH:_,NO_DOTS_SLASH:k,QMARK:A,QMARK_NO_DOT:g,STAR:v,START_ANCHOR:b}=c,w=L=>`(${a}(?:(?!${b}${L.dot?y:f}).)*?)`,x=t.dot?"":S,T=t.dot?A:g,P=t.bash===!0?w(t):v;t.capture&&(P=`(${P})`),typeof t.noext=="boolean"&&(t.noextglob=t.noext);let $={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=xe.removePrefix(n,$),r=n.length;let F=[],j=[],V=[],C=i,E,J=()=>$.index===r-1,D=$.peek=(L=1)=>n[$.index+L],Q=$.advance=()=>n[++$.index]||"",ve=()=>n.slice($.index+1),_e=(L="",ie=0)=>{$.consumed+=L,$.index+=ie},Vt=L=>{$.output+=L.output!=null?L.output:L.value,_e(L.value)},Se=()=>{let L=1;for(;D()==="!"&&(D(2)!=="("||D(3)==="?");)Q(),$.start++,L++;return L%2===0?!1:($.negated=!0,$.start++,!0)},qe=L=>{$[L]++,V.push(L)},pe=L=>{$[L]--,V.pop()},q=L=>{if(C.type==="globstar"){let ie=$.braces>0&&(L.type==="comma"||L.type==="brace"),M=L.extglob===!0||F.length&&(L.type==="pipe"||L.type==="paren");L.type!=="slash"&&L.type!=="paren"&&!ie&&!M&&($.output=$.output.slice(0,-C.output.length),C.type="star",C.value="*",C.output=P,$.output+=C.output)}if(F.length&&L.type!=="paren"&&(F[F.length-1].inner+=L.value),(L.value||L.output)&&Vt(L),C&&C.type==="text"&&L.type==="text"){C.value+=L.value,C.output=(C.output||"")+L.value;return}L.prev=C,o.push(L),C=L},Ae=(L,ie)=>{let M={...d[ie],conditions:1,inner:""};M.prev=C,M.parens=$.parens,M.output=$.output,M.startIndex=$.index,M.tokensIndex=o.length;let z=(t.capture?"(":"")+M.open;qe("parens"),q({type:L,value:ie,output:$.output?"":p}),q({type:"paren",extglob:!0,value:Q(),output:z}),F.push(M)},mg=L=>{let ie=n.slice(L.startIndex,$.index+1),M=n.slice(L.startIndex+2,$.index),z=nA(M,t);if((L.type==="plus"||L.type==="star")&&z.risky){let ee=z.safeOutput?(L.output?"":p)+(t.capture?`(${z.safeOutput})`:z.safeOutput):void 0,et=o[L.tokensIndex];et.type="text",et.value=ie,et.output=ee||xe.escapeRegex(ie);for(let tt=L.tokensIndex+1;tt<o.length;tt++)o[tt].value="",o[tt].output="",delete o[tt].suffix;$.output=L.output+et.output,$.backtrack=!0,q({type:"paren",extglob:!0,value:E,output:""}),pe("parens");return}let ne=L.close+(t.capture?")":""),fe;if(L.type==="negate"){let ee=P;if(L.inner&&L.inner.length>1&&L.inner.includes("/")&&(ee=w(t)),(ee!==P||J()||/^\)+$/.test(ve()))&&(ne=L.close=`)$))${ee}`),L.inner.includes("*")&&(fe=ve())&&/^\.[^\\/.]+$/.test(fe)){let et=Ma(fe,{...e,fastpaths:!1}).output;ne=L.close=`)${et})${ee})`}L.prev.type==="bos"&&($.negatedExtglob=!0)}q({type:"paren",extglob:!0,value:E,output:ne}),pe("parens")};if(t.fastpaths!==!1&&!/(^[*!]|[/()[\]{}"])/.test(n)){let L=!1,ie=n.replace(J_,(M,z,ne,fe,ee,et)=>fe==="\\"?(L=!0,M):fe==="?"?z?z+fe+(ee?A.repeat(ee.length):""):et===0?T+(ee?A.repeat(ee.length):""):A.repeat(ne.length):fe==="."?f.repeat(ne.length):fe==="*"?z?z+fe+(ee?P:""):P:z?M:`\\${M}`);return L===!0&&(t.unescape===!0?ie=ie.replace(/\\/g,""):ie=ie.replace(/\\+/g,M=>M.length%2===0?"\\\\":M?"\\":"")),ie===n&&t.contains===!0?($.output=n,$):($.output=xe.wrapOutput(ie,$,e),$)}for(;!J();){if(E=Q(),E==="\0")continue;if(E==="\\"){let M=D();if(M==="/"&&t.bash!==!0||M==="."||M===";")continue;if(!M){E+="\\",q({type:"text",value:E});continue}let z=/^\\+/.exec(ve()),ne=0;if(z&&z[0].length>2&&(ne=z[0].length,$.index+=ne,ne%2!==0&&(E+="\\")),t.unescape===!0?E=Q():E+=Q(),$.brackets===0){q({type:"text",value:E});continue}}if($.brackets>0&&(E!=="]"||C.value==="["||C.value==="[^")){if(t.posix!==!1&&E===":"){let M=C.value.slice(1);if(M.includes("[")&&(C.posix=!0,M.includes(":"))){let z=C.value.lastIndexOf("["),ne=C.value.slice(0,z),fe=C.value.slice(z+2),ee=z_[fe];if(ee){C.value=ne+ee,$.backtrack=!0,Q(),!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,Vt({value:E});continue}if($.quotes===1&&E!=='"'){E=xe.escapeRegex(E),C.value+=E,Vt({value:E});continue}if(E==='"'){$.quotes=$.quotes===1?0:1,t.keepQuotes===!0&&q({type:"text",value:E});continue}if(E==="("){qe("parens"),q({type:"paren",value:E});continue}if(E===")"){if($.parens===0&&t.strictBrackets===!0)throw new SyntaxError(pn("opening","("));let M=F[F.length-1];if(M&&$.parens===M.parens+1){mg(F.pop());continue}q({type:"paren",value:E,output:$.parens?")":"\\)"}),pe("parens");continue}if(E==="["){if(t.nobracket===!0||!ve().includes("]")){if(t.nobracket!==!0&&t.strictBrackets===!0)throw new SyntaxError(pn("closing","]"));E=`\\${E}`}else qe("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($.brackets===0){if(t.strictBrackets===!0)throw new SyntaxError(pn("opening","["));q({type:"text",value:E,output:`\\${E}`});continue}pe("brackets");let M=C.value.slice(1);if(C.posix!==!0&&M[0]==="^"&&!M.includes("/")&&(E=`/${E}`),C.value+=E,Vt({value:E}),t.literalBrackets===!1||xe.hasRegexChars(M))continue;let z=xe.escapeRegex(C.value);if($.output=$.output.slice(0,-C.value.length),t.literalBrackets===!0){$.output+=z,C.value=z;continue}C.value=`(${a}${z}|${C.value})`,$.output+=C.value;continue}if(E==="{"&&t.nobrace!==!0){qe("braces");let M={type:"brace",value:E,output:"(",outputIndex:$.output.length,tokensIndex:$.tokens.length};j.push(M),q(M);continue}if(E==="}"){let M=j[j.length-1];if(t.nobrace===!0||!M){q({type:"text",value:E,output:E});continue}let z=")";if(M.dots===!0){let ne=o.slice(),fe=[];for(let ee=ne.length-1;ee>=0&&(o.pop(),ne[ee].type!=="brace");ee--)ne[ee].type!=="dots"&&fe.unshift(ne[ee].value);z=Q_(fe,t),$.backtrack=!0}if(M.comma!==!0&&M.dots!==!0){let ne=$.output.slice(0,M.outputIndex),fe=$.tokens.slice(M.tokensIndex);M.value=M.output="\\{",E=z="\\}",$.output=ne;for(let ee of fe)$.output+=ee.output||ee.value}q({type:"brace",value:E,output:z}),pe("braces"),j.pop();continue}if(E==="|"){F.length>0&&F[F.length-1].conditions++,q({type:"text",value:E});continue}if(E===","){let M=E,z=j[j.length-1];z&&V[V.length-1]==="braces"&&(z.comma=!0,M="|"),q({type:"comma",value:E,output:M});continue}if(E==="/"){if(C.type==="dot"&&$.index===$.start+1){$.start=$.index+1,$.consumed="",$.output="",o.pop(),C=i;continue}q({type:"slash",value:E,output:m});continue}if(E==="."){if($.braces>0&&C.type==="dot"){C.value==="."&&(C.output=f);let M=j[j.length-1];C.type="dots",C.output+=E,C.value+=E,M.dots=!0;continue}if($.braces+$.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)!=="?"){Ae("qmark",E);continue}if(C&&C.type==="paren"){let z=D(),ne=E;if(z==="<"&&!xe.supportsLookbehinds())throw new Error("Node.js v10 or higher is required for regex lookbehinds");(C.value==="("&&!/[!=<:]/.test(z)||z==="<"&&!/<([!=]|\w+>)/.test(ve()))&&(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:g});continue}q({type:"qmark",value:E,output:A});continue}if(E==="!"){if(t.noextglob!==!0&&D()==="("&&(D(2)!=="?"||!/[!=<:]/.test(D(3)))){Ae("negate",E);continue}if(t.nonegate!==!0&&$.index===0){Se();continue}}if(E==="+"){if(t.noextglob!==!0&&D()==="("&&D(2)!=="?"){Ae("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")||$.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 M=Y_.exec(ve());M&&(E+=M[0],$.index+=M[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=P,$.backtrack=!0,$.globstar=!0,_e(E);continue}let L=ve();if(t.noextglob!==!0&&/^\([^?]/.test(L)){Ae("star",E);continue}if(C.type==="star"){if(t.noglobstar===!0){_e(E);continue}let M=C.prev,z=M.prev,ne=M.type==="slash"||M.type==="bos",fe=z&&(z.type==="star"||z.type==="globstar");if(t.bash===!0&&(!ne||L[0]&&L[0]!=="/")){q({type:"star",value:E,output:""});continue}let ee=$.braces>0&&(M.type==="comma"||M.type==="brace"),et=F.length&&(M.type==="pipe"||M.type==="paren");if(!ne&&M.type!=="paren"&&!ee&&!et){q({type:"star",value:E,output:""});continue}for(;L.slice(0,3)==="/**";){let tt=n[$.index+4];if(tt&&tt!=="/")break;L=L.slice(3),_e("/**",3)}if(M.type==="bos"&&J()){C.type="globstar",C.value+=E,C.output=w(t),$.output=C.output,$.globstar=!0,_e(E);continue}if(M.type==="slash"&&M.prev.type!=="bos"&&!fe&&J()){$.output=$.output.slice(0,-(M.output+C.output).length),M.output=`(?:${M.output}`,C.type="globstar",C.output=w(t)+(t.strictSlashes?")":"|$)"),C.value+=E,$.globstar=!0,$.output+=M.output+C.output,_e(E);continue}if(M.type==="slash"&&M.prev.type!=="bos"&&L[0]==="/"){let tt=L[1]!==void 0?"|$":"";$.output=$.output.slice(0,-(M.output+C.output).length),M.output=`(?:${M.output}`,C.type="globstar",C.output=`${w(t)}${m}|${m}${tt})`,C.value+=E,$.output+=M.output+C.output,$.globstar=!0,_e(E+Q()),q({type:"slash",value:"/",output:""});continue}if(M.type==="bos"&&L[0]==="/"){C.type="globstar",C.value+=E,C.output=`(?:^|${m}|${w(t)}${m})`,$.output=C.output,$.globstar=!0,_e(E+Q()),q({type:"slash",value:"/",output:""});continue}$.output=$.output.slice(0,-C.output.length),C.type="globstar",C.output=w(t),C.value+=E,$.output+=C.output,$.globstar=!0,_e(E);continue}let ie={type:"star",value:E,output:P};if(t.bash===!0){ie.output=".*?",(C.type==="bos"||C.type==="slash")&&(ie.output=x+ie.output),q(ie);continue}if(C&&(C.type==="bracket"||C.type==="paren")&&t.regex===!0){ie.output=E,q(ie);continue}($.index===$.start||C.type==="slash"||C.type==="dot")&&(C.type==="dot"?($.output+=_,C.output+=_):t.dot===!0?($.output+=k,C.output+=k):($.output+=x,C.output+=x),D()!=="*"&&($.output+=p,C.output+=p)),q(ie)}for(;$.brackets>0;){if(t.strictBrackets===!0)throw new SyntaxError(pn("closing","]"));$.output=xe.escapeLast($.output,"["),pe("brackets")}for(;$.parens>0;){if(t.strictBrackets===!0)throw new SyntaxError(pn("closing",")"));$.output=xe.escapeLast($.output,"("),pe("parens")}for(;$.braces>0;){if(t.strictBrackets===!0)throw new SyntaxError(pn("closing","}"));$.output=xe.escapeLast($.output,"{"),pe("braces")}if(t.strictSlashes!==!0&&(C.type==="star"||C.type==="bracket")&&q({type:"maybe_slash",value:"",output:`${m}?`}),$.backtrack===!0){$.output="";for(let L of $.tokens)$.output+=L.output!=null?L.output:L.value,L.suffix&&($.output+=L.suffix)}return $};Ma.fastpaths=(n,e)=>{let t={...e},s=typeof t.maxLength=="number"?Math.min(pr,t.maxLength):pr,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);n=ph[n]||n;let i=xe.isWindows(e),{DOT_LITERAL:o,SLASH_LITERAL:a,ONE_CHAR:l,DOTS_SLASH:c,NO_DOT:d,NO_DOTS:f,NO_DOTS_SLASH:h,STAR:m,START_ANCHOR:p}=qn.globChars(i),y=t.dot?f:d,S=t.dot?h:d,_=t.capture?"":"?:",k={negated:!1,prefix:""},A=t.bash===!0?".*?":m;t.capture&&(A=`(${A})`);let g=x=>x.noglobstar===!0?A:`(${_}(?:(?!${p}${x.dot?c:o}).)*?)`,v=x=>{switch(x){case"*":return`${y}${l}${A}`;case".*":return`${o}${l}${A}`;case"*.*":return`${y}${A}${o}${l}${A}`;case"*/*":return`${y}${A}${a}${l}${S}${A}`;case"**":return y+g(t);case"**/*":return`(?:${y}${g(t)}${a})?${S}${l}${A}`;case"**/*.*":return`(?:${y}${g(t)}${a})?${S}${A}${o}${l}${A}`;case"**/.*":return`(?:${y}${g(t)}${a})?${o}${l}${A}`;default:{let T=/^(.*?)\.(\w+)$/.exec(x);if(!T)return;let P=v(T[1]);return P?P+o+T[2]:void 0}}},b=xe.removePrefix(n,k),w=v(b);return w&&t.strictSlashes!==!0&&(w+=`${a}?`),w};gh.exports=Ma});var vh=H((fR,bh)=>{"use strict";var sA=require("path"),rA=fh(),La=yh(),Da=fr(),iA=Un(),oA=n=>n&&typeof n=="object"&&!Array.isArray(n),ce=(n,e,t=!1)=>{if(Array.isArray(n)){let d=n.map(h=>ce(h,e,t));return h=>{for(let m of d){let p=m(h);if(p)return p}return!1}}let s=oA(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=Da.isWindows(e),o=s?ce.compileRe(n,e):ce.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=ce(r.ignore,d,t)}let c=(d,f=!1)=>{let{isMatch:h,match:m,output:p}=ce.test(d,o,e,{glob:n,posix:i}),y={glob:n,state:a,regex:o,posix:i,input:d,output:p,match:m,isMatch:h};return typeof r.onResult=="function"&&r.onResult(y),h===!1?(y.isMatch=!1,f?y:!1):l(d)?(typeof r.onIgnore=="function"&&r.onIgnore(y),y.isMatch=!1,f?y:!1):(typeof r.onMatch=="function"&&r.onMatch(y),f?y:!0)};return t&&(c.state=a),c};ce.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?Da.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=ce.matchBase(n,e,t,r):a=e.exec(l)),{isMatch:!!a,match:a,output:l}};ce.matchBase=(n,e,t,s=Da.isWindows(t))=>(e instanceof RegExp?e:ce.makeRe(e,t)).test(sA.basename(n));ce.isMatch=(n,e,t)=>ce(e,t)(n);ce.parse=(n,e)=>Array.isArray(n)?n.map(t=>ce.parse(t,e)):La(n,{...e,fastpaths:!1});ce.scan=(n,e)=>rA(n,e);ce.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=ce.toRegex(a,e);return s===!0&&(l.state=n),l};ce.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=La.fastpaths(n,e)),r.output||(r=La(n,e)),ce.compileRe(r,e,t,s)};ce.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/$^/}};ce.constants=iA;bh.exports=ce});var Na=H((pR,wh)=>{"use strict";wh.exports=vh()});var Th=H((hR,Eh)=>{"use strict";var Gn=require("fs"),{Readable:aA}=require("stream"),Wn=require("path"),{promisify:yr}=require("util"),Fa=Na(),lA=yr(Gn.readdir),cA=yr(Gn.stat),xh=yr(Gn.lstat),uA=yr(Gn.realpath),dA="!",kh="READDIRP_RECURSIVE_ERROR",fA=new Set(["ENOENT","EPERM","EACCES","ELOOP",kh]),Ha="files",$h="directories",mr="files_directories",hr="all",Sh=[Ha,$h,mr,hr],pA=n=>fA.has(n.code),[_h,hA]=process.versions.node.split(".").slice(0,2).map(n=>Number.parseInt(n,10)),mA=process.platform==="win32"&&(_h>10||_h===10&&hA>=5),Ah=n=>{if(n!==void 0){if(typeof n=="function")return n;if(typeof n=="string"){let e=Fa(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)===dA?t.push(Fa(r.slice(1))):e.push(Fa(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))}}},gr=class n extends aA{static get defaultOptions(){return{root:".",fileFilter:e=>!0,directoryFilter:e=>!0,type:Ha,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=Ah(t.fileFilter),this._directoryFilter=Ah(t.directoryFilter);let i=t.lstat?xh:cA;mA?this._stat=o=>i(o,{bigint:!0}):this._stat=i,this._maxDepth=t.depth,this._wantsDir=[$h,mr,hr].includes(r),this._wantsFile=[Ha,mr,hr].includes(r),this._wantsEverything=r===hr,this._root=Wn.resolve(s),this._isDirent="Dirent"in Gn&&!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 lA(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=Wn.resolve(Wn.join(t,r));s={path:Wn.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){pA(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 uA(s),i=await xh(r);if(i.isFile())return"file";if(i.isDirectory()){let o=r.length;if(s.startsWith(r)&&s.substr(o,1)===Wn.sep){let a=new Error(`Circular symlink detected: "${s}" points to "${r}"`);return a.code=kh,this._onError(a)}return"directory"}}catch(r){this._onError(r)}}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}},hn=(n,e={})=>{let t=e.entryType||e.type;if(t==="both"&&(t=mr),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&&!Sh.includes(t))throw new Error(`readdirp: Invalid type passed. Use one of ${Sh.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return e.root=n,new gr(e)},gA=(n,e={})=>new Promise((t,s)=>{let r=[];hn(n,e).on("data",i=>r.push(i)).on("end",()=>t(r)).on("error",i=>s(i))});hn.promise=gA;hn.ReaddirpStream=gr;hn.default=hn;Eh.exports=hn});var ja=H((mR,Ch)=>{Ch.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 Lh=H((Ih,Mh)=>{"use strict";Object.defineProperty(Ih,"__esModule",{value:!0});var Ph=Na(),yA=ja(),Rh="!",bA={returnIndex:!1},vA=n=>Array.isArray(n)?n:[n],wA=(n,e)=>{if(typeof n=="function")return n;if(typeof n=="string"){let t=Ph(n,e);return s=>n===s||t(s)}return n instanceof RegExp?t=>n.test(t):t=>!1},Oh=(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=yA(i,!1);for(let l=0;l<e.length;l++){let c=e[l];if(c(o))return s?-1:!1}let a=r&&[o].concat(t.slice(1));for(let l=0;l<n.length;l++){let c=n[l];if(r?c(...a):c(o))return s?l:!0}return s?-1:!1},Ba=(n,e,t=bA)=>{if(n==null)throw new TypeError("anymatch: specify first argument");let s=typeof t=="boolean"?{returnIndex:t}:t,r=s.returnIndex||!1,i=vA(n),o=i.filter(l=>typeof l=="string"&&l.charAt(0)===Rh).map(l=>l.slice(1)).map(l=>Ph(l,s)),a=i.filter(l=>typeof l!="string"||typeof l=="string"&&l.charAt(0)!==Rh).map(l=>wA(l,s));return e==null?(l,c=!1)=>Oh(a,o,l,typeof c=="boolean"?c:!1):Oh(a,o,e,r)};Ba.default=Ba;Mh.exports=Ba});var Nh=H((gR,Dh)=>{Dh.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 Ua=H((yR,Hh)=>{var xA=Nh(),Fh={"{":"}","(":")","[":"]"},SA=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=Fh[a];if(l){var c=n.indexOf(l,e);c!==-1&&(e=c+1)}if(n[e]==="!")return!0}else e++}return!1},_A=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=Fh[t];if(s){var r=n.indexOf(s,e);r!==-1&&(e=r+1)}if(n[e]==="!")return!0}else e++}return!1};Hh.exports=function(e,t){if(typeof e!="string"||e==="")return!1;if(xA(e))return!0;var s=SA;return t&&t.strict===!1&&(s=_A),s(e)}});var Bh=H((bR,jh)=>{"use strict";var AA=Ua(),kA=require("path").posix.dirname,$A=require("os").platform()==="win32",Ka="/",EA=/\\/g,TA=/[\{\[].*[\}\]]$/,CA=/(^|[^\\])([\{\[]|\([^\)]+$)/,RA=/\\([\!\*\?\|\[\]\(\)\{\}])/g;jh.exports=function(e,t){var s=Object.assign({flipBackslashes:!0},t);s.flipBackslashes&&$A&&e.indexOf(Ka)<0&&(e=e.replace(EA,Ka)),TA.test(e)&&(e+=Ka),e+="a";do e=kA(e);while(AA(e)||CA.test(e));return e.replace(RA,"$1")}});var br=H(Ue=>{"use strict";Ue.isInteger=n=>typeof n=="number"?Number.isInteger(n):typeof n=="string"&&n.trim()!==""?Number.isInteger(Number(n)):!1;Ue.find=(n,e)=>n.nodes.find(t=>t.type===e);Ue.exceedsLimit=(n,e,t=1,s)=>s===!1||!Ue.isInteger(n)||!Ue.isInteger(e)?!1:(Number(e)-Number(n))/Number(t)>=s;Ue.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)};Ue.encloseBrace=n=>n.type!=="brace"?!1:n.commas>>0+n.ranges>>0===0?(n.invalid=!0,!0):!1;Ue.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;Ue.isOpenOrClose=n=>n.type==="open"||n.type==="close"?!0:n.open===!0||n.close===!0;Ue.reduce=n=>n.reduce((e,t)=>(t.type==="text"&&e.push(t.value),t.type==="range"&&(t.type="text"),e),[]);Ue.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 vr=H((wR,Kh)=>{"use strict";var Uh=br();Kh.exports=(n,e={})=>{let t=(s,r={})=>{let i=e.escapeInvalid&&Uh.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a="";if(s.value)return(i||o)&&Uh.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 Wh=H((xR,qh)=>{"use strict";qh.exports=function(n){return typeof n=="number"?n-n===0:typeof n=="string"&&n.trim()!==""?Number.isFinite?Number.isFinite(+n):isFinite(+n):!1}});var em=H((SR,Zh)=>{"use strict";var Gh=Wh(),qt=(n,e,t)=>{if(Gh(n)===!1)throw new TypeError("toRegexRange: expected the first argument to be a number");if(e===void 0||n===e)return String(n);if(Gh(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(qt.cache.hasOwnProperty(l))return qt.cache[l].result;let c=Math.min(n,e),d=Math.max(n,e);if(Math.abs(c-d)===1){let y=n+"|"+e;return s.capture?`(${y})`:s.wrap===!1?y:`(?:${y})`}let f=Xh(n)||Xh(e),h={min:n,max:e,a:c,b:d},m=[],p=[];if(f&&(h.isPadded=f,h.maxLen=String(h.max).length),c<0){let y=d<0?Math.abs(d):1;p=Vh(y,Math.abs(c),h,s),c=h.a=0}return d>=0&&(m=Vh(c,d,h,s)),h.negatives=p,h.positives=m,h.result=OA(p,m,s),s.capture===!0?h.result=`(${h.result})`:s.wrap!==!1&&m.length+p.length>1&&(h.result=`(?:${h.result})`),qt.cache[l]=h,h.result};function OA(n,e,t){let s=qa(n,e,"-",!1,t)||[],r=qa(e,n,"",!1,t)||[],i=qa(n,e,"-?",!0,t)||[];return s.concat(i).concat(r).join("|")}function PA(n,e){let t=1,s=1,r=Yh(n,t),i=new Set([e]);for(;n<=r&&r<=e;)i.add(r),t+=1,r=Yh(n,t);for(r=Jh(e+1,s)-1;n<r&&r<=e;)i.add(r),s+=1,r=Jh(e+1,s)-1;return i=[...i],i.sort(LA),i}function IA(n,e,t){if(n===e)return{pattern:n,count:[],digits:0};let s=MA(n,e),r=s.length,i="",o=0;for(let a=0;a<r;a++){let[l,c]=s[a];l===c?i+=l:l!=="0"||c!=="9"?i+=DA(l,c,t):o++}return o&&(i+=t.shorthand===!0?"\\d":"[0-9]"),{pattern:i,count:[o],digits:r}}function Vh(n,e,t,s){let r=PA(n,e),i=[],o=n,a;for(let l=0;l<r.length;l++){let c=r[l],d=IA(String(o),String(c),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+Qh(a.count),o=c+1;continue}t.isPadded&&(f=NA(c,t,s)),d.string=f+d.pattern+Qh(d.count),i.push(d),o=c+1,a=d}return i}function qa(n,e,t,s,r){let i=[];for(let o of n){let{string:a}=o;!s&&!zh(e,"string",a)&&i.push(t+a),s&&zh(e,"string",a)&&i.push(t+a)}return i}function MA(n,e){let t=[];for(let s=0;s<n.length;s++)t.push([n[s],e[s]]);return t}function LA(n,e){return n>e?1:e>n?-1:0}function zh(n,e,t){return n.some(s=>s[e]===t)}function Yh(n,e){return Number(String(n).slice(0,-e)+"9".repeat(e))}function Jh(n,e){return n-n%Math.pow(10,e)}function Qh(n){let[e=0,t=""]=n;return t||e>1?`{${e+(t?","+t:"")}}`:""}function DA(n,e,t){return`[${n}${e-n===1?"":"-"}${e}]`}function Xh(n){return/^-?(0+)\d/.test(n)}function NA(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}}`}}qt.cache={};qt.clearCache=()=>qt.cache={};Zh.exports=qt});var Va=H((_R,am)=>{"use strict";var FA=require("util"),nm=em(),tm=n=>n!==null&&typeof n=="object"&&!Array.isArray(n),HA=n=>e=>n===!0?Number(e):String(e),Wa=n=>typeof n=="number"||typeof n=="string"&&n!=="",Vn=n=>Number.isInteger(+n),Ga=n=>{let e=`${n}`,t=-1;if(e[0]==="-"&&(e=e.slice(1)),e==="0")return!1;for(;e[++t]==="0";);return t>0},jA=(n,e,t)=>typeof n=="string"||typeof e=="string"?!0:t.stringify===!0,BA=(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},xr=(n,e)=>{let t=n[0]==="-"?"-":"";for(t&&(n=n.slice(1),e--);n.length<e;)n="0"+n;return t?"-"+n:n},UA=(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=>xr(String(a),t)).join("|")),n.negatives.length&&(i=`-(${s}${n.negatives.map(a=>xr(String(a),t)).join("|")})`),r&&i?o=`${r}|${i}`:o=r||i,e.wrap?`(${s}${o})`:o},sm=(n,e,t,s)=>{if(t)return nm(n,e,{wrap:!1,...s});let r=String.fromCharCode(n);if(n===e)return r;let i=String.fromCharCode(e);return`[${r}-${i}]`},rm=(n,e,t)=>{if(Array.isArray(n)){let s=t.wrap===!0,r=t.capture?"":"?:";return s?`(${r}${n.join("|")})`:n.join("|")}return nm(n,e,t)},im=(...n)=>new RangeError("Invalid range arguments: "+FA.inspect(...n)),om=(n,e,t)=>{if(t.strictRanges===!0)throw im([n,e]);return[]},KA=(n,e)=>{if(e.strictRanges===!0)throw new TypeError(`Expected step "${n}" to be a number`);return[]},qA=(n,e,t=1,s={})=>{let r=Number(n),i=Number(e);if(!Number.isInteger(r)||!Number.isInteger(i)){if(s.strictRanges===!0)throw im([n,e]);return[]}r===0&&(r=0),i===0&&(i=0);let o=r>i,a=String(n),l=String(e),c=String(t);t=Math.max(Math.abs(t),1);let d=Ga(a)||Ga(l)||Ga(c),f=d?Math.max(a.length,l.length,c.length):0,h=d===!1&&jA(n,e,s)===!1,m=s.transform||HA(h);if(s.toRegex&&t===1)return sm(xr(n,f),xr(e,f),!0,s);let p={negatives:[],positives:[]},y=k=>p[k<0?"negatives":"positives"].push(Math.abs(k)),S=[],_=0;for(;o?r>=i:r<=i;)s.toRegex===!0&&t>1?y(r):S.push(BA(m(r,_),f,h)),r=o?r-t:r+t,_++;return s.toRegex===!0?t>1?UA(p,s,f):rm(S,null,{wrap:!1,...s}):S},WA=(n,e,t=1,s={})=>{if(!Vn(n)&&n.length>1||!Vn(e)&&e.length>1)return om(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),c=Math.max(i,o);if(s.toRegex&&t===1)return sm(l,c,!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?rm(d,null,{wrap:!1,options:s}):d},wr=(n,e,t,s={})=>{if(e==null&&Wa(n))return[n];if(!Wa(n)||!Wa(e))return om(n,e,s);if(typeof t=="function")return wr(n,e,1,{transform:t});if(tm(t))return wr(n,e,0,t);let r={...s};return r.capture===!0&&(r.wrap=!0),t=t||r.step||1,Vn(t)?Vn(n)&&Vn(e)?qA(n,e,t,r):WA(n,e,Math.max(Math.abs(t),1),r):t!=null&&!tm(t)?KA(t,r):wr(n,e,1,t)};am.exports=wr});var um=H((AR,cm)=>{"use strict";var GA=Va(),lm=br(),VA=(n,e={})=>{let t=(s,r={})=>{let i=lm.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a=i===!0||o===!0,l=e.escapeInvalid===!0?"\\":"",c="";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=lm.reduce(s.nodes),f=GA(...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)c+=t(d,s);return c};return t(n)};cm.exports=VA});var pm=H((kR,fm)=>{"use strict";var zA=Va(),dm=vr(),mn=br(),Wt=(n="",e="",t=!1)=>{let s=[];if(n=[].concat(n),e=[].concat(e),!e.length)return n;if(!n.length)return t?mn.flatten(e).map(r=>`{${r}}`):e;for(let r of n)if(Array.isArray(r))for(let i of r)s.push(Wt(i,e,t));else for(let i of e)t===!0&&typeof i=="string"&&(i=`{${i}}`),s.push(Array.isArray(i)?Wt(r,i,t):r+i);return mn.flatten(s)},YA=(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(Wt(a.pop(),dm(r,e)));return}if(r.type==="brace"&&r.invalid!==!0&&r.nodes.length===2){a.push(Wt(a.pop(),["{}"]));return}if(r.nodes&&r.ranges>0){let f=mn.reduce(r.nodes);if(mn.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=zA(...f,e);h.length===0&&(h=dm(r,e)),a.push(Wt(a.pop(),h)),r.nodes=[];return}let l=mn.encloseBrace(r),c=r.queue,d=r;for(;d.type!=="brace"&&d.type!=="root"&&d.parent;)d=d.parent,c=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&&c.push(""),c.push("");continue}if(h.type==="close"){a.push(Wt(a.pop(),c,l));continue}if(h.value&&h.type!=="open"){c.push(Wt(c.pop(),h.value));continue}h.nodes&&s(h,r)}return c};return mn.flatten(s(n))};fm.exports=YA});var mm=H(($R,hm)=>{"use strict";hm.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:`
|
|
909
|
-
`,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 wm=H((ER,vm)=>{"use strict";var JA=vr(),{MAX_LENGTH:gm,CHAR_BACKSLASH:za,CHAR_BACKTICK:QA,CHAR_COMMA:XA,CHAR_DOT:ZA,CHAR_LEFT_PARENTHESES:ek,CHAR_RIGHT_PARENTHESES:tk,CHAR_LEFT_CURLY_BRACE:nk,CHAR_RIGHT_CURLY_BRACE:sk,CHAR_LEFT_SQUARE_BRACKET:ym,CHAR_RIGHT_SQUARE_BRACKET:bm,CHAR_DOUBLE_QUOTE:rk,CHAR_SINGLE_QUOTE:ik,CHAR_NO_BREAK_SPACE:ok,CHAR_ZERO_WIDTH_NOBREAK_SPACE:ak}=mm(),lk=(n,e={})=>{if(typeof n!="string")throw new TypeError("Expected a string");let t=e||{},s=typeof t.maxLength=="number"?Math.min(gm,t.maxLength):gm;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,c=n.length,d=0,f=0,h,m=()=>n[d++],p=y=>{if(y.type==="text"&&a.type==="dot"&&(a.type="text"),a&&a.type==="text"&&y.type==="text"){a.value+=y.value;return}return o.nodes.push(y),y.parent=o,y.prev=a,a=y,y};for(p({type:"bos"});d<c;)if(o=i[i.length-1],h=m(),!(h===ak||h===ok)){if(h===za){p({type:"text",value:(e.keepEscaping?h:"")+m()});continue}if(h===bm){p({type:"text",value:"\\"+h});continue}if(h===ym){l++;let y;for(;d<c&&(y=m());){if(h+=y,y===ym){l++;continue}if(y===za){h+=m();continue}if(y===bm&&(l--,l===0))break}p({type:"text",value:h});continue}if(h===ek){o=p({type:"paren",nodes:[]}),i.push(o),p({type:"text",value:h});continue}if(h===tk){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===rk||h===ik||h===QA){let y=h,S;for(e.keepQuotes!==!0&&(h="");d<c&&(S=m());){if(S===za){h+=S+m();continue}if(S===y){e.keepQuotes===!0&&(h+=S);break}h+=S}p({type:"text",value:h});continue}if(h===nk){f++;let S={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(S),i.push(o),p({type:"open",value:h});continue}if(h===sk){if(o.type!=="brace"){p({type:"text",value:h});continue}let y="close";o=i.pop(),o.close=!0,p({type:y,value:h}),f--,o=i[i.length-1];continue}if(h===XA&&f>0){if(o.ranges>0){o.ranges=0;let y=o.nodes.shift();o.nodes=[y,{type:"text",value:JA(o)}]}p({type:"comma",value:h}),o.commas++;continue}if(h===ZA&&f>0&&o.commas===0){let y=o.nodes;if(f===0||y.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"){y.pop();let S=y[y.length-1];S.value+=a.value+h,a=S,o.ranges--;continue}p({type:"dot",value:h});continue}p({type:"text",value:h})}do if(o=i.pop(),o.type!=="root"){o.nodes.forEach(_=>{_.nodes||(_.type==="open"&&(_.isOpen=!0),_.type==="close"&&(_.isClose=!0),_.nodes||(_.type="text"),_.invalid=!0)});let y=i[i.length-1],S=y.nodes.indexOf(o);y.nodes.splice(S,1,...o.nodes)}while(i.length>0);return p({type:"eos"}),r};vm.exports=lk});var _m=H((TR,Sm)=>{"use strict";var xm=vr(),ck=um(),uk=pm(),dk=wm(),Me=(n,e={})=>{let t=[];if(Array.isArray(n))for(let s of n){let r=Me.create(s,e);Array.isArray(r)?t.push(...r):t.push(r)}else t=[].concat(Me.create(n,e));return e&&e.expand===!0&&e.nodupes===!0&&(t=[...new Set(t)]),t};Me.parse=(n,e={})=>dk(n,e);Me.stringify=(n,e={})=>xm(typeof n=="string"?Me.parse(n,e):n,e);Me.compile=(n,e={})=>(typeof n=="string"&&(n=Me.parse(n,e)),ck(n,e));Me.expand=(n,e={})=>{typeof n=="string"&&(n=Me.parse(n,e));let t=uk(n,e);return e.noempty===!0&&(t=t.filter(Boolean)),e.nodupes===!0&&(t=[...new Set(t)]),t};Me.create=(n,e={})=>n===""||n.length<3?[n]:e.expand!==!0?Me.compile(n,e):Me.expand(n,e);Sm.exports=Me});var Am=H((CR,fk)=>{fk.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 $m=H((RR,km)=>{km.exports=Am()});var Tm=H((OR,Em)=>{"use strict";var pk=require("path"),hk=$m(),mk=new Set(hk);Em.exports=n=>mk.has(pk.extname(n).slice(1).toLowerCase())});var Sr=H(B=>{"use strict";var{sep:gk}=require("path"),{platform:Ya}=process,yk=require("os");B.EV_ALL="all";B.EV_READY="ready";B.EV_ADD="add";B.EV_CHANGE="change";B.EV_ADD_DIR="addDir";B.EV_UNLINK="unlink";B.EV_UNLINK_DIR="unlinkDir";B.EV_RAW="raw";B.EV_ERROR="error";B.STR_DATA="data";B.STR_END="end";B.STR_CLOSE="close";B.FSEVENT_CREATED="created";B.FSEVENT_MODIFIED="modified";B.FSEVENT_DELETED="deleted";B.FSEVENT_MOVED="moved";B.FSEVENT_CLONED="cloned";B.FSEVENT_UNKNOWN="unknown";B.FSEVENT_FLAG_MUST_SCAN_SUBDIRS=1;B.FSEVENT_TYPE_FILE="file";B.FSEVENT_TYPE_DIRECTORY="directory";B.FSEVENT_TYPE_SYMLINK="symlink";B.KEY_LISTENERS="listeners";B.KEY_ERR="errHandlers";B.KEY_RAW="rawEmitters";B.HANDLER_KEYS=[B.KEY_LISTENERS,B.KEY_ERR,B.KEY_RAW];B.DOT_SLASH=`.${gk}`;B.BACK_SLASH_RE=/\\/g;B.DOUBLE_SLASH_RE=/\/\//;B.SLASH_OR_BACK_SLASH_RE=/[/\\]/;B.DOT_RE=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/;B.REPLACER_RE=/^\.[/\\]/;B.SLASH="/";B.SLASH_SLASH="//";B.BRACE_START="{";B.BANG="!";B.ONE_DOT=".";B.TWO_DOTS="..";B.STAR="*";B.GLOBSTAR="**";B.ROOT_GLOBSTAR="/**/*";B.SLASH_GLOBSTAR="/**";B.DIR_SUFFIX="Dir";B.ANYMATCH_OPTS={dot:!0};B.STRING_TYPE="string";B.FUNCTION_TYPE="function";B.EMPTY_STR="";B.EMPTY_FN=()=>{};B.IDENTITY_FN=n=>n;B.isWindows=Ya==="win32";B.isMacos=Ya==="darwin";B.isLinux=Ya==="linux";B.isIBMi=yk.type()==="OS400"});var Mm=H((IR,Im)=>{"use strict";var _t=require("fs"),me=require("path"),{promisify:Qn}=require("util"),bk=Tm(),{isWindows:vk,isLinux:wk,EMPTY_FN:xk,EMPTY_STR:Sk,KEY_LISTENERS:gn,KEY_ERR:Ja,KEY_RAW:zn,HANDLER_KEYS:_k,EV_CHANGE:Ar,EV_ADD:_r,EV_ADD_DIR:Ak,EV_ERROR:Rm,STR_DATA:kk,STR_END:$k,BRACE_START:Ek,STAR:Tk}=Sr(),Ck="watch",Rk=Qn(_t.open),Om=Qn(_t.stat),Ok=Qn(_t.lstat),Pk=Qn(_t.close),Qa=Qn(_t.realpath),Ik={lstat:Ok,stat:Om},Za=(n,e)=>{n instanceof Set?n.forEach(e):e(n)},Yn=(n,e,t)=>{let s=n[e];s instanceof Set||(n[e]=s=new Set([s])),s.add(t)},Mk=n=>e=>{let t=n[e];t instanceof Set?t.clear():delete n[e]},Jn=(n,e,t)=>{let s=n[e];s instanceof Set?s.delete(t):s===t&&delete n[e]},Pm=n=>n instanceof Set?n.size===0:!n,kr=new Map;function Cm(n,e,t,s,r){let i=(o,a)=>{t(n),r(o,a,{watchedPath:n}),a&&n!==a&&$r(me.resolve(n,a),gn,me.join(n,a))};try{return _t.watch(n,e,i)}catch(o){s(o)}}var $r=(n,e,t,s,r)=>{let i=kr.get(n);i&&Za(i[e],o=>{o(t,s,r)})},Lk=(n,e,t,s)=>{let{listener:r,errHandler:i,rawEmitter:o}=s,a=kr.get(e),l;if(!t.persistent)return l=Cm(n,t,r,i,o),l.close.bind(l);if(a)Yn(a,gn,r),Yn(a,Ja,i),Yn(a,zn,o);else{if(l=Cm(n,t,$r.bind(null,e,gn),i,$r.bind(null,e,zn)),!l)return;l.on(Rm,async c=>{let d=$r.bind(null,e,Ja);if(a.watcherUnusable=!0,vk&&c.code==="EPERM")try{let f=await Rk(n,"r");await Pk(f),d(c)}catch{}else d(c)}),a={listeners:r,errHandlers:i,rawEmitters:o,watcher:l},kr.set(e,a)}return()=>{Jn(a,gn,r),Jn(a,Ja,i),Jn(a,zn,o),Pm(a.listeners)&&(a.watcher.close(),kr.delete(e),_k.forEach(Mk(a)),a.watcher=void 0,Object.freeze(a))}},Xa=new Map,Dk=(n,e,t,s)=>{let{listener:r,rawEmitter:i}=s,o=Xa.get(e),a=new Set,l=new Set,c=o&&o.options;return c&&(c.persistent<t.persistent||c.interval>t.interval)&&(a=o.listeners,l=o.rawEmitters,_t.unwatchFile(e),o=void 0),o?(Yn(o,gn,r),Yn(o,zn,i)):(o={listeners:r,rawEmitters:i,options:t,watcher:_t.watchFile(e,t,(d,f)=>{Za(o.rawEmitters,m=>{m(Ar,e,{curr:d,prev:f})});let h=d.mtimeMs;(d.size!==f.size||h>f.mtimeMs||h===0)&&Za(o.listeners,m=>m(n,d))})},Xa.set(e,o)),()=>{Jn(o,gn,r),Jn(o,zn,i),Pm(o.listeners)&&(Xa.delete(e),_t.unwatchFile(e),o.options=o.watcher=void 0,Object.freeze(o))}},el=class{constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let s=this.fsw.options,r=me.dirname(e),i=me.basename(e);this.fsw._getWatchedDir(r).add(i);let a=me.resolve(e),l={persistent:s.persistent};t||(t=xk);let c;return s.usePolling?(l.interval=s.enableBinaryInterval&&bk(i)?s.binaryInterval:s.interval,c=Dk(e,a,l,{listener:t,rawEmitter:this.fsw._emitRaw})):c=Lk(e,a,l,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw}),c}_handleFile(e,t,s){if(this.fsw.closed)return;let r=me.dirname(e),i=me.basename(e),o=this.fsw._getWatchedDir(r),a=t;if(o.has(i))return;let l=async(d,f)=>{if(this.fsw._throttle(Ck,e,5)){if(!f||f.mtimeMs===0)try{let h=await Om(e);if(this.fsw.closed)return;let m=h.atimeMs,p=h.mtimeMs;(!m||m<=p||p!==a.mtimeMs)&&this.fsw._emit(Ar,e,h),wk&&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(Ar,e,f),a=f}}},c=this._watchWithNodeFs(e,l);if(!(s&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(_r,e,0))return;this.fsw._emit(_r,e,t)}return c}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 Qa(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(Ar,s,e.stats)):(o.add(r),this.fsw._symlinkPaths.set(i,a),this.fsw._emit(_r,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=me.join(e,Sk),!s.hasGlob&&(a=this.fsw._throttle("readdir",e,1e3),!a))return;let l=this.fsw._getWatchedDir(s.path),c=new Set,d=this.fsw._readdirp(e,{fileFilter:f=>s.filterPath(f),directoryFilter:f=>s.filterDir(f),depth:0}).on(kk,async f=>{if(this.fsw.closed){d=void 0;return}let h=f.path,m=me.join(e,h);if(c.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=me.join(i,me.relative(i,m)),this._addToNodeFs(m,t,s,o+1))}}).on(Rm,this._boundHandleError);return new Promise(f=>d.once($k,()=>{if(this.fsw.closed){d=void 0;return}let h=a?a.clear():!1;f(),l.getChildren().filter(m=>m!==e&&!c.has(m)&&(!s.hasGlob||s.filterPath({fullPath:me.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(me.dirname(e)),c=l.has(me.basename(e));!(s&&this.fsw.options.ignoreInitial)&&!i&&!c&&(!o.hasGlob||o.globFilter(e))&&this.fsw._emit(Ak,e,t),l.add(me.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 Ik[a.statMethod](a.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(a.watchPath,l))return o(),!1;let c=this.fsw.options.followSymlinks&&!e.includes(Tk)&&!e.includes(Ek),d;if(l.isDirectory()){let f=me.resolve(e),h=c?await Qa(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=c?await Qa(e):e;if(this.fsw.closed)return;let h=me.dirname(a.watchPath);if(this.fsw._getWatchedDir(h).add(a.watchPath),this.fsw._emit(_r,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(me.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}}};Im.exports=el});var Bm=H((MR,ll)=>{"use strict";var ol=require("fs"),ge=require("path"),{promisify:al}=require("util"),yn;try{yn=require("fsevents")}catch(n){process.env.CHOKIDAR_PRINT_FSEVENTS_REQUIRE_ERROR&&console.error(n)}if(yn){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&&(yn=void 0)}}var{EV_ADD:tl,EV_CHANGE:Nk,EV_ADD_DIR:Lm,EV_UNLINK:Er,EV_ERROR:Fk,STR_DATA:Hk,STR_END:jk,FSEVENT_CREATED:Bk,FSEVENT_MODIFIED:Uk,FSEVENT_DELETED:Kk,FSEVENT_MOVED:qk,FSEVENT_UNKNOWN:Wk,FSEVENT_FLAG_MUST_SCAN_SUBDIRS:Gk,FSEVENT_TYPE_FILE:Vk,FSEVENT_TYPE_DIRECTORY:Xn,FSEVENT_TYPE_SYMLINK:jm,ROOT_GLOBSTAR:Dm,DIR_SUFFIX:zk,DOT_SLASH:Nm,FUNCTION_TYPE:nl,EMPTY_FN:Yk,IDENTITY_FN:Jk}=Sr(),Qk=n=>isNaN(n)?{}:{depth:n},rl=al(ol.stat),Xk=al(ol.lstat),Fm=al(ol.realpath),Zk={stat:rl,lstat:Xk},Gt=new Map,e$=10,t$=new Set([69888,70400,71424,72704,73472,131328,131840,262912]),n$=(n,e)=>({stop:yn.watch(n,e)});function s$(n,e,t,s){let r=ge.extname(e)?ge.dirname(e):e,i=ge.dirname(r),o=Gt.get(r);r$(i)&&(r=i);let a=ge.resolve(n),l=a!==e,c=(f,h,m)=>{l&&(f=f.replace(e,a)),(f===a||!f.indexOf(a+ge.sep))&&t(f,h,m)},d=!1;for(let f of Gt.keys())if(e.indexOf(ge.resolve(f)+ge.sep)===0){r=f,o=Gt.get(r),d=!0;break}return o||d?o.listeners.add(c):(o={listeners:new Set([c]),rawEmitter:s,watcher:n$(r,(f,h)=>{if(!o.listeners.size||h&Gk)return;let m=yn.getInfo(f,h);o.listeners.forEach(p=>{p(f,h,m)}),o.rawEmitter(m.event,f,m)})},Gt.set(r,o)),()=>{let f=o.listeners;if(f.delete(c),!f.size&&(Gt.delete(r),o.watcher))return o.watcher.stop().then(()=>{o.rawEmitter=o.watcher=void 0,Object.freeze(o)})}}var r$=n=>{let e=0;for(let t of Gt.keys())if(t.indexOf(n)===0&&(e++,e>=e$))return!0;return!1},i$=()=>yn&&Gt.size<128,sl=(n,e)=>{let t=0;for(;!n.indexOf(e)&&(n=ge.dirname(n))!==e;)t++;return t},Hm=(n,e)=>n.type===Xn&&e.isDirectory()||n.type===jm&&e.isSymbolicLink()||n.type===Vk&&e.isFile(),il=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+Dm),!0;s.delete(e),s.delete(e+Dm)}addOrChange(e,t,s,r,i,o,a,l){let c=i.has(o)?Nk:tl;this.handleEvent(c,e,t,s,r,i,o,a,l)}async checkExists(e,t,s,r,i,o,a,l){try{let c=await rl(e);if(this.fsw.closed)return;Hm(a,c)?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(Er,e,t,s,r,i,o,a,l)}catch(c){c.code==="EACCES"?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(Er,e,t,s,r,i,o,a,l)}}handleEvent(e,t,s,r,i,o,a,l,c){if(!(this.fsw.closed||this.checkIgnored(t)))if(e===Er){let d=l.type===Xn;(d||o.has(a))&&this.fsw._remove(i,a,d)}else{if(e===tl){if(l.type===Xn&&this.fsw._getWatchedDir(t),l.type===jm&&c.followSymlinks){let f=c.depth===void 0?void 0:sl(s,r)+1;return this._addToFsEvents(t,!1,!0,f)}this.fsw._getWatchedDir(i).add(a)}let d=l.type===Xn?e+zk:e;this.fsw._emit(d,t),d===Lm&&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=s$(e,t,async(l,c,d)=>{if(this.fsw.closed||i.depth!==void 0&&sl(l,t)>i.depth)return;let f=s(ge.join(e,ge.relative(e,l)));if(r&&!r(f))return;let h=ge.dirname(f),m=ge.basename(f),p=this.fsw._getWatchedDir(d.type===Xn?f:h);if(t$.has(c)||d.event===Wk)if(typeof i.ignored===nl){let y;try{y=await rl(f)}catch{}if(this.fsw.closed||this.checkIgnored(f,y))return;Hm(d,y)?this.addOrChange(f,l,t,h,p,m,d,i):this.handleEvent(Er,f,l,t,h,p,m,d,i)}else this.checkExists(f,l,t,h,p,m,d,i);else switch(d.event){case Bk:case Uk:return this.addOrChange(f,l,t,h,p,m,d,i);case Kk:case qk: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 Fm(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!==Nm?a=o.replace(i,e):o!==Nm&&(a=ge.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(ge.dirname(o)),c=ge.basename(o);a&&this.fsw._getWatchedDir(o),!l.has(c)&&(l.add(c),(!r.ignoreInitial||i===!0)&&this.fsw._emit(a?Lm:tl,o,t))}initWatch(e,t,s,r){if(this.fsw.closed)return;let i=this._watchWithFsEvents(s.watchPath,ge.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===nl?t:Jk,a=this.fsw._getWatchHelpers(e);try{let l=await Zk[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:c=>a.filterPath(c),directoryFilter:c=>a.filterDir(c),...Qk(i.depth-(r||0))}).on(Hk,c=>{if(this.fsw.closed||c.stats.isDirectory()&&!a.filterPath(c))return;let d=ge.join(a.watchPath,c.path),{fullPath:f}=c;if(a.followSymlinks&&c.stats.isSymbolicLink()){let h=i.depth===void 0?void 0:sl(d,ge.resolve(a.watchPath))+1;this._handleFsEventsSymlink(d,f,o,h)}else this.emitAdd(d,c.stats,o,i,s)}).on(Fk,Yk).on(jk,()=>{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===nl)this.initWatch(void 0,e,a,o);else{let l;try{l=await Fm(a.watchPath)}catch{}this.initWatch(l,e,a,o)}}};ll.exports=il;ll.exports.canUse=i$});var Xm=H(_l=>{"use strict";var{EventEmitter:o$}=require("events"),xl=require("fs"),Z=require("path"),{promisify:zm}=require("util"),a$=Th(),hl=Lh().default,l$=Bh(),cl=Ua(),c$=_m(),u$=ja(),d$=Mm(),Um=Bm(),{EV_ALL:ul,EV_READY:f$,EV_ADD:Tr,EV_CHANGE:Zn,EV_UNLINK:Km,EV_ADD_DIR:p$,EV_UNLINK_DIR:h$,EV_RAW:m$,EV_ERROR:dl,STR_CLOSE:g$,STR_END:y$,BACK_SLASH_RE:b$,DOUBLE_SLASH_RE:qm,SLASH_OR_BACK_SLASH_RE:v$,DOT_RE:w$,REPLACER_RE:x$,SLASH:fl,SLASH_SLASH:S$,BRACE_START:_$,BANG:ml,ONE_DOT:Ym,TWO_DOTS:A$,GLOBSTAR:k$,SLASH_GLOBSTAR:pl,ANYMATCH_OPTS:gl,STRING_TYPE:Sl,FUNCTION_TYPE:$$,EMPTY_STR:yl,EMPTY_FN:E$,isWindows:T$,isMacos:C$,isIBMi:R$}=Sr(),O$=zm(xl.stat),P$=zm(xl.readdir),bl=(n=[])=>Array.isArray(n)?n:[n],Jm=(n,e=[])=>(n.forEach(t=>{Array.isArray(t)?Jm(t,e):e.push(t)}),e),Wm=n=>{let e=Jm(bl(n));if(!e.every(t=>typeof t===Sl))throw new TypeError(`Non-string provided as watch path: ${e}`);return e.map(Qm)},Gm=n=>{let e=n.replace(b$,fl),t=!1;for(e.startsWith(S$)&&(t=!0);e.match(qm);)e=e.replace(qm,fl);return t&&(e=fl+e),e},Qm=n=>Gm(Z.normalize(Gm(n))),Vm=(n=yl)=>e=>typeof e!==Sl?e:Qm(Z.isAbsolute(e)?e:Z.join(n,e)),I$=(n,e)=>Z.isAbsolute(n)?n:n.startsWith(ml)?ml+Z.join(e,n.slice(1)):Z.join(e,n),Ze=(n,e)=>n[e]===void 0,vl=class{constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==Ym&&e!==A$&&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 P$(s)}catch{this._removeWatcher&&this._removeWatcher(Z.dirname(s),Z.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)}},M$="stat",L$="lstat",wl=class{constructor(e,t,s,r){this.fsw=r,this.path=e=e.replace(x$,yl),this.watchPath=t,this.fullWatchPath=Z.resolve(t),this.hasGlob=t!==e,e===yl&&(this.hasGlob=!1),this.globSymlink=this.hasGlob&&s?void 0:!1,this.globFilter=this.hasGlob?hl(e,void 0,gl):!1,this.dirParts=this.getDirParts(e),this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=s,this.statMethod=s?M$:L$}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 Z.join(this.watchPath,Z.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===$$?this.globFilter(s):!0)&&this.fsw._isntIgnored(s,t)&&this.fsw._hasReadPermissions(t)}getDirParts(e){if(!this.hasGlob)return[];let t=[];return(e.includes(_$)?c$.expand(e):[e]).forEach(r=>{t.push(Z.relative(this.watchPath,r).split(v$))}),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===k$&&(s=!0),s||!t[0][o]||hl(i,t[0][o],gl))))}return!this.unmatchedGlob&&this.fsw._isntIgnored(this.entryPath(e),e.stats)}},Cr=class extends o${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,Ze(t,"persistent")&&(t.persistent=!0),Ze(t,"ignoreInitial")&&(t.ignoreInitial=!1),Ze(t,"ignorePermissionErrors")&&(t.ignorePermissionErrors=!1),Ze(t,"interval")&&(t.interval=100),Ze(t,"binaryInterval")&&(t.binaryInterval=300),Ze(t,"disableGlobbing")&&(t.disableGlobbing=!1),t.enableBinaryInterval=t.binaryInterval!==t.interval,Ze(t,"useFsEvents")&&(t.useFsEvents=!t.usePolling),Um.canUse()||(t.useFsEvents=!1),Ze(t,"usePolling")&&!t.useFsEvents&&(t.usePolling=C$),R$&&(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)),Ze(t,"atomic")&&(t.atomic=!t.usePolling&&!t.useFsEvents),t.atomic&&(this._pendingUnlinks=new Map),Ze(t,"followSymlinks")&&(t.followSymlinks=!0),Ze(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=bl(t.ignored));let a=0;this._emitReady=()=>{a++,a>=this._readyCount&&(this._emitReady=E$,this._readyEmitted=!0,process.nextTick(()=>this.emit(f$)))},this._emitRaw=(...l)=>this.emit(m$,...l),this._readyEmitted=!1,this.options=t,t.useFsEvents?this._fsEventsHandler=new Um(this):this._nodeFsHandler=new d$(this),Object.freeze(t)}add(e,t,s){let{cwd:r,disableGlobbing:i}=this.options;this.closed=!1;let o=Wm(e);return r&&(o=o.map(a=>{let l=I$(a,r);return i||!cl(a)?l:u$(l)})),o=o.filter(a=>a.startsWith(ml)?(this._ignoredPaths.add(a.slice(1)),!1):(this._ignoredPaths.delete(a),this._ignoredPaths.delete(a+pl),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(Z.dirname(l),Z.basename(t||l))})})),this}unwatch(e){if(this.closed)return this;let t=Wm(e),{cwd:s}=this.options;return t.forEach(r=>{!Z.isAbsolute(r)&&!this._closers.has(r)&&(s&&(r=Z.join(s,r)),r=Z.resolve(r)),this._closePath(r),this._ignoredPaths.add(r),this._watched.has(r)&&this._ignoredPaths.add(r+pl),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?Z.relative(this.options.cwd,s):s;e[r||Ym]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(...t),e!==dl&&this.emit(ul,...t)}async _emit(e,t,s,r,i){if(this.closed)return;let o=this.options;T$&&(t=Z.normalize(t)),o.cwd&&(t=Z.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,c;if(l&&(c=this._pendingWrites.get(t)))return c.lastChange=new Date,this;if(o.atomic){if(e===Km)return this._pendingUnlinks.set(t,a),setTimeout(()=>{this._pendingUnlinks.forEach((d,f)=>{this.emit(...d),this.emit(ul,...d),this._pendingUnlinks.delete(f)})},typeof o.atomic=="number"?o.atomic:100),this;e===Tr&&this._pendingUnlinks.has(t)&&(e=a[0]=Zn,this._pendingUnlinks.delete(t))}if(l&&(e===Tr||e===Zn)&&this._readyEmitted){let d=(f,h)=>{f?(e=a[0]=dl,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===Zn&&!this._throttle(Zn,t,50))return this;if(o.alwaysStat&&s===void 0&&(e===Tr||e===p$||e===Zn)){let d=o.cwd?Z.join(o.cwd,t):t,f;try{f=await O$(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(dl,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 c=r.get(t),d=c?c.count:0;return r.delete(t),clearTimeout(o),c&&clearTimeout(c.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&&!Z.isAbsolute(e)&&(o=Z.join(this.options.cwd,e));let a=new Date,l=c=>{xl.stat(o,(d,f)=>{if(d||!this._pendingWrites.has(e)){d&&d.code!=="ENOENT"&&r(d);return}let h=Number(new Date);c&&f.size!==c.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&&w$.test(e))return!0;if(!this._userIgnored){let{cwd:s}=this.options,r=this.options.ignored,i=r&&r.map(Vm(s)),o=bl(i).filter(l=>typeof l===Sl&&!cl(l)).map(l=>l+pl),a=this._getGlobIgnored().map(Vm(s)).concat(i,o);this._userIgnored=hl(a,void 0,gl)}return this._userIgnored([e,t])}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e,t){let s=t||this.options.disableGlobbing||!cl(e)?e:l$(e),r=this.options.followSymlinks;return new wl(e,s,r,this)}_getWatchedDir(e){this._boundRemove||(this._boundRemove=this._remove.bind(this));let t=Z.resolve(e);return this._watched.has(t)||this._watched.set(t,new vl(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=Z.join(e,t),i=Z.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),c=l.has(t);l.remove(t),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let d=r;if(this.options.cwd&&(d=Z.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(d)&&this._pendingWrites.get(d).cancelWait()===Tr)return;this._watched.delete(r),this._watched.delete(i);let f=s?h$:Km;c&&!this._isIgnored(r)&&this._emit(f,r),this.options.useFsEvents||this._closePath(r)}_closePath(e){this._closeFile(e);let t=Z.dirname(e);this._getWatchedDir(t).remove(Z.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:ul,alwaysStat:!0,lstat:!0,...t},r=a$(e,s);return this._streams.add(r),r.once(g$,()=>{r=void 0}),r.once(y$,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};_l.FSWatcher=Cr;var D$=(n,e)=>{let t=new Cr(e);return t.add(n),t};_l.watch=D$});var ng={};Re(ng,{CollaborationManager:()=>Al,addTeamMember:()=>H$,formatTeamConfig:()=>j$,initTeamConfig:()=>F$,loadTeamConfig:()=>N$,saveTeamConfig:()=>tg});function N$(n){let e=Ke.join(n,".hablas","team.json");if(ue.existsSync(e))try{return JSON.parse(ue.readFileSync(e,"utf-8"))}catch{return null}return null}function F$(n,e){let t={name:e,members:[]};return tg(n,t),t}function tg(n,e){let t=Ke.join(n,".hablas","team.json"),s=Ke.dirname(t);ue.existsSync(s)||ue.mkdirSync(s,{recursive:!0}),ue.writeFileSync(t,JSON.stringify(e,null,2),"utf-8")}function H$(n,e,t){return n.members.push({name:e,email:t}),n}function j$(n){return[`Team: ${n.name}`,"Members:",...n.members.map(t=>` - ${t.name} (${t.email})`)].join(`
|
|
910
|
-
`)
|
|
911
|
-
|
|
912
|
-
`)
|
|
913
|
-
|
|
900
|
+
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 c=i.map(u=>{let f=he.find(h=>h.role===u.agent);return`### @${u.agentName} (${f?.title??u.agent}):
|
|
901
|
+
${u.output}`}).join(`
|
|
902
|
+
|
|
903
|
+
`);return{results:t,finalSynthesis:c,synthesisOk:!1}}}});function Xe(n){switch(n){case"Hablas":return d.leader;case"Bob":return d.architect;case"Alex":return d.engineer;case"David":return d.analyst;case"Emma":return d.product;default:return d.primary}}function or(n){return n==="Hablas"?"\u2605":"\u25C6"}function Kn(n,e=140){let t=(n||"").replace(/\s+/g," ").trim();return t.length>e?t.slice(0,e-1)+"\u2026":t}var ar,Up=F(()=>{"use strict";nn();ar=class{channel;opts;attached=!1;listener;lastThinking=null;lastLine="";constructor(e,t={}){this.channel=e,this.opts={hideThinking:t.hideThinking??!1,hideActs:t.hideActs??!1,maxChars:t.maxChars??140},this.listener=s=>this.handle(s)}attach(){return this.attached?this:(this.channel.onEvent(this.listener),this.attached=!0,this)}detach(){return this.attached?(this.channel.offEvent(this.listener),this.attached=!1,this):this}handle(e){switch(e.type){case"phase":return this.renderPhase(e);case"handoff":return this.renderHandoff(e);case"thinking":return this.renderThinking(e);case"speak":return this.renderSpeak(e);case"act":return this.renderAct(e);case"observe":return this.renderObserve(e);case"review":return this.renderReview(e);case"summary":return this.renderSummary(e);case"decision":return this.renderDecision(e);case"done":return this.renderDone(e);case"error":return this.renderError(e)}}renderPhase(e){let t=(e.content||"").toString();t&&(this.print(`
|
|
904
|
+
${d.muted("\u25B8")} ${d.secondary(t)}`),this.lastThinking=null)}renderHandoff(e){let t=e.agent,s=e.to||"";if(!s)return;let r=Xe(t),i=Xe(s);this.print(` ${r(or(t))} ${r(t)} ${d.muted("\u2501\u2501\u25B6")} ${i(or(s))} ${i(s)}`),this.lastThinking=null}renderThinking(e){if(this.opts.hideThinking||this.lastThinking===e.agent)return;this.lastThinking=e.agent;let t=Xe(e.agent);this.print(` ${t("\u25C9")} [Active Agent: ${e.agent}] is thinking & formulating response\u2026`)}renderSpeak(e){let t=Kn(e.content||"",this.opts.maxChars);if(!t)return;let s=Xe(e.agent),r=e.to?` ${d.muted("\u2192")} ${Xe(e.to)("@"+e.to)}`:"",i=`speak:${e.agent}:${e.to||""}:${t}`;i!==this.lastLine&&(this.lastLine=i,this.print(` ${s(or(e.agent))} ${s(e.agent)}${r}${d.muted(":")} ${d.secondary(t)}`),this.lastThinking=null)}renderAct(e){if(this.opts.hideActs)return;let t=Xe(e.agent),s=e.toolName||"tool",r=e.toolArgs||{},i="";typeof r.path=="string"?i=` ${d.primary(r.path)}`:typeof r.command=="string"?i=` ${d.primary(r.command)}`:typeof r.query=="string"&&(i=` "${d.primary(r.query)}"`);let o=s==="write_file"||s==="edit_file"||s==="patch_file"?"\u270E":s==="run_command"?"\u2318":s==="read_file"?"\u{1F4D6}":s==="search_codebase"?"\u{1F50E}":"\u{1F527}";this.print(` ${t(o)} [Running Tool]: ${t(e.agent)} is executing ${d.strong(s)}${i}...`),this.lastThinking=null}renderObserve(e){if(this.opts.hideActs)return;let t=e.success!==!1,s=t?d.success("\u2713 COMPLETED"):d.error("\u2717 FAILED"),r=Kn(e.content||(t?"Execution succeeded":"Execution failed"),this.opts.maxChars);this.print(` ${d.muted("\u21B3")} ${s}: ${d.muted(r)}`)}renderReview(e){let t=e.agent,s=e.to||"",r=Kn(e.content||"",this.opts.maxChars);if(!r)return;let i=Xe(t),o=Xe(s);this.print(`
|
|
905
|
+
${i("\u270E")} ${d.strong("@"+t)} ${d.muted("reviewing")} ${o("@"+s)}${d.muted(":")} ${d.secondary(r)}`),this.lastThinking=null}renderSummary(e){let t=Xe(e.agent),s=e.durationMs?` ${d.muted(`(${(e.durationMs/1e3).toFixed(1)}s)`)}`:"";this.print(` ${t(or(e.agent))} ${t(e.agent)} ${d.muted("\u2500\u2500\u25BA")} ${d.leader("\u2605 Hablas")} ${d.muted("\xB7 report submitted")}${s}`),this.lastThinking=null}renderDecision(e){let t=Kn(e.content||"",this.opts.maxChars);if(!t)return;let s=Xe(e.agent);this.print(` ${s("\u25C6")} ${s(e.agent)} ${d.muted("decision:")} ${d.secondary(t)}`)}renderDone(e){this.print(`
|
|
906
|
+
${d.chrome("\u2500".repeat(56))}`),this.lastThinking=null}renderError(e){let t=Xe(e.agent),s=Kn(e.content||"unknown error",this.opts.maxChars);this.print(` ${t("\u25C6")} ${t(e.agent)} ${d.error("\u2717")} ${d.error(s)}`),this.lastThinking=null}print(e){console.log(e)}}});var lr,qp=F(()=>{"use strict";lr=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(c=>c.status==="done").length,r=e.tasks.filter(c=>c.status==="failed").length,i=e.tasks.filter(c=>c.status==="pending").length,o=e.tasks.filter(c=>c.status==="running").length,a=e.tasks.filter(c=>c.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())}}});function Wp(n){let e=n.trim(),t=e.toLowerCase();if(S_.test(e)||__.test(e)||e.length<15&&!A_.test(e))return"XS";if(C_.test(t)||Kp.test(t)&&e.length>150)return"XL";let s=t.match($_)||[],i=new Set(s.map(a=>a.toLowerCase())).size,o=e.split(/[.!?]+/).filter(a=>a.trim().length>5);return Kp.test(t)||o.length>=3&&i>=2||i>=3&&e.length>100?"L":E_.test(t)||i>=2&&e.length>=50||e.length>=50&&e.length<=150&&i>=1&&o.length>=2?"M":(e.length<50&&i<=1||k_.test(e)&&i<=1||i===1,"S")}var S_,__,A_,k_,$_,C_,Kp,E_,Gp=F(()=>{"use strict";S_=/^(hi|hello|hey|howdy|yo|sup|hiya|good\s*(morning|afternoon|evening|night)|what'?s\s*up|greetings|thanks?|thank\s*you|bye|goodbye|ok(ay)?|yes|no|cool|nice|great|got\s*it|sure|مرحبا|أهلا|هلا|السلام\s*عليكم|كيف\s*حالك)\b/i,__=/^(how\s*are\s*you|what'?s\s*your\s*name|who\s*are\s*you|what\s*can\s*you\s*do|help|tell\s*me\s*about\s*yourself)\s*[?!.]*$/i,A_=/\b(create|build|implement|write|generate|code|make|develop|design|architect|setup|configure|install|deploy|fix|debug|refactor|rewrite|restructure|migrate|convert|add|remove|delete|update|change|modify|edit|move|rename|test|run|execute|analyze|research|find|search|compare|optimize)\b/i,k_=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|scss|html|vue|svelte|go|rs|java|c|cpp|h|rb|php|sql|sh|toml|xml|env)/i,$_=/\b(create|build|implement|write|generate|design|architect|setup|configure|deploy|fix|debug|refactor|rewrite|restructure|migrate|add|remove|update|change|modify|test|analyze|research|optimize)\b/gi,C_=/\b(full\s+system|complete\s+project|from\s+scratch|entire\s+application|prd|product\s+requirements|architecture\s+.*implementation\s+.*deployment|end[\s-]*to[\s-]*end)\b/i,Kp=/\b(design|architect)\b.*\b(implement|build|create|develop)\b/i,E_=/\b(multiple\s+files|several\s+components|across\s+all|every\s+file|all\s+modules)\b/i});function Vp(n){let e=n.toLowerCase();return/\b(how|why|what|tell\s+me|explain)\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":"IMPLEMENTATION"}function zp(n){let e=n.trim();if(!e)return 0;let t=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|html|env)/i.test(e)?.4:0,s=/\b(read|write|run|edit|search|list|delete|patch)\b/i.test(e)?.3:0,r=e.startsWith("/")?.3:0;return Math.min(1,t+s+r)}var Yp=F(()=>{"use strict"});function T_(n,e){let t=[],s;for(Jp.lastIndex=0;(s=Jp.exec(n))!==null;){let r=s[1],i=xe.resolve(e,r);Qe.existsSync(i)&&t.push(r)}return[...new Set(t)]}function R_(n,e,t){let s=[],r=xe.extname(e),i=xe.dirname(xe.resolve(t,e));if([".ts",".tsx",".js",".jsx",".mjs",".cjs"].includes(r)){let o;for(Xp.lastIndex=0;(o=Xp.exec(n))!==null;){let a=o[1]||o[2];if(!a||!a.startsWith(".")&&!a.startsWith("/"))continue;let l=O_(a,i);l&&s.push(xe.relative(t,l))}}else if(r===".py"){let o;for(Qp.lastIndex=0;(o=Qp.exec(n))!==null;){let a=o[1]||o[2];if(!a)continue;let l=a.replace(/\./g,"/")+".py",c=xe.resolve(i,l);Qe.existsSync(c)&&s.push(xe.relative(t,c))}}return[...new Set(s)]}function O_(n,e){let t=[".ts",".tsx",".js",".jsx",".mjs",".cjs"],s=xe.resolve(e,n);if(Qe.existsSync(s)&&Qe.statSync(s).isFile())return s;for(let r of t){let i=s+r;if(Qe.existsSync(i))return i}for(let r of t){let i=xe.join(s,`index${r}`);if(Qe.existsSync(i))return i}return null}function Zp(n,e,t){let s=t?.maxFiles||10,r=t?.maxTokens||8e3,i=t?.followImports!==!1,o=T_(n,e),a=[],l=new Set,c=0;for(let u of o){if(a.length>=s||c>=r)break;if(!l.has(u)){l.add(u);try{let f=xe.resolve(e,u),h=Qe.readFileSync(f,"utf-8"),m=h.split(`
|
|
907
|
+
`).length,p=Math.ceil(h.length/4);if(p>4e3){let g=h.split(`
|
|
908
|
+
`).slice(0,200).join(`
|
|
909
|
+
`)+`
|
|
910
|
+
...(truncated)`,x=Math.ceil(g.length/4);c+x<=r&&(a.push({path:u,content:g,source:"mentioned",lineCount:200}),c+=x)}else if(c+p<=r&&(a.push({path:u,content:h,source:"mentioned",lineCount:m}),c+=p,i)){let g=R_(h,u,e);for(let x of g.slice(0,5)){if(a.length>=s||c>=r)break;if(!l.has(x)){l.add(x);try{let S=xe.resolve(e,x),C=Qe.readFileSync(S,"utf-8"),k=Math.ceil(C.length/4),y=C.split(`
|
|
911
|
+
`).length;if(k>2e3){let v=C.split(`
|
|
912
|
+
`).slice(0,100).join(`
|
|
913
|
+
`)+`
|
|
914
|
+
...(truncated)`,b=Math.ceil(v.length/4);c+b<=r&&(a.push({path:x,content:v,source:"imported",lineCount:100}),c+=b)}else c+k<=r&&(a.push({path:x,content:C,source:"imported",lineCount:y}),c+=k)}catch{}}}}}catch{}}}return{files:a,totalTokensEstimate:c,mentionedPaths:o}}function eh(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(`
|
|
915
|
+
`)}var Qe,xe,Jp,Xp,Qp,th=F(()=>{"use strict";Qe=O(require("fs")),xe=O(require("path")),Jp=/(?:^|\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,Xp=/(?:import\s+.*?\s+from\s+['"]([^'"]+)['"]|require\s*\(\s*['"]([^'"]+)['"]\s*\))/g,Qp=/(?:from\s+(\S+)\s+import|import\s+(\S+))/g});var Et={};Ee(Et,{activeCollabManager:()=>P_,runSingleCommand:()=>L_,startRepl:()=>ba});async function ba(n,e){let t=n.workingDirectory==="."?process.cwd():n.workingDirectory,s=Le(n),r=new In(t,n),i=new an(n),o=new Os(t),a=Ps(),l=new Is(t),c=new pn(t),u=new lr,f=new tr(n);f.setToolRegistry(r);let h=new nr;new ar(h).attach();let m=new rr(n,{tokenBudget:500,maxChars:140});console.log(Dc(n.model,t));let p=0,g=0,x=new AbortController;for(process.on("SIGINT",()=>{let S=Date.now();S-g<M_&&process.exit(0),g=S,x.abort(),x=new AbortController,console.log(`
|
|
916
|
+
`+Ae("Cancelled."))});;)try{let S=await o.prompt(`
|
|
917
|
+
${d.primary("\u203A")} `);if(!S.trim())continue;if(S.startsWith("/")){await uu(S,n,s,r,i,new Pt("",10),t,o,p,a,void 0,l,M=>{s=M},c,u,void 0,f);continue}let C=I_(sc(S),t),k=Zp(C,t,{maxFiles:5,maxTokens:4e3}),y=k.files.length>0?`[Files Attached: ${k.mentionedPaths.join(", ")}]
|
|
918
|
+
${eh(k)}
|
|
919
|
+
|
|
920
|
+
Request: ${C}`:C,v=await Rn(t,n),b=On(a.getActive()?.systemPrompt||Pn,v,l,c),w=new Pt(b,n.historySize);p++,console.log(Hc(p)),bs(gi(Qt()));let _=Vp(C),R=zp(C),D=Wp(C);if(!li(C)&&_!=="QUESTION"&&R<.7&&D!=="FILE"){let M=fc(C),N=pc(C,M),U=new ir(h,f,m,n),{finalSynthesis:E}=await U.run(y,N,r.getOllamaTools(),{abortSignal:x.signal});console.log(`
|
|
921
|
+
`+Cn("Hablas","Team Leader")),console.log(En(E))}else{w.addUserMessage(y);let M=new nt("Hablas is thinking");M.start(),await qn({identity:{name:"Hablas",title:"Team Leader",role:"hablas"},client:s,registry:r,session:w,contextManager:i,logger:e,safetyPolicy:Rp({autoMode:n.autoMode,interactive:!0,confirm:N=>o.confirm(N),confirmDangerous:N=>o.confirmDangerous(N)}),io:{onAssistantText:async N=>{M.stop(),console.log(Cn("Hablas","Team Leader")),console.log(En(N.replace(/<<?action\s*>>?[\s\S]*?<<?\/action\s*>>?/gi,"")))},onToolStart:(N,U)=>{M.stop(),console.log(d.muted(` \u2699 Executing ${N}: ${U}`)),M.start()},onToolEnd:(N,U)=>{M.stop(),console.log(U?d.success(` \u2713 ${N} done`):d.error(` \u2717 ${N} failed`)),M.start()},onToolCall:()=>bs(yi(Qt(),"tool_call"))},abortSignal:x.signal}),M.stop()}}catch(S){console.log(Ae(S.message))}}function I_(n,e){return n.replace(/#([\w./-]+)/g,(t,s)=>nh.existsSync(sh.resolve(e,s))?s:t)}async function L_(n,e,t){let s=Le(e),r=new In(e.workingDirectory,e),i=new Pt(Pn,10);i.addUserMessage(n),await qn({identity:{name:"Hablas",title:"Team Leader"},client:s,registry:r,session:i,logger:t,safetyPolicy:(o,a)=>"allow"})}var nh,sh,P_,M_,gt=F(()=>{"use strict";du();nh=O(require("fs")),sh=O(require("path"));Sn();td();Wi();Gi();id();ho();ld();Xr();_n();Ip();Dp();Fp();Bp();Up();kn();ga();qp();Gp();Yp();nn();ma();th();P_=null,M_=1500});function He(n={}){let e={};if(wt.existsSync(wa))try{let s=wt.readFileSync(wa,"utf-8");e=JSON.parse(s)}catch{}let t={...wn,...e,tools:{...wn.tools,...e.tools||{}},ui:{...wn.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=Wn.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 ot(n){wt.existsSync(va)||wt.mkdirSync(va,{recursive:!0}),wt.writeFileSync(wa,JSON.stringify(n,null,2),"utf-8")}var wt,Wn,rh,va,wa,xa=F(()=>{"use strict";wt=O(require("fs")),Wn=O(require("path")),rh=O(require("os"));xn();va=Wn.join(rh.homedir(),".hablas"),wa=Wn.join(va,"config.json")});function xt(n){let e=_a.join(ih.homedir(),".hablas","logs");cr.existsSync(e)||cr.mkdirSync(e,{recursive:!0});let t=_a.join(e,`session-${Date.now()}.log`);return(0,Sa.default)({level:"info"},Sa.default.destination({dest:t,sync:!1}))}var Sa,_a,ih,cr,Aa=F(()=>{"use strict";Sa=O(la()),_a=O(require("path")),ih=O(require("os")),cr=O(require("fs"))});var Gn=j((SR,uh)=>{"use strict";var D_=require("path"),at="\\\\/",oh=`[^${at}]`,F_=0,St="\\.",N_="\\+",j_="\\?",ur="\\/",H_="(?=.)",ah="[^/]",ka=`(?:${ur}|$)`,lh=`(?:^|${ur})`,$a=`${St}{1,2}${ka}`,B_=`(?!${St})`,U_=`(?!${lh}${$a})`,q_=`(?!${St}{0,1}${ka})`,K_=`(?!${$a})`,W_=`[^.${ur}]`,G_=`${ah}*?`,ch={DOT_LITERAL:St,PLUS_LITERAL:N_,QMARK_LITERAL:j_,SLASH_LITERAL:ur,ONE_CHAR:H_,QMARK:ah,END_ANCHOR:ka,DOTS_SLASH:$a,NO_DOT:B_,NO_DOTS:U_,NO_DOT_SLASH:q_,NO_DOTS_SLASH:K_,QMARK_NO_DOT:W_,STAR:G_,START_ANCHOR:lh},V_={...ch,SLASH_LITERAL:`[${at}]`,QMARK:oh,STAR:`${oh}*?`,DOTS_SLASH:`${St}{1,2}(?:[${at}]|$)`,NO_DOT:`(?!${St})`,NO_DOTS:`(?!(?:^|[${at}])${St}{1,2}(?:[${at}]|$))`,NO_DOT_SLASH:`(?!${St}{0,1}(?:[${at}]|$))`,NO_DOTS_SLASH:`(?!${St}{1,2}(?:[${at}]|$))`,QMARK_NO_DOT:`[^.${at}]`,START_ANCHOR:`(?:^|[${at}])`,END_ANCHOR:`(?:[${at}]|$)`},z_={__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"};uh.exports={DEFAULT_MAX_EXTGLOB_RECURSION:F_,MAX_LENGTH:1024*64,POSIX_REGEX_SOURCE:z_,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:D_.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?V_:ch}}});var dr=j(Ce=>{"use strict";var Y_=require("path"),J_=process.platform==="win32",{REGEX_BACKSLASH:X_,REGEX_REMOVE_BACKSLASH:Q_,REGEX_SPECIAL_CHARS:Z_,REGEX_SPECIAL_CHARS_GLOBAL:eA}=Gn();Ce.isObject=n=>n!==null&&typeof n=="object"&&!Array.isArray(n);Ce.hasRegexChars=n=>Z_.test(n);Ce.isRegexChar=n=>n.length===1&&Ce.hasRegexChars(n);Ce.escapeRegex=n=>n.replace(eA,"\\$1");Ce.toPosixSlashes=n=>n.replace(X_,"/");Ce.removeBackslashes=n=>n.replace(Q_,e=>e==="\\"?"":e);Ce.supportsLookbehinds=()=>{let n=process.version.slice(1).split(".").map(Number);return n.length===3&&n[0]>=9||n[0]===8&&n[1]>=10};Ce.isWindows=n=>n&&typeof n.windows=="boolean"?n.windows:J_===!0||Y_.sep==="\\";Ce.escapeLast=(n,e,t)=>{let s=n.lastIndexOf(e,t);return s===-1?n:n[s-1]==="\\"?Ce.escapeLast(n,e,s-1):`${n.slice(0,s)}\\${n.slice(s)}`};Ce.removePrefix=(n,e={})=>{let t=n;return t.startsWith("./")&&(t=t.slice(2),e.prefix="./"),t};Ce.wrapOutput=(n,e={},t={})=>{let s=t.contains?"":"^",r=t.contains?"":"$",i=`${s}(?:${n})${r}`;return e.negated===!0&&(i=`(?:^(?!${i}).*$)`),i}});var bh=j((AR,yh)=>{"use strict";var dh=dr(),{CHAR_ASTERISK:Ca,CHAR_AT:tA,CHAR_BACKWARD_SLASH:Vn,CHAR_COMMA:nA,CHAR_DOT:Ea,CHAR_EXCLAMATION_MARK:Ta,CHAR_FORWARD_SLASH:gh,CHAR_LEFT_CURLY_BRACE:Ra,CHAR_LEFT_PARENTHESES:Oa,CHAR_LEFT_SQUARE_BRACKET:sA,CHAR_PLUS:rA,CHAR_QUESTION_MARK:fh,CHAR_RIGHT_CURLY_BRACE:iA,CHAR_RIGHT_PARENTHESES:ph,CHAR_RIGHT_SQUARE_BRACKET:oA}=Gn(),hh=n=>n===gh||n===Vn,mh=n=>{n.isPrefix!==!0&&(n.depth=n.isGlobstar?1/0:1)},aA=(n,e)=>{let t=e||{},s=n.length-1,r=t.parts===!0||t.scanToEnd===!0,i=[],o=[],a=[],l=n,c=-1,u=0,f=0,h=!1,m=!1,p=!1,g=!1,x=!1,S=!1,C=!1,k=!1,y=!1,v=!1,b=0,w,_,R={value:"",depth:0,isGlob:!1},D=()=>c>=s,$=()=>l.charCodeAt(c+1),M=()=>(w=_,l.charCodeAt(++c));for(;c<s;){_=M();let V;if(_===Vn){C=R.backslashes=!0,_=M(),_===Ra&&(S=!0);continue}if(S===!0||_===Ra){for(b++;D()!==!0&&(_=M());){if(_===Vn){C=R.backslashes=!0,M();continue}if(_===Ra){b++;continue}if(S!==!0&&_===Ea&&(_=M())===Ea){if(h=R.isBrace=!0,p=R.isGlob=!0,v=!0,r===!0)continue;break}if(S!==!0&&_===nA){if(h=R.isBrace=!0,p=R.isGlob=!0,v=!0,r===!0)continue;break}if(_===iA&&(b--,b===0)){S=!1,h=R.isBrace=!0,v=!0;break}}if(r===!0)continue;break}if(_===gh){if(i.push(c),o.push(R),R={value:"",depth:0,isGlob:!1},v===!0)continue;if(w===Ea&&c===u+1){u+=2;continue}f=c+1;continue}if(t.noext!==!0&&(_===rA||_===tA||_===Ca||_===fh||_===Ta)===!0&&$()===Oa){if(p=R.isGlob=!0,g=R.isExtglob=!0,v=!0,_===Ta&&c===u&&(y=!0),r===!0){for(;D()!==!0&&(_=M());){if(_===Vn){C=R.backslashes=!0,_=M();continue}if(_===ph){p=R.isGlob=!0,v=!0;break}}continue}break}if(_===Ca){if(w===Ca&&(x=R.isGlobstar=!0),p=R.isGlob=!0,v=!0,r===!0)continue;break}if(_===fh){if(p=R.isGlob=!0,v=!0,r===!0)continue;break}if(_===sA){for(;D()!==!0&&(V=M());){if(V===Vn){C=R.backslashes=!0,M();continue}if(V===oA){m=R.isBracket=!0,p=R.isGlob=!0,v=!0;break}}if(r===!0)continue;break}if(t.nonegate!==!0&&_===Ta&&c===u){k=R.negated=!0,u++;continue}if(t.noparen!==!0&&_===Oa){if(p=R.isGlob=!0,r===!0){for(;D()!==!0&&(_=M());){if(_===Oa){C=R.backslashes=!0,_=M();continue}if(_===ph){v=!0;break}}continue}break}if(p===!0){if(v=!0,r===!0)continue;break}}t.noext===!0&&(g=!1,p=!1);let N=l,U="",E="";u>0&&(U=l.slice(0,u),l=l.slice(u),f-=u),N&&p===!0&&f>0?(N=l.slice(0,f),E=l.slice(f)):p===!0?(N="",E=l):N=l,N&&N!==""&&N!=="/"&&N!==l&&hh(N.charCodeAt(N.length-1))&&(N=N.slice(0,-1)),t.unescape===!0&&(E&&(E=dh.removeBackslashes(E)),N&&C===!0&&(N=dh.removeBackslashes(N)));let A={prefix:U,input:n,start:u,base:N,glob:E,isBrace:h,isBracket:m,isGlob:p,isExtglob:g,isGlobstar:x,negated:k,negatedExtglob:y};if(t.tokens===!0&&(A.maxDepth=0,hh(_)||o.push(R),A.tokens=o),t.parts===!0||t.tokens===!0){let V;for(let q=0;q<i.length;q++){let ue=V?V+1:u,ve=i[q],X=n.slice(ue,ve);t.tokens&&(q===0&&u!==0?(o[q].isPrefix=!0,o[q].value=U):o[q].value=X,mh(o[q]),A.maxDepth+=o[q].depth),(q!==0||X!=="")&&a.push(X),V=ve}if(V&&V+1<n.length){let q=n.slice(V+1);a.push(q),t.tokens&&(o[o.length-1].value=q,mh(o[o.length-1]),A.maxDepth+=o[o.length-1].depth)}A.slashes=i,A.parts=a}return A};yh.exports=aA});var _h=j((kR,Sh)=>{"use strict";var zn=Gn(),Se=dr(),{MAX_LENGTH:fr,POSIX_REGEX_SOURCE:lA,REGEX_NON_SPECIAL_CHARS:cA,REGEX_SPECIAL_CHARS_BACKREF:uA,REPLACEMENTS:vh}=zn,dA=(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=>Se.escapeRegex(r)).join("..")}return t},hn=(n,e)=>`Missing ${n}: "${e}" - use "\\\\${e}" to match literal characters`,wh=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},fA=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},xh=n=>{let e=n.trim(),t=!0;for(;t===!0;)t=!1,/^@\([^\\()[\]{}|]+\)$/.test(e)&&(e=e.slice(2,-1),t=!0);if(fA(e))return e.replace(/\\(.)/g,"$1")},pA=n=>{let e=n.map(xh).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},Pa=(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}}}}},hA=n=>{let e=0,t=[];for(;e<n.length;){let r=Pa(n.slice(e),!1);if(!r||r.type!=="*")return;let i=wh(r.body).map(a=>a.trim());if(i.length!==1)return;let o=xh(i[0]);if(!o||o.length!==1)return;t.push(o),e+=r.end+1}return t.length<1?void 0:`${t.length===1?Se.escapeRegex(t[0]):`[${t.map(r=>Se.escapeRegex(r)).join("")}]`}*`},mA=n=>{let e=0,t=n.trim(),s=Pa(t);for(;s;)e++,t=s.body.trim(),s=Pa(t);return e},gA=(n,e)=>{if(e.maxExtglobRecursion===!1)return{risky:!1};let t=typeof e.maxExtglobRecursion=="number"?e.maxExtglobRecursion:zn.DEFAULT_MAX_EXTGLOB_RECURSION,s=wh(n).map(r=>r.trim());if(s.length>1&&(s.some(r=>r==="")||s.some(r=>/^[*?]+$/.test(r))||pA(s)))return{risky:!0};for(let r of s){let i=hA(r);if(i)return{risky:!0,safeOutput:i};if(mA(r)>t)return{risky:!0}}return{risky:!1}},Ma=(n,e)=>{if(typeof n!="string")throw new TypeError("Expected a string");n=vh[n]||n;let t={...e},s=typeof t.maxLength=="number"?Math.min(fr,t.maxLength):fr,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=Se.isWindows(e),c=zn.globChars(l),u=zn.extglobChars(c),{DOT_LITERAL:f,PLUS_LITERAL:h,SLASH_LITERAL:m,ONE_CHAR:p,DOTS_SLASH:g,NO_DOT:x,NO_DOT_SLASH:S,NO_DOTS_SLASH:C,QMARK:k,QMARK_NO_DOT:y,STAR:v,START_ANCHOR:b}=c,w=L=>`(${a}(?:(?!${b}${L.dot?g:f}).)*?)`,_=t.dot?"":x,R=t.dot?k:y,D=t.bash===!0?w(t):v;t.capture&&(D=`(${D})`),typeof t.noext=="boolean"&&(t.noextglob=t.noext);let $={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=Se.removePrefix(n,$),r=n.length;let M=[],N=[],U=[],E=i,A,V=()=>$.index===r-1,q=$.peek=(L=1)=>n[$.index+L],ue=$.advance=()=>n[++$.index]||"",ve=()=>n.slice($.index+1),X=(L="",ie=0)=>{$.consumed+=L,$.index+=ie},qe=L=>{$.output+=L.output!=null?L.output:L.value,X(L.value)},At=()=>{let L=1;for(;q()==="!"&&(q(2)!=="("||q(3)==="?");)ue(),$.start++,L++;return L%2===0?!1:($.negated=!0,$.start++,!0)},Ke=L=>{$[L]++,U.push(L)},_e=L=>{$[L]--,U.pop()},J=L=>{if(E.type==="globstar"){let ie=$.braces>0&&(L.type==="comma"||L.type==="brace"),I=L.extglob===!0||M.length&&(L.type==="pipe"||L.type==="paren");L.type!=="slash"&&L.type!=="paren"&&!ie&&!I&&($.output=$.output.slice(0,-E.output.length),E.type="star",E.value="*",E.output=D,$.output+=E.output)}if(M.length&&L.type!=="paren"&&(M[M.length-1].inner+=L.value),(L.value||L.output)&&qe(L),E&&E.type==="text"&&L.type==="text"){E.value+=L.value,E.output=(E.output||"")+L.value;return}L.prev=E,o.push(L),E=L},is=(L,ie)=>{let I={...u[ie],conditions:1,inner:""};I.prev=E,I.parens=$.parens,I.output=$.output,I.startIndex=$.index,I.tokensIndex=o.length;let z=(t.capture?"(":"")+I.open;Ke("parens"),J({type:L,value:ie,output:$.output?"":p}),J({type:"paren",extglob:!0,value:ue(),output:z}),M.push(I)},xg=L=>{let ie=n.slice(L.startIndex,$.index+1),I=n.slice(L.startIndex+2,$.index),z=gA(I,t);if((L.type==="plus"||L.type==="star")&&z.risky){let ee=z.safeOutput?(L.output?"":p)+(t.capture?`(${z.safeOutput})`:z.safeOutput):void 0,et=o[L.tokensIndex];et.type="text",et.value=ie,et.output=ee||Se.escapeRegex(ie);for(let tt=L.tokensIndex+1;tt<o.length;tt++)o[tt].value="",o[tt].output="",delete o[tt].suffix;$.output=L.output+et.output,$.backtrack=!0,J({type:"paren",extglob:!0,value:A,output:""}),_e("parens");return}let ne=L.close+(t.capture?")":""),pe;if(L.type==="negate"){let ee=D;if(L.inner&&L.inner.length>1&&L.inner.includes("/")&&(ee=w(t)),(ee!==D||V()||/^\)+$/.test(ve()))&&(ne=L.close=`)$))${ee}`),L.inner.includes("*")&&(pe=ve())&&/^\.[^\\/.]+$/.test(pe)){let et=Ma(pe,{...e,fastpaths:!1}).output;ne=L.close=`)${et})${ee})`}L.prev.type==="bos"&&($.negatedExtglob=!0)}J({type:"paren",extglob:!0,value:A,output:ne}),_e("parens")};if(t.fastpaths!==!1&&!/(^[*!]|[/()[\]{}"])/.test(n)){let L=!1,ie=n.replace(uA,(I,z,ne,pe,ee,et)=>pe==="\\"?(L=!0,I):pe==="?"?z?z+pe+(ee?k.repeat(ee.length):""):et===0?R+(ee?k.repeat(ee.length):""):k.repeat(ne.length):pe==="."?f.repeat(ne.length):pe==="*"?z?z+pe+(ee?D:""):D:z?I:`\\${I}`);return L===!0&&(t.unescape===!0?ie=ie.replace(/\\/g,""):ie=ie.replace(/\\+/g,I=>I.length%2===0?"\\\\":I?"\\":"")),ie===n&&t.contains===!0?($.output=n,$):($.output=Se.wrapOutput(ie,$,e),$)}for(;!V();){if(A=ue(),A==="\0")continue;if(A==="\\"){let I=q();if(I==="/"&&t.bash!==!0||I==="."||I===";")continue;if(!I){A+="\\",J({type:"text",value:A});continue}let z=/^\\+/.exec(ve()),ne=0;if(z&&z[0].length>2&&(ne=z[0].length,$.index+=ne,ne%2!==0&&(A+="\\")),t.unescape===!0?A=ue():A+=ue(),$.brackets===0){J({type:"text",value:A});continue}}if($.brackets>0&&(A!=="]"||E.value==="["||E.value==="[^")){if(t.posix!==!1&&A===":"){let I=E.value.slice(1);if(I.includes("[")&&(E.posix=!0,I.includes(":"))){let z=E.value.lastIndexOf("["),ne=E.value.slice(0,z),pe=E.value.slice(z+2),ee=lA[pe];if(ee){E.value=ne+ee,$.backtrack=!0,ue(),!i.output&&o.indexOf(E)===1&&(i.output=p);continue}}}(A==="["&&q()!==":"||A==="-"&&q()==="]")&&(A=`\\${A}`),A==="]"&&(E.value==="["||E.value==="[^")&&(A=`\\${A}`),t.posix===!0&&A==="!"&&E.value==="["&&(A="^"),E.value+=A,qe({value:A});continue}if($.quotes===1&&A!=='"'){A=Se.escapeRegex(A),E.value+=A,qe({value:A});continue}if(A==='"'){$.quotes=$.quotes===1?0:1,t.keepQuotes===!0&&J({type:"text",value:A});continue}if(A==="("){Ke("parens"),J({type:"paren",value:A});continue}if(A===")"){if($.parens===0&&t.strictBrackets===!0)throw new SyntaxError(hn("opening","("));let I=M[M.length-1];if(I&&$.parens===I.parens+1){xg(M.pop());continue}J({type:"paren",value:A,output:$.parens?")":"\\)"}),_e("parens");continue}if(A==="["){if(t.nobracket===!0||!ve().includes("]")){if(t.nobracket!==!0&&t.strictBrackets===!0)throw new SyntaxError(hn("closing","]"));A=`\\${A}`}else Ke("brackets");J({type:"bracket",value:A});continue}if(A==="]"){if(t.nobracket===!0||E&&E.type==="bracket"&&E.value.length===1){J({type:"text",value:A,output:`\\${A}`});continue}if($.brackets===0){if(t.strictBrackets===!0)throw new SyntaxError(hn("opening","["));J({type:"text",value:A,output:`\\${A}`});continue}_e("brackets");let I=E.value.slice(1);if(E.posix!==!0&&I[0]==="^"&&!I.includes("/")&&(A=`/${A}`),E.value+=A,qe({value:A}),t.literalBrackets===!1||Se.hasRegexChars(I))continue;let z=Se.escapeRegex(E.value);if($.output=$.output.slice(0,-E.value.length),t.literalBrackets===!0){$.output+=z,E.value=z;continue}E.value=`(${a}${z}|${E.value})`,$.output+=E.value;continue}if(A==="{"&&t.nobrace!==!0){Ke("braces");let I={type:"brace",value:A,output:"(",outputIndex:$.output.length,tokensIndex:$.tokens.length};N.push(I),J(I);continue}if(A==="}"){let I=N[N.length-1];if(t.nobrace===!0||!I){J({type:"text",value:A,output:A});continue}let z=")";if(I.dots===!0){let ne=o.slice(),pe=[];for(let ee=ne.length-1;ee>=0&&(o.pop(),ne[ee].type!=="brace");ee--)ne[ee].type!=="dots"&&pe.unshift(ne[ee].value);z=dA(pe,t),$.backtrack=!0}if(I.comma!==!0&&I.dots!==!0){let ne=$.output.slice(0,I.outputIndex),pe=$.tokens.slice(I.tokensIndex);I.value=I.output="\\{",A=z="\\}",$.output=ne;for(let ee of pe)$.output+=ee.output||ee.value}J({type:"brace",value:A,output:z}),_e("braces"),N.pop();continue}if(A==="|"){M.length>0&&M[M.length-1].conditions++,J({type:"text",value:A});continue}if(A===","){let I=A,z=N[N.length-1];z&&U[U.length-1]==="braces"&&(z.comma=!0,I="|"),J({type:"comma",value:A,output:I});continue}if(A==="/"){if(E.type==="dot"&&$.index===$.start+1){$.start=$.index+1,$.consumed="",$.output="",o.pop(),E=i;continue}J({type:"slash",value:A,output:m});continue}if(A==="."){if($.braces>0&&E.type==="dot"){E.value==="."&&(E.output=f);let I=N[N.length-1];E.type="dots",E.output+=A,E.value+=A,I.dots=!0;continue}if($.braces+$.parens===0&&E.type!=="bos"&&E.type!=="slash"){J({type:"text",value:A,output:f});continue}J({type:"dot",value:A,output:f});continue}if(A==="?"){if(!(E&&E.value==="(")&&t.noextglob!==!0&&q()==="("&&q(2)!=="?"){is("qmark",A);continue}if(E&&E.type==="paren"){let z=q(),ne=A;if(z==="<"&&!Se.supportsLookbehinds())throw new Error("Node.js v10 or higher is required for regex lookbehinds");(E.value==="("&&!/[!=<:]/.test(z)||z==="<"&&!/<([!=]|\w+>)/.test(ve()))&&(ne=`\\${A}`),J({type:"text",value:A,output:ne});continue}if(t.dot!==!0&&(E.type==="slash"||E.type==="bos")){J({type:"qmark",value:A,output:y});continue}J({type:"qmark",value:A,output:k});continue}if(A==="!"){if(t.noextglob!==!0&&q()==="("&&(q(2)!=="?"||!/[!=<:]/.test(q(3)))){is("negate",A);continue}if(t.nonegate!==!0&&$.index===0){At();continue}}if(A==="+"){if(t.noextglob!==!0&&q()==="("&&q(2)!=="?"){is("plus",A);continue}if(E&&E.value==="("||t.regex===!1){J({type:"plus",value:A,output:h});continue}if(E&&(E.type==="bracket"||E.type==="paren"||E.type==="brace")||$.parens>0){J({type:"plus",value:A});continue}J({type:"plus",value:h});continue}if(A==="@"){if(t.noextglob!==!0&&q()==="("&&q(2)!=="?"){J({type:"at",extglob:!0,value:A,output:""});continue}J({type:"text",value:A});continue}if(A!=="*"){(A==="$"||A==="^")&&(A=`\\${A}`);let I=cA.exec(ve());I&&(A+=I[0],$.index+=I[0].length),J({type:"text",value:A});continue}if(E&&(E.type==="globstar"||E.star===!0)){E.type="star",E.star=!0,E.value+=A,E.output=D,$.backtrack=!0,$.globstar=!0,X(A);continue}let L=ve();if(t.noextglob!==!0&&/^\([^?]/.test(L)){is("star",A);continue}if(E.type==="star"){if(t.noglobstar===!0){X(A);continue}let I=E.prev,z=I.prev,ne=I.type==="slash"||I.type==="bos",pe=z&&(z.type==="star"||z.type==="globstar");if(t.bash===!0&&(!ne||L[0]&&L[0]!=="/")){J({type:"star",value:A,output:""});continue}let ee=$.braces>0&&(I.type==="comma"||I.type==="brace"),et=M.length&&(I.type==="pipe"||I.type==="paren");if(!ne&&I.type!=="paren"&&!ee&&!et){J({type:"star",value:A,output:""});continue}for(;L.slice(0,3)==="/**";){let tt=n[$.index+4];if(tt&&tt!=="/")break;L=L.slice(3),X("/**",3)}if(I.type==="bos"&&V()){E.type="globstar",E.value+=A,E.output=w(t),$.output=E.output,$.globstar=!0,X(A);continue}if(I.type==="slash"&&I.prev.type!=="bos"&&!pe&&V()){$.output=$.output.slice(0,-(I.output+E.output).length),I.output=`(?:${I.output}`,E.type="globstar",E.output=w(t)+(t.strictSlashes?")":"|$)"),E.value+=A,$.globstar=!0,$.output+=I.output+E.output,X(A);continue}if(I.type==="slash"&&I.prev.type!=="bos"&&L[0]==="/"){let tt=L[1]!==void 0?"|$":"";$.output=$.output.slice(0,-(I.output+E.output).length),I.output=`(?:${I.output}`,E.type="globstar",E.output=`${w(t)}${m}|${m}${tt})`,E.value+=A,$.output+=I.output+E.output,$.globstar=!0,X(A+ue()),J({type:"slash",value:"/",output:""});continue}if(I.type==="bos"&&L[0]==="/"){E.type="globstar",E.value+=A,E.output=`(?:^|${m}|${w(t)}${m})`,$.output=E.output,$.globstar=!0,X(A+ue()),J({type:"slash",value:"/",output:""});continue}$.output=$.output.slice(0,-E.output.length),E.type="globstar",E.output=w(t),E.value+=A,$.output+=E.output,$.globstar=!0,X(A);continue}let ie={type:"star",value:A,output:D};if(t.bash===!0){ie.output=".*?",(E.type==="bos"||E.type==="slash")&&(ie.output=_+ie.output),J(ie);continue}if(E&&(E.type==="bracket"||E.type==="paren")&&t.regex===!0){ie.output=A,J(ie);continue}($.index===$.start||E.type==="slash"||E.type==="dot")&&(E.type==="dot"?($.output+=S,E.output+=S):t.dot===!0?($.output+=C,E.output+=C):($.output+=_,E.output+=_),q()!=="*"&&($.output+=p,E.output+=p)),J(ie)}for(;$.brackets>0;){if(t.strictBrackets===!0)throw new SyntaxError(hn("closing","]"));$.output=Se.escapeLast($.output,"["),_e("brackets")}for(;$.parens>0;){if(t.strictBrackets===!0)throw new SyntaxError(hn("closing",")"));$.output=Se.escapeLast($.output,"("),_e("parens")}for(;$.braces>0;){if(t.strictBrackets===!0)throw new SyntaxError(hn("closing","}"));$.output=Se.escapeLast($.output,"{"),_e("braces")}if(t.strictSlashes!==!0&&(E.type==="star"||E.type==="bracket")&&J({type:"maybe_slash",value:"",output:`${m}?`}),$.backtrack===!0){$.output="";for(let L of $.tokens)$.output+=L.output!=null?L.output:L.value,L.suffix&&($.output+=L.suffix)}return $};Ma.fastpaths=(n,e)=>{let t={...e},s=typeof t.maxLength=="number"?Math.min(fr,t.maxLength):fr,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);n=vh[n]||n;let i=Se.isWindows(e),{DOT_LITERAL:o,SLASH_LITERAL:a,ONE_CHAR:l,DOTS_SLASH:c,NO_DOT:u,NO_DOTS:f,NO_DOTS_SLASH:h,STAR:m,START_ANCHOR:p}=zn.globChars(i),g=t.dot?f:u,x=t.dot?h:u,S=t.capture?"":"?:",C={negated:!1,prefix:""},k=t.bash===!0?".*?":m;t.capture&&(k=`(${k})`);let y=_=>_.noglobstar===!0?k:`(${S}(?:(?!${p}${_.dot?c:o}).)*?)`,v=_=>{switch(_){case"*":return`${g}${l}${k}`;case".*":return`${o}${l}${k}`;case"*.*":return`${g}${k}${o}${l}${k}`;case"*/*":return`${g}${k}${a}${l}${x}${k}`;case"**":return g+y(t);case"**/*":return`(?:${g}${y(t)}${a})?${x}${l}${k}`;case"**/*.*":return`(?:${g}${y(t)}${a})?${x}${k}${o}${l}${k}`;case"**/.*":return`(?:${g}${y(t)}${a})?${o}${l}${k}`;default:{let R=/^(.*?)\.(\w+)$/.exec(_);if(!R)return;let D=v(R[1]);return D?D+o+R[2]:void 0}}},b=Se.removePrefix(n,C),w=v(b);return w&&t.strictSlashes!==!0&&(w+=`${a}?`),w};Sh.exports=Ma});var kh=j(($R,Ah)=>{"use strict";var yA=require("path"),bA=bh(),Ia=_h(),La=dr(),vA=Gn(),wA=n=>n&&typeof n=="object"&&!Array.isArray(n),ce=(n,e,t=!1)=>{if(Array.isArray(n)){let u=n.map(h=>ce(h,e,t));return h=>{for(let m of u){let p=m(h);if(p)return p}return!1}}let s=wA(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=La.isWindows(e),o=s?ce.compileRe(n,e):ce.makeRe(n,e,!1,!0),a=o.state;delete o.state;let l=()=>!1;if(r.ignore){let u={...e,ignore:null,onMatch:null,onResult:null};l=ce(r.ignore,u,t)}let c=(u,f=!1)=>{let{isMatch:h,match:m,output:p}=ce.test(u,o,e,{glob:n,posix:i}),g={glob:n,state:a,regex:o,posix:i,input:u,output:p,match:m,isMatch:h};return typeof r.onResult=="function"&&r.onResult(g),h===!1?(g.isMatch=!1,f?g:!1):l(u)?(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&&(c.state=a),c};ce.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?La.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=ce.matchBase(n,e,t,r):a=e.exec(l)),{isMatch:!!a,match:a,output:l}};ce.matchBase=(n,e,t,s=La.isWindows(t))=>(e instanceof RegExp?e:ce.makeRe(e,t)).test(yA.basename(n));ce.isMatch=(n,e,t)=>ce(e,t)(n);ce.parse=(n,e)=>Array.isArray(n)?n.map(t=>ce.parse(t,e)):Ia(n,{...e,fastpaths:!1});ce.scan=(n,e)=>bA(n,e);ce.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=ce.toRegex(a,e);return s===!0&&(l.state=n),l};ce.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=Ia.fastpaths(n,e)),r.output||(r=Ia(n,e)),ce.compileRe(r,e,t,s)};ce.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/$^/}};ce.constants=vA;Ah.exports=ce});var Da=j((CR,$h)=>{"use strict";$h.exports=kh()});var Ih=j((ER,Mh)=>{"use strict";var Jn=require("fs"),{Readable:xA}=require("stream"),Yn=require("path"),{promisify:gr}=require("util"),Fa=Da(),SA=gr(Jn.readdir),_A=gr(Jn.stat),Ch=gr(Jn.lstat),AA=gr(Jn.realpath),kA="!",Oh="READDIRP_RECURSIVE_ERROR",$A=new Set(["ENOENT","EPERM","EACCES","ELOOP",Oh]),Na="files",Ph="directories",hr="files_directories",pr="all",Eh=[Na,Ph,hr,pr],CA=n=>$A.has(n.code),[Th,EA]=process.versions.node.split(".").slice(0,2).map(n=>Number.parseInt(n,10)),TA=process.platform==="win32"&&(Th>10||Th===10&&EA>=5),Rh=n=>{if(n!==void 0){if(typeof n=="function")return n;if(typeof n=="string"){let e=Fa(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)===kA?t.push(Fa(r.slice(1))):e.push(Fa(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))}}},mr=class n extends xA{static get defaultOptions(){return{root:".",fileFilter:e=>!0,directoryFilter:e=>!0,type:Na,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=Rh(t.fileFilter),this._directoryFilter=Rh(t.directoryFilter);let i=t.lstat?Ch:_A;TA?this._stat=o=>i(o,{bigint:!0}):this._stat=i,this._maxDepth=t.depth,this._wantsDir=[Ph,hr,pr].includes(r),this._wantsFile=[Na,hr,pr].includes(r),this._wantsEverything=r===pr,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 SA(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){CA(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 AA(s),i=await Ch(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=Oh,this._onError(a)}return"directory"}}catch(r){this._onError(r)}}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}},mn=(n,e={})=>{let t=e.entryType||e.type;if(t==="both"&&(t=hr),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&&!Eh.includes(t))throw new Error(`readdirp: Invalid type passed. Use one of ${Eh.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return e.root=n,new mr(e)},RA=(n,e={})=>new Promise((t,s)=>{let r=[];mn(n,e).on("data",i=>r.push(i)).on("end",()=>t(r)).on("error",i=>s(i))});mn.promise=RA;mn.ReaddirpStream=mr;mn.default=mn;Mh.exports=mn});var ja=j((TR,Lh)=>{Lh.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 Bh=j((jh,Hh)=>{"use strict";Object.defineProperty(jh,"__esModule",{value:!0});var Nh=Da(),OA=ja(),Dh="!",PA={returnIndex:!1},MA=n=>Array.isArray(n)?n:[n],IA=(n,e)=>{if(typeof n=="function")return n;if(typeof n=="string"){let t=Nh(n,e);return s=>n===s||t(s)}return n instanceof RegExp?t=>n.test(t):t=>!1},Fh=(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=OA(i,!1);for(let l=0;l<e.length;l++){let c=e[l];if(c(o))return s?-1:!1}let a=r&&[o].concat(t.slice(1));for(let l=0;l<n.length;l++){let c=n[l];if(r?c(...a):c(o))return s?l:!0}return s?-1:!1},Ha=(n,e,t=PA)=>{if(n==null)throw new TypeError("anymatch: specify first argument");let s=typeof t=="boolean"?{returnIndex:t}:t,r=s.returnIndex||!1,i=MA(n),o=i.filter(l=>typeof l=="string"&&l.charAt(0)===Dh).map(l=>l.slice(1)).map(l=>Nh(l,s)),a=i.filter(l=>typeof l!="string"||typeof l=="string"&&l.charAt(0)!==Dh).map(l=>IA(l,s));return e==null?(l,c=!1)=>Fh(a,o,l,typeof c=="boolean"?c:!1):Fh(a,o,e,r)};Ha.default=Ha;Hh.exports=Ha});var qh=j((RR,Uh)=>{Uh.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 Ba=j((OR,Wh)=>{var LA=qh(),Kh={"{":"}","(":")","[":"]"},DA=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=Kh[a];if(l){var c=n.indexOf(l,e);c!==-1&&(e=c+1)}if(n[e]==="!")return!0}else e++}return!1},FA=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=Kh[t];if(s){var r=n.indexOf(s,e);r!==-1&&(e=r+1)}if(n[e]==="!")return!0}else e++}return!1};Wh.exports=function(e,t){if(typeof e!="string"||e==="")return!1;if(LA(e))return!0;var s=DA;return t&&t.strict===!1&&(s=FA),s(e)}});var Vh=j((PR,Gh)=>{"use strict";var NA=Ba(),jA=require("path").posix.dirname,HA=require("os").platform()==="win32",Ua="/",BA=/\\/g,UA=/[\{\[].*[\}\]]$/,qA=/(^|[^\\])([\{\[]|\([^\)]+$)/,KA=/\\([\!\*\?\|\[\]\(\)\{\}])/g;Gh.exports=function(e,t){var s=Object.assign({flipBackslashes:!0},t);s.flipBackslashes&&HA&&e.indexOf(Ua)<0&&(e=e.replace(BA,Ua)),UA.test(e)&&(e+=Ua),e+="a";do e=jA(e);while(NA(e)||qA.test(e));return e.replace(KA,"$1")}});var yr=j(Be=>{"use strict";Be.isInteger=n=>typeof n=="number"?Number.isInteger(n):typeof n=="string"&&n.trim()!==""?Number.isInteger(Number(n)):!1;Be.find=(n,e)=>n.nodes.find(t=>t.type===e);Be.exceedsLimit=(n,e,t=1,s)=>s===!1||!Be.isInteger(n)||!Be.isInteger(e)?!1:(Number(e)-Number(n))/Number(t)>=s;Be.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)};Be.encloseBrace=n=>n.type!=="brace"?!1:n.commas>>0+n.ranges>>0===0?(n.invalid=!0,!0):!1;Be.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;Be.isOpenOrClose=n=>n.type==="open"||n.type==="close"?!0:n.open===!0||n.close===!0;Be.reduce=n=>n.reduce((e,t)=>(t.type==="text"&&e.push(t.value),t.type==="range"&&(t.type="text"),e),[]);Be.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 br=j((IR,Yh)=>{"use strict";var zh=yr();Yh.exports=(n,e={})=>{let t=(s,r={})=>{let i=e.escapeInvalid&&zh.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a="";if(s.value)return(i||o)&&zh.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 Xh=j((LR,Jh)=>{"use strict";Jh.exports=function(n){return typeof n=="number"?n-n===0:typeof n=="string"&&n.trim()!==""?Number.isFinite?Number.isFinite(+n):isFinite(+n):!1}});var om=j((DR,im)=>{"use strict";var Qh=Xh(),Vt=(n,e,t)=>{if(Qh(n)===!1)throw new TypeError("toRegexRange: expected the first argument to be a number");if(e===void 0||n===e)return String(n);if(Qh(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(Vt.cache.hasOwnProperty(l))return Vt.cache[l].result;let c=Math.min(n,e),u=Math.max(n,e);if(Math.abs(c-u)===1){let g=n+"|"+e;return s.capture?`(${g})`:s.wrap===!1?g:`(?:${g})`}let f=rm(n)||rm(e),h={min:n,max:e,a:c,b:u},m=[],p=[];if(f&&(h.isPadded=f,h.maxLen=String(h.max).length),c<0){let g=u<0?Math.abs(u):1;p=Zh(g,Math.abs(c),h,s),c=h.a=0}return u>=0&&(m=Zh(c,u,h,s)),h.negatives=p,h.positives=m,h.result=WA(p,m,s),s.capture===!0?h.result=`(${h.result})`:s.wrap!==!1&&m.length+p.length>1&&(h.result=`(?:${h.result})`),Vt.cache[l]=h,h.result};function WA(n,e,t){let s=qa(n,e,"-",!1,t)||[],r=qa(e,n,"",!1,t)||[],i=qa(n,e,"-?",!0,t)||[];return s.concat(i).concat(r).join("|")}function GA(n,e){let t=1,s=1,r=tm(n,t),i=new Set([e]);for(;n<=r&&r<=e;)i.add(r),t+=1,r=tm(n,t);for(r=nm(e+1,s)-1;n<r&&r<=e;)i.add(r),s+=1,r=nm(e+1,s)-1;return i=[...i],i.sort(YA),i}function VA(n,e,t){if(n===e)return{pattern:n,count:[],digits:0};let s=zA(n,e),r=s.length,i="",o=0;for(let a=0;a<r;a++){let[l,c]=s[a];l===c?i+=l:l!=="0"||c!=="9"?i+=JA(l,c,t):o++}return o&&(i+=t.shorthand===!0?"\\d":"[0-9]"),{pattern:i,count:[o],digits:r}}function Zh(n,e,t,s){let r=GA(n,e),i=[],o=n,a;for(let l=0;l<r.length;l++){let c=r[l],u=VA(String(o),String(c),s),f="";if(!t.isPadded&&a&&a.pattern===u.pattern){a.count.length>1&&a.count.pop(),a.count.push(u.count[0]),a.string=a.pattern+sm(a.count),o=c+1;continue}t.isPadded&&(f=XA(c,t,s)),u.string=f+u.pattern+sm(u.count),i.push(u),o=c+1,a=u}return i}function qa(n,e,t,s,r){let i=[];for(let o of n){let{string:a}=o;!s&&!em(e,"string",a)&&i.push(t+a),s&&em(e,"string",a)&&i.push(t+a)}return i}function zA(n,e){let t=[];for(let s=0;s<n.length;s++)t.push([n[s],e[s]]);return t}function YA(n,e){return n>e?1:e>n?-1:0}function em(n,e,t){return n.some(s=>s[e]===t)}function tm(n,e){return Number(String(n).slice(0,-e)+"9".repeat(e))}function nm(n,e){return n-n%Math.pow(10,e)}function sm(n){let[e=0,t=""]=n;return t||e>1?`{${e+(t?","+t:"")}}`:""}function JA(n,e,t){return`[${n}${e-n===1?"":"-"}${e}]`}function rm(n){return/^-?(0+)\d/.test(n)}function XA(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}}`}}Vt.cache={};Vt.clearCache=()=>Vt.cache={};im.exports=Vt});var Ga=j((FR,pm)=>{"use strict";var QA=require("util"),lm=om(),am=n=>n!==null&&typeof n=="object"&&!Array.isArray(n),ZA=n=>e=>n===!0?Number(e):String(e),Ka=n=>typeof n=="number"||typeof n=="string"&&n!=="",Xn=n=>Number.isInteger(+n),Wa=n=>{let e=`${n}`,t=-1;if(e[0]==="-"&&(e=e.slice(1)),e==="0")return!1;for(;e[++t]==="0";);return t>0},ek=(n,e,t)=>typeof n=="string"||typeof e=="string"?!0:t.stringify===!0,tk=(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},wr=(n,e)=>{let t=n[0]==="-"?"-":"";for(t&&(n=n.slice(1),e--);n.length<e;)n="0"+n;return t?"-"+n:n},nk=(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=>wr(String(a),t)).join("|")),n.negatives.length&&(i=`-(${s}${n.negatives.map(a=>wr(String(a),t)).join("|")})`),r&&i?o=`${r}|${i}`:o=r||i,e.wrap?`(${s}${o})`:o},cm=(n,e,t,s)=>{if(t)return lm(n,e,{wrap:!1,...s});let r=String.fromCharCode(n);if(n===e)return r;let i=String.fromCharCode(e);return`[${r}-${i}]`},um=(n,e,t)=>{if(Array.isArray(n)){let s=t.wrap===!0,r=t.capture?"":"?:";return s?`(${r}${n.join("|")})`:n.join("|")}return lm(n,e,t)},dm=(...n)=>new RangeError("Invalid range arguments: "+QA.inspect(...n)),fm=(n,e,t)=>{if(t.strictRanges===!0)throw dm([n,e]);return[]},sk=(n,e)=>{if(e.strictRanges===!0)throw new TypeError(`Expected step "${n}" to be a number`);return[]},rk=(n,e,t=1,s={})=>{let r=Number(n),i=Number(e);if(!Number.isInteger(r)||!Number.isInteger(i)){if(s.strictRanges===!0)throw dm([n,e]);return[]}r===0&&(r=0),i===0&&(i=0);let o=r>i,a=String(n),l=String(e),c=String(t);t=Math.max(Math.abs(t),1);let u=Wa(a)||Wa(l)||Wa(c),f=u?Math.max(a.length,l.length,c.length):0,h=u===!1&&ek(n,e,s)===!1,m=s.transform||ZA(h);if(s.toRegex&&t===1)return cm(wr(n,f),wr(e,f),!0,s);let p={negatives:[],positives:[]},g=C=>p[C<0?"negatives":"positives"].push(Math.abs(C)),x=[],S=0;for(;o?r>=i:r<=i;)s.toRegex===!0&&t>1?g(r):x.push(tk(m(r,S),f,h)),r=o?r-t:r+t,S++;return s.toRegex===!0?t>1?nk(p,s,f):um(x,null,{wrap:!1,...s}):x},ik=(n,e,t=1,s={})=>{if(!Xn(n)&&n.length>1||!Xn(e)&&e.length>1)return fm(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),c=Math.max(i,o);if(s.toRegex&&t===1)return cm(l,c,!1,s);let u=[],f=0;for(;a?i>=o:i<=o;)u.push(r(i,f)),i=a?i-t:i+t,f++;return s.toRegex===!0?um(u,null,{wrap:!1,options:s}):u},vr=(n,e,t,s={})=>{if(e==null&&Ka(n))return[n];if(!Ka(n)||!Ka(e))return fm(n,e,s);if(typeof t=="function")return vr(n,e,1,{transform:t});if(am(t))return vr(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)?rk(n,e,t,r):ik(n,e,Math.max(Math.abs(t),1),r):t!=null&&!am(t)?sk(t,r):vr(n,e,1,t)};pm.exports=vr});var gm=j((NR,mm)=>{"use strict";var ok=Ga(),hm=yr(),ak=(n,e={})=>{let t=(s,r={})=>{let i=hm.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a=i===!0||o===!0,l=e.escapeInvalid===!0?"\\":"",c="";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 u=hm.reduce(s.nodes),f=ok(...u,{...e,wrap:!1,toRegex:!0,strictZeros:!0});if(f.length!==0)return u.length>1&&f.length>1?`(${f})`:f}if(s.nodes)for(let u of s.nodes)c+=t(u,s);return c};return t(n)};mm.exports=ak});var vm=j((jR,bm)=>{"use strict";var lk=Ga(),ym=br(),gn=yr(),zt=(n="",e="",t=!1)=>{let s=[];if(n=[].concat(n),e=[].concat(e),!e.length)return n;if(!n.length)return t?gn.flatten(e).map(r=>`{${r}}`):e;for(let r of n)if(Array.isArray(r))for(let i of r)s.push(zt(i,e,t));else for(let i of e)t===!0&&typeof i=="string"&&(i=`{${i}}`),s.push(Array.isArray(i)?zt(r,i,t):r+i);return gn.flatten(s)},ck=(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(zt(a.pop(),ym(r,e)));return}if(r.type==="brace"&&r.invalid!==!0&&r.nodes.length===2){a.push(zt(a.pop(),["{}"]));return}if(r.nodes&&r.ranges>0){let f=gn.reduce(r.nodes);if(gn.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=lk(...f,e);h.length===0&&(h=ym(r,e)),a.push(zt(a.pop(),h)),r.nodes=[];return}let l=gn.encloseBrace(r),c=r.queue,u=r;for(;u.type!=="brace"&&u.type!=="root"&&u.parent;)u=u.parent,c=u.queue;for(let f=0;f<r.nodes.length;f++){let h=r.nodes[f];if(h.type==="comma"&&r.type==="brace"){f===1&&c.push(""),c.push("");continue}if(h.type==="close"){a.push(zt(a.pop(),c,l));continue}if(h.value&&h.type!=="open"){c.push(zt(c.pop(),h.value));continue}h.nodes&&s(h,r)}return c};return gn.flatten(s(n))};bm.exports=ck});var xm=j((HR,wm)=>{"use strict";wm.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:`
|
|
922
|
+
`,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 $m=j((BR,km)=>{"use strict";var uk=br(),{MAX_LENGTH:Sm,CHAR_BACKSLASH:Va,CHAR_BACKTICK:dk,CHAR_COMMA:fk,CHAR_DOT:pk,CHAR_LEFT_PARENTHESES:hk,CHAR_RIGHT_PARENTHESES:mk,CHAR_LEFT_CURLY_BRACE:gk,CHAR_RIGHT_CURLY_BRACE:yk,CHAR_LEFT_SQUARE_BRACKET:_m,CHAR_RIGHT_SQUARE_BRACKET:Am,CHAR_DOUBLE_QUOTE:bk,CHAR_SINGLE_QUOTE:vk,CHAR_NO_BREAK_SPACE:wk,CHAR_ZERO_WIDTH_NOBREAK_SPACE:xk}=xm(),Sk=(n,e={})=>{if(typeof n!="string")throw new TypeError("Expected a string");let t=e||{},s=typeof t.maxLength=="number"?Math.min(Sm,t.maxLength):Sm;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,c=n.length,u=0,f=0,h,m=()=>n[u++],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"});u<c;)if(o=i[i.length-1],h=m(),!(h===xk||h===wk)){if(h===Va){p({type:"text",value:(e.keepEscaping?h:"")+m()});continue}if(h===Am){p({type:"text",value:"\\"+h});continue}if(h===_m){l++;let g;for(;u<c&&(g=m());){if(h+=g,g===_m){l++;continue}if(g===Va){h+=m();continue}if(g===Am&&(l--,l===0))break}p({type:"text",value:h});continue}if(h===hk){o=p({type:"paren",nodes:[]}),i.push(o),p({type:"text",value:h});continue}if(h===mk){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===bk||h===vk||h===dk){let g=h,x;for(e.keepQuotes!==!0&&(h="");u<c&&(x=m());){if(x===Va){h+=x+m();continue}if(x===g){e.keepQuotes===!0&&(h+=x);break}h+=x}p({type:"text",value:h});continue}if(h===gk){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===yk){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===fk&&f>0){if(o.ranges>0){o.ranges=0;let g=o.nodes.shift();o.nodes=[g,{type:"text",value:uk(o)}]}p({type:"comma",value:h}),o.commas++;continue}if(h===pk&&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(S=>{S.nodes||(S.type==="open"&&(S.isOpen=!0),S.type==="close"&&(S.isClose=!0),S.nodes||(S.type="text"),S.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};km.exports=Sk});var Tm=j((UR,Em)=>{"use strict";var Cm=br(),_k=gm(),Ak=vm(),kk=$m(),Pe=(n,e={})=>{let t=[];if(Array.isArray(n))for(let s of n){let r=Pe.create(s,e);Array.isArray(r)?t.push(...r):t.push(r)}else t=[].concat(Pe.create(n,e));return e&&e.expand===!0&&e.nodupes===!0&&(t=[...new Set(t)]),t};Pe.parse=(n,e={})=>kk(n,e);Pe.stringify=(n,e={})=>Cm(typeof n=="string"?Pe.parse(n,e):n,e);Pe.compile=(n,e={})=>(typeof n=="string"&&(n=Pe.parse(n,e)),_k(n,e));Pe.expand=(n,e={})=>{typeof n=="string"&&(n=Pe.parse(n,e));let t=Ak(n,e);return e.noempty===!0&&(t=t.filter(Boolean)),e.nodupes===!0&&(t=[...new Set(t)]),t};Pe.create=(n,e={})=>n===""||n.length<3?[n]:e.expand!==!0?Pe.compile(n,e):Pe.expand(n,e);Em.exports=Pe});var Rm=j((qR,$k)=>{$k.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 Pm=j((KR,Om)=>{Om.exports=Rm()});var Im=j((WR,Mm)=>{"use strict";var Ck=require("path"),Ek=Pm(),Tk=new Set(Ek);Mm.exports=n=>Tk.has(Ck.extname(n).slice(1).toLowerCase())});var xr=j(H=>{"use strict";var{sep:Rk}=require("path"),{platform:za}=process,Ok=require("os");H.EV_ALL="all";H.EV_READY="ready";H.EV_ADD="add";H.EV_CHANGE="change";H.EV_ADD_DIR="addDir";H.EV_UNLINK="unlink";H.EV_UNLINK_DIR="unlinkDir";H.EV_RAW="raw";H.EV_ERROR="error";H.STR_DATA="data";H.STR_END="end";H.STR_CLOSE="close";H.FSEVENT_CREATED="created";H.FSEVENT_MODIFIED="modified";H.FSEVENT_DELETED="deleted";H.FSEVENT_MOVED="moved";H.FSEVENT_CLONED="cloned";H.FSEVENT_UNKNOWN="unknown";H.FSEVENT_FLAG_MUST_SCAN_SUBDIRS=1;H.FSEVENT_TYPE_FILE="file";H.FSEVENT_TYPE_DIRECTORY="directory";H.FSEVENT_TYPE_SYMLINK="symlink";H.KEY_LISTENERS="listeners";H.KEY_ERR="errHandlers";H.KEY_RAW="rawEmitters";H.HANDLER_KEYS=[H.KEY_LISTENERS,H.KEY_ERR,H.KEY_RAW];H.DOT_SLASH=`.${Rk}`;H.BACK_SLASH_RE=/\\/g;H.DOUBLE_SLASH_RE=/\/\//;H.SLASH_OR_BACK_SLASH_RE=/[/\\]/;H.DOT_RE=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/;H.REPLACER_RE=/^\.[/\\]/;H.SLASH="/";H.SLASH_SLASH="//";H.BRACE_START="{";H.BANG="!";H.ONE_DOT=".";H.TWO_DOTS="..";H.STAR="*";H.GLOBSTAR="**";H.ROOT_GLOBSTAR="/**/*";H.SLASH_GLOBSTAR="/**";H.DIR_SUFFIX="Dir";H.ANYMATCH_OPTS={dot:!0};H.STRING_TYPE="string";H.FUNCTION_TYPE="function";H.EMPTY_STR="";H.EMPTY_FN=()=>{};H.IDENTITY_FN=n=>n;H.isWindows=za==="win32";H.isMacos=za==="darwin";H.isLinux=za==="linux";H.isIBMi=Ok.type()==="OS400"});var Hm=j((VR,jm)=>{"use strict";var _t=require("fs"),me=require("path"),{promisify:ts}=require("util"),Pk=Im(),{isWindows:Mk,isLinux:Ik,EMPTY_FN:Lk,EMPTY_STR:Dk,KEY_LISTENERS:yn,KEY_ERR:Ya,KEY_RAW:Qn,HANDLER_KEYS:Fk,EV_CHANGE:_r,EV_ADD:Sr,EV_ADD_DIR:Nk,EV_ERROR:Dm,STR_DATA:jk,STR_END:Hk,BRACE_START:Bk,STAR:Uk}=xr(),qk="watch",Kk=ts(_t.open),Fm=ts(_t.stat),Wk=ts(_t.lstat),Gk=ts(_t.close),Ja=ts(_t.realpath),Vk={lstat:Wk,stat:Fm},Qa=(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)},zk=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]},Nm=n=>n instanceof Set?n.size===0:!n,Ar=new Map;function Lm(n,e,t,s,r){let i=(o,a)=>{t(n),r(o,a,{watchedPath:n}),a&&n!==a&&kr(me.resolve(n,a),yn,me.join(n,a))};try{return _t.watch(n,e,i)}catch(o){s(o)}}var kr=(n,e,t,s,r)=>{let i=Ar.get(n);i&&Qa(i[e],o=>{o(t,s,r)})},Yk=(n,e,t,s)=>{let{listener:r,errHandler:i,rawEmitter:o}=s,a=Ar.get(e),l;if(!t.persistent)return l=Lm(n,t,r,i,o),l.close.bind(l);if(a)Zn(a,yn,r),Zn(a,Ya,i),Zn(a,Qn,o);else{if(l=Lm(n,t,kr.bind(null,e,yn),i,kr.bind(null,e,Qn)),!l)return;l.on(Dm,async c=>{let u=kr.bind(null,e,Ya);if(a.watcherUnusable=!0,Mk&&c.code==="EPERM")try{let f=await Kk(n,"r");await Gk(f),u(c)}catch{}else u(c)}),a={listeners:r,errHandlers:i,rawEmitters:o,watcher:l},Ar.set(e,a)}return()=>{es(a,yn,r),es(a,Ya,i),es(a,Qn,o),Nm(a.listeners)&&(a.watcher.close(),Ar.delete(e),Fk.forEach(zk(a)),a.watcher=void 0,Object.freeze(a))}},Xa=new Map,Jk=(n,e,t,s)=>{let{listener:r,rawEmitter:i}=s,o=Xa.get(e),a=new Set,l=new Set,c=o&&o.options;return c&&(c.persistent<t.persistent||c.interval>t.interval)&&(a=o.listeners,l=o.rawEmitters,_t.unwatchFile(e),o=void 0),o?(Zn(o,yn,r),Zn(o,Qn,i)):(o={listeners:r,rawEmitters:i,options:t,watcher:_t.watchFile(e,t,(u,f)=>{Qa(o.rawEmitters,m=>{m(_r,e,{curr:u,prev:f})});let h=u.mtimeMs;(u.size!==f.size||h>f.mtimeMs||h===0)&&Qa(o.listeners,m=>m(n,u))})},Xa.set(e,o)),()=>{es(o,yn,r),es(o,Qn,i),Nm(o.listeners)&&(Xa.delete(e),_t.unwatchFile(e),o.options=o.watcher=void 0,Object.freeze(o))}},Za=class{constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let s=this.fsw.options,r=me.dirname(e),i=me.basename(e);this.fsw._getWatchedDir(r).add(i);let a=me.resolve(e),l={persistent:s.persistent};t||(t=Lk);let c;return s.usePolling?(l.interval=s.enableBinaryInterval&&Pk(i)?s.binaryInterval:s.interval,c=Jk(e,a,l,{listener:t,rawEmitter:this.fsw._emitRaw})):c=Yk(e,a,l,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw}),c}_handleFile(e,t,s){if(this.fsw.closed)return;let r=me.dirname(e),i=me.basename(e),o=this.fsw._getWatchedDir(r),a=t;if(o.has(i))return;let l=async(u,f)=>{if(this.fsw._throttle(qk,e,5)){if(!f||f.mtimeMs===0)try{let h=await Fm(e);if(this.fsw.closed)return;let m=h.atimeMs,p=h.mtimeMs;(!m||m<=p||p!==a.mtimeMs)&&this.fsw._emit(_r,e,h),Ik&&a.ino!==h.ino?(this.fsw._closeFile(u),a=h,this.fsw._addPathCloser(u,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(_r,e,f),a=f}}},c=this._watchWithNodeFs(e,l);if(!(s&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(Sr,e,0))return;this.fsw._emit(Sr,e,t)}return c}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 Ja(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(_r,s,e.stats)):(o.add(r),this.fsw._symlinkPaths.set(i,a),this.fsw._emit(Sr,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=me.join(e,Dk),!s.hasGlob&&(a=this.fsw._throttle("readdir",e,1e3),!a))return;let l=this.fsw._getWatchedDir(s.path),c=new Set,u=this.fsw._readdirp(e,{fileFilter:f=>s.filterPath(f),directoryFilter:f=>s.filterDir(f),depth:0}).on(jk,async f=>{if(this.fsw.closed){u=void 0;return}let h=f.path,m=me.join(e,h);if(c.add(h),!(f.stats.isSymbolicLink()&&await this._handleSymlink(f,e,m,h))){if(this.fsw.closed){u=void 0;return}(h===r||!r&&!l.has(h))&&(this.fsw._incrReadyCount(),m=me.join(i,me.relative(i,m)),this._addToNodeFs(m,t,s,o+1))}}).on(Dm,this._boundHandleError);return new Promise(f=>u.once(Hk,()=>{if(this.fsw.closed){u=void 0;return}let h=a?a.clear():!1;f(),l.getChildren().filter(m=>m!==e&&!c.has(m)&&(!s.hasGlob||s.filterPath({fullPath:me.resolve(e,m)}))).forEach(m=>{this.fsw._remove(e,m)}),u=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(me.dirname(e)),c=l.has(me.basename(e));!(s&&this.fsw.options.ignoreInitial)&&!i&&!c&&(!o.hasGlob||o.globFilter(e))&&this.fsw._emit(Nk,e,t),l.add(me.basename(e)),this.fsw._getWatchedDir(e);let u,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,u),this.fsw.closed))return;f=this._watchWithNodeFs(e,(m,p)=>{p&&p.mtimeMs===0||this._handleRead(m,!1,o,i,e,r,u)})}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 Vk[a.statMethod](a.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(a.watchPath,l))return o(),!1;let c=this.fsw.options.followSymlinks&&!e.includes(Uk)&&!e.includes(Bk),u;if(l.isDirectory()){let f=me.resolve(e),h=c?await Ja(e):e;if(this.fsw.closed||(u=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=c?await Ja(e):e;if(this.fsw.closed)return;let h=me.dirname(a.watchPath);if(this.fsw._getWatchedDir(h).add(a.watchPath),this.fsw._emit(Sr,a.watchPath,l),u=await this._handleDir(h,l,t,r,e,a,f),this.fsw.closed)return;f!==void 0&&this.fsw._symlinkPaths.set(me.resolve(e),f)}else u=this._handleFile(a.watchPath,l,t);return o(),this.fsw._addPathCloser(e,u),!1}catch(l){if(this.fsw._handleError(l))return o(),e}}};jm.exports=Za});var Vm=j((zR,al)=>{"use strict";var il=require("fs"),ge=require("path"),{promisify:ol}=require("util"),bn;try{bn=require("fsevents")}catch(n){process.env.CHOKIDAR_PRINT_FSEVENTS_REQUIRE_ERROR&&console.error(n)}if(bn){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&&(bn=void 0)}}var{EV_ADD:el,EV_CHANGE:Xk,EV_ADD_DIR:Bm,EV_UNLINK:$r,EV_ERROR:Qk,STR_DATA:Zk,STR_END:e0,FSEVENT_CREATED:t0,FSEVENT_MODIFIED:n0,FSEVENT_DELETED:s0,FSEVENT_MOVED:r0,FSEVENT_UNKNOWN:i0,FSEVENT_FLAG_MUST_SCAN_SUBDIRS:o0,FSEVENT_TYPE_FILE:a0,FSEVENT_TYPE_DIRECTORY:ns,FSEVENT_TYPE_SYMLINK:Gm,ROOT_GLOBSTAR:Um,DIR_SUFFIX:l0,DOT_SLASH:qm,FUNCTION_TYPE:tl,EMPTY_FN:c0,IDENTITY_FN:u0}=xr(),d0=n=>isNaN(n)?{}:{depth:n},sl=ol(il.stat),f0=ol(il.lstat),Km=ol(il.realpath),p0={stat:sl,lstat:f0},Yt=new Map,h0=10,m0=new Set([69888,70400,71424,72704,73472,131328,131840,262912]),g0=(n,e)=>({stop:bn.watch(n,e)});function y0(n,e,t,s){let r=ge.extname(e)?ge.dirname(e):e,i=ge.dirname(r),o=Yt.get(r);b0(i)&&(r=i);let a=ge.resolve(n),l=a!==e,c=(f,h,m)=>{l&&(f=f.replace(e,a)),(f===a||!f.indexOf(a+ge.sep))&&t(f,h,m)},u=!1;for(let f of Yt.keys())if(e.indexOf(ge.resolve(f)+ge.sep)===0){r=f,o=Yt.get(r),u=!0;break}return o||u?o.listeners.add(c):(o={listeners:new Set([c]),rawEmitter:s,watcher:g0(r,(f,h)=>{if(!o.listeners.size||h&o0)return;let m=bn.getInfo(f,h);o.listeners.forEach(p=>{p(f,h,m)}),o.rawEmitter(m.event,f,m)})},Yt.set(r,o)),()=>{let f=o.listeners;if(f.delete(c),!f.size&&(Yt.delete(r),o.watcher))return o.watcher.stop().then(()=>{o.rawEmitter=o.watcher=void 0,Object.freeze(o)})}}var b0=n=>{let e=0;for(let t of Yt.keys())if(t.indexOf(n)===0&&(e++,e>=h0))return!0;return!1},v0=()=>bn&&Yt.size<128,nl=(n,e)=>{let t=0;for(;!n.indexOf(e)&&(n=ge.dirname(n))!==e;)t++;return t},Wm=(n,e)=>n.type===ns&&e.isDirectory()||n.type===Gm&&e.isSymbolicLink()||n.type===a0&&e.isFile(),rl=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+Um),!0;s.delete(e),s.delete(e+Um)}addOrChange(e,t,s,r,i,o,a,l){let c=i.has(o)?Xk:el;this.handleEvent(c,e,t,s,r,i,o,a,l)}async checkExists(e,t,s,r,i,o,a,l){try{let c=await sl(e);if(this.fsw.closed)return;Wm(a,c)?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent($r,e,t,s,r,i,o,a,l)}catch(c){c.code==="EACCES"?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent($r,e,t,s,r,i,o,a,l)}}handleEvent(e,t,s,r,i,o,a,l,c){if(!(this.fsw.closed||this.checkIgnored(t)))if(e===$r){let u=l.type===ns;(u||o.has(a))&&this.fsw._remove(i,a,u)}else{if(e===el){if(l.type===ns&&this.fsw._getWatchedDir(t),l.type===Gm&&c.followSymlinks){let f=c.depth===void 0?void 0:nl(s,r)+1;return this._addToFsEvents(t,!1,!0,f)}this.fsw._getWatchedDir(i).add(a)}let u=l.type===ns?e+l0:e;this.fsw._emit(u,t),u===Bm&&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=y0(e,t,async(l,c,u)=>{if(this.fsw.closed||i.depth!==void 0&&nl(l,t)>i.depth)return;let f=s(ge.join(e,ge.relative(e,l)));if(r&&!r(f))return;let h=ge.dirname(f),m=ge.basename(f),p=this.fsw._getWatchedDir(u.type===ns?f:h);if(m0.has(c)||u.event===i0)if(typeof i.ignored===tl){let g;try{g=await sl(f)}catch{}if(this.fsw.closed||this.checkIgnored(f,g))return;Wm(u,g)?this.addOrChange(f,l,t,h,p,m,u,i):this.handleEvent($r,f,l,t,h,p,m,u,i)}else this.checkExists(f,l,t,h,p,m,u,i);else switch(u.event){case t0:case n0:return this.addOrChange(f,l,t,h,p,m,u,i);case s0:case r0:return this.checkExists(f,l,t,h,p,m,u,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 Km(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!==qm?a=o.replace(i,e):o!==qm&&(a=ge.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(ge.dirname(o)),c=ge.basename(o);a&&this.fsw._getWatchedDir(o),!l.has(c)&&(l.add(c),(!r.ignoreInitial||i===!0)&&this.fsw._emit(a?Bm:el,o,t))}initWatch(e,t,s,r){if(this.fsw.closed)return;let i=this._watchWithFsEvents(s.watchPath,ge.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===tl?t:u0,a=this.fsw._getWatchHelpers(e);try{let l=await p0[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:c=>a.filterPath(c),directoryFilter:c=>a.filterDir(c),...d0(i.depth-(r||0))}).on(Zk,c=>{if(this.fsw.closed||c.stats.isDirectory()&&!a.filterPath(c))return;let u=ge.join(a.watchPath,c.path),{fullPath:f}=c;if(a.followSymlinks&&c.stats.isSymbolicLink()){let h=i.depth===void 0?void 0:nl(u,ge.resolve(a.watchPath))+1;this._handleFsEventsSymlink(u,f,o,h)}else this.emitAdd(u,c.stats,o,i,s)}).on(Qk,c0).on(e0,()=>{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===tl)this.initWatch(void 0,e,a,o);else{let l;try{l=await Km(a.watchPath)}catch{}this.initWatch(l,e,a,o)}}};al.exports=rl;al.exports.canUse=v0});var rg=j(Sl=>{"use strict";var{EventEmitter:w0}=require("events"),wl=require("fs"),Z=require("path"),{promisify:eg}=require("util"),x0=Ih(),pl=Bh().default,S0=Vh(),ll=Ba(),_0=Tm(),A0=ja(),k0=Hm(),zm=Vm(),{EV_ALL:cl,EV_READY:$0,EV_ADD:Cr,EV_CHANGE:ss,EV_UNLINK:Ym,EV_ADD_DIR:C0,EV_UNLINK_DIR:E0,EV_RAW:T0,EV_ERROR:ul,STR_CLOSE:R0,STR_END:O0,BACK_SLASH_RE:P0,DOUBLE_SLASH_RE:Jm,SLASH_OR_BACK_SLASH_RE:M0,DOT_RE:I0,REPLACER_RE:L0,SLASH:dl,SLASH_SLASH:D0,BRACE_START:F0,BANG:hl,ONE_DOT:tg,TWO_DOTS:N0,GLOBSTAR:j0,SLASH_GLOBSTAR:fl,ANYMATCH_OPTS:ml,STRING_TYPE:xl,FUNCTION_TYPE:H0,EMPTY_STR:gl,EMPTY_FN:B0,isWindows:U0,isMacos:q0,isIBMi:K0}=xr(),W0=eg(wl.stat),G0=eg(wl.readdir),yl=(n=[])=>Array.isArray(n)?n:[n],ng=(n,e=[])=>(n.forEach(t=>{Array.isArray(t)?ng(t,e):e.push(t)}),e),Xm=n=>{let e=ng(yl(n));if(!e.every(t=>typeof t===xl))throw new TypeError(`Non-string provided as watch path: ${e}`);return e.map(sg)},Qm=n=>{let e=n.replace(P0,dl),t=!1;for(e.startsWith(D0)&&(t=!0);e.match(Jm);)e=e.replace(Jm,dl);return t&&(e=dl+e),e},sg=n=>Qm(Z.normalize(Qm(n))),Zm=(n=gl)=>e=>typeof e!==xl?e:sg(Z.isAbsolute(e)?e:Z.join(n,e)),V0=(n,e)=>Z.isAbsolute(n)?n:n.startsWith(hl)?hl+Z.join(e,n.slice(1)):Z.join(e,n),Ze=(n,e)=>n[e]===void 0,bl=class{constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==tg&&e!==N0&&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 G0(s)}catch{this._removeWatcher&&this._removeWatcher(Z.dirname(s),Z.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)}},z0="stat",Y0="lstat",vl=class{constructor(e,t,s,r){this.fsw=r,this.path=e=e.replace(L0,gl),this.watchPath=t,this.fullWatchPath=Z.resolve(t),this.hasGlob=t!==e,e===gl&&(this.hasGlob=!1),this.globSymlink=this.hasGlob&&s?void 0:!1,this.globFilter=this.hasGlob?pl(e,void 0,ml):!1,this.dirParts=this.getDirParts(e),this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=s,this.statMethod=s?z0:Y0}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 Z.join(this.watchPath,Z.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===H0?this.globFilter(s):!0)&&this.fsw._isntIgnored(s,t)&&this.fsw._hasReadPermissions(t)}getDirParts(e){if(!this.hasGlob)return[];let t=[];return(e.includes(F0)?_0.expand(e):[e]).forEach(r=>{t.push(Z.relative(this.watchPath,r).split(M0))}),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===j0&&(s=!0),s||!t[0][o]||pl(i,t[0][o],ml))))}return!this.unmatchedGlob&&this.fsw._isntIgnored(this.entryPath(e),e.stats)}},Er=class extends w0{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,Ze(t,"persistent")&&(t.persistent=!0),Ze(t,"ignoreInitial")&&(t.ignoreInitial=!1),Ze(t,"ignorePermissionErrors")&&(t.ignorePermissionErrors=!1),Ze(t,"interval")&&(t.interval=100),Ze(t,"binaryInterval")&&(t.binaryInterval=300),Ze(t,"disableGlobbing")&&(t.disableGlobbing=!1),t.enableBinaryInterval=t.binaryInterval!==t.interval,Ze(t,"useFsEvents")&&(t.useFsEvents=!t.usePolling),zm.canUse()||(t.useFsEvents=!1),Ze(t,"usePolling")&&!t.useFsEvents&&(t.usePolling=q0),K0&&(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)),Ze(t,"atomic")&&(t.atomic=!t.usePolling&&!t.useFsEvents),t.atomic&&(this._pendingUnlinks=new Map),Ze(t,"followSymlinks")&&(t.followSymlinks=!0),Ze(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=yl(t.ignored));let a=0;this._emitReady=()=>{a++,a>=this._readyCount&&(this._emitReady=B0,this._readyEmitted=!0,process.nextTick(()=>this.emit($0)))},this._emitRaw=(...l)=>this.emit(T0,...l),this._readyEmitted=!1,this.options=t,t.useFsEvents?this._fsEventsHandler=new zm(this):this._nodeFsHandler=new k0(this),Object.freeze(t)}add(e,t,s){let{cwd:r,disableGlobbing:i}=this.options;this.closed=!1;let o=Xm(e);return r&&(o=o.map(a=>{let l=V0(a,r);return i||!ll(a)?l:A0(l)})),o=o.filter(a=>a.startsWith(hl)?(this._ignoredPaths.add(a.slice(1)),!1):(this._ignoredPaths.delete(a),this._ignoredPaths.delete(a+fl),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(Z.dirname(l),Z.basename(t||l))})})),this}unwatch(e){if(this.closed)return this;let t=Xm(e),{cwd:s}=this.options;return t.forEach(r=>{!Z.isAbsolute(r)&&!this._closers.has(r)&&(s&&(r=Z.join(s,r)),r=Z.resolve(r)),this._closePath(r),this._ignoredPaths.add(r),this._watched.has(r)&&this._ignoredPaths.add(r+fl),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?Z.relative(this.options.cwd,s):s;e[r||tg]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(...t),e!==ul&&this.emit(cl,...t)}async _emit(e,t,s,r,i){if(this.closed)return;let o=this.options;U0&&(t=Z.normalize(t)),o.cwd&&(t=Z.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,c;if(l&&(c=this._pendingWrites.get(t)))return c.lastChange=new Date,this;if(o.atomic){if(e===Ym)return this._pendingUnlinks.set(t,a),setTimeout(()=>{this._pendingUnlinks.forEach((u,f)=>{this.emit(...u),this.emit(cl,...u),this._pendingUnlinks.delete(f)})},typeof o.atomic=="number"?o.atomic:100),this;e===Cr&&this._pendingUnlinks.has(t)&&(e=a[0]=ss,this._pendingUnlinks.delete(t))}if(l&&(e===Cr||e===ss)&&this._readyEmitted){let u=(f,h)=>{f?(e=a[0]=ul,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,u),this}if(e===ss&&!this._throttle(ss,t,50))return this;if(o.alwaysStat&&s===void 0&&(e===Cr||e===C0||e===ss)){let u=o.cwd?Z.join(o.cwd,t):t,f;try{f=await W0(u)}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(ul,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 c=r.get(t),u=c?c.count:0;return r.delete(t),clearTimeout(o),c&&clearTimeout(c.timeoutObject),u};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&&!Z.isAbsolute(e)&&(o=Z.join(this.options.cwd,e));let a=new Date,l=c=>{wl.stat(o,(u,f)=>{if(u||!this._pendingWrites.has(e)){u&&u.code!=="ENOENT"&&r(u);return}let h=Number(new Date);c&&f.size!==c.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&&I0.test(e))return!0;if(!this._userIgnored){let{cwd:s}=this.options,r=this.options.ignored,i=r&&r.map(Zm(s)),o=yl(i).filter(l=>typeof l===xl&&!ll(l)).map(l=>l+fl),a=this._getGlobIgnored().map(Zm(s)).concat(i,o);this._userIgnored=pl(a,void 0,ml)}return this._userIgnored([e,t])}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e,t){let s=t||this.options.disableGlobbing||!ll(e)?e:S0(e),r=this.options.followSymlinks;return new vl(e,s,r,this)}_getWatchedDir(e){this._boundRemove||(this._boundRemove=this._remove.bind(this));let t=Z.resolve(e);return this._watched.has(t)||this._watched.set(t,new bl(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=Z.join(e,t),i=Z.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),c=l.has(t);l.remove(t),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let u=r;if(this.options.cwd&&(u=Z.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(u)&&this._pendingWrites.get(u).cancelWait()===Cr)return;this._watched.delete(r),this._watched.delete(i);let f=s?E0:Ym;c&&!this._isIgnored(r)&&this._emit(f,r),this.options.useFsEvents||this._closePath(r)}_closePath(e){this._closeFile(e);let t=Z.dirname(e);this._getWatchedDir(t).remove(Z.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:cl,alwaysStat:!0,lstat:!0,...t},r=x0(e,s);return this._streams.add(r),r.once(R0,()=>{r=void 0}),r.once(O0,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};Sl.FSWatcher=Er;var J0=(n,e)=>{let t=new Er(e);return t.add(n),t};Sl.watch=J0});var lg={};Ee(lg,{CollaborationManager:()=>_l,addTeamMember:()=>Z0,formatTeamConfig:()=>e$,initTeamConfig:()=>Q0,loadTeamConfig:()=>X0,saveTeamConfig:()=>ag});function X0(n){let e=Ue.join(n,".hablas","team.json");if(de.existsSync(e))try{return JSON.parse(de.readFileSync(e,"utf-8"))}catch{return null}return null}function Q0(n,e){let t={name:e,members:[]};return ag(n,t),t}function ag(n,e){let t=Ue.join(n,".hablas","team.json"),s=Ue.dirname(t);de.existsSync(s)||de.mkdirSync(s,{recursive:!0}),de.writeFileSync(t,JSON.stringify(e,null,2),"utf-8")}function Z0(n,e,t){return n.members.push({name:e,email:t}),n}function e$(n){return[`Team: ${n.name}`,"Members:",...n.members.map(t=>` - ${t.name} (${t.email})`)].join(`
|
|
923
|
+
`)}var de,Ue,Tr,ig,og,_l,cg=F(()=>{"use strict";de=O(require("fs")),Ue=O(require("path")),Tr=O(require("os")),ig=O(require("crypto")),og=O(rg());nn();_l=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||Tr.userInfo().username||"developer",this.teamKey=r||"default-team",this.localStatePath=Ue.join(this.workingDir,".hablas","collaboration.json");let i=this.getProjectIdentifier();console.log(`
|
|
924
|
+
${d.muted("[Debug] Project Context:")} ${d.highlight(i)}`),this.projectTeamToken=ig.createHash("sha256").update(`${i}:${this.teamKey}`).digest("hex"),console.log(` ${d.muted("[Debug] Session Fingerprint:")} ${d.muted(this.projectTeamToken.slice(0,16))}...
|
|
925
|
+
`),this.loadSupabaseConfig()}async init(){if(!this.isConfigured)return console.log(` ${d.warning("\u26A0")} ${d.secondary("Supabase is not configured in .env. Collaboration mode operates locally.")}`),!1;let e=Ue.dirname(this.localStatePath);return de.existsSync(e)||de.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 c=0;c<a;c++)try{let u=await fetch(i,{method:t,headers:o,body:s?JSON.stringify(s):void 0,signal:AbortSignal.timeout(1e4)});if(!u.ok){let h=await u.text().catch(()=>"");if(l=new Error(`[Supabase ${u.status}] ${h}`),(u.status>=500||u.status===429)&&c<a-1){await this.delay(400*(c+1));continue}return{ok:!1,data:null}}let f=await u.text();return{ok:!0,data:f?JSON.parse(f):null}}catch(u){if(l=u,c<a-1){await this.delay(400*(c+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};de.writeFileSync(this.localStatePath,JSON.stringify(s,null,2),"utf-8")}getLocalState(){if(de.existsSync(this.localStatePath))try{return JSON.parse(de.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(`
|
|
926
|
+
${d.success("\u2713")} ${d.muted("[Team]")} Cloud sync reconnected \u2014 session restored.
|
|
914
927
|
`),this.announcedOffline=!1),this.consecutiveHeartbeatFailures=0):(this.consecutiveHeartbeatFailures++,this.consecutiveHeartbeatFailures>=4&&!this.announcedOffline&&(console.log(`
|
|
915
|
-
${
|
|
916
|
-
`),this.announcedOffline=!0))}async syncWithCloud(){let e=await this.apiRequest(`hablas_team_sessions?project_team_token=eq.${this.projectTeamToken}`,"GET");if(!e.ok)return!1;let t=e.data||[],s=await this.fetchLocks(),r=await this.fetchUnreadMessages();for(let c of r)this.renderMessageBox(c.sender_name,c.message_content);let i=Date.now(),o=t.filter(c=>{if(c.developer_name===this.username)return!0;let
|
|
917
|
-
${
|
|
918
|
-
`);else{let o=this.knownSessions.get(i.developer_name);i.current_task&&i.current_task!==o&&i.current_task!=="none"&&(this.knownSessions.set(i.developer_name,i.current_task),console.log(` ${
|
|
928
|
+
${d.warning("\u26A0")} ${d.muted("[Team]")} Cloud sync is unreachable \u2014 retrying in the background. Your session is preserved.
|
|
929
|
+
`),this.announcedOffline=!0))}async syncWithCloud(){let e=await this.apiRequest(`hablas_team_sessions?project_team_token=eq.${this.projectTeamToken}`,"GET");if(!e.ok)return!1;let t=e.data||[],s=await this.fetchLocks(),r=await this.fetchUnreadMessages();for(let c of r)this.renderMessageBox(c.sender_name,c.message_content);let i=Date.now(),o=t.filter(c=>{if(c.developer_name===this.username)return!0;let u=new Date(c.last_heartbeat).getTime();return i-u<=n.STALE_MS}),a=this.getLocalState(),l=r.length>0||JSON.stringify(a.sessions?.map(c=>c.developer_name).sort())!==JSON.stringify(o.map(c=>c.developer_name).sort())||JSON.stringify(a.locks?.map(c=>`${c.file_path}:${c.locked_by}`).sort())!==JSON.stringify(s.map(c=>`${c.file_path}:${c.locked_by}`).sort());return this.saveLocalState(o,s),l}startWatcher(){this.watcher=og.default.watch(this.localStatePath,{ignoreInitial:!1,persistent:!0}),this.watcher.on("change",()=>{let e=this.getLocalState();this.processStateChanges(e.sessions,e.locks)})}processStateChanges(e,t){let s=new Set;for(let i of e)if(i.developer_name!==this.username)if(s.add(i.developer_name),!this.knownSessions.has(i.developer_name))this.knownSessions.set(i.developer_name,i.current_task||"none"),console.log(`
|
|
930
|
+
${d.success("\u{1F514}")} ${d.muted("[Live Sync]")} ${d.strong(`@${i.developer_name}`)} has joined the session.
|
|
931
|
+
`);else{let o=this.knownSessions.get(i.developer_name);i.current_task&&i.current_task!==o&&i.current_task!=="none"&&(this.knownSessions.set(i.developer_name,i.current_task),console.log(` ${d.accent("\u27F3")} ${d.muted("[Activity]")} ${d.strong(`@${i.developer_name}`)} is now: "${d.secondary(i.current_task)}"
|
|
919
932
|
`))}for(let i of this.knownSessions.keys())s.has(i)||(this.knownSessions.delete(i),console.log(`
|
|
920
|
-
${
|
|
921
|
-
`));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(` ${
|
|
933
|
+
${d.warning("\u{1F44B}")} ${d.muted("[Live Sync]")} ${d.strong(`@${i}`)} has left the session.
|
|
934
|
+
`));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(` ${d.error("\u{1F512}")} ${d.muted("[File Locked]")} ${d.strong(`@${i.locked_by}`)} locked ${d.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(` ${d.success("\u{1F513}")} ${d.muted("[File Unlocked]")} ${d.strong(`@${o}`)} released lock on ${d.highlight(i)}`)}}renderMessageBox(e,t){let s=Math.min(process.stdout.columns-4,80),r=d.border("\u250C"+"\u2500".repeat(s-2)+"\u2510"),i=d.border("\u2514"+"\u2500".repeat(s-2)+"\u2518"),o=` MESSAGE FROM @${e.toUpperCase()} `,a=Math.max(0,Math.floor((s-2-o.length)/2)),l=d.border("\u2502")+" ".repeat(a)+d.strong(o)+" ".repeat(s-2-o.length-a)+d.border("\u2502"),c=t.replace(/\n/g," "),u=Math.max(0,s-8-c.length),f=d.border("\u2502")+` "${d.secondary(c)}"`+" ".repeat(u)+d.border("\u2502");console.log(`
|
|
922
935
|
`+r),console.log(l),console.log(f),console.log(i+`
|
|
923
|
-
`)}registerCleanups(){this.signalHandler||(this.signalHandler=()=>{this.shutdown()},process.on("SIGTERM",this.signalHandler),process.once("beforeExit",this.signalHandler))}loadSupabaseConfig(){let e=
|
|
924
|
-
`);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=Ke.join(Rr.homedir(),".hablas","config.json");if(ue.existsSync(e))try{let t=JSON.parse(ue.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=Ke.join(this.workingDir,"package.json");if(ue.existsSync(t)){let s=JSON.parse(ue.readFileSync(t,"utf-8"));s.name&&(e=s.name.toLowerCase())}}catch{}return e||(e=Ke.basename(this.workingDir).toLowerCase()),e.replace(/\s+/g,"")}}});var lg={};Re(lg,{createApiServer:()=>ag,startApiServer:()=>q$});function B$(){try{return JSON.parse(ig.readFileSync(og.resolve(__dirname,"..","..","package.json"),"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function ag(n){let e=xt(n),t=K$(n);return rg.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 c=Buffer.concat(l).toString();c&&(o=JSON.parse(c))}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},c=await a.handler(l);i.writeHead(c.status),i.end(JSON.stringify(c.body))}catch(l){e.error({err:l},"API error"),i.writeHead(500),i.end(JSON.stringify({error:"Internal Server Error",message:String(l)}))}})}function K$(n){return[{method:"GET",path:"/api/v1/health",handler:async()=>({status:200,body:{status:"ok",version:U$,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 q$(n){return new Promise((e,t)=>{let s=ag(n);s.on("error",t),s.listen(n.api.port,n.api.host,()=>{e(s)})})}var rg,ig,og,U$,cg=N(()=>{"use strict";rg=O(require("http")),ig=O(require("fs")),og=O(require("path"));ka();U$=B$()});var dg={};Re(dg,{runSetupWizard:()=>V$});function de(n,e){return new Promise(t=>{n.question(e,s=>t(s))})}function G$(){return["nvapi-","qJRIIcL3SbN6s91CK-","gk2DtzlHbUnaYvGJk","AoIohOTcABSY5lll","Kdwfj_fO_b55h"].join("")}async function V$(n){let e=ug.createInterface({input:process.stdin,output:process.stdout});switch(console.log(),console.log(`${Pt}${Le} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${I}`),console.log(`${Pt}${Le} hablas \u2014 Setup Wizard${I}`),console.log(`${K} Configure your AI provider and model${I}`),console.log(`${Pt}${Le} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${I}`),console.log(),console.log(`${Pt} Choose your setup:${I}`),console.log(),console.log(` ${W$}${Pt}1${I}. ${Pt}Hablas Integrated Engine${I} ${at}(instant \u2014 no setup needed)${I}`),console.log(` ${K}Pre-configured cloud AI, ready to use immediately${I}`),console.log(),console.log(` ${Le}${Pt}2${I}. ${Pt}Custom Provider${I} ${K}(bring your own API key)${I}`),console.log(` ${K}Choose from Ollama, OpenAI, Groq, OpenRouter, and more${I}`),console.log(),(await de(e,` ${K}Your choice (1-2):${I} `)).trim()){case"1":{n.provider=It.provider,n.apiUrl=It.apiUrl,n.apiKey=G$(),n.model=It.model,it(n),Ge({name:It.name,apiUrl:It.apiUrl,apiKey:n.apiKey,models:["stepfun-ai/step-3.7-flash","nvidia/llama-3.3-70b-instruct","deepseek-ai/deepseek-r1"],defaultModel:It.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${at} \u2713 Hablas Integrated Engine activated!${I}`),console.log(`${K} Model: ${It.model}${I}`),console.log(`${K} API: ${It.apiUrl}${I}`),console.log(`${K} No API key needed \u2014 everything is pre-configured.${I}`);break}case"2":{switch(console.log(),console.log(`${K} Select your provider:${I}`),console.log(` ${Le}a${I}. Ollama (local, free, private)`),console.log(` ${Le}b${I}. OpenAI API`),console.log(` ${Le}c${I}. Groq (fast, free tier)`),console.log(` ${Le}d${I}. OpenRouter (many models)`),console.log(` ${Le}e${I}. Together AI`),console.log(` ${Le}f${I}. DeepSeek`),console.log(` ${Le}g${I}. Custom OpenAI-compatible API`),console.log(` ${Le}h${I}. NVIDIA NIM (powerful cloud models)`),console.log(),(await de(e,` ${K}Your choice (a-h):${I} `)).trim().toLowerCase()){case"a":{n.provider="ollama";let r=await de(e,` ${K}Ollama host [http://localhost:11434]:${I} `);r.trim()&&(n.ollamaHost=r.trim());let i=await de(e,` ${K}Model [qwen2.5-coder:7b]:${I} `);i.trim()&&(n.model=i.trim()),it(n),console.log(),console.log(`${at} \u2713 Configured for Ollama${I}`),console.log(`${K} Model: ${n.model}${I}`),console.log(`${K} Host: ${n.ollamaHost}${I}`),console.log(`${K} Make sure Ollama is running: ollama serve${I}`);break}case"b":{let r=await de(e,` ${K}OpenAI API Key (sk-...):${I} `);if(!r.trim()){console.log(`${lt} \u26A0 No key provided \u2014 cancelled${I}`);break}let i=await de(e,` ${K}Model [gpt-4o]:${I} `);n.provider="custom",n.apiUrl="https://api.openai.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"gpt-4o",it(n),Ge({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(`${at} \u2713 Configured for OpenAI${I}`),console.log(`${K} Model: ${n.model}${I}`);break}case"c":{let r=await de(e,` ${K}Groq API Key (gsk_...):${I} `);if(!r.trim()){console.log(`${lt} \u26A0 No key provided \u2014 cancelled${I}`);break}let i=await de(e,` ${K}Model [llama-3.3-70b-versatile]:${I} `);n.provider="custom",n.apiUrl="https://api.groq.com/openai/v1",n.apiKey=r.trim(),n.model=i.trim()||"llama-3.3-70b-versatile",it(n),Ge({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(`${at} \u2713 Configured for Groq${I}`),console.log(`${K} Model: ${n.model}${I}`);break}case"d":{let r=await de(e,` ${K}OpenRouter API Key (sk-or-...):${I} `);if(!r.trim()){console.log(`${lt} \u26A0 No key provided \u2014 cancelled${I}`);break}let i=await de(e,` ${K}Model [anthropic/claude-3.5-sonnet]:${I} `);n.provider="custom",n.apiUrl="https://openrouter.ai/api/v1",n.apiKey=r.trim(),n.model=i.trim()||"anthropic/claude-3.5-sonnet",it(n),Ge({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(`${at} \u2713 Configured for OpenRouter${I}`),console.log(`${K} Model: ${n.model}${I}`);break}case"e":{let r=await de(e,` ${K}Together API Key:${I} `);if(!r.trim()){console.log(`${lt} \u26A0 No key provided \u2014 cancelled${I}`);break}let i=await de(e,` ${K}Model [meta-llama/Llama-3.3-70B-Instruct-Turbo]:${I} `);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",it(n),Ge({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(`${at} \u2713 Configured for Together AI${I}`),console.log(`${K} Model: ${n.model}${I}`);break}case"f":{let r=await de(e,` ${K}DeepSeek API Key:${I} `);if(!r.trim()){console.log(`${lt} \u26A0 No key provided \u2014 cancelled${I}`);break}let i=await de(e,` ${K}Model [deepseek-chat]:${I} `);n.provider="custom",n.apiUrl="https://api.deepseek.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"deepseek-chat",it(n),Ge({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(`${at} \u2713 Configured for DeepSeek${I}`),console.log(`${K} Model: ${n.model}${I}`);break}case"g":{let r=await de(e,` ${K}Provider name:${I} `);if(!r.trim()){console.log(`${lt} \u26A0 Cancelled${I}`);break}let i=await de(e,` ${K}API base URL:${I} `);if(!i.trim()){console.log(`${lt} \u26A0 URL is required \u2014 cancelled${I}`);break}let o=await de(e,` ${K}API Key (leave empty if none):${I} `),a=await de(e,` ${K}Default model ID:${I} `);n.provider="custom",n.apiUrl=i.trim(),n.apiKey=o.trim(),n.model=a.trim()||"default",it(n),Ge({name:r.trim(),apiUrl:i.trim(),apiKey:o.trim(),models:[n.model],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${at} \u2713 Configured for ${r.trim()}${I}`),console.log(`${K} URL: ${i.trim()}${I}`),console.log(`${K} Model: ${n.model}${I}`);break}case"h":{let r=await de(e,` ${K}NVIDIA API Key (nvapi-...):${I} `);if(!r.trim()){console.log(`${lt} \u26A0 No key provided \u2014 cancelled${I}`),console.log(`${K} Get your key at: https://build.nvidia.com/${I}`);break}let{NVIDIA_PROVIDER:i}=await Promise.resolve().then(()=>(wn(),jl));console.log(),console.log(`${K} Available NVIDIA models:${I}`),i.models.forEach((c,d)=>{console.log(` ${Le}${d+1}${I}. ${c}`)}),console.log();let o=await de(e,` ${K}Model number [1]:${I} `),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,it(n),Ge({name:"NVIDIA",apiUrl:i.apiUrl,apiKey:r.trim(),models:i.models,defaultModel:l,addedAt:new Date().toISOString()}),console.log(),console.log(`${at} \u2713 Configured for NVIDIA NIM${I}`),console.log(`${K} Model: ${l}${I}`),console.log(`${K} API: ${i.apiUrl}${I}`);break}default:console.log(`${lt} \u26A0 Invalid choice${I}`)}break}default:console.log(`${lt} \u26A0 Invalid choice \u2014 please select 1 or 2${I}`)}console.log(),console.log(`${K} Run 'hablas' to start chatting!${I}`),console.log(),e.close()}var ug,Le,at,lt,K,Pt,I,W$,It,fg=N(()=>{"use strict";ug=O(require("readline"));Sa();Qr();Le="\x1B[36m",at="\x1B[32m",lt="\x1B[33m",K="\x1B[2m",Pt="\x1B[1m",I="\x1B[0m",W$="\x1B[35m";It={provider:"nvidia",apiUrl:"https://integrate.api.nvidia.com/v1",model:"stepfun-ai/step-3.7-flash",name:"Hablas Integrated Engine"}});var Y$={};Re(Y$,{CLI_VERSION:()=>es});module.exports=xg(Y$);var Fl=O(Nl(),1),{program:r0,createCommand:i0,createArgument:o0,createOption:a0,CommanderError:l0,InvalidArgumentError:c0,InvalidOptionArgumentError:u0,Command:Hl,Argument:d0,Option:f0,Help:p0}=Fl.default;gt();Sa();ka();var pg=O(require("fs")),hg=O(require("path"));function z$(){try{let n=hg.resolve(__dirname,"..","package.json");return JSON.parse(pg.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}var es=z$(),te=new Hl;te.name("hablas").description(`hablas CLI v${es} by Abdulmoin Hablas \u2014 Multi-agent AI development system. Local-first via Ollama, NVIDIA NIM, or any OpenAI-compatible API.`).version(es).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");te.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=te.opts(),s=Be({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=xt(s),{runSingleCommand:i}=await Promise.resolve().then(()=>(gt(),Et)),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)});te.command("commit").description("Generate a smart commit message from staged changes").action(async()=>{let n=te.opts(),e=Be({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),t=xt(e),{getGitStatus:s,getDetailedDiff:r,generateCommitPrompt:i}=await Promise.resolve().then(()=>(Xt(),kn)),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),c=i(l,a.staged),{runSingleCommand:d}=await Promise.resolve().then(()=>(gt(),Et));await d(c,e,t)});te.command("pr").description("Generate a PR description from branch commits").option("--base <branch>","Base branch","main").action(async n=>{let e=te.opts(),t=Be({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=xt(t),{getGitStatus:r,getRecentCommits:i,generatePRPrompt:o}=await Promise.resolve().then(()=>(Xt(),kn)),a=t.workingDirectory||process.cwd(),l=await r(a),c=await i(a,20),d=o(c,n.base,l?.branch||"feature"),{runSingleCommand:f}=await Promise.resolve().then(()=>(gt(),Et));await f(d,t,s)});te.command("changelog").description("Generate changelog from recent commits").option("--version <ver>","Version number",es).option("-n, --count <n>","Number of commits to include","30").action(async n=>{let e=te.opts(),t=Be({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=xt(t),{getRecentCommits:r,generateChangelogPrompt:i}=await Promise.resolve().then(()=>(Xt(),kn)),o=t.workingDirectory||process.cwd(),a=await r(o,parseInt(n.count)),l=i(a,n.version),{runSingleCommand:c}=await Promise.resolve().then(()=>(gt(),Et));await c(l,t,s)});te.command("security").description("Run security scan on the project").option("--fix","Auto-fix issues where possible").action(async n=>{let e=te.opts(),t=Be({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(()=>(xi(),Sc)),i=t.workingDirectory||process.cwd();console.log(`
|
|
936
|
+
`)}registerCleanups(){this.signalHandler||(this.signalHandler=()=>{this.shutdown()},process.on("SIGTERM",this.signalHandler),process.once("beforeExit",this.signalHandler))}loadSupabaseConfig(){let e=Ue.join(this.workingDir,".env");if(de.existsSync(e))try{let s=de.readFileSync(e,"utf-8").split(`
|
|
937
|
+
`);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=Ue.join(Tr.homedir(),".hablas","config.json");if(de.existsSync(e))try{let t=JSON.parse(de.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=Ue.join(this.workingDir,"package.json");if(de.existsSync(t)){let s=JSON.parse(de.readFileSync(t,"utf-8"));s.name&&(e=s.name.toLowerCase())}}catch{}return e||(e=Ue.basename(this.workingDir).toLowerCase()),e.replace(/\s+/g,"")}}});var hg={};Ee(hg,{createApiServer:()=>pg,startApiServer:()=>r$});function t$(){try{return JSON.parse(dg.readFileSync(fg.resolve(__dirname,"..","..","package.json"),"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function pg(n){let e=xt(n),t=s$(n);return ug.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 u of r)l.push(u);let c=Buffer.concat(l).toString();c&&(o=JSON.parse(c))}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},c=await a.handler(l);i.writeHead(c.status),i.end(JSON.stringify(c.body))}catch(l){e.error({err:l},"API error"),i.writeHead(500),i.end(JSON.stringify({error:"Internal Server Error",message:String(l)}))}})}function s$(n){return[{method:"GET",path:"/api/v1/health",handler:async()=>({status:200,body:{status:"ok",version:n$,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 r$(n){return new Promise((e,t)=>{let s=pg(n);s.on("error",t),s.listen(n.api.port,n.api.host,()=>{e(s)})})}var ug,dg,fg,n$,mg=F(()=>{"use strict";ug=O(require("http")),dg=O(require("fs")),fg=O(require("path"));Aa();n$=t$()});var yg={};Ee(yg,{runSetupWizard:()=>a$});function fe(n,e){return new Promise(t=>{n.question(e,s=>t(s))})}function o$(){return["nvapi-","qJRIIcL3SbN6s91CK-","gk2DtzlHbUnaYvGJk","AoIohOTcABSY5lll","Kdwfj_fO_b55h"].join("")}async function a$(n){let e=gg.createInterface({input:process.stdin,output:process.stdout});switch(console.log(),console.log(`${Lt}${Me} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${P}`),console.log(`${Lt}${Me} hablas \u2014 Setup Wizard${P}`),console.log(`${K} Configure your AI provider and model${P}`),console.log(`${Lt}${Me} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${P}`),console.log(),console.log(`${Lt} Choose your setup:${P}`),console.log(),console.log(` ${i$}${Lt}1${P}. ${Lt}Hablas Integrated Engine${P} ${lt}(instant \u2014 no setup needed)${P}`),console.log(` ${K}Pre-configured cloud AI, ready to use immediately${P}`),console.log(),console.log(` ${Me}${Lt}2${P}. ${Lt}Custom Provider${P} ${K}(bring your own API key)${P}`),console.log(` ${K}Choose from Ollama, OpenAI, Groq, OpenRouter, and more${P}`),console.log(),(await fe(e,` ${K}Your choice (1-2):${P} `)).trim()){case"1":{n.provider=Dt.provider,n.apiUrl=Dt.apiUrl,n.apiKey=o$(),n.model=Dt.model,ot(n),We({name:Dt.name,apiUrl:Dt.apiUrl,apiKey:n.apiKey,models:["stepfun-ai/step-3.7-flash","nvidia/llama-3.3-70b-instruct","deepseek-ai/deepseek-r1"],defaultModel:Dt.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${lt} \u2713 Hablas Integrated Engine activated!${P}`),console.log(`${K} Model: ${Dt.model}${P}`),console.log(`${K} API: ${Dt.apiUrl}${P}`),console.log(`${K} No API key needed \u2014 everything is pre-configured.${P}`);break}case"2":{switch(console.log(),console.log(`${K} Select your provider:${P}`),console.log(` ${Me}a${P}. Ollama (local, free, private)`),console.log(` ${Me}b${P}. OpenAI API`),console.log(` ${Me}c${P}. Groq (fast, free tier)`),console.log(` ${Me}d${P}. OpenRouter (many models)`),console.log(` ${Me}e${P}. Together AI`),console.log(` ${Me}f${P}. DeepSeek`),console.log(` ${Me}g${P}. Custom OpenAI-compatible API`),console.log(` ${Me}h${P}. NVIDIA NIM (powerful cloud models)`),console.log(),(await fe(e,` ${K}Your choice (a-h):${P} `)).trim().toLowerCase()){case"a":{n.provider="ollama";let r=await fe(e,` ${K}Ollama host [http://localhost:11434]:${P} `);r.trim()&&(n.ollamaHost=r.trim());let i=await fe(e,` ${K}Model [qwen2.5-coder:7b]:${P} `);i.trim()&&(n.model=i.trim()),ot(n),console.log(),console.log(`${lt} \u2713 Configured for Ollama${P}`),console.log(`${K} Model: ${n.model}${P}`),console.log(`${K} Host: ${n.ollamaHost}${P}`),console.log(`${K} Make sure Ollama is running: ollama serve${P}`);break}case"b":{let r=await fe(e,` ${K}OpenAI API Key (sk-...):${P} `);if(!r.trim()){console.log(`${ct} \u26A0 No key provided \u2014 cancelled${P}`);break}let i=await fe(e,` ${K}Model [gpt-4o]:${P} `);n.provider="custom",n.apiUrl="https://api.openai.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"gpt-4o",ot(n),We({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(`${lt} \u2713 Configured for OpenAI${P}`),console.log(`${K} Model: ${n.model}${P}`);break}case"c":{let r=await fe(e,` ${K}Groq API Key (gsk_...):${P} `);if(!r.trim()){console.log(`${ct} \u26A0 No key provided \u2014 cancelled${P}`);break}let i=await fe(e,` ${K}Model [llama-3.3-70b-versatile]:${P} `);n.provider="custom",n.apiUrl="https://api.groq.com/openai/v1",n.apiKey=r.trim(),n.model=i.trim()||"llama-3.3-70b-versatile",ot(n),We({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(`${lt} \u2713 Configured for Groq${P}`),console.log(`${K} Model: ${n.model}${P}`);break}case"d":{let r=await fe(e,` ${K}OpenRouter API Key (sk-or-...):${P} `);if(!r.trim()){console.log(`${ct} \u26A0 No key provided \u2014 cancelled${P}`);break}let i=await fe(e,` ${K}Model [anthropic/claude-3.5-sonnet]:${P} `);n.provider="custom",n.apiUrl="https://openrouter.ai/api/v1",n.apiKey=r.trim(),n.model=i.trim()||"anthropic/claude-3.5-sonnet",ot(n),We({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(`${lt} \u2713 Configured for OpenRouter${P}`),console.log(`${K} Model: ${n.model}${P}`);break}case"e":{let r=await fe(e,` ${K}Together API Key:${P} `);if(!r.trim()){console.log(`${ct} \u26A0 No key provided \u2014 cancelled${P}`);break}let i=await fe(e,` ${K}Model [meta-llama/Llama-3.3-70B-Instruct-Turbo]:${P} `);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",ot(n),We({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(`${lt} \u2713 Configured for Together AI${P}`),console.log(`${K} Model: ${n.model}${P}`);break}case"f":{let r=await fe(e,` ${K}DeepSeek API Key:${P} `);if(!r.trim()){console.log(`${ct} \u26A0 No key provided \u2014 cancelled${P}`);break}let i=await fe(e,` ${K}Model [deepseek-chat]:${P} `);n.provider="custom",n.apiUrl="https://api.deepseek.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"deepseek-chat",ot(n),We({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(`${lt} \u2713 Configured for DeepSeek${P}`),console.log(`${K} Model: ${n.model}${P}`);break}case"g":{let r=await fe(e,` ${K}Provider name:${P} `);if(!r.trim()){console.log(`${ct} \u26A0 Cancelled${P}`);break}let i=await fe(e,` ${K}API base URL:${P} `);if(!i.trim()){console.log(`${ct} \u26A0 URL is required \u2014 cancelled${P}`);break}let o=await fe(e,` ${K}API Key (leave empty if none):${P} `),a=await fe(e,` ${K}Default model ID:${P} `);n.provider="custom",n.apiUrl=i.trim(),n.apiKey=o.trim(),n.model=a.trim()||"default",ot(n),We({name:r.trim(),apiUrl:i.trim(),apiKey:o.trim(),models:[n.model],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${lt} \u2713 Configured for ${r.trim()}${P}`),console.log(`${K} URL: ${i.trim()}${P}`),console.log(`${K} Model: ${n.model}${P}`);break}case"h":{let r=await fe(e,` ${K}NVIDIA API Key (nvapi-...):${P} `);if(!r.trim()){console.log(`${ct} \u26A0 No key provided \u2014 cancelled${P}`),console.log(`${K} Get your key at: https://build.nvidia.com/${P}`);break}let{NVIDIA_PROVIDER:i}=await Promise.resolve().then(()=>(xn(),jl));console.log(),console.log(`${K} Available NVIDIA models:${P}`),i.models.forEach((c,u)=>{console.log(` ${Me}${u+1}${P}. ${c}`)}),console.log();let o=await fe(e,` ${K}Model number [1]:${P} `),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,ot(n),We({name:"NVIDIA",apiUrl:i.apiUrl,apiKey:r.trim(),models:i.models,defaultModel:l,addedAt:new Date().toISOString()}),console.log(),console.log(`${lt} \u2713 Configured for NVIDIA NIM${P}`),console.log(`${K} Model: ${l}${P}`),console.log(`${K} API: ${i.apiUrl}${P}`);break}default:console.log(`${ct} \u26A0 Invalid choice${P}`)}break}default:console.log(`${ct} \u26A0 Invalid choice \u2014 please select 1 or 2${P}`)}console.log(),console.log(`${K} Run 'hablas' to start chatting!${P}`),console.log(),e.close()}var gg,Me,lt,ct,K,Lt,P,i$,Dt,bg=F(()=>{"use strict";gg=O(require("readline"));xa();Jr();Me="\x1B[36m",lt="\x1B[32m",ct="\x1B[33m",K="\x1B[2m",Lt="\x1B[1m",P="\x1B[0m",i$="\x1B[35m";Dt={provider:"nvidia",apiUrl:"https://integrate.api.nvidia.com/v1",model:"stepfun-ai/step-3.7-flash",name:"Hablas Integrated Engine"}});var c$={};Ee(c$,{CLI_VERSION:()=>rs});module.exports=Cg(c$);var Fl=O(Dl(),1),{program:b$,createCommand:v$,createArgument:w$,createOption:x$,CommanderError:S$,InvalidArgumentError:_$,InvalidOptionArgumentError:A$,Command:Nl,Argument:k$,Option:$$,Help:C$}=Fl.default;gt();xa();Aa();var vg=O(require("fs")),wg=O(require("path"));function l$(){try{let n=wg.resolve(__dirname,"..","package.json");return JSON.parse(vg.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}var rs=l$(),te=new Nl;te.name("hablas").description(`hablas CLI v${rs} by Abdulmoin Hablas \u2014 Multi-agent AI development system. Local-first via Ollama, NVIDIA NIM, or any OpenAI-compatible API.`).version(rs).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");te.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=te.opts(),s=He({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=xt(s),{runSingleCommand:i}=await Promise.resolve().then(()=>(gt(),Et)),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)});te.command("commit").description("Generate a smart commit message from staged changes").action(async()=>{let n=te.opts(),e=He({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),t=xt(e),{getGitStatus:s,getDetailedDiff:r,generateCommitPrompt:i}=await Promise.resolve().then(()=>(en(),$n)),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),c=i(l,a.staged),{runSingleCommand:u}=await Promise.resolve().then(()=>(gt(),Et));await u(c,e,t)});te.command("pr").description("Generate a PR description from branch commits").option("--base <branch>","Base branch","main").action(async n=>{let e=te.opts(),t=He({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=xt(t),{getGitStatus:r,getRecentCommits:i,generatePRPrompt:o}=await Promise.resolve().then(()=>(en(),$n)),a=t.workingDirectory||process.cwd(),l=await r(a),c=await i(a,20),u=o(c,n.base,l?.branch||"feature"),{runSingleCommand:f}=await Promise.resolve().then(()=>(gt(),Et));await f(u,t,s)});te.command("changelog").description("Generate changelog from recent commits").option("--version <ver>","Version number",rs).option("-n, --count <n>","Number of commits to include","30").action(async n=>{let e=te.opts(),t=He({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=xt(t),{getRecentCommits:r,generateChangelogPrompt:i}=await Promise.resolve().then(()=>(en(),$n)),o=t.workingDirectory||process.cwd(),a=await r(o,parseInt(n.count)),l=i(a,n.version),{runSingleCommand:c}=await Promise.resolve().then(()=>(gt(),Et));await c(l,t,s)});te.command("security").description("Run security scan on the project").option("--fix","Auto-fix issues where possible").action(async n=>{let e=te.opts(),t=He({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(()=>(xi(),wc)),i=t.workingDirectory||process.cwd();console.log(`
|
|
925
938
|
\u{1F512} Running security scan...
|
|
926
|
-
`);let o=s(i);console.log(r(o))});te.command("stats").description("Show developer analytics and usage statistics").action(async()=>{let{loadStats:n,formatStats:e}=await Promise.resolve().then(()=>(
|
|
939
|
+
`);let o=s(i);console.log(r(o))});te.command("stats").description("Show developer analytics and usage statistics").action(async()=>{let{loadStats:n,formatStats:e}=await Promise.resolve().then(()=>(kn(),bi)),t=n();console.log(e(t))});te.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=te.opts(),t=He({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(()=>(cg(),lg)),l=t.workingDirectory||process.cwd();if(n.init)r(l,n.init),console.log(`
|
|
927
940
|
\u2713 Team "${n.init}" initialized.`),console.log(` Config saved to: .hablas/team.json
|
|
928
|
-
`);else if(n.add){let c=s(l);if(!c){console.log(" \u26A0 No team config found. Run `hablas team --init <name>` first.");return}let
|
|
941
|
+
`);else if(n.add){let c=s(l);if(!c){console.log(" \u26A0 No team config found. Run `hablas team --init <name>` first.");return}let u=i(c,n.add.split("@")[0],n.add);o(l,u),console.log(` \u2713 Added ${n.add} to team.`)}else{let c=s(l);if(!c){console.log(" No team config found. Run `hablas team --init <name>` to create one.");return}console.log(a(c))}});te.command("info").description("Show workspace information and detected configuration").action(async()=>{let n=te.opts(),e=He({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(()=>(Ai(),Cc)),r=e.workingDirectory||process.cwd();console.log(`
|
|
929
942
|
\u25C6 Workspace Information
|
|
930
|
-
`);let i=t(r);console.log(s(i)),console.log("")});te.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=te.opts(),t=
|
|
931
|
-
\u25C6 Hablas API Server v${
|
|
943
|
+
`);let i=t(r);console.log(s(i)),console.log("")});te.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=te.opts(),t=He({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(()=>(mg(),hg));console.log(`
|
|
944
|
+
\u25C6 Hablas API Server v${rs}`),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(`
|
|
932
945
|
Press Ctrl+C to stop.
|
|
933
|
-
`)}catch(r){console.error(` \u2717 Failed to start API server: ${r}`)}});te.command("run <prompt>").description("Run a single command non-interactively").action(async n=>{let e=te.opts(),t=
|
|
946
|
+
`)}catch(r){console.error(` \u2717 Failed to start API server: ${r}`)}});te.command("run <prompt>").description("Run a single command non-interactively").action(async n=>{let e=te.opts(),t=He({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=xt(t),{runSingleCommand:r}=await Promise.resolve().then(()=>(gt(),Et));await r(n,t,s)});te.command("doctor").description("Run system diagnostics").action(async()=>{let n=te.opts(),e=He({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(()=>(ai(),uc)),r=await t({ollamaHost:e.ollamaHost,model:e.model,provider:e.provider,apiUrl:e.apiUrl});console.log(s(r))});te.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(()=>(si(),ac));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(`
|
|
934
947
|
\u{1F50D} Searching marketplace for "${n.search}"...`),console.log(" (Marketplace: https://registry.hablas.dev/plugins)"),console.log(`
|
|
935
948
|
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(`
|
|
936
949
|
Install: hablas plugins --install <name>
|
|
@@ -940,7 +953,7 @@ ${d.output}`}).join(`
|
|
|
940
953
|
\u25C6 Installed Plugins
|
|
941
954
|
`),console.log(s()),console.log(`
|
|
942
955
|
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>
|
|
943
|
-
`))});te.action(async()=>{let n=te.opts(),e=
|
|
956
|
+
`))});te.action(async()=>{let n=te.opts(),e=He({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(()=>(bg(),yg));await s(e);return}let t=xt(e);await ba(e,t)});te.parse();0&&(module.exports={CLI_VERSION});
|
|
944
957
|
/*! Bundled license information:
|
|
945
958
|
|
|
946
959
|
normalize-path/index.js:
|